@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.
- package/esm2022/lib/markup-kit/card/card-long/card-long.component.mjs +16 -16
- package/esm2022/lib/markup-kit/card/card-simple/card-simple.component.mjs +7 -7
- package/esm2022/lib/markup-kit/collapse/collapse/collapse.component.mjs +3 -3
- package/esm2022/lib/markup-kit/executors/mefdev-executor-page/mefdev-executor-page.component.mjs +69 -1
- package/esm2022/lib/markup-kit/executors/stage/stage.component.mjs +4 -1
- package/esm2022/lib/markup-kit/executors/step-executor/step-executor.component.mjs +116 -1
- package/esm2022/lib/markup-kit/modals/fill/fill.component.mjs +3 -3
- package/esm2022/lib/markup-kit/modals/slide-up/slide-up.component.mjs +3 -3
- package/esm2022/lib/markup-kit/slider/index.mjs +3 -0
- package/esm2022/lib/markup-kit/slider/slider/slider.component.mjs +120 -0
- package/esm2022/lib/markup-kit/slider/slider.module.mjs +28 -0
- package/esm2022/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.mjs +18 -7
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/natec-mef-dev-ui-kit.mjs +371 -34
- package/fesm2022/natec-mef-dev-ui-kit.mjs.map +1 -1
- package/lib/markup-kit/card/card-long/card-long.component.d.ts +14 -14
- package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +5 -5
- package/lib/markup-kit/executors/mefdev-executor-page/mefdev-executor-page.component.d.ts +68 -0
- package/lib/markup-kit/executors/stage/stage.component.d.ts +3 -0
- package/lib/markup-kit/executors/step-executor/step-executor.component.d.ts +115 -0
- package/lib/markup-kit/slider/index.d.ts +2 -0
- package/lib/markup-kit/slider/slider/slider.component.d.ts +93 -0
- package/lib/markup-kit/slider/slider.module.d.ts +9 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- 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,
|
|
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-
|
|
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-
|
|
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,
|
|
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==
|