@acorex/components 17.0.7 → 17.0.9
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/audio-wave/README.md +3 -0
- package/audio-wave/index.d.ts +3 -0
- package/audio-wave/lib/audio-wave.component.d.ts +51 -0
- package/audio-wave/lib/audio-wave.module.d.ts +10 -0
- package/audio-wave/lib/interfaces/audio-wave.interface.d.ts +15 -0
- package/chat/index.d.ts +1 -2
- package/chat/lib/chat-message/chat-message.component.d.ts +1 -1
- package/chat/lib/chat-messages/chat-message-text.component.d.ts +1 -1
- package/chat/lib/chat-messages/chat-messages-voice/chat-message-voice.component.d.ts +16 -0
- package/chat/lib/chat-view/chat-view.component.d.ts +2 -2
- package/chat/lib/chat.module.d.ts +13 -10
- package/chat/lib/chat.types.d.ts +6 -6
- package/data-pager/lib/data-pager.component.d.ts +1 -0
- package/data-table/lib/data-table/data-table.component.d.ts +24 -13
- package/esm2022/audio-wave/acorex-components-audio-wave.mjs +5 -0
- package/esm2022/audio-wave/index.mjs +4 -0
- package/esm2022/audio-wave/lib/audio-wave.component.mjs +199 -0
- package/esm2022/audio-wave/lib/audio-wave.module.mjs +20 -0
- package/esm2022/audio-wave/lib/interfaces/audio-wave.interface.mjs +2 -0
- package/esm2022/chat/index.mjs +2 -3
- package/esm2022/chat/lib/chat-message/chat-message.component.mjs +3 -3
- package/esm2022/chat/lib/chat-messages/chat-message-text.component.mjs +2 -2
- package/esm2022/chat/lib/chat-messages/chat-messages-voice/chat-message-voice.component.mjs +49 -0
- package/esm2022/chat/lib/chat-view/chat-view.component.mjs +2 -2
- package/esm2022/chat/lib/chat.module.mjs +18 -8
- package/esm2022/chat/lib/chat.types.mjs +1 -1
- package/esm2022/data-pager/lib/data-pager.component.mjs +19 -14
- package/esm2022/data-table/lib/data-table/data-table.component.mjs +83 -39
- package/esm2022/side-menu/lib/side-menu-item/side-menu-item.compoent.mjs +8 -8
- package/fesm2022/acorex-components-audio-wave.mjs +223 -0
- package/fesm2022/acorex-components-audio-wave.mjs.map +1 -0
- package/fesm2022/acorex-components-chat.mjs +65 -34
- package/fesm2022/acorex-components-chat.mjs.map +1 -1
- package/fesm2022/acorex-components-data-pager.mjs +18 -13
- package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
- package/fesm2022/acorex-components-data-table.mjs +82 -38
- package/fesm2022/acorex-components-data-table.mjs.map +1 -1
- package/fesm2022/acorex-components-side-menu.mjs +7 -7
- package/fesm2022/acorex-components-side-menu.mjs.map +1 -1
- package/package.json +7 -1
- package/side-menu/lib/side-menu-item/side-menu-item.compoent.d.ts +3 -4
- package/chat/lib/chat-messages/chat-message-audio.component.d.ts +0 -7
- package/chat/lib/chat-voice/chat-voice.component.d.ts +0 -6
- package/esm2022/chat/lib/chat-messages/chat-message-audio.component.mjs +0 -17
- package/esm2022/chat/lib/chat-voice/chat-voice.component.mjs +0 -12
@@ -0,0 +1,51 @@
|
|
1
|
+
import { ElementRef, InputSignal } from '@angular/core';
|
2
|
+
import WaveSurfer from 'wavesurfer.js';
|
3
|
+
import { AXAudioWaveChangeEvent, AXWaveConfig } from './interfaces/audio-wave.interface';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export declare class AXAudioWaveComponent {
|
6
|
+
protected div: ElementRef<HTMLDivElement>;
|
7
|
+
config: InputSignal<AXWaveConfig>;
|
8
|
+
onStatusChanged: import("@angular/core").OutputEmitterRef<AXAudioWaveChangeEvent>;
|
9
|
+
protected audio: WaveSurfer;
|
10
|
+
private ngZone;
|
11
|
+
constructor();
|
12
|
+
play(): Promise<any>;
|
13
|
+
pause(): void;
|
14
|
+
getDuration(): number;
|
15
|
+
getMediaElement(): HTMLMediaElement;
|
16
|
+
protected bindEvents(): void;
|
17
|
+
/** When audio starts loading */
|
18
|
+
protected handleLoad(): void;
|
19
|
+
/** During audio loading */
|
20
|
+
protected handleLoading(): void;
|
21
|
+
/** When the audio has been decoded */
|
22
|
+
protected handleDecode(): void;
|
23
|
+
/** When the audio is both decoded and can play */
|
24
|
+
protected handleReady(): void;
|
25
|
+
/** When all audio channel chunks of the waveform have drawn */
|
26
|
+
protected handleRedRawComplete(): void;
|
27
|
+
/** When the audio starts playing */
|
28
|
+
protected handlePlay(): void;
|
29
|
+
/** When the audio pauses */
|
30
|
+
protected handlePause(): void;
|
31
|
+
/** When the audio finishes playing */
|
32
|
+
protected handleFinish(): void;
|
33
|
+
/** On audio position change, fires continuously during playback */
|
34
|
+
protected handleTimeUpdate(): void;
|
35
|
+
/** When the user seeks to a new position */
|
36
|
+
protected handleSeeking(): void;
|
37
|
+
/** When the user interacts with the waveform (i.g. clicks or drags on it) */
|
38
|
+
protected handleInteraction(): void;
|
39
|
+
/** When the user clicks on the waveform */
|
40
|
+
protected handleClick(): void;
|
41
|
+
/** When the user drags the cursor */
|
42
|
+
protected handleDrag(): void;
|
43
|
+
/** When the waveform is scrolled (panned) */
|
44
|
+
protected handleScroll(): void;
|
45
|
+
/** When the zoom level changes */
|
46
|
+
protected handleZoom(): void;
|
47
|
+
/** Just before the waveform is destroyed so you can clean up your events */
|
48
|
+
protected handleDestroy(): void;
|
49
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXAudioWaveComponent, never>;
|
50
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXAudioWaveComponent, "ax-audio-wave", never, { "config": { "alias": "config"; "required": false; "isSignal": true; }; }, { "onStatusChanged": "onStatusChanged"; }, never, never, false, never>;
|
51
|
+
}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
import * as i0 from "@angular/core";
|
2
|
+
import * as i1 from "./audio-wave.component";
|
3
|
+
import * as i2 from "@angular/common";
|
4
|
+
import * as i3 from "@acorex/components/button";
|
5
|
+
import * as i4 from "@acorex/components/decorators";
|
6
|
+
export declare class AXAudioWaveModule {
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXAudioWaveModule, never>;
|
8
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<AXAudioWaveModule, [typeof i1.AXAudioWaveComponent], [typeof i2.CommonModule, typeof i3.AXButtonModule, typeof i4.AXDecoratorModule], [typeof i1.AXAudioWaveComponent]>;
|
9
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<AXAudioWaveModule>;
|
10
|
+
}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { AXEvent } from '@acorex/components/common';
|
2
|
+
export interface AXWaveConfig {
|
3
|
+
container?: HTMLElement;
|
4
|
+
waveColor?: string;
|
5
|
+
progressColor?: string;
|
6
|
+
url: string;
|
7
|
+
barWidth?: number;
|
8
|
+
barGap?: number;
|
9
|
+
barRadius?: number;
|
10
|
+
height?: number;
|
11
|
+
}
|
12
|
+
export interface AXAudioWaveChangeEvent extends AXEvent {
|
13
|
+
status: 'load' | 'loading' | 'decode' | 'ready' | 'redrawcomplete' | 'play' | 'pause' | 'finish' | 'timeupdate' | 'seeking' | 'interaction' | 'click' | 'drag' | 'scroll' | 'zoom' | 'destroy';
|
14
|
+
data: null | any;
|
15
|
+
}
|
package/chat/index.d.ts
CHANGED
@@ -2,12 +2,11 @@ export * from './lib/chat-input/chat-input.component';
|
|
2
2
|
export * from './lib/chat-input/chat-input.interface';
|
3
3
|
export * from './lib/chat-message/chat-message.component';
|
4
4
|
export * from './lib/chat-view/chat-view.component';
|
5
|
-
export * from './lib/chat-voice/chat-voice.component';
|
6
5
|
export * from './lib/chat.module';
|
7
6
|
export * from './lib/chat.types';
|
8
7
|
export * from './lib/classes/events.interface';
|
9
8
|
export * from './lib/services/chat-message-type-registry.service';
|
10
9
|
export * from './lib/services/chat.service';
|
11
10
|
export * from './lib/services/recording.service';
|
12
|
-
export * from './lib/chat-messages/chat-message-audio.component';
|
13
11
|
export * from './lib/chat-messages/chat-message-text.component';
|
12
|
+
export * from './lib/chat-messages/chat-messages-voice/chat-message-voice.component';
|
@@ -3,7 +3,7 @@ import { AXChatMessage } from '../chat.types';
|
|
3
3
|
import { AXChatMessageTypeRegistryService } from '../services/chat-message-type-registry.service';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
export declare class AXChatMessageComponent extends MXBaseComponent {
|
6
|
-
chatMessage: import("@angular/core").InputSignal<AXChatMessage
|
6
|
+
chatMessage: import("@angular/core").InputSignal<AXChatMessage<any>>;
|
7
7
|
protected get isOwn(): boolean;
|
8
8
|
protected registryService: AXChatMessageTypeRegistryService;
|
9
9
|
get __hostClass(): string;
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { AXChatMessageBaseComponent } from '../chat.types';
|
2
2
|
import * as i0 from "@angular/core";
|
3
|
-
export declare class AXChatTextMessageComponent extends AXChatMessageBaseComponent {
|
3
|
+
export declare class AXChatTextMessageComponent extends AXChatMessageBaseComponent<string> {
|
4
4
|
protected _text: import("@angular/core").WritableSignal<string>;
|
5
5
|
ngOnInit(): void;
|
6
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXChatTextMessageComponent, never>;
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { AXAudioWaveChangeEvent, AXAudioWaveComponent, AXWaveConfig } from '@acorex/components/audio-wave';
|
2
|
+
import { WritableSignal } from '@angular/core';
|
3
|
+
import { AXChatMessageBaseComponent } from '../../chat.types';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export declare class AXChatAudioMessageComponent extends AXChatMessageBaseComponent<string> {
|
6
|
+
audio: AXAudioWaveComponent;
|
7
|
+
config: AXWaveConfig;
|
8
|
+
audioState: WritableSignal<'playing' | 'paused' | 'loading' | 'ready'>;
|
9
|
+
audioProgress: WritableSignal<number>;
|
10
|
+
constructor();
|
11
|
+
handlePauseClick(): void;
|
12
|
+
handlePlayClick(): void;
|
13
|
+
handleOnStatusChanged(event: AXAudioWaveChangeEvent): void;
|
14
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXChatAudioMessageComponent, never>;
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXChatAudioMessageComponent, "ax-chat-message-audio", never, { "message": { "alias": "message"; "required": false; }; }, {}, never, never, false, never>;
|
16
|
+
}
|
@@ -3,8 +3,8 @@ import { WritableSignal } from '@angular/core';
|
|
3
3
|
import { AXChatMessage } from '../chat.types';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
export declare class AXChatViewComponent extends MXBaseComponent {
|
6
|
-
set chats(items: AXChatMessage[]);
|
7
|
-
protected _chats: WritableSignal<AXChatMessage[]>;
|
6
|
+
set chats(items: AXChatMessage<any>[]);
|
7
|
+
protected _chats: WritableSignal<AXChatMessage<any>[]>;
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXChatViewComponent, never>;
|
9
9
|
static ɵcmp: i0.ɵɵComponentDeclaration<AXChatViewComponent, "ax-chat-view", never, { "chats": { "alias": "chats"; "required": false; }; }, {}, never, never, false, never>;
|
10
10
|
}
|
@@ -4,15 +4,18 @@ import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "./chat-view/chat-view.component";
|
5
5
|
import * as i2 from "./chat-input/chat-input.component";
|
6
6
|
import * as i3 from "./chat-message/chat-message.component";
|
7
|
-
import * as i4 from "./chat-
|
8
|
-
import * as i5 from "
|
9
|
-
import * as i6 from "@angular/
|
10
|
-
import * as i7 from "@
|
11
|
-
import * as i8 from "@acorex/components/
|
12
|
-
import * as i9 from "@acorex/components/
|
13
|
-
import * as i10 from "@acorex/
|
14
|
-
import * as i11 from "@acorex/
|
15
|
-
import * as i12 from "@acorex/
|
7
|
+
import * as i4 from "./chat-messages/chat-message-text.component";
|
8
|
+
import * as i5 from "./chat-messages/chat-messages-voice/chat-message-voice.component";
|
9
|
+
import * as i6 from "@angular/common";
|
10
|
+
import * as i7 from "@angular/forms";
|
11
|
+
import * as i8 from "@acorex/components/common";
|
12
|
+
import * as i9 from "@acorex/components/button";
|
13
|
+
import * as i10 from "@acorex/components/decorators";
|
14
|
+
import * as i11 from "@acorex/core/translation";
|
15
|
+
import * as i12 from "@acorex/components/dropdown";
|
16
|
+
import * as i13 from "@acorex/core/format";
|
17
|
+
import * as i14 from "@acorex/components/audio-wave";
|
18
|
+
import * as i15 from "@acorex/components/circular-progress";
|
16
19
|
export interface AXChatModuleConfig {
|
17
20
|
types: AXChatMessageType[];
|
18
21
|
}
|
@@ -24,6 +27,6 @@ export declare class AXChatModule {
|
|
24
27
|
*/
|
25
28
|
constructor(instances: any[]);
|
26
29
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXChatModule, [{ optional: true; }]>;
|
27
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<AXChatModule, [typeof i1.AXChatViewComponent, typeof i2.AXChatInputComponent, typeof i3.AXChatMessageComponent, typeof i4.
|
30
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<AXChatModule, [typeof i1.AXChatViewComponent, typeof i2.AXChatInputComponent, typeof i3.AXChatMessageComponent, typeof i4.AXChatTextMessageComponent, typeof i5.AXChatAudioMessageComponent], [typeof i6.CommonModule, typeof i7.FormsModule, typeof i6.AsyncPipe, typeof i8.AXRippleDirective, typeof i9.AXButtonModule, typeof i10.AXDecoratorModule, typeof i11.AXTranslationModule, typeof i12.AXDropdownModule, typeof i13.AXFormatModule, typeof i14.AXAudioWaveModule, typeof i15.AXCircularProgressModule], [typeof i1.AXChatViewComponent, typeof i2.AXChatInputComponent, typeof i3.AXChatMessageComponent, typeof i4.AXChatTextMessageComponent, typeof i5.AXChatAudioMessageComponent]>;
|
28
31
|
static ɵinj: i0.ɵɵInjectorDeclaration<AXChatModule>;
|
29
32
|
}
|
package/chat/lib/chat.types.d.ts
CHANGED
@@ -4,18 +4,18 @@ export interface AXChatMessageType {
|
|
4
4
|
name: string;
|
5
5
|
component: Type<any>;
|
6
6
|
}
|
7
|
-
export interface AXChatMessage {
|
7
|
+
export interface AXChatMessage<T> {
|
8
8
|
id: string;
|
9
9
|
type: string;
|
10
10
|
sendTime: Date;
|
11
11
|
deliverTime?: Date;
|
12
12
|
readTime?: Date;
|
13
13
|
replyTo?: string;
|
14
|
-
content:
|
14
|
+
content: T;
|
15
15
|
fromId?: string;
|
16
16
|
}
|
17
|
-
export declare class AXChatMessageBaseComponent {
|
18
|
-
message: AXChatMessage
|
19
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<AXChatMessageBaseComponent
|
20
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<AXChatMessageBaseComponent
|
17
|
+
export declare class AXChatMessageBaseComponent<T> {
|
18
|
+
message: AXChatMessage<T>;
|
19
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXChatMessageBaseComponent<any>, never>;
|
20
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<AXChatMessageBaseComponent<any>>;
|
21
21
|
}
|
@@ -22,6 +22,7 @@ export declare class AXDataPagerComponent extends MXValueComponent<number> {
|
|
22
22
|
ngAfterViewInit(): void;
|
23
23
|
protected internalValueChanged(value: any): void;
|
24
24
|
protected internalGetValue(value: any): number;
|
25
|
+
private previousDisplayInfo;
|
25
26
|
get displayInfo(): AXDataPagerData;
|
26
27
|
private _emitChangedEvent;
|
27
28
|
goNextPage(): void;
|
@@ -6,15 +6,24 @@ import { AXDataTableColumnComponent } from '../columns/data-table-column';
|
|
6
6
|
import * as i0 from "@angular/core";
|
7
7
|
export declare class AXDataTableComponent extends AXBaseDataTable implements OnInit, AfterViewInit {
|
8
8
|
private _unsubscriber;
|
9
|
-
|
9
|
+
private _zone;
|
10
10
|
protected displayedRows: WritableSignal<any[]>;
|
11
11
|
protected page: WritableSignal<number>;
|
12
12
|
protected pageSize: WritableSignal<number>;
|
13
13
|
protected columnsList: WritableSignal<any[]>;
|
14
|
-
protected
|
15
|
-
|
16
|
-
|
17
|
-
|
14
|
+
protected isLoading: WritableSignal<boolean>;
|
15
|
+
protected resizeColumnProp: {
|
16
|
+
startX: number;
|
17
|
+
startWidth: number;
|
18
|
+
columnIndex: number;
|
19
|
+
newColumnWidth: number;
|
20
|
+
thElement: any;
|
21
|
+
};
|
22
|
+
protected hasItems: boolean;
|
23
|
+
protected totalRows: number;
|
24
|
+
protected currentPage: number;
|
25
|
+
protected totalPages: number;
|
26
|
+
protected startRowIndex: number;
|
18
27
|
rowTemplate?: TemplateRef<unknown>;
|
19
28
|
emptyTemplate?: TemplateRef<unknown>;
|
20
29
|
showHeader: boolean;
|
@@ -31,17 +40,15 @@ export declare class AXDataTableComponent extends AXBaseDataTable implements OnI
|
|
31
40
|
private _focusedRow;
|
32
41
|
get focusedRow(): unknown;
|
33
42
|
set focusedRow(v: unknown);
|
34
|
-
protected isLoading: WritableSignal<boolean>;
|
35
|
-
protected hasItems: boolean;
|
36
|
-
protected totalRows: number;
|
37
|
-
protected currentPage: number;
|
38
|
-
protected totalPages: number;
|
39
|
-
protected startRowIndex: number;
|
40
|
-
private lastIndex;
|
41
43
|
focusedRowChange: EventEmitter<unknown>;
|
42
44
|
onRowClick: EventEmitter<AXDataTableRowClick>;
|
43
45
|
onRowDbClick: EventEmitter<AXDataTableRowDbClick>;
|
46
|
+
onColumnsOrderChanged: EventEmitter<AXColumnsOrderChangedEvent>;
|
44
47
|
private clickSubject;
|
48
|
+
protected columns: QueryList<AXDataTableColumnComponent>;
|
49
|
+
ngOnInit(): void;
|
50
|
+
ngAfterViewInit(): void;
|
51
|
+
protected drop(event: CdkDragDrop<any, any, any>): void;
|
45
52
|
protected handleRowClick(event: MouseEvent, item: unknown): void;
|
46
53
|
private handleRowSingleClick;
|
47
54
|
protected onPageChanged(event: AXDataPagerChangedEvent): void;
|
@@ -49,7 +56,11 @@ export declare class AXDataTableComponent extends AXBaseDataTable implements OnI
|
|
49
56
|
handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent): void;
|
50
57
|
protected getSort(column: AXDataTableColumnComponent): string | undefined;
|
51
58
|
refresh(): void;
|
59
|
+
protected onResizeColumnStart(event: MouseEvent, columnIndex: number): void;
|
60
|
+
private onResizeColumnMove;
|
61
|
+
private onResizeColumnEnd;
|
62
|
+
private resetResizingProcess;
|
52
63
|
private calculateStickyColumnsPositions;
|
53
64
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTableComponent, never>;
|
54
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTableComponent, "ax-data-table", never, { "dataSource": { "alias": "dataSource"; "required": false; }; "rowTemplate": { "alias": "rowTemplate"; "required": false; }; "emptyTemplate": { "alias": "emptyTemplate"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "fixedHeader": { "alias": "fixedHeader"; "required": false; }; "itemHeight": { "alias": "itemHeight"; "required": false; }; "allowReordering": { "alias": "allowReordering"; "required": false; }; "paging": { "alias": "paging"; "required": false; }; "fetchDataMode": { "alias": "fetchDataMode"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "focusedRow": { "alias": "focusedRow"; "required": false; }; }, { "
|
65
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTableComponent, "ax-data-table", never, { "dataSource": { "alias": "dataSource"; "required": false; }; "rowTemplate": { "alias": "rowTemplate"; "required": false; }; "emptyTemplate": { "alias": "emptyTemplate"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "fixedHeader": { "alias": "fixedHeader"; "required": false; }; "itemHeight": { "alias": "itemHeight"; "required": false; }; "allowReordering": { "alias": "allowReordering"; "required": false; }; "paging": { "alias": "paging"; "required": false; }; "fetchDataMode": { "alias": "fetchDataMode"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "focusedRow": { "alias": "focusedRow"; "required": false; }; }, { "focusedRowChange": "focusedRowChange"; "onRowClick": "onRowClick"; "onRowDbClick": "onRowDbClick"; "onColumnsOrderChanged": "onColumnsOrderChanged"; }, ["columns"], ["ax-header", "ax-footer"], false, never>;
|
55
66
|
}
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/**
|
2
|
+
* Generated bundle index. Do not edit.
|
3
|
+
*/
|
4
|
+
export * from './index';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNvbXBvbmVudHMtYXVkaW8td2F2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9hdWRpby13YXZlL3NyYy9hY29yZXgtY29tcG9uZW50cy1hdWRpby13YXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
@@ -0,0 +1,4 @@
|
|
1
|
+
export * from './lib/audio-wave.component';
|
2
|
+
export * from './lib/audio-wave.module';
|
3
|
+
export * from './lib/interfaces/audio-wave.interface';
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvYXVkaW8td2F2ZS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsdUNBQXVDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9hdWRpby13YXZlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdWRpby13YXZlLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnRlcmZhY2VzL2F1ZGlvLXdhdmUuaW50ZXJmYWNlJztcbiJdfQ==
|
@@ -0,0 +1,199 @@
|
|
1
|
+
import { Component, ElementRef, NgZone, ViewChild, ViewEncapsulation, afterNextRender, inject, input, output, } from '@angular/core';
|
2
|
+
import WaveSurfer from 'wavesurfer.js';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export class AXAudioWaveComponent {
|
5
|
+
constructor() {
|
6
|
+
this.config = input();
|
7
|
+
this.onStatusChanged = output();
|
8
|
+
this.ngZone = inject(NgZone);
|
9
|
+
afterNextRender(() => {
|
10
|
+
const primary500 = getComputedStyle(document.body).getPropertyValue('--ax-color-primary-500');
|
11
|
+
const primary700 = getComputedStyle(document.body).getPropertyValue('--ax-color-primary-700');
|
12
|
+
this.audio = WaveSurfer.create({
|
13
|
+
container: this.div.nativeElement,
|
14
|
+
waveColor: this.config()?.waveColor || `rgba(${primary500})`,
|
15
|
+
progressColor: this.config()?.progressColor || `rgba(${primary700})`,
|
16
|
+
url: this.config()?.url || '',
|
17
|
+
barWidth: this.config()?.barWidth || 2,
|
18
|
+
barRadius: this.config()?.barRadius || 2,
|
19
|
+
barGap: this.config()?.barGap || 1,
|
20
|
+
height: this.config()?.height || 18,
|
21
|
+
});
|
22
|
+
this.audio.load(this.config()?.url);
|
23
|
+
this.bindEvents();
|
24
|
+
});
|
25
|
+
}
|
26
|
+
play() {
|
27
|
+
return this.audio.play();
|
28
|
+
}
|
29
|
+
pause() {
|
30
|
+
this.audio.pause();
|
31
|
+
}
|
32
|
+
getDuration() {
|
33
|
+
return this.audio?.getDuration();
|
34
|
+
}
|
35
|
+
getMediaElement() {
|
36
|
+
return this.audio?.getMediaElement();
|
37
|
+
}
|
38
|
+
bindEvents() {
|
39
|
+
this.handleLoad();
|
40
|
+
this.handleLoading();
|
41
|
+
this.handleDecode();
|
42
|
+
this.handleReady();
|
43
|
+
this.handleRedRawComplete();
|
44
|
+
this.handlePlay();
|
45
|
+
this.handlePause();
|
46
|
+
this.handleFinish();
|
47
|
+
this.handleTimeUpdate();
|
48
|
+
this.handleSeeking();
|
49
|
+
this.handleInteraction();
|
50
|
+
this.handleClick();
|
51
|
+
this.handleDrag();
|
52
|
+
this.handleScroll();
|
53
|
+
this.handleZoom();
|
54
|
+
this.handleDestroy();
|
55
|
+
}
|
56
|
+
/** When audio starts loading */
|
57
|
+
handleLoad() {
|
58
|
+
this.audio.on('load', (url) => {
|
59
|
+
this.ngZone.run(() => {
|
60
|
+
this.onStatusChanged.emit({ component: this, data: { url }, status: 'load', isUserInteraction: false });
|
61
|
+
});
|
62
|
+
});
|
63
|
+
}
|
64
|
+
/** During audio loading */
|
65
|
+
handleLoading() {
|
66
|
+
this.audio.on('loading', (percent) => {
|
67
|
+
this.ngZone.run(() => {
|
68
|
+
this.onStatusChanged.emit({ component: this, data: { percent }, status: 'loading', isUserInteraction: false });
|
69
|
+
});
|
70
|
+
});
|
71
|
+
}
|
72
|
+
/** When the audio has been decoded */
|
73
|
+
handleDecode() {
|
74
|
+
this.audio.on('decode', (duration) => {
|
75
|
+
this.ngZone.run(() => {
|
76
|
+
this.onStatusChanged.emit({ component: this, data: { duration }, status: 'decode', isUserInteraction: false });
|
77
|
+
});
|
78
|
+
});
|
79
|
+
}
|
80
|
+
/** When the audio is both decoded and can play */
|
81
|
+
handleReady() {
|
82
|
+
this.audio.on('ready', (duration) => {
|
83
|
+
this.ngZone.run(() => {
|
84
|
+
this.onStatusChanged.emit({ component: this, data: { duration }, status: 'ready', isUserInteraction: false });
|
85
|
+
});
|
86
|
+
});
|
87
|
+
}
|
88
|
+
/** When all audio channel chunks of the waveform have drawn */
|
89
|
+
handleRedRawComplete() {
|
90
|
+
this.audio.on('redrawcomplete', () => {
|
91
|
+
this.ngZone.run(() => {
|
92
|
+
this.onStatusChanged.emit({ component: this, data: null, status: 'redrawcomplete', isUserInteraction: false });
|
93
|
+
});
|
94
|
+
});
|
95
|
+
}
|
96
|
+
/** When the audio starts playing */
|
97
|
+
handlePlay() {
|
98
|
+
this.audio.on('play', () => {
|
99
|
+
this.ngZone.run(() => {
|
100
|
+
this.onStatusChanged.emit({ component: this, data: null, status: 'play', isUserInteraction: false });
|
101
|
+
});
|
102
|
+
});
|
103
|
+
}
|
104
|
+
/** When the audio pauses */
|
105
|
+
handlePause() {
|
106
|
+
this.audio.on('pause', () => {
|
107
|
+
this.ngZone.run(() => {
|
108
|
+
this.onStatusChanged.emit({ component: this, data: null, status: 'pause', isUserInteraction: false });
|
109
|
+
});
|
110
|
+
});
|
111
|
+
}
|
112
|
+
/** When the audio finishes playing */
|
113
|
+
handleFinish() {
|
114
|
+
this.audio.on('finish', () => {
|
115
|
+
this.ngZone.run(() => {
|
116
|
+
this.onStatusChanged.emit({ component: this, data: null, status: 'finish', isUserInteraction: false });
|
117
|
+
});
|
118
|
+
});
|
119
|
+
}
|
120
|
+
/** On audio position change, fires continuously during playback */
|
121
|
+
handleTimeUpdate() {
|
122
|
+
this.audio.on('timeupdate', (currentTime) => {
|
123
|
+
this.ngZone.run(() => {
|
124
|
+
this.onStatusChanged.emit({ component: this, data: { currentTime }, status: 'timeupdate', isUserInteraction: false });
|
125
|
+
});
|
126
|
+
});
|
127
|
+
}
|
128
|
+
/** When the user seeks to a new position */
|
129
|
+
handleSeeking() {
|
130
|
+
this.audio.on('seeking', (currentTime) => {
|
131
|
+
this.ngZone.run(() => {
|
132
|
+
this.onStatusChanged.emit({ component: this, data: { currentTime }, status: 'seeking', isUserInteraction: false });
|
133
|
+
});
|
134
|
+
});
|
135
|
+
}
|
136
|
+
/** When the user interacts with the waveform (i.g. clicks or drags on it) */
|
137
|
+
handleInteraction() {
|
138
|
+
this.audio.on('interaction', (newTime) => {
|
139
|
+
this.ngZone.run(() => {
|
140
|
+
this.onStatusChanged.emit({ component: this, data: { newTime }, status: 'interaction', isUserInteraction: false });
|
141
|
+
});
|
142
|
+
});
|
143
|
+
}
|
144
|
+
/** When the user clicks on the waveform */
|
145
|
+
handleClick() {
|
146
|
+
this.audio.on('click', (relativeX) => {
|
147
|
+
this.ngZone.run(() => {
|
148
|
+
this.onStatusChanged.emit({ component: this, data: { relativeX }, status: 'click', isUserInteraction: false });
|
149
|
+
});
|
150
|
+
});
|
151
|
+
}
|
152
|
+
/** When the user drags the cursor */
|
153
|
+
handleDrag() {
|
154
|
+
this.audio.on('drag', (relativeX) => {
|
155
|
+
this.ngZone.run(() => {
|
156
|
+
this.onStatusChanged.emit({ component: this, data: { relativeX }, status: 'drag', isUserInteraction: false });
|
157
|
+
});
|
158
|
+
});
|
159
|
+
}
|
160
|
+
/** When the waveform is scrolled (panned) */
|
161
|
+
handleScroll() {
|
162
|
+
this.audio.on('scroll', (visibleStartTime, visibleEndTime) => {
|
163
|
+
this.ngZone.run(() => {
|
164
|
+
this.onStatusChanged.emit({
|
165
|
+
component: this,
|
166
|
+
data: { visibleStartTime, visibleEndTime },
|
167
|
+
status: 'scroll',
|
168
|
+
isUserInteraction: false,
|
169
|
+
});
|
170
|
+
});
|
171
|
+
});
|
172
|
+
}
|
173
|
+
/** When the zoom level changes */
|
174
|
+
handleZoom() {
|
175
|
+
this.audio.on('zoom', (minPxPerSec) => {
|
176
|
+
this.ngZone.run(() => {
|
177
|
+
this.onStatusChanged.emit({ component: this, data: { minPxPerSec }, status: 'zoom', isUserInteraction: false });
|
178
|
+
});
|
179
|
+
});
|
180
|
+
}
|
181
|
+
/** Just before the waveform is destroyed so you can clean up your events */
|
182
|
+
handleDestroy() {
|
183
|
+
this.audio.on('destroy', () => {
|
184
|
+
this.ngZone.run(() => {
|
185
|
+
this.onStatusChanged.emit({ component: this, data: null, status: 'destroy', isUserInteraction: false });
|
186
|
+
});
|
187
|
+
});
|
188
|
+
}
|
189
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXAudioWaveComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
190
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.2", type: AXAudioWaveComponent, selector: "ax-audio-wave", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onStatusChanged: "onStatusChanged" }, viewQueries: [{ propertyName: "div", first: true, predicate: ["d"], descendants: true }], ngImport: i0, template: "<div class=\"ax-audio-wave\" #d></div>", styles: ["ax-audio-wave{display:block;width:100%;flex:1}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
191
|
+
}
|
192
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXAudioWaveComponent, decorators: [{
|
193
|
+
type: Component,
|
194
|
+
args: [{ selector: 'ax-audio-wave', encapsulation: ViewEncapsulation.None, template: "<div class=\"ax-audio-wave\" #d></div>", styles: ["ax-audio-wave{display:block;width:100%;flex:1}\n"] }]
|
195
|
+
}], ctorParameters: () => [], propDecorators: { div: [{
|
196
|
+
type: ViewChild,
|
197
|
+
args: ['d']
|
198
|
+
}] } });
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio-wave.component.js","sourceRoot":"","sources":["../../../../../../libs/components/audio-wave/src/lib/audio-wave.component.ts","../../../../../../libs/components/audio-wave/src/lib/audio-wave.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  InputSignal,\n  NgZone,\n  ViewChild,\n  ViewEncapsulation,\n  afterNextRender,\n  inject,\n  input,\n  output,\n} from '@angular/core';\nimport WaveSurfer from 'wavesurfer.js';\nimport { AXAudioWaveChangeEvent, AXWaveConfig } from './interfaces/audio-wave.interface';\n\n@Component({\n  selector: 'ax-audio-wave',\n  templateUrl: './audio-wave.component.html',\n  styleUrls: ['./audio-wave.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AXAudioWaveComponent {\n  @ViewChild('d') protected div: ElementRef<HTMLDivElement>;\n  config: InputSignal<AXWaveConfig> = input<AXWaveConfig>();\n\n  onStatusChanged = output<AXAudioWaveChangeEvent>();\n\n  protected audio: WaveSurfer;\n  private ngZone = inject(NgZone);\n\n  constructor() {\n    afterNextRender(() => {\n      const primary500 = getComputedStyle(document.body).getPropertyValue('--ax-color-primary-500');\n      const primary700 = getComputedStyle(document.body).getPropertyValue('--ax-color-primary-700');\n\n      this.audio = WaveSurfer.create({\n        container: this.div.nativeElement,\n        waveColor: this.config()?.waveColor || `rgba(${primary500})`,\n        progressColor: this.config()?.progressColor || `rgba(${primary700})`,\n        url: this.config()?.url || '',\n        barWidth: this.config()?.barWidth || 2,\n        barRadius: this.config()?.barRadius || 2,\n        barGap: this.config()?.barGap || 1,\n        height: this.config()?.height || 18,\n      });\n      this.audio.load(this.config()?.url);\n      this.bindEvents();\n    });\n  }\n\n  play(): Promise<any> {\n    return this.audio.play();\n  }\n\n  pause(): void {\n    this.audio.pause();\n  }\n\n  getDuration() {\n    return this.audio?.getDuration();\n  }\n\n  getMediaElement() {\n    return this.audio?.getMediaElement();\n  }\n\n  protected bindEvents() {\n    this.handleLoad();\n    this.handleLoading();\n    this.handleDecode();\n    this.handleReady();\n    this.handleRedRawComplete();\n    this.handlePlay();\n    this.handlePause();\n    this.handleFinish();\n    this.handleTimeUpdate();\n    this.handleSeeking();\n    this.handleInteraction();\n    this.handleClick();\n    this.handleDrag();\n    this.handleScroll();\n    this.handleZoom();\n    this.handleDestroy();\n  }\n  /** When audio starts loading */\n  protected handleLoad() {\n    this.audio.on('load', (url) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { url }, status: 'load', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** During audio loading */\n  protected handleLoading() {\n    this.audio.on('loading', (percent) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { percent }, status: 'loading', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the audio has been decoded */\n  protected handleDecode() {\n    this.audio.on('decode', (duration) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { duration }, status: 'decode', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the audio is both decoded and can play */\n  protected handleReady() {\n    this.audio.on('ready', (duration) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { duration }, status: 'ready', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When all audio channel chunks of the waveform have drawn */\n  protected handleRedRawComplete() {\n    this.audio.on('redrawcomplete', () => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: null, status: 'redrawcomplete', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the audio starts playing */\n  protected handlePlay() {\n    this.audio.on('play', () => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: null, status: 'play', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the audio pauses */\n  protected handlePause() {\n    this.audio.on('pause', () => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: null, status: 'pause', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the audio finishes playing */\n  protected handleFinish() {\n    this.audio.on('finish', () => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: null, status: 'finish', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** On audio position change, fires continuously during playback */\n  protected handleTimeUpdate() {\n    this.audio.on('timeupdate', (currentTime) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { currentTime }, status: 'timeupdate', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the user seeks to a new position */\n  protected handleSeeking() {\n    this.audio.on('seeking', (currentTime) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { currentTime }, status: 'seeking', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the user interacts with the waveform (i.g. clicks or drags on it) */\n  protected handleInteraction() {\n    this.audio.on('interaction', (newTime) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { newTime }, status: 'interaction', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the user clicks on the waveform */\n  protected handleClick() {\n    this.audio.on('click', (relativeX) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { relativeX }, status: 'click', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the user drags the cursor */\n  protected handleDrag() {\n    this.audio.on('drag', (relativeX) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { relativeX }, status: 'drag', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** When the waveform is scrolled (panned) */\n  protected handleScroll() {\n    this.audio.on('scroll', (visibleStartTime, visibleEndTime) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({\n          component: this,\n          data: { visibleStartTime, visibleEndTime },\n          status: 'scroll',\n          isUserInteraction: false,\n        });\n      });\n    });\n  }\n\n  /** When the zoom level changes */\n  protected handleZoom() {\n    this.audio.on('zoom', (minPxPerSec) => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: { minPxPerSec }, status: 'zoom', isUserInteraction: false });\n      });\n    });\n  }\n\n  /** Just before the waveform is destroyed so you can clean up your events */\n  protected handleDestroy() {\n    this.audio.on('destroy', () => {\n      this.ngZone.run(() => {\n        this.onStatusChanged.emit({ component: this, data: null, status: 'destroy', isUserInteraction: false });\n      });\n    });\n  }\n}\n","<div class=\"ax-audio-wave\" #d></div>"]}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { AXButtonModule } from '@acorex/components/button';
|
2
|
+
import { AXDecoratorModule } from '@acorex/components/decorators';
|
3
|
+
import { CommonModule } from '@angular/common';
|
4
|
+
import { NgModule } from '@angular/core';
|
5
|
+
import { AXAudioWaveComponent } from './audio-wave.component';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
export class AXAudioWaveModule {
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXAudioWaveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
9
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.2", ngImport: i0, type: AXAudioWaveModule, declarations: [AXAudioWaveComponent], imports: [CommonModule, AXButtonModule, AXDecoratorModule], exports: [AXAudioWaveComponent] }); }
|
10
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXAudioWaveModule, imports: [CommonModule, AXButtonModule, AXDecoratorModule] }); }
|
11
|
+
}
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXAudioWaveModule, decorators: [{
|
13
|
+
type: NgModule,
|
14
|
+
args: [{
|
15
|
+
declarations: [AXAudioWaveComponent],
|
16
|
+
imports: [CommonModule, AXButtonModule, AXDecoratorModule],
|
17
|
+
exports: [AXAudioWaveComponent],
|
18
|
+
}]
|
19
|
+
}] });
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaW8td2F2ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvYXVkaW8td2F2ZS9zcmMvbGliL2F1ZGlvLXdhdmUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFPOUQsTUFBTSxPQUFPLGlCQUFpQjs4R0FBakIsaUJBQWlCOytHQUFqQixpQkFBaUIsaUJBSmIsb0JBQW9CLGFBQ3pCLFlBQVksRUFBRSxjQUFjLEVBQUUsaUJBQWlCLGFBQy9DLG9CQUFvQjsrR0FFbkIsaUJBQWlCLFlBSGxCLFlBQVksRUFBRSxjQUFjLEVBQUUsaUJBQWlCOzsyRkFHOUMsaUJBQWlCO2tCQUw3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG9CQUFvQixDQUFDO29CQUNwQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixDQUFDO29CQUMxRCxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHsgQVhEZWNvcmF0b3JNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvZGVjb3JhdG9ycyc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYQXVkaW9XYXZlQ29tcG9uZW50IH0gZnJvbSAnLi9hdWRpby13YXZlLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0FYQXVkaW9XYXZlQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQVhCdXR0b25Nb2R1bGUsIEFYRGVjb3JhdG9yTW9kdWxlXSxcbiAgZXhwb3J0czogW0FYQXVkaW9XYXZlQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgQVhBdWRpb1dhdmVNb2R1bGUge31cbiJdfQ==
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaW8td2F2ZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvYXVkaW8td2F2ZS9zcmMvbGliL2ludGVyZmFjZXMvYXVkaW8td2F2ZS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYRXZlbnQgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBBWFdhdmVDb25maWcge1xuICBjb250YWluZXI/OiBIVE1MRWxlbWVudDtcbiAgd2F2ZUNvbG9yPzogc3RyaW5nO1xuICBwcm9ncmVzc0NvbG9yPzogc3RyaW5nO1xuICB1cmw6IHN0cmluZztcbiAgYmFyV2lkdGg/OiBudW1iZXI7XG4gIGJhckdhcD86IG51bWJlcjtcbiAgYmFyUmFkaXVzPzogbnVtYmVyO1xuICBoZWlnaHQ/OiBudW1iZXI7XG59XG5leHBvcnQgaW50ZXJmYWNlIEFYQXVkaW9XYXZlQ2hhbmdlRXZlbnQgZXh0ZW5kcyBBWEV2ZW50IHtcbiAgc3RhdHVzOlxuICAgIHwgJ2xvYWQnXG4gICAgfCAnbG9hZGluZydcbiAgICB8ICdkZWNvZGUnXG4gICAgfCAncmVhZHknXG4gICAgfCAncmVkcmF3Y29tcGxldGUnXG4gICAgfCAncGxheSdcbiAgICB8ICdwYXVzZSdcbiAgICB8ICdmaW5pc2gnXG4gICAgfCAndGltZXVwZGF0ZSdcbiAgICB8ICdzZWVraW5nJ1xuICAgIHwgJ2ludGVyYWN0aW9uJ1xuICAgIHwgJ2NsaWNrJ1xuICAgIHwgJ2RyYWcnXG4gICAgfCAnc2Nyb2xsJ1xuICAgIHwgJ3pvb20nXG4gICAgfCAnZGVzdHJveSc7XG4gIGRhdGE6IG51bGwgfCBhbnk7XG59XG4iXX0=
|
package/esm2022/chat/index.mjs
CHANGED
@@ -2,7 +2,6 @@ export * from './lib/chat-input/chat-input.component';
|
|
2
2
|
export * from './lib/chat-input/chat-input.interface';
|
3
3
|
export * from './lib/chat-message/chat-message.component';
|
4
4
|
export * from './lib/chat-view/chat-view.component';
|
5
|
-
export * from './lib/chat-voice/chat-voice.component';
|
6
5
|
export * from './lib/chat.module';
|
7
6
|
export * from './lib/chat.types';
|
8
7
|
export * from './lib/classes/events.interface';
|
@@ -10,6 +9,6 @@ export * from './lib/services/chat-message-type-registry.service';
|
|
10
9
|
export * from './lib/services/chat.service';
|
11
10
|
export * from './lib/services/recording.service';
|
12
11
|
//
|
13
|
-
export * from './lib/chat-messages/chat-message-audio.component';
|
14
12
|
export * from './lib/chat-messages/chat-message-text.component';
|
15
|
-
|
13
|
+
export * from './lib/chat-messages/chat-messages-voice/chat-message-voice.component';
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY2hhdC9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxFQUFFO0FBQ0YsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHNFQUFzRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhdC1pbnB1dC9jaGF0LWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGF0LWlucHV0L2NoYXQtaW5wdXQuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXQtbWVzc2FnZS9jaGF0LW1lc3NhZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXQtdmlldy9jaGF0LXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYXQudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xhc3Nlcy9ldmVudHMuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL2NoYXQtbWVzc2FnZS10eXBlLXJlZ2lzdHJ5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY2hhdC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3JlY29yZGluZy5zZXJ2aWNlJztcbi8vXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGF0LW1lc3NhZ2VzL2NoYXQtbWVzc2FnZS10ZXh0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGF0LW1lc3NhZ2VzL2NoYXQtbWVzc2FnZXMtdm9pY2UvY2hhdC1tZXNzYWdlLXZvaWNlLmNvbXBvbmVudCc7XG4iXX0=
|