@urso/core 0.7.90 → 0.7.92

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 (133) hide show
  1. package/.babelrc +11 -11
  2. package/LICENSE +20 -20
  3. package/README.md +227 -227
  4. package/build/js/index.js +1 -1
  5. package/package.json +50 -50
  6. package/src/js/app.js +104 -104
  7. package/src/js/components/base/controller.js +78 -78
  8. package/src/js/components/debug/controller.js +38 -38
  9. package/src/js/components/debug/coords.js +23 -23
  10. package/src/js/components/debug/fps.js +36 -36
  11. package/src/js/components/debug/template.js +55 -55
  12. package/src/js/components/debug/timescale.js +60 -60
  13. package/src/js/components/deviceRotate/controller.js +95 -95
  14. package/src/js/components/editor/api.js +127 -127
  15. package/src/js/components/editor/controller.js +12 -12
  16. package/src/js/components/fullscreen/android.js +104 -104
  17. package/src/js/components/fullscreen/controller.js +76 -76
  18. package/src/js/components/fullscreen/desktop.js +49 -49
  19. package/src/js/components/fullscreen/ios.js +115 -115
  20. package/src/js/components/layersSwitcher/config.js +26 -26
  21. package/src/js/components/layersSwitcher/controller.js +36 -36
  22. package/src/js/components/loader/controller.js +66 -66
  23. package/src/js/components/loader/template.js +70 -70
  24. package/src/js/components/soundInitialPopup/controller.js +42 -42
  25. package/src/js/components/soundInitialPopup/template.js +109 -109
  26. package/src/js/components/stateDriven/controller.js +123 -123
  27. package/src/js/config/load.js +194 -194
  28. package/src/js/config/main.js +17 -17
  29. package/src/js/extra/browserEvents.js +57 -57
  30. package/src/js/extra/main.js +19 -19
  31. package/src/js/extra/pixiPatch.js +171 -171
  32. package/src/js/index.js +7 -7
  33. package/src/js/lib/cache.js +125 -125
  34. package/src/js/lib/composition.js +85 -85
  35. package/src/js/lib/device.js +1215 -1215
  36. package/src/js/lib/helper.js +678 -678
  37. package/src/js/lib/loader.js +211 -211
  38. package/src/js/lib/localData.js +28 -28
  39. package/src/js/lib/logger.js +69 -69
  40. package/src/js/lib/math.js +161 -161
  41. package/src/js/lib/objectPool.js +207 -207
  42. package/src/js/lib/time.js +18 -18
  43. package/src/js/lib/tween.js +152 -152
  44. package/src/js/modules/assets/baseModel.js +20 -20
  45. package/src/js/modules/assets/config.js +38 -38
  46. package/src/js/modules/assets/controller.js +65 -65
  47. package/src/js/modules/assets/models/atlas.js +18 -18
  48. package/src/js/modules/assets/models/audiosprite.js +28 -28
  49. package/src/js/modules/assets/models/bitmapFont.js +10 -10
  50. package/src/js/modules/assets/models/container.js +18 -18
  51. package/src/js/modules/assets/models/font.js +10 -10
  52. package/src/js/modules/assets/models/html.js +10 -10
  53. package/src/js/modules/assets/models/image.js +17 -17
  54. package/src/js/modules/assets/models/json.js +10 -10
  55. package/src/js/modules/assets/models/jsonAtlas.js +10 -10
  56. package/src/js/modules/assets/models/sound.js +16 -16
  57. package/src/js/modules/assets/models/spine.js +16 -16
  58. package/src/js/modules/assets/service.js +541 -541
  59. package/src/js/modules/i18n/config.js +17 -17
  60. package/src/js/modules/i18n/controller.js +71 -71
  61. package/src/js/modules/instances/controller.js +357 -357
  62. package/src/js/modules/logic/config/sounds.js +23 -23
  63. package/src/js/modules/logic/controller.js +52 -52
  64. package/src/js/modules/logic/main.js +8 -8
  65. package/src/js/modules/logic/sounds.js +103 -103
  66. package/src/js/modules/objects/baseModel.js +207 -207
  67. package/src/js/modules/objects/cache.js +99 -99
  68. package/src/js/modules/objects/config.js +9 -9
  69. package/src/js/modules/objects/controller.js +139 -139
  70. package/src/js/modules/objects/find.js +58 -58
  71. package/src/js/modules/objects/models/atlasImage.js +52 -52
  72. package/src/js/modules/objects/models/bitmapText.js +48 -48
  73. package/src/js/modules/objects/models/button.js +196 -196
  74. package/src/js/modules/objects/models/buttonComposite.js +37 -37
  75. package/src/js/modules/objects/models/checkbox.js +96 -96
  76. package/src/js/modules/objects/models/collection.js +54 -54
  77. package/src/js/modules/objects/models/component.js +48 -48
  78. package/src/js/modules/objects/models/container.js +21 -21
  79. package/src/js/modules/objects/models/dragContainer.js +664 -664
  80. package/src/js/modules/objects/models/emitter.js +69 -69
  81. package/src/js/modules/objects/models/emitterFx.js +114 -114
  82. package/src/js/modules/objects/models/graphics.js +40 -40
  83. package/src/js/modules/objects/models/group.js +21 -21
  84. package/src/js/modules/objects/models/hitArea.js +119 -119
  85. package/src/js/modules/objects/models/image.js +36 -36
  86. package/src/js/modules/objects/models/imagesAnimation.js +115 -115
  87. package/src/js/modules/objects/models/mask.js +40 -40
  88. package/src/js/modules/objects/models/nineSlicePlane.js +32 -32
  89. package/src/js/modules/objects/models/scrollbox.js +66 -66
  90. package/src/js/modules/objects/models/slider.js +352 -352
  91. package/src/js/modules/objects/models/spine.js +338 -338
  92. package/src/js/modules/objects/models/text.js +70 -70
  93. package/src/js/modules/objects/models/textInput.js +68 -68
  94. package/src/js/modules/objects/models/toggle.js +179 -179
  95. package/src/js/modules/objects/models/world.js +21 -21
  96. package/src/js/modules/objects/pool.js +68 -68
  97. package/src/js/modules/objects/propertyAdapter.js +588 -588
  98. package/src/js/modules/objects/proxy.js +298 -298
  99. package/src/js/modules/objects/selector.js +136 -136
  100. package/src/js/modules/objects/service.js +254 -254
  101. package/src/js/modules/objects/styles.js +210 -210
  102. package/src/js/modules/observer/controller.js +167 -167
  103. package/src/js/modules/observer/events.js +56 -56
  104. package/src/js/modules/scenes/controller.js +127 -127
  105. package/src/js/modules/scenes/model.js +28 -28
  106. package/src/js/modules/scenes/pixiWrapper.js +351 -351
  107. package/src/js/modules/scenes/resolutions.js +173 -173
  108. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  109. package/src/js/modules/scenes/service.js +146 -146
  110. package/src/js/modules/soundManager/controller.js +103 -103
  111. package/src/js/modules/soundManager/soundSprite.js +285 -285
  112. package/src/js/modules/statesManager/action.js +97 -97
  113. package/src/js/modules/statesManager/all.js +23 -23
  114. package/src/js/modules/statesManager/configStates.js +77 -77
  115. package/src/js/modules/statesManager/controller.js +218 -218
  116. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  117. package/src/js/modules/statesManager/helper.js +27 -27
  118. package/src/js/modules/statesManager/race.js +91 -91
  119. package/src/js/modules/statesManager/sequence.js +48 -48
  120. package/src/js/modules/template/controller.js +28 -28
  121. package/src/js/modules/template/model.js +11 -11
  122. package/src/js/modules/template/service.js +137 -137
  123. package/src/js/modules/template/types.js +48 -48
  124. package/src/js/modules/transport/baseConnectionType.js +25 -25
  125. package/src/js/modules/transport/config.js +13 -13
  126. package/src/js/modules/transport/connectionTypes/websocket.js +76 -76
  127. package/src/js/modules/transport/connectionTypes/xhr.js +46 -46
  128. package/src/js/modules/transport/controller.js +48 -48
  129. package/src/js/modules/transport/decorator.js +17 -17
  130. package/src/js/modules/transport/service.js +150 -150
  131. package/webpack.config.js +47 -47
  132. package/build/162.js/index.js +0 -1
  133. package/build/24.js/index.js +0 -1
@@ -1,49 +1,49 @@
1
- class ComponentsFullscreenDesktop {
2
- init() { }
3
-
4
- get isFullscreen() {
5
- return (
6
- document.webkitIsFullScreen ||
7
- document.mozFullScreen ||
8
- document.fullscreen
9
- );
10
- }
11
-
12
- _requestFullscreen() {
13
- if (document.body.webkitRequestFullScreen)
14
- document.body.webkitRequestFullScreen();
15
- else if (document.body.mozRequestFullScreen)
16
- document.body.mozRequestFullScreen();
17
- else if (document.body.requestFullScreen)
18
- document.body.requestFullScreen();
19
- }
20
-
21
- _cancelFullscreen() {
22
- if (document.webkitCancelFullScreen)
23
- document.webkitCancelFullScreen();
24
- else if (document.mozCancelFullScreen)
25
- document.mozCancelFullScreen();
26
- else if (document.cancelFullScreen)
27
- document.cancelFullScreen();
28
- }
29
-
30
- _switchFullscreen(needGoFullscreen = null) {
31
- if (needGoFullscreen === null)
32
- needGoFullscreen = !this.isFullscreen;
33
-
34
- if (needGoFullscreen)
35
- this._requestFullscreen();
36
- else
37
- this._cancelFullscreen();
38
- }
39
-
40
- _fullscreenSwitchHandler(needGoFullscreen = null) {
41
- this._switchFullscreen(needGoFullscreen);
42
- }
43
-
44
- _subscribeOnce() {
45
- this.addListener(Urso.events.COMPONENTS_FULLSCREEN_SWITCH, this._fullscreenSwitchHandler.bind(this));
46
- }
47
- }
48
-
49
- module.exports = ComponentsFullscreenDesktop;
1
+ class ComponentsFullscreenDesktop {
2
+ init() { }
3
+
4
+ get isFullscreen() {
5
+ return (
6
+ document.webkitIsFullScreen ||
7
+ document.mozFullScreen ||
8
+ document.fullscreen
9
+ );
10
+ }
11
+
12
+ _requestFullscreen() {
13
+ if (document.body.webkitRequestFullScreen)
14
+ document.body.webkitRequestFullScreen();
15
+ else if (document.body.mozRequestFullScreen)
16
+ document.body.mozRequestFullScreen();
17
+ else if (document.body.requestFullScreen)
18
+ document.body.requestFullScreen();
19
+ }
20
+
21
+ _cancelFullscreen() {
22
+ if (document.webkitCancelFullScreen)
23
+ document.webkitCancelFullScreen();
24
+ else if (document.mozCancelFullScreen)
25
+ document.mozCancelFullScreen();
26
+ else if (document.cancelFullScreen)
27
+ document.cancelFullScreen();
28
+ }
29
+
30
+ _switchFullscreen(needGoFullscreen = null) {
31
+ if (needGoFullscreen === null)
32
+ needGoFullscreen = !this.isFullscreen;
33
+
34
+ if (needGoFullscreen)
35
+ this._requestFullscreen();
36
+ else
37
+ this._cancelFullscreen();
38
+ }
39
+
40
+ _fullscreenSwitchHandler(needGoFullscreen = null) {
41
+ this._switchFullscreen(needGoFullscreen);
42
+ }
43
+
44
+ _subscribeOnce() {
45
+ this.addListener(Urso.events.COMPONENTS_FULLSCREEN_SWITCH, this._fullscreenSwitchHandler.bind(this));
46
+ }
47
+ }
48
+
49
+ module.exports = ComponentsFullscreenDesktop;
@@ -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 = `${Urso.config.gamePath}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 = `${Urso.config.gamePath}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,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,36 +1,36 @@
1
- const ComponentsBaseController = require('./../base/controller');
2
-
3
- class ComponentsLayersSwitcherController extends ComponentsBaseController {
4
-
5
- constructor(...args) {
6
- super(...args);
7
- this._config = this.getInstance('Config');
8
- }
9
-
10
- /**
11
- * disable all layers from the list of managed layers (config.allLayers) and enables layers corresponding to the desired group (config.groupsLayers[groupName])
12
- * @param {String} groupName
13
- */
14
- _showGroup(groupName) {
15
- const configLayersGroup = this._config.groupsLayers[groupName];
16
-
17
- if (configLayersGroup) {
18
- this._config.allLayers.forEach(selectorLayers => {
19
- const layerVisibleStatus = (configLayersGroup.includes(selectorLayers)) ? true : false;
20
-
21
- Urso.findAll(selectorLayers).forEach((selectorObject) => {
22
- selectorObject.visible = layerVisibleStatus;
23
- });
24
- });
25
-
26
- } else {
27
- Urso.logger.error(`ComponentsLayersSwitcherController: group '${groupName}' was not found!`);
28
- }
29
- }
30
-
31
- _subscribeOnce() {
32
- this.addListener(Urso.events.COMPONENTS_LAYERS_SWITCHER_SWITCH, (groupName) => { this._showGroup(groupName) });
33
- }
34
- }
35
-
36
- module.exports = ComponentsLayersSwitcherController;
1
+ const ComponentsBaseController = require('./../base/controller');
2
+
3
+ class ComponentsLayersSwitcherController extends ComponentsBaseController {
4
+
5
+ constructor(...args) {
6
+ super(...args);
7
+ this._config = this.getInstance('Config');
8
+ }
9
+
10
+ /**
11
+ * disable all layers from the list of managed layers (config.allLayers) and enables layers corresponding to the desired group (config.groupsLayers[groupName])
12
+ * @param {String} groupName
13
+ */
14
+ _showGroup(groupName) {
15
+ const configLayersGroup = this._config.groupsLayers[groupName];
16
+
17
+ if (configLayersGroup) {
18
+ this._config.allLayers.forEach(selectorLayers => {
19
+ const layerVisibleStatus = (configLayersGroup.includes(selectorLayers)) ? true : false;
20
+
21
+ Urso.findAll(selectorLayers).forEach((selectorObject) => {
22
+ selectorObject.visible = layerVisibleStatus;
23
+ });
24
+ });
25
+
26
+ } else {
27
+ Urso.logger.error(`ComponentsLayersSwitcherController: group '${groupName}' was not found!`);
28
+ }
29
+ }
30
+
31
+ _subscribeOnce() {
32
+ this.addListener(Urso.events.COMPONENTS_LAYERS_SWITCHER_SWITCH, (groupName) => { this._showGroup(groupName) });
33
+ }
34
+ }
35
+
36
+ module.exports = ComponentsLayersSwitcherController;
@@ -1,66 +1,66 @@
1
- const ComponentsBaseController = require('./../base/controller');
2
-
3
- class ComponentsLoaderController extends ComponentsBaseController {
4
-
5
- constructor(options) {
6
- super(options);
7
-
8
- //load own assets
9
-
10
- //then create loader objects
11
- Urso.objects.create(this.getInstance('Template').objects);
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
- //todo remove all objects
29
- }
30
-
31
- setMask() {
32
- if (this.loaderBg && this.loaderBgMask)
33
- this.loaderBg._baseObject.mask = this.loaderBgMask._baseObject
34
- }
35
-
36
- formatAmountText(text) {
37
- return `${text}%`;
38
- }
39
-
40
- setLoadProgress(val) {
41
- if (!this.componentCreated)
42
- return;
43
-
44
- this.loaderBgMask._baseObject.scale.x = val;
45
- this.loadAmountText.text = this.formatAmountText(val);
46
- }
47
-
48
- get componentCreated() {
49
- return !!this.loadAmountText && !!this.loaderBg && !!this.loaderBgMask;
50
- }
51
-
52
- get loadAmountText() {
53
- return Urso.findOne('.loadAmountText');
54
- }
55
-
56
- get loaderBg() {
57
- return Urso.findOne('^loaderBg');
58
- }
59
-
60
- get loaderBgMask() {
61
- return Urso.findOne('^loaderBgMask');
62
- }
63
-
64
- }
65
-
66
- module.exports = ComponentsLoaderController;
1
+ const ComponentsBaseController = require('./../base/controller');
2
+
3
+ class ComponentsLoaderController extends ComponentsBaseController {
4
+
5
+ constructor(options) {
6
+ super(options);
7
+
8
+ //load own assets
9
+
10
+ //then create loader objects
11
+ Urso.objects.create(this.getInstance('Template').objects);
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
+ //todo remove all objects
29
+ }
30
+
31
+ setMask() {
32
+ if (this.loaderBg && this.loaderBgMask)
33
+ this.loaderBg._baseObject.mask = this.loaderBgMask._baseObject
34
+ }
35
+
36
+ formatAmountText(text) {
37
+ return `${text}%`;
38
+ }
39
+
40
+ setLoadProgress(val) {
41
+ if (!this.componentCreated)
42
+ return;
43
+
44
+ this.loaderBgMask._baseObject.scale.x = val;
45
+ this.loadAmountText.text = this.formatAmountText(val);
46
+ }
47
+
48
+ get componentCreated() {
49
+ return !!this.loadAmountText && !!this.loaderBg && !!this.loaderBgMask;
50
+ }
51
+
52
+ get loadAmountText() {
53
+ return Urso.findOne('.loadAmountText');
54
+ }
55
+
56
+ get loaderBg() {
57
+ return Urso.findOne('^loaderBg');
58
+ }
59
+
60
+ get loaderBgMask() {
61
+ return Urso.findOne('^loaderBgMask');
62
+ }
63
+
64
+ }
65
+
66
+ module.exports = ComponentsLoaderController;