31d0464a60
- Scaffold: package.json, tsconfig.json, vite.config.ts, index.html - src/lib/imageProcessor.ts: full pipeline (normalize, offset, seam repair, export, validation) - src/components/UploadPanel.tsx: drag-and-drop, file picker, clipboard paste - src/components/SettingsPanel.tsx: all controls per spec - src/components/PreviewPanel.tsx: Original / Tileable / Repeated tabs - src/components/ErrorBanner.tsx: dismissible error/warning banners - src/App.tsx: root component wiring everything together - src/index.css: dark premium glassmorphism theme w/ Inter font
23 lines
517 B
JavaScript
23 lines
517 B
JavaScript
import { dirname, resolve } from 'path';
|
|
import { readdir, stat } from 'fs';
|
|
import { promisify } from 'util';
|
|
|
|
const toStats = promisify(stat);
|
|
const toRead = promisify(readdir);
|
|
|
|
export default async function (start, callback) {
|
|
let dir = resolve('.', start);
|
|
let tmp, stats = await toStats(dir);
|
|
|
|
if (!stats.isDirectory()) {
|
|
dir = dirname(dir);
|
|
}
|
|
|
|
while (true) {
|
|
tmp = await callback(dir, await toRead(dir));
|
|
if (tmp) return resolve(dir, tmp);
|
|
dir = dirname(tmp = dir);
|
|
if (tmp === dir) break;
|
|
}
|
|
}
|