namirasoft-site-react 1.4.91 → 1.4.93

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 (273) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +70 -70
  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 +98 -98
  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 +53 -53
  20. package/dist/components/NSBoxDateTime.module.css +48 -48
  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/NSProductList.js +1 -1
  62. package/dist/components/NSProductList.js.map +1 -1
  63. package/dist/components/NSRadioButton.d.ts +25 -0
  64. package/dist/components/NSRadioButton.js +49 -0
  65. package/dist/components/NSRadioButton.js.map +1 -0
  66. package/dist/components/NSRange.module.css +66 -66
  67. package/dist/components/NSRepeater.d.ts +1 -1
  68. package/dist/components/NSRepeater.js +3 -5
  69. package/dist/components/NSRepeater.js.map +1 -1
  70. package/dist/components/NSSection.module.css +10 -10
  71. package/dist/components/NSSectionBars.module.css +10 -10
  72. package/dist/components/NSSectionCards.module.css +38 -38
  73. package/dist/components/NSTabPage.module.css +59 -59
  74. package/dist/components/NSTable.module.css +291 -291
  75. package/dist/components/NSTag.module.css +52 -52
  76. package/dist/components/NSTimeTable.module.css +6 -6
  77. package/dist/components/NSTimelineMonthly.module.css +71 -71
  78. package/dist/components/NSTitle.module.css +15 -15
  79. package/dist/index.css +6 -0
  80. package/dist/pages/NSNotFoundPage.module.css +17 -17
  81. package/dist/pages/NSUpdating.module.css +35 -35
  82. package/package.json +72 -72
  83. package/public/index.html +38 -38
  84. package/src/App.css +57 -57
  85. package/src/App.tsx +406 -406
  86. package/src/Color.tsx +10 -10
  87. package/src/CopyToClipboard.ts +6 -6
  88. package/src/Validator.ts +117 -117
  89. package/src/components/NSAccordion.module.css +4 -4
  90. package/src/components/NSAccordion.tsx +51 -51
  91. package/src/components/NSActionMenu.module.css +98 -98
  92. package/src/components/NSActionMenu.tsx +90 -90
  93. package/src/components/NSAssistantButton.module.css +135 -135
  94. package/src/components/NSAssistantButton.tsx +70 -70
  95. package/src/components/NSBarAction.module.css +97 -97
  96. package/src/components/NSBarAction.tsx +89 -89
  97. package/src/components/NSBarAlert.module.css +69 -69
  98. package/src/components/NSBarAlert.tsx +30 -30
  99. package/src/components/NSBarHeroBanner.module.css +42 -42
  100. package/src/components/NSBarHeroBanner.tsx +61 -61
  101. package/src/components/NSBarNotification.module.css +34 -34
  102. package/src/components/NSBarNotification.tsx +87 -87
  103. package/src/components/NSBarTitle.module.css +9 -9
  104. package/src/components/NSBarTitle.tsx +29 -29
  105. package/src/components/NSBox.module.css +126 -126
  106. package/src/components/NSBoxBoolean.module.css +88 -88
  107. package/src/components/NSBoxBoolean.tsx +124 -124
  108. package/src/components/NSBoxBooleans.tsx +159 -159
  109. package/src/components/NSBoxCombo.module.css +6 -6
  110. package/src/components/NSBoxCombo.tsx +151 -151
  111. package/src/components/NSBoxCopy.module.css +43 -43
  112. package/src/components/NSBoxCopy.tsx +41 -41
  113. package/src/components/NSBoxDate.module.css +53 -53
  114. package/src/components/NSBoxDate.tsx +88 -88
  115. package/src/components/NSBoxDateTime.module.css +48 -48
  116. package/src/components/NSBoxDateTime.tsx +89 -89
  117. package/src/components/NSBoxDouble.tsx +92 -92
  118. package/src/components/NSBoxDuration.tsx +92 -92
  119. package/src/components/NSBoxEmail.tsx +103 -103
  120. package/src/components/NSBoxEntity.module.css +21 -21
  121. package/src/components/NSBoxEntity.tsx +197 -197
  122. package/src/components/NSBoxEnum.tsx +55 -55
  123. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  124. package/src/components/NSBoxErrorNotifier.tsx +32 -32
  125. package/src/components/NSBoxFile.module.css +4 -4
  126. package/src/components/NSBoxFile.tsx +124 -124
  127. package/src/components/NSBoxIPV4.tsx +97 -97
  128. package/src/components/NSBoxIPV6.tsx +94 -94
  129. package/src/components/NSBoxInteger.tsx +94 -94
  130. package/src/components/NSBoxLabel.module.css +14 -14
  131. package/src/components/NSBoxLabel.tsx +29 -29
  132. package/src/components/NSBoxPassword.tsx +90 -90
  133. package/src/components/NSBoxPhone.tsx +97 -97
  134. package/src/components/NSBoxPrice.tsx +92 -92
  135. package/src/components/NSBoxRadio.module.css +70 -70
  136. package/src/components/NSBoxRadio.tsx +111 -111
  137. package/src/components/NSBoxSearch.tsx +107 -107
  138. package/src/components/NSBoxString.tsx +106 -106
  139. package/src/components/NSBoxTextArea.module.css +83 -83
  140. package/src/components/NSBoxTextArea.tsx +112 -112
  141. package/src/components/NSBoxTime.tsx +92 -92
  142. package/src/components/NSButton.module.css +42 -42
  143. package/src/components/NSButton.tsx +25 -25
  144. package/src/components/NSButtonBlue.module.css +4 -4
  145. package/src/components/NSButtonBlue.tsx +19 -19
  146. package/src/components/NSButtonGreen.module.css +4 -4
  147. package/src/components/NSButtonGreen.tsx +19 -19
  148. package/src/components/NSButtonRed.module.css +4 -4
  149. package/src/components/NSButtonRed.tsx +19 -19
  150. package/src/components/NSCard.module.css +114 -114
  151. package/src/components/NSCard.tsx +63 -63
  152. package/src/components/NSCardScreenshot.module.css +41 -41
  153. package/src/components/NSCardScreenshot.tsx +31 -31
  154. package/src/components/NSChartColumn.module.css +7 -7
  155. package/src/components/NSChartColumn.tsx +106 -106
  156. package/src/components/NSChartDoughnut.tsx +108 -108
  157. package/src/components/NSChartPie.tsx +105 -105
  158. package/src/components/NSChartRange.tsx +16 -16
  159. package/src/components/NSChartTable.module.css +21 -21
  160. package/src/components/NSChartTable.tsx +94 -94
  161. package/src/components/NSCopy.tsx +67 -67
  162. package/src/components/NSDeleteDialog.tsx +26 -26
  163. package/src/components/NSDialog.module.css +106 -106
  164. package/src/components/NSDialog.tsx +47 -47
  165. package/src/components/NSDownTimer.module.css +55 -55
  166. package/src/components/NSDownTimer.tsx +77 -77
  167. package/src/components/NSDownload.module.css +46 -46
  168. package/src/components/NSDownload.tsx +62 -62
  169. package/src/components/NSElectronicCard.module.css +60 -60
  170. package/src/components/NSElectronicCard.tsx +45 -45
  171. package/src/components/NSEntityBar.module.css +77 -77
  172. package/src/components/NSEntityBar.tsx +27 -27
  173. package/src/components/NSEntityCardBackground.module.css +27 -27
  174. package/src/components/NSEntityCardBackground.tsx +34 -34
  175. package/src/components/NSFilterBox.module.css +62 -62
  176. package/src/components/NSFilterBox.tsx +352 -352
  177. package/src/components/NSFilterBoxDialog.module.css +36 -36
  178. package/src/components/NSFilterBoxDialog.tsx +74 -74
  179. package/src/components/NSFilterItem.module.css +23 -23
  180. package/src/components/NSFilterItem.tsx +73 -73
  181. package/src/components/NSFooter.module.css +123 -123
  182. package/src/components/NSFooter.tsx +289 -289
  183. package/src/components/NSGroupedList.module.css +72 -72
  184. package/src/components/NSGroupedList.tsx +115 -115
  185. package/src/components/NSHeader.module.css +291 -291
  186. package/src/components/NSHeader.tsx +250 -250
  187. package/src/components/NSHeaderScreenshot.module.css +35 -35
  188. package/src/components/NSHeaderScreenshot.tsx +38 -38
  189. package/src/components/NSInfoDialog.tsx +36 -36
  190. package/src/components/NSLayout.module.css +13 -13
  191. package/src/components/NSLayout.tsx +109 -109
  192. package/src/components/NSLine.module.css +12 -12
  193. package/src/components/NSLine.tsx +15 -15
  194. package/src/components/NSLink.module.css +36 -36
  195. package/src/components/NSLink.tsx +25 -25
  196. package/src/components/NSLinkBlue.tsx +20 -20
  197. package/src/components/NSLinkGreen.tsx +5 -5
  198. package/src/components/NSLinkRed.tsx +5 -5
  199. package/src/components/NSLoading.module.css +30 -30
  200. package/src/components/NSLoading.tsx +20 -20
  201. package/src/components/NSNoData.module.css +8 -8
  202. package/src/components/NSNoData.tsx +24 -24
  203. package/src/components/NSPageSelectionModal.module.css +103 -103
  204. package/src/components/NSPageSelectionModal.tsx +228 -228
  205. package/src/components/NSPagination.module.css +110 -110
  206. package/src/components/NSPagination.tsx +191 -191
  207. package/src/components/NSPanel.module.css +46 -46
  208. package/src/components/NSPanel.tsx +19 -19
  209. package/src/components/NSProductList.tsx +43 -43
  210. package/src/components/NSRange.module.css +66 -66
  211. package/src/components/NSRange.tsx +81 -81
  212. package/src/components/NSRepeater.tsx +173 -175
  213. package/src/components/NSSection.module.css +10 -10
  214. package/src/components/NSSection.tsx +23 -23
  215. package/src/components/NSSectionBars.module.css +10 -10
  216. package/src/components/NSSectionBars.tsx +25 -25
  217. package/src/components/NSSectionCards.module.css +38 -38
  218. package/src/components/NSSectionCards.tsx +51 -51
  219. package/src/components/NSSectionTitle.tsx +21 -21
  220. package/src/components/NSSpace.tsx +28 -28
  221. package/src/components/NSTabPage.module.css +59 -59
  222. package/src/components/NSTabPage.tsx +78 -78
  223. package/src/components/NSTable.module.css +291 -291
  224. package/src/components/NSTable.tsx +439 -439
  225. package/src/components/NSTag.module.css +52 -52
  226. package/src/components/NSTag.tsx +73 -73
  227. package/src/components/NSTimeTable.module.css +6 -6
  228. package/src/components/NSTimeTable.tsx +49 -49
  229. package/src/components/NSTimelineMonthly.module.css +71 -71
  230. package/src/components/NSTimelineMonthly.tsx +42 -42
  231. package/src/components/NSTitle.module.css +15 -15
  232. package/src/components/NSTitle.tsx +19 -19
  233. package/src/formatter/BackColorFormatter.tsx +20 -20
  234. package/src/formatter/BaseColumnFormatter.ts +14 -14
  235. package/src/formatter/BooleanFormatter.ts +20 -20
  236. package/src/formatter/DateFormatter.ts +15 -15
  237. package/src/formatter/DateTimeFormatter.ts +15 -15
  238. package/src/formatter/DurationFormatter.ts +8 -8
  239. package/src/formatter/EmailFormatter.ts +8 -8
  240. package/src/formatter/EnumFormatter.ts +8 -8
  241. package/src/formatter/FloatFormatter.ts +8 -8
  242. package/src/formatter/ForeColorFormatter.tsx +20 -20
  243. package/src/formatter/ForeignIDFormatter.ts +8 -8
  244. package/src/formatter/IDFormatter.ts +8 -8
  245. package/src/formatter/IPFormatter.ts +8 -8
  246. package/src/formatter/IntegerFormatter.ts +8 -8
  247. package/src/formatter/JsonFormatter.ts +8 -8
  248. package/src/formatter/MoneyFormatter.ts +8 -8
  249. package/src/formatter/PhoneFormatter.ts +8 -8
  250. package/src/formatter/StringFormatter.ts +8 -8
  251. package/src/formatter/TimeFormatter.ts +16 -16
  252. package/src/formatter/UnknowFormatter.ts +8 -8
  253. package/src/index.tsx +7 -7
  254. package/src/main.ts +118 -118
  255. package/src/pages/NSNotFoundPage.module.css +17 -17
  256. package/src/pages/NSNotFoundPage.tsx +11 -11
  257. package/src/pages/NSUpdating.module.css +35 -35
  258. package/src/pages/NSUpdating.tsx +32 -32
  259. package/src/props/IBaseComponentProps.ts +8 -8
  260. package/src/props/IHeaderIconProps.ts +10 -10
  261. package/src/props/IHeaderProps.ts +7 -7
  262. package/src/props/IImageProps.ts +4 -4
  263. package/src/props/ILinkProps.ts +5 -5
  264. package/src/props/IValidationNumberProps.ts +4 -4
  265. package/src/props/IValidationProps.ts +7 -7
  266. package/src/props/IValidationRegexProps.ts +4 -4
  267. package/src/props/IValidationStringProps.ts +4 -4
  268. package/src/routing/INSRouterMaker.ts +6 -6
  269. package/src/routing/INSRouterProps.ts +5 -5
  270. package/src/routing/INSRouterState.ts +5 -5
  271. package/src/routing/NSRouterMaker.tsx +33 -33
  272. package/src/routing/Notifier.ts +79 -79
  273. package/tsconfig.json +43 -43
@@ -1,106 +1,106 @@
1
- /* eslint-disable @typescript-eslint/no-unused-vars */
2
- import { Pie } from 'react-chartjs-2';
3
- import { Chart as ChartJS, ArcElement, Tooltip, Legend, Title, SubTitle, CategoryScale, LinearScale, BarElement, PointElement, LineElement, ChartData, Plugin, ArcElement as ArcElementType } from 'chart.js';
4
- import { IBaseComponentProps } from '../props/IBaseComponentProps';
5
-
6
- ChartJS.register(ArcElement, Tooltip, Legend, Title, SubTitle, CategoryScale, LinearScale, BarElement, PointElement, LineElement);
7
- export interface NSChartPieProps extends IBaseComponentProps
8
- {
9
- title?: string;
10
- datas: number[];
11
- labels: string[];
12
- backgroundColors?: string[];
13
- borderWidth?: number;
14
- }
15
- export function NSChartPie(props: NSChartPieProps)
16
- {
17
- let backgroundColors: string[] = [""];
18
- const options = {
19
- responsive: true,
20
- plugins: {
21
- legend: {
22
- display: true,
23
- responsive: true,
24
- position: 'left' as 'top',
25
- labels: {
26
- useBorderRadius: true,
27
- borderRadius: 100,
28
- boxWidth: 16,
29
- color: 'hsla(250, 87%, 29%, 1)',
30
- },
31
- },
32
- tooltip: {
33
- enabled: true,
34
- titleFont: {
35
- size: 12
36
- },
37
- bodyFont: {
38
- size: 12
39
- },
40
- },
41
- },
42
- animation: {
43
- animateScale: true,
44
- }
45
- };
46
-
47
- const generateRandomColor = (): string =>
48
- {
49
- let maxVal = 0xFFFFFF;
50
- let randomNumber: number = Math.random() * maxVal;
51
- randomNumber = Math.floor(randomNumber);
52
- let X: string = randomNumber.toString(16);
53
- let randomColor: string = X.padStart(6, "0");
54
- return `#${randomColor.toUpperCase()}`
55
- }
56
-
57
- const setRandomColor = (): string[] =>
58
- {
59
- props.datas.forEach(() => backgroundColors?.push(generateRandomColor()))
60
- return backgroundColors;
61
- }
62
-
63
- const data: ChartData<'pie'> = {
64
- labels: props.labels,
65
- datasets: [
66
- {
67
- data: props.datas,
68
- backgroundColor: props.backgroundColors ?? setRandomColor(),
69
- borderColor: props.backgroundColors ?? setRandomColor(),
70
- borderWidth: props.borderWidth ?? 1
71
- }
72
- ]
73
- };
74
- const centerTitlePlugin: Plugin<'pie'> = {
75
- id: 'centerTitle',
76
- afterDraw(chart)
77
- {
78
- const { ctx, chartArea: { width, height } } = chart;
79
- const meta = chart.getDatasetMeta(0);
80
- const arc = meta.data[0] as unknown as ArcElementType;
81
-
82
- ctx.save();
83
- const fontSize = arc.innerRadius / 3;
84
- ctx.font = fontSize.toString() + "px";
85
- ctx.fillStyle = 'hsla(234, 64%, 22%, 1)';
86
- ctx.textBaseline = 'middle';
87
- ctx.textAlign = 'center';
88
-
89
- const text = props.title ?? "";
90
- const centerX = (arc.x || width / 2);
91
- const centerY = (arc.y || height / 2);
92
-
93
- ctx.fillText(text, centerX, centerY);
94
- ctx.restore();
95
- }
96
- };
97
- return (
98
- <div className={`${props.classList?.join(" ")} `} style={props.style}>
99
- <Pie
100
- data={data}
101
- options={options}
102
- plugins={[centerTitlePlugin]}
103
- />
104
- </div>
105
- );
1
+ /* eslint-disable @typescript-eslint/no-unused-vars */
2
+ import { Pie } from 'react-chartjs-2';
3
+ import { Chart as ChartJS, ArcElement, Tooltip, Legend, Title, SubTitle, CategoryScale, LinearScale, BarElement, PointElement, LineElement, ChartData, Plugin, ArcElement as ArcElementType } from 'chart.js';
4
+ import { IBaseComponentProps } from '../props/IBaseComponentProps';
5
+
6
+ ChartJS.register(ArcElement, Tooltip, Legend, Title, SubTitle, CategoryScale, LinearScale, BarElement, PointElement, LineElement);
7
+ export interface NSChartPieProps extends IBaseComponentProps
8
+ {
9
+ title?: string;
10
+ datas: number[];
11
+ labels: string[];
12
+ backgroundColors?: string[];
13
+ borderWidth?: number;
14
+ }
15
+ export function NSChartPie(props: NSChartPieProps)
16
+ {
17
+ let backgroundColors: string[] = [""];
18
+ const options = {
19
+ responsive: true,
20
+ plugins: {
21
+ legend: {
22
+ display: true,
23
+ responsive: true,
24
+ position: 'left' as 'top',
25
+ labels: {
26
+ useBorderRadius: true,
27
+ borderRadius: 100,
28
+ boxWidth: 16,
29
+ color: 'hsla(250, 87%, 29%, 1)',
30
+ },
31
+ },
32
+ tooltip: {
33
+ enabled: true,
34
+ titleFont: {
35
+ size: 12
36
+ },
37
+ bodyFont: {
38
+ size: 12
39
+ },
40
+ },
41
+ },
42
+ animation: {
43
+ animateScale: true,
44
+ }
45
+ };
46
+
47
+ const generateRandomColor = (): string =>
48
+ {
49
+ let maxVal = 0xFFFFFF;
50
+ let randomNumber: number = Math.random() * maxVal;
51
+ randomNumber = Math.floor(randomNumber);
52
+ let X: string = randomNumber.toString(16);
53
+ let randomColor: string = X.padStart(6, "0");
54
+ return `#${randomColor.toUpperCase()}`
55
+ }
56
+
57
+ const setRandomColor = (): string[] =>
58
+ {
59
+ props.datas.forEach(() => backgroundColors?.push(generateRandomColor()))
60
+ return backgroundColors;
61
+ }
62
+
63
+ const data: ChartData<'pie'> = {
64
+ labels: props.labels,
65
+ datasets: [
66
+ {
67
+ data: props.datas,
68
+ backgroundColor: props.backgroundColors ?? setRandomColor(),
69
+ borderColor: props.backgroundColors ?? setRandomColor(),
70
+ borderWidth: props.borderWidth ?? 1
71
+ }
72
+ ]
73
+ };
74
+ const centerTitlePlugin: Plugin<'pie'> = {
75
+ id: 'centerTitle',
76
+ afterDraw(chart)
77
+ {
78
+ const { ctx, chartArea: { width, height } } = chart;
79
+ const meta = chart.getDatasetMeta(0);
80
+ const arc = meta.data[0] as unknown as ArcElementType;
81
+
82
+ ctx.save();
83
+ const fontSize = arc.innerRadius / 3;
84
+ ctx.font = fontSize.toString() + "px";
85
+ ctx.fillStyle = 'hsla(234, 64%, 22%, 1)';
86
+ ctx.textBaseline = 'middle';
87
+ ctx.textAlign = 'center';
88
+
89
+ const text = props.title ?? "";
90
+ const centerX = (arc.x || width / 2);
91
+ const centerY = (arc.y || height / 2);
92
+
93
+ ctx.fillText(text, centerX, centerY);
94
+ ctx.restore();
95
+ }
96
+ };
97
+ return (
98
+ <div className={`${props.classList?.join(" ")} `} style={props.style}>
99
+ <Pie
100
+ data={data}
101
+ options={options}
102
+ plugins={[centerTitlePlugin]}
103
+ />
104
+ </div>
105
+ );
106
106
  }
@@ -1,17 +1,17 @@
1
- import Styles from './NSChartRange.module.css';
2
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
-
4
-
5
- export interface INSNSChartRangeProps extends IBaseComponentProps
6
- {
7
- }
8
-
9
- export function NSChartRange(props: INSNSChartRangeProps)
10
- {
11
- console.log(props)
12
- return (
13
- <div className={Styles.ns_parent}>
14
-
15
- </div>
16
- );
1
+ import Styles from './NSChartRange.module.css';
2
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
+
4
+
5
+ export interface INSNSChartRangeProps extends IBaseComponentProps
6
+ {
7
+ }
8
+
9
+ export function NSChartRange(props: INSNSChartRangeProps)
10
+ {
11
+ console.log(props)
12
+ return (
13
+ <div className={Styles.ns_parent}>
14
+
15
+ </div>
16
+ );
17
17
  }
@@ -1,22 +1,22 @@
1
- .custom_row td {
2
- border: none;
3
- }
4
-
5
- .custom_row td:nth-child(2),
6
- .custom_row td:nth-child(3),
7
- .custom_row td:nth-child(4),
8
- .custom_row td:nth-child(5),
9
- .custom_row td:nth-child(6) {
10
- border-bottom: 1px dashed #d9d9d9;
11
- }
12
-
13
- /* Override default Ant Design row borders */
14
- .ant-table-tbody>tr>td {
15
- border-bottom: none !important;
16
- }
17
-
18
- /* Increase progress bar height */
19
- .ant-progress {
20
- height: 16px !important;
21
- /* Adjust as needed */
1
+ .custom_row td {
2
+ border: none;
3
+ }
4
+
5
+ .custom_row td:nth-child(2),
6
+ .custom_row td:nth-child(3),
7
+ .custom_row td:nth-child(4),
8
+ .custom_row td:nth-child(5),
9
+ .custom_row td:nth-child(6) {
10
+ border-bottom: 1px dashed #d9d9d9;
11
+ }
12
+
13
+ /* Override default Ant Design row borders */
14
+ .ant-table-tbody>tr>td {
15
+ border-bottom: none !important;
16
+ }
17
+
18
+ /* Increase progress bar height */
19
+ .ant-progress {
20
+ height: 16px !important;
21
+ /* Adjust as needed */
22
22
  }
@@ -1,95 +1,95 @@
1
- import { Table, Progress } from 'antd';
2
- import { ColumnType } from 'antd/es/table';
3
- import { IBaseComponentProps } from '../props/IBaseComponentProps';
4
- import Styles from "./NSChartTable.module.css"
5
-
6
- interface DataType
7
- {
8
- key: string;
9
- job: string;
10
- totalHours: number;
11
- percentage: number;
12
- cost: number;
13
- income: number;
14
- benefit: number;
15
- }
16
-
17
- interface CustomTableProps extends IBaseComponentProps
18
- {
19
- data: DataType[];
20
- }
21
-
22
- export function NSChartTable(props: CustomTableProps)
23
- {
24
- const getColor = (percentage: number) =>
25
- {
26
- if (percentage >= 75) return '#368F01';
27
- if (percentage >= 60) return ' #44B400';
28
- if (percentage >= 50) return '#56E500';
29
- if (percentage >= 25) return '#FAFF00';
30
- return 'red';
31
- };
32
-
33
- const columns: ColumnType<DataType>[] = [
34
- {
35
- title: '',
36
- dataIndex: 'job',
37
- key: 'job',
38
- },
39
- {
40
- title: 'Total Hours',
41
- dataIndex: 'totalHours',
42
- key: 'totalHours',
43
- render: (text: number) => <div>{text}</div>,
44
- },
45
- {
46
- title: 'Percentage',
47
- dataIndex: 'percentage',
48
- key: 'percentage',
49
- render: (text: number) => <div>{text}%</div>,
50
- },
51
- {
52
- title: 'Cost',
53
- dataIndex: 'cost',
54
- key: 'cost',
55
- render: (text: number) => <div>${text}</div>,
56
- },
57
- {
58
- title: 'Income',
59
- dataIndex: 'income',
60
- key: 'income',
61
- render: (text: number) => <div>${text}</div>,
62
- },
63
- {
64
- title: 'Benefit',
65
- dataIndex: 'benefit',
66
- key: 'benefit',
67
- render: (text: number) => <div>${text}</div>,
68
- },
69
- {
70
- title: '',
71
- dataIndex: 'totalHours',
72
- key: 'chart',
73
- render: (totalHours: number, record: DataType) => (
74
- <Progress
75
- percent={(totalHours / 8) * 100}
76
- showInfo={false}
77
- strokeColor={getColor(record.percentage)}
78
- size={{ width: 310, height: 16 }}
79
- />
80
- ),
81
- },
82
- ];
83
-
84
- return (
85
- <div className={`${props.classList?.join(" ")}`} style={props.style}>
86
- <Table
87
- columns={columns}
88
- dataSource={props.data}
89
- pagination={false}
90
- scroll={{ x: 800 }}
91
- rowClassName={() => Styles.custom_row}
92
- />
93
- </div>
94
- );
1
+ import { Table, Progress } from 'antd';
2
+ import { ColumnType } from 'antd/es/table';
3
+ import { IBaseComponentProps } from '../props/IBaseComponentProps';
4
+ import Styles from "./NSChartTable.module.css"
5
+
6
+ interface DataType
7
+ {
8
+ key: string;
9
+ job: string;
10
+ totalHours: number;
11
+ percentage: number;
12
+ cost: number;
13
+ income: number;
14
+ benefit: number;
15
+ }
16
+
17
+ interface CustomTableProps extends IBaseComponentProps
18
+ {
19
+ data: DataType[];
20
+ }
21
+
22
+ export function NSChartTable(props: CustomTableProps)
23
+ {
24
+ const getColor = (percentage: number) =>
25
+ {
26
+ if (percentage >= 75) return '#368F01';
27
+ if (percentage >= 60) return ' #44B400';
28
+ if (percentage >= 50) return '#56E500';
29
+ if (percentage >= 25) return '#FAFF00';
30
+ return 'red';
31
+ };
32
+
33
+ const columns: ColumnType<DataType>[] = [
34
+ {
35
+ title: '',
36
+ dataIndex: 'job',
37
+ key: 'job',
38
+ },
39
+ {
40
+ title: 'Total Hours',
41
+ dataIndex: 'totalHours',
42
+ key: 'totalHours',
43
+ render: (text: number) => <div>{text}</div>,
44
+ },
45
+ {
46
+ title: 'Percentage',
47
+ dataIndex: 'percentage',
48
+ key: 'percentage',
49
+ render: (text: number) => <div>{text}%</div>,
50
+ },
51
+ {
52
+ title: 'Cost',
53
+ dataIndex: 'cost',
54
+ key: 'cost',
55
+ render: (text: number) => <div>${text}</div>,
56
+ },
57
+ {
58
+ title: 'Income',
59
+ dataIndex: 'income',
60
+ key: 'income',
61
+ render: (text: number) => <div>${text}</div>,
62
+ },
63
+ {
64
+ title: 'Benefit',
65
+ dataIndex: 'benefit',
66
+ key: 'benefit',
67
+ render: (text: number) => <div>${text}</div>,
68
+ },
69
+ {
70
+ title: '',
71
+ dataIndex: 'totalHours',
72
+ key: 'chart',
73
+ render: (totalHours: number, record: DataType) => (
74
+ <Progress
75
+ percent={(totalHours / 8) * 100}
76
+ showInfo={false}
77
+ strokeColor={getColor(record.percentage)}
78
+ size={{ width: 310, height: 16 }}
79
+ />
80
+ ),
81
+ },
82
+ ];
83
+
84
+ return (
85
+ <div className={`${props.classList?.join(" ")}`} style={props.style}>
86
+ <Table
87
+ columns={columns}
88
+ dataSource={props.data}
89
+ pagination={false}
90
+ scroll={{ x: 800 }}
91
+ rowClassName={() => Styles.custom_row}
92
+ />
93
+ </div>
94
+ );
95
95
  };
@@ -1,68 +1,68 @@
1
- import React, { useRef, useState } from "react";
2
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
-
4
- export interface NSCopyProps extends IBaseComponentProps
5
- {
6
- children: React.ReactNode;
7
- }
8
- export interface NSCopyState
9
- {
10
- copied: boolean;
11
- }
12
-
13
- export function NSCopy(props: NSCopyProps)
14
- {
15
- let NSCopyParent_ref = useRef<HTMLDivElement>(null);
16
-
17
- let [state, setState] = useState<NSCopyState>({
18
- copied: false
19
- })
20
-
21
- function onCopy(e: React.MouseEvent<HTMLImageElement>): void
22
- {
23
- e.stopPropagation();
24
- setState({ copied: true });
25
- setTimeout(() =>
26
- {
27
- setState({ copied: false });
28
- }, 3000);
29
-
30
- if (NSCopyParent_ref.current)
31
- navigator.clipboard.writeText(NSCopyParent_ref.current?.innerText);
32
- }
33
-
34
- return (
35
- <div
36
- ref={NSCopyParent_ref}
37
- id={props.id}
38
- className={`d-flex align-items-center justify-content-center ${props.classList?.join(" ")}`}
39
- style={props.style}
40
- >
41
- <div>
42
- {props.children}
43
- </div>
44
- {
45
- state.copied
46
- ? <img src={"https://static.namirasoft.com/image/concept/check/on/blue.svg"}
47
- alt='Copied'
48
- width={16}
49
- height={16}
50
- style={{
51
- marginLeft: "8px"
52
- }}
53
- />
54
- : <img
55
- src='https://static.namirasoft.com/image/concept/copy/blue.svg'
56
- alt='Copy_Button'
57
- width={16}
58
- height={16}
59
- onClick={onCopy}
60
- style={{
61
- cursor: "pointer",
62
- marginLeft: "8px"
63
- }}
64
- />
65
- }
66
- </div>
67
- );
1
+ import React, { useRef, useState } from "react";
2
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
+
4
+ export interface NSCopyProps extends IBaseComponentProps
5
+ {
6
+ children: React.ReactNode;
7
+ }
8
+ export interface NSCopyState
9
+ {
10
+ copied: boolean;
11
+ }
12
+
13
+ export function NSCopy(props: NSCopyProps)
14
+ {
15
+ let NSCopyParent_ref = useRef<HTMLDivElement>(null);
16
+
17
+ let [state, setState] = useState<NSCopyState>({
18
+ copied: false
19
+ })
20
+
21
+ function onCopy(e: React.MouseEvent<HTMLImageElement>): void
22
+ {
23
+ e.stopPropagation();
24
+ setState({ copied: true });
25
+ setTimeout(() =>
26
+ {
27
+ setState({ copied: false });
28
+ }, 3000);
29
+
30
+ if (NSCopyParent_ref.current)
31
+ navigator.clipboard.writeText(NSCopyParent_ref.current?.innerText);
32
+ }
33
+
34
+ return (
35
+ <div
36
+ ref={NSCopyParent_ref}
37
+ id={props.id}
38
+ className={`d-flex align-items-center justify-content-center ${props.classList?.join(" ")}`}
39
+ style={props.style}
40
+ >
41
+ <div>
42
+ {props.children}
43
+ </div>
44
+ {
45
+ state.copied
46
+ ? <img src={"https://static.namirasoft.com/image/concept/check/on/blue.svg"}
47
+ alt='Copied'
48
+ width={16}
49
+ height={16}
50
+ style={{
51
+ marginLeft: "8px"
52
+ }}
53
+ />
54
+ : <img
55
+ src='https://static.namirasoft.com/image/concept/copy/blue.svg'
56
+ alt='Copy_Button'
57
+ width={16}
58
+ height={16}
59
+ onClick={onCopy}
60
+ style={{
61
+ cursor: "pointer",
62
+ marginLeft: "8px"
63
+ }}
64
+ />
65
+ }
66
+ </div>
67
+ );
68
68
  }
@@ -1,27 +1,27 @@
1
- import { NSInfoDialog, NSInfoDialogProps } from './NSInfoDialog';
2
- import { NSButtonGreen } from "./NSButtonGreen";
3
- import { NSButtonRed } from "./NSButtonRed";
4
- import { NSSpace, NSSpaceSizeType } from "./NSSpace";
5
-
6
- export interface NSDeleteDialogProps extends NSInfoDialogProps
7
- {
8
- onYes: () => void;
9
- onNo: () => void;
10
- }
11
-
12
- export function NSDeleteDialog(props: NSDeleteDialogProps)
13
- {
14
- return (
15
- <NSInfoDialog {...props}
16
- onClose={props.onNo}
17
- >
18
- {props.children}
19
- <NSSpace size={NSSpaceSizeType.MINI}></NSSpace>
20
- <div>
21
- <NSButtonGreen title="Yes" onClick={props.onYes} />
22
- <NSSpace size={NSSpaceSizeType.MICRO}></NSSpace>
23
- <NSButtonRed title="No" onClick={props.onNo} />
24
- </div>
25
- </NSInfoDialog>
26
- );
1
+ import { NSInfoDialog, NSInfoDialogProps } from './NSInfoDialog';
2
+ import { NSButtonGreen } from "./NSButtonGreen";
3
+ import { NSButtonRed } from "./NSButtonRed";
4
+ import { NSSpace, NSSpaceSizeType } from "./NSSpace";
5
+
6
+ export interface NSDeleteDialogProps extends NSInfoDialogProps
7
+ {
8
+ onYes: () => void;
9
+ onNo: () => void;
10
+ }
11
+
12
+ export function NSDeleteDialog(props: NSDeleteDialogProps)
13
+ {
14
+ return (
15
+ <NSInfoDialog {...props}
16
+ onClose={props.onNo}
17
+ >
18
+ {props.children}
19
+ <NSSpace size={NSSpaceSizeType.MINI}></NSSpace>
20
+ <div>
21
+ <NSButtonGreen title="Yes" onClick={props.onYes} />
22
+ <NSSpace size={NSSpaceSizeType.MICRO}></NSSpace>
23
+ <NSButtonRed title="No" onClick={props.onNo} />
24
+ </div>
25
+ </NSInfoDialog>
26
+ );
27
27
  }