UNPKG

@cause-911/devextreme

Version:

Run `npm install @cause-911/devextreme --save` to add this library to your project

190 lines 14.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, EventEmitter, Input, NgZone, Output } from '@angular/core'; import { TranslateService } from '@cause-911/core'; export class CausePopupEditComponent { /** * @param {?} zone * @param {?} translate */ constructor(zone, translate) { this.zone = zone; this.translate = translate; this.title = ''; this.visibleChange = new EventEmitter(); this.popupShown = new EventEmitter(); this.save = new EventEmitter(); this.barItems = { ['ok']: { widget: 'dxButton', location: 'after', visible: true, options: { text: '' }, toolbar: 'bottom', parent: this, onClick: CausePopupEditComponent.onSaveClick }, ['save']: { widget: 'dxButton', location: 'after', visible: true, options: { text: '' }, toolbar: 'bottom', parent: this, onClick: CausePopupEditComponent.onSaveClick }, ['cancel']: { widget: 'dxButton', location: 'after', visible: true, options: { text: '' }, toolbar: 'bottom', parent: this, onClick: CausePopupEditComponent.onCancelClick } }; this.botomToolbarItems = [this.barItems['save'], this.barItems['cancel']]; this.translationKeyParent = 'devextreme.popupedit'; this.translationKeys = ['buttonsave', 'buttonok', 'buttoncancel']; this.types = { savecancel: 'savecancel', okcancel: 'okcancel' }; } /** * @param {?} name * @return {?} */ set type(name) { switch (name) { case this.types.okcancel: this.botomToolbarItems = [this.barItems.ok, this.barItems.cancel]; break; default: this.botomToolbarItems = [this.barItems.save, this.barItems.cancel]; break; } } /** * @param {?} e * @return {?} */ static onSaveClick(e) { e.itemData.parent.save.emit(); } /** * @param {?} e * @return {?} */ static onCancelClick(e) { e.itemData.parent.visible = false; e.itemData.parent.onVisibleChange(); } /** * @return {?} */ ngOnInit() { this.getTranslations(); } /** * @return {?} */ getTranslations() { /** @type {?} */ const keys = this.translationKeys.map((/** * @param {?} key * @return {?} */ key => [this.translationKeyParent, key].join('.'))); this.translate.get(keys).subscribe((/** * @param {?} translations * @return {?} */ translations => { this.initBarText(translations); })); } /** * @return {?} */ onVisibleChange() { this.visibleChange.emit(this.visible); } /** * @param {?} translations * @return {?} */ initBarText(translations) { this.barItems.save.options.text = translations[[this.translationKeyParent, 'buttonsave'].join('.')]; this.barItems.ok.options.text = translations[[this.translationKeyParent, 'buttonok'].join('.')]; this.barItems.cancel.options.text = translations[[this.translationKeyParent, 'buttoncancel'].join('.')]; } /** * @return {?} */ popupHidden() { this.visible = false; this.onVisibleChange(); } /** * @param {?} e * @return {?} */ onShown(e) { this.popupShown.emit(e); } } CausePopupEditComponent.decorators = [ { type: Component, args: [{ selector: 'cause-popup-edit', template: "<div>\n <dx-popup\n class=\"popup\"\n [showTitle]=\"true\"\n [title]=\"title\"\n [dragEnabled]=\"false\"\n [showCloseButton]=\"true\"\n [closeOnOutsideClick]=\"false\"\n [(visible)]=\"visible\"\n [toolbarItems]=\"botomToolbarItems\"\n (onHidden)=\"popupHidden()\"\n (onShown)=\"onShown($event)\"\n >\n <ng-content></ng-content>\n </dx-popup>\n</div>\n", styles: [""] }] } ]; /** @nocollapse */ CausePopupEditComponent.ctorParameters = () => [ { type: NgZone }, { type: TranslateService } ]; CausePopupEditComponent.propDecorators = { title: [{ type: Input }], type: [{ type: Input }], visible: [{ type: Input }], visibleChange: [{ type: Output }], popupShown: [{ type: Output }], save: [{ type: Output }] }; if (false) { /** @type {?} */ CausePopupEditComponent.prototype.title; /** @type {?} */ CausePopupEditComponent.prototype.visible; /** @type {?} */ CausePopupEditComponent.prototype.visibleChange; /** @type {?} */ CausePopupEditComponent.prototype.popupShown; /** @type {?} */ CausePopupEditComponent.prototype.save; /** @type {?} */ CausePopupEditComponent.prototype.barItems; /** @type {?} */ CausePopupEditComponent.prototype.botomToolbarItems; /** @type {?} */ CausePopupEditComponent.prototype.translationKeyParent; /** @type {?} */ CausePopupEditComponent.prototype.translationKeys; /** @type {?} */ CausePopupEditComponent.prototype.types; /** * @type {?} * @private */ CausePopupEditComponent.prototype.zone; /** * @type {?} * @private */ CausePopupEditComponent.prototype.translate; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cause-popup-edit.component.js","sourceRoot":"ng://@cause-911/devextreme/","sources":["lib/cause-popup-edit/cause-popup-edit.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, NgZone, Output} from '@angular/core';\nimport {TranslateService} from '@cause-911/core';\n\n@Component({\n  selector: 'cause-popup-edit',\n  templateUrl: './cause-popup-edit.component.html',\n  styleUrls: ['./cause-popup-edit.component.scss']\n})\nexport class CausePopupEditComponent {\n  @Input() title = '';\n\n  @Input() set type(name: string) {\n    switch (name) {\n      case this.types.okcancel :\n        this.botomToolbarItems = [this.barItems.ok, this.barItems.cancel];\n        break;\n      default:\n        this.botomToolbarItems = [this.barItems.save, this.barItems.cancel];\n        break;\n    }\n  }\n\n  @Input() visible: boolean;\n  @Output() visibleChange = new EventEmitter<boolean>();\n  @Output() popupShown = new EventEmitter<any>();\n  @Output() save = new EventEmitter<void>();\n\n  barItems: any = {\n    ['ok']: {\n      widget: 'dxButton',\n      location: 'after',\n      visible: true,\n      options: {text: ''},\n      toolbar: 'bottom',\n      parent: this,\n      onClick: CausePopupEditComponent.onSaveClick\n    },\n    ['save']: {\n      widget: 'dxButton',\n      location: 'after',\n      visible: true,\n      options: {text: ''},\n      toolbar: 'bottom',\n      parent: this,\n      onClick: CausePopupEditComponent.onSaveClick\n    },\n    ['cancel']: {\n      widget: 'dxButton',\n      location: 'after',\n      visible: true,\n      options: {text: ''},\n      toolbar: 'bottom',\n      parent: this,\n      onClick: CausePopupEditComponent.onCancelClick\n    }\n  };\n\n  botomToolbarItems: any = [this.barItems['save'], this.barItems['cancel']];\n  translationKeyParent = 'devextreme.popupedit';\n  translationKeys = ['buttonsave', 'buttonok', 'buttoncancel'];\n\n  types = {\n    savecancel: 'savecancel', okcancel: 'okcancel'\n  };\n\n  static onSaveClick(e) {\n    e.itemData.parent.save.emit();\n  }\n\n  static onCancelClick(e) {\n    e.itemData.parent.visible = false;\n    e.itemData.parent.onVisibleChange();\n  }\n\n  constructor(private zone: NgZone, private translate: TranslateService) {\n  }\n\n  ngOnInit() {\n    this.getTranslations();\n  }\n\n  getTranslations(): void {\n    const keys = this.translationKeys.map(key => [this.translationKeyParent, key].join('.'));\n    this.translate.get(keys).subscribe(translations => {\n      this.initBarText(translations);\n    });\n  }\n\n  onVisibleChange() {\n    this.visibleChange.emit(this.visible);\n  }\n\n  initBarText(translations: string[]) {\n    this.barItems.save.options.text = translations[[this.translationKeyParent, 'buttonsave'].join('.')];\n    this.barItems.ok.options.text = translations[[this.translationKeyParent, 'buttonok'].join('.')];\n    this.barItems.cancel.options.text = translations[[this.translationKeyParent, 'buttoncancel'].join('.')];\n  }\n\n  popupHidden() {\n    this.visible = false;\n    this.onVisibleChange();\n  }\n\n  onShown(e) {\n    this.popupShown.emit(e);\n  }\n}\n"]}