@impartner/design-components 1.0.3 → 1.0.5
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/esm2020/lib/dropdown/dropdown.component.mjs +4 -2
- package/esm2020/lib/modal/modal.component.mjs +17 -9
- package/esm2020/lib/pagination/pagination.component.mjs +38 -28
- package/esm2020/lib/pagination/pagination.module.mjs +5 -4
- package/esm2020/services/interaction.service.mjs +22 -5
- package/fesm2015/impartner-design-components.mjs +77 -41
- package/fesm2015/impartner-design-components.mjs.map +1 -1
- package/fesm2020/impartner-design-components.mjs +77 -41
- package/fesm2020/impartner-design-components.mjs.map +1 -1
- package/lib/dropdown/dropdown.component.d.ts +4 -3
- package/lib/modal/modal.component.d.ts +2 -2
- package/lib/pagination/pagination.component.d.ts +2 -0
- package/lib/pagination/pagination.module.d.ts +3 -2
- package/package.json +1 -1
- package/services/interaction.service.d.ts +3 -0
|
@@ -46,7 +46,6 @@ export class DropdownComponent {
|
|
|
46
46
|
*/
|
|
47
47
|
this.buttonClick = new EventEmitter();
|
|
48
48
|
this.classBtnGroup = true;
|
|
49
|
-
this._interactableId = this._interactionService.add(this);
|
|
50
49
|
}
|
|
51
50
|
get classDropdown() {
|
|
52
51
|
return this.position === 'down';
|
|
@@ -77,6 +76,9 @@ export class DropdownComponent {
|
|
|
77
76
|
get shown() {
|
|
78
77
|
return this.valid && this.show;
|
|
79
78
|
}
|
|
79
|
+
ngOnInit() {
|
|
80
|
+
this._interactableId = this._interactionService.add(this);
|
|
81
|
+
}
|
|
80
82
|
ngOnDestroy() {
|
|
81
83
|
this._interactionService.remove(this.interactableId);
|
|
82
84
|
this._interactableId = 0;
|
|
@@ -137,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
137
139
|
type: HostListener,
|
|
138
140
|
args: ['document:click']
|
|
139
141
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.ts","../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostListener,\n  Output,\n  EventEmitter,\n  HostBinding,\n  QueryList,\n  ContentChildren,\n  OnDestroy\n} from '@angular/core';\nimport { InteractionService } from '../../services';\nimport { ButtonTheme } from '../button';\nimport { DropdownItemComponent } from './components';\nimport { DropdownPosition } from './types';\n\n/**\n * The `DropdownComponent` (`<impdc-dropdown` or `<any impdc-dropdown`) contains a button that toggles a dropdown where a user\n * can select various actions. Items within must be wrapped with `DropdownItemComponent` (`<impdc-dropdown-item`).\n * To use, import `DropdownModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `DropdownModule` imports and exports [ButtonModule](./?path=/docs/design-components-button).\n */\n@Component({\n  selector: 'impdc-dropdown, [impdc-dropdown]',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss']\n})\nexport class DropdownComponent implements OnDestroy {\n  private _interactableId = 0;\n\n  /**\n   * Whether or not the dropdown list is showing.\n   */\n  @Input()\n  show = false;\n\n  /**\n   * The content projected `DropdownItemComponent` children.\n   */\n  @ContentChildren(DropdownItemComponent)\n  items!: QueryList<DropdownItemComponent>;\n\n  /**\n   * The theme of the button affecting text, icons, backgrounds, and borders.\n   */\n  @Input()\n  buttonTheme: ButtonTheme = 'primary';\n\n  /**\n   * The text of the button.\n   */\n  @Input()\n  buttonText = '';\n\n  // we don't want headerText to be available right now\n  // @Input()\n  //headerText: string = '';\n\n  /**\n   * Where the list shows relative to the button when it is showing.\n   */\n  @Input()\n  position: DropdownPosition = 'down';\n\n  /**\n   * If true, the icon is split from the button and only clicking the icon triggers the list showing/hiding.\n   */\n  @Input()\n  split = false;\n\n  /**\n   * Emitted when the dropdown is toggled.\n   */\n  @Output()\n  toggle = new EventEmitter<boolean>();\n\n  /**\n   * Emitted when the button is clicked.\n   */\n  @Output()\n  public buttonClick = new EventEmitter<MouseEvent>();\n\n  @HostBinding('class.btn-group') private classBtnGroup = true;\n\n  @HostBinding('class.dropdown') private get classDropdown() {\n    return this.position === 'down';\n  }\n\n  @HostBinding('class.dropend') private get classDropend() {\n    return this.position === 'right';\n  }\n\n  @HostBinding('class.dropstart') private get classDropstart() {\n    return this.position === 'left';\n  }\n\n  @HostBinding('class.dropup') private get classDropup() {\n    return this.position === 'up';\n  }\n\n  @HostListener('click')\n  handleHostClick($event: MouseEvent): void {\n    $event.stopPropagation();\n  }\n\n  @HostListener('document:click')\n  handleDocumentClick(): void {\n    if (this.show) {\n      this.hide();\n    }\n  }\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this.show;\n  }\n\n  constructor(private _interactionService: InteractionService) {\n    this._interactableId = this._interactionService.add(this);\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  handleToggle(): void {\n    this.show = this._interactionService.toggle(this);\n    this.toggle.emit(this.show);\n  }\n\n  handleButtonClick(event: MouseEvent): void {\n    this.buttonClick.emit(event);\n  }\n\n  hide(): void {\n    this.show = false;\n    this.toggle.emit(this.show);\n  }\n}\n","<ng-container *ngIf=\"!linkEl.children.length\">\n  <button\n    *ngIf=\"!split; else splitTemplate\"\n    impdcButton\n    [theme]=\"buttonTheme\"\n    [text]=\"buttonText\"\n    class=\"dropdown-toggle\"\n    [class.show]=\"show\"\n    data-bs-toggle=\"dropdown\"\n    [attr.aria-expanded]=\"show\"\n    (click)=\"handleToggle(); $event.stopPropagation()\"></button>\n\n  <ng-template #splitTemplate>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      [text]=\"buttonText\"\n      (click)=\"handleButtonClick($event)\"></button>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      class=\"dropdown-toggle dropdown-toggle-split\"\n      [class.show]=\"show\"\n      [attr.aria-expanded]=\"show\"\n      (click)=\"handleToggle(); $event.stopPropagation()\">\n      <span class=\"visually-hidden\">Toggle Dropdown</span>\n    </button>\n  </ng-template>\n</ng-container>\n\n<ul\n  class=\"dropdown-menu\"\n  [class.dropdown-menu-end]=\"false\"\n  [class.show]=\"show\"\n  (click)=\"$event.stopPropagation()\">\n  <!-- <li *ngIf=\"headerText\">\n    <h6 class=\"dropdown-header\">{{ headerText }}</h6>\n  </li> -->\n  <li *ngFor=\"let item of items\">\n    <span *ngIf=\"!item.divider; else dividerTemplate\" class=\"dropdown-item\">\n      <ng-content *ngTemplateOutlet=\"item.template\"></ng-content>\n    </span>\n  </li>\n</ul>\n\n<ng-template #dividerTemplate>\n  <hr class=\"dropdown-divider\" />\n</ng-template>\n\n<a\n  #linkEl\n  class=\"impdc-dropdown-link\"\n  [class.hide]=\"!linkEl.children.length\"\n  [class.impdc-dropdown-open]=\"show\"\n  data-bs-toggle=\"dropdown\"\n  [attr.aria-expanded]=\"show\"\n  (click)=\"handleToggle(); $event.stopPropagation()\">\n  <ng-content select=\"[toggle]\"></ng-content>\n</a>\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.ts","../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostListener,\n  Output,\n  EventEmitter,\n  HostBinding,\n  QueryList,\n  ContentChildren,\n  OnInit,\n  OnDestroy\n} from '@angular/core';\nimport { InteractionService } from '../../services';\nimport { ButtonTheme } from '../button';\nimport { DropdownItemComponent } from './components';\nimport { DropdownPosition } from './types';\n\n/**\n * The `DropdownComponent` (`<impdc-dropdown` or `<any impdc-dropdown`) contains a button that toggles a dropdown where a user\n * can select various actions. Items within must be wrapped with `DropdownItemComponent` (`<impdc-dropdown-item`).\n * To use, import `DropdownModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `DropdownModule` imports and exports [ButtonModule](./?path=/docs/design-components-button).\n */\n@Component({\n  selector: 'impdc-dropdown, [impdc-dropdown]',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss']\n})\nexport class DropdownComponent implements OnInit, OnDestroy {\n  private _interactableId = 0;\n\n  /**\n   * Whether or not the dropdown list is showing.\n   */\n  @Input()\n  show = false;\n\n  /**\n   * The content projected `DropdownItemComponent` children.\n   */\n  @ContentChildren(DropdownItemComponent)\n  items!: QueryList<DropdownItemComponent>;\n\n  /**\n   * The theme of the button affecting text, icons, backgrounds, and borders.\n   */\n  @Input()\n  buttonTheme: ButtonTheme = 'primary';\n\n  /**\n   * The text of the button.\n   */\n  @Input()\n  buttonText = '';\n\n  // we don't want headerText to be available right now\n  // @Input()\n  //headerText: string = '';\n\n  /**\n   * Where the list shows relative to the button when it is showing.\n   */\n  @Input()\n  position: DropdownPosition = 'down';\n\n  /**\n   * If true, the icon is split from the button and only clicking the icon triggers the list showing/hiding.\n   */\n  @Input()\n  split = false;\n\n  /**\n   * Emitted when the dropdown is toggled.\n   */\n  @Output()\n  toggle = new EventEmitter<boolean>();\n\n  /**\n   * Emitted when the button is clicked.\n   */\n  @Output()\n  public buttonClick = new EventEmitter<MouseEvent>();\n\n  @HostBinding('class.btn-group') private classBtnGroup = true;\n\n  @HostBinding('class.dropdown') private get classDropdown() {\n    return this.position === 'down';\n  }\n\n  @HostBinding('class.dropend') private get classDropend() {\n    return this.position === 'right';\n  }\n\n  @HostBinding('class.dropstart') private get classDropstart() {\n    return this.position === 'left';\n  }\n\n  @HostBinding('class.dropup') private get classDropup() {\n    return this.position === 'up';\n  }\n\n  @HostListener('click')\n  handleHostClick($event: MouseEvent): void {\n    $event.stopPropagation();\n  }\n\n  @HostListener('document:click')\n  handleDocumentClick(): void {\n    if (this.show) {\n      this.hide();\n    }\n  }\n\n  constructor(private _interactionService: InteractionService) {}\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this.show;\n  }\n\n  ngOnInit(): void {\n    this._interactableId = this._interactionService.add(this);\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  handleToggle(): void {\n    this.show = this._interactionService.toggle(this);\n    this.toggle.emit(this.show);\n  }\n\n  handleButtonClick(event: MouseEvent): void {\n    this.buttonClick.emit(event);\n  }\n\n  hide(): void {\n    this.show = false;\n    this.toggle.emit(this.show);\n  }\n}\n","<ng-container *ngIf=\"!linkEl.children.length\">\n  <button\n    *ngIf=\"!split; else splitTemplate\"\n    impdcButton\n    [theme]=\"buttonTheme\"\n    [text]=\"buttonText\"\n    class=\"dropdown-toggle\"\n    [class.show]=\"show\"\n    data-bs-toggle=\"dropdown\"\n    [attr.aria-expanded]=\"show\"\n    (click)=\"handleToggle(); $event.stopPropagation()\"></button>\n\n  <ng-template #splitTemplate>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      [text]=\"buttonText\"\n      (click)=\"handleButtonClick($event)\"></button>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      class=\"dropdown-toggle dropdown-toggle-split\"\n      [class.show]=\"show\"\n      [attr.aria-expanded]=\"show\"\n      (click)=\"handleToggle(); $event.stopPropagation()\">\n      <span class=\"visually-hidden\">Toggle Dropdown</span>\n    </button>\n  </ng-template>\n</ng-container>\n\n<ul\n  class=\"dropdown-menu\"\n  [class.dropdown-menu-end]=\"false\"\n  [class.show]=\"show\"\n  (click)=\"$event.stopPropagation()\">\n  <!-- <li *ngIf=\"headerText\">\n    <h6 class=\"dropdown-header\">{{ headerText }}</h6>\n  </li> -->\n  <li *ngFor=\"let item of items\">\n    <span *ngIf=\"!item.divider; else dividerTemplate\" class=\"dropdown-item\">\n      <ng-content *ngTemplateOutlet=\"item.template\"></ng-content>\n    </span>\n  </li>\n</ul>\n\n<ng-template #dividerTemplate>\n  <hr class=\"dropdown-divider\" />\n</ng-template>\n\n<a\n  #linkEl\n  class=\"impdc-dropdown-link\"\n  [class.hide]=\"!linkEl.children.length\"\n  [class.impdc-dropdown-open]=\"show\"\n  data-bs-toggle=\"dropdown\"\n  [attr.aria-expanded]=\"show\"\n  (click)=\"handleToggle(); $event.stopPropagation()\">\n  <ng-content select=\"[toggle]\"></ng-content>\n</a>\n"]}
|
|
@@ -58,13 +58,17 @@ export class ModalComponent {
|
|
|
58
58
|
* Event emitted when the Modal content is accepted.
|
|
59
59
|
*/
|
|
60
60
|
this.accept = new EventEmitter();
|
|
61
|
-
this._interactableId = this._interactionService.add(this);
|
|
62
61
|
}
|
|
63
62
|
/**
|
|
64
63
|
* Determines if the Modal should be shown immediately.
|
|
65
64
|
*/
|
|
66
65
|
set show(show) {
|
|
67
|
-
|
|
66
|
+
if (show) {
|
|
67
|
+
this.open();
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.close();
|
|
71
|
+
}
|
|
68
72
|
}
|
|
69
73
|
get interactableId() {
|
|
70
74
|
return this._interactableId;
|
|
@@ -88,6 +92,7 @@ export class ModalComponent {
|
|
|
88
92
|
return !this.titleText && !this.dismissable;
|
|
89
93
|
}
|
|
90
94
|
ngOnInit() {
|
|
95
|
+
this._interactableId = this._interactionService.add(this);
|
|
91
96
|
if (this.dismissable === undefined && this.theme === ModalTheme.Working) {
|
|
92
97
|
this.dismissable = true;
|
|
93
98
|
}
|
|
@@ -104,35 +109,38 @@ export class ModalComponent {
|
|
|
104
109
|
!!this.dismissEl?.nativeElement?.firstChild?.disabled) {
|
|
105
110
|
return;
|
|
106
111
|
}
|
|
107
|
-
this.
|
|
112
|
+
this.close();
|
|
108
113
|
this.dismiss.emit(event);
|
|
109
114
|
}
|
|
110
115
|
handleDeny(event) {
|
|
111
116
|
if (!!this.denyEl?.nativeElement?.firstChild?.disabled) {
|
|
112
117
|
return;
|
|
113
118
|
}
|
|
114
|
-
this.
|
|
119
|
+
this.close();
|
|
115
120
|
this.deny.emit(event);
|
|
116
121
|
}
|
|
117
122
|
handleAccept(event) {
|
|
118
|
-
console.log('this.acceptEl', this.acceptEl);
|
|
119
123
|
if (!!this.acceptEl?.nativeElement?.firstChild?.disabled) {
|
|
120
124
|
return;
|
|
121
125
|
}
|
|
122
|
-
this.
|
|
126
|
+
this.close();
|
|
123
127
|
this.accept.emit(event);
|
|
124
128
|
}
|
|
125
129
|
/**
|
|
126
|
-
* Opens/shows the modal programmatically.
|
|
130
|
+
* Opens/shows the modal. Can be used programmatically.
|
|
127
131
|
*/
|
|
128
132
|
open() {
|
|
133
|
+
if (this.backdrop) {
|
|
134
|
+
this._interactionService.queueBackdrop(this.interactableId);
|
|
135
|
+
}
|
|
129
136
|
this._show = true;
|
|
130
137
|
}
|
|
131
138
|
/**
|
|
132
|
-
* Closes/hides the modal programmatically.
|
|
139
|
+
* Closes/hides the modal. Can be used programmatically.
|
|
133
140
|
*/
|
|
134
141
|
close() {
|
|
135
142
|
this._show = false;
|
|
143
|
+
this._interactionService.dequeueBackdrop(this.interactableId);
|
|
136
144
|
}
|
|
137
145
|
}
|
|
138
146
|
ModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ModalComponent, deps: [{ token: i1.InteractionService }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -176,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
176
184
|
}], accept: [{
|
|
177
185
|
type: Output
|
|
178
186
|
}] } });
|
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/modal/modal.component.ts","../../../../../../projects/design-components/src/lib/modal/modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,OAAO,EAAuB,UAAU,EAAe,MAAM,SAAS,CAAC;;;;;;AAEvE;;;;;GAKG;AAMH,MAAM,OAAO,cAAc;IAuGzB,YAAoB,mBAAuC;QAAvC,wBAAmB,GAAnB,mBAAmB,CAAoB;QAtGnD,oBAAe,GAAG,CAAC,CAAC;QACpB,UAAK,GAAG,KAAK,CAAC;QAUtB;;WAEG;QAEH,UAAK,GAAgB,UAAU,CAAC,MAAM,CAAC;QAEvC;;WAEG;QAEH,SAAI,GAAwB,aAAa,CAAC,MAAM,CAAC;QAQjD;;;WAGG;QAEH,cAAS,GAAyB,OAAO,CAAC;QAE1C;;WAEG;QAEH,cAAS,GAAG,EAAE,CAAC;QAEf;;WAEG;QAEH,eAAU,GAAG,IAAI,CAAC;QAQlB;;WAEG;QAEH,SAAI,GAAG,IAAI,CAAC;QAEZ;;WAEG;QAEH,aAAQ,GAAG,IAAI,CAAC;QAoBhB;;WAEG;QAEH,YAAO,GAAG,IAAI,YAAY,EAAsB,CAAC;QAEjD;;WAEG;QAEH,SAAI,GAAG,IAAI,YAAY,EAAsB,CAAC;QAE9C;;WAEG;QAEH,WAAM,GAAG,IAAI,YAAY,EAAsB,CAAC;QAG9C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC5D,CAAC;IArGD;;OAEG;IACH,IACI,IAAI,CAAC,IAAa;QACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAiGD,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC;IAClC,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,OAAO,CAAC;IAC9D,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,WAAW,CAAC;IAClE,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IACtE,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC;IAC9C,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,OAAO,EAAE;YACvE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SACzB;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,WAAW,EAAE;YACxE,IAAI,CAAC,QAAQ,GAAG,sBAAsB,CAAC;SACxC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACrD,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC;IAC3B,CAAC;IAES,aAAa,CAAC,KAAyB;QAC/C,IACE,CAAC,IAAI,CAAC,WAAW;YACjB,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,EAAE,UAAU,EAAE,QAAQ,EACrD;YACA,OAAO;SACR;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAES,UAAU,CAAC,KAAyB;QAC5C,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,aAAa,EAAE,UAAU,EAAE,QAAQ,EAAE;YACtD,OAAO;SACR;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAES,YAAY,CAAC,KAAyB;QAC9C,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,aAAa,EAAE,UAAU,EAAE,QAAQ,EAAE;YACxD,OAAO;SACR;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,IAAI;QACF,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;4GA9LU,cAAc;gGAAd,cAAc,8lBC3B3B,iqFA0EA;4FD/Ca,cAAc;kBAL1B,SAAS;+BACE,aAAa;yGAYnB,IAAI;sBADP,KAAK;gBASN,KAAK;sBADJ,KAAK;gBAON,IAAI;sBADH,KAAK;gBAON,QAAQ;sBADP,KAAK;gBAQN,SAAS;sBADR,KAAK;gBAON,SAAS;sBADR,KAAK;gBAON,UAAU;sBADT,KAAK;gBAON,WAAW;sBADV,KAAK;gBAON,IAAI;sBADH,KAAK;gBAON,QAAQ;sBADP,KAAK;gBAON,SAAS;sBADR,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAOzC,MAAM;sBADL,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAOtC,QAAQ;sBADP,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAOxC,OAAO;sBADN,MAAM;gBAOP,IAAI;sBADH,MAAM;gBAOP,MAAM;sBADL,MAAM","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { FontAwesomeIcon, FontAwesomeIconTheme } from '../../constants';\nimport { InteractionService } from '../../services';\nimport { ComponentSize } from '../../types';\nimport { ButtonTheme } from '../button';\nimport { ModalComponentSizes, ModalTheme, ModalThemes } from './types';\n\n/**\n * The `ModalComponent` (`<impdc-modal`) displays over the content of the page when a user action is required.\n * To use, import `ModalModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ModalModule` imports and exports BackdropModule, [ButtonModule](./?path=/docs/design-components-button),\n * and [IconModule](./?path=/docs/design-components-icon).\n */\n@Component({\n  selector: 'impdc-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss']\n})\nexport class ModalComponent implements OnInit, OnDestroy {\n  private _interactableId = 0;\n  private _show = false;\n\n  /**\n   * Determines if the Modal should be shown immediately.\n   */\n  @Input()\n  set show(show: boolean) {\n    this._show = show;\n  }\n\n  /**\n   * The theme of the Modal. Affects the layout of the Modal as well as some colors.\n   */\n  @Input()\n  theme: ModalThemes = ModalTheme.Simple;\n\n  /**\n   * The size of the Modal.\n   */\n  @Input()\n  size: ModalComponentSizes = ComponentSize.Medium;\n\n  /**\n   * The Font Awesome 5 icon name. Only supported when the theme is Working or Destructive.\n   */\n  @Input()\n  iconName?: FontAwesomeIcon;\n\n  /**\n   * The Font Awesome 5 icon style. Fewer icons support the Regular theme and will fallback to Solid\n   * if not supported.\n   */\n  @Input()\n  iconTheme: FontAwesomeIconTheme = 'light';\n\n  /**\n   * The subject text of the Modal.\n   */\n  @Input()\n  titleText = '';\n\n  /**\n   * The fallback button text to accept the Modal. This is bypassed if you content-project the accept button.\n   */\n  @Input()\n  acceptText = 'OK';\n\n  /**\n   * Allows the Modal to be dismissed. This is different from `accept` and `deny`. If a Modal is meant to be re-opened frequently it should be dismissable.\n   */\n  @Input()\n  dismissable?: boolean;\n\n  /**\n   * Determines if the Modal should fade in/out.\n   */\n  @Input()\n  fade = true;\n\n  /**\n   * Shows a backdrop behind the Modal.\n   */\n  @Input()\n  backdrop = true;\n\n  /**\n   * Contains the dismiss button content projection.\n   */\n  @ViewChild('dismissEl', { static: false })\n  dismissEl!: ElementRef;\n\n  /**\n   * Contains the deny button content projection.\n   */\n  @ViewChild('denyEl', { static: false })\n  denyEl!: ElementRef;\n\n  /**\n   * Contains the accept button content projection.\n   */\n  @ViewChild('acceptEl', { static: false })\n  acceptEl!: ElementRef;\n\n  /**\n   * Event emitted when the Modal content is dismissed.\n   */\n  @Output()\n  dismiss = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is denied.\n   */\n  @Output()\n  deny = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is accepted.\n   */\n  @Output()\n  accept = new EventEmitter<MouseEvent | Event>();\n\n  constructor(private _interactionService: InteractionService) {\n    this._interactableId = this._interactionService.add(this);\n  }\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this._show;\n  }\n\n  get showWorkingIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Working;\n  }\n\n  get showDestructiveIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Destructive;\n  }\n\n  get acceptFallbackTheme(): ButtonTheme {\n    return this.theme === ModalTheme.Destructive ? 'danger' : 'primary';\n  }\n\n  get hideHeader(): boolean {\n    return !this.titleText && !this.dismissable;\n  }\n\n  ngOnInit(): void {\n    if (this.dismissable === undefined && this.theme === ModalTheme.Working) {\n      this.dismissable = true;\n    }\n\n    if (this.iconName === undefined && this.theme === ModalTheme.Destructive) {\n      this.iconName = 'exclamation-triangle';\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  protected handleDismiss(event: MouseEvent | Event): void {\n    if (\n      !this.dismissable ||\n      !!this.dismissEl?.nativeElement?.firstChild?.disabled\n    ) {\n      return;\n    }\n    this._show = false;\n    this.dismiss.emit(event);\n  }\n\n  protected handleDeny(event: MouseEvent | Event): void {\n    if (!!this.denyEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this._show = false;\n    this.deny.emit(event);\n  }\n\n  protected handleAccept(event: MouseEvent | Event): void {\n    console.log('this.acceptEl', this.acceptEl);\n    if (!!this.acceptEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this._show = false;\n    this.accept.emit(event);\n  }\n\n  /**\n   * Opens/shows the modal programmatically.\n   */\n  open(): void {\n    this._show = true;\n  }\n\n  /**\n   * Closes/hides the modal programmatically.\n   */\n  close(): void {\n    this._show = false;\n  }\n}\n","<div\n  *ngIf=\"valid\"\n  class=\"impdc modal\"\n  [class.fade]=\"fade\"\n  [class.in]=\"fade && shown\"\n  [class.show]=\"shown\"\n  [class.dismissable]=\"dismissable\"\n  tabindex=\"-1\"\n  (click)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.escape)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.enter)=\"handleAccept($event); $event.stopPropagation()\">\n  <div\n    class=\"modal-dialog modal-dialog-centered modal-dialog-scrollable modal-theme-{{\n      theme\n    }}\"\n    [class.modal-sm]=\"size === 'sm'\"\n    [class.modal-lg]=\"size === 'lg'\"\n    [class.modal-xl]=\"size === 'xl'\"\n    [class.modal-fullscreen]=\"size === 'fs'\"\n    [class.modal-fullscreen-lg-down]=\"size !== 'fs'\"\n    (click)=\"$event.stopPropagation()\">\n    <div class=\"modal-content\">\n      <div *ngIf=\"showDestructiveIcon\" class=\"modal-icon\">\n        <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n      </div>\n      <div #header class=\"modal-header\" [class.hide]=\"hideHeader\">\n        <h3 class=\"modal-title\">\n          <span *ngIf=\"showWorkingIcon\" class=\"modal-icon\">\n            <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n          </span>\n          <span>{{ titleText }}</span>\n        </h3>\n        <button\n          impdcButton\n          *ngIf=\"dismissable\"\n          theme=\"close\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\"></button>\n      </div>\n      <div #bodyEl class=\"modal-body\">\n        <ng-content></ng-content>\n      </div>\n      <div #footer class=\"modal-footer\">\n        <span\n          #dismissEl\n          *ngIf=\"dismissable\"\n          [class.hide]=\"!dismissEl.children.length\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\">\n          <ng-content select=\"[dismiss]\"></ng-content>\n        </span>\n        <span\n          #denyEl\n          [class.hide]=\"!denyEl.children.length\"\n          (click)=\"handleDeny($event); $event.stopPropagation()\">\n          <ng-content select=\"[deny]\"></ng-content>\n        </span>\n        <span\n          #acceptEl\n          [class.hide]=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <ng-content select=\"[accept]\"></ng-content>\n        </span>\n        <span\n          #acceptFallbackEl\n          *ngIf=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <button\n            impdcButton\n            [text]=\"acceptText\"\n            [theme]=\"acceptFallbackTheme\"></button>\n        </span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/modal/modal.component.ts","../../../../../../projects/design-components/src/lib/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { FontAwesomeIcon, FontAwesomeIconTheme } from '../../constants';\nimport { InteractionService } from '../../services';\nimport { ComponentSize } from '../../types';\nimport { ButtonTheme } from '../button';\nimport { ModalComponentSizes, ModalTheme, ModalThemes } from './types';\n\n/**\n * The `ModalComponent` (`<impdc-modal`) displays over the content of the page when a user action is required.\n * To use, import `ModalModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ModalModule` imports and exports BackdropModule, [ButtonModule](./?path=/docs/design-components-button),\n * and [IconModule](./?path=/docs/design-components-icon).\n */\n@Component({\n  selector: 'impdc-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss']\n})\nexport class ModalComponent implements OnInit, OnDestroy {\n  private _interactableId = 0;\n  private _show = false;\n\n  /**\n   * Determines if the Modal should be shown immediately.\n   */\n  @Input()\n  set show(show: boolean) {\n    if (show) {\n      this.open();\n    } else {\n      this.close();\n    }\n  }\n\n  /**\n   * The theme of the Modal. Affects the layout of the Modal as well as some colors.\n   */\n  @Input()\n  theme: ModalThemes = ModalTheme.Simple;\n\n  /**\n   * The size of the Modal.\n   */\n  @Input()\n  size: ModalComponentSizes = ComponentSize.Medium;\n\n  /**\n   * The Font Awesome 5 icon name. Only supported when the theme is Working or Destructive.\n   */\n  @Input()\n  iconName?: FontAwesomeIcon;\n\n  /**\n   * The Font Awesome 5 icon style. Fewer icons support the Regular theme and will fallback to Solid\n   * if not supported.\n   */\n  @Input()\n  iconTheme: FontAwesomeIconTheme = 'light';\n\n  /**\n   * The subject text of the Modal.\n   */\n  @Input()\n  titleText = '';\n\n  /**\n   * The fallback button text to accept the Modal. This is bypassed if you content-project the accept button.\n   */\n  @Input()\n  acceptText = 'OK';\n\n  /**\n   * Allows the Modal to be dismissed. This is different from `accept` and `deny`. If a Modal is meant to be re-opened frequently it should be dismissable.\n   */\n  @Input()\n  dismissable?: boolean;\n\n  /**\n   * Determines if the Modal should fade in/out.\n   */\n  @Input()\n  fade = true;\n\n  /**\n   * Shows a backdrop behind the Modal.\n   */\n  @Input()\n  backdrop = true;\n\n  /**\n   * Contains the dismiss button content projection.\n   */\n  @ViewChild('dismissEl', { static: false })\n  dismissEl!: ElementRef;\n\n  /**\n   * Contains the deny button content projection.\n   */\n  @ViewChild('denyEl', { static: false })\n  denyEl!: ElementRef;\n\n  /**\n   * Contains the accept button content projection.\n   */\n  @ViewChild('acceptEl', { static: false })\n  acceptEl!: ElementRef;\n\n  /**\n   * Event emitted when the Modal content is dismissed.\n   */\n  @Output()\n  dismiss = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is denied.\n   */\n  @Output()\n  deny = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is accepted.\n   */\n  @Output()\n  accept = new EventEmitter<MouseEvent | Event>();\n\n  constructor(private _interactionService: InteractionService) {}\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this._show;\n  }\n\n  get showWorkingIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Working;\n  }\n\n  get showDestructiveIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Destructive;\n  }\n\n  get acceptFallbackTheme(): ButtonTheme {\n    return this.theme === ModalTheme.Destructive ? 'danger' : 'primary';\n  }\n\n  get hideHeader(): boolean {\n    return !this.titleText && !this.dismissable;\n  }\n\n  ngOnInit(): void {\n    this._interactableId = this._interactionService.add(this);\n\n    if (this.dismissable === undefined && this.theme === ModalTheme.Working) {\n      this.dismissable = true;\n    }\n\n    if (this.iconName === undefined && this.theme === ModalTheme.Destructive) {\n      this.iconName = 'exclamation-triangle';\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  protected handleDismiss(event: MouseEvent | Event): void {\n    if (\n      !this.dismissable ||\n      !!this.dismissEl?.nativeElement?.firstChild?.disabled\n    ) {\n      return;\n    }\n    this.close();\n    this.dismiss.emit(event);\n  }\n\n  protected handleDeny(event: MouseEvent | Event): void {\n    if (!!this.denyEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this.close();\n    this.deny.emit(event);\n  }\n\n  protected handleAccept(event: MouseEvent | Event): void {\n    if (!!this.acceptEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this.close();\n    this.accept.emit(event);\n  }\n\n  /**\n   * Opens/shows the modal. Can be used programmatically.\n   */\n  open(): void {\n    if (this.backdrop) {\n      this._interactionService.queueBackdrop(this.interactableId);\n    }\n    this._show = true;\n  }\n\n  /**\n   * Closes/hides the modal. Can be used programmatically.\n   */\n  close(): void {\n    this._show = false;\n    this._interactionService.dequeueBackdrop(this.interactableId);\n  }\n}\n","<div\n  *ngIf=\"valid\"\n  class=\"impdc modal\"\n  [class.fade]=\"fade\"\n  [class.in]=\"fade && shown\"\n  [class.show]=\"shown\"\n  [class.dismissable]=\"dismissable\"\n  tabindex=\"-1\"\n  (click)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.escape)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.enter)=\"handleAccept($event); $event.stopPropagation()\">\n  <div\n    class=\"modal-dialog modal-dialog-centered modal-dialog-scrollable modal-theme-{{\n      theme\n    }}\"\n    [class.modal-sm]=\"size === 'sm'\"\n    [class.modal-lg]=\"size === 'lg'\"\n    [class.modal-xl]=\"size === 'xl'\"\n    [class.modal-fullscreen]=\"size === 'fs'\"\n    [class.modal-fullscreen-lg-down]=\"size !== 'fs'\"\n    (click)=\"$event.stopPropagation()\">\n    <div class=\"modal-content\">\n      <div *ngIf=\"showDestructiveIcon\" class=\"modal-icon\">\n        <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n      </div>\n      <div #header class=\"modal-header\" [class.hide]=\"hideHeader\">\n        <h3 class=\"modal-title\">\n          <span *ngIf=\"showWorkingIcon\" class=\"modal-icon\">\n            <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n          </span>\n          <span>{{ titleText }}</span>\n        </h3>\n        <button\n          impdcButton\n          *ngIf=\"dismissable\"\n          theme=\"close\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\"></button>\n      </div>\n      <div #bodyEl class=\"modal-body\">\n        <ng-content></ng-content>\n      </div>\n      <div #footer class=\"modal-footer\">\n        <span\n          #dismissEl\n          *ngIf=\"dismissable\"\n          [class.hide]=\"!dismissEl.children.length\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\">\n          <ng-content select=\"[dismiss]\"></ng-content>\n        </span>\n        <span\n          #denyEl\n          [class.hide]=\"!denyEl.children.length\"\n          (click)=\"handleDeny($event); $event.stopPropagation()\">\n          <ng-content select=\"[deny]\"></ng-content>\n        </span>\n        <span\n          #acceptEl\n          [class.hide]=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <ng-content select=\"[accept]\"></ng-content>\n        </span>\n        <span\n          #acceptFallbackEl\n          *ngIf=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <button\n            impdcButton\n            [text]=\"acceptText\"\n            [theme]=\"acceptFallbackTheme\"></button>\n        </span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -2,7 +2,8 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
|
2
2
|
import { sanitize } from '../../utilities';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../button/button.component";
|
|
5
|
-
import * as i2 from "
|
|
5
|
+
import * as i2 from "@angular/forms";
|
|
6
|
+
import * as i3 from "../form-field/controls/input/input.directive";
|
|
6
7
|
/**
|
|
7
8
|
* The `PaginationComponent` (`<impdc-pagination` or `<div impdc-pagination`) is a control for paged content such as tables or lists.
|
|
8
9
|
* To use, import `PaginationModule` or another module that imports and exports that module from `@impartner/design-components`.
|
|
@@ -51,22 +52,24 @@ export class PaginationComponent {
|
|
|
51
52
|
return Math.ceil(this.total / this.perPage);
|
|
52
53
|
}
|
|
53
54
|
get firstPageResult() {
|
|
54
|
-
|
|
55
|
+
const page = this._getPageClamped();
|
|
56
|
+
if (this.total < 1 || page < 1 || this.perPage < 1) {
|
|
55
57
|
return 0;
|
|
56
58
|
}
|
|
57
|
-
if (
|
|
59
|
+
if (page === 1) {
|
|
58
60
|
return 1;
|
|
59
61
|
}
|
|
60
|
-
if (
|
|
62
|
+
if (page > Math.ceil(this.total / this.perPage)) {
|
|
61
63
|
return this.total;
|
|
62
64
|
}
|
|
63
|
-
return (
|
|
65
|
+
return (page - 1) * this.perPage + 1;
|
|
64
66
|
}
|
|
65
67
|
get lastPageResult() {
|
|
66
|
-
|
|
68
|
+
const page = this._getPageClamped();
|
|
69
|
+
if (this.total <= 0 || page < 1 || this.perPage < 1) {
|
|
67
70
|
return 0;
|
|
68
71
|
}
|
|
69
|
-
if (
|
|
72
|
+
if (page === 1) {
|
|
70
73
|
if (this.total < this.perPage) {
|
|
71
74
|
return this.total;
|
|
72
75
|
}
|
|
@@ -74,26 +77,38 @@ export class PaginationComponent {
|
|
|
74
77
|
return this.perPage;
|
|
75
78
|
}
|
|
76
79
|
}
|
|
77
|
-
if (this.total < this.perPage *
|
|
80
|
+
if (this.total < this.perPage * page) {
|
|
78
81
|
return this.total;
|
|
79
82
|
}
|
|
80
83
|
else {
|
|
81
|
-
return this.perPage *
|
|
84
|
+
return this.perPage * page;
|
|
82
85
|
}
|
|
83
86
|
}
|
|
87
|
+
_getPageClamped(page) {
|
|
88
|
+
page = Number(page || this.page || 0);
|
|
89
|
+
if (isNaN(page) || page < 1) {
|
|
90
|
+
return 1;
|
|
91
|
+
}
|
|
92
|
+
if (page > this.totalPages) {
|
|
93
|
+
return this.totalPages;
|
|
94
|
+
}
|
|
95
|
+
return page;
|
|
96
|
+
}
|
|
84
97
|
goToPreviousPage() {
|
|
85
|
-
|
|
98
|
+
const page = this._getPageClamped();
|
|
99
|
+
if (page <= 1) {
|
|
86
100
|
return;
|
|
87
101
|
}
|
|
88
|
-
const previousPage =
|
|
102
|
+
const previousPage = page - 1;
|
|
89
103
|
this.page = previousPage;
|
|
90
104
|
this.goToPage.emit(previousPage);
|
|
91
105
|
}
|
|
92
106
|
goToNextPage() {
|
|
93
|
-
|
|
107
|
+
const page = this._getPageClamped();
|
|
108
|
+
if (page >= this.totalPages) {
|
|
94
109
|
return;
|
|
95
110
|
}
|
|
96
|
-
const nextPage =
|
|
111
|
+
const nextPage = page + 1;
|
|
97
112
|
this.page = nextPage;
|
|
98
113
|
this.goToPage.emit(nextPage);
|
|
99
114
|
}
|
|
@@ -101,25 +116,20 @@ export class PaginationComponent {
|
|
|
101
116
|
this.goToExactPage(target?.value);
|
|
102
117
|
}
|
|
103
118
|
goToExactPage(page) {
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
if (allowedPageNumber > this.totalPages) {
|
|
112
|
-
allowedPageNumber = this.totalPages;
|
|
113
|
-
}
|
|
114
|
-
this.page = allowedPageNumber;
|
|
115
|
-
this.goToPage.emit(allowedPageNumber);
|
|
119
|
+
this.page = this._getPageClamped(page);
|
|
120
|
+
this.goToPage.emit(this.page);
|
|
121
|
+
}
|
|
122
|
+
preventDefaultAndBlur(event) {
|
|
123
|
+
// prevents PRM form submit
|
|
124
|
+
event.preventDefault();
|
|
125
|
+
event.target.blur();
|
|
116
126
|
}
|
|
117
127
|
}
|
|
118
128
|
PaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
119
|
-
PaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: PaginationComponent, selector: "impdc-pagination, div[impdc-pagination]", inputs: { page: "page", perPage: "perPage", total: "total", summary: "summary" }, outputs: { goToPage: "goToPage" }, ngImport: i0, template: "<div class=\"pagination-container\">\n <div class=\"mobile-pagination\">\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page <= 1\"\n (click)=\"goToPreviousPage()\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page === totalPages\"\n (click)=\"goToNextPage()\">\n <i class=\"fas fa-chevron-right\"></i>\n </button>\n </div>\n\n <div class=\"desktop-pagination\">\n <div>\n <span class=\"summary\" [innerHTML]=\"summary\"></span>\n </div>\n <div class=\"pagination-actions\">\n <button\n impdcButton\n theme=\"secondary\"\n aria-label=\"First Page\"\n class=\"pagination-first-last-btns\"\n (click)=\"goToExactPage(1)\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left first\"></i>\n <i class=\"fas fa-chevron-left\"></i>\n <!-- 1 -->\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n class=\"previous\"\n aria-label=\"Previous\"\n (click)=\"goToPreviousPage()\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <div class=\"page-change\">\n <input\n impdcInput\n
|
|
129
|
+
PaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: PaginationComponent, selector: "impdc-pagination, div[impdc-pagination]", inputs: { page: "page", perPage: "perPage", total: "total", summary: "summary" }, outputs: { goToPage: "goToPage" }, ngImport: i0, template: "<div class=\"pagination-container\">\n <div class=\"mobile-pagination\">\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page <= 1\"\n (click)=\"goToPreviousPage()\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page === totalPages\"\n (click)=\"goToNextPage()\">\n <i class=\"fas fa-chevron-right\"></i>\n </button>\n </div>\n\n <div class=\"desktop-pagination\">\n <div>\n <span class=\"summary\" [innerHTML]=\"summary\"></span>\n </div>\n <div class=\"pagination-actions\">\n <button\n impdcButton\n theme=\"secondary\"\n aria-label=\"First Page\"\n class=\"pagination-first-last-btns\"\n (click)=\"goToExactPage(1)\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left first\"></i>\n <i class=\"fas fa-chevron-left\"></i>\n <!-- 1 -->\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n class=\"previous\"\n aria-label=\"Previous\"\n (click)=\"goToPreviousPage()\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <div class=\"page-change\">\n <input\n impdcInput\n [(ngModel)]=\"page\"\n maxlength=\"4\"\n (blur)=\"goToExactPageFromEvent($event)\"\n (keydown.enter)=\"preventDefaultAndBlur($event)\" />\n <span class=\"total-pages\"> / {{ totalPages }} </span>\n </div>\n <button\n impdcButton\n theme=\"secondary\"\n aria-label=\"Next\"\n (click)=\"goToNextPage()\"\n [disabled]=\"page >= totalPages\">\n <i class=\"fas fa-chevron-right\"></i>\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n class=\"pagination-first-last-btns\"\n aria-label=\"Last Page\"\n (click)=\"goToExactPage(totalPages)\"\n [disabled]=\"page === totalPages\">\n <i class=\"fas fa-chevron-right\"></i>\n <i class=\"fas fa-chevron-right last\"></i>\n <!-- {{ totalPages }} -->\n </button>\n </div>\n </div>\n</div>\n", styles: [".pagination-container{background-color:var(--impd-color-white);padding:var(--impd-size-3) var(--impd-size-6);gap:1rem;color:var(--impd-color-gray-700, #374151)}@media (min-width: 640px){.pagination-container{padding-left:var(--impd-size-6);padding-right:var(--impd-size-6)}}.mobile-pagination{display:flex;gap:2rem;justify-content:space-between;align-items:center}@media (min-width: 640px){.mobile-pagination{display:none}}.desktop-pagination{display:none}@media (min-width: 640px){.desktop-pagination{display:flex;flex:1 1 0%;align-items:center;justify-content:space-between;gap:2rem;flex-flow:wrap}}.summary{font-size:var(--impd-font-size-sm);line-height:var(--impd-size-5);font-weight:400;color:var(--impd-color-gray-700)}.pagination-actions{display:flex;flex-direction:row;gap:.4rem;flex-flow:wrap}.pagination-actions .first{margin-right:-1.2rem}.pagination-actions .last{margin-left:-1.2rem}.page-change{display:flex;flex-direction:row;align-items:center;gap:.4rem;font-size:var(--impd-size-3_5, 1.4rem)}.page-change .form-control{min-width:4.275rem;max-width:6.3rem;text-align:center}.page-change .total-pages{padding:0 1.2rem}.pagination-first-last-btns{padding-left:1.325rem;padding-right:1.325rem}\n"], dependencies: [{ kind: "component", type: i1.ButtonComponent, selector: "button[impdcButton]", inputs: ["type", "theme", "text", "disabled", "titleText", "ariaLabel"] }, { 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.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }] });
|
|
120
130
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PaginationComponent, decorators: [{
|
|
121
131
|
type: Component,
|
|
122
|
-
args: [{ selector: 'impdc-pagination, div[impdc-pagination]', template: "<div class=\"pagination-container\">\n <div class=\"mobile-pagination\">\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page <= 1\"\n (click)=\"goToPreviousPage()\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page === totalPages\"\n (click)=\"goToNextPage()\">\n <i class=\"fas fa-chevron-right\"></i>\n </button>\n </div>\n\n <div class=\"desktop-pagination\">\n <div>\n <span class=\"summary\" [innerHTML]=\"summary\"></span>\n </div>\n <div class=\"pagination-actions\">\n <button\n impdcButton\n theme=\"secondary\"\n aria-label=\"First Page\"\n class=\"pagination-first-last-btns\"\n (click)=\"goToExactPage(1)\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left first\"></i>\n <i class=\"fas fa-chevron-left\"></i>\n <!-- 1 -->\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n class=\"previous\"\n aria-label=\"Previous\"\n (click)=\"goToPreviousPage()\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <div class=\"page-change\">\n <input\n impdcInput\n
|
|
132
|
+
args: [{ selector: 'impdc-pagination, div[impdc-pagination]', template: "<div class=\"pagination-container\">\n <div class=\"mobile-pagination\">\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page <= 1\"\n (click)=\"goToPreviousPage()\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n [disabled]=\"page === totalPages\"\n (click)=\"goToNextPage()\">\n <i class=\"fas fa-chevron-right\"></i>\n </button>\n </div>\n\n <div class=\"desktop-pagination\">\n <div>\n <span class=\"summary\" [innerHTML]=\"summary\"></span>\n </div>\n <div class=\"pagination-actions\">\n <button\n impdcButton\n theme=\"secondary\"\n aria-label=\"First Page\"\n class=\"pagination-first-last-btns\"\n (click)=\"goToExactPage(1)\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left first\"></i>\n <i class=\"fas fa-chevron-left\"></i>\n <!-- 1 -->\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n class=\"previous\"\n aria-label=\"Previous\"\n (click)=\"goToPreviousPage()\"\n [disabled]=\"page <= 1\">\n <i class=\"fas fa-chevron-left\"></i>\n </button>\n <div class=\"page-change\">\n <input\n impdcInput\n [(ngModel)]=\"page\"\n maxlength=\"4\"\n (blur)=\"goToExactPageFromEvent($event)\"\n (keydown.enter)=\"preventDefaultAndBlur($event)\" />\n <span class=\"total-pages\"> / {{ totalPages }} </span>\n </div>\n <button\n impdcButton\n theme=\"secondary\"\n aria-label=\"Next\"\n (click)=\"goToNextPage()\"\n [disabled]=\"page >= totalPages\">\n <i class=\"fas fa-chevron-right\"></i>\n </button>\n <button\n impdcButton\n theme=\"secondary\"\n class=\"pagination-first-last-btns\"\n aria-label=\"Last Page\"\n (click)=\"goToExactPage(totalPages)\"\n [disabled]=\"page === totalPages\">\n <i class=\"fas fa-chevron-right\"></i>\n <i class=\"fas fa-chevron-right last\"></i>\n <!-- {{ totalPages }} -->\n </button>\n </div>\n </div>\n</div>\n", styles: [".pagination-container{background-color:var(--impd-color-white);padding:var(--impd-size-3) var(--impd-size-6);gap:1rem;color:var(--impd-color-gray-700, #374151)}@media (min-width: 640px){.pagination-container{padding-left:var(--impd-size-6);padding-right:var(--impd-size-6)}}.mobile-pagination{display:flex;gap:2rem;justify-content:space-between;align-items:center}@media (min-width: 640px){.mobile-pagination{display:none}}.desktop-pagination{display:none}@media (min-width: 640px){.desktop-pagination{display:flex;flex:1 1 0%;align-items:center;justify-content:space-between;gap:2rem;flex-flow:wrap}}.summary{font-size:var(--impd-font-size-sm);line-height:var(--impd-size-5);font-weight:400;color:var(--impd-color-gray-700)}.pagination-actions{display:flex;flex-direction:row;gap:.4rem;flex-flow:wrap}.pagination-actions .first{margin-right:-1.2rem}.pagination-actions .last{margin-left:-1.2rem}.page-change{display:flex;flex-direction:row;align-items:center;gap:.4rem;font-size:var(--impd-size-3_5, 1.4rem)}.page-change .form-control{min-width:4.275rem;max-width:6.3rem;text-align:center}.page-change .total-pages{padding:0 1.2rem}.pagination-first-last-btns{padding-left:1.325rem;padding-right:1.325rem}\n"] }]
|
|
123
133
|
}], propDecorators: { page: [{
|
|
124
134
|
type: Input
|
|
125
135
|
}], perPage: [{
|
|
@@ -131,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
131
141
|
}], goToPage: [{
|
|
132
142
|
type: Output
|
|
133
143
|
}] } });
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/pagination/pagination.component.ts","../../../../../../projects/design-components/src/lib/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { sanitize } from '../../utilities';\n\n/**\n * The `PaginationComponent` (`<impdc-pagination` or `<div impdc-pagination`) is a control for paged content such as tables or lists.\n * To use, import `PaginationModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ModalModule` imports and exports ImpdcFormsModule and [ButtonModule](./?path=/docs/design-components-button).\n */\n@Component({\n  selector: 'impdc-pagination, div[impdc-pagination]',\n  templateUrl: './pagination.component.html',\n  styleUrls: ['./pagination.component.scss']\n})\nexport class PaginationComponent {\n  private _summary =\n    'Showing {firstPageResult} to {lastPageResult} of {total} results';\n\n  /**\n   * The current page.\n   */\n  @Input()\n  public page = 0;\n\n  /**\n   * The number of items shown per page. Items are commonly displayed as rows in a table.\n   */\n  @Input()\n  public perPage = 10;\n\n  /**\n   * The total number of items.\n   */\n  @Input()\n  public total = 0;\n\n  /**\n   * A formattable text summary of pagination data. `{firstPageResult}` The first item within the current page.\n   * `{lastPageResult}` The last item within the current page. `{total}` The total number of items.\n   */\n  @Input()\n  public set summary(summary: string) {\n    this._summary = summary;\n  }\n\n  public get summary(): string {\n    return sanitize(this._summary)\n      .replace('{firstPageResult}', `<b>${this.firstPageResult}</b>`)\n      .replace('{lastPageResult}', `<b>${this.lastPageResult}</b>`)\n      .replace('{total}', `<b>${this.total}</b>`);\n  }\n\n  /**\n   * Emitted when the page number is changed, specifying the target page number.\n   */\n  @Output() public readonly goToPage = new EventEmitter<number>();\n\n  public get totalPages(): number {\n    if (this.total < 1 || this.perPage < 1) {\n      return 0;\n    }\n\n    if (this.total < this.perPage) {\n      return 1;\n    }\n\n    return Math.ceil(this.total / this.perPage);\n  }\n\n  public get firstPageResult(): number {\n    if (this.total < 1 || this.page < 1 || this.perPage < 1) {\n      return 0;\n    }\n\n    if (this.page === 1) {\n      return 1;\n    }\n\n    if (this.page > Math.ceil(this.total / this.perPage)) {\n      return this.total;\n    }\n\n    return (this.page - 1) * this.perPage + 1;\n  }\n\n  public get lastPageResult(): number {\n    if (this.total <= 0 || this.page < 1 || this.perPage < 1) {\n      return 0;\n    }\n\n    if (this.page === 1) {\n      if (this.total < this.perPage) {\n        return this.total;\n      } else {\n        return this.perPage;\n      }\n    }\n\n    if (this.total < this.perPage * this.page) {\n      return this.total;\n    } else {\n      return this.perPage * this.page;\n    }\n  }\n\n  public goToPreviousPage(): void {\n    if (this.page <= 1) {\n      return;\n    }\n\n    const previousPage = this.page - 1;\n    this.page = previousPage;\n\n    this.goToPage.emit(previousPage);\n  }\n\n  public goToNextPage(): void {\n    if (this.page >= this.totalPages) {\n      return;\n    }\n\n    const nextPage = this.page + 1;\n    this.page = nextPage;\n\n    this.goToPage.emit(nextPage);\n  }\n\n  public goToExactPageFromEvent({ target }: FocusEvent): void {\n    this.goToExactPage((target as HTMLInputElement)?.value);\n  }\n\n  public goToExactPage(page: number | string): void {\n    if (!page) {\n      return;\n    }\n\n    let allowedPageNumber = Number(page);\n\n    if (allowedPageNumber < 0) {\n      allowedPageNumber = 1;\n    }\n\n    if (allowedPageNumber > this.totalPages) {\n      allowedPageNumber = this.totalPages;\n    }\n\n    this.page = allowedPageNumber;\n\n    this.goToPage.emit(allowedPageNumber);\n  }\n}\n","<div class=\"pagination-container\">\n  <div class=\"mobile-pagination\">\n    <button\n      impdcButton\n      theme=\"secondary\"\n      [disabled]=\"page <= 1\"\n      (click)=\"goToPreviousPage()\">\n      <i class=\"fas fa-chevron-left\"></i>\n    </button>\n    <button\n      impdcButton\n      theme=\"secondary\"\n      [disabled]=\"page === totalPages\"\n      (click)=\"goToNextPage()\">\n      <i class=\"fas fa-chevron-right\"></i>\n    </button>\n  </div>\n\n  <div class=\"desktop-pagination\">\n    <div>\n      <span class=\"summary\" [innerHTML]=\"summary\"></span>\n    </div>\n    <div class=\"pagination-actions\">\n      <button\n        impdcButton\n        theme=\"secondary\"\n        aria-label=\"First Page\"\n        class=\"pagination-first-last-btns\"\n        (click)=\"goToExactPage(1)\"\n        [disabled]=\"page <= 1\">\n        <i class=\"fas fa-chevron-left first\"></i>\n        <i class=\"fas fa-chevron-left\"></i>\n        <!-- 1 -->\n      </button>\n      <button\n        impdcButton\n        theme=\"secondary\"\n        class=\"previous\"\n        aria-label=\"Previous\"\n        (click)=\"goToPreviousPage()\"\n        [disabled]=\"page <= 1\">\n        <i class=\"fas fa-chevron-left\"></i>\n      </button>\n      <div class=\"page-change\">\n        <input\n          impdcInput\n          maxlength=\"4\"\n          [value]=\"page\"\n          (blur)=\"goToExactPageFromEvent($event)\" />\n        <span class=\"total-pages\"> / {{ totalPages }} </span>\n      </div>\n      <button\n        impdcButton\n        theme=\"secondary\"\n        aria-label=\"Next\"\n        (click)=\"goToNextPage()\"\n        [disabled]=\"page === totalPages\">\n        <i class=\"fas fa-chevron-right\"></i>\n      </button>\n      <button\n        impdcButton\n        theme=\"secondary\"\n        class=\"pagination-first-last-btns\"\n        aria-label=\"Last Page\"\n        (click)=\"goToExactPage(totalPages)\"\n        [disabled]=\"page === totalPages\">\n        <i class=\"fas fa-chevron-right\"></i>\n        <i class=\"fas fa-chevron-right last\"></i>\n        <!-- {{ totalPages }} -->\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/pagination/pagination.component.ts","../../../../../../projects/design-components/src/lib/pagination/pagination.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;;;AAE3C;;;;GAIG;AAMH,MAAM,OAAO,mBAAmB;IALhC;QAMU,aAAQ,GACd,kEAAkE,CAAC;QAErE;;WAEG;QAEI,SAAI,GAAG,CAAC,CAAC;QAEhB;;WAEG;QAEI,YAAO,GAAG,EAAE,CAAC;QAEpB;;WAEG;QAEI,UAAK,GAAG,CAAC,CAAC;QAkBjB;;WAEG;QACuB,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;KAwGjE;IA3HC;;;OAGG;IACH,IACW,OAAO,CAAC,OAAe;QAChC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;IAC1B,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC;aAC3B,OAAO,CAAC,mBAAmB,EAAE,MAAM,IAAI,CAAC,eAAe,MAAM,CAAC;aAC9D,OAAO,CAAC,kBAAkB,EAAE,MAAM,IAAI,CAAC,cAAc,MAAM,CAAC;aAC5D,OAAO,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,KAAK,MAAM,CAAC,CAAC;IAChD,CAAC;IAOD,IAAW,UAAU;QACnB,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,GAAG,CAAC,EAAE;YACtC,OAAO,CAAC,CAAC;SACV;QAED,IAAI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,EAAE;YAC7B,OAAO,CAAC,CAAC;SACV;QAED,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,IAAW,eAAe;QACxB,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,GAAG,CAAC,EAAE;YAClD,OAAO,CAAC,CAAC;SACV;QAED,IAAI,IAAI,KAAK,CAAC,EAAE;YACd,OAAO,CAAC,CAAC;SACV;QAED,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,EAAE;YAC/C,OAAO,IAAI,CAAC,KAAK,CAAC;SACnB;QAED,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACvC,CAAC;IAED,IAAW,cAAc;QACvB,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,GAAG,CAAC,EAAE;YACnD,OAAO,CAAC,CAAC;SACV;QAED,IAAI,IAAI,KAAK,CAAC,EAAE;YACd,IAAI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,EAAE;gBAC7B,OAAO,IAAI,CAAC,KAAK,CAAC;aACnB;iBAAM;gBACL,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;SACF;QAED,IAAI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,EAAE;YACpC,OAAO,IAAI,CAAC,KAAK,CAAC;SACnB;aAAM;YACL,OAAO,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SAC5B;IACH,CAAC;IAEO,eAAe,CAAC,IAAsB;QAC5C,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;QACtC,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,EAAE;YAC3B,OAAO,CAAC,CAAC;SACV;QAED,IAAI,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE;YAC1B,OAAO,IAAI,CAAC,UAAU,CAAC;SACxB;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,gBAAgB;QACrB,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,IAAI,IAAI,IAAI,CAAC,EAAE;YACb,OAAO;SACR;QAED,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,CAAC;QAC9B,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;QAEzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnC,CAAC;IAEM,YAAY;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,IAAI,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;YAC3B,OAAO;SACR;QAED,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QAErB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAEM,sBAAsB,CAAC,EAAE,MAAM,EAAc;QAClD,IAAI,CAAC,aAAa,CAAE,MAA2B,EAAE,KAAK,CAAC,CAAC;IAC1D,CAAC;IAEM,aAAa,CAAC,IAAqB;QACxC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAEvC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAEM,qBAAqB,CAAC,KAAY;QACvC,2BAA2B;QAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;QACtB,KAAK,CAAC,MAA2B,CAAC,IAAI,EAAE,CAAC;IAC5C,CAAC;;iHAhJU,mBAAmB;qGAAnB,mBAAmB,oMCbhC,wsEA0EA;4FD7Da,mBAAmB;kBAL/B,SAAS;+BACE,yCAAyC;8BAY5C,IAAI;sBADV,KAAK;gBAOC,OAAO;sBADb,KAAK;gBAOC,KAAK;sBADX,KAAK;gBAQK,OAAO;sBADjB,KAAK;gBAeoB,QAAQ;sBAAjC,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { sanitize } from '../../utilities';\n\n/**\n * The `PaginationComponent` (`<impdc-pagination` or `<div impdc-pagination`) is a control for paged content such as tables or lists.\n * To use, import `PaginationModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ModalModule` imports and exports ImpdcFormsModule and [ButtonModule](./?path=/docs/design-components-button).\n */\n@Component({\n  selector: 'impdc-pagination, div[impdc-pagination]',\n  templateUrl: './pagination.component.html',\n  styleUrls: ['./pagination.component.scss']\n})\nexport class PaginationComponent {\n  private _summary =\n    'Showing {firstPageResult} to {lastPageResult} of {total} results';\n\n  /**\n   * The current page.\n   */\n  @Input()\n  public page = 0;\n\n  /**\n   * The number of items shown per page. Items are commonly displayed as rows in a table.\n   */\n  @Input()\n  public perPage = 10;\n\n  /**\n   * The total number of items.\n   */\n  @Input()\n  public total = 0;\n\n  /**\n   * A formattable text summary of pagination data. `{firstPageResult}` The first item within the current page.\n   * `{lastPageResult}` The last item within the current page. `{total}` The total number of items.\n   */\n  @Input()\n  public set summary(summary: string) {\n    this._summary = summary;\n  }\n\n  public get summary(): string {\n    return sanitize(this._summary)\n      .replace('{firstPageResult}', `<b>${this.firstPageResult}</b>`)\n      .replace('{lastPageResult}', `<b>${this.lastPageResult}</b>`)\n      .replace('{total}', `<b>${this.total}</b>`);\n  }\n\n  /**\n   * Emitted when the page number is changed, specifying the target page number.\n   */\n  @Output() public readonly goToPage = new EventEmitter<number>();\n\n  public get totalPages(): number {\n    if (this.total < 1 || this.perPage < 1) {\n      return 0;\n    }\n\n    if (this.total < this.perPage) {\n      return 1;\n    }\n\n    return Math.ceil(this.total / this.perPage);\n  }\n\n  public get firstPageResult(): number {\n    const page = this._getPageClamped();\n    if (this.total < 1 || page < 1 || this.perPage < 1) {\n      return 0;\n    }\n\n    if (page === 1) {\n      return 1;\n    }\n\n    if (page > Math.ceil(this.total / this.perPage)) {\n      return this.total;\n    }\n\n    return (page - 1) * this.perPage + 1;\n  }\n\n  public get lastPageResult(): number {\n    const page = this._getPageClamped();\n    if (this.total <= 0 || page < 1 || this.perPage < 1) {\n      return 0;\n    }\n\n    if (page === 1) {\n      if (this.total < this.perPage) {\n        return this.total;\n      } else {\n        return this.perPage;\n      }\n    }\n\n    if (this.total < this.perPage * page) {\n      return this.total;\n    } else {\n      return this.perPage * page;\n    }\n  }\n\n  private _getPageClamped(page?: string | number): number {\n    page = Number(page || this.page || 0);\n    if (isNaN(page) || page < 1) {\n      return 1;\n    }\n\n    if (page > this.totalPages) {\n      return this.totalPages;\n    }\n\n    return page;\n  }\n\n  public goToPreviousPage(): void {\n    const page = this._getPageClamped();\n    if (page <= 1) {\n      return;\n    }\n\n    const previousPage = page - 1;\n    this.page = previousPage;\n\n    this.goToPage.emit(previousPage);\n  }\n\n  public goToNextPage(): void {\n    const page = this._getPageClamped();\n    if (page >= this.totalPages) {\n      return;\n    }\n\n    const nextPage = page + 1;\n    this.page = nextPage;\n\n    this.goToPage.emit(nextPage);\n  }\n\n  public goToExactPageFromEvent({ target }: FocusEvent): void {\n    this.goToExactPage((target as HTMLInputElement)?.value);\n  }\n\n  public goToExactPage(page: number | string): void {\n    this.page = this._getPageClamped(page);\n\n    this.goToPage.emit(this.page);\n  }\n\n  public preventDefaultAndBlur(event: Event) {\n    // prevents PRM form submit\n    event.preventDefault();\n    (event.target as HTMLInputElement).blur();\n  }\n}\n","<div class=\"pagination-container\">\n  <div class=\"mobile-pagination\">\n    <button\n      impdcButton\n      theme=\"secondary\"\n      [disabled]=\"page <= 1\"\n      (click)=\"goToPreviousPage()\">\n      <i class=\"fas fa-chevron-left\"></i>\n    </button>\n    <button\n      impdcButton\n      theme=\"secondary\"\n      [disabled]=\"page === totalPages\"\n      (click)=\"goToNextPage()\">\n      <i class=\"fas fa-chevron-right\"></i>\n    </button>\n  </div>\n\n  <div class=\"desktop-pagination\">\n    <div>\n      <span class=\"summary\" [innerHTML]=\"summary\"></span>\n    </div>\n    <div class=\"pagination-actions\">\n      <button\n        impdcButton\n        theme=\"secondary\"\n        aria-label=\"First Page\"\n        class=\"pagination-first-last-btns\"\n        (click)=\"goToExactPage(1)\"\n        [disabled]=\"page <= 1\">\n        <i class=\"fas fa-chevron-left first\"></i>\n        <i class=\"fas fa-chevron-left\"></i>\n        <!-- 1 -->\n      </button>\n      <button\n        impdcButton\n        theme=\"secondary\"\n        class=\"previous\"\n        aria-label=\"Previous\"\n        (click)=\"goToPreviousPage()\"\n        [disabled]=\"page <= 1\">\n        <i class=\"fas fa-chevron-left\"></i>\n      </button>\n      <div class=\"page-change\">\n        <input\n          impdcInput\n          [(ngModel)]=\"page\"\n          maxlength=\"4\"\n          (blur)=\"goToExactPageFromEvent($event)\"\n          (keydown.enter)=\"preventDefaultAndBlur($event)\" />\n        <span class=\"total-pages\"> / {{ totalPages }} </span>\n      </div>\n      <button\n        impdcButton\n        theme=\"secondary\"\n        aria-label=\"Next\"\n        (click)=\"goToNextPage()\"\n        [disabled]=\"page >= totalPages\">\n        <i class=\"fas fa-chevron-right\"></i>\n      </button>\n      <button\n        impdcButton\n        theme=\"secondary\"\n        class=\"pagination-first-last-btns\"\n        aria-label=\"Last Page\"\n        (click)=\"goToExactPage(totalPages)\"\n        [disabled]=\"page === totalPages\">\n        <i class=\"fas fa-chevron-right\"></i>\n        <i class=\"fas fa-chevron-right last\"></i>\n        <!-- {{ totalPages }} -->\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
3
4
|
import { ButtonModule } from '../button';
|
|
4
5
|
import { ImpdcFormsModule } from '../form-field';
|
|
5
6
|
import { PaginationComponent } from './pagination.component';
|
|
@@ -8,14 +9,14 @@ export class PaginationModule {
|
|
|
8
9
|
constructor() { }
|
|
9
10
|
}
|
|
10
11
|
PaginationModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PaginationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
-
PaginationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: PaginationModule, declarations: [PaginationComponent], imports: [CommonModule, ButtonModule, ImpdcFormsModule], exports: [ButtonModule, ImpdcFormsModule, PaginationComponent] });
|
|
12
|
-
PaginationModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PaginationModule, imports: [CommonModule, ButtonModule, ImpdcFormsModule, ButtonModule, ImpdcFormsModule] });
|
|
12
|
+
PaginationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: PaginationModule, declarations: [PaginationComponent], imports: [CommonModule, ButtonModule, FormsModule, ImpdcFormsModule], exports: [ButtonModule, ImpdcFormsModule, PaginationComponent] });
|
|
13
|
+
PaginationModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PaginationModule, imports: [CommonModule, ButtonModule, FormsModule, ImpdcFormsModule, ButtonModule, ImpdcFormsModule] });
|
|
13
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PaginationModule, decorators: [{
|
|
14
15
|
type: NgModule,
|
|
15
16
|
args: [{
|
|
16
|
-
imports: [CommonModule, ButtonModule, ImpdcFormsModule],
|
|
17
|
+
imports: [CommonModule, ButtonModule, FormsModule, ImpdcFormsModule],
|
|
17
18
|
declarations: [PaginationComponent],
|
|
18
19
|
exports: [ButtonModule, ImpdcFormsModule, PaginationComponent]
|
|
19
20
|
}]
|
|
20
21
|
}], ctorParameters: function () { return []; } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3BhZ2luYXRpb24vcGFnaW5hdGlvbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU83RCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLGdCQUFlLENBQUM7OzhHQURMLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQUhaLG1CQUFtQixhQUR4QixZQUFZLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsYUFFekQsWUFBWSxFQUFFLGdCQUFnQixFQUFFLG1CQUFtQjsrR0FFbEQsZ0JBQWdCLFlBSmpCLFlBQVksRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUV6RCxZQUFZLEVBQUUsZ0JBQWdCOzRGQUU3QixnQkFBZ0I7a0JBTDVCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLENBQUM7b0JBQ3BFLFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNuQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsbUJBQW1CLENBQUM7aUJBQy9EIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2J1dHRvbic7XG5pbXBvcnQgeyBJbXBkY0Zvcm1zTW9kdWxlIH0gZnJvbSAnLi4vZm9ybS1maWVsZCc7XG5pbXBvcnQgeyBQYWdpbmF0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9wYWdpbmF0aW9uLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJ1dHRvbk1vZHVsZSwgRm9ybXNNb2R1bGUsIEltcGRjRm9ybXNNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtQYWdpbmF0aW9uQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0J1dHRvbk1vZHVsZSwgSW1wZGNGb3Jtc01vZHVsZSwgUGFnaW5hdGlvbkNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgUGFnaW5hdGlvbk1vZHVsZSB7XG4gIGNvbnN0cnVjdG9yKCkge31cbn1cbiJdfQ==
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
-
import { DropdownComponent
|
|
2
|
+
import { DropdownComponent } from '../lib';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class InteractionService {
|
|
5
5
|
constructor() {
|
|
6
6
|
this._interactables = [];
|
|
7
|
+
this._backdropQueue = [];
|
|
7
8
|
}
|
|
8
9
|
get showBackdrop() {
|
|
9
|
-
return this.
|
|
10
|
+
return this._backdropQueue.length > 0;
|
|
10
11
|
}
|
|
11
12
|
registerBackdrop(modalBackdrop) {
|
|
12
13
|
// WARNING: there should only be 1 backdrop component, preferably loaded in the body
|
|
@@ -28,8 +29,12 @@ export class InteractionService {
|
|
|
28
29
|
}
|
|
29
30
|
}
|
|
30
31
|
add(interactable) {
|
|
31
|
-
|
|
32
|
-
|
|
32
|
+
const interactableId = interactable.interactableId;
|
|
33
|
+
if (interactableId > 0) {
|
|
34
|
+
if (!this._interactables.some(i => i.interactableId === interactableId)) {
|
|
35
|
+
this._interactables.push(interactable);
|
|
36
|
+
}
|
|
37
|
+
return interactableId;
|
|
33
38
|
}
|
|
34
39
|
this._interactables.push(interactable);
|
|
35
40
|
return this._interactables.length;
|
|
@@ -39,6 +44,7 @@ export class InteractionService {
|
|
|
39
44
|
return;
|
|
40
45
|
}
|
|
41
46
|
this._interactables.splice(interactableId - 1, 1);
|
|
47
|
+
this.dequeueBackdrop(interactableId);
|
|
42
48
|
}
|
|
43
49
|
toggle(interactable) {
|
|
44
50
|
if (interactable.interactableId <= 0 || interactable.show) {
|
|
@@ -52,6 +58,17 @@ export class InteractionService {
|
|
|
52
58
|
}
|
|
53
59
|
return true;
|
|
54
60
|
}
|
|
61
|
+
queueBackdrop(interactableId) {
|
|
62
|
+
if (!this._backdropQueue.includes(interactableId)) {
|
|
63
|
+
this._backdropQueue.push(interactableId);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
dequeueBackdrop(interactableId) {
|
|
67
|
+
const interactableIdIndex = this._backdropQueue.indexOf(interactableId);
|
|
68
|
+
if (interactableIdIndex !== -1) {
|
|
69
|
+
this._backdropQueue.splice(interactableIdIndex, 1);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
55
72
|
}
|
|
56
73
|
InteractionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InteractionService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
57
74
|
InteractionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InteractionService, providedIn: 'root' });
|
|
@@ -61,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
61
78
|
providedIn: 'root'
|
|
62
79
|
}]
|
|
63
80
|
}] });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJhY3Rpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9zZXJ2aWNlcy9pbnRlcmFjdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFxQixpQkFBaUIsRUFBa0IsTUFBTSxRQUFRLENBQUM7O0FBTzlFLE1BQU0sT0FBTyxrQkFBa0I7SUFIL0I7UUFLVSxtQkFBYyxHQUE0QixFQUFFLENBQUM7UUFDN0MsbUJBQWMsR0FBYSxFQUFFLENBQUM7S0F1RXZDO0lBckVDLElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxhQUFnQztRQUMvQyxvRkFBb0Y7UUFDcEYsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxhQUFhLENBQUM7U0FDaEM7YUFBTSxJQUFJLElBQUksQ0FBQyxTQUFTLEtBQUssYUFBYSxFQUFFO1lBQzNDLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxhQUFhLENBQUM7WUFDL0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUU7Z0JBQ3hCLHVEQUF1RDtnQkFDdkQsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDO2FBQzFCO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsa0JBQWtCLENBQUMsYUFBZ0M7UUFDakQsSUFBSSxJQUFJLENBQUMsU0FBUyxLQUFLLGFBQWEsRUFBRTtZQUNwQyxJQUFJLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztTQUM1QjtJQUNILENBQUM7SUFFRCxHQUFHLENBQUMsWUFBbUM7UUFDckMsTUFBTSxjQUFjLEdBQUcsWUFBWSxDQUFDLGNBQWMsQ0FBQztRQUNuRCxJQUFJLGNBQWMsR0FBRyxDQUFDLEVBQUU7WUFDdEIsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLGNBQWMsS0FBSyxjQUFjLENBQUMsRUFBRTtnQkFDdkUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7YUFDeEM7WUFDRCxPQUFPLGNBQWMsQ0FBQztTQUN2QjtRQUNELElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3ZDLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUM7SUFDcEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFzQjtRQUMzQixJQUFJLGNBQWMsSUFBSSxDQUFDLElBQUksY0FBYyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFO1lBQ3RFLE9BQU87U0FDUjtRQUNELElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLGNBQWMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsTUFBTSxDQUFDLFlBQW1DO1FBQ3hDLElBQUksWUFBWSxDQUFDLGNBQWMsSUFBSSxDQUFDLElBQUksWUFBWSxDQUFDLElBQUksRUFBRTtZQUN6RCx3REFBd0Q7WUFDeEQsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUNELEtBQUssTUFBTSxpQkFBaUIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUN6RSxJQUFJLGlCQUFpQixZQUFZLGlCQUFpQixFQUFFO2dCQUNsRCxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUMxQjtTQUNGO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsYUFBYSxDQUFDLGNBQXNCO1FBQ2xDLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsRUFBRTtZQUNqRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztTQUMxQztJQUNILENBQUM7SUFFRCxlQUFlLENBQUMsY0FBc0I7UUFDcEMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUN4RSxJQUFJLG1CQUFtQixLQUFLLENBQUMsQ0FBQyxFQUFFO1lBQzlCLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLG1CQUFtQixFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQ3BEO0lBQ0gsQ0FBQzs7Z0hBekVVLGtCQUFrQjtvSEFBbEIsa0JBQWtCLGNBRmpCLE1BQU07NEZBRVAsa0JBQWtCO2tCQUg5QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhY2tkcm9wQ29tcG9uZW50LCBEcm9wZG93bkNvbXBvbmVudCwgTW9kYWxDb21wb25lbnQgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgdHlwZSBJbnRlcmFjdGFibGVDb21wb25lbnQgPSBNb2RhbENvbXBvbmVudCB8IERyb3Bkb3duQ29tcG9uZW50O1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBJbnRlcmFjdGlvblNlcnZpY2Uge1xuICBwcml2YXRlIF9iYWNrZHJvcD86IEJhY2tkcm9wQ29tcG9uZW50O1xuICBwcml2YXRlIF9pbnRlcmFjdGFibGVzOiBJbnRlcmFjdGFibGVDb21wb25lbnRbXSA9IFtdO1xuICBwcml2YXRlIF9iYWNrZHJvcFF1ZXVlOiBudW1iZXJbXSA9IFtdO1xuXG4gIGdldCBzaG93QmFja2Ryb3AoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2JhY2tkcm9wUXVldWUubGVuZ3RoID4gMDtcbiAgfVxuXG4gIHJlZ2lzdGVyQmFja2Ryb3AobW9kYWxCYWNrZHJvcDogQmFja2Ryb3BDb21wb25lbnQpIHtcbiAgICAvLyBXQVJOSU5HOiB0aGVyZSBzaG91bGQgb25seSBiZSAxIGJhY2tkcm9wIGNvbXBvbmVudCwgcHJlZmVyYWJseSBsb2FkZWQgaW4gdGhlIGJvZHlcbiAgICBpZiAoIXRoaXMuX2JhY2tkcm9wKSB7XG4gICAgICB0aGlzLl9iYWNrZHJvcCA9IG1vZGFsQmFja2Ryb3A7XG4gICAgfSBlbHNlIGlmICh0aGlzLl9iYWNrZHJvcCAhPT0gbW9kYWxCYWNrZHJvcCkge1xuICAgICAgdGhpcy5fYmFja2Ryb3AuaW52YWxpZGF0ZSgpO1xuICAgICAgdGhpcy5fYmFja2Ryb3AgPSBtb2RhbEJhY2tkcm9wO1xuICAgICAgaWYgKCFtb2RhbEJhY2tkcm9wLnZhbGlkKSB7XG4gICAgICAgIC8vIHdlIGludmFsaWRhdGVkIGFuZCBzZXQgYmFja2Ryb3AgdG8gdGhlIHNhbWUgYmFja2Ryb3BcbiAgICAgICAgbW9kYWxCYWNrZHJvcC52YWxpZGF0ZSgpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHVucmVnaXN0ZXJCYWNrZHJvcChtb2RhbEJhY2tkcm9wOiBCYWNrZHJvcENvbXBvbmVudCkge1xuICAgIGlmICh0aGlzLl9iYWNrZHJvcCA9PT0gbW9kYWxCYWNrZHJvcCkge1xuICAgICAgdGhpcy5fYmFja2Ryb3AgPSB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG5cbiAgYWRkKGludGVyYWN0YWJsZTogSW50ZXJhY3RhYmxlQ29tcG9uZW50KTogbnVtYmVyIHtcbiAgICBjb25zdCBpbnRlcmFjdGFibGVJZCA9IGludGVyYWN0YWJsZS5pbnRlcmFjdGFibGVJZDtcbiAgICBpZiAoaW50ZXJhY3RhYmxlSWQgPiAwKSB7XG4gICAgICBpZiAoIXRoaXMuX2ludGVyYWN0YWJsZXMuc29tZShpID0+IGkuaW50ZXJhY3RhYmxlSWQgPT09IGludGVyYWN0YWJsZUlkKSkge1xuICAgICAgICB0aGlzLl9pbnRlcmFjdGFibGVzLnB1c2goaW50ZXJhY3RhYmxlKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBpbnRlcmFjdGFibGVJZDtcbiAgICB9XG4gICAgdGhpcy5faW50ZXJhY3RhYmxlcy5wdXNoKGludGVyYWN0YWJsZSk7XG4gICAgcmV0dXJuIHRoaXMuX2ludGVyYWN0YWJsZXMubGVuZ3RoO1xuICB9XG5cbiAgcmVtb3ZlKGludGVyYWN0YWJsZUlkOiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAoaW50ZXJhY3RhYmxlSWQgPD0gMCB8fCBpbnRlcmFjdGFibGVJZCA+IHRoaXMuX2ludGVyYWN0YWJsZXMubGVuZ3RoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuX2ludGVyYWN0YWJsZXMuc3BsaWNlKGludGVyYWN0YWJsZUlkIC0gMSwgMSk7XG4gICAgdGhpcy5kZXF1ZXVlQmFja2Ryb3AoaW50ZXJhY3RhYmxlSWQpO1xuICB9XG5cbiAgdG9nZ2xlKGludGVyYWN0YWJsZTogSW50ZXJhY3RhYmxlQ29tcG9uZW50KTogYm9vbGVhbiB7XG4gICAgaWYgKGludGVyYWN0YWJsZS5pbnRlcmFjdGFibGVJZCA8PSAwIHx8IGludGVyYWN0YWJsZS5zaG93KSB7XG4gICAgICAvLyBvdGhlciBpbnRlcmFjdGFibGVzIGRvbid0IG5lZWQgdG8gYmUgYWx0ZXJlZC9ub3RpZmllZFxuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGNvbnN0IG90aGVySW50ZXJhY3RhYmxlIG9mIHRoaXMuX2ludGVyYWN0YWJsZXMuZmlsdGVyKG9pID0+IG9pLnNob3cpKSB7XG4gICAgICBpZiAob3RoZXJJbnRlcmFjdGFibGUgaW5zdGFuY2VvZiBEcm9wZG93bkNvbXBvbmVudCkge1xuICAgICAgICBvdGhlckludGVyYWN0YWJsZS5oaWRlKCk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgcXVldWVCYWNrZHJvcChpbnRlcmFjdGFibGVJZDogbnVtYmVyKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLl9iYWNrZHJvcFF1ZXVlLmluY2x1ZGVzKGludGVyYWN0YWJsZUlkKSkge1xuICAgICAgdGhpcy5fYmFja2Ryb3BRdWV1ZS5wdXNoKGludGVyYWN0YWJsZUlkKTtcbiAgICB9XG4gIH1cblxuICBkZXF1ZXVlQmFja2Ryb3AoaW50ZXJhY3RhYmxlSWQ6IG51bWJlcik6IHZvaWQge1xuICAgIGNvbnN0IGludGVyYWN0YWJsZUlkSW5kZXggPSB0aGlzLl9iYWNrZHJvcFF1ZXVlLmluZGV4T2YoaW50ZXJhY3RhYmxlSWQpO1xuICAgIGlmIChpbnRlcmFjdGFibGVJZEluZGV4ICE9PSAtMSkge1xuICAgICAgdGhpcy5fYmFja2Ryb3BRdWV1ZS5zcGxpY2UoaW50ZXJhY3RhYmxlSWRJbmRleCwgMSk7XG4gICAgfVxuICB9XG59XG4iXX0=
|