@flywheel-io/vision 1.0.3 → 1.1.0
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/components/alert/alert.component.d.ts +1 -1
- package/components/button-toggle/button-toggle-item/button-toggle-item.component.d.ts +18 -0
- package/components/button-toggle/button-toggle.component.d.ts +22 -0
- package/components/button-toggle/button-toggle.module.d.ts +10 -0
- package/components/card/card.component.d.ts +1 -1
- package/components/chip/chip.component.d.ts +2 -2
- package/components/dialog/dialog-confirm.component.d.ts +2 -2
- package/components/dialog/dialog-simple.component.d.ts +2 -2
- package/components/dialog/dialog.component.d.ts +1 -1
- package/components/legacy/notification/notification.module.d.ts +3 -4
- package/components/menu/menu.component.d.ts +3 -2
- package/components/paginator/paginator-advanced/paginator-advanced.component.d.ts +32 -0
- package/components/paginator/paginator.component.d.ts +40 -0
- package/components/paginator/paginator.model.d.ts +8 -0
- package/components/paginator/paginator.module.d.ts +14 -0
- package/components/select-menu/multi-select-menu/multi-select-menu.component.d.ts +13 -7
- package/components/select-menu/select-menu.component.d.ts +39 -8
- package/components/stepper/stepper.component.d.ts +1 -1
- package/components/switch/switch.component.d.ts +20 -0
- package/components/switch/switch.module.d.ts +8 -0
- package/components/tabs/tab/tab.component.d.ts +1 -1
- package/components/text-input/text-input.component.d.ts +4 -1
- package/esm2020/components/alert/alert.component.mjs +1 -1
- package/esm2020/components/button-toggle/button-toggle-item/button-toggle-item.component.mjs +49 -0
- package/esm2020/components/button-toggle/button-toggle.component.mjs +91 -0
- package/esm2020/components/button-toggle/button-toggle.module.mjs +33 -0
- package/esm2020/components/card/card.component.mjs +1 -1
- package/esm2020/components/chip/chip.component.mjs +1 -1
- package/esm2020/components/dialog/dialog-confirm.component.mjs +1 -1
- package/esm2020/components/dialog/dialog-simple.component.mjs +1 -1
- package/esm2020/components/dialog/dialog.component.mjs +1 -1
- package/esm2020/components/legacy/notification/notification-container/notification-container.component.mjs +4 -4
- package/esm2020/components/legacy/notification/notification.module.mjs +5 -9
- package/esm2020/components/menu/menu-container/menu-container.component.mjs +1 -1
- package/esm2020/components/menu/menu-item/menu-item.component.mjs +2 -2
- package/esm2020/components/menu/menu.component.mjs +8 -4
- package/esm2020/components/paginator/paginator-advanced/paginator-advanced.component.mjs +123 -0
- package/esm2020/components/paginator/paginator.component.mjs +133 -0
- package/esm2020/components/paginator/paginator.model.mjs +2 -0
- package/esm2020/components/paginator/paginator.module.mjs +49 -0
- package/esm2020/components/select-menu/multi-select-menu/multi-select-menu.component.mjs +59 -25
- package/esm2020/components/select-menu/select-menu.component.mjs +84 -21
- package/esm2020/components/snackbar/snackbar-container/snackbar-container.component.mjs +2 -2
- package/esm2020/components/stepper/step.component.mjs +2 -2
- package/esm2020/components/stepper/stepper.component.mjs +1 -1
- package/esm2020/components/switch/switch.component.mjs +54 -0
- package/esm2020/components/switch/switch.module.mjs +24 -0
- package/esm2020/components/tabs/tab/tab.component.mjs +1 -1
- package/esm2020/components/text-input/text-input.component.mjs +16 -5
- package/esm2020/components/tooltip/tooltip-panel/tooltip-panel.component.mjs +2 -2
- package/esm2020/components/tooltip/tooltip.component.mjs +3 -3
- package/esm2020/public-api.mjs +9 -1
- package/fesm2015/flywheel-io-vision.mjs +889 -309
- package/fesm2015/flywheel-io-vision.mjs.map +1 -1
- package/fesm2020/flywheel-io-vision.mjs +889 -309
- package/fesm2020/flywheel-io-vision.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +8 -0
- package/scss/icons/icons.scss +1 -2
- package/components/button-group/button-group.component.d.ts +0 -8
- package/components/button-group/button-group.module.d.ts +0 -7
- package/esm2020/components/button-group/button-group.component.mjs +0 -32
- package/esm2020/components/button-group/button-group.module.mjs +0 -20
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
2
|
-
import { Component, ContentChildren, Input, } from '@angular/core';
|
|
2
|
+
import { Component, ContentChildren, EventEmitter, Input, Output, } from '@angular/core';
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
4
|
import { FwMenuItemComponent } from './menu-item/menu-item.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -13,10 +13,11 @@ export class FwMenuComponent {
|
|
|
13
13
|
this.useCheckbox = false;
|
|
14
14
|
this.openWidth = 'inherit';
|
|
15
15
|
this.collapsedWidth = '44px';
|
|
16
|
+
// eslint-disable-next-line @angular-eslint/no-output-native
|
|
17
|
+
this.change = new EventEmitter();
|
|
16
18
|
this._filterText = '';
|
|
17
19
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
18
20
|
this.onChange = (value) => {
|
|
19
|
-
this.updateLayout();
|
|
20
21
|
};
|
|
21
22
|
this.onTouched = () => {
|
|
22
23
|
};
|
|
@@ -41,6 +42,7 @@ export class FwMenuComponent {
|
|
|
41
42
|
writeValue(value) {
|
|
42
43
|
this.value = value;
|
|
43
44
|
this.onChange(this.value);
|
|
45
|
+
this.change.emit(this.value);
|
|
44
46
|
this.updateLayout();
|
|
45
47
|
}
|
|
46
48
|
registerOnChange(fn) {
|
|
@@ -104,7 +106,7 @@ export class FwMenuComponent {
|
|
|
104
106
|
}
|
|
105
107
|
}
|
|
106
108
|
FwMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
-
FwMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwMenuComponent, selector: "fw-menu", inputs: { disabled: "disabled", size: "size", variant: "variant", collapsed: "collapsed", multiSelect: "multiSelect", useCheckbox: "useCheckbox", openWidth: "openWidth", collapsedWidth: "collapsedWidth", value: "value" }, providers: [{
|
|
109
|
+
FwMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwMenuComponent, selector: "fw-menu", inputs: { disabled: "disabled", size: "size", variant: "variant", collapsed: "collapsed", multiSelect: "multiSelect", useCheckbox: "useCheckbox", openWidth: "openWidth", collapsedWidth: "collapsedWidth", value: "value" }, outputs: { change: "change" }, providers: [{
|
|
108
110
|
provide: NG_VALUE_ACCESSOR,
|
|
109
111
|
useExisting: FwMenuComponent,
|
|
110
112
|
multi: true,
|
|
@@ -160,8 +162,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
160
162
|
type: Input
|
|
161
163
|
}], value: [{
|
|
162
164
|
type: Input
|
|
165
|
+
}], change: [{
|
|
166
|
+
type: Output
|
|
163
167
|
}], menuItems: [{
|
|
164
168
|
type: ContentChildren,
|
|
165
169
|
args: [FwMenuItemComponent]
|
|
166
170
|
}] } });
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../src/components/menu/menu.component.ts","../../../../../src/components/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  Input,\n  OnChanges,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwMenuItemComponent } from './menu-item/menu-item.component';\n\n@Component({\n  selector: 'fw-menu',\n  templateUrl: './menu.component.html',\n  styleUrls: ['./menu.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: FwMenuComponent,\n    multi: true,\n  }],\n  animations: [\n    trigger('openClose', [\n      // ...\n      state('open', style({\n        width: '{{openWidth}}',\n      }), { params: { openWidth: '200px' } }),\n      state('closed', style({\n        width: '{{collapsedWidth}}',\n      }), { params: { collapsedWidth: '44px' } }),\n      transition('open <=> closed', [\n        animate('.33s ease-in-out'),\n      ]),\n    ]),\n  ],\n})\nexport class FwMenuComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @Input() disabled = false;\n  @Input() size?: 'default' | 'compact' = 'default';\n  @Input() variant?: 'default' | 'modern' | 'button' = 'default';\n  @Input() collapsed?: boolean = false;\n  @Input() multiSelect?: boolean = false;\n  @Input() useCheckbox?: boolean = false;\n  @Input() openWidth?: string = 'inherit';\n  @Input() collapsedWidth?: string = '44px';\n  @Input() value?: string | string[];\n  @ContentChildren(FwMenuItemComponent) menuItems: QueryList<FwMenuItemComponent>;\n  private _filterText: string = '';\n\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (value: string | string[]): void => {\n    this.updateLayout();\n  };\n\n  onTouched = (): void => {\n  };\n\n\n  private subscriptions: Subscription[] = [];\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.updateLayout();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.menuItems.forEach(item => {\n      const sub = item.click.subscribe(value => this.handleSelect(value));\n      this.subscriptions.push(sub);\n    });\n    this.updateLayout();\n  }\n\n  writeValue(value: string | string[]): void {\n    this.value = value;\n    this.onChange(this.value);\n    this.updateLayout();\n  }\n\n  registerOnChange(fn: (value: string | string[]) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  setFilter(filterText: string): void {\n    this._filterText = filterText;\n    this.updateLayout();\n  }\n\n  handleSelect(value: string): void {\n    if (this.multiSelect) {\n      const newValues = [...this.value];\n      if (newValues.indexOf(value) >= 0) {\n        newValues.splice(newValues.indexOf(value), 1);\n      } else {\n        newValues.push(value);\n      }\n      this.writeValue(newValues);\n    } else {\n      this.writeValue(value);\n    }\n  }\n\n  updateLayout(): void {\n    if (this.menuItems) {\n      this.menuItems.forEach(item => {\n        if (this.size !== undefined) {\n          item.size = this.size;\n        }\n        if (this.variant !== undefined) {\n          item.variant = this.variant;\n        }\n        if (this.collapsed !== undefined) {\n          item.collapsed = this.collapsed;\n        }\n        if (this.useCheckbox !== undefined) {\n          item.showCheckbox = this.useCheckbox;\n        }\n        if (this.multiSelect !== undefined) {\n          item.multiSelect = this.multiSelect;\n        }\n        item.disabled = this.disabled;\n        if (this.value) {\n          item.selected = this.value === item.value || this.value.includes(item.value);\n        }\n        if (this._filterText && this._filterText.length > 0 && item.title) {\n          item.hidden = !item.title.toLowerCase().includes(this._filterText.toLowerCase());\n        } else {\n          item.hidden = false;\n        }\n      });\n    }\n  }\n}\n","<div\n  class=\"fw-menu\"\n  [@openClose]=\"{value: collapsed?'closed':'open', params: {openWidth: openWidth || 'inherit', collapsedWidth: collapsedWidth || '44px'}}\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../src/components/menu/menu.component.ts","../../../../../src/components/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwMenuItemComponent } from './menu-item/menu-item.component';\n\n@Component({\n  selector: 'fw-menu',\n  templateUrl: './menu.component.html',\n  styleUrls: ['./menu.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: FwMenuComponent,\n    multi: true,\n  }],\n  animations: [\n    trigger('openClose', [\n      // ...\n      state('open', style({\n        width: '{{openWidth}}',\n      }), { params: { openWidth: '200px' } }),\n      state('closed', style({\n        width: '{{collapsedWidth}}',\n      }), { params: { collapsedWidth: '44px' } }),\n      transition('open <=> closed', [\n        animate('.33s ease-in-out'),\n      ]),\n    ]),\n  ],\n})\nexport class FwMenuComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @Input() disabled = false;\n  @Input() size?: 'default' | 'compact' = 'default';\n  @Input() variant?: 'default' | 'modern' | 'button' = 'default';\n  @Input() collapsed?: boolean = false;\n  @Input() multiSelect?: boolean = false;\n  @Input() useCheckbox?: boolean = false;\n  @Input() openWidth?: string = 'inherit';\n  @Input() collapsedWidth?: string = '44px';\n  @Input() value?: string | string[];\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() change: EventEmitter<string | string[]> = new EventEmitter<string | string[]>();\n  @ContentChildren(FwMenuItemComponent) menuItems: QueryList<FwMenuItemComponent>;\n  private _filterText: string = '';\n\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (value: string | string[]): void => {\n  };\n\n  onTouched = (): void => {\n  };\n\n\n  private subscriptions: Subscription[] = [];\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.updateLayout();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.menuItems.forEach(item => {\n      const sub = item.click.subscribe(value => this.handleSelect(value));\n      this.subscriptions.push(sub);\n    });\n    this.updateLayout();\n  }\n\n  writeValue(value: string | string[]): void {\n    this.value = value;\n    this.onChange(this.value);\n    this.change.emit(this.value);\n    this.updateLayout();\n  }\n\n  registerOnChange(fn: (value: string | string[]) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  setFilter(filterText: string): void {\n    this._filterText = filterText;\n    this.updateLayout();\n  }\n\n  handleSelect(value: string): void {\n    if (this.multiSelect) {\n      const newValues = [...this.value];\n      if (newValues.indexOf(value) >= 0) {\n        newValues.splice(newValues.indexOf(value), 1);\n      } else {\n        newValues.push(value);\n      }\n      this.writeValue(newValues);\n    } else {\n      this.writeValue(value);\n    }\n  }\n\n  updateLayout(): void {\n    if (this.menuItems) {\n      this.menuItems.forEach(item => {\n        if (this.size !== undefined) {\n          item.size = this.size;\n        }\n        if (this.variant !== undefined) {\n          item.variant = this.variant;\n        }\n        if (this.collapsed !== undefined) {\n          item.collapsed = this.collapsed;\n        }\n        if (this.useCheckbox !== undefined) {\n          item.showCheckbox = this.useCheckbox;\n        }\n        if (this.multiSelect !== undefined) {\n          item.multiSelect = this.multiSelect;\n        }\n        item.disabled = this.disabled;\n        if (this.value) {\n          item.selected = this.value === item.value || this.value.includes(item.value);\n        }\n        if (this._filterText && this._filterText.length > 0 && item.title) {\n          item.hidden = !item.title.toLowerCase().includes(this._filterText.toLowerCase());\n        } else {\n          item.hidden = false;\n        }\n      });\n    }\n  }\n}\n","<div\n  class=\"fw-menu\"\n  [@openClose]=\"{value: collapsed?'closed':'open', params: {openWidth: openWidth || 'inherit', collapsedWidth: collapsedWidth || '44px'}}\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
import * as i3 from "../../icon/icon.component";
|
|
6
|
+
import * as i4 from "../../menu/menu-item/menu-item.component";
|
|
7
|
+
import * as i5 from "../../select-menu/select-menu.component";
|
|
8
|
+
export class FwPaginatorAdvancedComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.disabled = false;
|
|
11
|
+
this.showNext = true;
|
|
12
|
+
this.showPrevious = true;
|
|
13
|
+
this.showFirst = false;
|
|
14
|
+
this.showLast = false;
|
|
15
|
+
this.pageIndex = 0;
|
|
16
|
+
this.pageSizeOptions = [10, 25, 50, 100];
|
|
17
|
+
this.length = 0;
|
|
18
|
+
this.alignment = 'center';
|
|
19
|
+
this.selectorTitle = 'Items per page:';
|
|
20
|
+
this._pageSize = 10;
|
|
21
|
+
this.page = new EventEmitter();
|
|
22
|
+
}
|
|
23
|
+
get pageSize() {
|
|
24
|
+
return this._pageSize;
|
|
25
|
+
}
|
|
26
|
+
set pageSize(newSize) {
|
|
27
|
+
this._pageSize = parseInt(newSize.toString());
|
|
28
|
+
this.pageIndex = 0;
|
|
29
|
+
const pageEvt = this.buildPageEvent(0);
|
|
30
|
+
this.page.emit(pageEvt);
|
|
31
|
+
}
|
|
32
|
+
buildPageEvent(pageIndex) {
|
|
33
|
+
return {
|
|
34
|
+
length: this.length,
|
|
35
|
+
pageSize: this.pageSize,
|
|
36
|
+
pageIndex: pageIndex,
|
|
37
|
+
previousPageIndex: this.pageIndex,
|
|
38
|
+
rowIndexStart: this.getRowIndexStart(pageIndex),
|
|
39
|
+
rowIndexEnd: this.getRowIndexEnd(pageIndex),
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
firstPage() {
|
|
43
|
+
const evt = this.buildPageEvent(1);
|
|
44
|
+
this.pageIndex = 0;
|
|
45
|
+
this.page.emit(evt);
|
|
46
|
+
}
|
|
47
|
+
lastPage() {
|
|
48
|
+
const evt = this.buildPageEvent(this.getNumberOfPages());
|
|
49
|
+
this.pageIndex = this.getNumberOfPages() - 1;
|
|
50
|
+
this.page.emit(evt);
|
|
51
|
+
}
|
|
52
|
+
nextPage() {
|
|
53
|
+
if (this.hasNextPage()) {
|
|
54
|
+
const evt = this.buildPageEvent(this.pageIndex + 1);
|
|
55
|
+
this.pageIndex++;
|
|
56
|
+
this.page.emit(evt);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
previousPage() {
|
|
60
|
+
if (this.hasPreviousPage()) {
|
|
61
|
+
const evt = this.buildPageEvent(this.pageIndex - 1);
|
|
62
|
+
this.pageIndex--;
|
|
63
|
+
this.page.emit(evt);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
setPage(pageNumber) {
|
|
67
|
+
const evt = this.buildPageEvent(pageNumber);
|
|
68
|
+
this.pageIndex = pageNumber;
|
|
69
|
+
this.page.emit(evt);
|
|
70
|
+
}
|
|
71
|
+
getNumberOfPages() {
|
|
72
|
+
return Math.ceil(this.length / this.pageSize);
|
|
73
|
+
}
|
|
74
|
+
getRowIndexStart(pageIndex) {
|
|
75
|
+
const index = pageIndex !== undefined ? pageIndex : this.pageIndex;
|
|
76
|
+
return index * this.pageSize;
|
|
77
|
+
}
|
|
78
|
+
getRowIndexEnd(pageIndex) {
|
|
79
|
+
const index = pageIndex !== undefined ? pageIndex : this.pageIndex;
|
|
80
|
+
let indexEnd = (index * this.pageSize) + this.pageSize - 1;
|
|
81
|
+
if (indexEnd > this.length) {
|
|
82
|
+
indexEnd = this.length - 1;
|
|
83
|
+
}
|
|
84
|
+
return indexEnd;
|
|
85
|
+
}
|
|
86
|
+
hasNextPage() {
|
|
87
|
+
return (this.pageIndex !== this.getNumberOfPages() - 1);
|
|
88
|
+
}
|
|
89
|
+
hasPreviousPage() {
|
|
90
|
+
return (this.pageIndex > 0);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
FwPaginatorAdvancedComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorAdvancedComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
+
FwPaginatorAdvancedComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwPaginatorAdvancedComponent, selector: "fw-paginator-advanced", inputs: { disabled: "disabled", showNext: "showNext", showPrevious: "showPrevious", showFirst: "showFirst", showLast: "showLast", pageIndex: "pageIndex", pageSizeOptions: "pageSizeOptions", length: "length", alignment: "alignment", selectorTitle: "selectorTitle", pageSize: "pageSize" }, outputs: { page: "page" }, ngImport: i0, template: "<div [ngClass]=\"['paginator', alignment]\">\n <div class=\"pages-selector\">\n <div>\n <p class=\"vision-p2\" [ngClass]=\"disabled?'disabled':''\">{{ selectorTitle }}</p>\n \n <fw-select\n [disabled]=\"disabled\" width=\"80px\" placeholder=\"Size\"\n [(ngModel)]=\"pageSize\">\n <fw-menu-item\n *ngFor=\"let size of pageSizeOptions\"\n [value]=\"size.toString()\"\n [title]=\"size.toString()\"\n [selected]=\"pageSize.toString()===size.toString()\"\n [disabled]=\"disabled\"\n ></fw-menu-item>\n </fw-select>\n </div>\n <p class=\"vision-p2 record-count\" [ngClass]=\"disabled?'disabled':''\">\n {{ getRowIndexStart() + 1 }}-{{ getRowIndexEnd() + 1 }}\n of {{ length }}</p>\n <div>\n <button\n *ngIf=\"showFirst\"\n class=\"page-item page-action page-first\" [disabled]=\"!hasPreviousPage() || disabled\" (click)=\"firstPage()\">\n <fw-icon>arrow-back-collapse</fw-icon>\n </button>\n <button\n *ngIf=\"showPrevious\"\n class=\"page-item page-action page-previous\" [disabled]=\"!hasPreviousPage() || disabled\"\n (click)=\"previousPage()\">\n <fw-icon>chevron-back</fw-icon>\n </button>\n <button\n *ngIf=\"showNext\" class=\"page-item page-action page-next\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"nextPage()\">\n <fw-icon>chevron-forward</fw-icon>\n </button>\n <button\n *ngIf=\"showLast\" class=\"page-item page-action page-last\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"lastPage()\">\n <fw-icon>arrow-forward-collapse</fw-icon>\n </button>\n </div>\n </div>\n</div>\n", styles: [":host .paginator{display:flex}:host .paginator button{border:none;background-color:transparent}:host .paginator .page-item{box-sizing:border-box;cursor:pointer;display:flex;justify-content:center;align-items:center;border-radius:4px}:host .paginator .page-item:disabled{color:var(--typography-muted);cursor:not-allowed}:host .paginator .page-item:disabled h4{opacity:.4}:host .paginator .page-action fw-icon{font-size:22px}:host .paginator .page-action:disabled{opacity:.4}:host .paginator .pages-list{box-sizing:border-box;display:flex;gap:4px}:host .paginator .pages-list .page-number h4{margin:0;color:var(--typography-base)}:host .paginator .pages-list .page-number:disabled h4{color:var(--slate-base)!important}:host .paginator .pages-list .page-active{background-color:var(--slate-focus)}:host .paginator .pages-list .page-active:disabled{background-color:transparent}:host .paginator.start{justify-content:flex-start}:host .paginator.center{justify-content:center}:host .paginator.end{justify-content:flex-end}:host .paginator.large .page-item{width:40px;height:40px}:host .paginator.medium .page-item{width:32px;height:32px}:host .paginator.small .page-item{width:26px;height:26px}:host .paginator.primary .page-active:not(:disabled){background-color:var(--primary-base)!important}:host .paginator.primary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.secondary .page-active:not(:disabled){background-color:var(--secondary-base)!important}:host .paginator.secondary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.outline .page-item{border:1px solid var(--slate-border)}:host .paginator.outline .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.primary .page-active{background-color:var(--primary-hover)!important;border-color:var(--primary-border)!important}:host .paginator.outline.primary .page-active h4{color:var(--primary-base)!important}:host .paginator.outline.primary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.secondary .page-active{background-color:var(--secondary-hover)!important;border-color:var(--secondary-border)!important}:host .paginator.outline.secondary .page-active h4{color:var(--secondary-base)!important}:host .paginator.outline.secondary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.solid .page-item{border:1px solid var(--slate-border);background-color:var(--card-background)}:host .paginator.solid .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:var(--card-background)!important;opacity:.4}:host .paginator.solid .page-number:disabled h4{opacity:1}:host .paginator.circle .page-number{border-radius:999px!important}:host .paginator .pages-selector{display:flex;align-items:center;justify-content:flex-end;gap:16px}:host .paginator .pages-selector>div{display:flex;align-items:center}:host .paginator .pages-selector fw-icon{font-size:22px}:host .paginator .pages-selector .record-count{min-width:130px;text-align:center}:host .paginator .pages-selector p.disabled{color:var(--typography-light)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.FwIconComponent, selector: "fw-icon" }, { kind: "component", type: i4.FwMenuItemComponent, selector: "fw-menu-item", inputs: ["value", "variant", "size", "title", "description", "icon", "disabled", "showCheckbox", "multiSelect", "hidden", "collapsed", "href", "target", "focused", "selected"], outputs: ["click"] }, { kind: "component", type: i5.FwSelectMenuComponent, selector: "fw-select", inputs: ["options", "valueProperty", "titleProperty", "iconProperty", "showFilter", "disabled", "width", "optionsWidth", "maxOptionsHeight", "placeholder", "value"] }] });
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorAdvancedComponent, decorators: [{
|
|
96
|
+
type: Component,
|
|
97
|
+
args: [{ selector: 'fw-paginator-advanced', template: "<div [ngClass]=\"['paginator', alignment]\">\n <div class=\"pages-selector\">\n <div>\n <p class=\"vision-p2\" [ngClass]=\"disabled?'disabled':''\">{{ selectorTitle }}</p>\n \n <fw-select\n [disabled]=\"disabled\" width=\"80px\" placeholder=\"Size\"\n [(ngModel)]=\"pageSize\">\n <fw-menu-item\n *ngFor=\"let size of pageSizeOptions\"\n [value]=\"size.toString()\"\n [title]=\"size.toString()\"\n [selected]=\"pageSize.toString()===size.toString()\"\n [disabled]=\"disabled\"\n ></fw-menu-item>\n </fw-select>\n </div>\n <p class=\"vision-p2 record-count\" [ngClass]=\"disabled?'disabled':''\">\n {{ getRowIndexStart() + 1 }}-{{ getRowIndexEnd() + 1 }}\n of {{ length }}</p>\n <div>\n <button\n *ngIf=\"showFirst\"\n class=\"page-item page-action page-first\" [disabled]=\"!hasPreviousPage() || disabled\" (click)=\"firstPage()\">\n <fw-icon>arrow-back-collapse</fw-icon>\n </button>\n <button\n *ngIf=\"showPrevious\"\n class=\"page-item page-action page-previous\" [disabled]=\"!hasPreviousPage() || disabled\"\n (click)=\"previousPage()\">\n <fw-icon>chevron-back</fw-icon>\n </button>\n <button\n *ngIf=\"showNext\" class=\"page-item page-action page-next\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"nextPage()\">\n <fw-icon>chevron-forward</fw-icon>\n </button>\n <button\n *ngIf=\"showLast\" class=\"page-item page-action page-last\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"lastPage()\">\n <fw-icon>arrow-forward-collapse</fw-icon>\n </button>\n </div>\n </div>\n</div>\n", styles: [":host .paginator{display:flex}:host .paginator button{border:none;background-color:transparent}:host .paginator .page-item{box-sizing:border-box;cursor:pointer;display:flex;justify-content:center;align-items:center;border-radius:4px}:host .paginator .page-item:disabled{color:var(--typography-muted);cursor:not-allowed}:host .paginator .page-item:disabled h4{opacity:.4}:host .paginator .page-action fw-icon{font-size:22px}:host .paginator .page-action:disabled{opacity:.4}:host .paginator .pages-list{box-sizing:border-box;display:flex;gap:4px}:host .paginator .pages-list .page-number h4{margin:0;color:var(--typography-base)}:host .paginator .pages-list .page-number:disabled h4{color:var(--slate-base)!important}:host .paginator .pages-list .page-active{background-color:var(--slate-focus)}:host .paginator .pages-list .page-active:disabled{background-color:transparent}:host .paginator.start{justify-content:flex-start}:host .paginator.center{justify-content:center}:host .paginator.end{justify-content:flex-end}:host .paginator.large .page-item{width:40px;height:40px}:host .paginator.medium .page-item{width:32px;height:32px}:host .paginator.small .page-item{width:26px;height:26px}:host .paginator.primary .page-active:not(:disabled){background-color:var(--primary-base)!important}:host .paginator.primary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.secondary .page-active:not(:disabled){background-color:var(--secondary-base)!important}:host .paginator.secondary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.outline .page-item{border:1px solid var(--slate-border)}:host .paginator.outline .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.primary .page-active{background-color:var(--primary-hover)!important;border-color:var(--primary-border)!important}:host .paginator.outline.primary .page-active h4{color:var(--primary-base)!important}:host .paginator.outline.primary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.secondary .page-active{background-color:var(--secondary-hover)!important;border-color:var(--secondary-border)!important}:host .paginator.outline.secondary .page-active h4{color:var(--secondary-base)!important}:host .paginator.outline.secondary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.solid .page-item{border:1px solid var(--slate-border);background-color:var(--card-background)}:host .paginator.solid .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:var(--card-background)!important;opacity:.4}:host .paginator.solid .page-number:disabled h4{opacity:1}:host .paginator.circle .page-number{border-radius:999px!important}:host .paginator .pages-selector{display:flex;align-items:center;justify-content:flex-end;gap:16px}:host .paginator .pages-selector>div{display:flex;align-items:center}:host .paginator .pages-selector fw-icon{font-size:22px}:host .paginator .pages-selector .record-count{min-width:130px;text-align:center}:host .paginator .pages-selector p.disabled{color:var(--typography-light)}\n"] }]
|
|
98
|
+
}], propDecorators: { disabled: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], showNext: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], showPrevious: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], showFirst: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], showLast: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], pageIndex: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], pageSizeOptions: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], length: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], alignment: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], selectorTitle: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], pageSize: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], page: [{
|
|
121
|
+
type: Output
|
|
122
|
+
}] } });
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator-advanced.component.js","sourceRoot":"","sources":["../../../../../../src/components/paginator/paginator-advanced/paginator-advanced.component.ts","../../../../../../src/components/paginator/paginator-advanced/paginator-advanced.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { FwPaginatorEvent } from '../paginator.model';\n\n@Component({\n  selector: 'fw-paginator-advanced',\n  templateUrl: './paginator-advanced.component.html',\n  styleUrls: ['./paginator-advanced.component.scss'],\n})\nexport class FwPaginatorAdvancedComponent {\n  @Input() disabled: boolean = false;\n  @Input() showNext: boolean = true;\n  @Input() showPrevious: boolean = true;\n  @Input() showFirst: boolean = false;\n  @Input() showLast: boolean = false;\n  @Input() pageIndex: number = 0;\n  @Input() pageSizeOptions: number[] = [10, 25, 50, 100];\n  @Input() length: number = 0;\n  @Input() alignment: 'start' | 'center' | 'end' = 'center';\n  @Input() selectorTitle: string = 'Items per page:';\n\n  @Input()\n  get pageSize(): number {\n    return this._pageSize;\n  }\n\n  set pageSize(newSize: number) {\n    this._pageSize = parseInt(newSize.toString());\n    this.pageIndex = 0;\n    const pageEvt = this.buildPageEvent(0);\n    this.page.emit(pageEvt);\n  }\n\n  private _pageSize: number = 10;\n  @Output() page: EventEmitter<FwPaginatorEvent> = new EventEmitter<FwPaginatorEvent>();\n\n  private buildPageEvent(pageIndex: number): FwPaginatorEvent {\n    return {\n      length: this.length,\n      pageSize: this.pageSize,\n      pageIndex: pageIndex,\n      previousPageIndex: this.pageIndex,\n      rowIndexStart: this.getRowIndexStart(pageIndex),\n      rowIndexEnd: this.getRowIndexEnd(pageIndex),\n    };\n  }\n\n  firstPage(): void {\n    const evt = this.buildPageEvent(1);\n    this.pageIndex = 0;\n    this.page.emit(evt);\n  }\n\n  lastPage(): void {\n    const evt = this.buildPageEvent(this.getNumberOfPages());\n    this.pageIndex = this.getNumberOfPages() - 1;\n    this.page.emit(evt);\n  }\n\n  nextPage(): void {\n    if (this.hasNextPage()) {\n      const evt = this.buildPageEvent(this.pageIndex + 1);\n      this.pageIndex++;\n      this.page.emit(evt);\n    }\n  }\n\n  previousPage(): void {\n    if (this.hasPreviousPage()) {\n      const evt = this.buildPageEvent(this.pageIndex - 1);\n      this.pageIndex--;\n      this.page.emit(evt);\n    }\n  }\n\n  setPage(pageNumber: number): void {\n    const evt = this.buildPageEvent(pageNumber);\n    this.pageIndex = pageNumber;\n    this.page.emit(evt);\n  }\n\n  getNumberOfPages(): number {\n    return Math.ceil(this.length / this.pageSize);\n  }\n\n  getRowIndexStart(pageIndex?: number): number {\n    const index = pageIndex !== undefined ? pageIndex : this.pageIndex;\n    return index * this.pageSize;\n  }\n\n  getRowIndexEnd(pageIndex?: number): number {\n    const index = pageIndex !== undefined ? pageIndex : this.pageIndex;\n    let indexEnd = (index * this.pageSize) + this.pageSize - 1;\n    if (indexEnd > this.length) {\n      indexEnd = this.length - 1;\n    }\n    return indexEnd;\n  }\n\n  hasNextPage(): boolean {\n    return (this.pageIndex !== this.getNumberOfPages() - 1);\n  }\n\n  hasPreviousPage(): boolean {\n    return (this.pageIndex > 0);\n  }\n}\n","<div [ngClass]=\"['paginator', alignment]\">\n  <div class=\"pages-selector\">\n    <div>\n      <p class=\"vision-p2\" [ngClass]=\"disabled?'disabled':''\">{{ selectorTitle }}</p>\n      &nbsp;\n      <fw-select\n        [disabled]=\"disabled\" width=\"80px\" placeholder=\"Size\"\n        [(ngModel)]=\"pageSize\">\n        <fw-menu-item\n          *ngFor=\"let size of pageSizeOptions\"\n          [value]=\"size.toString()\"\n          [title]=\"size.toString()\"\n          [selected]=\"pageSize.toString()===size.toString()\"\n          [disabled]=\"disabled\"\n        ></fw-menu-item>\n      </fw-select>\n    </div>\n    <p class=\"vision-p2 record-count\" [ngClass]=\"disabled?'disabled':''\">\n      {{ getRowIndexStart() + 1 }}-{{ getRowIndexEnd() + 1 }}\n      of {{ length }}</p>\n    <div>\n      <button\n        *ngIf=\"showFirst\"\n        class=\"page-item page-action page-first\" [disabled]=\"!hasPreviousPage() ||  disabled\" (click)=\"firstPage()\">\n        <fw-icon>arrow-back-collapse</fw-icon>\n      </button>\n      <button\n        *ngIf=\"showPrevious\"\n        class=\"page-item page-action page-previous\" [disabled]=\"!hasPreviousPage() || disabled\"\n        (click)=\"previousPage()\">\n        <fw-icon>chevron-back</fw-icon>\n      </button>\n      <button\n        *ngIf=\"showNext\" class=\"page-item page-action page-next\" [disabled]=\"!hasNextPage() || disabled\"\n        (click)=\"nextPage()\">\n        <fw-icon>chevron-forward</fw-icon>\n      </button>\n      <button\n        *ngIf=\"showLast\" class=\"page-item page-action page-last\" [disabled]=\"!hasNextPage() || disabled\"\n        (click)=\"lastPage()\">\n        <fw-icon>arrow-forward-collapse</fw-icon>\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../icon/icon.component";
|
|
5
|
+
export class FwPaginatorComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.size = 'medium';
|
|
8
|
+
this.color = 'slate';
|
|
9
|
+
this.shape = 'rounded';
|
|
10
|
+
this.variant = 'ghost';
|
|
11
|
+
this.disabled = false;
|
|
12
|
+
this.showNext = true;
|
|
13
|
+
this.showPrevious = true;
|
|
14
|
+
this.showFirst = false;
|
|
15
|
+
this.showLast = false;
|
|
16
|
+
this.pageIndex = 0;
|
|
17
|
+
this.pageSize = 10;
|
|
18
|
+
this.maxPagesShown = 10;
|
|
19
|
+
this.length = 0;
|
|
20
|
+
this.alignment = 'center';
|
|
21
|
+
this.selectorTitle = 'Items per page:';
|
|
22
|
+
this.page = new EventEmitter();
|
|
23
|
+
}
|
|
24
|
+
buildPageEvent(pageIndex) {
|
|
25
|
+
return {
|
|
26
|
+
length: this.length,
|
|
27
|
+
pageSize: this.pageSize,
|
|
28
|
+
pageIndex: pageIndex,
|
|
29
|
+
previousPageIndex: this.pageIndex,
|
|
30
|
+
rowIndexStart: this.getRowIndexStart(pageIndex),
|
|
31
|
+
rowIndexEnd: this.getRowIndexEnd(pageIndex),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
firstPage() {
|
|
35
|
+
const evt = this.buildPageEvent(0);
|
|
36
|
+
this.pageIndex = 0;
|
|
37
|
+
this.page.emit(evt);
|
|
38
|
+
}
|
|
39
|
+
lastPage() {
|
|
40
|
+
const evt = this.buildPageEvent(this.getNumberOfPages());
|
|
41
|
+
this.pageIndex = this.getNumberOfPages() - 1;
|
|
42
|
+
this.page.emit(evt);
|
|
43
|
+
}
|
|
44
|
+
nextPage() {
|
|
45
|
+
if (this.hasNextPage()) {
|
|
46
|
+
const evt = this.buildPageEvent(this.pageIndex + 1);
|
|
47
|
+
this.pageIndex++;
|
|
48
|
+
this.page.emit(evt);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
previousPage() {
|
|
52
|
+
if (this.hasPreviousPage()) {
|
|
53
|
+
const evt = this.buildPageEvent(this.pageIndex - 1);
|
|
54
|
+
this.pageIndex--;
|
|
55
|
+
this.page.emit(evt);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
setPage(pageIndex) {
|
|
59
|
+
const evt = this.buildPageEvent(pageIndex);
|
|
60
|
+
this.pageIndex = pageIndex;
|
|
61
|
+
this.page.emit(evt);
|
|
62
|
+
}
|
|
63
|
+
getPages() {
|
|
64
|
+
const pages = [];
|
|
65
|
+
const currentSet = Math.ceil((this.pageIndex + 1) / this.maxPagesShown);
|
|
66
|
+
for (let i = 0; i < this.getNumberOfPages(); i++) {
|
|
67
|
+
if (currentSet === Math.ceil((i + 1) / this.maxPagesShown)) {
|
|
68
|
+
pages.push({ pageIndex: i, number: i + 1, active: this.pageIndex === i });
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return pages;
|
|
72
|
+
}
|
|
73
|
+
getNumberOfPages() {
|
|
74
|
+
return Math.ceil(this.length / this.pageSize);
|
|
75
|
+
}
|
|
76
|
+
getRowIndexStart(pageIndex) {
|
|
77
|
+
const index = pageIndex !== undefined ? pageIndex : this.pageIndex;
|
|
78
|
+
return index * this.pageSize;
|
|
79
|
+
}
|
|
80
|
+
getRowIndexEnd(pageIndex) {
|
|
81
|
+
const index = pageIndex !== undefined ? pageIndex : this.pageIndex;
|
|
82
|
+
let indexEnd = (index * this.pageSize) + this.pageSize - 1;
|
|
83
|
+
if (indexEnd >= this.length) {
|
|
84
|
+
indexEnd = this.length - 1;
|
|
85
|
+
}
|
|
86
|
+
return indexEnd;
|
|
87
|
+
}
|
|
88
|
+
hasNextPage() {
|
|
89
|
+
return (this.pageIndex !== this.getNumberOfPages() - 1);
|
|
90
|
+
}
|
|
91
|
+
hasPreviousPage() {
|
|
92
|
+
return (this.pageIndex > 0);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
FwPaginatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
96
|
+
FwPaginatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwPaginatorComponent, selector: "fw-paginator", inputs: { size: "size", color: "color", shape: "shape", variant: "variant", disabled: "disabled", showNext: "showNext", showPrevious: "showPrevious", showFirst: "showFirst", showLast: "showLast", pageIndex: "pageIndex", pageSize: "pageSize", maxPagesShown: "maxPagesShown", length: "length", alignment: "alignment", selectorTitle: "selectorTitle" }, outputs: { page: "page" }, ngImport: i0, template: "<div [ngClass]=\"['paginator', variant, color, size, shape, alignment]\">\n <div class=\"pages-list\">\n <button\n *ngIf=\"showFirst\" class=\"page-item page-action page-first\" [disabled]=\"!hasPreviousPage() || disabled\"\n (click)=\"firstPage()\">\n <fw-icon>arrow-back-collapse</fw-icon>\n </button>\n <button\n *ngIf=\"showPrevious\"\n class=\"page-item page-action page-previous\" [disabled]=\"!hasPreviousPage() || disabled\" (click)=\"previousPage()\">\n <fw-icon>chevron-back</fw-icon>\n </button>\n <button\n [ngClass]=\"['page-item', 'page-number', page.active ? 'page-active': '']\"\n [disabled]=\"disabled\"\n *ngFor=\"let page of getPages()\"\n (click)=\"setPage(page.pageIndex)\"\n >\n <h4>{{ page.number }}</h4>\n </button>\n <button\n *ngIf=\"showNext\" class=\"page-item page-action page-next\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"nextPage()\">\n <fw-icon>chevron-forward</fw-icon>\n </button>\n <button\n *ngIf=\"showLast\" class=\"page-item page-action page-last\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"lastPage()\">\n <fw-icon>arrow-forward-collapse</fw-icon>\n </button>\n </div>\n</div>\n", styles: [":host .paginator{display:flex}:host .paginator button{border:none;background-color:transparent}:host .paginator .page-item{box-sizing:border-box;cursor:pointer;display:flex;justify-content:center;align-items:center;border-radius:4px}:host .paginator .page-item:disabled{color:var(--typography-muted);cursor:not-allowed}:host .paginator .page-item:disabled h4{opacity:.4}:host .paginator .page-action fw-icon{font-size:22px}:host .paginator .page-action:disabled{opacity:.4}:host .paginator .pages-list{box-sizing:border-box;display:flex;gap:4px}:host .paginator .pages-list .page-number h4{margin:0;color:var(--typography-base)}:host .paginator .pages-list .page-number:disabled h4{color:var(--slate-base)!important}:host .paginator .pages-list .page-active{background-color:var(--slate-focus)}:host .paginator .pages-list .page-active:disabled{background-color:transparent}:host .paginator.start{justify-content:flex-start}:host .paginator.center{justify-content:center}:host .paginator.end{justify-content:flex-end}:host .paginator.large .page-item{width:40px;height:40px}:host .paginator.medium .page-item{width:32px;height:32px}:host .paginator.small .page-item{width:26px;height:26px}:host .paginator.primary .page-active:not(:disabled){background-color:var(--primary-base)!important}:host .paginator.primary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.secondary .page-active:not(:disabled){background-color:var(--secondary-base)!important}:host .paginator.secondary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.outline .page-item{border:1px solid var(--slate-border)}:host .paginator.outline .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.primary .page-active{background-color:var(--primary-hover)!important;border-color:var(--primary-border)!important}:host .paginator.outline.primary .page-active h4{color:var(--primary-base)!important}:host .paginator.outline.primary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.secondary .page-active{background-color:var(--secondary-hover)!important;border-color:var(--secondary-border)!important}:host .paginator.outline.secondary .page-active h4{color:var(--secondary-base)!important}:host .paginator.outline.secondary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.solid .page-item{border:1px solid var(--slate-border);background-color:var(--card-background)}:host .paginator.solid .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:var(--card-background)!important;opacity:.4}:host .paginator.solid .page-number:disabled h4{opacity:1}:host .paginator.circle .page-number{border-radius:999px!important}:host .paginator .pages-selector{display:flex;align-items:center;justify-content:flex-end;gap:16px}:host .paginator .pages-selector>div{display:flex;align-items:center}:host .paginator .pages-selector fw-icon{font-size:22px}:host .paginator .pages-selector .record-count{min-width:130px;text-align:center}:host .paginator .pages-selector p.disabled{color:var(--typography-light)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FwIconComponent, selector: "fw-icon" }] });
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorComponent, decorators: [{
|
|
98
|
+
type: Component,
|
|
99
|
+
args: [{ selector: 'fw-paginator', template: "<div [ngClass]=\"['paginator', variant, color, size, shape, alignment]\">\n <div class=\"pages-list\">\n <button\n *ngIf=\"showFirst\" class=\"page-item page-action page-first\" [disabled]=\"!hasPreviousPage() || disabled\"\n (click)=\"firstPage()\">\n <fw-icon>arrow-back-collapse</fw-icon>\n </button>\n <button\n *ngIf=\"showPrevious\"\n class=\"page-item page-action page-previous\" [disabled]=\"!hasPreviousPage() || disabled\" (click)=\"previousPage()\">\n <fw-icon>chevron-back</fw-icon>\n </button>\n <button\n [ngClass]=\"['page-item', 'page-number', page.active ? 'page-active': '']\"\n [disabled]=\"disabled\"\n *ngFor=\"let page of getPages()\"\n (click)=\"setPage(page.pageIndex)\"\n >\n <h4>{{ page.number }}</h4>\n </button>\n <button\n *ngIf=\"showNext\" class=\"page-item page-action page-next\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"nextPage()\">\n <fw-icon>chevron-forward</fw-icon>\n </button>\n <button\n *ngIf=\"showLast\" class=\"page-item page-action page-last\" [disabled]=\"!hasNextPage() || disabled\"\n (click)=\"lastPage()\">\n <fw-icon>arrow-forward-collapse</fw-icon>\n </button>\n </div>\n</div>\n", styles: [":host .paginator{display:flex}:host .paginator button{border:none;background-color:transparent}:host .paginator .page-item{box-sizing:border-box;cursor:pointer;display:flex;justify-content:center;align-items:center;border-radius:4px}:host .paginator .page-item:disabled{color:var(--typography-muted);cursor:not-allowed}:host .paginator .page-item:disabled h4{opacity:.4}:host .paginator .page-action fw-icon{font-size:22px}:host .paginator .page-action:disabled{opacity:.4}:host .paginator .pages-list{box-sizing:border-box;display:flex;gap:4px}:host .paginator .pages-list .page-number h4{margin:0;color:var(--typography-base)}:host .paginator .pages-list .page-number:disabled h4{color:var(--slate-base)!important}:host .paginator .pages-list .page-active{background-color:var(--slate-focus)}:host .paginator .pages-list .page-active:disabled{background-color:transparent}:host .paginator.start{justify-content:flex-start}:host .paginator.center{justify-content:center}:host .paginator.end{justify-content:flex-end}:host .paginator.large .page-item{width:40px;height:40px}:host .paginator.medium .page-item{width:32px;height:32px}:host .paginator.small .page-item{width:26px;height:26px}:host .paginator.primary .page-active:not(:disabled){background-color:var(--primary-base)!important}:host .paginator.primary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.secondary .page-active:not(:disabled){background-color:var(--secondary-base)!important}:host .paginator.secondary .page-active:not(:disabled) h4{color:var(--typography-contrast)!important}:host .paginator.outline .page-item{border:1px solid var(--slate-border)}:host .paginator.outline .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.primary .page-active{background-color:var(--primary-hover)!important;border-color:var(--primary-border)!important}:host .paginator.outline.primary .page-active h4{color:var(--primary-base)!important}:host .paginator.outline.primary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.outline.secondary .page-active{background-color:var(--secondary-hover)!important;border-color:var(--secondary-border)!important}:host .paginator.outline.secondary .page-active h4{color:var(--secondary-base)!important}:host .paginator.outline.secondary .page-active:disabled{border:1px solid var(--slate-border)!important;background-color:transparent!important}:host .paginator.solid .page-item{border:1px solid var(--slate-border);background-color:var(--card-background)}:host .paginator.solid .page-number:disabled{border:1px solid var(--slate-border)!important;background-color:var(--card-background)!important;opacity:.4}:host .paginator.solid .page-number:disabled h4{opacity:1}:host .paginator.circle .page-number{border-radius:999px!important}:host .paginator .pages-selector{display:flex;align-items:center;justify-content:flex-end;gap:16px}:host .paginator .pages-selector>div{display:flex;align-items:center}:host .paginator .pages-selector fw-icon{font-size:22px}:host .paginator .pages-selector .record-count{min-width:130px;text-align:center}:host .paginator .pages-selector p.disabled{color:var(--typography-light)}\n"] }]
|
|
100
|
+
}], propDecorators: { size: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], color: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], shape: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], variant: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], disabled: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], showNext: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], showPrevious: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], showFirst: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], showLast: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], pageIndex: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], pageSize: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], maxPagesShown: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], length: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], alignment: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], selectorTitle: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], page: [{
|
|
131
|
+
type: Output
|
|
132
|
+
}] } });
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../src/components/paginator/paginator.component.ts","../../../../../src/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { FwPaginatorEvent } from './paginator.model';\n\nexport interface PaginationPage {\n  pageIndex: number;\n  number: number;\n  active: boolean;\n}\n\n@Component({\n  selector: 'fw-paginator',\n  templateUrl: './paginator.component.html',\n  styleUrls: ['./paginator.component.scss'],\n})\nexport class FwPaginatorComponent {\n  @Input() size: 'small' | 'medium' | 'large' = 'medium';\n  @Input() color: 'slate' | 'primary' | 'secondary' = 'slate';\n  @Input() shape: 'rounded' | 'circle' = 'rounded';\n  @Input() variant: 'ghost' | 'outline' | 'solid' = 'ghost';\n  @Input() disabled: boolean = false;\n  @Input() showNext: boolean = true;\n  @Input() showPrevious: boolean = true;\n  @Input() showFirst: boolean = false;\n  @Input() showLast: boolean = false;\n  @Input() pageIndex: number = 0;\n  @Input() pageSize: number = 10;\n  @Input() maxPagesShown: number = 10;\n  @Input() length: number = 0;\n  @Input() alignment: 'start' | 'center' | 'end' = 'center';\n  @Input() selectorTitle: string = 'Items per page:';\n  @Output() page: EventEmitter<FwPaginatorEvent> = new EventEmitter<FwPaginatorEvent>();\n\n  private buildPageEvent(pageIndex: number): FwPaginatorEvent {\n    return {\n      length: this.length,\n      pageSize: this.pageSize,\n      pageIndex: pageIndex,\n      previousPageIndex: this.pageIndex,\n      rowIndexStart: this.getRowIndexStart(pageIndex),\n      rowIndexEnd: this.getRowIndexEnd(pageIndex),\n    };\n  }\n\n  firstPage(): void {\n    const evt = this.buildPageEvent(0);\n    this.pageIndex = 0;\n    this.page.emit(evt);\n  }\n\n  lastPage(): void {\n    const evt = this.buildPageEvent(this.getNumberOfPages());\n    this.pageIndex = this.getNumberOfPages() - 1;\n    this.page.emit(evt);\n  }\n\n  nextPage(): void {\n    if (this.hasNextPage()) {\n      const evt = this.buildPageEvent(this.pageIndex + 1);\n      this.pageIndex++;\n      this.page.emit(evt);\n    }\n  }\n\n  previousPage(): void {\n    if (this.hasPreviousPage()) {\n      const evt = this.buildPageEvent(this.pageIndex - 1);\n      this.pageIndex--;\n      this.page.emit(evt);\n    }\n  }\n\n  setPage(pageIndex: number): void {\n    const evt = this.buildPageEvent(pageIndex);\n    this.pageIndex = pageIndex;\n    this.page.emit(evt);\n  }\n\n  getPages(): PaginationPage[] {\n    const pages: PaginationPage[] = [];\n    const currentSet = Math.ceil((this.pageIndex + 1) / this.maxPagesShown);\n    for (let i = 0; i < this.getNumberOfPages(); i++) {\n      if (currentSet === Math.ceil((i + 1) / this.maxPagesShown)) {\n        pages.push({ pageIndex: i, number: i + 1, active: this.pageIndex === i });\n      }\n    }\n    return pages;\n  }\n\n  getNumberOfPages(): number {\n    return Math.ceil(this.length / this.pageSize);\n  }\n\n  getRowIndexStart(pageIndex?: number): number {\n    const index = pageIndex !== undefined ? pageIndex : this.pageIndex;\n    return index * this.pageSize;\n  }\n\n  getRowIndexEnd(pageIndex?: number): number {\n    const index = pageIndex !== undefined ? pageIndex : this.pageIndex;\n    let indexEnd = (index * this.pageSize) + this.pageSize - 1;\n    if (indexEnd >= this.length) {\n      indexEnd = this.length - 1;\n    }\n    return indexEnd;\n  }\n\n  hasNextPage(): boolean {\n    return (this.pageIndex !== this.getNumberOfPages() - 1);\n  }\n\n  hasPreviousPage(): boolean {\n    return (this.pageIndex > 0);\n  }\n}\n","<div [ngClass]=\"['paginator', variant, color, size, shape, alignment]\">\n  <div class=\"pages-list\">\n    <button\n      *ngIf=\"showFirst\" class=\"page-item page-action page-first\" [disabled]=\"!hasPreviousPage() ||  disabled\"\n      (click)=\"firstPage()\">\n      <fw-icon>arrow-back-collapse</fw-icon>\n    </button>\n    <button\n      *ngIf=\"showPrevious\"\n      class=\"page-item page-action page-previous\" [disabled]=\"!hasPreviousPage() || disabled\" (click)=\"previousPage()\">\n      <fw-icon>chevron-back</fw-icon>\n    </button>\n    <button\n      [ngClass]=\"['page-item', 'page-number', page.active ? 'page-active': '']\"\n      [disabled]=\"disabled\"\n      *ngFor=\"let page of getPages()\"\n      (click)=\"setPage(page.pageIndex)\"\n    >\n      <h4>{{ page.number }}</h4>\n    </button>\n    <button\n      *ngIf=\"showNext\" class=\"page-item page-action page-next\" [disabled]=\"!hasNextPage() || disabled\"\n      (click)=\"nextPage()\">\n      <fw-icon>chevron-forward</fw-icon>\n    </button>\n    <button\n      *ngIf=\"showLast\" class=\"page-item page-action page-last\" [disabled]=\"!hasNextPage() || disabled\"\n      (click)=\"lastPage()\">\n      <fw-icon>arrow-forward-collapse</fw-icon>\n    </button>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdG9yLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvcGFnaW5hdG9yL3BhZ2luYXRvci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBGd1BhZ2luYXRvckV2ZW50IHtcbiAgbGVuZ3RoOiBudW1iZXI7XG4gIHBhZ2VTaXplOiBudW1iZXI7XG4gIHBhZ2VJbmRleDogbnVtYmVyO1xuICBwcmV2aW91c1BhZ2VJbmRleDogbnVtYmVyO1xuICByb3dJbmRleFN0YXJ0OiBudW1iZXI7XG4gIHJvd0luZGV4RW5kOiBudW1iZXI7XG59XG4iXX0=
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { FwIconModule } from '../icon/icon.module';
|
|
5
|
+
import { FwIconButtonModule } from '../icon-button/icon-button.module';
|
|
6
|
+
import { FwMenuModule } from '../menu/menu.module';
|
|
7
|
+
import { FwSelectMenuModule } from '../select-menu/select-menu.module';
|
|
8
|
+
import { FwPaginatorComponent } from './paginator.component';
|
|
9
|
+
import { FwPaginatorAdvancedComponent } from './paginator-advanced/paginator-advanced.component';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class FwPaginatorModule {
|
|
12
|
+
}
|
|
13
|
+
FwPaginatorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
14
|
+
FwPaginatorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorModule, declarations: [FwPaginatorComponent,
|
|
15
|
+
FwPaginatorAdvancedComponent], imports: [CommonModule,
|
|
16
|
+
FormsModule,
|
|
17
|
+
FwIconButtonModule,
|
|
18
|
+
FwIconModule,
|
|
19
|
+
FwMenuModule,
|
|
20
|
+
FwSelectMenuModule], exports: [FwPaginatorComponent,
|
|
21
|
+
FwPaginatorAdvancedComponent] });
|
|
22
|
+
FwPaginatorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorModule, imports: [CommonModule,
|
|
23
|
+
FormsModule,
|
|
24
|
+
FwIconButtonModule,
|
|
25
|
+
FwIconModule,
|
|
26
|
+
FwMenuModule,
|
|
27
|
+
FwSelectMenuModule] });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwPaginatorModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
imports: [
|
|
32
|
+
CommonModule,
|
|
33
|
+
FormsModule,
|
|
34
|
+
FwIconButtonModule,
|
|
35
|
+
FwIconModule,
|
|
36
|
+
FwMenuModule,
|
|
37
|
+
FwSelectMenuModule,
|
|
38
|
+
],
|
|
39
|
+
exports: [
|
|
40
|
+
FwPaginatorComponent,
|
|
41
|
+
FwPaginatorAdvancedComponent,
|
|
42
|
+
],
|
|
43
|
+
declarations: [
|
|
44
|
+
FwPaginatorComponent,
|
|
45
|
+
FwPaginatorAdvancedComponent,
|
|
46
|
+
],
|
|
47
|
+
}]
|
|
48
|
+
}] });
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdG9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3BhZ2luYXRvci9wYWdpbmF0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzdELE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDOztBQW9CakcsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQUoxQixvQkFBb0I7UUFDcEIsNEJBQTRCLGFBYjVCLFlBQVk7UUFDWixXQUFXO1FBQ1gsa0JBQWtCO1FBQ2xCLFlBQVk7UUFDWixZQUFZO1FBQ1osa0JBQWtCLGFBR2xCLG9CQUFvQjtRQUNwQiw0QkFBNEI7K0dBT25CLGlCQUFpQixZQWhCMUIsWUFBWTtRQUNaLFdBQVc7UUFDWCxrQkFBa0I7UUFDbEIsWUFBWTtRQUNaLFlBQVk7UUFDWixrQkFBa0I7MkZBV1QsaUJBQWlCO2tCQWxCN0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGtCQUFrQjt3QkFDbEIsWUFBWTt3QkFDWixZQUFZO3dCQUNaLGtCQUFrQjtxQkFDbkI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG9CQUFvQjt3QkFDcEIsNEJBQTRCO3FCQUM3QjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osb0JBQW9CO3dCQUNwQiw0QkFBNEI7cUJBQzdCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHsgRndJY29uTW9kdWxlIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZHVsZSc7XG5pbXBvcnQgeyBGd0ljb25CdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9pY29uLWJ1dHRvbi9pY29uLWJ1dHRvbi5tb2R1bGUnO1xuaW1wb3J0IHsgRndNZW51TW9kdWxlIH0gZnJvbSAnLi4vbWVudS9tZW51Lm1vZHVsZSc7XG5pbXBvcnQgeyBGd1NlbGVjdE1lbnVNb2R1bGUgfSBmcm9tICcuLi9zZWxlY3QtbWVudS9zZWxlY3QtbWVudS5tb2R1bGUnO1xuaW1wb3J0IHsgRndQYWdpbmF0b3JDb21wb25lbnQgfSBmcm9tICcuL3BhZ2luYXRvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRndQYWdpbmF0b3JBZHZhbmNlZENvbXBvbmVudCB9IGZyb20gJy4vcGFnaW5hdG9yLWFkdmFuY2VkL3BhZ2luYXRvci1hZHZhbmNlZC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIEZ3SWNvbkJ1dHRvbk1vZHVsZSxcbiAgICBGd0ljb25Nb2R1bGUsXG4gICAgRndNZW51TW9kdWxlLFxuICAgIEZ3U2VsZWN0TWVudU1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEZ3UGFnaW5hdG9yQ29tcG9uZW50LFxuICAgIEZ3UGFnaW5hdG9yQWR2YW5jZWRDb21wb25lbnQsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEZ3UGFnaW5hdG9yQ29tcG9uZW50LFxuICAgIEZ3UGFnaW5hdG9yQWR2YW5jZWRDb21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZ3UGFnaW5hdG9yTW9kdWxlIHtcbn1cbiJdfQ==
|