UNPKG

geminis-ng

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.2.14.

129 lines 13.2 kB
var GnSelectComponent_1; import { __decorate } from "tslib"; import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { GnFormItem } from '../json-form/json-form-item/FormItem'; import { HttpClient } from '@angular/common/http'; import { GnMessageService } from '../message-service/message-service'; import { GnObjectUtils } from 'geminis-ng-core'; let GnSelectComponent = GnSelectComponent_1 = class GnSelectComponent { constructor(http, messageService) { this.http = http; this.messageService = messageService; this.items = []; this.pageSize = 10; this.valueChanged = new EventEmitter(); this.valueChange = (value) => { }; } set value(v) { if (this.innerValue !== v) { this.innerValue = v; this.valueChange(this.innerValue); } } get value() { return this.innerValue; } searchData(value) { if (this.showSearch) { this.searchValue = value; this.pageIndex = 0; this.noMore = false; this.items = []; this.fetchData(); } } appendData() { if (this.showSearch && !this.noMore) { this.pageIndex++; this.fetchData(); } } fetchData() { this.loading = true; const queryParameter = { pageSize: this.pageSize, pageIndex: this.pageIndex, includes: this.includes || [], filterGroup: { type: 'and', filters: [ { field: this.searchField, compareType: 'like', value: '%' + this.searchValue + '%' } ] } }; this.http.post(this.url, queryParameter) .subscribe((resp) => { if (resp.content.length === 0) { this.noMore = true; } resp.content.forEach(data => { this.items.push({ value: GnObjectUtils.getValue(data, this.valueField), label: GnObjectUtils.getValue(data, this.labelField) }); }); this.loading = false; }, error => { this.loading = false; this.messageService.error('获取数据错误'); throw error; }); } registerOnChange(fn) { this.valueChange = fn; } registerOnTouched(fn) { } writeValue(obj) { this.value = obj; } }; GnSelectComponent.decorators = [ { type: Component, args: [{ selector: 'gn-select', template: ` <nz-select [(ngModel)]="value" [nzAllowClear]="allowClear" [nzPlaceHolder]="placeHolder" (ngModelChange)="valueChanged.emit()" [nzShowSearch]="showSearch" [nzLoading]="loading" (nzOnSearch)="searchData($event)" (nzScrollToBottom)="appendData()" [nzDropdownRender]="renderTemplate"> <nz-option *ngFor="let item of items" [nzValue]="item.value" [nzLabel]="item.label"></nz-option> </nz-select> <ng-template #renderTemplate> <nz-spin *ngIf="loading"></nz-spin> </ng-template> `, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => GnSelectComponent_1), multi: true }] },] } ]; GnSelectComponent.ctorParameters = () => [ { type: HttpClient }, { type: GnMessageService } ]; GnSelectComponent.propDecorators = { value: [{ type: Input }], items: [{ type: Input }], placeHolder: [{ type: Input }], allowClear: [{ type: Input }], showSearch: [{ type: Input }], url: [{ type: Input }], pageSize: [{ type: Input }], includes: [{ type: Input }], searchField: [{ type: Input }], valueField: [{ type: Input }], labelField: [{ type: Input }], valueChanged: [{ type: Output }] }; GnSelectComponent = GnSelectComponent_1 = __decorate([ GnFormItem('select') ], GnSelectComponent); export { GnSelectComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../projects/geminis-ng/src/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, Output} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {GnFormItem} from '../json-form/json-form-item/FormItem';\nimport {HttpClient} from '@angular/common/http';\nimport {GnMessageService} from '../message-service/message-service';\nimport {GnObjectUtils} from 'geminis-ng-core';\n\n@Component({\n  selector: 'gn-select',\n  template: `\n    <nz-select [(ngModel)]=\"value\" [nzAllowClear]=\"allowClear\" [nzPlaceHolder]=\"placeHolder\"\n               (ngModelChange)=\"valueChanged.emit()\" [nzShowSearch]=\"showSearch\" [nzLoading]=\"loading\"\n               (nzOnSearch)=\"searchData($event)\" (nzScrollToBottom)=\"appendData()\" [nzDropdownRender]=\"renderTemplate\">\n      <nz-option *ngFor=\"let item of items\" [nzValue]=\"item.value\" [nzLabel]=\"item.label\"></nz-option>\n    </nz-select>\n    <ng-template #renderTemplate>\n      <nz-spin *ngIf=\"loading\"></nz-spin>\n    </ng-template>\n  `,\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => GnSelectComponent),\n    multi: true\n  }]\n})\n@GnFormItem('select')\nexport class GnSelectComponent implements ControlValueAccessor {\n\n  private innerValue: any;\n  private pageIndex: number;\n  private searchValue: string;\n  private noMore: boolean;\n\n  loading: boolean;\n\n  @Input() set value(v: any) {\n    if (this.innerValue !== v) {\n      this.innerValue = v;\n      this.valueChange(this.innerValue);\n    }\n  }\n\n  get value(): any {\n    return this.innerValue;\n  }\n\n  @Input() items: { value: any, label: string }[] = [];\n\n  @Input() placeHolder: string;\n  @Input() allowClear: boolean;\n  @Input() showSearch: boolean;\n  @Input() url: string;\n  @Input() pageSize = 10;\n  @Input() includes: string[];\n  @Input() searchField: string;\n  @Input() valueField: string;\n  @Input() labelField: string;\n  @Output() valueChanged = new EventEmitter();\n\n  constructor(private http: HttpClient,\n              private messageService: GnMessageService) {\n  }\n\n  searchData(value: string): void {\n    if (this.showSearch) {\n      this.searchValue = value;\n      this.pageIndex = 0;\n      this.noMore = false;\n      this.items = [];\n      this.fetchData();\n    }\n  }\n\n  appendData(): void {\n    if (this.showSearch && !this.noMore) {\n      this.pageIndex++;\n      this.fetchData();\n    }\n  }\n\n  private fetchData(): void {\n    this.loading = true;\n    const queryParameter = {\n      pageSize: this.pageSize,\n      pageIndex: this.pageIndex,\n      includes: this.includes || [],\n      filterGroup: {\n        type: 'and',\n        filters: [\n          {\n            field: this.searchField,\n            compareType: 'like',\n            value: '%' + this.searchValue + '%'\n          }\n        ]\n      }\n    };\n    this.http.post(this.url, queryParameter)\n      .subscribe((resp: any) => {\n          if (resp.content.length === 0) {\n            this.noMore = true;\n          }\n          resp.content.forEach(data => {\n            this.items.push({\n              value: GnObjectUtils.getValue(data, this.valueField),\n              label: GnObjectUtils.getValue(data, this.labelField)\n            });\n          });\n          this.loading = false;\n        },\n        error => {\n          this.loading = false;\n          this.messageService.error('获取数据错误');\n          throw error;\n        });\n  }\n\n  valueChange = (value: any) => {\n  }\n\n  registerOnChange(fn: any): void {\n    this.valueChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  writeValue(obj: any): void {\n    this.value = obj;\n  }\n\n}\n"]}