@urso/core 0.6.16-dev → 0.6.16

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 +227 -227
  4. package/build/js/index.js +1 -1
  5. package/build/js/index.js.LICENSE.txt +38 -270
  6. package/package.json +52 -52
  7. package/src/js/app.js +79 -79
  8. package/src/js/components/_info.js +11 -11
  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 +36 -36
  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 +65 -65
  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 +16 -16
  37. package/src/js/extra/_info.js +26 -26
  38. package/src/js/extra/browserEvents.js +51 -51
  39. package/src/js/extra/pixiPatch.js +150 -150
  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 +556 -556
  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 +203 -203
  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 +20 -20
  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 +15 -15
  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 +366 -366
  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 +357 -357
  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 -13
  81. package/src/js/modules/objects/baseModel.js +200 -200
  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 +27 -27
  86. package/src/js/modules/objects/models/atlasImage.js +50 -50
  87. package/src/js/modules/objects/models/bitmapText.js +37 -37
  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 +46 -46
  93. package/src/js/modules/objects/models/container.js +19 -19
  94. package/src/js/modules/objects/models/dragContainer.js +667 -667
  95. package/src/js/modules/objects/models/emitter.js +67 -67
  96. package/src/js/modules/objects/models/emitterFx.js +99 -99
  97. package/src/js/modules/objects/models/graphics.js +38 -38
  98. package/src/js/modules/objects/models/group.js +19 -19
  99. package/src/js/modules/objects/models/hitArea.js +104 -104
  100. package/src/js/modules/objects/models/image.js +34 -34
  101. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  102. package/src/js/modules/objects/models/mask.js +38 -38
  103. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  104. package/src/js/modules/objects/models/scrollbox.js +64 -64
  105. package/src/js/modules/objects/models/slider.js +253 -253
  106. package/src/js/modules/objects/models/spine.js +296 -287
  107. package/src/js/modules/objects/models/text.js +59 -59
  108. package/src/js/modules/objects/models/textInput.js +66 -66
  109. package/src/js/modules/objects/models/toggle.js +180 -180
  110. package/src/js/modules/objects/models/world.js +19 -19
  111. package/src/js/modules/objects/propertyAdapter.js +588 -587
  112. package/src/js/modules/objects/proxy.js +294 -294
  113. package/src/js/modules/objects/selector.js +136 -136
  114. package/src/js/modules/objects/service.js +242 -242
  115. package/src/js/modules/objects/styles.js +210 -210
  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 +52 -52
  119. package/src/js/modules/scenes/_info.js +8 -8
  120. package/src/js/modules/scenes/controller.js +119 -119
  121. package/src/js/modules/scenes/model.js +28 -28
  122. package/src/js/modules/scenes/pixiWrapper.js +336 -336
  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 +142 -142
  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 +251 -251
  129. package/src/js/modules/statesManager/_info.js +12 -12
  130. package/src/js/modules/statesManager/action.js +68 -68
  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 +46 -46
  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,76 +1,76 @@
1
- ComponentsBaseController = require('./../base/controller.js');
2
-
3
- class ComponentsFullscreenController extends ComponentsBaseController {
4
-
5
- constructor(params) {
6
- super(params);
7
-
8
- this._fullscreenActivator = null;
9
- this._resolutionsConfig = null;
10
- this.lastResizeFullscreenResult;
11
-
12
- this.createActivator();
13
- this._resizeHandler();
14
- }
15
-
16
- createActivator() {
17
- if (this._isCriOS)
18
- return;
19
-
20
- this._resolutionsConfig = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
21
-
22
- if (Urso.device.desktop)
23
- this._fullscreenActivator = this.getInstance('Desktop');
24
- else if (Urso.device.iOS)
25
- this._fullscreenActivator = this.getInstance('Ios');
26
- else if (Urso.device.android)
27
- this._fullscreenActivator = this.getInstance('Android');
28
-
29
- if (this._fullscreenActivator)
30
- this._fullscreenActivator.init();
31
- }
32
-
33
- get _isCriOS() {
34
- return navigator.userAgent.includes('CriOS');
35
- }
36
-
37
- get _orientationsConfig() {
38
- return Urso.getInstance('Modules.Scenes.ResolutionsConfig')._orientations || [];
39
- }
40
-
41
- get _showOnLandscape() {
42
- return this._resolutionsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.LANDSCAPE);
43
- }
44
-
45
- get _showOnPortrait() {
46
- return this._resolutionsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.PORTRAIT);
47
- }
48
-
49
- get _isPortrait() {
50
- return innerWidth > innerHeight ? Urso.device.ScreenOrientation.PORTRAIT : Urso.device.ScreenOrientation.LANDSCAPE;
51
- }
52
-
53
- get isFullscreen() {
54
- if (!this._fullscreenActivator)
55
- return false;
56
-
57
- return this._fullscreenActivator.isFullscreen;
58
- }
59
-
60
- _resizeHandler() {
61
- const isFullscreen = this.isFullscreen;
62
-
63
- if (this.lastResizeFullscreenResult === isFullscreen)
64
- return;
65
-
66
- this.lastResizeFullscreenResult = isFullscreen;
67
- Urso.localData.set('fullscreen.isFullscreen', isFullscreen);
68
- this.emit(Urso.events.COMPONENTS_FULLSCREEN_CHANGE, isFullscreen);
69
- }
70
-
71
- _subscribeOnce() {
72
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
73
- }
74
- }
75
-
76
- module.exports = ComponentsFullscreenController;
1
+ ComponentsBaseController = require('./../base/controller.js');
2
+
3
+ class ComponentsFullscreenController extends ComponentsBaseController {
4
+
5
+ constructor(params) {
6
+ super(params);
7
+
8
+ this._fullscreenActivator = null;
9
+ this._resolutionsConfig = null;
10
+ this.lastResizeFullscreenResult;
11
+
12
+ this.createActivator();
13
+ this._resizeHandler();
14
+ }
15
+
16
+ createActivator() {
17
+ if (this._isCriOS)
18
+ return;
19
+
20
+ this._resolutionsConfig = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
21
+
22
+ if (Urso.device.desktop)
23
+ this._fullscreenActivator = this.getInstance('Desktop');
24
+ else if (Urso.device.iOS)
25
+ this._fullscreenActivator = this.getInstance('Ios');
26
+ else if (Urso.device.android)
27
+ this._fullscreenActivator = this.getInstance('Android');
28
+
29
+ if (this._fullscreenActivator)
30
+ this._fullscreenActivator.init();
31
+ }
32
+
33
+ get _isCriOS() {
34
+ return navigator.userAgent.includes('CriOS');
35
+ }
36
+
37
+ get _orientationsConfig() {
38
+ return Urso.getInstance('Modules.Scenes.ResolutionsConfig')._orientations || [];
39
+ }
40
+
41
+ get _showOnLandscape() {
42
+ return this._resolutionsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.LANDSCAPE);
43
+ }
44
+
45
+ get _showOnPortrait() {
46
+ return this._resolutionsConfig.find(resolution => resolution.orientation === Urso.device.ScreenOrientation.PORTRAIT);
47
+ }
48
+
49
+ get _isPortrait() {
50
+ return innerWidth > innerHeight ? Urso.device.ScreenOrientation.PORTRAIT : Urso.device.ScreenOrientation.LANDSCAPE;
51
+ }
52
+
53
+ get isFullscreen() {
54
+ if (!this._fullscreenActivator)
55
+ return false;
56
+
57
+ return this._fullscreenActivator.isFullscreen;
58
+ }
59
+
60
+ _resizeHandler() {
61
+ const isFullscreen = this.isFullscreen;
62
+
63
+ if (this.lastResizeFullscreenResult === isFullscreen)
64
+ return;
65
+
66
+ this.lastResizeFullscreenResult = isFullscreen;
67
+ Urso.localData.set('fullscreen.isFullscreen', isFullscreen);
68
+ this.emit(Urso.events.COMPONENTS_FULLSCREEN_CHANGE, isFullscreen);
69
+ }
70
+
71
+ _subscribeOnce() {
72
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
73
+ }
74
+ }
75
+
76
+ module.exports = ComponentsFullscreenController;
@@ -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 = '/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
+ };