@matechat/ng 0.0.1-alpha.1 → 20.0.1-alpha.0
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/Base/base.component.d.ts +5 -5
- package/Bubble/bubble.component.d.ts +2 -2
- package/Input/button/button.component.d.ts +3 -2
- package/Input/input.component.d.ts +3 -3
- package/MarkdownCard/code-block.component.d.ts +6 -3
- package/MarkdownCard/markdown-card.component.d.ts +7 -5
- package/components-common/MarkdownCard/codeblock-foundation.d.ts +1 -0
- package/esm2022/Base/base.component.mjs +1 -2
- package/esm2022/Bubble/bubble.component.mjs +1 -1
- package/esm2022/Input/button/button.component.mjs +1 -1
- package/esm2022/Input/input.component.mjs +1 -1
- package/esm2022/MarkdownCard/code-block.component.mjs +30 -5
- package/esm2022/MarkdownCard/markdown-card.component.mjs +88 -58
- package/esm2022/components-common/MarkdownCard/codeblock-foundation.mjs +2 -2
- package/fesm2022/matechat-ng.mjs +115 -62
- package/fesm2022/matechat-ng.mjs.map +1 -1
- package/package.json +6 -4
package/Base/base.component.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { DefaultAdapter } from '../components-common/Base/foundation';
|
|
1
|
+
import BaseFoundation, { DefaultAdapter } from '../components-common/Base/foundation';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
export default class BaseComponent {
|
|
4
|
-
foundation:
|
|
3
|
+
export default class BaseComponent<T extends BaseFoundation<DefaultAdapter>> {
|
|
4
|
+
foundation: T;
|
|
5
5
|
cache: any;
|
|
6
6
|
constructor();
|
|
7
7
|
ngOnDestroy(): void;
|
|
8
8
|
get adapter(): DefaultAdapter;
|
|
9
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<BaseComponent
|
|
10
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<BaseComponent
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BaseComponent<any>, never>;
|
|
10
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BaseComponent<any>, "mate-base-component", never, {}, {}, never, never, true, never>;
|
|
11
11
|
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { TemplateRef, QueryList } from '@angular/core';
|
|
2
2
|
import { BubbleAlign, BubbleVariant, AvatarPosition, BubbleAvatar } from '../components-common//Bubble/common/bubble-types';
|
|
3
|
-
import { BubbleAdapter } from '../components-common/Bubble/foundation';
|
|
3
|
+
import { BubbleAdapter, BubbleFoundation } from '../components-common/Bubble/foundation';
|
|
4
4
|
import BaseComponent from '../Base/base.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class BubbleComponent extends BaseComponent {
|
|
6
|
+
export declare class BubbleComponent extends BaseComponent<BubbleFoundation> {
|
|
7
7
|
content: string;
|
|
8
8
|
loading: boolean;
|
|
9
9
|
align: BubbleAlign;
|
|
@@ -2,8 +2,9 @@ import { EventEmitter, ElementRef } from '@angular/core';
|
|
|
2
2
|
import { SendBtnVariant } from '../../components-common/Input/common/types';
|
|
3
3
|
import BaseComponent from '../../Base/base.component';
|
|
4
4
|
import { LocaleService } from '../../Locale';
|
|
5
|
+
import { InputButtonFoundation } from '../../components-common/Input/button-foundation';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class ButtonComponent extends BaseComponent {
|
|
7
|
+
export declare class ButtonComponent extends BaseComponent<InputButtonFoundation> {
|
|
7
8
|
private localeService;
|
|
8
9
|
disabled: boolean;
|
|
9
10
|
loading: boolean;
|
|
@@ -20,7 +21,7 @@ export declare class ButtonComponent extends BaseComponent {
|
|
|
20
21
|
left: string;
|
|
21
22
|
};
|
|
22
23
|
constructor(localeService: LocaleService);
|
|
23
|
-
get buttonClasses(): string
|
|
24
|
+
get buttonClasses(): Record<string, any>;
|
|
24
25
|
ngOnInit(): void;
|
|
25
26
|
onMouseDown(): void;
|
|
26
27
|
onMouseUp(): void;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { EventEmitter, OnInit, ElementRef, TemplateRef, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { DisplayType, InputVariant, SendBtnVariant, SubmitShortKey } from '../components-common/Input/common/types';
|
|
3
3
|
import BaseComponent from '../Base/base.component';
|
|
4
|
-
import { InputAdapter } from '../components-common/Input/foundation';
|
|
4
|
+
import { InputAdapter, InputFoundation } from '../components-common/Input/foundation';
|
|
5
5
|
import { LocaleService } from '../Locale/locale.service';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export type TextareaAutoSize = {
|
|
@@ -9,7 +9,7 @@ export type TextareaAutoSize = {
|
|
|
9
9
|
maxRows?: number;
|
|
10
10
|
} | boolean;
|
|
11
11
|
export declare const inputContextToken = "input-context";
|
|
12
|
-
export declare class InputComponent extends BaseComponent implements OnInit {
|
|
12
|
+
export declare class InputComponent extends BaseComponent<InputFoundation> implements OnInit {
|
|
13
13
|
private localeService;
|
|
14
14
|
value: string;
|
|
15
15
|
placeholder: string;
|
|
@@ -42,7 +42,7 @@ export declare class InputComponent extends BaseComponent implements OnInit {
|
|
|
42
42
|
get adapter(): InputAdapter;
|
|
43
43
|
onChange(e: any): void;
|
|
44
44
|
ngOnChanges(changes: SimpleChanges): void;
|
|
45
|
-
get inputClasses(): string
|
|
45
|
+
get inputClasses(): Record<string, any>;
|
|
46
46
|
get maxlengthValue(): number | null;
|
|
47
47
|
onInput(): void;
|
|
48
48
|
onCompositionStart(): void;
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { OnInit, ElementRef, OnChanges, SimpleChanges, ChangeDetectorRef } from '@angular/core';
|
|
1
|
+
import { OnInit, ElementRef, OnChanges, SimpleChanges, ChangeDetectorRef, QueryList } from '@angular/core';
|
|
2
2
|
import { TemplateRef } from '@angular/core';
|
|
3
3
|
import type { MermaidConfig } from '../components-common/MarkdownCard/common/mdCard.types';
|
|
4
4
|
import BaseComponent from '../Base/base.component';
|
|
5
|
-
import { CodeBlockAdapter } from '../components-common/MarkdownCard/codeblock-foundation';
|
|
5
|
+
import { CodeBlockAdapter, CodeBlockFoundation } from '../components-common/MarkdownCard/codeblock-foundation';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
export declare class CodeBlockComponent extends BaseComponent implements OnInit, OnChanges {
|
|
7
|
+
export declare class CodeBlockComponent extends BaseComponent<CodeBlockFoundation> implements OnInit, OnChanges {
|
|
8
8
|
private cdr;
|
|
9
9
|
code: string;
|
|
10
10
|
language: string;
|
|
@@ -17,9 +17,12 @@ export declare class CodeBlockComponent extends BaseComponent implements OnInit,
|
|
|
17
17
|
actionsTemplate: TemplateRef<any> | null;
|
|
18
18
|
rootRef: ElementRef;
|
|
19
19
|
mermaidContentRef: ElementRef;
|
|
20
|
+
codeElementRef: ElementRef;
|
|
21
|
+
codeElementTemplates: QueryList<ElementRef>;
|
|
20
22
|
expanded: boolean;
|
|
21
23
|
copied: boolean;
|
|
22
24
|
mermaidContent: string;
|
|
25
|
+
private diffDom;
|
|
23
26
|
private _showMermaidDiagram;
|
|
24
27
|
get showMermaidDiagram(): boolean;
|
|
25
28
|
set showMermaidDiagram(value: boolean);
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import { OnInit, OnChanges, OnDestroy, ChangeDetectorRef, SimpleChanges, EventEmitter, Renderer2, ViewContainerRef,
|
|
1
|
+
import { OnInit, OnChanges, OnDestroy, ChangeDetectorRef, SimpleChanges, EventEmitter, Renderer2, ViewContainerRef, TemplateRef } from '@angular/core';
|
|
2
2
|
import markdownit from 'markdown-it';
|
|
3
3
|
import type { Token } from 'markdown-it';
|
|
4
4
|
import type { ASTNode } from '../components-common/MarkdownCard/common/mdCard.types';
|
|
5
5
|
import { MarkdownCardProps } from '../components-common/MarkdownCard/common/mdCard.types';
|
|
6
6
|
import BaseComponent from '../Base/base.component';
|
|
7
|
-
import { MarkdownCardAdapter } from '../components-common/MarkdownCard/foundation';
|
|
7
|
+
import { MarkdownCardAdapter, MarkdownCardFoundation } from '../components-common/MarkdownCard/foundation';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
-
export declare class MarkdownCardComponent extends BaseComponent implements OnInit, OnChanges, OnDestroy {
|
|
10
|
-
private resolver;
|
|
9
|
+
export declare class MarkdownCardComponent extends BaseComponent<MarkdownCardFoundation> implements OnInit, OnChanges, OnDestroy {
|
|
11
10
|
private renderer;
|
|
12
11
|
cdr: ChangeDetectorRef;
|
|
13
12
|
private diffDom;
|
|
@@ -177,15 +176,18 @@ export declare class MarkdownCardComponent extends BaseComponent implements OnIn
|
|
|
177
176
|
isValidTagName: (tagName: string | undefined) => boolean;
|
|
178
177
|
};
|
|
179
178
|
mdCardService: any;
|
|
180
|
-
|
|
179
|
+
noDiff: boolean;
|
|
180
|
+
constructor(renderer: Renderer2, cdr: ChangeDetectorRef);
|
|
181
181
|
ngOnInit(): void;
|
|
182
182
|
get adapter(): MarkdownCardAdapter;
|
|
183
183
|
ngOnChanges(changes: SimpleChanges): void;
|
|
184
184
|
private parseContent;
|
|
185
185
|
private renderContent;
|
|
186
|
+
private getEmptyCodeBlock;
|
|
186
187
|
private astToVnodes;
|
|
187
188
|
private processASTNode;
|
|
188
189
|
private processHTMLNode;
|
|
190
|
+
private renderContentNoDiff;
|
|
189
191
|
private processInlineToken;
|
|
190
192
|
private processFenceNode;
|
|
191
193
|
private processASTNodeInternal;
|
|
@@ -3,6 +3,7 @@ import { MermaidService } from './common/MermaidService';
|
|
|
3
3
|
import { MDCardService } from './common/MDCardService';
|
|
4
4
|
export interface CodeBlockAdapter extends DefaultAdapter {
|
|
5
5
|
getContainer(): HTMLElement | null;
|
|
6
|
+
highlightCodeChange(code: string, language: string): void;
|
|
6
7
|
}
|
|
7
8
|
export declare class CodeBlockFoundation extends BaseFoundation<CodeBlockAdapter> {
|
|
8
9
|
mermaidService?: MermaidService;
|
|
@@ -2,7 +2,6 @@ import { Component } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export default class BaseComponent {
|
|
4
4
|
constructor() {
|
|
5
|
-
this.foundation = null;
|
|
6
5
|
}
|
|
7
6
|
ngOnDestroy() {
|
|
8
7
|
this.foundation &&
|
|
@@ -44,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
44
43
|
template: '',
|
|
45
44
|
}]
|
|
46
45
|
}], ctorParameters: () => [] });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzLW5nL3NyYy9CYXNlL2Jhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzFDLE1BQU0sQ0FBQyxPQUFPLE9BQU8sYUFBYTtJQUdoQztJQUNBLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVU7WUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxLQUFLLFVBQVU7WUFDN0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1QsT0FBTztZQUNMLE9BQU8sRUFBRSxDQUFDLEdBQVcsRUFBRSxFQUFFO2dCQUN2QixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixDQUFDO1lBQ0QsUUFBUSxFQUFFLEdBQUcsRUFBRTtnQkFDYixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFDRCxRQUFRLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEVBQUU7Z0JBQ3ZCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxFQUFFLENBQUM7b0JBQ3pCLElBQUksTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO3dCQUMvQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO29CQUMxQixDQUFDO29CQUNELEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQztnQkFDYixDQUFDO1lBQ0gsQ0FBQztZQUNELFFBQVEsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUM1QixTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSTtZQUNyQixRQUFRLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQztZQUN6QyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUs7WUFDM0IsUUFBUSxFQUFFLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDMUQsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztTQUNwQyxDQUFDO0lBQ0osQ0FBQzs4R0FuQ2tCLGFBQWE7a0dBQWIsYUFBYSwrRUFGdEIsRUFBRTs7MkZBRU8sYUFBYTtrQkFMakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLEVBQUU7aUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmFzZUZvdW5kYXRpb24sIHsgRGVmYXVsdEFkYXB0ZXIgfSBmcm9tICcuLi9jb21wb25lbnRzLWNvbW1vbi9CYXNlL2ZvdW5kYXRpb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21hdGUtYmFzZS1jb21wb25lbnQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICB0ZW1wbGF0ZTogJycsXG59KVxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQmFzZUNvbXBvbmVudDxUIGV4dGVuZHMgQmFzZUZvdW5kYXRpb248RGVmYXVsdEFkYXB0ZXI+PiB7XG4gIGZvdW5kYXRpb246IFQ7XG4gIGNhY2hlOiBhbnk7XG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5mb3VuZGF0aW9uICYmXG4gICAgICB0eXBlb2YgdGhpcy5mb3VuZGF0aW9uLmRlc3Ryb3kgPT09ICdmdW5jdGlvbicgJiZcbiAgICAgIHRoaXMuZm91bmRhdGlvbi5kZXN0cm95KCk7XG4gIH1cblxuICBnZXQgYWRhcHRlcigpOiBEZWZhdWx0QWRhcHRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGdldFByb3A6IChrZXk6IHN0cmluZykgPT4ge1xuICAgICAgICByZXR1cm4gdGhpc1trZXldO1xuICAgICAgfSxcbiAgICAgIGdldFByb3BzOiAoKSA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgICAgfSxcbiAgICAgIHNldFN0YXRlOiAoc3RhdGVzLCBjYikgPT4ge1xuICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiBzdGF0ZXMpIHtcbiAgICAgICAgICBpZiAoc3RhdGVzLmhhc093blByb3BlcnR5KGtleSkpIHtcbiAgICAgICAgICAgIHRoaXNba2V5XSA9IHN0YXRlc1trZXldO1xuICAgICAgICAgIH1cbiAgICAgICAgICBjYiAmJiBjYigpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgZ2V0U3RhdGU6IChrZXkpID0+IHRoaXNba2V5XSxcbiAgICAgIGdldFN0YXRlczogKCkgPT4gdGhpcyxcbiAgICAgIGdldENhY2hlOiAoa2V5KSA9PiBrZXkgJiYgdGhpcy5jYWNoZVtrZXldLFxuICAgICAgZ2V0Q2FjaGVzOiAoKSA9PiB0aGlzLmNhY2hlLFxuICAgICAgc2V0Q2FjaGU6IChrZXksIHZhbHVlKSA9PiBrZXkgJiYgKHRoaXMuY2FjaGVba2V5XSA9IHZhbHVlKSxcbiAgICAgIG5leHRUaWNrOiAoY2IpID0+IHNldFRpbWVvdXQoY2IsIDApLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -86,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
86
86
|
type: ContentChildren,
|
|
87
87
|
args: ['ng-content']
|
|
88
88
|
}] } });
|
|
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"]}
|
|
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,aAA+B;IAkBlE,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<BubbleFoundation> {\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"]}
|
|
@@ -80,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
80
80
|
type: HostListener,
|
|
81
81
|
args: ['mouseup']
|
|
82
82
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/components-ng/src/Input/button/button.component.ts","../../../../../projects/components-ng/src/Input/button/button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAc,MAAM,eAAe,CAAC;AAC5G,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAC5E,OAAO,aAAa,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAiB,aAAa,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAsB,qBAAqB,EAAE,MAAM,iDAAiD,CAAC;;;;AAQ1G,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAgBlD,YAAoB,aAA4B;QAAI,KAAK,EAAE,CAAC;QAAxC,kBAAa,GAAb,aAAa,CAAe;QAfvC,aAAQ,GAAY,KAAK,CAAC;QAC1B,YAAO,GAAY,KAAK,CAAC;QACzB,eAAU,GAAW,EAAE,CAAC;QACxB,mBAAc,GAAmB,cAAc,CAAC,IAAI,CAAC;QAEpD,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAClC,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QAI9C,gBAAW,GAAY,KAAK,CAAC;QAC7B,aAAQ,GAAY,KAAK,CAAC;QAC1B,cAAS,GAAkC,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IAEV,CAAC;IAE9D,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,OAA6B,CAAC,CAAC;QAChF,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAGD,WAAW;QACT,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAGD,SAAS;QACP,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,aAAa,CAAC,KAAiB;QAC7B,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IACzE,CAAC;IAED,SAAS,CAAC,KAAiB;QACzB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE1B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAClC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;8GAnDY,eAAe;kGAAf,eAAe,2cCd9B,4qIA2CA,giEDhCY,YAAY,wYAAE,iBAAiB,oDAAE,aAAa;;2FAG3C,eAAe;kBAN7B,SAAS;+BACE,WAAW,cACT,IAAI,WACP,CAAC,YAAY,EAAE,iBAAiB,EAAE,aAAa,CAAC;kFAIhD,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBAEc,aAAa;sBAAjC,SAAS;uBAAC,QAAQ;gBAkBnB,WAAW;sBADV,YAAY;uBAAC,WAAW;gBAMzB,SAAS;sBADR,YAAY;uBAAC,SAAS","sourcesContent":["import { Component, Input, EventEmitter, Output, HostListener, ViewChild, ElementRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { SendIconComponent } from '../send-icon/send-icon.component';\nimport { SendBtnVariant } from '../../components-common/Input/common/types';\nimport BaseComponent from '../../Base/base.component';\nimport { LocaleService, TranslatePipe } from '../../Locale';\nimport { InputButtonAdapter, InputButtonFoundation } from '../../components-common/Input/button-foundation';\n\n@Component({\n  selector: 'mc-button',\n  standalone: true,\n  imports: [CommonModule, SendIconComponent, TranslatePipe],\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n})export class ButtonComponent extends BaseComponent {\n  @Input() disabled: boolean = false;\n  @Input() loading: boolean = false;\n  @Input() inputValue: string = '';\n  @Input() sendBtnVariant: SendBtnVariant = SendBtnVariant.Full;\n  \n  @Output() submit = new EventEmitter<string>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() change = new EventEmitter<string>();\n  \n  @ViewChild('button') buttonElement!: ElementRef<HTMLButtonElement>;\n  \n  isMouseDown: boolean = false;\n  showWave: boolean = false;\n  waveStyle: { top: string; left: string } = { top: '0px', left: '0px' };\n  \n  constructor(private localeService: LocaleService) { super(); }\n  \n  get buttonClasses(): string {\n    return this.foundation.getButtonClasses();\n  }\n  \n  ngOnInit() {\n    this.foundation = new InputButtonFoundation(this.adapter as InputButtonAdapter);\n    this.foundation.init();\n  }\n  \n  @HostListener('mousedown')\n  onMouseDown(): void {\n    this.isMouseDown = true;\n  }\n  \n  @HostListener('mouseup')\n  onMouseUp(): void {\n    this.isMouseDown = false;\n  }\n  \n  showClickWave(event: MouseEvent): void {\n    this.foundation.showClickWave(this.buttonElement.nativeElement, event);\n  }\n  \n  onConfirm(event: MouseEvent): void {\n    this.showClickWave(event);\n    \n    if (this.loading) {\n      this.cancel.emit();\n    } else {\n      this.submit.emit(this.inputValue);\n      this.inputValue = '';\n      this.change.emit(this.inputValue);\n    }\n  }\n  \n\n}","<button\n  #button\n  [disabled]=\"disabled || (!loading && !inputValue)\"\n  [ngClass]=\"buttonClasses\"\n  (click)=\"onConfirm($event)\"\n  [attr.aria-label]=\"loading ? ('Input.pauseAnswer' | translate) : ('Input.send' | translate)\"\n  [attr.aria-disabled]=\"disabled || (!loading && !inputValue)\"\n  [attr.aria-busy]=\"loading\"\n>\n  <span class=\"mc-button-content\">\n    <ng-container *ngIf=\"loading\">\n      <ng-template [ngTemplateOutlet]=\"loadingIcon\"></ng-template>\n    </ng-container>\n    <mc-send-icon *ngIf=\"!loading\"></mc-send-icon>\n    <span *ngIf=\"sendBtnVariant === 'full'\">\n      {{\n        loading ? (\"Input.pauseAnswer\" | translate) : (\"Input.send\" | translate)\n      }}\n    </span>\n  </span>\n  <div\n    *ngIf=\"showWave\"\n    class=\"mc-button-water-wave\"\n    [style.top]=\"waveStyle.top\"\n    [style.left]=\"waveStyle.left\"\n  ></div>\n</button>\n\n<ng-template #loadingIcon>\n  <svg\n    width=\"16px\"\n    height=\"16px\"\n    viewBox=\"0 0 16 16\"\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      <path\n        d=\"M8,12 C8.27614237,12 8.5,12.2238576 8.5,12.5 L8.5,14.5 C8.5,14.7761424 8.27614237,15 8,15 C7.72385763,15 7.5,14.7761424 7.5,14.5 L7.5,12.5 C7.5,12.2238576 7.72385763,12 8,12 Z M11.0495421,11.3466838 L12.2251126,12.9647178 C12.3874251,13.1881217 12.3379006,13.5008065 12.1144968,13.663119 C11.8910929,13.8254314 11.5784081,13.775907 11.4160956,13.5525031 L10.2405251,11.9344691 C10.0782127,11.7110652 10.1277371,11.3983804 10.351141,11.236068 C10.5745449,11.0737556 10.8872297,11.12328 11.0495421,11.3466838 Z M5.64885899,11.236068 C5.87226287,11.3983804 5.92178728,11.7110652 5.75947486,11.9344691 L4.58390436,13.5525031 C4.42159194,13.775907 4.10890711,13.8254314 3.88550323,13.663119 C3.66209936,13.5008065 3.61257495,13.1881217 3.77488736,12.9647178 L4.95045787,11.3466838 C5.11277028,11.12328 5.42545512,11.0737556 5.64885899,11.236068 Z M12.4342628,8.91504822 L14.3363759,9.53308221 C14.5990029,9.61841489 14.7427283,9.90049196 14.6573956,10.163119 C14.5720629,10.425746 14.2899859,10.5694714 14.0273589,10.4841387 L12.1252458,9.86610473 C11.8626188,9.78077205 11.7188934,9.49869498 11.8042261,9.23606798 C11.8895588,8.97344097 12.1716358,8.82971553 12.4342628,8.91504822 Z M4.19577393,9.23606798 C4.28110662,9.49869498 4.13738118,9.78077205 3.87475417,9.86610473 L1.97264114,10.4841387 C1.71001414,10.5694714 1.42793707,10.425746 1.34260439,10.163119 C1.2572717,9.90049196 1.40099714,9.61841489 1.66362415,9.53308221 L3.56573718,8.91504822 C3.82836418,8.82971553 4.11044125,8.97344097 4.19577393,9.23606798 Z M14.6573956,5.83688104 C14.7427283,6.09950804 14.5990029,6.38158511 14.3363759,6.46691779 L12.4342628,7.08495178 C12.1716358,7.17028447 11.8895588,7.02655903 11.8042261,6.76393202 C11.7188934,6.50130502 11.8626188,6.21922795 12.1252458,6.13389527 L14.0273589,5.51586128 C14.2899859,5.43052859 14.5720629,5.57425403 14.6573956,5.83688104 Z M1.97264114,5.51586128 L3.87475417,6.13389527 C4.13738118,6.21922795 4.28110662,6.50130502 4.19577393,6.76393202 C4.11044125,7.02655903 3.82836418,7.17028447 3.56573718,7.08495178 L1.66362415,6.46691779 C1.40099714,6.38158511 1.2572717,6.09950804 1.34260439,5.83688104 C1.42793707,5.57425403 1.71001414,5.43052859 1.97264114,5.51586128 Z M12.1144968,2.33688104 C12.3379006,2.49919345 12.3874251,2.81187829 12.2251126,3.03528216 L11.0495421,4.65331615 C10.8872297,4.87672003 10.5745449,4.92624444 10.351141,4.76393202 C10.1277371,4.60161961 10.0782127,4.28893477 10.2405251,4.0655309 L11.4160956,2.44749691 C11.5784081,2.22409304 11.8910929,2.17456862 12.1144968,2.33688104 Z M4.58390436,2.44749691 L5.75947486,4.0655309 C5.92178728,4.28893477 5.87226287,4.60161961 5.64885899,4.76393202 C5.42545512,4.92624444 5.11277028,4.87672003 4.95045787,4.65331615 L3.77488736,3.03528216 C3.61257495,2.81187829 3.66209936,2.49919345 3.88550323,2.33688104 C4.10890711,2.17456862 4.42159194,2.22409304 4.58390436,2.44749691 Z M8,1 C8.27614237,1 8.5,1.22385763 8.5,1.5 L8.5,3.5 C8.5,3.77614237 8.27614237,4 8,4 C7.72385763,4 7.5,3.77614237 7.5,3.5 L7.5,1.5 C7.5,1.22385763 7.72385763,1 8,1 Z\"\n      ></path>\n    </g>\n  </svg>\n</ng-template>\n"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/components-ng/src/Input/button/button.component.ts","../../../../../projects/components-ng/src/Input/button/button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAc,MAAM,eAAe,CAAC;AAC5G,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAC5E,OAAO,aAAa,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAiB,aAAa,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAsB,qBAAqB,EAAE,MAAM,iDAAiD,CAAC;;;;AAQ1G,MAAM,OAAO,eAAgB,SAAQ,aAAoC;IAgBzE,YAAoB,aAA4B;QAAI,KAAK,EAAE,CAAC;QAAxC,kBAAa,GAAb,aAAa,CAAe;QAfvC,aAAQ,GAAY,KAAK,CAAC;QAC1B,YAAO,GAAY,KAAK,CAAC;QACzB,eAAU,GAAW,EAAE,CAAC;QACxB,mBAAc,GAAmB,cAAc,CAAC,IAAI,CAAC;QAEpD,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAClC,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QAI9C,gBAAW,GAAY,KAAK,CAAC;QAC7B,aAAQ,GAAY,KAAK,CAAC;QAC1B,cAAS,GAAkC,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IAEV,CAAC;IAE9D,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,OAA6B,CAAC,CAAC;QAChF,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAGD,WAAW;QACT,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAGD,SAAS;QACP,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,aAAa,CAAC,KAAiB;QAC7B,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IACzE,CAAC;IAED,SAAS,CAAC,KAAiB;QACzB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE1B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAClC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;8GAnDY,eAAe;kGAAf,eAAe,2cCd9B,4qIA2CA,giEDhCY,YAAY,wYAAE,iBAAiB,oDAAE,aAAa;;2FAG3C,eAAe;kBAN7B,SAAS;+BACE,WAAW,cACT,IAAI,WACP,CAAC,YAAY,EAAE,iBAAiB,EAAE,aAAa,CAAC;kFAIhD,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBAEc,aAAa;sBAAjC,SAAS;uBAAC,QAAQ;gBAkBnB,WAAW;sBADV,YAAY;uBAAC,WAAW;gBAMzB,SAAS;sBADR,YAAY;uBAAC,SAAS","sourcesContent":["import { Component, Input, EventEmitter, Output, HostListener, ViewChild, ElementRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { SendIconComponent } from '../send-icon/send-icon.component';\nimport { SendBtnVariant } from '../../components-common/Input/common/types';\nimport BaseComponent from '../../Base/base.component';\nimport { LocaleService, TranslatePipe } from '../../Locale';\nimport { InputButtonAdapter, InputButtonFoundation } from '../../components-common/Input/button-foundation';\n\n@Component({\n  selector: 'mc-button',\n  standalone: true,\n  imports: [CommonModule, SendIconComponent, TranslatePipe],\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n})export class ButtonComponent extends BaseComponent<InputButtonFoundation> {\n  @Input() disabled: boolean = false;\n  @Input() loading: boolean = false;\n  @Input() inputValue: string = '';\n  @Input() sendBtnVariant: SendBtnVariant = SendBtnVariant.Full;\n  \n  @Output() submit = new EventEmitter<string>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() change = new EventEmitter<string>();\n  \n  @ViewChild('button') buttonElement!: ElementRef<HTMLButtonElement>;\n  \n  isMouseDown: boolean = false;\n  showWave: boolean = false;\n  waveStyle: { top: string; left: string } = { top: '0px', left: '0px' };\n  \n  constructor(private localeService: LocaleService) { super(); }\n  \n  get buttonClasses(): Record<string, any> {\n    return this.foundation.getButtonClasses();\n  }\n  \n  ngOnInit() {\n    this.foundation = new InputButtonFoundation(this.adapter as InputButtonAdapter);\n    this.foundation.init();\n  }\n  \n  @HostListener('mousedown')\n  onMouseDown(): void {\n    this.isMouseDown = true;\n  }\n  \n  @HostListener('mouseup')\n  onMouseUp(): void {\n    this.isMouseDown = false;\n  }\n  \n  showClickWave(event: MouseEvent): void {\n    this.foundation.showClickWave(this.buttonElement.nativeElement, event);\n  }\n  \n  onConfirm(event: MouseEvent): void {\n    this.showClickWave(event);\n    \n    if (this.loading) {\n      this.cancel.emit();\n    } else {\n      this.submit.emit(this.inputValue);\n      this.inputValue = '';\n      this.change.emit(this.inputValue);\n    }\n  }\n  \n\n}","<button\n  #button\n  [disabled]=\"disabled || (!loading && !inputValue)\"\n  [ngClass]=\"buttonClasses\"\n  (click)=\"onConfirm($event)\"\n  [attr.aria-label]=\"loading ? ('Input.pauseAnswer' | translate) : ('Input.send' | translate)\"\n  [attr.aria-disabled]=\"disabled || (!loading && !inputValue)\"\n  [attr.aria-busy]=\"loading\"\n>\n  <span class=\"mc-button-content\">\n    <ng-container *ngIf=\"loading\">\n      <ng-template [ngTemplateOutlet]=\"loadingIcon\"></ng-template>\n    </ng-container>\n    <mc-send-icon *ngIf=\"!loading\"></mc-send-icon>\n    <span *ngIf=\"sendBtnVariant === 'full'\">\n      {{\n        loading ? (\"Input.pauseAnswer\" | translate) : (\"Input.send\" | translate)\n      }}\n    </span>\n  </span>\n  <div\n    *ngIf=\"showWave\"\n    class=\"mc-button-water-wave\"\n    [style.top]=\"waveStyle.top\"\n    [style.left]=\"waveStyle.left\"\n  ></div>\n</button>\n\n<ng-template #loadingIcon>\n  <svg\n    width=\"16px\"\n    height=\"16px\"\n    viewBox=\"0 0 16 16\"\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      <path\n        d=\"M8,12 C8.27614237,12 8.5,12.2238576 8.5,12.5 L8.5,14.5 C8.5,14.7761424 8.27614237,15 8,15 C7.72385763,15 7.5,14.7761424 7.5,14.5 L7.5,12.5 C7.5,12.2238576 7.72385763,12 8,12 Z M11.0495421,11.3466838 L12.2251126,12.9647178 C12.3874251,13.1881217 12.3379006,13.5008065 12.1144968,13.663119 C11.8910929,13.8254314 11.5784081,13.775907 11.4160956,13.5525031 L10.2405251,11.9344691 C10.0782127,11.7110652 10.1277371,11.3983804 10.351141,11.236068 C10.5745449,11.0737556 10.8872297,11.12328 11.0495421,11.3466838 Z M5.64885899,11.236068 C5.87226287,11.3983804 5.92178728,11.7110652 5.75947486,11.9344691 L4.58390436,13.5525031 C4.42159194,13.775907 4.10890711,13.8254314 3.88550323,13.663119 C3.66209936,13.5008065 3.61257495,13.1881217 3.77488736,12.9647178 L4.95045787,11.3466838 C5.11277028,11.12328 5.42545512,11.0737556 5.64885899,11.236068 Z M12.4342628,8.91504822 L14.3363759,9.53308221 C14.5990029,9.61841489 14.7427283,9.90049196 14.6573956,10.163119 C14.5720629,10.425746 14.2899859,10.5694714 14.0273589,10.4841387 L12.1252458,9.86610473 C11.8626188,9.78077205 11.7188934,9.49869498 11.8042261,9.23606798 C11.8895588,8.97344097 12.1716358,8.82971553 12.4342628,8.91504822 Z M4.19577393,9.23606798 C4.28110662,9.49869498 4.13738118,9.78077205 3.87475417,9.86610473 L1.97264114,10.4841387 C1.71001414,10.5694714 1.42793707,10.425746 1.34260439,10.163119 C1.2572717,9.90049196 1.40099714,9.61841489 1.66362415,9.53308221 L3.56573718,8.91504822 C3.82836418,8.82971553 4.11044125,8.97344097 4.19577393,9.23606798 Z M14.6573956,5.83688104 C14.7427283,6.09950804 14.5990029,6.38158511 14.3363759,6.46691779 L12.4342628,7.08495178 C12.1716358,7.17028447 11.8895588,7.02655903 11.8042261,6.76393202 C11.7188934,6.50130502 11.8626188,6.21922795 12.1252458,6.13389527 L14.0273589,5.51586128 C14.2899859,5.43052859 14.5720629,5.57425403 14.6573956,5.83688104 Z M1.97264114,5.51586128 L3.87475417,6.13389527 C4.13738118,6.21922795 4.28110662,6.50130502 4.19577393,6.76393202 C4.11044125,7.02655903 3.82836418,7.17028447 3.56573718,7.08495178 L1.66362415,6.46691779 C1.40099714,6.38158511 1.2572717,6.09950804 1.34260439,5.83688104 C1.42793707,5.57425403 1.71001414,5.43052859 1.97264114,5.51586128 Z M12.1144968,2.33688104 C12.3379006,2.49919345 12.3874251,2.81187829 12.2251126,3.03528216 L11.0495421,4.65331615 C10.8872297,4.87672003 10.5745449,4.92624444 10.351141,4.76393202 C10.1277371,4.60161961 10.0782127,4.28893477 10.2405251,4.0655309 L11.4160956,2.44749691 C11.5784081,2.22409304 11.8910929,2.17456862 12.1144968,2.33688104 Z M4.58390436,2.44749691 L5.75947486,4.0655309 C5.92178728,4.28893477 5.87226287,4.60161961 5.64885899,4.76393202 C5.42545512,4.92624444 5.11277028,4.87672003 4.95045787,4.65331615 L3.77488736,3.03528216 C3.61257495,2.81187829 3.66209936,2.49919345 3.88550323,2.33688104 C4.10890711,2.17456862 4.42159194,2.22409304 4.58390436,2.44749691 Z M8,1 C8.27614237,1 8.5,1.22385763 8.5,1.5 L8.5,3.5 C8.5,3.77614237 8.27614237,4 8,4 C7.72385763,4 7.5,3.77614237 7.5,3.5 L7.5,1.5 C7.5,1.22385763 7.72385763,1 8,1 Z\"\n      ></path>\n    </g>\n  </svg>\n</ng-template>\n"]}
|
|
@@ -282,4 +282,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
282
282
|
type: ContentChild,
|
|
283
283
|
args: ['extra']
|
|
284
284
|
}] } });
|
|
285
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../projects/components-ng/src/Input/input.component.ts","../../../../projects/components-ng/src/Input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  ViewChild,\n  ElementRef,\n  ContentChild,\n  TemplateRef,\n  SimpleChanges,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { ButtonComponent } from './button/button.component';\nimport {\n  DisplayType,\n  InputVariant,\n  SendBtnVariant,\n  SubmitShortKey,\n} from '../components-common/Input/common/types';\n\n// TextareaAutoSize类型定义\nexport type TextareaAutoSize = { minRows?: number; maxRows?: number } | boolean;\n\n// 默认的autosize配置\nconst DEFAULT_AUTOSIZE = {\n  minRows: 1,\n  maxRows: 5\n};\n\nimport BaseComponent from '../Base/base.component';\nimport {\n  InputAdapter,\n  InputFoundation,\n} from '../components-common/Input/foundation';\nimport { LocaleService } from '../Locale/locale.service';\nimport { TranslatePipe } from '../Locale/translate.pipe';\n\n// 创建一个token用于组件间通信\nexport const inputContextToken = 'input-context';\n\n@Component({\n  selector: 'mc-input',\n  standalone: true,\n  imports: [CommonModule, FormsModule, ButtonComponent, TranslatePipe],\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [{ provide: inputContextToken, useExisting: InputComponent }],\n})\nexport class InputComponent extends BaseComponent implements OnInit {\n  @Input() value: string = '';\n  @Input() placeholder: string = '';\n  @Input() disabled: boolean = false;\n  @Input() displayType: DisplayType = DisplayType.Full;\n  @Input() variant: InputVariant = InputVariant.Bordered;\n  @Input() sendBtnVariant: SendBtnVariant = SendBtnVariant.Full;\n  @Input() loading: boolean = false;\n  @Input() showCount: boolean = false;\n  @Input() maxLength: number | null = null;\n  @Input() submitShortKey: SubmitShortKey | null | string =\n    SubmitShortKey.Enter;\n  @Input() autofocus: boolean = false;\n  @Input() autosize: TextareaAutoSize = false;\n  \n  // textarea样式\n  textareaStyle: Record<string, string> = {};\n\n  @Output() change = new EventEmitter<string>();\n  @Output() submit = new EventEmitter<string>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() focus = new EventEmitter<FocusEvent>();\n  @Output() blur = new EventEmitter<FocusEvent>();\n\n  @ViewChild('textarea') textareaElement!: ElementRef<HTMLTextAreaElement>;\n\n  @ContentChild('head') headTemplate: TemplateRef<any> | null = null;\n  @ContentChild('prefix') prefixTemplate: TemplateRef<any> | null = null;\n  @ContentChild('suffix') suffixTemplate: TemplateRef<any> | null = null;\n  @ContentChild('button') buttonTemplate: TemplateRef<any> | null = null;\n  @ContentChild('extra') extraTemplate: TemplateRef<any> | null = null;\n\n  inputValue: string = '';\n  lock: boolean = false;\n\n  constructor(private localeService: LocaleService) {\n    super();\n  }\n\n  ngOnInit() {\n    this.foundation = new InputFoundation(this.adapter);\n    this.foundation.init();\n    this.inputValue = this.value;\n  }\n\n  override get adapter(): InputAdapter {\n    return {\n      ...super.adapter,\n      locale: (key, params) => this.localeService.translate(key, params),\n      emitChange: () => {\n        this.change.emit(this.inputValue);\n      },\n      submit: (inputValue) => {\n        this.submit.emit(inputValue);\n      },\n    };\n  }\n\n  onChange(e): void {\n    e.stopPropagation();\n    this.foundation.emitChange();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['value']) {\n      this.inputValue = changes['value']?.currentValue || '';\n      // 值变化时更新textarea样式\n      this.updateTextareaStyle();\n    }\n    \n    if (changes['autosize']) {\n      // autosize配置变化时更新textarea样式\n      this.updateTextareaStyle();\n    }\n  }\n\n  get inputClasses(): string {\n    return this.foundation.getInputClasses();\n  }\n\n  get maxlengthValue() {\n    return this.maxLength !== undefined ? this.maxLength : null;\n  }\n\n  onInput(): void {\n    if (!this.lock) {\n      this.foundation.emitChange();\n      // 输入时更新textarea样式\n      this.updateTextareaStyle();\n    }\n  }\n\n  onCompositionStart(): void {\n    this.lock = true;\n  }\n\n  onCompositionEnd(): void {\n    this.lock = false;\n    this.foundation.emitChange();\n  }\n\n  onKeydown(event: KeyboardEvent): void {\n    this.foundation.onKeydown(event);\n  }\n\n  clearInput(): void {\n    this.foundation.clearInput();\n  }\n\n  getInput(): string {\n    return this.inputValue;\n  }\n\n  // 处理button组件的事件\n  onButtonSubmit(value: string): void {\n    this.submit.emit(value);\n  }\n\n  onButtonCancel(): void {\n    this.cancel.emit();\n  }\n\n  onButtonChange(value: string): void {\n    this.inputValue = value;\n    this.foundation.emitChange();\n  }\n\n  ngAfterViewInit() {\n    if (this.autofocus && this.textareaElement && !this.disabled) {\n      // 在下一个变更检测周期中聚焦，以确保视图已经完全初始化\n      setTimeout(() => {\n        this.textareaElement.nativeElement.focus();\n      });\n    }\n    \n    // 初始化时更新textarea样式\n    this.updateTextareaStyle();\n  }\n  \n  // 更新textarea样式\n  updateTextareaStyle() {\n    if (!this.textareaElement || this.autosize === false) {\n      this.textareaStyle = {};\n      return;\n    }\n    \n    const config = this.getAutosizeConfig();\n    const result = this.computeTextareaHeight(\n      this.textareaElement.nativeElement,\n      config.minRows,\n      config.maxRows\n    );\n    \n    this.textareaStyle = {\n      ...result,\n      resize: 'none'\n    };\n  }\n  \n  // 获取autosize配置\n  private getAutosizeConfig() {\n    return typeof this.autosize === 'boolean'\n      ? DEFAULT_AUTOSIZE\n      : this.autosize;\n  }\n  \n  // 计算textarea高度\n  private computeTextareaHeight(\n    targetElement: HTMLTextAreaElement,\n    minRows = 1,\n    maxRows?: number\n  ): Record<string, string> {\n    const style = window.getComputedStyle(targetElement);\n    const boxSizing = style.getPropertyValue('box-sizing');\n    \n    const paddingSize = \n      Number.parseFloat(style.getPropertyValue('padding-top')) +\n      Number.parseFloat(style.getPropertyValue('padding-bottom'));\n    \n    const borderSize = \n      Number.parseFloat(style.getPropertyValue('border-top-width')) +\n      Number.parseFloat(style.getPropertyValue('border-bottom-width'));\n    \n    // 创建临时textarea元素\n    const tempTextarea = document.createElement('textarea');\n    const sizingStyle = [\n      'letter-spacing', 'line-height', 'padding-top', 'padding-bottom',\n      'font-family', 'font-weight', 'font-size', 'font-variant',\n      'text-rendering', 'text-transform', 'width', 'text-indent',\n      'padding-left', 'padding-right', 'border-width', 'box-sizing',\n      'word-break', 'white-space'\n    ];\n    \n    const contextStyle = sizingStyle\n      .map(name => `${name}:${style.getPropertyValue(name)}`)\n      .join(';');\n    \n    const hiddenStyle = `\n      min-height:0 !important;\n      max-height:none !important;\n      height:0 !important;\n      visibility:hidden !important;\n      overflow:hidden !important;\n      position:absolute !important;\n      z-index:-1000 !important;\n      top:0 !important;\n      right:0 !important;\n      pointer-events:none !important;\n    `;\n    \n    tempTextarea.setAttribute('style', `${contextStyle};${hiddenStyle}`);\n    tempTextarea.value = targetElement.value || targetElement.placeholder || '';\n    \n    document.body.appendChild(tempTextarea);\n    \n    let height = tempTextarea.scrollHeight;\n    const result: Record<string, string> = {\n      height: `${height}px`\n    };\n    \n    if (minRows !== undefined || maxRows !== undefined) {\n      tempTextarea.value = ' ';\n      const singleRowHeight = tempTextarea.scrollHeight - paddingSize;\n      \n      if (minRows !== undefined) {\n        let minHeight = singleRowHeight * minRows;\n        if (boxSizing === 'border-box') {\n          minHeight = minHeight + paddingSize + borderSize;\n        }\n        height = Math.max(minHeight, height);\n        result['minHeight'] = `${minHeight}px`;\n      }\n      \n      if (maxRows !== undefined) {\n        let maxHeight = singleRowHeight * maxRows;\n        if (boxSizing === 'border-box') {\n          maxHeight = maxHeight + paddingSize + borderSize;\n        }\n        if (height > maxHeight) {\n          height = maxHeight;\n          result['overflowY'] = 'auto';\n        }\n      }\n    }\n    \n    document.body.removeChild(tempTextarea);\n    \n    result['height'] = `${height}px`;\n    return result;\n  }\n\n  get placeholderText(): string {\n    return this.foundation.getPlaceholderText();\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focus.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.blur.emit(event);\n  }\n}\n","<div [ngClass]=\"inputClasses\">\n  <ng-container *ngIf=\"headTemplate; then headTemplate\"></ng-container>\n\n  <div class=\"mc-input-content\">\n    <ng-container *ngIf=\"prefixTemplate; then prefixTemplate\"></ng-container>\n\n    <textarea\n      #textarea\n      [(ngModel)]=\"inputValue\"\n      [placeholder]=\"placeholderText\"\n      [disabled]=\"disabled\"\n      [maxlength]=\"maxLength\"\n      class=\"mc-textarea\"\n      [ngClass]=\"{\n        'mc-textarea-simple': displayType === 'simple',\n        'mc-textarea-disabled': disabled\n      }\"\n      [ngStyle]=\"textareaStyle\"\n      [attr.aria-label]=\"'Input.ariaLabel' | translate\"\n      [attr.aria-disabled]=\"disabled\"\n      (input)=\"onInput()\"\n      (change)=\"onChange($event)\"\n      (compositionstart)=\"onCompositionStart()\"\n      (compositionend)=\"onCompositionEnd()\"\n      (keydown)=\"onKeydown($event)\"\n      (focus)=\"onFocus($event)\"\n      (blur)=\"onBlur($event)\"\n    ></textarea>\n    <ng-container *ngIf=\"suffixTemplate; then suffixTemplate\"></ng-container>\n\n    <ng-container *ngIf=\"displayType === 'simple'\">\n      <ng-container *ngIf=\"buttonTemplate; else defaultButton\">\n        <ng-container\n          *ngIf=\"buttonTemplate; then buttonTemplate\"\n        ></ng-container>\n      </ng-container>\n      <ng-template #defaultButton>\n        <mc-button\n          [disabled]=\"disabled || (!loading && !inputValue)\"\n          [loading]=\"loading\"\n          [inputValue]=\"inputValue\"\n          [sendBtnVariant]=\"sendBtnVariant\"\n          (submit)=\"onButtonSubmit($event)\"\n          (cancel)=\"onButtonCancel()\"\n          (change)=\"onButtonChange($event)\"\n        ></mc-button>\n      </ng-template>\n    </ng-container>\n  </div>\n\n  <div *ngIf=\"displayType === 'full'\" class=\"mc-input-foot\">\n    <div class=\"mc-input-foot-left\">\n      <ng-container *ngIf=\"extraTemplate; then extraTemplate\"></ng-container>\n      <span *ngIf=\"showCount\" id=\"mc-input-count\" class=\"mc-input-foot-count\">\n        {{ inputValue.length }}{{ !maxLength ? \"\" : \"/\" + maxLength }}\n      </span>\n    </div>\n\n    <ng-container *ngIf=\"buttonTemplate; else defaultFooterButton\">\n      <ng-container *ngIf=\"buttonTemplate; then buttonTemplate\"></ng-container>\n    </ng-container>\n    <ng-template #defaultFooterButton>\n      <mc-button\n        [disabled]=\"disabled || (!loading && !inputValue)\"\n        [loading]=\"loading\"\n        [inputValue]=\"inputValue\"\n        [sendBtnVariant]=\"sendBtnVariant\"\n        (submit)=\"onButtonSubmit($event)\"\n        (cancel)=\"onButtonCancel()\"\n        (change)=\"onButtonChange($event)\"\n      ></mc-button>\n    </ng-template>\n  </div>\n</div>\n"]}
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../projects/components-ng/src/Input/input.component.ts","../../../../projects/components-ng/src/Input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  ViewChild,\n  ElementRef,\n  ContentChild,\n  TemplateRef,\n  SimpleChanges,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { ButtonComponent } from './button/button.component';\nimport {\n  DisplayType,\n  InputVariant,\n  SendBtnVariant,\n  SubmitShortKey,\n} from '../components-common/Input/common/types';\n\n// TextareaAutoSize类型定义\nexport type TextareaAutoSize = { minRows?: number; maxRows?: number } | boolean;\n\n// 默认的autosize配置\nconst DEFAULT_AUTOSIZE = {\n  minRows: 1,\n  maxRows: 5\n};\n\nimport BaseComponent from '../Base/base.component';\nimport {\n  InputAdapter,\n  InputFoundation,\n} from '../components-common/Input/foundation';\nimport { LocaleService } from '../Locale/locale.service';\nimport { TranslatePipe } from '../Locale/translate.pipe';\n\n// 创建一个token用于组件间通信\nexport const inputContextToken = 'input-context';\n\n@Component({\n  selector: 'mc-input',\n  standalone: true,\n  imports: [CommonModule, FormsModule, ButtonComponent, TranslatePipe],\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [{ provide: inputContextToken, useExisting: InputComponent }],\n})\nexport class InputComponent extends BaseComponent<InputFoundation> implements OnInit {\n  @Input() value: string = '';\n  @Input() placeholder: string = '';\n  @Input() disabled: boolean = false;\n  @Input() displayType: DisplayType = DisplayType.Full;\n  @Input() variant: InputVariant = InputVariant.Bordered;\n  @Input() sendBtnVariant: SendBtnVariant = SendBtnVariant.Full;\n  @Input() loading: boolean = false;\n  @Input() showCount: boolean = false;\n  @Input() maxLength: number | null = null;\n  @Input() submitShortKey: SubmitShortKey | null | string =\n    SubmitShortKey.Enter;\n  @Input() autofocus: boolean = false;\n  @Input() autosize: TextareaAutoSize = false;\n  \n  // textarea样式\n  textareaStyle: Record<string, string> = {};\n\n  @Output() change = new EventEmitter<string>();\n  @Output() submit = new EventEmitter<string>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() focus = new EventEmitter<FocusEvent>();\n  @Output() blur = new EventEmitter<FocusEvent>();\n\n  @ViewChild('textarea') textareaElement!: ElementRef<HTMLTextAreaElement>;\n\n  @ContentChild('head') headTemplate: TemplateRef<any> | null = null;\n  @ContentChild('prefix') prefixTemplate: TemplateRef<any> | null = null;\n  @ContentChild('suffix') suffixTemplate: TemplateRef<any> | null = null;\n  @ContentChild('button') buttonTemplate: TemplateRef<any> | null = null;\n  @ContentChild('extra') extraTemplate: TemplateRef<any> | null = null;\n\n  inputValue: string = '';\n  lock: boolean = false;\n\n  constructor(private localeService: LocaleService) {\n    super();\n  }\n\n  ngOnInit() {\n    this.foundation = new InputFoundation(this.adapter);\n    this.foundation.init();\n    this.inputValue = this.value;\n  }\n\n  override get adapter(): InputAdapter {\n    return {\n      ...super.adapter,\n      locale: (key, params) => this.localeService.translate(key, params),\n      emitChange: () => {\n        this.change.emit(this.inputValue);\n      },\n      submit: (inputValue) => {\n        this.submit.emit(inputValue);\n      },\n    };\n  }\n\n  onChange(e): void {\n    e.stopPropagation();\n    this.foundation.emitChange();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['value']) {\n      this.inputValue = changes['value']?.currentValue || '';\n      // 值变化时更新textarea样式\n      this.updateTextareaStyle();\n    }\n    \n    if (changes['autosize']) {\n      // autosize配置变化时更新textarea样式\n      this.updateTextareaStyle();\n    }\n  }\n\n  get inputClasses(): Record<string, any> {\n    return this.foundation.getInputClasses();\n  }\n\n  get maxlengthValue() {\n    return this.maxLength !== undefined ? this.maxLength : null;\n  }\n\n  onInput(): void {\n    if (!this.lock) {\n      this.foundation.emitChange();\n      // 输入时更新textarea样式\n      this.updateTextareaStyle();\n    }\n  }\n\n  onCompositionStart(): void {\n    this.lock = true;\n  }\n\n  onCompositionEnd(): void {\n    this.lock = false;\n    this.foundation.emitChange();\n  }\n\n  onKeydown(event: KeyboardEvent): void {\n    this.foundation.onKeydown(event);\n  }\n\n  clearInput(): void {\n    this.foundation.clearInput();\n  }\n\n  getInput(): string {\n    return this.inputValue;\n  }\n\n  // 处理button组件的事件\n  onButtonSubmit(value: string): void {\n    this.submit.emit(value);\n  }\n\n  onButtonCancel(): void {\n    this.cancel.emit();\n  }\n\n  onButtonChange(value: string): void {\n    this.inputValue = value;\n    this.foundation.emitChange();\n  }\n\n  ngAfterViewInit() {\n    if (this.autofocus && this.textareaElement && !this.disabled) {\n      // 在下一个变更检测周期中聚焦，以确保视图已经完全初始化\n      setTimeout(() => {\n        this.textareaElement.nativeElement.focus();\n      });\n    }\n    \n    // 初始化时更新textarea样式\n    this.updateTextareaStyle();\n  }\n  \n  // 更新textarea样式\n  updateTextareaStyle() {\n    if (!this.textareaElement || this.autosize === false) {\n      this.textareaStyle = {};\n      return;\n    }\n    \n    const config = this.getAutosizeConfig();\n    const result = this.computeTextareaHeight(\n      this.textareaElement.nativeElement,\n      config.minRows,\n      config.maxRows\n    );\n    \n    this.textareaStyle = {\n      ...result,\n      resize: 'none'\n    };\n  }\n  \n  // 获取autosize配置\n  private getAutosizeConfig() {\n    return typeof this.autosize === 'boolean'\n      ? DEFAULT_AUTOSIZE\n      : this.autosize;\n  }\n  \n  // 计算textarea高度\n  private computeTextareaHeight(\n    targetElement: HTMLTextAreaElement,\n    minRows = 1,\n    maxRows?: number\n  ): Record<string, string> {\n    const style = window.getComputedStyle(targetElement);\n    const boxSizing = style.getPropertyValue('box-sizing');\n    \n    const paddingSize = \n      Number.parseFloat(style.getPropertyValue('padding-top')) +\n      Number.parseFloat(style.getPropertyValue('padding-bottom'));\n    \n    const borderSize = \n      Number.parseFloat(style.getPropertyValue('border-top-width')) +\n      Number.parseFloat(style.getPropertyValue('border-bottom-width'));\n    \n    // 创建临时textarea元素\n    const tempTextarea = document.createElement('textarea');\n    const sizingStyle = [\n      'letter-spacing', 'line-height', 'padding-top', 'padding-bottom',\n      'font-family', 'font-weight', 'font-size', 'font-variant',\n      'text-rendering', 'text-transform', 'width', 'text-indent',\n      'padding-left', 'padding-right', 'border-width', 'box-sizing',\n      'word-break', 'white-space'\n    ];\n    \n    const contextStyle = sizingStyle\n      .map(name => `${name}:${style.getPropertyValue(name)}`)\n      .join(';');\n    \n    const hiddenStyle = `\n      min-height:0 !important;\n      max-height:none !important;\n      height:0 !important;\n      visibility:hidden !important;\n      overflow:hidden !important;\n      position:absolute !important;\n      z-index:-1000 !important;\n      top:0 !important;\n      right:0 !important;\n      pointer-events:none !important;\n    `;\n    \n    tempTextarea.setAttribute('style', `${contextStyle};${hiddenStyle}`);\n    tempTextarea.value = targetElement.value || targetElement.placeholder || '';\n    \n    document.body.appendChild(tempTextarea);\n    \n    let height = tempTextarea.scrollHeight;\n    const result: Record<string, string> = {\n      height: `${height}px`\n    };\n    \n    if (minRows !== undefined || maxRows !== undefined) {\n      tempTextarea.value = ' ';\n      const singleRowHeight = tempTextarea.scrollHeight - paddingSize;\n      \n      if (minRows !== undefined) {\n        let minHeight = singleRowHeight * minRows;\n        if (boxSizing === 'border-box') {\n          minHeight = minHeight + paddingSize + borderSize;\n        }\n        height = Math.max(minHeight, height);\n        result['minHeight'] = `${minHeight}px`;\n      }\n      \n      if (maxRows !== undefined) {\n        let maxHeight = singleRowHeight * maxRows;\n        if (boxSizing === 'border-box') {\n          maxHeight = maxHeight + paddingSize + borderSize;\n        }\n        if (height > maxHeight) {\n          height = maxHeight;\n          result['overflowY'] = 'auto';\n        }\n      }\n    }\n    \n    document.body.removeChild(tempTextarea);\n    \n    result['height'] = `${height}px`;\n    return result;\n  }\n\n  get placeholderText(): string {\n    return this.foundation.getPlaceholderText();\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focus.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.blur.emit(event);\n  }\n}\n","<div [ngClass]=\"inputClasses\">\n  <ng-container *ngIf=\"headTemplate; then headTemplate\"></ng-container>\n\n  <div class=\"mc-input-content\">\n    <ng-container *ngIf=\"prefixTemplate; then prefixTemplate\"></ng-container>\n\n    <textarea\n      #textarea\n      [(ngModel)]=\"inputValue\"\n      [placeholder]=\"placeholderText\"\n      [disabled]=\"disabled\"\n      [maxlength]=\"maxLength\"\n      class=\"mc-textarea\"\n      [ngClass]=\"{\n        'mc-textarea-simple': displayType === 'simple',\n        'mc-textarea-disabled': disabled\n      }\"\n      [ngStyle]=\"textareaStyle\"\n      [attr.aria-label]=\"'Input.ariaLabel' | translate\"\n      [attr.aria-disabled]=\"disabled\"\n      (input)=\"onInput()\"\n      (change)=\"onChange($event)\"\n      (compositionstart)=\"onCompositionStart()\"\n      (compositionend)=\"onCompositionEnd()\"\n      (keydown)=\"onKeydown($event)\"\n      (focus)=\"onFocus($event)\"\n      (blur)=\"onBlur($event)\"\n    ></textarea>\n    <ng-container *ngIf=\"suffixTemplate; then suffixTemplate\"></ng-container>\n\n    <ng-container *ngIf=\"displayType === 'simple'\">\n      <ng-container *ngIf=\"buttonTemplate; else defaultButton\">\n        <ng-container\n          *ngIf=\"buttonTemplate; then buttonTemplate\"\n        ></ng-container>\n      </ng-container>\n      <ng-template #defaultButton>\n        <mc-button\n          [disabled]=\"disabled || (!loading && !inputValue)\"\n          [loading]=\"loading\"\n          [inputValue]=\"inputValue\"\n          [sendBtnVariant]=\"sendBtnVariant\"\n          (submit)=\"onButtonSubmit($event)\"\n          (cancel)=\"onButtonCancel()\"\n          (change)=\"onButtonChange($event)\"\n        ></mc-button>\n      </ng-template>\n    </ng-container>\n  </div>\n\n  <div *ngIf=\"displayType === 'full'\" class=\"mc-input-foot\">\n    <div class=\"mc-input-foot-left\">\n      <ng-container *ngIf=\"extraTemplate; then extraTemplate\"></ng-container>\n      <span *ngIf=\"showCount\" id=\"mc-input-count\" class=\"mc-input-foot-count\">\n        {{ inputValue.length }}{{ !maxLength ? \"\" : \"/\" + maxLength }}\n      </span>\n    </div>\n\n    <ng-container *ngIf=\"buttonTemplate; else defaultFooterButton\">\n      <ng-container *ngIf=\"buttonTemplate; then buttonTemplate\"></ng-container>\n    </ng-container>\n    <ng-template #defaultFooterButton>\n      <mc-button\n        [disabled]=\"disabled || (!loading && !inputValue)\"\n        [loading]=\"loading\"\n        [inputValue]=\"inputValue\"\n        [sendBtnVariant]=\"sendBtnVariant\"\n        (submit)=\"onButtonSubmit($event)\"\n        (cancel)=\"onButtonCancel()\"\n        (change)=\"onButtonChange($event)\"\n      ></mc-button>\n    </ng-template>\n  </div>\n</div>\n"]}
|