| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2015 Eyeo GmbH | 3 * Copyright (C) 2006-2015 Eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| (...skipping 340 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 351 switch (actions[i]) | 351 switch (actions[i]) |
| 352 { | 352 { |
| 353 case "add-domain-exception": | 353 case "add-domain-exception": |
| 354 addWhitelistedDomain(); | 354 addWhitelistedDomain(); |
| 355 break; | 355 break; |
| 356 case "add-predefined-subscription": | 356 case "add-predefined-subscription": |
| 357 var dialog = E("dialog-content-predefined"); | 357 var dialog = E("dialog-content-predefined"); |
| 358 var title = dialog.querySelector("h3").textContent; | 358 var title = dialog.querySelector("h3").textContent; |
| 359 var url = dialog.querySelector(".url").textContent; | 359 var url = dialog.querySelector(".url").textContent; |
| 360 addEnableSubscription(url, title); | 360 addEnableSubscription(url, title); |
| 361 document.body.removeAttribute("data-dialog"); | 361 closeDialog(); |
| 362 break; | 362 break; |
| 363 case "cancel-custom-filters": | 363 case "cancel-custom-filters": |
| 364 E("custom-filters").classList.remove("mode-edit"); | 364 E("custom-filters").classList.remove("mode-edit"); |
| 365 break; | 365 break; |
| 366 case "cancel-domain-exception": | 366 case "cancel-domain-exception": |
| 367 E("whitelisting-textbox").value = ""; | 367 E("whitelisting-textbox").value = ""; |
| 368 break; | 368 break; |
| 369 case "close-dialog": | 369 case "close-dialog": |
| 370 document.body.removeAttribute("data-dialog"); | 370 closeDialog(); |
| 371 break; | 371 break; |
| 372 case "edit-custom-filters": | 372 case "edit-custom-filters": |
| 373 E("custom-filters").classList.add("mode-edit"); | 373 E("custom-filters").classList.add("mode-edit"); |
| 374 editCustomFilters(); | 374 editCustomFilters(); |
| 375 break; | 375 break; |
| 376 case "import-subscription": | 376 case "import-subscription": |
| 377 var url = E("blockingList-textbox").value; | 377 var url = E("blockingList-textbox").value; |
| 378 addEnableSubscription(url); | 378 addEnableSubscription(url); |
| 379 document.body.removeAttribute("data-dialog"); | 379 closeDialog(); |
| 380 break; | 380 break; |
| 381 case "open-dialog": | 381 case "open-dialog": |
| 382 openDialog(element.getAttribute("data-dialog")); | 382 openDialog(element.getAttribute("data-dialog")); |
| 383 break; | 383 break; |
| 384 case "save-custom-filters": | 384 case "save-custom-filters": |
| 385 ext.backgroundPage.sendMessage( | 385 ext.backgroundPage.sendMessage( |
| 386 { | 386 { |
| 387 type: "filters.importRaw", | 387 type: "filters.importRaw", |
| 388 text: E("custom-filters-raw").value | 388 text: E("custom-filters-raw").value |
| 389 }); | 389 }); |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 410 | 410 |
| 411 function onFindLanguageKeyUp() | 411 function onFindLanguageKeyUp() |
| 412 { | 412 { |
| 413 var searchStyle = E("search-style"); | 413 var searchStyle = E("search-style"); |
| 414 if (!this.value) | 414 if (!this.value) |
| 415 searchStyle.innerHTML = ""; | 415 searchStyle.innerHTML = ""; |
| 416 else | 416 else |
| 417 searchStyle.innerHTML = "#all-lang-table li:not([data-search*=\"" + this .value.toLowerCase() + "\"]) { display: none; }"; | 417 searchStyle.innerHTML = "#all-lang-table li:not([data-search*=\"" + this .value.toLowerCase() + "\"]) { display: none; }"; |
| 418 } | 418 } |
| 419 | 419 |
| 420 function isEnterPressed(e) | 420 function getKey(e) |
| 421 { | 421 { |
| 422 // e.keyCode has been deprecated so we attempt to use e.key | 422 // e.keyCode has been deprecated so we attempt to use e.key |
| 423 if ("key" in e) | 423 if ("key" in e) |
| 424 return e.key == "Enter"; | 424 return e.key; |
| 425 return e.keyCode == 13; // keyCode "13" corresponds to "Enter" | 425 return getKey.keys[e.keyCode]; |
| 426 } | 426 } |
| 427 getKey.keys = { | |
| 428 9: "Tab", | |
| 429 13: "Enter", | |
| 430 27: "Escape" | |
| 431 }; | |
| 427 | 432 |
| 428 // Initialize navigation sidebar | 433 // Initialize navigation sidebar |
| 429 ext.backgroundPage.sendMessage( | 434 ext.backgroundPage.sendMessage( |
| 430 { | 435 { |
| 431 type: "app.get", | 436 type: "app.get", |
| 432 what: "addonVersion" | 437 what: "addonVersion" |
| 433 }, | 438 }, |
| 434 function(addonVersion) | 439 function(addonVersion) |
| 435 { | 440 { |
| 436 E("abp-version").textContent = addonVersion; | 441 E("abp-version").textContent = addonVersion; |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 447 | 452 |
| 448 updateShareLink(); | 453 updateShareLink(); |
| 449 | 454 |
| 450 // Initialize interactive UI elements | 455 // Initialize interactive UI elements |
| 451 document.body.addEventListener("click", onClick, false); | 456 document.body.addEventListener("click", onClick, false); |
| 452 var placeholderValue = ext.i18n.getMessage("options_dialog_language_find"); | 457 var placeholderValue = ext.i18n.getMessage("options_dialog_language_find"); |
| 453 E("find-language").setAttribute("placeholder", placeholderValue); | 458 E("find-language").setAttribute("placeholder", placeholderValue); |
| 454 E("find-language").addEventListener("keyup", onFindLanguageKeyUp, false); | 459 E("find-language").addEventListener("keyup", onFindLanguageKeyUp, false); |
| 455 E("whitelisting-textbox").addEventListener("keypress", function(e) | 460 E("whitelisting-textbox").addEventListener("keypress", function(e) |
| 456 { | 461 { |
| 457 if (isEnterPressed(e)) | 462 if (getKey(e) == "Enter") |
| 458 addWhitelistedDomain(); | 463 addWhitelistedDomain(); |
| 459 }, false); | 464 }, false); |
| 460 | 465 |
| 461 // Advanced tab | 466 // Advanced tab |
| 462 var filterTextbox = document.querySelector("#custom-filters-add input"); | 467 var filterTextbox = document.querySelector("#custom-filters-add input"); |
| 463 placeholderValue = ext.i18n.getMessage("options_customFilters_textbox_placeh older"); | 468 placeholderValue = ext.i18n.getMessage("options_customFilters_textbox_placeh older"); |
| 464 filterTextbox.setAttribute("placeholder", placeholderValue); | 469 filterTextbox.setAttribute("placeholder", placeholderValue); |
| 465 function addCustomFilters() | 470 function addCustomFilters() |
| 466 { | 471 { |
| 467 var filterText = filterTextbox.value; | 472 var filterText = filterTextbox.value; |
| 468 ext.backgroundPage.sendMessage( | 473 ext.backgroundPage.sendMessage( |
| 469 { | 474 { |
| 470 type: "filters.add", | 475 type: "filters.add", |
| 471 text: filterText | 476 text: filterText |
| 472 }); | 477 }); |
| 473 filterTextbox.value = ""; | 478 filterTextbox.value = ""; |
| 474 } | 479 } |
| 475 E("custom-filters-add").addEventListener("submit", function(e) | 480 E("custom-filters-add").addEventListener("submit", function(e) |
| 476 { | 481 { |
| 477 e.preventDefault(); | 482 e.preventDefault(); |
| 478 addCustomFilters(); | 483 addCustomFilters(); |
| 479 }, false); | 484 }, false); |
| 480 var customFilterEditButtons = document.querySelectorAll("#custom-filters-edi t-wrapper button"); | 485 var customFilterEditButtons = document.querySelectorAll("#custom-filters-edi t-wrapper button"); |
| 486 | |
| 487 E("dialog").addEventListener("keydown", function(e) | |
| 488 { | |
| 489 switch (getKey(e)) | |
| 490 { | |
| 491 case "Escape": | |
| 492 closeDialog(); | |
| 493 break; | |
| 494 case "Tab": | |
| 495 if (e.shiftKey) | |
| 496 { | |
| 497 if (e.target.classList.contains("focus-first")) | |
| 498 { | |
| 499 e.preventDefault(); | |
| 500 document.querySelector("#dialog .focus-last").focus(); | |
|
saroyanm
2015/10/01 16:31:40
you already has the dialog element, I think you ca
Thomas Greiner
2015/10/02 10:27:28
Done.
| |
| 501 } | |
| 502 } | |
| 503 else if (e.target.classList.contains("focus-last")) | |
| 504 { | |
| 505 e.preventDefault(); | |
| 506 document.querySelector("#dialog .focus-first").focus(); | |
| 507 } | |
| 508 break; | |
| 509 } | |
| 510 }, false); | |
| 481 } | 511 } |
| 482 | 512 |
| 513 var focusedBeforeDialog = null; | |
| 483 function openDialog(name) | 514 function openDialog(name) |
| 484 { | 515 { |
| 516 var dialog = E("dialog"); | |
| 517 dialog.setAttribute("aria-hidden", false); | |
| 518 dialog.setAttribute("aria-labelledby", "dialog-title-" + name); | |
| 485 document.body.setAttribute("data-dialog", name); | 519 document.body.setAttribute("data-dialog", name); |
| 520 | |
| 521 var defaultAction = document.querySelector("#dialog-content-" + name | |
|
saroyanm
2015/10/01 16:31:40
what about naming this defaultFocus or initialFocu
Thomas Greiner
2015/10/02 10:27:29
Done.
| |
| 522 + " .default-action"); | |
| 523 if (!defaultAction) | |
| 524 defaultAction = document.querySelector("#dialog .focus-first"); | |
|
saroyanm
2015/10/01 16:31:40
I think here you also can use dialog element "dial
Thomas Greiner
2015/10/02 10:27:29
Done.
| |
| 525 focusedBeforeDialog = document.activeElement; | |
| 526 defaultAction.focus(); | |
| 527 } | |
| 528 | |
| 529 function closeDialog() | |
| 530 { | |
| 531 var dialog = E("dialog"); | |
| 532 dialog.setAttribute("aria-hidden", true); | |
| 533 dialog.removeAttribute("aria-labelledby"); | |
| 534 document.body.removeAttribute("data-dialog"); | |
| 535 focusedBeforeDialog.focus(); | |
| 486 } | 536 } |
| 487 | 537 |
| 488 function populateLists() | 538 function populateLists() |
| 489 { | 539 { |
| 490 subscriptionsMap = Object.create(null); | 540 subscriptionsMap = Object.create(null); |
| 491 filtersMap = Object.create(null); | 541 filtersMap = Object.create(null); |
| 492 recommendationsMap = Object.create(null); | 542 recommendationsMap = Object.create(null); |
| 493 | 543 |
| 494 // Empty collections and lists | 544 // Empty collections and lists |
| 495 for (var property in collections) | 545 for (var property in collections) |
| (...skipping 246 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 742 filter: ["added", "loaded", "removed"] | 792 filter: ["added", "loaded", "removed"] |
| 743 }); | 793 }); |
| 744 ext.backgroundPage.sendMessage( | 794 ext.backgroundPage.sendMessage( |
| 745 { | 795 { |
| 746 type: "subscriptions.listen", | 796 type: "subscriptions.listen", |
| 747 filter: ["added", "disabled", "homepage", "removed", "title"] | 797 filter: ["added", "disabled", "homepage", "removed", "title"] |
| 748 }); | 798 }); |
| 749 | 799 |
| 750 window.addEventListener("DOMContentLoaded", onDOMLoaded, false); | 800 window.addEventListener("DOMContentLoaded", onDOMLoaded, false); |
| 751 })(); | 801 })(); |
| OLD | NEW |