@seedprotocol/sdk 0.4.9 → 0.4.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{ArweaveClient-sN5h2FvY.js → ArweaveClient-CwXE3NCK.js} +3 -3
- package/dist/{ArweaveClient-sN5h2FvY.js.map → ArweaveClient-CwXE3NCK.js.map} +1 -1
- package/dist/{ArweaveClient-DFqnm5Kj.js → ArweaveClient-DyhvHiIT.js} +3 -3
- package/dist/{ArweaveClient-DFqnm5Kj.js.map → ArweaveClient-DyhvHiIT.js.map} +1 -1
- package/dist/{Db-DIythELU.js → Db-Dr6gWq8d.js} +3 -3
- package/dist/{Db-DIythELU.js.map → Db-Dr6gWq8d.js.map} +1 -1
- package/dist/{Db-Dz17KxVs.js → Db-mH9nSDfI.js} +3 -3
- package/dist/{Db-Dz17KxVs.js.map → Db-mH9nSDfI.js.map} +1 -1
- package/dist/{EasClient-BadfcFDk.js → EasClient-Yh-t7zEA.js} +2 -2
- package/dist/{EasClient-DosbWaZN.js.map → EasClient-Yh-t7zEA.js.map} +1 -1
- package/dist/{EasClient-DosbWaZN.js → EasClient-aggdMFrc.js} +2 -2
- package/dist/{EasClient-BadfcFDk.js.map → EasClient-aggdMFrc.js.map} +1 -1
- package/dist/{FileManager-Wthr5yHO.js → FileManager-ClU_rIR0.js} +2 -2
- package/dist/{FileManager-Wthr5yHO.js.map → FileManager-ClU_rIR0.js.map} +1 -1
- package/dist/{FileManager-BHuVNWT3.js → FileManager-Dl2DD4Uc.js} +2 -2
- package/dist/{FileManager-BHuVNWT3.js.map → FileManager-Dl2DD4Uc.js.map} +1 -1
- package/dist/{ModelProperty-B9Z2DRxI.js → ModelProperty-gBmew8gY.js} +94 -18
- package/dist/ModelProperty-gBmew8gY.js.map +1 -0
- package/dist/{PathResolver-NEpTSgQK.js → PathResolver-CILJPhz1.js} +2 -2
- package/dist/{PathResolver-NEpTSgQK.js.map → PathResolver-CILJPhz1.js.map} +1 -1
- package/dist/{PathResolver-Cd1PZDLG.js → PathResolver-CfA_D3wa.js} +2 -2
- package/dist/{PathResolver-Cd1PZDLG.js.map → PathResolver-CfA_D3wa.js.map} +1 -1
- package/dist/{QueryClient-C9U8oZUe.js → QueryClient-BdpWYoxo.js} +2 -2
- package/dist/{QueryClient-C9U8oZUe.js.map → QueryClient-BdpWYoxo.js.map} +1 -1
- package/dist/{QueryClient-ndmA8MYL.js → QueryClient-Dl_P8u5s.js} +2 -2
- package/dist/{QueryClient-ndmA8MYL.js.map → QueryClient-Dl_P8u5s.js.map} +1 -1
- package/dist/{Schema-D1-HjT8z.js → Schema-B-vCLIuU.js} +21 -21
- package/dist/{Schema-D1-HjT8z.js.map → Schema-B-vCLIuU.js.map} +1 -1
- package/dist/{SchemaValidationService-CIXKzSpb.js → SchemaValidationService-C_iTQIjR.js} +2 -2
- package/dist/{SchemaValidationService-CIXKzSpb.js.map → SchemaValidationService-C_iTQIjR.js.map} +1 -1
- package/dist/cjs/{ModelProperty-09hNvSBl.js → ModelProperty-DcAM5M8T.js} +94 -18
- package/dist/cjs/ModelProperty-DcAM5M8T.js.map +1 -0
- package/dist/cjs/{Schema-BcwvUABB.js → Schema-B6ifYEhD.js} +20 -20
- package/dist/cjs/{Schema-BcwvUABB.js.map → Schema-B6ifYEhD.js.map} +1 -1
- package/dist/cjs/{SchemaValidationService-zty4nfCu.js → SchemaValidationService-OFyzZIUX.js} +2 -2
- package/dist/cjs/{SchemaValidationService-zty4nfCu.js.map → SchemaValidationService-OFyzZIUX.js.map} +1 -1
- package/dist/cjs/{getItem-Dlb5YSQn.js → getItem-CAYQYTpg.js} +2 -2
- package/dist/cjs/{getItem-Dlb5YSQn.js.map → getItem-CAYQYTpg.js.map} +1 -1
- package/dist/cjs/{getPublishPayload-BqL06sEI.js → getPublishPayload-CBuGIazw.js} +5 -5
- package/dist/cjs/{getPublishPayload-BqL06sEI.js.map → getPublishPayload-CBuGIazw.js.map} +1 -1
- package/dist/cjs/{getPublishUploads-oukGI2N6.js → getPublishUploads-B7bB1OGg.js} +3 -3
- package/dist/cjs/{getPublishUploads-oukGI2N6.js.map → getPublishUploads-B7bB1OGg.js.map} +1 -1
- package/dist/cjs/{getSegmentedItemProperties-JT984OOp.js → getSegmentedItemProperties-MVZ-0mQG.js} +2 -2
- package/dist/cjs/{getSegmentedItemProperties-JT984OOp.js.map → getSegmentedItemProperties-MVZ-0mQG.js.map} +1 -1
- package/dist/cjs/{index-jubgGeM2.js → index-6P4MEsbO.js} +2 -2
- package/dist/cjs/index-6P4MEsbO.js.map +1 -0
- package/dist/cjs/{index-BLETlVgA.js → index-CA4i5TA7.js} +105 -46
- package/dist/cjs/index-CA4i5TA7.js.map +1 -0
- package/dist/cjs/{ownership-vfvyz3KJ.js → ownership-5TQ-v2CF.js} +2 -2
- package/dist/cjs/{ownership-vfvyz3KJ.js.map → ownership-5TQ-v2CF.js.map} +1 -1
- package/dist/{getItem-f9rNUz7I.js → getItem-xpxRXqHI.js} +2 -2
- package/dist/{getItem-f9rNUz7I.js.map → getItem-xpxRXqHI.js.map} +1 -1
- package/dist/{getPublishPayload-BBI_j9I2.js → getPublishPayload-CBeCMSeQ.js} +5 -5
- package/dist/{getPublishPayload-BBI_j9I2.js.map → getPublishPayload-CBeCMSeQ.js.map} +1 -1
- package/dist/{getPublishUploads-BFM94w5S.js → getPublishUploads-NITxWWDD.js} +3 -3
- package/dist/{getPublishUploads-BFM94w5S.js.map → getPublishUploads-NITxWWDD.js.map} +1 -1
- package/dist/{getSegmentedItemProperties-Di9vevKz.js → getSegmentedItemProperties-CYzNtJxH.js} +2 -2
- package/dist/{getSegmentedItemProperties-Di9vevKz.js.map → getSegmentedItemProperties-CYzNtJxH.js.map} +1 -1
- package/dist/{index-CSAVWKeA.js → index-BC0xKxkf.js} +3 -3
- package/dist/index-BC0xKxkf.js.map +1 -0
- package/dist/{index-j8WN8W6V.js → index-B_apqB1Q.js} +120 -61
- package/dist/index-B_apqB1Q.js.map +1 -0
- package/dist/{index-ajj6SHkh.js → index-CcXvJ2H7.js} +2 -2
- package/dist/index-CcXvJ2H7.js.map +1 -0
- package/dist/main.cjs +1 -1
- package/dist/main.js +11 -11
- package/dist/node.js +10 -10
- package/dist/{ownership-DLNI17NE.js → ownership-C7Afj3yr.js} +2 -2
- package/dist/{ownership-DLNI17NE.js.map → ownership-C7Afj3yr.js.map} +1 -1
- package/dist/{property-C6qoOzLG.js → property-C2gviIFJ.js} +4 -4
- package/dist/{property-C6qoOzLG.js.map → property-C2gviIFJ.js.map} +1 -1
- package/dist/{queries-jMaUn86w.js → queries-BFzkFn4Y.js} +2 -2
- package/dist/{queries-jMaUn86w.js.map → queries-BFzkFn4Y.js.map} +1 -1
- package/dist/src/ModelProperty/ModelProperty.d.ts +5 -0
- package/dist/src/ModelProperty/ModelProperty.d.ts.map +1 -1
- package/dist/src/ModelProperty/service/actors/compareAndMarkDraft.d.ts.map +1 -1
- package/dist/src/ModelProperty/service/actors/validateProperty.d.ts.map +1 -1
- package/dist/src/ModelProperty/service/modelPropertyMachine.d.ts.map +1 -1
- package/dist/src/helpers/db.d.ts.map +1 -1
- package/dist/src/services/write/actors/writeToDatabase.d.ts.map +1 -1
- package/package.json +8 -8
- package/dist/ModelProperty-B9Z2DRxI.js.map +0 -1
- package/dist/cjs/ModelProperty-09hNvSBl.js.map +0 -1
- package/dist/cjs/index-BLETlVgA.js.map +0 -1
- package/dist/cjs/index-jubgGeM2.js.map +0 -1
- package/dist/index-CSAVWKeA.js.map +0 -1
- package/dist/index-ajj6SHkh.js.map +0 -1
- package/dist/index-j8WN8W6V.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModelProperty-DcAM5M8T.js","sources":["../../../src/ModelProperty/service/actors/saveToSchema.ts","../../../src/ModelProperty/service/actors/compareAndMarkDraft.ts","../../../src/ModelProperty/service/actors/validateProperty.ts","../../../src/ModelProperty/service/modelPropertyMachine.ts","../../../src/db/read/getModelPropertiesData.ts","../../../src/ModelProperty/ModelProperty.ts"],"sourcesContent":["import { EventObject, fromCallback } from 'xstate'\nimport { FromCallbackInput } from '@/types'\nimport { ModelPropertyMachineContext } from '../modelPropertyMachine'\nimport debug from 'debug'\nconst logger = debug('seedSdk:modelProperty:actors:saveToSchema')\n\n/**\n * Get schema name from model\n * This function finds which schema contains the given model\n * Exported so it can be reused by ModelProperty for setting schema name\n */\nexport async function getSchemaNameFromModel(modelName: string): Promise<string | undefined> {\n // Get the latest schema files and find which one contains this model\n const schemaHelpersMod = await import('../../../helpers/schema')\n const { listLatestSchemaFiles } = schemaHelpersMod\n const latestSchemas = await listLatestSchemaFiles()\n\n for (const schema of latestSchemas) {\n try {\n const fileManagerMod = await import('../../../helpers/FileManager/BaseFileManager')\n const { BaseFileManager } = fileManagerMod\n const content = await BaseFileManager.readFileAsString(schema.filePath)\n const schemaFile = JSON.parse(content) as any\n\n if (schemaFile.models && schemaFile.models[modelName]) {\n return schema.name\n }\n } catch (error) {\n logger('Error reading schema file:', error)\n continue\n }\n }\n\n return undefined\n}\n\nexport const saveToSchema = fromCallback<\n EventObject,\n FromCallbackInput<ModelPropertyMachineContext>\n>(({ sendBack, input: { context } }) => {\n const _saveToSchema = async (): Promise<void> => {\n // Use dynamic import to break circular dependency\n const validationServiceMod = await import('../../../Schema/service/validation/SchemaValidationService')\n const { SchemaValidationService } = validationServiceMod\n const validationService = new SchemaValidationService()\n \n // Validate property structure before saving\n const validationResult = validationService.validatePropertyStructure(context)\n if (!validationResult.isValid) {\n throw new Error(`Property validation failed: ${validationResult.errors.map(e => e.message).join(', ')}`)\n }\n\n // Validate required fields\n if (!context.name) {\n throw new Error('Property name is required')\n }\n\n if (!context.dataType) {\n throw new Error('Data type is required')\n }\n\n if (!context.modelName) {\n throw new Error(`Model not found for modelId: ${context.modelId}`)\n }\n\n // Persist to database only - schema file is updated only when user calls Schema.saveNewVersion()\n const dbMod = await import('../../../helpers/db')\n const { savePropertyToDb } = dbMod\n await savePropertyToDb(context)\n\n // Mark schema as draft so user knows to save\n const schemaName = context._schemaName ?? (await getSchemaNameFromModel(context.modelName))\n if (schemaName) {\n const schemaMod = await import('../../../Schema/Schema')\n const { Schema } = schemaMod\n const schema = Schema.create(schemaName, { waitForReady: false }) as import('@/Schema/Schema').Schema\n schema.getService().send({\n type: 'markAsDraft',\n propertyKey: `${context.modelName}:${context.name}`,\n })\n }\n\n logger(`Successfully saved property ${context.modelName}:${context.name} to database`)\n }\n\n _saveToSchema().then(() => {\n sendBack({ type: 'saveToSchemaSuccess' })\n }).catch((error) => {\n logger('Error saving to schema:', error)\n sendBack({ type: 'saveToSchemaError', error })\n })\n\n return () => {\n // Cleanup function (optional)\n }\n})\n","import { EventObject, fromCallback } from 'xstate'\nimport { FromCallbackInput } from '@/types'\nimport { ModelPropertyMachineContext } from '../modelPropertyMachine'\n// Dynamic import to break circular dependency: helpers/db -> ModelProperty -> compareAndMarkDraft -> helpers/db\n// import { savePropertyToDb } from '@/helpers/db'\nimport { BaseDb } from '@/db/Db/BaseDb'\nimport debug from 'debug'\n\nconst logger = debug('seedSdk:modelProperty:actors:compareAndMarkDraft')\n\nexport const compareAndMarkDraft = fromCallback<\n EventObject,\n FromCallbackInput<ModelPropertyMachineContext>\n>(({ sendBack, input: { context } }) => {\n const _compareAndMarkDraft = async (): Promise<void> => {\n // Fill modelName/dataType from _originalValues when missing, then from DB by schemaFileId\n let fullContext = {\n ...context,\n modelName: context.modelName ?? (context._originalValues as any)?.modelName,\n dataType: context.dataType ?? (context._originalValues as any)?.dataType,\n }\n const schemaFileIdForResolve = fullContext._propertyFileId || (typeof fullContext.id === 'string' ? fullContext.id : undefined)\n if (schemaFileIdForResolve && (fullContext.modelName === undefined || fullContext.dataType === undefined)) {\n try {\n const dbMod = await import('../../../helpers/db')\n const { getPropertyModelNameAndDataType, getModelNameByModelId } = dbMod\n let fromDb: { modelName: string; dataType: string } | undefined\n for (let attempt = 0; attempt < 6; attempt++) {\n fromDb = await getPropertyModelNameAndDataType(schemaFileIdForResolve)\n if (fromDb) break\n if (attempt < 5) await new Promise((r) => setTimeout(r, 40))\n }\n if (fromDb) {\n fullContext = {\n ...fullContext,\n modelName: fullContext.modelName ?? fromDb.modelName,\n dataType: fullContext.dataType ?? fromDb.dataType,\n }\n }\n if (fullContext.modelName === undefined && schemaFileIdForResolve) {\n const mod = await import('../../../ModelProperty/ModelProperty')\n const ModelProperty = mod?.ModelProperty ?? (mod as { default?: unknown })?.default\n const pendingModelId = ModelProperty?.getPendingModelId?.(schemaFileIdForResolve)\n if (pendingModelId != null) {\n const modelName = await getModelNameByModelId(pendingModelId)\n if (modelName) {\n fullContext = { ...fullContext, modelName }\n }\n }\n }\n } catch {\n // ignore\n }\n }\n const schemaFileId = fullContext._propertyFileId || (typeof fullContext.id === 'string' ? fullContext.id : undefined)\n // If _originalValues is not set, we still need to save to database if the property exists\n // This handles the case where the name is changed before _originalValues is initialized\n if (!fullContext._originalValues) {\n logger('No original values to compare against')\n logger(`[compareAndMarkDraft] Context: modelName=${fullContext.modelName}, name=${fullContext.name}, id=${fullContext.id}, _propertyFileId=${fullContext._propertyFileId}`)\n\n // #region agent log\n fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'compareAndMarkDraft.ts:noOriginalValues',message:'compareAndMarkDraft early path - no _originalValues',data:{name:fullContext.name,modelName:fullContext.modelName,schemaFileId:schemaFileId,willSave:!!(fullContext.modelName&&fullContext.name&&schemaFileId)},timestamp:Date.now(),hypothesisId:'A'})}).catch(()=>{});\n // #endregion\n \n // If we have a name and modelName, try to save to database anyway\n // This ensures name changes are persisted even if _originalValues isn't initialized yet\n // We need either schemaFileId (id or _propertyFileId) to find the property in the database\n if (fullContext.modelName && fullContext.name && schemaFileId) {\n logger(`[compareAndMarkDraft] _originalValues not set, but saving to database anyway for property ${context.modelName}:${context.name} (schemaFileId: ${schemaFileId})`)\n try {\n const dbMod = await import('../../../helpers/db')\n const { savePropertyToDb } = dbMod\n // Ensure _propertyFileId is set for savePropertyToDb to find the property\n const contextWithFileId = {\n ...fullContext,\n _propertyFileId: schemaFileId,\n }\n await savePropertyToDb(contextWithFileId)\n logger(`[compareAndMarkDraft] Successfully saved property ${fullContext.modelName}:${fullContext.name} to database (no _originalValues)`)\n } catch (error) {\n logger(`[compareAndMarkDraft] Error saving property to database (no _originalValues): ${error}`)\n // Don't throw - this is a best-effort save, but log the error for debugging\n console.error(`[compareAndMarkDraft] Failed to save property ${fullContext.modelName}:${fullContext.name}:`, error)\n }\n } else {\n logger(`[compareAndMarkDraft] Cannot save property ${fullContext.modelName}:${fullContext.name} - missing required fields (schemaFileId: ${schemaFileId})`)\n }\n return\n }\n\n logger(`[compareAndMarkDraft] Comparing: context.name=${fullContext.name}, _originalValues.name=${fullContext._originalValues?.name}`)\n\n // #region agent log\n fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'compareAndMarkDraft.ts:beforeHasChanges',message:'compareAndMarkDraft before hasChanges',data:{name:fullContext.name,originalName:fullContext._originalValues?.name,id:fullContext.id,schemaFileId:fullContext._propertyFileId||fullContext.id},timestamp:Date.now(),hypothesisId:'A'})}).catch(()=>{});\n // #endregion\n \n // Compare current values with original\n // Only compare property fields, not internal fields\n const propertyFields = ['name', 'dataType', 'ref', 'refModelName', 'refModelId', 'refValueType', 'storageType', 'localStorageDir', 'filenameSuffix', 'modelName', 'modelId']\n const hasChanges = propertyFields.some(key => {\n const currentValue = (fullContext as any)[key]\n const originalValue = (fullContext._originalValues as any)?.[key]\n \n // Handle name changes specifically\n if (key === 'name') {\n const nameChanged = currentValue !== originalValue\n if (nameChanged) {\n logger(`[compareAndMarkDraft] Name change detected: \"${originalValue}\" -> \"${currentValue}\"`)\n }\n return nameChanged\n }\n \n // Handle ref fields - compare by name\n if (key === 'ref' || key === 'refModelName') {\n const currentRef = fullContext.refModelName || fullContext.ref\n const originalRef = fullContext._originalValues?.refModelName || fullContext._originalValues?.ref\n // Both undefined/null means no ref, so they're the same\n if (!currentRef && !originalRef) return false\n return currentRef !== originalRef\n }\n \n // For other fields, compare values (handling undefined/null)\n if (currentValue === undefined && originalValue === undefined) return false\n if (currentValue === null && originalValue === null) return false\n if (currentValue === undefined && originalValue === null) return false\n if (currentValue === null && originalValue === undefined) return false\n \n return currentValue !== originalValue\n })\n\n if (hasChanges) {\n logger(`Property ${fullContext.modelName}:${fullContext.name} has changes, marking as edited`)\n logger(`[compareAndMarkDraft] Context when saving: id=${fullContext.id}, _propertyFileId=${fullContext._propertyFileId}, name=${fullContext.name}, _originalValues.name=${fullContext._originalValues?.name}`)\n\n // #region agent log\n fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'compareAndMarkDraft.ts:hasChanges-callingSave',message:'compareAndMarkDraft calling savePropertyToDb',data:{name:fullContext.name,originalName:fullContext._originalValues?.name,schemaFileId:fullContext._propertyFileId||fullContext.id},timestamp:Date.now(),hypothesisId:'A'})}).catch(()=>{});\n // #endregion\n\n // Use dynamic import to break circular dependency\n const dbMod = await import('../../../helpers/db')\n const { savePropertyToDb } = dbMod\n // Save to database (but not JSON file) - always save to DB when there are changes\n try {\n await savePropertyToDb(fullContext)\n logger(`[compareAndMarkDraft] Successfully saved property ${fullContext.modelName}:${fullContext.name} to database`)\n\n // #region agent log\n fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'compareAndMarkDraft.ts:savePropertyToDbSuccess',message:'savePropertyToDb completed successfully',data:{name:fullContext.name},timestamp:Date.now(),hypothesisId:'A'})}).catch(()=>{});\n // #endregion\n } catch (error) {\n logger(`[compareAndMarkDraft] Error saving property to database: ${error}`)\n // #region agent log\n if (typeof fetch === 'function') { fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'compareAndMarkDraft.ts:savePropertyToDbError',message:'savePropertyToDb FAILED',data:{name:fullContext.name,error:String(error)},timestamp:Date.now(),hypothesisId:'B'})}).catch(()=>{}); }\n // #endregion\n throw error\n }\n\n // Mark schema as draft if schema name is available\n if (fullContext._schemaName) {\n // Get the Schema instance and mark it as draft\n const schemaMod = await import('../../../Schema/Schema')\n const { Schema } = schemaMod\n const schema = Schema.create(fullContext._schemaName, {\n waitForReady: false,\n }) as import('@/Schema/Schema').Schema\n\n // Send event to Schema machine to mark as draft\n schema.getService().send({\n type: 'markAsDraft',\n propertyKey: `${fullContext.modelName}:${fullContext.name}`,\n })\n }\n } else {\n // No changes - clear edited flag in database and context\n logger(`Property ${fullContext.modelName}:${fullContext.name} has no changes`)\n \n // Clear isEdited flag in database\n try {\n const seedSchemaMod = await import('../../../seedSchema')\n const { properties: propertiesTable, models: modelsTable } = seedSchemaMod\n const drizzleMod = await import('drizzle-orm')\n const { eq, and } = drizzleMod\n \n const db = BaseDb.getAppDb()\n if (db && fullContext.modelName && fullContext.name) {\n // Find model by name\n const modelRecords = await db\n .select({ id: modelsTable.id })\n .from(modelsTable)\n .where(eq(modelsTable.name, fullContext.modelName))\n .limit(1)\n \n if (modelRecords.length > 0) {\n // Find property by name and modelId\n const propertyRecords = await db\n .select({ id: propertiesTable.id })\n .from(propertiesTable)\n .where(\n and(\n eq(propertiesTable.name, fullContext.name),\n eq(propertiesTable.modelId, modelRecords[0].id)\n )\n )\n .limit(1)\n \n if (propertyRecords.length > 0) {\n // Clear isEdited flag in database\n await db\n .update(propertiesTable)\n .set({ isEdited: false })\n .where(eq(propertiesTable.id, propertyRecords[0].id!))\n logger(`Cleared isEdited flag in database for property ${fullContext.modelName}:${fullContext.name}`)\n }\n }\n }\n } catch (error) {\n logger(`Error clearing isEdited flag in database: ${error}`)\n }\n \n sendBack({\n type: 'clearEdited',\n })\n }\n }\n\n _compareAndMarkDraft().then(() => {\n sendBack({ type: 'compareAndMarkDraftSuccess' })\n }).catch((error) => {\n logger('Error comparing and marking draft:', error)\n sendBack({ type: 'compareAndMarkDraftError', error })\n })\n\n return () => {\n // Cleanup function (optional)\n }\n})\n","import { EventObject, fromCallback } from 'xstate'\nimport { FromCallbackInput } from '@/types'\nimport { ModelPropertyMachineContext } from '../modelPropertyMachine'\n// Dynamic imports to break circular dependencies:\n// - schema/index -> ... -> validateProperty -> SchemaValidationService -> schema/index\n// - schema/Schema -> ... -> validateProperty -> Schema -> schema/Schema\n// import { SchemaValidationService } from '@/Schema/service/validation/SchemaValidationService'\n// import { Schema } from '@/Schema/Schema'\nimport debug from 'debug'\n\nconst logger = debug('seedSdk:modelProperty:actors:validateProperty')\n\nexport const validateProperty = fromCallback<\n EventObject,\n FromCallbackInput<ModelPropertyMachineContext>\n>(({ sendBack, input: { context } }) => {\n const _validateProperty = async (): Promise<void> => {\n // Use full context for validation: fill modelName/dataType from _originalValues when missing, then\n // from DB by schemaFileId (context.id) so just-created renames don't fail structure validation.\n let fullContext = {\n ...context,\n modelName: context.modelName ?? (context._originalValues as any)?.modelName,\n dataType: context.dataType ?? (context._originalValues as any)?.dataType,\n }\n const schemaFileId = typeof context.id === 'string' ? context.id : undefined\n if (schemaFileId && (fullContext.modelName === undefined || fullContext.dataType === undefined)) {\n // Brief wait so trackPendingWrite from ModelProperty.create() has time to run (it's in setTimeout(0))\n await new Promise((r) => setTimeout(r, 60))\n try {\n const dbMod = await import('../../../helpers/db')\n const { getPropertyModelNameAndDataType, getModelNameByModelId } = dbMod\n // Try pending write first (property row may not exist yet)\n if (fullContext.modelName === undefined && schemaFileId) {\n const mod = await import('../../../ModelProperty/ModelProperty')\n const ModelProperty = mod?.ModelProperty ?? (mod as { default?: unknown })?.default\n const pendingModelId = ModelProperty?.getPendingModelId?.(schemaFileId)\n if (pendingModelId != null) {\n const modelName = await getModelNameByModelId(pendingModelId)\n if (modelName) {\n fullContext = { ...fullContext, modelName }\n }\n }\n }\n // Then DB property lookup with retry (catches row after initial write)\n let fromDb: { modelName: string; dataType: string } | undefined\n for (let attempt = 0; attempt < 6; attempt++) {\n fromDb = await getPropertyModelNameAndDataType(schemaFileId)\n if (fromDb) break\n if (attempt < 5) await new Promise((r) => setTimeout(r, 40))\n }\n if (fromDb) {\n fullContext = {\n ...fullContext,\n modelName: fullContext.modelName ?? fromDb.modelName,\n dataType: fullContext.dataType ?? fromDb.dataType,\n }\n }\n // If still no modelName, try pending write again (may have been set during retries)\n if (fullContext.modelName === undefined && schemaFileId) {\n const mod = await import('../../../ModelProperty/ModelProperty')\n const ModelProperty = mod?.ModelProperty ?? (mod as { default?: unknown })?.default\n const pendingModelId = ModelProperty?.getPendingModelId?.(schemaFileId)\n if (pendingModelId != null) {\n const modelName = await getModelNameByModelId(pendingModelId)\n if (modelName) {\n fullContext = { ...fullContext, modelName }\n }\n }\n }\n } catch {\n // ignore\n }\n }\n // Last resort for structure validation: TProperty requires dataType; allow name+id to pass if we have schemaFileId\n if (fullContext.dataType === undefined && (fullContext.modelName !== undefined || schemaFileId)) {\n fullContext = { ...fullContext, dataType: (fullContext.dataType ?? (context._originalValues as any)?.dataType) || 'Text' }\n }\n // Use dynamic imports to break circular dependencies\n const validationServiceMod = await import('../../../Schema/service/validation/SchemaValidationService')\n const { SchemaValidationService } = validationServiceMod\n const validationService = new SchemaValidationService()\n const schemaMod = await import('../../../Schema/Schema')\n const { Schema } = schemaMod\n \n // Validate property structure\n const structureResult = validationService.validatePropertyStructure(fullContext)\n \n if (!structureResult.isValid) {\n // #region agent log\n if (typeof fetch === 'function') { fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'validateProperty.ts:structureInvalid',message:'validateProperty structure validation FAILED',data:{name:fullContext.name,errors:structureResult.errors?.map((e:any)=>e.message||e.code)},timestamp:Date.now(),hypothesisId:'D'})}).catch(()=>{}); }\n // #endregion\n sendBack({ type: 'validationError', errors: structureResult.errors })\n return\n }\n\n // If we have schema name and model name, validate against schema\n if (fullContext._schemaName && fullContext.modelName) {\n try {\n const schema = Schema.create(fullContext._schemaName, {\n waitForReady: false,\n }) as import('@/Schema/Schema').Schema\n const schemaSnapshot = schema.getService().getSnapshot()\n const schemaStatus = schemaSnapshot.value\n \n // Only validate against schema if it's loaded (in idle state)\n // If still loading, skip schema validation and only do structure validation\n if (schemaStatus === 'idle') {\n const schemaContext = schemaSnapshot.context\n \n // Check if models are actually loaded\n if (schemaContext.models && Object.keys(schemaContext.models).length > 0) {\n // If property name has changed, validate against the original name (from schema file)\n // This handles the case where a property is renamed - the schema file still has the old name\n const propertyNameToValidate = fullContext._originalValues?.name && fullContext._originalValues.name !== fullContext.name\n ? fullContext._originalValues.name\n : fullContext.name || ''\n \n const schemaResult = validationService.validateProperty(\n schemaContext,\n fullContext.modelName,\n propertyNameToValidate,\n fullContext\n )\n \n if (!schemaResult.isValid) {\n // If property was renamed, some validation errors are expected (like property_not_found, missing_type)\n // Only fail if it's a critical error that's not related to the rename\n const isRenamed = fullContext._originalValues?.name && fullContext._originalValues.name !== fullContext.name\n const criticalErrors = schemaResult.errors.filter(err => {\n // Allow property_not_found and missing_type errors when property is renamed\n if (isRenamed && (err.code === 'property_not_found' || err.code === 'missing_type')) {\n return false // Not critical\n }\n // For non-renamed properties, only allow property_not_found if we're validating with the same name\n if (err.code === 'property_not_found' && propertyNameToValidate === fullContext.name) {\n return false // Not critical\n }\n return true // Critical error\n })\n \n if (criticalErrors.length > 0) {\n // #region agent log\n if (typeof fetch === 'function') { fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'validateProperty.ts:schemaCriticalErrors',message:'validateProperty schema validation FAILED (critical)',data:{name:fullContext.name,isRenamed:!!(fullContext._originalValues?.name&&fullContext._originalValues.name!==fullContext.name),criticalErrors:criticalErrors?.map((e:any)=>e.message||e.code)},timestamp:Date.now(),hypothesisId:'D'})}).catch(()=>{}); }\n // #endregion\n sendBack({ type: 'validationError', errors: criticalErrors })\n return\n }\n // Continue with validation - rename-related errors are acceptable\n }\n } else {\n logger('Schema models not loaded yet, skipping schema validation')\n // Continue with structure validation only\n }\n } else {\n logger(`Schema is in ${schemaStatus} state, skipping schema validation`)\n // Continue with structure validation only\n }\n } catch (error) {\n logger('Error validating property against schema:', error)\n // Continue with structure validation only\n }\n }\n\n // All validations passed\n sendBack({ type: 'validationSuccess', errors: [] })\n }\n\n _validateProperty().catch((error) => {\n logger('Error in validateProperty:', error)\n sendBack({\n type: 'validationError',\n errors: [{\n field: 'property',\n message: error instanceof Error ? error.message : 'Unknown validation error',\n code: 'validation_exception',\n severity: 'error' as const,\n }],\n })\n })\n\n return () => {\n // Cleanup function (optional)\n }\n})\n\n","import { assign, setup, ActorRefFrom } from 'xstate'\nimport { Static } from '@sinclair/typebox'\nimport { TProperty } from '@/Schema'\nimport { saveToSchema } from './actors/saveToSchema'\nimport { compareAndMarkDraft } from './actors/compareAndMarkDraft'\nimport { validateProperty } from './actors/validateProperty'\nimport { ValidationError } from '@/Schema/validation'\nimport { writeProcessMachine } from '@/services/write/writeProcessMachine'\n\nexport type ModelPropertyMachineContext = Static<typeof TProperty> & {\n // Store original values from the JSON schema file\n _originalValues?: Partial<Static<typeof TProperty>>\n // Track if this property has been edited\n _isEdited?: boolean\n // Reference to the Schema instance this property belongs to\n _schemaName?: string\n // Validation errors\n _validationErrors?: ValidationError[]\n writeProcess?: ActorRefFrom<typeof writeProcessMachine> | null\n // Property file ID (schemaFileId from JSON schema file) - used for lookups\n _propertyFileId?: string\n // Note: id field (from TProperty) is now the schemaFileId (string)\n // _dbId (from TProperty) stores the database integer ID\n // Destroy lifecycle (for destroy hooks)\n _destroyInProgress?: boolean\n _destroyError?: { message: string; name?: string } | null\n}\n\nexport const modelPropertyMachine = setup({\n types: {\n context: {} as ModelPropertyMachineContext,\n input: {} as ModelPropertyMachineContext,\n events: {} as\n | { type: 'updateContext'; [key: string]: any }\n | { type: 'initializeOriginalValues'; originalValues: Partial<Static<typeof TProperty>>; schemaName?: string; isEdited?: boolean }\n | { type: 'clearEdited' }\n | { type: 'setSchemaName'; schemaName: string }\n | { type: 'saveToSchema' }\n | { type: 'saveToSchemaSuccess' }\n | { type: 'saveToSchemaError'; error: Error }\n | { type: 'compareAndMarkDraftSuccess' }\n | { type: 'compareAndMarkDraftError' }\n | { type: 'validateProperty' }\n | { type: 'validationSuccess'; errors: ValidationError[] }\n | { type: 'validationError'; errors: ValidationError[] }\n | { type: 'requestWrite'; data: any }\n | { type: 'destroyStarted' }\n | { type: 'destroyDone' }\n | { type: 'destroyError'; error: unknown }\n | { type: 'clearDestroyError' },\n },\n actors: {\n saveToSchema,\n compareAndMarkDraft,\n validateProperty,\n writeProcessMachine,\n },\n guards: {\n isPropertyValid: ({ context }) => {\n const valid = !context._validationErrors || context._validationErrors.length === 0\n return valid\n },\n hasValidationErrors: ({ context }) => {\n return !!context._validationErrors && context._validationErrors.length > 0\n },\n },\n actions: {\n assignValidationErrors: assign(({ context, event }) => {\n if (event.type === 'validationError') {\n return {\n ...context,\n _validationErrors: event.errors,\n }\n }\n return context\n }),\n },\n}).createMachine({\n id: 'modelProperty',\n initial: 'idle',\n context: ({ input }) => {\n const context = input as ModelPropertyMachineContext\n return context\n },\n on: {\n updateContext: {\n actions: assign(({ context, event }) => {\n const newContext = Object.assign({}, context) as any\n\n // #region agent log\n if ((event as any).name !== undefined && (event as any).name !== context.name) {\n fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'modelPropertyMachine.ts:updateContext',message:'Name change via updateContext',data:{oldName:context.name,newName:(event as any).name,id:context.id,_propertyFileId:context._propertyFileId,hasOriginalValues:!!context._originalValues},timestamp:Date.now(),hypothesisId:'A'})}).catch(()=>{});\n }\n // #endregion\n\n // Check if this is only updating internal fields\n const onlyInternalFields = Object.keys(event).every((key: string) => {\n return key === 'type' || key.startsWith('_')\n })\n \n // Update the context with new values\n for (let i = 0; i < Object.keys(event).length; i++) {\n const key = Object.keys(event)[i] as string\n if (key === 'type') {\n continue\n }\n let value = (event as any)[key]\n // Convert null to undefined for optional fields (TypeBox validation expects undefined, not null)\n // This is especially important for refValueType, refModelId, etc.\n if (value === null && (key === 'refValueType' || key === 'refModelId' || key === 'ref' || key === 'refModelName')) {\n value = undefined\n }\n newContext[key] = value\n }\n\n // Preserve modelName and dataType from context or _originalValues so validation and savePropertyToDb\n // never run with missing required/needed fields (e.g. when a just-created property is renamed before\n // the full context is available from the creator).\n if (newContext.modelName === undefined && (context._originalValues as any)?.modelName !== undefined) {\n newContext.modelName = (context._originalValues as any).modelName\n }\n if (newContext.dataType === undefined && (context._originalValues as any)?.dataType !== undefined) {\n newContext.dataType = (context._originalValues as any).dataType\n }\n\n // Compare with original values and set _isEdited flag (only for non-internal updates)\n if (!onlyInternalFields && context._originalValues) {\n const hasChanges = Object.keys(event).some((key: string) => {\n if (key === 'type' || key.startsWith('_')) return false\n return newContext[key] !== (context._originalValues as any)?.[key]\n })\n newContext._isEdited = hasChanges\n }\n\n // Clear validation errors on context update (will be re-validated if needed)\n newContext._validationErrors = undefined\n\n // Convert null to undefined for optional fields (TypeBox validation expects undefined, not null)\n // This is especially important for refValueType, refModelId, etc.\n const optionalFields = ['refValueType', 'refModelId', 'ref', 'refModelName']\n for (const field of optionalFields) {\n if (newContext[field] === null) {\n newContext[field] = undefined\n }\n }\n\n return newContext\n }),\n // Only trigger validation and compareAndMarkDraft if we're updating non-internal fields\n guard: ({ event }: { event: any }) => {\n const shouldTransition = !Object.keys(event).every((key: string) => {\n return key === 'type' || key.startsWith('_')\n })\n return shouldTransition\n },\n target: '.validating',\n },\n validateProperty: {\n target: '.validating',\n },\n validationSuccess: {\n actions: assign(({ context, event }) => ({\n ...context,\n _validationErrors: [],\n })),\n },\n validationError: {\n actions: 'assignValidationErrors',\n // Note: State-specific transitions are handled in child states\n // This root handler ensures errors are always assigned to context\n },\n initializeOriginalValues: {\n actions: assign(({ context, event }) => ({\n ...context,\n _originalValues: event.originalValues,\n _schemaName: event.schemaName,\n _isEdited: event.isEdited ?? false,\n _validationErrors: undefined,\n })),\n },\n clearEdited: {\n actions: assign(({ context }) => ({\n ...context,\n _isEdited: false,\n _originalValues: { ...context } as Partial<Static<typeof TProperty>>,\n })),\n },\n setSchemaName: {\n actions: assign(({ context, event }) => ({\n ...context,\n _schemaName: event.schemaName,\n })),\n },\n destroyStarted: {\n actions: assign({ _destroyInProgress: true, _destroyError: null }),\n },\n destroyDone: {\n actions: assign({ _destroyInProgress: false }),\n },\n destroyError: {\n actions: assign(({ event }) => ({\n _destroyInProgress: false,\n _destroyError:\n event.error instanceof Error\n ? { message: event.error.message, name: event.error.name }\n : { message: String(event.error) },\n })),\n },\n clearDestroyError: {\n actions: assign({ _destroyError: null }),\n },\n },\n states: {\n idle: {\n on: {\n saveToSchema: { target: 'saveToSchema' },\n validateProperty: {\n target: 'validating',\n },\n requestWrite: {\n actions: ({ context, event }) => {\n if (context.writeProcess) {\n context.writeProcess.send({\n type: 'startWrite',\n data: event.data,\n })\n }\n },\n },\n },\n entry: assign({\n writeProcess: ({ spawn, context }) => {\n // Spawn writeProcess if we have id (schemaFileId)\n // New properties will have id generated\n const entityId = context.id\n if (!context.writeProcess && entityId) {\n return spawn(writeProcessMachine, {\n input: {\n entityType: 'modelProperty',\n entityId: String(entityId),\n entityData: context,\n },\n })\n }\n return context.writeProcess\n },\n }),\n },\n validating: {\n on: {\n saveToSchema: { target: 'saveToSchema' },\n validationSuccess: {\n target: 'compareAndMarkDraft',\n actions: assign(({ context }) => ({\n ...context,\n _validationErrors: [],\n })),\n },\n // validationError: Uses root handler for assignment, but needs state-specific transition\n validationError: {\n target: 'idle',\n actions: 'assignValidationErrors',\n },\n },\n invoke: {\n src: 'validateProperty',\n input: ({ context }) => ({ context }),\n },\n },\n compareAndMarkDraft: {\n on: {\n saveToSchema: { target: 'saveToSchema' },\n compareAndMarkDraftSuccess: {\n target: 'idle',\n },\n compareAndMarkDraftError: {\n target: 'idle',\n },\n },\n invoke: {\n src: 'compareAndMarkDraft',\n input: ({ context }) => ({ context }),\n },\n },\n saveToSchema: {\n always: {\n guard: 'isPropertyValid',\n target: '.saving',\n },\n initial: 'saving',\n on: {\n // Apply updateContext but do not re-invoke saveToSchema actor (avoids infinite loop).\n // Context is updated; in-flight save completes with original context.\n updateContext: [\n {\n guard: ({ context, event }) => {\n const onlyInternal = Object.keys(event).every((k: string) => k === 'type' || k.startsWith('_'))\n return !onlyInternal && event.name !== undefined && event.name !== context.name\n },\n actions: assign(({ context, event }) => {\n const newContext = Object.assign({}, context) as any\n const onlyInternalFields = Object.keys(event).every((key: string) => key === 'type' || key.startsWith('_'))\n for (const key of Object.keys(event) as string[]) {\n if (key === 'type') continue\n let value = (event as any)[key]\n if (value === null && ['refValueType', 'refModelId', 'ref', 'refModelName'].includes(key)) value = undefined\n newContext[key] = value\n }\n if (newContext.modelName === undefined && (context._originalValues as any)?.modelName !== undefined) {\n newContext.modelName = (context._originalValues as any).modelName\n }\n if (newContext.dataType === undefined && (context._originalValues as any)?.dataType !== undefined) {\n newContext.dataType = (context._originalValues as any).dataType\n }\n if (!onlyInternalFields && context._originalValues) {\n const hasChanges = Object.keys(event).some((key: string) => {\n if (key === 'type' || key.startsWith('_')) return false\n return newContext[key] !== (context._originalValues as any)?.[key]\n })\n newContext._isEdited = hasChanges\n }\n newContext._validationErrors = undefined\n return newContext\n }),\n },\n {\n actions: assign(({ context, event }) => {\n const newContext = Object.assign({}, context) as any\n const onlyInternalFields = Object.keys(event).every((key: string) => key === 'type' || key.startsWith('_'))\n for (const key of Object.keys(event) as string[]) {\n if (key === 'type') continue\n let value = (event as any)[key]\n if (value === null && ['refValueType', 'refModelId', 'ref', 'refModelName'].includes(key)) value = undefined\n newContext[key] = value\n }\n if (newContext.modelName === undefined && (context._originalValues as any)?.modelName !== undefined) {\n newContext.modelName = (context._originalValues as any).modelName\n }\n if (newContext.dataType === undefined && (context._originalValues as any)?.dataType !== undefined) {\n newContext.dataType = (context._originalValues as any).dataType\n }\n if (!onlyInternalFields && context._originalValues) {\n const hasChanges = Object.keys(event).some((key: string) => {\n if (key === 'type' || key.startsWith('_')) return false\n return newContext[key] !== (context._originalValues as any)?.[key]\n })\n newContext._isEdited = hasChanges\n }\n newContext._validationErrors = undefined\n return newContext\n }),\n },\n ],\n // validationError: Uses root handler for assignment, but needs state-specific transition\n validationError: {\n target: 'idle',\n actions: 'assignValidationErrors',\n },\n },\n states: {\n saving: {\n on: {\n saveToSchemaSuccess: {\n target: '#modelProperty.idle',\n },\n saveToSchemaError: {\n target: '#modelProperty.idle',\n },\n },\n invoke: {\n src: 'saveToSchema',\n input: ({ context }) => ({ context }),\n },\n },\n },\n },\n },\n})\n","import { models as modelsTable, properties as propertiesTable } from '@/seedSchema/ModelSchema'\nimport { BaseDb } from '@/db/Db/BaseDb'\nimport { eq } from 'drizzle-orm'\n\nexport type ModelPropertyDataRow = {\n id: number\n name: string\n dataType: string\n modelId: number\n refModelId: number | null\n refValueType: string | null\n schemaFileId: string | null\n isEdited: number | null\n}\n\ntype GetModelPropertiesData = (\n modelFileId: string,\n) => Promise<ModelPropertyDataRow[]>\n\n/**\n * Returns property rows for a model identified by modelFileId (model's schemaFileId).\n * Resolves modelFileId -> modelId via models table, then selects all properties where modelId = ?.\n * Each row includes schemaFileId for use with ModelProperty.createById(schemaFileId).\n */\nexport const getModelPropertiesData: GetModelPropertiesData = async (\n modelFileId: string,\n): Promise<ModelPropertyDataRow[]> => {\n const appDb = BaseDb.getAppDb()\n if (!appDb || !modelFileId) {\n return []\n }\n\n const modelRows = await appDb\n .select({ id: modelsTable.id })\n .from(modelsTable)\n .where(eq(modelsTable.schemaFileId, modelFileId))\n .limit(1)\n\n if (modelRows.length === 0) {\n return []\n }\n\n const modelId = modelRows[0].id\n\n const rows = await appDb\n .select()\n .from(propertiesTable)\n .where(eq(propertiesTable.modelId, modelId))\n\n return rows as ModelPropertyDataRow[]\n}\n","import { ActorRefFrom, createActor, SnapshotFrom } from 'xstate'\nimport { Static } from '@sinclair/typebox'\nimport { ModelPropertyDataTypes, TProperty, normalizeDataType } from '@/Schema'\nimport { modelPropertyMachine, ModelPropertyMachineContext } from './service/modelPropertyMachine'\nimport { StorageType } from '@/types'\nimport type { CreateWaitOptions } from '@/types'\nimport { BaseFileManager, generateId } from '@/helpers'\nimport { BaseDb } from '@/db/Db/BaseDb'\nimport { getModelPropertiesData } from '@/db/read/getModelPropertiesData'\nimport { getModelId, getModelIdByFileId } from '@/helpers/db'\nimport { modelPropertiesToObject } from '@/helpers/model'\nimport { Model } from '@/Model/Model'\nimport { Schema } from '@/Schema/Schema'\nimport { properties as propertiesTable, models as modelsTable } from '@/seedSchema/ModelSchema'\nimport { schemas } from '@/seedSchema/SchemaSchema'\nimport { getSchemaNameFromModel } from './service/actors/saveToSchema'\nimport { modelSchemas } from '@/seedSchema/ModelSchemaSchema'\nimport { and, eq } from 'drizzle-orm'\nimport { createReactiveProxy } from '@/helpers/reactiveProxy'\nimport { waitForEntityIdle } from '@/helpers/waitForEntityIdle'\nimport { findEntity } from '@/helpers/entity/entityFind'\nimport { unloadEntity } from '@/helpers/entity/entityUnload'\nimport { forceRemoveFromCaches, runDestroyLifecycle } from '@/helpers/entity/entityDestroy'\nimport debug from 'debug'\n\nconst logger = debug('seedSdk:modelProperty:ModelProperty')\n\ntype ModelPropertyService = ActorRefFrom<typeof modelPropertyMachine>\ntype ModelPropertySnapshot = SnapshotFrom<typeof modelPropertyMachine>\n\n// Define the property keys from TProperty\nconst TPropertyKeys = [\n 'id',\n 'name',\n 'dataType',\n 'ref',\n 'modelId',\n 'refModelId',\n 'refValueType',\n 'storageType',\n 'localStorageDir',\n 'filenameSuffix',\n 'modelName',\n 'refModelName',\n] as const\n\nexport class ModelProperty {\n protected static instanceCache: Map<\n string,\n { instance: ModelProperty; refCount: number }\n > = new Map()\n \n // Pending writes tracking\n private static pendingWrites = new Map<string, {\n propertyFileId: string\n modelId: number\n status: 'pending' | 'writing' | 'success' | 'error'\n timestamp: number\n }>()\n \n protected readonly _service: ModelPropertyService\n\n name?: string\n dataType?: ModelPropertyDataTypes\n ref?: string\n modelId?: number\n modelName?: string\n refModelId?: number\n refModelName?: string\n refValueType?: ModelPropertyDataTypes\n storageType?: StorageType\n localStorageDir?: string\n filenameSuffix?: string\n\n constructor(property: Static<typeof TProperty>) {\n // id is now the schemaFileId (string), _dbId is the database integer ID\n // Preserve _propertyFileId if it exists in the property object (from getPropertySchema)\n // Convert null to undefined for optional fields (TypeBox validation expects undefined, not null)\n const serviceInput: ModelPropertyMachineContext = {\n ...property,\n _propertyFileId: (property as any)._propertyFileId || property.id,\n refValueType: property.refValueType ?? undefined,\n refModelId: property.refModelId ?? undefined,\n ref: property.ref ?? undefined,\n refModelName: property.refModelName ?? undefined,\n }\n\n this._service = createActor(modelPropertyMachine, {\n input: serviceInput,\n })\n\n this._service.start()\n\n // Initialize original values from the input property\n this._initializeOriginalValues(property)\n\n // Note: Property getters/setters are now handled by the Proxy in create()\n }\n\n /**\n * Initialize original values and schema name for tracking changes\n * This is called asynchronously after construction\n * If the property was loaded from the database and differs from the schema file,\n * it will be marked as edited.\n */\n private _initializeOriginalValues(property: Static<typeof TProperty>): void {\n // Resolve refModelId if ref/refModelName is provided but refModelId is missing\n const refModelName = property.refModelName || property.ref\n if (refModelName && !property.refModelId) {\n // Resolve refModelId asynchronously and update context\n this._resolveRefModelId(refModelName).then((refModelId) => {\n if (refModelId) {\n // Update the context with the resolved refModelId\n this._service.send({\n type: 'updateContext',\n refModelId,\n })\n }\n }).catch(() => {\n // Ignore errors - model might not exist yet\n })\n }\n\n // Get schema file values to use as \"original\" values\n // This allows us to detect if the property was edited (DB value differs from schema file)\n this._getSchemaFileValues(property).then((schemaFileValues) => {\n // Use schema file values as original (not the current property values)\n // This way, if current values differ from schema file, _isEdited will be true\n const originalValues: Partial<Static<typeof TProperty>> = schemaFileValues || {}\n \n // Compare current property values with schema file values to determine if edited\n // Only compare schema-relevant fields, not database-specific fields like id, modelId\n let isEdited = false\n if (schemaFileValues) {\n // Fields that are schema-relevant and should be compared\n const schemaRelevantFields: (keyof Static<typeof TProperty>)[] = [\n 'dataType',\n 'ref',\n 'refModelName',\n 'refValueType',\n 'storageType',\n 'localStorageDir',\n 'filenameSuffix',\n ]\n \n // Check if any schema-relevant field differs between current property and schema file\n isEdited = schemaRelevantFields.some((key) => {\n const currentValue = (property as any)[key]\n const originalValue = (schemaFileValues as any)[key]\n \n // Handle ref fields - compare by name\n if (key === 'ref' || key === 'refModelName') {\n const currentRef = property.refModelName || property.ref\n const originalRef = schemaFileValues.refModelName || schemaFileValues.ref\n // Both undefined/null means no ref, so they're the same\n if (!currentRef && !originalRef) return false\n return currentRef !== originalRef\n }\n \n // For other fields, compare values (handling undefined/null)\n if (currentValue === undefined && originalValue === undefined) return false\n if (currentValue === null && originalValue === null) return false\n if (currentValue === undefined && originalValue === null) return false\n if (currentValue === null && originalValue === undefined) return false\n \n return currentValue !== originalValue\n })\n } else {\n // No schema file values found - this is a runtime-created property\n // Use current property as original, but mark as edited since it hasn't been exported to file\n TPropertyKeys.forEach((key) => {\n if (property[key] !== undefined) {\n (originalValues as any)[key] = property[key]\n }\n })\n // For runtime-created properties, set isEdited = true initially\n isEdited = true\n }\n\n // Initialize with original values, including isEdited flag\n // Load isEdited from database if property exists in DB (async, fire-and-forget)\n this._loadIsEditedFromDb(property, isEdited).then((isEditedFromDb: boolean) => {\n this._service.send({\n type: 'initializeOriginalValues',\n originalValues,\n schemaName: undefined, // Will be set later if needed\n isEdited: isEditedFromDb,\n })\n }).catch(() => {\n // If we can't load from DB, use computed isEdited value\n this._service.send({\n type: 'initializeOriginalValues',\n originalValues,\n schemaName: undefined, // Will be set later if needed\n isEdited,\n })\n })\n }).catch(() => {\n // If we can't get schema file values, use current property as original\n const originalValues: Partial<Static<typeof TProperty>> = {}\n TPropertyKeys.forEach((key) => {\n if (property[key] !== undefined) {\n (originalValues as any)[key] = property[key]\n }\n })\n\n this._service.send({\n type: 'initializeOriginalValues',\n originalValues,\n schemaName: undefined,\n })\n })\n\n // Get schema name from model asynchronously (fire-and-forget)\n if (property.modelName) {\n this._setSchemaName(property.modelName).catch(() => {\n // If we can't get schema name, that's okay - it will be set later if needed\n })\n }\n }\n\n /**\n * Load isEdited flag from database if property exists in DB\n * @param property - The property data\n * @param fallbackIsEdited - Fallback value if property doesn't exist in DB\n * @returns The isEdited flag from database or fallback value\n */\n private async _loadIsEditedFromDb(\n property: Static<typeof TProperty>,\n fallbackIsEdited: boolean,\n ): Promise<boolean> {\n if (!property.modelName || !property.name) {\n return fallbackIsEdited\n }\n\n try {\n const db = BaseDb.getAppDb()\n if (!db) {\n return fallbackIsEdited\n }\n\n // Find model by name\n const modelRecords = await db\n .select({ id: modelsTable.id })\n .from(modelsTable)\n .where(eq(modelsTable.name, property.modelName))\n .limit(1)\n \n if (modelRecords.length === 0) {\n return fallbackIsEdited\n }\n\n // Find property by name and modelId\n const propertyRecords = await db\n .select({ isEdited: propertiesTable.isEdited })\n .from(propertiesTable)\n .where(\n and(\n eq(propertiesTable.name, property.name),\n eq(propertiesTable.modelId, modelRecords[0].id)\n )\n )\n .limit(1)\n \n if (propertyRecords.length > 0) {\n return propertyRecords[0].isEdited ?? false\n }\n } catch (error) {\n // Ignore errors - use fallback value\n }\n\n return fallbackIsEdited\n }\n\n /**\n * Resolve refModelId from refModelName by querying the database\n * @param refModelName - The name of the referenced model\n * @returns The database ID of the referenced model, or undefined if not found\n */\n private async _resolveRefModelId(refModelName: string): Promise<number | undefined> {\n if (!refModelName) {\n return undefined\n }\n\n try {\n const db = BaseDb.getAppDb()\n if (!db) {\n return undefined\n }\n\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, refModelName))\n .limit(1)\n \n if (refModelRecords.length > 0 && refModelRecords[0].id) {\n return refModelRecords[0].id\n }\n } catch (error) {\n // Ignore errors - model might not exist yet or database not available\n logger(`Error resolving refModelId for model \"${refModelName}\":`, error)\n }\n\n return undefined\n }\n\n /**\n * Get schema file values for this property to use as \"original\" values\n * This allows comparison with database values to detect edits\n */\n private async _getSchemaFileValues(\n property: Static<typeof TProperty>,\n ): Promise<Partial<Static<typeof TProperty>> | undefined> {\n if (!property.modelName || !property.name) {\n return undefined\n }\n\n try {\n const model = await Model.getByNameAsync(property.modelName)\n \n if (!model || !model.properties || model.properties.length === 0) {\n return undefined\n }\n\n const schema = modelPropertiesToObject(model.properties)\n // Get the schema file value for this property\n const schemaFileValue = schema[property.name]\n if (!schemaFileValue) {\n return undefined\n }\n\n // Return schema file values as original values\n const originalValues: Partial<Static<typeof TProperty>> = {\n name: property.name,\n modelName: property.modelName,\n dataType: schemaFileValue.dataType,\n storageType: schemaFileValue.storageType,\n localStorageDir: schemaFileValue.localStorageDir,\n filenameSuffix: schemaFileValue.filenameSuffix,\n }\n\n // Handle ref fields\n if (schemaFileValue.ref) {\n originalValues.ref = schemaFileValue.ref\n originalValues.refModelName = schemaFileValue.ref\n // Try to get refModelId from database\n const refModelId = await this._resolveRefModelId(schemaFileValue.ref)\n if (refModelId) {\n originalValues.refModelId = refModelId\n }\n }\n\n if (schemaFileValue.refValueType) {\n originalValues.refValueType = schemaFileValue.refValueType\n }\n\n return originalValues\n } catch (error) {\n return undefined\n }\n }\n\n /**\n * Set the schema name for this property by looking it up from the model\n * Tries database first (more reliable), then falls back to schema files\n */\n private async _setSchemaName(modelName: string): Promise<void> {\n try {\n let schemaName: string | undefined\n\n // Try to get schema name from database first (more reliable)\n if (this.modelId) {\n try {\n const db = BaseDb.getAppDb()\n if (db) {\n const modelSchemaRecords = await db\n .select({\n schemaName: schemas.name,\n })\n .from(modelSchemas)\n .innerJoin(schemas, eq(modelSchemas.schemaId, schemas.id))\n .innerJoin(modelsTable, eq(modelSchemas.modelId, modelsTable.id))\n .where(eq(modelsTable.id, this.modelId))\n .limit(1)\n\n if (modelSchemaRecords.length > 0) {\n schemaName = modelSchemaRecords[0].schemaName\n }\n }\n } catch (error) {\n // Database lookup failed, continue to file-based lookup\n }\n }\n\n // Fall back to schema file lookup if database didn't work\n if (!schemaName) {\n schemaName = await getSchemaNameFromModel(modelName)\n }\n\n if (schemaName) {\n // Update the context with the schema name using dedicated event\n this._service.send({\n type: 'setSchemaName',\n schemaName,\n })\n }\n } catch (error) {\n // If we can't get schema name, that's okay - it will be set later if needed\n }\n }\n\n /**\n * Resolve schema name from DB when _schemaName is missing (e.g. destroy ran before _setSchemaName finished).\n * Uses context.id (schemaFileId) and context.modelId to query properties → model_schemas → schemas.\n */\n private async _resolveSchemaNameForDestroy(\n db: NonNullable<ReturnType<typeof BaseDb.getAppDb>>,\n context: ModelPropertyMachineContext,\n ): Promise<string | undefined> {\n try {\n let modelId = context.modelId\n const schemaFileId = context.id ?? context._propertyFileId\n\n // If we don't have modelId, get it from the property row by schemaFileId\n if (modelId == null && schemaFileId) {\n const propRows = await db\n .select({ modelId: propertiesTable.modelId })\n .from(propertiesTable)\n .where(eq(propertiesTable.schemaFileId, schemaFileId))\n .limit(1)\n if (propRows.length > 0 && propRows[0].modelId != null) {\n modelId = propRows[0].modelId\n }\n }\n\n if (modelId == null) return undefined\n\n // Resolve modelFileId (string) to database ID (number) if needed - modelSchemas.modelId expects number\n const modelIdNum: number =\n typeof modelId === 'string' ? await getModelIdByFileId(modelId) : modelId\n\n const modelSchemaRecords = await db\n .select({ schemaName: schemas.name })\n .from(modelSchemas)\n .innerJoin(schemas, eq(modelSchemas.schemaId, schemas.id))\n .where(eq(modelSchemas.modelId, modelIdNum))\n .limit(1)\n\n return modelSchemaRecords.length > 0 ? modelSchemaRecords[0].schemaName ?? undefined : undefined\n } catch {\n return undefined\n }\n }\n\n /**\n * Manually set the schema name for this property\n * Useful when you know the schema name from context (e.g., when working with Schema instances)\n */\n setSchemaName(schemaName: string): void {\n this._service.send({\n type: 'setSchemaName',\n schemaName,\n })\n }\n\n static create(\n property: Static<typeof TProperty>,\n options?: { waitForReady?: false; schemaName?: string },\n ): ModelProperty\n static create(\n property: Static<typeof TProperty>,\n options?: { waitForReady?: true; readyTimeout?: number; schemaName?: string },\n ): Promise<ModelProperty>\n static create(\n property: Static<typeof TProperty>,\n options?: CreateWaitOptions & { schemaName?: string },\n ): ModelProperty | Promise<ModelProperty> {\n if (!property) {\n throw new Error('Property is required')\n }\n\n const waitForReady = options?.waitForReady !== false\n const readyTimeout = options?.readyTimeout ?? 5000\n const schemaName = options?.schemaName\n\n // Handle 'type' field from JSON schema format - convert to 'dataType'\n // Normalize to PascalCase so lowercase values from JSON (e.g. 'text') work\n const propertyWithId = { ...property }\n const rawType = propertyWithId.dataType ?? (propertyWithId as any).type\n if (rawType) {\n propertyWithId.dataType = normalizeDataType(rawType) as ModelPropertyDataTypes\n }\n \n // Ensure id (schemaFileId) is set correctly\n // Priority: _propertyFileId > id (if string) > generate new\n // If id is a number (old format), use _propertyFileId instead\n if (typeof propertyWithId.id === 'number') {\n // id is a database integer ID, not schemaFileId - use _propertyFileId if available\n if ((propertyWithId as any)._propertyFileId) {\n propertyWithId.id = (propertyWithId as any)._propertyFileId\n } else {\n // Fallback: generate new schemaFileId (shouldn't happen, but safety)\n propertyWithId.id = generateId()\n logger(`ModelProperty.create: id was a number, generated new schemaFileId \"${propertyWithId.id}\" for property \"${property.name}\"`)\n }\n } else if (!propertyWithId.id && (propertyWithId as any)._propertyFileId) {\n // id is not set but _propertyFileId is available - use it\n propertyWithId.id = (propertyWithId as any)._propertyFileId\n } else if (!propertyWithId.id) {\n // Generate id (schemaFileId) if not provided (for new properties)\n // This ensures new properties can trigger write process\n propertyWithId.id = generateId()\n logger(`ModelProperty.create: Generated new id (schemaFileId) \"${propertyWithId.id}\" for property \"${property.name}\"`)\n }\n\n // Create cache key from modelName and name, or use id\n const cacheKey = propertyWithId.modelName && propertyWithId.name\n ? `${propertyWithId.modelName}:${propertyWithId.name}`\n : propertyWithId.id\n ? `id:${propertyWithId.id}`\n : propertyWithId.name || 'unnamed'\n\n // Check if instance exists in cache\n if (this.instanceCache.has(cacheKey)) {\n const { instance, refCount } = this.instanceCache.get(cacheKey)!\n const cachedContext = instance._getSnapshotContext()\n \n // Update cached instance if new property data has fields that the cached instance doesn't have\n // This handles cases where the property was created without ref initially, but now we have ref from schema\n const needsUpdate: any = {}\n if (propertyWithId.ref && !cachedContext.ref) {\n needsUpdate.ref = propertyWithId.ref\n }\n if (propertyWithId.refModelName && !cachedContext.refModelName) {\n needsUpdate.refModelName = propertyWithId.refModelName\n }\n if (propertyWithId.refModelId && !cachedContext.refModelId) {\n needsUpdate.refModelId = propertyWithId.refModelId\n }\n \n if (Object.keys(needsUpdate).length > 0) {\n instance._service.send({\n type: 'updateContext',\n ...needsUpdate,\n })\n }\n \n this.instanceCache.set(cacheKey, {\n instance,\n refCount: refCount + 1,\n })\n if (!waitForReady) return instance\n return waitForEntityIdle(instance, { timeout: readyTimeout }).then(\n () => instance,\n )\n }\n\n const newInstance = new this(propertyWithId)\n \n // Set schema name before async operations so getModelId can resolve the correct model\n if (schemaName) {\n newInstance._service.send({\n type: 'setSchemaName',\n schemaName,\n })\n }\n \n // Wrap instance in Proxy for reactive property access\n const proxiedInstance = createReactiveProxy<ModelProperty>({\n instance: newInstance,\n service: newInstance._service,\n trackedProperties: TPropertyKeys,\n getContext: (instance) => {\n const context = instance._getSnapshotContext()\n return context\n },\n sendUpdate: (instance, prop: string, value: any) => {\n const currentContext = instance._getSnapshotContext()\n if ((currentContext as Record<string, unknown>)[prop] === value) return // No-op, avoid triggering machine\n instance._service.send({\n type: 'updateContext',\n [prop]: value,\n })\n },\n })\n \n this.instanceCache.set(cacheKey, {\n instance: proxiedInstance,\n refCount: 1,\n })\n \n // Trigger write process if property has modelId (or modelName) and id (schemaFileId)\n // Wait for service to be ready (idle state) and have writeProcess spawned\n const propertyFileId = propertyWithId.id // id is now the schemaFileId (string)\n const hasModelId = propertyWithId.modelId || propertyWithId.modelName\n \n if (hasModelId && propertyFileId) {\n // Wait for writeProcess to be spawned (it's spawned in idle state entry action)\n // Retry a few times if writeProcess isn't available yet\n let retries = 0\n const maxRetries = 10\n const checkAndSend = async () => {\n const service = proxiedInstance.getService()\n const snapshot = service.getSnapshot()\n \n if (snapshot.value === 'idle' && snapshot.context.writeProcess) {\n const writeProcess = snapshot.context.writeProcess\n \n // Resolve dbModelId - convert from string (modelFileId) to number (database ID) if needed\n let resolvedModelId: number | undefined = undefined\n \n if (propertyWithId.modelId) {\n if (typeof propertyWithId.modelId === 'number') {\n resolvedModelId = propertyWithId.modelId\n } else if (typeof propertyWithId.modelId === 'string') {\n // modelId is a string (modelFileId), need to convert to database ID\n try {\n resolvedModelId = await getModelIdByFileId(propertyWithId.modelId)\n logger(`Converted modelFileId \"${propertyWithId.modelId}\" to database modelId: ${resolvedModelId}`)\n } catch (error) {\n logger(`Failed to convert modelFileId \"${propertyWithId.modelId}\" to database ID: ${error}`)\n console.error(`[ModelProperty.create] Failed to convert modelFileId: ${error}`)\n }\n }\n }\n \n // If we still don't have a modelId, try to resolve it from modelName\n if (!resolvedModelId && propertyWithId.modelName) {\n try {\n // Get schemaName from context if available\n const schemaName = snapshot.context._schemaName\n resolvedModelId = await getModelId(propertyWithId.modelName, schemaName)\n logger(`Resolved modelId for model \"${propertyWithId.modelName}\": ${resolvedModelId}`)\n } catch (error) {\n logger(`Failed to resolve modelId for model \"${propertyWithId.modelName}\": ${error}`)\n console.error(`[ModelProperty.create] Failed to resolve modelId: ${error}`)\n }\n }\n \n if (!resolvedModelId) {\n logger(`ERROR: Cannot write property \"${property.name}\" - no modelId available`)\n console.error(`[ModelProperty.create] ERROR: Cannot write property \"${property.name}\" - no modelId available. modelId: ${propertyWithId.modelId}, modelName: ${propertyWithId.modelName}`)\n // Don't clear pending write here - it might resolve later\n return\n }\n \n // Track pending write now that we have the resolved modelId\n this.trackPendingWrite(propertyFileId, resolvedModelId)\n \n logger(`Triggering write process for property \"${property.name}\" (modelId: ${resolvedModelId}, propertyFileId: ${propertyFileId})`)\n \n // Check current write state\n const currentWriteState = writeProcess.getSnapshot()\n \n if (currentWriteState.value === 'success') {\n // Write already succeeded, clear pending write immediately\n this.clearPendingWrite(propertyFileId, 'success')\n } else {\n // Set up subscription to catch future state changes\n const writeSubscription = writeProcess.subscribe((writeSnapshot) => {\n if (writeSnapshot.value === 'success') {\n writeSubscription.unsubscribe()\n logger(`[writeProcess subscription] Write succeeded for property \"${property.name}\" (propertyFileId: ${propertyFileId})`)\n // Clear pending write on success\n this.clearPendingWrite(propertyFileId, 'success')\n } else if (writeSnapshot.value === 'error') {\n writeSubscription.unsubscribe()\n const errorContext = writeSnapshot.context\n logger(`Write process failed for property \"${property.name}\" (propertyFileId: ${propertyFileId}): ${errorContext.error?.message || 'Unknown error'}`)\n logger(`Write process error details:`, errorContext.error)\n // Mark pending write as error\n this.clearPendingWrite(propertyFileId, 'error')\n }\n })\n }\n \n const propertyData = {\n modelId: resolvedModelId,\n name: property.name!,\n dataType: property.dataType!,\n refModelId: property.refModelId,\n refValueType: property.refValueType,\n storageType: property.storageType,\n localStorageDir: property.localStorageDir,\n filenameSuffix: property.filenameSuffix,\n }\n \n service.send({\n type: 'requestWrite',\n data: propertyData,\n })\n } else if (retries < maxRetries) {\n retries++\n setTimeout(checkAndSend, 50) // Retry after 50ms\n } else {\n logger(`ERROR: writeProcess not available after ${maxRetries} retries for property \"${property.name}\" (propertyFileId: ${propertyFileId})`)\n console.error(`[ModelProperty.create] ERROR: writeProcess not available after ${maxRetries} retries for property \"${property.name}\" (propertyFileId: ${propertyFileId})`)\n // Mark as error if we couldn't even start the write process\n this.clearPendingWrite(propertyFileId, 'error')\n }\n }\n \n // Start checking after a short delay to allow state machine to initialize\n setTimeout(checkAndSend, 0)\n }\n \n if (!waitForReady) return proxiedInstance\n return waitForEntityIdle(proxiedInstance, { timeout: readyTimeout }).then(\n () => proxiedInstance,\n )\n }\n\n /**\n * Get ModelProperty instance by propertyFileId from static cache\n */\n static getById(propertyFileId: string): ModelProperty | undefined {\n if (!propertyFileId) return undefined\n \n // Search through cache to find by propertyFileId\n // Cache key might be \"modelName:propertyName\" or \"id:propertyId\"\n for (const [cacheKey, { instance }] of this.instanceCache.entries()) {\n const context = instance._getSnapshotContext()\n // id is now the schemaFileId (string)\n if (context.id === propertyFileId) {\n return instance\n }\n }\n \n return undefined\n }\n\n /**\n * Create or get ModelProperty instance by propertyFileId\n * Queries the database to find the property if not cached\n */\n static async createById(propertyFileId: string): Promise<ModelProperty | undefined> {\n if (!propertyFileId) {\n return undefined\n }\n\n // First, check if we have an instance cached\n const cachedInstance = this.getById(propertyFileId)\n if (cachedInstance) {\n return cachedInstance\n }\n\n // Query database to get property data from ID\n const db = BaseDb.getAppDb()\n if (!db) {\n return undefined\n }\n\n const testRecords = await db\n .select()\n .from(propertiesTable)\n .limit(100)\n\n const propertyRecords = await db\n .select()\n .from(propertiesTable)\n .where(eq(propertiesTable.schemaFileId, propertyFileId))\n .limit(1)\n\n if (propertyRecords.length === 0) {\n return undefined\n }\n\n const propertyRecord = propertyRecords[0]\n\n // Get model name\n const modelRecords = await db\n .select({ name: modelsTable.name })\n .from(modelsTable)\n .where(eq(modelsTable.id, propertyRecord.modelId))\n .limit(1)\n\n if (modelRecords.length === 0) {\n return undefined\n }\n\n const modelName = modelRecords[0].name\n\n // Build property data\n // id is now the schemaFileId (string), _dbId is the database integer ID\n // #region agent log\n if (typeof fetch === 'function') { fetch('http://127.0.0.1:7242/ingest/0978b378-ebae-46bf-8fd3-134ef2e16cdd',{method:'POST',headers:{'Content-Type':'application/json','X-Debug-Session-Id':'9ee076'},body:JSON.stringify({sessionId:'9ee076',location:'ModelProperty.ts:createById',message:'createById loading from DB',data:{propertyFileId,name:propertyRecord.name,modelName},timestamp:Date.now(),hypothesisId:'E'})}).catch(()=>{}); }\n // #endregion\n\n const propertyData: Static<typeof TProperty> = {\n id: propertyFileId, // schemaFileId (string) - public ID\n _dbId: propertyRecord.id ?? undefined, // Database integer ID - internal only\n name: propertyRecord.name,\n dataType: propertyRecord.dataType as ModelPropertyDataTypes,\n modelId: propertyRecord.modelId,\n modelName,\n refModelId: propertyRecord.refModelId || undefined,\n refValueType: propertyRecord.refValueType ? (propertyRecord.refValueType as ModelPropertyDataTypes) : undefined,\n }\n \n // Load isEdited from database\n const isEditedFromDb = propertyRecord.isEdited ?? false\n\n // Get ref model name if applicable\n if (propertyRecord.refModelId) {\n const refModelRecords = await db\n .select({ name: modelsTable.name })\n .from(modelsTable)\n .where(eq(modelsTable.id, propertyRecord.refModelId))\n .limit(1)\n\n if (refModelRecords.length > 0) {\n propertyData.refModelName = refModelRecords[0].name\n propertyData.ref = refModelRecords[0].name\n }\n }\n\n // Create ModelProperty instance (sync for createById so we can send updateContext)\n const instance = this.create(propertyData, { waitForReady: false })\n \n // Set isEdited from database after creation\n if (isEditedFromDb) {\n instance._service.send({\n type: 'updateContext',\n _isEdited: true,\n })\n }\n \n return instance\n }\n\n /**\n * Find ModelProperty instance by propertyFileId\n * Waits for the property to be fully loaded (idle state) by default\n * @param options - Find options including propertyFileId and wait configuration\n * @returns ModelProperty instance if found, undefined otherwise\n */\n static async find({\n propertyFileId,\n waitForReady = true,\n readyTimeout = 5000,\n }: {\n propertyFileId: string\n waitForReady?: boolean\n readyTimeout?: number\n }): Promise<ModelProperty | undefined> {\n if (!propertyFileId) {\n return undefined\n }\n\n return await findEntity<ModelProperty>(\n {\n getById: (id) => ModelProperty.getById(id),\n createById: (id) => ModelProperty.createById(id),\n },\n { id: propertyFileId },\n {\n waitForReady,\n readyTimeout,\n }\n )\n }\n\n /**\n * Get all ModelProperty instances for a model.\n * Loads property rows from DB for the given modelFileId, creates instances via createById, optionally waits for idle.\n */\n static async all(\n modelFileId: string,\n options?: { waitForReady?: boolean; readyTimeout?: number },\n ): Promise<ModelProperty[]> {\n const { waitForReady = false, readyTimeout = 5000 } = options ?? {}\n if (!modelFileId) {\n return []\n }\n\n const rows = await getModelPropertiesData(modelFileId)\n const instances: ModelProperty[] = []\n\n for (const row of rows) {\n if (row.schemaFileId) {\n const instance = await this.createById(row.schemaFileId)\n if (instance) {\n instances.push(instance)\n }\n }\n }\n\n if (waitForReady && instances.length > 0) {\n await Promise.all(\n instances.map((p) =>\n waitForEntityIdle(p as Parameters<typeof waitForEntityIdle>[0], {\n timeout: readyTimeout,\n }),\n ),\n )\n }\n\n return instances\n }\n\n /**\n * Track a pending write for a property\n */\n static trackPendingWrite(propertyFileId: string, modelId: number): void {\n this.pendingWrites.set(propertyFileId, {\n propertyFileId,\n modelId,\n status: 'pending',\n timestamp: Date.now(),\n })\n }\n\n /**\n * Clear or update pending write status\n */\n static clearPendingWrite(propertyFileId: string, status: 'success' | 'error' = 'success'): void {\n const write = this.pendingWrites.get(propertyFileId)\n if (write) {\n if (status === 'success') {\n // Remove successful writes from pendingWrites\n this.pendingWrites.delete(propertyFileId)\n logger(`Cleared pending write for property \"${propertyFileId}\" (status: success)`)\n } else {\n // Update status to error but keep in map (for debugging/retry purposes)\n write.status = 'error'\n this.pendingWrites.set(propertyFileId, write)\n logger(`Marked pending write as error for property \"${propertyFileId}\"`)\n }\n }\n }\n\n /**\n * Get all pending property IDs for a model\n */\n static getPendingPropertyIds(modelId: number): string[] {\n return Array.from(this.pendingWrites.entries())\n .filter(([_, write]) => write.modelId === modelId && write.status !== 'error')\n .map(([propertyFileId]) => propertyFileId)\n }\n\n /**\n * Get modelId for a property that has a pending write (row may not be in DB yet).\n * Used to resolve modelName when validating a just-created property rename.\n */\n static getPendingModelId(propertyFileId: string): number | undefined {\n return this.pendingWrites.get(propertyFileId)?.modelId\n }\n\n getService(): ModelPropertyService {\n return this._service\n }\n\n private _getSnapshot(): ModelPropertySnapshot {\n return this._service.getSnapshot() as ModelPropertySnapshot\n }\n\n public _getSnapshotContext(): ModelPropertyMachineContext {\n return this._getSnapshot().context\n }\n\n get path() {\n const workingDir = BaseFileManager.getWorkingDir()\n if (!this.localStorageDir || !this.name || !this.filenameSuffix) {\n return undefined\n }\n return `${workingDir}/${this.localStorageDir}/${this.name}${this.filenameSuffix || ''}`\n }\n\n get status() {\n return this._getSnapshot().value\n }\n\n get isEdited() {\n const context = this._getSnapshotContext()\n // First check in-memory state\n if (context._isEdited !== undefined) {\n return context._isEdited\n }\n // Fall back to reading from database if we have _dbId\n if (context._dbId) {\n // Load from database asynchronously (fire-and-forget for now)\n // For synchronous getter, we'll need to cache it or make it async\n // For now, return false if not in context\n return false\n }\n return false\n }\n\n get validationErrors() {\n return this._getSnapshotContext()._validationErrors || []\n }\n\n get isValid() {\n const errors = this.validationErrors\n return errors.length === 0\n }\n\n /**\n * Validate the property\n * @returns Validation result\n */\n async validate(): Promise<{ isValid: boolean; errors: any[] }> {\n return new Promise((resolve) => {\n let resolved = false\n const subscription = this._service.subscribe((snapshot) => {\n const state = snapshot.value\n // Wait for validation to complete (idle state after validating)\n if (state === 'idle' && !resolved) {\n resolved = true\n subscription.unsubscribe()\n const errors = snapshot.context._validationErrors || []\n resolve({\n isValid: errors.length === 0,\n errors,\n })\n }\n })\n\n this._service.send({ type: 'validateProperty' })\n \n // Timeout fallback\n setTimeout(() => {\n if (!resolved) {\n resolved = true\n subscription.unsubscribe()\n const errors = this._getSnapshotContext()._validationErrors || []\n resolve({\n isValid: errors.length === 0,\n errors,\n })\n }\n }, 5000)\n })\n }\n\n save(): void {\n const snapshot = this._service.getSnapshot()\n const isAlreadySaving =\n typeof snapshot.value === 'object' && snapshot.value !== null && 'saveToSchema' in snapshot.value\n if (isAlreadySaving) {\n return\n }\n const context = snapshot.context\n if (!context._isEdited) return // No changes to persist\n // Validation will happen automatically in the machine before saving\n this._service.send({\n type: 'saveToSchema',\n })\n }\n\n /**\n * Reload property from database\n * This refreshes the actor context with the latest data from the database\n * Note: ModelProperty doesn't have a dedicated load actor, so this will\n * re-initialize from the current property data\n */\n async reload(): Promise<void> {\n // ModelProperty doesn't have a separate load mechanism\n // It's loaded as part of the Model/Schema\n // This method is provided for API consistency\n // To actually reload, you'd need to reload the parent Model or Schema\n logger('ModelProperty.reload() called - ModelProperty is loaded as part of Model/Schema. Reload the parent Model or Schema instead.')\n // No-op for now, but could be enhanced to reload from DB if needed\n }\n\n unload(): void {\n // ModelProperty doesn't have liveQuery subscriptions or complex cache management\n // Just stop the service\n try {\n this._service.stop()\n } catch (error) {\n // Service might already be stopped\n }\n }\n\n /**\n * Destroy the model property: remove from caches, delete from database, update Schema context, stop service.\n */\n async destroy(): Promise<void> {\n const context = this._getSnapshotContext()\n const cacheKey =\n context.modelName && context.name\n ? `${context.modelName}:${context.name}`\n : (context.id ?? '')\n if (!cacheKey) return\n\n forceRemoveFromCaches(this, {\n getCacheKeys: () => [cacheKey],\n caches: [ModelProperty.instanceCache as Map<string, unknown>],\n })\n\n await runDestroyLifecycle(this, {\n getService: (instance) =>\n instance._service as { send: (ev: unknown) => void; stop: () => void },\n doDestroy: async () => {\n const db = BaseDb.getAppDb()\n let schemaName = context._schemaName\n const modelName = context.modelName\n const propertyName = context.name\n if (!modelName || !propertyName) return\n\n // Resolve schema name from DB when _schemaName is missing (e.g. destroy ran before _setSchemaName finished)\n if (!schemaName && db) {\n schemaName = await this._resolveSchemaNameForDestroy(db, context)\n }\n\n if (db && schemaName) {\n const propertyRecords = await db\n .select({ propertyId: propertiesTable.id })\n .from(propertiesTable)\n .innerJoin(modelsTable, eq(propertiesTable.modelId, modelsTable.id))\n .innerJoin(modelSchemas, eq(modelsTable.id, modelSchemas.modelId))\n .innerJoin(schemas, eq(modelSchemas.schemaId, schemas.id))\n .where(\n and(\n eq(schemas.name, schemaName),\n eq(modelsTable.name, modelName),\n eq(propertiesTable.name, propertyName),\n ),\n )\n .limit(1)\n if (propertyRecords.length > 0 && propertyRecords[0].propertyId != null) {\n await db\n .delete(propertiesTable)\n .where(eq(propertiesTable.id, propertyRecords[0].propertyId))\n }\n }\n\n if (schemaName) {\n const schema = Schema.create(schemaName, { waitForReady: false }) as import('@/Schema/Schema').Schema\n const snapshot = schema.getService().getSnapshot()\n const schemaContext = snapshot.context\n if (schemaContext.models?.[modelName]?.properties?.[propertyName]) {\n const updatedModels = { ...schemaContext.models }\n const updatedProperties = { ...updatedModels[modelName].properties }\n delete updatedProperties[propertyName]\n updatedModels[modelName] = { ...updatedModels[modelName], properties: updatedProperties }\n schema.getService().send({ type: 'updateContext', models: updatedModels })\n schema.getService().send({ type: 'markAsDraft', propertyKey: `property:${modelName}:${propertyName}` })\n }\n }\n },\n })\n }\n}\n"],"names":["logger","fromCallback","BaseDb","setup","writeProcessMachine","assign","modelsTable","eq","propertiesTable","createActor","and","Model","modelPropertiesToObject","schemas","modelSchemas","getModelIdByFileId","normalizeDataType","generateId","waitForEntityIdle","createReactiveProxy","getModelId","findEntity","BaseFileManager","forceRemoveFromCaches","runDestroyLifecycle","Schema"],"mappings":"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"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var xstate = require('xstate');
|
|
4
|
-
var main_cjs = require('./index-
|
|
4
|
+
var main_cjs = require('./index-CA4i5TA7.js');
|
|
5
5
|
var drizzleOrm = require('drizzle-orm');
|
|
6
6
|
var debug = require('debug');
|
|
7
|
-
var SchemaValidationService = require('./SchemaValidationService-
|
|
7
|
+
var SchemaValidationService = require('./SchemaValidationService-OFyzZIUX.js');
|
|
8
8
|
require('pluralize');
|
|
9
9
|
require('immer');
|
|
10
10
|
require('reflect-metadata');
|
|
@@ -75,7 +75,7 @@ const createModelInstances$2 = async (modelIds) => {
|
|
|
75
75
|
return;
|
|
76
76
|
}
|
|
77
77
|
try {
|
|
78
|
-
const modelMod = await Promise.resolve().then(function () { return require('./index-
|
|
78
|
+
const modelMod = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.Model$1; });
|
|
79
79
|
const { Model } = modelMod;
|
|
80
80
|
// Create instances for all model IDs in parallel
|
|
81
81
|
// Model.createById() will check cache first, then query DB and create if needed
|
|
@@ -188,7 +188,7 @@ const loadOrCreateSchema = xstate.fromCallback(({ sendBack, input: { context } }
|
|
|
188
188
|
// For Seed Protocol, always load from internal file, never create new
|
|
189
189
|
logger$d(`Loading internal Seed Protocol schema from SDK`);
|
|
190
190
|
try {
|
|
191
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
191
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
192
192
|
const schemaFile = internalSchema.default;
|
|
193
193
|
// Check if it exists in database, if not, add it
|
|
194
194
|
const db = main_cjs.BaseDb.getAppDb();
|
|
@@ -677,7 +677,7 @@ const loadOrCreateSchema = xstate.fromCallback(({ sendBack, input: { context } }
|
|
|
677
677
|
// Ensure models are populated (fallback for seed-protocol if missing)
|
|
678
678
|
if ((!mergedModels || Object.keys(mergedModels).length === 0) && schemaName === 'Seed Protocol') {
|
|
679
679
|
try {
|
|
680
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
680
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
681
681
|
const internalSchemaFile = internalSchema.default;
|
|
682
682
|
mergedModels = { ...(internalSchemaFile.models || {}) };
|
|
683
683
|
logger$d(`Populated models for seed-protocol schema from internal file`);
|
|
@@ -904,7 +904,7 @@ const loadOrCreateSchema = xstate.fromCallback(({ sendBack, input: { context } }
|
|
|
904
904
|
// Ensure models are populated (fallback for seed-protocol if missing)
|
|
905
905
|
if ((!mergedModels || Object.keys(mergedModels).length === 0) && schemaName === 'Seed Protocol') {
|
|
906
906
|
try {
|
|
907
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
907
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
908
908
|
const internalSchemaFile = internalSchema.default;
|
|
909
909
|
mergedModels = { ...(internalSchemaFile.models || {}) };
|
|
910
910
|
logger$d(`Populated models for seed-protocol schema from internal file`);
|
|
@@ -993,7 +993,7 @@ const loadOrCreateSchema = xstate.fromCallback(({ sendBack, input: { context } }
|
|
|
993
993
|
// Ensure models are populated (fallback for seed-protocol if missing)
|
|
994
994
|
if ((!mergedModels || Object.keys(mergedModels).length === 0) && schemaName === 'Seed Protocol') {
|
|
995
995
|
try {
|
|
996
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
996
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
997
997
|
const internalSchemaFile = internalSchema.default;
|
|
998
998
|
mergedModels = { ...(internalSchemaFile.models || {}) };
|
|
999
999
|
logger$d(`Populated models for seed-protocol schema from internal file`);
|
|
@@ -1079,7 +1079,7 @@ const loadOrCreateSchema = xstate.fromCallback(({ sendBack, input: { context } }
|
|
|
1079
1079
|
// If schemaData is missing, try to load from internal schema file for seed-protocol
|
|
1080
1080
|
if (!dbSchema.schemaData && schemaName === 'Seed Protocol') {
|
|
1081
1081
|
try {
|
|
1082
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
1082
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
1083
1083
|
const schemaFile = internalSchema.default;
|
|
1084
1084
|
logger$d(`Found seed-protocol schema in internal file (schemaData missing, using internal schema)`);
|
|
1085
1085
|
// Update database with schemaData for future loads
|
|
@@ -1188,7 +1188,7 @@ const loadOrCreateSchema = xstate.fromCallback(({ sendBack, input: { context } }
|
|
|
1188
1188
|
// Ensure models are populated (fallback for seed-protocol if missing)
|
|
1189
1189
|
if ((!mergedModels || Object.keys(mergedModels).length === 0) && schemaName === 'Seed Protocol') {
|
|
1190
1190
|
try {
|
|
1191
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
1191
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
1192
1192
|
const internalSchemaFile = internalSchema.default;
|
|
1193
1193
|
mergedModels = { ...(internalSchemaFile.models || {}) };
|
|
1194
1194
|
logger$d(`Populated models for seed-protocol schema from internal file`);
|
|
@@ -2086,7 +2086,7 @@ const createModelInstances$1 = async (modelIds) => {
|
|
|
2086
2086
|
return;
|
|
2087
2087
|
}
|
|
2088
2088
|
try {
|
|
2089
|
-
const mod = await Promise.resolve().then(function () { return require('./index-
|
|
2089
|
+
const mod = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.Model$1; });
|
|
2090
2090
|
const Model = mod?.Model ?? mod?.default;
|
|
2091
2091
|
if (!Model) {
|
|
2092
2092
|
logger$c('Model not available from dynamic import');
|
|
@@ -2131,7 +2131,7 @@ const checkExistingSchema = xstate.fromCallback(({ sendBack, input: { context }
|
|
|
2131
2131
|
if (isInternal && schemaName === main_cjs.SEED_PROTOCOL_SCHEMA_NAME) {
|
|
2132
2132
|
// For Seed Protocol, check if it exists in database
|
|
2133
2133
|
try {
|
|
2134
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
2134
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
2135
2135
|
const schemaFile = internalSchema.default;
|
|
2136
2136
|
if (db && schemaFile.id) {
|
|
2137
2137
|
const existing = await db
|
|
@@ -2489,7 +2489,7 @@ const writeSchemaToDb = xstate.fromCallback(({ sendBack, input }) => {
|
|
|
2489
2489
|
if (isInternal && schemaName === main_cjs.SEED_PROTOCOL_SCHEMA_NAME) {
|
|
2490
2490
|
// For Seed Protocol, load from internal file
|
|
2491
2491
|
logger$b(`Loading internal Seed Protocol schema from SDK`);
|
|
2492
|
-
const internalSchema = await Promise.resolve().then(function () { return require('./index-
|
|
2492
|
+
const internalSchema = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.SEEDPROTOCOL_Seed_Protocol_v1; });
|
|
2493
2493
|
finalSchema = internalSchema.default;
|
|
2494
2494
|
const db = main_cjs.BaseDb.getAppDb();
|
|
2495
2495
|
if (db && finalSchema.id) {
|
|
@@ -2957,7 +2957,7 @@ const createModelInstances = xstate.fromCallback(({ sendBack, input }) => {
|
|
|
2957
2957
|
return;
|
|
2958
2958
|
}
|
|
2959
2959
|
try {
|
|
2960
|
-
const modelMod = await Promise.resolve().then(function () { return require('./index-
|
|
2960
|
+
const modelMod = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.Model$1; });
|
|
2961
2961
|
const { Model } = modelMod;
|
|
2962
2962
|
// Create instances for all model IDs in parallel
|
|
2963
2963
|
// Model.createById() will check cache first, then query DB and create if needed
|
|
@@ -3043,7 +3043,7 @@ const verifyModelInstancesInCache = xstate.fromCallback(({ sendBack, input }) =>
|
|
|
3043
3043
|
}
|
|
3044
3044
|
try {
|
|
3045
3045
|
const result = await verifyWithRetry$2(async () => {
|
|
3046
|
-
const modelMod = await Promise.resolve().then(function () { return require('./index-
|
|
3046
|
+
const modelMod = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.Model$1; });
|
|
3047
3047
|
const { Model } = modelMod;
|
|
3048
3048
|
// Check each model ID in the cache
|
|
3049
3049
|
const verifiedInstances = [];
|
|
@@ -3100,7 +3100,7 @@ const writePropertiesToDb = xstate.fromCallback(({ sendBack, input }) => {
|
|
|
3100
3100
|
const _write = async () => {
|
|
3101
3101
|
const { modelIds } = input;
|
|
3102
3102
|
try {
|
|
3103
|
-
const modelSchemaMod = await Promise.resolve().then(function () { return require('./index-
|
|
3103
|
+
const modelSchemaMod = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.ModelSchema; });
|
|
3104
3104
|
const { models: modelsTable, properties: propertiesTable } = modelSchemaMod;
|
|
3105
3105
|
const drizzleMod = await import('drizzle-orm');
|
|
3106
3106
|
const { eq } = drizzleMod;
|
|
@@ -3288,9 +3288,9 @@ const createPropertyInstances = xstate.fromCallback(({ sendBack, input }) => {
|
|
|
3288
3288
|
return;
|
|
3289
3289
|
}
|
|
3290
3290
|
try {
|
|
3291
|
-
const modProp = await Promise.resolve().then(function () { return require('./ModelProperty-
|
|
3291
|
+
const modProp = await Promise.resolve().then(function () { return require('./ModelProperty-DcAM5M8T.js'); });
|
|
3292
3292
|
const ModelProperty = modProp?.ModelProperty ?? modProp?.default;
|
|
3293
|
-
const modModel = await Promise.resolve().then(function () { return require('./index-
|
|
3293
|
+
const modModel = await Promise.resolve().then(function () { return require('./index-CA4i5TA7.js'); }).then(function (n) { return n.Model$1; });
|
|
3294
3294
|
const Model = modModel?.Model ?? modModel?.default;
|
|
3295
3295
|
if (!ModelProperty || !Model) {
|
|
3296
3296
|
logger$3('ModelProperty or Model not available from dynamic import');
|
|
@@ -3395,7 +3395,7 @@ const verifyPropertyInstancesInCache = xstate.fromCallback(({ sendBack, input })
|
|
|
3395
3395
|
}
|
|
3396
3396
|
try {
|
|
3397
3397
|
const result = await verifyWithRetry(async () => {
|
|
3398
|
-
const mod = await Promise.resolve().then(function () { return require('./ModelProperty-
|
|
3398
|
+
const mod = await Promise.resolve().then(function () { return require('./ModelProperty-DcAM5M8T.js'); });
|
|
3399
3399
|
const ModelProperty = mod?.ModelProperty ?? mod?.default;
|
|
3400
3400
|
if (!ModelProperty) {
|
|
3401
3401
|
throw new Error('ModelProperty not available from dynamic import');
|
|
@@ -5162,7 +5162,7 @@ class Schema {
|
|
|
5162
5162
|
_dbVersion: publishedSchema.version,
|
|
5163
5163
|
});
|
|
5164
5164
|
// Clear edited flags on all ModelProperty instances and in database
|
|
5165
|
-
const modelPropertyMod = await Promise.resolve().then(function () { return require('./ModelProperty-
|
|
5165
|
+
const modelPropertyMod = await Promise.resolve().then(function () { return require('./ModelProperty-DcAM5M8T.js'); });
|
|
5166
5166
|
const { ModelProperty } = modelPropertyMod;
|
|
5167
5167
|
for (const propertyKey of context._editedProperties) {
|
|
5168
5168
|
const [modelName, propertyName] = propertyKey.split(':');
|
|
@@ -5964,4 +5964,4 @@ var Schema$1 = /*#__PURE__*/Object.freeze({
|
|
|
5964
5964
|
|
|
5965
5965
|
exports.Schema = Schema;
|
|
5966
5966
|
exports.schemaInstanceState = schemaInstanceState;
|
|
5967
|
-
//# sourceMappingURL=Schema-
|
|
5967
|
+
//# sourceMappingURL=Schema-B6ifYEhD.js.map
|