@natec/mef-dev-ui-kit 16.2.3 → 16.2.5

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 (26) hide show
  1. package/esm2022/lib/markup-kit/card/card-long/card-long.component.mjs +16 -16
  2. package/esm2022/lib/markup-kit/card/card-simple/card-simple.component.mjs +7 -7
  3. package/esm2022/lib/markup-kit/collapse/collapse/collapse.component.mjs +3 -3
  4. package/esm2022/lib/markup-kit/executors/mefdev-executor-page/mefdev-executor-page.component.mjs +69 -1
  5. package/esm2022/lib/markup-kit/executors/stage/stage.component.mjs +4 -1
  6. package/esm2022/lib/markup-kit/executors/step-executor/step-executor.component.mjs +116 -1
  7. package/esm2022/lib/markup-kit/modals/fill/fill.component.mjs +3 -3
  8. package/esm2022/lib/markup-kit/modals/slide-up/slide-up.component.mjs +3 -3
  9. package/esm2022/lib/markup-kit/slider/index.mjs +3 -0
  10. package/esm2022/lib/markup-kit/slider/slider/slider.component.mjs +120 -0
  11. package/esm2022/lib/markup-kit/slider/slider.module.mjs +28 -0
  12. package/esm2022/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.mjs +18 -7
  13. package/esm2022/public-api.mjs +2 -1
  14. package/fesm2022/natec-mef-dev-ui-kit.mjs +371 -34
  15. package/fesm2022/natec-mef-dev-ui-kit.mjs.map +1 -1
  16. package/lib/markup-kit/card/card-long/card-long.component.d.ts +14 -14
  17. package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +5 -5
  18. package/lib/markup-kit/executors/mefdev-executor-page/mefdev-executor-page.component.d.ts +68 -0
  19. package/lib/markup-kit/executors/stage/stage.component.d.ts +3 -0
  20. package/lib/markup-kit/executors/step-executor/step-executor.component.d.ts +115 -0
  21. package/lib/markup-kit/slider/index.d.ts +2 -0
  22. package/lib/markup-kit/slider/slider/slider.component.d.ts +93 -0
  23. package/lib/markup-kit/slider/slider.module.d.ts +9 -0
  24. package/package.json +1 -1
  25. package/public-api.d.ts +1 -0
  26. package/src/lib/styles/pg/vendor/ng-datatable.scss +5 -3
@@ -2,13 +2,104 @@ import { Component, ContentChild, EventEmitter, Input, Output, ViewChild } from
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  import * as i2 from "../stage/stage.component";
5
+ /**
6
+ * Wrapper component that represents a specific encapsulated executor.
7
+ *
8
+ * Example of usage:
9
+ *```
10
+ * <mefdev-step-executor #mainExecutor [view]="'regular'">
11
+ *
12
+ * <ng-template #title>
13
+ * <!-- Content for the executor title -->
14
+ * </ng-template>
15
+ * <ng-template #description>
16
+ * <!-- Content for the executor description -->
17
+ * </ng-template>
18
+ *
19
+ * <mefdev-executor-page
20
+ * [title]="'Description of situation 1'"
21
+ * [isActive]="mainExecutor.activePageInd === 0"
22
+ * [isCompleted]="mainExecutor.activePageInd >= 0">
23
+ * <!-- Content of the first executor step -->
24
+ * </mefdev-executor-page>
25
+ * <mefdev-executor-page
26
+ * [title]="'Description of situation 2'"
27
+ * [isActive]="mainExecutor.activePageInd === 1"
28
+ * [isCompleted]="mainExecutor.activePageInd >= 1">
29
+ * <!-- Content of the second executor step -->
30
+ * </mefdev-executor-page>
31
+ * <mefdev-executor-page
32
+ * [title]="'Description of situation 3'"
33
+ * [isActive]="mainExecutor.activePageInd === 2"
34
+ * [isCompleted]="mainExecutor.activePageInd >= 2">
35
+ * <!-- Content of the third executor step -->
36
+ * </mefdev-executor-page>
37
+ *
38
+ * <ng-template #footer>
39
+ * <!-- Content for the executor footer -->
40
+ * <ng-template>
41
+ *
42
+ * </mefdev-step-executor>
43
+ *
44
+ *```
45
+ */
5
46
  export class StepExecutorComponent {
6
47
  renderer;
48
+ /**
49
+ * Mandatory input parameter that specifies the type of the step-by-step wizard.
50
+ * It can have three options: regular, modal, right.
51
+ *
52
+ * @usageNotes
53
+ * ```
54
+ * <mefdev-step-executor #mainExecutor [view]="'regular'"></mefdev-step-executor>
55
+ * ```
56
+ */
7
57
  view;
58
+ /**
59
+ * ViewChild reference to the host executor content.
60
+ */
8
61
  container;
62
+ /**
63
+ * Template for displaying the content of the executor title.
64
+ *
65
+ * @usageNotes
66
+ * ```
67
+ * <ng-template #title>
68
+ * <!-- Content for the executor title -->
69
+ * </ng-template>
70
+ * ```
71
+ */
9
72
  title;
73
+ /**
74
+ * Template for displaying the content of the executor description.
75
+ *
76
+ * @usageNotes
77
+ * ```
78
+ * <ng-template #description>
79
+ * <!-- Content for the executor description -->
80
+ * </ng-template>
81
+ * ```
82
+ */
10
83
  description;
84
+ /**
85
+ * Template for displaying the content of the executor footer.
86
+ *
87
+ * @usageNotes
88
+ * ```
89
+ * <ng-template #footer>
90
+ * <!-- Content for the executor footer -->
91
+ * </ng-template>
92
+ * ```
93
+ */
11
94
  footer;
95
+ /**
96
+ * The output parameter that emits the class of the active page - active step.
97
+ *
98
+ * @usageNotes
99
+ * ```
100
+ * <mefdev-step-executor #mainExecutor (onActivePageChange)="getActiveStep($event)"></mefdev-step-executor>
101
+ * ```
102
+ */
12
103
  onActivePageChange = new EventEmitter();
13
104
  _activePageInd = 0;
14
105
  pages = [];
@@ -35,15 +126,24 @@ export class StepExecutorComponent {
35
126
  this.renderer.appendChild(this.container.nativeElement, this.activePage?.elRef.nativeElement);
36
127
  this.onActivePageChange.emit(this.pages.find((el) => el.isActive));
37
128
  }
129
+ /**
130
+ * Check whether there is a next step of the executor. If we are at the last step - disable the 'next' button
131
+ */
38
132
  nextBtnIsDisabled() {
39
133
  return this._activePageInd === this.pages.length - 1;
40
134
  }
135
+ /**
136
+ * Check whether there is a next step of the executor. If we are at the last step - disable the 'next' button
137
+ */
41
138
  prev() {
42
139
  const newPageInd = this.activePageInd - 1;
43
140
  if (newPageInd >= 0) {
44
141
  this.activePageInd = newPageInd;
45
142
  }
46
143
  }
144
+ /**
145
+ * Go back to the previous step
146
+ */
47
147
  cancel() {
48
148
  this.activePageInd = 0;
49
149
  const newPageInd = this.activePageInd - 1;
@@ -51,21 +151,33 @@ export class StepExecutorComponent {
51
151
  this.activePageInd = newPageInd;
52
152
  }
53
153
  }
154
+ /**
155
+ * Go to the next step
156
+ */
54
157
  next() {
55
158
  const newPageInd = this.activePageInd + 1;
56
159
  if (newPageInd < this.pages.length) {
57
160
  this.activePageInd = newPageInd;
58
161
  }
59
162
  }
163
+ /**
164
+ * Set a specific active page
165
+ */
60
166
  setActivePage(pageNumber) {
61
167
  pageNumber -= 1;
62
168
  if (pageNumber < this.pages.length && pageNumber >= 0) {
63
169
  this.activePageInd = pageNumber;
64
170
  }
65
171
  }
172
+ /**
173
+ * Add new page
174
+ */
66
175
  addPage(page) {
67
176
  this.pages.push(page);
68
177
  }
178
+ /**
179
+ * Delete a specific page
180
+ */
69
181
  removeSpecificPage(page) {
70
182
  const index = this.pages.indexOf(page);
71
183
  if (index !== -1) {
@@ -75,6 +187,9 @@ export class StepExecutorComponent {
75
187
  }
76
188
  }
77
189
  }
190
+ /**
191
+ * Delete a page by its index
192
+ */
78
193
  removePageByIndex(index) {
79
194
  if (index >= 0 && index < this.pages.length) {
80
195
  this.pages.splice(index, 1);
@@ -107,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
107
222
  }], onActivePageChange: [{
108
223
  type: Output
109
224
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-executor.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/executors/step-executor/step-executor.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/executors/step-executor/step-executor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit, Component,\r\n    ContentChild, ElementRef,\r\n    EventEmitter, Input,\r\n    Output, Renderer2,\r\n    TemplateRef, ViewChild\r\n} from '@angular/core';\r\nimport { MefdevExecutorPageComponent } from '../mefdev-executor-page/mefdev-executor-page.component';\r\n\r\n@Component({\r\n    selector: 'mefdev-step-executor',\r\n    templateUrl: './step-executor.component.html',\r\n    styleUrls: ['./step-executor.component.scss']\r\n})\r\n\r\nexport class StepExecutorComponent implements AfterViewInit {\r\n\r\n    @Input({required: true}) view: string;\r\n    @ViewChild('container') container: ElementRef<HTMLElement>;\r\n    @ContentChild('title') title: TemplateRef<void>;\r\n    @ContentChild('description') description: TemplateRef<void>;\r\n    @ContentChild('footer') footer: TemplateRef<void>;\r\n    @Output() onActivePageChange: EventEmitter<MefdevExecutorPageComponent> = new EventEmitter<MefdevExecutorPageComponent>();\r\n\r\n    public _activePageInd: number = 0;\r\n    public pages: MefdevExecutorPageComponent[] = [];\r\n\r\n    constructor(private renderer: Renderer2) {}\r\n\r\n    public set activePageInd(activePageNumber: number) {\r\n        this._activePageInd = activePageNumber;\r\n        if (activePageNumber >= 0 && this.container) {\r\n            if (this.container.nativeElement.innerHTML != '') {\r\n                this.container.nativeElement.innerHTML = '';\r\n            }\r\n            this.renderer.appendChild(this.container.nativeElement, this.activePage?.elRef.nativeElement);\r\n            this.onActivePageChange.emit(this.pages.find((el: MefdevExecutorPageComponent) => el.isActive));\r\n        }\r\n    }\r\n\r\n    public get activePageInd(): number {\r\n        return this._activePageInd;\r\n    }\r\n\r\n    get activePage(): MefdevExecutorPageComponent | null {\r\n        return this.activePageInd == -1 ? null : this.pages[this.activePageInd];\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this.renderer.appendChild(this.container.nativeElement, this.activePage?.elRef.nativeElement);\r\n        this.onActivePageChange.emit(this.pages.find((el: MefdevExecutorPageComponent) => el.isActive));\r\n    }\r\n\r\n    nextBtnIsDisabled(): boolean {\r\n        return this._activePageInd === this.pages.length - 1;\r\n    }\r\n\r\n    prev(): void {\r\n        const newPageInd = this.activePageInd - 1;\r\n        if (newPageInd >= 0) {\r\n            this.activePageInd = newPageInd;\r\n        }\r\n    }\r\n\r\n    cancel(): void {\r\n        this.activePageInd = 0;\r\n        const newPageInd = this.activePageInd - 1;\r\n        if (newPageInd >= 0) {\r\n            this.activePageInd = newPageInd;\r\n        }\r\n    }\r\n\r\n    next(): void {\r\n        const newPageInd = this.activePageInd + 1;\r\n        if (newPageInd < this.pages.length) {\r\n            this.activePageInd = newPageInd;\r\n        }\r\n    }\r\n\r\n    setActivePage(pageNumber: number): void {\r\n        pageNumber -= 1;\r\n        if (pageNumber < this.pages.length && pageNumber >= 0) {\r\n            this.activePageInd = pageNumber;\r\n        }\r\n    }\r\n\r\n    addPage(page: MefdevExecutorPageComponent): void {\r\n        this.pages.push(page);\r\n    }\r\n\r\n    removeSpecificPage(page: MefdevExecutorPageComponent): void {\r\n        const index: number = this.pages.indexOf(page);\r\n        if (index !== -1) {\r\n            this.pages.splice(index, 1);\r\n            if (index === this.activePageInd) {\r\n                this.prev();\r\n            }\r\n        }\r\n    }\r\n\r\n    removePageByIndex(index: number): void {\r\n        if (index >= 0 && index < this.pages.length) {\r\n            this.pages.splice(index, 1);\r\n            if (index === this.activePageInd) {\r\n                this.prev();\r\n            }\r\n        }\r\n\r\n    }\r\n\r\n\r\n}\r\n","<!--view == regular-->\r\n\r\n<div class=\"stepExecutorBlock\" *ngIf=\"view === 'regular'\">\r\n  <header class=\"stepExecutorHeader\">\r\n    <div class=\"stepExecutorHeaderText\">\r\n      <h1 class=\"title\">\r\n        <ng-container [ngTemplateOutlet]=\"title\"></ng-container>\r\n      </h1>\r\n      <p class=\"body-5\">\r\n        <ng-container [ngTemplateOutlet]=\"description\"></ng-container>\r\n      </p>\r\n    </div>\r\n    <div class=\"steps\">\r\n      <mefdev-stage *ngFor=\"let page of pages; let pageIndex = index\"\r\n                    [isRightModal]=\"false\"\r\n                    [title]=\"page.title\"\r\n                    [currentExecutorStep]=\"pageIndex + 1\"\r\n                    [isCompleted]=\"page.isCompleted\">\r\n      </mefdev-stage>\r\n    </div>\r\n  </header>\r\n\r\n  <div *ngIf=\"activePage\" class=\"executorChangeContent\">\r\n    <div #container></div>\r\n  </div>\r\n\r\n  <div class=\"footerButtons\">\r\n    <ng-container [ngTemplateOutlet]=\"footer\"></ng-container>\r\n  </div>\r\n</div>\r\n\r\n\r\n<!--view == modal-->\r\n\r\n<div class=\"modalStepExecutor\" *ngIf=\"view === 'modal'\">\r\n\r\n  <header class=\"modalHeader\">\r\n    <div class=\"headerModalText\">\r\n      <div class=\"textAndCloseButton\">\r\n        <h1 class=\"title\">\r\n          <ng-container [ngTemplateOutlet]=\"title\"></ng-container>\r\n        </h1>\r\n        <p class=\"body-5\">\r\n          <ng-container [ngTemplateOutlet]=\"description\"></ng-container>\r\n        </p>\r\n      </div>\r\n      <article class=\"closeBtn\">\r\n        <svg width=\"15\" height=\"15\" viewBox=\"0 0 15 15\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M6.26735 7.68135L0.610352 2.02435L2.02435 0.610352L7.68135 6.26735L13.3384 0.610352L14.7524 2.02435L9.09535 7.68135L14.7524 13.3384L13.3384 14.7524L7.68135 9.09535L2.02435 14.7524L0.610352 13.3384L6.26735 7.68135Z\" fill=\"#4D4D4D\"/>\r\n        </svg>\r\n      </article>\r\n    </div>\r\n    <div class=\"modalSteps\">\r\n      <mefdev-stage *ngFor=\"let page of pages; let pageIndex = index\"\r\n                    [isRightModal]=\"false\"\r\n                    [title]=\"page.title\"\r\n                    [currentExecutorStep]=\"pageIndex + 1\"\r\n                    [isCompleted]=\"page.isCompleted\">\r\n      </mefdev-stage>\r\n    </div>\r\n  </header>\r\n\r\n  <main *ngIf=\"activePage\" class=\"modalExecutorMainContent\">\r\n    <div #container></div>\r\n  </main>\r\n\r\n  <footer class=\"modalFooter\">\r\n    <ng-container [ngTemplateOutlet]=\"footer\"></ng-container>\r\n  </footer>\r\n\r\n</div>\r\n\r\n<!--view == right-->\r\n\r\n<div class=\"rightExecutorBlock\" *ngIf=\"view === 'right'\">\r\n\r\n  <header class=\"rightExecutorHeader\">\r\n    <div class=\"rightExecutorTextAndCloseButton\">\r\n      <span class=\"body-1\">\r\n        <ng-container [ngTemplateOutlet]=\"title\"></ng-container>\r\n      </span>\r\n      <p class=\"body-5\">\r\n        <ng-container [ngTemplateOutlet]=\"description\"></ng-container>\r\n      </p>\r\n    </div>\r\n    <div class=\"closeButton\">\r\n      <svg width=\"17\" height=\"17\" viewBox=\"0 0 17 17\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M16.0566 1.59971L14.6566 0.199707L8.05664 6.79971L1.45664 0.199707L0.0566406 1.59971L6.65664 8.19971L0.0566406 14.7997L1.45664 16.1997L8.05664 9.59971L14.6566 16.1997L16.0566 14.7997L9.45664 8.19971L16.0566 1.59971Z\" fill=\"#525252\"/>\r\n      </svg>\r\n    </div>\r\n  </header>\r\n\r\n  <div class=\"line\">\r\n    <svg width=\"363\" height=\"1\" viewBox=\"0 0 363 1\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <line x1=\"-4.37114e-08\" y1=\"0.5\" x2=\"362.674\" y2=\"0.499968\" stroke=\"#4D4D4D\"/>\r\n    </svg>\r\n  </div>\r\n\r\n  <div class=\"contentExecutor\">\r\n    <div class=\"rightChangeContent\">\r\n      <div *ngIf=\"activePage\" class=\"executorChangeContent\">\r\n        <div #container></div>\r\n      </div>\r\n      <div class=\"rightSteps\">\r\n        <mefdev-stage *ngFor=\"let page of pages; let pageIndex = index\"\r\n                      [isRightModal]=\"true\"\r\n                      [title]=\"page.title\"\r\n                      [currentExecutorStep]=\"pageIndex + 1\"\r\n                      [isCompleted]=\"page.isCompleted\">\r\n        </mefdev-stage>\r\n      </div>\r\n    </div>\r\n\r\n    <footer class=\"rightFooter\">\r\n      <ng-container [ngTemplateOutlet]=\"footer\"></ng-container>\r\n    </footer>\r\n  </div>\r\n\r\n</div>\r\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-executor.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/executors/step-executor/step-executor.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/executors/step-executor/step-executor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit, Component,\r\n    ContentChild, ElementRef,\r\n    EventEmitter, Input,\r\n    Output, Renderer2,\r\n    TemplateRef, ViewChild\r\n} from '@angular/core';\r\nimport { MefdevExecutorPageComponent } from '../mefdev-executor-page/mefdev-executor-page.component';\r\n\r\n/**\r\n * Wrapper component that represents a specific encapsulated executor.\r\n *\r\n * Example of usage:\r\n *```\r\n * <mefdev-step-executor #mainExecutor [view]=\"'regular'\">\r\n *\r\n *  <ng-template #title>\r\n *    <!-- Content for the executor title -->\r\n *  </ng-template>\r\n *  <ng-template #description>\r\n *    <!-- Content for the executor description -->\r\n *  </ng-template>\r\n *\r\n *  <mefdev-executor-page\r\n *     [title]=\"'Description of situation 1'\"\r\n *     [isActive]=\"mainExecutor.activePageInd === 0\"\r\n *     [isCompleted]=\"mainExecutor.activePageInd >= 0\">\r\n *      <!-- Content of the first executor step -->\r\n *  </mefdev-executor-page>\r\n *  <mefdev-executor-page\r\n *    [title]=\"'Description of situation 2'\"\r\n *    [isActive]=\"mainExecutor.activePageInd === 1\"\r\n *    [isCompleted]=\"mainExecutor.activePageInd >= 1\">\r\n *     <!-- Content of the second executor step -->\r\n *  </mefdev-executor-page>\r\n *  <mefdev-executor-page\r\n *    [title]=\"'Description of situation 3'\"\r\n *    [isActive]=\"mainExecutor.activePageInd === 2\"\r\n *    [isCompleted]=\"mainExecutor.activePageInd >= 2\">\r\n *      <!-- Content of the third executor step -->\r\n *  </mefdev-executor-page>\r\n *\r\n *  <ng-template #footer>\r\n *    <!-- Content for the executor footer -->\r\n *  <ng-template>\r\n *\r\n * </mefdev-step-executor>\r\n *\r\n *```\r\n */\r\n\r\n@Component({\r\n    selector: 'mefdev-step-executor',\r\n    templateUrl: './step-executor.component.html',\r\n    styleUrls: ['./step-executor.component.scss']\r\n})\r\n\r\nexport class StepExecutorComponent implements AfterViewInit {\r\n\r\n    /**\r\n     * Mandatory input parameter that specifies the type of the step-by-step wizard.\r\n     * It can have three options: regular, modal, right.\r\n     *\r\n     * @usageNotes\r\n     * ```\r\n     *  <mefdev-step-executor #mainExecutor [view]=\"'regular'\"></mefdev-step-executor>\r\n     * ```\r\n     */\r\n    @Input({required: true}) view: string;\r\n\r\n\r\n    /**\r\n     * ViewChild reference to the host executor content.\r\n     */\r\n    @ViewChild('container') container: ElementRef<HTMLElement>;\r\n\r\n    /**\r\n     * Template for displaying the content of the executor title.\r\n     *\r\n     * @usageNotes\r\n     * ```\r\n     * <ng-template #title>\r\n     *   <!-- Content for the executor title -->\r\n     * </ng-template>\r\n     * ```\r\n     */\r\n    @ContentChild('title') title: TemplateRef<void>;\r\n\r\n    /**\r\n     * Template for displaying the content of the executor description.\r\n     *\r\n     * @usageNotes\r\n     * ```\r\n     * <ng-template #description>\r\n     *  <!-- Content for the executor description -->\r\n     * </ng-template>\r\n     * ```\r\n     */\r\n    @ContentChild('description') description: TemplateRef<void>;\r\n\r\n\r\n    /**\r\n     * Template for displaying the content of the executor footer.\r\n     *\r\n     * @usageNotes\r\n     * ```\r\n     * <ng-template #footer>\r\n     *    <!-- Content for the executor footer -->\r\n     * </ng-template>\r\n     * ```\r\n     */\r\n    @ContentChild('footer') footer: TemplateRef<void>;\r\n\r\n    /**\r\n     * The output parameter that emits the class of the active page - active step.\r\n     *\r\n     * @usageNotes\r\n     * ```\r\n     *  <mefdev-step-executor #mainExecutor (onActivePageChange)=\"getActiveStep($event)\"></mefdev-step-executor>\r\n     * ```\r\n     */\r\n    @Output() onActivePageChange: EventEmitter<MefdevExecutorPageComponent> = new EventEmitter<MefdevExecutorPageComponent>();\r\n\r\n    public _activePageInd: number = 0;\r\n    public pages: MefdevExecutorPageComponent[] = [];\r\n\r\n    constructor(private renderer: Renderer2) {}\r\n\r\n    public set activePageInd(activePageNumber: number) {\r\n        this._activePageInd = activePageNumber;\r\n        if (activePageNumber >= 0 && this.container) {\r\n            if (this.container.nativeElement.innerHTML != '') {\r\n                this.container.nativeElement.innerHTML = '';\r\n            }\r\n            this.renderer.appendChild(this.container.nativeElement, this.activePage?.elRef.nativeElement);\r\n            this.onActivePageChange.emit(this.pages.find((el: MefdevExecutorPageComponent) => el.isActive));\r\n        }\r\n    }\r\n\r\n    public get activePageInd(): number {\r\n        return this._activePageInd;\r\n    }\r\n\r\n    get activePage(): MefdevExecutorPageComponent | null {\r\n        return this.activePageInd == -1 ? null : this.pages[this.activePageInd];\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this.renderer.appendChild(this.container.nativeElement, this.activePage?.elRef.nativeElement);\r\n        this.onActivePageChange.emit(this.pages.find((el: MefdevExecutorPageComponent) => el.isActive));\r\n    }\r\n\r\n    /**\r\n     * Check whether there is a next step of the executor. If we are at the last step - disable the 'next' button\r\n     */\r\n    nextBtnIsDisabled(): boolean {\r\n        return this._activePageInd === this.pages.length - 1;\r\n    }\r\n\r\n    /**\r\n     * Check whether there is a next step of the executor. If we are at the last step - disable the 'next' button\r\n     */\r\n    prev(): void {\r\n        const newPageInd = this.activePageInd - 1;\r\n        if (newPageInd >= 0) {\r\n            this.activePageInd = newPageInd;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Go back to the previous step\r\n     */\r\n    cancel(): void {\r\n        this.activePageInd = 0;\r\n        const newPageInd = this.activePageInd - 1;\r\n        if (newPageInd >= 0) {\r\n            this.activePageInd = newPageInd;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Go to the next step\r\n     */\r\n    next(): void {\r\n        const newPageInd = this.activePageInd + 1;\r\n        if (newPageInd < this.pages.length) {\r\n            this.activePageInd = newPageInd;\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Set a specific active page\r\n     */\r\n    setActivePage(pageNumber: number): void {\r\n        pageNumber -= 1;\r\n        if (pageNumber < this.pages.length && pageNumber >= 0) {\r\n            this.activePageInd = pageNumber;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Add new page\r\n     */\r\n    addPage(page: MefdevExecutorPageComponent): void {\r\n        this.pages.push(page);\r\n    }\r\n\r\n\r\n    /**\r\n     * Delete a specific page\r\n     */\r\n    removeSpecificPage(page: MefdevExecutorPageComponent): void {\r\n        const index: number = this.pages.indexOf(page);\r\n        if (index !== -1) {\r\n            this.pages.splice(index, 1);\r\n            if (index === this.activePageInd) {\r\n                this.prev();\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Delete a page by its index\r\n     */\r\n    removePageByIndex(index: number): void {\r\n        if (index >= 0 && index < this.pages.length) {\r\n            this.pages.splice(index, 1);\r\n            if (index === this.activePageInd) {\r\n                this.prev();\r\n            }\r\n        }\r\n\r\n    }\r\n\r\n\r\n}\r\n","<!--view == regular-->\r\n\r\n<div class=\"stepExecutorBlock\" *ngIf=\"view === 'regular'\">\r\n  <header class=\"stepExecutorHeader\">\r\n    <div class=\"stepExecutorHeaderText\">\r\n      <h1 class=\"title\">\r\n        <ng-container [ngTemplateOutlet]=\"title\"></ng-container>\r\n      </h1>\r\n      <p class=\"body-5\">\r\n        <ng-container [ngTemplateOutlet]=\"description\"></ng-container>\r\n      </p>\r\n    </div>\r\n    <div class=\"steps\">\r\n      <mefdev-stage *ngFor=\"let page of pages; let pageIndex = index\"\r\n                    [isRightModal]=\"false\"\r\n                    [title]=\"page.title\"\r\n                    [currentExecutorStep]=\"pageIndex + 1\"\r\n                    [isCompleted]=\"page.isCompleted\">\r\n      </mefdev-stage>\r\n    </div>\r\n  </header>\r\n\r\n  <div *ngIf=\"activePage\" class=\"executorChangeContent\">\r\n    <div #container></div>\r\n  </div>\r\n\r\n  <div class=\"footerButtons\">\r\n    <ng-container [ngTemplateOutlet]=\"footer\"></ng-container>\r\n  </div>\r\n</div>\r\n\r\n\r\n<!--view == modal-->\r\n\r\n<div class=\"modalStepExecutor\" *ngIf=\"view === 'modal'\">\r\n\r\n  <header class=\"modalHeader\">\r\n    <div class=\"headerModalText\">\r\n      <div class=\"textAndCloseButton\">\r\n        <h1 class=\"title\">\r\n          <ng-container [ngTemplateOutlet]=\"title\"></ng-container>\r\n        </h1>\r\n        <p class=\"body-5\">\r\n          <ng-container [ngTemplateOutlet]=\"description\"></ng-container>\r\n        </p>\r\n      </div>\r\n      <article class=\"closeBtn\">\r\n        <svg width=\"15\" height=\"15\" viewBox=\"0 0 15 15\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M6.26735 7.68135L0.610352 2.02435L2.02435 0.610352L7.68135 6.26735L13.3384 0.610352L14.7524 2.02435L9.09535 7.68135L14.7524 13.3384L13.3384 14.7524L7.68135 9.09535L2.02435 14.7524L0.610352 13.3384L6.26735 7.68135Z\" fill=\"#4D4D4D\"/>\r\n        </svg>\r\n      </article>\r\n    </div>\r\n    <div class=\"modalSteps\">\r\n      <mefdev-stage *ngFor=\"let page of pages; let pageIndex = index\"\r\n                    [isRightModal]=\"false\"\r\n                    [title]=\"page.title\"\r\n                    [currentExecutorStep]=\"pageIndex + 1\"\r\n                    [isCompleted]=\"page.isCompleted\">\r\n      </mefdev-stage>\r\n    </div>\r\n  </header>\r\n\r\n  <main *ngIf=\"activePage\" class=\"modalExecutorMainContent\">\r\n    <div #container></div>\r\n  </main>\r\n\r\n  <footer class=\"modalFooter\">\r\n    <ng-container [ngTemplateOutlet]=\"footer\"></ng-container>\r\n  </footer>\r\n\r\n</div>\r\n\r\n<!--view == right-->\r\n\r\n<div class=\"rightExecutorBlock\" *ngIf=\"view === 'right'\">\r\n\r\n  <header class=\"rightExecutorHeader\">\r\n    <div class=\"rightExecutorTextAndCloseButton\">\r\n      <span class=\"body-1\">\r\n        <ng-container [ngTemplateOutlet]=\"title\"></ng-container>\r\n      </span>\r\n      <p class=\"body-5\">\r\n        <ng-container [ngTemplateOutlet]=\"description\"></ng-container>\r\n      </p>\r\n    </div>\r\n    <div class=\"closeButton\">\r\n      <svg width=\"17\" height=\"17\" viewBox=\"0 0 17 17\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M16.0566 1.59971L14.6566 0.199707L8.05664 6.79971L1.45664 0.199707L0.0566406 1.59971L6.65664 8.19971L0.0566406 14.7997L1.45664 16.1997L8.05664 9.59971L14.6566 16.1997L16.0566 14.7997L9.45664 8.19971L16.0566 1.59971Z\" fill=\"#525252\"/>\r\n      </svg>\r\n    </div>\r\n  </header>\r\n\r\n  <div class=\"line\">\r\n    <svg width=\"363\" height=\"1\" viewBox=\"0 0 363 1\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <line x1=\"-4.37114e-08\" y1=\"0.5\" x2=\"362.674\" y2=\"0.499968\" stroke=\"#4D4D4D\"/>\r\n    </svg>\r\n  </div>\r\n\r\n  <div class=\"contentExecutor\">\r\n    <div class=\"rightChangeContent\">\r\n      <div *ngIf=\"activePage\" class=\"executorChangeContent\">\r\n        <div #container></div>\r\n      </div>\r\n      <div class=\"rightSteps\">\r\n        <mefdev-stage *ngFor=\"let page of pages; let pageIndex = index\"\r\n                      [isRightModal]=\"true\"\r\n                      [title]=\"page.title\"\r\n                      [currentExecutorStep]=\"pageIndex + 1\"\r\n                      [isCompleted]=\"page.isCompleted\">\r\n        </mefdev-stage>\r\n      </div>\r\n    </div>\r\n\r\n    <footer class=\"rightFooter\">\r\n      <ng-container [ngTemplateOutlet]=\"footer\"></ng-container>\r\n    </footer>\r\n  </div>\r\n\r\n</div>\r\n"]}
@@ -95,7 +95,7 @@ export class FillComponent {
95
95
  this.visibleChange.emit(this.visible);
96
96
  }
97
97
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FillComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
98
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: FillComponent, selector: "mefdev-fill-modal", inputs: { show: "show" }, outputs: { visibleChange: "visibleChange" }, queries: [{ propertyName: "modal_header", first: true, predicate: ["modal_header"], descendants: true }, { propertyName: "modal_footer", first: true, predicate: ["modal_footer"], descendants: true }], viewQueries: [{ propertyName: "dialog", first: true, predicate: ["dialog"], descendants: true }], ngImport: i0, template: "<button *ngIf=\"visible\" (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n<div [@dialog] *ngIf=\"visible\" class=\"dialog\" #dialog>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#ffffffd9;z-index:999}.dialog{z-index:1000;position:fixed;right:0;left:0;top:0;margin-left:auto;margin-right:auto;height:100%;min-height:200px;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;background-color:#ffffffd9;padding:12px;overflow-y:auto;display:flex;align-items:center}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;top:8px;right:8px;font-size:1.2em;z-index:1001}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
98
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: FillComponent, selector: "mefdev-fill-modal", inputs: { show: "show" }, outputs: { visibleChange: "visibleChange" }, queries: [{ propertyName: "modal_header", first: true, predicate: ["modal_header"], descendants: true }, { propertyName: "modal_footer", first: true, predicate: ["modal_footer"], descendants: true }], viewQueries: [{ propertyName: "dialog", first: true, predicate: ["dialog"], descendants: true }], ngImport: i0, template: "<button *ngIf=\"visible\" (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n<div [@dialog] *ngIf=\"visible\" class=\"dialog\" #dialog>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#ffffffd9;z-index:999}.dialog{z-index:1000;position:fixed;right:0;left:0;top:0;margin-left:auto;margin-right:auto;height:100%;min-height:200px;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;background-color:#ffffffd9;padding:12px;overflow-y:auto;display:flex;align-items:center}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;top:8px;right:8px;font-size:1.2em;z-index:1001}.modal-footer{padding-top:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
99
99
  trigger('dialog', [
100
100
  transition('void => *', [
101
101
  style({ transform: 'scale3d(.3, .3, .3)' }),
@@ -119,7 +119,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
119
119
  animate(100, style({ transform: 'scale3d(.0, .0, .0)' }))
120
120
  ])
121
121
  ])
122
- ], template: "<button *ngIf=\"visible\" (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n<div [@dialog] *ngIf=\"visible\" class=\"dialog\" #dialog>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#ffffffd9;z-index:999}.dialog{z-index:1000;position:fixed;right:0;left:0;top:0;margin-left:auto;margin-right:auto;height:100%;min-height:200px;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;background-color:#ffffffd9;padding:12px;overflow-y:auto;display:flex;align-items:center}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;top:8px;right:8px;font-size:1.2em;z-index:1001}\n"] }]
122
+ ], template: "<button *ngIf=\"visible\" (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n<div [@dialog] *ngIf=\"visible\" class=\"dialog\" #dialog>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#ffffffd9;z-index:999}.dialog{z-index:1000;position:fixed;right:0;left:0;top:0;margin-left:auto;margin-right:auto;height:100%;min-height:200px;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;background-color:#ffffffd9;padding:12px;overflow-y:auto;display:flex;align-items:center}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;top:8px;right:8px;font-size:1.2em;z-index:1001}.modal-footer{padding-top:10px}\n"] }]
123
123
  }], ctorParameters: function () { return []; }, propDecorators: { dialog: [{
124
124
  type: ViewChild,
125
125
  args: ['dialog', { static: false }]
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
134
134
  }], visibleChange: [{
135
135
  type: Output
136
136
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fill.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/modals/fill/fill.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/modals/fill/fill.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAc,YAAY,EAAE,KAAK,EAAU,MAAM,EAAe,SAAS,EAAE,MAAM,eAAe,CAAC;AAEjI,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;;;AAG1E;;;;;;;;;;;;;;;;;;;IAmBI;AAiBJ,MAAM,OAAO,aAAa;IACd,OAAO,GAAY,KAAK,CAAC;IAEe,MAAM,CAAc;IAGtE;;;;;;;;;MASE;IAC4B,YAAY,CAAoB;IAE9D;;;;;;;;;MASE;IAC4B,YAAY,CAAoB;IAE9D;;OAEG;IACH,IAAa,IAAI,CAAC,GAAY;QAC5B,IAAG,GAAG,EAAC;YACL,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;aACG;YACF,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;IAAA,CAAC;IAEF;;;;;;;OAOG;IACO,aAAa,GAAG,IAAI,YAAY,EAAW,CAAC;IAGtD,gBAAgB,CAAC;IAEjB,QAAQ;IACR,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;OAGG;IACI,SAAS;QACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAED;;;OAGG;IACI,SAAS;QACd,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;uGAlFU,aAAa;2FAAb,aAAa,2aCzC1B,uqBAeA,mxBDcc;YACV,OAAO,CAAC,QAAQ,EAAE;gBAChB,UAAU,CAAC,WAAW,EAAE;oBACtB,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC;oBAC3C,OAAO,CAAC,GAAG,CAAC;iBACb,CAAC;gBACF,UAAU,CAAC,WAAW,EAAE;oBACtB,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAC;iBAC1D,CAAC;aACH,CAAC;SACH;;2FAEU,aAAa;kBAhBzB,SAAS;+BACE,mBAAmB,cAGjB;wBACV,OAAO,CAAC,QAAQ,EAAE;4BAChB,UAAU,CAAC,WAAW,EAAE;gCACtB,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC;gCAC3C,OAAO,CAAC,GAAG,CAAC;6BACb,CAAC;4BACF,UAAU,CAAC,WAAW,EAAE;gCACtB,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAC;6BAC1D,CAAC;yBACH,CAAC;qBACH;0EAKiD,MAAM;sBAAvD,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAaR,YAAY;sBAAzC,YAAY;uBAAC,cAAc;gBAYE,YAAY;sBAAzC,YAAY;uBAAC,cAAc;gBAKf,IAAI;sBAAhB,KAAK;gBAiBI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, ContentChild, ElementRef, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { CommonModule } from \"@angular/common\"; // add for static analizer bug fix\r\nimport { animate, style, transition, trigger } from '@angular/animations';\r\n\r\n\r\n/**\r\n  * Fill Component for a modal window.\r\n  *\r\n  * Example of usage:\r\n  * ```\r\n  * <mefdev-fill-modal #pin_modal>\r\n  *   <!-- Modal header content -->\r\n  *   <ng-template #modal_header>\r\n  *     <!-- Header content goes here -->\r\n  *   </ng-template>\r\n  *\r\n  *   <!-- Modal footer content -->\r\n  *   <ng-template #modal_footer>\r\n  *     <!-- Footer content goes here -->\r\n  *   </ng-template>\r\n  * </mefdev-fill-modal>\r\n  * ```\r\n  *\r\n  * <example-url>https://mef.dev/ui_kit_demo/view/modals/fill</example-url>\r\n  */\r\n@Component({\r\n  selector: 'mefdev-fill-modal',\r\n  templateUrl: './fill.component.html',\r\n  styleUrls: ['./fill.component.scss'],\r\n  animations: [\r\n    trigger('dialog', [\r\n      transition('void => *', [\r\n        style({ transform: 'scale3d(.3, .3, .3)' }),\r\n        animate(100)\r\n      ]),\r\n      transition('* => void', [\r\n        animate(100, style({ transform: 'scale3d(.0, .0, .0)' }))\r\n      ])\r\n    ])\r\n  ]\r\n})\r\nexport class FillComponent implements OnInit {\r\n  protected visible: boolean = false;\r\n\r\n  @ViewChild('dialog', { static: false }) protected dialog?: ElementRef;\r\n\r\n\r\n  /**\r\n  * The header template of the modal window.\r\n  * ```\r\n  * <mefdev-fill-modal #pin_modal>\r\n   *   <ng-template #modal_header>\r\n   *     <!-- Header content goes here -->\r\n   *   </ng-template>\r\n   * </mefdev-fill-modal>\r\n  * ```\r\n  */\r\n  @ContentChild(\"modal_header\") modal_header: TemplateRef<void>;\r\n\r\n  /**\r\n  * The footer template of the modal window.\r\n  * ```\r\n  * <mefdev-fill-modal #pin_modal>\r\n   *   <ng-template #modal_footer>\r\n   *     <!-- Footer content goes here -->\r\n   *   </ng-template>\r\n   * </mefdev-fill-modal>\r\n  * ```\r\n  */\r\n  @ContentChild(\"modal_footer\") modal_footer: TemplateRef<void>;\r\n\r\n  /**\r\n   * Input parameter that determines whether to show the modal window.\r\n   */\r\n  @Input() set show(val: boolean){\r\n    if(val){\r\n      this.showModal();\r\n    }\r\n    else{\r\n      this.hideModal();\r\n    }\r\n  };\r\n\r\n  /**\r\n   * Event emitted when the modal is change state.\r\n   * Emits a boolean value indicating if the modal is closed(false), or open(true).\r\n   * Example:\r\n   * ```\r\n   * <mefdev-fill-modal (visibleChange)=\"onModalClosed($event)\"></mefdev-fill-modal>\r\n   * ```\r\n   */\r\n  @Output() visibleChange = new EventEmitter<boolean>();\r\n\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  /**\r\n   * Shows the modal state.\r\n   * Return a boolean value indicating if the modal is closed(false), or open(true)\r\n   */\r\n  getModalState(): boolean{\r\n    return this.visible;\r\n  }\r\n\r\n  /**\r\n   * Shows the modal.\r\n   * Call this method to open the modal window.\r\n   */\r\n  public showModal(){\r\n    this.visible = true;\r\n    this.visibleChange.emit(this.visible);\r\n  }\r\n\r\n  /**\r\n   * Hides the modal.\r\n   * Call this method to close the modal window.\r\n   */\r\n  public hideModal(){\r\n    this.visible = false;\r\n    this.visibleChange.emit(this.visible);\r\n  }\r\n}\r\n","<button *ngIf=\"visible\" (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n<div [@dialog] *ngIf=\"visible\" class=\"dialog\" #dialog>\r\n\t<div class=\"modal-content\">\r\n    <div class=\"modal-header clearfix text-left\">\r\n          <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n      </div>\r\n      <div class=\"modal-body\">\r\n          <ng-content></ng-content>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n          <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n      </div>\r\n  </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fill.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/modals/fill/fill.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/modals/fill/fill.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAc,YAAY,EAAE,KAAK,EAAU,MAAM,EAAe,SAAS,EAAE,MAAM,eAAe,CAAC;AAEjI,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;;;AAG1E;;;;;;;;;;;;;;;;;;;IAmBI;AAiBJ,MAAM,OAAO,aAAa;IACd,OAAO,GAAY,KAAK,CAAC;IAEe,MAAM,CAAc;IAGtE;;;;;;;;;MASE;IAC4B,YAAY,CAAoB;IAE9D;;;;;;;;;MASE;IAC4B,YAAY,CAAoB;IAE9D;;OAEG;IACH,IAAa,IAAI,CAAC,GAAY;QAC5B,IAAG,GAAG,EAAC;YACL,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;aACG;YACF,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;IAAA,CAAC;IAEF;;;;;;;OAOG;IACO,aAAa,GAAG,IAAI,YAAY,EAAW,CAAC;IAGtD,gBAAgB,CAAC;IAEjB,QAAQ;IACR,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;OAGG;IACI,SAAS;QACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAED;;;OAGG;IACI,SAAS;QACd,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;uGAlFU,aAAa;2FAAb,aAAa,2aCzC1B,uqBAeA,kzBDcc;YACV,OAAO,CAAC,QAAQ,EAAE;gBAChB,UAAU,CAAC,WAAW,EAAE;oBACtB,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC;oBAC3C,OAAO,CAAC,GAAG,CAAC;iBACb,CAAC;gBACF,UAAU,CAAC,WAAW,EAAE;oBACtB,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAC;iBAC1D,CAAC;aACH,CAAC;SACH;;2FAEU,aAAa;kBAhBzB,SAAS;+BACE,mBAAmB,cAGjB;wBACV,OAAO,CAAC,QAAQ,EAAE;4BAChB,UAAU,CAAC,WAAW,EAAE;gCACtB,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC;gCAC3C,OAAO,CAAC,GAAG,CAAC;6BACb,CAAC;4BACF,UAAU,CAAC,WAAW,EAAE;gCACtB,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAC;6BAC1D,CAAC;yBACH,CAAC;qBACH;0EAKiD,MAAM;sBAAvD,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAaR,YAAY;sBAAzC,YAAY;uBAAC,cAAc;gBAYE,YAAY;sBAAzC,YAAY;uBAAC,cAAc;gBAKf,IAAI;sBAAhB,KAAK;gBAiBI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, ContentChild, ElementRef, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { CommonModule } from \"@angular/common\"; // add for static analizer bug fix\r\nimport { animate, style, transition, trigger } from '@angular/animations';\r\n\r\n\r\n/**\r\n  * Fill Component for a modal window.\r\n  *\r\n  * Example of usage:\r\n  * ```\r\n  * <mefdev-fill-modal #pin_modal>\r\n  *   <!-- Modal header content -->\r\n  *   <ng-template #modal_header>\r\n  *     <!-- Header content goes here -->\r\n  *   </ng-template>\r\n  *\r\n  *   <!-- Modal footer content -->\r\n  *   <ng-template #modal_footer>\r\n  *     <!-- Footer content goes here -->\r\n  *   </ng-template>\r\n  * </mefdev-fill-modal>\r\n  * ```\r\n  *\r\n  * <example-url>https://mef.dev/ui_kit_demo/view/modals/fill</example-url>\r\n  */\r\n@Component({\r\n  selector: 'mefdev-fill-modal',\r\n  templateUrl: './fill.component.html',\r\n  styleUrls: ['./fill.component.scss'],\r\n  animations: [\r\n    trigger('dialog', [\r\n      transition('void => *', [\r\n        style({ transform: 'scale3d(.3, .3, .3)' }),\r\n        animate(100)\r\n      ]),\r\n      transition('* => void', [\r\n        animate(100, style({ transform: 'scale3d(.0, .0, .0)' }))\r\n      ])\r\n    ])\r\n  ]\r\n})\r\nexport class FillComponent implements OnInit {\r\n  protected visible: boolean = false;\r\n\r\n  @ViewChild('dialog', { static: false }) protected dialog?: ElementRef;\r\n\r\n\r\n  /**\r\n  * The header template of the modal window.\r\n  * ```\r\n  * <mefdev-fill-modal #pin_modal>\r\n   *   <ng-template #modal_header>\r\n   *     <!-- Header content goes here -->\r\n   *   </ng-template>\r\n   * </mefdev-fill-modal>\r\n  * ```\r\n  */\r\n  @ContentChild(\"modal_header\") modal_header: TemplateRef<void>;\r\n\r\n  /**\r\n  * The footer template of the modal window.\r\n  * ```\r\n  * <mefdev-fill-modal #pin_modal>\r\n   *   <ng-template #modal_footer>\r\n   *     <!-- Footer content goes here -->\r\n   *   </ng-template>\r\n   * </mefdev-fill-modal>\r\n  * ```\r\n  */\r\n  @ContentChild(\"modal_footer\") modal_footer: TemplateRef<void>;\r\n\r\n  /**\r\n   * Input parameter that determines whether to show the modal window.\r\n   */\r\n  @Input() set show(val: boolean){\r\n    if(val){\r\n      this.showModal();\r\n    }\r\n    else{\r\n      this.hideModal();\r\n    }\r\n  };\r\n\r\n  /**\r\n   * Event emitted when the modal is change state.\r\n   * Emits a boolean value indicating if the modal is closed(false), or open(true).\r\n   * Example:\r\n   * ```\r\n   * <mefdev-fill-modal (visibleChange)=\"onModalClosed($event)\"></mefdev-fill-modal>\r\n   * ```\r\n   */\r\n  @Output() visibleChange = new EventEmitter<boolean>();\r\n\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  /**\r\n   * Shows the modal state.\r\n   * Return a boolean value indicating if the modal is closed(false), or open(true)\r\n   */\r\n  getModalState(): boolean{\r\n    return this.visible;\r\n  }\r\n\r\n  /**\r\n   * Shows the modal.\r\n   * Call this method to open the modal window.\r\n   */\r\n  public showModal(){\r\n    this.visible = true;\r\n    this.visibleChange.emit(this.visible);\r\n  }\r\n\r\n  /**\r\n   * Hides the modal.\r\n   * Call this method to close the modal window.\r\n   */\r\n  public hideModal(){\r\n    this.visible = false;\r\n    this.visibleChange.emit(this.visible);\r\n  }\r\n}\r\n","<button *ngIf=\"visible\" (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n<div [@dialog] *ngIf=\"visible\" class=\"dialog\" #dialog>\r\n\t<div class=\"modal-content\">\r\n    <div class=\"modal-header clearfix text-left\">\r\n          <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n      </div>\r\n      <div class=\"modal-body\">\r\n          <ng-content></ng-content>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n          <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n      </div>\r\n  </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n"]}
@@ -79,7 +79,7 @@ export class SlideUpComponent {
79
79
  this.visibleChange.emit(this.visible);
80
80
  }
81
81
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SlideUpComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
82
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: SlideUpComponent, selector: "mefdev-slide-up-modal", inputs: { show: "show" }, outputs: { visibleChange: "visibleChange" }, queries: [{ propertyName: "modal_header", first: true, predicate: ["modal_header"], descendants: true }, { propertyName: "modal_footer", first: true, predicate: ["modal_footer"], descendants: true }], ngImport: i0, template: "<div [@dialog] *ngIf=\"visible\" class=\"dialog\">\r\n\t<button (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.dialog{z-index:1000;position:fixed;inset:50% 0;margin:auto;min-height:200px;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;background-color:#fff;padding:12px;box-shadow:0 7px 8px -4px #0003,0 13px 19px 2px #00000024,0 5px 24px 4px #0000001f}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;z-index:10002;top:8px;right:8px;font-size:1.2em}.modal-content .modal-footer{position:absolute;top:130px;right:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
82
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: SlideUpComponent, selector: "mefdev-slide-up-modal", inputs: { show: "show" }, outputs: { visibleChange: "visibleChange" }, queries: [{ propertyName: "modal_header", first: true, predicate: ["modal_header"], descendants: true }, { propertyName: "modal_footer", first: true, predicate: ["modal_footer"], descendants: true }], ngImport: i0, template: "<div [@dialog] *ngIf=\"visible\" class=\"dialog\">\r\n\t<button (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.dialog{z-index:1000;position:fixed;inset:50% 0;margin:auto;min-height:200px;max-height:90%;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;height:-moz-fit-content;height:fit-content;overflow:auto;background-color:#fff;padding:12px;box-shadow:0 7px 8px -4px #0003,0 13px 19px 2px #00000024,0 5px 24px 4px #0000001f}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;z-index:10002;top:8px;right:8px;font-size:1.2em}.modal-content .modal-body{min-height:120px;padding-bottom:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
83
83
  trigger('dialog', [
84
84
  transition('void => *', [
85
85
  style({ transform: 'scale3d(.3, .3, .3)' }),
@@ -103,7 +103,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
103
103
  animate(100, style({ transform: 'scale3d(.0, .0, .0)' }))
104
104
  ])
105
105
  ])
106
- ], template: "<div [@dialog] *ngIf=\"visible\" class=\"dialog\">\r\n\t<button (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.dialog{z-index:1000;position:fixed;inset:50% 0;margin:auto;min-height:200px;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;background-color:#fff;padding:12px;box-shadow:0 7px 8px -4px #0003,0 13px 19px 2px #00000024,0 5px 24px 4px #0000001f}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;z-index:10002;top:8px;right:8px;font-size:1.2em}.modal-content .modal-footer{position:absolute;top:130px;right:10px}\n"] }]
106
+ ], template: "<div [@dialog] *ngIf=\"visible\" class=\"dialog\">\r\n\t<button (click)=\"hideModal()\" aria-label=\"Close\" class=\"dialog__close-btn\">X</button>\r\n\t<div class=\"modal-content\">\r\n <div class=\"modal-header clearfix text-left\">\r\n <ng-template [ngTemplateOutlet]=\"modal_header\"></ng-template>\r\n </div>\r\n <div class=\"modal-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-template [ngTemplateOutlet]=\"modal_footer\"></ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n<div *ngIf=\"visible\" class=\"overlay\" (click)=\"hideModal()\"></div>\r\n", styles: [".overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.dialog{z-index:1000;position:fixed;inset:50% 0;margin:auto;min-height:200px;max-height:90%;min-width:520px;max-width:90%;width:-moz-fit-content;width:fit-content;height:-moz-fit-content;height:fit-content;overflow:auto;background-color:#fff;padding:12px;box-shadow:0 7px 8px -4px #0003,0 13px 19px 2px #00000024,0 5px 24px 4px #0000001f}.dialog__close-btn{border:0;background:none;color:#2d2d2d;position:absolute;z-index:10002;top:8px;right:8px;font-size:1.2em}.modal-content .modal-body{min-height:120px;padding-bottom:10px}\n"] }]
107
107
  }], ctorParameters: function () { return []; }, propDecorators: { modal_header: [{
108
108
  type: ContentChild,
109
109
  args: ["modal_header"]
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
115
115
  }], visibleChange: [{
116
116
  type: Output
117
117
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGUtdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvbW9kYWxzL3NsaWRlLXVwL3NsaWRlLXVwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L21vZGFscy9zbGlkZS11cC9zbGlkZS11cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBMEIsTUFBTSxlQUFlLENBQUM7QUFHckgsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7QUFFeEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUFtQkU7QUFpQkosTUFBTSxPQUFPLGdCQUFnQjtJQUNqQixPQUFPLEdBQVksS0FBSyxDQUFDO0lBQ25DOzs7T0FHRztJQUMyQixZQUFZLENBQW9CO0lBRTlEOzs7T0FHRztJQUMyQixZQUFZLENBQW9CO0lBQzlEOzs7T0FHRztJQUNILElBQWEsSUFBSSxDQUFDLEdBQVk7UUFDNUIsSUFBRyxHQUFHLEVBQUM7WUFDTCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDbEI7YUFDRztZQUNGLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNsQjtJQUNILENBQUM7SUFBQSxDQUFDO0lBRUY7OztPQUdHO0lBQ08sYUFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7SUFFdEQsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7SUFFRDs7O09BR0c7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRDs7O09BR0c7SUFDSSxTQUFTO1FBQ2QsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxTQUFTO1FBQ2QsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDckIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7dUdBN0RVLGdCQUFnQjsyRkFBaEIsZ0JBQWdCLDZVQ3pDN0IsK29CQWVBLDAwQkRjYztZQUNWLE9BQU8sQ0FBQyxRQUFRLEVBQUU7Z0JBQ2hCLFVBQVUsQ0FBQyxXQUFXLEVBQUU7b0JBQ3RCLEtBQUssQ0FBQyxFQUFFLFNBQVMsRUFBRSxxQkFBcUIsRUFBRSxDQUFDO29CQUMzQyxPQUFPLENBQUMsR0FBRyxDQUFDO2lCQUNiLENBQUM7Z0JBQ0YsVUFBVSxDQUFDLFdBQVcsRUFBRTtvQkFDdEIsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUUsQ0FBQyxDQUFDO2lCQUMxRCxDQUFDO2FBQ0gsQ0FBQztTQUNIOzsyRkFFVSxnQkFBZ0I7a0JBaEI1QixTQUFTOytCQUNFLHVCQUF1QixjQUdyQjt3QkFDVixPQUFPLENBQUMsUUFBUSxFQUFFOzRCQUNoQixVQUFVLENBQUMsV0FBVyxFQUFFO2dDQUN0QixLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUUsQ0FBQztnQ0FDM0MsT0FBTyxDQUFDLEdBQUcsQ0FBQzs2QkFDYixDQUFDOzRCQUNGLFVBQVUsQ0FBQyxXQUFXLEVBQUU7Z0NBQ3RCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsU0FBUyxFQUFFLHFCQUFxQixFQUFFLENBQUMsQ0FBQzs2QkFDMUQsQ0FBQzt5QkFDSCxDQUFDO3FCQUNIOzBFQVE2QixZQUFZO3NCQUF6QyxZQUFZO3VCQUFDLGNBQWM7Z0JBTUUsWUFBWTtzQkFBekMsWUFBWTt1QkFBQyxjQUFjO2dCQUtmLElBQUk7c0JBQWhCLEtBQUs7Z0JBYUksYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCwgVGVtcGxhdGVSZWYsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNb2RhbFNpemUgfSBmcm9tICcuLi9tb2RhbC1zaXplLmVudW0nO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7IC8vIGFkZCBmb3Igc3RhdGljIGFuYWxpemVyIGJ1ZyBmaXhcclxuaW1wb3J0IHsgYW5pbWF0ZSwgc3R5bGUsIHRyYW5zaXRpb24sIHRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcclxuXHJcbiAgLyoqXHJcbiAgKiBBIGNvbXBvbmVudCByZXByZXNlbnRpbmcgYSBzbGlkZS11cCBtb2RhbCB3aW5kb3cuXHJcbiAgKlxyXG4gICogRXhhbXBsZSBvZiB1c2FnZTpcclxuICAqXHJcbiAgKiBgYGBcclxuICAqIDxtZWZkZXYtc2xpZGUtdXAtbW9kYWwgW3Nob3ddPVwic2hvd01vZGFsXCI+XHJcbiAgKiAgIDxuZy10ZW1wbGF0ZSAjbW9kYWxfaGVhZGVyPlxyXG4gICogICAgIDxoND5Nb2RhbCBIZWFkZXI8L2g0PlxyXG4gICogICA8L25nLXRlbXBsYXRlPlxyXG4gICogICA8bmctdGVtcGxhdGUgI21vZGFsX2Zvb3Rlcj5cclxuICAqICAgICA8YnV0dG9uIChjbGljayk9XCJjbG9zZU1vZGFsKClcIj5DbG9zZTwvYnV0dG9uPlxyXG4gICogICA8L25nLXRlbXBsYXRlPlxyXG4gICogICA8ZGl2IGNsYXNzPVwibW9kYWwtYm9keVwiPlxyXG4gICogICAgIENvbnRlbnQgZ29lcyBoZXJlLi4uXHJcbiAgKiAgIDwvZGl2PlxyXG4gICogPC9tZWZkZXYtc2xpZGUtdXAtbW9kYWw+XHJcbiAgKiBgYGBcclxuICAqIDxleGFtcGxlLXVybD5odHRwczovL21lZi5kZXYvdWlfa2l0X2RlbW8vdmlldy9tb2RhbHMvc2xpZGUtdXA8L2V4YW1wbGUtdXJsPlxyXG4gICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LXNsaWRlLXVwLW1vZGFsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2xpZGUtdXAuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3NsaWRlLXVwLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgYW5pbWF0aW9uczogW1xyXG4gICAgdHJpZ2dlcignZGlhbG9nJywgW1xyXG4gICAgICB0cmFuc2l0aW9uKCd2b2lkID0+IConLCBbXHJcbiAgICAgICAgc3R5bGUoeyB0cmFuc2Zvcm06ICdzY2FsZTNkKC4zLCAuMywgLjMpJyB9KSxcclxuICAgICAgICBhbmltYXRlKDEwMClcclxuICAgICAgXSksXHJcbiAgICAgIHRyYW5zaXRpb24oJyogPT4gdm9pZCcsIFtcclxuICAgICAgICBhbmltYXRlKDEwMCwgc3R5bGUoeyB0cmFuc2Zvcm06ICdzY2FsZTNkKC4wLCAuMCwgLjApJyB9KSlcclxuICAgICAgXSlcclxuICAgIF0pXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2xpZGVVcENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHJvdGVjdGVkIHZpc2libGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAvKipcclxuICAgKiBSZWZlcmVuY2UgdG8gdGhlIHRlbXBsYXRlIGZvciB0aGUgbW9kYWwgaGVhZGVyLlxyXG4gICAqIFVzZSB0aGlzIHRlbXBsYXRlIHRvIGN1c3RvbWl6ZSB0aGUgaGVhZGVyIG9mIHRoZSBtb2RhbC5cclxuICAgKi9cclxuICBAQ29udGVudENoaWxkKFwibW9kYWxfaGVhZGVyXCIpIG1vZGFsX2hlYWRlcjogVGVtcGxhdGVSZWY8dm9pZD47XHJcblxyXG4gIC8qKlxyXG4gICAqIFJlZmVyZW5jZSB0byB0aGUgdGVtcGxhdGUgZm9yIHRoZSBtb2RhbCBmb290ZXIuXHJcbiAgICogVXNlIHRoaXMgdGVtcGxhdGUgdG8gY3VzdG9taXplIHRoZSBmb290ZXIgb2YgdGhlIG1vZGFsLlxyXG4gICAqL1xyXG4gIEBDb250ZW50Q2hpbGQoXCJtb2RhbF9mb290ZXJcIikgbW9kYWxfZm9vdGVyOiBUZW1wbGF0ZVJlZjx2b2lkPjtcclxuICAvKipcclxuICAgKiBGbGFnIGluZGljYXRpbmcgd2hldGhlciB0aGUgbW9kYWwgc2hvdWxkIGJlIHNob3duIG9yIGhpZGRlbi5cclxuICAgKiBTZXQgaXQgdG8gYHRydWVgIHRvIHNob3cgdGhlIG1vZGFsIGFuZCBgZmFsc2VgIHRvIGhpZGUgaXQuXHJcbiAgICovXHJcbiAgQElucHV0KCkgc2V0IHNob3codmFsOiBib29sZWFuKXtcclxuICAgIGlmKHZhbCl7XHJcbiAgICAgIHRoaXMuc2hvd01vZGFsKCk7XHJcbiAgICB9XHJcbiAgICBlbHNle1xyXG4gICAgICB0aGlzLmhpZGVNb2RhbCgpO1xyXG4gICAgfVxyXG4gIH07XHJcblxyXG4gIC8qKlxyXG4gICAqIEV2ZW50IGVtaXR0ZWQgd2hlbiB0aGUgbW9kYWwgaXMgY2hhbmdlIHN0YXRlLlxyXG4gICAqIEVtaXRzIGEgYm9vbGVhbiB2YWx1ZSBpbmRpY2F0aW5nIGlmIHRoZSBtb2RhbCBpcyBjbG9zZWQoZmFsc2UpLCBvciBvcGVuKHRydWUpLlxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSB2aXNpYmxlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNob3dzIHRoZSBtb2RhbCBzdGF0ZS5cclxuICAgKiBSZXR1cm4gYSBib29sZWFuIHZhbHVlIGluZGljYXRpbmcgaWYgdGhlIG1vZGFsIGlzIGNsb3NlZChmYWxzZSksIG9yIG9wZW4odHJ1ZSlcclxuICAgKi9cclxuICBnZXRNb2RhbFN0YXRlKCk6IGJvb2xlYW57XHJcbiAgICByZXR1cm4gdGhpcy52aXNpYmxlO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2hvd3MgdGhlIG1vZGFsLlxyXG4gICAqIENhbGwgdGhpcyBtZXRob2QgdG8gb3BlbiB0aGUgbW9kYWwgd2luZG93LlxyXG4gICAqL1xyXG4gIHB1YmxpYyBzaG93TW9kYWwoKXtcclxuICAgIHRoaXMudmlzaWJsZSA9IHRydWU7XHJcbiAgICB0aGlzLnZpc2libGVDaGFuZ2UuZW1pdCh0aGlzLnZpc2libGUpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogSGlkZXMgdGhlIG1vZGFsLlxyXG4gICAqIENhbGwgdGhpcyBtZXRob2QgdG8gY2xvc2UgdGhlIG1vZGFsIHdpbmRvdy5cclxuICAgKi9cclxuICBwdWJsaWMgaGlkZU1vZGFsKCl7XHJcbiAgICB0aGlzLnZpc2libGUgPSBmYWxzZTtcclxuICAgIHRoaXMudmlzaWJsZUNoYW5nZS5lbWl0KHRoaXMudmlzaWJsZSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgW0BkaWFsb2ddICpuZ0lmPVwidmlzaWJsZVwiIGNsYXNzPVwiZGlhbG9nXCI+XHJcblx0PGJ1dHRvbiAoY2xpY2spPVwiaGlkZU1vZGFsKClcIiBhcmlhLWxhYmVsPVwiQ2xvc2VcIiBjbGFzcz1cImRpYWxvZ19fY2xvc2UtYnRuXCI+WDwvYnV0dG9uPlxyXG5cdDxkaXYgY2xhc3M9XCJtb2RhbC1jb250ZW50XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwibW9kYWwtaGVhZGVyIGNsZWFyZml4IHRleHQtbGVmdFwiPlxyXG4gICAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIm1vZGFsX2hlYWRlclwiPjwvbmctdGVtcGxhdGU+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8ZGl2IGNsYXNzPVwibW9kYWwtYm9keVwiPlxyXG4gICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgICA8L2Rpdj5cclxuICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxyXG4gICAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIm1vZGFsX2Zvb3RlclwiPjwvbmctdGVtcGxhdGU+XHJcbiAgICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuPGRpdiAqbmdJZj1cInZpc2libGVcIiBjbGFzcz1cIm92ZXJsYXlcIiAoY2xpY2spPVwiaGlkZU1vZGFsKClcIj48L2Rpdj5cclxuIl19
118
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGUtdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvbW9kYWxzL3NsaWRlLXVwL3NsaWRlLXVwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L21vZGFscy9zbGlkZS11cC9zbGlkZS11cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBMEIsTUFBTSxlQUFlLENBQUM7QUFHckgsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7QUFFeEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUFtQkU7QUFpQkosTUFBTSxPQUFPLGdCQUFnQjtJQUNqQixPQUFPLEdBQVksS0FBSyxDQUFDO0lBQ25DOzs7T0FHRztJQUMyQixZQUFZLENBQW9CO0lBRTlEOzs7T0FHRztJQUMyQixZQUFZLENBQW9CO0lBQzlEOzs7T0FHRztJQUNILElBQWEsSUFBSSxDQUFDLEdBQVk7UUFDNUIsSUFBRyxHQUFHLEVBQUM7WUFDTCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDbEI7YUFDRztZQUNGLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNsQjtJQUNILENBQUM7SUFBQSxDQUFDO0lBRUY7OztPQUdHO0lBQ08sYUFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7SUFFdEQsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7SUFFRDs7O09BR0c7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRDs7O09BR0c7SUFDSSxTQUFTO1FBQ2QsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxTQUFTO1FBQ2QsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDckIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7dUdBN0RVLGdCQUFnQjsyRkFBaEIsZ0JBQWdCLDZVQ3pDN0IsK29CQWVBLDg0QkRjYztZQUNWLE9BQU8sQ0FBQyxRQUFRLEVBQUU7Z0JBQ2hCLFVBQVUsQ0FBQyxXQUFXLEVBQUU7b0JBQ3RCLEtBQUssQ0FBQyxFQUFFLFNBQVMsRUFBRSxxQkFBcUIsRUFBRSxDQUFDO29CQUMzQyxPQUFPLENBQUMsR0FBRyxDQUFDO2lCQUNiLENBQUM7Z0JBQ0YsVUFBVSxDQUFDLFdBQVcsRUFBRTtvQkFDdEIsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUUsQ0FBQyxDQUFDO2lCQUMxRCxDQUFDO2FBQ0gsQ0FBQztTQUNIOzsyRkFFVSxnQkFBZ0I7a0JBaEI1QixTQUFTOytCQUNFLHVCQUF1QixjQUdyQjt3QkFDVixPQUFPLENBQUMsUUFBUSxFQUFFOzRCQUNoQixVQUFVLENBQUMsV0FBVyxFQUFFO2dDQUN0QixLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUUsQ0FBQztnQ0FDM0MsT0FBTyxDQUFDLEdBQUcsQ0FBQzs2QkFDYixDQUFDOzRCQUNGLFVBQVUsQ0FBQyxXQUFXLEVBQUU7Z0NBQ3RCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsU0FBUyxFQUFFLHFCQUFxQixFQUFFLENBQUMsQ0FBQzs2QkFDMUQsQ0FBQzt5QkFDSCxDQUFDO3FCQUNIOzBFQVE2QixZQUFZO3NCQUF6QyxZQUFZO3VCQUFDLGNBQWM7Z0JBTUUsWUFBWTtzQkFBekMsWUFBWTt1QkFBQyxjQUFjO2dCQUtmLElBQUk7c0JBQWhCLEtBQUs7Z0JBYUksYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCwgVGVtcGxhdGVSZWYsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNb2RhbFNpemUgfSBmcm9tICcuLi9tb2RhbC1zaXplLmVudW0nO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7IC8vIGFkZCBmb3Igc3RhdGljIGFuYWxpemVyIGJ1ZyBmaXhcclxuaW1wb3J0IHsgYW5pbWF0ZSwgc3R5bGUsIHRyYW5zaXRpb24sIHRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcclxuXHJcbiAgLyoqXHJcbiAgKiBBIGNvbXBvbmVudCByZXByZXNlbnRpbmcgYSBzbGlkZS11cCBtb2RhbCB3aW5kb3cuXHJcbiAgKlxyXG4gICogRXhhbXBsZSBvZiB1c2FnZTpcclxuICAqXHJcbiAgKiBgYGBcclxuICAqIDxtZWZkZXYtc2xpZGUtdXAtbW9kYWwgW3Nob3ddPVwic2hvd01vZGFsXCI+XHJcbiAgKiAgIDxuZy10ZW1wbGF0ZSAjbW9kYWxfaGVhZGVyPlxyXG4gICogICAgIDxoND5Nb2RhbCBIZWFkZXI8L2g0PlxyXG4gICogICA8L25nLXRlbXBsYXRlPlxyXG4gICogICA8bmctdGVtcGxhdGUgI21vZGFsX2Zvb3Rlcj5cclxuICAqICAgICA8YnV0dG9uIChjbGljayk9XCJjbG9zZU1vZGFsKClcIj5DbG9zZTwvYnV0dG9uPlxyXG4gICogICA8L25nLXRlbXBsYXRlPlxyXG4gICogICA8ZGl2IGNsYXNzPVwibW9kYWwtYm9keVwiPlxyXG4gICogICAgIENvbnRlbnQgZ29lcyBoZXJlLi4uXHJcbiAgKiAgIDwvZGl2PlxyXG4gICogPC9tZWZkZXYtc2xpZGUtdXAtbW9kYWw+XHJcbiAgKiBgYGBcclxuICAqIDxleGFtcGxlLXVybD5odHRwczovL21lZi5kZXYvdWlfa2l0X2RlbW8vdmlldy9tb2RhbHMvc2xpZGUtdXA8L2V4YW1wbGUtdXJsPlxyXG4gICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LXNsaWRlLXVwLW1vZGFsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2xpZGUtdXAuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3NsaWRlLXVwLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgYW5pbWF0aW9uczogW1xyXG4gICAgdHJpZ2dlcignZGlhbG9nJywgW1xyXG4gICAgICB0cmFuc2l0aW9uKCd2b2lkID0+IConLCBbXHJcbiAgICAgICAgc3R5bGUoeyB0cmFuc2Zvcm06ICdzY2FsZTNkKC4zLCAuMywgLjMpJyB9KSxcclxuICAgICAgICBhbmltYXRlKDEwMClcclxuICAgICAgXSksXHJcbiAgICAgIHRyYW5zaXRpb24oJyogPT4gdm9pZCcsIFtcclxuICAgICAgICBhbmltYXRlKDEwMCwgc3R5bGUoeyB0cmFuc2Zvcm06ICdzY2FsZTNkKC4wLCAuMCwgLjApJyB9KSlcclxuICAgICAgXSlcclxuICAgIF0pXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2xpZGVVcENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHJvdGVjdGVkIHZpc2libGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAvKipcclxuICAgKiBSZWZlcmVuY2UgdG8gdGhlIHRlbXBsYXRlIGZvciB0aGUgbW9kYWwgaGVhZGVyLlxyXG4gICAqIFVzZSB0aGlzIHRlbXBsYXRlIHRvIGN1c3RvbWl6ZSB0aGUgaGVhZGVyIG9mIHRoZSBtb2RhbC5cclxuICAgKi9cclxuICBAQ29udGVudENoaWxkKFwibW9kYWxfaGVhZGVyXCIpIG1vZGFsX2hlYWRlcjogVGVtcGxhdGVSZWY8dm9pZD47XHJcblxyXG4gIC8qKlxyXG4gICAqIFJlZmVyZW5jZSB0byB0aGUgdGVtcGxhdGUgZm9yIHRoZSBtb2RhbCBmb290ZXIuXHJcbiAgICogVXNlIHRoaXMgdGVtcGxhdGUgdG8gY3VzdG9taXplIHRoZSBmb290ZXIgb2YgdGhlIG1vZGFsLlxyXG4gICAqL1xyXG4gIEBDb250ZW50Q2hpbGQoXCJtb2RhbF9mb290ZXJcIikgbW9kYWxfZm9vdGVyOiBUZW1wbGF0ZVJlZjx2b2lkPjtcclxuICAvKipcclxuICAgKiBGbGFnIGluZGljYXRpbmcgd2hldGhlciB0aGUgbW9kYWwgc2hvdWxkIGJlIHNob3duIG9yIGhpZGRlbi5cclxuICAgKiBTZXQgaXQgdG8gYHRydWVgIHRvIHNob3cgdGhlIG1vZGFsIGFuZCBgZmFsc2VgIHRvIGhpZGUgaXQuXHJcbiAgICovXHJcbiAgQElucHV0KCkgc2V0IHNob3codmFsOiBib29sZWFuKXtcclxuICAgIGlmKHZhbCl7XHJcbiAgICAgIHRoaXMuc2hvd01vZGFsKCk7XHJcbiAgICB9XHJcbiAgICBlbHNle1xyXG4gICAgICB0aGlzLmhpZGVNb2RhbCgpO1xyXG4gICAgfVxyXG4gIH07XHJcblxyXG4gIC8qKlxyXG4gICAqIEV2ZW50IGVtaXR0ZWQgd2hlbiB0aGUgbW9kYWwgaXMgY2hhbmdlIHN0YXRlLlxyXG4gICAqIEVtaXRzIGEgYm9vbGVhbiB2YWx1ZSBpbmRpY2F0aW5nIGlmIHRoZSBtb2RhbCBpcyBjbG9zZWQoZmFsc2UpLCBvciBvcGVuKHRydWUpLlxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSB2aXNpYmxlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNob3dzIHRoZSBtb2RhbCBzdGF0ZS5cclxuICAgKiBSZXR1cm4gYSBib29sZWFuIHZhbHVlIGluZGljYXRpbmcgaWYgdGhlIG1vZGFsIGlzIGNsb3NlZChmYWxzZSksIG9yIG9wZW4odHJ1ZSlcclxuICAgKi9cclxuICBnZXRNb2RhbFN0YXRlKCk6IGJvb2xlYW57XHJcbiAgICByZXR1cm4gdGhpcy52aXNpYmxlO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2hvd3MgdGhlIG1vZGFsLlxyXG4gICAqIENhbGwgdGhpcyBtZXRob2QgdG8gb3BlbiB0aGUgbW9kYWwgd2luZG93LlxyXG4gICAqL1xyXG4gIHB1YmxpYyBzaG93TW9kYWwoKXtcclxuICAgIHRoaXMudmlzaWJsZSA9IHRydWU7XHJcbiAgICB0aGlzLnZpc2libGVDaGFuZ2UuZW1pdCh0aGlzLnZpc2libGUpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogSGlkZXMgdGhlIG1vZGFsLlxyXG4gICAqIENhbGwgdGhpcyBtZXRob2QgdG8gY2xvc2UgdGhlIG1vZGFsIHdpbmRvdy5cclxuICAgKi9cclxuICBwdWJsaWMgaGlkZU1vZGFsKCl7XHJcbiAgICB0aGlzLnZpc2libGUgPSBmYWxzZTtcclxuICAgIHRoaXMudmlzaWJsZUNoYW5nZS5lbWl0KHRoaXMudmlzaWJsZSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgW0BkaWFsb2ddICpuZ0lmPVwidmlzaWJsZVwiIGNsYXNzPVwiZGlhbG9nXCI+XHJcblx0PGJ1dHRvbiAoY2xpY2spPVwiaGlkZU1vZGFsKClcIiBhcmlhLWxhYmVsPVwiQ2xvc2VcIiBjbGFzcz1cImRpYWxvZ19fY2xvc2UtYnRuXCI+WDwvYnV0dG9uPlxyXG5cdDxkaXYgY2xhc3M9XCJtb2RhbC1jb250ZW50XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwibW9kYWwtaGVhZGVyIGNsZWFyZml4IHRleHQtbGVmdFwiPlxyXG4gICAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIm1vZGFsX2hlYWRlclwiPjwvbmctdGVtcGxhdGU+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8ZGl2IGNsYXNzPVwibW9kYWwtYm9keVwiPlxyXG4gICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgICA8L2Rpdj5cclxuICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxyXG4gICAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIm1vZGFsX2Zvb3RlclwiPjwvbmctdGVtcGxhdGU+XHJcbiAgICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuPGRpdiAqbmdJZj1cInZpc2libGVcIiBjbGFzcz1cIm92ZXJsYXlcIiAoY2xpY2spPVwiaGlkZU1vZGFsKClcIj48L2Rpdj5cclxuIl19
@@ -0,0 +1,3 @@
1
+ export * from './slider/slider.component';
2
+ export * from './slider.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1raXQtbGliL3NyYy9saWIvbWFya3VwLWtpdC9zbGlkZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQTtBQUN6QyxjQUFjLGlCQUFpQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zbGlkZXIvc2xpZGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9zbGlkZXIubW9kdWxlJ1xyXG4iXX0=
@@ -0,0 +1,120 @@
1
+ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/forms";
4
+ /**
5
+ * Component for a slider that allows selecting a range of values.
6
+ * @example
7
+ * <mefdev-slider
8
+ * [disabled]="false"
9
+ * [range] = "{min: 1, max: 10000}"
10
+ * [id]= "'slider1'"
11
+ * (valueChange)="onChildValueChange($event)"
12
+ * ></mefdev-slider>
13
+ *
14
+ * <example-url>https://mef.dev/ui_kit_demo/view/typography/slider</example-url>
15
+ */
16
+ export class MefDevSliderComponent {
17
+ _range = { min: 1, max: 1000 };
18
+ /**
19
+ * Unique id for each slider. Use it, if u need more than one slider independent from another on the same page.
20
+ * @example
21
+ * <mefdev-slider
22
+ * [id]= "'slider1'"
23
+ * ></mefdev-slider>
24
+ */
25
+ id;
26
+ /**
27
+ * Input Object {min, max} container of the slider
28
+ * @example
29
+ * @interval
30
+ * <mefdev-slider
31
+ * [range] = "{min: 1, max: 10000}"
32
+ * ></mefdev-slider>
33
+ */
34
+ set range(range) {
35
+ this._range = range;
36
+ this.minValue = range.min;
37
+ this.maxValue = range.max;
38
+ }
39
+ get range() {
40
+ return this._range;
41
+ }
42
+ /**
43
+ * The minimum value of the slider.
44
+ */
45
+ minValue = this.range.min;
46
+ /**
47
+ * The maximum value of the slider.
48
+ */
49
+ maxValue = this.range.max;
50
+ /**
51
+ * Property indicating whether the component is disabled.
52
+ * @example
53
+ * <mefdev-slider
54
+ * [disabled]="true"
55
+ * ></mefdev-slider>
56
+ */
57
+ disabled = false;
58
+ /**
59
+ * Event emitted when the values of the slider change.
60
+ * It passes an object with `minValue` and `maxValue` properties.
61
+ * @event MefDevSliderComponent#valueChange
62
+ * @type {EventEmitter<{ minValue: number; maxValue: number }>}
63
+ * @example
64
+ * <mefdev-slider
65
+ * (valueChange)="onChildValueChange($event)"
66
+ * ></mefdev-slider>
67
+ */
68
+ valueChange = new EventEmitter();
69
+ /**
70
+ * Method called when the values of the slider change.
71
+ * Emits the `valueChange` event and calls methods to handle changes in the minimum and maximum values.
72
+ * @fires MefDevSliderComponent#valueChange
73
+ */
74
+ onValueChange() {
75
+ this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });
76
+ this.minValue = this.minValue;
77
+ this.onMinValueChange();
78
+ this.onMaxValueChange();
79
+ }
80
+ /**
81
+ * Method to handle changes in the minimum value.
82
+ * Converts a string to a number and removes all non-numeric characters.
83
+ * Then, emits the `valueChange` event and updates the value of the "fromSlider" slider.
84
+ * @fires MefDevSliderComponent#valueChange
85
+ */
86
+ onMinValueChange() {
87
+ const numericValue = parseFloat(this.minValue.toString().replace(/[^\d.]/g, ''));
88
+ this.minValue = isNaN(numericValue) ? 0 : numericValue;
89
+ this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });
90
+ const fromSlider = document.getElementById(`fromSlider-${this.id}`);
91
+ }
92
+ /**
93
+ * Method to handle changes in the maximum value.
94
+ * Converts a string to a number and removes all non-numeric characters.
95
+ * Then, emits the `valueChange` event and updates the value of the "toSlider" slider.
96
+ * @fires MefDevSliderComponent#valueChange
97
+ */
98
+ onMaxValueChange() {
99
+ const numericValue = parseFloat(this.maxValue.toString().replace(/[^\d.]/g, ''));
100
+ this.maxValue = isNaN(numericValue) ? 0 : numericValue; // Перевірка на NaN і присвоєння 0, якщо не вдалося конвертувати в число
101
+ this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });
102
+ const toSlider = document.getElementById(`toSlider-${this.id}`);
103
+ }
104
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: MefDevSliderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
105
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: MefDevSliderComponent, selector: "mefdev-slider", inputs: { id: "id", range: "range", disabled: "disabled" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<div class=\"range_container row\">\r\n <div class=\"inputs_control \">\r\n <input class=\"form_control_container__time__input h3\" [(ngModel)]=\"'\u20B4'+ minValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMinValueChange()\">\r\n <input class=\"form_control_container__time__input h3\" [(ngModel)]=\"'\u20B4'+ maxValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMaxValueChange()\">\r\n </div>\r\n <div class=\"sliders_control\">\r\n <input id=\"fromSlider\" type=\"range\" [(ngModel)]=\"minValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\">\r\n <input id=\"toSlider\" type=\"range\" [(ngModel)]=\"maxValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\" \r\n [style]=\"{'--minValue': minValue, '--maxValue': maxValue, '--minFromValue': range.min, '--maxToValue': range.max}\">\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.color-Dark-Gray-1{color:#373737!important}.color-Dark-Gray-2{color:#4d4d4d!important}.color-Red{color:#cf0106!important}.color-Green{color:#28b446!important}.color-Light-Gray-1{color:#929292!important}.color-Light-Gray-2{color:#eaeaea!important}.color-Light-Gray-3{color:#f3f3f3!important}.color-White{color:#fff!important}.color-Link{color:#0185cf!important}.b-color-Dark-Gray-1{background-color:#373737!important}.b-color-Dark-Gray-2{background-color:#4d4d4d!important}.b-color-Red{background-color:#cf0106!important}.b-color-Green{background-color:#28b446!important}.b-color-Light-Gray-1{background-color:#929292!important}.b-color-Light-Gray-2{background-color:#eaeaea!important}.b-color-Light-Gray-3{background-color:#f3f3f3!important}.b-color-White{background-color:#fff!important}.b-color-Link{background-color:#0185cf!important}.h1,h1{font-family:Montserrat;font-size:24px;line-height:29px;font-weight:700;text-transform:uppercase;color:#000}.h2,h2{font-family:Montserrat;font-size:24px;line-height:29px;font-weight:700;color:#000}.h3,h3{font-family:Montserrat;font-size:14px;line-height:20px;font-weight:400;text-transform:uppercase;color:#000}.h4,h4{font-family:Montserrat;font-weight:300;font-size:13px;line-height:20px;text-transform:uppercase;color:#000}.h5,h5{font-family:Montserrat;font-weight:600;font-size:13px;line-height:20px;color:#000}.h6,h6{font-family:Montserrat;font-weight:500;font-size:12px;line-height:20px;text-transform:capitalize;color:#000}.body-1,body-1{font-family:Lato;font-size:18px;line-height:20px;font-weight:700;color:#000}.body-2,body-2{font-family:Lato;font-size:16px;line-height:28px;font-weight:400;color:#000}.body-3,body-3{font-family:Lato;font-size:14px;line-height:22px;font-weight:700;color:#000}.body-4,body-4{font-family:Lato;font-size:14px;line-height:22px;font-weight:400;color:#000}.body-5,body-5{font-family:Lato;font-weight:600;font-size:13px;line-height:18px;color:#000}.body-6,body-6{font-family:Lato;font-size:13px;line-height:16px;font-weight:400;color:#000}.sliders_control{position:relative;min-height:50px}.inputs_control{position:relative;display:flex;justify-content:space-between;font-size:24px;color:#635a5a}.inputs_control .form_control_container__time__input{width:80px;height:28px;border-radius:5px;border:none;background:#FFF;text-align:center;box-shadow:2px 2px 2px #0000001a}#fromSlider::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:all;width:16px;height:16px;background-color:#cf0106;border-radius:50%;cursor:pointer;margin-top:13px}#toSlider::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:all;width:16px;height:16px;background-color:#cf0106;border-radius:50%;cursor:pointer;margin-top:-7px}input[type=range]::-moz-range-thumb{pointer-events:all;width:16px;height:16px;background-color:#cf0106;border-radius:50%;cursor:pointer}input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(to right,#929292 0%,#929292 calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 100%);height:3px}input[type=range]::-moz-range-track{background:linear-gradient(to right,#929292 0%,#929292 calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 100%);height:3px}input[type=range]::-webkit-slider-thumb:active{box-shadow:inset 0 0 3px #cf0106,0 0 9px #cf0106;-webkit-box-shadow:inset 0 0 3px #CF0106,0 0 9px #CF0106}input[type=number]{color:red;width:50px;height:30px;font-size:20px;border:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:.2}input[type=range]{-webkit-appearance:none;appearance:none;height:3px;width:100%;position:relative;background-color:#cf0106;pointer-events:none}input[type=range]::-moz-range-progress{background-color:transparent;height:3px}#fromSlider{height:0;z-index:9999}\n"], dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.RangeValueAccessor, selector: "input[type=range][formControlName],input[type=range][formControl],input[type=range][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: MefDevSliderComponent, decorators: [{
108
+ type: Component,
109
+ args: [{ selector: 'mefdev-slider', template: "<div class=\"range_container row\">\r\n <div class=\"inputs_control \">\r\n <input class=\"form_control_container__time__input h3\" [(ngModel)]=\"'\u20B4'+ minValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMinValueChange()\">\r\n <input class=\"form_control_container__time__input h3\" [(ngModel)]=\"'\u20B4'+ maxValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMaxValueChange()\">\r\n </div>\r\n <div class=\"sliders_control\">\r\n <input id=\"fromSlider\" type=\"range\" [(ngModel)]=\"minValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\">\r\n <input id=\"toSlider\" type=\"range\" [(ngModel)]=\"maxValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\" \r\n [style]=\"{'--minValue': minValue, '--maxValue': maxValue, '--minFromValue': range.min, '--maxToValue': range.max}\">\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.color-Dark-Gray-1{color:#373737!important}.color-Dark-Gray-2{color:#4d4d4d!important}.color-Red{color:#cf0106!important}.color-Green{color:#28b446!important}.color-Light-Gray-1{color:#929292!important}.color-Light-Gray-2{color:#eaeaea!important}.color-Light-Gray-3{color:#f3f3f3!important}.color-White{color:#fff!important}.color-Link{color:#0185cf!important}.b-color-Dark-Gray-1{background-color:#373737!important}.b-color-Dark-Gray-2{background-color:#4d4d4d!important}.b-color-Red{background-color:#cf0106!important}.b-color-Green{background-color:#28b446!important}.b-color-Light-Gray-1{background-color:#929292!important}.b-color-Light-Gray-2{background-color:#eaeaea!important}.b-color-Light-Gray-3{background-color:#f3f3f3!important}.b-color-White{background-color:#fff!important}.b-color-Link{background-color:#0185cf!important}.h1,h1{font-family:Montserrat;font-size:24px;line-height:29px;font-weight:700;text-transform:uppercase;color:#000}.h2,h2{font-family:Montserrat;font-size:24px;line-height:29px;font-weight:700;color:#000}.h3,h3{font-family:Montserrat;font-size:14px;line-height:20px;font-weight:400;text-transform:uppercase;color:#000}.h4,h4{font-family:Montserrat;font-weight:300;font-size:13px;line-height:20px;text-transform:uppercase;color:#000}.h5,h5{font-family:Montserrat;font-weight:600;font-size:13px;line-height:20px;color:#000}.h6,h6{font-family:Montserrat;font-weight:500;font-size:12px;line-height:20px;text-transform:capitalize;color:#000}.body-1,body-1{font-family:Lato;font-size:18px;line-height:20px;font-weight:700;color:#000}.body-2,body-2{font-family:Lato;font-size:16px;line-height:28px;font-weight:400;color:#000}.body-3,body-3{font-family:Lato;font-size:14px;line-height:22px;font-weight:700;color:#000}.body-4,body-4{font-family:Lato;font-size:14px;line-height:22px;font-weight:400;color:#000}.body-5,body-5{font-family:Lato;font-weight:600;font-size:13px;line-height:18px;color:#000}.body-6,body-6{font-family:Lato;font-size:13px;line-height:16px;font-weight:400;color:#000}.sliders_control{position:relative;min-height:50px}.inputs_control{position:relative;display:flex;justify-content:space-between;font-size:24px;color:#635a5a}.inputs_control .form_control_container__time__input{width:80px;height:28px;border-radius:5px;border:none;background:#FFF;text-align:center;box-shadow:2px 2px 2px #0000001a}#fromSlider::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:all;width:16px;height:16px;background-color:#cf0106;border-radius:50%;cursor:pointer;margin-top:13px}#toSlider::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:all;width:16px;height:16px;background-color:#cf0106;border-radius:50%;cursor:pointer;margin-top:-7px}input[type=range]::-moz-range-thumb{pointer-events:all;width:16px;height:16px;background-color:#cf0106;border-radius:50%;cursor:pointer}input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(to right,#929292 0%,#929292 calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 100%);height:3px}input[type=range]::-moz-range-track{background:linear-gradient(to right,#929292 0%,#929292 calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--minValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),transparent calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 calc((var(--maxValue) - var(--minFromValue)) / (var(--maxToValue) - var(--minFromValue)) * 100%),#929292 100%);height:3px}input[type=range]::-webkit-slider-thumb:active{box-shadow:inset 0 0 3px #cf0106,0 0 9px #cf0106;-webkit-box-shadow:inset 0 0 3px #CF0106,0 0 9px #CF0106}input[type=number]{color:red;width:50px;height:30px;font-size:20px;border:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:.2}input[type=range]{-webkit-appearance:none;appearance:none;height:3px;width:100%;position:relative;background-color:#cf0106;pointer-events:none}input[type=range]::-moz-range-progress{background-color:transparent;height:3px}#fromSlider{height:0;z-index:9999}\n"] }]
110
+ }], propDecorators: { id: [{
111
+ type: Input
112
+ }], range: [{
113
+ type: Input,
114
+ args: ['range']
115
+ }], disabled: [{
116
+ type: Input
117
+ }], valueChange: [{
118
+ type: Output
119
+ }] } });
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/slider/slider/slider.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/slider/slider/slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;;;AAEvE;;;;;;;;;;;EAWE;AAMF,MAAM,OAAO,qBAAqB;IAExB,MAAM,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;IAEvC;;;;;;MAME;IACO,EAAE,CAAS;IAGpB;;;;;;;MAOE;IACF,IAEI,KAAK,CAAC,KAAmC;QAC3C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC;IAC5B,CAAC;IACD,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;MAEE;IACF,QAAQ,GAAU,IAAI,CAAC,KAAK,CAAC,GAAG,CAAA;IAEhC;;MAEE;IACF,QAAQ,GAAU,IAAI,CAAC,KAAK,CAAC,GAAG,CAAA;IAIhC;;;;;;MAME;IACO,QAAQ,GAAY,KAAK,CAAC;IAEnC;;;;;;;;;MASE;IACQ,WAAW,GAAyD,IAAI,YAAY,EAAE,CAAC;IAEjG;;;;MAIE;IACF,aAAa;QACX,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAA;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAA;IACzB,CAAC;IAED;;;;;MAKE;IACF,gBAAgB;QACd,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;QACvD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,UAAU,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,IAAI,CAAC,EAAE,EAAE,CAAqB,CAAC;IAC1F,CAAC;IAED;;;;;MAKE;IACF,gBAAgB;QACd,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,wEAAwE;QAChI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,IAAI,CAAC,EAAE,EAAE,CAAqB,CAAC;IACtF,CAAC;uGAtGU,qBAAqB;2FAArB,qBAAqB,0JCnBlC,y5BAWA;;2FDQa,qBAAqB;kBALjC,SAAS;+BACE,eAAe;8BAehB,EAAE;sBAAV,KAAK;gBAaF,KAAK;sBAFR,KAAK;uBAAC,OAAO;gBA8BL,QAAQ;sBAAhB,KAAK;gBAYI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\n\r\n/**\r\n * Component for a slider that allows selecting a range of values.\r\n * @example\r\n * <mefdev-slider\r\n *  [disabled]=\"false\"\r\n *  [range] = \"{min: 1, max: 10000}\"\r\n *  [id]= \"'slider1'\"\r\n *  (valueChange)=\"onChildValueChange($event)\"\r\n *  ></mefdev-slider>\r\n *\r\n * <example-url>https://mef.dev/ui_kit_demo/view/typography/slider</example-url>    \r\n*/\r\n@Component({\r\n  selector: 'mefdev-slider',\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss']\r\n})\r\nexport class MefDevSliderComponent {\r\n\r\n  private _range = { min: 1, max: 1000 };\r\n\r\n  /**\r\n   * Unique id for each slider. Use it, if u need more than one slider independent from another on the same page. \r\n   * @example\r\n   * <mefdev-slider\r\n   *  [id]= \"'slider1'\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input() id: string;\r\n\r\n\r\n  /**\r\n   * Input Object {min, max} container of the slider\r\n   * @example\r\n   * @interval\r\n   * <mefdev-slider\r\n   *  [range] = \"{min: 1, max: 10000}\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input('range')\r\n  \r\n  set range(range: { min: number, max: number }) {\r\n    this._range = range;\r\n    this.minValue = range.min;\r\n    this.maxValue = range.max;\r\n  }\r\n  public get range(): { min: number, max: number } {\r\n    return this._range;\r\n  }\r\n\r\n  /**\r\n   * The minimum value of the slider.\r\n  */\r\n  minValue:number = this.range.min\r\n\r\n  /**\r\n   * The maximum value of the slider.\r\n  */\r\n  maxValue:number = this.range.max\r\n\r\n  \r\n\r\n  /**\r\n   * Property indicating whether the component is disabled.\r\n   * @example\r\n   * <mefdev-slider\r\n   *  [disabled]=\"true\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input() disabled : boolean= false;\r\n\r\n  /**\r\n   * Event emitted when the values of the slider change.\r\n   * It passes an object with `minValue` and `maxValue` properties.\r\n   * @event MefDevSliderComponent#valueChange\r\n   * @type {EventEmitter<{ minValue: number; maxValue: number }>}\r\n   * @example\r\n   * <mefdev-slider\r\n   *  (valueChange)=\"onChildValueChange($event)\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Output() valueChange: EventEmitter<{ minValue: number; maxValue: number }> = new EventEmitter();\r\n\r\n  /**\r\n   * Method called when the values of the slider change.\r\n   * Emits the `valueChange` event and calls methods to handle changes in the minimum and maximum values.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onValueChange() {\r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    this.minValue = this.minValue\r\n    this.onMinValueChange()\r\n    this.onMaxValueChange()\r\n  }\r\n\r\n  /**\r\n   * Method to handle changes in the minimum value.\r\n   * Converts a string to a number and removes all non-numeric characters.\r\n   * Then, emits the `valueChange` event and updates the value of the \"fromSlider\" slider.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onMinValueChange() {\r\n    const numericValue = parseFloat(this.minValue.toString().replace(/[^\\d.]/g, ''));\r\n    this.minValue = isNaN(numericValue) ? 0 : numericValue; \r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    const fromSlider = document.getElementById(`fromSlider-${this.id}`) as HTMLInputElement;\r\n  }\r\n\r\n  /**\r\n   * Method to handle changes in the maximum value.\r\n   * Converts a string to a number and removes all non-numeric characters.\r\n   * Then, emits the `valueChange` event and updates the value of the \"toSlider\" slider.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onMaxValueChange() {\r\n    const numericValue = parseFloat(this.maxValue.toString().replace(/[^\\d.]/g, ''));\r\n    this.maxValue = isNaN(numericValue) ? 0 : numericValue; // Перевірка на NaN і присвоєння 0, якщо не вдалося конвертувати в число\r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    const toSlider = document.getElementById(`toSlider-${this.id}`) as HTMLInputElement;\r\n  }\r\n}\r\n","<div class=\"range_container row\">\r\n    <div class=\"inputs_control \">\r\n      <input class=\"form_control_container__time__input h3\"  [(ngModel)]=\"'₴'+ minValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMinValueChange()\">\r\n      <input class=\"form_control_container__time__input h3\"  [(ngModel)]=\"'₴'+ maxValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMaxValueChange()\">\r\n    </div>\r\n    <div class=\"sliders_control\">\r\n      <input id=\"fromSlider\" type=\"range\"  [(ngModel)]=\"minValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\">\r\n      <input id=\"toSlider\" type=\"range\"  [(ngModel)]=\"maxValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\" \r\n          [style]=\"{'--minValue': minValue,  '--maxValue': maxValue, '--minFromValue': range.min, '--maxToValue': range.max}\">\r\n    </div>\r\n</div>\r\n"]}
@@ -0,0 +1,28 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { MefDevSliderComponent } from './slider/slider.component';
4
+ import { FormsModule } from '@angular/forms';
5
+ import * as i0 from "@angular/core";
6
+ export class MefDevSliderModule {
7
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: MefDevSliderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.6", ngImport: i0, type: MefDevSliderModule, declarations: [MefDevSliderComponent], imports: [CommonModule,
9
+ FormsModule], exports: [MefDevSliderComponent] });
10
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: MefDevSliderModule, imports: [CommonModule,
11
+ FormsModule] });
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: MefDevSliderModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ declarations: [
17
+ MefDevSliderComponent
18
+ ],
19
+ exports: [
20
+ MefDevSliderComponent
21
+ ],
22
+ imports: [
23
+ CommonModule,
24
+ FormsModule,
25
+ ]
26
+ }]
27
+ }] });
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3NsaWRlci9zbGlkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFnQjdDLE1BQU0sT0FBTyxrQkFBa0I7dUdBQWxCLGtCQUFrQjt3R0FBbEIsa0JBQWtCLGlCQVYzQixxQkFBcUIsYUFNckIsWUFBWTtZQUNaLFdBQVcsYUFKWCxxQkFBcUI7d0dBT1osa0JBQWtCLFlBSjNCLFlBQVk7WUFDWixXQUFXOzsyRkFHRixrQkFBa0I7a0JBWjlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHFCQUFxQjtxQkFDdEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHFCQUFxQjtxQkFDdEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVztxQkFDWjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE1lZkRldlNsaWRlckNvbXBvbmVudCB9IGZyb20gJy4vc2xpZGVyL3NsaWRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIE1lZkRldlNsaWRlckNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgTWVmRGV2U2xpZGVyQ29tcG9uZW50XHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNZWZEZXZTbGlkZXJNb2R1bGUgeyB9XHJcbiJdfQ==