Merge pull request #20621 from calixteman/bug2013899

Avoid to have to download the model when toggling the button in the alt-text image settings dialog (bug 2013899)
This commit is contained in:
calixteman 2026-02-04 14:12:27 +01:00 committed by GitHub
commit 1e0ba4dfec
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 1 additions and 81 deletions

View File

@ -532,15 +532,6 @@ pdfjs-editor-alt-text-settings-automatic-title = Automatic alt text
pdfjs-editor-alt-text-settings-create-model-button-label = Create alt text automatically pdfjs-editor-alt-text-settings-create-model-button-label = Create alt text automatically
pdfjs-editor-alt-text-settings-create-model-description = Suggests descriptions to help people who cant see the image or when the image doesnt load. pdfjs-editor-alt-text-settings-create-model-description = Suggests descriptions to help people who cant see the image or when the image doesnt load.
# Variables:
# $totalSize (Number) - the total size (in MB) of the AI model.
pdfjs-editor-alt-text-settings-download-model-label = Alt text AI model ({ $totalSize } MB)
pdfjs-editor-alt-text-settings-ai-model-description = Runs locally on your device so your data stays private. Required for automatic alt text.
pdfjs-editor-alt-text-settings-delete-model-button = Delete
pdfjs-editor-alt-text-settings-download-model-button = Download
pdfjs-editor-alt-text-settings-downloading-model-button = Downloading…
pdfjs-editor-alt-text-settings-editor-title = Alt text editor pdfjs-editor-alt-text-settings-editor-title = Alt text editor
pdfjs-editor-alt-text-settings-show-dialog-button-label = Show alt text editor right away when adding an image pdfjs-editor-alt-text-settings-show-dialog-button-label = Show alt text editor right away when adding an image
pdfjs-editor-alt-text-settings-show-dialog-description = Helps you make sure all your images have alt text. pdfjs-editor-alt-text-settings-show-dialog-description = Helps you make sure all your images have alt text.

View File

@ -1390,22 +1390,6 @@
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 12px; gap: 12px;
button {
width: fit-content;
}
&.download {
#deleteModelButton {
display: none;
}
}
&:not(.download) {
#downloadModelButton {
display: none;
}
}
} }
#automaticAltText, #automaticAltText,

View File

@ -522,12 +522,8 @@ class NewAltTextManager {
} }
class ImageAltTextSettings { class ImageAltTextSettings {
#aiModelSettings;
#createModelButton; #createModelButton;
#downloadModelButton;
#dialog; #dialog;
#eventBus; #eventBus;
@ -542,11 +538,8 @@ class ImageAltTextSettings {
{ {
dialog, dialog,
createModelButton, createModelButton,
aiModelSettings,
learnMore, learnMore,
closeButton, closeButton,
deleteModelButton,
downloadModelButton,
showAltTextDialogButton, showAltTextDialogButton,
}, },
overlayManager, overlayManager,
@ -554,9 +547,7 @@ class ImageAltTextSettings {
mlManager mlManager
) { ) {
this.#dialog = dialog; this.#dialog = dialog;
this.#aiModelSettings = aiModelSettings;
this.#createModelButton = createModelButton; this.#createModelButton = createModelButton;
this.#downloadModelButton = downloadModelButton;
this.#showAltTextDialogButton = showAltTextDialogButton; this.#showAltTextDialogButton = showAltTextDialogButton;
this.#overlayManager = overlayManager; this.#overlayManager = overlayManager;
this.#eventBus = eventBus; this.#eventBus = eventBus;
@ -571,6 +562,7 @@ class ImageAltTextSettings {
createModelButton.addEventListener("click", async e => { createModelButton.addEventListener("click", async e => {
const checked = this.#togglePref("enableGuessAltText", e); const checked = this.#togglePref("enableGuessAltText", e);
await (checked ? this.#download(true) : this.#delete(true));
await mlManager.toggleService("altText", checked); await mlManager.toggleService("altText", checked);
this.#reportTelemetry({ this.#reportTelemetry({
type: "stamp", type: "stamp",
@ -588,12 +580,6 @@ class ImageAltTextSettings {
}); });
}); });
deleteModelButton.addEventListener("click", this.#delete.bind(this, true));
downloadModelButton.addEventListener(
"click",
this.#download.bind(this, true)
);
closeButton.addEventListener("click", this.#finish.bind(this)); closeButton.addEventListener("click", this.#finish.bind(this));
learnMore.addEventListener("click", () => { learnMore.addEventListener("click", () => {
@ -627,29 +613,12 @@ class ImageAltTextSettings {
async #download(isFromUI = false) { async #download(isFromUI = false) {
if (isFromUI) { if (isFromUI) {
this.#downloadModelButton.disabled = true;
const span = this.#downloadModelButton.firstElementChild;
span.setAttribute(
"data-l10n-id",
"pdfjs-editor-alt-text-settings-downloading-model-button"
);
await this.#mlManager.downloadModel("altText"); await this.#mlManager.downloadModel("altText");
span.setAttribute(
"data-l10n-id",
"pdfjs-editor-alt-text-settings-download-model-button"
);
this.#createModelButton.disabled = false;
this.#setPref("enableGuessAltText", true); this.#setPref("enableGuessAltText", true);
this.#mlManager.toggleService("altText", true); this.#mlManager.toggleService("altText", true);
this.#setPref("enableAltTextModelDownload", true); this.#setPref("enableAltTextModelDownload", true);
this.#downloadModelButton.disabled = false;
} }
this.#aiModelSettings.classList.toggle("download", false);
this.#createModelButton.setAttribute("aria-pressed", true);
} }
async #delete(isFromUI = false) { async #delete(isFromUI = false) {
@ -659,14 +628,11 @@ class ImageAltTextSettings {
this.#setPref("enableAltTextModelDownload", false); this.#setPref("enableAltTextModelDownload", false);
} }
this.#aiModelSettings.classList.toggle("download", true);
this.#createModelButton.disabled = true;
this.#createModelButton.setAttribute("aria-pressed", false); this.#createModelButton.setAttribute("aria-pressed", false);
} }
async open({ enableGuessAltText, enableNewAltTextWhenAddingImage }) { async open({ enableGuessAltText, enableNewAltTextWhenAddingImage }) {
const { enableAltTextModelDownload } = this.#mlManager; const { enableAltTextModelDownload } = this.#mlManager;
this.#createModelButton.disabled = !enableAltTextModelDownload;
this.#createModelButton.setAttribute( this.#createModelButton.setAttribute(
"aria-pressed", "aria-pressed",
enableAltTextModelDownload && enableGuessAltText enableAltTextModelDownload && enableGuessAltText
@ -675,10 +641,6 @@ class ImageAltTextSettings {
"aria-pressed", "aria-pressed",
enableNewAltTextWhenAddingImage enableNewAltTextWhenAddingImage
); );
this.#aiModelSettings.classList.toggle(
"download",
!enableAltTextModelDownload
);
await this.#overlayManager.open(this.#dialog); await this.#overlayManager.open(this.#dialog);
this.#reportTelemetry({ this.#reportTelemetry({

View File

@ -1059,20 +1059,6 @@ See https://github.com/adobe-type-tools/cmap-resources
></a> ></a>
</div> </div>
</div> </div>
<div id="aiModelSettings">
<div>
<span data-l10n-id="pdfjs-editor-alt-text-settings-download-model-label" data-l10n-args='{ "totalSize": 180 }'></span>
<div id="aiModelDescription" class="description">
<span data-l10n-id="pdfjs-editor-alt-text-settings-ai-model-description"></span>
</div>
</div>
<button id="deleteModelButton" type="button" class="secondaryButton" tabindex="0">
<span data-l10n-id="pdfjs-editor-alt-text-settings-delete-model-button"></span>
</button>
<button id="downloadModelButton" type="button" class="secondaryButton" tabindex="0">
<span data-l10n-id="pdfjs-editor-alt-text-settings-download-model-button"></span>
</button>
</div>
</div> </div>
</div> </div>
<div class="dialogSeparator"></div> <div class="dialogSeparator"></div>

View File

@ -219,10 +219,7 @@ function getViewerConfiguration() {
altTextSettingsDialog: { altTextSettingsDialog: {
dialog: document.getElementById("altTextSettingsDialog"), dialog: document.getElementById("altTextSettingsDialog"),
createModelButton: document.getElementById("createModelButton"), createModelButton: document.getElementById("createModelButton"),
aiModelSettings: document.getElementById("aiModelSettings"),
learnMore: document.getElementById("altTextSettingsLearnMore"), learnMore: document.getElementById("altTextSettingsLearnMore"),
deleteModelButton: document.getElementById("deleteModelButton"),
downloadModelButton: document.getElementById("downloadModelButton"),
showAltTextDialogButton: document.getElementById( showAltTextDialogButton: document.getElementById(
"showAltTextDialogButton" "showAltTextDialogButton"
), ),