Improve styles (#30)

This commit is contained in:
Drew Powers 2021-03-25 18:23:45 -06:00 committed by GitHub
parent 04a443a888
commit 11637df579
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 141 additions and 70 deletions

View file

@ -1,5 +1,6 @@
<style lang="scss"> <style lang="scss">
@use '../../public/css/var' as *; @use '../../public/css/var' as *;
@use '../../public/css/animations' as *;
.hero { .hero {
display: flex; display: flex;
@ -83,6 +84,8 @@
margin: 0 auto 0.75rem; margin: 0 auto 0.75rem;
font-weight: 900; font-weight: 900;
font-size: 3.5rem; font-size: 3.5rem;
font-weight: 700;
font-family: $heading;
line-height: 1; line-height: 1;
letter-spacing: -0.045em; letter-spacing: -0.045em;
text-align: center; text-align: center;
@ -99,6 +102,7 @@
margin: 0; margin: 0;
margin: auto; margin: auto;
font-weight: 500; font-weight: 500;
font-family: $heading;
font-size: 2rem; font-size: 2rem;
line-height: 1; line-height: 1;
letter-spacing: -1px; letter-spacing: -1px;
@ -108,6 +112,42 @@
font-size: 3rem; font-size: 3rem;
} }
} }
.copy-button {
display: flex;
flex: none;
align-items: center;
justify-content: center;
box-sizing: border-box;
min-width: 292px;
padding: 0.75rem 1.25rem;
padding-bottom: 0.75rem;
font-size: 100%;
font-family: Menlo, ui-monospace, SFMono-Regular, Monaco, Consolas,
Liberation Mono, Courier New, monospace;
line-height: 1.5rem;
background-color: white;
border: 1px solid #0006;
border-radius: 4px;
cursor: pointer;
@include animation-copy-button;
svg,
.faded {
color: #ccc;
transition: color 0.1s ease-out;
}
}
// I don't think this is used
.copy-button.active {
animation: pulse 0.5s;
animation-iteration-count: 1;
svg {
color: #ccc;
}
}
</style> </style>
<div class="hero"> <div class="hero">

View file

@ -120,11 +120,11 @@
</li> </li>
<li class="section"> <li class="section">
<a class="link" href="/plugins"><span class="section-header">Plugin Catalog</span></a> <a class="link" href="/plugins"><span class="header">Plugin Catalog</span></a>
</li> </li>
<li class="section"> <li class="section">
<a class="link" href="/news"><span class="section-header">Community & News</span></a> <a class="link" href="/news"><span class="header">Community & News</span></a>
</li> </li>
</ol> </ol>
</nav> </nav>

View file

@ -63,6 +63,7 @@ export let version: string = '3.1.2';
.logo { .logo {
display: flex; display: flex;
align-items: center;
grid-area: logo; grid-area: logo;
justify-content: center; justify-content: center;
padding: 0.5rem; padding: 0.5rem;
@ -76,6 +77,22 @@ export let version: string = '3.1.2';
} }
} }
.logo-icon {
display: block;
width: 1em;
height: 1em;
margin-right: 0.25em;
margin-bottom: 0.15rem;
fill: currentColor;
}
.logo-type {
font-weight: 700;
font-family: $heading;
letter-spacing: -0.03em;
padding-top: 0.2rem;
}
.mobile-open { .mobile-open {
display: flex; display: flex;
grid-area: mobile; grid-area: mobile;
@ -233,8 +250,8 @@ export let version: string = '3.1.2';
</path> </path>
</svg> </svg>
</button> </button>
<a class="logo snow-logo" href="/"> <a class="logo" href="/">
<svg class="snow-logo-icon" viewbox="0 0 640 512" version="1.1" xmlns="http://www.w3.org/2000/svg" <svg class="logo-icon" viewbox="0 0 640 512" version="1.1" xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"> xmlns:xlink="http://www.w3.org/1999/xlink">
<g transform="translate(-1.000000, 0.000000)" fill-rule="nonzero"> <g transform="translate(-1.000000, 0.000000)" fill-rule="nonzero">
<path <path

View file

@ -1,6 +1,6 @@
import { h, Fragment } from 'preact'; import { h, Fragment } from 'preact';
import { useEffect, useState } from 'preact/hooks'; import { useEffect, useState } from 'preact/hooks';
import * as Styles from './PluginSearchPage.module.css'; import Styles from './PluginSearchPage.module.css';
async function searchPlugins(val) { async function searchPlugins(val) {
const params3 = new URLSearchParams([ const params3 = new URLSearchParams([

View file

@ -4,6 +4,16 @@
padding: 0.5rem 0.5rem 0.5rem 48px; padding: 0.5rem 0.5rem 0.5rem 48px;
flex-direction: column; flex-direction: column;
position: relative; position: relative;
display: flex;
grid-column: span 1;
overflow: hidden;
font-family: Open Sans, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
Cantarell, Noto Sans, sans-serif, BlinkMacSystemFont, Segoe UI, Roboto,
sans-serif;
color: #1a202c;
-webkit-font-smoothing: antialiased;
box-sizing: border-box;
border: 1px solid #e2e8f0;
} }
.Card:nth-child(3n + 2) .Icon__Plugin { .Card:nth-child(3n + 2) .Icon__Plugin {

View file

@ -27,7 +27,7 @@ let description = 'Snowpack is a lightning-fast frontend build tool, designed fo
padding: 0.1em !important; padding: 0.1em !important;
list-style: none; list-style: none;
h3 { .bullet-heading {
margin: 0 0 0.25em 0; margin: 0 0 0.25em 0;
font-size: 1.25em; font-size: 1.25em;
} }
@ -78,7 +78,8 @@ let description = 'Snowpack is a lightning-fast frontend build tool, designed fo
</a> </a>
<div class="content markdown-body feature-list"> <div class="content markdown-body feature-list">
<div class="feature-list-top"> <div class="top">
<h2 id="what-is-snowpack%3F">What is Snowpack?</h2>
<p> <p>
<strong>Snowpack is a lightning-fast frontend build tool, designed <strong>Snowpack is a lightning-fast frontend build tool, designed
for the modern web.</strong> for the modern web.</strong>
@ -95,38 +96,38 @@ let description = 'Snowpack is a lightning-fast frontend build tool, designed fo
</p> </p>
</div> </div>
<ul class="feature-list-bullets"> <ul class="bullets">
<li class="feature-list-bullet"> <li class="bullet">
<h3>Instant startup</h3> <h3 class="bullet-heading">Instant startup</h3>
Snowpack's unbundled web development server Snowpack's unbundled web development server
<strong>starts up in 50ms or less</strong> <strong>starts up in 50ms or less</strong>
and stays fast in large projects. and stays fast in large projects.
</li> </li>
<li class="feature-list-bullet"> <li class="bullet">
<h3>Build once, cache forever</h3> <h3 class="bullet-heading">Build once, cache forever</h3>
Snowpack never builds the same file twice. Powered by Snowpack never builds the same file twice. Powered by
JavaScripts native module system (ESM) in the browser. JavaScripts native module system (ESM) in the browser.
</li> </li>
<li class="feature-list-bullet"> <li class="bullet">
<h3>HMR feat. Fast Refresh</h3> <h3 class="bullet-heading">HMR feat. Fast Refresh</h3>
No refresh required. See changes reflected instantly in the No refresh required. See changes reflected instantly in the
browser with browser with
<a href="/concepts/hot-module-replacement">HMR + Fast Refresh</a> <a href="/concepts/hot-module-replacement">HMR + Fast Refresh</a>
for React, Preact & Svelte. for React, Preact & Svelte.
</li> </li>
<li class="feature-list-bullet"> <li class="bullet">
<h3>Out-of-the-box support</h3> <h3 class="bullet-heading">Out-of-the-box support</h3>
Enjoy Snowpack's built-in support for JSX, TypeScript, React, Enjoy Snowpack's built-in support for JSX, TypeScript, React,
Preact, CSS Modules Preact, CSS Modules
<a href="/reference/supported-files">and more.</a> <a href="/reference/supported-files">and more.</a>
</li> </li>
<li class="feature-list-bullet"> <li class="bullet">
<h3>Optimize for production</h3> <h3 class="bullet-heading">Optimize for production</h3>
Build for production with built-in optimizations and plugin Build for production with built-in optimizations and plugin
support for your favorite bundlers. support for your favorite bundlers.
</li> </li>
<li class="feature-list-bullet"> <li class="bullet">
<h3>Plugins? Plugins!</h3> <h3 class="bullet-heading">Plugins? Plugins!</h3>
Babel? Sass? MDX? Browse the entire Babel? Sass? MDX? Browse the entire
<a href="/plugins">Snowpack Plugin Catalog</a> <a href="/plugins">Snowpack Plugin Catalog</a>
to connect your favorite build tool (or to connect your favorite build tool (or
@ -134,9 +135,9 @@ let description = 'Snowpack is a lightning-fast frontend build tool, designed fo
</li> </li>
</ul> </ul>
<div class="feature-list-buttons"> <div class="buttons">
<a href="/tutorials/quick-start" class="button button-primary feature-list-button">Get started</a> <a href="/tutorials/quick-start" class="button button-primary feature-button">Get started</a>
<a href="/concepts/how-snowpack-works" class="button feature-list-button">Learn more</a> <a href="/concepts/how-snowpack-works" class="button feature-button">Learn more</a>
</div> </div>
</div> </div>
</article> </article>

View file

@ -19,9 +19,6 @@ p {
line-height: 1.25; line-height: 1.25;
} }
.header-logo,
.header-snowpack,
.header-snowpack-subtitle,
.pretty-font, .pretty-font,
.version-number { .version-number {
font-weight: 600; font-weight: 600;

View file

@ -15,7 +15,6 @@
@use './components/card-grid'; @use './components/card-grid';
@use './components/container'; @use './components/container';
@use './components/icon'; @use './components/icon';
@use './components/logo';
@use './components/old'; @use './components/old';
@use './components/view'; @use './components/view';

View file

@ -1,29 +0,0 @@
@use '../var' as *;
/**
* Snowpack Logo
* That iconic mountain you know and love
*/
.snow-logo {
display: inline-flex;
align-items: center;
// -----------
// Components
// -----------
&-icon {
display: block;
width: 1em;
height: 1em;
margin-right: 0.25em;
fill: currentColor;
}
&-type {
font-weight: 700;
font-family: $heading;
letter-spacing: -0.03em;
}
}

View file

@ -126,6 +126,22 @@ export default function ({ filename, fileID }: { filename: string; fileID: strin
html: { html: {
Element: { Element: {
enter(node) { enter(node) {
if (node.name === 'style') {
// Same as ast.css (below)
const code = Array.isArray(node.children) ? node.children.map(({ data }: any) => data).join('\n') : '';
if (!code) return;
const langAttr = (node.attributes || []).find(({ name }: any) => name === 'lang');
styleNodes.push(node);
styleTransformPromises.push(
transformStyle(code, {
type: (langAttr && langAttr.value[0] && langAttr.value[0].data) || undefined,
filename,
fileID,
})
);
return;
}
// Find the root node to inject the <style> tag in later // Find the root node to inject the <style> tag in later
if (node.name === 'head') { if (node.name === 'head') {
rootNode = node; // If this is <head>, this is what we want. Always take this if found. However, this may not always exist (it wont for Component subtrees). rootNode = node; // If this is <head>, this is what we want. Always take this if found. However, this may not always exist (it wont for Component subtrees).
@ -144,10 +160,19 @@ export default function ({ filename, fileID }: { filename: string; fileID: strin
css: { css: {
Style: { Style: {
enter(node) { enter(node) {
// Same as ast.html (above)
// Note: this is duplicated from html because of the compiler were using; in a future version we should combine these
if (!node.content || !node.content.styles) return;
const code = node.content.styles; const code = node.content.styles;
const typeAttr = (node.attributes || []).find(({ name }: { name: string }) => name === 'lang'); const langAttr = (node.attributes || []).find(({ name }: any) => name === 'lang');
styleNodes.push(node); styleNodes.push(node);
styleTransformPromises.push(transformStyle(code, { type: (typeAttr && typeAttr.value[0] && typeAttr.value[0].raw) || undefined, filename, fileID })); styleTransformPromises.push(
transformStyle(code, {
type: (langAttr && langAttr.value[0] && langAttr.value[0].data) || undefined,
filename,
fileID,
})
);
// TODO: we should delete the old untransformed <style> node after were done. // TODO: we should delete the old untransformed <style> node after were done.
// However, the svelte parser left it in ast.css, not ast.html. At the final step, this just gets ignored, so it will be deleted, in a sense. // However, the svelte parser left it in ast.css, not ast.html. At the final step, this just gets ignored, so it will be deleted, in a sense.
@ -167,21 +192,32 @@ export default function ({ filename, fileID }: { filename: string; fileID: strin
// 1. transform <style> tags // 1. transform <style> tags
styleTransforms.forEach((result, n) => { styleTransforms.forEach((result, n) => {
if (styleNodes[n].attributes) { if (styleNodes[n].attributes) {
// Add to global CSS Module class list for step 2 // 1a. Add to global CSS Module class list for step 2
for (const [k, v] of result.cssModules) { for (const [k, v] of result.cssModules) {
allCssModules.set(k, v); allCssModules.set(k, v);
} }
// Update original <style> node with finished results // 1b. Inject final CSS
styleNodes[n].attributes = styleNodes[n].attributes.map((attr: any) => { const isHeadStyle = !styleNodes[n].content;
if (attr.name === 'type') { if (isHeadStyle) {
attr.value[0].raw = 'text/css'; // Note: <style> tags in <head> have different attributes/rules, because of the parser. Unknown why
attr.value[0].data = 'text/css'; (styleNodes[n].children as any) = [{ ...(styleNodes[n].children as any)[0], data: result.css }];
} } else {
return attr; styleNodes[n].content.styles = result.css;
}); }
// 3b. Update <style> attributes
const styleTypeIndex = styleNodes[n].attributes.findIndex(({ name }: any) => name === 'type');
if (styleTypeIndex !== -1) {
console.log(styleNodes[n].attributes[styleTypeIndex]);
styleNodes[n].attributes[styleTypeIndex].value[0].raw = 'text/css';
styleNodes[n].attributes[styleTypeIndex].value[0].data = 'text/css';
} else {
styleNodes[n].attributes.push({ name: 'type', type: 'Attribute', value: [{ type: 'Text', raw: 'text/css', data: 'text/css' }] });
}
const styleLangIndex = styleNodes[n].attributes.findIndex(({ name }: any) => name === 'lang');
if (styleLangIndex !== -1) styleNodes[n].attributes.splice(styleLangIndex, 1);
} }
styleNodes[n].content.styles = result.css;
}); });
// 2. inject finished <style> tags into root node // 2. inject finished <style> tags into root node