namirasoft-site-react 1.4.91 → 1.4.92

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 (268) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +70 -70
  5. package/dist/App.css +58 -0
  6. package/dist/components/NSAccordion.module.css +4 -4
  7. package/dist/components/NSActionMenu.js +2 -2
  8. package/dist/components/NSActionMenu.module.css +98 -98
  9. package/dist/components/NSAssistantButton.module.css +135 -135
  10. package/dist/components/NSBarAction.module.css +97 -97
  11. package/dist/components/NSBarAlert.module.css +69 -69
  12. package/dist/components/NSBarHeroBanner.module.css +42 -42
  13. package/dist/components/NSBarNotification.module.css +34 -34
  14. package/dist/components/NSBarTitle.module.css +9 -9
  15. package/dist/components/NSBox.module.css +126 -126
  16. package/dist/components/NSBoxBoolean.module.css +88 -88
  17. package/dist/components/NSBoxCombo.module.css +6 -6
  18. package/dist/components/NSBoxCopy.module.css +43 -43
  19. package/dist/components/NSBoxDate.module.css +53 -53
  20. package/dist/components/NSBoxDateTime.module.css +48 -48
  21. package/dist/components/NSBoxEntity.module.css +21 -21
  22. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  23. package/dist/components/NSBoxFile.module.css +4 -4
  24. package/dist/components/NSBoxLabel.module.css +14 -14
  25. package/dist/components/NSBoxRadio.module.css +70 -70
  26. package/dist/components/NSBoxTextArea.module.css +83 -83
  27. package/dist/components/NSButton.module.css +42 -42
  28. package/dist/components/NSButtonBlue.module.css +4 -4
  29. package/dist/components/NSButtonGreen.module.css +4 -4
  30. package/dist/components/NSButtonRed.module.css +4 -4
  31. package/dist/components/NSCard.module.css +114 -114
  32. package/dist/components/NSCardScreenshot.module.css +41 -41
  33. package/dist/components/NSChartColumn.module.css +7 -7
  34. package/dist/components/NSChartPie.module.css +0 -0
  35. package/dist/components/NSChartTable.module.css +21 -21
  36. package/dist/components/NSCopyToClipboard.d.ts +7 -0
  37. package/dist/components/NSCopyToClipboard.js +13 -0
  38. package/dist/components/NSCopyToClipboard.js.map +1 -0
  39. package/dist/components/NSCopyToClipboard.module.css +44 -0
  40. package/dist/components/NSDialog.module.css +106 -106
  41. package/dist/components/NSDownTimer.module.css +55 -55
  42. package/dist/components/NSDownload.module.css +46 -46
  43. package/dist/components/NSElectronicCard.module.css +60 -60
  44. package/dist/components/NSEntityBar.module.css +77 -77
  45. package/dist/components/NSEntityCardBackground.module.css +27 -27
  46. package/dist/components/NSFilterBox.module.css +62 -62
  47. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  48. package/dist/components/NSFilterItem.module.css +23 -23
  49. package/dist/components/NSFooter.module.css +123 -123
  50. package/dist/components/NSGroupedList.module.css +72 -72
  51. package/dist/components/NSHeader.module.css +291 -291
  52. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  53. package/dist/components/NSLayout.module.css +13 -13
  54. package/dist/components/NSLine.module.css +12 -12
  55. package/dist/components/NSLink.module.css +36 -36
  56. package/dist/components/NSLoading.module.css +30 -30
  57. package/dist/components/NSNoData.module.css +8 -8
  58. package/dist/components/NSPageSelectionModal.module.css +103 -103
  59. package/dist/components/NSPagination.module.css +110 -110
  60. package/dist/components/NSPanel.module.css +46 -46
  61. package/dist/components/NSRadioButton.d.ts +25 -0
  62. package/dist/components/NSRadioButton.js +49 -0
  63. package/dist/components/NSRadioButton.js.map +1 -0
  64. package/dist/components/NSRange.module.css +66 -66
  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 +59 -59
  69. package/dist/components/NSTable.module.css +291 -291
  70. package/dist/components/NSTag.module.css +52 -52
  71. package/dist/components/NSTimeTable.module.css +6 -6
  72. package/dist/components/NSTimelineMonthly.module.css +71 -71
  73. package/dist/components/NSTitle.module.css +15 -15
  74. package/dist/index.css +6 -0
  75. package/dist/pages/NSNotFoundPage.module.css +17 -17
  76. package/dist/pages/NSUpdating.module.css +35 -35
  77. package/package.json +72 -72
  78. package/public/index.html +38 -38
  79. package/src/App.css +57 -57
  80. package/src/App.tsx +406 -406
  81. package/src/Color.tsx +10 -10
  82. package/src/CopyToClipboard.ts +6 -6
  83. package/src/Validator.ts +117 -117
  84. package/src/components/NSAccordion.module.css +4 -4
  85. package/src/components/NSAccordion.tsx +51 -51
  86. package/src/components/NSActionMenu.module.css +98 -98
  87. package/src/components/NSActionMenu.tsx +90 -90
  88. package/src/components/NSAssistantButton.module.css +135 -135
  89. package/src/components/NSAssistantButton.tsx +70 -70
  90. package/src/components/NSBarAction.module.css +97 -97
  91. package/src/components/NSBarAction.tsx +89 -89
  92. package/src/components/NSBarAlert.module.css +69 -69
  93. package/src/components/NSBarAlert.tsx +30 -30
  94. package/src/components/NSBarHeroBanner.module.css +42 -42
  95. package/src/components/NSBarHeroBanner.tsx +61 -61
  96. package/src/components/NSBarNotification.module.css +34 -34
  97. package/src/components/NSBarNotification.tsx +87 -87
  98. package/src/components/NSBarTitle.module.css +9 -9
  99. package/src/components/NSBarTitle.tsx +29 -29
  100. package/src/components/NSBox.module.css +126 -126
  101. package/src/components/NSBoxBoolean.module.css +88 -88
  102. package/src/components/NSBoxBoolean.tsx +124 -124
  103. package/src/components/NSBoxBooleans.tsx +159 -159
  104. package/src/components/NSBoxCombo.module.css +6 -6
  105. package/src/components/NSBoxCombo.tsx +151 -151
  106. package/src/components/NSBoxCopy.module.css +43 -43
  107. package/src/components/NSBoxCopy.tsx +41 -41
  108. package/src/components/NSBoxDate.module.css +53 -53
  109. package/src/components/NSBoxDate.tsx +88 -88
  110. package/src/components/NSBoxDateTime.module.css +48 -48
  111. package/src/components/NSBoxDateTime.tsx +89 -89
  112. package/src/components/NSBoxDouble.tsx +92 -92
  113. package/src/components/NSBoxDuration.tsx +92 -92
  114. package/src/components/NSBoxEmail.tsx +103 -103
  115. package/src/components/NSBoxEntity.module.css +21 -21
  116. package/src/components/NSBoxEntity.tsx +197 -197
  117. package/src/components/NSBoxEnum.tsx +55 -55
  118. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  119. package/src/components/NSBoxErrorNotifier.tsx +32 -32
  120. package/src/components/NSBoxFile.module.css +4 -4
  121. package/src/components/NSBoxFile.tsx +124 -124
  122. package/src/components/NSBoxIPV4.tsx +97 -97
  123. package/src/components/NSBoxIPV6.tsx +94 -94
  124. package/src/components/NSBoxInteger.tsx +94 -94
  125. package/src/components/NSBoxLabel.module.css +14 -14
  126. package/src/components/NSBoxLabel.tsx +29 -29
  127. package/src/components/NSBoxPassword.tsx +90 -90
  128. package/src/components/NSBoxPhone.tsx +97 -97
  129. package/src/components/NSBoxPrice.tsx +92 -92
  130. package/src/components/NSBoxRadio.module.css +70 -70
  131. package/src/components/NSBoxRadio.tsx +111 -111
  132. package/src/components/NSBoxSearch.tsx +107 -107
  133. package/src/components/NSBoxString.tsx +106 -106
  134. package/src/components/NSBoxTextArea.module.css +83 -83
  135. package/src/components/NSBoxTextArea.tsx +112 -112
  136. package/src/components/NSBoxTime.tsx +92 -92
  137. package/src/components/NSButton.module.css +42 -42
  138. package/src/components/NSButton.tsx +25 -25
  139. package/src/components/NSButtonBlue.module.css +4 -4
  140. package/src/components/NSButtonBlue.tsx +19 -19
  141. package/src/components/NSButtonGreen.module.css +4 -4
  142. package/src/components/NSButtonGreen.tsx +19 -19
  143. package/src/components/NSButtonRed.module.css +4 -4
  144. package/src/components/NSButtonRed.tsx +19 -19
  145. package/src/components/NSCard.module.css +114 -114
  146. package/src/components/NSCard.tsx +63 -63
  147. package/src/components/NSCardScreenshot.module.css +41 -41
  148. package/src/components/NSCardScreenshot.tsx +31 -31
  149. package/src/components/NSChartColumn.module.css +7 -7
  150. package/src/components/NSChartColumn.tsx +106 -106
  151. package/src/components/NSChartDoughnut.tsx +108 -108
  152. package/src/components/NSChartPie.tsx +105 -105
  153. package/src/components/NSChartRange.tsx +16 -16
  154. package/src/components/NSChartTable.module.css +21 -21
  155. package/src/components/NSChartTable.tsx +94 -94
  156. package/src/components/NSCopy.tsx +67 -67
  157. package/src/components/NSDeleteDialog.tsx +26 -26
  158. package/src/components/NSDialog.module.css +106 -106
  159. package/src/components/NSDialog.tsx +47 -47
  160. package/src/components/NSDownTimer.module.css +55 -55
  161. package/src/components/NSDownTimer.tsx +77 -77
  162. package/src/components/NSDownload.module.css +46 -46
  163. package/src/components/NSDownload.tsx +62 -62
  164. package/src/components/NSElectronicCard.module.css +60 -60
  165. package/src/components/NSElectronicCard.tsx +45 -45
  166. package/src/components/NSEntityBar.module.css +77 -77
  167. package/src/components/NSEntityBar.tsx +27 -27
  168. package/src/components/NSEntityCardBackground.module.css +27 -27
  169. package/src/components/NSEntityCardBackground.tsx +34 -34
  170. package/src/components/NSFilterBox.module.css +62 -62
  171. package/src/components/NSFilterBox.tsx +352 -352
  172. package/src/components/NSFilterBoxDialog.module.css +36 -36
  173. package/src/components/NSFilterBoxDialog.tsx +74 -74
  174. package/src/components/NSFilterItem.module.css +23 -23
  175. package/src/components/NSFilterItem.tsx +73 -73
  176. package/src/components/NSFooter.module.css +123 -123
  177. package/src/components/NSFooter.tsx +289 -289
  178. package/src/components/NSGroupedList.module.css +72 -72
  179. package/src/components/NSGroupedList.tsx +115 -115
  180. package/src/components/NSHeader.module.css +291 -291
  181. package/src/components/NSHeader.tsx +250 -250
  182. package/src/components/NSHeaderScreenshot.module.css +35 -35
  183. package/src/components/NSHeaderScreenshot.tsx +38 -38
  184. package/src/components/NSInfoDialog.tsx +36 -36
  185. package/src/components/NSLayout.module.css +13 -13
  186. package/src/components/NSLayout.tsx +109 -109
  187. package/src/components/NSLine.module.css +12 -12
  188. package/src/components/NSLine.tsx +15 -15
  189. package/src/components/NSLink.module.css +36 -36
  190. package/src/components/NSLink.tsx +25 -25
  191. package/src/components/NSLinkBlue.tsx +20 -20
  192. package/src/components/NSLinkGreen.tsx +5 -5
  193. package/src/components/NSLinkRed.tsx +5 -5
  194. package/src/components/NSLoading.module.css +30 -30
  195. package/src/components/NSLoading.tsx +20 -20
  196. package/src/components/NSNoData.module.css +8 -8
  197. package/src/components/NSNoData.tsx +24 -24
  198. package/src/components/NSPageSelectionModal.module.css +103 -103
  199. package/src/components/NSPageSelectionModal.tsx +228 -228
  200. package/src/components/NSPagination.module.css +110 -110
  201. package/src/components/NSPagination.tsx +191 -191
  202. package/src/components/NSPanel.module.css +46 -46
  203. package/src/components/NSPanel.tsx +19 -19
  204. package/src/components/NSProductList.tsx +43 -43
  205. package/src/components/NSRange.module.css +66 -66
  206. package/src/components/NSRange.tsx +81 -81
  207. package/src/components/NSRepeater.tsx +175 -175
  208. package/src/components/NSSection.module.css +10 -10
  209. package/src/components/NSSection.tsx +23 -23
  210. package/src/components/NSSectionBars.module.css +10 -10
  211. package/src/components/NSSectionBars.tsx +25 -25
  212. package/src/components/NSSectionCards.module.css +38 -38
  213. package/src/components/NSSectionCards.tsx +51 -51
  214. package/src/components/NSSectionTitle.tsx +21 -21
  215. package/src/components/NSSpace.tsx +28 -28
  216. package/src/components/NSTabPage.module.css +59 -59
  217. package/src/components/NSTabPage.tsx +78 -78
  218. package/src/components/NSTable.module.css +291 -291
  219. package/src/components/NSTable.tsx +439 -439
  220. package/src/components/NSTag.module.css +52 -52
  221. package/src/components/NSTag.tsx +73 -73
  222. package/src/components/NSTimeTable.module.css +6 -6
  223. package/src/components/NSTimeTable.tsx +49 -49
  224. package/src/components/NSTimelineMonthly.module.css +71 -71
  225. package/src/components/NSTimelineMonthly.tsx +42 -42
  226. package/src/components/NSTitle.module.css +15 -15
  227. package/src/components/NSTitle.tsx +19 -19
  228. package/src/formatter/BackColorFormatter.tsx +20 -20
  229. package/src/formatter/BaseColumnFormatter.ts +14 -14
  230. package/src/formatter/BooleanFormatter.ts +20 -20
  231. package/src/formatter/DateFormatter.ts +15 -15
  232. package/src/formatter/DateTimeFormatter.ts +15 -15
  233. package/src/formatter/DurationFormatter.ts +8 -8
  234. package/src/formatter/EmailFormatter.ts +8 -8
  235. package/src/formatter/EnumFormatter.ts +8 -8
  236. package/src/formatter/FloatFormatter.ts +8 -8
  237. package/src/formatter/ForeColorFormatter.tsx +20 -20
  238. package/src/formatter/ForeignIDFormatter.ts +8 -8
  239. package/src/formatter/IDFormatter.ts +8 -8
  240. package/src/formatter/IPFormatter.ts +8 -8
  241. package/src/formatter/IntegerFormatter.ts +8 -8
  242. package/src/formatter/JsonFormatter.ts +8 -8
  243. package/src/formatter/MoneyFormatter.ts +8 -8
  244. package/src/formatter/PhoneFormatter.ts +8 -8
  245. package/src/formatter/StringFormatter.ts +8 -8
  246. package/src/formatter/TimeFormatter.ts +16 -16
  247. package/src/formatter/UnknowFormatter.ts +8 -8
  248. package/src/index.tsx +7 -7
  249. package/src/main.ts +118 -118
  250. package/src/pages/NSNotFoundPage.module.css +17 -17
  251. package/src/pages/NSNotFoundPage.tsx +11 -11
  252. package/src/pages/NSUpdating.module.css +35 -35
  253. package/src/pages/NSUpdating.tsx +32 -32
  254. package/src/props/IBaseComponentProps.ts +8 -8
  255. package/src/props/IHeaderIconProps.ts +10 -10
  256. package/src/props/IHeaderProps.ts +7 -7
  257. package/src/props/IImageProps.ts +4 -4
  258. package/src/props/ILinkProps.ts +5 -5
  259. package/src/props/IValidationNumberProps.ts +4 -4
  260. package/src/props/IValidationProps.ts +7 -7
  261. package/src/props/IValidationRegexProps.ts +4 -4
  262. package/src/props/IValidationStringProps.ts +4 -4
  263. package/src/routing/INSRouterMaker.ts +6 -6
  264. package/src/routing/INSRouterProps.ts +5 -5
  265. package/src/routing/INSRouterState.ts +5 -5
  266. package/src/routing/NSRouterMaker.tsx +33 -33
  267. package/src/routing/Notifier.ts +79 -79
  268. package/tsconfig.json +43 -43
@@ -1,90 +1,90 @@
1
- "use client";
2
-
3
- import React from "react";
4
- import Styles from "./NSBoxDateTime.module.css";
5
- import StyleNSBox from "./NSBox.module.css";
6
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
- import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
8
- import { IValidationProps } from "../props/IValidationProps";
9
- import { Validator } from "../Validator";
10
-
11
- export interface INSBoxDateTimeProps extends IBaseComponentProps, IValidationProps
12
- {
13
- title: string;
14
- placeholder?: string;
15
- defaultValue?: string;
16
- onChanged?: (e: NSBoxDateTime, callback?: () => void) => void;
17
- onClicked?: (e: NSBoxDateTime) => void;
18
- }
19
-
20
- export interface INSBoxDateTimeState
21
- {
22
- value: string;
23
- error?: string;
24
- }
25
-
26
- export class NSBoxDateTime extends React.Component<INSBoxDateTimeProps, INSBoxDateTimeState>
27
- {
28
- constructor(props: INSBoxDateTimeProps)
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.getErrorDate(this.props.title, this.state.value)
41
- );
42
- }
43
- getValue(checkError: boolean = true): string
44
- {
45
- if (checkError)
46
- {
47
- let error = this.getError();
48
- if (error)
49
- {
50
- this.setState({ error });
51
- throw new Error(error);
52
- }
53
- }
54
- return this.state.value;
55
- }
56
- setValue(value: string, callback?: () => void): void
57
- {
58
- this.setState({ value }, () =>
59
- {
60
- if (this.props.onChanged)
61
- this.props.onChanged(this, callback);
62
- else if (callback)
63
- callback();
64
- });
65
- }
66
- private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
67
- {
68
- this.setValue(e.target.value);
69
- }
70
- override render()
71
- {
72
- return (
73
- <>
74
- <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
75
- <span className={StyleNSBox.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
76
- <input
77
- type="datetime-local"
78
- name={this.props.name}
79
- className={Styles.ns_input}
80
- placeholder={this.props.placeholder}
81
- value={this.state.value}
82
- onChange={this.onChanged}
83
- onClick={() => this.props.onClicked}
84
- />
85
- <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
86
- </div>
87
- </>
88
- );
89
- }
1
+ "use client";
2
+
3
+ import React from "react";
4
+ import Styles from "./NSBoxDateTime.module.css";
5
+ import StyleNSBox from "./NSBox.module.css";
6
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
+ import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
8
+ import { IValidationProps } from "../props/IValidationProps";
9
+ import { Validator } from "../Validator";
10
+
11
+ export interface INSBoxDateTimeProps extends IBaseComponentProps, IValidationProps
12
+ {
13
+ title: string;
14
+ placeholder?: string;
15
+ defaultValue?: string;
16
+ onChanged?: (e: NSBoxDateTime, callback?: () => void) => void;
17
+ onClicked?: (e: NSBoxDateTime) => void;
18
+ }
19
+
20
+ export interface INSBoxDateTimeState
21
+ {
22
+ value: string;
23
+ error?: string;
24
+ }
25
+
26
+ export class NSBoxDateTime extends React.Component<INSBoxDateTimeProps, INSBoxDateTimeState>
27
+ {
28
+ constructor(props: INSBoxDateTimeProps)
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.getErrorDate(this.props.title, this.state.value)
41
+ );
42
+ }
43
+ getValue(checkError: boolean = true): string
44
+ {
45
+ if (checkError)
46
+ {
47
+ let error = this.getError();
48
+ if (error)
49
+ {
50
+ this.setState({ error });
51
+ throw new Error(error);
52
+ }
53
+ }
54
+ return this.state.value;
55
+ }
56
+ setValue(value: string, callback?: () => void): void
57
+ {
58
+ this.setState({ value }, () =>
59
+ {
60
+ if (this.props.onChanged)
61
+ this.props.onChanged(this, callback);
62
+ else if (callback)
63
+ callback();
64
+ });
65
+ }
66
+ private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
67
+ {
68
+ this.setValue(e.target.value);
69
+ }
70
+ override render()
71
+ {
72
+ return (
73
+ <>
74
+ <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
75
+ <span className={StyleNSBox.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
76
+ <input
77
+ type="datetime-local"
78
+ name={this.props.name}
79
+ className={Styles.ns_input}
80
+ placeholder={this.props.placeholder}
81
+ value={this.state.value}
82
+ onChange={this.onChanged}
83
+ onClick={() => this.props.onClicked}
84
+ />
85
+ <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
86
+ </div>
87
+ </>
88
+ );
89
+ }
90
90
  }
@@ -1,93 +1,93 @@
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 { IValidationNumberProps } from "../props/IValidationNumberProps";
8
- import { Validator } from "../Validator";
9
- import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
10
-
11
- export interface INSBoxDoubleProps extends IBaseComponentProps, IValidationProps, IValidationNumberProps
12
- {
13
- title: string;
14
- placeholder?: string;
15
- defaultValue?: number;
16
- onChanged?: (e: NSBoxDouble, callback?: () => void) => void;
17
- onClicked?: (e: NSBoxDouble) => void;
18
- }
19
-
20
- export interface INSBoxDoubleState
21
- {
22
- value?: number;
23
- error?: string;
24
- }
25
-
26
- export class NSBoxDouble extends React.Component<INSBoxDoubleProps, INSBoxDoubleState>
27
- {
28
- constructor(props: INSBoxDoubleProps)
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(checkError: boolean = true): number | undefined
44
- {
45
- if (checkError)
46
- {
47
- let error = this.getError();
48
- if (error)
49
- {
50
- this.setState({ error });
51
- throw new Error(error);
52
- }
53
- }
54
- return this.state.value;
55
- }
56
- setValue(value: number | undefined, callback?: () => void): void
57
- {
58
- this.setState({ value }, () =>
59
- {
60
- if (this.props.onChanged)
61
- this.props.onChanged(this, callback);
62
- else if (callback)
63
- callback();
64
- });
65
- }
66
- private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
67
- {
68
- this.setValue(parseFloat(e.target.value));
69
- }
70
- override render()
71
- {
72
- return (
73
- <>
74
- <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
75
- <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
76
- <input
77
- type="number"
78
- name={this.props.name}
79
- className={Styles.ns_input}
80
- placeholder={this.props.placeholder}
81
- value={this.state.value}
82
- onChange={this.onChanged}
83
- onClick={() => this.props.onClicked}
84
- inputMode="decimal"
85
- pattern="[0-9]*[.,]?[0-9]*"
86
- style={{ background: `url("https://static.namirasoft.com/image/concept/nsbox/Float.png") white no-repeat scroll center right 16px`, backgroundSize: "24px" }}
87
- />
88
- <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
89
- </div>
90
- </>
91
- );
92
- }
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 { IValidationNumberProps } from "../props/IValidationNumberProps";
8
+ import { Validator } from "../Validator";
9
+ import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
10
+
11
+ export interface INSBoxDoubleProps extends IBaseComponentProps, IValidationProps, IValidationNumberProps
12
+ {
13
+ title: string;
14
+ placeholder?: string;
15
+ defaultValue?: number;
16
+ onChanged?: (e: NSBoxDouble, callback?: () => void) => void;
17
+ onClicked?: (e: NSBoxDouble) => void;
18
+ }
19
+
20
+ export interface INSBoxDoubleState
21
+ {
22
+ value?: number;
23
+ error?: string;
24
+ }
25
+
26
+ export class NSBoxDouble extends React.Component<INSBoxDoubleProps, INSBoxDoubleState>
27
+ {
28
+ constructor(props: INSBoxDoubleProps)
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(checkError: boolean = true): number | undefined
44
+ {
45
+ if (checkError)
46
+ {
47
+ let error = this.getError();
48
+ if (error)
49
+ {
50
+ this.setState({ error });
51
+ throw new Error(error);
52
+ }
53
+ }
54
+ return this.state.value;
55
+ }
56
+ setValue(value: number | undefined, callback?: () => void): void
57
+ {
58
+ this.setState({ value }, () =>
59
+ {
60
+ if (this.props.onChanged)
61
+ this.props.onChanged(this, callback);
62
+ else if (callback)
63
+ callback();
64
+ });
65
+ }
66
+ private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
67
+ {
68
+ this.setValue(parseFloat(e.target.value));
69
+ }
70
+ override render()
71
+ {
72
+ return (
73
+ <>
74
+ <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
75
+ <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
76
+ <input
77
+ type="number"
78
+ name={this.props.name}
79
+ className={Styles.ns_input}
80
+ placeholder={this.props.placeholder}
81
+ value={this.state.value}
82
+ onChange={this.onChanged}
83
+ onClick={() => this.props.onClicked}
84
+ inputMode="decimal"
85
+ pattern="[0-9]*[.,]?[0-9]*"
86
+ style={{ background: `url("https://static.namirasoft.com/image/concept/nsbox/Float.png") white no-repeat scroll center right 16px`, backgroundSize: "24px" }}
87
+ />
88
+ <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
89
+ </div>
90
+ </>
91
+ );
92
+ }
93
93
  }
@@ -1,93 +1,93 @@
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 { IValidationNumberProps } from "../props/IValidationNumberProps";
8
- import { IValidationStringProps } from "../props/IValidationStringProps";
9
- import { Validator } from "../Validator";
10
- import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
11
-
12
- export interface INSBoxDurationProps extends IBaseComponentProps, IValidationProps, IValidationStringProps, IValidationNumberProps
13
- {
14
- title: string;
15
- placeholder?: string;
16
- defaultValue?: string;
17
- onChanged?: (e: NSBoxDuration, callback?: () => void) => void;
18
- onClicked?: (e: NSBoxDuration) => void;
19
- }
20
-
21
- export interface INSBoxDurationState
22
- {
23
- value: string;
24
- error?: string;
25
- }
26
-
27
- export class NSBoxDuration extends React.Component<INSBoxDurationProps, INSBoxDurationState>
28
- {
29
- constructor(props: INSBoxDurationProps)
30
- {
31
- super(props);
32
- this.state = { value: props.defaultValue ?? "" };
33
- this.getValue = this.getValue.bind(this);
34
- this.setValue = this.setValue.bind(this);
35
- this.onChanged = this.onChanged.bind(this);
36
- }
37
- getError(): string | null
38
- {
39
- return (
40
- Validator.getError(this.props.title, this.state.value, this.props) ||
41
- Validator.getErrorDuration(this.props.title, this.state.value)
42
- );
43
- }
44
- getValue(checkError: boolean = true): string
45
- {
46
- if (checkError)
47
- {
48
- let error = this.getError();
49
- if (error)
50
- {
51
- this.setState({ error });
52
- throw new Error(error);
53
- }
54
- }
55
- return this.state.value;
56
- }
57
- setValue(value: string, callback?: () => void): void
58
- {
59
- this.setState({ value }, () =>
60
- {
61
- if (this.props.onChanged)
62
- this.props.onChanged(this, callback);
63
- else if (callback)
64
- callback();
65
- });
66
- }
67
- private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
68
- {
69
- this.setValue(e.target.value);
70
- }
71
- override render()
72
- {
73
- return (
74
- <>
75
- <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
76
- <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
77
- <input
78
- type="time"
79
- name={this.props.name}
80
- className={Styles.ns_input}
81
- placeholder={this.props.placeholder}
82
- value={this.state.value}
83
- onChange={this.onChanged}
84
- onClick={() => this.props.onClicked}
85
- step="2"
86
- style={{ background: `url("https://static.namirasoft.com/image/concept/nsbox/duration.png") white no-repeat scroll center right 16px`, backgroundSize: "24px" }}
87
- />
88
- <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
89
- </div>
90
- </>
91
- );
92
- }
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 { IValidationNumberProps } from "../props/IValidationNumberProps";
8
+ import { IValidationStringProps } from "../props/IValidationStringProps";
9
+ import { Validator } from "../Validator";
10
+ import { NSBoxErrorNotifier } from "./NSBoxErrorNotifier";
11
+
12
+ export interface INSBoxDurationProps extends IBaseComponentProps, IValidationProps, IValidationStringProps, IValidationNumberProps
13
+ {
14
+ title: string;
15
+ placeholder?: string;
16
+ defaultValue?: string;
17
+ onChanged?: (e: NSBoxDuration, callback?: () => void) => void;
18
+ onClicked?: (e: NSBoxDuration) => void;
19
+ }
20
+
21
+ export interface INSBoxDurationState
22
+ {
23
+ value: string;
24
+ error?: string;
25
+ }
26
+
27
+ export class NSBoxDuration extends React.Component<INSBoxDurationProps, INSBoxDurationState>
28
+ {
29
+ constructor(props: INSBoxDurationProps)
30
+ {
31
+ super(props);
32
+ this.state = { value: props.defaultValue ?? "" };
33
+ this.getValue = this.getValue.bind(this);
34
+ this.setValue = this.setValue.bind(this);
35
+ this.onChanged = this.onChanged.bind(this);
36
+ }
37
+ getError(): string | null
38
+ {
39
+ return (
40
+ Validator.getError(this.props.title, this.state.value, this.props) ||
41
+ Validator.getErrorDuration(this.props.title, this.state.value)
42
+ );
43
+ }
44
+ getValue(checkError: boolean = true): string
45
+ {
46
+ if (checkError)
47
+ {
48
+ let error = this.getError();
49
+ if (error)
50
+ {
51
+ this.setState({ error });
52
+ throw new Error(error);
53
+ }
54
+ }
55
+ return this.state.value;
56
+ }
57
+ setValue(value: string, callback?: () => void): void
58
+ {
59
+ this.setState({ value }, () =>
60
+ {
61
+ if (this.props.onChanged)
62
+ this.props.onChanged(this, callback);
63
+ else if (callback)
64
+ callback();
65
+ });
66
+ }
67
+ private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
68
+ {
69
+ this.setValue(e.target.value);
70
+ }
71
+ override render()
72
+ {
73
+ return (
74
+ <>
75
+ <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
76
+ <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
77
+ <input
78
+ type="time"
79
+ name={this.props.name}
80
+ className={Styles.ns_input}
81
+ placeholder={this.props.placeholder}
82
+ value={this.state.value}
83
+ onChange={this.onChanged}
84
+ onClick={() => this.props.onClicked}
85
+ step="2"
86
+ style={{ background: `url("https://static.namirasoft.com/image/concept/nsbox/duration.png") white no-repeat scroll center right 16px`, backgroundSize: "24px" }}
87
+ />
88
+ <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
89
+ </div>
90
+ </>
91
+ );
92
+ }
93
93
  }