namirasoft-site-react 1.3.229 → 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 (325) hide show
  1. package/config-overrides.js +70 -70
  2. package/dist/assets/images/404 image.svg +9 -9
  3. package/dist/assets/images/404 image_mobile.svg +9 -9
  4. package/dist/assets/images/arrow.svg +3 -3
  5. package/dist/assets/images/danger.svg +3 -3
  6. package/dist/assets/images/exit.svg +3 -3
  7. package/dist/assets/images/icon-input-copy.svg +3 -3
  8. package/dist/assets/images/icon-input-date.svg +9 -9
  9. package/dist/assets/images/icon-input-duration.svg +9 -9
  10. package/dist/assets/images/icon-input-email.svg +9 -9
  11. package/dist/assets/images/icon-input-float.svg +9 -9
  12. package/dist/assets/images/icon-input-integer.svg +9 -9
  13. package/dist/assets/images/icon-input-ip.svg +9 -9
  14. package/dist/assets/images/icon-input-phone.svg +9 -9
  15. package/dist/assets/images/icon-input-price.svg +9 -9
  16. package/dist/assets/images/icon-input-search.svg +3 -3
  17. package/dist/assets/images/icon-input-string.svg +9 -9
  18. package/dist/assets/images/icon-input-text.svg +9 -9
  19. package/dist/assets/images/icon-input-time.svg +9 -9
  20. package/dist/assets/images/icon-select-box.svg +3 -3
  21. package/dist/assets/images/logo.svg +9 -9
  22. package/dist/assets/images/menu.svg +3 -3
  23. package/dist/assets/images/namira.svg +9 -9
  24. package/dist/assets/images/rectangle.svg +3 -3
  25. package/dist/components/NSAccess.module.css +38 -38
  26. package/dist/components/NSActionMenu.js +2 -2
  27. package/dist/components/NSActionMenu.module.css +75 -75
  28. package/dist/components/NSBarAction.module.css +87 -87
  29. package/dist/components/NSBarHeroBanner.module.css +42 -42
  30. package/dist/components/NSBarNotification.module.css +31 -31
  31. package/dist/components/NSBarTitle.module.css +9 -9
  32. package/dist/components/NSBox.module.css +122 -122
  33. package/dist/components/NSBoxBoolean.module.css +54 -54
  34. package/dist/components/NSBoxDate.module.css +39 -39
  35. package/dist/components/NSBoxEnum.module.css +38 -38
  36. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  37. package/dist/components/NSBoxLabel.module.css +12 -12
  38. package/dist/components/NSBoxOTP.module.css +10 -10
  39. package/dist/components/NSBoxTextArea.module.css +76 -76
  40. package/dist/components/NSButton.module.css +27 -27
  41. package/dist/components/NSButtonBlue.module.css +4 -4
  42. package/dist/components/NSButtonGreen.module.css +4 -4
  43. package/dist/components/NSButtonRed.module.css +4 -4
  44. package/dist/components/NSCard.module.css +110 -110
  45. package/dist/components/NSCopyToClipboard.module.css +39 -39
  46. package/dist/components/NSElectronicCard.module.css +60 -60
  47. package/dist/components/NSEntityBar.module.css +77 -77
  48. package/dist/components/NSEntityCardBackground.module.css +27 -27
  49. package/dist/components/NSFilterBox.js +12 -5
  50. package/dist/components/NSFilterBox.js.map +1 -1
  51. package/dist/components/NSFilterBox.module.css +38 -38
  52. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  53. package/dist/components/NSFilterItem.module.css +23 -23
  54. package/dist/components/NSFooter.module.css +126 -126
  55. package/dist/components/NSGroupedList.module.css +70 -70
  56. package/dist/components/NSHeader.module.css +254 -254
  57. package/dist/components/NSLayout.module.css +13 -13
  58. package/dist/components/NSLink.module.css +36 -36
  59. package/dist/components/NSLoading.module.css +29 -29
  60. package/dist/components/NSModal.js +3 -3
  61. package/dist/components/NSModal.js.map +1 -1
  62. package/dist/components/NSModal.module.css +70 -70
  63. package/dist/components/NSPagination.module.css +82 -82
  64. package/dist/components/NSPanel.module.css +46 -46
  65. package/dist/components/NSSection.module.css +10 -10
  66. package/dist/components/NSSectionBars.module.css +10 -10
  67. package/dist/components/NSSectionCards.module.css +38 -38
  68. package/dist/components/NSTabPage.module.css +48 -48
  69. package/dist/components/NSTable.module.css +172 -172
  70. package/dist/components/NSTitle.module.css +15 -15
  71. package/dist/components/NSVerification.module.css +22 -22
  72. package/dist/pages/NSLoginPage.module.css +19 -19
  73. package/dist/pages/NSNotFoundPage.module.css +18 -18
  74. package/package.json +65 -65
  75. package/public/index.html +38 -38
  76. package/src/App.css +16 -16
  77. package/src/App.tsx +156 -156
  78. package/src/CopyToClipboard.ts +6 -6
  79. package/src/Validator.ts +110 -110
  80. package/src/assets/images/404 image.svg +9 -9
  81. package/src/assets/images/404 image_mobile.svg +9 -9
  82. package/src/assets/images/arrow.svg +3 -3
  83. package/src/assets/images/danger.svg +3 -3
  84. package/src/assets/images/exit.svg +3 -3
  85. package/src/assets/images/icon-input-copy.svg +3 -3
  86. package/src/assets/images/icon-input-date.svg +9 -9
  87. package/src/assets/images/icon-input-duration.svg +9 -9
  88. package/src/assets/images/icon-input-email.svg +9 -9
  89. package/src/assets/images/icon-input-float.svg +9 -9
  90. package/src/assets/images/icon-input-integer.svg +9 -9
  91. package/src/assets/images/icon-input-ip.svg +9 -9
  92. package/src/assets/images/icon-input-phone.svg +9 -9
  93. package/src/assets/images/icon-input-price.svg +9 -9
  94. package/src/assets/images/icon-input-search.svg +3 -3
  95. package/src/assets/images/icon-input-string.svg +9 -9
  96. package/src/assets/images/icon-input-text.svg +9 -9
  97. package/src/assets/images/icon-input-time.svg +9 -9
  98. package/src/assets/images/icon-select-box.svg +3 -3
  99. package/src/assets/images/logo.svg +9 -9
  100. package/src/assets/images/menu.svg +3 -3
  101. package/src/assets/images/namira.svg +9 -9
  102. package/src/assets/images/rectangle.svg +3 -3
  103. package/src/components/NSAccess.module.css +38 -38
  104. package/src/components/NSAccess.tsx +25 -25
  105. package/src/components/NSActionMenu.module.css +75 -75
  106. package/src/components/NSActionMenu.tsx +86 -86
  107. package/src/components/NSBarAction.module.css +87 -87
  108. package/src/components/NSBarAction.tsx +87 -87
  109. package/src/components/NSBarHeroBanner.module.css +42 -42
  110. package/src/components/NSBarHeroBanner.tsx +61 -61
  111. package/src/components/NSBarNotification.module.css +31 -31
  112. package/src/components/NSBarNotification.tsx +63 -63
  113. package/src/components/NSBarTitle.module.css +9 -9
  114. package/src/components/NSBarTitle.tsx +28 -28
  115. package/src/components/NSBox.module.css +122 -122
  116. package/src/components/NSBoxBoolean.module.css +54 -54
  117. package/src/components/NSBoxBoolean.tsx +91 -91
  118. package/src/components/NSBoxDate.module.css +39 -39
  119. package/src/components/NSBoxDate.tsx +84 -84
  120. package/src/components/NSBoxDateTime.tsx +84 -84
  121. package/src/components/NSBoxDouble.tsx +90 -90
  122. package/src/components/NSBoxDuration.tsx +88 -88
  123. package/src/components/NSBoxEmail.tsx +148 -148
  124. package/src/components/NSBoxEntity.tsx +120 -120
  125. package/src/components/NSBoxEnum.module.css +38 -38
  126. package/src/components/NSBoxEnum.tsx +127 -127
  127. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  128. package/src/components/NSBoxErrorNotifier.tsx +27 -27
  129. package/src/components/NSBoxIPV4.tsx +93 -93
  130. package/src/components/NSBoxIPV6.tsx +90 -90
  131. package/src/components/NSBoxInteger.tsx +86 -86
  132. package/src/components/NSBoxLabel.module.css +12 -12
  133. package/src/components/NSBoxLabel.tsx +28 -28
  134. package/src/components/NSBoxOTP.module.css +10 -10
  135. package/src/components/NSBoxOTP.tsx +61 -61
  136. package/src/components/NSBoxPassword.tsx +86 -86
  137. package/src/components/NSBoxPhone.tsx +114 -114
  138. package/src/components/NSBoxPrice.tsx +88 -88
  139. package/src/components/NSBoxString.tsx +135 -135
  140. package/src/components/NSBoxTextArea.module.css +76 -76
  141. package/src/components/NSBoxTextArea.tsx +131 -131
  142. package/src/components/NSBoxTime.tsx +88 -88
  143. package/src/components/NSButton.module.css +27 -27
  144. package/src/components/NSButton.tsx +23 -23
  145. package/src/components/NSButtonBlue.module.css +4 -4
  146. package/src/components/NSButtonBlue.tsx +12 -12
  147. package/src/components/NSButtonGreen.module.css +4 -4
  148. package/src/components/NSButtonGreen.tsx +11 -11
  149. package/src/components/NSButtonRed.module.css +4 -4
  150. package/src/components/NSButtonRed.tsx +11 -11
  151. package/src/components/NSCard.module.css +110 -110
  152. package/src/components/NSCard.tsx +69 -69
  153. package/src/components/NSCopyToClipboard.module.css +39 -39
  154. package/src/components/NSCopyToClipboard.tsx +35 -35
  155. package/src/components/NSElectronicCard.module.css +60 -60
  156. package/src/components/NSElectronicCard.tsx +47 -47
  157. package/src/components/NSEntityBar.module.css +77 -77
  158. package/src/components/NSEntityBar.tsx +27 -27
  159. package/src/components/NSEntityCardBackground.module.css +27 -27
  160. package/src/components/NSEntityCardBackground.tsx +34 -34
  161. package/src/components/NSFilterBox.module.css +38 -38
  162. package/src/components/NSFilterBox.tsx +351 -341
  163. package/src/components/NSFilterBoxDialog.module.css +36 -36
  164. package/src/components/NSFilterBoxDialog.tsx +72 -72
  165. package/src/components/NSFilterItem.module.css +23 -23
  166. package/src/components/NSFilterItem.tsx +72 -72
  167. package/src/components/NSFooter.module.css +126 -126
  168. package/src/components/NSFooter.tsx +153 -153
  169. package/src/components/NSGroupedList.module.css +70 -70
  170. package/src/components/NSGroupedList.tsx +64 -64
  171. package/src/components/NSHeader.module.css +254 -254
  172. package/src/components/NSHeader.tsx +187 -187
  173. package/src/components/NSLayout.module.css +13 -13
  174. package/src/components/NSLayout.tsx +75 -75
  175. package/src/components/NSLine.tsx +18 -18
  176. package/src/components/NSLink.module.css +36 -36
  177. package/src/components/NSLink.tsx +25 -25
  178. package/src/components/NSLinkBlue.tsx +20 -20
  179. package/src/components/NSLinkGreen.tsx +5 -5
  180. package/src/components/NSLinkRed.tsx +5 -5
  181. package/src/components/NSLoading.module.css +29 -29
  182. package/src/components/NSLoading.tsx +19 -19
  183. package/src/components/NSModal.module.css +70 -70
  184. package/src/components/NSModal.tsx +64 -62
  185. package/src/components/NSPagination.module.css +82 -82
  186. package/src/components/NSPagination.tsx +124 -124
  187. package/src/components/NSPanel.module.css +46 -46
  188. package/src/components/NSPanel.tsx +19 -19
  189. package/src/components/NSSection.module.css +10 -10
  190. package/src/components/NSSection.tsx +23 -23
  191. package/src/components/NSSectionBars.module.css +10 -10
  192. package/src/components/NSSectionBars.tsx +25 -25
  193. package/src/components/NSSectionCards.module.css +38 -38
  194. package/src/components/NSSectionCards.tsx +51 -51
  195. package/src/components/NSSectionTitle.tsx +21 -21
  196. package/src/components/NSSpace.tsx +28 -28
  197. package/src/components/NSTabPage.module.css +48 -48
  198. package/src/components/NSTabPage.tsx +45 -45
  199. package/src/components/NSTable.module.css +172 -172
  200. package/src/components/NSTable.tsx +190 -190
  201. package/src/components/NSTitle.module.css +15 -15
  202. package/src/components/NSTitle.tsx +19 -19
  203. package/src/components/NSVerification.module.css +22 -22
  204. package/src/components/NSVerification.tsx +41 -41
  205. package/src/index.tsx +7 -7
  206. package/src/main.ts +78 -78
  207. package/src/pages/NSLoginPage.module.css +19 -19
  208. package/src/pages/NSLoginPage.tsx +45 -45
  209. package/src/pages/NSNotFoundPage.module.css +18 -18
  210. package/src/pages/NSNotFoundPage.tsx +11 -11
  211. package/src/props/IBaseComponentProps.ts +7 -7
  212. package/src/props/IHeaderIconProps.ts +9 -9
  213. package/src/props/IHeaderProps.ts +6 -6
  214. package/src/props/IImageProps.ts +4 -4
  215. package/src/props/ILinkProps.ts +5 -5
  216. package/src/props/IValidationNumberProps.ts +4 -4
  217. package/src/props/IValidationProps.ts +7 -7
  218. package/src/props/IValidationRegexProps.ts +4 -4
  219. package/src/props/IValidationStringProps.ts +4 -4
  220. package/src/routing/INSRouterMaker.ts +6 -6
  221. package/src/routing/INSRouterProps.ts +5 -5
  222. package/src/routing/INSRouterState.ts +5 -5
  223. package/src/routing/NSRouterMaker.tsx +33 -33
  224. package/src/routing/Notifier.ts +79 -79
  225. package/tsconfig.json +43 -43
  226. package/dist/App.css +0 -17
  227. package/dist/assets/images/icon-export.svg +0 -3
  228. package/dist/assets/images/icon-input-id.svg +0 -9
  229. package/dist/assets/images/icon-refresh.svg +0 -3
  230. package/dist/components/NSBoxSearch.d.ts +0 -22
  231. package/dist/components/NSBoxSearch.js +0 -54
  232. package/dist/components/NSBoxSearch.js.map +0 -1
  233. package/dist/components/NSBoxText.d.ts +0 -25
  234. package/dist/components/NSBoxText.js +0 -56
  235. package/dist/components/NSBoxText.js.map +0 -1
  236. package/dist/components/NSInput.module.css +0 -74
  237. package/dist/components/NSInputDate.d.ts +0 -21
  238. package/dist/components/NSInputDate.js +0 -41
  239. package/dist/components/NSInputDate.js.map +0 -1
  240. package/dist/components/NSInputDate.module.css +0 -42
  241. package/dist/components/NSInputDuration.d.ts +0 -23
  242. package/dist/components/NSInputDuration.js +0 -42
  243. package/dist/components/NSInputDuration.js.map +0 -1
  244. package/dist/components/NSInputEmail.d.ts +0 -22
  245. package/dist/components/NSInputEmail.js +0 -43
  246. package/dist/components/NSInputEmail.js.map +0 -1
  247. package/dist/components/NSInputErrorNotifier.d.ts +0 -5
  248. package/dist/components/NSInputErrorNotifier.js +0 -7
  249. package/dist/components/NSInputErrorNotifier.js.map +0 -1
  250. package/dist/components/NSInputErrorNotifier.module.css +0 -3
  251. package/dist/components/NSInputFloat.d.ts +0 -22
  252. package/dist/components/NSInputFloat.js +0 -41
  253. package/dist/components/NSInputFloat.js.map +0 -1
  254. package/dist/components/NSInputIP.d.ts +0 -22
  255. package/dist/components/NSInputIP.js +0 -43
  256. package/dist/components/NSInputIP.js.map +0 -1
  257. package/dist/components/NSInputInteger.d.ts +0 -22
  258. package/dist/components/NSInputInteger.js +0 -41
  259. package/dist/components/NSInputInteger.js.map +0 -1
  260. package/dist/components/NSInputPassword.d.ts +0 -22
  261. package/dist/components/NSInputPassword.js +0 -42
  262. package/dist/components/NSInputPassword.js.map +0 -1
  263. package/dist/components/NSInputPhone.d.ts +0 -22
  264. package/dist/components/NSInputPhone.js +0 -38
  265. package/dist/components/NSInputPhone.js.map +0 -1
  266. package/dist/components/NSInputPrice.d.ts +0 -22
  267. package/dist/components/NSInputPrice.js +0 -41
  268. package/dist/components/NSInputPrice.js.map +0 -1
  269. package/dist/components/NSInputSearch.d.ts +0 -22
  270. package/dist/components/NSInputSearch.js +0 -41
  271. package/dist/components/NSInputSearch.js.map +0 -1
  272. package/dist/components/NSInputString.d.ts +0 -22
  273. package/dist/components/NSInputString.js +0 -42
  274. package/dist/components/NSInputString.js.map +0 -1
  275. package/dist/components/NSInputText.d.ts +0 -22
  276. package/dist/components/NSInputText.js +0 -42
  277. package/dist/components/NSInputText.js.map +0 -1
  278. package/dist/components/NSInputTime.d.ts +0 -22
  279. package/dist/components/NSInputTime.js +0 -43
  280. package/dist/components/NSInputTime.js.map +0 -1
  281. package/dist/components/NSLayoutAction.d.ts +0 -5
  282. package/dist/components/NSLayoutAction.js +0 -20
  283. package/dist/components/NSLayoutAction.js.map +0 -1
  284. package/dist/components/NSLayoutAction.module.css +0 -88
  285. package/dist/components/NSLayoutHeroBanner.d.ts +0 -2
  286. package/dist/components/NSLayoutHeroBanner.js +0 -8
  287. package/dist/components/NSLayoutHeroBanner.js.map +0 -1
  288. package/dist/components/NSLayoutHeroBanner.module.css +0 -43
  289. package/dist/components/NSLayoutTitle.d.ts +0 -2
  290. package/dist/components/NSLayoutTitle.js +0 -11
  291. package/dist/components/NSLayoutTitle.js.map +0 -1
  292. package/dist/components/NSLayoutTitle.module.css +0 -10
  293. package/dist/components/NSNotification.d.ts +0 -21
  294. package/dist/components/NSNotification.js +0 -37
  295. package/dist/components/NSNotification.js.map +0 -1
  296. package/dist/components/NSNotification.module.css +0 -32
  297. package/dist/components/NSSelectBox.d.ts +0 -24
  298. package/dist/components/NSSelectBox.js +0 -61
  299. package/dist/components/NSSelectBox.js.map +0 -1
  300. package/dist/components/NSSelectBox.module.css +0 -42
  301. package/dist/index.css +0 -6
  302. package/dist/props/BaseComponentProps.d.ts +0 -6
  303. package/dist/props/BaseComponentProps.js +0 -2
  304. package/dist/props/BaseComponentProps.js.map +0 -10
  305. package/dist/props/INamirasoftProps.d.ts +0 -4
  306. package/dist/props/INamirasoftProps.js +0 -2
  307. package/dist/props/INamirasoftProps.js.map +0 -1
  308. package/dist/props/ImageProps.d.ts +0 -4
  309. package/dist/props/ImageProps.js +0 -2
  310. package/dist/props/ImageProps.js.map +0 -10
  311. package/dist/props/LinkProps.d.ts +0 -5
  312. package/dist/props/LinkProps.js +0 -2
  313. package/dist/props/LinkProps.js.map +0 -10
  314. package/dist/props/ValidationNumberProps.d.ts +0 -4
  315. package/dist/props/ValidationNumberProps.js +0 -2
  316. package/dist/props/ValidationNumberProps.js.map +0 -10
  317. package/dist/props/ValidationProps.d.ts +0 -6
  318. package/dist/props/ValidationProps.js +0 -2
  319. package/dist/props/ValidationProps.js.map +0 -10
  320. package/dist/props/ValidationRegexProps.d.ts +0 -4
  321. package/dist/props/ValidationRegexProps.js +0 -2
  322. package/dist/props/ValidationRegexProps.js.map +0 -1
  323. package/dist/props/ValidationStringProps.d.ts +0 -4
  324. package/dist/props/ValidationStringProps.js +0 -2
  325. 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
  }