@baseplate-dev/project-builder-web 0.2.6 → 0.3.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/dist/assets/-constants-C0cnDlAn.js +4 -0
- package/dist/assets/-constants-C0cnDlAn.js.map +1 -0
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib/web-BCejYgPM.js +2 -0
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib/{web-CEscUEnR.js.map → web-BCejYgPM.js.map} +1 -1
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib-BxDAWgq7.js +2 -0
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib-BxDAWgq7.js.map +1 -0
- package/dist/assets/__federation_shared_@baseplate-dev/ui-components-D6OnTPTN.js +46 -0
- package/dist/assets/__federation_shared_@baseplate-dev/ui-components-D6OnTPTN.js.map +1 -0
- package/dist/assets/__federation_shared_@baseplate-dev/utils-DvvrgoSE.js +5 -0
- package/dist/assets/__federation_shared_@baseplate-dev/utils-DvvrgoSE.js.map +1 -0
- package/dist/assets/__federation_shared_@tanstack/react-router-B5c6YNeC.js +19 -0
- package/dist/assets/__federation_shared_@tanstack/react-router-B5c6YNeC.js.map +1 -0
- package/dist/assets/__federation_shared_react-WURrSs1p.js +2 -0
- package/dist/assets/{__federation_shared_react-CTQ9xfiH.js.map → __federation_shared_react-WURrSs1p.js.map} +1 -1
- package/dist/assets/__federation_shared_react-dom-CWagDEjd.js +2 -0
- package/dist/assets/{__federation_shared_react-dom-DPv53nVg.js.map → __federation_shared_react-dom-CWagDEjd.js.map} +1 -1
- package/dist/assets/_commonjsHelpers-CqkleIqs.js +2 -0
- package/dist/assets/_commonjsHelpers-CqkleIqs.js.map +1 -0
- package/dist/assets/_virtual___federation_fn_import-DXu2m-ZE.js +2 -0
- package/dist/assets/{_virtual___federation_fn_import-BLYgPlMt.js.map → _virtual___federation_fn_import-DXu2m-ZE.js.map} +1 -1
- package/dist/assets/admin-Bw70Pql0.js +2 -0
- package/dist/assets/admin-Bw70Pql0.js.map +1 -0
- package/dist/assets/backend-CoqSwiCt.js +2 -0
- package/dist/assets/{backend-hJNcdERv.js.map → backend-CoqSwiCt.js.map} +1 -1
- package/dist/assets/badge-with-type-label-BXoSRTRE.js +2 -0
- package/dist/assets/{badge-with-type-label-CezAtjFy.js.map → badge-with-type-label-BXoSRTRE.js.map} +1 -1
- package/dist/assets/edit._key-CtMMGDWu.js +2 -0
- package/dist/assets/edit._key-CtMMGDWu.js.map +1 -0
- package/dist/assets/edit._sectionKey-CTX9L0j4.js +3 -0
- package/dist/assets/edit._sectionKey-CTX9L0j4.js.map +1 -0
- package/dist/assets/enum-info-form-D5bAsvPH.js +2 -0
- package/dist/assets/{enum-info-form-xlZ2HO8I.js.map → enum-info-form-D5bAsvPH.js.map} +1 -1
- package/dist/assets/graphql-BmA-sAqU.js +2 -0
- package/dist/assets/{graphql-D3J4ZWXL.js.map → graphql-BmA-sAqU.js.map} +1 -1
- package/dist/assets/hierarchy-CZorhmS7.js +2 -0
- package/dist/assets/{hierarchy-DF9lzUjz.js.map → hierarchy-CZorhmS7.js.map} +1 -1
- package/dist/assets/immer-B7fdkLVi.js +2 -0
- package/dist/assets/immer-B7fdkLVi.js.map +1 -0
- package/dist/assets/index-BABen-rU.js +2 -0
- package/dist/assets/index-BABen-rU.js.map +1 -0
- package/dist/assets/index-BGLRovL6.js +2 -0
- package/dist/assets/index-BGLRovL6.js.map +1 -0
- package/dist/assets/index-BPzqpd9P.js +2 -0
- package/dist/assets/{index-DJsZccoO.js.map → index-BPzqpd9P.js.map} +1 -1
- package/dist/assets/index-BUYA3Tes.js +40 -0
- package/dist/assets/index-BUYA3Tes.js.map +1 -0
- package/dist/assets/index-Bl_iRlKL.js +2 -0
- package/dist/assets/index-Bl_iRlKL.js.map +1 -0
- package/dist/assets/index-BpDkQSTy.js +2 -0
- package/dist/assets/{index-BdmJimiZ.js.map → index-BpDkQSTy.js.map} +1 -1
- package/dist/assets/index-CaiaVpxa.js +2 -0
- package/dist/assets/index-CaiaVpxa.js.map +1 -0
- package/dist/assets/index-CsGKSjOd.js +2 -0
- package/dist/assets/index-CsGKSjOd.js.map +1 -0
- package/dist/assets/index-D-dbw3Qx.js +2 -0
- package/dist/assets/{index-1ErFJbDw.js.map → index-D-dbw3Qx.js.map} +1 -1
- package/dist/assets/index-DCiH936w.js +2 -0
- package/dist/assets/{index-Bv8hyN9u.js.map → index-DCiH936w.js.map} +1 -1
- package/dist/assets/index-DDivWD4R.js +2 -0
- package/dist/assets/index-DDivWD4R.js.map +1 -0
- package/dist/assets/index-DpJKJe06.js +2 -0
- package/dist/assets/index-DpJKJe06.js.map +1 -0
- package/dist/assets/{index-B0D_rfGi.js → index-DqHVrEeL.js} +2 -2
- package/dist/assets/{index-B0D_rfGi.js.map → index-DqHVrEeL.js.map} +1 -1
- package/dist/assets/index-PlVWOW99.css +1 -0
- package/dist/assets/index-_mf2naQd.js +2 -0
- package/dist/assets/index-_mf2naQd.js.map +1 -0
- package/dist/assets/{index-9Ra4Lmds.js → index-c0qeY2gs.js} +3 -3
- package/dist/assets/{index-9Ra4Lmds.js.map → index-c0qeY2gs.js.map} +1 -1
- package/dist/assets/index-p--SDqro.js +2 -0
- package/dist/assets/{index-B5-Qczd9.js.map → index-p--SDqro.js.map} +1 -1
- package/dist/assets/index.esm-CTDJ8Wko.js +2 -0
- package/dist/assets/index.esm-CTDJ8Wko.js.map +1 -0
- package/dist/assets/jsx-runtime-D_zvdyIk.js +10 -0
- package/dist/assets/jsx-runtime-D_zvdyIk.js.map +1 -0
- package/dist/assets/model-info-form-pKQBCJu4.js +2 -0
- package/dist/assets/{model-info-form-VtbYsjrH.js.map → model-info-form-pKQBCJu4.js.map} +1 -1
- package/dist/assets/model-merger-vEOkdVdS.js +2 -0
- package/dist/assets/model-merger-vEOkdVdS.js.map +1 -0
- package/dist/assets/new-admin-section-dialog-F58HZ0yO.js +2 -0
- package/dist/assets/new-admin-section-dialog-F58HZ0yO.js.map +1 -0
- package/dist/assets/new-app-dialog-DPQv-mvi.js +2 -0
- package/dist/assets/new-app-dialog-DPQv-mvi.js.map +1 -0
- package/dist/assets/new-enum-dialog-xVvneRQN.js +2 -0
- package/dist/assets/{new-enum-dialog-B0QcIWdY.js.map → new-enum-dialog-xVvneRQN.js.map} +1 -1
- package/dist/assets/new-model-dialog-ApenxGWq.js +2 -0
- package/dist/assets/{new-model-dialog-CM2dJ8Iv.js.map → new-model-dialog-ApenxGWq.js.map} +1 -1
- package/dist/assets/route-1RLqcpwJ.js +2 -0
- package/dist/assets/{route-DmdFbZkw.js.map → route-1RLqcpwJ.js.map} +1 -1
- package/dist/assets/route-9nRSk82v.js +2 -0
- package/dist/assets/route-9nRSk82v.js.map +1 -0
- package/dist/assets/route-B5_zLW88.js +2 -0
- package/dist/assets/{route-CAp89B2q.js.map → route-B5_zLW88.js.map} +1 -1
- package/dist/assets/route-BPsno3Cl.js +2 -0
- package/dist/assets/route-BPsno3Cl.js.map +1 -0
- package/dist/assets/route-BW0F_EH4.js +2 -0
- package/dist/assets/{route-DcsVxxui.js.map → route-BW0F_EH4.js.map} +1 -1
- package/dist/assets/route-C1hyfOXp.js +2 -0
- package/dist/assets/route-C1hyfOXp.js.map +1 -0
- package/dist/assets/route-CH7VQVwb.js +2 -0
- package/dist/assets/route-CH7VQVwb.js.map +1 -0
- package/dist/assets/route-CpoiDvOD.js +2 -0
- package/dist/assets/route-CpoiDvOD.js.map +1 -0
- package/dist/assets/route-Dq2UgkxS.js +2 -0
- package/dist/assets/{route-BsIUCKz1.js.map → route-Dq2UgkxS.js.map} +1 -1
- package/dist/assets/route-z54yq2nP.js +2 -0
- package/dist/assets/route-z54yq2nP.js.map +1 -0
- package/dist/assets/service-Cv-U7NUv.js +2 -0
- package/dist/assets/service-Cv-U7NUv.js.map +1 -0
- package/dist/assets/sortBy-C9bvycg5.js +2 -0
- package/dist/assets/sortBy-C9bvycg5.js.map +1 -0
- package/dist/assets/template-extractor-ElrbBsVj.js +2 -0
- package/dist/assets/{template-extractor-DEU0CX0Y.js.map → template-extractor-ElrbBsVj.js.map} +1 -1
- package/dist/assets/{theme-builder-La1nKR0K.js → theme-builder-Butjmy7L.js} +6 -6
- package/dist/assets/{theme-builder-La1nKR0K.js.map → theme-builder-Butjmy7L.js.map} +1 -1
- package/dist/assets/{use-definition-schema-CuFFJIzk.js → use-definition-schema-e7us6WfR.js} +2 -2
- package/dist/assets/{use-definition-schema-CuFFJIzk.js.map → use-definition-schema-e7us6WfR.js.map} +1 -1
- package/dist/assets/use-enum-form-CEyTBPQn.js +2 -0
- package/dist/assets/{use-enum-form-DKD2EDHZ.js.map → use-enum-form-CEyTBPQn.js.map} +1 -1
- package/dist/assets/use-model-form-Ch_tz0Rd.js +2 -0
- package/dist/assets/{use-model-form-BQa-PiE_.js.map → use-model-form-Ch_tz0Rd.js.map} +1 -1
- package/dist/assets/words-Cs2RBKRm.js +2 -0
- package/dist/assets/words-Cs2RBKRm.js.map +1 -0
- package/dist/index.html +11 -8
- package/package.json +11 -11
- package/dist/assets/-constants-CqYT9Sad.js +0 -4
- package/dist/assets/-constants-CqYT9Sad.js.map +0 -1
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib/web-CEscUEnR.js +0 -2
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib-CzpSl25Z.js +0 -5
- package/dist/assets/__federation_shared_@baseplate-dev/project-builder-lib-CzpSl25Z.js.map +0 -1
- package/dist/assets/__federation_shared_@baseplate-dev/ui-components-Bpztr-cx.js +0 -46
- package/dist/assets/__federation_shared_@baseplate-dev/ui-components-Bpztr-cx.js.map +0 -1
- package/dist/assets/__federation_shared_react-CTQ9xfiH.js +0 -2
- package/dist/assets/__federation_shared_react-dom-DPv53nVg.js +0 -2
- package/dist/assets/_virtual___federation_fn_import-BLYgPlMt.js +0 -2
- package/dist/assets/backend-hJNcdERv.js +0 -2
- package/dist/assets/badge-with-type-label-CezAtjFy.js +0 -2
- package/dist/assets/edit._id-bMpe6S3O.js +0 -2
- package/dist/assets/edit._id-bMpe6S3O.js.map +0 -1
- package/dist/assets/enum-info-form-xlZ2HO8I.js +0 -2
- package/dist/assets/graphql-D3J4ZWXL.js +0 -2
- package/dist/assets/hierarchy-DF9lzUjz.js +0 -2
- package/dist/assets/immer-BOh2djD_.js +0 -2
- package/dist/assets/immer-BOh2djD_.js.map +0 -1
- package/dist/assets/index-1ErFJbDw.js +0 -2
- package/dist/assets/index-37eYMUXo.js +0 -2
- package/dist/assets/index-37eYMUXo.js.map +0 -1
- package/dist/assets/index-B5-Qczd9.js +0 -2
- package/dist/assets/index-BLuLGksP.js +0 -2
- package/dist/assets/index-BLuLGksP.js.map +0 -1
- package/dist/assets/index-BPK2SbiO.js +0 -2
- package/dist/assets/index-BPK2SbiO.js.map +0 -1
- package/dist/assets/index-BdmJimiZ.js +0 -2
- package/dist/assets/index-Bv8hyN9u.js +0 -2
- package/dist/assets/index-C15I7WFi.js +0 -2
- package/dist/assets/index-C15I7WFi.js.map +0 -1
- package/dist/assets/index-C_wN4CIq.js +0 -58
- package/dist/assets/index-C_wN4CIq.js.map +0 -1
- package/dist/assets/index-DBOJRz5n.css +0 -1
- package/dist/assets/index-DJsZccoO.js +0 -2
- package/dist/assets/index-DwyYddxl.js +0 -2
- package/dist/assets/index-DwyYddxl.js.map +0 -1
- package/dist/assets/index-P-wtG1LL.js +0 -2
- package/dist/assets/index-P-wtG1LL.js.map +0 -1
- package/dist/assets/index.esm-DcyGeCKA.js +0 -10
- package/dist/assets/index.esm-DcyGeCKA.js.map +0 -1
- package/dist/assets/model-info-form-VtbYsjrH.js +0 -2
- package/dist/assets/model-merger-qJqD9I2_.js +0 -2
- package/dist/assets/model-merger-qJqD9I2_.js.map +0 -1
- package/dist/assets/new-app-dialog-CTtQ52jO.js +0 -2
- package/dist/assets/new-app-dialog-CTtQ52jO.js.map +0 -1
- package/dist/assets/new-enum-dialog-B0QcIWdY.js +0 -2
- package/dist/assets/new-model-dialog-CM2dJ8Iv.js +0 -2
- package/dist/assets/route-B34jnFQF.js +0 -2
- package/dist/assets/route-B34jnFQF.js.map +0 -1
- package/dist/assets/route-BRBmSLMi.js +0 -2
- package/dist/assets/route-BRBmSLMi.js.map +0 -1
- package/dist/assets/route-BsIUCKz1.js +0 -2
- package/dist/assets/route-CAp89B2q.js +0 -2
- package/dist/assets/route-DcsVxxui.js +0 -2
- package/dist/assets/route-DmdFbZkw.js +0 -2
- package/dist/assets/route-Dpmx4lrA.js +0 -2
- package/dist/assets/route-Dpmx4lrA.js.map +0 -1
- package/dist/assets/route-T4J_Uk-9.js +0 -2
- package/dist/assets/route-T4J_Uk-9.js.map +0 -1
- package/dist/assets/route-w8_2x1VY.js +0 -2
- package/dist/assets/route-w8_2x1VY.js.map +0 -1
- package/dist/assets/service-Bgm1ICPI.js +0 -2
- package/dist/assets/service-Bgm1ICPI.js.map +0 -1
- package/dist/assets/template-extractor-DEU0CX0Y.js +0 -2
- package/dist/assets/use-enum-form-DKD2EDHZ.js +0 -2
- package/dist/assets/use-model-form-BQa-PiE_.js +0 -2
- package/dist/assets/utils-BYjOwi1b.js +0 -2
- package/dist/assets/utils-BYjOwi1b.js.map +0 -1
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{i as o}from"./_virtual___federation_fn_import-DXu2m-ZE.js";import{j as e}from"./jsx-runtime-D_zvdyIk.js";import{w,s as g}from"./index-BUYA3Tes.js";const{createWebAppSchema:v}=await o("@baseplate-dev/project-builder-lib"),{useBlockUnsavedChangesNavigate:C,useDefinitionSchema:L,useProjectDefinition:F,useResettableForm:A}=await o("@baseplate-dev/project-builder-lib/web"),{FormActionBar:D,InputFieldController:n,SectionList:k,SectionListSection:r,SectionListSectionContent:p,SectionListSectionDescription:m,SectionListSectionHeader:d,SectionListSectionTitle:u,SwitchFieldController:b}=await o("@baseplate-dev/ui-components"),B=function(){const{saveDefinitionWithFeedback:x}=F(),{webDefinition:i}=w.useRouteContext(),j=L(v),s=A({resolver:g(j),values:i}),{control:t,handleSubmit:h,reset:S}=s,a=h(f=>x(c=>{c.apps=c.apps.map(l=>l.id===i.id?f:l)}));return C({control:t,reset:S,onSubmit:a}),e.jsxs("form",{onSubmit:a,className:"w-full max-w-7xl space-y-4 p-4",children:[e.jsxs(k,{children:[e.jsxs(r,{children:[e.jsxs(d,{children:[e.jsx(u,{children:"General"}),e.jsx(m,{children:"Basic configuration for your web application."})]}),e.jsxs(p,{className:"space-y-6",children:[e.jsx(n,{label:"Name",control:t,name:"name"}),e.jsx(n,{label:"Package Location (optional)",placeholder:"e.g. packages/web",control:t,name:"packageLocation"}),e.jsx(n,{label:"Page Title",control:t,name:"title"}),e.jsx(n,{label:"Description Meta Tag",control:t,name:"description"})]})]}),e.jsxs(r,{children:[e.jsxs(d,{children:[e.jsx(u,{children:"Features"}),e.jsx(m,{children:"Configure optional features for your web application."})]}),e.jsxs(p,{className:"space-y-6",children:[e.jsx(b,{label:"Include Auth?",control:t,name:"includeAuth"}),e.jsx(b,{label:"Include Upload Components?",control:t,name:"includeUploadComponents"})]})]})]}),e.jsx(D,{form:s})]})};export{B as component};
|
|
2
|
+
//# sourceMappingURL=index-CsGKSjOd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-CsGKSjOd.js","sources":["../../src/routes/apps/edit.$key/web/index.tsx?tsr-split=component"],"sourcesContent":["import type React from 'react';\n\nimport { createWebAppSchema } from '@baseplate-dev/project-builder-lib';\nimport {\n useBlockUnsavedChangesNavigate,\n useDefinitionSchema,\n useProjectDefinition,\n useResettableForm,\n} from '@baseplate-dev/project-builder-lib/web';\nimport {\n FormActionBar,\n InputFieldController,\n SectionList,\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionDescription,\n SectionListSectionHeader,\n SectionListSectionTitle,\n SwitchFieldController,\n} from '@baseplate-dev/ui-components';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport { createFileRoute } from '@tanstack/react-router';\n\nexport const Route = createFileRoute('/apps/edit/$key/web/')({\n component: WebAppGeneralForm,\n});\n\nfunction WebAppGeneralForm(): React.JSX.Element {\n const { saveDefinitionWithFeedback } = useProjectDefinition();\n const { webDefinition } = Route.useRouteContext();\n\n const webAppSchema = useDefinitionSchema(createWebAppSchema);\n const formProps = useResettableForm({\n resolver: zodResolver(webAppSchema),\n values: webDefinition,\n });\n const { control, handleSubmit, reset } = formProps;\n\n const onSubmit = handleSubmit((data) =>\n saveDefinitionWithFeedback((draftConfig) => {\n draftConfig.apps = draftConfig.apps.map((app) =>\n app.id === webDefinition.id ? data : app,\n );\n }),\n );\n\n useBlockUnsavedChangesNavigate({ control, reset, onSubmit });\n\n return (\n <form onSubmit={onSubmit} className=\"w-full max-w-7xl space-y-4 p-4\">\n <SectionList>\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>General</SectionListSectionTitle>\n <SectionListSectionDescription>\n Basic configuration for your web application.\n </SectionListSectionDescription>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-6\">\n <InputFieldController label=\"Name\" control={control} name=\"name\" />\n <InputFieldController\n label=\"Package Location (optional)\"\n placeholder=\"e.g. packages/web\"\n control={control}\n name=\"packageLocation\"\n />\n <InputFieldController\n label=\"Page Title\"\n control={control}\n name=\"title\"\n />\n <InputFieldController\n label=\"Description Meta Tag\"\n control={control}\n name=\"description\"\n />\n </SectionListSectionContent>\n </SectionListSection>\n\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>Features</SectionListSectionTitle>\n <SectionListSectionDescription>\n Configure optional features for your web application.\n </SectionListSectionDescription>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-6\">\n <SwitchFieldController\n label=\"Include Auth?\"\n control={control}\n name=\"includeAuth\"\n />\n <SwitchFieldController\n label=\"Include Upload Components?\"\n control={control}\n name=\"includeUploadComponents\"\n />\n </SectionListSectionContent>\n </SectionListSection>\n </SectionList>\n <FormActionBar form={formProps} />\n </form>\n );\n}\n"],"names":["createWebAppSchema","importShared","useBlockUnsavedChangesNavigate","useDefinitionSchema","useProjectDefinition","useResettableForm","FormActionBar","InputFieldController","SectionList","SectionListSection","SectionListSectionContent","SectionListSectionDescription","SectionListSectionHeader","SectionListSectionTitle","SwitchFieldController","SplitComponent","saveDefinitionWithFeedback","webDefinition","Route","useRouteContext","webAppSchema","formProps","resolver","zodResolver","values","control","handleSubmit","reset","onSubmit","draftConfig","apps","map","app","id","data","jsxs","jsx"],"mappings":"0JAEA,KAAA,CAAA,mBAAAA,CAAA,EAAA,MAAAC,EAAA,oCAAA,EACA,CAAA,+BAAAC,EAAA,oBAAAC,EAAA,qBAAAC,EAAA,kBAAAC,CAAA,EAAA,MAAAJ,EAAA,wCAAA,EAMA,CAAA,cAAAK,EAAA,qBAAAC,EAAA,YAAAC,EAAA,mBAAAC,EAAA,0BAAAC,EAAA,8BAAAC,EAAA,yBAAAC,EAAA,wBAAAC,EAAA,sBAAAC,CAAA,EAAA,MAAAb,EAAA,8BAAA,EAWsDc,EAAA,UAON,CACxC,KAAA,CAAEC,2BAAAA,GAA+BZ,EAAqB,EACtD,CAAEa,cAAAA,CAAAA,EAAkBC,EAAMC,gBAAgB,EAE1CC,EAAejB,EAAoBH,CAAkB,EACrDqB,EAAYhB,EAAkB,CAClCiB,SAAUC,EAAYH,CAAY,EAClCI,OAAQP,CAAAA,CACT,EACK,CAAEQ,QAAAA,EAASC,aAAAA,EAAcC,MAAAA,CAAAA,EAAUN,EAEnCO,EAAWF,EACfV,GAAAA,EAA4Ca,GAAA,CAC9BC,EAAAA,KAAOD,EAAYC,KAAKC,IAAKC,GACvCA,EAAIC,KAAOhB,EAAcgB,GAAKC,EAAOF,CACvC,CAAA,CACD,CACH,EAE+B,OAAA9B,EAAA,CAAEuB,QAAAA,EAASE,MAAAA,EAAOC,SAAAA,CAAAA,CAAU,EAGxDO,EAAAA,KAAA,OAAA,CAAK,SAAAP,EAAoB,UAAU,iCAClC,SAAA,CAAAO,OAAC3B,EACC,CAAA,SAAA,CAAA2B,OAAC1B,EACC,CAAA,SAAA,CAAA0B,OAACvB,EACC,CAAA,SAAA,CAAAwB,EAAAA,IAACvB,GAAwB,SAAO,SAAA,CAAA,EAChCuB,EAAAA,IAACzB,GAA6B,SAE9B,+CAAA,CAAA,CAAA,EACF,EACAwB,EAAAA,KAACzB,EAA0B,CAAA,UAAU,YACnC,SAAA,CAAA0B,EAAA,IAAC7B,EAAqB,CAAA,MAAM,OAAO,QAAAkB,EAAkB,KAAK,OAAM,EAChEW,MAAC7B,GACC,MAAM,8BACN,YAAY,oBACZ,QAAAkB,EACA,KAAK,kBAAiB,QAEvBlB,EACC,CAAA,MAAM,aACN,QAAAkB,EACA,KAAK,QAAO,QAEblB,EACC,CAAA,MAAM,uBACN,QAAAkB,EACA,KAAK,aAAa,CAAA,CAAA,CAEtB,CAAA,CAAA,EACF,SAEChB,EACC,CAAA,SAAA,CAAA0B,OAACvB,EACC,CAAA,SAAA,CAAAwB,EAAAA,IAACvB,GAAwB,SAAQ,UAAA,CAAA,EACjCuB,EAAAA,IAACzB,GAA6B,SAE9B,uDAAA,CAAA,CAAA,EACF,EACAwB,EAAAA,KAACzB,EAA0B,CAAA,UAAU,YACnC,SAAA,CAAA0B,EAAA,IAACtB,EACC,CAAA,MAAM,gBACN,QAAAW,EACA,KAAK,cAAa,QAEnBX,EACC,CAAA,MAAM,6BACN,QAAAW,EACA,KAAK,yBAAyB,CAAA,CAAA,CAElC,CAAA,CAAA,CACF,CAAA,CAAA,EACF,EACAW,EAAAA,IAAC9B,EAAc,CAAA,KAAMe,CAAU,CAAA,CAAA,EACjC,CAEJ"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{i as c}from"./_virtual___federation_fn_import-DXu2m-ZE.js";import{j as e}from"./jsx-runtime-D_zvdyIk.js";import{S,v as j,a as v}from"./index-BUYA3Tes.js";import{u as f}from"./use-enum-form-CEyTBPQn.js";import{L,c as y}from"./index-BGLRovL6.js";import{f as C,e as N}from"./index.esm-CTDJ8Wko.js";const{SectionListSection:b,SectionListSectionContent:g,SectionListSectionHeader:w,SectionListSectionTitle:E,SwitchFieldController:V}=await c("@baseplate-dev/ui-components");function F({control:s}){return e.jsxs(b,{children:[e.jsx(w,{children:e.jsx(E,{children:"GraphQL"})}),e.jsx(g,{className:"space-y-4",children:e.jsx(V,{label:"Expose in GraphQL schema",control:s,name:"isExposed",description:"Whether to expose this enum in the GraphQL schema"})})]})}function A(s){return s.split("_").map(i=>i.charAt(0).toUpperCase()+i.slice(1).toLowerCase()).join(" ")}const{modelEnumValueEntityType:T}=await c("@baseplate-dev/project-builder-lib"),{Button:d,InputFieldController:u,Label:p,SectionListSection:$,SectionListSectionContent:I,SectionListSectionDescription:k,SectionListSectionHeader:B,SectionListSectionTitle:D}=await c("@baseplate-dev/ui-components");function G({control:s,setValue:r}){const{fields:t,remove:i,append:l,move:a}=C({control:s,name:"values"}),o=N({control:s,name:"values"}),m="grid grid-cols-[repeat(2,minmax(130px,1fr))_80px] gap-3",x=t.map((h,n)=>({id:h.id,element:e.jsxs("div",{className:m,children:[e.jsx(u,{control:s,name:`values.${n}.name`}),e.jsx(u,{control:s,name:`values.${n}.friendlyName`,onFocus:()=>{!o[n].friendlyName&&o[n].name&&r(`values.${n}.friendlyName`,A(o[n].name))}}),e.jsxs(d,{variant:"ghost",size:"icon",onClick:()=>{i(n)},children:[e.jsx(L,{}),e.jsx("div",{className:"sr-only",children:"Delete Enum"})]})]})}));return e.jsxs($,{children:[e.jsxs(B,{children:[e.jsx(D,{children:"Values"}),e.jsx(k,{children:"Configure the allowed values for this enum."})]}),e.jsxs(I,{className:"space-y-4",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsxs("div",{className:y(m,"pl-12"),children:[e.jsx(p,{children:"Value Name, e.g. ACTIVE"}),e.jsx(p,{children:"Value Friendly Name, e.g. Active"}),e.jsx("div",{})]}),t.length===0?e.jsx("p",{className:"pt-4 text-style-muted",children:"Add some values to get started"}):e.jsx(S,{listItems:x,sortItems:a})]}),e.jsx(d,{size:"sm",variant:"secondary",onClick:()=>{l({id:T.generateNewId(),name:"",friendlyName:""})},children:"Add Value"})]})]})}const{useBlockUnsavedChangesNavigate:Q}=await c("@baseplate-dev/project-builder-lib/web"),{FormActionBar:H,SectionList:R}=await c("@baseplate-dev/ui-components"),M=function(){const{key:r}=j.useParams(),{form:t,onSubmit:i,isSavingDefinition:l}=f({omit:["name","featureRef"],enumKey:r}),{control:a,setValue:o}=t;return Q({control:a,reset:t.reset,onSubmit:i}),e.jsx(v,{children:e.jsxs("form",{onSubmit:i,className:"mx-4 max-w-7xl min-w-[700px] flex-1 space-y-4 pb-4",children:[e.jsxs(R,{children:[e.jsx(F,{control:a}),e.jsx(G,{control:a,setValue:o})]}),e.jsx(H,{form:t,disabled:l})]})})};export{M as component};
|
|
2
|
+
//# sourceMappingURL=index-D-dbw3Qx.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-1ErFJbDw.js","sources":["../../src/routes/data/enums/edit.$key/-components/enum-graph-ql-section.tsx","../../src/utils/casing.ts","../../src/routes/data/enums/edit.$key/-components/enum-values-section.tsx","../../src/routes/data/enums/edit.$key/index.tsx?tsr-split=component"],"sourcesContent":["import type { EnumConfig } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport {\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionHeader,\n SectionListSectionTitle,\n SwitchFieldController,\n} from '@baseplate-dev/ui-components';\n\nexport function EnumGraphQLSection({\n control,\n}: {\n control: Control<EnumConfig>;\n}): React.JSX.Element {\n return (\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>GraphQL</SectionListSectionTitle>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-4\">\n <SwitchFieldController\n label=\"Expose in GraphQL schema\"\n control={control}\n name=\"isExposed\"\n description=\"Whether to expose this enum in the GraphQL schema\"\n />\n </SectionListSectionContent>\n </SectionListSection>\n );\n}\n","export function underscoreToTitleCase(str: string): string {\n // Split the string into an array of words\n const words = str.split('_');\n\n // Capitalize the first letter of each word and join them back together\n const titleCase = words\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())\n .join(' ');\n\n return titleCase;\n}\n","import type { EnumConfig } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control, UseFormSetValue } from 'react-hook-form';\n\nimport { modelEnumValueEntityType } from '@baseplate-dev/project-builder-lib';\nimport {\n Button,\n InputFieldController,\n Label,\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionDescription,\n SectionListSectionHeader,\n SectionListSectionTitle,\n} from '@baseplate-dev/ui-components';\nimport clsx from 'clsx';\nimport { useFieldArray, useWatch } from 'react-hook-form';\nimport { MdDeleteOutline } from 'react-icons/md';\n\nimport { SortableList } from '#src/components/index.js';\nimport { underscoreToTitleCase } from '#src/utils/casing.js';\n\nexport function EnumValuesSection({\n control,\n setValue,\n}: {\n control: Control<EnumConfig>;\n setValue: UseFormSetValue<EnumConfig>;\n}): React.JSX.Element {\n const {\n fields: valueFields,\n remove: removeValue,\n append: appendValue,\n move: sortValues,\n } = useFieldArray({\n control,\n name: 'values',\n });\n\n const values = useWatch({ control, name: 'values' });\n\n const gridClassNames =\n 'grid grid-cols-[repeat(2,minmax(130px,1fr))_80px] gap-3';\n\n const valueListItems = valueFields.map((field, i) => ({\n id: field.id,\n element: (\n <div className={gridClassNames}>\n <InputFieldController control={control} name={`values.${i}.name`} />\n <InputFieldController\n control={control}\n name={`values.${i}.friendlyName`}\n onFocus={() => {\n if (!values[i].friendlyName && values[i].name) {\n setValue(\n `values.${i}.friendlyName`,\n underscoreToTitleCase(values[i].name),\n );\n }\n }}\n />\n <Button\n variant=\"ghost\"\n size=\"icon\"\n onClick={() => {\n removeValue(i);\n }}\n >\n <MdDeleteOutline />\n <div className=\"sr-only\">Delete Enum</div>\n </Button>\n </div>\n ),\n }));\n\n return (\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>Values</SectionListSectionTitle>\n <SectionListSectionDescription>\n Configure the allowed values for this enum.\n </SectionListSectionDescription>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-4\">\n <div className=\"space-y-2\">\n <div\n className={clsx(\n gridClassNames,\n // account for handle in sortable list\n 'pl-12',\n )}\n >\n <Label>Value Name, e.g. ACTIVE</Label>\n <Label>Value Friendly Name, e.g. Active</Label>\n <div />\n </div>\n {valueFields.length === 0 ? (\n <p className=\"pt-4 text-style-muted\">\n Add some values to get started\n </p>\n ) : (\n <SortableList listItems={valueListItems} sortItems={sortValues} />\n )}\n </div>\n <Button\n size=\"sm\"\n variant=\"secondary\"\n onClick={() => {\n appendValue({\n id: modelEnumValueEntityType.generateNewId(),\n name: '',\n friendlyName: '',\n });\n }}\n >\n Add Value\n </Button>\n </SectionListSectionContent>\n </SectionListSection>\n );\n}\n","import type React from 'react';\n\nimport { useBlockUnsavedChangesNavigate } from '@baseplate-dev/project-builder-lib/web';\nimport { FormActionBar, SectionList } from '@baseplate-dev/ui-components';\nimport { createFileRoute } from '@tanstack/react-router';\n\nimport { ErrorBoundary } from '#src/components/index.js';\n\nimport { useEnumForm } from '../-hooks/use-enum-form.js';\nimport { EnumGraphQLSection } from './-components/enum-graph-ql-section.js';\nimport { EnumValuesSection } from './-components/enum-values-section.js';\n\nexport const Route = createFileRoute('/data/enums/edit/$key/')({\n component: EnumEditPage,\n});\n\nfunction EnumEditPage(): React.JSX.Element {\n const { key } = Route.useParams();\n const { form, onSubmit, isSavingDefinition } = useEnumForm({\n omit: ['name', 'featureRef'],\n enumKey: key,\n });\n const { control, setValue } = form;\n\n useBlockUnsavedChangesNavigate({ control, reset: form.reset, onSubmit });\n\n return (\n <ErrorBoundary>\n <form\n onSubmit={onSubmit}\n className=\"mx-4 max-w-7xl min-w-[700px] flex-1 space-y-4 pb-4\"\n >\n <SectionList>\n <EnumGraphQLSection control={control} />\n <EnumValuesSection control={control} setValue={setValue} />\n </SectionList>\n <FormActionBar form={form} disabled={isSavingDefinition} />\n </form>\n </ErrorBoundary>\n );\n}\n"],"names":["SectionListSection","SectionListSectionContent","SectionListSectionHeader","SectionListSectionTitle","SwitchFieldController","importShared","EnumGraphQLSection","control","jsx","underscoreToTitleCase","str","word","modelEnumValueEntityType","Button","InputFieldController","Label","SectionListSectionDescription","EnumValuesSection","setValue","valueFields","removeValue","appendValue","sortValues","useFieldArray","values","useWatch","gridClassNames","valueListItems","field","jsxs","MdDeleteOutline","clsx","SortableList","useBlockUnsavedChangesNavigate","FormActionBar","SectionList","SplitComponent","key","Route","useParams","form","onSubmit","isSavingDefinition","useEnumForm","omit","enumKey","reset","ErrorBoundary"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index-D-dbw3Qx.js","sources":["../../src/routes/data/enums/edit.$key/-components/enum-graph-ql-section.tsx","../../src/utils/casing.ts","../../src/routes/data/enums/edit.$key/-components/enum-values-section.tsx","../../src/routes/data/enums/edit.$key/index.tsx?tsr-split=component"],"sourcesContent":["import type { EnumConfig } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport {\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionHeader,\n SectionListSectionTitle,\n SwitchFieldController,\n} from '@baseplate-dev/ui-components';\n\nexport function EnumGraphQLSection({\n control,\n}: {\n control: Control<EnumConfig>;\n}): React.JSX.Element {\n return (\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>GraphQL</SectionListSectionTitle>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-4\">\n <SwitchFieldController\n label=\"Expose in GraphQL schema\"\n control={control}\n name=\"isExposed\"\n description=\"Whether to expose this enum in the GraphQL schema\"\n />\n </SectionListSectionContent>\n </SectionListSection>\n );\n}\n","export function underscoreToTitleCase(str: string): string {\n // Split the string into an array of words\n const words = str.split('_');\n\n // Capitalize the first letter of each word and join them back together\n const titleCase = words\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())\n .join(' ');\n\n return titleCase;\n}\n","import type { EnumConfig } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control, UseFormSetValue } from 'react-hook-form';\n\nimport { modelEnumValueEntityType } from '@baseplate-dev/project-builder-lib';\nimport {\n Button,\n InputFieldController,\n Label,\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionDescription,\n SectionListSectionHeader,\n SectionListSectionTitle,\n} from '@baseplate-dev/ui-components';\nimport clsx from 'clsx';\nimport { useFieldArray, useWatch } from 'react-hook-form';\nimport { MdDeleteOutline } from 'react-icons/md';\n\nimport { SortableList } from '#src/components/index.js';\nimport { underscoreToTitleCase } from '#src/utils/casing.js';\n\nexport function EnumValuesSection({\n control,\n setValue,\n}: {\n control: Control<EnumConfig>;\n setValue: UseFormSetValue<EnumConfig>;\n}): React.JSX.Element {\n const {\n fields: valueFields,\n remove: removeValue,\n append: appendValue,\n move: sortValues,\n } = useFieldArray({\n control,\n name: 'values',\n });\n\n const values = useWatch({ control, name: 'values' });\n\n const gridClassNames =\n 'grid grid-cols-[repeat(2,minmax(130px,1fr))_80px] gap-3';\n\n const valueListItems = valueFields.map((field, i) => ({\n id: field.id,\n element: (\n <div className={gridClassNames}>\n <InputFieldController control={control} name={`values.${i}.name`} />\n <InputFieldController\n control={control}\n name={`values.${i}.friendlyName`}\n onFocus={() => {\n if (!values[i].friendlyName && values[i].name) {\n setValue(\n `values.${i}.friendlyName`,\n underscoreToTitleCase(values[i].name),\n );\n }\n }}\n />\n <Button\n variant=\"ghost\"\n size=\"icon\"\n onClick={() => {\n removeValue(i);\n }}\n >\n <MdDeleteOutline />\n <div className=\"sr-only\">Delete Enum</div>\n </Button>\n </div>\n ),\n }));\n\n return (\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>Values</SectionListSectionTitle>\n <SectionListSectionDescription>\n Configure the allowed values for this enum.\n </SectionListSectionDescription>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-4\">\n <div className=\"space-y-2\">\n <div\n className={clsx(\n gridClassNames,\n // account for handle in sortable list\n 'pl-12',\n )}\n >\n <Label>Value Name, e.g. ACTIVE</Label>\n <Label>Value Friendly Name, e.g. Active</Label>\n <div />\n </div>\n {valueFields.length === 0 ? (\n <p className=\"pt-4 text-style-muted\">\n Add some values to get started\n </p>\n ) : (\n <SortableList listItems={valueListItems} sortItems={sortValues} />\n )}\n </div>\n <Button\n size=\"sm\"\n variant=\"secondary\"\n onClick={() => {\n appendValue({\n id: modelEnumValueEntityType.generateNewId(),\n name: '',\n friendlyName: '',\n });\n }}\n >\n Add Value\n </Button>\n </SectionListSectionContent>\n </SectionListSection>\n );\n}\n","import type React from 'react';\n\nimport { useBlockUnsavedChangesNavigate } from '@baseplate-dev/project-builder-lib/web';\nimport { FormActionBar, SectionList } from '@baseplate-dev/ui-components';\nimport { createFileRoute } from '@tanstack/react-router';\n\nimport { ErrorBoundary } from '#src/components/index.js';\n\nimport { useEnumForm } from '../-hooks/use-enum-form.js';\nimport { EnumGraphQLSection } from './-components/enum-graph-ql-section.js';\nimport { EnumValuesSection } from './-components/enum-values-section.js';\n\nexport const Route = createFileRoute('/data/enums/edit/$key/')({\n component: EnumEditPage,\n});\n\nfunction EnumEditPage(): React.JSX.Element {\n const { key } = Route.useParams();\n const { form, onSubmit, isSavingDefinition } = useEnumForm({\n omit: ['name', 'featureRef'],\n enumKey: key,\n });\n const { control, setValue } = form;\n\n useBlockUnsavedChangesNavigate({ control, reset: form.reset, onSubmit });\n\n return (\n <ErrorBoundary>\n <form\n onSubmit={onSubmit}\n className=\"mx-4 max-w-7xl min-w-[700px] flex-1 space-y-4 pb-4\"\n >\n <SectionList>\n <EnumGraphQLSection control={control} />\n <EnumValuesSection control={control} setValue={setValue} />\n </SectionList>\n <FormActionBar form={form} disabled={isSavingDefinition} />\n </form>\n </ErrorBoundary>\n );\n}\n"],"names":["SectionListSection","SectionListSectionContent","SectionListSectionHeader","SectionListSectionTitle","SwitchFieldController","importShared","EnumGraphQLSection","control","jsx","underscoreToTitleCase","str","word","modelEnumValueEntityType","Button","InputFieldController","Label","SectionListSectionDescription","EnumValuesSection","setValue","valueFields","removeValue","appendValue","sortValues","useFieldArray","values","useWatch","gridClassNames","valueListItems","field","i","jsxs","MdDeleteOutline","clsx","SortableList","useBlockUnsavedChangesNavigate","FormActionBar","SectionList","SplitComponent","key","Route","useParams","form","onSubmit","isSavingDefinition","useEnumForm","omit","enumKey","reset","ErrorBoundary"],"mappings":"8SAIA,KAAA,oBAAAA,EAAA,0BAAAC,EAAA,yBAAAC,EAAAC,wBAAAA,EAAA,sBAAAC,CAAA,EAAA,MAAAC,EAAA,8BAAA,EAQO,SAASC,EAAmB,CACjC,QAAAC,CACF,EAEsB,CACpB,cACGP,EACC,CAAA,SAAA,CAAAQ,MAACN,EACC,CAAA,SAAAM,EAAA,IAACL,EAAwB,CAAA,SAAA,SAAO,CAAA,EAClC,EACAK,EAAAA,IAACP,EAA0B,CAAA,UAAU,YACnC,SAAAO,EAAA,IAACJ,EAAA,CACC,MAAM,2BACN,QAAAG,EACA,KAAK,YACL,YAAY,mDAAA,CAAA,CAEhB,CAAA,CAAA,EACF,CAEJ,CChCO,SAASE,EAAsBC,EAAqB,CASlD,OAPOA,EAAI,MAAM,GAAG,EAIxB,IAAKC,GAASA,EAAK,OAAO,CAAC,EAAE,cAAgBA,EAAK,MAAM,CAAC,EAAE,aAAa,EACxE,KAAK,GAAG,CAGb,CCNA,KAAA,CAAA,yBAAAC,CAAA,EAAA,MAAAP,EAAA,oCAAA,EACA,CAAA,OAAAQ,EAAA,qBAAAC,EAAA,MAAAC,EAAA,mBAAAf,EAAA,0BAAAC,EAAA,8BAAAe,EAAA,yBAAAd,EAAA,wBAAAC,CAAA,EAAA,MAAAE,EAAA,8BAAA,EAiBO,SAASY,EAAkB,CAChC,QAAAV,EACA,SAAAW,CACF,EAGsB,CACd,KAAA,CACJ,OAAQC,EACR,OAAQC,EACR,OAAQC,EACR,KAAMC,GACJC,EAAc,CAChB,QAAAhB,EACA,KAAM,QAAA,CACP,EAEKiB,EAASC,EAAS,CAAE,QAAAlB,EAAS,KAAM,SAAU,EAE7CmB,EACJ,0DAEIC,EAAiBR,EAAY,IAAI,CAACS,EAAOC,KAAO,CACpD,GAAID,EAAM,GACV,QACEE,EAAA,KAAC,MAAI,CAAA,UAAWJ,EACd,SAAA,CAAAlB,MAACM,EAAqB,CAAA,QAAAP,EAAkB,KAAM,UAAUsB,CAAC,QAAS,EAClErB,EAAA,IAACM,EAAA,CACC,QAAAP,EACA,KAAM,UAAUsB,CAAC,gBACjB,QAAS,IAAM,CACT,CAACL,EAAOK,CAAC,EAAE,cAAgBL,EAAOK,CAAC,EAAE,MACvCX,EACE,UAAUW,CAAC,gBACXpB,EAAsBe,EAAOK,CAAC,EAAE,IAAI,CACtC,CACF,CACF,CACF,EACAC,EAAA,KAACjB,EAAA,CACC,QAAQ,QACR,KAAK,OACL,QAAS,IAAM,CACbO,EAAYS,CAAC,CACf,EAEA,SAAA,CAAArB,EAAA,IAACuB,EAAgB,EAAA,EAChBvB,EAAA,IAAA,MAAA,CAAI,UAAU,UAAU,SAAW,aAAA,CAAA,CAAA,CAAA,CAAA,CACtC,CACF,CAAA,CAAA,EAEF,EAEF,cACGR,EACC,CAAA,SAAA,CAAA8B,OAAC5B,EACC,CAAA,SAAA,CAAAM,EAAAA,IAACL,GAAwB,SAAM,QAAA,CAAA,EAC/BK,EAAAA,IAACQ,GAA8B,SAE/B,6CAAA,CAAA,CAAA,EACF,EACAc,EAAAA,KAAC7B,EAA0B,CAAA,UAAU,YACnC,SAAA,CAAC6B,EAAAA,KAAA,MAAA,CAAI,UAAU,YACb,SAAA,CAAAA,EAAA,KAAC,MAAA,CACC,UAAWE,EACTN,EAEA,OACF,EAEA,SAAA,CAAAlB,EAAAA,IAACO,GAAM,SAAuB,yBAAA,CAAA,EAC9BP,EAAAA,IAACO,GAAM,SAAgC,kCAAA,CAAA,QACtC,MAAI,CAAA,CAAA,CAAA,CAAA,CACP,EACCI,EAAY,SAAW,EACtBX,EAAAA,IAAC,KAAE,UAAU,wBAAwB,SAErC,gCAAA,CAAA,EAECA,EAAAA,IAAAyB,EAAA,CAAa,UAAWN,EAAgB,UAAWL,CAAY,CAAA,CAAA,EAEpE,EACAd,EAAA,IAACK,EAAA,CACC,KAAK,KACL,QAAQ,YACR,QAAS,IAAM,CACDQ,EAAA,CACV,GAAIT,EAAyB,cAAc,EAC3C,KAAM,GACN,aAAc,EAAA,CACf,CACH,EACD,SAAA,WAAA,CAAA,CAED,CACF,CAAA,CAAA,EACF,CAEJ,CCtHA,KAAA,CAAA,+BAAAsB,CAAA,EAAA,MAAA7B,EAAA,wCAAA,EACA,CAAA,cAAA8B,EAAA,YAAAC,CAAA,EAAA,MAAA/B,EAAA,8BAAA,EAOyEgC,EAAA,UAM9B,CACnC,KAAA,CAAEC,IAAAA,CAAAA,EAAQC,EAAMC,UAAU,EAC1B,CAAEC,KAAAA,EAAMC,SAAAA,EAAUC,mBAAAA,GAAuBC,EAAY,CACzDC,KAAM,CAAC,OAAQ,YAAY,EAC3BC,QAASR,CAAAA,CACV,EACK,CAAE/B,QAAAA,EAASW,SAAAA,CAAAA,EAAauB,EAEC,OAAAP,EAAA,CAAE3B,QAAAA,EAASwC,MAAON,EAAKM,MAAOL,SAAAA,CAAAA,CAAU,QAGpEM,EACC,CAAA,SAAAlB,EAAA,KAAC,OACC,CAAA,SAAAY,EACA,UAAU,qDAEV,SAAA,CAAAZ,OAACM,EACC,CAAA,SAAA,CAAA5B,MAACF,GAAmB,QAAAC,EAAiB,EACrCC,EAAAA,IAACS,EAAkB,CAAA,QAAAV,EAAkB,SAAAW,CAAmB,CAAA,CAAA,EAC1D,EACCV,EAAAA,IAAA2B,EAAA,CAAc,KAAAM,EAAY,SAAUE,CAAmB,CAAA,CAAA,CAAA,CAC1D,CACF,CAAA,CAEJ"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{i as t}from"./_virtual___federation_fn_import-DXu2m-ZE.js";import{j as e}from"./jsx-runtime-D_zvdyIk.js";import{h as p}from"./index-BGLRovL6.js";import{N as n}from"./new-app-dialog-DPQv-mvi.js";import{s as c}from"./sortBy-C9bvycg5.js";const{appEntityType:d}=await t("@baseplate-dev/project-builder-lib"),{useProjectDefinition:l}=await t("@baseplate-dev/project-builder-lib/web"),{Button:a,Card:m,EmptyDisplay:h}=await t("@baseplate-dev/ui-components"),{Link:x}=await t("@tanstack/react-router"),N=function(){const{definition:r}=l(),{apps:o}=r,i=c(o,[s=>s.name]);return i.length===0?e.jsx(h,{icon:p,header:"No Apps",subtitle:"You haven't created any apps yet",actions:e.jsx(n,{children:e.jsx(a,{children:"New App"})})}):e.jsxs("div",{className:"space-y-4 p-4",children:[e.jsx("h1",{children:"Apps"}),e.jsx("p",{children:"These are the apps that are defined in your project. You can edit them here."}),e.jsx(n,{children:e.jsx(a,{children:"New App"})}),e.jsx("div",{className:"max-w-xl space-y-4",children:i.map(s=>e.jsxs(m,{className:"flex justify-between space-x-4 p-4",children:[e.jsxs("div",{children:[e.jsxs("h3",{children:[s.name," (",s.type,")"]}),e.jsx("p",{className:"text-xs text-muted-foreground",children:s.packageLocation})]}),e.jsx(x,{to:"/apps/edit/$key",params:{key:d.keyFromId(s.id)},className:"inline-block",children:e.jsx(a,{variant:"secondary",children:"Edit"})})]},s.id))})]})};export{N as component};
|
|
2
|
+
//# sourceMappingURL=index-DCiH936w.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-
|
|
1
|
+
{"version":3,"file":"index-DCiH936w.js","sources":["../../src/routes/apps/index.tsx?tsr-split=component"],"sourcesContent":["import type React from 'react';\n\nimport { appEntityType } from '@baseplate-dev/project-builder-lib';\nimport { useProjectDefinition } from '@baseplate-dev/project-builder-lib/web';\nimport { Button, Card, EmptyDisplay } from '@baseplate-dev/ui-components';\nimport { createFileRoute, Link } from '@tanstack/react-router';\nimport { sortBy } from 'es-toolkit';\nimport { MdApps } from 'react-icons/md';\n\nimport NewAppDialog from './-components/new-app-dialog.js';\n\nexport const Route = createFileRoute('/apps/')({\n component: AppsListPage,\n});\n\nfunction AppsListPage(): React.JSX.Element {\n const { definition } = useProjectDefinition();\n\n const { apps } = definition;\n const sortedApps = sortBy(apps, [(app) => app.name]);\n\n if (sortedApps.length === 0) {\n return (\n <EmptyDisplay\n icon={MdApps}\n header=\"No Apps\"\n subtitle=\"You haven't created any apps yet\"\n actions={\n <NewAppDialog>\n <Button>New App</Button>\n </NewAppDialog>\n }\n />\n );\n }\n\n return (\n <div className=\"space-y-4 p-4\">\n <h1>Apps</h1>\n <p>\n These are the apps that are defined in your project. You can edit them\n here.\n </p>\n <NewAppDialog>\n <Button>New App</Button>\n </NewAppDialog>\n <div className=\"max-w-xl space-y-4\">\n {sortedApps.map((app) => (\n <Card key={app.id} className=\"flex justify-between space-x-4 p-4\">\n <div>\n <h3>\n {app.name} ({app.type})\n </h3>\n <p className=\"text-xs text-muted-foreground\">\n {app.packageLocation}\n </p>\n </div>\n <Link\n to=\"/apps/edit/$key\"\n params={{ key: appEntityType.keyFromId(app.id) }}\n className=\"inline-block\"\n >\n <Button variant=\"secondary\">Edit</Button>\n </Link>\n </Card>\n ))}\n </div>\n </div>\n );\n}\n"],"names":["appEntityType","importShared","useProjectDefinition","Button","Card","EmptyDisplay","Link","SplitComponent","definition","apps","sortedApps","sortBy","app","name","length","jsx","MdApps","NewAppDialog","jsxs","map","type","packageLocation","key","keyFromId","id"],"mappings":"kPAEA,KAAA,CAAA,cAAAA,CAAA,EAAA,MAAAC,EAAA,oCAAA,EACA,CAAA,qBAAAC,CAAA,EAAA,MAAAD,EAAA,wCAAA,EACA,CAAA,OAAAE,EAAA,KAAAC,EAAA,aAAAC,CAAA,EAAA,MAAAJ,EAAA,8BAAA,EACA,CAAA,KAAAK,CAAA,EAAA,MAAAL,EAAA,wBAAA,EAI2DM,EAAA,UAMhB,CACnC,KAAA,CAAEC,WAAAA,GAAeN,EAAqB,EAEtC,CAAEO,KAAAA,CAAAA,EAASD,EACXE,EAAaC,EAAOF,EAAM,CAAUG,GAAAA,EAAIC,IAAI,CAAC,EAE/CH,OAAAA,EAAWI,SAAW,EAErBC,EAAA,IAAAV,EAAA,CACC,KAAMW,EACN,OAAO,UACP,SAAS,mCACT,cACGC,EACC,CAAA,SAAAF,EAAAA,IAACZ,EAAO,CAAA,SAAA,SAAA,CAAO,CACjB,CAAA,EAEF,EAKJe,EAAA,KAAC,MAAI,CAAA,UAAU,gBACb,SAAA,CAAAH,EAAAA,IAAC,MAAG,SAAI,MAAA,CAAA,EACRA,EAAAA,IAAC,KAAC,SAGF,8EAAA,CAAA,EACCA,MAAAE,EAAA,CACC,SAACF,EAAA,IAAAZ,EAAA,CAAO,kBAAO,CAAA,EACjB,EACAY,EAAA,IAAC,MAAI,CAAA,UAAU,qBACZL,SAAAA,EAAWS,IACVP,GAAAM,EAAA,KAACd,EAAkB,CAAA,UAAU,qCAC3B,SAAA,CAAAc,OAAC,MACC,CAAA,SAAA,CAAAA,OAAC,KACEN,CAAAA,SAAAA,CAAIC,EAAAA,KAAK,KAAGD,EAAIQ,KAAK,GAAA,EACxB,EACCL,EAAA,IAAA,IAAA,CAAE,UAAU,gCACVH,WAAIS,eACP,CAAA,CAAA,EACF,EACCN,EAAAA,IAAAT,EAAA,CACC,GAAG,kBACH,OAAQ,CAAEgB,IAAKtB,EAAcuB,UAAUX,EAAIY,EAAE,CAAE,EAC/C,UAAU,eAEV,SAAAT,MAACZ,GAAO,QAAQ,YAAY,eAAI,CAAA,CAClC,CAAA,CAAA,GAfSS,EAAIY,EAgBf,CACD,CACH,CAAA,CAAA,EACF,CAEJ"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{i as f}from"./_virtual___federation_fn_import-DXu2m-ZE.js";import{j as e}from"./jsx-runtime-D_zvdyIk.js";import{s as ie,o as E,e as ne,S as Se,p as $e,a as Ne,r as te}from"./index-BUYA3Tes.js";import{u as g,S as Fe,E as Me}from"./-constants-C0cnDlAn.js";import{u as Ie}from"./use-model-form-Ch_tz0Rd.js";import{r as Le,c as w,N as Te,O as Oe,P as Ue,Q as Ee,H as ye,L as be,A as Ce}from"./index-BGLRovL6.js";import{u as I,b as se,e as le,f as qe}from"./index.esm-CTDJ8Wko.js";import{i as Ae}from"./inflection-C1nKqrJS.js";import{c as Pe}from"./capitalize-gOJXDbsR.js";import{w as Be}from"./words-Cs2RBKRm.js";function M(c){const t=Be(c);if(t.length===0)return"";const[s,...l]=t;return`${s.toLowerCase()}${l.map(r=>Pe(r)).join("")}`}const{modelScalarFieldEntityType:ae}=await f("@baseplate-dev/project-builder-lib"),{Button:re,ButtonGroup:Ke,DropdownMenu:ze,DropdownMenuContent:Ve,DropdownMenuItem:ke,DropdownMenuTrigger:He}=await f("@baseplate-dev/ui-components"),{useMemo:We}=await f("react");function _e({className:c,appendField:t,setValue:s}){const l=g(i=>i.model.fields.map(a=>a.name)),r=g(i=>i.model.primaryKeyFieldRefs.length),n=We(()=>{const i=[];r||i.push({name:"ID (uuid)",fields:[{name:"id",type:"uuid",options:{genUuid:!0},isPrimaryKey:!0}]});const a=l.includes("createdAt"),m=l.includes("updatedAt");return(!a||!m)&&i.push({name:"Timestamps",fields:[{name:"createdAt",type:"dateTime",options:{defaultToNow:!0}},{name:"updatedAt",type:"dateTime",options:{updatedAt:!0,defaultToNow:!0}}]}),i},[l,r]),o=i=>{for(const{isPrimaryKey:a,...m}of i.fields){const d=ae.generateNewId();l.includes(m.name)||t({id:d,...m}),a&&s("model.primaryKeyFieldRefs",[d],{shouldDirty:!0})}};return e.jsxs(Ke,{className:c,children:[e.jsx(re,{variant:"secondary",onClick:()=>{t({id:ae.generateNewId(),name:"",type:"string",isOptional:!0,options:{default:""}})},size:"sm",children:"Add Field"}),e.jsxs(ze,{children:[e.jsx(He,{disabled:n.length===0,asChild:!0,children:e.jsx(re,{variant:"secondary",size:"sm",children:e.jsx(Le,{})})}),e.jsx(Ve,{children:n.map(i=>e.jsx(ke,{onClick:()=>{o(i)},children:i.name},i.name))})]})]})}const{Button:de,DialogClose:Ge,DialogFooter:Ye,MultiComboboxFieldController:Qe}=await f("@baseplate-dev/ui-components"),{useId:Xe}=await f("react"),{z:_}=await f("zod"),Je=_.object({fields:_.array(_.string()).min(1,"At least one primary key is required")});function Ze({className:c,control:t,onSubmitSuccess:s}){const l=g(d=>d.model.fields),{field:{value:r=[],onChange:n}}=I({name:"model.primaryKeyFieldRefs",control:t}),{control:o,handleSubmit:i}=se({resolver:ie(Je),values:{fields:r}}),a=i(d=>{n(d.fields),s?.()}),m=Xe();return e.jsxs("form",{className:w("space-y-4",c),onSubmit:d=>(d.stopPropagation(),a(d)),id:m,children:[e.jsx(Qe,{control:o,name:"fields",options:l.map(d=>({value:d.id,label:d.name})),placeholder:"Select fields to use as primary keys"}),e.jsxs(Ye,{children:[e.jsx(Ge,{asChild:!0,children:e.jsx(de,{variant:"secondary",children:"Cancel"})}),e.jsx(de,{type:"submit",form:m,children:"Save"})]})]})}const{Dialog:en,DialogContent:nn,DialogDescription:tn,DialogHeader:sn,DialogTitle:on,DialogTrigger:ln,useControlledState:an}=await f("@baseplate-dev/ui-components");function we({control:c,children:t,asChild:s,open:l,onOpenChange:r}){const[n,o]=an(l,r,!1);return e.jsxs(en,{open:n,onOpenChange:o,children:[t&&e.jsx(ln,{asChild:s,children:t}),e.jsxs(nn,{children:[e.jsxs(sn,{children:[e.jsx(on,{children:"Primary Keys"}),e.jsx(tn,{children:"Select the fields that will be used as the primary key for this model"})]}),e.jsx(Ze,{control:c,onSubmitSuccess:()=>{o(!1)}})]})]})}const{BadgeWithIcon:rn}=await f("@baseplate-dev/ui-components"),{useState:dn}=await f("react");function cn({className:c,control:t,autoCollapse:s}){const[l,r]=dn(!1),n=!s||l;return e.jsx(we,{control:t,children:e.jsx(rn,{icon:Te,variant:"secondary",className:c,onMouseEnter:()=>{r(!0)},onMouseLeave:()=>{r(!1)},"aria-label":"Primary Key",title:"Primary Key",children:n&&"Primary"})})}const{createModelRelationFieldSchema:mn,ModelFieldUtils:un,modelForeignRelationEntityType:fn,modelLocalRelationEntityType:pn,ModelUtils:ce}=await f("@baseplate-dev/project-builder-lib"),{useDefinitionSchema:hn,useProjectDefinition:xn}=await f("@baseplate-dev/project-builder-lib/web"),{Button:G,ComboboxField:jn,ComboboxFieldController:Y,DialogClose:gn,DialogFooter:vn,InputFieldController:me,SelectFieldController:yn,toast:ue}=await f("@baseplate-dev/ui-components"),De=await f("react"),{useId:bn,useMemo:Cn}=De;function wn(c,t,s){if(!s)return;const l=s.replace(/Id$/,""),r=a=>c.models.find(m=>m.id!==t.id&&a(m))?.id,n=r(a=>a.name.toLowerCase()===l.toLowerCase());if(n)return n;const o=r(a=>a.featureRef===a.featureRef&&a.name.toLowerCase().includes(l.toLowerCase()));return o||r(a=>a.name.toLowerCase().includes(l.toLowerCase()))}function fe(c,t,s,l){const r=(()=>{if(s.name)return s.name;if(s.modelRef){const i=ce.byIdOrThrow(c,s.modelRef);return M(i.name)}})(),n=(()=>{if(!s.modelRef)return;const{model:{fields:i,primaryKeyFieldRefs:a},name:m}=ce.byIdOrThrow(c,s.modelRef),d=i.filter(x=>a.includes(x.id)),p=s.references??[];return d.map((x,h)=>{const D=h===0&&l?l:d.length===1?`${M(m)}Id`:x.name;return{localRef:p[h]?.localRef??t.model.fields.find(v=>v.name===D)?.id,foreignRef:x.id}})})(),o=(()=>{if(!n)return;if(s.foreignRelationName)return s.foreignRelationName;const i=n.every(a=>a.localRef)&&un.areScalarsUnique(t,n.map(a=>a.localRef));return M(i?t.name:Ae.pluralize(t.name))})();return{name:r??"",foreignRelationName:o??"",references:n??[]}}function Dn({className:c,control:t,onSubmitSuccess:s,relationId:l,defaultFieldName:r}){const{definition:n}=xn(),o=g(u=>u),i=o.name,{fields:a}=o.model,{field:{value:m=[],onChange:d}}=I({name:"model.relations",control:t}),p=n.models.map(u=>({label:u.name,value:u.id})),x=l===void 0?void 0:m.find(u=>u.id===l),h=Cn(()=>{if(x)return x;const u=wn(n,o,r);return{id:pn.generateNewId(),foreignId:fn.generateNewId(),modelRef:u??"",onDelete:"Restrict",onUpdate:"Restrict",...fe(n,o,{modelRef:u},r)}},[x,r,n,o]),D=hn(mn),{control:b,handleSubmit:v,setError:H,watch:A,setValue:L}=se({resolver:ie(D),defaultValues:h}),S=A(),$=S.modelRef?n.models.find(u=>u.id===S.modelRef):void 0,T=$?.model.fields,W=a.map(u=>({label:u.name,value:u.id})),P=T?.map(u=>({label:u.name,value:u.id}))??[],j=S.references.some(u=>a.find(C=>C.id===u.localRef)?.isOptional),R=()=>{d(m.filter(u=>u.id!==l)),s?.()},Re=v(u=>{const{id:C}=u;if(a.some(y=>y.name===u.name)||m.some(y=>y.name===u.name&&y.id!==u.id)){H("name",{message:"The relation name cannot be the same as a field/relation name"});return}const U=u.references.map(y=>y.localRef);if(new Set(U).size!==U.length){ue.error("Local fields must be unique");return}const B=u.references.map(y=>y.foreignRef);if(new Set(B).size!==B.length){ue.error("Foreign fields must be unique");return}m.some(y=>y.id===C)?d(m.map(y=>y.id===C?u:y)):d([...m,u]),s?.()}),oe=bn(),O=!!$;return e.jsxs("form",{className:w("space-y-4",c),onSubmit:u=>(u.stopPropagation(),Re(u)),id:oe,children:[e.jsxs("div",{className:"grid grid-cols-2 gap-x-8 gap-y-2",children:[e.jsx(jn,{options:[{label:i,value:i}],value:i,disabled:!0,label:"Local Model"}),e.jsx(Y,{control:b,name:"modelRef",options:p,label:"Foreign Model",onChange:u=>{if(!u)return;const{foreignRelationName:C,name:U,references:B}=fe(n,o,{...S,modelRef:u},r);C&&L("foreignRelationName",C),U&&L("name",U),L("references",B)}})]}),e.jsxs("div",{className:w("grid grid-cols-2 gap-x-8 gap-y-2",!O&&"pointer-events-none opacity-50"),children:[e.jsx(me,{control:b,disabled:!O,name:"name",label:"Local Relation Name",description:e.jsxs("span",{children:["Name of the relation, e.g. ",M(i),".",e.jsx("strong",{children:$?.name?M($.name):"user"})]})}),e.jsx(me,{control:b,disabled:!O,name:"foreignRelationName",label:"Foreign Relation Name",description:e.jsxs("span",{children:["Name of the relation on the foreign model, e.g."," ",M($?.name??"post"),".",e.jsx("strong",{children:h.foreignRelationName||"user"})]})}),e.jsx("div",{className:"text-sm font-medium",children:"Local Field"}),e.jsx("div",{className:"text-sm font-medium",children:"Foreign Field"}),S.references.map((u,C)=>e.jsxs(De.Fragment,{children:[e.jsx(Y,{disabled:!O,control:b,name:`references.${C}.localRef`,options:W}),e.jsx(Y,{control:b,name:`references.${C}.foreignRef`,options:P,disabled:!0})]},C))]}),e.jsx("div",{className:"grid grid-cols-2 gap-x-8 gap-y-2 border-t pt-4",children:e.jsx(yn,{label:"On Delete",control:b,options:[{label:"Cascade (delete entire local row)",value:"Cascade"},{label:"Restrict (throw error)",value:"Restrict"},...j?[{label:"Set Null (set local field to null)",value:"SetNull"}]:[]],name:"onDelete",description:"What to do when the foreign row is deleted"})}),e.jsx(vn,{children:e.jsxs("div",{className:"flex w-full justify-between",children:[l&&e.jsx(G,{variant:"secondary",onClick:u=>{u.preventDefault(),R()},children:"Delete"}),e.jsxs("div",{className:"flex gap-4",children:[e.jsx(gn,{asChild:!0,children:e.jsx(G,{variant:"secondary",children:"Cancel"})}),e.jsx(G,{type:"submit",form:oe,disabled:!O,children:"Save"})]})]})})]})}const{Dialog:Rn,DialogContent:Sn,DialogDescription:$n,DialogHeader:Nn,DialogTitle:Fn,DialogTrigger:Mn,useControlledState:In}=await f("@baseplate-dev/ui-components");function V({control:c,children:t,asChild:s,open:l,onOpenChange:r,relationId:n,defaultFieldName:o}){const[i,a]=In(l,r,!1);return e.jsxs(Rn,{open:i,onOpenChange:a,children:[t&&e.jsx(Mn,{asChild:s,children:t}),e.jsxs(Sn,{width:"lg",children:[e.jsxs(Nn,{children:[e.jsx(Fn,{children:n?"Edit Relation":"Create Relation"}),e.jsx($n,{children:"Set up the relation between this model and another model"})]}),e.jsx(Dn,{control:c,onSubmitSuccess:()=>{a(!1)},relationId:n,defaultFieldName:o})]})]})}const{useProjectDefinition:Ln}=await f("@baseplate-dev/project-builder-lib/web"),{BadgeWithIcon:Tn}=await f("@baseplate-dev/ui-components"),{useState:On}=await f("react");function Un({className:c,control:t,relation:s,autoCollapse:l}){const{definitionContainer:r}=Ln(),[n,o]=On(!1),i=!l||n;return e.jsx(V,{control:t,relationId:s.id,children:e.jsx(Tn,{icon:Oe,variant:"secondary",className:w("max-w-[100px]",c),onMouseEnter:()=>{o(!0)},onMouseLeave:()=>{o(!1)},"aria-label":"Relation",title:"Relation",children:i&&`${r.nameFromId(s.modelRef)} ${s.references.length>1?`(${s.references.length})`:""}`})})}const{modelUniqueConstraintEntityType:En}=await f("@baseplate-dev/project-builder-lib"),{Button:Q,DialogClose:qn,DialogFooter:An,MultiComboboxFieldController:Pn}=await f("@baseplate-dev/ui-components"),{useId:Bn}=await f("react"),{z:K}=await f("zod"),Kn=K.object({id:K.string().optional(),fields:K.array(K.string()).min(1,"At least one field is required")});function zn({className:c,control:t,onSubmitSuccess:s,constraintId:l}){const r=g(h=>h.model.fields),{field:{value:n=[],onChange:o}}=I({name:"model.uniqueConstraints",control:t}),i=l===void 0?void 0:n.find(h=>h.id===l),{control:a,handleSubmit:m}=se({resolver:ie(Kn),values:i?{id:i.id,fields:i.fields.map(h=>h.fieldRef)}:{fields:[]}}),d=()=>{o(n.filter(h=>h.id!==l)),s?.()},p=m(h=>{const D={id:h.id??En.generateNewId(),fields:h.fields.map(v=>({fieldRef:v}))},{id:b}=D;n.some(v=>v.id===b)?o(n.map(v=>v.id===b?D:v)):o([...n,D]),s?.()}),x=Bn();return e.jsxs("form",{className:w("space-y-4",c),onSubmit:h=>(h.stopPropagation(),p(h)),id:x,children:[e.jsx(Pn,{control:a,name:"fields",options:r.map(h=>({value:h.id,label:h.name})),placeholder:"Select fields to use as primary keys"}),e.jsx(An,{children:e.jsxs("div",{className:"flex w-full justify-between",children:[l&&e.jsx(Q,{variant:"secondary",onClick:h=>{h.preventDefault(),d()},children:"Delete"}),e.jsxs("div",{className:"flex gap-4",children:[e.jsx(qn,{asChild:!0,children:e.jsx(Q,{variant:"secondary",children:"Cancel"})}),e.jsx(Q,{type:"submit",form:x,children:"Save"})]})]})})]})}const{Dialog:Vn,DialogContent:kn,DialogDescription:Hn,DialogHeader:Wn,DialogTitle:_n,DialogTrigger:Gn,useControlledState:Yn}=await f("@baseplate-dev/ui-components");function k({control:c,children:t,asChild:s,open:l,onOpenChange:r,constraintId:n}){const[o,i]=Yn(l,r,!1);return e.jsxs(Vn,{open:o,onOpenChange:i,children:[t&&e.jsx(Gn,{asChild:s,children:t}),e.jsxs(kn,{children:[e.jsxs(Wn,{children:[e.jsx(_n,{children:"Unique Constraint"}),e.jsx(Hn,{children:"Select the fields that will be part of this unique constraint."})]}),e.jsx(zn,{control:c,onSubmitSuccess:()=>{i(!1)},constraintId:n})]})]})}const{BadgeWithIcon:Qn}=await f("@baseplate-dev/ui-components"),{useState:Xn}=await f("react");function Jn({className:c,control:t,constraintId:s,autoCollapse:l}){const[r,n]=Xn(!1),o=!l||r,i=g(a=>a.model.uniqueConstraints?.find(m=>m.id===s)?.fields.length??0);return e.jsx(k,{control:t,constraintId:s,children:e.jsx(Qn,{variant:"secondary",icon:Ue,className:w("",c),onMouseEnter:()=>{n(!0)},onMouseLeave:()=>{n(!1)},"aria-label":"Unique Constraint",title:"Unique Constraint",children:o&&`Unique ${i>1?`(${i})`:""}`})})}function Zn({className:c,control:t,idx:s}){const l=g(d=>d.model.fields[s]),r=g(d=>d.model.primaryKeyFieldRefs.includes(l.id)),n=g(d=>d.model.uniqueConstraints?.filter(p=>p.fields.some(x=>x.fieldRef===l.id)).map(p=>p.id)??[]),o=g(({model:d})=>{const p=d.fields[s];return d.relations?.filter(x=>x.references.some(h=>h.localRef===p.id))??[]}),a=(r?1:0)+n.length+o.length>2,m=[r&&e.jsx(cn,{control:t,autoCollapse:a},"primary"),...n.map(d=>e.jsx(Jn,{control:t,constraintId:d,autoCollapse:a},d)),...o.map(d=>e.jsx(Un,{control:t,relation:d,autoCollapse:a},d.id))];return e.jsx("div",{className:w("flex gap-4",c),children:m})}const{EnumUtils:ei}=await f("@baseplate-dev/project-builder-lib"),{useProjectDefinition:ni}=await f("@baseplate-dev/project-builder-lib/web"),{Button:N,ComboboxField:ii,DropdownMenu:pe,DropdownMenuContent:he,DropdownMenuGroup:xe,DropdownMenuItem:X,DropdownMenuTrigger:je,InputField:ge,InputFieldController:J,SelectFieldController:ti}=await f("@baseplate-dev/ui-components");function si({control:c,idx:t,setValue:s}){const{definition:l}=ni(),r=le({control:c,name:`model.fields.${t}.type`}),{field:{value:n,onChange:o}}=I({name:`model.fields.${t}.options`,control:c}),i=le({control:c,name:`model.fields.${t}.options.default`});if(r==="boolean")return e.jsxs("div",{className:"flex items-center gap-1",children:[e.jsx(ti,{control:c,className:"flex-1",name:`model.fields.${t}.options.default`,options:[{label:"True",value:"true"},{label:"False",value:"false"}],placeholder:"NULL"}),i&&e.jsx(N,{title:"Reset",onClick:()=>{s(`model.fields.${t}.options.default`,"",{shouldDirty:!0})},variant:"ghost",size:"icon",children:e.jsx(E,{})})]});if(["string","int","float"].includes(r))return e.jsxs("div",{className:"flex items-center gap-1",children:[e.jsx(J,{control:c,placeholder:"NULL",name:`model.fields.${t}.options.default`,className:"flex-1"}),i&&e.jsx(N,{title:"Reset",onClick:()=>{s(`model.fields.${t}.options.default`,void 0,{shouldDirty:!0})},variant:"ghost",size:"icon",children:e.jsx(E,{})})]});if(r==="uuid")return n?.genUuid?e.jsxs("div",{className:"flex items-center gap-1",children:[e.jsx(ge,{disabled:!0,value:"Random UUID v4",className:"flex-1"}),e.jsx(N,{title:"Reset",onClick:()=>{o({...n,genUuid:!1})},variant:"ghost",size:"icon",children:e.jsx(E,{})})]}):e.jsxs("div",{className:"flex items-center gap-1",children:[e.jsx(J,{control:c,placeholder:"NULL",name:`model.fields.${t}.options.default`,className:"flex-1"}),e.jsxs(pe,{children:[e.jsx(je,{asChild:!0,children:e.jsx(N,{title:"Options",variant:"ghost",size:"icon",children:e.jsx(ne,{})})}),e.jsx(he,{children:e.jsx(xe,{children:e.jsx(X,{onSelect:()=>{o({...n,genUuid:!0})},children:"Random UUID v4"})})})]})]});if(r==="dateTime"||r==="date"){const{defaultToNow:a,updatedAt:m}=n??{};return a??m?e.jsxs("div",{className:"flex items-center gap-1",children:[e.jsx(ge,{disabled:!0,value:m?"Last Updated":"Now",className:"flex-1"}),e.jsx(N,{title:"Reset",onClick:()=>{o({...n,defaultToNow:!1,updatedAt:!1})},variant:"ghost",size:"icon",children:e.jsx(E,{})})]}):e.jsxs("div",{className:"flex items-center space-x-1",children:[e.jsx(J,{placeholder:"NULL",control:c,name:`model.fields.${t}.options.default`,className:"flex-1"}),e.jsxs(pe,{children:[e.jsx(je,{asChild:!0,children:e.jsx(N,{title:"Options",variant:"ghost",size:"icon",children:e.jsx(ne,{})})}),e.jsx(he,{children:e.jsxs(xe,{children:[e.jsx(X,{onSelect:()=>{o({...n,defaultToNow:!0,updatedAt:!1})},children:"Now"}),e.jsx(X,{onSelect:()=>{o({...n,defaultToNow:!0,updatedAt:!0})},children:"Last Updated At"})]})})]})]})}if(r==="enum"&&n?.enumRef){const m=ei.byIdOrThrow(l,n.enumRef).values.map(d=>({label:d.friendlyName,value:d.id}));return e.jsxs("div",{className:"flex items-center space-x-1",children:[e.jsx(ii,{placeholder:"NULL",value:n.defaultEnumValueRef??null,onChange:d=>{o({...n,defaultEnumValueRef:d||void 0})},options:m,className:"flex-1"}),n.defaultEnumValueRef&&e.jsx(N,{title:"Reset",onClick:()=>{o({...n,defaultEnumValueRef:""})},variant:"ghost",size:"icon",children:e.jsx(E,{})})]})}return e.jsx("div",{})}const{SCALAR_FIELD_TYPES:oi}=await f("@baseplate-dev/project-builder-lib"),{useProjectDefinition:li}=await f("@baseplate-dev/project-builder-lib/web"),{ComboboxField:ai}=await f("@baseplate-dev/ui-components");function ri({control:c,idx:t}){const{definition:s}=li(),l=(s.enums??[]).map(p=>({label:p.name,value:`enum-${p.id}`,description:"Enum type"})),r=[...oi.filter(p=>p!=="enum").map(p=>Fe[p]),...l],{field:{value:n,onChange:o}}=I({name:`model.fields.${t}.type`,control:c}),{field:{value:i,onChange:a}}=I({name:`model.fields.${t}.options`,control:c}),m=p=>{if(p?.startsWith("enum-")){const x=p.replace("enum-","");a({enumRef:x}),o("enum")}else o(p)},d=i?.enumRef;return e.jsx("div",{className:"space-y-2",children:e.jsx(ai,{value:n==="enum"&&d?`enum-${d}`:n,onChange:m,options:r,renderItemLabel:p=>e.jsxs("div",{className:"flex flex-col",children:[e.jsx("div",{children:p.label}),e.jsx("div",{className:"text-xs text-muted-foreground",children:p.description})]})})})}const{modelUniqueConstraintEntityType:di}=await f("@baseplate-dev/project-builder-lib"),{Button:ve,DropdownMenu:ci,DropdownMenuContent:mi,DropdownMenuGroup:ui,DropdownMenuItem:F,DropdownMenuTrigger:fi,InputFieldController:pi,SwitchFieldController:hi,toast:xi}=await f("@baseplate-dev/ui-components"),{useState:q}=await f("react");function ji({className:c,control:t,idx:s,setValue:l,onRemove:r}){const n=g(j=>j.model.fields[s]),o=g(j=>j.model.relations),i=g(j=>j.model.primaryKeyFieldRefs),a=g(j=>j.model.uniqueConstraints)??[],m=i.includes(n.id),d=i.length>1,p=a.filter(j=>j.fields.some(R=>R.fieldRef===n.id)),x=o?.filter(j=>j.references.some(R=>R.localRef===n.id))??[],h=(()=>{if(x.length>0)return`Unable to remove field as it is being used in relations ${x.map(j=>j.name).join(", ")}`;if(m&&d)return"Unable to remove field as it is being used in in the primary key";if(a.some(j=>j.fields.some(R=>R.fieldRef===n.id)))return"Unable to remove field as it is being used in in a unique constraint"})();function D(){if(h){xi.error(h);return}r(s),m&&!d&&l("model.primaryKeyFieldRefs",[],{shouldDirty:!0})}const[b,v]=q(!1),[H,A]=q(!1),[L,S]=q(),[$,T]=q(!1),[W,P]=q();return e.jsxs("div",{className:w("items-center",c),children:[e.jsx("div",{children:e.jsx(pi,{control:t,name:`model.fields.${s}.name`})}),e.jsx("div",{children:e.jsx(ri,{control:t,idx:s})}),e.jsx("div",{children:e.jsx(hi,{control:t,name:`model.fields.${s}.isOptional`})}),e.jsx("div",{className:"mr-4",children:e.jsx(si,{control:t,idx:s,setValue:l})}),e.jsx("div",{children:e.jsx(Zn,{control:t,idx:s})}),e.jsx("div",{children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxs(ci,{children:[e.jsx(fi,{asChild:!0,children:e.jsx(ve,{variant:"ghost",size:"icon",children:e.jsx(ne,{})})}),e.jsx(mi,{children:e.jsxs(ui,{children:[x.length===0&&e.jsx(F,{onSelect:()=>{T(!0),P(void 0)},children:"Add Relation"}),x.length>0&&x.map(j=>e.jsxs(F,{onSelect:()=>{T(!0),P(j.id)},children:["Edit Relation ",x.length>1&&j.name]},j.id)),!d&&!m&&e.jsx(F,{onSelect:()=>{l("model.primaryKeyFieldRefs",[n.id],{shouldDirty:!0})},children:"Set as Primary Key"}),m&&e.jsx(F,{onSelect:()=>{v(!0)},children:"Edit Primary Key"}),p.length===0&&(d||!m)&&e.jsx(F,{onSelect:()=>{l("model.uniqueConstraints",[...a,{id:di.generateNewId(),fields:[{fieldRef:n.id}]}],{shouldDirty:!0})},children:"Make Unique"}),p.length>0&&p.map((j,R)=>e.jsxs(F,{onSelect:()=>{S(j.id),A(!0)},children:["Edit Unique Constraint"," ",p.length>1&&R+1]},j.id))]})})]}),e.jsx(we,{control:t,open:b,onOpenChange:v}),e.jsx(k,{control:t,open:H,onOpenChange:A,constraintId:L}),e.jsx(V,{control:t,open:$,onOpenChange:T,relationId:W,defaultFieldName:n.name}),e.jsx(ve,{variant:"ghost",onClick:()=>{D()},size:"icon",children:e.jsx(Ee,{})})]})})]})}function gi({className:c,control:t,setValue:s}){const{fields:l,remove:r,append:n,move:o}=qe({control:t,name:"model.fields"}),i="grid grid-cols-[repeat(2,minmax(130px,1fr))_60px_minmax(130px,1fr)_minmax(100px,1fr)_80px] gap-3",a=l.map((m,d)=>({id:m.id,element:e.jsx(ji,{className:i,control:t,setValue:s,idx:d,onRemove:r},m.id)}));return e.jsxs("div",{className:w("space-y-4",c),children:[l.length===0?e.jsx("p",{className:"pt-4 text-style-muted",children:"Add some fields to get started"}):e.jsxs("div",{className:"flex w-full flex-col gap-2 bg-white",children:[e.jsxs("div",{className:w(i,"sticky -top-0 z-10 bg-white py-2 text-sm font-semibold","pl-12"),children:[e.jsx("div",{children:"Name"}),e.jsx("div",{children:"Type"}),e.jsx("div",{children:"Optional"}),e.jsx("div",{children:"Default Value"}),e.jsx("div",{className:"sr-only",children:"Badges"}),e.jsx("div",{className:"sr-only",children:"Actions"})]}),e.jsx(Se,{listItems:a,sortItems:o})]}),e.jsx(_e,{appendField:n,setValue:s})]})}const{useProjectDefinition:vi}=await f("@baseplate-dev/project-builder-lib/web"),{Button:Z,RecordView:yi,RecordViewActions:bi,RecordViewItem:z,RecordViewItemList:Ci,SectionListSection:wi,SectionListSectionContent:Di,SectionListSectionDescription:Ri,SectionListSectionHeader:Si,SectionListSectionTitle:$i,useConfirmDialog:Ni}=await f("@baseplate-dev/ui-components");function Fi({control:c,setValue:t}){const{requestConfirm:s}=Ni(),{definitionContainer:l}=vi(),r=g(({model:i})=>i.relations??[]),n=g(({model:i})=>Object.fromEntries(i.fields.map(a=>[a.id,a.name])));function o(i){const a=r.find(m=>m.id===i);s({title:"Delete Relation",content:`Are you sure you want to delete the relation "${a?.name??"<invalid>"}"?`,onConfirm:()=>{t("model.relations",r.filter(m=>m.id!==i))}})}return e.jsxs(wi,{children:[e.jsxs(Si,{children:[e.jsx($i,{children:"Relations"}),e.jsx(Ri,{children:"Define relations to enforce uniqueness on one or more fields."})]}),e.jsxs(Di,{className:"space-y-4",children:[r.map(i=>e.jsxs(yi,{children:[e.jsxs(Ci,{children:[e.jsx(z,{title:"Name",children:i.name}),e.jsx(z,{title:"Local Field",children:i.references.map(a=>n[a.localRef]).join(", ")}),e.jsx(z,{title:"Foreign Model",children:l.nameFromId(i.modelRef)}),e.jsx(z,{title:"On Delete",children:i.onDelete})]}),e.jsxs(bi,{children:[e.jsx(V,{relationId:i.id,control:c,asChild:!0,children:e.jsx(Z,{variant:"ghost",size:"icon",title:"Edit",children:e.jsx(ye,{})})}),e.jsx(Z,{variant:"ghostDestructive",size:"icon",title:"Delete",onClick:()=>{o(i.id)},children:e.jsx(be,{})})]})]},i.id)),e.jsx(V,{control:c,asChild:!0,children:e.jsxs(Z,{variant:"secondary",size:"sm",children:[e.jsx(Ce,{}),"Add Relation"]})})]})]})}const{Button:ee,RecordView:Mi,RecordViewActions:Ii,RecordViewItem:Li,RecordViewItemList:Ti,SectionListSection:Oi,SectionListSectionContent:Ui,SectionListSectionDescription:Ei,SectionListSectionHeader:qi,SectionListSectionTitle:Ai,useConfirmDialog:Pi}=await f("@baseplate-dev/ui-components");function Bi({control:c,setValue:t}){const{requestConfirm:s}=Pi(),l=g(({model:o})=>o.uniqueConstraints??[]),r=g(({model:o})=>Object.fromEntries(o.fields.map(i=>[i.id,i.name])));function n(o){s({title:"Delete Unique Constraint",content:"Are you sure you want to delete this unique constraint?",onConfirm:()=>{t("model.uniqueConstraints",l.filter(i=>i.id!==o))}})}return e.jsxs(Oi,{children:[e.jsxs(qi,{children:[e.jsx(Ai,{children:"Unique Constraints"}),e.jsx(Ei,{children:"Define unique constraints to enforce uniqueness on one or more fields."})]}),e.jsxs(Ui,{className:"space-y-4",children:[l.map(o=>e.jsxs(Mi,{children:[e.jsx(Ti,{children:e.jsx(Li,{title:"Fields",children:o.fields.map(i=>r[i.fieldRef]??"<invalid>").join(", ")})}),e.jsxs(Ii,{children:[e.jsx(k,{constraintId:o.id,control:c,asChild:!0,children:e.jsx(ee,{variant:"ghost",size:"icon",title:"Edit",children:e.jsx(ye,{})})}),e.jsx(ee,{variant:"ghostDestructive",size:"icon",title:"Delete",onClick:()=>{n(o.id)},children:e.jsx(be,{})})]})]},o.id)),e.jsx(k,{control:c,asChild:!0,children:e.jsxs(ee,{variant:"secondary",size:"sm",children:[e.jsx(Ce,{}),"Add Unique Constraint"]})})]})]})}const{modelEntityType:Ki,modelLocalRelationEntityType:zi,modelScalarFieldEntityType:Vi}=await f("@baseplate-dev/project-builder-lib"),{useBlockUnsavedChangesNavigate:ki}=await f("@baseplate-dev/project-builder-lib/web"),{FormActionBar:Hi,SectionList:Wi}=await f("@baseplate-dev/ui-components");te(Ki,"/data/models/edit/{key}");te(Vi,"/data/models/edit/{parentKey}");te(zi,"/data/models/edit/{parentKey}");const tt=function(){const{key:t}=$e.useParams(),{form:s,onSubmit:l,originalModel:r}=Ie({omit:["name","featureRef"],modelKey:t}),{control:n,watch:o,getValues:i,setValue:a,reset:m}=s;return ki({control:n,reset:m,onSubmit:l}),e.jsx(Ne,{children:e.jsx(Me,{originalModel:r,getValues:i,watch:o,children:e.jsxs("form",{onSubmit:l,className:"max-w-7xl min-w-[700px] flex-1 space-y-4 px-4 pb-4",children:[e.jsx(gi,{control:n,setValue:a}),e.jsxs(Wi,{children:[e.jsx(Fi,{control:n,setValue:a}),e.jsx(Bi,{control:n,setValue:a})]}),e.jsx(Hi,{form:s})]})})})};export{tt as component};
|
|
2
|
+
//# sourceMappingURL=index-DDivWD4R.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-DDivWD4R.js","sources":["../../../../node_modules/.pnpm/es-toolkit@1.31.0/node_modules/es-toolkit/dist/string/camelCase.mjs","../../src/routes/data/models/edit.$key/-components/fields/model-add-field-button.tsx","../../src/routes/data/models/edit.$key/-components/fields/primary-key/model-primary-key-form.tsx","../../src/routes/data/models/edit.$key/-components/fields/primary-key/model-primary-key-dialog.tsx","../../src/routes/data/models/edit.$key/-components/fields/primary-key/model-primary-key-badge.tsx","../../src/routes/data/models/edit.$key/-components/fields/relations/model-relation-form.tsx","../../src/routes/data/models/edit.$key/-components/fields/relations/model-relation-dialog.tsx","../../src/routes/data/models/edit.$key/-components/fields/relations/model-relation-badge.tsx","../../src/routes/data/models/edit.$key/-components/fields/unique-constraints/model-unique-constraint-form.tsx","../../src/routes/data/models/edit.$key/-components/fields/unique-constraints/model-unique-constraint-dialog.tsx","../../src/routes/data/models/edit.$key/-components/fields/unique-constraints/model-unique-constraint-badge.tsx","../../src/routes/data/models/edit.$key/-components/fields/badges/model-field-badges.tsx","../../src/routes/data/models/edit.$key/-components/fields/model-field-default-value-input.tsx","../../src/routes/data/models/edit.$key/-components/fields/model-field-type-input.tsx","../../src/routes/data/models/edit.$key/-components/fields/model-field-form.tsx","../../src/routes/data/models/edit.$key/-components/fields/model-fields-form.tsx","../../src/routes/data/models/edit.$key/-components/model-relations-section.tsx","../../src/routes/data/models/edit.$key/-components/model-unique-constraints-section.tsx","../../src/routes/data/models/edit.$key/index.tsx?tsr-split=component"],"sourcesContent":["import { capitalize } from './capitalize.mjs';\nimport { words } from './words.mjs';\n\nfunction camelCase(str) {\n const words$1 = words(str);\n if (words$1.length === 0) {\n return '';\n }\n const [first, ...rest] = words$1;\n return `${first.toLowerCase()}${rest.map(word => capitalize(word)).join('')}`;\n}\n\nexport { camelCase };\n","import type {\n ModelConfigInput,\n ModelScalarFieldConfig,\n ModelScalarFieldConfigInput,\n} from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { UseFieldArrayAppend, UseFormSetValue } from 'react-hook-form';\n\nimport { modelScalarFieldEntityType } from '@baseplate-dev/project-builder-lib';\nimport {\n Button,\n ButtonGroup,\n DropdownMenu,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuTrigger,\n} from '@baseplate-dev/ui-components';\nimport { useMemo } from 'react';\nimport { MdExpandMore } from 'react-icons/md';\n\nimport { useEditedModelConfig } from '../../../-hooks/use-edited-model-config.js';\n\ninterface ModelAddFieldButtonProps {\n className?: string;\n appendField: UseFieldArrayAppend<ModelConfigInput, 'model.fields'>;\n setValue: UseFormSetValue<ModelConfigInput>;\n}\n\ninterface AutoAddField {\n name: string;\n fields: (Omit<ModelScalarFieldConfigInput, 'id'> & {\n isPrimaryKey?: boolean;\n })[];\n}\n\nexport function ModelAddFieldButton({\n className,\n appendField,\n setValue,\n}: ModelAddFieldButtonProps): React.JSX.Element {\n const fieldNames = useEditedModelConfig((model) =>\n model.model.fields.map((f) => f.name),\n );\n const primaryKeyFieldLength = useEditedModelConfig(\n (model) => model.model.primaryKeyFieldRefs.length,\n );\n const availableAutoFields = useMemo(() => {\n const autoFields: AutoAddField[] = [];\n if (!primaryKeyFieldLength) {\n autoFields.push({\n name: 'ID (uuid)',\n fields: [\n {\n name: 'id',\n type: 'uuid',\n options: {\n genUuid: true,\n },\n isPrimaryKey: true,\n },\n ],\n });\n }\n const hasCreatedAt = fieldNames.includes('createdAt');\n const hasUpdatedAt = fieldNames.includes('updatedAt');\n if (!hasCreatedAt || !hasUpdatedAt) {\n autoFields.push({\n name: 'Timestamps',\n fields: [\n {\n name: 'createdAt',\n type: 'dateTime',\n options: {\n defaultToNow: true,\n },\n },\n {\n name: 'updatedAt',\n type: 'dateTime',\n options: {\n updatedAt: true,\n defaultToNow: true,\n },\n },\n ],\n });\n }\n return autoFields;\n }, [fieldNames, primaryKeyFieldLength]);\n\n const applyAutoField = (autoField: AutoAddField): void => {\n for (const { isPrimaryKey, ...field } of autoField.fields) {\n const fieldId = modelScalarFieldEntityType.generateNewId();\n if (!fieldNames.includes(field.name)) {\n appendField({\n id: fieldId,\n ...field,\n });\n }\n if (isPrimaryKey) {\n setValue('model.primaryKeyFieldRefs', [fieldId], { shouldDirty: true });\n }\n }\n };\n return (\n <ButtonGroup className={className}>\n <Button\n variant=\"secondary\"\n onClick={() => {\n appendField({\n id: modelScalarFieldEntityType.generateNewId(),\n name: '',\n type: 'string',\n isOptional: true,\n options: {\n default: '',\n },\n } satisfies ModelScalarFieldConfig);\n }}\n size=\"sm\"\n >\n Add Field\n </Button>\n <DropdownMenu>\n <DropdownMenuTrigger\n disabled={availableAutoFields.length === 0}\n asChild\n >\n <Button variant=\"secondary\" size=\"sm\">\n <MdExpandMore />\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent>\n {availableAutoFields.map((field) => (\n <DropdownMenuItem\n key={field.name}\n onClick={() => {\n applyAutoField(field);\n }}\n >\n {field.name}\n </DropdownMenuItem>\n ))}\n </DropdownMenuContent>\n </DropdownMenu>\n </ButtonGroup>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport {\n Button,\n DialogClose,\n DialogFooter,\n MultiComboboxFieldController,\n} from '@baseplate-dev/ui-components';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport { clsx } from 'clsx';\nimport { useId } from 'react';\nimport { useController, useForm } from 'react-hook-form';\nimport { z } from 'zod';\n\nimport { useEditedModelConfig } from '../../../../-hooks/use-edited-model-config.js';\n\ninterface ModelPrimaryKeyFormProps {\n className?: string;\n control: Control<ModelConfigInput>;\n onSubmitSuccess?: () => void;\n}\n\nconst primaryKeychema = z.object({\n fields: z.array(z.string()).min(1, 'At least one primary key is required'),\n});\n\ntype FormValues = z.infer<typeof primaryKeychema>;\n\nexport function ModelPrimaryKeyForm({\n className,\n control: modelControl,\n onSubmitSuccess,\n}: ModelPrimaryKeyFormProps): React.JSX.Element {\n const fields = useEditedModelConfig((model) => model.model.fields);\n const {\n field: { value: modelValue = [], onChange: onModelChange },\n } = useController({\n name: 'model.primaryKeyFieldRefs',\n control: modelControl,\n });\n\n const { control, handleSubmit } = useForm<FormValues>({\n resolver: zodResolver(primaryKeychema),\n values: { fields: modelValue },\n });\n\n const onSubmit = handleSubmit((data) => {\n onModelChange(data.fields);\n onSubmitSuccess?.();\n });\n\n const formId = useId();\n\n return (\n <form\n className={clsx('space-y-4', className)}\n onSubmit={(e) => {\n e.stopPropagation();\n return onSubmit(e);\n }}\n id={formId}\n >\n <MultiComboboxFieldController\n control={control}\n name=\"fields\"\n options={fields.map((f) => ({ value: f.id, label: f.name }))}\n placeholder=\"Select fields to use as primary keys\"\n />\n <DialogFooter>\n <DialogClose asChild>\n <Button variant=\"secondary\">Cancel</Button>\n </DialogClose>\n <Button type=\"submit\" form={formId}>\n Save\n </Button>\n </DialogFooter>\n </form>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogHeader,\n DialogTitle,\n DialogTrigger,\n useControlledState,\n} from '@baseplate-dev/ui-components';\n\nimport { ModelPrimaryKeyForm } from './model-primary-key-form.js';\n\ninterface ModelPrimaryKeyDialogProps {\n control: Control<ModelConfigInput>;\n asChild?: boolean;\n open?: boolean;\n onOpenChange?: (isOpen: boolean) => void;\n children?: React.ReactNode;\n}\n\nexport function ModelPrimaryKeyDialog({\n control,\n children,\n asChild,\n open,\n onOpenChange,\n}: ModelPrimaryKeyDialogProps): React.JSX.Element {\n const [isOpen, setIsOpen] = useControlledState(open, onOpenChange, false);\n return (\n <Dialog open={isOpen} onOpenChange={setIsOpen}>\n {children && <DialogTrigger asChild={asChild}>{children}</DialogTrigger>}\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Primary Keys</DialogTitle>\n <DialogDescription>\n Select the fields that will be used as the primary key for this\n model\n </DialogDescription>\n </DialogHeader>\n <ModelPrimaryKeyForm\n control={control}\n onSubmitSuccess={() => {\n setIsOpen(false);\n }}\n />\n </DialogContent>\n </Dialog>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport { BadgeWithIcon } from '@baseplate-dev/ui-components';\nimport { useState } from 'react';\nimport { MdKey } from 'react-icons/md';\n\nimport { ModelPrimaryKeyDialog } from './model-primary-key-dialog.js';\n\ninterface ModelPrimaryKeyBadgeProps {\n className?: string;\n control: Control<ModelConfigInput>;\n autoCollapse?: boolean;\n}\n\nexport function ModelPrimaryKeyBadge({\n className,\n control,\n autoCollapse,\n}: ModelPrimaryKeyBadgeProps): React.JSX.Element {\n const [isHovered, setIsHovered] = useState(false);\n const shouldShowText = !autoCollapse || isHovered;\n return (\n <ModelPrimaryKeyDialog control={control}>\n <BadgeWithIcon\n icon={MdKey}\n variant=\"secondary\"\n className={className}\n onMouseEnter={() => {\n setIsHovered(true);\n }}\n onMouseLeave={() => {\n setIsHovered(false);\n }}\n aria-label=\"Primary Key\"\n title=\"Primary Key\"\n >\n {shouldShowText && 'Primary'}\n </BadgeWithIcon>\n </ModelPrimaryKeyDialog>\n );\n}\n","import type {\n ModelConfig,\n ModelConfigInput,\n ModelRelationFieldConfig,\n ModelRelationFieldConfigInput,\n ProjectDefinition,\n} from '@baseplate-dev/project-builder-lib';\nimport type { Control } from 'react-hook-form';\n\nimport {\n createModelRelationFieldSchema,\n ModelFieldUtils,\n modelForeignRelationEntityType,\n modelLocalRelationEntityType,\n ModelUtils,\n} from '@baseplate-dev/project-builder-lib';\nimport {\n useDefinitionSchema,\n useProjectDefinition,\n} from '@baseplate-dev/project-builder-lib/web';\nimport {\n Button,\n ComboboxField,\n ComboboxFieldController,\n DialogClose,\n DialogFooter,\n InputFieldController,\n SelectFieldController,\n toast,\n} from '@baseplate-dev/ui-components';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport { clsx } from 'clsx';\nimport { camelCase } from 'es-toolkit';\nimport { pluralize } from 'inflection';\nimport React, { useId, useMemo } from 'react';\nimport { useController, useForm } from 'react-hook-form';\n\nimport { useEditedModelConfig } from '../../../../-hooks/use-edited-model-config.js';\n\ninterface ModelRelationFormProps {\n className?: string;\n control: Control<ModelConfigInput>;\n onSubmitSuccess?: () => void;\n relationId?: string;\n defaultFieldName?: string;\n}\n\n/**\n * Tries to guess the model type from the field name\n */\nfunction guessModelTypeFromFieldName(\n definition: ProjectDefinition,\n editedModel: ModelConfigInput,\n fieldName: string | undefined,\n): string | undefined {\n if (!fieldName) return;\n\n const name = fieldName.replace(/Id$/, '');\n\n const tryFindModel = (\n condition: (m: ModelConfig) => boolean,\n ): string | undefined =>\n definition.models.find((m) => m.id !== editedModel.id && condition(m))?.id;\n\n // try to find a model with the exact name first\n const modelWithName = tryFindModel(\n (m) => m.name.toLowerCase() === name.toLowerCase(),\n );\n if (modelWithName) return modelWithName;\n\n // try to find a model with the same feature and a similar name\n const modelWithFeature = tryFindModel(\n (m) =>\n m.featureRef === m.featureRef &&\n m.name.toLowerCase().includes(name.toLowerCase()),\n );\n if (modelWithFeature) return modelWithFeature;\n\n // try to find a model with a similar name\n const modelWithSimilarName = tryFindModel((m) =>\n m.name.toLowerCase().includes(name.toLowerCase()),\n );\n return modelWithSimilarName;\n}\n\n/**\n * Tries to guess the default values for a relation field based on the model\n */\nfunction getRelationDefaultsFromModel(\n definition: ProjectDefinition,\n editedModel: ModelConfigInput,\n editedRelation: Partial<ModelRelationFieldConfigInput>,\n defaultFieldName?: string,\n): Pick<\n ModelRelationFieldConfig,\n 'foreignRelationName' | 'name' | 'references'\n> {\n // default the name to the local field name if it ends with Id\n const name = (() => {\n if (editedRelation.name) return editedRelation.name;\n if (editedRelation.modelRef) {\n const model = ModelUtils.byIdOrThrow(definition, editedRelation.modelRef);\n return camelCase(model.name);\n }\n return;\n })();\n\n const references = (() => {\n if (!editedRelation.modelRef) return;\n const {\n model: { fields, primaryKeyFieldRefs },\n name: foreignName,\n } = ModelUtils.byIdOrThrow(definition, editedRelation.modelRef);\n const primaryKeys = fields.filter((f) =>\n primaryKeyFieldRefs.includes(f.id),\n );\n const existingReferences = editedRelation.references ?? [];\n return primaryKeys.map((primaryKey, i) => {\n const bestGuessLocalName = (() => {\n if (i === 0 && defaultFieldName) return defaultFieldName;\n if (primaryKeys.length === 1) return `${camelCase(foreignName)}Id`;\n return primaryKey.name;\n })();\n const bestGuessLocal =\n existingReferences[i]?.localRef ??\n editedModel.model.fields.find((f) => f.name === bestGuessLocalName)?.id;\n return {\n localRef: bestGuessLocal,\n foreignRef: primaryKey.id,\n };\n });\n })();\n\n const foreignRelationName = (() => {\n if (!references) return;\n if (editedRelation.foreignRelationName) {\n return editedRelation.foreignRelationName;\n }\n const isOneToOne =\n references.every((ref) => ref.localRef) &&\n ModelFieldUtils.areScalarsUnique(\n editedModel,\n references.map((r) => r.localRef),\n );\n return camelCase(\n isOneToOne ? editedModel.name : pluralize(editedModel.name),\n );\n })();\n\n return {\n name: name ?? '',\n foreignRelationName: foreignRelationName ?? '',\n references: references ?? [],\n };\n}\n\nexport function ModelRelationForm({\n className,\n control: modelControl,\n onSubmitSuccess,\n relationId,\n defaultFieldName,\n}: ModelRelationFormProps): React.JSX.Element {\n const { definition } = useProjectDefinition();\n const editedModel = useEditedModelConfig((model) => model);\n const modelName = editedModel.name;\n const { fields } = editedModel.model;\n const {\n field: { value: modelRelations = [], onChange: onModelRelationsChange },\n } = useController({\n name: `model.relations`,\n control: modelControl,\n });\n\n const foreignModelOptions = definition.models.map((type) => ({\n label: type.name,\n value: type.id,\n }));\n\n const modelRelation =\n relationId === undefined\n ? undefined\n : modelRelations.find((item) => item.id === relationId);\n\n const defaultValues = useMemo((): ModelRelationFieldConfigInput => {\n if (modelRelation) return modelRelation;\n const modelRef = guessModelTypeFromFieldName(\n definition,\n editedModel,\n defaultFieldName,\n );\n return {\n id: modelLocalRelationEntityType.generateNewId(),\n foreignId: modelForeignRelationEntityType.generateNewId(),\n modelRef: modelRef ?? '',\n onDelete: 'Restrict',\n onUpdate: 'Restrict',\n ...getRelationDefaultsFromModel(\n definition,\n editedModel,\n {\n modelRef,\n },\n defaultFieldName,\n ),\n };\n }, [modelRelation, defaultFieldName, definition, editedModel]);\n\n const modelRelationFieldSchema = useDefinitionSchema(\n createModelRelationFieldSchema,\n );\n\n const { control, handleSubmit, setError, watch, setValue } = useForm({\n resolver: zodResolver(modelRelationFieldSchema),\n defaultValues,\n });\n\n const relation = watch();\n\n const foreignModel = relation.modelRef\n ? definition.models.find((m) => m.id === relation.modelRef)\n : undefined;\n\n const foreignFields = foreignModel?.model.fields;\n\n const localFieldOptions = fields.map((f) => ({\n label: f.name,\n value: f.id,\n }));\n\n const foreignFieldOptions =\n foreignFields?.map((f) => ({\n label: f.name,\n value: f.id,\n })) ?? [];\n\n const isRelationOptional = relation.references.some(\n (ref) => fields.find((f) => f.id === ref.localRef)?.isOptional,\n );\n\n const onDelete = (): void => {\n onModelRelationsChange(\n modelRelations.filter((relation) => relation.id !== relationId),\n );\n onSubmitSuccess?.();\n };\n\n const onSubmit = handleSubmit((data): void => {\n const { id } = data;\n\n if (\n fields.some((field) => field.name === data.name) ||\n modelRelations.some(\n (relation) => relation.name === data.name && relation.id !== data.id,\n )\n ) {\n setError('name', {\n message:\n 'The relation name cannot be the same as a field/relation name',\n });\n return;\n }\n\n // look for duplicate local fields\n const localFields = data.references.map((ref) => ref.localRef);\n if (new Set(localFields).size !== localFields.length) {\n toast.error('Local fields must be unique');\n return;\n }\n\n const foreignFields = data.references.map((ref) => ref.foreignRef);\n if (new Set(foreignFields).size !== foreignFields.length) {\n toast.error('Foreign fields must be unique');\n return;\n }\n\n // replace the existing relation with the new one if it exists\n if (modelRelations.some((relation) => relation.id === id)) {\n onModelRelationsChange(\n modelRelations.map((relation) =>\n relation.id === id ? data : relation,\n ),\n );\n } else {\n onModelRelationsChange([...modelRelations, data]);\n }\n onSubmitSuccess?.();\n });\n\n const formId = useId();\n\n const hasSelectedForeignModel = !!foreignModel;\n\n return (\n <form\n className={clsx('space-y-4', className)}\n onSubmit={(e) => {\n e.stopPropagation();\n return onSubmit(e);\n }}\n id={formId}\n >\n <div className=\"grid grid-cols-2 gap-x-8 gap-y-2\">\n <ComboboxField\n options={[{ label: modelName, value: modelName }]}\n value={modelName}\n disabled\n label=\"Local Model\"\n />\n <ComboboxFieldController\n control={control}\n name=\"modelRef\"\n options={foreignModelOptions}\n label=\"Foreign Model\"\n onChange={(value) => {\n if (!value) return;\n const { foreignRelationName, name, references } =\n getRelationDefaultsFromModel(\n definition,\n editedModel,\n {\n ...relation,\n modelRef: value,\n },\n defaultFieldName,\n );\n if (foreignRelationName) {\n setValue('foreignRelationName', foreignRelationName);\n }\n if (name) {\n setValue('name', name);\n }\n setValue('references', references);\n }}\n />\n </div>\n <div\n className={clsx(\n 'grid grid-cols-2 gap-x-8 gap-y-2',\n !hasSelectedForeignModel && 'pointer-events-none opacity-50',\n )}\n >\n <InputFieldController\n control={control}\n disabled={!hasSelectedForeignModel}\n name=\"name\"\n label=\"Local Relation Name\"\n description={\n <span>\n Name of the relation, e.g. {camelCase(modelName)}.\n <strong>\n {foreignModel?.name ? camelCase(foreignModel.name) : 'user'}\n </strong>\n </span>\n }\n />\n <InputFieldController\n control={control}\n disabled={!hasSelectedForeignModel}\n name=\"foreignRelationName\"\n label=\"Foreign Relation Name\"\n description={\n <span>\n Name of the relation on the foreign model, e.g.{' '}\n {camelCase(foreignModel?.name ?? 'post')}.\n <strong>{defaultValues.foreignRelationName || 'user'}</strong>\n </span>\n }\n />\n <div className=\"text-sm font-medium\">Local Field</div>\n <div className=\"text-sm font-medium\">Foreign Field</div>\n {relation.references.map((_, i) => (\n <React.Fragment key={i}>\n <ComboboxFieldController\n disabled={!hasSelectedForeignModel}\n control={control}\n name={`references.${i}.localRef`}\n options={localFieldOptions}\n />\n <ComboboxFieldController\n control={control}\n name={`references.${i}.foreignRef`}\n options={foreignFieldOptions}\n disabled\n />\n </React.Fragment>\n ))}\n </div>\n <div className=\"grid grid-cols-2 gap-x-8 gap-y-2 border-t pt-4\">\n <SelectFieldController\n label=\"On Delete\"\n control={control}\n options={[\n { label: 'Cascade (delete entire local row)', value: 'Cascade' },\n { label: 'Restrict (throw error)', value: 'Restrict' },\n ...(isRelationOptional\n ? [\n {\n label: 'Set Null (set local field to null)',\n value: 'SetNull',\n },\n ]\n : []),\n ]}\n name=\"onDelete\"\n description=\"What to do when the foreign row is deleted\"\n />\n </div>\n <DialogFooter>\n <div className=\"flex w-full justify-between\">\n {relationId && (\n <Button\n variant=\"secondary\"\n onClick={(e) => {\n e.preventDefault();\n onDelete();\n }}\n >\n Delete\n </Button>\n )}\n <div className=\"flex gap-4\">\n <DialogClose asChild>\n <Button variant=\"secondary\">Cancel</Button>\n </DialogClose>\n <Button\n type=\"submit\"\n form={formId}\n disabled={!hasSelectedForeignModel}\n >\n Save\n </Button>\n </div>\n </div>\n </DialogFooter>\n </form>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogHeader,\n DialogTitle,\n DialogTrigger,\n useControlledState,\n} from '@baseplate-dev/ui-components';\n\nimport { ModelRelationForm } from './model-relation-form.js';\n\ninterface ModelRelationDialogProps {\n control: Control<ModelConfigInput>;\n asChild?: boolean;\n open?: boolean;\n onOpenChange?: (isOpen: boolean) => void;\n children?: React.ReactNode;\n relationId?: string;\n defaultFieldName?: string;\n}\n\nexport function ModelRelationDialog({\n control,\n children,\n asChild,\n open,\n onOpenChange,\n relationId,\n defaultFieldName,\n}: ModelRelationDialogProps): React.JSX.Element {\n const [isOpen, setIsOpen] = useControlledState(open, onOpenChange, false);\n return (\n <Dialog open={isOpen} onOpenChange={setIsOpen}>\n {children && <DialogTrigger asChild={asChild}>{children}</DialogTrigger>}\n <DialogContent width=\"lg\">\n <DialogHeader>\n <DialogTitle>\n {relationId ? 'Edit Relation' : 'Create Relation'}\n </DialogTitle>\n <DialogDescription>\n Set up the relation between this model and another model\n </DialogDescription>\n </DialogHeader>\n <ModelRelationForm\n control={control}\n onSubmitSuccess={() => {\n setIsOpen(false);\n }}\n relationId={relationId}\n defaultFieldName={defaultFieldName}\n />\n </DialogContent>\n </Dialog>\n );\n}\n","import type {\n ModelConfigInput,\n ModelRelationFieldConfigInput,\n} from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport { useProjectDefinition } from '@baseplate-dev/project-builder-lib/web';\nimport { BadgeWithIcon } from '@baseplate-dev/ui-components';\nimport clsx from 'clsx';\nimport { useState } from 'react';\nimport { MdLink } from 'react-icons/md';\n\nimport { ModelRelationDialog } from './model-relation-dialog.js';\n\ninterface ModelRelationBadgeProps {\n className?: string;\n control: Control<ModelConfigInput>;\n relation: ModelRelationFieldConfigInput;\n autoCollapse?: boolean;\n}\n\nexport function ModelRelationsBadge({\n className,\n control,\n relation,\n autoCollapse,\n}: ModelRelationBadgeProps): React.JSX.Element {\n const { definitionContainer } = useProjectDefinition();\n const [isHovered, setIsHovered] = useState(false);\n const shouldShowText = !autoCollapse || isHovered;\n return (\n <ModelRelationDialog control={control} relationId={relation.id}>\n <BadgeWithIcon\n icon={MdLink}\n variant=\"secondary\"\n className={clsx('max-w-[100px]', className)}\n onMouseEnter={() => {\n setIsHovered(true);\n }}\n onMouseLeave={() => {\n setIsHovered(false);\n }}\n aria-label=\"Relation\"\n title=\"Relation\"\n >\n {shouldShowText &&\n `${definitionContainer.nameFromId(relation.modelRef)} ${\n relation.references.length > 1\n ? `(${relation.references.length})`\n : ''\n }`}\n </BadgeWithIcon>\n </ModelRelationDialog>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport { modelUniqueConstraintEntityType } from '@baseplate-dev/project-builder-lib';\nimport {\n Button,\n DialogClose,\n DialogFooter,\n MultiComboboxFieldController,\n} from '@baseplate-dev/ui-components';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport { clsx } from 'clsx';\nimport { useId } from 'react';\nimport { useController, useForm } from 'react-hook-form';\nimport { z } from 'zod';\n\nimport { useEditedModelConfig } from '../../../../-hooks/use-edited-model-config.js';\n\ninterface ModelUniqueConstraintFormProps {\n className?: string;\n control: Control<ModelConfigInput>;\n onSubmitSuccess?: () => void;\n constraintId?: string;\n}\n\nconst formSchema = z.object({\n id: z.string().optional(),\n fields: z.array(z.string()).min(1, 'At least one field is required'),\n});\n\ntype FormValues = z.infer<typeof formSchema>;\n\nexport function ModelUniqueConstraintForm({\n className,\n control: modelControl,\n onSubmitSuccess,\n constraintId,\n}: ModelUniqueConstraintFormProps): React.JSX.Element {\n const fields = useEditedModelConfig((model) => model.model.fields);\n const {\n field: { value: modelValue = [], onChange: onModelChange },\n } = useController({\n name: `model.uniqueConstraints`,\n control: modelControl,\n });\n\n const modelUniqueConstraint =\n constraintId === undefined\n ? undefined\n : modelValue.find((uc) => uc.id === constraintId);\n\n const { control, handleSubmit } = useForm<FormValues>({\n resolver: zodResolver(formSchema),\n values: modelUniqueConstraint\n ? {\n id: modelUniqueConstraint.id,\n fields: modelUniqueConstraint.fields.map((f) => f.fieldRef),\n }\n : { fields: [] },\n });\n\n const onDelete = (): void => {\n onModelChange(modelValue.filter((uc) => uc.id !== constraintId));\n onSubmitSuccess?.();\n };\n\n const onSubmit = handleSubmit((data) => {\n const dataWithId = {\n id: data.id ?? modelUniqueConstraintEntityType.generateNewId(),\n fields: data.fields.map((fieldRef) => ({\n fieldRef,\n })),\n };\n const { id } = dataWithId;\n // replace the existing unique constraint with the new one if it exists\n if (modelValue.some((uc) => uc.id === id)) {\n onModelChange(modelValue.map((uc) => (uc.id === id ? dataWithId : uc)));\n } else {\n onModelChange([...modelValue, dataWithId]);\n }\n onSubmitSuccess?.();\n });\n\n const formId = useId();\n\n return (\n <form\n className={clsx('space-y-4', className)}\n onSubmit={(e) => {\n e.stopPropagation();\n return onSubmit(e);\n }}\n id={formId}\n >\n <MultiComboboxFieldController\n control={control}\n name=\"fields\"\n options={fields.map((f) => ({ value: f.id, label: f.name }))}\n placeholder=\"Select fields to use as primary keys\"\n />\n <DialogFooter>\n <div className=\"flex w-full justify-between\">\n {constraintId && (\n <Button\n variant=\"secondary\"\n onClick={(e) => {\n e.preventDefault();\n onDelete();\n }}\n >\n Delete\n </Button>\n )}\n <div className=\"flex gap-4\">\n <DialogClose asChild>\n <Button variant=\"secondary\">Cancel</Button>\n </DialogClose>\n <Button type=\"submit\" form={formId}>\n Save\n </Button>\n </div>\n </div>\n </DialogFooter>\n </form>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogHeader,\n DialogTitle,\n DialogTrigger,\n useControlledState,\n} from '@baseplate-dev/ui-components';\n\nimport { ModelUniqueConstraintForm } from './model-unique-constraint-form.js';\n\ninterface ModelUniqueConstraintDialogProps {\n control: Control<ModelConfigInput>;\n asChild?: boolean;\n open?: boolean;\n onOpenChange?: (isOpen: boolean) => void;\n children?: React.ReactNode;\n constraintId?: string;\n}\n\nexport function ModelUniqueConstraintDialog({\n control,\n children,\n asChild,\n open,\n onOpenChange,\n constraintId,\n}: ModelUniqueConstraintDialogProps): React.JSX.Element {\n const [isOpen, setIsOpen] = useControlledState(open, onOpenChange, false);\n return (\n <Dialog open={isOpen} onOpenChange={setIsOpen}>\n {children && <DialogTrigger asChild={asChild}>{children}</DialogTrigger>}\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Unique Constraint</DialogTitle>\n <DialogDescription>\n Select the fields that will be part of this unique constraint.\n </DialogDescription>\n </DialogHeader>\n <ModelUniqueConstraintForm\n control={control}\n onSubmitSuccess={() => {\n setIsOpen(false);\n }}\n constraintId={constraintId}\n />\n </DialogContent>\n </Dialog>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport { BadgeWithIcon } from '@baseplate-dev/ui-components';\nimport { clsx } from 'clsx';\nimport { useState } from 'react';\nimport { MdStar } from 'react-icons/md';\n\nimport { useEditedModelConfig } from '../../../../-hooks/use-edited-model-config.js';\nimport { ModelUniqueConstraintDialog } from './model-unique-constraint-dialog.js';\n\ninterface ModelFieldUniqueBadgeProps {\n className?: string;\n control: Control<ModelConfigInput>;\n constraintId: string;\n autoCollapse?: boolean;\n}\n\nexport function ModelFieldUniqueBadge({\n className,\n control,\n constraintId,\n autoCollapse,\n}: ModelFieldUniqueBadgeProps): React.JSX.Element {\n const [isHovered, setIsHovered] = useState(false);\n const shouldShowText = !autoCollapse || isHovered;\n const fieldsLength = useEditedModelConfig(\n (model) =>\n model.model.uniqueConstraints?.find((uc) => uc.id === constraintId)\n ?.fields.length ?? 0,\n );\n return (\n <ModelUniqueConstraintDialog control={control} constraintId={constraintId}>\n <BadgeWithIcon\n variant=\"secondary\"\n icon={MdStar}\n className={clsx('', className)}\n onMouseEnter={() => {\n setIsHovered(true);\n }}\n onMouseLeave={() => {\n setIsHovered(false);\n }}\n aria-label=\"Unique Constraint\"\n title=\"Unique Constraint\"\n >\n {shouldShowText &&\n `Unique ${fieldsLength > 1 ? `(${fieldsLength})` : ''}`}\n </BadgeWithIcon>\n </ModelUniqueConstraintDialog>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport { clsx } from 'clsx';\n\nimport { useEditedModelConfig } from '../../../../-hooks/use-edited-model-config.js';\nimport { ModelPrimaryKeyBadge } from '../primary-key/model-primary-key-badge.js';\nimport { ModelRelationsBadge } from '../relations/model-relation-badge.js';\nimport { ModelFieldUniqueBadge } from '../unique-constraints/model-unique-constraint-badge.js';\n\ninterface ModelFieldBadgesProps {\n className?: string;\n control: Control<ModelConfigInput>;\n idx: number;\n}\n\nexport function ModelFieldBadges({\n className,\n control,\n idx,\n}: ModelFieldBadgesProps): React.JSX.Element {\n const field = useEditedModelConfig((model) => model.model.fields[idx]);\n const isPrimary = useEditedModelConfig((model) =>\n model.model.primaryKeyFieldRefs.includes(field.id),\n );\n const uniqueConstraints = useEditedModelConfig(\n (model) =>\n model.model.uniqueConstraints\n ?.filter((constraint) =>\n constraint.fields.some((f) => f.fieldRef === field.id),\n )\n .map((uc) => uc.id) ?? [],\n );\n const modelFieldRelations = useEditedModelConfig(({ model }) => {\n const field = model.fields[idx];\n return (\n model.relations?.filter((r) =>\n r.references.some((ref) => ref.localRef === field.id),\n ) ?? []\n );\n });\n\n const totalBadges =\n (isPrimary ? 1 : 0) + uniqueConstraints.length + modelFieldRelations.length;\n const autoCollapse = totalBadges > 2;\n\n const badges = [\n isPrimary && (\n <ModelPrimaryKeyBadge\n key={'primary'}\n control={control}\n autoCollapse={autoCollapse}\n />\n ),\n ...uniqueConstraints.map((uc) => (\n <ModelFieldUniqueBadge\n key={uc}\n control={control}\n constraintId={uc}\n autoCollapse={autoCollapse}\n />\n )),\n ...modelFieldRelations.map((relation) => (\n <ModelRelationsBadge\n key={relation.id}\n control={control}\n relation={relation}\n autoCollapse={autoCollapse}\n />\n )),\n ];\n\n return <div className={clsx('flex gap-4', className)}>{badges}</div>;\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control, UseFormSetValue } from 'react-hook-form';\n\nimport { EnumUtils } from '@baseplate-dev/project-builder-lib';\nimport { useProjectDefinition } from '@baseplate-dev/project-builder-lib/web';\nimport {\n Button,\n ComboboxField,\n DropdownMenu,\n DropdownMenuContent,\n DropdownMenuGroup,\n DropdownMenuItem,\n DropdownMenuTrigger,\n InputField,\n InputFieldController,\n SelectFieldController,\n} from '@baseplate-dev/ui-components';\nimport { useController, useWatch } from 'react-hook-form';\nimport { HiDotsVertical, HiOutlineX } from 'react-icons/hi';\n\ninterface ModelFieldDefaultValueInputProps {\n control: Control<ModelConfigInput>;\n setValue: UseFormSetValue<ModelConfigInput>;\n idx: number;\n}\n\nexport function ModelFieldDefaultValueInput({\n control,\n idx,\n setValue,\n}: ModelFieldDefaultValueInputProps): React.JSX.Element {\n const { definition } = useProjectDefinition();\n const type = useWatch({\n control,\n name: `model.fields.${idx}.type`,\n });\n\n const {\n field: { value: optionsValue, onChange: onOptionsChange },\n } = useController({\n name: `model.fields.${idx}.options`,\n control,\n });\n\n const defaultValue = useWatch({\n control,\n name: `model.fields.${idx}.options.default`,\n });\n\n if (type === 'boolean') {\n return (\n <div className=\"flex items-center gap-1\">\n <SelectFieldController\n control={control}\n className=\"flex-1\"\n name={`model.fields.${idx}.options.default`}\n options={[\n { label: 'True', value: 'true' },\n { label: 'False', value: 'false' },\n ]}\n placeholder=\"NULL\"\n />\n {defaultValue && (\n <Button\n title=\"Reset\"\n onClick={() => {\n setValue(`model.fields.${idx}.options.default`, '', {\n shouldDirty: true,\n });\n }}\n variant=\"ghost\"\n size=\"icon\"\n >\n <HiOutlineX />\n </Button>\n )}\n </div>\n );\n }\n\n if (['string', 'int', 'float'].includes(type)) {\n return (\n <div className=\"flex items-center gap-1\">\n <InputFieldController\n control={control}\n placeholder=\"NULL\"\n name={`model.fields.${idx}.options.default`}\n className=\"flex-1\"\n />\n {defaultValue && (\n <Button\n title=\"Reset\"\n onClick={() => {\n setValue(`model.fields.${idx}.options.default`, undefined, {\n shouldDirty: true,\n });\n }}\n variant=\"ghost\"\n size=\"icon\"\n >\n <HiOutlineX />\n </Button>\n )}\n </div>\n );\n }\n\n if (type === 'uuid') {\n if (optionsValue?.genUuid) {\n return (\n <div className=\"flex items-center gap-1\">\n <InputField disabled value=\"Random UUID v4\" className=\"flex-1\" />\n <Button\n title=\"Reset\"\n onClick={() => {\n onOptionsChange({ ...optionsValue, genUuid: false });\n }}\n variant=\"ghost\"\n size=\"icon\"\n >\n <HiOutlineX />\n </Button>\n </div>\n );\n }\n return (\n <div className=\"flex items-center gap-1\">\n <InputFieldController\n control={control}\n placeholder=\"NULL\"\n name={`model.fields.${idx}.options.default`}\n className=\"flex-1\"\n />\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button title=\"Options\" variant=\"ghost\" size=\"icon\">\n <HiDotsVertical />\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuGroup>\n <DropdownMenuItem\n onSelect={() => {\n onOptionsChange({\n ...optionsValue,\n genUuid: true,\n });\n }}\n >\n Random UUID v4\n </DropdownMenuItem>\n </DropdownMenuGroup>\n </DropdownMenuContent>\n </DropdownMenu>\n </div>\n );\n }\n\n if (type === 'dateTime' || type === 'date') {\n const { defaultToNow, updatedAt } = optionsValue ?? {};\n\n if (defaultToNow ?? updatedAt) {\n return (\n <div className=\"flex items-center gap-1\">\n <InputField\n disabled\n value={updatedAt ? 'Last Updated' : 'Now'}\n className=\"flex-1\"\n />\n <Button\n title=\"Reset\"\n onClick={() => {\n onOptionsChange({\n ...optionsValue,\n defaultToNow: false,\n updatedAt: false,\n });\n }}\n variant=\"ghost\"\n size=\"icon\"\n >\n <HiOutlineX />\n </Button>\n </div>\n );\n }\n return (\n <div className=\"flex items-center space-x-1\">\n <InputFieldController\n placeholder=\"NULL\"\n control={control}\n name={`model.fields.${idx}.options.default`}\n className=\"flex-1\"\n />\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button title=\"Options\" variant=\"ghost\" size=\"icon\">\n <HiDotsVertical />\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuGroup>\n <DropdownMenuItem\n onSelect={() => {\n onOptionsChange({\n ...optionsValue,\n defaultToNow: true,\n updatedAt: false,\n });\n }}\n >\n Now\n </DropdownMenuItem>\n <DropdownMenuItem\n onSelect={() => {\n onOptionsChange({\n ...optionsValue,\n defaultToNow: true,\n updatedAt: true,\n });\n }}\n >\n Last Updated At\n </DropdownMenuItem>\n </DropdownMenuGroup>\n </DropdownMenuContent>\n </DropdownMenu>\n </div>\n );\n }\n\n if (type === 'enum' && optionsValue?.enumRef) {\n const fieldEnum = EnumUtils.byIdOrThrow(definition, optionsValue.enumRef);\n const enumValues = fieldEnum.values.map((v) => ({\n label: v.friendlyName,\n value: v.id,\n }));\n return (\n <div className=\"flex items-center space-x-1\">\n <ComboboxField\n placeholder=\"NULL\"\n value={optionsValue.defaultEnumValueRef ?? null}\n onChange={(value) => {\n onOptionsChange({\n ...optionsValue,\n defaultEnumValueRef: value ? value : undefined,\n });\n }}\n options={enumValues}\n className=\"flex-1\"\n />\n {optionsValue.defaultEnumValueRef && (\n <Button\n title=\"Reset\"\n onClick={() => {\n onOptionsChange({\n ...optionsValue,\n defaultEnumValueRef: '',\n });\n }}\n variant=\"ghost\"\n size=\"icon\"\n >\n <HiOutlineX />\n </Button>\n )}\n </div>\n );\n }\n\n return <div />;\n}\n","import type {\n ModelConfigInput,\n ScalarFieldType,\n} from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control } from 'react-hook-form';\n\nimport { SCALAR_FIELD_TYPES } from '@baseplate-dev/project-builder-lib';\nimport { useProjectDefinition } from '@baseplate-dev/project-builder-lib/web';\nimport { ComboboxField } from '@baseplate-dev/ui-components';\nimport { useController } from 'react-hook-form';\n\nimport type { ScalarFieldTypeOption } from '../../../-constants.js';\n\nimport { SCALAR_FIELD_TYPE_OPTIONS } from '../../../-constants.js';\n\ninterface ModelFieldTypeInputProps {\n control: Control<ModelConfigInput>;\n idx: number;\n}\n\nexport function ModelFieldTypeInput({\n control,\n idx,\n}: ModelFieldTypeInputProps): React.JSX.Element {\n const { definition } = useProjectDefinition();\n\n const enumOptions: ScalarFieldTypeOption[] = (definition.enums ?? []).map(\n (config) => ({\n label: config.name,\n value: `enum-${config.id}`,\n description: 'Enum type',\n }),\n );\n\n const typeOptions = [\n ...SCALAR_FIELD_TYPES.filter((t) => t !== 'enum').map(\n (fieldType) => SCALAR_FIELD_TYPE_OPTIONS[fieldType],\n ),\n ...enumOptions,\n ];\n\n const {\n field: { value: typeValue, onChange: onTypeChange },\n } = useController({\n name: `model.fields.${idx}.type`,\n control,\n });\n\n const {\n field: { value: fieldOptions, onChange: onFieldOptionsChange },\n } = useController({\n name: `model.fields.${idx}.options`,\n control,\n });\n\n const handleChange = (value: string | null): void => {\n if (value?.startsWith('enum-')) {\n const enumRef = value.replace('enum-', '');\n onFieldOptionsChange({\n enumRef,\n });\n onTypeChange('enum');\n } else {\n onTypeChange(value as ScalarFieldType);\n }\n };\n\n const enumRef = fieldOptions?.enumRef;\n\n return (\n <div className=\"space-y-2\">\n <ComboboxField\n value={typeValue === 'enum' && enumRef ? `enum-${enumRef}` : typeValue}\n onChange={handleChange}\n options={typeOptions}\n renderItemLabel={(option) => (\n <div className=\"flex flex-col\">\n <div>{option.label}</div>\n <div className=\"text-xs text-muted-foreground\">\n {option.description}\n </div>\n </div>\n )}\n />\n </div>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control, UseFormSetValue } from 'react-hook-form';\n\nimport { modelUniqueConstraintEntityType } from '@baseplate-dev/project-builder-lib';\nimport {\n Button,\n DropdownMenu,\n DropdownMenuContent,\n DropdownMenuGroup,\n DropdownMenuItem,\n DropdownMenuTrigger,\n InputFieldController,\n SwitchFieldController,\n toast,\n} from '@baseplate-dev/ui-components';\nimport clsx from 'clsx';\nimport { useState } from 'react';\nimport { HiDotsVertical } from 'react-icons/hi';\nimport { MdOutlineDelete } from 'react-icons/md';\n\nimport { useEditedModelConfig } from '../../../-hooks/use-edited-model-config.js';\nimport { ModelFieldBadges } from './badges/model-field-badges.js';\nimport { ModelFieldDefaultValueInput } from './model-field-default-value-input.js';\nimport { ModelFieldTypeInput } from './model-field-type-input.js';\nimport { ModelPrimaryKeyDialog } from './primary-key/model-primary-key-dialog.js';\nimport { ModelRelationDialog } from './relations/model-relation-dialog.js';\nimport { ModelUniqueConstraintDialog } from './unique-constraints/model-unique-constraint-dialog.js';\n\ninterface Props {\n className?: string;\n control: Control<ModelConfigInput>;\n setValue: UseFormSetValue<ModelConfigInput>;\n idx: number;\n onRemove: (idx: number) => void;\n}\n\nfunction ModelFieldForm({\n className,\n control,\n idx,\n setValue,\n onRemove,\n}: Props): React.JSX.Element {\n const watchedField = useEditedModelConfig((model) => model.model.fields[idx]);\n\n const watchedRelations = useEditedModelConfig(\n (model) => model.model.relations,\n );\n\n const primaryKeyFieldRefs = useEditedModelConfig(\n (model) => model.model.primaryKeyFieldRefs,\n );\n const uniqueConstraints =\n useEditedModelConfig((model) => model.model.uniqueConstraints) ?? [];\n const isPartOfPrimaryKey = primaryKeyFieldRefs.includes(watchedField.id);\n const hasCompositePrimaryKey = primaryKeyFieldRefs.length > 1;\n\n const ownUniqueConstraints = uniqueConstraints.filter((uc) =>\n uc.fields.some((f) => f.fieldRef === watchedField.id),\n );\n const usedRelations =\n watchedRelations?.filter((relation) =>\n relation.references.some((r) => r.localRef === watchedField.id),\n ) ?? [];\n\n const removeError = (() => {\n // check local references\n if (usedRelations.length > 0) {\n return `Unable to remove field as it is being used in relations ${usedRelations\n .map((r) => r.name)\n .join(', ')}`;\n }\n // check primary keys\n if (isPartOfPrimaryKey && hasCompositePrimaryKey) {\n return `Unable to remove field as it is being used in in the primary key`;\n }\n // check unique constraints\n if (\n uniqueConstraints.some((constraint) =>\n constraint.fields.some((f) => f.fieldRef === watchedField.id),\n )\n ) {\n return `Unable to remove field as it is being used in in a unique constraint`;\n }\n return;\n })();\n\n function handleRemove(): void {\n if (removeError) {\n toast.error(removeError);\n return;\n }\n\n onRemove(idx);\n\n if (isPartOfPrimaryKey && !hasCompositePrimaryKey) {\n setValue('model.primaryKeyFieldRefs', [], { shouldDirty: true });\n }\n }\n\n const [isPrimaryKeyDialogOpen, setIsPrimaryKeyDialogOpen] = useState(false);\n\n const [isUniqueConstraintDialogOpen, setIsUniqueConstraintDialogOpen] =\n useState(false);\n const [uniqueConstriantId, setUniqueConstraintId] = useState<\n string | undefined\n >();\n\n const [isRelationDialogOpen, setIsRelationDialogOpen] = useState(false);\n const [relationId, setRelationId] = useState<string | undefined>();\n\n return (\n <div className={clsx('items-center', className)}>\n <div>\n <InputFieldController\n control={control}\n name={`model.fields.${idx}.name`}\n />\n </div>\n <div>\n <ModelFieldTypeInput control={control} idx={idx} />\n </div>\n <div>\n <SwitchFieldController\n control={control}\n name={`model.fields.${idx}.isOptional`}\n />\n </div>\n <div className=\"mr-4\">\n <ModelFieldDefaultValueInput\n control={control}\n idx={idx}\n setValue={setValue}\n />\n </div>\n <div>\n <ModelFieldBadges control={control} idx={idx} />\n </div>\n <div>\n <div className=\"flex items-center gap-2\">\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button variant=\"ghost\" size=\"icon\">\n <HiDotsVertical />\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuGroup>\n {usedRelations.length === 0 && (\n <DropdownMenuItem\n onSelect={() => {\n setIsRelationDialogOpen(true);\n setRelationId(undefined);\n }}\n >\n Add Relation\n </DropdownMenuItem>\n )}\n {usedRelations.length > 0 &&\n usedRelations.map((relation) => (\n <DropdownMenuItem\n key={relation.id}\n onSelect={() => {\n setIsRelationDialogOpen(true);\n setRelationId(relation.id);\n }}\n >\n Edit Relation {usedRelations.length > 1 && relation.name}\n </DropdownMenuItem>\n ))}\n {!hasCompositePrimaryKey && !isPartOfPrimaryKey && (\n <DropdownMenuItem\n onSelect={() => {\n setValue('model.primaryKeyFieldRefs', [watchedField.id], {\n shouldDirty: true,\n });\n }}\n >\n Set as Primary Key\n </DropdownMenuItem>\n )}\n {isPartOfPrimaryKey && (\n <DropdownMenuItem\n onSelect={() => {\n setIsPrimaryKeyDialogOpen(true);\n }}\n >\n Edit Primary Key\n </DropdownMenuItem>\n )}\n {ownUniqueConstraints.length === 0 &&\n (hasCompositePrimaryKey || !isPartOfPrimaryKey) && (\n <DropdownMenuItem\n onSelect={() => {\n setValue(\n 'model.uniqueConstraints',\n [\n ...uniqueConstraints,\n {\n id: modelUniqueConstraintEntityType.generateNewId(),\n fields: [{ fieldRef: watchedField.id }],\n },\n ],\n { shouldDirty: true },\n );\n }}\n >\n Make Unique\n </DropdownMenuItem>\n )}\n {ownUniqueConstraints.length > 0 &&\n ownUniqueConstraints.map((uc, idx) => (\n <DropdownMenuItem\n key={uc.id}\n onSelect={() => {\n setUniqueConstraintId(uc.id);\n setIsUniqueConstraintDialogOpen(true);\n }}\n >\n Edit Unique Constraint{' '}\n {ownUniqueConstraints.length > 1 && idx + 1}\n </DropdownMenuItem>\n ))}\n </DropdownMenuGroup>\n </DropdownMenuContent>\n </DropdownMenu>\n <ModelPrimaryKeyDialog\n control={control}\n open={isPrimaryKeyDialogOpen}\n onOpenChange={setIsPrimaryKeyDialogOpen}\n />\n <ModelUniqueConstraintDialog\n control={control}\n open={isUniqueConstraintDialogOpen}\n onOpenChange={setIsUniqueConstraintDialogOpen}\n constraintId={uniqueConstriantId}\n />\n <ModelRelationDialog\n control={control}\n open={isRelationDialogOpen}\n onOpenChange={setIsRelationDialogOpen}\n relationId={relationId}\n defaultFieldName={watchedField.name}\n />\n <Button\n variant=\"ghost\"\n onClick={() => {\n handleRemove();\n }}\n size=\"icon\"\n >\n <MdOutlineDelete />\n </Button>\n </div>\n </div>\n </div>\n );\n}\n\nexport default ModelFieldForm;\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type {\n Control,\n FieldArrayWithId,\n UseFormSetValue,\n} from 'react-hook-form';\n\nimport { clsx } from 'clsx';\nimport { useFieldArray } from 'react-hook-form';\n\nimport { SortableList } from '#src/components/index.js';\n\nimport { ModelAddFieldButton } from './model-add-field-button.js';\nimport ModelFieldForm from './model-field-form.js';\n\ninterface ModelFieldsFormProps {\n className?: string;\n control: Control<ModelConfigInput>;\n setValue: UseFormSetValue<ModelConfigInput>;\n}\n\nexport function ModelFieldsForm({\n className,\n control,\n setValue,\n}: ModelFieldsFormProps): React.JSX.Element {\n const {\n fields: fieldFields,\n remove: removeField,\n append: appendField,\n move: sortFields,\n } = useFieldArray({\n control,\n name: 'model.fields',\n });\n\n const gridClassNames =\n 'grid grid-cols-[repeat(2,minmax(130px,1fr))_60px_minmax(130px,1fr)_minmax(100px,1fr)_80px] gap-3';\n\n const fieldListItems = fieldFields.map((f: FieldArrayWithId, i: number) => ({\n id: f.id,\n element: (\n <ModelFieldForm\n className={gridClassNames}\n key={f.id}\n control={control}\n setValue={setValue}\n idx={i}\n onRemove={removeField}\n />\n ),\n }));\n\n return (\n <div className={clsx('space-y-4', className)}>\n {fieldFields.length === 0 ? (\n <p className=\"pt-4 text-style-muted\">Add some fields to get started</p>\n ) : (\n <div className=\"flex w-full flex-col gap-2 bg-white\">\n <div\n className={clsx(\n gridClassNames,\n 'sticky -top-0 z-10 bg-white py-2 text-sm font-semibold',\n // account for handle in sortable list\n 'pl-12',\n )}\n >\n <div>Name</div>\n <div>Type</div>\n <div>Optional</div>\n <div>Default Value</div>\n <div className=\"sr-only\">Badges</div>\n <div className=\"sr-only\">Actions</div>\n </div>\n <SortableList listItems={fieldListItems} sortItems={sortFields} />\n </div>\n )}\n <ModelAddFieldButton appendField={appendField} setValue={setValue} />\n </div>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control, UseFormSetValue } from 'react-hook-form';\n\nimport { useProjectDefinition } from '@baseplate-dev/project-builder-lib/web';\nimport {\n Button,\n RecordView,\n RecordViewActions,\n RecordViewItem,\n RecordViewItemList,\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionDescription,\n SectionListSectionHeader,\n SectionListSectionTitle,\n useConfirmDialog,\n} from '@baseplate-dev/ui-components';\nimport { MdAdd, MdDeleteOutline, MdEdit } from 'react-icons/md';\n\nimport { useEditedModelConfig } from '../../-hooks/use-edited-model-config.js';\nimport { ModelRelationDialog } from './fields/relations/model-relation-dialog.js';\n\ninterface Props {\n control: Control<ModelConfigInput>;\n setValue: UseFormSetValue<ModelConfigInput>;\n}\n\nexport function ModelRelationsSection({\n control,\n setValue,\n}: Props): React.JSX.Element {\n const { requestConfirm } = useConfirmDialog();\n const { definitionContainer } = useProjectDefinition();\n const relations = useEditedModelConfig(({ model }) => model.relations ?? []);\n const fieldIdsToNames = useEditedModelConfig(({ model }) =>\n Object.fromEntries(model.fields.map((field) => [field.id, field.name])),\n );\n\n function handleDeleteRelation(relationId: string): void {\n const relation = relations.find((relation) => relation.id === relationId);\n requestConfirm({\n title: 'Delete Relation',\n content: `Are you sure you want to delete the relation \"${relation?.name ?? '<invalid>'}\"?`,\n onConfirm: () => {\n setValue(\n 'model.relations',\n relations.filter((relation) => relation.id !== relationId),\n );\n },\n });\n }\n\n return (\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>Relations</SectionListSectionTitle>\n <SectionListSectionDescription>\n Define relations to enforce uniqueness on one or more fields.\n </SectionListSectionDescription>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-4\">\n {relations.map((relation) => (\n <RecordView key={relation.id}>\n <RecordViewItemList>\n <RecordViewItem title=\"Name\">{relation.name}</RecordViewItem>\n <RecordViewItem title=\"Local Field\">\n {relation.references\n .map((r) => fieldIdsToNames[r.localRef])\n .join(', ')}\n </RecordViewItem>\n <RecordViewItem title=\"Foreign Model\">\n {definitionContainer.nameFromId(relation.modelRef)}\n </RecordViewItem>\n <RecordViewItem title=\"On Delete\">\n {relation.onDelete}\n </RecordViewItem>\n </RecordViewItemList>\n <RecordViewActions>\n <ModelRelationDialog\n relationId={relation.id}\n control={control}\n asChild\n >\n <Button variant=\"ghost\" size=\"icon\" title=\"Edit\">\n <MdEdit />\n </Button>\n </ModelRelationDialog>\n <Button\n variant=\"ghostDestructive\"\n size=\"icon\"\n title=\"Delete\"\n onClick={() => {\n handleDeleteRelation(relation.id);\n }}\n >\n <MdDeleteOutline />\n </Button>\n </RecordViewActions>\n </RecordView>\n ))}\n <ModelRelationDialog control={control} asChild>\n <Button variant=\"secondary\" size=\"sm\">\n <MdAdd />\n Add Relation\n </Button>\n </ModelRelationDialog>\n </SectionListSectionContent>\n </SectionListSection>\n );\n}\n","import type { ModelConfigInput } from '@baseplate-dev/project-builder-lib';\nimport type React from 'react';\nimport type { Control, UseFormSetValue } from 'react-hook-form';\n\nimport {\n Button,\n RecordView,\n RecordViewActions,\n RecordViewItem,\n RecordViewItemList,\n SectionListSection,\n SectionListSectionContent,\n SectionListSectionDescription,\n SectionListSectionHeader,\n SectionListSectionTitle,\n useConfirmDialog,\n} from '@baseplate-dev/ui-components';\nimport { MdAdd, MdDeleteOutline, MdEdit } from 'react-icons/md';\n\nimport { useEditedModelConfig } from '../../-hooks/use-edited-model-config.js';\nimport { ModelUniqueConstraintDialog } from './fields/unique-constraints/model-unique-constraint-dialog.js';\n\ninterface Props {\n control: Control<ModelConfigInput>;\n setValue: UseFormSetValue<ModelConfigInput>;\n}\n\nexport function ModelUniqueConstraintsSection({\n control,\n setValue,\n}: Props): React.JSX.Element {\n const { requestConfirm } = useConfirmDialog();\n const uniqueConstraints = useEditedModelConfig(\n ({ model }) => model.uniqueConstraints ?? [],\n );\n const fieldIdsToNames = useEditedModelConfig(({ model }) =>\n Object.fromEntries(model.fields.map((field) => [field.id, field.name])),\n );\n\n function handleDeleteConstraint(constraintId: string): void {\n requestConfirm({\n title: 'Delete Unique Constraint',\n content: 'Are you sure you want to delete this unique constraint?',\n onConfirm: () => {\n setValue(\n 'model.uniqueConstraints',\n uniqueConstraints.filter(\n (constraint) => constraint.id !== constraintId,\n ),\n );\n },\n });\n }\n\n return (\n <SectionListSection>\n <SectionListSectionHeader>\n <SectionListSectionTitle>Unique Constraints</SectionListSectionTitle>\n <SectionListSectionDescription>\n Define unique constraints to enforce uniqueness on one or more fields.\n </SectionListSectionDescription>\n </SectionListSectionHeader>\n <SectionListSectionContent className=\"space-y-4\">\n {uniqueConstraints.map((constraint) => (\n <RecordView key={constraint.id}>\n <RecordViewItemList>\n <RecordViewItem title=\"Fields\">\n {constraint.fields\n .map(\n (field) => fieldIdsToNames[field.fieldRef] ?? '<invalid>',\n )\n .join(', ')}\n </RecordViewItem>\n </RecordViewItemList>\n <RecordViewActions>\n <ModelUniqueConstraintDialog\n constraintId={constraint.id}\n control={control}\n asChild\n >\n <Button variant=\"ghost\" size=\"icon\" title=\"Edit\">\n <MdEdit />\n </Button>\n </ModelUniqueConstraintDialog>\n <Button\n variant=\"ghostDestructive\"\n size=\"icon\"\n title=\"Delete\"\n onClick={() => {\n handleDeleteConstraint(constraint.id);\n }}\n >\n <MdDeleteOutline />\n </Button>\n </RecordViewActions>\n </RecordView>\n ))}\n <ModelUniqueConstraintDialog control={control} asChild>\n <Button variant=\"secondary\" size=\"sm\">\n <MdAdd />\n Add Unique Constraint\n </Button>\n </ModelUniqueConstraintDialog>\n </SectionListSectionContent>\n </SectionListSection>\n );\n}\n","import type React from 'react';\n\nimport {\n modelEntityType,\n modelLocalRelationEntityType,\n modelScalarFieldEntityType,\n} from '@baseplate-dev/project-builder-lib';\nimport { useBlockUnsavedChangesNavigate } from '@baseplate-dev/project-builder-lib/web';\nimport { FormActionBar, SectionList } from '@baseplate-dev/ui-components';\nimport { createFileRoute } from '@tanstack/react-router';\n\nimport { ErrorBoundary } from '#src/components/index.js';\nimport { registerEntityTypeUrl } from '#src/services/entity-type.js';\n\nimport { EditedModelContextProvider } from '../-hooks/use-edited-model-config.js';\nimport { useModelForm } from '../-hooks/use-model-form.js';\nimport { ModelFieldsForm } from './-components/fields/model-fields-form.js';\nimport { ModelRelationsSection } from './-components/model-relations-section.js';\nimport { ModelUniqueConstraintsSection } from './-components/model-unique-constraints-section.js';\n\nregisterEntityTypeUrl(modelEntityType, `/data/models/edit/{key}`);\nregisterEntityTypeUrl(\n modelScalarFieldEntityType,\n `/data/models/edit/{parentKey}`,\n);\nregisterEntityTypeUrl(\n modelLocalRelationEntityType,\n `/data/models/edit/{parentKey}`,\n);\n\nexport const Route = createFileRoute('/data/models/edit/$key/')({\n component: ModelEditModelPage,\n});\n\nfunction ModelEditModelPage(): React.JSX.Element {\n const { key } = Route.useParams();\n const { form, onSubmit, originalModel } = useModelForm({\n omit: ['name', 'featureRef'],\n modelKey: key,\n });\n const { control, watch, getValues, setValue, reset } = form;\n\n useBlockUnsavedChangesNavigate({ control, reset, onSubmit });\n\n // TODO: Add validation for fields form where:\n // - referenced type does not match field type\n // - SET NULL is on non-optional fields\n\n return (\n <ErrorBoundary>\n <EditedModelContextProvider\n originalModel={originalModel}\n getValues={getValues}\n watch={watch}\n >\n <form\n onSubmit={onSubmit}\n className=\"max-w-7xl min-w-[700px] flex-1 space-y-4 px-4 pb-4\"\n >\n <ModelFieldsForm control={control} setValue={setValue} />\n <SectionList>\n <ModelRelationsSection control={control} setValue={setValue} />\n <ModelUniqueConstraintsSection\n control={control}\n setValue={setValue}\n />\n </SectionList>\n <FormActionBar form={form} />\n </form>\n </EditedModelContextProvider>\n </ErrorBoundary>\n );\n}\n"],"names":["camelCase","str","words$1","words","first","rest","word","capitalize","modelScalarFieldEntityType","importShared","Button","ButtonGroup","DropdownMenu","DropdownMenuContent","DropdownMenuItem","DropdownMenuTrigger","useMemo","ModelAddFieldButton","className","appendField","setValue","fieldNames","useEditedModelConfig","model","f","primaryKeyFieldLength","availableAutoFields","autoFields","hasCreatedAt","hasUpdatedAt","applyAutoField","autoField","isPrimaryKey","field","fieldId","jsxs","jsx","MdExpandMore","DialogClose","DialogFooter","MultiComboboxFieldController","useId","z","primaryKeychema","ModelPrimaryKeyForm","modelControl","onSubmitSuccess","fields","modelValue","onModelChange","useController","control","handleSubmit","useForm","zodResolver","onSubmit","data","formId","clsx","e","Dialog","DialogContent","DialogDescription","DialogHeader","DialogTitle","DialogTrigger","useControlledState","ModelPrimaryKeyDialog","children","asChild","open","onOpenChange","isOpen","setIsOpen","BadgeWithIcon","useState","ModelPrimaryKeyBadge","autoCollapse","isHovered","setIsHovered","shouldShowText","MdKey","createModelRelationFieldSchema","ModelFieldUtils","modelForeignRelationEntityType","modelLocalRelationEntityType","ModelUtils","useDefinitionSchema","useProjectDefinition","ComboboxField","ComboboxFieldController","InputFieldController","SelectFieldController","toast","React","guessModelTypeFromFieldName","definition","editedModel","fieldName","name","tryFindModel","condition","modelWithName","m","modelWithFeature","getRelationDefaultsFromModel","editedRelation","defaultFieldName","references","primaryKeyFieldRefs","foreignName","primaryKeys","existingReferences","primaryKey","i","bestGuessLocalName","foreignRelationName","isOneToOne","ref","r","pluralize","ModelRelationForm","relationId","modelName","modelRelations","onModelRelationsChange","foreignModelOptions","type","modelRelation","item","defaultValues","modelRef","modelRelationFieldSchema","setError","watch","relation","foreignModel","foreignFields","localFieldOptions","foreignFieldOptions","isRelationOptional","onDelete","id","localFields","hasSelectedForeignModel","value","_","ModelRelationDialog","ModelRelationsBadge","definitionContainer","MdLink","modelUniqueConstraintEntityType","formSchema","ModelUniqueConstraintForm","constraintId","modelUniqueConstraint","uc","dataWithId","fieldRef","ModelUniqueConstraintDialog","ModelFieldUniqueBadge","fieldsLength","MdStar","ModelFieldBadges","idx","isPrimary","uniqueConstraints","constraint","modelFieldRelations","badges","EnumUtils","DropdownMenuGroup","InputField","ModelFieldDefaultValueInput","useWatch","optionsValue","onOptionsChange","defaultValue","HiOutlineX","HiDotsVertical","defaultToNow","updatedAt","enumValues","v","SCALAR_FIELD_TYPES","ModelFieldTypeInput","enumOptions","config","typeOptions","t","fieldType","SCALAR_FIELD_TYPE_OPTIONS","typeValue","onTypeChange","fieldOptions","onFieldOptionsChange","handleChange","enumRef","option","SwitchFieldController","ModelFieldForm","onRemove","watchedField","watchedRelations","isPartOfPrimaryKey","hasCompositePrimaryKey","ownUniqueConstraints","usedRelations","removeError","handleRemove","isPrimaryKeyDialogOpen","setIsPrimaryKeyDialogOpen","isUniqueConstraintDialogOpen","setIsUniqueConstraintDialogOpen","uniqueConstriantId","setUniqueConstraintId","isRelationDialogOpen","setIsRelationDialogOpen","setRelationId","MdOutlineDelete","ModelFieldsForm","fieldFields","removeField","sortFields","useFieldArray","gridClassNames","fieldListItems","SortableList","RecordView","RecordViewActions","RecordViewItem","RecordViewItemList","SectionListSection","SectionListSectionContent","SectionListSectionDescription","SectionListSectionHeader","SectionListSectionTitle","useConfirmDialog","ModelRelationsSection","requestConfirm","relations","fieldIdsToNames","handleDeleteRelation","MdEdit","MdDeleteOutline","MdAdd","ModelUniqueConstraintsSection","handleDeleteConstraint","modelEntityType","useBlockUnsavedChangesNavigate","FormActionBar","SectionList","registerEntityTypeUrl","SplitComponent","key","Route","useParams","form","originalModel","useModelForm","omit","modelKey","getValues","reset","ErrorBoundary","EditedModelContextProvider"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{i as s}from"./_virtual___federation_fn_import-DXu2m-ZE.js";import{j as e}from"./jsx-runtime-D_zvdyIk.js";import{K as c}from"./index-BGLRovL6.js";import{N as m}from"./new-admin-section-dialog-F58HZ0yO.js";import{c as o}from"./index-BUYA3Tes.js";const{adminSectionEntityType:l}=await s("@baseplate-dev/project-builder-lib"),{Button:r,Card:p,EmptyDisplay:x}=await s("@baseplate-dev/ui-components"),{Link:h}=await s("@tanstack/react-router"),S=function(){const{adminApp:d,app:a}=o.useLoaderData(),{appKey:i}=o.useParams(),n=d.sections??[];return n.length===0?e.jsx(x,{icon:c,header:"No Admin Sections",subtitle:"Create your first admin section to get started with managing your data",actions:e.jsx(m,{appId:a.id,appKey:i,children:e.jsx(r,{children:"New Section"})})}):e.jsxs("div",{className:"space-y-4 p-4",children:[e.jsxs("div",{children:[e.jsxs("h1",{className:"text-2xl font-bold",children:[a.name," Admin Sections"]}),e.jsx("p",{className:"text-muted-foreground",children:"Manage CRUD interfaces for your data models. Select a section from the sidebar to edit it."})]}),e.jsx("div",{className:"grid gap-4 md:grid-cols-2 lg:grid-cols-3",children:n.map(t=>e.jsx(p,{className:"p-4",children:e.jsxs("div",{className:"space-y-2",children:[e.jsx("h3",{className:"font-semibold",children:t.name||"Unnamed Section"}),e.jsxs("p",{className:"text-sm text-muted-foreground",children:["Type: ",t.type]}),t.icon&&e.jsxs("p",{className:"text-sm text-muted-foreground",children:["Icon: ",t.icon]}),e.jsx(h,{to:"/admin-sections/$appKey/edit/$sectionKey",params:{appKey:i,sectionKey:l.keyFromId(t.id)},className:"inline-block",children:e.jsx(r,{variant:"secondary",size:"sm",children:"Edit"})})]})},t.id))})]})};export{S as component};
|
|
2
|
+
//# sourceMappingURL=index-DpJKJe06.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-DpJKJe06.js","sources":["../../src/routes/admin-sections.$appKey/index.tsx?tsr-split=component"],"sourcesContent":["import type React from 'react';\n\nimport { adminSectionEntityType } from '@baseplate-dev/project-builder-lib';\nimport { Button, Card, EmptyDisplay } from '@baseplate-dev/ui-components';\nimport { createFileRoute, Link, notFound } from '@tanstack/react-router';\nimport { MdSettings } from 'react-icons/md';\n\nimport NewAdminSectionDialog from './-components/new-admin-section-dialog.js';\n\nexport const Route = createFileRoute('/admin-sections/$appKey/')({\n component: AdminSectionsIndexPage,\n loader: ({ context: { adminApp, app } }) => {\n if (!adminApp) throw notFound();\n return { adminApp, app };\n },\n});\n\nfunction AdminSectionsIndexPage(): React.JSX.Element {\n const { adminApp, app } = Route.useLoaderData();\n const { appKey } = Route.useParams();\n\n // Find the web app definition and its admin sections\n const sections = adminApp.sections ?? [];\n\n if (sections.length === 0) {\n return (\n <EmptyDisplay\n icon={MdSettings}\n header=\"No Admin Sections\"\n subtitle=\"Create your first admin section to get started with managing your data\"\n actions={\n <NewAdminSectionDialog appId={app.id} appKey={appKey}>\n <Button>New Section</Button>\n </NewAdminSectionDialog>\n }\n />\n );\n }\n\n return (\n <div className=\"space-y-4 p-4\">\n <div>\n <h1 className=\"text-2xl font-bold\">{app.name} Admin Sections</h1>\n <p className=\"text-muted-foreground\">\n Manage CRUD interfaces for your data models. Select a section from the\n sidebar to edit it.\n </p>\n </div>\n\n <div className=\"grid gap-4 md:grid-cols-2 lg:grid-cols-3\">\n {sections.map((section) => (\n <Card key={section.id} className=\"p-4\">\n <div className=\"space-y-2\">\n <h3 className=\"font-semibold\">\n {section.name || 'Unnamed Section'}\n </h3>\n <p className=\"text-sm text-muted-foreground\">\n Type: {section.type}\n </p>\n {section.icon && (\n <p className=\"text-sm text-muted-foreground\">\n Icon: {section.icon}\n </p>\n )}\n <Link\n to=\"/admin-sections/$appKey/edit/$sectionKey\"\n params={{\n appKey,\n sectionKey: adminSectionEntityType.keyFromId(section.id),\n }}\n className=\"inline-block\"\n >\n <Button variant=\"secondary\" size=\"sm\">\n Edit\n </Button>\n </Link>\n </div>\n </Card>\n ))}\n </div>\n </div>\n );\n}\n"],"names":["adminSectionEntityType","importShared","Button","Card","EmptyDisplay","Link","SplitComponent","adminApp","app","Route","useLoaderData","appKey","useParams","sections","length","MdSettings","NewAdminSectionDialog","id","jsxs","name","jsx","map","section","type","icon","sectionKey","keyFromId"],"mappings":"2PAEA,KAAA,CAAA,uBAAAA,CAAA,EAAA,MAAAC,EAAA,oCAAA,EACA,CAAA,OAAAC,EAAA,KAAAC,EAAA,aAAAC,CAAA,EAAA,MAAAH,EAAA,8BAAA,EACA,CAAA,KAAAI,CAAA,EAAA,MAAAJ,EAAA,wBAAA,EAG8EK,EAAA,UAUzB,CAC7C,KAAA,CAAEC,SAAAA,EAAUC,IAAAA,CAAAA,EAAQC,EAAMC,cAAc,EACxC,CAAEC,OAAAA,CAAAA,EAAWF,EAAMG,UAAU,EAG7BC,EAAWN,EAASM,UAAY,CAAE,EAEpCA,OAAAA,EAASC,SAAW,QAEnBV,EACC,CAAA,KAAMW,EACN,OAAO,oBACP,SAAS,yEACT,cACGC,EAAsB,CAAA,MAAOR,EAAIS,GAAI,OAAAN,EACpC,eAACT,EAAO,CAAA,SAAA,cAAW,EACrB,CAEF,CAAA,EAKJgB,EAAA,KAAC,MAAI,CAAA,UAAU,gBACb,SAAA,CAAAA,OAAC,MACC,CAAA,SAAA,CAACA,EAAAA,KAAA,KAAA,CAAG,UAAU,qBAAsBV,SAAAA,CAAIW,EAAAA,KAAK,iBAAA,EAAe,EAC3DC,EAAA,IAAA,IAAA,CAAE,UAAU,wBAAuB,SAGpC,4FAAA,CAAA,CAAA,EACF,EAECA,MAAA,MAAA,CAAI,UAAU,2CACZP,WAASQ,IAAKC,GACZF,EAAAA,IAAAjB,EAAA,CAAsB,UAAU,MAC/B,SAACe,EAAAA,KAAA,MAAA,CAAI,UAAU,YACb,SAAA,CAAAE,MAAC,KAAG,CAAA,UAAU,gBACXE,SAAAA,EAAQH,MAAQ,kBACnB,EACAD,EAAAA,KAAC,IAAE,CAAA,UAAU,gCAA+B,SAAA,CAAA,SACnCI,EAAQC,IAAAA,EACjB,EACCD,EAAQE,MACNN,OAAA,IAAA,CAAE,UAAU,gCAA+B,SAAA,CAAA,SACnCI,EAAQE,IAAAA,EACjB,EAEDJ,EAAAA,IAAAf,EAAA,CACC,GAAG,2CACH,OAAQ,CACNM,OAAAA,EACAc,WAAYzB,EAAuB0B,UAAUJ,EAAQL,EAAE,CACzD,EACA,UAAU,eAEV,SAACG,EAAAA,IAAAlB,EAAA,CAAO,QAAQ,YAAY,KAAK,KAAI,SAAA,MAErC,CAAA,CACF,CAAA,CAAA,CAAA,CACF,CAzBSoB,EAAAA,EAAQL,EA0BnB,CACD,CACH,CAAA,CAAA,EACF,CAEJ"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as O}from"./index-
|
|
1
|
+
import{r as O}from"./index-c0qeY2gs.js";var y={exports:{}},n={};/**
|
|
2
2
|
* @license React
|
|
3
3
|
* react-dom.production.js
|
|
4
4
|
*
|
|
@@ -7,4 +7,4 @@ import{r as O}from"./index-9Ra4Lmds.js";var y={exports:{}},n={};/**
|
|
|
7
7
|
* This source code is licensed under the MIT license found in the
|
|
8
8
|
* LICENSE file in the root directory of this source tree.
|
|
9
9
|
*/var o;function S(){if(o)return n;o=1;var u=O();function g(r){var e="https://react.dev/errors/"+r;if(1<arguments.length){e+="?args[]="+encodeURIComponent(arguments[1]);for(var t=2;t<arguments.length;t++)e+="&args[]="+encodeURIComponent(arguments[t])}return"Minified React error #"+r+"; visit "+e+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}function c(){}var i={d:{f:c,r:function(){throw Error(g(522))},D:c,C:c,L:c,m:c,X:c,S:c,M:c},p:0,findDOMNode:null},m=Symbol.for("react.portal");function v(r,e,t){var a=3<arguments.length&&arguments[3]!==void 0?arguments[3]:null;return{$$typeof:m,key:a==null?null:""+a,children:r,containerInfo:e,implementation:t}}var f=u.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;function d(r,e){if(r==="font")return"";if(typeof e=="string")return e==="use-credentials"?e:""}return n.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE=i,n.createPortal=function(r,e){var t=2<arguments.length&&arguments[2]!==void 0?arguments[2]:null;if(!e||e.nodeType!==1&&e.nodeType!==9&&e.nodeType!==11)throw Error(g(299));return v(r,e,null,t)},n.flushSync=function(r){var e=f.T,t=i.p;try{if(f.T=null,i.p=2,r)return r()}finally{f.T=e,i.p=t,i.d.f()}},n.preconnect=function(r,e){typeof r=="string"&&(e?(e=e.crossOrigin,e=typeof e=="string"?e==="use-credentials"?e:"":void 0):e=null,i.d.C(r,e))},n.prefetchDNS=function(r){typeof r=="string"&&i.d.D(r)},n.preinit=function(r,e){if(typeof r=="string"&&e&&typeof e.as=="string"){var t=e.as,a=d(t,e.crossOrigin),s=typeof e.integrity=="string"?e.integrity:void 0,l=typeof e.fetchPriority=="string"?e.fetchPriority:void 0;t==="style"?i.d.S(r,typeof e.precedence=="string"?e.precedence:void 0,{crossOrigin:a,integrity:s,fetchPriority:l}):t==="script"&&i.d.X(r,{crossOrigin:a,integrity:s,fetchPriority:l,nonce:typeof e.nonce=="string"?e.nonce:void 0})}},n.preinitModule=function(r,e){if(typeof r=="string")if(typeof e=="object"&&e!==null){if(e.as==null||e.as==="script"){var t=d(e.as,e.crossOrigin);i.d.M(r,{crossOrigin:t,integrity:typeof e.integrity=="string"?e.integrity:void 0,nonce:typeof e.nonce=="string"?e.nonce:void 0})}}else e==null&&i.d.M(r)},n.preload=function(r,e){if(typeof r=="string"&&typeof e=="object"&&e!==null&&typeof e.as=="string"){var t=e.as,a=d(t,e.crossOrigin);i.d.L(r,t,{crossOrigin:a,integrity:typeof e.integrity=="string"?e.integrity:void 0,nonce:typeof e.nonce=="string"?e.nonce:void 0,type:typeof e.type=="string"?e.type:void 0,fetchPriority:typeof e.fetchPriority=="string"?e.fetchPriority:void 0,referrerPolicy:typeof e.referrerPolicy=="string"?e.referrerPolicy:void 0,imageSrcSet:typeof e.imageSrcSet=="string"?e.imageSrcSet:void 0,imageSizes:typeof e.imageSizes=="string"?e.imageSizes:void 0,media:typeof e.media=="string"?e.media:void 0})}},n.preloadModule=function(r,e){if(typeof r=="string")if(e){var t=d(e.as,e.crossOrigin);i.d.m(r,{as:typeof e.as=="string"&&e.as!=="script"?e.as:void 0,crossOrigin:t,integrity:typeof e.integrity=="string"?e.integrity:void 0})}else i.d.m(r)},n.requestFormReset=function(r){i.d.r(r)},n.unstable_batchedUpdates=function(r,e){return r(e)},n.useFormState=function(r,e,t){return f.H.useFormState(r,e,t)},n.useFormStatus=function(){return f.H.useHostTransitionStatus()},n.version="19.1.0",n}var _;function T(){if(_)return y.exports;_=1;function u(){if(!(typeof __REACT_DEVTOOLS_GLOBAL_HOOK__>"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(u)}catch(g){console.error(g)}}return u(),y.exports=S(),y.exports}export{T as r};
|
|
10
|
-
//# sourceMappingURL=index-
|
|
10
|
+
//# sourceMappingURL=index-DqHVrEeL.js.map
|