1
0
mirror of https://github.com/kognise/water.css.git synced 2025-10-24 18:06:09 +02:00

Globally set box-sizing to border-box (and improve code snippet copy button)

This commit is contained in:
Felix Mattick
2022-01-22 12:58:18 -06:00
parent 2ca1eee9cf
commit 9cf9e052ac
6 changed files with 40 additions and 24 deletions

View File

@@ -0,0 +1,11 @@
---
"water.css": major
---
Globally set box-sizing to border-box
This is a breaking change because of the potential to break many layouts/sites
We made this change because it makes many facets of writing CSS easier and more convenient
If it's an issue, you can apply `html { box-sizing: content-box; }`

2
dist/dark.css vendored
View File

@@ -237,5 +237,3 @@ tbody tr:nth-child(even) {
::-webkit-scrollbar-thumb:hover { ::-webkit-scrollbar-thumb:hover {
background: #415c73; background: #415c73;
} }
/*# sourceMappingURL=dark.css.map */

View File

@@ -327,18 +327,12 @@ for (const category of categories) {
const pre = document.createElement('pre') const pre = document.createElement('pre')
const code = document.createElement('code') const code = document.createElement('code')
code.innerText = snippet.code.trim() code.innerText = snippet.code.trim()
code.style.position = 'relative' pre.style.position = 'relative'
pre.appendChild(code)
const button = document.createElement('button') const button = document.createElement('button')
button.innerText = 'Copy' button.innerText = 'Copy'
Object.assign(button.style, { button.className = 'snippet-copy'
position: 'absolute',
top: '0',
right: '0',
margin: '6px',
padding: '8px'
})
let timeout = null let timeout = null
button.addEventListener('click', () => { button.addEventListener('click', () => {
navigator.clipboard.writeText(snippet.code.trim()) navigator.clipboard.writeText(snippet.code.trim())
@@ -347,9 +341,7 @@ for (const category of categories) {
timeout = setTimeout(() => { button.innerText = 'Copy' }, 1000) timeout = setTimeout(() => { button.innerText = 'Copy' }, 1000)
}) })
code.appendChild(button) pre.appendChild(button)
pre.appendChild(code)
demosContainer.appendChild(pre) demosContainer.appendChild(pre)
const details = document.createElement('details') const details = document.createElement('details')

View File

@@ -36,13 +36,6 @@
transition: transform 220ms cubic-bezier(0.175, 0.885, 0.32, 1) 220ms; transition: transform 220ms cubic-bezier(0.175, 0.885, 0.32, 1) 220ms;
} }
/* This is a really *really* evil hack to get around a half-char of overflow. */
@media only screen and (min-width: 840px) {
#link-snippet-container > pre > code {
overflow: hidden;
}
}
#link-snippet-container > pre[hidden] { #link-snippet-container > pre[hidden] {
display: block; display: block;
visibility: hidden; visibility: hidden;
@@ -69,7 +62,6 @@ body > footer {
justify-content: space-between; justify-content: space-between;
} }
/* Hmmm yes great class name */
.top-theme-form { .top-theme-form {
padding: 10px 0; padding: 10px 0;
top: 0; top: 0;
@@ -79,3 +71,16 @@ body > footer {
z-index: 999; z-index: 999;
background: var(--background-body); background: var(--background-body);
} }
.snippet-copy {
opacity: 0.5;
position: absolute;
top: 0;
right: 0;
margin: 6px;
padding: 8px;
}
.snippet-copy:hover {
opacity: 1;
}

View File

@@ -1,3 +1,13 @@
html {
box-sizing: border-box;
}
*,
*::before,
*::after {
box-sizing: inherit;
}
body { body {
font-family: font-family:
system-ui, system-ui,
@@ -31,5 +41,6 @@ textarea {
border-color var(--animation-duration) linear, border-color var(--animation-duration) linear,
color var(--animation-duration) linear, color var(--animation-duration) linear,
box-shadow var(--animation-duration) linear, box-shadow var(--animation-duration) linear,
transform var(--animation-duration) ease; transform var(--animation-duration) ease-in-out,
opacity var(--animation-duration) linear;
} }

View File

@@ -88,7 +88,6 @@ textarea {
textarea { textarea {
display: block; display: block;
margin-right: 0; margin-right: 0;
box-sizing: border-box;
resize: vertical; resize: vertical;
} }