mirror of
https://github.com/kbenestad/mdcms.git
synced 2026-06-18 07:24:31 +00:00
Implements four new mdcms fenced-block types: tab-underline / tab, tab-filled, accordion-underline / accordion, accordion-filled Each block reads items: from a YAML body. Tab state and accordion open/close are managed with aria-selected / aria-expanded and data-open attributes. Markdown content inside each item is rendered with the same pipeline as the surrounding page. Adds computeDerivedTokens() — called on every applyTheme() — which computes --mdcms-bar, --mdcms-filled-bg/border/fg, --mdcms-strip-border from the active palette. Uses HSL chroma (S × (1-|2L-1|)) instead of raw HSL S for the bold-nav heuristic, avoiding a false-positive on near-white nav colours like the default #F8FAFC. Adds app/pages/tabs-accordions.md as a visual test page and docs/unreleased.md to track this change ahead of the next release. https://claude.ai/code/session_01SFMh7PDxJjvvo5dYbCCFFs
66 lines
1.8 KiB
JavaScript
66 lines
1.8 KiB
JavaScript
// mdcms service worker — generated by mdcms build
|
|
const CACHE_NAME = 'mdcms-a1862733';
|
|
const PRECACHE_URLS = [
|
|
"index.html",
|
|
"config.yml",
|
|
"nav.yml",
|
|
"search.json",
|
|
"theme.yml",
|
|
"pages/about.md",
|
|
"pages/docs.md",
|
|
"pages/home.md",
|
|
"pages/tabs-accordions.md",
|
|
"posts/.gitkeep",
|
|
"assets/fonts/.gitkeep",
|
|
"assets/icons/.gitkeep",
|
|
"assets/icons/add.svg",
|
|
"assets/icons/arrow_drop_down.svg",
|
|
"assets/icons/arrow_right.svg",
|
|
"assets/icons/collapse_content.svg",
|
|
"assets/icons/dangerous.svg",
|
|
"assets/icons/dark_mode.svg",
|
|
"assets/icons/error.svg",
|
|
"assets/icons/exclamation.svg",
|
|
"assets/icons/expand_content.svg",
|
|
"assets/icons/history.svg",
|
|
"assets/icons/info.svg",
|
|
"assets/icons/keyboard_arrow_down.svg",
|
|
"assets/icons/keyboard_arrow_right.svg",
|
|
"assets/icons/keyboard_double_arrow_down.svg",
|
|
"assets/icons/keyboard_double_arrow_right.svg",
|
|
"assets/icons/language.svg",
|
|
"assets/icons/light_mode.svg",
|
|
"assets/icons/menu.svg",
|
|
"assets/icons/minimize.svg",
|
|
"assets/icons/mobile_arrow_down.svg",
|
|
"assets/icons/report.svg",
|
|
"assets/icons/search.svg",
|
|
"assets/icons/success.svg",
|
|
"assets/icons/text_compare.svg",
|
|
"assets/icons/warning.svg",
|
|
"assets/images/.gitkeep",
|
|
"assets/images/favicon.png"
|
|
];
|
|
|
|
self.addEventListener('install', event => {
|
|
event.waitUntil(
|
|
caches.open(CACHE_NAME).then(cache => cache.addAll(PRECACHE_URLS))
|
|
);
|
|
self.skipWaiting();
|
|
});
|
|
|
|
self.addEventListener('activate', event => {
|
|
event.waitUntil(
|
|
caches.keys().then(keys =>
|
|
Promise.all(keys.filter(k => k !== CACHE_NAME).map(k => caches.delete(k)))
|
|
)
|
|
);
|
|
self.clients.claim();
|
|
});
|
|
|
|
self.addEventListener('fetch', event => {
|
|
if (event.request.method !== 'GET') return;
|
|
event.respondWith(
|
|
caches.match(event.request).then(cached => cached || fetch(event.request))
|
|
);
|
|
});
|