UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

453 lines 48.8 kB
import { __decorate } from "tslib"; /** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { A11yModule } from '@angular/cdk/a11y'; import { OverlayModule } from '@angular/cdk/overlay'; import { DOCUMENT, NgClass, NgStyle } from '@angular/common'; import { ChangeDetectionStrategy, Component, Directive, ElementRef, EventEmitter, Input, Output, ViewChildren, ViewEncapsulation, booleanAttribute, inject } from '@angular/core'; import { Subject } from 'rxjs'; import { finalize, first, takeUntil } from 'rxjs/operators'; import { NzButtonModule } from 'ng-zorro-antd/button'; import { zoomBigMotion } from 'ng-zorro-antd/core/animation'; import { WithConfig } from 'ng-zorro-antd/core/config'; import { NzNoAnimationDirective } from 'ng-zorro-antd/core/no-animation'; import { NzOutletModule } from 'ng-zorro-antd/core/outlet'; import { NzOverlayModule } from 'ng-zorro-antd/core/overlay'; import { wrapIntoObservable } from 'ng-zorro-antd/core/util'; import { NzI18nModule } from 'ng-zorro-antd/i18n'; import { NzIconModule } from 'ng-zorro-antd/icon'; import { NzToolTipComponent, NzTooltipBaseDirective } from 'ng-zorro-antd/tooltip'; import * as i0 from "@angular/core"; import * as i1 from "@angular/cdk/overlay"; import * as i2 from "ng-zorro-antd/core/overlay"; import * as i3 from "@angular/cdk/a11y"; import * as i4 from "ng-zorro-antd/core/outlet"; import * as i5 from "ng-zorro-antd/icon"; import * as i6 from "ng-zorro-antd/button"; import * as i7 from "ng-zorro-antd/core/transition-patch"; import * as i8 from "ng-zorro-antd/core/wave"; import * as i9 from "ng-zorro-antd/i18n"; const NZ_CONFIG_MODULE_NAME = 'popconfirm'; export class NzPopconfirmDirective extends NzTooltipBaseDirective { getProxyPropertyMap() { return { nzOkText: ['nzOkText', () => this.nzOkText], nzOkType: ['nzOkType', () => this.nzOkType], nzOkDanger: ['nzOkDanger', () => this.nzOkDanger], nzOkDisabled: ['nzOkDisabled', () => this.nzOkDisabled], nzCancelText: ['nzCancelText', () => this.nzCancelText], nzBeforeConfirm: ['nzBeforeConfirm', () => this.nzBeforeConfirm], nzCondition: ['nzCondition', () => this.nzCondition], nzIcon: ['nzIcon', () => this.nzIcon], nzPopconfirmShowArrow: ['nzPopconfirmShowArrow', () => this.nzPopconfirmShowArrow], nzPopconfirmBackdrop: ['nzBackdrop', () => this.nzPopconfirmBackdrop], nzPopconfirmContext: ['nzTitleContext', () => this.titleContext], nzAutoFocus: ['nzAutoFocus', () => this.nzAutofocus], ...super.getProxyPropertyMap() }; } constructor() { super(NzPopconfirmComponent); this._nzModuleName = NZ_CONFIG_MODULE_NAME; this.titleContext = null; this.trigger = 'click'; this.placement = 'top'; this.nzCondition = false; this.nzPopconfirmShowArrow = true; this.nzPopconfirmBackdrop = false; this.nzAutofocus = null; // eslint-disable-next-line @angular-eslint/no-output-rename this.visibleChange = new EventEmitter(); this.nzOnCancel = new EventEmitter(); this.nzOnConfirm = new EventEmitter(); } /** * @override */ createComponent() { super.createComponent(); this.component.nzOnCancel.pipe(takeUntil(this.destroy$)).subscribe(() => { this.nzOnCancel.emit(); }); this.component.nzOnConfirm.pipe(takeUntil(this.destroy$)).subscribe(() => { this.nzOnConfirm.emit(); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzPopconfirmDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.1.2", type: NzPopconfirmDirective, isStandalone: true, selector: "[nz-popconfirm]", inputs: { arrowPointAtCenter: ["nzPopconfirmArrowPointAtCenter", "arrowPointAtCenter", booleanAttribute], title: ["nzPopconfirmTitle", "title"], titleContext: ["nzPopconfirmTitleContext", "titleContext"], directiveTitle: ["nz-popconfirm", "directiveTitle"], trigger: ["nzPopconfirmTrigger", "trigger"], placement: ["nzPopconfirmPlacement", "placement"], origin: ["nzPopconfirmOrigin", "origin"], mouseEnterDelay: ["nzPopconfirmMouseEnterDelay", "mouseEnterDelay"], mouseLeaveDelay: ["nzPopconfirmMouseLeaveDelay", "mouseLeaveDelay"], overlayClassName: ["nzPopconfirmOverlayClassName", "overlayClassName"], overlayStyle: ["nzPopconfirmOverlayStyle", "overlayStyle"], visible: ["nzPopconfirmVisible", "visible"], nzOkText: "nzOkText", nzOkType: "nzOkType", nzOkDisabled: ["nzOkDisabled", "nzOkDisabled", booleanAttribute], nzOkDanger: ["nzOkDanger", "nzOkDanger", booleanAttribute], nzCancelText: "nzCancelText", nzBeforeConfirm: "nzBeforeConfirm", nzIcon: "nzIcon", nzCondition: ["nzCondition", "nzCondition", booleanAttribute], nzPopconfirmShowArrow: ["nzPopconfirmShowArrow", "nzPopconfirmShowArrow", booleanAttribute], nzPopconfirmBackdrop: "nzPopconfirmBackdrop", nzAutofocus: "nzAutofocus" }, outputs: { visibleChange: "nzPopconfirmVisibleChange", nzOnCancel: "nzOnCancel", nzOnConfirm: "nzOnConfirm" }, host: { properties: { "class.ant-popover-open": "visible" } }, exportAs: ["nzPopconfirm"], usesInheritance: true, ngImport: i0 }); } } __decorate([ WithConfig() ], NzPopconfirmDirective.prototype, "nzPopconfirmBackdrop", void 0); __decorate([ WithConfig() ], NzPopconfirmDirective.prototype, "nzAutofocus", void 0); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzPopconfirmDirective, decorators: [{ type: Directive, args: [{ selector: '[nz-popconfirm]', exportAs: 'nzPopconfirm', host: { '[class.ant-popover-open]': 'visible' }, standalone: true }] }], ctorParameters: () => [], propDecorators: { arrowPointAtCenter: [{ type: Input, args: [{ alias: 'nzPopconfirmArrowPointAtCenter', transform: booleanAttribute }] }], title: [{ type: Input, args: ['nzPopconfirmTitle'] }], titleContext: [{ type: Input, args: ['nzPopconfirmTitleContext'] }], directiveTitle: [{ type: Input, args: ['nz-popconfirm'] }], trigger: [{ type: Input, args: ['nzPopconfirmTrigger'] }], placement: [{ type: Input, args: ['nzPopconfirmPlacement'] }], origin: [{ type: Input, args: ['nzPopconfirmOrigin'] }], mouseEnterDelay: [{ type: Input, args: ['nzPopconfirmMouseEnterDelay'] }], mouseLeaveDelay: [{ type: Input, args: ['nzPopconfirmMouseLeaveDelay'] }], overlayClassName: [{ type: Input, args: ['nzPopconfirmOverlayClassName'] }], overlayStyle: [{ type: Input, args: ['nzPopconfirmOverlayStyle'] }], visible: [{ type: Input, args: ['nzPopconfirmVisible'] }], nzOkText: [{ type: Input }], nzOkType: [{ type: Input }], nzOkDisabled: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzOkDanger: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzCancelText: [{ type: Input }], nzBeforeConfirm: [{ type: Input }], nzIcon: [{ type: Input }], nzCondition: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzPopconfirmShowArrow: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzPopconfirmBackdrop: [{ type: Input }], nzAutofocus: [{ type: Input }], visibleChange: [{ type: Output, args: ['nzPopconfirmVisibleChange'] }], nzOnCancel: [{ type: Output }], nzOnConfirm: [{ type: Output }] } }); export class NzPopconfirmComponent extends NzToolTipComponent { constructor(elementRef) { super(); this.elementRef = elementRef; this.nzCondition = false; this.nzPopconfirmShowArrow = true; this.nzOkType = 'primary'; this.nzOkDanger = false; this.nzOkDisabled = false; this.nzAutoFocus = null; this.nzBeforeConfirm = null; this.nzOnCancel = new Subject(); this.nzOnConfirm = new Subject(); this._trigger = 'click'; this.elementFocusedBeforeModalWasOpened = null; this.document = inject(DOCUMENT); this._prefix = 'ant-popover'; this.confirmLoading = false; } ngOnDestroy() { super.ngOnDestroy(); this.nzOnCancel.complete(); this.nzOnConfirm.complete(); } /** * @override */ show() { if (!this.nzCondition) { this.capturePreviouslyFocusedElement(); super.show(); } else { this.onConfirm(); } } hide() { super.hide(); this.restoreFocus(); } handleConfirm() { this.nzOnConfirm.next(); super.hide(); } onCancel() { this.nzOnCancel.next(); super.hide(); } onConfirm() { if (this.nzBeforeConfirm) { const observable = wrapIntoObservable(this.nzBeforeConfirm()).pipe(first()); this.confirmLoading = true; observable .pipe(finalize(() => { this.confirmLoading = false; this.cdr.markForCheck(); }), takeUntil(this.nzVisibleChange), takeUntil(this.destroy$)) .subscribe(value => { if (value) { this.handleConfirm(); } }); } else { this.handleConfirm(); } } capturePreviouslyFocusedElement() { if (this.document) { this.elementFocusedBeforeModalWasOpened = this.document.activeElement; } } restoreFocus() { const toFocus = this.elementFocusedBeforeModalWasOpened; // We need the extra check, because IE can set the `activeElement` to null in some cases. if (toFocus && typeof toFocus.focus === 'function') { const activeElement = this.document.activeElement; const element = this.elementRef.nativeElement; if (!activeElement || activeElement === this.document.body || activeElement === element || element.contains(activeElement)) { toFocus.focus(); } } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzPopconfirmComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzPopconfirmComponent, isStandalone: true, selector: "nz-popconfirm", viewQueries: [{ propertyName: "okBtn", predicate: ["okBtn"], descendants: true, read: ElementRef }, { propertyName: "cancelBtn", predicate: ["cancelBtn"], descendants: true, read: ElementRef }], exportAs: ["nzPopconfirmComponent"], usesInheritance: true, ngImport: i0, template: ` <ng-template #overlay="cdkConnectedOverlay" cdkConnectedOverlay nzConnectedOverlay [cdkConnectedOverlayHasBackdrop]="nzBackdrop" [cdkConnectedOverlayOrigin]="origin" (overlayOutsideClick)="onClickOutside($event)" (detach)="hide()" (positionChange)="onPositionChange($event)" [cdkConnectedOverlayPositions]="_positions" [cdkConnectedOverlayOpen]="_visible" [cdkConnectedOverlayPush]="cdkConnectedOverlayPush" [nzArrowPointAtCenter]="nzArrowPointAtCenter" > <div cdkTrapFocus [cdkTrapFocusAutoCapture]="nzAutoFocus !== null" class="ant-popover" [ngClass]="_classMap" [class.ant-popover-rtl]="dir === 'rtl'" [ngStyle]="nzOverlayStyle" [@.disabled]="!!noAnimation?.nzNoAnimation" [nzNoAnimation]="noAnimation?.nzNoAnimation" [@zoomBigMotion]="'active'" > <div class="ant-popover-content"> @if (nzPopconfirmShowArrow) { <div class="ant-popover-arrow"> <span class="ant-popover-arrow-content"></span> </div> } <div class="ant-popover-inner"> <div> <div class="ant-popover-inner-content"> <div class="ant-popover-message"> <ng-container *nzStringTemplateOutlet="nzTitle; context: nzTitleContext"> <ng-container *nzStringTemplateOutlet="nzIcon; let icon"> <span class="ant-popover-message-icon"> <span nz-icon [nzType]="icon || 'exclamation-circle'" nzTheme="fill"></span> </span> </ng-container> <div class="ant-popover-message-title">{{ nzTitle }}</div> </ng-container> </div> <div class="ant-popover-buttons"> <button nz-button #cancelBtn [nzSize]="'small'" (click)="onCancel()" [attr.cdkFocusInitial]="nzAutoFocus === 'cancel' || null" > @if (nzCancelText) { {{ nzCancelText }} } @else { {{ 'Modal.cancelText' | nzI18n }} } </button> <button nz-button #okBtn [nzSize]="'small'" [nzType]="nzOkType !== 'danger' ? nzOkType : 'primary'" [nzDanger]="nzOkDanger || nzOkType === 'danger'" [nzLoading]="confirmLoading" [disabled]="nzOkDisabled" (click)="onConfirm()" [attr.cdkFocusInitial]="nzAutoFocus === 'ok' || null" > @if (nzOkText) { {{ nzOkText }} } @else { {{ 'Modal.okText' | nzI18n }} } </button> </div> </div> </div> </div> </div> </div> </ng-template> `, isInline: true, dependencies: [{ kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i1.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "ngmodule", type: NzOverlayModule }, { kind: "directive", type: i2.NzConnectedOverlayDirective, selector: "[cdkConnectedOverlay][nzConnectedOverlay]", inputs: ["nzArrowPointAtCenter"], exportAs: ["nzConnectedOverlay"] }, { kind: "ngmodule", type: A11yModule }, { kind: "directive", type: i3.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NzNoAnimationDirective, selector: "[nzNoAnimation]", inputs: ["nzNoAnimation"], exportAs: ["nzNoAnimation"] }, { kind: "ngmodule", type: NzOutletModule }, { kind: "directive", type: i4.NzStringTemplateOutletDirective, selector: "[nzStringTemplateOutlet]", inputs: ["nzStringTemplateOutletContext", "nzStringTemplateOutlet"], exportAs: ["nzStringTemplateOutlet"] }, { kind: "ngmodule", type: NzIconModule }, { kind: "directive", type: i5.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "ngmodule", type: NzButtonModule }, { kind: "component", type: i6.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }, { kind: "directive", type: i7.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { kind: "directive", type: i8.NzWaveDirective, selector: "[nz-wave],button[nz-button]:not([nzType=\"link\"]):not([nzType=\"text\"])", inputs: ["nzWaveExtraNode"], exportAs: ["nzWave"] }, { kind: "ngmodule", type: NzI18nModule }, { kind: "pipe", type: i9.NzI18nPipe, name: "nzI18n" }], animations: [zoomBigMotion], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzPopconfirmComponent, decorators: [{ type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-popconfirm', exportAs: 'nzPopconfirmComponent', preserveWhitespaces: false, animations: [zoomBigMotion], template: ` <ng-template #overlay="cdkConnectedOverlay" cdkConnectedOverlay nzConnectedOverlay [cdkConnectedOverlayHasBackdrop]="nzBackdrop" [cdkConnectedOverlayOrigin]="origin" (overlayOutsideClick)="onClickOutside($event)" (detach)="hide()" (positionChange)="onPositionChange($event)" [cdkConnectedOverlayPositions]="_positions" [cdkConnectedOverlayOpen]="_visible" [cdkConnectedOverlayPush]="cdkConnectedOverlayPush" [nzArrowPointAtCenter]="nzArrowPointAtCenter" > <div cdkTrapFocus [cdkTrapFocusAutoCapture]="nzAutoFocus !== null" class="ant-popover" [ngClass]="_classMap" [class.ant-popover-rtl]="dir === 'rtl'" [ngStyle]="nzOverlayStyle" [@.disabled]="!!noAnimation?.nzNoAnimation" [nzNoAnimation]="noAnimation?.nzNoAnimation" [@zoomBigMotion]="'active'" > <div class="ant-popover-content"> @if (nzPopconfirmShowArrow) { <div class="ant-popover-arrow"> <span class="ant-popover-arrow-content"></span> </div> } <div class="ant-popover-inner"> <div> <div class="ant-popover-inner-content"> <div class="ant-popover-message"> <ng-container *nzStringTemplateOutlet="nzTitle; context: nzTitleContext"> <ng-container *nzStringTemplateOutlet="nzIcon; let icon"> <span class="ant-popover-message-icon"> <span nz-icon [nzType]="icon || 'exclamation-circle'" nzTheme="fill"></span> </span> </ng-container> <div class="ant-popover-message-title">{{ nzTitle }}</div> </ng-container> </div> <div class="ant-popover-buttons"> <button nz-button #cancelBtn [nzSize]="'small'" (click)="onCancel()" [attr.cdkFocusInitial]="nzAutoFocus === 'cancel' || null" > @if (nzCancelText) { {{ nzCancelText }} } @else { {{ 'Modal.cancelText' | nzI18n }} } </button> <button nz-button #okBtn [nzSize]="'small'" [nzType]="nzOkType !== 'danger' ? nzOkType : 'primary'" [nzDanger]="nzOkDanger || nzOkType === 'danger'" [nzLoading]="confirmLoading" [disabled]="nzOkDisabled" (click)="onConfirm()" [attr.cdkFocusInitial]="nzAutoFocus === 'ok' || null" > @if (nzOkText) { {{ nzOkText }} } @else { {{ 'Modal.okText' | nzI18n }} } </button> </div> </div> </div> </div> </div> </div> </ng-template> `, imports: [ OverlayModule, NzOverlayModule, A11yModule, NgClass, NgStyle, NzNoAnimationDirective, NzOutletModule, NzIconModule, NzButtonModule, NzI18nModule ], standalone: true }] }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { okBtn: [{ type: ViewChildren, args: ['okBtn', { read: ElementRef }] }], cancelBtn: [{ type: ViewChildren, args: ['cancelBtn', { read: ElementRef }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popconfirm.js","sourceRoot":"","sources":["../../../components/popconfirm/popconfirm.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { A11yModule } from '@angular/cdk/a11y';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { DOCUMENT, NgClass, NgStyle } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChildren,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject\n} from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { finalize, first, takeUntil } from 'rxjs/operators';\n\nimport { NzButtonModule, NzButtonType } from 'ng-zorro-antd/button';\nimport { zoomBigMotion } from 'ng-zorro-antd/core/animation';\nimport { NzConfigKey, WithConfig } from 'ng-zorro-antd/core/config';\nimport { NzNoAnimationDirective } from 'ng-zorro-antd/core/no-animation';\nimport { NzOutletModule } from 'ng-zorro-antd/core/outlet';\nimport { NzOverlayModule } from 'ng-zorro-antd/core/overlay';\nimport { NgStyleInterface, NzTSType } from 'ng-zorro-antd/core/types';\nimport { wrapIntoObservable } from 'ng-zorro-antd/core/util';\nimport { NzI18nModule } from 'ng-zorro-antd/i18n';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\nimport { NzToolTipComponent, NzTooltipBaseDirective, NzTooltipTrigger, PropertyMapping } from 'ng-zorro-antd/tooltip';\n\nexport type NzAutoFocusType = null | 'ok' | 'cancel';\n\nconst NZ_CONFIG_MODULE_NAME: NzConfigKey = 'popconfirm';\n\n@Directive({\n  selector: '[nz-popconfirm]',\n  exportAs: 'nzPopconfirm',\n  host: {\n    '[class.ant-popover-open]': 'visible'\n  },\n  standalone: true\n})\nexport class NzPopconfirmDirective extends NzTooltipBaseDirective {\n  readonly _nzModuleName: NzConfigKey = NZ_CONFIG_MODULE_NAME;\n\n  @Input({ alias: 'nzPopconfirmArrowPointAtCenter', transform: booleanAttribute })\n  override arrowPointAtCenter?: boolean;\n  @Input('nzPopconfirmTitle') override title?: NzTSType;\n  @Input('nzPopconfirmTitleContext') titleContext?: Object | null = null;\n  @Input('nz-popconfirm') override directiveTitle?: NzTSType | null;\n  @Input('nzPopconfirmTrigger') override trigger?: NzTooltipTrigger = 'click';\n  @Input('nzPopconfirmPlacement') override placement?: string | string[] = 'top';\n  @Input('nzPopconfirmOrigin') override origin?: ElementRef<HTMLElement>;\n  @Input('nzPopconfirmMouseEnterDelay') override mouseEnterDelay?: number;\n  @Input('nzPopconfirmMouseLeaveDelay') override mouseLeaveDelay?: number;\n  @Input('nzPopconfirmOverlayClassName') override overlayClassName?: string;\n  @Input('nzPopconfirmOverlayStyle') override overlayStyle?: NgStyleInterface;\n  @Input('nzPopconfirmVisible') override visible?: boolean;\n  @Input() nzOkText?: string;\n  @Input() nzOkType?: string;\n  @Input({ transform: booleanAttribute }) nzOkDisabled?: boolean;\n  @Input({ transform: booleanAttribute }) nzOkDanger?: boolean;\n  @Input() nzCancelText?: string;\n  @Input() nzBeforeConfirm?: () => Observable<boolean> | Promise<boolean> | boolean;\n  @Input() nzIcon?: string | TemplateRef<void>;\n  @Input({ transform: booleanAttribute }) nzCondition: boolean = false;\n  @Input({ transform: booleanAttribute }) nzPopconfirmShowArrow: boolean = true;\n  @Input() @WithConfig() nzPopconfirmBackdrop?: boolean = false;\n  @Input() @WithConfig() nzAutofocus: NzAutoFocusType = null;\n\n  // eslint-disable-next-line @angular-eslint/no-output-rename\n  @Output('nzPopconfirmVisibleChange') override readonly visibleChange = new EventEmitter<boolean>();\n  @Output() readonly nzOnCancel = new EventEmitter<void>();\n  @Output() readonly nzOnConfirm = new EventEmitter<void>();\n\n  protected override getProxyPropertyMap(): PropertyMapping {\n    return {\n      nzOkText: ['nzOkText', () => this.nzOkText],\n      nzOkType: ['nzOkType', () => this.nzOkType],\n      nzOkDanger: ['nzOkDanger', () => this.nzOkDanger],\n      nzOkDisabled: ['nzOkDisabled', () => this.nzOkDisabled],\n      nzCancelText: ['nzCancelText', () => this.nzCancelText],\n      nzBeforeConfirm: ['nzBeforeConfirm', () => this.nzBeforeConfirm],\n      nzCondition: ['nzCondition', () => this.nzCondition],\n      nzIcon: ['nzIcon', () => this.nzIcon],\n      nzPopconfirmShowArrow: ['nzPopconfirmShowArrow', () => this.nzPopconfirmShowArrow],\n      nzPopconfirmBackdrop: ['nzBackdrop', () => this.nzPopconfirmBackdrop],\n      nzPopconfirmContext: ['nzTitleContext', () => this.titleContext],\n      nzAutoFocus: ['nzAutoFocus', () => this.nzAutofocus],\n      ...super.getProxyPropertyMap()\n    };\n  }\n\n  constructor() {\n    super(NzPopconfirmComponent);\n  }\n\n  /**\n   * @override\n   */\n  protected override createComponent(): void {\n    super.createComponent();\n\n    (this.component as NzPopconfirmComponent).nzOnCancel.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.nzOnCancel.emit();\n    });\n    (this.component as NzPopconfirmComponent).nzOnConfirm.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.nzOnConfirm.emit();\n    });\n  }\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-popconfirm',\n  exportAs: 'nzPopconfirmComponent',\n  preserveWhitespaces: false,\n  animations: [zoomBigMotion],\n  template: `\n    <ng-template\n      #overlay=\"cdkConnectedOverlay\"\n      cdkConnectedOverlay\n      nzConnectedOverlay\n      [cdkConnectedOverlayHasBackdrop]=\"nzBackdrop\"\n      [cdkConnectedOverlayOrigin]=\"origin\"\n      (overlayOutsideClick)=\"onClickOutside($event)\"\n      (detach)=\"hide()\"\n      (positionChange)=\"onPositionChange($event)\"\n      [cdkConnectedOverlayPositions]=\"_positions\"\n      [cdkConnectedOverlayOpen]=\"_visible\"\n      [cdkConnectedOverlayPush]=\"cdkConnectedOverlayPush\"\n      [nzArrowPointAtCenter]=\"nzArrowPointAtCenter\"\n    >\n      <div\n        cdkTrapFocus\n        [cdkTrapFocusAutoCapture]=\"nzAutoFocus !== null\"\n        class=\"ant-popover\"\n        [ngClass]=\"_classMap\"\n        [class.ant-popover-rtl]=\"dir === 'rtl'\"\n        [ngStyle]=\"nzOverlayStyle\"\n        [@.disabled]=\"!!noAnimation?.nzNoAnimation\"\n        [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n        [@zoomBigMotion]=\"'active'\"\n      >\n        <div class=\"ant-popover-content\">\n          @if (nzPopconfirmShowArrow) {\n            <div class=\"ant-popover-arrow\">\n              <span class=\"ant-popover-arrow-content\"></span>\n            </div>\n          }\n          <div class=\"ant-popover-inner\">\n            <div>\n              <div class=\"ant-popover-inner-content\">\n                <div class=\"ant-popover-message\">\n                  <ng-container *nzStringTemplateOutlet=\"nzTitle; context: nzTitleContext\">\n                    <ng-container *nzStringTemplateOutlet=\"nzIcon; let icon\">\n                      <span class=\"ant-popover-message-icon\">\n                        <span nz-icon [nzType]=\"icon || 'exclamation-circle'\" nzTheme=\"fill\"></span>\n                      </span>\n                    </ng-container>\n                    <div class=\"ant-popover-message-title\">{{ nzTitle }}</div>\n                  </ng-container>\n                </div>\n                <div class=\"ant-popover-buttons\">\n                  <button\n                    nz-button\n                    #cancelBtn\n                    [nzSize]=\"'small'\"\n                    (click)=\"onCancel()\"\n                    [attr.cdkFocusInitial]=\"nzAutoFocus === 'cancel' || null\"\n                  >\n                    @if (nzCancelText) {\n                      {{ nzCancelText }}\n                    } @else {\n                      {{ 'Modal.cancelText' | nzI18n }}\n                    }\n                  </button>\n                  <button\n                    nz-button\n                    #okBtn\n                    [nzSize]=\"'small'\"\n                    [nzType]=\"nzOkType !== 'danger' ? nzOkType : 'primary'\"\n                    [nzDanger]=\"nzOkDanger || nzOkType === 'danger'\"\n                    [nzLoading]=\"confirmLoading\"\n                    [disabled]=\"nzOkDisabled\"\n                    (click)=\"onConfirm()\"\n                    [attr.cdkFocusInitial]=\"nzAutoFocus === 'ok' || null\"\n                  >\n                    @if (nzOkText) {\n                      {{ nzOkText }}\n                    } @else {\n                      {{ 'Modal.okText' | nzI18n }}\n                    }\n                  </button>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </ng-template>\n  `,\n  imports: [\n    OverlayModule,\n    NzOverlayModule,\n    A11yModule,\n    NgClass,\n    NgStyle,\n    NzNoAnimationDirective,\n    NzOutletModule,\n    NzIconModule,\n    NzButtonModule,\n    NzI18nModule\n  ],\n  standalone: true\n})\nexport class NzPopconfirmComponent extends NzToolTipComponent implements OnDestroy {\n  @ViewChildren('okBtn', { read: ElementRef }) okBtn!: QueryList<ElementRef>;\n  @ViewChildren('cancelBtn', { read: ElementRef }) cancelBtn!: QueryList<ElementRef>;\n\n  nzCancelText?: string;\n  nzCondition = false;\n  nzPopconfirmShowArrow = true;\n  nzIcon?: string | TemplateRef<void>;\n  nzOkText?: string;\n  nzOkType: NzButtonType | 'danger' = 'primary';\n  nzOkDanger: boolean = false;\n  nzOkDisabled: boolean = false;\n  nzAutoFocus: NzAutoFocusType = null;\n  nzBeforeConfirm: (() => Observable<boolean> | Promise<boolean> | boolean) | null = null;\n\n  readonly nzOnCancel = new Subject<void>();\n  readonly nzOnConfirm = new Subject<void>();\n\n  protected override _trigger: NzTooltipTrigger = 'click';\n  private elementFocusedBeforeModalWasOpened: HTMLElement | null = null;\n  private document: Document = inject(DOCUMENT);\n\n  override _prefix = 'ant-popover';\n\n  confirmLoading = false;\n\n  constructor(private elementRef: ElementRef) {\n    super();\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n\n    this.nzOnCancel.complete();\n    this.nzOnConfirm.complete();\n  }\n\n  /**\n   * @override\n   */\n  override show(): void {\n    if (!this.nzCondition) {\n      this.capturePreviouslyFocusedElement();\n      super.show();\n    } else {\n      this.onConfirm();\n    }\n  }\n\n  override hide(): void {\n    super.hide();\n    this.restoreFocus();\n  }\n\n  handleConfirm(): void {\n    this.nzOnConfirm.next();\n    super.hide();\n  }\n\n  onCancel(): void {\n    this.nzOnCancel.next();\n    super.hide();\n  }\n\n  onConfirm(): void {\n    if (this.nzBeforeConfirm) {\n      const observable = wrapIntoObservable(this.nzBeforeConfirm()).pipe(first());\n      this.confirmLoading = true;\n      observable\n        .pipe(\n          finalize(() => {\n            this.confirmLoading = false;\n            this.cdr.markForCheck();\n          }),\n          takeUntil(this.nzVisibleChange),\n          takeUntil(this.destroy$)\n        )\n        .subscribe(value => {\n          if (value) {\n            this.handleConfirm();\n          }\n        });\n    } else {\n      this.handleConfirm();\n    }\n  }\n\n  private capturePreviouslyFocusedElement(): void {\n    if (this.document) {\n      this.elementFocusedBeforeModalWasOpened = this.document.activeElement as HTMLElement;\n    }\n  }\n\n  private restoreFocus(): void {\n    const toFocus = this.elementFocusedBeforeModalWasOpened as HTMLElement;\n\n    // We need the extra check, because IE can set the `activeElement` to null in some cases.\n    if (toFocus && typeof toFocus.focus === 'function') {\n      const activeElement = this.document.activeElement as Element;\n      const element = this.elementRef.nativeElement;\n\n      if (\n        !activeElement ||\n        activeElement === this.document.body ||\n        activeElement === element ||\n        element.contains(activeElement)\n      ) {\n        toFocus.focus();\n      }\n    }\n  }\n}\n"]}