namirasoft-site-react 1.4.259 → 1.4.261

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 (288) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +72 -72
  5. package/dist/App.css +34 -0
  6. package/dist/components/NSBarAction.module.css +84 -84
  7. package/dist/components/NSBarAlert.module.css +79 -79
  8. package/dist/components/NSBarNotification.module.css +34 -34
  9. package/dist/components/NSBarTitle.module.css +9 -9
  10. package/dist/components/NSBox.module.css +50 -50
  11. package/dist/components/NSBoxBaseCombo.module.css +6 -6
  12. package/dist/components/NSBoxBoolean.module.css +67 -67
  13. package/dist/components/NSBoxDate.module.css +4 -4
  14. package/dist/components/NSBoxDateTime.module.css +4 -4
  15. package/dist/components/NSBoxDuration.module.css +4 -4
  16. package/dist/components/NSBoxFile.module.css +10 -10
  17. package/dist/components/NSBoxPhone.module.css +35 -35
  18. package/dist/components/NSBoxRadio.module.css +33 -33
  19. package/dist/components/NSBoxSchemaBase.module.css +17 -17
  20. package/dist/components/NSBoxSchemaVariable.module.css +16 -16
  21. package/dist/components/NSBoxTextArea.module.css +12 -12
  22. package/dist/components/NSBoxTime.module.css +4 -4
  23. package/dist/components/NSButton.module.css +57 -57
  24. package/dist/components/NSButtonBlue.module.css +4 -4
  25. package/dist/components/NSButtonGreen.module.css +4 -4
  26. package/dist/components/NSButtonRed.module.css +4 -4
  27. package/dist/components/NSCard.module.css +114 -114
  28. package/dist/components/NSCardScreenshot.module.css +41 -41
  29. package/dist/components/NSChartColumn.module.css +7 -7
  30. package/dist/components/NSChartTable.module.css +21 -21
  31. package/dist/components/NSColumn.module.css +16 -16
  32. package/dist/components/NSCopyBox.module.css +39 -39
  33. package/dist/components/NSDialog.module.css +112 -112
  34. package/dist/components/NSDialogPageSelection.module.css +103 -103
  35. package/dist/components/NSDownTimer.module.css +55 -55
  36. package/dist/components/NSDownload.module.css +46 -46
  37. package/dist/components/NSElectronicCard.module.css +60 -60
  38. package/dist/components/NSEntityCardBackground.module.css +27 -27
  39. package/dist/components/NSFilterBox.module.css +56 -56
  40. package/dist/components/NSFilterItem.module.css +24 -24
  41. package/dist/components/NSFooter.module.css +134 -134
  42. package/dist/components/NSHeader.module.css +291 -291
  43. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  44. package/dist/components/NSLabel.module.css +25 -25
  45. package/dist/components/NSLabelErrorNotifier.module.css +2 -2
  46. package/dist/components/NSLayout.module.css +14 -14
  47. package/dist/components/NSLine.module.css +15 -15
  48. package/dist/components/NSLink.module.css +36 -36
  49. package/dist/components/NSListGrouped.module.css +69 -69
  50. package/dist/components/NSLoading.module.css +30 -30
  51. package/dist/components/NSMenuAction.js +2 -2
  52. package/dist/components/NSMenuAction.module.css +88 -88
  53. package/dist/components/NSMenuButton.module.css +44 -44
  54. package/dist/components/NSNoData.module.css +9 -9
  55. package/dist/components/NSPagination.module.css +85 -85
  56. package/dist/components/NSPanel.module.css +19 -19
  57. package/dist/components/NSPanelAccordion.module.css +4 -4
  58. package/dist/components/NSRange.module.css +66 -66
  59. package/dist/components/NSRow.module.css +17 -17
  60. package/dist/components/NSSection.module.css +4 -4
  61. package/dist/components/NSSectionCards.module.css +38 -38
  62. package/dist/components/NSSectionTiles.module.css +10 -10
  63. package/dist/components/NSTabPage.module.css +59 -59
  64. package/dist/components/NSTable.module.css +263 -263
  65. package/dist/components/NSTile.module.css +76 -76
  66. package/dist/components/NSTimelineMonthly.module.css +71 -71
  67. package/dist/components/NSTitle.module.css +15 -15
  68. package/dist/formatter/MoneyFormatter.js +1 -1
  69. package/dist/formatter/MoneyFormatter.js.map +1 -1
  70. package/dist/index.css +6 -0
  71. package/dist/pages/NSNotFoundPage.module.css +18 -18
  72. package/dist/pages/NSUpdating.module.css +35 -35
  73. package/package.json +76 -76
  74. package/public/index.html +38 -38
  75. package/src/App.css +33 -33
  76. package/src/App.tsx +130 -130
  77. package/src/Color.tsx +10 -10
  78. package/src/CopyToClipboard.ts +6 -6
  79. package/src/NSBoxBuilder.tsx +912 -912
  80. package/src/Validator.ts +147 -147
  81. package/src/components/INSBox.tsx +6 -6
  82. package/src/components/NSBarAction.module.css +84 -84
  83. package/src/components/NSBarAction.tsx +90 -90
  84. package/src/components/NSBarAlert.module.css +79 -79
  85. package/src/components/NSBarAlert.tsx +35 -35
  86. package/src/components/NSBarNotification.module.css +34 -34
  87. package/src/components/NSBarNotification.tsx +89 -89
  88. package/src/components/NSBarTitle.module.css +9 -9
  89. package/src/components/NSBarTitle.tsx +23 -23
  90. package/src/components/NSBox.module.css +50 -50
  91. package/src/components/NSBox.tsx +19 -19
  92. package/src/components/NSBoxBaseCombo.module.css +6 -6
  93. package/src/components/NSBoxBaseCombo.tsx +314 -314
  94. package/src/components/NSBoxBaseLayout.tsx +88 -88
  95. package/src/components/NSBoxBaseLayoutRecursive.tsx +54 -54
  96. package/src/components/NSBoxBoolean.module.css +67 -67
  97. package/src/components/NSBoxBoolean.tsx +119 -119
  98. package/src/components/NSBoxBooleans.tsx +161 -161
  99. package/src/components/NSBoxColor.tsx +95 -95
  100. package/src/components/NSBoxCombo.tsx +91 -91
  101. package/src/components/NSBoxDate.module.css +4 -4
  102. package/src/components/NSBoxDate.tsx +90 -90
  103. package/src/components/NSBoxDateTime.module.css +4 -4
  104. package/src/components/NSBoxDateTime.tsx +105 -105
  105. package/src/components/NSBoxDouble.tsx +94 -94
  106. package/src/components/NSBoxDuration.module.css +4 -4
  107. package/src/components/NSBoxDuration.tsx +95 -95
  108. package/src/components/NSBoxDynamic.tsx +67 -67
  109. package/src/components/NSBoxDynamics.tsx +68 -68
  110. package/src/components/NSBoxEmail.tsx +98 -98
  111. package/src/components/NSBoxEntity.tsx +101 -101
  112. package/src/components/NSBoxEnum.tsx +108 -108
  113. package/src/components/NSBoxFile.module.css +10 -10
  114. package/src/components/NSBoxFile.tsx +101 -101
  115. package/src/components/NSBoxFilePath.tsx +95 -95
  116. package/src/components/NSBoxFont.tsx +95 -95
  117. package/src/components/NSBoxIPV4.tsx +95 -95
  118. package/src/components/NSBoxIPV4Range.tsx +95 -95
  119. package/src/components/NSBoxIPV6.tsx +92 -92
  120. package/src/components/NSBoxIPV6Range.tsx +95 -95
  121. package/src/components/NSBoxInteger.tsx +91 -91
  122. package/src/components/NSBoxMoney.tsx +95 -95
  123. package/src/components/NSBoxPassword.tsx +106 -106
  124. package/src/components/NSBoxPhone.module.css +35 -35
  125. package/src/components/NSBoxPhone.tsx +107 -107
  126. package/src/components/NSBoxRadio.module.css +33 -33
  127. package/src/components/NSBoxRadio.tsx +91 -91
  128. package/src/components/NSBoxSchemaBase.module.css +17 -17
  129. package/src/components/NSBoxSchemaBase.tsx +539 -539
  130. package/src/components/NSBoxSchemaVariable.module.css +16 -16
  131. package/src/components/NSBoxSchemaVariable.tsx +251 -251
  132. package/src/components/NSBoxSearch.tsx +97 -97
  133. package/src/components/NSBoxString.tsx +91 -91
  134. package/src/components/NSBoxTextArea.module.css +12 -12
  135. package/src/components/NSBoxTextArea.tsx +98 -98
  136. package/src/components/NSBoxTime.module.css +4 -4
  137. package/src/components/NSBoxTime.tsx +93 -93
  138. package/src/components/NSBoxTimeZone.tsx +95 -95
  139. package/src/components/NSBoxURL.tsx +104 -104
  140. package/src/components/NSBoxVersion.tsx +95 -95
  141. package/src/components/NSButton.module.css +57 -57
  142. package/src/components/NSButton.tsx +25 -25
  143. package/src/components/NSButtonBlue.module.css +4 -4
  144. package/src/components/NSButtonBlue.tsx +19 -19
  145. package/src/components/NSButtonGreen.module.css +4 -4
  146. package/src/components/NSButtonGreen.tsx +19 -19
  147. package/src/components/NSButtonRed.module.css +4 -4
  148. package/src/components/NSButtonRed.tsx +19 -19
  149. package/src/components/NSCard.module.css +114 -114
  150. package/src/components/NSCard.tsx +63 -63
  151. package/src/components/NSCardScreenshot.module.css +41 -41
  152. package/src/components/NSCardScreenshot.tsx +31 -31
  153. package/src/components/NSChartColumn.module.css +7 -7
  154. package/src/components/NSChartColumn.tsx +106 -106
  155. package/src/components/NSChartDoughnut.tsx +112 -112
  156. package/src/components/NSChartPie.tsx +105 -105
  157. package/src/components/NSChartRange.tsx +14 -14
  158. package/src/components/NSChartTable.module.css +21 -21
  159. package/src/components/NSChartTable.tsx +94 -94
  160. package/src/components/NSColumn.module.css +16 -16
  161. package/src/components/NSColumn.tsx +24 -24
  162. package/src/components/NSCopy.tsx +56 -56
  163. package/src/components/NSCopyBox.module.css +39 -39
  164. package/src/components/NSCopyBox.tsx +53 -53
  165. package/src/components/NSDialog.module.css +112 -112
  166. package/src/components/NSDialog.tsx +61 -61
  167. package/src/components/NSDialogDelete.tsx +26 -26
  168. package/src/components/NSDialogInfo.tsx +32 -32
  169. package/src/components/NSDialogPageSelection.module.css +103 -103
  170. package/src/components/NSDialogPageSelection.tsx +227 -227
  171. package/src/components/NSDownTimer.module.css +55 -55
  172. package/src/components/NSDownTimer.tsx +77 -77
  173. package/src/components/NSDownload.module.css +46 -46
  174. package/src/components/NSDownload.tsx +66 -66
  175. package/src/components/NSElectronicCard.module.css +60 -60
  176. package/src/components/NSElectronicCard.tsx +46 -46
  177. package/src/components/NSEntityCardBackground.module.css +27 -27
  178. package/src/components/NSEntityCardBackground.tsx +36 -36
  179. package/src/components/NSFilterBox.module.css +56 -56
  180. package/src/components/NSFilterBox.tsx +494 -494
  181. package/src/components/NSFilterItem.module.css +24 -24
  182. package/src/components/NSFilterItem.tsx +27 -27
  183. package/src/components/NSFooter.module.css +134 -134
  184. package/src/components/NSFooter.tsx +321 -321
  185. package/src/components/NSHeader.module.css +291 -291
  186. package/src/components/NSHeader.tsx +261 -261
  187. package/src/components/NSHeaderScreenshot.module.css +35 -35
  188. package/src/components/NSHeaderScreenshot.tsx +39 -39
  189. package/src/components/NSLabel.module.css +25 -25
  190. package/src/components/NSLabel.tsx +46 -46
  191. package/src/components/NSLabelErrorNotifier.module.css +2 -2
  192. package/src/components/NSLabelErrorNotifier.tsx +35 -35
  193. package/src/components/NSLayout.module.css +14 -14
  194. package/src/components/NSLayout.tsx +130 -130
  195. package/src/components/NSLine.module.css +15 -15
  196. package/src/components/NSLine.tsx +13 -13
  197. package/src/components/NSLink.module.css +36 -36
  198. package/src/components/NSLink.tsx +25 -25
  199. package/src/components/NSLinkBlue.tsx +21 -21
  200. package/src/components/NSLinkGreen.tsx +12 -12
  201. package/src/components/NSLinkRed.tsx +12 -12
  202. package/src/components/NSListGrouped.module.css +69 -69
  203. package/src/components/NSListGrouped.tsx +106 -106
  204. package/src/components/NSListProduct.tsx +44 -44
  205. package/src/components/NSLoading.module.css +30 -30
  206. package/src/components/NSLoading.tsx +21 -21
  207. package/src/components/NSMenuAction.module.css +88 -88
  208. package/src/components/NSMenuAction.tsx +90 -90
  209. package/src/components/NSMenuButton.module.css +44 -44
  210. package/src/components/NSMenuButton.tsx +206 -206
  211. package/src/components/NSNoData.module.css +9 -9
  212. package/src/components/NSNoData.tsx +24 -24
  213. package/src/components/NSPagination.module.css +85 -85
  214. package/src/components/NSPagination.tsx +182 -182
  215. package/src/components/NSPanel.module.css +19 -19
  216. package/src/components/NSPanel.tsx +24 -24
  217. package/src/components/NSPanelAccordion.module.css +4 -4
  218. package/src/components/NSPanelAccordion.tsx +51 -51
  219. package/src/components/NSRange.module.css +66 -66
  220. package/src/components/NSRange.tsx +83 -83
  221. package/src/components/NSRepeater.tsx +240 -240
  222. package/src/components/NSRepeaterNSBoxSchemaVariable.tsx +84 -84
  223. package/src/components/NSRepeaterNSTag.tsx +79 -79
  224. package/src/components/NSRow.module.css +17 -17
  225. package/src/components/NSRow.tsx +24 -24
  226. package/src/components/NSSection.module.css +4 -4
  227. package/src/components/NSSection.tsx +26 -26
  228. package/src/components/NSSectionCards.module.css +38 -38
  229. package/src/components/NSSectionCards.tsx +51 -51
  230. package/src/components/NSSectionTiles.module.css +10 -10
  231. package/src/components/NSSectionTiles.tsx +25 -25
  232. package/src/components/NSSectionTitle.tsx +21 -21
  233. package/src/components/NSSpace.tsx +28 -28
  234. package/src/components/NSTabPage.module.css +59 -59
  235. package/src/components/NSTabPage.tsx +91 -91
  236. package/src/components/NSTable.module.css +263 -263
  237. package/src/components/NSTable.tsx +471 -471
  238. package/src/components/NSTag.tsx +74 -74
  239. package/src/components/NSTile.module.css +76 -76
  240. package/src/components/NSTile.tsx +27 -27
  241. package/src/components/NSTimelineMonthly.module.css +71 -71
  242. package/src/components/NSTimelineMonthly.tsx +44 -44
  243. package/src/components/NSTitle.module.css +15 -15
  244. package/src/components/NSTitle.tsx +19 -19
  245. package/src/formatter/BackColorFormatter.tsx +23 -23
  246. package/src/formatter/BaseColumnFormatter.ts +16 -16
  247. package/src/formatter/BaseURLImageFormatter.tsx +28 -28
  248. package/src/formatter/BooleanFormatter.ts +22 -22
  249. package/src/formatter/DateFormatter.ts +20 -20
  250. package/src/formatter/DateTimeFormatter.ts +20 -20
  251. package/src/formatter/DurationFormatter.ts +13 -13
  252. package/src/formatter/EmailFormatter.tsx +21 -21
  253. package/src/formatter/EnumFormatter.ts +13 -13
  254. package/src/formatter/FloatFormatter.ts +23 -23
  255. package/src/formatter/ForeColorFormatter.tsx +24 -24
  256. package/src/formatter/IDFormatter.tsx +37 -37
  257. package/src/formatter/IPFormatter.ts +13 -13
  258. package/src/formatter/IntegerFormatter.ts +23 -23
  259. package/src/formatter/JsonFormatter.ts +21 -21
  260. package/src/formatter/MoneyFormatter.ts +23 -23
  261. package/src/formatter/PhoneFormatter.tsx +21 -21
  262. package/src/formatter/StringFormatter.tsx +43 -43
  263. package/src/formatter/TimeFormatter.ts +20 -20
  264. package/src/formatter/URLFormatter.tsx +21 -21
  265. package/src/formatter/UnknowFormatter.ts +18 -18
  266. package/src/index.tsx +7 -7
  267. package/src/main.ts +210 -210
  268. package/src/pages/NSNotFoundPage.module.css +18 -18
  269. package/src/pages/NSNotFoundPage.tsx +11 -11
  270. package/src/pages/NSUpdating.module.css +35 -35
  271. package/src/pages/NSUpdating.tsx +32 -32
  272. package/src/props/IBackgroundPropps.ts +5 -5
  273. package/src/props/IBaseComponentProps.ts +8 -8
  274. package/src/props/IHeaderIconProps.ts +10 -10
  275. package/src/props/IHeaderProps.ts +7 -7
  276. package/src/props/IImageProps.ts +4 -4
  277. package/src/props/ILinkProps.ts +5 -5
  278. package/src/props/IValidationNumberProps.ts +4 -4
  279. package/src/props/IValidationPrecisionProps.ts +3 -3
  280. package/src/props/IValidationProps.ts +9 -9
  281. package/src/props/IValidationRegexProps.ts +4 -4
  282. package/src/props/IValidationStringProps.ts +4 -4
  283. package/src/routing/INSRouterMaker.ts +6 -6
  284. package/src/routing/INSRouterProps.ts +5 -5
  285. package/src/routing/INSRouterState.ts +5 -5
  286. package/src/routing/NSRouterMaker.tsx +33 -33
  287. package/src/routing/Notifier.ts +79 -79
  288. package/tsconfig.json +43 -43
@@ -1,540 +1,540 @@
1
- "use client";
2
-
3
- import Styles from "./NSBoxSchemaBase.module.css";
4
-
5
- import React, { createRef } from "react";
6
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
- import { IValidationProps } from "../props/IValidationProps";
8
- import { IValidationStringProps } from "../props/IValidationStringProps";
9
- import { safeMenuMenuItem } from "./NSMenuButton";
10
- import { INSBoxBaseLayoutProps } from "./NSBoxBaseLayout";
11
- import { INSBox } from "./INSBox";
12
- import { NSBoxEnum } from "./NSBoxEnum";
13
- import { AnySchema, ArraySchema, BaseNumberSchema, BasePrecisionSchema, BaseTypeSchema, BaseVariableSchema, BigIntSchema, BoolSchema, ColorSchema, DateSchema, DateTimeSchema, DecimalSchema, DoubleSchema, DurationSchema, EmailSchema, EntitySchema, EnumSchema, FilePathSchema, FloatSchema, FontSchema, IntegerSchema, IPV4RangeSchema, IPV4Schema, IPV6RangeSchema, IPV6Schema, MediumIntSchema, MoneySchema, ObjectSchema, PhoneSchema, RealSchema, SmallIntSchema, StringSchema, TimeSchema, TimeZoneSchema, TinyIntSchema, TypeSchema, URLSchema, VariableSchema, VariableType, VersionSchema } from "namirasoft-schema";
14
- import { NSBoxBoolean } from "./NSBoxBoolean";
15
- import { NSRow } from "./NSRow";
16
- import { NSBoxString } from "./NSBoxString";
17
- import { NSBoxInteger } from "./NSBoxInteger";
18
- import { NSBoxBaseLayoutRecursive } from "./NSBoxBaseLayoutRecursive";
19
- import { NSRepeaterNSBoxSchemaVariable } from "./NSRepeaterNSBoxSchemaVariable";
20
- import { NSColumn } from "./NSColumn";
21
-
22
- export interface NSBoxSchemaBaseProps extends IBaseComponentProps, IValidationProps, IValidationStringProps, INSBoxBaseLayoutProps<string, NSBoxSchemaBase>
23
- {
24
- name: string;
25
- depth?: number;
26
- }
27
-
28
- export interface NSBoxSchemaBaseState
29
- {
30
- type: VariableType | null;
31
- show_details: boolean;
32
- }
33
-
34
- export class NSBoxSchemaBase extends React.Component<NSBoxSchemaBaseProps, NSBoxSchemaBaseState> implements INSBox
35
- {
36
- private NSBoxEnum_Type = createRef<NSBoxEnum<VariableType>>();
37
- private NSBoxString_Name = createRef<NSBoxString>();
38
- private NSBoxBoolean_Required = createRef<NSBoxBoolean>();
39
- private NSBoxSchemaBase_ArraySchema = createRef<NSBoxSchemaBase>();
40
- private NSRepeaterNSBoxSchemaVariable_ObjectFields = createRef<NSRepeaterNSBoxSchemaVariable>();
41
- private NSBoxInteger_Min = createRef<NSBoxInteger>();
42
- private NSBoxInteger_Max = createRef<NSBoxInteger>();
43
- private NSBoxInteger_Precision = createRef<NSBoxInteger>();
44
- private NSBoxInteger_MinLength = createRef<NSBoxInteger>();
45
- private NSBoxInteger_MaxLength = createRef<NSBoxInteger>();
46
- private NSBoxString_Regex = createRef<NSBoxString>();
47
- private NSBoxString_ValidList = createRef<NSBoxString>();
48
- private NSBoxString_InalidList = createRef<NSBoxString>();
49
- private NSBoxString_PlaceHolder = createRef<NSBoxString>();
50
- NSBoxBaseLayoutRecursive_Main = createRef<NSBoxBaseLayoutRecursive>();
51
- constructor(props: NSBoxSchemaBaseProps)
52
- {
53
- super(props);
54
- this.state = {
55
- type: null,
56
- show_details: false,
57
- };
58
- this.isEmpty = this.isEmpty.bind(this);
59
- this.getError = this.getError.bind(this);
60
- this.getValue = this.getValue.bind(this);
61
- this.setValue = this.setValue.bind(this);
62
- this.onChanged = this.onChanged.bind(this);
63
- }
64
- isEmpty(value: BaseTypeSchema | null): boolean
65
- {
66
- if (value)
67
- if (value.type || value.example || value.valids?.length > 0 || value.invalids?.length > 0)
68
- return false;
69
- return true;
70
- }
71
- getError(): string | null
72
- {
73
- return null;
74
- // let ans = this.NSBoxEnum_Type.current?.getError() ||
75
- // this.NSBoxString_Name.current?.getError() ||
76
- // this.NSBoxBoolean_Required.current?.getError() ||
77
- // this.NSBoxSchemaBase_ArraySchema.current?.getError() ||
78
- // this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.getError() ||
79
- // this.NSBoxInteger_Min.current?.getError() ||
80
- // this.NSBoxInteger_Max.current?.getError() ||
81
- // this.NSBoxInteger_Precision.current?.getError() ||
82
- // this.NSBoxInteger_MinLength.current?.getError() ||
83
- // this.NSBoxInteger_MaxLength.current?.getError() ||
84
- // this.NSBoxString_Regex.current?.getError() ||
85
- // this.NSBoxString_ValidList.current?.getError() ||
86
- // this.NSBoxString_InalidList.current?.getError() ||
87
- // this.NSBoxString_PlaceHolder.current?.getError();
88
- // return ans ?? null;
89
- }
90
- getValue(checkError: boolean = true): BaseTypeSchema | null
91
- {
92
- return NSBoxBaseLayoutRecursive.checkGetValue(this, checkError, () =>
93
- {
94
- let type = this.NSBoxEnum_Type.current?.getValueEnumOne(VariableType, VariableType.Any, checkError) ?? null;
95
- let required = this.NSBoxBoolean_Required.current?.getValueBool(checkError) ?? false;
96
-
97
- let name = this.NSBoxString_Name.current?.getValue(checkError) ?? null;
98
- let min = this.NSBoxInteger_Min.current?.getValue(checkError) ?? null;
99
- let max = this.NSBoxInteger_Max.current?.getValue(checkError) ?? null;
100
- let precision = this.NSBoxInteger_Precision.current?.getValue(checkError) ?? null;
101
- let min_length = this.NSBoxInteger_MinLength.current?.getValue(checkError) ?? null;
102
- let max_length = this.NSBoxInteger_MaxLength.current?.getValue(checkError) ?? null;
103
- let regex = this.NSBoxString_Regex.current?.getValue(checkError) ?? null;
104
- let schema = this.NSBoxSchemaBase_ArraySchema.current?.getValue(checkError) ?? null;
105
- let fields = this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.getValue(checkError) ?? null;
106
- let valid_list = this.NSBoxString_ValidList.current?.getValue(checkError)?.split(",") ?? [];
107
- let invlid_list = this.NSBoxString_InalidList.current?.getValue(checkError)?.split(",") ?? [];
108
- let place_holder = this.NSBoxString_PlaceHolder.current?.getValue(checkError) ?? undefined;
109
- let enum_object: { [name: string]: string } = {};
110
- invlid_list.forEach((v) => enum_object[v] = v);
111
-
112
- let ans = null;
113
- if (type)
114
- {
115
- switch (type)
116
- {
117
- /* VariableType */
118
- case VariableType.Any:
119
- ans = new AnySchema(required);
120
- break;
121
- case VariableType.Boolean:
122
- ans = new BoolSchema(required);
123
- break;
124
- case VariableType.TinyInt:
125
- ans = new TinyIntSchema(required, max, min);
126
- break;
127
- case VariableType.SmallInt:
128
- ans = new SmallIntSchema(required, max, min);
129
- break;
130
- case VariableType.MediumInt:
131
- ans = new MediumIntSchema(required, max, min);
132
- break;
133
- case VariableType.Integer:
134
- ans = new IntegerSchema(required, max, min);
135
- break;
136
- case VariableType.BigInt:
137
- ans = new BigIntSchema(required, max, min);
138
- break;
139
- case VariableType.Float:
140
- ans = new FloatSchema(required, max, min, precision);
141
- break;
142
- case VariableType.Double:
143
- ans = new DoubleSchema(required, max, min, precision);
144
- break;
145
- case VariableType.Decimal:
146
- ans = new DecimalSchema(required, max, min, precision);
147
- break;
148
- case VariableType.Real:
149
- ans = new RealSchema(required, max, min, precision);
150
- break;
151
- case VariableType.Money:
152
- ans = new MoneySchema(required, max, min);
153
- break;
154
- case VariableType.String:
155
- ans = new StringSchema(required, min_length, max_length);
156
- if (regex)
157
- ans.regex = new RegExp(regex);
158
- break;
159
- case VariableType.Date:
160
- ans = new DateSchema(required);
161
- break;
162
- case VariableType.Time:
163
- ans = new TimeSchema(required);
164
- break;
165
- case VariableType.DateTime:
166
- ans = new DateTimeSchema(required);
167
- break;
168
- case VariableType.TimeZone:
169
- ans = new TimeZoneSchema(required);
170
- break;
171
- case VariableType.Duration:
172
- ans = new DurationSchema(required);
173
- break;
174
- case VariableType.Email:
175
- ans = new EmailSchema(required);
176
- break;
177
- case VariableType.Phone:
178
- ans = new PhoneSchema(required);
179
- break;
180
- case VariableType.Version:
181
- ans = new VersionSchema(required);
182
- break;
183
- case VariableType.IPV4:
184
- ans = new IPV4Schema(required);
185
- break;
186
- case VariableType.IPV6:
187
- ans = new IPV6Schema(required);
188
- break;
189
- case VariableType.IPV4Range:
190
- ans = new IPV4RangeSchema(required);
191
- break;
192
- case VariableType.IPV6Range:
193
- ans = new IPV6RangeSchema(required);
194
- break;
195
- case VariableType.Color:
196
- ans = new ColorSchema(required);
197
- break;
198
- case VariableType.Font:
199
- ans = new FontSchema(required);
200
- break;
201
- case VariableType.FilePath:
202
- ans = new FilePathSchema(required);
203
- break;
204
- case VariableType.URL:
205
- ans = new URLSchema(required);
206
- break;
207
- case VariableType.Enum:
208
- ans = new EnumSchema(name ?? "", required, enum_object);
209
- break;
210
- case VariableType.Entity:
211
- // todo VariableType.Entity
212
- ans = new EntitySchema(required, "", "", "");
213
- break;
214
- case VariableType.Array:
215
- if (schema)
216
- ans = new ArraySchema(required, [schema], min, max);
217
- break;
218
- case VariableType.Object:
219
- if (fields)
220
- ans = new ObjectSchema(name ?? "", required, fields);
221
- break;
222
- case VariableType.Type:
223
- ans = new TypeSchema(required);
224
- break;
225
- case VariableType.Variable:
226
- ans = new VariableSchema(required);
227
- break;
228
- }
229
- if (ans)
230
- {
231
- ans.setValid(...valid_list);
232
- ans.setInvalid(...invlid_list);
233
- ans.example = place_holder;
234
- }
235
- }
236
- return ans;
237
- });
238
- }
239
- setValue(value: BaseTypeSchema | null, callback?: () => void): void
240
- {
241
- this.NSBoxEnum_Type.current?.setValue(value?.type ?? null, () =>
242
- {
243
- this.NSBoxBoolean_Required.current?.setValueBool(value?.required ?? false);
244
-
245
- let name = null;
246
- let min = null;
247
- let max = null;
248
- let precision = null;
249
- let min_length = null;
250
- let max_length = null;
251
- let regex = null;
252
- let array_schema = null;
253
- let object_fields: BaseVariableSchema[] = [];
254
- let valid_list = null;
255
- let invlid_list = null;
256
- let place_holder = null;
257
-
258
- if (value?.type)
259
- switch (value?.type)
260
- {
261
- /* VariableType */
262
- case VariableType.Any:
263
- break;
264
- case VariableType.Boolean:
265
- break;
266
- case VariableType.TinyInt:
267
- case VariableType.SmallInt:
268
- case VariableType.MediumInt:
269
- case VariableType.Integer:
270
- case VariableType.BigInt:
271
- {
272
- let schema = value as BaseNumberSchema;
273
- min = schema.min;
274
- max = schema.max;
275
- break;
276
- }
277
- case VariableType.Float:
278
- case VariableType.Double:
279
- case VariableType.Decimal:
280
- case VariableType.Real:
281
- case VariableType.Money:
282
- {
283
- let schema = value as BasePrecisionSchema;
284
- min = schema.min;
285
- max = schema.max;
286
- precision = schema.precision;
287
- break;
288
- }
289
- case VariableType.String:
290
- {
291
- let schema = value as StringSchema;
292
- min_length = schema.min_length;
293
- max_length = schema.max_length;
294
- if (schema.regex)
295
- regex = schema.regex + "";
296
- break;
297
- }
298
- case VariableType.Date:
299
- case VariableType.Time:
300
- case VariableType.DateTime:
301
- case VariableType.TimeZone:
302
- case VariableType.Duration:
303
- case VariableType.Email:
304
- case VariableType.Phone:
305
- case VariableType.Version:
306
- case VariableType.IPV4:
307
- case VariableType.IPV6:
308
- case VariableType.IPV4Range:
309
- case VariableType.IPV6Range:
310
- case VariableType.Color:
311
- case VariableType.Font:
312
- case VariableType.FilePath:
313
- case VariableType.URL:
314
- break;
315
- case VariableType.Enum:
316
- let schema = value as EnumSchema;
317
- name = schema.name;
318
- break;
319
- case VariableType.Entity:
320
- // todo VariableType.Entity
321
- break;
322
- case VariableType.Array:
323
- {
324
- let schema = value as ArraySchema;
325
- if (schema.items.length > 0)
326
- array_schema = schema.items[0];
327
- break;
328
- }
329
- case VariableType.Object:
330
- {
331
- let schema = value as ObjectSchema;
332
- name = schema.name;
333
- object_fields = schema.fields ?? [];
334
- break;
335
- }
336
- case VariableType.Type:
337
- break;
338
- case VariableType.Variable:
339
- break;
340
- }
341
-
342
- this.NSBoxString_Name.current?.setValue(name);
343
- this.NSBoxInteger_Min.current?.setValue(min);
344
- this.NSBoxInteger_Max.current?.setValue(max);
345
- this.NSBoxInteger_Precision.current?.setValue(precision);
346
- this.NSBoxInteger_MinLength.current?.setValue(min_length);
347
- this.NSBoxInteger_MaxLength.current?.setValue(max_length);
348
- this.NSBoxString_Regex.current?.setValue(regex);
349
- this.NSBoxSchemaBase_ArraySchema.current?.setValue(array_schema);
350
- this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.setValue(object_fields);
351
- this.NSBoxString_ValidList.current?.setValue(valid_list);
352
- this.NSBoxString_InalidList.current?.setValue(invlid_list);
353
- this.NSBoxString_PlaceHolder.current?.setValue(place_holder);
354
-
355
- this.props.onChanged?.(this);
356
- callback?.();
357
- });
358
- }
359
- private onChanged()
360
- {
361
- this.props.onChanged?.(this);
362
- }
363
- override render()
364
- {
365
- let menu = safeMenuMenuItem(this.props, (items) =>
366
- {
367
- items.push({
368
- title: "Show Detail",
369
- icon: this.state.show_details ? "https://static.namirasoft.com/image/concept/close/blue.svg" : "https://static.namirasoft.com/image/concept/ellipsis/vertical-blue.svg",
370
- onClick: () =>
371
- {
372
- this.setState({ show_details: !this.state.show_details })
373
- }
374
- });
375
- });
376
-
377
- /* VariableType */
378
- let isNumber = this.state.type && [VariableType.TinyInt, VariableType.SmallInt, VariableType.MediumInt, VariableType.Integer, VariableType.BigInt, VariableType.Float, VariableType.Double, VariableType.Decimal, VariableType.Real, VariableType.Money, VariableType.Array].includes(this.state.type);
379
- let isPrecision = this.state.type && [VariableType.Float, VariableType.Double, VariableType.Decimal, VariableType.Real, VariableType.Money].includes(this.state.type);
380
- let hasName = this.state.type && [VariableType.Enum, VariableType.Object].includes(this.state.type);
381
-
382
- return (
383
- <NSBoxBaseLayoutRecursive
384
- ref={this.NSBoxBaseLayoutRecursive_Main}
385
- {...this.props}
386
- depth={this.props.depth ?? 0}
387
- menu={menu}
388
- >
389
- <NSRow
390
- >
391
- <NSBoxEnum<VariableType>
392
- ref={this.NSBoxEnum_Type}
393
- required
394
- title="Type"
395
- multiple={false}
396
- getEnumObject={() => VariableType}
397
- /* VariableType */
398
- invalids={[VariableType.Any, ...(this.props.invalids ?? [])]}
399
- onChanged={(b) =>
400
- {
401
- this.setState({ type: b.getValueEnumOne(VariableType, VariableType.Any) });
402
- this.onChanged();
403
- }}
404
- classList={[Styles.ns_box_schema_base_type]}
405
- />
406
- {
407
- hasName &&
408
- <NSBoxString
409
- ref={this.NSBoxString_Name}
410
- required
411
- title="Name"
412
- classList={[Styles.ns_box_schema_base_name]}
413
- />
414
- }
415
- <NSBoxBoolean
416
- ref={this.NSBoxBoolean_Required}
417
- required
418
- title="Required"
419
- onChanged={() => this.onChanged()}
420
- classList={[hasName ? Styles.ns_box_schema_base_required_withname : Styles.ns_box_schema_base_required_withoutname]}
421
- />
422
- </NSRow>
423
- {
424
- this.state.type === VariableType.Array &&
425
- <NSBoxSchemaBase
426
- ref={this.NSBoxSchemaBase_ArraySchema}
427
- name={this.props.name}
428
- required
429
- title="Array Elements' Schema"
430
- style={{ width: "100%" }}
431
- invalids={[VariableType.Any, VariableType.Object, VariableType.Array]}
432
- depth={(this.props.depth ?? 0) + 1}
433
- />
434
- }
435
- {
436
- this.state.type === VariableType.Object &&
437
- <NSBoxBaseLayoutRecursive
438
- required
439
- depth={(this.props.depth ?? 0) + 1}
440
- title="Fields"
441
- style={{ width: "100%" }}
442
- >
443
- <NSRepeaterNSBoxSchemaVariable
444
- ref={this.NSRepeaterNSBoxSchemaVariable_ObjectFields}
445
- name={this.props.name}
446
- item_title="Field"
447
- style={{ width: "100%" }}
448
- />
449
- </NSBoxBaseLayoutRecursive>
450
- }
451
- {
452
- isNumber &&
453
- <NSRow
454
- style={{ display: this.state.show_details ? "" : "none", width: "100%", justifyContent: "left" }}
455
- >
456
- <NSBoxInteger
457
- ref={this.NSBoxInteger_Min}
458
- required={false}
459
- title="Min"
460
- style={{ minWidth: "150px", width: "150px" }}
461
- />
462
- <NSBoxInteger
463
- ref={this.NSBoxInteger_Max}
464
- required={false}
465
- title="Max"
466
- style={{ minWidth: "150px", width: "150px" }}
467
- />
468
- {
469
- isPrecision &&
470
- <NSBoxInteger
471
- ref={this.NSBoxInteger_Precision}
472
- required={false}
473
- title="Precision"
474
- style={{ minWidth: "150px", width: "150px" }}
475
- />
476
- }
477
- </NSRow>
478
- }
479
- {
480
- this.state.type === VariableType.String &&
481
- <NSColumn
482
- style={{ display: this.state.show_details ? "" : "none", width: "100%" }}
483
- >
484
- <NSRow
485
- style={{ justifyContent: "left" }}
486
- >
487
- <NSBoxInteger
488
- ref={this.NSBoxInteger_MinLength}
489
- required={false}
490
- title="Min Length"
491
- style={{ minWidth: "150px", width: "150px" }}
492
- />
493
- <NSBoxInteger
494
- ref={this.NSBoxInteger_MaxLength}
495
- required={false}
496
- title="Max Length"
497
- style={{ minWidth: "150px", width: "150px" }}
498
- />
499
- </NSRow>
500
- <NSBoxString
501
- ref={this.NSBoxString_Regex}
502
- required={false}
503
- title="Regex"
504
- style={{ width: "100%" }}
505
- />
506
- </NSColumn>
507
- }
508
- <div style={{ display: (this.state.type === VariableType.Enum || this.state.show_details) ? "" : "none", width: "100%" }}>
509
- <NSBoxString
510
- ref={this.NSBoxString_ValidList}
511
- required={this.state.type === VariableType.Enum}
512
- title="Valid List"
513
- placeholder="Please enter valid list and sperate them via comma."
514
- style={{ width: "100%" }}
515
- onChanged={() => this.onChanged()}
516
- />
517
- </div>
518
- <NSColumn
519
- style={{ display: this.state.show_details ? "" : "none", width: "100%" }}
520
- >
521
- <NSBoxString
522
- ref={this.NSBoxString_InalidList}
523
- required={false}
524
- title="Invalid List"
525
- placeholder="Please enter invvalid list and sperate them via comma."
526
- style={{ width: "100%" }}
527
- onChanged={() => this.onChanged()}
528
- />
529
- <NSBoxString
530
- ref={this.NSBoxString_PlaceHolder}
531
- required={false}
532
- title="Place Holder"
533
- style={{ width: "100%" }}
534
- onChanged={() => this.onChanged()}
535
- />
536
- </NSColumn>
537
- </NSBoxBaseLayoutRecursive>
538
- );
539
- }
1
+ "use client";
2
+
3
+ import Styles from "./NSBoxSchemaBase.module.css";
4
+
5
+ import React, { createRef } from "react";
6
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
+ import { IValidationProps } from "../props/IValidationProps";
8
+ import { IValidationStringProps } from "../props/IValidationStringProps";
9
+ import { safeMenuMenuItem } from "./NSMenuButton";
10
+ import { INSBoxBaseLayoutProps } from "./NSBoxBaseLayout";
11
+ import { INSBox } from "./INSBox";
12
+ import { NSBoxEnum } from "./NSBoxEnum";
13
+ import { AnySchema, ArraySchema, BaseNumberSchema, BasePrecisionSchema, BaseTypeSchema, BaseVariableSchema, BigIntSchema, BoolSchema, ColorSchema, DateSchema, DateTimeSchema, DecimalSchema, DoubleSchema, DurationSchema, EmailSchema, EntitySchema, EnumSchema, FilePathSchema, FloatSchema, FontSchema, IntegerSchema, IPV4RangeSchema, IPV4Schema, IPV6RangeSchema, IPV6Schema, MediumIntSchema, MoneySchema, ObjectSchema, PhoneSchema, RealSchema, SmallIntSchema, StringSchema, TimeSchema, TimeZoneSchema, TinyIntSchema, TypeSchema, URLSchema, VariableSchema, VariableType, VersionSchema } from "namirasoft-schema";
14
+ import { NSBoxBoolean } from "./NSBoxBoolean";
15
+ import { NSRow } from "./NSRow";
16
+ import { NSBoxString } from "./NSBoxString";
17
+ import { NSBoxInteger } from "./NSBoxInteger";
18
+ import { NSBoxBaseLayoutRecursive } from "./NSBoxBaseLayoutRecursive";
19
+ import { NSRepeaterNSBoxSchemaVariable } from "./NSRepeaterNSBoxSchemaVariable";
20
+ import { NSColumn } from "./NSColumn";
21
+
22
+ export interface NSBoxSchemaBaseProps extends IBaseComponentProps, IValidationProps, IValidationStringProps, INSBoxBaseLayoutProps<string, NSBoxSchemaBase>
23
+ {
24
+ name: string;
25
+ depth?: number;
26
+ }
27
+
28
+ export interface NSBoxSchemaBaseState
29
+ {
30
+ type: VariableType | null;
31
+ show_details: boolean;
32
+ }
33
+
34
+ export class NSBoxSchemaBase extends React.Component<NSBoxSchemaBaseProps, NSBoxSchemaBaseState> implements INSBox
35
+ {
36
+ private NSBoxEnum_Type = createRef<NSBoxEnum<VariableType>>();
37
+ private NSBoxString_Name = createRef<NSBoxString>();
38
+ private NSBoxBoolean_Required = createRef<NSBoxBoolean>();
39
+ private NSBoxSchemaBase_ArraySchema = createRef<NSBoxSchemaBase>();
40
+ private NSRepeaterNSBoxSchemaVariable_ObjectFields = createRef<NSRepeaterNSBoxSchemaVariable>();
41
+ private NSBoxInteger_Min = createRef<NSBoxInteger>();
42
+ private NSBoxInteger_Max = createRef<NSBoxInteger>();
43
+ private NSBoxInteger_Precision = createRef<NSBoxInteger>();
44
+ private NSBoxInteger_MinLength = createRef<NSBoxInteger>();
45
+ private NSBoxInteger_MaxLength = createRef<NSBoxInteger>();
46
+ private NSBoxString_Regex = createRef<NSBoxString>();
47
+ private NSBoxString_ValidList = createRef<NSBoxString>();
48
+ private NSBoxString_InalidList = createRef<NSBoxString>();
49
+ private NSBoxString_PlaceHolder = createRef<NSBoxString>();
50
+ NSBoxBaseLayoutRecursive_Main = createRef<NSBoxBaseLayoutRecursive>();
51
+ constructor(props: NSBoxSchemaBaseProps)
52
+ {
53
+ super(props);
54
+ this.state = {
55
+ type: null,
56
+ show_details: false,
57
+ };
58
+ this.isEmpty = this.isEmpty.bind(this);
59
+ this.getError = this.getError.bind(this);
60
+ this.getValue = this.getValue.bind(this);
61
+ this.setValue = this.setValue.bind(this);
62
+ this.onChanged = this.onChanged.bind(this);
63
+ }
64
+ isEmpty(value: BaseTypeSchema | null): boolean
65
+ {
66
+ if (value)
67
+ if (value.type || value.example || value.valids?.length > 0 || value.invalids?.length > 0)
68
+ return false;
69
+ return true;
70
+ }
71
+ getError(): string | null
72
+ {
73
+ return null;
74
+ // let ans = this.NSBoxEnum_Type.current?.getError() ||
75
+ // this.NSBoxString_Name.current?.getError() ||
76
+ // this.NSBoxBoolean_Required.current?.getError() ||
77
+ // this.NSBoxSchemaBase_ArraySchema.current?.getError() ||
78
+ // this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.getError() ||
79
+ // this.NSBoxInteger_Min.current?.getError() ||
80
+ // this.NSBoxInteger_Max.current?.getError() ||
81
+ // this.NSBoxInteger_Precision.current?.getError() ||
82
+ // this.NSBoxInteger_MinLength.current?.getError() ||
83
+ // this.NSBoxInteger_MaxLength.current?.getError() ||
84
+ // this.NSBoxString_Regex.current?.getError() ||
85
+ // this.NSBoxString_ValidList.current?.getError() ||
86
+ // this.NSBoxString_InalidList.current?.getError() ||
87
+ // this.NSBoxString_PlaceHolder.current?.getError();
88
+ // return ans ?? null;
89
+ }
90
+ getValue(checkError: boolean = true): BaseTypeSchema | null
91
+ {
92
+ return NSBoxBaseLayoutRecursive.checkGetValue(this, checkError, () =>
93
+ {
94
+ let type = this.NSBoxEnum_Type.current?.getValueEnumOne(VariableType, VariableType.Any, checkError) ?? null;
95
+ let required = this.NSBoxBoolean_Required.current?.getValueBool(checkError) ?? false;
96
+
97
+ let name = this.NSBoxString_Name.current?.getValue(checkError) ?? null;
98
+ let min = this.NSBoxInteger_Min.current?.getValue(checkError) ?? null;
99
+ let max = this.NSBoxInteger_Max.current?.getValue(checkError) ?? null;
100
+ let precision = this.NSBoxInteger_Precision.current?.getValue(checkError) ?? null;
101
+ let min_length = this.NSBoxInteger_MinLength.current?.getValue(checkError) ?? null;
102
+ let max_length = this.NSBoxInteger_MaxLength.current?.getValue(checkError) ?? null;
103
+ let regex = this.NSBoxString_Regex.current?.getValue(checkError) ?? null;
104
+ let schema = this.NSBoxSchemaBase_ArraySchema.current?.getValue(checkError) ?? null;
105
+ let fields = this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.getValue(checkError) ?? null;
106
+ let valid_list = this.NSBoxString_ValidList.current?.getValue(checkError)?.split(",") ?? [];
107
+ let invlid_list = this.NSBoxString_InalidList.current?.getValue(checkError)?.split(",") ?? [];
108
+ let place_holder = this.NSBoxString_PlaceHolder.current?.getValue(checkError) ?? undefined;
109
+ let enum_object: { [name: string]: string } = {};
110
+ invlid_list.forEach((v) => enum_object[v] = v);
111
+
112
+ let ans = null;
113
+ if (type)
114
+ {
115
+ switch (type)
116
+ {
117
+ /* VariableType */
118
+ case VariableType.Any:
119
+ ans = new AnySchema(required);
120
+ break;
121
+ case VariableType.Boolean:
122
+ ans = new BoolSchema(required);
123
+ break;
124
+ case VariableType.TinyInt:
125
+ ans = new TinyIntSchema(required, max, min);
126
+ break;
127
+ case VariableType.SmallInt:
128
+ ans = new SmallIntSchema(required, max, min);
129
+ break;
130
+ case VariableType.MediumInt:
131
+ ans = new MediumIntSchema(required, max, min);
132
+ break;
133
+ case VariableType.Integer:
134
+ ans = new IntegerSchema(required, max, min);
135
+ break;
136
+ case VariableType.BigInt:
137
+ ans = new BigIntSchema(required, max, min);
138
+ break;
139
+ case VariableType.Float:
140
+ ans = new FloatSchema(required, max, min, precision);
141
+ break;
142
+ case VariableType.Double:
143
+ ans = new DoubleSchema(required, max, min, precision);
144
+ break;
145
+ case VariableType.Decimal:
146
+ ans = new DecimalSchema(required, max, min, precision);
147
+ break;
148
+ case VariableType.Real:
149
+ ans = new RealSchema(required, max, min, precision);
150
+ break;
151
+ case VariableType.Money:
152
+ ans = new MoneySchema(required, max, min);
153
+ break;
154
+ case VariableType.String:
155
+ ans = new StringSchema(required, min_length, max_length);
156
+ if (regex)
157
+ ans.regex = new RegExp(regex);
158
+ break;
159
+ case VariableType.Date:
160
+ ans = new DateSchema(required);
161
+ break;
162
+ case VariableType.Time:
163
+ ans = new TimeSchema(required);
164
+ break;
165
+ case VariableType.DateTime:
166
+ ans = new DateTimeSchema(required);
167
+ break;
168
+ case VariableType.TimeZone:
169
+ ans = new TimeZoneSchema(required);
170
+ break;
171
+ case VariableType.Duration:
172
+ ans = new DurationSchema(required);
173
+ break;
174
+ case VariableType.Email:
175
+ ans = new EmailSchema(required);
176
+ break;
177
+ case VariableType.Phone:
178
+ ans = new PhoneSchema(required);
179
+ break;
180
+ case VariableType.Version:
181
+ ans = new VersionSchema(required);
182
+ break;
183
+ case VariableType.IPV4:
184
+ ans = new IPV4Schema(required);
185
+ break;
186
+ case VariableType.IPV6:
187
+ ans = new IPV6Schema(required);
188
+ break;
189
+ case VariableType.IPV4Range:
190
+ ans = new IPV4RangeSchema(required);
191
+ break;
192
+ case VariableType.IPV6Range:
193
+ ans = new IPV6RangeSchema(required);
194
+ break;
195
+ case VariableType.Color:
196
+ ans = new ColorSchema(required);
197
+ break;
198
+ case VariableType.Font:
199
+ ans = new FontSchema(required);
200
+ break;
201
+ case VariableType.FilePath:
202
+ ans = new FilePathSchema(required);
203
+ break;
204
+ case VariableType.URL:
205
+ ans = new URLSchema(required);
206
+ break;
207
+ case VariableType.Enum:
208
+ ans = new EnumSchema(name ?? "", required, enum_object);
209
+ break;
210
+ case VariableType.Entity:
211
+ // todo VariableType.Entity
212
+ ans = new EntitySchema(required, "", "", "");
213
+ break;
214
+ case VariableType.Array:
215
+ if (schema)
216
+ ans = new ArraySchema(required, [schema], min, max);
217
+ break;
218
+ case VariableType.Object:
219
+ if (fields)
220
+ ans = new ObjectSchema(name ?? "", required, fields);
221
+ break;
222
+ case VariableType.Type:
223
+ ans = new TypeSchema(required);
224
+ break;
225
+ case VariableType.Variable:
226
+ ans = new VariableSchema(required);
227
+ break;
228
+ }
229
+ if (ans)
230
+ {
231
+ ans.setValid(...valid_list);
232
+ ans.setInvalid(...invlid_list);
233
+ ans.example = place_holder;
234
+ }
235
+ }
236
+ return ans;
237
+ });
238
+ }
239
+ setValue(value: BaseTypeSchema | null, callback?: () => void): void
240
+ {
241
+ this.NSBoxEnum_Type.current?.setValue(value?.type ?? null, () =>
242
+ {
243
+ this.NSBoxBoolean_Required.current?.setValueBool(value?.required ?? false);
244
+
245
+ let name = null;
246
+ let min = null;
247
+ let max = null;
248
+ let precision = null;
249
+ let min_length = null;
250
+ let max_length = null;
251
+ let regex = null;
252
+ let array_schema = null;
253
+ let object_fields: BaseVariableSchema[] = [];
254
+ let valid_list = null;
255
+ let invlid_list = null;
256
+ let place_holder = null;
257
+
258
+ if (value?.type)
259
+ switch (value?.type)
260
+ {
261
+ /* VariableType */
262
+ case VariableType.Any:
263
+ break;
264
+ case VariableType.Boolean:
265
+ break;
266
+ case VariableType.TinyInt:
267
+ case VariableType.SmallInt:
268
+ case VariableType.MediumInt:
269
+ case VariableType.Integer:
270
+ case VariableType.BigInt:
271
+ {
272
+ let schema = value as BaseNumberSchema;
273
+ min = schema.min;
274
+ max = schema.max;
275
+ break;
276
+ }
277
+ case VariableType.Float:
278
+ case VariableType.Double:
279
+ case VariableType.Decimal:
280
+ case VariableType.Real:
281
+ case VariableType.Money:
282
+ {
283
+ let schema = value as BasePrecisionSchema;
284
+ min = schema.min;
285
+ max = schema.max;
286
+ precision = schema.precision;
287
+ break;
288
+ }
289
+ case VariableType.String:
290
+ {
291
+ let schema = value as StringSchema;
292
+ min_length = schema.min_length;
293
+ max_length = schema.max_length;
294
+ if (schema.regex)
295
+ regex = schema.regex + "";
296
+ break;
297
+ }
298
+ case VariableType.Date:
299
+ case VariableType.Time:
300
+ case VariableType.DateTime:
301
+ case VariableType.TimeZone:
302
+ case VariableType.Duration:
303
+ case VariableType.Email:
304
+ case VariableType.Phone:
305
+ case VariableType.Version:
306
+ case VariableType.IPV4:
307
+ case VariableType.IPV6:
308
+ case VariableType.IPV4Range:
309
+ case VariableType.IPV6Range:
310
+ case VariableType.Color:
311
+ case VariableType.Font:
312
+ case VariableType.FilePath:
313
+ case VariableType.URL:
314
+ break;
315
+ case VariableType.Enum:
316
+ let schema = value as EnumSchema;
317
+ name = schema.name;
318
+ break;
319
+ case VariableType.Entity:
320
+ // todo VariableType.Entity
321
+ break;
322
+ case VariableType.Array:
323
+ {
324
+ let schema = value as ArraySchema;
325
+ if (schema.items.length > 0)
326
+ array_schema = schema.items[0];
327
+ break;
328
+ }
329
+ case VariableType.Object:
330
+ {
331
+ let schema = value as ObjectSchema;
332
+ name = schema.name;
333
+ object_fields = schema.fields ?? [];
334
+ break;
335
+ }
336
+ case VariableType.Type:
337
+ break;
338
+ case VariableType.Variable:
339
+ break;
340
+ }
341
+
342
+ this.NSBoxString_Name.current?.setValue(name);
343
+ this.NSBoxInteger_Min.current?.setValue(min);
344
+ this.NSBoxInteger_Max.current?.setValue(max);
345
+ this.NSBoxInteger_Precision.current?.setValue(precision);
346
+ this.NSBoxInteger_MinLength.current?.setValue(min_length);
347
+ this.NSBoxInteger_MaxLength.current?.setValue(max_length);
348
+ this.NSBoxString_Regex.current?.setValue(regex);
349
+ this.NSBoxSchemaBase_ArraySchema.current?.setValue(array_schema);
350
+ this.NSRepeaterNSBoxSchemaVariable_ObjectFields.current?.setValue(object_fields);
351
+ this.NSBoxString_ValidList.current?.setValue(valid_list);
352
+ this.NSBoxString_InalidList.current?.setValue(invlid_list);
353
+ this.NSBoxString_PlaceHolder.current?.setValue(place_holder);
354
+
355
+ this.props.onChanged?.(this);
356
+ callback?.();
357
+ });
358
+ }
359
+ private onChanged()
360
+ {
361
+ this.props.onChanged?.(this);
362
+ }
363
+ override render()
364
+ {
365
+ let menu = safeMenuMenuItem(this.props, (items) =>
366
+ {
367
+ items.push({
368
+ title: "Show Detail",
369
+ icon: this.state.show_details ? "https://static.namirasoft.com/image/concept/close/blue.svg" : "https://static.namirasoft.com/image/concept/ellipsis/vertical-blue.svg",
370
+ onClick: () =>
371
+ {
372
+ this.setState({ show_details: !this.state.show_details })
373
+ }
374
+ });
375
+ });
376
+
377
+ /* VariableType */
378
+ let isNumber = this.state.type && [VariableType.TinyInt, VariableType.SmallInt, VariableType.MediumInt, VariableType.Integer, VariableType.BigInt, VariableType.Float, VariableType.Double, VariableType.Decimal, VariableType.Real, VariableType.Money, VariableType.Array].includes(this.state.type);
379
+ let isPrecision = this.state.type && [VariableType.Float, VariableType.Double, VariableType.Decimal, VariableType.Real, VariableType.Money].includes(this.state.type);
380
+ let hasName = this.state.type && [VariableType.Enum, VariableType.Object].includes(this.state.type);
381
+
382
+ return (
383
+ <NSBoxBaseLayoutRecursive
384
+ ref={this.NSBoxBaseLayoutRecursive_Main}
385
+ {...this.props}
386
+ depth={this.props.depth ?? 0}
387
+ menu={menu}
388
+ >
389
+ <NSRow
390
+ >
391
+ <NSBoxEnum<VariableType>
392
+ ref={this.NSBoxEnum_Type}
393
+ required
394
+ title="Type"
395
+ multiple={false}
396
+ getEnumObject={() => VariableType}
397
+ /* VariableType */
398
+ invalids={[VariableType.Any, ...(this.props.invalids ?? [])]}
399
+ onChanged={(b) =>
400
+ {
401
+ this.setState({ type: b.getValueEnumOne(VariableType, VariableType.Any) });
402
+ this.onChanged();
403
+ }}
404
+ classList={[Styles.ns_box_schema_base_type]}
405
+ />
406
+ {
407
+ hasName &&
408
+ <NSBoxString
409
+ ref={this.NSBoxString_Name}
410
+ required
411
+ title="Name"
412
+ classList={[Styles.ns_box_schema_base_name]}
413
+ />
414
+ }
415
+ <NSBoxBoolean
416
+ ref={this.NSBoxBoolean_Required}
417
+ required
418
+ title="Required"
419
+ onChanged={() => this.onChanged()}
420
+ classList={[hasName ? Styles.ns_box_schema_base_required_withname : Styles.ns_box_schema_base_required_withoutname]}
421
+ />
422
+ </NSRow>
423
+ {
424
+ this.state.type === VariableType.Array &&
425
+ <NSBoxSchemaBase
426
+ ref={this.NSBoxSchemaBase_ArraySchema}
427
+ name={this.props.name}
428
+ required
429
+ title="Array Elements' Schema"
430
+ style={{ width: "100%" }}
431
+ invalids={[VariableType.Any, VariableType.Object, VariableType.Array]}
432
+ depth={(this.props.depth ?? 0) + 1}
433
+ />
434
+ }
435
+ {
436
+ this.state.type === VariableType.Object &&
437
+ <NSBoxBaseLayoutRecursive
438
+ required
439
+ depth={(this.props.depth ?? 0) + 1}
440
+ title="Fields"
441
+ style={{ width: "100%" }}
442
+ >
443
+ <NSRepeaterNSBoxSchemaVariable
444
+ ref={this.NSRepeaterNSBoxSchemaVariable_ObjectFields}
445
+ name={this.props.name}
446
+ item_title="Field"
447
+ style={{ width: "100%" }}
448
+ />
449
+ </NSBoxBaseLayoutRecursive>
450
+ }
451
+ {
452
+ isNumber &&
453
+ <NSRow
454
+ style={{ display: this.state.show_details ? "" : "none", width: "100%", justifyContent: "left" }}
455
+ >
456
+ <NSBoxInteger
457
+ ref={this.NSBoxInteger_Min}
458
+ required={false}
459
+ title="Min"
460
+ style={{ minWidth: "150px", width: "150px" }}
461
+ />
462
+ <NSBoxInteger
463
+ ref={this.NSBoxInteger_Max}
464
+ required={false}
465
+ title="Max"
466
+ style={{ minWidth: "150px", width: "150px" }}
467
+ />
468
+ {
469
+ isPrecision &&
470
+ <NSBoxInteger
471
+ ref={this.NSBoxInteger_Precision}
472
+ required={false}
473
+ title="Precision"
474
+ style={{ minWidth: "150px", width: "150px" }}
475
+ />
476
+ }
477
+ </NSRow>
478
+ }
479
+ {
480
+ this.state.type === VariableType.String &&
481
+ <NSColumn
482
+ style={{ display: this.state.show_details ? "" : "none", width: "100%" }}
483
+ >
484
+ <NSRow
485
+ style={{ justifyContent: "left" }}
486
+ >
487
+ <NSBoxInteger
488
+ ref={this.NSBoxInteger_MinLength}
489
+ required={false}
490
+ title="Min Length"
491
+ style={{ minWidth: "150px", width: "150px" }}
492
+ />
493
+ <NSBoxInteger
494
+ ref={this.NSBoxInteger_MaxLength}
495
+ required={false}
496
+ title="Max Length"
497
+ style={{ minWidth: "150px", width: "150px" }}
498
+ />
499
+ </NSRow>
500
+ <NSBoxString
501
+ ref={this.NSBoxString_Regex}
502
+ required={false}
503
+ title="Regex"
504
+ style={{ width: "100%" }}
505
+ />
506
+ </NSColumn>
507
+ }
508
+ <div style={{ display: (this.state.type === VariableType.Enum || this.state.show_details) ? "" : "none", width: "100%" }}>
509
+ <NSBoxString
510
+ ref={this.NSBoxString_ValidList}
511
+ required={this.state.type === VariableType.Enum}
512
+ title="Valid List"
513
+ placeholder="Please enter valid list and sperate them via comma."
514
+ style={{ width: "100%" }}
515
+ onChanged={() => this.onChanged()}
516
+ />
517
+ </div>
518
+ <NSColumn
519
+ style={{ display: this.state.show_details ? "" : "none", width: "100%" }}
520
+ >
521
+ <NSBoxString
522
+ ref={this.NSBoxString_InalidList}
523
+ required={false}
524
+ title="Invalid List"
525
+ placeholder="Please enter invvalid list and sperate them via comma."
526
+ style={{ width: "100%" }}
527
+ onChanged={() => this.onChanged()}
528
+ />
529
+ <NSBoxString
530
+ ref={this.NSBoxString_PlaceHolder}
531
+ required={false}
532
+ title="Place Holder"
533
+ style={{ width: "100%" }}
534
+ onChanged={() => this.onChanged()}
535
+ />
536
+ </NSColumn>
537
+ </NSBoxBaseLayoutRecursive>
538
+ );
539
+ }
540
540
  }