pxl
👾 An adjustable framework-ish static site theme with sensible defaults and nice looks. (ˈpik-səl)
Note: This project is under heavy development, markup structure are subject to change till first major version bump. Expect to changes may break styles/scripts between version tags. Use it only if you know what you're doing.
Features
- 🥇 HTML & Semantic CSS first, JavaScript with zero-framework later for responsive layouts, accessibility features only (a.k.a. Progressive Enchancement)
- Improved legibility with vertical rhythm, modular scale, responsive text contrast
- Basic bidirectional support with CSS logical properties
- CSS reset by Sanitize.css
- Layout Primitives from Every Layout
- 🎈 11ty-compatible templates written in Liquid template language
- Plain version of templates are processed by PostHTML and compatible plugins
- 🌗 Light and dark mode support
- Auto selects based on system preference first, lets you toggle theme with drkmd.js
- Each mode has their own color scheme preference like Solarized, Gruvbox, One Dark UI…
- Each color scheme has different shades and tones of layers and 6 + 2 hues that is converted and edited from Tinted Theming base16 schemes
- 🎛 Objects and components with lots of style modifiers
- Container make-ups like border/outline (as
box-shadow
) thickness, corner roundness, shadow/emboss effects, - Responsive masonry layout and navigation component in homepage layout by default
- Optional external backgrounds for adding blending, grain/gradient effects that is full-sized fixed in all platforms.
- BEM class naming with chainable modifier and other tweaks for making code readable to both humans and web browsers.
- Container make-ups like border/outline (as
- 👷 Building (PostCSS + Lightning CSS, PostHTML), validation (html-validate, biome), optimization (htmlnano, swc, svgo, Lightning CSS, sharp) and file watching (via chokidar) tasks for markup, style, script and media files in NPM scripts
- ⚡️ Local, live and minimal dev server from 11ty
Demos
Setup
📦 Build from Source
Prerequisities
- Node.js 18 LTS, 20 LTS or later
git
pnpm
(ornpm
if you know what you're doing)
Note: On Windows, install WSL or Git for Windows to work with tasks that depends on Node modules and shell commands. If you go with Git for Windows, set this configuration. pnpm (or npm) config set script-shell "C:\\Program Files\\git\\bin\\bash.exe"
Open a terminal emulator (In Windows, right-click on start menu and select "Windows PowerShell" or in macOS, press ⌘+Space
and type "Terminal.app") and follow commands below:
# Clone the repository and change directory
git clone https://github.com/egeesin/pxl && cd pxl
# Install local Node modules of the repository
pnpm i # or "npm i"
# Note: If you're using npm, find and replace all "pnpm run" matches
# with "npm run" in package.json via a code editor or grep/sed.
# Generate your first build (pnpm build) and start dev server (pnpm watch)
pnpm start # or "npm start"
# Once server is running, type "http://localhost:3000" or
# "http://127.0.0.1:3000" in the address bar of a web browser. For testing
# dev server in different devices on local network, check the terminal log
# to access alternative host (usually begins with 192.168.1.1XX:3000)
☁️ Deployment
Warning: None of those deployment options are tested yet. Use it if you know what you're doing.
- Production branch:
main
- Build command:
pnpm build
- Development command:
pnpm build
- Install command:
pnpm i
- Build directory:
dist
🐙 Download Build Artifact
- Select Actions tab in main repository page.
- Find and click on the latest successful workflow run with the green checkmark at the top of the list.
- Scroll to the bottom and download build artifacts (
dist/
).
Usage
After you've cloned/forked this project in Setup section, follow the steps below:
🧹 Cleanup Steps
- [ ] Clear author, repository, funding inside
package.json
. - [ ] Clear files inside
view/media/
andview/_content/blog/article/
(Keep one if you need a dummy Markdown post to copy new posts from.) - [ ] (Optional) Remove
plain/
and set Node environment as "production" if you're not interested in testing with theme components. (All tasks contains "plain" must be skipped in build command!) - [ ] (Optional) If you're not using the built-in icon set, clear files inside
src/icon/
as well. - [ ] More steps coming soon…
✅ Essentials Checklist
- [ ] For global site info like title, favicon, author, social links, edit
view/_data/site.json
. - [ ] For navigation items, edit
view/_data/nav.json
. - [ ] For post content, import your Markdown files to
view/_content/blog/article/
. (e.g../2024-02-24-post-title.md
) Make sure it has identical front matter keys in example Markdown post. If you're migrating from WordPress, in admin dashboard, export XML backup of your posts to convert it as bulk Markdown files. - [ ] (Optional) For making site Progressive Web App (PWA), edit
view/app.webmanifest.liquid
- [ ] (Optional) To override CSS styles, edit
static/style/shame.css
. Also, you can make another CSS file as long as you don't forget to@import
it instatic/style/index.css
.@import-glob
is also allowed. - [ ] More steps coming soon…
🎨 Theme Modification
- [ ] Discover modifications as seen in here.
- [ ] Edit
html_classes
andbody_classes
part inview/_data/site.json
according to your likings. - [ ] (Optional) Use front matter keys such as
append_html_class
orappend_body_class
to force theme modification per page. - [ ] More steps coming soon…
🖥️ CLI Scripts
pnpm build
: Build production/dev directorypnpm watch
: Watch production/dev directory and serve dev serverpnpm upmod
: Update dependencies and package.jsonpnpm debug:11ty
: Output debug messages from Eleventy build taskpnpm "/^optimize:.*/"
: Execute all run scripts that begins with "optimize:" in parallel with nice output.pnpm exec browserslist | pbcopy
: Copies the list of min. supported browser versions to your clipboard so you can easily import this to Can I Use? as a new set. (Works in macOS with shell env. To use different clipboard tool replace "pbcopy" part) Note: Check more NPM run scripts inpackage.json
Related 3rd Party Commands
cloc <path-to-directory> --exclude-dir=node_modules,tmp,dist,.git,utility --exclude-ext=svg,png,jpg,jpeg,webp,tif,ico
: If you havecloc
, calculate total count of lines of the input.
🔑 Environment Variable
WEBMENTION_IO_TOKEN
Design
Initially, pxl is built as a personal web theme for blogging, portfolio and various content types. But as development kept going, different CSS methodologies and design systems has been applied to handle complexity and scalability.
CSS Methodology
By chronologic order, BEM (block--element__modifier
) naming convention, ITCSS (Inverted Triangle CSS) file structure, BEMIT (BEM + ITCSS) and other transparent UI namespaces from Harry Roberts, chainable modifiers from BEM (BEVM) and Intrinsic Web Design (influenced by Jen Simmons, Heydon Pickering & Andy Bell) are the designs pxl based on.
Directory Structure
Root directory contains information on metadata of this repository, which files to exclude, the license and this "README" page.
Inside
view/
directory, there are blog/website templates written with Liquid on top of HTML or Markdown content, JSON global website data, transform/filter scripts and CMS media files to be processed by framework-agnostic static site generator tool called 11ty. This directory is required for production.- Inside
static/
, there are stylesheets, scripts, vector icons, and placeholder images. Stylesheets (static/style
) are processed by PostCSS plugins + LightningCSS (as a PostCSS plugin) and also has sub-directories in order to emphasize and categorize different scopes of CSS.static/style/index.css
is the main file of all styles. With postcss-import and postcss-import-glob plugins, each categorized styles in corresponding subdirectory that is specified with globs are imported and concatenated with alphabetical order into single CSS file while building.static/style/_vendor/
or any other 3rd party CSS files sourced fromnode_modules
are for including CSS Reset beforehand.- Styles inside
static/style/abstract/
includes mixins, custom properties (variables), animation declarations and lots of color schemes for light/dark mode. These styles affects the look, spacing, typography of every page no matter what's inside the markup. static/style/base/
includes opinionated CSS resets, theme modifiers, default HTML styles like forms, inline elements, grid layouts and reusable components.static/style/class/
includes slightly concrete components like navigations, cards, frames, headers and external background frames.static/style/shame.css
has bleeding edge, experimental, uncategorized styles. Style declarations fromshame.css
tend to be renamed, deleted or moved to relevant CSS file in the future.
static/script/
has client-side functions and event listeners to apply certain style modifiers of navigation and rusty grid component based on viewport size or update ARIA attributes of essential elements for better accessibility in screen readers.main.js
is for production andtest.js
is for development only.static/asset/
has essential media files such as webfont and placeholder images.static/icon/
has SVG vector files exported from a Affinity Designer template file (not included on this repository yet). Those are for processing into a single<symbol>
spritesheet later.config/
is a place to keep all configurations of Node modules capable of checking, watching, building and optimizing source files there.Plain HTML files in
plain/
directory are for development and partials to processed by PostHTML plugins in order to decrease repeating markup and ease editing header/footer. The directory includes basic structures of various components, layouts with dummy content, color table, kitchen sink of all HTML elements. This directory is optional for production if you want to review or tinker with existing plain HTML files to make custom designs on a template language other than Liquid.plain/_include/
are the partials I mentioned earlier.- Templates in
plain/class/
contains the markup of reusable components, grids and layout primitives. plain/example/
includes examples of color scheme table, all classless HTML5 elements and icon preview.
Interpretation on Methodologies
The directory and specificity hierarchy from ITCSS, block and element namings from BEM, chainable modifiers from BEVM), camelCase name groups from ABEM are the chosen designs that are applied as it is.
Harry Roberts' namespaces (for objects, components, utilities, theme, scope, JS states, hacks) from BEMIT and Intrinsic Web Design are influenced designs that needed to be tinkered with or picked only the distinctive parts of it for making it sensible to co-exist with other designs and making this project accessible.
Typography
Most inline elements like paragraph and headings are sized based on a set modular scale. Each element has single vertical spacing unit or multiples (var(--typeScale…)
) to keep vertical rhythm intact throughout the whole page.
Default fonts are subset and OpenType feature/stylistic set frozen version of both Inter and Iosevka. Fallbacks are system font stack but there are different font stacks that should work on popular operating systems for different styles. Check static/style/abstract/01-font.css
for different font stacks.
Media Breakpoints for Responsive Design
By default, mobile-first responsive design approach is being used and expand through different screen sizes that fits different human ergonomics.
- 🤝 wrist (smartwatches, <2inch),
- 🤲 palm (smartphones, "phablets", ≥640px),
- 🦵 lap (tablets on portrait mode, ≥960px),
- 🖥️ desk (tablets on landscape mode, laptops, desktop PCs, ≥1280px) and,
- exaggarated custom media properties like:
- 🖼️ wall (desktop PCs, full HD monitors, ≥1600px)
- 🏬 mall (2K monitors, ≥1920px) and,
- 🦖 titan (ultra-wide monitors, 4K displays, ≥2400px)
Browser Support
All web browsers that has 0.5% or higher global usage (except Opera Mini and any other deprecated browsers) are supported. Review the query from browserslist
key in package.json. The up-to-date list of supported browsers shown here.
License
This project is under GNU GPL 3.0 license.