@matechat/ng 20.0.1-alpha.0 → 20.1.0-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/README.md +206 -41
- package/fesm2022/matechat-ng.mjs +71 -70
- package/fesm2022/matechat-ng.mjs.map +1 -1
- package/index.d.ts +612 -3
- package/package.json +14 -3
- package/Base/base.component.d.ts +0 -11
- package/Bubble/avatar/avatar.component.d.ts +0 -23
- package/Bubble/avatar-body-icon/avatar-body-icon.component.d.ts +0 -7
- package/Bubble/avatar-no-body-icon/avatar-no-body-icon.component.d.ts +0 -7
- package/Bubble/bubble-loading/bubble-loading.component.d.ts +0 -5
- package/Bubble/bubble.component.d.ts +0 -26
- package/Bubble/bubble.module.d.ts +0 -10
- package/Bubble/index.d.ts +0 -6
- package/Input/button/button.component.d.ts +0 -32
- package/Input/index.d.ts +0 -2
- package/Input/input.component.d.ts +0 -65
- package/Input/input.module.d.ts +0 -11
- package/Input/send-icon/send-icon.component.d.ts +0 -5
- package/Locale/index.d.ts +0 -5
- package/Locale/locale.module.d.ts +0 -17
- package/Locale/locale.service.d.ts +0 -50
- package/Locale/translate.pipe.d.ts +0 -23
- package/MarkdownCard/code-block.component.d.ts +0 -49
- package/MarkdownCard/index.d.ts +0 -3
- package/MarkdownCard/markdown-card.component.d.ts +0 -200
- package/MarkdownCard/markdown-card.module.d.ts +0 -13
- package/components-common/Base/foundation.d.ts +0 -45
- package/components-common/Bubble/common/bubble-constants.d.ts +0 -4
- package/components-common/Bubble/common/bubble-types.d.ts +0 -12
- package/components-common/Bubble/foundation.d.ts +0 -9
- package/components-common/Input/button-foundation.d.ts +0 -15
- package/components-common/Input/common/types.d.ts +0 -16
- package/components-common/Input/foundation.d.ts +0 -20
- package/components-common/Locale/lang/en-us.d.ts +0 -26
- package/components-common/Locale/lang/zh-cn.d.ts +0 -26
- package/components-common/MarkdownCard/codeblock-foundation.d.ts +0 -21
- package/components-common/MarkdownCard/common/MDCardService.d.ts +0 -14
- package/components-common/MarkdownCard/common/MermaidService.d.ts +0 -23
- package/components-common/MarkdownCard/common/mdCard.types.d.ts +0 -56
- package/components-common/MarkdownCard/common/parser.d.ts +0 -150
- package/components-common/MarkdownCard/foundation.d.ts +0 -38
- package/esm2022/Base/base.component.mjs +0 -46
- package/esm2022/Bubble/avatar/avatar.component.mjs +0 -121
- package/esm2022/Bubble/avatar-body-icon/avatar-body-icon.component.mjs +0 -19
- package/esm2022/Bubble/avatar-no-body-icon/avatar-no-body-icon.component.mjs +0 -19
- package/esm2022/Bubble/bubble-loading/bubble-loading.component.mjs +0 -11
- package/esm2022/Bubble/bubble.component.mjs +0 -89
- package/esm2022/Bubble/bubble.module.mjs +0 -36
- package/esm2022/Bubble/index.mjs +0 -7
- package/esm2022/Input/button/button.component.mjs +0 -83
- package/esm2022/Input/index.mjs +0 -3
- package/esm2022/Input/input.component.mjs +0 -285
- package/esm2022/Input/input.module.mjs +0 -34
- package/esm2022/Input/send-icon/send-icon.component.mjs +0 -11
- package/esm2022/Locale/index.mjs +0 -6
- package/esm2022/Locale/locale.module.mjs +0 -39
- package/esm2022/Locale/locale.service.mjs +0 -140
- package/esm2022/Locale/translate.pipe.mjs +0 -38
- package/esm2022/MarkdownCard/code-block.component.mjs +0 -175
- package/esm2022/MarkdownCard/index.mjs +0 -4
- package/esm2022/MarkdownCard/markdown-card.component.mjs +0 -436
- package/esm2022/MarkdownCard/markdown-card.module.mjs +0 -44
- package/esm2022/components-common/Base/foundation.mjs +0 -66
- package/esm2022/components-common/Bubble/common/bubble-constants.mjs +0 -5
- package/esm2022/components-common/Bubble/common/bubble-types.mjs +0 -2
- package/esm2022/components-common/Bubble/foundation.mjs +0 -30
- package/esm2022/components-common/Input/button-foundation.mjs +0 -33
- package/esm2022/components-common/Input/common/types.mjs +0 -21
- package/esm2022/components-common/Input/foundation.mjs +0 -71
- package/esm2022/components-common/Locale/lang/en-us.mjs +0 -26
- package/esm2022/components-common/Locale/lang/zh-cn.mjs +0 -26
- package/esm2022/components-common/MarkdownCard/codeblock-foundation.mjs +0 -132
- package/esm2022/components-common/MarkdownCard/common/MDCardService.mjs +0 -69
- package/esm2022/components-common/MarkdownCard/common/MermaidService.mjs +0 -222
- package/esm2022/components-common/MarkdownCard/common/mdCard.types.mjs +0 -6
- package/esm2022/components-common/MarkdownCard/common/parser.mjs +0 -194
- package/esm2022/components-common/MarkdownCard/foundation.mjs +0 -84
- package/esm2022/matechat-ng.mjs +0 -5
- package/esm2022/public-api.mjs +0 -8
- package/public-api.d.ts +0 -4
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import BaseFoundation, { DefaultAdapter } from '../Base/foundation';
|
|
2
|
-
export interface InputButtonAdapter extends DefaultAdapter {
|
|
3
|
-
locale(key: string, params?: Record<string, string>): string;
|
|
4
|
-
emitChange(): void;
|
|
5
|
-
}
|
|
6
|
-
export declare class InputButtonFoundation extends BaseFoundation<InputButtonAdapter> {
|
|
7
|
-
constructor(adapter: InputButtonAdapter);
|
|
8
|
-
showClickWave(nativeElement: HTMLElement, event: MouseEvent): void;
|
|
9
|
-
getButtonClasses(): {
|
|
10
|
-
'mc-button': boolean;
|
|
11
|
-
'mc-button-loading': any;
|
|
12
|
-
mousedown: any;
|
|
13
|
-
'mc-button-simple': boolean;
|
|
14
|
-
};
|
|
15
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
export declare enum DisplayType {
|
|
2
|
-
Simple = "simple",
|
|
3
|
-
Full = "full"
|
|
4
|
-
}
|
|
5
|
-
export declare enum InputVariant {
|
|
6
|
-
Bordered = "bordered",
|
|
7
|
-
BorderLess = "borderless"
|
|
8
|
-
}
|
|
9
|
-
export declare enum SendBtnVariant {
|
|
10
|
-
Simple = "simple",
|
|
11
|
-
Full = "full"
|
|
12
|
-
}
|
|
13
|
-
export declare enum SubmitShortKey {
|
|
14
|
-
Enter = "enter",
|
|
15
|
-
ShiftEnter = "shiftEnter"
|
|
16
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import BaseFoundation, { DefaultAdapter } from '../Base/foundation';
|
|
2
|
-
export interface InputAdapter extends DefaultAdapter {
|
|
3
|
-
locale(key: string, params?: Record<string, string>): string;
|
|
4
|
-
emitChange(): void;
|
|
5
|
-
submit(inputValue: string): void;
|
|
6
|
-
}
|
|
7
|
-
export declare class InputFoundation extends BaseFoundation<InputAdapter> {
|
|
8
|
-
constructor(adapter: InputAdapter);
|
|
9
|
-
getInputClasses(): {
|
|
10
|
-
'mc-input': boolean;
|
|
11
|
-
'mc-input-disabled': any;
|
|
12
|
-
'mc-input-simple': boolean;
|
|
13
|
-
'mc-input-borderless': boolean;
|
|
14
|
-
};
|
|
15
|
-
getPlaceholderText(): any;
|
|
16
|
-
clearInput(): void;
|
|
17
|
-
emitChange(): void;
|
|
18
|
-
submit(inputValue: string): void;
|
|
19
|
-
onKeydown(event: KeyboardEvent): void;
|
|
20
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
declare const _default: {
|
|
2
|
-
Input: {
|
|
3
|
-
send: string;
|
|
4
|
-
pauseAnswer: string;
|
|
5
|
-
pleaseEnter: string;
|
|
6
|
-
pleaseEnterPlaceholder: string;
|
|
7
|
-
ariaLabel: string;
|
|
8
|
-
};
|
|
9
|
-
Md: {
|
|
10
|
-
toggle: string;
|
|
11
|
-
copy: string;
|
|
12
|
-
diagram: string;
|
|
13
|
-
code: string;
|
|
14
|
-
zoomIn: string;
|
|
15
|
-
zoomOut: string;
|
|
16
|
-
downLoad: string;
|
|
17
|
-
};
|
|
18
|
-
Bubble: {
|
|
19
|
-
ariaLabel: string;
|
|
20
|
-
emptyAvatar: string;
|
|
21
|
-
userName: string;
|
|
22
|
-
content: string;
|
|
23
|
-
avatar: string;
|
|
24
|
-
};
|
|
25
|
-
};
|
|
26
|
-
export default _default;
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
declare const _default: {
|
|
2
|
-
Input: {
|
|
3
|
-
send: string;
|
|
4
|
-
pauseAnswer: string;
|
|
5
|
-
pleaseEnter: string;
|
|
6
|
-
pleaseEnterPlaceholder: string;
|
|
7
|
-
ariaLabel: string;
|
|
8
|
-
};
|
|
9
|
-
Md: {
|
|
10
|
-
toggle: string;
|
|
11
|
-
copy: string;
|
|
12
|
-
diagram: string;
|
|
13
|
-
code: string;
|
|
14
|
-
zoomIn: string;
|
|
15
|
-
zoomOut: string;
|
|
16
|
-
downLoad: string;
|
|
17
|
-
};
|
|
18
|
-
Bubble: {
|
|
19
|
-
ariaLabel: string;
|
|
20
|
-
emptyAvatar: string;
|
|
21
|
-
userName: string;
|
|
22
|
-
content: string;
|
|
23
|
-
avatar: string;
|
|
24
|
-
};
|
|
25
|
-
};
|
|
26
|
-
export default _default;
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import BaseFoundation, { DefaultAdapter } from '../Base/foundation';
|
|
2
|
-
import { MermaidService } from './common/MermaidService';
|
|
3
|
-
import { MDCardService } from './common/MDCardService';
|
|
4
|
-
export interface CodeBlockAdapter extends DefaultAdapter {
|
|
5
|
-
getContainer(): HTMLElement | null;
|
|
6
|
-
highlightCodeChange(code: string, language: string): void;
|
|
7
|
-
}
|
|
8
|
-
export declare class CodeBlockFoundation extends BaseFoundation<CodeBlockAdapter> {
|
|
9
|
-
mermaidService?: MermaidService;
|
|
10
|
-
mdCardService: MDCardService;
|
|
11
|
-
constructor(adapter: CodeBlockAdapter);
|
|
12
|
-
toggleExpand: () => void;
|
|
13
|
-
zoomOut: () => void;
|
|
14
|
-
zoomIn: () => void;
|
|
15
|
-
checkIsMermaid: () => any;
|
|
16
|
-
download: () => void;
|
|
17
|
-
handleCopySuccess: () => void;
|
|
18
|
-
copyCodeInternal(): void;
|
|
19
|
-
updateHighlightedCode: () => void;
|
|
20
|
-
renderMermaid: () => Promise<void>;
|
|
21
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { type IWhiteList } from 'xss';
|
|
2
|
-
import type { CustomXssRule, MdPlugin } from './mdCard.types.ts';
|
|
3
|
-
export declare class MDCardService {
|
|
4
|
-
private xssWhiteList;
|
|
5
|
-
private cssWhiteList;
|
|
6
|
-
constructor();
|
|
7
|
-
private setDefaultXss;
|
|
8
|
-
private onIgnoreTagAttr;
|
|
9
|
-
getXssWhiteList(): IWhiteList;
|
|
10
|
-
setXssWhiteList(list: IWhiteList): void;
|
|
11
|
-
setCustomXssRules(rules: CustomXssRule[]): void;
|
|
12
|
-
setMdPlugins(plugins: MdPlugin[], mdt: any): void;
|
|
13
|
-
filterHtml(html: string): string;
|
|
14
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import type { MermaidConfig } from './mdCard.types';
|
|
2
|
-
export declare class MermaidService {
|
|
3
|
-
private config;
|
|
4
|
-
private mermaidInstance;
|
|
5
|
-
private isLoading;
|
|
6
|
-
private lastValidResult;
|
|
7
|
-
private viewStateMap;
|
|
8
|
-
private containerHeight;
|
|
9
|
-
constructor(config?: MermaidConfig);
|
|
10
|
-
private loadMermaid;
|
|
11
|
-
renderToContainer(container: HTMLElement, code: string, theme?: 'light' | 'dark'): Promise<void>;
|
|
12
|
-
private initViewState;
|
|
13
|
-
private applyTransform;
|
|
14
|
-
zoomIn(container: HTMLElement): void;
|
|
15
|
-
zoomOut(container: HTMLElement): void;
|
|
16
|
-
reset(container: HTMLElement): void;
|
|
17
|
-
download(container: HTMLElement, filename?: string): Promise<void>;
|
|
18
|
-
private onSvgMouseDown;
|
|
19
|
-
private onSvgMouseMove;
|
|
20
|
-
private onSvgMouseUp;
|
|
21
|
-
renderMermaid(code: string, theme?: 'light' | 'dark'): Promise<string>;
|
|
22
|
-
setConfig(config?: MermaidConfig): void;
|
|
23
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import type { Options, PluginSimple, PluginWithOptions, PluginWithParams } from 'markdown-it';
|
|
2
|
-
import type { Token } from 'markdown-it';
|
|
3
|
-
export interface MermaidConfig {
|
|
4
|
-
theme?: string;
|
|
5
|
-
}
|
|
6
|
-
export interface CustomXssRule {
|
|
7
|
-
key: string;
|
|
8
|
-
value: string[] | null;
|
|
9
|
-
}
|
|
10
|
-
export interface CodBlockData {
|
|
11
|
-
code: string;
|
|
12
|
-
language: string;
|
|
13
|
-
}
|
|
14
|
-
export type CodeBlockSlot = {
|
|
15
|
-
actions?: () => void;
|
|
16
|
-
header?: () => void;
|
|
17
|
-
content?: () => void;
|
|
18
|
-
};
|
|
19
|
-
export type Theme = 'light' | 'dark';
|
|
20
|
-
export type TypingStyle = 'normal' | 'cursor' | 'color' | 'gradient';
|
|
21
|
-
export type IntervalType = number | [number, number];
|
|
22
|
-
export declare const defaultTypingConfig: {
|
|
23
|
-
step: number;
|
|
24
|
-
interval: number;
|
|
25
|
-
style: TypingStyle;
|
|
26
|
-
};
|
|
27
|
-
export interface MdPlugin {
|
|
28
|
-
plugin: PluginSimple | PluginWithOptions | PluginWithParams;
|
|
29
|
-
opts?: unknown;
|
|
30
|
-
}
|
|
31
|
-
export interface MarkdownCardProps {
|
|
32
|
-
content?: string;
|
|
33
|
-
typing?: boolean;
|
|
34
|
-
enableThink?: boolean;
|
|
35
|
-
typingOptions?: {
|
|
36
|
-
step?: number;
|
|
37
|
-
interval?: number | [number, number];
|
|
38
|
-
style?: TypingStyle;
|
|
39
|
-
};
|
|
40
|
-
thinkOptions?: {
|
|
41
|
-
customClass?: string;
|
|
42
|
-
};
|
|
43
|
-
mdOptions?: Options;
|
|
44
|
-
mdPlugins?: Array<MdPlugin>;
|
|
45
|
-
customXssRules?: Array<CustomXssRule>;
|
|
46
|
-
theme?: Theme;
|
|
47
|
-
enableMermaid?: boolean;
|
|
48
|
-
mermaidConfig?: MermaidConfig;
|
|
49
|
-
}
|
|
50
|
-
export interface ASTNode {
|
|
51
|
-
nodeType: string;
|
|
52
|
-
openNode: Token | null;
|
|
53
|
-
closeNode: Token | null;
|
|
54
|
-
children: (ASTNode | Token)[];
|
|
55
|
-
vNodeKey: string;
|
|
56
|
-
}
|
|
@@ -1,150 +0,0 @@
|
|
|
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;
|
|
@@ -1,38 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export default class BaseComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
}
|
|
6
|
-
ngOnDestroy() {
|
|
7
|
-
this.foundation &&
|
|
8
|
-
typeof this.foundation.destroy === 'function' &&
|
|
9
|
-
this.foundation.destroy();
|
|
10
|
-
}
|
|
11
|
-
get adapter() {
|
|
12
|
-
return {
|
|
13
|
-
getProp: (key) => {
|
|
14
|
-
return this[key];
|
|
15
|
-
},
|
|
16
|
-
getProps: () => {
|
|
17
|
-
return this;
|
|
18
|
-
},
|
|
19
|
-
setState: (states, cb) => {
|
|
20
|
-
for (const key in states) {
|
|
21
|
-
if (states.hasOwnProperty(key)) {
|
|
22
|
-
this[key] = states[key];
|
|
23
|
-
}
|
|
24
|
-
cb && cb();
|
|
25
|
-
}
|
|
26
|
-
},
|
|
27
|
-
getState: (key) => this[key],
|
|
28
|
-
getStates: () => this,
|
|
29
|
-
getCache: (key) => key && this.cache[key],
|
|
30
|
-
getCaches: () => this.cache,
|
|
31
|
-
setCache: (key, value) => key && (this.cache[key] = value),
|
|
32
|
-
nextTick: (cb) => setTimeout(cb, 0),
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: BaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: BaseComponent, isStandalone: true, selector: "mate-base-component", ngImport: i0, template: '', isInline: true }); }
|
|
37
|
-
}
|
|
38
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: BaseComponent, decorators: [{
|
|
39
|
-
type: Component,
|
|
40
|
-
args: [{
|
|
41
|
-
selector: 'mate-base-component',
|
|
42
|
-
standalone: true,
|
|
43
|
-
template: '',
|
|
44
|
-
}]
|
|
45
|
-
}], ctorParameters: () => [] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzLW5nL3NyYy9CYXNlL2Jhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzFDLE1BQU0sQ0FBQyxPQUFPLE9BQU8sYUFBYTtJQUdoQztJQUNBLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVU7WUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxLQUFLLFVBQVU7WUFDN0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1QsT0FBTztZQUNMLE9BQU8sRUFBRSxDQUFDLEdBQVcsRUFBRSxFQUFFO2dCQUN2QixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixDQUFDO1lBQ0QsUUFBUSxFQUFFLEdBQUcsRUFBRTtnQkFDYixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFDRCxRQUFRLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEVBQUU7Z0JBQ3ZCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxFQUFFLENBQUM7b0JBQ3pCLElBQUksTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO3dCQUMvQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO29CQUMxQixDQUFDO29CQUNELEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQztnQkFDYixDQUFDO1lBQ0gsQ0FBQztZQUNELFFBQVEsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUM1QixTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSTtZQUNyQixRQUFRLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQztZQUN6QyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUs7WUFDM0IsUUFBUSxFQUFFLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDMUQsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztTQUNwQyxDQUFDO0lBQ0osQ0FBQzs4R0FuQ2tCLGFBQWE7a0dBQWIsYUFBYSwrRUFGdEIsRUFBRTs7MkZBRU8sYUFBYTtrQkFMakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLEVBQUU7aUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmFzZUZvdW5kYXRpb24sIHsgRGVmYXVsdEFkYXB0ZXIgfSBmcm9tICcuLi9jb21wb25lbnRzLWNvbW1vbi9CYXNlL2ZvdW5kYXRpb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21hdGUtYmFzZS1jb21wb25lbnQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICB0ZW1wbGF0ZTogJycsXG59KVxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQmFzZUNvbXBvbmVudDxUIGV4dGVuZHMgQmFzZUZvdW5kYXRpb248RGVmYXVsdEFkYXB0ZXI+PiB7XG4gIGZvdW5kYXRpb246IFQ7XG4gIGNhY2hlOiBhbnk7XG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5mb3VuZGF0aW9uICYmXG4gICAgICB0eXBlb2YgdGhpcy5mb3VuZGF0aW9uLmRlc3Ryb3kgPT09ICdmdW5jdGlvbicgJiZcbiAgICAgIHRoaXMuZm91bmRhdGlvbi5kZXN0cm95KCk7XG4gIH1cblxuICBnZXQgYWRhcHRlcigpOiBEZWZhdWx0QWRhcHRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGdldFByb3A6IChrZXk6IHN0cmluZykgPT4ge1xuICAgICAgICByZXR1cm4gdGhpc1trZXldO1xuICAgICAgfSxcbiAgICAgIGdldFByb3BzOiAoKSA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgICAgfSxcbiAgICAgIHNldFN0YXRlOiAoc3RhdGVzLCBjYikgPT4ge1xuICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiBzdGF0ZXMpIHtcbiAgICAgICAgICBpZiAoc3RhdGVzLmhhc093blByb3BlcnR5KGtleSkpIHtcbiAgICAgICAgICAgIHRoaXNba2V5XSA9IHN0YXRlc1trZXldO1xuICAgICAgICAgIH1cbiAgICAgICAgICBjYiAmJiBjYigpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgZ2V0U3RhdGU6IChrZXkpID0+IHRoaXNba2V5XSxcbiAgICAgIGdldFN0YXRlczogKCkgPT4gdGhpcyxcbiAgICAgIGdldENhY2hlOiAoa2V5KSA9PiBrZXkgJiYgdGhpcy5jYWNoZVtrZXldLFxuICAgICAgZ2V0Q2FjaGVzOiAoKSA9PiB0aGlzLmNhY2hlLFxuICAgICAgc2V0Q2FjaGU6IChrZXksIHZhbHVlKSA9PiBrZXkgJiYgKHRoaXMuY2FjaGVba2V5XSA9IHZhbHVlKSxcbiAgICAgIG5leHRUaWNrOiAoY2IpID0+IHNldFRpbWVvdXQoY2IsIDApLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { AvatarBodyIconComponent } from '../avatar-body-icon/avatar-body-icon.component';
|
|
4
|
-
import { AvatarNoBodyIconComponent } from '../avatar-no-body-icon/avatar-no-body-icon.component';
|
|
5
|
-
import { TranslatePipe } from '../../Locale/translate.pipe';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/common";
|
|
8
|
-
export class AvatarComponent {
|
|
9
|
-
constructor() {
|
|
10
|
-
this.imgSrc = '';
|
|
11
|
-
this.name = '';
|
|
12
|
-
this.width = 36;
|
|
13
|
-
this.height = 36;
|
|
14
|
-
this.isRound = true;
|
|
15
|
-
this.gender = '';
|
|
16
|
-
this.isErrorImg = false;
|
|
17
|
-
this.isNobody = true;
|
|
18
|
-
this.code = 1;
|
|
19
|
-
this.fontSize = 12;
|
|
20
|
-
this.nameDisplay = '';
|
|
21
|
-
}
|
|
22
|
-
ngOnInit() {
|
|
23
|
-
this.calcValues(this.name);
|
|
24
|
-
}
|
|
25
|
-
ngOnChanges(changes) {
|
|
26
|
-
if (changes['name'] || changes['width'] || changes['height'] || changes['gender']) {
|
|
27
|
-
this.calcValues(this.name);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
onErrorImg() {
|
|
31
|
-
this.isErrorImg = true;
|
|
32
|
-
}
|
|
33
|
-
getBackgroundColor(char) {
|
|
34
|
-
if (this.gender) {
|
|
35
|
-
if (this.gender.toLowerCase() === 'male') {
|
|
36
|
-
this.code = 1;
|
|
37
|
-
}
|
|
38
|
-
else if (this.gender.toLowerCase() === 'female') {
|
|
39
|
-
this.code = 0;
|
|
40
|
-
}
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
const unicode = char.charCodeAt(0);
|
|
44
|
-
this.code = unicode % 2;
|
|
45
|
-
}
|
|
46
|
-
setDisplayName(nameValue, widthValue) {
|
|
47
|
-
if (!nameValue) {
|
|
48
|
-
this.nameDisplay = '';
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
if (nameValue.length < 2) {
|
|
52
|
-
this.nameDisplay = nameValue;
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
// 以中文开头显示最后两个字符
|
|
56
|
-
if (/^[\u4e00-\u9fa5]/.test(nameValue)) {
|
|
57
|
-
this.nameDisplay = nameValue.substr(nameValue.length - 2, 2);
|
|
58
|
-
// 英文开头
|
|
59
|
-
}
|
|
60
|
-
else if (/^[A-Za-z]/.test(nameValue)) {
|
|
61
|
-
// 含有两个及以上,包含空格,下划线,中划线分隔符的英文名取前两个字母的首字母
|
|
62
|
-
if (/[_ -]/.test(nameValue)) {
|
|
63
|
-
const parts = nameValue.split(/_|-|\s+/);
|
|
64
|
-
if (parts.length >= 2) {
|
|
65
|
-
this.nameDisplay = parts[0].substr(0, 1).toUpperCase() + parts[1].substr(0, 1).toUpperCase();
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
this.nameDisplay = nameValue.substr(0, 2).toUpperCase();
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
// 一个英文名的情况显示前两个字母
|
|
73
|
-
this.nameDisplay = nameValue.substr(0, 2).toUpperCase();
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
// 非中英文开头默认取前两个字符
|
|
78
|
-
this.nameDisplay = nameValue.substr(0, 2);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
if (widthValue < 30) {
|
|
82
|
-
this.nameDisplay = nameValue.substr(0, 1).toUpperCase();
|
|
83
|
-
}
|
|
84
|
-
this.getBackgroundColor(nameValue.substr(0, 1));
|
|
85
|
-
}
|
|
86
|
-
calcValues(nameInput) {
|
|
87
|
-
const userName = nameInput;
|
|
88
|
-
const minNum = Math.min(this.width, this.height);
|
|
89
|
-
if (userName) {
|
|
90
|
-
this.isNobody = false;
|
|
91
|
-
this.setDisplayName(userName, minNum);
|
|
92
|
-
}
|
|
93
|
-
else if (userName === '') {
|
|
94
|
-
this.isNobody = false;
|
|
95
|
-
this.nameDisplay = '';
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
this.isNobody = true;
|
|
99
|
-
}
|
|
100
|
-
this.fontSize = minNum / 4 + 3;
|
|
101
|
-
}
|
|
102
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: AvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
103
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: AvatarComponent, isStandalone: true, selector: "mc-avatar", inputs: { imgSrc: "imgSrc", name: "name", width: "width", height: "height", isRound: "isRound", gender: "gender" }, usesOnChanges: true, ngImport: i0, template: "<span class=\"mc-bubble-avatar-wrapper\">\n <img\n *ngIf=\"imgSrc && !isErrorImg\"\n [src]=\"imgSrc\"\n [attr.alt]=\"'Bubble.avatar' | translate:{ name: name }\"\n (error)=\"onErrorImg()\"\n [ngStyle]=\"{\n height: height + 'px',\n width: width + 'px',\n borderRadius: isRound ? '100%' : '0'\n }\"\n />\n <span\n *ngIf=\"!imgSrc && !isNobody && nameDisplay?.length !== 0\"\n [ngClass]=\"['mc-bubble-avatar-style', 'mc-bubble-avatar-background-' + code]\"\n [ngStyle]=\"{\n height: height + 'px',\n width: width + 'px',\n lineHeight: height + 'px',\n fontSize: fontSize + 'px',\n borderRadius: isRound ? '100%' : '0'\n }\"\n >\n {{ nameDisplay }}\n </span>\n <span\n *ngIf=\"!imgSrc && !isNobody && nameDisplay?.length === 0\"\n class=\"mc-bubble-avatar-style\"\n [ngStyle]=\"{ borderRadius: isRound ? '100%' : '0' }\"\n >\n <mc-avatar-body-icon [width]=\"width\" [height]=\"height\" />\n </span>\n <span\n *ngIf=\"(!imgSrc && isNobody) || (imgSrc && isErrorImg)\"\n class=\"mc-bubble-avatar-style\"\n [ngStyle]=\"{ borderRadius: isRound ? '100%' : '0' }\"\n >\n <mc-avatar-no-body-icon [width]=\"width\" [height]=\"height\" />\n </span>\n</span>", styles: [".mc-bubble-avatar-wrapper{display:inline-block}.mc-bubble-avatar-wrapper .mc-bubble-avatar-style{display:inline-block;text-align:center;color:var(--devui-light-text, #ffffff)}.mc-bubble-avatar-wrapper .mc-bubble-avatar-background-0{background-color:#ff8b87}.mc-bubble-avatar-wrapper .mc-bubble-avatar-background-1{background-color:#7693f5}\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.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: AvatarBodyIconComponent, selector: "mc-avatar-body-icon", inputs: ["width", "height"] }, { kind: "component", type: AvatarNoBodyIconComponent, selector: "mc-avatar-no-body-icon", inputs: ["width", "height"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
|
|
104
|
-
}
|
|
105
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: AvatarComponent, decorators: [{
|
|
106
|
-
type: Component,
|
|
107
|
-
args: [{ selector: 'mc-avatar', standalone: true, imports: [CommonModule, AvatarBodyIconComponent, AvatarNoBodyIconComponent, TranslatePipe], template: "<span class=\"mc-bubble-avatar-wrapper\">\n <img\n *ngIf=\"imgSrc && !isErrorImg\"\n [src]=\"imgSrc\"\n [attr.alt]=\"'Bubble.avatar' | translate:{ name: name }\"\n (error)=\"onErrorImg()\"\n [ngStyle]=\"{\n height: height + 'px',\n width: width + 'px',\n borderRadius: isRound ? '100%' : '0'\n }\"\n />\n <span\n *ngIf=\"!imgSrc && !isNobody && nameDisplay?.length !== 0\"\n [ngClass]=\"['mc-bubble-avatar-style', 'mc-bubble-avatar-background-' + code]\"\n [ngStyle]=\"{\n height: height + 'px',\n width: width + 'px',\n lineHeight: height + 'px',\n fontSize: fontSize + 'px',\n borderRadius: isRound ? '100%' : '0'\n }\"\n >\n {{ nameDisplay }}\n </span>\n <span\n *ngIf=\"!imgSrc && !isNobody && nameDisplay?.length === 0\"\n class=\"mc-bubble-avatar-style\"\n [ngStyle]=\"{ borderRadius: isRound ? '100%' : '0' }\"\n >\n <mc-avatar-body-icon [width]=\"width\" [height]=\"height\" />\n </span>\n <span\n *ngIf=\"(!imgSrc && isNobody) || (imgSrc && isErrorImg)\"\n class=\"mc-bubble-avatar-style\"\n [ngStyle]=\"{ borderRadius: isRound ? '100%' : '0' }\"\n >\n <mc-avatar-no-body-icon [width]=\"width\" [height]=\"height\" />\n </span>\n</span>", styles: [".mc-bubble-avatar-wrapper{display:inline-block}.mc-bubble-avatar-wrapper .mc-bubble-avatar-style{display:inline-block;text-align:center;color:var(--devui-light-text, #ffffff)}.mc-bubble-avatar-wrapper .mc-bubble-avatar-background-0{background-color:#ff8b87}.mc-bubble-avatar-wrapper .mc-bubble-avatar-background-1{background-color:#7693f5}\n"] }]
|
|
108
|
-
}], propDecorators: { imgSrc: [{
|
|
109
|
-
type: Input
|
|
110
|
-
}], name: [{
|
|
111
|
-
type: Input
|
|
112
|
-
}], width: [{
|
|
113
|
-
type: Input
|
|
114
|
-
}], height: [{
|
|
115
|
-
type: Input
|
|
116
|
-
}], isRound: [{
|
|
117
|
-
type: Input
|
|
118
|
-
}], gender: [{
|
|
119
|
-
type: Input
|
|
120
|
-
}] } });
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../projects/components-ng/src/Bubble/avatar/avatar.component.ts","../../../../../projects/components-ng/src/Bubble/avatar/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnChanges, SimpleChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { AvatarBodyIconComponent } from '../avatar-body-icon/avatar-body-icon.component';\nimport { AvatarNoBodyIconComponent } from '../avatar-no-body-icon/avatar-no-body-icon.component';\nimport { TranslatePipe } from '../../Locale/translate.pipe';\n\n@Component({\n  selector: 'mc-avatar',\n  standalone: true,\n  imports: [CommonModule, AvatarBodyIconComponent, AvatarNoBodyIconComponent, TranslatePipe],\n  templateUrl: './avatar.component.html',\n  styleUrls: ['./avatar.component.scss']\n})\nexport class AvatarComponent implements OnInit, OnChanges {\n  @Input() imgSrc: string = '';\n  @Input() name: string = '';\n  @Input() width: number = 36;\n  @Input() height: number = 36;\n  @Input() isRound: boolean = true;\n  @Input() gender: string = '';\n\n  isErrorImg: boolean = false;\n  isNobody: boolean = true;\n  code: number = 1;\n  fontSize: number = 12;\n  nameDisplay: string = '';\n\n  ngOnInit(): void {\n    this.calcValues(this.name);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['name'] || changes['width'] || changes['height'] || changes['gender']) {\n      this.calcValues(this.name);\n    }\n  }\n\n  onErrorImg(): void {\n    this.isErrorImg = true;\n  }\n\n  private getBackgroundColor(char: string): void {\n    if (this.gender) {\n      if (this.gender.toLowerCase() === 'male') {\n        this.code = 1;\n      } else if (this.gender.toLowerCase() === 'female') {\n        this.code = 0;\n      }\n      return;\n    }\n    const unicode = char.charCodeAt(0);\n    this.code = unicode % 2;\n  }\n\n  private setDisplayName(nameValue: string, widthValue: number): void {\n    if (!nameValue) {\n      this.nameDisplay = '';\n      return;\n    }\n\n    if (nameValue.length < 2) {\n      this.nameDisplay = nameValue;\n    } else {\n      // 以中文开头显示最后两个字符\n      if (/^[\\u4e00-\\u9fa5]/.test(nameValue)) {\n        this.nameDisplay = nameValue.substr(nameValue.length - 2, 2);\n        // 英文开头\n      } else if (/^[A-Za-z]/.test(nameValue)) {\n        // 含有两个及以上，包含空格，下划线，中划线分隔符的英文名取前两个字母的首字母\n        if (/[_ -]/.test(nameValue)) {\n          const parts = nameValue.split(/_|-|\\s+/);\n          if (parts.length >= 2) {\n            this.nameDisplay = parts[0].substr(0, 1).toUpperCase() + parts[1].substr(0, 1).toUpperCase();\n          } else {\n            this.nameDisplay = nameValue.substr(0, 2).toUpperCase();\n          }\n        } else {\n          // 一个英文名的情况显示前两个字母\n          this.nameDisplay = nameValue.substr(0, 2).toUpperCase();\n        }\n      } else {\n        // 非中英文开头默认取前两个字符\n        this.nameDisplay = nameValue.substr(0, 2);\n      }\n    }\n    if (widthValue < 30) {\n      this.nameDisplay = nameValue.substr(0, 1).toUpperCase();\n    }\n    this.getBackgroundColor(nameValue.substr(0, 1));\n  }\n\n  private calcValues(nameInput: string): void {\n    const userName = nameInput;\n    const minNum = Math.min(this.width, this.height);\n    if (userName) {\n      this.isNobody = false;\n      this.setDisplayName(userName, minNum);\n    } else if (userName === '') {\n      this.isNobody = false;\n      this.nameDisplay = '';\n    } else {\n      this.isNobody = true;\n    }\n    this.fontSize = minNum / 4 + 3;\n  }\n}","<span class=\"mc-bubble-avatar-wrapper\">\n  <img\n    *ngIf=\"imgSrc && !isErrorImg\"\n    [src]=\"imgSrc\"\n    [attr.alt]=\"'Bubble.avatar' | translate:{ name: name }\"\n    (error)=\"onErrorImg()\"\n    [ngStyle]=\"{\n      height: height + 'px',\n      width: width + 'px',\n      borderRadius: isRound ? '100%' : '0'\n    }\"\n  />\n  <span\n    *ngIf=\"!imgSrc && !isNobody && nameDisplay?.length !== 0\"\n    [ngClass]=\"['mc-bubble-avatar-style', 'mc-bubble-avatar-background-' + code]\"\n    [ngStyle]=\"{\n      height: height + 'px',\n      width: width + 'px',\n      lineHeight: height + 'px',\n      fontSize: fontSize + 'px',\n      borderRadius: isRound ? '100%' : '0'\n    }\"\n  >\n    {{ nameDisplay }}\n  </span>\n  <span\n    *ngIf=\"!imgSrc && !isNobody && nameDisplay?.length === 0\"\n    class=\"mc-bubble-avatar-style\"\n    [ngStyle]=\"{ borderRadius: isRound ? '100%' : '0' }\"\n  >\n    <mc-avatar-body-icon [width]=\"width\" [height]=\"height\" />\n  </span>\n  <span\n    *ngIf=\"(!imgSrc && isNobody) || (imgSrc && isErrorImg)\"\n    class=\"mc-bubble-avatar-style\"\n    [ngStyle]=\"{ borderRadius: isRound ? '100%' : '0' }\"\n  >\n    <mc-avatar-no-body-icon [width]=\"width\" [height]=\"height\" />\n  </span>\n</span>"]}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class AvatarBodyIconComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.width = 16;
|
|
6
|
-
this.height = 16;
|
|
7
|
-
}
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: AvatarBodyIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: AvatarBodyIconComponent, isStandalone: true, selector: "mc-avatar-body-icon", inputs: { width: "width", height: "height" }, ngImport: i0, template: "<svg\n [style.width.px]=\"width\"\n [style.height.px]=\"height\"\n style=\"vertical-align: middle;\"\n viewBox=\"0 0 30 30\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n>\n <g stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <circle id=\"Oval\" fill=\"#CACFD8\" cx=\"15\" cy=\"15\" r=\"15\"></circle>\n <path\n d=\"M14.9997866,16 C12.5145053,16 10.4997866,13.9852814 10.4997866, 11.5 C10.4997866,9.01471863 12.5145053,7 14.9997866,7 C17.485068, 7 19.4997866,9.01471863 19.4997866,11.5 C19.4997866,13.9852814 17.485068, 16 14.9997866,16 Z M23,23 L7,22.998553 C7,19.0122153 10.8892296, 16.5 14.9997866,16.5 C19.1103437,16.5 23,20 23,23 Z\"\n fill=\"#FFFFFF\"\n ></path>\n </g>\n</svg>", styles: [""] }); }
|
|
10
|
-
}
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: AvatarBodyIconComponent, decorators: [{
|
|
12
|
-
type: Component,
|
|
13
|
-
args: [{ selector: 'mc-avatar-body-icon', standalone: true, template: "<svg\n [style.width.px]=\"width\"\n [style.height.px]=\"height\"\n style=\"vertical-align: middle;\"\n viewBox=\"0 0 30 30\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n>\n <g stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <circle id=\"Oval\" fill=\"#CACFD8\" cx=\"15\" cy=\"15\" r=\"15\"></circle>\n <path\n d=\"M14.9997866,16 C12.5145053,16 10.4997866,13.9852814 10.4997866, 11.5 C10.4997866,9.01471863 12.5145053,7 14.9997866,7 C17.485068, 7 19.4997866,9.01471863 19.4997866,11.5 C19.4997866,13.9852814 17.485068, 16 14.9997866,16 Z M23,23 L7,22.998553 C7,19.0122153 10.8892296, 16.5 14.9997866,16.5 C19.1103437,16.5 23,20 23,23 Z\"\n fill=\"#FFFFFF\"\n ></path>\n </g>\n</svg>" }]
|
|
14
|
-
}], propDecorators: { width: [{
|
|
15
|
-
type: Input
|
|
16
|
-
}], height: [{
|
|
17
|
-
type: Input
|
|
18
|
-
}] } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLWJvZHktaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzLW5nL3NyYy9CdWJibGUvYXZhdGFyLWJvZHktaWNvbi9hdmF0YXItYm9keS1pY29uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMtbmcvc3JjL0J1YmJsZS9hdmF0YXItYm9keS1pY29uL2F2YXRhci1ib2R5LWljb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBUWpELE1BQU0sT0FBTyx1QkFBdUI7SUFOcEM7UUFPVyxVQUFLLEdBQVcsRUFBRSxDQUFDO1FBQ25CLFdBQU0sR0FBVyxFQUFFLENBQUM7S0FDOUI7OEdBSFksdUJBQXVCO2tHQUF2Qix1QkFBdUIsNkhDUnBDLDh1QkFlTTs7MkZEUE8sdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLHFCQUFxQixjQUNuQixJQUFJOzhCQUtQLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21jLWF2YXRhci1ib2R5LWljb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICB0ZW1wbGF0ZVVybDogJy4vYXZhdGFyLWJvZHktaWNvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2F2YXRhci1ib2R5LWljb24uY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBBdmF0YXJCb2R5SWNvbkNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHdpZHRoOiBudW1iZXIgPSAxNjtcbiAgQElucHV0KCkgaGVpZ2h0OiBudW1iZXIgPSAxNjtcbn0iLCI8c3ZnXG4gIFtzdHlsZS53aWR0aC5weF09XCJ3aWR0aFwiXG4gIFtzdHlsZS5oZWlnaHQucHhdPVwiaGVpZ2h0XCJcbiAgc3R5bGU9XCJ2ZXJ0aWNhbC1hbGlnbjogbWlkZGxlO1wiXG4gIHZpZXdCb3g9XCIwIDAgMzAgMzBcIlxuICB2ZXJzaW9uPVwiMS4xXCJcbiAgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiXG4+XG4gIDxnIHN0cm9rZT1cIm5vbmVcIiBzdHJva2Utd2lkdGg9XCIxXCIgZmlsbD1cIm5vbmVcIiBmaWxsLXJ1bGU9XCJldmVub2RkXCI+XG4gICAgPGNpcmNsZSBpZD1cIk92YWxcIiBmaWxsPVwiI0NBQ0ZEOFwiIGN4PVwiMTVcIiBjeT1cIjE1XCIgcj1cIjE1XCI+PC9jaXJjbGU+XG4gICAgPHBhdGhcbiAgICAgIGQ9XCJNMTQuOTk5Nzg2NiwxNiBDMTIuNTE0NTA1MywxNiAxMC40OTk3ODY2LDEzLjk4NTI4MTQgMTAuNDk5Nzg2NiwgMTEuNSBDMTAuNDk5Nzg2Niw5LjAxNDcxODYzIDEyLjUxNDUwNTMsNyAxNC45OTk3ODY2LDcgQzE3LjQ4NTA2OCwgNyAxOS40OTk3ODY2LDkuMDE0NzE4NjMgMTkuNDk5Nzg2NiwxMS41IEMxOS40OTk3ODY2LDEzLjk4NTI4MTQgMTcuNDg1MDY4LCAxNiAxNC45OTk3ODY2LDE2IFogTTIzLDIzIEw3LDIyLjk5ODU1MyBDNywxOS4wMTIyMTUzIDEwLjg4OTIyOTYsIDE2LjUgMTQuOTk5Nzg2NiwxNi41IEMxOS4xMTAzNDM3LDE2LjUgMjMsMjAgMjMsMjMgWlwiXG4gICAgICBmaWxsPVwiI0ZGRkZGRlwiXG4gICAgPjwvcGF0aD5cbiAgPC9nPlxuPC9zdmc+Il19
|