namirasoft-site-react 1.3.228 → 1.3.232

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 (329) hide show
  1. package/config-overrides.js +70 -70
  2. package/dist/App.js +2 -2
  3. package/dist/App.js.map +1 -1
  4. package/dist/assets/images/404 image.svg +9 -9
  5. package/dist/assets/images/404 image_mobile.svg +9 -9
  6. package/dist/assets/images/arrow.svg +3 -3
  7. package/dist/assets/images/danger.svg +3 -3
  8. package/dist/assets/images/exit.svg +3 -3
  9. package/dist/assets/images/icon-input-copy.svg +3 -3
  10. package/dist/assets/images/icon-input-date.svg +9 -9
  11. package/dist/assets/images/icon-input-duration.svg +9 -9
  12. package/dist/assets/images/icon-input-email.svg +9 -9
  13. package/dist/assets/images/icon-input-float.svg +9 -9
  14. package/dist/assets/images/icon-input-integer.svg +9 -9
  15. package/dist/assets/images/icon-input-ip.svg +9 -9
  16. package/dist/assets/images/icon-input-phone.svg +9 -9
  17. package/dist/assets/images/icon-input-price.svg +9 -9
  18. package/dist/assets/images/icon-input-search.svg +3 -3
  19. package/dist/assets/images/icon-input-string.svg +9 -9
  20. package/dist/assets/images/icon-input-text.svg +9 -9
  21. package/dist/assets/images/icon-input-time.svg +9 -9
  22. package/dist/assets/images/icon-select-box.svg +3 -3
  23. package/dist/assets/images/logo.svg +9 -9
  24. package/dist/assets/images/menu.svg +3 -3
  25. package/dist/assets/images/namira.svg +9 -9
  26. package/dist/assets/images/rectangle.svg +3 -3
  27. package/dist/components/NSAccess.module.css +38 -38
  28. package/dist/components/NSActionMenu.js +2 -2
  29. package/dist/components/NSActionMenu.module.css +75 -75
  30. package/dist/components/NSBarAction.module.css +87 -87
  31. package/dist/components/NSBarHeroBanner.module.css +42 -42
  32. package/dist/components/NSBarNotification.module.css +31 -31
  33. package/dist/components/NSBarTitle.module.css +9 -9
  34. package/dist/components/NSBox.module.css +122 -122
  35. package/dist/components/NSBoxBoolean.module.css +54 -54
  36. package/dist/components/NSBoxDate.module.css +39 -39
  37. package/dist/components/NSBoxEnum.module.css +38 -38
  38. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  39. package/dist/components/NSBoxLabel.module.css +12 -12
  40. package/dist/components/NSBoxOTP.module.css +10 -10
  41. package/dist/components/NSBoxTextArea.module.css +76 -76
  42. package/dist/components/NSButton.module.css +27 -27
  43. package/dist/components/NSButtonBlue.module.css +4 -4
  44. package/dist/components/NSButtonGreen.module.css +4 -4
  45. package/dist/components/NSButtonRed.module.css +4 -4
  46. package/dist/components/NSCard.module.css +110 -110
  47. package/dist/components/NSCopyToClipboard.module.css +39 -39
  48. package/dist/components/NSElectronicCard.module.css +60 -60
  49. package/dist/components/NSEntityBar.module.css +77 -77
  50. package/dist/components/NSEntityCardBackground.module.css +27 -27
  51. package/dist/components/NSFilterBox.d.ts +4 -1
  52. package/dist/components/NSFilterBox.js +21 -7
  53. package/dist/components/NSFilterBox.js.map +1 -1
  54. package/dist/components/NSFilterBox.module.css +38 -38
  55. package/dist/components/NSFilterBoxDialog.js.map +1 -1
  56. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  57. package/dist/components/NSFilterItem.module.css +23 -23
  58. package/dist/components/NSFooter.module.css +126 -126
  59. package/dist/components/NSGroupedList.module.css +70 -70
  60. package/dist/components/NSHeader.module.css +254 -254
  61. package/dist/components/NSLayout.module.css +13 -13
  62. package/dist/components/NSLink.module.css +36 -36
  63. package/dist/components/NSLoading.module.css +29 -29
  64. package/dist/components/NSModal.js +3 -3
  65. package/dist/components/NSModal.js.map +1 -1
  66. package/dist/components/NSModal.module.css +70 -70
  67. package/dist/components/NSPagination.module.css +82 -82
  68. package/dist/components/NSPanel.module.css +46 -46
  69. package/dist/components/NSSection.module.css +10 -10
  70. package/dist/components/NSSectionBars.module.css +10 -10
  71. package/dist/components/NSSectionCards.module.css +38 -38
  72. package/dist/components/NSTabPage.module.css +48 -48
  73. package/dist/components/NSTable.module.css +172 -172
  74. package/dist/components/NSTitle.module.css +15 -15
  75. package/dist/components/NSVerification.module.css +22 -22
  76. package/dist/pages/NSLoginPage.module.css +19 -19
  77. package/dist/pages/NSNotFoundPage.module.css +18 -18
  78. package/package.json +65 -65
  79. package/public/index.html +38 -38
  80. package/src/App.css +16 -16
  81. package/src/App.tsx +156 -155
  82. package/src/CopyToClipboard.ts +6 -6
  83. package/src/Validator.ts +110 -110
  84. package/src/assets/images/404 image.svg +9 -9
  85. package/src/assets/images/404 image_mobile.svg +9 -9
  86. package/src/assets/images/arrow.svg +3 -3
  87. package/src/assets/images/danger.svg +3 -3
  88. package/src/assets/images/exit.svg +3 -3
  89. package/src/assets/images/icon-input-copy.svg +3 -3
  90. package/src/assets/images/icon-input-date.svg +9 -9
  91. package/src/assets/images/icon-input-duration.svg +9 -9
  92. package/src/assets/images/icon-input-email.svg +9 -9
  93. package/src/assets/images/icon-input-float.svg +9 -9
  94. package/src/assets/images/icon-input-integer.svg +9 -9
  95. package/src/assets/images/icon-input-ip.svg +9 -9
  96. package/src/assets/images/icon-input-phone.svg +9 -9
  97. package/src/assets/images/icon-input-price.svg +9 -9
  98. package/src/assets/images/icon-input-search.svg +3 -3
  99. package/src/assets/images/icon-input-string.svg +9 -9
  100. package/src/assets/images/icon-input-text.svg +9 -9
  101. package/src/assets/images/icon-input-time.svg +9 -9
  102. package/src/assets/images/icon-select-box.svg +3 -3
  103. package/src/assets/images/logo.svg +9 -9
  104. package/src/assets/images/menu.svg +3 -3
  105. package/src/assets/images/namira.svg +9 -9
  106. package/src/assets/images/rectangle.svg +3 -3
  107. package/src/components/NSAccess.module.css +38 -38
  108. package/src/components/NSAccess.tsx +25 -25
  109. package/src/components/NSActionMenu.module.css +75 -75
  110. package/src/components/NSActionMenu.tsx +86 -86
  111. package/src/components/NSBarAction.module.css +87 -87
  112. package/src/components/NSBarAction.tsx +87 -87
  113. package/src/components/NSBarHeroBanner.module.css +42 -42
  114. package/src/components/NSBarHeroBanner.tsx +61 -61
  115. package/src/components/NSBarNotification.module.css +31 -31
  116. package/src/components/NSBarNotification.tsx +63 -63
  117. package/src/components/NSBarTitle.module.css +9 -9
  118. package/src/components/NSBarTitle.tsx +28 -28
  119. package/src/components/NSBox.module.css +122 -122
  120. package/src/components/NSBoxBoolean.module.css +54 -54
  121. package/src/components/NSBoxBoolean.tsx +91 -91
  122. package/src/components/NSBoxDate.module.css +39 -39
  123. package/src/components/NSBoxDate.tsx +84 -84
  124. package/src/components/NSBoxDateTime.tsx +84 -84
  125. package/src/components/NSBoxDouble.tsx +90 -90
  126. package/src/components/NSBoxDuration.tsx +88 -88
  127. package/src/components/NSBoxEmail.tsx +148 -148
  128. package/src/components/NSBoxEntity.tsx +120 -120
  129. package/src/components/NSBoxEnum.module.css +38 -38
  130. package/src/components/NSBoxEnum.tsx +127 -127
  131. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  132. package/src/components/NSBoxErrorNotifier.tsx +27 -27
  133. package/src/components/NSBoxIPV4.tsx +93 -93
  134. package/src/components/NSBoxIPV6.tsx +90 -90
  135. package/src/components/NSBoxInteger.tsx +86 -86
  136. package/src/components/NSBoxLabel.module.css +12 -12
  137. package/src/components/NSBoxLabel.tsx +28 -28
  138. package/src/components/NSBoxOTP.module.css +10 -10
  139. package/src/components/NSBoxOTP.tsx +61 -61
  140. package/src/components/NSBoxPassword.tsx +86 -86
  141. package/src/components/NSBoxPhone.tsx +114 -114
  142. package/src/components/NSBoxPrice.tsx +88 -88
  143. package/src/components/NSBoxString.tsx +135 -135
  144. package/src/components/NSBoxTextArea.module.css +76 -76
  145. package/src/components/NSBoxTextArea.tsx +131 -131
  146. package/src/components/NSBoxTime.tsx +88 -88
  147. package/src/components/NSButton.module.css +27 -27
  148. package/src/components/NSButton.tsx +23 -23
  149. package/src/components/NSButtonBlue.module.css +4 -4
  150. package/src/components/NSButtonBlue.tsx +12 -12
  151. package/src/components/NSButtonGreen.module.css +4 -4
  152. package/src/components/NSButtonGreen.tsx +11 -11
  153. package/src/components/NSButtonRed.module.css +4 -4
  154. package/src/components/NSButtonRed.tsx +11 -11
  155. package/src/components/NSCard.module.css +110 -110
  156. package/src/components/NSCard.tsx +69 -69
  157. package/src/components/NSCopyToClipboard.module.css +39 -39
  158. package/src/components/NSCopyToClipboard.tsx +35 -35
  159. package/src/components/NSElectronicCard.module.css +60 -60
  160. package/src/components/NSElectronicCard.tsx +47 -47
  161. package/src/components/NSEntityBar.module.css +77 -77
  162. package/src/components/NSEntityBar.tsx +27 -27
  163. package/src/components/NSEntityCardBackground.module.css +27 -27
  164. package/src/components/NSEntityCardBackground.tsx +34 -34
  165. package/src/components/NSFilterBox.module.css +38 -38
  166. package/src/components/NSFilterBox.tsx +351 -330
  167. package/src/components/NSFilterBoxDialog.module.css +36 -36
  168. package/src/components/NSFilterBoxDialog.tsx +72 -74
  169. package/src/components/NSFilterItem.module.css +23 -23
  170. package/src/components/NSFilterItem.tsx +72 -72
  171. package/src/components/NSFooter.module.css +126 -126
  172. package/src/components/NSFooter.tsx +153 -153
  173. package/src/components/NSGroupedList.module.css +70 -70
  174. package/src/components/NSGroupedList.tsx +64 -64
  175. package/src/components/NSHeader.module.css +254 -254
  176. package/src/components/NSHeader.tsx +187 -187
  177. package/src/components/NSLayout.module.css +13 -13
  178. package/src/components/NSLayout.tsx +75 -75
  179. package/src/components/NSLine.tsx +18 -18
  180. package/src/components/NSLink.module.css +36 -36
  181. package/src/components/NSLink.tsx +25 -25
  182. package/src/components/NSLinkBlue.tsx +20 -20
  183. package/src/components/NSLinkGreen.tsx +5 -5
  184. package/src/components/NSLinkRed.tsx +5 -5
  185. package/src/components/NSLoading.module.css +29 -29
  186. package/src/components/NSLoading.tsx +19 -19
  187. package/src/components/NSModal.module.css +70 -70
  188. package/src/components/NSModal.tsx +64 -62
  189. package/src/components/NSPagination.module.css +82 -82
  190. package/src/components/NSPagination.tsx +124 -124
  191. package/src/components/NSPanel.module.css +46 -46
  192. package/src/components/NSPanel.tsx +19 -19
  193. package/src/components/NSSection.module.css +10 -10
  194. package/src/components/NSSection.tsx +23 -23
  195. package/src/components/NSSectionBars.module.css +10 -10
  196. package/src/components/NSSectionBars.tsx +25 -25
  197. package/src/components/NSSectionCards.module.css +38 -38
  198. package/src/components/NSSectionCards.tsx +51 -51
  199. package/src/components/NSSectionTitle.tsx +21 -21
  200. package/src/components/NSSpace.tsx +28 -28
  201. package/src/components/NSTabPage.module.css +48 -48
  202. package/src/components/NSTabPage.tsx +45 -45
  203. package/src/components/NSTable.module.css +172 -172
  204. package/src/components/NSTable.tsx +190 -190
  205. package/src/components/NSTitle.module.css +15 -15
  206. package/src/components/NSTitle.tsx +19 -19
  207. package/src/components/NSVerification.module.css +22 -22
  208. package/src/components/NSVerification.tsx +41 -41
  209. package/src/index.tsx +7 -7
  210. package/src/main.ts +78 -78
  211. package/src/pages/NSLoginPage.module.css +19 -19
  212. package/src/pages/NSLoginPage.tsx +45 -45
  213. package/src/pages/NSNotFoundPage.module.css +18 -18
  214. package/src/pages/NSNotFoundPage.tsx +11 -11
  215. package/src/props/IBaseComponentProps.ts +7 -7
  216. package/src/props/IHeaderIconProps.ts +9 -9
  217. package/src/props/IHeaderProps.ts +6 -6
  218. package/src/props/IImageProps.ts +4 -4
  219. package/src/props/ILinkProps.ts +5 -5
  220. package/src/props/IValidationNumberProps.ts +4 -4
  221. package/src/props/IValidationProps.ts +7 -7
  222. package/src/props/IValidationRegexProps.ts +4 -4
  223. package/src/props/IValidationStringProps.ts +4 -4
  224. package/src/routing/INSRouterMaker.ts +6 -6
  225. package/src/routing/INSRouterProps.ts +5 -5
  226. package/src/routing/INSRouterState.ts +5 -5
  227. package/src/routing/NSRouterMaker.tsx +33 -33
  228. package/src/routing/Notifier.ts +79 -79
  229. package/tsconfig.json +43 -43
  230. package/dist/App.css +0 -17
  231. package/dist/assets/images/icon-export.svg +0 -3
  232. package/dist/assets/images/icon-input-id.svg +0 -9
  233. package/dist/assets/images/icon-refresh.svg +0 -3
  234. package/dist/components/NSBoxSearch.d.ts +0 -22
  235. package/dist/components/NSBoxSearch.js +0 -54
  236. package/dist/components/NSBoxSearch.js.map +0 -1
  237. package/dist/components/NSBoxText.d.ts +0 -25
  238. package/dist/components/NSBoxText.js +0 -56
  239. package/dist/components/NSBoxText.js.map +0 -1
  240. package/dist/components/NSInput.module.css +0 -74
  241. package/dist/components/NSInputDate.d.ts +0 -21
  242. package/dist/components/NSInputDate.js +0 -41
  243. package/dist/components/NSInputDate.js.map +0 -1
  244. package/dist/components/NSInputDate.module.css +0 -42
  245. package/dist/components/NSInputDuration.d.ts +0 -23
  246. package/dist/components/NSInputDuration.js +0 -42
  247. package/dist/components/NSInputDuration.js.map +0 -1
  248. package/dist/components/NSInputEmail.d.ts +0 -22
  249. package/dist/components/NSInputEmail.js +0 -43
  250. package/dist/components/NSInputEmail.js.map +0 -1
  251. package/dist/components/NSInputErrorNotifier.d.ts +0 -5
  252. package/dist/components/NSInputErrorNotifier.js +0 -7
  253. package/dist/components/NSInputErrorNotifier.js.map +0 -1
  254. package/dist/components/NSInputErrorNotifier.module.css +0 -3
  255. package/dist/components/NSInputFloat.d.ts +0 -22
  256. package/dist/components/NSInputFloat.js +0 -41
  257. package/dist/components/NSInputFloat.js.map +0 -1
  258. package/dist/components/NSInputIP.d.ts +0 -22
  259. package/dist/components/NSInputIP.js +0 -43
  260. package/dist/components/NSInputIP.js.map +0 -1
  261. package/dist/components/NSInputInteger.d.ts +0 -22
  262. package/dist/components/NSInputInteger.js +0 -41
  263. package/dist/components/NSInputInteger.js.map +0 -1
  264. package/dist/components/NSInputPassword.d.ts +0 -22
  265. package/dist/components/NSInputPassword.js +0 -42
  266. package/dist/components/NSInputPassword.js.map +0 -1
  267. package/dist/components/NSInputPhone.d.ts +0 -22
  268. package/dist/components/NSInputPhone.js +0 -38
  269. package/dist/components/NSInputPhone.js.map +0 -1
  270. package/dist/components/NSInputPrice.d.ts +0 -22
  271. package/dist/components/NSInputPrice.js +0 -41
  272. package/dist/components/NSInputPrice.js.map +0 -1
  273. package/dist/components/NSInputSearch.d.ts +0 -22
  274. package/dist/components/NSInputSearch.js +0 -41
  275. package/dist/components/NSInputSearch.js.map +0 -1
  276. package/dist/components/NSInputString.d.ts +0 -22
  277. package/dist/components/NSInputString.js +0 -42
  278. package/dist/components/NSInputString.js.map +0 -1
  279. package/dist/components/NSInputText.d.ts +0 -22
  280. package/dist/components/NSInputText.js +0 -42
  281. package/dist/components/NSInputText.js.map +0 -1
  282. package/dist/components/NSInputTime.d.ts +0 -22
  283. package/dist/components/NSInputTime.js +0 -43
  284. package/dist/components/NSInputTime.js.map +0 -1
  285. package/dist/components/NSLayoutAction.d.ts +0 -5
  286. package/dist/components/NSLayoutAction.js +0 -20
  287. package/dist/components/NSLayoutAction.js.map +0 -1
  288. package/dist/components/NSLayoutAction.module.css +0 -88
  289. package/dist/components/NSLayoutHeroBanner.d.ts +0 -2
  290. package/dist/components/NSLayoutHeroBanner.js +0 -8
  291. package/dist/components/NSLayoutHeroBanner.js.map +0 -1
  292. package/dist/components/NSLayoutHeroBanner.module.css +0 -43
  293. package/dist/components/NSLayoutTitle.d.ts +0 -2
  294. package/dist/components/NSLayoutTitle.js +0 -11
  295. package/dist/components/NSLayoutTitle.js.map +0 -1
  296. package/dist/components/NSLayoutTitle.module.css +0 -10
  297. package/dist/components/NSNotification.d.ts +0 -21
  298. package/dist/components/NSNotification.js +0 -37
  299. package/dist/components/NSNotification.js.map +0 -1
  300. package/dist/components/NSNotification.module.css +0 -32
  301. package/dist/components/NSSelectBox.d.ts +0 -24
  302. package/dist/components/NSSelectBox.js +0 -61
  303. package/dist/components/NSSelectBox.js.map +0 -1
  304. package/dist/components/NSSelectBox.module.css +0 -42
  305. package/dist/index.css +0 -6
  306. package/dist/props/BaseComponentProps.d.ts +0 -6
  307. package/dist/props/BaseComponentProps.js +0 -2
  308. package/dist/props/BaseComponentProps.js.map +0 -10
  309. package/dist/props/INamirasoftProps.d.ts +0 -4
  310. package/dist/props/INamirasoftProps.js +0 -2
  311. package/dist/props/INamirasoftProps.js.map +0 -1
  312. package/dist/props/ImageProps.d.ts +0 -4
  313. package/dist/props/ImageProps.js +0 -2
  314. package/dist/props/ImageProps.js.map +0 -10
  315. package/dist/props/LinkProps.d.ts +0 -5
  316. package/dist/props/LinkProps.js +0 -2
  317. package/dist/props/LinkProps.js.map +0 -10
  318. package/dist/props/ValidationNumberProps.d.ts +0 -4
  319. package/dist/props/ValidationNumberProps.js +0 -2
  320. package/dist/props/ValidationNumberProps.js.map +0 -10
  321. package/dist/props/ValidationProps.d.ts +0 -6
  322. package/dist/props/ValidationProps.js +0 -2
  323. package/dist/props/ValidationProps.js.map +0 -10
  324. package/dist/props/ValidationRegexProps.d.ts +0 -4
  325. package/dist/props/ValidationRegexProps.js +0 -2
  326. package/dist/props/ValidationRegexProps.js.map +0 -1
  327. package/dist/props/ValidationStringProps.d.ts +0 -4
  328. package/dist/props/ValidationStringProps.js +0 -2
  329. package/dist/props/ValidationStringProps.js.map +0 -10
@@ -1,121 +1,121 @@
1
- "use client";
2
- import React from "react";
3
- import Styles from "./NSBoxEnum.module.css";
4
- import { Select, Space } from 'antd';
5
- import IconSelectBox from '../assets/images/icon-select-box.svg';
6
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
- import { IValidationProps } from "../props/IValidationProps";
8
- import { Validator } from "../Validator";
9
- import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
10
- import { BaseOptionType } from "antd/es/select";
11
-
12
- export interface INSBoxEntitOption extends BaseOptionType
13
- {
14
- desc: string;
15
- value: string;
16
- }
17
-
18
- export interface INSBoxEntityProps extends IBaseComponentProps, IValidationProps
19
- {
20
- title: string;
21
- options: INSBoxEntitOption[];
22
- multiple: boolean;
23
- placeHolder?: string;
24
- }
25
-
26
- export interface INSBoxEntityState
27
- {
28
- value: string | null;
29
- values: string[];
30
- error?: string;
31
- }
32
-
33
- export class NSBoxEntity extends React.Component<INSBoxEntityProps, INSBoxEntityState>
34
- {
35
- constructor(props: INSBoxEntityProps)
36
- {
37
- super(props);
38
- this.state = {
39
- value: null,
40
- values: [],
41
- };
42
- this.getValues = this.getValues.bind(this);
43
- this.setValues = this.setValues.bind(this);
44
- this.setValue = this.setValue.bind(this);
45
- this.getValue = this.getValue.bind(this);
46
- this.handleChange = this.handleChange.bind(this);
47
- }
48
- getError(value: string): string | null
49
- {
50
- return (
51
- Validator.getError(this.props.title, value, this.props)
52
- );
53
- }
54
- getValue(): string | null
55
- {
56
- let error = this.getError(this.state.value || "");
57
- if (error)
58
- {
59
- this.setState({ error });
60
- throw new Error(error);
61
- }
62
- return this.state.value;
63
- }
64
- getValues(): string[]
65
- {
66
- this.state.values.forEach(value =>
67
- {
68
- let error = this.getError(value || "");
69
- if (error)
70
- {
71
- this.setState({ error });
72
- throw new Error(error);
73
- }
74
- });
75
- return this.state.values;
76
- }
77
- setValue(value: string | null): void
78
- {
79
- this.setState({ value });
80
- }
81
- setValues(values: string[]): void
82
- {
83
- this.setState({ values });
84
- }
85
- handleChange(value: string | null | string[]): void
86
- {
87
- if (this.props.multiple)
88
- {
89
- this.setValues(value as string[]);
90
- } else
91
- {
92
- this.setValue(value as string | null);
93
- }
94
- }
95
- override render()
96
- {
97
- return (
98
- <>
99
- <div className={`${Styles.ns_input_parent}`}>
100
- <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
101
- <Select
102
- mode={this.props.multiple ? "multiple" : undefined}
103
- style={{ width: '100%' }}
104
- className={Styles.ns_input_select}
105
- placeholder={this.props.placeHolder ?? "Combo Box"}
106
- onChange={this.handleChange}
107
- optionLabelProp="label"
108
- options={this.props.options}
109
- optionRender={(option) => (
110
- <Space className={Styles.ns_input_select_option}>
111
- {option.data.desc}
112
- </Space>
113
- )}
114
- suffixIcon={<img src={IconSelectBox} alt="SelectBox Icon" />}
115
- />
116
- </div>
117
- <NSBoxErrorNotifier error={this.state.error} />
118
- </>
119
- );
120
- }
1
+ "use client";
2
+ import React from "react";
3
+ import Styles from "./NSBoxEnum.module.css";
4
+ import { Select, Space } from 'antd';
5
+ import IconSelectBox from '../assets/images/icon-select-box.svg';
6
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
+ import { IValidationProps } from "../props/IValidationProps";
8
+ import { Validator } from "../Validator";
9
+ import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
10
+ import { BaseOptionType } from "antd/es/select";
11
+
12
+ export interface INSBoxEntitOption extends BaseOptionType
13
+ {
14
+ desc: string;
15
+ value: string;
16
+ }
17
+
18
+ export interface INSBoxEntityProps extends IBaseComponentProps, IValidationProps
19
+ {
20
+ title: string;
21
+ options: INSBoxEntitOption[];
22
+ multiple: boolean;
23
+ placeHolder?: string;
24
+ }
25
+
26
+ export interface INSBoxEntityState
27
+ {
28
+ value: string | null;
29
+ values: string[];
30
+ error?: string;
31
+ }
32
+
33
+ export class NSBoxEntity extends React.Component<INSBoxEntityProps, INSBoxEntityState>
34
+ {
35
+ constructor(props: INSBoxEntityProps)
36
+ {
37
+ super(props);
38
+ this.state = {
39
+ value: null,
40
+ values: [],
41
+ };
42
+ this.getValues = this.getValues.bind(this);
43
+ this.setValues = this.setValues.bind(this);
44
+ this.setValue = this.setValue.bind(this);
45
+ this.getValue = this.getValue.bind(this);
46
+ this.handleChange = this.handleChange.bind(this);
47
+ }
48
+ getError(value: string): string | null
49
+ {
50
+ return (
51
+ Validator.getError(this.props.title, value, this.props)
52
+ );
53
+ }
54
+ getValue(): string | null
55
+ {
56
+ let error = this.getError(this.state.value || "");
57
+ if (error)
58
+ {
59
+ this.setState({ error });
60
+ throw new Error(error);
61
+ }
62
+ return this.state.value;
63
+ }
64
+ getValues(): string[]
65
+ {
66
+ this.state.values.forEach(value =>
67
+ {
68
+ let error = this.getError(value || "");
69
+ if (error)
70
+ {
71
+ this.setState({ error });
72
+ throw new Error(error);
73
+ }
74
+ });
75
+ return this.state.values;
76
+ }
77
+ setValue(value: string | null): void
78
+ {
79
+ this.setState({ value });
80
+ }
81
+ setValues(values: string[]): void
82
+ {
83
+ this.setState({ values });
84
+ }
85
+ handleChange(value: string | null | string[]): void
86
+ {
87
+ if (this.props.multiple)
88
+ {
89
+ this.setValues(value as string[]);
90
+ } else
91
+ {
92
+ this.setValue(value as string | null);
93
+ }
94
+ }
95
+ override render()
96
+ {
97
+ return (
98
+ <>
99
+ <div className={`${Styles.ns_input_parent}`}>
100
+ <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
101
+ <Select
102
+ mode={this.props.multiple ? "multiple" : undefined}
103
+ style={{ width: '100%' }}
104
+ className={Styles.ns_input_select}
105
+ placeholder={this.props.placeHolder ?? "Combo Box"}
106
+ onChange={this.handleChange}
107
+ optionLabelProp="label"
108
+ options={this.props.options}
109
+ optionRender={(option) => (
110
+ <Space className={Styles.ns_input_select_option}>
111
+ {option.data.desc}
112
+ </Space>
113
+ )}
114
+ suffixIcon={<img src={IconSelectBox} alt="SelectBox Icon" />}
115
+ />
116
+ </div>
117
+ <NSBoxErrorNotifier error={this.state.error} />
118
+ </>
119
+ );
120
+ }
121
121
  }
@@ -1,39 +1,39 @@
1
- .ns_input_parent {
2
- width: 100%;
3
- max-width: 100%;
4
- color: #141B5C;
5
- }
6
-
7
- .ns_input_select {
8
- height: 48px;
9
- border: 1px solid #000 !important;
10
- border-radius: 8px;
11
- overflow: hidden;
12
- width: 100% !important;
13
- }
14
-
15
- .ns_input_select span span svg path {
16
- height: 24px !important;
17
- width: 24px !important;
18
- }
19
-
20
- .ns_input_select span span svg {
21
- height: 24px !important;
22
- width: 24px !important;
23
- }
24
-
25
- .ns_input_select span span span svg path {
26
- height: 12px !important;
27
- width: 12px !important;
28
- }
29
-
30
- .ns_input_select span span span svg {
31
- height: 12px !important;
32
- width: 12px !important;
33
- }
34
-
35
- @media only screen and (min-width: 380px) {
36
- .ns_input_parent {
37
- width: 272px;
38
- }
1
+ .ns_input_parent {
2
+ width: 100%;
3
+ max-width: 100%;
4
+ color: #141B5C;
5
+ }
6
+
7
+ .ns_input_select {
8
+ height: 48px;
9
+ border: 1px solid #000 !important;
10
+ border-radius: 8px;
11
+ overflow: hidden;
12
+ width: 100% !important;
13
+ }
14
+
15
+ .ns_input_select span span svg path {
16
+ height: 24px !important;
17
+ width: 24px !important;
18
+ }
19
+
20
+ .ns_input_select span span svg {
21
+ height: 24px !important;
22
+ width: 24px !important;
23
+ }
24
+
25
+ .ns_input_select span span span svg path {
26
+ height: 12px !important;
27
+ width: 12px !important;
28
+ }
29
+
30
+ .ns_input_select span span span svg {
31
+ height: 12px !important;
32
+ width: 12px !important;
33
+ }
34
+
35
+ @media only screen and (min-width: 380px) {
36
+ .ns_input_parent {
37
+ width: 272px;
38
+ }
39
39
  }
@@ -1,128 +1,128 @@
1
- "use client";
2
-
3
- import React from "react";
4
- import Styles from "./NSBoxEnum.module.css";
5
- import { Select, Space } from 'antd';
6
- import IconSelectBox from '../assets/images/icon-select-box.svg';
7
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
8
- import { IValidationProps } from "../props/IValidationProps";
9
- import { Validator } from "../Validator";
10
- import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
11
- import { BaseOptionType } from "antd/es/select";
12
-
13
- export interface INSBoxEnumOption extends BaseOptionType
14
- {
15
- desc: string;
16
- value: string;
17
- }
18
-
19
- export interface INSBoxEnumProps extends IBaseComponentProps, IValidationProps
20
- {
21
- title: string;
22
- options: INSBoxEnumOption[];
23
- multiple: boolean;
24
- placeHolder?: string;
25
- customClass?: string;
26
- }
27
-
28
- export interface INSBoxEnumState
29
- {
30
- value: string | null;
31
- values: string[];
32
- error?: string;
33
- }
34
-
35
- export class NSBoxEnum extends React.Component<INSBoxEnumProps, INSBoxEnumState>
36
- {
37
- constructor(props: INSBoxEnumProps)
38
- {
39
- super(props);
40
- this.state = {
41
- value: null,
42
- values: [],
43
- };
44
- this.getValues = this.getValues.bind(this);
45
- this.setValues = this.setValues.bind(this);
46
- this.setValue = this.setValue.bind(this);
47
- this.getValue = this.getValue.bind(this);
48
- this.handleChange = this.handleChange.bind(this);
49
- }
50
- getError(value: string): string | null
51
- {
52
- return (
53
- Validator.getError(this.props.title, value, this.props)
54
- );
55
- }
56
- getValue(): string | null
57
- {
58
- let error = this.getError(this.state.value || "");
59
- if (error)
60
- {
61
- this.setState({ error });
62
- setTimeout(() =>
63
- {
64
- this.setState({ error: "" });
65
- }, 7000);
66
- throw new Error(error);
67
- }
68
- return this.state.value;
69
- }
70
- getValues(): string[]
71
- {
72
- this.state.values.forEach(value =>
73
- {
74
- let error = this.getError(value || "");
75
- if (error)
76
- {
77
- this.setState({ error });
78
- throw new Error(error);
79
- }
80
- });
81
- return this.state.values;
82
- }
83
- setValue(value: string | null): void
84
- {
85
- this.setState({ value });
86
- }
87
- setValues(values: string[]): void
88
- {
89
- this.setState({ values });
90
- }
91
- handleChange(value: string | null | string[]): void
92
- {
93
- if (this.props.multiple)
94
- {
95
- this.setValues(value as string[]);
96
- } else
97
- {
98
- this.setValue(value as string | null);
99
- }
100
- }
101
- override render()
102
- {
103
- return (
104
- <>
105
- <div className={`${Styles.ns_input_parent} ${this.props.customClass}`}>
106
- <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
107
- <Select
108
- showSearch
109
- mode={this.props.multiple ? "multiple" : undefined}
110
- style={{ width: '100%' }}
111
- className={Styles.ns_input_select}
112
- placeholder={this.props.placeHolder ?? "Combo Box"}
113
- onChange={this.handleChange}
114
- optionLabelProp="label"
115
- options={this.props.options}
116
- optionRender={(option) => (
117
- <Space className={Styles.ns_input_select_option}>
118
- {option.data.desc}
119
- </Space>
120
- )}
121
- suffixIcon={<img src={IconSelectBox} alt="SelectBox Icon" />}
122
- />
123
- </div>
124
- <NSBoxErrorNotifier error={this.state.error} />
125
- </>
126
- );
127
- }
1
+ "use client";
2
+
3
+ import React from "react";
4
+ import Styles from "./NSBoxEnum.module.css";
5
+ import { Select, Space } from 'antd';
6
+ import IconSelectBox from '../assets/images/icon-select-box.svg';
7
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
8
+ import { IValidationProps } from "../props/IValidationProps";
9
+ import { Validator } from "../Validator";
10
+ import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
11
+ import { BaseOptionType } from "antd/es/select";
12
+
13
+ export interface INSBoxEnumOption extends BaseOptionType
14
+ {
15
+ desc: string;
16
+ value: string;
17
+ }
18
+
19
+ export interface INSBoxEnumProps extends IBaseComponentProps, IValidationProps
20
+ {
21
+ title: string;
22
+ options: INSBoxEnumOption[];
23
+ multiple: boolean;
24
+ placeHolder?: string;
25
+ customClass?: string;
26
+ }
27
+
28
+ export interface INSBoxEnumState
29
+ {
30
+ value: string | null;
31
+ values: string[];
32
+ error?: string;
33
+ }
34
+
35
+ export class NSBoxEnum extends React.Component<INSBoxEnumProps, INSBoxEnumState>
36
+ {
37
+ constructor(props: INSBoxEnumProps)
38
+ {
39
+ super(props);
40
+ this.state = {
41
+ value: null,
42
+ values: [],
43
+ };
44
+ this.getValues = this.getValues.bind(this);
45
+ this.setValues = this.setValues.bind(this);
46
+ this.setValue = this.setValue.bind(this);
47
+ this.getValue = this.getValue.bind(this);
48
+ this.handleChange = this.handleChange.bind(this);
49
+ }
50
+ getError(value: string): string | null
51
+ {
52
+ return (
53
+ Validator.getError(this.props.title, value, this.props)
54
+ );
55
+ }
56
+ getValue(): string | null
57
+ {
58
+ let error = this.getError(this.state.value || "");
59
+ if (error)
60
+ {
61
+ this.setState({ error });
62
+ setTimeout(() =>
63
+ {
64
+ this.setState({ error: "" });
65
+ }, 7000);
66
+ throw new Error(error);
67
+ }
68
+ return this.state.value;
69
+ }
70
+ getValues(): string[]
71
+ {
72
+ this.state.values.forEach(value =>
73
+ {
74
+ let error = this.getError(value || "");
75
+ if (error)
76
+ {
77
+ this.setState({ error });
78
+ throw new Error(error);
79
+ }
80
+ });
81
+ return this.state.values;
82
+ }
83
+ setValue(value: string | null): void
84
+ {
85
+ this.setState({ value });
86
+ }
87
+ setValues(values: string[]): void
88
+ {
89
+ this.setState({ values });
90
+ }
91
+ handleChange(value: string | null | string[]): void
92
+ {
93
+ if (this.props.multiple)
94
+ {
95
+ this.setValues(value as string[]);
96
+ } else
97
+ {
98
+ this.setValue(value as string | null);
99
+ }
100
+ }
101
+ override render()
102
+ {
103
+ return (
104
+ <>
105
+ <div className={`${Styles.ns_input_parent} ${this.props.customClass}`}>
106
+ <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
107
+ <Select
108
+ showSearch
109
+ mode={this.props.multiple ? "multiple" : undefined}
110
+ style={{ width: '100%' }}
111
+ className={Styles.ns_input_select}
112
+ placeholder={this.props.placeHolder ?? "Combo Box"}
113
+ onChange={this.handleChange}
114
+ optionLabelProp="label"
115
+ options={this.props.options}
116
+ optionRender={(option) => (
117
+ <Space className={Styles.ns_input_select_option}>
118
+ {option.data.desc}
119
+ </Space>
120
+ )}
121
+ suffixIcon={<img src={IconSelectBox} alt="SelectBox Icon" />}
122
+ />
123
+ </div>
124
+ <NSBoxErrorNotifier error={this.state.error} />
125
+ </>
126
+ );
127
+ }
128
128
  }
@@ -1,3 +1,3 @@
1
- .ns_input_error {
2
- color: #FF3F3F !important;
1
+ .ns_input_error {
2
+ color: #FF3F3F !important;
3
3
  }
@@ -1,28 +1,28 @@
1
- import Styles from "./NSBoxErrorNotifier.module.css";
2
- import Danger from '../assets/images/danger.svg';
3
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
4
-
5
- export interface INSBoxErrorNotifierProps extends IBaseComponentProps
6
- {
7
- error?: string;
8
- }
9
-
10
- export function NSBoxErrorNotifier(props: INSBoxErrorNotifierProps)
11
- {
12
- return <>
13
- {
14
- props.error && (
15
- <div className="d-flex justify-content-start align-items-center gap-2 ms-2">
16
- <img
17
- className={""}
18
- src={Danger}
19
- alt="Error Icon"
20
- width={13}
21
- height={13}
22
- />
23
- <span className={Styles.ns_input_error}>{props.error}</span>
24
- </div >
25
- )
26
- }
27
- </>;
1
+ import Styles from "./NSBoxErrorNotifier.module.css";
2
+ import Danger from '../assets/images/danger.svg';
3
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
4
+
5
+ export interface INSBoxErrorNotifierProps extends IBaseComponentProps
6
+ {
7
+ error?: string;
8
+ }
9
+
10
+ export function NSBoxErrorNotifier(props: INSBoxErrorNotifierProps)
11
+ {
12
+ return <>
13
+ {
14
+ props.error && (
15
+ <div className="d-flex justify-content-start align-items-center gap-2 ms-2">
16
+ <img
17
+ className={""}
18
+ src={Danger}
19
+ alt="Error Icon"
20
+ width={13}
21
+ height={13}
22
+ />
23
+ <span className={Styles.ns_input_error}>{props.error}</span>
24
+ </div >
25
+ )
26
+ }
27
+ </>;
28
28
  }