namirasoft-site-react 1.4.112 → 1.4.113

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