@po-ui/ng-components 17.26.26 → 17.26.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/po-modal/po-modal.component.mjs +5 -2
- package/esm2022/lib/components/po-page/po-page-slide/po-page-slide.component.mjs +5 -2
- package/esm2022/lib/components/po-table/po-table-column-frozen/po-table-column-frozen.directive.mjs +3 -1
- package/esm2022/lib/components/po-table/po-table.component.mjs +13 -11
- package/esm2022/lib/services/services.module.mjs +5 -12
- package/fesm2022/po-ui-ng-components.mjs +44 -40
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/services/services.module.d.ts +9 -10
- package/package.json +4 -4
- package/po-ui-ng-components-17.26.28.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v17/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-17.26.26.tgz +0 -0
|
@@ -124,7 +124,10 @@ export class PoModalComponent extends PoModalBaseComponent {
|
|
|
124
124
|
this.poActiveOverlayService = poActiveOverlayService;
|
|
125
125
|
}
|
|
126
126
|
close(xClosed = false) {
|
|
127
|
-
this.poActiveOverlayService.activeOverlay.
|
|
127
|
+
if (this.poActiveOverlayService.activeOverlay.length > 0 &&
|
|
128
|
+
this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id) {
|
|
129
|
+
this.poActiveOverlayService.activeOverlay.pop();
|
|
130
|
+
}
|
|
128
131
|
super.close(xClosed);
|
|
129
132
|
this.removeEventListeners();
|
|
130
133
|
if (this.sourceElement) {
|
|
@@ -219,4 +222,4 @@ export class PoModalComponent extends PoModalBaseComponent {
|
|
|
219
222
|
args: [PoModalFooterComponent]
|
|
220
223
|
}] }); })();
|
|
221
224
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoModalComponent, { className: "PoModalComponent", filePath: "lib/components/po-modal/po-modal.component.ts", lineNumber: 35 }); })();
|
|
222
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-modal/po-modal.component.ts","../../../../../../projects/ui/src/lib/components/po-modal/po-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AACrF,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;;;;ICG5B,8BAAgD;;;IAA1B,oCAAe;;;;IAKvC,qCAMC;IAFC,kLAAW,eAAA,aAAM,IAAI,CAAC,CAAA,IAAC;IAGzB,iBAAY;;;IALV,oDAA+B;;;IAYnC,6BAAmE;IACjE,qBAAkD;IACpD,0BAAe;;;;IAKT,qCAQC;IADC,kMAAW,eAAA,gCAAwB,CAAA,IAAC;IAEtC,iBAAY;;;IAPV,mEAA6C,gDAAA,0CAAA,8CAAA;;;;IAJnD,uCAAiB,cAAA;IAEb,mGASY;IAEZ,qCAQC;IADC,sLAAW,eAAA,8BAAsB,CAAA,IAAC;IAEpC,iBAAY,EAAA,EAAA;;;IAnBT,eAAqB;IAArB,6CAAqB;IAYtB,cAAiC;IAAjC,sDAAiC,6CAAA,uCAAA,2CAAA;;;;IA9CjD,iCAAmH;IAA9C,8KAAe,eAAA,qCAA6B,CAAA,IAAC;IAChH,8BAA+D;IAAjC,0KAAa,eAAA,0BAAkB,CAAA,IAAC;IAAC,iBAAM;IACrE,8BAAgD,aAAA,gBAAA,aAAA,aAAA;IAKtC,gFAAgD;IAChD,gCAA8B;IAC5B,aACF;IAAA,iBAAM,EAAA;IAER,sFAOY;IACd,iBAAM;IAEN,gCAA2B;IACzB,mBAAyB;IAC3B,iBAAM;IAEN,4FAEe,8GAAA;IA6BjB,iBAAM,EAAA,EAAA,EAAA;;;;IArDa,eAA4C;IAA5C,wEAA4C;IAG/C,eAAU;IAAV,kCAAU;IAElB,eACF;IADE,6CACF;IAGC,cAAgB;IAAhB,wCAAgB;IAaN,eAAmB;IAAnB,yCAAmB,iBAAA;;;;ADjB1C;;;;;;;;;;;;;;;;;;;GAmBG;AAMH,MAAM,OAAO,gBAAiB,SAAQ,oBAAoB;IAY9C;IAXuC,YAAY,CAAa;IACvB,cAAc,CAAa;IACxC,WAAW,CAAyB;IAElE,YAAY,CAAC;IACb,aAAa,CAAC;IACd,iBAAiB,GAAG,oDAAoD,CAAC;IACzE,EAAE,GAAW,IAAI,EAAE,CAAC;IACpB,aAAa,CAAC;IAEtB,YACU,sBAA8C,EACtD,iBAAoC;QAEpC,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAHjB,2BAAsB,GAAtB,sBAAsB,CAAwB;IAIxD,CAAC;IAED,KAAK,CAAC,OAAO,GAAG,KAAK;QACnB,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC;QAEhD,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAErB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,qBAAqB,CAAC,KAAK;QACzB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAED,8BAA8B;QAC5B,OAAO,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;IAC9G,CAAC;IAED,UAAU,CAAC,KAAK;QACd,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAC5E,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAED,IAAI;QACF,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;QAC5C,KAAK,CAAC,IAAI,EAAE,CAAC;QACb,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAExD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;aAC9D;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,aAAa,GAAG,CAAC,KAAU,EAAE,EAAE;YAClC,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;YAErD,IACE,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC;gBACpC,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,EAC3G;gBACA,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC;QAEF,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;SAC3B;aAAM;YACL,MAAM,iBAAiB,GACrB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;YACjH,iBAAiB,CAAC,KAAK,EAAE,CAAC;SAC3B;IACH,CAAC;IAEO,oBAAoB;QAC1B,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;IAClE,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,YAAY;YACf,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;IAC7G,CAAC;0EAhGU,gBAAgB;6DAAhB,gBAAgB;wCAGb,sBAAsB;;;;;mCAFD,UAAU;mCACR,UAAU;;;;;;;YCpCjD,kEA4DM;;YA5DgB,oCAAe;;;iFDkCxB,gBAAgB;cAJ5B,SAAS;2BACE,UAAU;uFAI6B,YAAY;kBAA5D,SAAS;mBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;YACI,cAAc;kBAAhE,SAAS;mBAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;YACX,WAAW;kBAAhD,YAAY;mBAAC,sBAAsB;;kFAHzB,gBAAgB","sourcesContent":["import { Component, ContentChild, ElementRef, ViewChild } from '@angular/core';\n\nimport { PoModalBaseComponent } from './po-modal-base.component';\nimport { PoModalFooterComponent } from './po-modal-footer/po-modal-footer.component';\nimport { uuid } from '../../utils/util';\n\nimport { PoActiveOverlayService } from '../../services/po-active-overlay/po-active-overlay.service';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\n\n/**\n * @docsExtends PoModalBaseComponent\n *\n * @example\n *\n * <example name=\"po-modal-basic\" title=\"PO Modal Basic\">\n *  <file name=\"sample-po-modal-basic/sample-po-modal-basic.component.html\"> </file>\n *  <file name=\"sample-po-modal-basic/sample-po-modal-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-modal-labs\" title=\"PO Modal Labs\">\n *  <file name=\"sample-po-modal-labs/sample-po-modal-labs.component.html\"> </file>\n *  <file name=\"sample-po-modal-labs/sample-po-modal-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-modal-fruits-salad\" title=\"PO Modal - Fruits Salad\">\n *  <file name=\"sample-po-modal-fruits-salad/sample-po-modal-fruits-salad.component.html\"> </file>\n *  <file name=\"sample-po-modal-fruits-salad/sample-po-modal-fruits-salad.component.ts\"> </file>\n * </example>\n */\n\n@Component({\n  selector: 'po-modal',\n  templateUrl: './po-modal.component.html'\n})\nexport class PoModalComponent extends PoModalBaseComponent {\n  @ViewChild('modalContent', { read: ElementRef }) modalContent: ElementRef;\n  @ViewChild('modalContainer', { read: ElementRef }) modalContainer: ElementRef;\n  @ContentChild(PoModalFooterComponent) modalFooter: PoModalFooterComponent;\n\n  private firstElement;\n  private focusFunction;\n  private focusableElements = 'input, select, textarea, button:not([disabled]), a';\n  private id: string = uuid();\n  private sourceElement;\n\n  constructor(\n    private poActiveOverlayService: PoActiveOverlayService,\n    poLanguageService: PoLanguageService\n  ) {\n    super(poLanguageService);\n  }\n\n  close(xClosed = false) {\n    this.poActiveOverlayService.activeOverlay.pop();\n\n    super.close(xClosed);\n\n    this.removeEventListeners();\n\n    if (this.sourceElement) {\n      this.sourceElement.focus();\n    }\n  }\n\n  closeModalOnEscapeKey(event) {\n    if (!this.hideClose) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.close();\n    }\n  }\n\n  getSecondaryActionButtonDanger() {\n    return this.secondaryAction && this.secondaryAction.danger && !this.primaryAction.danger ? 'true' : 'false';\n  }\n\n  onClickOut(event) {\n    if (this.clickOut && !this.modalContent.nativeElement.contains(event.target)) {\n      this.close();\n    }\n  }\n\n  open() {\n    this.sourceElement = document.activeElement;\n    super.open();\n    this.handleFocus();\n  }\n\n  private handleFocus(): any {\n    this.poActiveOverlayService.activeOverlay.push(this.id);\n\n    setTimeout(() => {\n      if (this.modalContent) {\n        this.initFocus();\n        document.addEventListener('focus', this.focusFunction, true);\n      }\n    });\n  }\n\n  private initFocus() {\n    this.focusFunction = (event: any) => {\n      const modalElement = this.modalContent.nativeElement;\n\n      if (\n        !modalElement.contains(event.target) &&\n        this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n      ) {\n        event.stopPropagation();\n        this.firstElement.focus();\n      }\n    };\n\n    this.setFirstElement();\n\n    if (this.hideClose) {\n      this.firstElement.focus();\n    } else {\n      const firstFieldElement =\n        this.modalContent.nativeElement.querySelectorAll(this.focusableElements)[1] || this.modalContent.nativeElement;\n      firstFieldElement.focus();\n    }\n  }\n\n  private removeEventListeners() {\n    document.removeEventListener('focus', this.focusFunction, true);\n  }\n\n  private setFirstElement() {\n    this.firstElement =\n      this.modalContent.nativeElement.querySelector(this.focusableElements) || this.modalContent.nativeElement;\n  }\n}\n","<div #modalContainer *ngIf=\"!isHidden\" class=\"po-modal\" tabindex=\"0\" (keydown.esc)=\"closeModalOnEscapeKey($event)\">\n  <div class=\"po-modal-overlay\" (mousedown)=\"onClickOut($event)\"></div>\n  <div class=\"po-modal-container po-pb-2 po-pt-2\">\n    <div class=\"po-modal-vertical-align\">\n      <div #modalContent class=\"po-modal-content po-modal-{{ size }}\" tabindex=\"-1\">\n        <div class=\"po-modal-header\">\n          <div class=\"po-modal-title po-text-ellipsis\">\n            <po-icon *ngIf=\"icon\" [p-icon]=\"icon\"></po-icon>\n            <div class=\"po-text-ellipsis\">\n              {{ title }}\n            </div>\n          </div>\n          <po-button\n            *ngIf=\"!hideClose\"\n            [p-aria-label]=\"literals.close\"\n            p-icon=\"ICON_CLOSE\"\n            (p-click)=\"close(true)\"\n            p-kind=\"tertiary\"\n          >\n          </po-button>\n        </div>\n\n        <div class=\"po-modal-body\">\n          <ng-content></ng-content>\n        </div>\n\n        <ng-container *ngIf=\"modalFooter; else defaultModalFooterTemplate\">\n          <ng-content select=\"po-modal-footer\"></ng-content>\n        </ng-container>\n\n        <ng-template #defaultModalFooterTemplate>\n          <po-modal-footer>\n            <div class=\"po-modal-footer-basic\">\n              <po-button\n                *ngIf=\"secondaryAction\"\n                [p-danger]=\"getSecondaryActionButtonDanger()\"\n                [p-disabled]=\"secondaryAction.disabled\"\n                [p-label]=\"secondaryAction.label\"\n                [p-loading]=\"secondaryAction.loading\"\n                p-kind=\"secondary\"\n                (p-click)=\"secondaryAction.action()\"\n              >\n              </po-button>\n\n              <po-button\n                class=\"po-button-modal-first-action\"\n                [p-danger]=\"primaryAction.danger\"\n                [p-disabled]=\"primaryAction.disabled\"\n                [p-label]=\"primaryAction.label\"\n                [p-loading]=\"primaryAction.loading\"\n                p-kind=\"primary\"\n                (p-click)=\"primaryAction.action()\"\n              >\n              </po-button>\n            </div>\n          </po-modal-footer>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-modal/po-modal.component.ts","../../../../../../projects/ui/src/lib/components/po-modal/po-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, ElementRef, ViewChild } from '@angular/core';\n\nimport { PoModalBaseComponent } from './po-modal-base.component';\nimport { PoModalFooterComponent } from './po-modal-footer/po-modal-footer.component';\nimport { uuid } from '../../utils/util';\n\nimport { PoActiveOverlayService } from '../../services/po-active-overlay/po-active-overlay.service';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\n\n/**\n * @docsExtends PoModalBaseComponent\n *\n * @example\n *\n * <example name=\"po-modal-basic\" title=\"PO Modal Basic\">\n *  <file name=\"sample-po-modal-basic/sample-po-modal-basic.component.html\"> </file>\n *  <file name=\"sample-po-modal-basic/sample-po-modal-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-modal-labs\" title=\"PO Modal Labs\">\n *  <file name=\"sample-po-modal-labs/sample-po-modal-labs.component.html\"> </file>\n *  <file name=\"sample-po-modal-labs/sample-po-modal-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-modal-fruits-salad\" title=\"PO Modal - Fruits Salad\">\n *  <file name=\"sample-po-modal-fruits-salad/sample-po-modal-fruits-salad.component.html\"> </file>\n *  <file name=\"sample-po-modal-fruits-salad/sample-po-modal-fruits-salad.component.ts\"> </file>\n * </example>\n */\n\n@Component({\n  selector: 'po-modal',\n  templateUrl: './po-modal.component.html'\n})\nexport class PoModalComponent extends PoModalBaseComponent {\n  @ViewChild('modalContent', { read: ElementRef }) modalContent: ElementRef;\n  @ViewChild('modalContainer', { read: ElementRef }) modalContainer: ElementRef;\n  @ContentChild(PoModalFooterComponent) modalFooter: PoModalFooterComponent;\n\n  private firstElement;\n  private focusFunction;\n  private focusableElements = 'input, select, textarea, button:not([disabled]), a';\n  private id: string = uuid();\n  private sourceElement;\n\n  constructor(\n    private poActiveOverlayService: PoActiveOverlayService,\n    poLanguageService: PoLanguageService\n  ) {\n    super(poLanguageService);\n  }\n\n  close(xClosed = false) {\n    if (\n      this.poActiveOverlayService.activeOverlay.length > 0 &&\n      this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n    ) {\n      this.poActiveOverlayService.activeOverlay.pop();\n    }\n\n    super.close(xClosed);\n\n    this.removeEventListeners();\n\n    if (this.sourceElement) {\n      this.sourceElement.focus();\n    }\n  }\n\n  closeModalOnEscapeKey(event) {\n    if (!this.hideClose) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.close();\n    }\n  }\n\n  getSecondaryActionButtonDanger() {\n    return this.secondaryAction && this.secondaryAction.danger && !this.primaryAction.danger ? 'true' : 'false';\n  }\n\n  onClickOut(event) {\n    if (this.clickOut && !this.modalContent.nativeElement.contains(event.target)) {\n      this.close();\n    }\n  }\n\n  open() {\n    this.sourceElement = document.activeElement;\n    super.open();\n    this.handleFocus();\n  }\n\n  private handleFocus(): any {\n    this.poActiveOverlayService.activeOverlay.push(this.id);\n\n    setTimeout(() => {\n      if (this.modalContent) {\n        this.initFocus();\n        document.addEventListener('focus', this.focusFunction, true);\n      }\n    });\n  }\n\n  private initFocus() {\n    this.focusFunction = (event: any) => {\n      const modalElement = this.modalContent.nativeElement;\n\n      if (\n        !modalElement.contains(event.target) &&\n        this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n      ) {\n        event.stopPropagation();\n        this.firstElement.focus();\n      }\n    };\n\n    this.setFirstElement();\n\n    if (this.hideClose) {\n      this.firstElement.focus();\n    } else {\n      const firstFieldElement =\n        this.modalContent.nativeElement.querySelectorAll(this.focusableElements)[1] || this.modalContent.nativeElement;\n      firstFieldElement.focus();\n    }\n  }\n\n  private removeEventListeners() {\n    document.removeEventListener('focus', this.focusFunction, true);\n  }\n\n  private setFirstElement() {\n    this.firstElement =\n      this.modalContent.nativeElement.querySelector(this.focusableElements) || this.modalContent.nativeElement;\n  }\n}\n","<div #modalContainer *ngIf=\"!isHidden\" class=\"po-modal\" tabindex=\"0\" (keydown.esc)=\"closeModalOnEscapeKey($event)\">\n  <div class=\"po-modal-overlay\" (mousedown)=\"onClickOut($event)\"></div>\n  <div class=\"po-modal-container po-pb-2 po-pt-2\">\n    <div class=\"po-modal-vertical-align\">\n      <div #modalContent class=\"po-modal-content po-modal-{{ size }}\" tabindex=\"-1\">\n        <div class=\"po-modal-header\">\n          <div class=\"po-modal-title po-text-ellipsis\">\n            <po-icon *ngIf=\"icon\" [p-icon]=\"icon\"></po-icon>\n            <div class=\"po-text-ellipsis\">\n              {{ title }}\n            </div>\n          </div>\n          <po-button\n            *ngIf=\"!hideClose\"\n            [p-aria-label]=\"literals.close\"\n            p-icon=\"ICON_CLOSE\"\n            (p-click)=\"close(true)\"\n            p-kind=\"tertiary\"\n          >\n          </po-button>\n        </div>\n\n        <div class=\"po-modal-body\">\n          <ng-content></ng-content>\n        </div>\n\n        <ng-container *ngIf=\"modalFooter; else defaultModalFooterTemplate\">\n          <ng-content select=\"po-modal-footer\"></ng-content>\n        </ng-container>\n\n        <ng-template #defaultModalFooterTemplate>\n          <po-modal-footer>\n            <div class=\"po-modal-footer-basic\">\n              <po-button\n                *ngIf=\"secondaryAction\"\n                [p-danger]=\"getSecondaryActionButtonDanger()\"\n                [p-disabled]=\"secondaryAction.disabled\"\n                [p-label]=\"secondaryAction.label\"\n                [p-loading]=\"secondaryAction.loading\"\n                p-kind=\"secondary\"\n                (p-click)=\"secondaryAction.action()\"\n              >\n              </po-button>\n\n              <po-button\n                class=\"po-button-modal-first-action\"\n                [p-danger]=\"primaryAction.danger\"\n                [p-disabled]=\"primaryAction.disabled\"\n                [p-label]=\"primaryAction.label\"\n                [p-loading]=\"primaryAction.loading\"\n                p-kind=\"primary\"\n                (p-click)=\"primaryAction.action()\"\n              >\n              </po-button>\n            </div>\n          </po-modal-footer>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -101,7 +101,10 @@ export class PoPageSlideComponent extends PoPageSlideBaseComponent {
|
|
|
101
101
|
this.loadingCompleted.pipe(take(1)).pipe(delay(0)).subscribe(this.handleFocus.bind(this));
|
|
102
102
|
}
|
|
103
103
|
close() {
|
|
104
|
-
this.poActiveOverlayService.activeOverlay.
|
|
104
|
+
if (this.poActiveOverlayService.activeOverlay.length > 0 &&
|
|
105
|
+
this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id) {
|
|
106
|
+
this.poActiveOverlayService.activeOverlay.pop();
|
|
107
|
+
}
|
|
105
108
|
super.close();
|
|
106
109
|
this.removeEventListeners();
|
|
107
110
|
this.sourceElement.focus();
|
|
@@ -193,4 +196,4 @@ export class PoPageSlideComponent extends PoPageSlideBaseComponent {
|
|
|
193
196
|
args: ['pageContent', { read: ElementRef }]
|
|
194
197
|
}] }); })();
|
|
195
198
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoPageSlideComponent, { className: "PoPageSlideComponent", filePath: "lib/components/po-page/po-page-slide/po-page-slide.component.ts", lineNumber: 52 }); })();
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-slide.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.ts","../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACtG,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,oBAAoB,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAGjE,OAAO,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;;;;;;;ICGhE,+BAAqD;IAAA,YAAc;IAAA,iBAAM;;;IAApB,cAAc;IAAd,qCAAc;;;;IAErE,qCAAwF;IAApB,sLAAW,eAAA,cAAO,CAAA,IAAC;IAAE,iBAAY;;;;;IAb7G,8BAAgE,aAAA;IAC3B,4KAAa,eAAA,yBAAkB,CAAA,IAAC;IAAC,iBAAM;IAC1E,8BAIC,gBAAA,aAAA,aAAA,WAAA;IAIa,YAAW;IAAA,iBAAO;IACxB,2EAAyE;IAC3E,iBAAM;IACN,yFAAqG;IACvG,iBAAM;IACN,gCAAgC;IAC9B,mBAAyB;IAC3B,iBAAM,EAAA,EAAA,EAAA;;;IAjB4C,iCAAO;IAG3D,eAA4E;IAA5E,wGAA4E;IAC5E,kCAAQ,yGAAA;IAMI,eAAW;IAAX,kCAAW;IACoB,cAAc;IAAd,sCAAc;IAEzC,cAAgB;IAAhB,wCAAgB;;;ADHpC;;;;;;;;;;;;;;;;;;;GAmBG;AAsBH,MAAM,OAAO,oBAAqB,SAAQ,wBAAwB;IAqB5C;IApBZ,YAAY,CAAa;IAEzB,YAAY,CAAM;IAClB,EAAE,GAAW,IAAI,EAAE,CAAC;IACpB,gBAAgB,GAAG,IAAI,aAAa,EAAQ,CAAC;IAC7C,aAAa,CAAM;IAEnB,UAAU,CAAgB;IAElC,IAAoD,WAAW,CAAC,WAAuB;QACrF,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;SAC9B;IACH,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,YAAoB,sBAA8C;QAChE,KAAK,EAAE,CAAC;QADU,2BAAsB,GAAtB,sBAAsB,CAAwB;IAElE,CAAC;IAEM,IAAI;QACT,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;QAC5C,KAAK,CAAC,IAAI,EAAE,CAAC;QACb,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5F,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC;QAChD,KAAK,CAAC,KAAK,EAAE,CAAC;QAEd,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC7B,CAAC;IAEM,UAAU,CAAC,KAAiB;QACjC,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAC3E,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjB,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAEO,SAAS;QACf,kCAAkC;QAClC,IAAI,CAAC,UAAU,GAAG,CAAC,KAAY,EAAE,EAAE;YACjC,IACE,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC;gBACtD,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,EAC3G;gBACA,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;SAC3B;aAAM;YACL,MAAM,QAAQ,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;YACtE,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;YAC9D,OAAO,CAAC,KAAK,EAAE,CAAC;SACjB;IACH,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,YAAY,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;IAChH,CAAC;IAEO,oBAAoB;QAC1B,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QAC7D,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;8EAjFU,oBAAoB;6DAApB,oBAAoB;mCAUG,UAAU;;;;8CA5BjC,EAAE;;YCjCf,uEAoBM;;YApBmC,kCAAa;6GDkCxC;gBACV,OAAO,CAAC,MAAM,EAAE;oBACd,UAAU,CAAC,QAAQ,EAAE;wBACnB,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;wBACrB,KAAK,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;qBAClF,CAAC;oBACF,UAAU,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBACxG,CAAC;gBACF,OAAO,CAAC,OAAO,EAAE;oBACf,UAAU,CAAC,QAAQ,EAAE;wBACnB,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC;wBACxC,OAAO,CAAC,mBAAmB,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;qBAC3D,CAAC;oBACF,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAC,CAAC;iBACnF,CAAC;aACH;;iFAEU,oBAAoB;cArBhC,SAAS;2BACE,eAAe,aAEd,EAAE,cACD;oBACV,OAAO,CAAC,MAAM,EAAE;wBACd,UAAU,CAAC,QAAQ,EAAE;4BACnB,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;4BACrB,KAAK,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;yBAClF,CAAC;wBACF,UAAU,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;qBACxG,CAAC;oBACF,OAAO,CAAC,OAAO,EAAE;wBACf,UAAU,CAAC,QAAQ,EAAE;4BACnB,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC;4BACxC,OAAO,CAAC,mBAAmB,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;yBAC3D,CAAC;wBACF,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAC,CAAC;qBACnF,CAAC;iBACH;uDAYmD,WAAW;kBAA9D,SAAS;mBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;;kFAVnC,oBAAoB","sourcesContent":["import { animate, animateChild, group, query, style, transition, trigger } from '@angular/animations';\nimport { Component, ElementRef, ViewChild } from '@angular/core';\nimport { ReplaySubject } from 'rxjs';\nimport { delay, take } from 'rxjs/operators';\n\nimport { getFocusableElements, uuid } from '../../../utils/util';\n\nimport { PoActiveOverlayService } from '../../../services/po-active-overlay/po-active-overlay.service';\nimport { PoPageSlideBaseComponent } from './po-page-slide-base.component';\n\n/**\n * @docsExtends PoPageSlideBaseComponent\n *\n * @example\n *\n * <example name=\"po-page-slide-basic\" title=\"PO Page Slide Basic\">\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-labs\" title=\"PO Page Slide Labs\">\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-configuration\" title=\"PO Page Slide - Configuration\">\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-slide',\n  templateUrl: './po-page-slide.component.html',\n  providers: [],\n  animations: [\n    trigger('fade', [\n      transition(':enter', [\n        style({ opacity: 0 }),\n        group([animate('150ms', style({ opacity: 1 })), query('@slide', animateChild())])\n      ]),\n      transition(':leave', group([query('@slide', animateChild()), animate('150ms', style({ opacity: 0 }))]))\n    ]),\n    trigger('slide', [\n      transition(':enter', [\n        style({ transform: 'translateX(50px)' }),\n        animate('691ms ease-in-out', style({ transform: 'none' }))\n      ]),\n      transition(':leave', [animate('150ms', style({ transform: 'translateX(50px)' }))])\n    ])\n  ]\n})\nexport class PoPageSlideComponent extends PoPageSlideBaseComponent {\n  private _pageContent: ElementRef;\n\n  private firstElement: any;\n  private id: string = uuid();\n  private loadingCompleted = new ReplaySubject<void>();\n  private sourceElement: any;\n\n  private focusEvent: EventListener;\n\n  @ViewChild('pageContent', { read: ElementRef }) set pageContent(pageContent: ElementRef) {\n    if (pageContent) {\n      this._pageContent = pageContent;\n      this.loadingCompleted.next();\n    }\n  }\n\n  get pageContent(): ElementRef {\n    return this._pageContent;\n  }\n\n  constructor(private poActiveOverlayService: PoActiveOverlayService) {\n    super();\n  }\n\n  public open(): void {\n    this.sourceElement = document.activeElement;\n    super.open();\n    this.loadingCompleted.pipe(take(1)).pipe(delay(0)).subscribe(this.handleFocus.bind(this));\n  }\n\n  public close(): void {\n    this.poActiveOverlayService.activeOverlay.pop();\n    super.close();\n\n    this.removeEventListeners();\n    this.sourceElement.focus();\n  }\n\n  public onClickOut(event: MouseEvent): void {\n    if (this.clickOut && !this.pageContent.nativeElement.contains(event.target)) {\n      this.close();\n    }\n  }\n\n  private handleFocus(): void {\n    this.poActiveOverlayService.activeOverlay.push(this.id);\n    this.loadFirstElement();\n    this.initFocus();\n\n    document.addEventListener('focus', this.focusEvent, true);\n  }\n\n  private initFocus() {\n    // O foco não pode sair da página.\n    this.focusEvent = (event: Event) => {\n      if (\n        !this.pageContent.nativeElement.contains(event.target) &&\n        this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n      ) {\n        event.stopPropagation();\n        this.firstElement.focus();\n      }\n    };\n\n    if (this.hideClose) {\n      this.firstElement.focus();\n    } else {\n      const elements = getFocusableElements(this.pageContent.nativeElement);\n      const element = elements[0] || this.pageContent.nativeElement;\n      element.focus();\n    }\n  }\n\n  private loadFirstElement(): void {\n    this.firstElement = getFocusableElements(this.pageContent.nativeElement)[0] || this.pageContent.nativeElement;\n  }\n\n  private removeEventListeners(): void {\n    document.removeEventListener('focus', this.focusEvent, true);\n    this.loadingCompleted.complete();\n  }\n}\n","<div class=\"po-page-slide\" tabindex=\"0\" *ngIf=\"!hidden\" [@fade]>\n  <div class=\"po-page-slide-overlay\" (mousedown)=\"onClickOut($event)\"></div>\n  <div\n    class=\"po-page-slide-container po-page-slide-right po-page-slide-{{ size }}\"\n    [@slide]\n    [ngStyle]=\"{ 'width': flexibleWidth ? '' : size === 'auto' ? 'auto' : '' }\"\n  >\n    <div class=\"po-page-slide-content\" tabindex=\"-1\" #pageContent>\n      <div class=\"po-page-slide-header\">\n        <div class=\"po-page-slide-title\">\n          <span>{{ title }}</span>\n          <div class=\"po-page-slide-subtitle\" *ngIf=\"subtitle\">{{ subtitle }}</div>\n        </div>\n        <po-button *ngIf=\"!hideClose\" p-icon=\"ICON_CLOSE\" p-kind=\"tertiary\" (p-click)=\"close()\"> </po-button>\n      </div>\n      <div class=\"po-page-slide-body\">\n        <ng-content></ng-content>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-slide.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.ts","../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, animateChild, group, query, style, transition, trigger } from '@angular/animations';\nimport { Component, ElementRef, ViewChild } from '@angular/core';\nimport { ReplaySubject } from 'rxjs';\nimport { delay, take } from 'rxjs/operators';\n\nimport { getFocusableElements, uuid } from '../../../utils/util';\n\nimport { PoActiveOverlayService } from '../../../services/po-active-overlay/po-active-overlay.service';\nimport { PoPageSlideBaseComponent } from './po-page-slide-base.component';\n\n/**\n * @docsExtends PoPageSlideBaseComponent\n *\n * @example\n *\n * <example name=\"po-page-slide-basic\" title=\"PO Page Slide Basic\">\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-labs\" title=\"PO Page Slide Labs\">\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-configuration\" title=\"PO Page Slide - Configuration\">\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-slide',\n  templateUrl: './po-page-slide.component.html',\n  providers: [],\n  animations: [\n    trigger('fade', [\n      transition(':enter', [\n        style({ opacity: 0 }),\n        group([animate('150ms', style({ opacity: 1 })), query('@slide', animateChild())])\n      ]),\n      transition(':leave', group([query('@slide', animateChild()), animate('150ms', style({ opacity: 0 }))]))\n    ]),\n    trigger('slide', [\n      transition(':enter', [\n        style({ transform: 'translateX(50px)' }),\n        animate('691ms ease-in-out', style({ transform: 'none' }))\n      ]),\n      transition(':leave', [animate('150ms', style({ transform: 'translateX(50px)' }))])\n    ])\n  ]\n})\nexport class PoPageSlideComponent extends PoPageSlideBaseComponent {\n  private _pageContent: ElementRef;\n\n  private firstElement: any;\n  private id: string = uuid();\n  private loadingCompleted = new ReplaySubject<void>();\n  private sourceElement: any;\n\n  private focusEvent: EventListener;\n\n  @ViewChild('pageContent', { read: ElementRef }) set pageContent(pageContent: ElementRef) {\n    if (pageContent) {\n      this._pageContent = pageContent;\n      this.loadingCompleted.next();\n    }\n  }\n\n  get pageContent(): ElementRef {\n    return this._pageContent;\n  }\n\n  constructor(private poActiveOverlayService: PoActiveOverlayService) {\n    super();\n  }\n\n  public open(): void {\n    this.sourceElement = document.activeElement;\n    super.open();\n    this.loadingCompleted.pipe(take(1)).pipe(delay(0)).subscribe(this.handleFocus.bind(this));\n  }\n\n  public close(): void {\n    if (\n      this.poActiveOverlayService.activeOverlay.length > 0 &&\n      this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n    ) {\n      this.poActiveOverlayService.activeOverlay.pop();\n    }\n\n    super.close();\n\n    this.removeEventListeners();\n    this.sourceElement.focus();\n  }\n\n  public onClickOut(event: MouseEvent): void {\n    if (this.clickOut && !this.pageContent.nativeElement.contains(event.target)) {\n      this.close();\n    }\n  }\n\n  private handleFocus(): void {\n    this.poActiveOverlayService.activeOverlay.push(this.id);\n    this.loadFirstElement();\n    this.initFocus();\n\n    document.addEventListener('focus', this.focusEvent, true);\n  }\n\n  private initFocus() {\n    // O foco não pode sair da página.\n    this.focusEvent = (event: Event) => {\n      if (\n        !this.pageContent.nativeElement.contains(event.target) &&\n        this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n      ) {\n        event.stopPropagation();\n        this.firstElement.focus();\n      }\n    };\n\n    if (this.hideClose) {\n      this.firstElement.focus();\n    } else {\n      const elements = getFocusableElements(this.pageContent.nativeElement);\n      const element = elements[0] || this.pageContent.nativeElement;\n      element.focus();\n    }\n  }\n\n  private loadFirstElement(): void {\n    this.firstElement = getFocusableElements(this.pageContent.nativeElement)[0] || this.pageContent.nativeElement;\n  }\n\n  private removeEventListeners(): void {\n    document.removeEventListener('focus', this.focusEvent, true);\n    this.loadingCompleted.complete();\n  }\n}\n","<div class=\"po-page-slide\" tabindex=\"0\" *ngIf=\"!hidden\" [@fade]>\n  <div class=\"po-page-slide-overlay\" (mousedown)=\"onClickOut($event)\"></div>\n  <div\n    class=\"po-page-slide-container po-page-slide-right po-page-slide-{{ size }}\"\n    [@slide]\n    [ngStyle]=\"{ 'width': flexibleWidth ? '' : size === 'auto' ? 'auto' : '' }\"\n  >\n    <div class=\"po-page-slide-content\" tabindex=\"-1\" #pageContent>\n      <div class=\"po-page-slide-header\">\n        <div class=\"po-page-slide-title\">\n          <span>{{ title }}</span>\n          <div class=\"po-page-slide-subtitle\" *ngIf=\"subtitle\">{{ subtitle }}</div>\n        </div>\n        <po-button *ngIf=\"!hideClose\" p-icon=\"ICON_CLOSE\" p-kind=\"tertiary\" (p-click)=\"close()\"> </po-button>\n      </div>\n      <div class=\"po-page-slide-body\">\n        <ng-content></ng-content>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
package/esm2022/lib/components/po-table/po-table-column-frozen/po-table-column-frozen.directive.mjs
CHANGED
|
@@ -50,6 +50,8 @@ export class PoTableColumnFrozenDirective {
|
|
|
50
50
|
if (prev &&
|
|
51
51
|
!prev.classList.contains('po-table-column-selectable') &&
|
|
52
52
|
!prev.classList.contains('po-table-column-actions') &&
|
|
53
|
+
!prev.classList.contains('po-table-header-single-action') &&
|
|
54
|
+
!prev.classList.contains('po-table-column-single-action') &&
|
|
53
55
|
!prev.classList.contains('po-table-column-detail-toggle') &&
|
|
54
56
|
!prev.classList.contains('po-table-header-master-detail')) {
|
|
55
57
|
left = this.getOuterWidth(prev) + (parseFloat(prev.style.left) || 0);
|
|
@@ -129,4 +131,4 @@ export class PoTableColumnFrozenDirective {
|
|
|
129
131
|
}], alignFrozen: [{
|
|
130
132
|
type: Input
|
|
131
133
|
}] }); })();
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-table-column-frozen.directive.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-table/po-table-column-frozen/po-table-column-frozen.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, Input, Renderer2, OnChanges, SimpleChanges } from '@angular/core';\n\n@Directive({\n  selector: '[pFrozenColumn]',\n  host: {\n    class: 'p-element',\n    '[class.po-frozen-column]': 'frozen'\n  }\n})\nexport class PoTableColumnFrozenDirective implements AfterViewInit, OnChanges {\n  _frozen: boolean = true;\n\n  get frozen(): boolean {\n    return this._frozen;\n  }\n\n  @Input('pFrozenColumn') set frozen(val: boolean) {\n    this._frozen = val;\n\n    if (!val) {\n      this.renderer.removeClass(this.el.nativeElement, 'po-table-column-fixed');\n    } else {\n      this.updateStickyPosition();\n    }\n  }\n\n  @Input() alignFrozen: string = 'left';\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2\n  ) {}\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      this.updateStickyPosition();\n    }, 300);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.frozen.previousValue && !changes.frozen.currentValue) {\n      setTimeout(() => {\n        this.resizeColumns();\n      }, 100);\n    }\n  }\n\n  /* istanbul ignore next */\n  updateStickyPosition() {\n    if (this._frozen) {\n      if (this.alignFrozen === 'right') {\n        let right = 0;\n        const next = this.el.nativeElement.nextElementSibling;\n\n        if (next) {\n          right = this.getOuterWidth(next) + (parseFloat(next.style.right) || 0);\n        }\n        this.el.nativeElement.style.right = right + 'px';\n      } else {\n        let left = 0;\n        const prev = this.el.nativeElement.previousElementSibling;\n        if (\n          prev &&\n          !prev.classList.contains('po-table-column-selectable') &&\n          !prev.classList.contains('po-table-column-actions') &&\n          !prev.classList.contains('po-table-column-detail-toggle') &&\n          !prev.classList.contains('po-table-header-master-detail')\n        ) {\n          left = this.getOuterWidth(prev) + (parseFloat(prev.style.left) || 0);\n        }\n        this.el.nativeElement.style.left = left - 1 + 'px';\n        this.renderer.addClass(this.el.nativeElement, 'po-table-column-fixed');\n      }\n\n      const filterRow = this.el.nativeElement.parentElement.nextElementSibling;\n\n      if (filterRow) {\n        const index = this.index(this.el.nativeElement);\n        if (filterRow.children && filterRow.children[index]) {\n          filterRow.children[index].style.left = this.el.nativeElement.style.left;\n          filterRow.children[index].style.right = this.el.nativeElement.style.right;\n        }\n      }\n    }\n  }\n\n  /* istanbul ignore next */\n  resizeColumns() {\n    const currentElement = this.el.nativeElement;\n    const prevElements = [];\n    let prevElement = currentElement.previousElementSibling;\n\n    // Encontra todos os elementos anteriores com a classe 'po-table-column-fixed'\n    while (prevElement && prevElement.classList.contains('po-table-column-fixed')) {\n      prevElements.push(prevElement);\n      prevElement = prevElement.previousElementSibling;\n    }\n\n    // Verifica se há elementos suficientes para ajustar os widths\n    if (prevElements.length >= 2) {\n      let leftAccumulator = 0;\n\n      // Calcula o novo 'left' para cada elemento anterior e aplica\n      for (let i = prevElements.length - 1; i >= 0; i--) {\n        const prevWidth = this.getOuterWidth(prevElements[i], true);\n        prevElements[i].style.left = leftAccumulator - 1 + 'px';\n        leftAccumulator += prevWidth;\n      }\n    }\n  }\n\n  getOuterWidth(el, margin?) {\n    let width = el.offsetWidth;\n\n    if (margin) {\n      const style = getComputedStyle(el);\n      width += parseFloat(style.marginLeft) + parseFloat(style.marginRight);\n    }\n\n    return width - 1;\n  }\n\n  index(element: any): number {\n    const children = element.parentNode.childNodes;\n    let num = 0;\n    for (let i = 0; i < children.length; i++) {\n      if (children[i] === element) {\n        return num;\n      }\n      if (children[i].nodeType === 1) {\n        num++;\n      }\n    }\n    return -1;\n  }\n}\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-table-column-frozen.directive.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-table/po-table-column-frozen/po-table-column-frozen.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, Input, Renderer2, OnChanges, SimpleChanges } from '@angular/core';\n\n@Directive({\n  selector: '[pFrozenColumn]',\n  host: {\n    class: 'p-element',\n    '[class.po-frozen-column]': 'frozen'\n  }\n})\nexport class PoTableColumnFrozenDirective implements AfterViewInit, OnChanges {\n  _frozen: boolean = true;\n\n  get frozen(): boolean {\n    return this._frozen;\n  }\n\n  @Input('pFrozenColumn') set frozen(val: boolean) {\n    this._frozen = val;\n\n    if (!val) {\n      this.renderer.removeClass(this.el.nativeElement, 'po-table-column-fixed');\n    } else {\n      this.updateStickyPosition();\n    }\n  }\n\n  @Input() alignFrozen: string = 'left';\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2\n  ) {}\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      this.updateStickyPosition();\n    }, 300);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.frozen.previousValue && !changes.frozen.currentValue) {\n      setTimeout(() => {\n        this.resizeColumns();\n      }, 100);\n    }\n  }\n\n  /* istanbul ignore next */\n  updateStickyPosition() {\n    if (this._frozen) {\n      if (this.alignFrozen === 'right') {\n        let right = 0;\n        const next = this.el.nativeElement.nextElementSibling;\n\n        if (next) {\n          right = this.getOuterWidth(next) + (parseFloat(next.style.right) || 0);\n        }\n        this.el.nativeElement.style.right = right + 'px';\n      } else {\n        let left = 0;\n        const prev = this.el.nativeElement.previousElementSibling;\n        if (\n          prev &&\n          !prev.classList.contains('po-table-column-selectable') &&\n          !prev.classList.contains('po-table-column-actions') &&\n          !prev.classList.contains('po-table-header-single-action') &&\n          !prev.classList.contains('po-table-column-single-action') &&\n          !prev.classList.contains('po-table-column-detail-toggle') &&\n          !prev.classList.contains('po-table-header-master-detail')\n        ) {\n          left = this.getOuterWidth(prev) + (parseFloat(prev.style.left) || 0);\n        }\n        this.el.nativeElement.style.left = left - 1 + 'px';\n        this.renderer.addClass(this.el.nativeElement, 'po-table-column-fixed');\n      }\n\n      const filterRow = this.el.nativeElement.parentElement.nextElementSibling;\n\n      if (filterRow) {\n        const index = this.index(this.el.nativeElement);\n        if (filterRow.children && filterRow.children[index]) {\n          filterRow.children[index].style.left = this.el.nativeElement.style.left;\n          filterRow.children[index].style.right = this.el.nativeElement.style.right;\n        }\n      }\n    }\n  }\n\n  /* istanbul ignore next */\n  resizeColumns() {\n    const currentElement = this.el.nativeElement;\n    const prevElements = [];\n    let prevElement = currentElement.previousElementSibling;\n\n    // Encontra todos os elementos anteriores com a classe 'po-table-column-fixed'\n    while (prevElement && prevElement.classList.contains('po-table-column-fixed')) {\n      prevElements.push(prevElement);\n      prevElement = prevElement.previousElementSibling;\n    }\n\n    // Verifica se há elementos suficientes para ajustar os widths\n    if (prevElements.length >= 2) {\n      let leftAccumulator = 0;\n\n      // Calcula o novo 'left' para cada elemento anterior e aplica\n      for (let i = prevElements.length - 1; i >= 0; i--) {\n        const prevWidth = this.getOuterWidth(prevElements[i], true);\n        prevElements[i].style.left = leftAccumulator - 1 + 'px';\n        leftAccumulator += prevWidth;\n      }\n    }\n  }\n\n  getOuterWidth(el, margin?) {\n    let width = el.offsetWidth;\n\n    if (margin) {\n      const style = getComputedStyle(el);\n      width += parseFloat(style.marginLeft) + parseFloat(style.marginRight);\n    }\n\n    return width - 1;\n  }\n\n  index(element: any): number {\n    const children = element.parentNode.childNodes;\n    let num = 0;\n    for (let i = 0; i < children.length; i++) {\n      if (children[i] === element) {\n        return num;\n      }\n      if (children[i].nodeType === 1) {\n        num++;\n      }\n    }\n    return -1;\n  }\n}\n"]}
|