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

MS Word documents: report when headings are collapsed in both speech and braille. #17499

Open
wants to merge 8 commits into
base: master
Choose a base branch
from

Conversation

michaelDCurran
Copy link
Member

Link to issue number:

None.

Summary of the issue:

In Microsoft Word, it is possible to collapse a heading, so that all the paragraphs directly following the heading are hidden. As of MS Word 16.0.18226, a new UIA text range custom attribute was added, to convey the expand collapse state of headings. NVDA should report when a heading is collapsed based on this value.

Description of user facing changes

In Microsoft Word, If a heading is collapsed, NVDA will now report this in speech and braille.

Description of development approach

  • When fetching format information for a text range in MS Word via UIA, if the range supports the expand collapse custom attribute, expose the 'collapsed' key on its format field, setting it to true for collapsed, and false for expanded.
  • speech.getFormatfieldSpeech: speak "collapsed" when moving by line or paragraph over text with 'collapsed' set to true in its format field, or if it changes to true when moving by word / character.
  • In Braille, Report a plus (+) sign at the start of text that is collapsed according to its format field.

Testing strategy:

Tested with MS Word 16.0.18331.

  • Open a new document in Microsoft word.
  • Type an initial line of text.
  • Type a second line of text and format it as a heading (press alt+shift+rightArrow)
  • Type another line of text directly below it formatted as a normal paragraph.
  • Arrow up to the heading, noting that the heading is spoken / braille dnormally (I.e. heading level 2 test). No expand / collapse info is reported.
  • Collapse the heading by choosing collapse in the context menu.
  • Arrow up and back down to read the heading. Note that NvDA now reports 'collapsed' in speech and a plus (+) sign in braille.

Known issues with pull request:

None known.

This implementation only reports when a heading is collapsed, and not explicitly when expanded. However, as expanded headings will far outweigh collapsed, I think it would be way too noisy to report expanded, when that is going to be the norm.

Code Review Checklist:

  • Documentation:
    • Change log entry
    • User Documentation
    • Developer / Technical Documentation
    • Context sensitive help for GUI changes
  • Testing:
    • Unit tests
    • System (end to end) tests
    • Manual testing
  • UX of all users considered:
    • Speech
    • Braille
    • Low Vision
    • Different web browsers
    • Localization in other languages / culture than English
  • API is compatible with existing add-ons.
  • Security precautions taken.

@coderabbitai summary

@michaelDCurran michaelDCurran requested a review from a team as a code owner December 11, 2024 01:15
user_docs/en/changes.md Outdated Show resolved Hide resolved
source/NVDAObjects/UIA/wordDocument.py Show resolved Hide resolved
source/braille.py Outdated Show resolved Hide resolved
source/speech/speech.py Outdated Show resolved Hide resolved
@CyrilleB79
Copy link
Collaborator

For the feature to be complete, the following could be added to this PR:

  1. There are still many people using legacy Word object model instead of UIA. When possible, it would be nice to have features developed for both interfaces at the same time. In the specific case, you can use Paragraph.CollapsedState property.

  2. There are shortcuts to collapse or expand headings. My Word is in French, but according to ChatGPT, on English Word, it is alt+shift+plus or alt+shift+-. Could you implement feedback reporting of these actions? If it is already reported automatically in newer Word versions (I have not tested myself), ignore this request of course.

If you prefer have this development merged as is, at least, document these missing points in "Known issues" sections and open new issues to track these missing points. Thanks.

Comment on lines 493 to 501
expandCollapseState = UIARemote.msWord_getCustomAttributeValue(
docElement,
textRange,
UIACustomAttributeID.EXPAND_COLLAPSE_STATE,
)
if expandCollapseState == EXPAND_COLLAPSE_STATE.COLLAPSED:
formatField.field["collapsed"] = True
elif expandCollapseState == EXPAND_COLLAPSE_STATE.EXPANDED:
formatField.field["collapsed"] = False
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I get the following error with an older Word version:
UnboundLocalError: cannot access local variable 'docElement' where it is not associated with a value

You should indent this code to execute it in the "if" branch where docElement is defined.

Suggested change
expandCollapseState = UIARemote.msWord_getCustomAttributeValue(
docElement,
textRange,
UIACustomAttributeID.EXPAND_COLLAPSE_STATE,
)
if expandCollapseState == EXPAND_COLLAPSE_STATE.COLLAPSED:
formatField.field["collapsed"] = True
elif expandCollapseState == EXPAND_COLLAPSE_STATE.EXPANDED:
formatField.field["collapsed"] = False
expandCollapseState = UIARemote.msWord_getCustomAttributeValue(
docElement,
textRange,
UIACustomAttributeID.EXPAND_COLLAPSE_STATE,
)
if expandCollapseState == EXPAND_COLLAPSE_STATE.COLLAPSED:
formatField.field["collapsed"] = True
elif expandCollapseState == EXPAND_COLLAPSE_STATE.EXPANDED:
formatField.field["collapsed"] = False

@michaelDCurran
Copy link
Member Author

@CyrilleB79 I have addressed the docElement issue pre Windows 11, and also exposed collapsed for headings in Word with the object model.
Re shortcuts: you are welcome to open issues for these if you like, but it is out of scope for this particular PR.

nvdaHelper/remote/winword.cpp Outdated Show resolved Hide resolved
source/NVDAObjects/window/winword.py Outdated Show resolved Hide resolved
Comment on lines 1163 to 1164
collapsed = field.get("collapsed")
if collapsed:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why does this need to be assigned to a variable?

Suggested change
collapsed = field.get("collapsed")
if collapsed:
if field.get("collapsed"):

@@ -27,7 +27,7 @@ To use this feature, "allow NVDA to control the volume of other applications" mu
* Automatic language switching is now supported when using Microsoft Speech API version 5 (SAPI5) and Microsoft Speech Platform voices. (#17146, @gexgd0419)
* NVDA can now be configured to speak the current line or paragraph when navigating with braille navigation keys. (#17053, @nvdaes)
* In Word, the selection update is now reported when using Word commands to extend or reduce the selection (`f8` or `shift+f8`). (#3293, @CyrilleB79)
* In Word 16.0.18226 and higher, NVDA will now report if a heading is collapsed in both speech and braille. (#17499)
* In Microsoft Word 16.0.18226 and higher, NVDA will now report if a heading is collapsed in both speech and braille. (#17499)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is the version of Word applicable now that this has been added to the object model too?

user_docs/en/changes.md Outdated Show resolved Hide resolved
@CyrilleB79
Copy link
Collaborator

I have just tested this PR, launching the installer (nvda_snapshot_pr17499-34747,bb1e29a1.exe) and running the temporary version.

  • With UIA always, the feature is not working; maybe it is expected on Windows 10?
  • With Word Object Model (UIA Only when necessary), Word crashes.

I am with:

  • Microsoft® Word 2016 MSO (Version 2410 Build 16.0.18129.20158) 32 bits
  • Windows 10 2004 (AMD64) build 19041.388; note that this is not the last version (I cannot test on last Win 10); may it be the cause of the crash?

@codeofdusk
Copy link
Contributor

@CyrilleB79 This is expected because Windows 10 doesn't have remote ops support in UIA core.

@michaelDCurran
Copy link
Member Author

michaelDCurran commented Dec 15, 2024 via email

@CyrilleB79
Copy link
Collaborator

I have not been able to get a crash dump for Word. I have tried both methods described in NVDA wiki:

  • paragraph Minidumps for Other Applications
  • paragraph Alternative Way to Get Minidumps for Other Applications, actually following MSDN article

In both cases, I cannot get any dumpfile. I have also tried to force a dumpfile, killing winword process from task manager without success, so I am probably doing something wrong when trying to get the dumpfile.

Word crashes, actually disappears, when arrowing in text heading formatted, or when trying to use expand / collapse commands. When I move the caret in normal (body) text, there is no problem.

It would be nice to be able to fix this. @Adriani90 would you be able to reproduce the crash described here with object model (legacy, i.e. "Only when necessary" in advanced settings)?

But if it is not possible to fix the issue with Word Object model, nor reproducible on your side, I understand that you may want to merge the UIA part, what is already an improvement.

@SaschaCowley SaschaCowley added the conceptApproved Similar 'triaged' for issues, PR accepted in theory, implementation needs review. label Dec 17, 2024
@CyrilleB79
Copy link
Collaborator

@michaelDCurran, I have found why it crashes on my end and tested that it does not crash anymore with the fix, running from source.

Strange that you have not experimented this crash; maybe you were not really testing Word object model due to 13704?

@michaelDCurran
Copy link
Member Author

michaelDCurran commented Dec 17, 2024 via email

@CyrilleB79
Copy link
Collaborator

I was definitely testing with the object model. Perhaps you are using 32 bit MS Word and I am using 64 bit, or you have tighter execution / memory policies set in Windows? Either way, I'm glad you found the cause.

Yes, I am running Office 2016 32 bits.

Co-authored-by: Sascha Cowley <[email protected]>
Co-authored-by: Cyrille Bougot <[email protected]>
Copy link
Member

@SaschaCowley SaschaCowley left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you please update the copyright headers of the files modified in this PR?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
conceptApproved Similar 'triaged' for issues, PR accepted in theory, implementation needs review.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants