@bnsights/bbsf-controls 1.0.170 → 1.0.172
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 +15 -4
- package/esm2022/lib/Shared/Components/app-base-component.mjs +4 -4
- package/esm2022/lib/Shared/Components/ng-tag-input.mjs +7 -7
- package/esm2022/lib/Shared/Directives/appPreventDoubleClick.directive.mjs +38 -0
- package/esm2022/lib/Shared/Directives/template-name.directive.mjs +5 -6
- package/esm2022/lib/Shared/Models/ControlOptionsBase.mjs +1 -1
- package/esm2022/lib/Shared/Models/MultilingualControlOptionsBase.mjs +1 -1
- package/esm2022/lib/Shared/Models/PagingOptions.mjs +3 -1
- package/esm2022/lib/Shared/Pipes/bbsf-date-time.pipe.mjs +5 -6
- package/esm2022/lib/Shared/Pipes/bbsf-date.pipe.mjs +5 -6
- package/esm2022/lib/Shared/default_intl.mjs +4 -4
- package/esm2022/lib/Shared/services/ControlUtility.mjs +4 -4
- package/esm2022/lib/Shared/services/GlobalSettings.service.mjs +4 -4
- package/esm2022/lib/Shared/services/OnPagingFiltersChange.service.mjs +4 -4
- package/esm2022/lib/Shared/services/file-upload.service.mjs +4 -4
- package/esm2022/lib/Shared/services/render-component-service.service.mjs +4 -4
- package/esm2022/lib/Shared/services/validationErrorMassage.service.mjs +4 -4
- package/esm2022/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.mjs +21 -8
- package/esm2022/lib/controls/Calendar/Calendar.component.mjs +5 -5
- package/esm2022/lib/controls/CheckBox/CheckBox.component.mjs +5 -5
- package/esm2022/lib/controls/ConfirmationModal/ConfirmationModal.component.mjs +5 -5
- package/esm2022/lib/controls/DateTimePicker/DateTimePicker.component.mjs +28 -17
- package/esm2022/lib/controls/DropdownList/DropdownList.component.mjs +44 -16
- package/esm2022/lib/controls/FileUplaod/FileUplaod.component.mjs +5 -5
- package/esm2022/lib/controls/Form/Form.component.mjs +5 -5
- package/esm2022/lib/controls/HtmlEditor/HtmlEditor.component.mjs +5 -5
- package/esm2022/lib/controls/ImageUpload/ImageUpload.component.mjs +5 -5
- package/esm2022/lib/controls/MapAutoComplete/MapAutoComplete.component.mjs +7 -7
- package/esm2022/lib/controls/MarkdownEditor/markdown-editor.component.mjs +5 -5
- package/esm2022/lib/controls/MultiLingualHtmlEditor/MultiLingualHtmlEditor.component.mjs +5 -5
- package/esm2022/lib/controls/MultiLingualTextArea/MultiLingualTextArea.component.mjs +5 -5
- package/esm2022/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.mjs +43 -51
- package/esm2022/lib/controls/Paging/JwPagination.component.mjs +5 -6
- package/esm2022/lib/controls/Paging/Paging.component.mjs +298 -14
- package/esm2022/lib/controls/Phone/Phone.component.mjs +6 -5
- package/esm2022/lib/controls/ProfileImageUploader/ProfileImageUploader.component.mjs +8 -8
- package/esm2022/lib/controls/RadioButton/RadioButton.component.mjs +6 -5
- package/esm2022/lib/controls/Recaptcha/Recaptcha.component.mjs +8 -8
- package/esm2022/lib/controls/Repeater/repeater/repeater.component.mjs +5 -5
- package/esm2022/lib/controls/Repeater/repeater-field-builder/repeater-field-builder.component.mjs +5 -5
- package/esm2022/lib/controls/Repeater/repeater-item-field/repeater-item-field.component.mjs +5 -5
- package/esm2022/lib/controls/Repeater/repeater-table/repeater-table.component.mjs +5 -5
- package/esm2022/lib/controls/TagsInput/TagsInput.component.mjs +15 -5
- package/esm2022/lib/controls/TextArea/TextArea.component.mjs +46 -29
- package/esm2022/lib/controls/TextBox/TextBox.component.mjs +12 -9
- package/esm2022/lib/controls/Toggleslide/Toggleslide.component.mjs +5 -5
- package/esm2022/lib/controls/bbsf-controls.module.mjs +46 -34
- package/esm2022/lib/controls/page-header-component/page-header-component.component.mjs +8 -7
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/bnsights-bbsf-controls.mjs +716 -309
- package/fesm2022/bnsights-bbsf-controls.mjs.map +1 -1
- package/lib/Shared/Directives/appPreventDoubleClick.directive.d.ts +12 -0
- package/lib/Shared/Models/ControlOptionsBase.d.ts +4 -3
- package/lib/Shared/Models/MultilingualControlOptionsBase.d.ts +2 -0
- package/lib/Shared/Models/PagingOptions.d.ts +2 -0
- package/lib/controls/DropdownList/DropdownList.component.d.ts +3 -1
- package/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.d.ts +1 -1
- package/lib/controls/Paging/Paging.component.d.ts +56 -4
- package/lib/controls/TextArea/TextArea.component.d.ts +1 -0
- package/lib/controls/bbsf-controls.module.d.ts +29 -25
- package/package.json +19 -20
- package/public-api.d.ts +1 -0
- package/bnsights-bbsf-controls-1.0.170.tgz +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Output, EventEmitter, Input } from '@angular/core';
|
|
1
|
+
import { Component, Output, EventEmitter, Input, HostListener } from '@angular/core';
|
|
2
2
|
import { PagingDTO } from '../../Shared/Models/PagingDTO';
|
|
3
3
|
import { Subscription } from 'rxjs';
|
|
4
4
|
import { FilterType } from '../../Shared/Enums/FilterType';
|
|
@@ -8,19 +8,21 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
import * as i1 from "@bnsights/bbsf-utilities";
|
|
9
9
|
import * as i2 from "@angular/common/http";
|
|
10
10
|
import * as i3 from "@angular/router";
|
|
11
|
-
import * as i4 from "
|
|
12
|
-
import * as i5 from "
|
|
13
|
-
import * as i6 from "
|
|
14
|
-
import * as i7 from "
|
|
11
|
+
import * as i4 from "@angular/common";
|
|
12
|
+
import * as i5 from "../../Shared/services/OnPagingFiltersChange.service";
|
|
13
|
+
import * as i6 from "ngx-infinite-scroll";
|
|
14
|
+
import * as i7 from "@angular/forms";
|
|
15
15
|
import * as i8 from "./JwPagination.component";
|
|
16
|
-
// tslint:disable-next-line: no-conflicting-lifecycle
|
|
17
16
|
export class PagingComponent {
|
|
18
|
-
constructor(utilityService, http, router, onChangeService, requestHandlerService) {
|
|
17
|
+
constructor(utilityService, http, router, route, location, onChangeService, requestHandlerService, cdr) {
|
|
19
18
|
this.utilityService = utilityService;
|
|
20
19
|
this.http = http;
|
|
21
20
|
this.router = router;
|
|
21
|
+
this.route = route;
|
|
22
|
+
this.location = location;
|
|
22
23
|
this.onChangeService = onChangeService;
|
|
23
24
|
this.requestHandlerService = requestHandlerService;
|
|
25
|
+
this.cdr = cdr;
|
|
24
26
|
this.items = [];
|
|
25
27
|
this.result = [];
|
|
26
28
|
this.pagerConfig = null;
|
|
@@ -39,9 +41,17 @@ export class PagingComponent {
|
|
|
39
41
|
this.isFirstCall = true;
|
|
40
42
|
this.previousFilters = {};
|
|
41
43
|
this.Items = new EventEmitter();
|
|
44
|
+
this.pageStateRestored = new EventEmitter();
|
|
42
45
|
this.subscriptions = new Subscription();
|
|
46
|
+
// Browser navigation support
|
|
47
|
+
this.isNavigatingBack = false;
|
|
48
|
+
this.isRestoringFilters = false;
|
|
49
|
+
this.pageHistory = [];
|
|
50
|
+
this.currentHistoryIndex = -1;
|
|
43
51
|
this.reinitializePaging = () => {
|
|
44
52
|
this.isFirstCall = true;
|
|
53
|
+
this.currentPage = 1;
|
|
54
|
+
this.clearHistoryState();
|
|
45
55
|
this.getItemList(1, true);
|
|
46
56
|
};
|
|
47
57
|
this.updatePaging = () => {
|
|
@@ -53,6 +63,10 @@ export class PagingComponent {
|
|
|
53
63
|
this.subscriptions.unsubscribe();
|
|
54
64
|
}
|
|
55
65
|
ngOnInit() {
|
|
66
|
+
// Initialize browser navigation support if enabled
|
|
67
|
+
if (this.options.enableBrowserNavigation) {
|
|
68
|
+
this.initializeBrowserNavigation();
|
|
69
|
+
}
|
|
56
70
|
if (this.options.isLoadMoreControl)
|
|
57
71
|
this.sum = this.options.pageSize;
|
|
58
72
|
if (this.options.dropdownFiltersControlNames != null && this.options.dropdownFiltersControlNames.length > 0) {
|
|
@@ -62,6 +76,7 @@ export class PagingComponent {
|
|
|
62
76
|
if (result.length > 0) {
|
|
63
77
|
this.isFirstCall = true;
|
|
64
78
|
this.currentPage = 1;
|
|
79
|
+
this.updateHistoryState();
|
|
65
80
|
this.getItemList(this.currentPage, true);
|
|
66
81
|
}
|
|
67
82
|
}));
|
|
@@ -73,6 +88,7 @@ export class PagingComponent {
|
|
|
73
88
|
if (result.length > 0) {
|
|
74
89
|
this.isFirstCall = true;
|
|
75
90
|
this.currentPage = 1;
|
|
91
|
+
this.updateHistoryState();
|
|
76
92
|
this.getItemList(this.currentPage, true);
|
|
77
93
|
}
|
|
78
94
|
}));
|
|
@@ -80,6 +96,181 @@ export class PagingComponent {
|
|
|
80
96
|
this.isFirstCall = true;
|
|
81
97
|
this.getItemList(this.currentPage, true);
|
|
82
98
|
}
|
|
99
|
+
/**
|
|
100
|
+
* Initialize browser navigation support
|
|
101
|
+
*/
|
|
102
|
+
initializeBrowserNavigation() {
|
|
103
|
+
// Try to restore state from browser history on initial load
|
|
104
|
+
this.restoreStateFromBrowserHistory();
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Restore state from browser history on initial load
|
|
108
|
+
*/
|
|
109
|
+
restoreStateFromBrowserHistory() {
|
|
110
|
+
try {
|
|
111
|
+
// Get the current history state
|
|
112
|
+
const currentState = history.state;
|
|
113
|
+
if (currentState && currentState.pagingState) {
|
|
114
|
+
const savedState = currentState.pagingState;
|
|
115
|
+
// Check if the saved state has valid data
|
|
116
|
+
if (savedState.page && savedState.pageSize && savedState.filters) {
|
|
117
|
+
// Restore filter values to form controls
|
|
118
|
+
this.restoreFilterValues(savedState.filters);
|
|
119
|
+
// Get current filters after restoration
|
|
120
|
+
const currentFilters = this.getFiltersValue();
|
|
121
|
+
// Only restore if filters match (same search context)
|
|
122
|
+
if (JSON.stringify(savedState.filters) === JSON.stringify(currentFilters)) {
|
|
123
|
+
let pageChanged = false;
|
|
124
|
+
let pageSizeChanged = false;
|
|
125
|
+
if (savedState.page !== this.currentPage) {
|
|
126
|
+
this.currentPage = savedState.page;
|
|
127
|
+
pageChanged = true;
|
|
128
|
+
}
|
|
129
|
+
if (savedState.pageSize !== this.options.pageSize) {
|
|
130
|
+
this.options.pageSize = savedState.pageSize;
|
|
131
|
+
pageSizeChanged = true;
|
|
132
|
+
}
|
|
133
|
+
// If page or page size changed, reload data
|
|
134
|
+
if (pageChanged || pageSizeChanged) {
|
|
135
|
+
this.getItemList(this.currentPage, pageSizeChanged);
|
|
136
|
+
}
|
|
137
|
+
// Add the restored state to our local history
|
|
138
|
+
this.pageHistory.push(savedState);
|
|
139
|
+
this.currentHistoryIndex = this.pageHistory.length - 1;
|
|
140
|
+
// Emit event to notify that page state was restored
|
|
141
|
+
this.pageStateRestored.emit({
|
|
142
|
+
page: this.currentPage,
|
|
143
|
+
pageSize: this.options.pageSize
|
|
144
|
+
});
|
|
145
|
+
// Force change detection to update the UI
|
|
146
|
+
this.cdr.detectChanges();
|
|
147
|
+
console.log(`Initial page state restored: Page ${this.currentPage}, PageSize ${this.options.pageSize}, Filters restored`);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
catch (error) {
|
|
153
|
+
console.warn('Failed to restore browser history state:', error);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Listen to browser back/forward navigation
|
|
158
|
+
*/
|
|
159
|
+
onPopState(event) {
|
|
160
|
+
if (!this.options.enableBrowserNavigation) {
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
console.log('Browser back/forward navigation detected');
|
|
164
|
+
this.isNavigatingBack = true;
|
|
165
|
+
this.restorePageStateFromHistory();
|
|
166
|
+
this.isNavigatingBack = false;
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Restore page state from browser history
|
|
170
|
+
*/
|
|
171
|
+
restorePageStateFromHistory() {
|
|
172
|
+
try {
|
|
173
|
+
// Get the current history state from browser
|
|
174
|
+
const currentState = history.state;
|
|
175
|
+
if (currentState && currentState.pagingState) {
|
|
176
|
+
const savedState = currentState.pagingState;
|
|
177
|
+
// Check if the saved state has valid data
|
|
178
|
+
if (savedState.page && savedState.pageSize && savedState.filters) {
|
|
179
|
+
// Restore filter values to form controls
|
|
180
|
+
this.restoreFilterValues(savedState.filters);
|
|
181
|
+
// Get current filters after restoration
|
|
182
|
+
const currentFilters = this.getFiltersValue();
|
|
183
|
+
// Only restore if filters match (same search context)
|
|
184
|
+
if (JSON.stringify(savedState.filters) === JSON.stringify(currentFilters)) {
|
|
185
|
+
let pageChanged = false;
|
|
186
|
+
let pageSizeChanged = false;
|
|
187
|
+
if (savedState.page !== this.currentPage) {
|
|
188
|
+
this.currentPage = savedState.page;
|
|
189
|
+
pageChanged = true;
|
|
190
|
+
}
|
|
191
|
+
if (savedState.pageSize !== this.options.pageSize) {
|
|
192
|
+
this.options.pageSize = savedState.pageSize;
|
|
193
|
+
pageSizeChanged = true;
|
|
194
|
+
}
|
|
195
|
+
// If page or page size changed, reload data
|
|
196
|
+
if (pageChanged || pageSizeChanged) {
|
|
197
|
+
this.getItemList(this.currentPage, pageSizeChanged);
|
|
198
|
+
}
|
|
199
|
+
// Update our local history index to match the browser state
|
|
200
|
+
this.updateLocalHistoryIndex(savedState);
|
|
201
|
+
// Emit event to notify that page state was restored
|
|
202
|
+
this.pageStateRestored.emit({
|
|
203
|
+
page: this.currentPage,
|
|
204
|
+
pageSize: this.options.pageSize
|
|
205
|
+
});
|
|
206
|
+
// Force change detection to update the UI
|
|
207
|
+
this.cdr.detectChanges();
|
|
208
|
+
console.log(`Page state restored from browser navigation: Page ${this.currentPage}, PageSize ${this.options.pageSize}, Filters restored`);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
catch (error) {
|
|
214
|
+
console.warn('Failed to restore page state from history:', error);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Update local history index to match browser state
|
|
219
|
+
*/
|
|
220
|
+
updateLocalHistoryIndex(savedState) {
|
|
221
|
+
// Find the matching state in our local history
|
|
222
|
+
const index = this.pageHistory.findIndex(state => state.page === savedState.page &&
|
|
223
|
+
state.pageSize === savedState.pageSize &&
|
|
224
|
+
JSON.stringify(state.filters) === JSON.stringify(savedState.filters));
|
|
225
|
+
if (index !== -1) {
|
|
226
|
+
this.currentHistoryIndex = index;
|
|
227
|
+
}
|
|
228
|
+
else {
|
|
229
|
+
// If not found, add it to our history
|
|
230
|
+
this.pageHistory.push(savedState);
|
|
231
|
+
this.currentHistoryIndex = this.pageHistory.length - 1;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Update browser history state with current page and page size
|
|
236
|
+
*/
|
|
237
|
+
updateHistoryState() {
|
|
238
|
+
if (!this.options.enableBrowserNavigation) {
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
const currentFilters = this.getFiltersValue();
|
|
242
|
+
const currentState = {
|
|
243
|
+
page: this.currentPage,
|
|
244
|
+
pageSize: this.options.pageSize,
|
|
245
|
+
filters: currentFilters
|
|
246
|
+
};
|
|
247
|
+
// Only update history if we're not already navigating back
|
|
248
|
+
if (!this.isNavigatingBack) {
|
|
249
|
+
// Add current state to local history
|
|
250
|
+
this.pageHistory.push(currentState);
|
|
251
|
+
this.currentHistoryIndex = this.pageHistory.length - 1;
|
|
252
|
+
// Limit history size to prevent memory issues
|
|
253
|
+
if (this.pageHistory.length > 50) {
|
|
254
|
+
this.pageHistory.shift();
|
|
255
|
+
this.currentHistoryIndex--;
|
|
256
|
+
}
|
|
257
|
+
// Update browser history state
|
|
258
|
+
const historyState = {
|
|
259
|
+
pagingState: currentState,
|
|
260
|
+
timestamp: Date.now()
|
|
261
|
+
};
|
|
262
|
+
try {
|
|
263
|
+
// Use history.pushState to add a new history entry
|
|
264
|
+
// This allows proper back/forward navigation
|
|
265
|
+
history.pushState(historyState, '', this.location.path());
|
|
266
|
+
}
|
|
267
|
+
catch (error) {
|
|
268
|
+
console.warn('Failed to update browser history state:', error);
|
|
269
|
+
// Fallback to replaceState if pushState fails
|
|
270
|
+
this.location.replaceState(this.location.path(), '', JSON.stringify(historyState));
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
}
|
|
83
274
|
ngAfterViewInit() {
|
|
84
275
|
if (this.options.onClickFiltersControlNames != null && this.options.onClickFiltersControlNames.length > 0) {
|
|
85
276
|
const OnClickFiltersControlNames = this.options.onClickFiltersControlNames;
|
|
@@ -88,6 +279,7 @@ export class PagingComponent {
|
|
|
88
279
|
document.getElementById(OnClickFiltersControlName).addEventListener("click", () => {
|
|
89
280
|
this.currentPage = 1;
|
|
90
281
|
this.isFirstCall = true;
|
|
282
|
+
this.updateHistoryState();
|
|
91
283
|
this.getItemList(this.currentPage, true);
|
|
92
284
|
}, false);
|
|
93
285
|
}
|
|
@@ -101,6 +293,7 @@ export class PagingComponent {
|
|
|
101
293
|
if (e.key == "Enter") {
|
|
102
294
|
this.currentPage = 1;
|
|
103
295
|
this.isFirstCall = true;
|
|
296
|
+
this.updateHistoryState();
|
|
104
297
|
this.getItemList(this.currentPage, true);
|
|
105
298
|
}
|
|
106
299
|
}, false);
|
|
@@ -124,6 +317,7 @@ export class PagingComponent {
|
|
|
124
317
|
if (e.key == "Enter") {
|
|
125
318
|
this.currentPage = 1;
|
|
126
319
|
this.isFirstCall = true;
|
|
320
|
+
this.updateHistoryState();
|
|
127
321
|
this.getItemList(this.currentPage, true);
|
|
128
322
|
}
|
|
129
323
|
}, false);
|
|
@@ -134,6 +328,7 @@ export class PagingComponent {
|
|
|
134
328
|
if (result) {
|
|
135
329
|
this.currentPage = 1;
|
|
136
330
|
this.isFirstCall = true;
|
|
331
|
+
this.updateHistoryState();
|
|
137
332
|
this.getItemList(this.currentPage, true);
|
|
138
333
|
}
|
|
139
334
|
}
|
|
@@ -146,6 +341,7 @@ export class PagingComponent {
|
|
|
146
341
|
return;
|
|
147
342
|
}
|
|
148
343
|
this.currentPage = Page;
|
|
344
|
+
this.updateHistoryState();
|
|
149
345
|
this.getItemList(Page);
|
|
150
346
|
}
|
|
151
347
|
}
|
|
@@ -153,6 +349,7 @@ export class PagingComponent {
|
|
|
153
349
|
this.options.pageSize = e.target.value;
|
|
154
350
|
this.currentPage = 1;
|
|
155
351
|
this.isFirstCall = true;
|
|
352
|
+
this.updateHistoryState();
|
|
156
353
|
this.getItemList(this.currentPage, true);
|
|
157
354
|
}
|
|
158
355
|
onScrollDown() {
|
|
@@ -167,7 +364,8 @@ export class PagingComponent {
|
|
|
167
364
|
this.options.startPagingCallback.call(null);
|
|
168
365
|
let filters = {};
|
|
169
366
|
filters = this.getFiltersValue();
|
|
170
|
-
|
|
367
|
+
// Skip filter change detection if we're restoring filters from browser history
|
|
368
|
+
if (!this.isRestoringFilters && !IsFilterUpdated && Object.keys(this.previousFilters).length != 0 && JSON.stringify(this.previousFilters) != JSON.stringify(filters)) {
|
|
171
369
|
//Reinitialize if filters changed
|
|
172
370
|
page = 1;
|
|
173
371
|
IsFilterUpdated = true;
|
|
@@ -207,6 +405,74 @@ export class PagingComponent {
|
|
|
207
405
|
this.router.navigate(["/Admin/account/login"]);
|
|
208
406
|
});
|
|
209
407
|
}
|
|
408
|
+
/**
|
|
409
|
+
* Force update the current page (useful for external components)
|
|
410
|
+
*/
|
|
411
|
+
setCurrentPage(page) {
|
|
412
|
+
if (page > 0 && page !== this.currentPage) {
|
|
413
|
+
this.currentPage = page;
|
|
414
|
+
this.updateHistoryState();
|
|
415
|
+
this.getItemList(page);
|
|
416
|
+
this.cdr.detectChanges();
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
/**
|
|
420
|
+
* Get the current page number
|
|
421
|
+
*/
|
|
422
|
+
getCurrentPage() {
|
|
423
|
+
return this.currentPage;
|
|
424
|
+
}
|
|
425
|
+
/**
|
|
426
|
+
* Restore filter values to form controls
|
|
427
|
+
*/
|
|
428
|
+
restoreFilterValues(savedFilters) {
|
|
429
|
+
if (!this.options.filters || !this.group) {
|
|
430
|
+
return;
|
|
431
|
+
}
|
|
432
|
+
this.isRestoringFilters = true;
|
|
433
|
+
try {
|
|
434
|
+
for (let index = 0; index < this.options.filters.length; index++) {
|
|
435
|
+
const filter = this.options.filters[index];
|
|
436
|
+
if (filter.formControlName && filter.formControlName !== "") {
|
|
437
|
+
const formControlName = filter.formControlName;
|
|
438
|
+
const actionParameterName = filter.actionParameterName;
|
|
439
|
+
// Check if we have a saved value for this filter
|
|
440
|
+
if (savedFilters.hasOwnProperty(actionParameterName)) {
|
|
441
|
+
const savedValue = savedFilters[actionParameterName];
|
|
442
|
+
// Only restore if the value is not null/undefined/empty
|
|
443
|
+
if (savedValue !== null && savedValue !== undefined && savedValue !== "") {
|
|
444
|
+
// Set the value to the form control
|
|
445
|
+
this.group.controls[formControlName].setValue(savedValue);
|
|
446
|
+
console.log(`Restored filter ${formControlName} with value:`, savedValue);
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
else if (filter.jQuerySelector) {
|
|
451
|
+
// Handle jQuery selector based filters
|
|
452
|
+
const actionParameterName = filter.actionParameterName;
|
|
453
|
+
if (savedFilters.hasOwnProperty(actionParameterName)) {
|
|
454
|
+
const savedValue = savedFilters[actionParameterName];
|
|
455
|
+
if (savedValue !== null && savedValue !== undefined && savedValue !== "") {
|
|
456
|
+
const element = document.querySelector(filter.jQuerySelector);
|
|
457
|
+
if (element) {
|
|
458
|
+
element.value = savedValue;
|
|
459
|
+
console.log(`Restored jQuery filter ${filter.jQuerySelector} with value:`, savedValue);
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
catch (error) {
|
|
467
|
+
console.warn('Failed to restore filter values:', error);
|
|
468
|
+
}
|
|
469
|
+
finally {
|
|
470
|
+
// Reset the flag after a short delay to allow form controls to update
|
|
471
|
+
setTimeout(() => {
|
|
472
|
+
this.isRestoringFilters = false;
|
|
473
|
+
}, 100);
|
|
474
|
+
}
|
|
475
|
+
}
|
|
210
476
|
castItems(objectArr) {
|
|
211
477
|
let originalArray = [];
|
|
212
478
|
for (let index = 0; index < objectArr.length; index++) {
|
|
@@ -258,9 +524,22 @@ export class PagingComponent {
|
|
|
258
524
|
this.group.controls[FormControlName].setValue(null);
|
|
259
525
|
}
|
|
260
526
|
}
|
|
527
|
+
// Clear history state when filters are reset
|
|
528
|
+
this.clearHistoryState();
|
|
261
529
|
this.reinitializePaging();
|
|
262
530
|
}
|
|
263
531
|
}
|
|
532
|
+
/**
|
|
533
|
+
* Clear page history state
|
|
534
|
+
*/
|
|
535
|
+
clearHistoryState() {
|
|
536
|
+
if (!this.options.enableBrowserNavigation) {
|
|
537
|
+
return;
|
|
538
|
+
}
|
|
539
|
+
// Clear the page history
|
|
540
|
+
this.pageHistory = [];
|
|
541
|
+
this.currentHistoryIndex = -1;
|
|
542
|
+
}
|
|
264
543
|
getFiltersValue() {
|
|
265
544
|
let filters = {};
|
|
266
545
|
if (this.options.filters != null) {
|
|
@@ -304,17 +583,22 @@ export class PagingComponent {
|
|
|
304
583
|
}
|
|
305
584
|
return filters;
|
|
306
585
|
}
|
|
307
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
308
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.
|
|
586
|
+
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: i1.RequestHandlerService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
587
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PagingComponent, 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)\">\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 <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\">\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)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n </div>\r\n</div>", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "directive", type: i7.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i7.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "component", type: i8.JwPaginationComponent, selector: "jw-pagination", inputs: ["items", "initialPage", "pageSize", "maxPages", "ShowFirstAndLast"], outputs: ["changePage"] }] }); }
|
|
309
588
|
}
|
|
310
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
589
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagingComponent, decorators: [{
|
|
311
590
|
type: Component,
|
|
312
|
-
args: [{ selector: 'BBSF-Paging',
|
|
313
|
-
}], ctorParameters: () => [{ type: i1.UtilityService }, { type: i2.HttpClient }, { type: i3.Router }, { type: i4.OnPagingFiltersChangeService }, { type: i1.RequestHandlerService }], propDecorators: { Items: [{
|
|
591
|
+
args: [{ selector: 'BBSF-Paging', template: "<div class=\"form-group bbsf-control bbsf-paging\" *ngIf=\"(result.length > 0)\">\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 <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\">\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)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n </div>\r\n</div>" }]
|
|
592
|
+
}], ctorParameters: () => [{ type: i1.UtilityService }, { type: i2.HttpClient }, { type: i3.Router }, { type: i3.ActivatedRoute }, { type: i4.Location }, { type: i5.OnPagingFiltersChangeService }, { type: i1.RequestHandlerService }, { type: i0.ChangeDetectorRef }], propDecorators: { Items: [{
|
|
593
|
+
type: Output
|
|
594
|
+
}], pageStateRestored: [{
|
|
314
595
|
type: Output
|
|
315
596
|
}], options: [{
|
|
316
597
|
type: Input
|
|
317
598
|
}], group: [{
|
|
318
599
|
type: Input
|
|
600
|
+
}], onPopState: [{
|
|
601
|
+
type: HostListener,
|
|
602
|
+
args: ['window:popstate', ['$event']]
|
|
319
603
|
}] } });
|
|
320
|
-
//# 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, SimpleChanges, ElementRef, OnDestroy } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { HttpClient, HttpErrorResponse, HttpHeaders, HttpParams } from '@angular/common/http';\r\nimport { PagingDTO } from '../../Shared/Models/PagingDTO';\r\nimport { PagingOptions } from '../../Shared/Models/PagingOptions';\r\nimport { Subject, Observable, Subscription } from 'rxjs';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { OnPagingFiltersChangeService } from '../../Shared/services/OnPagingFiltersChange.service';\r\nimport { FilterType } from '../../Shared/Enums/FilterType';\r\nimport { RequestHandlerService, RequestOptionsModel, UtilityService } from '@bnsights/bbsf-utilities';\r\nimport { plainToClass } from 'class-transformer';\r\nimport { PagingPayload } from '../../Shared/Models/PagingPayload';\r\n\r\n// tslint:disable-next-line: no-conflicting-lifecycle\r\n@Component({\r\n    selector: 'BBSF-Paging',\r\n    templateUrl: './Paging.component.html',\r\n    standalone: false\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  @Input() options: PagingOptions;\r\n  @Input() group: FormGroup;\r\n  subscriptions = new Subscription();\r\n\r\n  constructor(public utilityService: UtilityService, private http: HttpClient, private router: Router, private onChangeService: OnPagingFiltersChangeService, private requestHandlerService: RequestHandlerService) {\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n  ngOnInit() {\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.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.getItemList(this.currentPage, true);\r\n        }\r\n      }));\r\n    }\r\n    this.isFirstCall = true;\r\n    this.getItemList(this.currentPage, true);\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.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      for (let index = 0; index < OnKeyPressFiltersControlNames.length; index++) {\r\n        const OnKeyPressFiltersControlName = OnKeyPressFiltersControlNames[index];\r\n        let element = (<any>this.group.get(OnKeyPressFiltersControlName)).nativeElement as HTMLElement;\r\n        element.addEventListener(\"keypress\", (e) => {\r\n          if (e.key == \"Enter\") {\r\n            this.currentPage = 1;\r\n            this.isFirstCall = true;\r\n            this.getItemList(this.currentPage, true);\r\n          }\r\n        }, false);\r\n      }\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.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.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.getItemList(Page);\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.getItemList(this.currentPage, true);\r\n  }\r\n\r\n\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\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    if (!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.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  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      this.reinitializePaging();\r\n    }\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)\">\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]=\"1\" [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        <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\">\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)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n  </div>\r\n</div>"]}
|
|
604
|
+
//# 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 } from '@angular/core';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { HttpClient, HttpErrorResponse, HttpHeaders } from '@angular/common/http';\r\nimport { PagingDTO } from '../../Shared/Models/PagingDTO';\r\nimport { PagingOptions } from '../../Shared/Models/PagingOptions';\r\nimport { Subscription } from 'rxjs';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { OnPagingFiltersChangeService } from '../../Shared/services/OnPagingFiltersChange.service';\r\nimport { FilterType } from '../../Shared/Enums/FilterType';\r\nimport { RequestHandlerService, RequestOptionsModel, UtilityService } from '@bnsights/bbsf-utilities';\r\nimport { plainToClass } from 'class-transformer';\r\nimport { PagingPayload } from '../../Shared/Models/PagingPayload';\r\nimport { Location } from '@angular/common';\r\n\r\n@Component({\r\n  selector: 'BBSF-Paging',\r\n  templateUrl: './Paging.component.html'\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  ) {\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      for (let index = 0; index < OnKeyPressFiltersControlNames.length; index++) {\r\n        const OnKeyPressFiltersControlName = OnKeyPressFiltersControlNames[index];\r\n        let element = (<any>this.group.get(OnKeyPressFiltersControlName)).nativeElement as HTMLElement;\r\n        element.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    //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)\">\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        <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\">\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)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n  </div>\r\n</div>"]}
|