@acorex/components 5.5.0 → 5.8.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/esm2020/lib/action-sheet/action-sheet-item.component.mjs +4 -4
- package/esm2020/lib/action-sheet/action-sheet.component.mjs +4 -4
- package/esm2020/lib/action-sheet/action-sheet.module.mjs +5 -5
- package/esm2020/lib/alert/alert.component.mjs +23 -10
- package/esm2020/lib/alert/alert.module.mjs +5 -9
- package/esm2020/lib/alert/index.mjs +1 -2
- package/esm2020/lib/avatar/avatar-group.component.mjs +3 -3
- package/esm2020/lib/avatar/avatar.component.mjs +3 -3
- package/esm2020/lib/avatar/avatar.module.mjs +5 -5
- package/esm2020/lib/badge/badge.component.mjs +3 -3
- package/esm2020/lib/badge/badge.module.mjs +5 -5
- package/esm2020/lib/base/auto-focus.directive.mjs +43 -0
- package/esm2020/lib/base/common.module.mjs +9 -7
- package/esm2020/lib/base/components.class.mjs +34 -13
- package/esm2020/lib/base/custom-cdk-overlay.service.mjs +6 -6
- package/esm2020/lib/base/events.class.mjs +1 -1
- package/esm2020/lib/base/hotkey.directive.mjs +79 -0
- package/esm2020/lib/base/index.mjs +3 -1
- package/esm2020/lib/base/infinite-scroll.directive.mjs +3 -3
- package/esm2020/lib/base/mixin/base-components.class.mjs +3 -3
- package/esm2020/lib/base/mixin/button-mixin.class.mjs +2 -23
- package/esm2020/lib/base/mixin/datalist-component.class.mjs +13 -13
- package/esm2020/lib/base/mixin/index.mjs +3 -1
- package/esm2020/lib/base/mixin/interactive-mixin.class.mjs +2 -2
- package/esm2020/lib/base/mixin/loading-mixin.class.mjs +1 -1
- package/esm2020/lib/base/mixin/mixin.class.mjs +2 -3
- package/esm2020/lib/base/mixin/selection-component.class.mjs +2 -2
- package/esm2020/lib/base/mixin/textbox-mixin.class.mjs +82 -26
- package/esm2020/lib/base/mixin/value-mixin.class.mjs +47 -59
- package/esm2020/lib/base/overlay.service.mjs +3 -3
- package/esm2020/lib/base/responsive.directive.mjs +3 -3
- package/esm2020/lib/breadcrumbs/breadcrumbs-item.component.mjs +3 -3
- package/esm2020/lib/breadcrumbs/breadcrumbs.component.mjs +3 -3
- package/esm2020/lib/breadcrumbs/breadcrumbs.module.mjs +5 -5
- package/esm2020/lib/button/button-group.component.mjs +23 -57
- package/esm2020/lib/button/button-item.class.mjs +1 -1
- package/esm2020/lib/button/button-item.component.mjs +4 -4
- package/esm2020/lib/button/button.component.mjs +20 -29
- package/esm2020/lib/button/button.module.mjs +5 -5
- package/esm2020/lib/calendar/calendar.class.mjs +3 -3
- package/esm2020/lib/calendar/calendar.component.mjs +10 -10
- package/esm2020/lib/calendar/calendar.module.mjs +5 -5
- package/esm2020/lib/carousel/carousel-arrows.component.mjs +4 -4
- package/esm2020/lib/carousel/carousel-item.component.mjs +3 -3
- package/esm2020/lib/carousel/carousel-pager.component.mjs +4 -4
- package/esm2020/lib/carousel/carousel.class.mjs +3 -3
- package/esm2020/lib/carousel/carousel.component.mjs +3 -3
- package/esm2020/lib/carousel/carousel.module.mjs +5 -5
- package/esm2020/lib/checkbox/checkbox.component.mjs +8 -7
- package/esm2020/lib/checkbox/checkbox.module.mjs +5 -5
- package/esm2020/lib/collapse/collapse-group.component.mjs +3 -3
- package/esm2020/lib/collapse/collapse.component.mjs +3 -3
- package/esm2020/lib/collapse/collapse.module.mjs +5 -5
- package/esm2020/lib/color-palette/color-palette-input.component.mjs +49 -36
- package/esm2020/lib/color-palette/color-palette-picker.component.mjs +76 -14
- package/esm2020/lib/color-palette/color-palette-preview.component.mjs +25 -17
- package/esm2020/lib/color-palette/color-palette-swatches.component.mjs +31 -20
- package/esm2020/lib/color-palette/color-palette.class.mjs +11 -4
- package/esm2020/lib/color-palette/color-palette.component.mjs +47 -20
- package/esm2020/lib/color-palette/color-palette.module.mjs +10 -7
- package/esm2020/lib/color-picker/color-picker.component.mjs +23 -11
- package/esm2020/lib/color-picker/color-picker.module.mjs +15 -17
- package/esm2020/lib/data-pager/data-pager-base.component.mjs +37 -0
- package/esm2020/lib/data-pager/data-pager-info.component.mjs +52 -0
- package/esm2020/lib/data-pager/data-pager-input-selector.component.mjs +50 -0
- package/esm2020/lib/data-pager/data-pager-next-buttons.components.mjs +60 -0
- package/esm2020/lib/data-pager/data-pager-numeric-selector.component.mjs +99 -0
- package/esm2020/lib/data-pager/data-pager-pagesize-dropdown.component.mjs +86 -0
- package/esm2020/lib/data-pager/data-pager-prev-buttons.component.mjs +58 -0
- package/esm2020/lib/data-pager/data-pager.component.mjs +132 -0
- package/esm2020/lib/data-pager/data-pager.module.mjs +51 -0
- package/esm2020/lib/data-pager/index.mjs +9 -0
- package/esm2020/lib/data-table/data-column-cell-template.directive.mjs +17 -0
- package/esm2020/lib/data-table/data-column.directive.mjs +43 -0
- package/esm2020/lib/data-table/data-table.component.mjs +124 -0
- package/esm2020/lib/data-table/data-table.module.mjs +27 -0
- package/esm2020/lib/data-table/index.mjs +5 -0
- package/esm2020/lib/datalist/datalist.component.mjs +5 -5
- package/esm2020/lib/datalist/datalist.module.mjs +5 -5
- package/esm2020/lib/datepicker/datepicker.component.mjs +15 -15
- package/esm2020/lib/datepicker/datepicker.module.mjs +5 -5
- package/esm2020/lib/decorators/addon.component.mjs +3 -3
- package/esm2020/lib/decorators/close-button.component.mjs +3 -3
- package/esm2020/lib/decorators/content.component.mjs +3 -3
- package/esm2020/lib/decorators/decorators.module.mjs +6 -6
- package/esm2020/lib/decorators/footer.component.mjs +6 -6
- package/esm2020/lib/decorators/header.component.mjs +6 -6
- package/esm2020/lib/decorators/icon.component.mjs +3 -3
- package/esm2020/lib/decorators/prefix.component.mjs +6 -8
- package/esm2020/lib/decorators/suffix.component.mjs +6 -8
- package/esm2020/lib/decorators/title.component.mjs +3 -3
- package/esm2020/lib/dialog/dialog.component.mjs +22 -9
- package/esm2020/lib/dialog/dialog.module.mjs +7 -6
- package/esm2020/lib/dialog/dialog.service.mjs +14 -8
- package/esm2020/lib/drawer/drawer-container.component.mjs +3 -3
- package/esm2020/lib/drawer/drawer.component.mjs +19 -12
- package/esm2020/lib/drawer/drawer.module.mjs +5 -5
- package/esm2020/lib/dropdown/dropdown-panel.component.mjs +30 -27
- package/esm2020/lib/dropdown/dropdown.module.mjs +5 -5
- package/esm2020/lib/form/form-field.component.mjs +3 -3
- package/esm2020/lib/form/form-field.module.mjs +5 -5
- package/esm2020/lib/form/form-hint.component.mjs +3 -3
- package/esm2020/lib/form/form.component.mjs +32 -9
- package/esm2020/lib/input-mask/input-mask.component.mjs +3 -3
- package/esm2020/lib/input-mask/input-mask.module.mjs +5 -5
- package/esm2020/lib/label/label.component.mjs +7 -5
- package/esm2020/lib/label/label.module.mjs +5 -5
- package/esm2020/lib/loading/loading-spinner.component.mjs +4 -4
- package/esm2020/lib/loading/loading.component.mjs +4 -4
- package/esm2020/lib/loading/loading.directive.mjs +5 -5
- package/esm2020/lib/loading/loading.module.mjs +5 -5
- package/esm2020/lib/loading/loading.service.mjs +3 -3
- package/esm2020/lib/menu/menu.component.mjs +15 -9
- package/esm2020/lib/menu/menu.module.mjs +7 -10
- package/esm2020/lib/number-box/number-box.component.mjs +21 -12
- package/esm2020/lib/number-box/number-box.module.mjs +5 -5
- package/esm2020/lib/page/base-page.class.mjs +3 -3
- package/esm2020/lib/page/page.component.mjs +3 -3
- package/esm2020/lib/page/page.module.mjs +5 -5
- package/esm2020/lib/password-box/password-box.component.mjs +7 -7
- package/esm2020/lib/password-box/password-box.module.mjs +5 -5
- package/esm2020/lib/picker/picker.component.mjs +4 -4
- package/esm2020/lib/picker/picker.module.mjs +5 -5
- package/esm2020/lib/popover/popover.component.mjs +3 -3
- package/esm2020/lib/popover/popover.module.mjs +5 -5
- package/esm2020/lib/popup/popup.component.mjs +10 -10
- package/esm2020/lib/popup/popup.module.mjs +5 -5
- package/esm2020/lib/popup/popup.service.mjs +3 -3
- package/esm2020/lib/progress-bar/progress-bar.component.mjs +3 -3
- package/esm2020/lib/progress-bar/progress-bar.module.mjs +5 -5
- package/esm2020/lib/radio/radio.component.mjs +4 -4
- package/esm2020/lib/radio/radio.module.mjs +5 -5
- package/esm2020/lib/range-slider/range-slider.component.mjs +100 -11
- package/esm2020/lib/range-slider/range-slider.module.mjs +7 -6
- package/esm2020/lib/rating/rating.component.mjs +3 -3
- package/esm2020/lib/rating/rating.component.module.mjs +5 -5
- package/esm2020/lib/result/result.component.mjs +5 -5
- package/esm2020/lib/result/result.module.mjs +5 -5
- package/esm2020/lib/searchbox/searchbox.component.mjs +8 -8
- package/esm2020/lib/searchbox/searchbox.module.mjs +5 -5
- package/esm2020/lib/selectbox/selectbox.component.mjs +18 -19
- package/esm2020/lib/selectbox/selectbox.module.mjs +16 -17
- package/esm2020/lib/selection-list/selection-list.component.mjs +3 -3
- package/esm2020/lib/selection-list/selection-list.module.mjs +5 -5
- package/esm2020/lib/switch/switch.component.mjs +6 -6
- package/esm2020/lib/switch/switch.module.mjs +5 -5
- package/esm2020/lib/tabs/tab-content.directive.mjs +3 -3
- package/esm2020/lib/tabs/tab-item.component.mjs +4 -4
- package/esm2020/lib/tabs/tabs.component.mjs +3 -3
- package/esm2020/lib/tabs/tabs.module.mjs +5 -5
- package/esm2020/lib/textarea/textarea.component.mjs +3 -3
- package/esm2020/lib/textarea/textarea.module.mjs +6 -8
- package/esm2020/lib/textbox/textbox.component.mjs +12 -5
- package/esm2020/lib/textbox/textbox.module.mjs +9 -11
- package/esm2020/lib/time-box/time-box.component.mjs +5 -5
- package/esm2020/lib/time-box/time-box.module.mjs +5 -5
- package/esm2020/lib/toast/toast.component.mjs +20 -13
- package/esm2020/lib/toast/toast.module.mjs +5 -5
- package/esm2020/lib/toast/toast.service.mjs +25 -19
- package/esm2020/lib/tooltip/tooltip.component.mjs +3 -3
- package/esm2020/lib/tooltip/tooltip.directive.mjs +3 -3
- package/esm2020/lib/tooltip/tooltip.module.mjs +5 -5
- package/esm2020/lib/treeview/tree-view.component.mjs +5 -5
- package/esm2020/lib/treeview/tree-view.module.mjs +5 -5
- package/esm2020/lib/validation/index.mjs +2 -1
- package/esm2020/lib/validation/validation-rule.widget.mjs +4 -24
- package/esm2020/lib/validation/validation-summary.component.mjs +102 -0
- package/esm2020/lib/validation/validation.class.mjs +1 -1
- package/esm2020/lib/validation/validation.module.mjs +31 -19
- package/esm2020/public-api.mjs +3 -2
- package/fesm2015/acorex-components.mjs +2395 -1175
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +2381 -1199
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/{acorex-components.d.ts → index.d.ts} +0 -0
- package/lib/action-sheet/action-sheet-item.component.d.ts +1 -1
- package/lib/action-sheet/action-sheet.component.d.ts +1 -1
- package/lib/alert/alert.component.d.ts +7 -5
- package/lib/alert/alert.module.d.ts +3 -4
- package/lib/alert/index.d.ts +0 -1
- package/lib/avatar/avatar-group.component.d.ts +1 -1
- package/lib/avatar/avatar.component.d.ts +1 -1
- package/lib/badge/badge.component.d.ts +1 -1
- package/lib/base/auto-focus.directive.d.ts +12 -0
- package/lib/base/common.module.d.ts +3 -1
- package/lib/base/components.class.d.ts +26 -3
- package/lib/base/events.class.d.ts +1 -1
- package/lib/base/hotkey.directive.d.ts +22 -0
- package/lib/base/index.d.ts +2 -0
- package/lib/base/infinite-scroll.directive.d.ts +1 -1
- package/lib/base/mixin/button-mixin.class.d.ts +2 -10
- package/lib/base/mixin/index.d.ts +2 -0
- package/lib/base/mixin/mixin.class.d.ts +20 -14
- package/lib/base/mixin/textbox-mixin.class.d.ts +24 -5
- package/lib/base/mixin/value-mixin.class.d.ts +7 -8
- package/lib/base/responsive.directive.d.ts +1 -1
- package/lib/breadcrumbs/breadcrumbs-item.component.d.ts +1 -1
- package/lib/breadcrumbs/breadcrumbs.component.d.ts +1 -1
- package/lib/button/button-group.component.d.ts +66 -17
- package/lib/button/button-item.class.d.ts +4 -3
- package/lib/button/button-item.component.d.ts +1 -1
- package/lib/button/button.component.d.ts +3 -4
- package/lib/calendar/calendar.component.d.ts +1 -1
- package/lib/carousel/carousel-arrows.component.d.ts +1 -1
- package/lib/carousel/carousel-item.component.d.ts +1 -1
- package/lib/carousel/carousel-pager.component.d.ts +1 -1
- package/lib/carousel/carousel.component.d.ts +1 -1
- package/lib/checkbox/checkbox.component.d.ts +4 -3
- package/lib/collapse/collapse-group.component.d.ts +1 -1
- package/lib/collapse/collapse.component.d.ts +1 -1
- package/lib/color-palette/color-palette-input.component.d.ts +3 -3
- package/lib/color-palette/color-palette-picker.component.d.ts +19 -6
- package/lib/color-palette/color-palette-preview.component.d.ts +6 -7
- package/lib/color-palette/color-palette-swatches.component.d.ts +3 -2
- package/lib/color-palette/color-palette.class.d.ts +12 -1
- package/lib/color-palette/color-palette.component.d.ts +12 -6
- package/lib/color-palette/color-palette.module.d.ts +2 -1
- package/lib/color-picker/color-picker.component.d.ts +22 -18
- package/lib/data-pager/data-pager-base.component.d.ts +48 -0
- package/lib/data-pager/data-pager-info.component.d.ts +15 -0
- package/lib/data-pager/data-pager-input-selector.component.d.ts +15 -0
- package/lib/data-pager/data-pager-next-buttons.components.d.ts +16 -0
- package/lib/data-pager/data-pager-numeric-selector.component.d.ts +18 -0
- package/lib/data-pager/data-pager-pagesize-dropdown.component.d.ts +19 -0
- package/lib/data-pager/data-pager-prev-buttons.component.d.ts +15 -0
- package/lib/data-pager/data-pager.component.d.ts +34 -0
- package/lib/data-pager/data-pager.module.d.ts +18 -0
- package/lib/data-pager/index.d.ts +8 -0
- package/lib/data-table/data-column-cell-template.directive.d.ts +8 -0
- package/lib/data-table/data-column.directive.d.ts +16 -0
- package/lib/data-table/data-table.component.d.ts +34 -0
- package/lib/data-table/data-table.module.d.ts +14 -0
- package/lib/data-table/index.d.ts +4 -0
- package/lib/datalist/datalist.component.d.ts +1 -1
- package/lib/datepicker/datepicker.component.d.ts +8 -8
- package/lib/decorators/addon.component.d.ts +1 -1
- package/lib/decorators/close-button.component.d.ts +1 -1
- package/lib/decorators/content.component.d.ts +1 -1
- package/lib/decorators/footer.component.d.ts +1 -1
- package/lib/decorators/header.component.d.ts +1 -1
- package/lib/decorators/icon.component.d.ts +1 -1
- package/lib/decorators/prefix.component.d.ts +1 -1
- package/lib/decorators/suffix.component.d.ts +1 -1
- package/lib/decorators/title.component.d.ts +1 -1
- package/lib/dialog/dialog.component.d.ts +2 -1
- package/lib/dialog/dialog.module.d.ts +7 -6
- package/lib/drawer/drawer-container.component.d.ts +1 -1
- package/lib/drawer/drawer.component.d.ts +1 -2
- package/lib/dropdown/dropdown-panel.component.d.ts +7 -8
- package/lib/form/form-field.component.d.ts +1 -1
- package/lib/form/form-hint.component.d.ts +1 -1
- package/lib/form/form.component.d.ts +15 -5
- package/lib/input-mask/input-mask.component.d.ts +1 -1
- package/lib/label/label.component.d.ts +2 -1
- package/lib/loading/loading-spinner.component.d.ts +1 -1
- package/lib/loading/loading.component.d.ts +1 -1
- package/lib/loading/loading.directive.d.ts +1 -1
- package/lib/menu/menu.component.d.ts +6 -3
- package/lib/number-box/number-box.component.d.ts +2 -2
- package/lib/password-box/password-box.component.d.ts +1 -1
- package/lib/picker/picker.component.d.ts +1 -1
- package/lib/popover/popover.component.d.ts +1 -1
- package/lib/popup/popup.component.d.ts +1 -1
- package/lib/progress-bar/progress-bar.component.d.ts +1 -1
- package/lib/radio/radio.component.d.ts +1 -1
- package/lib/range-slider/range-slider.component.d.ts +36 -5
- package/lib/range-slider/range-slider.module.d.ts +2 -1
- package/lib/rating/rating.component.d.ts +1 -1
- package/lib/result/result.component.d.ts +2 -2
- package/lib/searchbox/searchbox.component.d.ts +1 -1
- package/lib/selectbox/selectbox.component.d.ts +1 -1
- package/lib/selection-list/selection-list.component.d.ts +1 -1
- package/lib/switch/switch.component.d.ts +1 -1
- package/lib/tabs/tab-content.directive.d.ts +1 -1
- package/lib/tabs/tab-item.component.d.ts +1 -1
- package/lib/tabs/tabs.component.d.ts +1 -1
- package/lib/textarea/textarea.component.d.ts +1 -1
- package/lib/textbox/textbox.component.d.ts +1 -1
- package/lib/time-box/time-box.component.d.ts +1 -1
- package/lib/toast/toast.component.d.ts +3 -1
- package/lib/toast/toast.service.d.ts +1 -0
- package/lib/tooltip/tooltip.component.d.ts +1 -1
- package/lib/tooltip/tooltip.directive.d.ts +1 -1
- package/lib/treeview/tree-view.component.d.ts +1 -1
- package/lib/validation/index.d.ts +1 -0
- package/lib/validation/validation-rule.widget.d.ts +1 -9
- package/lib/validation/validation-summary.component.d.ts +20 -0
- package/lib/validation/validation.class.d.ts +3 -2
- package/lib/validation/validation.module.d.ts +6 -2
- package/package.json +3 -3
- package/public-api.d.ts +2 -0
- package/esm2020/lib/alert/alert-button.component.mjs +0 -50
- package/lib/alert/alert-button.component.d.ts +0 -13
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, EventEmitter, Output, Inject, Optional } from '@angular/core';
|
|
2
|
+
import { isNumber } from 'lodash-es';
|
|
3
|
+
import { AXBaseValueComponentMixin, AXPagedComponent } from '../base';
|
|
4
|
+
import { VALUE_OUTPUT, VALUE_INPUTS } from '../base/mixin/value-mixin.class';
|
|
5
|
+
import { AXPagerComponent } from './data-pager-base.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "../decorators/prefix.component";
|
|
9
|
+
import * as i3 from "../decorators/suffix.component";
|
|
10
|
+
import * as i4 from "./data-pager-next-buttons.components";
|
|
11
|
+
import * as i5 from "./data-pager-prev-buttons.component";
|
|
12
|
+
import * as i6 from "./data-pager-pagesize-dropdown.component";
|
|
13
|
+
import * as i7 from "./data-pager-numeric-selector.component";
|
|
14
|
+
import * as i8 from "./data-pager-input-selector.component";
|
|
15
|
+
import * as i9 from "./data-pager-info.component";
|
|
16
|
+
import * as i10 from "../base";
|
|
17
|
+
export class AXDataPagerComponent extends AXBaseValueComponentMixin {
|
|
18
|
+
constructor(_elementRef, _cdr, _parent) {
|
|
19
|
+
super(_elementRef, _cdr);
|
|
20
|
+
this._elementRef = _elementRef;
|
|
21
|
+
this._cdr = _cdr;
|
|
22
|
+
this._parent = _parent;
|
|
23
|
+
this._size = 10;
|
|
24
|
+
this._total = 0;
|
|
25
|
+
this._totalPages = 0;
|
|
26
|
+
this.displayMode = 'full';
|
|
27
|
+
this.onStateChanged = new EventEmitter();
|
|
28
|
+
}
|
|
29
|
+
get size() {
|
|
30
|
+
return this._size;
|
|
31
|
+
}
|
|
32
|
+
set size(v) {
|
|
33
|
+
this._size = v;
|
|
34
|
+
this._emitStateChangedEvent();
|
|
35
|
+
const newPage = Math.ceil(this.state.range.from / this._size) || 1;
|
|
36
|
+
this.value = newPage;
|
|
37
|
+
}
|
|
38
|
+
get total() {
|
|
39
|
+
return this._total;
|
|
40
|
+
}
|
|
41
|
+
set total(v) {
|
|
42
|
+
this._total = v && v > 0 ? v : 0;
|
|
43
|
+
this._emitStateChangedEvent();
|
|
44
|
+
}
|
|
45
|
+
get totalPages() {
|
|
46
|
+
return this._totalPages;
|
|
47
|
+
}
|
|
48
|
+
set totalPages(value) {
|
|
49
|
+
this._totalPages = value;
|
|
50
|
+
}
|
|
51
|
+
onInit() {
|
|
52
|
+
if (this._parent) {
|
|
53
|
+
this._parent.onPageChanged.subscribe(c => {
|
|
54
|
+
this.size = this._parent.pageSize;
|
|
55
|
+
this.total = this._parent.totalCount;
|
|
56
|
+
this.value = c.value;
|
|
57
|
+
});
|
|
58
|
+
this.size = this._parent.pageSize;
|
|
59
|
+
this.total = this._parent.totalCount;
|
|
60
|
+
}
|
|
61
|
+
this.goFirstPage();
|
|
62
|
+
}
|
|
63
|
+
onViewInit() {
|
|
64
|
+
this._emitStateChangedEvent();
|
|
65
|
+
}
|
|
66
|
+
_onValueChanged(oldValue, newValue) {
|
|
67
|
+
this._emitStateChangedEvent();
|
|
68
|
+
this._parent?.goToPage(newValue);
|
|
69
|
+
}
|
|
70
|
+
_getValue(value) {
|
|
71
|
+
return (!isNumber(value) || value < 1) ? 1 : (value > this.totalPages ? this.totalPages : value);
|
|
72
|
+
}
|
|
73
|
+
get state() {
|
|
74
|
+
const skip = (this.value - 1) * this.size;
|
|
75
|
+
return {
|
|
76
|
+
page: this.value,
|
|
77
|
+
totalItems: this.total,
|
|
78
|
+
totalPages: this.totalPages,
|
|
79
|
+
range: {
|
|
80
|
+
from: skip + 1,
|
|
81
|
+
to: Math.min((this.value * this.size), this.total)
|
|
82
|
+
},
|
|
83
|
+
skip,
|
|
84
|
+
take: this.size,
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
_emitStateChangedEvent() {
|
|
88
|
+
this.totalPages = Math.ceil(this._total / this.size);
|
|
89
|
+
//
|
|
90
|
+
this.onStateChanged.emit(Object.assign({
|
|
91
|
+
component: this,
|
|
92
|
+
htmlElement: this._elementRef.nativeElement
|
|
93
|
+
}, this.state));
|
|
94
|
+
}
|
|
95
|
+
goNextPage() {
|
|
96
|
+
this.goToPage(Math.min(++this.value, this.totalPages));
|
|
97
|
+
}
|
|
98
|
+
goLastPage() {
|
|
99
|
+
this.goToPage(this.totalPages);
|
|
100
|
+
}
|
|
101
|
+
goFirstPage() {
|
|
102
|
+
this.goToPage(1);
|
|
103
|
+
}
|
|
104
|
+
goPrevPage() {
|
|
105
|
+
this.goToPage(Math.max(--this.value, 1));
|
|
106
|
+
}
|
|
107
|
+
goToPage(page) {
|
|
108
|
+
if (page != this.value) {
|
|
109
|
+
this.value = page;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
AXDataPagerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataPagerComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: AXPagedComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
114
|
+
AXDataPagerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: AXDataPagerComponent, selector: "ax-data-pager", inputs: { readonly: "readonly", allowNull: "allowNull", value: "value", name: "name", checked: "checked", size: "size", total: "total", displayMode: "displayMode" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onStateChanged: "onStateChanged" }, providers: [{ provide: AXPagerComponent, useExisting: AXDataPagerComponent }], usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"displayMode\">\r\n <ng-container *ngSwitchCase=\"'full'\">\r\n <ax-prefix>\r\n <ax-data-pager-numeric-selector>\r\n </ax-data-pager-numeric-selector>\r\n <ax-data-pager-page-sizes>\r\n </ax-data-pager-page-sizes>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <ax-data-pager-info>\r\n </ax-data-pager-info>\r\n </ax-suffix>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'compact'\">\r\n <ax-prefix>\r\n <ax-data-pager-prev-buttons>\r\n </ax-data-pager-prev-buttons>\r\n <ax-data-pager-input-selector>\r\n </ax-data-pager-input-selector>\r\n <ax-data-pager-next-buttons>\r\n </ax-data-pager-next-buttons>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <ax-data-pager-info>\r\n </ax-data-pager-info>\r\n </ax-suffix>\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n <ng-content select=\"ax-prefix\"></ng-content>\r\n <ng-content select=\"ax-suffix\"></ng-content>\r\n </ng-container>\r\n</ng-container>\r\n\r\n", dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i2.AXDecoratorPrefixComponent, selector: "ax-prefix" }, { kind: "component", type: i3.AXDecoratorSuffixComponent, selector: "ax-suffix" }, { kind: "component", type: i4.AXDataPagerNextButtonsComponent, selector: "ax-data-pager-next-buttons" }, { kind: "component", type: i5.AXDataPagerPrevButtonsComponent, selector: "ax-data-pager-prev-buttons" }, { kind: "component", type: i6.AXDataPagerPageSizesComponent, selector: "ax-data-pager-page-sizes", inputs: ["sizes"] }, { kind: "component", type: i7.AXDataPagerNumericSelectorComponent, selector: "ax-data-pager-numeric-selector" }, { kind: "component", type: i8.AXDataPagerInputSelectorComponent, selector: "ax-data-pager-input-selector" }, { kind: "component", type: i9.AXDataPagerInfoComponent, selector: "ax-data-pager-info", inputs: ["text"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
115
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataPagerComponent, decorators: [{
|
|
116
|
+
type: Component,
|
|
117
|
+
args: [{ selector: 'ax-data-pager', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, inputs: [...VALUE_INPUTS], outputs: [...VALUE_OUTPUT], providers: [{ provide: AXPagerComponent, useExisting: AXDataPagerComponent }], template: "<ng-container [ngSwitch]=\"displayMode\">\r\n <ng-container *ngSwitchCase=\"'full'\">\r\n <ax-prefix>\r\n <ax-data-pager-numeric-selector>\r\n </ax-data-pager-numeric-selector>\r\n <ax-data-pager-page-sizes>\r\n </ax-data-pager-page-sizes>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <ax-data-pager-info>\r\n </ax-data-pager-info>\r\n </ax-suffix>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'compact'\">\r\n <ax-prefix>\r\n <ax-data-pager-prev-buttons>\r\n </ax-data-pager-prev-buttons>\r\n <ax-data-pager-input-selector>\r\n </ax-data-pager-input-selector>\r\n <ax-data-pager-next-buttons>\r\n </ax-data-pager-next-buttons>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <ax-data-pager-info>\r\n </ax-data-pager-info>\r\n </ax-suffix>\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n <ng-content select=\"ax-prefix\"></ng-content>\r\n <ng-content select=\"ax-suffix\"></ng-content>\r\n </ng-container>\r\n</ng-container>\r\n\r\n" }]
|
|
118
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i10.AXPagedComponent, decorators: [{
|
|
119
|
+
type: Optional
|
|
120
|
+
}, {
|
|
121
|
+
type: Inject,
|
|
122
|
+
args: [AXPagedComponent]
|
|
123
|
+
}] }]; }, propDecorators: { size: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], total: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], displayMode: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], onStateChanged: [{
|
|
130
|
+
type: Output
|
|
131
|
+
}] } });
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-pager.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/data-pager/data-pager.component.ts","../../../../../../projects/acorex/components/src/lib/data-pager/data-pager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, ChangeDetectorRef, Input, EventEmitter, Output, Inject, Optional } from '@angular/core';\r\nimport { isNumber } from 'lodash-es';\r\nimport { AXBaseValueComponentMixin,  AXPagedComponent } from '../base';\r\nimport { VALUE_OUTPUT, VALUE_INPUTS } from '../base/mixin/value-mixin.class';\r\nimport { AXDataPagerDisplayMode, AXDataPagerInfoData, AXPagerComponent, AXPagerStateChangedEvent } from './data-pager-base.component';\r\n\r\n\r\n@Component({\r\n    selector: 'ax-data-pager',\r\n    templateUrl: './data-pager.component.html',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    encapsulation: ViewEncapsulation.None,\r\n    inputs: [...VALUE_INPUTS],\r\n    outputs: [...VALUE_OUTPUT],\r\n    providers: [{ provide: AXPagerComponent, useExisting: AXDataPagerComponent }]\r\n})\r\nexport class AXDataPagerComponent extends AXBaseValueComponentMixin {\r\n\r\n    private _size: number = 10;\r\n    @Input()\r\n    public get size(): number {\r\n        return this._size;\r\n    }\r\n    public set size(v: number) {\r\n        this._size = v;\r\n        this._emitStateChangedEvent();\r\n        const newPage = Math.ceil(this.state.range.from / this._size) || 1;\r\n        this.value = newPage;\r\n    }\r\n\r\n\r\n    private _total: number = 0;\r\n    @Input()\r\n    public get total(): number {\r\n        return this._total;\r\n    }\r\n    public set total(v: number) {\r\n        this._total = v && v > 0 ? v : 0;\r\n        this._emitStateChangedEvent();\r\n    }\r\n\r\n    private _totalPages: number = 0;\r\n\r\n    public get totalPages(): number {\r\n        return this._totalPages;\r\n    }\r\n\r\n    private set totalPages(value: number) {\r\n        this._totalPages = value;\r\n    }\r\n\r\n    @Input()\r\n    displayMode: AXDataPagerDisplayMode = 'full'\r\n\r\n    @Output()\r\n    onStateChanged: EventEmitter<AXPagerStateChangedEvent> = new EventEmitter<AXPagerStateChangedEvent>();\r\n\r\n    constructor(\r\n        private _elementRef: ElementRef,\r\n        private _cdr: ChangeDetectorRef,\r\n        @Optional()\r\n        @Inject(AXPagedComponent)\r\n        private _parent?: AXPagedComponent\r\n    ) {\r\n        super(_elementRef, _cdr);\r\n    }\r\n\r\n    onInit() {\r\n        if (this._parent) {\r\n            this._parent.onPageChanged.subscribe(c => {\r\n                this.size = this._parent.pageSize;\r\n                this.total = this._parent.totalCount;\r\n                this.value = c.value;\r\n            });\r\n            this.size = this._parent.pageSize;\r\n            this.total = this._parent.totalCount;\r\n        }\r\n        this.goFirstPage();\r\n    }\r\n\r\n    onViewInit() {\r\n        this._emitStateChangedEvent();\r\n    }\r\n\r\n    _onValueChanged(oldValue: number, newValue: number) {\r\n        this._emitStateChangedEvent();\r\n        this._parent?.goToPage(newValue);\r\n    }\r\n\r\n    _getValue(value: any) {\r\n        return (!isNumber(value) || value < 1) ? 1 : (value > this.totalPages ? this.totalPages : value);\r\n    }\r\n\r\n    public get state(): AXDataPagerInfoData {\r\n        const skip = (this.value - 1) * this.size;\r\n        return {\r\n            page: this.value,\r\n            totalItems: this.total,\r\n            totalPages: this.totalPages,\r\n            range: {\r\n                from: skip + 1,\r\n                to: Math.min((this.value * this.size), this.total)\r\n            },\r\n            skip,\r\n            take: this.size,\r\n        }\r\n    }\r\n\r\n    private _emitStateChangedEvent(): void {\r\n        this.totalPages = Math.ceil(this._total / this.size);\r\n        //\r\n        this.onStateChanged.emit(\r\n            Object.assign({\r\n                component: this,\r\n                htmlElement: this._elementRef.nativeElement\r\n            }, this.state)\r\n        );\r\n    }\r\n\r\n    goNextPage(): void {\r\n        this.goToPage(Math.min(++this.value, this.totalPages));\r\n    }\r\n\r\n    goLastPage(): void {\r\n        this.goToPage(this.totalPages);\r\n    }\r\n\r\n    goFirstPage(): void {\r\n        this.goToPage(1);\r\n    }\r\n\r\n    goPrevPage(): void {\r\n        this.goToPage(Math.max(--this.value, 1));\r\n    }\r\n\r\n    goToPage(page: number): void {\r\n        if (page != this.value) {\r\n            this.value = page;\r\n        }\r\n    }\r\n}\r\n","<ng-container [ngSwitch]=\"displayMode\">\r\n    <ng-container *ngSwitchCase=\"'full'\">\r\n        <ax-prefix>\r\n            <ax-data-pager-numeric-selector>\r\n            </ax-data-pager-numeric-selector>\r\n            <ax-data-pager-page-sizes>\r\n            </ax-data-pager-page-sizes>\r\n        </ax-prefix>\r\n        <ax-suffix>\r\n            <ax-data-pager-info>\r\n            </ax-data-pager-info>\r\n        </ax-suffix>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'compact'\">\r\n        <ax-prefix>\r\n            <ax-data-pager-prev-buttons>\r\n            </ax-data-pager-prev-buttons>\r\n            <ax-data-pager-input-selector>\r\n            </ax-data-pager-input-selector>\r\n            <ax-data-pager-next-buttons>\r\n            </ax-data-pager-next-buttons>\r\n        </ax-prefix>\r\n        <ax-suffix>\r\n            <ax-data-pager-info>\r\n            </ax-data-pager-info>\r\n        </ax-suffix>\r\n    </ng-container>\r\n    <ng-container *ngSwitchDefault>\r\n        <ng-content select=\"ax-prefix\"></ng-content>\r\n        <ng-content select=\"ax-suffix\"></ng-content>\r\n    </ng-container>\r\n</ng-container>\r\n\r\n"]}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AXDataPagerComponent } from './data-pager.component';
|
|
4
|
+
import { AXDataPagerNextButtonsComponent } from './data-pager-next-buttons.components';
|
|
5
|
+
import { AXButtonModule } from '../button';
|
|
6
|
+
import { AXDataPagerPrevButtonsComponent } from './data-pager-prev-buttons.component';
|
|
7
|
+
import { AXDataPagerPageSizesComponent } from './data-pager-pagesize-dropdown.component';
|
|
8
|
+
import { AXDataPagerNumericSelectorComponent } from './data-pager-numeric-selector.component';
|
|
9
|
+
import { AXDataPagerInputSelectorComponent } from './data-pager-input-selector.component';
|
|
10
|
+
import { AXDataPagerInfoComponent } from './data-pager-info.component';
|
|
11
|
+
import { AXNumberBoxModule } from '../number-box';
|
|
12
|
+
import { AXDropdownModule } from '../dropdown';
|
|
13
|
+
import { AXDecoratorModule } from '../decorators';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
const COMPONENT = [
|
|
16
|
+
AXDataPagerComponent,
|
|
17
|
+
AXDataPagerNextButtonsComponent,
|
|
18
|
+
AXDataPagerPrevButtonsComponent,
|
|
19
|
+
AXDataPagerPageSizesComponent,
|
|
20
|
+
AXDataPagerNumericSelectorComponent,
|
|
21
|
+
AXDataPagerInputSelectorComponent,
|
|
22
|
+
AXDataPagerInfoComponent
|
|
23
|
+
];
|
|
24
|
+
const MODULES = [CommonModule, AXButtonModule, AXNumberBoxModule, AXDropdownModule, AXDecoratorModule];
|
|
25
|
+
export class AXDataPagerModule {
|
|
26
|
+
}
|
|
27
|
+
AXDataPagerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataPagerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
28
|
+
AXDataPagerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.0", ngImport: i0, type: AXDataPagerModule, declarations: [AXDataPagerComponent,
|
|
29
|
+
AXDataPagerNextButtonsComponent,
|
|
30
|
+
AXDataPagerPrevButtonsComponent,
|
|
31
|
+
AXDataPagerPageSizesComponent,
|
|
32
|
+
AXDataPagerNumericSelectorComponent,
|
|
33
|
+
AXDataPagerInputSelectorComponent,
|
|
34
|
+
AXDataPagerInfoComponent], imports: [CommonModule, AXButtonModule, AXNumberBoxModule, AXDropdownModule, AXDecoratorModule], exports: [AXDataPagerComponent,
|
|
35
|
+
AXDataPagerNextButtonsComponent,
|
|
36
|
+
AXDataPagerPrevButtonsComponent,
|
|
37
|
+
AXDataPagerPageSizesComponent,
|
|
38
|
+
AXDataPagerNumericSelectorComponent,
|
|
39
|
+
AXDataPagerInputSelectorComponent,
|
|
40
|
+
AXDataPagerInfoComponent] });
|
|
41
|
+
AXDataPagerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataPagerModule, providers: [], imports: [MODULES] });
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataPagerModule, decorators: [{
|
|
43
|
+
type: NgModule,
|
|
44
|
+
args: [{
|
|
45
|
+
declarations: [...COMPONENT],
|
|
46
|
+
imports: [...MODULES],
|
|
47
|
+
exports: [...COMPONENT],
|
|
48
|
+
providers: [],
|
|
49
|
+
}]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1wYWdlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2RhdGEtcGFnZXIvZGF0YS1wYWdlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDOUQsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUMzQyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUN0RixPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUN6RixPQUFPLEVBQUUsbUNBQW1DLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RixPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMxRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN2RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFbEQsTUFBTSxTQUFTLEdBQUc7SUFDZCxvQkFBb0I7SUFDcEIsK0JBQStCO0lBQy9CLCtCQUErQjtJQUMvQiw2QkFBNkI7SUFDN0IsbUNBQW1DO0lBQ25DLGlDQUFpQztJQUNqQyx3QkFBd0I7Q0FDM0IsQ0FBQztBQUNGLE1BQU0sT0FBTyxHQUFHLENBQUMsWUFBWSxFQUFFLGNBQWMsRUFBRSxpQkFBaUIsRUFBQyxnQkFBZ0IsRUFBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBUXJHLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFoQjFCLG9CQUFvQjtRQUNwQiwrQkFBK0I7UUFDL0IsK0JBQStCO1FBQy9CLDZCQUE2QjtRQUM3QixtQ0FBbUM7UUFDbkMsaUNBQWlDO1FBQ2pDLHdCQUF3QixhQUVYLFlBQVksRUFBRSxjQUFjLEVBQUUsaUJBQWlCLEVBQUMsZ0JBQWdCLEVBQUMsaUJBQWlCLGFBUi9GLG9CQUFvQjtRQUNwQiwrQkFBK0I7UUFDL0IsK0JBQStCO1FBQy9CLDZCQUE2QjtRQUM3QixtQ0FBbUM7UUFDbkMsaUNBQWlDO1FBQ2pDLHdCQUF3QjsrR0FVZixpQkFBaUIsYUFGZixFQUFFLFlBRkEsT0FBTzsyRkFJWCxpQkFBaUI7a0JBTjdCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLEdBQUcsT0FBTyxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDdkIsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQVhEYXRhUGFnZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtcGFnZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhEYXRhUGFnZXJOZXh0QnV0dG9uc0NvbXBvbmVudCB9IGZyb20gJy4vZGF0YS1wYWdlci1uZXh0LWJ1dHRvbnMuY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IEFYQnV0dG9uTW9kdWxlIH0gZnJvbSAnLi4vYnV0dG9uJztcclxuaW1wb3J0IHsgQVhEYXRhUGFnZXJQcmV2QnV0dG9uc0NvbXBvbmVudCB9IGZyb20gJy4vZGF0YS1wYWdlci1wcmV2LWJ1dHRvbnMuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhEYXRhUGFnZXJQYWdlU2l6ZXNDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtcGFnZXItcGFnZXNpemUtZHJvcGRvd24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhEYXRhUGFnZXJOdW1lcmljU2VsZWN0b3JDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtcGFnZXItbnVtZXJpYy1zZWxlY3Rvci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWERhdGFQYWdlcklucHV0U2VsZWN0b3JDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtcGFnZXItaW5wdXQtc2VsZWN0b3IuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhEYXRhUGFnZXJJbmZvQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLXBhZ2VyLWluZm8uY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhOdW1iZXJCb3hNb2R1bGUgfSBmcm9tICcuLi9udW1iZXItYm94JztcclxuaW1wb3J0IHsgQVhEcm9wZG93bk1vZHVsZSB9IGZyb20gJy4uL2Ryb3Bkb3duJztcclxuaW1wb3J0IHsgQVhEZWNvcmF0b3JNb2R1bGUgfSBmcm9tICcuLi9kZWNvcmF0b3JzJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVCA9IFtcclxuICAgIEFYRGF0YVBhZ2VyQ29tcG9uZW50LFxyXG4gICAgQVhEYXRhUGFnZXJOZXh0QnV0dG9uc0NvbXBvbmVudCxcclxuICAgIEFYRGF0YVBhZ2VyUHJldkJ1dHRvbnNDb21wb25lbnQsXHJcbiAgICBBWERhdGFQYWdlclBhZ2VTaXplc0NvbXBvbmVudCxcclxuICAgIEFYRGF0YVBhZ2VyTnVtZXJpY1NlbGVjdG9yQ29tcG9uZW50LFxyXG4gICAgQVhEYXRhUGFnZXJJbnB1dFNlbGVjdG9yQ29tcG9uZW50LFxyXG4gICAgQVhEYXRhUGFnZXJJbmZvQ29tcG9uZW50XHJcbl07XHJcbmNvbnN0IE1PRFVMRVMgPSBbQ29tbW9uTW9kdWxlLCBBWEJ1dHRvbk1vZHVsZSwgQVhOdW1iZXJCb3hNb2R1bGUsQVhEcm9wZG93bk1vZHVsZSxBWERlY29yYXRvck1vZHVsZV07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQ09NUE9ORU5UXSxcclxuICAgIGltcG9ydHM6IFsuLi5NT0RVTEVTXSxcclxuICAgIGV4cG9ydHM6IFsuLi5DT01QT05FTlRdLFxyXG4gICAgcHJvdmlkZXJzOiBbXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYRGF0YVBhZ2VyTW9kdWxlIHsgfVxyXG4iXX0=
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from './data-pager.component';
|
|
2
|
+
export * from './data-pager-next-buttons.components';
|
|
3
|
+
export * from './data-pager-prev-buttons.component';
|
|
4
|
+
export * from './data-pager-pagesize-dropdown.component';
|
|
5
|
+
export * from './data-pager-numeric-selector.component';
|
|
6
|
+
export * from './data-pager-input-selector.component';
|
|
7
|
+
export * from './data-pager-info.component';
|
|
8
|
+
export * from './data-pager.module';
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2RhdGEtcGFnZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kYXRhLXBhZ2VyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1wYWdlci1uZXh0LWJ1dHRvbnMuY29tcG9uZW50cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1wYWdlci1wcmV2LWJ1dHRvbnMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9kYXRhLXBhZ2VyLXBhZ2VzaXplLWRyb3Bkb3duLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1wYWdlci1udW1lcmljLXNlbGVjdG9yLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1wYWdlci1pbnB1dC1zZWxlY3Rvci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtcGFnZXItaW5mby5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtcGFnZXIubW9kdWxlJztcclxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ContentChild, Directive, TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class AXDataColumnCellTemplateDirective {
|
|
4
|
+
get template() {
|
|
5
|
+
return this._contentTemplate;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
AXDataColumnCellTemplateDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataColumnCellTemplateDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
+
AXDataColumnCellTemplateDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.0", type: AXDataColumnCellTemplateDirective, selector: "ax-data-column-cell-template", queries: [{ propertyName: "_contentTemplate", first: true, predicate: TemplateRef, descendants: true, static: true }], ngImport: i0 });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataColumnCellTemplateDirective, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{ selector: 'ax-data-column-cell-template' }]
|
|
13
|
+
}], propDecorators: { _contentTemplate: [{
|
|
14
|
+
type: ContentChild,
|
|
15
|
+
args: [TemplateRef, { static: true }]
|
|
16
|
+
}] } });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1jb2x1bW4tY2VsbC10ZW1wbGF0ZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS1jb2x1bW4tY2VsbC10ZW1wbGF0ZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUdyRSxNQUFNLE9BQU8saUNBQWlDO0lBTTFDLElBQUksUUFBUTtRQUNSLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDO0lBQ2pDLENBQUM7OzhIQVJRLGlDQUFpQztrSEFBakMsaUNBQWlDLGtIQUU1QixXQUFXOzJGQUZoQixpQ0FBaUM7a0JBRDdDLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsOEJBQThCLEVBQUU7OEJBSW5ELGdCQUFnQjtzQkFEZixZQUFZO3VCQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250ZW50Q2hpbGQsIERpcmVjdGl2ZSwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ2F4LWRhdGEtY29sdW1uLWNlbGwtdGVtcGxhdGUnIH0pXHJcbmV4cG9ydCBjbGFzcyBBWERhdGFDb2x1bW5DZWxsVGVtcGxhdGVEaXJlY3RpdmUge1xyXG5cclxuICAgIEBDb250ZW50Q2hpbGQoVGVtcGxhdGVSZWYsIHsgc3RhdGljOiB0cnVlIH0pXHJcbiAgICBfY29udGVudFRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuXHJcbiAgICBnZXQgdGVtcGxhdGUoKTogVGVtcGxhdGVSZWY8YW55PiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX2NvbnRlbnRUZW1wbGF0ZTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Input, ContentChild, Directive, TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class AXDataColumnComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.width = 'auto';
|
|
6
|
+
}
|
|
7
|
+
get headerTemplate() {
|
|
8
|
+
return this._inputHeaderTemplate || this._contentHeaderTemplate;
|
|
9
|
+
}
|
|
10
|
+
get cellTemplate() {
|
|
11
|
+
return this._inputCellTemplate || this._contentCellTemplate || this._defaultTemplate;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
AXDataColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
15
|
+
AXDataColumnComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.0", type: AXDataColumnComponent, selector: "ax-data-column", inputs: { _inputHeaderTemplate: ["headerTemplate", "_inputHeaderTemplate"], _inputCellTemplate: ["cellTemplate", "_inputCellTemplate"], valueField: "valueField", caption: "caption", width: "width" }, queries: [{ propertyName: "_contentHeaderTemplate", first: true, predicate: ["header"], descendants: true, static: true }, { propertyName: "_defaultTemplate", first: true, predicate: TemplateRef, descendants: true, static: true }, { propertyName: "_contentCellTemplate", first: true, predicate: ["cell"], descendants: true, static: true }], ngImport: i0 });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataColumnComponent, decorators: [{
|
|
17
|
+
type: Directive,
|
|
18
|
+
args: [{
|
|
19
|
+
selector: 'ax-data-column',
|
|
20
|
+
}]
|
|
21
|
+
}], propDecorators: { _inputHeaderTemplate: [{
|
|
22
|
+
type: Input,
|
|
23
|
+
args: ["headerTemplate"]
|
|
24
|
+
}], _contentHeaderTemplate: [{
|
|
25
|
+
type: ContentChild,
|
|
26
|
+
args: ["header", { static: true }]
|
|
27
|
+
}], _defaultTemplate: [{
|
|
28
|
+
type: ContentChild,
|
|
29
|
+
args: [TemplateRef, { static: true }]
|
|
30
|
+
}], _inputCellTemplate: [{
|
|
31
|
+
type: Input,
|
|
32
|
+
args: ["cellTemplate"]
|
|
33
|
+
}], _contentCellTemplate: [{
|
|
34
|
+
type: ContentChild,
|
|
35
|
+
args: ["cell", { static: true }]
|
|
36
|
+
}], valueField: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}], caption: [{
|
|
39
|
+
type: Input
|
|
40
|
+
}], width: [{
|
|
41
|
+
type: Input
|
|
42
|
+
}] } });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1jb2x1bW4uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9kYXRhLXRhYmxlL2RhdGEtY29sdW1uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUs1RSxNQUFNLE9BQU8scUJBQXFCO0lBSGxDO1FBeUNJLFVBQUssR0FBb0IsTUFBTSxDQUFDO0tBQ25DO0lBNUJHLElBQUksY0FBYztRQUVkLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixJQUFJLElBQUksQ0FBQyxzQkFBc0IsQ0FBRTtJQUNyRSxDQUFDO0lBU0QsSUFBSSxZQUFZO1FBRVosT0FBTyxJQUFJLENBQUMsa0JBQWtCLElBQUksSUFBSSxDQUFDLG9CQUFvQixJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUN6RixDQUFDOztrSEExQlEscUJBQXFCO3NHQUFyQixxQkFBcUIsNlpBUWhCLFdBQVc7MkZBUmhCLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZ0JBQWdCO2lCQUM3Qjs4QkFJRyxvQkFBb0I7c0JBRG5CLEtBQUs7dUJBQUMsZ0JBQWdCO2dCQUl2QixzQkFBc0I7c0JBRHJCLFlBQVk7dUJBQUMsUUFBUSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFJeEMsZ0JBQWdCO3NCQURmLFlBQVk7dUJBQUMsV0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFVM0Msa0JBQWtCO3NCQURqQixLQUFLO3VCQUFDLGNBQWM7Z0JBSXJCLG9CQUFvQjtzQkFEbkIsWUFBWTt1QkFBQyxNQUFNLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO2dCQVl0QyxVQUFVO3NCQURULEtBQUs7Z0JBSU4sT0FBTztzQkFETixLQUFLO2dCQUlOLEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElucHV0LCBDb250ZW50Q2hpbGQsIERpcmVjdGl2ZSwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gICAgc2VsZWN0b3I6ICdheC1kYXRhLWNvbHVtbicsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWERhdGFDb2x1bW5Db21wb25lbnQge1xyXG5cclxuICAgIEBJbnB1dChcImhlYWRlclRlbXBsYXRlXCIpXHJcbiAgICBfaW5wdXRIZWFkZXJUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gICAgQENvbnRlbnRDaGlsZChcImhlYWRlclwiLCB7IHN0YXRpYzogdHJ1ZSB9KVxyXG4gICAgX2NvbnRlbnRIZWFkZXJUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gICAgQENvbnRlbnRDaGlsZChUZW1wbGF0ZVJlZiwgeyBzdGF0aWM6IHRydWUgfSlcclxuICAgIF9kZWZhdWx0VGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICAgIGdldCBoZWFkZXJUZW1wbGF0ZSgpOlRlbXBsYXRlUmVmPGFueT5cclxuICAgIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5faW5wdXRIZWFkZXJUZW1wbGF0ZSB8fCB0aGlzLl9jb250ZW50SGVhZGVyVGVtcGxhdGUgO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBASW5wdXQoXCJjZWxsVGVtcGxhdGVcIilcclxuICAgIF9pbnB1dENlbGxUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gICAgQENvbnRlbnRDaGlsZChcImNlbGxcIiwgeyBzdGF0aWM6IHRydWUgfSlcclxuICAgIF9jb250ZW50Q2VsbFRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgICBnZXQgY2VsbFRlbXBsYXRlKCk6VGVtcGxhdGVSZWY8YW55PlxyXG4gICAge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9pbnB1dENlbGxUZW1wbGF0ZSB8fCB0aGlzLl9jb250ZW50Q2VsbFRlbXBsYXRlIHx8IHRoaXMuX2RlZmF1bHRUZW1wbGF0ZTtcclxuICAgIH1cclxuXHJcbiAgICAvLyBAQ29udGVudENoaWxkKEFYRGF0YUNvbHVtbkNlbGxUZW1wbGF0ZURpcmVjdGl2ZSwgeyBzdGF0aWM6IHRydWUgfSlcclxuICAgIC8vIGNlbGxUZW1wbGF0ZT86IEFYRGF0YUNvbHVtbkNlbGxUZW1wbGF0ZURpcmVjdGl2ZTtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgdmFsdWVGaWVsZDogc3RyaW5nO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBjYXB0aW9uOiBzdHJpbmc7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHdpZHRoOiBzdHJpbmcgfCBudW1iZXIgPSAnYXV0byc7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, ContentChildren, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
import { AXBaseComponentMixin, AXPagedComponent } from '../base';
|
|
3
|
+
import { AXDataColumnComponent } from './data-column.directive';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "../result/result.component";
|
|
7
|
+
import * as i3 from "../loading/loading.directive";
|
|
8
|
+
import * as i4 from "@acorex/core";
|
|
9
|
+
export class AXDataTableComponent extends AXBaseComponentMixin {
|
|
10
|
+
constructor(elementRef, cdr) {
|
|
11
|
+
super(elementRef, cdr);
|
|
12
|
+
this._columns = {};
|
|
13
|
+
this.onPageChanged = new EventEmitter();
|
|
14
|
+
this._pageSize = 20;
|
|
15
|
+
this.fetchDataMode = "auto";
|
|
16
|
+
this._currentPage = 1;
|
|
17
|
+
this._isLoading = false;
|
|
18
|
+
this._loadedItems = [];
|
|
19
|
+
this._totalItems = 0;
|
|
20
|
+
this._isLazy = false;
|
|
21
|
+
this._items = [];
|
|
22
|
+
}
|
|
23
|
+
get pageSize() {
|
|
24
|
+
return this._pageSize;
|
|
25
|
+
}
|
|
26
|
+
set pageSize(v) {
|
|
27
|
+
this._pageSize = v;
|
|
28
|
+
}
|
|
29
|
+
get totalCount() {
|
|
30
|
+
return this._totalItems;
|
|
31
|
+
}
|
|
32
|
+
get isLazy() {
|
|
33
|
+
return this._isLazy;
|
|
34
|
+
}
|
|
35
|
+
get loadedCount() {
|
|
36
|
+
return this._loadedItems?.length || 0;
|
|
37
|
+
}
|
|
38
|
+
get items() {
|
|
39
|
+
return this._items;
|
|
40
|
+
}
|
|
41
|
+
set items(v) {
|
|
42
|
+
if (Array.isArray(v)) {
|
|
43
|
+
this._items = v;
|
|
44
|
+
}
|
|
45
|
+
else if (typeof v === 'function') {
|
|
46
|
+
this._isLazy = true;
|
|
47
|
+
this._items = v;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
this._items = [];
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
get displayItems() {
|
|
54
|
+
if (Array.isArray(this.items)) {
|
|
55
|
+
return (this._items || []);
|
|
56
|
+
}
|
|
57
|
+
else if (typeof this._items == 'function') {
|
|
58
|
+
return this._loadedItems || [];
|
|
59
|
+
}
|
|
60
|
+
return [];
|
|
61
|
+
}
|
|
62
|
+
onViewInit() {
|
|
63
|
+
if (this.fetchDataMode == 'auto')
|
|
64
|
+
this._fetchData();
|
|
65
|
+
}
|
|
66
|
+
_fetchData(opts) {
|
|
67
|
+
const skip = (this._currentPage - 1) * this.pageSize, take = this.pageSize;
|
|
68
|
+
if ((this.loadedCount >= this.totalCount && this.totalCount != 0) || this._isLoading || !this._isLazy || (skip > this.totalCount)) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
if (this._items) {
|
|
72
|
+
this._isLoading = true;
|
|
73
|
+
this._cdr.markForCheck();
|
|
74
|
+
const fetchFn = this._items;
|
|
75
|
+
fetchFn({ skip, take, searchQuery: opts?.searchQuery }).then(c => {
|
|
76
|
+
if (Array.isArray(c)) {
|
|
77
|
+
this._loadedItems = c;
|
|
78
|
+
this._totalItems = c.length;
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
this._totalItems = c.total || c.items?.length || 0;
|
|
82
|
+
//this._loadedItems = [...new Set(this._loadedItems.concat(c.items))];
|
|
83
|
+
this._loadedItems = [...new Set(c.items)];
|
|
84
|
+
}
|
|
85
|
+
}).finally(() => {
|
|
86
|
+
this._isLoading = false;
|
|
87
|
+
this.onPageChanged.next({
|
|
88
|
+
component: this,
|
|
89
|
+
isUserInteraction: false,
|
|
90
|
+
name: 'page',
|
|
91
|
+
value: this._currentPage
|
|
92
|
+
});
|
|
93
|
+
this._cdr.markForCheck();
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
refresh() {
|
|
98
|
+
this._fetchData();
|
|
99
|
+
}
|
|
100
|
+
goToPage(page) {
|
|
101
|
+
this._currentPage = page;
|
|
102
|
+
this.refresh();
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
AXDataTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataTableComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
106
|
+
AXDataTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: AXDataTableComponent, selector: "ax-data-table", inputs: { rowTemplate: "rowTemplate", pageSize: "pageSize", fetchDataMode: "fetchDataMode", items: "items" }, outputs: { onPageChanged: "onPageChanged" }, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], queries: [{ propertyName: "_columns", predicate: AXDataColumnComponent }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n <table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n <thead>\r\n \r\n <tr>\r\n <th *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n </ng-template>\r\n <ng-template #captionTpl>\r\n {{c.caption}}\r\n </ng-template>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #rowTpl>\r\n <tr>\r\n <ng-container *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #cellTpl>\r\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n {{d[c.valueField]}}\r\n </td>\r\n </ng-template>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #emptyTpl>\r\n <tr>\r\n <td [attr.colspan]=\"_columns.length\">\r\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </tbody>\r\n </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>\r\n\r\n<!-- <br>\r\n<table class=\"ax-table ax-table-responsive ax-table-alternate\">\r\n <thead>\r\n <col>\r\n <colgroup span=\"2\"></colgroup>\r\n <colgroup span=\"2\"></colgroup>\r\n <tr>\r\n <th rowspan=\"2\">Index</th>\r\n <th colspan=\"2\" scope=\"colgroup\">Mars</th>\r\n <th colspan=\"2\" scope=\"colgroup\">Venus</th>\r\n </tr>\r\n <tr>\r\n <th scope=\"col\">Produced</th>\r\n <th scope=\"col\">Sold</th>\r\n <th scope=\"col\">Produced</th>\r\n <th scope=\"col\">Sold</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr>\r\n <td >Teddy Bears</td>\r\n <td>50,000</td>\r\n <td>30,000</td>\r\n <td>100,000</td>\r\n <td>80,000</td>\r\n </tr>\r\n <tr>\r\n <td >Board Games</td>\r\n <td>10,000</td>\r\n <td>5,000</td>\r\n <td>12,000</td>\r\n <td>9,000</td>\r\n </tr>\r\n </tbody>\r\n </table> -->", dependencies: [{ 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: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXResultComponent, selector: "ax-result", inputs: ["type", "caption", "description"] }, { kind: "directive", type: i3.AXLoadingDirective, selector: "[axIsLoading]", inputs: ["axIsLoading"] }, { kind: "pipe", type: i4.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
107
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataTableComponent, decorators: [{
|
|
108
|
+
type: Component,
|
|
109
|
+
args: [{ selector: 'ax-data-table', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], template: "<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n <table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n <thead>\r\n \r\n <tr>\r\n <th *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n </ng-template>\r\n <ng-template #captionTpl>\r\n {{c.caption}}\r\n </ng-template>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #rowTpl>\r\n <tr>\r\n <ng-container *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #cellTpl>\r\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n {{d[c.valueField]}}\r\n </td>\r\n </ng-template>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #emptyTpl>\r\n <tr>\r\n <td [attr.colspan]=\"_columns.length\">\r\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </tbody>\r\n </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>\r\n\r\n<!-- <br>\r\n<table class=\"ax-table ax-table-responsive ax-table-alternate\">\r\n <thead>\r\n <col>\r\n <colgroup span=\"2\"></colgroup>\r\n <colgroup span=\"2\"></colgroup>\r\n <tr>\r\n <th rowspan=\"2\">Index</th>\r\n <th colspan=\"2\" scope=\"colgroup\">Mars</th>\r\n <th colspan=\"2\" scope=\"colgroup\">Venus</th>\r\n </tr>\r\n <tr>\r\n <th scope=\"col\">Produced</th>\r\n <th scope=\"col\">Sold</th>\r\n <th scope=\"col\">Produced</th>\r\n <th scope=\"col\">Sold</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr>\r\n <td >Teddy Bears</td>\r\n <td>50,000</td>\r\n <td>30,000</td>\r\n <td>100,000</td>\r\n <td>80,000</td>\r\n </tr>\r\n <tr>\r\n <td >Board Games</td>\r\n <td>10,000</td>\r\n <td>5,000</td>\r\n <td>12,000</td>\r\n <td>9,000</td>\r\n </tr>\r\n </tbody>\r\n </table> -->" }]
|
|
110
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _columns: [{
|
|
111
|
+
type: ContentChildren,
|
|
112
|
+
args: [AXDataColumnComponent]
|
|
113
|
+
}], onPageChanged: [{
|
|
114
|
+
type: Output
|
|
115
|
+
}], rowTemplate: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], pageSize: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], fetchDataMode: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], items: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}] } });
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/data-table/data-table.component.ts","../../../../../../projects/acorex/components/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, ChangeDetectorRef, Input, ContentChildren, QueryList, TemplateRef, EventEmitter, Output } from '@angular/core';\r\nimport { AXBaseComponentMixin, AXDataListFetchDataCallback, AXDataListItems, AXPagedComponent, AXPagedComponentInterface, AXValueChangedEvent } from '../base';\r\nimport { AXDataColumnComponent } from './data-column.directive';\r\n\r\n@Component({\r\n    selector: 'ax-data-table',\r\n    templateUrl: './data-table.component.html',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    encapsulation: ViewEncapsulation.None,\r\n    providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }]\r\n})\r\nexport class AXDataTableComponent extends AXBaseComponentMixin implements AXPagedComponentInterface {\r\n\r\n\r\n    @ContentChildren(AXDataColumnComponent)\r\n    _columns: QueryList<AXDataColumnComponent> = {} as QueryList<AXDataColumnComponent>;\r\n\r\n\r\n    @Output()\r\n    onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<AXValueChangedEvent<number>>();\r\n\r\n\r\n    @Input()\r\n    rowTemplate?: TemplateRef<any>;\r\n\r\n\r\n    private _pageSize: number = 20;\r\n    @Input()\r\n    public get pageSize(): number {\r\n        return this._pageSize;\r\n    }\r\n    public set pageSize(v: number) {\r\n        this._pageSize = v;\r\n    }\r\n\r\n\r\n\r\n    @Input()\r\n    fetchDataMode: 'auto' | 'manual' = \"auto\";\r\n\r\n    private _currentPage: number = 1;\r\n    _isLoading: boolean = false;\r\n    private _loadedItems: any[] = [];\r\n    private _totalItems: number = 0;\r\n\r\n    private _isLazy: boolean = false;\r\n\r\n    get totalCount(): number {\r\n        return this._totalItems;\r\n    }\r\n\r\n    get isLazy(): boolean {\r\n        return this._isLazy;\r\n    }\r\n\r\n    get loadedCount(): number {\r\n        return this._loadedItems?.length || 0;\r\n    }\r\n\r\n    private _items: AXDataListItems = [];\r\n\r\n    @Input()\r\n    get items(): AXDataListItems {\r\n        return this._items;\r\n    }\r\n    set items(v: AXDataListItems) {\r\n        if (Array.isArray(v)) {\r\n            this._items = v;\r\n        }\r\n        else if (typeof v === 'function') {\r\n            this._isLazy = true;\r\n            this._items = v;\r\n        }\r\n        else {\r\n            this._items = [];\r\n        }\r\n    }\r\n\r\n    get displayItems(): any[] {\r\n        if (Array.isArray(this.items)) {\r\n            return (this._items || []) as any[];\r\n        }\r\n        else if (typeof this._items == 'function') {\r\n            return this._loadedItems || [];\r\n        }\r\n        return [];\r\n    }\r\n\r\n\r\n    constructor(\r\n        elementRef: ElementRef,\r\n        cdr: ChangeDetectorRef\r\n    ) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n\r\n\r\n\r\n    onViewInit(): void {\r\n        if (this.fetchDataMode == 'auto')\r\n            this._fetchData();\r\n    }\r\n\r\n    _fetchData(opts?: { searchQuery?: string }) {\r\n        const skip = (this._currentPage - 1) * this.pageSize, take = this.pageSize;\r\n        if ((this.loadedCount >= this.totalCount && this.totalCount != 0) || this._isLoading || !this._isLazy || (skip > this.totalCount)) {\r\n            return;\r\n        }\r\n        if (this._items) {\r\n            this._isLoading = true;\r\n            this._cdr.markForCheck();\r\n            const fetchFn = this._items as AXDataListFetchDataCallback;\r\n            fetchFn({ skip, take, searchQuery: opts?.searchQuery }).then(c => {\r\n                \r\n                if (Array.isArray(c)) {\r\n                    this._loadedItems = c;\r\n                    this._totalItems = c.length;\r\n                }\r\n                else {\r\n                    this._totalItems = c.total || c.items?.length || 0;\r\n                    //this._loadedItems = [...new Set(this._loadedItems.concat(c.items))];\r\n                    this._loadedItems = [...new Set(c.items)];\r\n                }\r\n            }).finally(() => {\r\n                this._isLoading = false;\r\n                this.onPageChanged.next({\r\n                    component: this,\r\n                    isUserInteraction: false,\r\n                    name: 'page',\r\n                    value: this._currentPage\r\n                });\r\n                this._cdr.markForCheck();\r\n            });\r\n        }\r\n    }\r\n\r\n    refresh() {\r\n        this._fetchData();\r\n    }\r\n\r\n\r\n    goToPage(page: number) {\r\n        this._currentPage = page;\r\n        this.refresh();\r\n    }\r\n\r\n\r\n\r\n}\r\n","<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n  <table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n    <thead>\r\n     \r\n      <tr>\r\n        <th *ngFor=\"let c of _columns\">\r\n          <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n            <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n          </ng-template>\r\n          <ng-template #captionTpl>\r\n            {{c.caption}}\r\n          </ng-template>\r\n        </th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n        <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n          <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n            <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n            </ng-container>\r\n          </ng-template>\r\n          <ng-template #rowTpl>\r\n            <tr>\r\n              <ng-container *ngFor=\"let c of _columns\">\r\n                <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n                  <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n                  </ng-container>\r\n                </ng-template>\r\n                <ng-template #cellTpl>\r\n                  <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n                    {{d[c.valueField]}}\r\n                  </td>\r\n                </ng-template>\r\n              </ng-container>\r\n            </tr>\r\n          </ng-template>\r\n        </ng-container>\r\n      </ng-container>\r\n      <ng-template #emptyTpl>\r\n        <tr>\r\n          <td [attr.colspan]=\"_columns.length\">\r\n            <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    </tbody>\r\n  </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>\r\n\r\n<!-- <br>\r\n<table class=\"ax-table ax-table-responsive  ax-table-alternate\">\r\n    <thead>\r\n      <col>\r\n      <colgroup span=\"2\"></colgroup>\r\n      <colgroup span=\"2\"></colgroup>\r\n      <tr>\r\n        <th rowspan=\"2\">Index</th>\r\n        <th colspan=\"2\" scope=\"colgroup\">Mars</th>\r\n        <th colspan=\"2\" scope=\"colgroup\">Venus</th>\r\n      </tr>\r\n      <tr>\r\n        <th scope=\"col\">Produced</th>\r\n        <th scope=\"col\">Sold</th>\r\n        <th scope=\"col\">Produced</th>\r\n        <th scope=\"col\">Sold</th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <tr>\r\n        <td >Teddy Bears</td>\r\n        <td>50,000</td>\r\n        <td>30,000</td>\r\n        <td>100,000</td>\r\n        <td>80,000</td>\r\n      </tr>\r\n      <tr>\r\n        <td >Board Games</td>\r\n        <td>10,000</td>\r\n        <td>5,000</td>\r\n        <td>12,000</td>\r\n        <td>9,000</td>\r\n      </tr>\r\n    </tbody>\r\n  </table> -->"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AXDataTableComponent } from './data-table.component';
|
|
4
|
+
import { AXDataColumnComponent } from './data-column.directive';
|
|
5
|
+
import { AXDataColumnCellTemplateDirective } from './data-column-cell-template.directive';
|
|
6
|
+
import { AXTranslationModule } from '@acorex/core';
|
|
7
|
+
import { AXResultModule } from '../result';
|
|
8
|
+
import { AXLoadingModule } from '../loading';
|
|
9
|
+
import { AXDecoratorModule } from '../decorators';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
const COMPONENT = [AXDataTableComponent, AXDataColumnComponent, AXDataColumnCellTemplateDirective];
|
|
12
|
+
const MODULES = [CommonModule, AXTranslationModule, AXResultModule, AXLoadingModule, AXDecoratorModule];
|
|
13
|
+
export class AXDataTableModule {
|
|
14
|
+
}
|
|
15
|
+
AXDataTableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
AXDataTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.0", ngImport: i0, type: AXDataTableModule, declarations: [AXDataTableComponent, AXDataColumnComponent, AXDataColumnCellTemplateDirective], imports: [CommonModule, AXTranslationModule, AXResultModule, AXLoadingModule, AXDecoratorModule], exports: [AXDataTableComponent, AXDataColumnComponent, AXDataColumnCellTemplateDirective] });
|
|
17
|
+
AXDataTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataTableModule, providers: [], imports: [MODULES] });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataTableModule, decorators: [{
|
|
19
|
+
type: NgModule,
|
|
20
|
+
args: [{
|
|
21
|
+
declarations: [...COMPONENT],
|
|
22
|
+
imports: [...MODULES],
|
|
23
|
+
exports: [...COMPONENT],
|
|
24
|
+
providers: [],
|
|
25
|
+
}]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDMUYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRWxELE1BQU0sU0FBUyxHQUFHLENBQUMsb0JBQW9CLEVBQUUscUJBQXFCLEVBQUUsaUNBQWlDLENBQUMsQ0FBQztBQUNuRyxNQUFNLE9BQU8sR0FBRyxDQUFDLFlBQVksRUFBRSxtQkFBbUIsRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFDLGlCQUFpQixDQUFDLENBQUM7QUFRdkcsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQVRYLG9CQUFvQixFQUFFLHFCQUFxQixFQUFFLGlDQUFpQyxhQUNoRixZQUFZLEVBQUUsbUJBQW1CLEVBQUUsY0FBYyxFQUFFLGVBQWUsRUFBQyxpQkFBaUIsYUFEbEYsb0JBQW9CLEVBQUUscUJBQXFCLEVBQUUsaUNBQWlDOytHQVNwRixpQkFBaUIsYUFGZixFQUFFLFlBRkEsT0FBTzsyRkFJWCxpQkFBaUI7a0JBTjdCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLEdBQUcsT0FBTyxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDdkIsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQVhEYXRhVGFibGVDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtdGFibGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhEYXRhQ29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLWNvbHVtbi5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBBWERhdGFDb2x1bW5DZWxsVGVtcGxhdGVEaXJlY3RpdmUgfSBmcm9tICcuL2RhdGEtY29sdW1uLWNlbGwtdGVtcGxhdGUuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgQVhUcmFuc2xhdGlvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29yZSc7XHJcbmltcG9ydCB7IEFYUmVzdWx0TW9kdWxlIH0gZnJvbSAnLi4vcmVzdWx0JztcclxuaW1wb3J0IHsgQVhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnLi4vbG9hZGluZyc7XHJcbmltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnLi4vZGVjb3JhdG9ycyc7XHJcblxyXG5jb25zdCBDT01QT05FTlQgPSBbQVhEYXRhVGFibGVDb21wb25lbnQsIEFYRGF0YUNvbHVtbkNvbXBvbmVudCwgQVhEYXRhQ29sdW1uQ2VsbFRlbXBsYXRlRGlyZWN0aXZlXTtcclxuY29uc3QgTU9EVUxFUyA9IFtDb21tb25Nb2R1bGUsIEFYVHJhbnNsYXRpb25Nb2R1bGUsIEFYUmVzdWx0TW9kdWxlLCBBWExvYWRpbmdNb2R1bGUsQVhEZWNvcmF0b3JNb2R1bGVdO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXHJcbiAgICBpbXBvcnRzOiBbLi4uTU9EVUxFU10sXHJcbiAgICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWERhdGFUYWJsZU1vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './data-column.directive';
|
|
2
|
+
export * from './data-table.component';
|
|
3
|
+
export * from './data-column-cell-template.directive';
|
|
4
|
+
export * from './data-table.module';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2RhdGEtdGFibGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGF0YS1jb2x1bW4uZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9kYXRhLXRhYmxlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1jb2x1bW4tY2VsbC10ZW1wbGF0ZS5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtdGFibGUubW9kdWxlJztcclxuIl19
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, ContentChild, ViewChild } from '@angular/core';
|
|
2
2
|
import { AXBaseSelectionValueMixin } from '../base';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "../loading/loading.component";
|
|
6
6
|
import * as i3 from "@acorex/core";
|
|
7
7
|
export class AXDataListComponent extends AXBaseSelectionValueMixin {
|
|
8
8
|
constructor(elementRef, cdr) {
|
|
@@ -48,9 +48,9 @@ export class AXDataListComponent extends AXBaseSelectionValueMixin {
|
|
|
48
48
|
}, 100);
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
|
-
AXDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
52
|
-
AXDataListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
53
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
51
|
+
AXDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataListComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
52
|
+
AXDataListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: AXDataListComponent, selector: "ax-datalist", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", size: "size", value: "value", items: "items", pageSize: "pageSize", itemTemplate: "itemTemplate", emptyTemplate: "emptyTemplate", loadingTemplate: "loadingTemplate" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus" }, host: { classAttribute: "ax-list ax-list-container" }, queries: [{ propertyName: "_contentItemTemplate", first: true, predicate: ["itemTemplate"], descendants: true, static: true }, { propertyName: "_contentEmptyTemplate", first: true, predicate: ["emptyTemplate"], descendants: true, static: true }, { propertyName: "_contentloadingTemplate", first: true, predicate: ["loadingTemplate"], descendants: true, static: true }], viewQueries: [{ propertyName: "_container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-list-items-container ax-default ax-vertical\" (scroll)=\"_handleListScroll($event)\" #container>\r\n <ng-container *ngFor=\"let item of displayItems;trackBy : _trackByFunction\">\r\n <ng-container *ngIf=\"itemTemplate; else elseTemplate\">\r\n <div class=\"ax-list-item\" (click)=\"_handleOnItemClick($event,item)\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item,direction:direction}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <div class=\"ax-list-item\" (click)=\"_handleOnItemClick($event,item)\">\r\n {{ item ? _getItemDisplayTextTemplte(item) : 'Loading...'}}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"(displayItems==null || displayItems.length==0) && !isLoading\">\r\n <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"elseEmptyTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n Empty!\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"isLoading\">\r\n <ng-container *ngIf=\"loadingTemplate; else elseLoadingTemplate\">\r\n <ng-container *ngTemplateOutlet=\"loadingTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseLoadingTemplate>\r\n <div class=\"ax-list-loading-container\">\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n</div>", dependencies: [{ 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: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXLoadingComponent, selector: "ax-loading", inputs: ["visible", "type", "text"], outputs: ["visibleChange"] }, { kind: "pipe", type: i3.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataListComponent, decorators: [{
|
|
54
54
|
type: Component,
|
|
55
55
|
args: [{ selector: 'ax-datalist', inputs: ['disabled', 'readonly', 'tabIndex', 'size', 'value', 'items', 'pageSize'], outputs: ['valueChange', 'onValueChanged', 'onBlur', 'onFocus'], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-list ax-list-container' }, template: "<div class=\"ax-list-items-container ax-default ax-vertical\" (scroll)=\"_handleListScroll($event)\" #container>\r\n <ng-container *ngFor=\"let item of displayItems;trackBy : _trackByFunction\">\r\n <ng-container *ngIf=\"itemTemplate; else elseTemplate\">\r\n <div class=\"ax-list-item\" (click)=\"_handleOnItemClick($event,item)\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item,direction:direction}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <div class=\"ax-list-item\" (click)=\"_handleOnItemClick($event,item)\">\r\n {{ item ? _getItemDisplayTextTemplte(item) : 'Loading...'}}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"(displayItems==null || displayItems.length==0) && !isLoading\">\r\n <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"elseEmptyTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n Empty!\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"isLoading\">\r\n <ng-container *ngIf=\"loadingTemplate; else elseLoadingTemplate\">\r\n <ng-container *ngTemplateOutlet=\"loadingTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseLoadingTemplate>\r\n <div class=\"ax-list-loading-container\">\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n</div>" }]
|
|
56
56
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _container: [{
|
|
@@ -9,10 +9,10 @@ const COMPONENT = [AXDataListComponent];
|
|
|
9
9
|
const MODULES = [CommonModule, AXButtonModule, AXLoadingModule, AXTranslationModule];
|
|
10
10
|
export class AXDataListModule {
|
|
11
11
|
}
|
|
12
|
-
AXDataListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
13
|
-
AXDataListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "
|
|
14
|
-
AXDataListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
12
|
+
AXDataListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
AXDataListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.0", ngImport: i0, type: AXDataListModule, declarations: [AXDataListComponent], imports: [CommonModule, AXButtonModule, AXLoadingModule, AXTranslationModule], exports: [AXDataListComponent] });
|
|
14
|
+
AXDataListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataListModule, providers: [], imports: [MODULES] });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AXDataListModule, decorators: [{
|
|
16
16
|
type: NgModule,
|
|
17
17
|
args: [{
|
|
18
18
|
declarations: [...COMPONENT],
|
|
@@ -21,4 +21,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
|
|
|
21
21
|
providers: [],
|
|
22
22
|
}]
|
|
23
23
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWxpc3QubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9kYXRhbGlzdC9kYXRhbGlzdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQzdDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFJbkQsTUFBTSxTQUFTLEdBQUcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0FBQ3hDLE1BQU0sT0FBTyxHQUFHLENBQUMsWUFBWSxFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztBQVFyRixNQUFNLE9BQU8sZ0JBQWdCOzs2R0FBaEIsZ0JBQWdCOzhHQUFoQixnQkFBZ0IsaUJBVFYsbUJBQW1CLGFBQ3JCLFlBQVksRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFFLG1CQUFtQixhQURoRSxtQkFBbUI7OEdBU3pCLGdCQUFnQixhQUZkLEVBQUUsWUFGQSxPQUFPOzJGQUlYLGdCQUFnQjtrQkFONUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUM7b0JBQ3JCLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsRUFBRTtpQkFDaEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBBWERhdGFMaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9kYXRhbGlzdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWEJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2J1dHRvbic7XHJcbmltcG9ydCB7IEFYTG9hZGluZ01vZHVsZSB9IGZyb20gJy4uL2xvYWRpbmcnO1xyXG5pbXBvcnQgeyBBWFRyYW5zbGF0aW9uTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb3JlJztcclxuXHJcblxyXG5cclxuY29uc3QgQ09NUE9ORU5UID0gW0FYRGF0YUxpc3RDb21wb25lbnRdO1xyXG5jb25zdCBNT0RVTEVTID0gW0NvbW1vbk1vZHVsZSwgQVhCdXR0b25Nb2R1bGUsIEFYTG9hZGluZ01vZHVsZSwgQVhUcmFuc2xhdGlvbk1vZHVsZV07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQ09NUE9ORU5UXSxcclxuICAgIGltcG9ydHM6IFsuLi5NT0RVTEVTXSxcclxuICAgIGV4cG9ydHM6IFsuLi5DT01QT05FTlRdLFxyXG4gICAgcHJvdmlkZXJzOiBbXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYRGF0YUxpc3RNb2R1bGUgeyB9XHJcbiJdfQ==
|