@leanix/components 0.3.48 → 0.3.50
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/core-ui/components/icon-scale/icon-scale.component.mjs +1 -1
- package/esm2020/lib/core-ui/pipes/highlight-range.pipe.mjs +6 -1
- package/esm2020/lib/core-ui/pipes/highlight-term.pipe.mjs +13 -5
- package/esm2020/lib/core-ui/tooltip/tooltip.directive.mjs +1 -1
- package/esm2020/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.mjs +1 -1
- package/esm2020/lib/forms-ui/components/currency/currency-input.component.mjs +1 -1
- package/esm2020/lib/popover-ui/directives/popover-hover.directive.mjs +1 -1
- package/fesm2015/leanix-components.mjs +16 -3
- package/fesm2015/leanix-components.mjs.map +1 -1
- package/fesm2020/leanix-components.mjs +16 -3
- package/fesm2020/leanix-components.mjs.map +1 -1
- package/lib/core-ui/pipes/highlight-range.pipe.d.ts +2 -1
- package/lib/core-ui/pipes/highlight-term.pipe.d.ts +2 -1
- package/lib/core-ui/tooltip/tooltip.directive.d.ts +1 -1
- package/lib/forms-ui/components/currency/currency-input.component.d.ts +1 -1
- package/lib/popover-ui/directives/popover-hover.directive.d.ts +2 -2
- package/package.json +2 -1
|
@@ -37,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
37
37
|
}], numberOfItems: [{
|
|
38
38
|
type: Input
|
|
39
39
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1zY2FsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL2NvbXBvbmVudHMvaWNvbi1zY2FsZS9pY29uLXNjYWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9pY29uLXNjYWxlL2ljb24tc2NhbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQTRCLE1BQU0sZUFBZSxDQUFDOzs7QUFlcEcsTUFBTSxPQUFPLGtCQUFrQjtJQU4vQjtRQU9rQixTQUFJLEdBQVM7WUFDM0IsSUFBSSxFQUFFLE1BQU07U0FDYixDQUFDO1FBQ2MseUJBQW9CLEdBQUcsQ0FBQyxDQUFDO1FBQ3pCLGtCQUFhLEdBQUcsQ0FBQyxDQUFDO1FBRXpCLFNBQUksR0FBRyxvQkFBb0IsQ0FBQztRQUNyQyxjQUFTLEdBQWMsRUFBRSxDQUFDO0tBZTNCO0lBYlEsV0FBVyxDQUFDLFFBQXVCO1FBQ3hDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sSUFBSSxLQUFLLENBQUMsQ0FBQztJQUNwSCxDQUFDO0lBRU8sZUFBZSxDQUFDLFlBQW9CLEVBQUUsVUFBa0IsRUFBRSxPQUFnQjtRQUNoRixPQUFPLENBQUMsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNqRCxJQUFJLE9BQU8sRUFBRTtnQkFDWCxPQUFPLEtBQUssSUFBSSxVQUFVLEdBQUcsWUFBWSxDQUFDO2FBQzNDO2lCQUFNO2dCQUNMLE9BQU8sS0FBSyxHQUFHLFlBQVksQ0FBQzthQUM3QjtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7K0dBdEJVLGtCQUFrQjttR0FBbEIsa0JBQWtCLGtMQ2YvQixvTUFPQTsyRkRRYSxrQkFBa0I7a0JBTjlCLFNBQVM7K0JBQ0UsZUFBZSxtQkFHUix1QkFBdUIsQ0FBQyxNQUFNOzhCQUcvQixJQUFJO3NCQUFuQixLQUFLO2dCQUdVLG9CQUFvQjtzQkFBbkMsS0FBSztnQkFDVSxhQUFhO3NCQUE1QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEljb24ge1xuICAvKiogRm9udC1hd2Vzb21lIGljb24gY2xhc3MsIGUuZy4gJ2FkZHJlc3MtYm9vaycuIFNlZSBodHRwOi8vZm9udGF3ZXNvbWUuaW8vaWNvbnMvICovXG4gIHR5cGU6IHN0cmluZztcbiAgY29sb3I/OiBzdHJpbmc7XG4gIHJldmVyc2U/OiBib29sZWFuO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC1pY29uLXNjYWxlJyxcbiAgdGVtcGxhdGVVcmw6ICdpY29uLXNjYWxlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJ2ljb24tc2NhbGUuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgSWNvblNjYWxlQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcbiAgQElucHV0KCkgcHVibGljIGljb246IEljb24gPSB7XG4gICAgdHlwZTogJ3N0YXInXG4gIH07XG4gIEBJbnB1dCgpIHB1YmxpYyBudW1iZXJPZkNvbG9yZWRJdGVtcyA9IDA7XG4gIEBJbnB1dCgpIHB1YmxpYyBudW1iZXJPZkl0ZW1zID0gMDtcblxuICByZWFkb25seSBOQU1FID0gJ0ljb25TY2FsZUNvbXBvbmVudCc7XG4gIGljb25BcnJheTogYm9vbGVhbltdID0gW107XG5cbiAgcHVibGljIG5nT25DaGFuZ2VzKF9jaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgdGhpcy5pY29uQXJyYXkgPSB0aGlzLmNyZWF0ZUljb25BcnJheSh0aGlzLm51bWJlck9mQ29sb3JlZEl0ZW1zLCB0aGlzLm51bWJlck9mSXRlbXMsIHRoaXMuaWNvbj8ucmV2ZXJzZSB8fCBmYWxzZSk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUljb25BcnJheShjb2xvcmVkSXRlbXM6IG51bWJlciwgdG90YWxJdGVtczogbnVtYmVyLCByZXZlcnNlOiBib29sZWFuKTogYm9vbGVhbltdIHtcbiAgICByZXR1cm4gWy4uLkFycmF5KHRvdGFsSXRlbXMpLmtleXMoKV0ubWFwKChpbmRleCkgPT4ge1xuICAgICAgaWYgKHJldmVyc2UpIHtcbiAgICAgICAgcmV0dXJuIGluZGV4ID49IHRvdGFsSXRlbXMgLSBjb2xvcmVkSXRlbXM7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gaW5kZXggPCBjb2xvcmVkSXRlbXM7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiIsIjxzcGFuXG4gICpuZ0Zvcj1cImxldCBpc0NvbG9yZWQgb2YgaWNvbkFycmF5XCJcbiAgZGF0YS10ZXN0aWQ9XCJpY29uLXNjYWxlXCJcbiAgY2xhc3M9XCJpY29uRWxlbWVudCBmYXMgZmEte3sgaWNvbi50eXBlIH19XCJcbiAgW25nU3R5bGVdPVwiaXNDb2xvcmVkID8geyBjb2xvcjogaWNvbi5jb2xvciB9IDoge31cIlxuPlxuPC9zcGFuPlxuIl19
|
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
import { Pipe } from '@angular/core';
|
|
2
|
+
import { sanitize } from 'dompurify';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export class HighlightRangePipe {
|
|
4
5
|
transform(text, offset = 0, length = 0) {
|
|
6
|
+
const highlightedMarkup = this.doTransform(text, offset, length);
|
|
7
|
+
return sanitize(highlightedMarkup, { ALLOWED_TAGS: ['span'], ALLOWED_ATTR: ['class'] });
|
|
8
|
+
}
|
|
9
|
+
doTransform(text, offset, length) {
|
|
5
10
|
if (!text || offset < 0 || length < 0 || offset >= text?.length || offset + length > text?.length) {
|
|
6
11
|
return '';
|
|
7
12
|
}
|
|
@@ -18,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
18
23
|
type: Pipe,
|
|
19
24
|
args: [{ name: 'lxHighlightRange' }]
|
|
20
25
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlnaGxpZ2h0LXJhbmdlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3BpcGVzL2hpZ2hsaWdodC1yYW5nZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7O0FBR3JDLE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsU0FBUyxDQUFDLElBQVksRUFBRSxTQUFpQixDQUFDLEVBQUUsU0FBaUIsQ0FBQztRQUM1RCxNQUFNLGlCQUFpQixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNqRSxPQUFPLFFBQVEsQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLFlBQVksRUFBRSxDQUFDLE1BQU0sQ0FBQyxFQUFFLFlBQVksRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMxRixDQUFDO0lBRU8sV0FBVyxDQUFDLElBQW1CLEVBQUUsTUFBYyxFQUFFLE1BQWM7UUFDckUsSUFBSSxDQUFDLElBQUksSUFBSSxNQUFNLEdBQUcsQ0FBQyxJQUFJLE1BQU0sR0FBRyxDQUFDLElBQUksTUFBTSxJQUFJLElBQUksRUFBRSxNQUFNLElBQUksTUFBTSxHQUFHLE1BQU0sR0FBRyxJQUFJLEVBQUUsTUFBTSxFQUFFO1lBQ2pHLE9BQU8sRUFBRSxDQUFDO1NBQ1g7UUFDRCxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsTUFBTSxDQUFDLENBQUM7UUFDNUQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsQ0FBQztJQUNySSxDQUFDO0lBRU8sU0FBUyxDQUFDLElBQVk7UUFDNUIsT0FBTywrQkFBK0IsSUFBSSxTQUFTLENBQUM7SUFDdEQsQ0FBQzs7K0dBaEJVLGtCQUFrQjs2R0FBbEIsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBRDlCLElBQUk7bUJBQUMsRUFBRSxJQUFJLEVBQUUsa0JBQWtCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBzYW5pdGl6ZSB9IGZyb20gJ2RvbXB1cmlmeSc7XG5cbkBQaXBlKHsgbmFtZTogJ2x4SGlnaGxpZ2h0UmFuZ2UnIH0pXG5leHBvcnQgY2xhc3MgSGlnaGxpZ2h0UmFuZ2VQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybSh0ZXh0OiBzdHJpbmcsIG9mZnNldDogbnVtYmVyID0gMCwgbGVuZ3RoOiBudW1iZXIgPSAwKTogc3RyaW5nIHtcbiAgICBjb25zdCBoaWdobGlnaHRlZE1hcmt1cCA9IHRoaXMuZG9UcmFuc2Zvcm0odGV4dCwgb2Zmc2V0LCBsZW5ndGgpO1xuICAgIHJldHVybiBzYW5pdGl6ZShoaWdobGlnaHRlZE1hcmt1cCwgeyBBTExPV0VEX1RBR1M6IFsnc3BhbiddLCBBTExPV0VEX0FUVFI6IFsnY2xhc3MnXSB9KTtcbiAgfVxuXG4gIHByaXZhdGUgZG9UcmFuc2Zvcm0odGV4dDogc3RyaW5nIHwgbnVsbCwgb2Zmc2V0OiBudW1iZXIsIGxlbmd0aDogbnVtYmVyKTogc3RyaW5nIHtcbiAgICBpZiAoIXRleHQgfHwgb2Zmc2V0IDwgMCB8fCBsZW5ndGggPCAwIHx8IG9mZnNldCA+PSB0ZXh0Py5sZW5ndGggfHwgb2Zmc2V0ICsgbGVuZ3RoID4gdGV4dD8ubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gJyc7XG4gICAgfVxuICAgIGNvbnN0IGhpZ2hsaWdodGVkUGFydCA9IHRleHQuc2xpY2Uob2Zmc2V0LCBvZmZzZXQgKyBsZW5ndGgpO1xuICAgIHJldHVybiB0ZXh0LnNsaWNlKDAsIG9mZnNldCkgKyAoaGlnaGxpZ2h0ZWRQYXJ0Lmxlbmd0aCAhPT0gMCA/IHRoaXMuaGlnaGxpZ2h0KGhpZ2hsaWdodGVkUGFydCkgOiAnJykgKyB0ZXh0LnNsaWNlKG9mZnNldCArIGxlbmd0aCk7XG4gIH1cblxuICBwcml2YXRlIGhpZ2hsaWdodCh0ZXh0OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBgPHNwYW4gY2xhc3M9XCJ0ZXJtSGlnaGxpZ2h0XCI+JHt0ZXh0fTwvc3Bhbj5gO1xuICB9XG59XG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Pipe } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { sanitize } from 'dompurify';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
5
5
|
* These characters are treated as seperators by
|
|
@@ -16,12 +16,21 @@ export class HighlightTermPipe {
|
|
|
16
16
|
* @returns The transformed text with highlighted search term.
|
|
17
17
|
*/
|
|
18
18
|
transform(text, search, options = { exactMatch: false }) {
|
|
19
|
-
if (
|
|
19
|
+
if (text) {
|
|
20
|
+
const highlightedMarkup = this.doTransform(text, search, options);
|
|
21
|
+
return highlightedMarkup ? sanitize(highlightedMarkup, { ALLOWED_TAGS: ['span'], ALLOWED_ATTR: ['class'] }) : undefined;
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
return undefined;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
doTransform(text, search, options) {
|
|
28
|
+
if (search) {
|
|
20
29
|
let pattern = options.exactMatch ? search.trim() : search.replace(STANDARD_TOKENIZER_SEPERATORS, ' ');
|
|
21
30
|
// replace special chars for a backslash for RegExp
|
|
22
31
|
pattern = pattern.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, '\\$&');
|
|
23
32
|
pattern = options.exactMatch
|
|
24
|
-
?
|
|
33
|
+
? pattern
|
|
25
34
|
: pattern
|
|
26
35
|
.split(' ')
|
|
27
36
|
.filter((t) => {
|
|
@@ -29,7 +38,6 @@ export class HighlightTermPipe {
|
|
|
29
38
|
})
|
|
30
39
|
.join('|');
|
|
31
40
|
const regex = new RegExp(pattern, 'gi');
|
|
32
|
-
text = escape(text);
|
|
33
41
|
return text.replace(regex, (match) => `<span class="termHighlight">${match}</span>`); // add highlighting to matched regex pattern
|
|
34
42
|
}
|
|
35
43
|
else {
|
|
@@ -43,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
43
51
|
type: Pipe,
|
|
44
52
|
args: [{ name: 'lxHighlightTerm' }]
|
|
45
53
|
}] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlnaGxpZ2h0LXRlcm0ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvcGlwZXMvaGlnaGxpZ2h0LXRlcm0ucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sV0FBVyxDQUFDOztBQVVyQzs7OztHQUlHO0FBQ0gsTUFBTSw2QkFBNkIsR0FBRyxnQkFBZ0IsQ0FBQztBQUd2RCxNQUFNLE9BQU8saUJBQWlCO0lBQzVCOzs7Ozs7T0FNRztJQUNILFNBQVMsQ0FBQyxJQUFhLEVBQUUsTUFBc0IsRUFBRSxVQUFzQyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUU7UUFDMUcsSUFBSSxJQUFJLEVBQUU7WUFDUixNQUFNLGlCQUFpQixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztZQUNsRSxPQUFPLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxZQUFZLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFBRSxZQUFZLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztTQUN6SDthQUFNO1lBQ0wsT0FBTyxTQUFTLENBQUM7U0FDbEI7SUFDSCxDQUFDO0lBRU8sV0FBVyxDQUFDLElBQVksRUFBRSxNQUFpQyxFQUFFLE9BQW1DO1FBQ3RHLElBQUksTUFBTSxFQUFFO1lBQ1YsSUFBSSxPQUFPLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLDZCQUE2QixFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBRXRHLG1EQUFtRDtZQUNuRCxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxxQ0FBcUMsRUFBRSxNQUFNLENBQUMsQ0FBQztZQUV6RSxPQUFPLEdBQUcsT0FBTyxDQUFDLFVBQVU7Z0JBQzFCLENBQUMsQ0FBQyxPQUFPO2dCQUNULENBQUMsQ0FBQyxPQUFPO3FCQUNKLEtBQUssQ0FBQyxHQUFHLENBQUM7cUJBQ1YsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7b0JBQ1osT0FBTyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztnQkFDdEIsQ0FBQyxDQUFDO3FCQUNELElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUVqQixNQUFNLEtBQUssR0FBRyxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDeEMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsK0JBQStCLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyw0Q0FBNEM7U0FDbkk7YUFBTTtZQUNMLE9BQU8sSUFBSSxDQUFDO1NBQ2I7SUFDSCxDQUFDOzs4R0F0Q1UsaUJBQWlCOzRHQUFqQixpQkFBaUI7MkZBQWpCLGlCQUFpQjtrQkFEN0IsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHNhbml0aXplIH0gZnJvbSAnZG9tcHVyaWZ5JztcblxuZXhwb3J0IGludGVyZmFjZSBIaWdobGlnaHRUZXJtU2VhcmNoT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBzZWFyY2ggdGVybSBzaG91bGQgYmUgZXhhY3RseSBtYXRjaGVkIGluIHRoZSBnaXZlbiB0ZXh0LiBXaGVuIHNldCB0byB0cnVlLCB0aGUgZm9sbG93aW5nXG4gICAqIGNoYXJhY3RlcnMgYW5kIHNwYWNlcyBiZXR3ZWVuIHdvcmRzIGFyZSBpbmNsdWRlZCBpbiB0aGUgc2VhcmNoOiAtIFsgXSAvIHsgfSAoICkgKiArID8gLiBeICQgfFxuICAgKi9cbiAgZXhhY3RNYXRjaDogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBUaGVzZSBjaGFyYWN0ZXJzIGFyZSB0cmVhdGVkIGFzIHNlcGVyYXRvcnMgYnlcbiAqIGVsYXN0aWNzZWFyY2ggYW5kIHNwbGl0IHRoZSBpbnB1dCBpbnRvIHNlYXJjaCB0b2tlbnNcbiAqIHdoaWNoIGFyZSB1c2VkIHRvIGZpbmQgbWF0Y2hlcy5cbiAqL1xuY29uc3QgU1RBTkRBUkRfVE9LRU5JWkVSX1NFUEVSQVRPUlMgPSAvW15hLXpBLVpcXGRcXHNdL2c7XG5cbkBQaXBlKHsgbmFtZTogJ2x4SGlnaGxpZ2h0VGVybScgfSlcbmV4cG9ydCBjbGFzcyBIaWdobGlnaHRUZXJtUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAvKipcbiAgICogVHJhbnNmb3JtcyB0aGUgaW5wdXQgdGV4dCB3aXRoIGhpZ2hsaWdodGVkIHRleHQgYWNjb3JkaW5nIHRvIHRoZSBwcm92aWRlZCBzZWFyY2ggdGVybS5cbiAgICogQHBhcmFtIHRleHQgVGhlIGlucHV0IHRleHQuXG4gICAqIEBwYXJhbSBzZWFyY2ggVGhlIHNlYXJjaCB0ZXJtIHRvIGhpZ2hsaWdodC5cbiAgICogQHBhcmFtIG9wdGlvbnMgVGhlIGhpZ2hsaWdodCB0ZXJtIHNlYXJjaCBvcHRpb25zLlxuICAgKiBAcmV0dXJucyBUaGUgdHJhbnNmb3JtZWQgdGV4dCB3aXRoIGhpZ2hsaWdodGVkIHNlYXJjaCB0ZXJtLlxuICAgKi9cbiAgdHJhbnNmb3JtKHRleHQ/OiBzdHJpbmcsIHNlYXJjaD86IHN0cmluZyB8IG51bGwsIG9wdGlvbnM6IEhpZ2hsaWdodFRlcm1TZWFyY2hPcHRpb25zID0geyBleGFjdE1hdGNoOiBmYWxzZSB9KTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICBpZiAodGV4dCkge1xuICAgICAgY29uc3QgaGlnaGxpZ2h0ZWRNYXJrdXAgPSB0aGlzLmRvVHJhbnNmb3JtKHRleHQsIHNlYXJjaCwgb3B0aW9ucyk7XG4gICAgICByZXR1cm4gaGlnaGxpZ2h0ZWRNYXJrdXAgPyBzYW5pdGl6ZShoaWdobGlnaHRlZE1hcmt1cCwgeyBBTExPV0VEX1RBR1M6IFsnc3BhbiddLCBBTExPV0VEX0FUVFI6IFsnY2xhc3MnXSB9KSA6IHVuZGVmaW5lZDtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGRvVHJhbnNmb3JtKHRleHQ6IHN0cmluZywgc2VhcmNoOiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkLCBvcHRpb25zOiBIaWdobGlnaHRUZXJtU2VhcmNoT3B0aW9ucyk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKHNlYXJjaCkge1xuICAgICAgbGV0IHBhdHRlcm4gPSBvcHRpb25zLmV4YWN0TWF0Y2ggPyBzZWFyY2gudHJpbSgpIDogc2VhcmNoLnJlcGxhY2UoU1RBTkRBUkRfVE9LRU5JWkVSX1NFUEVSQVRPUlMsICcgJyk7XG5cbiAgICAgIC8vIHJlcGxhY2Ugc3BlY2lhbCBjaGFycyBmb3IgYSBiYWNrc2xhc2ggZm9yIFJlZ0V4cFxuICAgICAgcGF0dGVybiA9IHBhdHRlcm4ucmVwbGFjZSgvW1xcLVxcW1xcXVxcL1xce1xcfVxcKFxcKVxcKlxcK1xcP1xcLlxcXFxcXF5cXCRcXHxdL2csICdcXFxcJCYnKTtcblxuICAgICAgcGF0dGVybiA9IG9wdGlvbnMuZXhhY3RNYXRjaFxuICAgICAgICA/IHBhdHRlcm5cbiAgICAgICAgOiBwYXR0ZXJuXG4gICAgICAgICAgICAuc3BsaXQoJyAnKVxuICAgICAgICAgICAgLmZpbHRlcigodCkgPT4ge1xuICAgICAgICAgICAgICByZXR1cm4gdC5sZW5ndGggPiAwO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIC5qb2luKCd8Jyk7XG5cbiAgICAgIGNvbnN0IHJlZ2V4ID0gbmV3IFJlZ0V4cChwYXR0ZXJuLCAnZ2knKTtcbiAgICAgIHJldHVybiB0ZXh0LnJlcGxhY2UocmVnZXgsIChtYXRjaCkgPT4gYDxzcGFuIGNsYXNzPVwidGVybUhpZ2hsaWdodFwiPiR7bWF0Y2h9PC9zcGFuPmApOyAvLyBhZGQgaGlnaGxpZ2h0aW5nIHRvIG1hdGNoZWQgcmVnZXggcGF0dGVyblxuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gdGV4dDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -102,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
102
102
|
type: HostListener,
|
|
103
103
|
args: ['blur']
|
|
104
104
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBZ0IsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQXVDLE1BQU0sZUFBZSxDQUFDO0FBQzlILE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBbUIsTUFBTSw4QkFBOEIsQ0FBQztBQUNuRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBS3ZELE1BQU0sT0FBTyxnQkFBZ0I7SUF1QjNCLFlBQW9CLHNCQUE4QyxFQUFVLFVBQXNCLEVBQVUsT0FBZ0I7UUFBeEcsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUF3QjtRQUFVLGVBQVUsR0FBVixVQUFVLENBQVk7UUFBVSxZQUFPLEdBQVAsT0FBTyxDQUFTO1FBZnBILGFBQVEsR0FBb0I7WUFDbEMsQ0FBQyxFQUFFLFFBQVE7WUFDWCxDQUFDLEVBQUUsS0FBSztTQUNULENBQUM7UUFFTywyQkFBc0IsR0FBWSxLQUFLLENBQUM7UUFJekMsdUJBQWtCLEdBQVksS0FBSyxDQUFDO0lBTW1GLENBQUM7SUFyQmhJLElBQWEsaUJBQWlCLENBQUMsS0FBMkM7UUFDeEUsSUFBSSxDQUFDLFFBQVEsR0FBRztZQUNkLENBQUMsRUFBRSxLQUFLLElBQUksUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUTtZQUNsRCxDQUFDLEVBQUUsS0FBSyxJQUFJLFFBQVEs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LGdCQUFnQjsyRkFBaEIsZ0JBQWdCO2tCQUg1QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxhQUFhO2lCQUN4Qjs0SkFFcUIsT0FBTztzQkFBMUIsS0FBSzt1QkFBQyxXQUFXO2dCQUNMLGlCQUFpQjtzQkFBN0IsS0FBSztnQkFVRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLHNCQUFzQjtzQkFBOUIsS0FBSztnQkFvQ04sSUFBSTtzQkFGSCxZQUFZO3VCQUFDLFlBQVk7O3NCQUN6QixZQUFZO3VCQUFDLE9BQU87Z0JBdUJyQixJQUFJO3NCQUhILFlBQVk7dUJBQUMsWUFBWTs7c0JBQ3pCLFlBQVk7dUJBQUMsT0FBTzs7c0JBQ3BCLFlBQVk7dUJBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXksIE92ZXJsYXlQb3NpdGlvbkJ1aWxkZXIsIE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21wb25lbnRQb3J0YWwgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IENvbXBvbmVudFJlZiwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIsIElucHV0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdG9DZGtQb3NpdGlvbiB9IGZyb20gJy4vdG8tY2RrLXBvc2l0aW9uLmZ1bmN0aW9uJztcbmltcG9ydCB7IGlzVmFsaWRYLCBpc1ZhbGlkWSwgVG9vbHRpcFBvc2l0aW9uIH0gZnJvbSAnLi90b29sdGlwLXBvc2l0aW9uLmludGVyZmFjZSc7XG5pbXBvcnQgeyBUb29sdGlwQ29tcG9uZW50IH0gZnJvbSAnLi90b29sdGlwLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tseFRvb2x0aXBdJ1xufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwRGlyZWN0aXZlIGltcGxlbWVudHMgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICBASW5wdXQoJ2x4VG9vbHRpcCcpIGNvbnRlbnQ/
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/core-ui/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Directive, ElementRef, HostListener, Input, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';\nimport { toCdkPosition } from './to-cdk-position.function';\nimport { isValidX, isValidY, TooltipPosition } from './tooltip-position.interface';\nimport { TooltipComponent } from './tooltip.component';\n\n@Directive({\n  selector: '[lxTooltip]'\n})\nexport class TooltipDirective implements OnChanges, OnDestroy {\n  @Input('lxTooltip') content?: string | null;\n  @Input() set lxTooltipPosition(value: { x: string; y: string } | undefined) {\n    this.position = {\n      x: value && isValidX(value.x) ? value.x : 'center',\n      y: value && isValidY(value.y) ? value.y : 'top'\n    };\n  }\n  private position: TooltipPosition = {\n    x: 'center',\n    y: 'top'\n  };\n  @Input() lxTooltipDelay?: number;\n  @Input() lxTooltipIsHtmlContent: boolean = false;\n\n  private overlayRef?: OverlayRef;\n  private tooltipRef?: ComponentRef<TooltipComponent>;\n  private mouseOrFocusOnHost: boolean = false;\n\n  get positionStrategy() {\n    return this.overlayPositionBuilder.flexibleConnectedTo(this.elementRef).withPositions([toCdkPosition(this.position)]);\n  }\n\n  constructor(private overlayPositionBuilder: OverlayPositionBuilder, private elementRef: ElementRef, private overlay: Overlay) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.overlayRef && changes['lxTooltipPosition']) {\n      this.overlayRef.updatePositionStrategy(this.positionStrategy);\n    }\n    if (this.tooltipRef) {\n      if (changes['lxTooltipPosition']) {\n        this.tooltipRef.instance.position = this.position;\n      }\n      if (changes['lxTooltipIsHtmlContent']) {\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n      }\n      if (changes['content']) {\n        if (this.content) {\n          this.tooltipRef.instance.content = this.content;\n          this.overlayRef?.updatePosition();\n        } else {\n          this.overlayRef?.detach();\n        }\n      }\n    }\n  }\n\n  @HostListener('mouseenter')\n  @HostListener('focus')\n  show() {\n    this.mouseOrFocusOnHost = true;\n    setTimeout(() => {\n      if (!this.overlayRef?.hasAttached() && this.mouseOrFocusOnHost && this.content) {\n        this.overlayRef = this.overlay.create({ positionStrategy: this.positionStrategy });\n        const tooltipPortal = new ComponentPortal(TooltipComponent);\n        this.tooltipRef = this.overlayRef.attach(tooltipPortal);\n        this.tooltipRef.instance.content = this.content;\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n        this.tooltipRef.instance.position = this.position;\n      }\n    }, this.lxTooltipDelay ?? 90);\n  }\n\n  ngOnDestroy() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n\n  @HostListener('mouseleave')\n  @HostListener('click')\n  @HostListener('blur')\n  hide() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n}\n"]}
|
|
@@ -103,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
103
103
|
type: ContentChild,
|
|
104
104
|
args: ['descriptionTemplateRef']
|
|
105
105
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { isEqual, some, toLower } from 'lodash/fp';\nimport { SingleSelectPadding } from '../../models/single-select-padding.interface';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\n@Component({\n  selector: 'lx-basic-dropdown',\n  templateUrl: 'basic-dropdown.component.html',\n  styleUrls: ['basic-dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BasicDropdownComponent extends KeyboardSelectDirective implements AfterViewInit {\n  public static isNewItem(items: any[], term: string, key?: string): boolean {\n    if (!term) {\n      return false;\n    }\n    const isEqualIgnoringCase = (item: any) => {\n      const value = key ? item[key] : item;\n      return isEqual(toLower(value), toLower(term));\n    };\n    return !some(isEqualIgnoringCase, items);\n  }\n\n  readonly NAME = 'BasicDropdownComponent';\n\n  @Input() options: any[] = [];\n  @Input() initiallySelectedIndex: number = -1;\n  @Input() labelKey?: string;\n  @Input() itemKey?: string;\n  @Input() placeholder?: string;\n  @Input() loading: boolean = false;\n  @Input() newOptionLabel!: string;\n  @Input() padding?: SingleSelectPadding = 'default';\n  @Input() showCreateNewOption = false;\n\n  @Input() disabledOptions: { [itemKey: string]: any } = {};\n\n  @Output() onItemSelected = new EventEmitter<any>();\n  @Output() triggerRequestForMoreEntries = new EventEmitter<void>();\n  @Output() newOptionLabelSelected = new EventEmitter<string>();\n  @Output() createNewOptionSelected = new EventEmitter<void>();\n\n  @ContentChild('optionTemplate') optionTemplateRef!: TemplateRef<any>;\n  @ContentChild('createNewOptionTemplate') createNewOptionTemplateRef!: TemplateRef<any>;\n  @ContentChild('descriptionTemplateRef') descriptionTemplateRef!: TemplateRef<any>;\n\n  selectOption(option: any) {\n    if (!option || !this.itemKey) {\n      this.onItemSelected.emit(option);\n    } else if (!this.disabledOptions[option[this.itemKey]]) {\n      this.onItemSelected.emit(option);\n    }\n  }\n\n  public get isNewItem() {\n    return BasicDropdownComponent.isNewItem(this.options, this.newOptionLabel, this.labelKey);\n  }\n\n  public trackByProp(prop?: string) {\n    return (index: number, pill: any) => (prop ? pill[prop] : index);\n  }\n\n  public onScroll() {\n    this.triggerRequestForMoreEntries.emit();\n  }\n\n  public onNewItemSelected() {\n    if (!this.loading) {\n      this.selectOption(null);\n      this.newOptionLabelSelected.emit(this.newOptionLabel);\n    }\n  }\n\n  public onCreateNewOptionSelected() {\n    this.createNewOptionSelected.emit();\n  }\n}\n","<ul\n  class=\"options {{ padding }}Padding lxThinScrollbar\"\n  #keyboardSelectContainer\n  infinite-scroll\n  [scrollWindow]=\"false\"\n  [fromRoot]=\"true\"\n  (scrolled)=\"onScroll()\"\n>\n  <li\n    *ngIf=\"newOptionLabel && isNewItem\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (click)=\"onNewItemSelected()\"\n    (select)=\"onNewItemSelected()\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    class=\"option keyboardSelectable onTheFlyOption\"\n  >\n    <span class=\"newEntryContent\">\n      {{ newOptionLabel }}\n    </span>\n    <lx-badge class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\"></lx-badge>\n  </li>\n  <li\n    *ngIf=\"showCreateNewOption\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (click)=\"onCreateNewOptionSelected()\"\n    (select)=\"onCreateNewOptionSelected()\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    class=\"option keyboardSelectable newEntryOption\"\n  >\n    <span class=\"newEntryContent\">\n      <ng-container *ngIf=\"createNewOptionTemplateRef; else defaultNewOption\">\n        <ng-container *ngTemplateOutlet=\"createNewOptionTemplateRef\"></ng-container>\n      </ng-container>\n      <ng-template #defaultNewOption>\n        <span>\n          {{ NAME + '.new' | translate }}\n        </span>\n      </ng-template>\n    </span>\n  </li>\n  <li\n    *ngIf=\"descriptionTemplateRef\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    class=\"option description disabledItem\"\n  >\n    <span class=\"descriptionContent\">\n      <ng-container *ngTemplateOutlet=\"descriptionTemplateRef\"></ng-container>\n    </span>\n  </li>\n  <li\n    *ngIf=\"options?.length === 0 && !newOptionLabel && !loading\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    class=\"option keyboardSelectable noOptionsAvailable\"\n  >\n    {{ NAME + '.noResults' | translate }}\n  </li>\n  <li\n    *ngIf=\"placeholder\"\n    tabindex=\"-1\"\n    class=\"option keyboardSelectable clearSelection\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (click)=\"selectOption(null)\"\n    (select)=\"selectOption(null)\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n  >\n    {{ placeholder }}\n  </li>\n  <li\n    *ngFor=\"let option of options; let index = index; trackBy: trackByProp(itemKey)\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    class=\"option keyboardSelectable\"\n    (click)=\"selectOption(option)\"\n    (select)=\"selectOption(option)\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    [class.initiallySelected]=\"index === initiallySelectedIndex\"\n    [class.disabledItem]=\"itemKey ? !!disabledOptions[option[itemKey]] : false\"\n  >\n    <ng-container *ngIf=\"optionTemplateRef; else simpleStringDisplay\">\n      <ng-container *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index }\"></ng-container>\n    </ng-container>\n    <ng-template #simpleStringDisplay>\n      <span>\n        {{ labelKey ? option[labelKey] : option }}\n      </span>\n    </ng-template>\n  </li>\n  <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\"></lx-spinner>\n</ul>\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { isEqual, some, toLower } from 'lodash/fp';\nimport { SingleSelectPadding } from '../../models/single-select-padding.interface';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\n@Component({\n  selector: 'lx-basic-dropdown',\n  templateUrl: 'basic-dropdown.component.html',\n  styleUrls: ['basic-dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BasicDropdownComponent extends KeyboardSelectDirective implements AfterViewInit {\n  public static isNewItem(items: any[], term: string, key?: string): boolean {\n    if (!term) {\n      return false;\n    }\n    const isEqualIgnoringCase = (item: any) => {\n      const value = key ? item[key] : item;\n      return isEqual(toLower(value), toLower(term));\n    };\n    return !some(isEqualIgnoringCase, items);\n  }\n\n  readonly NAME = 'BasicDropdownComponent';\n\n  @Input() options: any[] = [];\n  @Input() initiallySelectedIndex = -1;\n  @Input() labelKey?: string;\n  @Input() itemKey?: string;\n  @Input() placeholder?: string;\n  @Input() loading: boolean = false;\n  @Input() newOptionLabel!: string;\n  @Input() padding?: SingleSelectPadding = 'default';\n  @Input() showCreateNewOption = false;\n\n  @Input() disabledOptions: { [itemKey: string]: any } = {};\n\n  @Output() onItemSelected = new EventEmitter<any>();\n  @Output() triggerRequestForMoreEntries = new EventEmitter<void>();\n  @Output() newOptionLabelSelected = new EventEmitter<string>();\n  @Output() createNewOptionSelected = new EventEmitter<void>();\n\n  @ContentChild('optionTemplate') optionTemplateRef!: TemplateRef<any>;\n  @ContentChild('createNewOptionTemplate') createNewOptionTemplateRef!: TemplateRef<any>;\n  @ContentChild('descriptionTemplateRef') descriptionTemplateRef!: TemplateRef<any>;\n\n  selectOption(option: any) {\n    if (!option || !this.itemKey) {\n      this.onItemSelected.emit(option);\n    } else if (!this.disabledOptions[option[this.itemKey]]) {\n      this.onItemSelected.emit(option);\n    }\n  }\n\n  public get isNewItem() {\n    return BasicDropdownComponent.isNewItem(this.options, this.newOptionLabel, this.labelKey);\n  }\n\n  public trackByProp(prop?: string) {\n    return (index: number, pill: any) => (prop ? pill[prop] : index);\n  }\n\n  public onScroll() {\n    this.triggerRequestForMoreEntries.emit();\n  }\n\n  public onNewItemSelected() {\n    if (!this.loading) {\n      this.selectOption(null);\n      this.newOptionLabelSelected.emit(this.newOptionLabel);\n    }\n  }\n\n  public onCreateNewOptionSelected() {\n    this.createNewOptionSelected.emit();\n  }\n}\n","<ul\n  class=\"options {{ padding }}Padding lxThinScrollbar\"\n  #keyboardSelectContainer\n  infinite-scroll\n  [scrollWindow]=\"false\"\n  [fromRoot]=\"true\"\n  (scrolled)=\"onScroll()\"\n>\n  <li\n    *ngIf=\"newOptionLabel && isNewItem\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (click)=\"onNewItemSelected()\"\n    (select)=\"onNewItemSelected()\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    class=\"option keyboardSelectable onTheFlyOption\"\n  >\n    <span class=\"newEntryContent\">\n      {{ newOptionLabel }}\n    </span>\n    <lx-badge class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\"></lx-badge>\n  </li>\n  <li\n    *ngIf=\"showCreateNewOption\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (click)=\"onCreateNewOptionSelected()\"\n    (select)=\"onCreateNewOptionSelected()\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    class=\"option keyboardSelectable newEntryOption\"\n  >\n    <span class=\"newEntryContent\">\n      <ng-container *ngIf=\"createNewOptionTemplateRef; else defaultNewOption\">\n        <ng-container *ngTemplateOutlet=\"createNewOptionTemplateRef\"></ng-container>\n      </ng-container>\n      <ng-template #defaultNewOption>\n        <span>\n          {{ NAME + '.new' | translate }}\n        </span>\n      </ng-template>\n    </span>\n  </li>\n  <li\n    *ngIf=\"descriptionTemplateRef\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    class=\"option description disabledItem\"\n  >\n    <span class=\"descriptionContent\">\n      <ng-container *ngTemplateOutlet=\"descriptionTemplateRef\"></ng-container>\n    </span>\n  </li>\n  <li\n    *ngIf=\"options?.length === 0 && !newOptionLabel && !loading\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    class=\"option keyboardSelectable noOptionsAvailable\"\n  >\n    {{ NAME + '.noResults' | translate }}\n  </li>\n  <li\n    *ngIf=\"placeholder\"\n    tabindex=\"-1\"\n    class=\"option keyboardSelectable clearSelection\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    (click)=\"selectOption(null)\"\n    (select)=\"selectOption(null)\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n  >\n    {{ placeholder }}\n  </li>\n  <li\n    *ngFor=\"let option of options; let index = index; trackBy: trackByProp(itemKey)\"\n    tabindex=\"-1\"\n    lxSelectableItem\n    [scrollInContainer]=\"keyboardSelectContainer\"\n    #item\n    class=\"option keyboardSelectable\"\n    (click)=\"selectOption(option)\"\n    (select)=\"selectOption(option)\"\n    [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n    [class.initiallySelected]=\"index === initiallySelectedIndex\"\n    [class.disabledItem]=\"itemKey ? !!disabledOptions[option[itemKey]] : false\"\n  >\n    <ng-container *ngIf=\"optionTemplateRef; else simpleStringDisplay\">\n      <ng-container *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index }\"></ng-container>\n    </ng-container>\n    <ng-template #simpleStringDisplay>\n      <span>\n        {{ labelKey ? option[labelKey] : option }}\n      </span>\n    </ng-template>\n  </li>\n  <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\"></lx-spinner>\n</ul>\n"]}
|
|
@@ -138,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
138
138
|
type: ViewChild,
|
|
139
139
|
args: ['currencyInput']
|
|
140
140
|
}] } });
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\n\nexport type CurrencyInputMode = 'view' | 'edit';\nexport type CurrencyIconPosition = 'first' | 'end';\n\ntype DecimalSeparator = ',' | '.';\n\n@Component({\n  selector: 'lx-currency-input',\n  templateUrl: 'currency-input.component.html',\n  styleUrls: ['currency-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CurrencyInputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CurrencyInputComponent implements AfterViewInit, OnDestroy, ControlValueAccessor, OnInit {\n  @Input() public code!: string;\n  @Input() public decimalSeparator: DecimalSeparator = '.';\n  @Input() public placeholder!: string;\n  @Input() public data: number = 0;\n  @Observe<number>('data') data$!: Observable<number>;\n\n  @Input() public disabled: boolean = false;\n  @Input() public mode: CurrencyInputMode = 'edit';\n  @Input() public fieldDefinitionType!: 'DOUBLE' | 'INTEGER';\n  @Input() public iconPosition: CurrencyIconPosition = 'first';\n  @Input() public format: string = '1.2-2';\n\n  @Output() public onFocusLost = new EventEmitter<boolean>();\n  @Output() public onChange = new EventEmitter<number>();\n\n  @ViewChild('currencyInput') private currencyInput!: ElementRef<HTMLInputElement>;\n  showCurrencyInput: boolean = false;\n  dataValue$ = new ReplaySubject<number>();\n\n  private get allowedCharacters() {\n    return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\\e\\\\${this.decimalSeparator}\\]`) : /[0-9\\e\\\\]/;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetector: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.data$.pipe(takeUntil(this.destroyed$)).subscribe(this.dataValue$);\n  }\n\n  ngAfterViewInit() {\n    if (this.currencyInput) {\n      fromEvent<KeyboardEvent>(this.currencyInput.nativeElement, 'keypress')\n        .pipe(\n          filter((keyboardEvent) => this.shouldRejectKey(keyboardEvent)),\n          takeUntil(this.destroyed$)\n        )\n        .subscribe((keyboardEvent) => {\n          keyboardEvent.preventDefault();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  valueChanged(value: string | number) {\n    if (typeof value === 'string') {\n      const invalidSeparator = this.decimalSeparator === '.' ? ',' : '.';\n      value = this.parseInput(value, invalidSeparator) as number;\n    }\n    // fix copy & paste string values being interpreted wrongly\n    this.dataValue$.next(value);\n    this.onChange.emit(value);\n    this.propagateChange(value);\n  }\n\n  onBlur() {\n    this.showCurrencyInput = false;\n    this.onFocusLost.emit(true);\n  }\n\n  focusCurrencyInput() {\n    this.showCurrencyInput = true;\n    this.changeDetector.detectChanges();\n    this.currencyInput.nativeElement.focus();\n    this.currencyInput.nativeElement.setSelectionRange(0, 0);\n  }\n\n  shouldRejectKey(event: KeyboardEvent) {\n    if (this.fieldDefinitionType === 'DOUBLE' && event.key === this.decimalSeparator) {\n      return this.containsSeparators(this.currencyInput.nativeElement.value);\n    }\n    return !this.allowedCharacters.test(event.key);\n  }\n\n  propagateChange(_newValue: number) {}\n\n  writeValue(newValue: number) {\n    this.dataValue$.next(newValue);\n  }\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(_fn: any) {}\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  private parseInput(value: string, char: string) {\n    const countOccurences = value.split(char).length - 1;\n    if (countOccurences > 1) {\n      for (let i = 0; i < countOccurences; i++) {\n        value = value.replace(char, '');\n      }\n    }\n    const parsedValue = parseFloat(value.replace(',', '.').replace(/ /g, ''));\n    return isNaN(parsedValue) ? null : parsedValue;\n  }\n\n  private containsSeparators(value: string) {\n    return value.indexOf(',') > -1 || value.indexOf('.') > -1;\n  }\n}\n","<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n  <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    *ngIf=\"!showCurrencyInput\"\n    type=\"text\"\n    class=\"form-control currencyDisplayValue\"\n    placeholder=\"{{ placeholder }}\"\n    [value]=\"dataValue$ | async | number: format\"\n    (focus)=\"focusCurrencyInput()\"\n  />\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    [class.hideInput]=\"!showCurrencyInput\"\n    type=\"text\"\n    inputmode=\"numeric\"\n    class=\"form-control currencyInput\"\n    name=\"inputAmount\"\n    #currencyInput\n    placeholder=\"{{ placeholder }}\"\n    [ngModel]=\"dataValue$ | async\"\n    (blur)=\"onBlur()\"\n    (ngModelChange)=\"valueChanged($event)\"\n  />\n  <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n  <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n  <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\n\nexport type CurrencyInputMode = 'view' | 'edit';\nexport type CurrencyIconPosition = 'first' | 'end' | 'none';\n\ntype DecimalSeparator = ',' | '.';\n\n@Component({\n  selector: 'lx-currency-input',\n  templateUrl: 'currency-input.component.html',\n  styleUrls: ['currency-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CurrencyInputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CurrencyInputComponent implements AfterViewInit, OnDestroy, ControlValueAccessor, OnInit {\n  @Input() public code!: string;\n  @Input() public decimalSeparator: DecimalSeparator = '.';\n  @Input() public placeholder!: string;\n  @Input() public data: number = 0;\n  @Observe<number>('data') data$!: Observable<number>;\n\n  @Input() public disabled: boolean = false;\n  @Input() public mode: CurrencyInputMode = 'edit';\n  @Input() public fieldDefinitionType!: 'DOUBLE' | 'INTEGER';\n  @Input() public iconPosition: CurrencyIconPosition = 'first';\n  @Input() public format: string = '1.2-2';\n\n  @Output() public onFocusLost = new EventEmitter<boolean>();\n  @Output() public onChange = new EventEmitter<number>();\n\n  @ViewChild('currencyInput') private currencyInput!: ElementRef<HTMLInputElement>;\n  showCurrencyInput: boolean = false;\n  dataValue$ = new ReplaySubject<number>();\n\n  private get allowedCharacters() {\n    return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\\e\\\\${this.decimalSeparator}\\]`) : /[0-9\\e\\\\]/;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetector: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.data$.pipe(takeUntil(this.destroyed$)).subscribe(this.dataValue$);\n  }\n\n  ngAfterViewInit() {\n    if (this.currencyInput) {\n      fromEvent<KeyboardEvent>(this.currencyInput.nativeElement, 'keypress')\n        .pipe(\n          filter((keyboardEvent) => this.shouldRejectKey(keyboardEvent)),\n          takeUntil(this.destroyed$)\n        )\n        .subscribe((keyboardEvent) => {\n          keyboardEvent.preventDefault();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  valueChanged(value: string | number) {\n    if (typeof value === 'string') {\n      const invalidSeparator = this.decimalSeparator === '.' ? ',' : '.';\n      value = this.parseInput(value, invalidSeparator) as number;\n    }\n    // fix copy & paste string values being interpreted wrongly\n    this.dataValue$.next(value);\n    this.onChange.emit(value);\n    this.propagateChange(value);\n  }\n\n  onBlur() {\n    this.showCurrencyInput = false;\n    this.onFocusLost.emit(true);\n  }\n\n  focusCurrencyInput() {\n    this.showCurrencyInput = true;\n    this.changeDetector.detectChanges();\n    this.currencyInput.nativeElement.focus();\n    this.currencyInput.nativeElement.setSelectionRange(0, 0);\n  }\n\n  shouldRejectKey(event: KeyboardEvent) {\n    if (this.fieldDefinitionType === 'DOUBLE' && event.key === this.decimalSeparator) {\n      return this.containsSeparators(this.currencyInput.nativeElement.value);\n    }\n    return !this.allowedCharacters.test(event.key);\n  }\n\n  propagateChange(_newValue: number) {}\n\n  writeValue(newValue: number) {\n    this.dataValue$.next(newValue);\n  }\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(_fn: any) {}\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  private parseInput(value: string, char: string) {\n    const countOccurences = value.split(char).length - 1;\n    if (countOccurences > 1) {\n      for (let i = 0; i < countOccurences; i++) {\n        value = value.replace(char, '');\n      }\n    }\n    const parsedValue = parseFloat(value.replace(',', '.').replace(/ /g, ''));\n    return isNaN(parsedValue) ? null : parsedValue;\n  }\n\n  private containsSeparators(value: string) {\n    return value.indexOf(',') > -1 || value.indexOf('.') > -1;\n  }\n}\n","<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n  <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    *ngIf=\"!showCurrencyInput\"\n    type=\"text\"\n    class=\"form-control currencyDisplayValue\"\n    placeholder=\"{{ placeholder }}\"\n    [value]=\"dataValue$ | async | number: format\"\n    (focus)=\"focusCurrencyInput()\"\n  />\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    [class.hideInput]=\"!showCurrencyInput\"\n    type=\"text\"\n    inputmode=\"numeric\"\n    class=\"form-control currencyInput\"\n    name=\"inputAmount\"\n    #currencyInput\n    placeholder=\"{{ placeholder }}\"\n    [ngModel]=\"dataValue$ | async\"\n    (blur)=\"onBlur()\"\n    (ngModelChange)=\"valueChanged($event)\"\n  />\n  <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n  <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n  <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n"]}
|
|
@@ -84,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
84
84
|
type: HostListener,
|
|
85
85
|
args: ['mouseleave']
|
|
86
86
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1ob3Zlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9wb3BvdmVyLXVpL2RpcmVjdGl2ZXMvcG9wb3Zlci1ob3Zlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDN0QsT0FBTyxFQUFpQixTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUV6RixPQUFPLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNuQyxPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBUTdEOztHQUVHO0FBS0gsTUFBTSxPQUFPLHFCQUFxQjtJQTRCaEMsWUFBbUIsTUFBd0I7UUFBeEIsV0FBTSxHQUFOLE1BQU0sQ0FBa0I7UUFkM0M7O1dBRUc7UUFFSCxtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUV2QixzREFBc0Q7UUFDOUMsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBMEIsQ0FBQztRQUU3RCxzREFBc0Q7UUFDOUMsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBMEIsQ0FBQztRQUVwRCxlQUFVLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQUVJLENBQUM7SUEzQi9DOzs7T0FHRztJQUNILElBQ0ksY0FBYztRQUNoQixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUM7SUFDOUIsQ0FBQztJQUNELElBQUksY0FBYyxDQUFDLEdBQVk7UUFDN0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxvQkFBb0IsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDeEQsQ0FBQztJQW1CRCxlQUFlO1FBQ2IsbUVBQW1FO1FBQ25FLHFFQUFxRTtRQUNyRSxpREFBaUQ7UUFDakQsSUFBSSxDQUFDLFlBQVk7YUFDZCxJQUFJLENBQ0gsU0FBUyxDQUFDLENBQUMsRUFBRSxTQUFTLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFDdEgsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FDM0I7YUFDQSxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUUvQyx3R0FBd0c7UUFDeEcseUdBQXlHO1FBQ3pHLElBQUksQ0FBQyxZQUFZO2FBQ2QsSUFBSSxDQUNILFNBQVMsQ0FBQyxDQUFDLEVBQUUsU0FBUyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFDckcsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FDM0I7YUFDQSxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsRUFBRTtnQkFDaEMsNEVBQTRFO2dCQUM1RSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUM3QjtpQkFBTTtnQkFDTCxzR0FBc0c7Z0JBQ3RHLHNHQUFzRztnQkFDdEcsb0dBQW9HO2dCQUNwRyxpR0FBaUc7Z0JBQ2pHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUNuQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFHRCxXQUFXLENBQUMsU0FBUyxHQUFHLEtBQUs7UUFDM0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFHRCxZQUFZLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxjQUFjO1FBQzFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUN4QyxDQUFDOztrSEExRVUscUJBQXFCO3NHQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFKakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7dUdBT0ssY0FBYztzQkFEakIsS0FBSztnQkFhTixjQUFjO3NCQURiLEtBQUs7Z0JBa0ROLFdBQVc7c0JBRFYsWUFBWTt1QkFBQyxZQUFZO2dCQU0xQixZQUFZO3NCQURYLFlBQVk7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvZXJjZU51bWJlclByb3BlcnR5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTYXRQb3BvdmVyQW5jaG9yIH0gZnJvbSAnQG5jc3RhdGUvc2F0LXBvcG92ZXInO1xuaW1wb3J0IHsgb2YsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGRlbGF5LCBzd2l0Y2hNYXAsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuZXhwb3J0IGludGVyZmFjZSBQb3BvdmVyVHJpZ2dlckRpcmVjdGl2ZSB7XG4gIGFuY2hvcjogU2F0UG9wb3ZlckFuY2hvcjtcbiAgc2hvd1BvcG92ZXIoc2tpcERlbGF5PzogYm9vbGVhbik6IHZvaWQ7XG4gIGNsb3NlUG9wb3Zlcihza2lwRGVsYXk/OiBib29sZWFuKTogdm9pZDtcbn1cblxuLyoqXG4gKiBAc2VlIFBvcG92ZXJDb21wb25lbnQgZm9yIHVzYWdlIGRvY3VtZW50YXRpb24uXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBleHBvcnRBczogJ2hvdmVyQW5jaG9yJyxcbiAgc2VsZWN0b3I6ICdbbHhQb3BvdmVySG92ZXJdJ1xufSlcbmV4cG9ydCBjbGFzcyBQb3BvdmVySG92ZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICAvKipcbiAgICogQW1vdW50IG9mIHRpbWUgdG8gZGVsYXkgKG1zKSBhZnRlciBob3ZlcmluZyBzdGFydHMgYmVmb3JlXG4gICAqIHRoZSBwb3BvdmVyIG9wZW5zLlxuICAgKi9cbiAgQElucHV0KClcbiAgZ2V0IGx4UG9wb3ZlckhvdmVyKCkge1xuICAgIHJldHVybiB0aGlzLl9seFBvcG92ZXJIb3ZlcjtcbiAgfVxuICBzZXQgbHhQb3BvdmVySG92ZXIodmFsOiB1bmtub3duKSB7XG4gICAgdGhpcy5fbHhQb3BvdmVySG92ZXIgPSBjb2VyY2VOdW1iZXJQcm9wZXJ0eSh2YWwsIDIwMCk7XG4gIH1cbiAgcHJpdmF0ZSBfbHhQb3BvdmVySG92ZXIhOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFJlbGV2YW50IGZvciB0b29sdGlwIHN0eWxlLlxuICAgKi9cbiAgQElucHV0KClcbiAgc2tpcENsb3NlRGVsYXkgPSBmYWxzZTtcblxuICAvKiogRW1pdHMgd2hlbiB0aGUgdXNlcidzIG1vdXNlIGVudGVycyB0aGUgZWxlbWVudC4gKi9cbiAgcHJpdmF0ZSBvbk1vdXNlRW50ZXIgPSBuZXcgU3ViamVjdDx7IHNraXBEZWxheTogYm9vbGVhbiB9PigpO1xuXG4gIC8qKiBFbWl0cyB3aGVuIHRoZSB1c2VyJ3MgbW91c2UgbGVhdmVzIHRoZSBlbGVtZW50LiAqL1xuICBwcml2YXRlIG9uTW91c2VMZWF2ZSA9IG5ldyBTdWJqZWN0PHsgc2tpcERlbGF5OiBib29sZWFuIH0+KCk7XG5cbiAgcmVhZG9ubHkgZGVzdHJveWVkJCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgY29uc3RydWN0b3IocHVibGljIGFuY2hvcjogU2F0UG9wb3ZlckFuY2hvcikge31cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgLy8gV2hlbmV2ZXIgdGhlIHVzZXIgaG92ZXJzIHRoaXMgaG9zdCBlbGVtZW50LCBkZWxheSB0aGUgY29uZmlndXJlZFxuICAgIC8vIGFtb3VudCBvZiB0aW1lIGFuZCBvcGVuIHRoZSBwb3BvdmVyLiBUZXJtaW5hdGUgaWYgdGhlIG1vdXNlIGxlYXZlc1xuICAgIC8vIHRoZSBob3N0IGVsZW1lbnQgYmVmb3JlIHRoZSBkZWxheSBpcyBjb21wbGV0ZS5cbiAgICB0aGlzLm9uTW91c2VFbnRlclxuICAgICAgLnBpcGUoXG4gICAgICAgIHN3aXRjaE1hcCgoeyBza2lwRGVsYXkgfSkgPT4gb2YobnVsbCkucGlwZShkZWxheShza2lwRGVsYXkgPyAwIDogdGhpcy5fbHhQb3BvdmVySG92ZXIpLCB0YWtlVW50aWwodGhpcy5vbk1vdXNlTGVhdmUpKSksXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLmRlc3Ryb3llZCQpXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHRoaXMuYW5jaG9yLnBvcG92ZXIub3BlbigpKTtcblxuICAgIC8vIFdoZW5ldmVyIHRoZSB1c2VyIGxlYXZlcyB0aGlzIGhvc3QgZWxlbWVudCwgZGVsYXkgdGhlIGNsb3Npbmcgb2YgdGhlIHBvcG92ZXIgYnkgdGhlIGNvbmZpZ3VyZWQgZGVsYXkuXG4gICAgLy8gQWJvcnQgY2xvc2luZyBpZiBkdXJpbmcgdGhpcyBkZWxheSBhbm90aGVyIG1vdXNlRW50ZXIgZXZlbnQgb2NjdXJzLCBmb3IgZXhhbXBsZSBieSB0aGUgcG9wb3ZlciBpdHNlbGYuXG4gICAgdGhpcy5vbk1vdXNlTGVhdmVcbiAgICAgIC5waXBlKFxuICAgICAgICBzd2l0Y2hNYXAoKHsgc2tpcERlbGF5IH0pID0+IG9mKG51bGwpLnBpcGUoZGVsYXkoc2tpcERlbGF5ID8gMCA6IDMwMCksIHRha2VVbnRpbCh0aGlzLm9uTW91c2VFbnRlcikpKSxcbiAgICAgICAgdGFrZVVudGlsKHRoaXMuZGVzdHJveWVkJClcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5hbmNob3IucG9wb3Zlci5pc09wZW4oKSkge1xuICAgICAgICAgIC8vIFRoaXMgaXMgdGhlIGRlZmF1bHQgY2FzZTogdGhlIHBvcG92ZXIgd2FzIHNob3duLCBub3cgd2Ugd2FudCB0byBjbG9zZSBpdC5cbiAgICAgICAgICB0aGlzLmFuY2hvci5wb3BvdmVyLmNsb3NlKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgLy8gVGhpcyBjYW4gaGFwcGVuIGlmIHdlIGhhdmUgZGVsYXllZCB0aGUgb3BlbmluZyBvZiB0aGUgcG9wb3ZlciwgYnV0IHRoZSBtb3VzZSBsZWZ0IHRoZSBhbmNob3IgYmVmb3JlXG4gICAgICAgICAgLy8gdGhlIHBvcG92ZXIgd2FzIHNob3duLiBJbiB0aGlzIGNhc2UsIHRoaXMuYW5jaG9yLnBvcG92ZXIuY2xvc2UoKSB3b3VsZCBub3QgZ2VuZXJhdGUgYSBjbG9zZWQgZXZlbnQsXG4gICAgICAgICAgLy8gd2hpY2ggaXMgd2h5IHdlIGdlbmVyYXRlIGl0IG1hbnVhbGx5IGhlcmUuIFRoaXMgYmVoYXZpb3Igc3VwcG9ydHMgY2FzZXMgd2hlcmUgYSBcImR1bW15XCIgYW5jaG9yIGlzXG4gICAgICAgICAgLy8gZHluYW1pY2FsbHkgY3JlYXRlZCwgbGlrZSB0aGUgRmFjdCBTaGVldCBkZXRhaWwgcG9wb3ZlciBpbiBSZXBvcnRpbmcgb3IgdGhlIHJlbGF0aW9ucyBkaWFncmFtLlxuICAgICAgICAgIHRoaXMuYW5jaG9yLnBvcG92ZXIuY2xvc2VkLmVtaXQoKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmRlc3Ryb3llZCQubmV4dCgpO1xuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignbW91c2VlbnRlcicpXG4gIHNob3dQb3BvdmVyKHNraXBEZWxheSA9IGZhbHNlKSB7XG4gICAgdGhpcy5vbk1vdXNlRW50ZXIubmV4dCh7IHNraXBEZWxheSB9KTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKVxuICBjbG9zZVBvcG92ZXIoc2tpcERlbGF5ID0gdGhpcy5za2lwQ2xvc2VEZWxheSkge1xuICAgIHRoaXMub25Nb3VzZUxlYXZlLm5leHQoeyBza2lwRGVsYXkgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -16,6 +16,7 @@ import { TranslatePipe, TranslateModule } from '@ngx-translate/core';
|
|
|
16
16
|
import * as i1$3 from '@angular/platform-browser';
|
|
17
17
|
import Color from 'color';
|
|
18
18
|
import { format, distanceInWords, startOfDay } from 'date-fns';
|
|
19
|
+
import { sanitize } from 'dompurify';
|
|
19
20
|
import _, { curry } from 'lodash';
|
|
20
21
|
import { Renderer, marked } from 'marked';
|
|
21
22
|
import * as i2$1 from '@angular/forms';
|
|
@@ -1353,6 +1354,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
1353
1354
|
|
|
1354
1355
|
class HighlightRangePipe {
|
|
1355
1356
|
transform(text, offset = 0, length = 0) {
|
|
1357
|
+
const highlightedMarkup = this.doTransform(text, offset, length);
|
|
1358
|
+
return sanitize(highlightedMarkup, { ALLOWED_TAGS: ['span'], ALLOWED_ATTR: ['class'] });
|
|
1359
|
+
}
|
|
1360
|
+
doTransform(text, offset, length) {
|
|
1356
1361
|
if (!text || offset < 0 || length < 0 || offset >= (text === null || text === void 0 ? void 0 : text.length) || offset + length > (text === null || text === void 0 ? void 0 : text.length)) {
|
|
1357
1362
|
return '';
|
|
1358
1363
|
}
|
|
@@ -1385,12 +1390,21 @@ class HighlightTermPipe {
|
|
|
1385
1390
|
* @returns The transformed text with highlighted search term.
|
|
1386
1391
|
*/
|
|
1387
1392
|
transform(text, search, options = { exactMatch: false }) {
|
|
1388
|
-
if (
|
|
1393
|
+
if (text) {
|
|
1394
|
+
const highlightedMarkup = this.doTransform(text, search, options);
|
|
1395
|
+
return highlightedMarkup ? sanitize(highlightedMarkup, { ALLOWED_TAGS: ['span'], ALLOWED_ATTR: ['class'] }) : undefined;
|
|
1396
|
+
}
|
|
1397
|
+
else {
|
|
1398
|
+
return undefined;
|
|
1399
|
+
}
|
|
1400
|
+
}
|
|
1401
|
+
doTransform(text, search, options) {
|
|
1402
|
+
if (search) {
|
|
1389
1403
|
let pattern = options.exactMatch ? search.trim() : search.replace(STANDARD_TOKENIZER_SEPERATORS, ' ');
|
|
1390
1404
|
// replace special chars for a backslash for RegExp
|
|
1391
1405
|
pattern = pattern.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, '\\$&');
|
|
1392
1406
|
pattern = options.exactMatch
|
|
1393
|
-
?
|
|
1407
|
+
? pattern
|
|
1394
1408
|
: pattern
|
|
1395
1409
|
.split(' ')
|
|
1396
1410
|
.filter((t) => {
|
|
@@ -1398,7 +1412,6 @@ class HighlightTermPipe {
|
|
|
1398
1412
|
})
|
|
1399
1413
|
.join('|');
|
|
1400
1414
|
const regex = new RegExp(pattern, 'gi');
|
|
1401
|
-
text = escape(text);
|
|
1402
1415
|
return text.replace(regex, (match) => `<span class="termHighlight">${match}</span>`); // add highlighting to matched regex pattern
|
|
1403
1416
|
}
|
|
1404
1417
|
else {
|