morgan pushed to branch tor-browser-115.21.0esr-13.5-1 at The Tor Project / Applications / Tor Browser
Commits:
-
2b5edd06
by Henry Wilkes at 2025-03-11T17:31:56+00:00
8 changed files:
- browser/components/BrowserGlue.sys.mjs
- browser/components/abouttor/AboutTorChild.sys.mjs
- browser/components/abouttor/AboutTorParent.sys.mjs
- + browser/components/abouttor/content/1f44b-waving-hand.svg
- browser/components/abouttor/content/aboutTor.css
- browser/components/abouttor/content/aboutTor.html
- browser/components/abouttor/content/aboutTor.js
- browser/components/abouttor/jar.mn
Changes:
... | ... | @@ -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 |
... | ... | @@ -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 | } |
... | ... | @@ -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 | }
|
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> |
... | ... | @@ -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 | } |
... | ... | @@ -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> |
... | ... | @@ -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 | }); |
... | ... | @@ -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)
|