namirasoft-site-react 1.4.554 → 1.4.556

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 (472) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/SKILL.md +307 -307
  5. package/config-overrides.js +72 -72
  6. package/dist/App.d.ts +1 -1
  7. package/dist/NSBoxBuilder.d.ts +25 -25
  8. package/dist/components/NSBanner.d.ts +1 -1
  9. package/dist/components/NSBanner.module.css +47 -47
  10. package/dist/components/NSBarAction.d.ts +1 -1
  11. package/dist/components/NSBarAction.module.css +91 -91
  12. package/dist/components/NSBarAlert.d.ts +1 -1
  13. package/dist/components/NSBarAlert.module.css +79 -79
  14. package/dist/components/NSBarNotification.d.ts +1 -1
  15. package/dist/components/NSBarNotification.module.css +34 -34
  16. package/dist/components/NSBarTitle.d.ts +1 -1
  17. package/dist/components/NSBarTitle.module.css +9 -9
  18. package/dist/components/NSBox.module.css +87 -87
  19. package/dist/components/NSBoxBaseCombo.d.ts +1 -1
  20. package/dist/components/NSBoxBaseCombo.module.css +6 -6
  21. package/dist/components/NSBoxBaseLayout.d.ts +1 -1
  22. package/dist/components/NSBoxBaseLayoutRecursive.d.ts +1 -1
  23. package/dist/components/NSBoxBoolean.d.ts +1 -1
  24. package/dist/components/NSBoxBoolean.module.css +73 -73
  25. package/dist/components/NSBoxBooleans.d.ts +1 -1
  26. package/dist/components/NSBoxColor.d.ts +1 -1
  27. package/dist/components/NSBoxCombo.d.ts +1 -1
  28. package/dist/components/NSBoxDate.d.ts +1 -1
  29. package/dist/components/NSBoxDate.module.css +4 -4
  30. package/dist/components/NSBoxDateRange.d.ts +1 -1
  31. package/dist/components/NSBoxDateRangeBase.d.ts +1 -1
  32. package/dist/components/NSBoxDateRangeBase.module.css +73 -73
  33. package/dist/components/NSBoxDateTime.d.ts +1 -1
  34. package/dist/components/NSBoxDateTime.module.css +4 -4
  35. package/dist/components/NSBoxDateTimeRange.d.ts +1 -1
  36. package/dist/components/NSBoxDouble.d.ts +1 -1
  37. package/dist/components/NSBoxDuration.d.ts +1 -1
  38. package/dist/components/NSBoxDuration.module.css +4 -4
  39. package/dist/components/NSBoxDynamic.d.ts +1 -1
  40. package/dist/components/NSBoxDynamics.d.ts +1 -1
  41. package/dist/components/NSBoxEmail.d.ts +1 -1
  42. package/dist/components/NSBoxEntity.d.ts +1 -1
  43. package/dist/components/NSBoxEnum.d.ts +1 -1
  44. package/dist/components/NSBoxFile.d.ts +1 -1
  45. package/dist/components/NSBoxFile.module.css +10 -10
  46. package/dist/components/NSBoxFilePath.d.ts +1 -1
  47. package/dist/components/NSBoxFont.d.ts +1 -1
  48. package/dist/components/NSBoxIPV4.d.ts +1 -1
  49. package/dist/components/NSBoxIPV4Range.d.ts +1 -1
  50. package/dist/components/NSBoxIPV6.d.ts +1 -1
  51. package/dist/components/NSBoxIPV6Range.d.ts +1 -1
  52. package/dist/components/NSBoxInteger.d.ts +1 -1
  53. package/dist/components/NSBoxInteger.module.css +16 -16
  54. package/dist/components/NSBoxMoney.d.ts +1 -1
  55. package/dist/components/NSBoxPhone.d.ts +1 -1
  56. package/dist/components/NSBoxPhone.module.css +35 -35
  57. package/dist/components/NSBoxRadio.d.ts +1 -1
  58. package/dist/components/NSBoxRadio.module.css +33 -33
  59. package/dist/components/NSBoxSchemaBase.d.ts +1 -1
  60. package/dist/components/NSBoxSchemaBase.module.css +17 -17
  61. package/dist/components/NSBoxSchemaVariable.d.ts +1 -1
  62. package/dist/components/NSBoxSchemaVariable.module.css +16 -16
  63. package/dist/components/NSBoxSearch.d.ts +1 -1
  64. package/dist/components/NSBoxSensitive.d.ts +1 -1
  65. package/dist/components/NSBoxString.d.ts +1 -1
  66. package/dist/components/NSBoxTextArea.d.ts +1 -1
  67. package/dist/components/NSBoxTextArea.module.css +12 -12
  68. package/dist/components/NSBoxTime.d.ts +1 -1
  69. package/dist/components/NSBoxTime.module.css +4 -4
  70. package/dist/components/NSBoxTimeRange.d.ts +1 -1
  71. package/dist/components/NSBoxTimeZone.d.ts +1 -1
  72. package/dist/components/NSBoxURL.d.ts +1 -1
  73. package/dist/components/NSBoxVersion.d.ts +1 -1
  74. package/dist/components/NSButton.module.css +57 -57
  75. package/dist/components/NSButtonBlue.d.ts +1 -1
  76. package/dist/components/NSButtonBlue.module.css +4 -4
  77. package/dist/components/NSButtonGreen.d.ts +1 -1
  78. package/dist/components/NSButtonGreen.module.css +4 -4
  79. package/dist/components/NSButtonRed.d.ts +1 -1
  80. package/dist/components/NSButtonRed.module.css +4 -4
  81. package/dist/components/NSCard.d.ts +1 -1
  82. package/dist/components/NSCard.module.css +113 -113
  83. package/dist/components/NSCardScreenshot.d.ts +1 -1
  84. package/dist/components/NSCardScreenshot.module.css +41 -41
  85. package/dist/components/NSChartColumn.d.ts +1 -1
  86. package/dist/components/NSChartColumn.module.css +7 -7
  87. package/dist/components/NSChartDoughnut.d.ts +1 -1
  88. package/dist/components/NSChartPie.d.ts +1 -1
  89. package/dist/components/NSChartRange.d.ts +1 -1
  90. package/dist/components/NSChartTable.d.ts +1 -1
  91. package/dist/components/NSChartTable.module.css +21 -21
  92. package/dist/components/NSColumn.d.ts +1 -1
  93. package/dist/components/NSColumn.module.css +16 -16
  94. package/dist/components/NSCopy.d.ts +1 -1
  95. package/dist/components/NSCopyBox.d.ts +1 -1
  96. package/dist/components/NSCopyBox.module.css +39 -39
  97. package/dist/components/NSDialog.d.ts +1 -1
  98. package/dist/components/NSDialog.module.css +105 -105
  99. package/dist/components/NSDialogBox.d.ts +1 -1
  100. package/dist/components/NSDialogBoxDate.d.ts +1 -1
  101. package/dist/components/NSDialogBoxDateTime.d.ts +1 -1
  102. package/dist/components/NSDialogBoxPhone.d.ts +1 -1
  103. package/dist/components/NSDialogBoxString.d.ts +1 -1
  104. package/dist/components/NSDialogDelete.d.ts +1 -1
  105. package/dist/components/NSDialogInfo.d.ts +1 -1
  106. package/dist/components/NSDialogPageSelection.d.ts +2 -2
  107. package/dist/components/NSDialogPageSelection.module.css +103 -103
  108. package/dist/components/NSDownTimer.d.ts +1 -1
  109. package/dist/components/NSDownTimer.module.css +55 -55
  110. package/dist/components/NSDownload.d.ts +1 -1
  111. package/dist/components/NSDownload.module.css +46 -46
  112. package/dist/components/NSElectronicCard.d.ts +1 -1
  113. package/dist/components/NSElectronicCard.module.css +60 -60
  114. package/dist/components/NSEntityCardBackground.d.ts +1 -1
  115. package/dist/components/NSEntityCardBackground.module.css +27 -27
  116. package/dist/components/NSFilterBox.d.ts +2 -2
  117. package/dist/components/NSFilterBox.module.css +27 -27
  118. package/dist/components/NSFilterBoxItems.d.ts +1 -1
  119. package/dist/components/NSFilterBoxItems.module.css +15 -15
  120. package/dist/components/NSFilterItem.d.ts +1 -1
  121. package/dist/components/NSFilterItem.module.css +24 -24
  122. package/dist/components/NSFooter.d.ts +1 -1
  123. package/dist/components/NSFooter.module.css +140 -140
  124. package/dist/components/NSGauge.d.ts +1 -1
  125. package/dist/components/NSGauge.module.css +67 -67
  126. package/dist/components/NSGaugeDate.d.ts +1 -1
  127. package/dist/components/NSGaugeDate.module.css +57 -57
  128. package/dist/components/NSGaugeNumber.d.ts +1 -1
  129. package/dist/components/NSGaugeNumber.module.css +66 -66
  130. package/dist/components/NSHeader.d.ts +1 -1
  131. package/dist/components/NSHeader.module.css +316 -316
  132. package/dist/components/NSHeaderScreenshot.d.ts +1 -1
  133. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  134. package/dist/components/NSID.d.ts +1 -1
  135. package/dist/components/NSInfo.d.ts +1 -1
  136. package/dist/components/NSLabel.d.ts +1 -1
  137. package/dist/components/NSLabel.module.css +25 -25
  138. package/dist/components/NSLabelErrorNotifier.d.ts +1 -1
  139. package/dist/components/NSLabelErrorNotifier.module.css +2 -2
  140. package/dist/components/NSLabelSensitive.d.ts +1 -1
  141. package/dist/components/NSLabelSensitive.module.css +9 -9
  142. package/dist/components/NSLayout.d.ts +1 -1
  143. package/dist/components/NSLayout.module.css +23 -23
  144. package/dist/components/NSLine.d.ts +1 -1
  145. package/dist/components/NSLine.module.css +15 -15
  146. package/dist/components/NSLineText.d.ts +1 -1
  147. package/dist/components/NSLineText.module.css +38 -38
  148. package/dist/components/NSLink.d.ts +1 -1
  149. package/dist/components/NSLink.module.css +36 -36
  150. package/dist/components/NSLinkBlue.d.ts +1 -1
  151. package/dist/components/NSLinkGreen.d.ts +1 -1
  152. package/dist/components/NSLinkRed.d.ts +1 -1
  153. package/dist/components/NSListGrouped.d.ts +1 -1
  154. package/dist/components/NSListGrouped.module.css +69 -69
  155. package/dist/components/NSListProduct.d.ts +1 -1
  156. package/dist/components/NSLoading.d.ts +1 -1
  157. package/dist/components/NSLoading.module.css +10 -10
  158. package/dist/components/NSMegaMenu.d.ts +1 -1
  159. package/dist/components/NSMegaMenu.module.css +133 -133
  160. package/dist/components/NSMenuAction.d.ts +1 -1
  161. package/dist/components/NSMenuAction.module.css +88 -88
  162. package/dist/components/NSMenuButton.d.ts +1 -1
  163. package/dist/components/NSMenuButton.module.css +44 -44
  164. package/dist/components/NSNoData.d.ts +1 -1
  165. package/dist/components/NSNoData.module.css +11 -11
  166. package/dist/components/NSPagination.d.ts +1 -1
  167. package/dist/components/NSPagination.module.css +86 -86
  168. package/dist/components/NSPanel.d.ts +1 -1
  169. package/dist/components/NSPanel.module.css +19 -19
  170. package/dist/components/NSPanelAccordion.d.ts +1 -1
  171. package/dist/components/NSPanelAccordion.module.css +4 -4
  172. package/dist/components/NSProductSearch.d.ts +1 -1
  173. package/dist/components/NSProductSearch.module.css +73 -73
  174. package/dist/components/NSProgressBar.d.ts +1 -1
  175. package/dist/components/NSProgressBar.module.css +38 -38
  176. package/dist/components/NSRange.d.ts +1 -1
  177. package/dist/components/NSRange.module.css +66 -66
  178. package/dist/components/NSRepeater.d.ts +1 -1
  179. package/dist/components/NSRepeaterNSBoxSchemaVariable.d.ts +1 -1
  180. package/dist/components/NSRepeaterNSTag.d.ts +1 -1
  181. package/dist/components/NSRow.d.ts +1 -1
  182. package/dist/components/NSRow.module.css +17 -17
  183. package/dist/components/NSSection.d.ts +1 -1
  184. package/dist/components/NSSection.module.css +4 -4
  185. package/dist/components/NSSectionCards.d.ts +1 -1
  186. package/dist/components/NSSectionCards.module.css +38 -38
  187. package/dist/components/NSSectionTiles.d.ts +1 -1
  188. package/dist/components/NSSectionTiles.module.css +10 -10
  189. package/dist/components/NSSectionTitle.d.ts +1 -1
  190. package/dist/components/NSSpace.d.ts +1 -1
  191. package/dist/components/NSSplitter.d.ts +1 -1
  192. package/dist/components/NSSplitter.module.css +58 -58
  193. package/dist/components/NSTabPage.d.ts +1 -1
  194. package/dist/components/NSTabPage.module.css +59 -59
  195. package/dist/components/NSTable.d.ts +1 -4
  196. package/dist/components/NSTable.js +10 -25
  197. package/dist/components/NSTable.js.map +1 -1
  198. package/dist/components/NSTable.module.css +371 -411
  199. package/dist/components/NSTag.d.ts +1 -1
  200. package/dist/components/NSTile.d.ts +1 -1
  201. package/dist/components/NSTile.module.css +76 -76
  202. package/dist/components/NSTimelineMonthly.d.ts +1 -1
  203. package/dist/components/NSTimelineMonthly.module.css +71 -71
  204. package/dist/components/NSTitle.d.ts +1 -1
  205. package/dist/components/NSTitle.module.css +15 -15
  206. package/dist/formatter/StringFormatter.d.ts +1 -1
  207. package/dist/pages/NSImplementing.d.ts +1 -1
  208. package/dist/pages/NSImplementing.module.css +35 -35
  209. package/dist/pages/NSNotFoundPage.d.ts +1 -1
  210. package/dist/pages/NSNotFoundPage.module.css +18 -18
  211. package/dist/pages/NSUpdating.d.ts +1 -1
  212. package/dist/pages/NSUpdating.module.css +35 -35
  213. package/package.json +86 -86
  214. package/public/index.html +38 -38
  215. package/src/App.css +33 -33
  216. package/src/App.tsx +198 -198
  217. package/src/Color.tsx +10 -10
  218. package/src/CopyToClipboard.ts +6 -6
  219. package/src/EncryptionOperation.ts +98 -98
  220. package/src/NSBoxBuilder.tsx +922 -922
  221. package/src/ProductCacheService.ts +15 -15
  222. package/src/Validator.ts +199 -199
  223. package/src/components/INSBox.tsx +7 -7
  224. package/src/components/NSBanner.module.css +47 -47
  225. package/src/components/NSBanner.tsx +80 -80
  226. package/src/components/NSBarAction.module.css +91 -91
  227. package/src/components/NSBarAction.tsx +95 -95
  228. package/src/components/NSBarAlert.module.css +79 -79
  229. package/src/components/NSBarAlert.tsx +35 -35
  230. package/src/components/NSBarNotification.module.css +34 -34
  231. package/src/components/NSBarNotification.tsx +86 -86
  232. package/src/components/NSBarTitle.module.css +9 -9
  233. package/src/components/NSBarTitle.tsx +23 -23
  234. package/src/components/NSBox.module.css +87 -87
  235. package/src/components/NSBox.tsx +19 -19
  236. package/src/components/NSBoxBaseCombo.module.css +6 -6
  237. package/src/components/NSBoxBaseCombo.tsx +479 -479
  238. package/src/components/NSBoxBaseLayout.tsx +163 -163
  239. package/src/components/NSBoxBaseLayoutRecursive.tsx +59 -59
  240. package/src/components/NSBoxBoolean.module.css +73 -73
  241. package/src/components/NSBoxBoolean.tsx +152 -152
  242. package/src/components/NSBoxBooleans.tsx +181 -181
  243. package/src/components/NSBoxColor.tsx +107 -107
  244. package/src/components/NSBoxCombo.tsx +95 -95
  245. package/src/components/NSBoxDate.module.css +4 -4
  246. package/src/components/NSBoxDate.tsx +119 -119
  247. package/src/components/NSBoxDateRange.tsx +88 -88
  248. package/src/components/NSBoxDateRangeBase.module.css +73 -73
  249. package/src/components/NSBoxDateRangeBase.tsx +198 -198
  250. package/src/components/NSBoxDateTime.module.css +4 -4
  251. package/src/components/NSBoxDateTime.tsx +116 -116
  252. package/src/components/NSBoxDateTimeRange.tsx +65 -65
  253. package/src/components/NSBoxDouble.tsx +110 -110
  254. package/src/components/NSBoxDuration.module.css +4 -4
  255. package/src/components/NSBoxDuration.tsx +107 -107
  256. package/src/components/NSBoxDynamic.tsx +77 -77
  257. package/src/components/NSBoxDynamics.tsx +68 -68
  258. package/src/components/NSBoxEmail.tsx +117 -117
  259. package/src/components/NSBoxEntity.tsx +181 -181
  260. package/src/components/NSBoxEnum.tsx +113 -113
  261. package/src/components/NSBoxFile.module.css +10 -10
  262. package/src/components/NSBoxFile.tsx +106 -106
  263. package/src/components/NSBoxFilePath.tsx +106 -106
  264. package/src/components/NSBoxFont.tsx +107 -107
  265. package/src/components/NSBoxIPV4.tsx +107 -107
  266. package/src/components/NSBoxIPV4Range.tsx +107 -107
  267. package/src/components/NSBoxIPV6.tsx +104 -104
  268. package/src/components/NSBoxIPV6Range.tsx +107 -107
  269. package/src/components/NSBoxInteger.module.css +16 -16
  270. package/src/components/NSBoxInteger.tsx +126 -126
  271. package/src/components/NSBoxMoney.tsx +115 -115
  272. package/src/components/NSBoxPhone.module.css +35 -35
  273. package/src/components/NSBoxPhone.tsx +120 -120
  274. package/src/components/NSBoxRadio.module.css +33 -33
  275. package/src/components/NSBoxRadio.tsx +104 -104
  276. package/src/components/NSBoxSchemaBase.module.css +17 -17
  277. package/src/components/NSBoxSchemaBase.tsx +562 -562
  278. package/src/components/NSBoxSchemaVariable.module.css +16 -16
  279. package/src/components/NSBoxSchemaVariable.tsx +263 -263
  280. package/src/components/NSBoxSearch.tsx +112 -112
  281. package/src/components/NSBoxSensitive.tsx +133 -133
  282. package/src/components/NSBoxString.tsx +106 -106
  283. package/src/components/NSBoxTextArea.module.css +12 -12
  284. package/src/components/NSBoxTextArea.tsx +136 -136
  285. package/src/components/NSBoxTime.module.css +4 -4
  286. package/src/components/NSBoxTime.tsx +106 -106
  287. package/src/components/NSBoxTimeRange.tsx +220 -220
  288. package/src/components/NSBoxTimeZone.tsx +122 -122
  289. package/src/components/NSBoxURL.tsx +117 -117
  290. package/src/components/NSBoxVersion.tsx +107 -107
  291. package/src/components/NSButton.module.css +57 -57
  292. package/src/components/NSButton.tsx +74 -74
  293. package/src/components/NSButtonBlue.module.css +4 -4
  294. package/src/components/NSButtonBlue.tsx +29 -29
  295. package/src/components/NSButtonGreen.module.css +4 -4
  296. package/src/components/NSButtonGreen.tsx +29 -29
  297. package/src/components/NSButtonRed.module.css +4 -4
  298. package/src/components/NSButtonRed.tsx +29 -29
  299. package/src/components/NSCard.module.css +113 -113
  300. package/src/components/NSCard.tsx +67 -67
  301. package/src/components/NSCardScreenshot.module.css +41 -41
  302. package/src/components/NSCardScreenshot.tsx +31 -31
  303. package/src/components/NSChartColumn.module.css +7 -7
  304. package/src/components/NSChartColumn.tsx +130 -130
  305. package/src/components/NSChartDoughnut.tsx +112 -112
  306. package/src/components/NSChartPie.tsx +105 -105
  307. package/src/components/NSChartRange.tsx +14 -14
  308. package/src/components/NSChartTable.module.css +21 -21
  309. package/src/components/NSChartTable.tsx +94 -94
  310. package/src/components/NSColumn.module.css +16 -16
  311. package/src/components/NSColumn.tsx +24 -24
  312. package/src/components/NSCopy.tsx +58 -58
  313. package/src/components/NSCopyBox.module.css +39 -39
  314. package/src/components/NSCopyBox.tsx +53 -53
  315. package/src/components/NSDialog.module.css +105 -105
  316. package/src/components/NSDialog.tsx +72 -72
  317. package/src/components/NSDialogBox.tsx +38 -38
  318. package/src/components/NSDialogBoxDate.tsx +28 -28
  319. package/src/components/NSDialogBoxDateTime.tsx +28 -28
  320. package/src/components/NSDialogBoxPhone.tsx +28 -28
  321. package/src/components/NSDialogBoxString.tsx +28 -28
  322. package/src/components/NSDialogDelete.tsx +36 -36
  323. package/src/components/NSDialogInfo.tsx +49 -49
  324. package/src/components/NSDialogPageSelection.module.css +103 -103
  325. package/src/components/NSDialogPageSelection.tsx +219 -219
  326. package/src/components/NSDownTimer.module.css +55 -55
  327. package/src/components/NSDownTimer.tsx +91 -91
  328. package/src/components/NSDownload.module.css +46 -46
  329. package/src/components/NSDownload.tsx +69 -69
  330. package/src/components/NSElectronicCard.module.css +60 -60
  331. package/src/components/NSElectronicCard.tsx +46 -46
  332. package/src/components/NSEntityCardBackground.module.css +27 -27
  333. package/src/components/NSEntityCardBackground.tsx +36 -36
  334. package/src/components/NSFilterBox.module.css +27 -27
  335. package/src/components/NSFilterBox.tsx +477 -477
  336. package/src/components/NSFilterBoxItems.module.css +15 -15
  337. package/src/components/NSFilterBoxItems.tsx +52 -52
  338. package/src/components/NSFilterItem.module.css +24 -24
  339. package/src/components/NSFilterItem.tsx +27 -27
  340. package/src/components/NSFooter.module.css +140 -140
  341. package/src/components/NSFooter.tsx +321 -321
  342. package/src/components/NSGauge.module.css +67 -67
  343. package/src/components/NSGauge.tsx +52 -52
  344. package/src/components/NSGaugeDate.module.css +57 -57
  345. package/src/components/NSGaugeDate.tsx +125 -125
  346. package/src/components/NSGaugeNumber.module.css +66 -66
  347. package/src/components/NSGaugeNumber.tsx +90 -90
  348. package/src/components/NSHeader.module.css +316 -316
  349. package/src/components/NSHeader.tsx +334 -334
  350. package/src/components/NSHeaderScreenshot.module.css +35 -35
  351. package/src/components/NSHeaderScreenshot.tsx +39 -39
  352. package/src/components/NSID.tsx +159 -159
  353. package/src/components/NSInfo.tsx +50 -50
  354. package/src/components/NSLabel.module.css +25 -25
  355. package/src/components/NSLabel.tsx +47 -47
  356. package/src/components/NSLabelErrorNotifier.module.css +2 -2
  357. package/src/components/NSLabelErrorNotifier.tsx +35 -35
  358. package/src/components/NSLabelSensitive.module.css +9 -9
  359. package/src/components/NSLabelSensitive.tsx +85 -85
  360. package/src/components/NSLayout.module.css +23 -23
  361. package/src/components/NSLayout.tsx +140 -140
  362. package/src/components/NSLine.module.css +15 -15
  363. package/src/components/NSLine.tsx +13 -13
  364. package/src/components/NSLineText.module.css +38 -38
  365. package/src/components/NSLineText.tsx +17 -17
  366. package/src/components/NSLink.module.css +36 -36
  367. package/src/components/NSLink.tsx +26 -26
  368. package/src/components/NSLinkBlue.tsx +22 -22
  369. package/src/components/NSLinkGreen.tsx +13 -13
  370. package/src/components/NSLinkRed.tsx +13 -13
  371. package/src/components/NSListGrouped.module.css +69 -69
  372. package/src/components/NSListGrouped.tsx +106 -106
  373. package/src/components/NSListProduct.tsx +78 -78
  374. package/src/components/NSLoading.module.css +10 -10
  375. package/src/components/NSLoading.tsx +43 -43
  376. package/src/components/NSMegaMenu.module.css +133 -133
  377. package/src/components/NSMegaMenu.tsx +188 -188
  378. package/src/components/NSMenuAction.module.css +88 -88
  379. package/src/components/NSMenuAction.tsx +106 -106
  380. package/src/components/NSMenuButton.module.css +44 -44
  381. package/src/components/NSMenuButton.tsx +197 -197
  382. package/src/components/NSNoData.module.css +11 -11
  383. package/src/components/NSNoData.tsx +24 -24
  384. package/src/components/NSPagination.module.css +86 -86
  385. package/src/components/NSPagination.tsx +182 -182
  386. package/src/components/NSPanel.module.css +19 -19
  387. package/src/components/NSPanel.tsx +24 -24
  388. package/src/components/NSPanelAccordion.module.css +4 -4
  389. package/src/components/NSPanelAccordion.tsx +51 -51
  390. package/src/components/NSProductSearch.module.css +73 -73
  391. package/src/components/NSProductSearch.tsx +193 -193
  392. package/src/components/NSProgressBar.module.css +38 -38
  393. package/src/components/NSProgressBar.tsx +29 -29
  394. package/src/components/NSRange.module.css +66 -66
  395. package/src/components/NSRange.tsx +83 -83
  396. package/src/components/NSRepeater.tsx +328 -328
  397. package/src/components/NSRepeaterNSBoxSchemaVariable.tsx +94 -94
  398. package/src/components/NSRepeaterNSTag.tsx +86 -86
  399. package/src/components/NSRow.module.css +17 -17
  400. package/src/components/NSRow.tsx +24 -24
  401. package/src/components/NSSection.module.css +4 -4
  402. package/src/components/NSSection.tsx +26 -26
  403. package/src/components/NSSectionCards.module.css +38 -38
  404. package/src/components/NSSectionCards.tsx +51 -51
  405. package/src/components/NSSectionTiles.module.css +10 -10
  406. package/src/components/NSSectionTiles.tsx +25 -25
  407. package/src/components/NSSectionTitle.tsx +19 -19
  408. package/src/components/NSSpace.tsx +28 -28
  409. package/src/components/NSSplitter.module.css +58 -58
  410. package/src/components/NSSplitter.tsx +95 -95
  411. package/src/components/NSTabPage.module.css +59 -59
  412. package/src/components/NSTabPage.tsx +122 -122
  413. package/src/components/NSTable.module.css +371 -411
  414. package/src/components/NSTable.tsx +1099 -1120
  415. package/src/components/NSTag.tsx +74 -74
  416. package/src/components/NSTile.module.css +76 -76
  417. package/src/components/NSTile.tsx +27 -27
  418. package/src/components/NSTimelineMonthly.module.css +71 -71
  419. package/src/components/NSTimelineMonthly.tsx +44 -44
  420. package/src/components/NSTitle.module.css +15 -15
  421. package/src/components/NSTitle.tsx +19 -19
  422. package/src/formatter/BackColorFormatter.tsx +23 -23
  423. package/src/formatter/BaseColumnFormatter.ts +18 -18
  424. package/src/formatter/BaseURLImageFormatter.tsx +33 -33
  425. package/src/formatter/BooleanFormatter.ts +22 -22
  426. package/src/formatter/BytesFormatter.tsx +15 -15
  427. package/src/formatter/DateFormatter.ts +22 -22
  428. package/src/formatter/DateTimeFormatter.ts +22 -22
  429. package/src/formatter/DurationFormatter.ts +13 -13
  430. package/src/formatter/EmailFormatter.tsx +21 -21
  431. package/src/formatter/EnumFormatter.ts +13 -13
  432. package/src/formatter/FloatFormatter.ts +23 -23
  433. package/src/formatter/ForeColorFormatter.tsx +24 -24
  434. package/src/formatter/IDFormatter.tsx +53 -53
  435. package/src/formatter/IPFormatter.ts +13 -13
  436. package/src/formatter/IntegerFormatter.ts +23 -23
  437. package/src/formatter/JsonFormatter.tsx +58 -58
  438. package/src/formatter/MoneyFormatter.ts +35 -35
  439. package/src/formatter/PercentFormatter.tsx +39 -39
  440. package/src/formatter/PhoneFormatter.tsx +21 -21
  441. package/src/formatter/SensitiveFormatter.tsx +33 -33
  442. package/src/formatter/StringFormatter.tsx +43 -43
  443. package/src/formatter/TimeFormatter.ts +21 -21
  444. package/src/formatter/URLFormatter.tsx +24 -24
  445. package/src/formatter/UnknowFormatter.ts +18 -18
  446. package/src/index.tsx +7 -7
  447. package/src/main.ts +258 -258
  448. package/src/pages/NSImplementing.module.css +35 -35
  449. package/src/pages/NSImplementing.tsx +32 -32
  450. package/src/pages/NSNotFoundPage.module.css +18 -18
  451. package/src/pages/NSNotFoundPage.tsx +14 -14
  452. package/src/pages/NSUpdating.module.css +35 -35
  453. package/src/pages/NSUpdating.tsx +32 -32
  454. package/src/props/IBackgroundProps.ts +5 -5
  455. package/src/props/IBaseComponentProps.ts +8 -8
  456. package/src/props/IHeaderIconProps.ts +10 -10
  457. package/src/props/IHeaderLeftProps.ts +6 -6
  458. package/src/props/IHeaderRightProps.ts +8 -8
  459. package/src/props/IImageProps.ts +4 -4
  460. package/src/props/ILinkProps.ts +4 -4
  461. package/src/props/IValidationNumberProps.ts +4 -4
  462. package/src/props/IValidationPrecisionProps.ts +3 -3
  463. package/src/props/IValidationProps.ts +9 -9
  464. package/src/props/IValidationRegexProps.ts +4 -4
  465. package/src/props/IValidationStringProps.ts +4 -4
  466. package/src/routing/NSNotifier.ts +114 -114
  467. package/src/routing/NSRouterMaker.tsx +20 -20
  468. package/src/routing/NSRouterMakerComponent.ts +5 -5
  469. package/src/routing/NSRouterMakerProps.ts +5 -5
  470. package/tsconfig.json +43 -43
  471. package/dist/App.css +0 -34
  472. package/dist/index.css +0 -6
@@ -1,335 +1,335 @@
1
- "use client";
2
-
3
- import { Component, createRef, ReactNode } from "react";
4
- import Styles from "./NSHeader.module.css";
5
- import NavDropdown from 'react-bootstrap/NavDropdown';
6
- import { NamirasoftAPILinkServer, FilterLinkFullRow } from 'namirasoft-api-link';
7
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
8
- import { IHeaderRightProps } from "../props/IHeaderRightProps";
9
- import { IHeaderLeftProps } from "../props/IHeaderLeftProps";
10
- import { IStorageLocal, CacheService, SetTimeouService } from "namirasoft-core";
11
- import { EnvService } from 'namirasoft-core'
12
- import { NSRouterMakerProps } from "../routing/NSRouterMakerProps";
13
- import { NSBoxSearch } from "./NSBoxSearch";
14
- import { NSDialog } from "./NSDialog";
15
- import { NSProductSearch } from "./NSProductSearch";
16
- import NSMegaMenu from "./NSMegaMenu";
17
-
18
- export interface NSHeaderProps extends IBaseComponentProps, NSRouterMakerProps
19
- {
20
- nav?: IBaseComponentProps;
21
- right: IHeaderRightProps;
22
- left: IHeaderLeftProps;
23
- mega_menu?: boolean;
24
- children?: ReactNode;
25
- onCollapse?: () => void;
26
- isLoggedIn: () => boolean;
27
- }
28
-
29
- export interface NSHeaderState
30
- {
31
- filters: FilterLinkFullRow[];
32
- selected: FilterLinkFullRow | null;
33
- show_navbar: boolean;
34
- search: string;
35
- }
36
-
37
- export class NSHeader extends Component<NSHeaderProps, NSHeaderState>
38
- {
39
- private cache: CacheService<{
40
- rows: FilterLinkFullRow[];
41
- count: number;
42
- }>;
43
- private service = new SetTimeouService();
44
-
45
- NSBoxSearch_Ref = createRef<NSBoxSearch>();
46
- NSProductSearch_Ref = createRef<NSProductSearch>();
47
-
48
- constructor(props: NSHeaderProps)
49
- {
50
- super(props);
51
- this.state = {
52
- filters: [],
53
- selected: null,
54
- show_navbar: false,
55
- search: ""
56
- };
57
- this.hasChild = this.hasChild.bind(this);
58
- this.onMenuItemToggled = this.onMenuItemToggled.bind(this);
59
- this.render_menu = this.render_menu.bind(this);
60
- this.render_menuItem = this.render_menuItem.bind(this);
61
- this.handleShowNavbar = this.handleShowNavbar.bind(this);
62
- this.cache = new CacheService<{
63
- rows: FilterLinkFullRow[];
64
- count: number;
65
- }>("ns-header", new IStorageLocal(), 720, async () => "1.0.0", async () =>
66
- {
67
- let REACT_APP_BASE_URL_API_LINK = new EnvService("REACT_APP_BASE_URL_API_LINK", true).getString();
68
- let server = new NamirasoftAPILinkServer(REACT_APP_BASE_URL_API_LINK, props.notifier.onError);
69
- return server.filter.ListFilterLinks(this.props.left.scope, this.props.left.name, null, null, null, []);
70
- });
71
- this.service = new SetTimeouService();
72
- }
73
- override componentDidMount(): void
74
- {
75
- this.cache.get().then(filters =>
76
- {
77
- this.setState({ filters: filters.rows });
78
- }).catch(() => { });
79
- }
80
- private onMenuItemToggled(checked: boolean, selected: FilterLinkFullRow)
81
- {
82
- if (checked)
83
- this.setState({ selected });
84
- }
85
- private getFilters(): FilterLinkFullRow[]
86
- {
87
- let loggedin = this.props.isLoggedIn();
88
- let ans = this.state.filters?.filter(f =>
89
- {
90
- if (f.link)
91
- {
92
- if (loggedin)
93
- return f.link.private;
94
- return f.link.public;
95
- }
96
- return true;
97
- }) ?? [];
98
-
99
- while (true)
100
- {
101
- let old_length = ans.length;
102
- let old = ans;
103
- ans = ans.filter(f =>
104
- {
105
- if (f.link?.url)
106
- return true;
107
- return old.filter(x => x.parent_id === f.id).length > 0;
108
- });
109
- let new_length = ans.length;
110
- if (old_length === new_length)
111
- break;
112
- }
113
- ans.sort((a, b) => a.order - b.order);
114
- return ans;
115
- }
116
- private hasChild(id: number): boolean
117
- {
118
- return this.getFilters().some(f => f.parent_id === id);
119
- }
120
- handleShowNavbar(): void
121
- {
122
- this.setState({ show_navbar: !this.state.show_navbar });
123
- }
124
- override render()
125
- {
126
- let nav: IBaseComponentProps | undefined = this.props.nav;
127
- if (!nav)
128
- nav = { style: {} };
129
- if (!nav.style)
130
- nav.style = {};
131
- if (!nav.style?.backgroundColor)
132
- nav.style.backgroundColor = "rgba(20, 27, 92, 1)";
133
- return (
134
- <header id={this.props.id}
135
- className={`${Styles.ns_header} ${this.props.classList?.join(" ") ?? ""}`}
136
- style={this.props.style}
137
- >
138
- <nav
139
- id={this.props.nav?.id}
140
- className={`${Styles.ns_navbar} ${this.props.nav?.classList?.join(" ") ?? ""}`}
141
- style={nav?.style}
142
- >
143
- <div className={`${Styles.ns_navbar_parent_content} container`}>
144
- {
145
- this.props.onCollapse &&
146
- <button className={Styles.ns_collapse_btn} onClick={() => this.props.onCollapse?.()}>
147
- <img src="https://static.namirasoft.com/image/concept/sidebar/white.svg" alt={"collapse"} width={20} height={20} />
148
- </button>
149
- }
150
- <a className="me-2" href="/">
151
- <img
152
- src={this.props.left.logo}
153
- alt="Logo"
154
- width={48}
155
- height={48}
156
- />
157
- </a>
158
- {
159
- this.props.left.title &&
160
- <h2 className={`${Styles.ns_navbar_title} mb-0 flex-shrink-0`}>
161
- {this.props.left.title}
162
- </h2>
163
- }
164
- <div className={`${Styles.ns_navbar_content} `} >
165
- <div className={`${Styles.ns_navbar_elements} ${this.state.show_navbar && Styles.ns_navbar_active}`}>
166
- {this.render_menu(0, null)}
167
- </div>
168
- <NSBoxSearch
169
- ref={this.NSBoxSearch_Ref}
170
- required={false}
171
- title=""
172
- hideHeader
173
- placeholder="Search"
174
- autoComplete="one-time-code"
175
- style={{ flex: 0.8, minWidth: "15rem" }}
176
- input={{
177
- style: { zIndex: 800 },
178
- name: "search",
179
- }}
180
- onChanged={(e) =>
181
- {
182
- let search = e.getValue(false) ?? "";
183
- if (search.length === 0)
184
- this.setState({ search });
185
- else
186
- this.service.setTimeoutIfNotCalledAgain(() =>
187
- {
188
- let search = e.getValue(false) ?? "";
189
- this.setState({ search });
190
- this.NSProductSearch_Ref.current?.reload(search);
191
- }, 700);
192
- }}
193
- />
194
- {
195
- this.state.search.length >= 3 &&
196
- <NSDialog
197
- onClose={() =>
198
- {
199
- this.NSBoxSearch_Ref.current?.setValue("");
200
- }}
201
- center_dialog={true}
202
- zIndex={799}
203
- >
204
- <NSProductSearch
205
- ref={this.NSProductSearch_Ref}
206
- search={this.state.search}
207
- />
208
- </NSDialog>
209
- }
210
- {
211
- this.props.right &&
212
- <div className="d-flex gap-3 align-items-center">
213
- {
214
- this.props.right?.title &&
215
- <span className={Styles.ns_navbar_title}>{this.props.right?.title}</span>
216
- }
217
- {
218
- this.props.right?.link &&
219
- <a href={this.props.right?.link?.href} target={this.props.right?.link?.target} className={Styles.ns_navbar_title}>{this.props.right?.link?.children}</a>
220
- }
221
- {
222
- this.props.right.icons.map((icon, index) =>
223
- <div
224
- key={`NSHeader_div_icon_key${index}`}
225
- title={icon.tooltip}
226
- className={Styles.ns_header_icon}
227
- >
228
- <img
229
- src={icon.src}
230
- alt={icon.alt}
231
- width={20}
232
- height={20}
233
- onClick={() => icon.onClicked(icon)}
234
- />
235
- {
236
- icon.count !== 0 && icon.count &&
237
- <div
238
- className={Styles.ns_navbar_notification_count}
239
- onClick={() => icon.onClicked(icon)}
240
- >
241
- {
242
- icon.count < 100 ? icon.count : "+99"
243
- }
244
- </div>
245
- }
246
- {
247
- icon.children
248
- }
249
- </div>
250
- )
251
- }
252
- {
253
- this.getFilters().length > 0 &&
254
- <div className={Styles.ns_navbar_menu_icon} onClick={this.handleShowNavbar}>
255
- <img
256
- src=
257
- {
258
- this.state.show_navbar ?
259
- "https://static.namirasoft.com/image/concept/close/white.svg"
260
- : "https://static.namirasoft.com/image/concept/menu/burger-white.svg"
261
- }
262
- alt="Menu Icon"
263
- width={24}
264
- height={24}
265
- />
266
- </div>
267
- }
268
- </div>
269
- }
270
- </div>
271
- </div>
272
- </nav>
273
- {
274
- this.props.children
275
- }
276
- </header>
277
- );
278
- }
279
- private render_menu(level: number, parent_id: number | null)
280
- {
281
- let fs: FilterLinkFullRow[] = this.getFilters().filter(f => f.parent_id === parent_id);
282
- return (
283
- <div className={`me-auto nav ${Styles.ns_navbar_items_container}`}>
284
- {fs?.map(f => this.render_menuItem(level, f))}
285
- </div>
286
- );
287
- }
288
- private render_menuItem(level: number, filter: FilterLinkFullRow)
289
- {
290
- if (this.hasChild(filter.id))
291
- {
292
- let sub_menus = <></>;
293
- if (level === 0)
294
- if (this.state.selected)
295
- sub_menus = (
296
- <div id={`dropdown_items${filter.id}`}>
297
- {
298
- this.props.mega_menu &&
299
- <NSMegaMenu items={this.getFilters()} selected={this.state.selected} />
300
- }
301
- {
302
- this.render_menu(1, this.state.selected.id)
303
- }
304
- </div>
305
- );
306
-
307
- return (
308
- <NavDropdown
309
- id={`dropdown_parent${filter.id}`}
310
- key={filter.id}
311
- title={filter.name}
312
- className={level === 0 ? Styles.ns_navbar_first_level_item : Styles.ns_navbar_second_level_item}
313
- onToggle={(checked) => this.onMenuItemToggled(checked, filter)}
314
- >
315
- {sub_menus}
316
- </NavDropdown>
317
- );
318
- }
319
- else
320
- {
321
- let href = filter.link?.url;
322
- if (process.env.REACT_APP_STANDALONE)
323
- if (href)
324
- {
325
- let url = new URL(href);
326
- url.host = window.location.host;
327
- url.protocol = window.location.protocol;
328
- href = url.toString();
329
- }
330
- return (
331
- <a key={filter.id} className={`${Styles.ns_navbar_items_link} ${level === 0 ? Styles.ns_navbar_first_level_item : Styles.ns_navbar_second_level_item}`} href={href}>{filter.name}</a>
332
- );
333
- }
334
- }
1
+ "use client";
2
+
3
+ import { Component, createRef, ReactNode } from "react";
4
+ import Styles from "./NSHeader.module.css";
5
+ import NavDropdown from 'react-bootstrap/NavDropdown';
6
+ import { NamirasoftAPILinkServer, FilterLinkFullRow } from 'namirasoft-api-link';
7
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
8
+ import { IHeaderRightProps } from "../props/IHeaderRightProps";
9
+ import { IHeaderLeftProps } from "../props/IHeaderLeftProps";
10
+ import { IStorageLocal, CacheService, SetTimeouService } from "namirasoft-core";
11
+ import { EnvService } from 'namirasoft-core'
12
+ import { NSRouterMakerProps } from "../routing/NSRouterMakerProps";
13
+ import { NSBoxSearch } from "./NSBoxSearch";
14
+ import { NSDialog } from "./NSDialog";
15
+ import { NSProductSearch } from "./NSProductSearch";
16
+ import NSMegaMenu from "./NSMegaMenu";
17
+
18
+ export interface NSHeaderProps extends IBaseComponentProps, NSRouterMakerProps
19
+ {
20
+ nav?: IBaseComponentProps;
21
+ right: IHeaderRightProps;
22
+ left: IHeaderLeftProps;
23
+ mega_menu?: boolean;
24
+ children?: ReactNode;
25
+ onCollapse?: () => void;
26
+ isLoggedIn: () => boolean;
27
+ }
28
+
29
+ export interface NSHeaderState
30
+ {
31
+ filters: FilterLinkFullRow[];
32
+ selected: FilterLinkFullRow | null;
33
+ show_navbar: boolean;
34
+ search: string;
35
+ }
36
+
37
+ export class NSHeader extends Component<NSHeaderProps, NSHeaderState>
38
+ {
39
+ private cache: CacheService<{
40
+ rows: FilterLinkFullRow[];
41
+ count: number;
42
+ }>;
43
+ private service = new SetTimeouService();
44
+
45
+ NSBoxSearch_Ref = createRef<NSBoxSearch>();
46
+ NSProductSearch_Ref = createRef<NSProductSearch>();
47
+
48
+ constructor(props: NSHeaderProps)
49
+ {
50
+ super(props);
51
+ this.state = {
52
+ filters: [],
53
+ selected: null,
54
+ show_navbar: false,
55
+ search: ""
56
+ };
57
+ this.hasChild = this.hasChild.bind(this);
58
+ this.onMenuItemToggled = this.onMenuItemToggled.bind(this);
59
+ this.render_menu = this.render_menu.bind(this);
60
+ this.render_menuItem = this.render_menuItem.bind(this);
61
+ this.handleShowNavbar = this.handleShowNavbar.bind(this);
62
+ this.cache = new CacheService<{
63
+ rows: FilterLinkFullRow[];
64
+ count: number;
65
+ }>("ns-header", new IStorageLocal(), 720, async () => "1.0.0", async () =>
66
+ {
67
+ let REACT_APP_BASE_URL_API_LINK = new EnvService("REACT_APP_BASE_URL_API_LINK", true).getString();
68
+ let server = new NamirasoftAPILinkServer(REACT_APP_BASE_URL_API_LINK, props.notifier.onError);
69
+ return server.filter.ListFilterLinks(this.props.left.scope, this.props.left.name, null, null, null, []);
70
+ });
71
+ this.service = new SetTimeouService();
72
+ }
73
+ override componentDidMount(): void
74
+ {
75
+ this.cache.get().then(filters =>
76
+ {
77
+ this.setState({ filters: filters.rows });
78
+ }).catch(() => { });
79
+ }
80
+ private onMenuItemToggled(checked: boolean, selected: FilterLinkFullRow)
81
+ {
82
+ if (checked)
83
+ this.setState({ selected });
84
+ }
85
+ private getFilters(): FilterLinkFullRow[]
86
+ {
87
+ let loggedin = this.props.isLoggedIn();
88
+ let ans = this.state.filters?.filter(f =>
89
+ {
90
+ if (f.link)
91
+ {
92
+ if (loggedin)
93
+ return f.link.private;
94
+ return f.link.public;
95
+ }
96
+ return true;
97
+ }) ?? [];
98
+
99
+ while (true)
100
+ {
101
+ let old_length = ans.length;
102
+ let old = ans;
103
+ ans = ans.filter(f =>
104
+ {
105
+ if (f.link?.url)
106
+ return true;
107
+ return old.filter(x => x.parent_id === f.id).length > 0;
108
+ });
109
+ let new_length = ans.length;
110
+ if (old_length === new_length)
111
+ break;
112
+ }
113
+ ans.sort((a, b) => a.order - b.order);
114
+ return ans;
115
+ }
116
+ private hasChild(id: number): boolean
117
+ {
118
+ return this.getFilters().some(f => f.parent_id === id);
119
+ }
120
+ handleShowNavbar(): void
121
+ {
122
+ this.setState({ show_navbar: !this.state.show_navbar });
123
+ }
124
+ override render()
125
+ {
126
+ let nav: IBaseComponentProps | undefined = this.props.nav;
127
+ if (!nav)
128
+ nav = { style: {} };
129
+ if (!nav.style)
130
+ nav.style = {};
131
+ if (!nav.style?.backgroundColor)
132
+ nav.style.backgroundColor = "rgba(20, 27, 92, 1)";
133
+ return (
134
+ <header id={this.props.id}
135
+ className={`${Styles.ns_header} ${this.props.classList?.join(" ") ?? ""}`}
136
+ style={this.props.style}
137
+ >
138
+ <nav
139
+ id={this.props.nav?.id}
140
+ className={`${Styles.ns_navbar} ${this.props.nav?.classList?.join(" ") ?? ""}`}
141
+ style={nav?.style}
142
+ >
143
+ <div className={`${Styles.ns_navbar_parent_content} container`}>
144
+ {
145
+ this.props.onCollapse &&
146
+ <button className={Styles.ns_collapse_btn} onClick={() => this.props.onCollapse?.()}>
147
+ <img src="https://static.namirasoft.com/image/concept/sidebar/white.svg" alt={"collapse"} width={20} height={20} />
148
+ </button>
149
+ }
150
+ <a className="me-2" href="/">
151
+ <img
152
+ src={this.props.left.logo}
153
+ alt="Logo"
154
+ width={48}
155
+ height={48}
156
+ />
157
+ </a>
158
+ {
159
+ this.props.left.title &&
160
+ <h2 className={`${Styles.ns_navbar_title} mb-0 flex-shrink-0`}>
161
+ {this.props.left.title}
162
+ </h2>
163
+ }
164
+ <div className={`${Styles.ns_navbar_content} `} >
165
+ <div className={`${Styles.ns_navbar_elements} ${this.state.show_navbar && Styles.ns_navbar_active}`}>
166
+ {this.render_menu(0, null)}
167
+ </div>
168
+ <NSBoxSearch
169
+ ref={this.NSBoxSearch_Ref}
170
+ required={false}
171
+ title=""
172
+ hideHeader
173
+ placeholder="Search"
174
+ autoComplete="one-time-code"
175
+ style={{ flex: 0.8, minWidth: "15rem" }}
176
+ input={{
177
+ style: { zIndex: 800 },
178
+ name: "search",
179
+ }}
180
+ onChanged={(e) =>
181
+ {
182
+ let search = e.getValue(false) ?? "";
183
+ if (search.length === 0)
184
+ this.setState({ search });
185
+ else
186
+ this.service.setTimeoutIfNotCalledAgain(() =>
187
+ {
188
+ let search = e.getValue(false) ?? "";
189
+ this.setState({ search });
190
+ this.NSProductSearch_Ref.current?.reload(search);
191
+ }, 700);
192
+ }}
193
+ />
194
+ {
195
+ this.state.search.length >= 3 &&
196
+ <NSDialog
197
+ onClose={() =>
198
+ {
199
+ this.NSBoxSearch_Ref.current?.setValue("");
200
+ }}
201
+ center_dialog={true}
202
+ zIndex={799}
203
+ >
204
+ <NSProductSearch
205
+ ref={this.NSProductSearch_Ref}
206
+ search={this.state.search}
207
+ />
208
+ </NSDialog>
209
+ }
210
+ {
211
+ this.props.right &&
212
+ <div className="d-flex gap-3 align-items-center">
213
+ {
214
+ this.props.right?.title &&
215
+ <span className={Styles.ns_navbar_title}>{this.props.right?.title}</span>
216
+ }
217
+ {
218
+ this.props.right?.link &&
219
+ <a href={this.props.right?.link?.href} target={this.props.right?.link?.target} className={Styles.ns_navbar_title}>{this.props.right?.link?.children}</a>
220
+ }
221
+ {
222
+ this.props.right.icons.map((icon, index) =>
223
+ <div
224
+ key={`NSHeader_div_icon_key${index}`}
225
+ title={icon.tooltip}
226
+ className={Styles.ns_header_icon}
227
+ >
228
+ <img
229
+ src={icon.src}
230
+ alt={icon.alt}
231
+ width={20}
232
+ height={20}
233
+ onClick={() => icon.onClicked(icon)}
234
+ />
235
+ {
236
+ icon.count !== 0 && icon.count &&
237
+ <div
238
+ className={Styles.ns_navbar_notification_count}
239
+ onClick={() => icon.onClicked(icon)}
240
+ >
241
+ {
242
+ icon.count < 100 ? icon.count : "+99"
243
+ }
244
+ </div>
245
+ }
246
+ {
247
+ icon.children
248
+ }
249
+ </div>
250
+ )
251
+ }
252
+ {
253
+ this.getFilters().length > 0 &&
254
+ <div className={Styles.ns_navbar_menu_icon} onClick={this.handleShowNavbar}>
255
+ <img
256
+ src=
257
+ {
258
+ this.state.show_navbar ?
259
+ "https://static.namirasoft.com/image/concept/close/white.svg"
260
+ : "https://static.namirasoft.com/image/concept/menu/burger-white.svg"
261
+ }
262
+ alt="Menu Icon"
263
+ width={24}
264
+ height={24}
265
+ />
266
+ </div>
267
+ }
268
+ </div>
269
+ }
270
+ </div>
271
+ </div>
272
+ </nav>
273
+ {
274
+ this.props.children
275
+ }
276
+ </header>
277
+ );
278
+ }
279
+ private render_menu(level: number, parent_id: number | null)
280
+ {
281
+ let fs: FilterLinkFullRow[] = this.getFilters().filter(f => f.parent_id === parent_id);
282
+ return (
283
+ <div className={`me-auto nav ${Styles.ns_navbar_items_container}`}>
284
+ {fs?.map(f => this.render_menuItem(level, f))}
285
+ </div>
286
+ );
287
+ }
288
+ private render_menuItem(level: number, filter: FilterLinkFullRow)
289
+ {
290
+ if (this.hasChild(filter.id))
291
+ {
292
+ let sub_menus = <></>;
293
+ if (level === 0)
294
+ if (this.state.selected)
295
+ sub_menus = (
296
+ <div id={`dropdown_items${filter.id}`}>
297
+ {
298
+ this.props.mega_menu &&
299
+ <NSMegaMenu items={this.getFilters()} selected={this.state.selected} />
300
+ }
301
+ {
302
+ this.render_menu(1, this.state.selected.id)
303
+ }
304
+ </div>
305
+ );
306
+
307
+ return (
308
+ <NavDropdown
309
+ id={`dropdown_parent${filter.id}`}
310
+ key={filter.id}
311
+ title={filter.name}
312
+ className={level === 0 ? Styles.ns_navbar_first_level_item : Styles.ns_navbar_second_level_item}
313
+ onToggle={(checked) => this.onMenuItemToggled(checked, filter)}
314
+ >
315
+ {sub_menus}
316
+ </NavDropdown>
317
+ );
318
+ }
319
+ else
320
+ {
321
+ let href = filter.link?.url;
322
+ if (process.env.REACT_APP_STANDALONE)
323
+ if (href)
324
+ {
325
+ let url = new URL(href);
326
+ url.host = window.location.host;
327
+ url.protocol = window.location.protocol;
328
+ href = url.toString();
329
+ }
330
+ return (
331
+ <a key={filter.id} className={`${Styles.ns_navbar_items_link} ${level === 0 ? Styles.ns_navbar_first_level_item : Styles.ns_navbar_second_level_item}`} href={href}>{filter.name}</a>
332
+ );
333
+ }
334
+ }
335
335
  }