@agorapulse/ui-components 13.2.1 → 13.2.2
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/agorapulse-ui-components-13.2.2.tgz +0 -0
- package/esm2020/src/lib/directives/multi-style-text.directive.mjs +54 -22
- package/fesm2015/agorapulse-ui-components.mjs +52 -20
- package/fesm2015/agorapulse-ui-components.mjs.map +1 -1
- package/fesm2020/agorapulse-ui-components.mjs +52 -20
- package/fesm2020/agorapulse-ui-components.mjs.map +1 -1
- package/package.json +1 -1
- package/src/lib/directives/multi-style-text.directive.d.ts +5 -4
- package/agorapulse-ui-components-13.2.1.tgz +0 -0
|
Binary file
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
-
import { Directive, Input } from '@angular/core';
|
|
1
|
+
import { Directive, Input, Output, EventEmitter } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
const PART_START = '<ng-container data-mst="';
|
|
4
4
|
const PARSE_MIDDLE = '">';
|
|
5
5
|
const PARSE_END = '</ng-container>';
|
|
6
|
-
const
|
|
6
|
+
const DATA_SEPARATOR = ',';
|
|
7
|
+
const OPTIONAL_EVENTS_SEPARATOR = ';';
|
|
7
8
|
/**
|
|
8
|
-
* This directive aims to parse simple string to extract some specific tags and to turn them into SPAN with styling classes attributes.
|
|
9
|
-
* The specific tags must this schema: <ng-container data-mst="STYLING-CLASSES>TEXT</ng-container>.
|
|
9
|
+
* This directive aims to parse simple string to extract some specific tags and to turn them into SPAN with styling classes attributes and optional event listening.
|
|
10
|
+
* The specific tags must this schema: <ng-container data-mst="STYLING-CLASSES">TEXT</ng-container>.
|
|
10
11
|
* Example: 'Lorem <ng-container data-mst="my-style">ipsum</ng-container> dolor sit amet'.
|
|
11
12
|
*/
|
|
12
13
|
export class MultiStyleTextDirective {
|
|
@@ -14,43 +15,54 @@ export class MultiStyleTextDirective {
|
|
|
14
15
|
this.elRef = elRef;
|
|
15
16
|
this.renderer = renderer;
|
|
16
17
|
this.childrenCreated = [];
|
|
18
|
+
this.partEvent = new EventEmitter();
|
|
17
19
|
}
|
|
18
20
|
set multiStyleText(fullText) {
|
|
19
21
|
// First remove previously added children (on update).
|
|
20
22
|
for (const child of this.childrenCreated) {
|
|
21
23
|
this.renderer.removeChild(this.elRef.nativeElement, child);
|
|
22
24
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
25
|
+
MultiStyleTextDirective.parse(fullText).forEach((part) => {
|
|
26
|
+
if (part.clazz || part.clickName) {
|
|
27
|
+
// Parsed item with styling classes and/or event listening.
|
|
26
28
|
const span = this.renderer.createElement('span');
|
|
27
29
|
const text = this.renderer.createText(part.content);
|
|
28
30
|
this.renderer.appendChild(span, text);
|
|
29
|
-
part.clazz
|
|
31
|
+
if (part.clazz) {
|
|
32
|
+
part.clazz.forEach(clazz => this.renderer.addClass(span, clazz));
|
|
33
|
+
}
|
|
34
|
+
if (part.clickName) {
|
|
35
|
+
this.renderer.listen(span, 'click', () => this.partEvent.emit(part.clickName));
|
|
36
|
+
}
|
|
30
37
|
this.renderer.appendChild(this.elRef.nativeElement, span);
|
|
31
38
|
this.childrenCreated.push(span);
|
|
32
39
|
}
|
|
33
40
|
else {
|
|
41
|
+
// Specific of part without styling classes (could be used to get event listening only)
|
|
34
42
|
const text = this.renderer.createText(part.content);
|
|
35
43
|
this.renderer.appendChild(this.elRef.nativeElement, text);
|
|
36
44
|
this.childrenCreated.push(text);
|
|
37
45
|
}
|
|
38
|
-
}
|
|
46
|
+
});
|
|
39
47
|
}
|
|
40
48
|
static parse(toParse) {
|
|
41
49
|
const parts = [];
|
|
42
50
|
let startIndex = toParse.indexOf(PART_START);
|
|
43
51
|
while (startIndex >= 0) {
|
|
44
52
|
if (startIndex > 0) {
|
|
45
|
-
// Optional
|
|
46
|
-
parts.push({ content: toParse.
|
|
53
|
+
// Optional text before first parsed part.
|
|
54
|
+
parts.push({ content: toParse.substring(0, startIndex) });
|
|
47
55
|
}
|
|
48
|
-
const elem = this.cutFirstGroup(toParse.
|
|
56
|
+
const elem = this.cutFirstGroup(toParse.substring(startIndex));
|
|
49
57
|
if (elem === 'invalid') {
|
|
50
58
|
return [];
|
|
51
59
|
}
|
|
52
60
|
else if (elem) {
|
|
53
|
-
parts.push({
|
|
61
|
+
parts.push({
|
|
62
|
+
content: elem.content,
|
|
63
|
+
clazz: elem.classes,
|
|
64
|
+
clickName: elem.clickName
|
|
65
|
+
});
|
|
54
66
|
toParse = elem.rest;
|
|
55
67
|
startIndex = toParse.indexOf(PART_START);
|
|
56
68
|
}
|
|
@@ -66,29 +78,47 @@ export class MultiStyleTextDirective {
|
|
|
66
78
|
}
|
|
67
79
|
static cutFirstGroup(toCut) {
|
|
68
80
|
if (!toCut.startsWith(PART_START)) {
|
|
69
|
-
// String
|
|
81
|
+
// String doesn't start with expected parser start.
|
|
70
82
|
return null;
|
|
71
83
|
}
|
|
72
|
-
const afterParserStart = toCut.
|
|
84
|
+
const afterParserStart = toCut.substring(PART_START.length);
|
|
73
85
|
let index = afterParserStart.indexOf(PARSE_MIDDLE);
|
|
74
86
|
if (index <= 0) {
|
|
75
87
|
console.error('Not able to parse invalid string: ' + toCut);
|
|
76
88
|
return 'invalid';
|
|
77
89
|
}
|
|
78
|
-
const
|
|
79
|
-
let
|
|
90
|
+
const data = afterParserStart.substring(0, index);
|
|
91
|
+
let classes;
|
|
92
|
+
let clickName;
|
|
93
|
+
const eventsPartSeparatorIndex = data.indexOf(OPTIONAL_EVENTS_SEPARATOR);
|
|
94
|
+
if (eventsPartSeparatorIndex > 0) {
|
|
95
|
+
// Case the data contains events part with dedicated separator
|
|
96
|
+
classes = data.substring(0, eventsPartSeparatorIndex);
|
|
97
|
+
clickName = data.substring(eventsPartSeparatorIndex + 1);
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
// Otherwise, only design classes are provided
|
|
101
|
+
classes = data;
|
|
102
|
+
clickName = undefined;
|
|
103
|
+
}
|
|
104
|
+
let rest = afterParserStart.substring(index + PARSE_MIDDLE.length);
|
|
80
105
|
index = rest.indexOf(PARSE_END);
|
|
81
106
|
if (index <= 0) {
|
|
82
107
|
console.error('Not able to parse invalid string: ' + toCut);
|
|
83
108
|
return 'invalid';
|
|
84
109
|
}
|
|
85
|
-
const content = rest.
|
|
86
|
-
rest = rest.
|
|
87
|
-
return {
|
|
110
|
+
const content = rest.substring(0, index);
|
|
111
|
+
rest = rest.substring(index + PARSE_END.length);
|
|
112
|
+
return {
|
|
113
|
+
content,
|
|
114
|
+
classes: classes.split(DATA_SEPARATOR),
|
|
115
|
+
clickName,
|
|
116
|
+
rest
|
|
117
|
+
};
|
|
88
118
|
}
|
|
89
119
|
}
|
|
90
120
|
/** @nocollapse */ /** @nocollapse */ MultiStyleTextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: MultiStyleTextDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
91
|
-
/** @nocollapse */ /** @nocollapse */ MultiStyleTextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: MultiStyleTextDirective, selector: "[multiStyleText]", inputs: { multiStyleText: "multiStyleText" }, ngImport: i0 });
|
|
121
|
+
/** @nocollapse */ /** @nocollapse */ MultiStyleTextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: MultiStyleTextDirective, selector: "[multiStyleText]", inputs: { multiStyleText: "multiStyleText" }, outputs: { partEvent: "partEvent" }, ngImport: i0 });
|
|
92
122
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: MultiStyleTextDirective, decorators: [{
|
|
93
123
|
type: Directive,
|
|
94
124
|
args: [{
|
|
@@ -97,5 +127,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
97
127
|
}]
|
|
98
128
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { multiStyleText: [{
|
|
99
129
|
type: Input
|
|
130
|
+
}], partEvent: [{
|
|
131
|
+
type: Output
|
|
100
132
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-style-text.directive.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/directives/multi-style-text.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, Renderer2, ElementRef} from '@angular/core';\n\nconst PART_START = '<ng-container data-mst=\"';\nconst PARSE_MIDDLE = '\">';\nconst PARSE_END = '</ng-container>';\nconst CLASS_SEPARATOR = ',';\n\ninterface Part {\n    content: string;\n    clazz?: string[];\n}\n\n/**\n * This directive aims to parse simple string to extract some specific tags and to turn them into SPAN with styling classes attributes.\n * The specific tags must this schema: <ng-container data-mst=\"STYLING-CLASSES>TEXT</ng-container>.\n * Example: 'Lorem <ng-container data-mst=\"my-style\">ipsum</ng-container> dolor sit amet'.\n */\n@Directive({\n    // tslint:disable-next-line:directive-selector\n    selector: '[multiStyleText]'\n})\nexport class MultiStyleTextDirective {\n\n    private childrenCreated: any[] = [];\n\n    @Input() set multiStyleText(fullText: string) {\n        // First remove previously added children (on update).\n        for (const child of this.childrenCreated) {\n            this.renderer.removeChild(this.elRef.nativeElement, child);\n        }\n\n        const parts = MultiStyleTextDirective.parse(fullText);\n\n        for (const part of parts) {\n            if (part.clazz) {\n                const span = this.renderer.createElement('span');\n                const text = this.renderer.createText(part.content);\n                this.renderer.appendChild(span, text);\n                part.clazz.forEach(clazz => this.renderer.addClass(span, clazz));\n                this.renderer.appendChild(this.elRef.nativeElement, span);\n                this.childrenCreated.push(span);\n            } else {\n                const text = this.renderer.createText(part.content);\n                this.renderer.appendChild(this.elRef.nativeElement, text);\n                this.childrenCreated.push(text);\n            }\n        }\n    }\n\n    public constructor(\n        private elRef: ElementRef,\n        private renderer: Renderer2\n    ) {\n    }\n\n    private static parse(toParse: string): Part[] {\n        const parts: Part[] = [];\n\n        let startIndex = toParse.indexOf(PART_START);\n        while (startIndex >= 0) {\n            if (startIndex > 0) {\n                // Optional start before parser start.\n                parts.push({content: toParse.substr(0, startIndex)});\n            }\n            const elem = this.cutFirstGroup(toParse.substr(startIndex));\n            if (elem === 'invalid') {\n                return [];\n            } else if (elem) {\n                parts.push({content: elem.content, clazz: elem.classes});\n                toParse = elem.rest;\n                startIndex = toParse.indexOf(PART_START);\n            } else {\n                parts.push({content: toParse});\n            }\n        }\n        // Very end\n        if (toParse.length > 0) {\n            parts.push({content: toParse});\n        }\n        return parts;\n    }\n\n    private static cutFirstGroup(toCut: string): {content: string, classes: string[], rest: string} | 'invalid' | null {\n        if (!toCut.startsWith(PART_START)) {\n            // String doesnt start with expected parser start.\n            return null;\n        }\n\n        const afterParserStart = toCut.substr(PART_START.length);\n        let index = afterParserStart.indexOf(PARSE_MIDDLE);\n        if (index <= 0) {\n            console.error('Not able to parse invalid string: ' + toCut);\n            return 'invalid';\n        }\n        const classes = afterParserStart.substr(0, index);\n        let rest = afterParserStart.substr(index + PARSE_MIDDLE.length);\n        index = rest.indexOf(PARSE_END);\n        if (index <= 0) {\n            console.error('Not able to parse invalid string: ' + toCut);\n            return 'invalid';\n        }\n        const content = rest.substr(0, index);\n        rest = rest.substr(index + PARSE_END.length);\n\n        return {content, classes: classes.split(CLASS_SEPARATOR), rest};\n    }\n}\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-style-text.directive.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/directives/multi-style-text.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, Renderer2, ElementRef, Output, EventEmitter} from '@angular/core';\n\nconst PART_START = '<ng-container data-mst=\"';\nconst PARSE_MIDDLE = '\">';\nconst PARSE_END = '</ng-container>';\nconst DATA_SEPARATOR = ',';\nconst OPTIONAL_EVENTS_SEPARATOR = ';';\n\ninterface Part {\n    content: string;\n    clazz?: string[]; // Not defined on sterile text\n    clickName?: string; // Not defined on sterile text\n}\n\n/**\n * This directive aims to parse simple string to extract some specific tags and to turn them into SPAN with styling classes attributes and optional event listening.\n * The specific tags must this schema: <ng-container data-mst=\"STYLING-CLASSES\">TEXT</ng-container>.\n * Example: 'Lorem <ng-container data-mst=\"my-style\">ipsum</ng-container> dolor sit amet'.\n */\n@Directive({\n    // tslint:disable-next-line:directive-selector\n    selector: '[multiStyleText]'\n})\nexport class MultiStyleTextDirective {\n\n    private childrenCreated: any[] = [];\n\n    @Input() set multiStyleText(fullText: string) {\n        // First remove previously added children (on update).\n        for (const child of this.childrenCreated) {\n            this.renderer.removeChild(this.elRef.nativeElement, child);\n        }\n\n        MultiStyleTextDirective.parse(fullText).forEach((part: Part) => {\n            if (part.clazz || part.clickName) {\n                // Parsed item with styling classes and/or event listening.\n                const span = this.renderer.createElement('span');\n                const text = this.renderer.createText(part.content);\n                this.renderer.appendChild(span, text);\n                if (part.clazz) {\n                    part.clazz.forEach(clazz => this.renderer.addClass(span, clazz));\n                }\n                if (part.clickName) {\n                    this.renderer.listen(span, 'click', () => this.partEvent.emit(part.clickName));\n                }\n                this.renderer.appendChild(this.elRef.nativeElement, span);\n                this.childrenCreated.push(span);\n            } else {\n                // Specific of part without styling classes (could be used to get event listening only)\n                const text = this.renderer.createText(part.content);\n                this.renderer.appendChild(this.elRef.nativeElement, text);\n                this.childrenCreated.push(text);\n            }\n        });\n    }\n\n    @Output() partEvent = new EventEmitter<string>();\n\n    public constructor(\n        private elRef: ElementRef,\n        private renderer: Renderer2\n    ) {\n    }\n\n    private static parse(toParse: string): Part[] {\n        const parts: Part[] = [];\n        let startIndex = toParse.indexOf(PART_START);\n        while (startIndex >= 0) {\n            if (startIndex > 0) {\n                // Optional text before first parsed part.\n                parts.push({content: toParse.substring(0, startIndex)});\n            }\n            const elem = this.cutFirstGroup(toParse.substring(startIndex));\n            if (elem === 'invalid') {\n                return [];\n            } else if (elem) {\n                parts.push({\n                    content: elem.content,\n                    clazz: elem.classes,\n                    clickName: elem.clickName\n                });\n                toParse = elem.rest;\n                startIndex = toParse.indexOf(PART_START);\n            } else {\n                parts.push({content: toParse});\n            }\n        }\n        // Very end\n        if (toParse.length > 0) {\n            parts.push({content: toParse});\n        }\n        return parts;\n    }\n\n    private static cutFirstGroup(toCut: string): {content: string, classes: string[], clickName: string, rest: string} | 'invalid' | null {\n        if (!toCut.startsWith(PART_START)) {\n            // String doesn't start with expected parser start.\n            return null;\n        }\n\n        const afterParserStart = toCut.substring(PART_START.length);\n        let index = afterParserStart.indexOf(PARSE_MIDDLE);\n        if (index <= 0) {\n            console.error('Not able to parse invalid string: ' + toCut);\n            return 'invalid';\n        }\n        const data = afterParserStart.substring(0, index);\n        let classes;\n        let clickName;\n        const eventsPartSeparatorIndex = data.indexOf(OPTIONAL_EVENTS_SEPARATOR);\n        if (eventsPartSeparatorIndex > 0) {\n            // Case the data contains events part with dedicated separator\n            classes = data.substring(0, eventsPartSeparatorIndex);\n            clickName = data.substring(eventsPartSeparatorIndex + 1);\n        } else {\n            // Otherwise, only design classes are provided\n            classes = data;\n            clickName = undefined;\n        }\n        let rest = afterParserStart.substring(index + PARSE_MIDDLE.length);\n        index = rest.indexOf(PARSE_END);\n        if (index <= 0) {\n            console.error('Not able to parse invalid string: ' + toCut);\n            return 'invalid';\n        }\n        const content = rest.substring(0, index);\n        rest = rest.substring(index + PARSE_END.length);\n\n        return {\n            content,\n            classes: classes.split(DATA_SEPARATOR),\n            clickName,\n            rest\n        };\n    }\n}\n"]}
|
|
@@ -3264,10 +3264,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
3264
3264
|
const PART_START = '<ng-container data-mst="';
|
|
3265
3265
|
const PARSE_MIDDLE = '">';
|
|
3266
3266
|
const PARSE_END = '</ng-container>';
|
|
3267
|
-
const
|
|
3267
|
+
const DATA_SEPARATOR = ',';
|
|
3268
|
+
const OPTIONAL_EVENTS_SEPARATOR = ';';
|
|
3268
3269
|
/**
|
|
3269
|
-
* This directive aims to parse simple string to extract some specific tags and to turn them into SPAN with styling classes attributes.
|
|
3270
|
-
* The specific tags must this schema: <ng-container data-mst="STYLING-CLASSES>TEXT</ng-container>.
|
|
3270
|
+
* This directive aims to parse simple string to extract some specific tags and to turn them into SPAN with styling classes attributes and optional event listening.
|
|
3271
|
+
* The specific tags must this schema: <ng-container data-mst="STYLING-CLASSES">TEXT</ng-container>.
|
|
3271
3272
|
* Example: 'Lorem <ng-container data-mst="my-style">ipsum</ng-container> dolor sit amet'.
|
|
3272
3273
|
*/
|
|
3273
3274
|
class MultiStyleTextDirective {
|
|
@@ -3275,43 +3276,54 @@ class MultiStyleTextDirective {
|
|
|
3275
3276
|
this.elRef = elRef;
|
|
3276
3277
|
this.renderer = renderer;
|
|
3277
3278
|
this.childrenCreated = [];
|
|
3279
|
+
this.partEvent = new EventEmitter();
|
|
3278
3280
|
}
|
|
3279
3281
|
set multiStyleText(fullText) {
|
|
3280
3282
|
// First remove previously added children (on update).
|
|
3281
3283
|
for (const child of this.childrenCreated) {
|
|
3282
3284
|
this.renderer.removeChild(this.elRef.nativeElement, child);
|
|
3283
3285
|
}
|
|
3284
|
-
|
|
3285
|
-
|
|
3286
|
-
|
|
3286
|
+
MultiStyleTextDirective.parse(fullText).forEach((part) => {
|
|
3287
|
+
if (part.clazz || part.clickName) {
|
|
3288
|
+
// Parsed item with styling classes and/or event listening.
|
|
3287
3289
|
const span = this.renderer.createElement('span');
|
|
3288
3290
|
const text = this.renderer.createText(part.content);
|
|
3289
3291
|
this.renderer.appendChild(span, text);
|
|
3290
|
-
part.clazz
|
|
3292
|
+
if (part.clazz) {
|
|
3293
|
+
part.clazz.forEach(clazz => this.renderer.addClass(span, clazz));
|
|
3294
|
+
}
|
|
3295
|
+
if (part.clickName) {
|
|
3296
|
+
this.renderer.listen(span, 'click', () => this.partEvent.emit(part.clickName));
|
|
3297
|
+
}
|
|
3291
3298
|
this.renderer.appendChild(this.elRef.nativeElement, span);
|
|
3292
3299
|
this.childrenCreated.push(span);
|
|
3293
3300
|
}
|
|
3294
3301
|
else {
|
|
3302
|
+
// Specific of part without styling classes (could be used to get event listening only)
|
|
3295
3303
|
const text = this.renderer.createText(part.content);
|
|
3296
3304
|
this.renderer.appendChild(this.elRef.nativeElement, text);
|
|
3297
3305
|
this.childrenCreated.push(text);
|
|
3298
3306
|
}
|
|
3299
|
-
}
|
|
3307
|
+
});
|
|
3300
3308
|
}
|
|
3301
3309
|
static parse(toParse) {
|
|
3302
3310
|
const parts = [];
|
|
3303
3311
|
let startIndex = toParse.indexOf(PART_START);
|
|
3304
3312
|
while (startIndex >= 0) {
|
|
3305
3313
|
if (startIndex > 0) {
|
|
3306
|
-
// Optional
|
|
3307
|
-
parts.push({ content: toParse.
|
|
3314
|
+
// Optional text before first parsed part.
|
|
3315
|
+
parts.push({ content: toParse.substring(0, startIndex) });
|
|
3308
3316
|
}
|
|
3309
|
-
const elem = this.cutFirstGroup(toParse.
|
|
3317
|
+
const elem = this.cutFirstGroup(toParse.substring(startIndex));
|
|
3310
3318
|
if (elem === 'invalid') {
|
|
3311
3319
|
return [];
|
|
3312
3320
|
}
|
|
3313
3321
|
else if (elem) {
|
|
3314
|
-
parts.push({
|
|
3322
|
+
parts.push({
|
|
3323
|
+
content: elem.content,
|
|
3324
|
+
clazz: elem.classes,
|
|
3325
|
+
clickName: elem.clickName
|
|
3326
|
+
});
|
|
3315
3327
|
toParse = elem.rest;
|
|
3316
3328
|
startIndex = toParse.indexOf(PART_START);
|
|
3317
3329
|
}
|
|
@@ -3327,29 +3339,47 @@ class MultiStyleTextDirective {
|
|
|
3327
3339
|
}
|
|
3328
3340
|
static cutFirstGroup(toCut) {
|
|
3329
3341
|
if (!toCut.startsWith(PART_START)) {
|
|
3330
|
-
// String
|
|
3342
|
+
// String doesn't start with expected parser start.
|
|
3331
3343
|
return null;
|
|
3332
3344
|
}
|
|
3333
|
-
const afterParserStart = toCut.
|
|
3345
|
+
const afterParserStart = toCut.substring(PART_START.length);
|
|
3334
3346
|
let index = afterParserStart.indexOf(PARSE_MIDDLE);
|
|
3335
3347
|
if (index <= 0) {
|
|
3336
3348
|
console.error('Not able to parse invalid string: ' + toCut);
|
|
3337
3349
|
return 'invalid';
|
|
3338
3350
|
}
|
|
3339
|
-
const
|
|
3340
|
-
let
|
|
3351
|
+
const data = afterParserStart.substring(0, index);
|
|
3352
|
+
let classes;
|
|
3353
|
+
let clickName;
|
|
3354
|
+
const eventsPartSeparatorIndex = data.indexOf(OPTIONAL_EVENTS_SEPARATOR);
|
|
3355
|
+
if (eventsPartSeparatorIndex > 0) {
|
|
3356
|
+
// Case the data contains events part with dedicated separator
|
|
3357
|
+
classes = data.substring(0, eventsPartSeparatorIndex);
|
|
3358
|
+
clickName = data.substring(eventsPartSeparatorIndex + 1);
|
|
3359
|
+
}
|
|
3360
|
+
else {
|
|
3361
|
+
// Otherwise, only design classes are provided
|
|
3362
|
+
classes = data;
|
|
3363
|
+
clickName = undefined;
|
|
3364
|
+
}
|
|
3365
|
+
let rest = afterParserStart.substring(index + PARSE_MIDDLE.length);
|
|
3341
3366
|
index = rest.indexOf(PARSE_END);
|
|
3342
3367
|
if (index <= 0) {
|
|
3343
3368
|
console.error('Not able to parse invalid string: ' + toCut);
|
|
3344
3369
|
return 'invalid';
|
|
3345
3370
|
}
|
|
3346
|
-
const content = rest.
|
|
3347
|
-
rest = rest.
|
|
3348
|
-
return {
|
|
3371
|
+
const content = rest.substring(0, index);
|
|
3372
|
+
rest = rest.substring(index + PARSE_END.length);
|
|
3373
|
+
return {
|
|
3374
|
+
content,
|
|
3375
|
+
classes: classes.split(DATA_SEPARATOR),
|
|
3376
|
+
clickName,
|
|
3377
|
+
rest
|
|
3378
|
+
};
|
|
3349
3379
|
}
|
|
3350
3380
|
}
|
|
3351
3381
|
/** @nocollapse */ /** @nocollapse */ MultiStyleTextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: MultiStyleTextDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
3352
|
-
/** @nocollapse */ /** @nocollapse */ MultiStyleTextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: MultiStyleTextDirective, selector: "[multiStyleText]", inputs: { multiStyleText: "multiStyleText" }, ngImport: i0 });
|
|
3382
|
+
/** @nocollapse */ /** @nocollapse */ MultiStyleTextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: MultiStyleTextDirective, selector: "[multiStyleText]", inputs: { multiStyleText: "multiStyleText" }, outputs: { partEvent: "partEvent" }, ngImport: i0 });
|
|
3353
3383
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: MultiStyleTextDirective, decorators: [{
|
|
3354
3384
|
type: Directive,
|
|
3355
3385
|
args: [{
|
|
@@ -3358,6 +3388,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
3358
3388
|
}]
|
|
3359
3389
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { multiStyleText: [{
|
|
3360
3390
|
type: Input
|
|
3391
|
+
}], partEvent: [{
|
|
3392
|
+
type: Output
|
|
3361
3393
|
}] } });
|
|
3362
3394
|
|
|
3363
3395
|
// Angular
|