namirasoft-site-react 1.3.350 → 1.3.352

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 (353) hide show
  1. package/.dockerignore +86 -86
  2. package/Dockerfile +18 -18
  3. package/config-overrides.js +70 -70
  4. package/dist/assets/images/404 image.svg +9 -9
  5. package/dist/assets/images/404 image_mobile.svg +9 -9
  6. package/dist/assets/images/arrow.svg +3 -3
  7. package/dist/assets/images/danger.svg +3 -3
  8. package/dist/assets/images/exit.svg +3 -3
  9. package/dist/assets/images/icon-input-copy.svg +3 -3
  10. package/dist/assets/images/icon-input-date.svg +9 -9
  11. package/dist/assets/images/icon-input-duration.svg +9 -9
  12. package/dist/assets/images/icon-input-email.svg +9 -9
  13. package/dist/assets/images/icon-input-float.svg +9 -9
  14. package/dist/assets/images/icon-input-integer.svg +9 -9
  15. package/dist/assets/images/icon-input-ip.svg +9 -9
  16. package/dist/assets/images/icon-input-phone.svg +9 -9
  17. package/dist/assets/images/icon-input-price.svg +9 -9
  18. package/dist/assets/images/icon-input-search.svg +3 -3
  19. package/dist/assets/images/icon-input-string.svg +9 -9
  20. package/dist/assets/images/icon-input-text.svg +9 -9
  21. package/dist/assets/images/icon-input-time.svg +9 -9
  22. package/dist/assets/images/icon-select-box.svg +3 -3
  23. package/dist/assets/images/logo.svg +9 -9
  24. package/dist/assets/images/menu.svg +3 -3
  25. package/dist/assets/images/namira.svg +9 -9
  26. package/dist/assets/images/rectangle.svg +3 -3
  27. package/dist/components/NSActionMenu.js +2 -2
  28. package/dist/components/NSActionMenu.module.css +75 -75
  29. package/dist/components/NSAssistantButton.module.css +133 -133
  30. package/dist/components/NSBarAction.module.css +87 -87
  31. package/dist/components/NSBarHeroBanner.module.css +42 -42
  32. package/dist/components/NSBarNotification.module.css +34 -34
  33. package/dist/components/NSBarTitle.module.css +9 -9
  34. package/dist/components/NSBox.module.css +123 -123
  35. package/dist/components/NSBoxBoolean.module.css +53 -53
  36. package/dist/components/NSBoxCombo.module.css +17 -16
  37. package/dist/components/NSBoxDate.module.css +39 -39
  38. package/dist/components/NSBoxEntity.module.css +25 -25
  39. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  40. package/dist/components/NSBoxLabel.module.css +12 -12
  41. package/dist/components/NSBoxOTP.module.css +10 -10
  42. package/dist/components/NSBoxTextArea.module.css +76 -76
  43. package/dist/components/NSButton.module.css +27 -27
  44. package/dist/components/NSButtonBlue.module.css +4 -4
  45. package/dist/components/NSButtonGreen.module.css +4 -4
  46. package/dist/components/NSButtonRed.module.css +4 -4
  47. package/dist/components/NSCard.module.css +108 -108
  48. package/dist/components/NSCopyToClipboard.module.css +39 -39
  49. package/dist/components/NSElectronicCard.module.css +60 -60
  50. package/dist/components/NSEntityBar.module.css +77 -77
  51. package/dist/components/NSEntityCardBackground.module.css +27 -27
  52. package/dist/components/NSFilterBox.module.css +47 -47
  53. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  54. package/dist/components/NSFilterItem.module.css +23 -23
  55. package/dist/components/NSFooter.module.css +123 -123
  56. package/dist/components/NSGroupedList.module.css +72 -72
  57. package/dist/components/NSHeader.module.css +271 -271
  58. package/dist/components/NSLayout.js +13 -1
  59. package/dist/components/NSLayout.js.map +1 -1
  60. package/dist/components/NSLayout.module.css +13 -13
  61. package/dist/components/NSLink.module.css +36 -36
  62. package/dist/components/NSLoading.module.css +29 -29
  63. package/dist/components/NSModal.js +2 -2
  64. package/dist/components/NSModal.module.css +70 -70
  65. package/dist/components/NSNoData.module.css +8 -8
  66. package/dist/components/NSPageSelectionModal.module.css +102 -102
  67. package/dist/components/NSPagination.module.css +101 -101
  68. package/dist/components/NSPanel.module.css +46 -46
  69. package/dist/components/NSRadioButton.module.css +61 -61
  70. package/dist/components/NSSection.module.css +10 -10
  71. package/dist/components/NSSectionBars.module.css +10 -10
  72. package/dist/components/NSSectionCards.module.css +38 -38
  73. package/dist/components/NSTabPage.module.css +57 -57
  74. package/dist/components/NSTable.module.css +253 -253
  75. package/dist/components/NSTag.module.css +44 -44
  76. package/dist/components/NSTitle.module.css +15 -15
  77. package/dist/components/NSVerification.module.css +22 -22
  78. package/dist/pages/NSNotFoundPage.module.css +18 -18
  79. package/package.json +67 -67
  80. package/public/index.html +38 -38
  81. package/src/App.css +16 -16
  82. package/src/App.tsx +166 -166
  83. package/src/CopyToClipboard.ts +6 -6
  84. package/src/Validator.ts +110 -110
  85. package/src/assets/images/404 image.svg +9 -9
  86. package/src/assets/images/404 image_mobile.svg +9 -9
  87. package/src/assets/images/arrow.svg +3 -3
  88. package/src/assets/images/danger.svg +3 -3
  89. package/src/assets/images/exit.svg +3 -3
  90. package/src/assets/images/icon-input-copy.svg +3 -3
  91. package/src/assets/images/icon-input-date.svg +9 -9
  92. package/src/assets/images/icon-input-duration.svg +9 -9
  93. package/src/assets/images/icon-input-email.svg +9 -9
  94. package/src/assets/images/icon-input-float.svg +9 -9
  95. package/src/assets/images/icon-input-integer.svg +9 -9
  96. package/src/assets/images/icon-input-ip.svg +9 -9
  97. package/src/assets/images/icon-input-phone.svg +9 -9
  98. package/src/assets/images/icon-input-price.svg +9 -9
  99. package/src/assets/images/icon-input-search.svg +3 -3
  100. package/src/assets/images/icon-input-string.svg +9 -9
  101. package/src/assets/images/icon-input-text.svg +9 -9
  102. package/src/assets/images/icon-input-time.svg +9 -9
  103. package/src/assets/images/icon-select-box.svg +3 -3
  104. package/src/assets/images/logo.svg +9 -9
  105. package/src/assets/images/menu.svg +3 -3
  106. package/src/assets/images/namira.svg +9 -9
  107. package/src/assets/images/rectangle.svg +3 -3
  108. package/src/components/NSActionMenu.module.css +75 -75
  109. package/src/components/NSActionMenu.tsx +88 -88
  110. package/src/components/NSAssistantButton.module.css +133 -133
  111. package/src/components/NSAssistantButton.tsx +74 -74
  112. package/src/components/NSBarAction.module.css +87 -87
  113. package/src/components/NSBarAction.tsx +86 -86
  114. package/src/components/NSBarHeroBanner.module.css +42 -42
  115. package/src/components/NSBarHeroBanner.tsx +61 -61
  116. package/src/components/NSBarNotification.module.css +34 -34
  117. package/src/components/NSBarNotification.tsx +63 -63
  118. package/src/components/NSBarTitle.module.css +9 -9
  119. package/src/components/NSBarTitle.tsx +28 -28
  120. package/src/components/NSBox.module.css +123 -123
  121. package/src/components/NSBoxBoolean.module.css +53 -53
  122. package/src/components/NSBoxBoolean.tsx +84 -84
  123. package/src/components/NSBoxCombo.module.css +17 -16
  124. package/src/components/NSBoxCombo.tsx +132 -132
  125. package/src/components/NSBoxDate.module.css +39 -39
  126. package/src/components/NSBoxDate.tsx +83 -83
  127. package/src/components/NSBoxDateTime.tsx +83 -83
  128. package/src/components/NSBoxDouble.tsx +88 -88
  129. package/src/components/NSBoxDuration.tsx +88 -88
  130. package/src/components/NSBoxEmail.tsx +104 -104
  131. package/src/components/NSBoxEntity.module.css +25 -25
  132. package/src/components/NSBoxEntity.tsx +178 -178
  133. package/src/components/NSBoxEnum.tsx +56 -56
  134. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  135. package/src/components/NSBoxErrorNotifier.tsx +33 -33
  136. package/src/components/NSBoxIPV4.tsx +93 -93
  137. package/src/components/NSBoxIPV6.tsx +90 -90
  138. package/src/components/NSBoxInteger.tsx +86 -86
  139. package/src/components/NSBoxLabel.module.css +12 -12
  140. package/src/components/NSBoxLabel.tsx +29 -29
  141. package/src/components/NSBoxOTP.module.css +10 -10
  142. package/src/components/NSBoxOTP.tsx +65 -65
  143. package/src/components/NSBoxPassword.tsx +86 -86
  144. package/src/components/NSBoxPhone.tsx +88 -88
  145. package/src/components/NSBoxPrice.tsx +88 -88
  146. package/src/components/NSBoxSearch.tsx +103 -103
  147. package/src/components/NSBoxString.tsx +103 -103
  148. package/src/components/NSBoxTextArea.module.css +76 -76
  149. package/src/components/NSBoxTextArea.tsx +106 -106
  150. package/src/components/NSBoxTime.tsx +88 -88
  151. package/src/components/NSButton.module.css +27 -27
  152. package/src/components/NSButton.tsx +23 -23
  153. package/src/components/NSButtonBlue.module.css +4 -4
  154. package/src/components/NSButtonBlue.tsx +12 -12
  155. package/src/components/NSButtonGreen.module.css +4 -4
  156. package/src/components/NSButtonGreen.tsx +11 -11
  157. package/src/components/NSButtonRed.module.css +4 -4
  158. package/src/components/NSButtonRed.tsx +11 -11
  159. package/src/components/NSCard.module.css +108 -108
  160. package/src/components/NSCard.tsx +70 -70
  161. package/src/components/NSCopyToClipboard.module.css +39 -39
  162. package/src/components/NSCopyToClipboard.tsx +35 -35
  163. package/src/components/NSElectronicCard.module.css +60 -60
  164. package/src/components/NSElectronicCard.tsx +47 -47
  165. package/src/components/NSEntityBar.module.css +77 -77
  166. package/src/components/NSEntityBar.tsx +27 -27
  167. package/src/components/NSEntityCardBackground.module.css +27 -27
  168. package/src/components/NSEntityCardBackground.tsx +34 -34
  169. package/src/components/NSFilterBox.module.css +47 -47
  170. package/src/components/NSFilterBox.tsx +373 -373
  171. package/src/components/NSFilterBoxDialog.module.css +36 -36
  172. package/src/components/NSFilterBoxDialog.tsx +74 -74
  173. package/src/components/NSFilterItem.module.css +23 -23
  174. package/src/components/NSFilterItem.tsx +72 -72
  175. package/src/components/NSFooter.module.css +123 -123
  176. package/src/components/NSFooter.tsx +196 -196
  177. package/src/components/NSGroupedList.module.css +72 -72
  178. package/src/components/NSGroupedList.tsx +107 -107
  179. package/src/components/NSHeader.module.css +271 -271
  180. package/src/components/NSHeader.tsx +235 -235
  181. package/src/components/NSLayout.module.css +13 -13
  182. package/src/components/NSLayout.tsx +105 -82
  183. package/src/components/NSLine.tsx +18 -18
  184. package/src/components/NSLink.module.css +36 -36
  185. package/src/components/NSLink.tsx +25 -25
  186. package/src/components/NSLinkBlue.tsx +20 -20
  187. package/src/components/NSLinkGreen.tsx +5 -5
  188. package/src/components/NSLinkRed.tsx +5 -5
  189. package/src/components/NSLoading.module.css +29 -29
  190. package/src/components/NSLoading.tsx +19 -19
  191. package/src/components/NSModal.module.css +70 -70
  192. package/src/components/NSModal.tsx +49 -49
  193. package/src/components/NSNoData.module.css +8 -8
  194. package/src/components/NSNoData.tsx +24 -24
  195. package/src/components/NSPageSelectionModal.module.css +102 -102
  196. package/src/components/NSPageSelectionModal.tsx +228 -228
  197. package/src/components/NSPagination.module.css +101 -101
  198. package/src/components/NSPagination.tsx +190 -190
  199. package/src/components/NSPanel.module.css +46 -46
  200. package/src/components/NSPanel.tsx +19 -19
  201. package/src/components/NSRadioButton.module.css +61 -61
  202. package/src/components/NSRadioButton.tsx +100 -100
  203. package/src/components/NSSection.module.css +10 -10
  204. package/src/components/NSSection.tsx +23 -23
  205. package/src/components/NSSectionBars.module.css +10 -10
  206. package/src/components/NSSectionBars.tsx +25 -25
  207. package/src/components/NSSectionCards.module.css +38 -38
  208. package/src/components/NSSectionCards.tsx +51 -51
  209. package/src/components/NSSectionTitle.tsx +21 -21
  210. package/src/components/NSSpace.tsx +28 -28
  211. package/src/components/NSTabPage.module.css +57 -57
  212. package/src/components/NSTabPage.tsx +53 -53
  213. package/src/components/NSTable.module.css +253 -253
  214. package/src/components/NSTable.tsx +361 -361
  215. package/src/components/NSTag.module.css +44 -44
  216. package/src/components/NSTag.tsx +49 -49
  217. package/src/components/NSTitle.module.css +15 -15
  218. package/src/components/NSTitle.tsx +19 -19
  219. package/src/components/NSVerification.module.css +22 -22
  220. package/src/components/NSVerification.tsx +41 -41
  221. package/src/index.tsx +7 -7
  222. package/src/main.ts +78 -78
  223. package/src/pages/NSNotFoundPage.module.css +18 -18
  224. package/src/pages/NSNotFoundPage.tsx +11 -11
  225. package/src/props/IBaseComponentProps.ts +8 -8
  226. package/src/props/IHeaderIconProps.ts +9 -9
  227. package/src/props/IHeaderProps.ts +6 -6
  228. package/src/props/IImageProps.ts +4 -4
  229. package/src/props/ILinkProps.ts +5 -5
  230. package/src/props/IValidationNumberProps.ts +4 -4
  231. package/src/props/IValidationProps.ts +7 -7
  232. package/src/props/IValidationRegexProps.ts +4 -4
  233. package/src/props/IValidationStringProps.ts +4 -4
  234. package/src/routing/INSRouterMaker.ts +6 -6
  235. package/src/routing/INSRouterProps.ts +5 -5
  236. package/src/routing/INSRouterState.ts +5 -5
  237. package/src/routing/NSRouterMaker.tsx +33 -33
  238. package/src/routing/Notifier.ts +79 -79
  239. package/tsconfig.json +43 -43
  240. package/dist/App.css +0 -17
  241. package/dist/assets/images/1.png +0 -0
  242. package/dist/assets/images/2.png +0 -0
  243. package/dist/assets/images/3.png +0 -0
  244. package/dist/assets/images/4.png +0 -0
  245. package/dist/assets/images/5.jpg +0 -0
  246. package/dist/assets/images/icon-export.svg +0 -3
  247. package/dist/assets/images/icon-input-id.svg +0 -9
  248. package/dist/assets/images/icon-refresh.svg +0 -3
  249. package/dist/components/NSAccess.d.ts +0 -2
  250. package/dist/components/NSAccess.js +0 -8
  251. package/dist/components/NSAccess.js.map +0 -1
  252. package/dist/components/NSAccess.module.css +0 -39
  253. package/dist/components/NSBoxText.d.ts +0 -25
  254. package/dist/components/NSBoxText.js +0 -56
  255. package/dist/components/NSBoxText.js.map +0 -1
  256. package/dist/components/NSInput.module.css +0 -74
  257. package/dist/components/NSInputDate.d.ts +0 -21
  258. package/dist/components/NSInputDate.js +0 -41
  259. package/dist/components/NSInputDate.js.map +0 -1
  260. package/dist/components/NSInputDate.module.css +0 -42
  261. package/dist/components/NSInputDuration.d.ts +0 -23
  262. package/dist/components/NSInputDuration.js +0 -42
  263. package/dist/components/NSInputDuration.js.map +0 -1
  264. package/dist/components/NSInputEmail.d.ts +0 -22
  265. package/dist/components/NSInputEmail.js +0 -43
  266. package/dist/components/NSInputEmail.js.map +0 -1
  267. package/dist/components/NSInputErrorNotifier.d.ts +0 -5
  268. package/dist/components/NSInputErrorNotifier.js +0 -7
  269. package/dist/components/NSInputErrorNotifier.js.map +0 -1
  270. package/dist/components/NSInputErrorNotifier.module.css +0 -3
  271. package/dist/components/NSInputFloat.d.ts +0 -22
  272. package/dist/components/NSInputFloat.js +0 -41
  273. package/dist/components/NSInputFloat.js.map +0 -1
  274. package/dist/components/NSInputIP.d.ts +0 -22
  275. package/dist/components/NSInputIP.js +0 -43
  276. package/dist/components/NSInputIP.js.map +0 -1
  277. package/dist/components/NSInputInteger.d.ts +0 -22
  278. package/dist/components/NSInputInteger.js +0 -41
  279. package/dist/components/NSInputInteger.js.map +0 -1
  280. package/dist/components/NSInputPassword.d.ts +0 -22
  281. package/dist/components/NSInputPassword.js +0 -42
  282. package/dist/components/NSInputPassword.js.map +0 -1
  283. package/dist/components/NSInputPhone.d.ts +0 -22
  284. package/dist/components/NSInputPhone.js +0 -38
  285. package/dist/components/NSInputPhone.js.map +0 -1
  286. package/dist/components/NSInputPrice.d.ts +0 -22
  287. package/dist/components/NSInputPrice.js +0 -41
  288. package/dist/components/NSInputPrice.js.map +0 -1
  289. package/dist/components/NSInputSearch.d.ts +0 -22
  290. package/dist/components/NSInputSearch.js +0 -41
  291. package/dist/components/NSInputSearch.js.map +0 -1
  292. package/dist/components/NSInputString.d.ts +0 -22
  293. package/dist/components/NSInputString.js +0 -42
  294. package/dist/components/NSInputString.js.map +0 -1
  295. package/dist/components/NSInputText.d.ts +0 -22
  296. package/dist/components/NSInputText.js +0 -42
  297. package/dist/components/NSInputText.js.map +0 -1
  298. package/dist/components/NSInputTime.d.ts +0 -22
  299. package/dist/components/NSInputTime.js +0 -43
  300. package/dist/components/NSInputTime.js.map +0 -1
  301. package/dist/components/NSLayoutAction.d.ts +0 -5
  302. package/dist/components/NSLayoutAction.js +0 -20
  303. package/dist/components/NSLayoutAction.js.map +0 -1
  304. package/dist/components/NSLayoutAction.module.css +0 -88
  305. package/dist/components/NSLayoutHeroBanner.d.ts +0 -2
  306. package/dist/components/NSLayoutHeroBanner.js +0 -8
  307. package/dist/components/NSLayoutHeroBanner.js.map +0 -1
  308. package/dist/components/NSLayoutHeroBanner.module.css +0 -43
  309. package/dist/components/NSLayoutTitle.d.ts +0 -2
  310. package/dist/components/NSLayoutTitle.js +0 -11
  311. package/dist/components/NSLayoutTitle.js.map +0 -1
  312. package/dist/components/NSLayoutTitle.module.css +0 -10
  313. package/dist/components/NSNotification.d.ts +0 -21
  314. package/dist/components/NSNotification.js +0 -37
  315. package/dist/components/NSNotification.js.map +0 -1
  316. package/dist/components/NSNotification.module.css +0 -32
  317. package/dist/components/NSPrintModal.d.ts +0 -15
  318. package/dist/components/NSPrintModal.js +0 -35
  319. package/dist/components/NSPrintModal.js.map +0 -1
  320. package/dist/components/NSPrintModal.module.css +0 -82
  321. package/dist/components/NSSelectBox.d.ts +0 -24
  322. package/dist/components/NSSelectBox.js +0 -61
  323. package/dist/components/NSSelectBox.js.map +0 -1
  324. package/dist/components/NSSelectBox.module.css +0 -42
  325. package/dist/index.css +0 -6
  326. package/dist/pages/NSLoginPage.d.ts +0 -6
  327. package/dist/pages/NSLoginPage.js +0 -8
  328. package/dist/pages/NSLoginPage.js.map +0 -1
  329. package/dist/pages/NSLoginPage.module.css +0 -20
  330. package/dist/props/BaseComponentProps.d.ts +0 -6
  331. package/dist/props/BaseComponentProps.js +0 -2
  332. package/dist/props/BaseComponentProps.js.map +0 -10
  333. package/dist/props/INamirasoftProps.d.ts +0 -4
  334. package/dist/props/INamirasoftProps.js +0 -2
  335. package/dist/props/INamirasoftProps.js.map +0 -1
  336. package/dist/props/ImageProps.d.ts +0 -4
  337. package/dist/props/ImageProps.js +0 -2
  338. package/dist/props/ImageProps.js.map +0 -10
  339. package/dist/props/LinkProps.d.ts +0 -5
  340. package/dist/props/LinkProps.js +0 -2
  341. package/dist/props/LinkProps.js.map +0 -10
  342. package/dist/props/ValidationNumberProps.d.ts +0 -4
  343. package/dist/props/ValidationNumberProps.js +0 -2
  344. package/dist/props/ValidationNumberProps.js.map +0 -10
  345. package/dist/props/ValidationProps.d.ts +0 -6
  346. package/dist/props/ValidationProps.js +0 -2
  347. package/dist/props/ValidationProps.js.map +0 -10
  348. package/dist/props/ValidationRegexProps.d.ts +0 -4
  349. package/dist/props/ValidationRegexProps.js +0 -2
  350. package/dist/props/ValidationRegexProps.js.map +0 -1
  351. package/dist/props/ValidationStringProps.d.ts +0 -4
  352. package/dist/props/ValidationStringProps.js +0 -2
  353. package/dist/props/ValidationStringProps.js.map +0 -10
@@ -1,229 +1,229 @@
1
- import React, { Component, createRef } from 'react';
2
- import Styles from './NSPageSelectionModal.module.css';
3
- import { NSButtonBlue } from './NSButtonBlue';
4
- import { NSBoxString } from './NSBoxString';
5
- import { NSSpace } from './NSSpace';
6
- import { NSSpaceSizeType } from '../main';
7
- import { NSRadioButton } from './NSRadioButton';
8
-
9
- export interface NSPageSelectionModalProps<RowType>
10
- {
11
- current_page: number;
12
- max_page: number;
13
- onClose: () => void;
14
- getItems: (page: number, selected: boolean) => Promise<RowType[]>;
15
- onFinish: (items: RowType[]) => void;
16
- }
17
-
18
- interface NSPageSelectionModalState
19
- {
20
- selectedRadio: string;
21
- }
22
-
23
- export class NSPageSelectionModal<RowType> extends Component<NSPageSelectionModalProps<RowType>, NSPageSelectionModalState>
24
- {
25
- private toastRef: React.RefObject<HTMLDivElement> = createRef();
26
- private NSBoxBoolean_CurrentPage: React.RefObject<NSRadioButton> = createRef();
27
- private NSBoxBoolean_SelectedItems: React.RefObject<NSRadioButton> = createRef();
28
- private NSBoxBoolean_CustomPage: React.RefObject<NSRadioButton> = createRef();
29
- private NSBoxBoolean_AllPage: React.RefObject<NSRadioButton> = createRef();
30
- private NSBoxString_Pages: React.RefObject<NSBoxString> = createRef();
31
-
32
- constructor(props: NSPageSelectionModalProps<RowType>)
33
- {
34
- super(props);
35
- this.state = {
36
- selectedRadio: 'current_page'
37
- };
38
- this.onClickOutside = this.onClickOutside.bind(this);
39
- this.handleRadioChange = this.handleRadioChange.bind(this);
40
- }
41
- override componentDidMount(): void
42
- {
43
- document.addEventListener('mousedown', this.onClickOutside);
44
- }
45
- override componentWillUnmount(): void
46
- {
47
- document.removeEventListener('mousedown', this.onClickOutside);
48
- }
49
- parseCustomPage(pages_value: string): number[]
50
- {
51
- let ans: number[] = [];
52
- let pages = pages_value.split(',').map(p => p.trim()).filter(p => p);
53
- for (let i = 0; i < pages.length; i++)
54
- {
55
- const element = pages[i];
56
- if (element.includes("-"))
57
- {
58
- let ps = element.split('-').map(p => p.trim());
59
- if (ps.length == 2)
60
- {
61
- let from = parseInt(ps[0]);
62
- let to = parseInt(ps[1]);
63
- for (let p = from; p <= to; p++)
64
- ans.push(p);
65
- }
66
- else
67
- throw new Error("Parse Error for : " + element);
68
- }
69
- else
70
- {
71
- let p = parseInt(element);
72
- ans.push(p);
73
- }
74
- }
75
- ans.forEach(p =>
76
- {
77
- if (p < 1)
78
- throw new Error("Page number must be more than equal to 1");
79
- if (p > this.props.max_page)
80
- throw new Error("Page number must be less than equal to " + this.props.max_page);
81
- })
82
- return ans;
83
- }
84
- private onClickOutside(event: MouseEvent)
85
- {
86
- if (this.toastRef.current && !this.toastRef.current.contains(event.target as Node))
87
- {
88
- this.props.onClose();
89
- }
90
- }
91
- private handleRadioChange(selectedRadio: string)
92
- {
93
- this.setState({ selectedRadio });
94
- }
95
- override render()
96
- {
97
- return (
98
- <>
99
- {
100
- <>
101
- <div className={Styles.ns_print_container} ref={this.toastRef}>
102
- <div className={Styles.ns_header_print}>
103
- <img
104
- src="https://static.namirasoft.com/image/concept/close/blue.svg"
105
- alt="Close"
106
- width={24}
107
- height={24}
108
- onClick={(e) =>
109
- {
110
- e.stopPropagation();
111
- this.props.onClose();
112
- }}
113
- className={Styles.ns_close_icon}
114
- />
115
- <div className={Styles.ns_print_title}>
116
- <img
117
- src="https://static.namirasoft.com/image/concept/print/blue.svg"
118
- alt="Print"
119
- width={24}
120
- height={24}
121
- />
122
- <h2 className='m-0'>Page Selection</h2>
123
- </div>
124
- <NSSpace size={NSSpaceSizeType.SMALL} />
125
- <p className={Styles.ns_print_description}>Please select which pages you want to continue with</p>
126
- <NSSpace size={NSSpaceSizeType.SMALL} />
127
- <div className={Styles.ns_parent_checkboxs}>
128
- <NSRadioButton
129
- defaultValue={true}
130
- ref={this.NSBoxBoolean_CurrentPage}
131
- title={"Current page"}
132
- required={false}
133
- name={"PageSelection"}
134
- isSelected={this.state.selectedRadio === 'current_page'}
135
- onClick={() => this.handleRadioChange('current_page')}
136
- />
137
- <NSRadioButton
138
- ref={this.NSBoxBoolean_SelectedItems}
139
- title={"Only Selected Items"}
140
- required={false}
141
- name={"PageSelection"}
142
- isSelected={this.state.selectedRadio === 'selected_items'}
143
- onClick={() => this.handleRadioChange('selected_items')}
144
- />
145
- <NSRadioButton
146
- ref={this.NSBoxBoolean_CustomPage}
147
- title={"Custom Pages"}
148
- required={false}
149
- name={"PageSelection"}
150
- isSelected={this.state.selectedRadio === 'custom_page'}
151
- onClick={() => this.handleRadioChange('custom_page')}
152
- />
153
- <NSRadioButton
154
- ref={this.NSBoxBoolean_AllPage}
155
- title={"All Pages"}
156
- required={false}
157
- name={"PageSelection"}
158
- isSelected={this.state.selectedRadio === 'all_page'}
159
- onClick={() => this.handleRadioChange('all_page')}
160
- /> </div>
161
- <NSSpace size={NSSpaceSizeType.MICRO} />
162
- {this.state.selectedRadio === 'custom_page' && (
163
- <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
164
- getError={value =>
165
- {
166
- try
167
- {
168
- this.parseCustomPage(value);
169
- return null;
170
- } catch (error: any)
171
- {
172
- return error.message;
173
- }
174
- }} />
175
- )}
176
- <NSSpace size={NSSpaceSizeType.SMALL} />
177
- <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
178
- {
179
- try
180
- {
181
- let items: RowType[] = [];
182
- if (this.NSBoxBoolean_CurrentPage.current?.getValue())
183
- {
184
- let is = await this.props.getItems(this.props.current_page, false);
185
- items.push(...is);
186
- }
187
- else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
188
- {
189
- let is = await this.props.getItems(this.props.current_page, true);
190
- items.push(...is);
191
- }
192
- else if (this.NSBoxBoolean_CustomPage.current?.getValue())
193
- {
194
- let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
195
- let pages = this.parseCustomPage(pages_value);
196
-
197
- for (let p = 0; p < pages.length; p++)
198
- {
199
- let is = await this.props.getItems(pages[p], false);
200
- items.push(...is);
201
- }
202
- }
203
- else if (this.NSBoxBoolean_AllPage.current?.getValue())
204
- {
205
- for (let p = 1; p <= this.props.max_page; p++)
206
- {
207
- let is = await this.props.getItems(p, false);
208
- items.push(...is);
209
- }
210
- }
211
- else
212
- { }
213
- this.props.onFinish(items);
214
- } catch (error)
215
- {
216
- // todo
217
- }
218
- }} />
219
- </div>
220
- </div>
221
- <div className={Styles.ns_toast_background}></div>
222
- </>
223
- }
224
- </>
225
- );
226
- }
227
- }
228
-
1
+ import React, { Component, createRef } from 'react';
2
+ import Styles from './NSPageSelectionModal.module.css';
3
+ import { NSButtonBlue } from './NSButtonBlue';
4
+ import { NSBoxString } from './NSBoxString';
5
+ import { NSSpace } from './NSSpace';
6
+ import { NSSpaceSizeType } from '../main';
7
+ import { NSRadioButton } from './NSRadioButton';
8
+
9
+ export interface NSPageSelectionModalProps<RowType>
10
+ {
11
+ current_page: number;
12
+ max_page: number;
13
+ onClose: () => void;
14
+ getItems: (page: number, selected: boolean) => Promise<RowType[]>;
15
+ onFinish: (items: RowType[]) => void;
16
+ }
17
+
18
+ interface NSPageSelectionModalState
19
+ {
20
+ selectedRadio: string;
21
+ }
22
+
23
+ export class NSPageSelectionModal<RowType> extends Component<NSPageSelectionModalProps<RowType>, NSPageSelectionModalState>
24
+ {
25
+ private toastRef: React.RefObject<HTMLDivElement> = createRef();
26
+ private NSBoxBoolean_CurrentPage: React.RefObject<NSRadioButton> = createRef();
27
+ private NSBoxBoolean_SelectedItems: React.RefObject<NSRadioButton> = createRef();
28
+ private NSBoxBoolean_CustomPage: React.RefObject<NSRadioButton> = createRef();
29
+ private NSBoxBoolean_AllPage: React.RefObject<NSRadioButton> = createRef();
30
+ private NSBoxString_Pages: React.RefObject<NSBoxString> = createRef();
31
+
32
+ constructor(props: NSPageSelectionModalProps<RowType>)
33
+ {
34
+ super(props);
35
+ this.state = {
36
+ selectedRadio: 'current_page'
37
+ };
38
+ this.onClickOutside = this.onClickOutside.bind(this);
39
+ this.handleRadioChange = this.handleRadioChange.bind(this);
40
+ }
41
+ override componentDidMount(): void
42
+ {
43
+ document.addEventListener('mousedown', this.onClickOutside);
44
+ }
45
+ override componentWillUnmount(): void
46
+ {
47
+ document.removeEventListener('mousedown', this.onClickOutside);
48
+ }
49
+ parseCustomPage(pages_value: string): number[]
50
+ {
51
+ let ans: number[] = [];
52
+ let pages = pages_value.split(',').map(p => p.trim()).filter(p => p);
53
+ for (let i = 0; i < pages.length; i++)
54
+ {
55
+ const element = pages[i];
56
+ if (element.includes("-"))
57
+ {
58
+ let ps = element.split('-').map(p => p.trim());
59
+ if (ps.length == 2)
60
+ {
61
+ let from = parseInt(ps[0]);
62
+ let to = parseInt(ps[1]);
63
+ for (let p = from; p <= to; p++)
64
+ ans.push(p);
65
+ }
66
+ else
67
+ throw new Error("Parse Error for : " + element);
68
+ }
69
+ else
70
+ {
71
+ let p = parseInt(element);
72
+ ans.push(p);
73
+ }
74
+ }
75
+ ans.forEach(p =>
76
+ {
77
+ if (p < 1)
78
+ throw new Error("Page number must be more than equal to 1");
79
+ if (p > this.props.max_page)
80
+ throw new Error("Page number must be less than equal to " + this.props.max_page);
81
+ })
82
+ return ans;
83
+ }
84
+ private onClickOutside(event: MouseEvent)
85
+ {
86
+ if (this.toastRef.current && !this.toastRef.current.contains(event.target as Node))
87
+ {
88
+ this.props.onClose();
89
+ }
90
+ }
91
+ private handleRadioChange(selectedRadio: string)
92
+ {
93
+ this.setState({ selectedRadio });
94
+ }
95
+ override render()
96
+ {
97
+ return (
98
+ <>
99
+ {
100
+ <>
101
+ <div className={Styles.ns_print_container} ref={this.toastRef}>
102
+ <div className={Styles.ns_header_print}>
103
+ <img
104
+ src="https://static.namirasoft.com/image/concept/close/blue.svg"
105
+ alt="Close"
106
+ width={24}
107
+ height={24}
108
+ onClick={(e) =>
109
+ {
110
+ e.stopPropagation();
111
+ this.props.onClose();
112
+ }}
113
+ className={Styles.ns_close_icon}
114
+ />
115
+ <div className={Styles.ns_print_title}>
116
+ <img
117
+ src="https://static.namirasoft.com/image/concept/print/blue.svg"
118
+ alt="Print"
119
+ width={24}
120
+ height={24}
121
+ />
122
+ <h2 className='m-0'>Page Selection</h2>
123
+ </div>
124
+ <NSSpace size={NSSpaceSizeType.SMALL} />
125
+ <p className={Styles.ns_print_description}>Please select which pages you want to continue with</p>
126
+ <NSSpace size={NSSpaceSizeType.SMALL} />
127
+ <div className={Styles.ns_parent_checkboxs}>
128
+ <NSRadioButton
129
+ defaultValue={true}
130
+ ref={this.NSBoxBoolean_CurrentPage}
131
+ title={"Current page"}
132
+ required={false}
133
+ name={"PageSelection"}
134
+ isSelected={this.state.selectedRadio === 'current_page'}
135
+ onClick={() => this.handleRadioChange('current_page')}
136
+ />
137
+ <NSRadioButton
138
+ ref={this.NSBoxBoolean_SelectedItems}
139
+ title={"Only Selected Items"}
140
+ required={false}
141
+ name={"PageSelection"}
142
+ isSelected={this.state.selectedRadio === 'selected_items'}
143
+ onClick={() => this.handleRadioChange('selected_items')}
144
+ />
145
+ <NSRadioButton
146
+ ref={this.NSBoxBoolean_CustomPage}
147
+ title={"Custom Pages"}
148
+ required={false}
149
+ name={"PageSelection"}
150
+ isSelected={this.state.selectedRadio === 'custom_page'}
151
+ onClick={() => this.handleRadioChange('custom_page')}
152
+ />
153
+ <NSRadioButton
154
+ ref={this.NSBoxBoolean_AllPage}
155
+ title={"All Pages"}
156
+ required={false}
157
+ name={"PageSelection"}
158
+ isSelected={this.state.selectedRadio === 'all_page'}
159
+ onClick={() => this.handleRadioChange('all_page')}
160
+ /> </div>
161
+ <NSSpace size={NSSpaceSizeType.MICRO} />
162
+ {this.state.selectedRadio === 'custom_page' && (
163
+ <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
164
+ getError={value =>
165
+ {
166
+ try
167
+ {
168
+ this.parseCustomPage(value);
169
+ return null;
170
+ } catch (error: any)
171
+ {
172
+ return error.message;
173
+ }
174
+ }} />
175
+ )}
176
+ <NSSpace size={NSSpaceSizeType.SMALL} />
177
+ <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
178
+ {
179
+ try
180
+ {
181
+ let items: RowType[] = [];
182
+ if (this.NSBoxBoolean_CurrentPage.current?.getValue())
183
+ {
184
+ let is = await this.props.getItems(this.props.current_page, false);
185
+ items.push(...is);
186
+ }
187
+ else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
188
+ {
189
+ let is = await this.props.getItems(this.props.current_page, true);
190
+ items.push(...is);
191
+ }
192
+ else if (this.NSBoxBoolean_CustomPage.current?.getValue())
193
+ {
194
+ let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
195
+ let pages = this.parseCustomPage(pages_value);
196
+
197
+ for (let p = 0; p < pages.length; p++)
198
+ {
199
+ let is = await this.props.getItems(pages[p], false);
200
+ items.push(...is);
201
+ }
202
+ }
203
+ else if (this.NSBoxBoolean_AllPage.current?.getValue())
204
+ {
205
+ for (let p = 1; p <= this.props.max_page; p++)
206
+ {
207
+ let is = await this.props.getItems(p, false);
208
+ items.push(...is);
209
+ }
210
+ }
211
+ else
212
+ { }
213
+ this.props.onFinish(items);
214
+ } catch (error)
215
+ {
216
+ // todo
217
+ }
218
+ }} />
219
+ </div>
220
+ </div>
221
+ <div className={Styles.ns_toast_background}></div>
222
+ </>
223
+ }
224
+ </>
225
+ );
226
+ }
227
+ }
228
+
229
229
  export default NSPageSelectionModal;
@@ -1,102 +1,102 @@
1
- .ns_pagination_container {
2
- display: flex;
3
- flex-direction: row;
4
- align-items: center;
5
- justify-content: space-between;
6
- text-align: left;
7
- font-size: 14px;
8
- justify-items: center;
9
- width: 100%;
10
- max-width: max-content;
11
- }
12
-
13
- .ns_select_number_parent {
14
- font-weight: 500;
15
- border-radius: 50px;
16
- height: 32px;
17
- width: 32px;
18
- text-align: center;
19
- display: flex;
20
- justify-content: center;
21
- align-items: center;
22
- }
23
-
24
- .ns_paginate_link {
25
- color: rgba(20, 27, 92, 1);
26
- text-decoration: none;
27
- font-size: 14px;
28
- font-weight: 600;
29
- line-height: 22px;
30
- font-family: inherit;
31
- }
32
-
33
- .ns_select_number {
34
- color: rgba(20, 27, 92, 1);
35
- font-weight: 500;
36
- background-color: rgb(255, 255, 255);
37
- border: 2px solid rgba(20, 27, 92, 1);
38
- border-radius: 50px;
39
- border-radius: 50px;
40
- height: 32px;
41
- width: 32px;
42
- text-align: center;
43
- display: flex;
44
- justify-content: center;
45
- align-items: center;
46
- }
47
-
48
- .ns_pagination_left_ellipses {
49
- padding-bottom: 10px;
50
- }
51
-
52
- .ns_pagination_left_ellipses a {
53
- color: rgba(20, 27, 92, 1);
54
- font-size: 24px;
55
- font-weight: 700;
56
- }
57
-
58
- .ns_pagination_right_ellipses {
59
- padding-bottom: 10px;
60
- }
61
-
62
- .ns_pagination_right_ellipses a {
63
- color: rgba(20, 27, 92, 1);
64
- font-size: 24px;
65
- font-weight: 700;
66
- }
67
-
68
- .ns_pagination_info {
69
- margin-left: 12px;
70
- width: fit-content;
71
- min-width: 140px;
72
- height: 48px;
73
- display: flex;
74
- flex-direction: row;
75
- justify-content: center;
76
- gap: 12px;
77
- min-width: 248px;
78
- }
79
-
80
- .ns_pagination_info h6 {
81
- background-color: rgb(255, 255, 255);
82
- width: 124px;
83
- display: flex;
84
- align-items: center;
85
- justify-content: center;
86
- height: 100%;
87
- color: rgba(20, 27, 92, 1);
88
- padding-left: 16px 24px;
89
- text-align: center;
90
- border-radius: 8px;
91
- border: 1px solid black;
92
- }
93
-
94
- .ns_pagination_combobox div {
95
- width: 74px;
96
- margin: 0;
97
- padding: 0;
98
- }
99
-
100
- .ns_pagination_combobox span {
101
- margin: 0
1
+ .ns_pagination_container {
2
+ display: flex;
3
+ flex-direction: row;
4
+ align-items: center;
5
+ justify-content: space-between;
6
+ text-align: left;
7
+ font-size: 14px;
8
+ justify-items: center;
9
+ width: 100%;
10
+ max-width: max-content;
11
+ }
12
+
13
+ .ns_select_number_parent {
14
+ font-weight: 500;
15
+ border-radius: 50px;
16
+ height: 32px;
17
+ width: 32px;
18
+ text-align: center;
19
+ display: flex;
20
+ justify-content: center;
21
+ align-items: center;
22
+ }
23
+
24
+ .ns_paginate_link {
25
+ color: rgba(20, 27, 92, 1);
26
+ text-decoration: none;
27
+ font-size: 14px;
28
+ font-weight: 600;
29
+ line-height: 22px;
30
+ font-family: inherit;
31
+ }
32
+
33
+ .ns_select_number {
34
+ color: rgba(20, 27, 92, 1);
35
+ font-weight: 500;
36
+ background-color: rgb(255, 255, 255);
37
+ border: 2px solid rgba(20, 27, 92, 1);
38
+ border-radius: 50px;
39
+ border-radius: 50px;
40
+ height: 32px;
41
+ width: 32px;
42
+ text-align: center;
43
+ display: flex;
44
+ justify-content: center;
45
+ align-items: center;
46
+ }
47
+
48
+ .ns_pagination_left_ellipses {
49
+ padding-bottom: 10px;
50
+ }
51
+
52
+ .ns_pagination_left_ellipses a {
53
+ color: rgba(20, 27, 92, 1);
54
+ font-size: 24px;
55
+ font-weight: 700;
56
+ }
57
+
58
+ .ns_pagination_right_ellipses {
59
+ padding-bottom: 10px;
60
+ }
61
+
62
+ .ns_pagination_right_ellipses a {
63
+ color: rgba(20, 27, 92, 1);
64
+ font-size: 24px;
65
+ font-weight: 700;
66
+ }
67
+
68
+ .ns_pagination_info {
69
+ margin-left: 12px;
70
+ width: fit-content;
71
+ min-width: 140px;
72
+ height: 48px;
73
+ display: flex;
74
+ flex-direction: row;
75
+ justify-content: center;
76
+ gap: 12px;
77
+ min-width: 248px;
78
+ }
79
+
80
+ .ns_pagination_info h6 {
81
+ background-color: rgb(255, 255, 255);
82
+ width: 124px;
83
+ display: flex;
84
+ align-items: center;
85
+ justify-content: center;
86
+ height: 100%;
87
+ color: rgba(20, 27, 92, 1);
88
+ padding-left: 16px 24px;
89
+ text-align: center;
90
+ border-radius: 8px;
91
+ border: 1px solid black;
92
+ }
93
+
94
+ .ns_pagination_combobox div {
95
+ width: 74px;
96
+ margin: 0;
97
+ padding: 0;
98
+ }
99
+
100
+ .ns_pagination_combobox span {
101
+ margin: 0
102
102
  }