UNPKG

@gsp-cmp/ccmp-ui

Version:

CCMP UI Component Library for Angular

250 lines 22.6 kB
/** * @fileoverview added by tsickle * Generated from: lib/ccmp-selector/common-component-selector.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, EventEmitter, Output, ViewChild, TemplateRef } from '@angular/core'; import { DefaultGspComponentSerializeContext } from '@gsp-cmp/common-component'; import { ViewUtils } from '../view-utils/view-utils'; import { ComponentInfo } from '../params/component-info'; import { ComponentConvertor } from '../convertor/convertor'; import { WebServiceComponentSerializerContext } from '@gsp-cmp/wscmp-models'; import { DatagridComponent } from '@farris/ui-datagrid'; export class CommonComponentSelectorComponent { /** * @param {?} utils */ constructor(utils) { this.utils = utils; this.selectedIds = []; this.columns = []; this.multiSelection = false; this.confirmEmitter = new EventEmitter(); this.closeEmitter = new EventEmitter(); } /** * @param {?} _componentInfo * @return {?} */ set componentInfo(_componentInfo) { this._componentInfo = _componentInfo; switch (this._componentInfo.type) { case 'CommonComponent': this.CommonComponentInit(this._componentInfo); break; case 'WebServiceComponent': this.WebServiceComponentInit(this._componentInfo); break; default: throw new Error('不支持的构件类型' + this._componentInfo.type); } } /** * @param {?} options * @return {?} */ set _options(options) { this.multiSelection = options && options.multiSelection || false; } /** * @return {?} */ ngOnInit() { this._componentInfo = this._componentInfo || new ComponentInfo(); this.columnsInit(); } /** * @return {?} */ columnsInit() { this.columns = [ { field: 'code', width: 100, title: this.utils.translateService.instant('operation_code') }, { field: 'name', width: 100, title: this.utils.translateService.instant('operation_name') }, ]; } /** * @param {?} _componentInfo * @return {?} */ CommonComponentInit(_componentInfo) { /** @type {?} */ let convertor = new ComponentConvertor(); /** @type {?} */ let ctx = new DefaultGspComponentSerializeContext(); this.metadata = convertor.initFromObject(convertor.convertorToObject(_componentInfo.metadata, ctx), ctx); this.metadata.operations = new Array(); } /** * @param {?} _componentInfo * @return {?} */ WebServiceComponentInit(_componentInfo) { /** @type {?} */ let convertor = new ComponentConvertor(); /** @type {?} */ let ctx = new WebServiceComponentSerializerContext(); this.metadata = convertor.initFromObject(convertor.convertorToObject(_componentInfo.metadata, ctx), ctx); this.metadata.operations = new Array(); } /** * @return {?} */ confirm() { if (this.selectedIds.length <= 0) { this.utils.showInfo(this.utils.translateService.instant('operation_choose'), 'info', '', 1500); return; } this.metadata.operations = []; this.selectedIds.map((/** * @param {?} x * @return {?} */ x => { /** @type {?} */ let operation = this._componentInfo.metadata.operations.find((/** * @param {?} op * @return {?} */ op => op.code === x)); if (operation) { this.metadata.operations.push(operation); } })); if (this.dialog) { this.dialog.close(); } this.confirmEmitter.emit(this.metadata); this.selectedIds = []; } /** * @return {?} */ close() { if (this.dialog) { this.dialog.close(); } this.closeEmitter.emit(); } /** * @param {?} row * @return {?} */ checkedHandler(row) { /** @type {?} */ let index = this.selectedIds.findIndex((/** * @param {?} x * @return {?} */ x => x === row.id)); if (index == (-1)) { this.selectedIds.push(row.id); } } /** * @param {?} row * @return {?} */ unCheckedHandler(row) { /** @type {?} */ let index = this.selectedIds.findIndex((/** * @param {?} x * @return {?} */ x => x === row.id)); if (index !== (-1)) { this.selectedIds.splice(index, 1); } } /** * @param {?} rows * @return {?} */ checkAllHandler(rows) { if (rows && rows.length > 0) { rows.forEach((/** * @param {?} row * @return {?} */ row => { /** @type {?} */ let index = this.selectedIds.findIndex((/** * @param {?} x * @return {?} */ x => x === row.id)); if (index == (-1)) { this.selectedIds.push(row.id); } })); } } /** * @param {?} rows * @return {?} */ unCheckAllHandler(rows) { if (rows && rows.length > 0) { rows.forEach((/** * @param {?} row * @return {?} */ row => { /** @type {?} */ let index = this.selectedIds.findIndex((/** * @param {?} x * @return {?} */ x => x === row.id)); if (index !== (-1)) { this.selectedIds.splice(index, 1); } })); } } } CommonComponentSelectorComponent.decorators = [ { type: Component, args: [{ selector: 'common-component-selector', template: "<div class=\"d-flex\" style=\"position: absolute;top: 0;bottom: 0;left: 0;right: 0;\">\r\n <div class=\"f-utils-fill selector-modal\">\r\n <farris-datagrid #dg=\"datagrid\" [showLineNumber]=\"true\" [fit]=\"true\" [pagination]=\"true\" [virtualized]=\"false\"\r\n [fitColumns]=\"true\" [showAllCheckbox]=\"true\" [selectOnCheck]=\"true\" [showCheckbox]=\"true\" [idField]=\"'code'\"\r\n [multiSelect]=\"multiSelection\" [showPageList]=\"true\" [onlySelectSelf]=\"true\" [columns]=\"columns\" [data]=\"_componentInfo.metadata.operations\"\r\n (checkAll)=\"checkAllHandler($event)\" (unCheckAll)=\"unCheckAllHandler($event)\" (checked)=\"checkedHandler($event)\" (unChecked)=\"unCheckedHandler($event)\">\r\n </farris-datagrid>\r\n </div>\r\n</div>\r\n\r\n\r\n<ng-template #btnRef>\r\n <div style=\"width: 100%;line-height: 50px; text-align: center;min-width: 140px;\"> \r\n <button class=\"btn btn-primary\" (click)=confirm() style=\"float:right;margin-right: 5px\">{{'confirm'|i18n}}</button>\r\n <button class=\"btn btn-secondary\" (click)=\"close()\" style=\"float:right;margin-right: 5px\">{{'cancel'|i18n}}</button>\r\n </div>\r\n</ng-template>", styles: [".selector-modal{padding:0 8px;width:100%;display:flex}"] }] } ]; /** @nocollapse */ CommonComponentSelectorComponent.ctorParameters = () => [ { type: ViewUtils } ]; CommonComponentSelectorComponent.propDecorators = { componentInfo: [{ type: Input }], dg: [{ type: ViewChild, args: ['dg',] }], btnRef: [{ type: ViewChild, args: ['btnRef',] }], confirmEmitter: [{ type: Output }], closeEmitter: [{ type: Output }] }; if (false) { /** @type {?} */ CommonComponentSelectorComponent.prototype._componentInfo; /** @type {?} */ CommonComponentSelectorComponent.prototype.dg; /** @type {?} */ CommonComponentSelectorComponent.prototype.selectedIds; /** @type {?} */ CommonComponentSelectorComponent.prototype.columns; /** @type {?} */ CommonComponentSelectorComponent.prototype.dialog; /** @type {?} */ CommonComponentSelectorComponent.prototype.metadata; /** @type {?} */ CommonComponentSelectorComponent.prototype.multiSelection; /** @type {?} */ CommonComponentSelectorComponent.prototype.btnRef; /** @type {?} */ CommonComponentSelectorComponent.prototype.confirmEmitter; /** @type {?} */ CommonComponentSelectorComponent.prototype.closeEmitter; /** * @type {?} * @private */ CommonComponentSelectorComponent.prototype.utils; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-component-selector.component.js","sourceRoot":"ng://@gsp-cmp/ccmp-ui/","sources":["lib/ccmp-selector/common-component-selector.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, EventEmitter, Output, ViewChild, TemplateRef } from '@angular/core';\r\nimport { GspComponent, DefaultGspComponentSerializeContext } from '@gsp-cmp/common-component';\r\nimport { ViewUtils } from '../view-utils/view-utils';\r\nimport { ComponentInfo } from '../params/component-info';\r\nimport { BsModalRef } from '@farris/ui-modal';\r\nimport { ComponentConvertor } from '../convertor/convertor';\r\nimport { Operation } from '@ecp-caf/common-structure';\r\nimport { WebServiceComponentSerializerContext } from '@gsp-cmp/wscmp-models';\r\nimport { SelectedRow, DatagridComponent } from '@farris/ui-datagrid';\r\nimport { Options } from '../params/options';\r\n\r\n@Component({\r\n    selector: 'common-component-selector',\r\n    templateUrl: './common-component-selector.component.html',\r\n    styleUrls: ['./common-component-selector.component.css']\r\n})\r\nexport class CommonComponentSelectorComponent implements OnInit {\r\n\r\n    _componentInfo: ComponentInfo;\r\n\r\n    @Input() set componentInfo(_componentInfo: ComponentInfo) {\r\n\r\n        this._componentInfo = _componentInfo;\r\n\r\n        switch (this._componentInfo.type) {\r\n            case 'CommonComponent':\r\n                this.CommonComponentInit(this._componentInfo);\r\n                break;\r\n            case 'WebServiceComponent':\r\n                this.WebServiceComponentInit(this._componentInfo);\r\n                break;\r\n            default:\r\n                throw new Error('不支持的构件类型' + this._componentInfo.type)\r\n        }\r\n    }\r\n\r\n    @ViewChild('dg') dg: DatagridComponent;\r\n\r\n    selectedIds = [];\r\n\r\n    columns = [];\r\n\r\n    dialog: BsModalRef;\r\n\r\n    metadata: GspComponent;\r\n\r\n    multiSelection: boolean = false;\r\n\r\n    set _options(options: Options) {\r\n        this.multiSelection = options && options.multiSelection || false;\r\n    }\r\n\r\n    @ViewChild('btnRef') btnRef: TemplateRef<any>;\r\n\r\n    @Output() confirmEmitter: EventEmitter<GspComponent> = new EventEmitter();\r\n\r\n    @Output() closeEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n    constructor(private utils: ViewUtils) { }\r\n\r\n    ngOnInit() {\r\n        this._componentInfo = this._componentInfo || new ComponentInfo();\r\n        this.columnsInit();\r\n    }\r\n\r\n    columnsInit() {\r\n        this.columns = [\r\n            { field: 'code', width: 100, title: this.utils.translateService.instant('operation_code') },\r\n            { field: 'name', width: 100, title: this.utils.translateService.instant('operation_name') },\r\n        ];\r\n    }\r\n\r\n    CommonComponentInit(_componentInfo: ComponentInfo) {\r\n        let convertor = new ComponentConvertor();\r\n        let ctx = new DefaultGspComponentSerializeContext();\r\n        this.metadata = convertor.initFromObject(convertor.convertorToObject(_componentInfo.metadata, ctx), ctx);\r\n        this.metadata.operations = new Array<Operation>();\r\n    }\r\n\r\n    WebServiceComponentInit(_componentInfo: ComponentInfo) {\r\n        let convertor = new ComponentConvertor();\r\n        let ctx = new WebServiceComponentSerializerContext();\r\n        this.metadata = convertor.initFromObject(convertor.convertorToObject(_componentInfo.metadata, ctx), ctx);\r\n        this.metadata.operations = new Array<Operation>();\r\n    }\r\n\r\n    confirm() {\r\n        if (this.selectedIds.length <= 0) {\r\n            this.utils.showInfo(this.utils.translateService.instant('operation_choose'), 'info', '', 1500);\r\n            return;\r\n        }\r\n        this.metadata.operations = [];\r\n        this.selectedIds.map(x => {\r\n            let operation = this._componentInfo.metadata.operations.find(op => op.code === x);\r\n            if (operation) {\r\n                this.metadata.operations.push(operation);\r\n            }\r\n        })\r\n        if (this.dialog) {\r\n            this.dialog.close();\r\n        }\r\n        this.confirmEmitter.emit(this.metadata);\r\n        this.selectedIds = [];\r\n    }\r\n\r\n    close() {\r\n        if (this.dialog) {\r\n            this.dialog.close();\r\n        }\r\n        this.closeEmitter.emit();\r\n    }\r\n\r\n    checkedHandler(row: SelectedRow) {\r\n        let index = this.selectedIds.findIndex(x => x === row.id);\r\n        if (index == (-1)) {\r\n            this.selectedIds.push(row.id);\r\n        }\r\n    }\r\n\r\n    unCheckedHandler(row: SelectedRow) {\r\n        let index = this.selectedIds.findIndex(x => x === row.id);\r\n        if (index !== (-1)) {\r\n            this.selectedIds.splice(index, 1);\r\n        }\r\n    }\r\n\r\n    checkAllHandler(rows: SelectedRow[]) {\r\n        if (rows && rows.length > 0) {\r\n            rows.forEach(row => {\r\n                let index = this.selectedIds.findIndex(x => x === row.id);\r\n                if (index == (-1)) {\r\n                    this.selectedIds.push(row.id);\r\n                }\r\n            });\r\n        }\r\n    }\r\n\r\n    unCheckAllHandler(rows: SelectedRow[]) {\r\n        if (rows && rows.length > 0) {\r\n            rows.forEach(row => {\r\n                let index = this.selectedIds.findIndex(x => x === row.id);\r\n                if (index !== (-1)) {\r\n                    this.selectedIds.splice(index, 1);\r\n                }\r\n            });\r\n        }\r\n    }\r\n}\r\n"]}