namirasoft-site-react 1.4.402 → 1.4.403

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 (304) 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.js +7 -1
  6. package/dist/App.js.map +1 -1
  7. package/dist/components/NSBanner.module.css +47 -47
  8. package/dist/components/NSBarAction.module.css +84 -84
  9. package/dist/components/NSBarAlert.module.css +79 -79
  10. package/dist/components/NSBarNotification.module.css +34 -34
  11. package/dist/components/NSBarTitle.module.css +9 -9
  12. package/dist/components/NSBox.module.css +54 -54
  13. package/dist/components/NSBoxBaseCombo.module.css +6 -6
  14. package/dist/components/NSBoxBoolean.module.css +73 -73
  15. package/dist/components/NSBoxDate.module.css +4 -4
  16. package/dist/components/NSBoxDateTime.module.css +4 -4
  17. package/dist/components/NSBoxDuration.module.css +4 -4
  18. package/dist/components/NSBoxFile.module.css +10 -10
  19. package/dist/components/NSBoxPhone.module.css +35 -35
  20. package/dist/components/NSBoxRadio.module.css +33 -33
  21. package/dist/components/NSBoxSchemaBase.module.css +17 -17
  22. package/dist/components/NSBoxSchemaVariable.module.css +16 -16
  23. package/dist/components/NSBoxTextArea.module.css +12 -12
  24. package/dist/components/NSBoxTime.module.css +4 -4
  25. package/dist/components/NSButton.module.css +57 -57
  26. package/dist/components/NSButtonBlue.module.css +4 -4
  27. package/dist/components/NSButtonGreen.module.css +4 -4
  28. package/dist/components/NSButtonRed.module.css +4 -4
  29. package/dist/components/NSCard.module.css +114 -114
  30. package/dist/components/NSCardScreenshot.module.css +41 -41
  31. package/dist/components/NSChartColumn.module.css +7 -7
  32. package/dist/components/NSChartTable.module.css +21 -21
  33. package/dist/components/NSColumn.module.css +16 -16
  34. package/dist/components/NSCopyBox.module.css +39 -39
  35. package/dist/components/NSDialog.module.css +112 -112
  36. package/dist/components/NSDialogPageSelection.module.css +103 -103
  37. package/dist/components/NSDownTimer.module.css +55 -55
  38. package/dist/components/NSDownload.module.css +46 -46
  39. package/dist/components/NSElectronicCard.module.css +60 -60
  40. package/dist/components/NSEntityCardBackground.module.css +27 -27
  41. package/dist/components/NSFilterBox.module.css +27 -27
  42. package/dist/components/NSFilterBoxItems.module.css +15 -15
  43. package/dist/components/NSFilterItem.module.css +24 -24
  44. package/dist/components/NSFooter.module.css +134 -134
  45. package/dist/components/NSHeader.d.ts +7 -1
  46. package/dist/components/NSHeader.js +29 -6
  47. package/dist/components/NSHeader.js.map +1 -1
  48. package/dist/components/NSHeader.module.css +291 -291
  49. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  50. package/dist/components/NSLabel.module.css +25 -25
  51. package/dist/components/NSLabelErrorNotifier.module.css +2 -2
  52. package/dist/components/NSLayout.module.css +14 -14
  53. package/dist/components/NSLine.module.css +15 -15
  54. package/dist/components/NSLink.module.css +36 -36
  55. package/dist/components/NSListGrouped.module.css +69 -69
  56. package/dist/components/NSListProduct.js.map +1 -1
  57. package/dist/components/NSLoading.module.css +38 -38
  58. package/dist/components/NSMenuAction.module.css +88 -88
  59. package/dist/components/NSMenuButton.module.css +44 -44
  60. package/dist/components/NSNoData.module.css +9 -9
  61. package/dist/components/NSPagination.module.css +85 -85
  62. package/dist/components/NSPanel.module.css +19 -19
  63. package/dist/components/NSPanelAccordion.module.css +4 -4
  64. package/dist/components/NSProductSearch.d.ts +16 -0
  65. package/dist/components/NSProductSearch.js +56 -0
  66. package/dist/components/NSProductSearch.js.map +1 -0
  67. package/dist/components/NSProductSearch.module.css +69 -0
  68. package/dist/components/NSRange.module.css +66 -66
  69. package/dist/components/NSRow.module.css +17 -17
  70. package/dist/components/NSSection.module.css +4 -4
  71. package/dist/components/NSSectionCards.module.css +38 -38
  72. package/dist/components/NSSectionTiles.module.css +10 -10
  73. package/dist/components/NSTabPage.module.css +59 -59
  74. package/dist/components/NSTable.module.css +263 -263
  75. package/dist/components/NSTile.module.css +76 -76
  76. package/dist/components/NSTimelineMonthly.module.css +71 -71
  77. package/dist/components/NSTitle.module.css +15 -15
  78. package/dist/pages/NSNotFoundPage.module.css +18 -18
  79. package/dist/pages/NSUpdating.module.css +35 -35
  80. package/package.json +82 -82
  81. package/public/index.html +38 -38
  82. package/src/App.css +33 -33
  83. package/src/App.tsx +216 -210
  84. package/src/Color.tsx +10 -10
  85. package/src/CopyToClipboard.ts +6 -6
  86. package/src/NSBoxBuilder.tsx +912 -912
  87. package/src/ProductCacheService.ts +15 -15
  88. package/src/Validator.ts +166 -166
  89. package/src/components/INSBox.tsx +6 -6
  90. package/src/components/NSBanner.module.css +47 -47
  91. package/src/components/NSBanner.tsx +80 -80
  92. package/src/components/NSBarAction.module.css +84 -84
  93. package/src/components/NSBarAction.tsx +91 -91
  94. package/src/components/NSBarAlert.module.css +79 -79
  95. package/src/components/NSBarAlert.tsx +35 -35
  96. package/src/components/NSBarNotification.module.css +34 -34
  97. package/src/components/NSBarNotification.tsx +86 -86
  98. package/src/components/NSBarTitle.module.css +9 -9
  99. package/src/components/NSBarTitle.tsx +23 -23
  100. package/src/components/NSBox.module.css +54 -54
  101. package/src/components/NSBox.tsx +19 -19
  102. package/src/components/NSBoxBaseCombo.module.css +6 -6
  103. package/src/components/NSBoxBaseCombo.tsx +428 -428
  104. package/src/components/NSBoxBaseLayout.tsx +88 -88
  105. package/src/components/NSBoxBaseLayoutRecursive.tsx +54 -54
  106. package/src/components/NSBoxBoolean.module.css +73 -73
  107. package/src/components/NSBoxBoolean.tsx +128 -128
  108. package/src/components/NSBoxBooleans.tsx +178 -178
  109. package/src/components/NSBoxColor.tsx +95 -95
  110. package/src/components/NSBoxCombo.tsx +91 -91
  111. package/src/components/NSBoxDate.module.css +4 -4
  112. package/src/components/NSBoxDate.tsx +90 -90
  113. package/src/components/NSBoxDateTime.module.css +4 -4
  114. package/src/components/NSBoxDateTime.tsx +103 -103
  115. package/src/components/NSBoxDouble.tsx +94 -94
  116. package/src/components/NSBoxDuration.module.css +4 -4
  117. package/src/components/NSBoxDuration.tsx +95 -95
  118. package/src/components/NSBoxDynamic.tsx +67 -67
  119. package/src/components/NSBoxDynamics.tsx +68 -68
  120. package/src/components/NSBoxEmail.tsx +98 -98
  121. package/src/components/NSBoxEntity.tsx +174 -174
  122. package/src/components/NSBoxEnum.tsx +108 -108
  123. package/src/components/NSBoxFile.module.css +10 -10
  124. package/src/components/NSBoxFile.tsx +101 -101
  125. package/src/components/NSBoxFilePath.tsx +95 -95
  126. package/src/components/NSBoxFont.tsx +95 -95
  127. package/src/components/NSBoxIPV4.tsx +95 -95
  128. package/src/components/NSBoxIPV4Range.tsx +95 -95
  129. package/src/components/NSBoxIPV6.tsx +92 -92
  130. package/src/components/NSBoxIPV6Range.tsx +95 -95
  131. package/src/components/NSBoxInteger.tsx +91 -91
  132. package/src/components/NSBoxMoney.tsx +95 -95
  133. package/src/components/NSBoxPassword.tsx +108 -108
  134. package/src/components/NSBoxPhone.module.css +35 -35
  135. package/src/components/NSBoxPhone.tsx +107 -107
  136. package/src/components/NSBoxRadio.module.css +33 -33
  137. package/src/components/NSBoxRadio.tsx +91 -91
  138. package/src/components/NSBoxSchemaBase.module.css +17 -17
  139. package/src/components/NSBoxSchemaBase.tsx +540 -540
  140. package/src/components/NSBoxSchemaVariable.module.css +16 -16
  141. package/src/components/NSBoxSchemaVariable.tsx +247 -247
  142. package/src/components/NSBoxSearch.tsx +97 -97
  143. package/src/components/NSBoxString.tsx +93 -93
  144. package/src/components/NSBoxTextArea.module.css +12 -12
  145. package/src/components/NSBoxTextArea.tsx +98 -98
  146. package/src/components/NSBoxTime.module.css +4 -4
  147. package/src/components/NSBoxTime.tsx +93 -93
  148. package/src/components/NSBoxTimeZone.tsx +95 -95
  149. package/src/components/NSBoxURL.tsx +104 -104
  150. package/src/components/NSBoxVersion.tsx +95 -95
  151. package/src/components/NSButton.module.css +57 -57
  152. package/src/components/NSButton.tsx +75 -75
  153. package/src/components/NSButtonBlue.module.css +4 -4
  154. package/src/components/NSButtonBlue.tsx +29 -29
  155. package/src/components/NSButtonGreen.module.css +4 -4
  156. package/src/components/NSButtonGreen.tsx +29 -29
  157. package/src/components/NSButtonRed.module.css +4 -4
  158. package/src/components/NSButtonRed.tsx +29 -29
  159. package/src/components/NSCard.module.css +114 -114
  160. package/src/components/NSCard.tsx +63 -63
  161. package/src/components/NSCardScreenshot.module.css +41 -41
  162. package/src/components/NSCardScreenshot.tsx +31 -31
  163. package/src/components/NSChartColumn.module.css +7 -7
  164. package/src/components/NSChartColumn.tsx +106 -106
  165. package/src/components/NSChartDoughnut.tsx +112 -112
  166. package/src/components/NSChartPie.tsx +105 -105
  167. package/src/components/NSChartRange.tsx +14 -14
  168. package/src/components/NSChartTable.module.css +21 -21
  169. package/src/components/NSChartTable.tsx +94 -94
  170. package/src/components/NSColumn.module.css +16 -16
  171. package/src/components/NSColumn.tsx +24 -24
  172. package/src/components/NSCopy.tsx +58 -58
  173. package/src/components/NSCopyBox.module.css +39 -39
  174. package/src/components/NSCopyBox.tsx +53 -53
  175. package/src/components/NSDialog.module.css +112 -112
  176. package/src/components/NSDialog.tsx +61 -61
  177. package/src/components/NSDialogDelete.tsx +27 -27
  178. package/src/components/NSDialogInfo.tsx +49 -49
  179. package/src/components/NSDialogPageSelection.module.css +103 -103
  180. package/src/components/NSDialogPageSelection.tsx +234 -234
  181. package/src/components/NSDownTimer.module.css +55 -55
  182. package/src/components/NSDownTimer.tsx +91 -91
  183. package/src/components/NSDownload.module.css +46 -46
  184. package/src/components/NSDownload.tsx +69 -69
  185. package/src/components/NSElectronicCard.module.css +60 -60
  186. package/src/components/NSElectronicCard.tsx +46 -46
  187. package/src/components/NSEntityCardBackground.module.css +27 -27
  188. package/src/components/NSEntityCardBackground.tsx +36 -36
  189. package/src/components/NSFilterBox.module.css +27 -27
  190. package/src/components/NSFilterBox.tsx +477 -477
  191. package/src/components/NSFilterBoxItems.module.css +15 -15
  192. package/src/components/NSFilterBoxItems.tsx +52 -52
  193. package/src/components/NSFilterItem.module.css +24 -24
  194. package/src/components/NSFilterItem.tsx +27 -27
  195. package/src/components/NSFooter.module.css +134 -134
  196. package/src/components/NSFooter.tsx +321 -321
  197. package/src/components/NSHeader.module.css +291 -291
  198. package/src/components/NSHeader.tsx +309 -260
  199. package/src/components/NSHeaderScreenshot.module.css +35 -35
  200. package/src/components/NSHeaderScreenshot.tsx +39 -39
  201. package/src/components/NSID.tsx +158 -158
  202. package/src/components/NSLabel.module.css +25 -25
  203. package/src/components/NSLabel.tsx +47 -47
  204. package/src/components/NSLabelErrorNotifier.module.css +2 -2
  205. package/src/components/NSLabelErrorNotifier.tsx +35 -35
  206. package/src/components/NSLayout.module.css +14 -14
  207. package/src/components/NSLayout.tsx +134 -134
  208. package/src/components/NSLine.module.css +15 -15
  209. package/src/components/NSLine.tsx +13 -13
  210. package/src/components/NSLink.module.css +36 -36
  211. package/src/components/NSLink.tsx +25 -25
  212. package/src/components/NSLinkBlue.tsx +21 -21
  213. package/src/components/NSLinkGreen.tsx +12 -12
  214. package/src/components/NSLinkRed.tsx +12 -12
  215. package/src/components/NSListGrouped.module.css +69 -69
  216. package/src/components/NSListGrouped.tsx +106 -106
  217. package/src/components/NSListProduct.tsx +44 -43
  218. package/src/components/NSLoading.module.css +38 -38
  219. package/src/components/NSLoading.tsx +37 -37
  220. package/src/components/NSMenuAction.module.css +88 -88
  221. package/src/components/NSMenuAction.tsx +106 -106
  222. package/src/components/NSMenuButton.module.css +44 -44
  223. package/src/components/NSMenuButton.tsx +206 -206
  224. package/src/components/NSNoData.module.css +9 -9
  225. package/src/components/NSNoData.tsx +24 -24
  226. package/src/components/NSPagination.module.css +85 -85
  227. package/src/components/NSPagination.tsx +182 -182
  228. package/src/components/NSPanel.module.css +19 -19
  229. package/src/components/NSPanel.tsx +24 -24
  230. package/src/components/NSPanelAccordion.module.css +4 -4
  231. package/src/components/NSPanelAccordion.tsx +51 -51
  232. package/src/components/NSProductSearch.module.css +69 -0
  233. package/src/components/NSProductSearch.tsx +156 -0
  234. package/src/components/NSRange.module.css +66 -66
  235. package/src/components/NSRange.tsx +83 -83
  236. package/src/components/NSRepeater.tsx +254 -254
  237. package/src/components/NSRepeaterNSBoxSchemaVariable.tsx +90 -90
  238. package/src/components/NSRepeaterNSTag.tsx +82 -82
  239. package/src/components/NSRow.module.css +17 -17
  240. package/src/components/NSRow.tsx +24 -24
  241. package/src/components/NSSection.module.css +4 -4
  242. package/src/components/NSSection.tsx +26 -26
  243. package/src/components/NSSectionCards.module.css +38 -38
  244. package/src/components/NSSectionCards.tsx +51 -51
  245. package/src/components/NSSectionTiles.module.css +10 -10
  246. package/src/components/NSSectionTiles.tsx +25 -25
  247. package/src/components/NSSectionTitle.tsx +21 -21
  248. package/src/components/NSSpace.tsx +28 -28
  249. package/src/components/NSTabPage.module.css +59 -59
  250. package/src/components/NSTabPage.tsx +91 -91
  251. package/src/components/NSTable.module.css +263 -263
  252. package/src/components/NSTable.tsx +636 -636
  253. package/src/components/NSTag.tsx +74 -74
  254. package/src/components/NSTile.module.css +76 -76
  255. package/src/components/NSTile.tsx +27 -27
  256. package/src/components/NSTimelineMonthly.module.css +71 -71
  257. package/src/components/NSTimelineMonthly.tsx +44 -44
  258. package/src/components/NSTitle.module.css +15 -15
  259. package/src/components/NSTitle.tsx +19 -19
  260. package/src/formatter/BackColorFormatter.tsx +23 -23
  261. package/src/formatter/BaseColumnFormatter.ts +16 -16
  262. package/src/formatter/BaseURLImageFormatter.tsx +33 -33
  263. package/src/formatter/BooleanFormatter.ts +22 -22
  264. package/src/formatter/DateFormatter.ts +21 -21
  265. package/src/formatter/DateTimeFormatter.ts +21 -21
  266. package/src/formatter/DurationFormatter.ts +13 -13
  267. package/src/formatter/EmailFormatter.tsx +21 -21
  268. package/src/formatter/EnumFormatter.ts +13 -13
  269. package/src/formatter/FloatFormatter.ts +23 -23
  270. package/src/formatter/ForeColorFormatter.tsx +24 -24
  271. package/src/formatter/IDFormatter.tsx +30 -30
  272. package/src/formatter/IPFormatter.ts +13 -13
  273. package/src/formatter/IntegerFormatter.ts +23 -23
  274. package/src/formatter/JsonFormatter.ts +21 -21
  275. package/src/formatter/MoneyFormatter.ts +35 -35
  276. package/src/formatter/PhoneFormatter.tsx +21 -21
  277. package/src/formatter/StringFormatter.tsx +43 -43
  278. package/src/formatter/TimeFormatter.ts +21 -21
  279. package/src/formatter/URLFormatter.tsx +21 -21
  280. package/src/formatter/UnknowFormatter.ts +18 -18
  281. package/src/index.tsx +7 -7
  282. package/src/main.ts +225 -225
  283. package/src/pages/NSNotFoundPage.module.css +18 -18
  284. package/src/pages/NSNotFoundPage.tsx +11 -11
  285. package/src/pages/NSUpdating.module.css +35 -35
  286. package/src/pages/NSUpdating.tsx +32 -32
  287. package/src/props/IBackgroundProps.ts +5 -5
  288. package/src/props/IBaseComponentProps.ts +8 -8
  289. package/src/props/IHeaderIconProps.ts +10 -10
  290. package/src/props/IHeaderLeftProps.ts +6 -6
  291. package/src/props/IHeaderRightProps.ts +6 -6
  292. package/src/props/IImageProps.ts +4 -4
  293. package/src/props/ILinkProps.ts +5 -5
  294. package/src/props/IValidationNumberProps.ts +4 -4
  295. package/src/props/IValidationPrecisionProps.ts +3 -3
  296. package/src/props/IValidationProps.ts +9 -9
  297. package/src/props/IValidationRegexProps.ts +4 -4
  298. package/src/props/IValidationStringProps.ts +4 -4
  299. package/src/routing/NSNotifier.ts +114 -114
  300. package/src/routing/NSRouterMaker.tsx +20 -20
  301. package/src/routing/NSRouterMakerComponent.ts +5 -5
  302. package/src/routing/NSRouterMakerProps.ts +5 -5
  303. package/dist/App.css +0 -34
  304. package/dist/index.css +0 -6
@@ -1,913 +1,913 @@
1
- import { AnySchema, ArraySchema, BaseNumberSchema, BasePrecisionSchema, BaseTypeBuilder, 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";
2
- import { NSBoxBoolean } from "./components/NSBoxBoolean";
3
- import { NSBoxCombo } from "./components/NSBoxCombo";
4
- import { NSBoxDate } from "./components/NSBoxDate";
5
- import { NSBoxDateTime } from "./components/NSBoxDateTime";
6
- import { NSBoxDouble } from "./components/NSBoxDouble";
7
- import { NSBoxDuration } from "./components/NSBoxDuration";
8
- import { NSBoxDynamic, NSBoxDynamicProps } from "./components/NSBoxDynamic";
9
- import { NSBoxEmail } from "./components/NSBoxEmail";
10
- import { NSBoxEntity } from "./components/NSBoxEntity";
11
- import { NSBoxInteger } from "./components/NSBoxInteger";
12
- import { NSBoxIPV4 } from "./components/NSBoxIPV4";
13
- import { NSBoxIPV6 } from "./components/NSBoxIPV6";
14
- import { NSBoxMoney } from "./components/NSBoxMoney";
15
- import { NSBoxPhone } from "./components/NSBoxPhone";
16
- import { NSBoxString } from "./components/NSBoxString";
17
- import { NSBoxTime } from "./components/NSBoxTime";
18
- import { NSRepeater } from "./components/NSRepeater";
19
- import { NSBoxTimeZone } from "./components/NSBoxTimeZone";
20
- import { NSBoxVersion } from "./components/NSBoxVersion";
21
- import { NSBoxIPV4Range } from "./components/NSBoxIPV4Range";
22
- import { NSBoxIPV6Range } from "./components/NSBoxIPV6Range";
23
- import { NSBoxColor } from "./components/NSBoxColor";
24
- import { NSBoxFont } from "./components/NSBoxFont";
25
- import { NSBoxFilePath } from "./components/NSBoxFilePath";
26
- import { NSBoxURL } from "./components/NSBoxURL";
27
- import { NamingConvention, ObjectService } from "namirasoft-core";
28
- import { INSBox } from "./components/INSBox";
29
- import { createRef } from "react";
30
- import { NSBoxBaseLayoutRecursive } from "./components/NSBoxBaseLayoutRecursive";
31
- import { NSMenuButtonMenuProps, safeMenuMenuItem } from "./components/NSMenuButton";
32
- import { NSBoxSchemaBase, NSBoxSchemaVariable } from "./main";
33
- import { NamirasoftMap } from "namirasoft-site-map";
34
-
35
- export class NSBoxBuilder extends BaseTypeBuilder<React.JSX.Element | null>
36
- {
37
- private depth: number = 0;
38
- private box: NSBoxDynamic;
39
- private props: NSBoxDynamicProps;
40
- private box_ref: React.RefObject<INSBox>;
41
- private key: string;
42
- private title: string;
43
- private placeholder: string;
44
- private menu: NSMenuButtonMenuProps;
45
- private builders: { builder: NSBoxBuilder, ref: React.RefObject<INSBox> }[] = [];
46
- private multiple: boolean;
47
-
48
- constructor(box: NSBoxDynamic, props: NSBoxDynamicProps, box_ref: React.RefObject<INSBox>, key: string, onDelete?: () => void)
49
- {
50
- super(props.variable.type);
51
- this.box = box;
52
- this.props = props;
53
- this.box_ref = box_ref;
54
- this.key = key;
55
- this.toInteger = this.toInteger.bind(this);
56
- this.toPrecision = this.toPrecision.bind(this);
57
- this.ifOjbect = this.ifOjbect.bind(this);
58
-
59
- this.title = this.props.title;
60
- if (!this.title)
61
- this.title = NamingConvention.auto.convert(this.props.variable.name, NamingConvention.Pascal_Case_Space);
62
- this.placeholder = props.variable.type.example ?? "";
63
- this.multiple = props.variable.tags["multiple"] === "true";
64
- this.menu = safeMenuMenuItem(this.props, () => { });
65
- this.menu.builtin.delete = { enabled: onDelete != null, onDelete: () => { onDelete?.() } };
66
- this.builders = this.ifOjbect((_, fields) =>
67
- {
68
- return fields.map((f) =>
69
- {
70
- let title = NamingConvention.auto.convert(f.name, NamingConvention.Pascal_Case_Space);
71
- let props = {
72
- ...this.props,
73
- title,
74
- onChanged: (box: NSBoxDynamic) =>
75
- {
76
- this.props.onChanged?.(box);
77
- },
78
- variable: f,
79
- multiple: false
80
- };
81
- let ref = createRef<INSBox>();
82
- let builder = new NSBoxBuilder(this.box, props, ref, "NSBoxBuilder_Object_" + f.name);
83
- builder.depth = this.depth + 1;
84
- return { builder, ref };
85
- });
86
- }) ?? [];
87
- }
88
- private ifOjbect<T>(handler: (schema: ObjectSchema, fields: BaseVariableSchema[]) => T): T | null
89
- {
90
- if (this.props.variable.type.type === VariableType.Object)
91
- {
92
- let schema = this.props.variable.type as ObjectSchema;
93
-
94
- if (this.multiple)
95
- return null;
96
- if (schema.external)
97
- return null;
98
- if (!schema.fields)
99
- return null
100
- if (schema.fields.length === 0)
101
- return null
102
- if (schema.fields)
103
- return handler(schema, schema.fields);
104
- }
105
- return null;
106
- }
107
- getValue(checkError: boolean = true): any | null
108
- {
109
- let obj = this.box_ref.current?.getValue(checkError);
110
-
111
- let res = this.ifOjbect((_, fields) =>
112
- {
113
- let ans: { [name: string]: any } = {};
114
- fields.forEach((f, index) =>
115
- {
116
- let obj = this.builders[index].builder.getValue(checkError);
117
- ans[f.name] = obj;
118
- });
119
- return ans;
120
- });
121
- if (res != null)
122
- obj = res;
123
-
124
- return obj;
125
- }
126
- setValue(value: any | null, callback?: () => void): void
127
- {
128
- if (!this.ifOjbect((_, fields) =>
129
- {
130
- fields.forEach((f, index) =>
131
- {
132
- let obj = value?.[f.name];
133
- this.builders[index].builder.setValue(obj);
134
- });
135
- return true;
136
- }))
137
- this.box_ref.current?.setValue(value, callback);
138
- }
139
- /* VariableType */
140
- protected override _toAny(_: AnySchema)
141
- {
142
- return null;
143
- }
144
- protected override _toBool(schema: BoolSchema)
145
- {
146
- if (this.multiple)
147
- return null;
148
-
149
- return (
150
- <NSBoxBoolean
151
- ref={this.box_ref as React.RefObject<any>}
152
- key={this.key}
153
- {...this.props}
154
-
155
- required={schema.required}
156
- valids={schema.valids}
157
- invalids={schema.invalids}
158
- // regex={schema.regex}
159
-
160
- title={this.title}
161
- placeholder={this.placeholder}
162
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullBoolean() ?? undefined}
163
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
164
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
165
- menu={this.menu}
166
- />
167
- );
168
- }
169
- private toInteger(schema: BaseNumberSchema): React.JSX.Element | null
170
- {
171
- if (this.multiple)
172
- return null;
173
-
174
- return (
175
- <NSBoxInteger
176
- ref={this.box_ref as React.RefObject<any>}
177
- key={this.key}
178
- {...this.props}
179
-
180
- required={schema.required}
181
- valids={schema.valids}
182
- invalids={schema.invalids}
183
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
184
-
185
- title={this.title}
186
- placeholder={this.placeholder}
187
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullInt() ?? undefined}
188
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
189
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
190
- menu={this.menu}
191
-
192
- min={schema.min ?? undefined}
193
- max={schema.max ?? undefined}
194
- />
195
- );
196
- }
197
- protected override _toTinyInt(schema: TinyIntSchema)
198
- {
199
- return this.toInteger(schema);
200
- }
201
- protected override _toSmallInt(schema: SmallIntSchema)
202
- {
203
- return this.toInteger(schema);
204
- }
205
- protected override _toMediumInt(schema: MediumIntSchema)
206
- {
207
- return this.toInteger(schema);
208
- }
209
- protected override _toInteger(schema: IntegerSchema)
210
- {
211
- return this.toInteger(schema);
212
- }
213
- protected override _toBigInt(schema: BigIntSchema)
214
- {
215
- return this.toInteger(schema);
216
- }
217
- private toPrecision(schema: BasePrecisionSchema): React.JSX.Element | null
218
- {
219
- if (this.multiple)
220
- return null;
221
-
222
- return (
223
- <NSBoxDouble
224
- ref={this.box_ref as React.RefObject<any>}
225
- key={this.key}
226
- {...this.props}
227
-
228
- required={schema.required}
229
- valids={schema.valids}
230
- invalids={schema.invalids}
231
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
232
-
233
- title={this.title}
234
- placeholder={this.placeholder}
235
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullFloat() ?? undefined}
236
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
237
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
238
- menu={this.menu}
239
-
240
- min={schema.min ?? undefined}
241
- max={schema.max ?? undefined}
242
- precision={schema.precision ?? undefined}
243
- />
244
- );
245
- }
246
- protected override _toFloat(schema: FloatSchema)
247
- {
248
- return this.toPrecision(schema);
249
- }
250
- protected override _toDouble(schema: DoubleSchema)
251
- {
252
- return this.toPrecision(schema);
253
- }
254
- protected override _toDecimal(schema: DecimalSchema)
255
- {
256
- return this.toPrecision(schema);
257
- }
258
- protected override _toReal(schema: RealSchema)
259
- {
260
- return this.toPrecision(schema);
261
- }
262
- protected override _toMoney(schema: MoneySchema)
263
- {
264
- if (this.multiple)
265
- return null;
266
-
267
- return (
268
- <NSBoxMoney
269
- ref={this.box_ref as React.RefObject<any>}
270
- key={this.key}
271
- {...this.props}
272
-
273
- required={schema.required}
274
- valids={schema.valids}
275
- invalids={schema.invalids}
276
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
277
-
278
- title={this.title}
279
- placeholder={this.placeholder}
280
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullFloat() ?? undefined}
281
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
282
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
283
- menu={this.menu}
284
-
285
- min={schema.min ?? undefined}
286
- max={schema.max ?? undefined}
287
- precision={schema.precision ?? undefined}
288
- />
289
- );
290
- }
291
- protected override _toString(schema: StringSchema)
292
- {
293
- if (this.multiple)
294
- return null;
295
-
296
- return (
297
- <NSBoxString
298
- ref={this.box_ref as React.RefObject<any>}
299
- key={this.key}
300
- {...this.props}
301
-
302
- required={schema.required}
303
- valids={schema.valids}
304
- invalids={schema.invalids}
305
- regex={schema.regex ? { name: this.props.variable.name, regex: schema.regex } : undefined}
306
-
307
- title={this.title}
308
- placeholder={this.placeholder}
309
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
310
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
311
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
312
- menu={this.menu}
313
-
314
- min_length={schema.min_length ?? undefined}
315
- max_length={schema.max_length ?? undefined}
316
- />
317
- );
318
- }
319
- protected override _toDate(schema: DateSchema)
320
- {
321
- if (this.multiple)
322
- return null;
323
-
324
- return (
325
- <NSBoxDate
326
- ref={this.box_ref as React.RefObject<any>}
327
- key={this.key}
328
- {...this.props}
329
-
330
- required={schema.required}
331
- valids={schema.valids}
332
- invalids={schema.invalids}
333
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
334
-
335
- title={this.title}
336
- placeholder={this.placeholder}
337
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
338
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
339
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
340
- menu={this.menu}
341
- />
342
- );
343
- }
344
- protected override _toTime(schema: TimeSchema)
345
- {
346
- if (this.multiple)
347
- return null;
348
-
349
- return (
350
- <NSBoxTime
351
- ref={this.box_ref as React.RefObject<any>}
352
- key={this.key}
353
- {...this.props}
354
-
355
- required={schema.required}
356
- valids={schema.valids}
357
- invalids={schema.invalids}
358
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
359
-
360
- title={this.title}
361
- placeholder={this.placeholder}
362
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
363
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
364
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
365
- menu={this.menu}
366
- />
367
- );
368
- }
369
- protected override _toDateTime(schema: DateTimeSchema)
370
- {
371
- if (this.multiple)
372
- return null;
373
-
374
- return (
375
- <NSBoxDateTime
376
- ref={this.box_ref as React.RefObject<any>}
377
- key={this.key}
378
- {...this.props}
379
-
380
- required={schema.required}
381
- valids={schema.valids}
382
- invalids={schema.invalids}
383
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
384
-
385
- title={this.title}
386
- placeholder={this.placeholder}
387
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullDate() ?? undefined}
388
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
389
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
390
- menu={this.menu}
391
- />
392
- );
393
- }
394
- protected override _toTimeZone(schema: TimeZoneSchema)
395
- {
396
- if (this.multiple)
397
- return null;
398
-
399
- return (
400
- <NSBoxTimeZone
401
- ref={this.box_ref as React.RefObject<any>}
402
- key={this.key}
403
- {...this.props}
404
-
405
- required={schema.required}
406
- valids={schema.valids}
407
- invalids={schema.invalids}
408
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
409
-
410
- title={this.title}
411
- placeholder={this.placeholder}
412
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
413
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
414
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
415
- menu={this.menu}
416
- />
417
- );
418
- }
419
- protected override _toDuration(schema: DurationSchema)
420
- {
421
- if (this.multiple)
422
- return null;
423
-
424
- return (
425
- <NSBoxDuration
426
- ref={this.box_ref as React.RefObject<any>}
427
- key={this.key}
428
- {...this.props}
429
-
430
- required={schema.required}
431
- valids={schema.valids}
432
- invalids={schema.invalids}
433
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
434
-
435
- title={this.title}
436
- placeholder={this.placeholder}
437
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
438
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
439
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
440
- menu={this.menu}
441
- />
442
- );
443
- }
444
- protected override _toEmail(schema: EmailSchema)
445
- {
446
- if (this.multiple)
447
- return null;
448
-
449
- return (
450
- <NSBoxEmail
451
- ref={this.box_ref as React.RefObject<any>}
452
- key={this.key}
453
- {...this.props}
454
-
455
- required={schema.required}
456
- valids={schema.valids}
457
- invalids={schema.invalids}
458
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
459
-
460
- title={this.title}
461
- placeholder={this.placeholder}
462
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
463
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
464
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
465
- menu={this.menu}
466
- />
467
- );
468
- }
469
- protected override _toPhone(schema: PhoneSchema)
470
- {
471
- if (this.multiple)
472
- return null;
473
-
474
- return (
475
- <NSBoxPhone
476
- ref={this.box_ref as React.RefObject<any>}
477
- key={this.key}
478
- {...this.props}
479
-
480
- required={schema.required}
481
- valids={schema.valids}
482
- invalids={schema.invalids}
483
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
484
-
485
- title={this.title}
486
- placeholder={this.placeholder}
487
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
488
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
489
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
490
- menu={this.menu}
491
- />
492
- );
493
- }
494
- protected override _toVersion(schema: VersionSchema)
495
- {
496
- if (this.multiple)
497
- return null;
498
- return (
499
- <NSBoxVersion
500
- ref={this.box_ref as React.RefObject<any>}
501
- key={this.key}
502
- {...this.props}
503
-
504
- required={schema.required}
505
- valids={schema.valids}
506
- invalids={schema.invalids}
507
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
508
-
509
- title={this.title}
510
- placeholder={this.placeholder}
511
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
512
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
513
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
514
- menu={this.menu}
515
- />
516
- );
517
- }
518
- protected override _toIPV4(schema: IPV4Schema)
519
- {
520
- if (this.multiple)
521
- return null;
522
- return (
523
- <NSBoxIPV4
524
- ref={this.box_ref as React.RefObject<any>}
525
- key={this.key}
526
- {...this.props}
527
-
528
- required={schema.required}
529
- valids={schema.valids}
530
- invalids={schema.invalids}
531
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
532
-
533
- title={this.title}
534
- placeholder={this.placeholder}
535
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
536
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
537
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
538
- menu={this.menu}
539
- />
540
- );
541
- }
542
- protected override _toIPV6(schema: IPV6Schema)
543
- {
544
- if (this.multiple)
545
- return null;
546
- return (
547
- <NSBoxIPV6
548
- ref={this.box_ref as React.RefObject<any>}
549
- key={this.key}
550
- {...this.props}
551
-
552
- required={schema.required}
553
- valids={schema.valids}
554
- invalids={schema.invalids}
555
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
556
-
557
- title={this.title}
558
- placeholder={this.placeholder}
559
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
560
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
561
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
562
- menu={this.menu}
563
- />
564
- );
565
- }
566
- protected override _toIPV4Range(schema: IPV4RangeSchema)
567
- {
568
- if (this.multiple)
569
- return null;
570
- return (
571
- <NSBoxIPV4Range
572
- ref={this.box_ref as React.RefObject<any>}
573
- key={this.key}
574
- {...this.props}
575
-
576
- required={schema.required}
577
- valids={schema.valids}
578
- invalids={schema.invalids}
579
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
580
-
581
- title={this.title}
582
- placeholder={this.placeholder}
583
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
584
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
585
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
586
- menu={this.menu}
587
- />
588
- );
589
- }
590
- protected override _toIPV6Range(schema: IPV6RangeSchema)
591
- {
592
- if (this.multiple)
593
- return null;
594
- return (
595
- <NSBoxIPV6Range
596
- ref={this.box_ref as React.RefObject<any>}
597
- key={this.key}
598
- {...this.props}
599
-
600
- required={schema.required}
601
- valids={schema.valids}
602
- invalids={schema.invalids}
603
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
604
-
605
- title={this.title}
606
- placeholder={this.placeholder}
607
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
608
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
609
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
610
- menu={this.menu}
611
- />
612
- );
613
- }
614
- protected override _toColor(schema: ColorSchema)
615
- {
616
- if (this.multiple)
617
- return null;
618
- return (
619
- <NSBoxColor
620
- ref={this.box_ref as React.RefObject<any>}
621
- key={this.key}
622
- {...this.props}
623
-
624
- required={schema.required}
625
- valids={schema.valids}
626
- invalids={schema.invalids}
627
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
628
-
629
- title={this.title}
630
- placeholder={this.placeholder}
631
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
632
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
633
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
634
- menu={this.menu}
635
- />
636
- );
637
- }
638
- protected override _toFont(schema: FontSchema)
639
- {
640
- if (this.multiple)
641
- return null;
642
- return (
643
- <NSBoxFont
644
- ref={this.box_ref as React.RefObject<any>}
645
- key={this.key}
646
- {...this.props}
647
-
648
- required={schema.required}
649
- valids={schema.valids}
650
- invalids={schema.invalids}
651
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
652
-
653
- title={this.title}
654
- placeholder={this.placeholder}
655
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
656
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
657
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
658
- menu={this.menu}
659
- />
660
- );
661
- }
662
- protected override _toFilePath(schema: FilePathSchema)
663
- {
664
- if (this.multiple)
665
- return null;
666
- return (
667
- <NSBoxFilePath
668
- ref={this.box_ref as React.RefObject<any>}
669
- key={this.key}
670
- {...this.props}
671
-
672
- required={schema.required}
673
- valids={schema.valids}
674
- invalids={schema.invalids}
675
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
676
-
677
- title={this.title}
678
- placeholder={this.placeholder}
679
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
680
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
681
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
682
- menu={this.menu}
683
- />
684
- );
685
- }
686
- protected override _toURL(schema: URLSchema)
687
- {
688
- if (this.multiple)
689
- return null;
690
- return (
691
- <NSBoxURL
692
- ref={this.box_ref as React.RefObject<any>}
693
- key={this.key}
694
- {...this.props}
695
-
696
- required={schema.required}
697
- valids={schema.valids}
698
- invalids={schema.invalids}
699
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
700
-
701
- title={this.title}
702
- placeholder={this.placeholder}
703
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
704
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
705
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
706
- menu={this.menu}
707
- />
708
- );
709
- }
710
- protected override _toEnum(schema: EnumSchema)
711
- {
712
- return (
713
- <NSBoxCombo
714
- ref={this.box_ref as React.RefObject<any>}
715
- key={this.key}
716
- {...this.props}
717
-
718
- required={schema.required}
719
- valids={schema.valids}
720
- invalids={schema.invalids}
721
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
722
-
723
- title={this.title}
724
- placeholder={this.placeholder}
725
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
726
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
727
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
728
- menu={this.menu}
729
-
730
- multiple={this.multiple ?? false}
731
- getOptions={() =>
732
- {
733
- let valids = schema.valids;
734
- valids = valids.filter((v) => !schema.invalids.includes(v));
735
- return valids.map((v) => ({ title: v, value: v }));
736
- }}
737
- />
738
- );
739
- }
740
- protected override _toEntity(schema: EntitySchema)
741
- {
742
- let global = new NamirasoftMap()
743
- let meta = global.getByShortName(schema.product);
744
- if (meta.table)
745
- return (
746
- <NSBoxEntity<any>
747
- ref={this.box_ref as React.RefObject<any>}
748
- key={this.key}
749
- {...this.props}
750
-
751
- required={schema.required}
752
- valids={schema.valids}
753
- invalids={schema.invalids}
754
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
755
-
756
- title={this.title}
757
- placeholder={this.placeholder}
758
- defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
759
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
760
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
761
- menu={this.menu}
762
-
763
- multiple={this.multiple ?? false}
764
-
765
- table={meta.table}
766
- getValue={(item) => item.id}
767
- getTitle={(item) => item.name}
768
- getSort={() => null}
769
- />
770
- );
771
- return <>Could not find table information</>;
772
- }
773
- protected override _toArray(schema: ArraySchema, callback: (schema: BaseTypeSchema) => void)
774
- {
775
- if (this.multiple)
776
- return null;
777
- if (schema.items.length === 0)
778
- return null;
779
- if (schema.items.length > 1)
780
- return null;
781
-
782
- let menu = safeMenuMenuItem(this.props, () => { });
783
-
784
- return (
785
- <NSBoxBaseLayoutRecursive
786
- id={this.props.id}
787
- {...this.props}
788
- required
789
- title={this.title}
790
- depth={this.depth}
791
- menu={menu}
792
- >
793
- <NSRepeater<INSBox, string>
794
- ref={this.box_ref as React.RefObject<any>}
795
- key={this.key}
796
- title={this.title}
797
- createItem={(gIndex: number, lIndex: number, ref: React.RefObject<INSBox>, onChange: () => void, onDelete: undefined | ((index: number) => void)) =>
798
- {
799
- let title = "Item " + (lIndex + 1)
800
- let props = {
801
- ...this.props,
802
- title,
803
- onChanged: (box: NSBoxDynamic) =>
804
- {
805
- this.props.onChanged?.(box);
806
- onChange();
807
- },
808
- style: { ...this.props.style },
809
- variable: new BaseVariableSchema(title, schema.items[0]),
810
- multiple: false
811
- };
812
- let builder = new NSBoxBuilder(this.box, props, ref, "NSBoxBuilder_NSRepeater_Item_" + (gIndex + 1),
813
- onDelete ? () => { onDelete(gIndex) } : undefined
814
- );
815
- builder.depth = this.depth + 1;
816
- return builder.runSynch(callback);
817
- }}
818
- setValue={function (item: INSBox, _: number, value: string | null): void
819
- {
820
- if (value)
821
- item.setValue(value);
822
- }}
823
- getValue={function (item: INSBox, checkError: boolean): string
824
- {
825
- return item.getValue(checkError)
826
- }}
827
- isEmpty={function (item: INSBox, value: string | null): boolean
828
- {
829
- return item.isEmpty(value)
830
- }}
831
- required={schema.required}
832
- min={schema.min ?? undefined}
833
- max={schema.max ?? undefined}
834
- />
835
- </NSBoxBaseLayoutRecursive>
836
- );
837
- }
838
- protected override _toObject(schema: ObjectSchema, callback: (schema: BaseTypeSchema) => void)
839
- {
840
- let children: React.JSX.Element[] | null = this.ifOjbect((_, fields) =>
841
- {
842
- return fields.map((_, index) =>
843
- {
844
- return this.builders[index].builder.runSynch(callback);
845
- }).filter(x => x).map(x => x as React.JSX.Element);
846
- });
847
- if (!children)
848
- return null;
849
-
850
- let menu = safeMenuMenuItem(this.props, () => { });
851
-
852
- return (
853
- <NSBoxBaseLayoutRecursive
854
- id={this.props.id}
855
- {...this.props}
856
- required
857
- title={this.title + ((schema.name && schema.name !== this.title) ? ` (${schema.name})` : "")}
858
- depth={this.depth}
859
- menu={menu}
860
- >
861
- {children}
862
- </NSBoxBaseLayoutRecursive>
863
- );
864
- }
865
- protected override _toType(schema: TypeSchema)
866
- {
867
- if (this.multiple)
868
- return null;
869
- return (
870
- <NSBoxSchemaBase
871
- ref={this.box_ref as React.RefObject<any>}
872
- key={this.key}
873
- {...this.props}
874
-
875
- required={schema.required}
876
- valids={schema.valids}
877
- invalids={schema.invalids}
878
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
879
-
880
- title={this.title}
881
- placeholder={this.placeholder}
882
- defaultValue={undefined}
883
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
884
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
885
- menu={this.menu}
886
- />
887
- );
888
- }
889
- protected override _toVariable(schema: VariableSchema)
890
- {
891
- if (this.multiple)
892
- return null;
893
- return (
894
- <NSBoxSchemaVariable
895
- ref={this.box_ref as React.RefObject<any>}
896
- key={this.key}
897
- {...this.props}
898
-
899
- required={schema.required}
900
- valids={schema.valids}
901
- invalids={schema.invalids}
902
- // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
903
-
904
- title={this.title}
905
- placeholder={this.placeholder}
906
- defaultValue={undefined}
907
- onChanged={(_) => { this.props.onChanged?.(this.box); }}
908
- onClicked={(_) => { this.props.onClicked?.(this.box); }}
909
- menu={this.menu}
910
- />
911
- );
912
- }
1
+ import { AnySchema, ArraySchema, BaseNumberSchema, BasePrecisionSchema, BaseTypeBuilder, 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";
2
+ import { NSBoxBoolean } from "./components/NSBoxBoolean";
3
+ import { NSBoxCombo } from "./components/NSBoxCombo";
4
+ import { NSBoxDate } from "./components/NSBoxDate";
5
+ import { NSBoxDateTime } from "./components/NSBoxDateTime";
6
+ import { NSBoxDouble } from "./components/NSBoxDouble";
7
+ import { NSBoxDuration } from "./components/NSBoxDuration";
8
+ import { NSBoxDynamic, NSBoxDynamicProps } from "./components/NSBoxDynamic";
9
+ import { NSBoxEmail } from "./components/NSBoxEmail";
10
+ import { NSBoxEntity } from "./components/NSBoxEntity";
11
+ import { NSBoxInteger } from "./components/NSBoxInteger";
12
+ import { NSBoxIPV4 } from "./components/NSBoxIPV4";
13
+ import { NSBoxIPV6 } from "./components/NSBoxIPV6";
14
+ import { NSBoxMoney } from "./components/NSBoxMoney";
15
+ import { NSBoxPhone } from "./components/NSBoxPhone";
16
+ import { NSBoxString } from "./components/NSBoxString";
17
+ import { NSBoxTime } from "./components/NSBoxTime";
18
+ import { NSRepeater } from "./components/NSRepeater";
19
+ import { NSBoxTimeZone } from "./components/NSBoxTimeZone";
20
+ import { NSBoxVersion } from "./components/NSBoxVersion";
21
+ import { NSBoxIPV4Range } from "./components/NSBoxIPV4Range";
22
+ import { NSBoxIPV6Range } from "./components/NSBoxIPV6Range";
23
+ import { NSBoxColor } from "./components/NSBoxColor";
24
+ import { NSBoxFont } from "./components/NSBoxFont";
25
+ import { NSBoxFilePath } from "./components/NSBoxFilePath";
26
+ import { NSBoxURL } from "./components/NSBoxURL";
27
+ import { NamingConvention, ObjectService } from "namirasoft-core";
28
+ import { INSBox } from "./components/INSBox";
29
+ import { createRef } from "react";
30
+ import { NSBoxBaseLayoutRecursive } from "./components/NSBoxBaseLayoutRecursive";
31
+ import { NSMenuButtonMenuProps, safeMenuMenuItem } from "./components/NSMenuButton";
32
+ import { NSBoxSchemaBase, NSBoxSchemaVariable } from "./main";
33
+ import { NamirasoftMap } from "namirasoft-site-map";
34
+
35
+ export class NSBoxBuilder extends BaseTypeBuilder<React.JSX.Element | null>
36
+ {
37
+ private depth: number = 0;
38
+ private box: NSBoxDynamic;
39
+ private props: NSBoxDynamicProps;
40
+ private box_ref: React.RefObject<INSBox>;
41
+ private key: string;
42
+ private title: string;
43
+ private placeholder: string;
44
+ private menu: NSMenuButtonMenuProps;
45
+ private builders: { builder: NSBoxBuilder, ref: React.RefObject<INSBox> }[] = [];
46
+ private multiple: boolean;
47
+
48
+ constructor(box: NSBoxDynamic, props: NSBoxDynamicProps, box_ref: React.RefObject<INSBox>, key: string, onDelete?: () => void)
49
+ {
50
+ super(props.variable.type);
51
+ this.box = box;
52
+ this.props = props;
53
+ this.box_ref = box_ref;
54
+ this.key = key;
55
+ this.toInteger = this.toInteger.bind(this);
56
+ this.toPrecision = this.toPrecision.bind(this);
57
+ this.ifOjbect = this.ifOjbect.bind(this);
58
+
59
+ this.title = this.props.title;
60
+ if (!this.title)
61
+ this.title = NamingConvention.auto.convert(this.props.variable.name, NamingConvention.Pascal_Case_Space);
62
+ this.placeholder = props.variable.type.example ?? "";
63
+ this.multiple = props.variable.tags["multiple"] === "true";
64
+ this.menu = safeMenuMenuItem(this.props, () => { });
65
+ this.menu.builtin.delete = { enabled: onDelete != null, onDelete: () => { onDelete?.() } };
66
+ this.builders = this.ifOjbect((_, fields) =>
67
+ {
68
+ return fields.map((f) =>
69
+ {
70
+ let title = NamingConvention.auto.convert(f.name, NamingConvention.Pascal_Case_Space);
71
+ let props = {
72
+ ...this.props,
73
+ title,
74
+ onChanged: (box: NSBoxDynamic) =>
75
+ {
76
+ this.props.onChanged?.(box);
77
+ },
78
+ variable: f,
79
+ multiple: false
80
+ };
81
+ let ref = createRef<INSBox>();
82
+ let builder = new NSBoxBuilder(this.box, props, ref, "NSBoxBuilder_Object_" + f.name);
83
+ builder.depth = this.depth + 1;
84
+ return { builder, ref };
85
+ });
86
+ }) ?? [];
87
+ }
88
+ private ifOjbect<T>(handler: (schema: ObjectSchema, fields: BaseVariableSchema[]) => T): T | null
89
+ {
90
+ if (this.props.variable.type.type === VariableType.Object)
91
+ {
92
+ let schema = this.props.variable.type as ObjectSchema;
93
+
94
+ if (this.multiple)
95
+ return null;
96
+ if (schema.external)
97
+ return null;
98
+ if (!schema.fields)
99
+ return null
100
+ if (schema.fields.length === 0)
101
+ return null
102
+ if (schema.fields)
103
+ return handler(schema, schema.fields);
104
+ }
105
+ return null;
106
+ }
107
+ getValue(checkError: boolean = true): any | null
108
+ {
109
+ let obj = this.box_ref.current?.getValue(checkError);
110
+
111
+ let res = this.ifOjbect((_, fields) =>
112
+ {
113
+ let ans: { [name: string]: any } = {};
114
+ fields.forEach((f, index) =>
115
+ {
116
+ let obj = this.builders[index].builder.getValue(checkError);
117
+ ans[f.name] = obj;
118
+ });
119
+ return ans;
120
+ });
121
+ if (res != null)
122
+ obj = res;
123
+
124
+ return obj;
125
+ }
126
+ setValue(value: any | null, callback?: () => void): void
127
+ {
128
+ if (!this.ifOjbect((_, fields) =>
129
+ {
130
+ fields.forEach((f, index) =>
131
+ {
132
+ let obj = value?.[f.name];
133
+ this.builders[index].builder.setValue(obj);
134
+ });
135
+ return true;
136
+ }))
137
+ this.box_ref.current?.setValue(value, callback);
138
+ }
139
+ /* VariableType */
140
+ protected override _toAny(_: AnySchema)
141
+ {
142
+ return null;
143
+ }
144
+ protected override _toBool(schema: BoolSchema)
145
+ {
146
+ if (this.multiple)
147
+ return null;
148
+
149
+ return (
150
+ <NSBoxBoolean
151
+ ref={this.box_ref as React.RefObject<any>}
152
+ key={this.key}
153
+ {...this.props}
154
+
155
+ required={schema.required}
156
+ valids={schema.valids}
157
+ invalids={schema.invalids}
158
+ // regex={schema.regex}
159
+
160
+ title={this.title}
161
+ placeholder={this.placeholder}
162
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullBoolean() ?? undefined}
163
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
164
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
165
+ menu={this.menu}
166
+ />
167
+ );
168
+ }
169
+ private toInteger(schema: BaseNumberSchema): React.JSX.Element | null
170
+ {
171
+ if (this.multiple)
172
+ return null;
173
+
174
+ return (
175
+ <NSBoxInteger
176
+ ref={this.box_ref as React.RefObject<any>}
177
+ key={this.key}
178
+ {...this.props}
179
+
180
+ required={schema.required}
181
+ valids={schema.valids}
182
+ invalids={schema.invalids}
183
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
184
+
185
+ title={this.title}
186
+ placeholder={this.placeholder}
187
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullInt() ?? undefined}
188
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
189
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
190
+ menu={this.menu}
191
+
192
+ min={schema.min ?? undefined}
193
+ max={schema.max ?? undefined}
194
+ />
195
+ );
196
+ }
197
+ protected override _toTinyInt(schema: TinyIntSchema)
198
+ {
199
+ return this.toInteger(schema);
200
+ }
201
+ protected override _toSmallInt(schema: SmallIntSchema)
202
+ {
203
+ return this.toInteger(schema);
204
+ }
205
+ protected override _toMediumInt(schema: MediumIntSchema)
206
+ {
207
+ return this.toInteger(schema);
208
+ }
209
+ protected override _toInteger(schema: IntegerSchema)
210
+ {
211
+ return this.toInteger(schema);
212
+ }
213
+ protected override _toBigInt(schema: BigIntSchema)
214
+ {
215
+ return this.toInteger(schema);
216
+ }
217
+ private toPrecision(schema: BasePrecisionSchema): React.JSX.Element | null
218
+ {
219
+ if (this.multiple)
220
+ return null;
221
+
222
+ return (
223
+ <NSBoxDouble
224
+ ref={this.box_ref as React.RefObject<any>}
225
+ key={this.key}
226
+ {...this.props}
227
+
228
+ required={schema.required}
229
+ valids={schema.valids}
230
+ invalids={schema.invalids}
231
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
232
+
233
+ title={this.title}
234
+ placeholder={this.placeholder}
235
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullFloat() ?? undefined}
236
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
237
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
238
+ menu={this.menu}
239
+
240
+ min={schema.min ?? undefined}
241
+ max={schema.max ?? undefined}
242
+ precision={schema.precision ?? undefined}
243
+ />
244
+ );
245
+ }
246
+ protected override _toFloat(schema: FloatSchema)
247
+ {
248
+ return this.toPrecision(schema);
249
+ }
250
+ protected override _toDouble(schema: DoubleSchema)
251
+ {
252
+ return this.toPrecision(schema);
253
+ }
254
+ protected override _toDecimal(schema: DecimalSchema)
255
+ {
256
+ return this.toPrecision(schema);
257
+ }
258
+ protected override _toReal(schema: RealSchema)
259
+ {
260
+ return this.toPrecision(schema);
261
+ }
262
+ protected override _toMoney(schema: MoneySchema)
263
+ {
264
+ if (this.multiple)
265
+ return null;
266
+
267
+ return (
268
+ <NSBoxMoney
269
+ ref={this.box_ref as React.RefObject<any>}
270
+ key={this.key}
271
+ {...this.props}
272
+
273
+ required={schema.required}
274
+ valids={schema.valids}
275
+ invalids={schema.invalids}
276
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
277
+
278
+ title={this.title}
279
+ placeholder={this.placeholder}
280
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullFloat() ?? undefined}
281
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
282
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
283
+ menu={this.menu}
284
+
285
+ min={schema.min ?? undefined}
286
+ max={schema.max ?? undefined}
287
+ precision={schema.precision ?? undefined}
288
+ />
289
+ );
290
+ }
291
+ protected override _toString(schema: StringSchema)
292
+ {
293
+ if (this.multiple)
294
+ return null;
295
+
296
+ return (
297
+ <NSBoxString
298
+ ref={this.box_ref as React.RefObject<any>}
299
+ key={this.key}
300
+ {...this.props}
301
+
302
+ required={schema.required}
303
+ valids={schema.valids}
304
+ invalids={schema.invalids}
305
+ regex={schema.regex ? { name: this.props.variable.name, regex: schema.regex } : undefined}
306
+
307
+ title={this.title}
308
+ placeholder={this.placeholder}
309
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
310
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
311
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
312
+ menu={this.menu}
313
+
314
+ min_length={schema.min_length ?? undefined}
315
+ max_length={schema.max_length ?? undefined}
316
+ />
317
+ );
318
+ }
319
+ protected override _toDate(schema: DateSchema)
320
+ {
321
+ if (this.multiple)
322
+ return null;
323
+
324
+ return (
325
+ <NSBoxDate
326
+ ref={this.box_ref as React.RefObject<any>}
327
+ key={this.key}
328
+ {...this.props}
329
+
330
+ required={schema.required}
331
+ valids={schema.valids}
332
+ invalids={schema.invalids}
333
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
334
+
335
+ title={this.title}
336
+ placeholder={this.placeholder}
337
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
338
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
339
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
340
+ menu={this.menu}
341
+ />
342
+ );
343
+ }
344
+ protected override _toTime(schema: TimeSchema)
345
+ {
346
+ if (this.multiple)
347
+ return null;
348
+
349
+ return (
350
+ <NSBoxTime
351
+ ref={this.box_ref as React.RefObject<any>}
352
+ key={this.key}
353
+ {...this.props}
354
+
355
+ required={schema.required}
356
+ valids={schema.valids}
357
+ invalids={schema.invalids}
358
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
359
+
360
+ title={this.title}
361
+ placeholder={this.placeholder}
362
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
363
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
364
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
365
+ menu={this.menu}
366
+ />
367
+ );
368
+ }
369
+ protected override _toDateTime(schema: DateTimeSchema)
370
+ {
371
+ if (this.multiple)
372
+ return null;
373
+
374
+ return (
375
+ <NSBoxDateTime
376
+ ref={this.box_ref as React.RefObject<any>}
377
+ key={this.key}
378
+ {...this.props}
379
+
380
+ required={schema.required}
381
+ valids={schema.valids}
382
+ invalids={schema.invalids}
383
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
384
+
385
+ title={this.title}
386
+ placeholder={this.placeholder}
387
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullDate() ?? undefined}
388
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
389
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
390
+ menu={this.menu}
391
+ />
392
+ );
393
+ }
394
+ protected override _toTimeZone(schema: TimeZoneSchema)
395
+ {
396
+ if (this.multiple)
397
+ return null;
398
+
399
+ return (
400
+ <NSBoxTimeZone
401
+ ref={this.box_ref as React.RefObject<any>}
402
+ key={this.key}
403
+ {...this.props}
404
+
405
+ required={schema.required}
406
+ valids={schema.valids}
407
+ invalids={schema.invalids}
408
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
409
+
410
+ title={this.title}
411
+ placeholder={this.placeholder}
412
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
413
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
414
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
415
+ menu={this.menu}
416
+ />
417
+ );
418
+ }
419
+ protected override _toDuration(schema: DurationSchema)
420
+ {
421
+ if (this.multiple)
422
+ return null;
423
+
424
+ return (
425
+ <NSBoxDuration
426
+ ref={this.box_ref as React.RefObject<any>}
427
+ key={this.key}
428
+ {...this.props}
429
+
430
+ required={schema.required}
431
+ valids={schema.valids}
432
+ invalids={schema.invalids}
433
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
434
+
435
+ title={this.title}
436
+ placeholder={this.placeholder}
437
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
438
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
439
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
440
+ menu={this.menu}
441
+ />
442
+ );
443
+ }
444
+ protected override _toEmail(schema: EmailSchema)
445
+ {
446
+ if (this.multiple)
447
+ return null;
448
+
449
+ return (
450
+ <NSBoxEmail
451
+ ref={this.box_ref as React.RefObject<any>}
452
+ key={this.key}
453
+ {...this.props}
454
+
455
+ required={schema.required}
456
+ valids={schema.valids}
457
+ invalids={schema.invalids}
458
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
459
+
460
+ title={this.title}
461
+ placeholder={this.placeholder}
462
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
463
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
464
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
465
+ menu={this.menu}
466
+ />
467
+ );
468
+ }
469
+ protected override _toPhone(schema: PhoneSchema)
470
+ {
471
+ if (this.multiple)
472
+ return null;
473
+
474
+ return (
475
+ <NSBoxPhone
476
+ ref={this.box_ref as React.RefObject<any>}
477
+ key={this.key}
478
+ {...this.props}
479
+
480
+ required={schema.required}
481
+ valids={schema.valids}
482
+ invalids={schema.invalids}
483
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
484
+
485
+ title={this.title}
486
+ placeholder={this.placeholder}
487
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
488
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
489
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
490
+ menu={this.menu}
491
+ />
492
+ );
493
+ }
494
+ protected override _toVersion(schema: VersionSchema)
495
+ {
496
+ if (this.multiple)
497
+ return null;
498
+ return (
499
+ <NSBoxVersion
500
+ ref={this.box_ref as React.RefObject<any>}
501
+ key={this.key}
502
+ {...this.props}
503
+
504
+ required={schema.required}
505
+ valids={schema.valids}
506
+ invalids={schema.invalids}
507
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
508
+
509
+ title={this.title}
510
+ placeholder={this.placeholder}
511
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
512
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
513
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
514
+ menu={this.menu}
515
+ />
516
+ );
517
+ }
518
+ protected override _toIPV4(schema: IPV4Schema)
519
+ {
520
+ if (this.multiple)
521
+ return null;
522
+ return (
523
+ <NSBoxIPV4
524
+ ref={this.box_ref as React.RefObject<any>}
525
+ key={this.key}
526
+ {...this.props}
527
+
528
+ required={schema.required}
529
+ valids={schema.valids}
530
+ invalids={schema.invalids}
531
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
532
+
533
+ title={this.title}
534
+ placeholder={this.placeholder}
535
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
536
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
537
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
538
+ menu={this.menu}
539
+ />
540
+ );
541
+ }
542
+ protected override _toIPV6(schema: IPV6Schema)
543
+ {
544
+ if (this.multiple)
545
+ return null;
546
+ return (
547
+ <NSBoxIPV6
548
+ ref={this.box_ref as React.RefObject<any>}
549
+ key={this.key}
550
+ {...this.props}
551
+
552
+ required={schema.required}
553
+ valids={schema.valids}
554
+ invalids={schema.invalids}
555
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
556
+
557
+ title={this.title}
558
+ placeholder={this.placeholder}
559
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
560
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
561
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
562
+ menu={this.menu}
563
+ />
564
+ );
565
+ }
566
+ protected override _toIPV4Range(schema: IPV4RangeSchema)
567
+ {
568
+ if (this.multiple)
569
+ return null;
570
+ return (
571
+ <NSBoxIPV4Range
572
+ ref={this.box_ref as React.RefObject<any>}
573
+ key={this.key}
574
+ {...this.props}
575
+
576
+ required={schema.required}
577
+ valids={schema.valids}
578
+ invalids={schema.invalids}
579
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
580
+
581
+ title={this.title}
582
+ placeholder={this.placeholder}
583
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
584
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
585
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
586
+ menu={this.menu}
587
+ />
588
+ );
589
+ }
590
+ protected override _toIPV6Range(schema: IPV6RangeSchema)
591
+ {
592
+ if (this.multiple)
593
+ return null;
594
+ return (
595
+ <NSBoxIPV6Range
596
+ ref={this.box_ref as React.RefObject<any>}
597
+ key={this.key}
598
+ {...this.props}
599
+
600
+ required={schema.required}
601
+ valids={schema.valids}
602
+ invalids={schema.invalids}
603
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
604
+
605
+ title={this.title}
606
+ placeholder={this.placeholder}
607
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
608
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
609
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
610
+ menu={this.menu}
611
+ />
612
+ );
613
+ }
614
+ protected override _toColor(schema: ColorSchema)
615
+ {
616
+ if (this.multiple)
617
+ return null;
618
+ return (
619
+ <NSBoxColor
620
+ ref={this.box_ref as React.RefObject<any>}
621
+ key={this.key}
622
+ {...this.props}
623
+
624
+ required={schema.required}
625
+ valids={schema.valids}
626
+ invalids={schema.invalids}
627
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
628
+
629
+ title={this.title}
630
+ placeholder={this.placeholder}
631
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
632
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
633
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
634
+ menu={this.menu}
635
+ />
636
+ );
637
+ }
638
+ protected override _toFont(schema: FontSchema)
639
+ {
640
+ if (this.multiple)
641
+ return null;
642
+ return (
643
+ <NSBoxFont
644
+ ref={this.box_ref as React.RefObject<any>}
645
+ key={this.key}
646
+ {...this.props}
647
+
648
+ required={schema.required}
649
+ valids={schema.valids}
650
+ invalids={schema.invalids}
651
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
652
+
653
+ title={this.title}
654
+ placeholder={this.placeholder}
655
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
656
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
657
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
658
+ menu={this.menu}
659
+ />
660
+ );
661
+ }
662
+ protected override _toFilePath(schema: FilePathSchema)
663
+ {
664
+ if (this.multiple)
665
+ return null;
666
+ return (
667
+ <NSBoxFilePath
668
+ ref={this.box_ref as React.RefObject<any>}
669
+ key={this.key}
670
+ {...this.props}
671
+
672
+ required={schema.required}
673
+ valids={schema.valids}
674
+ invalids={schema.invalids}
675
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
676
+
677
+ title={this.title}
678
+ placeholder={this.placeholder}
679
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
680
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
681
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
682
+ menu={this.menu}
683
+ />
684
+ );
685
+ }
686
+ protected override _toURL(schema: URLSchema)
687
+ {
688
+ if (this.multiple)
689
+ return null;
690
+ return (
691
+ <NSBoxURL
692
+ ref={this.box_ref as React.RefObject<any>}
693
+ key={this.key}
694
+ {...this.props}
695
+
696
+ required={schema.required}
697
+ valids={schema.valids}
698
+ invalids={schema.invalids}
699
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
700
+
701
+ title={this.title}
702
+ placeholder={this.placeholder}
703
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
704
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
705
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
706
+ menu={this.menu}
707
+ />
708
+ );
709
+ }
710
+ protected override _toEnum(schema: EnumSchema)
711
+ {
712
+ return (
713
+ <NSBoxCombo
714
+ ref={this.box_ref as React.RefObject<any>}
715
+ key={this.key}
716
+ {...this.props}
717
+
718
+ required={schema.required}
719
+ valids={schema.valids}
720
+ invalids={schema.invalids}
721
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
722
+
723
+ title={this.title}
724
+ placeholder={this.placeholder}
725
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
726
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
727
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
728
+ menu={this.menu}
729
+
730
+ multiple={this.multiple ?? false}
731
+ getOptions={() =>
732
+ {
733
+ let valids = schema.valids;
734
+ valids = valids.filter((v) => !schema.invalids.includes(v));
735
+ return valids.map((v) => ({ title: v, value: v }));
736
+ }}
737
+ />
738
+ );
739
+ }
740
+ protected override _toEntity(schema: EntitySchema)
741
+ {
742
+ let global = new NamirasoftMap()
743
+ let meta = global.getByShortName(schema.product);
744
+ if (meta.table)
745
+ return (
746
+ <NSBoxEntity<any>
747
+ ref={this.box_ref as React.RefObject<any>}
748
+ key={this.key}
749
+ {...this.props}
750
+
751
+ required={schema.required}
752
+ valids={schema.valids}
753
+ invalids={schema.invalids}
754
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
755
+
756
+ title={this.title}
757
+ placeholder={this.placeholder}
758
+ defaultValue={new ObjectService(this.props.variable.defaultValue).getNullString() ?? undefined}
759
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
760
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
761
+ menu={this.menu}
762
+
763
+ multiple={this.multiple ?? false}
764
+
765
+ table={meta.table}
766
+ getValue={(item) => item.id}
767
+ getTitle={(item) => item.name}
768
+ getSort={() => null}
769
+ />
770
+ );
771
+ return <>Could not find table information</>;
772
+ }
773
+ protected override _toArray(schema: ArraySchema, callback: (schema: BaseTypeSchema) => void)
774
+ {
775
+ if (this.multiple)
776
+ return null;
777
+ if (schema.items.length === 0)
778
+ return null;
779
+ if (schema.items.length > 1)
780
+ return null;
781
+
782
+ let menu = safeMenuMenuItem(this.props, () => { });
783
+
784
+ return (
785
+ <NSBoxBaseLayoutRecursive
786
+ id={this.props.id}
787
+ {...this.props}
788
+ required
789
+ title={this.title}
790
+ depth={this.depth}
791
+ menu={menu}
792
+ >
793
+ <NSRepeater<INSBox, string>
794
+ ref={this.box_ref as React.RefObject<any>}
795
+ key={this.key}
796
+ title={this.title}
797
+ createItem={(gIndex: number, lIndex: number, ref: React.RefObject<INSBox>, onChange: () => void, onDelete: undefined | ((index: number) => void)) =>
798
+ {
799
+ let title = "Item " + (lIndex + 1)
800
+ let props = {
801
+ ...this.props,
802
+ title,
803
+ onChanged: (box: NSBoxDynamic) =>
804
+ {
805
+ this.props.onChanged?.(box);
806
+ onChange();
807
+ },
808
+ style: { ...this.props.style },
809
+ variable: new BaseVariableSchema(title, schema.items[0]),
810
+ multiple: false
811
+ };
812
+ let builder = new NSBoxBuilder(this.box, props, ref, "NSBoxBuilder_NSRepeater_Item_" + (gIndex + 1),
813
+ onDelete ? () => { onDelete(gIndex) } : undefined
814
+ );
815
+ builder.depth = this.depth + 1;
816
+ return builder.runSynch(callback);
817
+ }}
818
+ setValue={function (item: INSBox, _: number, value: string | null): void
819
+ {
820
+ if (value)
821
+ item.setValue(value);
822
+ }}
823
+ getValue={function (item: INSBox, checkError: boolean): string
824
+ {
825
+ return item.getValue(checkError)
826
+ }}
827
+ isEmpty={function (item: INSBox, value: string | null): boolean
828
+ {
829
+ return item.isEmpty(value)
830
+ }}
831
+ required={schema.required}
832
+ min={schema.min ?? undefined}
833
+ max={schema.max ?? undefined}
834
+ />
835
+ </NSBoxBaseLayoutRecursive>
836
+ );
837
+ }
838
+ protected override _toObject(schema: ObjectSchema, callback: (schema: BaseTypeSchema) => void)
839
+ {
840
+ let children: React.JSX.Element[] | null = this.ifOjbect((_, fields) =>
841
+ {
842
+ return fields.map((_, index) =>
843
+ {
844
+ return this.builders[index].builder.runSynch(callback);
845
+ }).filter(x => x).map(x => x as React.JSX.Element);
846
+ });
847
+ if (!children)
848
+ return null;
849
+
850
+ let menu = safeMenuMenuItem(this.props, () => { });
851
+
852
+ return (
853
+ <NSBoxBaseLayoutRecursive
854
+ id={this.props.id}
855
+ {...this.props}
856
+ required
857
+ title={this.title + ((schema.name && schema.name !== this.title) ? ` (${schema.name})` : "")}
858
+ depth={this.depth}
859
+ menu={menu}
860
+ >
861
+ {children}
862
+ </NSBoxBaseLayoutRecursive>
863
+ );
864
+ }
865
+ protected override _toType(schema: TypeSchema)
866
+ {
867
+ if (this.multiple)
868
+ return null;
869
+ return (
870
+ <NSBoxSchemaBase
871
+ ref={this.box_ref as React.RefObject<any>}
872
+ key={this.key}
873
+ {...this.props}
874
+
875
+ required={schema.required}
876
+ valids={schema.valids}
877
+ invalids={schema.invalids}
878
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
879
+
880
+ title={this.title}
881
+ placeholder={this.placeholder}
882
+ defaultValue={undefined}
883
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
884
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
885
+ menu={this.menu}
886
+ />
887
+ );
888
+ }
889
+ protected override _toVariable(schema: VariableSchema)
890
+ {
891
+ if (this.multiple)
892
+ return null;
893
+ return (
894
+ <NSBoxSchemaVariable
895
+ ref={this.box_ref as React.RefObject<any>}
896
+ key={this.key}
897
+ {...this.props}
898
+
899
+ required={schema.required}
900
+ valids={schema.valids}
901
+ invalids={schema.invalids}
902
+ // regex={schema.regex ? { name: variable.name, regex: schema.regex } : undefined}
903
+
904
+ title={this.title}
905
+ placeholder={this.placeholder}
906
+ defaultValue={undefined}
907
+ onChanged={(_) => { this.props.onChanged?.(this.box); }}
908
+ onClicked={(_) => { this.props.onClicked?.(this.box); }}
909
+ menu={this.menu}
910
+ />
911
+ );
912
+ }
913
913
  }