morgan pushed to branch tor-browser-115.21.0esr-13.5-1 at The Tor Project / Applications / Tor Browser

Commits:

8 changed files:

Changes:

  • browser/components/BrowserGlue.sys.mjs
    ... ... @@ -502,6 +502,7 @@ let JSWINDOWACTORS = {
    502 502
           events: {
    
    503 503
             DOMContentLoaded: {},
    
    504 504
             SubmitSearchOnionize: { wantUntrusted: true },
    
    505
    +        SurveyDismissed: { wantUntrusted: true },
    
    505 506
           },
    
    506 507
         },
    
    507 508
     
    

  • browser/components/abouttor/AboutTorChild.sys.mjs
    ... ... @@ -26,6 +26,10 @@ export class AboutTorChild extends JSWindowActorChild {
    26 26
           case "SubmitSearchOnionize":
    
    27 27
             this.sendAsyncMessage("AboutTor:SetSearchOnionize", !!event.detail);
    
    28 28
             break;
    
    29
    +      case "SurveyDismissed":
    
    30
    +        // event.detail is the survey version.
    
    31
    +        this.sendAsyncMessage("AboutTor:SurveyDismissed", event.detail);
    
    32
    +        break;
    
    29 33
         }
    
    30 34
       }
    
    31 35
     }

  • browser/components/abouttor/AboutTorParent.sys.mjs
    ... ... @@ -10,6 +10,8 @@ ChromeUtils.defineESModuleGetters(lazy, {
    10 10
     export class AboutTorParent extends JSWindowActorParent {
    
    11 11
       receiveMessage(message) {
    
    12 12
         const onionizePref = "torbrowser.homepage.search.onionize";
    
    13
    +    const surveyDismissVersionPref =
    
    14
    +      "torbrowser.homepage.survey.dismiss_version";
    
    13 15
         switch (message.name) {
    
    14 16
           case "AboutTor:GetInitialData":
    
    15 17
             return Promise.resolve({
    
    ... ... @@ -17,10 +19,26 @@ export class AboutTorParent extends JSWindowActorParent {
    17 19
               messageData: lazy.AboutTorMessage.getNext(),
    
    18 20
               isStable: AppConstants.MOZ_UPDATE_CHANNEL === "release",
    
    19 21
               searchOnionize: Services.prefs.getBoolPref(onionizePref, false),
    
    22
    +          surveyDismissVersion: Services.prefs.getIntPref(
    
    23
    +            surveyDismissVersionPref,
    
    24
    +            0
    
    25
    +          ),
    
    20 26
             });
    
    21 27
           case "AboutTor:SetSearchOnionize":
    
    22 28
             Services.prefs.setBoolPref(onionizePref, message.data);
    
    23 29
             break;
    
    30
    +      case "AboutTor:SurveyDismissed":
    
    31
    +        // The message.data contains the version of the current survey.
    
    32
    +        // Rather than introduce a new preference for each survey campaign we
    
    33
    +        // reuse the same integer preference and increase its value every time
    
    34
    +        // a new version of the survey is shown and dismissed by the user.
    
    35
    +        // I.e. if the preference value is 2, we will not show survey version 2
    
    36
    +        // but will show survey version 3 or higher when they are introduced.
    
    37
    +        // It should be safe to overwrite the value since we do not expect more
    
    38
    +        // than one active survey campaign at any given time, nor do we expect
    
    39
    +        // the version value to decrease.
    
    40
    +        Services.prefs.setIntPref(surveyDismissVersionPref, message.data);
    
    41
    +        break;
    
    24 42
         }
    
    25 43
         return undefined;
    
    26 44
       }
    

  • browser/components/abouttor/content/1f44b-waving-hand.svg
    1
    +<!-- FROM https://github.com/twitter/twemoji
    
    2
    +   - licensed under CC-BY 4.0: https://creativecommons.org/licenses/by/4.0/ -->
    
    3
    +<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 36 36"><path fill="#EF9645" d="M4.861 9.147c.94-.657 2.357-.531 3.201.166l-.968-1.407c-.779-1.111-.5-2.313.612-3.093 1.112-.777 4.263 1.312 4.263 1.312-.786-1.122-.639-2.544.483-3.331 1.122-.784 2.67-.513 3.456.611l10.42 14.72L25 31l-11.083-4.042L4.25 12.625c-.793-1.129-.519-2.686.611-3.478z"/><path fill="#FFDC5D" d="M2.695 17.336s-1.132-1.65.519-2.781c1.649-1.131 2.78.518 2.78.518l5.251 7.658c.181-.302.379-.6.6-.894L4.557 11.21s-1.131-1.649.519-2.78c1.649-1.131 2.78.518 2.78.518l6.855 9.997c.255-.208.516-.417.785-.622L7.549 6.732s-1.131-1.649.519-2.78c1.649-1.131 2.78.518 2.78.518l7.947 11.589c.292-.179.581-.334.871-.498L12.238 4.729s-1.131-1.649.518-2.78c1.649-1.131 2.78.518 2.78.518l7.854 11.454 1.194 1.742c-4.948 3.394-5.419 9.779-2.592 13.902.565.825 1.39.26 1.39.26-3.393-4.949-2.357-10.51 2.592-13.903L24.515 8.62s-.545-1.924 1.378-2.47c1.924-.545 2.47 1.379 2.47 1.379l1.685 5.004c.668 1.984 1.379 3.961 2.32 5.831 2.657 5.28 1.07 11.842-3.94 15.279-5.465 3.747-12.936 2.354-16.684-3.11L2.695 17.336z"/><g fill="#5DADEC"><path d="M12 32.042C8 32.042 3.958 28 3.958 24c0-.553-.405-1-.958-1s-1.042.447-1.042 1C1.958 30 6 34.042 12 34.042c.553 0 1-.489 1-1.042s-.447-.958-1-.958z"/><path d="M7 34c-3 0-5-2-5-5 0-.553-.447-1-1-1s-1 .447-1 1c0 4 3 7 7 7 .553 0 1-.447 1-1s-.447-1-1-1zM24 2c-.552 0-1 .448-1 1s.448 1 1 1c4 0 8 3.589 8 8 0 .552.448 1 1 1s1-.448 1-1c0-5.514-4-10-10-10z"/><path d="M29 .042c-.552 0-1 .406-1 .958s.448 1.042 1 1.042c3 0 4.958 2.225 4.958 4.958 0 .552.489 1 1.042 1s.958-.448.958-1C35.958 3.163 33 .042 29 .042z"/></g></svg>

  • browser/components/abouttor/content/aboutTor.css
    ... ... @@ -12,6 +12,7 @@ body {
    12 12
         "tor-check tor-check tor-check" auto
    
    13 13
         ". form ." min-content
    
    14 14
         "message message message" auto
    
    15
    +    "survey survey survey" auto
    
    15 16
         /* End space: unfilled.
    
    16 17
          * Reserve 150px for background image.
    
    17 18
          * NOTE: Since the body has "auto" height, the other "1fr" flex row will
    
    ... ... @@ -48,18 +49,24 @@ h1 {
    48 49
     
    
    49 50
     #tor-check {
    
    50 51
       grid-area: tor-check;
    
    51
    -  max-width: var(--form-max-width);
    
    52
    -  box-sizing: border-box;
    
    53 52
       display: flex;
    
    54 53
       gap: 10px;
    
    55 54
       align-items: center;
    
    56
    -  padding-inline: 24px;
    
    57
    -  padding-block: 12px;
    
    55
    +  padding-inline: 23px;
    
    56
    +  padding-block: 11px;
    
    58 57
       border-radius: 8px;
    
    59 58
       margin-block-start: 0;
    
    60 59
       margin-block-end: 30px;
    
    61 60
     }
    
    62 61
     
    
    62
    +.tor-home-box {
    
    63
    +  border: 1px solid var(--in-content-box-border-color);
    
    64
    +  background-color: var(--in-content-box-info-background);
    
    65
    +  max-width: var(--form-max-width);
    
    66
    +  width: -moz-available;
    
    67
    +  box-sizing: border-box;
    
    68
    +}
    
    69
    +
    
    63 70
     body:not(.show-tor-check) #tor-check {
    
    64 71
       display: none;
    
    65 72
     }
    
    ... ... @@ -82,8 +89,7 @@ body:not(.show-tor-check) #tor-check {
    82 89
       /* line-height and text-align are used when wrapping. */
    
    83 90
       line-height: 1.5;
    
    84 91
       text-align: center;
    
    85
    -  margin-block-start: 1.6em;
    
    86
    -  margin-block-end: 1em;
    
    92
    +  margin-block: 1.6em;
    
    87 93
     }
    
    88 94
     
    
    89 95
     .message-emoji {
    
    ... ... @@ -165,14 +171,101 @@ body:not(.show-tor-check) #tor-check {
    165 171
     
    
    166 172
     }
    
    167 173
     
    
    174
    +#survey {
    
    175
    +  grid-area: survey;
    
    176
    +  display: grid;
    
    177
    +  grid-template:
    
    178
    +    "icon heading close" min-content
    
    179
    +    "icon body close" auto
    
    180
    +    ". buttons buttons" min-content
    
    181
    +    / min-content 1fr min-content;
    
    182
    +  border-radius: 4px;
    
    183
    +  /* Remove 1px from padding for border. */
    
    184
    +  padding-block: 3px 11px;
    
    185
    +  padding-inline: 15px 3px;
    
    186
    +  gap: 8px;
    
    187
    +  margin-block-end: 1.6em;
    
    188
    +}
    
    189
    +
    
    190
    +body:not(.show-survey) #survey {
    
    191
    +  display: none;
    
    192
    +}
    
    193
    +
    
    194
    +#survey > * {
    
    195
    +  margin: 0;
    
    196
    +}
    
    197
    +
    
    198
    +#survey-icon {
    
    199
    +  grid-area: icon;
    
    200
    +  width: 24px;
    
    201
    +  height: 24px;
    
    202
    +  padding: 8px;
    
    203
    +  border-radius: 20px;
    
    204
    +}
    
    205
    +
    
    206
    +#survey-heading {
    
    207
    +  grid-area: heading;
    
    208
    +  font-size: inherit;
    
    209
    +}
    
    210
    +
    
    211
    +#survey-icon,
    
    212
    +#survey-heading {
    
    213
    +  margin-block-start: 8px;
    
    214
    +}
    
    215
    +
    
    216
    +#survey-body {
    
    217
    +  grid-area: body;
    
    218
    +  margin-block-end: 8px;
    
    219
    +}
    
    220
    +
    
    221
    +#survey-buttons {
    
    222
    +  grid-area: buttons;
    
    223
    +  display: flex;
    
    224
    +  gap: 8px;
    
    225
    +}
    
    226
    +
    
    227
    +#survey-buttons > * {
    
    228
    +  flex: 0 0 auto;
    
    229
    +  margin: 0;
    
    230
    +}
    
    231
    +
    
    232
    +#survey-close {
    
    233
    +  grid-area: close;
    
    234
    +  /* Look like moz-button with "icon ghost" type. */
    
    235
    +  color: inherit;
    
    236
    +  border: transparent;
    
    237
    +  background: transparent;
    
    238
    +  display: grid;
    
    239
    +  width: fit-content;
    
    240
    +  height: fit-content;
    
    241
    +  min-width: fit-content;
    
    242
    +  min-height: fit-content;
    
    243
    +  padding: 8px;
    
    244
    +}
    
    245
    +
    
    246
    +#survey-close:enabled:hover {
    
    247
    +  color: inherit;
    
    248
    +  border: transparent;
    
    249
    +  background: var(--in-content-button-background-hover);
    
    250
    +}
    
    251
    +
    
    252
    +#survey-close:enabled:hover:active {
    
    253
    +  color: inherit;
    
    254
    +  border: transparent;
    
    255
    +  background: var(--in-content-button-background-active);
    
    256
    +}
    
    257
    +
    
    258
    +#survey-close img {
    
    259
    +  width: 16px;
    
    260
    +  height: 16px;
    
    261
    +  -moz-context-properties: fill;
    
    262
    +  fill: currentColor;
    
    263
    +}
    
    264
    +
    
    168 265
     @media (prefers-contrast) {
    
    169 266
       #search-form {
    
    170 267
         border-color: var(--in-content-box-border-color);
    
    171 268
       }
    
    172
    -
    
    173
    -  #tor-check {
    
    174
    -    background-color: var(--in-content-box-info-background);
    
    175
    -  }
    
    176 269
     }
    
    177 270
     
    
    178 271
     @media not (prefers-contrast) {
    
    ... ... @@ -187,6 +280,7 @@ body:not(.show-tor-check) #tor-check {
    187 280
     
    
    188 281
       #tor-check {
    
    189 282
         background-color: #1f0333;
    
    283
    +    border-color: transparent;
    
    190 284
       }
    
    191 285
     
    
    192 286
       body > :not(#search-form) {
    
    ... ... @@ -202,6 +296,10 @@ body:not(.show-tor-check) #tor-check {
    202 296
          * See tor-browser#42025 */
    
    203 297
         --in-content-link-color-hover: var(--purple-40);
    
    204 298
         --in-content-link-color-active: var(--purple-50);
    
    299
    +
    
    300
    +    --in-content-button-text-color: var(--in-content-text-color);
    
    301
    +    --in-content-button-text-color-hover: var(--in-content-text-color);
    
    302
    +    --in-content-button-text-color-active: var(--in-content-text-color);
    
    205 303
       }
    
    206 304
     
    
    207 305
       #search-form {
    
    ... ... @@ -231,4 +329,20 @@ body:not(.show-tor-check) #tor-check {
    231 329
       #search-form.onionized-search #onionize-toggle {
    
    232 330
         color: var(--purple-60);
    
    233 331
       }
    
    332
    +
    
    333
    +  #survey {
    
    334
    +    background-color: #3d1559;
    
    335
    +    border-color: transparent;
    
    336
    +  }
    
    337
    +
    
    338
    +  #survey-icon {
    
    339
    +    background-color: #00000040;
    
    340
    +  }
    
    341
    +
    
    342
    +  #survey-launch {
    
    343
    +    color: #15141a; /* --color-gray-100 */
    
    344
    +    --in-content-primary-button-background: var(--purple-30);
    
    345
    +    --in-content-primary-button-background-hover: var(--purple-40);
    
    346
    +    --in-content-primary-button-background-active: var(--purple-50);
    
    347
    +  }
    
    234 348
     }

  • browser/components/abouttor/content/aboutTor.html
    ... ... @@ -37,7 +37,7 @@
    37 37
           />
    
    38 38
           <span id="tor-browser-home-heading-text"></span>
    
    39 39
         </h1>
    
    40
    -    <p id="tor-check">
    
    40
    +    <p id="tor-check" class="tor-home-box">
    
    41 41
           <img
    
    42 42
             id="tor-check-icon"
    
    43 43
             alt=""
    
    ... ... @@ -125,5 +125,22 @@
    125 125
             ></a>
    
    126 126
           </span>
    
    127 127
         </p>
    
    128
    +    <!-- Survey element, initially used for tor-browser#43504. -->
    
    129
    +    <article id="survey" class="tor-home-box" aria-labelledby="survey-heading">
    
    130
    +      <img
    
    131
    +        id="survey-icon"
    
    132
    +        alt=""
    
    133
    +        src="chrome://browser/content/abouttor/1f44b-waving-hand.svg"
    
    134
    +      />
    
    135
    +      <h2 id="survey-heading"></h2>
    
    136
    +      <p id="survey-body"></p>
    
    137
    +      <div id="survey-buttons">
    
    138
    +        <button id="survey-launch" class="primary"></button>
    
    139
    +        <button id="survey-dismiss"></button>
    
    140
    +      </div>
    
    141
    +      <button id="survey-close">
    
    142
    +        <img alt="" src="chrome://global/skin/icons/close.svg" />
    
    143
    +      </button>
    
    144
    +    </article>
    
    128 145
       </body>
    
    129 146
     </html>

  • browser/components/abouttor/content/aboutTor.js
    ... ... @@ -170,14 +170,241 @@ const MessageArea = {
    170 170
       },
    
    171 171
     };
    
    172 172
     
    
    173
    +/**
    
    174
    + * A reusable area for surveys.
    
    175
    + *
    
    176
    + * Initially used for tor-browser#43504.
    
    177
    + */
    
    178
    +const SurveyArea = {
    
    179
    +  /**
    
    180
    +   * The current version of the survey.
    
    181
    +   *
    
    182
    +   * Should be increased every time we start a new survey campaign.
    
    183
    +   *
    
    184
    +   * @type {integer}
    
    185
    +   */
    
    186
    +  _version: 1,
    
    187
    +
    
    188
    +  /**
    
    189
    +   * The date to start showing the survey.
    
    190
    +   *
    
    191
    +   * @type {integer}
    
    192
    +   */
    
    193
    +  _startDate: Date.UTC(2025, 3, 14, 12), // 2025 April 14th, 12:00.
    
    194
    +
    
    195
    +  /**
    
    196
    +   * The date to stop showing the current survey.
    
    197
    +   *
    
    198
    +   * @type {integer}
    
    199
    +   */
    
    200
    +  _endDate: Date.UTC(2025, 3, 28), // 2025 April 28th, 00:00.
    
    201
    +
    
    202
    +  /**
    
    203
    +   * The survey URL.
    
    204
    +   *
    
    205
    +   * @type {string}
    
    206
    +   */
    
    207
    +  _urlBase: "https://survey.torproject.org/index.php/923269",
    
    208
    +
    
    209
    +  /**
    
    210
    +   * @typedef {object} SurveyLocaleData
    
    211
    +   *
    
    212
    +   * Locale-specific data for the survey.
    
    213
    +   *
    
    214
    +   * @property {string[]} browserLocales - The browser locales this should match
    
    215
    +   *   with. The first locale should match the locale of the strings.
    
    216
    +   * @property {string} urlCode - The language code to pass to the survey URL.
    
    217
    +   * @property {string} dir - The direction of the locale.
    
    218
    +   * @property {object} strings - The strings to use for the survey banner.
    
    219
    +   */
    
    220
    +
    
    221
    +  /**
    
    222
    +   * The data for the selected locale.
    
    223
    +   *
    
    224
    +   * @type {SurveyLocaleData}
    
    225
    +   */
    
    226
    +  _localeData: null,
    
    227
    +
    
    228
    +  /**
    
    229
    +   * The data for each locale that is supported.
    
    230
    +   *
    
    231
    +   * The first entry is the default.
    
    232
    +   *
    
    233
    +   * @type {SurveyLocaleData[]}
    
    234
    +   */
    
    235
    +  _localeDataSet: [
    
    236
    +    {
    
    237
    +      browserLocales: ["en-US"],
    
    238
    +      dir: "ltr",
    
    239
    +      urlCode: "en",
    
    240
    +      strings: {
    
    241
    +        heading: "We’d love your feedback",
    
    242
    +        body: "Help us improve Tor Browser by completing this 10-minute survey.",
    
    243
    +        launch: "Launch the survey",
    
    244
    +        dismiss: "Not now",
    
    245
    +        close: "Close",
    
    246
    +      },
    
    247
    +    },
    
    248
    +    {
    
    249
    +      browserLocales: ["es-ES"],
    
    250
    +      dir: "ltr",
    
    251
    +      urlCode: "es",
    
    252
    +      strings: {
    
    253
    +        heading: "Danos tu opinión",
    
    254
    +        body: "Ayúdanos a mejorar el Navegador Tor completando esta encuesta de 10 minutos.",
    
    255
    +        launch: "Iniciar la encuesta",
    
    256
    +        dismiss: "Más adelante",
    
    257
    +        close: "Cerrar",
    
    258
    +      },
    
    259
    +    },
    
    260
    +    {
    
    261
    +      browserLocales: ["ru"],
    
    262
    +      dir: "ltr",
    
    263
    +      urlCode: "ru",
    
    264
    +      strings: {
    
    265
    +        heading: "Мы будем рады вашим отзывам",
    
    266
    +        body: "Помогите нам улучшить браузер Tor, пройдя 10-минутный опрос.",
    
    267
    +        launch: "Начать опрос",
    
    268
    +        dismiss: "Не сейчас",
    
    269
    +        close: "Закрыть",
    
    270
    +      },
    
    271
    +    },
    
    272
    +    {
    
    273
    +      browserLocales: ["fr"],
    
    274
    +      dir: "ltr",
    
    275
    +      urlCode: "fr",
    
    276
    +      strings: {
    
    277
    +        heading: "Nous serions ravis d’avoir votre avis !",
    
    278
    +        body: "Aidez-nous à améliorer le navigateur Tor en répondant à cette enquête de 10 minutes.",
    
    279
    +        launch: "Lancer l'enquête",
    
    280
    +        dismiss: "Pas maintenant",
    
    281
    +        close: "Fermer",
    
    282
    +      },
    
    283
    +    },
    
    284
    +    {
    
    285
    +      // Also show this pt-BR banner for the pt-PT browser locale.
    
    286
    +      browserLocales: ["pt-BR", "pt-PT"],
    
    287
    +      dir: "ltr",
    
    288
    +      urlCode: "pt-BR",
    
    289
    +      strings: {
    
    290
    +        heading: "Adoraríamos ouvir sua opinião",
    
    291
    +        body: "Ajude-nos a melhorar o Navegador Tor respondendo a esta pesquisa de 10 minutos.",
    
    292
    +        launch: "Iniciar a pesquisa",
    
    293
    +        dismiss: "Mais tarde",
    
    294
    +        close: "Fechar",
    
    295
    +      },
    
    296
    +    },
    
    297
    +  ],
    
    298
    +
    
    299
    +  /**
    
    300
    +   * Initialize the survey area.
    
    301
    +   */
    
    302
    +  init() {
    
    303
    +    document.getElementById("survey-launch").addEventListener("click", () => {
    
    304
    +      if (!this._localeData) {
    
    305
    +        return;
    
    306
    +      }
    
    307
    +      const url = new URL(this._urlBase);
    
    308
    +      url.searchParams.append("lang", this._localeData.urlCode);
    
    309
    +      open(url.href);
    
    310
    +    });
    
    311
    +    document.getElementById("survey-close").addEventListener("click", () => {
    
    312
    +      this._hide();
    
    313
    +    });
    
    314
    +    document.getElementById("survey-dismiss").addEventListener("click", () => {
    
    315
    +      this._hide();
    
    316
    +    });
    
    317
    +  },
    
    318
    +
    
    319
    +  /**
    
    320
    +   * Permanently hide this survey.
    
    321
    +   */
    
    322
    +  _hide() {
    
    323
    +    document.body.classList.remove("show-survey");
    
    324
    +    // Move focus to the search input.
    
    325
    +    document.getElementById("search-input").focus();
    
    326
    +
    
    327
    +    dispatchEvent(
    
    328
    +      new CustomEvent("SurveyDismissed", {
    
    329
    +        // We pass in the current survey version to record the *latest*
    
    330
    +        // version that the user has dismissed. This will overwrite any
    
    331
    +        // previous versions.
    
    332
    +        detail: this._version,
    
    333
    +        bubbles: true,
    
    334
    +      })
    
    335
    +    );
    
    336
    +  },
    
    337
    +
    
    338
    +  /**
    
    339
    +   * Decide whether to show the survey.
    
    340
    +   *
    
    341
    +   * @param {integer} dismissVersion - The latest version of survey that the
    
    342
    +   *   user has already dismissed.
    
    343
    +   * @param {boolean} isStable - Whether this is the stable release of Tor
    
    344
    +   *   Browser.
    
    345
    +   */
    
    346
    +  potentiallyShow(dismissVersion, isStable) {
    
    347
    +    const now = Date.now();
    
    348
    +    if (
    
    349
    +      now < this._startDate ||
    
    350
    +      now >= this._endDate ||
    
    351
    +      // The user has already dismissed this version of the survey before:
    
    352
    +      dismissVersion >= this._version ||
    
    353
    +      !isStable
    
    354
    +    ) {
    
    355
    +      // Don't show the survey.
    
    356
    +      return;
    
    357
    +    }
    
    358
    +
    
    359
    +    // Determine the survey locale based on the about:tor locale.
    
    360
    +    // NOTE: We do not user document.l10n to translate the survey banner.
    
    361
    +    // Instead we only translate the banner into a limited set of locales that
    
    362
    +    // match the languages that the survey itself supports. This should match
    
    363
    +    // the language of the survey when it is opened by the user.
    
    364
    +    const pageLocale = document.documentElement.getAttribute("lang");
    
    365
    +    for (const localeData of this._localeDataSet) {
    
    366
    +      if (localeData.browserLocales.includes(pageLocale)) {
    
    367
    +        this._localeData = localeData;
    
    368
    +        break;
    
    369
    +      }
    
    370
    +    }
    
    371
    +    if (!this._localeData) {
    
    372
    +      // Show the default en-US banner.
    
    373
    +      this._localeData = this._localeDataSet[0];
    
    374
    +    }
    
    375
    +
    
    376
    +    // Make sure the survey's lang and dir attributes match the chosen locale.
    
    377
    +    const surveyEl = document.getElementById("survey");
    
    378
    +    surveyEl.setAttribute("lang", this._localeData.browserLocales[0]);
    
    379
    +    surveyEl.setAttribute("dir", this._localeData.dir);
    
    380
    +
    
    381
    +    const { heading, body, launch, dismiss, close } = this._localeData.strings;
    
    382
    +
    
    383
    +    document.getElementById("survey-heading").textContent = heading;
    
    384
    +    document.getElementById("survey-body").textContent = body;
    
    385
    +    document.getElementById("survey-launch").textContent = launch;
    
    386
    +    document.getElementById("survey-dismiss").textContent = dismiss;
    
    387
    +    document.getElementById("survey-close").setAttribute("title", close);
    
    388
    +
    
    389
    +    document.body.classList.add("show-survey");
    
    390
    +  },
    
    391
    +};
    
    392
    +
    
    173 393
     window.addEventListener("DOMContentLoaded", () => {
    
    174 394
       SearchWidget.init();
    
    175 395
       MessageArea.init();
    
    396
    +  SurveyArea.init();
    
    176 397
     });
    
    177 398
     
    
    178 399
     window.addEventListener("InitialData", event => {
    
    179
    -  const { torConnectEnabled, isStable, searchOnionize, messageData } =
    
    180
    -    event.detail;
    
    400
    +  const {
    
    401
    +    torConnectEnabled,
    
    402
    +    isStable,
    
    403
    +    searchOnionize,
    
    404
    +    messageData,
    
    405
    +    surveyDismissVersion,
    
    406
    +  } = event.detail;
    
    181 407
       SearchWidget.setOnionizeState(!!searchOnionize);
    
    182 408
       MessageArea.setMessageData(messageData, !!isStable, !!torConnectEnabled);
    
    409
    +  SurveyArea.potentiallyShow(surveyDismissVersion, isStable);
    
    183 410
     });

  • browser/components/abouttor/jar.mn
    ... ... @@ -3,6 +3,7 @@ browser.jar:
    3 3
       content/browser/abouttor/aboutTor.js            (content/aboutTor.js)
    
    4 4
       content/browser/abouttor/aboutTor.html          (content/aboutTor.html)
    
    5 5
       content/browser/abouttor/dax-logo.svg           (content/dax-logo.svg)
    
    6
    +  content/browser/abouttor/1f44b-waving-hand.svg  (content/1f44b-waving-hand.svg)
    
    6 7
       content/browser/abouttor/1f4e3-megaphone.svg    (content/1f4e3-megaphone.svg)
    
    7 8
       content/browser/abouttor/26a1-high-voltage.svg  (content/26a1-high-voltage.svg)
    
    8 9
       content/browser/abouttor/2728-sparkles.svg      (content/2728-sparkles.svg)