@updevs/components 1.0.0-alpha.40 → 1.0.0-alpha.42

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 (99) hide show
  1. package/assets/styles/_core.scss +9 -0
  2. package/assets/styles/_debug.scss +49 -0
  3. package/assets/styles/_props.scss +91 -0
  4. package/assets/styles/_utilities-marketing.scss +209 -0
  5. package/assets/styles/_utilities.scss +127 -92
  6. package/assets/styles/_variables-dark.scss +8 -6
  7. package/assets/styles/_variables.scss +326 -257
  8. package/assets/styles/helpers/_index.scss +143 -0
  9. package/assets/styles/layout/_core.scss +3 -2
  10. package/assets/styles/layout/_dark.scss +40 -35
  11. package/assets/styles/layout/_footer.scss +1 -1
  12. package/assets/styles/layout/_navbar.scss +31 -19
  13. package/assets/styles/layout/_page.scss +6 -5
  14. package/assets/styles/layout/_root.scss +26 -34
  15. package/assets/styles/marketing/_browser.scss +67 -0
  16. package/assets/styles/marketing/_core.scss +8 -0
  17. package/assets/styles/marketing/_filters.scss +0 -0
  18. package/assets/styles/marketing/_hero.scss +70 -0
  19. package/assets/styles/marketing/_pricing.scss +111 -0
  20. package/assets/styles/marketing/_sections.scss +124 -0
  21. package/assets/styles/marketing/_shape.scss +31 -0
  22. package/assets/styles/mixins/_functions.scss +53 -0
  23. package/assets/styles/mixins/_mixins.scss +9 -9
  24. package/assets/styles/ui/_accordion.scss +165 -11
  25. package/assets/styles/ui/_alerts.scss +80 -38
  26. package/assets/styles/ui/_avatars.scss +36 -9
  27. package/assets/styles/ui/_badges.scss +47 -13
  28. package/assets/styles/ui/_button-group.scss +1 -1
  29. package/assets/styles/ui/_buttons.scss +33 -37
  30. package/assets/styles/ui/_calendars.scss +2 -2
  31. package/assets/styles/ui/_cards.scss +9 -0
  32. package/assets/styles/ui/_carousel.scss +1 -1
  33. package/assets/styles/ui/_charts.scss +1 -1
  34. package/assets/styles/ui/_chat.scss +38 -0
  35. package/assets/styles/ui/_close.scss +54 -1
  36. package/assets/styles/ui/_datagrid.scss +1 -1
  37. package/assets/styles/ui/_dropdowns.scss +3 -0
  38. package/assets/styles/ui/_empty.scss +0 -5
  39. package/assets/styles/ui/_flags.scss +2 -2
  40. package/assets/styles/ui/_forms.scss +33 -7
  41. package/assets/styles/ui/_grid.scss +1 -1
  42. package/assets/styles/ui/_icons.scss +1 -1
  43. package/assets/styles/ui/_images.scss +4 -0
  44. package/assets/styles/ui/_lists.scss +12 -16
  45. package/assets/styles/ui/_loaders.scss +1 -1
  46. package/assets/styles/ui/_markdown.scss +15 -4
  47. package/assets/styles/ui/_modals.scss +2 -2
  48. package/assets/styles/ui/_nav.scss +17 -3
  49. package/assets/styles/ui/_offcanvas.scss +2 -2
  50. package/assets/styles/ui/_pagination.scss +2 -0
  51. package/assets/styles/ui/_payments.scss +1 -1
  52. package/assets/styles/ui/_placeholder.scss +1 -1
  53. package/assets/styles/ui/_progress.scss +1 -1
  54. package/assets/styles/ui/_ribbons.scss +1 -0
  55. package/assets/styles/ui/_segmented.scss +101 -0
  56. package/assets/styles/ui/_signature.scss +15 -0
  57. package/assets/styles/ui/_social.scss +52 -0
  58. package/assets/styles/ui/_status.scss +1 -1
  59. package/assets/styles/ui/_steps.scss +5 -1
  60. package/assets/styles/ui/_switch-icon.scss +1 -1
  61. package/assets/styles/ui/_tables.scss +27 -1
  62. package/assets/styles/ui/_tags.scss +1 -1
  63. package/assets/styles/ui/_timeline.scss +1 -1
  64. package/assets/styles/ui/_toasts.scss +0 -1
  65. package/assets/styles/ui/_tracking.scss +1 -1
  66. package/assets/styles/ui/_type.scss +169 -8
  67. package/assets/styles/ui/forms/_form-check.scss +1 -1
  68. package/assets/styles/ui/forms/_form-colorinput.scss +1 -1
  69. package/assets/styles/ui/forms/_form-custom.scss +1 -1
  70. package/assets/styles/ui/forms/_form-imagecheck.scss +6 -5
  71. package/assets/styles/ui/forms/_form-selectgroup.scss +2 -2
  72. package/assets/styles/ui/typo/_hr.scss +4 -2
  73. package/assets/styles/utils/_colors.scss +72 -11
  74. package/assets/styles/utils/_opacity.scss +1 -1
  75. package/assets/styles/utils/_scroll.scss +0 -2
  76. package/assets/styles/utils/_sizing.scss +1 -1
  77. package/assets/styles/utils/_text.scss +1 -2
  78. package/assets/styles/vendor/_apexcharts.scss +52 -0
  79. package/assets/styles/vendor/_coloris.scss +72 -0
  80. package/assets/styles/vendor/_dropzone.scss +27 -0
  81. package/assets/styles/vendor/_fslightbox.scss +13 -0
  82. package/assets/styles/vendor/_jsvectormap.scss +47 -0
  83. package/assets/styles/vendor/_litepicker.scss +69 -0
  84. package/assets/styles/vendor/_nouislider.scss +49 -0
  85. package/assets/styles/vendor/_plyr.scss +3 -0
  86. package/assets/styles/vendor/_stars-rating.scss +22 -0
  87. package/assets/styles/vendor/_tom-select.scss +81 -0
  88. package/assets/styles/vendor/_turbo.scss +3 -0
  89. package/assets/styles/vendor/_typed.scss +4 -0
  90. package/assets/styles/vendor/_wysiwyg.scss +46 -0
  91. package/esm2022/form-controls/checkbox/checkbox.component.mjs +5 -2
  92. package/esm2022/layout/partials/sidebar/sidebar.component.mjs +102 -30
  93. package/fesm2022/updevs-components-form-controls-checkbox.mjs +4 -1
  94. package/fesm2022/updevs-components-form-controls-checkbox.mjs.map +1 -1
  95. package/fesm2022/updevs-components-layout.mjs +101 -29
  96. package/fesm2022/updevs-components-layout.mjs.map +1 -1
  97. package/form-controls/checkbox/checkbox.component.d.ts +1 -1
  98. package/layout/partials/sidebar/sidebar.component.d.ts +5 -0
  99. package/package.json +31 -31
@@ -0,0 +1,47 @@
1
+ .jvm-tooltip {
2
+ background: var(--#{$prefix}bg-surface-inverted);
3
+ color: var(--#{$prefix}text-inverted);
4
+ font-family: inherit;
5
+ font-size: $h5-font-size;
6
+ box-shadow: $card-box-shadow;
7
+ }
8
+
9
+ .jvm-series-container .jvm-legend .jvm-legend-title {
10
+ border-bottom: 0;
11
+ font-weight: var(--#{$prefix}font-weight-medium);
12
+ }
13
+
14
+ .jvm-series-container .jvm-legend {
15
+ background-color: var(--#{$prefix}card-bg, var(--#{$prefix}bg-surface));
16
+ border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color);
17
+ min-width: 8rem;
18
+
19
+ .jvm-legend-inner .jvm-legend-tick {
20
+ display: flex;
21
+ align-items: center;
22
+
23
+ .jvm-legend-tick-sample {
24
+ width: .75rem;
25
+ height: .75rem;
26
+ }
27
+ }
28
+ }
29
+
30
+ .jvm-zoom-btn {
31
+ border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color);
32
+ background: var(--#{$prefix}card-bg, var(--#{$prefix}bg-surface));
33
+ color: var(--#{$prefix}body-color);
34
+ padding: 0;
35
+ display: flex;
36
+ align-items: center;
37
+ justify-content: center;
38
+ line-height: 1;
39
+ width: 1.5rem;
40
+ height: 1.5rem;
41
+ font-size: 1rem;
42
+ box-shadow: $card-box-shadow;
43
+
44
+ &.jvm-zoomout {
45
+ top: 2.5rem;
46
+ }
47
+ }
@@ -0,0 +1,69 @@
1
+ .litepicker {
2
+ --litepicker-month-weekday-color: #{var(--#{$prefix}secondary)};
3
+ --litepicker-button-prev-month-color: #{var(--#{$prefix}secondary)};
4
+ --litepicker-button-next-month-color: #{var(--#{$prefix}secondary)};
5
+ --litepicker-button-prev-month-color-hover: #{ var(--#{$prefix}primary) };
6
+ --litepicker-button-next-month-color-hover: #{ var(--#{$prefix}primary) };
7
+ --litepicker-day-color: var(--#{$prefix}body-color);
8
+ --litepicker-day-color-hover: #{ var(--#{$prefix}primary) };
9
+ --litepicker-is-start-color-bg: #{ var(--#{$prefix}primary) };
10
+ --litepicker-is-end-color-bg: #{ var(--#{$prefix}primary) };
11
+ --litepicker-is-in-range-color: #{ var(--#{$prefix}info) };
12
+ --litepicker-is-today-color: #{ var(--#{$prefix}primary) };
13
+ --litepicker-month-header-color: var(--#{$prefix}body-color);
14
+ --litepicker-container-months-color-bg: var(--#{$prefix}bg-surface);
15
+ font: inherit;
16
+ user-select: none;
17
+
18
+ .day-item.is-in-range {
19
+ --litepicker-day-color: var(--#{$prefix}light);
20
+ }
21
+
22
+ svg {
23
+ fill: none !important;
24
+ }
25
+
26
+ .container__main {
27
+ border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color);
28
+ border-radius: var(--#{$prefix}border-radius);
29
+ box-shadow: none;
30
+ }
31
+
32
+ .container__months {
33
+ .month-item-name,
34
+ .month-item-year {
35
+ font-weight: var(--#{$prefix}font-weight-medium) !important;
36
+ }
37
+
38
+ .button-next-month,
39
+ .button-previous-month {
40
+ cursor: pointer !important;
41
+ }
42
+
43
+ .month-item-weekdays-row {
44
+ > div {
45
+ padding: .5rem 0 !important;
46
+ font-size: $h5-font-size;
47
+ }
48
+ }
49
+ }
50
+
51
+ .container__days {
52
+ .day-item {
53
+ cursor: pointer !important;
54
+ padding: .5rem 0 !important;
55
+ @include transition(color $transition-time, background-color $transition-time, border-color $transition-time);
56
+ }
57
+ }
58
+
59
+ .datepicker-inline & {
60
+ box-shadow: $input-box-shadow;
61
+
62
+ .container__months {
63
+ box-shadow: none;
64
+ background-color: var(--#{$prefix}bg-forms);
65
+ border-radius: calc(var(--#{$prefix}border-radius) - 1px);
66
+ }
67
+ }
68
+ }
69
+
@@ -0,0 +1,49 @@
1
+ .noUi-target {
2
+ border: 0;
3
+ box-shadow: none;
4
+ background: none;
5
+ border-radius: 0;
6
+ color: $form-range-thumb-bg;
7
+ }
8
+
9
+ .noUi-horizontal {
10
+ height: add($form-range-track-height, 1rem);
11
+ padding: .5rem 0;
12
+ }
13
+
14
+ .noUi-base {
15
+ background: $form-range-track-bg;
16
+ border-radius: $form-range-track-border-radius;
17
+ }
18
+
19
+ .noUi-handle {
20
+ width: $form-range-thumb-width;
21
+ height: $form-range-thumb-height;
22
+ border: $form-range-thumb-border;
23
+ box-shadow: $form-range-thumb-box-shadow;
24
+ border-radius: $form-range-thumb-border-radius;
25
+ background: currentColor;
26
+ outline: 0;
27
+
28
+ &:before,
29
+ &:after {
30
+ content: none;
31
+ }
32
+
33
+ .noUi-horizontal & {
34
+ width: $form-range-thumb-width;
35
+ height: $form-range-thumb-height;
36
+ top: (-$form-range-thumb-height * .5);
37
+ right: (-$form-range-thumb-height * .5);
38
+ margin: 1px 1px 0 0;
39
+ }
40
+
41
+ &.noUi-active,
42
+ &:focus {
43
+ box-shadow: $form-range-thumb-focus-box-shadow;
44
+ }
45
+ }
46
+
47
+ .noUi-connect {
48
+ background: currentColor;
49
+ }
@@ -0,0 +1,3 @@
1
+ body {
2
+ --plyr-color-main: #{var(--#{$prefix}primary)};
3
+ }
@@ -0,0 +1,22 @@
1
+ :root {
2
+ --gl-star-size: auto;
3
+ --gl-star-color: var(--#{$prefix}yellow);
4
+ --gl-star-color-inactive: var(--#{$prefix}border-color);
5
+ }
6
+
7
+ [data-star-rating] {
8
+ svg {
9
+ width: var(--#{$prefix}icon-size, --gl-star-size);
10
+ height: var(--#{$prefix}icon-size, --gl-star-size);
11
+ }
12
+
13
+ :not(.gl-active) > .gl-star-full {
14
+ color: var(--gl-star-color-inactive) !important;
15
+ }
16
+
17
+ .gl-active > .gl-star-full {
18
+ color: var(--gl-star-color);
19
+ fill: currentColor;
20
+ stroke: currentColor;
21
+ }
22
+ }
@@ -0,0 +1,81 @@
1
+ $select-color-dropdown: #fff;
2
+ $select-color-dropdown-border-top: red;
3
+ $input-border-width: 1px;
4
+
5
+ :root {
6
+ --ts-pr-clear-button: 0rem;
7
+ --ts-pr-caret: 0rem;
8
+ }
9
+
10
+ .ts-input {
11
+ color: inherit;
12
+ }
13
+
14
+ .focus .ts-control {
15
+ border-radius: var(--#{$prefix}border-radius);
16
+ }
17
+
18
+
19
+ .ts-control {
20
+ color: inherit;
21
+
22
+ .dropdown-menu {
23
+ width: 100%;
24
+ height: auto;
25
+ }
26
+ }
27
+
28
+ .ts-wrapper {
29
+ .form-control,
30
+ .form-select,
31
+ &.form-control,
32
+ &.form-select {
33
+ box-shadow: $input-box-shadow;
34
+ }
35
+
36
+ &.is-invalid,
37
+ &.is-valid {
38
+ .ts-control {
39
+ --ts-pr-clear-button: 1.5rem;
40
+ }
41
+ }
42
+ }
43
+
44
+ .ts-dropdown {
45
+ background: var(--#{$prefix}bg-surface);
46
+ color: var(--#{$prefix}body-color);
47
+ box-shadow: var(--#{$prefix}shadow-dropdown);
48
+ z-index: $zindex-dropdown;
49
+
50
+ .option {
51
+ padding: $dropdown-item-padding-y $dropdown-item-padding-x;
52
+ }
53
+ }
54
+
55
+ .ts-control,
56
+ .ts-control input {
57
+ color: var(--#{$prefix}body-color);
58
+ }
59
+
60
+ .ts-control input {
61
+ &::placeholder{
62
+ color: $input-placeholder-color;
63
+ }
64
+ }
65
+
66
+ .ts-wrapper.multi,
67
+ .ts-wrapper.multi.disabled {
68
+ .ts-control > div {
69
+ background: var(--#{$prefix}bg-surface-secondary);
70
+ border: 1px solid var(--#{$prefix}border-color);
71
+ color: var(--#{$prefix}body-color);
72
+ }
73
+ }
74
+
75
+ .ts-wrapper.disabled .ts-control {
76
+ opacity: 1;
77
+
78
+ &> div.item {
79
+ color: var(--#{$prefix}gray-500);
80
+ }
81
+ }
@@ -0,0 +1,3 @@
1
+ .turbo-progress-bar {
2
+ background: var(--#{$prefix}primary);
3
+ }
@@ -0,0 +1,4 @@
1
+ .typed-cursor {
2
+ font-weight: 500;
3
+ color: $secondary;
4
+ }
@@ -0,0 +1,46 @@
1
+ .tox-hugerte {
2
+ border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color) !important;
3
+ border-radius: $border-radius !important;
4
+ font-family: var(--#{$prefix}font-sans-serif) !important;
5
+ }
6
+
7
+ .tox-toolbar__group {
8
+ padding: 0 .5rem 0;
9
+ }
10
+
11
+ .tox .tox-toolbar__primary {
12
+ background: transparent !important;
13
+ }
14
+
15
+ .tox:not(.tox-hugerte-inline) {
16
+ .tox-editor-header {
17
+ border-bottom: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color) !important;
18
+ box-shadow: none !important;
19
+ padding: 0 !important;
20
+ }
21
+ }
22
+
23
+ .tox-tbtn {
24
+ margin: 0 !important;
25
+ background: var(--#{$prefix}bg-surface) !important;
26
+
27
+ &:hover,
28
+ &.tox-tbtn--enabled {
29
+ background: var(--#{$prefix}bg-surface-secondary) !important;
30
+ }
31
+ }
32
+
33
+ .tox-edit-area {
34
+ &::before {
35
+ border: none !important
36
+ }
37
+ }
38
+
39
+ .tox-statusbar {
40
+ border-top: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color) !important;
41
+ }
42
+
43
+ .tox .tox-toolbar-overlord,
44
+ .tox:not(.tox-hugerte-inline) .tox-editor-header {
45
+ background: transparent !important;
46
+ }
@@ -24,7 +24,10 @@ export class CheckboxComponent extends BaseControl {
24
24
  return [...lClasses, ...(this.customClasses() || '').split(' ')];
25
25
  });
26
26
  effect(() => {
27
- this.checkboxInput.nativeElement.indeterminate = !!this.isIndeterminate();
27
+ this.isIndeterminate();
28
+ if (!!this.checkboxInput) {
29
+ this.checkboxInput.nativeElement.indeterminate = !!this.isIndeterminate();
30
+ }
28
31
  });
29
32
  }
30
33
  onSelectChange(event) {
@@ -48,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
48
51
  }], changed: [{
49
52
  type: Output
50
53
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2Zvcm0tY29udHJvbHMvY2hlY2tib3gvc3JjL2NoZWNrYm94LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9mb3JtLWNvbnRyb2xzL2NoZWNrYm94L3NyYy9jaGVja2JveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUNULEtBQUssRUFDTCxpQkFBaUIsRUFDakIsV0FBVyxFQUNYLE1BQU0sRUFDTixZQUFZLEVBQ1osU0FBUyxFQUNULFVBQVUsRUFDVixNQUFNLEVBQ04sS0FBSyxFQUNMLEtBQUssRUFDTCxRQUFRLEVBQ1gsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLCtDQUErQyxDQUFDOzs7OztBQVE1RSxNQUFNLE9BQU8saUJBQWtCLFNBQVEsV0FBVztJQXVCOUM7UUFDSSxLQUFLLEVBQUUsQ0FBQztRQXZCbUIsbUJBQWMsR0FBRyxFQUFFLENBQUM7UUFHaEMsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFFekQsVUFBSyxHQUFHLEtBQUssRUFBTyxDQUFDO1FBQ3JCLGtCQUFhLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDaEMsY0FBUyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsQyxhQUFRLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLGFBQVEsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDakMsb0JBQWUsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDeEMsWUFBTyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDcEIsTUFBTSxRQUFRLEdBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1lBRWhELElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLENBQUM7Z0JBQzVCLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLGdCQUFnQixFQUFFLEVBQUUsQ0FBQztnQkFDbEQsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUM3QixDQUFDO1lBRUQsT0FBTyxDQUFDLEdBQUcsUUFBUSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDckUsQ0FBQyxDQUFDLENBQUM7UUFLQyxNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsYUFBYSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDOUUsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsY0FBYyxDQUFDLEtBQVk7UUFDdkIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUUsS0FBSyxDQUFDLE1BQTJCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbEUsQ0FBQzs4R0FsQ1EsaUJBQWlCO2tHQUFqQixpQkFBaUIsc3ZDQUVVLFVBQVUsb0RDeEJsRCwyNkNBa0NBOzsyRkRaYSxpQkFBaUI7a0JBTjdCLFNBQVM7K0JBQ0ksY0FBYyxpQkFHVCxpQkFBaUIsQ0FBQyxJQUFJO3dEQUdOLGNBQWM7c0JBQTVDLFdBQVc7dUJBQUMsT0FBTzs7c0JBQUcsS0FBSztnQkFDc0IsYUFBYTtzQkFBOUQsU0FBUzt1QkFBQyxlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFO2dCQUU3QixPQUFPO3NCQUF6QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnQsXG4gICAgSW5wdXQsXG4gICAgVmlld0VuY2Fwc3VsYXRpb24sXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgT3V0cHV0LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBWaWV3Q2hpbGQsXG4gICAgRWxlbWVudFJlZixcbiAgICBlZmZlY3QsXG4gICAgaW5wdXQsXG4gICAgbW9kZWwsXG4gICAgY29tcHV0ZWRcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYXNlQ29udHJvbCB9IGZyb20gJ0B1cGRldnMvY29tcG9uZW50cy9mb3JtLWNvbnRyb2xzL2Fic3RyYWN0aW9ucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndXBkLWNoZWNrYm94JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tib3guY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2NoZWNrYm94LmNvbXBvbmVudC5zY3NzJ10sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveENvbXBvbmVudCBleHRlbmRzIEJhc2VDb250cm9sIHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgQElucHV0KCkgd3JhcHBlckNsYXNzZXMgPSAnJztcbiAgICBAVmlld0NoaWxkKCdjaGVja2JveElucHV0JywgeyByZWFkOiBFbGVtZW50UmVmIH0pIGNoZWNrYm94SW5wdXQhOiBFbGVtZW50UmVmO1xuXG4gICAgQE91dHB1dCgpIHJlYWRvbmx5IGNoYW5nZWQgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG5cbiAgICB2YWx1ZSA9IGlucHV0PGFueT4oKTtcbiAgICBjdXN0b21DbGFzc2VzID0gaW5wdXQ8c3RyaW5nPigpO1xuICAgIGlzQ2hlY2tlZCA9IG1vZGVsPGJvb2xlYW4+KGZhbHNlKTtcbiAgICBpc0lubGluZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgICBpc1N3aXRjaCA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgICBpc0luZGV0ZXJtaW5hdGUgPSBtb2RlbDxib29sZWFuPihmYWxzZSk7XG4gICAgY2xhc3NlcyA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3QgbENsYXNzZXM6IHN0cmluZ1tdID0gWydmb3JtLWNoZWNrLWlucHV0J107XG5cbiAgICAgICAgaWYgKCEhdGhpcy52YWxpZGF0aW9uU3RhdHVzKCkpIHtcbiAgICAgICAgICAgIGNvbnN0IHN0YXR1c0NscyA9IGBpcy0ke3RoaXMudmFsaWRhdGlvblN0YXR1cygpfWA7XG4gICAgICAgICAgICBsQ2xhc3Nlcy5wdXNoKHN0YXR1c0Nscyk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gWy4uLmxDbGFzc2VzLCAuLi4odGhpcy5jdXN0b21DbGFzc2VzKCkgfHwgJycpLnNwbGl0KCcgJyldO1xuICAgIH0pO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCk7XG5cbiAgICAgICAgZWZmZWN0KCgpID0+IHtcbiAgICAgICAgICAgIHRoaXMuY2hlY2tib3hJbnB1dC5uYXRpdmVFbGVtZW50LmluZGV0ZXJtaW5hdGUgPSAhIXRoaXMuaXNJbmRldGVybWluYXRlKCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG9uU2VsZWN0Q2hhbmdlKGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzSW5kZXRlcm1pbmF0ZS5zZXQoZmFsc2UpO1xuICAgICAgICB0aGlzLmNoYW5nZWQuZW1pdCgoZXZlbnQudGFyZ2V0IGFzIEhUTUxJbnB1dEVsZW1lbnQpLmNoZWNrZWQpO1xuICAgIH1cbn1cbiIsIjxsYWJlbCBjbGFzcz1cImZvcm0tY2hlY2tcIiBbY2xhc3MuZm9ybS1jaGVjay1pbmxpbmVdPVwiaXNJbmxpbmUoKVwiIFtjbGFzcy5mb3JtLXN3aXRjaF09XCJpc1N3aXRjaCgpXCIgW25nQ2xhc3NdPVwiY3VzdG9tQ2xhc3NlcygpXCI+XG4gICAgQGlmICghIWhpbnRUZXh0IHx8ICEhaGludFRlbXBsYXRlKCkpIHtcbiAgICAgICAgPGRpdiBjbGFzcz1cInJvdyBnLTJcIj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtYXV0b1wiPlxuICAgICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSBbbmdUZW1wbGF0ZU91dGxldF09XCJjb250ZW50VHBsXCI+PC9uZy10ZW1wbGF0ZT5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1hdXRvIGFsaWduLXNlbGYtY2VudGVyXCI+XG4gICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJmb3JtLWhlbHBcIiBbdXBkUG9wb3Zlcl09XCJoaW50VGV4dFwiIFt1cGRQb3BvdmVyVGVtcGxhdGVdPVwiaGludFRlbXBsYXRlKClcIlxuICAgICAgICAgICAgICAgICAgICBbdXBkUG9wb3ZlckFjdEFzVG9vbHRpcF09XCJoaW50QXNUb29sdGlwKClcIj5cbiAgICAgICAgICAgICAgICAgICAgP1xuICAgICAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICB9IEBlbHNlIHtcbiAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImNvbnRlbnRUcGxcIj48L25nLXRlbXBsYXRlPlxuICAgIH1cbjwvbGFiZWw+XG5cbjxuZy10ZW1wbGF0ZSAjY29udGVudFRwbD5cbiAgICA8aW5wdXQgI2NoZWNrYm94SW5wdXQgdHlwZT1cImNoZWNrYm94XCIgW2Rpc2FibGVkXT1cImlzRGlzYWJsZWQoKVwiIFtuZ0NsYXNzXT1cImNsYXNzZXMoKVwiIFt2YWx1ZV09XCJ2YWx1ZSgpXCIgW2F0dHIubmFtZV09XCJuYW1lKClcIlxuICAgICAgICBbYXR0ci5yZWFkb25seV09XCJpc0Rpc2FibGVkKCkgPyAnJyA6IHVuZGVmaW5lZFwiIFsobmdNb2RlbCldPVwiaXNDaGVja2VkXCIgKGNoYW5nZSk9XCJvblNlbGVjdENoYW5nZSgkZXZlbnQpXCI+XG5cbiAgICBAaWYgKCEhbGFiZWxUZXh0KSB7XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZm9ybS1jaGVjay1sYWJlbFwiPnt7IGxhYmVsVGV4dCB9fTwvc3Bhbj5cbiAgICB9XG5cbiAgICBAaWYgKCEhZGVzY3JpcHRpb25UZXh0KSB7XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZm9ybS1jaGVjay1kZXNjcmlwdGlvblwiPnt7IGRlc2NyaXB0aW9uVGV4dCB9fTwvc3Bhbj5cbiAgICB9XG5cbiAgICBAaWYgKHZhbGlkYXRpb25TdGF0dXMoKSA9PT0gJ2ludmFsaWQnICYmICEhdmFsaWRhdGlvblN0YXR1c1RleHRzKSB7XG4gICAgICAgIDxkaXYgY2xhc3M9XCJpbnZhbGlkLWZlZWRiYWNrXCI+e3sgdmFsaWRhdGlvblN0YXR1c1RleHRzIH19PC9kaXY+XG4gICAgfVxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2Zvcm0tY29udHJvbHMvY2hlY2tib3gvc3JjL2NoZWNrYm94LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9mb3JtLWNvbnRyb2xzL2NoZWNrYm94L3NyYy9jaGVja2JveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUNULEtBQUssRUFDTCxpQkFBaUIsRUFDakIsV0FBVyxFQUNYLE1BQU0sRUFDTixZQUFZLEVBQ1osU0FBUyxFQUNULFVBQVUsRUFDVixNQUFNLEVBQ04sS0FBSyxFQUNMLEtBQUssRUFDTCxRQUFRLEVBQ1gsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLCtDQUErQyxDQUFDOzs7OztBQVE1RSxNQUFNLE9BQU8saUJBQWtCLFNBQVEsV0FBVztJQXVCOUM7UUFDSSxLQUFLLEVBQUUsQ0FBQztRQXZCbUIsbUJBQWMsR0FBRyxFQUFFLENBQUM7UUFHaEMsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFFekQsVUFBSyxHQUFHLEtBQUssRUFBTyxDQUFDO1FBQ3JCLGtCQUFhLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDaEMsY0FBUyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsQyxhQUFRLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLGFBQVEsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDakMsb0JBQWUsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDeEMsWUFBTyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDcEIsTUFBTSxRQUFRLEdBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1lBRWhELElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLENBQUM7Z0JBQzVCLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLGdCQUFnQixFQUFFLEVBQUUsQ0FBQztnQkFDbEQsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUM3QixDQUFDO1lBRUQsT0FBTyxDQUFDLEdBQUcsUUFBUSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDckUsQ0FBQyxDQUFDLENBQUM7UUFLQyxNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1IsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBRXZCLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztnQkFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsYUFBYSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDOUUsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFZO1FBQ3ZCLElBQUksQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFFLEtBQUssQ0FBQyxNQUEyQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2xFLENBQUM7OEdBdENRLGlCQUFpQjtrR0FBakIsaUJBQWlCLHN2Q0FFVSxVQUFVLG9EQ3hCbEQsMjZDQWtDQTs7MkZEWmEsaUJBQWlCO2tCQU43QixTQUFTOytCQUNJLGNBQWMsaUJBR1QsaUJBQWlCLENBQUMsSUFBSTt3REFHTixjQUFjO3NCQUE1QyxXQUFXO3VCQUFDLE9BQU87O3NCQUFHLEtBQUs7Z0JBQ3NCLGFBQWE7c0JBQTlELFNBQVM7dUJBQUMsZUFBZSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRTtnQkFFN0IsT0FBTztzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tcG9uZW50LFxuICAgIElucHV0LFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxuICAgIEhvc3RCaW5kaW5nLFxuICAgIE91dHB1dCxcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgVmlld0NoaWxkLFxuICAgIEVsZW1lbnRSZWYsXG4gICAgZWZmZWN0LFxuICAgIGlucHV0LFxuICAgIG1vZGVsLFxuICAgIGNvbXB1dGVkXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZUNvbnRyb2wgfSBmcm9tICdAdXBkZXZzL2NvbXBvbmVudHMvZm9ybS1jb250cm9scy9hYnN0cmFjdGlvbnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3VwZC1jaGVja2JveCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jaGVja2JveC5jb21wb25lbnQuc2NzcyddLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgQ2hlY2tib3hDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29udHJvbCB7XG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcycpIEBJbnB1dCgpIHdyYXBwZXJDbGFzc2VzID0gJyc7XG4gICAgQFZpZXdDaGlsZCgnY2hlY2tib3hJbnB1dCcsIHsgcmVhZDogRWxlbWVudFJlZiB9KSBjaGVja2JveElucHV0PzogRWxlbWVudFJlZjtcblxuICAgIEBPdXRwdXQoKSByZWFkb25seSBjaGFuZ2VkID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gICAgdmFsdWUgPSBpbnB1dDxhbnk+KCk7XG4gICAgY3VzdG9tQ2xhc3NlcyA9IGlucHV0PHN0cmluZz4oKTtcbiAgICBpc0NoZWNrZWQgPSBtb2RlbDxib29sZWFuPihmYWxzZSk7XG4gICAgaXNJbmxpbmUgPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG4gICAgaXNTd2l0Y2ggPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG4gICAgaXNJbmRldGVybWluYXRlID0gbW9kZWw8Ym9vbGVhbj4oZmFsc2UpO1xuICAgIGNsYXNzZXMgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IGxDbGFzc2VzOiBzdHJpbmdbXSA9IFsnZm9ybS1jaGVjay1pbnB1dCddO1xuXG4gICAgICAgIGlmICghIXRoaXMudmFsaWRhdGlvblN0YXR1cygpKSB7XG4gICAgICAgICAgICBjb25zdCBzdGF0dXNDbHMgPSBgaXMtJHt0aGlzLnZhbGlkYXRpb25TdGF0dXMoKX1gO1xuICAgICAgICAgICAgbENsYXNzZXMucHVzaChzdGF0dXNDbHMpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIFsuLi5sQ2xhc3NlcywgLi4uKHRoaXMuY3VzdG9tQ2xhc3NlcygpIHx8ICcnKS5zcGxpdCgnICcpXTtcbiAgICB9KTtcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcigpO1xuXG4gICAgICAgIGVmZmVjdCgoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmlzSW5kZXRlcm1pbmF0ZSgpO1xuXG4gICAgICAgICAgICBpZiAoISF0aGlzLmNoZWNrYm94SW5wdXQpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmNoZWNrYm94SW5wdXQubmF0aXZlRWxlbWVudC5pbmRldGVybWluYXRlID0gISF0aGlzLmlzSW5kZXRlcm1pbmF0ZSgpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBvblNlbGVjdENoYW5nZShldmVudDogRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pc0luZGV0ZXJtaW5hdGUuc2V0KGZhbHNlKTtcbiAgICAgICAgdGhpcy5jaGFuZ2VkLmVtaXQoKGV2ZW50LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS5jaGVja2VkKTtcbiAgICB9XG59XG4iLCI8bGFiZWwgY2xhc3M9XCJmb3JtLWNoZWNrXCIgW2NsYXNzLmZvcm0tY2hlY2staW5saW5lXT1cImlzSW5saW5lKClcIiBbY2xhc3MuZm9ybS1zd2l0Y2hdPVwiaXNTd2l0Y2goKVwiIFtuZ0NsYXNzXT1cImN1c3RvbUNsYXNzZXMoKVwiPlxuICAgIEBpZiAoISFoaW50VGV4dCB8fCAhIWhpbnRUZW1wbGF0ZSgpKSB7XG4gICAgICAgIDxkaXYgY2xhc3M9XCJyb3cgZy0yXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLWF1dG9cIj5cbiAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgW25nVGVtcGxhdGVPdXRsZXRdPVwiY29udGVudFRwbFwiPjwvbmctdGVtcGxhdGU+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtYXV0byBhbGlnbi1zZWxmLWNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZm9ybS1oZWxwXCIgW3VwZFBvcG92ZXJdPVwiaGludFRleHRcIiBbdXBkUG9wb3ZlclRlbXBsYXRlXT1cImhpbnRUZW1wbGF0ZSgpXCJcbiAgICAgICAgICAgICAgICAgICAgW3VwZFBvcG92ZXJBY3RBc1Rvb2x0aXBdPVwiaGludEFzVG9vbHRpcCgpXCI+XG4gICAgICAgICAgICAgICAgICAgID9cbiAgICAgICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgfSBAZWxzZSB7XG4gICAgICAgIDxuZy10ZW1wbGF0ZSBbbmdUZW1wbGF0ZU91dGxldF09XCJjb250ZW50VHBsXCI+PC9uZy10ZW1wbGF0ZT5cbiAgICB9XG48L2xhYmVsPlxuXG48bmctdGVtcGxhdGUgI2NvbnRlbnRUcGw+XG4gICAgPGlucHV0ICNjaGVja2JveElucHV0IHR5cGU9XCJjaGVja2JveFwiIFtkaXNhYmxlZF09XCJpc0Rpc2FibGVkKClcIiBbbmdDbGFzc109XCJjbGFzc2VzKClcIiBbdmFsdWVdPVwidmFsdWUoKVwiIFthdHRyLm5hbWVdPVwibmFtZSgpXCJcbiAgICAgICAgW2F0dHIucmVhZG9ubHldPVwiaXNEaXNhYmxlZCgpID8gJycgOiB1bmRlZmluZWRcIiBbKG5nTW9kZWwpXT1cImlzQ2hlY2tlZFwiIChjaGFuZ2UpPVwib25TZWxlY3RDaGFuZ2UoJGV2ZW50KVwiPlxuXG4gICAgQGlmICghIWxhYmVsVGV4dCkge1xuICAgICAgICA8c3BhbiBjbGFzcz1cImZvcm0tY2hlY2stbGFiZWxcIj57eyBsYWJlbFRleHQgfX08L3NwYW4+XG4gICAgfVxuXG4gICAgQGlmICghIWRlc2NyaXB0aW9uVGV4dCkge1xuICAgICAgICA8c3BhbiBjbGFzcz1cImZvcm0tY2hlY2stZGVzY3JpcHRpb25cIj57eyBkZXNjcmlwdGlvblRleHQgfX08L3NwYW4+XG4gICAgfVxuXG4gICAgQGlmICh2YWxpZGF0aW9uU3RhdHVzKCkgPT09ICdpbnZhbGlkJyAmJiAhIXZhbGlkYXRpb25TdGF0dXNUZXh0cykge1xuICAgICAgICA8ZGl2IGNsYXNzPVwiaW52YWxpZC1mZWVkYmFja1wiPnt7IHZhbGlkYXRpb25TdGF0dXNUZXh0cyB9fTwvZGl2PlxuICAgIH1cbjwvbmctdGVtcGxhdGU+XG4iXX0=