@bnsights/bbsf-controls 1.0.194-beta.8 → 1.2.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/README.md +7 -0
- package/fesm2022/bnsights-bbsf-controls.mjs +378 -345
- package/fesm2022/bnsights-bbsf-controls.mjs.map +1 -1
- package/lib/Shared/Models/DropdownOptions.d.ts +3 -0
- package/lib/Shared/Models/RepeaterOptions.d.ts +2 -0
- package/lib/controls/ConfirmationModal/ConfirmationModal.component.d.ts +0 -1
- package/lib/controls/MapAutoComplete/MapAutoComplete.component.d.ts +0 -1
- package/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.d.ts +1 -1
- package/lib/controls/Repeater/repeater/repeater.component.d.ts +7 -0
- package/lib/controls/Repeater/repeater-table/repeater-table.component.d.ts +7 -0
- package/lib/modules/bbsf-editors.module.d.ts +6 -7
- package/package.json +33 -36
- package/src/lib/assets/Style.scss +2 -0
- package/src/lib/assets/ace-builds/ace.js +1 -1
- package/src/lib/assets/ace-builds/mode-markdown.js +1 -1
- package/esm2022/bnsights-bbsf-controls.mjs +0 -5
- package/esm2022/lib/Shared/Components/app-base-component.mjs +0 -226
- package/esm2022/lib/Shared/Components/ng-tag-input.mjs +0 -336
- package/esm2022/lib/Shared/Directives/appPreventDoubleClick.directive.mjs +0 -39
- package/esm2022/lib/Shared/Directives/template-name.directive.mjs +0 -19
- package/esm2022/lib/Shared/Enums/CalendarView.mjs +0 -8
- package/esm2022/lib/Shared/Enums/ControlLayout.mjs +0 -6
- package/esm2022/lib/Shared/Enums/Countries.mjs +0 -247
- package/esm2022/lib/Shared/Enums/Enums.mjs +0 -36
- package/esm2022/lib/Shared/Enums/FileType.mjs +0 -29
- package/esm2022/lib/Shared/Enums/FilterType.mjs +0 -11
- package/esm2022/lib/Shared/Enums/FontSize.mjs +0 -7
- package/esm2022/lib/Shared/Enums/ForceDirection.mjs +0 -6
- package/esm2022/lib/Shared/Enums/IconPosition.mjs +0 -6
- package/esm2022/lib/Shared/Enums/ImageType.mjs +0 -10
- package/esm2022/lib/Shared/Enums/InputType.mjs +0 -10
- package/esm2022/lib/Shared/Enums/Insert.mjs +0 -9
- package/esm2022/lib/Shared/Enums/LanguageMode.mjs +0 -11
- package/esm2022/lib/Shared/Enums/LanguageValidation.mjs +0 -6
- package/esm2022/lib/Shared/Enums/Markdown.mjs +0 -20
- package/esm2022/lib/Shared/Enums/Misc.mjs +0 -7
- package/esm2022/lib/Shared/Enums/PagingActionMode.mjs +0 -6
- package/esm2022/lib/Shared/Enums/Para.mjs +0 -9
- package/esm2022/lib/Shared/Enums/PickerType.mjs +0 -7
- package/esm2022/lib/Shared/Enums/SelectMode.mjs +0 -6
- package/esm2022/lib/Shared/Enums/StartView.mjs +0 -7
- package/esm2022/lib/Shared/Enums/Style.mjs +0 -8
- package/esm2022/lib/Shared/Enums/StyleConfirmationMode.mjs +0 -7
- package/esm2022/lib/Shared/Enums/TagInputView.mjs +0 -7
- package/esm2022/lib/Shared/Enums/ToolbarButtons.mjs +0 -33
- package/esm2022/lib/Shared/Enums/map-enums.mjs +0 -15
- package/esm2022/lib/Shared/Enums/menu-list-enum.mjs +0 -6
- package/esm2022/lib/Shared/Models/Attribute.mjs +0 -3
- package/esm2022/lib/Shared/Models/AutocompleteDTO.mjs +0 -8
- package/esm2022/lib/Shared/Models/AutocompleteOptions.mjs +0 -39
- package/esm2022/lib/Shared/Models/CalendarDTO.mjs +0 -3
- package/esm2022/lib/Shared/Models/CalendarEventDTO.mjs +0 -3
- package/esm2022/lib/Shared/Models/CalendarOptions.mjs +0 -19
- package/esm2022/lib/Shared/Models/CancelDTO.mjs +0 -7
- package/esm2022/lib/Shared/Models/CaptchaStyle.mjs +0 -3
- package/esm2022/lib/Shared/Models/CheckBoxOptions.mjs +0 -11
- package/esm2022/lib/Shared/Models/ConfirmationModalOptions.mjs +0 -39
- package/esm2022/lib/Shared/Models/ControlOptionsBase.mjs +0 -17
- package/esm2022/lib/Shared/Models/CustomValidation.mjs +0 -14
- package/esm2022/lib/Shared/Models/DatePickerOptions.mjs +0 -40
- package/esm2022/lib/Shared/Models/DropdownListItem.mjs +0 -3
- package/esm2022/lib/Shared/Models/DropdownOptions.mjs +0 -38
- package/esm2022/lib/Shared/Models/EditPersonalImage.mjs +0 -7
- package/esm2022/lib/Shared/Models/EnglishArabicDTO.mjs +0 -10
- package/esm2022/lib/Shared/Models/FileDTO.mjs +0 -24
- package/esm2022/lib/Shared/Models/FileOptions.mjs +0 -15
- package/esm2022/lib/Shared/Models/FileUploadModel.mjs +0 -3
- package/esm2022/lib/Shared/Models/FileUploadOptions.mjs +0 -13
- package/esm2022/lib/Shared/Models/FilterItem.mjs +0 -8
- package/esm2022/lib/Shared/Models/FormOptions.mjs +0 -32
- package/esm2022/lib/Shared/Models/HtmlEditorOptions.mjs +0 -12
- package/esm2022/lib/Shared/Models/ImageUploadOptions.mjs +0 -14
- package/esm2022/lib/Shared/Models/MapAutoCompleteOptions.mjs +0 -12
- package/esm2022/lib/Shared/Models/MapAutocompleteDTO.mjs +0 -6
- package/esm2022/lib/Shared/Models/MarkdownEditorOptions.mjs +0 -24
- package/esm2022/lib/Shared/Models/MultiLingualHtmlEditorOptions.mjs +0 -9
- package/esm2022/lib/Shared/Models/MultiLingualTextAreaOptions.mjs +0 -9
- package/esm2022/lib/Shared/Models/MultiLingualTextBoxOptions.mjs +0 -17
- package/esm2022/lib/Shared/Models/MultilingualControlOptionsBase.mjs +0 -21
- package/esm2022/lib/Shared/Models/MultipleFileUploadModel.mjs +0 -9
- package/esm2022/lib/Shared/Models/PagingDTO.mjs +0 -13
- package/esm2022/lib/Shared/Models/PagingOptions.mjs +0 -49
- package/esm2022/lib/Shared/Models/PagingPayload.mjs +0 -3
- package/esm2022/lib/Shared/Models/PhoneOptions.mjs +0 -16
- package/esm2022/lib/Shared/Models/ProfileImageUploadOptions.mjs +0 -11
- package/esm2022/lib/Shared/Models/ProfilePictureDTO.mjs +0 -3
- package/esm2022/lib/Shared/Models/RadioButtonItem.mjs +0 -3
- package/esm2022/lib/Shared/Models/RadioButtonOptions.mjs +0 -7
- package/esm2022/lib/Shared/Models/RangeNumber.mjs +0 -3
- package/esm2022/lib/Shared/Models/Recaptcha.mjs +0 -6
- package/esm2022/lib/Shared/Models/RecaptchaOptions.mjs +0 -22
- package/esm2022/lib/Shared/Models/RepeaterField.mjs +0 -3
- package/esm2022/lib/Shared/Models/RepeaterOptions.mjs +0 -14
- package/esm2022/lib/Shared/Models/SaveDTO.mjs +0 -7
- package/esm2022/lib/Shared/Models/TagsInputDTO.mjs +0 -3
- package/esm2022/lib/Shared/Models/TagsInputOptions.mjs +0 -56
- package/esm2022/lib/Shared/Models/TextAreaOptions.mjs +0 -19
- package/esm2022/lib/Shared/Models/TextBoxOptions.mjs +0 -27
- package/esm2022/lib/Shared/Models/ToggleSlideOptions.mjs +0 -9
- package/esm2022/lib/Shared/Models/UploadPersonalImage.mjs +0 -7
- package/esm2022/lib/Shared/Models/bread-crumb.mjs +0 -8
- package/esm2022/lib/Shared/Models/control-filter-Item.mjs +0 -6
- package/esm2022/lib/Shared/Models/filter-options.mjs +0 -9
- package/esm2022/lib/Shared/Models/index.mjs +0 -58
- package/esm2022/lib/Shared/Models/page-header-options.mjs +0 -78
- package/esm2022/lib/Shared/Pipes/bbsf-date-time.pipe.mjs +0 -22
- package/esm2022/lib/Shared/Pipes/bbsf-date.pipe.mjs +0 -22
- package/esm2022/lib/Shared/config/environment.mjs +0 -12
- package/esm2022/lib/Shared/default_intl.mjs +0 -29
- package/esm2022/lib/Shared/services/ControlUtility.mjs +0 -162
- package/esm2022/lib/Shared/services/GlobalSettings.service.mjs +0 -30
- package/esm2022/lib/Shared/services/OnPagingFiltersChange.service.mjs +0 -24
- package/esm2022/lib/Shared/services/file-upload.service.mjs +0 -29
- package/esm2022/lib/Shared/services/index.mjs +0 -7
- package/esm2022/lib/Shared/services/render-component-service.service.mjs +0 -32
- package/esm2022/lib/Shared/services/validationErrorMassage.service.mjs +0 -125
- package/esm2022/lib/Shared/utils/date-formatter.mjs +0 -48
- package/esm2022/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.mjs +0 -299
- package/esm2022/lib/controls/Calendar/Calendar.component.mjs +0 -179
- package/esm2022/lib/controls/CheckBox/CheckBox.component.mjs +0 -121
- package/esm2022/lib/controls/ConfirmationModal/ConfirmationModal.component.mjs +0 -143
- package/esm2022/lib/controls/DateTimePicker/DateTimePicker.component.mjs +0 -240
- package/esm2022/lib/controls/DropdownList/DropdownList.component.mjs +0 -296
- package/esm2022/lib/controls/FileUpload/FileUpload.component.mjs +0 -741
- package/esm2022/lib/controls/Form/Form.component.mjs +0 -117
- package/esm2022/lib/controls/HtmlEditor/HtmlEditor.component.mjs +0 -185
- package/esm2022/lib/controls/ImageUpload/ImageUpload.component.mjs +0 -360
- package/esm2022/lib/controls/MapAutoComplete/MapAutoComplete.component.mjs +0 -502
- package/esm2022/lib/controls/MarkdownEditor/markdown-editor.component.mjs +0 -243
- package/esm2022/lib/controls/MultiLingualHtmlEditor/MultiLingualHtmlEditor.component.mjs +0 -456
- package/esm2022/lib/controls/MultiLingualTextArea/MultiLingualTextArea.component.mjs +0 -441
- package/esm2022/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.mjs +0 -500
- package/esm2022/lib/controls/Paging/JwPagination.component.mjs +0 -160
- package/esm2022/lib/controls/Paging/Paging.component.mjs +0 -623
- package/esm2022/lib/controls/Phone/Phone.component.mjs +0 -134
- package/esm2022/lib/controls/ProfileImageUploader/ProfileImageUploader.component.mjs +0 -390
- package/esm2022/lib/controls/RadioButton/RadioButton.component.mjs +0 -113
- package/esm2022/lib/controls/Recaptcha/Recaptcha.component.mjs +0 -134
- package/esm2022/lib/controls/Repeater/repeater/repeater.component.mjs +0 -135
- package/esm2022/lib/controls/Repeater/repeater-field-builder/repeater-field-builder.component.mjs +0 -1291
- package/esm2022/lib/controls/Repeater/repeater-item-field/repeater-item-field.component.mjs +0 -22
- package/esm2022/lib/controls/Repeater/repeater-table/repeater-table.component.mjs +0 -118
- package/esm2022/lib/controls/TagsInput/TagsInput.component.mjs +0 -308
- package/esm2022/lib/controls/TextArea/TextArea.component.mjs +0 -581
- package/esm2022/lib/controls/TextBox/TextBox.component.mjs +0 -357
- package/esm2022/lib/controls/Toggleslide/Toggleslide.component.mjs +0 -96
- package/esm2022/lib/controls/bbsf-controls.module.mjs +0 -92
- package/esm2022/lib/controls/page-header-component/page-header-component.component.mjs +0 -42
- package/esm2022/lib/modules/bbsf-core.module.mjs +0 -210
- package/esm2022/lib/modules/bbsf-datetime.module.mjs +0 -90
- package/esm2022/lib/modules/bbsf-dropdown.module.mjs +0 -57
- package/esm2022/lib/modules/bbsf-editors.module.mjs +0 -97
- package/esm2022/lib/modules/bbsf-forms-basic.module.mjs +0 -79
- package/esm2022/lib/modules/bbsf-multilingual.module.mjs +0 -60
- package/esm2022/lib/modules/bbsf-phone.module.mjs +0 -57
- package/esm2022/lib/modules/bbsf-specialized.module.mjs +0 -160
- package/esm2022/lib/modules/bbsf-uploads.module.mjs +0 -106
- package/esm2022/lib/modules/bbsf-utility.module.mjs +0 -103
- package/esm2022/public-api.mjs +0 -169
|
@@ -1,623 +0,0 @@
|
|
|
1
|
-
import { Component, Output, EventEmitter, Input, HostListener, CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
-
import { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';
|
|
5
|
-
import { BlockUIModule } from 'ng-block-ui';
|
|
6
|
-
import { InlineSVGModule } from 'ng-inline-svg-2';
|
|
7
|
-
import { PagingDTO } from '../../Shared/Models/PagingDTO';
|
|
8
|
-
import { Subscription } from 'rxjs';
|
|
9
|
-
import { FilterType } from '../../Shared/Enums/FilterType';
|
|
10
|
-
import { RequestOptionsModel } from '@bnsights/bbsf-utilities/http';
|
|
11
|
-
import { plainToClass } from 'class-transformer';
|
|
12
|
-
import { JwPaginationComponent } from './JwPagination.component';
|
|
13
|
-
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "@bnsights/bbsf-utilities/ui";
|
|
15
|
-
import * as i2 from "@angular/common/http";
|
|
16
|
-
import * as i3 from "@angular/router";
|
|
17
|
-
import * as i4 from "@angular/common";
|
|
18
|
-
import * as i5 from "../../Shared/services/OnPagingFiltersChange.service";
|
|
19
|
-
import * as i6 from "@bnsights/bbsf-utilities/http";
|
|
20
|
-
import * as i7 from "@angular/forms";
|
|
21
|
-
export class PagingComponent {
|
|
22
|
-
constructor(utilityService, http, router, route, location, onChangeService, requestHandlerService, cdr, renderer, elementRef) {
|
|
23
|
-
this.utilityService = utilityService;
|
|
24
|
-
this.http = http;
|
|
25
|
-
this.router = router;
|
|
26
|
-
this.route = route;
|
|
27
|
-
this.location = location;
|
|
28
|
-
this.onChangeService = onChangeService;
|
|
29
|
-
this.requestHandlerService = requestHandlerService;
|
|
30
|
-
this.cdr = cdr;
|
|
31
|
-
this.renderer = renderer;
|
|
32
|
-
this.elementRef = elementRef;
|
|
33
|
-
this.items = [];
|
|
34
|
-
this.result = [];
|
|
35
|
-
this.pagerConfig = null;
|
|
36
|
-
this.totalRow = 0;
|
|
37
|
-
this.pageSize = 10;
|
|
38
|
-
this.Pages = 0;
|
|
39
|
-
this.currentPage = 1;
|
|
40
|
-
this.showPageSizeOption = true;
|
|
41
|
-
this.showFirstAndLast = true;
|
|
42
|
-
this.hidePaginationWhenPageSizeEqualOne = true;
|
|
43
|
-
this.sum = 0;
|
|
44
|
-
this.throttle = 300;
|
|
45
|
-
this.scrollDistance = 1;
|
|
46
|
-
this.scrollUpDistance = 2;
|
|
47
|
-
this.direction = '';
|
|
48
|
-
this.isFirstCall = true;
|
|
49
|
-
this.previousFilters = {};
|
|
50
|
-
this.Items = new EventEmitter();
|
|
51
|
-
this.pageStateRestored = new EventEmitter();
|
|
52
|
-
this.subscriptions = new Subscription();
|
|
53
|
-
// Browser navigation support
|
|
54
|
-
this.isNavigatingBack = false;
|
|
55
|
-
this.isRestoringFilters = false;
|
|
56
|
-
this.pageHistory = [];
|
|
57
|
-
this.currentHistoryIndex = -1;
|
|
58
|
-
this.reinitializePaging = () => {
|
|
59
|
-
this.isFirstCall = true;
|
|
60
|
-
this.currentPage = 1;
|
|
61
|
-
this.clearHistoryState();
|
|
62
|
-
this.getItemList(1, true);
|
|
63
|
-
};
|
|
64
|
-
this.updatePaging = () => {
|
|
65
|
-
//this.IsFirstCall=true;
|
|
66
|
-
this.getItemList(this.currentPage);
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
ngOnDestroy() {
|
|
70
|
-
this.subscriptions.unsubscribe();
|
|
71
|
-
}
|
|
72
|
-
ngOnInit() {
|
|
73
|
-
// Initialize browser navigation support if enabled
|
|
74
|
-
if (this.options.enableBrowserNavigation) {
|
|
75
|
-
this.initializeBrowserNavigation();
|
|
76
|
-
}
|
|
77
|
-
if (this.options.isLoadMoreControl)
|
|
78
|
-
this.sum = this.options.pageSize;
|
|
79
|
-
if (this.options.dropdownFiltersControlNames != null && this.options.dropdownFiltersControlNames.length > 0) {
|
|
80
|
-
const DropdownFiltersControlNames = this.options.dropdownFiltersControlNames;
|
|
81
|
-
this.subscriptions.add(this.onChangeService.GetValue().subscribe((value) => {
|
|
82
|
-
let result = this.options.dropdownFiltersControlNames.filter((item) => item == value);
|
|
83
|
-
if (result.length > 0) {
|
|
84
|
-
this.isFirstCall = true;
|
|
85
|
-
this.currentPage = 1;
|
|
86
|
-
this.updateHistoryState();
|
|
87
|
-
this.getItemList(this.currentPage, true);
|
|
88
|
-
}
|
|
89
|
-
}));
|
|
90
|
-
}
|
|
91
|
-
if (this.options.bootstrapDatePickersFiltersControlNames != null && this.options.bootstrapDatePickersFiltersControlNames.length > 0) {
|
|
92
|
-
const BootstrapDatePickersFiltersControlNames = this.options.bootstrapDatePickersFiltersControlNames;
|
|
93
|
-
this.subscriptions.add(this.onChangeService.GetValue().subscribe((value) => {
|
|
94
|
-
let result = this.options.bootstrapDatePickersFiltersControlNames.filter((item) => item == value);
|
|
95
|
-
if (result.length > 0) {
|
|
96
|
-
this.isFirstCall = true;
|
|
97
|
-
this.currentPage = 1;
|
|
98
|
-
this.updateHistoryState();
|
|
99
|
-
this.getItemList(this.currentPage, true);
|
|
100
|
-
}
|
|
101
|
-
}));
|
|
102
|
-
}
|
|
103
|
-
this.isFirstCall = true;
|
|
104
|
-
this.getItemList(this.currentPage, true);
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* Initialize browser navigation support
|
|
108
|
-
*/
|
|
109
|
-
initializeBrowserNavigation() {
|
|
110
|
-
// Try to restore state from browser history on initial load
|
|
111
|
-
this.restoreStateFromBrowserHistory();
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* Restore state from browser history on initial load
|
|
115
|
-
*/
|
|
116
|
-
restoreStateFromBrowserHistory() {
|
|
117
|
-
try {
|
|
118
|
-
// Get the current history state
|
|
119
|
-
const currentState = history.state;
|
|
120
|
-
if (currentState && currentState.pagingState) {
|
|
121
|
-
const savedState = currentState.pagingState;
|
|
122
|
-
// Check if the saved state has valid data
|
|
123
|
-
if (savedState.page && savedState.pageSize && savedState.filters) {
|
|
124
|
-
// Restore filter values to form controls
|
|
125
|
-
this.restoreFilterValues(savedState.filters);
|
|
126
|
-
// Get current filters after restoration
|
|
127
|
-
const currentFilters = this.getFiltersValue();
|
|
128
|
-
// Only restore if filters match (same search context)
|
|
129
|
-
if (JSON.stringify(savedState.filters) === JSON.stringify(currentFilters)) {
|
|
130
|
-
let pageChanged = false;
|
|
131
|
-
let pageSizeChanged = false;
|
|
132
|
-
if (savedState.page !== this.currentPage) {
|
|
133
|
-
this.currentPage = savedState.page;
|
|
134
|
-
pageChanged = true;
|
|
135
|
-
}
|
|
136
|
-
if (savedState.pageSize !== this.options.pageSize) {
|
|
137
|
-
this.options.pageSize = savedState.pageSize;
|
|
138
|
-
pageSizeChanged = true;
|
|
139
|
-
}
|
|
140
|
-
// If page or page size changed, reload data
|
|
141
|
-
if (pageChanged || pageSizeChanged) {
|
|
142
|
-
this.getItemList(this.currentPage, pageSizeChanged);
|
|
143
|
-
}
|
|
144
|
-
// Add the restored state to our local history
|
|
145
|
-
this.pageHistory.push(savedState);
|
|
146
|
-
this.currentHistoryIndex = this.pageHistory.length - 1;
|
|
147
|
-
// Emit event to notify that page state was restored
|
|
148
|
-
this.pageStateRestored.emit({
|
|
149
|
-
page: this.currentPage,
|
|
150
|
-
pageSize: this.options.pageSize
|
|
151
|
-
});
|
|
152
|
-
// Force change detection to update the UI
|
|
153
|
-
this.cdr.detectChanges();
|
|
154
|
-
console.log(`Initial page state restored: Page ${this.currentPage}, PageSize ${this.options.pageSize}, Filters restored`);
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
catch (error) {
|
|
160
|
-
console.warn('Failed to restore browser history state:', error);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
/**
|
|
164
|
-
* Listen to browser back/forward navigation
|
|
165
|
-
*/
|
|
166
|
-
onPopState(event) {
|
|
167
|
-
if (!this.options.enableBrowserNavigation) {
|
|
168
|
-
return;
|
|
169
|
-
}
|
|
170
|
-
console.log('Browser back/forward navigation detected');
|
|
171
|
-
this.isNavigatingBack = true;
|
|
172
|
-
this.restorePageStateFromHistory();
|
|
173
|
-
this.isNavigatingBack = false;
|
|
174
|
-
}
|
|
175
|
-
/**
|
|
176
|
-
* Restore page state from browser history
|
|
177
|
-
*/
|
|
178
|
-
restorePageStateFromHistory() {
|
|
179
|
-
try {
|
|
180
|
-
// Get the current history state from browser
|
|
181
|
-
const currentState = history.state;
|
|
182
|
-
if (currentState && currentState.pagingState) {
|
|
183
|
-
const savedState = currentState.pagingState;
|
|
184
|
-
// Check if the saved state has valid data
|
|
185
|
-
if (savedState.page && savedState.pageSize && savedState.filters) {
|
|
186
|
-
// Restore filter values to form controls
|
|
187
|
-
this.restoreFilterValues(savedState.filters);
|
|
188
|
-
// Get current filters after restoration
|
|
189
|
-
const currentFilters = this.getFiltersValue();
|
|
190
|
-
// Only restore if filters match (same search context)
|
|
191
|
-
if (JSON.stringify(savedState.filters) === JSON.stringify(currentFilters)) {
|
|
192
|
-
let pageChanged = false;
|
|
193
|
-
let pageSizeChanged = false;
|
|
194
|
-
if (savedState.page !== this.currentPage) {
|
|
195
|
-
this.currentPage = savedState.page;
|
|
196
|
-
pageChanged = true;
|
|
197
|
-
}
|
|
198
|
-
if (savedState.pageSize !== this.options.pageSize) {
|
|
199
|
-
this.options.pageSize = savedState.pageSize;
|
|
200
|
-
pageSizeChanged = true;
|
|
201
|
-
}
|
|
202
|
-
// If page or page size changed, reload data
|
|
203
|
-
if (pageChanged || pageSizeChanged) {
|
|
204
|
-
this.getItemList(this.currentPage, pageSizeChanged);
|
|
205
|
-
}
|
|
206
|
-
// Update our local history index to match the browser state
|
|
207
|
-
this.updateLocalHistoryIndex(savedState);
|
|
208
|
-
// Emit event to notify that page state was restored
|
|
209
|
-
this.pageStateRestored.emit({
|
|
210
|
-
page: this.currentPage,
|
|
211
|
-
pageSize: this.options.pageSize
|
|
212
|
-
});
|
|
213
|
-
// Force change detection to update the UI
|
|
214
|
-
this.cdr.detectChanges();
|
|
215
|
-
console.log(`Page state restored from browser navigation: Page ${this.currentPage}, PageSize ${this.options.pageSize}, Filters restored`);
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
catch (error) {
|
|
221
|
-
console.warn('Failed to restore page state from history:', error);
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
/**
|
|
225
|
-
* Update local history index to match browser state
|
|
226
|
-
*/
|
|
227
|
-
updateLocalHistoryIndex(savedState) {
|
|
228
|
-
// Find the matching state in our local history
|
|
229
|
-
const index = this.pageHistory.findIndex(state => state.page === savedState.page &&
|
|
230
|
-
state.pageSize === savedState.pageSize &&
|
|
231
|
-
JSON.stringify(state.filters) === JSON.stringify(savedState.filters));
|
|
232
|
-
if (index !== -1) {
|
|
233
|
-
this.currentHistoryIndex = index;
|
|
234
|
-
}
|
|
235
|
-
else {
|
|
236
|
-
// If not found, add it to our history
|
|
237
|
-
this.pageHistory.push(savedState);
|
|
238
|
-
this.currentHistoryIndex = this.pageHistory.length - 1;
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
/**
|
|
242
|
-
* Update browser history state with current page and page size
|
|
243
|
-
*/
|
|
244
|
-
updateHistoryState() {
|
|
245
|
-
if (!this.options.enableBrowserNavigation) {
|
|
246
|
-
return;
|
|
247
|
-
}
|
|
248
|
-
const currentFilters = this.getFiltersValue();
|
|
249
|
-
const currentState = {
|
|
250
|
-
page: this.currentPage,
|
|
251
|
-
pageSize: this.options.pageSize,
|
|
252
|
-
filters: currentFilters
|
|
253
|
-
};
|
|
254
|
-
// Only update history if we're not already navigating back
|
|
255
|
-
if (!this.isNavigatingBack) {
|
|
256
|
-
// Add current state to local history
|
|
257
|
-
this.pageHistory.push(currentState);
|
|
258
|
-
this.currentHistoryIndex = this.pageHistory.length - 1;
|
|
259
|
-
// Limit history size to prevent memory issues
|
|
260
|
-
if (this.pageHistory.length > 50) {
|
|
261
|
-
this.pageHistory.shift();
|
|
262
|
-
this.currentHistoryIndex--;
|
|
263
|
-
}
|
|
264
|
-
// Update browser history state
|
|
265
|
-
const historyState = {
|
|
266
|
-
pagingState: currentState,
|
|
267
|
-
timestamp: Date.now()
|
|
268
|
-
};
|
|
269
|
-
try {
|
|
270
|
-
// Use history.pushState to add a new history entry
|
|
271
|
-
// This allows proper back/forward navigation
|
|
272
|
-
history.pushState(historyState, '', this.location.path());
|
|
273
|
-
}
|
|
274
|
-
catch (error) {
|
|
275
|
-
console.warn('Failed to update browser history state:', error);
|
|
276
|
-
// Fallback to replaceState if pushState fails
|
|
277
|
-
this.location.replaceState(this.location.path(), '', JSON.stringify(historyState));
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
ngAfterViewInit() {
|
|
282
|
-
if (this.options.onClickFiltersControlNames != null && this.options.onClickFiltersControlNames.length > 0) {
|
|
283
|
-
const OnClickFiltersControlNames = this.options.onClickFiltersControlNames;
|
|
284
|
-
for (let index = 0; index < OnClickFiltersControlNames.length; index++) {
|
|
285
|
-
const OnClickFiltersControlName = OnClickFiltersControlNames[index];
|
|
286
|
-
document.getElementById(OnClickFiltersControlName).addEventListener("click", () => {
|
|
287
|
-
this.currentPage = 1;
|
|
288
|
-
this.isFirstCall = true;
|
|
289
|
-
this.updateHistoryState();
|
|
290
|
-
this.getItemList(this.currentPage, true);
|
|
291
|
-
}, false);
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
if (this.options.onKeyPressFiltersControlNames != null && this.options.onKeyPressFiltersControlNames.length > 0) {
|
|
295
|
-
const OnKeyPressFiltersControlNames = this.options.onKeyPressFiltersControlNames;
|
|
296
|
-
// Use Renderer2 to listen to document keypress event
|
|
297
|
-
// This works with elements in parent component
|
|
298
|
-
const keypressListener = this.renderer.listen('document', 'keypress', (event) => {
|
|
299
|
-
if (event.key === "Enter") {
|
|
300
|
-
const target = event.target;
|
|
301
|
-
const formControlName = target.getAttribute('id');
|
|
302
|
-
if (formControlName && OnKeyPressFiltersControlNames.includes(formControlName)) {
|
|
303
|
-
this.currentPage = 1;
|
|
304
|
-
this.isFirstCall = true;
|
|
305
|
-
this.updateHistoryState();
|
|
306
|
-
this.getItemList(this.currentPage, true);
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
});
|
|
310
|
-
// Store the unsubscribe function
|
|
311
|
-
this.subscriptions.add({ unsubscribe: keypressListener });
|
|
312
|
-
}
|
|
313
|
-
//Add click event on Reset Filter button
|
|
314
|
-
if (this.options.resetFilterButtonName != null) {
|
|
315
|
-
const button = document.getElementsByName(this.options.resetFilterButtonName)[0];
|
|
316
|
-
if (button != undefined) {
|
|
317
|
-
let element = button;
|
|
318
|
-
element.addEventListener("click", (e) => {
|
|
319
|
-
this.clearFilters();
|
|
320
|
-
}, false);
|
|
321
|
-
}
|
|
322
|
-
}
|
|
323
|
-
if (this.options.typeaheadSearchControlNames != null && this.options.typeaheadSearchControlNames.length > 0) {
|
|
324
|
-
const TypeaheadSearchControlNames = this.options.typeaheadSearchControlNames;
|
|
325
|
-
for (let index = 0; index < TypeaheadSearchControlNames.length; index++) {
|
|
326
|
-
const TypeaheadSearchControlName = TypeaheadSearchControlNames[index];
|
|
327
|
-
document.getElementById(TypeaheadSearchControlName).addEventListener("keypress", (e) => {
|
|
328
|
-
if (e.key == "Enter") {
|
|
329
|
-
this.currentPage = 1;
|
|
330
|
-
this.isFirstCall = true;
|
|
331
|
-
this.updateHistoryState();
|
|
332
|
-
this.getItemList(this.currentPage, true);
|
|
333
|
-
}
|
|
334
|
-
}, false);
|
|
335
|
-
}
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
onDropDownChange(result) {
|
|
339
|
-
if (result) {
|
|
340
|
-
this.currentPage = 1;
|
|
341
|
-
this.isFirstCall = true;
|
|
342
|
-
this.updateHistoryState();
|
|
343
|
-
this.getItemList(this.currentPage, true);
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
onChangePage(Page) {
|
|
347
|
-
if (Page == 0)
|
|
348
|
-
return;
|
|
349
|
-
if (Page > 0) {
|
|
350
|
-
if (this.isFirstCall) {
|
|
351
|
-
this.isFirstCall = false;
|
|
352
|
-
return;
|
|
353
|
-
}
|
|
354
|
-
this.currentPage = Page;
|
|
355
|
-
this.updateHistoryState();
|
|
356
|
-
this.getItemList(Page);
|
|
357
|
-
}
|
|
358
|
-
}
|
|
359
|
-
changePageSize(e) {
|
|
360
|
-
this.options.pageSize = e.target.value;
|
|
361
|
-
this.currentPage = 1;
|
|
362
|
-
this.isFirstCall = true;
|
|
363
|
-
this.updateHistoryState();
|
|
364
|
-
this.getItemList(this.currentPage, true);
|
|
365
|
-
}
|
|
366
|
-
onScrollDown() {
|
|
367
|
-
this.sum += this.options.pageSize;
|
|
368
|
-
this.currentPage = 1;
|
|
369
|
-
this.isFirstCall = true;
|
|
370
|
-
this.direction = 'down';
|
|
371
|
-
this.getItemList(this.currentPage, true);
|
|
372
|
-
}
|
|
373
|
-
getItemList(page, IsFilterUpdated = false) {
|
|
374
|
-
if (this.options.startPagingCallback)
|
|
375
|
-
this.options.startPagingCallback.call(null);
|
|
376
|
-
let filters = {};
|
|
377
|
-
filters = this.getFiltersValue();
|
|
378
|
-
// Skip filter change detection if we're restoring filters from browser history
|
|
379
|
-
if (!this.isRestoringFilters && !IsFilterUpdated && Object.keys(this.previousFilters).length != 0 && JSON.stringify(this.previousFilters) != JSON.stringify(filters)) {
|
|
380
|
-
//Reinitialize if filters changed
|
|
381
|
-
page = 1;
|
|
382
|
-
IsFilterUpdated = true;
|
|
383
|
-
}
|
|
384
|
-
this.previousFilters = filters;
|
|
385
|
-
let pagingDTO = new PagingDTO();
|
|
386
|
-
let size = Number.parseInt(this.options.pageSize.toString());
|
|
387
|
-
if (this.options.isLoadMoreControl)
|
|
388
|
-
pagingDTO.PageCount = this.sum;
|
|
389
|
-
else
|
|
390
|
-
pagingDTO.PageCount = size;
|
|
391
|
-
pagingDTO.CurrentPageNumber = page;
|
|
392
|
-
pagingDTO.TotalCount = this.totalRow;
|
|
393
|
-
pagingDTO.IsFilterUpdated = IsFilterUpdated;
|
|
394
|
-
//Set Filters object that sent to action URL
|
|
395
|
-
let filtersDTO = {
|
|
396
|
-
PagingDTO: pagingDTO,
|
|
397
|
-
Filters: filters
|
|
398
|
-
};
|
|
399
|
-
let requestOptions = new RequestOptionsModel();
|
|
400
|
-
requestOptions.disableBlockUI = this.options.disableBlockUI;
|
|
401
|
-
this.requestHandlerService.post(this.options.actionPostURL, this.options.filters && this.options.filters.length > 0 ? filtersDTO : pagingDTO, null, null, requestOptions)
|
|
402
|
-
.subscribe((responseData) => {
|
|
403
|
-
this.options.totalCount = responseData.totalCount;
|
|
404
|
-
this.result = responseData.items; //this.castItems(responseData.items);
|
|
405
|
-
let castedResult = plainToClass(this.options.TypeOfResponse, this.result, { excludeExtraneousValues: true });
|
|
406
|
-
this.Items.emit(castedResult);
|
|
407
|
-
this.totalRow = responseData.totalCount;
|
|
408
|
-
if (IsFilterUpdated) {
|
|
409
|
-
this.items = [];
|
|
410
|
-
this.Pages = Math.ceil((this.totalRow / this.options.pageSize));
|
|
411
|
-
this.items = Array(this.totalRow);
|
|
412
|
-
this.setText(this.Pages, this.totalRow);
|
|
413
|
-
}
|
|
414
|
-
}, (error) => {
|
|
415
|
-
if (error.status == 401)
|
|
416
|
-
this.router.navigate(["/Admin/account/login"]);
|
|
417
|
-
});
|
|
418
|
-
}
|
|
419
|
-
/**
|
|
420
|
-
* Force update the current page (useful for external components)
|
|
421
|
-
*/
|
|
422
|
-
setCurrentPage(page) {
|
|
423
|
-
if (page > 0 && page !== this.currentPage) {
|
|
424
|
-
this.currentPage = page;
|
|
425
|
-
this.updateHistoryState();
|
|
426
|
-
this.getItemList(page);
|
|
427
|
-
this.cdr.detectChanges();
|
|
428
|
-
}
|
|
429
|
-
}
|
|
430
|
-
/**
|
|
431
|
-
* Get the current page number
|
|
432
|
-
*/
|
|
433
|
-
getCurrentPage() {
|
|
434
|
-
return this.currentPage;
|
|
435
|
-
}
|
|
436
|
-
/**
|
|
437
|
-
* Restore filter values to form controls
|
|
438
|
-
*/
|
|
439
|
-
restoreFilterValues(savedFilters) {
|
|
440
|
-
if (!this.options.filters || !this.group) {
|
|
441
|
-
return;
|
|
442
|
-
}
|
|
443
|
-
this.isRestoringFilters = true;
|
|
444
|
-
try {
|
|
445
|
-
for (let index = 0; index < this.options.filters.length; index++) {
|
|
446
|
-
const filter = this.options.filters[index];
|
|
447
|
-
if (filter.formControlName && filter.formControlName !== "") {
|
|
448
|
-
const formControlName = filter.formControlName;
|
|
449
|
-
const actionParameterName = filter.actionParameterName;
|
|
450
|
-
// Check if we have a saved value for this filter
|
|
451
|
-
if (savedFilters.hasOwnProperty(actionParameterName)) {
|
|
452
|
-
const savedValue = savedFilters[actionParameterName];
|
|
453
|
-
// Only restore if the value is not null/undefined/empty
|
|
454
|
-
if (savedValue !== null && savedValue !== undefined && savedValue !== "") {
|
|
455
|
-
// Set the value to the form control
|
|
456
|
-
this.group.controls[formControlName].setValue(savedValue);
|
|
457
|
-
console.log(`Restored filter ${formControlName} with value:`, savedValue);
|
|
458
|
-
}
|
|
459
|
-
}
|
|
460
|
-
}
|
|
461
|
-
else if (filter.jQuerySelector) {
|
|
462
|
-
// Handle jQuery selector based filters
|
|
463
|
-
const actionParameterName = filter.actionParameterName;
|
|
464
|
-
if (savedFilters.hasOwnProperty(actionParameterName)) {
|
|
465
|
-
const savedValue = savedFilters[actionParameterName];
|
|
466
|
-
if (savedValue !== null && savedValue !== undefined && savedValue !== "") {
|
|
467
|
-
const element = document.querySelector(filter.jQuerySelector);
|
|
468
|
-
if (element) {
|
|
469
|
-
element.value = savedValue;
|
|
470
|
-
console.log(`Restored jQuery filter ${filter.jQuerySelector} with value:`, savedValue);
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
}
|
|
474
|
-
}
|
|
475
|
-
}
|
|
476
|
-
}
|
|
477
|
-
catch (error) {
|
|
478
|
-
console.warn('Failed to restore filter values:', error);
|
|
479
|
-
}
|
|
480
|
-
finally {
|
|
481
|
-
// Reset the flag after a short delay to allow form controls to update
|
|
482
|
-
setTimeout(() => {
|
|
483
|
-
this.isRestoringFilters = false;
|
|
484
|
-
}, 100);
|
|
485
|
-
}
|
|
486
|
-
}
|
|
487
|
-
castItems(objectArr) {
|
|
488
|
-
let originalArray = [];
|
|
489
|
-
for (let index = 0; index < objectArr.length; index++) {
|
|
490
|
-
const element = objectArr[index];
|
|
491
|
-
let key, keys = Object.keys(element);
|
|
492
|
-
let n = keys.length;
|
|
493
|
-
let newObject = {};
|
|
494
|
-
while (n--) {
|
|
495
|
-
key = keys[n];
|
|
496
|
-
let Okey = key;
|
|
497
|
-
newObject[key.charAt(0).toUpperCase() + Okey.slice(1)] = element[key];
|
|
498
|
-
}
|
|
499
|
-
let finalObject = newObject;
|
|
500
|
-
originalArray.push(finalObject);
|
|
501
|
-
}
|
|
502
|
-
return originalArray;
|
|
503
|
-
}
|
|
504
|
-
setText(pagesNumber, itemsNumber) {
|
|
505
|
-
if (this.utilityService.isCurrentLanguageArabic()) {
|
|
506
|
-
//Set pages text
|
|
507
|
-
if (pagesNumber < 3 || pagesNumber > 10)
|
|
508
|
-
this.pagesText = this.utilityService.getResourceValue("Page");
|
|
509
|
-
else
|
|
510
|
-
this.pagesText = this.utilityService.getResourceValue("Pages");
|
|
511
|
-
//Set items text
|
|
512
|
-
if (itemsNumber < 3 || itemsNumber > 10)
|
|
513
|
-
this.itemsText = this.utilityService.getResourceValue("Item");
|
|
514
|
-
else
|
|
515
|
-
this.itemsText = this.utilityService.getResourceValue("Items");
|
|
516
|
-
}
|
|
517
|
-
else {
|
|
518
|
-
//Set pages text
|
|
519
|
-
if (pagesNumber > 1)
|
|
520
|
-
this.pagesText = this.utilityService.getResourceValue("Pages");
|
|
521
|
-
else
|
|
522
|
-
this.pagesText = this.utilityService.getResourceValue("Page");
|
|
523
|
-
//Set items text
|
|
524
|
-
if (itemsNumber > 1)
|
|
525
|
-
this.itemsText = this.utilityService.getResourceValue("Items");
|
|
526
|
-
else
|
|
527
|
-
this.itemsText = this.utilityService.getResourceValue("Item");
|
|
528
|
-
}
|
|
529
|
-
}
|
|
530
|
-
clearFilters() {
|
|
531
|
-
if (this.options.filters != null) {
|
|
532
|
-
for (let index = 0; index < this.options.filters.length; index++) {
|
|
533
|
-
if (this.options.filters[index].formControlName != null && this.options.filters[index].formControlName != "") {
|
|
534
|
-
const FormControlName = this.options.filters[index].formControlName;
|
|
535
|
-
this.group.controls[FormControlName].setValue(null);
|
|
536
|
-
}
|
|
537
|
-
}
|
|
538
|
-
// Clear history state when filters are reset
|
|
539
|
-
this.clearHistoryState();
|
|
540
|
-
this.reinitializePaging();
|
|
541
|
-
}
|
|
542
|
-
}
|
|
543
|
-
/**
|
|
544
|
-
* Clear page history state
|
|
545
|
-
*/
|
|
546
|
-
clearHistoryState() {
|
|
547
|
-
if (!this.options.enableBrowserNavigation) {
|
|
548
|
-
return;
|
|
549
|
-
}
|
|
550
|
-
// Clear the page history
|
|
551
|
-
this.pageHistory = [];
|
|
552
|
-
this.currentHistoryIndex = -1;
|
|
553
|
-
}
|
|
554
|
-
getFiltersValue() {
|
|
555
|
-
let filters = {};
|
|
556
|
-
if (this.options.filters != null) {
|
|
557
|
-
for (let index = 0; index < this.options.filters.length; index++) {
|
|
558
|
-
if (this.options.filters[index].formControlName != null && this.options.filters[index].formControlName != "") {
|
|
559
|
-
const FormControlName = this.options.filters[index].formControlName;
|
|
560
|
-
let ControlValue = this.group.controls[FormControlName].value;
|
|
561
|
-
if (ControlValue != undefined && ControlValue != null && ControlValue != "") {
|
|
562
|
-
if (this.options.filters[index].filterType == FilterType.DatePicker) {
|
|
563
|
-
//if (Array.isArray(ControlValue)) {
|
|
564
|
-
// for (let element = 0; element < ControlValue.length; element++) {
|
|
565
|
-
// const value = ControlValue[element];
|
|
566
|
-
// filters[this.options.Filters[index].ActionParameterName] = value;
|
|
567
|
-
// }
|
|
568
|
-
//}
|
|
569
|
-
//else {
|
|
570
|
-
filters[this.options.filters[index].actionParameterName] = ControlValue;
|
|
571
|
-
//}
|
|
572
|
-
}
|
|
573
|
-
else {
|
|
574
|
-
if (this.options.filters[index].filterType == FilterType.AutocompleteTextBox)
|
|
575
|
-
ControlValue = ControlValue;
|
|
576
|
-
if (this.options.filters[index].filterType == FilterType.TagInput)
|
|
577
|
-
ControlValue = ControlValue;
|
|
578
|
-
filters[this.options.filters[index].actionParameterName] = ControlValue;
|
|
579
|
-
}
|
|
580
|
-
}
|
|
581
|
-
else {
|
|
582
|
-
filters[this.options.filters[index].actionParameterName] = null;
|
|
583
|
-
}
|
|
584
|
-
}
|
|
585
|
-
else {
|
|
586
|
-
const ElementjQuerySelector = this.options.filters[index].jQuerySelector;
|
|
587
|
-
let ElementValue = document.querySelector(ElementjQuerySelector).value;
|
|
588
|
-
if (ElementValue != undefined && ElementValue != null)
|
|
589
|
-
filters[this.options.filters[index].actionParameterName] = ElementValue;
|
|
590
|
-
else
|
|
591
|
-
filters[this.options.filters[index].actionParameterName] = null;
|
|
592
|
-
}
|
|
593
|
-
}
|
|
594
|
-
}
|
|
595
|
-
return filters;
|
|
596
|
-
}
|
|
597
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagingComponent, deps: [{ token: i1.UtilityService }, { token: i2.HttpClient }, { token: i3.Router }, { token: i3.ActivatedRoute }, { token: i4.Location }, { token: i5.OnPagingFiltersChangeService }, { token: i6.RequestHandlerService }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
598
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PagingComponent, isStandalone: true, selector: "BBSF-Paging", inputs: { options: "options", group: "group" }, outputs: { Items: "Items", pageStateRestored: "pageStateRestored" }, host: { listeners: { "window:popstate": "onPopState($event)" } }, ngImport: i0, template: "<div class=\"form-group bbsf-control bbsf-paging\" *ngIf=\"(result.length > 0)\" role=\"navigation\" [attr.aria-label]=\"utilityService.getResourceValue('Pagination')\">\r\n <!--paging container-->\r\n <div class=\"bbsf-paging-container\" *ngIf=\"!options.isLoadMoreControl\">\r\n <!--items-->\r\n <div class=\"bbsf-pagination\">\r\n <jw-pagination [items]=\"items\" *ngIf=\"!((Pages==1)&&options.hidePaginationWhenPageSizeEqualOne)\"\r\n (changePage)=\"onChangePage($event)\" [pageSize]=\"options.pageSize\" [ShowFirstAndLast]=\"options.showFirstAndLast\"\r\n [initialPage]=\"currentPage\" [maxPages]=\"10\"></jw-pagination>\r\n </div>\r\n <!--page count-->\r\n <div class=\"bbsf-pages\" *ngIf=\"!((Pages==1)&&options.hidePaginationWhenPageSizeEqualOne)\">\r\n <select (change)=\"changePageSize($event)\" *ngIf=\"options.showPageSizeOption\" \r\n [attr.aria-label]=\"utilityService.getResourceValue('SelectPageSize')\" \r\n [ngbTooltip]=\"utilityService.getResourceValue('SelectPageSize')\">\r\n <option>10</option>\r\n <option>20</option>\r\n <option>50</option>\r\n <option>100</option>\r\n <option>200</option>\r\n </select>\r\n <div class=\"bssf-items\" [attr.aria-label]=\"utilityService.getResourceValue('PageInfo')\">\r\n <strong>{{totalRow}}</strong> {{itemsText}} {{utilityService.getResourceValue(\"In\")}} <strong>\r\n {{Pages}}</strong> {{pagesText}}\r\n </div>\r\n </div>\r\n </div>\r\n <!--load more-->\r\n <div class=\"bbsf-loadmore\" *ngIf=\"options.isLoadMoreControl\">\r\n <div class=\"search-results\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\"\r\n [infiniteScrollUpDistance]=\"scrollUpDistance\" [infiniteScrollThrottle]=\"throttle\"\r\n (scrolled)=\"options.isInfiniteScroll==true?onScrollDown():null\" [scrollWindow]=\"options.scrollWindow\"\r\n [infiniteScrollContainer]=\"options.infiniteScrollContainer\">\r\n </div>\r\n <button class=\"btn btn-sm btn-primary\" (click)=\"onScrollDown()\"\r\n *ngIf=\"!(result.length==totalRow)\"\r\n [attr.aria-label]=\"utilityService.getResourceValue('LoadMore')\"\r\n [ngbTooltip]=\"utilityService.getResourceValue('LoadMore')\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n </div>\r\n</div>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i7.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "ngmodule", type: BlockUIModule }, { kind: "ngmodule", type: InlineSVGModule }, { kind: "component", type: JwPaginationComponent, selector: "jw-pagination", inputs: ["items", "initialPage", "pageSize", "maxPages", "ShowFirstAndLast"], outputs: ["changePage"] }] }); }
|
|
599
|
-
}
|
|
600
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagingComponent, decorators: [{
|
|
601
|
-
type: Component,
|
|
602
|
-
args: [{ selector: 'BBSF-Paging', standalone: true, imports: [
|
|
603
|
-
CommonModule,
|
|
604
|
-
FormsModule,
|
|
605
|
-
ReactiveFormsModule,
|
|
606
|
-
NgbTooltip,
|
|
607
|
-
BlockUIModule,
|
|
608
|
-
InlineSVGModule,
|
|
609
|
-
JwPaginationComponent
|
|
610
|
-
], schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA], template: "<div class=\"form-group bbsf-control bbsf-paging\" *ngIf=\"(result.length > 0)\" role=\"navigation\" [attr.aria-label]=\"utilityService.getResourceValue('Pagination')\">\r\n <!--paging container-->\r\n <div class=\"bbsf-paging-container\" *ngIf=\"!options.isLoadMoreControl\">\r\n <!--items-->\r\n <div class=\"bbsf-pagination\">\r\n <jw-pagination [items]=\"items\" *ngIf=\"!((Pages==1)&&options.hidePaginationWhenPageSizeEqualOne)\"\r\n (changePage)=\"onChangePage($event)\" [pageSize]=\"options.pageSize\" [ShowFirstAndLast]=\"options.showFirstAndLast\"\r\n [initialPage]=\"currentPage\" [maxPages]=\"10\"></jw-pagination>\r\n </div>\r\n <!--page count-->\r\n <div class=\"bbsf-pages\" *ngIf=\"!((Pages==1)&&options.hidePaginationWhenPageSizeEqualOne)\">\r\n <select (change)=\"changePageSize($event)\" *ngIf=\"options.showPageSizeOption\" \r\n [attr.aria-label]=\"utilityService.getResourceValue('SelectPageSize')\" \r\n [ngbTooltip]=\"utilityService.getResourceValue('SelectPageSize')\">\r\n <option>10</option>\r\n <option>20</option>\r\n <option>50</option>\r\n <option>100</option>\r\n <option>200</option>\r\n </select>\r\n <div class=\"bssf-items\" [attr.aria-label]=\"utilityService.getResourceValue('PageInfo')\">\r\n <strong>{{totalRow}}</strong> {{itemsText}} {{utilityService.getResourceValue(\"In\")}} <strong>\r\n {{Pages}}</strong> {{pagesText}}\r\n </div>\r\n </div>\r\n </div>\r\n <!--load more-->\r\n <div class=\"bbsf-loadmore\" *ngIf=\"options.isLoadMoreControl\">\r\n <div class=\"search-results\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\"\r\n [infiniteScrollUpDistance]=\"scrollUpDistance\" [infiniteScrollThrottle]=\"throttle\"\r\n (scrolled)=\"options.isInfiniteScroll==true?onScrollDown():null\" [scrollWindow]=\"options.scrollWindow\"\r\n [infiniteScrollContainer]=\"options.infiniteScrollContainer\">\r\n </div>\r\n <button class=\"btn btn-sm btn-primary\" (click)=\"onScrollDown()\"\r\n *ngIf=\"!(result.length==totalRow)\"\r\n [attr.aria-label]=\"utilityService.getResourceValue('LoadMore')\"\r\n [ngbTooltip]=\"utilityService.getResourceValue('LoadMore')\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n </div>\r\n</div>" }]
|
|
611
|
-
}], ctorParameters: () => [{ type: i1.UtilityService }, { type: i2.HttpClient }, { type: i3.Router }, { type: i3.ActivatedRoute }, { type: i4.Location }, { type: i5.OnPagingFiltersChangeService }, { type: i6.RequestHandlerService }, { type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { Items: [{
|
|
612
|
-
type: Output
|
|
613
|
-
}], pageStateRestored: [{
|
|
614
|
-
type: Output
|
|
615
|
-
}], options: [{
|
|
616
|
-
type: Input
|
|
617
|
-
}], group: [{
|
|
618
|
-
type: Input
|
|
619
|
-
}], onPopState: [{
|
|
620
|
-
type: HostListener,
|
|
621
|
-
args: ['window:popstate', ['$event']]
|
|
622
|
-
}] } });
|
|
623
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Paging.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/Paging/Paging.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/Paging/Paging.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Output, EventEmitter, Input, OnDestroy, HostListener, ChangeDetectorRef, CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA, Renderer2, ElementRef } from '@angular/core';\r\nimport { CommonModule, Location } from '@angular/common';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { HttpClient, HttpErrorResponse, HttpHeaders } from '@angular/common/http';\r\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\r\nimport { BlockUIModule } from 'ng-block-ui';\r\nimport { InlineSVGModule } from 'ng-inline-svg-2';\r\nimport { PagingDTO } from '../../Shared/Models/PagingDTO';\r\nimport { PagingOptions } from '../../Shared/Models/PagingOptions';\r\nimport { Subscription } from 'rxjs';\r\nimport { OnPagingFiltersChangeService } from '../../Shared/services/OnPagingFiltersChange.service';\r\nimport { FilterType } from '../../Shared/Enums/FilterType';\r\nimport { RequestHandlerService, RequestOptionsModel } from '@bnsights/bbsf-utilities/http';\r\nimport { UtilityService } from '@bnsights/bbsf-utilities/ui';\r\nimport { plainToClass } from 'class-transformer';\r\nimport { PagingPayload } from '../../Shared/Models/PagingPayload';\r\nimport { JwPaginationComponent } from './JwPagination.component';\r\n\r\n@Component({\r\n  selector: 'BBSF-Paging',\r\n  templateUrl: './Paging.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    NgbTooltip,\r\n    BlockUIModule,\r\n    InlineSVGModule,\r\n    JwPaginationComponent\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA]\r\n})\r\nexport class PagingComponent<T> implements OnInit, OnDestroy {\r\n\r\n  items = [];\r\n  pageOfItems: Array<any>;\r\n  result: T[] = [];\r\n  pagerConfig: any = null;\r\n  totalRow: any = 0;\r\n  pageSize: any = 10;\r\n  Pages: any = 0;\r\n  pagesText: string;\r\n  itemsText: string;\r\n  currentPage: any = 1;\r\n  showPageSizeOption = true;\r\n  showFirstAndLast = true;\r\n  hidePaginationWhenPageSizeEqualOne = true;\r\n  sum = 0;\r\n  throttle = 300;\r\n  scrollDistance = 1;\r\n  scrollUpDistance = 2;\r\n  direction = '';\r\n  headers: HttpHeaders;\r\n  isFirstCall: boolean = true;\r\n  previousFilters: any = {};\r\n  @Output() Items: EventEmitter<T[]> = new EventEmitter<T[]>();\r\n  @Output() pageStateRestored: EventEmitter<{ page: number, pageSize: number; }> = new EventEmitter<{ page: number, pageSize: number; }>();\r\n  @Input() options: PagingOptions;\r\n  @Input() group: FormGroup;\r\n  subscriptions = new Subscription();\r\n\r\n  // Browser navigation support\r\n  private isNavigatingBack = false;\r\n  private isRestoringFilters = false;\r\n  private pageHistory: Array<{ page: number, pageSize: number, filters: any; }> = [];\r\n  private currentHistoryIndex = -1;\r\n\r\n  constructor(\r\n    public utilityService: UtilityService,\r\n    private http: HttpClient,\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private location: Location,\r\n    private onChangeService: OnPagingFiltersChangeService,\r\n    private requestHandlerService: RequestHandlerService,\r\n    private cdr: ChangeDetectorRef,\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n  ngOnInit() {\r\n    // Initialize browser navigation support if enabled\r\n    if (this.options.enableBrowserNavigation) {\r\n      this.initializeBrowserNavigation();\r\n    }\r\n\r\n    if (this.options.isLoadMoreControl)\r\n      this.sum = this.options.pageSize;\r\n\r\n    if (this.options.dropdownFiltersControlNames != null && this.options.dropdownFiltersControlNames.length > 0) {\r\n      const DropdownFiltersControlNames = this.options.dropdownFiltersControlNames;\r\n      this.subscriptions.add(\r\n        this.onChangeService.GetValue().subscribe((value) => {\r\n          let result = this.options.dropdownFiltersControlNames.filter((item) => item == value);\r\n          if (result.length > 0) {\r\n            this.isFirstCall = true;\r\n            this.currentPage = 1;\r\n            this.updateHistoryState();\r\n            this.getItemList(this.currentPage, true);\r\n          }\r\n        }));\r\n    }\r\n\r\n    if (this.options.bootstrapDatePickersFiltersControlNames != null && this.options.bootstrapDatePickersFiltersControlNames.length > 0) {\r\n      const BootstrapDatePickersFiltersControlNames = this.options.bootstrapDatePickersFiltersControlNames;\r\n      this.subscriptions.add(this.onChangeService.GetValue().subscribe((value) => {\r\n        let result = this.options.bootstrapDatePickersFiltersControlNames.filter((item) => item == value);\r\n        if (result.length > 0) {\r\n          this.isFirstCall = true;\r\n          this.currentPage = 1;\r\n          this.updateHistoryState();\r\n          this.getItemList(this.currentPage, true);\r\n        }\r\n      }));\r\n    }\r\n\r\n    this.isFirstCall = true;\r\n    this.getItemList(this.currentPage, true);\r\n  }\r\n\r\n  /**\r\n   * Initialize browser navigation support\r\n   */\r\n  private initializeBrowserNavigation(): void {\r\n    // Try to restore state from browser history on initial load\r\n    this.restoreStateFromBrowserHistory();\r\n  }\r\n\r\n  /**\r\n   * Restore state from browser history on initial load\r\n   */\r\n  private restoreStateFromBrowserHistory(): void {\r\n    try {\r\n      // Get the current history state\r\n      const currentState = history.state;\r\n\r\n      if (currentState && currentState.pagingState) {\r\n        const savedState = currentState.pagingState;\r\n\r\n        // Check if the saved state has valid data\r\n        if (savedState.page && savedState.pageSize && savedState.filters) {\r\n          // Restore filter values to form controls\r\n          this.restoreFilterValues(savedState.filters);\r\n\r\n          // Get current filters after restoration\r\n          const currentFilters = this.getFiltersValue();\r\n\r\n          // Only restore if filters match (same search context)\r\n          if (JSON.stringify(savedState.filters) === JSON.stringify(currentFilters)) {\r\n            let pageChanged = false;\r\n            let pageSizeChanged = false;\r\n\r\n            if (savedState.page !== this.currentPage) {\r\n              this.currentPage = savedState.page;\r\n              pageChanged = true;\r\n            }\r\n\r\n            if (savedState.pageSize !== this.options.pageSize) {\r\n              this.options.pageSize = savedState.pageSize;\r\n              pageSizeChanged = true;\r\n            }\r\n\r\n            // If page or page size changed, reload data\r\n            if (pageChanged || pageSizeChanged) {\r\n              this.getItemList(this.currentPage, pageSizeChanged);\r\n            }\r\n\r\n            // Add the restored state to our local history\r\n            this.pageHistory.push(savedState);\r\n            this.currentHistoryIndex = this.pageHistory.length - 1;\r\n\r\n            // Emit event to notify that page state was restored\r\n            this.pageStateRestored.emit({\r\n              page: this.currentPage,\r\n              pageSize: this.options.pageSize\r\n            });\r\n\r\n            // Force change detection to update the UI\r\n            this.cdr.detectChanges();\r\n\r\n            console.log(`Initial page state restored: Page ${this.currentPage}, PageSize ${this.options.pageSize}, Filters restored`);\r\n          }\r\n        }\r\n      }\r\n    } catch (error) {\r\n      console.warn('Failed to restore browser history state:', error);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Listen to browser back/forward navigation\r\n   */\r\n  @HostListener('window:popstate', ['$event'])\r\n  onPopState(event: PopStateEvent): void {\r\n    if (!this.options.enableBrowserNavigation) {\r\n      return;\r\n    }\r\n\r\n    console.log('Browser back/forward navigation detected');\r\n    this.isNavigatingBack = true;\r\n    this.restorePageStateFromHistory();\r\n    this.isNavigatingBack = false;\r\n  }\r\n\r\n  /**\r\n   * Restore page state from browser history\r\n   */\r\n  private restorePageStateFromHistory(): void {\r\n    try {\r\n      // Get the current history state from browser\r\n      const currentState = history.state;\r\n\r\n      if (currentState && currentState.pagingState) {\r\n        const savedState = currentState.pagingState;\r\n\r\n        // Check if the saved state has valid data\r\n        if (savedState.page && savedState.pageSize && savedState.filters) {\r\n          // Restore filter values to form controls\r\n          this.restoreFilterValues(savedState.filters);\r\n\r\n          // Get current filters after restoration\r\n          const currentFilters = this.getFiltersValue();\r\n\r\n          // Only restore if filters match (same search context)\r\n          if (JSON.stringify(savedState.filters) === JSON.stringify(currentFilters)) {\r\n            let pageChanged = false;\r\n            let pageSizeChanged = false;\r\n\r\n            if (savedState.page !== this.currentPage) {\r\n              this.currentPage = savedState.page;\r\n              pageChanged = true;\r\n            }\r\n\r\n            if (savedState.pageSize !== this.options.pageSize) {\r\n              this.options.pageSize = savedState.pageSize;\r\n              pageSizeChanged = true;\r\n            }\r\n\r\n            // If page or page size changed, reload data\r\n            if (pageChanged || pageSizeChanged) {\r\n              this.getItemList(this.currentPage, pageSizeChanged);\r\n            }\r\n\r\n            // Update our local history index to match the browser state\r\n            this.updateLocalHistoryIndex(savedState);\r\n\r\n            // Emit event to notify that page state was restored\r\n            this.pageStateRestored.emit({\r\n              page: this.currentPage,\r\n              pageSize: this.options.pageSize\r\n            });\r\n\r\n            // Force change detection to update the UI\r\n            this.cdr.detectChanges();\r\n\r\n            console.log(`Page state restored from browser navigation: Page ${this.currentPage}, PageSize ${this.options.pageSize}, Filters restored`);\r\n          }\r\n        }\r\n      }\r\n    } catch (error) {\r\n      console.warn('Failed to restore page state from history:', error);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Update local history index to match browser state\r\n   */\r\n  private updateLocalHistoryIndex(savedState: any): void {\r\n    // Find the matching state in our local history\r\n    const index = this.pageHistory.findIndex(state =>\r\n      state.page === savedState.page &&\r\n      state.pageSize === savedState.pageSize &&\r\n      JSON.stringify(state.filters) === JSON.stringify(savedState.filters)\r\n    );\r\n\r\n    if (index !== -1) {\r\n      this.currentHistoryIndex = index;\r\n    } else {\r\n      // If not found, add it to our history\r\n      this.pageHistory.push(savedState);\r\n      this.currentHistoryIndex = this.pageHistory.length - 1;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Update browser history state with current page and page size\r\n   */\r\n  private updateHistoryState(): void {\r\n    if (!this.options.enableBrowserNavigation) {\r\n      return;\r\n    }\r\n\r\n    const currentFilters = this.getFiltersValue();\r\n    const currentState = {\r\n      page: this.currentPage,\r\n      pageSize: this.options.pageSize,\r\n      filters: currentFilters\r\n    };\r\n\r\n    // Only update history if we're not already navigating back\r\n    if (!this.isNavigatingBack) {\r\n      // Add current state to local history\r\n      this.pageHistory.push(currentState);\r\n      this.currentHistoryIndex = this.pageHistory.length - 1;\r\n\r\n      // Limit history size to prevent memory issues\r\n      if (this.pageHistory.length > 50) {\r\n        this.pageHistory.shift();\r\n        this.currentHistoryIndex--;\r\n      }\r\n\r\n      // Update browser history state\r\n      const historyState = {\r\n        pagingState: currentState,\r\n        timestamp: Date.now()\r\n      };\r\n\r\n      try {\r\n        // Use history.pushState to add a new history entry\r\n        // This allows proper back/forward navigation\r\n        history.pushState(historyState, '', this.location.path());\r\n      } catch (error) {\r\n        console.warn('Failed to update browser history state:', error);\r\n        // Fallback to replaceState if pushState fails\r\n        this.location.replaceState(this.location.path(), '', JSON.stringify(historyState));\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (this.options.onClickFiltersControlNames != null && this.options.onClickFiltersControlNames.length > 0) {\r\n      const OnClickFiltersControlNames = this.options.onClickFiltersControlNames;\r\n      for (let index = 0; index < OnClickFiltersControlNames.length; index++) {\r\n        const OnClickFiltersControlName = OnClickFiltersControlNames[index];\r\n        document.getElementById(OnClickFiltersControlName).addEventListener(\"click\", () => {\r\n          this.currentPage = 1;\r\n          this.isFirstCall = true;\r\n          this.updateHistoryState();\r\n          this.getItemList(this.currentPage, true);\r\n        }, false);\r\n      }\r\n    }\r\n    if (this.options.onKeyPressFiltersControlNames != null && this.options.onKeyPressFiltersControlNames.length > 0) {\r\n      const OnKeyPressFiltersControlNames = this.options.onKeyPressFiltersControlNames;\r\n      // Use Renderer2 to listen to document keypress event\r\n      // This works with elements in parent component\r\n      const keypressListener = this.renderer.listen('document', 'keypress', (event: KeyboardEvent) => {\r\n        if (event.key === \"Enter\") {\r\n          const target = event.target as HTMLElement;\r\n          const formControlName = target.getAttribute('id');\r\n          if (formControlName && OnKeyPressFiltersControlNames.includes(formControlName)) {\r\n            this.currentPage = 1;\r\n            this.isFirstCall = true;\r\n            this.updateHistoryState();\r\n            this.getItemList(this.currentPage, true);\r\n          }\r\n        }\r\n      });\r\n\r\n      // Store the unsubscribe function\r\n      this.subscriptions.add({ unsubscribe: keypressListener });\r\n    }\r\n    //Add click event on Reset Filter button\r\n    if (this.options.resetFilterButtonName != null) {\r\n      const button = document.getElementsByName(this.options.resetFilterButtonName)[0];\r\n      if (button != undefined) {\r\n        let element = button as HTMLElement;\r\n        element.addEventListener(\"click\", (e) => {\r\n          this.clearFilters();\r\n        }, false);\r\n      }\r\n    }\r\n    if (this.options.typeaheadSearchControlNames != null && this.options.typeaheadSearchControlNames.length > 0) {\r\n      const TypeaheadSearchControlNames = this.options.typeaheadSearchControlNames;\r\n      for (let index = 0; index < TypeaheadSearchControlNames.length; index++) {\r\n        const TypeaheadSearchControlName = TypeaheadSearchControlNames[index];\r\n        document.getElementById(TypeaheadSearchControlName).addEventListener(\"keypress\", (e) => {\r\n          if (e.key == \"Enter\") {\r\n            this.currentPage = 1;\r\n            this.isFirstCall = true;\r\n            this.updateHistoryState();\r\n            this.getItemList(this.currentPage, true);\r\n          }\r\n        }, false);\r\n\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  onDropDownChange(result) {\r\n    if (result) {\r\n      this.currentPage = 1;\r\n      this.isFirstCall = true;\r\n      this.updateHistoryState();\r\n      this.getItemList(this.currentPage, true);\r\n    }\r\n  }\r\n\r\n  onChangePage(Page) {\r\n    if (Page == 0)\r\n      return;\r\n    if (Page > 0) {\r\n      if (this.isFirstCall) {\r\n        this.isFirstCall = false;\r\n        return;\r\n      }\r\n      this.currentPage = Page;\r\n      this.updateHistoryState();\r\n      this.getItemList(Page);\r\n    }\r\n  }\r\n\r\n  changePageSize(e) {\r\n    this.options.pageSize = e.target.value;\r\n    this.currentPage = 1;\r\n    this.isFirstCall = true;\r\n    this.updateHistoryState();\r\n    this.getItemList(this.currentPage, true);\r\n  }\r\n\r\n  onScrollDown() {\r\n    this.sum += this.options.pageSize;\r\n    this.currentPage = 1;\r\n    this.isFirstCall = true;\r\n    this.direction = 'down';\r\n    this.getItemList(this.currentPage, true);\r\n  }\r\n\r\n  getItemList(page, IsFilterUpdated = false) {\r\n    if (this.options.startPagingCallback)\r\n      this.options.startPagingCallback.call(null);\r\n\r\n    let filters = {};\r\n    filters = this.getFiltersValue();\r\n\r\n    // Skip filter change detection if we're restoring filters from browser history\r\n    if (!this.isRestoringFilters && !IsFilterUpdated && Object.keys(this.previousFilters).length != 0 && JSON.stringify(this.previousFilters) != JSON.stringify(filters)) {\r\n      //Reinitialize if filters changed\r\n      page = 1;\r\n      IsFilterUpdated = true;\r\n    }\r\n    this.previousFilters = filters;\r\n    let pagingDTO = new PagingDTO();\r\n    let size = Number.parseInt(this.options.pageSize.toString());\r\n    if (this.options.isLoadMoreControl)\r\n      pagingDTO.PageCount = this.sum;\r\n    else\r\n      pagingDTO.PageCount = size;\r\n\r\n    pagingDTO.CurrentPageNumber = page;\r\n    pagingDTO.TotalCount = this.totalRow;\r\n    pagingDTO.IsFilterUpdated = IsFilterUpdated;\r\n\r\n    //Set Filters object that sent to action URL\r\n    let filtersDTO: PagingPayload = {\r\n      PagingDTO: pagingDTO,\r\n      Filters: filters\r\n    };\r\n\r\n    let requestOptions = new RequestOptionsModel();\r\n    requestOptions.disableBlockUI = this.options.disableBlockUI;\r\n    this.requestHandlerService.post(this.options.actionPostURL, this.options.filters && this.options.filters.length > 0 ? filtersDTO : pagingDTO, null, null, requestOptions)\r\n      .subscribe((responseData: any) => {\r\n        this.options.totalCount = responseData.totalCount;\r\n        this.result = responseData.items; //this.castItems(responseData.items);\r\n        let castedResult = plainToClass(this.options.TypeOfResponse, this.result, { excludeExtraneousValues: true });\r\n        this.Items.emit(castedResult);\r\n        this.totalRow = responseData.totalCount;\r\n\r\n        if (IsFilterUpdated) {\r\n          this.items = [];\r\n          this.Pages = Math.ceil((this.totalRow / this.options.pageSize));\r\n          this.items = Array(this.totalRow);\r\n\r\n          this.setText(this.Pages, this.totalRow);\r\n\r\n        }\r\n      }, (error: HttpErrorResponse) => {\r\n        if (error.status == 401)\r\n          this.router.navigate([\"/Admin/account/login\"]);\r\n      });\r\n  }\r\n\r\n  reinitializePaging = () => {\r\n    this.isFirstCall = true;\r\n    this.currentPage = 1;\r\n    this.clearHistoryState();\r\n    this.getItemList(1, true);\r\n  };\r\n\r\n  updatePaging = () => {\r\n    //this.IsFirstCall=true;\r\n    this.getItemList(this.currentPage);\r\n  };\r\n\r\n  /**\r\n   * Force update the current page (useful for external components)\r\n   */\r\n  setCurrentPage(page: number): void {\r\n    if (page > 0 && page !== this.currentPage) {\r\n      this.currentPage = page;\r\n      this.updateHistoryState();\r\n      this.getItemList(page);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get the current page number\r\n   */\r\n  getCurrentPage(): number {\r\n    return this.currentPage;\r\n  }\r\n\r\n  /**\r\n   * Restore filter values to form controls\r\n   */\r\n  private restoreFilterValues(savedFilters: any): void {\r\n    if (!this.options.filters || !this.group) {\r\n      return;\r\n    }\r\n\r\n    this.isRestoringFilters = true;\r\n\r\n    try {\r\n      for (let index = 0; index < this.options.filters.length; index++) {\r\n        const filter = this.options.filters[index];\r\n\r\n        if (filter.formControlName && filter.formControlName !== \"\") {\r\n          const formControlName = filter.formControlName;\r\n          const actionParameterName = filter.actionParameterName;\r\n\r\n          // Check if we have a saved value for this filter\r\n          if (savedFilters.hasOwnProperty(actionParameterName)) {\r\n            const savedValue = savedFilters[actionParameterName];\r\n\r\n            // Only restore if the value is not null/undefined/empty\r\n            if (savedValue !== null && savedValue !== undefined && savedValue !== \"\") {\r\n              // Set the value to the form control\r\n              this.group.controls[formControlName].setValue(savedValue);\r\n              console.log(`Restored filter ${formControlName} with value:`, savedValue);\r\n            }\r\n          }\r\n        } else if (filter.jQuerySelector) {\r\n          // Handle jQuery selector based filters\r\n          const actionParameterName = filter.actionParameterName;\r\n\r\n          if (savedFilters.hasOwnProperty(actionParameterName)) {\r\n            const savedValue = savedFilters[actionParameterName];\r\n\r\n            if (savedValue !== null && savedValue !== undefined && savedValue !== \"\") {\r\n              const element = document.querySelector(filter.jQuerySelector) as HTMLInputElement;\r\n              if (element) {\r\n                element.value = savedValue;\r\n                console.log(`Restored jQuery filter ${filter.jQuerySelector} with value:`, savedValue);\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    } catch (error) {\r\n      console.warn('Failed to restore filter values:', error);\r\n    } finally {\r\n      // Reset the flag after a short delay to allow form controls to update\r\n      setTimeout(() => {\r\n        this.isRestoringFilters = false;\r\n      }, 100);\r\n    }\r\n  }\r\n\r\n  castItems(objectArr: any[]): T[] {\r\n    let originalArray: T[] = [];\r\n    for (let index = 0; index < objectArr.length; index++) {\r\n      const element = objectArr[index];\r\n      let key, keys = Object.keys(element);\r\n      let n = keys.length;\r\n      let newObject = {};\r\n      while (n--) {\r\n        key = keys[n];\r\n        let Okey = key;\r\n        newObject[key.charAt(0).toUpperCase() + Okey.slice(1)] = element[key];\r\n      }\r\n      let finalObject = newObject as T;\r\n      originalArray.push(finalObject);\r\n    }\r\n\r\n    return originalArray;\r\n  }\r\n\r\n  setText(pagesNumber: number, itemsNumber: number) {\r\n    if (this.utilityService.isCurrentLanguageArabic()) {\r\n      //Set pages text\r\n      if (pagesNumber < 3 || pagesNumber > 10)\r\n        this.pagesText = this.utilityService.getResourceValue(\"Page\");\r\n      else\r\n        this.pagesText = this.utilityService.getResourceValue(\"Pages\");\r\n      //Set items text\r\n      if (itemsNumber < 3 || itemsNumber > 10)\r\n        this.itemsText = this.utilityService.getResourceValue(\"Item\");\r\n      else\r\n        this.itemsText = this.utilityService.getResourceValue(\"Items\");\r\n    }\r\n    else {\r\n      //Set pages text\r\n      if (pagesNumber > 1)\r\n        this.pagesText = this.utilityService.getResourceValue(\"Pages\");\r\n      else\r\n        this.pagesText = this.utilityService.getResourceValue(\"Page\");\r\n      //Set items text\r\n      if (itemsNumber > 1)\r\n        this.itemsText = this.utilityService.getResourceValue(\"Items\");\r\n      else\r\n        this.itemsText = this.utilityService.getResourceValue(\"Item\");\r\n    }\r\n  }\r\n\r\n  clearFilters() {\r\n    if (this.options.filters != null) {\r\n      for (let index = 0; index < this.options.filters.length; index++) {\r\n        if (this.options.filters[index].formControlName != null && this.options.filters[index].formControlName != \"\") {\r\n          const FormControlName = this.options.filters[index].formControlName;\r\n          this.group.controls[FormControlName].setValue(null);\r\n        }\r\n      }\r\n      // Clear history state when filters are reset\r\n      this.clearHistoryState();\r\n      this.reinitializePaging();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear page history state\r\n   */\r\n  private clearHistoryState(): void {\r\n    if (!this.options.enableBrowserNavigation) {\r\n      return;\r\n    }\r\n\r\n    // Clear the page history\r\n    this.pageHistory = [];\r\n    this.currentHistoryIndex = -1;\r\n  }\r\n\r\n  getFiltersValue() {\r\n    let filters = {};\r\n    if (this.options.filters != null) {\r\n      for (let index = 0; index < this.options.filters.length; index++) {\r\n        if (this.options.filters[index].formControlName != null && this.options.filters[index].formControlName != \"\") {\r\n          const FormControlName = this.options.filters[index].formControlName;\r\n          let ControlValue = this.group.controls[FormControlName].value;\r\n          if (ControlValue != undefined && ControlValue != null && ControlValue != \"\") {\r\n            if (this.options.filters[index].filterType == FilterType.DatePicker) {\r\n              //if (Array.isArray(ControlValue)) {\r\n              //  for (let element = 0; element < ControlValue.length; element++) {\r\n              //    const value = ControlValue[element];\r\n              //    filters[this.options.Filters[index].ActionParameterName] = value;\r\n              //  }\r\n              //}\r\n              //else {\r\n              filters[this.options.filters[index].actionParameterName] = ControlValue;\r\n              //}\r\n            }\r\n            else {\r\n              if (this.options.filters[index].filterType == FilterType.AutocompleteTextBox)\r\n                ControlValue = ControlValue;\r\n              if (this.options.filters[index].filterType == FilterType.TagInput)\r\n                ControlValue = ControlValue;\r\n\r\n              filters[this.options.filters[index].actionParameterName] = ControlValue;\r\n            }\r\n          }\r\n          else {\r\n            filters[this.options.filters[index].actionParameterName] = null;\r\n          }\r\n        }\r\n        else {\r\n          const ElementjQuerySelector = this.options.filters[index].jQuerySelector;\r\n          let ElementValue = (document.querySelector(ElementjQuerySelector) as HTMLInputElement).value;\r\n          if (ElementValue != undefined && ElementValue != null)\r\n            filters[this.options.filters[index].actionParameterName] = ElementValue;\r\n          else\r\n            filters[this.options.filters[index].actionParameterName] = null;\r\n        }\r\n      }\r\n    }\r\n    return filters;\r\n  }\r\n}\r\n","<div class=\"form-group bbsf-control bbsf-paging\" *ngIf=\"(result.length > 0)\" role=\"navigation\" [attr.aria-label]=\"utilityService.getResourceValue('Pagination')\">\r\n  <!--paging container-->\r\n  <div class=\"bbsf-paging-container\" *ngIf=\"!options.isLoadMoreControl\">\r\n    <!--items-->\r\n    <div class=\"bbsf-pagination\">\r\n      <jw-pagination [items]=\"items\" *ngIf=\"!((Pages==1)&&options.hidePaginationWhenPageSizeEqualOne)\"\r\n        (changePage)=\"onChangePage($event)\" [pageSize]=\"options.pageSize\" [ShowFirstAndLast]=\"options.showFirstAndLast\"\r\n        [initialPage]=\"currentPage\" [maxPages]=\"10\"></jw-pagination>\r\n    </div>\r\n    <!--page count-->\r\n    <div class=\"bbsf-pages\" *ngIf=\"!((Pages==1)&&options.hidePaginationWhenPageSizeEqualOne)\">\r\n      <select (change)=\"changePageSize($event)\" *ngIf=\"options.showPageSizeOption\" \r\n        [attr.aria-label]=\"utilityService.getResourceValue('SelectPageSize')\" \r\n        [ngbTooltip]=\"utilityService.getResourceValue('SelectPageSize')\">\r\n        <option>10</option>\r\n        <option>20</option>\r\n        <option>50</option>\r\n        <option>100</option>\r\n        <option>200</option>\r\n      </select>\r\n      <div class=\"bssf-items\" [attr.aria-label]=\"utilityService.getResourceValue('PageInfo')\">\r\n        <strong>{{totalRow}}</strong> {{itemsText}} {{utilityService.getResourceValue(\"In\")}} <strong>\r\n          {{Pages}}</strong> {{pagesText}}\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!--load more-->\r\n  <div class=\"bbsf-loadmore\" *ngIf=\"options.isLoadMoreControl\">\r\n    <div class=\"search-results\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\"\r\n      [infiniteScrollUpDistance]=\"scrollUpDistance\" [infiniteScrollThrottle]=\"throttle\"\r\n      (scrolled)=\"options.isInfiniteScroll==true?onScrollDown():null\" [scrollWindow]=\"options.scrollWindow\"\r\n      [infiniteScrollContainer]=\"options.infiniteScrollContainer\">\r\n    </div>\r\n    <button class=\"btn btn-sm btn-primary\" (click)=\"onScrollDown()\"\r\n      *ngIf=\"!(result.length==totalRow)\"\r\n      [attr.aria-label]=\"utilityService.getResourceValue('LoadMore')\"\r\n      [ngbTooltip]=\"utilityService.getResourceValue('LoadMore')\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n  </div>\r\n</div>"]}
|