@almadar/orb-linux-x64 1.9.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/orb +0 -0
  2. package/package.json +9 -0
  3. package/shells/orb-shell/LICENSE +21 -0
  4. package/shells/orb-shell/README.md +25 -0
  5. package/shells/orb-shell/locales/en.json +120 -0
  6. package/shells/orb-shell/package.json +35 -0
  7. package/shells/orb-shell/packages/client/eslint.config.cjs +23 -0
  8. package/shells/orb-shell/packages/client/index.html +13 -0
  9. package/shells/orb-shell/packages/client/package.json +55 -0
  10. package/shells/orb-shell/packages/client/postcss.config.js +6 -0
  11. package/shells/orb-shell/packages/client/src/App.tsx +79 -0
  12. package/shells/orb-shell/packages/client/src/config/firebase.ts +37 -0
  13. package/shells/orb-shell/packages/client/src/features/auth/AuthContext.tsx +139 -0
  14. package/shells/orb-shell/packages/client/src/features/auth/authService.ts +83 -0
  15. package/shells/orb-shell/packages/client/src/features/auth/components/Login.tsx +218 -0
  16. package/shells/orb-shell/packages/client/src/features/auth/components/ProtectedRoute.tsx +27 -0
  17. package/shells/orb-shell/packages/client/src/features/auth/components/UserProfile.tsx +68 -0
  18. package/shells/orb-shell/packages/client/src/features/auth/components/index.ts +3 -0
  19. package/shells/orb-shell/packages/client/src/features/auth/index.ts +13 -0
  20. package/shells/orb-shell/packages/client/src/features/auth/types.ts +24 -0
  21. package/shells/orb-shell/packages/client/src/generated/index.ts +13 -0
  22. package/shells/orb-shell/packages/client/src/index.css +35 -0
  23. package/shells/orb-shell/packages/client/src/main.tsx +10 -0
  24. package/shells/orb-shell/packages/client/src/navigation/index.ts +55 -0
  25. package/shells/orb-shell/packages/client/src/pages/index.ts +12 -0
  26. package/shells/orb-shell/packages/client/tailwind-preset.js +243 -0
  27. package/shells/orb-shell/packages/client/tailwind.config.js +15 -0
  28. package/shells/orb-shell/packages/client/tsconfig.json +33 -0
  29. package/shells/orb-shell/packages/client/vite.config.ts +49 -0
  30. package/shells/orb-shell/packages/server/eslint.config.cjs +19 -0
  31. package/shells/orb-shell/packages/server/package.json +37 -0
  32. package/shells/orb-shell/packages/server/src/app.ts +36 -0
  33. package/shells/orb-shell/packages/server/src/index.ts +30 -0
  34. package/shells/orb-shell/packages/server/src/routes.ts +11 -0
  35. package/shells/orb-shell/packages/server/src/types/express.d.ts +15 -0
  36. package/shells/orb-shell/packages/server/tsconfig.json +23 -0
  37. package/shells/orb-shell/packages/shared/package.json +10 -0
  38. package/shells/orb-shell/packages/shared/src/index.ts +2 -0
  39. package/shells/orb-shell/pnpm-lock.yaml +9247 -0
  40. package/shells/orb-shell/pnpm-workspace.yaml +2 -0
  41. package/shells/orb-shell/tsup.config.ts +13 -0
  42. package/shells/orb-shell/turbo.json +17 -0
  43. package/shells/orb-shell/vitest.config.ts +8 -0
@@ -0,0 +1,243 @@
1
+ /**
2
+ * @almadar/ui Tailwind Preset
3
+ *
4
+ * Provides the complete Almadar design token system as a Tailwind preset.
5
+ * Includes a safelist of all CSS-variable-based arbitrary classes used by
6
+ * @almadar/ui components so Tailwind generates them without scanning node_modules.
7
+ *
8
+ * Usage in tailwind.config.js:
9
+ * presets: [require('@almadar/ui/tailwind-preset')]
10
+ */
11
+
12
+ /** @type {import('tailwindcss').Config} */
13
+ module.exports = {
14
+ darkMode: 'class',
15
+ safelist: [
16
+ 'accent-[var(--color-foreground)]',
17
+ 'accent-[var(--color-primary)]',
18
+ 'active:bg-[var(--color-muted)]',
19
+ 'active:bg-[var(--color-primary)]',
20
+ 'active:scale-[var(--active-scale)]',
21
+ 'active:shadow-[var(--shadow-active)]',
22
+ 'active:text-[var(--color-primary-foreground)]',
23
+ 'bg-[var(--color-accent)]',
24
+ 'bg-[var(--color-background)]',
25
+ 'bg-[var(--color-border)]',
26
+ 'bg-[var(--color-card)]',
27
+ 'bg-[var(--color-error)]',
28
+ 'bg-[var(--color-foreground)]',
29
+ 'bg-[var(--color-info)]',
30
+ 'bg-[var(--color-muted)]',
31
+ 'bg-[var(--color-muted-foreground)]',
32
+ ':bg-[var(--color-primary)]',
33
+ 'bg-[var(--color-primary)]',
34
+ 'bg-[var(--color-primary-foreground)]',
35
+ 'bg-[var(--color-secondary)]',
36
+ 'bg-[var(--color-success)]',
37
+ 'bg-[var(--color-surface)]',
38
+ 'bg-[var(--color-table-header)]',
39
+ 'bg-[var(--color-warning)]',
40
+ 'border-b-[length:var(--border-width)]',
41
+ 'border-b-[var(--color-foreground)]',
42
+ 'border-b-[var(--color-primary)]',
43
+ 'border-[length:var(--border-width)]',
44
+ 'border-[length:var(--border-width-thin)]',
45
+ 'border-l-[length:var(--border-width)]',
46
+ 'border-l-[var(--color-foreground)]',
47
+ 'border-l-[var(--color-primary)]',
48
+ 'border-r-[length:var(--border-width)]',
49
+ 'border-r-[var(--color-foreground)]',
50
+ 'border-r-[var(--color-primary)]',
51
+ 'border-t-[length:var(--border-width)]',
52
+ 'border-t-[var(--color-foreground)]',
53
+ 'border-t-[var(--color-primary)]',
54
+ 'border-[var(--color-accent)]',
55
+ ':border-[var(--color-border)]',
56
+ 'border-[var(--color-border)]',
57
+ 'border-[var(--color-card)]',
58
+ 'border-[var(--color-error)]',
59
+ 'border-[var(--color-foreground)]',
60
+ 'border-[var(--color-info)]',
61
+ ':border-[var(--color-primary)]',
62
+ 'border-[var(--color-primary)]',
63
+ 'border-[var(--color-success)]',
64
+ 'border-[var(--color-table-border)]',
65
+ 'border-[var(--color-warning)]',
66
+ 'border-x-[length:var(--border-width)]',
67
+ 'checked:bg-[var(--color-primary)]',
68
+ 'dark:bg-[var(--color-background)]',
69
+ 'dark:bg-[var(--color-card)]',
70
+ 'dark:bg-[var(--color-foreground)]',
71
+ 'dark:bg-[var(--color-muted)]',
72
+ 'dark:border-[var(--color-border)]',
73
+ 'dark:hover:bg-[var(--color-error)]',
74
+ 'dark:hover:bg-[var(--color-muted)]',
75
+ 'dark:text-[var(--color-error)]',
76
+ 'dark:text-[var(--color-foreground)]',
77
+ 'dark:text-[var(--color-muted-foreground)]',
78
+ 'disabled:bg-[var(--color-muted)]',
79
+ 'disabled:text-[var(--color-muted-foreground)]',
80
+ 'duration-[var(--transition-fast)]',
81
+ 'duration-[var(--transition-normal)]',
82
+ 'fill-[var(--color-warning)]',
83
+ 'focus:bg-[var(--color-card)]',
84
+ 'focus:bg-[var(--color-muted)]',
85
+ 'focus:border-[var(--color-error)]',
86
+ 'focus:border-[var(--color-primary)]',
87
+ 'focus:border-[var(--color-ring)]',
88
+ 'focus:ring-[length:var(--focus-ring-width)]',
89
+ 'focus:ring-offset-[length:var(--focus-ring-offset)]',
90
+ 'focus:ring-[var(--color-error)]',
91
+ 'focus:ring-[var(--color-ring)]',
92
+ 'font-[var(--font-weight-bold)]',
93
+ 'font-[var(--font-weight-medium)]',
94
+ 'from-[var(--color-muted)]',
95
+ 'group-hover:bg-[var(--color-foreground)]',
96
+ 'group-hover:text-[var(--color-foreground)]',
97
+ 'group-hover:text-[var(--color-muted-foreground)]',
98
+ 'hover:bg-[var(--color-error)]',
99
+ 'hover:bg-[var(--color-muted)]',
100
+ 'hover:bg-[var(--color-muted-foreground)]',
101
+ 'hover:bg-[var(--color-primary)]',
102
+ 'hover:bg-[var(--color-primary-hover)]',
103
+ 'hover:bg-[var(--color-secondary-hover)]',
104
+ 'hover:bg-[var(--color-success)]',
105
+ 'hover:bg-[var(--color-surface)]',
106
+ 'hover:bg-[var(--color-surface-hover)]',
107
+ 'hover:bg-[var(--color-table-row-hover)]',
108
+ 'hover:bg-[var(--color-warning)]',
109
+ 'hover:border-[var(--color-border)]',
110
+ 'hover:border-[var(--color-border-hover)]',
111
+ 'hover:border-[var(--color-muted-foreground)]',
112
+ 'hover:border-[var(--color-primary)]',
113
+ 'hover:ring-[var(--color-ring)]',
114
+ 'hover:shadow-[var(--shadow-hover)]',
115
+ 'hover:shadow-[var(--shadow-sm)]',
116
+ 'hover:text-[var(--color-error)]',
117
+ 'hover:text-[var(--color-error-foreground)]',
118
+ 'hover:text-[var(--color-foreground)]',
119
+ 'hover:text-[var(--color-primary)]',
120
+ 'hover:text-[var(--color-success-foreground)]',
121
+ 'hover:text-[var(--color-warning-foreground)]',
122
+ 'peer-focus:ring-[var(--color-error)]',
123
+ 'peer-focus:ring-[var(--color-ring)]',
124
+ 'placeholder:text-[var(--color-muted-foreground)]',
125
+ 'placeholder:text-[var(--color-placeholder)]',
126
+ 'ring-[var(--color-accent)]',
127
+ 'ring-[var(--color-error)]',
128
+ 'ring-[var(--color-info)]',
129
+ 'ring-[var(--color-muted-foreground)]',
130
+ 'ring-[var(--color-primary)]',
131
+ 'ring-[var(--color-success)]',
132
+ 'ring-[var(--color-warning)]',
133
+ 'rounded-l-[var(--radius-sm)]',
134
+ 'rounded-r-[var(--radius-sm)]',
135
+ 'rounded-t-[var(--radius-lg)]',
136
+ 'rounded-t-[var(--radius-sm)]',
137
+ 'rounded-[var(--radius-full)]',
138
+ 'rounded-[var(--radius-lg)]',
139
+ 'rounded-[var(--radius-md)]',
140
+ 'rounded-[var(--radius-sm)]',
141
+ 'rounded-[var(--radius-xl)]',
142
+ 'shadow-[var(--shadow-lg)]',
143
+ 'shadow-[var(--shadow-main)]',
144
+ 'shadow-[var(--shadow-sm)]',
145
+ 'text-[var(--color-accent)]',
146
+ 'text-[var(--color-accent-foreground)]',
147
+ 'text-[var(--color-background)]',
148
+ 'text-[var(--color-card-foreground)]',
149
+ 'text-[var(--color-error)]',
150
+ 'text-[var(--color-error-foreground)]',
151
+ 'text-[var(--color-foreground)]',
152
+ 'text-[var(--color-info)]',
153
+ 'text-[var(--color-info-foreground)]',
154
+ 'text-[var(--color-muted)]',
155
+ 'text-[var(--color-muted-foreground)]',
156
+ 'text-[var(--color-primary)]',
157
+ ':text-[var(--color-primary-foreground)]',
158
+ 'text-[var(--color-primary-foreground)]',
159
+ 'text-[var(--color-secondary-foreground)]',
160
+ 'text-[var(--color-success)]',
161
+ 'text-[var(--color-warning)]',
162
+ 'text-[var(--color-warning-foreground)]',
163
+ 'to-[var(--color-accent)]',
164
+ ],
165
+ theme: {
166
+ fontFamily: {
167
+ sans: ['var(--font-family)', 'ui-sans-serif', 'system-ui', 'sans-serif'],
168
+ mono: ['var(--font-family-mono, ui-monospace)', 'SFMono-Regular', 'Menlo', 'Monaco', 'Consolas', 'monospace'],
169
+ },
170
+ extend: {
171
+ colors: {
172
+ primary: {
173
+ DEFAULT: 'var(--color-primary)',
174
+ foreground: 'var(--color-primary-foreground)',
175
+ hover: 'var(--color-primary-hover)',
176
+ },
177
+ secondary: {
178
+ DEFAULT: 'var(--color-secondary)',
179
+ foreground: 'var(--color-secondary-foreground)',
180
+ hover: 'var(--color-secondary-hover)',
181
+ },
182
+ muted: {
183
+ DEFAULT: 'var(--color-muted)',
184
+ foreground: 'var(--color-muted-foreground)',
185
+ },
186
+ accent: {
187
+ DEFAULT: 'var(--color-accent)',
188
+ foreground: 'var(--color-accent-foreground)',
189
+ },
190
+ background: 'var(--color-background)',
191
+ foreground: 'var(--color-foreground)',
192
+ card: {
193
+ DEFAULT: 'var(--color-card)',
194
+ foreground: 'var(--color-card-foreground)',
195
+ },
196
+ surface: 'var(--color-surface)',
197
+ border: 'var(--color-border)',
198
+ input: 'var(--color-input)',
199
+ ring: 'var(--color-ring)',
200
+ error: {
201
+ DEFAULT: 'var(--color-error)',
202
+ foreground: 'var(--color-error-foreground)',
203
+ },
204
+ success: {
205
+ DEFAULT: 'var(--color-success)',
206
+ foreground: 'var(--color-success-foreground)',
207
+ },
208
+ warning: {
209
+ DEFAULT: 'var(--color-warning)',
210
+ foreground: 'var(--color-warning-foreground)',
211
+ },
212
+ info: {
213
+ DEFAULT: 'var(--color-info)',
214
+ foreground: 'var(--color-info-foreground)',
215
+ },
216
+ },
217
+ borderRadius: {
218
+ none: 'var(--radius-none, 0)',
219
+ sm: 'var(--radius-sm)',
220
+ md: 'var(--radius-md)',
221
+ lg: 'var(--radius-lg)',
222
+ xl: 'var(--radius-xl)',
223
+ full: 'var(--radius-full)',
224
+ },
225
+ boxShadow: {
226
+ sm: 'var(--shadow-sm)',
227
+ DEFAULT: 'var(--shadow-main)',
228
+ lg: 'var(--shadow-lg)',
229
+ inner: 'var(--shadow-inner)',
230
+ },
231
+ fontWeight: {
232
+ normal: 'var(--font-weight-normal, 400)',
233
+ medium: 'var(--font-weight-medium, 500)',
234
+ bold: 'var(--font-weight-bold, 600)',
235
+ },
236
+ transitionDuration: {
237
+ fast: 'var(--transition-fast, 150ms)',
238
+ normal: 'var(--transition-normal, 250ms)',
239
+ slow: 'var(--transition-slow, 400ms)',
240
+ },
241
+ },
242
+ },
243
+ };
@@ -0,0 +1,15 @@
1
+ import { createRequire } from 'module';
2
+ const require = createRequire(import.meta.url);
3
+
4
+ /** @type {import('tailwindcss').Config} */
5
+ export default {
6
+ presets: [require('@almadar/ui/tailwind-preset')],
7
+ content: [
8
+ "./index.html",
9
+ "./src/**/*.{js,ts,jsx,tsx}",
10
+ ],
11
+ theme: {
12
+ extend: {},
13
+ },
14
+ plugins: [],
15
+ }
@@ -0,0 +1,33 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "useDefineForClassFields": true,
5
+ "lib": ["ES2022", "DOM", "DOM.Iterable"],
6
+ "types": ["vite/client"],
7
+ "module": "ESNext",
8
+ "skipLibCheck": true,
9
+ "moduleResolution": "bundler",
10
+ "allowImportingTsExtensions": true,
11
+ "resolveJsonModule": true,
12
+ "isolatedModules": true,
13
+ "noEmit": true,
14
+ "jsx": "react-jsx",
15
+ "strict": true,
16
+ "noUnusedLocals": false,
17
+ "noUnusedParameters": false,
18
+ "noFallthroughCasesInSwitch": true,
19
+ "baseUrl": ".",
20
+ "paths": {
21
+ "@/*": ["./src/*"],
22
+ "@generated/*": ["./src/generated/*"],
23
+ "@pages/*": ["./src/pages/*"],
24
+ "@app/shared": ["../shared/src/index.ts"],
25
+ "@app/shared/*": ["../shared/src/*"],
26
+ "@shared/*": ["../shared/src/*"],
27
+ "@design-system": ["../../../design-system/index.ts"],
28
+ "@design-system/*": ["../../../design-system/*"]
29
+ }
30
+ },
31
+ "include": ["src", "../../../design-system/types"],
32
+ "exclude": ["node_modules", "dist", "src/**/__tests__", "src/**/*.stories.ts", "src/**/*.stories.tsx"]
33
+ }
@@ -0,0 +1,49 @@
1
+ import { defineConfig, loadEnv } from 'vite';
2
+ import react from '@vitejs/plugin-react';
3
+ import path from 'path';
4
+
5
+ export default defineConfig(({ mode }) => {
6
+ const env = loadEnv(mode, process.cwd(), '');
7
+ const backendUrl = env.VITE_API_URL || 'http://localhost:3030';
8
+ const wsUrl = backendUrl.replace('http://', 'ws://').replace('https://', 'wss://');
9
+
10
+ return {
11
+ plugins: [react()],
12
+
13
+ resolve: {
14
+ alias: {
15
+ '@design-system': path.resolve(__dirname, '../../../design-system'),
16
+ '@': path.resolve(__dirname, './src'),
17
+ '@generated': path.resolve(__dirname, './src/generated'),
18
+ '@pages': path.resolve(__dirname, './src/pages'),
19
+ '@app/shared': path.resolve(__dirname, '../shared/src'),
20
+ '@shared': path.resolve(__dirname, '../shared/src'),
21
+ },
22
+ },
23
+
24
+ server: {
25
+ host: true,
26
+ port: 5173,
27
+ proxy: {
28
+ '/api': {
29
+ target: backendUrl,
30
+ changeOrigin: true,
31
+ },
32
+ '/ws': {
33
+ target: wsUrl,
34
+ ws: true,
35
+ },
36
+ },
37
+ },
38
+
39
+ build: {
40
+ outDir: 'dist',
41
+ sourcemap: true,
42
+ },
43
+
44
+ test: {
45
+ environment: 'jsdom',
46
+ globals: true,
47
+ },
48
+ };
49
+ });
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ const tsParser = require("@typescript-eslint/parser");
3
+ const almadarPlugin = require("@almadar/eslint-plugin");
4
+
5
+ module.exports = [
6
+ { ignores: ["dist/**", "node_modules/**", "**/*.test.ts"] },
7
+ {
8
+ files: ["src/**/*.ts"],
9
+ languageOptions: {
10
+ parser: tsParser,
11
+ parserOptions: { ecmaVersion: "latest", sourceType: "module" },
12
+ },
13
+ plugins: { almadar: almadarPlugin },
14
+ rules: {
15
+ "almadar/no-as-any": "error",
16
+ "almadar/no-import-generated": "error",
17
+ },
18
+ },
19
+ ];
@@ -0,0 +1,37 @@
1
+ {
2
+ "name": "@almadar/shell-server",
3
+ "version": "1.0.0",
4
+ "private": true,
5
+ "type": "module",
6
+ "scripts": {
7
+ "dev": "tsx watch src/index.ts",
8
+ "build": "esbuild src/index.ts --bundle --platform=node --format=esm --packages=external --outfile=dist/index.js",
9
+ "start": "node dist/index.js",
10
+ "typecheck": "tsc --noEmit",
11
+ "lint": "eslint src/",
12
+ "test": "vitest run --passWithNoTests",
13
+ "test:watch": "vitest"
14
+ },
15
+ "dependencies": {
16
+ "@almadar/server": "^2.0.2",
17
+ "@almadar/evaluator": "^2.0.0",
18
+ "@almadar/core": "^2.1.0",
19
+ "cors": "^2.8.5",
20
+ "dotenv": "^16.4.7",
21
+ "express": "^4.21.2",
22
+ "firebase-admin": "^12.7.0",
23
+ "zod": "^3.22.0"
24
+ },
25
+ "devDependencies": {
26
+ "@almadar/eslint-plugin": ">=2.3.0",
27
+ "@typescript-eslint/parser": "8.56.0",
28
+ "@types/cors": "^2.8.17",
29
+ "@types/express": "^5.0.0",
30
+ "@types/node": "^20.17.19",
31
+ "eslint": "10.0.0",
32
+ "esbuild": "^0.25.0",
33
+ "tsx": "^4.19.3",
34
+ "typescript": "^5.7.3",
35
+ "vitest": "^2.1.9"
36
+ }
37
+ }
@@ -0,0 +1,36 @@
1
+ /**
2
+ * Express Application Setup
3
+ */
4
+
5
+ import express, { type Express } from 'express';
6
+ import cors from 'cors';
7
+ import {
8
+ env,
9
+ logger,
10
+ errorHandler,
11
+ notFoundHandler,
12
+ debugEventsRouter,
13
+ } from '@almadar/server';
14
+ import { registerRoutes } from './routes.js';
15
+
16
+ export const app: Express = express();
17
+
18
+ // Middleware
19
+ app.use(cors({ origin: true, credentials: true }));
20
+ app.use(express.json());
21
+ app.use(express.urlencoded({ extended: true }));
22
+
23
+ // Health check
24
+ app.get('/health', (_req, res) => {
25
+ res.json({ status: 'ok' });
26
+ });
27
+
28
+ // Debug event bus endpoints (dev-only, no-op in production)
29
+ app.use('/api/debug', debugEventsRouter());
30
+
31
+ // Register generated routes
32
+ registerRoutes(app);
33
+
34
+ // Error handling
35
+ app.use(notFoundHandler);
36
+ app.use(errorHandler);
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Server Entry Point
3
+ */
4
+
5
+ import { initializeFirebase, env, logger } from '@almadar/server';
6
+
7
+ // Initialize Firebase before anything else uses it
8
+ initializeFirebase();
9
+
10
+ import { app } from './app.js';
11
+
12
+ const PORT = env.PORT || 3030;
13
+
14
+ async function start(): Promise<void> {
15
+ // Seed mock data when USE_MOCK_DATA is enabled
16
+ if (env.USE_MOCK_DATA) {
17
+ try {
18
+ const { initializeMockData } = await import(/* @vite-ignore */ './seedMockData.js' as string);
19
+ await initializeMockData();
20
+ } catch {
21
+ logger.warn('seedMockData.ts not found — skipping mock data seeding');
22
+ }
23
+ }
24
+
25
+ app.listen(PORT, () => {
26
+ logger.info(`Server running on port ${PORT}`);
27
+ });
28
+ }
29
+
30
+ start();
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Route Registration
3
+ *
4
+ * Compiler generates route registration code here.
5
+ */
6
+
7
+ import type { Express } from 'express';
8
+
9
+ export function registerRoutes(app: Express): void {
10
+ // {{GENERATED_ROUTE_REGISTRATION}}
11
+ }
@@ -0,0 +1,15 @@
1
+ declare global {
2
+ namespace Express {
3
+ interface Request {
4
+ firebaseUser?: {
5
+ uid: string;
6
+ email?: string;
7
+ name?: string;
8
+ picture?: string;
9
+ [key: string]: unknown;
10
+ };
11
+ }
12
+ }
13
+ }
14
+
15
+ export {};
@@ -0,0 +1,23 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "module": "ESNext",
5
+ "moduleResolution": "bundler",
6
+ "outDir": "./dist",
7
+ "strict": true,
8
+ "strictNullChecks": false,
9
+ "esModuleInterop": true,
10
+ "skipLibCheck": true,
11
+ "forceConsistentCasingInFileNames": true,
12
+ "declaration": true,
13
+ "declarationMap": true,
14
+ "baseUrl": ".",
15
+ "paths": {
16
+ "@/*": ["./src/*"],
17
+ "@app/shared": ["../shared/src/index.ts"],
18
+ "@app/shared/*": ["../shared/src/*"]
19
+ }
20
+ },
21
+ "include": ["src"],
22
+ "exclude": ["node_modules", "dist", "src/**/__tests__/**", "src/**/*.test.ts", "src/**/*.spec.ts"]
23
+ }
@@ -0,0 +1,10 @@
1
+ {
2
+ "name": "@app/shared",
3
+ "version": "1.0.0",
4
+ "private": true,
5
+ "main": "src/index.ts",
6
+ "types": "src/index.ts",
7
+ "dependencies": {
8
+ "zod": "^3.22.0"
9
+ }
10
+ }
@@ -0,0 +1,2 @@
1
+ // Placeholder — the compiler generates actual shared types here.
2
+ export {};