348 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			348 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <html id="stylus">
 | |
| 
 | |
| <head>
 | |
|   <meta charset="UTF-8">
 | |
|   <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
|   <title i18n-text="manageTitle"></title>
 | |
|   <link rel="stylesheet" href="global.css">
 | |
|   <link rel="stylesheet" href="manage/manage.css">
 | |
|   <link rel="stylesheet" href="manage/config-dialog.css">
 | |
|   <link rel="stylesheet" href="msgbox/msgbox.css">
 | |
|   <link rel="stylesheet" href="options/onoffswitch.css">
 | |
|   <link rel="stylesheet" href="vendor-overwrites/colorpicker/colorpicker.css">
 | |
| 
 | |
|   <style id="style-overrides"></style>
 | |
| 
 | |
|   <style id="firefox-transitions-bug-suppressor">
 | |
|     /* restrict to FF */
 | |
|     @supports (-moz-appearance:none) {
 | |
|       /* increased specificity to override sane selectors in user styles */
 | |
|       html#stylus.firefox #stylus-manage #header * {
 | |
|         transition: none !important;
 | |
|       }
 | |
|     }
 | |
|   </style>
 | |
| 
 | |
|   <!-- Notes:
 | |
|     * Chrome doesn't garbage-collect (or even leaks) SVG <symbol> referenced via <use> so we'll embed the code directly
 | |
|     * inter-tag whitespace in templates is automatically removed in localization.js
 | |
|     * i18n-anything attribute automatically creates "anything" attribute
 | |
|   -->
 | |
| 
 | |
|   <template data-id="style">
 | |
|     <div class="entry">
 | |
|       <h2 class="style-name">
 | |
|         <a class="style-name-link"></a>
 | |
|         <a target="_blank" class="homepage"></a>
 | |
|       </h2>
 | |
|       <p class="applies-to">
 | |
|         <label i18n-text="appliesDisplay"></label>
 | |
|         <span class="targets"></span>
 | |
|       </p>
 | |
|       <p class="actions">
 | |
|         <a class="style-edit-link">
 | |
|           <button i18n-text="editStyleLabel"></button>
 | |
|         </a>
 | |
|         <button class="enable" i18n-text="enableStyleLabel"></button>
 | |
|         <button class="disable" i18n-text="disableStyleLabel"></button>
 | |
|         <button class="delete" i18n-text="deleteStyleLabel"></button>
 | |
|         <button class="check-update" i18n-text="checkForUpdate"></button>
 | |
|         <button class="update" i18n-text="installUpdate"></button>
 | |
|         <span class="update-note"></span>
 | |
|       </p>
 | |
|     </div>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="styleCompact">
 | |
|     <div class="entry">
 | |
|       <h2 class="style-name">
 | |
|       <div class="checkmate">
 | |
|         <input class="checker" type="checkbox" i18n-title="toggleStyle">
 | |
|         <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|       </div>
 | |
|         <a class="style-name-link"></a>
 | |
|       </h2>
 | |
|       <p class="actions">
 | |
|         <a target="_blank" class="homepage"></a>
 | |
|         <span i18n-title="deleteStyleLabel">
 | |
|           <svg class="svg-icon delete" viewBox="0 0 20 20">
 | |
|             <polygon points="16.2,5.5 14.5,3.8 10,8.3 5.5,3.8 3.8,5.5 8.3,10 3.8,14.5
 | |
|                              5.5,16.2 10,11.7 14.5,16.2 16.2,14.5 11.7,10 "/>
 | |
|           </svg>
 | |
|         </span>
 | |
|       </p>
 | |
|       <div class="applies-to">
 | |
|         <div class="targets"></div>
 | |
|         <span class="expander">...</span>
 | |
|       </div>
 | |
|     </div>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="homepageIconBig">
 | |
|     <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|       <polygon shape-rendering="crispEdges" points="3,3 3,17 17,17 17,13 15,13 15,15 5,15 5,5 7,5 7,3 "/>
 | |
|       <polygon points="10,3 12.5,5.5 8,10 10,12 14.5,7.5 17,10 17,3 "/>
 | |
|     </svg>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="homepageIconSmall">
 | |
|     <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|       <path d="M4,4h5v2H6v8h8v-3h2v5H4V4z M11,3h6v6l-2-2l-4,4L9,9l4-4L11,3z"/>
 | |
|     </svg>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="configureIcon">
 | |
|     <span class="configure-usercss" i18n-title="configureStyle">
 | |
|       <svg class="svg-icon configure" viewBox="0 0 16 16">
 | |
|         <path d="M8,0C7.6,0,7.3,0,6.9,0.1v2.2C6.1,2.5,5.4,2.8,4.8,3.2L3.2,1.6c-0.6,0.4-1.1,1-1.6,1.6l1.6,1.6C2.8,5.4,2.5,6.1,2.3,6.9H0.1C0,7.3,0,7.6,0,8c0,0.4,0,0.7,0.1,1.1h2.2c0.1,0.8,0.4,1.5,0.9,2.1l-1.6,1.6c0.4,0.6,1,1.1,1.6,1.6l1.6-1.6c0.6,0.4,1.4,0.7,2.1,0.9v2.2C7.3,16,7.6,16,8,16c0.4,0,0.7,0,1.1-0.1v-2.2c0.8-0.1,1.5-0.4,2.1-0.9l1.6,1.6c0.6-0.4,1.1-1,1.6-1.6l-1.6-1.6c0.4-0.6,0.7-1.4,0.9-2.1h2.2C16,8.7,16,8.4,16,8c0-0.4,0-0.7-0.1-1.1h-2.2c-0.1-0.8-0.4-1.5-0.9-2.1l1.6-1.6c-0.4-0.6-1-1.1-1.6-1.6l-1.6,1.6c-0.6-0.4-1.4-0.7-2.1-0.9V0.1C8.7,0,8.4,0,8,0z M8,4.3c2.1,0,3.7,1.7,3.7,3.7c0,0,0,0,0,0c0,2.1-1.7,3.7-3.7,3.7c0,0,0,0,0,0c-2.1,0-3.7-1.7-3.7-3.7c0,0,0,0,0,0C4.3,5.9,5.9,4.3,8,4.3C8,4.3,8,4.3,8,4.3z"></path>
 | |
|       </svg>
 | |
|     </span>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="updaterIcons">
 | |
|     <span class="updater-icons">
 | |
|       <span class="check-update" i18n-title="checkForUpdate">
 | |
|         <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|           <path d="M18,16.6l-3.1-3.1c0.5-0.7,0.9-1.5,1-2.5h-2.1c-0.4,1.7-2,3-3.9,3c-0.8,0-1.6-0.3-2.3-0.7
 | |
|                    L10,11H6.1H4.1H4v6l2.3-2.3c1,0.8,2.3,1.3,3.7,1.3c1.3,0,2.5-0.4,3.5-1.1l3.1,3.1L18,16.6z"/>
 | |
|           <path d="M10,6c0.8,0,1.6,0.3,2.3,0.7L10,9h3.9h2.1H16V3l-2.3,2.3C12.7,4.5,11.4,4,10,4
 | |
|                    C7,4,4.6,6.2,4.1,9h2.1C6.6,7.3,8.1,6,10,6z"/>
 | |
|         </svg>
 | |
|       </span>
 | |
|       <span class="update" i18n-title="installUpdate">
 | |
|         <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|           <polygon points="16,8 12,8 12,3 8,3 8,8 4,8 10,14 "/>
 | |
|           <rect shape-rendering="crispEdges" x="4" y="15" width="12" height="2"/>
 | |
|         </svg>
 | |
|       </span>
 | |
|       <span class="up-to-date" i18n-title="updateCheckSucceededNoUpdate">
 | |
|         <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|           <polygon points="15.83 4.75 8.76 11.82 5.2 8.26 3.51 9.95 8.76 15.19 17.52 6.43 15.83 4.75"/>
 | |
|         </svg>
 | |
|       </span>
 | |
|       <span class="updated" i18n-title="updateCompleted">
 | |
|         <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|           <polygon points="15.83 4.75 8.76 11.82 5.2 8.26 3.51 9.95 8.76 15.19 17.52 6.43 15.83 4.75"/>
 | |
|         </svg>
 | |
|       </span>
 | |
|       <span class="update-note"></span>
 | |
|     </span>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="appliesToTarget">
 | |
|     <span class="target"></span>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="appliesToSeparator">
 | |
|     <span class="sep">, </span>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="appliesToEverything">
 | |
|     <span class="target" i18n-text="appliesToEverything"></span>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="extraAppliesTo">
 | |
|     <details class="applies-to-extra">
 | |
|       <summary class="applies-to-extra-expander" i18n-text="appliesDisplayTruncatedSuffix"></summary>
 | |
|     </details>
 | |
|   </template>
 | |
| 
 | |
|   <script src="js/dom.js"></script>
 | |
|   <script src="js/messaging.js"></script>
 | |
|   <script src="js/prefs.js"></script>
 | |
|   <script src="content/apply.js"></script>
 | |
|   <script src="js/localization.js"></script>
 | |
|   <script src="manage/filters.js"></script>
 | |
|   <script src="manage/updater-ui.js"></script>
 | |
|   <script src="manage/object-diff.js"></script>
 | |
|   <script src="vendor-overwrites/colorpicker/colorpicker.js"></script>
 | |
|   <script src="manage/config-dialog.js"></script>
 | |
|   <script src="manage/manage.js"></script>
 | |
| </head>
 | |
| 
 | |
| <body id="stylus-manage" i18n-dragndrop-hint="dragDropMessage">
 | |
| 
 | |
| <div id="header">
 | |
|   <h1 id="manage-heading" i18n-text="manageHeading"></h1>
 | |
| 
 | |
|   <details id="filters" data-pref="manage.filters.expanded">
 | |
|     <summary><h2 i18n-text="manageFilters">: <span id="filters-stats"></span></h2></summary>
 | |
| 
 | |
|     <div class="filter-selection">
 | |
|       <label>
 | |
|         <div class="checkmate">
 | |
|           <input id="manage.onlyEnabled" type="checkbox"
 | |
|                  data-filter=".enabled"
 | |
|                  data-filter-hide=".disabled">
 | |
|           <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|         </div>
 | |
|       </label>
 | |
|       <div class="select-resizer">
 | |
|         <select id="manage.onlyEnabled.invert">
 | |
|           <option i18n-text="manageOnlyEnabled" value="false"></option>
 | |
|           <option i18n-text="manageOnlyDisabled" value="true"></option>
 | |
|         </select>
 | |
|         <svg class="svg-icon select-arrow"><use xlink:href="#svg-icon-select-arrow"/></svg>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="filter-selection">
 | |
|       <label>
 | |
|         <div class="checkmate">
 | |
|           <input id="manage.onlyLocal" type="checkbox"
 | |
|                  data-filter=":not(.updatable):not(.update-done)"
 | |
|                  data-filter-hide=".updatable, .update-done">
 | |
|           <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|         </div>
 | |
|       </label>
 | |
|       <div class="select-resizer">
 | |
|         <select id="manage.onlyLocal.invert" i18n-title="manageOnlyLocalTooltip">
 | |
|           <option i18n-text="manageOnlyLocal" value="false"></option>
 | |
|           <option i18n-text="manageOnlyExternal" value="true"></option>
 | |
|         </select>
 | |
|         <svg class="svg-icon select-arrow"><use xlink:href="#svg-icon-select-arrow"/></svg>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="filter-selection">
 | |
|       <label>
 | |
|         <div class="checkmate">
 | |
|           <input id="manage.onlyUsercss" type="checkbox"
 | |
|                  data-filter=".usercss"
 | |
|                  data-filter-hide=":not(.usercss)">
 | |
|           <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|         </div>
 | |
|       </label>
 | |
|       <div class="select-resizer">
 | |
|         <select id="manage.onlyUsercss.invert">
 | |
|           <option i18n-text="manageOnlyUsercss" value="false"></option>
 | |
|           <option i18n-text="manageOnlyNonUsercss" value="true"></option>
 | |
|         </select>
 | |
|         <svg class="svg-icon select-arrow"><use xlink:href="#svg-icon-select-arrow"/></svg>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|     <label id="onlyUpdates" class="hidden">
 | |
|       <input type="checkbox"
 | |
|              data-filter=".can-update, .update-problem, .update-done"
 | |
|              data-filter-hide=":not(.updatable):not(.update-done), .no-update:not(.update-problem)">
 | |
|       <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|       <span i18n-text="manageOnlyUpdates"></span>
 | |
|     </label>
 | |
| 
 | |
|     <input id="search" type="search" i18n-placeholder="searchStyles" spellcheck="false"
 | |
|            i18n-title="searchStylesTooltip"
 | |
|            data-filter=":not(.not-matching)"
 | |
|            data-filter-hide=".not-matching">
 | |
| 
 | |
|   </details>
 | |
| 
 | |
|   <p class="nowrap">
 | |
|     <button id="check-all-updates" i18n-text="checkAllUpdates"><span id="update-progress"></span></button>
 | |
|     <span id="update-history" i18n-title="genericHistoryLabel">
 | |
|       <svg class="svg-icon" viewBox="0 0 20 20" i18n-alt="helpAlt">
 | |
|         <path d="M13,7H7V6h6Zm6,6.5A5.5,5.5,0,0,1,8.61,16H4V3H16V8.61A5.5,5.5,0,0,1,19,13.5ZM8,14c0-.16,0-.84,0-1H7V12H8.21a5.46,5.46,0,0,1,.39-1H7V10H9.26a5.55,5.55,0,0,1,1.09-1H7V8h7V5H6v9Zm10-.5A4.5,4.5,0,1,0,13.5,18,4.5,4.5,0,0,0,18,13.5ZM14,13V10H13v4h4V13Z"/>
 | |
|       </svg>
 | |
|     </span>
 | |
|   </p>
 | |
| 
 | |
|   <p>
 | |
|     <button id="apply-all-updates" class="hidden" i18n-text="applyAllUpdates"></button>
 | |
|     <span id="update-all-no-updates" class="hidden" i18n-text="updateAllCheckSucceededNoUpdate"></span>
 | |
|     <button id="check-all-updates-force" class="hidden" i18n-text="checkAllUpdatesForce"></button>
 | |
|   </p>
 | |
| 
 | |
|   <p id="add-style-wrapper">
 | |
|     <a href="edit.html">
 | |
|       <button id="add-style-label" i18n-text="addStyleLabel"></button>
 | |
|     </a>
 | |
|     <label id="newStyleAsUsercss-wrapper">
 | |
|       <input type="checkbox" id="newStyleAsUsercss">
 | |
|       <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|       <span i18n-text="manageNewStyleAsUsercss" i18n-title="optionsAdvancedNewStyleAsUsercss"></span>
 | |
|       <a id="usercss-wiki"
 | |
|          href="https://github.com/openstyles/stylus/wiki/Usercss"
 | |
|          i18n-title="externalUsercssDocument">
 | |
|         <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|           <path d="M4,4h5v2H6v8h8v-3h2v5H4V4z M11,3h6v6l-2-2l-4,4L9,9l4-4L11,3z"/>
 | |
|         </svg>
 | |
|       </a>
 | |
|     </label>
 | |
|   </p>
 | |
| 
 | |
|   <details id="options" data-pref="manage.options.expanded">
 | |
| 
 | |
|     <summary><h2 id="options-heading" i18n-text="optionsHeading"></h2></summary>
 | |
| 
 | |
|     <label>
 | |
|       <input id="manage.newUI" type="checkbox">
 | |
|       <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|       <span i18n-text="manageNewUI"></span>
 | |
|     </label>
 | |
| 
 | |
|     <div id="newUIoptions">
 | |
|       <div>
 | |
|         <label for="manage.newUI.favicons" i18n-text="manageFavicons">
 | |
|           <input id="manage.newUI.favicons" type="checkbox">
 | |
|           <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|         </label>
 | |
|         <svg class="svg-icon info" viewBox="0 0 14 16" i18n-alt="helpAlt" data-toggle-on-click="#faviconsHelp">
 | |
|           <path fill-rule="evenodd" d="M6.3 5.69a.942.942 0 0 1-.28-.7c0-.28.09-.52.28-.7.19-.18.42-.28.7-.28.28 0 .52.09.7.28.18.19.28.42.28.7 0 .28-.09.52-.28.7a1 1 0 0 1-.7.3c-.28 0-.52-.11-.7-.3zM8 7.99c-.02-.25-.11-.48-.31-.69-.2-.19-.42-.3-.69-.31H6c-.27.02-.48.13-.69.31-.2.2-.3.44-.31.69h1v3c.02.27.11.5.31.69.2.2.42.31.69.31h1c.27 0 .48-.11.69-.31.2-.19.3-.42.31-.69H8V7.98v.01zM7 2.3c-3.14 0-5.7 2.54-5.7 5.68 0 3.14 2.56 5.7 5.7 5.7s5.7-2.55 5.7-5.7c0-3.15-2.56-5.69-5.7-5.69v.01zM7 .98c3.86 0 7 3.14 7 7s-3.14 7-7 7-7-3.12-7-7 3.14-7 7-7z"></path>
 | |
|         </svg>
 | |
|         <div id="faviconsHelp" class="hidden" i18n-text="manageFaviconsHelp">
 | |
|           <div>
 | |
|             <label for="manage.newUI.faviconsGray" i18n-text="manageFaviconsGray">
 | |
|               <input id="manage.newUI.faviconsGray" type="checkbox">
 | |
|               <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|             </label>
 | |
|           </div>
 | |
|         </div>
 | |
|       </div>
 | |
|      <label><input id="manage.newUI.targets" type="number" min="1" max="99"><span i18n-text="manageMaxTargets"></span></label>
 | |
|     </div>
 | |
| 
 | |
|     <p>
 | |
|       <button id="manage-options-button" i18n-text="openOptionsManage"></button>
 | |
|       <button id="manage-shortcuts-button" class="chromium-only"
 | |
|               i18n-text="shortcuts"
 | |
|               i18n-title="shortcutsNote"></button>
 | |
|       <a id="find-editor-styles"
 | |
|          href="https://userstyles.org/styles/browse/chrome-extension"
 | |
|          i18n-title="editorStylesButton"
 | |
|          target="_blank"><button i18n-text="cm_theme"></button></a>
 | |
|     </p>
 | |
| 
 | |
|   </details>
 | |
| 
 | |
|   <details id="backup" data-pref="manage.backup.expanded">
 | |
|     <summary><h2 id="backup-title" i18n-text="backupButtons"></h2></summary>
 | |
|     <span id="backup-message" i18n-text="backupMessage"></span>
 | |
|     <p>
 | |
|       <button id="file-all-styles" i18n-text="bckpInstStyles"></button>
 | |
|       <button id="unfile-all-styles" i18n-text="retrieveBckp"></button>
 | |
|     </p>
 | |
|   </details>
 | |
| 
 | |
|   <p id="manage-text" i18n-html="manageText"></p>
 | |
| 
 | |
| </div>
 | |
| 
 | |
| <div id="installed"></div>
 | |
| 
 | |
| <script src="manage/import-export.js"></script>
 | |
| <script src="msgbox/msgbox.js"></script>
 | |
| <script src="manage/incremental-search.js" async></script>
 | |
| 
 | |
| <svg xmlns="http://www.w3.org/2000/svg" style="display: none !important;">
 | |
|   <symbol id="svg-icon-checked" viewBox="0 0 1000 1000">
 | |
|     <path fill-rule="evenodd" d="M983.2,184.3L853,69.8c-4-3.5-9.3-5.3-14.5-5c-5.3,0.4-10.3,2.8-13.8,6.8L352.3,609.2L184.4,386.9c-3.2-4.2-8-7-13.2-7.8c-5.3-0.8-10.6,0.6-14.9,3.9L18,487.5c-8.8,6.7-10.6,19.3-3.9,28.1L325,927.2c3.6,4.8,9.3,7.7,15.3,8c0.2,0,0.5,0,0.7,0c5.8,0,11.3-2.5,15.1-6.8L985,212.6C992.3,204.3,991.5,191.6,983.2,184.3z"/>
 | |
|   </symbol>
 | |
| 
 | |
|   <symbol id="svg-icon-select-arrow" viewBox="0 0 1792 1792">
 | |
|     <path fill-rule="evenodd" d="M1408 704q0 26-19 45l-448 448q-19 19-45 19t-45-19l-448-448q-19-19-19-45t19-45 45-19h896q26 0 45 19t19 45z"/>
 | |
|   </symbol>
 | |
| </svg>
 | |
| 
 | |
| </body>
 | |
| </html>
 |