@urso/core 0.1.91 → 0.2.0-dev

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 (143) hide show
  1. package/.babelrc +11 -11
  2. package/README.md +10 -10
  3. package/build/js/index.js +1 -1
  4. package/package.json +49 -49
  5. package/src/js/app.js +76 -75
  6. package/src/js/components/_info.js +8 -8
  7. package/src/js/components/base/_info.js +3 -3
  8. package/src/js/components/base/controller.js +78 -78
  9. package/src/js/components/debug/_info.js +6 -6
  10. package/src/js/components/debug/controller.js +38 -38
  11. package/src/js/components/debug/coords.js +23 -23
  12. package/src/js/components/debug/fps.js +34 -34
  13. package/src/js/components/debug/template.js +33 -33
  14. package/src/js/components/deviceRotate/_info.js +3 -3
  15. package/src/js/components/deviceRotate/controller.js +86 -86
  16. package/src/js/components/fullscreen/_info.js +6 -6
  17. package/src/js/components/fullscreen/android.js +104 -104
  18. package/src/js/components/fullscreen/controller.js +64 -64
  19. package/src/js/components/fullscreen/desktop.js +49 -49
  20. package/src/js/components/fullscreen/ios.js +111 -111
  21. package/src/js/components/loader/_info.js +4 -4
  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/_info.js +3 -3
  25. package/src/js/components/soundInitialPopup/controller.js +42 -42
  26. package/src/js/components/soundInitialPopup/template.js +109 -109
  27. package/src/js/components/stateDriven/_info.js +4 -3
  28. package/src/js/components/stateDriven/actionConfig.js +7 -0
  29. package/src/js/components/stateDriven/controller.js +61 -52
  30. package/src/js/config/load.js +5 -5
  31. package/src/js/config/main.js +9 -8
  32. package/src/js/extra/_info.js +22 -22
  33. package/src/js/extra/browserEvents.js +32 -32
  34. package/src/js/index.js +8 -8
  35. package/src/js/lib/_info.js +13 -13
  36. package/src/js/lib/cache.js +98 -98
  37. package/src/js/lib/composition.js +89 -89
  38. package/src/js/lib/device.js +1276 -1276
  39. package/src/js/lib/helper.js +513 -513
  40. package/src/js/lib/loader.js +121 -100
  41. package/src/js/lib/localData.js +15 -15
  42. package/src/js/lib/logger.js +22 -22
  43. package/src/js/lib/math.js +20 -20
  44. package/src/js/lib/objectPool.js +54 -54
  45. package/src/js/lib/time.js +18 -18
  46. package/src/js/lib/tween.js +147 -147
  47. package/src/js/modules/_info.js +11 -11
  48. package/src/js/modules/assets/_info.js +7 -7
  49. package/src/js/modules/assets/baseModel.js +18 -18
  50. package/src/js/modules/assets/config.js +35 -25
  51. package/src/js/modules/assets/controller.js +37 -21
  52. package/src/js/modules/assets/models/_info.js +12 -12
  53. package/src/js/modules/assets/models/atlas.js +8 -8
  54. package/src/js/modules/assets/models/audiosprite.js +27 -27
  55. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  56. package/src/js/modules/assets/models/container.js +16 -16
  57. package/src/js/modules/assets/models/dragonBones.js +26 -26
  58. package/src/js/modules/assets/models/font.js +8 -8
  59. package/src/js/modules/assets/models/image.js +14 -14
  60. package/src/js/modules/assets/models/json.js +8 -8
  61. package/src/js/modules/assets/models/sound.js +14 -14
  62. package/src/js/modules/assets/models/spine.js +8 -8
  63. package/src/js/modules/assets/service.js +330 -303
  64. package/src/js/modules/instances/_info.js +3 -3
  65. package/src/js/modules/instances/controller.js +218 -218
  66. package/src/js/modules/logic/_info.js +5 -5
  67. package/src/js/modules/logic/buttons.js +120 -120
  68. package/src/js/modules/logic/config/_info.js +3 -3
  69. package/src/js/modules/logic/config/buttons.js +63 -63
  70. package/src/js/modules/logic/config/sounds.js +23 -23
  71. package/src/js/modules/logic/controller.js +48 -48
  72. package/src/js/modules/logic/sounds.js +96 -96
  73. package/src/js/modules/objects/_info.js +11 -11
  74. package/src/js/modules/objects/baseModel.js +161 -161
  75. package/src/js/modules/objects/cache.js +99 -99
  76. package/src/js/modules/objects/controller.js +115 -115
  77. package/src/js/modules/objects/create.js +231 -231
  78. package/src/js/modules/objects/find.js +140 -140
  79. package/src/js/modules/objects/models/_info.js +20 -20
  80. package/src/js/modules/objects/models/atlasImage.js +50 -50
  81. package/src/js/modules/objects/models/bitmapText.js +23 -23
  82. package/src/js/modules/objects/models/button.js +184 -184
  83. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  84. package/src/js/modules/objects/models/collection.js +54 -54
  85. package/src/js/modules/objects/models/component.js +44 -44
  86. package/src/js/modules/objects/models/container.js +19 -19
  87. package/src/js/modules/objects/models/dragonBones.js +250 -250
  88. package/src/js/modules/objects/models/emitter.js +54 -54
  89. package/src/js/modules/objects/models/graphics.js +38 -38
  90. package/src/js/modules/objects/models/group.js +19 -19
  91. package/src/js/modules/objects/models/hitArea.js +104 -104
  92. package/src/js/modules/objects/models/image.js +34 -34
  93. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  94. package/src/js/modules/objects/models/mask.js +38 -38
  95. package/src/js/modules/objects/models/spine.js +83 -83
  96. package/src/js/modules/objects/models/text.js +38 -38
  97. package/src/js/modules/objects/models/world.js +19 -19
  98. package/src/js/modules/objects/propertyAdapter.js +416 -416
  99. package/src/js/modules/objects/proxy.js +179 -179
  100. package/src/js/modules/objects/styles.js +116 -116
  101. package/src/js/modules/observer/_info.js +4 -4
  102. package/src/js/modules/observer/controller.js +99 -99
  103. package/src/js/modules/observer/events.js +28 -28
  104. package/src/js/modules/scenes/_info.js +8 -8
  105. package/src/js/modules/scenes/controller.js +34 -34
  106. package/src/js/modules/scenes/model.js +35 -35
  107. package/src/js/modules/scenes/pixiWrapper.js +194 -194
  108. package/src/js/modules/scenes/resolutions.js +161 -161
  109. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  110. package/src/js/modules/scenes/service.js +84 -84
  111. package/src/js/modules/soundManager/_info.js +3 -3
  112. package/src/js/modules/soundManager/controller.js +99 -99
  113. package/src/js/modules/soundManager/soundSprite.js +202 -202
  114. package/src/js/modules/statesManager/_info.js +12 -12
  115. package/src/js/modules/statesManager/action.js +55 -113
  116. package/src/js/modules/statesManager/actions/_info.js +3 -3
  117. package/src/js/modules/statesManager/all.js +23 -23
  118. package/src/js/modules/statesManager/configStates.js +71 -86
  119. package/src/js/modules/statesManager/controller.js +132 -91
  120. package/src/js/modules/statesManager/functionsStorage.js +83 -0
  121. package/src/js/modules/statesManager/helper.js +27 -37
  122. package/src/js/modules/statesManager/race.js +75 -80
  123. package/src/js/modules/statesManager/sequence.js +47 -47
  124. package/src/js/modules/template/_info.js +6 -6
  125. package/src/js/modules/template/controller.js +28 -28
  126. package/src/js/modules/template/model.js +11 -11
  127. package/src/js/modules/template/service.js +125 -122
  128. package/src/js/modules/template/types.js +41 -41
  129. package/src/js/modules/transport/_info.js +8 -8
  130. package/src/js/modules/transport/baseConnectionType.js +24 -24
  131. package/src/js/modules/transport/config.js +22 -22
  132. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  133. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  134. package/src/js/modules/transport/connectionTypes/xhr.js +41 -41
  135. package/src/js/modules/transport/controller.js +48 -48
  136. package/src/js/modules/transport/decorator.js +16 -16
  137. package/src/js/modules/transport/service.js +138 -138
  138. package/src/js/templates/_info.js +4 -4
  139. package/src/js/templates/groups/_info.js +1 -1
  140. package/src/js/templates/scenes/_info.js +1 -1
  141. package/webpack.config.js +47 -47
  142. package/src/js/modules/statesManager/actionModel.js +0 -48
  143. package/src/js/modules/statesManager/configActions.js +0 -54
@@ -1,33 +1,33 @@
1
- class ComponentsDebugTemplate {
2
-
3
- constructor() {
4
- this.objects = [
5
- {
6
- type: Urso.types.objects.CONTAINER,
7
- name: 'debugContainer',
8
- contents:[
9
- {
10
- type: Urso.types.objects.TEXT,
11
- name: 'debugCoords',
12
- text: 'x:0, y:0',
13
- fontFamily: 'Helvetica',
14
- fontSize: 15,
15
- fill: '#00FF00'
16
- },
17
- {
18
- type: Urso.types.objects.TEXT,
19
- name: 'debugFps',
20
- text: 'fps: 0',
21
- y: 15,
22
- fontFamily: 'Helvetica',
23
- fontSize: 15,
24
- fill: '#00FF00'
25
- }
26
- ]
27
- }
28
- ]
29
- }
30
-
31
- }
32
-
33
- module.exports = ComponentsDebugTemplate;
1
+ class ComponentsDebugTemplate {
2
+
3
+ constructor() {
4
+ this.objects = [
5
+ {
6
+ type: Urso.types.objects.CONTAINER,
7
+ name: 'debugContainer',
8
+ contents:[
9
+ {
10
+ type: Urso.types.objects.TEXT,
11
+ name: 'debugCoords',
12
+ text: 'x:0, y:0',
13
+ fontFamily: 'Helvetica',
14
+ fontSize: 15,
15
+ fill: '#00FF00'
16
+ },
17
+ {
18
+ type: Urso.types.objects.TEXT,
19
+ name: 'debugFps',
20
+ text: 'fps: 0',
21
+ y: 15,
22
+ fontFamily: 'Helvetica',
23
+ fontSize: 15,
24
+ fill: '#00FF00'
25
+ }
26
+ ]
27
+ }
28
+ ]
29
+ }
30
+
31
+ }
32
+
33
+ module.exports = ComponentsDebugTemplate;
@@ -1,3 +1,3 @@
1
- Urso.Core.Components.DeviceRotate = {
2
- Controller: require('./controller.js')
3
- };
1
+ Urso.Core.Components.DeviceRotate = {
2
+ Controller: require('./controller.js')
3
+ };
@@ -1,86 +1,86 @@
1
- ComponentsBaseController = require('./../base/controller.js');
2
-
3
- class ComponentsDeviceRotateController extends ComponentsBaseController {
4
- constructor(params) {
5
- super(params);
6
-
7
- this._div = null;
8
- this._orientation = null;
9
- this._resolutionsConfig = null;
10
- }
11
-
12
- create() {
13
- if (Urso.device.desktop)
14
- return;
15
-
16
- this._resolutionsConfig = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
17
-
18
- this._createDom();
19
- this._updateOrientation();
20
- this._updateVisibility();
21
- }
22
-
23
- _createDom() {
24
- this._div = document.createElement('div');
25
- this._div.className = 'fullscreen';
26
- this._div.style.touchAction = 'none';
27
- this._div.style.visibility = 'hidden';
28
-
29
- document.body.prepend(this._div);
30
-
31
- const infoDiv = document.createElement('div');
32
- infoDiv.className = 'fullscreen-info';
33
- this._div.appendChild(infoDiv);
34
-
35
- const image = document.createElement('img');
36
- image.src = '/assets/images/fullscreen/rotate.png';
37
- const span = document.createElement('span');
38
- span.innerText = 'Please rotate device';
39
-
40
- infoDiv.appendChild(image);
41
- infoDiv.appendChild(span);
42
- }
43
-
44
- get _showOnLandscape() {
45
- return !this._resolutionsConfig.find(resolution => resolution.orientation === 'landscape');
46
- }
47
-
48
- get _showOnPortrait() {
49
- return !this._resolutionsConfig.find(resolution => resolution.orientation === 'portrait');
50
- }
51
-
52
- get _isPortrait() {
53
- return this._orientation === 'portrait';
54
- }
55
-
56
- get _needShow() {
57
- return (this._orientation === 'portrait' && this._showOnPortrait) ||
58
- (this._orientation !== 'portrait' && this._showOnLandscape)
59
- }
60
-
61
- set _isVisible(needShowDiv) {
62
- this._div.style.visibility = needShowDiv ? 'visible' : 'hidden';
63
- }
64
-
65
- _updateOrientation() {
66
- this._orientation = innerWidth > innerHeight ? 'landscape' : 'portrait';
67
- }
68
-
69
- _updateVisibility() {
70
- this._isVisible = this._needShow;
71
- }
72
-
73
- _resizeHandler() {
74
- this._updateOrientation();
75
- this._updateVisibility();
76
- }
77
-
78
- _subscribeOnce() {
79
- if (Urso.device.desktop)
80
- return;
81
-
82
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
83
- }
84
- }
85
-
86
- module.exports = ComponentsDeviceRotateController;
1
+ ComponentsBaseController = require('./../base/controller.js');
2
+
3
+ class ComponentsDeviceRotateController extends ComponentsBaseController {
4
+ constructor(params) {
5
+ super(params);
6
+
7
+ this._div = null;
8
+ this._orientation = null;
9
+ this._resolutionsConfig = null;
10
+ }
11
+
12
+ create() {
13
+ if (Urso.device.desktop)
14
+ return;
15
+
16
+ this._resolutionsConfig = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
17
+
18
+ this._createDom();
19
+ this._updateOrientation();
20
+ this._updateVisibility();
21
+ }
22
+
23
+ _createDom() {
24
+ this._div = document.createElement('div');
25
+ this._div.className = 'fullscreen';
26
+ this._div.style.touchAction = 'none';
27
+ this._div.style.visibility = 'hidden';
28
+
29
+ document.body.prepend(this._div);
30
+
31
+ const infoDiv = document.createElement('div');
32
+ infoDiv.className = 'fullscreen-info';
33
+ this._div.appendChild(infoDiv);
34
+
35
+ const image = document.createElement('img');
36
+ image.src = '/assets/images/fullscreen/rotate.png';
37
+ const span = document.createElement('span');
38
+ span.innerText = 'Please rotate device';
39
+
40
+ infoDiv.appendChild(image);
41
+ infoDiv.appendChild(span);
42
+ }
43
+
44
+ get _showOnLandscape() {
45
+ return !this._resolutionsConfig.find(resolution => resolution.orientation === 'landscape');
46
+ }
47
+
48
+ get _showOnPortrait() {
49
+ return !this._resolutionsConfig.find(resolution => resolution.orientation === 'portrait');
50
+ }
51
+
52
+ get _isPortrait() {
53
+ return this._orientation === 'portrait';
54
+ }
55
+
56
+ get _needShow() {
57
+ return (this._orientation === 'portrait' && this._showOnPortrait) ||
58
+ (this._orientation !== 'portrait' && this._showOnLandscape)
59
+ }
60
+
61
+ set _isVisible(needShowDiv) {
62
+ this._div.style.visibility = needShowDiv ? 'visible' : 'hidden';
63
+ }
64
+
65
+ _updateOrientation() {
66
+ this._orientation = innerWidth > innerHeight ? 'landscape' : 'portrait';
67
+ }
68
+
69
+ _updateVisibility() {
70
+ this._isVisible = this._needShow;
71
+ }
72
+
73
+ _resizeHandler() {
74
+ this._updateOrientation();
75
+ this._updateVisibility();
76
+ }
77
+
78
+ _subscribeOnce() {
79
+ if (Urso.device.desktop)
80
+ return;
81
+
82
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
83
+ }
84
+ }
85
+
86
+ module.exports = ComponentsDeviceRotateController;
@@ -1,6 +1,6 @@
1
- Urso.Core.Components.Fullscreen = {
2
- Android: require('./android.js'),
3
- Controller: require('./controller.js'),
4
- Desktop: require('./desktop.js'),
5
- Ios: require('./ios.js'),
6
- };
1
+ Urso.Core.Components.Fullscreen = {
2
+ Android: require('./android.js'),
3
+ Controller: require('./controller.js'),
4
+ Desktop: require('./desktop.js'),
5
+ Ios: require('./ios.js'),
6
+ };
@@ -1,104 +1,104 @@
1
- class ComponentsFullscreenAndroid {
2
-
3
- constructor() {
4
- this._div = null;
5
- this._orientation = null;
6
- }
7
-
8
- init() {
9
- this._createDom();
10
- this._addListeners();
11
-
12
- this._updateOrientation();
13
- this._updateResize();
14
- }
15
-
16
- _createDom() {
17
- this._div = document.createElement('div');
18
- this._div.className = 'fullscreen fullscreen-android';
19
- document.body.prepend(this._div);
20
-
21
- const infoDiv = document.createElement('div');
22
- infoDiv.className = 'fullscreen-info';
23
- this._div.appendChild(infoDiv);
24
-
25
- const image = document.createElement('img');
26
- image.src = '/assets/images/fullscreen/hand.png'
27
- const span = document.createElement('span');
28
- span.innerText = 'Tap to enter fullscreen';
29
-
30
- infoDiv.appendChild(image);
31
- infoDiv.appendChild(span);
32
-
33
- }
34
-
35
- _updateOrientation() {
36
- this._orientation = innerWidth > innerHeight ? 'landscape' : 'portrait';
37
- }
38
-
39
- get isFullscreen() {
40
- return (
41
- document.webkitIsFullScreen ||
42
- document.mozFullScreen ||
43
- document.fullscreen
44
- );
45
- }
46
-
47
- get _orientationsConfig() {
48
- return Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
49
- }
50
-
51
- get _isPortrait() {
52
- return this._orientation === 'portrait';
53
- }
54
-
55
- get _needShowOnCurrentOrientation() {
56
- return (this._isPortrait && this._showOnPortrait) ||
57
- (!this._isPortrait && this._showOnLandscape);
58
- }
59
-
60
- get _showOnLandscape() {
61
- return this._orientationsConfig.find(resolution => resolution.orientation === 'landscape');
62
- }
63
-
64
- get _showOnPortrait() {
65
- return this._orientationsConfig.find(resolution => resolution.orientation === 'portrait');
66
- }
67
-
68
- set isVisible(needShowDiv) {
69
- this._div.style.visibility = needShowDiv ? 'visible' : 'hidden';
70
- }
71
-
72
- _requestFullscreen() {
73
- if (document.body.webkitRequestFullScreen)
74
- document.body.webkitRequestFullScreen();
75
- else if (document.body.mozRequestFullScreen)
76
- document.body.mozRequestFullScreen();
77
- else if (document.body.requestFullScreen)
78
- document.body.requestFullScreen();
79
- }
80
-
81
- _updateResize() {
82
- this.isVisible = this._needShowOnCurrentOrientation && !this.isFullscreen;
83
- }
84
-
85
- _resizeHandler() {
86
- this._updateOrientation();
87
- this._updateResize();
88
- }
89
-
90
- _addListeners() {
91
- window.addEventListener('touchend', (e) => {
92
- if (!this.isFullscreen)
93
- this._requestFullscreen();
94
-
95
- this._updateResize();
96
- });
97
- }
98
-
99
- _subscribeOnce() {
100
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
101
- }
102
- }
103
-
104
- module.exports = ComponentsFullscreenAndroid;
1
+ class ComponentsFullscreenAndroid {
2
+
3
+ constructor() {
4
+ this._div = null;
5
+ this._orientation = null;
6
+ }
7
+
8
+ init() {
9
+ this._createDom();
10
+ this._addListeners();
11
+
12
+ this._updateOrientation();
13
+ this._updateResize();
14
+ }
15
+
16
+ _createDom() {
17
+ this._div = document.createElement('div');
18
+ this._div.className = 'fullscreen fullscreen-android';
19
+ document.body.prepend(this._div);
20
+
21
+ const infoDiv = document.createElement('div');
22
+ infoDiv.className = 'fullscreen-info';
23
+ this._div.appendChild(infoDiv);
24
+
25
+ const image = document.createElement('img');
26
+ image.src = '/assets/images/fullscreen/hand.png'
27
+ const span = document.createElement('span');
28
+ span.innerText = 'Tap to enter fullscreen';
29
+
30
+ infoDiv.appendChild(image);
31
+ infoDiv.appendChild(span);
32
+
33
+ }
34
+
35
+ _updateOrientation() {
36
+ this._orientation = innerWidth > innerHeight ? 'landscape' : 'portrait';
37
+ }
38
+
39
+ get isFullscreen() {
40
+ return (
41
+ document.webkitIsFullScreen ||
42
+ document.mozFullScreen ||
43
+ document.fullscreen
44
+ );
45
+ }
46
+
47
+ get _orientationsConfig() {
48
+ return Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
49
+ }
50
+
51
+ get _isPortrait() {
52
+ return this._orientation === 'portrait';
53
+ }
54
+
55
+ get _needShowOnCurrentOrientation() {
56
+ return (this._isPortrait && this._showOnPortrait) ||
57
+ (!this._isPortrait && this._showOnLandscape);
58
+ }
59
+
60
+ get _showOnLandscape() {
61
+ return this._orientationsConfig.find(resolution => resolution.orientation === 'landscape');
62
+ }
63
+
64
+ get _showOnPortrait() {
65
+ return this._orientationsConfig.find(resolution => resolution.orientation === 'portrait');
66
+ }
67
+
68
+ set isVisible(needShowDiv) {
69
+ this._div.style.visibility = needShowDiv ? 'visible' : 'hidden';
70
+ }
71
+
72
+ _requestFullscreen() {
73
+ if (document.body.webkitRequestFullScreen)
74
+ document.body.webkitRequestFullScreen();
75
+ else if (document.body.mozRequestFullScreen)
76
+ document.body.mozRequestFullScreen();
77
+ else if (document.body.requestFullScreen)
78
+ document.body.requestFullScreen();
79
+ }
80
+
81
+ _updateResize() {
82
+ this.isVisible = this._needShowOnCurrentOrientation && !this.isFullscreen;
83
+ }
84
+
85
+ _resizeHandler() {
86
+ this._updateOrientation();
87
+ this._updateResize();
88
+ }
89
+
90
+ _addListeners() {
91
+ window.addEventListener('touchend', (e) => {
92
+ if (!this.isFullscreen)
93
+ this._requestFullscreen();
94
+
95
+ this._updateResize();
96
+ });
97
+ }
98
+
99
+ _subscribeOnce() {
100
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
101
+ }
102
+ }
103
+
104
+ module.exports = ComponentsFullscreenAndroid;
@@ -1,64 +1,64 @@
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
-
11
- this.createActivator();
12
- }
13
-
14
- createActivator() {
15
- if (this._isCriOS)
16
- return;
17
-
18
- this._resolutionsConfig = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
19
-
20
- if (Urso.device.desktop)
21
- this._fullscreenActivator = this.getInstance('Desktop');
22
- else if (Urso.device.iOS)
23
- this._fullscreenActivator = this.getInstance('Ios');
24
- else if (Urso.device.android)
25
- this._fullscreenActivator = this.getInstance('Android');
26
-
27
- if (this._fullscreenActivator)
28
- this._fullscreenActivator.init();
29
- }
30
-
31
- get _isCriOS() {
32
- return navigator.userAgent.indexOf('CriOS') !== -1;
33
- }
34
-
35
- get _orientationsConfig() {
36
- return Urso.getInstance('Modules.Scenes.ResolutionsConfig')._orientations || [];
37
- }
38
-
39
- get _showOnLandscape() {
40
- return this._resolutionsConfig.find(resolution => resolution.orientation === 'landscape');
41
- }
42
-
43
- get _showOnPortrait() {
44
- return this._resolutionsConfig.find(resolution => resolution.orientation === 'portrait');
45
- }
46
-
47
- get _isPortrait() {
48
- return innerWidth > innerHeight ? 'portrait' : 'landscape';
49
- }
50
-
51
- get isFullscreen() {
52
- return this._fullscreenActivator.isFullscreen;
53
- }
54
-
55
- _resizeHandler() {
56
- Urso.localData.set('fullscreen.isFullscreen', this.isFullscreen);
57
- }
58
-
59
- _subscribeOnce() {
60
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
61
- }
62
- }
63
-
64
- 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
+
11
+ this.createActivator();
12
+ }
13
+
14
+ createActivator() {
15
+ if (this._isCriOS)
16
+ return;
17
+
18
+ this._resolutionsConfig = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents || [];
19
+
20
+ if (Urso.device.desktop)
21
+ this._fullscreenActivator = this.getInstance('Desktop');
22
+ else if (Urso.device.iOS)
23
+ this._fullscreenActivator = this.getInstance('Ios');
24
+ else if (Urso.device.android)
25
+ this._fullscreenActivator = this.getInstance('Android');
26
+
27
+ if (this._fullscreenActivator)
28
+ this._fullscreenActivator.init();
29
+ }
30
+
31
+ get _isCriOS() {
32
+ return navigator.userAgent.indexOf('CriOS') !== -1;
33
+ }
34
+
35
+ get _orientationsConfig() {
36
+ return Urso.getInstance('Modules.Scenes.ResolutionsConfig')._orientations || [];
37
+ }
38
+
39
+ get _showOnLandscape() {
40
+ return this._resolutionsConfig.find(resolution => resolution.orientation === 'landscape');
41
+ }
42
+
43
+ get _showOnPortrait() {
44
+ return this._resolutionsConfig.find(resolution => resolution.orientation === 'portrait');
45
+ }
46
+
47
+ get _isPortrait() {
48
+ return innerWidth > innerHeight ? 'portrait' : 'landscape';
49
+ }
50
+
51
+ get isFullscreen() {
52
+ return this._fullscreenActivator.isFullscreen;
53
+ }
54
+
55
+ _resizeHandler() {
56
+ Urso.localData.set('fullscreen.isFullscreen', this.isFullscreen);
57
+ }
58
+
59
+ _subscribeOnce() {
60
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this._resizeHandler.bind(this));
61
+ }
62
+ }
63
+
64
+ module.exports = ComponentsFullscreenController;