- Node/Express/TypeScript API under /api/v1 with JWT auth (login, refresh, logout, /me) - Prisma schema: vendors, users, roles, products, categories, taxes, transactions - SQLite for local dev; Postgres via docker-compose for production - Full CRUD routes for vendors, users, categories, taxes, products with Zod validation and RBAC - Paginated list endpoints scoped per vendor; refresh token rotation - React/TypeScript admin SPA (Vite): login, protected routing, sidebar layout - Pages: Dashboard, Catalog (tabbed Products/Categories/Taxes), Users, Vendor Settings - Shared UI: Table, Modal, FormField, Btn, PageHeader components - Multi-stage Dockerfile; docker-compose with Postgres healthcheck - Seed script with demo vendor and owner account - INSTRUCTIONS.md, ROADMAP.md, .claude/launch.json for dev server config Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
26 lines
712 B
JavaScript
26 lines
712 B
JavaScript
const { EOL } = require('os')
|
|
|
|
const getFirstRegexpMatchOrDefault = (text, regexp, defaultValue) => {
|
|
regexp.lastIndex = 0 // https://stackoverflow.com/a/11477448/4536543
|
|
let match = regexp.exec(text)
|
|
if (match !== null) {
|
|
return match[1]
|
|
} else {
|
|
return defaultValue
|
|
}
|
|
}
|
|
|
|
const DEFAULT_INDENT = ' '
|
|
const INDENT_REGEXP = /^([ \t]+)[^\s]/m
|
|
|
|
module.exports.detectIndent = text =>
|
|
getFirstRegexpMatchOrDefault(text, INDENT_REGEXP, DEFAULT_INDENT)
|
|
module.exports.DEFAULT_INDENT = DEFAULT_INDENT
|
|
|
|
const DEFAULT_EOL = EOL
|
|
const EOL_REGEXP = /(\r\n|\n|\r)/g
|
|
|
|
module.exports.detectEOL = text =>
|
|
getFirstRegexpMatchOrDefault(text, EOL_REGEXP, DEFAULT_EOL)
|
|
module.exports.DEFAULT_EOL = DEFAULT_EOL
|