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
JavaScript
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"]}