@cause-911/devextreme
Version:
Run `npm install @cause-911/devextreme --save` to add this library to your project
190 lines • 14.5 kB
JavaScript
/**
* @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"]}