@urso/core 0.1.92 → 0.1.97

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 (147) hide show
  1. package/.babelrc +11 -11
  2. package/README.md +10 -10
  3. package/build/js/index.js +1 -1
  4. package/build/js/index.js.LICENSE.txt +41 -39
  5. package/package.json +52 -49
  6. package/src/js/app.js +76 -75
  7. package/src/js/components/_info.js +8 -8
  8. package/src/js/components/base/_info.js +3 -3
  9. package/src/js/components/base/controller.js +78 -78
  10. package/src/js/components/debug/_info.js +6 -6
  11. package/src/js/components/debug/controller.js +38 -38
  12. package/src/js/components/debug/coords.js +23 -23
  13. package/src/js/components/debug/fps.js +34 -34
  14. package/src/js/components/debug/template.js +33 -33
  15. package/src/js/components/deviceRotate/_info.js +3 -3
  16. package/src/js/components/deviceRotate/controller.js +86 -86
  17. package/src/js/components/fullscreen/_info.js +6 -6
  18. package/src/js/components/fullscreen/android.js +104 -104
  19. package/src/js/components/fullscreen/controller.js +64 -64
  20. package/src/js/components/fullscreen/desktop.js +49 -49
  21. package/src/js/components/fullscreen/ios.js +111 -111
  22. package/src/js/components/loader/_info.js +4 -4
  23. package/src/js/components/loader/controller.js +66 -66
  24. package/src/js/components/loader/template.js +70 -70
  25. package/src/js/components/soundInitialPopup/_info.js +3 -3
  26. package/src/js/components/soundInitialPopup/controller.js +42 -42
  27. package/src/js/components/soundInitialPopup/template.js +109 -109
  28. package/src/js/components/stateDriven/_info.js +3 -3
  29. package/src/js/components/stateDriven/controller.js +52 -52
  30. package/src/js/config/load.js +5 -5
  31. package/src/js/config/main.js +9 -8
  32. package/src/js/extra/_info.js +23 -22
  33. package/src/js/extra/browserEvents.js +32 -32
  34. package/src/js/index.js +8 -8
  35. package/src/js/lib/_info.js +13 -13
  36. package/src/js/lib/cache.js +98 -98
  37. package/src/js/lib/composition.js +89 -89
  38. package/src/js/lib/device.js +1276 -1276
  39. package/src/js/lib/helper.js +524 -513
  40. package/src/js/lib/loader.js +121 -100
  41. package/src/js/lib/localData.js +15 -15
  42. package/src/js/lib/logger.js +22 -22
  43. package/src/js/lib/math.js +20 -20
  44. package/src/js/lib/objectPool.js +54 -54
  45. package/src/js/lib/time.js +18 -18
  46. package/src/js/lib/tween.js +147 -147
  47. package/src/js/modules/_info.js +11 -11
  48. package/src/js/modules/assets/_info.js +7 -7
  49. package/src/js/modules/assets/baseModel.js +18 -18
  50. package/src/js/modules/assets/config.js +35 -25
  51. package/src/js/modules/assets/controller.js +37 -21
  52. package/src/js/modules/assets/models/_info.js +12 -12
  53. package/src/js/modules/assets/models/atlas.js +8 -8
  54. package/src/js/modules/assets/models/audiosprite.js +27 -27
  55. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  56. package/src/js/modules/assets/models/container.js +16 -16
  57. package/src/js/modules/assets/models/dragonBones.js +26 -26
  58. package/src/js/modules/assets/models/font.js +8 -8
  59. package/src/js/modules/assets/models/image.js +14 -14
  60. package/src/js/modules/assets/models/json.js +8 -8
  61. package/src/js/modules/assets/models/sound.js +14 -14
  62. package/src/js/modules/assets/models/spine.js +8 -8
  63. package/src/js/modules/assets/service.js +330 -303
  64. package/src/js/modules/instances/_info.js +3 -3
  65. package/src/js/modules/instances/controller.js +218 -218
  66. package/src/js/modules/logic/_info.js +5 -5
  67. package/src/js/modules/logic/buttons.js +120 -120
  68. package/src/js/modules/logic/config/_info.js +3 -3
  69. package/src/js/modules/logic/config/buttons.js +63 -63
  70. package/src/js/modules/logic/config/sounds.js +23 -23
  71. package/src/js/modules/logic/controller.js +48 -48
  72. package/src/js/modules/logic/sounds.js +96 -96
  73. package/src/js/modules/objects/_info.js +11 -11
  74. package/src/js/modules/objects/baseModel.js +161 -161
  75. package/src/js/modules/objects/cache.js +99 -99
  76. package/src/js/modules/objects/controller.js +115 -115
  77. package/src/js/modules/objects/create.js +246 -231
  78. package/src/js/modules/objects/find.js +140 -140
  79. package/src/js/modules/objects/models/_info.js +25 -20
  80. package/src/js/modules/objects/models/atlasImage.js +50 -50
  81. package/src/js/modules/objects/models/bitmapText.js +23 -23
  82. package/src/js/modules/objects/models/button.js +184 -184
  83. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  84. package/src/js/modules/objects/models/checkbox.js +91 -0
  85. package/src/js/modules/objects/models/collection.js +54 -54
  86. package/src/js/modules/objects/models/component.js +44 -44
  87. package/src/js/modules/objects/models/container.js +19 -19
  88. package/src/js/modules/objects/models/dragonBones.js +250 -250
  89. package/src/js/modules/objects/models/emitter.js +54 -54
  90. package/src/js/modules/objects/models/graphics.js +38 -38
  91. package/src/js/modules/objects/models/group.js +19 -19
  92. package/src/js/modules/objects/models/hitArea.js +104 -104
  93. package/src/js/modules/objects/models/image.js +34 -34
  94. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  95. package/src/js/modules/objects/models/mask.js +38 -38
  96. package/src/js/modules/objects/models/scrollbox.js +62 -0
  97. package/src/js/modules/objects/models/slider.js +154 -0
  98. package/src/js/modules/objects/models/spine.js +83 -83
  99. package/src/js/modules/objects/models/text.js +38 -38
  100. package/src/js/modules/objects/models/textInput.js +55 -0
  101. package/src/js/modules/objects/models/toggle.js +165 -0
  102. package/src/js/modules/objects/models/world.js +19 -19
  103. package/src/js/modules/objects/propertyAdapter.js +421 -416
  104. package/src/js/modules/objects/proxy.js +179 -179
  105. package/src/js/modules/objects/styles.js +116 -116
  106. package/src/js/modules/observer/_info.js +4 -4
  107. package/src/js/modules/observer/controller.js +99 -99
  108. package/src/js/modules/observer/events.js +31 -28
  109. package/src/js/modules/scenes/_info.js +8 -8
  110. package/src/js/modules/scenes/controller.js +34 -34
  111. package/src/js/modules/scenes/model.js +35 -35
  112. package/src/js/modules/scenes/pixiWrapper.js +194 -194
  113. package/src/js/modules/scenes/resolutions.js +161 -161
  114. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  115. package/src/js/modules/scenes/service.js +84 -84
  116. package/src/js/modules/soundManager/_info.js +3 -3
  117. package/src/js/modules/soundManager/controller.js +99 -99
  118. package/src/js/modules/soundManager/soundSprite.js +202 -202
  119. package/src/js/modules/statesManager/_info.js +12 -12
  120. package/src/js/modules/statesManager/action.js +113 -113
  121. package/src/js/modules/statesManager/actionModel.js +47 -47
  122. package/src/js/modules/statesManager/actions/_info.js +3 -3
  123. package/src/js/modules/statesManager/all.js +23 -23
  124. package/src/js/modules/statesManager/configActions.js +54 -54
  125. package/src/js/modules/statesManager/configStates.js +86 -86
  126. package/src/js/modules/statesManager/controller.js +91 -91
  127. package/src/js/modules/statesManager/helper.js +37 -37
  128. package/src/js/modules/statesManager/race.js +80 -80
  129. package/src/js/modules/statesManager/sequence.js +47 -47
  130. package/src/js/modules/template/_info.js +6 -6
  131. package/src/js/modules/template/controller.js +28 -28
  132. package/src/js/modules/template/model.js +11 -11
  133. package/src/js/modules/template/service.js +125 -125
  134. package/src/js/modules/template/types.js +46 -41
  135. package/src/js/modules/transport/_info.js +8 -8
  136. package/src/js/modules/transport/baseConnectionType.js +24 -24
  137. package/src/js/modules/transport/config.js +22 -22
  138. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  139. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  140. package/src/js/modules/transport/connectionTypes/xhr.js +41 -41
  141. package/src/js/modules/transport/controller.js +48 -48
  142. package/src/js/modules/transport/decorator.js +16 -16
  143. package/src/js/modules/transport/service.js +138 -138
  144. package/src/js/templates/_info.js +4 -4
  145. package/src/js/templates/groups/_info.js +1 -1
  146. package/src/js/templates/scenes/_info.js +1 -1
  147. package/webpack.config.js +47 -47
@@ -1,113 +1,113 @@
1
- class ModulesObjectsModelsImagesAnimation extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.IMAGES_ANIMATION;
6
-
7
- //sys
8
- this._tween = null;
9
- this._currentFrame = -1;
10
- this._defaultTexture;
11
- this._animationTextures = {};
12
-
13
- this._addBaseObject();
14
- }
15
-
16
- setupParams(params) {
17
- super.setupParams(params);
18
-
19
- this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
20
-
21
- this.duration = Urso.helper.recursiveGet('duration', params, 0);
22
- this.animationKeys = Urso.helper.recursiveGet('animationKeys', params, []);
23
- this.loop = Urso.helper.recursiveGet('loop', params, false);
24
- this.autostart = Urso.helper.recursiveGet('autostart', params, false);
25
- this.onComplete = Urso.helper.recursiveGet('onComplete', params, false);
26
- }
27
-
28
- _addBaseObject() {
29
- let texture = Urso.cache.getTexture(this.assetKey)
30
-
31
- if (!texture)
32
- Urso.logger.error('ModulesObjectsModelsImage assets error: no image ' + this.assetKey);
33
-
34
- this._defaultTexture = texture;
35
- this._baseObject = new PIXI.Sprite(this._defaultTexture);
36
-
37
- this._createAnimationTextures();
38
-
39
- if (this.autostart)
40
- this.start();
41
- };
42
-
43
- start() {
44
- this._createTween();
45
- };
46
-
47
- stop() {
48
- if (!this._tween)
49
- return false;
50
-
51
- this._stopAnimation();
52
- };
53
-
54
- _createAnimationTextures() {
55
- for (let key in this.animationKeys) {
56
- let texture = Urso.cache.getTexture(this.animationKeys[key]);
57
-
58
- if (!texture)
59
- continue;
60
-
61
- this._animationTextures[key] = texture;
62
- }
63
-
64
- return this._animationTextures;
65
- }
66
-
67
- _createTween() {
68
- const totalFrames = this.animationKeys.length;
69
- const tweenParams = { x: totalFrames, duration: this.duration / 1000, ease: "none" };
70
-
71
- if (this.loop)
72
- tweenParams.repeat = -1;
73
-
74
- this._tween = gsap.to({ x: 0 }, tweenParams);
75
-
76
- this._tween.eventCallback("onUpdate", this._onUpdate.bind(this));
77
-
78
- this._tween.eventCallback("onComplete", () => {
79
- this._baseObject.texture = this._defaultTexture;
80
- this._onComplete();
81
- });
82
- }
83
-
84
- _onUpdate() {
85
- if (!this._tween)
86
- return;
87
-
88
- let frameIndex = ~~this._tween.targets()[0].x;
89
- const totalFrames = this.animationKeys.length;
90
-
91
- const frameKey = this.animationKeys[frameIndex];
92
-
93
- if (this._currentFrame !== frameKey) {
94
- this._baseObject.texture = this._animationTextures[frameIndex];
95
- this._currentFrame = frameKey;
96
- }
97
- }
98
-
99
- _onComplete() {
100
- if (this.onComplete)
101
- this.onComplete();
102
- };
103
-
104
- _stopAnimation() {
105
- this._tween.kill();
106
- this._baseObject.texture = this._defaultTexture;
107
-
108
- this._onComplete();
109
- }
110
-
111
- }
112
-
113
- module.exports = ModulesObjectsModelsImagesAnimation;
1
+ class ModulesObjectsModelsImagesAnimation extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.IMAGES_ANIMATION;
6
+
7
+ //sys
8
+ this._tween = null;
9
+ this._currentFrame = -1;
10
+ this._defaultTexture;
11
+ this._animationTextures = {};
12
+
13
+ this._addBaseObject();
14
+ }
15
+
16
+ setupParams(params) {
17
+ super.setupParams(params);
18
+
19
+ this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
20
+
21
+ this.duration = Urso.helper.recursiveGet('duration', params, 0);
22
+ this.animationKeys = Urso.helper.recursiveGet('animationKeys', params, []);
23
+ this.loop = Urso.helper.recursiveGet('loop', params, false);
24
+ this.autostart = Urso.helper.recursiveGet('autostart', params, false);
25
+ this.onComplete = Urso.helper.recursiveGet('onComplete', params, false);
26
+ }
27
+
28
+ _addBaseObject() {
29
+ let texture = Urso.cache.getTexture(this.assetKey)
30
+
31
+ if (!texture)
32
+ Urso.logger.error('ModulesObjectsModelsImage assets error: no image ' + this.assetKey);
33
+
34
+ this._defaultTexture = texture;
35
+ this._baseObject = new PIXI.Sprite(this._defaultTexture);
36
+
37
+ this._createAnimationTextures();
38
+
39
+ if (this.autostart)
40
+ this.start();
41
+ };
42
+
43
+ start() {
44
+ this._createTween();
45
+ };
46
+
47
+ stop() {
48
+ if (!this._tween)
49
+ return false;
50
+
51
+ this._stopAnimation();
52
+ };
53
+
54
+ _createAnimationTextures() {
55
+ for (let key in this.animationKeys) {
56
+ let texture = Urso.cache.getTexture(this.animationKeys[key]);
57
+
58
+ if (!texture)
59
+ continue;
60
+
61
+ this._animationTextures[key] = texture;
62
+ }
63
+
64
+ return this._animationTextures;
65
+ }
66
+
67
+ _createTween() {
68
+ const totalFrames = this.animationKeys.length;
69
+ const tweenParams = { x: totalFrames, duration: this.duration / 1000, ease: "none" };
70
+
71
+ if (this.loop)
72
+ tweenParams.repeat = -1;
73
+
74
+ this._tween = gsap.to({ x: 0 }, tweenParams);
75
+
76
+ this._tween.eventCallback("onUpdate", this._onUpdate.bind(this));
77
+
78
+ this._tween.eventCallback("onComplete", () => {
79
+ this._baseObject.texture = this._defaultTexture;
80
+ this._onComplete();
81
+ });
82
+ }
83
+
84
+ _onUpdate() {
85
+ if (!this._tween)
86
+ return;
87
+
88
+ let frameIndex = ~~this._tween.targets()[0].x;
89
+ const totalFrames = this.animationKeys.length;
90
+
91
+ const frameKey = this.animationKeys[frameIndex];
92
+
93
+ if (this._currentFrame !== frameKey) {
94
+ this._baseObject.texture = this._animationTextures[frameIndex];
95
+ this._currentFrame = frameKey;
96
+ }
97
+ }
98
+
99
+ _onComplete() {
100
+ if (this.onComplete)
101
+ this.onComplete();
102
+ };
103
+
104
+ _stopAnimation() {
105
+ this._tween.kill();
106
+ this._baseObject.texture = this._defaultTexture;
107
+
108
+ this._onComplete();
109
+ }
110
+
111
+ }
112
+
113
+ module.exports = ModulesObjectsModelsImagesAnimation;
@@ -1,38 +1,38 @@
1
- class ModulesObjectsModelsMask extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.MASK;
6
- this._addBaseObject();
7
- }
8
-
9
- setupParams(params) {
10
- super.setupParams(params);
11
-
12
- //NOTE: you can use just one key: rectangle or rectangles
13
- this.rectangle = Urso.helper.recursiveGet('rectangle', params, false); // [50, 50, 100, 100]
14
- this.rectangles = Urso.helper.recursiveGet('rectangles', params, false); //array of rectangles
15
- }
16
-
17
- _addBaseObject() {
18
- let mask = new PIXI.Graphics();
19
- mask.lineStyle(0);
20
- mask.beginFill(0xffffff);
21
-
22
- if (this.rectangle)
23
- this._drawRect(mask, this.rectangle);
24
- else if (this.rectangles)
25
- for (let rectangle of this.rectangles)
26
- this._drawRect(mask, rectangle);
27
-
28
- mask.endFill();
29
-
30
- this._baseObject = mask;
31
- };
32
-
33
- _drawRect(maskObject, rectangle) {
34
- maskObject.drawRect(rectangle[0], rectangle[1], rectangle[2], rectangle[3]);
35
- }
36
- }
37
-
38
- module.exports = ModulesObjectsModelsMask;
1
+ class ModulesObjectsModelsMask extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.MASK;
6
+ this._addBaseObject();
7
+ }
8
+
9
+ setupParams(params) {
10
+ super.setupParams(params);
11
+
12
+ //NOTE: you can use just one key: rectangle or rectangles
13
+ this.rectangle = Urso.helper.recursiveGet('rectangle', params, false); // [50, 50, 100, 100]
14
+ this.rectangles = Urso.helper.recursiveGet('rectangles', params, false); //array of rectangles
15
+ }
16
+
17
+ _addBaseObject() {
18
+ let mask = new PIXI.Graphics();
19
+ mask.lineStyle(0);
20
+ mask.beginFill(0xffffff);
21
+
22
+ if (this.rectangle)
23
+ this._drawRect(mask, this.rectangle);
24
+ else if (this.rectangles)
25
+ for (let rectangle of this.rectangles)
26
+ this._drawRect(mask, rectangle);
27
+
28
+ mask.endFill();
29
+
30
+ this._baseObject = mask;
31
+ };
32
+
33
+ _drawRect(maskObject, rectangle) {
34
+ maskObject.drawRect(rectangle[0], rectangle[1], rectangle[2], rectangle[3]);
35
+ }
36
+ }
37
+
38
+ module.exports = ModulesObjectsModelsMask;
@@ -0,0 +1,62 @@
1
+ class ModulesObjectsModelsScrollbox extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.SCROLLBOX;
6
+ this._addBaseObject();
7
+ this._createContent();
8
+ }
9
+
10
+ setupParams(params) {
11
+ super.setupParams(params);
12
+
13
+ this.content = Urso.helper.recursiveGet('content', params, []);
14
+ this.dragScroll = Urso.helper.recursiveGet('dragScroll', params, true);
15
+ this.scrollType = Urso.helper.recursiveGet('scrollType', params, 3);
16
+ }
17
+
18
+ _getScrollboxParams(){
19
+ return {
20
+ boxWidth: this.width,
21
+ boxHeight: this.height,
22
+ dragScroll: this.dragScroll,
23
+ fade: true,
24
+ fadeScrollbarTime: 300
25
+ }
26
+ }
27
+
28
+ _setScrollWidth(){
29
+ if(this.scrollType === 1 || this.scrollType === 0){
30
+ this._baseObject.scrollWidth = this.width;
31
+ this._baseObject.overflowX = 'hidden';
32
+ }
33
+ }
34
+
35
+ _setScrollHeight(){
36
+ if(this.scrollType === 2 || this.scrollType === 0){
37
+ this._baseObject.scrollHeight = this.height;
38
+ this._baseObject.overflowY = 'hidden'
39
+ }
40
+ }
41
+
42
+ _createContent(){
43
+ this.content.forEach(child => {
44
+ let object = Urso.objects.create(child)
45
+ this._baseObject.content.addChild(object._baseObject)
46
+ })
47
+
48
+ this._baseObject.update();
49
+ }
50
+
51
+ _addBaseObject() {
52
+ const params = this._getScrollboxParams();
53
+
54
+ const Scrollbox = require('pixi-scrollbox').Scrollbox;
55
+ this._baseObject = new Scrollbox(params);
56
+
57
+ this._setScrollHeight();
58
+ this._setScrollWidth();
59
+ };
60
+ }
61
+
62
+ module.exports = ModulesObjectsModelsScrollbox
@@ -0,0 +1,154 @@
1
+ class ModulesObjectsModelsSlider extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.SLIDER;
6
+ this._sliderBg = null;
7
+ this._sliderHandle = null;
8
+ this._baseObject = null;
9
+ this._handleIsPulling = false;
10
+
11
+ this._addBaseObject();
12
+ this._createSliderTextures();
13
+ this._createValueText();
14
+ this._setDefaultValue();
15
+ }
16
+
17
+ setupParams(params) {
18
+ super.setupParams(params);
19
+ this.contents = [];
20
+ this.points = Urso.helper.recursiveGet('points', params, [0, 1]);
21
+ this.defaultValue = Urso.helper.recursiveGet('defaultValue', params, this.points[0]);
22
+ this.bgTexture = Urso.helper.recursiveGet('bgTexture', params, false);
23
+ this.handleTexture = Urso.helper.recursiveGet('handleTexture', params, false);
24
+ this.minValueTextModel = Urso.helper.recursiveGet('minValueTextModel', params, false);
25
+ this.maxValueTextModel = Urso.helper.recursiveGet('maxValueTextModel', params, false);
26
+ this.currentValueTextModel = Urso.helper.recursiveGet('currentValueTextModel', params, false);
27
+ }
28
+
29
+ _createSliderTextures() {
30
+ this._sliderBg = this._createTexture(this.bgTexture);
31
+ this._sliderHandle = this._createTexture(this.handleTexture);
32
+
33
+ this._setEvents(this._sliderBg._baseObject);
34
+ this._setEvents(this._sliderHandle._baseObject);
35
+ }
36
+
37
+ _createValueText() {
38
+ if (this.minValueTextModel) {
39
+ this.minValueText = Urso.objects.create(this.minValueTextModel, this);
40
+ this.minValueText.text = this.points[0];
41
+ }
42
+
43
+ if (this.maxValueTextModel) {
44
+ this.maxValueText = Urso.objects.create(this.maxValueTextModel, this);
45
+ this.maxValueText.text = this.points.length <= 2 ? '100' : this.points[this.points.length - 1];
46
+ }
47
+
48
+ if(this.currentValueTextModel){
49
+ this.currentValueText = Urso.objects.create(this.currentValueTextModel, this);
50
+ }
51
+ }
52
+
53
+ _createTexture(model) {
54
+ if (model.type === Urso.types.objects.GRAPHICS || model.type === Urso.types.objects.IMAGE)
55
+ return Urso.objects.create(model, this);
56
+ else
57
+ Urso.logger.error('ModulesObjectsModelsSlider objects error: textures should be GRAPHICS or IMAGE type');
58
+ }
59
+
60
+ _setEvents(obj) {
61
+ obj.interactive = true;
62
+ obj.buttonMode = true;
63
+
64
+ obj
65
+ .on('pointerdown', this._onPointerDown.bind(this))
66
+ .on('pointerup', this._onPointerUp.bind(this))
67
+ .on('pointerupoutside', this._onPointerUp.bind(this))
68
+ }
69
+
70
+ _addBaseObject() {
71
+ this._baseObject = new PIXI.Container();
72
+ };
73
+
74
+ _onPointerDown(obj) {
75
+ if (obj.target === this._sliderHandle._baseObject)
76
+ this._handleIsDragging = true;
77
+ }
78
+
79
+ _onMouseMove({ x }) {
80
+ if (!this._handleIsDragging)
81
+ return
82
+
83
+ if (x < this.x)
84
+ this._sliderHandle.x = 0;
85
+ else if (x > this.x + this._sliderBg._baseObject.width)
86
+ this._sliderHandle.x = this._sliderBg._baseObject.width;
87
+ else
88
+ this._sliderHandle.x = x - this.x;
89
+ }
90
+
91
+ _onPointerUp(obj) {
92
+ this._handleIsDragging = false;
93
+ let x;
94
+
95
+ if (obj.target === this._sliderBg._baseObject) {
96
+ x = obj.data.getLocalPosition(obj.target).x;
97
+ } else
98
+ x = this._sliderHandle.x;
99
+
100
+ this._dropHandle(x);
101
+ }
102
+
103
+ _setDefaultValue(){
104
+ if(!this.defaultValue)
105
+ return
106
+
107
+ if(!this.points.includes(this.defaultValue))
108
+ this.defaultValue = this.points[0];
109
+
110
+ let x = this.points.indexOf(this.defaultValue) * this._sliderBg._baseObject.width / (this.points.length - 1);
111
+
112
+ this._setNewValue(x, this.defaultValue);
113
+ }
114
+
115
+ _dropHandle(x) {
116
+ let value;
117
+ let handleX;
118
+
119
+ if(this.points.length <= 2){
120
+ handleX = x;
121
+ value = ~~(100 / this._sliderBg._baseObject.width * x);
122
+ }
123
+ // calculate closest point
124
+ else{
125
+ for (let i = 0; i < this.points.length; i++) {
126
+ let pointX = i * this._sliderBg._baseObject.width / (this.points.length - 1);
127
+
128
+ if (typeof (handleX) === 'number' && x - pointX < handleX - x) {
129
+ handleX = handleX;
130
+ } else {
131
+ handleX = pointX;
132
+ value = this.points[i];
133
+ }
134
+ }
135
+ }
136
+
137
+ this._setNewValue(handleX, value)
138
+ }
139
+
140
+ _setNewValue(x, value){
141
+ this._sliderHandle.x = x;
142
+
143
+ if (this.currentValueText)
144
+ this.currentValueText.text = value;
145
+
146
+ this.emit(Urso.events.MODULES_OBJECTS_SLIDER_SET_NEW_VALUE, { name: this.name, value: value });
147
+ }
148
+
149
+ _subscribeOnce() {
150
+ this.addListener(Urso.events.MODULES_SCENES_MOUSE_NEW_POSITION, this._onMouseMove.bind(this));
151
+ }
152
+ }
153
+
154
+ module.exports = ModulesObjectsModelsSlider;
@@ -1,83 +1,83 @@
1
- class ModulesObjectsModelsSpine extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.SPINE;
6
- this._addBaseObject();
7
- }
8
-
9
- setupParams(params) {
10
- super.setupParams(params);
11
-
12
- this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
13
-
14
- this.animation = {
15
- timeScale: Urso.helper.recursiveGet('animation.timeScale', params, 1),
16
- name: Urso.helper.recursiveGet('animation.name', params, false),
17
- loop: Urso.helper.recursiveGet('animation.loop', params, false),
18
- onComplete: Urso.helper.recursiveGet('animation.onComplete', params, false)
19
- };
20
- }
21
-
22
- play(animationName, loopFlag = false, track = 0) {
23
- this._baseObject.state.setAnimation(track, animationName, loopFlag);
24
- }
25
-
26
- addToSlot(object, slotName) {
27
- const spine = this._baseObject;
28
- const slotIndex = spine.spineData.slots.findIndex(({ name }) => name === slotName);
29
- const currentSlot = spine.slotContainers[slotIndex];
30
-
31
- if (currentSlot) {
32
- object._baseObject.scale.y = -1;
33
-
34
- Urso.objects.removeChild(object.parent, object)
35
- currentSlot.addChild(object._baseObject);
36
- } else {
37
- Urso.logger.warn('ModulesObjectsModelsSpine addToSlot error: no spine slot ' + slotName);
38
- }
39
- }
40
-
41
- /**
42
- *
43
- * @param {*} config
44
- * @param {boolean} [noObjectCreate] dont use this flag out of core
45
- *
46
- * config keys:
47
- timeScale
48
- onComplete
49
- */
50
- setAnimationConfig(config = {}, noObjectCreate) {
51
- this.animation = {
52
- ...this.animation,
53
- ...config
54
- };
55
-
56
- if (config.timeScale)
57
- this._baseObject.state.timeScale = config.timeScale;
58
-
59
- if (config.onComplete) {
60
- window.asd = this._baseObject.state
61
- this._baseObject.state.clearListeners();
62
- this._baseObject.state.addListener({ complete: this.animation.onComplete });
63
- }
64
- }
65
-
66
- _addBaseObject() {
67
- let spineAsset = Urso.cache.getSpine(this.assetKey);
68
-
69
- if (!spineAsset)
70
- Urso.logger.error('ModulesObjectsModelsSpine assets error: no spine object ' + this.assetKey);
71
-
72
- this._baseObject = new PIXI.spine.Spine(spineAsset.spineData);
73
- this._baseObject.state.timeScale = this.animation.timeScale;
74
-
75
- if (this.animation.onComplete)
76
- this._baseObject.state.addListener({ complete: this.animation.onComplete });
77
-
78
- if (this.animation.name)
79
- this.play(this.animation.name, this.animation.loop);
80
- };
81
- }
82
-
83
- module.exports = ModulesObjectsModelsSpine;
1
+ class ModulesObjectsModelsSpine extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.SPINE;
6
+ this._addBaseObject();
7
+ }
8
+
9
+ setupParams(params) {
10
+ super.setupParams(params);
11
+
12
+ this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
13
+
14
+ this.animation = {
15
+ timeScale: Urso.helper.recursiveGet('animation.timeScale', params, 1),
16
+ name: Urso.helper.recursiveGet('animation.name', params, false),
17
+ loop: Urso.helper.recursiveGet('animation.loop', params, false),
18
+ onComplete: Urso.helper.recursiveGet('animation.onComplete', params, false)
19
+ };
20
+ }
21
+
22
+ play(animationName, loopFlag = false, track = 0) {
23
+ this._baseObject.state.setAnimation(track, animationName, loopFlag);
24
+ }
25
+
26
+ addToSlot(object, slotName) {
27
+ const spine = this._baseObject;
28
+ const slotIndex = spine.spineData.slots.findIndex(({ name }) => name === slotName);
29
+ const currentSlot = spine.slotContainers[slotIndex];
30
+
31
+ if (currentSlot) {
32
+ object._baseObject.scale.y = -1;
33
+
34
+ Urso.objects.removeChild(object.parent, object)
35
+ currentSlot.addChild(object._baseObject);
36
+ } else {
37
+ Urso.logger.warn('ModulesObjectsModelsSpine addToSlot error: no spine slot ' + slotName);
38
+ }
39
+ }
40
+
41
+ /**
42
+ *
43
+ * @param {*} config
44
+ * @param {boolean} [noObjectCreate] dont use this flag out of core
45
+ *
46
+ * config keys:
47
+ timeScale
48
+ onComplete
49
+ */
50
+ setAnimationConfig(config = {}, noObjectCreate) {
51
+ this.animation = {
52
+ ...this.animation,
53
+ ...config
54
+ };
55
+
56
+ if (config.timeScale)
57
+ this._baseObject.state.timeScale = config.timeScale;
58
+
59
+ if (config.onComplete) {
60
+ window.asd = this._baseObject.state
61
+ this._baseObject.state.clearListeners();
62
+ this._baseObject.state.addListener({ complete: this.animation.onComplete });
63
+ }
64
+ }
65
+
66
+ _addBaseObject() {
67
+ let spineAsset = Urso.cache.getSpine(this.assetKey);
68
+
69
+ if (!spineAsset)
70
+ Urso.logger.error('ModulesObjectsModelsSpine assets error: no spine object ' + this.assetKey);
71
+
72
+ this._baseObject = new PIXI.spine.Spine(spineAsset.spineData);
73
+ this._baseObject.state.timeScale = this.animation.timeScale;
74
+
75
+ if (this.animation.onComplete)
76
+ this._baseObject.state.addListener({ complete: this.animation.onComplete });
77
+
78
+ if (this.animation.name)
79
+ this.play(this.animation.name, this.animation.loop);
80
+ };
81
+ }
82
+
83
+ module.exports = ModulesObjectsModelsSpine;