Bring every tool's header in line with archive's pattern: [logo] [title] [version] [Add Local Directory] [⟳] ............... [◐] [?] ------------- header-left --------------- ----- header-right - Changes per tool: * browse: rename "Select Directory" → "Add Local Directory"; add the red-non-stable wrap to the build label (was missing); add a help panel + bundle shared/help.js. * classifier: rename selectDirectoryBtn → addDirectoryBtn, refreshBtn → refreshHeaderBtn for consistency. Update all JS callers and welcome-screen copy to the new label. * mdedit: same id rename. Move the previously-in-pane refresh button into the header. Stop renaming the dir button to "Directory: <name>" once a folder is loaded — instead use the shared btn--subtle variant to de-emphasize while keeping the standard label. * transmittal: convert non-standard <div class="app-header"> with spacer/icons containers to <header class="app-header"> with the canonical header-left/header-right pair. Move the publish split- button into header-left (Transmittal-specific primary action). Remove dead .app-header__spacer/__icons/header-icon-btn CSS now that nothing references those classes. * landing, form: add help-btn + help-panel + bundle shared/help.js. Each panel is tool-specific (project picker docs for landing, schema-driven form docs for form). Cross-cutting: * shared/base.css: promote .btn--subtle from browse/css/tree.css so any tool with an online mode can de-emphasize Add Local Directory consistently. Verified all 7 tools in headless Chromium: header structure correct, build label red on non-stable cuts, help panel opens + closes via button + Esc.
191 lines
9.3 KiB
HTML
191 lines
9.3 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>ZDDC Browse</title>
|
|
<link rel="icon" type="image/svg+xml" href="{{FAVICON}}">
|
|
<style>
|
|
{{CSS_PLACEHOLDER}}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<header class="app-header">
|
|
<div class="header-left">
|
|
<svg class="app-header__logo" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 64 64" aria-hidden="true">
|
|
<rect width="64" height="64" rx="12" fill="#1e3a5f"/>
|
|
<g fill="#fff">
|
|
<rect x="14" y="18" width="36" height="7"/>
|
|
<polygon points="43,25 50,25 21,43 14,43"/>
|
|
<rect x="14" y="43" width="36" height="7"/>
|
|
</g>
|
|
</svg>
|
|
<div class="header-title-group">
|
|
<span class="app-header__title">ZDDC Browse</span>
|
|
<span class="build-timestamp">{{BUILD_LABEL}}</span>
|
|
</div>
|
|
<button id="addDirectoryBtn" class="btn btn-primary">Add Local Directory</button>
|
|
<button id="refreshHeaderBtn" class="btn btn-secondary hidden" title="Refresh listing" aria-label="Refresh listing" style="font-size:1.1rem;">⟳</button>
|
|
</div>
|
|
<div class="header-right">
|
|
<button id="theme-btn" class="btn btn-secondary" title="Theme: auto (follows OS)" aria-label="Theme: auto (follows OS)">◐</button>
|
|
<button id="help-btn" class="btn btn-secondary" title="Help" aria-label="Help">?</button>
|
|
</div>
|
|
</header>
|
|
|
|
<main id="appMain">
|
|
<div id="emptyState" class="empty-state">
|
|
<div class="empty-state__inner">
|
|
<h2>ZDDC Browse</h2>
|
|
<p>A simple directory listing for ZDDC archives — and any directory.
|
|
Pick how you want to browse:</p>
|
|
<ul>
|
|
<li><b>Online</b> — when this page is served by zddc-server, the
|
|
listing for the current directory loads automatically.</li>
|
|
<li><b>Local</b> — click <i>Add Local Directory</i> to pick any folder
|
|
on your computer (Chromium-based browsers).</li>
|
|
</ul>
|
|
<p>Once loaded: click a folder to expand it, <b>shift-click</b>
|
|
to expand its entire subtree (or collapse it again),
|
|
click column headers to sort. Use the 📄 row to filter files
|
|
(and the 📁 row to scope to matching folders) — file matches
|
|
stay visible together with their containing folders.
|
|
Click any file to open it.</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="browseRoot" class="browse-root hidden">
|
|
<div class="toolbar">
|
|
<nav class="breadcrumbs" id="breadcrumbs" aria-label="Path"></nav>
|
|
<span class="toolbar__count" id="entryCount"></span>
|
|
</div>
|
|
<div class="browse-table-wrap">
|
|
<table class="browse-table" id="browseTable">
|
|
<thead>
|
|
<tr class="header-row">
|
|
<th data-sort="name" class="col-name sortable">Name <span class="sort-arrow"></span></th>
|
|
<th data-sort="size" class="col-size sortable">Size <span class="sort-arrow"></span></th>
|
|
<th data-sort="ext" class="col-ext sortable">Type <span class="sort-arrow"></span></th>
|
|
<th data-sort="date" class="col-date sortable">Modified <span class="sort-arrow"></span></th>
|
|
</tr>
|
|
<tr class="filter-row filter-row--file" title="Filter files">
|
|
<th class="col-name">
|
|
<span class="filter-row__icon" aria-hidden="true">📄</span>
|
|
<input type="text" class="column-filter" data-filter="file"
|
|
placeholder="filter files…" spellcheck="false"
|
|
aria-label="Filter by file name">
|
|
</th>
|
|
<th class="col-size"></th>
|
|
<th class="col-ext">
|
|
<input type="text" class="column-filter" data-filter="ext"
|
|
placeholder="ext…" spellcheck="false"
|
|
aria-label="Filter by extension">
|
|
</th>
|
|
<th class="col-date"></th>
|
|
</tr>
|
|
<tr class="filter-row filter-row--folder" title="Filter folders">
|
|
<th class="col-name">
|
|
<span class="filter-row__icon" aria-hidden="true">📁</span>
|
|
<input type="text" class="column-filter" data-filter="folder"
|
|
placeholder="filter folders…" spellcheck="false"
|
|
aria-label="Filter by folder name">
|
|
</th>
|
|
<th class="col-size"></th>
|
|
<th class="col-ext"></th>
|
|
<th class="col-date"></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="browseTbody"></tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</main>
|
|
|
|
<div id="statusBar" class="status-bar"></div>
|
|
|
|
<!-- Help Panel -->
|
|
<aside id="help-panel" class="help-panel" hidden aria-labelledby="help-panel-title">
|
|
<div class="help-panel__header">
|
|
<h2 id="help-panel-title" class="help-panel__title">Help — ZDDC Browse</h2>
|
|
<button type="button" class="help-panel__close" id="help-panel-close" aria-label="Close">×</button>
|
|
</div>
|
|
<div class="help-panel__body">
|
|
<h3>What is Browse?</h3>
|
|
<p>Browse is a directory listing for ZDDC archives — and any directory. It works in two modes:</p>
|
|
<dl>
|
|
<dt>Online</dt>
|
|
<dd>When the page is served by zddc-server, the listing for the current
|
|
URL directory loads automatically. Breadcrumbs link to ancestor folders.</dd>
|
|
<dt>Local</dt>
|
|
<dd>Click <strong>Add Local Directory</strong> to pick any folder on your
|
|
computer. Local mode requires a Chromium-based browser (File System
|
|
Access API).</dd>
|
|
</dl>
|
|
|
|
<h3>Tree navigation</h3>
|
|
<dl>
|
|
<dt>Click a folder</dt>
|
|
<dd>Toggle expand/collapse on that folder.</dd>
|
|
<dt>Shift-click a folder</dt>
|
|
<dd>Recursive expand or collapse — applies to the whole subtree.</dd>
|
|
<dt>Click a file</dt>
|
|
<dd>Open in the preview popup. Modifier-click (Ctrl/Cmd) or middle-click
|
|
opens in a new tab.</dd>
|
|
<dt>ZIP files</dt>
|
|
<dd>Behave as folders — click to inspect contents inline. JSZip is
|
|
bundled, so this works offline.</dd>
|
|
<dt>Column headers</dt>
|
|
<dd>Click to sort; click again to reverse.</dd>
|
|
<dt>Refresh</dt>
|
|
<dd>Re-fetches the current directory listing — works for both
|
|
local (re-enumerates the FS handle) and online (re-fetches the JSON).</dd>
|
|
</dl>
|
|
|
|
<h3>Filter rows</h3>
|
|
<p>Two filter rows live in the table header:</p>
|
|
<dl>
|
|
<dt>📄 file row</dt>
|
|
<dd>Filter by file name (left input) and/or extension (Type input).
|
|
File matches stay visible together with their ancestor folders, so
|
|
the path to each hit is always shown.</dd>
|
|
<dt>📁 folder row</dt>
|
|
<dd>Filter by folder name. Matching folders show with their entire
|
|
subtree. Combined with file filter: file must also be inside a
|
|
matching folder's subtree (intersection).</dd>
|
|
</dl>
|
|
<p>Filter syntax (shared across all ZDDC tools):</p>
|
|
<dl>
|
|
<dt><code>term</code></dt>
|
|
<dd>Contains "term" (case-insensitive)</dd>
|
|
<dt><code>!term</code></dt>
|
|
<dd>Does not contain</dd>
|
|
<dt><code>^term</code></dt>
|
|
<dd>Starts with</dd>
|
|
<dt><code>term$</code></dt>
|
|
<dd>Ends with</dd>
|
|
<dt><code>a b</code></dt>
|
|
<dd>Both (AND)</dd>
|
|
<dt><code>a | b</code></dt>
|
|
<dd>Either (OR)</dd>
|
|
<dt><code>el.*spc</code></dt>
|
|
<dd>Regex — any-char + any-sequence</dd>
|
|
</dl>
|
|
|
|
<h3>Header buttons</h3>
|
|
<dl>
|
|
<dt>Add Local Directory</dt>
|
|
<dd>Pick a folder from your computer. Works in both modes; in online
|
|
mode it's de-emphasized but still available.</dd>
|
|
<dt>⟳ Refresh</dt>
|
|
<dd>Re-load the current directory listing.</dd>
|
|
<dt>◐ Theme</dt>
|
|
<dd>Cycle auto / light / dark.</dd>
|
|
</dl>
|
|
</div>
|
|
</aside>
|
|
|
|
<script>
|
|
{{JS_PLACEHOLDER}}
|
|
</script>
|
|
</body>
|
|
</html>
|