@bnsights/bbsf-controls 1.0.85 → 1.0.87

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 (219) hide show
  1. package/README.md +6 -1
  2. package/bnsights-bbsf-controls-1.0.87.tgz +0 -0
  3. package/bnsights-bbsf-controls.d.ts +1 -1
  4. package/esm2020/bnsights-bbsf-controls.mjs +5 -0
  5. package/esm2020/lib/Shared/Directives/template-name.directive.mjs +18 -0
  6. package/{esm2015/lib/Shared/Enums/CalendarView.js → esm2020/lib/Shared/Enums/CalendarView.mjs} +0 -0
  7. package/{esm2015/lib/Shared/Enums/ControlLayout.js → esm2020/lib/Shared/Enums/ControlLayout.mjs} +0 -0
  8. package/{esm2015/lib/Shared/Enums/Countries.js → esm2020/lib/Shared/Enums/Countries.mjs} +0 -0
  9. package/{esm2015/lib/Shared/Enums/Enums.js → esm2020/lib/Shared/Enums/Enums.mjs} +0 -0
  10. package/{esm2015/lib/Shared/Enums/FileType.js → esm2020/lib/Shared/Enums/FileType.mjs} +0 -0
  11. package/{esm2015/lib/Shared/Enums/FilterType.js → esm2020/lib/Shared/Enums/FilterType.mjs} +0 -0
  12. package/{esm2015/lib/Shared/Enums/FontSize.js → esm2020/lib/Shared/Enums/FontSize.mjs} +0 -0
  13. package/{esm2015/lib/Shared/Enums/ForceDirection.js → esm2020/lib/Shared/Enums/ForceDirection.mjs} +0 -0
  14. package/{esm2015/lib/Shared/Enums/IconPosition.js → esm2020/lib/Shared/Enums/IconPosition.mjs} +0 -0
  15. package/{esm2015/lib/Shared/Enums/ImageType.js → esm2020/lib/Shared/Enums/ImageType.mjs} +0 -0
  16. package/{esm2015/lib/Shared/Enums/InputType.js → esm2020/lib/Shared/Enums/InputType.mjs} +0 -0
  17. package/{esm2015/lib/Shared/Enums/Insert.js → esm2020/lib/Shared/Enums/Insert.mjs} +0 -0
  18. package/{esm2015/lib/Shared/Enums/LanguageMode.js → esm2020/lib/Shared/Enums/LanguageMode.mjs} +0 -0
  19. package/{esm2015/lib/Shared/Enums/LanguageValidation.js → esm2020/lib/Shared/Enums/LanguageValidation.mjs} +0 -0
  20. package/{esm2015/lib/Shared/Enums/Misc.js → esm2020/lib/Shared/Enums/Misc.mjs} +0 -0
  21. package/{esm2015/lib/Shared/Enums/PagingActionMode.js → esm2020/lib/Shared/Enums/PagingActionMode.mjs} +0 -0
  22. package/{esm2015/lib/Shared/Enums/Para.js → esm2020/lib/Shared/Enums/Para.mjs} +0 -0
  23. package/{esm2015/lib/Shared/Enums/PickerType.js → esm2020/lib/Shared/Enums/PickerType.mjs} +0 -0
  24. package/{esm2015/lib/Shared/Enums/SelectMode.js → esm2020/lib/Shared/Enums/SelectMode.mjs} +0 -0
  25. package/{esm2015/lib/Shared/Enums/StartView.js → esm2020/lib/Shared/Enums/StartView.mjs} +0 -0
  26. package/{esm2015/lib/Shared/Enums/Style.js → esm2020/lib/Shared/Enums/Style.mjs} +0 -0
  27. package/{esm2015/lib/Shared/Enums/StyleConfirmationMode.js → esm2020/lib/Shared/Enums/StyleConfirmationMode.mjs} +0 -0
  28. package/{esm2015/lib/Shared/Enums/TagInputView.js → esm2020/lib/Shared/Enums/TagInputView.mjs} +0 -0
  29. package/{esm2015/lib/Shared/Enums/menu-list-enum.js → esm2020/lib/Shared/Enums/menu-list-enum.mjs} +0 -0
  30. package/{esm2015/lib/Shared/Models/Attribute.js → esm2020/lib/Shared/Models/Attribute.mjs} +0 -0
  31. package/{esm2015/lib/Shared/Models/AutocompleteDTO.js → esm2020/lib/Shared/Models/AutocompleteDTO.mjs} +0 -0
  32. package/{esm2015/lib/Shared/Models/AutocompleteOptions.js → esm2020/lib/Shared/Models/AutocompleteOptions.mjs} +0 -0
  33. package/{esm2015/lib/Shared/Models/CalendarEventDTO.js → esm2020/lib/Shared/Models/CalendarEventDTO.mjs} +0 -0
  34. package/{esm2015/lib/Shared/Models/CalendarOptions.js → esm2020/lib/Shared/Models/CalendarOptions.mjs} +0 -0
  35. package/{esm2015/lib/Shared/Models/CancelDTO.js → esm2020/lib/Shared/Models/CancelDTO.mjs} +0 -0
  36. package/{esm2015/lib/Shared/Models/CaptchaStyle.js → esm2020/lib/Shared/Models/CaptchaStyle.mjs} +0 -0
  37. package/{esm2015/lib/Shared/Models/CheckBoxOptions.js → esm2020/lib/Shared/Models/CheckBoxOptions.mjs} +0 -0
  38. package/{esm2015/lib/Shared/Models/ConfirmationModalOptions.js → esm2020/lib/Shared/Models/ConfirmationModalOptions.mjs} +0 -0
  39. package/{esm2015/lib/Shared/Models/ControlOptionsBase.js → esm2020/lib/Shared/Models/ControlOptionsBase.mjs} +0 -0
  40. package/{esm2015/lib/Shared/Models/CustomValidation.js → esm2020/lib/Shared/Models/CustomValidation.mjs} +0 -0
  41. package/{esm2015/lib/Shared/Models/DropdownListItem.js → esm2020/lib/Shared/Models/DropdownListItem.mjs} +0 -0
  42. package/{esm2015/lib/Shared/Models/DropdownOptions.js → esm2020/lib/Shared/Models/DropdownOptions.mjs} +0 -0
  43. package/{esm2015/lib/Shared/Models/EditPersonalImage.js → esm2020/lib/Shared/Models/EditPersonalImage.mjs} +0 -0
  44. package/{esm2015/lib/Shared/Models/EnglishArabicDTO.js → esm2020/lib/Shared/Models/EnglishArabicDTO.mjs} +0 -0
  45. package/{esm2015/lib/Shared/Models/FileDTO.js → esm2020/lib/Shared/Models/FileDTO.mjs} +0 -0
  46. package/{esm2015/lib/Shared/Models/FileUploadModel.js → esm2020/lib/Shared/Models/FileUploadModel.mjs} +0 -0
  47. package/{esm2015/lib/Shared/Models/FileUploadOptions.js → esm2020/lib/Shared/Models/FileUploadOptions.mjs} +0 -0
  48. package/{esm2015/lib/Shared/Models/FilterItem.js → esm2020/lib/Shared/Models/FilterItem.mjs} +0 -0
  49. package/{esm2015/lib/Shared/Models/FormOptions.js → esm2020/lib/Shared/Models/FormOptions.mjs} +0 -0
  50. package/{esm2015/lib/Shared/Models/HtmlEditorOptions.js → esm2020/lib/Shared/Models/HtmlEditorOptions.mjs} +0 -0
  51. package/{esm2015/lib/Shared/Models/ImageUploadOptions.js → esm2020/lib/Shared/Models/ImageUploadOptions.mjs} +0 -0
  52. package/{esm2015/lib/Shared/Models/MapAutoCompleteOptions.js → esm2020/lib/Shared/Models/MapAutoCompleteOptions.mjs} +0 -0
  53. package/{esm2015/lib/Shared/Models/MapAutocompleteDTO.js → esm2020/lib/Shared/Models/MapAutocompleteDTO.mjs} +0 -0
  54. package/{esm2015/lib/Shared/Models/MultiLingualHtmlEditorOptions.js → esm2020/lib/Shared/Models/MultiLingualHtmlEditorOptions.mjs} +0 -0
  55. package/{esm2015/lib/Shared/Models/MultiLingualTextAreaOptions.js → esm2020/lib/Shared/Models/MultiLingualTextAreaOptions.mjs} +0 -0
  56. package/{esm2015/lib/Shared/Models/MultilingualControlOptionsBase.js → esm2020/lib/Shared/Models/MultilingualControlOptionsBase.mjs} +0 -0
  57. package/{esm2015/lib/Shared/Models/MultilingualTextBoxOptions.js → esm2020/lib/Shared/Models/MultilingualTextBoxOptions.mjs} +0 -0
  58. package/{esm2015/lib/Shared/Models/MultipleFileUploadModel.js → esm2020/lib/Shared/Models/MultipleFileUploadModel.mjs} +0 -0
  59. package/{esm2015/lib/Shared/Models/PagingDTO.js → esm2020/lib/Shared/Models/PagingDTO.mjs} +0 -0
  60. package/{esm2015/lib/Shared/Models/PagingOptions.js → esm2020/lib/Shared/Models/PagingOptions.mjs} +0 -0
  61. package/{esm2015/lib/Shared/Models/PagingPayload.js → esm2020/lib/Shared/Models/PagingPayload.mjs} +0 -0
  62. package/{esm2015/lib/Shared/Models/PhoneOptions.js → esm2020/lib/Shared/Models/PhoneOptions.mjs} +0 -0
  63. package/{esm2015/lib/Shared/Models/ProfileImageUploadOptions.js → esm2020/lib/Shared/Models/ProfileImageUploadOptions.mjs} +0 -0
  64. package/{esm2015/lib/Shared/Models/ProfilePictureDTO.js → esm2020/lib/Shared/Models/ProfilePictureDTO.mjs} +0 -0
  65. package/{esm2015/lib/Shared/Models/RadioButtonItem.js → esm2020/lib/Shared/Models/RadioButtonItem.mjs} +0 -0
  66. package/{esm2015/lib/Shared/Models/RadioButtonOptions.js → esm2020/lib/Shared/Models/RadioButtonOptions.mjs} +0 -0
  67. package/{esm2015/lib/Shared/Models/RangeNumber.js → esm2020/lib/Shared/Models/RangeNumber.mjs} +0 -0
  68. package/{esm2015/lib/Shared/Models/Recaptcha.js → esm2020/lib/Shared/Models/Recaptcha.mjs} +0 -0
  69. package/{esm2015/lib/Shared/Models/RecaptchaOptions.js → esm2020/lib/Shared/Models/RecaptchaOptions.mjs} +0 -0
  70. package/{esm2015/lib/Shared/Models/RepeaterField.js → esm2020/lib/Shared/Models/RepeaterField.mjs} +0 -0
  71. package/{esm2015/lib/Shared/Models/RepeaterOptions.js → esm2020/lib/Shared/Models/RepeaterOptions.mjs} +0 -0
  72. package/{esm2015/lib/Shared/Models/SaveDTO.js → esm2020/lib/Shared/Models/SaveDTO.mjs} +0 -0
  73. package/{esm2015/lib/Shared/Models/TagsInputDTO.js → esm2020/lib/Shared/Models/TagsInputDTO.mjs} +0 -0
  74. package/{esm2015/lib/Shared/Models/TagsInputOptions.js → esm2020/lib/Shared/Models/TagsInputOptions.mjs} +0 -0
  75. package/{esm2015/lib/Shared/Models/TextAreaOptions.js → esm2020/lib/Shared/Models/TextAreaOptions.mjs} +0 -0
  76. package/{esm2015/lib/Shared/Models/TextBoxOptions.js → esm2020/lib/Shared/Models/TextBoxOptions.mjs} +0 -0
  77. package/{esm2015/lib/Shared/Models/ToggleslideOptions.js → esm2020/lib/Shared/Models/ToggleslideOptions.mjs} +0 -0
  78. package/{esm2015/lib/Shared/Models/UploadPersonalImage.js → esm2020/lib/Shared/Models/UploadPersonalImage.mjs} +0 -0
  79. package/{esm2015/lib/Shared/Models/bread-crumb.js → esm2020/lib/Shared/Models/bread-crumb.mjs} +0 -0
  80. package/{esm2015/lib/Shared/Models/control-filter-Item.js → esm2020/lib/Shared/Models/control-filter-Item.mjs} +0 -0
  81. package/{esm2015/lib/Shared/Models/datePickerOptions.js → esm2020/lib/Shared/Models/datePickerOptions.mjs} +1 -1
  82. package/{esm2015/lib/Shared/Models/filter-options.js → esm2020/lib/Shared/Models/filter-options.mjs} +0 -0
  83. package/{esm2015/lib/Shared/Models/page-header-options.js → esm2020/lib/Shared/Models/page-header-options.mjs} +0 -0
  84. package/esm2020/lib/Shared/Pipes/bbsf-date-time.pipe.mjs +21 -0
  85. package/esm2020/lib/Shared/Pipes/bbsf-date.pipe.mjs +21 -0
  86. package/esm2020/lib/Shared/components/app-base-component.mjs +198 -0
  87. package/esm2020/lib/Shared/components/ng-tag-input.mjs +336 -0
  88. package/{esm2015/lib/Shared/config/environment.js → esm2020/lib/Shared/config/environment.mjs} +0 -0
  89. package/esm2020/lib/Shared/default_intl.mjs +29 -0
  90. package/esm2020/lib/Shared/services/ControlUtility.mjs +162 -0
  91. package/esm2020/lib/Shared/services/GlobalSettings.service.mjs +30 -0
  92. package/esm2020/lib/Shared/services/OnPagingFiltersChange.service.mjs +24 -0
  93. package/esm2020/lib/Shared/services/render-component-service.service.mjs +30 -0
  94. package/esm2020/lib/Shared/services/validationErrorMassage.service.mjs +137 -0
  95. package/esm2020/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.mjs +245 -0
  96. package/esm2020/lib/controls/Calendar/Calendar.component.mjs +172 -0
  97. package/esm2020/lib/controls/CheckBox/CheckBox.component.mjs +114 -0
  98. package/esm2020/lib/controls/ConfirmationModal/ConfirmationModal.component.mjs +136 -0
  99. package/esm2020/lib/controls/DateTimePicker/DateTimePicker.component.mjs +217 -0
  100. package/esm2020/lib/controls/DropdownList/DropdownList.component.mjs +179 -0
  101. package/esm2020/lib/controls/FileUplaod/FileUplaod.component.mjs +453 -0
  102. package/esm2020/lib/controls/Form/Form.component.mjs +101 -0
  103. package/esm2020/lib/controls/HtmlEditor/HtmlEditor.component.mjs +223 -0
  104. package/esm2020/lib/controls/ImageUpload/ImageUpload.component.mjs +350 -0
  105. package/esm2020/lib/controls/MapAutoComplete/MapAutoComplete.component.mjs +325 -0
  106. package/esm2020/lib/controls/MultiLingualHtmlEditor/MultiLingualHtmlEditor.component.mjs +427 -0
  107. package/esm2020/lib/controls/MultiLingualTextArea/MultiLingualTextArea.component.mjs +427 -0
  108. package/esm2020/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.mjs +426 -0
  109. package/esm2020/lib/controls/Paging/JwPagination.component.mjs +156 -0
  110. package/esm2020/lib/controls/Paging/Paging.component.mjs +312 -0
  111. package/esm2020/lib/controls/Phone/Phone.component.mjs +124 -0
  112. package/esm2020/lib/controls/ProfileImageUploader/ProfileImageUploader.component.mjs +354 -0
  113. package/esm2020/lib/controls/RadioButton/RadioButton.component.mjs +106 -0
  114. package/esm2020/lib/controls/Recaptcha/Recaptcha.component.mjs +132 -0
  115. package/esm2020/lib/controls/Repeater/repeater/repeater.component.mjs +125 -0
  116. package/esm2020/lib/controls/Repeater/repeater-field-builder/repeater-field-builder.component.mjs +750 -0
  117. package/esm2020/lib/controls/Repeater/repeater-item-field/repeater-item-field.component.mjs +21 -0
  118. package/esm2020/lib/controls/Repeater/repeater-table/repeater-table.component.mjs +108 -0
  119. package/esm2020/lib/controls/TagsInput/TagsInput.component.mjs +268 -0
  120. package/esm2020/lib/controls/TextArea/TextArea.component.mjs +192 -0
  121. package/esm2020/lib/controls/TextBox/TextBox.component.mjs +266 -0
  122. package/esm2020/lib/controls/Toggleslide/toggleslide.component.mjs +84 -0
  123. package/esm2020/lib/controls/bbsf-controls.module.mjs +401 -0
  124. package/esm2020/lib/controls/page-header-component/page-header-component.component.mjs +37 -0
  125. package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
  126. package/fesm2015/{bnsights-bbsf-controls.js → bnsights-bbsf-controls.mjs} +1872 -1625
  127. package/fesm2015/bnsights-bbsf-controls.mjs.map +1 -0
  128. package/fesm2020/bnsights-bbsf-controls.mjs +8938 -0
  129. package/fesm2020/bnsights-bbsf-controls.mjs.map +1 -0
  130. package/lib/Shared/Directives/template-name.directive.d.ts +3 -0
  131. package/lib/Shared/Models/datePickerOptions.d.ts +1 -1
  132. package/lib/Shared/Pipes/bbsf-date-time.pipe.d.ts +3 -0
  133. package/lib/Shared/Pipes/bbsf-date.pipe.d.ts +3 -0
  134. package/lib/Shared/components/app-base-component.d.ts +3 -0
  135. package/lib/Shared/components/ng-tag-input.d.ts +3 -0
  136. package/lib/Shared/default_intl.d.ts +3 -0
  137. package/lib/Shared/services/ControlUtility.d.ts +3 -0
  138. package/lib/Shared/services/GlobalSettings.service.d.ts +3 -0
  139. package/lib/Shared/services/OnPagingFiltersChange.service.d.ts +3 -0
  140. package/lib/Shared/services/render-component-service.service.d.ts +3 -0
  141. package/lib/Shared/services/validationErrorMassage.service.d.ts +3 -0
  142. package/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.d.ts +4 -0
  143. package/lib/controls/Calendar/Calendar.component.d.ts +3 -0
  144. package/lib/controls/CheckBox/CheckBox.component.d.ts +4 -0
  145. package/lib/controls/ConfirmationModal/ConfirmationModal.component.d.ts +3 -0
  146. package/lib/controls/DateTimePicker/DateTimePicker.component.d.ts +8 -2
  147. package/lib/controls/DropdownList/DropdownList.component.d.ts +4 -0
  148. package/lib/controls/FileUplaod/FileUplaod.component.d.ts +5 -0
  149. package/lib/controls/Form/Form.component.d.ts +3 -0
  150. package/lib/controls/HtmlEditor/HtmlEditor.component.d.ts +4 -0
  151. package/lib/controls/ImageUpload/ImageUpload.component.d.ts +3 -0
  152. package/lib/controls/MapAutoComplete/MapAutoComplete.component.d.ts +3 -0
  153. package/lib/controls/MultiLingualHtmlEditor/MultiLingualHtmlEditor.component.d.ts +3 -0
  154. package/lib/controls/MultiLingualTextArea/MultiLingualTextArea.component.d.ts +3 -0
  155. package/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.d.ts +3 -0
  156. package/lib/controls/Paging/JwPagination.component.d.ts +3 -0
  157. package/lib/controls/Paging/Paging.component.d.ts +3 -0
  158. package/lib/controls/Phone/Phone.component.d.ts +7 -1
  159. package/lib/controls/ProfileImageUploader/ProfileImageUploader.component.d.ts +3 -0
  160. package/lib/controls/RadioButton/RadioButton.component.d.ts +3 -0
  161. package/lib/controls/Recaptcha/Recaptcha.component.d.ts +4 -0
  162. package/lib/controls/Repeater/repeater/repeater.component.d.ts +3 -0
  163. package/lib/controls/Repeater/repeater-field-builder/repeater-field-builder.component.d.ts +3 -0
  164. package/lib/controls/Repeater/repeater-item-field/repeater-item-field.component.d.ts +3 -0
  165. package/lib/controls/Repeater/repeater-table/repeater-table.component.d.ts +3 -0
  166. package/lib/controls/TagsInput/TagsInput.component.d.ts +4 -0
  167. package/lib/controls/TextArea/TextArea.component.d.ts +4 -0
  168. package/lib/controls/TextBox/TextBox.component.d.ts +4 -0
  169. package/lib/controls/Toggleslide/toggleslide.component.d.ts +4 -0
  170. package/lib/controls/bbsf-controls.module.d.ts +74 -0
  171. package/lib/controls/page-header-component/page-header-component.component.d.ts +3 -0
  172. package/package.json +20 -8
  173. package/bnsights-bbsf-controls-1.0.85.tgz +0 -0
  174. package/bnsights-bbsf-controls.metadata.json +0 -1
  175. package/bundles/bnsights-bbsf-controls.umd.js +0 -9326
  176. package/bundles/bnsights-bbsf-controls.umd.js.map +0 -1
  177. package/esm2015/bnsights-bbsf-controls.js +0 -6
  178. package/esm2015/lib/Shared/Directives/template-name.directive.js +0 -18
  179. package/esm2015/lib/Shared/Pipes/bbsf-date-time.pipe.js +0 -20
  180. package/esm2015/lib/Shared/Pipes/bbsf-date.pipe.js +0 -20
  181. package/esm2015/lib/Shared/components/app-base-component.js +0 -198
  182. package/esm2015/lib/Shared/components/ng-tag-input.js +0 -323
  183. package/esm2015/lib/Shared/default_intl.js +0 -29
  184. package/esm2015/lib/Shared/services/ControlUtility.js +0 -164
  185. package/esm2015/lib/Shared/services/GlobalSettings.service.js +0 -28
  186. package/esm2015/lib/Shared/services/OnPagingFiltersChange.service.js +0 -22
  187. package/esm2015/lib/Shared/services/render-component-service.service.js +0 -30
  188. package/esm2015/lib/Shared/services/validationErrorMassage.service.js +0 -137
  189. package/esm2015/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.js +0 -248
  190. package/esm2015/lib/controls/Calendar/Calendar.component.js +0 -176
  191. package/esm2015/lib/controls/CheckBox/CheckBox.component.js +0 -114
  192. package/esm2015/lib/controls/ConfirmationModal/ConfirmationModal.component.js +0 -139
  193. package/esm2015/lib/controls/DateTimePicker/DateTimePicker.component.js +0 -215
  194. package/esm2015/lib/controls/DropdownList/DropdownList.component.js +0 -178
  195. package/esm2015/lib/controls/FileUplaod/FileUplaod.component.js +0 -347
  196. package/esm2015/lib/controls/Form/Form.component.js +0 -106
  197. package/esm2015/lib/controls/HtmlEditor/HtmlEditor.component.js +0 -222
  198. package/esm2015/lib/controls/ImageUpload/ImageUpload.component.js +0 -347
  199. package/esm2015/lib/controls/MapAutoComplete/MapAutoComplete.component.js +0 -325
  200. package/esm2015/lib/controls/MultiLingualHtmlEditor/MultiLingualHtmlEditor.component.js +0 -429
  201. package/esm2015/lib/controls/MultiLingualTextArea/MultiLingualTextArea.component.js +0 -430
  202. package/esm2015/lib/controls/MultiLingualTextBox/MultiLingualTextBox.component.js +0 -429
  203. package/esm2015/lib/controls/Paging/JwPagination.component.js +0 -129
  204. package/esm2015/lib/controls/Paging/Paging.component.js +0 -312
  205. package/esm2015/lib/controls/Phone/Phone.component.js +0 -119
  206. package/esm2015/lib/controls/ProfileImageUploader/ProfileImageUploader.component.js +0 -349
  207. package/esm2015/lib/controls/RadioButton/RadioButton.component.js +0 -108
  208. package/esm2015/lib/controls/Recaptcha/Recaptcha.component.js +0 -131
  209. package/esm2015/lib/controls/Repeater/repeater/repeater.component.js +0 -117
  210. package/esm2015/lib/controls/Repeater/repeater-field-builder/repeater-field-builder.component.js +0 -748
  211. package/esm2015/lib/controls/Repeater/repeater-item-field/repeater-item-field.component.js +0 -19
  212. package/esm2015/lib/controls/Repeater/repeater-table/repeater-table.component.js +0 -108
  213. package/esm2015/lib/controls/TagsInput/TagsInput.component.js +0 -268
  214. package/esm2015/lib/controls/TextArea/TextArea.component.js +0 -191
  215. package/esm2015/lib/controls/TextBox/TextBox.component.js +0 -262
  216. package/esm2015/lib/controls/Toggleslide/toggleslide.component.js +0 -83
  217. package/esm2015/lib/controls/bbsf-controls.module.js +0 -243
  218. package/esm2015/lib/controls/page-header-component/page-header-component.component.js +0 -32
  219. package/fesm2015/bnsights-bbsf-controls.js.map +0 -1
@@ -0,0 +1,156 @@
1
+ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ export class JwPaginationComponent {
5
+ constructor() {
6
+ this.changePage = new EventEmitter();
7
+ this.initialPage = 1;
8
+ this.pageSize = 10;
9
+ this.maxPages = 10;
10
+ this.ShowFirstAndLast = false;
11
+ this.pager = {};
12
+ }
13
+ ngOnInit() {
14
+ // set page if items array isn't empty
15
+ if (this.items && this.items.length) {
16
+ this.setPage(this.initialPage);
17
+ }
18
+ }
19
+ ngOnChanges(changes) {
20
+ if (changes.items.firstChange)
21
+ return;
22
+ // reset page if items array has changed
23
+ if (changes.items.currentValue !== changes.items.previousValue) {
24
+ this.setPage(this.initialPage);
25
+ }
26
+ }
27
+ setPage(page) {
28
+ // get new pager object for specified page
29
+ this.pager = this.paginate(this.items.length, page, this.pageSize, this.maxPages);
30
+ // get new page of items from items array
31
+ var pageOfItems = this.items.slice(this.pager.startIndex, this.pager.endIndex + 1);
32
+ // call change page function in parent component
33
+ this.changePage.emit(this.pager.currentPage);
34
+ }
35
+ paginate(totalItems, currentPage, pageSize, maxPages) {
36
+ if (currentPage === void 0) {
37
+ currentPage = 1;
38
+ }
39
+ if (pageSize === void 0) {
40
+ pageSize = 10;
41
+ }
42
+ if (maxPages === void 0) {
43
+ maxPages = 10;
44
+ }
45
+ // calculate total pages
46
+ var totalPages = Math.ceil(totalItems / pageSize);
47
+ // ensure current page isn't out of range
48
+ if (currentPage < 1) {
49
+ currentPage = 1;
50
+ }
51
+ else if (currentPage > totalPages) {
52
+ currentPage = totalPages;
53
+ }
54
+ var startPage, endPage;
55
+ if (totalPages <= maxPages) {
56
+ // total pages less than max so show all pages
57
+ startPage = 1;
58
+ endPage = totalPages;
59
+ }
60
+ else {
61
+ // total pages more than max so calculate start and end pages
62
+ var maxPagesBeforeCurrentPage = Math.floor(maxPages / 2);
63
+ var maxPagesAfterCurrentPage = Math.ceil(maxPages / 2) - 1;
64
+ if (currentPage <= maxPagesBeforeCurrentPage) {
65
+ // current page near the start
66
+ startPage = 1;
67
+ endPage = maxPages;
68
+ }
69
+ else if (currentPage + maxPagesAfterCurrentPage >= totalPages) {
70
+ // current page near the end
71
+ startPage = totalPages - maxPages + 1;
72
+ endPage = totalPages;
73
+ }
74
+ else {
75
+ // current page somewhere in the middle
76
+ startPage = currentPage - maxPagesBeforeCurrentPage;
77
+ endPage = currentPage + maxPagesAfterCurrentPage;
78
+ }
79
+ }
80
+ // calculate start and end item indexes
81
+ var startIndex = (currentPage - 1) * pageSize;
82
+ var endIndex = Math.min(startIndex + pageSize - 1, totalItems - 1);
83
+ // create an array of pages to ng-repeat in the pager control
84
+ var pages = Array.from(Array((endPage + 1) - startPage).keys()).map(function (i) { return startPage + i; });
85
+ // return object with all pager properties required by the view
86
+ return {
87
+ totalItems: totalItems,
88
+ currentPage: currentPage,
89
+ pageSize: pageSize,
90
+ totalPages: totalPages,
91
+ startPage: startPage,
92
+ endPage: endPage,
93
+ startIndex: startIndex,
94
+ endIndex: endIndex,
95
+ pages: pages
96
+ };
97
+ }
98
+ }
99
+ JwPaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: JwPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
100
+ JwPaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: JwPaginationComponent, selector: "jw-pagination", inputs: { items: "items", initialPage: "initialPage", pageSize: "pageSize", maxPages: "maxPages", ShowFirstAndLast: "ShowFirstAndLast" }, outputs: { changePage: "changePage" }, usesOnChanges: true, ngImport: i0, template: `
101
+ <ul *ngIf="pager.pages && pager.pages.length" class="pagination">
102
+ <li *ngIf="ShowFirstAndLast" [ngClass]="{disabled:pager.currentPage === 1}" class="page-item first-item">
103
+ <a (click)="setPage(1)" class="page-link">❮❮</a>
104
+ </li>
105
+ <li [ngClass]="{disabled:pager.currentPage === 1}" class="page-item previous-item">
106
+ <a (click)="setPage(pager.currentPage - 1)" class="page-link">❮</a>
107
+ </li>
108
+ <li *ngFor="let page of pager.pages" [ngClass]="{active:pager.currentPage === page}" class="page-item number-item">
109
+ <a (click)="setPage(page)" class="page-link">{{page}}</a>
110
+ </li>
111
+ <li [ngClass]="{disabled:pager.currentPage === pager.totalPages}" class="page-item next-item">
112
+ <a (click)="setPage(pager.currentPage + 1)" class="page-link">❯</a>
113
+ </li>
114
+ <li *ngIf="ShowFirstAndLast" [ngClass]="{disabled:pager.currentPage === pager.totalPages}" class="page-item last-item">
115
+ <a (click)="setPage(pager.totalPages)" class="page-link">❯❯</a>
116
+ </li>
117
+ </ul>
118
+ `, isInline: true, directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
119
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: JwPaginationComponent, decorators: [{
120
+ type: Component,
121
+ args: [{
122
+ selector: 'jw-pagination',
123
+ template: `
124
+ <ul *ngIf="pager.pages && pager.pages.length" class="pagination">
125
+ <li *ngIf="ShowFirstAndLast" [ngClass]="{disabled:pager.currentPage === 1}" class="page-item first-item">
126
+ <a (click)="setPage(1)" class="page-link">❮❮</a>
127
+ </li>
128
+ <li [ngClass]="{disabled:pager.currentPage === 1}" class="page-item previous-item">
129
+ <a (click)="setPage(pager.currentPage - 1)" class="page-link">❮</a>
130
+ </li>
131
+ <li *ngFor="let page of pager.pages" [ngClass]="{active:pager.currentPage === page}" class="page-item number-item">
132
+ <a (click)="setPage(page)" class="page-link">{{page}}</a>
133
+ </li>
134
+ <li [ngClass]="{disabled:pager.currentPage === pager.totalPages}" class="page-item next-item">
135
+ <a (click)="setPage(pager.currentPage + 1)" class="page-link">❯</a>
136
+ </li>
137
+ <li *ngIf="ShowFirstAndLast" [ngClass]="{disabled:pager.currentPage === pager.totalPages}" class="page-item last-item">
138
+ <a (click)="setPage(pager.totalPages)" class="page-link">❯❯</a>
139
+ </li>
140
+ </ul>
141
+ `
142
+ }]
143
+ }], propDecorators: { items: [{
144
+ type: Input
145
+ }], changePage: [{
146
+ type: Output
147
+ }], initialPage: [{
148
+ type: Input
149
+ }], pageSize: [{
150
+ type: Input
151
+ }], maxPages: [{
152
+ type: Input
153
+ }], ShowFirstAndLast: [{
154
+ type: Input
155
+ }] } });
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"JwPagination.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/Paging/JwPagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges } from '@angular/core';\r\n\r\n@Component({\r\n    selector: 'jw-pagination',\r\n    template: `\r\n  <ul *ngIf=\"pager.pages && pager.pages.length\" class=\"pagination\">\r\n  <li *ngIf=\"ShowFirstAndLast\" [ngClass]=\"{disabled:pager.currentPage === 1}\" class=\"page-item first-item\">\r\n      <a (click)=\"setPage(1)\" class=\"page-link\">❮❮</a>\r\n  </li>\r\n  <li [ngClass]=\"{disabled:pager.currentPage === 1}\" class=\"page-item previous-item\">\r\n      <a (click)=\"setPage(pager.currentPage - 1)\" class=\"page-link\">❮</a>\r\n  </li>\r\n  <li *ngFor=\"let page of pager.pages\" [ngClass]=\"{active:pager.currentPage === page}\" class=\"page-item number-item\">\r\n      <a (click)=\"setPage(page)\" class=\"page-link\">{{page}}</a>\r\n  </li>\r\n  <li [ngClass]=\"{disabled:pager.currentPage === pager.totalPages}\" class=\"page-item next-item\">\r\n      <a (click)=\"setPage(pager.currentPage + 1)\" class=\"page-link\">❯</a>\r\n  </li>\r\n  <li  *ngIf=\"ShowFirstAndLast\" [ngClass]=\"{disabled:pager.currentPage === pager.totalPages}\" class=\"page-item last-item\">\r\n      <a (click)=\"setPage(pager.totalPages)\" class=\"page-link\">❯❯</a>\r\n  </li>\r\n</ul>\r\n`\r\n})\r\n\r\nexport class JwPaginationComponent implements OnInit, OnChanges {\r\n    @Input() items: Array<any>;\r\n    @Output() changePage = new EventEmitter();\r\n    @Input() initialPage = 1;\r\n    @Input() pageSize = 10;\r\n    @Input() maxPages = 10;\r\n    @Input() ShowFirstAndLast = false;\r\n\r\n\r\n    pager: any = {};\r\n\r\n    ngOnInit() {\r\n        // set page if items array isn't empty\r\n        if (this.items && this.items.length) {\r\n            this.setPage(this.initialPage);\r\n        }\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.items.firstChange)\r\n            return\r\n        // reset page if items array has changed\r\n        if (changes.items.currentValue !== changes.items.previousValue) {\r\n            this.setPage(this.initialPage);\r\n        }\r\n    }\r\n\r\n    setPage(page: number) {\r\n        // get new pager object for specified page\r\n        this.pager = this.paginate(this.items.length, page, this.pageSize, this.maxPages);\r\n\r\n        // get new page of items from items array\r\n        var pageOfItems = this.items.slice(this.pager.startIndex, this.pager.endIndex + 1);\r\n\r\n        // call change page function in parent component\r\n        this.changePage.emit(this.pager.currentPage);\r\n    }\r\n\r\n    paginate(totalItems, currentPage, pageSize, maxPages) {\r\n        if (currentPage === void 0) { currentPage = 1; }\r\n        if (pageSize === void 0) { pageSize = 10; }\r\n        if (maxPages === void 0) { maxPages = 10; }\r\n        // calculate total pages\r\n        var totalPages = Math.ceil(totalItems / pageSize);\r\n        // ensure current page isn't out of range\r\n        if (currentPage < 1) {\r\n            currentPage = 1;\r\n        }\r\n        else if (currentPage > totalPages) {\r\n            currentPage = totalPages;\r\n        }\r\n        var startPage, endPage;\r\n        if (totalPages <= maxPages) {\r\n            // total pages less than max so show all pages\r\n            startPage = 1;\r\n            endPage = totalPages;\r\n        }\r\n        else {\r\n            // total pages more than max so calculate start and end pages\r\n            var maxPagesBeforeCurrentPage = Math.floor(maxPages / 2);\r\n            var maxPagesAfterCurrentPage = Math.ceil(maxPages / 2) - 1;\r\n            if (currentPage <= maxPagesBeforeCurrentPage) {\r\n                // current page near the start\r\n                startPage = 1;\r\n                endPage = maxPages;\r\n            }\r\n            else if (currentPage + maxPagesAfterCurrentPage >= totalPages) {\r\n                // current page near the end\r\n                startPage = totalPages - maxPages + 1;\r\n                endPage = totalPages;\r\n            }\r\n            else {\r\n                // current page somewhere in the middle\r\n                startPage = currentPage - maxPagesBeforeCurrentPage;\r\n                endPage = currentPage + maxPagesAfterCurrentPage;\r\n            }\r\n        }\r\n        // calculate start and end item indexes\r\n        var startIndex = (currentPage - 1) * pageSize;\r\n        var endIndex = Math.min(startIndex + pageSize - 1, totalItems - 1);\r\n        // create an array of pages to ng-repeat in the pager control\r\n        var pages = Array.from(Array((endPage + 1) - startPage).keys()).map(function (i) { return startPage + i; });\r\n        // return object with all pager properties required by the view\r\n        return {\r\n            totalItems: totalItems,\r\n            currentPage: currentPage,\r\n            pageSize: pageSize,\r\n            totalPages: totalPages,\r\n            startPage: startPage,\r\n            endPage: endPage,\r\n            startIndex: startIndex,\r\n            endIndex: endIndex,\r\n            pages: pages\r\n        };\r\n    }\r\n\r\n}"]}
@@ -0,0 +1,312 @@
1
+ import { Component, Output, EventEmitter, Input } from '@angular/core';
2
+ import { PagingDTO } from '../../Shared/Models/PagingDTO';
3
+ import { Subscription } from 'rxjs';
4
+ import { FilterType } from '../../Shared/Enums/FilterType';
5
+ import { RequestOptionsModel } from '@bnsights/bbsf-utilities';
6
+ import { plainToClass } from 'class-transformer';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@bnsights/bbsf-utilities";
9
+ import * as i2 from "@angular/common/http";
10
+ import * as i3 from "@angular/router";
11
+ import * as i4 from "../../Shared/services/OnPagingFiltersChange.service";
12
+ import * as i5 from "./JwPagination.component";
13
+ import * as i6 from "@angular/common";
14
+ import * as i7 from "@angular/forms";
15
+ import * as i8 from "ngx-infinite-scroll";
16
+ // tslint:disable-next-line: no-conflicting-lifecycle
17
+ export class PagingComponent {
18
+ constructor(utilityService, http, router, onChangeService, requestHandlerService) {
19
+ this.utilityService = utilityService;
20
+ this.http = http;
21
+ this.router = router;
22
+ this.onChangeService = onChangeService;
23
+ this.requestHandlerService = requestHandlerService;
24
+ this.items = [];
25
+ this.result = [];
26
+ this.pagerConfig = null;
27
+ this.totalRow = 0;
28
+ this.pageSize = 10;
29
+ this.Pages = 0;
30
+ this.CurrentPage = 1;
31
+ this.ShowPageSizeOption = true;
32
+ this.ShowFirstAndLast = true;
33
+ this.hidePaginationWhenPageSizeEqualOne = true;
34
+ this.Sum = 0;
35
+ this.Throttle = 300;
36
+ this.ScrollDistance = 1;
37
+ this.ScrollUpDistance = 2;
38
+ this.direction = '';
39
+ this.IsFirstCall = true;
40
+ this.Items = new EventEmitter();
41
+ this.subscriptions = new Subscription();
42
+ this.ReinitializePaging = () => {
43
+ this.IsFirstCall = true;
44
+ this.getItemList(1, true);
45
+ };
46
+ this.UpdatePaging = () => {
47
+ //this.IsFirstCall=true;
48
+ this.getItemList(this.CurrentPage);
49
+ };
50
+ }
51
+ ngOnDestroy() {
52
+ this.subscriptions.unsubscribe();
53
+ }
54
+ ngOnInit() {
55
+ if (this.options.IsLoadMoreControl)
56
+ this.Sum = this.options.PageSize;
57
+ if (this.options.DropdownFiltersControlNames != null && this.options.DropdownFiltersControlNames.length > 0) {
58
+ const DropdownFiltersControlNames = this.options.DropdownFiltersControlNames;
59
+ this.subscriptions.add(this.onChangeService.GetValue().subscribe((value) => {
60
+ let result = this.options.DropdownFiltersControlNames.filter((item) => item == value);
61
+ if (result.length > 0) {
62
+ this.IsFirstCall = true;
63
+ this.CurrentPage = 1;
64
+ this.getItemList(this.CurrentPage, true);
65
+ }
66
+ }));
67
+ }
68
+ if (this.options.BootstrapDatePickersFiltersControlNames != null && this.options.BootstrapDatePickersFiltersControlNames.length > 0) {
69
+ const BootstrapDatePickersFiltersControlNames = this.options.BootstrapDatePickersFiltersControlNames;
70
+ this.subscriptions.add(this.onChangeService.GetValue().subscribe((value) => {
71
+ let result = this.options.BootstrapDatePickersFiltersControlNames.filter((item) => item == value);
72
+ if (result.length > 0) {
73
+ this.IsFirstCall = true;
74
+ this.CurrentPage = 1;
75
+ this.getItemList(this.CurrentPage, true);
76
+ }
77
+ }));
78
+ }
79
+ this.IsFirstCall = true;
80
+ this.getItemList(this.CurrentPage, true);
81
+ }
82
+ ngAfterViewInit() {
83
+ if (this.options.OnClickFiltersControlNames != null && this.options.OnClickFiltersControlNames.length > 0) {
84
+ const OnClickFiltersControlNames = this.options.OnClickFiltersControlNames;
85
+ for (let index = 0; index < OnClickFiltersControlNames.length; index++) {
86
+ const OnClickFiltersControlName = OnClickFiltersControlNames[index];
87
+ document.getElementById(OnClickFiltersControlName).addEventListener("click", () => {
88
+ this.CurrentPage = 1;
89
+ this.IsFirstCall = true;
90
+ this.getItemList(this.CurrentPage, true);
91
+ }, false);
92
+ }
93
+ }
94
+ if (this.options.OnKeyPressFiltersControlNames != null && this.options.OnKeyPressFiltersControlNames.length > 0) {
95
+ const OnKeyPressFiltersControlNames = this.options.OnKeyPressFiltersControlNames;
96
+ for (let index = 0; index < OnKeyPressFiltersControlNames.length; index++) {
97
+ const OnKeyPressFiltersControlName = OnKeyPressFiltersControlNames[index];
98
+ let element = this.group.get(OnKeyPressFiltersControlName).nativeElement;
99
+ element.addEventListener("keypress", (e) => {
100
+ if (e.key == "Enter") {
101
+ this.CurrentPage = 1;
102
+ this.IsFirstCall = true;
103
+ this.getItemList(this.CurrentPage, true);
104
+ }
105
+ }, false);
106
+ }
107
+ }
108
+ //Add click event on Reset Filter button
109
+ if (this.options.ResetFilterButtonName != null) {
110
+ const button = document.getElementsByName(this.options.ResetFilterButtonName)[0];
111
+ if (button != undefined) {
112
+ let element = button;
113
+ element.addEventListener("click", (e) => {
114
+ this.clearFilters();
115
+ }, false);
116
+ }
117
+ }
118
+ if (this.options.TypeaheadSearchControlNames != null && this.options.TypeaheadSearchControlNames.length > 0) {
119
+ const TypeaheadSearchControlNames = this.options.TypeaheadSearchControlNames;
120
+ for (let index = 0; index < TypeaheadSearchControlNames.length; index++) {
121
+ const TypeaheadSearchControlName = TypeaheadSearchControlNames[index];
122
+ document.getElementById(TypeaheadSearchControlName).addEventListener("keypress", (e) => {
123
+ if (e.key == "Enter") {
124
+ this.CurrentPage = 1;
125
+ this.IsFirstCall = true;
126
+ this.getItemList(this.CurrentPage, true);
127
+ }
128
+ }, false);
129
+ }
130
+ }
131
+ }
132
+ onDropDownChange(result) {
133
+ if (result) {
134
+ this.CurrentPage = 1;
135
+ this.IsFirstCall = true;
136
+ this.getItemList(this.CurrentPage, true);
137
+ }
138
+ }
139
+ onChangePage(Page) {
140
+ if (Page == 0)
141
+ return;
142
+ if (Page > 0) {
143
+ if (this.IsFirstCall) {
144
+ this.IsFirstCall = false;
145
+ return;
146
+ }
147
+ this.CurrentPage = Page;
148
+ this.getItemList(Page);
149
+ }
150
+ }
151
+ changePageSize(e) {
152
+ this.options.PageSize = e.target.value;
153
+ this.CurrentPage = 1;
154
+ this.IsFirstCall = true;
155
+ this.getItemList(this.CurrentPage, true);
156
+ }
157
+ onScrollDown() {
158
+ this.Sum += this.options.PageSize;
159
+ this.CurrentPage = 1;
160
+ this.IsFirstCall = true;
161
+ this.direction = 'down';
162
+ this.getItemList(this.CurrentPage, true);
163
+ }
164
+ getItemList(page, IsFilterUpdated = false) {
165
+ if (this.options.StartPagingCallback)
166
+ this.options.StartPagingCallback.call(null);
167
+ let pagingDTO = new PagingDTO();
168
+ let size = Number.parseInt(this.options.PageSize.toString());
169
+ if (this.options.IsLoadMoreControl)
170
+ pagingDTO.PageCount = this.Sum;
171
+ else
172
+ pagingDTO.PageCount = size;
173
+ pagingDTO.CurrentPageNumber = page;
174
+ pagingDTO.TotalCount = this.totalRow;
175
+ pagingDTO.IsFilterUpdated = IsFilterUpdated;
176
+ let filters = {};
177
+ filters = this.getFiltersValue();
178
+ //Set Filters object that sent to action URL
179
+ let filtersDTO = {
180
+ PagingDTO: pagingDTO,
181
+ Filters: filters
182
+ };
183
+ let requestOptions = new RequestOptionsModel();
184
+ requestOptions.disableBlockUI = this.options.DisableBlockUI;
185
+ this.requestHandlerService.post(this.options.ActionPostURL, this.options.Filters && this.options.Filters.length > 0 ? filtersDTO : pagingDTO, null, null, requestOptions)
186
+ .subscribe((responseData) => {
187
+ this.result = responseData.items; //this.castItems(responseData.items);
188
+ let castedResult = plainToClass(this.options.TypeOfResponse, this.result, { excludeExtraneousValues: true });
189
+ this.Items.emit(castedResult);
190
+ this.totalRow = responseData.totalCount;
191
+ if (IsFilterUpdated) {
192
+ this.items = [];
193
+ this.Pages = Math.ceil((this.totalRow / this.options.PageSize));
194
+ this.items = Array(this.totalRow);
195
+ this.setText(this.Pages, this.totalRow);
196
+ }
197
+ }, (error) => {
198
+ if (error.status == 401)
199
+ this.router.navigate(["/Admin/account/login"]);
200
+ });
201
+ }
202
+ castItems(objectArr) {
203
+ let originalArray = [];
204
+ for (let index = 0; index < objectArr.length; index++) {
205
+ const element = objectArr[index];
206
+ let key, keys = Object.keys(element);
207
+ let n = keys.length;
208
+ let newObject = {};
209
+ while (n--) {
210
+ key = keys[n];
211
+ let Okey = key;
212
+ newObject[key.charAt(0).toUpperCase() + Okey.slice(1)] = element[key];
213
+ }
214
+ let finalObject = newObject;
215
+ originalArray.push(finalObject);
216
+ }
217
+ return originalArray;
218
+ }
219
+ setText(pagesNumber, itemsNumber) {
220
+ if (this.utilityService.isCurrentLanguageArabic()) {
221
+ //Set pages text
222
+ if (pagesNumber < 3 || pagesNumber > 10)
223
+ this.pagesText = this.utilityService.getResourceValue("Page");
224
+ else
225
+ this.pagesText = this.utilityService.getResourceValue("Pages");
226
+ //Set items text
227
+ if (itemsNumber < 3 || itemsNumber > 10)
228
+ this.itemsText = this.utilityService.getResourceValue("Item");
229
+ else
230
+ this.itemsText = this.utilityService.getResourceValue("Items");
231
+ }
232
+ else {
233
+ //Set pages text
234
+ if (pagesNumber > 1)
235
+ this.pagesText = this.utilityService.getResourceValue("Pages");
236
+ else
237
+ this.pagesText = this.utilityService.getResourceValue("Page");
238
+ //Set items text
239
+ if (itemsNumber > 1)
240
+ this.itemsText = this.utilityService.getResourceValue("Items");
241
+ else
242
+ this.itemsText = this.utilityService.getResourceValue("Item");
243
+ }
244
+ }
245
+ clearFilters() {
246
+ if (this.options.Filters != null && this.options.Filters != []) {
247
+ for (let index = 0; index < this.options.Filters.length; index++) {
248
+ if (this.options.Filters[index].FormControlName != null && this.options.Filters[index].FormControlName != "") {
249
+ const FormControlName = this.options.Filters[index].FormControlName;
250
+ this.group.controls[FormControlName].setValue(null);
251
+ }
252
+ }
253
+ this.ReinitializePaging();
254
+ }
255
+ }
256
+ getFiltersValue() {
257
+ let filters = {};
258
+ if (this.options.Filters != null && this.options.Filters != []) {
259
+ for (let index = 0; index < this.options.Filters.length; index++) {
260
+ if (this.options.Filters[index].FormControlName != null && this.options.Filters[index].FormControlName != "") {
261
+ const FormControlName = this.options.Filters[index].FormControlName;
262
+ let ControlValue = this.group.controls[FormControlName].value;
263
+ if (ControlValue != undefined && ControlValue != null && ControlValue != "") {
264
+ if (this.options.Filters[index].FilterType == FilterType.DatePicker) {
265
+ //if (Array.isArray(ControlValue)) {
266
+ // for (let element = 0; element < ControlValue.length; element++) {
267
+ // const value = ControlValue[element];
268
+ // filters[this.options.Filters[index].ActionParameterName] = value;
269
+ // }
270
+ //}
271
+ //else {
272
+ filters[this.options.Filters[index].ActionParameterName] = ControlValue;
273
+ //}
274
+ }
275
+ else {
276
+ if (this.options.Filters[index].FilterType == FilterType.AutocompleteTextBox)
277
+ ControlValue = ControlValue;
278
+ if (this.options.Filters[index].FilterType == FilterType.TagInput)
279
+ ControlValue = ControlValue;
280
+ filters[this.options.Filters[index].ActionParameterName] = ControlValue;
281
+ }
282
+ }
283
+ else {
284
+ filters[this.options.Filters[index].ActionParameterName] = null;
285
+ }
286
+ }
287
+ else {
288
+ const ElementjQuerySelector = this.options.Filters[index].jQuerySelector;
289
+ let ElementValue = document.querySelector(ElementjQuerySelector).value;
290
+ if (ElementValue != undefined && ElementValue != null)
291
+ filters[this.options.Filters[index].ActionParameterName] = ElementValue;
292
+ else
293
+ filters[this.options.Filters[index].ActionParameterName] = null;
294
+ }
295
+ }
296
+ }
297
+ return filters;
298
+ }
299
+ }
300
+ PagingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: PagingComponent, deps: [{ token: i1.UtilityService }, { token: i2.HttpClient }, { token: i3.Router }, { token: i4.OnPagingFiltersChangeService }, { token: i1.RequestHandlerService }], target: i0.ɵɵFactoryTarget.Component });
301
+ PagingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: PagingComponent, selector: "BBSF-Paging", inputs: { options: "options", group: "group" }, outputs: { Items: "Items" }, 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]=\"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> {{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\" (scrolled)=\"options.IsInfiniteScroll==true?onScrollDown():null\"\r\n [scrollWindow]=\"options.ScrollWindow\" [infiniteScrollContainer]=\"options.InfiniteScrollContainer\">\r\n </div>\r\n <button class=\"btn btn-sm btn-primary\" (click)=\"onScrollDown()\" *ngIf=\"!(result.length==totalRow)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n </div>\r\n</div>\r\n\r\n\r\n", components: [{ type: i5.JwPaginationComponent, selector: "jw-pagination", inputs: ["items", "initialPage", "pageSize", "maxPages", "ShowFirstAndLast"], outputs: ["changePage"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i7.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i8.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] });
302
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: PagingComponent, decorators: [{
303
+ type: Component,
304
+ 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]=\"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> {{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\" (scrolled)=\"options.IsInfiniteScroll==true?onScrollDown():null\"\r\n [scrollWindow]=\"options.ScrollWindow\" [infiniteScrollContainer]=\"options.InfiniteScrollContainer\">\r\n </div>\r\n <button class=\"btn btn-sm btn-primary\" (click)=\"onScrollDown()\" *ngIf=\"!(result.length==totalRow)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n </div>\r\n</div>\r\n\r\n\r\n" }]
305
+ }], ctorParameters: function () { return [{ type: i1.UtilityService }, { type: i2.HttpClient }, { type: i3.Router }, { type: i4.OnPagingFiltersChangeService }, { type: i1.RequestHandlerService }]; }, propDecorators: { Items: [{
306
+ type: Output
307
+ }], options: [{
308
+ type: Input
309
+ }], group: [{
310
+ type: Input
311
+ }] } });
312
+ //# 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":"AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,YAAY,EAAE,KAAK,EAAwC,MAAM,eAAe,CAAC;AAGrH,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAG1D,OAAO,EAAuB,YAAY,EAAE,MAAM,MAAM,CAAC;AAGzD,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAyB,mBAAmB,EAAkB,MAAM,0BAA0B,CAAC;AACtG,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;;AAGjD,qDAAqD;AAKrD,MAAM,OAAO,eAAe;IA2B1B,YAAmB,cAA8B,EAAU,IAAgB,EAAU,MAAc,EAAU,eAA6C,EAAU,qBAA4C;QAA7L,mBAAc,GAAd,cAAc,CAAgB;QAAU,SAAI,GAAJ,IAAI,CAAY;QAAU,WAAM,GAAN,MAAM,CAAQ;QAAU,oBAAe,GAAf,eAAe,CAA8B;QAAU,0BAAqB,GAArB,qBAAqB,CAAuB;QAzBhN,UAAK,GAAG,EAAE,CAAC;QAEX,WAAM,GAAQ,EAAE,CAAC;QACjB,gBAAW,GAAQ,IAAI,CAAC;QACxB,aAAQ,GAAQ,CAAC,CAAC;QAClB,aAAQ,GAAQ,EAAE,CAAA;QAClB,UAAK,GAAQ,CAAC,CAAA;QAGd,gBAAW,GAAQ,CAAC,CAAA;QACpB,uBAAkB,GAAG,IAAI,CAAC;QAC1B,qBAAgB,GAAG,IAAI,CAAC;QACxB,uCAAkC,GAAG,IAAI,CAAA;QACzC,QAAG,GAAG,CAAC,CAAC;QACR,aAAQ,GAAG,GAAG,CAAC;QACf,mBAAc,GAAG,CAAC,CAAC;QACnB,qBAAgB,GAAG,CAAC,CAAC;QACrB,cAAS,GAAG,EAAE,CAAC;QAEf,gBAAW,GAAY,IAAI,CAAC;QAClB,UAAK,GAAsB,IAAI,YAAY,EAAO,CAAC;QAG7D,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAmLnC,uBAAkB,GAAG,GAAG,EAAE;YACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAA;QAED,iBAAY,GAAG,GAAG,EAAE;YAClB,wBAAwB;YACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrC,CAAC,CAAA;IAxLD,CAAC;IACD,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAA;IAClC,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,OAAO,CAAC,iBAAiB;YAChC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QAEnC,IAAI,IAAI,CAAC,OAAO,CAAC,2BAA2B,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3G,MAAM,2BAA2B,GAAG,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC;YAC7E,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBAClD,IAAI,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,KAAK,CAAC,CAAA;gBACrF,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;oBACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;oBACxB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;oBACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;iBAC1C;YACH,CAAC,CAAC,CAAC,CAAA;SACN;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,uCAAuC,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,uCAAuC,CAAC,MAAM,GAAG,CAAC,EAAE;YACnI,MAAM,uCAAuC,GAAG,IAAI,CAAC,OAAO,CAAC,uCAAuC,CAAC;YACrG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACzE,IAAI,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,uCAAuC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,KAAK,CAAC,CAAA;gBACjG,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;oBACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;oBACxB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;oBACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;iBAC1C;YACH,CAAC,CAAC,CAAC,CAAA;SACJ;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IACD,eAAe;QAEb,IAAI,IAAI,CAAC,OAAO,CAAC,0BAA0B,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,0BAA0B,CAAC,MAAM,GAAG,CAAC,EAAE;YACzG,MAAM,0BAA0B,GAAG,IAAI,CAAC,OAAO,CAAC,0BAA0B,CAAC;YAC3E,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,0BAA0B,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACtE,MAAM,yBAAyB,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;gBACpE,QAAQ,CAAC,cAAc,CAAC,yBAAyB,CAAC,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBAChF,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;oBACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;oBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;gBAC3C,CAAC,EAAE,KAAK,CAAC,CAAC;aACX;SACF;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,6BAA6B,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,6BAA6B,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/G,MAAM,6BAA6B,GAAG,IAAI,CAAC,OAAO,CAAC,6BAA6B,CAAC;YACjF,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,6BAA6B,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACzE,MAAM,4BAA4B,GAAG,6BAA6B,CAAC,KAAK,CAAC,CAAC;gBAC1E,IAAI,OAAO,GAAS,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,4BAA4B,CAAE,CAAC,aAA4B,CAAC;gBAC/F,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC,EAAE,EAAE;oBACzC,IAAI,CAAC,CAAC,GAAG,IAAI,OAAO,EAAE;wBACpB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;wBACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;wBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;qBAC1C;gBACH,CAAC,EAAE,KAAK,CAAC,CAAC;aACX;SACF;QACD,wCAAwC;QACxC,IAAI,IAAI,CAAC,OAAO,CAAC,qBAAqB,IAAI,IAAI,EAAE;YAC9C,MAAM,MAAM,GAAG,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC;YACjF,IAAI,MAAM,IAAI,SAAS,EAAE;gBACvB,IAAI,OAAO,GAAG,MAAqB,CAAC;gBACpC,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;oBACtC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,CAAC,EAAE,KAAK,CAAC,CAAC;aACX;SACF;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,2BAA2B,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3G,MAAM,2BAA2B,GAAG,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC;YAC7E,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,2BAA2B,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACvE,MAAM,0BAA0B,GAAG,2BAA2B,CAAC,KAAK,CAAC,CAAC;gBACtE,QAAQ,CAAC,cAAc,CAAC,0BAA0B,CAAC,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC,EAAE,EAAE;oBACrF,IAAI,CAAC,CAAC,GAAG,IAAI,OAAO,EAAE;wBACpB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;wBACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;wBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;qBAC1C;gBACH,CAAC,EAAE,KAAK,CAAC,CAAC;aAEX;SACF;IAEH,CAAC;IAED,gBAAgB,CAAC,MAAM;QACrB,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;YACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;SAC1C;IACH,CAAC;IAED,YAAY,CAAC,IAAI;QACf,IAAI,IAAI,IAAI,CAAC;YACX,OAAO;QACT,IAAI,IAAI,GAAG,CAAC,EAAE;YACZ,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,OAAO;aACR;YACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SACxB;IACH,CAAC;IACD,cAAc,CAAC,CAAC;QACd,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IAKD,YAAY;QACV,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAA;QACjC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAA;QACpB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IAID,WAAW,CAAC,IAAI,EAAE,eAAe,GAAG,KAAK;QACvC,IAAI,IAAI,CAAC,OAAO,CAAC,mBAAmB;YAClC,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9C,IAAI,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;QAChC,IAAI,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC7D,IAAI,IAAI,CAAC,OAAO,CAAC,iBAAiB;YAChC,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC;;YAE/B,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC;QAE7B,SAAS,CAAC,iBAAiB,GAAG,IAAI,CAAC;QACnC,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC;QACrC,SAAS,CAAC,eAAe,GAAG,eAAe,CAAC;QAC5C,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAEjC,4CAA4C;QAC5C,IAAI,UAAU,GAAkB;YAC9B,SAAS,EAAE,SAAS;YACpB,OAAO,EAAE,OAAO;SACjB,CAAC;QAEF,IAAI,cAAc,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC/C,cAAc,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC;QAC5D,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,cAAc,CAAC;aACtK,SAAS,CAAC,CAAC,YAAiB,EAAE,EAAE;YAC/B,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,KAAK,CAAA,CAAC,qCAAqC;YACtE,IAAI,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC,CAAA;YAC5G,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC9B,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,UAAU,CAAC;YAExC,IAAI,eAAe,EAAE;gBACnB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;gBAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAChE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAElC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;aAEzC;QACH,CAAC,EAAE,CAAC,KAAwB,EAAE,EAAE;YAC9B,IAAI,KAAK,CAAC,MAAM,IAAI,GAAG;gBACrB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAA;QAClD,CAAC,CAAC,CAAC;IACP,CAAC;IAYD,SAAS,CAAC,SAAgB;QACxB,IAAI,aAAa,GAAQ,EAAE,CAAA;QAC3B,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,SAAS,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACrD,MAAM,OAAO,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;YACjC,IAAI,GAAG,EAAE,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACrC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;YACpB,IAAI,SAAS,GAAG,EAAE,CAAA;YAClB,OAAO,CAAC,EAAE,EAAE;gBACV,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACd,IAAI,IAAI,GAAG,GAAG,CAAA;gBACd,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;aACvE;YACD,IAAI,WAAW,GAAG,SAAc,CAAA;YAChC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SAChC;QAED,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,OAAO,CAAC,WAAmB,EAAE,WAAmB;QAC9C,IAAI,IAAI,CAAC,cAAc,CAAC,uBAAuB,EAAE,EAAE;YACjD,gBAAgB;YAChB,IAAI,WAAW,GAAG,CAAC,IAAI,WAAW,GAAG,EAAE;gBACrC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;;gBAE9D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YACjE,gBAAgB;YAChB,IAAI,WAAW,GAAG,CAAC,IAAI,WAAW,GAAG,EAAE;gBACrC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;;gBAE9D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;SAClE;aACI;YACH,gBAAgB;YAChB,IAAI,WAAW,GAAG,CAAC;gBACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;;gBAE/D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAChE,gBAAgB;YAChB,IAAI,WAAW,GAAG,CAAC;gBACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;;gBAE/D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;SACjE;IACH,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;YAC9D,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBAChE,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,IAAI,EAAE,EAAE;oBAC5G,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC;oBACpE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;iBACrD;aACF;YACD,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,eAAe;QACb,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;YAC9D,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBAChE,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,IAAI,EAAE,EAAE;oBAC5G,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC;oBACpE,IAAI,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC;oBAC9D,IAAI,YAAY,IAAI,SAAS,IAAI,YAAY,IAAI,IAAI,IAAI,YAAY,IAAI,EAAE,EAAE;wBAC3E,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,IAAI,UAAU,CAAC,UAAU,EAAE;4BACnE,oCAAoC;4BACpC,qEAAqE;4BACrE,0CAA0C;4BAC1C,uEAAuE;4BACvE,KAAK;4BACL,GAAG;4BACH,QAAQ;4BACR,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,mBAAmB,CAAC,GAAG,YAAY,CAAC;4BACxE,GAAG;yBACJ;6BACI;4BACH,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,IAAI,UAAU,CAAC,mBAAmB;gCAC1E,YAAY,GAAG,YAAY,CAAC;4BAC9B,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,IAAI,UAAU,CAAC,QAAQ;gCAC/D,YAAY,GAAG,YAAY,CAAC;4BAE9B,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,mBAAmB,CAAC,GAAG,YAAY,CAAC;yBACzE;qBACF;yBACI;wBACH,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC;qBACjE;iBACF;qBACI;oBACH,MAAM,qBAAqB,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC;oBACzE,IAAI,YAAY,GAAI,QAAQ,CAAC,aAAa,CAAC,qBAAqB,CAAsB,CAAC,KAAK,CAAC;oBAC7F,IAAI,YAAY,IAAI,SAAS,IAAI,YAAY,IAAI,IAAI;wBACnD,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,mBAAmB,CAAC,GAAG,YAAY,CAAC;;wBAExE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC;iBACnE;aACF;SACF;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;;6GA3TU,eAAe;iGAAf,eAAe,gICnB5B,y2DAkCA;4FDfa,eAAe;kBAJ3B,SAAS;+BACE,aAAa;kOAyBb,KAAK;sBAAd,MAAM;gBACE,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK","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 { RequestOptions, ResponseContentType, Headers } from '@angular/http';\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})\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  @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 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    let filters = {};\r\n    filters = this.getFiltersValue();\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.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 && this.options.Filters != []) {\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 && this.options.Filters != []) {\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> {{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\" (scrolled)=\"options.IsInfiniteScroll==true?onScrollDown():null\"\r\n         [scrollWindow]=\"options.ScrollWindow\" [infiniteScrollContainer]=\"options.InfiniteScrollContainer\">\r\n    </div>\r\n    <button class=\"btn btn-sm btn-primary\" (click)=\"onScrollDown()\" *ngIf=\"!(result.length==totalRow)\">{{utilityService.getResourceValue(\"LoadMore\")}}</button>\r\n  </div>\r\n</div>\r\n\r\n\r\n"]}