@specverse/engines 4.1.30 → 4.2.0
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.
- package/assets/examples/manifests/frontend-only.yaml +3 -6
- package/assets/examples/manifests/fullstack-app.yaml +5 -7
- package/assets/examples/manifests/fullstack-monorepo.yaml +3 -6
- package/dist/inference/comprehensive-engine.d.ts.map +1 -1
- package/dist/inference/comprehensive-engine.js +3 -19
- package/dist/inference/comprehensive-engine.js.map +1 -1
- package/dist/inference/core/rule-engine.d.ts +31 -0
- package/dist/inference/core/rule-engine.d.ts.map +1 -1
- package/dist/inference/core/rule-engine.js +117 -33
- package/dist/inference/core/rule-engine.js.map +1 -1
- package/dist/inference/core/rule-file-types.d.ts +0 -2
- package/dist/inference/core/rule-file-types.d.ts.map +1 -1
- package/dist/inference/core/rule-file-types.js +3 -6
- package/dist/inference/core/rule-file-types.js.map +1 -1
- package/dist/inference/core/rule-loader.d.ts +5 -15
- package/dist/inference/core/rule-loader.d.ts.map +1 -1
- package/dist/inference/core/rule-loader.js +43 -132
- package/dist/inference/core/rule-loader.js.map +1 -1
- package/dist/inference/core/types.d.ts +0 -6
- package/dist/inference/core/types.d.ts.map +1 -1
- package/dist/inference/core/types.js +0 -4
- package/dist/inference/core/types.js.map +1 -1
- package/dist/inference/logical/generators/component-type-resolver.d.ts +0 -26
- package/dist/inference/logical/generators/component-type-resolver.d.ts.map +1 -1
- package/dist/inference/logical/generators/component-type-resolver.js +0 -19
- package/dist/inference/logical/generators/component-type-resolver.js.map +1 -1
- package/dist/inference/logical/generators/specialist-view-expander.d.ts +1 -17
- package/dist/inference/logical/generators/specialist-view-expander.d.ts.map +1 -1
- package/dist/inference/logical/generators/specialist-view-expander.js +0 -15
- package/dist/inference/logical/generators/specialist-view-expander.js.map +1 -1
- package/dist/inference/logical/generators/view-generator.d.ts +4 -14
- package/dist/inference/logical/generators/view-generator.d.ts.map +1 -1
- package/dist/inference/logical/generators/view-generator.js +6 -26
- package/dist/inference/logical/generators/view-generator.js.map +1 -1
- package/dist/inference/logical/index.d.ts +2 -2
- package/dist/inference/logical/index.d.ts.map +1 -1
- package/dist/inference/logical/logical-engine.d.ts.map +1 -1
- package/dist/inference/logical/logical-engine.js +17 -80
- package/dist/inference/logical/logical-engine.js.map +1 -1
- package/dist/inference/quint-transpiler.d.ts +5 -3
- package/dist/inference/quint-transpiler.d.ts.map +1 -1
- package/dist/inference/quint-transpiler.js +11 -6
- package/dist/inference/quint-transpiler.js.map +1 -1
- package/dist/libs/instance-factories/applications/templates/react-starter/app-tsx-generator.js +110 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/dashboard-body-composer.js +121 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/detail-body-composer.js +78 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/form-body-composer.js +190 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/helpers-emitter.js +45 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/html-to-jsx.js +192 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/list-body-composer.js +46 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/orchestrator.js +30 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/package-json-generator.js +38 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/regen-safety.js +89 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/view-emitter.js +56 -0
- package/dist/libs/instance-factories/applications/templates/react-starter/views-generator.js +66 -0
- package/dist/libs/instance-factories/cli/templates/commander/command-generator.js +14 -11
- package/dist/realize/index.d.ts.map +1 -1
- package/dist/realize/index.js +15 -22
- package/dist/realize/index.js.map +1 -1
- package/dist/registry/utils/manifest-adapter.d.ts +8 -1
- package/dist/registry/utils/manifest-adapter.d.ts.map +1 -1
- package/dist/registry/utils/manifest-adapter.js +8 -1
- package/dist/registry/utils/manifest-adapter.js.map +1 -1
- package/libs/instance-factories/applications/react-app-starter.yaml +150 -0
- package/libs/instance-factories/applications/templates/react-starter/README.md +211 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/dashboard-body-composer.test.ts +153 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/detail-body-composer.test.ts +145 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/form-body-composer.test.ts +175 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/helpers-emitter.test.ts +55 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/html-to-jsx.test.ts +140 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/list-body-composer.test.ts +146 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/orchestrator.test.ts +163 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/parity-p2-factory-imports.test.ts +116 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/parity-p3-rendered-output.test.ts +183 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/regen-safety.test.ts +144 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/starter-generators.test.ts +114 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/view-emitter.test.ts +107 -0
- package/libs/instance-factories/applications/templates/react-starter/__tests__/views-generator.test.ts +139 -0
- package/libs/instance-factories/applications/templates/react-starter/app-tsx-generator.ts +141 -0
- package/libs/instance-factories/applications/templates/react-starter/dashboard-body-composer.ts +174 -0
- package/libs/instance-factories/applications/templates/react-starter/detail-body-composer.ts +135 -0
- package/libs/instance-factories/applications/templates/react-starter/form-body-composer.ts +306 -0
- package/libs/instance-factories/applications/templates/react-starter/helpers-emitter.ts +60 -0
- package/libs/instance-factories/applications/templates/react-starter/html-to-jsx.ts +334 -0
- package/libs/instance-factories/applications/templates/react-starter/list-body-composer.ts +120 -0
- package/libs/instance-factories/applications/templates/react-starter/orchestrator.ts +80 -0
- package/libs/instance-factories/applications/templates/react-starter/package-json-generator.ts +57 -0
- package/libs/instance-factories/applications/templates/react-starter/regen-safety.ts +157 -0
- package/libs/instance-factories/applications/templates/react-starter/skeletons/dashboard.tsx.template +47 -0
- package/libs/instance-factories/applications/templates/react-starter/skeletons/detail.tsx.template +94 -0
- package/libs/instance-factories/applications/templates/react-starter/skeletons/form.tsx.template +114 -0
- package/libs/instance-factories/applications/templates/react-starter/skeletons/list.tsx.template +72 -0
- package/libs/instance-factories/applications/templates/react-starter/view-emitter.ts +151 -0
- package/libs/instance-factories/applications/templates/react-starter/views-generator.ts +137 -0
- package/libs/instance-factories/cli/templates/commander/command-generator.ts +14 -11
- package/package.json +3 -3
- package/dist/libs/instance-factories/applications/templates/react/_view-components-source.js +0 -530
- package/dist/libs/instance-factories/applications/templates/react/app-tsx-generator.js +0 -73
- package/dist/libs/instance-factories/applications/templates/react/field-helpers-generator.js +0 -99
- package/dist/libs/instance-factories/applications/templates/react/package-json-generator.js +0 -49
- package/dist/libs/instance-factories/applications/templates/react/pattern-adapter-generator.js +0 -156
- package/dist/libs/instance-factories/applications/templates/react/react-pattern-adapter.js +0 -935
- package/dist/libs/instance-factories/applications/templates/react/relationship-field-generator.js +0 -143
- package/dist/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.js +0 -646
- package/dist/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.js +0 -65
- package/dist/libs/instance-factories/applications/templates/react/view-dashboard-generator.js +0 -143
- package/dist/libs/instance-factories/applications/templates/react/view-detail-generator.js +0 -143
- package/dist/libs/instance-factories/applications/templates/react/view-form-generator.js +0 -355
- package/dist/libs/instance-factories/applications/templates/react/view-list-generator.js +0 -91
- package/dist/libs/instance-factories/applications/templates/react/view-router-generator.js +0 -79
- package/dist/libs/instance-factories/views/index.js +0 -48
- package/dist/libs/instance-factories/views/templates/react/adapters/antd-adapter.js +0 -742
- package/dist/libs/instance-factories/views/templates/react/adapters/mui-adapter.js +0 -824
- package/dist/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.js +0 -719
- package/dist/libs/instance-factories/views/templates/react/app-generator.js +0 -45
- package/dist/libs/instance-factories/views/templates/react/components-generator.js +0 -820
- package/dist/libs/instance-factories/views/templates/react/forms-generator.js +0 -275
- package/dist/libs/instance-factories/views/templates/react/frontend-package-json-generator.js +0 -46
- package/dist/libs/instance-factories/views/templates/react/hooks-generator.js +0 -81
- package/dist/libs/instance-factories/views/templates/react/index-css-generator.js +0 -9
- package/dist/libs/instance-factories/views/templates/react/index-html-generator.js +0 -23
- package/dist/libs/instance-factories/views/templates/react/main-tsx-generator.js +0 -21
- package/dist/libs/instance-factories/views/templates/react/react-component-generator.js +0 -299
- package/dist/libs/instance-factories/views/templates/react/router-generator.js +0 -136
- package/dist/libs/instance-factories/views/templates/react/router-generic-generator.js +0 -107
- package/dist/libs/instance-factories/views/templates/react/shared-utils-generator.js +0 -187
- package/dist/libs/instance-factories/views/templates/react/spec-json-generator.js +0 -7
- package/dist/libs/instance-factories/views/templates/react/types-generator.js +0 -56
- package/dist/libs/instance-factories/views/templates/react/views-metadata-generator.js +0 -27
- package/dist/libs/instance-factories/views/templates/react/vite-config-generator.js +0 -29
- package/dist/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js +0 -261
- package/dist/libs/instance-factories/views/templates/shared/adapter-types.js +0 -34
- package/dist/libs/instance-factories/views/templates/shared/atomic-components-registry.js +0 -800
- package/dist/libs/instance-factories/views/templates/shared/base-generator.js +0 -305
- package/dist/libs/instance-factories/views/templates/shared/component-metadata.js +0 -517
- package/dist/libs/instance-factories/views/templates/shared/composite-pattern-types.js +0 -0
- package/dist/libs/instance-factories/views/templates/shared/composite-patterns.js +0 -445
- package/dist/libs/instance-factories/views/templates/shared/index.js +0 -80
- package/dist/libs/instance-factories/views/templates/shared/pattern-validator.js +0 -210
- package/dist/libs/instance-factories/views/templates/shared/property-mapper.js +0 -492
- package/dist/libs/instance-factories/views/templates/shared/syntax-mapper.js +0 -321
- package/dist/realize/index.js.bak +0 -758
- package/libs/instance-factories/applications/react-app.yaml +0 -186
- package/libs/instance-factories/applications/templates/react/_view-components-source.ts +0 -555
- package/libs/instance-factories/applications/templates/react/app-tsx-generator.ts +0 -94
- package/libs/instance-factories/applications/templates/react/field-helpers-generator.ts +0 -106
- package/libs/instance-factories/applications/templates/react/package-json-generator.ts +0 -57
- package/libs/instance-factories/applications/templates/react/pattern-adapter-generator.ts +0 -179
- package/libs/instance-factories/applications/templates/react/react-pattern-adapter.tsx +0 -1347
- package/libs/instance-factories/applications/templates/react/relationship-field-generator.ts +0 -150
- package/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts +0 -704
- package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts +0 -84
- package/libs/instance-factories/applications/templates/react/view-dashboard-generator.ts +0 -150
- package/libs/instance-factories/applications/templates/react/view-detail-generator.ts +0 -150
- package/libs/instance-factories/applications/templates/react/view-form-generator.ts +0 -362
- package/libs/instance-factories/applications/templates/react/view-list-generator.ts +0 -98
- package/libs/instance-factories/applications/templates/react/view-router-generator.ts +0 -89
- package/libs/instance-factories/views/README.md +0 -62
- package/libs/instance-factories/views/index.d.ts +0 -13
- package/libs/instance-factories/views/index.d.ts.map +0 -1
- package/libs/instance-factories/views/index.js +0 -18
- package/libs/instance-factories/views/index.js.map +0 -1
- package/libs/instance-factories/views/index.ts +0 -45
- package/libs/instance-factories/views/react-components.yaml +0 -129
- package/libs/instance-factories/views/templates/ARCHITECTURE.md +0 -198
- package/libs/instance-factories/views/templates/react/adapters/antd-adapter.ts +0 -869
- package/libs/instance-factories/views/templates/react/adapters/mui-adapter.ts +0 -953
- package/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.ts +0 -806
- package/libs/instance-factories/views/templates/react/app-generator.ts +0 -55
- package/libs/instance-factories/views/templates/react/components-generator.ts +0 -938
- package/libs/instance-factories/views/templates/react/forms-generator.ts +0 -325
- package/libs/instance-factories/views/templates/react/frontend-package-json-generator.ts +0 -57
- package/libs/instance-factories/views/templates/react/hooks-generator.ts +0 -106
- package/libs/instance-factories/views/templates/react/index-css-generator.ts +0 -14
- package/libs/instance-factories/views/templates/react/index-html-generator.ts +0 -34
- package/libs/instance-factories/views/templates/react/main-tsx-generator.ts +0 -29
- package/libs/instance-factories/views/templates/react/react-component-generator.d.ts +0 -152
- package/libs/instance-factories/views/templates/react/react-component-generator.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/react/react-component-generator.js +0 -398
- package/libs/instance-factories/views/templates/react/react-component-generator.js.map +0 -1
- package/libs/instance-factories/views/templates/react/react-component-generator.ts +0 -533
- package/libs/instance-factories/views/templates/react/router-generator.ts +0 -197
- package/libs/instance-factories/views/templates/react/router-generic-generator.ts +0 -132
- package/libs/instance-factories/views/templates/react/shared-utils-generator.ts +0 -196
- package/libs/instance-factories/views/templates/react/spec-json-generator.ts +0 -17
- package/libs/instance-factories/views/templates/react/types-generator.ts +0 -76
- package/libs/instance-factories/views/templates/react/views-metadata-generator.ts +0 -42
- package/libs/instance-factories/views/templates/react/vite-config-generator.ts +0 -38
- package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js.map +0 -1
- package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.ts +0 -474
- package/libs/instance-factories/views/templates/shared/__tests__/composite-patterns.test.ts +0 -242
- package/libs/instance-factories/views/templates/shared/adapter-types.d.ts +0 -77
- package/libs/instance-factories/views/templates/shared/adapter-types.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/shared/adapter-types.js +0 -47
- package/libs/instance-factories/views/templates/shared/adapter-types.js.map +0 -1
- package/libs/instance-factories/views/templates/shared/adapter-types.ts +0 -142
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts +0 -63
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.js +0 -822
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.js.map +0 -1
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.ts +0 -908
- package/libs/instance-factories/views/templates/shared/base-generator.d.ts +0 -247
- package/libs/instance-factories/views/templates/shared/base-generator.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/shared/base-generator.js +0 -363
- package/libs/instance-factories/views/templates/shared/base-generator.js.map +0 -1
- package/libs/instance-factories/views/templates/shared/base-generator.ts +0 -608
- package/libs/instance-factories/views/templates/shared/component-metadata.d.ts +0 -254
- package/libs/instance-factories/views/templates/shared/component-metadata.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/shared/component-metadata.js +0 -602
- package/libs/instance-factories/views/templates/shared/component-metadata.js.map +0 -1
- package/libs/instance-factories/views/templates/shared/component-metadata.ts +0 -803
- package/libs/instance-factories/views/templates/shared/composite-pattern-types.ts +0 -250
- package/libs/instance-factories/views/templates/shared/composite-patterns.ts +0 -535
- package/libs/instance-factories/views/templates/shared/index.ts +0 -68
- package/libs/instance-factories/views/templates/shared/pattern-validator.ts +0 -279
- package/libs/instance-factories/views/templates/shared/property-mapper.d.ts +0 -149
- package/libs/instance-factories/views/templates/shared/property-mapper.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/shared/property-mapper.js +0 -580
- package/libs/instance-factories/views/templates/shared/property-mapper.js.map +0 -1
- package/libs/instance-factories/views/templates/shared/property-mapper.ts +0 -700
- package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts +0 -143
- package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts.map +0 -1
- package/libs/instance-factories/views/templates/shared/syntax-mapper.js +0 -420
- package/libs/instance-factories/views/templates/shared/syntax-mapper.js.map +0 -1
- package/libs/instance-factories/views/templates/shared/syntax-mapper.ts +0 -539
package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts
DELETED
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tailwind Adapter Wrapper Generator
|
|
3
|
-
*
|
|
4
|
-
* Bundles the tailwind-adapter-generator.ts source file for generated projects.
|
|
5
|
-
* This file is imported by react-pattern-adapter.tsx.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { readFileSync, existsSync } from 'fs';
|
|
9
|
-
import { join, dirname } from 'path';
|
|
10
|
-
import { fileURLToPath } from 'url';
|
|
11
|
-
|
|
12
|
-
export interface TailwindAdapterGeneratorContext {
|
|
13
|
-
spec: any;
|
|
14
|
-
manifest: any;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export async function generate(context: TailwindAdapterGeneratorContext): Promise<string> {
|
|
18
|
-
const __filename = fileURLToPath(import.meta.url);
|
|
19
|
-
const __dirname = dirname(__filename);
|
|
20
|
-
|
|
21
|
-
// Try to find the tailwind-adapter-generator.ts source file
|
|
22
|
-
const possiblePaths = [
|
|
23
|
-
// PRIORITY 1: Bundled with package (in libs/ directory)
|
|
24
|
-
join(__dirname, '../../../../../../libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts'),
|
|
25
|
-
// PRIORITY 2: Development environment (local)
|
|
26
|
-
join(__dirname, './tailwind-adapter-generator.ts'),
|
|
27
|
-
join(__dirname, '../tailwind-adapter-generator.ts')
|
|
28
|
-
];
|
|
29
|
-
|
|
30
|
-
let adapterSource: string | null = null;
|
|
31
|
-
let foundPath: string | null = null;
|
|
32
|
-
|
|
33
|
-
for (const path of possiblePaths) {
|
|
34
|
-
if (existsSync(path)) {
|
|
35
|
-
try {
|
|
36
|
-
adapterSource = readFileSync(path, 'utf-8');
|
|
37
|
-
foundPath = path;
|
|
38
|
-
break;
|
|
39
|
-
} catch (error) {
|
|
40
|
-
// Continue to next path
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (adapterSource) {
|
|
46
|
-
// Successfully read the adapter - return it with a header comment
|
|
47
|
-
return `/**
|
|
48
|
-
* Universal Tailwind Adapter Generator
|
|
49
|
-
*
|
|
50
|
-
* AUTO-GENERATED: Copied from @specverse/lang
|
|
51
|
-
* Source: ${foundPath}
|
|
52
|
-
*
|
|
53
|
-
* This file provides Tailwind CSS rendering for all atomic component types.
|
|
54
|
-
* It is imported by react-pattern-adapter.tsx.
|
|
55
|
-
*
|
|
56
|
-
* DO NOT EDIT: Changes will be overwritten on next generation.
|
|
57
|
-
*/
|
|
58
|
-
|
|
59
|
-
${adapterSource}
|
|
60
|
-
`;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
// Fallback: Return minimal stub (should never happen with bundled source)
|
|
64
|
-
return `/**
|
|
65
|
-
* Tailwind Adapter Generator (STUB)
|
|
66
|
-
*
|
|
67
|
-
* ⚠️ WARNING: Could not locate tailwind-adapter-generator.ts source file.
|
|
68
|
-
*/
|
|
69
|
-
|
|
70
|
-
import type { ComponentAdapter } from '@specverse/lang';
|
|
71
|
-
|
|
72
|
-
export function createUniversalTailwindAdapter(): ComponentAdapter {
|
|
73
|
-
return {
|
|
74
|
-
renderComponent(type: string, properties: Record<string, any> = {}, children?: string): string {
|
|
75
|
-
return \`<div class="p-4 border border-gray-300 rounded bg-gray-50">
|
|
76
|
-
<span class="text-gray-700">\${type}</span>
|
|
77
|
-
</div>\`;
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
console.warn('⚠️ Using stub Tailwind adapter - full source file not found during generation');
|
|
83
|
-
`;
|
|
84
|
-
}
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* DashboardView Generator (Pattern-Based v0.9.0)
|
|
3
|
-
* Generates pattern-based DashboardView using RuntimeView architecture
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
export interface ViewDashboardGeneratorContext {
|
|
7
|
-
spec: any;
|
|
8
|
-
manifest: any;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export async function generate(context: ViewDashboardGeneratorContext): Promise<string> {
|
|
12
|
-
return `/**
|
|
13
|
-
* DashboardView - Pattern-Based Dashboard View Component
|
|
14
|
-
*
|
|
15
|
-
* Uses pattern-based rendering with ReactPatternAdapter.
|
|
16
|
-
* Supports multi-component dashboard layouts with entity selection.
|
|
17
|
-
*/
|
|
18
|
-
|
|
19
|
-
import { useState, useEffect, useMemo } from 'react';
|
|
20
|
-
import { useEntitiesQuery, useModelSchemaQuery } from '../../hooks/useApi';
|
|
21
|
-
import { usePatternAdapter, REACT_PROTOCOL_MAPPING } from '../../lib/react-pattern-adapter';
|
|
22
|
-
import type { View } from '../../types/api';
|
|
23
|
-
|
|
24
|
-
interface DashboardViewProps {
|
|
25
|
-
view: View;
|
|
26
|
-
spec?: any;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function DashboardView({ view, spec }: DashboardViewProps) {
|
|
30
|
-
const patternAdapter = usePatternAdapter();
|
|
31
|
-
|
|
32
|
-
// Determine controller and model
|
|
33
|
-
let controllerName: string;
|
|
34
|
-
let modelName: string;
|
|
35
|
-
|
|
36
|
-
if (view.controller && spec) {
|
|
37
|
-
controllerName = view.controller;
|
|
38
|
-
const controller = spec.controllers[view.controller];
|
|
39
|
-
modelName = controller.model;
|
|
40
|
-
} else {
|
|
41
|
-
modelName = view.model as string;
|
|
42
|
-
controllerName = \`\${modelName}Controller\`;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
// Fetch data and schema
|
|
46
|
-
const { data: entities = [] } = useEntitiesQuery(controllerName, modelName);
|
|
47
|
-
const { data: schema } = useModelSchemaQuery(modelName);
|
|
48
|
-
|
|
49
|
-
// Track selected entity
|
|
50
|
-
const [selectedEntityId, setSelectedEntityId] = useState<string | null>(
|
|
51
|
-
entities.length > 0 ? entities[0].id : null
|
|
52
|
-
);
|
|
53
|
-
|
|
54
|
-
// Update selected entity when entities change
|
|
55
|
-
useEffect(() => {
|
|
56
|
-
if (entities.length > 0 && !selectedEntityId) {
|
|
57
|
-
setSelectedEntityId(entities[0].id);
|
|
58
|
-
}
|
|
59
|
-
}, [entities, selectedEntityId]);
|
|
60
|
-
|
|
61
|
-
// Get selected entity
|
|
62
|
-
const selectedEntity = useMemo(
|
|
63
|
-
() => entities.find((e: any) => e.id === selectedEntityId) || null,
|
|
64
|
-
[entities, selectedEntityId]
|
|
65
|
-
);
|
|
66
|
-
|
|
67
|
-
// Build model data and schemas
|
|
68
|
-
const modelData = useMemo(() => ({
|
|
69
|
-
[modelName]: entities
|
|
70
|
-
}), [modelName, entities]);
|
|
71
|
-
|
|
72
|
-
const modelSchemas = useMemo(() =>
|
|
73
|
-
schema ? { [modelName]: schema } : {}
|
|
74
|
-
, [modelName, schema]);
|
|
75
|
-
|
|
76
|
-
if (entities.length === 0) {
|
|
77
|
-
return <div className="p-4">No entities found</div>;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// Detect pattern
|
|
81
|
-
const pattern = patternAdapter.detectPattern({ ...view, type: 'dashboard' });
|
|
82
|
-
|
|
83
|
-
if (!pattern) {
|
|
84
|
-
return (
|
|
85
|
-
<div className="p-4 text-red-600">
|
|
86
|
-
Pattern not found for dashboard view
|
|
87
|
-
</div>
|
|
88
|
-
);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// Build render context
|
|
92
|
-
const context = {
|
|
93
|
-
pattern,
|
|
94
|
-
viewSpec: { ...view, type: 'dashboard', model: modelName },
|
|
95
|
-
modelData,
|
|
96
|
-
modelSchemas,
|
|
97
|
-
primaryModel: modelName,
|
|
98
|
-
selectedEntity,
|
|
99
|
-
primaryEntities: entities,
|
|
100
|
-
protocolMapping: REACT_PROTOCOL_MAPPING,
|
|
101
|
-
tailwindAdapter: patternAdapter['tailwindAdapter']
|
|
102
|
-
};
|
|
103
|
-
|
|
104
|
-
// Render entity selector
|
|
105
|
-
let html = '';
|
|
106
|
-
if (entities.length > 0) {
|
|
107
|
-
html += \`
|
|
108
|
-
<div class="mb-4 pb-4 border-b border-gray-200 dark:border-gray-700">
|
|
109
|
-
<label class="block text-sm font-semibold text-gray-700 dark:text-gray-200 mb-2">
|
|
110
|
-
Select \${modelName}:
|
|
111
|
-
</label>
|
|
112
|
-
<select
|
|
113
|
-
id="entity-selector"
|
|
114
|
-
class="w-full max-w-md px-3 py-2 border border-gray-300 dark:border-gray-600 rounded bg-white dark:bg-gray-700 text-gray-900 dark:text-gray-100 focus:outline-none focus:ring-2 focus:ring-blue-500"
|
|
115
|
-
>
|
|
116
|
-
\${entities.map((entity: any) => {
|
|
117
|
-
const displayName = entity.data?.name || entity.data?.title || entity.id;
|
|
118
|
-
return \`<option value="\${entity.id}" \${entity.id === selectedEntityId ? 'selected' : ''}>\${displayName}</option>\`;
|
|
119
|
-
}).join('')}
|
|
120
|
-
</select>
|
|
121
|
-
</div>
|
|
122
|
-
\`;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
// Render pattern
|
|
126
|
-
html += patternAdapter.renderPattern(context);
|
|
127
|
-
|
|
128
|
-
// Add event handler for selector
|
|
129
|
-
useEffect(() => {
|
|
130
|
-
const selector = document.getElementById('entity-selector') as HTMLSelectElement;
|
|
131
|
-
if (selector) {
|
|
132
|
-
const handler = (e: Event) => {
|
|
133
|
-
const newId = (e.target as HTMLSelectElement).value;
|
|
134
|
-
setSelectedEntityId(newId);
|
|
135
|
-
};
|
|
136
|
-
selector.addEventListener('change', handler);
|
|
137
|
-
return () => selector.removeEventListener('change', handler);
|
|
138
|
-
}
|
|
139
|
-
}, [html]);
|
|
140
|
-
|
|
141
|
-
return (
|
|
142
|
-
<div className="runtime-view-container p-4 h-full overflow-auto">
|
|
143
|
-
<div dangerouslySetInnerHTML={{ __html: html }} />
|
|
144
|
-
</div>
|
|
145
|
-
);
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
export default DashboardView;
|
|
149
|
-
`;
|
|
150
|
-
}
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* DetailView Generator (Pattern-Based v0.9.0)
|
|
3
|
-
* Generates pattern-based DetailView using RuntimeView architecture
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
export interface ViewDetailGeneratorContext {
|
|
7
|
-
spec: any;
|
|
8
|
-
manifest: any;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export async function generate(context: ViewDetailGeneratorContext): Promise<string> {
|
|
12
|
-
return `/**
|
|
13
|
-
* DetailView - Pattern-Based Detail View Component
|
|
14
|
-
*
|
|
15
|
-
* Uses pattern-based rendering with ReactPatternAdapter.
|
|
16
|
-
* Supports entity selection and relationship display.
|
|
17
|
-
*/
|
|
18
|
-
|
|
19
|
-
import { useState, useEffect, useMemo } from 'react';
|
|
20
|
-
import { useEntitiesQuery, useModelSchemaQuery } from '../../hooks/useApi';
|
|
21
|
-
import { usePatternAdapter, REACT_PROTOCOL_MAPPING } from '../../lib/react-pattern-adapter';
|
|
22
|
-
import type { View } from '../../types/api';
|
|
23
|
-
|
|
24
|
-
interface DetailViewProps {
|
|
25
|
-
view: View;
|
|
26
|
-
spec?: any;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function DetailView({ view, spec }: DetailViewProps) {
|
|
30
|
-
const patternAdapter = usePatternAdapter();
|
|
31
|
-
|
|
32
|
-
// Determine controller and model
|
|
33
|
-
let controllerName: string;
|
|
34
|
-
let modelName: string;
|
|
35
|
-
|
|
36
|
-
if (view.controller && spec) {
|
|
37
|
-
controllerName = view.controller;
|
|
38
|
-
const controller = spec.controllers[view.controller];
|
|
39
|
-
modelName = controller.model;
|
|
40
|
-
} else {
|
|
41
|
-
modelName = view.model as string;
|
|
42
|
-
controllerName = \`\${modelName}Controller\`;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
// Fetch data and schema
|
|
46
|
-
const { data: entities = [] } = useEntitiesQuery(controllerName, modelName);
|
|
47
|
-
const { data: schema } = useModelSchemaQuery(modelName);
|
|
48
|
-
|
|
49
|
-
// Track selected entity
|
|
50
|
-
const [selectedEntityId, setSelectedEntityId] = useState<string | null>(
|
|
51
|
-
entities.length > 0 ? entities[0].id : null
|
|
52
|
-
);
|
|
53
|
-
|
|
54
|
-
// Update selected entity when entities change
|
|
55
|
-
useEffect(() => {
|
|
56
|
-
if (entities.length > 0 && !selectedEntityId) {
|
|
57
|
-
setSelectedEntityId(entities[0].id);
|
|
58
|
-
}
|
|
59
|
-
}, [entities, selectedEntityId]);
|
|
60
|
-
|
|
61
|
-
// Get selected entity
|
|
62
|
-
const selectedEntity = useMemo(
|
|
63
|
-
() => entities.find((e: any) => e.id === selectedEntityId) || null,
|
|
64
|
-
[entities, selectedEntityId]
|
|
65
|
-
);
|
|
66
|
-
|
|
67
|
-
// Build model data and schemas
|
|
68
|
-
const modelData = useMemo(() => ({
|
|
69
|
-
[modelName]: entities
|
|
70
|
-
}), [modelName, entities]);
|
|
71
|
-
|
|
72
|
-
const modelSchemas = useMemo(() =>
|
|
73
|
-
schema ? { [modelName]: schema } : {}
|
|
74
|
-
, [modelName, schema]);
|
|
75
|
-
|
|
76
|
-
if (entities.length === 0) {
|
|
77
|
-
return <div className="p-4">No entities found</div>;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// Detect pattern
|
|
81
|
-
const pattern = patternAdapter.detectPattern({ ...view, type: 'detail' });
|
|
82
|
-
|
|
83
|
-
if (!pattern) {
|
|
84
|
-
return (
|
|
85
|
-
<div className="p-4 text-red-600">
|
|
86
|
-
Pattern not found for detail view
|
|
87
|
-
</div>
|
|
88
|
-
);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// Build render context
|
|
92
|
-
const context = {
|
|
93
|
-
pattern,
|
|
94
|
-
viewSpec: { ...view, type: 'detail', model: modelName },
|
|
95
|
-
modelData,
|
|
96
|
-
modelSchemas,
|
|
97
|
-
primaryModel: modelName,
|
|
98
|
-
selectedEntity,
|
|
99
|
-
primaryEntities: entities,
|
|
100
|
-
protocolMapping: REACT_PROTOCOL_MAPPING,
|
|
101
|
-
tailwindAdapter: patternAdapter['tailwindAdapter']
|
|
102
|
-
};
|
|
103
|
-
|
|
104
|
-
// Render entity selector
|
|
105
|
-
let html = '';
|
|
106
|
-
if (entities.length > 0) {
|
|
107
|
-
html += \`
|
|
108
|
-
<div class="mb-4 pb-4 border-b border-gray-200 dark:border-gray-700">
|
|
109
|
-
<label class="block text-sm font-semibold text-gray-700 dark:text-gray-200 mb-2">
|
|
110
|
-
Select \${modelName}:
|
|
111
|
-
</label>
|
|
112
|
-
<select
|
|
113
|
-
id="entity-selector"
|
|
114
|
-
class="w-full max-w-md px-3 py-2 border border-gray-300 dark:border-gray-600 rounded bg-white dark:bg-gray-700 text-gray-900 dark:text-gray-100 focus:outline-none focus:ring-2 focus:ring-blue-500"
|
|
115
|
-
>
|
|
116
|
-
\${entities.map((entity: any) => {
|
|
117
|
-
const displayName = entity.data?.name || entity.data?.title || entity.id;
|
|
118
|
-
return \`<option value="\${entity.id}" \${entity.id === selectedEntityId ? 'selected' : ''}>\${displayName}</option>\`;
|
|
119
|
-
}).join('')}
|
|
120
|
-
</select>
|
|
121
|
-
</div>
|
|
122
|
-
\`;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
// Render pattern
|
|
126
|
-
html += patternAdapter.renderPattern(context);
|
|
127
|
-
|
|
128
|
-
// Add event handler for selector
|
|
129
|
-
useEffect(() => {
|
|
130
|
-
const selector = document.getElementById('entity-selector') as HTMLSelectElement;
|
|
131
|
-
if (selector) {
|
|
132
|
-
const handler = (e: Event) => {
|
|
133
|
-
const newId = (e.target as HTMLSelectElement).value;
|
|
134
|
-
setSelectedEntityId(newId);
|
|
135
|
-
};
|
|
136
|
-
selector.addEventListener('change', handler);
|
|
137
|
-
return () => selector.removeEventListener('change', handler);
|
|
138
|
-
}
|
|
139
|
-
}, [html]);
|
|
140
|
-
|
|
141
|
-
return (
|
|
142
|
-
<div className="runtime-view-container p-4 h-full overflow-auto">
|
|
143
|
-
<div dangerouslySetInnerHTML={{ __html: html }} />
|
|
144
|
-
</div>
|
|
145
|
-
);
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
export default DetailView;
|
|
149
|
-
`;
|
|
150
|
-
}
|