namirasoft-site-react 1.3.335 → 1.3.336

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 (352) hide show
  1. package/.dockerignore +86 -86
  2. package/Dockerfile +18 -18
  3. package/config-overrides.js +70 -70
  4. package/dist/App.css +17 -0
  5. package/dist/assets/images/1.png +0 -0
  6. package/dist/assets/images/2.png +0 -0
  7. package/dist/assets/images/3.png +0 -0
  8. package/dist/assets/images/4.png +0 -0
  9. package/dist/assets/images/404 image.svg +9 -9
  10. package/dist/assets/images/404 image_mobile.svg +9 -9
  11. package/dist/assets/images/5.jpg +0 -0
  12. package/dist/assets/images/arrow.svg +3 -3
  13. package/dist/assets/images/danger.svg +3 -3
  14. package/dist/assets/images/exit.svg +3 -3
  15. package/dist/assets/images/icon-export.svg +3 -0
  16. package/dist/assets/images/icon-input-copy.svg +3 -3
  17. package/dist/assets/images/icon-input-date.svg +9 -9
  18. package/dist/assets/images/icon-input-duration.svg +9 -9
  19. package/dist/assets/images/icon-input-email.svg +9 -9
  20. package/dist/assets/images/icon-input-float.svg +9 -9
  21. package/dist/assets/images/icon-input-id.svg +9 -0
  22. package/dist/assets/images/icon-input-integer.svg +9 -9
  23. package/dist/assets/images/icon-input-ip.svg +9 -9
  24. package/dist/assets/images/icon-input-phone.svg +9 -9
  25. package/dist/assets/images/icon-input-price.svg +9 -9
  26. package/dist/assets/images/icon-input-search.svg +3 -3
  27. package/dist/assets/images/icon-input-string.svg +9 -9
  28. package/dist/assets/images/icon-input-text.svg +9 -9
  29. package/dist/assets/images/icon-input-time.svg +9 -9
  30. package/dist/assets/images/icon-refresh.svg +3 -0
  31. package/dist/assets/images/icon-select-box.svg +3 -3
  32. package/dist/assets/images/logo.svg +9 -9
  33. package/dist/assets/images/menu.svg +3 -3
  34. package/dist/assets/images/namira.svg +9 -9
  35. package/dist/assets/images/rectangle.svg +3 -3
  36. package/dist/components/NSAccess.d.ts +2 -0
  37. package/dist/components/NSAccess.js +8 -0
  38. package/dist/components/NSAccess.js.map +1 -0
  39. package/dist/components/NSAccess.module.css +39 -0
  40. package/dist/components/NSActionMenu.js +2 -2
  41. package/dist/components/NSActionMenu.module.css +75 -75
  42. package/dist/components/NSAssistantButton.module.css +133 -133
  43. package/dist/components/NSBarAction.module.css +87 -87
  44. package/dist/components/NSBarHeroBanner.module.css +42 -42
  45. package/dist/components/NSBarNotification.module.css +34 -34
  46. package/dist/components/NSBarTitle.module.css +9 -9
  47. package/dist/components/NSBox.module.css +123 -123
  48. package/dist/components/NSBoxBoolean.module.css +53 -53
  49. package/dist/components/NSBoxCombo.module.css +16 -16
  50. package/dist/components/NSBoxDate.module.css +39 -39
  51. package/dist/components/NSBoxEntity.module.css +25 -25
  52. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  53. package/dist/components/NSBoxLabel.module.css +12 -12
  54. package/dist/components/NSBoxOTP.module.css +10 -10
  55. package/dist/components/NSBoxText.d.ts +25 -0
  56. package/dist/components/NSBoxText.js +56 -0
  57. package/dist/components/NSBoxText.js.map +1 -0
  58. package/dist/components/NSBoxTextArea.module.css +76 -76
  59. package/dist/components/NSButton.module.css +27 -27
  60. package/dist/components/NSButtonBlue.module.css +4 -4
  61. package/dist/components/NSButtonGreen.module.css +4 -4
  62. package/dist/components/NSButtonRed.module.css +4 -4
  63. package/dist/components/NSCard.module.css +108 -108
  64. package/dist/components/NSCopyToClipboard.module.css +39 -39
  65. package/dist/components/NSElectronicCard.module.css +60 -60
  66. package/dist/components/NSEntityBar.module.css +77 -77
  67. package/dist/components/NSEntityCardBackground.module.css +27 -27
  68. package/dist/components/NSFilterBox.module.css +47 -47
  69. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  70. package/dist/components/NSFilterItem.module.css +23 -23
  71. package/dist/components/NSFooter.module.css +123 -123
  72. package/dist/components/NSGroupedList.module.css +72 -72
  73. package/dist/components/NSHeader.module.css +271 -271
  74. package/dist/components/NSInput.module.css +74 -0
  75. package/dist/components/NSInputDate.d.ts +21 -0
  76. package/dist/components/NSInputDate.js +41 -0
  77. package/dist/components/NSInputDate.js.map +1 -0
  78. package/dist/components/NSInputDate.module.css +42 -0
  79. package/dist/components/NSInputDuration.d.ts +23 -0
  80. package/dist/components/NSInputDuration.js +42 -0
  81. package/dist/components/NSInputDuration.js.map +1 -0
  82. package/dist/components/NSInputEmail.d.ts +22 -0
  83. package/dist/components/NSInputEmail.js +43 -0
  84. package/dist/components/NSInputEmail.js.map +1 -0
  85. package/dist/components/NSInputErrorNotifier.d.ts +5 -0
  86. package/dist/components/NSInputErrorNotifier.js +7 -0
  87. package/dist/components/NSInputErrorNotifier.js.map +1 -0
  88. package/dist/components/NSInputErrorNotifier.module.css +3 -0
  89. package/dist/components/NSInputFloat.d.ts +22 -0
  90. package/dist/components/NSInputFloat.js +41 -0
  91. package/dist/components/NSInputFloat.js.map +1 -0
  92. package/dist/components/NSInputIP.d.ts +22 -0
  93. package/dist/components/NSInputIP.js +43 -0
  94. package/dist/components/NSInputIP.js.map +1 -0
  95. package/dist/components/NSInputInteger.d.ts +22 -0
  96. package/dist/components/NSInputInteger.js +41 -0
  97. package/dist/components/NSInputInteger.js.map +1 -0
  98. package/dist/components/NSInputPassword.d.ts +22 -0
  99. package/dist/components/NSInputPassword.js +42 -0
  100. package/dist/components/NSInputPassword.js.map +1 -0
  101. package/dist/components/NSInputPhone.d.ts +22 -0
  102. package/dist/components/NSInputPhone.js +38 -0
  103. package/dist/components/NSInputPhone.js.map +1 -0
  104. package/dist/components/NSInputPrice.d.ts +22 -0
  105. package/dist/components/NSInputPrice.js +41 -0
  106. package/dist/components/NSInputPrice.js.map +1 -0
  107. package/dist/components/NSInputSearch.d.ts +22 -0
  108. package/dist/components/NSInputSearch.js +41 -0
  109. package/dist/components/NSInputSearch.js.map +1 -0
  110. package/dist/components/NSInputString.d.ts +22 -0
  111. package/dist/components/NSInputString.js +42 -0
  112. package/dist/components/NSInputString.js.map +1 -0
  113. package/dist/components/NSInputText.d.ts +22 -0
  114. package/dist/components/NSInputText.js +42 -0
  115. package/dist/components/NSInputText.js.map +1 -0
  116. package/dist/components/NSInputTime.d.ts +22 -0
  117. package/dist/components/NSInputTime.js +43 -0
  118. package/dist/components/NSInputTime.js.map +1 -0
  119. package/dist/components/NSLayout.module.css +13 -13
  120. package/dist/components/NSLayoutAction.d.ts +5 -0
  121. package/dist/components/NSLayoutAction.js +20 -0
  122. package/dist/components/NSLayoutAction.js.map +1 -0
  123. package/dist/components/NSLayoutAction.module.css +88 -0
  124. package/dist/components/NSLayoutHeroBanner.d.ts +2 -0
  125. package/dist/components/NSLayoutHeroBanner.js +8 -0
  126. package/dist/components/NSLayoutHeroBanner.js.map +1 -0
  127. package/dist/components/NSLayoutHeroBanner.module.css +43 -0
  128. package/dist/components/NSLayoutTitle.d.ts +2 -0
  129. package/dist/components/NSLayoutTitle.js +11 -0
  130. package/dist/components/NSLayoutTitle.js.map +1 -0
  131. package/dist/components/NSLayoutTitle.module.css +10 -0
  132. package/dist/components/NSLink.module.css +36 -36
  133. package/dist/components/NSLoading.module.css +29 -29
  134. package/dist/components/NSModal.js +2 -2
  135. package/dist/components/NSModal.module.css +70 -70
  136. package/dist/components/NSNoData.module.css +8 -8
  137. package/dist/components/NSNotification.d.ts +21 -0
  138. package/dist/components/NSNotification.js +37 -0
  139. package/dist/components/NSNotification.js.map +1 -0
  140. package/dist/components/NSNotification.module.css +32 -0
  141. package/dist/components/NSPageSelectionModal.module.css +102 -102
  142. package/dist/components/NSPagination.module.css +101 -101
  143. package/dist/components/NSPanel.module.css +46 -46
  144. package/dist/components/NSPrintModal.d.ts +15 -0
  145. package/dist/components/NSPrintModal.js +35 -0
  146. package/dist/components/NSPrintModal.js.map +1 -0
  147. package/dist/components/NSPrintModal.module.css +82 -0
  148. package/dist/components/NSRadioButton.module.css +61 -61
  149. package/dist/components/NSSection.module.css +10 -10
  150. package/dist/components/NSSectionBars.module.css +10 -10
  151. package/dist/components/NSSectionCards.module.css +38 -38
  152. package/dist/components/NSSelectBox.d.ts +24 -0
  153. package/dist/components/NSSelectBox.js +61 -0
  154. package/dist/components/NSSelectBox.js.map +1 -0
  155. package/dist/components/NSSelectBox.module.css +42 -0
  156. package/dist/components/NSTabPage.module.css +57 -57
  157. package/dist/components/NSTable.js +1 -1
  158. package/dist/components/NSTable.js.map +1 -1
  159. package/dist/components/NSTable.module.css +253 -253
  160. package/dist/components/NSTag.module.css +44 -44
  161. package/dist/components/NSTitle.module.css +15 -15
  162. package/dist/components/NSVerification.module.css +22 -22
  163. package/dist/index.css +6 -0
  164. package/dist/pages/NSLoginPage.module.css +19 -19
  165. package/dist/pages/NSNotFoundPage.module.css +18 -18
  166. package/dist/props/BaseComponentProps.d.ts +6 -0
  167. package/dist/props/BaseComponentProps.js +2 -0
  168. package/dist/props/BaseComponentProps.js.map +10 -0
  169. package/dist/props/INamirasoftProps.d.ts +4 -0
  170. package/dist/props/INamirasoftProps.js +2 -0
  171. package/dist/props/INamirasoftProps.js.map +1 -0
  172. package/dist/props/ImageProps.d.ts +4 -0
  173. package/dist/props/ImageProps.js +2 -0
  174. package/dist/props/ImageProps.js.map +10 -0
  175. package/dist/props/LinkProps.d.ts +5 -0
  176. package/dist/props/LinkProps.js +2 -0
  177. package/dist/props/LinkProps.js.map +10 -0
  178. package/dist/props/ValidationNumberProps.d.ts +4 -0
  179. package/dist/props/ValidationNumberProps.js +2 -0
  180. package/dist/props/ValidationNumberProps.js.map +10 -0
  181. package/dist/props/ValidationProps.d.ts +6 -0
  182. package/dist/props/ValidationProps.js +2 -0
  183. package/dist/props/ValidationProps.js.map +10 -0
  184. package/dist/props/ValidationRegexProps.d.ts +4 -0
  185. package/dist/props/ValidationRegexProps.js +2 -0
  186. package/dist/props/ValidationRegexProps.js.map +1 -0
  187. package/dist/props/ValidationStringProps.d.ts +4 -0
  188. package/dist/props/ValidationStringProps.js +2 -0
  189. package/dist/props/ValidationStringProps.js.map +10 -0
  190. package/package.json +67 -67
  191. package/public/index.html +38 -38
  192. package/src/App.css +16 -16
  193. package/src/App.tsx +166 -166
  194. package/src/CopyToClipboard.ts +6 -6
  195. package/src/Validator.ts +110 -110
  196. package/src/assets/images/404 image.svg +9 -9
  197. package/src/assets/images/404 image_mobile.svg +9 -9
  198. package/src/assets/images/arrow.svg +3 -3
  199. package/src/assets/images/danger.svg +3 -3
  200. package/src/assets/images/exit.svg +3 -3
  201. package/src/assets/images/icon-input-copy.svg +3 -3
  202. package/src/assets/images/icon-input-date.svg +9 -9
  203. package/src/assets/images/icon-input-duration.svg +9 -9
  204. package/src/assets/images/icon-input-email.svg +9 -9
  205. package/src/assets/images/icon-input-float.svg +9 -9
  206. package/src/assets/images/icon-input-integer.svg +9 -9
  207. package/src/assets/images/icon-input-ip.svg +9 -9
  208. package/src/assets/images/icon-input-phone.svg +9 -9
  209. package/src/assets/images/icon-input-price.svg +9 -9
  210. package/src/assets/images/icon-input-search.svg +3 -3
  211. package/src/assets/images/icon-input-string.svg +9 -9
  212. package/src/assets/images/icon-input-text.svg +9 -9
  213. package/src/assets/images/icon-input-time.svg +9 -9
  214. package/src/assets/images/icon-select-box.svg +3 -3
  215. package/src/assets/images/logo.svg +9 -9
  216. package/src/assets/images/menu.svg +3 -3
  217. package/src/assets/images/namira.svg +9 -9
  218. package/src/assets/images/rectangle.svg +3 -3
  219. package/src/components/NSActionMenu.module.css +75 -75
  220. package/src/components/NSActionMenu.tsx +88 -88
  221. package/src/components/NSAssistantButton.module.css +133 -133
  222. package/src/components/NSAssistantButton.tsx +74 -74
  223. package/src/components/NSBarAction.module.css +87 -87
  224. package/src/components/NSBarAction.tsx +86 -86
  225. package/src/components/NSBarHeroBanner.module.css +42 -42
  226. package/src/components/NSBarHeroBanner.tsx +61 -61
  227. package/src/components/NSBarNotification.module.css +34 -34
  228. package/src/components/NSBarNotification.tsx +63 -63
  229. package/src/components/NSBarTitle.module.css +9 -9
  230. package/src/components/NSBarTitle.tsx +28 -28
  231. package/src/components/NSBox.module.css +123 -123
  232. package/src/components/NSBoxBoolean.module.css +53 -53
  233. package/src/components/NSBoxBoolean.tsx +84 -84
  234. package/src/components/NSBoxCombo.module.css +16 -16
  235. package/src/components/NSBoxCombo.tsx +131 -131
  236. package/src/components/NSBoxDate.module.css +39 -39
  237. package/src/components/NSBoxDate.tsx +83 -83
  238. package/src/components/NSBoxDateTime.tsx +83 -83
  239. package/src/components/NSBoxDouble.tsx +88 -88
  240. package/src/components/NSBoxDuration.tsx +88 -88
  241. package/src/components/NSBoxEmail.tsx +104 -104
  242. package/src/components/NSBoxEntity.module.css +25 -25
  243. package/src/components/NSBoxEntity.tsx +134 -134
  244. package/src/components/NSBoxEnum.tsx +56 -56
  245. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  246. package/src/components/NSBoxErrorNotifier.tsx +33 -33
  247. package/src/components/NSBoxIPV4.tsx +93 -93
  248. package/src/components/NSBoxIPV6.tsx +90 -90
  249. package/src/components/NSBoxInteger.tsx +86 -86
  250. package/src/components/NSBoxLabel.module.css +12 -12
  251. package/src/components/NSBoxLabel.tsx +29 -29
  252. package/src/components/NSBoxOTP.module.css +10 -10
  253. package/src/components/NSBoxOTP.tsx +65 -65
  254. package/src/components/NSBoxPassword.tsx +86 -86
  255. package/src/components/NSBoxPhone.tsx +88 -88
  256. package/src/components/NSBoxPrice.tsx +88 -88
  257. package/src/components/NSBoxSearch.tsx +103 -103
  258. package/src/components/NSBoxString.tsx +103 -103
  259. package/src/components/NSBoxTextArea.module.css +76 -76
  260. package/src/components/NSBoxTextArea.tsx +106 -106
  261. package/src/components/NSBoxTime.tsx +88 -88
  262. package/src/components/NSButton.module.css +27 -27
  263. package/src/components/NSButton.tsx +23 -23
  264. package/src/components/NSButtonBlue.module.css +4 -4
  265. package/src/components/NSButtonBlue.tsx +12 -12
  266. package/src/components/NSButtonGreen.module.css +4 -4
  267. package/src/components/NSButtonGreen.tsx +11 -11
  268. package/src/components/NSButtonRed.module.css +4 -4
  269. package/src/components/NSButtonRed.tsx +11 -11
  270. package/src/components/NSCard.module.css +108 -108
  271. package/src/components/NSCard.tsx +70 -70
  272. package/src/components/NSCopyToClipboard.module.css +39 -39
  273. package/src/components/NSCopyToClipboard.tsx +35 -35
  274. package/src/components/NSElectronicCard.module.css +60 -60
  275. package/src/components/NSElectronicCard.tsx +47 -47
  276. package/src/components/NSEntityBar.module.css +77 -77
  277. package/src/components/NSEntityBar.tsx +27 -27
  278. package/src/components/NSEntityCardBackground.module.css +27 -27
  279. package/src/components/NSEntityCardBackground.tsx +34 -34
  280. package/src/components/NSFilterBox.module.css +47 -47
  281. package/src/components/NSFilterBox.tsx +374 -374
  282. package/src/components/NSFilterBoxDialog.module.css +36 -36
  283. package/src/components/NSFilterBoxDialog.tsx +74 -74
  284. package/src/components/NSFilterItem.module.css +23 -23
  285. package/src/components/NSFilterItem.tsx +72 -72
  286. package/src/components/NSFooter.module.css +123 -123
  287. package/src/components/NSFooter.tsx +153 -153
  288. package/src/components/NSGroupedList.module.css +72 -72
  289. package/src/components/NSGroupedList.tsx +107 -107
  290. package/src/components/NSHeader.module.css +271 -271
  291. package/src/components/NSHeader.tsx +191 -191
  292. package/src/components/NSLayout.module.css +13 -13
  293. package/src/components/NSLayout.tsx +75 -75
  294. package/src/components/NSLine.tsx +18 -18
  295. package/src/components/NSLink.module.css +36 -36
  296. package/src/components/NSLink.tsx +25 -25
  297. package/src/components/NSLinkBlue.tsx +20 -20
  298. package/src/components/NSLinkGreen.tsx +5 -5
  299. package/src/components/NSLinkRed.tsx +5 -5
  300. package/src/components/NSLoading.module.css +29 -29
  301. package/src/components/NSLoading.tsx +19 -19
  302. package/src/components/NSModal.module.css +70 -70
  303. package/src/components/NSModal.tsx +49 -49
  304. package/src/components/NSNoData.module.css +8 -8
  305. package/src/components/NSNoData.tsx +24 -24
  306. package/src/components/NSPageSelectionModal.module.css +102 -102
  307. package/src/components/NSPageSelectionModal.tsx +228 -228
  308. package/src/components/NSPagination.module.css +101 -101
  309. package/src/components/NSPagination.tsx +191 -191
  310. package/src/components/NSPanel.module.css +46 -46
  311. package/src/components/NSPanel.tsx +19 -19
  312. package/src/components/NSRadioButton.module.css +61 -61
  313. package/src/components/NSRadioButton.tsx +100 -100
  314. package/src/components/NSSection.module.css +10 -10
  315. package/src/components/NSSection.tsx +23 -23
  316. package/src/components/NSSectionBars.module.css +10 -10
  317. package/src/components/NSSectionBars.tsx +25 -25
  318. package/src/components/NSSectionCards.module.css +38 -38
  319. package/src/components/NSSectionCards.tsx +51 -51
  320. package/src/components/NSSectionTitle.tsx +21 -21
  321. package/src/components/NSSpace.tsx +28 -28
  322. package/src/components/NSTabPage.module.css +57 -57
  323. package/src/components/NSTabPage.tsx +46 -46
  324. package/src/components/NSTable.module.css +253 -253
  325. package/src/components/NSTable.tsx +358 -358
  326. package/src/components/NSTag.module.css +44 -44
  327. package/src/components/NSTag.tsx +49 -49
  328. package/src/components/NSTitle.module.css +15 -15
  329. package/src/components/NSTitle.tsx +19 -19
  330. package/src/components/NSVerification.module.css +22 -22
  331. package/src/components/NSVerification.tsx +41 -41
  332. package/src/index.tsx +7 -7
  333. package/src/main.ts +79 -79
  334. package/src/pages/NSLoginPage.module.css +19 -19
  335. package/src/pages/NSLoginPage.tsx +30 -30
  336. package/src/pages/NSNotFoundPage.module.css +18 -18
  337. package/src/pages/NSNotFoundPage.tsx +11 -11
  338. package/src/props/IBaseComponentProps.ts +8 -8
  339. package/src/props/IHeaderIconProps.ts +9 -9
  340. package/src/props/IHeaderProps.ts +6 -6
  341. package/src/props/IImageProps.ts +4 -4
  342. package/src/props/ILinkProps.ts +5 -5
  343. package/src/props/IValidationNumberProps.ts +4 -4
  344. package/src/props/IValidationProps.ts +7 -7
  345. package/src/props/IValidationRegexProps.ts +4 -4
  346. package/src/props/IValidationStringProps.ts +4 -4
  347. package/src/routing/INSRouterMaker.ts +6 -6
  348. package/src/routing/INSRouterProps.ts +5 -5
  349. package/src/routing/INSRouterState.ts +5 -5
  350. package/src/routing/NSRouterMaker.tsx +33 -33
  351. package/src/routing/Notifier.ts +79 -79
  352. package/tsconfig.json +43 -43
package/src/App.tsx CHANGED
@@ -1,167 +1,167 @@
1
- import './App.css';
2
- import 'bootstrap/dist/css/bootstrap.min.css';
3
- import { NSBarAction, NSBoxBoolean, NSBoxEmail, NSBoxEnum, NSBoxSearch, NSBoxString, NSEntityBar, NSLayout, NSNoData, NSPagination, NSSpace, NSSpaceSizeType, NSTabPage, NSTable } from './main';
4
- import { NSBoxLabel } from './components/NSBoxLabel';
5
- import { NSRadioButton } from './components/NSRadioButton';
6
- import NSTag from './components/NSTag';
7
- import NSButton from './components/NSButton';
8
- import { useRef } from 'react';
9
-
10
- export interface INSBarActionState
11
- {
12
- id: string;
13
- menu_item: string;
14
- handler: () => void;
15
- isActive: () => boolean;
16
- }
17
- export function App()
18
- {
19
- const onClicked = () =>
20
- {
21
- console.log("clicked")
22
- }
23
- let icons = [
24
- { src: "https://static.namirasoft.com/image/namirasoft/message/logo/base.png", alt: "", onClicked, count: 1 },
25
- { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
26
- { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
27
- { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
28
- { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
29
- { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
30
- { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
31
- ];
32
- let content1 = () => <>
33
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
34
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
35
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
36
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
37
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
38
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
39
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
40
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
41
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
42
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
43
- <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
44
- </>;
45
- let content2 = () => <div>Content for Tab2</div>;
46
- let content3 = () => <div>Content for Tab3</div>;
47
- const tabs = [
48
- { title: 'Information', getContent: content1 },
49
- { title: 'Price History', getContent: content2 },
50
- { title: 'Price Estimator', getContent: content3 }
51
- ];
52
-
53
- const getColumns = (): { [key: string]: string } =>
54
- {
55
- return {
56
- id: "ID",
57
- name: "Name",
58
- user_id: "User Id",
59
- os: "OS"
60
- };
61
- };
62
- let rows = [
63
- {
64
- id: 1,
65
- name: "Accountant",
66
- policy: "Lorem ipsum dolor sit amet, consetetur ",
67
- },
68
- {
69
- id: 2,
70
- name: "Accountant",
71
- policy: "Lorem ipsum dolor sit amet, consetetur ",
72
- },
73
- {
74
- id: 3,
75
- name: "Accountant",
76
- policy: "Lorem ipsum dolor sit amet, consetetur ",
77
- },
78
- {
79
- id: 4,
80
- name: "Accountant",
81
- policy: "Lorem ipsum dolor sit amet, consetetur ",
82
- },
83
- ]
84
- let group: any = [
85
- [
86
- {
87
- id: "1",
88
- handler: () => { },
89
- isActive: () => false,
90
- menu_item: "1"
91
- }, {
92
- id: "2",
93
- handler: () => { },
94
- isActive: () => true,
95
- menu_item: "2"
96
- },
97
- {
98
- id: "2",
99
- handler: () => { },
100
- isActive: () => true,
101
- menu_item: "3"
102
- }
103
- ]
104
- ]
105
- let table = useRef<NSTable<any>>(null);
106
- function getCell(row: any, column: string): any
107
- {
108
- if (column === "check")
109
- {
110
- return <>
111
- <input id={`checkbox_${row.id}`} type="checkbox" className="table_checkbox" />
112
- <label htmlFor={`checkbox_${row.id}`}></label>
113
- </>
114
- } else
115
- {
116
- return (row as any)[column];
117
- }
118
- }
119
- return (
120
- <>
121
- <NSLayout
122
- header={{
123
- title: "any",
124
- icons: icons
125
- }}
126
- scope="Namirasoft Account Console"
127
- logo="exampleLogoUrl"
128
- notifications={[]}
129
- background=""
130
- >
131
- <>
132
- <NSTabPage tabs={tabs} />
133
- <NSSpace size={NSSpaceSizeType.SMALL} />
134
- <NSPagination totalItems={100} onPageChange={() => { }} />
135
- </>
136
- <NSTable
137
- ref={table}
138
- columns={getColumns()}
139
- getCell={getCell}
140
- getRowKey={row => row.id.toString()}
141
- getColumnAttributes={() => { return {} }}
142
- totalItems={0}
143
- getRows={async () => { return rows; }}
144
- checkbox={true}
145
- />
146
- <NSBarAction title='' menus={group} />
147
- <NSBoxEmail title='Email' required />
148
- <NSBoxString title='String' required />
149
- <NSRadioButton title={"Radio Button"} required={false} />
150
- <NSSpace size={NSSpaceSizeType.LARGE} />
151
- <NSBoxBoolean defaultValue={true} title='' required />
152
- <NSButton title='Clear Filters' onClick={() => window.location.reload()} style={{ width: "136px", border: "2px solid #001664" }} />
153
- <NSTag />
154
- <NSNoData lable="No New Message" />
155
- <div className="d-flex flex-row gap-2 w-100">
156
- <NSBoxString title="Name" required />
157
- <NSBoxEnum options={[]} required title='Notification_sender_topic_id' multiple />
158
- <NSBoxEmail title="Name" required />
159
- <NSBoxSearch title="Name" required />
160
- </div>
161
- <NSSpace size={NSSpaceSizeType.MEDUIM} />
162
- <NSBoxBoolean title='CheckBox' required />
163
- <NSEntityBar title='' description='' image={{ src: "" }} />
164
- </NSLayout>
165
- </>
166
- );
1
+ import './App.css';
2
+ import 'bootstrap/dist/css/bootstrap.min.css';
3
+ import { NSBarAction, NSBoxBoolean, NSBoxEmail, NSBoxEnum, NSBoxSearch, NSBoxString, NSEntityBar, NSLayout, NSNoData, NSPagination, NSSpace, NSSpaceSizeType, NSTabPage, NSTable } from './main';
4
+ import { NSBoxLabel } from './components/NSBoxLabel';
5
+ import { NSRadioButton } from './components/NSRadioButton';
6
+ import NSTag from './components/NSTag';
7
+ import NSButton from './components/NSButton';
8
+ import { useRef } from 'react';
9
+
10
+ export interface INSBarActionState
11
+ {
12
+ id: string;
13
+ menu_item: string;
14
+ handler: () => void;
15
+ isActive: () => boolean;
16
+ }
17
+ export function App()
18
+ {
19
+ const onClicked = () =>
20
+ {
21
+ console.log("clicked")
22
+ }
23
+ let icons = [
24
+ { src: "https://static.namirasoft.com/image/namirasoft/message/logo/base.png", alt: "", onClicked, count: 1 },
25
+ { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
26
+ { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
27
+ { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
28
+ { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
29
+ { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
30
+ { src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
31
+ ];
32
+ let content1 = () => <>
33
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
34
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
35
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
36
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
37
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
38
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
39
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
40
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
41
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
42
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
43
+ <NSBoxLabel title="URL"><p style={{ color: "#000" }}>http://URL.com</p></NSBoxLabel>
44
+ </>;
45
+ let content2 = () => <div>Content for Tab2</div>;
46
+ let content3 = () => <div>Content for Tab3</div>;
47
+ const tabs = [
48
+ { title: 'Information', getContent: content1 },
49
+ { title: 'Price History', getContent: content2 },
50
+ { title: 'Price Estimator', getContent: content3 }
51
+ ];
52
+
53
+ const getColumns = (): { [key: string]: string } =>
54
+ {
55
+ return {
56
+ id: "ID",
57
+ name: "Name",
58
+ user_id: "User Id",
59
+ os: "OS"
60
+ };
61
+ };
62
+ let rows = [
63
+ {
64
+ id: 1,
65
+ name: "Accountant",
66
+ policy: "Lorem ipsum dolor sit amet, consetetur ",
67
+ },
68
+ {
69
+ id: 2,
70
+ name: "Accountant",
71
+ policy: "Lorem ipsum dolor sit amet, consetetur ",
72
+ },
73
+ {
74
+ id: 3,
75
+ name: "Accountant",
76
+ policy: "Lorem ipsum dolor sit amet, consetetur ",
77
+ },
78
+ {
79
+ id: 4,
80
+ name: "Accountant",
81
+ policy: "Lorem ipsum dolor sit amet, consetetur ",
82
+ },
83
+ ]
84
+ let group: any = [
85
+ [
86
+ {
87
+ id: "1",
88
+ handler: () => { },
89
+ isActive: () => false,
90
+ menu_item: "1"
91
+ }, {
92
+ id: "2",
93
+ handler: () => { },
94
+ isActive: () => true,
95
+ menu_item: "2"
96
+ },
97
+ {
98
+ id: "2",
99
+ handler: () => { },
100
+ isActive: () => true,
101
+ menu_item: "3"
102
+ }
103
+ ]
104
+ ]
105
+ let table = useRef<NSTable<any>>(null);
106
+ function getCell(row: any, column: string): any
107
+ {
108
+ if (column === "check")
109
+ {
110
+ return <>
111
+ <input id={`checkbox_${row.id}`} type="checkbox" className="table_checkbox" />
112
+ <label htmlFor={`checkbox_${row.id}`}></label>
113
+ </>
114
+ } else
115
+ {
116
+ return (row as any)[column];
117
+ }
118
+ }
119
+ return (
120
+ <>
121
+ <NSLayout
122
+ header={{
123
+ title: "any",
124
+ icons: icons
125
+ }}
126
+ scope="Namirasoft Account Console"
127
+ logo="exampleLogoUrl"
128
+ notifications={[]}
129
+ background=""
130
+ >
131
+ <>
132
+ <NSTabPage tabs={tabs} />
133
+ <NSSpace size={NSSpaceSizeType.SMALL} />
134
+ <NSPagination totalItems={100} onPageChange={() => { }} />
135
+ </>
136
+ <NSTable
137
+ ref={table}
138
+ columns={getColumns()}
139
+ getCell={getCell}
140
+ getRowKey={row => row.id.toString()}
141
+ getColumnAttributes={() => { return {} }}
142
+ totalItems={0}
143
+ getRows={async () => { return rows; }}
144
+ checkbox={true}
145
+ />
146
+ <NSBarAction title='' menus={group} />
147
+ <NSBoxEmail title='Email' required />
148
+ <NSBoxString title='String' required />
149
+ <NSRadioButton title={"Radio Button"} required={false} />
150
+ <NSSpace size={NSSpaceSizeType.LARGE} />
151
+ <NSBoxBoolean defaultValue={true} title='' required />
152
+ <NSButton title='Clear Filters' onClick={() => window.location.reload()} style={{ width: "136px", border: "2px solid #001664" }} />
153
+ <NSTag />
154
+ <NSNoData lable="No New Message" />
155
+ <div className="d-flex flex-row gap-2 w-100">
156
+ <NSBoxString title="Name" required />
157
+ <NSBoxEnum options={[]} required title='Notification_sender_topic_id' multiple />
158
+ <NSBoxEmail title="Name" required />
159
+ <NSBoxSearch title="Name" required />
160
+ </div>
161
+ <NSSpace size={NSSpaceSizeType.MEDUIM} />
162
+ <NSBoxBoolean title='CheckBox' required />
163
+ <NSEntityBar title='' description='' image={{ src: "" }} />
164
+ </NSLayout>
165
+ </>
166
+ );
167
167
  }
@@ -1,7 +1,7 @@
1
- export default class CopyToClipboard
2
- {
3
- static copyToClipboard(value: string): void
4
- {
5
- navigator.clipboard.writeText(value);
6
- }
1
+ export default class CopyToClipboard
2
+ {
3
+ static copyToClipboard(value: string): void
4
+ {
5
+ navigator.clipboard.writeText(value);
6
+ }
7
7
  };
package/src/Validator.ts CHANGED
@@ -1,111 +1,111 @@
1
- import { PhoneOperation, RegexTemplate } from "namirasoft-core";
2
- import { IValidationNumberProps } from "./props/IValidationNumberProps";
3
- import { IValidationProps } from "./props/IValidationProps";
4
- import { IValidationStringProps } from "./props/IValidationStringProps";
5
-
6
- export class Validator
7
- {
8
- static getError(name: string, value: string | number | null | undefined, validator: IValidationProps): string | null
9
- {
10
- if (validator.required)
11
- if (!value)
12
- return `${name} is required.`;
13
- if (value != null)
14
- if (validator.regex)
15
- if (!validator.regex.regex.test(value + ""))
16
- return `${name} is not a valid ${validator.regex.name}.`;
17
- if (value != null)
18
- if (validator.validator)
19
- {
20
- let error = validator.validator(name, value);
21
- if (error)
22
- return error;
23
- }
24
- return null;
25
- }
26
- static getErrorString(name: string, value: string | null | undefined, validator: IValidationStringProps): string | null
27
- {
28
- if (value != null)
29
- {
30
- if (validator.max_length != null)
31
- if (validator.max_length < value.length)
32
- return `Max length of ${name} should be ${validator.max_length} characters.`;
33
- if (validator.min_length != null)
34
- if (validator.min_length > value.length)
35
- return `Minlength of ${name} should be ${validator.min_length} characters.`;
36
- }
37
- return null;
38
- }
39
- static getErrorNumber(name: string, value: number | null | undefined, validator: IValidationNumberProps): string | null
40
- {
41
- if (value != null)
42
- {
43
- if (isNaN(value))
44
- return `${name} is not a number.`;
45
- if (validator.max != null)
46
- if (validator.max < value)
47
- return `Max value of ${name} should be ${validator.max} characters.`;
48
- if (validator.min != null)
49
- if (validator.min > value)
50
- return `Min value of ${name} should be ${validator.min} characters.`;
51
- }
52
- return null;
53
- }
54
- static getErrorEmail(name: string, value: string | null | undefined): string | null
55
- {
56
- return Validator.getError(name, value, {
57
- required: true, regex: {
58
- name: "Email",
59
- regex: RegexTemplate.Email
60
- }
61
- });
62
- }
63
- static getErrorDate(name: string, value: string | null | undefined): string | null
64
- {
65
- return Validator.getError(name, value, {
66
- required: true, regex: {
67
- name: "Date",
68
- regex: RegexTemplate.Date
69
- }
70
- });
71
- }
72
- static getErrorTime(name: string, value: string | null | undefined): string | null
73
- {
74
- return Validator.getError(name, value, {
75
- required: true, regex: {
76
- name: "Time",
77
- regex: RegexTemplate.Time
78
- }
79
- });
80
- }
81
- static getErrorDuration(name: string, value: string | null | undefined): string | null
82
- {
83
- return Validator.getError(name, value, {
84
- required: true, regex: {
85
- name: "Duration",
86
- regex: RegexTemplate.Duration
87
- }
88
- });
89
- }
90
- static getErrorIP(name: string, value: string | null | undefined): string | null
91
- {
92
- return Validator.getError(name, value, {
93
- required: true, regex: {
94
- name: "IP",
95
- regex: RegexTemplate.IP
96
- }
97
- });
98
- }
99
- static getErrorPhone(name: string, value: string | null | undefined): string | null
100
- {
101
- return Validator.getError(name, value, {
102
- required: true, validator: () =>
103
- {
104
- if (value)
105
- if (!PhoneOperation.isValid(value))
106
- return `${name} is not a valid phone number`;
107
- return null;
108
- }
109
- });
110
- }
1
+ import { PhoneOperation, RegexTemplate } from "namirasoft-core";
2
+ import { IValidationNumberProps } from "./props/IValidationNumberProps";
3
+ import { IValidationProps } from "./props/IValidationProps";
4
+ import { IValidationStringProps } from "./props/IValidationStringProps";
5
+
6
+ export class Validator
7
+ {
8
+ static getError(name: string, value: string | number | null | undefined, validator: IValidationProps): string | null
9
+ {
10
+ if (validator.required)
11
+ if (!value)
12
+ return `${name} is required.`;
13
+ if (value != null)
14
+ if (validator.regex)
15
+ if (!validator.regex.regex.test(value + ""))
16
+ return `${name} is not a valid ${validator.regex.name}.`;
17
+ if (value != null)
18
+ if (validator.validator)
19
+ {
20
+ let error = validator.validator(name, value);
21
+ if (error)
22
+ return error;
23
+ }
24
+ return null;
25
+ }
26
+ static getErrorString(name: string, value: string | null | undefined, validator: IValidationStringProps): string | null
27
+ {
28
+ if (value != null)
29
+ {
30
+ if (validator.max_length != null)
31
+ if (validator.max_length < value.length)
32
+ return `Max length of ${name} should be ${validator.max_length} characters.`;
33
+ if (validator.min_length != null)
34
+ if (validator.min_length > value.length)
35
+ return `Minlength of ${name} should be ${validator.min_length} characters.`;
36
+ }
37
+ return null;
38
+ }
39
+ static getErrorNumber(name: string, value: number | null | undefined, validator: IValidationNumberProps): string | null
40
+ {
41
+ if (value != null)
42
+ {
43
+ if (isNaN(value))
44
+ return `${name} is not a number.`;
45
+ if (validator.max != null)
46
+ if (validator.max < value)
47
+ return `Max value of ${name} should be ${validator.max} characters.`;
48
+ if (validator.min != null)
49
+ if (validator.min > value)
50
+ return `Min value of ${name} should be ${validator.min} characters.`;
51
+ }
52
+ return null;
53
+ }
54
+ static getErrorEmail(name: string, value: string | null | undefined): string | null
55
+ {
56
+ return Validator.getError(name, value, {
57
+ required: true, regex: {
58
+ name: "Email",
59
+ regex: RegexTemplate.Email
60
+ }
61
+ });
62
+ }
63
+ static getErrorDate(name: string, value: string | null | undefined): string | null
64
+ {
65
+ return Validator.getError(name, value, {
66
+ required: true, regex: {
67
+ name: "Date",
68
+ regex: RegexTemplate.Date
69
+ }
70
+ });
71
+ }
72
+ static getErrorTime(name: string, value: string | null | undefined): string | null
73
+ {
74
+ return Validator.getError(name, value, {
75
+ required: true, regex: {
76
+ name: "Time",
77
+ regex: RegexTemplate.Time
78
+ }
79
+ });
80
+ }
81
+ static getErrorDuration(name: string, value: string | null | undefined): string | null
82
+ {
83
+ return Validator.getError(name, value, {
84
+ required: true, regex: {
85
+ name: "Duration",
86
+ regex: RegexTemplate.Duration
87
+ }
88
+ });
89
+ }
90
+ static getErrorIP(name: string, value: string | null | undefined): string | null
91
+ {
92
+ return Validator.getError(name, value, {
93
+ required: true, regex: {
94
+ name: "IP",
95
+ regex: RegexTemplate.IP
96
+ }
97
+ });
98
+ }
99
+ static getErrorPhone(name: string, value: string | null | undefined): string | null
100
+ {
101
+ return Validator.getError(name, value, {
102
+ required: true, validator: () =>
103
+ {
104
+ if (value)
105
+ if (!PhoneOperation.isValid(value))
106
+ return `${name} is not a valid phone number`;
107
+ return null;
108
+ }
109
+ });
110
+ }
111
111
  }