@api-client/core 0.11.11 → 0.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (252) hide show
  1. package/Testing.md +1 -1
  2. package/bin/plugins/events/EventPlugin.ts +61 -0
  3. package/bin/plugins/events/assert.ts +193 -0
  4. package/bin/plugins/events/types.ts +6 -0
  5. package/bin/test.ts +8 -1
  6. package/build/src/amf/AmfShapeGenerator.d.ts +6 -3
  7. package/build/src/amf/AmfShapeGenerator.d.ts.map +1 -1
  8. package/build/src/amf/AmfShapeGenerator.js +4 -1
  9. package/build/src/amf/AmfShapeGenerator.js.map +1 -1
  10. package/build/src/amf/AmfTypes.d.ts +2 -2
  11. package/build/src/amf/AmfTypes.d.ts.map +1 -1
  12. package/build/src/amf/AmfTypes.js.map +1 -1
  13. package/build/src/amf/DataValueGenerator.d.ts +15 -15
  14. package/build/src/amf/DataValueGenerator.d.ts.map +1 -1
  15. package/build/src/amf/DataValueGenerator.js +14 -14
  16. package/build/src/amf/DataValueGenerator.js.map +1 -1
  17. package/build/src/browser.d.ts +12 -9
  18. package/build/src/browser.d.ts.map +1 -1
  19. package/build/src/browser.js +11 -8
  20. package/build/src/browser.js.map +1 -1
  21. package/build/src/exceptions/attach_exception.d.ts +11 -0
  22. package/build/src/exceptions/attach_exception.d.ts.map +1 -0
  23. package/build/src/exceptions/attach_exception.js +11 -0
  24. package/build/src/exceptions/attach_exception.js.map +1 -0
  25. package/build/src/exceptions/detach_exception.d.ts +11 -0
  26. package/build/src/exceptions/detach_exception.d.ts.map +1 -0
  27. package/build/src/exceptions/detach_exception.js +11 -0
  28. package/build/src/exceptions/detach_exception.js.map +1 -0
  29. package/build/src/exceptions/remove_model_exception.d.ts +8 -0
  30. package/build/src/exceptions/remove_model_exception.d.ts.map +1 -0
  31. package/build/src/exceptions/remove_model_exception.js +8 -0
  32. package/build/src/exceptions/remove_model_exception.js.map +1 -0
  33. package/build/src/exceptions/remove_namespace_exception.d.ts +8 -0
  34. package/build/src/exceptions/remove_namespace_exception.d.ts.map +1 -0
  35. package/build/src/exceptions/remove_namespace_exception.js +8 -0
  36. package/build/src/exceptions/remove_namespace_exception.js.map +1 -0
  37. package/build/src/index.d.ts +12 -9
  38. package/build/src/index.d.ts.map +1 -1
  39. package/build/src/index.js +11 -8
  40. package/build/src/index.js.map +1 -1
  41. package/build/src/legacy.d.ts +8 -0
  42. package/build/src/legacy.d.ts.map +1 -1
  43. package/build/src/legacy.js +9 -0
  44. package/build/src/legacy.js.map +1 -1
  45. package/build/src/modeling/Bindings.d.ts +2 -2
  46. package/build/src/modeling/Bindings.d.ts.map +1 -1
  47. package/build/src/modeling/Bindings.js.map +1 -1
  48. package/build/src/modeling/DataDomain.d.ts +601 -0
  49. package/build/src/modeling/DataDomain.d.ts.map +1 -0
  50. package/build/src/modeling/DataDomain.js +1142 -0
  51. package/build/src/modeling/DataDomain.js.map +1 -0
  52. package/build/src/modeling/DataFormat.d.ts +42 -41
  53. package/build/src/modeling/DataFormat.d.ts.map +1 -1
  54. package/build/src/modeling/DataFormat.js +30 -131
  55. package/build/src/modeling/DataFormat.js.map +1 -1
  56. package/build/src/modeling/DomainAssociation.d.ts +281 -0
  57. package/build/src/modeling/DomainAssociation.d.ts.map +1 -0
  58. package/build/src/modeling/DomainAssociation.js +440 -0
  59. package/build/src/modeling/DomainAssociation.js.map +1 -0
  60. package/build/src/modeling/DomainElement.d.ts +33 -0
  61. package/build/src/modeling/DomainElement.d.ts.map +1 -0
  62. package/build/src/modeling/DomainElement.js +32 -0
  63. package/build/src/modeling/DomainElement.js.map +1 -0
  64. package/build/src/modeling/DomainEntity.d.ts +383 -0
  65. package/build/src/modeling/DomainEntity.d.ts.map +1 -0
  66. package/build/src/modeling/DomainEntity.js +718 -0
  67. package/build/src/modeling/DomainEntity.js.map +1 -0
  68. package/build/src/modeling/DomainFile.d.ts +25 -0
  69. package/build/src/modeling/DomainFile.d.ts.map +1 -0
  70. package/build/src/modeling/DomainFile.js +86 -0
  71. package/build/src/modeling/DomainFile.js.map +1 -0
  72. package/build/src/modeling/DomainImpactAnalysis.d.ts +60 -47
  73. package/build/src/modeling/DomainImpactAnalysis.d.ts.map +1 -1
  74. package/build/src/modeling/DomainImpactAnalysis.js +201 -132
  75. package/build/src/modeling/DomainImpactAnalysis.js.map +1 -1
  76. package/build/src/modeling/DomainModel.d.ts +226 -0
  77. package/build/src/modeling/DomainModel.d.ts.map +1 -0
  78. package/build/src/modeling/DomainModel.js +401 -0
  79. package/build/src/modeling/DomainModel.js.map +1 -0
  80. package/build/src/modeling/DomainNamespace.d.ts +268 -0
  81. package/build/src/modeling/DomainNamespace.d.ts.map +1 -0
  82. package/build/src/modeling/DomainNamespace.js +512 -0
  83. package/build/src/modeling/DomainNamespace.js.map +1 -0
  84. package/build/src/modeling/DomainProperty.d.ts +281 -0
  85. package/build/src/modeling/DomainProperty.d.ts.map +1 -0
  86. package/build/src/modeling/DomainProperty.js +560 -0
  87. package/build/src/modeling/DomainProperty.js.map +1 -0
  88. package/build/src/modeling/DomainSerialization.d.ts +40 -0
  89. package/build/src/modeling/DomainSerialization.d.ts.map +1 -0
  90. package/build/src/modeling/DomainSerialization.js +288 -0
  91. package/build/src/modeling/DomainSerialization.js.map +1 -0
  92. package/build/src/modeling/DomainVersioning.d.ts +17 -0
  93. package/build/src/modeling/DomainVersioning.d.ts.map +1 -0
  94. package/build/src/modeling/DomainVersioning.js +124 -0
  95. package/build/src/modeling/DomainVersioning.js.map +1 -0
  96. package/build/src/modeling/GraphUtils.d.ts +8 -0
  97. package/build/src/modeling/GraphUtils.d.ts.map +1 -0
  98. package/build/src/modeling/GraphUtils.js +26 -0
  99. package/build/src/modeling/GraphUtils.js.map +1 -0
  100. package/build/src/modeling/amf/ShapeGenerator.d.ts +164 -0
  101. package/build/src/modeling/amf/ShapeGenerator.d.ts.map +1 -0
  102. package/build/src/modeling/amf/ShapeGenerator.js +492 -0
  103. package/build/src/modeling/amf/ShapeGenerator.js.map +1 -0
  104. package/build/src/modeling/{DataAssociation.d.ts → legacy/DataAssociation.d.ts} +10 -5
  105. package/build/src/modeling/legacy/DataAssociation.d.ts.map +1 -0
  106. package/build/src/modeling/{DataAssociation.js → legacy/DataAssociation.js} +9 -6
  107. package/build/src/modeling/legacy/DataAssociation.js.map +1 -0
  108. package/build/src/modeling/{DataEntity.d.ts → legacy/DataEntity.d.ts} +12 -7
  109. package/build/src/modeling/legacy/DataEntity.d.ts.map +1 -0
  110. package/build/src/modeling/{DataEntity.js → legacy/DataEntity.js} +19 -18
  111. package/build/src/modeling/legacy/DataEntity.js.map +1 -0
  112. package/build/src/modeling/{DataEntityBuilder.d.ts → legacy/DataEntityBuilder.d.ts} +3 -2
  113. package/build/src/modeling/legacy/DataEntityBuilder.d.ts.map +1 -0
  114. package/build/src/modeling/{DataEntityBuilder.js → legacy/DataEntityBuilder.js} +3 -2
  115. package/build/src/modeling/legacy/DataEntityBuilder.js.map +1 -0
  116. package/build/src/modeling/legacy/DataImpactAnalysis.d.ts +298 -0
  117. package/build/src/modeling/legacy/DataImpactAnalysis.d.ts.map +1 -0
  118. package/build/src/modeling/legacy/DataImpactAnalysis.js +441 -0
  119. package/build/src/modeling/legacy/DataImpactAnalysis.js.map +1 -0
  120. package/build/src/modeling/{DataModel.d.ts → legacy/DataModel.d.ts} +6 -4
  121. package/build/src/modeling/legacy/DataModel.d.ts.map +1 -0
  122. package/build/src/modeling/{DataModel.js → legacy/DataModel.js} +7 -6
  123. package/build/src/modeling/legacy/DataModel.js.map +1 -0
  124. package/build/src/modeling/{DataNamespace.d.ts → legacy/DataNamespace.d.ts} +22 -3
  125. package/build/src/modeling/legacy/DataNamespace.d.ts.map +1 -0
  126. package/build/src/modeling/{DataNamespace.js → legacy/DataNamespace.js} +7 -3
  127. package/build/src/modeling/legacy/DataNamespace.js.map +1 -0
  128. package/build/src/modeling/{DataProperty.d.ts → legacy/DataProperty.d.ts} +13 -5
  129. package/build/src/modeling/legacy/DataProperty.d.ts.map +1 -0
  130. package/build/src/modeling/{DataProperty.js → legacy/DataProperty.js} +8 -5
  131. package/build/src/modeling/legacy/DataProperty.js.map +1 -0
  132. package/build/src/modeling/observed.d.ts +67 -0
  133. package/build/src/modeling/observed.d.ts.map +1 -0
  134. package/build/src/modeling/observed.js +230 -0
  135. package/build/src/modeling/observed.js.map +1 -0
  136. package/build/src/modeling/types.d.ts +165 -1
  137. package/build/src/modeling/types.d.ts.map +1 -1
  138. package/build/src/modeling/types.js.map +1 -1
  139. package/build/src/models/Thing.d.ts +26 -5
  140. package/build/src/models/Thing.d.ts.map +1 -1
  141. package/build/src/models/Thing.js +193 -91
  142. package/build/src/models/Thing.js.map +1 -1
  143. package/build/src/models/kinds.d.ts +31 -6
  144. package/build/src/models/kinds.d.ts.map +1 -1
  145. package/build/src/models/kinds.js +31 -6
  146. package/build/src/models/kinds.js.map +1 -1
  147. package/build/src/models/store/DataFile.d.ts +3 -1
  148. package/build/src/models/store/DataFile.d.ts.map +1 -1
  149. package/build/src/models/store/DataFile.js +2 -0
  150. package/build/src/models/store/DataFile.js.map +1 -1
  151. package/build/src/models/types.d.ts +12 -0
  152. package/build/src/models/types.d.ts.map +1 -0
  153. package/build/src/models/types.js +2 -0
  154. package/build/src/models/types.js.map +1 -0
  155. package/build/src/runtime/store/FilesSdk.d.ts +2 -2
  156. package/build/src/runtime/store/FilesSdk.d.ts.map +1 -1
  157. package/build/src/runtime/store/FilesSdk.js.map +1 -1
  158. package/data/models/example-generator-api.json +16 -16
  159. package/package.json +20 -6
  160. package/readme.md +1 -1
  161. package/src/amf/AmfShapeGenerator.ts +7 -4
  162. package/src/amf/AmfTypes.ts +2 -2
  163. package/src/amf/DataValueGenerator.ts +21 -21
  164. package/src/exceptions/attach_exception.ts +11 -0
  165. package/src/exceptions/detach_exception.ts +11 -0
  166. package/src/exceptions/remove_model_exception.ts +8 -0
  167. package/src/exceptions/remove_namespace_exception.ts +8 -0
  168. package/src/modeling/Bindings.ts +2 -2
  169. package/src/modeling/DataDomain.ts +1221 -0
  170. package/src/modeling/DataFormat.ts +54 -163
  171. package/src/modeling/DomainAssociation.ts +476 -0
  172. package/src/modeling/DomainElement.ts +50 -0
  173. package/src/modeling/DomainEntity.ts +769 -0
  174. package/src/modeling/DomainFile.ts +94 -0
  175. package/src/modeling/DomainImpactAnalysis.ts +218 -144
  176. package/src/modeling/DomainModel.ts +421 -0
  177. package/src/modeling/DomainNamespace.ts +537 -0
  178. package/src/modeling/DomainProperty.ts +548 -0
  179. package/src/modeling/DomainSerialization.ts +312 -0
  180. package/src/modeling/DomainVersioning.ts +144 -0
  181. package/src/modeling/GraphUtils.ts +28 -0
  182. package/src/modeling/amf/ShapeGenerator.ts +552 -0
  183. package/src/modeling/graph.md +115 -0
  184. package/src/modeling/{DataAssociation.ts → legacy/DataAssociation.ts} +13 -8
  185. package/src/modeling/{DataEntity.ts → legacy/DataEntity.ts} +28 -23
  186. package/src/modeling/{DataEntityBuilder.ts → legacy/DataEntityBuilder.ts} +4 -3
  187. package/src/modeling/legacy/DataImpactAnalysis.ts +530 -0
  188. package/src/modeling/{DataModel.ts → legacy/DataModel.ts} +10 -8
  189. package/src/modeling/{DataNamespace.ts → legacy/DataNamespace.ts} +23 -5
  190. package/src/modeling/{DataProperty.ts → legacy/DataProperty.ts} +15 -7
  191. package/src/modeling/observed.ts +267 -0
  192. package/src/modeling/types.ts +174 -1
  193. package/src/models/Thing.ts +70 -5
  194. package/src/models/kinds.ts +32 -6
  195. package/src/models/store/DataFile.ts +3 -1
  196. package/src/models/types.ts +11 -0
  197. package/src/runtime/store/FilesSdk.ts +2 -2
  198. package/tests/unit/amf/data_value_generator.spec.ts +15 -15
  199. package/tests/unit/legacy-transformers/ARC-legacy-import.spec.ts +1 -1
  200. package/tests/unit/modeling/amf/shape_generator.spec.ts +1174 -0
  201. package/tests/unit/modeling/data_domain.spec.ts +444 -0
  202. package/tests/unit/modeling/data_domain_associations.spec.ts +279 -0
  203. package/tests/unit/modeling/data_domain_change_observers.spec.ts +681 -0
  204. package/tests/unit/modeling/data_domain_entities.spec.ts +449 -0
  205. package/tests/unit/modeling/data_domain_foreign.spec.ts +355 -0
  206. package/tests/unit/modeling/data_domain_models.spec.ts +658 -0
  207. package/tests/unit/modeling/data_domain_namespaces.spec.ts +668 -0
  208. package/tests/unit/modeling/data_domain_property.spec.ts +264 -0
  209. package/tests/unit/modeling/data_domain_serialization.spec.ts +294 -0
  210. package/tests/unit/modeling/domain.property.spec.ts +822 -0
  211. package/tests/unit/modeling/domain_asociation.spec.ts +643 -0
  212. package/tests/unit/modeling/domain_asociation_targets.spec.ts +350 -0
  213. package/tests/unit/modeling/domain_entity.spec.ts +730 -0
  214. package/tests/unit/modeling/domain_entity_associations.spec.ts +330 -0
  215. package/tests/unit/modeling/domain_entity_example_generator_json.spec.ts +988 -0
  216. package/tests/unit/modeling/domain_entity_example_generator_xml.spec.ts +1451 -0
  217. package/tests/unit/modeling/domain_entity_fields.spec.ts +113 -0
  218. package/tests/unit/modeling/domain_entity_generators.spec.ts +20 -0
  219. package/tests/unit/modeling/domain_entity_parents.spec.ts +291 -0
  220. package/tests/unit/modeling/domain_entity_properties.spec.ts +305 -0
  221. package/tests/unit/modeling/{data_file.spec.ts → domain_file.spec.ts} +29 -85
  222. package/tests/unit/modeling/domain_impact_analysis.spec.ts +452 -0
  223. package/tests/unit/modeling/domain_model.spec.ts +568 -0
  224. package/tests/unit/modeling/domain_model_entities.spec.ts +408 -0
  225. package/tests/unit/modeling/domain_namespace.spec.ts +514 -0
  226. package/tests/unit/modeling/domain_namespace_models.spec.ts +324 -0
  227. package/tests/unit/modeling/domain_namespace_namespaces.spec.ts +404 -0
  228. package/tests/unit/modeling/domain_versioning.spec.ts +140 -0
  229. package/tests/unit/{amf → modeling/legacy}/amf_shape_generator.spec.ts +11 -11
  230. package/tests/unit/modeling/{data_association.spec.ts → legacy/data_association.spec.ts} +3 -11
  231. package/tests/unit/modeling/{data_entity.spec.ts → legacy/data_entity.spec.ts} +10 -8
  232. package/tests/unit/modeling/{data_entity_generator_json.spec.ts → legacy/data_entity_generator_json.spec.ts} +1 -1
  233. package/tests/unit/modeling/{data_entity_generator_xml.spec.ts → legacy/data_entity_generator_xml.spec.ts} +1 -1
  234. package/tests/unit/modeling/{data_model.spec.ts → legacy/data_model.spec.ts} +3 -3
  235. package/tests/unit/modeling/{data_namespace.spec.ts → legacy/data_namespace.spec.ts} +3 -10
  236. package/tests/unit/modeling/{data_property.spec.ts → legacy/data_property.spec.ts} +3 -6
  237. package/tests/unit/modeling/{impact_analysis.spec.ts → legacy/impact_analysis.spec.ts} +9 -9
  238. package/tests/unit/models/File/new.spec.ts +1 -1
  239. package/tests/unit/models/HttpProject.spec.ts +3 -3
  240. package/tsconfig.node.json +35 -0
  241. package/build/src/modeling/DataAssociation.d.ts.map +0 -1
  242. package/build/src/modeling/DataAssociation.js.map +0 -1
  243. package/build/src/modeling/DataEntity.d.ts.map +0 -1
  244. package/build/src/modeling/DataEntity.js.map +0 -1
  245. package/build/src/modeling/DataEntityBuilder.d.ts.map +0 -1
  246. package/build/src/modeling/DataEntityBuilder.js.map +0 -1
  247. package/build/src/modeling/DataModel.d.ts.map +0 -1
  248. package/build/src/modeling/DataModel.js.map +0 -1
  249. package/build/src/modeling/DataNamespace.d.ts.map +0 -1
  250. package/build/src/modeling/DataNamespace.js.map +0 -1
  251. package/build/src/modeling/DataProperty.d.ts.map +0 -1
  252. package/build/src/modeling/DataProperty.js.map +0 -1
@@ -1,11 +1,11 @@
1
1
  import { Json } from '@api-client/json'
2
- import { IThing, Thing } from '../models/Thing.js'
3
- import v4 from '../lib/uuid.js'
2
+ import { IThing, Thing } from '../../models/Thing.js'
3
+ import v4 from '../../lib/uuid.js'
4
4
  import { DataNamespace } from './DataNamespace.js'
5
- import { IApiPropertyShape } from '../amf/definitions/Shapes.js'
6
- import { AmfShapeGenerator } from '../amf/AmfShapeGenerator.js'
7
- import { PropertyBinding, PropertyBindings, PropertyWebBindings } from './Bindings.js'
8
- import { DataPropertyKind } from '../models/kinds.js'
5
+ import { IApiPropertyShape } from '../../amf/definitions/Shapes.js'
6
+ import { AmfShapeGenerator } from '../../amf/AmfShapeGenerator.js'
7
+ import { PropertyBinding, PropertyBindings, PropertyWebBindings } from '../Bindings.js'
8
+ import { DataPropertyKind } from '../../models/kinds.js'
9
9
  import {
10
10
  type BinaryFormat,
11
11
  BinaryFormats,
@@ -17,11 +17,12 @@ import {
17
17
  DataPropertyTypes,
18
18
  type NumberFormat,
19
19
  NumberFormats,
20
- } from './DataFormat.js'
20
+ } from '../DataFormat.js'
21
21
  import type { DataEntity } from './DataEntity.js'
22
22
 
23
23
  /**
24
24
  * Describes the default value set on a property schema.
25
+ * @deprecated
25
26
  */
26
27
  export interface SchemaDefaultValue {
27
28
  /**
@@ -41,6 +42,7 @@ export interface SchemaDefaultValue {
41
42
  /**
42
43
  * A general schema definition for a property.
43
44
  * This is propagated to all bindings (when they support these properties).
45
+ * @deprecated
44
46
  */
45
47
  export interface DataPropertySchema {
46
48
  /**
@@ -109,6 +111,9 @@ export interface DataPropertySchema {
109
111
  examples?: string[]
110
112
  }
111
113
 
114
+ /**
115
+ * @deprecated
116
+ */
112
117
  export interface IDataProperty {
113
118
  kind: typeof DataPropertyKind
114
119
  /**
@@ -180,6 +185,9 @@ export interface IDataProperty {
180
185
  bindings?: PropertyBinding[]
181
186
  }
182
187
 
188
+ /**
189
+ * @deprecated
190
+ */
183
191
  export class DataProperty {
184
192
  kind = DataPropertyKind
185
193
 
@@ -0,0 +1,267 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ const reactiveSymbol = Symbol('reactive')
3
+ const proxySymbol = Symbol('proxy')
4
+
5
+ interface DomainInstance {
6
+ domain?: { notifyChange(): void }
7
+ notifyChange?: () => void
8
+ }
9
+
10
+ export interface PropertyDecorator {
11
+ // accessor decorator signature
12
+ <C extends DomainInstance, V>(
13
+ target: ClassAccessorDecoratorTarget<C, V>,
14
+ context: ClassAccessorDecoratorContext<C, V>
15
+ ): ClassAccessorDecoratorResult<C, V>
16
+ // setter decorator signature
17
+ <C extends DomainInstance, V>(
18
+ target: (value: V) => void,
19
+ context: ClassSetterDecoratorContext<C, V>
20
+ ): (this: C, value: V) => void
21
+ }
22
+
23
+ type StandardPropertyContext<C, V> = ClassAccessorDecoratorContext<C, V> | ClassSetterDecoratorContext<C, V>
24
+ type StandardPropertyTarget<C, V> = ClassAccessorDecoratorTarget<C, V> | ((value: V) => void)
25
+
26
+ export interface ObserveConfig {
27
+ /**
28
+ * To be used when observing an object and not a primitive.
29
+ * It creates a proxy that observes changes in the object.
30
+ */
31
+ deep?: boolean
32
+ }
33
+
34
+ /**
35
+ * Reads the raw value of the object, that is, not proxied object.
36
+ * @param source The source object that contains the object
37
+ * @param target The target object set on the source object
38
+ * @returns The not proxied object or undefined
39
+ */
40
+ export function toRaw<T extends object = object>(source: object, target: T): T | undefined {
41
+ const proxies = Reflect.get(source, proxySymbol) as Map<object, object>
42
+ if (!proxies) {
43
+ return undefined
44
+ }
45
+ for (const [key, value] of proxies.entries()) {
46
+ if (value === target) {
47
+ return key as T
48
+ }
49
+ }
50
+ }
51
+
52
+ /**
53
+ * Turns a class property or a setter into an observed property
54
+ * that notifies the root domain when changed.
55
+ *
56
+ * A property has to be declared with the `accessor` type to be
57
+ * observed.
58
+ *
59
+ * ```typescript
60
+ * @observed() accessor name: string | undefined
61
+ *
62
+ * @observed()
63
+ * set height(value: number) {
64
+ * this.#height = value
65
+ * }
66
+ *
67
+ * get height(): number {
68
+ * return this.#height
69
+ * }
70
+ * ```
71
+ *
72
+ * The decorator can be used in the following ways:
73
+ * - As a class property decorator
74
+ * - As a class setter decorator
75
+ *
76
+ * The property class either has to have a `root` property
77
+ * or a `notifyChange` method. The decorator will call the
78
+ * `notifyChange` method if it exists. Otherwise, it will
79
+ * call the `notifyChange` method of the root domain.
80
+ */
81
+ export function observed(config: ObserveConfig = {}): PropertyDecorator {
82
+ return <C extends DomainInstance, V>(
83
+ target: StandardPropertyTarget<C, V>,
84
+ context: StandardPropertyContext<C, V>
85
+ ): any => {
86
+ const { kind } = context
87
+ const { deep } = config
88
+
89
+ function createDeepProxy(this: DomainInstance, obj: unknown, notifyChange: () => void): any {
90
+ if (typeof obj !== 'object' || obj === null) {
91
+ return obj
92
+ }
93
+ // instead of using the target object to store the proxy info, we
94
+ // reflect the proxy info to the object itself. This way we can
95
+ // keep the stored values clean, which helps with testing (deep equal would include symbols)
96
+ // Keys are original objects, values are proxies
97
+ let proxies = Reflect.get(this, proxySymbol) as Map<object, object>
98
+ if (!proxies) {
99
+ proxies = new Map()
100
+ Reflect.set(this, proxySymbol, proxies)
101
+ }
102
+
103
+ if (proxies.has(obj)) {
104
+ return obj
105
+ }
106
+
107
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
108
+ const targetObject = this
109
+
110
+ const proxy = new Proxy(obj, {
111
+ get(target, prop) {
112
+ const value = Reflect.get(target, prop)
113
+ return createDeepProxy.bind(targetObject)(value, notifyChange)
114
+ },
115
+ set(target, prop, value) {
116
+ const oldValue = Reflect.get(target, prop)
117
+ if (oldValue !== value) {
118
+ Reflect.set(target, prop, value)
119
+ notifyChange()
120
+ }
121
+ return true
122
+ },
123
+ deleteProperty(target, prop) {
124
+ Reflect.deleteProperty(target, prop)
125
+ notifyChange()
126
+ return true
127
+ },
128
+ })
129
+ proxies.set(obj, proxy)
130
+ return proxy
131
+ }
132
+
133
+ if (kind === 'accessor') {
134
+ return {
135
+ set(this: DomainInstance, value: V): void {
136
+ let map = Reflect.get(this, reactiveSymbol)
137
+ if (!map) {
138
+ map = {}
139
+ Reflect.set(this, reactiveSymbol, map)
140
+ }
141
+ if (map[context.name] === context.name) {
142
+ return
143
+ }
144
+ const notify = () => {
145
+ if (this.domain) {
146
+ this.domain.notifyChange()
147
+ } else if (this.notifyChange) {
148
+ this.notifyChange()
149
+ }
150
+ }
151
+ if (deep) {
152
+ value = createDeepProxy.bind(this)(value, notify)
153
+ }
154
+ if (value === undefined) {
155
+ // eslint-disable-next-line @typescript-eslint/no-dynamic-delete
156
+ delete map[context.name]
157
+ } else {
158
+ map[context.name] = value
159
+ }
160
+ notify()
161
+ },
162
+
163
+ get(): V {
164
+ const map = Reflect.get(this, reactiveSymbol) || {}
165
+ return map[context.name]
166
+ },
167
+ }
168
+ } else if (kind === 'setter') {
169
+ const { name } = context
170
+ return function (this: DomainInstance, value: V): void {
171
+ const oldValue = this[name as keyof DomainInstance]
172
+ if (value === oldValue) {
173
+ return
174
+ }
175
+ const notify = () => {
176
+ if (this.domain) {
177
+ this.domain.notifyChange()
178
+ } else if (this.notifyChange) {
179
+ this.notifyChange()
180
+ }
181
+ }
182
+ ;(target as (value: V) => void).call(this, value)
183
+ notify()
184
+ }
185
+ }
186
+ throw new Error(`Unsupported decorator location: ${kind}`)
187
+ }
188
+ }
189
+
190
+ /**
191
+ * A decorator that can be used to retarget the change event
192
+ * of a property to the root domain.
193
+ *
194
+ * This decorator should not be used with the `observed` decorator.
195
+ * It does the same thing. It will notify about a change to the
196
+ * property itself.
197
+ */
198
+ export function retargetChange() {
199
+ return <C extends DomainInstance, V extends EventTarget>(
200
+ target: StandardPropertyTarget<C, V>,
201
+ context: StandardPropertyContext<C, V>
202
+ ): any => {
203
+ const { kind } = context
204
+ function observer(this: DomainInstance) {
205
+ if (this.domain) {
206
+ this.domain.notifyChange()
207
+ }
208
+ }
209
+ let binding: ((this: DomainInstance) => void) | undefined
210
+ if (kind === 'accessor') {
211
+ return {
212
+ set(this: DomainInstance, value: V): void {
213
+ let map = Reflect.get(this, reactiveSymbol)
214
+ if (!map) {
215
+ map = {}
216
+ Reflect.set(this, reactiveSymbol, map)
217
+ }
218
+ if (map[context.name] === context.name) {
219
+ return
220
+ }
221
+ const oldValue = map[context.name]
222
+ if (oldValue === value) {
223
+ return
224
+ }
225
+ if (value === undefined) {
226
+ // eslint-disable-next-line @typescript-eslint/no-dynamic-delete
227
+ delete map[context.name]
228
+ } else {
229
+ map[context.name] = value
230
+ }
231
+ if (oldValue && binding) {
232
+ oldValue.removeEventListener('change', binding)
233
+ }
234
+ if (value) {
235
+ binding = observer.bind(this)
236
+ value.addEventListener('change', binding)
237
+ }
238
+ if (this.domain) {
239
+ this.domain.notifyChange()
240
+ }
241
+ },
242
+
243
+ get(): V {
244
+ const map = Reflect.get(this, reactiveSymbol) || {}
245
+ return map[context.name]
246
+ },
247
+ }
248
+ } else if (kind === 'setter') {
249
+ const { name } = context
250
+ return function (this: DomainInstance, value: V): void {
251
+ const oldValue = this[name as keyof DomainInstance] as unknown as V
252
+ if (value === oldValue) {
253
+ return
254
+ }
255
+ ;(target as (value: V) => void).call(this, value)
256
+ if (oldValue && binding) {
257
+ oldValue.removeEventListener('change', binding)
258
+ }
259
+ if (value) {
260
+ binding = observer.bind(this)
261
+ value.addEventListener('change', binding)
262
+ }
263
+ }
264
+ }
265
+ throw new Error(`Unsupported decorator location: ${kind}`)
266
+ }
267
+ }
@@ -1,6 +1,13 @@
1
+ import type { Graph, GraphJson } from '@api-client/graph'
2
+ import type { DomainAssociation } from './DomainAssociation.js'
3
+ import type { DomainEntity } from './DomainEntity.js'
4
+ import type { DomainModel } from './DomainModel.js'
5
+ import type { DomainNamespace } from './DomainNamespace.js'
6
+ import type { DomainProperty } from './DomainProperty.js'
7
+
1
8
  export interface DataDomainRemoveOptions {
2
9
  /**
3
- * When true, the object will be forcebly removed.
10
+ * When true, the object will be forcibly removed.
4
11
  * The resolution defined in the `ImpactResolution` class will be applied.
5
12
  *
6
13
  * For example, when removing an entity that is a parent to another entity, it will
@@ -11,3 +18,169 @@ export interface DataDomainRemoveOptions {
11
18
  */
12
19
  force?: boolean
13
20
  }
21
+
22
+ export interface AssociationAddOptions {
23
+ /**
24
+ * When set, it is the the association target's origin data domain.
25
+ * The key of the target data domain where this target entity is defined.
26
+ * Only used when `key` is specified.
27
+ */
28
+ domain?: string
29
+ /**
30
+ * The key of the association target, if known.
31
+ * If the target of the association is not specified, and the association has no other targets,
32
+ * the association is ignored in the namespace while processing.
33
+ */
34
+ key?: string
35
+ }
36
+
37
+ export interface DomainGraphEdge {
38
+ /**
39
+ * Indicates that the edge is to or from a foreign domain.
40
+ */
41
+ foreign?: boolean
42
+ /**
43
+ * The key of the foreign domain. Always set with the `foreign` property.
44
+ */
45
+ domain?: string
46
+ /**
47
+ * The type of the edge.
48
+ * - `association` The edge is to an association object.
49
+ * - When coming **from** an entiry (the `v` property), that entity owns the association.
50
+ * - When coming **to** an entity (the `w` property), that entity is the target of the association.
51
+ * An association can have multiple targets.
52
+ * - `property` The edge is to a property object. Can only be created between an entity and a property.
53
+ * - The **from** (`v`) is the entity.
54
+ * - The **to** (`w`) is the property.
55
+ * - `parent` The edge is to a parent object.
56
+ * - The **from** (`v`) is the child entity.
57
+ * - The **to** (`w`) is the parent entity.
58
+ */
59
+ type: 'association' | 'property' | 'parent'
60
+ }
61
+
62
+ export type DomainGraphNodeType = DomainNamespace | DomainModel | DomainEntity | DomainProperty | DomainAssociation
63
+
64
+ /**
65
+ * An interface that describes the data domain dependency.
66
+ */
67
+ export interface ForeignDomainDependency {
68
+ /**
69
+ * The system registered key of the foreign domain.
70
+ */
71
+ key: string
72
+ /**
73
+ * The version of the foreign domain used in this domain.
74
+ */
75
+ version: string
76
+ }
77
+
78
+ export interface AssociationTarget {
79
+ /**
80
+ * The key of the target entity.
81
+ */
82
+ key: string
83
+ /**
84
+ * The key of the target data domain.
85
+ * This is only set when the target is in a different data domain.
86
+ */
87
+ domain?: string
88
+ }
89
+
90
+ /**
91
+ * Describes the default value set on a property schema.
92
+ */
93
+ export interface SchemaDefaultValue {
94
+ /**
95
+ * The type of the default value.
96
+ *
97
+ * - `literal` The `value` should be used as-is.
98
+ * - `function` The value represents the name of the function to be used.
99
+ */
100
+ type: 'literal' | 'function'
101
+ /**
102
+ * The actual value type depends on the `type`.
103
+ * It is always a string and it has to be casted to the property's data type.
104
+ */
105
+ value: string
106
+ }
107
+
108
+ /**
109
+ * A general schema definition for a property.
110
+ * This is propagated to all bindings (when they support these properties).
111
+ */
112
+ export interface PropertySchema {
113
+ /**
114
+ * The minimum value of the property.
115
+ *
116
+ * By default it is inclusive value. Use the `exclusiveMinimum` property to make it exclusive.
117
+ *
118
+ * Used with:
119
+ * - string
120
+ * - number
121
+ * - date
122
+ * - time
123
+ * - datetime
124
+ */
125
+ minimum?: number
126
+ /**
127
+ * The maximum value of the property.
128
+ *
129
+ * By default it is inclusive value. Use the `exclusiveMaximum` property to make it exclusive.
130
+ *
131
+ * Used with:
132
+ * - string
133
+ * - number
134
+ * - date
135
+ * - time
136
+ * - datetime
137
+ */
138
+ maximum?: number
139
+ /**
140
+ * When set, the minimum value is exclusive.
141
+ *
142
+ * - When `false`: value ≥ minimum.
143
+ * - When `true`: value > minimum.
144
+ */
145
+ exclusiveMinimum?: boolean
146
+ /**
147
+ * When set, the exclusiveMaximum value is exclusive.
148
+ *
149
+ * - When `false`: value ≤ maximum.
150
+ * - When `true`: value < minimum.
151
+ */
152
+ exclusiveMaximum?: boolean
153
+ /**
154
+ * The multiplier value for a number scalar.
155
+ *
156
+ * Examples:
157
+ * - if `1` then every integer is allowed
158
+ * - if `2` than every even number is allowed
159
+ * - if `0.5` than every number dividable by `0.5` is allowed
160
+ */
161
+ multipleOf?: number
162
+ /**
163
+ * The enum values for the property.
164
+ * They are always encoded as strings. The actual type is defined in the `dataType` property.
165
+ */
166
+ enum?: string[]
167
+ /**
168
+ * The default value for the property.
169
+ * This is always encoded as a string. The actual type is defined in the `dataType` property.
170
+ */
171
+ defaultValue?: SchemaDefaultValue
172
+ /**
173
+ * The example values for the property.
174
+ * They are always encoded as strings. The actual type is defined in the `dataType` property.
175
+ */
176
+ examples?: string[]
177
+ }
178
+
179
+ /**
180
+ * The shortcut type for the data domain graph.
181
+ */
182
+ export type DataDomainGraph = Graph<unknown, DomainGraphNodeType, DomainGraphEdge>
183
+ /**
184
+ * The serialized version of the data domain graph.
185
+ */
186
+ export type SerializedGraph = GraphJson<unknown, object, DomainGraphEdge>
@@ -1,4 +1,6 @@
1
1
  import { ThingKind } from './kinds.js'
2
+ import { ModelValidationOptions } from './types.js'
3
+ import { observed } from '../modeling/observed.js'
2
4
 
3
5
  /**
4
6
  * An interface describing a base metadata of a thing.
@@ -28,31 +30,33 @@ export declare interface IThing {
28
30
  version?: string
29
31
  }
30
32
 
31
- export class Thing {
33
+ export class Thing extends EventTarget {
32
34
  kind = ThingKind
33
35
  /**
34
36
  * The name of the thing.
35
37
  */
36
- name?: string
38
+ @observed() accessor name: string | undefined
37
39
  /**
38
40
  * Optional value to overwrite the `name` in the UI.
39
41
  * The primary descriptive field is the `name`. The display name is only used in the presentation of the data.
40
42
  */
41
- displayName?: string
43
+ @observed() accessor displayName: string | undefined
42
44
  /**
43
45
  * The description of the thing.
44
46
  */
45
- description?: string
47
+ @observed() accessor description: string | undefined
46
48
  /**
47
49
  * The version number of the thing.
48
50
  */
49
- version?: string
51
+ @observed() accessor version: string | undefined
50
52
 
51
53
  /**
52
54
  * Returns one in this order:
53
55
  * - displayName
54
56
  * - name
55
57
  * - 'Unnamed object'
58
+ *
59
+ * @deprecated Use `getLabel()` instead.
56
60
  */
57
61
  get renderLabel(): string {
58
62
  return this.displayName || this.name || 'Unnamed object'
@@ -69,10 +73,42 @@ export class Thing {
69
73
  return thing
70
74
  }
71
75
 
76
+ /**
77
+ * Creates a new thing instance.
78
+ *
79
+ * @param input The thing definition used to restore the state.
80
+ */
81
+ static fromJSON(input: Partial<IThing> = {}, defaults: Partial<IThing> = {}): Thing {
82
+ const result = new Thing()
83
+ const { name, displayName, description, version } = input || {}
84
+ if (typeof name === 'string') {
85
+ result.name = name
86
+ } else if (typeof defaults.name === 'string') {
87
+ result.name = defaults.name
88
+ }
89
+ if (typeof displayName === 'string') {
90
+ result.displayName = displayName
91
+ } else if (typeof defaults.displayName === 'string') {
92
+ result.displayName = defaults.displayName
93
+ }
94
+ if (description) {
95
+ result.description = description
96
+ } else if (typeof defaults.description === 'string') {
97
+ result.description = defaults.description
98
+ }
99
+ if (version) {
100
+ result.version = version
101
+ } else if (typeof defaults.version === 'string') {
102
+ result.version = defaults.version
103
+ }
104
+ return result
105
+ }
106
+
72
107
  /**
73
108
  * @param input The thing definition used to restore the state.
74
109
  */
75
110
  constructor(input?: string | IThing) {
111
+ super()
76
112
  let init: IThing
77
113
  if (typeof input === 'string') {
78
114
  init = JSON.parse(input)
@@ -103,6 +139,22 @@ export class Thing {
103
139
  this.version = version
104
140
  }
105
141
 
142
+ notifyChange(): void {
143
+ this.dispatchEvent(new Event('change'))
144
+ }
145
+
146
+ static validate(input: unknown, options: ModelValidationOptions = {}): boolean {
147
+ const { strict } = options
148
+ if (input && typeof input === 'object') {
149
+ const typed = input as IThing
150
+ if (strict && typed.kind !== ThingKind) {
151
+ return false
152
+ }
153
+ return true
154
+ }
155
+ return false
156
+ }
157
+
106
158
  /**
107
159
  * Checks whether the input is a definition of a server.
108
160
  */
@@ -132,4 +184,17 @@ export class Thing {
132
184
  }
133
185
  return result
134
186
  }
187
+
188
+ /**
189
+ * Returns one in this order:
190
+ * - `this.displayName`
191
+ * - `this.name`
192
+ * - `defaultName`
193
+ * - 'Unnamed object'
194
+ *
195
+ * @param defaultName The default name to use when no other is available.
196
+ */
197
+ getLabel(defaultName?: string): string {
198
+ return this.displayName || this.name || defaultName || 'Unnamed object'
199
+ }
135
200
  }
@@ -2,16 +2,42 @@ export const ProjectFolderKind = 'Core#ProjectFolder'
2
2
  export const ResponseKind = 'Core#HttpResponse'
3
3
  export const HttpResponseKind = 'Core#HttpResponse'
4
4
  export const CertificateFileKind = 'Core#CertificateFile'
5
- export const DataNamespaceKind = 'Core#DataNamespace'
6
- export const DataModelKind = 'Core#DataModel'
7
- export const DataEntityKind = 'Core#DataEntity'
8
- export const DataAssociationKind = 'Core#DataAssociation'
9
- export const DataPropertyKind = 'Core#DataProperty'
10
5
  export const FolderKind = 'Core#Folder'
11
6
  export const ProjectKind = 'Core#Project'
12
7
  export const ThingKind = 'Core#Thing'
13
- export const DataFileKind = 'Core#DataFile'
14
8
  export const DeletionKind = 'Core#Deletion'
15
9
  export const RevisionKind = 'Core#Revision'
16
10
  export const UnresolvedDependencyKind = 'Core#UnresolvedDependency'
17
11
  export const UserKind = 'Core#User'
12
+ export const DomainFileKind = 'Data#DomainFile'
13
+ export const DataDomainKind = 'Data#Domain'
14
+ export const DomainNamespaceKind = 'Domain#Namespace'
15
+ export const DomainModelKind = 'Domain#Model'
16
+ export const DomainEntityKind = 'Domain#Entity'
17
+ export const DomainAssociationKind = 'Domain#Association'
18
+ export const DomainPropertyKind = 'Domain#Property'
19
+
20
+ /**
21
+ * @deprecated Not used anymore.
22
+ */
23
+ export const DataFileKind = 'Core#DataFile'
24
+ /**
25
+ * @deprecated Not used anymore.
26
+ */
27
+ export const DataNamespaceKind = 'Data#DataNamespace'
28
+ /**
29
+ * @deprecated Not used anymore.
30
+ */
31
+ export const DataModelKind = 'Data#DataModel'
32
+ /**
33
+ * @deprecated Not used anymore.
34
+ */
35
+ export const DataEntityKind = 'Data#DataEntity'
36
+ /**
37
+ * @deprecated Not used anymore.
38
+ */
39
+ export const DataAssociationKind = 'Data#DataAssociation'
40
+ /**
41
+ * @deprecated Not used anymore.
42
+ */
43
+ export const DataPropertyKind = 'Data#DataProperty'