namirasoft-site-react 1.4.401 → 1.4.403

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 (305) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +72 -72
  5. package/dist/App.js +7 -1
  6. package/dist/App.js.map +1 -1
  7. package/dist/components/NSBanner.module.css +47 -47
  8. package/dist/components/NSBarAction.module.css +84 -84
  9. package/dist/components/NSBarAlert.module.css +79 -79
  10. package/dist/components/NSBarNotification.module.css +34 -34
  11. package/dist/components/NSBarTitle.module.css +9 -9
  12. package/dist/components/NSBox.module.css +54 -54
  13. package/dist/components/NSBoxBaseCombo.module.css +6 -6
  14. package/dist/components/NSBoxBoolean.module.css +73 -73
  15. package/dist/components/NSBoxDate.module.css +4 -4
  16. package/dist/components/NSBoxDateTime.module.css +4 -4
  17. package/dist/components/NSBoxDuration.module.css +4 -4
  18. package/dist/components/NSBoxFile.module.css +10 -10
  19. package/dist/components/NSBoxPhone.module.css +35 -35
  20. package/dist/components/NSBoxRadio.module.css +33 -33
  21. package/dist/components/NSBoxSchemaBase.module.css +17 -17
  22. package/dist/components/NSBoxSchemaVariable.module.css +16 -16
  23. package/dist/components/NSBoxTextArea.module.css +12 -12
  24. package/dist/components/NSBoxTime.module.css +4 -4
  25. package/dist/components/NSButton.module.css +57 -57
  26. package/dist/components/NSButtonBlue.module.css +4 -4
  27. package/dist/components/NSButtonGreen.module.css +4 -4
  28. package/dist/components/NSButtonRed.module.css +4 -4
  29. package/dist/components/NSCard.module.css +114 -114
  30. package/dist/components/NSCardScreenshot.module.css +41 -41
  31. package/dist/components/NSChartColumn.module.css +7 -7
  32. package/dist/components/NSChartTable.module.css +21 -21
  33. package/dist/components/NSColumn.module.css +16 -16
  34. package/dist/components/NSCopyBox.module.css +39 -39
  35. package/dist/components/NSDialog.module.css +112 -112
  36. package/dist/components/NSDialogPageSelection.module.css +103 -103
  37. package/dist/components/NSDownTimer.module.css +55 -55
  38. package/dist/components/NSDownload.module.css +46 -46
  39. package/dist/components/NSElectronicCard.module.css +60 -60
  40. package/dist/components/NSEntityCardBackground.module.css +27 -27
  41. package/dist/components/NSFilterBox.module.css +27 -27
  42. package/dist/components/NSFilterBoxItems.module.css +15 -15
  43. package/dist/components/NSFilterItem.module.css +24 -24
  44. package/dist/components/NSFooter.module.css +134 -134
  45. package/dist/components/NSHeader.d.ts +7 -1
  46. package/dist/components/NSHeader.js +29 -6
  47. package/dist/components/NSHeader.js.map +1 -1
  48. package/dist/components/NSHeader.module.css +291 -291
  49. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  50. package/dist/components/NSLabel.module.css +25 -25
  51. package/dist/components/NSLabelErrorNotifier.module.css +2 -2
  52. package/dist/components/NSLayout.d.ts +1 -1
  53. package/dist/components/NSLayout.module.css +14 -14
  54. package/dist/components/NSLine.module.css +15 -15
  55. package/dist/components/NSLink.module.css +36 -36
  56. package/dist/components/NSListGrouped.module.css +69 -69
  57. package/dist/components/NSListProduct.js.map +1 -1
  58. package/dist/components/NSLoading.module.css +38 -38
  59. package/dist/components/NSMenuAction.module.css +88 -88
  60. package/dist/components/NSMenuButton.module.css +44 -44
  61. package/dist/components/NSNoData.module.css +9 -9
  62. package/dist/components/NSPagination.module.css +85 -85
  63. package/dist/components/NSPanel.module.css +19 -19
  64. package/dist/components/NSPanelAccordion.module.css +4 -4
  65. package/dist/components/NSProductSearch.d.ts +16 -0
  66. package/dist/components/NSProductSearch.js +56 -0
  67. package/dist/components/NSProductSearch.js.map +1 -0
  68. package/dist/components/NSProductSearch.module.css +69 -0
  69. package/dist/components/NSRange.module.css +66 -66
  70. package/dist/components/NSRow.module.css +17 -17
  71. package/dist/components/NSSection.module.css +4 -4
  72. package/dist/components/NSSectionCards.module.css +38 -38
  73. package/dist/components/NSSectionTiles.module.css +10 -10
  74. package/dist/components/NSTabPage.module.css +59 -59
  75. package/dist/components/NSTable.module.css +263 -263
  76. package/dist/components/NSTile.module.css +76 -76
  77. package/dist/components/NSTimelineMonthly.module.css +71 -71
  78. package/dist/components/NSTitle.module.css +15 -15
  79. package/dist/pages/NSNotFoundPage.module.css +18 -18
  80. package/dist/pages/NSUpdating.module.css +35 -35
  81. package/package.json +82 -82
  82. package/public/index.html +38 -38
  83. package/src/App.css +33 -33
  84. package/src/App.tsx +216 -210
  85. package/src/Color.tsx +10 -10
  86. package/src/CopyToClipboard.ts +6 -6
  87. package/src/NSBoxBuilder.tsx +912 -912
  88. package/src/ProductCacheService.ts +15 -15
  89. package/src/Validator.ts +166 -166
  90. package/src/components/INSBox.tsx +6 -6
  91. package/src/components/NSBanner.module.css +47 -47
  92. package/src/components/NSBanner.tsx +80 -80
  93. package/src/components/NSBarAction.module.css +84 -84
  94. package/src/components/NSBarAction.tsx +91 -91
  95. package/src/components/NSBarAlert.module.css +79 -79
  96. package/src/components/NSBarAlert.tsx +35 -35
  97. package/src/components/NSBarNotification.module.css +34 -34
  98. package/src/components/NSBarNotification.tsx +86 -86
  99. package/src/components/NSBarTitle.module.css +9 -9
  100. package/src/components/NSBarTitle.tsx +23 -23
  101. package/src/components/NSBox.module.css +54 -54
  102. package/src/components/NSBox.tsx +19 -19
  103. package/src/components/NSBoxBaseCombo.module.css +6 -6
  104. package/src/components/NSBoxBaseCombo.tsx +428 -428
  105. package/src/components/NSBoxBaseLayout.tsx +88 -88
  106. package/src/components/NSBoxBaseLayoutRecursive.tsx +54 -54
  107. package/src/components/NSBoxBoolean.module.css +73 -73
  108. package/src/components/NSBoxBoolean.tsx +128 -128
  109. package/src/components/NSBoxBooleans.tsx +178 -178
  110. package/src/components/NSBoxColor.tsx +95 -95
  111. package/src/components/NSBoxCombo.tsx +91 -91
  112. package/src/components/NSBoxDate.module.css +4 -4
  113. package/src/components/NSBoxDate.tsx +90 -90
  114. package/src/components/NSBoxDateTime.module.css +4 -4
  115. package/src/components/NSBoxDateTime.tsx +103 -103
  116. package/src/components/NSBoxDouble.tsx +94 -94
  117. package/src/components/NSBoxDuration.module.css +4 -4
  118. package/src/components/NSBoxDuration.tsx +95 -95
  119. package/src/components/NSBoxDynamic.tsx +67 -67
  120. package/src/components/NSBoxDynamics.tsx +68 -68
  121. package/src/components/NSBoxEmail.tsx +98 -98
  122. package/src/components/NSBoxEntity.tsx +174 -174
  123. package/src/components/NSBoxEnum.tsx +108 -108
  124. package/src/components/NSBoxFile.module.css +10 -10
  125. package/src/components/NSBoxFile.tsx +101 -101
  126. package/src/components/NSBoxFilePath.tsx +95 -95
  127. package/src/components/NSBoxFont.tsx +95 -95
  128. package/src/components/NSBoxIPV4.tsx +95 -95
  129. package/src/components/NSBoxIPV4Range.tsx +95 -95
  130. package/src/components/NSBoxIPV6.tsx +92 -92
  131. package/src/components/NSBoxIPV6Range.tsx +95 -95
  132. package/src/components/NSBoxInteger.tsx +91 -91
  133. package/src/components/NSBoxMoney.tsx +95 -95
  134. package/src/components/NSBoxPassword.tsx +108 -108
  135. package/src/components/NSBoxPhone.module.css +35 -35
  136. package/src/components/NSBoxPhone.tsx +107 -107
  137. package/src/components/NSBoxRadio.module.css +33 -33
  138. package/src/components/NSBoxRadio.tsx +91 -91
  139. package/src/components/NSBoxSchemaBase.module.css +17 -17
  140. package/src/components/NSBoxSchemaBase.tsx +540 -540
  141. package/src/components/NSBoxSchemaVariable.module.css +16 -16
  142. package/src/components/NSBoxSchemaVariable.tsx +247 -247
  143. package/src/components/NSBoxSearch.tsx +97 -97
  144. package/src/components/NSBoxString.tsx +93 -93
  145. package/src/components/NSBoxTextArea.module.css +12 -12
  146. package/src/components/NSBoxTextArea.tsx +98 -98
  147. package/src/components/NSBoxTime.module.css +4 -4
  148. package/src/components/NSBoxTime.tsx +93 -93
  149. package/src/components/NSBoxTimeZone.tsx +95 -95
  150. package/src/components/NSBoxURL.tsx +104 -104
  151. package/src/components/NSBoxVersion.tsx +95 -95
  152. package/src/components/NSButton.module.css +57 -57
  153. package/src/components/NSButton.tsx +75 -75
  154. package/src/components/NSButtonBlue.module.css +4 -4
  155. package/src/components/NSButtonBlue.tsx +29 -29
  156. package/src/components/NSButtonGreen.module.css +4 -4
  157. package/src/components/NSButtonGreen.tsx +29 -29
  158. package/src/components/NSButtonRed.module.css +4 -4
  159. package/src/components/NSButtonRed.tsx +29 -29
  160. package/src/components/NSCard.module.css +114 -114
  161. package/src/components/NSCard.tsx +63 -63
  162. package/src/components/NSCardScreenshot.module.css +41 -41
  163. package/src/components/NSCardScreenshot.tsx +31 -31
  164. package/src/components/NSChartColumn.module.css +7 -7
  165. package/src/components/NSChartColumn.tsx +106 -106
  166. package/src/components/NSChartDoughnut.tsx +112 -112
  167. package/src/components/NSChartPie.tsx +105 -105
  168. package/src/components/NSChartRange.tsx +14 -14
  169. package/src/components/NSChartTable.module.css +21 -21
  170. package/src/components/NSChartTable.tsx +94 -94
  171. package/src/components/NSColumn.module.css +16 -16
  172. package/src/components/NSColumn.tsx +24 -24
  173. package/src/components/NSCopy.tsx +58 -58
  174. package/src/components/NSCopyBox.module.css +39 -39
  175. package/src/components/NSCopyBox.tsx +53 -53
  176. package/src/components/NSDialog.module.css +112 -112
  177. package/src/components/NSDialog.tsx +61 -61
  178. package/src/components/NSDialogDelete.tsx +27 -27
  179. package/src/components/NSDialogInfo.tsx +49 -49
  180. package/src/components/NSDialogPageSelection.module.css +103 -103
  181. package/src/components/NSDialogPageSelection.tsx +234 -234
  182. package/src/components/NSDownTimer.module.css +55 -55
  183. package/src/components/NSDownTimer.tsx +91 -91
  184. package/src/components/NSDownload.module.css +46 -46
  185. package/src/components/NSDownload.tsx +69 -69
  186. package/src/components/NSElectronicCard.module.css +60 -60
  187. package/src/components/NSElectronicCard.tsx +46 -46
  188. package/src/components/NSEntityCardBackground.module.css +27 -27
  189. package/src/components/NSEntityCardBackground.tsx +36 -36
  190. package/src/components/NSFilterBox.module.css +27 -27
  191. package/src/components/NSFilterBox.tsx +477 -477
  192. package/src/components/NSFilterBoxItems.module.css +15 -15
  193. package/src/components/NSFilterBoxItems.tsx +52 -52
  194. package/src/components/NSFilterItem.module.css +24 -24
  195. package/src/components/NSFilterItem.tsx +27 -27
  196. package/src/components/NSFooter.module.css +134 -134
  197. package/src/components/NSFooter.tsx +321 -321
  198. package/src/components/NSHeader.module.css +291 -291
  199. package/src/components/NSHeader.tsx +309 -260
  200. package/src/components/NSHeaderScreenshot.module.css +35 -35
  201. package/src/components/NSHeaderScreenshot.tsx +39 -39
  202. package/src/components/NSID.tsx +158 -158
  203. package/src/components/NSLabel.module.css +25 -25
  204. package/src/components/NSLabel.tsx +47 -47
  205. package/src/components/NSLabelErrorNotifier.module.css +2 -2
  206. package/src/components/NSLabelErrorNotifier.tsx +35 -35
  207. package/src/components/NSLayout.module.css +14 -14
  208. package/src/components/NSLayout.tsx +134 -134
  209. package/src/components/NSLine.module.css +15 -15
  210. package/src/components/NSLine.tsx +13 -13
  211. package/src/components/NSLink.module.css +36 -36
  212. package/src/components/NSLink.tsx +25 -25
  213. package/src/components/NSLinkBlue.tsx +21 -21
  214. package/src/components/NSLinkGreen.tsx +12 -12
  215. package/src/components/NSLinkRed.tsx +12 -12
  216. package/src/components/NSListGrouped.module.css +69 -69
  217. package/src/components/NSListGrouped.tsx +106 -106
  218. package/src/components/NSListProduct.tsx +44 -43
  219. package/src/components/NSLoading.module.css +38 -38
  220. package/src/components/NSLoading.tsx +37 -37
  221. package/src/components/NSMenuAction.module.css +88 -88
  222. package/src/components/NSMenuAction.tsx +106 -106
  223. package/src/components/NSMenuButton.module.css +44 -44
  224. package/src/components/NSMenuButton.tsx +206 -206
  225. package/src/components/NSNoData.module.css +9 -9
  226. package/src/components/NSNoData.tsx +24 -24
  227. package/src/components/NSPagination.module.css +85 -85
  228. package/src/components/NSPagination.tsx +182 -182
  229. package/src/components/NSPanel.module.css +19 -19
  230. package/src/components/NSPanel.tsx +24 -24
  231. package/src/components/NSPanelAccordion.module.css +4 -4
  232. package/src/components/NSPanelAccordion.tsx +51 -51
  233. package/src/components/NSProductSearch.module.css +69 -0
  234. package/src/components/NSProductSearch.tsx +156 -0
  235. package/src/components/NSRange.module.css +66 -66
  236. package/src/components/NSRange.tsx +83 -83
  237. package/src/components/NSRepeater.tsx +254 -254
  238. package/src/components/NSRepeaterNSBoxSchemaVariable.tsx +90 -90
  239. package/src/components/NSRepeaterNSTag.tsx +82 -82
  240. package/src/components/NSRow.module.css +17 -17
  241. package/src/components/NSRow.tsx +24 -24
  242. package/src/components/NSSection.module.css +4 -4
  243. package/src/components/NSSection.tsx +26 -26
  244. package/src/components/NSSectionCards.module.css +38 -38
  245. package/src/components/NSSectionCards.tsx +51 -51
  246. package/src/components/NSSectionTiles.module.css +10 -10
  247. package/src/components/NSSectionTiles.tsx +25 -25
  248. package/src/components/NSSectionTitle.tsx +21 -21
  249. package/src/components/NSSpace.tsx +28 -28
  250. package/src/components/NSTabPage.module.css +59 -59
  251. package/src/components/NSTabPage.tsx +91 -91
  252. package/src/components/NSTable.module.css +263 -263
  253. package/src/components/NSTable.tsx +636 -636
  254. package/src/components/NSTag.tsx +74 -74
  255. package/src/components/NSTile.module.css +76 -76
  256. package/src/components/NSTile.tsx +27 -27
  257. package/src/components/NSTimelineMonthly.module.css +71 -71
  258. package/src/components/NSTimelineMonthly.tsx +44 -44
  259. package/src/components/NSTitle.module.css +15 -15
  260. package/src/components/NSTitle.tsx +19 -19
  261. package/src/formatter/BackColorFormatter.tsx +23 -23
  262. package/src/formatter/BaseColumnFormatter.ts +16 -16
  263. package/src/formatter/BaseURLImageFormatter.tsx +33 -33
  264. package/src/formatter/BooleanFormatter.ts +22 -22
  265. package/src/formatter/DateFormatter.ts +21 -21
  266. package/src/formatter/DateTimeFormatter.ts +21 -21
  267. package/src/formatter/DurationFormatter.ts +13 -13
  268. package/src/formatter/EmailFormatter.tsx +21 -21
  269. package/src/formatter/EnumFormatter.ts +13 -13
  270. package/src/formatter/FloatFormatter.ts +23 -23
  271. package/src/formatter/ForeColorFormatter.tsx +24 -24
  272. package/src/formatter/IDFormatter.tsx +30 -30
  273. package/src/formatter/IPFormatter.ts +13 -13
  274. package/src/formatter/IntegerFormatter.ts +23 -23
  275. package/src/formatter/JsonFormatter.ts +21 -21
  276. package/src/formatter/MoneyFormatter.ts +35 -35
  277. package/src/formatter/PhoneFormatter.tsx +21 -21
  278. package/src/formatter/StringFormatter.tsx +43 -43
  279. package/src/formatter/TimeFormatter.ts +21 -21
  280. package/src/formatter/URLFormatter.tsx +21 -21
  281. package/src/formatter/UnknowFormatter.ts +18 -18
  282. package/src/index.tsx +7 -7
  283. package/src/main.ts +225 -225
  284. package/src/pages/NSNotFoundPage.module.css +18 -18
  285. package/src/pages/NSNotFoundPage.tsx +11 -11
  286. package/src/pages/NSUpdating.module.css +35 -35
  287. package/src/pages/NSUpdating.tsx +32 -32
  288. package/src/props/IBackgroundProps.ts +5 -5
  289. package/src/props/IBaseComponentProps.ts +8 -8
  290. package/src/props/IHeaderIconProps.ts +10 -10
  291. package/src/props/IHeaderLeftProps.ts +6 -6
  292. package/src/props/IHeaderRightProps.ts +6 -6
  293. package/src/props/IImageProps.ts +4 -4
  294. package/src/props/ILinkProps.ts +5 -5
  295. package/src/props/IValidationNumberProps.ts +4 -4
  296. package/src/props/IValidationPrecisionProps.ts +3 -3
  297. package/src/props/IValidationProps.ts +9 -9
  298. package/src/props/IValidationRegexProps.ts +4 -4
  299. package/src/props/IValidationStringProps.ts +4 -4
  300. package/src/routing/NSNotifier.ts +114 -114
  301. package/src/routing/NSRouterMaker.tsx +20 -20
  302. package/src/routing/NSRouterMakerComponent.ts +5 -5
  303. package/src/routing/NSRouterMakerProps.ts +5 -5
  304. package/dist/App.css +0 -34
  305. package/dist/index.css +0 -6
@@ -1,104 +1,104 @@
1
- .ns_print_container {
2
- transform: translate(50%, 50%);
3
- background-color: rgba(255, 255, 255, 1);
4
- border-radius: 16px;
5
- border: 0.2px solid rgb(210, 210, 210);
6
- padding: 16px;
7
- max-width: 380px;
8
- position: fixed;
9
- top: 50%;
10
- left: 50%;
11
- transform: translate(-50%, -50%);
12
- z-index: 100;
13
- width: 100%;
14
- border: 8px solid rgb(233, 232, 232);
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: center;
46
- gap: 16px;
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_parent_checkboxs {
68
- justify-content: space-between;
69
- }
70
-
71
- .ns_print_container {
72
- max-width: 610px;
73
- }
74
-
75
- .ns_w_box_boolean div {
76
- width: 272px !important;
77
- }
78
-
79
- .ns_w_box_boolean {
80
- width: 272px !important;
81
- }
82
-
83
- .ns_w_box_string {
84
- width: 272px !important;
85
- }
86
-
87
- .ns_w_box_string input {
88
- width: 272px !important;
89
- }
90
- }
91
-
92
- .ns_toast_background {
93
- width: 100vw;
94
- height: 100vh;
95
- background-color: #00000090;
96
- position: fixed;
97
- top: 0;
98
- left: 0;
99
- display: flex;
100
- justify-content: center;
101
- align-items: center;
102
- cursor: default;
103
- z-index: 99;
1
+ .ns_print_container {
2
+ transform: translate(50%, 50%);
3
+ background-color: rgba(255, 255, 255, 1);
4
+ border-radius: 16px;
5
+ border: 0.2px solid rgb(210, 210, 210);
6
+ padding: 16px;
7
+ max-width: 380px;
8
+ position: fixed;
9
+ top: 50%;
10
+ left: 50%;
11
+ transform: translate(-50%, -50%);
12
+ z-index: 100;
13
+ width: 100%;
14
+ border: 8px solid rgb(233, 232, 232);
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: center;
46
+ gap: 16px;
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_parent_checkboxs {
68
+ justify-content: space-between;
69
+ }
70
+
71
+ .ns_print_container {
72
+ max-width: 610px;
73
+ }
74
+
75
+ .ns_w_box_boolean div {
76
+ width: 272px !important;
77
+ }
78
+
79
+ .ns_w_box_boolean {
80
+ width: 272px !important;
81
+ }
82
+
83
+ .ns_w_box_string {
84
+ width: 272px !important;
85
+ }
86
+
87
+ .ns_w_box_string input {
88
+ width: 272px !important;
89
+ }
90
+ }
91
+
92
+ .ns_toast_background {
93
+ width: 100vw;
94
+ height: 100vh;
95
+ background-color: #00000090;
96
+ position: fixed;
97
+ top: 0;
98
+ left: 0;
99
+ display: flex;
100
+ justify-content: center;
101
+ align-items: center;
102
+ cursor: default;
103
+ z-index: 99;
104
104
  }
@@ -1,235 +1,235 @@
1
- import React, { Component, createRef } from 'react';
2
- import { NSButtonBlue } from './NSButtonBlue';
3
- import { NSBoxString } from './NSBoxString';
4
- import { NSSpace, NSSpaceSizeType } from './NSSpace';
5
- import Styles from './NSDialogPageSelection.module.css';
6
- import { NSBoxRadio } from './NSBoxRadio';
7
-
8
- export interface NSDialogPageSelectionProps<RowType>
9
- {
10
- current_page: number;
11
- current_size: number;
12
- max_page: number;
13
- onClose: () => void;
14
- getItems: (page: number, size: number, selected: boolean) => Promise<RowType[]>;
15
- onFinish: (items: RowType[]) => Promise<void>;
16
- icon?: string;
17
- }
18
-
19
- interface NSDialogPageSelectionState
20
- {
21
- selectedRadio: string;
22
- }
23
-
24
- export class NSDialogPageSelection<RowType> extends Component<NSDialogPageSelectionProps<RowType>, NSDialogPageSelectionState>
25
- {
26
- private toastRef: React.RefObject<HTMLDivElement> = createRef();
27
- private NSBoxBoolean_CurrentPage: React.RefObject<NSBoxRadio> = createRef();
28
- private NSBoxBoolean_SelectedItems: React.RefObject<NSBoxRadio> = createRef();
29
- private NSBoxBoolean_CustomPage: React.RefObject<NSBoxRadio> = createRef();
30
- private NSBoxBoolean_AllPage: React.RefObject<NSBoxRadio> = createRef();
31
- private NSBoxString_Pages: React.RefObject<NSBoxString> = createRef();
32
-
33
- constructor(props: NSDialogPageSelectionProps<RowType>)
34
- {
35
- super(props);
36
- this.state = {
37
- selectedRadio: 'current_page'
38
- };
39
- this.onClickOutside = this.onClickOutside.bind(this);
40
- this.handleRadioChange = this.handleRadioChange.bind(this);
41
- }
42
- override componentDidMount(): void
43
- {
44
- document.addEventListener('mousedown', this.onClickOutside);
45
- }
46
- override componentWillUnmount(): void
47
- {
48
- document.removeEventListener('mousedown', this.onClickOutside);
49
- }
50
- parseCustomPage(pages_value: string): number[]
51
- {
52
- let ans: number[] = [];
53
- let pages = pages_value.split(',').map(p => p.trim()).filter(p => p);
54
- for (let i = 0; i < pages.length; i++)
55
- {
56
- const element = pages[i];
57
- if (element.includes("-"))
58
- {
59
- let ps = element.split('-').map(p => p.trim());
60
- if (ps.length === 2)
61
- {
62
- let from = parseInt(ps[0]);
63
- let to = parseInt(ps[1]);
64
- for (let p = from; p <= to; p++)
65
- ans.push(p);
66
- }
67
- else
68
- throw new Error("Parse Error for : " + element);
69
- }
70
- else
71
- {
72
- let p = parseInt(element);
73
- ans.push(p);
74
- }
75
- }
76
- ans.forEach(p =>
77
- {
78
- if (p < 1)
79
- throw new Error("Page number must be more than equal to 1");
80
- if (p > this.props.max_page)
81
- throw new Error("Page number must be less than equal to " + this.props.max_page);
82
- })
83
- return ans;
84
- }
85
- private onClickOutside(event: MouseEvent)
86
- {
87
- if (this.toastRef.current && !this.toastRef.current.contains(event.target as Node))
88
- {
89
- this.props.onClose();
90
- }
91
- }
92
- private handleRadioChange(selectedRadio: string)
93
- {
94
- this.setState({ selectedRadio });
95
- }
96
- override render()
97
- {
98
- return (
99
- <>
100
- {
101
- <>
102
- <div className={Styles.ns_print_container} ref={this.toastRef}>
103
- <div className={Styles.ns_header_print}>
104
- <img
105
- src="https://static.namirasoft.com/image/concept/close/blue.svg"
106
- alt="Close"
107
- width={24}
108
- height={24}
109
- onClick={(e) =>
110
- {
111
- e.stopPropagation();
112
- this.props.onClose();
113
- }}
114
- className={Styles.ns_close_icon}
115
- />
116
- <div className={Styles.ns_print_title}>
117
- <img
118
- src={this.props.icon && this.props.icon}
119
- alt="Print"
120
- width={24}
121
- height={24}
122
- />
123
- <h2 className='m-0'>Page Selection</h2>
124
- </div>
125
- <NSSpace size={NSSpaceSizeType.SMALL} />
126
- <p className={Styles.ns_print_description}>Please select which pages you want to continue with</p>
127
- <NSSpace size={NSSpaceSizeType.SMALL} />
128
- <div className={Styles.ns_parent_checkboxs}>
129
- {/* todo: input id for check when click on labels */}
130
- <NSBoxRadio
131
- ref={this.NSBoxBoolean_CurrentPage}
132
- required={false}
133
- defaultValue={true}
134
- title={"Current page"}
135
- hideHeader
136
- checked={this.state.selectedRadio === 'current_page'}
137
- onClicked={() => this.handleRadioChange('current_page')}
138
- />
139
- <NSBoxRadio
140
- ref={this.NSBoxBoolean_SelectedItems}
141
- required={false}
142
- title={"Only Selected Items"}
143
- hideHeader
144
- checked={this.state.selectedRadio === 'selected_items'}
145
- onClicked={() => this.handleRadioChange('selected_items')}
146
- />
147
- <NSBoxRadio
148
- ref={this.NSBoxBoolean_CustomPage}
149
- title={"Custom Pages"}
150
- required={false}
151
- hideHeader
152
- checked={this.state.selectedRadio === 'custom_page'}
153
- onClicked={() => this.handleRadioChange('custom_page')}
154
- />
155
- <NSBoxRadio
156
- ref={this.NSBoxBoolean_AllPage}
157
- title={"All Pages"}
158
- required={false}
159
- hideHeader
160
- checked={this.state.selectedRadio === 'all_page'}
161
- onClicked={() => this.handleRadioChange('all_page')}
162
- />
163
- </div>
164
- <NSSpace size={NSSpaceSizeType.MICRO} />
165
- {this.state.selectedRadio === 'custom_page' && (
166
- <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
167
- validator={(_, value) =>
168
- {
169
- try
170
- {
171
- this.parseCustomPage(value);
172
- return null;
173
- } catch (error: any)
174
- {
175
- return error.message;
176
- }
177
- }} />
178
- )}
179
- <NSSpace size={NSSpaceSizeType.SMALL} />
180
- <NSButtonBlue
181
- style={{ width: "100%" }}
182
- title='Apply'
183
- onClick={{
184
- action: async (onFinished) =>
185
- {
186
- try
187
- {
188
- let items: RowType[] = [];
189
- if (this.NSBoxBoolean_CurrentPage.current?.getValue())
190
- {
191
- let is = await this.props.getItems(this.props.current_page, this.props.current_size, false);
192
- items.push(...is);
193
- }
194
- else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
195
- {
196
- let is = await this.props.getItems(this.props.current_page, this.props.current_size, true);
197
- items.push(...is);
198
- }
199
- else if (this.NSBoxBoolean_CustomPage.current?.getValue())
200
- {
201
- let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
202
- let pages = this.parseCustomPage(pages_value);
203
-
204
- for (let p = 0; p < pages.length; p++)
205
- {
206
- let is = await this.props.getItems(pages[p], this.props.current_size, false);
207
- items.push(...is);
208
- }
209
- }
210
- else if (this.NSBoxBoolean_AllPage.current?.getValue())
211
- {
212
- for (let p = 1; p <= this.props.max_page; p++)
213
- {
214
- let is = await this.props.getItems(p, this.props.current_size, false);
215
- items.push(...is);
216
- }
217
- }
218
- else
219
- { }
220
- await this.props.onFinish(items);
221
- } catch (error)
222
- {
223
- }
224
- onFinished();
225
- }
226
- }} />
227
- </div>
228
- </div>
229
- <div className={Styles.ns_toast_background}></div>
230
- </>
231
- }
232
- </>
233
- );
234
- }
1
+ import React, { Component, createRef } from 'react';
2
+ import { NSButtonBlue } from './NSButtonBlue';
3
+ import { NSBoxString } from './NSBoxString';
4
+ import { NSSpace, NSSpaceSizeType } from './NSSpace';
5
+ import Styles from './NSDialogPageSelection.module.css';
6
+ import { NSBoxRadio } from './NSBoxRadio';
7
+
8
+ export interface NSDialogPageSelectionProps<RowType>
9
+ {
10
+ current_page: number;
11
+ current_size: number;
12
+ max_page: number;
13
+ onClose: () => void;
14
+ getItems: (page: number, size: number, selected: boolean) => Promise<RowType[]>;
15
+ onFinish: (items: RowType[]) => Promise<void>;
16
+ icon?: string;
17
+ }
18
+
19
+ interface NSDialogPageSelectionState
20
+ {
21
+ selectedRadio: string;
22
+ }
23
+
24
+ export class NSDialogPageSelection<RowType> extends Component<NSDialogPageSelectionProps<RowType>, NSDialogPageSelectionState>
25
+ {
26
+ private toastRef: React.RefObject<HTMLDivElement> = createRef();
27
+ private NSBoxBoolean_CurrentPage: React.RefObject<NSBoxRadio> = createRef();
28
+ private NSBoxBoolean_SelectedItems: React.RefObject<NSBoxRadio> = createRef();
29
+ private NSBoxBoolean_CustomPage: React.RefObject<NSBoxRadio> = createRef();
30
+ private NSBoxBoolean_AllPage: React.RefObject<NSBoxRadio> = createRef();
31
+ private NSBoxString_Pages: React.RefObject<NSBoxString> = createRef();
32
+
33
+ constructor(props: NSDialogPageSelectionProps<RowType>)
34
+ {
35
+ super(props);
36
+ this.state = {
37
+ selectedRadio: 'current_page'
38
+ };
39
+ this.onClickOutside = this.onClickOutside.bind(this);
40
+ this.handleRadioChange = this.handleRadioChange.bind(this);
41
+ }
42
+ override componentDidMount(): void
43
+ {
44
+ document.addEventListener('mousedown', this.onClickOutside);
45
+ }
46
+ override componentWillUnmount(): void
47
+ {
48
+ document.removeEventListener('mousedown', this.onClickOutside);
49
+ }
50
+ parseCustomPage(pages_value: string): number[]
51
+ {
52
+ let ans: number[] = [];
53
+ let pages = pages_value.split(',').map(p => p.trim()).filter(p => p);
54
+ for (let i = 0; i < pages.length; i++)
55
+ {
56
+ const element = pages[i];
57
+ if (element.includes("-"))
58
+ {
59
+ let ps = element.split('-').map(p => p.trim());
60
+ if (ps.length === 2)
61
+ {
62
+ let from = parseInt(ps[0]);
63
+ let to = parseInt(ps[1]);
64
+ for (let p = from; p <= to; p++)
65
+ ans.push(p);
66
+ }
67
+ else
68
+ throw new Error("Parse Error for : " + element);
69
+ }
70
+ else
71
+ {
72
+ let p = parseInt(element);
73
+ ans.push(p);
74
+ }
75
+ }
76
+ ans.forEach(p =>
77
+ {
78
+ if (p < 1)
79
+ throw new Error("Page number must be more than equal to 1");
80
+ if (p > this.props.max_page)
81
+ throw new Error("Page number must be less than equal to " + this.props.max_page);
82
+ })
83
+ return ans;
84
+ }
85
+ private onClickOutside(event: MouseEvent)
86
+ {
87
+ if (this.toastRef.current && !this.toastRef.current.contains(event.target as Node))
88
+ {
89
+ this.props.onClose();
90
+ }
91
+ }
92
+ private handleRadioChange(selectedRadio: string)
93
+ {
94
+ this.setState({ selectedRadio });
95
+ }
96
+ override render()
97
+ {
98
+ return (
99
+ <>
100
+ {
101
+ <>
102
+ <div className={Styles.ns_print_container} ref={this.toastRef}>
103
+ <div className={Styles.ns_header_print}>
104
+ <img
105
+ src="https://static.namirasoft.com/image/concept/close/blue.svg"
106
+ alt="Close"
107
+ width={24}
108
+ height={24}
109
+ onClick={(e) =>
110
+ {
111
+ e.stopPropagation();
112
+ this.props.onClose();
113
+ }}
114
+ className={Styles.ns_close_icon}
115
+ />
116
+ <div className={Styles.ns_print_title}>
117
+ <img
118
+ src={this.props.icon && this.props.icon}
119
+ alt="Print"
120
+ width={24}
121
+ height={24}
122
+ />
123
+ <h2 className='m-0'>Page Selection</h2>
124
+ </div>
125
+ <NSSpace size={NSSpaceSizeType.SMALL} />
126
+ <p className={Styles.ns_print_description}>Please select which pages you want to continue with</p>
127
+ <NSSpace size={NSSpaceSizeType.SMALL} />
128
+ <div className={Styles.ns_parent_checkboxs}>
129
+ {/* todo: input id for check when click on labels */}
130
+ <NSBoxRadio
131
+ ref={this.NSBoxBoolean_CurrentPage}
132
+ required={false}
133
+ defaultValue={true}
134
+ title={"Current page"}
135
+ hideHeader
136
+ checked={this.state.selectedRadio === 'current_page'}
137
+ onClicked={() => this.handleRadioChange('current_page')}
138
+ />
139
+ <NSBoxRadio
140
+ ref={this.NSBoxBoolean_SelectedItems}
141
+ required={false}
142
+ title={"Only Selected Items"}
143
+ hideHeader
144
+ checked={this.state.selectedRadio === 'selected_items'}
145
+ onClicked={() => this.handleRadioChange('selected_items')}
146
+ />
147
+ <NSBoxRadio
148
+ ref={this.NSBoxBoolean_CustomPage}
149
+ title={"Custom Pages"}
150
+ required={false}
151
+ hideHeader
152
+ checked={this.state.selectedRadio === 'custom_page'}
153
+ onClicked={() => this.handleRadioChange('custom_page')}
154
+ />
155
+ <NSBoxRadio
156
+ ref={this.NSBoxBoolean_AllPage}
157
+ title={"All Pages"}
158
+ required={false}
159
+ hideHeader
160
+ checked={this.state.selectedRadio === 'all_page'}
161
+ onClicked={() => this.handleRadioChange('all_page')}
162
+ />
163
+ </div>
164
+ <NSSpace size={NSSpaceSizeType.MICRO} />
165
+ {this.state.selectedRadio === 'custom_page' && (
166
+ <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
167
+ validator={(_, value) =>
168
+ {
169
+ try
170
+ {
171
+ this.parseCustomPage(value);
172
+ return null;
173
+ } catch (error: any)
174
+ {
175
+ return error.message;
176
+ }
177
+ }} />
178
+ )}
179
+ <NSSpace size={NSSpaceSizeType.SMALL} />
180
+ <NSButtonBlue
181
+ style={{ width: "100%" }}
182
+ title='Apply'
183
+ onClick={{
184
+ action: async (onFinished) =>
185
+ {
186
+ try
187
+ {
188
+ let items: RowType[] = [];
189
+ if (this.NSBoxBoolean_CurrentPage.current?.getValue())
190
+ {
191
+ let is = await this.props.getItems(this.props.current_page, this.props.current_size, false);
192
+ items.push(...is);
193
+ }
194
+ else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
195
+ {
196
+ let is = await this.props.getItems(this.props.current_page, this.props.current_size, true);
197
+ items.push(...is);
198
+ }
199
+ else if (this.NSBoxBoolean_CustomPage.current?.getValue())
200
+ {
201
+ let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
202
+ let pages = this.parseCustomPage(pages_value);
203
+
204
+ for (let p = 0; p < pages.length; p++)
205
+ {
206
+ let is = await this.props.getItems(pages[p], this.props.current_size, false);
207
+ items.push(...is);
208
+ }
209
+ }
210
+ else if (this.NSBoxBoolean_AllPage.current?.getValue())
211
+ {
212
+ for (let p = 1; p <= this.props.max_page; p++)
213
+ {
214
+ let is = await this.props.getItems(p, this.props.current_size, false);
215
+ items.push(...is);
216
+ }
217
+ }
218
+ else
219
+ { }
220
+ await this.props.onFinish(items);
221
+ } catch (error)
222
+ {
223
+ }
224
+ onFinished();
225
+ }
226
+ }} />
227
+ </div>
228
+ </div>
229
+ <div className={Styles.ns_toast_background}></div>
230
+ </>
231
+ }
232
+ </>
233
+ );
234
+ }
235
235
  }