namirasoft-site-react 1.4.166 → 1.4.167

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 (377) 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.css +34 -0
  6. package/dist/App.js +4 -36
  7. package/dist/App.js.map +1 -1
  8. package/dist/NSBoxBuilder.d.ts +2 -0
  9. package/dist/NSBoxBuilder.js +78 -71
  10. package/dist/NSBoxBuilder.js.map +1 -1
  11. package/dist/Validator.js +3 -3
  12. package/dist/Validator.js.map +1 -1
  13. package/dist/components/NSBarAction.module.css +82 -82
  14. package/dist/components/NSBarAlert.module.css +79 -79
  15. package/dist/components/NSBarNotification.module.css +34 -34
  16. package/dist/components/NSBarTitle.module.css +9 -9
  17. package/dist/components/NSBox.module.css +50 -50
  18. package/dist/components/NSBoxBaseCombo.js +11 -13
  19. package/dist/components/NSBoxBaseCombo.js.map +1 -1
  20. package/dist/components/NSBoxBaseCombo.module.css +6 -6
  21. package/dist/components/NSBoxBaseLayout.d.ts +2 -3
  22. package/dist/components/NSBoxBaseLayout.js +3 -2
  23. package/dist/components/NSBoxBaseLayout.js.map +1 -1
  24. package/dist/components/NSBoxBaseLayoutRecursive.d.ts +13 -0
  25. package/dist/components/NSBoxBaseLayoutRecursive.js +38 -0
  26. package/dist/components/NSBoxBaseLayoutRecursive.js.map +1 -0
  27. package/dist/components/NSBoxBoolean.js +6 -8
  28. package/dist/components/NSBoxBoolean.js.map +1 -1
  29. package/dist/components/NSBoxBoolean.module.css +67 -67
  30. package/dist/components/NSBoxBooleans.js +3 -4
  31. package/dist/components/NSBoxBooleans.js.map +1 -1
  32. package/dist/components/NSBoxColor.js +5 -6
  33. package/dist/components/NSBoxColor.js.map +1 -1
  34. package/dist/components/NSBoxCombo.js +5 -5
  35. package/dist/components/NSBoxCombo.js.map +1 -1
  36. package/dist/components/NSBoxDate.js +5 -6
  37. package/dist/components/NSBoxDate.js.map +1 -1
  38. package/dist/components/NSBoxDate.module.css +4 -4
  39. package/dist/components/NSBoxDateTime.js +5 -6
  40. package/dist/components/NSBoxDateTime.js.map +1 -1
  41. package/dist/components/NSBoxDateTime.module.css +4 -4
  42. package/dist/components/NSBoxDouble.js +5 -6
  43. package/dist/components/NSBoxDouble.js.map +1 -1
  44. package/dist/components/NSBoxDuration.js +5 -6
  45. package/dist/components/NSBoxDuration.js.map +1 -1
  46. package/dist/components/NSBoxDuration.module.css +4 -4
  47. package/dist/components/NSBoxDynamic.d.ts +0 -1
  48. package/dist/components/NSBoxDynamic.js.map +1 -1
  49. package/dist/components/NSBoxEmail.js +6 -5
  50. package/dist/components/NSBoxEmail.js.map +1 -1
  51. package/dist/components/NSBoxEntity.js +5 -5
  52. package/dist/components/NSBoxEntity.js.map +1 -1
  53. package/dist/components/NSBoxEnum.js +9 -5
  54. package/dist/components/NSBoxEnum.js.map +1 -1
  55. package/dist/components/NSBoxFile.js +1 -3
  56. package/dist/components/NSBoxFile.js.map +1 -1
  57. package/dist/components/NSBoxFile.module.css +10 -10
  58. package/dist/components/NSBoxFilePath.js +5 -6
  59. package/dist/components/NSBoxFilePath.js.map +1 -1
  60. package/dist/components/NSBoxFont.js +5 -6
  61. package/dist/components/NSBoxFont.js.map +1 -1
  62. package/dist/components/NSBoxIPV4.js +5 -6
  63. package/dist/components/NSBoxIPV4.js.map +1 -1
  64. package/dist/components/NSBoxIPV4Range.js +5 -6
  65. package/dist/components/NSBoxIPV4Range.js.map +1 -1
  66. package/dist/components/NSBoxIPV6.js +5 -6
  67. package/dist/components/NSBoxIPV6.js.map +1 -1
  68. package/dist/components/NSBoxIPV6Range.js +5 -6
  69. package/dist/components/NSBoxIPV6Range.js.map +1 -1
  70. package/dist/components/NSBoxInteger.js +5 -6
  71. package/dist/components/NSBoxInteger.js.map +1 -1
  72. package/dist/components/NSBoxMoney.d.ts +3 -3
  73. package/dist/components/NSBoxMoney.js +8 -8
  74. package/dist/components/NSBoxMoney.js.map +1 -1
  75. package/dist/components/NSBoxPassword.js +4 -7
  76. package/dist/components/NSBoxPassword.js.map +1 -1
  77. package/dist/components/NSBoxPhone.js +5 -6
  78. package/dist/components/NSBoxPhone.js.map +1 -1
  79. package/dist/components/NSBoxPhone.module.css +35 -35
  80. package/dist/components/NSBoxRadio.js +6 -8
  81. package/dist/components/NSBoxRadio.js.map +1 -1
  82. package/dist/components/NSBoxRadio.module.css +33 -33
  83. package/dist/components/NSBoxSchemaBase.d.ts +39 -0
  84. package/dist/components/NSBoxSchemaBase.js +327 -0
  85. package/dist/components/NSBoxSchemaBase.js.map +1 -0
  86. package/dist/components/NSBoxSchemaBase.module.css +18 -0
  87. package/dist/components/NSBoxSchemaVariable.d.ts +32 -0
  88. package/dist/components/NSBoxSchemaVariable.js +127 -0
  89. package/dist/components/NSBoxSchemaVariable.js.map +1 -0
  90. package/dist/components/NSBoxSchemaVariable.module.css +17 -0
  91. package/dist/components/NSBoxSearch.js +8 -5
  92. package/dist/components/NSBoxSearch.js.map +1 -1
  93. package/dist/components/NSBoxString.js +8 -5
  94. package/dist/components/NSBoxString.js.map +1 -1
  95. package/dist/components/NSBoxTextArea.js +8 -5
  96. package/dist/components/NSBoxTextArea.js.map +1 -1
  97. package/dist/components/NSBoxTextArea.module.css +12 -12
  98. package/dist/components/NSBoxTime.js +5 -6
  99. package/dist/components/NSBoxTime.js.map +1 -1
  100. package/dist/components/NSBoxTime.module.css +4 -4
  101. package/dist/components/NSBoxTimeZone.js +5 -6
  102. package/dist/components/NSBoxTimeZone.js.map +1 -1
  103. package/dist/components/NSBoxURL.js +6 -6
  104. package/dist/components/NSBoxURL.js.map +1 -1
  105. package/dist/components/NSBoxVersion.js +5 -6
  106. package/dist/components/NSBoxVersion.js.map +1 -1
  107. package/dist/components/NSButton.module.css +57 -57
  108. package/dist/components/NSButtonBlue.module.css +4 -4
  109. package/dist/components/NSButtonGreen.module.css +4 -4
  110. package/dist/components/NSButtonRed.module.css +4 -4
  111. package/dist/components/NSCard.module.css +114 -114
  112. package/dist/components/NSCardScreenshot.module.css +41 -41
  113. package/dist/components/NSChartColumn.module.css +7 -7
  114. package/dist/components/NSChartTable.module.css +21 -21
  115. package/dist/components/NSColumn.module.css +16 -16
  116. package/dist/components/NSCopyBox.module.css +39 -39
  117. package/dist/components/NSDialog.module.css +111 -110
  118. package/dist/components/NSDialogPageSelection.module.css +103 -103
  119. package/dist/components/NSDownTimer.module.css +55 -55
  120. package/dist/components/NSDownload.module.css +46 -46
  121. package/dist/components/NSElectronicCard.module.css +60 -60
  122. package/dist/components/NSEntityCardBackground.module.css +27 -27
  123. package/dist/components/NSFilterBox.module.css +56 -56
  124. package/dist/components/NSFilterItem.module.css +25 -25
  125. package/dist/components/NSFooter.module.css +123 -123
  126. package/dist/components/NSHeader.module.css +291 -291
  127. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  128. package/dist/components/NSLabel.module.css +15 -15
  129. package/dist/components/NSLabelErrorNotifier.module.css +2 -2
  130. package/dist/components/NSLayout.module.css +14 -14
  131. package/dist/components/NSLine.js.map +1 -1
  132. package/dist/components/NSLine.module.css +13 -12
  133. package/dist/components/NSLink.module.css +36 -36
  134. package/dist/components/NSListGrouped.module.css +69 -69
  135. package/dist/components/NSLoading.module.css +30 -30
  136. package/dist/components/NSMenuAction.js +2 -2
  137. package/dist/components/NSMenuAction.module.css +87 -87
  138. package/dist/components/NSMenuButton.d.ts +10 -5
  139. package/dist/components/NSMenuButton.js +13 -12
  140. package/dist/components/NSMenuButton.js.map +1 -1
  141. package/dist/components/NSMenuButton.module.css +44 -44
  142. package/dist/components/NSNoData.module.css +9 -9
  143. package/dist/components/NSPagination.module.css +85 -85
  144. package/dist/components/NSPanel.module.css +19 -18
  145. package/dist/components/NSPanelAccordion.module.css +4 -4
  146. package/dist/components/NSRange.module.css +66 -66
  147. package/dist/components/NSRepeater.d.ts +8 -6
  148. package/dist/components/NSRepeater.js +21 -14
  149. package/dist/components/NSRepeater.js.map +1 -1
  150. package/dist/components/NSRepeaterNSBoxSchemaVariable.d.ts +23 -0
  151. package/dist/components/NSRepeaterNSBoxSchemaVariable.js +50 -0
  152. package/dist/components/NSRepeaterNSBoxSchemaVariable.js.map +1 -0
  153. package/dist/components/NSRow.module.css +17 -17
  154. package/dist/components/NSSection.module.css +4 -4
  155. package/dist/components/NSSectionCards.module.css +38 -38
  156. package/dist/components/NSSectionTiles.module.css +10 -10
  157. package/dist/components/NSTabPage.module.css +59 -59
  158. package/dist/components/NSTable.module.css +263 -263
  159. package/dist/components/NSTag.module.css +52 -52
  160. package/dist/components/NSTile.module.css +76 -76
  161. package/dist/components/NSTimelineMonthly.module.css +71 -71
  162. package/dist/components/NSTitle.module.css +15 -15
  163. package/dist/index.css +6 -0
  164. package/dist/pages/NSNotFoundPage.module.css +17 -17
  165. package/dist/pages/NSUpdating.module.css +35 -35
  166. package/package.json +76 -76
  167. package/public/index.html +38 -38
  168. package/src/App.css +33 -33
  169. package/src/App.tsx +54 -107
  170. package/src/Color.tsx +10 -10
  171. package/src/CopyToClipboard.ts +6 -6
  172. package/src/NSBoxBuilder.tsx +849 -828
  173. package/src/Validator.ts +147 -147
  174. package/src/components/INSBox.tsx +6 -6
  175. package/src/components/NSBarAction.module.css +82 -82
  176. package/src/components/NSBarAction.tsx +85 -85
  177. package/src/components/NSBarAlert.module.css +79 -79
  178. package/src/components/NSBarAlert.tsx +31 -31
  179. package/src/components/NSBarNotification.module.css +34 -34
  180. package/src/components/NSBarNotification.tsx +89 -89
  181. package/src/components/NSBarTitle.module.css +9 -9
  182. package/src/components/NSBarTitle.tsx +29 -29
  183. package/src/components/NSBox.module.css +50 -50
  184. package/src/components/NSBox.tsx +19 -19
  185. package/src/components/NSBoxBaseCombo.module.css +6 -6
  186. package/src/components/NSBoxBaseCombo.tsx +298 -305
  187. package/src/components/NSBoxBaseLayout.tsx +79 -83
  188. package/src/components/NSBoxBaseLayoutRecursive.tsx +55 -0
  189. package/src/components/NSBoxBoolean.module.css +67 -67
  190. package/src/components/NSBoxBoolean.tsx +114 -120
  191. package/src/components/NSBoxBooleans.tsx +161 -163
  192. package/src/components/NSBoxColor.tsx +87 -91
  193. package/src/components/NSBoxCombo.tsx +84 -86
  194. package/src/components/NSBoxDate.module.css +4 -4
  195. package/src/components/NSBoxDate.tsx +101 -105
  196. package/src/components/NSBoxDateTime.module.css +4 -4
  197. package/src/components/NSBoxDateTime.tsx +102 -106
  198. package/src/components/NSBoxDouble.tsx +91 -95
  199. package/src/components/NSBoxDuration.module.css +4 -4
  200. package/src/components/NSBoxDuration.tsx +92 -96
  201. package/src/components/NSBoxDynamic.tsx +55 -56
  202. package/src/components/NSBoxEmail.tsx +96 -98
  203. package/src/components/NSBoxEntity.tsx +73 -75
  204. package/src/components/NSBoxEnum.tsx +101 -99
  205. package/src/components/NSBoxFile.module.css +10 -10
  206. package/src/components/NSBoxFile.tsx +101 -105
  207. package/src/components/NSBoxFilePath.tsx +87 -91
  208. package/src/components/NSBoxFont.tsx +87 -91
  209. package/src/components/NSBoxIPV4.tsx +92 -96
  210. package/src/components/NSBoxIPV4Range.tsx +87 -91
  211. package/src/components/NSBoxIPV6.tsx +89 -93
  212. package/src/components/NSBoxIPV6Range.tsx +87 -91
  213. package/src/components/NSBoxInteger.tsx +89 -93
  214. package/src/components/NSBoxMoney.tsx +92 -96
  215. package/src/components/NSBoxPassword.tsx +103 -109
  216. package/src/components/NSBoxPhone.module.css +35 -35
  217. package/src/components/NSBoxPhone.tsx +107 -112
  218. package/src/components/NSBoxRadio.module.css +33 -33
  219. package/src/components/NSBoxRadio.tsx +89 -95
  220. package/src/components/NSBoxSchemaBase.module.css +18 -0
  221. package/src/components/NSBoxSchemaBase.tsx +523 -0
  222. package/src/components/NSBoxSchemaVariable.module.css +17 -0
  223. package/src/components/NSBoxSchemaVariable.tsx +247 -0
  224. package/src/components/NSBoxSearch.tsx +95 -93
  225. package/src/components/NSBoxString.tsx +88 -86
  226. package/src/components/NSBoxTextArea.module.css +12 -12
  227. package/src/components/NSBoxTextArea.tsx +96 -94
  228. package/src/components/NSBoxTime.module.css +4 -4
  229. package/src/components/NSBoxTime.tsx +90 -93
  230. package/src/components/NSBoxTimeZone.tsx +87 -91
  231. package/src/components/NSBoxURL.tsx +88 -91
  232. package/src/components/NSBoxVersion.tsx +87 -91
  233. package/src/components/NSButton.module.css +57 -57
  234. package/src/components/NSButton.tsx +25 -25
  235. package/src/components/NSButtonBlue.module.css +4 -4
  236. package/src/components/NSButtonBlue.tsx +19 -19
  237. package/src/components/NSButtonGreen.module.css +4 -4
  238. package/src/components/NSButtonGreen.tsx +19 -19
  239. package/src/components/NSButtonRed.module.css +4 -4
  240. package/src/components/NSButtonRed.tsx +19 -19
  241. package/src/components/NSCard.module.css +114 -114
  242. package/src/components/NSCard.tsx +63 -63
  243. package/src/components/NSCardScreenshot.module.css +41 -41
  244. package/src/components/NSCardScreenshot.tsx +31 -31
  245. package/src/components/NSChartColumn.module.css +7 -7
  246. package/src/components/NSChartColumn.tsx +106 -106
  247. package/src/components/NSChartDoughnut.tsx +108 -108
  248. package/src/components/NSChartPie.tsx +105 -105
  249. package/src/components/NSChartRange.tsx +14 -14
  250. package/src/components/NSChartTable.module.css +21 -21
  251. package/src/components/NSChartTable.tsx +94 -94
  252. package/src/components/NSColumn.module.css +16 -16
  253. package/src/components/NSColumn.tsx +18 -18
  254. package/src/components/NSCopy.tsx +56 -56
  255. package/src/components/NSCopyBox.module.css +39 -39
  256. package/src/components/NSCopyBox.tsx +53 -53
  257. package/src/components/NSDialog.module.css +111 -110
  258. package/src/components/NSDialog.tsx +61 -61
  259. package/src/components/NSDialogDelete.tsx +26 -26
  260. package/src/components/NSDialogInfo.tsx +32 -32
  261. package/src/components/NSDialogPageSelection.module.css +103 -103
  262. package/src/components/NSDialogPageSelection.tsx +223 -223
  263. package/src/components/NSDownTimer.module.css +55 -55
  264. package/src/components/NSDownTimer.tsx +77 -77
  265. package/src/components/NSDownload.module.css +46 -46
  266. package/src/components/NSDownload.tsx +63 -63
  267. package/src/components/NSElectronicCard.module.css +60 -60
  268. package/src/components/NSElectronicCard.tsx +46 -46
  269. package/src/components/NSEntityCardBackground.module.css +27 -27
  270. package/src/components/NSEntityCardBackground.tsx +36 -36
  271. package/src/components/NSFilterBox.module.css +56 -56
  272. package/src/components/NSFilterBox.tsx +366 -366
  273. package/src/components/NSFilterItem.module.css +25 -25
  274. package/src/components/NSFilterItem.tsx +27 -27
  275. package/src/components/NSFooter.module.css +123 -123
  276. package/src/components/NSFooter.tsx +316 -316
  277. package/src/components/NSHeader.module.css +291 -291
  278. package/src/components/NSHeader.tsx +253 -253
  279. package/src/components/NSHeaderScreenshot.module.css +35 -35
  280. package/src/components/NSHeaderScreenshot.tsx +39 -39
  281. package/src/components/NSLabel.module.css +15 -15
  282. package/src/components/NSLabel.tsx +29 -29
  283. package/src/components/NSLabelErrorNotifier.module.css +2 -2
  284. package/src/components/NSLabelErrorNotifier.tsx +32 -32
  285. package/src/components/NSLayout.module.css +14 -14
  286. package/src/components/NSLayout.tsx +94 -94
  287. package/src/components/NSLine.module.css +13 -12
  288. package/src/components/NSLine.tsx +13 -15
  289. package/src/components/NSLink.module.css +36 -36
  290. package/src/components/NSLink.tsx +25 -25
  291. package/src/components/NSLinkBlue.tsx +21 -21
  292. package/src/components/NSLinkGreen.tsx +5 -5
  293. package/src/components/NSLinkRed.tsx +5 -5
  294. package/src/components/NSListGrouped.module.css +69 -69
  295. package/src/components/NSListGrouped.tsx +119 -119
  296. package/src/components/NSListProduct.tsx +44 -44
  297. package/src/components/NSLoading.module.css +30 -30
  298. package/src/components/NSLoading.tsx +19 -19
  299. package/src/components/NSMenuAction.module.css +87 -87
  300. package/src/components/NSMenuAction.tsx +90 -90
  301. package/src/components/NSMenuButton.module.css +44 -44
  302. package/src/components/NSMenuButton.tsx +177 -172
  303. package/src/components/NSNoData.module.css +9 -9
  304. package/src/components/NSNoData.tsx +24 -24
  305. package/src/components/NSPagination.module.css +85 -85
  306. package/src/components/NSPagination.tsx +182 -182
  307. package/src/components/NSPanel.module.css +19 -18
  308. package/src/components/NSPanel.tsx +18 -18
  309. package/src/components/NSPanelAccordion.module.css +4 -4
  310. package/src/components/NSPanelAccordion.tsx +51 -51
  311. package/src/components/NSRange.module.css +66 -66
  312. package/src/components/NSRange.tsx +83 -83
  313. package/src/components/NSRepeater.tsx +223 -217
  314. package/src/components/NSRepeaterNSBoxSchemaVariable.tsx +90 -0
  315. package/src/components/NSRow.module.css +17 -17
  316. package/src/components/NSRow.tsx +18 -18
  317. package/src/components/NSSection.module.css +4 -4
  318. package/src/components/NSSection.tsx +20 -20
  319. package/src/components/NSSectionCards.module.css +38 -38
  320. package/src/components/NSSectionCards.tsx +51 -51
  321. package/src/components/NSSectionTiles.module.css +10 -10
  322. package/src/components/NSSectionTiles.tsx +25 -25
  323. package/src/components/NSSectionTitle.tsx +21 -21
  324. package/src/components/NSSpace.tsx +28 -28
  325. package/src/components/NSTabPage.module.css +59 -59
  326. package/src/components/NSTabPage.tsx +77 -77
  327. package/src/components/NSTable.module.css +263 -263
  328. package/src/components/NSTable.tsx +479 -479
  329. package/src/components/NSTag.module.css +52 -52
  330. package/src/components/NSTag.tsx +78 -78
  331. package/src/components/NSTile.module.css +76 -76
  332. package/src/components/NSTile.tsx +27 -27
  333. package/src/components/NSTimelineMonthly.module.css +71 -71
  334. package/src/components/NSTimelineMonthly.tsx +44 -44
  335. package/src/components/NSTitle.module.css +15 -15
  336. package/src/components/NSTitle.tsx +19 -19
  337. package/src/formatter/BackColorFormatter.tsx +23 -23
  338. package/src/formatter/BaseColumnFormatter.ts +16 -16
  339. package/src/formatter/BooleanFormatter.ts +22 -22
  340. package/src/formatter/DateFormatter.ts +20 -20
  341. package/src/formatter/DateTimeFormatter.ts +20 -20
  342. package/src/formatter/DurationFormatter.ts +13 -13
  343. package/src/formatter/EmailFormatter.ts +13 -13
  344. package/src/formatter/EnumFormatter.ts +13 -13
  345. package/src/formatter/FloatFormatter.ts +16 -16
  346. package/src/formatter/ForeColorFormatter.tsx +24 -24
  347. package/src/formatter/IDFormatter.tsx +30 -30
  348. package/src/formatter/IPFormatter.ts +13 -13
  349. package/src/formatter/IntegerFormatter.ts +16 -16
  350. package/src/formatter/JsonFormatter.ts +14 -14
  351. package/src/formatter/MoneyFormatter.ts +16 -16
  352. package/src/formatter/PhoneFormatter.ts +13 -13
  353. package/src/formatter/StringFormatter.ts +22 -22
  354. package/src/formatter/TimeFormatter.ts +21 -21
  355. package/src/formatter/UnknowFormatter.ts +18 -18
  356. package/src/index.tsx +7 -7
  357. package/src/main.ts +193 -193
  358. package/src/pages/NSNotFoundPage.module.css +17 -17
  359. package/src/pages/NSNotFoundPage.tsx +11 -11
  360. package/src/pages/NSUpdating.module.css +35 -35
  361. package/src/pages/NSUpdating.tsx +32 -32
  362. package/src/props/IBaseComponentProps.ts +8 -8
  363. package/src/props/IHeaderIconProps.ts +10 -10
  364. package/src/props/IHeaderProps.ts +7 -7
  365. package/src/props/IImageProps.ts +4 -4
  366. package/src/props/ILinkProps.ts +5 -5
  367. package/src/props/IValidationNumberProps.ts +4 -4
  368. package/src/props/IValidationPrecisionProps.ts +3 -3
  369. package/src/props/IValidationProps.ts +9 -9
  370. package/src/props/IValidationRegexProps.ts +4 -4
  371. package/src/props/IValidationStringProps.ts +4 -4
  372. package/src/routing/INSRouterMaker.ts +6 -6
  373. package/src/routing/INSRouterProps.ts +5 -5
  374. package/src/routing/INSRouterState.ts +5 -5
  375. package/src/routing/NSRouterMaker.tsx +33 -33
  376. package/src/routing/Notifier.ts +79 -79
  377. package/tsconfig.json +43 -43
@@ -0,0 +1,523 @@
1
+ "use client";
2
+
3
+ import Styles from "./NSBoxSchemaBase.module.css";
4
+
5
+ import React, { createRef } from "react";
6
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
+ import { IValidationProps } from "../props/IValidationProps";
8
+ import { IValidationStringProps } from "../props/IValidationStringProps";
9
+ import { safeMenuMenuItem } from "./NSMenuButton";
10
+ import { INSBoxBaseLayoutProps } from "./NSBoxBaseLayout";
11
+ import { INSBox } from "./INSBox";
12
+ import { NSBoxEnum } from "./NSBoxEnum";
13
+ import { AnySchema, ArraySchema, BaseNumberSchema, BasePrecisionSchema, BaseTypeSchema, BaseVariableSchema, BigIntSchema, BoolSchema, ColorSchema, DateSchema, DateTimeSchema, DecimalSchema, DoubleSchema, DurationSchema, EmailSchema, EntitySchema, EnumSchema, FilePathSchema, FloatSchema, FontSchema, IntegerSchema, IPV4RangeSchema, IPV4Schema, IPV6RangeSchema, IPV6Schema, MediumIntSchema, MoneySchema, ObjectSchema, PhoneSchema, RealSchema, SmallIntSchema, StringSchema, TimeSchema, TimeZoneSchema, TinyIntSchema, URLSchema, VariableType, VersionSchema } from "namirasoft-schema";
14
+ import { NSBoxBoolean } from "./NSBoxBoolean";
15
+ import { NSRow } from "./NSRow";
16
+ import { NSBoxString } from "./NSBoxString";
17
+ import { NSBoxInteger } from "./NSBoxInteger";
18
+ import { NSBoxBaseLayoutRecursive } from "./NSBoxBaseLayoutRecursive";
19
+ import { NSRepeaterNSBoxSchemaVariable } from "./NSRepeaterNSBoxSchemaVariable";
20
+ import { NSColumn } from "./NSColumn";
21
+
22
+ export interface NSBoxSchemaBaseProps extends IBaseComponentProps, IValidationProps, IValidationStringProps, INSBoxBaseLayoutProps<string, NSBoxSchemaBase>
23
+ {
24
+ depth?: number;
25
+ }
26
+
27
+ export interface NSBoxSchemaBaseState
28
+ {
29
+ type: VariableType | null;
30
+ show_details: boolean;
31
+ }
32
+
33
+ export class NSBoxSchemaBase extends React.Component<NSBoxSchemaBaseProps, NSBoxSchemaBaseState> implements INSBox
34
+ {
35
+ private NSBoxEnum_Type = createRef<NSBoxEnum<VariableType>>();
36
+ private NSBoxString_Name = createRef<NSBoxString>();
37
+ private NSBoxBoolean_Required = createRef<NSBoxBoolean>();
38
+ private NSBoxSchemaBase_ArraySchema = createRef<NSBoxSchemaBase>();
39
+ private NSRepeaterNSBoxSchemaVariable_ObjectFields = createRef<NSRepeaterNSBoxSchemaVariable>();
40
+ private NSBoxInteger_Min = createRef<NSBoxInteger>();
41
+ private NSBoxInteger_Max = createRef<NSBoxInteger>();
42
+ private NSBoxInteger_Precision = createRef<NSBoxInteger>();
43
+ private NSBoxInteger_MinLength = createRef<NSBoxInteger>();
44
+ private NSBoxInteger_MaxLength = createRef<NSBoxInteger>();
45
+ private NSBoxString_Regex = createRef<NSBoxString>();
46
+ private NSBoxString_ValidList = createRef<NSBoxString>();
47
+ private NSBoxString_InalidList = createRef<NSBoxString>();
48
+ private NSBoxString_PlaceHolder = createRef<NSBoxString>();
49
+ NSBoxBaseLayoutRecursive_Main = createRef<NSBoxBaseLayoutRecursive>();
50
+ constructor(props: NSBoxSchemaBaseProps)
51
+ {
52
+ super(props);
53
+ this.state = {
54
+ type: null,
55
+ show_details: false,
56
+ };
57
+ this.isEmpty = this.isEmpty.bind(this);
58
+ this.getError = this.getError.bind(this);
59
+ this.getValue = this.getValue.bind(this);
60
+ this.setValue = this.setValue.bind(this);
61
+ this.onChanged = this.onChanged.bind(this);
62
+ }
63
+ isEmpty(value: BaseTypeSchema | null): boolean
64
+ {
65
+ if (value)
66
+ if (value.type || value.example || value.valids?.length > 0 || value.invalids?.length > 0)
67
+ return false;
68
+ return true;
69
+ }
70
+ getError(): string | null
71
+ {
72
+ return null;
73
+ // let ans = this.NSBoxEnum_Type.current?.getError() ||
74
+ // this.NSBoxString_Name.current?.getError() ||
75
+ // this.NSBoxBoolean_Required.current?.getError() ||
76
+ // this.NSBoxSchemaBase_ArraySchema.current?.getError() ||
77
+ // this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.getError() ||
78
+ // this.NSBoxInteger_Min.current?.getError() ||
79
+ // this.NSBoxInteger_Max.current?.getError() ||
80
+ // this.NSBoxInteger_Precision.current?.getError() ||
81
+ // this.NSBoxInteger_MinLength.current?.getError() ||
82
+ // this.NSBoxInteger_MaxLength.current?.getError() ||
83
+ // this.NSBoxString_Regex.current?.getError() ||
84
+ // this.NSBoxString_ValidList.current?.getError() ||
85
+ // this.NSBoxString_InalidList.current?.getError() ||
86
+ // this.NSBoxString_PlaceHolder.current?.getError();
87
+ // return ans ?? null;
88
+ }
89
+ getValue(checkError: boolean = true): BaseTypeSchema | null
90
+ {
91
+ return NSBoxBaseLayoutRecursive.checkGetValue(this, checkError, () =>
92
+ {
93
+ let type = this.NSBoxEnum_Type.current?.getValueEnumOne(VariableType, VariableType.Any, checkError) ?? null;
94
+ let required = this.NSBoxBoolean_Required.current?.getValueBool(checkError) ?? false;
95
+
96
+ let name = this.NSBoxString_Name.current?.getValue(checkError) ?? null;
97
+ let min = this.NSBoxInteger_Min.current?.getValue(checkError) ?? null;
98
+ let max = this.NSBoxInteger_Max.current?.getValue(checkError) ?? null;
99
+ let precision = this.NSBoxInteger_Precision.current?.getValue(checkError) ?? null;
100
+ let min_length = this.NSBoxInteger_MinLength.current?.getValue(checkError) ?? null;
101
+ let max_length = this.NSBoxInteger_MaxLength.current?.getValue(checkError) ?? null;
102
+ let regex = this.NSBoxString_Regex.current?.getValue(checkError) ?? null;
103
+ let schema = this.NSBoxSchemaBase_ArraySchema.current?.getValue(checkError) ?? null;
104
+ let fields = this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.getValue(checkError) ?? null;
105
+ let valid_list = this.NSBoxString_ValidList.current?.getValue(checkError)?.split(",") ?? [];
106
+ let invlid_list = this.NSBoxString_InalidList.current?.getValue(checkError)?.split(",") ?? [];
107
+ let place_holder = this.NSBoxString_PlaceHolder.current?.getValue(checkError) ?? undefined;
108
+ let enum_object: { [name: string]: string } = {};
109
+ invlid_list.forEach((v) => enum_object[v] = v);
110
+
111
+ let ans = null;
112
+ if (type)
113
+ {
114
+ switch (type)
115
+ {
116
+ case VariableType.Boolean:
117
+ ans = new BoolSchema(required);
118
+ break;
119
+ case VariableType.TinyInt:
120
+ ans = new TinyIntSchema(required, max, min);
121
+ break;
122
+ case VariableType.SmallInt:
123
+ ans = new SmallIntSchema(required, max, min);
124
+ break;
125
+ case VariableType.MediumInt:
126
+ ans = new MediumIntSchema(required, max, min);
127
+ break;
128
+ case VariableType.Integer:
129
+ ans = new IntegerSchema(required, max, min);
130
+ break;
131
+ case VariableType.BigInt:
132
+ ans = new BigIntSchema(required, max, min);
133
+ break;
134
+ case VariableType.Float:
135
+ ans = new FloatSchema(required, max, min, precision);
136
+ break;
137
+ case VariableType.Double:
138
+ ans = new DoubleSchema(required, max, min, precision);
139
+ break;
140
+ case VariableType.Decimal:
141
+ ans = new DecimalSchema(required, max, min, precision);
142
+ break;
143
+ case VariableType.Real:
144
+ ans = new RealSchema(required, max, min, precision);
145
+ break;
146
+ case VariableType.Money:
147
+ ans = new MoneySchema(required, max, min);
148
+ break;
149
+ case VariableType.String:
150
+ ans = new StringSchema(required, min_length, max_length);
151
+ if (regex)
152
+ ans.regex = new RegExp(regex);
153
+ break;
154
+ case VariableType.Date:
155
+ ans = new DateSchema(required);
156
+ break;
157
+ case VariableType.Time:
158
+ ans = new TimeSchema(required);
159
+ break;
160
+ case VariableType.DateTime:
161
+ ans = new DateTimeSchema(required);
162
+ break;
163
+ case VariableType.TimeZone:
164
+ ans = new TimeZoneSchema(required);
165
+ break;
166
+ case VariableType.Duration:
167
+ ans = new DurationSchema(required);
168
+ break;
169
+ case VariableType.Email:
170
+ ans = new EmailSchema(required);
171
+ break;
172
+ case VariableType.Phone:
173
+ ans = new PhoneSchema(required);
174
+ break;
175
+ case VariableType.Version:
176
+ ans = new VersionSchema(required);
177
+ break;
178
+ case VariableType.IPV4:
179
+ ans = new IPV4Schema(required);
180
+ break;
181
+ case VariableType.IPV6:
182
+ ans = new IPV6Schema(required);
183
+ break;
184
+ case VariableType.IPV4Range:
185
+ ans = new IPV4RangeSchema(required);
186
+ break;
187
+ case VariableType.IPV6Range:
188
+ ans = new IPV6RangeSchema(required);
189
+ break;
190
+ case VariableType.Color:
191
+ ans = new ColorSchema(required);
192
+ break;
193
+ case VariableType.Font:
194
+ ans = new FontSchema(required);
195
+ break;
196
+ case VariableType.FilePath:
197
+ ans = new FilePathSchema(required);
198
+ break;
199
+ case VariableType.URL:
200
+ ans = new URLSchema(required);
201
+ break;
202
+ case VariableType.Enum:
203
+ ans = new EnumSchema(name ?? "", required, enum_object);
204
+ break;
205
+ case VariableType.Entity:
206
+ // todo VariableType.Entity
207
+ ans = new EntitySchema(required, "", "", "");
208
+ break;
209
+ case VariableType.Array:
210
+ if (schema)
211
+ ans = new ArraySchema(required, [schema], min, max);
212
+ break;
213
+ case VariableType.Object:
214
+ if (fields)
215
+ ans = new ObjectSchema(name ?? "", required, fields);
216
+ break;
217
+ case VariableType.Any:
218
+ ans = new AnySchema(required);
219
+ break;
220
+ }
221
+ if (ans)
222
+ {
223
+ ans.setValid(...valid_list);
224
+ ans.setInvalid(...invlid_list);
225
+ ans.example = place_holder;
226
+ }
227
+ }
228
+ return ans;
229
+ });
230
+ }
231
+ setValue(value: BaseTypeSchema | null, callback?: () => void): void
232
+ {
233
+ this.NSBoxEnum_Type.current?.setValue(value?.type ?? null, () =>
234
+ {
235
+ this.NSBoxBoolean_Required.current?.setValueBool(value?.required ?? false);
236
+
237
+ let name = null;
238
+ let min = null;
239
+ let max = null;
240
+ let precision = null;
241
+ let min_length = null;
242
+ let max_length = null;
243
+ let regex = null;
244
+ let array_schema = null;
245
+ let object_fields: BaseVariableSchema[] = [];
246
+ let valid_list = null;
247
+ let invlid_list = null;
248
+ let place_holder = null;
249
+
250
+ if (value?.type)
251
+ switch (value?.type)
252
+ {
253
+ case VariableType.Boolean:
254
+ break;
255
+ case VariableType.TinyInt:
256
+ case VariableType.SmallInt:
257
+ case VariableType.MediumInt:
258
+ case VariableType.Integer:
259
+ case VariableType.BigInt:
260
+ {
261
+ let schema = value as BaseNumberSchema;
262
+ min = schema.min;
263
+ max = schema.max;
264
+ break;
265
+ }
266
+ case VariableType.Float:
267
+ case VariableType.Double:
268
+ case VariableType.Decimal:
269
+ case VariableType.Real:
270
+ case VariableType.Money:
271
+ {
272
+ let schema = value as BasePrecisionSchema;
273
+ min = schema.min;
274
+ max = schema.max;
275
+ precision = schema.precision;
276
+ break;
277
+ }
278
+ case VariableType.String:
279
+ {
280
+ let schema = value as StringSchema;
281
+ min_length = schema.min_length;
282
+ max_length = schema.max_length;
283
+ if (schema.regex)
284
+ regex = schema.regex + "";
285
+ break;
286
+ }
287
+ case VariableType.Date:
288
+ case VariableType.Time:
289
+ case VariableType.DateTime:
290
+ case VariableType.TimeZone:
291
+ case VariableType.Duration:
292
+ case VariableType.Email:
293
+ case VariableType.Phone:
294
+ case VariableType.Version:
295
+ case VariableType.IPV4:
296
+ case VariableType.IPV6:
297
+ case VariableType.IPV4Range:
298
+ case VariableType.IPV6Range:
299
+ case VariableType.Color:
300
+ case VariableType.Font:
301
+ case VariableType.FilePath:
302
+ case VariableType.URL:
303
+ break;
304
+ case VariableType.Enum:
305
+ let schema = value as EnumSchema;
306
+ name = schema.name;
307
+ break;
308
+ case VariableType.Entity:
309
+ // todo VariableType.Entity
310
+ break;
311
+ case VariableType.Array:
312
+ {
313
+ let schema = value as ArraySchema;
314
+ if (schema.items.length > 0)
315
+ array_schema = schema.items[0];
316
+ break;
317
+ }
318
+ case VariableType.Object:
319
+ {
320
+ let schema = value as ObjectSchema;
321
+ name = schema.name;
322
+ object_fields = schema.fields ?? [];
323
+ break;
324
+ }
325
+ case VariableType.Any:
326
+ break;
327
+ }
328
+
329
+ this.NSBoxString_Name.current?.setValue(name);
330
+ this.NSBoxInteger_Min.current?.setValue(min);
331
+ this.NSBoxInteger_Max.current?.setValue(max);
332
+ this.NSBoxInteger_Precision.current?.setValue(precision);
333
+ this.NSBoxInteger_MinLength.current?.setValue(min_length);
334
+ this.NSBoxInteger_MaxLength.current?.setValue(max_length);
335
+ this.NSBoxString_Regex.current?.setValue(regex);
336
+ this.NSBoxSchemaBase_ArraySchema.current?.setValue(array_schema);
337
+ this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.setValue(object_fields);
338
+ this.NSBoxString_ValidList.current?.setValue(valid_list);
339
+ this.NSBoxString_InalidList.current?.setValue(invlid_list);
340
+ this.NSBoxString_PlaceHolder.current?.setValue(place_holder);
341
+
342
+ this.props.onChanged?.(this);
343
+ callback?.();
344
+ });
345
+ }
346
+ private onChanged()
347
+ {
348
+ this.props.onChanged?.(this);
349
+ }
350
+ override render()
351
+ {
352
+ let menu = safeMenuMenuItem(this.props, (items) =>
353
+ {
354
+ items.push({
355
+ title: "Show Detail",
356
+ icon: this.state.show_details ? "https://static.namirasoft.com/image/concept/close/blue.svg" : "https://static.namirasoft.com/image/concept/ellipsis/vertical-blue.svg",
357
+ onClick: () =>
358
+ {
359
+ this.setState({ show_details: !this.state.show_details })
360
+ }
361
+ });
362
+ });
363
+
364
+ let isNumber = this.state.type && [VariableType.TinyInt, VariableType.SmallInt, VariableType.MediumInt, VariableType.Integer, VariableType.BigInt, VariableType.Float, VariableType.Double, VariableType.Decimal, VariableType.Real, VariableType.Money, VariableType.Array].includes(this.state.type);
365
+ let isPrecision = this.state.type && [VariableType.Float, VariableType.Double, VariableType.Decimal, VariableType.Real, VariableType.Money].includes(this.state.type);
366
+ let hasName = this.state.type && [VariableType.Enum, VariableType.Object].includes(this.state.type);
367
+
368
+ return (
369
+ <NSBoxBaseLayoutRecursive
370
+ ref={this.NSBoxBaseLayoutRecursive_Main}
371
+ {...this.props}
372
+ depth={this.props.depth ?? 0}
373
+ menu={menu}
374
+ >
375
+ <NSRow
376
+ >
377
+ <NSBoxEnum<VariableType>
378
+ ref={this.NSBoxEnum_Type}
379
+ required
380
+ title="Type"
381
+ multiple={false}
382
+ getEnumObject={() => VariableType}
383
+ invalids={[VariableType.Any, ...(this.props.invalids ?? [])]}
384
+ onChanged={(b) =>
385
+ {
386
+ this.setState({ type: b.getValueEnumOne(VariableType, VariableType.Any) });
387
+ this.onChanged();
388
+ }}
389
+ classList={[Styles.ns_box_schema_base_type]}
390
+ />
391
+ {
392
+ hasName &&
393
+ <NSBoxString
394
+ ref={this.NSBoxString_Name}
395
+ required
396
+ title="Name"
397
+ classList={[Styles.ns_box_schema_base_name]}
398
+ />
399
+ }
400
+ <NSBoxBoolean
401
+ ref={this.NSBoxBoolean_Required}
402
+ required
403
+ title="Required"
404
+ onChanged={() => this.onChanged()}
405
+ classList={[hasName ? Styles.ns_box_schema_base_required_withname : Styles.ns_box_schema_base_required_withoutname]}
406
+ />
407
+ </NSRow>
408
+ {
409
+ this.state.type === VariableType.Array &&
410
+ <NSBoxSchemaBase
411
+ ref={this.NSBoxSchemaBase_ArraySchema}
412
+ required
413
+ title="Array Elements' Schema"
414
+ style={{ width: "100%" }}
415
+ invalids={[VariableType.Any, VariableType.Object, VariableType.Array]}
416
+ depth={(this.props.depth ?? 0) + 1}
417
+ />
418
+ }
419
+ {
420
+ this.state.type === VariableType.Object &&
421
+ <NSBoxBaseLayoutRecursive
422
+ required
423
+ depth={(this.props.depth ?? 0) + 1}
424
+ title="Fields"
425
+ style={{ width: "100%" }}
426
+ >
427
+ <NSRepeaterNSBoxSchemaVariable
428
+ ref={this.NSRepeaterNSBoxSchemaVariable_ObjectFields}
429
+ item_title="Field"
430
+ style={{ width: "100%" }}
431
+ />
432
+ </NSBoxBaseLayoutRecursive>
433
+ }
434
+ {
435
+ isNumber &&
436
+ <NSRow
437
+ style={{ display: this.state.show_details ? "" : "none", width: "100%", justifyContent: "left" }}
438
+ >
439
+ <NSBoxInteger
440
+ ref={this.NSBoxInteger_Min}
441
+ required={false}
442
+ title="Min"
443
+ style={{ minWidth: "150px", width: "150px" }}
444
+ />
445
+ <NSBoxInteger
446
+ ref={this.NSBoxInteger_Max}
447
+ required={false}
448
+ title="Max"
449
+ style={{ minWidth: "150px", width: "150px" }}
450
+ />
451
+ {
452
+ isPrecision &&
453
+ <NSBoxInteger
454
+ ref={this.NSBoxInteger_Precision}
455
+ required={false}
456
+ title="Precision"
457
+ style={{ minWidth: "150px", width: "150px" }}
458
+ />
459
+ }
460
+ </NSRow>
461
+ }
462
+ {
463
+ this.state.type === VariableType.String &&
464
+ <NSColumn
465
+ style={{ display: this.state.show_details ? "" : "none", width: "100%" }}
466
+ >
467
+ <NSRow
468
+ style={{ justifyContent: "left" }}
469
+ >
470
+ <NSBoxInteger
471
+ ref={this.NSBoxInteger_MinLength}
472
+ required={false}
473
+ title="Min Length"
474
+ style={{ minWidth: "150px", width: "150px" }}
475
+ />
476
+ <NSBoxInteger
477
+ ref={this.NSBoxInteger_MaxLength}
478
+ required={false}
479
+ title="Max Length"
480
+ style={{ minWidth: "150px", width: "150px" }}
481
+ />
482
+ </NSRow>
483
+ <NSBoxString
484
+ ref={this.NSBoxString_Regex}
485
+ required={false}
486
+ title="Regex"
487
+ style={{ width: "100%" }}
488
+ />
489
+ </NSColumn>
490
+ }
491
+ <div style={{ display: (this.state.type === VariableType.Enum || this.state.show_details) ? "" : "none", width: "100%" }}>
492
+ <NSBoxString
493
+ ref={this.NSBoxString_ValidList}
494
+ required={this.state.type === VariableType.Enum}
495
+ title="Valid List"
496
+ placeholder="Please enter valid list and sperate them via comma."
497
+ style={{ width: "100%" }}
498
+ onChanged={() => this.onChanged()}
499
+ />
500
+ </div>
501
+ <NSColumn
502
+ style={{ display: this.state.show_details ? "" : "none", width: "100%" }}
503
+ >
504
+ <NSBoxString
505
+ ref={this.NSBoxString_InalidList}
506
+ required={false}
507
+ title="Invalid List"
508
+ placeholder="Please enter invvalid list and sperate them via comma."
509
+ style={{ width: "100%" }}
510
+ onChanged={() => this.onChanged()}
511
+ />
512
+ <NSBoxString
513
+ ref={this.NSBoxString_PlaceHolder}
514
+ required={false}
515
+ title="Place Holder"
516
+ style={{ width: "100%" }}
517
+ onChanged={() => this.onChanged()}
518
+ />
519
+ </NSColumn>
520
+ </NSBoxBaseLayoutRecursive>
521
+ );
522
+ }
523
+ }
@@ -0,0 +1,17 @@
1
+ .ns_box_schema_variable_default {
2
+ flex-grow: 1;
3
+ }
4
+
5
+ @media only screen and (min-width: 768px) {
6
+ .ns_box_schema_variable_name {
7
+ width: 192px;
8
+ }
9
+
10
+ .ns_box_schema_variable_default {
11
+ width: 100px;
12
+ }
13
+
14
+ .ns_box_schema_variable_multiple {
15
+ width: 100px;
16
+ }
17
+ }