* rework/simplify external links * remove title from svg (i) icon as it randomly shows instead of the parent's title * ensure original element isn't focused when showing modal * center more help modals
		
			
				
	
	
		
			375 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			375 lines
		
	
	
		
			16 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">
 | |
| 
 | |
|   <!-- 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">
 | |
|            
 | |
|           <span class="style-info" data-type="version"></span>
 | |
|         </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" tabindex="-1"></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>
 | |
|         <button class="configure-usercss" i18n-text="configureStyle"></button>
 | |
|         <span class="update-note"></span>
 | |
|       </p>
 | |
|     </div>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="styleNewUI">
 | |
|     <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">
 | |
|            
 | |
|           <span class="style-info" data-type="version"></span>
 | |
|         </a>
 | |
|       </h2>
 | |
|       <p class="actions">
 | |
|         <a target="_blank" class="homepage" tabindex="0"></a>
 | |
|         <a class="delete" i18n-title="deleteStyleLabel" tabindex="0">
 | |
|           <svg class="svg-icon" 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>
 | |
|         </a>
 | |
|       </p>
 | |
|       <p class="style-info" data-type="age"></p>
 | |
|       <div class="applies-to">
 | |
|         <div class="targets"></div>
 | |
|         <a class="expander" tabindex="0">...</a>
 | |
|       </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">
 | |
|     <a class="configure-usercss" i18n-title="configureStyle" tabindex="0">
 | |
|       <svg class="svg-icon config"><use xlink:href="#svg-icon-config"></use></svg>
 | |
|     </a>
 | |
|   </template>
 | |
| 
 | |
|   <template data-id="updaterIcons">
 | |
|     <span class="updater-icons">
 | |
|       <a class="check-update" i18n-title="checkForUpdate" tabindex="0">
 | |
|         <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>
 | |
|       </a>
 | |
|       <a class="update" i18n-title="installUpdate" tabindex="0">
 | |
|         <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>
 | |
|       </a>
 | |
|       <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/polyfill.js"></script>
 | |
|   <script src="js/msg.js"></script>
 | |
|   <script src="js/toolbox.js"></script>
 | |
|   <script src="js/prefs.js"></script>
 | |
|   <script src="js/dom.js"></script>
 | |
|   <script src="js/localization.js"></script>
 | |
|   <script src="js/router.js"></script>
 | |
| 
 | |
|   <script src="content/style-injector.js"></script>
 | |
|   <script src="content/apply.js"></script>
 | |
| 
 | |
|   <script src="manage/events.js"></script>
 | |
|   <script src="manage/filters.js"></script>
 | |
|   <script src="manage/render.js"></script>
 | |
|   <script src="manage/sorter.js"></script>
 | |
|   <script src="manage/manage.js"></script>
 | |
| 
 | |
|   <link rel="stylesheet" href="manage/manage.css">
 | |
| </head>
 | |
| 
 | |
| <body id="stylus-manage" i18n-dragndrop-hint="dragDropMessage">
 | |
| 
 | |
| <div id="header">
 | |
|   <h1 id="manage-heading" i18n-text="manageHeading"></h1>
 | |
| 
 | |
|   <div id="manage-settings">
 | |
|     <div class="settings-column">
 | |
|       <details id="filters" data-pref="manage.filters.expanded">
 | |
|         <summary>
 | |
|           <h2 i18n-text="manageFilters">:
 | |
|             <div class="filter-stats-wrapper">
 | |
|               <span id="filters-stats"></span>
 | |
|               <a id="reset-filters" tabindex="0">
 | |
|                 <svg class="svg-icon" viewBox="0 0 20 20">
 | |
|                   <title i18n-text="genericResetLabel"></title>
 | |
|                   <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>
 | |
|               </a>
 | |
|             </div>
 | |
|           </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" class="fit-width">
 | |
|               <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" class="fit-width">
 | |
|               <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" class="fit-width">
 | |
|               <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="only-updates" 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),
 | |
|                                    .updatable:not(.can-update):not(.update-problem):not(.update-done)">
 | |
|           <svg class="svg-icon checked"><use xlink:href="#svg-icon-checked"/></svg>
 | |
|           <span i18n-text="manageOnlyUpdates"></span>
 | |
|         </label>
 | |
| 
 | |
|         <div id="search-wrapper">
 | |
|           <input id="search" type="search" i18n-placeholder="search" spellcheck="false"
 | |
|                  data-filter=":not(.not-matching)"
 | |
|                  data-filter-hide=".not-matching">
 | |
|           <div class="select-wrapper">
 | |
|             <select id="searchMode" class="fit-width">
 | |
|               <option i18n-text="searchStylesName" value="name"></option>
 | |
|               <option i18n-text="searchStylesMeta" value="meta" selected></option>
 | |
|               <option i18n-text="searchStylesCode" value="code"></option>
 | |
|               <option i18n-text="searchStylesMatchUrl" value="url"></option>
 | |
|               <option i18n-text="searchStylesAll" value="all"></option>
 | |
|             </select>
 | |
|             <svg class="svg-icon select-arrow"><use xlink:href="#svg-icon-select-arrow"/></svg>
 | |
|           </div>
 | |
|           <a id="search-help" tabindex="0">
 | |
|             <svg class="svg-icon info"><use xlink:href="#svg-icon-help"/></svg>
 | |
|           </a>
 | |
|         </div>
 | |
| 
 | |
|       </details>
 | |
| 
 | |
|       <div id="sort-wrapper">
 | |
|         <div class="sorter-selection" i18n-title="sortLabel">
 | |
|           <select id="manage.newUI.sort"></select>
 | |
|           <svg class="svg-icon select-arrow"><use xlink:href="#svg-icon-select-arrow"/></svg>
 | |
|         </div>
 | |
|         <a id="sorter-help" tabindex="0">
 | |
|           <svg class="svg-icon info"><use xlink:href="#svg-icon-help"/></svg>
 | |
|         </a>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="settings-column">
 | |
|       <details id="actions" data-pref="manage.actions.expanded">
 | |
|         <summary><h2 i18n-text="optionsActions"></h2></summary>
 | |
|         <div id="update-check">
 | |
|           <button id="check-all-updates" i18n-text="checkAllUpdates">
 | |
|             <span id="update-progress"></span>
 | |
|           </button>
 | |
|           <a id="update-history" i18n-title="genericHistoryLabel" tabindex="0">
 | |
|             <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>
 | |
|           </a>
 | |
|         </div>
 | |
| 
 | |
|         <div id="update-all">
 | |
|           <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>
 | |
|         </div>
 | |
| 
 | |
|         <div id="add-style-wrapper">
 | |
|           <a href="edit.html">
 | |
|             <button id="add-style-label" i18n-text="addStyleLabel" tabindex="-1"></button>
 | |
|           </a>
 | |
|           <label id="add-style-as-usercss-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>
 | |
|         </div>
 | |
| 
 | |
|         <button id="manage-options-button" i18n-text="openOptions"></button>
 | |
|       </details>
 | |
|     </div>
 | |
| 
 | |
|     <div class="settings-column">
 | |
|       <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>
 | |
|         <div id="backup-buttons">
 | |
|           <button id="file-all-styles" i18n-text="exportLabel"></button>
 | |
|           <button id="unfile-all-styles" i18n-text="importLabel"></button>
 | |
|           <button id="sync-styles" i18n-text="optionsCustomizeSync"></button>
 | |
|         </div>
 | |
|       </details>
 | |
| 
 | |
|       <div id="manage-text">
 | |
|         <span>
 | |
|           <a href="https://userstyles.world/" target="_blank" i18n-text="linkGetShareStyles"></a>
 | |
|           <a tabindex="0" i18n-title="linkGetShareStylesInfo" data-cmd="note">
 | |
|             <svg class="svg-icon info"><use xlink:href="#svg-icon-help"/></svg>
 | |
|           </a>
 | |
|         </span>
 | |
|         <span>
 | |
|           <a href="https://33kk.github.io/uso-archive/" target="_blank" i18n-text="linkGetStyles"></a>
 | |
|           <a tabindex="0" i18n-title="linkGetStylesInfo" data-cmd="note">
 | |
|             <svg class="svg-icon info"><use xlink:href="#svg-icon-help"/></svg>
 | |
|           </a>
 | |
|         </span>
 | |
|         <span><a href="https://add0n.com/stylus.html#features" target="_blank" i18n-text="linkGetHelp"></a></span>
 | |
|         <span><a href="https://github.com/openstyles/stylus/wiki" target="_blank" i18n-text="linkStylusWiki"></a></span>
 | |
|         <span><a href="https://www.transifex.com/github-7/Stylus" target="_blank" i18n-text="linkTranslate"></a></span>
 | |
|       </div>
 | |
|     </div>
 | |
|   </div>
 | |
| 
 | |
| </div>
 | |
| 
 | |
| <div id="installed"></div>
 | |
| 
 | |
| <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>
 | |
| 
 | |
|   <symbol id="svg-icon-help" viewBox="0 0 14 16">
 | |
|     <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>
 | |
|   </symbol>
 | |
| 
 | |
|   <symbol id="svg-icon-config" viewBox="0 0 16 16">
 | |
|     <path d="M13.3,12.8l1.5-2.6l-2.2-1.5c0-0.2,0.1-0.5,0.1-0.7c0-0.2,0-0.5-0.1-0.7l2.2-1.5l-1.5-2.6l-2.4,1.2 c-0.4-0.3-0.8-0.5-1.2-0.7L9.5,1h-3L6.3,3.7C5.9,3.8,5.5,4.1,5.1,4.4L2.7,3.2L1.2,5.8l2.2,1.5c0,0.2-0.1,0.5-0.1,0.7 c0,0.2,0,0.5,0.1,0.7l-2.2,1.5l1.5,2.6l2.4-1.2c0.4,0.3,0.8,0.5,1.2,0.7L6.5,15h3l0.2-2.7c0.4-0.2,0.8-0.4,1.2-0.7L13.3,12.8z  M8,10.3c-1.3,0-2.3-1-2.3-2.3c0-1.3,1-2.3,2.3-2.3c1.3,0,2.3,1,2.3,2.3C10.3,9.3,9.3,10.3,8,10.3z"/>
 | |
|   </symbol>
 | |
| </svg>
 | |
| 
 | |
| </body>
 | |
| </html>
 |