namirasoft-site-react 1.4.111 → 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 (335) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +72 -70
  5. package/dist/App.css +58 -0
  6. package/dist/App.js +56 -117
  7. package/dist/App.js.map +1 -1
  8. package/dist/components/NSAccordion.module.css +4 -4
  9. package/dist/components/NSActionMenu.js +2 -2
  10. package/dist/components/NSActionMenu.module.css +101 -101
  11. package/dist/components/NSAssistantButton.module.css +135 -135
  12. package/dist/components/NSBarAction.module.css +97 -97
  13. package/dist/components/NSBarAlert.module.css +69 -69
  14. package/dist/components/NSBarHeroBanner.module.css +42 -42
  15. package/dist/components/NSBarNotification.module.css +34 -34
  16. package/dist/components/NSBarTitle.module.css +9 -9
  17. package/dist/components/NSBox.module.css +126 -126
  18. package/dist/components/NSBoxBoolean.module.css +88 -88
  19. package/dist/components/NSBoxCombo.module.css +6 -6
  20. package/dist/components/NSBoxCopy.module.css +43 -43
  21. package/dist/components/NSBoxDate.module.css +56 -56
  22. package/dist/components/NSBoxDateTime.module.css +51 -51
  23. package/dist/components/NSBoxEntity.module.css +21 -21
  24. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  25. package/dist/components/NSBoxFile.module.css +4 -4
  26. package/dist/components/NSBoxLabel.module.css +14 -14
  27. package/dist/components/NSBoxRadio.module.css +70 -70
  28. package/dist/components/NSBoxTextArea.module.css +83 -83
  29. package/dist/components/NSButton.module.css +42 -42
  30. package/dist/components/NSButtonBlue.module.css +4 -4
  31. package/dist/components/NSButtonGreen.module.css +4 -4
  32. package/dist/components/NSButtonRed.module.css +4 -4
  33. package/dist/components/NSCard.module.css +114 -114
  34. package/dist/components/NSCardScreenshot.module.css +41 -41
  35. package/dist/components/NSChartColumn.module.css +7 -7
  36. package/dist/components/NSChartPie.module.css +0 -0
  37. package/dist/components/NSChartTable.module.css +21 -21
  38. package/dist/components/NSCopyToClipboard.d.ts +7 -0
  39. package/dist/components/NSCopyToClipboard.js +13 -0
  40. package/dist/components/NSCopyToClipboard.js.map +1 -0
  41. package/dist/components/NSCopyToClipboard.module.css +44 -0
  42. package/dist/components/NSDialog.module.css +106 -106
  43. package/dist/components/NSDownTimer.module.css +55 -55
  44. package/dist/components/NSDownload.module.css +46 -46
  45. package/dist/components/NSElectronicCard.module.css +60 -60
  46. package/dist/components/NSEntityBar.module.css +77 -77
  47. package/dist/components/NSEntityCardBackground.module.css +27 -27
  48. package/dist/components/NSFilterBox.js +11 -5
  49. package/dist/components/NSFilterBox.js.map +1 -1
  50. package/dist/components/NSFilterBox.module.css +62 -62
  51. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  52. package/dist/components/NSFilterItem.module.css +23 -23
  53. package/dist/components/NSFooter.module.css +123 -123
  54. package/dist/components/NSGroupedList.module.css +72 -72
  55. package/dist/components/NSHeader.module.css +291 -291
  56. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  57. package/dist/components/NSLayout.module.css +13 -13
  58. package/dist/components/NSLine.module.css +12 -12
  59. package/dist/components/NSLink.module.css +36 -36
  60. package/dist/components/NSLoading.module.css +30 -30
  61. package/dist/components/NSNoData.module.css +8 -8
  62. package/dist/components/NSPageSelectionModal.module.css +103 -103
  63. package/dist/components/NSPagination.module.css +110 -110
  64. package/dist/components/NSPanel.module.css +46 -46
  65. package/dist/components/NSRadioButton.d.ts +25 -0
  66. package/dist/components/NSRadioButton.js +49 -0
  67. package/dist/components/NSRadioButton.js.map +1 -0
  68. package/dist/components/NSRange.module.css +66 -66
  69. package/dist/components/NSSection.module.css +10 -10
  70. package/dist/components/NSSectionBars.module.css +10 -10
  71. package/dist/components/NSSectionCards.module.css +38 -38
  72. package/dist/components/NSTabPage.module.css +59 -59
  73. package/dist/components/NSTable.js +8 -15
  74. package/dist/components/NSTable.js.map +1 -1
  75. package/dist/components/NSTable.module.css +290 -291
  76. package/dist/components/NSTag.module.css +52 -52
  77. package/dist/components/NSTimeTable.module.css +6 -6
  78. package/dist/components/NSTimelineMonthly.module.css +71 -71
  79. package/dist/components/NSTitle.module.css +15 -15
  80. package/dist/formatter/BackColorFormatter.d.ts +1 -1
  81. package/dist/formatter/BackColorFormatter.js +3 -1
  82. package/dist/formatter/BackColorFormatter.js.map +1 -1
  83. package/dist/formatter/BaseColumnFormatter.d.ts +2 -0
  84. package/dist/formatter/BaseColumnFormatter.js +4 -0
  85. package/dist/formatter/BaseColumnFormatter.js.map +1 -1
  86. package/dist/formatter/BooleanFormatter.d.ts +1 -1
  87. package/dist/formatter/BooleanFormatter.js +3 -1
  88. package/dist/formatter/BooleanFormatter.js.map +1 -1
  89. package/dist/formatter/DateFormatter.d.ts +1 -0
  90. package/dist/formatter/DateFormatter.js +4 -0
  91. package/dist/formatter/DateFormatter.js.map +1 -1
  92. package/dist/formatter/DateTimeFormatter.d.ts +1 -0
  93. package/dist/formatter/DateTimeFormatter.js +5 -1
  94. package/dist/formatter/DateTimeFormatter.js.map +1 -1
  95. package/dist/formatter/DurationFormatter.d.ts +1 -0
  96. package/dist/formatter/DurationFormatter.js +4 -0
  97. package/dist/formatter/DurationFormatter.js.map +1 -1
  98. package/dist/formatter/EmailFormatter.d.ts +1 -0
  99. package/dist/formatter/EmailFormatter.js +4 -0
  100. package/dist/formatter/EmailFormatter.js.map +1 -1
  101. package/dist/formatter/EnumFormatter.d.ts +1 -0
  102. package/dist/formatter/EnumFormatter.js +4 -0
  103. package/dist/formatter/EnumFormatter.js.map +1 -1
  104. package/dist/formatter/FloatFormatter.d.ts +1 -0
  105. package/dist/formatter/FloatFormatter.js +8 -1
  106. package/dist/formatter/FloatFormatter.js.map +1 -1
  107. package/dist/formatter/ForeColorFormatter.d.ts +1 -1
  108. package/dist/formatter/ForeColorFormatter.js +3 -1
  109. package/dist/formatter/ForeColorFormatter.js.map +1 -1
  110. package/dist/formatter/IDFormatter.d.ts +1 -0
  111. package/dist/formatter/IDFormatter.js +13 -0
  112. package/dist/formatter/IDFormatter.js.map +1 -1
  113. package/dist/formatter/IPFormatter.d.ts +1 -0
  114. package/dist/formatter/IPFormatter.js +4 -0
  115. package/dist/formatter/IPFormatter.js.map +1 -1
  116. package/dist/formatter/IntegerFormatter.d.ts +1 -0
  117. package/dist/formatter/IntegerFormatter.js +8 -1
  118. package/dist/formatter/IntegerFormatter.js.map +1 -1
  119. package/dist/formatter/JsonFormatter.d.ts +1 -0
  120. package/dist/formatter/JsonFormatter.js +5 -0
  121. package/dist/formatter/JsonFormatter.js.map +1 -1
  122. package/dist/formatter/MoneyFormatter.d.ts +1 -0
  123. package/dist/formatter/MoneyFormatter.js +8 -1
  124. package/dist/formatter/MoneyFormatter.js.map +1 -1
  125. package/dist/formatter/PhoneFormatter.d.ts +1 -0
  126. package/dist/formatter/PhoneFormatter.js +4 -0
  127. package/dist/formatter/PhoneFormatter.js.map +1 -1
  128. package/dist/formatter/StringFormatter.d.ts +1 -0
  129. package/dist/formatter/StringFormatter.js +4 -0
  130. package/dist/formatter/StringFormatter.js.map +1 -1
  131. package/dist/formatter/TimeFormatter.d.ts +1 -0
  132. package/dist/formatter/TimeFormatter.js +5 -1
  133. package/dist/formatter/TimeFormatter.js.map +1 -1
  134. package/dist/formatter/UnknowFormatter.d.ts +1 -0
  135. package/dist/formatter/UnknowFormatter.js +5 -0
  136. package/dist/formatter/UnknowFormatter.js.map +1 -1
  137. package/dist/index.css +6 -0
  138. package/dist/main.d.ts +0 -1
  139. package/dist/main.js +0 -1
  140. package/dist/main.js.map +1 -1
  141. package/dist/pages/NSNotFoundPage.module.css +17 -17
  142. package/dist/pages/NSUpdating.module.css +35 -35
  143. package/package.json +75 -73
  144. package/public/index.html +38 -38
  145. package/src/App.css +57 -57
  146. package/src/App.tsx +372 -440
  147. package/src/Color.tsx +10 -10
  148. package/src/CopyToClipboard.ts +6 -6
  149. package/src/Validator.ts +117 -117
  150. package/src/components/NSAccordion.module.css +4 -4
  151. package/src/components/NSAccordion.tsx +51 -51
  152. package/src/components/NSActionMenu.module.css +101 -101
  153. package/src/components/NSActionMenu.tsx +90 -90
  154. package/src/components/NSAssistantButton.module.css +135 -135
  155. package/src/components/NSAssistantButton.tsx +70 -70
  156. package/src/components/NSBarAction.module.css +97 -97
  157. package/src/components/NSBarAction.tsx +89 -89
  158. package/src/components/NSBarAlert.module.css +69 -69
  159. package/src/components/NSBarAlert.tsx +30 -30
  160. package/src/components/NSBarHeroBanner.module.css +42 -42
  161. package/src/components/NSBarHeroBanner.tsx +61 -61
  162. package/src/components/NSBarNotification.module.css +34 -34
  163. package/src/components/NSBarNotification.tsx +87 -87
  164. package/src/components/NSBarTitle.module.css +9 -9
  165. package/src/components/NSBarTitle.tsx +29 -29
  166. package/src/components/NSBox.module.css +126 -126
  167. package/src/components/NSBoxBoolean.module.css +88 -88
  168. package/src/components/NSBoxBoolean.tsx +124 -124
  169. package/src/components/NSBoxBooleans.tsx +159 -159
  170. package/src/components/NSBoxCombo.module.css +6 -6
  171. package/src/components/NSBoxCombo.tsx +151 -151
  172. package/src/components/NSBoxCopy.module.css +43 -43
  173. package/src/components/NSBoxCopy.tsx +41 -41
  174. package/src/components/NSBoxDate.module.css +56 -56
  175. package/src/components/NSBoxDate.tsx +88 -88
  176. package/src/components/NSBoxDateTime.module.css +51 -51
  177. package/src/components/NSBoxDateTime.tsx +89 -89
  178. package/src/components/NSBoxDouble.tsx +92 -92
  179. package/src/components/NSBoxDuration.tsx +92 -92
  180. package/src/components/NSBoxEmail.tsx +103 -103
  181. package/src/components/NSBoxEntity.module.css +21 -21
  182. package/src/components/NSBoxEntity.tsx +197 -197
  183. package/src/components/NSBoxEnum.tsx +55 -55
  184. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  185. package/src/components/NSBoxErrorNotifier.tsx +32 -32
  186. package/src/components/NSBoxFile.module.css +4 -4
  187. package/src/components/NSBoxFile.tsx +124 -124
  188. package/src/components/NSBoxIPV4.tsx +97 -97
  189. package/src/components/NSBoxIPV6.tsx +94 -94
  190. package/src/components/NSBoxInteger.tsx +94 -94
  191. package/src/components/NSBoxLabel.module.css +14 -14
  192. package/src/components/NSBoxLabel.tsx +29 -29
  193. package/src/components/NSBoxPassword.tsx +90 -90
  194. package/src/components/NSBoxPhone.tsx +97 -97
  195. package/src/components/NSBoxPrice.tsx +92 -92
  196. package/src/components/NSBoxRadio.module.css +70 -70
  197. package/src/components/NSBoxRadio.tsx +111 -111
  198. package/src/components/NSBoxSearch.tsx +107 -107
  199. package/src/components/NSBoxString.tsx +106 -106
  200. package/src/components/NSBoxTextArea.module.css +83 -83
  201. package/src/components/NSBoxTextArea.tsx +112 -112
  202. package/src/components/NSBoxTime.tsx +92 -92
  203. package/src/components/NSButton.module.css +42 -42
  204. package/src/components/NSButton.tsx +25 -25
  205. package/src/components/NSButtonBlue.module.css +4 -4
  206. package/src/components/NSButtonBlue.tsx +19 -19
  207. package/src/components/NSButtonGreen.module.css +4 -4
  208. package/src/components/NSButtonGreen.tsx +19 -19
  209. package/src/components/NSButtonRed.module.css +4 -4
  210. package/src/components/NSButtonRed.tsx +19 -19
  211. package/src/components/NSCard.module.css +114 -114
  212. package/src/components/NSCard.tsx +63 -63
  213. package/src/components/NSCardScreenshot.module.css +41 -41
  214. package/src/components/NSCardScreenshot.tsx +31 -31
  215. package/src/components/NSChartColumn.module.css +7 -7
  216. package/src/components/NSChartColumn.tsx +106 -106
  217. package/src/components/NSChartDoughnut.tsx +108 -108
  218. package/src/components/NSChartPie.tsx +105 -105
  219. package/src/components/NSChartRange.tsx +16 -16
  220. package/src/components/NSChartTable.module.css +21 -21
  221. package/src/components/NSChartTable.tsx +94 -94
  222. package/src/components/NSCopy.tsx +67 -67
  223. package/src/components/NSDeleteDialog.tsx +26 -26
  224. package/src/components/NSDialog.module.css +106 -106
  225. package/src/components/NSDialog.tsx +56 -56
  226. package/src/components/NSDownTimer.module.css +55 -55
  227. package/src/components/NSDownTimer.tsx +77 -77
  228. package/src/components/NSDownload.module.css +46 -46
  229. package/src/components/NSDownload.tsx +62 -62
  230. package/src/components/NSElectronicCard.module.css +60 -60
  231. package/src/components/NSElectronicCard.tsx +45 -45
  232. package/src/components/NSEntityBar.module.css +77 -77
  233. package/src/components/NSEntityBar.tsx +27 -27
  234. package/src/components/NSEntityCardBackground.module.css +27 -27
  235. package/src/components/NSEntityCardBackground.tsx +34 -34
  236. package/src/components/NSFilterBox.module.css +62 -62
  237. package/src/components/NSFilterBox.tsx +360 -352
  238. package/src/components/NSFilterBoxDialog.module.css +36 -36
  239. package/src/components/NSFilterBoxDialog.tsx +74 -74
  240. package/src/components/NSFilterItem.module.css +23 -23
  241. package/src/components/NSFilterItem.tsx +73 -73
  242. package/src/components/NSFooter.module.css +123 -123
  243. package/src/components/NSFooter.tsx +289 -289
  244. package/src/components/NSGroupedList.module.css +72 -72
  245. package/src/components/NSGroupedList.tsx +115 -115
  246. package/src/components/NSHeader.module.css +291 -291
  247. package/src/components/NSHeader.tsx +250 -250
  248. package/src/components/NSHeaderScreenshot.module.css +35 -35
  249. package/src/components/NSHeaderScreenshot.tsx +38 -38
  250. package/src/components/NSInfoDialog.tsx +36 -36
  251. package/src/components/NSLayout.module.css +13 -13
  252. package/src/components/NSLayout.tsx +109 -109
  253. package/src/components/NSLine.module.css +12 -12
  254. package/src/components/NSLine.tsx +15 -15
  255. package/src/components/NSLink.module.css +36 -36
  256. package/src/components/NSLink.tsx +25 -25
  257. package/src/components/NSLinkBlue.tsx +20 -20
  258. package/src/components/NSLinkGreen.tsx +5 -5
  259. package/src/components/NSLinkRed.tsx +5 -5
  260. package/src/components/NSLoading.module.css +30 -30
  261. package/src/components/NSLoading.tsx +20 -20
  262. package/src/components/NSNoData.module.css +8 -8
  263. package/src/components/NSNoData.tsx +24 -24
  264. package/src/components/NSPageSelectionModal.module.css +103 -103
  265. package/src/components/NSPageSelectionModal.tsx +228 -228
  266. package/src/components/NSPagination.module.css +110 -110
  267. package/src/components/NSPagination.tsx +191 -191
  268. package/src/components/NSPanel.module.css +46 -46
  269. package/src/components/NSPanel.tsx +19 -19
  270. package/src/components/NSProductList.tsx +43 -43
  271. package/src/components/NSRange.module.css +66 -66
  272. package/src/components/NSRange.tsx +81 -81
  273. package/src/components/NSRepeater.tsx +179 -179
  274. package/src/components/NSSection.module.css +10 -10
  275. package/src/components/NSSection.tsx +23 -23
  276. package/src/components/NSSectionBars.module.css +10 -10
  277. package/src/components/NSSectionBars.tsx +25 -25
  278. package/src/components/NSSectionCards.module.css +38 -38
  279. package/src/components/NSSectionCards.tsx +51 -51
  280. package/src/components/NSSectionTitle.tsx +21 -21
  281. package/src/components/NSSpace.tsx +28 -28
  282. package/src/components/NSTabPage.module.css +59 -59
  283. package/src/components/NSTabPage.tsx +78 -78
  284. package/src/components/NSTable.module.css +290 -291
  285. package/src/components/NSTable.tsx +436 -440
  286. package/src/components/NSTag.module.css +52 -52
  287. package/src/components/NSTag.tsx +78 -78
  288. package/src/components/NSTimeTable.module.css +6 -6
  289. package/src/components/NSTimeTable.tsx +49 -49
  290. package/src/components/NSTimelineMonthly.module.css +71 -71
  291. package/src/components/NSTimelineMonthly.tsx +42 -42
  292. package/src/components/NSTitle.module.css +15 -15
  293. package/src/components/NSTitle.tsx +19 -19
  294. package/src/formatter/BackColorFormatter.tsx +22 -20
  295. package/src/formatter/BaseColumnFormatter.ts +16 -14
  296. package/src/formatter/BooleanFormatter.ts +22 -20
  297. package/src/formatter/DateFormatter.ts +20 -15
  298. package/src/formatter/DateTimeFormatter.ts +20 -15
  299. package/src/formatter/DurationFormatter.ts +13 -8
  300. package/src/formatter/EmailFormatter.ts +13 -8
  301. package/src/formatter/EnumFormatter.ts +13 -8
  302. package/src/formatter/FloatFormatter.ts +16 -8
  303. package/src/formatter/ForeColorFormatter.tsx +22 -20
  304. package/src/formatter/IDFormatter.tsx +29 -0
  305. package/src/formatter/IPFormatter.ts +13 -8
  306. package/src/formatter/IntegerFormatter.ts +16 -8
  307. package/src/formatter/JsonFormatter.ts +14 -8
  308. package/src/formatter/MoneyFormatter.ts +16 -8
  309. package/src/formatter/PhoneFormatter.ts +13 -8
  310. package/src/formatter/StringFormatter.ts +13 -8
  311. package/src/formatter/TimeFormatter.ts +21 -16
  312. package/src/formatter/UnknowFormatter.ts +14 -8
  313. package/src/index.tsx +7 -7
  314. package/src/main.ts +117 -118
  315. package/src/pages/NSNotFoundPage.module.css +17 -17
  316. package/src/pages/NSNotFoundPage.tsx +11 -11
  317. package/src/pages/NSUpdating.module.css +35 -35
  318. package/src/pages/NSUpdating.tsx +32 -32
  319. package/src/props/IBaseComponentProps.ts +8 -8
  320. package/src/props/IHeaderIconProps.ts +10 -10
  321. package/src/props/IHeaderProps.ts +7 -7
  322. package/src/props/IImageProps.ts +4 -4
  323. package/src/props/ILinkProps.ts +5 -5
  324. package/src/props/IValidationNumberProps.ts +4 -4
  325. package/src/props/IValidationProps.ts +7 -7
  326. package/src/props/IValidationRegexProps.ts +4 -4
  327. package/src/props/IValidationStringProps.ts +4 -4
  328. package/src/routing/INSRouterMaker.ts +6 -6
  329. package/src/routing/INSRouterProps.ts +5 -5
  330. package/src/routing/INSRouterState.ts +5 -5
  331. package/src/routing/NSRouterMaker.tsx +33 -33
  332. package/src/routing/Notifier.ts +79 -79
  333. package/tsconfig.json +43 -43
  334. package/src/formatter/ForeignIDFormatter.ts +0 -9
  335. package/src/formatter/IDFormatter.ts +0 -9
@@ -1,56 +1,56 @@
1
- "use client";
2
-
3
- import React, { createRef } from "react";
4
- import { ObjectService } from "namirasoft-core";
5
- import { INSBoxComboOption, INSBoxComboProps, NSBoxCombo } from "./NSBoxCombo";
6
-
7
- export interface INSBoxEnumProps extends INSBoxComboProps
8
- {
9
- }
10
-
11
- export class NSBoxEnum extends React.Component<INSBoxEnumProps>
12
- {
13
- public NSBoxCombo = createRef<NSBoxCombo>();
14
- constructor(props: INSBoxEnumProps)
15
- {
16
- super(props);
17
- this.getValues = this.getValues.bind(this);
18
- this.setValues = this.setValues.bind(this);
19
- this.setValue = this.setValue.bind(this);
20
- this.getValue = this.getValue.bind(this);
21
- }
22
- getError(value: string): string | null
23
- {
24
- return this.NSBoxCombo.current?.getError(value) ?? null;
25
- }
26
- getValue<T>(enumObj: { [s: string]: T }, _default: T): T | null
27
- {
28
- return new ObjectService(this.NSBoxCombo.current?.getValue()).getEnum(enumObj, _default);
29
- }
30
- getValues<T>(enumObj: { [s: string]: T }, _default: T): T[]
31
- {
32
- let values = this.NSBoxCombo.current?.getValues() ?? [];
33
- return values.map(value => new ObjectService(value).getEnum(enumObj, _default));
34
- }
35
- setValue(value: string | null, callback?: () => void): void
36
- {
37
- this.NSBoxCombo.current?.setValue(value, callback);
38
- }
39
- setValues(values: string[], callback?: () => void): void
40
- {
41
- this.NSBoxCombo.current?.setValues(values, callback);
42
- }
43
- override render()
44
- {
45
- let options: INSBoxComboOption[] = this.props.options.map((option: INSBoxComboOption) =>
46
- {
47
- return {
48
- title: option.title,
49
- value: option.value,
50
- };
51
- });
52
- return (
53
- <NSBoxCombo ref={this.NSBoxCombo} {...this.props} options={options}></NSBoxCombo>
54
- );
55
- }
1
+ "use client";
2
+
3
+ import React, { createRef } from "react";
4
+ import { ObjectService } from "namirasoft-core";
5
+ import { INSBoxComboOption, INSBoxComboProps, NSBoxCombo } from "./NSBoxCombo";
6
+
7
+ export interface INSBoxEnumProps extends INSBoxComboProps
8
+ {
9
+ }
10
+
11
+ export class NSBoxEnum extends React.Component<INSBoxEnumProps>
12
+ {
13
+ public NSBoxCombo = createRef<NSBoxCombo>();
14
+ constructor(props: INSBoxEnumProps)
15
+ {
16
+ super(props);
17
+ this.getValues = this.getValues.bind(this);
18
+ this.setValues = this.setValues.bind(this);
19
+ this.setValue = this.setValue.bind(this);
20
+ this.getValue = this.getValue.bind(this);
21
+ }
22
+ getError(value: string): string | null
23
+ {
24
+ return this.NSBoxCombo.current?.getError(value) ?? null;
25
+ }
26
+ getValue<T>(enumObj: { [s: string]: T }, _default: T): T | null
27
+ {
28
+ return new ObjectService(this.NSBoxCombo.current?.getValue()).getEnum(enumObj, _default);
29
+ }
30
+ getValues<T>(enumObj: { [s: string]: T }, _default: T): T[]
31
+ {
32
+ let values = this.NSBoxCombo.current?.getValues() ?? [];
33
+ return values.map(value => new ObjectService(value).getEnum(enumObj, _default));
34
+ }
35
+ setValue(value: string | null, callback?: () => void): void
36
+ {
37
+ this.NSBoxCombo.current?.setValue(value, callback);
38
+ }
39
+ setValues(values: string[], callback?: () => void): void
40
+ {
41
+ this.NSBoxCombo.current?.setValues(values, callback);
42
+ }
43
+ override render()
44
+ {
45
+ let options: INSBoxComboOption[] = this.props.options.map((option: INSBoxComboOption) =>
46
+ {
47
+ return {
48
+ title: option.title,
49
+ value: option.value,
50
+ };
51
+ });
52
+ return (
53
+ <NSBoxCombo ref={this.NSBoxCombo} {...this.props} options={options}></NSBoxCombo>
54
+ );
55
+ }
56
56
  }
@@ -1,3 +1,3 @@
1
- .ns_input_error {
2
- color: #FF3F3F !important;
1
+ .ns_input_error {
2
+ color: #FF3F3F !important;
3
3
  }
@@ -1,33 +1,33 @@
1
- import Styles from "./NSBoxErrorNotifier.module.css";
2
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
-
4
- export interface INSBoxErrorNotifierProps extends IBaseComponentProps
5
- {
6
- error?: string;
7
- clearError: () => void;
8
- }
9
-
10
- export function NSBoxErrorNotifier(props: INSBoxErrorNotifierProps)
11
- {
12
- if (props.error)
13
- setTimeout(() =>
14
- {
15
- props.clearError();
16
- }, 5000);
17
- return <>
18
- {
19
- props.error && (
20
- <div id={props.id} className="d-flex justify-content-start align-items-center gap-2 ms-2">
21
- <img
22
- className={""}
23
- src="https://static.namirasoft.com/image/concept/danger/red.svg"
24
- alt="Error Icon"
25
- width={13}
26
- height={13}
27
- />
28
- <span className={Styles.ns_input_error}>{props.error}</span>
29
- </div >
30
- )
31
- }
32
- </>;
1
+ import Styles from "./NSBoxErrorNotifier.module.css";
2
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
+
4
+ export interface INSBoxErrorNotifierProps extends IBaseComponentProps
5
+ {
6
+ error?: string;
7
+ clearError: () => void;
8
+ }
9
+
10
+ export function NSBoxErrorNotifier(props: INSBoxErrorNotifierProps)
11
+ {
12
+ if (props.error)
13
+ setTimeout(() =>
14
+ {
15
+ props.clearError();
16
+ }, 5000);
17
+ return <>
18
+ {
19
+ props.error && (
20
+ <div id={props.id} className="d-flex justify-content-start align-items-center gap-2 ms-2">
21
+ <img
22
+ className={""}
23
+ src="https://static.namirasoft.com/image/concept/danger/red.svg"
24
+ alt="Error Icon"
25
+ width={13}
26
+ height={13}
27
+ />
28
+ <span className={Styles.ns_input_error}>{props.error}</span>
29
+ </div >
30
+ )
31
+ }
32
+ </>;
33
33
  }
@@ -1,5 +1,5 @@
1
- @media screen and (min-width: 540px) {
2
- .ns_input_file {
3
- max-width: 700px;
4
- }
1
+ @media screen and (min-width: 540px) {
2
+ .ns_input_file {
3
+ max-width: 700px;
4
+ }
5
5
  }
@@ -1,125 +1,125 @@
1
- import React, { ChangeEvent } from "react";
2
- import { InboxOutlined } from '@ant-design/icons';
3
- import { message, Upload, UploadProps } from "antd";
4
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
5
- import { IValidationProps } from "../props/IValidationProps";
6
- import Styles from "./NSBoxFile.module.css"
7
-
8
- const { Dragger } = Upload;
9
-
10
- export interface INSBoxFileProps extends IBaseComponentProps, IValidationProps
11
- {
12
- title: string;
13
- placeholder?: string;
14
- defaultValue?: string;
15
- onChanged?: (info: any) => void;
16
- onDroped?: (info: any) => void;
17
- onClicked?: (e: NSBoxFile) => void;
18
- showUploadList?: boolean;
19
- maxFilesCount?: number;
20
- multiple?: boolean;
21
- }
22
-
23
- const props: UploadProps = {
24
- name: 'file',
25
- multiple: false,
26
- action: 'https://660d2bd96ddfa2943b33731c.mockapi.io/api/upload',
27
- onChange(info)
28
- {
29
- const { status } = info.file;
30
- if (status !== 'uploading')
31
- {
32
- console.log(info.file, info.fileList);
33
- }
34
- if (status === 'done')
35
- {
36
- message.success(`${info.file.name} file uploaded successfully.`);
37
- } else if (status === 'error')
38
- {
39
- message.error(`${info.file.name} file upload failed.`);
40
- }
41
- },
42
- onDrop(e)
43
- {
44
- console.log('Dropped files', e.dataTransfer.files);
45
- },
46
- };
47
-
48
- export interface INSBoxFileState
49
- {
50
- file: File | null;
51
- error?: string;
52
- }
53
-
54
- export class NSBoxFile extends React.Component<INSBoxFileProps, INSBoxFileState>
55
- {
56
- constructor(props: INSBoxFileProps)
57
- {
58
- super(props);
59
- this.state = {
60
- file: null,
61
- };
62
- this.getError = this.getError.bind(this);
63
- this.getFile = this.getFile.bind(this);
64
- this.setFile = this.setFile.bind(this);
65
- this.onChanged = this.onChanged.bind(this)
66
- }
67
-
68
- getError(): string | null
69
- {
70
- return null;
71
- }
72
-
73
- handleFileChange = (event: ChangeEvent<HTMLInputElement>) =>
74
- {
75
- const file = event.target.files ? event.target.files[0] : null;
76
- this.setState({ file });
77
- };
78
-
79
- getFile = (): File | null =>
80
- {
81
- return this.state.file;
82
- };
83
-
84
- setFile = (file: File | null) =>
85
- {
86
- this.setState({ file }, () =>
87
- {
88
- if (this.props.onChanged)
89
- this.props.onChanged(this.state.file);
90
- });
91
- };
92
-
93
- private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
94
- {
95
- const file = e.target.files ? e.target.files[0] : null;
96
- this.setState({ file });
97
- if (this.props.onChanged)
98
- this.props.onChanged(this.state.file);
99
- }
100
-
101
- override render()
102
- {
103
- return (
104
- <div className={`${Styles.ns_input_file}`}>
105
- <Dragger {...props}
106
- onChange={this.props.onChanged}
107
- onDrop={this.props.onDroped}
108
- showUploadList={this.props.showUploadList}
109
- maxCount={this.props.maxFilesCount}
110
- multiple={this.props.multiple}
111
- style={{ border: "none" }}
112
- >
113
- <p className="ant-upload-drag-icon">
114
- <InboxOutlined style={{ color: "#141B5C" }} />
115
- </p>
116
- <p className="ant-upload-text" style={{ color: "#141B5C" }}>Click or drag file to this area to upload</p>
117
- <p className="ant-upload-hint" style={{ color: "#141B5C" }}>
118
- Support for a single or bulk upload. Strictly prohibited from uploading company data or other
119
- banned files.
120
- </p>
121
- </Dragger>
122
- </div>
123
- )
124
- }
1
+ import React, { ChangeEvent } from "react";
2
+ import { InboxOutlined } from '@ant-design/icons';
3
+ import { message, Upload, UploadProps } from "antd";
4
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
5
+ import { IValidationProps } from "../props/IValidationProps";
6
+ import Styles from "./NSBoxFile.module.css"
7
+
8
+ const { Dragger } = Upload;
9
+
10
+ export interface INSBoxFileProps extends IBaseComponentProps, IValidationProps
11
+ {
12
+ title: string;
13
+ placeholder?: string;
14
+ defaultValue?: string;
15
+ onChanged?: (info: any) => void;
16
+ onDroped?: (info: any) => void;
17
+ onClicked?: (e: NSBoxFile) => void;
18
+ showUploadList?: boolean;
19
+ maxFilesCount?: number;
20
+ multiple?: boolean;
21
+ }
22
+
23
+ const props: UploadProps = {
24
+ name: 'file',
25
+ multiple: false,
26
+ action: 'https://660d2bd96ddfa2943b33731c.mockapi.io/api/upload',
27
+ onChange(info)
28
+ {
29
+ const { status } = info.file;
30
+ if (status !== 'uploading')
31
+ {
32
+ console.log(info.file, info.fileList);
33
+ }
34
+ if (status === 'done')
35
+ {
36
+ message.success(`${info.file.name} file uploaded successfully.`);
37
+ } else if (status === 'error')
38
+ {
39
+ message.error(`${info.file.name} file upload failed.`);
40
+ }
41
+ },
42
+ onDrop(e)
43
+ {
44
+ console.log('Dropped files', e.dataTransfer.files);
45
+ },
46
+ };
47
+
48
+ export interface INSBoxFileState
49
+ {
50
+ file: File | null;
51
+ error?: string;
52
+ }
53
+
54
+ export class NSBoxFile extends React.Component<INSBoxFileProps, INSBoxFileState>
55
+ {
56
+ constructor(props: INSBoxFileProps)
57
+ {
58
+ super(props);
59
+ this.state = {
60
+ file: null,
61
+ };
62
+ this.getError = this.getError.bind(this);
63
+ this.getFile = this.getFile.bind(this);
64
+ this.setFile = this.setFile.bind(this);
65
+ this.onChanged = this.onChanged.bind(this)
66
+ }
67
+
68
+ getError(): string | null
69
+ {
70
+ return null;
71
+ }
72
+
73
+ handleFileChange = (event: ChangeEvent<HTMLInputElement>) =>
74
+ {
75
+ const file = event.target.files ? event.target.files[0] : null;
76
+ this.setState({ file });
77
+ };
78
+
79
+ getFile = (): File | null =>
80
+ {
81
+ return this.state.file;
82
+ };
83
+
84
+ setFile = (file: File | null) =>
85
+ {
86
+ this.setState({ file }, () =>
87
+ {
88
+ if (this.props.onChanged)
89
+ this.props.onChanged(this.state.file);
90
+ });
91
+ };
92
+
93
+ private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
94
+ {
95
+ const file = e.target.files ? e.target.files[0] : null;
96
+ this.setState({ file });
97
+ if (this.props.onChanged)
98
+ this.props.onChanged(this.state.file);
99
+ }
100
+
101
+ override render()
102
+ {
103
+ return (
104
+ <div className={`${Styles.ns_input_file}`}>
105
+ <Dragger {...props}
106
+ onChange={this.props.onChanged}
107
+ onDrop={this.props.onDroped}
108
+ showUploadList={this.props.showUploadList}
109
+ maxCount={this.props.maxFilesCount}
110
+ multiple={this.props.multiple}
111
+ style={{ border: "none" }}
112
+ >
113
+ <p className="ant-upload-drag-icon">
114
+ <InboxOutlined style={{ color: "#141B5C" }} />
115
+ </p>
116
+ <p className="ant-upload-text" style={{ color: "#141B5C" }}>Click or drag file to this area to upload</p>
117
+ <p className="ant-upload-hint" style={{ color: "#141B5C" }}>
118
+ Support for a single or bulk upload. Strictly prohibited from uploading company data or other
119
+ banned files.
120
+ </p>
121
+ </Dragger>
122
+ </div>
123
+ )
124
+ }
125
125
  }
@@ -1,98 +1,98 @@
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
-
11
- //todo: check pattern
12
- const IPV4_PATTERN: string = "^((\\d{1,2}|1\\d\\d|2[0-4]\\d|25[0-5])\\.){3}(\\d{1,2}|1\\d\\d|2[0-4]\\d|25[0-5])$"
13
- export interface INSBoxIPV4Props extends IBaseComponentProps, IValidationProps, IValidationStringProps
14
- {
15
- title: string;
16
- placeholder?: string;
17
- defaultValue?: string;
18
- onChanged?: (e: NSBoxIPV4, callback?: () => void) => void;
19
- onClicked?: (e: NSBoxIPV4) => void;
20
- }
21
-
22
- export interface INSBoxIPV4State
23
- {
24
- value: string;
25
- error?: string;
26
- }
27
-
28
- export class NSBoxIPV4 extends React.Component<INSBoxIPV4Props, INSBoxIPV4State>
29
- {
30
- constructor(props: INSBoxIPV4Props)
31
- {
32
- super(props);
33
- this.state = { value: props.defaultValue ?? "" };
34
- this.getValue = this.getValue.bind(this);
35
- this.setValue = this.setValue.bind(this);
36
- this.onChanged = this.onChanged.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
- Validator.getErrorIP(this.props.title, this.state.value)
44
- );
45
- }
46
- getValue(checkError: boolean = true): string
47
- {
48
- if (checkError)
49
- {
50
- let error = this.getError();
51
- if (error)
52
- {
53
- this.setState({ error });
54
- throw new Error(error);
55
- }
56
- }
57
- return this.state.value;
58
- }
59
- setValue(value: string, callback?: () => void): void
60
- {
61
- this.setState({ value }, () =>
62
- {
63
- if (this.props.onChanged)
64
- this.props.onChanged(this, callback);
65
- else if (callback)
66
- callback();
67
- });
68
- }
69
- private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
70
- {
71
- this.setValue(e.target.value);
72
- }
73
- override render()
74
- {
75
- return (
76
- <>
77
- <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
78
- <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
79
- <input
80
- type="text"
81
- name={this.props.name}
82
- className={Styles.ns_input}
83
- placeholder={this.props.placeholder}
84
- value={this.state.value}
85
- onChange={this.onChanged}
86
- onClick={() => this.props.onClicked}
87
- minLength={7}
88
- maxLength={15}
89
- size={15}
90
- pattern={IPV4_PATTERN}
91
- style={{ background: `url("https://static.namirasoft.com/image/concept/nsbox/ipv4%266.png") white no-repeat scroll center right 16px`, backgroundSize: "24px" }}
92
- />
93
- <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
94
- </div>
95
- </>
96
- );
97
- }
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
+
11
+ //todo: check pattern
12
+ const IPV4_PATTERN: string = "^((\\d{1,2}|1\\d\\d|2[0-4]\\d|25[0-5])\\.){3}(\\d{1,2}|1\\d\\d|2[0-4]\\d|25[0-5])$"
13
+ export interface INSBoxIPV4Props extends IBaseComponentProps, IValidationProps, IValidationStringProps
14
+ {
15
+ title: string;
16
+ placeholder?: string;
17
+ defaultValue?: string;
18
+ onChanged?: (e: NSBoxIPV4, callback?: () => void) => void;
19
+ onClicked?: (e: NSBoxIPV4) => void;
20
+ }
21
+
22
+ export interface INSBoxIPV4State
23
+ {
24
+ value: string;
25
+ error?: string;
26
+ }
27
+
28
+ export class NSBoxIPV4 extends React.Component<INSBoxIPV4Props, INSBoxIPV4State>
29
+ {
30
+ constructor(props: INSBoxIPV4Props)
31
+ {
32
+ super(props);
33
+ this.state = { value: props.defaultValue ?? "" };
34
+ this.getValue = this.getValue.bind(this);
35
+ this.setValue = this.setValue.bind(this);
36
+ this.onChanged = this.onChanged.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
+ Validator.getErrorIP(this.props.title, this.state.value)
44
+ );
45
+ }
46
+ getValue(checkError: boolean = true): string
47
+ {
48
+ if (checkError)
49
+ {
50
+ let error = this.getError();
51
+ if (error)
52
+ {
53
+ this.setState({ error });
54
+ throw new Error(error);
55
+ }
56
+ }
57
+ return this.state.value;
58
+ }
59
+ setValue(value: string, callback?: () => void): void
60
+ {
61
+ this.setState({ value }, () =>
62
+ {
63
+ if (this.props.onChanged)
64
+ this.props.onChanged(this, callback);
65
+ else if (callback)
66
+ callback();
67
+ });
68
+ }
69
+ private onChanged(e: React.ChangeEvent<HTMLInputElement>): void
70
+ {
71
+ this.setValue(e.target.value);
72
+ }
73
+ override render()
74
+ {
75
+ return (
76
+ <>
77
+ <div id={this.props.id} className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
78
+ <span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
79
+ <input
80
+ type="text"
81
+ name={this.props.name}
82
+ className={Styles.ns_input}
83
+ placeholder={this.props.placeholder}
84
+ value={this.state.value}
85
+ onChange={this.onChanged}
86
+ onClick={() => this.props.onClicked}
87
+ minLength={7}
88
+ maxLength={15}
89
+ size={15}
90
+ pattern={IPV4_PATTERN}
91
+ style={{ background: `url("https://static.namirasoft.com/image/concept/nsbox/ipv4%266.png") white no-repeat scroll center right 16px`, backgroundSize: "24px" }}
92
+ />
93
+ <NSBoxErrorNotifier error={this.state.error} clearError={() => this.setState({ error: "" })} />
94
+ </div>
95
+ </>
96
+ );
97
+ }
98
98
  }