myrta-ui 1.1.34 → 1.1.37
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/esm2020/lib/components/form/checkbox-group/checkbox-group.component.mjs +60 -37
- package/esm2020/lib/components/form/checkbox-group/components/checkbox-group-header/checkbox-group-header.component.mjs +4 -4
- package/esm2020/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.mjs +42 -43
- package/esm2020/lib/components/form/checkbox-group/helpers/change-group-value.mjs +7 -8
- package/esm2020/lib/components/form/checkbox-group/helpers/change-item-value.mjs +2 -2
- package/esm2020/lib/components/form/checkbox-group/helpers/filter-search-group.mjs +5 -5
- package/esm2020/lib/components/form/checkbox-group/helpers/get-checked-items.mjs +2 -2
- package/esm2020/lib/components/form/checkbox-group/helpers/get-inner-list.helper.mjs +46 -0
- package/esm2020/lib/components/form/checkbox-group/helpers/get-item-by-id.mjs +4 -4
- package/esm2020/lib/components/form/checkbox-group/helpers/get-sorted-list.mjs +2 -2
- package/esm2020/lib/components/form/checkbox-group/models/checkbox-group.model.mjs +1 -1
- package/esm2020/lib/components/form/formula-editor/formula-editor.component.mjs +3 -2
- package/esm2020/lib/components/form/input-text/input-text.component.mjs +2 -2
- package/esm2020/lib/components/form/radio-group/components/radio-group-item/radio-group-item.component.mjs +3 -3
- package/esm2020/lib/services/mrx-form-validator/helpers/get-sorting-validations.helper.mjs +4 -3
- package/esm2020/lib/services/mrx-form-validator/validations/max-length.validation.mjs +6 -2
- package/esm2020/lib/services/mrx-form-validator/validations/max-value.validation.mjs +1 -1
- package/esm2020/lib/services/mrx-form-validator/validations/min-length.validation.mjs +6 -2
- package/esm2020/lib/services/mrx-form-validator/validations/required.validation.mjs +1 -1
- package/fesm2015/myrta-ui.mjs +176 -100
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +175 -100
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/form/checkbox-group/checkbox-group.component.d.ts +21 -14
- package/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.d.ts +13 -9
- package/lib/components/form/checkbox-group/helpers/change-group-value.d.ts +3 -3
- package/lib/components/form/checkbox-group/helpers/change-item-value.d.ts +3 -3
- package/lib/components/form/checkbox-group/helpers/filter-search-group.d.ts +2 -2
- package/lib/components/form/checkbox-group/helpers/get-checked-items.d.ts +2 -2
- package/lib/components/form/checkbox-group/helpers/get-inner-list.helper.d.ts +2 -0
- package/lib/components/form/checkbox-group/helpers/get-item-by-id.d.ts +2 -2
- package/lib/components/form/checkbox-group/helpers/get-sorted-list.d.ts +2 -2
- package/lib/components/form/checkbox-group/models/checkbox-group.model.d.ts +7 -2
- package/lib/services/mrx-form-validator/helpers/get-sorting-validations.helper.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,20 +1,19 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { getItemInnerById } from './get-item-by-id';
|
|
2
2
|
export const checkUnderArrayValue = (array, value) => {
|
|
3
3
|
return array.some((x) => {
|
|
4
4
|
if (x.type === 'array') {
|
|
5
|
-
return checkUnderArrayValue(x.
|
|
5
|
+
return checkUnderArrayValue(x.items, value);
|
|
6
6
|
}
|
|
7
7
|
return x.value !== value;
|
|
8
8
|
});
|
|
9
9
|
};
|
|
10
|
-
export const changeGroupValue = (list,
|
|
11
|
-
if (!
|
|
10
|
+
export const changeGroupValue = (list, parentId, value) => {
|
|
11
|
+
if (!parentId) {
|
|
12
12
|
return;
|
|
13
13
|
}
|
|
14
|
-
const parent =
|
|
14
|
+
const parent = getItemInnerById(list, parentId);
|
|
15
15
|
if (parent) {
|
|
16
|
-
parent.value = checkUnderArrayValue(parent.
|
|
17
|
-
changeGroupValue(list, parent.parentId, value);
|
|
16
|
+
parent.value = checkUnderArrayValue(parent.items, value) ? null : value;
|
|
18
17
|
}
|
|
19
18
|
};
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbmdlLWdyb3VwLXZhbHVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vY2hlY2tib3gtZ3JvdXAvaGVscGVycy9jaGFuZ2UtZ3JvdXAtdmFsdWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFcEQsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxLQUErQixFQUFFLEtBQWlDLEVBQVcsRUFBRTtJQUNsSCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUF5QixFQUFFLEVBQUU7UUFDOUMsSUFBSSxDQUFDLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTtZQUN0QixPQUFPLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUE7U0FDNUM7UUFFRCxPQUFPLENBQUMsQ0FBQyxLQUFLLEtBQUssS0FBSyxDQUFBO0lBQzFCLENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyxDQUFBO0FBRUQsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxJQUE4QixFQUFFLFFBQWdDLEVBQUUsS0FBaUMsRUFBRSxFQUFFO0lBQ3RJLElBQUksQ0FBQyxRQUFRLEVBQUU7UUFDYixPQUFNO0tBQ1A7SUFDRCxNQUFNLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUE7SUFFL0MsSUFBSSxNQUFNLEVBQUU7UUFDVixNQUFNLENBQUMsS0FBSyxHQUFHLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFBO0tBQ3hFO0FBQ0gsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hlY2tib3hHcm91cElubmVySXRlbSwgQ2hlY2tib3hJbmRldGVybWluYXRlU3RhdGUgfSBmcm9tICcuLi9tb2RlbHMvY2hlY2tib3gtZ3JvdXAubW9kZWwnO1xyXG5pbXBvcnQgeyBnZXRJdGVtSW5uZXJCeUlkIH0gZnJvbSAnLi9nZXQtaXRlbS1ieS1pZCc7XHJcblxyXG5leHBvcnQgY29uc3QgY2hlY2tVbmRlckFycmF5VmFsdWUgPSAoYXJyYXk6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSwgdmFsdWU6IENoZWNrYm94SW5kZXRlcm1pbmF0ZVN0YXRlKTogYm9vbGVhbiA9PiB7XHJcbiAgcmV0dXJuIGFycmF5LnNvbWUoKHg6IENoZWNrYm94R3JvdXBJbm5lckl0ZW0pID0+IHtcclxuICAgIGlmICh4LnR5cGUgPT09ICdhcnJheScpIHtcclxuICAgICAgcmV0dXJuIGNoZWNrVW5kZXJBcnJheVZhbHVlKHguaXRlbXMsIHZhbHVlKVxyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiB4LnZhbHVlICE9PSB2YWx1ZVxyXG4gIH0pXHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBjaGFuZ2VHcm91cFZhbHVlID0gKGxpc3Q6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSwgcGFyZW50SWQ6IHN0cmluZyB8IG51bWJlciB8IG51bGwsIHZhbHVlOiBDaGVja2JveEluZGV0ZXJtaW5hdGVTdGF0ZSkgPT4ge1xyXG4gIGlmICghcGFyZW50SWQpIHtcclxuICAgIHJldHVyblxyXG4gIH1cclxuICBjb25zdCBwYXJlbnQgPSBnZXRJdGVtSW5uZXJCeUlkKGxpc3QsIHBhcmVudElkKVxyXG5cclxuICBpZiAocGFyZW50KSB7XHJcbiAgICBwYXJlbnQudmFsdWUgPSBjaGVja1VuZGVyQXJyYXlWYWx1ZShwYXJlbnQuaXRlbXMsIHZhbHVlKSA/IG51bGwgOiB2YWx1ZVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export const changeItemValue = (item, value) => {
|
|
2
2
|
item.value = value;
|
|
3
3
|
if (item.type === 'array') {
|
|
4
|
-
item.
|
|
4
|
+
item.items?.forEach((item) => {
|
|
5
5
|
changeItemValue(item, value);
|
|
6
6
|
});
|
|
7
7
|
}
|
|
@@ -12,4 +12,4 @@ export const changeListValue = (list, value) => {
|
|
|
12
12
|
changeItemValue(item, value);
|
|
13
13
|
});
|
|
14
14
|
};
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbmdlLWl0ZW0tdmFsdWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9oZWxwZXJzL2NoYW5nZS1pdGVtLXZhbHVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxDQUFDLElBQTRCLEVBQUUsS0FBaUMsRUFBRSxFQUFFO0lBQ2pHLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFBO0lBQ2xCLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxPQUFPLEVBQUU7UUFDekIsSUFBSSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQyxJQUE0QixFQUFFLEVBQUU7WUFDbkQsZUFBZSxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQTtRQUM5QixDQUFDLENBQUMsQ0FBQTtLQUNIO0lBRUQsT0FBTyxJQUFJLENBQUE7QUFDYixDQUFDLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxJQUE4QixFQUFFLEtBQWlDLEVBQUUsRUFBRTtJQUNuRyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBNEIsRUFBRSxFQUFFO1FBQzVDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUE7SUFDOUIsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGVja2JveEdyb3VwSW5uZXJJdGVtLCBDaGVja2JveEluZGV0ZXJtaW5hdGVTdGF0ZSB9IGZyb20gJy4uL21vZGVscy9jaGVja2JveC1ncm91cC5tb2RlbCc7XHJcblxyXG5leHBvcnQgY29uc3QgY2hhbmdlSXRlbVZhbHVlID0gKGl0ZW06IENoZWNrYm94R3JvdXBJbm5lckl0ZW0sIHZhbHVlOiBDaGVja2JveEluZGV0ZXJtaW5hdGVTdGF0ZSkgPT4ge1xyXG4gIGl0ZW0udmFsdWUgPSB2YWx1ZVxyXG4gIGlmIChpdGVtLnR5cGUgPT09ICdhcnJheScpIHtcclxuICAgIGl0ZW0uaXRlbXM/LmZvckVhY2goKGl0ZW06IENoZWNrYm94R3JvdXBJbm5lckl0ZW0pID0+IHtcclxuICAgICAgY2hhbmdlSXRlbVZhbHVlKGl0ZW0sIHZhbHVlKVxyXG4gICAgfSlcclxuICB9XHJcblxyXG4gIHJldHVybiBpdGVtXHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBjaGFuZ2VMaXN0VmFsdWUgPSAobGlzdDogQ2hlY2tib3hHcm91cElubmVySXRlbVtdLCB2YWx1ZTogQ2hlY2tib3hJbmRldGVybWluYXRlU3RhdGUpID0+IHtcclxuICBsaXN0LmZvckVhY2goKGl0ZW06IENoZWNrYm94R3JvdXBJbm5lckl0ZW0pID0+IHtcclxuICAgIGNoYW5nZUl0ZW1WYWx1ZShpdGVtLCB2YWx1ZSlcclxuICB9KVxyXG59XHJcbiJdfQ==
|
|
@@ -6,8 +6,8 @@ export const filterSearchGroup = (list, searchValue) => {
|
|
|
6
6
|
array.forEach((item) => {
|
|
7
7
|
if (item.text.toLowerCase().includes(searchValue.toLowerCase())) {
|
|
8
8
|
if (item.type === 'array') {
|
|
9
|
-
const newArray = getIntersectionsFromString(item.
|
|
10
|
-
searchArray.push({ ...item,
|
|
9
|
+
const newArray = getIntersectionsFromString(item.items || []);
|
|
10
|
+
searchArray.push({ ...item, items: newArray });
|
|
11
11
|
}
|
|
12
12
|
else {
|
|
13
13
|
searchArray.push(item);
|
|
@@ -15,8 +15,8 @@ export const filterSearchGroup = (list, searchValue) => {
|
|
|
15
15
|
}
|
|
16
16
|
else {
|
|
17
17
|
if (item.type === 'array') {
|
|
18
|
-
const newArray = getIntersectionsFromString(item.
|
|
19
|
-
newArray.length && searchArray.push({ ...item,
|
|
18
|
+
const newArray = getIntersectionsFromString(item.items || []);
|
|
19
|
+
newArray.length && searchArray.push({ ...item, items: newArray });
|
|
20
20
|
}
|
|
21
21
|
}
|
|
22
22
|
});
|
|
@@ -24,4 +24,4 @@ export const filterSearchGroup = (list, searchValue) => {
|
|
|
24
24
|
};
|
|
25
25
|
return getIntersectionsFromString(list);
|
|
26
26
|
};
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXNlYXJjaC1ncm91cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2NoZWNrYm94LWdyb3VwL2hlbHBlcnMvZmlsdGVyLXNlYXJjaC1ncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLElBQThCLEVBQUUsV0FBcUMsRUFBRSxFQUFFO0lBQ3pHLElBQUksQ0FBQyxJQUFJO1FBQUUsT0FBTyxJQUFJLENBQUE7SUFFdEIsTUFBTSwwQkFBMEIsR0FBRyxDQUFDLEtBQStCLEVBQUUsRUFBRTtRQUNyRSxNQUFNLFdBQVcsR0FBNkIsRUFBRSxDQUFBO1FBRWhELEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUE0QixFQUFFLEVBQUU7WUFDN0MsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRTtnQkFDL0QsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTtvQkFDekIsTUFBTSxRQUFRLEdBQTZCLDBCQUEwQixDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUE7b0JBQ3ZGLFdBQVcsQ0FBQyxJQUFJLENBQUMsRUFBQyxHQUFHLElBQUksRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFDLENBQUMsQ0FBQTtpQkFDN0M7cUJBQU07b0JBQ0wsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtpQkFDdkI7YUFDRjtpQkFBTTtnQkFDTCxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFFO29CQUN6QixNQUFNLFFBQVEsR0FBNkIsMEJBQTBCLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUMsQ0FBQTtvQkFDdkYsUUFBUSxDQUFDLE1BQU0sSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUMsR0FBRyxJQUFJLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBQyxDQUFDLENBQUE7aUJBQ2hFO2FBQ0Y7UUFDSCxDQUFDLENBQUMsQ0FBQTtRQUVGLE9BQU8sV0FBVyxDQUFBO0lBQ3BCLENBQUMsQ0FBQTtJQUVELE9BQU8sMEJBQTBCLENBQUMsSUFBSSxDQUFDLENBQUE7QUFDekMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hlY2tib3hHcm91cElubmVySXRlbSwgQ2hlY2tib3hHcm91cFNlYXJjaFZhbHVlIH0gZnJvbSAnLi4vbW9kZWxzL2NoZWNrYm94LWdyb3VwLm1vZGVsJztcclxuXHJcbmV4cG9ydCBjb25zdCBmaWx0ZXJTZWFyY2hHcm91cCA9IChsaXN0OiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10sIHNlYXJjaFZhbHVlOiBDaGVja2JveEdyb3VwU2VhcmNoVmFsdWUpID0+IHtcclxuICBpZiAoIWxpc3QpIHJldHVybiBsaXN0XHJcblxyXG4gIGNvbnN0IGdldEludGVyc2VjdGlvbnNGcm9tU3RyaW5nID0gKGFycmF5OiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10pID0+IHtcclxuICAgIGNvbnN0IHNlYXJjaEFycmF5OiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10gPSBbXVxyXG5cclxuICAgIGFycmF5LmZvckVhY2goKGl0ZW06IENoZWNrYm94R3JvdXBJbm5lckl0ZW0pID0+IHtcclxuICAgICAgaWYgKGl0ZW0udGV4dC50b0xvd2VyQ2FzZSgpLmluY2x1ZGVzKHNlYXJjaFZhbHVlLnRvTG93ZXJDYXNlKCkpKSB7XHJcbiAgICAgICAgaWYgKGl0ZW0udHlwZSA9PT0gJ2FycmF5Jykge1xyXG4gICAgICAgICAgY29uc3QgbmV3QXJyYXk6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSA9IGdldEludGVyc2VjdGlvbnNGcm9tU3RyaW5nKGl0ZW0uaXRlbXMgfHwgW10pXHJcbiAgICAgICAgICBzZWFyY2hBcnJheS5wdXNoKHsuLi5pdGVtLCBpdGVtczogbmV3QXJyYXl9KVxyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBzZWFyY2hBcnJheS5wdXNoKGl0ZW0pXHJcbiAgICAgICAgfVxyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIGlmIChpdGVtLnR5cGUgPT09ICdhcnJheScpIHtcclxuICAgICAgICAgIGNvbnN0IG5ld0FycmF5OiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10gPSBnZXRJbnRlcnNlY3Rpb25zRnJvbVN0cmluZyhpdGVtLml0ZW1zIHx8IFtdKVxyXG4gICAgICAgICAgbmV3QXJyYXkubGVuZ3RoICYmIHNlYXJjaEFycmF5LnB1c2goey4uLml0ZW0sIGl0ZW1zOiBuZXdBcnJheX0pXHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9KVxyXG5cclxuICAgIHJldHVybiBzZWFyY2hBcnJheVxyXG4gIH1cclxuXHJcbiAgcmV0dXJuIGdldEludGVyc2VjdGlvbnNGcm9tU3RyaW5nKGxpc3QpXHJcbn1cclxuIl19
|
|
@@ -5,7 +5,7 @@ export const getCheckedItems = (list) => {
|
|
|
5
5
|
const getCheckedItemsFromArray = (list) => {
|
|
6
6
|
list.forEach((item) => {
|
|
7
7
|
if (item.type === 'array') {
|
|
8
|
-
getCheckedItemsFromArray(item.
|
|
8
|
+
getCheckedItemsFromArray(item.items || []);
|
|
9
9
|
}
|
|
10
10
|
else {
|
|
11
11
|
if (item.value) {
|
|
@@ -17,4 +17,4 @@ export const getCheckedItems = (list) => {
|
|
|
17
17
|
getCheckedItemsFromArray(list);
|
|
18
18
|
return checkedItems;
|
|
19
19
|
};
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWNoZWNrZWQtaXRlbXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9oZWxwZXJzL2dldC1jaGVja2VkLWl0ZW1zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxDQUFDLElBQThCLEVBQUUsRUFBRTtJQUNoRSxJQUFJLENBQUMsSUFBSTtRQUFFLE9BQU8sSUFBSSxDQUFBO0lBRXRCLE1BQU0sWUFBWSxHQUE2QixFQUFFLENBQUE7SUFFakQsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLElBQThCLEVBQUUsRUFBRTtRQUNsRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBNEIsRUFBRSxFQUFFO1lBQzVDLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxPQUFPLEVBQUU7Z0JBQ3pCLHdCQUF3QixDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUE7YUFDM0M7aUJBQU07Z0JBQ0wsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO29CQUNkLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7aUJBQ3hCO2FBQ0Y7UUFDSCxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUMsQ0FBQTtJQUVELHdCQUF3QixDQUFDLElBQUksQ0FBQyxDQUFBO0lBRTlCLE9BQU8sWUFBWSxDQUFBO0FBQ3JCLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoZWNrYm94R3JvdXBJbm5lckl0ZW0gfSBmcm9tICcuLi9tb2RlbHMvY2hlY2tib3gtZ3JvdXAubW9kZWwnO1xyXG5cclxuZXhwb3J0IGNvbnN0IGdldENoZWNrZWRJdGVtcyA9IChsaXN0OiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10pID0+IHtcclxuICBpZiAoIWxpc3QpIHJldHVybiBsaXN0XHJcblxyXG4gIGNvbnN0IGNoZWNrZWRJdGVtczogQ2hlY2tib3hHcm91cElubmVySXRlbVtdID0gW11cclxuXHJcbiAgY29uc3QgZ2V0Q2hlY2tlZEl0ZW1zRnJvbUFycmF5ID0gKGxpc3Q6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSkgPT4ge1xyXG4gICAgbGlzdC5mb3JFYWNoKChpdGVtOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtKSA9PiB7XHJcbiAgICAgIGlmIChpdGVtLnR5cGUgPT09ICdhcnJheScpIHtcclxuICAgICAgICBnZXRDaGVja2VkSXRlbXNGcm9tQXJyYXkoaXRlbS5pdGVtcyB8fCBbXSlcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBpZiAoaXRlbS52YWx1ZSkge1xyXG4gICAgICAgICAgY2hlY2tlZEl0ZW1zLnB1c2goaXRlbSlcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBnZXRDaGVja2VkSXRlbXNGcm9tQXJyYXkobGlzdClcclxuXHJcbiAgcmV0dXJuIGNoZWNrZWRJdGVtc1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
export const getInnerList = (list, checkedList) => {
|
|
2
|
+
const getItemValue = (item) => {
|
|
3
|
+
if (item.items) {
|
|
4
|
+
let value = false;
|
|
5
|
+
let count = 0;
|
|
6
|
+
item.items.forEach((i, idx, array) => {
|
|
7
|
+
if (i.items) {
|
|
8
|
+
if (value === false) {
|
|
9
|
+
value = getItemValue(i);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
if (checkedList.find(c => c.id === i.id)) {
|
|
14
|
+
count++;
|
|
15
|
+
if (value === false) {
|
|
16
|
+
value = null;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
if (idx === array.length - 1) {
|
|
21
|
+
if (count === array.length) {
|
|
22
|
+
value = true;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
return value;
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
return !!checkedList.find(c => c.id === item.id);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
const getModifiedList = (items, parentId = null) => {
|
|
33
|
+
return items.map((item, idx, array) => {
|
|
34
|
+
return {
|
|
35
|
+
id: item.id,
|
|
36
|
+
text: item.text,
|
|
37
|
+
value: getItemValue(item),
|
|
38
|
+
parentId: parentId,
|
|
39
|
+
type: item.items ? 'array' : 'single',
|
|
40
|
+
items: item.items ? getModifiedList(item.items, item.id) : []
|
|
41
|
+
};
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
return getModifiedList(list);
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWlubmVyLWxpc3QuaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vY2hlY2tib3gtZ3JvdXAvaGVscGVycy9nZXQtaW5uZXItbGlzdC5oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsSUFBeUIsRUFBRSxXQUFnQyxFQUE0QixFQUFFO0lBQ3BILE1BQU0sWUFBWSxHQUFHLENBQUMsSUFBdUIsRUFBa0IsRUFBRTtRQUMvRCxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDZCxJQUFJLEtBQUssR0FBbUIsS0FBSyxDQUFBO1lBQ2pDLElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQTtZQUViLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsRUFBRTtnQkFDbkMsSUFBSSxDQUFDLENBQUMsS0FBSyxFQUFFO29CQUNYLElBQUksS0FBSyxLQUFLLEtBQUssRUFBRTt3QkFDbkIsS0FBSyxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQTtxQkFDeEI7aUJBQ0Y7cUJBQU07b0JBQ0wsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUU7d0JBQ3hDLEtBQUssRUFBRSxDQUFBO3dCQUVQLElBQUksS0FBSyxLQUFLLEtBQUssRUFBRTs0QkFDbkIsS0FBSyxHQUFHLElBQUksQ0FBQTt5QkFDYjtxQkFDRjtpQkFDRjtnQkFFRCxJQUFJLEdBQUcsS0FBSyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtvQkFDNUIsSUFBSSxLQUFLLEtBQUssS0FBSyxDQUFDLE1BQU0sRUFBRTt3QkFDMUIsS0FBSyxHQUFHLElBQUksQ0FBQTtxQkFDYjtpQkFDRjtZQUNILENBQUMsQ0FBQyxDQUFBO1lBRUYsT0FBTyxLQUFLLENBQUE7U0FDYjthQUFNO1lBQ0wsT0FBTyxDQUFDLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1NBQ2pEO0lBQ0gsQ0FBQyxDQUFBO0lBRUQsTUFBTSxlQUFlLEdBQUcsQ0FBQyxLQUEwQixFQUFFLFdBQW1DLElBQUksRUFBNEIsRUFBRTtRQUN4SCxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxFQUFFO1lBQ3BDLE9BQU87Z0JBQ0wsRUFBRSxFQUFFLElBQUksQ0FBQyxFQUFFO2dCQUNYLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtnQkFDZixLQUFLLEVBQUUsWUFBWSxDQUFDLElBQUksQ0FBQztnQkFDekIsUUFBUSxFQUFFLFFBQVE7Z0JBQ2xCLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFFBQVE7Z0JBQ3JDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUU7YUFDOUQsQ0FBQTtRQUNILENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQyxDQUFBO0lBRUQsT0FBTyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUE7QUFDOUIsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hlY2tib3hHcm91cElubmVySXRlbSwgQ2hlY2tib3hHcm91cEl0ZW0gfSBmcm9tICcuLi9tb2RlbHMvY2hlY2tib3gtZ3JvdXAubW9kZWwnO1xyXG5cclxuZXhwb3J0IGNvbnN0IGdldElubmVyTGlzdCA9IChsaXN0OiBDaGVja2JveEdyb3VwSXRlbVtdLCBjaGVja2VkTGlzdDogQ2hlY2tib3hHcm91cEl0ZW1bXSk6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSA9PiB7XHJcbiAgY29uc3QgZ2V0SXRlbVZhbHVlID0gKGl0ZW06IENoZWNrYm94R3JvdXBJdGVtKTogYm9vbGVhbiB8IG51bGwgPT4ge1xyXG4gICAgaWYgKGl0ZW0uaXRlbXMpIHtcclxuICAgICAgbGV0IHZhbHVlOiBib29sZWFuIHwgbnVsbCA9IGZhbHNlXHJcbiAgICAgIGxldCBjb3VudCA9IDBcclxuXHJcbiAgICAgIGl0ZW0uaXRlbXMuZm9yRWFjaCgoaSwgaWR4LCBhcnJheSkgPT4ge1xyXG4gICAgICAgIGlmIChpLml0ZW1zKSB7XHJcbiAgICAgICAgICBpZiAodmFsdWUgPT09IGZhbHNlKSB7XHJcbiAgICAgICAgICAgIHZhbHVlID0gZ2V0SXRlbVZhbHVlKGkpXHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGlmIChjaGVja2VkTGlzdC5maW5kKGMgPT4gYy5pZCA9PT0gaS5pZCkpIHtcclxuICAgICAgICAgICAgY291bnQrK1xyXG5cclxuICAgICAgICAgICAgaWYgKHZhbHVlID09PSBmYWxzZSkge1xyXG4gICAgICAgICAgICAgIHZhbHVlID0gbnVsbFxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBpZiAoaWR4ID09PSBhcnJheS5sZW5ndGggLSAxKSB7XHJcbiAgICAgICAgICBpZiAoY291bnQgPT09IGFycmF5Lmxlbmd0aCkge1xyXG4gICAgICAgICAgICB2YWx1ZSA9IHRydWVcclxuICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgIH0pXHJcblxyXG4gICAgICByZXR1cm4gdmFsdWVcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHJldHVybiAhIWNoZWNrZWRMaXN0LmZpbmQoYyA9PiBjLmlkID09PSBpdGVtLmlkKVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgY29uc3QgZ2V0TW9kaWZpZWRMaXN0ID0gKGl0ZW1zOiBDaGVja2JveEdyb3VwSXRlbVtdLCBwYXJlbnRJZDogc3RyaW5nIHwgbnVtYmVyIHwgbnVsbCA9IG51bGwpOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10gPT4ge1xyXG4gICAgcmV0dXJuIGl0ZW1zLm1hcCgoaXRlbSwgaWR4LCBhcnJheSkgPT4ge1xyXG4gICAgICByZXR1cm4ge1xyXG4gICAgICAgIGlkOiBpdGVtLmlkLFxyXG4gICAgICAgIHRleHQ6IGl0ZW0udGV4dCxcclxuICAgICAgICB2YWx1ZTogZ2V0SXRlbVZhbHVlKGl0ZW0pLFxyXG4gICAgICAgIHBhcmVudElkOiBwYXJlbnRJZCxcclxuICAgICAgICB0eXBlOiBpdGVtLml0ZW1zID8gJ2FycmF5JyA6ICdzaW5nbGUnLFxyXG4gICAgICAgIGl0ZW1zOiBpdGVtLml0ZW1zID8gZ2V0TW9kaWZpZWRMaXN0KGl0ZW0uaXRlbXMsIGl0ZW0uaWQpIDogW11cclxuICAgICAgfVxyXG4gICAgfSlcclxuICB9XHJcblxyXG4gIHJldHVybiBnZXRNb2RpZmllZExpc3QobGlzdClcclxufVxyXG4iXX0=
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
export const
|
|
1
|
+
export const getItemInnerById = (list, itemId) => {
|
|
2
2
|
const findById = (acc, el) => {
|
|
3
3
|
if (el?.id === itemId)
|
|
4
4
|
return el;
|
|
5
|
-
if (el?.
|
|
6
|
-
return el.
|
|
5
|
+
if (el?.items)
|
|
6
|
+
return el.items.reduce(findById, acc);
|
|
7
7
|
return acc;
|
|
8
8
|
};
|
|
9
9
|
return list.reduce(findById, null);
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWl0ZW0tYnktaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9oZWxwZXJzL2dldC1pdGVtLWJ5LWlkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQUMsSUFBOEIsRUFBRSxNQUE4QixFQUFFLEVBQUU7SUFDakcsTUFBTSxRQUFRLEdBQUcsQ0FBQyxHQUFrQyxFQUFFLEVBQWlDLEVBQWlDLEVBQUU7UUFDeEgsSUFBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLE1BQU07WUFBRyxPQUFPLEVBQUUsQ0FBQztRQUNuQyxJQUFLLEVBQUUsRUFBRSxLQUFLO1lBQUcsT0FBTyxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDdkQsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDLENBQUE7SUFFRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ3JDLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoZWNrYm94R3JvdXBJbm5lckl0ZW0sIENoZWNrYm94R3JvdXBJdGVtIH0gZnJvbSAnLi4vbW9kZWxzL2NoZWNrYm94LWdyb3VwLm1vZGVsJztcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRJdGVtSW5uZXJCeUlkID0gKGxpc3Q6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSwgaXRlbUlkOiBzdHJpbmcgfCBudW1iZXIgfCBudWxsKSA9PiB7XHJcbiAgY29uc3QgZmluZEJ5SWQgPSAoYWNjOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtIHwgbnVsbCwgZWw6IENoZWNrYm94R3JvdXBJbm5lckl0ZW0gfCBudWxsKTogQ2hlY2tib3hHcm91cElubmVySXRlbSB8IG51bGwgPT4ge1xyXG4gICAgaWYgKCBlbD8uaWQgPT09IGl0ZW1JZCApIHJldHVybiBlbDtcclxuICAgIGlmICggZWw/Lml0ZW1zICkgcmV0dXJuIGVsLml0ZW1zLnJlZHVjZShmaW5kQnlJZCwgYWNjKTtcclxuICAgIHJldHVybiBhY2M7XHJcbiAgfVxyXG5cclxuICByZXR1cm4gbGlzdC5yZWR1Y2UoZmluZEJ5SWQsIG51bGwpO1xyXG59XHJcbiJdfQ==
|
|
@@ -40,11 +40,11 @@ export const getSortedList = (list, sortable) => {
|
|
|
40
40
|
const sortedList = list.sort(sortedFunc);
|
|
41
41
|
sortedList.forEach((item) => {
|
|
42
42
|
if (item.type === 'array') {
|
|
43
|
-
getSortedListInner(item.
|
|
43
|
+
getSortedListInner(item.items);
|
|
44
44
|
}
|
|
45
45
|
});
|
|
46
46
|
return sortedList;
|
|
47
47
|
};
|
|
48
48
|
return getSortedListInner(list);
|
|
49
49
|
};
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXNvcnRlZC1saXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vY2hlY2tib3gtZ3JvdXAvaGVscGVycy9nZXQtc29ydGVkLWxpc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLENBQUMsSUFBOEIsRUFBRSxRQUFpQixFQUE0QixFQUFFO0lBQzNHLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRO1FBQUUsT0FBTyxJQUFJLENBQUE7SUFFbkMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxJQUE0QixFQUFFLElBQTRCLEVBQUUsRUFBRTtRQUNoRixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxFQUFFO1lBQ3ZCLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxJQUFJLEVBQUU7Z0JBQ3ZCLE9BQU8sQ0FBQyxDQUFBO2FBQ1Q7aUJBQU0sSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO2dCQUNyQixPQUFPLENBQUMsQ0FBQTthQUNUO2lCQUFNO2dCQUNMLE9BQU8sQ0FBQyxDQUFDLENBQUE7YUFDVjtTQUNGO2FBQU0sSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ3JCLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO2dCQUN0QyxPQUFPLENBQUMsQ0FBQyxDQUFBO2FBQ1Y7aUJBQU07Z0JBQ0wsT0FBTyxDQUFDLENBQUE7YUFDVDtTQUNGO2FBQU07WUFDTCxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUU7Z0JBQ3JDLE9BQU8sQ0FBQyxDQUFBO2FBQ1Q7aUJBQU07Z0JBQ0wsSUFBSSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUU7b0JBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztpQkFBQztnQkFDdkMsSUFBSSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUU7b0JBQUMsT0FBTyxDQUFDLENBQUM7aUJBQUM7Z0JBQ3RDLE9BQU8sQ0FBQyxDQUFBO2FBQ1Q7U0FDRjtJQUNILENBQUMsQ0FBQTtJQUVELE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxJQUE4QixFQUFFLEVBQUU7UUFDNUQsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUV4QyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBNEIsRUFBRSxFQUFFO1lBQ2xELElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxPQUFPLEVBQUU7Z0JBQ3pCLGtCQUFrQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTthQUMvQjtRQUNILENBQUMsQ0FBQyxDQUFBO1FBRUYsT0FBTyxVQUFVLENBQUE7SUFDbkIsQ0FBQyxDQUFBO0lBRUQsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsQ0FBQTtBQUNqQyxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGVja2JveEdyb3VwSW5uZXJJdGVtIH0gZnJvbSAnLi4vbW9kZWxzL2NoZWNrYm94LWdyb3VwLm1vZGVsJztcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRTb3J0ZWRMaXN0ID0gKGxpc3Q6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSwgc29ydGFibGU6IGJvb2xlYW4pOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10gPT4ge1xyXG4gIGlmICghbGlzdCB8fCAhc29ydGFibGUpIHJldHVybiBsaXN0XHJcblxyXG4gIGNvbnN0IHNvcnRlZEZ1bmMgPSAocHJldjogQ2hlY2tib3hHcm91cElubmVySXRlbSwgbmV4dDogQ2hlY2tib3hHcm91cElubmVySXRlbSkgPT4ge1xyXG4gICAgaWYgKHByZXYudmFsdWUgPT09IG51bGwpIHtcclxuICAgICAgaWYgKG5leHQudmFsdWUgPT09IG51bGwpIHtcclxuICAgICAgICByZXR1cm4gMFxyXG4gICAgICB9IGVsc2UgaWYgKG5leHQudmFsdWUpIHtcclxuICAgICAgICByZXR1cm4gMVxyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHJldHVybiAtMVxyXG4gICAgICB9XHJcbiAgICB9IGVsc2UgaWYgKHByZXYudmFsdWUpIHtcclxuICAgICAgaWYgKG5leHQudmFsdWUgPT09IG51bGwgfHwgIW5leHQudmFsdWUpIHtcclxuICAgICAgICByZXR1cm4gLTFcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICByZXR1cm4gMFxyXG4gICAgICB9XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICBpZiAobmV4dC52YWx1ZSA9PT0gbnVsbCB8fCBuZXh0LnZhbHVlKSB7XHJcbiAgICAgICAgcmV0dXJuIDFcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBpZiAocHJldi50ZXh0IDwgbmV4dC50ZXh0KSB7cmV0dXJuIC0xO31cclxuICAgICAgICBpZiAocHJldi50ZXh0ID4gbmV4dC50ZXh0KSB7cmV0dXJuIDE7fVxyXG4gICAgICAgIHJldHVybiAwXHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcblxyXG4gIGNvbnN0IGdldFNvcnRlZExpc3RJbm5lciA9IChsaXN0OiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10pID0+IHtcclxuICAgIGNvbnN0IHNvcnRlZExpc3QgPSBsaXN0LnNvcnQoc29ydGVkRnVuYylcclxuXHJcbiAgICBzb3J0ZWRMaXN0LmZvckVhY2goKGl0ZW06IENoZWNrYm94R3JvdXBJbm5lckl0ZW0pID0+IHtcclxuICAgICAgaWYgKGl0ZW0udHlwZSA9PT0gJ2FycmF5Jykge1xyXG4gICAgICAgIGdldFNvcnRlZExpc3RJbm5lcihpdGVtLml0ZW1zKVxyXG4gICAgICB9XHJcbiAgICB9KVxyXG5cclxuICAgIHJldHVybiBzb3J0ZWRMaXN0XHJcbiAgfVxyXG5cclxuICByZXR1cm4gZ2V0U29ydGVkTGlzdElubmVyKGxpc3QpXHJcbn1cclxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZ3JvdXAubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9tb2RlbHMvY2hlY2tib3gtZ3JvdXAubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cEl0ZW0ge1xyXG4gIGlkOiBzdHJpbmcgfCBudW1iZXIsXHJcbiAgdGV4dDogc3RyaW5nLFxyXG4gIGl0ZW1zPzogQ2hlY2tib3hHcm91cEl0ZW1bXSxcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDaGVja2JveEdyb3VwSW5uZXJJdGVtIHtcclxuICBpZDogc3RyaW5nIHwgbnVtYmVyLFxyXG4gIHRleHQ6IHN0cmluZyxcclxuICBwYXJlbnRJZDogc3RyaW5nIHwgbnVtYmVyIHwgbnVsbCxcclxuICB2YWx1ZTogYm9vbGVhbiB8IG51bGwsXHJcbiAgdHlwZTogJ3NpbmdsZScgfCAnYXJyYXknLFxyXG4gIGl0ZW1zOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10sXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENoZWNrYm94SW5kZXRlcm1pbmF0ZVN0YXRlID0gYm9vbGVhbiB8IG51bGxcclxuXHJcbmV4cG9ydCB0eXBlIENoZWNrYm94R3JvdXBTZWFyY2hWYWx1ZSA9IHN0cmluZ1xyXG5cclxuZXhwb3J0IHR5cGUgQW5pbWF0ZUNoZWNrYm94R3JvdXBTdGF0ZSA9ICdvcGVuJyB8ICdjbG9zZScgfCAnc3VzdGFpbidcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cFZhbHVlV2l0aElkIHtcclxuICB2YWx1ZTogQ2hlY2tib3hHcm91cEl0ZW1bXSxcclxuICBpZDogc3RyaW5nXHJcbn1cclxuIl19
|
|
@@ -111,7 +111,8 @@ export class FormulaEditorComponent {
|
|
|
111
111
|
}
|
|
112
112
|
onFocus(event) {
|
|
113
113
|
this.isFocused = true;
|
|
114
|
-
this._detector.
|
|
114
|
+
this._detector.detectChanges();
|
|
115
|
+
this._placeCaretAtEnd();
|
|
115
116
|
}
|
|
116
117
|
onClear() {
|
|
117
118
|
this.updateValue('');
|
|
@@ -328,4 +329,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
328
329
|
type: HostListener,
|
|
329
330
|
args: ['document:click', ['$event']]
|
|
330
331
|
}] } });
|
|
331
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formula-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component, ElementRef, EventEmitter,\r\n  forwardRef, HostListener, Inject, Input,\r\n  Output, ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { ErrorMessagesEnum, ErrorTypeEnum } from './enums/error-messages.enum';\r\nimport { createBracket, createNumber, createOperator, createTag, createTagOutside } from './helpers/create-tags.helper';\r\nimport { isAn } from '../../../helpers/is-number.helper';\r\nimport { WhiteListItemModel, CheckErrorResultModel } from './models';\r\nimport {\r\n  checkBracketErrors,\r\n  checkDividerErrors,\r\n  checkInterpretationErrors,\r\n  checkSequenceErrors\r\n} from './helpers/check-errors.helper';\r\nimport { FormulaEditorValueTypes, FormulaEditorValueWithId } from './models';\r\nimport { FormulaEditorSizesEnum, FormulaEditorSizesTypes } from './enums/formula-editor-size.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-formula-editor',\r\n  templateUrl: './formula-editor.component.html',\r\n  styleUrls: ['./formula-editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => FormulaEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class FormulaEditorComponent implements ControlValueAccessor {\r\n  private _range: any;\r\n  private _selection: Selection | null = null;\r\n  private _cursorPosition: {\r\n    startContainer: Node | null,\r\n    endContainer: Node | null,\r\n    startOffset: number,\r\n    endOffset: number\r\n  } = {\r\n    startContainer: null,\r\n    endContainer: null,\r\n    startOffset: 0,\r\n    endOffset: 0\r\n  };\r\n\r\n  private searchText: string = '';\r\n\r\n  private _operatorList: string[] = ['+', '-', '*', '/'];\r\n  private _bracketList: string[] = ['(', ')'];\r\n  private _itemList: WhiteListItemModel[] = [];\r\n  private _modifiedItemList: { items: { [p: string]: string }, regExp: RegExp } = {\r\n    items: {},\r\n    regExp: new RegExp(''),\r\n  };\r\n\r\n  public value = '';\r\n  public visibleValue = '';\r\n\r\n  public isFocused = false;\r\n\r\n  public errorModel: CheckErrorResultModel = {\r\n    isError: false,\r\n    errorType: ErrorTypeEnum.Default\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public size: FormulaEditorSizesTypes = 'large';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input()\r\n  set items(items: WhiteListItemModel[]) {\r\n    const itemsMap = Object.fromEntries(items.map(obj => [obj.label, obj.sysName]));\r\n\r\n    this._itemList = items;\r\n    this._modifiedItemList.items = itemsMap;\r\n    this._modifiedItemList.regExp = new RegExp(items.map(s => s.label).join('|'), 'g');\r\n\r\n    const {visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n    this.updateVisibleValue(visibleValue);\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  @ViewChild('inputElement', {static: true}) inputElement!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output() public changed: EventEmitter<FormulaEditorValueTypes> = new EventEmitter<FormulaEditorValueTypes>();\r\n  @Output() public blurred: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n  @Output() public modelChange: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: Document,\r\n    private _detector: ChangeDetectorRef,\r\n    private eRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  public get getErrorMessage(): string | string[] {\r\n    return this.invalidMessage || ErrorMessagesEnum[this.errorModel.errorType];\r\n  }\r\n\r\n  public get filteredList(): WhiteListItemModel[] {\r\n    return this._itemList.filter(item => item.label.includes(this.searchText));\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this.errorModel.isError || this.invalid;\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${FormulaEditorSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getIconClass(): string {\r\n    return `${this.size !== 'large' ? 'icon-font-16' : 'icon-font-24'}`;\r\n  }\r\n\r\n  public get canClean(): boolean {\r\n    return !!this.visibleValue.trim();\r\n  }\r\n\r\n  private get _inputValue(): string {\r\n    return this.inputElement.nativeElement.textContent || '';\r\n  }\r\n\r\n  writeValue(outsideValue: FormulaEditorValueTypes): void {\r\n    if (outsideValue !== null && this.value === '') {\r\n      const {visibleValue} = this._transformValue(this._modifiedValue(outsideValue));\r\n\r\n      this.value = outsideValue;\r\n      this.visibleValue = visibleValue;\r\n\r\n      this._detector.detectChanges();\r\n    }\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const {value, searchText} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n    // this.updateValue(value);\r\n\r\n    this.searchText = searchText;\r\n\r\n    this._storeCursorPosition();\r\n  }\r\n\r\n  onFocus(event: Event) {\r\n    this.isFocused = true;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  onClear() {\r\n    this.updateValue('');\r\n    this.updateVisibleValue('');\r\n  }\r\n\r\n  onBlur(event: Event) {\r\n    this._storeCursorPosition();\r\n  }\r\n\r\n  onKeyup(event: any) {\r\n    event.preventDefault();\r\n\r\n    const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n    this.updateValue(value);\r\n    this.updateVisibleValue(visibleValue);\r\n\r\n    this.isFocused = false;\r\n\r\n    this.inputElement.nativeElement.blur();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  insertTag(whiteListItem: WhiteListItemModel) {\r\n    this._restoreCursorPosition(this.inputElement.nativeElement);\r\n    this._insertPositionText(`{${whiteListItem.sysName}}`);\r\n\r\n    setTimeout(() => {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n      this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n    });\r\n\r\n    this._placeCaretAtEnd();\r\n\r\n    this.searchText = '';\r\n  }\r\n\r\n  updateVisibleValue(insideValue: string) {\r\n    this.visibleValue = insideValue;\r\n\r\n    this._storeCursorPosition();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  updateValue(insideValue: string) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n\r\n  private _modifiedValue(value: string): string {\r\n    return value.replace(this._modifiedItemList.regExp, match => {\r\n      return this._modifiedItemList.items[match] ? `{${this._modifiedItemList.items[match]}}` : '';\r\n    });\r\n  }\r\n\r\n  private _transformValue(content: string, analise: boolean = false) {\r\n    const valueArray = content.split(/[\\s\\u00A0]+/).filter(Boolean);\r\n\r\n    const visibleValueArray: string[] = [];\r\n    const originalValueArray: string[] = [];\r\n\r\n    let isInterpretationError = false;\r\n\r\n    let searchText = '';\r\n\r\n    valueArray.forEach((item) => {\r\n      const clearedItem = item.trim();\r\n      const findItem = this._itemList.find(v => clearedItem.includes(v.sysName));\r\n\r\n      if (findItem) {\r\n        visibleValueArray.push(createTag(findItem.label));\r\n        originalValueArray.push(createTagOutside(findItem.sysName));\r\n      } else if (this._bracketList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createBracket(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (this._operatorList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createOperator(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (isAn(clearedItem)) {\r\n        visibleValueArray.push(createNumber(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else {\r\n        visibleValueArray.push(clearedItem);\r\n        originalValueArray.push(clearedItem);\r\n        searchText = clearedItem;\r\n\r\n        isInterpretationError = true;\r\n      }\r\n    });\r\n\r\n    if (analise) {\r\n      this._checkErrors(originalValueArray, isInterpretationError);\r\n    }\r\n\r\n    return {\r\n      value: originalValueArray.join(' '),\r\n      visibleValue: visibleValueArray.join(' '),\r\n      searchText: searchText\r\n    };\r\n  }\r\n\r\n  private _checkErrors(valueArray: string[], isInterpretationError: boolean) {\r\n    this._disableError();\r\n\r\n    this._toggleError(checkBracketErrors(valueArray));\r\n    this._toggleError(checkDividerErrors(valueArray, this._itemList));\r\n    this._toggleError(checkSequenceErrors(valueArray, this._operatorList, this._bracketList));\r\n    this._toggleError(checkInterpretationErrors(isInterpretationError));\r\n  }\r\n\r\n  private _toggleError(errorModel: CheckErrorResultModel) {\r\n    if (!this.errorModel.isError) {\r\n      this.errorModel = errorModel;\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _disableError() {\r\n    this.errorModel = {\r\n      isError: false,\r\n      errorType: ErrorTypeEnum.Default\r\n    };\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _insertPositionText(content: string) {\r\n    const node = document.createTextNode(content);\r\n\r\n    try {\r\n      if (this._range) {\r\n        this._range.deleteContents();\r\n        this._range.insertNode(node);\r\n        this._range = this._range.cloneRange();\r\n        this._range.selectNodeContents(node);\r\n        this._range.collapse(false);\r\n      }\r\n    } catch (e) {\r\n    }\r\n  }\r\n\r\n  private _storeCursorPosition() {\r\n    this._selection = window.getSelection();\r\n\r\n    if (this._selection && this._selection.rangeCount > 0) {\r\n      this._range = this._selection.getRangeAt(0);\r\n\r\n      this._cursorPosition.startContainer = this._range.startContainer;\r\n      this._cursorPosition.endContainer = this._range.endContainer;\r\n      this._cursorPosition.startOffset = this._range.startOffset;\r\n      this._cursorPosition.endOffset = this._range.endOffset;\r\n    }\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _restoreCursorPosition(element: HTMLInputElement) {\r\n    this._range = document.createRange();\r\n\r\n    if (this._cursorPosition.startContainer && this._cursorPosition.endContainer) {\r\n      this._range.setStart(this._cursorPosition.startContainer, this._cursorPosition.startOffset);\r\n      this._range.setEnd(this._cursorPosition.endContainer, this._cursorPosition.endOffset);\r\n    }\r\n  }\r\n\r\n  private _placeCaretAtEnd() {\r\n    setTimeout(() => {\r\n      this._range = document.createRange();\r\n      this._selection = document.getSelection();\r\n\r\n      if (this._selection) {\r\n        this._range.selectNodeContents(this.inputElement.nativeElement);\r\n        this._range.collapse(false);\r\n        this._selection.removeAllRanges();\r\n        this._selection.addRange(this._range);\r\n        this.inputElement.nativeElement.focus();\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  clickOut(event: Event) {\r\n    if (!this.eRef.nativeElement.contains(event.target) && this.isFocused) {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n      this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n\r\n      this.isFocused = false;\r\n      this._detector.detectChanges();\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n}\r\n","<div\r\n  class=\"mrx-formula-editor\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-formula-editor__wrapper\">\r\n    <div\r\n      [innerHTML]=\"visibleValue.trim() | safe\"\r\n      #inputElement\r\n      class=\"mrx-formula-editor__box\"\r\n      contenteditable=\"true\"\r\n      [attr.data-ph]=\"placeholder\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n      (focus)=\"onFocus($event)\"\r\n      (keydown.enter)=\"onKeyup($event)\"\r\n      (keydown.tab)=\"onKeyup($event)\"\r\n    ></div>\r\n\r\n    <div class=\"mrx-formula-editor__clear\" *ngIf=\"canClean\" (click)=\"onClear()\">\r\n      <div class=\"mrx-icon icon-close\" [class]=\"getIconClass\"></div>\r\n    </div>\r\n\r\n    <div class=\"mrx-formula-editor__popup\" *ngIf=\"isFocused\">\r\n      <ng-container *ngIf=\"errorModel.isError && isFocused\">\r\n        <div class=\"mrx-formula-editor__popup--error\">\r\n          {{ getErrorMessage }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"filteredList.length; else emptyList\">\r\n        <div\r\n          class=\"mrx-formula-editor__popup--row\"\r\n          *ngFor=\"let item of filteredList\"\r\n          (click)=\"insertTag(item); $event.stopPropagation()\"\r\n        >\r\n          {{ item.label }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-template #emptyList>\r\n        <div class=\"mrx-formula-editor__popup--row\">\r\n          Нет результатов\r\n        </div>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n\r\n    <mrx-error-message\r\n      *ngIf=\"getInvalid && getErrorMessage && !isFocused\"\r\n      [invalidMessage]=\"getErrorMessage\"\r\n    ></mrx-error-message>\r\n\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
332
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formula-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component, ElementRef, EventEmitter,\r\n  forwardRef, HostListener, Inject, Input,\r\n  Output, ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { ErrorMessagesEnum, ErrorTypeEnum } from './enums/error-messages.enum';\r\nimport { createBracket, createNumber, createOperator, createTag, createTagOutside } from './helpers/create-tags.helper';\r\nimport { isAn } from '../../../helpers/is-number.helper';\r\nimport { WhiteListItemModel, CheckErrorResultModel } from './models';\r\nimport {\r\n  checkBracketErrors,\r\n  checkDividerErrors,\r\n  checkInterpretationErrors,\r\n  checkSequenceErrors\r\n} from './helpers/check-errors.helper';\r\nimport { FormulaEditorValueTypes, FormulaEditorValueWithId } from './models';\r\nimport { FormulaEditorSizesEnum, FormulaEditorSizesTypes } from './enums/formula-editor-size.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-formula-editor',\r\n  templateUrl: './formula-editor.component.html',\r\n  styleUrls: ['./formula-editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => FormulaEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class FormulaEditorComponent implements ControlValueAccessor {\r\n  private _range: any;\r\n  private _selection: Selection | null = null;\r\n  private _cursorPosition: {\r\n    startContainer: Node | null,\r\n    endContainer: Node | null,\r\n    startOffset: number,\r\n    endOffset: number\r\n  } = {\r\n    startContainer: null,\r\n    endContainer: null,\r\n    startOffset: 0,\r\n    endOffset: 0\r\n  };\r\n\r\n  private searchText: string = '';\r\n\r\n  private _operatorList: string[] = ['+', '-', '*', '/'];\r\n  private _bracketList: string[] = ['(', ')'];\r\n  private _itemList: WhiteListItemModel[] = [];\r\n  private _modifiedItemList: { items: { [p: string]: string }, regExp: RegExp } = {\r\n    items: {},\r\n    regExp: new RegExp(''),\r\n  };\r\n\r\n  public value = '';\r\n  public visibleValue = '';\r\n\r\n  public isFocused = false;\r\n\r\n  public errorModel: CheckErrorResultModel = {\r\n    isError: false,\r\n    errorType: ErrorTypeEnum.Default\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public size: FormulaEditorSizesTypes = 'large';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input()\r\n  set items(items: WhiteListItemModel[]) {\r\n    const itemsMap = Object.fromEntries(items.map(obj => [obj.label, obj.sysName]));\r\n\r\n    this._itemList = items;\r\n    this._modifiedItemList.items = itemsMap;\r\n    this._modifiedItemList.regExp = new RegExp(items.map(s => s.label).join('|'), 'g');\r\n\r\n    const {visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n    this.updateVisibleValue(visibleValue);\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  @ViewChild('inputElement', {static: true}) inputElement!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output() public changed: EventEmitter<FormulaEditorValueTypes> = new EventEmitter<FormulaEditorValueTypes>();\r\n  @Output() public blurred: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n  @Output() public modelChange: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: Document,\r\n    private _detector: ChangeDetectorRef,\r\n    private eRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  public get getErrorMessage(): string | string[] {\r\n    return this.invalidMessage || ErrorMessagesEnum[this.errorModel.errorType];\r\n  }\r\n\r\n  public get filteredList(): WhiteListItemModel[] {\r\n    return this._itemList.filter(item => item.label.includes(this.searchText));\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this.errorModel.isError || this.invalid;\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${FormulaEditorSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getIconClass(): string {\r\n    return `${this.size !== 'large' ? 'icon-font-16' : 'icon-font-24'}`;\r\n  }\r\n\r\n  public get canClean(): boolean {\r\n    return !!this.visibleValue.trim();\r\n  }\r\n\r\n  private get _inputValue(): string {\r\n    return this.inputElement.nativeElement.textContent || '';\r\n  }\r\n\r\n  writeValue(outsideValue: FormulaEditorValueTypes): void {\r\n    if (outsideValue !== null && this.value === '') {\r\n      const {visibleValue} = this._transformValue(this._modifiedValue(outsideValue));\r\n\r\n      this.value = outsideValue;\r\n      this.visibleValue = visibleValue;\r\n\r\n      this._detector.detectChanges();\r\n    }\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const {value, searchText} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n    // this.updateValue(value);\r\n\r\n    this.searchText = searchText;\r\n\r\n    this._storeCursorPosition();\r\n  }\r\n\r\n  onFocus(event: Event) {\r\n    this.isFocused = true;\r\n\r\n    this._detector.detectChanges();\r\n\r\n    this._placeCaretAtEnd();\r\n  }\r\n\r\n  onClear() {\r\n    this.updateValue('');\r\n    this.updateVisibleValue('');\r\n  }\r\n\r\n  onBlur(event: Event) {\r\n    this._storeCursorPosition();\r\n  }\r\n\r\n  onKeyup(event: any) {\r\n    event.preventDefault();\r\n\r\n    const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n    this.updateValue(value);\r\n    this.updateVisibleValue(visibleValue);\r\n\r\n    this.isFocused = false;\r\n\r\n    this.inputElement.nativeElement.blur();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  insertTag(whiteListItem: WhiteListItemModel) {\r\n    this._restoreCursorPosition(this.inputElement.nativeElement);\r\n    this._insertPositionText(`{${whiteListItem.sysName}}`);\r\n\r\n    setTimeout(() => {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n      this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n    });\r\n\r\n    this._placeCaretAtEnd();\r\n\r\n    this.searchText = '';\r\n  }\r\n\r\n  updateVisibleValue(insideValue: string) {\r\n    this.visibleValue = insideValue;\r\n\r\n    this._storeCursorPosition();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  updateValue(insideValue: string) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n\r\n  private _modifiedValue(value: string): string {\r\n    return value.replace(this._modifiedItemList.regExp, match => {\r\n      return this._modifiedItemList.items[match] ? `{${this._modifiedItemList.items[match]}}` : '';\r\n    });\r\n  }\r\n\r\n  private _transformValue(content: string, analise: boolean = false) {\r\n    const valueArray = content.split(/[\\s\\u00A0]+/).filter(Boolean);\r\n\r\n    const visibleValueArray: string[] = [];\r\n    const originalValueArray: string[] = [];\r\n\r\n    let isInterpretationError = false;\r\n\r\n    let searchText = '';\r\n\r\n    valueArray.forEach((item) => {\r\n      const clearedItem = item.trim();\r\n      const findItem = this._itemList.find(v => clearedItem.includes(v.sysName));\r\n\r\n      if (findItem) {\r\n        visibleValueArray.push(createTag(findItem.label));\r\n        originalValueArray.push(createTagOutside(findItem.sysName));\r\n      } else if (this._bracketList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createBracket(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (this._operatorList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createOperator(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (isAn(clearedItem)) {\r\n        visibleValueArray.push(createNumber(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else {\r\n        visibleValueArray.push(clearedItem);\r\n        originalValueArray.push(clearedItem);\r\n        searchText = clearedItem;\r\n\r\n        isInterpretationError = true;\r\n      }\r\n    });\r\n\r\n    if (analise) {\r\n      this._checkErrors(originalValueArray, isInterpretationError);\r\n    }\r\n\r\n    return {\r\n      value: originalValueArray.join(' '),\r\n      visibleValue: visibleValueArray.join(' '),\r\n      searchText: searchText\r\n    };\r\n  }\r\n\r\n  private _checkErrors(valueArray: string[], isInterpretationError: boolean) {\r\n    this._disableError();\r\n\r\n    this._toggleError(checkBracketErrors(valueArray));\r\n    this._toggleError(checkDividerErrors(valueArray, this._itemList));\r\n    this._toggleError(checkSequenceErrors(valueArray, this._operatorList, this._bracketList));\r\n    this._toggleError(checkInterpretationErrors(isInterpretationError));\r\n  }\r\n\r\n  private _toggleError(errorModel: CheckErrorResultModel) {\r\n    if (!this.errorModel.isError) {\r\n      this.errorModel = errorModel;\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _disableError() {\r\n    this.errorModel = {\r\n      isError: false,\r\n      errorType: ErrorTypeEnum.Default\r\n    };\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _insertPositionText(content: string) {\r\n    const node = document.createTextNode(content);\r\n\r\n    try {\r\n      if (this._range) {\r\n        this._range.deleteContents();\r\n        this._range.insertNode(node);\r\n        this._range = this._range.cloneRange();\r\n        this._range.selectNodeContents(node);\r\n        this._range.collapse(false);\r\n      }\r\n    } catch (e) {\r\n    }\r\n  }\r\n\r\n  private _storeCursorPosition() {\r\n    this._selection = window.getSelection();\r\n\r\n    if (this._selection && this._selection.rangeCount > 0) {\r\n      this._range = this._selection.getRangeAt(0);\r\n\r\n      this._cursorPosition.startContainer = this._range.startContainer;\r\n      this._cursorPosition.endContainer = this._range.endContainer;\r\n      this._cursorPosition.startOffset = this._range.startOffset;\r\n      this._cursorPosition.endOffset = this._range.endOffset;\r\n    }\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _restoreCursorPosition(element: HTMLInputElement) {\r\n    this._range = document.createRange();\r\n\r\n    if (this._cursorPosition.startContainer && this._cursorPosition.endContainer) {\r\n      this._range.setStart(this._cursorPosition.startContainer, this._cursorPosition.startOffset);\r\n      this._range.setEnd(this._cursorPosition.endContainer, this._cursorPosition.endOffset);\r\n    }\r\n  }\r\n\r\n  private _placeCaretAtEnd() {\r\n    setTimeout(() => {\r\n      this._range = document.createRange();\r\n      this._selection = document.getSelection();\r\n\r\n      if (this._selection) {\r\n        this._range.selectNodeContents(this.inputElement.nativeElement);\r\n        this._range.collapse(false);\r\n        this._selection.removeAllRanges();\r\n        this._selection.addRange(this._range);\r\n        this.inputElement.nativeElement.focus();\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  clickOut(event: Event) {\r\n    if (!this.eRef.nativeElement.contains(event.target) && this.isFocused) {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n      this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n\r\n      this.isFocused = false;\r\n      this._detector.detectChanges();\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n}\r\n","<div\r\n  class=\"mrx-formula-editor\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-formula-editor__wrapper\">\r\n    <div\r\n      [innerHTML]=\"visibleValue.trim() | safe\"\r\n      #inputElement\r\n      class=\"mrx-formula-editor__box\"\r\n      contenteditable=\"true\"\r\n      [attr.data-ph]=\"placeholder\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n      (focus)=\"onFocus($event)\"\r\n      (keydown.enter)=\"onKeyup($event)\"\r\n      (keydown.tab)=\"onKeyup($event)\"\r\n    ></div>\r\n\r\n    <div class=\"mrx-formula-editor__clear\" *ngIf=\"canClean\" (click)=\"onClear()\">\r\n      <div class=\"mrx-icon icon-close\" [class]=\"getIconClass\"></div>\r\n    </div>\r\n\r\n    <div class=\"mrx-formula-editor__popup\" *ngIf=\"isFocused\">\r\n      <ng-container *ngIf=\"errorModel.isError && isFocused\">\r\n        <div class=\"mrx-formula-editor__popup--error\">\r\n          {{ getErrorMessage }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"filteredList.length; else emptyList\">\r\n        <div\r\n          class=\"mrx-formula-editor__popup--row\"\r\n          *ngFor=\"let item of filteredList\"\r\n          (click)=\"insertTag(item); $event.stopPropagation()\"\r\n        >\r\n          {{ item.label }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-template #emptyList>\r\n        <div class=\"mrx-formula-editor__popup--row\">\r\n          Нет результатов\r\n        </div>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n\r\n    <mrx-error-message\r\n      *ngIf=\"getInvalid && getErrorMessage && !isFocused\"\r\n      [invalidMessage]=\"getErrorMessage\"\r\n    ></mrx-error-message>\r\n\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -71,7 +71,7 @@ export class InputTextComponent {
|
|
|
71
71
|
return this.maxlength > this.value?.length;
|
|
72
72
|
}
|
|
73
73
|
formatValue(value) {
|
|
74
|
-
return value.length === this.maskPrefix.length ? '' : value;
|
|
74
|
+
return value ? value.length === this.maskPrefix.length ? '' : value : '';
|
|
75
75
|
}
|
|
76
76
|
insertPositionText(tagText) {
|
|
77
77
|
if (this.selectionStart && this.selectionEnd) {
|
|
@@ -191,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
191
191
|
}], modelChange: [{
|
|
192
192
|
type: Output
|
|
193
193
|
}] } });
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  InputTextIconColorEnum,\r\n  InputTextIconColorTypes,\r\n  InputTextSizesEnum,\r\n  InputTextSizesTypes,\r\n  InputTextValueTypes,\r\n  InputTextValueWithId\r\n} from './input-text.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\n\r\n@Component({\r\n  selector: 'mrx-input-text',\r\n  templateUrl: './input-text.component.html',\r\n  styleUrls: ['./input-text.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextComponent implements ControlValueAccessor {\r\n  public value: InputTextValueTypes = '';\r\n  public selectionStart: number | undefined;\r\n  public selectionEnd: number | undefined;\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4()\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public required = false;\r\n  @Input() public readonly = false;\r\n  @Input() public maxlength = 0;\r\n  @Input() public minlength = 0;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public size: InputTextSizesTypes = 'large';\r\n  @Input() public isTooltipValue = false;\r\n  @Input() public icon: string | null = null;\r\n  @Input() public iconColor: InputTextIconColorTypes = 'default';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input() public restrictInput = true;\r\n\r\n  // MASK\r\n  @Input() mask = '';\r\n  @Input() maskPrefix = '';\r\n  @Input() showMaskTyped = false;\r\n  @Input() maskDropSpecialCharacters: boolean | string[] = true;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<InputTextValueTypes> = new EventEmitter<InputTextValueTypes>();\r\n  @Output() public blurred: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n  @Output() public modelChange: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n\r\n  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this._isInvalidValueLength || this.invalid\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : ''\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputTextSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getIconClass(): string {\r\n    return `${this.icon} ${this.size !== 'small' ? 'icon-font-24' : 'icon-font-16'} ${InputTextIconColorEnum[this.iconColor]}`\r\n  }\r\n\r\n  public get getTooltipValue(): string {\r\n    return this.isTooltipValue ? this.value : ''\r\n  }\r\n\r\n  private _lengthValidate(): boolean {\r\n    return this.maxlength > this.value?.length\r\n  }\r\n\r\n  private formatValue(value: string): string {\r\n    return value.length === this.maskPrefix.length ? '' : value\r\n  }\r\n\r\n  public insertPositionText(tagText: string): void {\r\n    if (this.selectionStart && this.selectionEnd) {\r\n      const firstText = this.value ? this.value.substring(0, this.selectionStart) : ''\r\n      const secondText = this.value.substring(this.selectionEnd);\r\n      const text = firstText + tagText + secondText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.selectionEnd = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    } else {\r\n      const text = this.value ? this.value : '' + tagText\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = text.length;\r\n        this.inputElement.nativeElement.selectionEnd = text.length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  public updateSelection(event: any) {\r\n    this.selectionStart = event.target.selectionStart;\r\n    this.selectionEnd = event.target.selectionEnd;\r\n\r\n    this.blurred.emit()\r\n  }\r\n\r\n  private onChange = (value: InputTextValueTypes) => {};\r\n  private onTouched = () => {};\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public writeValue(outsideValue: InputTextValueTypes) {\r\n    this.value = outsideValue;\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  public updateValue(insideValue: InputTextValueTypes) {\r\n    this.value = insideValue;\r\n    this.changed.emit(this.formatValue(insideValue));\r\n    this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})\r\n    this.onChange(this.formatValue(insideValue));\r\n    this.onTouched();\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.updateSelection(event)\r\n    this.blurred.emit({value: this.formatValue(this.value), id: this.uuid})\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-text\"\r\n  [class]=\"getClasses\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.mrx-input-text-with-icon]=\"icon\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [mrxCdkTooltip]=\"getTooltipValue\"\r\n  [tooltipPosition]=\"'top-start'\"\r\n>\r\n  <div class=\"mrx-input-text__wrapper\">\r\n    <span *ngIf=\"icon\" class=\"mrx-icon mrx-input-text-icon\" [class]=\"getIconClass\"></span>\r\n\r\n    <input\r\n      autocomplete=\"nope\"\r\n      #inputElement\r\n      [type]=\"'text'\"\r\n      [id]=\"uuid\"\r\n      [ngModel]=\"value\"\r\n      [title]=\"placeholder || ''\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"readonly\"\r\n      [placeholder]=\"!disabled && placeholder ? placeholder : ''\"\r\n      [mask]=\"mask\"\r\n      [prefix]=\"maskPrefix\"\r\n      [showMaskTyped]=\"showMaskTyped\"\r\n      [dropSpecialCharacters]=\"maskDropSpecialCharacters\"\r\n      [minlength]=\"minlength > 0 && restrictInput ? minlength : null\"\r\n      [maxlength]=\"maxlength > 0 && restrictInput ? maxlength : null\"\r\n      (ngModelChange)=\"updateValue($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n    />\r\n\r\n    <mrx-chars-left\r\n      *ngIf=\"!disabled && maxlength\"\r\n      [value]=\"value\"\r\n      [maxlength]=\"maxlength\"\r\n    ></mrx-chars-left>\r\n  </div>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  InputTextIconColorEnum,\r\n  InputTextIconColorTypes,\r\n  InputTextSizesEnum,\r\n  InputTextSizesTypes,\r\n  InputTextValueTypes,\r\n  InputTextValueWithId\r\n} from './input-text.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\n\r\n@Component({\r\n  selector: 'mrx-input-text',\r\n  templateUrl: './input-text.component.html',\r\n  styleUrls: ['./input-text.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextComponent implements ControlValueAccessor {\r\n  public value: InputTextValueTypes = '';\r\n  public selectionStart: number | undefined;\r\n  public selectionEnd: number | undefined;\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4()\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public required = false;\r\n  @Input() public readonly = false;\r\n  @Input() public maxlength = 0;\r\n  @Input() public minlength = 0;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public size: InputTextSizesTypes = 'large';\r\n  @Input() public isTooltipValue = false;\r\n  @Input() public icon: string | null = null;\r\n  @Input() public iconColor: InputTextIconColorTypes = 'default';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input() public restrictInput = true;\r\n\r\n  // MASK\r\n  @Input() mask = '';\r\n  @Input() maskPrefix = '';\r\n  @Input() showMaskTyped = false;\r\n  @Input() maskDropSpecialCharacters: boolean | string[] = true;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<InputTextValueTypes> = new EventEmitter<InputTextValueTypes>();\r\n  @Output() public blurred: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n  @Output() public modelChange: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n\r\n  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this._isInvalidValueLength || this.invalid\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : ''\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputTextSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getIconClass(): string {\r\n    return `${this.icon} ${this.size !== 'small' ? 'icon-font-24' : 'icon-font-16'} ${InputTextIconColorEnum[this.iconColor]}`\r\n  }\r\n\r\n  public get getTooltipValue(): string {\r\n    return this.isTooltipValue ? this.value : ''\r\n  }\r\n\r\n  private _lengthValidate(): boolean {\r\n    return this.maxlength > this.value?.length\r\n  }\r\n\r\n  private formatValue(value: string): string {\r\n    return value ? value.length === this.maskPrefix.length ? '' : value : ''\r\n  }\r\n\r\n  public insertPositionText(tagText: string): void {\r\n    if (this.selectionStart && this.selectionEnd) {\r\n      const firstText = this.value ? this.value.substring(0, this.selectionStart) : ''\r\n      const secondText = this.value.substring(this.selectionEnd);\r\n      const text = firstText + tagText + secondText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.selectionEnd = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    } else {\r\n      const text = this.value ? this.value : '' + tagText\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = text.length;\r\n        this.inputElement.nativeElement.selectionEnd = text.length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  public updateSelection(event: any) {\r\n    this.selectionStart = event.target.selectionStart;\r\n    this.selectionEnd = event.target.selectionEnd;\r\n\r\n    this.blurred.emit()\r\n  }\r\n\r\n  private onChange = (value: InputTextValueTypes) => {};\r\n  private onTouched = () => {};\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public writeValue(outsideValue: InputTextValueTypes) {\r\n    this.value = outsideValue;\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  public updateValue(insideValue: InputTextValueTypes) {\r\n    this.value = insideValue;\r\n    this.changed.emit(this.formatValue(insideValue));\r\n    this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})\r\n    this.onChange(this.formatValue(insideValue));\r\n    this.onTouched();\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.updateSelection(event)\r\n    this.blurred.emit({value: this.formatValue(this.value), id: this.uuid})\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-text\"\r\n  [class]=\"getClasses\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.mrx-input-text-with-icon]=\"icon\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [mrxCdkTooltip]=\"getTooltipValue\"\r\n  [tooltipPosition]=\"'top-start'\"\r\n>\r\n  <div class=\"mrx-input-text__wrapper\">\r\n    <span *ngIf=\"icon\" class=\"mrx-icon mrx-input-text-icon\" [class]=\"getIconClass\"></span>\r\n\r\n    <input\r\n      autocomplete=\"nope\"\r\n      #inputElement\r\n      [type]=\"'text'\"\r\n      [id]=\"uuid\"\r\n      [ngModel]=\"value\"\r\n      [title]=\"placeholder || ''\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"readonly\"\r\n      [placeholder]=\"!disabled && placeholder ? placeholder : ''\"\r\n      [mask]=\"mask\"\r\n      [prefix]=\"maskPrefix\"\r\n      [showMaskTyped]=\"showMaskTyped\"\r\n      [dropSpecialCharacters]=\"maskDropSpecialCharacters\"\r\n      [minlength]=\"minlength > 0 && restrictInput ? minlength : null\"\r\n      [maxlength]=\"maxlength > 0 && restrictInput ? maxlength : null\"\r\n      (ngModelChange)=\"updateValue($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n    />\r\n\r\n    <mrx-chars-left\r\n      *ngIf=\"!disabled && maxlength\"\r\n      [value]=\"value\"\r\n      [maxlength]=\"maxlength\"\r\n    ></mrx-chars-left>\r\n  </div>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -35,10 +35,10 @@ export class RadioGroupItemComponent {
|
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
RadioGroupItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: RadioGroupItemComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
-
RadioGroupItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: RadioGroupItemComponent, selector: "mrx-radio-group-item", inputs: { invalid: "invalid", name: "name", selectedValue: "selectedValue", item: "item", displaced: "displaced", level: "level", bold: "bold", animationTrigger: "animationTrigger", isLast: "isLast", disabled: "disabled", readonly: "readonly" }, outputs: { animationEnd: "animationEnd", radioChanged: "radioChanged" }, ngImport: i0, template: "<div class=\"mrx-radio-group__item\" [class.mrx-radio-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-radio-group__item--array\" *ngIf=\"item.array.length && level < 10; else singleradioTemplate\">\r\n <div class=\"mrx-radio-group__item--array-head mb-12px\">\r\n\r\n <mrx-radio\r\n [ngModel]=\"selectedValue?.id\"\r\n [value]=\"item.id\"\r\n [name]=\"name\"\r\n [boldLabel]=\"bold\"\r\n [invalid]=\"invalid\"\r\n
|
|
38
|
+
RadioGroupItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: RadioGroupItemComponent, selector: "mrx-radio-group-item", inputs: { invalid: "invalid", name: "name", selectedValue: "selectedValue", item: "item", displaced: "displaced", level: "level", bold: "bold", animationTrigger: "animationTrigger", isLast: "isLast", disabled: "disabled", readonly: "readonly" }, outputs: { animationEnd: "animationEnd", radioChanged: "radioChanged" }, ngImport: i0, template: "<div class=\"mrx-radio-group__item\" [class.mrx-radio-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-radio-group__item--array\" *ngIf=\"item.array.length && level < 10; else singleradioTemplate\">\r\n <div class=\"mrx-radio-group__item--array-head mb-12px\">\r\n\r\n <mrx-radio\r\n [ngModel]=\"selectedValue?.id\"\r\n [value]=\"item.id\"\r\n [name]=\"name\"\r\n [boldLabel]=\"bold\"\r\n [invalid]=\"invalid\"\r\n (ngModelChange)=\"radioChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-radio>\r\n </div>\r\n\r\n <div class=\"mrx-radio-group__item--array-list\">\r\n <ng-container>\r\n <mrx-radio-group-item\r\n *ngFor=\"let child of item.array; trackBy: trackByFn\"\r\n [level]=\"level + 1\"\r\n [selectedValue]=\"selectedValue\"\r\n [item]=\"child\"\r\n [invalid]=\"invalid\"\r\n [bold]=\"bold\"\r\n [name]=\"name\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [animationTrigger]=\"animationTrigger\"\r\n (radioChanged)=\"radioChanged.emit($event)\"\r\n ></mrx-radio-group-item>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <ng-template #singleradioTemplate>\r\n <div class=\"mrx-radio-group__item--single\">\r\n <mrx-radio\r\n [ngModel]=\"selectedValue?.id\"\r\n [name]=\"name\"\r\n [boldLabel]=\"bold\"\r\n [type]=\"'default'\"\r\n [value]=\"item.id\"\r\n [invalid]=\"invalid\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n (ngModelChange)=\"radioChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-radio>\r\n </div>\r\n </ng-template>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-radio-group__item--array-head{display:flex;justify-content:flex-start;align-items:center}.mrx-radio-group__item--array-list{padding-left:20px}.mrx-radio-group__item--buttom-ident{margin-bottom:12px}\n"], components: [{ type: i1.RadioComponent, selector: "mrx-radio", inputs: ["required", "type", "name", "boldLabel", "disabled", "readonly", "placeholder", "label", "customClasses", "invalid", "value"] }, { type: RadioGroupItemComponent, selector: "mrx-radio-group-item", inputs: ["invalid", "name", "selectedValue", "item", "displaced", "level", "bold", "animationTrigger", "isLast", "disabled", "readonly"], outputs: ["animationEnd", "radioChanged"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
39
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: RadioGroupItemComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
|
-
args: [{ selector: 'mrx-radio-group-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-radio-group__item\" [class.mrx-radio-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-radio-group__item--array\" *ngIf=\"item.array.length && level < 10; else singleradioTemplate\">\r\n <div class=\"mrx-radio-group__item--array-head mb-12px\">\r\n\r\n <mrx-radio\r\n [ngModel]=\"selectedValue?.id\"\r\n [value]=\"item.id\"\r\n [name]=\"name\"\r\n [boldLabel]=\"bold\"\r\n [invalid]=\"invalid\"\r\n
|
|
41
|
+
args: [{ selector: 'mrx-radio-group-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-radio-group__item\" [class.mrx-radio-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-radio-group__item--array\" *ngIf=\"item.array.length && level < 10; else singleradioTemplate\">\r\n <div class=\"mrx-radio-group__item--array-head mb-12px\">\r\n\r\n <mrx-radio\r\n [ngModel]=\"selectedValue?.id\"\r\n [value]=\"item.id\"\r\n [name]=\"name\"\r\n [boldLabel]=\"bold\"\r\n [invalid]=\"invalid\"\r\n (ngModelChange)=\"radioChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-radio>\r\n </div>\r\n\r\n <div class=\"mrx-radio-group__item--array-list\">\r\n <ng-container>\r\n <mrx-radio-group-item\r\n *ngFor=\"let child of item.array; trackBy: trackByFn\"\r\n [level]=\"level + 1\"\r\n [selectedValue]=\"selectedValue\"\r\n [item]=\"child\"\r\n [invalid]=\"invalid\"\r\n [bold]=\"bold\"\r\n [name]=\"name\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [animationTrigger]=\"animationTrigger\"\r\n (radioChanged)=\"radioChanged.emit($event)\"\r\n ></mrx-radio-group-item>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <ng-template #singleradioTemplate>\r\n <div class=\"mrx-radio-group__item--single\">\r\n <mrx-radio\r\n [ngModel]=\"selectedValue?.id\"\r\n [name]=\"name\"\r\n [boldLabel]=\"bold\"\r\n [type]=\"'default'\"\r\n [value]=\"item.id\"\r\n [invalid]=\"invalid\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n (ngModelChange)=\"radioChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-radio>\r\n </div>\r\n </ng-template>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-radio-group__item--array-head{display:flex;justify-content:flex-start;align-items:center}.mrx-radio-group__item--array-list{padding-left:20px}.mrx-radio-group__item--buttom-ident{margin-bottom:12px}\n"] }]
|
|
42
42
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { invalid: [{
|
|
43
43
|
type: Input
|
|
44
44
|
}], name: [{
|
|
@@ -66,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
66
66
|
}], radioChanged: [{
|
|
67
67
|
type: Output
|
|
68
68
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tZ3JvdXAtaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9yYWRpby1ncm91cC9jb21wb25lbnRzL3JhZGlvLWdyb3VwLWl0ZW0vcmFkaW8tZ3JvdXAtaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9yYWRpby1ncm91cC9jb21wb25lbnRzL3JhZGlvLWdyb3VwLWl0ZW0vcmFkaW8tZ3JvdXAtaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBRXZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFTdkIsTUFBTSxPQUFPLHVCQUF1QjtJQWtCbEMsWUFBb0IsUUFBMkI7UUFBM0IsYUFBUSxHQUFSLFFBQVEsQ0FBbUI7UUFoQi9CLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDdkIsU0FBSSxHQUFXLEVBQUUsQ0FBQztRQUNsQixrQkFBYSxHQUEwQixJQUFJLENBQUM7UUFFNUMsY0FBUyxHQUFHLEtBQUssQ0FBQTtRQUNqQixVQUFLLEdBQUcsQ0FBQyxDQUFBO1FBQ0YsU0FBSSxHQUFHLEtBQUssQ0FBQztRQUNwQixxQkFBZ0IsR0FBbUIsSUFBSSxDQUFBO1FBRWhDLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVoQixpQkFBWSxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO1FBQzVELGlCQUFZLEdBQzNCLElBQUksWUFBWSxFQUE0RCxDQUFDO0lBRy9FLENBQUM7SUFFRCxJQUFXLGVBQWU7UUFDeEIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxJQUFJLENBQUE7SUFDOUIsQ0FBQztJQUVNLFNBQVMsQ0FBQyxLQUFhLEVBQUUsSUFBb0I7UUFDbEQsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxLQUE4QixFQUFFLElBQW9CO1FBQzFFLElBQUksSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUN4QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQTtTQUMvQzthQUFNO1lBQ0wsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUE7U0FDL0M7UUFFRCxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsRUFBRSxDQUFBO0lBQy9CLENBQUM7O29IQXJDVSx1QkFBdUI7d0dBQXZCLHVCQUF1QiwyWENoQnBDLDh5REFtREEsOGFEbkNhLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLHNCQUFzQixtQkFHZix1QkFBdUIsQ0FBQyxNQUFNO3dHQUkvQixPQUFPO3NCQUF0QixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDVSxJQUFJO3NCQUFuQixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ1UsUUFBUTtzQkFBdkIsS0FBSztnQkFDVSxRQUFRO3NCQUF2QixLQUFLO2dCQUVXLFlBQVk7c0JBQTVCLE1BQU07Z0JBQ1UsWUFBWTtzQkFBNUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbnB1dCxcclxuICBPdXRwdXQsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJhZGlvR3JvdXBJdGVtLCBSYWRpb0luZGV0ZXJtaW5hdGVTdGF0ZSB9IGZyb20gJy4uLy4uL21vZGVscy9yYWRpby1ncm91cC5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21yeC1yYWRpby1ncm91cC1pdGVtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vcmFkaW8tZ3JvdXAtaXRlbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vcmFkaW8tZ3JvdXAtaXRlbS5jb21wb25lbnQubGVzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSYWRpb0dyb3VwSXRlbUNvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIHB1YmxpYyBpbnZhbGlkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgbmFtZTogc3RyaW5nID0gJyc7XHJcbiAgQElucHV0KCkgc2VsZWN0ZWRWYWx1ZTogUmFkaW9Hcm91cEl0ZW0gfCBudWxsID0gbnVsbDtcclxuICBASW5wdXQoKSBpdGVtITogUmFkaW9Hcm91cEl0ZW1cclxuICBASW5wdXQoKSBkaXNwbGFjZWQgPSBmYWxzZVxyXG4gIEBJbnB1dCgpIGxldmVsID0gMFxyXG4gIEBJbnB1dCgpIHB1YmxpYyBib2xkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgYW5pbWF0aW9uVHJpZ2dlcjogYm9vbGVhbiB8IG51bGwgPSBudWxsXHJcbiAgQElucHV0KCkgaXNMYXN0ITogYm9vbGVhblxyXG4gIEBJbnB1dCgpIHB1YmxpYyBkaXNhYmxlZCA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIHB1YmxpYyByZWFkb25seSA9IGZhbHNlO1xyXG5cclxuICBAT3V0cHV0KCkgcHVibGljIGFuaW1hdGlvbkVuZDogRXZlbnRFbWl0dGVyPG51bGw+ID0gbmV3IEV2ZW50RW1pdHRlcjxudWxsPigpO1xyXG4gIEBPdXRwdXQoKSBwdWJsaWMgcmFkaW9DaGFuZ2VkOiBFdmVudEVtaXR0ZXI8eyB2YWx1ZTogUmFkaW9JbmRldGVybWluYXRlU3RhdGUsIGl0ZW06IFJhZGlvR3JvdXBJdGVtIH0+ID1cclxuICAgIG5ldyBFdmVudEVtaXR0ZXI8eyB2YWx1ZTogUmFkaW9JbmRldGVybWluYXRlU3RhdGUsIGl0ZW06IFJhZGlvR3JvdXBJdGVtIH0+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGlzSW5kZXRlcm1pbmF0ZSgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLml0ZW0uaWQgPT09IG51bGxcclxuICB9XHJcblxyXG4gIHB1YmxpYyB0cmFja0J5Rm4oaW5kZXg6IG51bWJlciwgaXRlbTogUmFkaW9Hcm91cEl0ZW0pIHtcclxuICAgIHJldHVybiBpdGVtLmlkO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHJhZGlvQ2hhbmdlTW9kZWwodmFsdWU6IFJhZGlvSW5kZXRlcm1pbmF0ZVN0YXRlLCBpdGVtOiBSYWRpb0dyb3VwSXRlbSk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMuaXNJbmRldGVybWluYXRlKSB7XHJcbiAgICAgIHRoaXMucmFkaW9DaGFuZ2VkLmVtaXQoeyB2YWx1ZTogZmFsc2UsIGl0ZW0gfSlcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMucmFkaW9DaGFuZ2VkLmVtaXQoeyB2YWx1ZTogdmFsdWUsIGl0ZW0gfSlcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLmRldGVjdG9yLmRldGVjdENoYW5nZXMoKVxyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwibXJ4LXJhZGlvLWdyb3VwX19pdGVtXCIgW2NsYXNzLm1yeC1yYWRpby1ncm91cF9faXRlbS0tYnV0dG9tLWlkZW50XT1cIiFpc0xhc3RcIj5cclxuICA8ZGl2IGNsYXNzPVwibXJ4LXJhZGlvLWdyb3VwX19pdGVtLS1hcnJheVwiICpuZ0lmPVwiaXRlbS5hcnJheS5sZW5ndGggJiYgbGV2ZWwgPCAxMDsgZWxzZSBzaW5nbGVyYWRpb1RlbXBsYXRlXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwibXJ4LXJhZGlvLWdyb3VwX19pdGVtLS1hcnJheS1oZWFkIG1iLTEycHhcIj5cclxuXHJcbiAgICAgIDxtcngtcmFkaW9cclxuICAgICAgICAgIFtuZ01vZGVsXT1cInNlbGVjdGVkVmFsdWU/LmlkXCJcclxuICAgICAgICAgIFt2YWx1ZV09XCJpdGVtLmlkXCJcclxuICAgICAgICAgIFtuYW1lXT1cIm5hbWVcIlxyXG4gICAgICAgICAgW2JvbGRMYWJlbF09XCJib2xkXCJcclxuICAgICAgICAgIFtpbnZhbGlkXT1cImludmFsaWRcIlxyXG4gICAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwicmFkaW9DaGFuZ2VNb2RlbCgkZXZlbnQsIGl0ZW0pXCJcclxuICAgICAgPnt7IGl0ZW0udGV4dCB9fTwvbXJ4LXJhZGlvPlxyXG4gICAgPC9kaXY+XHJcblxyXG4gICAgPGRpdiBjbGFzcz1cIm1yeC1yYWRpby1ncm91cF9faXRlbS0tYXJyYXktbGlzdFwiPlxyXG4gICAgICA8bmctY29udGFpbmVyPlxyXG4gICAgICAgIDxtcngtcmFkaW8tZ3JvdXAtaXRlbVxyXG4gICAgICAgICAgICAqbmdGb3I9XCJsZXQgY2hpbGQgb2YgaXRlbS5hcnJheTsgdHJhY2tCeTogdHJhY2tCeUZuXCJcclxuICAgICAgICAgICAgW2xldmVsXT1cImxldmVsICsgMVwiXHJcbiAgICAgICAgICAgIFtzZWxlY3RlZFZhbHVlXT1cInNlbGVjdGVkVmFsdWVcIlxyXG4gICAgICAgICAgICBbaXRlbV09XCJjaGlsZFwiXHJcbiAgICAgICAgICAgIFtpbnZhbGlkXT1cImludmFsaWRcIlxyXG4gICAgICAgICAgICBbYm9sZF09XCJib2xkXCJcclxuICAgICAgICAgICAgW25hbWVdPVwibmFtZVwiXHJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXHJcbiAgICAgICAgICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiXHJcbiAgICAgICAgICAgIFthbmltYXRpb25UcmlnZ2VyXT1cImFuaW1hdGlvblRyaWdnZXJcIlxyXG4gICAgICAgICAgICAocmFkaW9DaGFuZ2VkKT1cInJhZGlvQ2hhbmdlZC5lbWl0KCRldmVudClcIlxyXG4gICAgICAgID48L21yeC1yYWRpby1ncm91cC1pdGVtPlxyXG4gICAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG5cclxuICA8bmctdGVtcGxhdGUgI3NpbmdsZXJhZGlvVGVtcGxhdGU+XHJcbiAgICA8ZGl2IGNsYXNzPVwibXJ4LXJhZGlvLWdyb3VwX19pdGVtLS1zaW5nbGVcIj5cclxuICAgICAgPG1yeC1yYWRpb1xyXG4gICAgICAgICAgW25nTW9kZWxdPVwic2VsZWN0ZWRWYWx1ZT8uaWRcIlxyXG4gICAgICAgICAgW25hbWVdPVwibmFtZVwiXHJcbiAgICAgICAgICBbYm9sZExhYmVsXT1cImJvbGRcIlxyXG4gICAgICAgICAgW3R5cGVdPVwiJ2RlZmF1bHQnXCJcclxuICAgICAgICAgIFt2YWx1ZV09XCJpdGVtLmlkXCJcclxuICAgICAgICAgIFtpbnZhbGlkXT1cImludmFsaWRcIlxyXG4gICAgICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgICAgICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiXHJcbiAgICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJyYWRpb0NoYW5nZU1vZGVsKCRldmVudCwgaXRlbSlcIlxyXG4gICAgICA+e3sgaXRlbS50ZXh0IH19PC9tcngtcmFkaW8+XHJcbiAgICA8L2Rpdj5cclxuICA8L25nLXRlbXBsYXRlPlxyXG48L2Rpdj5cclxuXHJcblxyXG4iXX0=
|