@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.
Files changed (159) hide show
  1. package/README.md +7 -0
  2. package/fesm2022/bnsights-bbsf-controls.mjs +378 -345
  3. package/fesm2022/bnsights-bbsf-controls.mjs.map +1 -1
  4. package/lib/Shared/Models/DropdownOptions.d.ts +3 -0
  5. package/lib/Shared/Models/RepeaterOptions.d.ts +2 -0
  6. package/lib/controls/ConfirmationModal/ConfirmationModal.component.d.ts +0 -1
  7. package/lib/controls/MapAutoComplete/MapAutoComplete.component.d.ts +0 -1
  8. package/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.d.ts +1 -1
  9. package/lib/controls/Repeater/repeater/repeater.component.d.ts +7 -0
  10. package/lib/controls/Repeater/repeater-table/repeater-table.component.d.ts +7 -0
  11. package/lib/modules/bbsf-editors.module.d.ts +6 -7
  12. package/package.json +33 -36
  13. package/src/lib/assets/Style.scss +2 -0
  14. package/src/lib/assets/ace-builds/ace.js +1 -1
  15. package/src/lib/assets/ace-builds/mode-markdown.js +1 -1
  16. package/esm2022/bnsights-bbsf-controls.mjs +0 -5
  17. package/esm2022/lib/Shared/Components/app-base-component.mjs +0 -226
  18. package/esm2022/lib/Shared/Components/ng-tag-input.mjs +0 -336
  19. package/esm2022/lib/Shared/Directives/appPreventDoubleClick.directive.mjs +0 -39
  20. package/esm2022/lib/Shared/Directives/template-name.directive.mjs +0 -19
  21. package/esm2022/lib/Shared/Enums/CalendarView.mjs +0 -8
  22. package/esm2022/lib/Shared/Enums/ControlLayout.mjs +0 -6
  23. package/esm2022/lib/Shared/Enums/Countries.mjs +0 -247
  24. package/esm2022/lib/Shared/Enums/Enums.mjs +0 -36
  25. package/esm2022/lib/Shared/Enums/FileType.mjs +0 -29
  26. package/esm2022/lib/Shared/Enums/FilterType.mjs +0 -11
  27. package/esm2022/lib/Shared/Enums/FontSize.mjs +0 -7
  28. package/esm2022/lib/Shared/Enums/ForceDirection.mjs +0 -6
  29. package/esm2022/lib/Shared/Enums/IconPosition.mjs +0 -6
  30. package/esm2022/lib/Shared/Enums/ImageType.mjs +0 -10
  31. package/esm2022/lib/Shared/Enums/InputType.mjs +0 -10
  32. package/esm2022/lib/Shared/Enums/Insert.mjs +0 -9
  33. package/esm2022/lib/Shared/Enums/LanguageMode.mjs +0 -11
  34. package/esm2022/lib/Shared/Enums/LanguageValidation.mjs +0 -6
  35. package/esm2022/lib/Shared/Enums/Markdown.mjs +0 -20
  36. package/esm2022/lib/Shared/Enums/Misc.mjs +0 -7
  37. package/esm2022/lib/Shared/Enums/PagingActionMode.mjs +0 -6
  38. package/esm2022/lib/Shared/Enums/Para.mjs +0 -9
  39. package/esm2022/lib/Shared/Enums/PickerType.mjs +0 -7
  40. package/esm2022/lib/Shared/Enums/SelectMode.mjs +0 -6
  41. package/esm2022/lib/Shared/Enums/StartView.mjs +0 -7
  42. package/esm2022/lib/Shared/Enums/Style.mjs +0 -8
  43. package/esm2022/lib/Shared/Enums/StyleConfirmationMode.mjs +0 -7
  44. package/esm2022/lib/Shared/Enums/TagInputView.mjs +0 -7
  45. package/esm2022/lib/Shared/Enums/ToolbarButtons.mjs +0 -33
  46. package/esm2022/lib/Shared/Enums/map-enums.mjs +0 -15
  47. package/esm2022/lib/Shared/Enums/menu-list-enum.mjs +0 -6
  48. package/esm2022/lib/Shared/Models/Attribute.mjs +0 -3
  49. package/esm2022/lib/Shared/Models/AutocompleteDTO.mjs +0 -8
  50. package/esm2022/lib/Shared/Models/AutocompleteOptions.mjs +0 -39
  51. package/esm2022/lib/Shared/Models/CalendarDTO.mjs +0 -3
  52. package/esm2022/lib/Shared/Models/CalendarEventDTO.mjs +0 -3
  53. package/esm2022/lib/Shared/Models/CalendarOptions.mjs +0 -19
  54. package/esm2022/lib/Shared/Models/CancelDTO.mjs +0 -7
  55. package/esm2022/lib/Shared/Models/CaptchaStyle.mjs +0 -3
  56. package/esm2022/lib/Shared/Models/CheckBoxOptions.mjs +0 -11
  57. package/esm2022/lib/Shared/Models/ConfirmationModalOptions.mjs +0 -39
  58. package/esm2022/lib/Shared/Models/ControlOptionsBase.mjs +0 -17
  59. package/esm2022/lib/Shared/Models/CustomValidation.mjs +0 -14
  60. package/esm2022/lib/Shared/Models/DatePickerOptions.mjs +0 -40
  61. package/esm2022/lib/Shared/Models/DropdownListItem.mjs +0 -3
  62. package/esm2022/lib/Shared/Models/DropdownOptions.mjs +0 -38
  63. package/esm2022/lib/Shared/Models/EditPersonalImage.mjs +0 -7
  64. package/esm2022/lib/Shared/Models/EnglishArabicDTO.mjs +0 -10
  65. package/esm2022/lib/Shared/Models/FileDTO.mjs +0 -24
  66. package/esm2022/lib/Shared/Models/FileOptions.mjs +0 -15
  67. package/esm2022/lib/Shared/Models/FileUploadModel.mjs +0 -3
  68. package/esm2022/lib/Shared/Models/FileUploadOptions.mjs +0 -13
  69. package/esm2022/lib/Shared/Models/FilterItem.mjs +0 -8
  70. package/esm2022/lib/Shared/Models/FormOptions.mjs +0 -32
  71. package/esm2022/lib/Shared/Models/HtmlEditorOptions.mjs +0 -12
  72. package/esm2022/lib/Shared/Models/ImageUploadOptions.mjs +0 -14
  73. package/esm2022/lib/Shared/Models/MapAutoCompleteOptions.mjs +0 -12
  74. package/esm2022/lib/Shared/Models/MapAutocompleteDTO.mjs +0 -6
  75. package/esm2022/lib/Shared/Models/MarkdownEditorOptions.mjs +0 -24
  76. package/esm2022/lib/Shared/Models/MultiLingualHtmlEditorOptions.mjs +0 -9
  77. package/esm2022/lib/Shared/Models/MultiLingualTextAreaOptions.mjs +0 -9
  78. package/esm2022/lib/Shared/Models/MultiLingualTextBoxOptions.mjs +0 -17
  79. package/esm2022/lib/Shared/Models/MultilingualControlOptionsBase.mjs +0 -21
  80. package/esm2022/lib/Shared/Models/MultipleFileUploadModel.mjs +0 -9
  81. package/esm2022/lib/Shared/Models/PagingDTO.mjs +0 -13
  82. package/esm2022/lib/Shared/Models/PagingOptions.mjs +0 -49
  83. package/esm2022/lib/Shared/Models/PagingPayload.mjs +0 -3
  84. package/esm2022/lib/Shared/Models/PhoneOptions.mjs +0 -16
  85. package/esm2022/lib/Shared/Models/ProfileImageUploadOptions.mjs +0 -11
  86. package/esm2022/lib/Shared/Models/ProfilePictureDTO.mjs +0 -3
  87. package/esm2022/lib/Shared/Models/RadioButtonItem.mjs +0 -3
  88. package/esm2022/lib/Shared/Models/RadioButtonOptions.mjs +0 -7
  89. package/esm2022/lib/Shared/Models/RangeNumber.mjs +0 -3
  90. package/esm2022/lib/Shared/Models/Recaptcha.mjs +0 -6
  91. package/esm2022/lib/Shared/Models/RecaptchaOptions.mjs +0 -22
  92. package/esm2022/lib/Shared/Models/RepeaterField.mjs +0 -3
  93. package/esm2022/lib/Shared/Models/RepeaterOptions.mjs +0 -14
  94. package/esm2022/lib/Shared/Models/SaveDTO.mjs +0 -7
  95. package/esm2022/lib/Shared/Models/TagsInputDTO.mjs +0 -3
  96. package/esm2022/lib/Shared/Models/TagsInputOptions.mjs +0 -56
  97. package/esm2022/lib/Shared/Models/TextAreaOptions.mjs +0 -19
  98. package/esm2022/lib/Shared/Models/TextBoxOptions.mjs +0 -27
  99. package/esm2022/lib/Shared/Models/ToggleSlideOptions.mjs +0 -9
  100. package/esm2022/lib/Shared/Models/UploadPersonalImage.mjs +0 -7
  101. package/esm2022/lib/Shared/Models/bread-crumb.mjs +0 -8
  102. package/esm2022/lib/Shared/Models/control-filter-Item.mjs +0 -6
  103. package/esm2022/lib/Shared/Models/filter-options.mjs +0 -9
  104. package/esm2022/lib/Shared/Models/index.mjs +0 -58
  105. package/esm2022/lib/Shared/Models/page-header-options.mjs +0 -78
  106. package/esm2022/lib/Shared/Pipes/bbsf-date-time.pipe.mjs +0 -22
  107. package/esm2022/lib/Shared/Pipes/bbsf-date.pipe.mjs +0 -22
  108. package/esm2022/lib/Shared/config/environment.mjs +0 -12
  109. package/esm2022/lib/Shared/default_intl.mjs +0 -29
  110. package/esm2022/lib/Shared/services/ControlUtility.mjs +0 -162
  111. package/esm2022/lib/Shared/services/GlobalSettings.service.mjs +0 -30
  112. package/esm2022/lib/Shared/services/OnPagingFiltersChange.service.mjs +0 -24
  113. package/esm2022/lib/Shared/services/file-upload.service.mjs +0 -29
  114. package/esm2022/lib/Shared/services/index.mjs +0 -7
  115. package/esm2022/lib/Shared/services/render-component-service.service.mjs +0 -32
  116. package/esm2022/lib/Shared/services/validationErrorMassage.service.mjs +0 -125
  117. package/esm2022/lib/Shared/utils/date-formatter.mjs +0 -48
  118. package/esm2022/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.mjs +0 -299
  119. package/esm2022/lib/controls/Calendar/Calendar.component.mjs +0 -179
  120. package/esm2022/lib/controls/CheckBox/CheckBox.component.mjs +0 -121
  121. package/esm2022/lib/controls/ConfirmationModal/ConfirmationModal.component.mjs +0 -143
  122. package/esm2022/lib/controls/DateTimePicker/DateTimePicker.component.mjs +0 -240
  123. package/esm2022/lib/controls/DropdownList/DropdownList.component.mjs +0 -296
  124. package/esm2022/lib/controls/FileUpload/FileUpload.component.mjs +0 -741
  125. package/esm2022/lib/controls/Form/Form.component.mjs +0 -117
  126. package/esm2022/lib/controls/HtmlEditor/HtmlEditor.component.mjs +0 -185
  127. package/esm2022/lib/controls/ImageUpload/ImageUpload.component.mjs +0 -360
  128. package/esm2022/lib/controls/MapAutoComplete/MapAutoComplete.component.mjs +0 -502
  129. package/esm2022/lib/controls/MarkdownEditor/markdown-editor.component.mjs +0 -243
  130. package/esm2022/lib/controls/MultiLingualHtmlEditor/MultiLingualHtmlEditor.component.mjs +0 -456
  131. package/esm2022/lib/controls/MultiLingualTextArea/MultiLingualTextArea.component.mjs +0 -441
  132. package/esm2022/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.mjs +0 -500
  133. package/esm2022/lib/controls/Paging/JwPagination.component.mjs +0 -160
  134. package/esm2022/lib/controls/Paging/Paging.component.mjs +0 -623
  135. package/esm2022/lib/controls/Phone/Phone.component.mjs +0 -134
  136. package/esm2022/lib/controls/ProfileImageUploader/ProfileImageUploader.component.mjs +0 -390
  137. package/esm2022/lib/controls/RadioButton/RadioButton.component.mjs +0 -113
  138. package/esm2022/lib/controls/Recaptcha/Recaptcha.component.mjs +0 -134
  139. package/esm2022/lib/controls/Repeater/repeater/repeater.component.mjs +0 -135
  140. package/esm2022/lib/controls/Repeater/repeater-field-builder/repeater-field-builder.component.mjs +0 -1291
  141. package/esm2022/lib/controls/Repeater/repeater-item-field/repeater-item-field.component.mjs +0 -22
  142. package/esm2022/lib/controls/Repeater/repeater-table/repeater-table.component.mjs +0 -118
  143. package/esm2022/lib/controls/TagsInput/TagsInput.component.mjs +0 -308
  144. package/esm2022/lib/controls/TextArea/TextArea.component.mjs +0 -581
  145. package/esm2022/lib/controls/TextBox/TextBox.component.mjs +0 -357
  146. package/esm2022/lib/controls/Toggleslide/Toggleslide.component.mjs +0 -96
  147. package/esm2022/lib/controls/bbsf-controls.module.mjs +0 -92
  148. package/esm2022/lib/controls/page-header-component/page-header-component.component.mjs +0 -42
  149. package/esm2022/lib/modules/bbsf-core.module.mjs +0 -210
  150. package/esm2022/lib/modules/bbsf-datetime.module.mjs +0 -90
  151. package/esm2022/lib/modules/bbsf-dropdown.module.mjs +0 -57
  152. package/esm2022/lib/modules/bbsf-editors.module.mjs +0 -97
  153. package/esm2022/lib/modules/bbsf-forms-basic.module.mjs +0 -79
  154. package/esm2022/lib/modules/bbsf-multilingual.module.mjs +0 -60
  155. package/esm2022/lib/modules/bbsf-phone.module.mjs +0 -57
  156. package/esm2022/lib/modules/bbsf-specialized.module.mjs +0 -160
  157. package/esm2022/lib/modules/bbsf-uploads.module.mjs +0 -106
  158. package/esm2022/lib/modules/bbsf-utility.module.mjs +0 -103
  159. 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>"]}