@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.
@@ -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 CLASS_SEPARATOR = ',';
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
- const parts = MultiStyleTextDirective.parse(fullText);
24
- for (const part of parts) {
25
- if (part.clazz) {
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.forEach(clazz => this.renderer.addClass(span, 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 start before parser start.
46
- parts.push({ content: toParse.substr(0, startIndex) });
53
+ // Optional text before first parsed part.
54
+ parts.push({ content: toParse.substring(0, startIndex) });
47
55
  }
48
- const elem = this.cutFirstGroup(toParse.substr(startIndex));
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({ content: elem.content, clazz: elem.classes });
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 doesnt start with expected parser start.
81
+ // String doesn't start with expected parser start.
70
82
  return null;
71
83
  }
72
- const afterParserStart = toCut.substr(PART_START.length);
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 classes = afterParserStart.substr(0, index);
79
- let rest = afterParserStart.substr(index + PARSE_MIDDLE.length);
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.substr(0, index);
86
- rest = rest.substr(index + PARSE_END.length);
87
- return { content, classes: classes.split(CLASS_SEPARATOR), rest };
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 CLASS_SEPARATOR = ',';
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
- const parts = MultiStyleTextDirective.parse(fullText);
3285
- for (const part of parts) {
3286
- if (part.clazz) {
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.forEach(clazz => this.renderer.addClass(span, 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 start before parser start.
3307
- parts.push({ content: toParse.substr(0, startIndex) });
3314
+ // Optional text before first parsed part.
3315
+ parts.push({ content: toParse.substring(0, startIndex) });
3308
3316
  }
3309
- const elem = this.cutFirstGroup(toParse.substr(startIndex));
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({ content: elem.content, clazz: elem.classes });
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 doesnt start with expected parser start.
3342
+ // String doesn't start with expected parser start.
3331
3343
  return null;
3332
3344
  }
3333
- const afterParserStart = toCut.substr(PART_START.length);
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 classes = afterParserStart.substr(0, index);
3340
- let rest = afterParserStart.substr(index + PARSE_MIDDLE.length);
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.substr(0, index);
3347
- rest = rest.substr(index + PARSE_END.length);
3348
- return { content, classes: classes.split(CLASS_SEPARATOR), rest };
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