[editor] A couple of small FreeText-related fixes (PR 14976 follow-up)
- Ensure that the modified-warning won't be displayed, when navigating away from the viewer, if the user has added custom Annotations and then *removed all* of them. - Ensure that the *initial* editor-buttons state, i.e. the `toggled`-class, is correctly displayed in the toolbar when then viewer loads. - Tweak the CSS-classes for the editor-buttons, such that they use the correct focus/hover-rules (similar to the sidebar-buttons). - Remove a no longer accurate comment from the `BaseViewer.annotationEditorMode`-setter. - Address a couple of *smaller* outstanding review comments, including some re-formatting changes, from PR 14976.
This commit is contained in:
		
							parent
							
								
									c8ef87197c
								
							
						
					
					
						commit
						51bf928061
					
				| @ -253,6 +253,7 @@ web_fonts_disabled=Web fonts are disabled: unable to use embedded PDF fonts. | |||||||
| # Editor | # Editor | ||||||
| editor_none.title=Disable Annotation Editing | editor_none.title=Disable Annotation Editing | ||||||
| editor_none_label=Disable Editing | editor_none_label=Disable Editing | ||||||
| freetext_default_content=Enter some text… |  | ||||||
| editor_free_text.title=Add FreeText Annotation | editor_free_text.title=Add FreeText Annotation | ||||||
| editor_free_text_label=FreeText Annotation | editor_free_text_label=FreeText Annotation | ||||||
|  | 
 | ||||||
|  | freetext_default_content=Enter some text… | ||||||
|  | |||||||
| @ -69,6 +69,10 @@ class AnnotationStorage { | |||||||
|    */ |    */ | ||||||
|   removeKey(key) { |   removeKey(key) { | ||||||
|     this._storage.delete(key); |     this._storage.delete(key); | ||||||
|  | 
 | ||||||
|  |     if (this._storage.size === 0) { | ||||||
|  |       this.resetModified(); | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   /** |   /** | ||||||
|  | |||||||
| @ -55,7 +55,7 @@ const AnnotationEditorPrefix = "pdfjs_internal_editor_"; | |||||||
| 
 | 
 | ||||||
| const AnnotationEditorType = { | const AnnotationEditorType = { | ||||||
|   NONE: 0, |   NONE: 0, | ||||||
|   FREETEXT: 1, |   FREETEXT: 3, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // Permission flags from Table 22, Section 7.6.3.2 of the PDF specification.
 | // Permission flags from Table 22, Section 7.6.3.2 of the PDF specification.
 | ||||||
|  | |||||||
| @ -85,6 +85,10 @@ const PagesCountLimit = { | |||||||
|   PAUSE_EAGER_PAGE_INIT: 250, |   PAUSE_EAGER_PAGE_INIT: 250, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | function isValidAnnotationEditorMode(mode) { | ||||||
|  |   return Object.values(AnnotationEditorType).includes(mode); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * @typedef {Object} PDFViewerOptions |  * @typedef {Object} PDFViewerOptions | ||||||
|  * @property {HTMLDivElement} container - The container for the viewer element. |  * @property {HTMLDivElement} container - The container for the viewer element. | ||||||
| @ -2122,28 +2126,24 @@ class BaseViewer { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   /** |   /** | ||||||
|    * @param {number} mode - Annotation Editor mode (None, FreeText, Ink, ...) |    * @param {number} mode - AnnotationEditor mode (None, FreeText, Ink, ...) | ||||||
|    */ |    */ | ||||||
|   set annotationEditorMode(mode) { |   set annotationEditorMode(mode) { | ||||||
|     if (!this.#annotationEditorUIManager) { |     if (!this.#annotationEditorUIManager) { | ||||||
|       throw new Error(`The AnnotationEditor is not enabled.`); |       throw new Error(`The AnnotationEditor is not enabled.`); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     if (this.#annotationEditorMode === mode) { |     if (this.#annotationEditorMode === mode) { | ||||||
|       return; |       return; // The AnnotationEditor mode didn't change.
 | ||||||
|     } |     } | ||||||
| 
 |     if (!isValidAnnotationEditorMode(mode)) { | ||||||
|     if (!Object.values(AnnotationEditorType).includes(mode)) { |  | ||||||
|       throw new Error(`Invalid AnnotationEditor mode: ${mode}`); |       throw new Error(`Invalid AnnotationEditor mode: ${mode}`); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     // If the mode is the same as before, it means that this mode is disabled
 |  | ||||||
|     // and consequently the mode is NONE.
 |  | ||||||
|     this.#annotationEditorMode = mode; |     this.#annotationEditorMode = mode; | ||||||
|     this.eventBus.dispatch("annotationeditormodechanged", { |     this.eventBus.dispatch("annotationeditormodechanged", { | ||||||
|       source: this, |       source: this, | ||||||
|       mode, |       mode, | ||||||
|     }); |     }); | ||||||
|  | 
 | ||||||
|     this.#annotationEditorUIManager.updateMode(mode); |     this.#annotationEditorUIManager.updateMode(mode); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -81,6 +81,7 @@ const DEFAULT_L10N_STRINGS = { | |||||||
|   printing_not_ready: "Warning: The PDF is not fully loaded for printing.", |   printing_not_ready: "Warning: The PDF is not fully loaded for printing.", | ||||||
|   web_fonts_disabled: |   web_fonts_disabled: | ||||||
|     "Web fonts are disabled: unable to use embedded PDF fonts.", |     "Web fonts are disabled: unable to use embedded PDF fonts.", | ||||||
|  | 
 | ||||||
|   freetext_default_content: "Enter some text…", |   freetext_default_content: "Enter some text…", | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -45,8 +45,8 @@ const PAGE_NUMBER_LOADING_INDICATOR = "visiblePageIsLoading"; | |||||||
|  * @property {HTMLButtonElement} presentationModeButton - Button to switch to |  * @property {HTMLButtonElement} presentationModeButton - Button to switch to | ||||||
|  *   presentation mode. |  *   presentation mode. | ||||||
|  * @property {HTMLButtonElement} editorNoneButton - Button to disable editing. |  * @property {HTMLButtonElement} editorNoneButton - Button to disable editing. | ||||||
|  * @property {HTMLButtonElement} editorFreeTextButton - Button to switch to Free |  * @property {HTMLButtonElement} editorFreeTextButton - Button to switch to | ||||||
|  *   Text edition. |  *   FreeText editing. | ||||||
|  * @property {HTMLButtonElement} download - Button to download the document. |  * @property {HTMLButtonElement} download - Button to download the document. | ||||||
|  * @property {HTMLAnchorElement} viewBookmark - Button to obtain a bookmark link |  * @property {HTMLAnchorElement} viewBookmark - Button to obtain a bookmark link | ||||||
|  *   to the current location in the document. |  *   to the current location in the document. | ||||||
|  | |||||||
| @ -263,8 +263,8 @@ See https://github.com/adobe-type-tools/cmap-resources | |||||||
|                 <span id="numPages" class="toolbarLabel"></span> |                 <span id="numPages" class="toolbarLabel"></span> | ||||||
|               </div> |               </div> | ||||||
|               <div id="toolbarViewerRight"> |               <div id="toolbarViewerRight"> | ||||||
|                 <div id="editorModeButtons" class="splitToolbarButton hidden" role="radiogroup"> |                 <div id="editorModeButtons" class="splitToolbarButton toggled hidden" role="radiogroup"> | ||||||
|                   <button id="editorNone" class="toolbarButton" title="Disable Annotation Editing" role="radio" aria-checked="false" tabindex="31" data-l10n-id="editor_none"> |                   <button id="editorNone" class="toolbarButton toggled" title="Disable Annotation Editing" role="radio" aria-checked="true" tabindex="31" data-l10n-id="editor_none"> | ||||||
|                     <span data-l10n-id="editor_none_label">Disable Editing</span> |                     <span data-l10n-id="editor_none_label">Disable Editing</span> | ||||||
|                   </button> |                   </button> | ||||||
|                   <button id="editorFreeText" class="toolbarButton" title="Add FreeText Annotation" role="radio" aria-checked="false" tabindex="32" data-l10n-id="editor_free_text"> |                   <button id="editorFreeText" class="toolbarButton" title="Add FreeText Annotation" role="radio" aria-checked="false" tabindex="32" data-l10n-id="editor_free_text"> | ||||||
|  | |||||||
| @ -93,8 +93,8 @@ function getViewerConfiguration() { | |||||||
|           ? document.getElementById("openFile") |           ? document.getElementById("openFile") | ||||||
|           : null, |           : null, | ||||||
|       print: document.getElementById("print"), |       print: document.getElementById("print"), | ||||||
|       editorFreeTextButton: document.getElementById("editorFreeText"), |  | ||||||
|       editorNoneButton: document.getElementById("editorNone"), |       editorNoneButton: document.getElementById("editorNone"), | ||||||
|  |       editorFreeTextButton: document.getElementById("editorFreeText"), | ||||||
|       presentationModeButton: document.getElementById("presentationMode"), |       presentationModeButton: document.getElementById("presentationMode"), | ||||||
|       download: document.getElementById("download"), |       download: document.getElementById("download"), | ||||||
|       viewBookmark: document.getElementById("viewBookmark"), |       viewBookmark: document.getElementById("viewBookmark"), | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user