ngx-rs-ant 0.2.4 → 0.4.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/box-container/PluginManager.d.ts +15 -0
- package/box-container/box-container.component.d.ts +12 -0
- package/box-container/box-container.module.d.ts +21 -0
- package/box-container/box-item/box-item-host.directive.d.ts +10 -0
- package/box-container/box-item/box-item.component.d.ts +36 -0
- package/box-container/box-item/item-blank/item-blank.component.d.ts +8 -0
- package/box-container/box-item/item-config/item-config.component.d.ts +8 -0
- package/box-container/box-item/item-style/item-style.component.d.ts +10 -0
- package/box-container/box-item/item-style/style/style.component.d.ts +12 -0
- package/box-container/box-item/item-style/style-blank/style-blank.component.d.ts +5 -0
- package/box-container/plugin-active/divider/divider-line/divider-line.component.d.ts +12 -0
- package/box-container/plugin-active/divider/divider.component.d.ts +23 -0
- package/box-container/plugin-active/plugin-active.component.d.ts +31 -0
- package/box-container/plugin-hover/plugin-hover.component.d.ts +18 -0
- package/data-grid/data-grid.component.d.ts +7 -4
- package/data-grid/data-grid.module.d.ts +1 -1
- package/esm2020/box-container/PluginManager.mjs +103 -0
- package/esm2020/box-container/box-container.component.mjs +44 -0
- package/esm2020/box-container/box-container.module.mjs +69 -0
- package/esm2020/box-container/box-item/box-item-host.directive.mjs +20 -0
- package/esm2020/box-container/box-item/box-item.component.mjs +169 -0
- package/esm2020/box-container/box-item/item-blank/item-blank.component.mjs +20 -0
- package/esm2020/box-container/box-item/item-config/item-config.component.mjs +35 -0
- package/esm2020/box-container/box-item/item-style/item-style.component.mjs +35 -0
- package/esm2020/box-container/box-item/item-style/style/style.component.mjs +44 -0
- package/esm2020/box-container/box-item/item-style/style-blank/style-blank.component.mjs +11 -0
- package/esm2020/box-container/plugin-active/divider/divider-line/divider-line.component.mjs +35 -0
- package/esm2020/box-container/plugin-active/divider/divider.component.mjs +50 -0
- package/esm2020/box-container/plugin-active/plugin-active.component.mjs +55 -0
- package/esm2020/box-container/plugin-hover/plugin-hover.component.mjs +26 -0
- package/esm2020/data-grid/data-grid.component.mjs +18 -11
- package/esm2020/data-grid/data-grid.module.mjs +9 -9
- package/esm2020/form/form.component.mjs +53 -0
- package/esm2020/form/form.module.mjs +39 -0
- package/esm2020/modal/modal.component.mjs +5 -5
- package/esm2020/modal/modal.module.mjs +8 -6
- package/esm2020/modal/modal.service.mjs +3 -3
- package/esm2020/public-api.mjs +11 -3
- package/fesm2015/ngx-rs-ant.mjs +905 -155
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +897 -155
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/form/form.component.d.ts +21 -0
- package/form/form.module.d.ts +11 -0
- package/modal/modal.component.d.ts +1 -1
- package/modal/modal.module.d.ts +1 -1
- package/package.json +4 -3
- package/public-api.d.ts +10 -2
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ComponentRef, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import { BoxItemComponent } from './box-item/box-item.component';
|
|
4
|
+
import { ItemConfigComponent } from "./box-item/item-config/item-config.component";
|
|
5
|
+
import { ItemStyleComponent } from "./box-item/item-style/item-style.component";
|
|
6
|
+
export declare class PluginManager {
|
|
7
|
+
static hoverItems: any[];
|
|
8
|
+
static activeItem: Subject<any>;
|
|
9
|
+
static activeItems: any[];
|
|
10
|
+
static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any, editMode?: boolean, control?: any): any;
|
|
11
|
+
static createHoverComponent(viewContainerRef: ViewContainerRef, componentRef: ComponentRef<any>, caption: string): any;
|
|
12
|
+
static createActiveComponent(boxItem: BoxItemComponent, index: number, componentRef: ComponentRef<any>, style: any, config: any, showClose: boolean): any;
|
|
13
|
+
static getItemConfigComponent(): typeof ItemConfigComponent;
|
|
14
|
+
static getItemStyleComponent(): typeof ItemStyleComponent;
|
|
15
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { OnInit, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { UntypedFormGroup } from "@angular/forms";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class BoxContainerComponent implements OnInit {
|
|
5
|
+
editMode: boolean;
|
|
6
|
+
config: any;
|
|
7
|
+
control?: UntypedFormGroup;
|
|
8
|
+
boxContainerContent: ViewContainerRef;
|
|
9
|
+
ngOnInit(): void;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BoxContainerComponent, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BoxContainerComponent, "rs-box-container", never, { "editMode": "editMode"; "config": "config"; "control": "control"; }, {}, never, never, false, never>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./box-container.component";
|
|
3
|
+
import * as i2 from "./box-item/box-item-host.directive";
|
|
4
|
+
import * as i3 from "./box-item/box-item.component";
|
|
5
|
+
import * as i4 from "./plugin-active/plugin-active.component";
|
|
6
|
+
import * as i5 from "./plugin-active/divider/divider.component";
|
|
7
|
+
import * as i6 from "./plugin-active/divider/divider-line/divider-line.component";
|
|
8
|
+
import * as i7 from "./plugin-hover/plugin-hover.component";
|
|
9
|
+
import * as i8 from "./box-item/item-config/item-config.component";
|
|
10
|
+
import * as i9 from "./box-item/item-style/item-style.component";
|
|
11
|
+
import * as i10 from "./box-item/item-style/style-blank/style-blank.component";
|
|
12
|
+
import * as i11 from "./box-item/item-blank/item-blank.component";
|
|
13
|
+
import * as i12 from "./box-item/item-style/style/style.component";
|
|
14
|
+
import * as i13 from "@angular/common";
|
|
15
|
+
import * as i14 from "ng-devui";
|
|
16
|
+
import * as i15 from "@angular/forms";
|
|
17
|
+
export declare class BoxContainerModule {
|
|
18
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BoxContainerModule, never>;
|
|
19
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<BoxContainerModule, [typeof i1.BoxContainerComponent, typeof i2.BoxItemHostDirective, typeof i3.BoxItemComponent, typeof i4.PluginActiveComponent, typeof i5.DividerComponent, typeof i6.DividerLineComponent, typeof i7.PluginHoverComponent, typeof i8.ItemConfigComponent, typeof i9.ItemStyleComponent, typeof i10.StyleBlankComponent, typeof i11.ItemBlankComponent, typeof i12.StyleComponent], [typeof i13.CommonModule, typeof i14.DevUIModule, typeof i15.FormsModule], [typeof i1.BoxContainerComponent, typeof i8.ItemConfigComponent, typeof i9.ItemStyleComponent]>;
|
|
20
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<BoxContainerModule>;
|
|
21
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ElementRef, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class BoxItemHostDirective {
|
|
4
|
+
private el;
|
|
5
|
+
viewContainerRef: ViewContainerRef;
|
|
6
|
+
hostId: any;
|
|
7
|
+
constructor(el: ElementRef, viewContainerRef: ViewContainerRef);
|
|
8
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BoxItemHostDirective, never>;
|
|
9
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<BoxItemHostDirective, "[rsBoxItemHost]", never, { "hostId": "hostId"; }, {}, never, never, false, never>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { EventEmitter, OnInit, QueryList } from '@angular/core';
|
|
2
|
+
import { BoxItemHostDirective } from './box-item-host.directive';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class BoxItemComponent implements OnInit {
|
|
5
|
+
editMode: boolean;
|
|
6
|
+
style: any;
|
|
7
|
+
config: any;
|
|
8
|
+
control: any;
|
|
9
|
+
pDirection?: 'row' | 'column';
|
|
10
|
+
get _direction(): any;
|
|
11
|
+
get _style(): {};
|
|
12
|
+
leaveOneItem: EventEmitter<any>;
|
|
13
|
+
itemHosts: QueryList<BoxItemHostDirective>;
|
|
14
|
+
ngOnInit(): void;
|
|
15
|
+
load(): void;
|
|
16
|
+
private createBlankComponent;
|
|
17
|
+
calcStyle(item: any): {
|
|
18
|
+
flex: string;
|
|
19
|
+
height: string;
|
|
20
|
+
pointerEvents: string;
|
|
21
|
+
width?: undefined;
|
|
22
|
+
} | {
|
|
23
|
+
width: string;
|
|
24
|
+
flex: string;
|
|
25
|
+
pointerEvents: string;
|
|
26
|
+
height?: undefined;
|
|
27
|
+
} | {
|
|
28
|
+
pointerEvents: string;
|
|
29
|
+
flex?: undefined;
|
|
30
|
+
height?: undefined;
|
|
31
|
+
width?: undefined;
|
|
32
|
+
};
|
|
33
|
+
private _calcStyle;
|
|
34
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BoxItemComponent, never>;
|
|
35
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BoxItemComponent, "rs-box-item", never, {}, { "leaveOneItem": "leaveOneItem"; }, never, never, false, never>;
|
|
36
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class ItemBlankComponent {
|
|
4
|
+
dropItem: EventEmitter<any>;
|
|
5
|
+
dropEvent($event: any): void;
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ItemBlankComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ItemBlankComponent, "rs-item-blank", never, {}, { "dropItem": "dropItem"; }, never, never, false, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { OnInit, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class ItemConfigComponent implements OnInit {
|
|
4
|
+
pageConfigContent: ViewContainerRef;
|
|
5
|
+
ngOnInit(): void;
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ItemConfigComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ItemConfigComponent, "rs-item-config", never, {}, {}, never, never, false, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ChangeDetectorRef, OnInit, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class ItemStyleComponent implements OnInit {
|
|
4
|
+
private changeDetectorRef;
|
|
5
|
+
pageStyleContent: ViewContainerRef;
|
|
6
|
+
constructor(changeDetectorRef: ChangeDetectorRef);
|
|
7
|
+
ngOnInit(): void;
|
|
8
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ItemStyleComponent, never>;
|
|
9
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ItemStyleComponent, "rs-item-style", never, {}, {}, never, never, false, never>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class StyleComponent implements OnInit {
|
|
4
|
+
style: any;
|
|
5
|
+
width: number | undefined;
|
|
6
|
+
height: number | undefined;
|
|
7
|
+
ngOnInit(): void;
|
|
8
|
+
select(name: string, value: any): void;
|
|
9
|
+
typing(name: string, value: any): void;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StyleComponent, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<StyleComponent, "rs-style", never, {}, {}, never, never, false, never>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class StyleBlankComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StyleBlankComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<StyleBlankComponent, "rs-style-blank", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class DividerLineComponent {
|
|
3
|
+
direction?: 'row' | 'column';
|
|
4
|
+
targetElement: any;
|
|
5
|
+
get _style(): {
|
|
6
|
+
height?: undefined;
|
|
7
|
+
} | {
|
|
8
|
+
height: string;
|
|
9
|
+
};
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DividerLineComponent, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DividerLineComponent, "rs-divider-line", never, { "direction": "direction"; "targetElement": "targetElement"; }, {}, never, never, false, never>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class DividerComponent {
|
|
4
|
+
direction?: 'row' | 'column';
|
|
5
|
+
targetElement: any;
|
|
6
|
+
dividerClick: EventEmitter<any>;
|
|
7
|
+
get _style(): {
|
|
8
|
+
top?: undefined;
|
|
9
|
+
left?: undefined;
|
|
10
|
+
transform?: undefined;
|
|
11
|
+
} | {
|
|
12
|
+
top: string;
|
|
13
|
+
left: string;
|
|
14
|
+
transform: string;
|
|
15
|
+
} | {
|
|
16
|
+
top: string;
|
|
17
|
+
left: string;
|
|
18
|
+
transform?: undefined;
|
|
19
|
+
};
|
|
20
|
+
onClick(): void;
|
|
21
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DividerComponent, never>;
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DividerComponent, "rs-divider", never, { "direction": "direction"; "targetElement": "targetElement"; }, { "dividerClick": "dividerClick"; }, never, never, false, never>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { EventEmitter, OnInit } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class PluginActiveComponent implements OnInit {
|
|
4
|
+
name: string;
|
|
5
|
+
showClose: boolean;
|
|
6
|
+
showDivider: boolean;
|
|
7
|
+
itemRemove: EventEmitter<any>;
|
|
8
|
+
targetElement: any;
|
|
9
|
+
targetRect: any;
|
|
10
|
+
_targetRect: any;
|
|
11
|
+
width: number;
|
|
12
|
+
_width: number;
|
|
13
|
+
height: number;
|
|
14
|
+
_height: number;
|
|
15
|
+
get _style(): {
|
|
16
|
+
width?: undefined;
|
|
17
|
+
height?: undefined;
|
|
18
|
+
top?: undefined;
|
|
19
|
+
left?: undefined;
|
|
20
|
+
} | {
|
|
21
|
+
width: string;
|
|
22
|
+
height: string;
|
|
23
|
+
top: string;
|
|
24
|
+
left: string;
|
|
25
|
+
};
|
|
26
|
+
ngOnInit(): void;
|
|
27
|
+
onItemCloseIconClick($event: any): void;
|
|
28
|
+
splitItem(direction: 'row' | 'column'): void;
|
|
29
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PluginActiveComponent, never>;
|
|
30
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PluginActiveComponent, "rs-plugin-active", never, {}, {}, never, never, false, never>;
|
|
31
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class PluginHoverComponent {
|
|
3
|
+
name: string;
|
|
4
|
+
targetElement: any;
|
|
5
|
+
get _style(): {
|
|
6
|
+
width?: undefined;
|
|
7
|
+
height?: undefined;
|
|
8
|
+
top?: undefined;
|
|
9
|
+
left?: undefined;
|
|
10
|
+
} | {
|
|
11
|
+
width: string;
|
|
12
|
+
height: string;
|
|
13
|
+
top: string;
|
|
14
|
+
left: string;
|
|
15
|
+
};
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PluginHoverComponent, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PluginHoverComponent, "rs-plugin-hover", never, {}, {}, never, never, false, never>;
|
|
18
|
+
}
|
|
@@ -1,16 +1,19 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
|
+
import { DxDataGridComponent } from "devextreme-angular";
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class DataGridComponent implements OnInit {
|
|
4
5
|
tenant: any;
|
|
5
6
|
className: any;
|
|
6
|
-
view
|
|
7
|
-
filter
|
|
7
|
+
view?: any;
|
|
8
|
+
filter?: any;
|
|
8
9
|
service: any;
|
|
9
10
|
dataSource: any;
|
|
10
11
|
columns: any[];
|
|
11
12
|
typeMap: any;
|
|
13
|
+
height?: any;
|
|
14
|
+
dxDataGrid: DxDataGridComponent;
|
|
12
15
|
ngOnInit(): void;
|
|
13
|
-
|
|
16
|
+
reload(): void;
|
|
14
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<DataGridComponent, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DataGridComponent, "rs-data-grid", never, { "tenant": "tenant"; "className": "className"; "view": "view"; "filter": "filter"; "service": "service"; }, {}, never, never, false, never>;
|
|
18
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DataGridComponent, "rs-data-grid", never, { "tenant": "tenant"; "className": "className"; "view": "view"; "filter": "filter"; "service": "service"; "height": "height"; }, {}, never, never, false, never>;
|
|
16
19
|
}
|
|
@@ -4,6 +4,6 @@ import * as i2 from "@angular/common";
|
|
|
4
4
|
import * as i3 from "devextreme-angular";
|
|
5
5
|
export declare class DataGridModule {
|
|
6
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<DataGridModule, never>;
|
|
7
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<DataGridModule, [typeof i1.DataGridComponent], [typeof i2.CommonModule, typeof i3.
|
|
7
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<DataGridModule, [typeof i1.DataGridComponent], [typeof i2.CommonModule, typeof i3.DxDataGridModule], [typeof i1.DataGridComponent]>;
|
|
8
8
|
static ɵinj: i0.ɵɵInjectorDeclaration<DataGridModule>;
|
|
9
9
|
}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { PluginFactory } from 'coast-plugin-register';
|
|
2
|
+
import { PluginActiveComponent } from './plugin-active/plugin-active.component';
|
|
3
|
+
import { PluginHoverComponent } from './plugin-hover/plugin-hover.component';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { ItemConfigComponent } from "./box-item/item-config/item-config.component";
|
|
6
|
+
import { ItemStyleComponent } from "./box-item/item-style/item-style.component";
|
|
7
|
+
import { UntypedFormControl } from "@angular/forms";
|
|
8
|
+
export class PluginManager {
|
|
9
|
+
static createComponent(boxItem, index, style, config, editMode = false, control) {
|
|
10
|
+
const plugin = PluginFactory.get(config.name);
|
|
11
|
+
if (!plugin) {
|
|
12
|
+
console.error('undefined plugin: ' + config.name);
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const viewContainerRef = boxItem.itemHosts.get(index)?.viewContainerRef;
|
|
16
|
+
viewContainerRef.clear();
|
|
17
|
+
const componentRef = viewContainerRef.createComponent(plugin.component);
|
|
18
|
+
const instance = componentRef.instance;
|
|
19
|
+
Object.assign(instance, config.pluginConfig);
|
|
20
|
+
if (plugin.category === 'form') {
|
|
21
|
+
if (editMode) {
|
|
22
|
+
instance.control = new UntypedFormControl('');
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
instance.control = control.get(config.pluginConfig.field);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
if (editMode) {
|
|
29
|
+
instance.onRemove = () => {
|
|
30
|
+
boxItem.config.list.splice(index, 1, { type: 'blank', style: boxItem.config.list[index].style });
|
|
31
|
+
boxItem.load();
|
|
32
|
+
};
|
|
33
|
+
if (plugin.type === 'default') {
|
|
34
|
+
componentRef.location.nativeElement.style.pointerEvents = 'all';
|
|
35
|
+
for (let child of componentRef.location.nativeElement.children) {
|
|
36
|
+
child.style.pointerEvents = 'none';
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
this.createHoverComponent(viewContainerRef, componentRef, plugin.caption);
|
|
40
|
+
this.createActiveComponent(boxItem, index, componentRef, style, {
|
|
41
|
+
caption: plugin.caption,
|
|
42
|
+
config
|
|
43
|
+
}, true);
|
|
44
|
+
}
|
|
45
|
+
return componentRef;
|
|
46
|
+
}
|
|
47
|
+
static createHoverComponent(viewContainerRef, componentRef, caption) {
|
|
48
|
+
const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);
|
|
49
|
+
hoverComponentRef.instance.name = caption;
|
|
50
|
+
hoverComponentRef.instance.targetElement = componentRef.location.nativeElement;
|
|
51
|
+
const hoverElement = hoverComponentRef.location.nativeElement;
|
|
52
|
+
componentRef.location.nativeElement.appendChild(hoverElement);
|
|
53
|
+
this.hoverItems.push(componentRef.location.nativeElement);
|
|
54
|
+
componentRef.location.nativeElement.addEventListener('mouseenter', ($event) => {
|
|
55
|
+
for (let hoverItem of this.hoverItems) {
|
|
56
|
+
hoverItem.classList.remove('plugin-hover');
|
|
57
|
+
}
|
|
58
|
+
$event.target.classList.add('plugin-hover');
|
|
59
|
+
});
|
|
60
|
+
componentRef.location.nativeElement.addEventListener('mouseleave', ($event) => {
|
|
61
|
+
$event.target.classList.remove('plugin-hover');
|
|
62
|
+
$event.target.parentElement.parentElement.classList.add('plugin-hover');
|
|
63
|
+
});
|
|
64
|
+
return hoverComponentRef;
|
|
65
|
+
}
|
|
66
|
+
static createActiveComponent(boxItem, index, componentRef, style, config, showClose) {
|
|
67
|
+
const viewContainerRef = boxItem.itemHosts.get(index)?.viewContainerRef;
|
|
68
|
+
const activeComponentRef = viewContainerRef.createComponent(PluginActiveComponent);
|
|
69
|
+
activeComponentRef.instance.name = config.caption;
|
|
70
|
+
activeComponentRef.instance.showClose = showClose;
|
|
71
|
+
activeComponentRef.instance.targetElement = componentRef.location.nativeElement;
|
|
72
|
+
const activeElement = activeComponentRef.location.nativeElement;
|
|
73
|
+
componentRef.location.nativeElement.appendChild(activeElement);
|
|
74
|
+
this.activeItems.push(componentRef.location.nativeElement);
|
|
75
|
+
componentRef.location.nativeElement.addEventListener('click', ($event) => {
|
|
76
|
+
$event.stopPropagation();
|
|
77
|
+
for (let activeItem of this.activeItems) {
|
|
78
|
+
activeItem.classList.remove('plugin-active');
|
|
79
|
+
}
|
|
80
|
+
if (this.activeItems.indexOf($event.target) < 0) {
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
this.activeItem.next({ boxItem, index, style, config: config.config });
|
|
84
|
+
$event.target.classList.add('plugin-active');
|
|
85
|
+
});
|
|
86
|
+
activeComponentRef.instance.itemRemove.subscribe(() => {
|
|
87
|
+
this.activeItem.next('');
|
|
88
|
+
viewContainerRef.clear();
|
|
89
|
+
componentRef.instance.onRemove();
|
|
90
|
+
});
|
|
91
|
+
return activeComponentRef;
|
|
92
|
+
}
|
|
93
|
+
static getItemConfigComponent() {
|
|
94
|
+
return ItemConfigComponent;
|
|
95
|
+
}
|
|
96
|
+
static getItemStyleComponent() {
|
|
97
|
+
return ItemStyleComponent;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
PluginManager.hoverItems = [];
|
|
101
|
+
PluginManager.activeItem = new Subject();
|
|
102
|
+
PluginManager.activeItems = [];
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PluginManager.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/box-container/PluginManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentRef, ViewContainerRef} from '@angular/core';\r\nimport {PluginFactory} from 'coast-plugin-register';\r\nimport {PluginActiveComponent} from './plugin-active/plugin-active.component';\r\nimport {PluginHoverComponent} from './plugin-hover/plugin-hover.component';\r\nimport {Subject} from 'rxjs';\r\nimport {BoxItemComponent} from './box-item/box-item.component';\r\nimport {ItemConfigComponent} from \"./box-item/item-config/item-config.component\";\r\nimport {ItemStyleComponent} from \"./box-item/item-style/item-style.component\";\r\nimport {UntypedFormControl} from \"@angular/forms\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<any>();\r\n  static activeItems: any[] = [];\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any, editMode = false, control?: any): any {\r\n    const plugin = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      return;\r\n    }\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    viewContainerRef.clear();\r\n    const componentRef = viewContainerRef.createComponent(plugin.component);\r\n    const instance: any = componentRef.instance;\r\n    Object.assign(instance, config.pluginConfig);\r\n    if (plugin.category === 'form') {\r\n      if (editMode) {\r\n        instance.control = new UntypedFormControl('');\r\n      } else {\r\n        instance.control = control.get(config.pluginConfig.field);\r\n      }\r\n    }\r\n    if (editMode) {\r\n      instance.onRemove = () => {\r\n        boxItem.config.list.splice(index, 1, {type: 'blank', style: boxItem.config.list[index].style});\r\n        boxItem.load();\r\n      };\r\n      if (plugin.type === 'default') {\r\n        componentRef.location.nativeElement.style.pointerEvents = 'all';\r\n        for (let child of componentRef.location.nativeElement.children) {\r\n          child.style.pointerEvents = 'none';\r\n        }\r\n      }\r\n      this.createHoverComponent(viewContainerRef, componentRef, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, componentRef, style, {\r\n        caption: plugin.caption,\r\n        config\r\n      }, true);\r\n    }\r\n    return componentRef;\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, componentRef: ComponentRef<any>, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(hoverElement);\r\n    this.hoverItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('mouseenter', ($event: any) => {\r\n      for (let hoverItem of this.hoverItems) {\r\n        hoverItem.classList.remove('plugin-hover');\r\n      }\r\n      $event.target.classList.add('plugin-hover');\r\n    });\r\n    componentRef.location.nativeElement.addEventListener('mouseleave', ($event: any) => {\r\n      $event.target.classList.remove('plugin-hover');\r\n      $event.target.parentElement.parentElement.classList.add('plugin-hover');\r\n    });\r\n    return hoverComponentRef;\r\n  }\r\n\r\n  static createActiveComponent(boxItem: BoxItemComponent, index: number, componentRef: ComponentRef<any>,\r\n                               style: any, config: any, showClose: boolean): any {\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    const activeComponentRef = viewContainerRef.createComponent(PluginActiveComponent);\r\n    activeComponentRef.instance.name = config.caption;\r\n    activeComponentRef.instance.showClose = showClose;\r\n    activeComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(activeElement);\r\n    this.activeItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems.indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({boxItem, index, style, config: config.config});\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next('');\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n\r\n  static getItemConfigComponent() {\r\n    return ItemConfigComponent;\r\n  }\r\n\r\n  static getItemStyleComponent() {\r\n    return ItemStyleComponent;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { BoxItemComponent } from './box-item/box-item.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class BoxContainerComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.editMode = false;
|
|
7
|
+
this.config = {
|
|
8
|
+
direction: 'row',
|
|
9
|
+
list: [{ type: 'blank', style: {} }]
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
ngOnInit() {
|
|
13
|
+
const boxItemComponentRef = this.boxContainerContent.createComponent(BoxItemComponent);
|
|
14
|
+
const instance = boxItemComponentRef.instance;
|
|
15
|
+
instance.editMode = this.editMode;
|
|
16
|
+
instance.config = this.config;
|
|
17
|
+
instance.control = this.control;
|
|
18
|
+
instance.leaveOneItem?.subscribe((item) => {
|
|
19
|
+
if (item.type === 'item') {
|
|
20
|
+
Object.assign(instance.config, item);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
instance.config.direction = 'row';
|
|
24
|
+
}
|
|
25
|
+
instance.load();
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
BoxContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
BoxContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: BoxContainerComponent, selector: "rs-box-container", inputs: { editMode: "editMode", config: "config", control: "control" }, viewQueries: [{ propertyName: "boxContainerContent", first: true, predicate: ["boxContainerContent"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<ng-container #boxContainerContent></ng-container>\n", styles: [":host{flex:auto;position:relative;display:flex;overflow:auto}\n"] });
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxContainerComponent, decorators: [{
|
|
32
|
+
type: Component,
|
|
33
|
+
args: [{ selector: 'rs-box-container', template: "<ng-container #boxContainerContent></ng-container>\n", styles: [":host{flex:auto;position:relative;display:flex;overflow:auto}\n"] }]
|
|
34
|
+
}], propDecorators: { editMode: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], config: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}], control: [{
|
|
39
|
+
type: Input
|
|
40
|
+
}], boxContainerContent: [{
|
|
41
|
+
type: ViewChild,
|
|
42
|
+
args: ['boxContainerContent', { static: true, read: ViewContainerRef }]
|
|
43
|
+
}] } });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94LWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvYm94LWNvbnRhaW5lci9ib3gtY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFVLFNBQVMsRUFBRSxnQkFBZ0IsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNwRixPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQzs7QUFRL0QsTUFBTSxPQUFPLHFCQUFxQjtJQUxsQztRQU9FLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFFMUIsV0FBTSxHQUFRO1lBQ1osU0FBUyxFQUFFLEtBQUs7WUFDaEIsSUFBSSxFQUFFLENBQUMsRUFBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUMsQ0FBQztTQUNuQyxDQUFDO0tBb0JIO0lBZkMsUUFBUTtRQUNOLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ3ZGLE1BQU0sUUFBUSxHQUFHLG1CQUFtQixDQUFDLFFBQVEsQ0FBQztRQUM5QyxRQUFRLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDbEMsUUFBUSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzlCLFFBQVEsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUNoQyxRQUFRLENBQUMsWUFBWSxFQUFFLFNBQVMsQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFO1lBQzdDLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxNQUFNLEVBQUU7Z0JBQ3hCLE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQzthQUN0QztpQkFBTTtnQkFDTCxRQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7YUFDbkM7WUFDRCxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDbEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOztrSEExQlUscUJBQXFCO3NHQUFyQixxQkFBcUIsdU9BVXVCLGdCQUFnQiwyQ0NuQnpFLHNEQUNBOzJGRFFhLHFCQUFxQjtrQkFMakMsU0FBUzsrQkFDRSxrQkFBa0I7OEJBTTVCLFFBQVE7c0JBRFAsS0FBSztnQkFHTixNQUFNO3NCQURMLEtBQUs7Z0JBTU4sT0FBTztzQkFETixLQUFLO2dCQUVvRSxtQkFBbUI7c0JBQTVGLFNBQVM7dUJBQUMscUJBQXFCLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCb3hJdGVtQ29tcG9uZW50fSBmcm9tICcuL2JveC1pdGVtL2JveC1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQge1VudHlwZWRGb3JtQXJyYXksIFVudHlwZWRGb3JtR3JvdXB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdycy1ib3gtY29udGFpbmVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2JveC1jb250YWluZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9ib3gtY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQm94Q29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgZWRpdE1vZGU6IGJvb2xlYW4gPSBmYWxzZTtcbiAgQElucHV0KClcbiAgY29uZmlnOiBhbnkgPSB7XG4gICAgZGlyZWN0aW9uOiAncm93JyxcbiAgICBsaXN0OiBbe3R5cGU6ICdibGFuaycsIHN0eWxlOiB7fX1dXG4gIH07XG4gIEBJbnB1dCgpXG4gIGNvbnRyb2w/OiBVbnR5cGVkRm9ybUdyb3VwO1xuICBAVmlld0NoaWxkKCdib3hDb250YWluZXJDb250ZW50Jywge3N0YXRpYzogdHJ1ZSwgcmVhZDogVmlld0NvbnRhaW5lclJlZn0pIGJveENvbnRhaW5lckNvbnRlbnQhOiBWaWV3Q29udGFpbmVyUmVmO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGJveEl0ZW1Db21wb25lbnRSZWYgPSB0aGlzLmJveENvbnRhaW5lckNvbnRlbnQuY3JlYXRlQ29tcG9uZW50KEJveEl0ZW1Db21wb25lbnQpO1xuICAgIGNvbnN0IGluc3RhbmNlID0gYm94SXRlbUNvbXBvbmVudFJlZi5pbnN0YW5jZTtcbiAgICBpbnN0YW5jZS5lZGl0TW9kZSA9IHRoaXMuZWRpdE1vZGU7XG4gICAgaW5zdGFuY2UuY29uZmlnID0gdGhpcy5jb25maWc7XG4gICAgaW5zdGFuY2UuY29udHJvbCA9IHRoaXMuY29udHJvbDtcbiAgICBpbnN0YW5jZS5sZWF2ZU9uZUl0ZW0/LnN1YnNjcmliZSgoaXRlbTogYW55KSA9PiB7XG4gICAgICBpZiAoaXRlbS50eXBlID09PSAnaXRlbScpIHtcbiAgICAgICAgT2JqZWN0LmFzc2lnbihpbnN0YW5jZS5jb25maWcsIGl0ZW0pO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaW5zdGFuY2UuY29uZmlnLmRpcmVjdGlvbiA9ICdyb3cnO1xuICAgICAgfVxuICAgICAgaW5zdGFuY2UubG9hZCgpO1xuICAgIH0pO1xuICB9XG59XG4iLCI8bmctY29udGFpbmVyICNib3hDb250YWluZXJDb250ZW50PjwvbmctY29udGFpbmVyPlxuIl19
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { BoxContainerComponent } from './box-container.component';
|
|
4
|
+
import { BoxItemHostDirective } from './box-item/box-item-host.directive';
|
|
5
|
+
import { BoxItemComponent } from './box-item/box-item.component';
|
|
6
|
+
import { DevUIModule } from 'ng-devui';
|
|
7
|
+
import { PluginActiveComponent } from "./plugin-active/plugin-active.component";
|
|
8
|
+
import { PluginHoverComponent } from "./plugin-hover/plugin-hover.component";
|
|
9
|
+
import { DividerComponent } from "./plugin-active/divider/divider.component";
|
|
10
|
+
import { DividerLineComponent } from "./plugin-active/divider/divider-line/divider-line.component";
|
|
11
|
+
import { ItemConfigComponent } from './box-item/item-config/item-config.component';
|
|
12
|
+
import { ItemStyleComponent } from './box-item/item-style/item-style.component';
|
|
13
|
+
import { StyleBlankComponent } from './box-item/item-style/style-blank/style-blank.component';
|
|
14
|
+
import { ItemBlankComponent } from './box-item/item-blank/item-blank.component';
|
|
15
|
+
import { FormsModule } from "@angular/forms";
|
|
16
|
+
import { StyleComponent } from './box-item/item-style/style/style.component';
|
|
17
|
+
import * as i0 from "@angular/core";
|
|
18
|
+
export class BoxContainerModule {
|
|
19
|
+
}
|
|
20
|
+
BoxContainerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxContainerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
21
|
+
BoxContainerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: BoxContainerModule, declarations: [BoxContainerComponent,
|
|
22
|
+
BoxItemHostDirective,
|
|
23
|
+
BoxItemComponent,
|
|
24
|
+
PluginActiveComponent,
|
|
25
|
+
DividerComponent,
|
|
26
|
+
DividerLineComponent,
|
|
27
|
+
PluginHoverComponent,
|
|
28
|
+
ItemConfigComponent,
|
|
29
|
+
ItemStyleComponent,
|
|
30
|
+
StyleBlankComponent,
|
|
31
|
+
ItemBlankComponent,
|
|
32
|
+
StyleComponent], imports: [CommonModule,
|
|
33
|
+
DevUIModule,
|
|
34
|
+
FormsModule], exports: [BoxContainerComponent,
|
|
35
|
+
ItemConfigComponent,
|
|
36
|
+
ItemStyleComponent] });
|
|
37
|
+
BoxContainerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxContainerModule, imports: [CommonModule,
|
|
38
|
+
DevUIModule,
|
|
39
|
+
FormsModule] });
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxContainerModule, decorators: [{
|
|
41
|
+
type: NgModule,
|
|
42
|
+
args: [{
|
|
43
|
+
declarations: [
|
|
44
|
+
BoxContainerComponent,
|
|
45
|
+
BoxItemHostDirective,
|
|
46
|
+
BoxItemComponent,
|
|
47
|
+
PluginActiveComponent,
|
|
48
|
+
DividerComponent,
|
|
49
|
+
DividerLineComponent,
|
|
50
|
+
PluginHoverComponent,
|
|
51
|
+
ItemConfigComponent,
|
|
52
|
+
ItemStyleComponent,
|
|
53
|
+
StyleBlankComponent,
|
|
54
|
+
ItemBlankComponent,
|
|
55
|
+
StyleComponent
|
|
56
|
+
],
|
|
57
|
+
imports: [
|
|
58
|
+
CommonModule,
|
|
59
|
+
DevUIModule,
|
|
60
|
+
FormsModule
|
|
61
|
+
],
|
|
62
|
+
exports: [
|
|
63
|
+
BoxContainerComponent,
|
|
64
|
+
ItemConfigComponent,
|
|
65
|
+
ItemStyleComponent
|
|
66
|
+
]
|
|
67
|
+
}]
|
|
68
|
+
}] });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94LWNvbnRhaW5lci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1jb250YWluZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxVQUFVLENBQUM7QUFDckMsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDM0UsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDM0UsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sNkRBQTZELENBQUM7QUFDakcsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDakYsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDOUUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0seURBQXlELENBQUM7QUFDNUYsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDOUUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQzs7QUE0QjNFLE1BQU0sT0FBTyxrQkFBa0I7OytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixpQkF4QjNCLHFCQUFxQjtRQUNyQixvQkFBb0I7UUFDcEIsZ0JBQWdCO1FBQ2hCLHFCQUFxQjtRQUNyQixnQkFBZ0I7UUFDaEIsb0JBQW9CO1FBQ3BCLG9CQUFvQjtRQUNwQixtQkFBbUI7UUFDbkIsa0JBQWtCO1FBQ2xCLG1CQUFtQjtRQUNuQixrQkFBa0I7UUFDbEIsY0FBYyxhQUdkLFlBQVk7UUFDWixXQUFXO1FBQ1gsV0FBVyxhQUdYLHFCQUFxQjtRQUNyQixtQkFBbUI7UUFDbkIsa0JBQWtCO2dIQUdULGtCQUFrQixZQVYzQixZQUFZO1FBQ1osV0FBVztRQUNYLFdBQVc7MkZBUUYsa0JBQWtCO2tCQTFCOUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1oscUJBQXFCO3dCQUNyQixvQkFBb0I7d0JBQ3BCLGdCQUFnQjt3QkFDaEIscUJBQXFCO3dCQUNyQixnQkFBZ0I7d0JBQ2hCLG9CQUFvQjt3QkFDcEIsb0JBQW9CO3dCQUNwQixtQkFBbUI7d0JBQ25CLGtCQUFrQjt3QkFDbEIsbUJBQW1CO3dCQUNuQixrQkFBa0I7d0JBQ2xCLGNBQWM7cUJBQ2Y7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxXQUFXO3FCQUNaO29CQUNELE9BQU8sRUFBRTt3QkFDUCxxQkFBcUI7d0JBQ3JCLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3FCQUNuQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtCb3hDb250YWluZXJDb21wb25lbnR9IGZyb20gJy4vYm94LWNvbnRhaW5lci5jb21wb25lbnQnO1xyXG5pbXBvcnQge0JveEl0ZW1Ib3N0RGlyZWN0aXZlfSBmcm9tICcuL2JveC1pdGVtL2JveC1pdGVtLWhvc3QuZGlyZWN0aXZlJztcclxuaW1wb3J0IHtCb3hJdGVtQ29tcG9uZW50fSBmcm9tICcuL2JveC1pdGVtL2JveC1pdGVtLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7RGV2VUlNb2R1bGV9IGZyb20gJ25nLWRldnVpJztcclxuaW1wb3J0IHtQbHVnaW5BY3RpdmVDb21wb25lbnR9IGZyb20gXCIuL3BsdWdpbi1hY3RpdmUvcGx1Z2luLWFjdGl2ZS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtQbHVnaW5Ib3ZlckNvbXBvbmVudH0gZnJvbSBcIi4vcGx1Z2luLWhvdmVyL3BsdWdpbi1ob3Zlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEaXZpZGVyQ29tcG9uZW50fSBmcm9tIFwiLi9wbHVnaW4tYWN0aXZlL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEaXZpZGVyTGluZUNvbXBvbmVudH0gZnJvbSBcIi4vcGx1Z2luLWFjdGl2ZS9kaXZpZGVyL2RpdmlkZXItbGluZS9kaXZpZGVyLWxpbmUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SXRlbUNvbmZpZ0NvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLWNvbmZpZy9pdGVtLWNvbmZpZy5jb21wb25lbnQnO1xyXG5pbXBvcnQge0l0ZW1TdHlsZUNvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLXN0eWxlL2l0ZW0tc3R5bGUuY29tcG9uZW50JztcclxuaW1wb3J0IHtTdHlsZUJsYW5rQ29tcG9uZW50fSBmcm9tICcuL2JveC1pdGVtL2l0ZW0tc3R5bGUvc3R5bGUtYmxhbmsvc3R5bGUtYmxhbmsuY29tcG9uZW50JztcclxuaW1wb3J0IHtJdGVtQmxhbmtDb21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1ibGFuay9pdGVtLWJsYW5rLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5pbXBvcnQge1N0eWxlQ29tcG9uZW50fSBmcm9tICcuL2JveC1pdGVtL2l0ZW0tc3R5bGUvc3R5bGUvc3R5bGUuY29tcG9uZW50JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBCb3hDb250YWluZXJDb21wb25lbnQsXHJcbiAgICBCb3hJdGVtSG9zdERpcmVjdGl2ZSxcclxuICAgIEJveEl0ZW1Db21wb25lbnQsXHJcbiAgICBQbHVnaW5BY3RpdmVDb21wb25lbnQsXHJcbiAgICBEaXZpZGVyQ29tcG9uZW50LFxyXG4gICAgRGl2aWRlckxpbmVDb21wb25lbnQsXHJcbiAgICBQbHVnaW5Ib3ZlckNvbXBvbmVudCxcclxuICAgIEl0ZW1Db25maWdDb21wb25lbnQsXHJcbiAgICBJdGVtU3R5bGVDb21wb25lbnQsXHJcbiAgICBTdHlsZUJsYW5rQ29tcG9uZW50LFxyXG4gICAgSXRlbUJsYW5rQ29tcG9uZW50LFxyXG4gICAgU3R5bGVDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIERldlVJTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIEJveENvbnRhaW5lckNvbXBvbmVudCxcclxuICAgIEl0ZW1Db25maWdDb21wb25lbnQsXHJcbiAgICBJdGVtU3R5bGVDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCb3hDb250YWluZXJNb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class BoxItemHostDirective {
|
|
4
|
+
constructor(el, viewContainerRef) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.viewContainerRef = viewContainerRef;
|
|
7
|
+
this.el.nativeElement.hostId = this.hostId;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
BoxItemHostDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxItemHostDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
11
|
+
BoxItemHostDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: BoxItemHostDirective, selector: "[rsBoxItemHost]", inputs: { hostId: "hostId" }, ngImport: i0 });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BoxItemHostDirective, decorators: [{
|
|
13
|
+
type: Directive,
|
|
14
|
+
args: [{
|
|
15
|
+
selector: '[rsBoxItemHost]'
|
|
16
|
+
}]
|
|
17
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }]; }, propDecorators: { hostId: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}] } });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94LWl0ZW0taG9zdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1pdGVtL2JveC1pdGVtLWhvc3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQWMsS0FBSyxFQUFtQixNQUFNLGVBQWUsQ0FBQzs7QUFLN0UsTUFBTSxPQUFPLG9CQUFvQjtJQUkvQixZQUFvQixFQUFjLEVBQVMsZ0JBQWtDO1FBQXpELE9BQUUsR0FBRixFQUFFLENBQVk7UUFBUyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQzNFLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQzdDLENBQUM7O2lIQU5VLG9CQUFvQjtxR0FBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBSGhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtpQkFDNUI7Z0lBR0MsTUFBTTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBWaWV3Q29udGFpbmVyUmVmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3JzQm94SXRlbUhvc3RdJ1xufSlcbmV4cG9ydCBjbGFzcyBCb3hJdGVtSG9zdERpcmVjdGl2ZSB7XG4gIEBJbnB1dCgpXG4gIGhvc3RJZDogYW55O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsIHB1YmxpYyB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmKSB7XG4gICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50Lmhvc3RJZCA9IHRoaXMuaG9zdElkO1xuICB9XG59XG4iXX0=
|