UNPKG

stimulsoft-viewer-angular

Version:
209 lines (197 loc) 22.2 kB
import { Component, Input, ViewChild } from '@angular/core'; import { Variable } from '../services/objects'; import * as i0 from "@angular/core"; import * as i1 from "../services/model.service"; import * as i2 from "../services/helper.service"; import * as i3 from "./menu.service"; import * as i4 from "@angular/common"; import * as i5 from "../controls/parameters/parameter-text-box.component"; import * as i6 from "../controls/parameters/parameter-button.component"; import * as i7 from "./parameter-menu-item.component"; import * as i8 from "./parameter-menu-separator.component"; export class ParameterMenuEditListComponent { constructor(model, helper, menuService) { this.model = model; this.helper = helper; this.menuService = menuService; } ngOnInit() { } newItem(event) { const item = new Variable(); if (this.menu.params.type === 'DateTime') { item.key = this.helper.getDateTimeObject(); item.value = this.helper.dateTimeObjectToString(item.key); } else if (this.menu.params.type === 'TimeSpan') { item.key = '00:00:00'; item.value = '00:00:00'; } else if (this.menu.params.type === 'Bool') { item.key = 'False'; item.value = 'False'; } else { item.key = ''; item.value = ''; } item.focusOnCreate = true; if (!this.menu.params.items) { this.menu.params.items = []; } this.menu.params.items.push(item); setTimeout(() => { item.focusOnCreate = false; }); } dateTimeButtonAction(item) { this.menuService.addMenu({ type: 'datePickerMenu', name: 'datePickerMenu', items: [], parent: this.dateTimeButton, params: item, state: '' }); setTimeout(() => { this.menuService.showMenu('datePickerMenu'); }); } guidButtonAction(item) { item.key = this.helper.newGuid(); } removeButtonAction(item) { this.menu.params.items.splice(this.menu.params.items.indexOf(item), 1); } removeAllAction() { this.menu.params.items.splice(0, this.menu.params.items.length); } closeAction() { this.menu.state = 'initialDown'; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ParameterMenuEditListComponent, deps: [{ token: i1.ModelService }, { token: i2.HelperService }, { token: i3.MenuService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ParameterMenuEditListComponent, selector: "sti-parameter-menu-edit-list", inputs: { menu: "menu" }, viewQueries: [{ propertyName: "dateTimeButton", first: true, predicate: ["dateTimeButton"], descendants: true }], ngImport: i0, template: ` <table class="stiJsViewerClearAllStyles stiJsViewerParametersMenuInnerTable" cellpadding="0" cellspacing="0" [style.fontFamily]="model.options.toolbar.fontFamily" [style.color]="model.options.toolbar.fontColor" [style.fontSize]="'12px'" [style.width]="(menu.parent.nativeElement.offsetWidth - 5) + 'px'"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <!--New Item Button --> <sti-parameter-menu-item (action)="newItem($event)"> {{model.loc('NewItem')}} </sti-parameter-menu-item> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <sti-parameter-menu-item *ngFor="let item of menu.params.items" [active]="false"> <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" [style.padding]="'0px 1px 0px 0px'"> <sti-parameter-text-box [item]="item" [isMenu]="true" [variable]="menu.params" [focusOnCreate]="item.focusOnCreate"> </sti-parameter-text-box> </td> <td *ngIf="menu.params.type == 'DateTime'" class="stiJsViewerClearAllStyles" [style.padding]="'0 1px 0 1px'" #dateTimeButton> <sti-parameter-button [buttonType]="'DateTimeButton'" (action)="dateTimeButtonAction(item)"> </sti-parameter-button> </td> <td *ngIf="menu.params.type == 'Guid'" class="stiJsViewerClearAllStyles" [style.padding]="'0 1px 0 1px'"> <sti-parameter-button [buttonType]="'GuidButton'" (action)="guidButtonAction(item)"> </sti-parameter-button> </td> <td class="stiJsViewerClearAllStyles" [style.padding]="'0 1px 0 1px'"> <sti-parameter-button [buttonType]="'RemoveItemButton'" (action)="removeButtonAction(item)" [params]="item"> </sti-parameter-button> </td> </tr> </tbody> </table> </sti-parameter-menu-item> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <sti-parameter-menu-item (action)="removeAllAction()"> {{model.loc('RemoveAll')}} </sti-parameter-menu-item> <sti-parameter-menu-separator></sti-parameter-menu-separator> <sti-parameter-menu-item (action)="closeAction()"> {{model.loc('Close')}} </sti-parameter-menu-item> </td> </tr> </tbody> </table> `, isInline: true, dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.ParameterTextBoxComponent, selector: "sti-parameter-text-box", inputs: ["item", "variable", "readOnly", "focusOnCreate", "isMenu", "value", "secondTextBox"] }, { kind: "component", type: i6.ParameterButtonComponent, selector: "sti-parameter-button", inputs: ["params", "buttonType"], outputs: ["action"] }, { kind: "component", type: i7.ParameterMenuItemComponent, selector: "sti-parameter-menu-item", inputs: ["active", "padding"], outputs: ["action"] }, { kind: "component", type: i8.ParameterMenuSeparatorComponent, selector: "sti-parameter-menu-separator" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ParameterMenuEditListComponent, decorators: [{ type: Component, args: [{ selector: 'sti-parameter-menu-edit-list', template: ` <table class="stiJsViewerClearAllStyles stiJsViewerParametersMenuInnerTable" cellpadding="0" cellspacing="0" [style.fontFamily]="model.options.toolbar.fontFamily" [style.color]="model.options.toolbar.fontColor" [style.fontSize]="'12px'" [style.width]="(menu.parent.nativeElement.offsetWidth - 5) + 'px'"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <!--New Item Button --> <sti-parameter-menu-item (action)="newItem($event)"> {{model.loc('NewItem')}} </sti-parameter-menu-item> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <sti-parameter-menu-item *ngFor="let item of menu.params.items" [active]="false"> <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" [style.padding]="'0px 1px 0px 0px'"> <sti-parameter-text-box [item]="item" [isMenu]="true" [variable]="menu.params" [focusOnCreate]="item.focusOnCreate"> </sti-parameter-text-box> </td> <td *ngIf="menu.params.type == 'DateTime'" class="stiJsViewerClearAllStyles" [style.padding]="'0 1px 0 1px'" #dateTimeButton> <sti-parameter-button [buttonType]="'DateTimeButton'" (action)="dateTimeButtonAction(item)"> </sti-parameter-button> </td> <td *ngIf="menu.params.type == 'Guid'" class="stiJsViewerClearAllStyles" [style.padding]="'0 1px 0 1px'"> <sti-parameter-button [buttonType]="'GuidButton'" (action)="guidButtonAction(item)"> </sti-parameter-button> </td> <td class="stiJsViewerClearAllStyles" [style.padding]="'0 1px 0 1px'"> <sti-parameter-button [buttonType]="'RemoveItemButton'" (action)="removeButtonAction(item)" [params]="item"> </sti-parameter-button> </td> </tr> </tbody> </table> </sti-parameter-menu-item> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <sti-parameter-menu-item (action)="removeAllAction()"> {{model.loc('RemoveAll')}} </sti-parameter-menu-item> <sti-parameter-menu-separator></sti-parameter-menu-separator> <sti-parameter-menu-item (action)="closeAction()"> {{model.loc('Close')}} </sti-parameter-menu-item> </td> </tr> </tbody> </table> ` }] }], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.HelperService }, { type: i3.MenuService }], propDecorators: { dateTimeButton: [{ type: ViewChild, args: ['dateTimeButton'] }], menu: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parameter-menu-edit-list.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/menu/parameter-menu-edit-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { MenuItem } from './meni-item.component';\r\nimport { Menu, MenuService } from './menu.service';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { Variable } from '../services/objects';\r\n\r\n@Component({\r\n  selector: 'sti-parameter-menu-edit-list',\r\n  template: `\r\n        <table class=\"stiJsViewerClearAllStyles stiJsViewerParametersMenuInnerTable\" cellpadding=\"0\" cellspacing=\"0\"\r\n        [style.fontFamily]=\"model.options.toolbar.fontFamily\"\r\n        [style.color]=\"model.options.toolbar.fontColor\"\r\n        [style.fontSize]=\"'12px'\"\r\n        [style.width]=\"(menu.parent.nativeElement.offsetWidth - 5) + 'px'\">\r\n          <tbody>\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <!--New Item Button -->\r\n                <sti-parameter-menu-item (action)=\"newItem($event)\">\r\n                  {{model.loc('NewItem')}}\r\n                </sti-parameter-menu-item>\r\n              </td>\r\n            </tr>\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <sti-parameter-menu-item *ngFor=\"let item of menu.params.items\" [active]=\"false\">\r\n                  <table class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\">\r\n                    <tbody>\r\n                      <tr class=\"stiJsViewerClearAllStyles\">\r\n                         <td class=\"stiJsViewerClearAllStyles\" [style.padding]=\"'0px 1px 0px 0px'\">\r\n                            <sti-parameter-text-box [item]=\"item\" [isMenu]=\"true\"\r\n                              [variable]=\"menu.params\" [focusOnCreate]=\"item.focusOnCreate\">\r\n                            </sti-parameter-text-box>\r\n                         </td>\r\n\r\n                         <td *ngIf=\"menu.params.type == 'DateTime'\" class=\"stiJsViewerClearAllStyles\" [style.padding]=\"'0 1px 0 1px'\" #dateTimeButton>\r\n                           <sti-parameter-button [buttonType]=\"'DateTimeButton'\" (action)=\"dateTimeButtonAction(item)\">\r\n                           </sti-parameter-button>\r\n                         </td>\r\n\r\n                         <td *ngIf=\"menu.params.type == 'Guid'\" class=\"stiJsViewerClearAllStyles\" [style.padding]=\"'0 1px 0 1px'\">\r\n                           <sti-parameter-button [buttonType]=\"'GuidButton'\" (action)=\"guidButtonAction(item)\">\r\n                           </sti-parameter-button>\r\n                         </td>\r\n\r\n                         <td class=\"stiJsViewerClearAllStyles\" [style.padding]=\"'0 1px 0 1px'\">\r\n                           <sti-parameter-button [buttonType]=\"'RemoveItemButton'\" (action)=\"removeButtonAction(item)\" [params]=\"item\">\r\n                           </sti-parameter-button>\r\n                         </td>\r\n                       </tr>\r\n                     </tbody>\r\n                  </table>\r\n                </sti-parameter-menu-item>\r\n              </td>\r\n            </tr>\r\n\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                  <sti-parameter-menu-item (action)=\"removeAllAction()\">\r\n                      {{model.loc('RemoveAll')}}\r\n                  </sti-parameter-menu-item>\r\n\r\n                  <sti-parameter-menu-separator></sti-parameter-menu-separator>\r\n\r\n                  <sti-parameter-menu-item (action)=\"closeAction()\">\r\n                      {{model.loc('Close')}}\r\n                  </sti-parameter-menu-item>\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n  `\r\n})\r\n\r\nexport class ParameterMenuEditListComponent implements OnInit {\r\n\r\n  @ViewChild('dateTimeButton') dateTimeButton: ElementRef;\r\n\r\n  @Input() menu: Menu;\r\n\r\n  constructor(public model: ModelService, public helper: HelperService, public menuService: MenuService) { }\r\n\r\n  ngOnInit() { }\r\n\r\n  newItem(event: any) {\r\n    const item: any = new Variable();\r\n    if (this.menu.params.type === 'DateTime') {\r\n      item.key = this.helper.getDateTimeObject();\r\n      item.value = this.helper.dateTimeObjectToString(item.key);\r\n    } else if (this.menu.params.type === 'TimeSpan') {\r\n      item.key = '00:00:00';\r\n      item.value = '00:00:00';\r\n    } else if (this.menu.params.type === 'Bool') {\r\n      item.key = 'False';\r\n      item.value = 'False';\r\n    } else {\r\n      item.key = '';\r\n      item.value = '';\r\n    }\r\n    item.focusOnCreate = true;\r\n    if (!this.menu.params.items) {\r\n      this.menu.params.items = [];\r\n    }\r\n    this.menu.params.items.push(item);\r\n    setTimeout(() => {\r\n      item.focusOnCreate = false;\r\n    });\r\n  }\r\n\r\n  dateTimeButtonAction(item: Variable) {\r\n    this.menuService.addMenu({\r\n      type: 'datePickerMenu', name: 'datePickerMenu', items: [], parent: this.dateTimeButton,\r\n      params: item,\r\n      state: ''\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.menuService.showMenu('datePickerMenu');\r\n    });\r\n  }\r\n\r\n  guidButtonAction(item: Variable) {\r\n    item.key = this.helper.newGuid();\r\n  }\r\n\r\n  removeButtonAction(item: Variable) {\r\n    this.menu.params.items.splice(this.menu.params.items.indexOf(item), 1);\r\n  }\r\n\r\n  removeAllAction() {\r\n    this.menu.params.items.splice(0, this.menu.params.items.length);\r\n  }\r\n\r\n  closeAction() {\r\n    this.menu.state = 'initialDown';\r\n  }\r\n}\r\n"]}