@natec/mef-dev-ui-kit 16.2.4 → 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/README.md +6 -1
- 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/fesm2022/natec-mef-dev-ui-kit.mjs +186 -0
- package/fesm2022/natec-mef-dev-ui-kit.mjs.map +1 -1
- package/lib/markup-kit/card/card.module.d.ts +1 -1
- 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/package.json +1 -1
package/README.md
CHANGED
|
@@ -37,6 +37,11 @@ You can use the library on the following versions of Angular:
|
|
|
37
37
|
npm i bootstrap@5
|
|
38
38
|
```
|
|
39
39
|
|
|
40
|
+
> Ngx-bootstrap provides Bootstrap components powered by Angular, so you don't need to include original JS components.ngx-bootstrap:
|
|
41
|
+
```sh
|
|
42
|
+
npm i ngx-bootstrap@10
|
|
43
|
+
```
|
|
44
|
+
|
|
40
45
|
> CSS font-family parser/stringifier. Font-awesome:
|
|
41
46
|
```sh
|
|
42
47
|
npm i font-awesome@4
|
|
@@ -133,4 +138,4 @@ ___
|
|
|
133
138
|
* Documentation of the library: https://mef.dev/ui_kit
|
|
134
139
|
* Demo of the library: https://mef.dev/ui_kit_demo
|
|
135
140
|
* Library package: https://www.npmjs.com/package/@natec/mef-dev-ui-kit
|
|
136
|
-
* Ui-kit-lib at GitHub: https://github.com/mef-dev/ui-kit-demo.git
|
|
141
|
+
* Ui-kit-lib at GitHub: https://github.com/mef-dev/ui-kit-demo.git
|
package/esm2022/lib/markup-kit/executors/mefdev-executor-page/mefdev-executor-page.component.mjs
CHANGED
|
@@ -1,12 +1,80 @@
|
|
|
1
1
|
import { Component, EventEmitter, Host, Input, Output } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../step-executor/step-executor.component";
|
|
4
|
+
/**
|
|
5
|
+
* A component that allows us to create a content page - a step in our executor.
|
|
6
|
+
* Each individual step can have different styles, content and settings.
|
|
7
|
+
*
|
|
8
|
+
* Example of usage:
|
|
9
|
+
*
|
|
10
|
+
* ```
|
|
11
|
+
* <mefdev-executor-page
|
|
12
|
+
* [title]="'Executor title 1'"
|
|
13
|
+
* [isActive]="mainExecutor.activePageInd === 0"
|
|
14
|
+
* [isCompleted]="mainExecutor.activePageInd >= 0"
|
|
15
|
+
* class="yourClass">
|
|
16
|
+
* <!-- Content of the first executor step -->
|
|
17
|
+
* </mefdev-executor-page>
|
|
18
|
+
* <mefdev-executor-page
|
|
19
|
+
* [title]="'Executor title 2'"
|
|
20
|
+
* [isActive]="mainExecutor.activePageInd === 1"
|
|
21
|
+
* [isCompleted]="mainExecutor.activePageInd >= 1"
|
|
22
|
+
* class="yourClass">
|
|
23
|
+
* <!-- Content of the second executor step -->
|
|
24
|
+
* </mefdev-executor-page>
|
|
25
|
+
* <mefdev-executor-page
|
|
26
|
+
* [title]="'Executor title 3'"
|
|
27
|
+
* [isActive]="mainExecutor.activePageInd === 2"
|
|
28
|
+
* [isCompleted]="mainExecutor.activePageInd >= 2"
|
|
29
|
+
* class="yourClass">
|
|
30
|
+
* <!-- Content of the third executor step -->
|
|
31
|
+
* </mefdev-executor-page>
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
*/
|
|
4
35
|
export class MefdevExecutorPageComponent {
|
|
5
36
|
_mainExecutor;
|
|
6
37
|
_elementRef;
|
|
38
|
+
/**
|
|
39
|
+
* The title of the step
|
|
40
|
+
* @usageNotes
|
|
41
|
+
* ```
|
|
42
|
+
* <mefdev-executor-page [title]="'Description of situation 1'"></mefdev-executor-page>
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
7
45
|
title;
|
|
46
|
+
/**
|
|
47
|
+
* The input parameter that corresponds to whether the current step matches the respective page.
|
|
48
|
+
* The value of the active page is passed by reference from the specific component StepExecutorComponent.
|
|
49
|
+
*
|
|
50
|
+
* @usageNotes
|
|
51
|
+
* ```
|
|
52
|
+
* <mefdev-step-executor #mainExecutor>
|
|
53
|
+
* <mefdev-executor-page [isActive]="mainExecutor.activePageInd === 0">
|
|
54
|
+
* <mefdev-executor-page [isActive]="mainExecutor.activePageInd === 1">
|
|
55
|
+
* <mefdev-executor-page [isActive]="mainExecutor.activePageInd === 2">
|
|
56
|
+
* </<mefdev-step-executor>
|
|
57
|
+
*
|
|
58
|
+
* ```
|
|
59
|
+
*/
|
|
8
60
|
isActive = false;
|
|
61
|
+
/**
|
|
62
|
+
* The input parameter that checks whether the step is completed.
|
|
63
|
+
*
|
|
64
|
+
* @usageNotes
|
|
65
|
+
* ```
|
|
66
|
+
* <mefdev-executor-page [isCompleted]="mainExecutor.activePageInd >= 0"></mefdev-executor-page>
|
|
67
|
+
* ```
|
|
68
|
+
*/
|
|
9
69
|
isCompleted = false;
|
|
70
|
+
/**
|
|
71
|
+
* The output parameter that emits a boolean value indicating whether our completed step has changed.
|
|
72
|
+
*
|
|
73
|
+
* @usageNotes
|
|
74
|
+
* ```
|
|
75
|
+
* <mefdev-executor-page (isCompletedChange)="onStepChanged($event)"></mefdev-executor-page>
|
|
76
|
+
* ```
|
|
77
|
+
*/
|
|
10
78
|
isCompletedChange = new EventEmitter();
|
|
11
79
|
elRef;
|
|
12
80
|
constructor(_mainExecutor, _elementRef) {
|
|
@@ -41,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
41
109
|
}], isCompletedChange: [{
|
|
42
110
|
type: Output
|
|
43
111
|
}] } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVmZGV2LWV4ZWN1dG9yLXBhZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvZXhlY3V0b3JzL21lZmRldi1leGVjdXRvci1wYWdlL21lZmRldi1leGVjdXRvci1wYWdlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUFjLFlBQVksRUFBRSxJQUFJLEVBQ3pDLEtBQUssRUFBYSxNQUFNLEVBQ3pCLE1BQU0sZUFBZSxDQUFDOzs7QUFHdkI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQThCSTtBQU9KLE1BQU0sT0FBTywyQkFBMkI7SUFtRGxCO0lBQ1I7SUFsRFo7Ozs7OztPQU1HO0lBQ00sS0FBSyxDQUFTO0lBRXZCOzs7Ozs7Ozs7Ozs7O09BYUc7SUFDTSxRQUFRLEdBQVksS0FBSyxDQUFDO0lBR25DOzs7Ozs7O09BT0c7SUFDTSxXQUFXLEdBQVksS0FBSyxDQUFDO0lBRXRDOzs7Ozs7O09BT0c7SUFDTyxpQkFBaUIsR0FBMEIsSUFBSSxZQUFZLEVBQVcsQ0FBQztJQUUxRSxLQUFLLENBQWE7SUFFekIsWUFDb0IsYUFBb0MsRUFDNUMsV0FBdUI7UUFEZixrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7UUFDNUMsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFFakMsSUFBSSxDQUFDLEtBQUssR0FBRyxXQUFXLENBQUM7UUFDekIsYUFBYSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsSUFBSSxhQUFhLENBQUMsYUFBYSxJQUFJLENBQUMsQ0FBQyxFQUFFO1lBQ3JDLGFBQWEsQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDO1NBQ2pDO0lBQ0gsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUNwRSxDQUFDO3VHQS9EVSwyQkFBMkI7MkZBQTNCLDJCQUEyQixvTkFINUIsMkJBQTJCOzsyRkFHMUIsMkJBQTJCO2tCQUx2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFFBQVEsRUFBRSwyQkFBMkI7aUJBQ3RDOzswQkFxRE0sSUFBSTtxRUExQ0EsS0FBSztzQkFBYixLQUFLO2dCQWdCRyxRQUFRO3NCQUFoQixLQUFLO2dCQVdHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBVUksaUJBQWlCO3NCQUExQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdCxcclxuICBJbnB1dCwgT25DaGFuZ2VzLCBPdXRwdXQsIFNpbXBsZUNoYW5nZXNcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3RlcEV4ZWN1dG9yQ29tcG9uZW50IH0gZnJvbSAnLi4vc3RlcC1leGVjdXRvci9zdGVwLWV4ZWN1dG9yLmNvbXBvbmVudCc7XHJcblxyXG4vKipcclxuICogQSBjb21wb25lbnQgdGhhdCBhbGxvd3MgdXMgdG8gY3JlYXRlIGEgY29udGVudCBwYWdlIC0gYSBzdGVwIGluIG91ciBleGVjdXRvci5cclxuICogRWFjaCBpbmRpdmlkdWFsIHN0ZXAgY2FuIGhhdmUgZGlmZmVyZW50IHN0eWxlcywgY29udGVudCBhbmQgc2V0dGluZ3MuXHJcbiAqXHJcbiAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAqXHJcbiAqIGBgYFxyXG4gKiAgPG1lZmRldi1leGVjdXRvci1wYWdlXHJcbiAqICAgICBbdGl0bGVdPVwiJ0V4ZWN1dG9yIHRpdGxlIDEnXCJcclxuICogICAgIFtpc0FjdGl2ZV09XCJtYWluRXhlY3V0b3IuYWN0aXZlUGFnZUluZCA9PT0gMFwiXHJcbiAqICAgICBbaXNDb21wbGV0ZWRdPVwibWFpbkV4ZWN1dG9yLmFjdGl2ZVBhZ2VJbmQgPj0gMFwiXHJcbiAqICAgICBjbGFzcz1cInlvdXJDbGFzc1wiPlxyXG4gKiAgICAgIDwhLS0gQ29udGVudCBvZiB0aGUgZmlyc3QgZXhlY3V0b3Igc3RlcCAtLT5cclxuICogIDwvbWVmZGV2LWV4ZWN1dG9yLXBhZ2U+XHJcbiAqICA8bWVmZGV2LWV4ZWN1dG9yLXBhZ2VcclxuICogICAgIFt0aXRsZV09XCInRXhlY3V0b3IgdGl0bGUgMidcIlxyXG4gKiAgICAgW2lzQWN0aXZlXT1cIm1haW5FeGVjdXRvci5hY3RpdmVQYWdlSW5kID09PSAxXCJcclxuICogICAgIFtpc0NvbXBsZXRlZF09XCJtYWluRXhlY3V0b3IuYWN0aXZlUGFnZUluZCA+PSAxXCJcclxuICogICAgIGNsYXNzPVwieW91ckNsYXNzXCI+XHJcbiAqICAgICAgPCEtLSBDb250ZW50IG9mIHRoZSBzZWNvbmQgZXhlY3V0b3Igc3RlcCAtLT5cclxuICogIDwvbWVmZGV2LWV4ZWN1dG9yLXBhZ2U+XHJcbiAqICA8bWVmZGV2LWV4ZWN1dG9yLXBhZ2VcclxuICogICAgIFt0aXRsZV09XCInRXhlY3V0b3IgdGl0bGUgMydcIlxyXG4gKiAgICAgW2lzQWN0aXZlXT1cIm1haW5FeGVjdXRvci5hY3RpdmVQYWdlSW5kID09PSAyXCJcclxuICogICAgIFtpc0NvbXBsZXRlZF09XCJtYWluRXhlY3V0b3IuYWN0aXZlUGFnZUluZCA+PSAyXCJcclxuICogICAgIGNsYXNzPVwieW91ckNsYXNzXCI+XHJcbiAqICAgICAgPCEtLSBDb250ZW50IG9mIHRoZSB0aGlyZCBleGVjdXRvciBzdGVwIC0tPlxyXG4gKiAgPC9tZWZkZXYtZXhlY3V0b3ItcGFnZT5cclxuICogYGBgXHJcbiAqXHJcbiAgKi9cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LWV4ZWN1dG9yLXBhZ2UnLFxyXG4gIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgTWVmZGV2RXhlY3V0b3JQYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHRpdGxlIG9mIHRoZSBzdGVwXHJcbiAgICogQHVzYWdlTm90ZXNcclxuICAgKiBgYGBcclxuICAgKiAgPG1lZmRldi1leGVjdXRvci1wYWdlIFt0aXRsZV09XCInRGVzY3JpcHRpb24gb2Ygc2l0dWF0aW9uIDEnXCI+PC9tZWZkZXYtZXhlY3V0b3ItcGFnZT5cclxuICAgKiBgYGBcclxuICAgKi9cclxuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgaW5wdXQgcGFyYW1ldGVyIHRoYXQgY29ycmVzcG9uZHMgdG8gd2hldGhlciB0aGUgY3VycmVudCBzdGVwIG1hdGNoZXMgdGhlIHJlc3BlY3RpdmUgcGFnZS5cclxuICAgKiBUaGUgdmFsdWUgb2YgdGhlIGFjdGl2ZSBwYWdlIGlzIHBhc3NlZCBieSByZWZlcmVuY2UgZnJvbSB0aGUgc3BlY2lmaWMgY29tcG9uZW50IFN0ZXBFeGVjdXRvckNvbXBvbmVudC5cclxuICAgKlxyXG4gICAqIEB1c2FnZU5vdGVzXHJcbiAgICogYGBgXHJcbiAgICogIDxtZWZkZXYtc3RlcC1leGVjdXRvciAjbWFpbkV4ZWN1dG9yPlxyXG4gICAqICAgIDxtZWZkZXYtZXhlY3V0b3ItcGFnZSBbaXNBY3RpdmVdPVwibWFpbkV4ZWN1dG9yLmFjdGl2ZVBhZ2VJbmQgPT09IDBcIj5cclxuICAgKiAgICA8bWVmZGV2LWV4ZWN1dG9yLXBhZ2UgW2lzQWN0aXZlXT1cIm1haW5FeGVjdXRvci5hY3RpdmVQYWdlSW5kID09PSAxXCI+XHJcbiAgICogICAgPG1lZmRldi1leGVjdXRvci1wYWdlIFtpc0FjdGl2ZV09XCJtYWluRXhlY3V0b3IuYWN0aXZlUGFnZUluZCA9PT0gMlwiPlxyXG4gICAqICA8LzxtZWZkZXYtc3RlcC1leGVjdXRvcj5cclxuICAgKlxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGlzQWN0aXZlOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG5cclxuICAvKipcclxuICAgKiBUaGUgaW5wdXQgcGFyYW1ldGVyIHRoYXQgY2hlY2tzIHdoZXRoZXIgdGhlIHN0ZXAgaXMgY29tcGxldGVkLlxyXG4gICAqXHJcbiAgICogQHVzYWdlTm90ZXNcclxuICAgKiBgYGBcclxuICAgKiAgPG1lZmRldi1leGVjdXRvci1wYWdlIFtpc0NvbXBsZXRlZF09XCJtYWluRXhlY3V0b3IuYWN0aXZlUGFnZUluZCA+PSAwXCI+PC9tZWZkZXYtZXhlY3V0b3ItcGFnZT5cclxuICAgKiBgYGBcclxuICAgKi9cclxuICBASW5wdXQoKSBpc0NvbXBsZXRlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgb3V0cHV0IHBhcmFtZXRlciB0aGF0IGVtaXRzIGEgYm9vbGVhbiB2YWx1ZSBpbmRpY2F0aW5nIHdoZXRoZXIgb3VyIGNvbXBsZXRlZCBzdGVwIGhhcyBjaGFuZ2VkLlxyXG4gICAqXHJcbiAgICogQHVzYWdlTm90ZXNcclxuICAgKiBgYGBcclxuICAgKiAgPG1lZmRldi1leGVjdXRvci1wYWdlIChpc0NvbXBsZXRlZENoYW5nZSk9XCJvblN0ZXBDaGFuZ2VkKCRldmVudClcIj48L21lZmRldi1leGVjdXRvci1wYWdlPlxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSBpc0NvbXBsZXRlZENoYW5nZTogRXZlbnRFbWl0dGVyPGJvb2xlYW4+ID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG5cclxuICBwdWJsaWMgZWxSZWY6IEVsZW1lbnRSZWY7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgICBASG9zdCgpIHByaXZhdGUgX21haW5FeGVjdXRvcjogU3RlcEV4ZWN1dG9yQ29tcG9uZW50LFxyXG4gICAgICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmXHJcbiAgKSB7XHJcbiAgICB0aGlzLmVsUmVmID0gX2VsZW1lbnRSZWY7XHJcbiAgICBfbWFpbkV4ZWN1dG9yLnBhZ2VzLnB1c2godGhpcyk7XHJcbiAgICBpZiAoX21haW5FeGVjdXRvci5hY3RpdmVQYWdlSW5kID09IC0xKSB7XHJcbiAgICAgIF9tYWluRXhlY3V0b3IuYWN0aXZlUGFnZUluZCA9IDA7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICB0aGlzLmlzQ29tcGxldGVkQ2hhbmdlLmVtaXQoY2hhbmdlc1snaXNDb21wbGV0ZWQnXT8uY3VycmVudFZhbHVlKTtcclxuICB9XHJcblxyXG5cclxufVxyXG4iXX0=
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
|
+
/**
|
|
5
|
+
* @ignore
|
|
6
|
+
*/
|
|
4
7
|
export class StageComponent {
|
|
5
8
|
currentExecutorStep;
|
|
6
9
|
isRightModal;
|
|
@@ -21,4 +24,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
21
24
|
}], title: [{
|
|
22
25
|
type: Input
|
|
23
26
|
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvZXhlY3V0b3JzL3N0YWdlL3N0YWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L2V4ZWN1dG9ycy9zdGFnZS9zdGFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBRWpEOztHQUVHO0FBUUgsTUFBTSxPQUFPLGNBQWM7SUFFaEIsbUJBQW1CLENBQVM7SUFDNUIsWUFBWSxDQUFVO0lBQ3RCLFdBQVcsQ0FBVTtJQUNyQixLQUFLLENBQVM7dUdBTFosY0FBYzsyRkFBZCxjQUFjLHNMQ1ozQix5c0NBdUJBOzsyRkRYYSxjQUFjO2tCQU4xQixTQUFTOytCQUNFLGNBQWM7OEJBT2YsbUJBQW1CO3NCQUEzQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogQGlnbm9yZVxyXG4gKi9cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LXN0YWdlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc3RhZ2UuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3N0YWdlLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgU3RhZ2VDb21wb25lbnQge1xyXG5cclxuICBASW5wdXQoKSBjdXJyZW50RXhlY3V0b3JTdGVwOiBudW1iZXI7XHJcbiAgQElucHV0KCkgaXNSaWdodE1vZGFsOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIGlzQ29tcGxldGVkOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIHRpdGxlOiBzdHJpbmc7XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJzdGVwXCI+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiIWlzQ29tcGxldGVkIGVsc2UgZG9uZVwiPlxyXG4gICAgICAgIDxzdmcgd2lkdGg9XCIzNlwiIGhlaWdodD1cIjM2XCIgdmlld0JveD1cIjAgMCAzNiAzNlwiIFtuZ1N0eWxlXT1cImlzUmlnaHRNb2RhbCA/IHsgJ2ZpbGwnOiAnI0ZGRkZGRicgfSA6IHsgJ2ZpbGwnOiAnI0YzRjNGMycgfVwiPlxyXG4gICAgICAgICAgICA8cmVjdCB3aWR0aD1cIjM2XCIgaGVpZ2h0PVwiMzZcIiByeD1cIjE4XCIgLz5cclxuICAgICAgICAgICAgPHRleHQgY2xhc3M9XCJib2R5LTNcIiB4PVwiNTAlXCIgeT1cIjUwJVwiIGRvbWluYW50LWJhc2VsaW5lPVwibWlkZGxlXCIgdGV4dC1hbmNob3I9XCJtaWRkbGVcIiBmb250LXNpemU9XCIxNlwiIGZpbGw9XCJibGFja1wiPlxyXG4gICAgICAgICAgICAgICAge3sgY3VycmVudEV4ZWN1dG9yU3RlcCB9fVxyXG4gICAgICAgICAgICA8L3RleHQ+XHJcbiAgICAgICAgPC9zdmc+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImJvZHktNiBkZXNjcmlwdGlvblN0ZXBUZXh0XCIgKm5nSWY9XCIhaXNSaWdodE1vZGFsXCI+XHJcbiAgICAgICAgICAgIHt7IHRpdGxlIH19XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L25nLWNvbnRhaW5lcj5cclxuPC9kaXY+XHJcbjxuZy10ZW1wbGF0ZSAjZG9uZT5cclxuICAgIDxzdmcgd2lkdGg9XCIzNlwiIGhlaWdodD1cIjM2XCIgdmlld0JveD1cIjAgMCAzNiAzNlwiIGZpbGw9XCJub25lXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxyXG4gICAgICAgIDxyZWN0IHg9XCIwLjVcIiB5PVwiMC41XCIgd2lkdGg9XCIzNVwiIGhlaWdodD1cIjM1XCIgcng9XCIxNy41XCIgc3Ryb2tlPVwiIzkyOTI5MlwiLz5cclxuICAgICAgICA8cGF0aCBkPVwiTTI0LjczNzMgMTBMMTQuNTQ2NiAyMC4zNzY5TDExLjI0MTUgMTcuMDExNEw4IDIwLjMxMjJMMTEuMzA1MSAyMy42Nzc3TDE0LjU2NzggMjdMMTcuODA5MyAyMy42OTkyTDI4IDEzLjMyMjRMMjQuNzM3MyAxMFpcIlxyXG4gICAgICAgICAgICAgIGZpbGw9XCIjMjhCNDQ2XCIvPlxyXG4gICAgPC9zdmc+XHJcbiAgICA8c3BhbiBjbGFzcz1cImJvZHktNiBkZXNjcmlwdGlvblN0ZXBUZXh0XCIgKm5nSWY9XCIhaXNSaWdodE1vZGFsXCI+XHJcbiAgICAgICAge3sgdGl0bGUgfX1cclxuICAgIDwvc3Bhbj5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19
|
|
@@ -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":"AAAA,OAAO,EACY,SAAS,EACxB,YAAY,EACZ,YAAY,EAAE,KAAK,EACnB,MAAM,EACO,SAAS,EACzB,MAAM,eAAe,CAAC;;;;AAGvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAQH,MAAM,OAAO,qBAAqB;IAqEV;IAnEpB;;;;;;;;OAQG;IACsB,IAAI,CAAS;IAGtC;;OAEG;IACqB,SAAS,CAA0B;IAE3D;;;;;;;;;OASG;IACoB,KAAK,CAAoB;IAEhD;;;;;;;;;OASG;IAC0B,WAAW,CAAoB;IAG5D;;;;;;;;;OASG;IACqB,MAAM,CAAoB;IAElD;;;;;;;OAOG;IACO,kBAAkB,GAA8C,IAAI,YAAY,EAA+B,CAAC;IAEnH,cAAc,GAAW,CAAC,CAAC;IAC3B,KAAK,GAAkC,EAAE,CAAC;IAEjD,YAAoB,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;IAAG,CAAC;IAE3C,IAAW,aAAa,CAAC,gBAAwB;QAC7C,IAAI,CAAC,cAAc,GAAG,gBAAgB,CAAC;QACvC,IAAI,gBAAgB,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;YACzC,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,SAAS,IAAI,EAAE,EAAE;gBAC9C,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,SAAS,GAAG,EAAE,CAAC;aAC/C;YACD,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;YAC9F,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAA+B,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;SACnG;IACL,CAAC;IAED,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC5E,CAAC;IAED,eAAe;QACX,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;QAC9F,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAA+B,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IACpG,CAAC;IAED;;OAEG;IACH,iBAAiB;QACb,OAAO,IAAI,CAAC,cAAc,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;IACzD,CAAC;IAED;;OAEG;IACH,IAAI;QACA,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QAC1C,IAAI,UAAU,IAAI,CAAC,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC;SACnC;IACL,CAAC;IAED;;OAEG;IACH,MAAM;QACF,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QAC1C,IAAI,UAAU,IAAI,CAAC,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC;SACnC;IACL,CAAC;IAED;;OAEG;IACH,IAAI;QACA,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QAC1C,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YAChC,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC;SACnC;IACL,CAAC;IAGD;;OAEG;IACH,aAAa,CAAC,UAAkB;QAC5B,UAAU,IAAI,CAAC,CAAC;QAChB,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,UAAU,IAAI,CAAC,EAAE;YACnD,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC;SACnC;IACL,CAAC;IAED;;OAEG;IACH,OAAO,CAAC,IAAiC;QACrC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAGD;;OAEG;IACH,kBAAkB,CAAC,IAAiC;QAChD,MAAM,KAAK,GAAW,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/C,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC5B,IAAI,KAAK,KAAK,IAAI,CAAC,aAAa,EAAE;gBAC9B,IAAI,CAAC,IAAI,EAAE,CAAC;aACf;SACJ;IACL,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,KAAa;QAC3B,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YACzC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC5B,IAAI,KAAK,KAAK,IAAI,CAAC,aAAa,EAAE;gBAC9B,IAAI,CAAC,IAAI,EAAE,CAAC;aACf;SACJ;IAEL,CAAC;uGAhLQ,qBAAqB;2FAArB,qBAAqB,igBCzDlC,+hJAuHA;;2FD9Da,qBAAqB;kBANjC,SAAS;+BACI,sBAAsB;gGAgBP,IAAI;sBAA5B,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBAMC,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBAYC,KAAK;sBAA3B,YAAY;uBAAC,OAAO;gBAYQ,WAAW;sBAAvC,YAAY;uBAAC,aAAa;gBAaH,MAAM;sBAA7B,YAAY;uBAAC,QAAQ;gBAUZ,kBAAkB;sBAA3B,MAAM","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"]}
|
|
@@ -3821,6 +3821,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
3821
3821
|
}]
|
|
3822
3822
|
}] });
|
|
3823
3823
|
|
|
3824
|
+
/**
|
|
3825
|
+
* @ignore
|
|
3826
|
+
*/
|
|
3824
3827
|
class StageComponent {
|
|
3825
3828
|
currentExecutorStep;
|
|
3826
3829
|
isRightModal;
|
|
@@ -3842,13 +3845,104 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
3842
3845
|
type: Input
|
|
3843
3846
|
}] } });
|
|
3844
3847
|
|
|
3848
|
+
/**
|
|
3849
|
+
* Wrapper component that represents a specific encapsulated executor.
|
|
3850
|
+
*
|
|
3851
|
+
* Example of usage:
|
|
3852
|
+
*```
|
|
3853
|
+
* <mefdev-step-executor #mainExecutor [view]="'regular'">
|
|
3854
|
+
*
|
|
3855
|
+
* <ng-template #title>
|
|
3856
|
+
* <!-- Content for the executor title -->
|
|
3857
|
+
* </ng-template>
|
|
3858
|
+
* <ng-template #description>
|
|
3859
|
+
* <!-- Content for the executor description -->
|
|
3860
|
+
* </ng-template>
|
|
3861
|
+
*
|
|
3862
|
+
* <mefdev-executor-page
|
|
3863
|
+
* [title]="'Description of situation 1'"
|
|
3864
|
+
* [isActive]="mainExecutor.activePageInd === 0"
|
|
3865
|
+
* [isCompleted]="mainExecutor.activePageInd >= 0">
|
|
3866
|
+
* <!-- Content of the first executor step -->
|
|
3867
|
+
* </mefdev-executor-page>
|
|
3868
|
+
* <mefdev-executor-page
|
|
3869
|
+
* [title]="'Description of situation 2'"
|
|
3870
|
+
* [isActive]="mainExecutor.activePageInd === 1"
|
|
3871
|
+
* [isCompleted]="mainExecutor.activePageInd >= 1">
|
|
3872
|
+
* <!-- Content of the second executor step -->
|
|
3873
|
+
* </mefdev-executor-page>
|
|
3874
|
+
* <mefdev-executor-page
|
|
3875
|
+
* [title]="'Description of situation 3'"
|
|
3876
|
+
* [isActive]="mainExecutor.activePageInd === 2"
|
|
3877
|
+
* [isCompleted]="mainExecutor.activePageInd >= 2">
|
|
3878
|
+
* <!-- Content of the third executor step -->
|
|
3879
|
+
* </mefdev-executor-page>
|
|
3880
|
+
*
|
|
3881
|
+
* <ng-template #footer>
|
|
3882
|
+
* <!-- Content for the executor footer -->
|
|
3883
|
+
* <ng-template>
|
|
3884
|
+
*
|
|
3885
|
+
* </mefdev-step-executor>
|
|
3886
|
+
*
|
|
3887
|
+
*```
|
|
3888
|
+
*/
|
|
3845
3889
|
class StepExecutorComponent {
|
|
3846
3890
|
renderer;
|
|
3891
|
+
/**
|
|
3892
|
+
* Mandatory input parameter that specifies the type of the step-by-step wizard.
|
|
3893
|
+
* It can have three options: regular, modal, right.
|
|
3894
|
+
*
|
|
3895
|
+
* @usageNotes
|
|
3896
|
+
* ```
|
|
3897
|
+
* <mefdev-step-executor #mainExecutor [view]="'regular'"></mefdev-step-executor>
|
|
3898
|
+
* ```
|
|
3899
|
+
*/
|
|
3847
3900
|
view;
|
|
3901
|
+
/**
|
|
3902
|
+
* ViewChild reference to the host executor content.
|
|
3903
|
+
*/
|
|
3848
3904
|
container;
|
|
3905
|
+
/**
|
|
3906
|
+
* Template for displaying the content of the executor title.
|
|
3907
|
+
*
|
|
3908
|
+
* @usageNotes
|
|
3909
|
+
* ```
|
|
3910
|
+
* <ng-template #title>
|
|
3911
|
+
* <!-- Content for the executor title -->
|
|
3912
|
+
* </ng-template>
|
|
3913
|
+
* ```
|
|
3914
|
+
*/
|
|
3849
3915
|
title;
|
|
3916
|
+
/**
|
|
3917
|
+
* Template for displaying the content of the executor description.
|
|
3918
|
+
*
|
|
3919
|
+
* @usageNotes
|
|
3920
|
+
* ```
|
|
3921
|
+
* <ng-template #description>
|
|
3922
|
+
* <!-- Content for the executor description -->
|
|
3923
|
+
* </ng-template>
|
|
3924
|
+
* ```
|
|
3925
|
+
*/
|
|
3850
3926
|
description;
|
|
3927
|
+
/**
|
|
3928
|
+
* Template for displaying the content of the executor footer.
|
|
3929
|
+
*
|
|
3930
|
+
* @usageNotes
|
|
3931
|
+
* ```
|
|
3932
|
+
* <ng-template #footer>
|
|
3933
|
+
* <!-- Content for the executor footer -->
|
|
3934
|
+
* </ng-template>
|
|
3935
|
+
* ```
|
|
3936
|
+
*/
|
|
3851
3937
|
footer;
|
|
3938
|
+
/**
|
|
3939
|
+
* The output parameter that emits the class of the active page - active step.
|
|
3940
|
+
*
|
|
3941
|
+
* @usageNotes
|
|
3942
|
+
* ```
|
|
3943
|
+
* <mefdev-step-executor #mainExecutor (onActivePageChange)="getActiveStep($event)"></mefdev-step-executor>
|
|
3944
|
+
* ```
|
|
3945
|
+
*/
|
|
3852
3946
|
onActivePageChange = new EventEmitter();
|
|
3853
3947
|
_activePageInd = 0;
|
|
3854
3948
|
pages = [];
|
|
@@ -3875,15 +3969,24 @@ class StepExecutorComponent {
|
|
|
3875
3969
|
this.renderer.appendChild(this.container.nativeElement, this.activePage?.elRef.nativeElement);
|
|
3876
3970
|
this.onActivePageChange.emit(this.pages.find((el) => el.isActive));
|
|
3877
3971
|
}
|
|
3972
|
+
/**
|
|
3973
|
+
* Check whether there is a next step of the executor. If we are at the last step - disable the 'next' button
|
|
3974
|
+
*/
|
|
3878
3975
|
nextBtnIsDisabled() {
|
|
3879
3976
|
return this._activePageInd === this.pages.length - 1;
|
|
3880
3977
|
}
|
|
3978
|
+
/**
|
|
3979
|
+
* Check whether there is a next step of the executor. If we are at the last step - disable the 'next' button
|
|
3980
|
+
*/
|
|
3881
3981
|
prev() {
|
|
3882
3982
|
const newPageInd = this.activePageInd - 1;
|
|
3883
3983
|
if (newPageInd >= 0) {
|
|
3884
3984
|
this.activePageInd = newPageInd;
|
|
3885
3985
|
}
|
|
3886
3986
|
}
|
|
3987
|
+
/**
|
|
3988
|
+
* Go back to the previous step
|
|
3989
|
+
*/
|
|
3887
3990
|
cancel() {
|
|
3888
3991
|
this.activePageInd = 0;
|
|
3889
3992
|
const newPageInd = this.activePageInd - 1;
|
|
@@ -3891,21 +3994,33 @@ class StepExecutorComponent {
|
|
|
3891
3994
|
this.activePageInd = newPageInd;
|
|
3892
3995
|
}
|
|
3893
3996
|
}
|
|
3997
|
+
/**
|
|
3998
|
+
* Go to the next step
|
|
3999
|
+
*/
|
|
3894
4000
|
next() {
|
|
3895
4001
|
const newPageInd = this.activePageInd + 1;
|
|
3896
4002
|
if (newPageInd < this.pages.length) {
|
|
3897
4003
|
this.activePageInd = newPageInd;
|
|
3898
4004
|
}
|
|
3899
4005
|
}
|
|
4006
|
+
/**
|
|
4007
|
+
* Set a specific active page
|
|
4008
|
+
*/
|
|
3900
4009
|
setActivePage(pageNumber) {
|
|
3901
4010
|
pageNumber -= 1;
|
|
3902
4011
|
if (pageNumber < this.pages.length && pageNumber >= 0) {
|
|
3903
4012
|
this.activePageInd = pageNumber;
|
|
3904
4013
|
}
|
|
3905
4014
|
}
|
|
4015
|
+
/**
|
|
4016
|
+
* Add new page
|
|
4017
|
+
*/
|
|
3906
4018
|
addPage(page) {
|
|
3907
4019
|
this.pages.push(page);
|
|
3908
4020
|
}
|
|
4021
|
+
/**
|
|
4022
|
+
* Delete a specific page
|
|
4023
|
+
*/
|
|
3909
4024
|
removeSpecificPage(page) {
|
|
3910
4025
|
const index = this.pages.indexOf(page);
|
|
3911
4026
|
if (index !== -1) {
|
|
@@ -3915,6 +4030,9 @@ class StepExecutorComponent {
|
|
|
3915
4030
|
}
|
|
3916
4031
|
}
|
|
3917
4032
|
}
|
|
4033
|
+
/**
|
|
4034
|
+
* Delete a page by its index
|
|
4035
|
+
*/
|
|
3918
4036
|
removePageByIndex(index) {
|
|
3919
4037
|
if (index >= 0 && index < this.pages.length) {
|
|
3920
4038
|
this.pages.splice(index, 1);
|
|
@@ -3948,12 +4066,80 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
3948
4066
|
type: Output
|
|
3949
4067
|
}] } });
|
|
3950
4068
|
|
|
4069
|
+
/**
|
|
4070
|
+
* A component that allows us to create a content page - a step in our executor.
|
|
4071
|
+
* Each individual step can have different styles, content and settings.
|
|
4072
|
+
*
|
|
4073
|
+
* Example of usage:
|
|
4074
|
+
*
|
|
4075
|
+
* ```
|
|
4076
|
+
* <mefdev-executor-page
|
|
4077
|
+
* [title]="'Executor title 1'"
|
|
4078
|
+
* [isActive]="mainExecutor.activePageInd === 0"
|
|
4079
|
+
* [isCompleted]="mainExecutor.activePageInd >= 0"
|
|
4080
|
+
* class="yourClass">
|
|
4081
|
+
* <!-- Content of the first executor step -->
|
|
4082
|
+
* </mefdev-executor-page>
|
|
4083
|
+
* <mefdev-executor-page
|
|
4084
|
+
* [title]="'Executor title 2'"
|
|
4085
|
+
* [isActive]="mainExecutor.activePageInd === 1"
|
|
4086
|
+
* [isCompleted]="mainExecutor.activePageInd >= 1"
|
|
4087
|
+
* class="yourClass">
|
|
4088
|
+
* <!-- Content of the second executor step -->
|
|
4089
|
+
* </mefdev-executor-page>
|
|
4090
|
+
* <mefdev-executor-page
|
|
4091
|
+
* [title]="'Executor title 3'"
|
|
4092
|
+
* [isActive]="mainExecutor.activePageInd === 2"
|
|
4093
|
+
* [isCompleted]="mainExecutor.activePageInd >= 2"
|
|
4094
|
+
* class="yourClass">
|
|
4095
|
+
* <!-- Content of the third executor step -->
|
|
4096
|
+
* </mefdev-executor-page>
|
|
4097
|
+
* ```
|
|
4098
|
+
*
|
|
4099
|
+
*/
|
|
3951
4100
|
class MefdevExecutorPageComponent {
|
|
3952
4101
|
_mainExecutor;
|
|
3953
4102
|
_elementRef;
|
|
4103
|
+
/**
|
|
4104
|
+
* The title of the step
|
|
4105
|
+
* @usageNotes
|
|
4106
|
+
* ```
|
|
4107
|
+
* <mefdev-executor-page [title]="'Description of situation 1'"></mefdev-executor-page>
|
|
4108
|
+
* ```
|
|
4109
|
+
*/
|
|
3954
4110
|
title;
|
|
4111
|
+
/**
|
|
4112
|
+
* The input parameter that corresponds to whether the current step matches the respective page.
|
|
4113
|
+
* The value of the active page is passed by reference from the specific component StepExecutorComponent.
|
|
4114
|
+
*
|
|
4115
|
+
* @usageNotes
|
|
4116
|
+
* ```
|
|
4117
|
+
* <mefdev-step-executor #mainExecutor>
|
|
4118
|
+
* <mefdev-executor-page [isActive]="mainExecutor.activePageInd === 0">
|
|
4119
|
+
* <mefdev-executor-page [isActive]="mainExecutor.activePageInd === 1">
|
|
4120
|
+
* <mefdev-executor-page [isActive]="mainExecutor.activePageInd === 2">
|
|
4121
|
+
* </<mefdev-step-executor>
|
|
4122
|
+
*
|
|
4123
|
+
* ```
|
|
4124
|
+
*/
|
|
3955
4125
|
isActive = false;
|
|
4126
|
+
/**
|
|
4127
|
+
* The input parameter that checks whether the step is completed.
|
|
4128
|
+
*
|
|
4129
|
+
* @usageNotes
|
|
4130
|
+
* ```
|
|
4131
|
+
* <mefdev-executor-page [isCompleted]="mainExecutor.activePageInd >= 0"></mefdev-executor-page>
|
|
4132
|
+
* ```
|
|
4133
|
+
*/
|
|
3956
4134
|
isCompleted = false;
|
|
4135
|
+
/**
|
|
4136
|
+
* The output parameter that emits a boolean value indicating whether our completed step has changed.
|
|
4137
|
+
*
|
|
4138
|
+
* @usageNotes
|
|
4139
|
+
* ```
|
|
4140
|
+
* <mefdev-executor-page (isCompletedChange)="onStepChanged($event)"></mefdev-executor-page>
|
|
4141
|
+
* ```
|
|
4142
|
+
*/
|
|
3957
4143
|
isCompletedChange = new EventEmitter();
|
|
3958
4144
|
elRef;
|
|
3959
4145
|
constructor(_mainExecutor, _elementRef) {
|