UNPKG

@delon/abc

Version:

Common business components of ng-alain.

293 lines 25.3 kB
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation, inject } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; import * as i3 from "ng-zorro-antd/icon"; import * as i4 from "ng-zorro-antd/checkbox"; import * as i5 from "ng-zorro-antd/menu"; import * as i6 from "ng-zorro-antd/dropdown"; import * as i7 from "ng-zorro-antd/radio"; import * as i8 from "ng-zorro-antd/input"; import * as i9 from "ng-zorro-antd/input-number"; import * as i10 from "ng-zorro-antd/date-picker"; export class STFilterComponent { constructor() { this.cdr = inject(ChangeDetectorRef); this.visible = false; this.locale = {}; this.n = new EventEmitter(); this.handle = new EventEmitter(); } get icon() { return this.f.icon; } stopPropagation($event) { $event.stopPropagation(); } checkboxChange() { this.n.emit(this.f.menus?.filter(w => w.checked)); } radioChange(item) { this.f.menus.forEach(i => (i.checked = false)); item.checked = !item.checked; this.n.emit(item); } close(result) { if (result != null) this.handle.emit(result); this.visible = false; this.cdr.detectChanges(); } confirm() { this.handle.emit(true); return this; } reset() { this.handle.emit(false); return this; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: STFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: STFilterComponent, selector: "st-filter", inputs: { col: "col", locale: "locale", f: "f" }, outputs: { n: "n", handle: "handle" }, host: { properties: { "class.ant-table-filter-trigger-container": "true", "class.st__filter": "true", "class.ant-table-filter-trigger-container-open": "visible" } }, ngImport: i0, template: ` <span class="ant-table-filter-trigger" [class.active]="visible || f.default" nz-dropdown [nzDropdownMenu]="filterMenu" nzTrigger="click" [nzClickHide]="false" [(nzVisible)]="visible" nzOverlayClassName="st__filter-wrap" (click)="stopPropagation($event)" > <i nz-icon [nzType]="icon.type" [nzTheme]="icon.theme!"></i> </span> <nz-dropdown-menu #filterMenu="nzDropdownMenu"> <div class="ant-table-filter-dropdown"> @switch (f.type) { @case ('keyword') { <div class="st__filter-keyword"> <input type="text" nz-input [attr.placeholder]="f.placeholder" [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" (keyup.enter)="confirm()" /> </div> } @case ('number') { <div class="p-sm st__filter-number"> <nz-input-number [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" [nzMin]="f.number!.min!" [nzMax]="f.number!.max!" [nzStep]="f.number!.step!" [nzPrecision]="f.number!.precision" [nzPlaceHolder]="f.placeholder!" class="width-100" /> </div> } @case ('date') { <div class="p-sm st__filter-date"> @if (f.date!.range) { <nz-range-picker nzInline [nzMode]="$any(f.date!.mode)" [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" [nzShowNow]="f.date!.showNow" [nzShowToday]="f.date!.showToday" [nzDisabledDate]="f.date!.disabledDate" [nzDisabledTime]="f.date!.disabledTime" /> } @else { <nz-date-picker nzInline [nzMode]="$any(f.date!.mode)" [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" [nzShowNow]="f.date!.showNow" [nzShowToday]="f.date!.showToday" [nzDisabledDate]="f.date!.disabledDate" [nzDisabledTime]="f.date!.disabledTime" /> } </div> } @case ('custom') { <div class="st__filter-custom"> <ng-template [ngTemplateOutlet]="f.custom!" [ngTemplateOutletContext]="{ $implicit: f, col: col, handle: this }" /> </div> } @default { <ul nz-menu> @for (filter of f.menus; track $index) { <li nz-menu-item> @if (f.multiple) { <label nz-checkbox [(ngModel)]="filter.checked" (ngModelChange)="checkboxChange()"> {{ filter.text }} </label> } @else { <label nz-radio [ngModel]="filter.checked" (ngModelChange)="radioChange(filter)"> {{ filter.text }} </label> } </li> } </ul> } } @if (f.showOPArea) { <div class="ant-table-filter-dropdown-btns"> <a class="ant-table-filter-dropdown-link confirm" (click)="confirm()"> <span>{{ f.confirmText || locale.filterConfirm }}</span> </a> <a class="ant-table-filter-dropdown-link clear" (click)="reset()"> <span>{{ f.clearText || locale.filterReset }}</span> </a> </div> } </div> </nz-dropdown-menu> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: i4.NzCheckboxComponent, selector: "[nz-checkbox]", inputs: ["nzValue", "nzAutoFocus", "nzDisabled", "nzIndeterminate", "nzChecked", "nzId"], outputs: ["nzCheckedChange"], exportAs: ["nzCheckbox"] }, { kind: "directive", type: i5.NzMenuDirective, selector: "[nz-menu]", inputs: ["nzInlineIndent", "nzTheme", "nzMode", "nzInlineCollapsed", "nzSelectable"], outputs: ["nzClick"], exportAs: ["nzMenu"] }, { kind: "component", type: i5.NzMenuItemComponent, selector: "[nz-menu-item]", inputs: ["nzPaddingLeft", "nzDisabled", "nzSelected", "nzDanger", "nzMatchRouterExact", "nzMatchRouter"], exportAs: ["nzMenuItem"] }, { kind: "directive", type: i6.NzDropDownDirective, selector: "[nz-dropdown]", inputs: ["nzDropdownMenu", "nzTrigger", "nzMatchWidthElement", "nzBackdrop", "nzClickHide", "nzDisabled", "nzVisible", "nzOverlayClassName", "nzOverlayStyle", "nzPlacement"], outputs: ["nzVisibleChange"], exportAs: ["nzDropdown"] }, { kind: "component", type: i6.NzDropdownMenuComponent, selector: "nz-dropdown-menu", exportAs: ["nzDropdownMenu"] }, { kind: "component", type: i7.NzRadioComponent, selector: "[nz-radio],[nz-radio-button]", inputs: ["nzValue", "nzDisabled", "nzAutoFocus", "nz-radio-button"], exportAs: ["nzRadio"] }, { kind: "directive", type: i8.NzInputDirective, selector: "input[nz-input],textarea[nz-input]", inputs: ["nzBorderless", "nzSize", "nzStepperless", "nzStatus", "disabled"], exportAs: ["nzInput"] }, { kind: "component", type: i9.NzInputNumberComponent, selector: "nz-input-number", inputs: ["nzSize", "nzMin", "nzMax", "nzParser", "nzPrecision", "nzPrecisionMode", "nzPlaceHolder", "nzStatus", "nzStep", "nzInputMode", "nzId", "nzDisabled", "nzReadOnly", "nzAutoFocus", "nzBorderless", "nzFormatter"], outputs: ["nzBlur", "nzFocus"], exportAs: ["nzInputNumber"] }, { kind: "component", type: i10.NzDatePickerComponent, selector: "nz-date-picker,nz-week-picker,nz-month-picker,nz-quarter-picker,nz-year-picker,nz-range-picker", inputs: ["nzAllowClear", "nzAutoFocus", "nzDisabled", "nzBorderless", "nzInputReadOnly", "nzInline", "nzOpen", "nzDisabledDate", "nzLocale", "nzPlaceHolder", "nzPopupStyle", "nzDropdownClassName", "nzSize", "nzStatus", "nzFormat", "nzDateRender", "nzDisabledTime", "nzRenderExtraFooter", "nzShowToday", "nzMode", "nzShowNow", "nzRanges", "nzDefaultPickerValue", "nzSeparator", "nzSuffixIcon", "nzBackdrop", "nzId", "nzPlacement", "nzShowWeekNumber", "nzShowTime"], outputs: ["nzOnPanelChange", "nzOnCalendarChange", "nzOnOk", "nzOnOpenChange"], exportAs: ["nzDatePicker"] }, { kind: "directive", type: i10.NzRangePickerComponent, selector: "nz-range-picker", exportAs: ["nzRangePicker"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: STFilterComponent, decorators: [{ type: Component, args: [{ selector: 'st-filter', template: ` <span class="ant-table-filter-trigger" [class.active]="visible || f.default" nz-dropdown [nzDropdownMenu]="filterMenu" nzTrigger="click" [nzClickHide]="false" [(nzVisible)]="visible" nzOverlayClassName="st__filter-wrap" (click)="stopPropagation($event)" > <i nz-icon [nzType]="icon.type" [nzTheme]="icon.theme!"></i> </span> <nz-dropdown-menu #filterMenu="nzDropdownMenu"> <div class="ant-table-filter-dropdown"> @switch (f.type) { @case ('keyword') { <div class="st__filter-keyword"> <input type="text" nz-input [attr.placeholder]="f.placeholder" [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" (keyup.enter)="confirm()" /> </div> } @case ('number') { <div class="p-sm st__filter-number"> <nz-input-number [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" [nzMin]="f.number!.min!" [nzMax]="f.number!.max!" [nzStep]="f.number!.step!" [nzPrecision]="f.number!.precision" [nzPlaceHolder]="f.placeholder!" class="width-100" /> </div> } @case ('date') { <div class="p-sm st__filter-date"> @if (f.date!.range) { <nz-range-picker nzInline [nzMode]="$any(f.date!.mode)" [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" [nzShowNow]="f.date!.showNow" [nzShowToday]="f.date!.showToday" [nzDisabledDate]="f.date!.disabledDate" [nzDisabledTime]="f.date!.disabledTime" /> } @else { <nz-date-picker nzInline [nzMode]="$any(f.date!.mode)" [(ngModel)]="f.menus![0]!.value" (ngModelChange)="n.emit($event)" [nzShowNow]="f.date!.showNow" [nzShowToday]="f.date!.showToday" [nzDisabledDate]="f.date!.disabledDate" [nzDisabledTime]="f.date!.disabledTime" /> } </div> } @case ('custom') { <div class="st__filter-custom"> <ng-template [ngTemplateOutlet]="f.custom!" [ngTemplateOutletContext]="{ $implicit: f, col: col, handle: this }" /> </div> } @default { <ul nz-menu> @for (filter of f.menus; track $index) { <li nz-menu-item> @if (f.multiple) { <label nz-checkbox [(ngModel)]="filter.checked" (ngModelChange)="checkboxChange()"> {{ filter.text }} </label> } @else { <label nz-radio [ngModel]="filter.checked" (ngModelChange)="radioChange(filter)"> {{ filter.text }} </label> } </li> } </ul> } } @if (f.showOPArea) { <div class="ant-table-filter-dropdown-btns"> <a class="ant-table-filter-dropdown-link confirm" (click)="confirm()"> <span>{{ f.confirmText || locale.filterConfirm }}</span> </a> <a class="ant-table-filter-dropdown-link clear" (click)="reset()"> <span>{{ f.clearText || locale.filterReset }}</span> </a> </div> } </div> </nz-dropdown-menu> `, host: { '[class.ant-table-filter-trigger-container]': `true`, '[class.st__filter]': `true`, '[class.ant-table-filter-trigger-container-open]': `visible` }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] }], propDecorators: { col: [{ type: Input }], locale: [{ type: Input }], f: [{ type: Input }], n: [{ type: Output }], handle: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-filter.component.js","sourceRoot":"","sources":["../../../../../packages/abc/st/st-filter.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,iBAAiB,EACjB,MAAM,EACP,MAAM,eAAe,CAAC;;;;;;;;;;;;AA+HvB,MAAM,OAAO,iBAAiB;IAxH9B;QAyHmB,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEjD,YAAO,GAAG,KAAK,CAAC;QAEP,WAAM,GAAe,EAAE,CAAC;QAEd,MAAC,GAAG,IAAI,YAAY,EAAW,CAAC;QAChC,WAAM,GAAG,IAAI,YAAY,EAAW,CAAC;KAmCzD;IAlCC,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,CAAC,CAAC,IAAc,CAAC;IAC/B,CAAC;IAED,eAAe,CAAC,MAAkB;QAChC,MAAM,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,IAAwB;QAClC,IAAI,CAAC,CAAC,CAAC,KAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,MAAgB;QACpB,IAAI,MAAM,IAAI,IAAI;YAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE7C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;8GA1CU,iBAAiB;kGAAjB,iBAAiB,gTAtHlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4GT;;2FAUU,iBAAiB;kBAxH7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,WAAW;oBACrB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4GT;oBACD,IAAI,EAAE;wBACJ,4CAA4C,EAAE,MAAM;wBACpD,oBAAoB,EAAE,MAAM;wBAC5B,iDAAiD,EAAE,SAAS;qBAC7D;oBACD,mBAAmB,EAAE,KAAK;oBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;8BAKU,GAAG;sBAAX,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,CAAC;sBAAT,KAAK;gBACa,CAAC;sBAAnB,MAAM;gBACY,MAAM;sBAAxB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  inject\n} from '@angular/core';\n\nimport { LocaleData } from '@delon/theme';\n\nimport { STColumnFilter, STColumnFilterMenu, STIcon } from './st.interfaces';\nimport { _STColumn } from './st.types';\n\n@Component({\n  selector: 'st-filter',\n  template: `\n    <span\n      class=\"ant-table-filter-trigger\"\n      [class.active]=\"visible || f.default\"\n      nz-dropdown\n      [nzDropdownMenu]=\"filterMenu\"\n      nzTrigger=\"click\"\n      [nzClickHide]=\"false\"\n      [(nzVisible)]=\"visible\"\n      nzOverlayClassName=\"st__filter-wrap\"\n      (click)=\"stopPropagation($event)\"\n    >\n      <i nz-icon [nzType]=\"icon.type\" [nzTheme]=\"icon.theme!\"></i>\n    </span>\n    <nz-dropdown-menu #filterMenu=\"nzDropdownMenu\">\n      <div class=\"ant-table-filter-dropdown\">\n        @switch (f.type) {\n          @case ('keyword') {\n            <div class=\"st__filter-keyword\">\n              <input\n                type=\"text\"\n                nz-input\n                [attr.placeholder]=\"f.placeholder\"\n                [(ngModel)]=\"f.menus![0]!.value\"\n                (ngModelChange)=\"n.emit($event)\"\n                (keyup.enter)=\"confirm()\"\n              />\n            </div>\n          }\n          @case ('number') {\n            <div class=\"p-sm st__filter-number\">\n              <nz-input-number\n                [(ngModel)]=\"f.menus![0]!.value\"\n                (ngModelChange)=\"n.emit($event)\"\n                [nzMin]=\"f.number!.min!\"\n                [nzMax]=\"f.number!.max!\"\n                [nzStep]=\"f.number!.step!\"\n                [nzPrecision]=\"f.number!.precision\"\n                [nzPlaceHolder]=\"f.placeholder!\"\n                class=\"width-100\"\n              />\n            </div>\n          }\n          @case ('date') {\n            <div class=\"p-sm st__filter-date\">\n              @if (f.date!.range) {\n                <nz-range-picker\n                  nzInline\n                  [nzMode]=\"$any(f.date!.mode)\"\n                  [(ngModel)]=\"f.menus![0]!.value\"\n                  (ngModelChange)=\"n.emit($event)\"\n                  [nzShowNow]=\"f.date!.showNow\"\n                  [nzShowToday]=\"f.date!.showToday\"\n                  [nzDisabledDate]=\"f.date!.disabledDate\"\n                  [nzDisabledTime]=\"f.date!.disabledTime\"\n                />\n              } @else {\n                <nz-date-picker\n                  nzInline\n                  [nzMode]=\"$any(f.date!.mode)\"\n                  [(ngModel)]=\"f.menus![0]!.value\"\n                  (ngModelChange)=\"n.emit($event)\"\n                  [nzShowNow]=\"f.date!.showNow\"\n                  [nzShowToday]=\"f.date!.showToday\"\n                  [nzDisabledDate]=\"f.date!.disabledDate\"\n                  [nzDisabledTime]=\"f.date!.disabledTime\"\n                />\n              }\n            </div>\n          }\n          @case ('custom') {\n            <div class=\"st__filter-custom\">\n              <ng-template\n                [ngTemplateOutlet]=\"f.custom!\"\n                [ngTemplateOutletContext]=\"{ $implicit: f, col: col, handle: this }\"\n              />\n            </div>\n          }\n          @default {\n            <ul nz-menu>\n              @for (filter of f.menus; track $index) {\n                <li nz-menu-item>\n                  @if (f.multiple) {\n                    <label nz-checkbox [(ngModel)]=\"filter.checked\" (ngModelChange)=\"checkboxChange()\">\n                      {{ filter.text }}\n                    </label>\n                  } @else {\n                    <label nz-radio [ngModel]=\"filter.checked\" (ngModelChange)=\"radioChange(filter)\">\n                      {{ filter.text }}\n                    </label>\n                  }\n                </li>\n              }\n            </ul>\n          }\n        }\n        @if (f.showOPArea) {\n          <div class=\"ant-table-filter-dropdown-btns\">\n            <a class=\"ant-table-filter-dropdown-link confirm\" (click)=\"confirm()\">\n              <span>{{ f.confirmText || locale.filterConfirm }}</span>\n            </a>\n            <a class=\"ant-table-filter-dropdown-link clear\" (click)=\"reset()\">\n              <span>{{ f.clearText || locale.filterReset }}</span>\n            </a>\n          </div>\n        }\n      </div>\n    </nz-dropdown-menu>\n  `,\n  host: {\n    '[class.ant-table-filter-trigger-container]': `true`,\n    '[class.st__filter]': `true`,\n    '[class.ant-table-filter-trigger-container-open]': `visible`\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class STFilterComponent {\n  private readonly cdr = inject(ChangeDetectorRef);\n\n  visible = false;\n  @Input() col!: _STColumn;\n  @Input() locale: LocaleData = {};\n  @Input() f!: STColumnFilter;\n  @Output() readonly n = new EventEmitter<unknown>();\n  @Output() readonly handle = new EventEmitter<boolean>();\n  get icon(): STIcon {\n    return this.f.icon as STIcon;\n  }\n\n  stopPropagation($event: MouseEvent): void {\n    $event.stopPropagation();\n  }\n\n  checkboxChange(): void {\n    this.n.emit(this.f.menus?.filter(w => w.checked));\n  }\n\n  radioChange(item: STColumnFilterMenu): void {\n    this.f.menus!.forEach(i => (i.checked = false));\n    item.checked = !item.checked;\n    this.n.emit(item);\n  }\n\n  close(result?: boolean): void {\n    if (result != null) this.handle.emit(result);\n\n    this.visible = false;\n    this.cdr.detectChanges();\n  }\n\n  confirm(): this {\n    this.handle.emit(true);\n    return this;\n  }\n\n  reset(): this {\n    this.handle.emit(false);\n    return this;\n  }\n}\n"]}