namirasoft-site-react 1.4.112 → 1.4.113

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (270) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +72 -71
  5. package/dist/App.css +58 -0
  6. package/dist/components/NSAccordion.module.css +4 -4
  7. package/dist/components/NSActionMenu.js +2 -2
  8. package/dist/components/NSActionMenu.module.css +101 -101
  9. package/dist/components/NSAssistantButton.module.css +135 -135
  10. package/dist/components/NSBarAction.module.css +97 -97
  11. package/dist/components/NSBarAlert.module.css +69 -69
  12. package/dist/components/NSBarHeroBanner.module.css +42 -42
  13. package/dist/components/NSBarNotification.module.css +34 -34
  14. package/dist/components/NSBarTitle.module.css +9 -9
  15. package/dist/components/NSBox.module.css +126 -126
  16. package/dist/components/NSBoxBoolean.module.css +88 -88
  17. package/dist/components/NSBoxCombo.module.css +6 -6
  18. package/dist/components/NSBoxCopy.module.css +43 -43
  19. package/dist/components/NSBoxDate.module.css +56 -56
  20. package/dist/components/NSBoxDateTime.module.css +51 -51
  21. package/dist/components/NSBoxEntity.module.css +21 -21
  22. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  23. package/dist/components/NSBoxFile.module.css +4 -4
  24. package/dist/components/NSBoxLabel.module.css +14 -14
  25. package/dist/components/NSBoxRadio.module.css +70 -70
  26. package/dist/components/NSBoxTextArea.module.css +83 -83
  27. package/dist/components/NSButton.module.css +42 -42
  28. package/dist/components/NSButtonBlue.module.css +4 -4
  29. package/dist/components/NSButtonGreen.module.css +4 -4
  30. package/dist/components/NSButtonRed.module.css +4 -4
  31. package/dist/components/NSCard.module.css +114 -114
  32. package/dist/components/NSCardScreenshot.module.css +41 -41
  33. package/dist/components/NSChartColumn.module.css +7 -7
  34. package/dist/components/NSChartPie.module.css +0 -0
  35. package/dist/components/NSChartTable.module.css +21 -21
  36. package/dist/components/NSCopyToClipboard.d.ts +7 -0
  37. package/dist/components/NSCopyToClipboard.js +13 -0
  38. package/dist/components/NSCopyToClipboard.js.map +1 -0
  39. package/dist/components/NSCopyToClipboard.module.css +44 -0
  40. package/dist/components/NSDialog.module.css +106 -106
  41. package/dist/components/NSDownTimer.module.css +55 -55
  42. package/dist/components/NSDownload.module.css +46 -46
  43. package/dist/components/NSElectronicCard.module.css +60 -60
  44. package/dist/components/NSEntityBar.module.css +77 -77
  45. package/dist/components/NSEntityCardBackground.module.css +27 -27
  46. package/dist/components/NSFilterBox.module.css +62 -62
  47. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  48. package/dist/components/NSFilterItem.module.css +23 -23
  49. package/dist/components/NSFooter.module.css +123 -123
  50. package/dist/components/NSGroupedList.module.css +72 -72
  51. package/dist/components/NSHeader.module.css +291 -291
  52. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  53. package/dist/components/NSLayout.module.css +13 -13
  54. package/dist/components/NSLine.module.css +12 -12
  55. package/dist/components/NSLink.module.css +36 -36
  56. package/dist/components/NSLoading.module.css +30 -30
  57. package/dist/components/NSNoData.module.css +8 -8
  58. package/dist/components/NSPageSelectionModal.module.css +103 -103
  59. package/dist/components/NSPagination.module.css +110 -110
  60. package/dist/components/NSPanel.module.css +46 -46
  61. package/dist/components/NSRadioButton.d.ts +25 -0
  62. package/dist/components/NSRadioButton.js +49 -0
  63. package/dist/components/NSRadioButton.js.map +1 -0
  64. package/dist/components/NSRange.module.css +66 -66
  65. package/dist/components/NSSection.module.css +10 -10
  66. package/dist/components/NSSectionBars.module.css +10 -10
  67. package/dist/components/NSSectionCards.module.css +38 -38
  68. package/dist/components/NSTabPage.module.css +59 -59
  69. package/dist/components/NSTable.module.css +290 -290
  70. package/dist/components/NSTag.module.css +52 -52
  71. package/dist/components/NSTimeTable.module.css +6 -6
  72. package/dist/components/NSTimelineMonthly.module.css +71 -71
  73. package/dist/components/NSTitle.module.css +15 -15
  74. package/dist/formatter/ForeignIDFormatter.d.ts +4 -0
  75. package/dist/formatter/ForeignIDFormatter.js +7 -0
  76. package/dist/formatter/ForeignIDFormatter.js.map +1 -0
  77. package/dist/index.css +6 -0
  78. package/dist/pages/NSNotFoundPage.module.css +17 -17
  79. package/dist/pages/NSUpdating.module.css +35 -35
  80. package/package.json +75 -75
  81. package/public/index.html +38 -38
  82. package/src/App.css +57 -57
  83. package/src/App.tsx +372 -372
  84. package/src/Color.tsx +10 -10
  85. package/src/CopyToClipboard.ts +6 -6
  86. package/src/Validator.ts +117 -117
  87. package/src/components/NSAccordion.module.css +4 -4
  88. package/src/components/NSAccordion.tsx +51 -51
  89. package/src/components/NSActionMenu.module.css +101 -101
  90. package/src/components/NSActionMenu.tsx +90 -90
  91. package/src/components/NSAssistantButton.module.css +135 -135
  92. package/src/components/NSAssistantButton.tsx +70 -70
  93. package/src/components/NSBarAction.module.css +97 -97
  94. package/src/components/NSBarAction.tsx +89 -89
  95. package/src/components/NSBarAlert.module.css +69 -69
  96. package/src/components/NSBarAlert.tsx +30 -30
  97. package/src/components/NSBarHeroBanner.module.css +42 -42
  98. package/src/components/NSBarHeroBanner.tsx +61 -61
  99. package/src/components/NSBarNotification.module.css +34 -34
  100. package/src/components/NSBarNotification.tsx +87 -87
  101. package/src/components/NSBarTitle.module.css +9 -9
  102. package/src/components/NSBarTitle.tsx +29 -29
  103. package/src/components/NSBox.module.css +126 -126
  104. package/src/components/NSBoxBoolean.module.css +88 -88
  105. package/src/components/NSBoxBoolean.tsx +124 -124
  106. package/src/components/NSBoxBooleans.tsx +159 -159
  107. package/src/components/NSBoxCombo.module.css +6 -6
  108. package/src/components/NSBoxCombo.tsx +151 -151
  109. package/src/components/NSBoxCopy.module.css +43 -43
  110. package/src/components/NSBoxCopy.tsx +41 -41
  111. package/src/components/NSBoxDate.module.css +56 -56
  112. package/src/components/NSBoxDate.tsx +88 -88
  113. package/src/components/NSBoxDateTime.module.css +51 -51
  114. package/src/components/NSBoxDateTime.tsx +89 -89
  115. package/src/components/NSBoxDouble.tsx +92 -92
  116. package/src/components/NSBoxDuration.tsx +92 -92
  117. package/src/components/NSBoxEmail.tsx +103 -103
  118. package/src/components/NSBoxEntity.module.css +21 -21
  119. package/src/components/NSBoxEntity.tsx +197 -197
  120. package/src/components/NSBoxEnum.tsx +55 -55
  121. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  122. package/src/components/NSBoxErrorNotifier.tsx +32 -32
  123. package/src/components/NSBoxFile.module.css +4 -4
  124. package/src/components/NSBoxFile.tsx +124 -124
  125. package/src/components/NSBoxIPV4.tsx +97 -97
  126. package/src/components/NSBoxIPV6.tsx +94 -94
  127. package/src/components/NSBoxInteger.tsx +94 -94
  128. package/src/components/NSBoxLabel.module.css +14 -14
  129. package/src/components/NSBoxLabel.tsx +29 -29
  130. package/src/components/NSBoxPassword.tsx +90 -90
  131. package/src/components/NSBoxPhone.tsx +97 -97
  132. package/src/components/NSBoxPrice.tsx +92 -92
  133. package/src/components/NSBoxRadio.module.css +70 -70
  134. package/src/components/NSBoxRadio.tsx +111 -111
  135. package/src/components/NSBoxSearch.tsx +107 -107
  136. package/src/components/NSBoxString.tsx +106 -106
  137. package/src/components/NSBoxTextArea.module.css +83 -83
  138. package/src/components/NSBoxTextArea.tsx +112 -112
  139. package/src/components/NSBoxTime.tsx +92 -92
  140. package/src/components/NSButton.module.css +42 -42
  141. package/src/components/NSButton.tsx +25 -25
  142. package/src/components/NSButtonBlue.module.css +4 -4
  143. package/src/components/NSButtonBlue.tsx +19 -19
  144. package/src/components/NSButtonGreen.module.css +4 -4
  145. package/src/components/NSButtonGreen.tsx +19 -19
  146. package/src/components/NSButtonRed.module.css +4 -4
  147. package/src/components/NSButtonRed.tsx +19 -19
  148. package/src/components/NSCard.module.css +114 -114
  149. package/src/components/NSCard.tsx +63 -63
  150. package/src/components/NSCardScreenshot.module.css +41 -41
  151. package/src/components/NSCardScreenshot.tsx +31 -31
  152. package/src/components/NSChartColumn.module.css +7 -7
  153. package/src/components/NSChartColumn.tsx +106 -106
  154. package/src/components/NSChartDoughnut.tsx +108 -108
  155. package/src/components/NSChartPie.tsx +105 -105
  156. package/src/components/NSChartRange.tsx +16 -16
  157. package/src/components/NSChartTable.module.css +21 -21
  158. package/src/components/NSChartTable.tsx +94 -94
  159. package/src/components/NSCopy.tsx +67 -67
  160. package/src/components/NSDeleteDialog.tsx +26 -26
  161. package/src/components/NSDialog.module.css +106 -106
  162. package/src/components/NSDialog.tsx +56 -56
  163. package/src/components/NSDownTimer.module.css +55 -55
  164. package/src/components/NSDownTimer.tsx +77 -77
  165. package/src/components/NSDownload.module.css +46 -46
  166. package/src/components/NSDownload.tsx +62 -62
  167. package/src/components/NSElectronicCard.module.css +60 -60
  168. package/src/components/NSElectronicCard.tsx +45 -45
  169. package/src/components/NSEntityBar.module.css +77 -77
  170. package/src/components/NSEntityBar.tsx +27 -27
  171. package/src/components/NSEntityCardBackground.module.css +27 -27
  172. package/src/components/NSEntityCardBackground.tsx +34 -34
  173. package/src/components/NSFilterBox.module.css +62 -62
  174. package/src/components/NSFilterBox.tsx +360 -360
  175. package/src/components/NSFilterBoxDialog.module.css +36 -36
  176. package/src/components/NSFilterBoxDialog.tsx +74 -74
  177. package/src/components/NSFilterItem.module.css +23 -23
  178. package/src/components/NSFilterItem.tsx +73 -73
  179. package/src/components/NSFooter.module.css +123 -123
  180. package/src/components/NSFooter.tsx +289 -289
  181. package/src/components/NSGroupedList.module.css +72 -72
  182. package/src/components/NSGroupedList.tsx +115 -115
  183. package/src/components/NSHeader.module.css +291 -291
  184. package/src/components/NSHeader.tsx +250 -250
  185. package/src/components/NSHeaderScreenshot.module.css +35 -35
  186. package/src/components/NSHeaderScreenshot.tsx +38 -38
  187. package/src/components/NSInfoDialog.tsx +36 -36
  188. package/src/components/NSLayout.module.css +13 -13
  189. package/src/components/NSLayout.tsx +109 -109
  190. package/src/components/NSLine.module.css +12 -12
  191. package/src/components/NSLine.tsx +15 -15
  192. package/src/components/NSLink.module.css +36 -36
  193. package/src/components/NSLink.tsx +25 -25
  194. package/src/components/NSLinkBlue.tsx +20 -20
  195. package/src/components/NSLinkGreen.tsx +5 -5
  196. package/src/components/NSLinkRed.tsx +5 -5
  197. package/src/components/NSLoading.module.css +30 -30
  198. package/src/components/NSLoading.tsx +20 -20
  199. package/src/components/NSNoData.module.css +8 -8
  200. package/src/components/NSNoData.tsx +24 -24
  201. package/src/components/NSPageSelectionModal.module.css +103 -103
  202. package/src/components/NSPageSelectionModal.tsx +228 -228
  203. package/src/components/NSPagination.module.css +110 -110
  204. package/src/components/NSPagination.tsx +191 -191
  205. package/src/components/NSPanel.module.css +46 -46
  206. package/src/components/NSPanel.tsx +19 -19
  207. package/src/components/NSProductList.tsx +43 -43
  208. package/src/components/NSRange.module.css +66 -66
  209. package/src/components/NSRange.tsx +81 -81
  210. package/src/components/NSRepeater.tsx +179 -179
  211. package/src/components/NSSection.module.css +10 -10
  212. package/src/components/NSSection.tsx +23 -23
  213. package/src/components/NSSectionBars.module.css +10 -10
  214. package/src/components/NSSectionBars.tsx +25 -25
  215. package/src/components/NSSectionCards.module.css +38 -38
  216. package/src/components/NSSectionCards.tsx +51 -51
  217. package/src/components/NSSectionTitle.tsx +21 -21
  218. package/src/components/NSSpace.tsx +28 -28
  219. package/src/components/NSTabPage.module.css +59 -59
  220. package/src/components/NSTabPage.tsx +78 -78
  221. package/src/components/NSTable.module.css +290 -290
  222. package/src/components/NSTable.tsx +436 -436
  223. package/src/components/NSTag.module.css +52 -52
  224. package/src/components/NSTag.tsx +78 -78
  225. package/src/components/NSTimeTable.module.css +6 -6
  226. package/src/components/NSTimeTable.tsx +49 -49
  227. package/src/components/NSTimelineMonthly.module.css +71 -71
  228. package/src/components/NSTimelineMonthly.tsx +42 -42
  229. package/src/components/NSTitle.module.css +15 -15
  230. package/src/components/NSTitle.tsx +19 -19
  231. package/src/formatter/BackColorFormatter.tsx +22 -22
  232. package/src/formatter/BaseColumnFormatter.ts +16 -16
  233. package/src/formatter/BooleanFormatter.ts +22 -22
  234. package/src/formatter/DateFormatter.ts +20 -20
  235. package/src/formatter/DateTimeFormatter.ts +20 -20
  236. package/src/formatter/DurationFormatter.ts +13 -13
  237. package/src/formatter/EmailFormatter.ts +13 -13
  238. package/src/formatter/EnumFormatter.ts +13 -13
  239. package/src/formatter/FloatFormatter.ts +16 -16
  240. package/src/formatter/ForeColorFormatter.tsx +22 -22
  241. package/src/formatter/IDFormatter.tsx +28 -28
  242. package/src/formatter/IPFormatter.ts +13 -13
  243. package/src/formatter/IntegerFormatter.ts +16 -16
  244. package/src/formatter/JsonFormatter.ts +14 -14
  245. package/src/formatter/MoneyFormatter.ts +16 -16
  246. package/src/formatter/PhoneFormatter.ts +13 -13
  247. package/src/formatter/StringFormatter.ts +13 -13
  248. package/src/formatter/TimeFormatter.ts +21 -21
  249. package/src/formatter/UnknowFormatter.ts +14 -14
  250. package/src/index.tsx +7 -7
  251. package/src/main.ts +117 -117
  252. package/src/pages/NSNotFoundPage.module.css +17 -17
  253. package/src/pages/NSNotFoundPage.tsx +11 -11
  254. package/src/pages/NSUpdating.module.css +35 -35
  255. package/src/pages/NSUpdating.tsx +32 -32
  256. package/src/props/IBaseComponentProps.ts +8 -8
  257. package/src/props/IHeaderIconProps.ts +10 -10
  258. package/src/props/IHeaderProps.ts +7 -7
  259. package/src/props/IImageProps.ts +4 -4
  260. package/src/props/ILinkProps.ts +5 -5
  261. package/src/props/IValidationNumberProps.ts +4 -4
  262. package/src/props/IValidationProps.ts +7 -7
  263. package/src/props/IValidationRegexProps.ts +4 -4
  264. package/src/props/IValidationStringProps.ts +4 -4
  265. package/src/routing/INSRouterMaker.ts +6 -6
  266. package/src/routing/INSRouterProps.ts +5 -5
  267. package/src/routing/INSRouterState.ts +5 -5
  268. package/src/routing/NSRouterMaker.tsx +33 -33
  269. package/src/routing/Notifier.ts +79 -79
  270. package/tsconfig.json +43 -43
package/src/App.tsx CHANGED
@@ -1,373 +1,373 @@
1
- import './App.css';
2
- import 'bootstrap/dist/css/bootstrap.min.css';
3
- import { NSTable, INSTableProps, TableColumnInfo, TableRowInfo } from './components/NSTable';
4
- import { BackColorFormatter, BooleanFormatter, DateFormatter, DateTimeFormatter, EmailFormatter, EnumFormatter, FloatFormatter, IDFormatter, IntegerFormatter, IPFormatter, NSBarAlert, NSBoxBoolean, NSBoxBooleans, NSBoxDate, NSBoxEnum, NSBoxInteger, NSBoxPhone, NSBoxRadio, NSBoxSearch, NSBoxString, NSBoxTextArea, NSButtonBlue, NSCard, NSChartDoughnut, NSDialog, NSDownTimer, NSNotFoundPage, NSRepeater, NSTabPage, PhoneFormatter, TimeFormatter } from './main';
5
- import { useState } from 'react';
6
-
7
- export interface INSBarActionState
8
- {
9
- id: string;
10
- menu_item: string;
11
- handler: () => void;
12
- isActive: () => boolean;
13
- }
14
-
15
- const columns: TableColumnInfo[] = [
16
- {
17
- index: 0,
18
- name: 'id',
19
- text: 'ID',
20
- formatter: new IDFormatter(),
21
- },
22
- {
23
- index: 1,
24
- name: 'valid',
25
- text: 'Valid',
26
- formatter: new BackColorFormatter(new BooleanFormatter("Valid", "Invalid"), { true: "green", false: "red" }),
27
- },
28
- {
29
- index: 2,
30
- name: 'data',
31
- text: 'Date',
32
- formatter: new DateFormatter(),
33
- },
34
- {
35
- index: 3,
36
- name: 'time',
37
- text: 'Time',
38
- formatter: new TimeFormatter(),
39
- },
40
- {
41
- index: 4,
42
- name: 'datetime',
43
- text: 'DateTime',
44
- formatter: new DateTimeFormatter(),
45
- },
46
- {
47
- index: 5,
48
- name: 'email',
49
- text: 'Email',
50
- formatter: new EmailFormatter(),
51
- },
52
- {
53
- index: 5,
54
- name: 'status',
55
- text: 'Status',
56
- formatter: new EnumFormatter(),
57
- },
58
- {
59
- index: 5,
60
- name: 'float',
61
- text: 'Float',
62
- formatter: new FloatFormatter(),
63
- },
64
- {
65
- index: 5,
66
- name: 'int',
67
- text: 'Int',
68
- formatter: new IntegerFormatter(),
69
- },
70
- {
71
- index: 5,
72
- name: 'ip',
73
- text: 'IP',
74
- formatter: new IPFormatter(),
75
- },
76
- {
77
- index: 5,
78
- name: 'phone',
79
- text: 'Phone',
80
- formatter: new PhoneFormatter(),
81
- },
82
- ];
83
- const rows = [
84
- { index: 0, id: 'bln-trn-401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "jane.doe123@example.com", status: "Active", float: 0.0123, int: -500, ip: "127.0.0.1", phone: "(123) 456-7890" },
85
- { index: 1, id: 'sss-0123401234012340', valid: false, data: new Date(), time: new Date(), datetime: new Date(), email: "random.guy45@fakeemail.net", status: "Pending", float: 200, int: 0.123, ip: "localhost", phone: "+1-234-567-8901" },
86
- { index: 2, id: 'pym-0123401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "hello.world99@sample.org", status: "Done", float: 4000, int: 9.999, ip: "192.168.10.255", phone: "123.456.7890" },
87
- { index: 2, id: 'pym-0123401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "user.name2024@testmail.com", status: "Done", float: 5999.0099, int: 4200, ip: "10.10.0.0/24", phone: "+44 20 7946 0958" },
88
- { index: 2, id: 'pym-0123401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "cool.kid77@domain.io", status: "Done", float: 800000.99, int: 250000000000, ip: "200.122.43.555/24", phone: "+1 (555) 555-5555" },
89
- ];
90
- let getFakeRows = async (page: number, size: number) =>
91
- {
92
- console.log(page, size);
93
- return { rows, count: rows.length };
94
- };
95
-
96
- const getFakeRowKey = (row: TableRowInfo<any>) =>
97
- { return `${row.index}`; };
98
-
99
- export function App()
100
- {
101
- const tableProps: INSTableProps<any> = {
102
- checkbox: true,
103
- columns: columns,
104
- getRows: getFakeRows,
105
- getRowKey: getFakeRowKey,
106
- };
107
- let [state, setState] = useState<(boolean | null)>(true);
108
-
109
- return (
110
- <>
111
- <NSTable {...tableProps} />
112
- <NSRepeater<NSBoxString, string>
113
- createItem={(_: number, lIndex: number, ref: React.RefObject<NSBoxString>, onChange: (index: number) => void, onDelete: (index: number) => void, __: boolean, style) =>
114
- {
115
- return <NSBoxString ref={ref} required={false} title={lIndex.toString()} style={style}
116
- onChanged={
117
- (x) =>
118
- {
119
- console.log(x)
120
- if (x.getValue() === "d")
121
- onDelete(lIndex);
122
- else
123
- onChange(lIndex);
124
- }
125
- }
126
- ></NSBoxString >;
127
- }
128
- }
129
- getValue={(item, checkError) => item.getValue(checkError)}
130
- isEmpty={value => value === ""}
131
- updateItem={(item: NSBoxString, _: number, value: string | null) =>
132
- {
133
- if (value)
134
- item.setValue(value);
135
- }}
136
- ></NSRepeater >
137
- <NSBoxBoolean checked={state} required={false} title={state + ""} indeterminate={false}
138
- onChanged={(e) =>
139
- {
140
- setState(e.getValue());
141
- }}
142
- ></NSBoxBoolean>
143
- <NSButtonBlue
144
- onClick={() =>
145
- {
146
- setState(!state);
147
- // if (state == null)
148
- // setState(false);
149
- // if (state == false)
150
- // setState(true);
151
- // if (state == true)
152
- // setState(null);
153
- }}
154
- ></NSButtonBlue>
155
-
156
- <NSNotFoundPage />
157
- <NSBoxDate required title='' />
158
- <NSBoxPhone
159
- required
160
- title=''
161
- />
162
- <NSBoxInteger
163
- required
164
- title=''
165
- min={8}
166
- max={12}
167
- />
168
- <NSBoxTextArea
169
- required
170
- title='asd'
171
- />
172
- <NSBoxEnum
173
- title='Retention Unit'
174
- required
175
- multiple={false}
176
- options={[
177
- { title: "LogGroupRetentionUnit.Day", value: "LogGroupRetentionUnit.Day" },
178
- { title: "LogGroupRetentionUnit.Week", value: "LogGroupRetentionUnit.Week" },
179
- { title: "LogGroupRetentionUnit.Month", value: "LogGroupRetentionUnit.Month" },
180
- { title: "LogGroupRetentionUnit.Year", value: "LogGroupRetentionUnit.Year" },
181
- ]}
182
- />
183
- <NSBoxRadio
184
- required
185
- title='asd'
186
- />
187
- <NSTabPage
188
- tabs={
189
- [{
190
- title: "asdasd",
191
- getContent: () =>
192
- {
193
- return (
194
-
195
- <div
196
- style={{ backgroundColor: "#fff", width: "100%", color: "#fff" }}
197
- className='ns_tab_page_custom_style'
198
- >
199
- <NSBoxPhone
200
- required
201
- title='teststs'
202
- />
203
- </div>
204
- )
205
- }
206
- },
207
- {
208
- title: "qwe asd ",
209
- getContent: () =>
210
- {
211
- return (
212
- <>
213
-
214
- <div
215
- style={{ backgroundColor: "#fff", width: "100%", color: "#fff" }}
216
- className='ns_tab_page_custom_style'
217
- >
218
- <NSBoxPhone
219
- required
220
- title='teststs'
221
- />
222
- </div>
223
- <NSButtonBlue
224
- title="Send"
225
- onClick={() => { }}
226
- />
227
- </>
228
- )
229
- }
230
- },
231
- {
232
- title: ";lkjqwiu lasid yh",
233
- getContent: () =>
234
- {
235
- return (
236
-
237
- <div
238
- style={{ backgroundColor: "#fff", width: "100%", color: "#fff" }}
239
- className='ns_tab_page_custom_style'
240
- >
241
- <NSBoxPhone
242
- required
243
- title='teststs'
244
- />
245
- </div>
246
- )
247
- }
248
- }
249
- ]
250
- }
251
-
252
- />
253
-
254
- <NSBoxDate
255
- required
256
- title='Test Test'
257
- />
258
- <NSBarAlert
259
- isVisible={() => true}
260
- onContinue={() => window.open("/")}
261
- title={
262
- {
263
- title: "Verify Your Email",
264
- description: "Lorem ipsum dolor sit amet consectetur. In ipsum gravida libero vitae tempor.Ipsum"
265
- }
266
- }
267
- />
268
- <NSBarAlert
269
- isVisible={() => true}
270
- onContinue={() => window.open("/")}
271
- title={
272
- {
273
- title: "Verify Your Email",
274
- description: "Lorem ipsum dolor sit amet consectetur. In ipsum gravida libero vitae tempor.Ipsum"
275
- }
276
- }
277
- />
278
- <div style={{ width: "560px" }}>
279
-
280
- <NSBoxSearch
281
- required
282
- title='asdasd'
283
- style={{ width: "100%", maxWidth: "100%" }}
284
- />
285
- </div>
286
- <NSButtonBlue
287
- onClick={() => { }}
288
- title='sssssssssss'
289
- disabled
290
- />
291
- <NSBarAlert
292
- isVisible={() => true}
293
- onContinue={() => window.open("/")}
294
- title={
295
- {
296
- title: "Verify Your Email",
297
- description: "Lorem ipsum dolor sit amet consectetur. In ipsum gravida libero vitae tempor.Ipsum"
298
- }
299
- }
300
- />
301
- <NSCard
302
- title="Namirasoft Job Arranger "
303
- description="asdasd asda sd asd asdd asd "
304
- image={{
305
- src: "https://static.namirasoft.com/image/namirasoft/history/logo/base.png",
306
- }}
307
- link={{
308
- href: "ss",
309
- title: "test",
310
- target: "_seld"
311
- }}
312
- />
313
-
314
- <div className="flex justify-content-center align-items-center w-100">
315
- <NSChartDoughnut
316
- datas={[7, 5, 8, 22, 5, 18]}
317
- labels={["test", "test2", "test3", "test4", "test5", "test6",]}
318
- backgroundColors={["#FF5733",
319
- "#42A5F5",
320
- "#FFC107",
321
- "#8BC34A",
322
- "#FF5722",
323
- "#673AB7",
324
- "#E91E63",
325
- "#4CAF50",
326
- "#FF9800",
327
- "#9C27B0",
328
- "#2196F3",
329
- "#FFEB3B",
330
- "#FF4081",
331
- "#00BCD4",
332
- "#CDDC39",]}
333
- title='test'
334
- />
335
- </div>
336
- <NSBoxBoolean
337
- required={false}
338
- title='test'
339
- checked={true}
340
-
341
- />
342
- <div className='out'>
343
- <div className="middle">
344
- <div className='in'></div>
345
- </div>
346
- </div>
347
- <NSDownTimer
348
- date={new Date()}
349
- text='Test '
350
- />
351
- <NSBoxBooleans
352
- items={[
353
- { value: "test1", text: "test1" },
354
- { value: "test2", text: "test2" },
355
- { value: "test3", text: "test3" },
356
- ]}
357
- onChanged={(box) =>
358
- {
359
- console.log(box.getValues());
360
- }}
361
- />
362
- {
363
- state &&
364
- <NSDialog
365
- center_dialog
366
- onClose={() => { setState(false) }}
367
- >
368
- <></>
369
- </NSDialog>
370
- }
371
- </>
372
- );
1
+ import './App.css';
2
+ import 'bootstrap/dist/css/bootstrap.min.css';
3
+ import { NSTable, INSTableProps, TableColumnInfo, TableRowInfo } from './components/NSTable';
4
+ import { BackColorFormatter, BooleanFormatter, DateFormatter, DateTimeFormatter, EmailFormatter, EnumFormatter, FloatFormatter, IDFormatter, IntegerFormatter, IPFormatter, NSBarAlert, NSBoxBoolean, NSBoxBooleans, NSBoxDate, NSBoxEnum, NSBoxInteger, NSBoxPhone, NSBoxRadio, NSBoxSearch, NSBoxString, NSBoxTextArea, NSButtonBlue, NSCard, NSChartDoughnut, NSDialog, NSDownTimer, NSNotFoundPage, NSRepeater, NSTabPage, PhoneFormatter, TimeFormatter } from './main';
5
+ import { useState } from 'react';
6
+
7
+ export interface INSBarActionState
8
+ {
9
+ id: string;
10
+ menu_item: string;
11
+ handler: () => void;
12
+ isActive: () => boolean;
13
+ }
14
+
15
+ const columns: TableColumnInfo[] = [
16
+ {
17
+ index: 0,
18
+ name: 'id',
19
+ text: 'ID',
20
+ formatter: new IDFormatter(),
21
+ },
22
+ {
23
+ index: 1,
24
+ name: 'valid',
25
+ text: 'Valid',
26
+ formatter: new BackColorFormatter(new BooleanFormatter("Valid", "Invalid"), { true: "green", false: "red" }),
27
+ },
28
+ {
29
+ index: 2,
30
+ name: 'data',
31
+ text: 'Date',
32
+ formatter: new DateFormatter(),
33
+ },
34
+ {
35
+ index: 3,
36
+ name: 'time',
37
+ text: 'Time',
38
+ formatter: new TimeFormatter(),
39
+ },
40
+ {
41
+ index: 4,
42
+ name: 'datetime',
43
+ text: 'DateTime',
44
+ formatter: new DateTimeFormatter(),
45
+ },
46
+ {
47
+ index: 5,
48
+ name: 'email',
49
+ text: 'Email',
50
+ formatter: new EmailFormatter(),
51
+ },
52
+ {
53
+ index: 5,
54
+ name: 'status',
55
+ text: 'Status',
56
+ formatter: new EnumFormatter(),
57
+ },
58
+ {
59
+ index: 5,
60
+ name: 'float',
61
+ text: 'Float',
62
+ formatter: new FloatFormatter(),
63
+ },
64
+ {
65
+ index: 5,
66
+ name: 'int',
67
+ text: 'Int',
68
+ formatter: new IntegerFormatter(),
69
+ },
70
+ {
71
+ index: 5,
72
+ name: 'ip',
73
+ text: 'IP',
74
+ formatter: new IPFormatter(),
75
+ },
76
+ {
77
+ index: 5,
78
+ name: 'phone',
79
+ text: 'Phone',
80
+ formatter: new PhoneFormatter(),
81
+ },
82
+ ];
83
+ const rows = [
84
+ { index: 0, id: 'bln-trn-401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "jane.doe123@example.com", status: "Active", float: 0.0123, int: -500, ip: "127.0.0.1", phone: "(123) 456-7890" },
85
+ { index: 1, id: 'sss-0123401234012340', valid: false, data: new Date(), time: new Date(), datetime: new Date(), email: "random.guy45@fakeemail.net", status: "Pending", float: 200, int: 0.123, ip: "localhost", phone: "+1-234-567-8901" },
86
+ { index: 2, id: 'pym-0123401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "hello.world99@sample.org", status: "Done", float: 4000, int: 9.999, ip: "192.168.10.255", phone: "123.456.7890" },
87
+ { index: 2, id: 'pym-0123401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "user.name2024@testmail.com", status: "Done", float: 5999.0099, int: 4200, ip: "10.10.0.0/24", phone: "+44 20 7946 0958" },
88
+ { index: 2, id: 'pym-0123401234012340', valid: true, data: new Date(), time: new Date(), datetime: new Date(), email: "cool.kid77@domain.io", status: "Done", float: 800000.99, int: 250000000000, ip: "200.122.43.555/24", phone: "+1 (555) 555-5555" },
89
+ ];
90
+ let getFakeRows = async (page: number, size: number) =>
91
+ {
92
+ console.log(page, size);
93
+ return { rows, count: rows.length };
94
+ };
95
+
96
+ const getFakeRowKey = (row: TableRowInfo<any>) =>
97
+ { return `${row.index}`; };
98
+
99
+ export function App()
100
+ {
101
+ const tableProps: INSTableProps<any> = {
102
+ checkbox: true,
103
+ columns: columns,
104
+ getRows: getFakeRows,
105
+ getRowKey: getFakeRowKey,
106
+ };
107
+ let [state, setState] = useState<(boolean | null)>(true);
108
+
109
+ return (
110
+ <>
111
+ <NSTable {...tableProps} />
112
+ <NSRepeater<NSBoxString, string>
113
+ createItem={(_: number, lIndex: number, ref: React.RefObject<NSBoxString>, onChange: (index: number) => void, onDelete: (index: number) => void, __: boolean, style) =>
114
+ {
115
+ return <NSBoxString ref={ref} required={false} title={lIndex.toString()} style={style}
116
+ onChanged={
117
+ (x) =>
118
+ {
119
+ console.log(x)
120
+ if (x.getValue() === "d")
121
+ onDelete(lIndex);
122
+ else
123
+ onChange(lIndex);
124
+ }
125
+ }
126
+ ></NSBoxString >;
127
+ }
128
+ }
129
+ getValue={(item, checkError) => item.getValue(checkError)}
130
+ isEmpty={value => value === ""}
131
+ updateItem={(item: NSBoxString, _: number, value: string | null) =>
132
+ {
133
+ if (value)
134
+ item.setValue(value);
135
+ }}
136
+ ></NSRepeater >
137
+ <NSBoxBoolean checked={state} required={false} title={state + ""} indeterminate={false}
138
+ onChanged={(e) =>
139
+ {
140
+ setState(e.getValue());
141
+ }}
142
+ ></NSBoxBoolean>
143
+ <NSButtonBlue
144
+ onClick={() =>
145
+ {
146
+ setState(!state);
147
+ // if (state == null)
148
+ // setState(false);
149
+ // if (state == false)
150
+ // setState(true);
151
+ // if (state == true)
152
+ // setState(null);
153
+ }}
154
+ ></NSButtonBlue>
155
+
156
+ <NSNotFoundPage />
157
+ <NSBoxDate required title='' />
158
+ <NSBoxPhone
159
+ required
160
+ title=''
161
+ />
162
+ <NSBoxInteger
163
+ required
164
+ title=''
165
+ min={8}
166
+ max={12}
167
+ />
168
+ <NSBoxTextArea
169
+ required
170
+ title='asd'
171
+ />
172
+ <NSBoxEnum
173
+ title='Retention Unit'
174
+ required
175
+ multiple={false}
176
+ options={[
177
+ { title: "LogGroupRetentionUnit.Day", value: "LogGroupRetentionUnit.Day" },
178
+ { title: "LogGroupRetentionUnit.Week", value: "LogGroupRetentionUnit.Week" },
179
+ { title: "LogGroupRetentionUnit.Month", value: "LogGroupRetentionUnit.Month" },
180
+ { title: "LogGroupRetentionUnit.Year", value: "LogGroupRetentionUnit.Year" },
181
+ ]}
182
+ />
183
+ <NSBoxRadio
184
+ required
185
+ title='asd'
186
+ />
187
+ <NSTabPage
188
+ tabs={
189
+ [{
190
+ title: "asdasd",
191
+ getContent: () =>
192
+ {
193
+ return (
194
+
195
+ <div
196
+ style={{ backgroundColor: "#fff", width: "100%", color: "#fff" }}
197
+ className='ns_tab_page_custom_style'
198
+ >
199
+ <NSBoxPhone
200
+ required
201
+ title='teststs'
202
+ />
203
+ </div>
204
+ )
205
+ }
206
+ },
207
+ {
208
+ title: "qwe asd ",
209
+ getContent: () =>
210
+ {
211
+ return (
212
+ <>
213
+
214
+ <div
215
+ style={{ backgroundColor: "#fff", width: "100%", color: "#fff" }}
216
+ className='ns_tab_page_custom_style'
217
+ >
218
+ <NSBoxPhone
219
+ required
220
+ title='teststs'
221
+ />
222
+ </div>
223
+ <NSButtonBlue
224
+ title="Send"
225
+ onClick={() => { }}
226
+ />
227
+ </>
228
+ )
229
+ }
230
+ },
231
+ {
232
+ title: ";lkjqwiu lasid yh",
233
+ getContent: () =>
234
+ {
235
+ return (
236
+
237
+ <div
238
+ style={{ backgroundColor: "#fff", width: "100%", color: "#fff" }}
239
+ className='ns_tab_page_custom_style'
240
+ >
241
+ <NSBoxPhone
242
+ required
243
+ title='teststs'
244
+ />
245
+ </div>
246
+ )
247
+ }
248
+ }
249
+ ]
250
+ }
251
+
252
+ />
253
+
254
+ <NSBoxDate
255
+ required
256
+ title='Test Test'
257
+ />
258
+ <NSBarAlert
259
+ isVisible={() => true}
260
+ onContinue={() => window.open("/")}
261
+ title={
262
+ {
263
+ title: "Verify Your Email",
264
+ description: "Lorem ipsum dolor sit amet consectetur. In ipsum gravida libero vitae tempor.Ipsum"
265
+ }
266
+ }
267
+ />
268
+ <NSBarAlert
269
+ isVisible={() => true}
270
+ onContinue={() => window.open("/")}
271
+ title={
272
+ {
273
+ title: "Verify Your Email",
274
+ description: "Lorem ipsum dolor sit amet consectetur. In ipsum gravida libero vitae tempor.Ipsum"
275
+ }
276
+ }
277
+ />
278
+ <div style={{ width: "560px" }}>
279
+
280
+ <NSBoxSearch
281
+ required
282
+ title='asdasd'
283
+ style={{ width: "100%", maxWidth: "100%" }}
284
+ />
285
+ </div>
286
+ <NSButtonBlue
287
+ onClick={() => { }}
288
+ title='sssssssssss'
289
+ disabled
290
+ />
291
+ <NSBarAlert
292
+ isVisible={() => true}
293
+ onContinue={() => window.open("/")}
294
+ title={
295
+ {
296
+ title: "Verify Your Email",
297
+ description: "Lorem ipsum dolor sit amet consectetur. In ipsum gravida libero vitae tempor.Ipsum"
298
+ }
299
+ }
300
+ />
301
+ <NSCard
302
+ title="Namirasoft Job Arranger "
303
+ description="asdasd asda sd asd asdd asd "
304
+ image={{
305
+ src: "https://static.namirasoft.com/image/namirasoft/history/logo/base.png",
306
+ }}
307
+ link={{
308
+ href: "ss",
309
+ title: "test",
310
+ target: "_seld"
311
+ }}
312
+ />
313
+
314
+ <div className="flex justify-content-center align-items-center w-100">
315
+ <NSChartDoughnut
316
+ datas={[7, 5, 8, 22, 5, 18]}
317
+ labels={["test", "test2", "test3", "test4", "test5", "test6",]}
318
+ backgroundColors={["#FF5733",
319
+ "#42A5F5",
320
+ "#FFC107",
321
+ "#8BC34A",
322
+ "#FF5722",
323
+ "#673AB7",
324
+ "#E91E63",
325
+ "#4CAF50",
326
+ "#FF9800",
327
+ "#9C27B0",
328
+ "#2196F3",
329
+ "#FFEB3B",
330
+ "#FF4081",
331
+ "#00BCD4",
332
+ "#CDDC39",]}
333
+ title='test'
334
+ />
335
+ </div>
336
+ <NSBoxBoolean
337
+ required={false}
338
+ title='test'
339
+ checked={true}
340
+
341
+ />
342
+ <div className='out'>
343
+ <div className="middle">
344
+ <div className='in'></div>
345
+ </div>
346
+ </div>
347
+ <NSDownTimer
348
+ date={new Date()}
349
+ text='Test '
350
+ />
351
+ <NSBoxBooleans
352
+ items={[
353
+ { value: "test1", text: "test1" },
354
+ { value: "test2", text: "test2" },
355
+ { value: "test3", text: "test3" },
356
+ ]}
357
+ onChanged={(box) =>
358
+ {
359
+ console.log(box.getValues());
360
+ }}
361
+ />
362
+ {
363
+ state &&
364
+ <NSDialog
365
+ center_dialog
366
+ onClose={() => { setState(false) }}
367
+ >
368
+ <></>
369
+ </NSDialog>
370
+ }
371
+ </>
372
+ );
373
373
  }