warscript 0.0.1-dev.d690591 → 0.0.1-dev.d6e2c10

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 (106) hide show
  1. package/attributes.d.ts +6 -0
  2. package/attributes.lua +17 -1
  3. package/core/types/frame.lua +24 -21
  4. package/core/types/player.d.ts +16 -0
  5. package/core/types/player.lua +60 -15
  6. package/core/types/playerCamera.d.ts +2 -0
  7. package/core/types/playerCamera.lua +123 -5
  8. package/core/types/tileCell.d.ts +11 -1
  9. package/core/types/tileCell.lua +97 -0
  10. package/core/types/timer.d.ts +3 -1
  11. package/core/types/timer.lua +27 -2
  12. package/decl/native.d.ts +6 -4
  13. package/destroyable.d.ts +1 -0
  14. package/destroyable.lua +9 -0
  15. package/engine/behavior.d.ts +12 -1
  16. package/engine/behavior.lua +172 -70
  17. package/engine/behaviour/ability/apply-buff.lua +5 -5
  18. package/engine/behaviour/ability/emulate-impact.d.ts +1 -1
  19. package/engine/behaviour/ability/emulate-impact.lua +11 -3
  20. package/engine/behaviour/ability/remove-buffs.d.ts +9 -0
  21. package/engine/behaviour/ability/remove-buffs.lua +21 -0
  22. package/engine/behaviour/ability/restore-mana.d.ts +1 -1
  23. package/engine/behaviour/ability/restore-mana.lua +6 -6
  24. package/engine/behaviour/ability.d.ts +2 -1
  25. package/engine/behaviour/ability.lua +10 -18
  26. package/engine/behaviour/unit/stun-immunity.d.ts +11 -5
  27. package/engine/behaviour/unit/stun-immunity.lua +53 -28
  28. package/engine/behaviour/unit.d.ts +39 -3
  29. package/engine/behaviour/unit.lua +259 -6
  30. package/engine/buff.d.ts +14 -6
  31. package/engine/buff.lua +145 -97
  32. package/engine/internal/ability.d.ts +7 -1
  33. package/engine/internal/ability.lua +49 -9
  34. package/engine/internal/item/ability.lua +63 -11
  35. package/engine/internal/item+owner.lua +12 -6
  36. package/engine/internal/item.d.ts +16 -16
  37. package/engine/internal/item.lua +135 -49
  38. package/engine/internal/misc/frame-coordinates.d.ts +2 -0
  39. package/engine/internal/misc/frame-coordinates.lua +21 -0
  40. package/engine/internal/misc/get-terrain-z.d.ts +2 -0
  41. package/engine/internal/misc/get-terrain-z.lua +11 -0
  42. package/engine/internal/misc/player-local-handle.d.ts +2 -0
  43. package/engine/internal/misc/player-local-handle.lua +5 -0
  44. package/engine/internal/unit/ability.d.ts +35 -0
  45. package/engine/internal/unit/ability.lua +98 -9
  46. package/engine/internal/unit/allowed-targets.d.ts +1 -1
  47. package/engine/internal/unit/allowed-targets.lua +9 -1
  48. package/engine/internal/unit/fly-height.d.ts +7 -0
  49. package/engine/internal/unit/fly-height.lua +20 -0
  50. package/engine/internal/unit/main-selected.lua +12 -27
  51. package/engine/internal/unit/order.d.ts +20 -0
  52. package/engine/internal/unit/order.lua +136 -0
  53. package/engine/internal/unit/scale.d.ts +7 -0
  54. package/engine/internal/unit/scale.lua +20 -0
  55. package/engine/internal/unit+ability.lua +10 -1
  56. package/engine/internal/unit-missile-launch.lua +45 -14
  57. package/engine/internal/unit.d.ts +29 -18
  58. package/engine/internal/unit.lua +257 -140
  59. package/engine/local-client.d.ts +2 -0
  60. package/engine/local-client.lua +30 -0
  61. package/engine/object-data/auxiliary/armor-type.d.ts +11 -0
  62. package/engine/object-data/auxiliary/armor-type.lua +46 -0
  63. package/engine/object-data/entry/ability-type/permanent-invisibility.d.ts +8 -0
  64. package/engine/object-data/entry/ability-type/permanent-invisibility.lua +26 -0
  65. package/engine/object-data/entry/ability-type.lua +5 -4
  66. package/engine/object-data/entry/destructible-type.d.ts +17 -1
  67. package/engine/object-data/entry/destructible-type.lua +90 -0
  68. package/engine/object-data/entry/unit-type.d.ts +15 -2
  69. package/engine/object-data/entry/unit-type.lua +135 -33
  70. package/engine/object-field/ability.d.ts +3 -3
  71. package/engine/object-field/ability.lua +7 -6
  72. package/engine/object-field/unit.d.ts +24 -1
  73. package/engine/object-field/unit.lua +91 -0
  74. package/engine/object-field.d.ts +15 -6
  75. package/engine/object-field.lua +225 -124
  76. package/engine/random.d.ts +9 -0
  77. package/engine/random.lua +13 -0
  78. package/engine/standard/fields/ability.d.ts +2 -2
  79. package/engine/standard/fields/ability.lua +2 -2
  80. package/engine/standard/fields/unit.d.ts +6 -0
  81. package/engine/standard/fields/unit.lua +11 -0
  82. package/engine/synchronization.d.ts +11 -0
  83. package/engine/synchronization.lua +77 -0
  84. package/engine/text-tag.d.ts +36 -2
  85. package/engine/text-tag.lua +250 -10
  86. package/engine/unit.d.ts +3 -0
  87. package/engine/unit.lua +3 -0
  88. package/net/socket.lua +1 -1
  89. package/objutil/buff.lua +1 -1
  90. package/package.json +2 -2
  91. package/patch-lualib.lua +1 -1
  92. package/utility/arrays.d.ts +1 -0
  93. package/utility/arrays.lua +8 -0
  94. package/utility/callback-array.d.ts +17 -0
  95. package/utility/callback-array.lua +61 -0
  96. package/utility/functions.d.ts +7 -0
  97. package/utility/functions.lua +12 -0
  98. package/utility/linked-set.d.ts +1 -0
  99. package/utility/linked-set.lua +19 -1
  100. package/utility/lua-maps.d.ts +12 -2
  101. package/utility/lua-maps.lua +37 -2
  102. package/utility/lua-sets.d.ts +1 -0
  103. package/utility/lua-sets.lua +4 -0
  104. package/utility/types.d.ts +3 -0
  105. package/core/types/order.d.ts +0 -25
  106. package/core/types/order.lua +0 -55
@@ -12,7 +12,7 @@ import { ReadonlyNonEmptyLinkedSet } from "../../utility/linked-set";
12
12
  export declare abstract class AbilityField<ValueType extends number | string | boolean = number | string | boolean, NativeFieldType extends jabilityfield = jabilityfield> extends ObjectField<AbilityType, Ability, ValueType, NativeFieldType> {
13
13
  protected get instanceClass(): typeof Ability;
14
14
  protected getObjectDataEntryId(instance: Ability): AbilityTypeId;
15
- protected hasNativeFieldValue(instance: Ability): boolean;
15
+ protected hasNativeFieldValue(abilityTypeId: AbilityTypeId): boolean;
16
16
  static get valueChangeEvent(): ObjectFieldValueChangeEvent<ReadonlyObjectFieldType<AbilityField>>;
17
17
  }
18
18
  export declare class AbilityBooleanField extends AbilityField<boolean, jabilitybooleanfield> {
@@ -48,7 +48,7 @@ export declare class AbilityStringField extends AbilityField<string, jabilitystr
48
48
  export declare abstract class AbilityArrayField<ValueType extends number | string | boolean = number | string | boolean, NativeFieldType extends jabilityfield = jabilityfield> extends ObjectArrayField<AbilityType, Ability, ValueType, NativeFieldType> {
49
49
  protected get instanceClass(): typeof Ability;
50
50
  protected getObjectDataEntryId(instance: Ability): AbilityTypeId;
51
- protected hasNativeFieldValue(instance: Ability): boolean;
51
+ protected hasNativeFieldValue(abilityTypeId: AbilityTypeId): boolean;
52
52
  }
53
53
  export declare class AbilityStringArrayField extends AbilityArrayField<string, jabilitystringlevelfield> {
54
54
  protected get defaultValue(): string;
@@ -68,7 +68,7 @@ export declare abstract class AbilityLevelField<ValueType extends number | strin
68
68
  protected get instanceClass(): typeof Ability;
69
69
  protected getLevelCount(entry: AbilityType | Ability): number;
70
70
  protected getObjectDataEntryId(instance: Ability): AbilityTypeId;
71
- protected hasNativeFieldValue(instance: Ability): boolean;
71
+ protected hasNativeFieldValue(abilityTypeId: AbilityTypeId): boolean;
72
72
  static get valueChangeEvent(): ObjectLevelFieldValueChangeEvent<ReadonlyObjectLevelFieldType<AbilityLevelField>>;
73
73
  }
74
74
  export declare class AbilityBooleanLevelField extends AbilityLevelField<boolean, boolean, jabilityintegerlevelfield> {
@@ -7,6 +7,7 @@ local __TS__InstanceOf = ____lualib.__TS__InstanceOf
7
7
  local ____exports = {}
8
8
  local ____ability = require("engine.internal.ability")
9
9
  local Ability = ____ability.Ability
10
+ local abilityTypeHasField = ____ability.abilityTypeHasField
10
11
  local ____object_2Dfield = require("engine.object-field")
11
12
  local ObjectArrayField = ____object_2Dfield.ObjectArrayField
12
13
  local ObjectField = ____object_2Dfield.ObjectField
@@ -29,8 +30,8 @@ __TS__ClassExtends(AbilityField, ObjectField)
29
30
  function AbilityField.prototype.getObjectDataEntryId(self, instance)
30
31
  return instance.typeId
31
32
  end
32
- function AbilityField.prototype.hasNativeFieldValue(self, instance)
33
- return instance:hasField(self.nativeField)
33
+ function AbilityField.prototype.hasNativeFieldValue(self, abilityTypeId)
34
+ return abilityTypeHasField(abilityTypeId, self.nativeField)
34
35
  end
35
36
  __TS__SetDescriptor(
36
37
  AbilityField.prototype,
@@ -197,8 +198,8 @@ __TS__ClassExtends(AbilityArrayField, ObjectArrayField)
197
198
  function AbilityArrayField.prototype.getObjectDataEntryId(self, instance)
198
199
  return instance.typeId
199
200
  end
200
- function AbilityArrayField.prototype.hasNativeFieldValue(self, instance)
201
- return instance:hasField(self.nativeField)
201
+ function AbilityArrayField.prototype.hasNativeFieldValue(self, abilityTypeId)
202
+ return abilityTypeHasField(abilityTypeId, self.nativeField)
202
203
  end
203
204
  __TS__SetDescriptor(
204
205
  AbilityArrayField.prototype,
@@ -269,8 +270,8 @@ end
269
270
  function AbilityLevelField.prototype.getObjectDataEntryId(self, instance)
270
271
  return instance.typeId
271
272
  end
272
- function AbilityLevelField.prototype.hasNativeFieldValue(self, instance)
273
- return instance:hasField(self.nativeField)
273
+ function AbilityLevelField.prototype.hasNativeFieldValue(self, abilityTypeId)
274
+ return abilityTypeHasField(abilityTypeId, self.nativeField)
274
275
  end
275
276
  __TS__SetDescriptor(
276
277
  AbilityLevelField.prototype,
@@ -1,37 +1,43 @@
1
1
  /** @noSelfInFile */
2
2
  import { Unit } from "../internal/unit";
3
- import { ObjectField, ObjectLevelField, ObjectLevelFieldValueChangeEvent, ReadonlyObjectLevelFieldType } from "../object-field";
3
+ import { ObjectField, ObjectFieldValueChangeEvent, ObjectLevelField, ObjectLevelFieldValueChangeEvent, ReadonlyObjectFieldType, ReadonlyObjectLevelFieldType } from "../object-field";
4
4
  import { UnitType, UnitTypeId } from "../object-data/entry/unit-type";
5
5
  import { ReadonlyNonEmptyLinkedSet } from "../../utility/linked-set";
6
6
  import { AttackType } from "../object-data/auxiliary/attack-type";
7
+ import { UnitClassifications } from "../object-data/auxiliary/unit-classification";
7
8
  export declare abstract class UnitField<ValueType extends number | string | boolean = number | string | boolean, NativeFieldType = any> extends ObjectField<UnitType, Unit, ValueType, NativeFieldType> {
8
9
  protected get instanceClass(): typeof Unit;
9
10
  protected getObjectDataEntryId(instance: Unit): UnitTypeId;
10
11
  protected hasNativeFieldValue(): boolean;
12
+ static get valueChangeEvent(): ObjectFieldValueChangeEvent<ReadonlyObjectFieldType<UnitField>>;
11
13
  }
12
14
  export declare class UnitBooleanField extends UnitField<boolean, junitbooleanfield> {
13
15
  protected get defaultValue(): boolean;
14
16
  protected getNativeFieldById(id: number): junitbooleanfield;
15
17
  protected getNativeFieldValue(instance: Unit): boolean;
16
18
  protected setNativeFieldValue(instance: Unit, value: boolean): boolean;
19
+ static get valueChangeEvent(): ObjectFieldValueChangeEvent<ReadonlyObjectFieldType<UnitBooleanField>>;
17
20
  }
18
21
  export declare class UnitFloatField extends UnitField<number, junitrealfield> {
19
22
  protected get defaultValue(): number;
20
23
  protected getNativeFieldById(id: number): junitrealfield;
21
24
  protected getNativeFieldValue(instance: Unit): number;
22
25
  protected setNativeFieldValue(instance: Unit, value: number): boolean;
26
+ static get valueChangeEvent(): ObjectFieldValueChangeEvent<ReadonlyObjectFieldType<UnitFloatField>>;
23
27
  }
24
28
  export declare class UnitIntegerField extends UnitField<number, junitintegerfield> {
25
29
  protected get defaultValue(): number;
26
30
  protected getNativeFieldById(id: number): junitintegerfield;
27
31
  protected getNativeFieldValue(instance: Unit): number;
28
32
  protected setNativeFieldValue(instance: Unit, value: number): boolean;
33
+ static get valueChangeEvent(): ObjectFieldValueChangeEvent<ReadonlyObjectFieldType<UnitIntegerField>>;
29
34
  }
30
35
  export declare class UnitStringField extends UnitField<string, junitstringfield> {
31
36
  protected get defaultValue(): string;
32
37
  protected getNativeFieldById(id: number): junitstringfield;
33
38
  protected getNativeFieldValue(instance: Unit): string;
34
39
  protected setNativeFieldValue(instance: Unit, value: string): boolean;
40
+ static get valueChangeEvent(): ObjectFieldValueChangeEvent<ReadonlyObjectFieldType<UnitStringField>>;
35
41
  }
36
42
  type junitweaponfield = junitweaponbooleanfield | junitweaponintegerfield | junitweaponrealfield | junitweaponstringfield;
37
43
  export declare abstract class UnitWeaponField<ValueType extends number | string | boolean = number | string | boolean, InputValueType extends ValueType = never, NativeFieldType extends junitweaponfield = junitweaponfield> extends ObjectLevelField<UnitType, Unit, ValueType, InputValueType, NativeFieldType> {
@@ -56,4 +62,21 @@ export declare abstract class UnitEnumWeaponField<T extends number> extends Unit
56
62
  export declare class UnitAttackTypeWeaponField extends UnitEnumWeaponField<AttackType> {
57
63
  protected values: ReadonlyNonEmptyLinkedSet<AttackType>;
58
64
  }
65
+ export declare class UnitClassificationsField extends UnitField<UnitClassifications, junitintegerfield> {
66
+ protected get defaultValue(): UnitClassifications;
67
+ protected getNativeFieldById(id: number): junitintegerfield;
68
+ protected getNativeFieldValue(instance: Unit): UnitClassifications;
69
+ protected setNativeFieldValue(instance: Unit, value: UnitClassifications): boolean;
70
+ }
71
+ export declare class UnitFlyHeightField extends UnitFloatField {
72
+ protected getNativeFieldValue(instance: Unit): number;
73
+ protected setNativeFieldValue(instance: Unit, value: number): boolean;
74
+ }
75
+ export declare class UnitPropulsionWindowField extends UnitFloatField {
76
+ protected getNativeFieldValue(instance: Unit): number;
77
+ protected setNativeFieldValue(instance: Unit, value: number): boolean;
78
+ }
79
+ export declare class UnitScalingValueField extends UnitFloatField {
80
+ protected setNativeFieldValue(instance: Unit, value: number): boolean;
81
+ }
59
82
  export {};
@@ -18,6 +18,11 @@ local convertUnitStringField = ConvertUnitStringField
18
18
  local convertUnitWeaponIntegerField = ConvertUnitWeaponIntegerField
19
19
  local getUnitWeaponIntegerField = BlzGetUnitWeaponIntegerField
20
20
  local setUnitWeaponIntegerField = BlzSetUnitWeaponIntegerField
21
+ local getUnitFlyHeight = GetUnitFlyHeight
22
+ local setUnitFlyHeight = SetUnitFlyHeight
23
+ local getUnitPropulsionWindow = GetUnitPropWindow
24
+ local setUnitPropulsionWindow = SetUnitPropWindow
25
+ local setUnitScale = SetUnitScale
21
26
  ____exports.UnitField = __TS__Class()
22
27
  local UnitField = ____exports.UnitField
23
28
  UnitField.name = "UnitField"
@@ -36,6 +41,13 @@ __TS__SetDescriptor(
36
41
  end},
37
42
  true
38
43
  )
44
+ __TS__ObjectDefineProperty(
45
+ UnitField,
46
+ "valueChangeEvent",
47
+ {get = function(self)
48
+ return self:getOrCreateValueChangeEvent()
49
+ end}
50
+ )
39
51
  ____exports.UnitBooleanField = __TS__Class()
40
52
  local UnitBooleanField = ____exports.UnitBooleanField
41
53
  UnitBooleanField.name = "UnitBooleanField"
@@ -57,6 +69,13 @@ __TS__SetDescriptor(
57
69
  end},
58
70
  true
59
71
  )
72
+ __TS__ObjectDefineProperty(
73
+ UnitBooleanField,
74
+ "valueChangeEvent",
75
+ {get = function(self)
76
+ return self:getOrCreateValueChangeEvent()
77
+ end}
78
+ )
60
79
  ____exports.UnitFloatField = __TS__Class()
61
80
  local UnitFloatField = ____exports.UnitFloatField
62
81
  UnitFloatField.name = "UnitFloatField"
@@ -78,6 +97,13 @@ __TS__SetDescriptor(
78
97
  end},
79
98
  true
80
99
  )
100
+ __TS__ObjectDefineProperty(
101
+ UnitFloatField,
102
+ "valueChangeEvent",
103
+ {get = function(self)
104
+ return self:getOrCreateValueChangeEvent()
105
+ end}
106
+ )
81
107
  ____exports.UnitIntegerField = __TS__Class()
82
108
  local UnitIntegerField = ____exports.UnitIntegerField
83
109
  UnitIntegerField.name = "UnitIntegerField"
@@ -99,6 +125,13 @@ __TS__SetDescriptor(
99
125
  end},
100
126
  true
101
127
  )
128
+ __TS__ObjectDefineProperty(
129
+ UnitIntegerField,
130
+ "valueChangeEvent",
131
+ {get = function(self)
132
+ return self:getOrCreateValueChangeEvent()
133
+ end}
134
+ )
102
135
  ____exports.UnitStringField = __TS__Class()
103
136
  local UnitStringField = ____exports.UnitStringField
104
137
  UnitStringField.name = "UnitStringField"
@@ -120,6 +153,13 @@ __TS__SetDescriptor(
120
153
  end},
121
154
  true
122
155
  )
156
+ __TS__ObjectDefineProperty(
157
+ UnitStringField,
158
+ "valueChangeEvent",
159
+ {get = function(self)
160
+ return self:getOrCreateValueChangeEvent()
161
+ end}
162
+ )
123
163
  ____exports.UnitWeaponField = __TS__Class()
124
164
  local UnitWeaponField = ____exports.UnitWeaponField
125
165
  UnitWeaponField.name = "UnitWeaponField"
@@ -215,4 +255,55 @@ function UnitAttackTypeWeaponField.prototype.____constructor(self, ...)
215
255
  6
216
256
  )
217
257
  end
258
+ ____exports.UnitClassificationsField = __TS__Class()
259
+ local UnitClassificationsField = ____exports.UnitClassificationsField
260
+ UnitClassificationsField.name = "UnitClassificationsField"
261
+ __TS__ClassExtends(UnitClassificationsField, ____exports.UnitField)
262
+ function UnitClassificationsField.prototype.getNativeFieldById(self, id)
263
+ return convertUnitIntegerField(id)
264
+ end
265
+ function UnitClassificationsField.prototype.getNativeFieldValue(self, instance)
266
+ return instance:getField(self.nativeField)
267
+ end
268
+ function UnitClassificationsField.prototype.setNativeFieldValue(self, instance, value)
269
+ return instance:setField(self.nativeField, value)
270
+ end
271
+ __TS__SetDescriptor(
272
+ UnitClassificationsField.prototype,
273
+ "defaultValue",
274
+ {get = function(self)
275
+ return 0
276
+ end},
277
+ true
278
+ )
279
+ ____exports.UnitFlyHeightField = __TS__Class()
280
+ local UnitFlyHeightField = ____exports.UnitFlyHeightField
281
+ UnitFlyHeightField.name = "UnitFlyHeightField"
282
+ __TS__ClassExtends(UnitFlyHeightField, ____exports.UnitFloatField)
283
+ function UnitFlyHeightField.prototype.getNativeFieldValue(self, instance)
284
+ return getUnitFlyHeight(instance.handle)
285
+ end
286
+ function UnitFlyHeightField.prototype.setNativeFieldValue(self, instance, value)
287
+ setUnitFlyHeight(instance.handle, value, 100000)
288
+ return true
289
+ end
290
+ ____exports.UnitPropulsionWindowField = __TS__Class()
291
+ local UnitPropulsionWindowField = ____exports.UnitPropulsionWindowField
292
+ UnitPropulsionWindowField.name = "UnitPropulsionWindowField"
293
+ __TS__ClassExtends(UnitPropulsionWindowField, ____exports.UnitFloatField)
294
+ function UnitPropulsionWindowField.prototype.getNativeFieldValue(self, instance)
295
+ return getUnitPropulsionWindow(instance.handle)
296
+ end
297
+ function UnitPropulsionWindowField.prototype.setNativeFieldValue(self, instance, value)
298
+ setUnitPropulsionWindow(instance.handle, value)
299
+ return true
300
+ end
301
+ ____exports.UnitScalingValueField = __TS__Class()
302
+ local UnitScalingValueField = ____exports.UnitScalingValueField
303
+ UnitScalingValueField.name = "UnitScalingValueField"
304
+ __TS__ClassExtends(UnitScalingValueField, ____exports.UnitFloatField)
305
+ function UnitScalingValueField.prototype.setNativeFieldValue(self, instance, value)
306
+ setUnitScale(instance.handle, value, value, value)
307
+ return UnitScalingValueField.____super.prototype.setNativeFieldValue(self, instance, value)
308
+ end
218
309
  return ____exports
@@ -5,9 +5,10 @@ import { ObjectDataEntry, ObjectDataEntryIdType, ObjectDataEntryLevelFieldValueS
5
5
  export type ObjectFieldId = number & {
6
6
  readonly __objectDataEntryFieldId: unique symbol;
7
7
  };
8
- export type ObjectFieldConstructor<T extends ObjectFieldBase<any, any, any, any>> = OmitConstructor<typeof ObjectFieldBase> & (new (id: number) => T);
8
+ export type ObjectFieldConstructor<T extends ObjectFieldBase<any, any, any, any>> = OmitConstructor<typeof ObjectFieldBase> & (new (id: number, isGlobal?: boolean) => T);
9
9
  export type ObjectFieldAbstractConstructor<T extends ObjectFieldBase<any, any, any, any>> = OmitConstructor<typeof ObjectFieldBase> & (abstract new (id: number) => T);
10
10
  declare abstract class ObjectFieldBase<ObjectDataEntryType extends ObjectDataEntry, InstanceType extends AnyNotNil, ValueType, NativeFieldType> {
11
+ readonly isGlobal: boolean;
11
12
  protected abstract readonly instanceClass: AbstractConstructor<InstanceType> | Function;
12
13
  supports(instance: AnyNotNil): instance is InstanceType & {
13
14
  readonly __oneSidedTypeGuard: unique symbol;
@@ -16,10 +17,10 @@ declare abstract class ObjectFieldBase<ObjectDataEntryType extends ObjectDataEnt
16
17
  readonly id: ObjectFieldId;
17
18
  protected abstract getNativeFieldById(id: number): NativeFieldType;
18
19
  protected abstract getObjectDataEntryId(instance: InstanceType): ObjectDataEntryIdType<ObjectDataEntryType>;
19
- protected abstract hasNativeFieldValue(instance: InstanceType): boolean;
20
- hasValue(instance: InstanceType): boolean;
21
- constructor(id: number);
22
- static create<T extends ObjectFieldBase<any, any, any, any>>(this: ObjectFieldConstructor<T>, id?: number): T & symbol;
20
+ protected abstract hasNativeFieldValue(objectDataEntryId: ObjectDataEntryIdType<ObjectDataEntryType>): boolean;
21
+ hasValue(objectDataEntryId: ObjectDataEntryIdType<ObjectDataEntryType>): boolean;
22
+ constructor(id: number, isGlobal?: boolean);
23
+ static create<T extends ObjectFieldBase<any, any, any, any>>(this: ObjectFieldConstructor<T>, id?: number, isGlobal?: boolean): T & symbol;
23
24
  static of<T extends ObjectFieldBase<any, any, any, any>>(this: ObjectFieldAbstractConstructor<T>, id: number): T | undefined;
24
25
  }
25
26
  export type ObjectFieldValueChangeEvent<T extends ObjectField<any, any, any, any> | ReadonlyObjectFieldType<ObjectField<any, any, any, any>>> = T extends ObjectField<any, infer InstanceType, infer ValueType, any> ? DispatchingEvent<[
@@ -35,7 +36,8 @@ export type ObjectFieldValueChangeEvent<T extends ObjectField<any, any, any, any
35
36
  ]> : never;
36
37
  export type ReadonlyObjectFieldType<T extends ObjectField<any, any, any, any>> = Omit<T, "setValue" | "removeValue" | "trySetValue">;
37
38
  type ReadonlyObjectFieldConstructor<T extends ObjectField> = OmitConstructor<typeof ObjectField> & (abstract new (...args: any[]) => ReadonlyObjectFieldType<T>);
38
- type ObjectFieldModifier<InstanceType extends AnyNotNil, ValueType extends number | string | boolean> = (instance: InstanceType, currentValue: ValueType, originalValue: ValueType) => ValueType;
39
+ export type ObjectFieldModifier<InstanceType extends AnyNotNil, ValueType extends number | string | boolean> = (instance: InstanceType, currentValue: ValueType, originalValue: ValueType) => ValueType;
40
+ export type ObjectLevelFieldModifier<InstanceType extends AnyNotNil, ValueType extends number | string | boolean> = (instance: InstanceType, level: number, currentValue: ValueType, originalValue: ValueType) => ValueType;
39
41
  export declare abstract class ObjectField<ObjectDataEntryType extends ObjectDataEntry = ObjectDataEntry, InstanceType extends AnyNotNil = AnyNotNil, ValueType extends number | string | boolean = number | string | boolean, NativeFieldType = unknown> extends ObjectFieldBase<ObjectDataEntryType, InstanceType, ValueType, NativeFieldType> {
40
42
  protected abstract readonly defaultValue: ValueType;
41
43
  protected abstract getNativeFieldValue(instance: InstanceType): ValueType;
@@ -79,13 +81,20 @@ export declare abstract class ObjectArrayField<ObjectDataEntryType extends Objec
79
81
  setValue(entry: ObjectDataEntryType | InstanceType, value: ValueType[]): boolean;
80
82
  }
81
83
  export declare abstract class ObjectLevelField<ObjectDataEntryType extends ObjectDataEntry = ObjectDataEntry, InstanceType extends AnyNotNil = AnyNotNil, ValueType extends number | string | boolean = number | string | boolean, InputValueType extends ValueType = never, NativeFieldType = unknown> extends ObjectFieldBase<ObjectDataEntryType, InstanceType, ValueType[], NativeFieldType> {
84
+ private originalValueByLevelByInstance?;
85
+ private modifiersByInstance?;
82
86
  protected abstract readonly defaultValue: ValueType;
83
87
  protected abstract getNativeFieldValue(instance: InstanceType, level: number): ValueType;
84
88
  protected abstract setNativeFieldValue(instance: InstanceType, level: number, value: ValueType): boolean;
85
89
  protected abstract getLevelCount(entry: ObjectDataEntryType | InstanceType): number;
86
90
  getValue<LevelType extends [number] | []>(entry: ObjectDataEntryType | InstanceType, ...[level]: LevelType): LevelType extends [number] ? ValueType : ValueType[];
87
91
  setValue(entry: ObjectDataEntryType | InstanceType, ...[levelOrValue, value]: [value: ObjectDataEntryLevelFieldValueSupplier<InputValueType, ValueType>] | [level: number, value: InputValueType]): boolean;
92
+ applyModifier(instance: InstanceType, modifier: ObjectLevelFieldModifier<InstanceType, ValueType>): void;
93
+ removeModifier(instance: InstanceType, modifier: ObjectLevelFieldModifier<InstanceType, ValueType>): boolean;
88
94
  trySetValue(entry: ObjectDataEntryType | InstanceType, levelOrValue: number | unknown, value?: unknown): boolean;
95
+ private getActualValue;
96
+ private setActualValue;
97
+ private calculateActualValue;
89
98
  private invokeValueChangeEvent;
90
99
  private invokeValueChangeEventRecursive;
91
100
  protected static getOrCreateValueChangeEvent<T extends ObjectLevelField, R extends ReadonlyObjectLevelFieldType<T>>(this: ReadonlyObjectLevelFieldConstructor<T>): ObjectLevelFieldValueChangeEvent<R>;