chore: initialize @limitless/ui git repo + add AppShell
This brings the long-untracked @limitless/ui source tree under version
control. Until now /srv/k8s/templates/limitless-ui has been a plain
file: dependency consumed by gscChronos / gscCRM / gscAdmin, with
copies scattered across web/gsc{Portal,WWW,Aether,Register}/ and
apps/gsc{Meet,Share}/. None were git-tracked.
Treating /srv/k8s/templates/limitless-ui as the canonical going
forward; secondary copies should be replaced with this version
in their consumers' Dockerfiles when they next get touched.
Changes in this initial commit beyond the snapshot:
- Add src/layout/AppShell.tsx — runtime-loaded chrome (header,
sidebar, footer) backed by gsc-shell-api. Public surface:
AppShell, ShellProvider, useShell, ShellConfig types
Framework-agnostic (no Next.js dep). Apps pass appKey + apiUrl +
getToken; AppShell composes the existing PageShell / Navbar /
Sidebar / Footer primitives with API data.
- Re-export AppShell from src/index.ts.
- Fix build script: `tsc -p tsconfig.json --noEmit false`. The bare
`tsc` command was a no-op because tsconfig.json sets noEmit:true
for typecheck speed. Existing dist/ only existed because of an
earlier emit; clean rebuilds were silently broken.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
64
.next/types/routes.d.ts
vendored
Normal file
64
.next/types/routes.d.ts
vendored
Normal file
@@ -0,0 +1,64 @@
|
||||
// This file is generated automatically by Next.js
|
||||
// Do not edit this file manually
|
||||
|
||||
type AppRoutes = never
|
||||
type PageRoutes = "/" | "/Auth" | "/Chat" | "/Error" | "/Invoice" | "/Mail" | "/Search" | "/TaskManager" | "/UserProfile"
|
||||
type LayoutRoutes = never
|
||||
type RedirectRoutes = never
|
||||
type RewriteRoutes = never
|
||||
type Routes = AppRoutes | PageRoutes | LayoutRoutes | RedirectRoutes | RewriteRoutes
|
||||
|
||||
|
||||
interface ParamMap {
|
||||
"/": {}
|
||||
"/Auth": {}
|
||||
"/Chat": {}
|
||||
"/Error": {}
|
||||
"/Invoice": {}
|
||||
"/Mail": {}
|
||||
"/Search": {}
|
||||
"/TaskManager": {}
|
||||
"/UserProfile": {}
|
||||
}
|
||||
|
||||
|
||||
export type ParamsOf<Route extends Routes> = ParamMap[Route]
|
||||
|
||||
interface LayoutSlotMap {
|
||||
}
|
||||
|
||||
|
||||
export type { AppRoutes, PageRoutes, LayoutRoutes, RedirectRoutes, RewriteRoutes, ParamMap }
|
||||
|
||||
declare global {
|
||||
/**
|
||||
* Props for Next.js App Router page components
|
||||
* @example
|
||||
* ```tsx
|
||||
* export default function Page(props: PageProps<'/blog/[slug]'>) {
|
||||
* const { slug } = await props.params
|
||||
* return <div>Blog post: {slug}</div>
|
||||
* }
|
||||
* ```
|
||||
*/
|
||||
interface PageProps<AppRoute extends AppRoutes> {
|
||||
params: Promise<ParamMap[AppRoute]>
|
||||
searchParams: Promise<Record<string, string | string[] | undefined>>
|
||||
}
|
||||
|
||||
/**
|
||||
* Props for Next.js App Router layout components
|
||||
* @example
|
||||
* ```tsx
|
||||
* export default function Layout(props: LayoutProps<'/dashboard'>) {
|
||||
* return <div>{props.children}</div>
|
||||
* }
|
||||
* ```
|
||||
*/
|
||||
type LayoutProps<LayoutRoute extends LayoutRoutes> = {
|
||||
params: Promise<ParamMap[LayoutRoute]>
|
||||
children: React.ReactNode
|
||||
} & {
|
||||
[K in LayoutSlotMap[LayoutRoute]]: React.ReactNode
|
||||
}
|
||||
}
|
||||
112
.next/types/validator.ts
Normal file
112
.next/types/validator.ts
Normal file
@@ -0,0 +1,112 @@
|
||||
// This file is generated automatically by Next.js
|
||||
// Do not edit this file manually
|
||||
// This file validates that all pages and layouts export the correct types
|
||||
|
||||
|
||||
|
||||
type PagesPageConfig = {
|
||||
default: React.ComponentType<any> | ((props: any) => React.ReactNode | Promise<React.ReactNode> | never | void)
|
||||
getStaticProps?: (context: any) => Promise<any> | any
|
||||
getStaticPaths?: (context: any) => Promise<any> | any
|
||||
getServerSideProps?: (context: any) => Promise<any> | any
|
||||
getInitialProps?: (context: any) => Promise<any> | any
|
||||
/**
|
||||
* Segment configuration for legacy Pages Router pages.
|
||||
* Validated at build-time by parsePagesSegmentConfig.
|
||||
*/
|
||||
config?: {
|
||||
maxDuration?: number
|
||||
runtime?: 'edge' | 'experimental-edge' | 'nodejs' | string // necessary unless config is exported as const
|
||||
regions?: string[]
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
// Validate ../../src/pages/Auth.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/Auth.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/Chat.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/Chat.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/Error.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/Error.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/Invoice.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/Invoice.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/Mail.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/Mail.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/Search.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/Search.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/TaskManager.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/TaskManager.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/UserProfile.tsx
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/UserProfile.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
// Validate ../../src/pages/index.ts
|
||||
{
|
||||
type __IsExpected<Specific extends PagesPageConfig> = Specific
|
||||
const handler = {} as typeof import("../../src/pages/index.js")
|
||||
type __Check = __IsExpected<typeof handler>
|
||||
// @ts-ignore
|
||||
type __Unused = __Check
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user