@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.
Files changed (977) hide show
  1. package/dist/ArweaveClient-DFqnm5Kj.js +202 -0
  2. package/dist/ArweaveClient-DFqnm5Kj.js.map +1 -0
  3. package/dist/ArweaveClient-sN5h2FvY.js +202 -0
  4. package/dist/ArweaveClient-sN5h2FvY.js.map +1 -0
  5. package/dist/Db-DIythELU.js +246 -0
  6. package/dist/Db-DIythELU.js.map +1 -0
  7. package/dist/Db-Dz17KxVs.js +1530 -0
  8. package/dist/Db-Dz17KxVs.js.map +1 -0
  9. package/dist/EasClient-BadfcFDk.js +29 -0
  10. package/dist/EasClient-BadfcFDk.js.map +1 -0
  11. package/dist/EasClient-DosbWaZN.js +29 -0
  12. package/dist/EasClient-DosbWaZN.js.map +1 -0
  13. package/dist/FileManager-BHuVNWT3.js +174 -0
  14. package/dist/FileManager-BHuVNWT3.js.map +1 -0
  15. package/dist/FileManager-Wthr5yHO.js +1142 -0
  16. package/dist/FileManager-Wthr5yHO.js.map +1 -0
  17. package/dist/ModelProperty-B9Z2DRxI.js +1731 -0
  18. package/dist/ModelProperty-B9Z2DRxI.js.map +1 -0
  19. package/dist/PathResolver-Cd1PZDLG.js +204 -0
  20. package/dist/PathResolver-Cd1PZDLG.js.map +1 -0
  21. package/dist/PathResolver-NEpTSgQK.js +78 -0
  22. package/dist/PathResolver-NEpTSgQK.js.map +1 -0
  23. package/dist/QueryClient-C9U8oZUe.js +34 -0
  24. package/dist/QueryClient-C9U8oZUe.js.map +1 -0
  25. package/dist/QueryClient-ndmA8MYL.js +47 -0
  26. package/dist/QueryClient-ndmA8MYL.js.map +1 -0
  27. package/dist/Schema-D1-HjT8z.js +6521 -0
  28. package/dist/Schema-D1-HjT8z.js.map +1 -0
  29. package/dist/SchemaValidationService-CIXKzSpb.js +654 -0
  30. package/dist/SchemaValidationService-CIXKzSpb.js.map +1 -0
  31. package/dist/cjs/ModelProperty-09hNvSBl.js +1725 -0
  32. package/dist/cjs/ModelProperty-09hNvSBl.js.map +1 -0
  33. package/dist/cjs/Schema-BcwvUABB.js +5967 -0
  34. package/dist/cjs/Schema-BcwvUABB.js.map +1 -0
  35. package/dist/cjs/SchemaValidationService-zty4nfCu.js +670 -0
  36. package/dist/cjs/SchemaValidationService-zty4nfCu.js.map +1 -0
  37. package/dist/cjs/getItem-Dlb5YSQn.js +55 -0
  38. package/dist/cjs/getItem-Dlb5YSQn.js.map +1 -0
  39. package/dist/cjs/getPublishPayload-BqL06sEI.js +520 -0
  40. package/dist/cjs/getPublishPayload-BqL06sEI.js.map +1 -0
  41. package/dist/cjs/getPublishUploads-oukGI2N6.js +282 -0
  42. package/dist/cjs/getPublishUploads-oukGI2N6.js.map +1 -0
  43. package/dist/cjs/getSegmentedItemProperties-JT984OOp.js +71 -0
  44. package/dist/cjs/getSegmentedItemProperties-JT984OOp.js.map +1 -0
  45. package/dist/cjs/index-BLETlVgA.js +17614 -0
  46. package/dist/cjs/index-BLETlVgA.js.map +1 -0
  47. package/dist/cjs/index-jubgGeM2.js +58 -0
  48. package/dist/cjs/index-jubgGeM2.js.map +1 -0
  49. package/dist/cjs/ownership-vfvyz3KJ.js +103 -0
  50. package/dist/cjs/ownership-vfvyz3KJ.js.map +1 -0
  51. package/dist/db/drizzle/drizzle/0004_add_publisher_to_seeds.sql +1 -0
  52. package/dist/db/drizzle/drizzle/meta/0004_snapshot.json +857 -0
  53. package/dist/db/drizzle/drizzle/meta/_journal.json +7 -0
  54. package/dist/getItem-f9rNUz7I.js +38 -0
  55. package/dist/getItem-f9rNUz7I.js.map +1 -0
  56. package/dist/getPublishPayload-BBI_j9I2.js +503 -0
  57. package/dist/getPublishPayload-BBI_j9I2.js.map +1 -0
  58. package/dist/getPublishUploads-BFM94w5S.js +246 -0
  59. package/dist/getPublishUploads-BFM94w5S.js.map +1 -0
  60. package/dist/getSegmentedItemProperties-Di9vevKz.js +69 -0
  61. package/dist/getSegmentedItemProperties-Di9vevKz.js.map +1 -0
  62. package/dist/index-CSAVWKeA.js +18 -0
  63. package/dist/index-CSAVWKeA.js.map +1 -0
  64. package/dist/index-ajj6SHkh.js +23 -0
  65. package/dist/index-ajj6SHkh.js.map +1 -0
  66. package/dist/index-j8WN8W6V.js +16296 -0
  67. package/dist/index-j8WN8W6V.js.map +1 -0
  68. package/dist/main.cjs +1 -1
  69. package/dist/main.js +162 -540
  70. package/dist/main.js.map +1 -1
  71. package/dist/node.js +33 -15
  72. package/dist/node.js.map +1 -1
  73. package/dist/ownership-DLNI17NE.js +85 -0
  74. package/dist/ownership-DLNI17NE.js.map +1 -0
  75. package/dist/property-C6qoOzLG.js +264 -0
  76. package/dist/property-C6qoOzLG.js.map +1 -0
  77. package/dist/queries-jMaUn86w.js +16 -0
  78. package/dist/queries-jMaUn86w.js.map +1 -0
  79. package/dist/seedSchema/ModelSchemaSchema.ts +4 -4
  80. package/dist/seedSchema/ModelUidSchema.ts +1 -1
  81. package/dist/seedSchema/PropertyUidSchema.ts +1 -1
  82. package/dist/seedSchema/SEEDPROTOCOL_Seed_Protocol_v1.json +38 -1
  83. package/dist/seedSchema/SeedSchema.ts +1 -0
  84. package/dist/seedSchema/index.ts +10 -10
  85. package/dist/src/Item/Item.d.ts +141 -0
  86. package/dist/src/Item/Item.d.ts.map +1 -0
  87. package/dist/src/Item/queries.d.ts.map +1 -0
  88. package/dist/src/Item/service/actors/fetchDataFromEas.d.ts.map +1 -0
  89. package/dist/src/Item/service/actors/hydrateExistingItem.d.ts.map +1 -0
  90. package/dist/src/Item/service/actors/hydrateNewItem.d.ts.map +1 -0
  91. package/dist/src/Item/service/actors/initialize.d.ts.map +1 -0
  92. package/dist/src/Item/service/actors/loadOrCreateItem.d.ts.map +1 -0
  93. package/dist/src/Item/service/actors/reload.d.ts.map +1 -0
  94. package/dist/src/Item/service/actors/runPublish.d.ts.map +1 -0
  95. package/dist/src/Item/service/actors/saveDataToDb.d.ts.map +1 -0
  96. package/dist/src/Item/service/actors/waitForDb.d.ts.map +1 -0
  97. package/dist/src/Item/service/itemMachineSingle.d.ts.map +1 -0
  98. package/dist/src/ItemProperty/ItemProperty.d.ts +126 -0
  99. package/dist/src/ItemProperty/ItemProperty.d.ts.map +1 -0
  100. package/dist/src/ItemProperty/service/actors/hydrateFromDb.d.ts.map +1 -0
  101. package/dist/src/ItemProperty/service/actors/initialize.d.ts.map +1 -0
  102. package/dist/src/ItemProperty/service/actors/loadOrCreateProperty.d.ts.map +1 -0
  103. package/dist/src/ItemProperty/service/actors/resolveRelatedValue.d.ts.map +1 -0
  104. package/dist/src/ItemProperty/service/actors/resolveRemoteStorage.d.ts.map +1 -0
  105. package/dist/src/ItemProperty/service/actors/saveValueToDb/analyzeInput.d.ts.map +1 -0
  106. package/dist/src/ItemProperty/service/actors/saveValueToDb/index.d.ts +7 -0
  107. package/dist/src/ItemProperty/service/actors/saveValueToDb/index.d.ts.map +1 -0
  108. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveFile.d.ts +5 -0
  109. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveFile.d.ts.map +1 -0
  110. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveHtml.d.ts +5 -0
  111. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveHtml.d.ts.map +1 -0
  112. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveImage.d.ts.map +1 -0
  113. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveItemStorage.d.ts.map +1 -0
  114. package/dist/src/ItemProperty/service/actors/saveValueToDb/saveRelation.d.ts.map +1 -0
  115. package/dist/src/ItemProperty/service/actors/waitForDb.d.ts.map +1 -0
  116. package/dist/src/ItemProperty/service/propertyMachine.d.ts +78 -0
  117. package/dist/src/ItemProperty/service/propertyMachine.d.ts.map +1 -0
  118. package/dist/src/Model/Model.d.ts +230 -0
  119. package/dist/src/Model/Model.d.ts.map +1 -0
  120. package/dist/src/Model/index.d.ts.map +1 -0
  121. package/dist/src/Model/service/actors/createModelProperties.d.ts.map +1 -0
  122. package/dist/src/Model/service/actors/loadOrCreateModel.d.ts.map +1 -0
  123. package/dist/src/Model/service/actors/validateModel.d.ts.map +1 -0
  124. package/dist/src/Model/service/modelMachine.d.ts +222 -0
  125. package/dist/src/Model/service/modelMachine.d.ts.map +1 -0
  126. package/dist/src/ModelProperty/ModelProperty.d.ts +148 -0
  127. package/dist/src/ModelProperty/ModelProperty.d.ts.map +1 -0
  128. package/dist/src/ModelProperty/service/actors/compareAndMarkDraft.d.ts.map +1 -0
  129. package/dist/src/ModelProperty/service/actors/saveToSchema.d.ts.map +1 -0
  130. package/dist/src/ModelProperty/service/actors/validateProperty.d.ts.map +1 -0
  131. package/dist/src/ModelProperty/service/modelPropertyMachine.d.ts.map +1 -0
  132. package/dist/src/Schema/Schema.d.ts.map +1 -0
  133. package/dist/src/Schema/errors.d.ts.map +1 -0
  134. package/dist/src/Schema/index.d.ts.map +1 -0
  135. package/dist/src/Schema/service/actors/checkExistingSchema.d.ts.map +1 -0
  136. package/dist/src/Schema/service/actors/createModelInstances.d.ts.map +1 -0
  137. package/dist/src/Schema/service/actors/createPropertyInstances.d.ts.map +1 -0
  138. package/dist/src/Schema/service/actors/loadOrCreateSchema.d.ts.map +1 -0
  139. package/dist/src/Schema/service/actors/validateSchema.d.ts.map +1 -0
  140. package/dist/src/Schema/service/actors/verifyModelInstancesInCache.d.ts.map +1 -0
  141. package/dist/src/Schema/service/actors/verifyModelsInDb.d.ts.map +1 -0
  142. package/dist/src/Schema/service/actors/verifyPropertiesInDb.d.ts.map +1 -0
  143. package/dist/src/Schema/service/actors/verifyPropertyInstancesInCache.d.ts.map +1 -0
  144. package/dist/src/Schema/service/actors/verifySchemaInDb.d.ts.map +1 -0
  145. package/dist/src/Schema/service/actors/writeModelsToDb.d.ts.map +1 -0
  146. package/dist/src/Schema/service/actors/writePropertiesToDb.d.ts.map +1 -0
  147. package/dist/src/Schema/service/actors/writeSchemaToDb.d.ts.map +1 -0
  148. package/dist/src/Schema/service/addModelsMachine.d.ts +123 -0
  149. package/dist/src/Schema/service/addModelsMachine.d.ts.map +1 -0
  150. package/dist/src/Schema/service/schemaMachine.d.ts +526 -0
  151. package/dist/src/Schema/service/schemaMachine.d.ts.map +1 -0
  152. package/dist/src/Schema/service/validation/SchemaValidationService.d.ts.map +1 -0
  153. package/dist/src/Schema/validation.d.ts.map +1 -0
  154. package/dist/src/browser/db/Db.d.ts.map +1 -0
  155. package/dist/src/browser/db/drizzleFiles.d.ts +8 -0
  156. package/dist/src/browser/db/drizzleFiles.d.ts.map +1 -0
  157. package/dist/src/browser/db/sqlWasmClient.d.ts.map +1 -0
  158. package/dist/src/browser/helpers/ArweaveClient.d.ts.map +1 -0
  159. package/dist/src/browser/helpers/EasClient.d.ts.map +1 -0
  160. package/dist/src/browser/helpers/FileManager.d.ts +42 -0
  161. package/dist/src/browser/helpers/FileManager.d.ts.map +1 -0
  162. package/dist/src/browser/helpers/PathResolver.d.ts.map +1 -0
  163. package/dist/src/browser/helpers/QueryClient.d.ts.map +1 -0
  164. package/dist/src/browser/helpers/index.d.ts.map +1 -0
  165. package/dist/src/browser/index.d.ts.map +1 -0
  166. package/dist/src/browser/react/OPFSImage.d.ts.map +1 -0
  167. package/dist/src/browser/react/SeedImage.d.ts.map +1 -0
  168. package/dist/src/browser/react/SeedProvider.d.ts.map +1 -0
  169. package/dist/src/browser/react/client.d.ts.map +1 -0
  170. package/dist/src/browser/react/db.d.ts.map +1 -0
  171. package/dist/src/browser/react/index.d.ts +14 -0
  172. package/dist/src/browser/react/index.d.ts.map +1 -0
  173. package/dist/src/browser/react/item.d.ts +44 -0
  174. package/dist/src/browser/react/item.d.ts.map +1 -0
  175. package/dist/src/browser/react/itemProperty.d.ts.map +1 -0
  176. package/dist/src/browser/react/liveQuery.d.ts.map +1 -0
  177. package/dist/src/browser/react/model.d.ts.map +1 -0
  178. package/dist/src/browser/react/modelProperty.d.ts.map +1 -0
  179. package/dist/src/browser/react/queryClient.d.ts.map +1 -0
  180. package/dist/src/browser/react/schema.d.ts.map +1 -0
  181. package/dist/src/browser/react/services.d.ts.map +1 -0
  182. package/dist/src/browser/react/trash.d.ts.map +1 -0
  183. package/dist/src/browser/react/useImageFiles.d.ts +19 -0
  184. package/dist/src/browser/react/useImageFiles.d.ts.map +1 -0
  185. package/dist/src/browser/seed.d.ts.map +1 -0
  186. package/dist/src/browser/workers/FileDownloader.d.ts.map +1 -0
  187. package/dist/src/browser/workers/ImageResizer.d.ts.map +1 -0
  188. package/dist/src/browser/workers/content-hash.d.ts.map +1 -0
  189. package/dist/src/browser/workers/dbWorker.d.ts.map +1 -0
  190. package/dist/src/browser/workers/filesDownload.d.ts.map +1 -0
  191. package/dist/src/browser/workers/imageResize.d.ts.map +1 -0
  192. package/dist/src/client/BaseClientManager.d.ts.map +1 -0
  193. package/dist/src/client/ClientManager.d.ts +220 -0
  194. package/dist/src/client/ClientManager.d.ts.map +1 -0
  195. package/dist/src/client/actions/setAddresses.d.ts.map +1 -0
  196. package/dist/src/client/actors/addModelsToDb.d.ts.map +1 -0
  197. package/dist/src/client/actors/addModelsToStore.d.ts.map +1 -0
  198. package/dist/src/client/actors/dbInit.d.ts.map +1 -0
  199. package/dist/src/client/actors/fileSystemInit.d.ts.map +1 -0
  200. package/dist/src/client/actors/platformClassesInit.d.ts.map +1 -0
  201. package/dist/src/client/actors/processSchemaFiles.d.ts.map +1 -0
  202. package/dist/src/client/actors/saveAppState.d.ts.map +1 -0
  203. package/dist/src/client/actors/saveConfig.d.ts.map +1 -0
  204. package/dist/src/client/clientManagerMachine.d.ts.map +1 -0
  205. package/dist/src/client/constants.d.ts.map +1 -0
  206. package/dist/src/client/index.d.ts.map +1 -0
  207. package/dist/src/db/Db/BaseDb.d.ts.map +1 -0
  208. package/dist/src/db/configs/dev.schema.config.d.ts.map +1 -0
  209. package/dist/src/db/read/getExistingItem.d.ts.map +1 -0
  210. package/dist/src/db/read/getItem.d.ts.map +1 -0
  211. package/dist/src/db/read/getItemData.d.ts.map +1 -0
  212. package/dist/src/db/read/getItemProperties.d.ts.map +1 -0
  213. package/dist/src/db/read/getItemProperty.d.ts.map +1 -0
  214. package/dist/src/db/read/getItems.d.ts +11 -0
  215. package/dist/src/db/read/getItems.d.ts.map +1 -0
  216. package/dist/src/db/read/getMetadata.d.ts.map +1 -0
  217. package/dist/src/db/read/getModelPropertiesData.d.ts.map +1 -0
  218. package/dist/src/db/read/getModelSchemas.d.ts.map +1 -0
  219. package/dist/src/db/read/getModels.d.ts.map +1 -0
  220. package/dist/src/db/read/getModelsData.d.ts.map +1 -0
  221. package/dist/src/db/read/getPropertyData.d.ts.map +1 -0
  222. package/dist/src/db/read/getPublishPayload.d.ts +36 -0
  223. package/dist/src/db/read/getPublishPayload.d.ts.map +1 -0
  224. package/dist/src/db/read/getPublishUploads.d.ts +10 -0
  225. package/dist/src/db/read/getPublishUploads.d.ts.map +1 -0
  226. package/dist/src/db/read/getRelatedItemsForPublish.d.ts +8 -0
  227. package/dist/src/db/read/getRelatedItemsForPublish.d.ts.map +1 -0
  228. package/dist/src/db/read/getRelationValueData.d.ts.map +1 -0
  229. package/dist/src/db/read/getSchemaUidForModel.d.ts +2 -0
  230. package/dist/src/db/read/getSchemaUidForModel.d.ts.map +1 -0
  231. package/dist/src/db/read/getSeedData.d.ts.map +1 -0
  232. package/dist/src/db/read/getStorageTransactionIdForSeedUid.d.ts.map +1 -0
  233. package/dist/src/db/read/getVersionData.d.ts.map +1 -0
  234. package/dist/src/db/read/getVersionsForVersionUids.d.ts.map +1 -0
  235. package/dist/src/db/read/subqueries/metadataLatest.d.ts.map +1 -0
  236. package/dist/src/db/read/subqueries/versionData.d.ts.map +1 -0
  237. package/dist/src/db/write/createMetadata.d.ts.map +1 -0
  238. package/dist/src/db/write/createNewItem.d.ts.map +1 -0
  239. package/dist/src/db/write/createSeed.d.ts.map +1 -0
  240. package/dist/src/db/write/createSeeds.d.ts.map +1 -0
  241. package/dist/src/db/write/createVersion.d.ts.map +1 -0
  242. package/dist/src/db/write/deleteItem.d.ts.map +1 -0
  243. package/dist/src/db/write/recoverDeletedItem.d.ts.map +1 -0
  244. package/dist/src/db/write/saveAppState.d.ts.map +1 -0
  245. package/dist/src/db/write/saveMetadata.d.ts.map +1 -0
  246. package/dist/src/db/write/updateItemPropertyValue.d.ts.map +1 -0
  247. package/dist/src/db/write/updateMetadata.d.ts.map +1 -0
  248. package/dist/src/db/write/updateSeedUid.d.ts.map +1 -0
  249. package/dist/src/eas.d.ts +26 -0
  250. package/dist/src/eas.d.ts.map +1 -0
  251. package/dist/src/eslint-rules/align-imports.d.ts.map +1 -0
  252. package/dist/src/eventBus.d.ts.map +1 -0
  253. package/dist/src/events/files/download.d.ts.map +1 -0
  254. package/dist/src/events/files/index.d.ts.map +1 -0
  255. package/dist/src/events/index.d.ts.map +1 -0
  256. package/dist/src/events/item/index.d.ts.map +1 -0
  257. package/dist/src/events/item/syncDbWithEas.d.ts.map +1 -0
  258. package/dist/src/events/services/allItems.d.ts.map +1 -0
  259. package/dist/src/events/services/index.d.ts.map +1 -0
  260. package/dist/src/graphql/fragments/Attestation.d.ts.map +1 -0
  261. package/dist/src/graphql/fragments/Schema.d.ts.map +1 -0
  262. package/dist/src/graphql/fragments/index.d.ts.map +1 -0
  263. package/dist/src/graphql/gql/fragment-masking.d.ts.map +1 -0
  264. package/dist/src/graphql/gql/gql.d.ts.map +1 -0
  265. package/dist/src/graphql/gql/graphql.d.ts.map +1 -0
  266. package/dist/src/graphql/gql/index.d.ts.map +1 -0
  267. package/dist/src/helpers/ArweaveClient/BaseArweaveClient.d.ts.map +1 -0
  268. package/dist/src/helpers/ArweaveClient/index.d.ts.map +1 -0
  269. package/dist/src/helpers/ArweaveClient/queries.d.ts.map +1 -0
  270. package/dist/src/helpers/EasClient/BaseEasClient.d.ts.map +1 -0
  271. package/dist/src/helpers/FileManager/BaseFileManager.d.ts +41 -0
  272. package/dist/src/helpers/FileManager/BaseFileManager.d.ts.map +1 -0
  273. package/dist/src/helpers/PathResolver/BasePathResolver.d.ts.map +1 -0
  274. package/dist/src/helpers/QueryClient/BaseQueryClient.d.ts.map +1 -0
  275. package/dist/src/helpers/addresses.d.ts +12 -0
  276. package/dist/src/helpers/addresses.d.ts.map +1 -0
  277. package/dist/src/helpers/constants.d.ts +71 -0
  278. package/dist/src/helpers/constants.d.ts.map +1 -0
  279. package/dist/src/helpers/crypto.d.ts.map +1 -0
  280. package/dist/src/helpers/db.d.ts +143 -0
  281. package/dist/src/helpers/db.d.ts.map +1 -0
  282. package/dist/src/helpers/entity/entityCache.d.ts.map +1 -0
  283. package/dist/src/helpers/entity/entityCommon.d.ts.map +1 -0
  284. package/dist/src/helpers/entity/entityDestroy.d.ts.map +1 -0
  285. package/dist/src/helpers/entity/entityFind.d.ts.map +1 -0
  286. package/dist/src/helpers/entity/entityLiveQuery.d.ts.map +1 -0
  287. package/dist/src/helpers/entity/entityUnload.d.ts +54 -0
  288. package/dist/src/helpers/entity/entityUnload.d.ts.map +1 -0
  289. package/dist/src/helpers/entity/index.d.ts.map +1 -0
  290. package/dist/src/helpers/environment.d.ts.map +1 -0
  291. package/dist/src/helpers/file/download/actors.d.ts.map +1 -0
  292. package/dist/src/helpers/file/download/index.d.ts.map +1 -0
  293. package/dist/src/helpers/file/fetchAll/actors.d.ts.map +1 -0
  294. package/dist/src/helpers/file/fetchAll/index.d.ts.map +1 -0
  295. package/dist/src/helpers/file/queries.d.ts.map +1 -0
  296. package/dist/src/helpers/files.d.ts.map +1 -0
  297. package/dist/src/helpers/getSchemaForItemProperty.d.ts +15 -0
  298. package/dist/src/helpers/getSchemaForItemProperty.d.ts.map +1 -0
  299. package/dist/src/helpers/getSegmentedItemProperties.d.ts.map +1 -0
  300. package/dist/src/helpers/image/queries.d.ts.map +1 -0
  301. package/dist/src/helpers/index.d.ts +30 -0
  302. package/dist/src/helpers/index.d.ts.map +1 -0
  303. package/dist/src/helpers/model.d.ts.map +1 -0
  304. package/dist/src/helpers/ownership.d.ts +16 -0
  305. package/dist/src/helpers/ownership.d.ts.map +1 -0
  306. package/dist/src/helpers/property/index.d.ts +304 -0
  307. package/dist/src/helpers/property/index.d.ts.map +1 -0
  308. package/dist/src/helpers/property.d.ts.map +1 -0
  309. package/dist/src/helpers/publishConfig.d.ts +18 -0
  310. package/dist/src/helpers/publishConfig.d.ts.map +1 -0
  311. package/dist/src/helpers/reactiveProxy.d.ts.map +1 -0
  312. package/dist/src/helpers/schema.d.ts.map +1 -0
  313. package/dist/src/helpers/updateMachineContext.d.ts.map +1 -0
  314. package/dist/src/helpers/updateSchema.d.ts +128 -0
  315. package/dist/src/helpers/updateSchema.d.ts.map +1 -0
  316. package/dist/src/helpers/waitForEntityIdle.d.ts.map +1 -0
  317. package/dist/src/imports/index.d.ts.map +1 -0
  318. package/dist/src/imports/json.d.ts.map +1 -0
  319. package/dist/src/imports/markdown.d.ts +40 -0
  320. package/dist/src/imports/markdown.d.ts.map +1 -0
  321. package/dist/src/index.d.ts +31 -0
  322. package/dist/src/index.d.ts.map +1 -0
  323. package/dist/src/interfaces/IDb.d.ts.map +1 -0
  324. package/dist/src/interfaces/IEasClient.d.ts.map +1 -0
  325. package/dist/src/interfaces/IItem.d.ts.map +1 -0
  326. package/dist/src/interfaces/IItemProperty.d.ts.map +1 -0
  327. package/dist/src/interfaces/IQueryClient.d.ts.map +1 -0
  328. package/dist/src/interfaces/index.d.ts.map +1 -0
  329. package/dist/src/node/codegen/drizzle.d.ts.map +1 -0
  330. package/dist/src/node/codegen/index.d.ts.map +1 -0
  331. package/dist/src/node/codegen/ts-to-proto.d.ts.map +1 -0
  332. package/dist/src/node/constants.d.ts.map +1 -0
  333. package/dist/src/node/db/Db.d.ts.map +1 -0
  334. package/dist/src/node/db/index.d.ts.map +1 -0
  335. package/dist/src/node/db/node.app.db.config.d.ts.map +1 -0
  336. package/dist/src/node/helpers/ArweaveClient.d.ts.map +1 -0
  337. package/dist/src/node/helpers/EasClient.d.ts.map +1 -0
  338. package/dist/src/node/helpers/FileManager.d.ts +27 -0
  339. package/dist/src/node/helpers/FileManager.d.ts.map +1 -0
  340. package/dist/src/node/helpers/PathResolver.d.ts.map +1 -0
  341. package/dist/src/node/helpers/QueryClient.d.ts.map +1 -0
  342. package/dist/src/node/helpers/index.d.ts.map +1 -0
  343. package/dist/src/node/helpers/scripts.d.ts.map +1 -0
  344. package/dist/src/node/index.d.ts.map +1 -0
  345. package/dist/src/node/seed.d.ts.map +1 -0
  346. package/dist/src/node/webpack/fs-proxy.d.ts.map +1 -0
  347. package/dist/src/node/webpack/index.d.ts.map +1 -0
  348. package/dist/src/seedSchema/AppStateSchema.d.ts.map +1 -0
  349. package/dist/src/seedSchema/ConfigSchema.d.ts.map +1 -0
  350. package/dist/src/seedSchema/MetadataSchema.d.ts.map +1 -0
  351. package/dist/src/seedSchema/ModelSchema.d.ts.map +1 -0
  352. package/dist/src/seedSchema/ModelSchemaSchema.d.ts +61 -0
  353. package/dist/src/seedSchema/ModelSchemaSchema.d.ts.map +1 -0
  354. package/dist/src/seedSchema/ModelUidSchema.d.ts.map +1 -0
  355. package/dist/src/seedSchema/PropertyUidSchema.d.ts.map +1 -0
  356. package/dist/src/seedSchema/SchemaSchema.d.ts.map +1 -0
  357. package/dist/src/seedSchema/SeedSchema.d.ts +192 -0
  358. package/dist/src/seedSchema/SeedSchema.d.ts.map +1 -0
  359. package/dist/src/seedSchema/VersionSchema.d.ts.map +1 -0
  360. package/dist/src/seedSchema/index.d.ts +11 -0
  361. package/dist/src/seedSchema/index.d.ts.map +1 -0
  362. package/dist/src/services/events.d.ts.map +1 -0
  363. package/dist/src/services/publish/actors/createPublishAttempt.d.ts.map +1 -0
  364. package/dist/src/services/publish/actors/preparePublishRequestData.d.ts.map +1 -0
  365. package/dist/src/services/publish/actors/upload.d.ts.map +1 -0
  366. package/dist/src/services/publish/actors/validateItemData.d.ts.map +1 -0
  367. package/dist/src/services/publish/publishMachine.d.ts.map +1 -0
  368. package/dist/src/services/write/actors/validateEntity.d.ts.map +1 -0
  369. package/dist/src/services/write/actors/writeToDatabase.d.ts.map +1 -0
  370. package/dist/src/services/write/writeProcessMachine.d.ts.map +1 -0
  371. package/dist/src/stores/eas.d.ts +20 -0
  372. package/dist/src/stores/eas.d.ts.map +1 -0
  373. package/dist/src/types/arweave.d.ts.map +1 -0
  374. package/dist/src/types/browser.d.ts.map +1 -0
  375. package/dist/src/types/db.d.ts.map +1 -0
  376. package/dist/src/types/fileManager.d.ts.map +1 -0
  377. package/dist/src/types/helpers.d.ts.map +1 -0
  378. package/dist/src/types/import.d.ts.map +1 -0
  379. package/dist/src/types/index.d.ts +66 -0
  380. package/dist/src/types/index.d.ts.map +1 -0
  381. package/dist/src/types/item.d.ts +85 -0
  382. package/dist/src/types/item.d.ts.map +1 -0
  383. package/dist/src/types/machines.d.ts +53 -0
  384. package/dist/src/types/machines.d.ts.map +1 -0
  385. package/dist/src/types/model.d.ts.map +1 -0
  386. package/dist/src/types/property.d.ts.map +1 -0
  387. package/dist/src/types/publish.d.ts.map +1 -0
  388. package/dist/src/types/seedProtocol.d.ts.map +1 -0
  389. package/dist/src/types/services.d.ts.map +1 -0
  390. package/dist/src/vite/easFix.d.ts.map +1 -0
  391. package/dist/src/vite/index.d.ts.map +1 -0
  392. package/dist/vite.cjs +0 -5
  393. package/dist/vite.cjs.map +1 -1
  394. package/dist/vite.js +0 -5
  395. package/dist/vite.js.map +1 -1
  396. package/package.json +21 -113
  397. package/README.md +0 -67
  398. package/dist/ArweaveClient-Caio37h1.js +0 -202
  399. package/dist/ArweaveClient-Caio37h1.js.map +0 -1
  400. package/dist/ArweaveClient-DLKAaS3K.js +0 -202
  401. package/dist/ArweaveClient-DLKAaS3K.js.map +0 -1
  402. package/dist/Db-C9fppVRl.js +0 -1514
  403. package/dist/Db-C9fppVRl.js.map +0 -1
  404. package/dist/Db-DJAG-5Di.js +0 -345
  405. package/dist/Db-DJAG-5Di.js.map +0 -1
  406. package/dist/EasClient-DQGAIj-b.js +0 -29
  407. package/dist/EasClient-DQGAIj-b.js.map +0 -1
  408. package/dist/EasClient-T7Nx9185.js +0 -29
  409. package/dist/EasClient-T7Nx9185.js.map +0 -1
  410. package/dist/FileManager-BohtoKYo.js +0 -1153
  411. package/dist/FileManager-BohtoKYo.js.map +0 -1
  412. package/dist/FileManager-d64CkqXy.js +0 -165
  413. package/dist/FileManager-d64CkqXy.js.map +0 -1
  414. package/dist/Item/Item.d.ts +0 -134
  415. package/dist/Item/Item.d.ts.map +0 -1
  416. package/dist/Item/queries.d.ts.map +0 -1
  417. package/dist/Item/service/actors/fetchDataFromEas.d.ts.map +0 -1
  418. package/dist/Item/service/actors/hydrateExistingItem.d.ts.map +0 -1
  419. package/dist/Item/service/actors/hydrateNewItem.d.ts.map +0 -1
  420. package/dist/Item/service/actors/initialize.d.ts.map +0 -1
  421. package/dist/Item/service/actors/loadOrCreateItem.d.ts.map +0 -1
  422. package/dist/Item/service/actors/reload.d.ts.map +0 -1
  423. package/dist/Item/service/actors/runPublish.d.ts.map +0 -1
  424. package/dist/Item/service/actors/saveDataToDb.d.ts.map +0 -1
  425. package/dist/Item/service/actors/waitForDb.d.ts.map +0 -1
  426. package/dist/Item/service/itemMachineSingle.d.ts.map +0 -1
  427. package/dist/ItemProperty/ItemProperty.d.ts +0 -118
  428. package/dist/ItemProperty/ItemProperty.d.ts.map +0 -1
  429. package/dist/ItemProperty/service/actors/hydrateFromDb.d.ts.map +0 -1
  430. package/dist/ItemProperty/service/actors/initialize.d.ts.map +0 -1
  431. package/dist/ItemProperty/service/actors/loadOrCreateProperty.d.ts.map +0 -1
  432. package/dist/ItemProperty/service/actors/resolveRelatedValue.d.ts.map +0 -1
  433. package/dist/ItemProperty/service/actors/resolveRemoteStorage.d.ts.map +0 -1
  434. package/dist/ItemProperty/service/actors/saveValueToDb/analyzeInput.d.ts.map +0 -1
  435. package/dist/ItemProperty/service/actors/saveValueToDb/index.d.ts +0 -5
  436. package/dist/ItemProperty/service/actors/saveValueToDb/index.d.ts.map +0 -1
  437. package/dist/ItemProperty/service/actors/saveValueToDb/saveImage.d.ts.map +0 -1
  438. package/dist/ItemProperty/service/actors/saveValueToDb/saveItemStorage.d.ts.map +0 -1
  439. package/dist/ItemProperty/service/actors/saveValueToDb/saveRelation.d.ts.map +0 -1
  440. package/dist/ItemProperty/service/actors/waitForDb.d.ts.map +0 -1
  441. package/dist/ItemProperty/service/propertyMachine.d.ts +0 -68
  442. package/dist/ItemProperty/service/propertyMachine.d.ts.map +0 -1
  443. package/dist/Model/Model.d.ts +0 -225
  444. package/dist/Model/Model.d.ts.map +0 -1
  445. package/dist/Model/index.d.ts.map +0 -1
  446. package/dist/Model/service/actors/createModelProperties.d.ts.map +0 -1
  447. package/dist/Model/service/actors/loadOrCreateModel.d.ts.map +0 -1
  448. package/dist/Model/service/actors/validateModel.d.ts.map +0 -1
  449. package/dist/Model/service/modelMachine.d.ts +0 -222
  450. package/dist/Model/service/modelMachine.d.ts.map +0 -1
  451. package/dist/ModelProperty/ModelProperty.d.ts +0 -146
  452. package/dist/ModelProperty/ModelProperty.d.ts.map +0 -1
  453. package/dist/ModelProperty/service/actors/compareAndMarkDraft.d.ts.map +0 -1
  454. package/dist/ModelProperty/service/actors/saveToSchema.d.ts.map +0 -1
  455. package/dist/ModelProperty/service/actors/validateProperty.d.ts.map +0 -1
  456. package/dist/ModelProperty/service/modelPropertyMachine.d.ts.map +0 -1
  457. package/dist/ModelProperty-Cpd9xiIM.js +0 -1784
  458. package/dist/ModelProperty-Cpd9xiIM.js.map +0 -1
  459. package/dist/PathResolver-CLZUWoX2.js +0 -78
  460. package/dist/PathResolver-CLZUWoX2.js.map +0 -1
  461. package/dist/PathResolver-D6M0rzKV.js +0 -191
  462. package/dist/PathResolver-D6M0rzKV.js.map +0 -1
  463. package/dist/QueryClient-BUoz2Vb0.js +0 -47
  464. package/dist/QueryClient-BUoz2Vb0.js.map +0 -1
  465. package/dist/QueryClient-COQ_Rs4-.js +0 -34
  466. package/dist/QueryClient-COQ_Rs4-.js.map +0 -1
  467. package/dist/Schema/Schema.d.ts.map +0 -1
  468. package/dist/Schema/errors.d.ts.map +0 -1
  469. package/dist/Schema/index.d.ts.map +0 -1
  470. package/dist/Schema/service/actors/checkExistingSchema.d.ts.map +0 -1
  471. package/dist/Schema/service/actors/createModelInstances.d.ts.map +0 -1
  472. package/dist/Schema/service/actors/createPropertyInstances.d.ts.map +0 -1
  473. package/dist/Schema/service/actors/loadOrCreateSchema.d.ts.map +0 -1
  474. package/dist/Schema/service/actors/validateSchema.d.ts.map +0 -1
  475. package/dist/Schema/service/actors/verifyModelInstancesInCache.d.ts.map +0 -1
  476. package/dist/Schema/service/actors/verifyModelsInDb.d.ts.map +0 -1
  477. package/dist/Schema/service/actors/verifyPropertiesInDb.d.ts.map +0 -1
  478. package/dist/Schema/service/actors/verifyPropertyInstancesInCache.d.ts.map +0 -1
  479. package/dist/Schema/service/actors/verifySchemaInDb.d.ts.map +0 -1
  480. package/dist/Schema/service/actors/writeModelsToDb.d.ts.map +0 -1
  481. package/dist/Schema/service/actors/writePropertiesToDb.d.ts.map +0 -1
  482. package/dist/Schema/service/actors/writeSchemaToDb.d.ts.map +0 -1
  483. package/dist/Schema/service/addModelsMachine.d.ts +0 -123
  484. package/dist/Schema/service/addModelsMachine.d.ts.map +0 -1
  485. package/dist/Schema/service/schemaMachine.d.ts +0 -526
  486. package/dist/Schema/service/schemaMachine.d.ts.map +0 -1
  487. package/dist/Schema/service/validation/SchemaValidationService.d.ts.map +0 -1
  488. package/dist/Schema/validation.d.ts.map +0 -1
  489. package/dist/Schema-BZKBy5Tx.js +0 -6593
  490. package/dist/Schema-BZKBy5Tx.js.map +0 -1
  491. package/dist/SchemaValidationService-F8No7BHp.js +0 -563
  492. package/dist/SchemaValidationService-F8No7BHp.js.map +0 -1
  493. package/dist/browser/db/Db.d.ts.map +0 -1
  494. package/dist/browser/db/drizzleFiles.d.ts +0 -7
  495. package/dist/browser/db/drizzleFiles.d.ts.map +0 -1
  496. package/dist/browser/db/sqlWasmClient.d.ts.map +0 -1
  497. package/dist/browser/helpers/ArweaveClient.d.ts.map +0 -1
  498. package/dist/browser/helpers/EasClient.d.ts.map +0 -1
  499. package/dist/browser/helpers/FileManager.d.ts +0 -41
  500. package/dist/browser/helpers/FileManager.d.ts.map +0 -1
  501. package/dist/browser/helpers/PathResolver.d.ts.map +0 -1
  502. package/dist/browser/helpers/QueryClient.d.ts.map +0 -1
  503. package/dist/browser/helpers/index.d.ts.map +0 -1
  504. package/dist/browser/index.d.ts.map +0 -1
  505. package/dist/browser/react/OPFSImage.d.ts.map +0 -1
  506. package/dist/browser/react/SeedImage.d.ts.map +0 -1
  507. package/dist/browser/react/SeedProvider.d.ts.map +0 -1
  508. package/dist/browser/react/client.d.ts.map +0 -1
  509. package/dist/browser/react/db.d.ts.map +0 -1
  510. package/dist/browser/react/index.d.ts +0 -13
  511. package/dist/browser/react/index.d.ts.map +0 -1
  512. package/dist/browser/react/item.d.ts +0 -42
  513. package/dist/browser/react/item.d.ts.map +0 -1
  514. package/dist/browser/react/itemProperty.d.ts.map +0 -1
  515. package/dist/browser/react/liveQuery.d.ts.map +0 -1
  516. package/dist/browser/react/model.d.ts.map +0 -1
  517. package/dist/browser/react/modelProperty.d.ts.map +0 -1
  518. package/dist/browser/react/queryClient.d.ts.map +0 -1
  519. package/dist/browser/react/schema.d.ts.map +0 -1
  520. package/dist/browser/react/services.d.ts.map +0 -1
  521. package/dist/browser/react/trash.d.ts.map +0 -1
  522. package/dist/browser/seed.d.ts.map +0 -1
  523. package/dist/browser/workers/FileDownloader.d.ts.map +0 -1
  524. package/dist/browser/workers/ImageResizer.d.ts.map +0 -1
  525. package/dist/browser/workers/content-hash.d.ts.map +0 -1
  526. package/dist/browser/workers/dbWorker.d.ts.map +0 -1
  527. package/dist/browser/workers/filesDownload.d.ts.map +0 -1
  528. package/dist/browser/workers/imageResize.d.ts.map +0 -1
  529. package/dist/cjs/ModelProperty-B4pV91tc.js +0 -1780
  530. package/dist/cjs/ModelProperty-B4pV91tc.js.map +0 -1
  531. package/dist/cjs/Schema-TErl3J36.js +0 -6217
  532. package/dist/cjs/Schema-TErl3J36.js.map +0 -1
  533. package/dist/cjs/SchemaValidationService-p5BbJV9T.js +0 -579
  534. package/dist/cjs/SchemaValidationService-p5BbJV9T.js.map +0 -1
  535. package/dist/cjs/getItem-BrnLfC12.js +0 -55
  536. package/dist/cjs/getItem-BrnLfC12.js.map +0 -1
  537. package/dist/cjs/getPublishPayload-BcjCN_bD.js +0 -340
  538. package/dist/cjs/getPublishPayload-BcjCN_bD.js.map +0 -1
  539. package/dist/cjs/getPublishUploads-5_oXzwol.js +0 -229
  540. package/dist/cjs/getPublishUploads-5_oXzwol.js.map +0 -1
  541. package/dist/cjs/getSegmentedItemProperties-WFdizUDv.js +0 -61
  542. package/dist/cjs/getSegmentedItemProperties-WFdizUDv.js.map +0 -1
  543. package/dist/cjs/index-BrmvhXsG.js +0 -57
  544. package/dist/cjs/index-BrmvhXsG.js.map +0 -1
  545. package/dist/cjs/index-CXI4VF1H.js +0 -16804
  546. package/dist/cjs/index-CXI4VF1H.js.map +0 -1
  547. package/dist/client/BaseClientManager.d.ts.map +0 -1
  548. package/dist/client/ClientManager.d.ts +0 -209
  549. package/dist/client/ClientManager.d.ts.map +0 -1
  550. package/dist/client/actions/setAddresses.d.ts.map +0 -1
  551. package/dist/client/actors/addModelsToDb.d.ts.map +0 -1
  552. package/dist/client/actors/addModelsToStore.d.ts.map +0 -1
  553. package/dist/client/actors/dbInit.d.ts.map +0 -1
  554. package/dist/client/actors/fileSystemInit.d.ts.map +0 -1
  555. package/dist/client/actors/platformClassesInit.d.ts.map +0 -1
  556. package/dist/client/actors/processSchemaFiles.d.ts.map +0 -1
  557. package/dist/client/actors/saveAppState.d.ts.map +0 -1
  558. package/dist/client/actors/saveConfig.d.ts.map +0 -1
  559. package/dist/client/clientManagerMachine.d.ts.map +0 -1
  560. package/dist/client/constants.d.ts.map +0 -1
  561. package/dist/client/index.d.ts.map +0 -1
  562. package/dist/db/Db/BaseDb.d.ts.map +0 -1
  563. package/dist/db/configs/dev.schema.config.d.ts.map +0 -1
  564. package/dist/db/read/getExistingItem.d.ts.map +0 -1
  565. package/dist/db/read/getItem.d.ts.map +0 -1
  566. package/dist/db/read/getItemData.d.ts.map +0 -1
  567. package/dist/db/read/getItemProperties.d.ts.map +0 -1
  568. package/dist/db/read/getItemProperty.d.ts.map +0 -1
  569. package/dist/db/read/getItems.d.ts +0 -9
  570. package/dist/db/read/getItems.d.ts.map +0 -1
  571. package/dist/db/read/getMetadata.d.ts.map +0 -1
  572. package/dist/db/read/getModelPropertiesData.d.ts.map +0 -1
  573. package/dist/db/read/getModelSchemas.d.ts.map +0 -1
  574. package/dist/db/read/getModels.d.ts.map +0 -1
  575. package/dist/db/read/getModelsData.d.ts.map +0 -1
  576. package/dist/db/read/getPropertyData.d.ts.map +0 -1
  577. package/dist/db/read/getPublishPayload.d.ts +0 -23
  578. package/dist/db/read/getPublishPayload.d.ts.map +0 -1
  579. package/dist/db/read/getPublishUploads.d.ts +0 -10
  580. package/dist/db/read/getPublishUploads.d.ts.map +0 -1
  581. package/dist/db/read/getRelationValueData.d.ts.map +0 -1
  582. package/dist/db/read/getSchemaUidForModel.d.ts +0 -2
  583. package/dist/db/read/getSchemaUidForModel.d.ts.map +0 -1
  584. package/dist/db/read/getSeedData.d.ts.map +0 -1
  585. package/dist/db/read/getStorageTransactionIdForSeedUid.d.ts.map +0 -1
  586. package/dist/db/read/getVersionData.d.ts.map +0 -1
  587. package/dist/db/read/getVersionsForVersionUids.d.ts.map +0 -1
  588. package/dist/db/read/subqueries/metadataLatest.d.ts.map +0 -1
  589. package/dist/db/read/subqueries/versionData.d.ts.map +0 -1
  590. package/dist/db/write/createMetadata.d.ts.map +0 -1
  591. package/dist/db/write/createNewItem.d.ts.map +0 -1
  592. package/dist/db/write/createSeed.d.ts.map +0 -1
  593. package/dist/db/write/createSeeds.d.ts.map +0 -1
  594. package/dist/db/write/createVersion.d.ts.map +0 -1
  595. package/dist/db/write/deleteItem.d.ts.map +0 -1
  596. package/dist/db/write/recoverDeletedItem.d.ts.map +0 -1
  597. package/dist/db/write/saveAppState.d.ts.map +0 -1
  598. package/dist/db/write/saveMetadata.d.ts.map +0 -1
  599. package/dist/db/write/updateItemPropertyValue.d.ts.map +0 -1
  600. package/dist/db/write/updateMetadata.d.ts.map +0 -1
  601. package/dist/db/write/updateSeedUid.d.ts.map +0 -1
  602. package/dist/eas.d.ts +0 -26
  603. package/dist/eas.d.ts.map +0 -1
  604. package/dist/eslint-rules/align-imports.d.ts.map +0 -1
  605. package/dist/eventBus.d.ts.map +0 -1
  606. package/dist/events/files/download.d.ts.map +0 -1
  607. package/dist/events/files/index.d.ts.map +0 -1
  608. package/dist/events/index.d.ts.map +0 -1
  609. package/dist/events/item/index.d.ts.map +0 -1
  610. package/dist/events/item/syncDbWithEas.d.ts.map +0 -1
  611. package/dist/events/services/allItems.d.ts.map +0 -1
  612. package/dist/events/services/index.d.ts.map +0 -1
  613. package/dist/feed.d.ts +0 -2
  614. package/dist/feed.d.ts.map +0 -1
  615. package/dist/getItem-DaQVdeae.js +0 -38
  616. package/dist/getItem-DaQVdeae.js.map +0 -1
  617. package/dist/getPublishPayload-CWiLI1yd.js +0 -324
  618. package/dist/getPublishPayload-CWiLI1yd.js.map +0 -1
  619. package/dist/getPublishUploads-DhvcKD_9.js +0 -193
  620. package/dist/getPublishUploads-DhvcKD_9.js.map +0 -1
  621. package/dist/getSegmentedItemProperties-Cp4kcWIF.js +0 -59
  622. package/dist/getSegmentedItemProperties-Cp4kcWIF.js.map +0 -1
  623. package/dist/graphql/fragments/Attestation.d.ts.map +0 -1
  624. package/dist/graphql/fragments/Schema.d.ts.map +0 -1
  625. package/dist/graphql/fragments/index.d.ts.map +0 -1
  626. package/dist/graphql/gql/fragment-masking.d.ts.map +0 -1
  627. package/dist/graphql/gql/gql.d.ts.map +0 -1
  628. package/dist/graphql/gql/graphql.d.ts.map +0 -1
  629. package/dist/graphql/gql/index.d.ts.map +0 -1
  630. package/dist/helpers/ArweaveClient/BaseArweaveClient.d.ts.map +0 -1
  631. package/dist/helpers/ArweaveClient/index.d.ts.map +0 -1
  632. package/dist/helpers/ArweaveClient/queries.d.ts.map +0 -1
  633. package/dist/helpers/EasClient/BaseEasClient.d.ts.map +0 -1
  634. package/dist/helpers/FileManager/BaseFileManager.d.ts +0 -29
  635. package/dist/helpers/FileManager/BaseFileManager.d.ts.map +0 -1
  636. package/dist/helpers/PathResolver/BasePathResolver.d.ts.map +0 -1
  637. package/dist/helpers/QueryClient/BaseQueryClient.d.ts.map +0 -1
  638. package/dist/helpers/constants.d.ts +0 -67
  639. package/dist/helpers/constants.d.ts.map +0 -1
  640. package/dist/helpers/crypto.d.ts.map +0 -1
  641. package/dist/helpers/db.d.ts +0 -131
  642. package/dist/helpers/db.d.ts.map +0 -1
  643. package/dist/helpers/entity/entityCache.d.ts.map +0 -1
  644. package/dist/helpers/entity/entityCommon.d.ts.map +0 -1
  645. package/dist/helpers/entity/entityDestroy.d.ts.map +0 -1
  646. package/dist/helpers/entity/entityFind.d.ts.map +0 -1
  647. package/dist/helpers/entity/entityLiveQuery.d.ts.map +0 -1
  648. package/dist/helpers/entity/entityUnload.d.ts +0 -50
  649. package/dist/helpers/entity/entityUnload.d.ts.map +0 -1
  650. package/dist/helpers/entity/index.d.ts.map +0 -1
  651. package/dist/helpers/environment.d.ts.map +0 -1
  652. package/dist/helpers/file/download/actors.d.ts.map +0 -1
  653. package/dist/helpers/file/download/index.d.ts.map +0 -1
  654. package/dist/helpers/file/fetchAll/actors.d.ts.map +0 -1
  655. package/dist/helpers/file/fetchAll/index.d.ts.map +0 -1
  656. package/dist/helpers/file/queries.d.ts.map +0 -1
  657. package/dist/helpers/files.d.ts.map +0 -1
  658. package/dist/helpers/getSchemaForItemProperty.d.ts +0 -15
  659. package/dist/helpers/getSchemaForItemProperty.d.ts.map +0 -1
  660. package/dist/helpers/getSegmentedItemProperties.d.ts.map +0 -1
  661. package/dist/helpers/image/queries.d.ts.map +0 -1
  662. package/dist/helpers/index.d.ts +0 -29
  663. package/dist/helpers/index.d.ts.map +0 -1
  664. package/dist/helpers/model.d.ts.map +0 -1
  665. package/dist/helpers/property/index.d.ts +0 -298
  666. package/dist/helpers/property/index.d.ts.map +0 -1
  667. package/dist/helpers/property.d.ts.map +0 -1
  668. package/dist/helpers/reactiveProxy.d.ts.map +0 -1
  669. package/dist/helpers/schema.d.ts.map +0 -1
  670. package/dist/helpers/updateMachineContext.d.ts.map +0 -1
  671. package/dist/helpers/updateSchema.d.ts +0 -118
  672. package/dist/helpers/updateSchema.d.ts.map +0 -1
  673. package/dist/helpers/waitForEntityIdle.d.ts.map +0 -1
  674. package/dist/imports/index.d.ts.map +0 -1
  675. package/dist/imports/json.d.ts.map +0 -1
  676. package/dist/imports/markdown.d.ts +0 -38
  677. package/dist/imports/markdown.d.ts.map +0 -1
  678. package/dist/index-DBy53qbb.js +0 -23
  679. package/dist/index-DBy53qbb.js.map +0 -1
  680. package/dist/index-Dk73a7JE.js +0 -15426
  681. package/dist/index-Dk73a7JE.js.map +0 -1
  682. package/dist/index-LfXKx_PE.js +0 -18
  683. package/dist/index-LfXKx_PE.js.map +0 -1
  684. package/dist/index.d.ts +0 -22
  685. package/dist/index.d.ts.map +0 -1
  686. package/dist/interfaces/IDb.d.ts.map +0 -1
  687. package/dist/interfaces/IEasClient.d.ts.map +0 -1
  688. package/dist/interfaces/IItem.d.ts.map +0 -1
  689. package/dist/interfaces/IItemProperty.d.ts.map +0 -1
  690. package/dist/interfaces/IQueryClient.d.ts.map +0 -1
  691. package/dist/interfaces/index.d.ts.map +0 -1
  692. package/dist/node/codegen/drizzle.d.ts.map +0 -1
  693. package/dist/node/codegen/index.d.ts.map +0 -1
  694. package/dist/node/codegen/ts-to-proto.d.ts.map +0 -1
  695. package/dist/node/constants.d.ts.map +0 -1
  696. package/dist/node/db/Db.d.ts.map +0 -1
  697. package/dist/node/db/index.d.ts.map +0 -1
  698. package/dist/node/db/node.app.db.config.d.ts.map +0 -1
  699. package/dist/node/helpers/ArweaveClient.d.ts.map +0 -1
  700. package/dist/node/helpers/EasClient.d.ts.map +0 -1
  701. package/dist/node/helpers/FileManager.d.ts +0 -26
  702. package/dist/node/helpers/FileManager.d.ts.map +0 -1
  703. package/dist/node/helpers/PathResolver.d.ts.map +0 -1
  704. package/dist/node/helpers/QueryClient.d.ts.map +0 -1
  705. package/dist/node/helpers/index.d.ts.map +0 -1
  706. package/dist/node/helpers/scripts.d.ts.map +0 -1
  707. package/dist/node/index.d.ts.map +0 -1
  708. package/dist/node/seed.d.ts.map +0 -1
  709. package/dist/node/webpack/fs-proxy.d.ts.map +0 -1
  710. package/dist/node/webpack/index.d.ts.map +0 -1
  711. package/dist/property-1o2MvYTm.js +0 -282
  712. package/dist/property-1o2MvYTm.js.map +0 -1
  713. package/dist/queries-DA4G0iEN.js +0 -16
  714. package/dist/queries-DA4G0iEN.js.map +0 -1
  715. package/dist/seedSchema/AppStateSchema.d.ts.map +0 -1
  716. package/dist/seedSchema/ConfigSchema.d.ts.map +0 -1
  717. package/dist/seedSchema/MetadataSchema.d.ts.map +0 -1
  718. package/dist/seedSchema/ModelSchema.d.ts.map +0 -1
  719. package/dist/seedSchema/ModelSchemaSchema.d.ts +0 -61
  720. package/dist/seedSchema/ModelSchemaSchema.d.ts.map +0 -1
  721. package/dist/seedSchema/ModelUidSchema.d.ts.map +0 -1
  722. package/dist/seedSchema/PropertyUidSchema.d.ts.map +0 -1
  723. package/dist/seedSchema/SchemaSchema.d.ts.map +0 -1
  724. package/dist/seedSchema/SeedSchema.d.ts +0 -173
  725. package/dist/seedSchema/SeedSchema.d.ts.map +0 -1
  726. package/dist/seedSchema/VersionSchema.d.ts.map +0 -1
  727. package/dist/seedSchema/index.d.ts +0 -11
  728. package/dist/seedSchema/index.d.ts.map +0 -1
  729. package/dist/services/events.d.ts.map +0 -1
  730. package/dist/services/publish/actors/createPublishAttempt.d.ts.map +0 -1
  731. package/dist/services/publish/actors/preparePublishRequestData.d.ts.map +0 -1
  732. package/dist/services/publish/actors/upload.d.ts.map +0 -1
  733. package/dist/services/publish/actors/validateItemData.d.ts.map +0 -1
  734. package/dist/services/publish/publishMachine.d.ts.map +0 -1
  735. package/dist/services/write/actors/validateEntity.d.ts.map +0 -1
  736. package/dist/services/write/actors/writeToDatabase.d.ts.map +0 -1
  737. package/dist/services/write/writeProcessMachine.d.ts.map +0 -1
  738. package/dist/stores/eas.d.ts +0 -14
  739. package/dist/stores/eas.d.ts.map +0 -1
  740. package/dist/types/arweave.d.ts.map +0 -1
  741. package/dist/types/browser.d.ts.map +0 -1
  742. package/dist/types/db.d.ts.map +0 -1
  743. package/dist/types/fileManager.d.ts.map +0 -1
  744. package/dist/types/helpers.d.ts.map +0 -1
  745. package/dist/types/import.d.ts.map +0 -1
  746. package/dist/types/index.d.ts +0 -54
  747. package/dist/types/index.d.ts.map +0 -1
  748. package/dist/types/item.d.ts +0 -84
  749. package/dist/types/item.d.ts.map +0 -1
  750. package/dist/types/machines.d.ts +0 -50
  751. package/dist/types/machines.d.ts.map +0 -1
  752. package/dist/types/model.d.ts.map +0 -1
  753. package/dist/types/property.d.ts.map +0 -1
  754. package/dist/types/publish.d.ts.map +0 -1
  755. package/dist/types/seedProtocol.d.ts.map +0 -1
  756. package/dist/types/services.d.ts.map +0 -1
  757. package/dist/vite/easFix.d.ts.map +0 -1
  758. package/dist/vite/index.d.ts.map +0 -1
  759. /package/dist/{Item → src/Item}/queries.d.ts +0 -0
  760. /package/dist/{Item → src/Item}/service/actors/fetchDataFromEas.d.ts +0 -0
  761. /package/dist/{Item → src/Item}/service/actors/hydrateExistingItem.d.ts +0 -0
  762. /package/dist/{Item → src/Item}/service/actors/hydrateNewItem.d.ts +0 -0
  763. /package/dist/{Item → src/Item}/service/actors/initialize.d.ts +0 -0
  764. /package/dist/{Item → src/Item}/service/actors/loadOrCreateItem.d.ts +0 -0
  765. /package/dist/{Item → src/Item}/service/actors/reload.d.ts +0 -0
  766. /package/dist/{Item → src/Item}/service/actors/runPublish.d.ts +0 -0
  767. /package/dist/{Item → src/Item}/service/actors/saveDataToDb.d.ts +0 -0
  768. /package/dist/{Item → src/Item}/service/actors/waitForDb.d.ts +0 -0
  769. /package/dist/{Item → src/Item}/service/itemMachineSingle.d.ts +0 -0
  770. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/hydrateFromDb.d.ts +0 -0
  771. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/initialize.d.ts +0 -0
  772. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/loadOrCreateProperty.d.ts +0 -0
  773. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/resolveRelatedValue.d.ts +0 -0
  774. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/resolveRemoteStorage.d.ts +0 -0
  775. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/analyzeInput.d.ts +0 -0
  776. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/saveImage.d.ts +0 -0
  777. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/saveItemStorage.d.ts +0 -0
  778. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/saveValueToDb/saveRelation.d.ts +0 -0
  779. /package/dist/{ItemProperty → src/ItemProperty}/service/actors/waitForDb.d.ts +0 -0
  780. /package/dist/{Model → src/Model}/index.d.ts +0 -0
  781. /package/dist/{Model → src/Model}/service/actors/createModelProperties.d.ts +0 -0
  782. /package/dist/{Model → src/Model}/service/actors/loadOrCreateModel.d.ts +0 -0
  783. /package/dist/{Model → src/Model}/service/actors/validateModel.d.ts +0 -0
  784. /package/dist/{ModelProperty → src/ModelProperty}/service/actors/compareAndMarkDraft.d.ts +0 -0
  785. /package/dist/{ModelProperty → src/ModelProperty}/service/actors/saveToSchema.d.ts +0 -0
  786. /package/dist/{ModelProperty → src/ModelProperty}/service/actors/validateProperty.d.ts +0 -0
  787. /package/dist/{ModelProperty → src/ModelProperty}/service/modelPropertyMachine.d.ts +0 -0
  788. /package/dist/{Schema → src/Schema}/Schema.d.ts +0 -0
  789. /package/dist/{Schema → src/Schema}/errors.d.ts +0 -0
  790. /package/dist/{Schema → src/Schema}/index.d.ts +0 -0
  791. /package/dist/{Schema → src/Schema}/service/actors/checkExistingSchema.d.ts +0 -0
  792. /package/dist/{Schema → src/Schema}/service/actors/createModelInstances.d.ts +0 -0
  793. /package/dist/{Schema → src/Schema}/service/actors/createPropertyInstances.d.ts +0 -0
  794. /package/dist/{Schema → src/Schema}/service/actors/loadOrCreateSchema.d.ts +0 -0
  795. /package/dist/{Schema → src/Schema}/service/actors/validateSchema.d.ts +0 -0
  796. /package/dist/{Schema → src/Schema}/service/actors/verifyModelInstancesInCache.d.ts +0 -0
  797. /package/dist/{Schema → src/Schema}/service/actors/verifyModelsInDb.d.ts +0 -0
  798. /package/dist/{Schema → src/Schema}/service/actors/verifyPropertiesInDb.d.ts +0 -0
  799. /package/dist/{Schema → src/Schema}/service/actors/verifyPropertyInstancesInCache.d.ts +0 -0
  800. /package/dist/{Schema → src/Schema}/service/actors/verifySchemaInDb.d.ts +0 -0
  801. /package/dist/{Schema → src/Schema}/service/actors/writeModelsToDb.d.ts +0 -0
  802. /package/dist/{Schema → src/Schema}/service/actors/writePropertiesToDb.d.ts +0 -0
  803. /package/dist/{Schema → src/Schema}/service/actors/writeSchemaToDb.d.ts +0 -0
  804. /package/dist/{Schema → src/Schema}/service/validation/SchemaValidationService.d.ts +0 -0
  805. /package/dist/{Schema → src/Schema}/validation.d.ts +0 -0
  806. /package/dist/{browser → src/browser}/db/Db.d.ts +0 -0
  807. /package/dist/{browser → src/browser}/db/sqlWasmClient.d.ts +0 -0
  808. /package/dist/{browser → src/browser}/helpers/ArweaveClient.d.ts +0 -0
  809. /package/dist/{browser → src/browser}/helpers/EasClient.d.ts +0 -0
  810. /package/dist/{browser → src/browser}/helpers/PathResolver.d.ts +0 -0
  811. /package/dist/{browser → src/browser}/helpers/QueryClient.d.ts +0 -0
  812. /package/dist/{browser → src/browser}/helpers/index.d.ts +0 -0
  813. /package/dist/{browser → src/browser}/index.d.ts +0 -0
  814. /package/dist/{browser → src/browser}/react/OPFSImage.d.ts +0 -0
  815. /package/dist/{browser → src/browser}/react/SeedImage.d.ts +0 -0
  816. /package/dist/{browser → src/browser}/react/SeedProvider.d.ts +0 -0
  817. /package/dist/{browser → src/browser}/react/client.d.ts +0 -0
  818. /package/dist/{browser → src/browser}/react/db.d.ts +0 -0
  819. /package/dist/{browser → src/browser}/react/itemProperty.d.ts +0 -0
  820. /package/dist/{browser → src/browser}/react/liveQuery.d.ts +0 -0
  821. /package/dist/{browser → src/browser}/react/model.d.ts +0 -0
  822. /package/dist/{browser → src/browser}/react/modelProperty.d.ts +0 -0
  823. /package/dist/{browser → src/browser}/react/queryClient.d.ts +0 -0
  824. /package/dist/{browser → src/browser}/react/schema.d.ts +0 -0
  825. /package/dist/{browser → src/browser}/react/services.d.ts +0 -0
  826. /package/dist/{browser → src/browser}/react/trash.d.ts +0 -0
  827. /package/dist/{browser → src/browser}/seed.d.ts +0 -0
  828. /package/dist/{browser → src/browser}/workers/FileDownloader.d.ts +0 -0
  829. /package/dist/{browser → src/browser}/workers/ImageResizer.d.ts +0 -0
  830. /package/dist/{browser → src/browser}/workers/content-hash.d.ts +0 -0
  831. /package/dist/{browser → src/browser}/workers/dbWorker.d.ts +0 -0
  832. /package/dist/{browser → src/browser}/workers/filesDownload.d.ts +0 -0
  833. /package/dist/{browser → src/browser}/workers/imageResize.d.ts +0 -0
  834. /package/dist/{client → src/client}/BaseClientManager.d.ts +0 -0
  835. /package/dist/{client → src/client}/actions/setAddresses.d.ts +0 -0
  836. /package/dist/{client → src/client}/actors/addModelsToDb.d.ts +0 -0
  837. /package/dist/{client → src/client}/actors/addModelsToStore.d.ts +0 -0
  838. /package/dist/{client → src/client}/actors/dbInit.d.ts +0 -0
  839. /package/dist/{client → src/client}/actors/fileSystemInit.d.ts +0 -0
  840. /package/dist/{client → src/client}/actors/platformClassesInit.d.ts +0 -0
  841. /package/dist/{client → src/client}/actors/processSchemaFiles.d.ts +0 -0
  842. /package/dist/{client → src/client}/actors/saveAppState.d.ts +0 -0
  843. /package/dist/{client → src/client}/actors/saveConfig.d.ts +0 -0
  844. /package/dist/{client → src/client}/clientManagerMachine.d.ts +0 -0
  845. /package/dist/{client → src/client}/constants.d.ts +0 -0
  846. /package/dist/{client → src/client}/index.d.ts +0 -0
  847. /package/dist/{db → src/db}/Db/BaseDb.d.ts +0 -0
  848. /package/dist/{db → src/db}/configs/dev.schema.config.d.ts +0 -0
  849. /package/dist/{db → src/db}/read/getExistingItem.d.ts +0 -0
  850. /package/dist/{db → src/db}/read/getItem.d.ts +0 -0
  851. /package/dist/{db → src/db}/read/getItemData.d.ts +0 -0
  852. /package/dist/{db → src/db}/read/getItemProperties.d.ts +0 -0
  853. /package/dist/{db → src/db}/read/getItemProperty.d.ts +0 -0
  854. /package/dist/{db → src/db}/read/getMetadata.d.ts +0 -0
  855. /package/dist/{db → src/db}/read/getModelPropertiesData.d.ts +0 -0
  856. /package/dist/{db → src/db}/read/getModelSchemas.d.ts +0 -0
  857. /package/dist/{db → src/db}/read/getModels.d.ts +0 -0
  858. /package/dist/{db → src/db}/read/getModelsData.d.ts +0 -0
  859. /package/dist/{db → src/db}/read/getPropertyData.d.ts +0 -0
  860. /package/dist/{db → src/db}/read/getRelationValueData.d.ts +0 -0
  861. /package/dist/{db → src/db}/read/getSeedData.d.ts +0 -0
  862. /package/dist/{db → src/db}/read/getStorageTransactionIdForSeedUid.d.ts +0 -0
  863. /package/dist/{db → src/db}/read/getVersionData.d.ts +0 -0
  864. /package/dist/{db → src/db}/read/getVersionsForVersionUids.d.ts +0 -0
  865. /package/dist/{db → src/db}/read/subqueries/metadataLatest.d.ts +0 -0
  866. /package/dist/{db → src/db}/read/subqueries/versionData.d.ts +0 -0
  867. /package/dist/{db → src/db}/write/createMetadata.d.ts +0 -0
  868. /package/dist/{db → src/db}/write/createNewItem.d.ts +0 -0
  869. /package/dist/{db → src/db}/write/createSeed.d.ts +0 -0
  870. /package/dist/{db → src/db}/write/createSeeds.d.ts +0 -0
  871. /package/dist/{db → src/db}/write/createVersion.d.ts +0 -0
  872. /package/dist/{db → src/db}/write/deleteItem.d.ts +0 -0
  873. /package/dist/{db → src/db}/write/recoverDeletedItem.d.ts +0 -0
  874. /package/dist/{db → src/db}/write/saveAppState.d.ts +0 -0
  875. /package/dist/{db → src/db}/write/saveMetadata.d.ts +0 -0
  876. /package/dist/{db → src/db}/write/updateItemPropertyValue.d.ts +0 -0
  877. /package/dist/{db → src/db}/write/updateMetadata.d.ts +0 -0
  878. /package/dist/{db → src/db}/write/updateSeedUid.d.ts +0 -0
  879. /package/dist/{eslint-rules → src/eslint-rules}/align-imports.d.ts +0 -0
  880. /package/dist/{eventBus.d.ts → src/eventBus.d.ts} +0 -0
  881. /package/dist/{events → src/events}/files/download.d.ts +0 -0
  882. /package/dist/{events → src/events}/files/index.d.ts +0 -0
  883. /package/dist/{events → src/events}/index.d.ts +0 -0
  884. /package/dist/{events → src/events}/item/index.d.ts +0 -0
  885. /package/dist/{events → src/events}/item/syncDbWithEas.d.ts +0 -0
  886. /package/dist/{events → src/events}/services/allItems.d.ts +0 -0
  887. /package/dist/{events → src/events}/services/index.d.ts +0 -0
  888. /package/dist/{graphql → src/graphql}/fragments/Attestation.d.ts +0 -0
  889. /package/dist/{graphql → src/graphql}/fragments/Schema.d.ts +0 -0
  890. /package/dist/{graphql → src/graphql}/fragments/index.d.ts +0 -0
  891. /package/dist/{graphql → src/graphql}/gql/fragment-masking.d.ts +0 -0
  892. /package/dist/{graphql → src/graphql}/gql/gql.d.ts +0 -0
  893. /package/dist/{graphql → src/graphql}/gql/graphql.d.ts +0 -0
  894. /package/dist/{graphql → src/graphql}/gql/index.d.ts +0 -0
  895. /package/dist/{helpers → src/helpers}/ArweaveClient/BaseArweaveClient.d.ts +0 -0
  896. /package/dist/{helpers → src/helpers}/ArweaveClient/index.d.ts +0 -0
  897. /package/dist/{helpers → src/helpers}/ArweaveClient/queries.d.ts +0 -0
  898. /package/dist/{helpers → src/helpers}/EasClient/BaseEasClient.d.ts +0 -0
  899. /package/dist/{helpers → src/helpers}/PathResolver/BasePathResolver.d.ts +0 -0
  900. /package/dist/{helpers → src/helpers}/QueryClient/BaseQueryClient.d.ts +0 -0
  901. /package/dist/{helpers → src/helpers}/crypto.d.ts +0 -0
  902. /package/dist/{helpers → src/helpers}/entity/entityCache.d.ts +0 -0
  903. /package/dist/{helpers → src/helpers}/entity/entityCommon.d.ts +0 -0
  904. /package/dist/{helpers → src/helpers}/entity/entityDestroy.d.ts +0 -0
  905. /package/dist/{helpers → src/helpers}/entity/entityFind.d.ts +0 -0
  906. /package/dist/{helpers → src/helpers}/entity/entityLiveQuery.d.ts +0 -0
  907. /package/dist/{helpers → src/helpers}/entity/index.d.ts +0 -0
  908. /package/dist/{helpers → src/helpers}/environment.d.ts +0 -0
  909. /package/dist/{helpers → src/helpers}/file/download/actors.d.ts +0 -0
  910. /package/dist/{helpers → src/helpers}/file/download/index.d.ts +0 -0
  911. /package/dist/{helpers → src/helpers}/file/fetchAll/actors.d.ts +0 -0
  912. /package/dist/{helpers → src/helpers}/file/fetchAll/index.d.ts +0 -0
  913. /package/dist/{helpers → src/helpers}/file/queries.d.ts +0 -0
  914. /package/dist/{helpers → src/helpers}/files.d.ts +0 -0
  915. /package/dist/{helpers → src/helpers}/getSegmentedItemProperties.d.ts +0 -0
  916. /package/dist/{helpers → src/helpers}/image/queries.d.ts +0 -0
  917. /package/dist/{helpers → src/helpers}/model.d.ts +0 -0
  918. /package/dist/{helpers → src/helpers}/property.d.ts +0 -0
  919. /package/dist/{helpers → src/helpers}/reactiveProxy.d.ts +0 -0
  920. /package/dist/{helpers → src/helpers}/schema.d.ts +0 -0
  921. /package/dist/{helpers → src/helpers}/updateMachineContext.d.ts +0 -0
  922. /package/dist/{helpers → src/helpers}/waitForEntityIdle.d.ts +0 -0
  923. /package/dist/{imports → src/imports}/index.d.ts +0 -0
  924. /package/dist/{imports → src/imports}/json.d.ts +0 -0
  925. /package/dist/{interfaces → src/interfaces}/IDb.d.ts +0 -0
  926. /package/dist/{interfaces → src/interfaces}/IEasClient.d.ts +0 -0
  927. /package/dist/{interfaces → src/interfaces}/IItem.d.ts +0 -0
  928. /package/dist/{interfaces → src/interfaces}/IItemProperty.d.ts +0 -0
  929. /package/dist/{interfaces → src/interfaces}/IQueryClient.d.ts +0 -0
  930. /package/dist/{interfaces → src/interfaces}/index.d.ts +0 -0
  931. /package/dist/{node → src/node}/codegen/drizzle.d.ts +0 -0
  932. /package/dist/{node → src/node}/codegen/index.d.ts +0 -0
  933. /package/dist/{node → src/node}/codegen/ts-to-proto.d.ts +0 -0
  934. /package/dist/{node → src/node}/constants.d.ts +0 -0
  935. /package/dist/{node → src/node}/db/Db.d.ts +0 -0
  936. /package/dist/{node → src/node}/db/index.d.ts +0 -0
  937. /package/dist/{node → src/node}/db/node.app.db.config.d.ts +0 -0
  938. /package/dist/{node → src/node}/helpers/ArweaveClient.d.ts +0 -0
  939. /package/dist/{node → src/node}/helpers/EasClient.d.ts +0 -0
  940. /package/dist/{node → src/node}/helpers/PathResolver.d.ts +0 -0
  941. /package/dist/{node → src/node}/helpers/QueryClient.d.ts +0 -0
  942. /package/dist/{node → src/node}/helpers/index.d.ts +0 -0
  943. /package/dist/{node → src/node}/helpers/scripts.d.ts +0 -0
  944. /package/dist/{node → src/node}/index.d.ts +0 -0
  945. /package/dist/{node → src/node}/seed.d.ts +0 -0
  946. /package/dist/{node → src/node}/webpack/fs-proxy.d.ts +0 -0
  947. /package/dist/{node → src/node}/webpack/index.d.ts +0 -0
  948. /package/dist/{seedSchema → src/seedSchema}/AppStateSchema.d.ts +0 -0
  949. /package/dist/{seedSchema → src/seedSchema}/ConfigSchema.d.ts +0 -0
  950. /package/dist/{seedSchema → src/seedSchema}/MetadataSchema.d.ts +0 -0
  951. /package/dist/{seedSchema → src/seedSchema}/ModelSchema.d.ts +0 -0
  952. /package/dist/{seedSchema → src/seedSchema}/ModelUidSchema.d.ts +0 -0
  953. /package/dist/{seedSchema → src/seedSchema}/PropertyUidSchema.d.ts +0 -0
  954. /package/dist/{seedSchema → src/seedSchema}/SchemaSchema.d.ts +0 -0
  955. /package/dist/{seedSchema → src/seedSchema}/VersionSchema.d.ts +0 -0
  956. /package/dist/{services → src/services}/events.d.ts +0 -0
  957. /package/dist/{services → src/services}/publish/actors/createPublishAttempt.d.ts +0 -0
  958. /package/dist/{services → src/services}/publish/actors/preparePublishRequestData.d.ts +0 -0
  959. /package/dist/{services → src/services}/publish/actors/upload.d.ts +0 -0
  960. /package/dist/{services → src/services}/publish/actors/validateItemData.d.ts +0 -0
  961. /package/dist/{services → src/services}/publish/publishMachine.d.ts +0 -0
  962. /package/dist/{services → src/services}/write/actors/validateEntity.d.ts +0 -0
  963. /package/dist/{services → src/services}/write/actors/writeToDatabase.d.ts +0 -0
  964. /package/dist/{services → src/services}/write/writeProcessMachine.d.ts +0 -0
  965. /package/dist/{types → src/types}/arweave.d.ts +0 -0
  966. /package/dist/{types → src/types}/browser.d.ts +0 -0
  967. /package/dist/{types → src/types}/db.d.ts +0 -0
  968. /package/dist/{types → src/types}/fileManager.d.ts +0 -0
  969. /package/dist/{types → src/types}/helpers.d.ts +0 -0
  970. /package/dist/{types → src/types}/import.d.ts +0 -0
  971. /package/dist/{types → src/types}/model.d.ts +0 -0
  972. /package/dist/{types → src/types}/property.d.ts +0 -0
  973. /package/dist/{types → src/types}/publish.d.ts +0 -0
  974. /package/dist/{types → src/types}/seedProtocol.d.ts +0 -0
  975. /package/dist/{types → src/types}/services.d.ts +0 -0
  976. /package/dist/{vite → src/vite}/easFix.d.ts +0 -0
  977. /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