mirror of
https://github.com/felipegcoutinho/openmonetis.git
synced 2026-03-10 04:51:47 +00:00
refactor: migrate from ESLint to Biome and extract SQL queries to data.ts
- Replace ESLint with Biome for linting and formatting - Configure Biome with tabs, double quotes, and organized imports - Move all SQL/Drizzle queries from page.tsx files to data.ts files - Create new data.ts files for: ajustes, dashboard, relatorios/categorias - Update existing data.ts files: extrato, fatura (add lancamentos queries) - Remove all drizzle-orm imports from page.tsx files - Update README.md with new tooling info Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -11,7 +11,7 @@
|
||||
* @returns Filename only
|
||||
*/
|
||||
export const normalizeLogo = (logo?: string | null) =>
|
||||
logo?.split("/").filter(Boolean).pop() ?? "";
|
||||
logo?.split("/").filter(Boolean).pop() ?? "";
|
||||
|
||||
/**
|
||||
* Derives a display name from a logo filename
|
||||
@@ -21,20 +21,20 @@ export const normalizeLogo = (logo?: string | null) =>
|
||||
* deriveNameFromLogo("my-company-logo.png") // "My Company Logo"
|
||||
*/
|
||||
export const deriveNameFromLogo = (logo?: string | null) => {
|
||||
if (!logo) {
|
||||
return "";
|
||||
}
|
||||
if (!logo) {
|
||||
return "";
|
||||
}
|
||||
|
||||
const fileName = normalizeLogo(logo);
|
||||
const fileName = normalizeLogo(logo);
|
||||
|
||||
if (!fileName) {
|
||||
return "";
|
||||
}
|
||||
if (!fileName) {
|
||||
return "";
|
||||
}
|
||||
|
||||
const withoutExtension = fileName.replace(/\.[^/.]+$/, "");
|
||||
return withoutExtension
|
||||
.split(/[-_.\s]+/)
|
||||
.filter(Boolean)
|
||||
.map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())
|
||||
.join(" ");
|
||||
const withoutExtension = fileName.replace(/\.[^/.]+$/, "");
|
||||
return withoutExtension
|
||||
.split(/[-_.\s]+/)
|
||||
.filter(Boolean)
|
||||
.map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())
|
||||
.join(" ");
|
||||
};
|
||||
|
||||
@@ -16,15 +16,15 @@ const LOGO_EXTENSIONS = new Set([".png", ".jpg", ".jpeg", ".svg", ".webp"]);
|
||||
* @returns Array of logo filenames sorted alphabetically
|
||||
*/
|
||||
export async function loadLogoOptions() {
|
||||
try {
|
||||
const files = await readdir(LOGOS_DIRECTORY, { withFileTypes: true });
|
||||
try {
|
||||
const files = await readdir(LOGOS_DIRECTORY, { withFileTypes: true });
|
||||
|
||||
return files
|
||||
.filter((file) => file.isFile())
|
||||
.map((file) => file.name)
|
||||
.filter((file) => LOGO_EXTENSIONS.has(path.extname(file).toLowerCase()))
|
||||
.sort((a, b) => a.localeCompare(b, "pt-BR", { sensitivity: "base" }));
|
||||
} catch {
|
||||
return [];
|
||||
}
|
||||
return files
|
||||
.filter((file) => file.isFile())
|
||||
.map((file) => file.name)
|
||||
.filter((file) => LOGO_EXTENSIONS.has(path.extname(file).toLowerCase()))
|
||||
.sort((a, b) => a.localeCompare(b, "pt-BR", { sensitivity: "base" }));
|
||||
} catch {
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user