dcl-npc-toolkit 1.0.5 → 1.0.6-20230511223948.commit-74300a8

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/dist/ui.js CHANGED
@@ -1,81 +1,92 @@
1
1
  import { Color4 } from '@dcl/sdk/math';
2
- import ReactEcs, { ReactEcsRenderer, UiEntity } from '@dcl/sdk/react-ecs';
3
- import { buttonClick, displayButton, displayDialog, displayFirstButtonContainer, displaySecondButtonContainer, getButtonText, getFontSize, getText, handleDialogClick } from './dialog';
2
+ import ReactEcs, { UiEntity } from '@dcl/sdk/react-ecs';
3
+ import { buttonClick, displayButton, displayDialog, displayFirstButtonContainer, displaySecondButtonContainer, getButtonText, getFontSize, getImageAtlasMapping, getText, realHeight, realWidth } from './dialog';
4
+ import { sourcesComponentsCoordinates } from './uiResources';
4
5
  export let lightTheme = ('https://decentraland.org/images/ui/light-atlas-v3.png');
5
6
  export let darkTheme = ('https://decentraland.org/images/ui/dark-atlas-v3.png');
6
7
  export let bubblesTexture = ('https://decentraland.org/images/ui/dialog-bubbles.png');
7
- export let dialogs = new Map();
8
- export function createDialog(npc) {
9
- ReactEcsRenderer.setUiRenderer(() => (ReactEcs.createElement(UiEntity, { uiTransform: {
10
- width: '100%',
11
- height: '300px',
8
+ export let section = {
9
+ ...sourcesComponentsCoordinates.backgrounds.promptBackground,
10
+ atlasHeight: sourcesComponentsCoordinates.atlasHeight,
11
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth,
12
+ };
13
+ export const NpcUtilsUi = () => {
14
+ const width = realWidth(600);
15
+ const height = realHeight(225);
16
+ return (ReactEcs.createElement(UiEntity, { uiTransform: {
12
17
  display: displayDialog() ? 'flex' : 'none',
18
+ flexDirection: 'column',
19
+ alignItems: 'center',
13
20
  justifyContent: 'center',
14
- flexDirection: 'row',
15
- alignItems: 'flex-end',
16
- alignSelf: 'auto',
17
21
  positionType: 'absolute',
18
- position: { top: '50%' }
22
+ position: { top: '50%', left: '50%' },
23
+ margin: { top: -height / 2, left: -width / 2 },
24
+ width,
25
+ height,
19
26
  } },
20
27
  ReactEcs.createElement(UiEntity, { uiTransform: {
21
- width: '700px',
22
- height: '225px',
28
+ positionType: 'absolute',
29
+ position: { top: 0, left: 0 },
30
+ width: '100%',
31
+ height: '100%',
32
+ }, uiBackground: {
33
+ textureMode: 'stretch',
34
+ texture: {
35
+ src: lightTheme,
36
+ },
37
+ uvs: getImageAtlasMapping(section),
38
+ } }),
39
+ ReactEcs.createElement(UiEntity, { uiTransform: {
40
+ width: '100px',
41
+ height: '50px',
42
+ alignItems: 'center',
43
+ }, uiText: { value: getText(), color: Color4.Black(), fontSize: getFontSize() } }),
44
+ ReactEcs.createElement(UiEntity, { uiTransform: {
45
+ width: '300px',
23
46
  alignItems: 'center',
24
- justifyContent: 'center',
25
- alignContent: 'flex-start',
26
- flexDirection: 'column'
27
- }, uiBackground: { color: Color4.White() }, onMouseDown: () => { handleDialogClick(); } },
47
+ flexDirection: 'row',
48
+ justifyContent: 'space-between',
49
+ display: displayFirstButtonContainer() ? 'flex' : 'none',
50
+ } },
28
51
  ReactEcs.createElement(UiEntity, { uiTransform: {
29
- width: '100px',
52
+ width: '125px',
30
53
  height: '50px',
31
54
  alignItems: 'center',
32
- }, uiText: { value: getText(), color: Color4.Black(), fontSize: getFontSize() } }),
55
+ justifyContent: 'center',
56
+ alignContent: 'flex-start',
57
+ display: displayButton(1) ? 'flex' : 'none',
58
+ }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(0), fontSize: 16 }, onMouseDown: () => { buttonClick(0); } }),
33
59
  ReactEcs.createElement(UiEntity, { uiTransform: {
34
- width: '300px',
60
+ width: '125px',
61
+ height: '50px',
35
62
  alignItems: 'center',
36
- flexDirection: 'row',
37
- justifyContent: 'space-between',
38
- display: displayFirstButtonContainer() ? 'flex' : 'none',
39
- } },
40
- ReactEcs.createElement(UiEntity, { uiTransform: {
41
- width: '125px',
42
- height: '50px',
43
- alignItems: 'center',
44
- justifyContent: 'center',
45
- alignContent: 'flex-start',
46
- display: displayButton(1) ? 'flex' : 'none',
47
- }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(0), fontSize: 16 }, onMouseDown: () => { buttonClick(0); } }),
48
- ReactEcs.createElement(UiEntity, { uiTransform: {
49
- width: '125px',
50
- height: '50px',
51
- alignItems: 'center',
52
- justifyContent: 'center',
53
- alignContent: 'flex-start',
54
- display: displayButton(2) ? 'flex' : 'none',
55
- }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(1), fontSize: 16 }, onMouseDown: () => { buttonClick(1); } })),
63
+ justifyContent: 'center',
64
+ alignContent: 'flex-start',
65
+ display: displayButton(2) ? 'flex' : 'none',
66
+ }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(1), fontSize: 16 }, onMouseDown: () => { buttonClick(1); } })),
67
+ ReactEcs.createElement(UiEntity, { uiTransform: {
68
+ width: '125px',
69
+ alignItems: 'center',
70
+ flexDirection: 'row',
71
+ justifyContent: 'space-between',
72
+ margin: { top: 20 },
73
+ display: displaySecondButtonContainer() ? 'flex' : 'none',
74
+ } },
75
+ ReactEcs.createElement(UiEntity, { uiTransform: {
76
+ width: '125px',
77
+ height: '50px',
78
+ alignItems: 'center',
79
+ justifyContent: 'center',
80
+ alignContent: 'flex-start',
81
+ display: displayButton(3) ? 'flex' : 'none',
82
+ }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(2), fontSize: 16 }, onMouseDown: () => { buttonClick(3); } }),
56
83
  ReactEcs.createElement(UiEntity, { uiTransform: {
57
84
  width: '125px',
85
+ height: '50px',
58
86
  alignItems: 'center',
59
- flexDirection: 'row',
60
- justifyContent: 'space-between',
61
- margin: { top: 20 },
62
- display: displaySecondButtonContainer() ? 'flex' : 'none',
63
- } },
64
- ReactEcs.createElement(UiEntity, { uiTransform: {
65
- width: '125px',
66
- height: '50px',
67
- alignItems: 'center',
68
- justifyContent: 'center',
69
- alignContent: 'flex-start',
70
- display: displayButton(3) ? 'flex' : 'none',
71
- }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(2), fontSize: 16 }, onMouseDown: () => { buttonClick(3); } }),
72
- ReactEcs.createElement(UiEntity, { uiTransform: {
73
- width: '125px',
74
- height: '50px',
75
- alignItems: 'center',
76
- justifyContent: 'center',
77
- alignContent: 'flex-start',
78
- display: displayButton(4) ? 'flex' : 'none',
79
- }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(3), fontSize: 16 }, onMouseDown: () => { buttonClick(4); } }))))));
80
- }
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.js","sourceRoot":"","sources":["../src/ui.tsx"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Color4 } from '@dcl/sdk/math'\nimport ReactEcs, { Button, Label, ReactEcsRenderer, UiEntity } from '@dcl/sdk/react-ecs'\nimport { Entity } from '@dcl/sdk/ecs'\nimport { buttonClick, confirmText, displayButton, displayDialog, displayFirstButtonContainer, displaySecondButtonContainer, getButtonText, getFontSize, getText, getTextPosition, handleDialogClick } from './dialog'\n\nexport let lightTheme = ('https://decentraland.org/images/ui/light-atlas-v3.png')\nexport let darkTheme = ('https://decentraland.org/images/ui/dark-atlas-v3.png')\n\nexport let bubblesTexture = ('https://decentraland.org/images/ui/dialog-bubbles.png')\n\nexport let dialogs:Map<Entity, any> = new Map()\n\nexport function createDialog(npc:Entity){//\n\t// console.log('creating dialog for npc', npc)\n\t// dialogs.set(npc,\n\tReactEcsRenderer.setUiRenderer(() => (\n\t\t<UiEntity\n\t\tuiTransform={{\n\t\t  width: '100%',\n\t\t  height: '300px',\n\t\t  display: displayDialog() ? 'flex' :'none',\n\t\t  justifyContent: 'center',\n\t\t  flexDirection:'row',\n\t\t  alignItems:'flex-end',\n\t\t  alignSelf:'auto',\n\t\t  positionType:'absolute',\n\t\t  position:{top:'50%'}\n\t\t}}\n\t  >\n\t\t<UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '700px',\n\t\t\theight: '225px',\n\t\t\talignItems: 'center',\n\t\t\tjustifyContent:'center',\n\t\t\talignContent:'flex-start',\n\t\t\tflexDirection:'column'\n\t\t  }}\n\t\t  uiBackground={{ color: Color4.White() }}\n\t\t  onMouseDown={() => { handleDialogClick() } }\n\t\t  >\n\t\t<UiEntity\n\t\t\t\tuiTransform={{\n\t\t\t\t\twidth: '100px',\n\t\t\t\t\theight: '50px',\n\t\t\t\t\talignItems: 'center',\n\t\t\t\t}}\n\t\t\t\tuiText={{value: getText(),color:Color4.Black(), fontSize: getFontSize()}}\n\t\t\t\t>\n\t\t\t</UiEntity>\n\n\t\t<UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '300px',\n\t\t\talignItems: 'center',\n\t\t\tflexDirection:'row',\n\t\t\tjustifyContent:'space-between',\n\t\t\tdisplay: displayFirstButtonContainer() ? 'flex' :'none',\n\t\t  }}\n\t\t  >\n\t\t\n\t\t{/* Button1 */}\n\t\t<UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '125px',\n\t\t\theight: '50px',\n\t\t\talignItems: 'center',\n\t\t\tjustifyContent:'center',\n\t\t\talignContent:'flex-start',\n\t\t\tdisplay: displayButton(1) ? 'flex' :'none',\n\t\t  }}\n\t\t  uiBackground={{ color: Color4.Red() }}\n\t\t  uiText={{value: getButtonText(0), fontSize: 16}}\n\t\t  onMouseDown={() => { buttonClick(0) } }\n\t\t  >\n\t\t  </UiEntity>\n\n\n\t\t\t{/* Button2 */}\n\t\t<UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '125px',\n\t\t\theight: '50px',\n\t\t\talignItems: 'center',\n\t\t\tjustifyContent:'center',\n\t\t\talignContent:'flex-start',\n\t\t\tdisplay: displayButton(2) ? 'flex' :'none',\n\t\t  }}\n\t\t  uiBackground={{ color: Color4.Red() }}\n\t\t  uiText={{value: getButtonText(1), fontSize: 16}}\n\t\t  onMouseDown={() => { buttonClick(1) } }\n\t\t  ></UiEntity>\n\n\t\t </UiEntity>\n\n\n\t\t <UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '125px',\n\t\t\talignItems: 'center',\n\t\t\tflexDirection:'row',\n\t\t\tjustifyContent:'space-between',\n\t\t\tmargin:{top:20},\n\t\t\tdisplay: displaySecondButtonContainer() ? 'flex' :'none',\n\t\t  }}\n\t\t  >\n\t\t\n\t\t{/* Button3 */}\n\t\t<UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '125px',\n\t\t\theight: '50px',\n\t\t\talignItems: 'center',\n\t\t\tjustifyContent:'center',\n\t\t\talignContent:'flex-start',\n\t\t\tdisplay: displayButton(3) ? 'flex' :'none',\n\t\t  }}\n\t\t  uiBackground={{ color: Color4.Red() }}\n\t\t  uiText={{value: getButtonText(2), fontSize: 16}}\n\t\t  onMouseDown={() => { buttonClick(3) } }\n\t\t  >\n\t\t  </UiEntity>\n\n\n\t\t\t{/* Button4 */}\n\t\t<UiEntity\n\t\t  uiTransform={{\n\t\t\twidth: '125px',\n\t\t\theight: '50px',\n\t\t\talignItems: 'center',\n\t\t\tjustifyContent:'center',\n\t\t\talignContent:'flex-start',\n\t\t\tdisplay: displayButton(4) ? 'flex' :'none',\n\t\t  }}\n\t\t  uiBackground={{ color: Color4.Red() }}\n\t\t  uiText={{value: getButtonText(3), fontSize: 16}}\n\t\t  onMouseDown={() => { buttonClick(4) } }\n\t\t  ></UiEntity>\n\n\t\t </UiEntity>\n\t\t \n\n\t\t </UiEntity>\n\n\n\n\t  </UiEntity>\n\t))\n}\n"]}
87
+ justifyContent: 'center',
88
+ alignContent: 'flex-start',
89
+ display: displayButton(4) ? 'flex' : 'none',
90
+ }, uiBackground: { color: Color4.Red() }, uiText: { value: getButtonText(3), fontSize: 16 }, onMouseDown: () => { buttonClick(4); } }))));
91
+ };
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.js","sourceRoot":"","sources":["../src/ui.tsx"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Color4 } from '@dcl/sdk/math'\nimport ReactEcs, { Button, Label, ReactEcsRenderer, UiEntity } from '@dcl/sdk/react-ecs'\nimport { Entity } from '@dcl/sdk/ecs'\nimport { buttonClick, confirmText, displayButton, displayDialog, displayFirstButtonContainer, displaySecondButtonContainer, getButtonText, getFontSize, getImageAtlasMapping, getText, getTextPosition, handleDialogClick, realHeight, realWidth } from './dialog'\nimport { sourcesComponentsCoordinates } from './uiResources'\n\nexport let lightTheme = ('https://decentraland.org/images/ui/light-atlas-v3.png')\nexport let darkTheme = ('https://decentraland.org/images/ui/dark-atlas-v3.png')\n\nexport let bubblesTexture = ('https://decentraland.org/images/ui/dialog-bubbles.png')\n\nexport let section = {\n\t...sourcesComponentsCoordinates.backgrounds.promptBackground,\n\tatlasHeight: sourcesComponentsCoordinates.atlasHeight,\n\tatlasWidth: sourcesComponentsCoordinates.atlasWidth,\n  }\n\nexport const NpcUtilsUi = () =>{\n\tconst width = realWidth(600)\n    const height = realHeight(225)\n\nreturn (\n\t<UiEntity\n\tuiTransform={{\n\t  display: displayDialog() ? 'flex' : 'none',\n\t  flexDirection: 'column',\n\t  alignItems: 'center',\n\t  justifyContent: 'center',\n\t  positionType: 'absolute',\n\t  position: { top: '50%', left: '50%' },\n\t  margin: { top: -height / 2, left: -width / 2 },\n\t  width,\n\t  height,\n\t}}\n  >\n\t<UiEntity\n\t  uiTransform={{\n\t\tpositionType: 'absolute',\n\t\tposition: { top: 0, left: 0 },\n\t\twidth: '100%',\n\t\theight: '100%',\n\t  }}\n\t  uiBackground={{\n\t\ttextureMode: 'stretch',\n\t\ttexture: {\n\t\t  src: lightTheme,\n\t\t},\n\t\tuvs: getImageAtlasMapping(section),\n\t  }}\n\t/>\n\n\t<UiEntity\n\t\t\tuiTransform={{\n\t\t\t\twidth: '100px',\n\t\t\t\theight: '50px',\n\t\t\t\talignItems: 'center',\n\t\t\t}}\n\t\t\tuiText={{value: getText(),color:Color4.Black(), fontSize: getFontSize()}}\n\t\t\t>\n\t\t</UiEntity>\n\n\t<UiEntity\n\t  uiTransform={{\n\t\twidth: '300px',\n\t\talignItems: 'center',\n\t\tflexDirection:'row',\n\t\tjustifyContent:'space-between',\n\t\tdisplay: displayFirstButtonContainer() ? 'flex' :'none',\n\t  }}\n\t  >\n\t\n\t{/* Button1 */}\n\t<UiEntity\n\t  uiTransform={{\n\t\twidth: '125px',\n\t\theight: '50px',\n\t\talignItems: 'center',\n\t\tjustifyContent:'center',\n\t\talignContent:'flex-start',\n\t\tdisplay: displayButton(1) ? 'flex' :'none',\n\t  }}\n\t  uiBackground={{ color: Color4.Red() }}\n\t  uiText={{value: getButtonText(0), fontSize: 16}}\n\t  onMouseDown={() => { buttonClick(0) } }\n\t  >\n\t  </UiEntity>\n\n\n\t\t{/* Button2 */}\n\t<UiEntity\n\t  uiTransform={{\n\t\twidth: '125px',\n\t\theight: '50px',\n\t\talignItems: 'center',\n\t\tjustifyContent:'center',\n\t\talignContent:'flex-start',\n\t\tdisplay: displayButton(2) ? 'flex' :'none',\n\t  }}\n\t  uiBackground={{ color: Color4.Red() }}\n\t  uiText={{value: getButtonText(1), fontSize: 16}}\n\t  onMouseDown={() => { buttonClick(1) } }\n\t  ></UiEntity>\n\n\t </UiEntity>\n\n\n\t <UiEntity\n\t  uiTransform={{\n\t\twidth: '125px',\n\t\talignItems: 'center',\n\t\tflexDirection:'row',\n\t\tjustifyContent:'space-between',\n\t\tmargin:{top:20},\n\t\tdisplay: displaySecondButtonContainer() ? 'flex' :'none',\n\t  }}\n\t  >\n\t\n\t{/* Button3 */}\n\t<UiEntity\n\t  uiTransform={{\n\t\twidth: '125px',\n\t\theight: '50px',\n\t\talignItems: 'center',\n\t\tjustifyContent:'center',\n\t\talignContent:'flex-start',\n\t\tdisplay: displayButton(3) ? 'flex' :'none',\n\t  }}\n\t  uiBackground={{ color: Color4.Red() }}\n\t  uiText={{value: getButtonText(2), fontSize: 16}}\n\t  onMouseDown={() => { buttonClick(3) } }\n\t  >\n\t  </UiEntity>\n\n\n\t\t{/* Button4 */}\n\t<UiEntity\n\t  uiTransform={{\n\t\twidth: '125px',\n\t\theight: '50px',\n\t\talignItems: 'center',\n\t\tjustifyContent:'center',\n\t\talignContent:'flex-start',\n\t\tdisplay: displayButton(4) ? 'flex' :'none',\n\t  }}\n\t  uiBackground={{ color: Color4.Red() }}\n\t  uiText={{value: getButtonText(3), fontSize: 16}}\n\t  onMouseDown={() => { buttonClick(4) } }\n\t  ></UiEntity>\n\t</UiEntity>\n\n\n\n  </UiEntity>\n)\n}\n\n"]}
@@ -0,0 +1,320 @@
1
+ export declare const sourcesComponentsCoordinates: {
2
+ atlasHeight: number;
3
+ atlasWidth: number;
4
+ buttons: {
5
+ E: {
6
+ sourceWidth: number;
7
+ sourceHeight: number;
8
+ sourceLeft: number;
9
+ sourceTop: number;
10
+ };
11
+ F: {
12
+ sourceWidth: number;
13
+ sourceHeight: number;
14
+ sourceLeft: number;
15
+ sourceTop: number;
16
+ };
17
+ EBlack: {
18
+ sourceWidth: number;
19
+ sourceHeight: number;
20
+ sourceLeft: number;
21
+ sourceTop: number;
22
+ };
23
+ FBlack: {
24
+ sourceWidth: number;
25
+ sourceHeight: number;
26
+ sourceLeft: number;
27
+ sourceTop: number;
28
+ };
29
+ buttonE: {
30
+ sourceWidth: number;
31
+ sourceHeight: number;
32
+ sourceLeft: number;
33
+ sourceTop: number;
34
+ };
35
+ buttonF: {
36
+ sourceWidth: number;
37
+ sourceHeight: number;
38
+ sourceLeft: number;
39
+ sourceTop: number;
40
+ };
41
+ white: {
42
+ sourceWidth: number;
43
+ sourceHeight: number;
44
+ sourceLeft: number;
45
+ sourceTop: number;
46
+ };
47
+ red: {
48
+ sourceWidth: number;
49
+ sourceHeight: number;
50
+ sourceLeft: number;
51
+ sourceTop: number;
52
+ };
53
+ dark: {
54
+ sourceWidth: number;
55
+ sourceHeight: number;
56
+ sourceLeft: number;
57
+ sourceTop: number;
58
+ };
59
+ roundBlack: {
60
+ sourceWidth: number;
61
+ sourceHeight: number;
62
+ sourceLeft: number;
63
+ sourceTop: number;
64
+ };
65
+ squareBlack: {
66
+ sourceWidth: number;
67
+ sourceHeight: number;
68
+ sourceLeft: number;
69
+ sourceTop: number;
70
+ };
71
+ roundWhite: {
72
+ sourceWidth: number;
73
+ sourceHeight: number;
74
+ sourceLeft: number;
75
+ sourceTop: number;
76
+ };
77
+ squareWhite: {
78
+ sourceWidth: number;
79
+ sourceHeight: number;
80
+ sourceLeft: number;
81
+ sourceTop: number;
82
+ };
83
+ roundSilver: {
84
+ sourceWidth: number;
85
+ sourceHeight: number;
86
+ sourceLeft: number;
87
+ sourceTop: number;
88
+ };
89
+ squareSilver: {
90
+ sourceWidth: number;
91
+ sourceHeight: number;
92
+ sourceLeft: number;
93
+ sourceTop: number;
94
+ };
95
+ roundGold: {
96
+ sourceWidth: number;
97
+ sourceHeight: number;
98
+ sourceLeft: number;
99
+ sourceTop: number;
100
+ };
101
+ squareGold: {
102
+ sourceWidth: number;
103
+ sourceHeight: number;
104
+ sourceLeft: number;
105
+ sourceTop: number;
106
+ };
107
+ };
108
+ backgrounds: {
109
+ promptBackground: {
110
+ sourceWidth: number;
111
+ sourceHeight: number;
112
+ sourceLeft: number;
113
+ sourceTop: number;
114
+ };
115
+ promptLargeBackground: {
116
+ sourceWidth: number;
117
+ sourceHeight: number;
118
+ sourceLeft: number;
119
+ sourceTop: number;
120
+ };
121
+ promptSlantedBackground: {
122
+ sourceWidth: number;
123
+ sourceHeight: number;
124
+ sourceLeft: number;
125
+ sourceTop: number;
126
+ };
127
+ NPCDialog: {
128
+ sourceWidth: number;
129
+ sourceHeight: number;
130
+ sourceLeft: number;
131
+ sourceTop: number;
132
+ };
133
+ };
134
+ icons: {
135
+ closeW: {
136
+ sourceWidth: number;
137
+ sourceHeight: number;
138
+ sourceLeft: number;
139
+ sourceTop: number;
140
+ };
141
+ closeD: {
142
+ sourceWidth: number;
143
+ sourceHeight: number;
144
+ sourceLeft: number;
145
+ sourceTop: number;
146
+ };
147
+ closeWLarge: {
148
+ sourceWidth: number;
149
+ sourceHeight: number;
150
+ sourceLeft: number;
151
+ sourceTop: number;
152
+ };
153
+ closeDLarge: {
154
+ sourceWidth: number;
155
+ sourceHeight: number;
156
+ sourceLeft: number;
157
+ sourceTop: number;
158
+ };
159
+ closeWNoBack: {
160
+ sourceWidth: number;
161
+ sourceHeight: number;
162
+ sourceLeft: number;
163
+ sourceTop: number;
164
+ };
165
+ closeDNoBack: {
166
+ sourceWidth: number;
167
+ sourceHeight: number;
168
+ sourceLeft: number;
169
+ sourceTop: number;
170
+ };
171
+ closeWNoBackLarge: {
172
+ sourceWidth: number;
173
+ sourceHeight: number;
174
+ sourceLeft: number;
175
+ sourceTop: number;
176
+ };
177
+ closeDNoBackLarge: {
178
+ sourceWidth: number;
179
+ sourceHeight: number;
180
+ sourceLeft: number;
181
+ sourceTop: number;
182
+ };
183
+ FDark: {
184
+ sourceWidth: number;
185
+ sourceHeight: number;
186
+ sourceLeft: number;
187
+ sourceTop: number;
188
+ };
189
+ FWhite: {
190
+ sourceWidth: number;
191
+ sourceHeight: number;
192
+ sourceLeft: number;
193
+ sourceTop: number;
194
+ };
195
+ EDark: {
196
+ sourceWidth: number;
197
+ sourceHeight: number;
198
+ sourceLeft: number;
199
+ sourceTop: number;
200
+ };
201
+ EWhite: {
202
+ sourceWidth: number;
203
+ sourceHeight: number;
204
+ sourceLeft: number;
205
+ sourceTop: number;
206
+ };
207
+ Timer: {
208
+ sourceWidth: number;
209
+ sourceHeight: number;
210
+ sourceLeft: number;
211
+ sourceTop: number;
212
+ };
213
+ TimerLarge: {
214
+ sourceWidth: number;
215
+ sourceHeight: number;
216
+ sourceLeft: number;
217
+ sourceTop: number;
218
+ };
219
+ ClickWhite: {
220
+ sourceWidth: number;
221
+ sourceHeight: number;
222
+ sourceLeft: number;
223
+ sourceTop: number;
224
+ };
225
+ ClickDark: {
226
+ sourceWidth: number;
227
+ sourceHeight: number;
228
+ sourceLeft: number;
229
+ sourceTop: number;
230
+ };
231
+ };
232
+ checkboxes: {
233
+ wOff: {
234
+ sourceWidth: number;
235
+ sourceHeight: number;
236
+ sourceLeft: number;
237
+ sourceTop: number;
238
+ };
239
+ wOn: {
240
+ sourceWidth: number;
241
+ sourceHeight: number;
242
+ sourceLeft: number;
243
+ sourceTop: number;
244
+ };
245
+ dOff: {
246
+ sourceWidth: number;
247
+ sourceHeight: number;
248
+ sourceLeft: number;
249
+ sourceTop: number;
250
+ };
251
+ dOn: {
252
+ sourceWidth: number;
253
+ sourceHeight: number;
254
+ sourceLeft: number;
255
+ sourceTop: number;
256
+ };
257
+ wLargeOff: {
258
+ sourceWidth: number;
259
+ sourceHeight: number;
260
+ sourceLeft: number;
261
+ sourceTop: number;
262
+ };
263
+ wLargeOn: {
264
+ sourceWidth: number;
265
+ sourceHeight: number;
266
+ sourceLeft: number;
267
+ sourceTop: number;
268
+ };
269
+ dLargeOff: {
270
+ sourceWidth: number;
271
+ sourceHeight: number;
272
+ sourceLeft: number;
273
+ sourceTop: number;
274
+ };
275
+ dLargeOn: {
276
+ sourceWidth: number;
277
+ sourceHeight: number;
278
+ sourceLeft: number;
279
+ sourceTop: number;
280
+ };
281
+ };
282
+ switches: {
283
+ roundOff: {
284
+ sourceWidth: number;
285
+ sourceHeight: number;
286
+ sourceLeft: number;
287
+ sourceTop: number;
288
+ };
289
+ squareOff: {
290
+ sourceWidth: number;
291
+ sourceHeight: number;
292
+ sourceLeft: number;
293
+ sourceTop: number;
294
+ };
295
+ roundRed: {
296
+ sourceWidth: number;
297
+ sourceHeight: number;
298
+ sourceLeft: number;
299
+ sourceTop: number;
300
+ };
301
+ roundGreen: {
302
+ sourceWidth: number;
303
+ sourceHeight: number;
304
+ sourceLeft: number;
305
+ sourceTop: number;
306
+ };
307
+ squareRed: {
308
+ sourceWidth: number;
309
+ sourceHeight: number;
310
+ sourceLeft: number;
311
+ sourceTop: number;
312
+ };
313
+ squareGreen: {
314
+ sourceWidth: number;
315
+ sourceHeight: number;
316
+ sourceLeft: number;
317
+ sourceTop: number;
318
+ };
319
+ };
320
+ };