@urso/core 0.5.5 → 0.5.8

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 (158) 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 +222 -38
  6. package/package.json +52 -52
  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/fullscreen/_info.js +6 -6
  20. package/src/js/components/fullscreen/android.js +104 -104
  21. package/src/js/components/fullscreen/controller.js +76 -76
  22. package/src/js/components/fullscreen/desktop.js +49 -49
  23. package/src/js/components/fullscreen/ios.js +115 -115
  24. package/src/js/components/layersSwitcher/_info.js +4 -4
  25. package/src/js/components/layersSwitcher/config.js +26 -26
  26. package/src/js/components/layersSwitcher/controller.js +34 -34
  27. package/src/js/components/loader/_info.js +4 -4
  28. package/src/js/components/loader/controller.js +66 -66
  29. package/src/js/components/loader/template.js +70 -70
  30. package/src/js/components/soundInitialPopup/_info.js +3 -3
  31. package/src/js/components/soundInitialPopup/controller.js +42 -42
  32. package/src/js/components/soundInitialPopup/template.js +109 -109
  33. package/src/js/components/stateDriven/_info.js +3 -3
  34. package/src/js/components/stateDriven/controller.js +118 -118
  35. package/src/js/config/load.js +5 -5
  36. package/src/js/config/main.js +12 -12
  37. package/src/js/extra/_info.js +26 -26
  38. package/src/js/extra/browserEvents.js +38 -38
  39. package/src/js/extra/pixiPatch.js +79 -79
  40. package/src/js/extra/setTimeout.js +7 -7
  41. package/src/js/index.js +8 -8
  42. package/src/js/lib/_info.js +13 -13
  43. package/src/js/lib/cache.js +105 -105
  44. package/src/js/lib/composition.js +85 -85
  45. package/src/js/lib/device.js +1286 -1286
  46. package/src/js/lib/helper.js +539 -539
  47. package/src/js/lib/loader.js +136 -136
  48. package/src/js/lib/localData.js +15 -15
  49. package/src/js/lib/logger.js +69 -69
  50. package/src/js/lib/math.js +35 -35
  51. package/src/js/lib/objectPool.js +54 -54
  52. package/src/js/lib/time.js +18 -18
  53. package/src/js/lib/tween.js +147 -147
  54. package/src/js/modules/_info.js +12 -12
  55. package/src/js/modules/assets/_info.js +7 -7
  56. package/src/js/modules/assets/baseModel.js +18 -18
  57. package/src/js/modules/assets/config.js +37 -37
  58. package/src/js/modules/assets/controller.js +46 -46
  59. package/src/js/modules/assets/models/_info.js +11 -11
  60. package/src/js/modules/assets/models/atlas.js +8 -8
  61. package/src/js/modules/assets/models/audiosprite.js +27 -27
  62. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  63. package/src/js/modules/assets/models/container.js +16 -16
  64. package/src/js/modules/assets/models/font.js +8 -8
  65. package/src/js/modules/assets/models/image.js +13 -13
  66. package/src/js/modules/assets/models/json.js +8 -8
  67. package/src/js/modules/assets/models/sound.js +14 -14
  68. package/src/js/modules/assets/models/spine.js +14 -14
  69. package/src/js/modules/assets/service.js +365 -365
  70. package/src/js/modules/i18n/_info.js +4 -4
  71. package/src/js/modules/i18n/config.js +17 -17
  72. package/src/js/modules/i18n/controller.js +79 -79
  73. package/src/js/modules/instances/_info.js +3 -3
  74. package/src/js/modules/instances/controller.js +261 -261
  75. package/src/js/modules/logic/_info.js +4 -4
  76. package/src/js/modules/logic/config/_info.js +2 -2
  77. package/src/js/modules/logic/config/sounds.js +23 -23
  78. package/src/js/modules/logic/controller.js +48 -48
  79. package/src/js/modules/logic/sounds.js +103 -103
  80. package/src/js/modules/objects/_info.js +13 -12
  81. package/src/js/modules/objects/baseModel.js +197 -197
  82. package/src/js/modules/objects/cache.js +99 -99
  83. package/src/js/modules/objects/controller.js +131 -131
  84. package/src/js/modules/objects/find.js +58 -58
  85. package/src/js/modules/objects/models/_info.js +26 -26
  86. package/src/js/modules/objects/models/atlasImage.js +50 -50
  87. package/src/js/modules/objects/models/bitmapText.js +37 -39
  88. package/src/js/modules/objects/models/button.js +189 -189
  89. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  90. package/src/js/modules/objects/models/checkbox.js +96 -96
  91. package/src/js/modules/objects/models/collection.js +54 -54
  92. package/src/js/modules/objects/models/component.js +44 -44
  93. package/src/js/modules/objects/models/container.js +19 -19
  94. package/src/js/modules/objects/models/emitter.js +67 -67
  95. package/src/js/modules/objects/models/emitterFx.js +99 -99
  96. package/src/js/modules/objects/models/graphics.js +38 -38
  97. package/src/js/modules/objects/models/group.js +19 -19
  98. package/src/js/modules/objects/models/hitArea.js +104 -104
  99. package/src/js/modules/objects/models/image.js +34 -34
  100. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  101. package/src/js/modules/objects/models/mask.js +38 -38
  102. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  103. package/src/js/modules/objects/models/scrollbox.js +64 -64
  104. package/src/js/modules/objects/models/slider.js +253 -253
  105. package/src/js/modules/objects/models/spine.js +276 -276
  106. package/src/js/modules/objects/models/text.js +59 -59
  107. package/src/js/modules/objects/models/textInput.js +66 -66
  108. package/src/js/modules/objects/models/toggle.js +180 -180
  109. package/src/js/modules/objects/models/world.js +19 -19
  110. package/src/js/modules/objects/propertyAdapter.js +423 -423
  111. package/src/js/modules/objects/proxy.js +294 -282
  112. package/src/js/modules/objects/selector.js +136 -136
  113. package/src/js/modules/objects/service.js +240 -240
  114. package/src/js/modules/objects/styles.js +210 -210
  115. package/src/js/modules/observer/_info.js +4 -4
  116. package/src/js/modules/observer/controller.js +99 -99
  117. package/src/js/modules/observer/events.js +45 -45
  118. package/src/js/modules/scenes/_info.js +8 -8
  119. package/src/js/modules/scenes/controller.js +103 -103
  120. package/src/js/modules/scenes/model.js +28 -28
  121. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  122. package/src/js/modules/scenes/resolutions.js +173 -173
  123. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  124. package/src/js/modules/scenes/service.js +142 -142
  125. package/src/js/modules/soundManager/_info.js +3 -3
  126. package/src/js/modules/soundManager/controller.js +100 -100
  127. package/src/js/modules/soundManager/soundSprite.js +250 -243
  128. package/src/js/modules/statesManager/_info.js +12 -12
  129. package/src/js/modules/statesManager/action.js +60 -60
  130. package/src/js/modules/statesManager/actions/_info.js +3 -3
  131. package/src/js/modules/statesManager/all.js +23 -23
  132. package/src/js/modules/statesManager/configStates.js +71 -71
  133. package/src/js/modules/statesManager/controller.js +170 -170
  134. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  135. package/src/js/modules/statesManager/helper.js +27 -27
  136. package/src/js/modules/statesManager/race.js +75 -75
  137. package/src/js/modules/statesManager/sequence.js +47 -47
  138. package/src/js/modules/template/_info.js +6 -6
  139. package/src/js/modules/template/controller.js +28 -28
  140. package/src/js/modules/template/model.js +11 -11
  141. package/src/js/modules/template/service.js +137 -137
  142. package/src/js/modules/template/types.js +46 -46
  143. package/src/js/modules/transport/_info.js +8 -8
  144. package/src/js/modules/transport/baseConnectionType.js +24 -24
  145. package/src/js/modules/transport/config.js +13 -13
  146. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  147. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  148. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  149. package/src/js/modules/transport/controller.js +48 -48
  150. package/src/js/modules/transport/decorator.js +17 -17
  151. package/src/js/modules/transport/service.js +153 -153
  152. package/src/js/templates/_info.js +4 -4
  153. package/src/js/templates/groups/_info.js +1 -1
  154. package/src/js/templates/scenes/_info.js +1 -1
  155. package/webpack.config.js +47 -47
  156. package/src/js/components/editor/_info.js +0 -4
  157. package/src/js/components/editor/api.js +0 -72
  158. package/src/js/components/editor/controller.js +0 -13
@@ -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
  }