namirasoft-site-react 1.3.217 → 1.3.219

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