@seedprotocol/sdk 0.4.6 → 0.4.8
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/ArweaveClient-DFqnm5Kj.js +202 -0
- package/dist/ArweaveClient-DFqnm5Kj.js.map +1 -0
- package/dist/ArweaveClient-sN5h2FvY.js +202 -0
- package/dist/ArweaveClient-sN5h2FvY.js.map +1 -0
- package/dist/Db-DIythELU.js +246 -0
- package/dist/Db-DIythELU.js.map +1 -0
- package/dist/Db-Dz17KxVs.js +1530 -0
- package/dist/Db-Dz17KxVs.js.map +1 -0
- package/dist/EasClient-BadfcFDk.js +29 -0
- package/dist/EasClient-BadfcFDk.js.map +1 -0
- package/dist/EasClient-DosbWaZN.js +29 -0
- package/dist/EasClient-DosbWaZN.js.map +1 -0
- package/dist/FileManager-BHuVNWT3.js +174 -0
- package/dist/FileManager-BHuVNWT3.js.map +1 -0
- package/dist/FileManager-Wthr5yHO.js +1142 -0
- package/dist/FileManager-Wthr5yHO.js.map +1 -0
- package/dist/ModelProperty-B9Z2DRxI.js +1731 -0
- package/dist/ModelProperty-B9Z2DRxI.js.map +1 -0
- package/dist/PathResolver-Cd1PZDLG.js +204 -0
- package/dist/PathResolver-Cd1PZDLG.js.map +1 -0
- package/dist/PathResolver-NEpTSgQK.js +78 -0
- package/dist/PathResolver-NEpTSgQK.js.map +1 -0
- package/dist/QueryClient-C9U8oZUe.js +34 -0
- package/dist/QueryClient-C9U8oZUe.js.map +1 -0
- package/dist/QueryClient-ndmA8MYL.js +47 -0
- package/dist/QueryClient-ndmA8MYL.js.map +1 -0
- package/dist/Schema-D1-HjT8z.js +6521 -0
- package/dist/Schema-D1-HjT8z.js.map +1 -0
- package/dist/SchemaValidationService-CIXKzSpb.js +654 -0
- package/dist/SchemaValidationService-CIXKzSpb.js.map +1 -0
- package/dist/cjs/ModelProperty-09hNvSBl.js +1725 -0
- package/dist/cjs/ModelProperty-09hNvSBl.js.map +1 -0
- package/dist/cjs/Schema-BcwvUABB.js +5967 -0
- package/dist/cjs/Schema-BcwvUABB.js.map +1 -0
- package/dist/cjs/SchemaValidationService-zty4nfCu.js +670 -0
- package/dist/cjs/SchemaValidationService-zty4nfCu.js.map +1 -0
- package/dist/cjs/getItem-Dlb5YSQn.js +55 -0
- package/dist/cjs/getItem-Dlb5YSQn.js.map +1 -0
- package/dist/cjs/getPublishPayload-BqL06sEI.js +520 -0
- package/dist/cjs/getPublishPayload-BqL06sEI.js.map +1 -0
- package/dist/cjs/getPublishUploads-oukGI2N6.js +282 -0
- package/dist/cjs/getPublishUploads-oukGI2N6.js.map +1 -0
- package/dist/cjs/getSegmentedItemProperties-JT984OOp.js +71 -0
- package/dist/cjs/getSegmentedItemProperties-JT984OOp.js.map +1 -0
- package/dist/cjs/index-BLETlVgA.js +17614 -0
- package/dist/cjs/index-BLETlVgA.js.map +1 -0
- package/dist/cjs/index-jubgGeM2.js +58 -0
- package/dist/cjs/index-jubgGeM2.js.map +1 -0
- package/dist/cjs/ownership-vfvyz3KJ.js +103 -0
- package/dist/cjs/ownership-vfvyz3KJ.js.map +1 -0
- package/dist/db/drizzle/drizzle/0004_add_publisher_to_seeds.sql +1 -0
- package/dist/db/drizzle/drizzle/meta/0004_snapshot.json +857 -0
- package/dist/db/drizzle/drizzle/meta/_journal.json +7 -0
- package/dist/getItem-f9rNUz7I.js +38 -0
- package/dist/getItem-f9rNUz7I.js.map +1 -0
- package/dist/getPublishPayload-BBI_j9I2.js +503 -0
- package/dist/getPublishPayload-BBI_j9I2.js.map +1 -0
- package/dist/getPublishUploads-BFM94w5S.js +246 -0
- package/dist/getPublishUploads-BFM94w5S.js.map +1 -0
- package/dist/getSegmentedItemProperties-Di9vevKz.js +69 -0
- package/dist/getSegmentedItemProperties-Di9vevKz.js.map +1 -0
- package/dist/index-CSAVWKeA.js +18 -0
- package/dist/index-CSAVWKeA.js.map +1 -0
- package/dist/index-ajj6SHkh.js +23 -0
- package/dist/index-ajj6SHkh.js.map +1 -0
- package/dist/index-j8WN8W6V.js +16296 -0
- package/dist/index-j8WN8W6V.js.map +1 -0
- package/dist/main.cjs +1 -1
- package/dist/main.js +162 -540
- package/dist/main.js.map +1 -1
- package/dist/node.js +33 -15
- package/dist/node.js.map +1 -1
- package/dist/ownership-DLNI17NE.js +85 -0
- package/dist/ownership-DLNI17NE.js.map +1 -0
- package/dist/property-C6qoOzLG.js +264 -0
- package/dist/property-C6qoOzLG.js.map +1 -0
- package/dist/queries-jMaUn86w.js +16 -0
- package/dist/queries-jMaUn86w.js.map +1 -0
- package/dist/seedSchema/ModelSchemaSchema.ts +4 -4
- package/dist/seedSchema/ModelUidSchema.ts +1 -1
- package/dist/seedSchema/PropertyUidSchema.ts +1 -1
- package/dist/seedSchema/SEEDPROTOCOL_Seed_Protocol_v1.json +38 -1
- package/dist/seedSchema/SeedSchema.ts +1 -0
- package/dist/seedSchema/index.ts +10 -10
- package/dist/src/Item/Item.d.ts +141 -0
- package/dist/src/Item/Item.d.ts.map +1 -0
- package/dist/src/Item/queries.d.ts.map +1 -0
- package/dist/src/Item/service/actors/fetchDataFromEas.d.ts.map +1 -0
- package/dist/src/Item/service/actors/hydrateExistingItem.d.ts.map +1 -0
- package/dist/src/Item/service/actors/hydrateNewItem.d.ts.map +1 -0
- package/dist/src/Item/service/actors/initialize.d.ts.map +1 -0
- package/dist/src/Item/service/actors/loadOrCreateItem.d.ts.map +1 -0
- package/dist/src/Item/service/actors/reload.d.ts.map +1 -0
- package/dist/src/Item/service/actors/runPublish.d.ts.map +1 -0
- package/dist/src/Item/service/actors/saveDataToDb.d.ts.map +1 -0
- package/dist/src/Item/service/actors/waitForDb.d.ts.map +1 -0
- package/dist/src/Item/service/itemMachineSingle.d.ts.map +1 -0
- package/dist/src/ItemProperty/ItemProperty.d.ts +126 -0
- package/dist/src/ItemProperty/ItemProperty.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/hydrateFromDb.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/initialize.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/loadOrCreateProperty.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/resolveRelatedValue.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/resolveRemoteStorage.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/analyzeInput.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/index.d.ts +7 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/index.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveFile.d.ts +5 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveFile.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveHtml.d.ts +5 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveHtml.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveImage.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveItemStorage.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/saveValueToDb/saveRelation.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/actors/waitForDb.d.ts.map +1 -0
- package/dist/src/ItemProperty/service/propertyMachine.d.ts +78 -0
- package/dist/src/ItemProperty/service/propertyMachine.d.ts.map +1 -0
- package/dist/src/Model/Model.d.ts +230 -0
- package/dist/src/Model/Model.d.ts.map +1 -0
- package/dist/src/Model/index.d.ts.map +1 -0
- package/dist/src/Model/service/actors/createModelProperties.d.ts.map +1 -0
- package/dist/src/Model/service/actors/loadOrCreateModel.d.ts.map +1 -0
- package/dist/src/Model/service/actors/validateModel.d.ts.map +1 -0
- package/dist/src/Model/service/modelMachine.d.ts +222 -0
- package/dist/src/Model/service/modelMachine.d.ts.map +1 -0
- package/dist/src/ModelProperty/ModelProperty.d.ts +148 -0
- package/dist/src/ModelProperty/ModelProperty.d.ts.map +1 -0
- package/dist/src/ModelProperty/service/actors/compareAndMarkDraft.d.ts.map +1 -0
- package/dist/src/ModelProperty/service/actors/saveToSchema.d.ts.map +1 -0
- package/dist/src/ModelProperty/service/actors/validateProperty.d.ts.map +1 -0
- package/dist/src/ModelProperty/service/modelPropertyMachine.d.ts.map +1 -0
- package/dist/src/Schema/Schema.d.ts.map +1 -0
- package/dist/src/Schema/errors.d.ts.map +1 -0
- package/dist/src/Schema/index.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/checkExistingSchema.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/createModelInstances.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/createPropertyInstances.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/loadOrCreateSchema.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/validateSchema.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/verifyModelInstancesInCache.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/verifyModelsInDb.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/verifyPropertiesInDb.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/verifyPropertyInstancesInCache.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/verifySchemaInDb.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/writeModelsToDb.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/writePropertiesToDb.d.ts.map +1 -0
- package/dist/src/Schema/service/actors/writeSchemaToDb.d.ts.map +1 -0
- package/dist/src/Schema/service/addModelsMachine.d.ts +123 -0
- package/dist/src/Schema/service/addModelsMachine.d.ts.map +1 -0
- package/dist/src/Schema/service/schemaMachine.d.ts +526 -0
- package/dist/src/Schema/service/schemaMachine.d.ts.map +1 -0
- package/dist/src/Schema/service/validation/SchemaValidationService.d.ts.map +1 -0
- package/dist/src/Schema/validation.d.ts.map +1 -0
- package/dist/src/browser/db/Db.d.ts.map +1 -0
- package/dist/src/browser/db/drizzleFiles.d.ts +8 -0
- package/dist/src/browser/db/drizzleFiles.d.ts.map +1 -0
- package/dist/src/browser/db/sqlWasmClient.d.ts.map +1 -0
- package/dist/src/browser/helpers/ArweaveClient.d.ts.map +1 -0
- package/dist/src/browser/helpers/EasClient.d.ts.map +1 -0
- package/dist/src/browser/helpers/FileManager.d.ts +42 -0
- package/dist/src/browser/helpers/FileManager.d.ts.map +1 -0
- package/dist/src/browser/helpers/PathResolver.d.ts.map +1 -0
- package/dist/src/browser/helpers/QueryClient.d.ts.map +1 -0
- package/dist/src/browser/helpers/index.d.ts.map +1 -0
- package/dist/src/browser/index.d.ts.map +1 -0
- package/dist/src/browser/react/OPFSImage.d.ts.map +1 -0
- package/dist/src/browser/react/SeedImage.d.ts.map +1 -0
- package/dist/src/browser/react/SeedProvider.d.ts.map +1 -0
- package/dist/src/browser/react/client.d.ts.map +1 -0
- package/dist/src/browser/react/db.d.ts.map +1 -0
- package/dist/src/browser/react/index.d.ts +14 -0
- package/dist/src/browser/react/index.d.ts.map +1 -0
- package/dist/src/browser/react/item.d.ts +44 -0
- package/dist/src/browser/react/item.d.ts.map +1 -0
- package/dist/src/browser/react/itemProperty.d.ts.map +1 -0
- package/dist/src/browser/react/liveQuery.d.ts.map +1 -0
- package/dist/src/browser/react/model.d.ts.map +1 -0
- package/dist/src/browser/react/modelProperty.d.ts.map +1 -0
- package/dist/src/browser/react/queryClient.d.ts.map +1 -0
- package/dist/src/browser/react/schema.d.ts.map +1 -0
- package/dist/src/browser/react/services.d.ts.map +1 -0
- package/dist/src/browser/react/trash.d.ts.map +1 -0
- package/dist/src/browser/react/useImageFiles.d.ts +19 -0
- package/dist/src/browser/react/useImageFiles.d.ts.map +1 -0
- package/dist/src/browser/seed.d.ts.map +1 -0
- package/dist/src/browser/workers/FileDownloader.d.ts.map +1 -0
- package/dist/src/browser/workers/ImageResizer.d.ts.map +1 -0
- package/dist/src/browser/workers/content-hash.d.ts.map +1 -0
- package/dist/src/browser/workers/dbWorker.d.ts.map +1 -0
- package/dist/src/browser/workers/filesDownload.d.ts.map +1 -0
- package/dist/src/browser/workers/imageResize.d.ts.map +1 -0
- package/dist/src/client/BaseClientManager.d.ts.map +1 -0
- package/dist/src/client/ClientManager.d.ts +220 -0
- package/dist/src/client/ClientManager.d.ts.map +1 -0
- package/dist/src/client/actions/setAddresses.d.ts.map +1 -0
- package/dist/src/client/actors/addModelsToDb.d.ts.map +1 -0
- package/dist/src/client/actors/addModelsToStore.d.ts.map +1 -0
- package/dist/src/client/actors/dbInit.d.ts.map +1 -0
- package/dist/src/client/actors/fileSystemInit.d.ts.map +1 -0
- package/dist/src/client/actors/platformClassesInit.d.ts.map +1 -0
- package/dist/src/client/actors/processSchemaFiles.d.ts.map +1 -0
- package/dist/src/client/actors/saveAppState.d.ts.map +1 -0
- package/dist/src/client/actors/saveConfig.d.ts.map +1 -0
- package/dist/src/client/clientManagerMachine.d.ts.map +1 -0
- package/dist/src/client/constants.d.ts.map +1 -0
- package/dist/src/client/index.d.ts.map +1 -0
- package/dist/src/db/Db/BaseDb.d.ts.map +1 -0
- package/dist/src/db/configs/dev.schema.config.d.ts.map +1 -0
- package/dist/src/db/read/getExistingItem.d.ts.map +1 -0
- package/dist/src/db/read/getItem.d.ts.map +1 -0
- package/dist/src/db/read/getItemData.d.ts.map +1 -0
- package/dist/src/db/read/getItemProperties.d.ts.map +1 -0
- package/dist/src/db/read/getItemProperty.d.ts.map +1 -0
- package/dist/src/db/read/getItems.d.ts +11 -0
- package/dist/src/db/read/getItems.d.ts.map +1 -0
- package/dist/src/db/read/getMetadata.d.ts.map +1 -0
- package/dist/src/db/read/getModelPropertiesData.d.ts.map +1 -0
- package/dist/src/db/read/getModelSchemas.d.ts.map +1 -0
- package/dist/src/db/read/getModels.d.ts.map +1 -0
- package/dist/src/db/read/getModelsData.d.ts.map +1 -0
- package/dist/src/db/read/getPropertyData.d.ts.map +1 -0
- package/dist/src/db/read/getPublishPayload.d.ts +36 -0
- package/dist/src/db/read/getPublishPayload.d.ts.map +1 -0
- package/dist/src/db/read/getPublishUploads.d.ts +10 -0
- package/dist/src/db/read/getPublishUploads.d.ts.map +1 -0
- package/dist/src/db/read/getRelatedItemsForPublish.d.ts +8 -0
- package/dist/src/db/read/getRelatedItemsForPublish.d.ts.map +1 -0
- package/dist/src/db/read/getRelationValueData.d.ts.map +1 -0
- package/dist/src/db/read/getSchemaUidForModel.d.ts +2 -0
- package/dist/src/db/read/getSchemaUidForModel.d.ts.map +1 -0
- package/dist/src/db/read/getSeedData.d.ts.map +1 -0
- package/dist/src/db/read/getStorageTransactionIdForSeedUid.d.ts.map +1 -0
- package/dist/src/db/read/getVersionData.d.ts.map +1 -0
- package/dist/src/db/read/getVersionsForVersionUids.d.ts.map +1 -0
- package/dist/src/db/read/subqueries/metadataLatest.d.ts.map +1 -0
- package/dist/src/db/read/subqueries/versionData.d.ts.map +1 -0
- package/dist/src/db/write/createMetadata.d.ts.map +1 -0
- package/dist/src/db/write/createNewItem.d.ts.map +1 -0
- package/dist/src/db/write/createSeed.d.ts.map +1 -0
- package/dist/src/db/write/createSeeds.d.ts.map +1 -0
- package/dist/src/db/write/createVersion.d.ts.map +1 -0
- package/dist/src/db/write/deleteItem.d.ts.map +1 -0
- package/dist/src/db/write/recoverDeletedItem.d.ts.map +1 -0
- package/dist/src/db/write/saveAppState.d.ts.map +1 -0
- package/dist/src/db/write/saveMetadata.d.ts.map +1 -0
- package/dist/src/db/write/updateItemPropertyValue.d.ts.map +1 -0
- package/dist/src/db/write/updateMetadata.d.ts.map +1 -0
- package/dist/src/db/write/updateSeedUid.d.ts.map +1 -0
- package/dist/src/eas.d.ts +26 -0
- package/dist/src/eas.d.ts.map +1 -0
- package/dist/src/eslint-rules/align-imports.d.ts.map +1 -0
- package/dist/src/eventBus.d.ts.map +1 -0
- package/dist/src/events/files/download.d.ts.map +1 -0
- package/dist/src/events/files/index.d.ts.map +1 -0
- package/dist/src/events/index.d.ts.map +1 -0
- package/dist/src/events/item/index.d.ts.map +1 -0
- package/dist/src/events/item/syncDbWithEas.d.ts.map +1 -0
- package/dist/src/events/services/allItems.d.ts.map +1 -0
- package/dist/src/events/services/index.d.ts.map +1 -0
- package/dist/src/graphql/fragments/Attestation.d.ts.map +1 -0
- package/dist/src/graphql/fragments/Schema.d.ts.map +1 -0
- package/dist/src/graphql/fragments/index.d.ts.map +1 -0
- package/dist/src/graphql/gql/fragment-masking.d.ts.map +1 -0
- package/dist/src/graphql/gql/gql.d.ts.map +1 -0
- package/dist/src/graphql/gql/graphql.d.ts.map +1 -0
- package/dist/src/graphql/gql/index.d.ts.map +1 -0
- package/dist/src/helpers/ArweaveClient/BaseArweaveClient.d.ts.map +1 -0
- package/dist/src/helpers/ArweaveClient/index.d.ts.map +1 -0
- package/dist/src/helpers/ArweaveClient/queries.d.ts.map +1 -0
- package/dist/src/helpers/EasClient/BaseEasClient.d.ts.map +1 -0
- package/dist/src/helpers/FileManager/BaseFileManager.d.ts +41 -0
- package/dist/src/helpers/FileManager/BaseFileManager.d.ts.map +1 -0
- package/dist/src/helpers/PathResolver/BasePathResolver.d.ts.map +1 -0
- package/dist/src/helpers/QueryClient/BaseQueryClient.d.ts.map +1 -0
- package/dist/src/helpers/addresses.d.ts +12 -0
- package/dist/src/helpers/addresses.d.ts.map +1 -0
- package/dist/src/helpers/constants.d.ts +71 -0
- package/dist/src/helpers/constants.d.ts.map +1 -0
- package/dist/src/helpers/crypto.d.ts.map +1 -0
- package/dist/src/helpers/db.d.ts +143 -0
- package/dist/src/helpers/db.d.ts.map +1 -0
- package/dist/src/helpers/entity/entityCache.d.ts.map +1 -0
- package/dist/src/helpers/entity/entityCommon.d.ts.map +1 -0
- package/dist/src/helpers/entity/entityDestroy.d.ts.map +1 -0
- package/dist/src/helpers/entity/entityFind.d.ts.map +1 -0
- package/dist/src/helpers/entity/entityLiveQuery.d.ts.map +1 -0
- package/dist/src/helpers/entity/entityUnload.d.ts +54 -0
- package/dist/src/helpers/entity/entityUnload.d.ts.map +1 -0
- package/dist/src/helpers/entity/index.d.ts.map +1 -0
- package/dist/src/helpers/environment.d.ts.map +1 -0
- package/dist/src/helpers/file/download/actors.d.ts.map +1 -0
- package/dist/src/helpers/file/download/index.d.ts.map +1 -0
- package/dist/src/helpers/file/fetchAll/actors.d.ts.map +1 -0
- package/dist/src/helpers/file/fetchAll/index.d.ts.map +1 -0
- package/dist/src/helpers/file/queries.d.ts.map +1 -0
- package/dist/src/helpers/files.d.ts.map +1 -0
- package/dist/src/helpers/getSchemaForItemProperty.d.ts +15 -0
- package/dist/src/helpers/getSchemaForItemProperty.d.ts.map +1 -0
- package/dist/src/helpers/getSegmentedItemProperties.d.ts.map +1 -0
- package/dist/src/helpers/image/queries.d.ts.map +1 -0
- package/dist/src/helpers/index.d.ts +30 -0
- package/dist/src/helpers/index.d.ts.map +1 -0
- package/dist/src/helpers/model.d.ts.map +1 -0
- package/dist/src/helpers/ownership.d.ts +16 -0
- package/dist/src/helpers/ownership.d.ts.map +1 -0
- package/dist/src/helpers/property/index.d.ts +304 -0
- package/dist/src/helpers/property/index.d.ts.map +1 -0
- package/dist/src/helpers/property.d.ts.map +1 -0
- package/dist/src/helpers/publishConfig.d.ts +18 -0
- package/dist/src/helpers/publishConfig.d.ts.map +1 -0
- package/dist/src/helpers/reactiveProxy.d.ts.map +1 -0
- package/dist/src/helpers/schema.d.ts.map +1 -0
- package/dist/src/helpers/updateMachineContext.d.ts.map +1 -0
- package/dist/src/helpers/updateSchema.d.ts +128 -0
- package/dist/src/helpers/updateSchema.d.ts.map +1 -0
- package/dist/src/helpers/waitForEntityIdle.d.ts.map +1 -0
- package/dist/src/imports/index.d.ts.map +1 -0
- package/dist/src/imports/json.d.ts.map +1 -0
- package/dist/src/imports/markdown.d.ts +40 -0
- package/dist/src/imports/markdown.d.ts.map +1 -0
- package/dist/src/index.d.ts +31 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/interfaces/IDb.d.ts.map +1 -0
- package/dist/src/interfaces/IEasClient.d.ts.map +1 -0
- package/dist/src/interfaces/IItem.d.ts.map +1 -0
- package/dist/src/interfaces/IItemProperty.d.ts.map +1 -0
- package/dist/src/interfaces/IQueryClient.d.ts.map +1 -0
- package/dist/src/interfaces/index.d.ts.map +1 -0
- package/dist/src/node/codegen/drizzle.d.ts.map +1 -0
- package/dist/src/node/codegen/index.d.ts.map +1 -0
- package/dist/src/node/codegen/ts-to-proto.d.ts.map +1 -0
- package/dist/src/node/constants.d.ts.map +1 -0
- package/dist/src/node/db/Db.d.ts.map +1 -0
- package/dist/src/node/db/index.d.ts.map +1 -0
- package/dist/src/node/db/node.app.db.config.d.ts.map +1 -0
- package/dist/src/node/helpers/ArweaveClient.d.ts.map +1 -0
- package/dist/src/node/helpers/EasClient.d.ts.map +1 -0
- package/dist/src/node/helpers/FileManager.d.ts +27 -0
- package/dist/src/node/helpers/FileManager.d.ts.map +1 -0
- package/dist/src/node/helpers/PathResolver.d.ts.map +1 -0
- package/dist/src/node/helpers/QueryClient.d.ts.map +1 -0
- package/dist/src/node/helpers/index.d.ts.map +1 -0
- package/dist/src/node/helpers/scripts.d.ts.map +1 -0
- package/dist/src/node/index.d.ts.map +1 -0
- package/dist/src/node/seed.d.ts.map +1 -0
- package/dist/src/node/webpack/fs-proxy.d.ts.map +1 -0
- package/dist/src/node/webpack/index.d.ts.map +1 -0
- package/dist/src/seedSchema/AppStateSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/ConfigSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/MetadataSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/ModelSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/ModelSchemaSchema.d.ts +61 -0
- package/dist/src/seedSchema/ModelSchemaSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/ModelUidSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/PropertyUidSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/SchemaSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/SeedSchema.d.ts +192 -0
- package/dist/src/seedSchema/SeedSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/VersionSchema.d.ts.map +1 -0
- package/dist/src/seedSchema/index.d.ts +11 -0
- package/dist/src/seedSchema/index.d.ts.map +1 -0
- package/dist/src/services/events.d.ts.map +1 -0
- package/dist/src/services/publish/actors/createPublishAttempt.d.ts.map +1 -0
- package/dist/src/services/publish/actors/preparePublishRequestData.d.ts.map +1 -0
- package/dist/src/services/publish/actors/upload.d.ts.map +1 -0
- package/dist/src/services/publish/actors/validateItemData.d.ts.map +1 -0
- package/dist/src/services/publish/publishMachine.d.ts.map +1 -0
- package/dist/src/services/write/actors/validateEntity.d.ts.map +1 -0
- package/dist/src/services/write/actors/writeToDatabase.d.ts.map +1 -0
- package/dist/src/services/write/writeProcessMachine.d.ts.map +1 -0
- package/dist/src/stores/eas.d.ts +20 -0
- package/dist/src/stores/eas.d.ts.map +1 -0
- package/dist/src/types/arweave.d.ts.map +1 -0
- package/dist/src/types/browser.d.ts.map +1 -0
- package/dist/src/types/db.d.ts.map +1 -0
- package/dist/src/types/fileManager.d.ts.map +1 -0
- package/dist/src/types/helpers.d.ts.map +1 -0
- package/dist/src/types/import.d.ts.map +1 -0
- package/dist/src/types/index.d.ts +66 -0
- package/dist/src/types/index.d.ts.map +1 -0
- package/dist/src/types/item.d.ts +85 -0
- package/dist/src/types/item.d.ts.map +1 -0
- package/dist/src/types/machines.d.ts +53 -0
- package/dist/src/types/machines.d.ts.map +1 -0
- package/dist/src/types/model.d.ts.map +1 -0
- package/dist/src/types/property.d.ts.map +1 -0
- package/dist/src/types/publish.d.ts.map +1 -0
- package/dist/src/types/seedProtocol.d.ts.map +1 -0
- package/dist/src/types/services.d.ts.map +1 -0
- package/dist/src/vite/easFix.d.ts.map +1 -0
- package/dist/src/vite/index.d.ts.map +1 -0
- package/dist/vite.cjs +0 -5
- package/dist/vite.cjs.map +1 -1
- package/dist/vite.js +0 -5
- package/dist/vite.js.map +1 -1
- package/package.json +21 -113
- package/README.md +0 -67
- package/dist/ArweaveClient-Caio37h1.js +0 -202
- package/dist/ArweaveClient-Caio37h1.js.map +0 -1
- package/dist/ArweaveClient-DLKAaS3K.js +0 -202
- package/dist/ArweaveClient-DLKAaS3K.js.map +0 -1
- package/dist/Db-C9fppVRl.js +0 -1514
- package/dist/Db-C9fppVRl.js.map +0 -1
- package/dist/Db-DJAG-5Di.js +0 -345
- package/dist/Db-DJAG-5Di.js.map +0 -1
- package/dist/EasClient-DQGAIj-b.js +0 -29
- package/dist/EasClient-DQGAIj-b.js.map +0 -1
- package/dist/EasClient-T7Nx9185.js +0 -29
- package/dist/EasClient-T7Nx9185.js.map +0 -1
- package/dist/FileManager-BohtoKYo.js +0 -1153
- package/dist/FileManager-BohtoKYo.js.map +0 -1
- package/dist/FileManager-d64CkqXy.js +0 -165
- package/dist/FileManager-d64CkqXy.js.map +0 -1
- package/dist/Item/Item.d.ts +0 -134
- package/dist/Item/Item.d.ts.map +0 -1
- package/dist/Item/queries.d.ts.map +0 -1
- package/dist/Item/service/actors/fetchDataFromEas.d.ts.map +0 -1
- package/dist/Item/service/actors/hydrateExistingItem.d.ts.map +0 -1
- package/dist/Item/service/actors/hydrateNewItem.d.ts.map +0 -1
- package/dist/Item/service/actors/initialize.d.ts.map +0 -1
- package/dist/Item/service/actors/loadOrCreateItem.d.ts.map +0 -1
- package/dist/Item/service/actors/reload.d.ts.map +0 -1
- package/dist/Item/service/actors/runPublish.d.ts.map +0 -1
- package/dist/Item/service/actors/saveDataToDb.d.ts.map +0 -1
- package/dist/Item/service/actors/waitForDb.d.ts.map +0 -1
- package/dist/Item/service/itemMachineSingle.d.ts.map +0 -1
- package/dist/ItemProperty/ItemProperty.d.ts +0 -118
- package/dist/ItemProperty/ItemProperty.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/hydrateFromDb.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/initialize.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/loadOrCreateProperty.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/resolveRelatedValue.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/resolveRemoteStorage.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/saveValueToDb/analyzeInput.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/saveValueToDb/index.d.ts +0 -5
- package/dist/ItemProperty/service/actors/saveValueToDb/index.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/saveValueToDb/saveImage.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/saveValueToDb/saveItemStorage.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/saveValueToDb/saveRelation.d.ts.map +0 -1
- package/dist/ItemProperty/service/actors/waitForDb.d.ts.map +0 -1
- package/dist/ItemProperty/service/propertyMachine.d.ts +0 -68
- package/dist/ItemProperty/service/propertyMachine.d.ts.map +0 -1
- package/dist/Model/Model.d.ts +0 -225
- package/dist/Model/Model.d.ts.map +0 -1
- package/dist/Model/index.d.ts.map +0 -1
- package/dist/Model/service/actors/createModelProperties.d.ts.map +0 -1
- package/dist/Model/service/actors/loadOrCreateModel.d.ts.map +0 -1
- package/dist/Model/service/actors/validateModel.d.ts.map +0 -1
- package/dist/Model/service/modelMachine.d.ts +0 -222
- package/dist/Model/service/modelMachine.d.ts.map +0 -1
- package/dist/ModelProperty/ModelProperty.d.ts +0 -146
- package/dist/ModelProperty/ModelProperty.d.ts.map +0 -1
- package/dist/ModelProperty/service/actors/compareAndMarkDraft.d.ts.map +0 -1
- package/dist/ModelProperty/service/actors/saveToSchema.d.ts.map +0 -1
- package/dist/ModelProperty/service/actors/validateProperty.d.ts.map +0 -1
- package/dist/ModelProperty/service/modelPropertyMachine.d.ts.map +0 -1
- package/dist/ModelProperty-Cpd9xiIM.js +0 -1784
- package/dist/ModelProperty-Cpd9xiIM.js.map +0 -1
- package/dist/PathResolver-CLZUWoX2.js +0 -78
- package/dist/PathResolver-CLZUWoX2.js.map +0 -1
- package/dist/PathResolver-D6M0rzKV.js +0 -191
- package/dist/PathResolver-D6M0rzKV.js.map +0 -1
- package/dist/QueryClient-BUoz2Vb0.js +0 -47
- package/dist/QueryClient-BUoz2Vb0.js.map +0 -1
- package/dist/QueryClient-COQ_Rs4-.js +0 -34
- package/dist/QueryClient-COQ_Rs4-.js.map +0 -1
- package/dist/Schema/Schema.d.ts.map +0 -1
- package/dist/Schema/errors.d.ts.map +0 -1
- package/dist/Schema/index.d.ts.map +0 -1
- package/dist/Schema/service/actors/checkExistingSchema.d.ts.map +0 -1
- package/dist/Schema/service/actors/createModelInstances.d.ts.map +0 -1
- package/dist/Schema/service/actors/createPropertyInstances.d.ts.map +0 -1
- package/dist/Schema/service/actors/loadOrCreateSchema.d.ts.map +0 -1
- package/dist/Schema/service/actors/validateSchema.d.ts.map +0 -1
- package/dist/Schema/service/actors/verifyModelInstancesInCache.d.ts.map +0 -1
- package/dist/Schema/service/actors/verifyModelsInDb.d.ts.map +0 -1
- package/dist/Schema/service/actors/verifyPropertiesInDb.d.ts.map +0 -1
- package/dist/Schema/service/actors/verifyPropertyInstancesInCache.d.ts.map +0 -1
- package/dist/Schema/service/actors/verifySchemaInDb.d.ts.map +0 -1
- package/dist/Schema/service/actors/writeModelsToDb.d.ts.map +0 -1
- package/dist/Schema/service/actors/writePropertiesToDb.d.ts.map +0 -1
- package/dist/Schema/service/actors/writeSchemaToDb.d.ts.map +0 -1
- package/dist/Schema/service/addModelsMachine.d.ts +0 -123
- package/dist/Schema/service/addModelsMachine.d.ts.map +0 -1
- package/dist/Schema/service/schemaMachine.d.ts +0 -526
- package/dist/Schema/service/schemaMachine.d.ts.map +0 -1
- package/dist/Schema/service/validation/SchemaValidationService.d.ts.map +0 -1
- package/dist/Schema/validation.d.ts.map +0 -1
- package/dist/Schema-BZKBy5Tx.js +0 -6593
- package/dist/Schema-BZKBy5Tx.js.map +0 -1
- package/dist/SchemaValidationService-F8No7BHp.js +0 -563
- package/dist/SchemaValidationService-F8No7BHp.js.map +0 -1
- package/dist/browser/db/Db.d.ts.map +0 -1
- package/dist/browser/db/drizzleFiles.d.ts +0 -7
- package/dist/browser/db/drizzleFiles.d.ts.map +0 -1
- package/dist/browser/db/sqlWasmClient.d.ts.map +0 -1
- package/dist/browser/helpers/ArweaveClient.d.ts.map +0 -1
- package/dist/browser/helpers/EasClient.d.ts.map +0 -1
- package/dist/browser/helpers/FileManager.d.ts +0 -41
- package/dist/browser/helpers/FileManager.d.ts.map +0 -1
- package/dist/browser/helpers/PathResolver.d.ts.map +0 -1
- package/dist/browser/helpers/QueryClient.d.ts.map +0 -1
- package/dist/browser/helpers/index.d.ts.map +0 -1
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/react/OPFSImage.d.ts.map +0 -1
- package/dist/browser/react/SeedImage.d.ts.map +0 -1
- package/dist/browser/react/SeedProvider.d.ts.map +0 -1
- package/dist/browser/react/client.d.ts.map +0 -1
- package/dist/browser/react/db.d.ts.map +0 -1
- package/dist/browser/react/index.d.ts +0 -13
- package/dist/browser/react/index.d.ts.map +0 -1
- package/dist/browser/react/item.d.ts +0 -42
- package/dist/browser/react/item.d.ts.map +0 -1
- package/dist/browser/react/itemProperty.d.ts.map +0 -1
- package/dist/browser/react/liveQuery.d.ts.map +0 -1
- package/dist/browser/react/model.d.ts.map +0 -1
- package/dist/browser/react/modelProperty.d.ts.map +0 -1
- package/dist/browser/react/queryClient.d.ts.map +0 -1
- package/dist/browser/react/schema.d.ts.map +0 -1
- package/dist/browser/react/services.d.ts.map +0 -1
- package/dist/browser/react/trash.d.ts.map +0 -1
- package/dist/browser/seed.d.ts.map +0 -1
- package/dist/browser/workers/FileDownloader.d.ts.map +0 -1
- package/dist/browser/workers/ImageResizer.d.ts.map +0 -1
- package/dist/browser/workers/content-hash.d.ts.map +0 -1
- package/dist/browser/workers/dbWorker.d.ts.map +0 -1
- package/dist/browser/workers/filesDownload.d.ts.map +0 -1
- package/dist/browser/workers/imageResize.d.ts.map +0 -1
- package/dist/cjs/ModelProperty-B4pV91tc.js +0 -1780
- package/dist/cjs/ModelProperty-B4pV91tc.js.map +0 -1
- package/dist/cjs/Schema-TErl3J36.js +0 -6217
- package/dist/cjs/Schema-TErl3J36.js.map +0 -1
- package/dist/cjs/SchemaValidationService-p5BbJV9T.js +0 -579
- package/dist/cjs/SchemaValidationService-p5BbJV9T.js.map +0 -1
- package/dist/cjs/getItem-BrnLfC12.js +0 -55
- package/dist/cjs/getItem-BrnLfC12.js.map +0 -1
- package/dist/cjs/getPublishPayload-BcjCN_bD.js +0 -340
- package/dist/cjs/getPublishPayload-BcjCN_bD.js.map +0 -1
- package/dist/cjs/getPublishUploads-5_oXzwol.js +0 -229
- package/dist/cjs/getPublishUploads-5_oXzwol.js.map +0 -1
- package/dist/cjs/getSegmentedItemProperties-WFdizUDv.js +0 -61
- package/dist/cjs/getSegmentedItemProperties-WFdizUDv.js.map +0 -1
- package/dist/cjs/index-BrmvhXsG.js +0 -57
- package/dist/cjs/index-BrmvhXsG.js.map +0 -1
- package/dist/cjs/index-CXI4VF1H.js +0 -16804
- package/dist/cjs/index-CXI4VF1H.js.map +0 -1
- package/dist/client/BaseClientManager.d.ts.map +0 -1
- package/dist/client/ClientManager.d.ts +0 -209
- package/dist/client/ClientManager.d.ts.map +0 -1
- package/dist/client/actions/setAddresses.d.ts.map +0 -1
- package/dist/client/actors/addModelsToDb.d.ts.map +0 -1
- package/dist/client/actors/addModelsToStore.d.ts.map +0 -1
- package/dist/client/actors/dbInit.d.ts.map +0 -1
- package/dist/client/actors/fileSystemInit.d.ts.map +0 -1
- package/dist/client/actors/platformClassesInit.d.ts.map +0 -1
- package/dist/client/actors/processSchemaFiles.d.ts.map +0 -1
- package/dist/client/actors/saveAppState.d.ts.map +0 -1
- package/dist/client/actors/saveConfig.d.ts.map +0 -1
- package/dist/client/clientManagerMachine.d.ts.map +0 -1
- package/dist/client/constants.d.ts.map +0 -1
- package/dist/client/index.d.ts.map +0 -1
- package/dist/db/Db/BaseDb.d.ts.map +0 -1
- package/dist/db/configs/dev.schema.config.d.ts.map +0 -1
- package/dist/db/read/getExistingItem.d.ts.map +0 -1
- package/dist/db/read/getItem.d.ts.map +0 -1
- package/dist/db/read/getItemData.d.ts.map +0 -1
- package/dist/db/read/getItemProperties.d.ts.map +0 -1
- package/dist/db/read/getItemProperty.d.ts.map +0 -1
- package/dist/db/read/getItems.d.ts +0 -9
- package/dist/db/read/getItems.d.ts.map +0 -1
- package/dist/db/read/getMetadata.d.ts.map +0 -1
- package/dist/db/read/getModelPropertiesData.d.ts.map +0 -1
- package/dist/db/read/getModelSchemas.d.ts.map +0 -1
- package/dist/db/read/getModels.d.ts.map +0 -1
- package/dist/db/read/getModelsData.d.ts.map +0 -1
- package/dist/db/read/getPropertyData.d.ts.map +0 -1
- package/dist/db/read/getPublishPayload.d.ts +0 -23
- package/dist/db/read/getPublishPayload.d.ts.map +0 -1
- package/dist/db/read/getPublishUploads.d.ts +0 -10
- package/dist/db/read/getPublishUploads.d.ts.map +0 -1
- package/dist/db/read/getRelationValueData.d.ts.map +0 -1
- package/dist/db/read/getSchemaUidForModel.d.ts +0 -2
- package/dist/db/read/getSchemaUidForModel.d.ts.map +0 -1
- package/dist/db/read/getSeedData.d.ts.map +0 -1
- package/dist/db/read/getStorageTransactionIdForSeedUid.d.ts.map +0 -1
- package/dist/db/read/getVersionData.d.ts.map +0 -1
- package/dist/db/read/getVersionsForVersionUids.d.ts.map +0 -1
- package/dist/db/read/subqueries/metadataLatest.d.ts.map +0 -1
- package/dist/db/read/subqueries/versionData.d.ts.map +0 -1
- package/dist/db/write/createMetadata.d.ts.map +0 -1
- package/dist/db/write/createNewItem.d.ts.map +0 -1
- package/dist/db/write/createSeed.d.ts.map +0 -1
- package/dist/db/write/createSeeds.d.ts.map +0 -1
- package/dist/db/write/createVersion.d.ts.map +0 -1
- package/dist/db/write/deleteItem.d.ts.map +0 -1
- package/dist/db/write/recoverDeletedItem.d.ts.map +0 -1
- package/dist/db/write/saveAppState.d.ts.map +0 -1
- package/dist/db/write/saveMetadata.d.ts.map +0 -1
- package/dist/db/write/updateItemPropertyValue.d.ts.map +0 -1
- package/dist/db/write/updateMetadata.d.ts.map +0 -1
- package/dist/db/write/updateSeedUid.d.ts.map +0 -1
- package/dist/eas.d.ts +0 -26
- package/dist/eas.d.ts.map +0 -1
- package/dist/eslint-rules/align-imports.d.ts.map +0 -1
- package/dist/eventBus.d.ts.map +0 -1
- package/dist/events/files/download.d.ts.map +0 -1
- package/dist/events/files/index.d.ts.map +0 -1
- package/dist/events/index.d.ts.map +0 -1
- package/dist/events/item/index.d.ts.map +0 -1
- package/dist/events/item/syncDbWithEas.d.ts.map +0 -1
- package/dist/events/services/allItems.d.ts.map +0 -1
- package/dist/events/services/index.d.ts.map +0 -1
- package/dist/feed.d.ts +0 -2
- package/dist/feed.d.ts.map +0 -1
- package/dist/getItem-DaQVdeae.js +0 -38
- package/dist/getItem-DaQVdeae.js.map +0 -1
- package/dist/getPublishPayload-CWiLI1yd.js +0 -324
- package/dist/getPublishPayload-CWiLI1yd.js.map +0 -1
- package/dist/getPublishUploads-DhvcKD_9.js +0 -193
- package/dist/getPublishUploads-DhvcKD_9.js.map +0 -1
- package/dist/getSegmentedItemProperties-Cp4kcWIF.js +0 -59
- package/dist/getSegmentedItemProperties-Cp4kcWIF.js.map +0 -1
- package/dist/graphql/fragments/Attestation.d.ts.map +0 -1
- package/dist/graphql/fragments/Schema.d.ts.map +0 -1
- package/dist/graphql/fragments/index.d.ts.map +0 -1
- package/dist/graphql/gql/fragment-masking.d.ts.map +0 -1
- package/dist/graphql/gql/gql.d.ts.map +0 -1
- package/dist/graphql/gql/graphql.d.ts.map +0 -1
- package/dist/graphql/gql/index.d.ts.map +0 -1
- package/dist/helpers/ArweaveClient/BaseArweaveClient.d.ts.map +0 -1
- package/dist/helpers/ArweaveClient/index.d.ts.map +0 -1
- package/dist/helpers/ArweaveClient/queries.d.ts.map +0 -1
- package/dist/helpers/EasClient/BaseEasClient.d.ts.map +0 -1
- package/dist/helpers/FileManager/BaseFileManager.d.ts +0 -29
- package/dist/helpers/FileManager/BaseFileManager.d.ts.map +0 -1
- package/dist/helpers/PathResolver/BasePathResolver.d.ts.map +0 -1
- package/dist/helpers/QueryClient/BaseQueryClient.d.ts.map +0 -1
- package/dist/helpers/constants.d.ts +0 -67
- package/dist/helpers/constants.d.ts.map +0 -1
- package/dist/helpers/crypto.d.ts.map +0 -1
- package/dist/helpers/db.d.ts +0 -131
- package/dist/helpers/db.d.ts.map +0 -1
- package/dist/helpers/entity/entityCache.d.ts.map +0 -1
- package/dist/helpers/entity/entityCommon.d.ts.map +0 -1
- package/dist/helpers/entity/entityDestroy.d.ts.map +0 -1
- package/dist/helpers/entity/entityFind.d.ts.map +0 -1
- package/dist/helpers/entity/entityLiveQuery.d.ts.map +0 -1
- package/dist/helpers/entity/entityUnload.d.ts +0 -50
- package/dist/helpers/entity/entityUnload.d.ts.map +0 -1
- package/dist/helpers/entity/index.d.ts.map +0 -1
- package/dist/helpers/environment.d.ts.map +0 -1
- package/dist/helpers/file/download/actors.d.ts.map +0 -1
- package/dist/helpers/file/download/index.d.ts.map +0 -1
- package/dist/helpers/file/fetchAll/actors.d.ts.map +0 -1
- package/dist/helpers/file/fetchAll/index.d.ts.map +0 -1
- package/dist/helpers/file/queries.d.ts.map +0 -1
- package/dist/helpers/files.d.ts.map +0 -1
- package/dist/helpers/getSchemaForItemProperty.d.ts +0 -15
- package/dist/helpers/getSchemaForItemProperty.d.ts.map +0 -1
- package/dist/helpers/getSegmentedItemProperties.d.ts.map +0 -1
- package/dist/helpers/image/queries.d.ts.map +0 -1
- package/dist/helpers/index.d.ts +0 -29
- package/dist/helpers/index.d.ts.map +0 -1
- package/dist/helpers/model.d.ts.map +0 -1
- package/dist/helpers/property/index.d.ts +0 -298
- package/dist/helpers/property/index.d.ts.map +0 -1
- package/dist/helpers/property.d.ts.map +0 -1
- package/dist/helpers/reactiveProxy.d.ts.map +0 -1
- package/dist/helpers/schema.d.ts.map +0 -1
- package/dist/helpers/updateMachineContext.d.ts.map +0 -1
- package/dist/helpers/updateSchema.d.ts +0 -118
- package/dist/helpers/updateSchema.d.ts.map +0 -1
- package/dist/helpers/waitForEntityIdle.d.ts.map +0 -1
- package/dist/imports/index.d.ts.map +0 -1
- package/dist/imports/json.d.ts.map +0 -1
- package/dist/imports/markdown.d.ts +0 -38
- package/dist/imports/markdown.d.ts.map +0 -1
- package/dist/index-DBy53qbb.js +0 -23
- package/dist/index-DBy53qbb.js.map +0 -1
- package/dist/index-Dk73a7JE.js +0 -15426
- package/dist/index-Dk73a7JE.js.map +0 -1
- package/dist/index-LfXKx_PE.js +0 -18
- package/dist/index-LfXKx_PE.js.map +0 -1
- package/dist/index.d.ts +0 -22
- package/dist/index.d.ts.map +0 -1
- package/dist/interfaces/IDb.d.ts.map +0 -1
- package/dist/interfaces/IEasClient.d.ts.map +0 -1
- package/dist/interfaces/IItem.d.ts.map +0 -1
- package/dist/interfaces/IItemProperty.d.ts.map +0 -1
- package/dist/interfaces/IQueryClient.d.ts.map +0 -1
- package/dist/interfaces/index.d.ts.map +0 -1
- package/dist/node/codegen/drizzle.d.ts.map +0 -1
- package/dist/node/codegen/index.d.ts.map +0 -1
- package/dist/node/codegen/ts-to-proto.d.ts.map +0 -1
- package/dist/node/constants.d.ts.map +0 -1
- package/dist/node/db/Db.d.ts.map +0 -1
- package/dist/node/db/index.d.ts.map +0 -1
- package/dist/node/db/node.app.db.config.d.ts.map +0 -1
- package/dist/node/helpers/ArweaveClient.d.ts.map +0 -1
- package/dist/node/helpers/EasClient.d.ts.map +0 -1
- package/dist/node/helpers/FileManager.d.ts +0 -26
- package/dist/node/helpers/FileManager.d.ts.map +0 -1
- package/dist/node/helpers/PathResolver.d.ts.map +0 -1
- package/dist/node/helpers/QueryClient.d.ts.map +0 -1
- package/dist/node/helpers/index.d.ts.map +0 -1
- package/dist/node/helpers/scripts.d.ts.map +0 -1
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/seed.d.ts.map +0 -1
- package/dist/node/webpack/fs-proxy.d.ts.map +0 -1
- package/dist/node/webpack/index.d.ts.map +0 -1
- package/dist/property-1o2MvYTm.js +0 -282
- package/dist/property-1o2MvYTm.js.map +0 -1
- package/dist/queries-DA4G0iEN.js +0 -16
- package/dist/queries-DA4G0iEN.js.map +0 -1
- package/dist/seedSchema/AppStateSchema.d.ts.map +0 -1
- package/dist/seedSchema/ConfigSchema.d.ts.map +0 -1
- package/dist/seedSchema/MetadataSchema.d.ts.map +0 -1
- package/dist/seedSchema/ModelSchema.d.ts.map +0 -1
- package/dist/seedSchema/ModelSchemaSchema.d.ts +0 -61
- package/dist/seedSchema/ModelSchemaSchema.d.ts.map +0 -1
- package/dist/seedSchema/ModelUidSchema.d.ts.map +0 -1
- package/dist/seedSchema/PropertyUidSchema.d.ts.map +0 -1
- package/dist/seedSchema/SchemaSchema.d.ts.map +0 -1
- package/dist/seedSchema/SeedSchema.d.ts +0 -173
- package/dist/seedSchema/SeedSchema.d.ts.map +0 -1
- package/dist/seedSchema/VersionSchema.d.ts.map +0 -1
- package/dist/seedSchema/index.d.ts +0 -11
- package/dist/seedSchema/index.d.ts.map +0 -1
- package/dist/services/events.d.ts.map +0 -1
- package/dist/services/publish/actors/createPublishAttempt.d.ts.map +0 -1
- package/dist/services/publish/actors/preparePublishRequestData.d.ts.map +0 -1
- package/dist/services/publish/actors/upload.d.ts.map +0 -1
- package/dist/services/publish/actors/validateItemData.d.ts.map +0 -1
- package/dist/services/publish/publishMachine.d.ts.map +0 -1
- package/dist/services/write/actors/validateEntity.d.ts.map +0 -1
- package/dist/services/write/actors/writeToDatabase.d.ts.map +0 -1
- package/dist/services/write/writeProcessMachine.d.ts.map +0 -1
- package/dist/stores/eas.d.ts +0 -14
- package/dist/stores/eas.d.ts.map +0 -1
- package/dist/types/arweave.d.ts.map +0 -1
- package/dist/types/browser.d.ts.map +0 -1
- package/dist/types/db.d.ts.map +0 -1
- package/dist/types/fileManager.d.ts.map +0 -1
- package/dist/types/helpers.d.ts.map +0 -1
- package/dist/types/import.d.ts.map +0 -1
- package/dist/types/index.d.ts +0 -54
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/item.d.ts +0 -84
- package/dist/types/item.d.ts.map +0 -1
- package/dist/types/machines.d.ts +0 -50
- package/dist/types/machines.d.ts.map +0 -1
- package/dist/types/model.d.ts.map +0 -1
- package/dist/types/property.d.ts.map +0 -1
- package/dist/types/publish.d.ts.map +0 -1
- package/dist/types/seedProtocol.d.ts.map +0 -1
- package/dist/types/services.d.ts.map +0 -1
- package/dist/vite/easFix.d.ts.map +0 -1
- package/dist/vite/index.d.ts.map +0 -1
- /package/dist/{Item → src/Item}/queries.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/fetchDataFromEas.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/hydrateExistingItem.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/hydrateNewItem.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/initialize.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/loadOrCreateItem.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/reload.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/runPublish.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/saveDataToDb.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/actors/waitForDb.d.ts +0 -0
- /package/dist/{Item → src/Item}/service/itemMachineSingle.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/hydrateFromDb.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/initialize.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/loadOrCreateProperty.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/resolveRelatedValue.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/resolveRemoteStorage.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/analyzeInput.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/saveImage.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/saveItemStorage.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/saveRelation.d.ts +0 -0
- /package/dist/{ItemProperty → src/ItemProperty}/service/actors/waitForDb.d.ts +0 -0
- /package/dist/{Model → src/Model}/index.d.ts +0 -0
- /package/dist/{Model → src/Model}/service/actors/createModelProperties.d.ts +0 -0
- /package/dist/{Model → src/Model}/service/actors/loadOrCreateModel.d.ts +0 -0
- /package/dist/{Model → src/Model}/service/actors/validateModel.d.ts +0 -0
- /package/dist/{ModelProperty → src/ModelProperty}/service/actors/compareAndMarkDraft.d.ts +0 -0
- /package/dist/{ModelProperty → src/ModelProperty}/service/actors/saveToSchema.d.ts +0 -0
- /package/dist/{ModelProperty → src/ModelProperty}/service/actors/validateProperty.d.ts +0 -0
- /package/dist/{ModelProperty → src/ModelProperty}/service/modelPropertyMachine.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/Schema.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/errors.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/index.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/checkExistingSchema.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/createModelInstances.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/createPropertyInstances.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/loadOrCreateSchema.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/validateSchema.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/verifyModelInstancesInCache.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/verifyModelsInDb.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/verifyPropertiesInDb.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/verifyPropertyInstancesInCache.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/verifySchemaInDb.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/writeModelsToDb.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/writePropertiesToDb.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/actors/writeSchemaToDb.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/service/validation/SchemaValidationService.d.ts +0 -0
- /package/dist/{Schema → src/Schema}/validation.d.ts +0 -0
- /package/dist/{browser → src/browser}/db/Db.d.ts +0 -0
- /package/dist/{browser → src/browser}/db/sqlWasmClient.d.ts +0 -0
- /package/dist/{browser → src/browser}/helpers/ArweaveClient.d.ts +0 -0
- /package/dist/{browser → src/browser}/helpers/EasClient.d.ts +0 -0
- /package/dist/{browser → src/browser}/helpers/PathResolver.d.ts +0 -0
- /package/dist/{browser → src/browser}/helpers/QueryClient.d.ts +0 -0
- /package/dist/{browser → src/browser}/helpers/index.d.ts +0 -0
- /package/dist/{browser → src/browser}/index.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/OPFSImage.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/SeedImage.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/SeedProvider.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/client.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/db.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/itemProperty.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/liveQuery.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/model.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/modelProperty.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/queryClient.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/schema.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/services.d.ts +0 -0
- /package/dist/{browser → src/browser}/react/trash.d.ts +0 -0
- /package/dist/{browser → src/browser}/seed.d.ts +0 -0
- /package/dist/{browser → src/browser}/workers/FileDownloader.d.ts +0 -0
- /package/dist/{browser → src/browser}/workers/ImageResizer.d.ts +0 -0
- /package/dist/{browser → src/browser}/workers/content-hash.d.ts +0 -0
- /package/dist/{browser → src/browser}/workers/dbWorker.d.ts +0 -0
- /package/dist/{browser → src/browser}/workers/filesDownload.d.ts +0 -0
- /package/dist/{browser → src/browser}/workers/imageResize.d.ts +0 -0
- /package/dist/{client → src/client}/BaseClientManager.d.ts +0 -0
- /package/dist/{client → src/client}/actions/setAddresses.d.ts +0 -0
- /package/dist/{client → src/client}/actors/addModelsToDb.d.ts +0 -0
- /package/dist/{client → src/client}/actors/addModelsToStore.d.ts +0 -0
- /package/dist/{client → src/client}/actors/dbInit.d.ts +0 -0
- /package/dist/{client → src/client}/actors/fileSystemInit.d.ts +0 -0
- /package/dist/{client → src/client}/actors/platformClassesInit.d.ts +0 -0
- /package/dist/{client → src/client}/actors/processSchemaFiles.d.ts +0 -0
- /package/dist/{client → src/client}/actors/saveAppState.d.ts +0 -0
- /package/dist/{client → src/client}/actors/saveConfig.d.ts +0 -0
- /package/dist/{client → src/client}/clientManagerMachine.d.ts +0 -0
- /package/dist/{client → src/client}/constants.d.ts +0 -0
- /package/dist/{client → src/client}/index.d.ts +0 -0
- /package/dist/{db → src/db}/Db/BaseDb.d.ts +0 -0
- /package/dist/{db → src/db}/configs/dev.schema.config.d.ts +0 -0
- /package/dist/{db → src/db}/read/getExistingItem.d.ts +0 -0
- /package/dist/{db → src/db}/read/getItem.d.ts +0 -0
- /package/dist/{db → src/db}/read/getItemData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getItemProperties.d.ts +0 -0
- /package/dist/{db → src/db}/read/getItemProperty.d.ts +0 -0
- /package/dist/{db → src/db}/read/getMetadata.d.ts +0 -0
- /package/dist/{db → src/db}/read/getModelPropertiesData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getModelSchemas.d.ts +0 -0
- /package/dist/{db → src/db}/read/getModels.d.ts +0 -0
- /package/dist/{db → src/db}/read/getModelsData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getPropertyData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getRelationValueData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getSeedData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getStorageTransactionIdForSeedUid.d.ts +0 -0
- /package/dist/{db → src/db}/read/getVersionData.d.ts +0 -0
- /package/dist/{db → src/db}/read/getVersionsForVersionUids.d.ts +0 -0
- /package/dist/{db → src/db}/read/subqueries/metadataLatest.d.ts +0 -0
- /package/dist/{db → src/db}/read/subqueries/versionData.d.ts +0 -0
- /package/dist/{db → src/db}/write/createMetadata.d.ts +0 -0
- /package/dist/{db → src/db}/write/createNewItem.d.ts +0 -0
- /package/dist/{db → src/db}/write/createSeed.d.ts +0 -0
- /package/dist/{db → src/db}/write/createSeeds.d.ts +0 -0
- /package/dist/{db → src/db}/write/createVersion.d.ts +0 -0
- /package/dist/{db → src/db}/write/deleteItem.d.ts +0 -0
- /package/dist/{db → src/db}/write/recoverDeletedItem.d.ts +0 -0
- /package/dist/{db → src/db}/write/saveAppState.d.ts +0 -0
- /package/dist/{db → src/db}/write/saveMetadata.d.ts +0 -0
- /package/dist/{db → src/db}/write/updateItemPropertyValue.d.ts +0 -0
- /package/dist/{db → src/db}/write/updateMetadata.d.ts +0 -0
- /package/dist/{db → src/db}/write/updateSeedUid.d.ts +0 -0
- /package/dist/{eslint-rules → src/eslint-rules}/align-imports.d.ts +0 -0
- /package/dist/{eventBus.d.ts → src/eventBus.d.ts} +0 -0
- /package/dist/{events → src/events}/files/download.d.ts +0 -0
- /package/dist/{events → src/events}/files/index.d.ts +0 -0
- /package/dist/{events → src/events}/index.d.ts +0 -0
- /package/dist/{events → src/events}/item/index.d.ts +0 -0
- /package/dist/{events → src/events}/item/syncDbWithEas.d.ts +0 -0
- /package/dist/{events → src/events}/services/allItems.d.ts +0 -0
- /package/dist/{events → src/events}/services/index.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/fragments/Attestation.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/fragments/Schema.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/fragments/index.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/gql/fragment-masking.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/gql/gql.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/gql/graphql.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/gql/index.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/ArweaveClient/BaseArweaveClient.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/ArweaveClient/index.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/ArweaveClient/queries.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/EasClient/BaseEasClient.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/PathResolver/BasePathResolver.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/QueryClient/BaseQueryClient.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/crypto.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/entity/entityCache.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/entity/entityCommon.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/entity/entityDestroy.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/entity/entityFind.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/entity/entityLiveQuery.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/entity/index.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/environment.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/file/download/actors.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/file/download/index.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/file/fetchAll/actors.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/file/fetchAll/index.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/file/queries.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/files.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/getSegmentedItemProperties.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/image/queries.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/model.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/property.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/reactiveProxy.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/schema.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/updateMachineContext.d.ts +0 -0
- /package/dist/{helpers → src/helpers}/waitForEntityIdle.d.ts +0 -0
- /package/dist/{imports → src/imports}/index.d.ts +0 -0
- /package/dist/{imports → src/imports}/json.d.ts +0 -0
- /package/dist/{interfaces → src/interfaces}/IDb.d.ts +0 -0
- /package/dist/{interfaces → src/interfaces}/IEasClient.d.ts +0 -0
- /package/dist/{interfaces → src/interfaces}/IItem.d.ts +0 -0
- /package/dist/{interfaces → src/interfaces}/IItemProperty.d.ts +0 -0
- /package/dist/{interfaces → src/interfaces}/IQueryClient.d.ts +0 -0
- /package/dist/{interfaces → src/interfaces}/index.d.ts +0 -0
- /package/dist/{node → src/node}/codegen/drizzle.d.ts +0 -0
- /package/dist/{node → src/node}/codegen/index.d.ts +0 -0
- /package/dist/{node → src/node}/codegen/ts-to-proto.d.ts +0 -0
- /package/dist/{node → src/node}/constants.d.ts +0 -0
- /package/dist/{node → src/node}/db/Db.d.ts +0 -0
- /package/dist/{node → src/node}/db/index.d.ts +0 -0
- /package/dist/{node → src/node}/db/node.app.db.config.d.ts +0 -0
- /package/dist/{node → src/node}/helpers/ArweaveClient.d.ts +0 -0
- /package/dist/{node → src/node}/helpers/EasClient.d.ts +0 -0
- /package/dist/{node → src/node}/helpers/PathResolver.d.ts +0 -0
- /package/dist/{node → src/node}/helpers/QueryClient.d.ts +0 -0
- /package/dist/{node → src/node}/helpers/index.d.ts +0 -0
- /package/dist/{node → src/node}/helpers/scripts.d.ts +0 -0
- /package/dist/{node → src/node}/index.d.ts +0 -0
- /package/dist/{node → src/node}/seed.d.ts +0 -0
- /package/dist/{node → src/node}/webpack/fs-proxy.d.ts +0 -0
- /package/dist/{node → src/node}/webpack/index.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/AppStateSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/ConfigSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/MetadataSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/ModelSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/ModelUidSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/PropertyUidSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/SchemaSchema.d.ts +0 -0
- /package/dist/{seedSchema → src/seedSchema}/VersionSchema.d.ts +0 -0
- /package/dist/{services → src/services}/events.d.ts +0 -0
- /package/dist/{services → src/services}/publish/actors/createPublishAttempt.d.ts +0 -0
- /package/dist/{services → src/services}/publish/actors/preparePublishRequestData.d.ts +0 -0
- /package/dist/{services → src/services}/publish/actors/upload.d.ts +0 -0
- /package/dist/{services → src/services}/publish/actors/validateItemData.d.ts +0 -0
- /package/dist/{services → src/services}/publish/publishMachine.d.ts +0 -0
- /package/dist/{services → src/services}/write/actors/validateEntity.d.ts +0 -0
- /package/dist/{services → src/services}/write/actors/writeToDatabase.d.ts +0 -0
- /package/dist/{services → src/services}/write/writeProcessMachine.d.ts +0 -0
- /package/dist/{types → src/types}/arweave.d.ts +0 -0
- /package/dist/{types → src/types}/browser.d.ts +0 -0
- /package/dist/{types → src/types}/db.d.ts +0 -0
- /package/dist/{types → src/types}/fileManager.d.ts +0 -0
- /package/dist/{types → src/types}/helpers.d.ts +0 -0
- /package/dist/{types → src/types}/import.d.ts +0 -0
- /package/dist/{types → src/types}/model.d.ts +0 -0
- /package/dist/{types → src/types}/property.d.ts +0 -0
- /package/dist/{types → src/types}/publish.d.ts +0 -0
- /package/dist/{types → src/types}/seedProtocol.d.ts +0 -0
- /package/dist/{types → src/types}/services.d.ts +0 -0
- /package/dist/{vite → src/vite}/easFix.d.ts +0 -0
- /package/dist/{vite → src/vite}/index.d.ts +0 -0
|
@@ -0,0 +1,1725 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var xstate = require('xstate');
|
|
4
|
+
require('reflect-metadata');
|
|
5
|
+
var main_cjs = require('./index-BLETlVgA.js');
|
|
6
|
+
require('pluralize');
|
|
7
|
+
var drizzleOrm = require('drizzle-orm');
|
|
8
|
+
var debug = require('debug');
|
|
9
|
+
var Schema = require('./Schema-BcwvUABB.js');
|
|
10
|
+
require('immer');
|
|
11
|
+
require('drizzle-orm/sqlite-core');
|
|
12
|
+
require('nanoid');
|
|
13
|
+
require('nanoid-dictionary');
|
|
14
|
+
require('ethers');
|
|
15
|
+
require('rxjs');
|
|
16
|
+
require('lodash-es');
|
|
17
|
+
require('drizzle-orm/casing');
|
|
18
|
+
require('eventemitter3');
|
|
19
|
+
require('arweave');
|
|
20
|
+
require('@sinclair/typebox');
|
|
21
|
+
require('fs/promises');
|
|
22
|
+
require('fs');
|
|
23
|
+
require('path');
|
|
24
|
+
require('@libsql/client');
|
|
25
|
+
require('drizzle-orm/libsql');
|
|
26
|
+
require('drizzle-kit/api');
|
|
27
|
+
require('js-yaml');
|
|
28
|
+
require('ts-import');
|
|
29
|
+
require('glob');
|
|
30
|
+
require('rimraf');
|
|
31
|
+
require('child_process');
|
|
32
|
+
require('url');
|
|
33
|
+
require('graphql-request');
|
|
34
|
+
require('./SchemaValidationService-zty4nfCu.js');
|
|
35
|
+
require('@sinclair/typebox/value');
|
|
36
|
+
|
|
37
|
+
const logger$3 = debug('seedSdk:modelProperty:actors:saveToSchema');
|
|
38
|
+
/**
|
|
39
|
+
* Get schema name from model
|
|
40
|
+
* This function finds which schema contains the given model
|
|
41
|
+
* Exported so it can be reused by ModelProperty for setting schema name
|
|
42
|
+
*/
|
|
43
|
+
async function getSchemaNameFromModel(modelName) {
|
|
44
|
+
// Get the latest schema files and find which one contains this model
|
|
45
|
+
const schemaHelpersMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.schema$1; });
|
|
46
|
+
const { listLatestSchemaFiles } = schemaHelpersMod;
|
|
47
|
+
const latestSchemas = await listLatestSchemaFiles();
|
|
48
|
+
for (const schema of latestSchemas) {
|
|
49
|
+
try {
|
|
50
|
+
const fileManagerMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.BaseFileManager$1; });
|
|
51
|
+
const { BaseFileManager } = fileManagerMod;
|
|
52
|
+
const content = await BaseFileManager.readFileAsString(schema.filePath);
|
|
53
|
+
const schemaFile = JSON.parse(content);
|
|
54
|
+
if (schemaFile.models && schemaFile.models[modelName]) {
|
|
55
|
+
return schema.name;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
logger$3('Error reading schema file:', error);
|
|
60
|
+
continue;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return undefined;
|
|
64
|
+
}
|
|
65
|
+
const saveToSchema = xstate.fromCallback(({ sendBack, input: { context } }) => {
|
|
66
|
+
const _saveToSchema = async () => {
|
|
67
|
+
// Use dynamic import to break circular dependency
|
|
68
|
+
const validationServiceMod = await Promise.resolve().then(function () { return require('./SchemaValidationService-zty4nfCu.js'); });
|
|
69
|
+
const { SchemaValidationService } = validationServiceMod;
|
|
70
|
+
const validationService = new SchemaValidationService();
|
|
71
|
+
// Validate property structure before saving
|
|
72
|
+
const validationResult = validationService.validatePropertyStructure(context);
|
|
73
|
+
if (!validationResult.isValid) {
|
|
74
|
+
throw new Error(`Property validation failed: ${validationResult.errors.map(e => e.message).join(', ')}`);
|
|
75
|
+
}
|
|
76
|
+
// Validate required fields
|
|
77
|
+
if (!context.name) {
|
|
78
|
+
throw new Error('Property name is required');
|
|
79
|
+
}
|
|
80
|
+
if (!context.dataType) {
|
|
81
|
+
throw new Error('Data type is required');
|
|
82
|
+
}
|
|
83
|
+
if (!context.modelName) {
|
|
84
|
+
throw new Error(`Model not found for modelId: ${context.modelId}`);
|
|
85
|
+
}
|
|
86
|
+
// Persist to database only - schema file is updated only when user calls Schema.saveNewVersion()
|
|
87
|
+
const dbMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.db; });
|
|
88
|
+
const { savePropertyToDb } = dbMod;
|
|
89
|
+
await savePropertyToDb(context);
|
|
90
|
+
// Mark schema as draft so user knows to save
|
|
91
|
+
const schemaName = context._schemaName ?? (await getSchemaNameFromModel(context.modelName));
|
|
92
|
+
if (schemaName) {
|
|
93
|
+
const schemaMod = await Promise.resolve().then(function () { return require('./Schema-BcwvUABB.js'); });
|
|
94
|
+
const { Schema } = schemaMod;
|
|
95
|
+
const schema = Schema.create(schemaName, { waitForReady: false });
|
|
96
|
+
schema.getService().send({
|
|
97
|
+
type: 'markAsDraft',
|
|
98
|
+
propertyKey: `${context.modelName}:${context.name}`,
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
logger$3(`Successfully saved property ${context.modelName}:${context.name} to database`);
|
|
102
|
+
};
|
|
103
|
+
_saveToSchema().then(() => {
|
|
104
|
+
sendBack({ type: 'saveToSchemaSuccess' });
|
|
105
|
+
}).catch((error) => {
|
|
106
|
+
logger$3('Error saving to schema:', error);
|
|
107
|
+
sendBack({ type: 'saveToSchemaError', error });
|
|
108
|
+
});
|
|
109
|
+
return () => {
|
|
110
|
+
// Cleanup function (optional)
|
|
111
|
+
};
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
const logger$2 = debug('seedSdk:modelProperty:actors:compareAndMarkDraft');
|
|
115
|
+
const compareAndMarkDraft = xstate.fromCallback(({ sendBack, input: { context } }) => {
|
|
116
|
+
const _compareAndMarkDraft = async () => {
|
|
117
|
+
// Fill modelName/dataType from _originalValues when missing, then from DB by schemaFileId
|
|
118
|
+
let fullContext = {
|
|
119
|
+
...context,
|
|
120
|
+
modelName: context.modelName ?? context._originalValues?.modelName,
|
|
121
|
+
dataType: context.dataType ?? context._originalValues?.dataType,
|
|
122
|
+
};
|
|
123
|
+
const schemaFileIdForResolve = fullContext._propertyFileId || (typeof fullContext.id === 'string' ? fullContext.id : undefined);
|
|
124
|
+
if (schemaFileIdForResolve && (fullContext.modelName === undefined || fullContext.dataType === undefined)) {
|
|
125
|
+
try {
|
|
126
|
+
const dbMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.db; });
|
|
127
|
+
const { getPropertyModelNameAndDataType, getModelNameByModelId } = dbMod;
|
|
128
|
+
let fromDb;
|
|
129
|
+
for (let attempt = 0; attempt < 6; attempt++) {
|
|
130
|
+
fromDb = await getPropertyModelNameAndDataType(schemaFileIdForResolve);
|
|
131
|
+
if (fromDb)
|
|
132
|
+
break;
|
|
133
|
+
if (attempt < 5)
|
|
134
|
+
await new Promise((r) => setTimeout(r, 40));
|
|
135
|
+
}
|
|
136
|
+
if (fromDb) {
|
|
137
|
+
fullContext = {
|
|
138
|
+
...fullContext,
|
|
139
|
+
modelName: fullContext.modelName ?? fromDb.modelName,
|
|
140
|
+
dataType: fullContext.dataType ?? fromDb.dataType,
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
if (fullContext.modelName === undefined && schemaFileIdForResolve) {
|
|
144
|
+
const mod = await Promise.resolve().then(function () { return ModelProperty$1; });
|
|
145
|
+
const ModelProperty = mod?.ModelProperty ?? mod?.default;
|
|
146
|
+
const pendingModelId = ModelProperty?.getPendingModelId?.(schemaFileIdForResolve);
|
|
147
|
+
if (pendingModelId != null) {
|
|
148
|
+
const modelName = await getModelNameByModelId(pendingModelId);
|
|
149
|
+
if (modelName) {
|
|
150
|
+
fullContext = { ...fullContext, modelName };
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
catch {
|
|
156
|
+
// ignore
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
const schemaFileId = fullContext._propertyFileId || (typeof fullContext.id === 'string' ? fullContext.id : undefined);
|
|
160
|
+
// If _originalValues is not set, we still need to save to database if the property exists
|
|
161
|
+
// This handles the case where the name is changed before _originalValues is initialized
|
|
162
|
+
if (!fullContext._originalValues) {
|
|
163
|
+
logger$2('No original values to compare against');
|
|
164
|
+
logger$2(`[compareAndMarkDraft] Context: modelName=${fullContext.modelName}, name=${fullContext.name}, id=${fullContext.id}, _propertyFileId=${fullContext._propertyFileId}`);
|
|
165
|
+
// If we have a name and modelName, try to save to database anyway
|
|
166
|
+
// This ensures name changes are persisted even if _originalValues isn't initialized yet
|
|
167
|
+
// We need either schemaFileId (id or _propertyFileId) to find the property in the database
|
|
168
|
+
if (fullContext.modelName && fullContext.name && schemaFileId) {
|
|
169
|
+
logger$2(`[compareAndMarkDraft] _originalValues not set, but saving to database anyway for property ${context.modelName}:${context.name} (schemaFileId: ${schemaFileId})`);
|
|
170
|
+
try {
|
|
171
|
+
const dbMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.db; });
|
|
172
|
+
const { savePropertyToDb } = dbMod;
|
|
173
|
+
// Ensure _propertyFileId is set for savePropertyToDb to find the property
|
|
174
|
+
const contextWithFileId = {
|
|
175
|
+
...fullContext,
|
|
176
|
+
_propertyFileId: schemaFileId,
|
|
177
|
+
};
|
|
178
|
+
await savePropertyToDb(contextWithFileId);
|
|
179
|
+
logger$2(`[compareAndMarkDraft] Successfully saved property ${fullContext.modelName}:${fullContext.name} to database (no _originalValues)`);
|
|
180
|
+
}
|
|
181
|
+
catch (error) {
|
|
182
|
+
logger$2(`[compareAndMarkDraft] Error saving property to database (no _originalValues): ${error}`);
|
|
183
|
+
// Don't throw - this is a best-effort save, but log the error for debugging
|
|
184
|
+
console.error(`[compareAndMarkDraft] Failed to save property ${fullContext.modelName}:${fullContext.name}:`, error);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
else {
|
|
188
|
+
logger$2(`[compareAndMarkDraft] Cannot save property ${fullContext.modelName}:${fullContext.name} - missing required fields (schemaFileId: ${schemaFileId})`);
|
|
189
|
+
}
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
logger$2(`[compareAndMarkDraft] Comparing: context.name=${fullContext.name}, _originalValues.name=${fullContext._originalValues?.name}`);
|
|
193
|
+
// Compare current values with original
|
|
194
|
+
// Only compare property fields, not internal fields
|
|
195
|
+
const propertyFields = ['name', 'dataType', 'ref', 'refModelName', 'refModelId', 'refValueType', 'storageType', 'localStorageDir', 'filenameSuffix', 'modelName', 'modelId'];
|
|
196
|
+
const hasChanges = propertyFields.some(key => {
|
|
197
|
+
const currentValue = fullContext[key];
|
|
198
|
+
const originalValue = fullContext._originalValues?.[key];
|
|
199
|
+
// Handle name changes specifically
|
|
200
|
+
if (key === 'name') {
|
|
201
|
+
const nameChanged = currentValue !== originalValue;
|
|
202
|
+
if (nameChanged) {
|
|
203
|
+
logger$2(`[compareAndMarkDraft] Name change detected: "${originalValue}" -> "${currentValue}"`);
|
|
204
|
+
}
|
|
205
|
+
return nameChanged;
|
|
206
|
+
}
|
|
207
|
+
// Handle ref fields - compare by name
|
|
208
|
+
if (key === 'ref' || key === 'refModelName') {
|
|
209
|
+
const currentRef = fullContext.refModelName || fullContext.ref;
|
|
210
|
+
const originalRef = fullContext._originalValues?.refModelName || fullContext._originalValues?.ref;
|
|
211
|
+
// Both undefined/null means no ref, so they're the same
|
|
212
|
+
if (!currentRef && !originalRef)
|
|
213
|
+
return false;
|
|
214
|
+
return currentRef !== originalRef;
|
|
215
|
+
}
|
|
216
|
+
// For other fields, compare values (handling undefined/null)
|
|
217
|
+
if (currentValue === undefined && originalValue === undefined)
|
|
218
|
+
return false;
|
|
219
|
+
if (currentValue === null && originalValue === null)
|
|
220
|
+
return false;
|
|
221
|
+
if (currentValue === undefined && originalValue === null)
|
|
222
|
+
return false;
|
|
223
|
+
if (currentValue === null && originalValue === undefined)
|
|
224
|
+
return false;
|
|
225
|
+
return currentValue !== originalValue;
|
|
226
|
+
});
|
|
227
|
+
if (hasChanges) {
|
|
228
|
+
logger$2(`Property ${fullContext.modelName}:${fullContext.name} has changes, marking as edited`);
|
|
229
|
+
logger$2(`[compareAndMarkDraft] Context when saving: id=${fullContext.id}, _propertyFileId=${fullContext._propertyFileId}, name=${fullContext.name}, _originalValues.name=${fullContext._originalValues?.name}`);
|
|
230
|
+
// Use dynamic import to break circular dependency
|
|
231
|
+
const dbMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.db; });
|
|
232
|
+
const { savePropertyToDb } = dbMod;
|
|
233
|
+
// Save to database (but not JSON file) - always save to DB when there are changes
|
|
234
|
+
try {
|
|
235
|
+
await savePropertyToDb(fullContext);
|
|
236
|
+
logger$2(`[compareAndMarkDraft] Successfully saved property ${fullContext.modelName}:${fullContext.name} to database`);
|
|
237
|
+
}
|
|
238
|
+
catch (error) {
|
|
239
|
+
logger$2(`[compareAndMarkDraft] Error saving property to database: ${error}`);
|
|
240
|
+
throw error;
|
|
241
|
+
}
|
|
242
|
+
// Mark schema as draft if schema name is available
|
|
243
|
+
if (fullContext._schemaName) {
|
|
244
|
+
// Get the Schema instance and mark it as draft
|
|
245
|
+
const schemaMod = await Promise.resolve().then(function () { return require('./Schema-BcwvUABB.js'); });
|
|
246
|
+
const { Schema } = schemaMod;
|
|
247
|
+
const schema = Schema.create(fullContext._schemaName, {
|
|
248
|
+
waitForReady: false,
|
|
249
|
+
});
|
|
250
|
+
// Send event to Schema machine to mark as draft
|
|
251
|
+
schema.getService().send({
|
|
252
|
+
type: 'markAsDraft',
|
|
253
|
+
propertyKey: `${fullContext.modelName}:${fullContext.name}`,
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
// No changes - clear edited flag in database and context
|
|
259
|
+
logger$2(`Property ${fullContext.modelName}:${fullContext.name} has no changes`);
|
|
260
|
+
// Clear isEdited flag in database
|
|
261
|
+
try {
|
|
262
|
+
const seedSchemaMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.schema; });
|
|
263
|
+
const { properties: propertiesTable, models: modelsTable } = seedSchemaMod;
|
|
264
|
+
const drizzleMod = await import('drizzle-orm');
|
|
265
|
+
const { eq, and } = drizzleMod;
|
|
266
|
+
const db = main_cjs.BaseDb.getAppDb();
|
|
267
|
+
if (db && fullContext.modelName && fullContext.name) {
|
|
268
|
+
// Find model by name
|
|
269
|
+
const modelRecords = await db
|
|
270
|
+
.select({ id: modelsTable.id })
|
|
271
|
+
.from(modelsTable)
|
|
272
|
+
.where(eq(modelsTable.name, fullContext.modelName))
|
|
273
|
+
.limit(1);
|
|
274
|
+
if (modelRecords.length > 0) {
|
|
275
|
+
// Find property by name and modelId
|
|
276
|
+
const propertyRecords = await db
|
|
277
|
+
.select({ id: propertiesTable.id })
|
|
278
|
+
.from(propertiesTable)
|
|
279
|
+
.where(and(eq(propertiesTable.name, fullContext.name), eq(propertiesTable.modelId, modelRecords[0].id)))
|
|
280
|
+
.limit(1);
|
|
281
|
+
if (propertyRecords.length > 0) {
|
|
282
|
+
// Clear isEdited flag in database
|
|
283
|
+
await db
|
|
284
|
+
.update(propertiesTable)
|
|
285
|
+
.set({ isEdited: false })
|
|
286
|
+
.where(eq(propertiesTable.id, propertyRecords[0].id));
|
|
287
|
+
logger$2(`Cleared isEdited flag in database for property ${fullContext.modelName}:${fullContext.name}`);
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
catch (error) {
|
|
293
|
+
logger$2(`Error clearing isEdited flag in database: ${error}`);
|
|
294
|
+
}
|
|
295
|
+
sendBack({
|
|
296
|
+
type: 'clearEdited',
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
};
|
|
300
|
+
_compareAndMarkDraft().then(() => {
|
|
301
|
+
sendBack({ type: 'compareAndMarkDraftSuccess' });
|
|
302
|
+
}).catch((error) => {
|
|
303
|
+
logger$2('Error comparing and marking draft:', error);
|
|
304
|
+
sendBack({ type: 'compareAndMarkDraftError', error });
|
|
305
|
+
});
|
|
306
|
+
return () => {
|
|
307
|
+
// Cleanup function (optional)
|
|
308
|
+
};
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
const logger$1 = debug('seedSdk:modelProperty:actors:validateProperty');
|
|
312
|
+
const validateProperty = xstate.fromCallback(({ sendBack, input: { context } }) => {
|
|
313
|
+
const _validateProperty = async () => {
|
|
314
|
+
// Use full context for validation: fill modelName/dataType from _originalValues when missing, then
|
|
315
|
+
// from DB by schemaFileId (context.id) so just-created renames don't fail structure validation.
|
|
316
|
+
let fullContext = {
|
|
317
|
+
...context,
|
|
318
|
+
modelName: context.modelName ?? context._originalValues?.modelName,
|
|
319
|
+
dataType: context.dataType ?? context._originalValues?.dataType,
|
|
320
|
+
};
|
|
321
|
+
const schemaFileId = typeof context.id === 'string' ? context.id : undefined;
|
|
322
|
+
if (schemaFileId && (fullContext.modelName === undefined || fullContext.dataType === undefined)) {
|
|
323
|
+
// Brief wait so trackPendingWrite from ModelProperty.create() has time to run (it's in setTimeout(0))
|
|
324
|
+
await new Promise((r) => setTimeout(r, 60));
|
|
325
|
+
try {
|
|
326
|
+
const dbMod = await Promise.resolve().then(function () { return require('./index-BLETlVgA.js'); }).then(function (n) { return n.db; });
|
|
327
|
+
const { getPropertyModelNameAndDataType, getModelNameByModelId } = dbMod;
|
|
328
|
+
// Try pending write first (property row may not exist yet)
|
|
329
|
+
if (fullContext.modelName === undefined && schemaFileId) {
|
|
330
|
+
const mod = await Promise.resolve().then(function () { return ModelProperty$1; });
|
|
331
|
+
const ModelProperty = mod?.ModelProperty ?? mod?.default;
|
|
332
|
+
const pendingModelId = ModelProperty?.getPendingModelId?.(schemaFileId);
|
|
333
|
+
if (pendingModelId != null) {
|
|
334
|
+
const modelName = await getModelNameByModelId(pendingModelId);
|
|
335
|
+
if (modelName) {
|
|
336
|
+
fullContext = { ...fullContext, modelName };
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
// Then DB property lookup with retry (catches row after initial write)
|
|
341
|
+
let fromDb;
|
|
342
|
+
for (let attempt = 0; attempt < 6; attempt++) {
|
|
343
|
+
fromDb = await getPropertyModelNameAndDataType(schemaFileId);
|
|
344
|
+
if (fromDb)
|
|
345
|
+
break;
|
|
346
|
+
if (attempt < 5)
|
|
347
|
+
await new Promise((r) => setTimeout(r, 40));
|
|
348
|
+
}
|
|
349
|
+
if (fromDb) {
|
|
350
|
+
fullContext = {
|
|
351
|
+
...fullContext,
|
|
352
|
+
modelName: fullContext.modelName ?? fromDb.modelName,
|
|
353
|
+
dataType: fullContext.dataType ?? fromDb.dataType,
|
|
354
|
+
};
|
|
355
|
+
}
|
|
356
|
+
// If still no modelName, try pending write again (may have been set during retries)
|
|
357
|
+
if (fullContext.modelName === undefined && schemaFileId) {
|
|
358
|
+
const mod = await Promise.resolve().then(function () { return ModelProperty$1; });
|
|
359
|
+
const ModelProperty = mod?.ModelProperty ?? mod?.default;
|
|
360
|
+
const pendingModelId = ModelProperty?.getPendingModelId?.(schemaFileId);
|
|
361
|
+
if (pendingModelId != null) {
|
|
362
|
+
const modelName = await getModelNameByModelId(pendingModelId);
|
|
363
|
+
if (modelName) {
|
|
364
|
+
fullContext = { ...fullContext, modelName };
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
catch {
|
|
370
|
+
// ignore
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
// Last resort for structure validation: TProperty requires dataType; allow name+id to pass if we have schemaFileId
|
|
374
|
+
if (fullContext.dataType === undefined && (fullContext.modelName !== undefined || schemaFileId)) {
|
|
375
|
+
fullContext = { ...fullContext, dataType: (fullContext.dataType ?? context._originalValues?.dataType) || 'Text' };
|
|
376
|
+
}
|
|
377
|
+
// Use dynamic imports to break circular dependencies
|
|
378
|
+
const validationServiceMod = await Promise.resolve().then(function () { return require('./SchemaValidationService-zty4nfCu.js'); });
|
|
379
|
+
const { SchemaValidationService } = validationServiceMod;
|
|
380
|
+
const validationService = new SchemaValidationService();
|
|
381
|
+
const schemaMod = await Promise.resolve().then(function () { return require('./Schema-BcwvUABB.js'); });
|
|
382
|
+
const { Schema } = schemaMod;
|
|
383
|
+
// Validate property structure
|
|
384
|
+
const structureResult = validationService.validatePropertyStructure(fullContext);
|
|
385
|
+
if (!structureResult.isValid) {
|
|
386
|
+
sendBack({ type: 'validationError', errors: structureResult.errors });
|
|
387
|
+
return;
|
|
388
|
+
}
|
|
389
|
+
// If we have schema name and model name, validate against schema
|
|
390
|
+
if (fullContext._schemaName && fullContext.modelName) {
|
|
391
|
+
try {
|
|
392
|
+
const schema = Schema.create(fullContext._schemaName, {
|
|
393
|
+
waitForReady: false,
|
|
394
|
+
});
|
|
395
|
+
const schemaSnapshot = schema.getService().getSnapshot();
|
|
396
|
+
const schemaStatus = schemaSnapshot.value;
|
|
397
|
+
// Only validate against schema if it's loaded (in idle state)
|
|
398
|
+
// If still loading, skip schema validation and only do structure validation
|
|
399
|
+
if (schemaStatus === 'idle') {
|
|
400
|
+
const schemaContext = schemaSnapshot.context;
|
|
401
|
+
// Check if models are actually loaded
|
|
402
|
+
if (schemaContext.models && Object.keys(schemaContext.models).length > 0) {
|
|
403
|
+
// If property name has changed, validate against the original name (from schema file)
|
|
404
|
+
// This handles the case where a property is renamed - the schema file still has the old name
|
|
405
|
+
const propertyNameToValidate = fullContext._originalValues?.name && fullContext._originalValues.name !== fullContext.name
|
|
406
|
+
? fullContext._originalValues.name
|
|
407
|
+
: fullContext.name || '';
|
|
408
|
+
const schemaResult = validationService.validateProperty(schemaContext, fullContext.modelName, propertyNameToValidate, fullContext);
|
|
409
|
+
if (!schemaResult.isValid) {
|
|
410
|
+
// If property was renamed, some validation errors are expected (like property_not_found, missing_type)
|
|
411
|
+
// Only fail if it's a critical error that's not related to the rename
|
|
412
|
+
const isRenamed = fullContext._originalValues?.name && fullContext._originalValues.name !== fullContext.name;
|
|
413
|
+
const criticalErrors = schemaResult.errors.filter(err => {
|
|
414
|
+
// Allow property_not_found and missing_type errors when property is renamed
|
|
415
|
+
if (isRenamed && (err.code === 'property_not_found' || err.code === 'missing_type')) {
|
|
416
|
+
return false; // Not critical
|
|
417
|
+
}
|
|
418
|
+
// For non-renamed properties, only allow property_not_found if we're validating with the same name
|
|
419
|
+
if (err.code === 'property_not_found' && propertyNameToValidate === fullContext.name) {
|
|
420
|
+
return false; // Not critical
|
|
421
|
+
}
|
|
422
|
+
return true; // Critical error
|
|
423
|
+
});
|
|
424
|
+
if (criticalErrors.length > 0) {
|
|
425
|
+
sendBack({ type: 'validationError', errors: criticalErrors });
|
|
426
|
+
return;
|
|
427
|
+
}
|
|
428
|
+
// Continue with validation - rename-related errors are acceptable
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
else {
|
|
432
|
+
logger$1('Schema models not loaded yet, skipping schema validation');
|
|
433
|
+
// Continue with structure validation only
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
else {
|
|
437
|
+
logger$1(`Schema is in ${schemaStatus} state, skipping schema validation`);
|
|
438
|
+
// Continue with structure validation only
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
catch (error) {
|
|
442
|
+
logger$1('Error validating property against schema:', error);
|
|
443
|
+
// Continue with structure validation only
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
// All validations passed
|
|
447
|
+
sendBack({ type: 'validationSuccess', errors: [] });
|
|
448
|
+
};
|
|
449
|
+
_validateProperty().catch((error) => {
|
|
450
|
+
logger$1('Error in validateProperty:', error);
|
|
451
|
+
sendBack({
|
|
452
|
+
type: 'validationError',
|
|
453
|
+
errors: [{
|
|
454
|
+
field: 'property',
|
|
455
|
+
message: error instanceof Error ? error.message : 'Unknown validation error',
|
|
456
|
+
code: 'validation_exception',
|
|
457
|
+
severity: 'error',
|
|
458
|
+
}],
|
|
459
|
+
});
|
|
460
|
+
});
|
|
461
|
+
return () => {
|
|
462
|
+
// Cleanup function (optional)
|
|
463
|
+
};
|
|
464
|
+
});
|
|
465
|
+
|
|
466
|
+
const modelPropertyMachine = xstate.setup({
|
|
467
|
+
types: {
|
|
468
|
+
context: {},
|
|
469
|
+
input: {},
|
|
470
|
+
events: {},
|
|
471
|
+
},
|
|
472
|
+
actors: {
|
|
473
|
+
saveToSchema,
|
|
474
|
+
compareAndMarkDraft,
|
|
475
|
+
validateProperty,
|
|
476
|
+
writeProcessMachine: main_cjs.writeProcessMachine,
|
|
477
|
+
},
|
|
478
|
+
guards: {
|
|
479
|
+
isPropertyValid: ({ context }) => {
|
|
480
|
+
const valid = !context._validationErrors || context._validationErrors.length === 0;
|
|
481
|
+
return valid;
|
|
482
|
+
},
|
|
483
|
+
hasValidationErrors: ({ context }) => {
|
|
484
|
+
return !!context._validationErrors && context._validationErrors.length > 0;
|
|
485
|
+
},
|
|
486
|
+
},
|
|
487
|
+
actions: {
|
|
488
|
+
assignValidationErrors: xstate.assign(({ context, event }) => {
|
|
489
|
+
if (event.type === 'validationError') {
|
|
490
|
+
return {
|
|
491
|
+
...context,
|
|
492
|
+
_validationErrors: event.errors,
|
|
493
|
+
};
|
|
494
|
+
}
|
|
495
|
+
return context;
|
|
496
|
+
}),
|
|
497
|
+
},
|
|
498
|
+
}).createMachine({
|
|
499
|
+
id: 'modelProperty',
|
|
500
|
+
initial: 'idle',
|
|
501
|
+
context: ({ input }) => {
|
|
502
|
+
const context = input;
|
|
503
|
+
return context;
|
|
504
|
+
},
|
|
505
|
+
on: {
|
|
506
|
+
updateContext: {
|
|
507
|
+
actions: xstate.assign(({ context, event }) => {
|
|
508
|
+
const newContext = Object.assign({}, context);
|
|
509
|
+
// Check if this is only updating internal fields
|
|
510
|
+
const onlyInternalFields = Object.keys(event).every((key) => {
|
|
511
|
+
return key === 'type' || key.startsWith('_');
|
|
512
|
+
});
|
|
513
|
+
// Update the context with new values
|
|
514
|
+
for (let i = 0; i < Object.keys(event).length; i++) {
|
|
515
|
+
const key = Object.keys(event)[i];
|
|
516
|
+
if (key === 'type') {
|
|
517
|
+
continue;
|
|
518
|
+
}
|
|
519
|
+
let value = event[key];
|
|
520
|
+
// Convert null to undefined for optional fields (TypeBox validation expects undefined, not null)
|
|
521
|
+
// This is especially important for refValueType, refModelId, etc.
|
|
522
|
+
if (value === null && (key === 'refValueType' || key === 'refModelId' || key === 'ref' || key === 'refModelName')) {
|
|
523
|
+
value = undefined;
|
|
524
|
+
}
|
|
525
|
+
newContext[key] = value;
|
|
526
|
+
}
|
|
527
|
+
// Preserve modelName and dataType from context or _originalValues so validation and savePropertyToDb
|
|
528
|
+
// never run with missing required/needed fields (e.g. when a just-created property is renamed before
|
|
529
|
+
// the full context is available from the creator).
|
|
530
|
+
if (newContext.modelName === undefined && context._originalValues?.modelName !== undefined) {
|
|
531
|
+
newContext.modelName = context._originalValues.modelName;
|
|
532
|
+
}
|
|
533
|
+
if (newContext.dataType === undefined && context._originalValues?.dataType !== undefined) {
|
|
534
|
+
newContext.dataType = context._originalValues.dataType;
|
|
535
|
+
}
|
|
536
|
+
// Compare with original values and set _isEdited flag (only for non-internal updates)
|
|
537
|
+
if (!onlyInternalFields && context._originalValues) {
|
|
538
|
+
const hasChanges = Object.keys(event).some((key) => {
|
|
539
|
+
if (key === 'type' || key.startsWith('_'))
|
|
540
|
+
return false;
|
|
541
|
+
return newContext[key] !== context._originalValues?.[key];
|
|
542
|
+
});
|
|
543
|
+
newContext._isEdited = hasChanges;
|
|
544
|
+
}
|
|
545
|
+
// Clear validation errors on context update (will be re-validated if needed)
|
|
546
|
+
newContext._validationErrors = undefined;
|
|
547
|
+
// Convert null to undefined for optional fields (TypeBox validation expects undefined, not null)
|
|
548
|
+
// This is especially important for refValueType, refModelId, etc.
|
|
549
|
+
const optionalFields = ['refValueType', 'refModelId', 'ref', 'refModelName'];
|
|
550
|
+
for (const field of optionalFields) {
|
|
551
|
+
if (newContext[field] === null) {
|
|
552
|
+
newContext[field] = undefined;
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
return newContext;
|
|
556
|
+
}),
|
|
557
|
+
// Only trigger validation and compareAndMarkDraft if we're updating non-internal fields
|
|
558
|
+
guard: ({ event }) => {
|
|
559
|
+
const shouldTransition = !Object.keys(event).every((key) => {
|
|
560
|
+
return key === 'type' || key.startsWith('_');
|
|
561
|
+
});
|
|
562
|
+
return shouldTransition;
|
|
563
|
+
},
|
|
564
|
+
target: '.validating',
|
|
565
|
+
},
|
|
566
|
+
validateProperty: {
|
|
567
|
+
target: '.validating',
|
|
568
|
+
},
|
|
569
|
+
validationSuccess: {
|
|
570
|
+
actions: xstate.assign(({ context, event }) => ({
|
|
571
|
+
...context,
|
|
572
|
+
_validationErrors: [],
|
|
573
|
+
})),
|
|
574
|
+
},
|
|
575
|
+
validationError: {
|
|
576
|
+
actions: 'assignValidationErrors',
|
|
577
|
+
// Note: State-specific transitions are handled in child states
|
|
578
|
+
// This root handler ensures errors are always assigned to context
|
|
579
|
+
},
|
|
580
|
+
initializeOriginalValues: {
|
|
581
|
+
actions: xstate.assign(({ context, event }) => ({
|
|
582
|
+
...context,
|
|
583
|
+
_originalValues: event.originalValues,
|
|
584
|
+
_schemaName: event.schemaName,
|
|
585
|
+
_isEdited: event.isEdited ?? false,
|
|
586
|
+
_validationErrors: undefined,
|
|
587
|
+
})),
|
|
588
|
+
},
|
|
589
|
+
clearEdited: {
|
|
590
|
+
actions: xstate.assign(({ context }) => ({
|
|
591
|
+
...context,
|
|
592
|
+
_isEdited: false,
|
|
593
|
+
_originalValues: { ...context },
|
|
594
|
+
})),
|
|
595
|
+
},
|
|
596
|
+
setSchemaName: {
|
|
597
|
+
actions: xstate.assign(({ context, event }) => ({
|
|
598
|
+
...context,
|
|
599
|
+
_schemaName: event.schemaName,
|
|
600
|
+
})),
|
|
601
|
+
},
|
|
602
|
+
destroyStarted: {
|
|
603
|
+
actions: xstate.assign({ _destroyInProgress: true, _destroyError: null }),
|
|
604
|
+
},
|
|
605
|
+
destroyDone: {
|
|
606
|
+
actions: xstate.assign({ _destroyInProgress: false }),
|
|
607
|
+
},
|
|
608
|
+
destroyError: {
|
|
609
|
+
actions: xstate.assign(({ event }) => ({
|
|
610
|
+
_destroyInProgress: false,
|
|
611
|
+
_destroyError: event.error instanceof Error
|
|
612
|
+
? { message: event.error.message, name: event.error.name }
|
|
613
|
+
: { message: String(event.error) },
|
|
614
|
+
})),
|
|
615
|
+
},
|
|
616
|
+
clearDestroyError: {
|
|
617
|
+
actions: xstate.assign({ _destroyError: null }),
|
|
618
|
+
},
|
|
619
|
+
},
|
|
620
|
+
states: {
|
|
621
|
+
idle: {
|
|
622
|
+
on: {
|
|
623
|
+
saveToSchema: { target: 'saveToSchema' },
|
|
624
|
+
validateProperty: {
|
|
625
|
+
target: 'validating',
|
|
626
|
+
},
|
|
627
|
+
requestWrite: {
|
|
628
|
+
actions: ({ context, event }) => {
|
|
629
|
+
if (context.writeProcess) {
|
|
630
|
+
context.writeProcess.send({
|
|
631
|
+
type: 'startWrite',
|
|
632
|
+
data: event.data,
|
|
633
|
+
});
|
|
634
|
+
}
|
|
635
|
+
},
|
|
636
|
+
},
|
|
637
|
+
},
|
|
638
|
+
entry: xstate.assign({
|
|
639
|
+
writeProcess: ({ spawn, context }) => {
|
|
640
|
+
// Spawn writeProcess if we have id (schemaFileId)
|
|
641
|
+
// New properties will have id generated
|
|
642
|
+
const entityId = context.id;
|
|
643
|
+
if (!context.writeProcess && entityId) {
|
|
644
|
+
return spawn(main_cjs.writeProcessMachine, {
|
|
645
|
+
input: {
|
|
646
|
+
entityType: 'modelProperty',
|
|
647
|
+
entityId: String(entityId),
|
|
648
|
+
entityData: context,
|
|
649
|
+
},
|
|
650
|
+
});
|
|
651
|
+
}
|
|
652
|
+
return context.writeProcess;
|
|
653
|
+
},
|
|
654
|
+
}),
|
|
655
|
+
},
|
|
656
|
+
validating: {
|
|
657
|
+
on: {
|
|
658
|
+
saveToSchema: { target: 'saveToSchema' },
|
|
659
|
+
validationSuccess: {
|
|
660
|
+
target: 'compareAndMarkDraft',
|
|
661
|
+
actions: xstate.assign(({ context }) => ({
|
|
662
|
+
...context,
|
|
663
|
+
_validationErrors: [],
|
|
664
|
+
})),
|
|
665
|
+
},
|
|
666
|
+
// validationError: Uses root handler for assignment, but needs state-specific transition
|
|
667
|
+
validationError: {
|
|
668
|
+
target: 'idle',
|
|
669
|
+
actions: 'assignValidationErrors',
|
|
670
|
+
},
|
|
671
|
+
},
|
|
672
|
+
invoke: {
|
|
673
|
+
src: 'validateProperty',
|
|
674
|
+
input: ({ context }) => ({ context }),
|
|
675
|
+
},
|
|
676
|
+
},
|
|
677
|
+
compareAndMarkDraft: {
|
|
678
|
+
on: {
|
|
679
|
+
saveToSchema: { target: 'saveToSchema' },
|
|
680
|
+
compareAndMarkDraftSuccess: {
|
|
681
|
+
target: 'idle',
|
|
682
|
+
},
|
|
683
|
+
compareAndMarkDraftError: {
|
|
684
|
+
target: 'idle',
|
|
685
|
+
},
|
|
686
|
+
},
|
|
687
|
+
invoke: {
|
|
688
|
+
src: 'compareAndMarkDraft',
|
|
689
|
+
input: ({ context }) => ({ context }),
|
|
690
|
+
},
|
|
691
|
+
},
|
|
692
|
+
saveToSchema: {
|
|
693
|
+
always: {
|
|
694
|
+
guard: 'isPropertyValid',
|
|
695
|
+
target: '.saving',
|
|
696
|
+
},
|
|
697
|
+
initial: 'saving',
|
|
698
|
+
on: {
|
|
699
|
+
// Apply updateContext but do not re-invoke saveToSchema actor (avoids infinite loop).
|
|
700
|
+
// Context is updated; in-flight save completes with original context.
|
|
701
|
+
updateContext: [
|
|
702
|
+
{
|
|
703
|
+
guard: ({ context, event }) => {
|
|
704
|
+
const onlyInternal = Object.keys(event).every((k) => k === 'type' || k.startsWith('_'));
|
|
705
|
+
return !onlyInternal && event.name !== undefined && event.name !== context.name;
|
|
706
|
+
},
|
|
707
|
+
actions: xstate.assign(({ context, event }) => {
|
|
708
|
+
const newContext = Object.assign({}, context);
|
|
709
|
+
const onlyInternalFields = Object.keys(event).every((key) => key === 'type' || key.startsWith('_'));
|
|
710
|
+
for (const key of Object.keys(event)) {
|
|
711
|
+
if (key === 'type')
|
|
712
|
+
continue;
|
|
713
|
+
let value = event[key];
|
|
714
|
+
if (value === null && ['refValueType', 'refModelId', 'ref', 'refModelName'].includes(key))
|
|
715
|
+
value = undefined;
|
|
716
|
+
newContext[key] = value;
|
|
717
|
+
}
|
|
718
|
+
if (newContext.modelName === undefined && context._originalValues?.modelName !== undefined) {
|
|
719
|
+
newContext.modelName = context._originalValues.modelName;
|
|
720
|
+
}
|
|
721
|
+
if (newContext.dataType === undefined && context._originalValues?.dataType !== undefined) {
|
|
722
|
+
newContext.dataType = context._originalValues.dataType;
|
|
723
|
+
}
|
|
724
|
+
if (!onlyInternalFields && context._originalValues) {
|
|
725
|
+
const hasChanges = Object.keys(event).some((key) => {
|
|
726
|
+
if (key === 'type' || key.startsWith('_'))
|
|
727
|
+
return false;
|
|
728
|
+
return newContext[key] !== context._originalValues?.[key];
|
|
729
|
+
});
|
|
730
|
+
newContext._isEdited = hasChanges;
|
|
731
|
+
}
|
|
732
|
+
newContext._validationErrors = undefined;
|
|
733
|
+
return newContext;
|
|
734
|
+
}),
|
|
735
|
+
},
|
|
736
|
+
{
|
|
737
|
+
actions: xstate.assign(({ context, event }) => {
|
|
738
|
+
const newContext = Object.assign({}, context);
|
|
739
|
+
const onlyInternalFields = Object.keys(event).every((key) => key === 'type' || key.startsWith('_'));
|
|
740
|
+
for (const key of Object.keys(event)) {
|
|
741
|
+
if (key === 'type')
|
|
742
|
+
continue;
|
|
743
|
+
let value = event[key];
|
|
744
|
+
if (value === null && ['refValueType', 'refModelId', 'ref', 'refModelName'].includes(key))
|
|
745
|
+
value = undefined;
|
|
746
|
+
newContext[key] = value;
|
|
747
|
+
}
|
|
748
|
+
if (newContext.modelName === undefined && context._originalValues?.modelName !== undefined) {
|
|
749
|
+
newContext.modelName = context._originalValues.modelName;
|
|
750
|
+
}
|
|
751
|
+
if (newContext.dataType === undefined && context._originalValues?.dataType !== undefined) {
|
|
752
|
+
newContext.dataType = context._originalValues.dataType;
|
|
753
|
+
}
|
|
754
|
+
if (!onlyInternalFields && context._originalValues) {
|
|
755
|
+
const hasChanges = Object.keys(event).some((key) => {
|
|
756
|
+
if (key === 'type' || key.startsWith('_'))
|
|
757
|
+
return false;
|
|
758
|
+
return newContext[key] !== context._originalValues?.[key];
|
|
759
|
+
});
|
|
760
|
+
newContext._isEdited = hasChanges;
|
|
761
|
+
}
|
|
762
|
+
newContext._validationErrors = undefined;
|
|
763
|
+
return newContext;
|
|
764
|
+
}),
|
|
765
|
+
},
|
|
766
|
+
],
|
|
767
|
+
// validationError: Uses root handler for assignment, but needs state-specific transition
|
|
768
|
+
validationError: {
|
|
769
|
+
target: 'idle',
|
|
770
|
+
actions: 'assignValidationErrors',
|
|
771
|
+
},
|
|
772
|
+
},
|
|
773
|
+
states: {
|
|
774
|
+
saving: {
|
|
775
|
+
on: {
|
|
776
|
+
saveToSchemaSuccess: {
|
|
777
|
+
target: '#modelProperty.idle',
|
|
778
|
+
},
|
|
779
|
+
saveToSchemaError: {
|
|
780
|
+
target: '#modelProperty.idle',
|
|
781
|
+
},
|
|
782
|
+
},
|
|
783
|
+
invoke: {
|
|
784
|
+
src: 'saveToSchema',
|
|
785
|
+
input: ({ context }) => ({ context }),
|
|
786
|
+
},
|
|
787
|
+
},
|
|
788
|
+
},
|
|
789
|
+
},
|
|
790
|
+
},
|
|
791
|
+
});
|
|
792
|
+
|
|
793
|
+
/**
|
|
794
|
+
* Returns property rows for a model identified by modelFileId (model's schemaFileId).
|
|
795
|
+
* Resolves modelFileId -> modelId via models table, then selects all properties where modelId = ?.
|
|
796
|
+
* Each row includes schemaFileId for use with ModelProperty.createById(schemaFileId).
|
|
797
|
+
*/
|
|
798
|
+
const getModelPropertiesData = async (modelFileId) => {
|
|
799
|
+
const appDb = main_cjs.BaseDb.getAppDb();
|
|
800
|
+
if (!appDb || !modelFileId) {
|
|
801
|
+
return [];
|
|
802
|
+
}
|
|
803
|
+
const modelRows = await appDb
|
|
804
|
+
.select({ id: main_cjs.models.id })
|
|
805
|
+
.from(main_cjs.models)
|
|
806
|
+
.where(drizzleOrm.eq(main_cjs.models.schemaFileId, modelFileId))
|
|
807
|
+
.limit(1);
|
|
808
|
+
if (modelRows.length === 0) {
|
|
809
|
+
return [];
|
|
810
|
+
}
|
|
811
|
+
const modelId = modelRows[0].id;
|
|
812
|
+
const rows = await appDb
|
|
813
|
+
.select()
|
|
814
|
+
.from(main_cjs.properties)
|
|
815
|
+
.where(drizzleOrm.eq(main_cjs.properties.modelId, modelId));
|
|
816
|
+
return rows;
|
|
817
|
+
};
|
|
818
|
+
|
|
819
|
+
const logger = debug('seedSdk:modelProperty:ModelProperty');
|
|
820
|
+
// Define the property keys from TProperty
|
|
821
|
+
const TPropertyKeys = [
|
|
822
|
+
'id',
|
|
823
|
+
'name',
|
|
824
|
+
'dataType',
|
|
825
|
+
'ref',
|
|
826
|
+
'modelId',
|
|
827
|
+
'refModelId',
|
|
828
|
+
'refValueType',
|
|
829
|
+
'storageType',
|
|
830
|
+
'localStorageDir',
|
|
831
|
+
'filenameSuffix',
|
|
832
|
+
'modelName',
|
|
833
|
+
'refModelName',
|
|
834
|
+
];
|
|
835
|
+
class ModelProperty {
|
|
836
|
+
constructor(property) {
|
|
837
|
+
// id is now the schemaFileId (string), _dbId is the database integer ID
|
|
838
|
+
// Preserve _propertyFileId if it exists in the property object (from getPropertySchema)
|
|
839
|
+
// Convert null to undefined for optional fields (TypeBox validation expects undefined, not null)
|
|
840
|
+
const serviceInput = {
|
|
841
|
+
...property,
|
|
842
|
+
_propertyFileId: property._propertyFileId || property.id,
|
|
843
|
+
refValueType: property.refValueType ?? undefined,
|
|
844
|
+
refModelId: property.refModelId ?? undefined,
|
|
845
|
+
ref: property.ref ?? undefined,
|
|
846
|
+
refModelName: property.refModelName ?? undefined,
|
|
847
|
+
};
|
|
848
|
+
this._service = xstate.createActor(modelPropertyMachine, {
|
|
849
|
+
input: serviceInput,
|
|
850
|
+
});
|
|
851
|
+
this._service.start();
|
|
852
|
+
// Initialize original values from the input property
|
|
853
|
+
this._initializeOriginalValues(property);
|
|
854
|
+
// Note: Property getters/setters are now handled by the Proxy in create()
|
|
855
|
+
}
|
|
856
|
+
/**
|
|
857
|
+
* Initialize original values and schema name for tracking changes
|
|
858
|
+
* This is called asynchronously after construction
|
|
859
|
+
* If the property was loaded from the database and differs from the schema file,
|
|
860
|
+
* it will be marked as edited.
|
|
861
|
+
*/
|
|
862
|
+
_initializeOriginalValues(property) {
|
|
863
|
+
// Resolve refModelId if ref/refModelName is provided but refModelId is missing
|
|
864
|
+
const refModelName = property.refModelName || property.ref;
|
|
865
|
+
if (refModelName && !property.refModelId) {
|
|
866
|
+
// Resolve refModelId asynchronously and update context
|
|
867
|
+
this._resolveRefModelId(refModelName).then((refModelId) => {
|
|
868
|
+
if (refModelId) {
|
|
869
|
+
// Update the context with the resolved refModelId
|
|
870
|
+
this._service.send({
|
|
871
|
+
type: 'updateContext',
|
|
872
|
+
refModelId,
|
|
873
|
+
});
|
|
874
|
+
}
|
|
875
|
+
}).catch(() => {
|
|
876
|
+
// Ignore errors - model might not exist yet
|
|
877
|
+
});
|
|
878
|
+
}
|
|
879
|
+
// Get schema file values to use as "original" values
|
|
880
|
+
// This allows us to detect if the property was edited (DB value differs from schema file)
|
|
881
|
+
this._getSchemaFileValues(property).then((schemaFileValues) => {
|
|
882
|
+
// Use schema file values as original (not the current property values)
|
|
883
|
+
// This way, if current values differ from schema file, _isEdited will be true
|
|
884
|
+
const originalValues = schemaFileValues || {};
|
|
885
|
+
// Compare current property values with schema file values to determine if edited
|
|
886
|
+
// Only compare schema-relevant fields, not database-specific fields like id, modelId
|
|
887
|
+
let isEdited = false;
|
|
888
|
+
if (schemaFileValues) {
|
|
889
|
+
// Fields that are schema-relevant and should be compared
|
|
890
|
+
const schemaRelevantFields = [
|
|
891
|
+
'dataType',
|
|
892
|
+
'ref',
|
|
893
|
+
'refModelName',
|
|
894
|
+
'refValueType',
|
|
895
|
+
'storageType',
|
|
896
|
+
'localStorageDir',
|
|
897
|
+
'filenameSuffix',
|
|
898
|
+
];
|
|
899
|
+
// Check if any schema-relevant field differs between current property and schema file
|
|
900
|
+
isEdited = schemaRelevantFields.some((key) => {
|
|
901
|
+
const currentValue = property[key];
|
|
902
|
+
const originalValue = schemaFileValues[key];
|
|
903
|
+
// Handle ref fields - compare by name
|
|
904
|
+
if (key === 'ref' || key === 'refModelName') {
|
|
905
|
+
const currentRef = property.refModelName || property.ref;
|
|
906
|
+
const originalRef = schemaFileValues.refModelName || schemaFileValues.ref;
|
|
907
|
+
// Both undefined/null means no ref, so they're the same
|
|
908
|
+
if (!currentRef && !originalRef)
|
|
909
|
+
return false;
|
|
910
|
+
return currentRef !== originalRef;
|
|
911
|
+
}
|
|
912
|
+
// For other fields, compare values (handling undefined/null)
|
|
913
|
+
if (currentValue === undefined && originalValue === undefined)
|
|
914
|
+
return false;
|
|
915
|
+
if (currentValue === null && originalValue === null)
|
|
916
|
+
return false;
|
|
917
|
+
if (currentValue === undefined && originalValue === null)
|
|
918
|
+
return false;
|
|
919
|
+
if (currentValue === null && originalValue === undefined)
|
|
920
|
+
return false;
|
|
921
|
+
return currentValue !== originalValue;
|
|
922
|
+
});
|
|
923
|
+
}
|
|
924
|
+
else {
|
|
925
|
+
// No schema file values found - this is a runtime-created property
|
|
926
|
+
// Use current property as original, but mark as edited since it hasn't been exported to file
|
|
927
|
+
TPropertyKeys.forEach((key) => {
|
|
928
|
+
if (property[key] !== undefined) {
|
|
929
|
+
originalValues[key] = property[key];
|
|
930
|
+
}
|
|
931
|
+
});
|
|
932
|
+
// For runtime-created properties, set isEdited = true initially
|
|
933
|
+
isEdited = true;
|
|
934
|
+
}
|
|
935
|
+
// Initialize with original values, including isEdited flag
|
|
936
|
+
// Load isEdited from database if property exists in DB (async, fire-and-forget)
|
|
937
|
+
this._loadIsEditedFromDb(property, isEdited).then((isEditedFromDb) => {
|
|
938
|
+
this._service.send({
|
|
939
|
+
type: 'initializeOriginalValues',
|
|
940
|
+
originalValues,
|
|
941
|
+
schemaName: undefined, // Will be set later if needed
|
|
942
|
+
isEdited: isEditedFromDb,
|
|
943
|
+
});
|
|
944
|
+
}).catch(() => {
|
|
945
|
+
// If we can't load from DB, use computed isEdited value
|
|
946
|
+
this._service.send({
|
|
947
|
+
type: 'initializeOriginalValues',
|
|
948
|
+
originalValues,
|
|
949
|
+
schemaName: undefined, // Will be set later if needed
|
|
950
|
+
isEdited,
|
|
951
|
+
});
|
|
952
|
+
});
|
|
953
|
+
}).catch(() => {
|
|
954
|
+
// If we can't get schema file values, use current property as original
|
|
955
|
+
const originalValues = {};
|
|
956
|
+
TPropertyKeys.forEach((key) => {
|
|
957
|
+
if (property[key] !== undefined) {
|
|
958
|
+
originalValues[key] = property[key];
|
|
959
|
+
}
|
|
960
|
+
});
|
|
961
|
+
this._service.send({
|
|
962
|
+
type: 'initializeOriginalValues',
|
|
963
|
+
originalValues,
|
|
964
|
+
schemaName: undefined,
|
|
965
|
+
});
|
|
966
|
+
});
|
|
967
|
+
// Get schema name from model asynchronously (fire-and-forget)
|
|
968
|
+
if (property.modelName) {
|
|
969
|
+
this._setSchemaName(property.modelName).catch(() => {
|
|
970
|
+
// If we can't get schema name, that's okay - it will be set later if needed
|
|
971
|
+
});
|
|
972
|
+
}
|
|
973
|
+
}
|
|
974
|
+
/**
|
|
975
|
+
* Load isEdited flag from database if property exists in DB
|
|
976
|
+
* @param property - The property data
|
|
977
|
+
* @param fallbackIsEdited - Fallback value if property doesn't exist in DB
|
|
978
|
+
* @returns The isEdited flag from database or fallback value
|
|
979
|
+
*/
|
|
980
|
+
async _loadIsEditedFromDb(property, fallbackIsEdited) {
|
|
981
|
+
if (!property.modelName || !property.name) {
|
|
982
|
+
return fallbackIsEdited;
|
|
983
|
+
}
|
|
984
|
+
try {
|
|
985
|
+
const db = main_cjs.BaseDb.getAppDb();
|
|
986
|
+
if (!db) {
|
|
987
|
+
return fallbackIsEdited;
|
|
988
|
+
}
|
|
989
|
+
// Find model by name
|
|
990
|
+
const modelRecords = await db
|
|
991
|
+
.select({ id: main_cjs.models.id })
|
|
992
|
+
.from(main_cjs.models)
|
|
993
|
+
.where(drizzleOrm.eq(main_cjs.models.name, property.modelName))
|
|
994
|
+
.limit(1);
|
|
995
|
+
if (modelRecords.length === 0) {
|
|
996
|
+
return fallbackIsEdited;
|
|
997
|
+
}
|
|
998
|
+
// Find property by name and modelId
|
|
999
|
+
const propertyRecords = await db
|
|
1000
|
+
.select({ isEdited: main_cjs.properties.isEdited })
|
|
1001
|
+
.from(main_cjs.properties)
|
|
1002
|
+
.where(drizzleOrm.and(drizzleOrm.eq(main_cjs.properties.name, property.name), drizzleOrm.eq(main_cjs.properties.modelId, modelRecords[0].id)))
|
|
1003
|
+
.limit(1);
|
|
1004
|
+
if (propertyRecords.length > 0) {
|
|
1005
|
+
return propertyRecords[0].isEdited ?? false;
|
|
1006
|
+
}
|
|
1007
|
+
}
|
|
1008
|
+
catch (error) {
|
|
1009
|
+
// Ignore errors - use fallback value
|
|
1010
|
+
}
|
|
1011
|
+
return fallbackIsEdited;
|
|
1012
|
+
}
|
|
1013
|
+
/**
|
|
1014
|
+
* Resolve refModelId from refModelName by querying the database
|
|
1015
|
+
* @param refModelName - The name of the referenced model
|
|
1016
|
+
* @returns The database ID of the referenced model, or undefined if not found
|
|
1017
|
+
*/
|
|
1018
|
+
async _resolveRefModelId(refModelName) {
|
|
1019
|
+
if (!refModelName) {
|
|
1020
|
+
return undefined;
|
|
1021
|
+
}
|
|
1022
|
+
try {
|
|
1023
|
+
const db = main_cjs.BaseDb.getAppDb();
|
|
1024
|
+
if (!db) {
|
|
1025
|
+
return undefined;
|
|
1026
|
+
}
|
|
1027
|
+
const refModelRecords = await db
|
|
1028
|
+
.select()
|
|
1029
|
+
.from(main_cjs.models)
|
|
1030
|
+
.where(drizzleOrm.eq(main_cjs.models.name, refModelName))
|
|
1031
|
+
.limit(1);
|
|
1032
|
+
if (refModelRecords.length > 0 && refModelRecords[0].id) {
|
|
1033
|
+
return refModelRecords[0].id;
|
|
1034
|
+
}
|
|
1035
|
+
}
|
|
1036
|
+
catch (error) {
|
|
1037
|
+
// Ignore errors - model might not exist yet or database not available
|
|
1038
|
+
logger(`Error resolving refModelId for model "${refModelName}":`, error);
|
|
1039
|
+
}
|
|
1040
|
+
return undefined;
|
|
1041
|
+
}
|
|
1042
|
+
/**
|
|
1043
|
+
* Get schema file values for this property to use as "original" values
|
|
1044
|
+
* This allows comparison with database values to detect edits
|
|
1045
|
+
*/
|
|
1046
|
+
async _getSchemaFileValues(property) {
|
|
1047
|
+
if (!property.modelName || !property.name) {
|
|
1048
|
+
return undefined;
|
|
1049
|
+
}
|
|
1050
|
+
try {
|
|
1051
|
+
const model = await main_cjs.Model.getByNameAsync(property.modelName);
|
|
1052
|
+
if (!model || !model.properties || model.properties.length === 0) {
|
|
1053
|
+
return undefined;
|
|
1054
|
+
}
|
|
1055
|
+
const schema = main_cjs.modelPropertiesToObject(model.properties);
|
|
1056
|
+
// Get the schema file value for this property
|
|
1057
|
+
const schemaFileValue = schema[property.name];
|
|
1058
|
+
if (!schemaFileValue) {
|
|
1059
|
+
return undefined;
|
|
1060
|
+
}
|
|
1061
|
+
// Return schema file values as original values
|
|
1062
|
+
const originalValues = {
|
|
1063
|
+
name: property.name,
|
|
1064
|
+
modelName: property.modelName,
|
|
1065
|
+
dataType: schemaFileValue.dataType,
|
|
1066
|
+
storageType: schemaFileValue.storageType,
|
|
1067
|
+
localStorageDir: schemaFileValue.localStorageDir,
|
|
1068
|
+
filenameSuffix: schemaFileValue.filenameSuffix,
|
|
1069
|
+
};
|
|
1070
|
+
// Handle ref fields
|
|
1071
|
+
if (schemaFileValue.ref) {
|
|
1072
|
+
originalValues.ref = schemaFileValue.ref;
|
|
1073
|
+
originalValues.refModelName = schemaFileValue.ref;
|
|
1074
|
+
// Try to get refModelId from database
|
|
1075
|
+
const refModelId = await this._resolveRefModelId(schemaFileValue.ref);
|
|
1076
|
+
if (refModelId) {
|
|
1077
|
+
originalValues.refModelId = refModelId;
|
|
1078
|
+
}
|
|
1079
|
+
}
|
|
1080
|
+
if (schemaFileValue.refValueType) {
|
|
1081
|
+
originalValues.refValueType = schemaFileValue.refValueType;
|
|
1082
|
+
}
|
|
1083
|
+
return originalValues;
|
|
1084
|
+
}
|
|
1085
|
+
catch (error) {
|
|
1086
|
+
return undefined;
|
|
1087
|
+
}
|
|
1088
|
+
}
|
|
1089
|
+
/**
|
|
1090
|
+
* Set the schema name for this property by looking it up from the model
|
|
1091
|
+
* Tries database first (more reliable), then falls back to schema files
|
|
1092
|
+
*/
|
|
1093
|
+
async _setSchemaName(modelName) {
|
|
1094
|
+
try {
|
|
1095
|
+
let schemaName;
|
|
1096
|
+
// Try to get schema name from database first (more reliable)
|
|
1097
|
+
if (this.modelId) {
|
|
1098
|
+
try {
|
|
1099
|
+
const db = main_cjs.BaseDb.getAppDb();
|
|
1100
|
+
if (db) {
|
|
1101
|
+
const modelSchemaRecords = await db
|
|
1102
|
+
.select({
|
|
1103
|
+
schemaName: main_cjs.schemas.name,
|
|
1104
|
+
})
|
|
1105
|
+
.from(main_cjs.modelSchemas)
|
|
1106
|
+
.innerJoin(main_cjs.schemas, drizzleOrm.eq(main_cjs.modelSchemas.schemaId, main_cjs.schemas.id))
|
|
1107
|
+
.innerJoin(main_cjs.models, drizzleOrm.eq(main_cjs.modelSchemas.modelId, main_cjs.models.id))
|
|
1108
|
+
.where(drizzleOrm.eq(main_cjs.models.id, this.modelId))
|
|
1109
|
+
.limit(1);
|
|
1110
|
+
if (modelSchemaRecords.length > 0) {
|
|
1111
|
+
schemaName = modelSchemaRecords[0].schemaName;
|
|
1112
|
+
}
|
|
1113
|
+
}
|
|
1114
|
+
}
|
|
1115
|
+
catch (error) {
|
|
1116
|
+
// Database lookup failed, continue to file-based lookup
|
|
1117
|
+
}
|
|
1118
|
+
}
|
|
1119
|
+
// Fall back to schema file lookup if database didn't work
|
|
1120
|
+
if (!schemaName) {
|
|
1121
|
+
schemaName = await getSchemaNameFromModel(modelName);
|
|
1122
|
+
}
|
|
1123
|
+
if (schemaName) {
|
|
1124
|
+
// Update the context with the schema name using dedicated event
|
|
1125
|
+
this._service.send({
|
|
1126
|
+
type: 'setSchemaName',
|
|
1127
|
+
schemaName,
|
|
1128
|
+
});
|
|
1129
|
+
}
|
|
1130
|
+
}
|
|
1131
|
+
catch (error) {
|
|
1132
|
+
// If we can't get schema name, that's okay - it will be set later if needed
|
|
1133
|
+
}
|
|
1134
|
+
}
|
|
1135
|
+
/**
|
|
1136
|
+
* Manually set the schema name for this property
|
|
1137
|
+
* Useful when you know the schema name from context (e.g., when working with Schema instances)
|
|
1138
|
+
*/
|
|
1139
|
+
setSchemaName(schemaName) {
|
|
1140
|
+
this._service.send({
|
|
1141
|
+
type: 'setSchemaName',
|
|
1142
|
+
schemaName,
|
|
1143
|
+
});
|
|
1144
|
+
}
|
|
1145
|
+
static create(property, options) {
|
|
1146
|
+
if (!property) {
|
|
1147
|
+
throw new Error('Property is required');
|
|
1148
|
+
}
|
|
1149
|
+
const waitForReady = options?.waitForReady !== false;
|
|
1150
|
+
const readyTimeout = options?.readyTimeout ?? 5000;
|
|
1151
|
+
const schemaName = options?.schemaName;
|
|
1152
|
+
// Handle 'type' field from JSON schema format - convert to 'dataType'
|
|
1153
|
+
// Normalize to PascalCase so lowercase values from JSON (e.g. 'text') work
|
|
1154
|
+
const propertyWithId = { ...property };
|
|
1155
|
+
const rawType = propertyWithId.dataType ?? propertyWithId.type;
|
|
1156
|
+
if (rawType) {
|
|
1157
|
+
propertyWithId.dataType = main_cjs.normalizeDataType(rawType);
|
|
1158
|
+
}
|
|
1159
|
+
// Ensure id (schemaFileId) is set correctly
|
|
1160
|
+
// Priority: _propertyFileId > id (if string) > generate new
|
|
1161
|
+
// If id is a number (old format), use _propertyFileId instead
|
|
1162
|
+
if (typeof propertyWithId.id === 'number') {
|
|
1163
|
+
// id is a database integer ID, not schemaFileId - use _propertyFileId if available
|
|
1164
|
+
if (propertyWithId._propertyFileId) {
|
|
1165
|
+
propertyWithId.id = propertyWithId._propertyFileId;
|
|
1166
|
+
}
|
|
1167
|
+
else {
|
|
1168
|
+
// Fallback: generate new schemaFileId (shouldn't happen, but safety)
|
|
1169
|
+
propertyWithId.id = main_cjs.generateId();
|
|
1170
|
+
logger(`ModelProperty.create: id was a number, generated new schemaFileId "${propertyWithId.id}" for property "${property.name}"`);
|
|
1171
|
+
}
|
|
1172
|
+
}
|
|
1173
|
+
else if (!propertyWithId.id && propertyWithId._propertyFileId) {
|
|
1174
|
+
// id is not set but _propertyFileId is available - use it
|
|
1175
|
+
propertyWithId.id = propertyWithId._propertyFileId;
|
|
1176
|
+
}
|
|
1177
|
+
else if (!propertyWithId.id) {
|
|
1178
|
+
// Generate id (schemaFileId) if not provided (for new properties)
|
|
1179
|
+
// This ensures new properties can trigger write process
|
|
1180
|
+
propertyWithId.id = main_cjs.generateId();
|
|
1181
|
+
logger(`ModelProperty.create: Generated new id (schemaFileId) "${propertyWithId.id}" for property "${property.name}"`);
|
|
1182
|
+
}
|
|
1183
|
+
// Create cache key from modelName and name, or use id
|
|
1184
|
+
const cacheKey = propertyWithId.modelName && propertyWithId.name
|
|
1185
|
+
? `${propertyWithId.modelName}:${propertyWithId.name}`
|
|
1186
|
+
: propertyWithId.id
|
|
1187
|
+
? `id:${propertyWithId.id}`
|
|
1188
|
+
: propertyWithId.name || 'unnamed';
|
|
1189
|
+
// Check if instance exists in cache
|
|
1190
|
+
if (this.instanceCache.has(cacheKey)) {
|
|
1191
|
+
const { instance, refCount } = this.instanceCache.get(cacheKey);
|
|
1192
|
+
const cachedContext = instance._getSnapshotContext();
|
|
1193
|
+
// Update cached instance if new property data has fields that the cached instance doesn't have
|
|
1194
|
+
// This handles cases where the property was created without ref initially, but now we have ref from schema
|
|
1195
|
+
const needsUpdate = {};
|
|
1196
|
+
if (propertyWithId.ref && !cachedContext.ref) {
|
|
1197
|
+
needsUpdate.ref = propertyWithId.ref;
|
|
1198
|
+
}
|
|
1199
|
+
if (propertyWithId.refModelName && !cachedContext.refModelName) {
|
|
1200
|
+
needsUpdate.refModelName = propertyWithId.refModelName;
|
|
1201
|
+
}
|
|
1202
|
+
if (propertyWithId.refModelId && !cachedContext.refModelId) {
|
|
1203
|
+
needsUpdate.refModelId = propertyWithId.refModelId;
|
|
1204
|
+
}
|
|
1205
|
+
if (Object.keys(needsUpdate).length > 0) {
|
|
1206
|
+
instance._service.send({
|
|
1207
|
+
type: 'updateContext',
|
|
1208
|
+
...needsUpdate,
|
|
1209
|
+
});
|
|
1210
|
+
}
|
|
1211
|
+
this.instanceCache.set(cacheKey, {
|
|
1212
|
+
instance,
|
|
1213
|
+
refCount: refCount + 1,
|
|
1214
|
+
});
|
|
1215
|
+
if (!waitForReady)
|
|
1216
|
+
return instance;
|
|
1217
|
+
return main_cjs.waitForEntityIdle(instance, { timeout: readyTimeout }).then(() => instance);
|
|
1218
|
+
}
|
|
1219
|
+
const newInstance = new this(propertyWithId);
|
|
1220
|
+
// Set schema name before async operations so getModelId can resolve the correct model
|
|
1221
|
+
if (schemaName) {
|
|
1222
|
+
newInstance._service.send({
|
|
1223
|
+
type: 'setSchemaName',
|
|
1224
|
+
schemaName,
|
|
1225
|
+
});
|
|
1226
|
+
}
|
|
1227
|
+
// Wrap instance in Proxy for reactive property access
|
|
1228
|
+
const proxiedInstance = main_cjs.createReactiveProxy({
|
|
1229
|
+
instance: newInstance,
|
|
1230
|
+
service: newInstance._service,
|
|
1231
|
+
trackedProperties: TPropertyKeys,
|
|
1232
|
+
getContext: (instance) => {
|
|
1233
|
+
const context = instance._getSnapshotContext();
|
|
1234
|
+
return context;
|
|
1235
|
+
},
|
|
1236
|
+
sendUpdate: (instance, prop, value) => {
|
|
1237
|
+
const currentContext = instance._getSnapshotContext();
|
|
1238
|
+
if (currentContext[prop] === value)
|
|
1239
|
+
return; // No-op, avoid triggering machine
|
|
1240
|
+
instance._service.send({
|
|
1241
|
+
type: 'updateContext',
|
|
1242
|
+
[prop]: value,
|
|
1243
|
+
});
|
|
1244
|
+
},
|
|
1245
|
+
});
|
|
1246
|
+
this.instanceCache.set(cacheKey, {
|
|
1247
|
+
instance: proxiedInstance,
|
|
1248
|
+
refCount: 1,
|
|
1249
|
+
});
|
|
1250
|
+
// Trigger write process if property has modelId (or modelName) and id (schemaFileId)
|
|
1251
|
+
// Wait for service to be ready (idle state) and have writeProcess spawned
|
|
1252
|
+
const propertyFileId = propertyWithId.id; // id is now the schemaFileId (string)
|
|
1253
|
+
const hasModelId = propertyWithId.modelId || propertyWithId.modelName;
|
|
1254
|
+
if (hasModelId && propertyFileId) {
|
|
1255
|
+
// Wait for writeProcess to be spawned (it's spawned in idle state entry action)
|
|
1256
|
+
// Retry a few times if writeProcess isn't available yet
|
|
1257
|
+
let retries = 0;
|
|
1258
|
+
const maxRetries = 10;
|
|
1259
|
+
const checkAndSend = async () => {
|
|
1260
|
+
const service = proxiedInstance.getService();
|
|
1261
|
+
const snapshot = service.getSnapshot();
|
|
1262
|
+
if (snapshot.value === 'idle' && snapshot.context.writeProcess) {
|
|
1263
|
+
const writeProcess = snapshot.context.writeProcess;
|
|
1264
|
+
// Resolve dbModelId - convert from string (modelFileId) to number (database ID) if needed
|
|
1265
|
+
let resolvedModelId = undefined;
|
|
1266
|
+
if (propertyWithId.modelId) {
|
|
1267
|
+
if (typeof propertyWithId.modelId === 'number') {
|
|
1268
|
+
resolvedModelId = propertyWithId.modelId;
|
|
1269
|
+
}
|
|
1270
|
+
else if (typeof propertyWithId.modelId === 'string') {
|
|
1271
|
+
// modelId is a string (modelFileId), need to convert to database ID
|
|
1272
|
+
try {
|
|
1273
|
+
resolvedModelId = await main_cjs.getModelIdByFileId(propertyWithId.modelId);
|
|
1274
|
+
logger(`Converted modelFileId "${propertyWithId.modelId}" to database modelId: ${resolvedModelId}`);
|
|
1275
|
+
}
|
|
1276
|
+
catch (error) {
|
|
1277
|
+
logger(`Failed to convert modelFileId "${propertyWithId.modelId}" to database ID: ${error}`);
|
|
1278
|
+
console.error(`[ModelProperty.create] Failed to convert modelFileId: ${error}`);
|
|
1279
|
+
}
|
|
1280
|
+
}
|
|
1281
|
+
}
|
|
1282
|
+
// If we still don't have a modelId, try to resolve it from modelName
|
|
1283
|
+
if (!resolvedModelId && propertyWithId.modelName) {
|
|
1284
|
+
try {
|
|
1285
|
+
// Get schemaName from context if available
|
|
1286
|
+
const schemaName = snapshot.context._schemaName;
|
|
1287
|
+
resolvedModelId = await main_cjs.getModelId(propertyWithId.modelName, schemaName);
|
|
1288
|
+
logger(`Resolved modelId for model "${propertyWithId.modelName}": ${resolvedModelId}`);
|
|
1289
|
+
}
|
|
1290
|
+
catch (error) {
|
|
1291
|
+
logger(`Failed to resolve modelId for model "${propertyWithId.modelName}": ${error}`);
|
|
1292
|
+
console.error(`[ModelProperty.create] Failed to resolve modelId: ${error}`);
|
|
1293
|
+
}
|
|
1294
|
+
}
|
|
1295
|
+
if (!resolvedModelId) {
|
|
1296
|
+
logger(`ERROR: Cannot write property "${property.name}" - no modelId available`);
|
|
1297
|
+
console.error(`[ModelProperty.create] ERROR: Cannot write property "${property.name}" - no modelId available. modelId: ${propertyWithId.modelId}, modelName: ${propertyWithId.modelName}`);
|
|
1298
|
+
// Don't clear pending write here - it might resolve later
|
|
1299
|
+
return;
|
|
1300
|
+
}
|
|
1301
|
+
// Track pending write now that we have the resolved modelId
|
|
1302
|
+
this.trackPendingWrite(propertyFileId, resolvedModelId);
|
|
1303
|
+
logger(`Triggering write process for property "${property.name}" (modelId: ${resolvedModelId}, propertyFileId: ${propertyFileId})`);
|
|
1304
|
+
// Check current write state
|
|
1305
|
+
const currentWriteState = writeProcess.getSnapshot();
|
|
1306
|
+
if (currentWriteState.value === 'success') {
|
|
1307
|
+
// Write already succeeded, clear pending write immediately
|
|
1308
|
+
this.clearPendingWrite(propertyFileId, 'success');
|
|
1309
|
+
}
|
|
1310
|
+
else {
|
|
1311
|
+
// Set up subscription to catch future state changes
|
|
1312
|
+
const writeSubscription = writeProcess.subscribe((writeSnapshot) => {
|
|
1313
|
+
if (writeSnapshot.value === 'success') {
|
|
1314
|
+
writeSubscription.unsubscribe();
|
|
1315
|
+
logger(`[writeProcess subscription] Write succeeded for property "${property.name}" (propertyFileId: ${propertyFileId})`);
|
|
1316
|
+
// Clear pending write on success
|
|
1317
|
+
this.clearPendingWrite(propertyFileId, 'success');
|
|
1318
|
+
}
|
|
1319
|
+
else if (writeSnapshot.value === 'error') {
|
|
1320
|
+
writeSubscription.unsubscribe();
|
|
1321
|
+
const errorContext = writeSnapshot.context;
|
|
1322
|
+
logger(`Write process failed for property "${property.name}" (propertyFileId: ${propertyFileId}): ${errorContext.error?.message || 'Unknown error'}`);
|
|
1323
|
+
logger(`Write process error details:`, errorContext.error);
|
|
1324
|
+
// Mark pending write as error
|
|
1325
|
+
this.clearPendingWrite(propertyFileId, 'error');
|
|
1326
|
+
}
|
|
1327
|
+
});
|
|
1328
|
+
}
|
|
1329
|
+
const propertyData = {
|
|
1330
|
+
modelId: resolvedModelId,
|
|
1331
|
+
name: property.name,
|
|
1332
|
+
dataType: property.dataType,
|
|
1333
|
+
refModelId: property.refModelId,
|
|
1334
|
+
refValueType: property.refValueType,
|
|
1335
|
+
storageType: property.storageType,
|
|
1336
|
+
localStorageDir: property.localStorageDir,
|
|
1337
|
+
filenameSuffix: property.filenameSuffix,
|
|
1338
|
+
};
|
|
1339
|
+
service.send({
|
|
1340
|
+
type: 'requestWrite',
|
|
1341
|
+
data: propertyData,
|
|
1342
|
+
});
|
|
1343
|
+
}
|
|
1344
|
+
else if (retries < maxRetries) {
|
|
1345
|
+
retries++;
|
|
1346
|
+
setTimeout(checkAndSend, 50); // Retry after 50ms
|
|
1347
|
+
}
|
|
1348
|
+
else {
|
|
1349
|
+
logger(`ERROR: writeProcess not available after ${maxRetries} retries for property "${property.name}" (propertyFileId: ${propertyFileId})`);
|
|
1350
|
+
console.error(`[ModelProperty.create] ERROR: writeProcess not available after ${maxRetries} retries for property "${property.name}" (propertyFileId: ${propertyFileId})`);
|
|
1351
|
+
// Mark as error if we couldn't even start the write process
|
|
1352
|
+
this.clearPendingWrite(propertyFileId, 'error');
|
|
1353
|
+
}
|
|
1354
|
+
};
|
|
1355
|
+
// Start checking after a short delay to allow state machine to initialize
|
|
1356
|
+
setTimeout(checkAndSend, 0);
|
|
1357
|
+
}
|
|
1358
|
+
if (!waitForReady)
|
|
1359
|
+
return proxiedInstance;
|
|
1360
|
+
return main_cjs.waitForEntityIdle(proxiedInstance, { timeout: readyTimeout }).then(() => proxiedInstance);
|
|
1361
|
+
}
|
|
1362
|
+
/**
|
|
1363
|
+
* Get ModelProperty instance by propertyFileId from static cache
|
|
1364
|
+
*/
|
|
1365
|
+
static getById(propertyFileId) {
|
|
1366
|
+
if (!propertyFileId)
|
|
1367
|
+
return undefined;
|
|
1368
|
+
// Search through cache to find by propertyFileId
|
|
1369
|
+
// Cache key might be "modelName:propertyName" or "id:propertyId"
|
|
1370
|
+
for (const [cacheKey, { instance }] of this.instanceCache.entries()) {
|
|
1371
|
+
const context = instance._getSnapshotContext();
|
|
1372
|
+
// id is now the schemaFileId (string)
|
|
1373
|
+
if (context.id === propertyFileId) {
|
|
1374
|
+
return instance;
|
|
1375
|
+
}
|
|
1376
|
+
}
|
|
1377
|
+
return undefined;
|
|
1378
|
+
}
|
|
1379
|
+
/**
|
|
1380
|
+
* Create or get ModelProperty instance by propertyFileId
|
|
1381
|
+
* Queries the database to find the property if not cached
|
|
1382
|
+
*/
|
|
1383
|
+
static async createById(propertyFileId) {
|
|
1384
|
+
if (!propertyFileId) {
|
|
1385
|
+
return undefined;
|
|
1386
|
+
}
|
|
1387
|
+
// First, check if we have an instance cached
|
|
1388
|
+
const cachedInstance = this.getById(propertyFileId);
|
|
1389
|
+
if (cachedInstance) {
|
|
1390
|
+
return cachedInstance;
|
|
1391
|
+
}
|
|
1392
|
+
// Query database to get property data from ID
|
|
1393
|
+
const db = main_cjs.BaseDb.getAppDb();
|
|
1394
|
+
if (!db) {
|
|
1395
|
+
return undefined;
|
|
1396
|
+
}
|
|
1397
|
+
await db
|
|
1398
|
+
.select()
|
|
1399
|
+
.from(main_cjs.properties)
|
|
1400
|
+
.limit(100);
|
|
1401
|
+
const propertyRecords = await db
|
|
1402
|
+
.select()
|
|
1403
|
+
.from(main_cjs.properties)
|
|
1404
|
+
.where(drizzleOrm.eq(main_cjs.properties.schemaFileId, propertyFileId))
|
|
1405
|
+
.limit(1);
|
|
1406
|
+
if (propertyRecords.length === 0) {
|
|
1407
|
+
return undefined;
|
|
1408
|
+
}
|
|
1409
|
+
const propertyRecord = propertyRecords[0];
|
|
1410
|
+
// Get model name
|
|
1411
|
+
const modelRecords = await db
|
|
1412
|
+
.select({ name: main_cjs.models.name })
|
|
1413
|
+
.from(main_cjs.models)
|
|
1414
|
+
.where(drizzleOrm.eq(main_cjs.models.id, propertyRecord.modelId))
|
|
1415
|
+
.limit(1);
|
|
1416
|
+
if (modelRecords.length === 0) {
|
|
1417
|
+
return undefined;
|
|
1418
|
+
}
|
|
1419
|
+
const modelName = modelRecords[0].name;
|
|
1420
|
+
// Build property data
|
|
1421
|
+
// id is now the schemaFileId (string), _dbId is the database integer ID
|
|
1422
|
+
const propertyData = {
|
|
1423
|
+
id: propertyFileId, // schemaFileId (string) - public ID
|
|
1424
|
+
_dbId: propertyRecord.id ?? undefined, // Database integer ID - internal only
|
|
1425
|
+
name: propertyRecord.name,
|
|
1426
|
+
dataType: propertyRecord.dataType,
|
|
1427
|
+
modelId: propertyRecord.modelId,
|
|
1428
|
+
modelName,
|
|
1429
|
+
refModelId: propertyRecord.refModelId || undefined,
|
|
1430
|
+
refValueType: propertyRecord.refValueType ? propertyRecord.refValueType : undefined,
|
|
1431
|
+
};
|
|
1432
|
+
// Load isEdited from database
|
|
1433
|
+
const isEditedFromDb = propertyRecord.isEdited ?? false;
|
|
1434
|
+
// Get ref model name if applicable
|
|
1435
|
+
if (propertyRecord.refModelId) {
|
|
1436
|
+
const refModelRecords = await db
|
|
1437
|
+
.select({ name: main_cjs.models.name })
|
|
1438
|
+
.from(main_cjs.models)
|
|
1439
|
+
.where(drizzleOrm.eq(main_cjs.models.id, propertyRecord.refModelId))
|
|
1440
|
+
.limit(1);
|
|
1441
|
+
if (refModelRecords.length > 0) {
|
|
1442
|
+
propertyData.refModelName = refModelRecords[0].name;
|
|
1443
|
+
propertyData.ref = refModelRecords[0].name;
|
|
1444
|
+
}
|
|
1445
|
+
}
|
|
1446
|
+
// Create ModelProperty instance (sync for createById so we can send updateContext)
|
|
1447
|
+
const instance = this.create(propertyData, { waitForReady: false });
|
|
1448
|
+
// Set isEdited from database after creation
|
|
1449
|
+
if (isEditedFromDb) {
|
|
1450
|
+
instance._service.send({
|
|
1451
|
+
type: 'updateContext',
|
|
1452
|
+
_isEdited: true,
|
|
1453
|
+
});
|
|
1454
|
+
}
|
|
1455
|
+
return instance;
|
|
1456
|
+
}
|
|
1457
|
+
/**
|
|
1458
|
+
* Find ModelProperty instance by propertyFileId
|
|
1459
|
+
* Waits for the property to be fully loaded (idle state) by default
|
|
1460
|
+
* @param options - Find options including propertyFileId and wait configuration
|
|
1461
|
+
* @returns ModelProperty instance if found, undefined otherwise
|
|
1462
|
+
*/
|
|
1463
|
+
static async find({ propertyFileId, waitForReady = true, readyTimeout = 5000, }) {
|
|
1464
|
+
if (!propertyFileId) {
|
|
1465
|
+
return undefined;
|
|
1466
|
+
}
|
|
1467
|
+
return await main_cjs.findEntity({
|
|
1468
|
+
getById: (id) => ModelProperty.getById(id),
|
|
1469
|
+
createById: (id) => ModelProperty.createById(id),
|
|
1470
|
+
}, { id: propertyFileId }, {
|
|
1471
|
+
waitForReady,
|
|
1472
|
+
readyTimeout,
|
|
1473
|
+
});
|
|
1474
|
+
}
|
|
1475
|
+
/**
|
|
1476
|
+
* Get all ModelProperty instances for a model.
|
|
1477
|
+
* Loads property rows from DB for the given modelFileId, creates instances via createById, optionally waits for idle.
|
|
1478
|
+
*/
|
|
1479
|
+
static async all(modelFileId, options) {
|
|
1480
|
+
const { waitForReady = false, readyTimeout = 5000 } = options ?? {};
|
|
1481
|
+
if (!modelFileId) {
|
|
1482
|
+
return [];
|
|
1483
|
+
}
|
|
1484
|
+
const rows = await getModelPropertiesData(modelFileId);
|
|
1485
|
+
const instances = [];
|
|
1486
|
+
for (const row of rows) {
|
|
1487
|
+
if (row.schemaFileId) {
|
|
1488
|
+
const instance = await this.createById(row.schemaFileId);
|
|
1489
|
+
if (instance) {
|
|
1490
|
+
instances.push(instance);
|
|
1491
|
+
}
|
|
1492
|
+
}
|
|
1493
|
+
}
|
|
1494
|
+
if (waitForReady && instances.length > 0) {
|
|
1495
|
+
await Promise.all(instances.map((p) => main_cjs.waitForEntityIdle(p, {
|
|
1496
|
+
timeout: readyTimeout,
|
|
1497
|
+
})));
|
|
1498
|
+
}
|
|
1499
|
+
return instances;
|
|
1500
|
+
}
|
|
1501
|
+
/**
|
|
1502
|
+
* Track a pending write for a property
|
|
1503
|
+
*/
|
|
1504
|
+
static trackPendingWrite(propertyFileId, modelId) {
|
|
1505
|
+
this.pendingWrites.set(propertyFileId, {
|
|
1506
|
+
propertyFileId,
|
|
1507
|
+
modelId,
|
|
1508
|
+
status: 'pending',
|
|
1509
|
+
timestamp: Date.now(),
|
|
1510
|
+
});
|
|
1511
|
+
}
|
|
1512
|
+
/**
|
|
1513
|
+
* Clear or update pending write status
|
|
1514
|
+
*/
|
|
1515
|
+
static clearPendingWrite(propertyFileId, status = 'success') {
|
|
1516
|
+
const write = this.pendingWrites.get(propertyFileId);
|
|
1517
|
+
if (write) {
|
|
1518
|
+
if (status === 'success') {
|
|
1519
|
+
// Remove successful writes from pendingWrites
|
|
1520
|
+
this.pendingWrites.delete(propertyFileId);
|
|
1521
|
+
logger(`Cleared pending write for property "${propertyFileId}" (status: success)`);
|
|
1522
|
+
}
|
|
1523
|
+
else {
|
|
1524
|
+
// Update status to error but keep in map (for debugging/retry purposes)
|
|
1525
|
+
write.status = 'error';
|
|
1526
|
+
this.pendingWrites.set(propertyFileId, write);
|
|
1527
|
+
logger(`Marked pending write as error for property "${propertyFileId}"`);
|
|
1528
|
+
}
|
|
1529
|
+
}
|
|
1530
|
+
}
|
|
1531
|
+
/**
|
|
1532
|
+
* Get all pending property IDs for a model
|
|
1533
|
+
*/
|
|
1534
|
+
static getPendingPropertyIds(modelId) {
|
|
1535
|
+
return Array.from(this.pendingWrites.entries())
|
|
1536
|
+
.filter(([_, write]) => write.modelId === modelId && write.status !== 'error')
|
|
1537
|
+
.map(([propertyFileId]) => propertyFileId);
|
|
1538
|
+
}
|
|
1539
|
+
/**
|
|
1540
|
+
* Get modelId for a property that has a pending write (row may not be in DB yet).
|
|
1541
|
+
* Used to resolve modelName when validating a just-created property rename.
|
|
1542
|
+
*/
|
|
1543
|
+
static getPendingModelId(propertyFileId) {
|
|
1544
|
+
return this.pendingWrites.get(propertyFileId)?.modelId;
|
|
1545
|
+
}
|
|
1546
|
+
getService() {
|
|
1547
|
+
return this._service;
|
|
1548
|
+
}
|
|
1549
|
+
_getSnapshot() {
|
|
1550
|
+
return this._service.getSnapshot();
|
|
1551
|
+
}
|
|
1552
|
+
_getSnapshotContext() {
|
|
1553
|
+
return this._getSnapshot().context;
|
|
1554
|
+
}
|
|
1555
|
+
get path() {
|
|
1556
|
+
const workingDir = main_cjs.BaseFileManager.getWorkingDir();
|
|
1557
|
+
if (!this.localStorageDir || !this.name || !this.filenameSuffix) {
|
|
1558
|
+
return undefined;
|
|
1559
|
+
}
|
|
1560
|
+
return `${workingDir}/${this.localStorageDir}/${this.name}${this.filenameSuffix || ''}`;
|
|
1561
|
+
}
|
|
1562
|
+
get status() {
|
|
1563
|
+
return this._getSnapshot().value;
|
|
1564
|
+
}
|
|
1565
|
+
get isEdited() {
|
|
1566
|
+
const context = this._getSnapshotContext();
|
|
1567
|
+
// First check in-memory state
|
|
1568
|
+
if (context._isEdited !== undefined) {
|
|
1569
|
+
return context._isEdited;
|
|
1570
|
+
}
|
|
1571
|
+
// Fall back to reading from database if we have _dbId
|
|
1572
|
+
if (context._dbId) {
|
|
1573
|
+
// Load from database asynchronously (fire-and-forget for now)
|
|
1574
|
+
// For synchronous getter, we'll need to cache it or make it async
|
|
1575
|
+
// For now, return false if not in context
|
|
1576
|
+
return false;
|
|
1577
|
+
}
|
|
1578
|
+
return false;
|
|
1579
|
+
}
|
|
1580
|
+
get validationErrors() {
|
|
1581
|
+
return this._getSnapshotContext()._validationErrors || [];
|
|
1582
|
+
}
|
|
1583
|
+
get isValid() {
|
|
1584
|
+
const errors = this.validationErrors;
|
|
1585
|
+
return errors.length === 0;
|
|
1586
|
+
}
|
|
1587
|
+
/**
|
|
1588
|
+
* Validate the property
|
|
1589
|
+
* @returns Validation result
|
|
1590
|
+
*/
|
|
1591
|
+
async validate() {
|
|
1592
|
+
return new Promise((resolve) => {
|
|
1593
|
+
let resolved = false;
|
|
1594
|
+
const subscription = this._service.subscribe((snapshot) => {
|
|
1595
|
+
const state = snapshot.value;
|
|
1596
|
+
// Wait for validation to complete (idle state after validating)
|
|
1597
|
+
if (state === 'idle' && !resolved) {
|
|
1598
|
+
resolved = true;
|
|
1599
|
+
subscription.unsubscribe();
|
|
1600
|
+
const errors = snapshot.context._validationErrors || [];
|
|
1601
|
+
resolve({
|
|
1602
|
+
isValid: errors.length === 0,
|
|
1603
|
+
errors,
|
|
1604
|
+
});
|
|
1605
|
+
}
|
|
1606
|
+
});
|
|
1607
|
+
this._service.send({ type: 'validateProperty' });
|
|
1608
|
+
// Timeout fallback
|
|
1609
|
+
setTimeout(() => {
|
|
1610
|
+
if (!resolved) {
|
|
1611
|
+
resolved = true;
|
|
1612
|
+
subscription.unsubscribe();
|
|
1613
|
+
const errors = this._getSnapshotContext()._validationErrors || [];
|
|
1614
|
+
resolve({
|
|
1615
|
+
isValid: errors.length === 0,
|
|
1616
|
+
errors,
|
|
1617
|
+
});
|
|
1618
|
+
}
|
|
1619
|
+
}, 5000);
|
|
1620
|
+
});
|
|
1621
|
+
}
|
|
1622
|
+
save() {
|
|
1623
|
+
const snapshot = this._service.getSnapshot();
|
|
1624
|
+
const isAlreadySaving = typeof snapshot.value === 'object' && snapshot.value !== null && 'saveToSchema' in snapshot.value;
|
|
1625
|
+
if (isAlreadySaving) {
|
|
1626
|
+
return;
|
|
1627
|
+
}
|
|
1628
|
+
const context = snapshot.context;
|
|
1629
|
+
if (!context._isEdited)
|
|
1630
|
+
return; // No changes to persist
|
|
1631
|
+
// Validation will happen automatically in the machine before saving
|
|
1632
|
+
this._service.send({
|
|
1633
|
+
type: 'saveToSchema',
|
|
1634
|
+
});
|
|
1635
|
+
}
|
|
1636
|
+
/**
|
|
1637
|
+
* Reload property from database
|
|
1638
|
+
* This refreshes the actor context with the latest data from the database
|
|
1639
|
+
* Note: ModelProperty doesn't have a dedicated load actor, so this will
|
|
1640
|
+
* re-initialize from the current property data
|
|
1641
|
+
*/
|
|
1642
|
+
async reload() {
|
|
1643
|
+
// ModelProperty doesn't have a separate load mechanism
|
|
1644
|
+
// It's loaded as part of the Model/Schema
|
|
1645
|
+
// This method is provided for API consistency
|
|
1646
|
+
// To actually reload, you'd need to reload the parent Model or Schema
|
|
1647
|
+
logger('ModelProperty.reload() called - ModelProperty is loaded as part of Model/Schema. Reload the parent Model or Schema instead.');
|
|
1648
|
+
// No-op for now, but could be enhanced to reload from DB if needed
|
|
1649
|
+
}
|
|
1650
|
+
unload() {
|
|
1651
|
+
// ModelProperty doesn't have liveQuery subscriptions or complex cache management
|
|
1652
|
+
// Just stop the service
|
|
1653
|
+
try {
|
|
1654
|
+
this._service.stop();
|
|
1655
|
+
}
|
|
1656
|
+
catch (error) {
|
|
1657
|
+
// Service might already be stopped
|
|
1658
|
+
}
|
|
1659
|
+
}
|
|
1660
|
+
/**
|
|
1661
|
+
* Destroy the model property: remove from caches, delete from database, update Schema context, stop service.
|
|
1662
|
+
*/
|
|
1663
|
+
async destroy() {
|
|
1664
|
+
const context = this._getSnapshotContext();
|
|
1665
|
+
const cacheKey = context.modelName && context.name
|
|
1666
|
+
? `${context.modelName}:${context.name}`
|
|
1667
|
+
: (context.id ?? '');
|
|
1668
|
+
if (!cacheKey)
|
|
1669
|
+
return;
|
|
1670
|
+
main_cjs.forceRemoveFromCaches(this, {
|
|
1671
|
+
getCacheKeys: () => [cacheKey],
|
|
1672
|
+
caches: [ModelProperty.instanceCache],
|
|
1673
|
+
});
|
|
1674
|
+
await main_cjs.runDestroyLifecycle(this, {
|
|
1675
|
+
getService: (instance) => instance._service,
|
|
1676
|
+
doDestroy: async () => {
|
|
1677
|
+
const db = main_cjs.BaseDb.getAppDb();
|
|
1678
|
+
const schemaName = context._schemaName;
|
|
1679
|
+
const modelName = context.modelName;
|
|
1680
|
+
const propertyName = context.name;
|
|
1681
|
+
if (!modelName || !propertyName)
|
|
1682
|
+
return;
|
|
1683
|
+
if (db && schemaName) {
|
|
1684
|
+
const propertyRecords = await db
|
|
1685
|
+
.select({ propertyId: main_cjs.properties.id })
|
|
1686
|
+
.from(main_cjs.properties)
|
|
1687
|
+
.innerJoin(main_cjs.models, drizzleOrm.eq(main_cjs.properties.modelId, main_cjs.models.id))
|
|
1688
|
+
.innerJoin(main_cjs.modelSchemas, drizzleOrm.eq(main_cjs.models.id, main_cjs.modelSchemas.modelId))
|
|
1689
|
+
.innerJoin(main_cjs.schemas, drizzleOrm.eq(main_cjs.modelSchemas.schemaId, main_cjs.schemas.id))
|
|
1690
|
+
.where(drizzleOrm.and(drizzleOrm.eq(main_cjs.schemas.name, schemaName), drizzleOrm.eq(main_cjs.models.name, modelName), drizzleOrm.eq(main_cjs.properties.name, propertyName)))
|
|
1691
|
+
.limit(1);
|
|
1692
|
+
if (propertyRecords.length > 0 && propertyRecords[0].propertyId != null) {
|
|
1693
|
+
await db
|
|
1694
|
+
.delete(main_cjs.properties)
|
|
1695
|
+
.where(drizzleOrm.eq(main_cjs.properties.id, propertyRecords[0].propertyId));
|
|
1696
|
+
}
|
|
1697
|
+
}
|
|
1698
|
+
if (schemaName) {
|
|
1699
|
+
const schema = Schema.Schema.create(schemaName, { waitForReady: false });
|
|
1700
|
+
const snapshot = schema.getService().getSnapshot();
|
|
1701
|
+
const schemaContext = snapshot.context;
|
|
1702
|
+
if (schemaContext.models?.[modelName]?.properties?.[propertyName]) {
|
|
1703
|
+
const updatedModels = { ...schemaContext.models };
|
|
1704
|
+
const updatedProperties = { ...updatedModels[modelName].properties };
|
|
1705
|
+
delete updatedProperties[propertyName];
|
|
1706
|
+
updatedModels[modelName] = { ...updatedModels[modelName], properties: updatedProperties };
|
|
1707
|
+
schema.getService().send({ type: 'updateContext', models: updatedModels });
|
|
1708
|
+
schema.getService().send({ type: 'markAsDraft', propertyKey: `property:${modelName}:${propertyName}` });
|
|
1709
|
+
}
|
|
1710
|
+
}
|
|
1711
|
+
},
|
|
1712
|
+
});
|
|
1713
|
+
}
|
|
1714
|
+
}
|
|
1715
|
+
ModelProperty.instanceCache = new Map();
|
|
1716
|
+
// Pending writes tracking
|
|
1717
|
+
ModelProperty.pendingWrites = new Map();
|
|
1718
|
+
|
|
1719
|
+
var ModelProperty$1 = /*#__PURE__*/Object.freeze({
|
|
1720
|
+
__proto__: null,
|
|
1721
|
+
ModelProperty: ModelProperty
|
|
1722
|
+
});
|
|
1723
|
+
|
|
1724
|
+
exports.ModelProperty = ModelProperty;
|
|
1725
|
+
//# sourceMappingURL=ModelProperty-09hNvSBl.js.map
|