ngx-rs-ant 1.6.2 → 1.6.3
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/box-container.module.d.ts +7 -6
- package/box-container/box-item/item-config/form-item-config-error/form-item-config-error.component.d.ts +5 -0
- package/esm2020/box-container/PluginManager.mjs +11 -2
- package/esm2020/box-container/box-container.module.mjs +4 -1
- package/esm2020/box-container/box-item/item-config/form-item-config-error/form-item-config-error.component.mjs +11 -0
- package/esm2020/form/field-selector/field-selector.component.mjs +144 -0
- package/esm2020/form/form.module.mjs +10 -5
- package/esm2020/public-api.mjs +3 -1
- package/esm2020/util/form-item-config-base.mjs +7 -0
- package/fesm2015/ngx-rs-ant.mjs +170 -6
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +170 -6
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/form/field-selector/field-selector.component.d.ts +25 -0
- package/form/form.module.d.ts +5 -4
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/util/form-item-config-base.d.ts +6 -0
|
@@ -10,13 +10,14 @@ import * as i8 from "./box-item/item-config/item-config.component";
|
|
|
10
10
|
import * as i9 from "./box-item/item-style/item-style.component";
|
|
11
11
|
import * as i10 from "./box-item/item-style/style-blank/style-blank.component";
|
|
12
12
|
import * as i11 from "./box-item/item-blank/item-blank.component";
|
|
13
|
-
import * as i12 from "./box-item/item-
|
|
14
|
-
import * as i13 from "./
|
|
15
|
-
import * as i14 from "./
|
|
16
|
-
import * as i15 from "
|
|
17
|
-
import * as i16 from "
|
|
13
|
+
import * as i12 from "./box-item/item-config/form-item-config-error/form-item-config-error.component";
|
|
14
|
+
import * as i13 from "./box-item/item-style/style/style.component";
|
|
15
|
+
import * as i14 from "./plugin-not-found/plugin-not-found.component";
|
|
16
|
+
import * as i15 from "./box-item/item-config/config-blank/config-blank.component";
|
|
17
|
+
import * as i16 from "@angular/common";
|
|
18
|
+
import * as i17 from "devextreme-angular";
|
|
18
19
|
export declare class BoxContainerModule {
|
|
19
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<BoxContainerModule, never>;
|
|
20
|
-
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.
|
|
21
|
+
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.FormItemConfigErrorComponent, typeof i13.StyleComponent, typeof i14.PluginNotFoundComponent, typeof i15.ConfigBlankComponent], [typeof i16.CommonModule, typeof i17.DevExtremeModule], [typeof i1.BoxContainerComponent, typeof i8.ItemConfigComponent, typeof i9.ItemStyleComponent]>;
|
|
21
22
|
static ɵinj: i0.ɵɵInjectorDeclaration<BoxContainerModule>;
|
|
22
23
|
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class FormItemConfigErrorComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FormItemConfigErrorComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FormItemConfigErrorComponent, "rs-form-item-config-error", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -6,6 +6,8 @@ import { PluginNotFoundComponent } from "./plugin-not-found/plugin-not-found.com
|
|
|
6
6
|
import { ConfigBlankComponent } from "./box-item/item-config/config-blank/config-blank.component";
|
|
7
7
|
import { StyleComponent } from "./box-item/item-style/style/style.component";
|
|
8
8
|
import { StyleBlankComponent } from "./box-item/item-style/style-blank/style-blank.component";
|
|
9
|
+
import { FormItemConfigBase } from "../util/form-item-config-base";
|
|
10
|
+
import { FormItemConfigErrorComponent } from "./box-item/item-config/form-item-config-error/form-item-config-error.component";
|
|
9
11
|
export class PluginManager {
|
|
10
12
|
static createComponent(boxItem, index, style, config) {
|
|
11
13
|
let plugin = PluginFactory.get(config.name);
|
|
@@ -150,6 +152,11 @@ export class PluginManager {
|
|
|
150
152
|
const instance = componentRef.instance;
|
|
151
153
|
instance.config = item.config.pluginConfig;
|
|
152
154
|
if (pluginType === 'form') {
|
|
155
|
+
if (!(instance instanceof FormItemConfigBase)) {
|
|
156
|
+
itemConfigContainerRef.clear();
|
|
157
|
+
itemConfigContainerRef.createComponent(FormItemConfigErrorComponent);
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
153
160
|
instance.fieldTree = fieldTree;
|
|
154
161
|
}
|
|
155
162
|
instance.configChange.subscribe((reload) => {
|
|
@@ -158,7 +165,9 @@ export class PluginManager {
|
|
|
158
165
|
componentRef.location.nativeElement.click();
|
|
159
166
|
}
|
|
160
167
|
else {
|
|
161
|
-
|
|
168
|
+
setTimeout(() => {
|
|
169
|
+
Object.assign(item.componentRef.instance, item.config.pluginConfig);
|
|
170
|
+
});
|
|
162
171
|
}
|
|
163
172
|
});
|
|
164
173
|
}
|
|
@@ -180,4 +189,4 @@ export class PluginManager {
|
|
|
180
189
|
PluginManager.hoverItems = [];
|
|
181
190
|
PluginManager.activeItem = new Subject();
|
|
182
191
|
PluginManager.activeItems = {};
|
|
183
|
-
//# 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 {PluginNotFoundComponent} from \"./plugin-not-found/plugin-not-found.component\";\r\nimport {ConfigBlankComponent} from \"./box-item/item-config/config-blank/config-blank.component\";\r\nimport {StyleComponent} from \"./box-item/item-style/style/style.component\";\r\nimport {StyleBlankComponent} from \"./box-item/item-style/style-blank/style-blank.component\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<{ id: string, item: any }>();\r\n  static activeItems: { [id: string]: any } = {};\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any): any {\r\n    let plugin: any = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      plugin = {\r\n        component: PluginNotFoundComponent,\r\n        name: config.name,\r\n        caption: config.name\r\n      }\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    instance.editMode = boxItem.boxContainer.editMode;\r\n    if (plugin.type === 'form') {\r\n      instance.model = boxItem.boxContainer.model;\r\n    }\r\n    if (boxItem.boxContainer.readonly) {\r\n      instance.readonly = true;\r\n    }\r\n    instance.opener = boxItem.boxContainer.opener;\r\n    instance.params = boxItem.boxContainer.params;\r\n    instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;\r\n    if (boxItem.boxContainer.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      componentRef.location.nativeElement.style.margin = '8px';\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      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 id = boxItem.boxContainer.id;\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    if (this.activeItems[id]) {\r\n      this.activeItems[id].push(componentRef.location.nativeElement);\r\n    } else {\r\n      this.activeItems[id] = [componentRef.location.nativeElement];\r\n    }\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems[id]) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems[id].indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({\r\n        id,\r\n        item: {boxItem, index, style, config: config.config, componentRef}\r\n      });\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.splitItem = (direction: 'row' | 'column') => {\r\n      if (boxItem.config.direction === direction) {\r\n        boxItem.config.list.splice(index + 1, 0, {type: 'blank', style: {}});\r\n        boxItem.load();\r\n      } else {\r\n        if (boxItem.config.list.length === 1) {\r\n          boxItem.config.direction = direction;\r\n          boxItem.config.list.push({type: 'blank', style: {}});\r\n        } else {\r\n          if (boxItem.config.list[index].type === 'item' && boxItem.config.list[index].config.direction === direction) {\r\n            boxItem.config.list[index].config.list.push({type: 'blank', style: {}});\r\n          } else {\r\n            boxItem.config.list.splice(index, 1, {\r\n              type: 'item',\r\n              style: boxItem.config.list[index].style,\r\n              config: {\r\n                direction,\r\n                list: [boxItem.config.list[index], {type: 'blank', style: {}}]\r\n              }\r\n            });\r\n          }\r\n        }\r\n        boxItem.load();\r\n      }\r\n    };\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next({\r\n        id,\r\n        item: ''\r\n      });\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n\r\n  static resetItemConfig(itemConfigContainerRef: ViewContainerRef, item: any, fieldTree?: any) {\r\n    itemConfigContainerRef.clear();\r\n    if (!item) {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n      return;\r\n    }\r\n    const plugin = PluginFactory.get(item.config?.name);\r\n    const pluginType = plugin?.type;\r\n    const pluginConfig = PluginFactory.getConfig(item.config?.name);\r\n    if (pluginConfig) {\r\n      const componentRef = itemConfigContainerRef.createComponent(pluginConfig.component);\r\n      const instance: any = componentRef.instance;\r\n      instance.config = item.config.pluginConfig;\r\n      if (pluginType === 'form') {\r\n        instance.fieldTree = fieldTree;\r\n      }\r\n      instance.configChange.subscribe((reload?: boolean) => {\r\n        if (reload) {\r\n          const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);\r\n          componentRef.location.nativeElement.click();\r\n        } else {\r\n          Object.assign(item.componentRef.instance, item.config.pluginConfig);\r\n        }\r\n      });\r\n    } else {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n    }\r\n  }\r\n\r\n  static resetItemStyle(itemStyleContainerRef: ViewContainerRef, item: any) {\r\n    itemStyleContainerRef.clear();\r\n    if (!item) {\r\n      itemStyleContainerRef.createComponent(StyleBlankComponent);\r\n      return;\r\n    }\r\n    const componentRef = itemStyleContainerRef.createComponent(StyleComponent);\r\n    const instance: any = componentRef.instance;\r\n    instance.style = item.style;\r\n  }\r\n}\r\n"]}
|
|
192
|
+
//# 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 {PluginNotFoundComponent} from \"./plugin-not-found/plugin-not-found.component\";\r\nimport {ConfigBlankComponent} from \"./box-item/item-config/config-blank/config-blank.component\";\r\nimport {StyleComponent} from \"./box-item/item-style/style/style.component\";\r\nimport {StyleBlankComponent} from \"./box-item/item-style/style-blank/style-blank.component\";\r\nimport {FormItemConfigBase} from \"../util/form-item-config-base\";\r\nimport {\r\n  FormItemConfigErrorComponent\r\n} from \"./box-item/item-config/form-item-config-error/form-item-config-error.component\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<{ id: string, item: any }>();\r\n  static activeItems: { [id: string]: any } = {};\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any): any {\r\n    let plugin: any = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      plugin = {\r\n        component: PluginNotFoundComponent,\r\n        name: config.name,\r\n        caption: config.name\r\n      }\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    instance.editMode = boxItem.boxContainer.editMode;\r\n    if (plugin.type === 'form') {\r\n      instance.model = boxItem.boxContainer.model;\r\n    }\r\n    if (boxItem.boxContainer.readonly) {\r\n      instance.readonly = true;\r\n    }\r\n    instance.opener = boxItem.boxContainer.opener;\r\n    instance.params = boxItem.boxContainer.params;\r\n    instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;\r\n    if (boxItem.boxContainer.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      componentRef.location.nativeElement.style.margin = '8px';\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      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 id = boxItem.boxContainer.id;\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    if (this.activeItems[id]) {\r\n      this.activeItems[id].push(componentRef.location.nativeElement);\r\n    } else {\r\n      this.activeItems[id] = [componentRef.location.nativeElement];\r\n    }\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems[id]) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems[id].indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({\r\n        id,\r\n        item: {boxItem, index, style, config: config.config, componentRef}\r\n      });\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.splitItem = (direction: 'row' | 'column') => {\r\n      if (boxItem.config.direction === direction) {\r\n        boxItem.config.list.splice(index + 1, 0, {type: 'blank', style: {}});\r\n        boxItem.load();\r\n      } else {\r\n        if (boxItem.config.list.length === 1) {\r\n          boxItem.config.direction = direction;\r\n          boxItem.config.list.push({type: 'blank', style: {}});\r\n        } else {\r\n          if (boxItem.config.list[index].type === 'item' && boxItem.config.list[index].config.direction === direction) {\r\n            boxItem.config.list[index].config.list.push({type: 'blank', style: {}});\r\n          } else {\r\n            boxItem.config.list.splice(index, 1, {\r\n              type: 'item',\r\n              style: boxItem.config.list[index].style,\r\n              config: {\r\n                direction,\r\n                list: [boxItem.config.list[index], {type: 'blank', style: {}}]\r\n              }\r\n            });\r\n          }\r\n        }\r\n        boxItem.load();\r\n      }\r\n    };\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next({\r\n        id,\r\n        item: ''\r\n      });\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n\r\n  static resetItemConfig(itemConfigContainerRef: ViewContainerRef, item: any, fieldTree?: any) {\r\n    itemConfigContainerRef.clear();\r\n    if (!item) {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n      return;\r\n    }\r\n    const plugin = PluginFactory.get(item.config?.name);\r\n    const pluginType = plugin?.type;\r\n    const pluginConfig = PluginFactory.getConfig(item.config?.name);\r\n    if (pluginConfig) {\r\n      const componentRef = itemConfigContainerRef.createComponent(pluginConfig.component);\r\n      const instance: any = componentRef.instance;\r\n      instance.config = item.config.pluginConfig;\r\n      if (pluginType === 'form') {\r\n        if (!(instance instanceof FormItemConfigBase)) {\r\n          itemConfigContainerRef.clear();\r\n          itemConfigContainerRef.createComponent(FormItemConfigErrorComponent);\r\n          return;\r\n        }\r\n        instance.fieldTree = fieldTree;\r\n      }\r\n      instance.configChange.subscribe((reload?: boolean) => {\r\n        if (reload) {\r\n          const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);\r\n          componentRef.location.nativeElement.click();\r\n        } else {\r\n          setTimeout(() => {\r\n            Object.assign(item.componentRef.instance, item.config.pluginConfig);\r\n          });\r\n        }\r\n      });\r\n    } else {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n    }\r\n  }\r\n\r\n  static resetItemStyle(itemStyleContainerRef: ViewContainerRef, item: any) {\r\n    itemStyleContainerRef.clear();\r\n    if (!item) {\r\n      itemStyleContainerRef.createComponent(StyleBlankComponent);\r\n      return;\r\n    }\r\n    const componentRef = itemStyleContainerRef.createComponent(StyleComponent);\r\n    const instance: any = componentRef.instance;\r\n    instance.style = item.style;\r\n  }\r\n}\r\n"]}
|
|
@@ -15,6 +15,7 @@ import { StyleComponent } from './box-item/item-style/style/style.component';
|
|
|
15
15
|
import { PluginNotFoundComponent } from './plugin-not-found/plugin-not-found.component';
|
|
16
16
|
import { DevExtremeModule } from "devextreme-angular";
|
|
17
17
|
import { ConfigBlankComponent } from './box-item/item-config/config-blank/config-blank.component';
|
|
18
|
+
import { FormItemConfigErrorComponent } from './box-item/item-config/form-item-config-error/form-item-config-error.component';
|
|
18
19
|
import * as i0 from "@angular/core";
|
|
19
20
|
export class BoxContainerModule {
|
|
20
21
|
}
|
|
@@ -30,6 +31,7 @@ BoxContainerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", vers
|
|
|
30
31
|
ItemStyleComponent,
|
|
31
32
|
StyleBlankComponent,
|
|
32
33
|
ItemBlankComponent,
|
|
34
|
+
FormItemConfigErrorComponent,
|
|
33
35
|
StyleComponent,
|
|
34
36
|
PluginNotFoundComponent,
|
|
35
37
|
ConfigBlankComponent], imports: [CommonModule,
|
|
@@ -53,6 +55,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
53
55
|
ItemStyleComponent,
|
|
54
56
|
StyleBlankComponent,
|
|
55
57
|
ItemBlankComponent,
|
|
58
|
+
FormItemConfigErrorComponent,
|
|
56
59
|
StyleComponent,
|
|
57
60
|
PluginNotFoundComponent,
|
|
58
61
|
ConfigBlankComponent
|
|
@@ -68,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
68
71
|
]
|
|
69
72
|
}]
|
|
70
73
|
}] });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94LWNvbnRhaW5lci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1jb250YWluZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDZEQUE2RCxDQUFDO0FBQ2pHLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlEQUF5RCxDQUFDO0FBQzVGLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUMzRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUN0RixPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNoRyxPQUFPLEVBQ0wsNEJBQTRCLEVBQzdCLE1BQU0sZ0ZBQWdGLENBQUM7O0FBOEJ4RixNQUFNLE9BQU8sa0JBQWtCOzsrR0FBbEIsa0JBQWtCO2dIQUFsQixrQkFBa0IsaUJBMUIzQixxQkFBcUI7UUFDckIsb0JBQW9CO1FBQ3BCLGdCQUFnQjtRQUNoQixxQkFBcUI7UUFDckIsZ0JBQWdCO1FBQ2hCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsbUJBQW1CO1FBQ25CLGtCQUFrQjtRQUNsQixtQkFBbUI7UUFDbkIsa0JBQWtCO1FBQ2xCLDRCQUE0QjtRQUM1QixjQUFjO1FBQ2QsdUJBQXVCO1FBQ3ZCLG9CQUFvQixhQUdwQixZQUFZO1FBQ1osZ0JBQWdCLGFBR2hCLHFCQUFxQjtRQUNyQixtQkFBbUI7UUFDbkIsa0JBQWtCO2dIQUdULGtCQUFrQixZQVQzQixZQUFZO1FBQ1osZ0JBQWdCOzJGQVFQLGtCQUFrQjtrQkE1QjlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHFCQUFxQjt3QkFDckIsb0JBQW9CO3dCQUNwQixnQkFBZ0I7d0JBQ2hCLHFCQUFxQjt3QkFDckIsZ0JBQWdCO3dCQUNoQixvQkFBb0I7d0JBQ3BCLG9CQUFvQjt3QkFDcEIsbUJBQW1CO3dCQUNuQixrQkFBa0I7d0JBQ2xCLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3dCQUNsQiw0QkFBNEI7d0JBQzVCLGNBQWM7d0JBQ2QsdUJBQXVCO3dCQUN2QixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHFCQUFxQjt3QkFDckIsbUJBQW1CO3dCQUNuQixrQkFBa0I7cUJBQ25CO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge0JveENvbnRhaW5lckNvbXBvbmVudH0gZnJvbSAnLi9ib3gtY29udGFpbmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7Qm94SXRlbUhvc3REaXJlY3RpdmV9IGZyb20gJy4vYm94LWl0ZW0vYm94LWl0ZW0taG9zdC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQge0JveEl0ZW1Db21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vYm94LWl0ZW0uY29tcG9uZW50JztcclxuaW1wb3J0IHtQbHVnaW5BY3RpdmVDb21wb25lbnR9IGZyb20gXCIuL3BsdWdpbi1hY3RpdmUvcGx1Z2luLWFjdGl2ZS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtQbHVnaW5Ib3ZlckNvbXBvbmVudH0gZnJvbSBcIi4vcGx1Z2luLWhvdmVyL3BsdWdpbi1ob3Zlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEaXZpZGVyQ29tcG9uZW50fSBmcm9tIFwiLi9wbHVnaW4tYWN0aXZlL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEaXZpZGVyTGluZUNvbXBvbmVudH0gZnJvbSBcIi4vcGx1Z2luLWFjdGl2ZS9kaXZpZGVyL2RpdmlkZXItbGluZS9kaXZpZGVyLWxpbmUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SXRlbUNvbmZpZ0NvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLWNvbmZpZy9pdGVtLWNvbmZpZy5jb21wb25lbnQnO1xyXG5pbXBvcnQge0l0ZW1TdHlsZUNvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLXN0eWxlL2l0ZW0tc3R5bGUuY29tcG9uZW50JztcclxuaW1wb3J0IHtTdHlsZUJsYW5rQ29tcG9uZW50fSBmcm9tICcuL2JveC1pdGVtL2l0ZW0tc3R5bGUvc3R5bGUtYmxhbmsvc3R5bGUtYmxhbmsuY29tcG9uZW50JztcclxuaW1wb3J0IHtJdGVtQmxhbmtDb21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1ibGFuay9pdGVtLWJsYW5rLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7U3R5bGVDb21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1zdHlsZS9zdHlsZS9zdHlsZS5jb21wb25lbnQnO1xyXG5pbXBvcnQge1BsdWdpbk5vdEZvdW5kQ29tcG9uZW50fSBmcm9tICcuL3BsdWdpbi1ub3QtZm91bmQvcGx1Z2luLW5vdC1mb3VuZC5jb21wb25lbnQnO1xyXG5pbXBvcnQge0RldkV4dHJlbWVNb2R1bGV9IGZyb20gXCJkZXZleHRyZW1lLWFuZ3VsYXJcIjtcclxuaW1wb3J0IHtDb25maWdCbGFua0NvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLWNvbmZpZy9jb25maWctYmxhbmsvY29uZmlnLWJsYW5rLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7XHJcbiAgRm9ybUl0ZW1Db25maWdFcnJvckNvbXBvbmVudFxyXG59IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1jb25maWcvZm9ybS1pdGVtLWNvbmZpZy1lcnJvci9mb3JtLWl0ZW0tY29uZmlnLWVycm9yLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgQm94Q29udGFpbmVyQ29tcG9uZW50LFxyXG4gICAgQm94SXRlbUhvc3REaXJlY3RpdmUsXHJcbiAgICBCb3hJdGVtQ29tcG9uZW50LFxyXG4gICAgUGx1Z2luQWN0aXZlQ29tcG9uZW50LFxyXG4gICAgRGl2aWRlckNvbXBvbmVudCxcclxuICAgIERpdmlkZXJMaW5lQ29tcG9uZW50LFxyXG4gICAgUGx1Z2luSG92ZXJDb21wb25lbnQsXHJcbiAgICBJdGVtQ29uZmlnQ29tcG9uZW50LFxyXG4gICAgSXRlbVN0eWxlQ29tcG9uZW50LFxyXG4gICAgU3R5bGVCbGFua0NvbXBvbmVudCxcclxuICAgIEl0ZW1CbGFua0NvbXBvbmVudCxcclxuICAgIEZvcm1JdGVtQ29uZmlnRXJyb3JDb21wb25lbnQsXHJcbiAgICBTdHlsZUNvbXBvbmVudCxcclxuICAgIFBsdWdpbk5vdEZvdW5kQ29tcG9uZW50LFxyXG4gICAgQ29uZmlnQmxhbmtDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIERldkV4dHJlbWVNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIEJveENvbnRhaW5lckNvbXBvbmVudCxcclxuICAgIEl0ZW1Db25maWdDb21wb25lbnQsXHJcbiAgICBJdGVtU3R5bGVDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCb3hDb250YWluZXJNb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class FormItemConfigErrorComponent {
|
|
4
|
+
}
|
|
5
|
+
FormItemConfigErrorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormItemConfigErrorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
FormItemConfigErrorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: FormItemConfigErrorComponent, selector: "rs-form-item-config-error", ngImport: i0, template: "<div>\n <span>\u8868\u5355\u7EC4\u4EF6\u914D\u7F6E\u5FC5\u9700\u7EE7\u627F\u81EAFormItemConfigBase</span>\n</div>\n", styles: [":host{height:80px;margin:8px;display:flex;flex-flow:row nowrap;justify-content:center}:host div{flex:1;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center}:host div span{text-align:center;-webkit-user-select:none;user-select:none}\n"] });
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormItemConfigErrorComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'rs-form-item-config-error', template: "<div>\n <span>\u8868\u5355\u7EC4\u4EF6\u914D\u7F6E\u5FC5\u9700\u7EE7\u627F\u81EAFormItemConfigBase</span>\n</div>\n", styles: [":host{height:80px;margin:8px;display:flex;flex-flow:row nowrap;justify-content:center}:host div{flex:1;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center}:host div span{text-align:center;-webkit-user-select:none;user-select:none}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1pdGVtL2l0ZW0tY29uZmlnL2Zvcm0taXRlbS1jb25maWctZXJyb3IvZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1pdGVtL2l0ZW0tY29uZmlnL2Zvcm0taXRlbS1jb25maWctZXJyb3IvZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQU94QyxNQUFNLE9BQU8sNEJBQTRCOzt5SEFBNUIsNEJBQTRCOzZHQUE1Qiw0QkFBNEIsaUVDUHpDLHNIQUdBOzJGRElhLDRCQUE0QjtrQkFMeEMsU0FBUzsrQkFDRSwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3JzLWZvcm0taXRlbS1jb25maWctZXJyb3InLFxuICB0ZW1wbGF0ZVVybDogJy4vZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Zvcm0taXRlbS1jb25maWctZXJyb3IuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBGb3JtSXRlbUNvbmZpZ0Vycm9yQ29tcG9uZW50IHtcblxufVxuIiwiPGRpdj5cbiAgPHNwYW4+6KGo5Y2V57uE5Lu26YWN572u5b+F6ZyA57un5om/6IeqRm9ybUl0ZW1Db25maWdCYXNlPC9zcGFuPlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "devextreme-angular/core";
|
|
5
|
+
import * as i3 from "devextreme-angular/ui/button";
|
|
6
|
+
import * as i4 from "devextreme-angular/ui/nested";
|
|
7
|
+
import * as i5 from "devextreme-angular/ui/drop-down-box";
|
|
8
|
+
import * as i6 from "devextreme-angular/ui/tag-box";
|
|
9
|
+
import * as i7 from "devextreme-angular/ui/text-box";
|
|
10
|
+
import * as i8 from "devextreme-angular/ui/tree-list";
|
|
11
|
+
import * as i9 from "devextreme-angular/ui/validator";
|
|
12
|
+
export class FieldSelectorComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.fieldTree = [];
|
|
15
|
+
this.required = false;
|
|
16
|
+
this.label = '属性';
|
|
17
|
+
this.readonly = false;
|
|
18
|
+
this.multiple = false;
|
|
19
|
+
this.fieldChanged = new EventEmitter();
|
|
20
|
+
this.__fields = [];
|
|
21
|
+
this.suspendSelectionChanged = false;
|
|
22
|
+
}
|
|
23
|
+
set _fields(__fields) {
|
|
24
|
+
if (this.__fields !== __fields) {
|
|
25
|
+
this.__fields = __fields;
|
|
26
|
+
this.fieldChange(this.__fields);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
get _fields() {
|
|
30
|
+
return this.__fields;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
if (this.config.field) {
|
|
34
|
+
if (Array.isArray(this.config.field)) {
|
|
35
|
+
this._fields = this.config.field;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this._fields = [this.config.field];
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
fieldChange(value) {
|
|
43
|
+
if (value && value.length > 0) {
|
|
44
|
+
this.config.__formAttribute = value.join(';');
|
|
45
|
+
if (this.multiple) {
|
|
46
|
+
this.config.field = value;
|
|
47
|
+
const fields = [];
|
|
48
|
+
for (const fieldName of value) {
|
|
49
|
+
fields.push(this.getField(this.fieldTree, fieldName));
|
|
50
|
+
}
|
|
51
|
+
this.fieldChanged.emit(fields);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
this.config.field = value[0];
|
|
55
|
+
this.fieldChanged.emit(this.getField(this.fieldTree, value[0]));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
this.config.field = '';
|
|
60
|
+
this.config.__formAttribute = '';
|
|
61
|
+
this.fieldChanged.emit();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
getField(tree, field) {
|
|
65
|
+
for (const node of tree) {
|
|
66
|
+
if (node.innerName === field) {
|
|
67
|
+
return node;
|
|
68
|
+
}
|
|
69
|
+
if (node.children) {
|
|
70
|
+
const result = this.getField(node.children, field);
|
|
71
|
+
if (result) {
|
|
72
|
+
return result;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return undefined;
|
|
77
|
+
}
|
|
78
|
+
onRowPrepared($event) {
|
|
79
|
+
if ($event.rowType === 'header') {
|
|
80
|
+
$event.rowElement.style.display = 'none';
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
onCellPrepared($event) {
|
|
84
|
+
if ($event.rowType === 'data') {
|
|
85
|
+
if (!this.multiple) {
|
|
86
|
+
$event.cellElement.style.cursor = 'pointer';
|
|
87
|
+
}
|
|
88
|
+
if (this.multiple && !$event.visible && $event.data.hasItems) {
|
|
89
|
+
const checkbox = $event.cellElement.querySelector('.dx-select-checkbox');
|
|
90
|
+
checkbox.style.display = 'none';
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
onSelectionChanged($event, dropDownBox) {
|
|
95
|
+
if (this.multiple) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
if (this.suspendSelectionChanged) {
|
|
99
|
+
this.suspendSelectionChanged = false;
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
if ($event.selectedRowsData.length === 0) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
if (!$event.selectedRowsData[0].visible && $event.selectedRowsData[0].hasItems) {
|
|
106
|
+
if ($event.component.isRowExpanded($event.selectedRowKeys[0])) {
|
|
107
|
+
$event.component.collapseRow($event.selectedRowKeys[0]);
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
$event.component.expandRow($event.selectedRowKeys[0]);
|
|
111
|
+
}
|
|
112
|
+
this.suspendSelectionChanged = true;
|
|
113
|
+
$event.component.selectRows($event.currentDeselectedRowKeys[0]);
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
dropDownBox.instance.close();
|
|
117
|
+
}
|
|
118
|
+
removeItem($event, field) {
|
|
119
|
+
$event.stopPropagation();
|
|
120
|
+
const findIndex = this._fields.findIndex((innerName) => innerName === field.innerName);
|
|
121
|
+
this._fields.splice(findIndex, 1);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
FieldSelectorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FieldSelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
125
|
+
FieldSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: FieldSelectorComponent, selector: "rs-field-selector", inputs: { fieldTree: "fieldTree", config: "config", required: "required", label: "label", readonly: "readonly", multiple: "multiple" }, outputs: { fieldChanged: "fieldChanged" }, ngImport: i0, template: "<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u5C5E\u6027</span>\n <span class=\"required-mark\" *ngIf=\"required\"> *</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-drop-down-box #fieldDropDownBox\n [dataSource]=\"fieldTree\"\n valueExpr=\"innerName\"\n fieldTemplate=\"fieldTemplate\"\n contentTemplate=\"contentTemplate\"\n [showClearButton]=\"true\"\n [dropDownOptions]=\"{maxHeight: 'none', deferRendering: false}\"\n [(value)]=\"_fields\"\n [readOnly]=\"readonly\">\n <div *dxTemplate=\"let info of 'fieldTemplate'\">\n <dx-text-box [visible]=\"false\"></dx-text-box>\n <dx-tag-box [dataSource]=\"fieldTree\"\n valueExpr=\"innerName\"\n width=\"100%\"\n [openOnFieldClick]=\"false\"\n [(value)]=\"_fields\"\n [class.coast-tag-selector]=\"true\"\n [readOnly]=\"readonly\">\n <div *dxTemplate=\"let field of 'tag'\">\n <dx-button [elementAttr]=\"{ class: 'item'}\">\n <span>{{ field.caption }}</span>\n <i *ngIf=\"multiple && !readonly\" class=\"coast-icon-close\" (click)=\"removeItem($event, field)\"></i>\n </dx-button>\n </div>\n </dx-tag-box>\n </div>\n <div *dxTemplate=\"let data of 'contentTemplate'\">\n <dx-text-box mode=\"search\" placeholder=\"\u641C\u7D22...\" valueChangeEvent=\"keyup\"\n (onValueChanged)=\"dxTreeList.instance.searchByText($event.value)\"></dx-text-box>\n <dx-tree-list #dxTreeList\n [dataSource]=\"fieldTree\"\n [filterValue]=\"['visible','=',true]\"\n keyExpr=\"innerName\"\n parentIdExpr=\"parentInnerName\"\n [(selectedRowKeys)]=\"_fields\"\n [height]=\"360\"\n [showRowLines]=\"true\"\n [showBorders]=\"true\"\n [hoverStateEnabled]=\"true\"\n [rowAlternationEnabled]=\"true\"\n [columnAutoWidth]=\"true\"\n (onRowPrepared)=\"onRowPrepared($event)\"\n (onCellPrepared)=\"onCellPrepared($event)\"\n (onSelectionChanged)=\"onSelectionChanged($event, fieldDropDownBox)\">\n <dxi-column dataField=\"innerName\" dataType=\"string\" [visible]=\"false\"></dxi-column>\n <dxi-column dataField=\"caption\" dataType=\"string\" caption=\"\u540D\u79F0\"></dxi-column>\n <dxi-column dataField=\"visible\" dataType=\"boolean\" [visible]=\"false\"></dxi-column>\n <dxo-selection [mode]=\"multiple ? 'multiple' : 'single'\" [allowSelectAll]=\"false\"></dxo-selection>\n <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n </dx-tree-list>\n </div>\n <dx-validator>\n <dxi-validation-rule *ngIf=\"required\" type=\"required\" message=\"\u503C\u4E0D\u80FD\u4E3A\u7A7A\"></dxi-validation-rule>\n </dx-validator>\n </dx-drop-down-box>\n </div>\n</div>\n", styles: [":host .dx-field{margin-bottom:8px;display:flex;flex-flow:row nowrap}:host .dx-field .dx-field-label{flex:0 0 80px}:host .dx-field .dx-field-value{flex:1}:host dx-tag-box{display:block}:host dx-tag-box .item{min-height:20px}:host dx-tag-box .item .coast-icon-close{padding-left:4px}:host dx-tag-box .item .coast-icon-close:hover{color:var(--coast-danger-color, #d9534f)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }, { kind: "component", type: i3.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }, { kind: "component", type: i4.DxoSelectionComponent, selector: "dxo-selection", inputs: ["allowSelectAll", "recursive", "selectByClick", "deferred", "mode", "selectAllMode", "showCheckBoxesMode"] }, { kind: "component", type: i4.DxiColumnComponent, selector: "dxi-column", inputs: ["alignment", "allowEditing", "allowExporting", "allowFiltering", "allowFixing", "allowGrouping", "allowHeaderFiltering", "allowHiding", "allowReordering", "allowResizing", "allowSearch", "allowSorting", "autoExpandGroup", "buttons", "calculateCellValue", "calculateDisplayValue", "calculateFilterExpression", "calculateGroupValue", "calculateSortValue", "caption", "cellTemplate", "columns", "cssClass", "customizeText", "dataField", "dataType", "editCellTemplate", "editorOptions", "encodeHtml", "falseText", "filterOperations", "filterType", "filterValue", "filterValues", "fixed", "fixedPosition", "format", "formItem", "groupCellTemplate", "groupIndex", "headerCellTemplate", "headerFilter", "hidingPriority", "isBand", "lookup", "minWidth", "name", "ownerBand", "renderAsync", "selectedFilterOperation", "setCellValue", "showEditorAlways", "showInColumnChooser", "showWhenGrouped", "sortIndex", "sortingMethod", "sortOrder", "trueText", "type", "validationRules", "visible", "visibleIndex", "width"], outputs: ["filterValueChange", "filterValuesChange", "groupIndexChange", "selectedFilterOperationChange", "sortIndexChange", "sortOrderChange", "visibleChange", "visibleIndexChange"] }, { kind: "component", type: i4.DxiValidationRuleComponent, selector: "dxi-validation-rule", inputs: ["message", "trim", "type", "ignoreEmptyValue", "max", "min", "reevaluate", "validationCallback", "comparisonTarget", "comparisonType", "pattern"] }, { kind: "component", type: i4.DxoScrollingComponent, selector: "dxo-scrolling", inputs: ["columnRenderingMode", "mode", "preloadEnabled", "renderAsync", "rowRenderingMode", "scrollByContent", "scrollByThumb", "showScrollbar", "useNative"] }, { kind: "component", type: i5.DxDropDownBoxComponent, selector: "dx-drop-down-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "buttons", "contentTemplate", "dataSource", "deferRendering", "disabled", "displayExpr", "displayValueFormatter", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "items", "label", "labelMode", "maxLength", "name", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showDropDownButton", "stylingMode", "tabIndex", "text", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "valueExpr", "visible", "width"], outputs: ["onChange", "onClosed", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOpened", "onOptionChanged", "onPaste", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "contentTemplateChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "displayValueFormatterChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "itemsChange", "labelChange", "labelModeChange", "maxLengthChange", "nameChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showDropDownButtonChange", "stylingModeChange", "tabIndexChange", "textChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "valueExprChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i6.DxTagBoxComponent, selector: "dx-tag-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "applyValueMode", "buttons", "customItemCreateEvent", "dataSource", "deferRendering", "disabled", "displayExpr", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "grouped", "groupTemplate", "height", "hideSelectedItems", "hint", "hoverStateEnabled", "inputAttr", "isValid", "items", "itemTemplate", "label", "labelMode", "maxDisplayedTags", "maxFilterQueryLength", "maxLength", "minSearchLength", "multiline", "name", "noDataText", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "selectAllMode", "selectAllText", "selectedItems", "showClearButton", "showDataBeforeSearch", "showDropDownButton", "showMultiTagOnly", "showSelectionControls", "stylingMode", "tabIndex", "tagTemplate", "text", "useItemTextAsTitle", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "valueExpr", "visible", "width", "wrapItemText"], outputs: ["onChange", "onClosed", "onContentReady", "onCustomItemCreating", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onItemClick", "onKeyDown", "onKeyUp", "onMultiTagPreparing", "onOpened", "onOptionChanged", "onSelectAllValueChanged", "onSelectionChanged", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "applyValueModeChange", "buttonsChange", "customItemCreateEventChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "groupedChange", "groupTemplateChange", "heightChange", "hideSelectedItemsChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "itemsChange", "itemTemplateChange", "labelChange", "labelModeChange", "maxDisplayedTagsChange", "maxFilterQueryLengthChange", "maxLengthChange", "minSearchLengthChange", "multilineChange", "nameChange", "noDataTextChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "selectAllModeChange", "selectAllTextChange", "selectedItemsChange", "showClearButtonChange", "showDataBeforeSearchChange", "showDropDownButtonChange", "showMultiTagOnlyChange", "showSelectionControlsChange", "stylingModeChange", "tabIndexChange", "tagTemplateChange", "textChange", "useItemTextAsTitleChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "valueExprChange", "visibleChange", "widthChange", "wrapItemTextChange", "onBlur"] }, { kind: "component", type: i7.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i8.DxTreeListComponent, selector: "dx-tree-list", inputs: ["accessKey", "activeStateEnabled", "allowColumnReordering", "allowColumnResizing", "autoExpandAll", "autoNavigateToFocusedRow", "cacheEnabled", "cellHintEnabled", "columnAutoWidth", "columnChooser", "columnFixing", "columnHidingEnabled", "columnMinWidth", "columnResizingMode", "columns", "columnWidth", "customizeColumns", "dataSource", "dataStructure", "dateSerializationFormat", "disabled", "editing", "elementAttr", "errorRowEnabled", "expandedRowKeys", "expandNodesOnFiltering", "filterBuilder", "filterBuilderPopup", "filterMode", "filterPanel", "filterRow", "filterSyncEnabled", "filterValue", "focusedColumnIndex", "focusedRowEnabled", "focusedRowIndex", "focusedRowKey", "hasItemsExpr", "headerFilter", "height", "highlightChanges", "hint", "hoverStateEnabled", "itemsExpr", "keyboardNavigation", "keyExpr", "loadPanel", "noDataText", "pager", "paging", "parentIdExpr", "remoteOperations", "renderAsync", "repaintChangesOnly", "rootValue", "rowAlternationEnabled", "rowDragging", "rtlEnabled", "scrolling", "searchPanel", "selectedRowKeys", "selection", "showBorders", "showColumnHeaders", "showColumnLines", "showRowLines", "sorting", "stateStoring", "syncLookupFilterValues", "tabIndex", "toolbar", "twoWayBindingEnabled", "visible", "width", "wordWrapEnabled"], outputs: ["onAdaptiveDetailRowPreparing", "onCellClick", "onCellDblClick", "onCellHoverChanged", "onCellPrepared", "onContentReady", "onContextMenuPreparing", "onDataErrorOccurred", "onDisposing", "onEditCanceled", "onEditCanceling", "onEditingStart", "onEditorPrepared", "onEditorPreparing", "onFocusedCellChanged", "onFocusedCellChanging", "onFocusedRowChanged", "onFocusedRowChanging", "onInitialized", "onInitNewRow", "onKeyDown", "onNodesInitialized", "onOptionChanged", "onRowClick", "onRowCollapsed", "onRowCollapsing", "onRowDblClick", "onRowExpanded", "onRowExpanding", "onRowInserted", "onRowInserting", "onRowPrepared", "onRowRemoved", "onRowRemoving", "onRowUpdated", "onRowUpdating", "onRowValidating", "onSaved", "onSaving", "onSelectionChanged", "onToolbarPreparing", "accessKeyChange", "activeStateEnabledChange", "allowColumnReorderingChange", "allowColumnResizingChange", "autoExpandAllChange", "autoNavigateToFocusedRowChange", "cacheEnabledChange", "cellHintEnabledChange", "columnAutoWidthChange", "columnChooserChange", "columnFixingChange", "columnHidingEnabledChange", "columnMinWidthChange", "columnResizingModeChange", "columnsChange", "columnWidthChange", "customizeColumnsChange", "dataSourceChange", "dataStructureChange", "dateSerializationFormatChange", "disabledChange", "editingChange", "elementAttrChange", "errorRowEnabledChange", "expandedRowKeysChange", "expandNodesOnFilteringChange", "filterBuilderChange", "filterBuilderPopupChange", "filterModeChange", "filterPanelChange", "filterRowChange", "filterSyncEnabledChange", "filterValueChange", "focusedColumnIndexChange", "focusedRowEnabledChange", "focusedRowIndexChange", "focusedRowKeyChange", "hasItemsExprChange", "headerFilterChange", "heightChange", "highlightChangesChange", "hintChange", "hoverStateEnabledChange", "itemsExprChange", "keyboardNavigationChange", "keyExprChange", "loadPanelChange", "noDataTextChange", "pagerChange", "pagingChange", "parentIdExprChange", "remoteOperationsChange", "renderAsyncChange", "repaintChangesOnlyChange", "rootValueChange", "rowAlternationEnabledChange", "rowDraggingChange", "rtlEnabledChange", "scrollingChange", "searchPanelChange", "selectedRowKeysChange", "selectionChange", "showBordersChange", "showColumnHeadersChange", "showColumnLinesChange", "showRowLinesChange", "sortingChange", "stateStoringChange", "syncLookupFilterValuesChange", "tabIndexChange", "toolbarChange", "twoWayBindingEnabledChange", "visibleChange", "widthChange", "wordWrapEnabledChange"] }, { kind: "component", type: i9.DxValidatorComponent, selector: "dx-validator", inputs: ["adapter", "elementAttr", "height", "name", "validationGroup", "validationRules", "width"], outputs: ["onDisposing", "onInitialized", "onOptionChanged", "onValidated", "adapterChange", "elementAttrChange", "heightChange", "nameChange", "validationGroupChange", "validationRulesChange", "widthChange"] }] });
|
|
126
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FieldSelectorComponent, decorators: [{
|
|
127
|
+
type: Component,
|
|
128
|
+
args: [{ selector: 'rs-field-selector', template: "<div class=\"dx-field\">\n <div class=\"dx-field-label\">\n <span>\u5C5E\u6027</span>\n <span class=\"required-mark\" *ngIf=\"required\"> *</span>\n </div>\n <div class=\"dx-field-value\">\n <dx-drop-down-box #fieldDropDownBox\n [dataSource]=\"fieldTree\"\n valueExpr=\"innerName\"\n fieldTemplate=\"fieldTemplate\"\n contentTemplate=\"contentTemplate\"\n [showClearButton]=\"true\"\n [dropDownOptions]=\"{maxHeight: 'none', deferRendering: false}\"\n [(value)]=\"_fields\"\n [readOnly]=\"readonly\">\n <div *dxTemplate=\"let info of 'fieldTemplate'\">\n <dx-text-box [visible]=\"false\"></dx-text-box>\n <dx-tag-box [dataSource]=\"fieldTree\"\n valueExpr=\"innerName\"\n width=\"100%\"\n [openOnFieldClick]=\"false\"\n [(value)]=\"_fields\"\n [class.coast-tag-selector]=\"true\"\n [readOnly]=\"readonly\">\n <div *dxTemplate=\"let field of 'tag'\">\n <dx-button [elementAttr]=\"{ class: 'item'}\">\n <span>{{ field.caption }}</span>\n <i *ngIf=\"multiple && !readonly\" class=\"coast-icon-close\" (click)=\"removeItem($event, field)\"></i>\n </dx-button>\n </div>\n </dx-tag-box>\n </div>\n <div *dxTemplate=\"let data of 'contentTemplate'\">\n <dx-text-box mode=\"search\" placeholder=\"\u641C\u7D22...\" valueChangeEvent=\"keyup\"\n (onValueChanged)=\"dxTreeList.instance.searchByText($event.value)\"></dx-text-box>\n <dx-tree-list #dxTreeList\n [dataSource]=\"fieldTree\"\n [filterValue]=\"['visible','=',true]\"\n keyExpr=\"innerName\"\n parentIdExpr=\"parentInnerName\"\n [(selectedRowKeys)]=\"_fields\"\n [height]=\"360\"\n [showRowLines]=\"true\"\n [showBorders]=\"true\"\n [hoverStateEnabled]=\"true\"\n [rowAlternationEnabled]=\"true\"\n [columnAutoWidth]=\"true\"\n (onRowPrepared)=\"onRowPrepared($event)\"\n (onCellPrepared)=\"onCellPrepared($event)\"\n (onSelectionChanged)=\"onSelectionChanged($event, fieldDropDownBox)\">\n <dxi-column dataField=\"innerName\" dataType=\"string\" [visible]=\"false\"></dxi-column>\n <dxi-column dataField=\"caption\" dataType=\"string\" caption=\"\u540D\u79F0\"></dxi-column>\n <dxi-column dataField=\"visible\" dataType=\"boolean\" [visible]=\"false\"></dxi-column>\n <dxo-selection [mode]=\"multiple ? 'multiple' : 'single'\" [allowSelectAll]=\"false\"></dxo-selection>\n <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n </dx-tree-list>\n </div>\n <dx-validator>\n <dxi-validation-rule *ngIf=\"required\" type=\"required\" message=\"\u503C\u4E0D\u80FD\u4E3A\u7A7A\"></dxi-validation-rule>\n </dx-validator>\n </dx-drop-down-box>\n </div>\n</div>\n", styles: [":host .dx-field{margin-bottom:8px;display:flex;flex-flow:row nowrap}:host .dx-field .dx-field-label{flex:0 0 80px}:host .dx-field .dx-field-value{flex:1}:host dx-tag-box{display:block}:host dx-tag-box .item{min-height:20px}:host dx-tag-box .item .coast-icon-close{padding-left:4px}:host dx-tag-box .item .coast-icon-close:hover{color:var(--coast-danger-color, #d9534f)}\n"] }]
|
|
129
|
+
}], propDecorators: { fieldTree: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], config: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], required: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], label: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], readonly: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], multiple: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], fieldChanged: [{
|
|
142
|
+
type: Output
|
|
143
|
+
}] } });
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-selector.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-rs-ant/src/form/field-selector/field-selector.component.ts","../../../../../projects/ngx-rs-ant/src/form/field-selector/field-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, Output} from '@angular/core';\nimport {DxDropDownBoxComponent} from \"devextreme-angular\";\n\n@Component({\n  selector: 'rs-field-selector',\n  templateUrl: './field-selector.component.html',\n  styleUrls: ['./field-selector.component.scss']\n})\nexport class FieldSelectorComponent {\n  @Input()\n  fieldTree: any = [];\n  @Input()\n  config: any;\n  @Input()\n  required = false;\n  @Input()\n  label: string = '属性';\n  @Input()\n  readonly = false;\n  @Input()\n  multiple = false;\n  @Output()\n  fieldChanged = new EventEmitter<any>();\n\n  set _fields(__fields: any) {\n    if (this.__fields !== __fields) {\n      this.__fields = __fields;\n      this.fieldChange(this.__fields);\n    }\n  }\n\n  get _fields() {\n    return this.__fields;\n  }\n\n  protected __fields: string[] = [];\n\n  ngOnInit(): void {\n    if (this.config.field) {\n      if (Array.isArray(this.config.field)) {\n        this._fields = this.config.field;\n      } else {\n        this._fields = [this.config.field];\n      }\n    }\n  }\n\n  fieldChange(value: any): void {\n    if (value && value.length > 0) {\n      this.config.__formAttribute = value.join(';');\n      if (this.multiple) {\n        this.config.field = value;\n        const fields = [];\n        for (const fieldName of value) {\n          fields.push(this.getField(this.fieldTree, fieldName));\n        }\n        this.fieldChanged.emit(fields);\n      } else {\n        this.config.field = value[0];\n        this.fieldChanged.emit(this.getField(this.fieldTree, value[0]));\n      }\n    } else {\n      this.config.field = '';\n      this.config.__formAttribute = '';\n      this.fieldChanged.emit();\n    }\n  }\n\n  private getField(tree: any, field: any) {\n    for (const node of tree) {\n      if (node.innerName === field) {\n        return node;\n      }\n      if (node.children) {\n        const result: any = this.getField(node.children, field);\n        if (result) {\n          return result;\n        }\n      }\n    }\n    return undefined;\n  }\n\n  onRowPrepared($event: any) {\n    if ($event.rowType === 'header') {\n      $event.rowElement.style.display = 'none';\n    }\n  }\n\n  onCellPrepared($event: any) {\n    if ($event.rowType === 'data') {\n      if (!this.multiple) {\n        $event.cellElement.style.cursor = 'pointer';\n      }\n      if (this.multiple && !$event.visible && $event.data.hasItems) {\n        const checkbox = $event.cellElement.querySelector('.dx-select-checkbox');\n        checkbox.style.display = 'none';\n      }\n    }\n  }\n\n  suspendSelectionChanged = false;\n\n  onSelectionChanged($event: any, dropDownBox: DxDropDownBoxComponent) {\n    if (this.multiple) {\n      return;\n    }\n    if (this.suspendSelectionChanged) {\n      this.suspendSelectionChanged = false;\n      return;\n    }\n    if ($event.selectedRowsData.length === 0) {\n      return;\n    }\n    if (!$event.selectedRowsData[0].visible && $event.selectedRowsData[0].hasItems) {\n      if ($event.component.isRowExpanded($event.selectedRowKeys[0])) {\n        $event.component.collapseRow($event.selectedRowKeys[0]);\n      } else {\n        $event.component.expandRow($event.selectedRowKeys[0]);\n      }\n      this.suspendSelectionChanged = true;\n      $event.component.selectRows($event.currentDeselectedRowKeys[0]);\n      return;\n    }\n    dropDownBox.instance.close();\n  }\n\n  removeItem($event: any, field: any) {\n    $event.stopPropagation();\n    const findIndex = this._fields.findIndex((innerName: any) => innerName === field.innerName);\n    this._fields.splice(findIndex, 1);\n  }\n}\n","<div class=\"dx-field\">\n  <div class=\"dx-field-label\">\n    <span>属性</span>\n    <span class=\"required-mark\" *ngIf=\"required\">&nbsp;*</span>\n  </div>\n  <div class=\"dx-field-value\">\n    <dx-drop-down-box #fieldDropDownBox\n                      [dataSource]=\"fieldTree\"\n                      valueExpr=\"innerName\"\n                      fieldTemplate=\"fieldTemplate\"\n                      contentTemplate=\"contentTemplate\"\n                      [showClearButton]=\"true\"\n                      [dropDownOptions]=\"{maxHeight: 'none', deferRendering: false}\"\n                      [(value)]=\"_fields\"\n                      [readOnly]=\"readonly\">\n      <div *dxTemplate=\"let info of 'fieldTemplate'\">\n        <dx-text-box [visible]=\"false\"></dx-text-box>\n        <dx-tag-box [dataSource]=\"fieldTree\"\n                    valueExpr=\"innerName\"\n                    width=\"100%\"\n                    [openOnFieldClick]=\"false\"\n                    [(value)]=\"_fields\"\n                    [class.coast-tag-selector]=\"true\"\n                    [readOnly]=\"readonly\">\n          <div *dxTemplate=\"let field of 'tag'\">\n            <dx-button [elementAttr]=\"{ class: 'item'}\">\n              <span>{{ field.caption }}</span>\n              <i *ngIf=\"multiple && !readonly\" class=\"coast-icon-close\" (click)=\"removeItem($event, field)\"></i>\n            </dx-button>\n          </div>\n        </dx-tag-box>\n      </div>\n      <div *dxTemplate=\"let data of 'contentTemplate'\">\n        <dx-text-box mode=\"search\" placeholder=\"搜索...\" valueChangeEvent=\"keyup\"\n                     (onValueChanged)=\"dxTreeList.instance.searchByText($event.value)\"></dx-text-box>\n        <dx-tree-list #dxTreeList\n                      [dataSource]=\"fieldTree\"\n                      [filterValue]=\"['visible','=',true]\"\n                      keyExpr=\"innerName\"\n                      parentIdExpr=\"parentInnerName\"\n                      [(selectedRowKeys)]=\"_fields\"\n                      [height]=\"360\"\n                      [showRowLines]=\"true\"\n                      [showBorders]=\"true\"\n                      [hoverStateEnabled]=\"true\"\n                      [rowAlternationEnabled]=\"true\"\n                      [columnAutoWidth]=\"true\"\n                      (onRowPrepared)=\"onRowPrepared($event)\"\n                      (onCellPrepared)=\"onCellPrepared($event)\"\n                      (onSelectionChanged)=\"onSelectionChanged($event, fieldDropDownBox)\">\n          <dxi-column dataField=\"innerName\" dataType=\"string\" [visible]=\"false\"></dxi-column>\n          <dxi-column dataField=\"caption\" dataType=\"string\" caption=\"名称\"></dxi-column>\n          <dxi-column dataField=\"visible\" dataType=\"boolean\" [visible]=\"false\"></dxi-column>\n          <dxo-selection [mode]=\"multiple ? 'multiple' : 'single'\" [allowSelectAll]=\"false\"></dxo-selection>\n          <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n        </dx-tree-list>\n      </div>\n      <dx-validator>\n        <dxi-validation-rule *ngIf=\"required\" type=\"required\" message=\"值不能为空\"></dxi-validation-rule>\n      </dx-validator>\n    </dx-drop-down-box>\n  </div>\n</div>\n"]}
|
|
@@ -3,13 +3,16 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { FormComponent } from './form.component';
|
|
4
4
|
import { BoxContainerModule } from "../box-container/box-container.module";
|
|
5
5
|
import { DevExtremeModule } from "devextreme-angular";
|
|
6
|
+
import { FieldSelectorComponent } from './field-selector/field-selector.component';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export class FormModule {
|
|
8
9
|
}
|
|
9
10
|
FormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
-
FormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: FormModule, declarations: [FormComponent
|
|
11
|
+
FormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: FormModule, declarations: [FormComponent,
|
|
12
|
+
FieldSelectorComponent], imports: [CommonModule,
|
|
11
13
|
BoxContainerModule,
|
|
12
|
-
DevExtremeModule], exports: [FormComponent
|
|
14
|
+
DevExtremeModule], exports: [FormComponent,
|
|
15
|
+
FieldSelectorComponent] });
|
|
13
16
|
FormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormModule, imports: [CommonModule,
|
|
14
17
|
BoxContainerModule,
|
|
15
18
|
DevExtremeModule] });
|
|
@@ -17,7 +20,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
17
20
|
type: NgModule,
|
|
18
21
|
args: [{
|
|
19
22
|
declarations: [
|
|
20
|
-
FormComponent
|
|
23
|
+
FormComponent,
|
|
24
|
+
FieldSelectorComponent
|
|
21
25
|
],
|
|
22
26
|
imports: [
|
|
23
27
|
CommonModule,
|
|
@@ -25,8 +29,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
25
29
|
DevExtremeModule
|
|
26
30
|
],
|
|
27
31
|
exports: [
|
|
28
|
-
FormComponent
|
|
32
|
+
FormComponent,
|
|
33
|
+
FieldSelectorComponent
|
|
29
34
|
]
|
|
30
35
|
}]
|
|
31
36
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9mb3JtL2Zvcm0ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUN6RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQzs7QUFpQmpGLE1BQU0sT0FBTyxVQUFVOzt1R0FBVixVQUFVO3dHQUFWLFVBQVUsaUJBYm5CLGFBQWE7UUFDYixzQkFBc0IsYUFHdEIsWUFBWTtRQUNaLGtCQUFrQjtRQUNsQixnQkFBZ0IsYUFHaEIsYUFBYTtRQUNiLHNCQUFzQjt3R0FHYixVQUFVLFlBVG5CLFlBQVk7UUFDWixrQkFBa0I7UUFDbEIsZ0JBQWdCOzJGQU9QLFVBQVU7a0JBZnRCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGFBQWE7d0JBQ2Isc0JBQXNCO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixrQkFBa0I7d0JBQ2xCLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2Isc0JBQXNCO3FCQUN2QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0Zvcm1Db21wb25lbnR9IGZyb20gJy4vZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHtCb3hDb250YWluZXJNb2R1bGV9IGZyb20gXCIuLi9ib3gtY29udGFpbmVyL2JveC1jb250YWluZXIubW9kdWxlXCI7XG5pbXBvcnQge0RldkV4dHJlbWVNb2R1bGV9IGZyb20gXCJkZXZleHRyZW1lLWFuZ3VsYXJcIjtcbmltcG9ydCB7RmllbGRTZWxlY3RvckNvbXBvbmVudH0gZnJvbSAnLi9maWVsZC1zZWxlY3Rvci9maWVsZC1zZWxlY3Rvci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBGb3JtQ29tcG9uZW50LFxuICAgIEZpZWxkU2VsZWN0b3JDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBCb3hDb250YWluZXJNb2R1bGUsXG4gICAgRGV2RXh0cmVtZU1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRm9ybUNvbXBvbmVudCxcbiAgICBGaWVsZFNlbGVjdG9yQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRm9ybU1vZHVsZSB7XG59XG4iXX0=
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -21,6 +21,7 @@ export * from './dynamic-params/dynamic-params.component';
|
|
|
21
21
|
export * from './dynamic-params/tooltip-content-template.directive';
|
|
22
22
|
export * from './dynamic-params/dynamic-params.module';
|
|
23
23
|
export * from './form/form.component';
|
|
24
|
+
export * from './form/field-selector/field-selector.component';
|
|
24
25
|
export * from './form/form.module';
|
|
25
26
|
export * from './form/form.service';
|
|
26
27
|
export * from './fullscreen/fullscreen.directive';
|
|
@@ -31,7 +32,8 @@ export * from './modal/modal.module';
|
|
|
31
32
|
export * from './modal/modal.service';
|
|
32
33
|
export * from './pdf-viewer/pdf-viewer.component';
|
|
33
34
|
export * from './util/change-filter';
|
|
35
|
+
export * from './util/form-item-config-base';
|
|
34
36
|
export * from './util/utils';
|
|
35
37
|
export * from './websocket/websocket.module';
|
|
36
38
|
export * from './websocket/websocket.service';
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYm94LWNvbnRhaW5lci9ib3gtaXRlbS9pdGVtLWNvbmZpZy9pdGVtLWNvbmZpZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JveC1jb250YWluZXIvYm94LWl0ZW0vaXRlbS1zdHlsZS9pdGVtLXN0eWxlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYm94LWNvbnRhaW5lci9ib3gtY29udGFpbmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYm94LWNvbnRhaW5lci9ib3gtY29udGFpbmVyLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYm94LWNvbnRhaW5lci9QbHVnaW5NYW5hZ2VyJztcclxuZXhwb3J0ICogZnJvbSAnLi9jYW11bmRhLWJwbW4tZWRpdG9yL2NhbXVuZGEtYnBtbi1lZGl0b3IuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jYW11bmRhLWJwbW4tZWRpdG9yL2NhbXVuZGEtYnBtbi1lZGl0b3IubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9jb2RlLWVkaXRvci9jb2RlLWVkaXRvci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvZGUtZWRpdG9yL2NvZGUtZWRpdG9yLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL2RhdGEtZ3JpZC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtZ3JpZC9kYXRhLWdyaWQuZmFjdG9yeSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL3Jvdy1idXR0b25zLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL2RhdGEtZ3JpZC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtZ3JpZC9kYXRhLWdyaWQuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1kZXRhaWwvZGF0YS1kZXRhaWwuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9kYXRhLWRldGFpbC9kYXRhLWRldGFpbC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RyYXdlci9kcmF3ZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9kcmF3ZXIvZHJhd2VyLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZHJhd2VyL2RyYXdlci5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9keW5hbWljLXBhcmFtcy9keW5hbWljLXBhcmFtcy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcGFyYW1zL3Rvb2x0aXAtY29udGVudC10ZW1wbGF0ZS5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcGFyYW1zL2R5bmFtaWMtcGFyYW1zLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS9mb3JtLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS9maWVsZC1zZWxlY3Rvci9maWVsZC1zZWxlY3Rvci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vZm9ybS5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vZm9ybS5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9mdWxsc2NyZWVuL2Z1bGxzY3JlZW4uZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9pY29uLXNlbGVjdG9yL2ljb24tc2VsZWN0b3IuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9pY29uLXNlbGVjdG9yL2ljb24tc2VsZWN0b3IubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9tb2RhbC9tb2RhbC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL21vZGFsL21vZGFsLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwvbW9kYWwuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGRmLXZpZXdlci9wZGYtdmlld2VyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC9jaGFuZ2UtZmlsdGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL2Zvcm0taXRlbS1jb25maWctYmFzZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC91dGlscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vd2Vic29ja2V0L3dlYnNvY2tldC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL3dlYnNvY2tldC93ZWJzb2NrZXQuc2VydmljZSc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { EventEmitter } from "@angular/core";
|
|
2
|
+
export class FormItemConfigBase {
|
|
3
|
+
constructor() {
|
|
4
|
+
this.configChange = new EventEmitter();
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1pdGVtLWNvbmZpZy1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvdXRpbC9mb3JtLWl0ZW0tY29uZmlnLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUzQyxNQUFNLE9BQU8sa0JBQWtCO0lBQS9CO1FBR0UsaUJBQVksR0FBc0MsSUFBSSxZQUFZLEVBQXVCLENBQUM7SUFDNUYsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtFdmVudEVtaXR0ZXJ9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgRm9ybUl0ZW1Db25maWdCYXNlIHtcclxuICBmaWVsZFRyZWU6IGFueTtcclxuICBjb25maWc6IGFueTtcclxuICBjb25maWdDaGFuZ2U6IEV2ZW50RW1pdHRlcjxib29sZWFuIHwgdW5kZWZpbmVkPiA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbiB8IHVuZGVmaW5lZD4oKTtcclxufVxyXG4iXX0=
|