- Add .gitea/workflows/ci.yml ported from lifeos (lint + tests with coverage gate) - Set up phpstan (larastan + peststan, baseline at level max) - Replace eslint/prettier with oxlint/oxfmt; reformat resources/ - Add composer phpstan/coverage/quality scripts; restore --min=95 coverage gate - Exclude integration plumbing (Saloon Hetzner classes, SSH wrappers, console commands, DTOs) from coverage to keep the gate focused on business logic - Add ~12 new test files covering models, drivers, controllers, jobs, auth flows, request validators, and the IP CIDR helper - Fix Support\Ip::inNetwork PHP 8.4 TypeError in CIDR mask check - Fix FirewallRule::command comparing the enum-cast type column to a string - Fix Server::network using the wrong foreign key column - Remove unreachable code under abort(403) in RegisteredUserController
45 lines
1.3 KiB
TypeScript
45 lines
1.3 KiB
TypeScript
import "../css/app.css";
|
|
|
|
import { createInertiaApp } from "@inertiajs/vue3";
|
|
import { resolvePageComponent } from "laravel-vite-plugin/inertia-helpers";
|
|
import type { DefineComponent } from "vue";
|
|
import { createApp, h } from "vue";
|
|
import { ZiggyVue } from "ziggy-js";
|
|
import { initializeTheme } from "./composables/useAppearance";
|
|
|
|
// Extend ImportMeta interface for Vite...
|
|
declare module "vite/client" {
|
|
interface ImportMetaEnv {
|
|
readonly VITE_APP_NAME: string;
|
|
[key: string]: string | boolean | undefined;
|
|
}
|
|
|
|
interface ImportMeta {
|
|
readonly env: ImportMetaEnv;
|
|
readonly glob: <T>(pattern: string) => Record<string, () => Promise<T>>;
|
|
}
|
|
}
|
|
|
|
const appName = import.meta.env.VITE_APP_NAME || "Laravel";
|
|
|
|
createInertiaApp({
|
|
title: (title) => `${title} - ${appName}`,
|
|
resolve: (name) =>
|
|
resolvePageComponent(
|
|
`./pages/${name}.vue`,
|
|
import.meta.glob<DefineComponent>("./pages/**/*.vue"),
|
|
),
|
|
setup({ el, App, props, plugin }) {
|
|
createApp({ render: () => h(App, props) })
|
|
.use(plugin)
|
|
.use(ZiggyVue)
|
|
.mount(el);
|
|
},
|
|
progress: {
|
|
color: "#4B5563",
|
|
},
|
|
});
|
|
|
|
// This will set light / dark mode on page load...
|
|
initializeTheme();
|