Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(English) Documentation Gives Wrong Instructions for Rule Creation #24

Open
XLTechie opened this issue Feb 29, 2024 · 1 comment
Open

Comments

@XLTechie
Copy link

XLTechie commented Feb 29, 2024

Add-on version: 2024.02.08
NVDA: 2024.1beta10
Firefox: 123.0

This seemed to be a very interesting add-on, and I was looking forward to trying it. However, in following the English documentation for first time use, I find that the instructions do not work in the interface.
Even doing what I think the instructions want but that isn't written there, the add-on itself doesn't work. See step 9 below for that part.

The instructions say to:

  1. Create a module. This works.
  2. Create a rule, by entering the name in the General section of the New rule option. This works.
  3. Technical notes is not mentioned as a field, but that's probably okay.
  4. In General, after entering the name, are we supposed to press OK, Apply, or not press any button? The Readme doesn't specify, so I assume neither should be pressed.
  5. In switching to the Criteria category, is where the trouble begins. If you don't press the new button, there is an "Alternatives unknown" control. But that is fine, because the instructions instruct to press New.
  6. When pressing New, we are immediately taken back to General, with the rule name we entered before erased. We must now enter a new rule name, starting over from the beginning.
  7. In addition, the categories change from "General", "Criteria", "Actions", and "Properties". Instead, they become "General", "Criteria", and "Overrides". None of that is documented.
  8. After entering the alternate rule name in General (or is this an inner rule?), we can then go to Criteria, and select options.
  9. After choosing some Criteria--for example to move to the link title of an issue on a GitHub issues page--then choosing OK, then choosing a keyboard shortcut and maybe some other options, the OK/Apply buttons result in an error, and the dialog will not close.
ERROR - unhandled exception (06:09:12.595) - MainThread (1848):
Traceback (most recent call last):
  File "gui\settingsDialogs.pyc", line 735, in onApply
  File "C:\Users\luke\AppData\Roaming\nvda\addons\webAccess\globalPlugins\webAccess\gui\ruleEditor.py", line 943, in _doSave
    super(RuleEditorDialog, self)._doSave()
  File "gui\settingsDialogs.pyc", line 715, in _doSave
  File "gui\settingsDialogs.pyc", line 703, in _validateAllPanels
  File "C:\Users\luke\AppData\Roaming\nvda\addons\webAccess\globalPlugins\webAccess\gui\ruleEditor.py", line 286, in isValid
    if rule is not None and rule.name is not self.context.get("rule").name:
                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
AttributeError: 'NoneType' object has no attribute 'name'

I can generate a more methodical and complete log if you can't easily reproduce this.

So this process seems convoluted and unnecessarily obscure. Why do we have to enter a rule name, switch to Criteria, press New, then start back at General and enter a rule name again? What happened to the first rule name we entered? Are there now two rules with similar (or the same?) names? Or is this a sub-rule inside the outer rule?

Obviously these instructions have not been updated, because they don't mention the "Technical Notes" fields, which appear in several places (twice in the second "General", for example), and there are fields such as "Help (Markdown)" in the module creation step, that are also not documented.

@AAClause
Copy link
Member

AAClause commented Mar 3, 2024

Indeed, the documentation must be updated and there are several bugs.
Meanwhile, you can take a look at issue #7 for more info on rule editor. Most things are still relevant. However, we had to change some things. For instance, maintaining compatibility with older versions of NVDA is no longer a consideration.

JulienCochuyt added a commit that referenced this issue Jul 29, 2024
 * Minor capitalization tweek on the dialog title
JulienCochuyt added a commit that referenced this issue Aug 31, 2024
Implement Overridden Properties and Actions for Criteria #21

 - Bump format version to 0.9-dev
 - Bump API version to 0.5
 - Alternative criteria sets now hold properties and actions
 - `Rule` and `Criteria` properties are now managed through their `properties` attribute
 - GUI: Rule Editor: New tree category selector:
    - Category nodes may have sub-nodes for fast editing of common fields
    - Pressing `space` on a sub-node toggles the field value (or focuses the field, depending on its type)
    - Pressing `delete` on a sub-node reverts the field value to its default
 - GUI: Fix several scaling issues
 - GUI: Drop support for older wxPython that was required for NVDA < 2018.3
 - GUI: Rules Manager: Migrate use of deprecated `wx.TreeCtrl.[Get|Set]ItemPyData`
 - GUI: Criteria Editor: Rename the Criteria Set name field for easier UI discovery (#24)
 - Python 3: Replace lengthy Python 2 `super` calls


* Refactor `TreeContextualPanel` and fix field labelling in "One Input" panel

 * Extract generic part and move it in `gui.__init__.py`
 * Rename specific part to `gui.ruleEditor.RuleEditorTreeContextualPanel`
 * Use dataclasses for `CategoryParams`
 * Remove value from the "One Input" field label
 * Fix some labels not being translatable

* RuleEditor: PropertiesPanel: WIP on fixing the rendering of the edit controls

 * Free text fields still misbehave (upcoming properties spec refactoring)
 * Edit control still not shown if only one property is supported for the rule type
 * Re-arranged buttons on the CriteriaEditor PropertiesPanel

* fix update tree refresh when criterion deleted or created

* Utils: `guarded` decorator: Add doc and forward decorated func's doc and name

* RulesManager: Guard wx event handlers

* GUI: Do not store a Result in context pretending it's a Rule

Had a hard time figuring this one out, left-over from early prototyping
of multi-criteria. Was my bad, actually.

* GUI: Remove backport of `SettingsPanelAccessible` from NVDA 2021.1

* RuleEditor: Keyboard navigation (#38)

 - `F6`: Switch focus between categories and content panel
 - `control[+shift]+tab`: Cycle through same level categories
 - `alt+{home|end}`: Focus first/last content panel control
 - Guard more wx event handlers

* GUI: Make TreeMultiCategorySettingsDialog "fillable"

Allow content panels to fill the whole available container height.

* GUI: TreeMultiCategorySettingsDialog: Restore original code styling

Aim is to reduce diff when comparing with original code from
NVDA's MultiCategorySettingsDialog

* RuleEditor: Keyboard navigation (#38) - Follow-up

 - `control+enter`: Validate the dialog, independantly of wheither the
   currently focused control handles `enter` in some way

Follow-up of 7ba4e94

* Criteria Editor: Fix Criteria panel systematically exhibiting a horizontal scroll bar

 - Added new `gui.SizeFrugalComboBox` which does not request for additional width
   to accommodate the content of its drop-down.

* Refactor UI and Properties

 - Centralize properties handling in `ruleHandler.properties`
 - Add `utils.logException` decorator to help diagnose issues in property getters
 - Extract rule agnostic portion of `gui.ruleEditor.ChildOneInputPanel` into `gui.SingleFieldEditorPanel`
 - Refactore `gui.shortcutDialog` into `gui.gestureBinding` and fix handling of editing existing gesture bindings
 - Document methods of `gui.ContextualSettingsPanel` and make it abstract
 - Move `gui.ruleEditor` to `gui.rule.editor`
 - Move `gui.rulesManager` to `gui.rule.manager`
 - Rule Editor: Fix updating of tree child nodes upon change
 - Rule Editor: Fix focus move upon change
 - Rule Editor: Fix list selection upon change
 - Rule Editor: Fix rule comment not being saved
 - Rule Editor: Fix handling of alternative deletion
 - Rule Editor: Fix handling of gesture binding deletion

* GUI: GestureBinding: Don't send bare modifiers when capturing input

Avoid triggering eg. Windows "Switch Keyboard Layout" shortcut
when pressing `ctrl+shift`.

* GUI: Actions: Fix broken save operation

Fix-up of 24e005b

* GUI: Editors: Notify errors upon saving

* NodeHandler: Fix mouse move in Python 3

* Criteria Alternatives: Support overriding rule gestures

Follow-up of feb09ce

* Editors: Fix Criteria Summary re. Properties

Fix-up of 24e005b

* Criteria Alternatives: Fix handling of the "multiple" property when overridden

* Properties: Fix "multiple" should not be allowed for zones

Was a dev leftover from the `feature/subModules` branch

* DataRecovery: Refactor modules into their own package

* Bump format version to 0.9-dev

Properties are only stored if they differ from the default value.
Choice properties default to None. Text properties default to the empty string.
These defaults may have been previously stored interchangeably.
A None or empty value in a Criteria Property now overrides a defined value
at Rule level.

* Remove `ruleHandler.ruleTypes.RULE_TYPE_FIELDS`

Superseded by `ruleHandler.properties.PropertySpec.ruleTypes`

* Fix typo

Fix-up of 0585603

* fix: ensure correct setting of formMode in RuleEditorDialog

* fix(webAccess/gui/rule): correct default data type in AlternativesPanel's getData method

* Addressed review action: fixup cbce52e
See #21 (review)

* fix: correct mutation property access in control mutation

* Layers: Restore trigger override naming

This "overrides" key at WebModule level really means
"This WebModule overrides the trigger set and help content
coming from a WebModule with the same key ref on an upper layer
which can be found in another file, usually shipped with an addon."

Not to be confused with overridden Rule properties at
Criteria Alternative level - once called _overrides_ -
despite the ambiguous _layered property_ naming at
WebModule level.

The former informs about what were the original values,
the latter masks original values with new ones.

Fix-up of c8422c6

* GUI: Editors: Fix displaying of custom action names

Fix-up of 24e005b

* Properties: Be more verbose when reporting errors

* DataRecovery: Fix from 0.6-dev to 0.8-dev and from 0.8-dev to 0.9-dev

* DataRecovery: Update batch recovery from 0.6-dev to 0.9-dev (was to 0.8-dev)

* GUI: Avoid mistaking an unintentional ValueError for a meaningful ValidationError

* GUI: Follow-up of NVDA #15121

 - `gui.mainFrame._popupSettingsDialog` is deprecated as of NVDA 2023.2
 - `gui.mainFrame.popupSettingsDialog` is now part of the public API

* GUI: MultiCategory editors: Select the invalid panel's category upon validation failure

* RuleEditor: Remove the apply button

* remove useless condition in onCategroyChange

* fix undefined data in editor onAutoActionChoice

* Fix KeyError in `testCriteria(...)` by adding default to pop method

* Rename module from 'recoverFrom_0_6_to_0_9' to 'from_0_6_to_0_9' in data recovery to fix "TypeError: 'module' object is not callable"

---------

Co-authored-by: Sendhil RANDON <[email protected]>
Co-authored-by: BOUYSSOU Gatien <[email protected]>
Co-authored-by: Julien Cochuyt <[email protected]>
JulienCochuyt added a commit that referenced this issue Aug 31, 2024
Implement Overridden Properties and Actions for Criteria #21

 - Bump addon version to 2024.08.31
 - Bump format version to 0.9-dev
 - Bump API version to 0.5
 - Properties are only stored if they differ from the default value.
   Choice properties default to None. Text properties default to the empty string.
   These defaults may have been previously stored interchangeably.
   A `None` or empty value in a Criteria Property now overrides a defined value
   at Rule level.
 - Remove `ruleHandler.ruleTypes.RULE_TYPE_FIELDS`
   Superseded by `ruleHandler.properties.PropertySpec.ruleTypes`
 - Alternative criteria sets now hold properties and actions
 - Centralize properties handling in `ruleHandler.properties`
 - `Rule` and `Criteria` properties are now managed through their `properties` attribute
 - Zones: Support the "multiple" property
 - Refactore `gui.shortcutDialog` into `gui.gestureBinding` and fix handling of editing existing gesture bindings
 - Refactor `gui.ruleEditor` into `gui.rule.editor`
 - Refactor `gui.rulesManager` into `gui.rule.manager`
 - GUI: Rule Editor: New tree category selector:
    - Category nodes may have sub-nodes for fast editing of common fields
	- Keyboard shortcuts (#38):
      - `space` on a sub-node toggles the field value (or focuses the field, depending on its type)
      - `delete` on a sub-node reverts the field value to its default
	  - `control(+shift)+tab` cycles through categories of same level
      - `alt+{home|end}` focuses first/last content panel control
      - `F6` switches focus between categories and content panel
      - `control+enter` validates the dialog, independantly of wheither the
        currently focused control handles `enter` in some way
 - GUI: Criteria Editor: Rename the Criteria Set name field for easier UI discovery (#24)
 - GUI: Criteria Editor: Fix Criteria panel systematically exhibiting a horizontal scroll bar
 * GUI: GestureBinding: Don't send bare modifiers when capturing input
   Avoid triggering eg. Windows "Switch Keyboard Layout" shortcut
   when pressing `ctrl+shift`.
 - GUI: Avoid mistaking an unintentional `ValueError` for a meaningful `ValidationError`
 - GUI: MultiCategory editors: Select the invalid panel's category upon validation failure
 - Utils: `guarded` decorator: Add doc and forward decorated func's doc and name
 - Utils: Add `logException` decorator to help diagnose issues in property getters
 - GUI: guard more event handlers
 - GUI: Fix several scaling issues
 - GUI: Make `gui.ContextualSettingsPanel` properly support multiple inheritance from subclasses.
 - Document methods of `gui.ContextualSettingsPanel` and make it abstract
 - GUI: Added new `gui.SizeFrugalComboBox` which does not request for additional width
   to accommodate the content of its drop-down
 - GUI: Follow-up of NVDA #15121
    - `gui.mainFrame._popupSettingsDialog` is deprecated as of NVDA 2023.2
    - `gui.mainFrame.popupSettingsDialog` is now part of the public API
 - GUI: Remove backport of `SettingsPanelAccessible` from NVDA 2021.1
 - GUI: Drop support for older wxPython that was required for NVDA < 2018.3
 - GUI: Rules Manager: Migrate use of deprecated `wx.TreeCtrl.[Get|Set]ItemPyData`
 - NodeHandler: Fix mouse move in Python 3
 - Python 3: Replace lengthy Python 2 `super` calls

---------

Co-authored-by: Sendhil RANDON <[email protected]>
Co-authored-by: BOUYSSOU Gatien <[email protected]>
Co-authored-by: Julien Cochuyt <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants