@matechat/ng 0.0.1-alpha.0 → 0.0.1-alpha.1
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/Bubble/bubble.component.d.ts +5 -3
- package/Input/input.component.d.ts +10 -1
- package/MarkdownCard/code-block.component.d.ts +46 -0
- package/MarkdownCard/index.d.ts +3 -0
- package/MarkdownCard/markdown-card.component.d.ts +198 -0
- package/MarkdownCard/markdown-card.module.d.ts +13 -0
- package/README.md +117 -13
- package/components-common/Base/foundation.d.ts +2 -0
- package/components-common/MarkdownCard/codeblock-foundation.d.ts +20 -0
- package/components-common/MarkdownCard/common/MDCardService.d.ts +14 -0
- package/components-common/MarkdownCard/common/MermaidService.d.ts +23 -0
- package/components-common/MarkdownCard/common/mdCard.types.d.ts +56 -0
- package/components-common/MarkdownCard/common/parser.d.ts +150 -0
- package/components-common/MarkdownCard/foundation.d.ts +38 -0
- package/esm2022/Base/base.component.mjs +2 -1
- package/esm2022/Bubble/bubble.component.mjs +15 -8
- package/esm2022/Input/input.component.mjs +107 -3
- package/esm2022/Locale/locale.service.mjs +5 -5
- package/esm2022/MarkdownCard/code-block.component.mjs +150 -0
- package/esm2022/MarkdownCard/index.mjs +4 -0
- package/esm2022/MarkdownCard/markdown-card.component.mjs +406 -0
- package/esm2022/MarkdownCard/markdown-card.module.mjs +44 -0
- package/esm2022/components-common/Base/foundation.mjs +4 -1
- package/esm2022/components-common/Input/foundation.mjs +1 -2
- package/esm2022/components-common/MarkdownCard/codeblock-foundation.mjs +132 -0
- package/esm2022/components-common/MarkdownCard/common/MDCardService.mjs +69 -0
- package/esm2022/components-common/MarkdownCard/common/MermaidService.mjs +222 -0
- package/esm2022/components-common/MarkdownCard/common/mdCard.types.mjs +6 -0
- package/esm2022/components-common/MarkdownCard/common/parser.mjs +194 -0
- package/esm2022/components-common/MarkdownCard/foundation.mjs +84 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/matechat-ng.mjs +1460 -16
- package/fesm2022/matechat-ng.mjs.map +1 -1
- package/package.json +8 -5
- package/public-api.d.ts +1 -0
- package/fesm2022/matechat-ng-en-us-DsYnUbZd.mjs +0 -28
- package/fesm2022/matechat-ng-en-us-DsYnUbZd.mjs.map +0 -1
- package/fesm2022/matechat-ng-zh-cn--_YVZHnW.mjs +0 -28
- package/fesm2022/matechat-ng-zh-cn--_YVZHnW.mjs.map +0 -1
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import type { Token } from "markdown-it";
|
|
2
|
+
import type { ASTNode } from './mdCard.types';
|
|
3
|
+
export declare const isSelfClosingTag: (token: Token) => boolean;
|
|
4
|
+
export declare const isClosingTag: (openToken: Token, closeToken: Token) => boolean;
|
|
5
|
+
export declare const genTreeNode: (node: Token | null) => ASTNode;
|
|
6
|
+
export declare const matchHtmlToken: (token: Token, stack: Token[]) => void;
|
|
7
|
+
export declare const isValidTagName: (tagName: string | undefined) => boolean;
|
|
8
|
+
export declare const tokensToAst: (tokens: Token[]) => ASTNode[];
|
|
9
|
+
declare const _default: {
|
|
10
|
+
isSelfClosingTag: (token: {
|
|
11
|
+
type: string;
|
|
12
|
+
tag: string;
|
|
13
|
+
attrs: [string, string][] | null;
|
|
14
|
+
map: [number, number] | null;
|
|
15
|
+
nesting: Token.Nesting;
|
|
16
|
+
level: number;
|
|
17
|
+
children: any[] | null;
|
|
18
|
+
content: string;
|
|
19
|
+
markup: string;
|
|
20
|
+
info: string;
|
|
21
|
+
meta: any;
|
|
22
|
+
block: boolean;
|
|
23
|
+
hidden: boolean;
|
|
24
|
+
attrIndex(name: string): number;
|
|
25
|
+
attrPush(attrData: [string, string]): void;
|
|
26
|
+
attrSet(name: string, value: string): void;
|
|
27
|
+
attrGet(name: string): string | null;
|
|
28
|
+
attrJoin(name: string, value: string): void;
|
|
29
|
+
}) => boolean;
|
|
30
|
+
isClosingTag: (openToken: {
|
|
31
|
+
type: string;
|
|
32
|
+
tag: string;
|
|
33
|
+
attrs: [string, string][] | null;
|
|
34
|
+
map: [number, number] | null;
|
|
35
|
+
nesting: Token.Nesting;
|
|
36
|
+
level: number;
|
|
37
|
+
children: any[] | null;
|
|
38
|
+
content: string;
|
|
39
|
+
markup: string;
|
|
40
|
+
info: string;
|
|
41
|
+
meta: any;
|
|
42
|
+
block: boolean;
|
|
43
|
+
hidden: boolean;
|
|
44
|
+
attrIndex(name: string): number;
|
|
45
|
+
attrPush(attrData: [string, string]): void;
|
|
46
|
+
attrSet(name: string, value: string): void;
|
|
47
|
+
attrGet(name: string): string | null;
|
|
48
|
+
attrJoin(name: string, value: string): void;
|
|
49
|
+
}, closeToken: {
|
|
50
|
+
type: string;
|
|
51
|
+
tag: string;
|
|
52
|
+
attrs: [string, string][] | null;
|
|
53
|
+
map: [number, number] | null;
|
|
54
|
+
nesting: Token.Nesting;
|
|
55
|
+
level: number;
|
|
56
|
+
children: any[] | null;
|
|
57
|
+
content: string;
|
|
58
|
+
markup: string;
|
|
59
|
+
info: string;
|
|
60
|
+
meta: any;
|
|
61
|
+
block: boolean;
|
|
62
|
+
hidden: boolean;
|
|
63
|
+
attrIndex(name: string): number;
|
|
64
|
+
attrPush(attrData: [string, string]): void;
|
|
65
|
+
attrSet(name: string, value: string): void;
|
|
66
|
+
attrGet(name: string): string | null;
|
|
67
|
+
attrJoin(name: string, value: string): void;
|
|
68
|
+
}) => boolean;
|
|
69
|
+
tokensToAst: (tokens: {
|
|
70
|
+
type: string;
|
|
71
|
+
tag: string;
|
|
72
|
+
attrs: [string, string][] | null;
|
|
73
|
+
map: [number, number] | null;
|
|
74
|
+
nesting: Token.Nesting;
|
|
75
|
+
level: number;
|
|
76
|
+
children: any[] | null;
|
|
77
|
+
content: string;
|
|
78
|
+
markup: string;
|
|
79
|
+
info: string;
|
|
80
|
+
meta: any;
|
|
81
|
+
block: boolean;
|
|
82
|
+
hidden: boolean;
|
|
83
|
+
attrIndex(name: string): number;
|
|
84
|
+
attrPush(attrData: [string, string]): void;
|
|
85
|
+
attrSet(name: string, value: string): void;
|
|
86
|
+
attrGet(name: string): string | null;
|
|
87
|
+
attrJoin(name: string, value: string): void;
|
|
88
|
+
}[]) => ASTNode[];
|
|
89
|
+
genTreeNode: (node: {
|
|
90
|
+
type: string;
|
|
91
|
+
tag: string;
|
|
92
|
+
attrs: [string, string][] | null;
|
|
93
|
+
map: [number, number] | null;
|
|
94
|
+
nesting: Token.Nesting;
|
|
95
|
+
level: number;
|
|
96
|
+
children: any[] | null;
|
|
97
|
+
content: string;
|
|
98
|
+
markup: string;
|
|
99
|
+
info: string;
|
|
100
|
+
meta: any;
|
|
101
|
+
block: boolean;
|
|
102
|
+
hidden: boolean;
|
|
103
|
+
attrIndex(name: string): number;
|
|
104
|
+
attrPush(attrData: [string, string]): void;
|
|
105
|
+
attrSet(name: string, value: string): void;
|
|
106
|
+
attrGet(name: string): string | null;
|
|
107
|
+
attrJoin(name: string, value: string): void;
|
|
108
|
+
} | null) => ASTNode;
|
|
109
|
+
matchHtmlToken: (token: {
|
|
110
|
+
type: string;
|
|
111
|
+
tag: string;
|
|
112
|
+
attrs: [string, string][] | null;
|
|
113
|
+
map: [number, number] | null;
|
|
114
|
+
nesting: Token.Nesting;
|
|
115
|
+
level: number;
|
|
116
|
+
children: any[] | null;
|
|
117
|
+
content: string;
|
|
118
|
+
markup: string;
|
|
119
|
+
info: string;
|
|
120
|
+
meta: any;
|
|
121
|
+
block: boolean;
|
|
122
|
+
hidden: boolean;
|
|
123
|
+
attrIndex(name: string): number;
|
|
124
|
+
attrPush(attrData: [string, string]): void;
|
|
125
|
+
attrSet(name: string, value: string): void;
|
|
126
|
+
attrGet(name: string): string | null;
|
|
127
|
+
attrJoin(name: string, value: string): void;
|
|
128
|
+
}, stack: {
|
|
129
|
+
type: string;
|
|
130
|
+
tag: string;
|
|
131
|
+
attrs: [string, string][] | null;
|
|
132
|
+
map: [number, number] | null;
|
|
133
|
+
nesting: Token.Nesting;
|
|
134
|
+
level: number;
|
|
135
|
+
children: any[] | null;
|
|
136
|
+
content: string;
|
|
137
|
+
markup: string;
|
|
138
|
+
info: string;
|
|
139
|
+
meta: any;
|
|
140
|
+
block: boolean;
|
|
141
|
+
hidden: boolean;
|
|
142
|
+
attrIndex(name: string): number;
|
|
143
|
+
attrPush(attrData: [string, string]): void;
|
|
144
|
+
attrSet(name: string, value: string): void;
|
|
145
|
+
attrGet(name: string): string | null;
|
|
146
|
+
attrJoin(name: string, value: string): void;
|
|
147
|
+
}[]) => void;
|
|
148
|
+
isValidTagName: (tagName: string | undefined) => boolean;
|
|
149
|
+
};
|
|
150
|
+
export default _default;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import BaseFoundation, { DefaultAdapter } from '../Base/foundation';
|
|
2
|
+
import type { Token } from 'markdown-it';
|
|
3
|
+
import type { ASTNode } from './common/mdCard.types';
|
|
4
|
+
export interface MarkdownCardAdapter extends DefaultAdapter {
|
|
5
|
+
locale(key: string, params?: Record<string, string>): string;
|
|
6
|
+
typingStart: () => void;
|
|
7
|
+
typingEnd: () => void;
|
|
8
|
+
typingEvent: () => void;
|
|
9
|
+
parseContent: (content: string) => void;
|
|
10
|
+
}
|
|
11
|
+
export declare class MarkdownCardFoundation extends BaseFoundation<MarkdownCardAdapter> {
|
|
12
|
+
constructor(adapter: MarkdownCardAdapter);
|
|
13
|
+
isToken: (node: ASTNode | Token) => node is {
|
|
14
|
+
type: string;
|
|
15
|
+
tag: string;
|
|
16
|
+
attrs: [string, string][] | null;
|
|
17
|
+
map: [number, number] | null;
|
|
18
|
+
nesting: Token.Nesting;
|
|
19
|
+
level: number;
|
|
20
|
+
children: any[] | null;
|
|
21
|
+
content: string;
|
|
22
|
+
markup: string;
|
|
23
|
+
info: string;
|
|
24
|
+
meta: any;
|
|
25
|
+
block: boolean;
|
|
26
|
+
hidden: boolean;
|
|
27
|
+
attrIndex(name: string): number;
|
|
28
|
+
attrPush(attrData: [string, string]): void;
|
|
29
|
+
attrSet(name: string, value: string): void;
|
|
30
|
+
attrGet(name: string): string | null;
|
|
31
|
+
attrJoin(name: string, value: string): void;
|
|
32
|
+
};
|
|
33
|
+
typewriterEnd: () => void;
|
|
34
|
+
getThinkContent: (content: string, thinkOptions: any) => string;
|
|
35
|
+
parseTypingContent: (content: string) => string;
|
|
36
|
+
parseContent: () => void;
|
|
37
|
+
typewriterStart: () => void;
|
|
38
|
+
}
|
|
@@ -30,6 +30,7 @@ export default class BaseComponent {
|
|
|
30
30
|
getCache: (key) => key && this.cache[key],
|
|
31
31
|
getCaches: () => this.cache,
|
|
32
32
|
setCache: (key, value) => key && (this.cache[key] = value),
|
|
33
|
+
nextTick: (cb) => setTimeout(cb, 0),
|
|
33
34
|
};
|
|
34
35
|
}
|
|
35
36
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: BaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -43,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
43
44
|
template: '',
|
|
44
45
|
}]
|
|
45
46
|
}], ctorParameters: () => [] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzLW5nL3NyYy9CYXNlL2Jhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzFDLE1BQU0sQ0FBQyxPQUFPLE9BQU8sYUFBYTtJQUdoQztRQUNFLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVU7WUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxLQUFLLFVBQVU7WUFDN0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1QsT0FBTztZQUNMLE9BQU8sRUFBRSxDQUFDLEdBQVcsRUFBRSxFQUFFO2dCQUN2QixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixDQUFDO1lBQ0QsUUFBUSxFQUFFLEdBQUcsRUFBRTtnQkFDYixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFDRCxRQUFRLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEVBQUU7Z0JBQ3ZCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxFQUFFLENBQUM7b0JBQ3pCLElBQUksTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO3dCQUMvQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO29CQUMxQixDQUFDO29CQUNELEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQztnQkFDYixDQUFDO1lBQ0gsQ0FBQztZQUNELFFBQVEsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUM1QixTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSTtZQUNyQixRQUFRLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQztZQUN6QyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUs7WUFDM0IsUUFBUSxFQUFFLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDMUQsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztTQUNwQyxDQUFDO0lBQ0osQ0FBQzs4R0FwQ2tCLGFBQWE7a0dBQWIsYUFBYSwrRUFGdEIsRUFBRTs7MkZBRU8sYUFBYTtrQkFMakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLEVBQUU7aUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZWZhdWx0QWRhcHRlciB9IGZyb20gJy4uL2NvbXBvbmVudHMtY29tbW9uL0Jhc2UvZm91bmRhdGlvbic7XG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbWF0ZS1iYXNlLWNvbXBvbmVudCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHRlbXBsYXRlOiAnJyxcbn0pXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBCYXNlQ29tcG9uZW50IHtcbiAgZm91bmRhdGlvbjogYW55O1xuICBjYWNoZTogYW55O1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLmZvdW5kYXRpb24gPSBudWxsO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5mb3VuZGF0aW9uICYmXG4gICAgICB0eXBlb2YgdGhpcy5mb3VuZGF0aW9uLmRlc3Ryb3kgPT09ICdmdW5jdGlvbicgJiZcbiAgICAgIHRoaXMuZm91bmRhdGlvbi5kZXN0cm95KCk7XG4gIH1cblxuICBnZXQgYWRhcHRlcigpOiBEZWZhdWx0QWRhcHRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGdldFByb3A6IChrZXk6IHN0cmluZykgPT4ge1xuICAgICAgICByZXR1cm4gdGhpc1trZXldO1xuICAgICAgfSxcbiAgICAgIGdldFByb3BzOiAoKSA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgICAgfSxcbiAgICAgIHNldFN0YXRlOiAoc3RhdGVzLCBjYikgPT4ge1xuICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiBzdGF0ZXMpIHtcbiAgICAgICAgICBpZiAoc3RhdGVzLmhhc093blByb3BlcnR5KGtleSkpIHtcbiAgICAgICAgICAgIHRoaXNba2V5XSA9IHN0YXRlc1trZXldO1xuICAgICAgICAgIH1cbiAgICAgICAgICBjYiAmJiBjYigpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgZ2V0U3RhdGU6IChrZXkpID0+IHRoaXNba2V5XSxcbiAgICAgIGdldFN0YXRlczogKCkgPT4gdGhpcyxcbiAgICAgIGdldENhY2hlOiAoa2V5KSA9PiBrZXkgJiYgdGhpcy5jYWNoZVtrZXldLFxuICAgICAgZ2V0Q2FjaGVzOiAoKSA9PiB0aGlzLmNhY2hlLFxuICAgICAgc2V0Q2FjaGU6IChrZXksIHZhbHVlKSA9PiBrZXkgJiYgKHRoaXMuY2FjaGVba2V5XSA9IHZhbHVlKSxcbiAgICAgIG5leHRUaWNrOiAoY2IpID0+IHNldFRpbWVvdXQoY2IsIDApLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, ContentChild } from '@angular/core';
|
|
1
|
+
import { Component, Input, ContentChild, ContentChildren } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { BubbleLoadingComponent } from './bubble-loading/bubble-loading.component';
|
|
4
4
|
import { AvatarComponent } from './avatar/avatar.component';
|
|
@@ -8,6 +8,10 @@ import { TranslatePipe } from '../Locale/translate.pipe';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "@angular/common";
|
|
10
10
|
export class BubbleComponent extends BaseComponent {
|
|
11
|
+
// 计算是否有内容投影
|
|
12
|
+
get ngContentProjected() {
|
|
13
|
+
return this.contentChildren && this.contentChildren.length > 0;
|
|
14
|
+
}
|
|
11
15
|
constructor() {
|
|
12
16
|
super();
|
|
13
17
|
// 组件属性
|
|
@@ -17,9 +21,9 @@ export class BubbleComponent extends BaseComponent {
|
|
|
17
21
|
this.avatarPosition = 'side';
|
|
18
22
|
this.variant = 'filled';
|
|
19
23
|
// 内容投影模板引用
|
|
24
|
+
this.avatarTemplate = null;
|
|
20
25
|
this.topTemplate = null;
|
|
21
26
|
this.loadingTplTemplate = null;
|
|
22
|
-
this.defaultTemplate = null;
|
|
23
27
|
this.bottomTemplate = null;
|
|
24
28
|
}
|
|
25
29
|
ngOnInit() {
|
|
@@ -49,11 +53,11 @@ export class BubbleComponent extends BaseComponent {
|
|
|
49
53
|
}
|
|
50
54
|
;
|
|
51
55
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: BubbleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
52
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: BubbleComponent, isStandalone: true, selector: "mc-bubble", inputs: { content: "content", loading: "loading", align: "align", avatarPosition: "avatarPosition", variant: "variant", avatarConfig: "avatarConfig" }, queries: [{ propertyName: "
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: BubbleComponent, isStandalone: true, selector: "mc-bubble", inputs: { content: "content", loading: "loading", align: "align", avatarPosition: "avatarPosition", variant: "variant", avatarConfig: "avatarConfig" }, queries: [{ propertyName: "avatarTemplate", first: true, predicate: ["avatar"], descendants: true }, { propertyName: "topTemplate", first: true, predicate: ["top"], descendants: true }, { propertyName: "loadingTplTemplate", first: true, predicate: ["loadingTpl"], descendants: true }, { propertyName: "bottomTemplate", first: true, predicate: ["bottom"], descendants: true }, { propertyName: "contentChildren", predicate: ["ng-content"] }], usesInheritance: true, ngImport: i0, template: "<div class=\"mc-bubble\" [ngClass]=\"bubbleClasses\" role=\"group\" [attr.aria-label]=\"'Bubble.ariaLabel' | translate\">\n <!-- \u81EA\u5B9A\u4E49\u5934\u50CF\u533A\u57DF -->\n <div *ngIf=\"avatarTemplate\" class=\"mc-bubble-avatar\" role=\"img\">\n <ng-container *ngTemplateOutlet=\"avatarTemplate\"></ng-container>\n <ng-content select=\"[avatar]\"></ng-content>\n </div>\n \n <!-- \u9ED8\u8BA4\u5934\u50CF\u914D\u7F6E -->\n <div *ngIf=\"!avatarTemplate && avatarConfig\"\n class=\"mc-bubble-avatar\" role=\"img\"\n [ngClass]=\"{ 'empty-avatar': isEmptyAvatar }\"\n >\n <mc-avatar\n *ngIf=\"!isEmptyAvatar\"\n [imgSrc]=\"avatarConfig?.imgSrc || ''\"\n [name]=\"avatarConfig?.name || ''\"\n [width]=\"avatarConfig?.width || 36\"\n [height]=\"avatarConfig?.height || 36\"\n [gender]=\"avatarConfig?.gender || ''\"\n />\n <div *ngIf=\"isEmptyAvatar\" class=\"mc-bubble-avatar-wrapper\" [attr.aria-label]=\"'Bubble.emptyAvatar' | translate\"\n [style.width.px]=\"avatarConfig?.width || 36\"\n [style.height.px]=\"avatarConfig?.height || 36\"></div>\n <span *ngIf=\"avatarPosition === 'top'\" class=\"mc-bubble-avatar-name\" [attr.aria-label]=\"'Bubble.userName' | translate:{ name: avatarConfig?.displayName || '' } \">{{\n avatarConfig?.displayName\n }}</span>\n </div>\n <div\n class=\"mc-bubble-content-container\" aria-live=\"polite\"\n [ngClass]=\"{ 'with-avatar': avatarTemplate || avatarConfig }\"\n >\n <!-- \u9876\u90E8\u5185\u5BB9\u6295\u5F71 -->\n <ng-container *ngIf=\"!loading\">\n <ng-container *ngTemplateOutlet=\"topTemplate\"></ng-container>\n <ng-content select=\"[top]\"></ng-content>\n </ng-container>\n \n <!-- \u52A0\u8F7D\u72B6\u6001 -->\n <div *ngIf=\"loading\" class=\"loading-container\" role=\"status\" aria-busy=\"true\">\n <ng-container *ngIf=\"loadingTplTemplate; else defaultLoadingTemplate\">\n <ng-container *ngTemplateOutlet=\"loadingTplTemplate\"></ng-container>\n <ng-content select=\"[loadingTpl]\"></ng-content>\n </ng-container>\n <ng-template #defaultLoadingTemplate>\n <mc-bubble-loading></mc-bubble-loading>\n </ng-template>\n </div>\n \n <!-- \u4E3B\u8981\u5185\u5BB9 -->\n <div\n *ngIf=\"!loading\"\n class=\"mc-bubble-content\"\n [ngClass]=\"[variant]\"\n role=\"region\"\n >\n <ng-content></ng-content>\n <ng-container *ngIf=\"content && !ngContentProjected\">\n <span [attr.aria-label]=\"'Bubble.content' | translate\">{{ content }}</span>\n </ng-container>\n </div>\n \n <!-- \u5E95\u90E8\u5185\u5BB9\u6295\u5F71 -->\n <ng-container *ngIf=\"!loading\">\n <ng-container *ngTemplateOutlet=\"bottomTemplate\"></ng-container>\n <ng-content select=\"[bottom]\"></ng-content>\n </ng-container>\n </div>\n</div>\n", styles: [".mc-bubble{display:flex;gap:4px;font-size:var(--devui-font-size, 14px)}.mc-bubble .mc-bubble-content{word-wrap:break-word}.mc-bubble .mc-bubble-content.filled,.mc-bubble .mc-bubble-content.bordered{padding:12px 16px;border-radius:12px}.mc-bubble .mc-bubble-content.filled{background-color:var(--devui-global-bg, #f6f6f8)}.mc-bubble .mc-bubble-content.bordered{border:1px solid var(--devui-dividing-line, #f2f2f3)}.mc-bubble .mc-bubble-avatar{flex-shrink:0;display:flex;gap:4px}.mc-bubble .mc-bubble-avatar .mc-bubble-avatar-name{font-size:14px}.mc-bubble .mc-bubble-avatar.empty-avatar{visibility:hidden}.mc-bubble.mc-bubble-avatar-top .mc-bubble-avatar{align-items:center}.mc-bubble .mc-bubble-content-container{max-width:100%}.mc-bubble.mc-bubble-avatar-top{flex-direction:column}.mc-bubble.mc-bubble-avatar-top .mc-bubble-content-container{align-items:flex-start;flex-direction:column}.mc-bubble.mc-bubble-loading.mc-bubble-avatar-side{align-items:center}.mc-bubble.mc-bubble-avatar-side.mc-bubble-right{flex-direction:row-reverse;justify-content:end}.mc-bubble.mc-bubble-avatar-top .mc-bubble-avatar,.mc-bubble.mc-bubble-avatar-top .mc-bubble-content-container{display:flex}.mc-bubble.mc-bubble-avatar-top.mc-bubble-right .mc-bubble-avatar,.mc-bubble.mc-bubble-avatar-top.mc-bubble-right .mc-bubble-content-container{align-items:flex-end}.mc-bubble.mc-bubble-avatar-top.mc-bubble-right .mc-bubble-avatar{flex-direction:row-reverse}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: BubbleLoadingComponent, selector: "mc-bubble-loading" }, { kind: "component", type: AvatarComponent, selector: "mc-avatar", inputs: ["imgSrc", "name", "width", "height", "isRound", "gender"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
|
|
53
57
|
}
|
|
54
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: BubbleComponent, decorators: [{
|
|
55
59
|
type: Component,
|
|
56
|
-
args: [{ selector: 'mc-bubble', standalone: true, imports: [CommonModule, BubbleLoadingComponent, AvatarComponent, TranslatePipe], template: "<div class=\"mc-bubble\" [ngClass]=\"bubbleClasses\" role=\"group\" [attr.aria-label]=\"'Bubble.ariaLabel' | translate\">\n <div\n *ngIf=\"avatarConfig\"\n class=\"mc-bubble-avatar\" role=\"img\"\n [ngClass]=\"{ 'empty-avatar': isEmptyAvatar }\"\n >\n <mc-avatar\n *ngIf=\"!isEmptyAvatar\"\n [imgSrc]=\"avatarConfig?.imgSrc || ''\"\n [name]=\"avatarConfig?.name || ''\"\n [width]=\"avatarConfig?.width || 36\"\n [height]=\"avatarConfig?.height || 36\"\n [gender]=\"avatarConfig?.gender || ''\"\n />\n <div *ngIf=\"isEmptyAvatar\" class=\"mc-bubble-avatar-wrapper\" [attr.aria-label]=\"'Bubble.emptyAvatar' | translate\"\n [style.width.px]=\"avatarConfig?.width || 36\"\n [style.height.px]=\"avatarConfig?.height || 36\"></div>\n <span *ngIf=\"avatarPosition === 'top'\" class=\"mc-bubble-avatar-name\" [attr.aria-label]=\"'Bubble.userName' | translate:{ name: avatarConfig?.displayName || '' } \">{{\n avatarConfig?.displayName\n }}</span>\n </div>\n <div\n class=\"mc-bubble-content-container\" aria-live=\"polite\"\n [ngClass]=\"{ 'with-avatar': avatarConfig }\"\n >\n <!-- \u9876\u90E8\u5185\u5BB9\u6295\u5F71 -->\n <ng-container *ngIf=\"!loading\">\n <ng-container *ngTemplateOutlet=\"topTemplate\"></ng-container>\n <ng-content select=\"[top]\"></ng-content>\n </ng-container>\n \n <!-- \u52A0\u8F7D\u72B6\u6001 -->\n <div *ngIf=\"loading\" class=\"loading-container\" role=\"status\" aria-busy=\"true\">\n <ng-container *ngIf=\"loadingTplTemplate; else defaultLoadingTemplate\">\n <ng-container *ngTemplateOutlet=\"loadingTplTemplate\"></ng-container>\n <ng-content select=\"[loadingTpl]\"></ng-content>\n </ng-container>\n <ng-template #defaultLoadingTemplate>\n <mc-bubble-loading></mc-bubble-loading>\n </ng-template>\n </div>\n \n <!-- \u4E3B\u8981\u5185\u5BB9 -->\n <div\n *ngIf=\"
|
|
60
|
+
args: [{ selector: 'mc-bubble', standalone: true, imports: [CommonModule, BubbleLoadingComponent, AvatarComponent, TranslatePipe], template: "<div class=\"mc-bubble\" [ngClass]=\"bubbleClasses\" role=\"group\" [attr.aria-label]=\"'Bubble.ariaLabel' | translate\">\n <!-- \u81EA\u5B9A\u4E49\u5934\u50CF\u533A\u57DF -->\n <div *ngIf=\"avatarTemplate\" class=\"mc-bubble-avatar\" role=\"img\">\n <ng-container *ngTemplateOutlet=\"avatarTemplate\"></ng-container>\n <ng-content select=\"[avatar]\"></ng-content>\n </div>\n \n <!-- \u9ED8\u8BA4\u5934\u50CF\u914D\u7F6E -->\n <div *ngIf=\"!avatarTemplate && avatarConfig\"\n class=\"mc-bubble-avatar\" role=\"img\"\n [ngClass]=\"{ 'empty-avatar': isEmptyAvatar }\"\n >\n <mc-avatar\n *ngIf=\"!isEmptyAvatar\"\n [imgSrc]=\"avatarConfig?.imgSrc || ''\"\n [name]=\"avatarConfig?.name || ''\"\n [width]=\"avatarConfig?.width || 36\"\n [height]=\"avatarConfig?.height || 36\"\n [gender]=\"avatarConfig?.gender || ''\"\n />\n <div *ngIf=\"isEmptyAvatar\" class=\"mc-bubble-avatar-wrapper\" [attr.aria-label]=\"'Bubble.emptyAvatar' | translate\"\n [style.width.px]=\"avatarConfig?.width || 36\"\n [style.height.px]=\"avatarConfig?.height || 36\"></div>\n <span *ngIf=\"avatarPosition === 'top'\" class=\"mc-bubble-avatar-name\" [attr.aria-label]=\"'Bubble.userName' | translate:{ name: avatarConfig?.displayName || '' } \">{{\n avatarConfig?.displayName\n }}</span>\n </div>\n <div\n class=\"mc-bubble-content-container\" aria-live=\"polite\"\n [ngClass]=\"{ 'with-avatar': avatarTemplate || avatarConfig }\"\n >\n <!-- \u9876\u90E8\u5185\u5BB9\u6295\u5F71 -->\n <ng-container *ngIf=\"!loading\">\n <ng-container *ngTemplateOutlet=\"topTemplate\"></ng-container>\n <ng-content select=\"[top]\"></ng-content>\n </ng-container>\n \n <!-- \u52A0\u8F7D\u72B6\u6001 -->\n <div *ngIf=\"loading\" class=\"loading-container\" role=\"status\" aria-busy=\"true\">\n <ng-container *ngIf=\"loadingTplTemplate; else defaultLoadingTemplate\">\n <ng-container *ngTemplateOutlet=\"loadingTplTemplate\"></ng-container>\n <ng-content select=\"[loadingTpl]\"></ng-content>\n </ng-container>\n <ng-template #defaultLoadingTemplate>\n <mc-bubble-loading></mc-bubble-loading>\n </ng-template>\n </div>\n \n <!-- \u4E3B\u8981\u5185\u5BB9 -->\n <div\n *ngIf=\"!loading\"\n class=\"mc-bubble-content\"\n [ngClass]=\"[variant]\"\n role=\"region\"\n >\n <ng-content></ng-content>\n <ng-container *ngIf=\"content && !ngContentProjected\">\n <span [attr.aria-label]=\"'Bubble.content' | translate\">{{ content }}</span>\n </ng-container>\n </div>\n \n <!-- \u5E95\u90E8\u5185\u5BB9\u6295\u5F71 -->\n <ng-container *ngIf=\"!loading\">\n <ng-container *ngTemplateOutlet=\"bottomTemplate\"></ng-container>\n <ng-content select=\"[bottom]\"></ng-content>\n </ng-container>\n </div>\n</div>\n", styles: [".mc-bubble{display:flex;gap:4px;font-size:var(--devui-font-size, 14px)}.mc-bubble .mc-bubble-content{word-wrap:break-word}.mc-bubble .mc-bubble-content.filled,.mc-bubble .mc-bubble-content.bordered{padding:12px 16px;border-radius:12px}.mc-bubble .mc-bubble-content.filled{background-color:var(--devui-global-bg, #f6f6f8)}.mc-bubble .mc-bubble-content.bordered{border:1px solid var(--devui-dividing-line, #f2f2f3)}.mc-bubble .mc-bubble-avatar{flex-shrink:0;display:flex;gap:4px}.mc-bubble .mc-bubble-avatar .mc-bubble-avatar-name{font-size:14px}.mc-bubble .mc-bubble-avatar.empty-avatar{visibility:hidden}.mc-bubble.mc-bubble-avatar-top .mc-bubble-avatar{align-items:center}.mc-bubble .mc-bubble-content-container{max-width:100%}.mc-bubble.mc-bubble-avatar-top{flex-direction:column}.mc-bubble.mc-bubble-avatar-top .mc-bubble-content-container{align-items:flex-start;flex-direction:column}.mc-bubble.mc-bubble-loading.mc-bubble-avatar-side{align-items:center}.mc-bubble.mc-bubble-avatar-side.mc-bubble-right{flex-direction:row-reverse;justify-content:end}.mc-bubble.mc-bubble-avatar-top .mc-bubble-avatar,.mc-bubble.mc-bubble-avatar-top .mc-bubble-content-container{display:flex}.mc-bubble.mc-bubble-avatar-top.mc-bubble-right .mc-bubble-avatar,.mc-bubble.mc-bubble-avatar-top.mc-bubble-right .mc-bubble-content-container{align-items:flex-end}.mc-bubble.mc-bubble-avatar-top.mc-bubble-right .mc-bubble-avatar{flex-direction:row-reverse}\n"] }]
|
|
57
61
|
}], ctorParameters: () => [], propDecorators: { content: [{
|
|
58
62
|
type: Input
|
|
59
63
|
}], loading: [{
|
|
@@ -66,17 +70,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
66
70
|
type: Input
|
|
67
71
|
}], avatarConfig: [{
|
|
68
72
|
type: Input
|
|
73
|
+
}], avatarTemplate: [{
|
|
74
|
+
type: ContentChild,
|
|
75
|
+
args: ['avatar']
|
|
69
76
|
}], topTemplate: [{
|
|
70
77
|
type: ContentChild,
|
|
71
78
|
args: ['top']
|
|
72
79
|
}], loadingTplTemplate: [{
|
|
73
80
|
type: ContentChild,
|
|
74
81
|
args: ['loadingTpl']
|
|
75
|
-
}], defaultTemplate: [{
|
|
76
|
-
type: ContentChild,
|
|
77
|
-
args: ['defaultTemplate']
|
|
78
82
|
}], bottomTemplate: [{
|
|
79
83
|
type: ContentChild,
|
|
80
84
|
args: ['bottom']
|
|
85
|
+
}], contentChildren: [{
|
|
86
|
+
type: ContentChildren,
|
|
87
|
+
args: ['ng-content']
|
|
81
88
|
}] } });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bubble.component.js","sourceRoot":"","sources":["../../../../projects/components-ng/src/Bubble/bubble.component.ts","../../../../projects/components-ng/src/Bubble/bubble.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAY,YAAY,EAAe,MAAM,eAAe,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAC;AACnF,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAG5D,OAAO,EAAiB,gBAAgB,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,aAAa,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;;;AASzD,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAehD;QAAgB,KAAK,EAAE,CAAC;QAdxB,OAAO;QACE,YAAO,GAAW,EAAE,CAAC;QACrB,YAAO,GAAY,KAAK,CAAC;QACzB,UAAK,GAAgB,MAAM,CAAC;QAC5B,mBAAc,GAAmB,MAAM,CAAC;QACxC,YAAO,GAAkB,QAAQ,CAAC;QAG3C,WAAW;QACU,gBAAW,GAA4B,IAAI,CAAC;QACrC,uBAAkB,GAA4B,IAAI,CAAC;QAC9C,oBAAe,GAA4B,IAAI,CAAC;QACzD,mBAAc,GAA4B,IAAI,CAAC;IAE9C,CAAC;IAE1B,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,IAAa,OAAO;QAClB,OAAO;YACL,GAAG,KAAK,CAAC,OAAO;YAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC;gBACf,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,cAAc,EAAE,IAAI,CAAC,cAAc;gBACnC,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,YAAY,EAAE,IAAI,CAAC,YAAY;aAChC,CAAC;SACH,CAAA;IACH,CAAC;IAED,OAAO;IACP,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC;IAAA,CAAC;IAEF,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;IAAA,CAAC;8GA3CS,eAAe;kGAAf,eAAe,unBCjB5B,+qFAiEA,s9CDpDY,YAAY,wYAAE,sBAAsB,8DAAE,eAAe,qHAAE,aAAa;;2FAInE,eAAe;kBAP3B,SAAS;+BACE,WAAW,cACT,IAAI,WACP,CAAC,YAAY,EAAE,sBAAsB,EAAE,eAAe,EAAE,aAAa,CAAC;wDAMtE,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAGe,WAAW;sBAA/B,YAAY;uBAAC,KAAK;gBACS,kBAAkB;sBAA7C,YAAY;uBAAC,YAAY;gBACO,eAAe;sBAA/C,YAAY;uBAAC,iBAAiB;gBACP,cAAc;sBAArC,YAAY;uBAAC,QAAQ","sourcesContent":["import { Component, Input, computed, ContentChild, TemplateRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { BubbleLoadingComponent } from './bubble-loading/bubble-loading.component';\nimport { AvatarComponent } from './avatar/avatar.component';\nimport { DEFAULT_AVATAR_WIDTH, DEFAULT_AVATAR_HEIGHT, AVATAR_NAME, AVATAR_IMG } from '../components-common/Bubble/common/bubble-constants';\nimport { BubbleAlign, BubbleVariant, AvatarPosition, BubbleAvatar } from '../components-common//Bubble/common/bubble-types';\nimport { BubbleAdapter, BubbleFoundation } from '../components-common/Bubble/foundation';\nimport BaseComponent from '../Base/base.component';\nimport { TranslatePipe } from '../Locale/translate.pipe';\n\n@Component({\n  selector: 'mc-bubble',\n  standalone: true,\n  imports: [CommonModule, BubbleLoadingComponent, AvatarComponent, TranslatePipe],\n  templateUrl: './bubble.component.html',\n  styleUrls: ['./bubble.component.scss']\n})\nexport class BubbleComponent extends BaseComponent {\n  // 组件属性\n  @Input() content: string = '';\n  @Input() loading: boolean = false;\n  @Input() align: BubbleAlign = 'left';\n  @Input() avatarPosition: AvatarPosition = 'side';\n  @Input() variant: BubbleVariant = 'filled';\n  @Input() avatarConfig?: BubbleAvatar;\n\n  // 内容投影模板引用\n  @ContentChild('top') topTemplate: TemplateRef<any> | null = null;\n  @ContentChild('loadingTpl') loadingTplTemplate: TemplateRef<any> | null = null;\n  @ContentChild('defaultTemplate') defaultTemplate: TemplateRef<any> | null = null;\n  @ContentChild('bottom') bottomTemplate: TemplateRef<any> | null = null;\n\n  constructor() { super(); }\n\n  ngOnInit() {\n    this.foundation = new BubbleFoundation(this.adapter);\n    this.foundation.init();\n  }\n\n  override get adapter(): BubbleAdapter {\n    return {\n      ...super.adapter,\n      getProps: () => ({\n        content: this.content,\n        loading: this.loading,\n        align: this.align,\n        avatarPosition: this.avatarPosition,\n        variant: this.variant,\n        avatarConfig: this.avatarConfig,\n      }),\n    }\n  }\n\n  // 计算属性\n  get bubbleClasses(): string {\n    return this.foundation.getBubbleClasses();\n  };\n\n  get isEmptyAvatar(): boolean {\n    return this.foundation.getIsEmptyAvatar(this.avatarConfig);\n  };\n}\n","<div class=\"mc-bubble\" [ngClass]=\"bubbleClasses\" role=\"group\" [attr.aria-label]=\"'Bubble.ariaLabel' | translate\">\n  <div\n    *ngIf=\"avatarConfig\"\n    class=\"mc-bubble-avatar\" role=\"img\"\n    [ngClass]=\"{ 'empty-avatar': isEmptyAvatar }\"\n  >\n    <mc-avatar\n      *ngIf=\"!isEmptyAvatar\"\n      [imgSrc]=\"avatarConfig?.imgSrc || ''\"\n      [name]=\"avatarConfig?.name || ''\"\n      [width]=\"avatarConfig?.width || 36\"\n      [height]=\"avatarConfig?.height || 36\"\n      [gender]=\"avatarConfig?.gender || ''\"\n    />\n    <div *ngIf=\"isEmptyAvatar\"    class=\"mc-bubble-avatar-wrapper\" [attr.aria-label]=\"'Bubble.emptyAvatar' | translate\"\n         [style.width.px]=\"avatarConfig?.width || 36\"\n         [style.height.px]=\"avatarConfig?.height || 36\"></div>\n    <span *ngIf=\"avatarPosition === 'top'\" class=\"mc-bubble-avatar-name\" [attr.aria-label]=\"'Bubble.userName' | translate:{ name: avatarConfig?.displayName || '' } \">{{\n      avatarConfig?.displayName\n    }}</span>\n  </div>\n  <div\n    class=\"mc-bubble-content-container\" aria-live=\"polite\"\n    [ngClass]=\"{ 'with-avatar': avatarConfig }\"\n  >\n    <!-- 顶部内容投影 -->\n    <ng-container *ngIf=\"!loading\">\n      <ng-container *ngTemplateOutlet=\"topTemplate\"></ng-container>\n      <ng-content select=\"[top]\"></ng-content>\n    </ng-container>\n    \n    <!-- 加载状态 -->\n    <div *ngIf=\"loading\" class=\"loading-container\" role=\"status\" aria-busy=\"true\">\n      <ng-container *ngIf=\"loadingTplTemplate; else defaultLoadingTemplate\">\n        <ng-container *ngTemplateOutlet=\"loadingTplTemplate\"></ng-container>\n        <ng-content select=\"[loadingTpl]\"></ng-content>\n      </ng-container>\n      <ng-template #defaultLoadingTemplate>\n        <mc-bubble-loading></mc-bubble-loading>\n      </ng-template>\n    </div>\n    \n    <!-- 主要内容 -->\n    <div\n      *ngIf=\"(defaultTemplate || content) && !loading\"\n      class=\"mc-bubble-content\"\n      [ngClass]=\"[variant]\"\n      role=\"region\"\n    >\n      <ng-container *ngIf=\"defaultTemplate; else contentTemplate\">\n        <ng-container *ngTemplateOutlet=\"defaultTemplate\"></ng-container>\n        <ng-content></ng-content>\n      </ng-container>\n      <ng-template #contentTemplate>\n        <span [attr.aria-label]=\"'Bubble.content' | translate\">{{ content }}</span>\n      </ng-template>\n    </div>\n    \n    <!-- 底部内容投影 -->\n    <ng-container *ngIf=\"!loading\">\n      <ng-container *ngTemplateOutlet=\"bottomTemplate\"></ng-container>\n      <ng-content select=\"[bottom]\"></ng-content>\n    </ng-container>\n  </div>\n</div>\n"]}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bubble.component.js","sourceRoot":"","sources":["../../../../projects/components-ng/src/Bubble/bubble.component.ts","../../../../projects/components-ng/src/Bubble/bubble.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAY,YAAY,EAAe,eAAe,EAAa,MAAM,eAAe,CAAC;AAClH,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAC;AACnF,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAG5D,OAAO,EAAiB,gBAAgB,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,aAAa,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;;;AASzD,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAkBhD,YAAY;IACZ,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;IACjE,CAAC;IAED;QAAgB,KAAK,EAAE,CAAC;QAtBxB,OAAO;QACE,YAAO,GAAW,EAAE,CAAC;QACrB,YAAO,GAAY,KAAK,CAAC;QACzB,UAAK,GAAgB,MAAM,CAAC;QAC5B,mBAAc,GAAmB,MAAM,CAAC;QACxC,YAAO,GAAkB,QAAQ,CAAC;QAG3C,WAAW;QACa,mBAAc,GAA4B,IAAI,CAAC;QAClD,gBAAW,GAA4B,IAAI,CAAC;QACrC,uBAAkB,GAA4B,IAAI,CAAC;QACvD,mBAAc,GAA4B,IAAI,CAAC;IAU9C,CAAC;IAE1B,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,IAAa,OAAO;QAClB,OAAO;YACL,GAAG,KAAK,CAAC,OAAO;YAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC;gBACf,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,cAAc,EAAE,IAAI,CAAC,cAAc;gBACnC,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,YAAY,EAAE,IAAI,CAAC,YAAY;aAChC,CAAC;SACH,CAAA;IACH,CAAC;IAED,OAAO;IACP,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC;IAAA,CAAC;IAEF,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;IAAA,CAAC;8GAnDS,eAAe;kGAAf,eAAe,6qBCjB5B,w1FAoEA,s9CDvDY,YAAY,wYAAE,sBAAsB,8DAAE,eAAe,qHAAE,aAAa;;2FAInE,eAAe;kBAP3B,SAAS;+BACE,WAAW,cACT,IAAI,WACP,CAAC,YAAY,EAAE,sBAAsB,EAAE,eAAe,EAAE,aAAa,CAAC;wDAMtE,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAGkB,cAAc;sBAArC,YAAY;uBAAC,QAAQ;gBACD,WAAW;sBAA/B,YAAY;uBAAC,KAAK;gBACS,kBAAkB;sBAA7C,YAAY;uBAAC,YAAY;gBACF,cAAc;sBAArC,YAAY;uBAAC,QAAQ;gBAGS,eAAe;sBAA7C,eAAe;uBAAC,YAAY","sourcesContent":["import { Component, Input, computed, ContentChild, TemplateRef, ContentChildren, QueryList } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { BubbleLoadingComponent } from './bubble-loading/bubble-loading.component';\nimport { AvatarComponent } from './avatar/avatar.component';\nimport { DEFAULT_AVATAR_WIDTH, DEFAULT_AVATAR_HEIGHT, AVATAR_NAME, AVATAR_IMG } from '../components-common/Bubble/common/bubble-constants';\nimport { BubbleAlign, BubbleVariant, AvatarPosition, BubbleAvatar } from '../components-common//Bubble/common/bubble-types';\nimport { BubbleAdapter, BubbleFoundation } from '../components-common/Bubble/foundation';\nimport BaseComponent from '../Base/base.component';\nimport { TranslatePipe } from '../Locale/translate.pipe';\n\n@Component({\n  selector: 'mc-bubble',\n  standalone: true,\n  imports: [CommonModule, BubbleLoadingComponent, AvatarComponent, TranslatePipe],\n  templateUrl: './bubble.component.html',\n  styleUrls: ['./bubble.component.scss']\n})\nexport class BubbleComponent extends BaseComponent {\n  // 组件属性\n  @Input() content: string = '';\n  @Input() loading: boolean = false;\n  @Input() align: BubbleAlign = 'left';\n  @Input() avatarPosition: AvatarPosition = 'side';\n  @Input() variant: BubbleVariant = 'filled';\n  @Input() avatarConfig?: BubbleAvatar;\n\n  // 内容投影模板引用\n  @ContentChild('avatar') avatarTemplate: TemplateRef<any> | null = null;\n  @ContentChild('top') topTemplate: TemplateRef<any> | null = null;\n  @ContentChild('loadingTpl') loadingTplTemplate: TemplateRef<any> | null = null;\n  @ContentChild('bottom') bottomTemplate: TemplateRef<any> | null = null;\n  \n  // 检测是否有内容投影\n  @ContentChildren('ng-content') contentChildren: QueryList<any>;\n  \n  // 计算是否有内容投影\n  get ngContentProjected(): boolean {\n    return this.contentChildren && this.contentChildren.length > 0;\n  }\n  \n  constructor() { super(); }\n\n  ngOnInit() {\n    this.foundation = new BubbleFoundation(this.adapter);\n    this.foundation.init();\n  }\n\n  override get adapter(): BubbleAdapter {\n    return {\n      ...super.adapter,\n      getProps: () => ({\n        content: this.content,\n        loading: this.loading,\n        align: this.align,\n        avatarPosition: this.avatarPosition,\n        variant: this.variant,\n        avatarConfig: this.avatarConfig,\n      }),\n    }\n  }\n\n  // 计算属性\n  get bubbleClasses(): string {\n    return this.foundation.getBubbleClasses();\n  };\n\n  get isEmptyAvatar(): boolean {\n    return this.foundation.getIsEmptyAvatar(this.avatarConfig);\n  };\n}\n","<div class=\"mc-bubble\" [ngClass]=\"bubbleClasses\" role=\"group\" [attr.aria-label]=\"'Bubble.ariaLabel' | translate\">\n  <!-- 自定义头像区域 -->\n  <div *ngIf=\"avatarTemplate\" class=\"mc-bubble-avatar\" role=\"img\">\n    <ng-container *ngTemplateOutlet=\"avatarTemplate\"></ng-container>\n    <ng-content select=\"[avatar]\"></ng-content>\n  </div>\n  \n  <!-- 默认头像配置 -->\n  <div *ngIf=\"!avatarTemplate && avatarConfig\"\n    class=\"mc-bubble-avatar\" role=\"img\"\n    [ngClass]=\"{ 'empty-avatar': isEmptyAvatar }\"\n  >\n    <mc-avatar\n      *ngIf=\"!isEmptyAvatar\"\n      [imgSrc]=\"avatarConfig?.imgSrc || ''\"\n      [name]=\"avatarConfig?.name || ''\"\n      [width]=\"avatarConfig?.width || 36\"\n      [height]=\"avatarConfig?.height || 36\"\n      [gender]=\"avatarConfig?.gender || ''\"\n    />\n    <div *ngIf=\"isEmptyAvatar\"    class=\"mc-bubble-avatar-wrapper\" [attr.aria-label]=\"'Bubble.emptyAvatar' | translate\"\n         [style.width.px]=\"avatarConfig?.width || 36\"\n         [style.height.px]=\"avatarConfig?.height || 36\"></div>\n    <span *ngIf=\"avatarPosition === 'top'\" class=\"mc-bubble-avatar-name\" [attr.aria-label]=\"'Bubble.userName' | translate:{ name: avatarConfig?.displayName || '' } \">{{\n      avatarConfig?.displayName\n    }}</span>\n  </div>\n  <div\n    class=\"mc-bubble-content-container\" aria-live=\"polite\"\n    [ngClass]=\"{ 'with-avatar': avatarTemplate || avatarConfig }\"\n  >\n    <!-- 顶部内容投影 -->\n    <ng-container *ngIf=\"!loading\">\n      <ng-container *ngTemplateOutlet=\"topTemplate\"></ng-container>\n      <ng-content select=\"[top]\"></ng-content>\n    </ng-container>\n    \n    <!-- 加载状态 -->\n    <div *ngIf=\"loading\" class=\"loading-container\" role=\"status\" aria-busy=\"true\">\n      <ng-container *ngIf=\"loadingTplTemplate; else defaultLoadingTemplate\">\n        <ng-container *ngTemplateOutlet=\"loadingTplTemplate\"></ng-container>\n        <ng-content select=\"[loadingTpl]\"></ng-content>\n      </ng-container>\n      <ng-template #defaultLoadingTemplate>\n        <mc-bubble-loading></mc-bubble-loading>\n      </ng-template>\n    </div>\n    \n    <!-- 主要内容 -->\n    <div\n      *ngIf=\"!loading\"\n      class=\"mc-bubble-content\"\n      [ngClass]=\"[variant]\"\n      role=\"region\"\n    >\n      <ng-content></ng-content>\n      <ng-container *ngIf=\"content && !ngContentProjected\">\n        <span [attr.aria-label]=\"'Bubble.content' | translate\">{{ content }}</span>\n      </ng-container>\n    </div>\n    \n    <!-- 底部内容投影 -->\n    <ng-container *ngIf=\"!loading\">\n      <ng-container *ngTemplateOutlet=\"bottomTemplate\"></ng-container>\n      <ng-content select=\"[bottom]\"></ng-content>\n    </ng-container>\n  </div>\n</div>\n"]}
|