@fragno-dev/create 0.1.3 → 0.1.5
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/.turbo/turbo-build.log +5 -5
- package/CHANGELOG.md +13 -0
- package/dist/index.js +12 -22
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/integration.test.ts +19 -7
- package/src/package-json.ts +8 -12
- package/templates/fragment/src/client/react.ts +1 -1
- package/templates/fragment/src/client/solid.ts +1 -1
- package/templates/fragment/src/client/svelte.ts +1 -1
- package/templates/fragment/src/client/vanilla.ts +1 -1
- package/templates/fragment/src/client/vue.ts +1 -1
- package/templates/fragment/src/index.ts +23 -28
- package/templates/optional/builder/rollup.config.js +1 -0
- package/templates/optional/builder/vite.config.ts +3 -0
- package/templates/optional/database/index.ts +220 -74
- package/templates/optional/database/schema.ts +25 -12
- package/dist/tsconfig.tsbuildinfo +0 -1
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
> @fragno-dev/create@0.1.
|
|
2
|
+
> @fragno-dev/create@0.1.5 build /home/runner/work/fragno/fragno/packages/create
|
|
3
3
|
> tsdown
|
|
4
4
|
|
|
5
5
|
[34mℹ[39m tsdown [2mv0.15.12[22m powered by rolldown [2mv1.0.0-beta.45[22m
|
|
@@ -7,9 +7,9 @@
|
|
|
7
7
|
[34mℹ[39m entry: [34msrc/index.ts[39m
|
|
8
8
|
[34mℹ[39m tsconfig: [34mtsconfig.json[39m
|
|
9
9
|
[34mℹ[39m Build start
|
|
10
|
-
[34mℹ[39m [2mdist/[22m[1mindex.js[22m [2m
|
|
11
|
-
[34mℹ[39m [2mdist/[22mindex.js.map [2m11.
|
|
10
|
+
[34mℹ[39m [2mdist/[22m[1mindex.js[22m [2m 5.75 kB[22m [2m│ gzip: 1.93 kB[22m
|
|
11
|
+
[34mℹ[39m [2mdist/[22mindex.js.map [2m11.47 kB[22m [2m│ gzip: 3.49 kB[22m
|
|
12
12
|
[34mℹ[39m [2mdist/[22mindex.d.ts.map [2m 0.58 kB[22m [2m│ gzip: 0.31 kB[22m
|
|
13
13
|
[34mℹ[39m [2mdist/[22m[32m[1mindex.d.ts[22m[39m [2m 1.28 kB[22m [2m│ gzip: 0.48 kB[22m
|
|
14
|
-
[34mℹ[39m 4 files, total: 19.
|
|
15
|
-
[32m✔[39m Build complete in [
|
|
14
|
+
[34mℹ[39m 4 files, total: 19.08 kB
|
|
15
|
+
[32m✔[39m Build complete in [32m1641ms[39m
|
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,18 @@
|
|
|
1
1
|
# @fragno-dev/create
|
|
2
2
|
|
|
3
|
+
## 0.1.5
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- 68135c4: Update database template to use latest fragno-db UOW API and bump dependency versions in
|
|
8
|
+
generated fragments
|
|
9
|
+
|
|
10
|
+
## 0.1.4
|
|
11
|
+
|
|
12
|
+
### Patch Changes
|
|
13
|
+
|
|
14
|
+
- bc072dd: feat: update create template for newest Fragno version
|
|
15
|
+
|
|
3
16
|
## 0.1.3
|
|
4
17
|
|
|
5
18
|
### Patch Changes
|
package/dist/index.js
CHANGED
|
@@ -47,18 +47,20 @@ function copy(from, to, rename = identity) {
|
|
|
47
47
|
|
|
48
48
|
//#endregion
|
|
49
49
|
//#region src/package-json.ts
|
|
50
|
-
const fragnoCoreVersion = "
|
|
51
|
-
const fragnoDbVersion = "
|
|
52
|
-
const unpluginFragnoVersion = "
|
|
53
|
-
const fragnoCliVersion = "
|
|
50
|
+
const fragnoCoreVersion = "0.1.11";
|
|
51
|
+
const fragnoDbVersion = "0.2.0";
|
|
52
|
+
const unpluginFragnoVersion = "0.0.7";
|
|
53
|
+
const fragnoCliVersion = "0.1.21";
|
|
54
54
|
const basePkg = {
|
|
55
55
|
dependencies: {
|
|
56
56
|
"@fragno-dev/core": fragnoCoreVersion,
|
|
57
|
-
|
|
57
|
+
"@standard-schema/spec": "^1.0.0",
|
|
58
|
+
zod: "^4.0.5"
|
|
58
59
|
},
|
|
59
60
|
devDependencies: {
|
|
60
|
-
"@types/node": "^
|
|
61
|
-
"@fragno-dev/cli": fragnoCliVersion
|
|
61
|
+
"@types/node": "^24",
|
|
62
|
+
"@fragno-dev/cli": fragnoCliVersion,
|
|
63
|
+
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion
|
|
62
64
|
},
|
|
63
65
|
peerDependencies: {
|
|
64
66
|
typescript: ">=5",
|
|
@@ -75,29 +77,19 @@ const databasePkg = {
|
|
|
75
77
|
const buildToolPkg = {
|
|
76
78
|
none: {},
|
|
77
79
|
tsdown: {
|
|
78
|
-
devDependencies: {
|
|
79
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
80
|
-
tsdown: "^0.12.0"
|
|
81
|
-
},
|
|
80
|
+
devDependencies: { tsdown: "^0.12.0" },
|
|
82
81
|
scripts: { build: "tsdown" }
|
|
83
82
|
},
|
|
84
83
|
esbuild: {
|
|
85
|
-
devDependencies: {
|
|
86
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
87
|
-
esbuild: "^0.25.12"
|
|
88
|
-
},
|
|
84
|
+
devDependencies: { esbuild: "^0.25.12" },
|
|
89
85
|
scripts: { build: "./esbuild.config.js" }
|
|
90
86
|
},
|
|
91
87
|
vite: {
|
|
92
|
-
devDependencies: {
|
|
93
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
94
|
-
vite: "^6.3.5"
|
|
95
|
-
},
|
|
88
|
+
devDependencies: { vite: "^6.3.5" },
|
|
96
89
|
scripts: { build: "vite build" }
|
|
97
90
|
},
|
|
98
91
|
rollup: {
|
|
99
92
|
devDependencies: {
|
|
100
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
101
93
|
"@rollup/plugin-node-resolve": "^16.0.2",
|
|
102
94
|
"@rollup/plugin-typescript": "^12.1.4",
|
|
103
95
|
tslib: "^2.8.1",
|
|
@@ -107,7 +99,6 @@ const buildToolPkg = {
|
|
|
107
99
|
},
|
|
108
100
|
webpack: {
|
|
109
101
|
devDependencies: {
|
|
110
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
111
102
|
webpack: "^5.99.9",
|
|
112
103
|
"webpack-cli": "^6.0.1",
|
|
113
104
|
"ts-loader": "^9.5.1"
|
|
@@ -116,7 +107,6 @@ const buildToolPkg = {
|
|
|
116
107
|
},
|
|
117
108
|
rspack: {
|
|
118
109
|
devDependencies: {
|
|
119
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
120
110
|
"@rspack/core": "^1.6.1",
|
|
121
111
|
"@rspack/cli": "^1.6.1"
|
|
122
112
|
},
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["e: unknown","basePkg: Record<string, unknown>","databasePkg: Record<string, unknown>","buildToolPkg: Record<BuildTools, Record<string, unknown>>","pkgOverride: Record<string, unknown>"],"sources":["../src/utils.ts","../src/package-json.ts","../src/index.ts"],"sourcesContent":["import fs from \"node:fs\";\nimport path from \"node:path\";\n\nexport function mkdirp(dir: string): void {\n try {\n fs.mkdirSync(dir, { recursive: true });\n } catch (e: unknown) {\n if (e instanceof Error && \"code\" in e && e.code === \"EEXIST\") {\n return;\n }\n throw e;\n }\n}\n\nfunction isPlainObject(value: unknown): value is Record<string, unknown> {\n return (\n value !== null &&\n typeof value === \"object\" &&\n !Array.isArray(value) &&\n Object.prototype.toString.call(value) === \"[object Object]\"\n );\n}\n\n/**\n * Deep merge plain objects. Arrays and primitives are overwritten, not merged.\n * @param target The target object\n * @param source The source object\n * @returns The merged object\n */\nexport function merge<T extends Record<string, unknown>>(\n target: T,\n source: Record<string, unknown>,\n): T {\n const result = { ...target } as Record<string, unknown>;\n\n for (const key in source) {\n const sourceValue = source[key];\n const targetValue = result[key];\n\n if (isPlainObject(sourceValue) && isPlainObject(targetValue)) {\n result[key] = merge(targetValue, sourceValue);\n } else {\n result[key] = sourceValue;\n }\n }\n\n return result as T;\n}\n\nfunction identity<T>(x: T): T {\n return x;\n}\n\nexport function copy(\n from: string,\n to: string,\n rename: (basename: string) => string = identity,\n): void {\n if (!fs.existsSync(from)) {\n return;\n }\n\n const stats = fs.statSync(from);\n\n if (stats.isDirectory()) {\n fs.readdirSync(from).forEach((file) => {\n copy(path.join(from, file), path.join(to, rename(file)));\n });\n } else {\n mkdirp(path.dirname(to));\n fs.copyFileSync(from, to);\n }\n}\n","import type { BuildTools } from \"./index\";\n\nconst fragnoCoreVersion = \"^0.1.7\";\nconst fragnoDbVersion = \"^0.1.13\";\nconst unpluginFragnoVersion = \"^0.0.3\";\nconst fragnoCliVersion = \"^0.1.16\";\n\nexport const basePkg: Record<string, unknown> = {\n dependencies: {\n \"@fragno-dev/core\": fragnoCoreVersion,\n zod: \"^4.1.12\",\n },\n devDependencies: {\n \"@types/node\": \"^22\",\n \"@fragno-dev/cli\": fragnoCliVersion,\n },\n peerDependencies: {\n typescript: \">=5\",\n react: \">=18.0.0\",\n svelte: \">=4.0.0\",\n \"solid-js\": \">=1.0.0\",\n vue: \">=3.0.0\",\n },\n};\n\nexport const databasePkg: Record<string, unknown> = {\n devDependencies: {\n \"@fragno-dev/db\": fragnoDbVersion,\n },\n peerDependencies: {\n \"@fragno-dev/db\": fragnoDbVersion,\n },\n};\n\nexport const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {\n none: {},\n tsdown: {\n devDependencies: {\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n tsdown: \"^0.12.0\",\n },\n scripts: {\n build: \"tsdown\",\n },\n },\n esbuild: {\n devDependencies: {\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n esbuild: \"^0.25.12\",\n },\n scripts: {\n build: \"./esbuild.config.js\",\n },\n },\n vite: {\n devDependencies: {\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n vite: \"^6.3.5\",\n },\n scripts: {\n build: \"vite build\",\n },\n },\n rollup: {\n devDependencies: {\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n \"@rollup/plugin-node-resolve\": \"^16.0.2\",\n \"@rollup/plugin-typescript\": \"^12.1.4\",\n tslib: \"^2.8.1\",\n rollup: \"^4.41.0\",\n },\n scripts: {\n build: \"rollup -c\",\n },\n },\n webpack: {\n devDependencies: {\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n webpack: \"^5.99.9\",\n \"webpack-cli\": \"^6.0.1\",\n \"ts-loader\": \"^9.5.1\",\n },\n scripts: {\n build: \"webpack\",\n },\n },\n rspack: {\n devDependencies: {\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n \"@rspack/core\": \"^1.6.1\",\n \"@rspack/cli\": \"^1.6.1\",\n },\n scripts: {\n build: \"rspack build\",\n },\n },\n};\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport { copy, merge } from \"./utils.ts\";\nimport { basePkg, buildToolPkg, databasePkg } from \"./package-json.ts\";\nimport { z } from \"zod\";\n\nconst templateTypesSchema = z.literal(\"fragment\");\nexport type TemplateTypes = z.infer<typeof templateTypesSchema>;\n\nconst buildToolsSchema = z.enum([\n \"esbuild\",\n \"tsdown\",\n \"vite\",\n \"rollup\",\n \"webpack\",\n \"rspack\",\n \"none\",\n]);\nexport type BuildTools = z.infer<typeof buildToolsSchema>;\n\nconst agentDocsSchema = z.enum([\"AGENTS.md\", \"CLAUDE.md\", \"none\"]);\nexport type AgentDocs = z.infer<typeof agentDocsSchema>;\n\nexport const createOptionsSchema = z.object({\n path: z.string(),\n buildTool: buildToolsSchema,\n name: z.string(),\n template: templateTypesSchema,\n agentDocs: agentDocsSchema,\n withDatabase: z.boolean(),\n});\n\ntype CreateOptions = z.infer<typeof createOptionsSchema>;\n\nexport function create(options: CreateOptions) {\n let pkgOverride: Record<string, unknown> = merge(basePkg, { name: options.name });\n\n // Build tool pkg overrides\n pkgOverride = merge(pkgOverride, buildToolPkg[options.buildTool]);\n\n // Database pkg overrides\n if (options.withDatabase) {\n pkgOverride = merge(pkgOverride, databasePkg);\n }\n\n if (options.template == \"fragment\") {\n writeFragmentTemplate(options.path, pkgOverride);\n } else {\n throw new Error(`Unsupported template type: ${options.template}`);\n }\n\n switch (options.buildTool) {\n case \"esbuild\":\n writeOptionalTemplate(options.path, \"builder/esbuild.config.js\");\n break;\n case \"tsdown\":\n writeOptionalTemplate(options.path, \"builder/tsdown.config.ts\");\n break;\n case \"vite\":\n writeOptionalTemplate(options.path, \"builder/vite.config.ts\");\n break;\n case \"rollup\":\n writeOptionalTemplate(options.path, \"builder/rollup.config.js\");\n break;\n case \"webpack\":\n writeOptionalTemplate(options.path, \"builder/webpack.config.js\");\n break;\n case \"rspack\":\n writeOptionalTemplate(options.path, \"builder/rspack.config.js\");\n break;\n case \"none\":\n break;\n }\n\n switch (options.agentDocs) {\n case \"AGENTS.md\":\n writeOptionalTemplate(options.path, \"agent/AGENTS.md\");\n break;\n case \"CLAUDE.md\":\n writeOptionalTemplate(options.path, \"agent/AGENTS.md\", \"CLAUDE.md\");\n break;\n case \"none\":\n break;\n }\n\n if (options.withDatabase) {\n writeOptionalTemplate(options.path, \"database/index.ts\", \"src/index.ts\");\n writeOptionalTemplate(options.path, \"database/schema.ts\", \"src/schema.ts\");\n }\n}\n\nfunction getTemplateDir(): string {\n const __dirname = path.dirname(fileURLToPath(import.meta.url));\n return path.join(__dirname, \"..\", \"templates\");\n}\n\nfunction writeOptionalTemplate(targetPath: string, template: string, rename?: string) {\n const templatePath = path.join(getTemplateDir(), \"optional\", template);\n const targetFileName = rename ? rename : path.basename(template);\n const targetFile = path.join(targetPath, targetFileName);\n\n copy(templatePath, targetFile);\n}\n\nfunction writeFragmentTemplate(targetPath: string, pkgOverrides: Record<string, unknown>) {\n const templateDir = path.join(getTemplateDir(), \"fragment\");\n\n // Copy template files\n copy(templateDir, targetPath, (basename) => {\n if (basename === \"package.template.json\") {\n return \"package.json\";\n }\n return basename;\n });\n\n // Update package.json based on chosen options\n const packageJsonPath = path.join(targetPath, \"package.json\");\n const basePkg = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"));\n const newPkg = merge(basePkg, pkgOverrides);\n\n // Write to disk\n fs.writeFileSync(packageJsonPath, JSON.stringify(newPkg, null, 2) + \"\\n\");\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["e: unknown","basePkg: Record<string, unknown>","databasePkg: Record<string, unknown>","buildToolPkg: Record<BuildTools, Record<string, unknown>>","pkgOverride: Record<string, unknown>"],"sources":["../src/utils.ts","../src/package-json.ts","../src/index.ts"],"sourcesContent":["import fs from \"node:fs\";\nimport path from \"node:path\";\n\nexport function mkdirp(dir: string): void {\n try {\n fs.mkdirSync(dir, { recursive: true });\n } catch (e: unknown) {\n if (e instanceof Error && \"code\" in e && e.code === \"EEXIST\") {\n return;\n }\n throw e;\n }\n}\n\nfunction isPlainObject(value: unknown): value is Record<string, unknown> {\n return (\n value !== null &&\n typeof value === \"object\" &&\n !Array.isArray(value) &&\n Object.prototype.toString.call(value) === \"[object Object]\"\n );\n}\n\n/**\n * Deep merge plain objects. Arrays and primitives are overwritten, not merged.\n * @param target The target object\n * @param source The source object\n * @returns The merged object\n */\nexport function merge<T extends Record<string, unknown>>(\n target: T,\n source: Record<string, unknown>,\n): T {\n const result = { ...target } as Record<string, unknown>;\n\n for (const key in source) {\n const sourceValue = source[key];\n const targetValue = result[key];\n\n if (isPlainObject(sourceValue) && isPlainObject(targetValue)) {\n result[key] = merge(targetValue, sourceValue);\n } else {\n result[key] = sourceValue;\n }\n }\n\n return result as T;\n}\n\nfunction identity<T>(x: T): T {\n return x;\n}\n\nexport function copy(\n from: string,\n to: string,\n rename: (basename: string) => string = identity,\n): void {\n if (!fs.existsSync(from)) {\n return;\n }\n\n const stats = fs.statSync(from);\n\n if (stats.isDirectory()) {\n fs.readdirSync(from).forEach((file) => {\n copy(path.join(from, file), path.join(to, rename(file)));\n });\n } else {\n mkdirp(path.dirname(to));\n fs.copyFileSync(from, to);\n }\n}\n","import type { BuildTools } from \"./index\";\n\nconst fragnoCoreVersion = \"0.1.11\";\nconst fragnoDbVersion = \"0.2.0\";\nconst unpluginFragnoVersion = \"0.0.7\";\nconst fragnoCliVersion = \"0.1.21\";\n\nexport const basePkg: Record<string, unknown> = {\n dependencies: {\n \"@fragno-dev/core\": fragnoCoreVersion,\n \"@standard-schema/spec\": \"^1.0.0\",\n zod: \"^4.0.5\",\n },\n devDependencies: {\n \"@types/node\": \"^24\",\n \"@fragno-dev/cli\": fragnoCliVersion,\n \"@fragno-dev/unplugin-fragno\": unpluginFragnoVersion,\n },\n peerDependencies: {\n typescript: \">=5\",\n react: \">=18.0.0\",\n svelte: \">=4.0.0\",\n \"solid-js\": \">=1.0.0\",\n vue: \">=3.0.0\",\n },\n};\n\nexport const databasePkg: Record<string, unknown> = {\n devDependencies: {\n \"@fragno-dev/db\": fragnoDbVersion,\n },\n peerDependencies: {\n \"@fragno-dev/db\": fragnoDbVersion,\n },\n};\n\nexport const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {\n none: {},\n tsdown: {\n devDependencies: {\n tsdown: \"^0.12.0\",\n },\n scripts: {\n build: \"tsdown\",\n },\n },\n esbuild: {\n devDependencies: {\n esbuild: \"^0.25.12\",\n },\n scripts: {\n build: \"./esbuild.config.js\",\n },\n },\n vite: {\n devDependencies: {\n vite: \"^6.3.5\",\n },\n scripts: {\n build: \"vite build\",\n },\n },\n rollup: {\n devDependencies: {\n \"@rollup/plugin-node-resolve\": \"^16.0.2\",\n \"@rollup/plugin-typescript\": \"^12.1.4\",\n tslib: \"^2.8.1\",\n rollup: \"^4.41.0\",\n },\n scripts: {\n build: \"rollup -c\",\n },\n },\n webpack: {\n devDependencies: {\n webpack: \"^5.99.9\",\n \"webpack-cli\": \"^6.0.1\",\n \"ts-loader\": \"^9.5.1\",\n },\n scripts: {\n build: \"webpack\",\n },\n },\n rspack: {\n devDependencies: {\n \"@rspack/core\": \"^1.6.1\",\n \"@rspack/cli\": \"^1.6.1\",\n },\n scripts: {\n build: \"rspack build\",\n },\n },\n};\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport { copy, merge } from \"./utils.ts\";\nimport { basePkg, buildToolPkg, databasePkg } from \"./package-json.ts\";\nimport { z } from \"zod\";\n\nconst templateTypesSchema = z.literal(\"fragment\");\nexport type TemplateTypes = z.infer<typeof templateTypesSchema>;\n\nconst buildToolsSchema = z.enum([\n \"esbuild\",\n \"tsdown\",\n \"vite\",\n \"rollup\",\n \"webpack\",\n \"rspack\",\n \"none\",\n]);\nexport type BuildTools = z.infer<typeof buildToolsSchema>;\n\nconst agentDocsSchema = z.enum([\"AGENTS.md\", \"CLAUDE.md\", \"none\"]);\nexport type AgentDocs = z.infer<typeof agentDocsSchema>;\n\nexport const createOptionsSchema = z.object({\n path: z.string(),\n buildTool: buildToolsSchema,\n name: z.string(),\n template: templateTypesSchema,\n agentDocs: agentDocsSchema,\n withDatabase: z.boolean(),\n});\n\ntype CreateOptions = z.infer<typeof createOptionsSchema>;\n\nexport function create(options: CreateOptions) {\n let pkgOverride: Record<string, unknown> = merge(basePkg, { name: options.name });\n\n // Build tool pkg overrides\n pkgOverride = merge(pkgOverride, buildToolPkg[options.buildTool]);\n\n // Database pkg overrides\n if (options.withDatabase) {\n pkgOverride = merge(pkgOverride, databasePkg);\n }\n\n if (options.template == \"fragment\") {\n writeFragmentTemplate(options.path, pkgOverride);\n } else {\n throw new Error(`Unsupported template type: ${options.template}`);\n }\n\n switch (options.buildTool) {\n case \"esbuild\":\n writeOptionalTemplate(options.path, \"builder/esbuild.config.js\");\n break;\n case \"tsdown\":\n writeOptionalTemplate(options.path, \"builder/tsdown.config.ts\");\n break;\n case \"vite\":\n writeOptionalTemplate(options.path, \"builder/vite.config.ts\");\n break;\n case \"rollup\":\n writeOptionalTemplate(options.path, \"builder/rollup.config.js\");\n break;\n case \"webpack\":\n writeOptionalTemplate(options.path, \"builder/webpack.config.js\");\n break;\n case \"rspack\":\n writeOptionalTemplate(options.path, \"builder/rspack.config.js\");\n break;\n case \"none\":\n break;\n }\n\n switch (options.agentDocs) {\n case \"AGENTS.md\":\n writeOptionalTemplate(options.path, \"agent/AGENTS.md\");\n break;\n case \"CLAUDE.md\":\n writeOptionalTemplate(options.path, \"agent/AGENTS.md\", \"CLAUDE.md\");\n break;\n case \"none\":\n break;\n }\n\n if (options.withDatabase) {\n writeOptionalTemplate(options.path, \"database/index.ts\", \"src/index.ts\");\n writeOptionalTemplate(options.path, \"database/schema.ts\", \"src/schema.ts\");\n }\n}\n\nfunction getTemplateDir(): string {\n const __dirname = path.dirname(fileURLToPath(import.meta.url));\n return path.join(__dirname, \"..\", \"templates\");\n}\n\nfunction writeOptionalTemplate(targetPath: string, template: string, rename?: string) {\n const templatePath = path.join(getTemplateDir(), \"optional\", template);\n const targetFileName = rename ? rename : path.basename(template);\n const targetFile = path.join(targetPath, targetFileName);\n\n copy(templatePath, targetFile);\n}\n\nfunction writeFragmentTemplate(targetPath: string, pkgOverrides: Record<string, unknown>) {\n const templateDir = path.join(getTemplateDir(), \"fragment\");\n\n // Copy template files\n copy(templateDir, targetPath, (basename) => {\n if (basename === \"package.template.json\") {\n return \"package.json\";\n }\n return basename;\n });\n\n // Update package.json based on chosen options\n const packageJsonPath = path.join(targetPath, \"package.json\");\n const basePkg = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"));\n const newPkg = merge(basePkg, pkgOverrides);\n\n // Write to disk\n fs.writeFileSync(packageJsonPath, JSON.stringify(newPkg, null, 2) + \"\\n\");\n}\n"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/integration.test.ts
CHANGED
|
@@ -62,13 +62,25 @@ function createFragmentTestSuite(buildTool: BuildTool, withDatabase: boolean) {
|
|
|
62
62
|
expect(stdout).toBeDefined();
|
|
63
63
|
});
|
|
64
64
|
|
|
65
|
-
test("compiles", { timeout: 30000 }, async () => {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
65
|
+
test("type checks (compiles)", { timeout: 30000 }, async () => {
|
|
66
|
+
try {
|
|
67
|
+
const { stdout } = await execAsync("pnpm run types:check", {
|
|
68
|
+
cwd: tempDir,
|
|
69
|
+
encoding: "utf8",
|
|
70
|
+
});
|
|
71
|
+
expect(stdout).toBeDefined();
|
|
72
|
+
} catch (error: unknown) {
|
|
73
|
+
// When command fails, stdout and stderr are in the error object
|
|
74
|
+
const execError = error as { stdout?: string; stderr?: string };
|
|
75
|
+
console.error("TypeScript type check failed:");
|
|
76
|
+
if (execError.stdout) {
|
|
77
|
+
console.error(execError.stdout);
|
|
78
|
+
}
|
|
79
|
+
if (execError.stderr) {
|
|
80
|
+
console.error(execError.stderr);
|
|
81
|
+
}
|
|
82
|
+
throw error;
|
|
83
|
+
}
|
|
72
84
|
});
|
|
73
85
|
/*
|
|
74
86
|
FIXME: Skipping this test for rollup:
|
package/src/package-json.ts
CHANGED
|
@@ -1,18 +1,20 @@
|
|
|
1
1
|
import type { BuildTools } from "./index";
|
|
2
2
|
|
|
3
|
-
const fragnoCoreVersion = "
|
|
4
|
-
const fragnoDbVersion = "
|
|
5
|
-
const unpluginFragnoVersion = "
|
|
6
|
-
const fragnoCliVersion = "
|
|
3
|
+
const fragnoCoreVersion = "0.1.11";
|
|
4
|
+
const fragnoDbVersion = "0.2.0";
|
|
5
|
+
const unpluginFragnoVersion = "0.0.7";
|
|
6
|
+
const fragnoCliVersion = "0.1.21";
|
|
7
7
|
|
|
8
8
|
export const basePkg: Record<string, unknown> = {
|
|
9
9
|
dependencies: {
|
|
10
10
|
"@fragno-dev/core": fragnoCoreVersion,
|
|
11
|
-
|
|
11
|
+
"@standard-schema/spec": "^1.0.0",
|
|
12
|
+
zod: "^4.0.5",
|
|
12
13
|
},
|
|
13
14
|
devDependencies: {
|
|
14
|
-
"@types/node": "^
|
|
15
|
+
"@types/node": "^24",
|
|
15
16
|
"@fragno-dev/cli": fragnoCliVersion,
|
|
17
|
+
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
16
18
|
},
|
|
17
19
|
peerDependencies: {
|
|
18
20
|
typescript: ">=5",
|
|
@@ -36,7 +38,6 @@ export const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {
|
|
|
36
38
|
none: {},
|
|
37
39
|
tsdown: {
|
|
38
40
|
devDependencies: {
|
|
39
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
40
41
|
tsdown: "^0.12.0",
|
|
41
42
|
},
|
|
42
43
|
scripts: {
|
|
@@ -45,7 +46,6 @@ export const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {
|
|
|
45
46
|
},
|
|
46
47
|
esbuild: {
|
|
47
48
|
devDependencies: {
|
|
48
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
49
49
|
esbuild: "^0.25.12",
|
|
50
50
|
},
|
|
51
51
|
scripts: {
|
|
@@ -54,7 +54,6 @@ export const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {
|
|
|
54
54
|
},
|
|
55
55
|
vite: {
|
|
56
56
|
devDependencies: {
|
|
57
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
58
57
|
vite: "^6.3.5",
|
|
59
58
|
},
|
|
60
59
|
scripts: {
|
|
@@ -63,7 +62,6 @@ export const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {
|
|
|
63
62
|
},
|
|
64
63
|
rollup: {
|
|
65
64
|
devDependencies: {
|
|
66
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
67
65
|
"@rollup/plugin-node-resolve": "^16.0.2",
|
|
68
66
|
"@rollup/plugin-typescript": "^12.1.4",
|
|
69
67
|
tslib: "^2.8.1",
|
|
@@ -75,7 +73,6 @@ export const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {
|
|
|
75
73
|
},
|
|
76
74
|
webpack: {
|
|
77
75
|
devDependencies: {
|
|
78
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
79
76
|
webpack: "^5.99.9",
|
|
80
77
|
"webpack-cli": "^6.0.1",
|
|
81
78
|
"ts-loader": "^9.5.1",
|
|
@@ -86,7 +83,6 @@ export const buildToolPkg: Record<BuildTools, Record<string, unknown>> = {
|
|
|
86
83
|
},
|
|
87
84
|
rspack: {
|
|
88
85
|
devDependencies: {
|
|
89
|
-
"@fragno-dev/unplugin-fragno": unpluginFragnoVersion,
|
|
90
86
|
"@rspack/core": "^1.6.1",
|
|
91
87
|
"@rspack/cli": "^1.6.1",
|
|
92
88
|
},
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useFragno } from "@fragno-dev/core/react";
|
|
2
2
|
import { createExampleFragmentClients } from "..";
|
|
3
|
-
import type { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
3
|
+
import type { FragnoPublicClientConfig } from "@fragno-dev/core/client";
|
|
4
4
|
|
|
5
5
|
export function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {
|
|
6
6
|
return useFragno(createExampleFragmentClients(config));
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useFragno } from "@fragno-dev/core/solid";
|
|
2
2
|
import { createExampleFragmentClients } from "..";
|
|
3
|
-
import type { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
3
|
+
import type { FragnoPublicClientConfig } from "@fragno-dev/core/client";
|
|
4
4
|
|
|
5
5
|
export function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {
|
|
6
6
|
return useFragno(createExampleFragmentClients(config));
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useFragno } from "@fragno-dev/core/svelte";
|
|
2
2
|
import { createExampleFragmentClients } from "..";
|
|
3
|
-
import type { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
3
|
+
import type { FragnoPublicClientConfig } from "@fragno-dev/core/client";
|
|
4
4
|
|
|
5
5
|
export function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {
|
|
6
6
|
return useFragno(createExampleFragmentClients(config));
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useFragno } from "@fragno-dev/core/vanilla";
|
|
2
2
|
import { createExampleFragmentClients } from "..";
|
|
3
|
-
import type { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
3
|
+
import type { FragnoPublicClientConfig } from "@fragno-dev/core/client";
|
|
4
4
|
|
|
5
5
|
export function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {
|
|
6
6
|
return useFragno(createExampleFragmentClients(config));
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useFragno } from "@fragno-dev/core/vue";
|
|
2
2
|
import { createExampleFragmentClients } from "..";
|
|
3
|
-
import type { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
3
|
+
import type { FragnoPublicClientConfig } from "@fragno-dev/core/client";
|
|
4
4
|
|
|
5
5
|
export function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {
|
|
6
6
|
return useFragno(createExampleFragmentClients(config));
|
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
2
|
defineFragment,
|
|
3
|
-
defineRoute,
|
|
4
3
|
defineRoutes,
|
|
5
|
-
|
|
6
|
-
type FragnoPublicClientConfig,
|
|
4
|
+
instantiate,
|
|
7
5
|
type FragnoPublicConfig,
|
|
8
6
|
} from "@fragno-dev/core";
|
|
9
|
-
import { createClientBuilder } from "@fragno-dev/core/client";
|
|
7
|
+
import { createClientBuilder, type FragnoPublicClientConfig } from "@fragno-dev/core/client";
|
|
10
8
|
|
|
11
9
|
// NOTE: We use zod here for defining schemas, but any StandardSchema library can be used!
|
|
12
10
|
// For a complete list see:
|
|
@@ -17,16 +15,21 @@ export interface ExampleConfig {
|
|
|
17
15
|
initialData?: string;
|
|
18
16
|
}
|
|
19
17
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
18
|
+
const exampleFragmentDefinition = defineFragment<ExampleConfig>("example-fragment")
|
|
19
|
+
.withDependencies(({ config }) => {
|
|
20
|
+
return {
|
|
21
|
+
serverSideData: { value: config.initialData ?? "Hello World! This is a server-side data." },
|
|
22
|
+
};
|
|
23
|
+
})
|
|
24
|
+
.providesBaseService(({ deps }) => {
|
|
25
|
+
return {
|
|
26
|
+
getData: () => deps.serverSideData.value,
|
|
27
|
+
};
|
|
28
|
+
})
|
|
29
|
+
.build();
|
|
27
30
|
|
|
28
|
-
const exampleRoutesFactory = defineRoutes
|
|
29
|
-
({ deps }) => {
|
|
31
|
+
const exampleRoutesFactory = defineRoutes(exampleFragmentDefinition).create(
|
|
32
|
+
({ deps, defineRoute }) => {
|
|
30
33
|
const { serverSideData } = deps;
|
|
31
34
|
|
|
32
35
|
return [
|
|
@@ -55,23 +58,15 @@ const exampleRoutesFactory = defineRoutes<ExampleConfig, ExampleDeps, ExampleSer
|
|
|
55
58
|
},
|
|
56
59
|
);
|
|
57
60
|
|
|
58
|
-
const exampleFragmentDefinition = defineFragment<ExampleConfig>("example-fragment")
|
|
59
|
-
.withDependencies(({ config }) => {
|
|
60
|
-
return {
|
|
61
|
-
serverSideData: { value: config.initialData ?? "Hello World! This is a server-side data." },
|
|
62
|
-
};
|
|
63
|
-
})
|
|
64
|
-
.providesService(({ deps }) => {
|
|
65
|
-
return {
|
|
66
|
-
getData: () => deps.serverSideData.value,
|
|
67
|
-
};
|
|
68
|
-
});
|
|
69
|
-
|
|
70
61
|
export function createExampleFragment(
|
|
71
62
|
config: ExampleConfig = {},
|
|
72
|
-
|
|
63
|
+
options: FragnoPublicConfig = {},
|
|
73
64
|
) {
|
|
74
|
-
return
|
|
65
|
+
return instantiate(exampleFragmentDefinition)
|
|
66
|
+
.withConfig(config)
|
|
67
|
+
.withRoutes([exampleRoutesFactory])
|
|
68
|
+
.withOptions(options)
|
|
69
|
+
.build();
|
|
75
70
|
}
|
|
76
71
|
|
|
77
72
|
export function createExampleFragmentClients(fragnoConfig: FragnoPublicClientConfig) {
|
|
@@ -82,4 +77,4 @@ export function createExampleFragmentClients(fragnoConfig: FragnoPublicClientCon
|
|
|
82
77
|
useHelloMutator: b.createMutator("POST", "/hello"),
|
|
83
78
|
};
|
|
84
79
|
}
|
|
85
|
-
export type { FragnoRouteConfig } from "@fragno-dev/core
|
|
80
|
+
export type { FragnoRouteConfig } from "@fragno-dev/core";
|
|
@@ -3,6 +3,9 @@ import unpluginFragno from "@fragno-dev/unplugin-fragno/vite";
|
|
|
3
3
|
|
|
4
4
|
export default defineConfig({
|
|
5
5
|
plugins: [unpluginFragno({ platform: "browser" })],
|
|
6
|
+
resolve: {
|
|
7
|
+
conditions: ["browser"],
|
|
8
|
+
},
|
|
6
9
|
// https://vite.dev/guide/build.html#library-mode
|
|
7
10
|
build: {
|
|
8
11
|
lib: {
|