namirasoft-site-react 1.3.364 → 1.3.367

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