@urso/core 0.8.21 → 0.9.1-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.
- package/LICENSE +20 -20
- package/README.md +227 -227
- package/build/js/index.js +77212 -2
- package/package.json +36 -50
- package/src/js/app.js +105 -104
- package/src/js/components/base/controller.js +76 -78
- package/src/js/components/debug/controller.js +39 -39
- package/src/js/components/debug/coords.js +23 -23
- package/src/js/components/debug/fps.js +36 -36
- package/src/js/components/debug/template.js +55 -55
- package/src/js/components/debug/timescale.js +60 -60
- package/src/js/components/deviceRotate/controller.js +95 -95
- package/src/js/components/editor/api.js +127 -127
- package/src/js/components/editor/controller.js +13 -13
- package/src/js/components/fullscreen/android.js +104 -104
- package/src/js/components/fullscreen/controller.js +76 -76
- package/src/js/components/fullscreen/desktop.js +49 -49
- package/src/js/components/fullscreen/ios.js +115 -115
- package/src/js/components/layersSwitcher/config.js +26 -26
- package/src/js/components/layersSwitcher/controller.js +36 -36
- package/src/js/components/loader/controller.js +66 -66
- package/src/js/components/loader/template.js +71 -71
- package/src/js/components/soundInitialPopup/controller.js +43 -43
- package/src/js/components/soundInitialPopup/template.js +110 -110
- package/src/js/components/stateDriven/controller.js +123 -123
- package/src/js/config/load.js +325 -194
- package/src/js/config/main.js +17 -17
- package/src/js/extra/browserEvents.js +57 -57
- package/src/js/extra/main.js +23 -25
- package/src/js/extra/pixiPatch.js +173 -171
- package/src/js/index.js +7 -7
- package/src/js/lib/cache.js +199 -125
- package/src/js/lib/composition.js +85 -85
- package/src/js/lib/device.js +1215 -1215
- package/src/js/lib/helper.js +678 -678
- package/src/js/lib/loader.js +216 -218
- package/src/js/lib/localData.js +29 -29
- package/src/js/lib/logger.js +69 -69
- package/src/js/lib/math.js +161 -161
- package/src/js/lib/objectPool.js +208 -208
- package/src/js/lib/time.js +19 -19
- package/src/js/lib/tween.js +153 -153
- package/src/js/modules/assets/baseModel.js +21 -21
- package/src/js/modules/assets/config.js +38 -38
- package/src/js/modules/assets/controller.js +65 -65
- package/src/js/modules/assets/models/atlas.js +19 -19
- package/src/js/modules/assets/models/audiosprite.js +28 -28
- package/src/js/modules/assets/models/bitmapFont.js +11 -11
- package/src/js/modules/assets/models/container.js +19 -19
- package/src/js/modules/assets/models/font.js +11 -11
- package/src/js/modules/assets/models/html.js +11 -11
- package/src/js/modules/assets/models/image.js +17 -17
- package/src/js/modules/assets/models/json.js +11 -11
- package/src/js/modules/assets/models/jsonAtlas.js +11 -11
- package/src/js/modules/assets/models/sound.js +17 -17
- package/src/js/modules/assets/models/spine.js +18 -17
- package/src/js/modules/assets/models/spineAtlas.js +11 -0
- package/src/js/modules/assets/service.js +564 -553
- package/src/js/modules/i18n/config.js +17 -17
- package/src/js/modules/i18n/controller.js +71 -71
- package/src/js/modules/instances/controller.js +357 -357
- package/src/js/modules/logic/config/sounds.js +23 -23
- package/src/js/modules/logic/controller.js +52 -52
- package/src/js/modules/logic/main.js +8 -8
- package/src/js/modules/logic/sounds.js +103 -103
- package/src/js/modules/objects/baseModel.js +205 -207
- package/src/js/modules/objects/cache.js +99 -99
- package/src/js/modules/objects/config.js +10 -10
- package/src/js/modules/objects/controller.js +139 -139
- package/src/js/modules/objects/find.js +58 -58
- package/src/js/modules/objects/models/bitmapText.js +56 -49
- package/src/js/modules/objects/models/button.js +208 -209
- package/src/js/modules/objects/models/buttonComposite.js +38 -38
- package/src/js/modules/objects/models/checkbox.js +100 -100
- package/src/js/modules/objects/models/collection.js +56 -54
- package/src/js/modules/objects/models/component.js +48 -48
- package/src/js/modules/objects/models/container.js +22 -22
- package/src/js/modules/objects/models/emitterFx.js +103 -114
- package/src/js/modules/objects/models/graphics.js +40 -40
- package/src/js/modules/objects/models/group.js +22 -22
- package/src/js/modules/objects/models/hitArea.js +187 -187
- package/src/js/modules/objects/models/image.js +36 -36
- package/src/js/modules/objects/models/imagesAnimation.js +115 -115
- package/src/js/modules/objects/models/mask.js +40 -40
- package/src/js/modules/objects/models/nineSlicePlane.js +32 -32
- package/src/js/modules/objects/models/slider.js +357 -357
- package/src/js/modules/objects/models/spine.js +354 -339
- package/src/js/modules/objects/models/text.js +70 -70
- package/src/js/modules/objects/models/toggle.js +186 -186
- package/src/js/modules/objects/models/world.js +22 -22
- package/src/js/modules/objects/pool.js +68 -68
- package/src/js/modules/objects/propertyAdapter.js +592 -592
- package/src/js/modules/objects/proxy.js +299 -298
- package/src/js/modules/objects/selector.js +136 -136
- package/src/js/modules/objects/service.js +255 -254
- package/src/js/modules/objects/styles.js +210 -210
- package/src/js/modules/observer/controller.js +168 -168
- package/src/js/modules/observer/events.js +51 -56
- package/src/js/modules/scenes/controller.js +126 -127
- package/src/js/modules/scenes/model.js +28 -28
- package/src/js/modules/scenes/pixiWrapper.js +360 -351
- package/src/js/modules/scenes/resolutions.js +173 -173
- package/src/js/modules/scenes/resolutionsConfig.js +73 -73
- package/src/js/modules/scenes/service.js +144 -146
- package/src/js/modules/soundManager/controller.js +103 -103
- package/src/js/modules/soundManager/soundSprite.js +314 -314
- package/src/js/modules/statesManager/action.js +97 -97
- package/src/js/modules/statesManager/all.js +23 -23
- package/src/js/modules/statesManager/configStates.js +77 -77
- package/src/js/modules/statesManager/controller.js +219 -219
- package/src/js/modules/statesManager/functionsStorage.js +83 -83
- package/src/js/modules/statesManager/helper.js +27 -27
- package/src/js/modules/statesManager/race.js +91 -91
- package/src/js/modules/statesManager/sequence.js +48 -48
- package/src/js/modules/template/controller.js +28 -28
- package/src/js/modules/template/model.js +11 -11
- package/src/js/modules/template/service.js +137 -137
- package/src/js/modules/template/types.js +50 -49
- package/src/js/modules/transport/baseConnectionType.js +25 -25
- package/src/js/modules/transport/config.js +13 -13
- package/src/js/modules/transport/connectionTypes/websocket.js +77 -77
- package/src/js/modules/transport/connectionTypes/xhr.js +47 -47
- package/src/js/modules/transport/controller.js +48 -48
- package/src/js/modules/transport/decorator.js +17 -17
- package/src/js/modules/transport/service.js +150 -150
- package/vite.config.js +31 -0
- package/.babelrc +0 -12
- package/build/js/index.js.LICENSE.txt +0 -227
- package/src/js/modules/objects/models/atlasImage.js +0 -52
- package/src/js/modules/objects/models/dragContainer.js +0 -665
- package/src/js/modules/objects/models/emitter.js +0 -69
- package/src/js/modules/objects/models/scrollbox.js +0 -67
- package/src/js/modules/objects/models/textInput.js +0 -68
- package/webpack.config.js +0 -47
|
@@ -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
|
-
|
|
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
|
+
export default 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
|
-
|
|
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
|
+
export default 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
|
-
|
|
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
|
+
export default ComponentsLayersSwitcher;
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
|
|
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
|
-
|
|
1
|
+
import ComponentsBaseController from './../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
|
+
export default ComponentsLayersSwitcherController;
|
|
@@ -1,66 +1,66 @@
|
|
|
1
|
-
|
|
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
|
-
|
|
1
|
+
import ComponentsBaseController from './../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
|
+
export default ComponentsLoaderController;
|