summaryrefslogtreecommitdiffstats
path: root/comm/python/l10n/tb_fluent_migrations
diff options
context:
space:
mode:
Diffstat (limited to 'comm/python/l10n/tb_fluent_migrations')
-rw-r--r--comm/python/l10n/tb_fluent_migrations/__init__.py0
-rw-r--r--comm/python/l10n/tb_fluent_migrations/bug_1827199_multi_message_view.py33
-rw-r--r--comm/python/l10n/tb_fluent_migrations/bug_1831422_backupKeyPassword.py25
-rw-r--r--comm/python/l10n/tb_fluent_migrations/bug_1833042_unfied_toolbar_button_style.py25
-rw-r--r--comm/python/l10n/tb_fluent_migrations/bug_1838109_changeExpiryDlg.py27
-rw-r--r--comm/python/l10n/tb_fluent_migrations/bug_1838770_properties_menu_item.py56
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_ics_file_dialog.py20
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_uri_redirect_dialog.py20
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1731837_delete_commands.py114
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1798509_unified_toolbar_customization.py52
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1803705_thread_pane.py111
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1805746_calendar_view.py29
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1805938_calendar_recurrence_ux.py25
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1806567_quick_filter_bar_migration.py182
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1809312_unified_toolbar_buttons.py218
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1811400_thread_pane_column_picker.py79
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1814393_unified_toolbar_customization_tabs.py36
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1814664_unified_toolbar_calendar_items.py48
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1815489_add_back_forward_and_stop.py33
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1815605_calendar_context_menu_has_empty_items.py52
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1816532_about_dialog_migration.py94
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1816593_flexbox_emulation_dialogs.py21
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1817914_tags_mode.py21
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1817915_get_new_messages.py22
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1820700_select_thread.py35
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1823033_activity_indicator.py23
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1827261_add_enable_disable_compact_mode_options_to_folder_mode_context_menu.py26
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1827891_dnt_prefs_learn_more.py21
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1828340_aboutdialog_layout_fixes.py42
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1830004_folder_quota.py28
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_cal_enable78.py30
-rw-r--r--comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_extensions_to_fluent.py531
32 files changed, 2079 insertions, 0 deletions
diff --git a/comm/python/l10n/tb_fluent_migrations/__init__.py b/comm/python/l10n/tb_fluent_migrations/__init__.py
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/__init__.py
diff --git a/comm/python/l10n/tb_fluent_migrations/bug_1827199_multi_message_view.py b/comm/python/l10n/tb_fluent_migrations/bug_1827199_multi_message_view.py
new file mode 100644
index 0000000000..47cc910b67
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/bug_1827199_multi_message_view.py
@@ -0,0 +1,33 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY_PATTERN
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1827199 - Message summary preview header buttons are not keyboard accessible"""
+
+ target = reference = "mail/locales/en-US/messenger/multimessageview.ftl"
+ ctx.add_transforms(
+ target,
+ reference,
+ transforms_from(
+ """
+multi-message-window-title =
+ .title = {{COPY_PATTERN(from_path, "window.title")}}
+
+selected-messages-label =
+ .label = {{COPY_PATTERN(from_path, "selectedmessages.label")}}
+
+multi-message-archive-button =
+ .label = {{COPY_PATTERN(from_path, "archiveButton.label")}}
+ .tooltiptext = {{COPY_PATTERN(from_path, "archiveButton.label")}}
+
+multi-message-delete-button =
+ .label = {{COPY_PATTERN(from_path, "deleteButton.label")}}
+ .tooltiptext = {{COPY_PATTERN(from_path, "deleteButton.label")}}
+ """,
+ from_path="mail/locales/en-US/chrome/messenger/multimessageview.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/bug_1831422_backupKeyPassword.py b/comm/python/l10n/tb_fluent_migrations/bug_1831422_backupKeyPassword.py
new file mode 100644
index 0000000000..1c86a338a4
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/bug_1831422_backupKeyPassword.py
@@ -0,0 +1,25 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY_PATTERN
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1831422 - migrations in OpenPGP key backup dialog"""
+
+ target = reference = "mail/messenger/openpgp/backupKeyPassword.ftl"
+ ctx.add_transforms(
+ target,
+ reference,
+ transforms_from(
+ """
+set-password-window-title = {{COPY_PATTERN(from_path, "set-password-window.title")}}
+
+set-password-backup-pw-label = {{COPY_PATTERN(from_path, "set-password-backup-pw.value")}}
+
+set-password-backup-pw2-label = {{COPY_PATTERN(from_path, "set-password-repeat-backup-pw.value")}}
+ """,
+ from_path="mail/messenger/openpgp/backupKeyPassword.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/bug_1833042_unfied_toolbar_button_style.py b/comm/python/l10n/tb_fluent_migrations/bug_1833042_unfied_toolbar_button_style.py
new file mode 100644
index 0000000000..108f48474e
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/bug_1833042_unfied_toolbar_button_style.py
@@ -0,0 +1,25 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate.helpers import transforms_from
+from fluent.migrate import COPY_PATTERN
+
+
+def migrate(ctx):
+ """Bug 1833042 - Don't automatically update the button style preference when changed in the unified toolbar customization panel, part {index}."""
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbar.ftl",
+ "mail/messenger/unifiedToolbar.ftl",
+ transforms_from(
+ """
+customize-button-style-icons-beside-text-option = {COPY_PATTERN(from_path, "customize-button-style-icons-beside-text.label")}
+
+customize-button-style-icons-above-text-option = {COPY_PATTERN(from_path, "customize-button-style-icons-above-text.label")}
+
+customize-button-style-icons-only-option = {COPY_PATTERN(from_path, "customize-button-style-icons-only.label")}
+
+customize-button-style-text-only-option = {COPY_PATTERN(from_path, "customize-button-style-text-only.label")}
+ """,
+ from_path="mail/messenger/unifiedToolbar.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/bug_1838109_changeExpiryDlg.py b/comm/python/l10n/tb_fluent_migrations/bug_1838109_changeExpiryDlg.py
new file mode 100644
index 0000000000..68566c4131
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/bug_1838109_changeExpiryDlg.py
@@ -0,0 +1,27 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY_PATTERN
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1838109 - migrate some strings in changeExpiryDlg.xhtml"""
+
+ target = reference = "mail/messenger/openpgp/changeExpiryDlg.ftl"
+ ctx.add_transforms(
+ target,
+ reference,
+ transforms_from(
+ """
+openpgp-change-expiry-title = {{COPY_PATTERN(from_path, "openpgp-change-key-expiry-title.title")}}
+
+expire-no-change-label = {{COPY_PATTERN(from_path, "expire-dont-change.label")}}
+
+expire-in-time-label = {{COPY_PATTERN(from_path, "expire-in-label.label")}}
+
+expire-never-expire-label = {{COPY_PATTERN(from_path, "expire-never-label.label")}}
+ """,
+ from_path="mail/messenger/openpgp/changeExpiryDlg.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/bug_1838770_properties_menu_item.py b/comm/python/l10n/tb_fluent_migrations/bug_1838770_properties_menu_item.py
new file mode 100644
index 0000000000..04e15628b8
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/bug_1838770_properties_menu_item.py
@@ -0,0 +1,56 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY
+
+import fluent.syntax.ast as FTL
+
+
+def migrate(ctx):
+ """Bug 1838770 - Edit > Folder Properties doesn't work, part {index}."""
+ source = "mail/chrome/messenger/messenger.dtd"
+ dest = "mail/messenger/messenger.ftl"
+ ctx.add_transforms(
+ dest,
+ dest,
+ [
+ FTL.Message(
+ id=FTL.Identifier("menu-edit-properties"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"), value=COPY(source, "folderPropsCmd2.label")
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(source, "folderPropsCmd.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("menu-edit-folder-properties"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(source, "folderPropsFolderCmd2.label"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(source, "folderPropsCmd.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("menu-edit-newsgroup-properties"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(source, "folderPropsNewsgroupCmd2.label"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(source, "folderPropsCmd.accesskey"),
+ ),
+ ],
+ ),
+ ],
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_ics_file_dialog.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_ics_file_dialog.py
new file mode 100644
index 0000000000..4e7df08f73
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_ics_file_dialog.py
@@ -0,0 +1,20 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1703164 - convert calendar/base/content/dialogs/calendar-ics-file-dialog.xhtml to html"""
+
+ ctx.add_transforms(
+ "calendar/calendar/calendar-ics-file-dialog.ftl",
+ "calendar/calendar/calendar-ics-file-dialog.ftl",
+ transforms_from(
+ """
+calendar-ics-file-window-title = {{COPY_PATTERN(from_path, "calendar-ics-file-window-2.title")}}
+ """,
+ from_path="calendar/calendar/calendar-ics-file-dialog.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_uri_redirect_dialog.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_uri_redirect_dialog.py
new file mode 100644
index 0000000000..cd4e681da0
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1703164_calendar_uri_redirect_dialog.py
@@ -0,0 +1,20 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1703164 - convert calendar/base/content/dialogs/calendar-uri-redirect-dialog.xhtml to top level html"""
+
+ ctx.add_transforms(
+ "calendar/calendar/calendar-uri-redirect-dialog.ftl",
+ "calendar/calendar/calendar-uri-redirect-dialog.ftl",
+ transforms_from(
+ """
+calendar-uri-redirect-window-title = {{COPY_PATTERN(from_path, "calendar-uri-redirect-window.title")}}
+ """,
+ from_path="calendar/calendar/calendar-uri-redirect-dialog.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1731837_delete_commands.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1731837_delete_commands.py
new file mode 100644
index 0000000000..fc045d1ed6
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1731837_delete_commands.py
@@ -0,0 +1,114 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import re
+
+from fluent.migratetb import COPY, COPY_PATTERN
+from fluent.migratetb.helpers import VARIABLE_REFERENCE
+from fluent.migratetb.transforms import Transform, TransformPattern
+
+import fluent.syntax.ast as FTL
+
+
+def migrate(ctx):
+ """Bug 1731837 - Fix multiple problems with the labelling of Delete commands, part {index}."""
+ source = "mail/chrome/messenger/messenger.dtd"
+ dest = "mail/messenger/messenger.ftl"
+ ctx.add_transforms(
+ dest,
+ dest,
+ [
+ FTL.Message(
+ id=FTL.Identifier("menu-edit-delete-folder"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"), value=COPY(source, "deleteFolderCmd.label")
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(source, "deleteFolderCmd.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("menu-edit-delete-messages"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=Transform.pattern_of(
+ FTL.SelectExpression(
+ selector=VARIABLE_REFERENCE("count"),
+ variants=[
+ FTL.Variant(
+ key=FTL.Identifier("one"),
+ value=COPY(source, "deleteMsgCmd.label"),
+ ),
+ FTL.Variant(
+ key=FTL.Identifier("other"),
+ default=True,
+ value=COPY(source, "deleteMsgsCmd.label"),
+ ),
+ ],
+ )
+ ),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(source, "deleteMsgCmd.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("menu-edit-undelete-messages"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=Transform.pattern_of(
+ FTL.SelectExpression(
+ selector=VARIABLE_REFERENCE("count"),
+ variants=[
+ FTL.Variant(
+ key=FTL.Identifier("one"),
+ value=COPY(source, "undeleteMsgCmd.label"),
+ ),
+ FTL.Variant(
+ key=FTL.Identifier("other"),
+ default=True,
+ value=COPY(source, "undeleteMsgsCmd.label"),
+ ),
+ ],
+ )
+ ),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(source, "undeleteMsgCmd.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("mail-context-undelete-messages"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=Transform.pattern_of(
+ FTL.SelectExpression(
+ selector=VARIABLE_REFERENCE("count"),
+ variants=[
+ FTL.Variant(
+ key=FTL.Identifier("one"),
+ value=COPY(source, "undeleteMsgCmd.label"),
+ ),
+ FTL.Variant(
+ key=FTL.Identifier("other"),
+ default=True,
+ value=COPY(source, "undeleteMsgsCmd.label"),
+ ),
+ ],
+ )
+ ),
+ )
+ ],
+ ),
+ ],
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1798509_unified_toolbar_customization.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1798509_unified_toolbar_customization.py
new file mode 100644
index 0000000000..7ac296ec35
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1798509_unified_toolbar_customization.py
@@ -0,0 +1,52 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1798509 - Unified toolbar customization fluent migration part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbar.ftl",
+ "mail/messenger/unifiedToolbar.ftl",
+ transforms_from(
+ """
+customize-menu-customize =
+ .label = { COPY(from_path, "customizeToolbar.label") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbar.ftl",
+ "mail/messenger/unifiedToolbar.ftl",
+ transforms_from(
+ """
+customize-space-mail = { COPY_PATTERN(from_path, "spaces-toolbar-button-mail2.title") }
+
+customize-space-addressbook = { COPY_PATTERN(from_path, "spaces-toolbar-button-address-book2.title") }
+
+customize-space-calendar = { COPY_PATTERN(from_path, "spaces-toolbar-button-calendar2.title") }
+
+customize-space-tasks = { COPY_PATTERN(from_path, "spaces-toolbar-button-tasks2.title") }
+
+customize-space-chat = { COPY_PATTERN(from_path, "spaces-toolbar-button-chat2.title") }
+
+customize-space-settings = { COPY_PATTERN(from_path, "spaces-toolbar-button-settings2.title") }
+ """,
+ from_path="mail/messenger/messenger.ftl",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbar.ftl",
+ "mail/messenger/unifiedToolbar.ftl",
+ transforms_from(
+ """
+customize-button-style-icons-beside-text =
+ .label = { COPY(from_path, "iconsBesideText.label") }
+ """,
+ from_path="mail/chrome/messenger/customizeToolbar.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1803705_thread_pane.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1803705_thread_pane.py
new file mode 100644
index 0000000000..b3f41b1c5a
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1803705_thread_pane.py
@@ -0,0 +1,111 @@
+# coding=utf8
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate.helpers import transforms_from
+from fluent.migrate import COPY
+
+
+def migrate(ctx):
+ """Bug 1803705 - Migrate thread tree strings to fluent, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/treeView.ftl",
+ "mail/messenger/treeView.ftl",
+ transforms_from(
+ """
+tree-list-view-column-picker =
+ .title = { COPY(from_path, "columnChooser2.tooltip") }
+""",
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
+
+ ctx.add_transforms(
+ "mail/messenger/about3Pane.ftl",
+ "mail/messenger/about3Pane.ftl",
+ transforms_from(
+ """
+threadpane-column-header-select =
+ .title = { COPY(from_path, "selectColumn.tooltip") }
+threadpane-column-label-select =
+ .label = { COPY(from_path, "selectColumn.label") }
+threadpane-column-label-thread =
+ .label = { COPY(from_path, "threadColumn.label") }
+threadpane-column-header-flagged =
+ .title = { COPY(from_path, "starredColumn2.tooltip") }
+threadpane-column-label-flagged =
+ .label = { COPY(from_path, "starredColumn.label") }
+threadpane-column-header-attachments =
+ .title = { COPY(from_path, "attachmentColumn2.tooltip") }
+threadpane-column-label-attachments =
+ .label = { COPY(from_path, "attachmentColumn.label") }
+threadpane-column-header-sender = { COPY(from_path, "fromColumn.label") }
+ .title = { COPY(from_path, "fromColumn2.tooltip") }
+threadpane-column-label-sender =
+ .label = { COPY(from_path, "fromColumn.label") }
+threadpane-column-header-recipient = { COPY(from_path, "recipientColumn.label") }
+ .title = { COPY(from_path, "recipientColumn2.tooltip") }
+threadpane-column-label-recipient =
+ .label = { COPY(from_path, "recipientColumn.label") }
+threadpane-column-header-correspondents = { COPY(from_path, "correspondentColumn.label") }
+ .title = { COPY(from_path, "correspondentColumn2.tooltip") }
+threadpane-column-label-correspondents =
+ .label = { COPY(from_path, "correspondentColumn.label") }
+threadpane-column-header-subject = { COPY(from_path, "subjectColumn.label") }
+ .title = { COPY(from_path, "subjectColumn2.tooltip") }
+threadpane-column-label-subject =
+ .label = { COPY(from_path, "subjectColumn.label") }
+threadpane-column-header-date = { COPY(from_path, "dateColumn.label") }
+ .title = { COPY(from_path, "dateColumn2.tooltip") }
+threadpane-column-label-date =
+ .label = { COPY(from_path, "dateColumn.label") }
+threadpane-column-header-received = { COPY(from_path, "receivedColumn.label") }
+ .title = { COPY(from_path, "receivedColumn2.tooltip") }
+threadpane-column-label-received =
+ .label = { COPY(from_path, "receivedColumn.label") }
+threadpane-column-header-status = { COPY(from_path, "statusColumn.label") }
+ .title = { COPY(from_path, "statusColumn2.tooltip") }
+threadpane-column-label-status =
+ .label = { COPY(from_path, "statusColumn.label") }
+threadpane-column-header-size = { COPY(from_path, "sizeColumn.label") }
+ .title = { COPY(from_path, "sizeColumn2.tooltip") }
+threadpane-column-label-size =
+ .label = { COPY(from_path, "sizeColumn.label") }
+threadpane-column-header-tags = { COPY(from_path, "tagsColumn.label") }
+ .title = { COPY(from_path, "tagsColumn2.tooltip") }
+threadpane-column-label-tags =
+ .label = { COPY(from_path, "tagsColumn.label") }
+threadpane-column-header-account = { COPY(from_path, "accountColumn.label") }
+ .title = { COPY(from_path, "accountColumn2.tooltip") }
+threadpane-column-label-account =
+ .label = { COPY(from_path, "accountColumn.label") }
+threadpane-column-header-priority = { COPY(from_path, "priorityColumn.label") }
+ .title = { COPY(from_path, "priorityColumn2.tooltip") }
+threadpane-column-label-priority =
+ .label = { COPY(from_path, "priorityColumn.label") }
+threadpane-column-header-unread = { COPY(from_path, "unreadColumn.label") }
+ .title = { COPY(from_path, "unreadColumn2.tooltip") }
+threadpane-column-label-unread =
+ .label = { COPY(from_path, "unreadColumn.label") }
+threadpane-column-header-total = { COPY(from_path, "totalColumn.label") }
+ .title = { COPY(from_path, "totalColumn2.tooltip") }
+threadpane-column-label-total =
+ .label = { COPY(from_path, "totalColumn.label") }
+threadpane-column-header-location = { COPY(from_path, "locationColumn.label") }
+ .title = { COPY(from_path, "locationColumn2.tooltip") }
+threadpane-column-label-location =
+ .label = { COPY(from_path, "locationColumn.label") }
+threadpane-column-header-id = { COPY(from_path, "idColumn.label") }
+ .title = { COPY(from_path, "idColumn2.tooltip") }
+threadpane-column-label-id =
+ .label = { COPY(from_path, "idColumn.label") }
+threadpane-column-header-delete =
+ .title = { COPY(from_path, "deleteColumn.tooltip") }
+threadpane-column-label-delete =
+ .label = { COPY(from_path, "deleteColumn.label") }
+""",
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1805746_calendar_view.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1805746_calendar_view.py
new file mode 100644
index 0000000000..eec0fbe44e
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1805746_calendar_view.py
@@ -0,0 +1,29 @@
+# coding=utf8
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate.helpers import transforms_from
+from fluent.migrate import COPY
+
+
+def migrate(ctx):
+ """Bug 1805746 - Update Calendar View selection part {index}."""
+
+ ctx.add_transforms(
+ "calendar/calendar/calendar-widgets.ftl",
+ "calendar/calendar/calendar-widgets.ftl",
+ transforms_from(
+ """
+calendar-view-toggle-day = { COPY(from_path, "calendar.day.button.label") }
+ .title = { COPY(from_path, "calendar.day.button.tooltip") }
+calendar-view-toggle-week = { COPY(from_path, "calendar.week.button.label") }
+ .title = { COPY(from_path, "calendar.week.button.tooltip") }
+calendar-view-toggle-multiweek = { COPY(from_path, "calendar.multiweek.button.label") }
+ .title = { COPY(from_path, "calendar.multiweek.button.tooltip") }
+calendar-view-toggle-month = { COPY(from_path, "calendar.month.button.label") }
+ .title = { COPY(from_path, "calendar.month.button.tooltip") }
+""",
+ from_path="calendar/chrome/calendar/calendar.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1805938_calendar_recurrence_ux.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1805938_calendar_recurrence_ux.py
new file mode 100644
index 0000000000..715b475015
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1805938_calendar_recurrence_ux.py
@@ -0,0 +1,25 @@
+# coding=utf8
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate.helpers import transforms_from
+from fluent.migrate import COPY
+
+
+def migrate(ctx):
+ """Bug 1805938 - Refactor recurrence calendar UX part {index}."""
+
+ source = "calendar/chrome/calendar/calendar-event-dialog.dtd"
+ reference = target = "calendar/calendar/calendar-recurrence-dialog.ftl"
+
+ ctx.add_transforms(
+ target,
+ reference,
+ transforms_from(
+ """
+calendar-recurrence-preview-label = { COPY(from_path, "event.recurrence.preview.label") }
+""",
+ from_path=source,
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1806567_quick_filter_bar_migration.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1806567_quick_filter_bar_migration.py
new file mode 100644
index 0000000000..72967ef4d8
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1806567_quick_filter_bar_migration.py
@@ -0,0 +1,182 @@
+# coding=utf8
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import fluent.syntax.ast as FTL
+from fluent.migrate.helpers import (
+ MESSAGE_REFERENCE,
+ VARIABLE_REFERENCE,
+ transforms_from,
+)
+from fluent.migrate.transforms import (
+ CONCAT,
+ PLURALS,
+ REPLACE,
+ REPLACE_IN_TEXT,
+ Transform,
+)
+
+
+def migrate(ctx):
+ """Bug 1806567 - Migrate Quick Filter Bar strings from DTD to FTL, part {index}"""
+
+ source = "mail/chrome/messenger/quickFilterBar.dtd"
+ target1 = reference1 = "mail/messenger/about3Pane.ftl"
+ ctx.add_transforms(
+ target1,
+ reference1,
+ transforms_from(
+ """
+
+quick-filter-bar-sticky =
+ .title = { COPY(from_path, "quickFilterBar.sticky.tooltip") }
+quick-filter-bar-unread =
+ .title = { COPY(from_path, "quickFilterBar.unread.tooltip") }
+quick-filter-bar-unread-label = { COPY(from_path, "quickFilterBar.unread.label") }
+quick-filter-bar-starred =
+ .title = { COPY(from_path, "quickFilterBar.starred.tooltip") }
+quick-filter-bar-starred-label = { COPY(from_path, "quickFilterBar.starred.label") }
+quick-filter-bar-inaddrbook =
+ .title = { COPY(from_path, "quickFilterBar.inaddrbook.tooltip") }
+quick-filter-bar-inaddrbook-label = { COPY(from_path, "quickFilterBar.inaddrbook.label") }
+quick-filter-bar-tags =
+ .title = { COPY(from_path, "quickFilterBar.tags.tooltip") }
+quick-filter-bar-tags-label = { COPY(from_path, "quickFilterBar.tags.label") }
+quick-filter-bar-attachment =
+ .title = { COPY(from_path, "quickFilterBar.attachment.tooltip") }
+quick-filter-bar-attachment-label = { COPY(from_path, "quickFilterBar.attachment.label") }
+quick-filter-bar-no-results = { COPY(from_path, "quickFilterBar.resultsLabel.none") }
+""",
+ from_path=source,
+ ),
+ )
+ ctx.add_transforms(
+ target1,
+ reference1,
+ [
+ FTL.Message(
+ id=FTL.Identifier("quick-filter-bar-results"),
+ value=PLURALS(
+ source,
+ "quickFilterBar.resultsLabel.some.formatString",
+ VARIABLE_REFERENCE("count"),
+ lambda text: REPLACE_IN_TEXT(text, {"#1": VARIABLE_REFERENCE("count")}),
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("quick-filter-bar-textbox-shortcut"),
+ value=Transform.pattern_of(
+ FTL.SelectExpression(
+ selector=FTL.FunctionReference(
+ id=FTL.Identifier("PLATFORM"),
+ arguments=FTL.CallArguments(),
+ ),
+ variants=[
+ FTL.Variant(
+ key=FTL.Identifier("macos"),
+ default=False,
+ value=REPLACE(
+ source,
+ "quickFilterBar.textbox.emptyText.keyLabel2.mac",
+ {
+ "<": FTL.TextElement(""),
+ "⇧⌘": FTL.TextElement("⇧ ⌘ "),
+ ">": FTL.TextElement(""),
+ },
+ ),
+ ),
+ FTL.Variant(
+ key=FTL.Identifier("other"),
+ default=True,
+ value=REPLACE(
+ source,
+ "quickFilterBar.textbox.emptyText.keyLabel2.nonmac",
+ {
+ "<": FTL.TextElement(""),
+ ">": FTL.TextElement(""),
+ },
+ ),
+ ),
+ ],
+ )
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("quick-filter-bar-textbox"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("placeholder"),
+ value=REPLACE(
+ source,
+ "quickFilterBar.textbox.emptyText.base1",
+ {
+ "#1": CONCAT(
+ FTL.TextElement("<"),
+ MESSAGE_REFERENCE("quick-filter-bar-textbox-shortcut"),
+ FTL.TextElement(">"),
+ )
+ },
+ ),
+ ),
+ ],
+ ),
+ ],
+ )
+ ctx.add_transforms(
+ target1,
+ reference1,
+ transforms_from(
+ """
+quick-filter-bar-boolean-mode =
+ .title = { COPY(from_path, "quickFilterBar.booleanMode.tooltip") }
+quick-filter-bar-boolean-mode-any =
+ .label = { COPY(from_path, "quickFilterBar.booleanModeAny.label") }
+ .title = { COPY(from_path, "quickFilterBar.booleanModeAny.tooltip") }
+quick-filter-bar-boolean-mode-all =
+ .label = { COPY(from_path, "quickFilterBar.booleanModeAll.label") }
+ .title = { COPY(from_path, "quickFilterBar.booleanModeAll.tooltip") }
+quick-filter-bar-text-filter-explanation = { COPY(from_path, "quickFilterBar.textFilter.explanation.label") }
+quick-filter-bar-text-filter-sender = { COPY(from_path, "quickFilterBar.textFilter.sender.label") }
+quick-filter-bar-text-filter-recipients = { COPY(from_path, "quickFilterBar.textFilter.recipients.label") }
+quick-filter-bar-text-filter-subject = { COPY(from_path, "quickFilterBar.textFilter.subject.label") }
+quick-filter-bar-text-filter-body = { COPY(from_path, "quickFilterBar.textFilter.body.label") }
+quick-filter-bar-gloda-upsell-line1 = { COPY(from_path, "quickFilterBar.glodaUpsell.continueSearch") }
+""",
+ from_path=source,
+ ),
+ )
+ ctx.add_transforms(
+ target1,
+ reference1,
+ [
+ FTL.Message(
+ id=FTL.Identifier("quick-filter-bar-gloda-upsell-line2"),
+ value=REPLACE(
+ source,
+ "quickFilterBar.glodaUpsell.pressEnterAndCurrent",
+ {
+ "#1": VARIABLE_REFERENCE("text"),
+ " '": FTL.TextElement(" ‘"),
+ "' ": FTL.TextElement("’ "),
+ },
+ ),
+ ),
+ ],
+ )
+
+ target2 = reference2 = "mail/messenger/messenger.ftl"
+ ctx.add_transforms(
+ target2,
+ reference2,
+ transforms_from(
+ """
+quick-filter-bar-toggle =
+ .label = { COPY(from_path, "quickFilterBar.toggleBarVisibility.menu.label") }
+ .accesskey = { COPY(from_path, "quickFilterBar.toggleBarVisibility.menu.accesskey") }
+quick-filter-bar-show =
+ .key = { COPY(from_path, "quickFilterBar.show.key2") }
+""",
+ from_path=source,
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1809312_unified_toolbar_buttons.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1809312_unified_toolbar_buttons.py
new file mode 100644
index 0000000000..6558f5d6a7
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1809312_unified_toolbar_buttons.py
@@ -0,0 +1,218 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1809312 - Implement mail space actions for unified toolbar fluent migration part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+spacer-label = { COPY(from_path, "springTitle") }
+ """,
+ from_path="mail/chrome/messenger/customizeToolbar.properties",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-write-message-label = { COPY(from_path, "newMsgButton.label") }
+
+toolbar-write-message =
+ .title = { COPY(from_path, "newMsgButton.tooltip") }
+
+toolbar-folder-location-label = { COPY(from_path, "folderLocationToolbarItem.title") }
+
+toolbar-get-messages-label = { COPY(from_path, "getMsgButton1.label") }
+
+toolbar-reply-label = { COPY(from_path, "replyButton.label") }
+
+toolbar-reply =
+ .title = { COPY(from_path, "replyButton.tooltip") }
+
+toolbar-reply-all-label = { COPY(from_path, "replyAllButton.label") }
+
+toolbar-reply-all =
+ .title = { COPY(from_path, "replyAllButton.tooltip") }
+
+toolbar-reply-to-list-label = { COPY(from_path, "replyListButton.label") }
+
+toolbar-reply-to-list =
+ .title = { COPY(from_path, "replyListButton.tooltip") }
+
+toolbar-archive-label = { COPY(from_path, "archiveButton.label") }
+
+toolbar-archive =
+ .title = { COPY(from_path, "archiveButton.tooltip") }
+
+toolbar-conversation-label = { COPY(from_path, "openConversationButton.label") }
+
+toolbar-conversation =
+ .title = { COPY(from_path, "openMsgConversationButton.tooltip") }
+
+toolbar-previous-unread-label = { COPY(from_path, "previousButtonToolbarItem.label") }
+
+toolbar-previous-unread =
+ .title = { COPY(from_path, "previousButton.tooltip") }
+
+toolbar-previous-label = { COPY(from_path, "previousButton.label") }
+
+toolbar-previous =
+ .title = { COPY(from_path, "previousMsgButton.tooltip") }
+
+toolbar-next-unread-label = { COPY(from_path, "nextButtonToolbarItem.label") }
+
+toolbar-next-unread =
+ .title = { COPY(from_path, "nextButton.tooltip") }
+
+toolbar-next-label = { COPY(from_path, "nextMsgButton.label") }
+
+toolbar-next =
+ .title = { COPY(from_path, "nextMsgButton.tooltip") }
+
+toolbar-compact-label = { COPY(from_path, "compactButton.label") }
+
+toolbar-compact =
+ .title = { COPY(from_path, "compactButton.tooltip") }
+
+toolbar-tag-message-label = { COPY(from_path, "tagButton.label") }
+
+toolbar-tag-message =
+ .title = { COPY(from_path, "tagButton.tooltip") }
+
+toolbar-forward-inline-label = { COPY(from_path, "forwardButton.label") }
+
+toolbar-forward-inline =
+ .title = { COPY(from_path, "forwardAsInline.tooltip") }
+
+toolbar-forward-attachment-label = { COPY(from_path, "buttonMenuForwardAsAttachment.label") }
+
+toolbar-forward-attachment =
+ .title = { COPY(from_path, "forwardAsAttachment.tooltip") }
+
+toolbar-mark-as-label = { COPY(from_path, "markButton.label") }
+
+toolbar-mark-as =
+ .title = { COPY(from_path, "markButton.tooltip") }
+
+toolbar-address-book-label = { COPY(from_path, "addressBookButton.title") }
+
+toolbar-address-book =
+ .title = { COPY(from_path, "addressBookButton.tooltip") }
+
+toolbar-chat-label = { COPY(from_path, "chatButton.label") }
+
+toolbar-chat =
+ .title = { COPY(from_path, "chatButton.tooltip") }
+
+toolbar-print-label = { COPY(from_path, "printButton.label") }
+
+toolbar-print =
+ .title = { COPY(from_path, "printButton.tooltip") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-unifinder-label = { COPY(from_path, "showUnifinderCmd.label") }
+
+toolbar-unifinder =
+ .title = { COPY(from_path, "showUnifinderCmd.tooltip") }
+ """,
+ from_path="calendar/chrome/calendar/menuOverlay.dtd",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-edit-event-label = { COPY(from_path, "lightning.toolbar.edit.label") }
+
+toolbar-edit-event =
+ .title = { COPY(from_path, "lightning.toolbar.edit.tooltip") }
+
+toolbar-calendar-label = { COPY(from_path, "lightning.toolbar.calendar.label") }
+
+toolbar-calendar =
+ .title = { COPY(from_path, "lightning.toolbar.calendar.tooltip") }
+
+toolbar-tasks-label = { COPY(from_path, "lightning.toolbar.task.label") }
+
+toolbar-tasks =
+ .title = { COPY(from_path, "lightning.toolbar.task.tooltip") }
+ """,
+ from_path="calendar/chrome/lightning/lightning-toolbar.dtd",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-redirect-label = { COPY_PATTERN(from_path, "redirect-msg-button.label") }
+
+toolbar-redirect =
+ .title = { COPY_PATTERN(from_path, "redirect-msg-button.tooltiptext") }
+
+toolbar-add-ons-and-themes-label = { COPY_PATTERN(from_path, "addons-and-themes-toolbarbutton.label") }
+
+toolbar-add-ons-and-themes =
+ .title = { COPY_PATTERN(from_path, "addons-and-themes-toolbarbutton.tooltiptext") }
+
+
+toolbar-quick-filter-bar-label = { COPY_PATTERN(from_path, "quick-filter-toolbarbutton.label") }
+
+toolbar-quick-filter-bar =
+ .title = { COPY_PATTERN(from_path, "quick-filter-toolbarbutton.tooltiptext") }
+ """,
+ from_path="mail/messenger/messenger.ftl",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-junk-label = { COPY_PATTERN(from_path, "toolbar-junk-button.label") }
+
+toolbar-junk =
+ .title = { COPY_PATTERN(from_path, "toolbar-junk-button.tooltiptext") }
+
+toolbar-delete-label = { COPY_PATTERN(from_path, "toolbar-delete-button.label") }
+
+toolbar-delete =
+ .title = { COPY_PATTERN(from_path, "toolbar-delete-button.tooltiptext") }
+ """,
+ from_path="mail/messenger/menubar.ftl",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-add-as-event-label = { COPY(from_path, "calendar.extract.event.button") }
+
+toolbar-add-as-event =
+ .title = { COPY(from_path, "calendar.extract.event.button.tooltip") }
+
+toolbar-add-as-task-label = { COPY(from_path, "calendar.extract.task.button") }
+
+toolbar-add-as-task =
+ .title = { COPY(from_path, "calendar.extract.task.button.tooltip") }
+ """,
+ from_path="calendar/chrome/calendar/calendar.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1811400_thread_pane_column_picker.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1811400_thread_pane_column_picker.py
new file mode 100644
index 0000000000..925a4cbbb7
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1811400_thread_pane_column_picker.py
@@ -0,0 +1,79 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import fluent.syntax.ast as FTL
+from fluent.migrate.helpers import VARIABLE_REFERENCE, transforms_from
+from fluent.migrate.transforms import REPLACE
+
+
+def migrate(ctx):
+ """Bug 1811400 - Migrate thread pane strings, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/about3Pane.ftl",
+ "mail/messenger/about3Pane.ftl",
+ transforms_from(
+ """
+apply-columns-to-menu =
+ .label = { COPY(from_path, "columnPicker.applyTo.label") }
+
+apply-current-view-to-folder =
+ .label = { COPY(from_path, "columnPicker.applyToFolder.label") }
+
+apply-current-view-to-folder-children =
+ .label = { COPY(from_path, "columnPicker.applyToFolderAndChildren.label") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/about3Pane.ftl",
+ "mail/messenger/about3Pane.ftl",
+ transforms_from(
+ """
+apply-current-view-to-menu =
+ .label = { COPY_PATTERN(from_path, "apply-current-view-to-menu.label") }
+
+apply-changes-to-folder-title = {
+ COPY_PATTERN(from_path, "threadpane-apply-changes-prompt-title")
+}
+
+apply-current-view-to-folder-message = {
+ COPY_PATTERN(from_path, "threadpane-apply-changes-prompt-no-children-text")
+}
+
+apply-current-view-to-folder-with-children-message = {
+ COPY_PATTERN(from_path, "threadpane-apply-changes-prompt-with-children-text")
+}
+ """,
+ from_path="mail/messenger/mailWidgets.ftl",
+ ),
+ )
+ ctx.add_transforms(
+ "mail/messenger/about3Pane.ftl",
+ "mail/messenger/about3Pane.ftl",
+ [
+ FTL.Message(
+ id=FTL.Identifier("apply-current-columns-to-folder-message"),
+ value=REPLACE(
+ "mail/chrome/messenger/messenger.properties",
+ "threadPane.columnPicker.confirmFolder.noChildren.message",
+ {
+ "%1$S": VARIABLE_REFERENCE("name"),
+ },
+ normalize_printf=True,
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("apply-current-columns-to-folder-with-children-message"),
+ value=REPLACE(
+ "mail/chrome/messenger/messenger.properties",
+ "threadPane.columnPicker.confirmFolder.withChildren.message",
+ {
+ "%1$S": VARIABLE_REFERENCE("name"),
+ },
+ normalize_printf=True,
+ ),
+ ),
+ ],
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1814393_unified_toolbar_customization_tabs.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1814393_unified_toolbar_customization_tabs.py
new file mode 100644
index 0000000000..5f4c3b469b
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1814393_unified_toolbar_customization_tabs.py
@@ -0,0 +1,36 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1814393 - Unified toolbar customization tab titles part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbar.ftl",
+ "mail/messenger/unifiedToolbar.ftl",
+ transforms_from(
+ """
+customize-space-tab-mail = { COPY_PATTERN(from_path, "customize-space-mail") }
+ .title = { COPY_PATTERN(from_path, "customize-space-mail") }
+
+customize-space-tab-addressbook = { COPY_PATTERN(from_path, "customize-space-addressbook") }
+ .title = { COPY_PATTERN(from_path, "customize-space-addressbook") }
+
+customize-space-tab-calendar = { COPY_PATTERN(from_path, "customize-space-calendar") }
+ .title = { COPY_PATTERN(from_path, "customize-space-calendar") }
+
+customize-space-tab-tasks = { COPY_PATTERN(from_path, "customize-space-tasks") }
+ .title = { COPY_PATTERN(from_path, "customize-space-tasks") }
+
+customize-space-tab-chat = { COPY_PATTERN(from_path, "customize-space-chat") }
+ .title = { COPY_PATTERN(from_path, "customize-space-chat") }
+
+customize-space-tab-settings = { COPY_PATTERN(from_path, "customize-space-settings") }
+ .title = { COPY_PATTERN(from_path, "customize-space-settings") }
+ """,
+ from_path="mail/messenger/unifiedToolbar.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1814664_unified_toolbar_calendar_items.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1814664_unified_toolbar_calendar_items.py
new file mode 100644
index 0000000000..5985124c42
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1814664_unified_toolbar_calendar_items.py
@@ -0,0 +1,48 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1814664 - Add calendar items to unified toolbar fluent migration part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-synchronize-label = { COPY(from_path, "lightning.toolbar.sync.label") }
+
+toolbar-synchronize =
+ .title = { COPY(from_path, "lightning.toolbar.sync.tooltip") }
+
+toolbar-delete-event-label = { COPY(from_path, "lightning.toolbar.delete.label") }
+
+toolbar-delete-event =
+ .title = { COPY(from_path, "lightning.toolbar.delete.tooltip") }
+
+toolbar-go-to-today-label = { COPY(from_path, "lightning.toolbar.gototoday.label") }
+
+toolbar-go-to-today =
+ .title = { COPY(from_path, "lightning.toolbar.gototoday.tooltip") }
+
+toolbar-print-event-label = { COPY(from_path, "lightning.toolbar.print.label") }
+
+toolbar-print-event =
+ .title = { COPY(from_path, "lightning.toolbar.print.tooltip") }
+
+toolbar-new-event-label = { COPY(from_path, "lightning.toolbar.newevent.label") }
+
+toolbar-new-event =
+ .title = { COPY(from_path, "lightning.toolbar.newevent.tooltip") }
+
+toolbar-new-task-label = { COPY(from_path, "lightning.toolbar.newtask.label") }
+
+toolbar-new-task =
+ .title = { COPY(from_path, "lightning.toolbar.newtask.tooltip") }
+ """,
+ from_path="calendar/chrome/lightning/lightning-toolbar.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1815489_add_back_forward_and_stop.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1815489_add_back_forward_and_stop.py
new file mode 100644
index 0000000000..8dab08d9ab
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1815489_add_back_forward_and_stop.py
@@ -0,0 +1,33 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1815489 - Add back, forward and stop to unified toolbar fluent migration part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-go-back-label = { COPY(from_path, "backButton1.label") }
+
+toolbar-go-back =
+ .title = { COPY(from_path, "goBackButton.tooltip") }
+
+toolbar-go-forward-label = { COPY(from_path, "goForwardButton1.label") }
+
+toolbar-go-forward =
+ .title = { COPY(from_path, "goForwardButton.tooltip") }
+
+toolbar-stop-label = { COPY(from_path, "stopButton.label") }
+
+toolbar-stop =
+ .title = { COPY(from_path, "stopButton.tooltip") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1815605_calendar_context_menu_has_empty_items.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1815605_calendar_context_menu_has_empty_items.py
new file mode 100644
index 0000000000..de0157ac47
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1815605_calendar_context_menu_has_empty_items.py
@@ -0,0 +1,52 @@
+# coding=utf8
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate.helpers import transforms_from
+from fluent.migrate import COPY
+
+
+def migrate(ctx):
+ """Bug 1815605 - calendar context menu has empty items, part {index}."""
+
+ ctx.add_transforms(
+ "calendar/calendar/calendar-widgets.ftl",
+ "calendar/calendar/calendar-widgets.ftl",
+ transforms_from(
+ """
+calendar-context-menu-previous-day =
+ .label = { COPY(from_path, "calendar.prevday.label") }
+ .accesskey = { COPY(from_path, "calendar.prevday.accesskey") }
+
+calendar-context-menu-previous-week =
+ .label = { COPY(from_path, "calendar.prevweek.label") }
+ .accesskey = { COPY(from_path, "calendar.prevweek.accesskey") }
+
+calendar-context-menu-previous-multiweek =
+ .label = { COPY(from_path, "calendar.prevweek.label") }
+ .accesskey = { COPY(from_path, "calendar.prevweek.accesskey") }
+
+calendar-context-menu-previous-month =
+ .label = { COPY(from_path, "calendar.prevmonth.label") }
+ .accesskey = { COPY(from_path, "calendar.prevmonth.accesskey") }
+
+calendar-context-menu-next-day =
+ .label = { COPY(from_path, "calendar.nextday.label") }
+ .accesskey = { COPY(from_path, "calendar.nextday.accesskey") }
+
+calendar-context-menu-next-week =
+ .label = { COPY(from_path, "calendar.nextweek.label") }
+ .accesskey = { COPY(from_path, "calendar.nextweek.accesskey") }
+
+calendar-context-menu-next-multiweek =
+ .label = { COPY(from_path, "calendar.nextweek.label") }
+ .accesskey = { COPY(from_path, "calendar.nextweek.accesskey") }
+
+calendar-context-menu-next-month =
+ .label = { COPY(from_path, "calendar.nextmonth.label") }
+ .accesskey = { COPY(from_path, "calendar.nextmonth.accesskey") }
+""",
+ from_path="calendar/chrome/calendar/calendar.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1816532_about_dialog_migration.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1816532_about_dialog_migration.py
new file mode 100644
index 0000000000..cc47261099
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1816532_about_dialog_migration.py
@@ -0,0 +1,94 @@
+# coding=utf8
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+
+from fluent.migratetb.helpers import TERM_REFERENCE
+from fluent.migratetb.helpers import transforms_from
+
+
+# This can't just be a straight up literal dict (eg: {"a":"b"}) because the
+# validator fails... so make it a function call that returns a dict.. it works
+about_replacements = dict(
+ {
+ "&brandShorterName;": TERM_REFERENCE("brand-shorter-name"),
+ "&brandShortName;": TERM_REFERENCE("brand-short-name"),
+ "&vendorShortName;": TERM_REFERENCE("vendor-short-name"),
+ }
+)
+
+
+def migrate(ctx):
+ """Bug 1816532 - Migrate aboutDialog.dtd strings to Fluent, part {index}"""
+ target = reference = "mail/messenger/aboutDialog.ftl"
+ source = "mail/chrome/messenger/aboutDialog.dtd"
+
+ ctx.add_transforms(
+ target,
+ reference,
+ transforms_from(
+ """
+release-notes-link = { COPY(source, "releaseNotes.link") }
+
+update-check-for-updates-button = { COPY(source, "update.checkForUpdatesButton.label") }
+ .accesskey = { COPY(source, "update.checkForUpdatesButton.accesskey") }
+
+update-update-button = { REPLACE(source, "update.updateButton.label3", about_replacements) }
+ .accesskey = { COPY(source, "update.updateButton.accesskey") }
+
+update-checking-for-updates = { COPY(source, "update.checkingForUpdates") }
+
+update-downloading-message = { COPY(source, "update.downloading.start") }<span data-l10n-name="download-status"></span>
+
+update-applying = { COPY(source, "update.applying") }
+
+update-downloading = <img data-l10n-name="icon"/>{ COPY(source, "update.downloading.start") }<span data-l10n-name="download-status"></hspan>
+
+update-failed = { COPY(source, "update.failed.start") }<a data-l10n-name="failed-link">{ COPY(source, "update.failed.linkText") }</a>
+
+update-admin-disabled = { COPY(source, "update.adminDisabled") }
+
+update-no-updates-found = { REPLACE(source, "update.noUpdatesFound", about_replacements) }
+
+update-other-instance-handling-updates = { REPLACE(source, "update.otherInstanceHandlingUpdates", about_replacements) }
+
+update-unsupported = { COPY(source, "update.unsupported.start") }<a data-l10n-name="unsupported-link">{ COPY(source, "update.unsupported.linkText") }</a>
+
+update-restarting = { COPY(source, "update.restarting") }
+
+channel-description = { COPY(source, "channel.description.start") }<span data-l10n-name="current-channel">{ $channel }</span> { COPY(source, "channel.description.end", trim: "True") }
+
+warning-desc-version = { REPLACE(source, "warningDesc.version", about_replacements) }
+
+warning-desc-telemetry = { REPLACE(source, "warningDesc.telemetryDesc", about_replacements) }
+
+community-exp = <a data-l10n-name="community-exp-mozilla-link">
+ { REPLACE(source, "community.exp.mozillaLink", about_replacements) }</a>
+ { COPY(source, "community.exp.middle") }<a data-l10n-name="community-exp-credits-link">
+ { COPY(source, "community.exp.creditsLink") }</a>
+ { COPY(source, "community.exp.end") }
+
+community-2 = { REPLACE(source, "community.start2", about_replacements) }<a data-l10n-name="community-mozilla-link">
+ { REPLACE(source, "community.mozillaLink", about_replacements) }</a>
+ { COPY(source, "community.middle2") }<a data-l10n-name="community-credits-link">
+ { COPY(source, "community.creditsLink") }</a>
+ { COPY(source, "community.end3") }
+
+about-helpus = { COPY(source, "helpus.start") }<a data-l10n-name="helpus-donate-link">
+ { COPY(source, "helpus.donateLink") }</a> or <a data-l10n-name="helpus-get-involved-link">
+ { COPY(source, "helpus.getInvolvedLink") }</a>
+
+bottom-links-license = { COPY(source, "bottomLinks.license") }
+
+bottom-links-rights = { COPY(source, "bottomLinks.rights") }
+
+bottom-links-privacy = { COPY(source, "bottomLinks.privacy") }
+
+cmd-close-mac-command-key =
+ .key = { COPY(source, "cmdCloseMac.commandKey") }
+""",
+ source=source,
+ about_replacements=about_replacements,
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1816593_flexbox_emulation_dialogs.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1816593_flexbox_emulation_dialogs.py
new file mode 100644
index 0000000000..a920b9c0fd
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1816593_flexbox_emulation_dialogs.py
@@ -0,0 +1,21 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migrate import COPY_PATTERN
+from fluent.migrate.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1816593 - Fix wrong sized dialogs due to flexbox emulation, part {index}"""
+
+ ctx.add_transforms(
+ "mail/messenger/compactFoldersDialog.ftl",
+ "mail/messenger/compactFoldersDialog.ftl",
+ transforms_from(
+ """
+compact-dialog-window-title =
+ .title = {{COPY_PATTERN(from_path, "compact-dialog-window.title")}}
+ """,
+ from_path="mail/messenger/compactFoldersDialog.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1817914_tags_mode.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1817914_tags_mode.py
new file mode 100644
index 0000000000..d8b3c80d0c
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1817914_tags_mode.py
@@ -0,0 +1,21 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1820700 - Implement a Tags folder pane mode, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/messenger.ftl",
+ "mail/messenger/messenger.ftl",
+ transforms_from(
+ """
+show-tags-folders-label =
+ .label = {COPY(from_path, "viewTags.label")}
+ .accesskey = {COPY(from_path, "viewTags.accesskey")}
+""",
+ from_path="mail/chrome/messenger/msgViewPickerOverlay.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1817915_get_new_messages.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1817915_get_new_messages.py
new file mode 100644
index 0000000000..2e2c1ac497
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1817915_get_new_messages.py
@@ -0,0 +1,22 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb.helpers import transforms_from
+from fluent.migratetb import COPY
+
+
+def migrate(ctx):
+ """Bug 1817915 - Add context menu to Get Messages folder pane button to fetch all messages or per account, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/about3Pane.ftl",
+ "mail/messenger/about3Pane.ftl",
+ transforms_from(
+ """
+folder-pane-get-all-messages-menuitem =
+ .label = { COPY(from_path, "getAllNewMsgCmd.label") }
+ .accesskey = { COPY(from_path, "getAllNewMsgCmd.accesskey") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1820700_select_thread.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1820700_select_thread.py
new file mode 100644
index 0000000000..ae65f694d1
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1820700_select_thread.py
@@ -0,0 +1,35 @@
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at https://mozilla.org/MPL/2.0/.
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import fluent.syntax.ast as FTL
+from fluent.migratetb.helpers import VARIABLE_REFERENCE, transforms_from
+from fluent.migratetb.transforms import REPLACE
+
+
+def migrate(ctx):
+ """Bug 1820700 - Migrate thread img strings to button, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/treeView.ftl",
+ "mail/messenger/treeView.ftl",
+ transforms_from(
+ """
+tree-list-view-row-thread-button =
+ .title = {COPY_PATTERN(from_path, "tree-list-view-row-thread-icon.title")}
+
+tree-list-view-row-ignored-thread-button =
+ .title = {COPY_PATTERN(from_path, "tree-list-view-row-ignored-thread-icon.title")}
+
+tree-list-view-row-ignored-subthread-button =
+ .title = {COPY_PATTERN(from_path, "tree-list-view-row-ignored-subthread-icon.title")}
+
+tree-list-view-row-watched-thread-button =
+ .title = {COPY_PATTERN(from_path, "tree-list-view-row-watched-thread-icon.title")}
+""",
+ from_path="mail/messenger/treeView.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1823033_activity_indicator.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1823033_activity_indicator.py
new file mode 100644
index 0000000000..4cfaec4695
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1823033_activity_indicator.py
@@ -0,0 +1,23 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1823033 - Add activity indicator to unified toolbar fluent migration part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/unifiedToolbarItems.ftl",
+ "mail/messenger/unifiedToolbarItems.ftl",
+ transforms_from(
+ """
+toolbar-throbber-label = { COPY(from_path, "throbberItem.title") }
+
+toolbar-throbber =
+ .title = { COPY(from_path, "throbberItem.title") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1827261_add_enable_disable_compact_mode_options_to_folder_mode_context_menu.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1827261_add_enable_disable_compact_mode_options_to_folder_mode_context_menu.py
new file mode 100644
index 0000000000..7ea090e903
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1827261_add_enable_disable_compact_mode_options_to_folder_mode_context_menu.py
@@ -0,0 +1,26 @@
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at https://mozilla.org/MPL/2.0/.
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb.helpers import transforms_from
+from fluent.migratetb import COPY
+
+
+def migrate(ctx):
+ """Bug 1827261 - Add enable/disable compact mode options to Folder Mode context menu, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/about3Pane.ftl",
+ "mail/messenger/about3Pane.ftl",
+ transforms_from(
+ """
+folder-pane-mode-context-toggle-compact-mode =
+ .label = { COPY(from_path, "compactVersion.label") }
+ .accesskey = { COPY(from_path, "compactVersion.accesskey") }
+ """,
+ from_path="mail/chrome/messenger/messenger.dtd",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1827891_dnt_prefs_learn_more.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1827891_dnt_prefs_learn_more.py
new file mode 100644
index 0000000000..4861e428bc
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1827891_dnt_prefs_learn_more.py
@@ -0,0 +1,21 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+from fluent.migratetb import COPY_PATTERN
+from fluent.migratetb.helpers import transforms_from
+
+
+def migrate(ctx):
+ """Bug 1827891 - DNT Prefs 'learn more' link fix, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/preferences/preferences.ftl",
+ "mail/messenger/preferences/preferences.ftl",
+ transforms_from(
+ """
+dnt-learn-more-button =
+ .value = {{ COPY_PATTERN(from_path, "learn-button.label") }}
+ """,
+ from_path="mail/messenger/preferences/preferences.ftl",
+ ),
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1828340_aboutdialog_layout_fixes.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1828340_aboutdialog_layout_fixes.py
new file mode 100644
index 0000000000..d162e94659
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1828340_aboutdialog_layout_fixes.py
@@ -0,0 +1,42 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import re
+
+from fluent.migratetb import COPY_PATTERN
+from fluent.migratetb.transforms import TransformPattern
+
+import fluent.syntax.ast as FTL
+
+
+class STRIP_NEWLINES(TransformPattern):
+ def visit_TextElement(self, node):
+ node.value = re.sub("\n", "", node.value)
+ return node
+
+
+def migrate(ctx):
+ """Bug 1828340 - Fix aboutDialog layout issues, part {index}."""
+ path = "mail/messenger/aboutDialog.ftl"
+ ctx.add_transforms(
+ path,
+ path,
+ [
+ FTL.Message(
+ id=FTL.Identifier("about-dialog-title"),
+ value=COPY_PATTERN(path, "aboutDialog-title.title"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("community-experimental"),
+ value=STRIP_NEWLINES(path, "community-exp"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("community-desc"),
+ value=STRIP_NEWLINES(path, "community-2"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("about-donation"),
+ value=STRIP_NEWLINES(path, "about-helpus"),
+ ),
+ ],
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1830004_folder_quota.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1830004_folder_quota.py
new file mode 100644
index 0000000000..07f4505912
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1830004_folder_quota.py
@@ -0,0 +1,28 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import fluent.syntax.ast as FTL
+from fluent.migratetb.helpers import VARIABLE_REFERENCE, transforms_from
+from fluent.migratetb.transforms import REPLACE
+
+
+def migrate(ctx):
+ """Bug 1830004 - Migrate a quota string, part {index}."""
+
+ ctx.add_transforms(
+ "mail/messenger/folderprops.ftl",
+ "mail/messenger/folderprops.ftl",
+ [
+ FTL.Message(
+ id=FTL.Identifier("quota-percent-used"),
+ value=REPLACE(
+ "mail/chrome/messenger/messenger.properties",
+ "quotaPercentUsed",
+ {
+ "%1$S": VARIABLE_REFERENCE("percent"),
+ },
+ normalize_printf=True,
+ ),
+ ),
+ ],
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_cal_enable78.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_cal_enable78.py
new file mode 100644
index 0000000000..b3f6c420c6
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_cal_enable78.py
@@ -0,0 +1,30 @@
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at https://mozilla.org/MPL/2.0/.
+
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import fluent.syntax.ast as FTL
+from fluent.migratetb.helpers import VARIABLE_REFERENCE, transforms_from
+from fluent.migratetb.transforms import REPLACE
+from fluent.migratetb.transforms import COPY
+
+
+def migrate(ctx):
+ """Bug 1834662 - Migrate calendar enable button, part {index}."""
+ target = reference = "calendar/calendar/calendar-widgets.ftl"
+
+ ctx.add_transforms(
+ target,
+ reference,
+ [
+ FTL.Message(
+ id=FTL.Identifier("calendar-enable-button"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.sideloadEnable.label",
+ ),
+ ),
+ ],
+ )
diff --git a/comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_extensions_to_fluent.py b/comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_extensions_to_fluent.py
new file mode 100644
index 0000000000..cdd8736b67
--- /dev/null
+++ b/comm/python/l10n/tb_fluent_migrations/completed/bug_1834662_extensions_to_fluent.py
@@ -0,0 +1,531 @@
+# Any copyright is dedicated to the Public Domain.
+# http://creativecommons.org/publicdomain/zero/1.0/
+
+import fluent.syntax.ast as FTL
+from fluent.migratetb.helpers import TERM_REFERENCE, VARIABLE_REFERENCE
+from fluent.migratetb.transforms import (
+ COPY,
+ COPY_PATTERN,
+ PLURALS,
+ REPLACE,
+ REPLACE_IN_TEXT,
+)
+
+
+def migrate(ctx):
+ """Bug 1834662 - Migrate addon/extension stuff, part {index}."""
+
+ # extensionPermissions.ftl - from addons.properties
+ ctx.add_transforms(
+ "mail/messenger/extensionPermissions.ftl",
+ "mail/messenger/extensionPermissions.ftl",
+ [
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-accountsFolders"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.accountsFolders",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-accountsIdentities"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.accountsIdentities",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-accountsRead"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.accountsRead2",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-addressBooks"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.addressBooks",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-compose"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.compose",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-compose"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.compose",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-compose-send"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.compose.send",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-compose-save"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.compose.save",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-experiment"),
+ value=REPLACE(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.experiment",
+ {"%1$S": TERM_REFERENCE("brand-short-name")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-messagesImport"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.messagesImport",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-messagesModify"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.messagesModify",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-messagesMove"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.messagesMove2",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-messagesDelete"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.messagesDelete",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-messagesRead"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.messagesRead",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-messagesTags"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.messagesTags",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-description-sensitiveDataUpload"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.description.sensitiveDataUpload",
+ ),
+ ),
+ ],
+ )
+
+ # extensionsUI.ftl - from here and there
+ ctx.add_transforms(
+ "mail/messenger/extensionsUI.ftl",
+ "mail/messenger/extensionsUI.ftl",
+ [
+ FTL.Message(
+ id=FTL.Identifier("webext-experiment-warning"),
+ value=COPY(
+ "mail/chrome/messenger/addons.properties",
+ "webextPerms.experimentWarning",
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-learn-more"),
+ value=COPY("mail/chrome/messenger/addons.properties", "webextPerms.learnMore2"),
+ ),
+ ],
+ )
+
+ # addonNotifications.ftl - copied from browser/ migration script
+
+ addons_properties = "mail/chrome/messenger/addons.properties"
+ notifications = "mail/messenger/addonNotifications.ftl"
+
+ ctx.add_transforms(
+ notifications,
+ notifications,
+ [
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt"),
+ value=REPLACE(
+ addons_properties,
+ "xpinstallPromptMessage",
+ {"%1$S": TERM_REFERENCE("brand-short-name")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-header"),
+ value=REPLACE(
+ addons_properties,
+ "xpinstallPromptMessage.header",
+ {"%1$S": VARIABLE_REFERENCE("host")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-message"),
+ value=REPLACE(
+ addons_properties,
+ "xpinstallPromptMessage.message",
+ {"%1$S": VARIABLE_REFERENCE("host")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-header-unknown"),
+ value=COPY(addons_properties, "xpinstallPromptMessage.header.unknown"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-message-unknown"),
+ value=COPY(addons_properties, "xpinstallPromptMessage.message.unknown"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-dont-allow"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(addons_properties, "xpinstallPromptMessage.dontAllow"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(
+ addons_properties,
+ "xpinstallPromptMessage.dontAllow.accesskey",
+ ),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-never-allow"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(addons_properties, "xpinstallPromptMessage.neverAllow"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(
+ addons_properties,
+ "xpinstallPromptMessage.neverAllow.accesskey",
+ ),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-never-allow-and-report"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(
+ addons_properties,
+ "xpinstallPromptMessage.neverAllowAndReport",
+ ),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(
+ addons_properties,
+ "xpinstallPromptMessage.neverAllowAndReport.accesskey",
+ ),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("site-permission-install-first-prompt-midi-header"),
+ value=COPY(addons_properties, "sitePermissionInstallFirstPrompt.midi.header"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("site-permission-install-first-prompt-midi-message"),
+ value=COPY(addons_properties, "sitePermissionInstallFirstPrompt.midi.message"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-prompt-install"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(addons_properties, "xpinstallPromptMessage.install"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(
+ addons_properties,
+ "xpinstallPromptMessage.install.accesskey",
+ ),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-disabled-locked"),
+ value=COPY(addons_properties, "xpinstallDisabledMessageLocked"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-disabled"),
+ value=COPY(addons_properties, "xpinstallDisabledMessage"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("xpinstall-disabled-button"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(addons_properties, "xpinstallDisabledButton"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(addons_properties, "xpinstallDisabledButton.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-blocked-by-policy"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallBlockedByPolicy",
+ {
+ "%1$S": VARIABLE_REFERENCE("addonName"),
+ "%2$S": VARIABLE_REFERENCE("addonId"),
+ "%3$S": FTL.TextElement(""),
+ },
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-domain-blocked-by-policy"),
+ value=COPY(addons_properties, "addonDomainBlockedByPolicy"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-full-screen-blocked"),
+ value=COPY(addons_properties, "addonInstallFullScreenBlocked"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-sideload-menu-item"),
+ value=REPLACE(
+ addons_properties,
+ "webextPerms.sideloadMenuItem",
+ {
+ "%1$S": VARIABLE_REFERENCE("addonName"),
+ "%2$S": TERM_REFERENCE("brand-short-name"),
+ },
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("webext-perms-update-menu-item"),
+ value=REPLACE(
+ addons_properties,
+ "webextPerms.updateMenuItem",
+ {"%1$S": VARIABLE_REFERENCE("addonName")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-removal-message"),
+ value=REPLACE(
+ addons_properties,
+ "webext.remove.confirmation.message",
+ {
+ "%1$S": VARIABLE_REFERENCE("name"),
+ "%2$S": TERM_REFERENCE("brand-shorter-name"),
+ },
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-removal-button"),
+ value=COPY(addons_properties, "webext.remove.confirmation.button"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-downloading-and-verifying"),
+ value=PLURALS(
+ addons_properties,
+ "addonDownloadingAndVerifying",
+ VARIABLE_REFERENCE("addonCount"),
+ foreach=lambda n: REPLACE_IN_TEXT(
+ n,
+ {"#1": VARIABLE_REFERENCE("addonCount")},
+ ),
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-download-verifying"),
+ value=COPY(addons_properties, "addonDownloadVerifying"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-cancel-button"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(addons_properties, "addonInstall.cancelButton.label"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(addons_properties, "addonInstall.cancelButton.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-accept-button"),
+ attributes=[
+ FTL.Attribute(
+ id=FTL.Identifier("label"),
+ value=COPY(addons_properties, "addonInstall.acceptButton2.label"),
+ ),
+ FTL.Attribute(
+ id=FTL.Identifier("accesskey"),
+ value=COPY(addons_properties, "addonInstall.acceptButton2.accesskey"),
+ ),
+ ],
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-confirm-install-message"),
+ value=PLURALS(
+ addons_properties,
+ "addonConfirmInstall.message",
+ VARIABLE_REFERENCE("addonCount"),
+ foreach=lambda n: REPLACE_IN_TEXT(
+ n,
+ {
+ "#1": TERM_REFERENCE("brand-short-name"),
+ "#2": VARIABLE_REFERENCE("addonCount"),
+ },
+ ),
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-confirm-install-unsigned-message"),
+ value=PLURALS(
+ addons_properties,
+ "addonConfirmInstallUnsigned.message",
+ VARIABLE_REFERENCE("addonCount"),
+ foreach=lambda n: REPLACE_IN_TEXT(
+ n,
+ {
+ "#1": TERM_REFERENCE("brand-short-name"),
+ "#2": VARIABLE_REFERENCE("addonCount"),
+ },
+ ),
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-confirm-install-some-unsigned-message"),
+ value=PLURALS(
+ addons_properties,
+ "addonConfirmInstallSomeUnsigned.message",
+ VARIABLE_REFERENCE("addonCount"),
+ foreach=lambda n: REPLACE_IN_TEXT(
+ n,
+ {
+ "#1": TERM_REFERENCE("brand-short-name"),
+ "#2": VARIABLE_REFERENCE("addonCount"),
+ },
+ ),
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-network-failure"),
+ value=COPY(addons_properties, "addonInstallError-1"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-incorrect-hash"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallError-2",
+ {"%1$S": TERM_REFERENCE("brand-short-name")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-corrupt-file"),
+ value=COPY(addons_properties, "addonInstallError-3"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-file-access"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallError-4",
+ {
+ "%2$S": VARIABLE_REFERENCE("addonName"),
+ "%1$S": TERM_REFERENCE("brand-short-name"),
+ },
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-not-signed"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallError-5",
+ {"%1$S": TERM_REFERENCE("brand-short-name")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-invalid-domain"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallError-8",
+ {"%2$S": VARIABLE_REFERENCE("addonName")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-local-install-error-network-failure"),
+ value=COPY(addons_properties, "addonLocalInstallError-1"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-local-install-error-incorrect-hash"),
+ value=REPLACE(
+ addons_properties,
+ "addonLocalInstallError-2",
+ {"%1$S": TERM_REFERENCE("brand-short-name")},
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-local-install-error-corrupt-file"),
+ value=COPY(addons_properties, "addonLocalInstallError-3"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-local-install-error-file-access"),
+ value=REPLACE(
+ addons_properties,
+ "addonLocalInstallError-4",
+ {
+ "%2$S": VARIABLE_REFERENCE("addonName"),
+ "%1$S": TERM_REFERENCE("brand-short-name"),
+ },
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-local-install-error-not-signed"),
+ value=COPY(addons_properties, "addonLocalInstallError-5"),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-incompatible"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallErrorIncompatible",
+ {
+ "%3$S": VARIABLE_REFERENCE("addonName"),
+ "%1$S": TERM_REFERENCE("brand-short-name"),
+ "%2$S": VARIABLE_REFERENCE("appVersion"),
+ },
+ ),
+ ),
+ FTL.Message(
+ id=FTL.Identifier("addon-install-error-blocklisted"),
+ value=REPLACE(
+ addons_properties,
+ "addonInstallErrorBlocklisted",
+ {"%1$S": VARIABLE_REFERENCE("addonName")},
+ ),
+ ),
+ ],
+ )