UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

216 lines (215 loc) 16.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, EventEmitter, Output } from '@angular/core'; import { AbstractMenuItem } from './AbstractMenuItem'; import { NeedFocusService } from '../service/NeedFocusService.service'; import { Option } from '../decorator/Option.decorator'; import { I18N } from '../decorator/I18N.decorator'; import { MenuItemModel } from './model/MenuItemModel'; import { EventUtils } from '../share/utils/EventUtils'; import { CHECK_EVENT, UNCHECK_EVENT } from '../share/CustomEventType'; const /** @type {?} */ TYPE_NAME = "phx-check-menu-item"; export class CheckMenuItem extends AbstractMenuItem { /** * @param {?} needFocusService */ constructor(needFocusService) { super(needFocusService); this._isCheck = false; this.checkEvent = new EventEmitter(); this.uncheckEvent = new EventEmitter(); } /** * @return {?} */ ngOnInit() { if (this.model !== null && typeof this.model !== 'undefined') { let /** @type {?} */ chkModel = this.model; if (chkModel.checked !== null && typeof chkModel.checked === 'boolean') { this._isCheck = chkModel.checked; } } } /** * @param {?} check * @return {?} */ setCheck(check) { this._isCheck = check; } /** * @return {?} */ hasModel() { if (this.model !== null && typeof this.model !== 'undefined') { return true; } return false; } /** * @return {?} */ hasPrefixIcon() { if (this.model !== null && typeof this.model !== 'undefined') { let /** @type {?} */ chkModel = this.model; if (chkModel.prefixIconURL !== null && typeof chkModel.prefixIconURL === 'string') { return true; } } return false; } /** * @return {?} */ check() { this.setCheck(true); let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(CHECK_EVENT, this, data, null); this.checkEvent.emit(ev); } /** * @return {?} */ uncheck() { this.setCheck(false); let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(UNCHECK_EVENT, this, data, null); this.uncheckEvent.emit(ev); } /** * @return {?} */ getCheckEvent() { return this.checkEvent; } /** * @param {?} event * @return {?} */ setCheckEvent(event) { this.checkEvent = event; } /** * @return {?} */ getUncheckEvent() { return this.uncheckEvent; } /** * @param {?} event * @return {?} */ setUncheckEvent(event) { this.uncheckEvent = event; } /** * @return {?} */ isCheck() { return this._isCheck; } /** * @return {?} */ getPrefixIconURL() { if (this.model === null || typeof this.model === 'undefined') { return null; } return (/** @type {?} */ (this.model)).prefixIconURL; } /** * @return {?} */ getPrefixLabel() { if (this.model === null || typeof this.model === 'undefined') { return null; } return (/** @type {?} */ (this.model)).prefixLabel; } /** * @return {?} */ getLabel() { if (this.model === null || typeof this.model === 'undefined') { return null; } return (/** @type {?} */ (this.model)).label; } } CheckMenuItem.TYPE_NAME = TYPE_NAME; CheckMenuItem.CHECK_EVENT = CHECK_EVENT; CheckMenuItem.UNCHECK_EVENT = UNCHECK_EVENT; CheckMenuItem.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="phx-check-menu-item" (click)="onClick($event)"> <div class="container" *ngIf="hasModel()"> <div class="left"> <div *ngIf="hasPrefixIcon()"> <img src="{{getPrefixIconURL()}}"> </div> <div *ngIf="!hasPrefixIcon()"> {{getPrefixLabel()}} </div> </div> <div class="center">{{getLabel()}}</div> <div class="right"> <div class="heavy-check-mark" *ngIf="isCheck()"></div> </div> </div> </div> ` },] }, ]; /** @nocollapse */ CheckMenuItem.ctorParameters = () => [ { type: NeedFocusService, }, ]; CheckMenuItem.propDecorators = { "model": [{ type: Input },], "checkEvent": [{ type: Output, args: ['phxCheck',] },], "uncheckEvent": [{ type: Output, args: ['phxUncheck',] },], }; tslib_1.__decorate([ Option(), I18N(), tslib_1.__metadata("design:type", MenuItemModel) ], CheckMenuItem.prototype, "model", void 0); tslib_1.__decorate([ Option('check'), tslib_1.__metadata("design:type", EventEmitter) ], CheckMenuItem.prototype, "checkEvent", void 0); tslib_1.__decorate([ Option('uncheck'), tslib_1.__metadata("design:type", EventEmitter) ], CheckMenuItem.prototype, "uncheckEvent", void 0); function CheckMenuItem_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ CheckMenuItem.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ CheckMenuItem.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ CheckMenuItem.propDecorators; /** @type {?} */ CheckMenuItem.TYPE_NAME; /** @type {?} */ CheckMenuItem.CHECK_EVENT; /** @type {?} */ CheckMenuItem.UNCHECK_EVENT; /** @type {?} */ CheckMenuItem.prototype._isCheck; /** @type {?} */ CheckMenuItem.prototype.model; /** @type {?} */ CheckMenuItem.prototype.checkEvent; /** @type {?} */ CheckMenuItem.prototype.uncheckEvent; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CheckMenuItem.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/CheckMenuItem.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, EventEmitter, Output } from '@angular/core';\nimport { AbstractMenuItem } from './AbstractMenuItem';\nimport { NeedFocusService } from '../service/NeedFocusService.service';\n\nimport { Option } from '../decorator/Option.decorator';\nimport { I18N } from '../decorator/I18N.decorator';\n\nimport { MenuItemModel } from './model/MenuItemModel';\n\nimport { EventUtils } from '../share/utils/EventUtils';\n\nimport { CHECK_EVENT, UNCHECK_EVENT } from '../share/CustomEventType';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-check-menu-item\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-check-menu-item\" (click)=\"onClick($event)\">\n\t<div class=\"container\" *ngIf=\"hasModel()\">\n\t\t<div class=\"left\">\n\t\t\t<div *ngIf=\"hasPrefixIcon()\">\n\t\t\t\t<img src=\"{{getPrefixIconURL()}}\">\n\t\t\t</div>\n\t\t\t<div *ngIf=\"!hasPrefixIcon()\">\n\t\t\t\t{{getPrefixLabel()}}\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"center\">{{getLabel()}}</div>\n\t\t<div class=\"right\">\n\t\t\t<div class=\"heavy-check-mark\" *ngIf=\"isCheck()\"></div>\n\t\t</div>\n\t</div>\n</div>\n`\n})\nexport class CheckMenuItem extends AbstractMenuItem implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  public static readonly CHECK_EVENT: string = CHECK_EVENT;\n  public static readonly UNCHECK_EVENT: string = UNCHECK_EVENT;\n\n  private _isCheck: boolean;\n\n  @Input()\n  @Option()\n  @I18N()\n  protected model: MenuItemModel;\n\n  @Output('phxCheck')\n  @Option('check')\n  private checkEvent: EventEmitter<any>;\n  @Output('phxUncheck')\n  @Option('uncheck')\n  private uncheckEvent: EventEmitter<any>;\n\n  constructor(needFocusService: NeedFocusService) {\n    super(needFocusService);\n    this._isCheck = false;\n    this.checkEvent = new EventEmitter();\n    this.uncheckEvent = new EventEmitter();\n  }\n\n  public ngOnInit(): void {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      let chkModel: any = this.model;\n      if (chkModel.checked !== null && typeof chkModel.checked === 'boolean') {\n        this._isCheck = chkModel.checked;\n      }\n    }\n  }\n\n  private setCheck(check: boolean): void {\n    this._isCheck = check;\n  }\n\n  public hasModel(): boolean {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      return true;\n    }\n    return false;\n  }\n\n  public hasPrefixIcon(): boolean {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      let chkModel: any = this.model;\n      if (chkModel.prefixIconURL !== null && typeof chkModel.prefixIconURL === 'string') {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  public check(): void {\n    this.setCheck(true);\n\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(CHECK_EVENT, this, data, null);\n\n    this.checkEvent.emit(ev);\n  }\n\n  public uncheck(): void {\n    this.setCheck(false);\n\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(UNCHECK_EVENT, this, data, null);\n\n    this.uncheckEvent.emit(ev);\n  }\n\n  public getCheckEvent(): EventEmitter<any> {\n    return this.checkEvent;\n  }\n\n  public setCheckEvent(event: EventEmitter<any>): void {\n    this.checkEvent = event;\n  }\n\n  public getUncheckEvent(): EventEmitter<any> {\n    return this.uncheckEvent;\n  }\n\n  public setUncheckEvent(event: EventEmitter<any>): void {\n    this.uncheckEvent = event;\n  }\n\n  public isCheck(): boolean {\n    return this._isCheck;\n  }\n\n  public getPrefixIconURL(): string {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return null;\n    }\n\n    return (<any>this.model).prefixIconURL;\n  }\n\n  public getPrefixLabel(): string {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return null;\n    }\n\n    return (<any>this.model).prefixLabel;\n  }\n\n  public getLabel(): string {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return null;\n    }\n\n    return (<any>this.model).label;\n  }\n}\n"]}