|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
h1 { |
|
|
h1 { |
|
|
border-bottom: 1px solid #ddd; |
|
|
border-bottom: 1px solid #ddd; |
|
|
|
|
|
margin: 0.5em 0; |
|
|
} |
|
|
} |
|
|
h2 { |
|
|
h2 { |
|
|
margin: 0; |
|
|
margin: 0; |
|
|
|
|
|
|
|
|
font-family: Inconsolata, Courier, monospace; |
|
|
font-family: Inconsolata, Courier, monospace; |
|
|
font-size: 1.125rem; |
|
|
font-size: 1.125rem; |
|
|
width: 100%; |
|
|
width: 100%; |
|
|
|
|
|
display: block; |
|
|
} |
|
|
} |
|
|
#matchingPatterns textarea { |
|
|
#matchingPatterns textarea { |
|
|
min-height: 300px; |
|
|
min-height: 300px; |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
form { |
|
|
form { |
|
|
text-align: right; |
|
|
text-align: right; |
|
|
margin: 0 0 1em 0; |
|
|
|
|
|
|
|
|
margin: 0 0 2.5em 0; |
|
|
display: flex; |
|
|
display: flex; |
|
|
justify-content: flex-end; |
|
|
|
|
|
align-items: center; |
|
|
align-items: center; |
|
|
} |
|
|
} |
|
|
|
|
|
form .buttons { |
|
|
|
|
|
display: flex; |
|
|
|
|
|
align-items: center; |
|
|
|
|
|
justify-content: flex-end; |
|
|
|
|
|
flex: 1 1 0; |
|
|
|
|
|
} |
|
|
button { |
|
|
button { |
|
|
-webkit-appearance: none; |
|
|
-webkit-appearance: none; |
|
|
-moz-appearance: none; |
|
|
-moz-appearance: none; |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
button:disabled { |
|
|
button:disabled { |
|
|
background-color: #777; |
|
|
background-color: #777; |
|
|
opacity: 0.5; |
|
|
|
|
|
|
|
|
opacity: 0.3; |
|
|
|
|
|
} |
|
|
|
|
|
input#whitelist-mode { |
|
|
|
|
|
display: block; |
|
|
|
|
|
-webkit-appearance: none; |
|
|
|
|
|
-moz-appearance: none; |
|
|
|
|
|
border: 1px solid #000; |
|
|
|
|
|
font-size: 1rem; |
|
|
|
|
|
height: 2em; |
|
|
|
|
|
width: 4em; |
|
|
|
|
|
margin: 0 6px; |
|
|
|
|
|
background-color: #000; |
|
|
|
|
|
box-shadow: |
|
|
|
|
|
-2em 0 0 1px #fff inset, |
|
|
|
|
|
0 0 0 3px #fff inset; |
|
|
|
|
|
} |
|
|
|
|
|
input#whitelist-mode:checked { |
|
|
|
|
|
border: 1px solid #fff; |
|
|
|
|
|
background-color: #fff; |
|
|
|
|
|
box-shadow: |
|
|
|
|
|
2em 0 0 1px #000 inset, |
|
|
|
|
|
0 0 0 3px #000 inset; |
|
|
|
|
|
} |
|
|
|
|
|
input#whitelist-mode, |
|
|
|
|
|
.mode-select-container span { |
|
|
|
|
|
cursor: pointer; |
|
|
|
|
|
} |
|
|
|
|
|
.mode-select-container { |
|
|
|
|
|
white-space: nowrap; |
|
|
|
|
|
display: flex; |
|
|
|
|
|
align-items: center; |
|
|
|
|
|
align-self: flex-start; |
|
|
|
|
|
border: 1px solid #ddd; |
|
|
|
|
|
padding: 8px 10px; |
|
|
|
|
|
cursor: default; |
|
|
|
|
|
background-color: #fff; |
|
|
|
|
|
} |
|
|
|
|
|
.mode-select-container.whitelist { |
|
|
|
|
|
background-color: #000; |
|
|
|
|
|
color: #fff; |
|
|
|
|
|
} |
|
|
|
|
|
.mode-select-container:not(.whitelist) .blacklist-mode-label, |
|
|
|
|
|
.mode-select-container.whitelist .whitelist-mode-label { |
|
|
|
|
|
border-bottom: 1px dotted currentColor; |
|
|
|
|
|
} |
|
|
|
|
|
.mode-select-container span::selection { |
|
|
|
|
|
background-color: transparent; |
|
|
|
|
|
} |
|
|
|
|
|
.mode-select-container span.disabled { |
|
|
|
|
|
pointer-events: none; |
|
|
|
|
|
} |
|
|
|
|
|
.mode-select-container span:not(.disabled):hover { |
|
|
|
|
|
border-bottom: 1px solid currentColor; |
|
|
|
|
|
} |
|
|
|
|
|
form button:not(:disabled):hover { |
|
|
|
|
|
text-shadow: |
|
|
|
|
|
0 0 1px #fff, |
|
|
|
|
|
0 0 3px #fff, |
|
|
|
|
|
0 0 5px #fff; |
|
|
|
|
|
cursor: pointer; |
|
|
|
|
|
} |
|
|
|
|
|
#matchingPatterns.disabled h2 { |
|
|
|
|
|
color: rgba(0,0,0,0.15); |
|
|
|
|
|
} |
|
|
|
|
|
#matchingPatterns.disabled p { |
|
|
|
|
|
opacity: 0.2; |
|
|
|
|
|
} |
|
|
|
|
|
#matchingPatterns.disabled .textarea-container { |
|
|
|
|
|
position: relative; |
|
|
|
|
|
} |
|
|
|
|
|
#matchingPatterns.disabled .textarea-container::before { |
|
|
|
|
|
content: ".*"; |
|
|
|
|
|
display: flex; |
|
|
|
|
|
position: absolute; |
|
|
|
|
|
background-color: rgba(232,232,232,0.9); |
|
|
|
|
|
width: 100%; |
|
|
|
|
|
height: 100%; |
|
|
|
|
|
z-index: 1; |
|
|
|
|
|
justify-content: center; |
|
|
|
|
|
align-items: center; |
|
|
|
|
|
font-family: Inconsolata, Courier, monospace; |
|
|
|
|
|
font-size: 4em; |
|
|
} |
|
|
} |
|
|
body > p { |
|
|
body > p { |
|
|
padding: 0 15px; |
|
|
padding: 0 15px; |
|
|
|
|
|
|
|
|
<body> |
|
|
<body> |
|
|
<h1>Always Kill Sticky</h1> |
|
|
<h1>Always Kill Sticky</h1> |
|
|
<form> |
|
|
<form> |
|
|
<button disabled type='button' class='reset-button'>Reset</button> |
|
|
|
|
|
<button disabled type='button' class='save-button'>Save</button> |
|
|
|
|
|
|
|
|
<span class='mode-select-container'> |
|
|
|
|
|
<span class='blacklist-mode-label'>Blacklist mode</span> |
|
|
|
|
|
<input type='checkbox' id='whitelist-mode'></input> |
|
|
|
|
|
<span class='whitelist-mode-label'>Whitelist mode</span> |
|
|
|
|
|
</span> |
|
|
|
|
|
<span class='buttons'> |
|
|
|
|
|
<button disabled type='button' class='reset-button'>Reset</button> |
|
|
|
|
|
<button disabled type='button' class='save-button'>Save</button> |
|
|
|
|
|
</span> |
|
|
</form> |
|
|
</form> |
|
|
<div id='matchingPatterns'> |
|
|
<div id='matchingPatterns'> |
|
|
<h2>Matching patterns</h2> |
|
|
<h2>Matching patterns</h2> |
|
|
<p>Kill stickies on web page URLs matching the following <a href='https://regexr.com/' rel='nofollow'>regular expressions</a> (one per line):</p> |
|
|
<p>Kill stickies on web page URLs matching the following <a href='https://regexr.com/' rel='nofollow'>regular expressions</a> (one per line):</p> |
|
|
<textarea spellcheck="false"></textarea> |
|
|
|
|
|
|
|
|
<div class='textarea-container'> |
|
|
|
|
|
<textarea spellcheck="false"></textarea> |
|
|
|
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
<div id='exclusionPatterns'> |
|
|
<div id='exclusionPatterns'> |
|
|
<h2>Exclusion patterns</h2> |
|
|
<h2>Exclusion patterns</h2> |
|
|
<p>Do <strong>not</strong> kill stickies on web page URLs matching the following <a href='https://regexr.com/' rel='nofollow'>regular expressions</a> (one per line):</p> |
|
|
<p>Do <strong>not</strong> kill stickies on web page URLs matching the following <a href='https://regexr.com/' rel='nofollow'>regular expressions</a> (one per line):</p> |
|
|
<textarea spellcheck="false"></textarea> |
|
|
|
|
|
|
|
|
<div class='textarea-container'> |
|
|
|
|
|
<textarea spellcheck="false"></textarea> |
|
|
|
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
<p>NOTE: Exclusion patterns override matching patterns; if a page is <em>both</em> matched <em>and</em> excluded, stickies will <strong>not</strong> be killed on that page.</p> |
|
|
<p>NOTE: Exclusion patterns override matching patterns; if a page is <em>both</em> matched <em>and</em> excluded, stickies will <strong>not</strong> be killed on that page.</p> |
|
|
</body> |
|
|
</body> |