ngx-rs-ant 1.9.6 → 1.9.8

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.
@@ -29,10 +29,10 @@ export class PluginManager {
29
29
  }
30
30
  if (PluginFactory.hasType(plugin, 'form')) {
31
31
  instance.editMode = boxItem.boxContainer.editMode;
32
- instance.validationGroupName = boxItem.boxContainer.context?.__form.uniqueId;
33
- instance.tenant = boxItem.boxContainer.context?.__form.tenant;
34
- instance.className = boxItem.boxContainer.context?.__form.className;
35
- instance.oid = boxItem.boxContainer.context?.__form.oid;
32
+ instance.validationGroupName = boxItem.boxContainer.context?.__form?.uniqueId;
33
+ instance.tenant = boxItem.boxContainer.context?.__form?.tenant;
34
+ instance.className = boxItem.boxContainer.context?.__form?.className;
35
+ instance.oid = boxItem.boxContainer.context?.__form?.oid;
36
36
  instance.model = boxItem.boxContainer.context?.__model;
37
37
  instance.opener = boxItem.boxContainer.context?.__opener;
38
38
  if (boxItem.boxContainer.readonly) {
@@ -205,4 +205,4 @@ export class PluginManager {
205
205
  PluginManager.hoverItems = [];
206
206
  PluginManager.activeItem = new Subject();
207
207
  PluginManager.activeItems = {};
208
- //# 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, EventEmitter, 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: symbol, item: any }>();\r\n  static activeItems: { [id: symbol]: 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    if (PluginFactory.hasType(plugin, 'page')) {\r\n      instance.editMode = boxItem.boxContainer.editMode;\r\n      instance.tabId = boxItem.boxContainer.context?.__tabId;\r\n    }\r\n    if (PluginFactory.hasType(plugin, 'form')) {\r\n      instance.editMode = boxItem.boxContainer.editMode;\r\n      instance.validationGroupName = boxItem.boxContainer.context?.__form.uniqueId;\r\n      instance.tenant = boxItem.boxContainer.context?.__form.tenant;\r\n      instance.className = boxItem.boxContainer.context?.__form.className;\r\n      instance.oid = boxItem.boxContainer.context?.__form.oid;\r\n      instance.model = boxItem.boxContainer.context?.__model;\r\n      instance.opener = boxItem.boxContainer.context?.__opener;\r\n      if (boxItem.boxContainer.readonly) {\r\n        instance.readonly = true;\r\n      }\r\n    }\r\n    if (PluginFactory.hasType(plugin, 'modal')) {\r\n      instance.opener = boxItem.boxContainer.context?.__opener;\r\n    }\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      const wrapperDiv = this.createWrapperDiv(componentRef.location.nativeElement, boxItem.wrapperDivIndex + 1);\r\n      this.createHoverComponent(viewContainerRef, wrapperDiv, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, wrapperDiv, 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 createWrapperDiv(parent: Element, zIndex: number) {\r\n    const div = document.createElement('div');\r\n    div.style.position = 'absolute';\r\n    div.style.inset = '8px';\r\n    div.style.cursor = 'pointer';\r\n    div.style.zIndex = String(zIndex);\r\n    return parent.appendChild(div);\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, wrapperDiv: Element, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = wrapperDiv;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    wrapperDiv.appendChild(hoverElement);\r\n    this.hoverItems.push(wrapperDiv);\r\n    wrapperDiv.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    wrapperDiv.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, wrapperDiv: Element, 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 = wrapperDiv;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    wrapperDiv.appendChild(activeElement);\r\n    if (this.activeItems[id]) {\r\n      this.activeItems[id].push(wrapperDiv);\r\n    } else {\r\n      this.activeItems[id] = [wrapperDiv];\r\n    }\r\n    wrapperDiv.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, context?: 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 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      if (PluginFactory.hasType(plugin, 'page')) {\r\n        instance.configChange = new EventEmitter<boolean | undefined>();\r\n      }\r\n      if (PluginFactory.hasType(plugin, 'form')) {\r\n        instance.configChange = new EventEmitter<boolean | undefined>();\r\n        instance.tenant = context?.tenant;\r\n        instance.className = context?.className;\r\n        instance.fieldTree = context?.fieldTree;\r\n      }\r\n      instance.config = item.config.pluginConfig;\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      instance.tabViewContainerRef = item.boxItem.boxContainer.tabViewContainerRef;\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"]}
208
+ //# 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, EventEmitter, 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: symbol, item: any }>();\r\n  static activeItems: { [id: symbol]: 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    if (PluginFactory.hasType(plugin, 'page')) {\r\n      instance.editMode = boxItem.boxContainer.editMode;\r\n      instance.tabId = boxItem.boxContainer.context?.__tabId;\r\n    }\r\n    if (PluginFactory.hasType(plugin, 'form')) {\r\n      instance.editMode = boxItem.boxContainer.editMode;\r\n      instance.validationGroupName = boxItem.boxContainer.context?.__form?.uniqueId;\r\n      instance.tenant = boxItem.boxContainer.context?.__form?.tenant;\r\n      instance.className = boxItem.boxContainer.context?.__form?.className;\r\n      instance.oid = boxItem.boxContainer.context?.__form?.oid;\r\n      instance.model = boxItem.boxContainer.context?.__model;\r\n      instance.opener = boxItem.boxContainer.context?.__opener;\r\n      if (boxItem.boxContainer.readonly) {\r\n        instance.readonly = true;\r\n      }\r\n    }\r\n    if (PluginFactory.hasType(plugin, 'modal')) {\r\n      instance.opener = boxItem.boxContainer.context?.__opener;\r\n    }\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      const wrapperDiv = this.createWrapperDiv(componentRef.location.nativeElement, boxItem.wrapperDivIndex + 1);\r\n      this.createHoverComponent(viewContainerRef, wrapperDiv, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, wrapperDiv, 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 createWrapperDiv(parent: Element, zIndex: number) {\r\n    const div = document.createElement('div');\r\n    div.style.position = 'absolute';\r\n    div.style.inset = '8px';\r\n    div.style.cursor = 'pointer';\r\n    div.style.zIndex = String(zIndex);\r\n    return parent.appendChild(div);\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, wrapperDiv: Element, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = wrapperDiv;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    wrapperDiv.appendChild(hoverElement);\r\n    this.hoverItems.push(wrapperDiv);\r\n    wrapperDiv.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    wrapperDiv.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, wrapperDiv: Element, 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 = wrapperDiv;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    wrapperDiv.appendChild(activeElement);\r\n    if (this.activeItems[id]) {\r\n      this.activeItems[id].push(wrapperDiv);\r\n    } else {\r\n      this.activeItems[id] = [wrapperDiv];\r\n    }\r\n    wrapperDiv.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, context?: 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 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      if (PluginFactory.hasType(plugin, 'page')) {\r\n        instance.configChange = new EventEmitter<boolean | undefined>();\r\n      }\r\n      if (PluginFactory.hasType(plugin, 'form')) {\r\n        instance.configChange = new EventEmitter<boolean | undefined>();\r\n        instance.tenant = context?.tenant;\r\n        instance.className = context?.className;\r\n        instance.fieldTree = context?.fieldTree;\r\n      }\r\n      instance.config = item.config.pluginConfig;\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      instance.tabViewContainerRef = item.boxItem.boxContainer.tabViewContainerRef;\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"]}
@@ -21,8 +21,10 @@ export class BoxItemComponent {
21
21
  return {};
22
22
  }
23
23
  const width = this.style?.width ? this.style.width : 'auto';
24
+ const widthType = this.style?.widthType ? this.style.widthType : 'screen';
24
25
  const height = this.style?.height ? this.style.height : 'auto';
25
- return this._calcStyle(this.pDirection, width, height);
26
+ const heightType = this.style?.heightType ? this.style.heightType : 'screen';
27
+ return this._calcStyle(this.pDirection, width, widthType, height, heightType);
26
28
  }
27
29
  ngOnInit() {
28
30
  this.load();
@@ -122,23 +124,25 @@ export class BoxItemComponent {
122
124
  }
123
125
  calcStyle(item) {
124
126
  const width = item.style?.width ? item.style.width : 'auto';
127
+ const widthType = item.style?.widthType ? item.style.widthType : 'screen';
125
128
  const height = item.style?.height ? item.style.height : 'auto';
129
+ const heightType = item.style?.heightType ? item.style.heightType : 'screen';
126
130
  return {
127
- ...this._calcStyle(this.config.direction, width, height),
131
+ ...this._calcStyle(this.config.direction, width, widthType, height, heightType),
128
132
  position: 'relative'
129
133
  };
130
134
  }
131
- _calcStyle(direction, width, height) {
135
+ _calcStyle(direction, width, widthType, height, heightType) {
132
136
  if (direction === 'row') {
133
137
  return {
134
- flex: width === 'auto' ? '1' : '0 0 ' + width,
138
+ flex: width === 'auto' ? (widthType === 'screen' ? '1' : 'none') : '0 0 ' + width,
135
139
  height
136
140
  };
137
141
  }
138
142
  else if (direction === 'column') {
139
143
  return {
140
144
  width,
141
- flex: height === 'auto' ? 'auto' : '0 0 ' + height
145
+ flex: height === 'auto' ? (heightType === 'screen' ? 'auto' : 'none') : '0 0 ' + height
142
146
  };
143
147
  }
144
148
  return {};
@@ -200,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
200
204
  type: ViewChildren,
201
205
  args: [BoxItemHostDirective]
202
206
  }] } });
203
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"box-item.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-rs-ant/src/box-container/box-item/box-item.component.ts","../../../../../projects/ngx-rs-ant/src/box-container/box-item/box-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, OnInit, Output, QueryList, ViewChildren} from '@angular/core';\nimport {BoxItemHostDirective} from './box-item-host.directive';\nimport {PluginManager} from '../PluginManager';\nimport {ItemBlankComponent} from \"./item-blank/item-blank.component\";\n\n@Component({\n  selector: 'rs-box-item',\n  templateUrl: './box-item.component.html',\n  styleUrls: ['./box-item.component.scss']\n})\nexport class BoxItemComponent implements OnInit {\n  boxContainer: any;\n  style: any = {};\n  config: any = {};\n  pDirection?: 'row' | 'column';\n  wrapperDivIndex: number = 10;\n\n  @HostBinding('style.flex-direction') get _direction() {\n    return this.config.direction;\n  }\n\n  @HostBinding('style') get _style() {\n    if (this.pDirection) {\n      return {};\n    }\n    const width = this.style?.width ? this.style.width : 'auto';\n    const height = this.style?.height ? this.style.height : 'auto';\n    return this._calcStyle(this.pDirection, width, height);\n  }\n\n  @Output()\n  leaveOneItem = new EventEmitter();\n  @ViewChildren(BoxItemHostDirective) itemHosts!: QueryList<BoxItemHostDirective>;\n\n  ngOnInit(): void {\n    this.load();\n  }\n\n  load(activeIndex?: number) {\n    setTimeout(() => {\n      for (let i = 0; i < this.itemHosts.length; i++) {\n        const itemHost: any = this.itemHosts.get(i);\n        itemHost.viewContainerRef.clear();\n        const item = this.config.list[i];\n        switch (item.type) {\n          case 'plugin':\n            const componentRef = PluginManager.createComponent(this, i, item.style, item.config);\n            if (activeIndex === i) {\n              componentRef.location.nativeElement.click();\n            }\n            break;\n          case 'item':\n            const boxItemComponentRef = itemHost.viewContainerRef.createComponent(BoxItemComponent);\n            const instance = boxItemComponentRef.instance;\n            instance.boxContainer = this.boxContainer;\n            instance.style = item.style;\n            instance.config = item.config;\n            instance.pDirection = this.config.direction;\n            instance.wrapperDivIndex = this.wrapperDivIndex + 1;\n            if (this.boxContainer.editMode) {\n              boxItemComponentRef.location.nativeElement.style.margin = '8px';\n              instance.leaveOneItem.subscribe((item: any) => {\n                if (item.type === 'item' && item.direction === this.config.direction) {\n                  this.config.list.splice(i, 1, ...item.list);\n                } else {\n                  this.config.list.splice(i, 1, item);\n                }\n                this.load();\n              });\n              const wrapperDiv = PluginManager.createWrapperDiv(boxItemComponentRef.location.nativeElement, this.wrapperDivIndex + 1);\n              PluginManager.createHoverComponent(itemHost.viewContainerRef, wrapperDiv, '格子容器');\n              PluginManager.createActiveComponent(this, i, wrapperDiv, boxItemComponentRef, item.style, {\n                name: 'coast-box-container',\n                caption: '格子容器'\n              }, false);\n            }\n            break;\n          case 'blank':\n          default:\n            if (this.boxContainer.editMode) {\n              this.createBlankComponent(i);\n            }\n            break;\n        }\n      }\n    });\n  }\n\n  private createBlankComponent(index: number) {\n    const viewContainerRef: any = this.itemHosts.get(index)?.viewContainerRef;\n    const containerBlankComponentRef: any = viewContainerRef.createComponent(ItemBlankComponent);\n    containerBlankComponentRef.instance.onRemove = () => {\n      this.config.list.splice(index, 1);\n      if (this.config.list.length === 1) {\n        this.leaveOneItem.emit(this.config.list[0]);\n      } else {\n        this.load();\n      }\n    };\n    const wrapperDiv = PluginManager.createWrapperDiv(containerBlankComponentRef.location.nativeElement, this.wrapperDivIndex + 1);\n    PluginManager.createHoverComponent(viewContainerRef, wrapperDiv, '占位格');\n    const activeComponentRef = PluginManager.createActiveComponent(this, index, wrapperDiv, containerBlankComponentRef,\n      this.config.list[index].style, {\n        name: 'coast-box-container',\n        caption: '占位格'\n      }, this.config.list.length > 1);\n    activeComponentRef.instance.showDivider = true;\n    activeComponentRef.instance.splitItem = (direction: 'row' | 'column') => {\n      if (this.config.direction === direction) {\n        this.config.list.splice(index + 1, 0, {type: 'blank', style: {}});\n        this.load();\n      } else {\n        if (this.config.list.length === 1) {\n          this.config.direction = direction;\n          this.config.list.push({type: 'blank', style: {}});\n        } else {\n          this.config.list.splice(index, 1, {\n            type: 'item',\n            style: {},\n            config: {\n              direction,\n              list: [this.config.list[index], {type: 'blank', style: {}}]\n            }\n          });\n        }\n        this.load();\n      }\n    };\n  }\n\n  calcStyle(item: any) {\n    const width = item.style?.width ? item.style.width : 'auto';\n    const height = item.style?.height ? item.style.height : 'auto';\n    return {\n      ...this._calcStyle(this.config.direction, width, height),\n      position: 'relative'\n    };\n  }\n\n  private _calcStyle(direction: any, width: string, height: string) {\n    if (direction === 'row') {\n      return {\n        flex: width === 'auto' ? '1' : '0 0 ' + width,\n        height\n      }\n    } else if (direction === 'column') {\n      return {\n        width,\n        flex: height === 'auto' ? 'auto' : '0 0 ' + height\n      }\n    }\n    return {};\n  }\n\n  dragOverComponent: any;\n\n  onDragMove($event: any) {\n    if ($event.fromData === $event.toData) {\n      this.dragOverComponent?.instance()?.element()?.classList?.remove('active');\n      delete this.dragOverComponent;\n      return;\n    }\n    if ($event.toComponent !== this.dragOverComponent) {\n      this.dragOverComponent?.instance()?.element()?.classList?.remove('active');\n      this.dragOverComponent = $event.toComponent;\n      this.dragOverComponent.instance().element().classList.add('active');\n    }\n  }\n\n  onDragEnd($event: any) {\n    this.dragOverComponent?.instance()?.element()?.classList?.remove('active');\n    delete this.dragOverComponent;\n    const toBoxItem = $event.toData.boxItem;\n    const toIndex = $event.toData.index;\n    const fromIndex = $event.fromData.index;\n    const fromBoxItemConfig = this.config.list[fromIndex].config;\n    if ($event.toData.item.type === 'plugin') {\n      this.config.list[fromIndex].config = toBoxItem.config.list[toIndex].config;\n      this.load();\n      toBoxItem.config.list[toIndex].config = fromBoxItemConfig;\n    } else if ($event.toData.item.type === 'blank') {\n      this.config.list.splice(fromIndex, 1, {type: 'blank', style: this.config.list[fromIndex].style});\n      this.load();\n      toBoxItem.config.list[toIndex] = {\n        type: 'plugin',\n        style: toBoxItem.config.list[toIndex].style,\n        config: {\n          name: fromBoxItemConfig.name,\n          pluginConfig: fromBoxItemConfig.pluginConfig || {}\n        }\n      };\n    }\n    toBoxItem.load(toIndex);\n    $event.cancel = true;\n  }\n}\n","<ng-container *ngFor=\"let item of config.list; index as index\">\n  <ng-container *ngIf=\"boxContainer.editMode\">\n    <ng-container *ngIf=\"item.type === 'plugin'\">\n      <dx-draggable [ngStyle]=\"calcStyle(item)\"\n                    [data]=\"{boxItem: this, item, index}\"\n                    handle=\".coast-icon-drag\"\n                    group=\"rsBoxContainerDragGroup\"\n                    (onDragMove)=\"onDragMove($event)\"\n                    (onDragEnd)=\"onDragEnd($event)\">\n        <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n      </dx-draggable>\n    </ng-container>\n    <ng-container *ngIf=\"item.type === 'item'\">\n      <div [ngStyle]=\"calcStyle(item)\">\n        <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n      </div>\n    </ng-container>\n    <ng-container *ngIf=\"item.type === 'blank'\">\n      <dx-draggable [ngStyle]=\"calcStyle(item)\"\n                    [data]=\"{boxItem: this, item, index}\"\n                    group=\"rsBoxContainerDragGroup\"\n                    (onDragStart)=\"$event.cancel = true\">\n        <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n      </dx-draggable>\n    </ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"!boxContainer.editMode\">\n    <div [ngStyle]=\"calcStyle(item)\">\n      <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"box-item.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-rs-ant/src/box-container/box-item/box-item.component.ts","../../../../../projects/ngx-rs-ant/src/box-container/box-item/box-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, OnInit, Output, QueryList, ViewChildren} from '@angular/core';\nimport {BoxItemHostDirective} from './box-item-host.directive';\nimport {PluginManager} from '../PluginManager';\nimport {ItemBlankComponent} from \"./item-blank/item-blank.component\";\n\n@Component({\n  selector: 'rs-box-item',\n  templateUrl: './box-item.component.html',\n  styleUrls: ['./box-item.component.scss']\n})\nexport class BoxItemComponent implements OnInit {\n  boxContainer: any;\n  style: any = {};\n  config: any = {};\n  pDirection?: 'row' | 'column';\n  wrapperDivIndex: number = 10;\n\n  @HostBinding('style.flex-direction') get _direction() {\n    return this.config.direction;\n  }\n\n  @HostBinding('style') get _style() {\n    if (this.pDirection) {\n      return {};\n    }\n    const width = this.style?.width ? this.style.width : 'auto';\n    const widthType = this.style?.widthType ? this.style.widthType : 'screen';\n    const height = this.style?.height ? this.style.height : 'auto';\n    const heightType = this.style?.heightType ? this.style.heightType : 'screen';\n    return this._calcStyle(this.pDirection, width, widthType, height, heightType);\n  }\n\n  @Output()\n  leaveOneItem = new EventEmitter();\n  @ViewChildren(BoxItemHostDirective) itemHosts!: QueryList<BoxItemHostDirective>;\n\n  ngOnInit(): void {\n    this.load();\n  }\n\n  load(activeIndex?: number) {\n    setTimeout(() => {\n      for (let i = 0; i < this.itemHosts.length; i++) {\n        const itemHost: any = this.itemHosts.get(i);\n        itemHost.viewContainerRef.clear();\n        const item = this.config.list[i];\n        switch (item.type) {\n          case 'plugin':\n            const componentRef = PluginManager.createComponent(this, i, item.style, item.config);\n            if (activeIndex === i) {\n              componentRef.location.nativeElement.click();\n            }\n            break;\n          case 'item':\n            const boxItemComponentRef = itemHost.viewContainerRef.createComponent(BoxItemComponent);\n            const instance = boxItemComponentRef.instance;\n            instance.boxContainer = this.boxContainer;\n            instance.style = item.style;\n            instance.config = item.config;\n            instance.pDirection = this.config.direction;\n            instance.wrapperDivIndex = this.wrapperDivIndex + 1;\n            if (this.boxContainer.editMode) {\n              boxItemComponentRef.location.nativeElement.style.margin = '8px';\n              instance.leaveOneItem.subscribe((item: any) => {\n                if (item.type === 'item' && item.direction === this.config.direction) {\n                  this.config.list.splice(i, 1, ...item.list);\n                } else {\n                  this.config.list.splice(i, 1, item);\n                }\n                this.load();\n              });\n              const wrapperDiv = PluginManager.createWrapperDiv(boxItemComponentRef.location.nativeElement, this.wrapperDivIndex + 1);\n              PluginManager.createHoverComponent(itemHost.viewContainerRef, wrapperDiv, '格子容器');\n              PluginManager.createActiveComponent(this, i, wrapperDiv, boxItemComponentRef, item.style, {\n                name: 'coast-box-container',\n                caption: '格子容器'\n              }, false);\n            }\n            break;\n          case 'blank':\n          default:\n            if (this.boxContainer.editMode) {\n              this.createBlankComponent(i);\n            }\n            break;\n        }\n      }\n    });\n  }\n\n  private createBlankComponent(index: number) {\n    const viewContainerRef: any = this.itemHosts.get(index)?.viewContainerRef;\n    const containerBlankComponentRef: any = viewContainerRef.createComponent(ItemBlankComponent);\n    containerBlankComponentRef.instance.onRemove = () => {\n      this.config.list.splice(index, 1);\n      if (this.config.list.length === 1) {\n        this.leaveOneItem.emit(this.config.list[0]);\n      } else {\n        this.load();\n      }\n    };\n    const wrapperDiv = PluginManager.createWrapperDiv(containerBlankComponentRef.location.nativeElement, this.wrapperDivIndex + 1);\n    PluginManager.createHoverComponent(viewContainerRef, wrapperDiv, '占位格');\n    const activeComponentRef = PluginManager.createActiveComponent(this, index, wrapperDiv, containerBlankComponentRef,\n      this.config.list[index].style, {\n        name: 'coast-box-container',\n        caption: '占位格'\n      }, this.config.list.length > 1);\n    activeComponentRef.instance.showDivider = true;\n    activeComponentRef.instance.splitItem = (direction: 'row' | 'column') => {\n      if (this.config.direction === direction) {\n        this.config.list.splice(index + 1, 0, {type: 'blank', style: {}});\n        this.load();\n      } else {\n        if (this.config.list.length === 1) {\n          this.config.direction = direction;\n          this.config.list.push({type: 'blank', style: {}});\n        } else {\n          this.config.list.splice(index, 1, {\n            type: 'item',\n            style: {},\n            config: {\n              direction,\n              list: [this.config.list[index], {type: 'blank', style: {}}]\n            }\n          });\n        }\n        this.load();\n      }\n    };\n  }\n\n  calcStyle(item: any) {\n    const width = item.style?.width ? item.style.width : 'auto';\n    const widthType = item.style?.widthType ? item.style.widthType : 'screen';\n    const height = item.style?.height ? item.style.height : 'auto';\n    const heightType = item.style?.heightType ? item.style.heightType : 'screen';\n    return {\n      ...this._calcStyle(this.config.direction, width, widthType, height, heightType),\n      position: 'relative'\n    };\n  }\n\n  private _calcStyle(direction: any, width: string, widthType: string, height: string, heightType: string) {\n    if (direction === 'row') {\n      return {\n        flex: width === 'auto' ? (widthType === 'screen' ? '1' : 'none') : '0 0 ' + width,\n        height\n      }\n    } else if (direction === 'column') {\n      return {\n        width,\n        flex: height === 'auto' ? (heightType === 'screen' ? 'auto' : 'none') : '0 0 ' + height\n      }\n    }\n    return {};\n  }\n\n  dragOverComponent: any;\n\n  onDragMove($event: any) {\n    if ($event.fromData === $event.toData) {\n      this.dragOverComponent?.instance()?.element()?.classList?.remove('active');\n      delete this.dragOverComponent;\n      return;\n    }\n    if ($event.toComponent !== this.dragOverComponent) {\n      this.dragOverComponent?.instance()?.element()?.classList?.remove('active');\n      this.dragOverComponent = $event.toComponent;\n      this.dragOverComponent.instance().element().classList.add('active');\n    }\n  }\n\n  onDragEnd($event: any) {\n    this.dragOverComponent?.instance()?.element()?.classList?.remove('active');\n    delete this.dragOverComponent;\n    const toBoxItem = $event.toData.boxItem;\n    const toIndex = $event.toData.index;\n    const fromIndex = $event.fromData.index;\n    const fromBoxItemConfig = this.config.list[fromIndex].config;\n    if ($event.toData.item.type === 'plugin') {\n      this.config.list[fromIndex].config = toBoxItem.config.list[toIndex].config;\n      this.load();\n      toBoxItem.config.list[toIndex].config = fromBoxItemConfig;\n    } else if ($event.toData.item.type === 'blank') {\n      this.config.list.splice(fromIndex, 1, {type: 'blank', style: this.config.list[fromIndex].style});\n      this.load();\n      toBoxItem.config.list[toIndex] = {\n        type: 'plugin',\n        style: toBoxItem.config.list[toIndex].style,\n        config: {\n          name: fromBoxItemConfig.name,\n          pluginConfig: fromBoxItemConfig.pluginConfig || {}\n        }\n      };\n    }\n    toBoxItem.load(toIndex);\n    $event.cancel = true;\n  }\n}\n","<ng-container *ngFor=\"let item of config.list; index as index\">\n  <ng-container *ngIf=\"boxContainer.editMode\">\n    <ng-container *ngIf=\"item.type === 'plugin'\">\n      <dx-draggable [ngStyle]=\"calcStyle(item)\"\n                    [data]=\"{boxItem: this, item, index}\"\n                    handle=\".coast-icon-drag\"\n                    group=\"rsBoxContainerDragGroup\"\n                    (onDragMove)=\"onDragMove($event)\"\n                    (onDragEnd)=\"onDragEnd($event)\">\n        <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n      </dx-draggable>\n    </ng-container>\n    <ng-container *ngIf=\"item.type === 'item'\">\n      <div [ngStyle]=\"calcStyle(item)\">\n        <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n      </div>\n    </ng-container>\n    <ng-container *ngIf=\"item.type === 'blank'\">\n      <dx-draggable [ngStyle]=\"calcStyle(item)\"\n                    [data]=\"{boxItem: this, item, index}\"\n                    group=\"rsBoxContainerDragGroup\"\n                    (onDragStart)=\"$event.cancel = true\">\n        <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n      </dx-draggable>\n    </ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"!boxContainer.editMode\">\n    <div [ngStyle]=\"calcStyle(item)\">\n      <ng-template rsBoxItemHost [hostId]=\"index\"></ng-template>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
@@ -9,7 +9,9 @@ export class StyleComponent {
9
9
  }
10
10
  ngOnInit() {
11
11
  this.style.width = this.style.width ? this.style.width : 'auto';
12
+ this.style.widthType = this.style.widthType ? this.style.widthType : 'screen';
12
13
  this.style.height = this.style.height ? this.style.height : 'auto';
14
+ this.style.heightType = this.style.heightType ? this.style.heightType : 'screen';
13
15
  if (this.style.width !== 'auto') {
14
16
  this.width = this.style.width.substring(0, this.style.width.length - 2);
15
17
  }
@@ -40,9 +42,9 @@ export class StyleComponent {
40
42
  }
41
43
  }
42
44
  StyleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: StyleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
43
- StyleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: StyleComponent, selector: "rs-style", ngImport: i0, template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\"\n [readOnly]=\"style.width === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\"\n [readOnly]=\"style.height === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.DxNumberBoxComponent, selector: "dx-number-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "format", "height", "hint", "hoverStateEnabled", "inputAttr", "invalidValueMessage", "isDirty", "isValid", "label", "labelMode", "max", "min", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showSpinButtons", "step", "stylingMode", "tabIndex", "text", "useLargeSpinButtons", "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", "formatChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "invalidValueMessageChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maxChange", "minChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showSpinButtonsChange", "stepChange", "stylingModeChange", "tabIndexChange", "textChange", "useLargeSpinButtonsChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }] });
45
+ StyleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: StyleComponent, selector: "rs-style", ngImport: i0, template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.widthType || style.widthType === 'screen' ? 'active' : ''\"\n (click)=\"style.widthType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.widthType && style.widthType === 'content' ? 'active' : ''\"\n (click)=\"style.widthType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.heightType || style.heightType === 'screen' ? 'active' : ''\"\n (click)=\"style.heightType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.heightType && style.heightType === 'content' ? 'active' : ''\"\n (click)=\"style.heightType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DxNumberBoxComponent, selector: "dx-number-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "format", "height", "hint", "hoverStateEnabled", "inputAttr", "invalidValueMessage", "isDirty", "isValid", "label", "labelMode", "max", "min", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showSpinButtons", "step", "stylingMode", "tabIndex", "text", "useLargeSpinButtons", "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", "formatChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "invalidValueMessageChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maxChange", "minChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showSpinButtonsChange", "stepChange", "stylingModeChange", "tabIndexChange", "textChange", "useLargeSpinButtonsChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }] });
44
46
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: StyleComponent, decorators: [{
45
47
  type: Component,
46
- args: [{ selector: 'rs-style', template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\"\n [readOnly]=\"style.width === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\"\n [readOnly]=\"style.height === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"] }]
48
+ args: [{ selector: 'rs-style', template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.widthType || style.widthType === 'screen' ? 'active' : ''\"\n (click)=\"style.widthType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.widthType && style.widthType === 'content' ? 'active' : ''\"\n (click)=\"style.widthType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.heightType || style.heightType === 'screen' ? 'active' : ''\"\n (click)=\"style.heightType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.heightType && style.heightType === 'content' ? 'active' : ''\"\n (click)=\"style.heightType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"] }]
47
49
  }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvYm94LWNvbnRhaW5lci9ib3gtaXRlbS9pdGVtLXN0eWxlL3N0eWxlL3N0eWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL2JveC1jb250YWluZXIvYm94LWl0ZW0vaXRlbS1zdHlsZS9zdHlsZS9zdHlsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFTLE1BQU0sZUFBZSxDQUFDOzs7O0FBT2hELE1BQU0sT0FBTyxjQUFjO0lBTDNCO1FBT0UsVUFBSyxHQUFXLENBQUMsQ0FBQztRQUNsQixXQUFNLEdBQVcsQ0FBQyxDQUFDO0tBaUNwQjtJQS9CQyxRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFDaEUsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFDbkUsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssS0FBSyxNQUFNLEVBQUU7WUFDL0IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztTQUN6RTtRQUNELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssTUFBTSxFQUFFO1lBQ2hDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUM7U0FDNUU7SUFDSCxDQUFDO0lBRUQsTUFBTSxDQUFDLElBQVksRUFBRSxLQUFVO1FBQzdCLE1BQU0sSUFBSSxHQUFRLElBQUksQ0FBQztRQUN2QixJQUFJLEtBQUssS0FBSyxNQUFNLEVBQUU7WUFDcEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxNQUFNLENBQUM7WUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNoQjthQUFNO1lBQ0wsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDZixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDO2FBQ3BCO1lBQ0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDO1NBQ3RDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxJQUFZLEVBQUUsS0FBVTtRQUM3QixJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxHQUFHLElBQUksQ0FBQztTQUNqQzthQUFNO1lBQ0wsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxNQUFNLENBQUM7U0FDM0I7SUFDSCxDQUFDOzs0R0FuQ1UsY0FBYztnR0FBZCxjQUFjLGdEQ1AzQix1a0VBc0RBOzRGRC9DYSxjQUFjO2tCQUwxQixTQUFTOytCQUNFLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncnMtc3R5bGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3R5bGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zdHlsZS5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFN0eWxlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgc3R5bGU6IGFueTtcbiAgd2lkdGg6IG51bWJlciA9IDA7XG4gIGhlaWdodDogbnVtYmVyID0gMDtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnN0eWxlLndpZHRoID0gdGhpcy5zdHlsZS53aWR0aCA/IHRoaXMuc3R5bGUud2lkdGggOiAnYXV0byc7XG4gICAgdGhpcy5zdHlsZS5oZWlnaHQgPSB0aGlzLnN0eWxlLmhlaWdodCA/IHRoaXMuc3R5bGUuaGVpZ2h0IDogJ2F1dG8nO1xuICAgIGlmICh0aGlzLnN0eWxlLndpZHRoICE9PSAnYXV0bycpIHtcbiAgICAgIHRoaXMud2lkdGggPSB0aGlzLnN0eWxlLndpZHRoLnN1YnN0cmluZygwLCB0aGlzLnN0eWxlLndpZHRoLmxlbmd0aCAtIDIpO1xuICAgIH1cbiAgICBpZiAodGhpcy5zdHlsZS5oZWlnaHQgIT09ICdhdXRvJykge1xuICAgICAgdGhpcy5oZWlnaHQgPSB0aGlzLnN0eWxlLmhlaWdodC5zdWJzdHJpbmcoMCwgdGhpcy5zdHlsZS5oZWlnaHQubGVuZ3RoIC0gMik7XG4gICAgfVxuICB9XG5cbiAgc2VsZWN0KG5hbWU6IHN0cmluZywgdmFsdWU6IGFueSkge1xuICAgIGNvbnN0IHRoYXQ6IGFueSA9IHRoaXM7XG4gICAgaWYgKHZhbHVlID09PSAnYXV0bycpIHtcbiAgICAgIHRoaXMuc3R5bGVbbmFtZV0gPSAnYXV0byc7XG4gICAgICB0aGF0W25hbWVdID0gMDtcbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKCF0aGF0W25hbWVdKSB7XG4gICAgICAgIHRoYXRbbmFtZV0gPSB2YWx1ZTtcbiAgICAgIH1cbiAgICAgIHRoaXMuc3R5bGVbbmFtZV0gPSB0aGF0W25hbWVdICsgJ3B4JztcbiAgICB9XG4gIH1cblxuICB0eXBpbmcobmFtZTogc3RyaW5nLCB2YWx1ZTogYW55KSB7XG4gICAgaWYgKHZhbHVlKSB7XG4gICAgICB0aGlzLnN0eWxlW25hbWVdID0gdmFsdWUgKyAncHgnO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnN0eWxlW25hbWVdID0gJ2F1dG8nO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImNvbmZpZy1pdGVtXCI+XG4gIDxkaXYgY2xhc3M9XCJpdGVtLXRpdGxlXCI+5a695bqm57G75Z6LPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJpdGVtLXNldHRpbmdcIj5cbiAgICA8ZGl2IGNsYXNzPVwiY2FyZC1zdHlsZS1yYWRpb1wiPlxuICAgICAgPGRpdiBjbGFzcz1cInJhZGlvLXZhbHVlXCIgW25nQ2xhc3NdPVwiIXN0eWxlLndpZHRoIHx8IHN0eWxlLndpZHRoID09PSAnYXV0bycgPyAnYWN0aXZlJyA6ICcnXCJcbiAgICAgICAgICAgKGNsaWNrKT1cInNlbGVjdCgnd2lkdGgnLCdhdXRvJylcIj5cbiAgICAgICAgPHNwYW4+6Ieq6YCC5bqUPC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwicmFkaW8tdmFsdWVcIiBbbmdDbGFzc109XCJzdHlsZS53aWR0aCAmJiBzdHlsZS53aWR0aCAhPT0gJ2F1dG8nID8gJ2FjdGl2ZScgOiAnJ1wiXG4gICAgICAgICAgIChjbGljayk9XCJzZWxlY3QoJ3dpZHRoJywyNDApXCI+XG4gICAgICAgIDxzcGFuPuWbuuWumuWAvDwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuPGRpdiBjbGFzcz1cImNvbmZpZy1pdGVtXCI+XG4gIDxkaXYgY2xhc3M9XCJpdGVtLXRpdGxlXCI+5Zu65a6a5a695bqmPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJpdGVtLXNldHRpbmdcIj5cbiAgICA8ZHgtbnVtYmVyLWJveCBbbWluXT1cIjBcIlxuICAgICAgICAgICAgICAgICAgIFtzaG93U3BpbkJ1dHRvbnNdPVwidHJ1ZVwiXG4gICAgICAgICAgICAgICAgICAgW3Nob3dDbGVhckJ1dHRvbl09XCJ0cnVlXCJcbiAgICAgICAgICAgICAgICAgICBbKHZhbHVlKV09XCJ3aWR0aFwiXG4gICAgICAgICAgICAgICAgICAgKG9uVmFsdWVDaGFuZ2VkKT1cInR5cGluZygnd2lkdGgnLCAkZXZlbnQudmFsdWUpXCJcbiAgICAgICAgICAgICAgICAgICBbcmVhZE9ubHldPVwic3R5bGUud2lkdGggPT09ICdhdXRvJ1wiPlxuICAgIDwvZHgtbnVtYmVyLWJveD5cbiAgPC9kaXY+XG48L2Rpdj5cbjxkaXYgY2xhc3M9XCJjb25maWctaXRlbVwiPlxuICA8ZGl2IGNsYXNzPVwiaXRlbS10aXRsZVwiPumrmOW6puexu+WeizwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiaXRlbS1zZXR0aW5nXCI+XG4gICAgPGRpdiBjbGFzcz1cImNhcmQtc3R5bGUtcmFkaW9cIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby12YWx1ZVwiIFtuZ0NsYXNzXT1cIiFzdHlsZS5oZWlnaHQgfHwgc3R5bGUuaGVpZ2h0ID09PSAnYXV0bycgPyAnYWN0aXZlJyA6ICcnXCJcbiAgICAgICAgICAgKGNsaWNrKT1cInNlbGVjdCgnaGVpZ2h0JywnYXV0bycpXCI+XG4gICAgICAgIDxzcGFuPuiHqumAguW6lDwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cInJhZGlvLXZhbHVlXCIgW25nQ2xhc3NdPVwic3R5bGUuaGVpZ2h0ICYmIHN0eWxlLmhlaWdodCAhPT0gJ2F1dG8nID8gJ2FjdGl2ZScgOiAnJ1wiXG4gICAgICAgICAgIChjbGljayk9XCJzZWxlY3QoJ2hlaWdodCcsODAwKVwiPlxuICAgICAgICA8c3Bhbj7lm7rlrprlgLw8L3NwYW4+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbjxkaXYgY2xhc3M9XCJjb25maWctaXRlbVwiPlxuICA8ZGl2IGNsYXNzPVwiaXRlbS10aXRsZVwiPuWbuuWumumrmOW6pjwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiaXRlbS1zZXR0aW5nXCI+XG4gICAgPGR4LW51bWJlci1ib3ggW21pbl09XCIwXCJcbiAgICAgICAgICAgICAgICAgICBbc2hvd1NwaW5CdXR0b25zXT1cInRydWVcIlxuICAgICAgICAgICAgICAgICAgIFtzaG93Q2xlYXJCdXR0b25dPVwidHJ1ZVwiXG4gICAgICAgICAgICAgICAgICAgWyh2YWx1ZSldPVwiaGVpZ2h0XCJcbiAgICAgICAgICAgICAgICAgICAob25WYWx1ZUNoYW5nZWQpPVwidHlwaW5nKCdoZWlnaHQnLCAkZXZlbnQudmFsdWUpXCJcbiAgICAgICAgICAgICAgICAgICBbcmVhZE9ubHldPVwic3R5bGUuaGVpZ2h0ID09PSAnYXV0bydcIj5cbiAgICA8L2R4LW51bWJlci1ib3g+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
50
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"style.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-rs-ant/src/box-container/box-item/item-style/style/style.component.ts","../../../../../../../projects/ngx-rs-ant/src/box-container/box-item/item-style/style/style.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAS,MAAM,eAAe,CAAC;;;;AAOhD,MAAM,OAAO,cAAc;IAL3B;QAOE,UAAK,GAAW,CAAC,CAAC;QAClB,WAAM,GAAW,CAAC,CAAC;KAmCpB;IAjCC,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;QAChE,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC9E,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;QACnE,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC;QACjF,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,MAAM,EAAE;YAC/B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;SACzE;QACD,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,EAAE;YAChC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;SAC5E;IACH,CAAC;IAED,MAAM,CAAC,IAAY,EAAE,KAAU;QAC7B,MAAM,IAAI,GAAQ,IAAI,CAAC;QACvB,IAAI,KAAK,KAAK,MAAM,EAAE;YACpB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAChB;aAAM;YACL,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACf,IAAI,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;aACpB;YACD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;SACtC;IACH,CAAC;IAED,MAAM,CAAC,IAAY,EAAE,KAAU;QAC7B,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC;SACjC;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;SAC3B;IACH,CAAC;;4GArCU,cAAc;gGAAd,cAAc,gDCP3B,00GAkFA;4FD3Ea,cAAc;kBAL1B,SAAS;+BACE,UAAU","sourcesContent":["import {Component, OnInit} from '@angular/core';\n\n@Component({\n  selector: 'rs-style',\n  templateUrl: './style.component.html',\n  styleUrls: ['./style.component.scss']\n})\nexport class StyleComponent implements OnInit {\n  style: any;\n  width: number = 0;\n  height: number = 0;\n\n  ngOnInit(): void {\n    this.style.width = this.style.width ? this.style.width : 'auto';\n    this.style.widthType = this.style.widthType ? this.style.widthType : 'screen';\n    this.style.height = this.style.height ? this.style.height : 'auto';\n    this.style.heightType = this.style.heightType ? this.style.heightType : 'screen';\n    if (this.style.width !== 'auto') {\n      this.width = this.style.width.substring(0, this.style.width.length - 2);\n    }\n    if (this.style.height !== 'auto') {\n      this.height = this.style.height.substring(0, this.style.height.length - 2);\n    }\n  }\n\n  select(name: string, value: any) {\n    const that: any = this;\n    if (value === 'auto') {\n      this.style[name] = 'auto';\n      that[name] = 0;\n    } else {\n      if (!that[name]) {\n        that[name] = value;\n      }\n      this.style[name] = that[name] + 'px';\n    }\n  }\n\n  typing(name: string, value: any) {\n    if (value) {\n      this.style[name] = value + 'px';\n    } else {\n      this.style[name] = 'auto';\n    }\n  }\n}\n","<div class=\"config-item\">\n  <div class=\"item-title\">宽度类型</div>\n  <div class=\"item-setting\">\n    <div class=\"card-style-radio\">\n      <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n           (click)=\"select('width','auto')\">\n        <span>自适应</span>\n      </div>\n      <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n           (click)=\"select('width',240)\">\n        <span>固定值</span>\n      </div>\n    </div>\n  </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width === 'auto'\">\n  <div class=\"item-title\">适应方式</div>\n  <div class=\"item-setting\">\n    <div class=\"card-style-radio\">\n      <div class=\"radio-value\" [ngClass]=\"!style.widthType || style.widthType === 'screen' ? 'active' : ''\"\n           (click)=\"style.widthType = 'screen'\">\n        <span>按屏幕</span>\n      </div>\n      <div class=\"radio-value\" [ngClass]=\"style.widthType && style.widthType === 'content' ? 'active' : ''\"\n           (click)=\"style.widthType = 'content'\">\n        <span>按内容</span>\n      </div>\n    </div>\n  </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width !== 'auto'\">\n  <div class=\"item-title\">固定宽度</div>\n  <div class=\"item-setting\">\n    <dx-number-box [min]=\"0\"\n                   [showSpinButtons]=\"true\"\n                   [showClearButton]=\"true\"\n                   [(value)]=\"width\"\n                   (onValueChanged)=\"typing('width', $event.value)\">\n    </dx-number-box>\n  </div>\n</div>\n<div class=\"config-item\">\n  <div class=\"item-title\">高度类型</div>\n  <div class=\"item-setting\">\n    <div class=\"card-style-radio\">\n      <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n           (click)=\"select('height','auto')\">\n        <span>自适应</span>\n      </div>\n      <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n           (click)=\"select('height',800)\">\n        <span>固定值</span>\n      </div>\n    </div>\n  </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height === 'auto'\">\n  <div class=\"item-title\">适应方式</div>\n  <div class=\"item-setting\">\n    <div class=\"card-style-radio\">\n      <div class=\"radio-value\" [ngClass]=\"!style.heightType || style.heightType === 'screen' ? 'active' : ''\"\n           (click)=\"style.heightType = 'screen'\">\n        <span>按屏幕</span>\n      </div>\n      <div class=\"radio-value\" [ngClass]=\"style.heightType && style.heightType === 'content' ? 'active' : ''\"\n           (click)=\"style.heightType = 'content'\">\n        <span>按内容</span>\n      </div>\n    </div>\n  </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height !== 'auto'\">\n  <div class=\"item-title\">固定高度</div>\n  <div class=\"item-setting\">\n    <dx-number-box [min]=\"0\"\n                   [showSpinButtons]=\"true\"\n                   [showClearButton]=\"true\"\n                   [(value)]=\"height\"\n                   (onValueChanged)=\"typing('height', $event.value)\">\n    </dx-number-box>\n  </div>\n</div>\n"]}
@@ -206,7 +206,9 @@ class StyleComponent {
206
206
  }
207
207
  ngOnInit() {
208
208
  this.style.width = this.style.width ? this.style.width : 'auto';
209
+ this.style.widthType = this.style.widthType ? this.style.widthType : 'screen';
209
210
  this.style.height = this.style.height ? this.style.height : 'auto';
211
+ this.style.heightType = this.style.heightType ? this.style.heightType : 'screen';
210
212
  if (this.style.width !== 'auto') {
211
213
  this.width = this.style.width.substring(0, this.style.width.length - 2);
212
214
  }
@@ -237,10 +239,10 @@ class StyleComponent {
237
239
  }
238
240
  }
239
241
  StyleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: StyleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
240
- StyleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: StyleComponent, selector: "rs-style", ngImport: i0, template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\"\n [readOnly]=\"style.width === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\"\n [readOnly]=\"style.height === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.DxNumberBoxComponent, selector: "dx-number-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "format", "height", "hint", "hoverStateEnabled", "inputAttr", "invalidValueMessage", "isDirty", "isValid", "label", "labelMode", "max", "min", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showSpinButtons", "step", "stylingMode", "tabIndex", "text", "useLargeSpinButtons", "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", "formatChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "invalidValueMessageChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maxChange", "minChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showSpinButtonsChange", "stepChange", "stylingModeChange", "tabIndexChange", "textChange", "useLargeSpinButtonsChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }] });
242
+ StyleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: StyleComponent, selector: "rs-style", ngImport: i0, template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.widthType || style.widthType === 'screen' ? 'active' : ''\"\n (click)=\"style.widthType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.widthType && style.widthType === 'content' ? 'active' : ''\"\n (click)=\"style.widthType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.heightType || style.heightType === 'screen' ? 'active' : ''\"\n (click)=\"style.heightType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.heightType && style.heightType === 'content' ? 'active' : ''\"\n (click)=\"style.heightType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DxNumberBoxComponent, selector: "dx-number-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "format", "height", "hint", "hoverStateEnabled", "inputAttr", "invalidValueMessage", "isDirty", "isValid", "label", "labelMode", "max", "min", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showSpinButtons", "step", "stylingMode", "tabIndex", "text", "useLargeSpinButtons", "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", "formatChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "invalidValueMessageChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maxChange", "minChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showSpinButtonsChange", "stepChange", "stylingModeChange", "tabIndexChange", "textChange", "useLargeSpinButtonsChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }] });
241
243
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: StyleComponent, decorators: [{
242
244
  type: Component,
243
- args: [{ selector: 'rs-style', template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\"\n [readOnly]=\"style.width === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\"\n [readOnly]=\"style.height === 'auto'\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"] }]
245
+ args: [{ selector: 'rs-style', template: "<div class=\"config-item\">\n <div class=\"item-title\">\u5BBD\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.width || style.width === 'auto' ? 'active' : ''\"\n (click)=\"select('width','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.width && style.width !== 'auto' ? 'active' : ''\"\n (click)=\"select('width',240)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.widthType || style.widthType === 'screen' ? 'active' : ''\"\n (click)=\"style.widthType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.widthType && style.widthType === 'content' ? 'active' : ''\"\n (click)=\"style.widthType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.width !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u5BBD\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"width\"\n (onValueChanged)=\"typing('width', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n<div class=\"config-item\">\n <div class=\"item-title\">\u9AD8\u5EA6\u7C7B\u578B</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.height || style.height === 'auto' ? 'active' : ''\"\n (click)=\"select('height','auto')\">\n <span>\u81EA\u9002\u5E94</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.height && style.height !== 'auto' ? 'active' : ''\"\n (click)=\"select('height',800)\">\n <span>\u56FA\u5B9A\u503C</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height === 'auto'\">\n <div class=\"item-title\">\u9002\u5E94\u65B9\u5F0F</div>\n <div class=\"item-setting\">\n <div class=\"card-style-radio\">\n <div class=\"radio-value\" [ngClass]=\"!style.heightType || style.heightType === 'screen' ? 'active' : ''\"\n (click)=\"style.heightType = 'screen'\">\n <span>\u6309\u5C4F\u5E55</span>\n </div>\n <div class=\"radio-value\" [ngClass]=\"style.heightType && style.heightType === 'content' ? 'active' : ''\"\n (click)=\"style.heightType = 'content'\">\n <span>\u6309\u5185\u5BB9</span>\n </div>\n </div>\n </div>\n</div>\n<div class=\"config-item\" *ngIf=\"style.height !== 'auto'\">\n <div class=\"item-title\">\u56FA\u5B9A\u9AD8\u5EA6</div>\n <div class=\"item-setting\">\n <dx-number-box [min]=\"0\"\n [showSpinButtons]=\"true\"\n [showClearButton]=\"true\"\n [(value)]=\"height\"\n (onValueChanged)=\"typing('height', $event.value)\">\n </dx-number-box>\n </div>\n</div>\n", styles: [":host .config-item{display:flex;flex-flow:row nowrap;align-items:center;margin-bottom:8px}:host .config-item .item-title{flex:0 0 80px}:host .config-item .item-setting{flex:1;display:flex;flex-flow:row nowrap}:host .config-item .item-setting .card-style-radio{flex:1;display:flex;flex-flow:row nowrap;justify-content:stretch}:host .config-item .item-setting .card-style-radio .radio-value{flex:1;border:1px solid var(--coast-border-color, rgb(221, 221, 221));text-align:center;padding:4px;margin-left:-1px;cursor:pointer}:host .config-item .item-setting .card-style-radio .radio-value span{-webkit-user-select:none;user-select:none}:host .config-item .item-setting .card-style-radio .radio-value.active{color:var(--coast-default-color, rgb(51, 122, 183));border:1px solid var(--coast-default-color, rgb(51, 122, 183));z-index:1}:host .config-item .item-setting dx-number-box{flex:1}\n"] }]
244
246
  }] });
245
247
 
246
248
  class StyleBlankComponent {
@@ -254,7 +256,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
254
256
 
255
257
  class PluginManager {
256
258
  static createComponent(boxItem, index, style, config) {
257
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
259
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
258
260
  let plugin = PluginFactory.get(config.name);
259
261
  if (!plugin) {
260
262
  console.error('undefined plugin: ' + config.name);
@@ -275,18 +277,18 @@ class PluginManager {
275
277
  }
276
278
  if (PluginFactory.hasType(plugin, 'form')) {
277
279
  instance.editMode = boxItem.boxContainer.editMode;
278
- instance.validationGroupName = (_c = boxItem.boxContainer.context) === null || _c === void 0 ? void 0 : _c.__form.uniqueId;
279
- instance.tenant = (_d = boxItem.boxContainer.context) === null || _d === void 0 ? void 0 : _d.__form.tenant;
280
- instance.className = (_e = boxItem.boxContainer.context) === null || _e === void 0 ? void 0 : _e.__form.className;
281
- instance.oid = (_f = boxItem.boxContainer.context) === null || _f === void 0 ? void 0 : _f.__form.oid;
282
- instance.model = (_g = boxItem.boxContainer.context) === null || _g === void 0 ? void 0 : _g.__model;
283
- instance.opener = (_h = boxItem.boxContainer.context) === null || _h === void 0 ? void 0 : _h.__opener;
280
+ instance.validationGroupName = (_d = (_c = boxItem.boxContainer.context) === null || _c === void 0 ? void 0 : _c.__form) === null || _d === void 0 ? void 0 : _d.uniqueId;
281
+ instance.tenant = (_f = (_e = boxItem.boxContainer.context) === null || _e === void 0 ? void 0 : _e.__form) === null || _f === void 0 ? void 0 : _f.tenant;
282
+ instance.className = (_h = (_g = boxItem.boxContainer.context) === null || _g === void 0 ? void 0 : _g.__form) === null || _h === void 0 ? void 0 : _h.className;
283
+ instance.oid = (_k = (_j = boxItem.boxContainer.context) === null || _j === void 0 ? void 0 : _j.__form) === null || _k === void 0 ? void 0 : _k.oid;
284
+ instance.model = (_l = boxItem.boxContainer.context) === null || _l === void 0 ? void 0 : _l.__model;
285
+ instance.opener = (_m = boxItem.boxContainer.context) === null || _m === void 0 ? void 0 : _m.__opener;
284
286
  if (boxItem.boxContainer.readonly) {
285
287
  instance.readonly = true;
286
288
  }
287
289
  }
288
290
  if (PluginFactory.hasType(plugin, 'modal')) {
289
- instance.opener = (_j = boxItem.boxContainer.context) === null || _j === void 0 ? void 0 : _j.__opener;
291
+ instance.opener = (_o = boxItem.boxContainer.context) === null || _o === void 0 ? void 0 : _o.__opener;
290
292
  }
291
293
  instance.params = boxItem.boxContainer.params;
292
294
  instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;
@@ -547,13 +549,15 @@ class BoxItemComponent {
547
549
  return this.config.direction;
548
550
  }
549
551
  get _style() {
550
- var _a, _b;
552
+ var _a, _b, _c, _d;
551
553
  if (this.pDirection) {
552
554
  return {};
553
555
  }
554
556
  const width = ((_a = this.style) === null || _a === void 0 ? void 0 : _a.width) ? this.style.width : 'auto';
555
- const height = ((_b = this.style) === null || _b === void 0 ? void 0 : _b.height) ? this.style.height : 'auto';
556
- return this._calcStyle(this.pDirection, width, height);
557
+ const widthType = ((_b = this.style) === null || _b === void 0 ? void 0 : _b.widthType) ? this.style.widthType : 'screen';
558
+ const height = ((_c = this.style) === null || _c === void 0 ? void 0 : _c.height) ? this.style.height : 'auto';
559
+ const heightType = ((_d = this.style) === null || _d === void 0 ? void 0 : _d.heightType) ? this.style.heightType : 'screen';
560
+ return this._calcStyle(this.pDirection, width, widthType, height, heightType);
557
561
  }
558
562
  ngOnInit() {
559
563
  this.load();
@@ -653,22 +657,24 @@ class BoxItemComponent {
653
657
  };
654
658
  }
655
659
  calcStyle(item) {
656
- var _a, _b;
660
+ var _a, _b, _c, _d;
657
661
  const width = ((_a = item.style) === null || _a === void 0 ? void 0 : _a.width) ? item.style.width : 'auto';
658
- const height = ((_b = item.style) === null || _b === void 0 ? void 0 : _b.height) ? item.style.height : 'auto';
659
- return Object.assign(Object.assign({}, this._calcStyle(this.config.direction, width, height)), { position: 'relative' });
662
+ const widthType = ((_b = item.style) === null || _b === void 0 ? void 0 : _b.widthType) ? item.style.widthType : 'screen';
663
+ const height = ((_c = item.style) === null || _c === void 0 ? void 0 : _c.height) ? item.style.height : 'auto';
664
+ const heightType = ((_d = item.style) === null || _d === void 0 ? void 0 : _d.heightType) ? item.style.heightType : 'screen';
665
+ return Object.assign(Object.assign({}, this._calcStyle(this.config.direction, width, widthType, height, heightType)), { position: 'relative' });
660
666
  }
661
- _calcStyle(direction, width, height) {
667
+ _calcStyle(direction, width, widthType, height, heightType) {
662
668
  if (direction === 'row') {
663
669
  return {
664
- flex: width === 'auto' ? '1' : '0 0 ' + width,
670
+ flex: width === 'auto' ? (widthType === 'screen' ? '1' : 'none') : '0 0 ' + width,
665
671
  height
666
672
  };
667
673
  }
668
674
  else if (direction === 'column') {
669
675
  return {
670
676
  width,
671
- flex: height === 'auto' ? 'auto' : '0 0 ' + height
677
+ flex: height === 'auto' ? (heightType === 'screen' ? 'auto' : 'none') : '0 0 ' + height
672
678
  };
673
679
  }
674
680
  return {};