summaryrefslogtreecommitdiffstats
path: root/browser/components/migration/content
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/migration/content')
-rw-r--r--browser/components/migration/content/migration-wizard.mjs155
1 files changed, 143 insertions, 12 deletions
diff --git a/browser/components/migration/content/migration-wizard.mjs b/browser/components/migration/content/migration-wizard.mjs
index 7643e4bce3..6fc7a715d7 100644
--- a/browser/components/migration/content/migration-wizard.mjs
+++ b/browser/components/migration/content/migration-wizard.mjs
@@ -38,7 +38,7 @@ export class MigrationWizard extends HTMLElement {
<link rel="stylesheet" href="chrome://browser/skin/migration/migration-wizard.css">
<named-deck id="wizard-deck" selected-view="page-loading" aria-busy="true" part="deck">
<div name="page-loading">
- <h1 data-l10n-id="migration-wizard-selection-header" part="header"></h1>
+ <h1 class="migration-wizard-header" data-l10n-id="migration-wizard-selection-header" part="header"></h1>
<div class="loading-block large"></div>
<div class="loading-block small"></div>
<div class="loading-block small"></div>
@@ -46,12 +46,13 @@ export class MigrationWizard extends HTMLElement {
<!-- If possible, use the same button labels as the SELECTION page with the same strings.
That'll prevent flicker when the load state exits if we then enter the SELECTION page. -->
<button class="cancel-close" data-l10n-id="migration-cancel-button-label" disabled></button>
- <button data-l10n-id="migration-import-button-label" disabled></button>
+ <button class="migration-import-button" data-l10n-id="migration-import-button-label" disabled></button>
</moz-button-group>
</div>
<div name="page-selection">
- <h1 data-l10n-id="migration-wizard-selection-header" part="header"></h1>
+ <h1 class="migration-wizard-header" data-l10n-id="migration-wizard-selection-header" part="header"></h1>
+ <p class="migration-wizard-subheader" part="subheader" hidden=""></p>
<button id="browser-profile-selector" aria-haspopup="menu" aria-labelledby="migrator-name profile-name">
<span class="migrator-icon" role="img"></span>
<div class="migrator-description" role="presentation">
@@ -89,22 +90,22 @@ export class MigrationWizard extends HTMLElement {
<label id="select-all">
<input type="checkbox" class="select-all-checkbox"/><span data-l10n-id="migration-select-all-option-label"></span>
</label>
- <label id="bookmarks" data-resource-type="BOOKMARKS"/>
+ <label id="bookmarks" class="resource-type-label" data-resource-type="BOOKMARKS"/>
<input type="checkbox"/><span default-data-l10n-id="migration-bookmarks-option-label" ie-edge-data-l10n-id="migration-favorites-option-label"></span>
</label>
- <label id="logins-and-passwords" data-resource-type="PASSWORDS">
+ <label id="logins-and-passwords" class="resource-type-label" data-resource-type="PASSWORDS">
<input type="checkbox"/><span data-l10n-id="migration-passwords-option-label"></span>
</label>
- <label id="history" data-resource-type="HISTORY">
+ <label id="history" class="resource-type-label" data-resource-type="HISTORY">
<input type="checkbox"/><span data-l10n-id="migration-history-option-label"></span>
</label>
- <label id="extensions" data-resource-type="EXTENSIONS">
+ <label id="extensions" class="resource-type-label" data-resource-type="EXTENSIONS">
<input type="checkbox"/><span data-l10n-id="migration-extensions-option-label"></span>
</label>
- <label id="form-autofill" data-resource-type="FORMDATA">
+ <label id="form-autofill" class="resource-type-label" data-resource-type="FORMDATA">
<input type="checkbox"/><span data-l10n-id="migration-form-autofill-option-label"></span>
</label>
- <label id="payment-methods" data-resource-type="PAYMENT_METHODS">
+ <label id="payment-methods" class="resource-type-label" data-resource-type="PAYMENT_METHODS">
<input type="checkbox"/><span data-l10n-id="migration-payment-methods-option-label"></span>
</label>
</fieldset>
@@ -118,7 +119,7 @@ export class MigrationWizard extends HTMLElement {
<moz-button-group class="buttons" part="buttons">
<button class="cancel-close" data-l10n-id="migration-cancel-button-label"></button>
<button id="import-from-file" class="primary" data-l10n-id="migration-import-from-file-button-label"></button>
- <button id="import" class="primary" data-l10n-id="migration-import-button-label"></button>
+ <button id="import" class="primary migration-import-button" data-l10n-id="migration-import-button-label"></button>
<button id="get-permissions" class="primary" data-l10n-id="migration-continue-button-label"></button>
</moz-button-group>
</div>
@@ -582,6 +583,18 @@ export class MigrationWizard extends HTMLElement {
"div[name='page-selection']"
);
+ if (this.hasAttribute("selection-header-string")) {
+ selectionPage.querySelector(".migration-wizard-header").textContent =
+ this.getAttribute("selection-header-string");
+ }
+
+ let selectionSubheaderString = this.getAttribute(
+ "selection-subheader-string"
+ );
+ let subheader = selectionPage.querySelector(".migration-wizard-subheader");
+ subheader.textContent = selectionSubheaderString;
+ subheader.toggleAttribute("hidden", !selectionSubheaderString);
+
let details = this.#shadowRoot.querySelector("details");
if (this.hasAttribute("force-show-import-all")) {
@@ -596,6 +609,8 @@ export class MigrationWizard extends HTMLElement {
this.#expandedDetails = false;
+ this.#applyContentCustomizations();
+
for (let migrator of state.migrators) {
let opt = document.createElement("panel-item");
opt.setAttribute("key", migrator.key);
@@ -772,6 +787,7 @@ export class MigrationWizard extends HTMLElement {
MigrationWizardConstants.DISPLAYED_RESOURCE_TYPES.EXTENSIONS
) {
messageText.textContent = "";
+ this.#extensionsSuccessLink.target = "_blank";
this.#extensionsSuccessLink.textContent =
state.progress[resourceType].message;
}
@@ -787,6 +803,7 @@ export class MigrationWizard extends HTMLElement {
messageText.textContent = state.progress[resourceType].message;
supportLink.textContent = state.progress[resourceType].linkText;
supportLink.href = state.progress[resourceType].linkURL;
+ supportLink.target = "_blank";
remainingProgressGroups--;
totalWarnings++;
break;
@@ -800,11 +817,13 @@ export class MigrationWizard extends HTMLElement {
messageText.textContent = state.progress[resourceType].message;
supportLink.textContent = state.progress[resourceType].linkText;
supportLink.href = state.progress[resourceType].linkURL;
+ supportLink.target = "_blank";
if (
resourceType ==
MigrationWizardConstants.DISPLAYED_RESOURCE_TYPES.EXTENSIONS
) {
messageText.textContent = "";
+ this.#extensionsSuccessLink.target = "_blank";
this.#extensionsSuccessLink.textContent =
state.progress[resourceType].message;
}
@@ -816,16 +835,20 @@ export class MigrationWizard extends HTMLElement {
let migrationDone = remainingProgressGroups == 0;
let headerL10nID = "migration-wizard-progress-header";
+ let header = this.#shadowRoot.getElementById("progress-header");
if (migrationDone) {
if (totalWarnings) {
headerL10nID = "migration-wizard-progress-done-with-warnings-header";
+ } else if (this.getAttribute("data-import-complete-success-string")) {
+ header.textContent = this.getAttribute(
+ "data-import-complete-success-string"
+ );
} else {
headerL10nID = "migration-wizard-progress-done-header";
}
}
- let header = this.#shadowRoot.getElementById("progress-header");
document.l10n.setAttributes(header, headerL10nID);
let finishButtons = progressPage.querySelectorAll(".finish-button");
@@ -1233,7 +1256,10 @@ export class MigrationWizard extends HTMLElement {
let importButton = this.#shadowRoot.querySelector("#import");
importButton.disabled = checkedResources == 0;
- if (checkedResources == 0) {
+ if (this.hasAttribute("option-expander-title-string")) {
+ let optionString = this.getAttribute("option-expander-title-string");
+ selectedDataHeader.textContent = optionString;
+ } else if (checkedResources == 0) {
document.l10n.setAttributes(
selectedDataHeader,
"migration-no-selected-data-label"
@@ -1260,6 +1286,111 @@ export class MigrationWizard extends HTMLElement {
);
}
+ /**
+ * Updates content and layout to apply changes that are
+ * informed through element attributes
+ */
+ #applyContentCustomizations() {
+ let selectionPage = this.#shadowRoot.querySelector(
+ "div[name='page-selection']"
+ );
+ if (this.hasAttribute("hide-select-all")) {
+ let hideSelectAll = this.getAttribute("hide-select-all");
+
+ selectionPage.toggleAttribute("hide-select-all", hideSelectAll);
+ } else {
+ selectionPage.removeAttribute("hide-select-all");
+ }
+
+ if (this.hasAttribute("import-button-string")) {
+ if (this.getAttribute("import-button-string")) {
+ this.#importButton.textContent = this.getAttribute(
+ "import-button-string"
+ );
+ }
+ }
+
+ if (this.hasAttribute("checkbox-margin-inline")) {
+ let inlineMargin = this.getAttribute("checkbox-margin-inline");
+ this.style.setProperty(
+ "--resource-type-label-margin-inline",
+ inlineMargin
+ );
+ }
+
+ if (this.hasAttribute("checkbox-margin-block")) {
+ let blockMargin = this.getAttribute("checkbox-margin-block");
+ this.style.setProperty("--resource-type-label-margin-block", blockMargin);
+ }
+
+ if (this.hasAttribute("import-button-class")) {
+ let importButtonClass = this.getAttribute("import-button-class");
+ if (importButtonClass) {
+ this.#importButton.classList.add(importButtonClass);
+ }
+ }
+
+ if (this.hasAttribute("header-font-size")) {
+ let headerFontSize = this.getAttribute("header-font-size");
+ if (headerFontSize) {
+ this.style.setProperty(
+ "--embedded-wizard-header-font-size",
+ headerFontSize
+ );
+ }
+ }
+
+ if (this.hasAttribute("header-font-weight")) {
+ let headerFontWeight = this.getAttribute("header-font-weight");
+ if (headerFontWeight) {
+ this.style.setProperty(
+ "--embedded-wizard-header-font-weight",
+ headerFontWeight
+ );
+ }
+ }
+
+ if (this.hasAttribute("header-margin-block")) {
+ let headerMarginBlock = this.getAttribute("header-margin-block");
+ if (headerMarginBlock) {
+ this.style.setProperty(
+ "--embedded-wizard-header-margin-block",
+ headerMarginBlock
+ );
+ }
+ }
+
+ if (this.hasAttribute("subheader-font-size")) {
+ let subheaderFontSize = this.getAttribute("subheader-font-size");
+ if (subheaderFontSize) {
+ this.style.setProperty(
+ "--embedded-wizard-subheader-font-size",
+ subheaderFontSize
+ );
+ }
+ }
+
+ if (this.hasAttribute("subheader-font-weight")) {
+ let subheaderFontWeight = this.getAttribute("subheader-font-weight");
+ if (subheaderFontWeight) {
+ this.style.setProperty(
+ "--embedded-wizard-subheader-font-weight",
+ subheaderFontWeight
+ );
+ }
+ }
+
+ if (this.hasAttribute("subheader-margin-block")) {
+ let subheaderMarginBlock = this.getAttribute("subheader-margin-block");
+ if (subheaderMarginBlock) {
+ this.style.setProperty(
+ "--embedded-wizard-subheader-margin-block",
+ subheaderMarginBlock
+ );
+ }
+ }
+ }
+
handleEvent(event) {
switch (event.type) {
case "click": {