@antimatter-audio/antimatter-ui 9.1.0 → 9.2.1
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/assets/src/core/Button/Button.css.ts.vanilla-Be5tO_i6.css +30 -0
- package/dist/assets/src/core/Button/Button.css.ts.vanilla-BgDwK7hH.css +30 -0
- package/dist/assets/src/core/Button/Button.css.ts.vanilla-CqBl7vyU.css +30 -0
- package/dist/assets/src/core/Button/Button.css.ts.vanilla-DBvWYymw.css +32 -0
- package/dist/assets/src/core/Button/Button.css.ts.vanilla-DklkKqpr.css +28 -0
- package/dist/assets/src/core/Button/Button.css.ts.vanilla-UfrXQS8M.css +30 -0
- package/dist/assets/src/core/Button/Button.css.ts.vanilla-ZHEMMDf9.css +33 -0
- package/dist/index.d.ts +3 -2
- package/dist/index.js +27 -6
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
15
|
+
appearance: none;
|
|
16
|
+
user-select: none;
|
|
17
|
+
min-width: 1rem;
|
|
18
|
+
min-height: 1rem;
|
|
19
|
+
}
|
|
20
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
21
|
+
width: var(--spacing-medium__1rgzsg04);
|
|
22
|
+
height: var(--spacing-medium__1rgzsg04);
|
|
23
|
+
}
|
|
24
|
+
.Button_variants_small__1m3jauc2 {
|
|
25
|
+
height: var(--spacing-large__1rgzsg06);
|
|
26
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
27
|
+
}
|
|
28
|
+
.Button_variants_large__1m3jauc3 {
|
|
29
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
30
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
15
|
+
appearance: none;
|
|
16
|
+
user-select: none;
|
|
17
|
+
min-width: 1rem;
|
|
18
|
+
min-height: 1rem;
|
|
19
|
+
}
|
|
20
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
21
|
+
width: var(--spacing-small__1rgzsg02);
|
|
22
|
+
height: var(--spacing-small__1rgzsg02);
|
|
23
|
+
}
|
|
24
|
+
.Button_variants_small__1m3jauc2 {
|
|
25
|
+
height: var(--spacing-large__1rgzsg06);
|
|
26
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
27
|
+
}
|
|
28
|
+
.Button_variants_large__1m3jauc3 {
|
|
29
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
30
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
15
|
+
appearance: none;
|
|
16
|
+
user-select: none;
|
|
17
|
+
min-width: 1rem;
|
|
18
|
+
min-height: 1rem;
|
|
19
|
+
}
|
|
20
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
21
|
+
width: var(--spacing-mediumLarge__1rgzsg05);
|
|
22
|
+
height: var(--spacing-mediumLarge__1rgzsg05);
|
|
23
|
+
}
|
|
24
|
+
.Button_variants_small__1m3jauc2 {
|
|
25
|
+
height: var(--spacing-large__1rgzsg06);
|
|
26
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
27
|
+
}
|
|
28
|
+
.Button_variants_large__1m3jauc3 {
|
|
29
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
30
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
15
|
+
appearance: none;
|
|
16
|
+
user-select: none;
|
|
17
|
+
}
|
|
18
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
19
|
+
width: var(--spacing-mediumLarge__1rgzsg05);
|
|
20
|
+
height: var(--spacing-mediumLarge__1rgzsg05);
|
|
21
|
+
}
|
|
22
|
+
.Button_variants_small__1m3jauc2 {
|
|
23
|
+
height: var(--spacing-large__1rgzsg06);
|
|
24
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
25
|
+
min-width: 1rem;
|
|
26
|
+
min-height: 1rem;
|
|
27
|
+
}
|
|
28
|
+
.Button_variants_large__1m3jauc3 {
|
|
29
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
30
|
+
min-width: 1rem;
|
|
31
|
+
min-height: 1rem;
|
|
32
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
15
|
+
appearance: none;
|
|
16
|
+
user-select: none;
|
|
17
|
+
}
|
|
18
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
19
|
+
width: var(--spacing-mediumLarge__1rgzsg05);
|
|
20
|
+
height: var(--spacing-mediumLarge__1rgzsg05);
|
|
21
|
+
}
|
|
22
|
+
.Button_variants_small__1m3jauc2 {
|
|
23
|
+
height: var(--spacing-large__1rgzsg06);
|
|
24
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
25
|
+
}
|
|
26
|
+
.Button_variants_large__1m3jauc3 {
|
|
27
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
28
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
15
|
+
appearance: none;
|
|
16
|
+
user-select: none;
|
|
17
|
+
}
|
|
18
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
19
|
+
width: var(--spacing-mediumLarge__1rgzsg05);
|
|
20
|
+
height: var(--spacing-mediumLarge__1rgzsg05);
|
|
21
|
+
}
|
|
22
|
+
.Button_variants_small__1m3jauc2 {
|
|
23
|
+
height: var(--spacing-large__1rgzsg06);
|
|
24
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
25
|
+
min-width: 1rem;
|
|
26
|
+
min-height: 1rem;
|
|
27
|
+
}
|
|
28
|
+
.Button_variants_large__1m3jauc3 {
|
|
29
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
30
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
.Button_ButtonStyle__1m3jauc0 {
|
|
2
|
+
font-size: var(--fontSizes-small__1rgzsg09);
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
6
|
+
padding-right: var(--spacing-mediumSmall__1rgzsg03);
|
|
7
|
+
padding-left: var(--spacing-mediumSmall__1rgzsg03);
|
|
8
|
+
cursor: pointer;
|
|
9
|
+
vertical-align: middle;
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
text-decoration: none;
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 0;
|
|
14
|
+
appearance: none;
|
|
15
|
+
user-select: none;
|
|
16
|
+
}
|
|
17
|
+
.Button_variants_xSmall__1m3jauc1 {
|
|
18
|
+
width: var(--spacing-mediumLarge__1rgzsg05);
|
|
19
|
+
height: var(--spacing-mediumLarge__1rgzsg05);
|
|
20
|
+
}
|
|
21
|
+
.Button_variants_small__1m3jauc2 {
|
|
22
|
+
height: var(--spacing-large__1rgzsg06);
|
|
23
|
+
font-size: var(--fontSizes-xSmall__1rgzsg08);
|
|
24
|
+
min-width: 1rem;
|
|
25
|
+
min-height: 1rem;
|
|
26
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
27
|
+
}
|
|
28
|
+
.Button_variants_large__1m3jauc3 {
|
|
29
|
+
border-radius: var(--borderRadius__1rgzsg0e);
|
|
30
|
+
height: var(--spacing-xLarge__1rgzsg07);
|
|
31
|
+
min-width: 1rem;
|
|
32
|
+
min-height: 1rem;
|
|
33
|
+
}
|
package/dist/index.d.ts
CHANGED
|
@@ -53,6 +53,7 @@ declare namespace Tabs {
|
|
|
53
53
|
}
|
|
54
54
|
|
|
55
55
|
declare enum ButtonSize {
|
|
56
|
+
xSmall = "xSmall",
|
|
56
57
|
small = "small",
|
|
57
58
|
large = "large"
|
|
58
59
|
}
|
|
@@ -69,9 +70,9 @@ interface TextButtonProps {
|
|
|
69
70
|
text?: string;
|
|
70
71
|
className?: string;
|
|
71
72
|
style?: object;
|
|
72
|
-
children?:
|
|
73
|
+
children?: React__default.ReactNode;
|
|
73
74
|
}
|
|
74
|
-
declare function Button({ disabled, text, id, className, style, children, type, size, }:
|
|
75
|
+
declare function Button({ disabled, text, id, className, style, children, type, size, }: React__default.PropsWithChildren<TextButtonProps>): React__default.JSX.Element;
|
|
75
76
|
declare namespace Button {
|
|
76
77
|
var type: typeof ButtonType;
|
|
77
78
|
var size: typeof ButtonSize;
|
package/dist/index.js
CHANGED
|
@@ -5,7 +5,7 @@ import { TabGroup, TabList, Tab, Listbox, ListboxButton, ListboxOptions, Listbox
|
|
|
5
5
|
import './assets/src/common/styles/base.css.ts.vanilla-aBQSVOsn.css';
|
|
6
6
|
import './assets/src/core/Tabs/Tabs.css.ts.vanilla-DQ1nIUyD.css';
|
|
7
7
|
import * as Juce from 'juce-framework-frontend';
|
|
8
|
-
import './assets/src/core/Button/Button.css.ts.vanilla-
|
|
8
|
+
import './assets/src/core/Button/Button.css.ts.vanilla-ZHEMMDf9.css';
|
|
9
9
|
import './assets/src/core/Dropdown/Dropdown.css.ts.vanilla-BLtRNWLI.css';
|
|
10
10
|
import './assets/src/core/Input/Input.css.ts.vanilla-BKrnSGGE.css';
|
|
11
11
|
import { useDrag } from '@use-gesture/react';
|
|
@@ -178,6 +178,7 @@ Tabs.margin = Spacing;
|
|
|
178
178
|
|
|
179
179
|
var ButtonSize;
|
|
180
180
|
(function(ButtonSize) {
|
|
181
|
+
ButtonSize["xSmall"] = "xSmall";
|
|
181
182
|
ButtonSize["small"] = "small";
|
|
182
183
|
ButtonSize["large"] = "large";
|
|
183
184
|
})(ButtonSize || (ButtonSize = {}));
|
|
@@ -188,7 +189,7 @@ var ButtonType;
|
|
|
188
189
|
})(ButtonType || (ButtonType = {}));
|
|
189
190
|
|
|
190
191
|
var ButtonStyle = 'Button_ButtonStyle__1m3jauc0';
|
|
191
|
-
var variants$2 = {small:'
|
|
192
|
+
var variants$2 = {xSmall:'Button_variants_xSmall__1m3jauc1 Button_ButtonStyle__1m3jauc0',small:'Button_variants_small__1m3jauc2 Button_ButtonStyle__1m3jauc0',large:'Button_variants_large__1m3jauc3 Button_ButtonStyle__1m3jauc0'};
|
|
192
193
|
|
|
193
194
|
function _array_like_to_array$5(arr, len) {
|
|
194
195
|
if (len == null || len > arr.length) len = arr.length;
|
|
@@ -266,8 +267,28 @@ function _unsupported_iterable_to_array$5(o, minLen) {
|
|
|
266
267
|
}
|
|
267
268
|
function Button(param) {
|
|
268
269
|
var disabled = param.disabled, text = param.text, id = param.id, className = param.className, style = param.style, children = param.children, _param_type = param.type, type = _param_type === void 0 ? ButtonType.latch : _param_type, _param_size = param.size, size = _param_size === void 0 ? ButtonSize.large : _param_size;
|
|
269
|
-
var _React_useState = _sliced_to_array$5(
|
|
270
|
+
var _React_useState = _sliced_to_array$5(React__default.useState(false), 2), isSelected = _React_useState[0], setIsSelected = _React_useState[1];
|
|
270
271
|
var buttonState = Juce.getToggleState(id);
|
|
272
|
+
var isLocalhost = window.location.hostname === 'localhost';
|
|
273
|
+
// Update the local state when the ID changes
|
|
274
|
+
useEffect(function() {
|
|
275
|
+
setIsSelected(buttonState === null || buttonState === void 0 ? void 0 : buttonState.value);
|
|
276
|
+
}, [
|
|
277
|
+
id
|
|
278
|
+
]);
|
|
279
|
+
// Sets up listeners to handle changes on the backend
|
|
280
|
+
useEffect(function() {
|
|
281
|
+
if (!isLocalhost) {
|
|
282
|
+
var valueListenerId = buttonState === null || buttonState === void 0 ? void 0 : buttonState.valueChangedEvent.addListener(function() {
|
|
283
|
+
setIsSelected(buttonState === null || buttonState === void 0 ? void 0 : buttonState.value);
|
|
284
|
+
});
|
|
285
|
+
return function cleanup() {
|
|
286
|
+
buttonState === null || buttonState === void 0 ? void 0 : buttonState.valueChangedEvent.removeListener(valueListenerId);
|
|
287
|
+
};
|
|
288
|
+
} else {
|
|
289
|
+
return;
|
|
290
|
+
}
|
|
291
|
+
});
|
|
271
292
|
var handleMouseDown = function(e) {
|
|
272
293
|
e.preventDefault();
|
|
273
294
|
if (type === ButtonType.momentary) {
|
|
@@ -282,7 +303,7 @@ function Button(param) {
|
|
|
282
303
|
setIsSelected(false);
|
|
283
304
|
buttonState.setValue(false);
|
|
284
305
|
};
|
|
285
|
-
|
|
306
|
+
React__default.useEffect(function() {
|
|
286
307
|
if (type === ButtonType.momentary) {
|
|
287
308
|
window.addEventListener('mouseup', handleMouseUp);
|
|
288
309
|
return function() {
|
|
@@ -293,13 +314,13 @@ function Button(param) {
|
|
|
293
314
|
}, [
|
|
294
315
|
isSelected
|
|
295
316
|
]);
|
|
296
|
-
return /*#__PURE__*/
|
|
317
|
+
return /*#__PURE__*/ React__default.createElement("button", {
|
|
297
318
|
id: id,
|
|
298
319
|
onMouseDown: handleMouseDown,
|
|
299
320
|
disabled: disabled,
|
|
300
321
|
style: _object_spread$b({}, style),
|
|
301
322
|
className: classnames('Button', ButtonStyle, variants$2[size], isSelected && 'selected', className)
|
|
302
|
-
}, text ? text : children);
|
|
323
|
+
}, size !== ButtonSize.xSmall && (text ? text : children));
|
|
303
324
|
}
|
|
304
325
|
Button.type = ButtonType;
|
|
305
326
|
Button.size = ButtonSize;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|