@urso/core 0.4.45 → 0.4.49

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 (156) hide show
  1. package/.babelrc +11 -11
  2. package/LICENSE +20 -20
  3. package/README.md +220 -220
  4. package/build/js/index.js +1 -1
  5. package/build/js/index.js.LICENSE.txt +32 -32
  6. package/package.json +51 -51
  7. package/src/js/app.js +78 -78
  8. package/src/js/components/_info.js +10 -10
  9. package/src/js/components/base/_info.js +3 -3
  10. package/src/js/components/base/controller.js +78 -78
  11. package/src/js/components/debug/_info.js +7 -7
  12. package/src/js/components/debug/controller.js +38 -38
  13. package/src/js/components/debug/coords.js +23 -23
  14. package/src/js/components/debug/fps.js +34 -34
  15. package/src/js/components/debug/template.js +55 -55
  16. package/src/js/components/debug/timescale.js +60 -60
  17. package/src/js/components/deviceRotate/_info.js +3 -3
  18. package/src/js/components/deviceRotate/controller.js +86 -86
  19. package/src/js/components/editor/_info.js +4 -0
  20. package/src/js/components/editor/api.js +72 -0
  21. package/src/js/components/editor/controller.js +13 -0
  22. package/src/js/components/fullscreen/_info.js +6 -6
  23. package/src/js/components/fullscreen/android.js +104 -104
  24. package/src/js/components/fullscreen/controller.js +76 -76
  25. package/src/js/components/fullscreen/desktop.js +49 -49
  26. package/src/js/components/fullscreen/ios.js +115 -115
  27. package/src/js/components/layersSwitcher/_info.js +4 -4
  28. package/src/js/components/layersSwitcher/config.js +26 -26
  29. package/src/js/components/layersSwitcher/controller.js +34 -34
  30. package/src/js/components/loader/_info.js +4 -4
  31. package/src/js/components/loader/controller.js +66 -66
  32. package/src/js/components/loader/template.js +70 -70
  33. package/src/js/components/soundInitialPopup/_info.js +3 -3
  34. package/src/js/components/soundInitialPopup/controller.js +42 -42
  35. package/src/js/components/soundInitialPopup/template.js +109 -109
  36. package/src/js/components/stateDriven/_info.js +3 -3
  37. package/src/js/components/stateDriven/controller.js +118 -118
  38. package/src/js/config/load.js +5 -5
  39. package/src/js/config/main.js +11 -10
  40. package/src/js/extra/_info.js +24 -24
  41. package/src/js/extra/browserEvents.js +38 -38
  42. package/src/js/extra/pixiPatch.js +79 -79
  43. package/src/js/extra/setTimeout.js +7 -7
  44. package/src/js/index.js +8 -8
  45. package/src/js/lib/_info.js +13 -13
  46. package/src/js/lib/cache.js +105 -105
  47. package/src/js/lib/composition.js +85 -85
  48. package/src/js/lib/device.js +1286 -1286
  49. package/src/js/lib/helper.js +539 -539
  50. package/src/js/lib/loader.js +136 -131
  51. package/src/js/lib/localData.js +15 -15
  52. package/src/js/lib/logger.js +22 -22
  53. package/src/js/lib/math.js +35 -35
  54. package/src/js/lib/objectPool.js +54 -54
  55. package/src/js/lib/time.js +18 -18
  56. package/src/js/lib/tween.js +147 -147
  57. package/src/js/modules/_info.js +12 -12
  58. package/src/js/modules/assets/_info.js +7 -7
  59. package/src/js/modules/assets/baseModel.js +18 -18
  60. package/src/js/modules/assets/config.js +37 -37
  61. package/src/js/modules/assets/controller.js +46 -46
  62. package/src/js/modules/assets/models/_info.js +11 -11
  63. package/src/js/modules/assets/models/atlas.js +8 -8
  64. package/src/js/modules/assets/models/audiosprite.js +27 -27
  65. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  66. package/src/js/modules/assets/models/container.js +16 -16
  67. package/src/js/modules/assets/models/font.js +8 -8
  68. package/src/js/modules/assets/models/image.js +13 -13
  69. package/src/js/modules/assets/models/json.js +8 -8
  70. package/src/js/modules/assets/models/sound.js +14 -14
  71. package/src/js/modules/assets/models/spine.js +14 -14
  72. package/src/js/modules/assets/service.js +365 -365
  73. package/src/js/modules/i18n/_info.js +4 -4
  74. package/src/js/modules/i18n/config.js +17 -17
  75. package/src/js/modules/i18n/controller.js +79 -79
  76. package/src/js/modules/instances/_info.js +3 -3
  77. package/src/js/modules/instances/controller.js +261 -261
  78. package/src/js/modules/logic/_info.js +4 -4
  79. package/src/js/modules/logic/config/_info.js +2 -2
  80. package/src/js/modules/logic/config/sounds.js +23 -23
  81. package/src/js/modules/logic/controller.js +48 -48
  82. package/src/js/modules/logic/sounds.js +103 -103
  83. package/src/js/modules/objects/_info.js +11 -11
  84. package/src/js/modules/objects/baseModel.js +197 -197
  85. package/src/js/modules/objects/cache.js +99 -99
  86. package/src/js/modules/objects/controller.js +131 -131
  87. package/src/js/modules/objects/create.js +237 -237
  88. package/src/js/modules/objects/find.js +140 -140
  89. package/src/js/modules/objects/models/_info.js +25 -25
  90. package/src/js/modules/objects/models/atlasImage.js +50 -50
  91. package/src/js/modules/objects/models/bitmapText.js +39 -39
  92. package/src/js/modules/objects/models/button.js +189 -189
  93. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  94. package/src/js/modules/objects/models/checkbox.js +96 -96
  95. package/src/js/modules/objects/models/collection.js +54 -54
  96. package/src/js/modules/objects/models/component.js +44 -44
  97. package/src/js/modules/objects/models/container.js +19 -19
  98. package/src/js/modules/objects/models/emitter.js +67 -54
  99. package/src/js/modules/objects/models/graphics.js +38 -38
  100. package/src/js/modules/objects/models/group.js +19 -19
  101. package/src/js/modules/objects/models/hitArea.js +104 -104
  102. package/src/js/modules/objects/models/image.js +34 -34
  103. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  104. package/src/js/modules/objects/models/mask.js +38 -38
  105. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  106. package/src/js/modules/objects/models/scrollbox.js +61 -61
  107. package/src/js/modules/objects/models/slider.js +253 -253
  108. package/src/js/modules/objects/models/spine.js +271 -271
  109. package/src/js/modules/objects/models/text.js +59 -59
  110. package/src/js/modules/objects/models/textInput.js +66 -66
  111. package/src/js/modules/objects/models/toggle.js +180 -180
  112. package/src/js/modules/objects/models/world.js +19 -19
  113. package/src/js/modules/objects/propertyAdapter.js +422 -422
  114. package/src/js/modules/objects/proxy.js +282 -282
  115. package/src/js/modules/objects/styles.js +120 -120
  116. package/src/js/modules/observer/_info.js +4 -4
  117. package/src/js/modules/observer/controller.js +99 -99
  118. package/src/js/modules/observer/events.js +44 -44
  119. package/src/js/modules/scenes/_info.js +8 -8
  120. package/src/js/modules/scenes/controller.js +103 -103
  121. package/src/js/modules/scenes/model.js +28 -28
  122. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  123. package/src/js/modules/scenes/resolutions.js +173 -173
  124. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  125. package/src/js/modules/scenes/service.js +139 -139
  126. package/src/js/modules/soundManager/_info.js +3 -3
  127. package/src/js/modules/soundManager/controller.js +100 -100
  128. package/src/js/modules/soundManager/soundSprite.js +243 -243
  129. package/src/js/modules/statesManager/_info.js +12 -12
  130. package/src/js/modules/statesManager/action.js +60 -60
  131. package/src/js/modules/statesManager/actions/_info.js +3 -3
  132. package/src/js/modules/statesManager/all.js +23 -23
  133. package/src/js/modules/statesManager/configStates.js +71 -71
  134. package/src/js/modules/statesManager/controller.js +170 -170
  135. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  136. package/src/js/modules/statesManager/helper.js +27 -27
  137. package/src/js/modules/statesManager/race.js +75 -75
  138. package/src/js/modules/statesManager/sequence.js +47 -47
  139. package/src/js/modules/template/_info.js +6 -6
  140. package/src/js/modules/template/controller.js +28 -28
  141. package/src/js/modules/template/model.js +11 -11
  142. package/src/js/modules/template/service.js +137 -137
  143. package/src/js/modules/template/types.js +45 -45
  144. package/src/js/modules/transport/_info.js +8 -8
  145. package/src/js/modules/transport/baseConnectionType.js +24 -24
  146. package/src/js/modules/transport/config.js +13 -13
  147. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  148. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  149. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  150. package/src/js/modules/transport/controller.js +48 -48
  151. package/src/js/modules/transport/decorator.js +17 -17
  152. package/src/js/modules/transport/service.js +153 -153
  153. package/src/js/templates/_info.js +4 -4
  154. package/src/js/templates/groups/_info.js +1 -1
  155. package/src/js/templates/scenes/_info.js +1 -1
  156. package/webpack.config.js +47 -47
@@ -1,115 +1,115 @@
1
- class ComponentsFullscreenIos {
2
- constructor() {
3
- this._div = null;
4
- this._orientation = null;
5
- this._scrollTimeout = null;
6
- }
7
-
8
- init() {
9
- this._createDom();
10
- this._addListeners();
11
- this._updateResize();
12
- }
13
-
14
- _createDom() {
15
- this._div = document.createElement('div');
16
- this._div.className = 'fullscreen fullscreen-ios';
17
- document.body.prepend(this._div);
18
-
19
- const infoDiv = document.createElement('div');
20
- infoDiv.className = 'fullscreen-info';
21
- this._div.appendChild(infoDiv);
22
-
23
- const image = document.createElement('img');
24
- image.src = '/assets/images/fullscreen/scroll.png';
25
- const span = document.createElement('span');
26
- span.innerText = 'Swipe up to enter fullscreen';
27
-
28
- infoDiv.appendChild(image);
29
- infoDiv.appendChild(span);
30
- }
31
-
32
- _addListeners() {
33
- window.addEventListener('touchmove', (e) => {
34
- this._updateResize();
35
-
36
- if (e.touches.length > 1) {
37
- e.preventDefault();
38
- return;
39
- }
40
- });
41
- }
42
-
43
- get isFullscreen() {
44
- return this._isFullscreen;
45
- }
46
-
47
- get _isFullscreen() {
48
- const minFactor = 0.51;
49
- const deviceFactor = screen.width / screen.height;
50
- const factor = this._isPortrait ?
51
- innerWidth / innerHeight :
52
- innerHeight / innerWidth;
53
-
54
- return !(
55
- this._isPortrait ?
56
- factor - deviceFactor < 0.1 :
57
- factor > minFactor
58
- );
59
- }
60
-
61
- _updateOrientation() {
62
- this._orientation = innerWidth > innerHeight ? Urso.device.ScreenOrientation.LANDSCAPE : Urso.device.ScreenOrientation.PORTRAIT;
63
- }
64
-
65
- _updateResize() {
66
- this._updateOrientation();
67
- this.isVisible = this._needShowOnCurrentOrientation && this._isFullscreen;
68
- }
69
-
70
- get _orientationsConfig() {
71
- return Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
72
- }
73
-
74
- get _isPortrait() {
75
- return this._orientation === Urso.device.ScreenOrientation.PORTRAIT;
76
- }
77
-
78
- get _needShowOnCurrentOrientation() {
79
- return (this._isPortrait && this._showOnPortrait) || (!this._isPortrait && this._showOnLandscape);
80
- }
81
-
82
- get _showOnLandscape() {
83
- return this._orientationsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.LANDSCAPE);
84
- }
85
-
86
- get _showOnPortrait() {
87
- return this._orientationsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.PORTRAIT);
88
- }
89
-
90
- set isVisible(needShowDiv) {
91
- this._div.style.zIndex = needShowDiv ? 1 : -1;
92
- clearTimeout(this._scrollTimeout)
93
- this._scrollTimeout = setTimeout(() => {
94
- if (needShowDiv)
95
- window.scrollTo(0, 0);
96
- }, 200);
97
- }
98
-
99
- _resizeHandler() {
100
- this._updateResize();
101
- }
102
-
103
- _fullscreenSwitchHandler(needGoFullscreen = null) {
104
- this._switchFullscreen(needGoFullscreen);
105
- }
106
-
107
- _subscribeOnce() {
108
- this.addListener(
109
- Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE,
110
- this._resizeHandler.bind(this)
111
- );
112
- }
113
- }
114
-
115
- module.exports = ComponentsFullscreenIos;
1
+ class ComponentsFullscreenIos {
2
+ constructor() {
3
+ this._div = null;
4
+ this._orientation = null;
5
+ this._scrollTimeout = null;
6
+ }
7
+
8
+ init() {
9
+ this._createDom();
10
+ this._addListeners();
11
+ this._updateResize();
12
+ }
13
+
14
+ _createDom() {
15
+ this._div = document.createElement('div');
16
+ this._div.className = 'fullscreen fullscreen-ios';
17
+ document.body.prepend(this._div);
18
+
19
+ const infoDiv = document.createElement('div');
20
+ infoDiv.className = 'fullscreen-info';
21
+ this._div.appendChild(infoDiv);
22
+
23
+ const image = document.createElement('img');
24
+ image.src = '/assets/images/fullscreen/scroll.png';
25
+ const span = document.createElement('span');
26
+ span.innerText = 'Swipe up to enter fullscreen';
27
+
28
+ infoDiv.appendChild(image);
29
+ infoDiv.appendChild(span);
30
+ }
31
+
32
+ _addListeners() {
33
+ window.addEventListener('touchmove', (e) => {
34
+ this._updateResize();
35
+
36
+ if (e.touches.length > 1) {
37
+ e.preventDefault();
38
+ return;
39
+ }
40
+ });
41
+ }
42
+
43
+ get isFullscreen() {
44
+ return this._isFullscreen;
45
+ }
46
+
47
+ get _isFullscreen() {
48
+ const minFactor = 0.51;
49
+ const deviceFactor = screen.width / screen.height;
50
+ const factor = this._isPortrait ?
51
+ innerWidth / innerHeight :
52
+ innerHeight / innerWidth;
53
+
54
+ return !(
55
+ this._isPortrait ?
56
+ factor - deviceFactor < 0.1 :
57
+ factor > minFactor
58
+ );
59
+ }
60
+
61
+ _updateOrientation() {
62
+ this._orientation = innerWidth > innerHeight ? Urso.device.ScreenOrientation.LANDSCAPE : Urso.device.ScreenOrientation.PORTRAIT;
63
+ }
64
+
65
+ _updateResize() {
66
+ this._updateOrientation();
67
+ this.isVisible = this._needShowOnCurrentOrientation && this._isFullscreen;
68
+ }
69
+
70
+ get _orientationsConfig() {
71
+ return Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
72
+ }
73
+
74
+ get _isPortrait() {
75
+ return this._orientation === Urso.device.ScreenOrientation.PORTRAIT;
76
+ }
77
+
78
+ get _needShowOnCurrentOrientation() {
79
+ return (this._isPortrait && this._showOnPortrait) || (!this._isPortrait && this._showOnLandscape);
80
+ }
81
+
82
+ get _showOnLandscape() {
83
+ return this._orientationsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.LANDSCAPE);
84
+ }
85
+
86
+ get _showOnPortrait() {
87
+ return this._orientationsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.PORTRAIT);
88
+ }
89
+
90
+ set isVisible(needShowDiv) {
91
+ this._div.style.zIndex = needShowDiv ? 1 : -1;
92
+ clearTimeout(this._scrollTimeout)
93
+ this._scrollTimeout = setTimeout(() => {
94
+ if (needShowDiv)
95
+ window.scrollTo(0, 0);
96
+ }, 200);
97
+ }
98
+
99
+ _resizeHandler() {
100
+ this._updateResize();
101
+ }
102
+
103
+ _fullscreenSwitchHandler(needGoFullscreen = null) {
104
+ this._switchFullscreen(needGoFullscreen);
105
+ }
106
+
107
+ _subscribeOnce() {
108
+ this.addListener(
109
+ Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE,
110
+ this._resizeHandler.bind(this)
111
+ );
112
+ }
113
+ }
114
+
115
+ module.exports = ComponentsFullscreenIos;
@@ -1,4 +1,4 @@
1
- Urso.Core.Components.LayersSwitcher = {
2
- Controller: require('./controller'),
3
- Config: require('./config'),
4
- };
1
+ Urso.Core.Components.LayersSwitcher = {
2
+ Controller: require('./controller'),
3
+ Config: require('./config'),
4
+ };
@@ -1,26 +1,26 @@
1
- class ComponentsLayersSwitcher {
2
-
3
- constructor() {
4
-
5
- //allLayers config example
6
- this.allLayers = [
7
- '^granny',
8
- '^mainButton',
9
- '^logo',
10
- '.backround',
11
- '^bonusPopup',
12
- '.baseGame',
13
- '.bonusGame'
14
- ];
15
-
16
- //groups layers config example
17
- this.groupsLayers = {
18
- 'mainElements': ['^logo', '^mainButton', '.baseGame'],
19
- 'background': ['.backround'],
20
- 'granny': ['^granny'],
21
- 'bonusGame': ['.bonusGame', '^bonusPopup']
22
- };
23
- }
24
- }
25
-
26
- module.exports = ComponentsLayersSwitcher;
1
+ class ComponentsLayersSwitcher {
2
+
3
+ constructor() {
4
+
5
+ //allLayers config example
6
+ this.allLayers = [
7
+ '^granny',
8
+ '^mainButton',
9
+ '^logo',
10
+ '.backround',
11
+ '^bonusPopup',
12
+ '.baseGame',
13
+ '.bonusGame'
14
+ ];
15
+
16
+ //groups layers config example
17
+ this.groupsLayers = {
18
+ 'mainElements': ['^logo', '^mainButton', '.baseGame'],
19
+ 'background': ['.backround'],
20
+ 'granny': ['^granny'],
21
+ 'bonusGame': ['.bonusGame', '^bonusPopup']
22
+ };
23
+ }
24
+ }
25
+
26
+ module.exports = ComponentsLayersSwitcher;
@@ -1,34 +1,34 @@
1
- class ComponentsLayersSwitcherController extends Urso.Core.Components.Base.Controller {
2
-
3
- constructor(...args) {
4
- super(...args);
5
- this._config = this.getInstance('Config');
6
- }
7
-
8
- /**
9
- * disable all layers from the list of managed layers (config.allLayers) and enables layers corresponding to the desired group (config.groupsLayers[groupName])
10
- * @param {String} groupName
11
- */
12
- _showGroup(groupName) {
13
- const configLayersGroup = this._config.groupsLayers[groupName];
14
-
15
- if (configLayersGroup) {
16
- this._config.allLayers.forEach(selectorLayers => {
17
- const layerVisibleStatus = (configLayersGroup.includes(selectorLayers)) ? true : false;
18
-
19
- Urso.findAll(selectorLayers).forEach((selectorObject) => {
20
- selectorObject.visible = layerVisibleStatus;
21
- });
22
- });
23
-
24
- } else {
25
- Urso.logger.error(`ComponentsLayersSwitcherController: group '${groupName}' was not found!`);
26
- }
27
- }
28
-
29
- _subscribeOnce() {
30
- this.addListener(Urso.events.COMPONENTS_LAYERS_SWITCHER_SWITCH, (groupName) => { this._showGroup(groupName) });
31
- }
32
- }
33
-
34
- module.exports = ComponentsLayersSwitcherController;
1
+ class ComponentsLayersSwitcherController extends Urso.Core.Components.Base.Controller {
2
+
3
+ constructor(...args) {
4
+ super(...args);
5
+ this._config = this.getInstance('Config');
6
+ }
7
+
8
+ /**
9
+ * disable all layers from the list of managed layers (config.allLayers) and enables layers corresponding to the desired group (config.groupsLayers[groupName])
10
+ * @param {String} groupName
11
+ */
12
+ _showGroup(groupName) {
13
+ const configLayersGroup = this._config.groupsLayers[groupName];
14
+
15
+ if (configLayersGroup) {
16
+ this._config.allLayers.forEach(selectorLayers => {
17
+ const layerVisibleStatus = (configLayersGroup.includes(selectorLayers)) ? true : false;
18
+
19
+ Urso.findAll(selectorLayers).forEach((selectorObject) => {
20
+ selectorObject.visible = layerVisibleStatus;
21
+ });
22
+ });
23
+
24
+ } else {
25
+ Urso.logger.error(`ComponentsLayersSwitcherController: group '${groupName}' was not found!`);
26
+ }
27
+ }
28
+
29
+ _subscribeOnce() {
30
+ this.addListener(Urso.events.COMPONENTS_LAYERS_SWITCHER_SWITCH, (groupName) => { this._showGroup(groupName) });
31
+ }
32
+ }
33
+
34
+ module.exports = ComponentsLayersSwitcherController;
@@ -1,4 +1,4 @@
1
- Urso.Core.Components.Loader = {
2
- Controller: require('./controller.js'),
3
- Template: require('./template.js')
4
- };
1
+ Urso.Core.Components.Loader = {
2
+ Controller: require('./controller.js'),
3
+ Template: require('./template.js')
4
+ };
@@ -1,66 +1,66 @@
1
- class ComponentsLoaderController extends Urso.Core.Components.Base.Controller {
2
-
3
- constructor(options){
4
- super(options);
5
-
6
- //load own assets
7
-
8
- //then create loader objects
9
- Urso.objects.create(this.getInstance('Template').objects)
10
-
11
-
12
- }
13
-
14
- assetsMount() {
15
- return false;
16
- }
17
-
18
- objectsMount() {
19
- return false;
20
- }
21
-
22
- loadUpdate(loadProgress) {
23
- this.setLoadProgress(loadProgress);
24
- }
25
-
26
- create(){
27
- this.setMask();
28
-
29
- //todo remove all objects
30
- }
31
-
32
- setMask(){
33
- if(this.loaderBg && this.loaderBgMask)
34
- this.loaderBg._baseObject.mask = this.loaderBgMask._baseObject
35
- }
36
-
37
- formatAmountText(text){
38
- return `${text}%`;
39
- }
40
-
41
- setLoadProgress(val){
42
- if(!this.componentCreated)
43
- return;
44
-
45
- this.loaderBgMask._baseObject.scale.x = val;
46
- this.loadAmountText.text = this.formatAmountText(val);
47
- }
48
-
49
- get componentCreated(){
50
- return !!this.loadAmountText && !!this.loaderBg && !!this.loaderBgMask;
51
- }
52
-
53
- get loadAmountText(){
54
- return Urso.findOne('.loadAmountText');
55
- }
56
-
57
- get loaderBg(){
58
- return Urso.findOne('^loaderBg');
59
- }
60
-
61
- get loaderBgMask(){
62
- return Urso.findOne('^loaderBgMask');
63
- }
64
- }
65
-
66
- module.exports = ComponentsLoaderController;
1
+ class ComponentsLoaderController extends Urso.Core.Components.Base.Controller {
2
+
3
+ constructor(options){
4
+ super(options);
5
+
6
+ //load own assets
7
+
8
+ //then create loader objects
9
+ Urso.objects.create(this.getInstance('Template').objects)
10
+
11
+
12
+ }
13
+
14
+ assetsMount() {
15
+ return false;
16
+ }
17
+
18
+ objectsMount() {
19
+ return false;
20
+ }
21
+
22
+ loadUpdate(loadProgress) {
23
+ this.setLoadProgress(loadProgress);
24
+ }
25
+
26
+ create(){
27
+ this.setMask();
28
+
29
+ //todo remove all objects
30
+ }
31
+
32
+ setMask(){
33
+ if(this.loaderBg && this.loaderBgMask)
34
+ this.loaderBg._baseObject.mask = this.loaderBgMask._baseObject
35
+ }
36
+
37
+ formatAmountText(text){
38
+ return `${text}%`;
39
+ }
40
+
41
+ setLoadProgress(val){
42
+ if(!this.componentCreated)
43
+ return;
44
+
45
+ this.loaderBgMask._baseObject.scale.x = val;
46
+ this.loadAmountText.text = this.formatAmountText(val);
47
+ }
48
+
49
+ get componentCreated(){
50
+ return !!this.loadAmountText && !!this.loaderBg && !!this.loaderBgMask;
51
+ }
52
+
53
+ get loadAmountText(){
54
+ return Urso.findOne('.loadAmountText');
55
+ }
56
+
57
+ get loaderBg(){
58
+ return Urso.findOne('^loaderBg');
59
+ }
60
+
61
+ get loaderBgMask(){
62
+ return Urso.findOne('^loaderBgMask');
63
+ }
64
+ }
65
+
66
+ module.exports = ComponentsLoaderController;
@@ -1,71 +1,71 @@
1
- class ComponentsLoaderTemplate {
2
- constructor() {
3
- this.styles = {
4
- '.loadingTextStyle': {
5
- fill: 0xFFFFFF,
6
- fontSize: 32,
7
- fontWeight: 'bold'
8
- }
9
- };
10
-
11
- this.assets = [];
12
-
13
- this.objects = [
14
- {
15
- type: Urso.types.objects.CONTAINER,
16
- name: 'loaderContainer',
17
- contents: [
18
- {
19
- type: Urso.types.objects.GRAPHICS,
20
- name: 'bgLoader',
21
- figure: {
22
- rectangle: [0, 20, 500, 20],
23
- fillColor: 0x66f542
24
- }
25
- },
26
- {
27
- type: Urso.types.objects.CONTAINER,
28
- contents: [
29
- {
30
- type: Urso.types.objects.GRAPHICS,
31
- figure: {
32
- rectangle: [4, 24, 492, 13],
33
- }
34
- },
35
- {
36
- type: Urso.types.objects.GRAPHICS,
37
- name: 'loaderBg',
38
- figure: {
39
- rectangle: [4, 24, 492, 13],
40
- fillColor: 0x66f542
41
- }
42
- },
43
- {
44
- type: Urso.types.objects.GRAPHICS,
45
- name: 'loaderBgMask',
46
- figure: {
47
- rectangle: [4, 24, 492, 13]
48
- }
49
- },
50
- {
51
- type: Urso.types.objects.CONTAINER,
52
- x: 260,
53
- y: 50,
54
- contents: [
55
- {
56
- type: Urso.types.objects.TEXT,
57
- class: 'loadingTextStyle loadAmountText',
58
- anchorX: 0.5,
59
- text: '100%'
60
- }
61
- ]
62
- }
63
- ]
64
- }
65
- ]
66
- }
67
- ];
68
- };
69
- };
70
-
1
+ class ComponentsLoaderTemplate {
2
+ constructor() {
3
+ this.styles = {
4
+ '.loadingTextStyle': {
5
+ fill: 0xFFFFFF,
6
+ fontSize: 32,
7
+ fontWeight: 'bold'
8
+ }
9
+ };
10
+
11
+ this.assets = [];
12
+
13
+ this.objects = [
14
+ {
15
+ type: Urso.types.objects.CONTAINER,
16
+ name: 'loaderContainer',
17
+ contents: [
18
+ {
19
+ type: Urso.types.objects.GRAPHICS,
20
+ name: 'bgLoader',
21
+ figure: {
22
+ rectangle: [0, 20, 500, 20],
23
+ fillColor: 0x66f542
24
+ }
25
+ },
26
+ {
27
+ type: Urso.types.objects.CONTAINER,
28
+ contents: [
29
+ {
30
+ type: Urso.types.objects.GRAPHICS,
31
+ figure: {
32
+ rectangle: [4, 24, 492, 13],
33
+ }
34
+ },
35
+ {
36
+ type: Urso.types.objects.GRAPHICS,
37
+ name: 'loaderBg',
38
+ figure: {
39
+ rectangle: [4, 24, 492, 13],
40
+ fillColor: 0x66f542
41
+ }
42
+ },
43
+ {
44
+ type: Urso.types.objects.GRAPHICS,
45
+ name: 'loaderBgMask',
46
+ figure: {
47
+ rectangle: [4, 24, 492, 13]
48
+ }
49
+ },
50
+ {
51
+ type: Urso.types.objects.CONTAINER,
52
+ x: 260,
53
+ y: 50,
54
+ contents: [
55
+ {
56
+ type: Urso.types.objects.TEXT,
57
+ class: 'loadingTextStyle loadAmountText',
58
+ anchorX: 0.5,
59
+ text: '100%'
60
+ }
61
+ ]
62
+ }
63
+ ]
64
+ }
65
+ ]
66
+ }
67
+ ];
68
+ };
69
+ };
70
+
71
71
  module.exports = ComponentsLoaderTemplate;
@@ -1,4 +1,4 @@
1
- Urso.Core.Components.SoundInitialPopup = {
2
- Controller: require('./controller.js'),
3
- Template: require('./template.js'),
1
+ Urso.Core.Components.SoundInitialPopup = {
2
+ Controller: require('./controller.js'),
3
+ Template: require('./template.js'),
4
4
  }