@gadgetinc/ggt 1.0.5 → 1.1.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.
Files changed (89) hide show
  1. package/dist/add-RDTHYTCK.js +78 -0
  2. package/dist/add-RDTHYTCK.js.map +7 -0
  3. package/dist/chunk-3Q3GPB6Z.js +2 -0
  4. package/dist/chunk-3Q3GPB6Z.js.map +7 -0
  5. package/dist/chunk-457GEPUN.js +9 -0
  6. package/dist/chunk-457GEPUN.js.map +7 -0
  7. package/dist/{chunk-5DLLJX5F.js → chunk-5ONACLO6.js} +8 -8
  8. package/dist/{chunk-5DLLJX5F.js.map → chunk-5ONACLO6.js.map} +3 -3
  9. package/dist/chunk-CQLM5U6T.js +67 -0
  10. package/dist/chunk-CQLM5U6T.js.map +7 -0
  11. package/dist/chunk-FLXIAZND.js +12 -0
  12. package/dist/chunk-FLXIAZND.js.map +7 -0
  13. package/dist/chunk-JKDJXJKF.js +8 -0
  14. package/dist/{chunk-QEVWPU3D.js.map → chunk-JKDJXJKF.js.map} +3 -3
  15. package/dist/chunk-LWW4E6P5.js +173 -0
  16. package/dist/chunk-LWW4E6P5.js.map +7 -0
  17. package/dist/chunk-M2OJZLL7.js +18 -0
  18. package/dist/chunk-M2OJZLL7.js.map +7 -0
  19. package/dist/{chunk-Q5N5L6H3.js → chunk-M4PNFOA5.js} +2 -2
  20. package/dist/chunk-M4PNFOA5.js.map +7 -0
  21. package/dist/chunk-NGTOMLDS.js +33 -0
  22. package/dist/{chunk-G3VNV5Z6.js.map → chunk-NGTOMLDS.js.map} +3 -3
  23. package/dist/chunk-RYQWS5BH.js +117 -0
  24. package/dist/chunk-RYQWS5BH.js.map +7 -0
  25. package/dist/{chunk-IKJVXTZK.js → chunk-TRHAPK2F.js} +4 -6
  26. package/dist/{chunk-IKJVXTZK.js.map → chunk-TRHAPK2F.js.map} +2 -2
  27. package/dist/chunk-VICN6LTV.js +12 -0
  28. package/dist/chunk-VICN6LTV.js.map +7 -0
  29. package/dist/context-GN36UFJL.js +2 -0
  30. package/dist/deploy-BAMMI3ZA.js +24 -0
  31. package/dist/deploy-BAMMI3ZA.js.map +7 -0
  32. package/dist/{dev-M3WDGK4D.js → dev-5UFCKF4X.js} +9 -11
  33. package/dist/{dev-M3WDGK4D.js.map → dev-5UFCKF4X.js.map} +3 -3
  34. package/dist/esm-GJ7RK6IC.js +34 -0
  35. package/dist/esm-GJ7RK6IC.js.map +7 -0
  36. package/dist/list-WGRXHV2B.js +11 -0
  37. package/dist/list-WGRXHV2B.js.map +7 -0
  38. package/dist/login-5YZOB4XB.js +2 -0
  39. package/dist/logout-YXDH5ZZI.js +7 -0
  40. package/dist/{logout-UZBACOIX.js.map → logout-YXDH5ZZI.js.map} +3 -3
  41. package/dist/main.js +6 -8
  42. package/dist/main.js.map +3 -3
  43. package/dist/{open-GWKGQQG3.js → open-EOH3Q5KP.js} +3 -3
  44. package/dist/{open-GWKGQQG3.js.map → open-EOH3Q5KP.js.map} +2 -2
  45. package/dist/{pull-7C5A65KB.js → pull-UAKKKJJP.js} +3 -5
  46. package/dist/{pull-7C5A65KB.js.map → pull-UAKKKJJP.js.map} +2 -2
  47. package/dist/push-7X4P2364.js +2 -0
  48. package/dist/push-7X4P2364.js.map +7 -0
  49. package/dist/status-UJUGP24U.js +14 -0
  50. package/dist/{status-DFKKSRVB.js.map → status-UJUGP24U.js.map} +1 -1
  51. package/dist/user-B2RIDVTH.js +2 -0
  52. package/dist/user-B2RIDVTH.js.map +7 -0
  53. package/dist/{version-JD42JXWY.js → version-VE55GG37.js} +2 -2
  54. package/dist/whoami-OAH55L4M.js +7 -0
  55. package/dist/{whoami-I23R6HOG.js.map → whoami-OAH55L4M.js.map} +2 -2
  56. package/package.json +22 -22
  57. package/dist/add-4ME2KTJQ.js +0 -84
  58. package/dist/add-4ME2KTJQ.js.map +0 -7
  59. package/dist/chunk-BZY2AIPV.js +0 -57
  60. package/dist/chunk-BZY2AIPV.js.map +0 -7
  61. package/dist/chunk-G3VNV5Z6.js +0 -33
  62. package/dist/chunk-GA7AL463.js +0 -24
  63. package/dist/chunk-GA7AL463.js.map +0 -7
  64. package/dist/chunk-KGSSHEEC.js +0 -17
  65. package/dist/chunk-KGSSHEEC.js.map +0 -7
  66. package/dist/chunk-KXK37C5D.js +0 -183
  67. package/dist/chunk-KXK37C5D.js.map +0 -7
  68. package/dist/chunk-NJIDVM2C.js +0 -27
  69. package/dist/chunk-NJIDVM2C.js.map +0 -7
  70. package/dist/chunk-Q5N5L6H3.js.map +0 -7
  71. package/dist/chunk-QEVWPU3D.js +0 -8
  72. package/dist/chunk-X36GM74C.js +0 -2
  73. package/dist/chunk-X36GM74C.js.map +0 -7
  74. package/dist/chunk-YRP2UZ2I.js +0 -126
  75. package/dist/chunk-YRP2UZ2I.js.map +0 -7
  76. package/dist/deploy-6HOBYPE6.js +0 -30
  77. package/dist/deploy-6HOBYPE6.js.map +0 -7
  78. package/dist/esm-BL3OM5UJ.js +0 -33
  79. package/dist/esm-BL3OM5UJ.js.map +0 -7
  80. package/dist/list-725RHWD5.js +0 -11
  81. package/dist/list-725RHWD5.js.map +0 -7
  82. package/dist/login-I4RGMDLE.js +0 -2
  83. package/dist/logout-UZBACOIX.js +0 -7
  84. package/dist/push-LPUIR4EO.js +0 -2
  85. package/dist/status-DFKKSRVB.js +0 -14
  86. package/dist/whoami-I23R6HOG.js +0 -7
  87. /package/dist/{login-I4RGMDLE.js.map → context-GN36UFJL.js.map} +0 -0
  88. /package/dist/{push-LPUIR4EO.js.map → login-5YZOB4XB.js.map} +0 -0
  89. /package/dist/{version-JD42JXWY.js.map → version-VE55GG37.js.map} +0 -0
@@ -1,84 +0,0 @@
1
- import{d as F,e as C,f as B,g as U,h as O,m as P}from"./chunk-KXK37C5D.js";import{g as E,l as L,m as M,n as k,o as N}from"./chunk-YRP2UZ2I.js";import"./chunk-5DLLJX5F.js";import{b as y,g as S,h as j}from"./chunk-G3VNV5Z6.js";import"./chunk-QEVWPU3D.js";import{b as $}from"./chunk-D2K5XPNJ.js";import"./chunk-Q5N5L6H3.js";import"./chunk-NJIDVM2C.js";import{b as A,e as b,f as v,i as p}from"./chunk-KGSSHEEC.js";import{c as h}from"./chunk-GA7AL463.js";import{T as l,V as c,b as g,m as _}from"./chunk-BZY2AIPV.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{g as T}from"./chunk-5WC5D4WL.js";T();var f=class extends v{isBug=b.NO;constructor(n){let a="";if(_(n.cause)){let e=$(n.cause.map(o=>o.message));a=l` • ${e.map(o=>o.split(`
2
- `).join(`
3
- \u200E \u2022 `)).join(`
4
- `)}`}else a=l`${n.cause}`;super(a)}render(){return`${g.redBright(h.cross)} Failed to add:
5
- `+this.message}},le={...M},J=()=>l`
6
- Adds models, fields, actions and routes to your app.
7
-
8
- This command first performs a sync to ensure that your local and environment directories match, changes are tracked since last sync.
9
- If any conflicts are detected, they must be resolved before adding models, fields, actions or routes.
10
-
11
- {gray Usage}
12
- ggt add model <model_name> [field_name:field_type ...]
13
-
14
- ggt add action [CONTEXT]/<action_name>
15
- CONTEXT:Specifies the kind of action. Use "model" for model actions otherwise use "action".
16
-
17
- ggt add route <HTTP_METHOD> <route_path>
18
-
19
- ggt add field <model_path>/<field_name>:<field_type>
20
-
21
- {gray Options}
22
- -e, --env <env_name> Selects the environment to add to. Default set on ".gadget/sync.json"
23
-
24
- {gray Examples}
25
- Add a new model 'post' with out fields:
26
- {cyanBright $ ggt add model modelA}
27
-
28
- Add a new model 'post' with 2 new 'string' type fields 'title' and 'body':
29
- {cyanBright $ ggt add model post title:string body:string}
30
-
31
- Add new action 'publish' to the 'post' model:
32
- {cyanBright ggt add action model/post/publish}
33
-
34
- Add a new action 'audit'
35
- {cyanBright ggt add action action/audit}
36
-
37
- Add a new route 'howdy'
38
- {cyanBright ggt add route GET howdy}
39
-
40
- Add a new 'boolean' type field 'published' to an existing model
41
- {cyanBright ggt add field post/published:boolean}
42
- `,ce=async t=>{let n=await N(process.cwd()),a=await k.load(t,{directory:n});if(!a)throw new E(t,{directory:n});let e=new P(a),o=await e.hashes(t,!0);o.inSync||await e.merge(t,{hashes:o,printEnvironmentChangesOptions:{limit:5},printLocalChangesOptions:{limit:5},quietly:!0}),c({ensureEmptyLineAbove:!0})`${g.greenBright(h.tick)} Sync completed ${O()}`;let i=t.args._[0];if(!i){c(J(t));return}switch(i){case"model":await V(t,e);break;case"action":await G(t,e);break;case"route":await H(t,e);break;case"field":await X(t,e);break;default:c(J(t));return}};var D=t=>{let n=[],a=[];return t.forEach(e=>{let o=e.match(/^(.*):+(.*)$/);!o||o.length!==3||!o[1]||!o[2]?n.push(l`${e} is not a valid field definition`):a.push({name:o[1].replace(/:+/g,""),fieldType:o[2]})}),[a,n]},V=async(t,n)=>{let a=n.syncJson,e=t.args._[1];if(!e)throw new p(l`Failed to add model, missing model path
43
-
44
- {gray Usage}
45
- {cyanBright ggt add model <model_name> [field_name:field_type ...]}`);let o=[];if(t.args._.length>2){let[d,m]=D(t.args._.slice(2));if(m.length>0)throw new p(l`
46
- Failed to add model:
47
- • ${m.join(`
48
- \u2022 `)}
49
-
50
- {gray Usage}
51
- {cyanBright ggt add model ${e} [field_name:field_type ...]}`);o.push(...d)}let i;try{i=(await a.edit.mutate({mutation:F,variables:{path:e,fields:o.map(d=>({name:d.name,fieldType:d.fieldType}))}})).createModel}catch(d){throw d instanceof y?new f(d):d}c({ensureEmptyLineAbove:!0})`${g.gray("New model created in environment.")}`,await n.writeToLocalFilesystem(t,{filesVersion:i.remoteFilesVersion,files:i.changed,delete:[]});let s=A.isSupported?A(e,`https://${a.app.primaryDomain}/edit/${a.env.name}/model/${e}/schema`):e;c({ensureEmptyLineAbove:!0})`${g.greenBright(h.tick)} Model ${g.cyanBright(s)} added successfully.`},G=async(t,n)=>{let a=n.syncJson,e=t.args._[1];if(!e)throw new p(l`Failed to add action, missing action path
52
-
53
- {gray Usage}
54
- {cyanBright ggt add action [CONTEXT]/<action_name>
55
- CONTEXT:Specifies the kind of action. Use "model" for model actions otherwise use "action".}`);let o=await S(t),i=await j(t),s=e.split("/"),d,m=s.length>1?s.slice(0,s.length-1):s,u=s[s.length-1],I=o.find(r=>{let w=m[m.length-1];return r.apiIdentifier.toUpperCase()===w?.toUpperCase()&&r.namespace?.join("/")===m.slice(0,m.length-1).join("/")}),R=i.find(r=>r.namespace?.join("/")===m.join("/"));if(I&&R){let r=m.join("/");d=await L({choices:Object.values(["models","actions"]),formatChoice:w=>{switch(w){case"models":return`As a Model action in ${g.gray(`models/${r}/${u}.js`)}`;case"actions":return`As an Action in ${g.gray(`actions/${r}/${u}.js`)}`}}})`
56
- {bold Namespace Conflict:} The action '${u}.js' cannot be automatically added due to a namespace conflict.
57
-
58
- How would you like to proceed?:
59
- `,c({ensureEmptyLineAbove:!0})`${g.yellowBright(h.info)} You can override the context of the action by specifying the context in the path. For example: {gray ggt add action ${d}/${e}}`}try{let r=(await a.edit.mutate({mutation:C,variables:{path:d?`${d}/`+e:e}})).createAction;await n.writeToLocalFilesystem(t,{filesVersion:r.remoteFilesVersion,files:r.changed,delete:[]})}catch(r){throw r instanceof y?new f(r):r}c({ensureEmptyLineAbove:!0})`
60
- Action {cyanBright ${e}} added successfully.
61
- `},H=async(t,n)=>{let a=n.syncJson,e=t.args._[1],o=t.args._[2];if(!e)throw new p(l`Failed to add route, missing route method
62
-
63
- {gray Usage}
64
- {cyanBright ggt add route <HTTP_METHOD> <route_path>}`);if(!o)throw new p(l`Failed to add route, missing route path
65
-
66
- {gray Usage}
67
- {cyanBright ggt add route ${e} <route_path>}`);try{let i=(await a.edit.mutate({mutation:B,variables:{method:e,path:o}})).createRoute;await n.writeToLocalFilesystem(t,{filesVersion:i.remoteFilesVersion,files:i.changed,delete:[]})}catch(i){throw i instanceof y?new f(i):i}c({ensureEmptyLineAbove:!0})`
68
- Route {cyanBright ${o}} added successfully.
69
- `},X=async(t,n)=>{let a=n.syncJson,e=t.args._[1]?.split("/");if(!e)throw new p(l`Failed to add field, invalid field path definition
70
-
71
- {gray Usage}
72
- {cyanBright ggt add field <model_path>/<field_name>:<field_type>}`);let o=[];if(e[1]){let[i,s]=D([e[1]]);if(s.length>0)throw new p(l`
73
- Failed to add field:
74
- • ${s.join(`
75
- \u2022`)}
76
-
77
- {gray Usage}
78
- {cyanBright ggt add field ${e[0]}/<field_name>:<field_type>}`);o.push(...i)}else throw new p(l`Failed to add field, invalid field definition
79
-
80
- {gray Usage}
81
- {cyanBright ggt add field ${e[0]}/<field_name>:<field_type>}`);try{let i=(await a.edit.mutate({mutation:U,variables:{path:e[0],fields:o.map(s=>({name:s.name,fieldType:s.fieldType}))}})).createModelFields;await n.writeToLocalFilesystem(t,{filesVersion:i.remoteFilesVersion,files:i.changed,delete:[]})}catch(i){throw i instanceof y?new f(i):i}c({ensureEmptyLineAbove:!0})`
82
- Field {cyanBright ${o[0]?.name}} added successfully.
83
- `};export{f as AddClientError,le as args,ce as run,J as usage};
84
- //# sourceMappingURL=add-4ME2KTJQ.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../src/commands/add.ts"],
4
- "sourcesContent": ["/* eslint-disable no-case-declarations */\nimport chalk from \"chalk\";\nimport terminalLink from \"terminal-link\";\nimport { getGlobalActions, getModels } from \"../services/app/app.js\";\nimport {\n CREATE_ACTION_MUTATION,\n CREATE_MODEL_FIELDS_MUTATION,\n CREATE_MODEL_MUTATION,\n CREATE_ROUTE_MUTATION,\n} from \"../services/app/edit/operation.js\";\nimport { ClientError } from \"../services/app/error.js\";\nimport { ArgError } from \"../services/command/arg.js\";\nimport type { Run, Usage } from \"../services/command/command.js\";\nimport type { Context } from \"../services/command/context.js\";\nimport { UnknownDirectoryError } from \"../services/filesync/error.js\";\nimport { FileSync } from \"../services/filesync/filesync.js\";\nimport { SyncJson, SyncJsonArgs, loadSyncJsonDirectory } from \"../services/filesync/sync-json.js\";\nimport { println } from \"../services/output/print.js\";\nimport { GGTError, IsBug } from \"../services/output/report.js\";\nimport { select } from \"../services/output/select.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { symbol } from \"../services/output/symbols.js\";\nimport { ts } from \"../services/output/timestamp.js\";\nimport { uniq } from \"../services/util/collection.js\";\nimport { isGraphQLErrors } from \"../services/util/is.js\";\nimport type { DevArgs } from \"./dev.js\";\n\nexport class AddClientError extends GGTError {\n isBug = IsBug.NO;\n\n constructor(error: ClientError) {\n let template = \"\";\n\n if (isGraphQLErrors(error.cause)) {\n const errors = uniq(error.cause.map((x) => x.message));\n\n template = sprint` \u2022 ${errors.map((e) => e.split(\"\\n\").join(\"\\n\u200E \u2022 \")).join(\"\\n\")}`; // Why in gods name do I have to put an empty character for the tab to work?\n } else {\n template = sprint`${error.cause}`;\n }\n\n super(template);\n }\n\n protected override render(): string {\n return `${chalk.redBright(symbol.cross)} Failed to add:\\n ` + this.message;\n }\n}\n\nexport type AddArgs = typeof args;\n\nexport const args = {\n ...SyncJsonArgs,\n};\n\nexport const usage: Usage = () => {\n return sprint`\n Adds models, fields, actions and routes to your app.\n\n This command first performs a sync to ensure that your local and environment directories match, changes are tracked since last sync.\n If any conflicts are detected, they must be resolved before adding models, fields, actions or routes.\n\n {gray Usage}\n ggt add model <model_name> [field_name:field_type ...]\n\n ggt add action [CONTEXT]/<action_name>\n CONTEXT:Specifies the kind of action. Use \"model\" for model actions otherwise use \"action\".\n\n ggt add route <HTTP_METHOD> <route_path>\n\n ggt add field <model_path>/<field_name>:<field_type>\n\n {gray Options}\n -e, --env <env_name> Selects the environment to add to. Default set on \".gadget/sync.json\"\n\n {gray Examples}\n Add a new model 'post' with out fields:\n {cyanBright $ ggt add model modelA}\n\n Add a new model 'post' with 2 new 'string' type fields 'title' and 'body':\n {cyanBright $ ggt add model post title:string body:string}\n\n Add new action 'publish' to the 'post' model:\n {cyanBright ggt add action model/post/publish}\n\n Add a new action 'audit'\n {cyanBright ggt add action action/audit}\n\n Add a new route 'howdy'\n {cyanBright ggt add route GET howdy}\n\n Add a new 'boolean' type field 'published' to an existing model\n {cyanBright ggt add field post/published:boolean}\n `;\n};\n\nexport const run: Run<AddArgs> = async (ctx) => {\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.load(ctx, { directory });\n if (!syncJson) {\n throw new UnknownDirectoryError(ctx, { directory });\n }\n\n const filesync = new FileSync(syncJson);\n const hashes = await filesync.hashes(ctx, true);\n\n if (!hashes.inSync) {\n await filesync.merge(ctx as unknown as Context<DevArgs>, {\n hashes,\n printEnvironmentChangesOptions: {\n limit: 5,\n },\n printLocalChangesOptions: {\n limit: 5,\n },\n quietly: true,\n });\n }\n\n println({ ensureEmptyLineAbove: true })`${chalk.greenBright(symbol.tick)} Sync completed ${ts()}`;\n\n const actionType = ctx.args._[0] as AddActionType | undefined;\n if (!actionType) {\n println(usage(ctx));\n return;\n }\n\n switch (actionType) {\n case \"model\":\n await modelSubCommand(ctx, filesync);\n break;\n case \"action\":\n await actionSubCommand(ctx, filesync);\n break;\n case \"route\":\n await routeSubCommand(ctx, filesync);\n break;\n case \"field\":\n await fieldSubCommand(ctx, filesync);\n break;\n default:\n println(usage(ctx));\n return;\n }\n};\n\nconst addActionType = [\"model\", \"action\", \"route\", \"field\"] as const;\n\ntype AddActionType = (typeof addActionType)[number];\n\nconst parseFieldValues = (fields: string[]): [{ name: string; fieldType: string }[], problems: string[]] => {\n const problems: string[] = [];\n const modelFields: { name: string; fieldType: string }[] = [];\n\n fields.forEach((field) => {\n const matches = field.match(/^(.*):+(.*)$/);\n if (!matches || matches.length !== 3 || !matches[1] || !matches[2]) {\n problems.push(sprint`${field} is not a valid field definition`);\n } else {\n modelFields.push({ name: matches[1].replace(/:+/g, \"\"), fieldType: matches[2] });\n }\n });\n\n return [modelFields, problems];\n};\n\nconst modelSubCommand = async (ctx: Context<AddArgs>, filesync: FileSync): Promise<void> => {\n const syncJson = filesync.syncJson;\n const modelApiIdentifier = ctx.args._[1];\n\n if (!modelApiIdentifier) {\n throw new ArgError(sprint`Failed to add model, missing model path\n\n {gray Usage}\n {cyanBright ggt add model <model_name> [field_name:field_type ...]}`);\n }\n\n const modelFieldsList: { name: string; fieldType: string }[] = [];\n if (ctx.args._.length > 2) {\n const [modelFields, problems] = parseFieldValues(ctx.args._.slice(2));\n\n if (problems.length > 0) {\n throw new ArgError(sprint`\n Failed to add model:\n \u2022 ${problems.join(\"\\n \u2022 \")}\n\n {gray Usage}\n {cyanBright ggt add model ${modelApiIdentifier} [field_name:field_type ...]}`);\n }\n\n modelFieldsList.push(...modelFields);\n }\n\n let result;\n\n try {\n result = (\n await syncJson.edit.mutate({\n mutation: CREATE_MODEL_MUTATION,\n variables: {\n path: modelApiIdentifier,\n fields: modelFieldsList.map((fields) => ({\n name: fields.name,\n fieldType: fields.fieldType,\n })),\n },\n })\n ).createModel;\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({ ensureEmptyLineAbove: true })`${chalk.gray(\"New model created in environment.\")}`;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n\n const modelPrintout = terminalLink.isSupported\n ? terminalLink(modelApiIdentifier, `https://${syncJson.app.primaryDomain}/edit/${syncJson.env.name}/model/${modelApiIdentifier}/schema`)\n : modelApiIdentifier;\n println({ ensureEmptyLineAbove: true })`${chalk.greenBright(symbol.tick)} Model ${chalk.cyanBright(modelPrintout)} added successfully.`;\n};\n\nconst actionSubCommand = async (ctx: Context<AddArgs>, filesync: FileSync): Promise<void> => {\n const syncJson = filesync.syncJson;\n const path = ctx.args._[1];\n\n if (!path) {\n throw new ArgError(sprint`Failed to add action, missing action path\n\n {gray Usage}\n {cyanBright ggt add action [CONTEXT]/<action_name>\n CONTEXT:Specifies the kind of action. Use \"model\" for model actions otherwise use \"action\".}`);\n }\n\n const models = await getModels(ctx);\n const globalActions = await getGlobalActions(ctx);\n const splitPath = path.split(\"/\");\n\n let overrideContextAction: \"models\" | \"actions\" | undefined;\n\n const parsedPaths = splitPath.length > 1 ? splitPath.slice(0, splitPath.length - 1) : splitPath;\n const parsedAction = splitPath[splitPath.length - 1];\n\n const conflictingModel = models.find((model) => {\n const modelName = parsedPaths[parsedPaths.length - 1];\n\n return (\n model.apiIdentifier.toUpperCase() === modelName?.toUpperCase() &&\n model.namespace?.join(\"/\") === parsedPaths.slice(0, parsedPaths.length - 1).join(\"/\")\n );\n });\n\n const conflictingActionNamespace = globalActions.find((action) => {\n return action.namespace?.join(\"/\") === parsedPaths.join(\"/\");\n });\n\n if (conflictingModel && conflictingActionNamespace) {\n const joinedParsedPaths = parsedPaths.join(\"/\");\n overrideContextAction = await select({\n choices: Object.values([\"models\", \"actions\"]),\n formatChoice: (choice) => {\n switch (choice) {\n case \"models\": {\n return `As a Model action in ${chalk.gray(`models/${joinedParsedPaths}/${parsedAction}.js`)}`;\n }\n case \"actions\": {\n return `As an Action in ${chalk.gray(`actions/${joinedParsedPaths}/${parsedAction}.js`)}`;\n }\n }\n },\n })`\n {bold Namespace Conflict:} The action '${parsedAction}.js' cannot be automatically added due to a namespace conflict.\n\n How would you like to proceed?:\n `;\n\n println({\n ensureEmptyLineAbove: true,\n })`${chalk.yellowBright(symbol.info)} You can override the context of the action by specifying the context in the path. For example: {gray ggt add action ${overrideContextAction}/${path}}`;\n }\n\n try {\n const result = (\n await syncJson.edit.mutate({\n mutation: CREATE_ACTION_MUTATION,\n variables: { path: overrideContextAction ? `${overrideContextAction}/` + path : path },\n })\n ).createAction;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({ ensureEmptyLineAbove: true })`\n Action {cyanBright ${path}} added successfully.\n `;\n};\n\nconst routeSubCommand = async (ctx: Context<AddArgs>, filesync: FileSync): Promise<void> => {\n const syncJson = filesync.syncJson;\n const routeMethod = ctx.args._[1];\n const routePath = ctx.args._[2];\n\n if (!routeMethod) {\n throw new ArgError(sprint`Failed to add route, missing route method\n\n {gray Usage}\n {cyanBright ggt add route <HTTP_METHOD> <route_path>}`);\n }\n\n if (!routePath) {\n throw new ArgError(sprint`Failed to add route, missing route path\n\n {gray Usage}\n {cyanBright ggt add route ${routeMethod} <route_path>}`);\n }\n\n try {\n const result = (\n await syncJson.edit.mutate({\n mutation: CREATE_ROUTE_MUTATION,\n variables: { method: routeMethod, path: routePath },\n })\n ).createRoute;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({ ensureEmptyLineAbove: true })`\n Route {cyanBright ${routePath}} added successfully.\n `;\n};\n\nconst fieldSubCommand = async (ctx: Context<AddArgs>, filesync: FileSync): Promise<void> => {\n const syncJson = filesync.syncJson;\n\n const splitPathAndField = ctx.args._[1]?.split(\"/\");\n\n if (!splitPathAndField) {\n throw new ArgError(sprint`Failed to add field, invalid field path definition\n\n {gray Usage}\n {cyanBright ggt add field <model_path>/<field_name>:<field_type>}`);\n }\n\n const modelFieldsList: { name: string; fieldType: string }[] = [];\n\n if (splitPathAndField[1]) {\n const [modelFields, problems] = parseFieldValues([splitPathAndField[1]]);\n\n if (problems.length > 0) {\n throw new ArgError(sprint`\n Failed to add field:\n \u2022 ${problems.join(\"\\n \u2022\")}\n\n {gray Usage}\n {cyanBright ggt add field ${splitPathAndField[0]}/<field_name>:<field_type>}`);\n }\n\n modelFieldsList.push(...modelFields);\n } else {\n throw new ArgError(sprint`Failed to add field, invalid field definition\n\n {gray Usage}\n {cyanBright ggt add field ${splitPathAndField[0]}/<field_name>:<field_type>}`);\n }\n\n try {\n const result = (\n await syncJson.edit.mutate({\n mutation: CREATE_MODEL_FIELDS_MUTATION,\n variables: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n path: splitPathAndField[0]!,\n fields: modelFieldsList.map((field) => ({\n name: field.name,\n fieldType: field.fieldType,\n })),\n },\n })\n ).createModelFields;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({ ensureEmptyLineAbove: true })`\n Field {cyanBright ${modelFieldsList[0]?.name}} added successfully.\n `;\n};\n"],
5
- "mappings": "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",
6
- "names": ["init_cjs", "AddClientError", "GGTError", "IsBug", "error", "template", "isGraphQLErrors", "errors", "uniq", "x", "sprint", "e", "source_default", "symbol", "args", "SyncJsonArgs", "usage", "run", "ctx", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "filesync", "FileSync", "hashes", "println", "ts", "actionType", "modelSubCommand", "actionSubCommand", "routeSubCommand", "fieldSubCommand", "parseFieldValues", "fields", "problems", "modelFields", "field", "matches", "sprint", "modelSubCommand", "ctx", "filesync", "syncJson", "modelApiIdentifier", "ArgError", "modelFieldsList", "result", "CREATE_MODEL_MUTATION", "error", "ClientError", "AddClientError", "println", "source_default", "modelPrintout", "terminalLink", "symbol", "actionSubCommand", "path", "models", "getModels", "globalActions", "getGlobalActions", "splitPath", "overrideContextAction", "parsedPaths", "parsedAction", "conflictingModel", "model", "modelName", "conflictingActionNamespace", "action", "joinedParsedPaths", "select", "choice", "CREATE_ACTION_MUTATION", "routeSubCommand", "routeMethod", "routePath", "CREATE_ROUTE_MUTATION", "fieldSubCommand", "splitPathAndField", "CREATE_MODEL_FIELDS_MUTATION"]
7
- }