namirasoft-site-react 1.3.367 → 1.3.368

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 (387) 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.d.ts +4 -1
  36. package/dist/components/NSBoxBoolean.js +20 -3
  37. package/dist/components/NSBoxBoolean.js.map +1 -1
  38. package/dist/components/NSBoxBoolean.module.css +53 -53
  39. package/dist/components/NSBoxCombo.module.css +17 -17
  40. package/dist/components/NSBoxDate.module.css +39 -39
  41. package/dist/components/NSBoxEntity.module.css +25 -25
  42. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  43. package/dist/components/NSBoxLabel.module.css +12 -12
  44. package/dist/components/NSBoxOTP.module.css +10 -10
  45. package/dist/components/NSBoxTextArea.module.css +76 -76
  46. package/dist/components/NSButton.module.css +27 -27
  47. package/dist/components/NSButtonBlue.module.css +4 -4
  48. package/dist/components/NSButtonGreen.module.css +4 -4
  49. package/dist/components/NSButtonRed.module.css +4 -4
  50. package/dist/components/NSCard.module.css +108 -108
  51. package/dist/components/NSCopyToClipboard.module.css +39 -39
  52. package/dist/components/NSDialog.module.css +45 -45
  53. package/dist/components/NSElectronicCard.module.css +60 -60
  54. package/dist/components/NSEntityBar.module.css +77 -77
  55. package/dist/components/NSEntityCardBackground.module.css +27 -27
  56. package/dist/components/NSFilterBox.module.css +47 -47
  57. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  58. package/dist/components/NSFilterItem.module.css +23 -23
  59. package/dist/components/NSFooter.module.css +123 -123
  60. package/dist/components/NSGroupedList.module.css +72 -72
  61. package/dist/components/NSHeader.module.css +271 -271
  62. package/dist/components/NSLayout.module.css +13 -13
  63. package/dist/components/NSLink.module.css +36 -36
  64. package/dist/components/NSLoading.module.css +29 -29
  65. package/dist/components/NSModal.js +2 -2
  66. package/dist/components/NSModal.js.map +1 -1
  67. package/dist/components/NSModal.module.css +70 -70
  68. package/dist/components/NSNoData.module.css +8 -8
  69. package/dist/components/NSPageSelectionModal.js +1 -1
  70. package/dist/components/NSPageSelectionModal.js.map +1 -1
  71. package/dist/components/NSPageSelectionModal.module.css +102 -102
  72. package/dist/components/NSPagination.module.css +101 -101
  73. package/dist/components/NSPanel.module.css +46 -46
  74. package/dist/components/NSRadioButton.js.map +1 -1
  75. package/dist/components/NSRadioButton.module.css +61 -61
  76. package/dist/components/NSSection.module.css +10 -10
  77. package/dist/components/NSSectionBars.module.css +10 -10
  78. package/dist/components/NSSectionCards.module.css +38 -38
  79. package/dist/components/NSTabPage.module.css +57 -57
  80. package/dist/components/NSTable.module.css +253 -253
  81. package/dist/components/NSTag.module.css +44 -44
  82. package/dist/components/NSTitle.module.css +15 -15
  83. package/dist/components/NSVerification.module.css +22 -22
  84. package/dist/pages/NSNotFoundPage.module.css +18 -18
  85. package/package.json +67 -67
  86. package/public/index.html +38 -38
  87. package/src/App.css +16 -16
  88. package/src/App.tsx +124 -124
  89. package/src/CopyToClipboard.ts +6 -6
  90. package/src/Validator.ts +110 -110
  91. package/src/assets/images/404 image.svg +9 -9
  92. package/src/assets/images/404 image_mobile.svg +9 -9
  93. package/src/assets/images/arrow.svg +3 -3
  94. package/src/assets/images/danger.svg +3 -3
  95. package/src/assets/images/exit.svg +3 -3
  96. package/src/assets/images/icon-input-copy.svg +3 -3
  97. package/src/assets/images/icon-input-date.svg +9 -9
  98. package/src/assets/images/icon-input-duration.svg +9 -9
  99. package/src/assets/images/icon-input-email.svg +9 -9
  100. package/src/assets/images/icon-input-float.svg +9 -9
  101. package/src/assets/images/icon-input-integer.svg +9 -9
  102. package/src/assets/images/icon-input-ip.svg +9 -9
  103. package/src/assets/images/icon-input-phone.svg +9 -9
  104. package/src/assets/images/icon-input-price.svg +9 -9
  105. package/src/assets/images/icon-input-search.svg +3 -3
  106. package/src/assets/images/icon-input-string.svg +9 -9
  107. package/src/assets/images/icon-input-text.svg +9 -9
  108. package/src/assets/images/icon-input-time.svg +9 -9
  109. package/src/assets/images/icon-select-box.svg +3 -3
  110. package/src/assets/images/logo.svg +9 -9
  111. package/src/assets/images/menu.svg +3 -3
  112. package/src/assets/images/namira.svg +9 -9
  113. package/src/assets/images/rectangle.svg +3 -3
  114. package/src/components/NSActionMenu.module.css +75 -75
  115. package/src/components/NSActionMenu.tsx +88 -88
  116. package/src/components/NSAssistantButton.module.css +133 -133
  117. package/src/components/NSAssistantButton.tsx +74 -74
  118. package/src/components/NSBarAction.module.css +87 -87
  119. package/src/components/NSBarAction.tsx +86 -86
  120. package/src/components/NSBarHeroBanner.module.css +42 -42
  121. package/src/components/NSBarHeroBanner.tsx +61 -61
  122. package/src/components/NSBarNotification.module.css +34 -34
  123. package/src/components/NSBarNotification.tsx +85 -85
  124. package/src/components/NSBarTitle.module.css +9 -9
  125. package/src/components/NSBarTitle.tsx +28 -28
  126. package/src/components/NSBox.module.css +123 -123
  127. package/src/components/NSBoxBoolean.module.css +53 -53
  128. package/src/components/NSBoxBoolean.tsx +105 -84
  129. package/src/components/NSBoxCombo.module.css +17 -17
  130. package/src/components/NSBoxCombo.tsx +132 -132
  131. package/src/components/NSBoxDate.module.css +39 -39
  132. package/src/components/NSBoxDate.tsx +83 -83
  133. package/src/components/NSBoxDateTime.tsx +83 -83
  134. package/src/components/NSBoxDouble.tsx +88 -88
  135. package/src/components/NSBoxDuration.tsx +88 -88
  136. package/src/components/NSBoxEmail.tsx +104 -104
  137. package/src/components/NSBoxEntity.module.css +25 -25
  138. package/src/components/NSBoxEntity.tsx +178 -178
  139. package/src/components/NSBoxEnum.tsx +56 -56
  140. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  141. package/src/components/NSBoxErrorNotifier.tsx +33 -33
  142. package/src/components/NSBoxIPV4.tsx +93 -93
  143. package/src/components/NSBoxIPV6.tsx +90 -90
  144. package/src/components/NSBoxInteger.tsx +86 -86
  145. package/src/components/NSBoxLabel.module.css +12 -12
  146. package/src/components/NSBoxLabel.tsx +29 -29
  147. package/src/components/NSBoxOTP.module.css +10 -10
  148. package/src/components/NSBoxOTP.tsx +65 -65
  149. package/src/components/NSBoxPassword.tsx +86 -86
  150. package/src/components/NSBoxPhone.tsx +88 -88
  151. package/src/components/NSBoxPrice.tsx +88 -88
  152. package/src/components/NSBoxSearch.tsx +103 -103
  153. package/src/components/NSBoxString.tsx +103 -103
  154. package/src/components/NSBoxTextArea.module.css +76 -76
  155. package/src/components/NSBoxTextArea.tsx +106 -106
  156. package/src/components/NSBoxTime.tsx +88 -88
  157. package/src/components/NSButton.module.css +27 -27
  158. package/src/components/NSButton.tsx +23 -23
  159. package/src/components/NSButtonBlue.module.css +4 -4
  160. package/src/components/NSButtonBlue.tsx +12 -12
  161. package/src/components/NSButtonGreen.module.css +4 -4
  162. package/src/components/NSButtonGreen.tsx +11 -11
  163. package/src/components/NSButtonRed.module.css +4 -4
  164. package/src/components/NSButtonRed.tsx +11 -11
  165. package/src/components/NSCard.module.css +108 -108
  166. package/src/components/NSCard.tsx +70 -70
  167. package/src/components/NSCopyToClipboard.module.css +39 -39
  168. package/src/components/NSCopyToClipboard.tsx +35 -35
  169. package/src/components/NSDialog.module.css +45 -45
  170. package/src/components/NSDialog.tsx +35 -35
  171. package/src/components/NSElectronicCard.module.css +60 -60
  172. package/src/components/NSElectronicCard.tsx +47 -47
  173. package/src/components/NSEntityBar.module.css +77 -77
  174. package/src/components/NSEntityBar.tsx +27 -27
  175. package/src/components/NSEntityCardBackground.module.css +27 -27
  176. package/src/components/NSEntityCardBackground.tsx +34 -34
  177. package/src/components/NSFilterBox.module.css +47 -47
  178. package/src/components/NSFilterBox.tsx +373 -373
  179. package/src/components/NSFilterBoxDialog.module.css +36 -36
  180. package/src/components/NSFilterBoxDialog.tsx +74 -74
  181. package/src/components/NSFilterItem.module.css +23 -23
  182. package/src/components/NSFilterItem.tsx +72 -72
  183. package/src/components/NSFooter.module.css +123 -123
  184. package/src/components/NSFooter.tsx +194 -194
  185. package/src/components/NSGroupedList.module.css +72 -72
  186. package/src/components/NSGroupedList.tsx +107 -107
  187. package/src/components/NSHeader.module.css +271 -271
  188. package/src/components/NSHeader.tsx +234 -234
  189. package/src/components/NSLayout.module.css +13 -13
  190. package/src/components/NSLayout.tsx +82 -82
  191. package/src/components/NSLine.tsx +18 -18
  192. package/src/components/NSLink.module.css +36 -36
  193. package/src/components/NSLink.tsx +25 -25
  194. package/src/components/NSLinkBlue.tsx +20 -20
  195. package/src/components/NSLinkGreen.tsx +5 -5
  196. package/src/components/NSLinkRed.tsx +5 -5
  197. package/src/components/NSLoading.module.css +29 -29
  198. package/src/components/NSLoading.tsx +19 -19
  199. package/src/components/NSModal.module.css +70 -70
  200. package/src/components/NSModal.tsx +53 -49
  201. package/src/components/NSNoData.module.css +8 -8
  202. package/src/components/NSNoData.tsx +24 -24
  203. package/src/components/NSPageSelectionModal.module.css +102 -102
  204. package/src/components/NSPageSelectionModal.tsx +229 -228
  205. package/src/components/NSPagination.module.css +101 -101
  206. package/src/components/NSPagination.tsx +190 -190
  207. package/src/components/NSPanel.module.css +46 -46
  208. package/src/components/NSPanel.tsx +19 -19
  209. package/src/components/NSRadioButton.module.css +61 -61
  210. package/src/components/NSRadioButton.tsx +101 -100
  211. package/src/components/NSSection.module.css +10 -10
  212. package/src/components/NSSection.tsx +23 -23
  213. package/src/components/NSSectionBars.module.css +10 -10
  214. package/src/components/NSSectionBars.tsx +25 -25
  215. package/src/components/NSSectionCards.module.css +38 -38
  216. package/src/components/NSSectionCards.tsx +51 -51
  217. package/src/components/NSSectionTitle.tsx +21 -21
  218. package/src/components/NSSpace.tsx +28 -28
  219. package/src/components/NSTabPage.module.css +57 -57
  220. package/src/components/NSTabPage.tsx +53 -53
  221. package/src/components/NSTable.module.css +253 -253
  222. package/src/components/NSTable.tsx +407 -407
  223. package/src/components/NSTag.module.css +44 -44
  224. package/src/components/NSTag.tsx +49 -49
  225. package/src/components/NSTitle.module.css +15 -15
  226. package/src/components/NSTitle.tsx +19 -19
  227. package/src/components/NSVerification.module.css +22 -22
  228. package/src/components/NSVerification.tsx +41 -41
  229. package/src/formatter/BackColorFormatter.tsx +20 -20
  230. package/src/formatter/BaseColumnFormatter.ts +14 -14
  231. package/src/formatter/BooleanFormatter.ts +20 -20
  232. package/src/formatter/DateFormatter.ts +16 -16
  233. package/src/formatter/DateTimeFormatter.ts +20 -20
  234. package/src/formatter/DurationFormatter.ts +8 -8
  235. package/src/formatter/EmailFormatter.ts +8 -8
  236. package/src/formatter/EnumFormatter.ts +8 -8
  237. package/src/formatter/FloatFormatter.ts +8 -8
  238. package/src/formatter/ForeColorFormatter.tsx +20 -20
  239. package/src/formatter/ForeignIDFormatter.ts +8 -8
  240. package/src/formatter/IDFormatter.ts +8 -8
  241. package/src/formatter/IPFormatter.ts +8 -8
  242. package/src/formatter/IntegerFormatter.ts +8 -8
  243. package/src/formatter/JsonFormatter.ts +8 -8
  244. package/src/formatter/MoneyFormatter.ts +8 -8
  245. package/src/formatter/PhoneFormatter.ts +8 -8
  246. package/src/formatter/StringFormatter.ts +8 -8
  247. package/src/formatter/TimeFormatter.ts +20 -20
  248. package/src/formatter/UnknowFormatter.ts +8 -8
  249. package/src/index.tsx +7 -7
  250. package/src/main.ts +99 -99
  251. package/src/pages/NSNotFoundPage.module.css +18 -18
  252. package/src/pages/NSNotFoundPage.tsx +11 -11
  253. package/src/props/IBaseComponentProps.ts +8 -8
  254. package/src/props/IHeaderIconProps.ts +10 -10
  255. package/src/props/IHeaderProps.ts +6 -6
  256. package/src/props/IImageProps.ts +4 -4
  257. package/src/props/ILinkProps.ts +5 -5
  258. package/src/props/IValidationNumberProps.ts +4 -4
  259. package/src/props/IValidationProps.ts +7 -7
  260. package/src/props/IValidationRegexProps.ts +4 -4
  261. package/src/props/IValidationStringProps.ts +4 -4
  262. package/src/routing/INSRouterMaker.ts +6 -6
  263. package/src/routing/INSRouterProps.ts +5 -5
  264. package/src/routing/INSRouterState.ts +5 -5
  265. package/src/routing/NSRouterMaker.tsx +33 -33
  266. package/src/routing/Notifier.ts +79 -79
  267. package/tsconfig.json +43 -43
  268. package/dist/App.css +0 -17
  269. package/dist/assets/images/1.png +0 -0
  270. package/dist/assets/images/2.png +0 -0
  271. package/dist/assets/images/3.png +0 -0
  272. package/dist/assets/images/4.png +0 -0
  273. package/dist/assets/images/5.jpg +0 -0
  274. package/dist/assets/images/icon-export.svg +0 -3
  275. package/dist/assets/images/icon-input-id.svg +0 -9
  276. package/dist/assets/images/icon-refresh.svg +0 -3
  277. package/dist/components/NSAccess.d.ts +0 -2
  278. package/dist/components/NSAccess.js +0 -8
  279. package/dist/components/NSAccess.js.map +0 -1
  280. package/dist/components/NSAccess.module.css +0 -39
  281. package/dist/components/NSBoxText.d.ts +0 -25
  282. package/dist/components/NSBoxText.js +0 -56
  283. package/dist/components/NSBoxText.js.map +0 -1
  284. package/dist/components/NSInput.module.css +0 -74
  285. package/dist/components/NSInputDate.d.ts +0 -21
  286. package/dist/components/NSInputDate.js +0 -41
  287. package/dist/components/NSInputDate.js.map +0 -1
  288. package/dist/components/NSInputDate.module.css +0 -42
  289. package/dist/components/NSInputDuration.d.ts +0 -23
  290. package/dist/components/NSInputDuration.js +0 -42
  291. package/dist/components/NSInputDuration.js.map +0 -1
  292. package/dist/components/NSInputEmail.d.ts +0 -22
  293. package/dist/components/NSInputEmail.js +0 -43
  294. package/dist/components/NSInputEmail.js.map +0 -1
  295. package/dist/components/NSInputErrorNotifier.d.ts +0 -5
  296. package/dist/components/NSInputErrorNotifier.js +0 -7
  297. package/dist/components/NSInputErrorNotifier.js.map +0 -1
  298. package/dist/components/NSInputErrorNotifier.module.css +0 -3
  299. package/dist/components/NSInputFloat.d.ts +0 -22
  300. package/dist/components/NSInputFloat.js +0 -41
  301. package/dist/components/NSInputFloat.js.map +0 -1
  302. package/dist/components/NSInputIP.d.ts +0 -22
  303. package/dist/components/NSInputIP.js +0 -43
  304. package/dist/components/NSInputIP.js.map +0 -1
  305. package/dist/components/NSInputInteger.d.ts +0 -22
  306. package/dist/components/NSInputInteger.js +0 -41
  307. package/dist/components/NSInputInteger.js.map +0 -1
  308. package/dist/components/NSInputPassword.d.ts +0 -22
  309. package/dist/components/NSInputPassword.js +0 -42
  310. package/dist/components/NSInputPassword.js.map +0 -1
  311. package/dist/components/NSInputPhone.d.ts +0 -22
  312. package/dist/components/NSInputPhone.js +0 -38
  313. package/dist/components/NSInputPhone.js.map +0 -1
  314. package/dist/components/NSInputPrice.d.ts +0 -22
  315. package/dist/components/NSInputPrice.js +0 -41
  316. package/dist/components/NSInputPrice.js.map +0 -1
  317. package/dist/components/NSInputSearch.d.ts +0 -22
  318. package/dist/components/NSInputSearch.js +0 -41
  319. package/dist/components/NSInputSearch.js.map +0 -1
  320. package/dist/components/NSInputString.d.ts +0 -22
  321. package/dist/components/NSInputString.js +0 -42
  322. package/dist/components/NSInputString.js.map +0 -1
  323. package/dist/components/NSInputText.d.ts +0 -22
  324. package/dist/components/NSInputText.js +0 -42
  325. package/dist/components/NSInputText.js.map +0 -1
  326. package/dist/components/NSInputTime.d.ts +0 -22
  327. package/dist/components/NSInputTime.js +0 -43
  328. package/dist/components/NSInputTime.js.map +0 -1
  329. package/dist/components/NSLayoutAction.d.ts +0 -5
  330. package/dist/components/NSLayoutAction.js +0 -20
  331. package/dist/components/NSLayoutAction.js.map +0 -1
  332. package/dist/components/NSLayoutAction.module.css +0 -88
  333. package/dist/components/NSLayoutHeroBanner.d.ts +0 -2
  334. package/dist/components/NSLayoutHeroBanner.js +0 -8
  335. package/dist/components/NSLayoutHeroBanner.js.map +0 -1
  336. package/dist/components/NSLayoutHeroBanner.module.css +0 -43
  337. package/dist/components/NSLayoutTitle.d.ts +0 -2
  338. package/dist/components/NSLayoutTitle.js +0 -11
  339. package/dist/components/NSLayoutTitle.js.map +0 -1
  340. package/dist/components/NSLayoutTitle.module.css +0 -10
  341. package/dist/components/NSNotification.d.ts +0 -21
  342. package/dist/components/NSNotification.js +0 -37
  343. package/dist/components/NSNotification.js.map +0 -1
  344. package/dist/components/NSNotification.module.css +0 -32
  345. package/dist/components/NSPrintModal.d.ts +0 -15
  346. package/dist/components/NSPrintModal.js +0 -35
  347. package/dist/components/NSPrintModal.js.map +0 -1
  348. package/dist/components/NSPrintModal.module.css +0 -82
  349. package/dist/components/NSSelectBox.d.ts +0 -24
  350. package/dist/components/NSSelectBox.js +0 -61
  351. package/dist/components/NSSelectBox.js.map +0 -1
  352. package/dist/components/NSSelectBox.module.css +0 -42
  353. package/dist/formatter/AnyFormatter.d.ts +0 -5
  354. package/dist/formatter/AnyFormatter.js +0 -10
  355. package/dist/formatter/AnyFormatter.js.map +0 -1
  356. package/dist/formatter/PresentFormatter.d.ts +0 -7
  357. package/dist/formatter/PresentFormatter.js +0 -17
  358. package/dist/formatter/PresentFormatter.js.map +0 -1
  359. package/dist/index.css +0 -6
  360. package/dist/pages/NSLoginPage.d.ts +0 -6
  361. package/dist/pages/NSLoginPage.js +0 -8
  362. package/dist/pages/NSLoginPage.js.map +0 -1
  363. package/dist/pages/NSLoginPage.module.css +0 -20
  364. package/dist/props/BaseComponentProps.d.ts +0 -6
  365. package/dist/props/BaseComponentProps.js +0 -2
  366. package/dist/props/BaseComponentProps.js.map +0 -10
  367. package/dist/props/INamirasoftProps.d.ts +0 -4
  368. package/dist/props/INamirasoftProps.js +0 -2
  369. package/dist/props/INamirasoftProps.js.map +0 -1
  370. package/dist/props/ImageProps.d.ts +0 -4
  371. package/dist/props/ImageProps.js +0 -2
  372. package/dist/props/ImageProps.js.map +0 -10
  373. package/dist/props/LinkProps.d.ts +0 -5
  374. package/dist/props/LinkProps.js +0 -2
  375. package/dist/props/LinkProps.js.map +0 -10
  376. package/dist/props/ValidationNumberProps.d.ts +0 -4
  377. package/dist/props/ValidationNumberProps.js +0 -2
  378. package/dist/props/ValidationNumberProps.js.map +0 -10
  379. package/dist/props/ValidationProps.d.ts +0 -6
  380. package/dist/props/ValidationProps.js +0 -2
  381. package/dist/props/ValidationProps.js.map +0 -10
  382. package/dist/props/ValidationRegexProps.d.ts +0 -4
  383. package/dist/props/ValidationRegexProps.js +0 -2
  384. package/dist/props/ValidationRegexProps.js.map +0 -1
  385. package/dist/props/ValidationStringProps.d.ts +0 -4
  386. package/dist/props/ValidationStringProps.js +0 -2
  387. package/dist/props/ValidationStringProps.js.map +0 -10
@@ -1,229 +1,230 @@
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
+ />
161
+ </div>
162
+ <NSSpace size={NSSpaceSizeType.MICRO} />
163
+ {this.state.selectedRadio === 'custom_page' && (
164
+ <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
165
+ getError={value =>
166
+ {
167
+ try
168
+ {
169
+ this.parseCustomPage(value);
170
+ return null;
171
+ } catch (error: any)
172
+ {
173
+ return error.message;
174
+ }
175
+ }} />
176
+ )}
177
+ <NSSpace size={NSSpaceSizeType.SMALL} />
178
+ <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
179
+ {
180
+ try
181
+ {
182
+ let items: RowType[] = [];
183
+ if (this.NSBoxBoolean_CurrentPage.current?.getValue())
184
+ {
185
+ let is = await this.props.getItems(this.props.current_page, false);
186
+ items.push(...is);
187
+ }
188
+ else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
189
+ {
190
+ let is = await this.props.getItems(this.props.current_page, true);
191
+ items.push(...is);
192
+ }
193
+ else if (this.NSBoxBoolean_CustomPage.current?.getValue())
194
+ {
195
+ let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
196
+ let pages = this.parseCustomPage(pages_value);
197
+
198
+ for (let p = 0; p < pages.length; p++)
199
+ {
200
+ let is = await this.props.getItems(pages[p], false);
201
+ items.push(...is);
202
+ }
203
+ }
204
+ else if (this.NSBoxBoolean_AllPage.current?.getValue())
205
+ {
206
+ for (let p = 1; p <= this.props.max_page; p++)
207
+ {
208
+ let is = await this.props.getItems(p, false);
209
+ items.push(...is);
210
+ }
211
+ }
212
+ else
213
+ { }
214
+ this.props.onFinish(items);
215
+ } catch (error)
216
+ {
217
+ // todo
218
+ }
219
+ }} />
220
+ </div>
221
+ </div>
222
+ <div className={Styles.ns_toast_background}></div>
223
+ </>
224
+ }
225
+ </>
226
+ );
227
+ }
228
+ }
229
+
229
230
  export default NSPageSelectionModal;