namirasoft-site-react 1.4.135 → 1.4.136

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 (259) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +72 -72
  5. package/dist/App.css +34 -0
  6. package/dist/components/NSBarAction.module.css +97 -97
  7. package/dist/components/NSBarAlert.module.css +69 -69
  8. package/dist/components/NSBarNotification.module.css +34 -34
  9. package/dist/components/NSBarTitle.module.css +9 -9
  10. package/dist/components/NSBox.module.css +50 -50
  11. package/dist/components/NSBoxBaseCombo.module.css +6 -6
  12. package/dist/components/NSBoxBoolean.module.css +67 -67
  13. package/dist/components/NSBoxDate.module.css +4 -4
  14. package/dist/components/NSBoxDateTime.module.css +4 -4
  15. package/dist/components/NSBoxDuration.module.css +4 -4
  16. package/dist/components/NSBoxFile.module.css +10 -10
  17. package/dist/components/NSBoxPhone.module.css +35 -35
  18. package/dist/components/NSBoxRadio.module.css +33 -33
  19. package/dist/components/NSBoxTextArea.module.css +12 -12
  20. package/dist/components/NSBoxTime.module.css +4 -4
  21. package/dist/components/NSButton.module.css +41 -41
  22. package/dist/components/NSButtonBlue.module.css +4 -4
  23. package/dist/components/NSButtonGreen.module.css +4 -4
  24. package/dist/components/NSButtonRed.module.css +4 -4
  25. package/dist/components/NSCard.module.css +114 -114
  26. package/dist/components/NSCardScreenshot.module.css +41 -41
  27. package/dist/components/NSChartColumn.module.css +7 -7
  28. package/dist/components/NSChartTable.module.css +21 -21
  29. package/dist/components/NSCopyBox.module.css +43 -43
  30. package/dist/components/NSDialog.module.css +110 -110
  31. package/dist/components/NSDialogPageSelection.module.css +103 -103
  32. package/dist/components/NSDownTimer.module.css +55 -55
  33. package/dist/components/NSDownload.module.css +46 -46
  34. package/dist/components/NSElectronicCard.module.css +60 -60
  35. package/dist/components/NSEntityCardBackground.module.css +27 -27
  36. package/dist/components/NSFilterBox.module.css +55 -55
  37. package/dist/components/NSFilterItem.module.css +23 -23
  38. package/dist/components/NSFooter.module.css +123 -123
  39. package/dist/components/NSHeader.module.css +291 -291
  40. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  41. package/dist/components/NSLabel.module.css +15 -15
  42. package/dist/components/NSLabelErrorNotifier.module.css +2 -2
  43. package/dist/components/NSLayout.module.css +13 -13
  44. package/dist/components/NSLine.module.css +12 -12
  45. package/dist/components/NSLink.module.css +36 -36
  46. package/dist/components/NSListGrouped.module.css +72 -72
  47. package/dist/components/NSLoading.module.css +30 -30
  48. package/dist/components/NSMenuAction.js +2 -2
  49. package/dist/components/NSMenuAction.module.css +78 -78
  50. package/dist/components/NSMenuButton.module.css +44 -44
  51. package/dist/components/NSNoData.module.css +9 -9
  52. package/dist/components/NSPagination.module.css +85 -85
  53. package/dist/components/NSPanel.module.css +46 -46
  54. package/dist/components/NSPanelAccordion.module.css +4 -4
  55. package/dist/components/NSRange.module.css +66 -66
  56. package/dist/components/NSSection.module.css +10 -10
  57. package/dist/components/NSSectionCards.module.css +38 -38
  58. package/dist/components/NSSectionTiles.module.css +10 -10
  59. package/dist/components/NSTabPage.module.css +59 -59
  60. package/dist/components/NSTable.module.css +261 -260
  61. package/dist/components/NSTag.module.css +52 -52
  62. package/dist/components/NSTile.module.css +77 -77
  63. package/dist/components/NSTimelineMonthly.module.css +71 -71
  64. package/dist/components/NSTitle.module.css +15 -15
  65. package/dist/formatter/UnknowFormatter.d.ts +2 -1
  66. package/dist/formatter/UnknowFormatter.js +4 -1
  67. package/dist/formatter/UnknowFormatter.js.map +1 -1
  68. package/dist/index.css +6 -0
  69. package/dist/pages/NSNotFoundPage.module.css +17 -17
  70. package/dist/pages/NSUpdating.module.css +35 -35
  71. package/package.json +76 -76
  72. package/public/index.html +38 -38
  73. package/src/App.css +33 -33
  74. package/src/App.tsx +225 -225
  75. package/src/Color.tsx +10 -10
  76. package/src/CopyToClipboard.ts +6 -6
  77. package/src/Validator.ts +125 -125
  78. package/src/components/NSBarAction.module.css +97 -97
  79. package/src/components/NSBarAction.tsx +91 -91
  80. package/src/components/NSBarAlert.module.css +69 -69
  81. package/src/components/NSBarAlert.tsx +31 -31
  82. package/src/components/NSBarNotification.module.css +34 -34
  83. package/src/components/NSBarNotification.tsx +89 -89
  84. package/src/components/NSBarTitle.module.css +9 -9
  85. package/src/components/NSBarTitle.tsx +29 -29
  86. package/src/components/NSBox.module.css +50 -50
  87. package/src/components/NSBoxBaseCombo.module.css +6 -6
  88. package/src/components/NSBoxBaseCombo.tsx +241 -241
  89. package/src/components/NSBoxBaseLayout.tsx +82 -82
  90. package/src/components/NSBoxBoolean.module.css +67 -67
  91. package/src/components/NSBoxBoolean.tsx +112 -112
  92. package/src/components/NSBoxBooleans.tsx +163 -163
  93. package/src/components/NSBoxCombo.tsx +63 -63
  94. package/src/components/NSBoxDate.module.css +4 -4
  95. package/src/components/NSBoxDate.tsx +86 -86
  96. package/src/components/NSBoxDateTime.module.css +4 -4
  97. package/src/components/NSBoxDateTime.tsx +86 -86
  98. package/src/components/NSBoxDouble.tsx +89 -89
  99. package/src/components/NSBoxDuration.module.css +4 -4
  100. package/src/components/NSBoxDuration.tsx +91 -91
  101. package/src/components/NSBoxEmail.tsx +96 -96
  102. package/src/components/NSBoxEntity.tsx +52 -52
  103. package/src/components/NSBoxEnum.tsx +66 -66
  104. package/src/components/NSBoxFile.module.css +10 -10
  105. package/src/components/NSBoxFile.tsx +111 -111
  106. package/src/components/NSBoxIPV4.tsx +91 -91
  107. package/src/components/NSBoxIPV6.tsx +88 -88
  108. package/src/components/NSBoxInteger.tsx +88 -88
  109. package/src/components/NSBoxMoney.tsx +87 -87
  110. package/src/components/NSBoxPassword.tsx +97 -97
  111. package/src/components/NSBoxPhone.module.css +35 -35
  112. package/src/components/NSBoxPhone.tsx +103 -103
  113. package/src/components/NSBoxRadio.module.css +33 -33
  114. package/src/components/NSBoxRadio.tsx +97 -97
  115. package/src/components/NSBoxSearch.tsx +86 -86
  116. package/src/components/NSBoxString.tsx +79 -79
  117. package/src/components/NSBoxTextArea.module.css +12 -12
  118. package/src/components/NSBoxTextArea.tsx +89 -89
  119. package/src/components/NSBoxTime.module.css +4 -4
  120. package/src/components/NSBoxTime.tsx +83 -83
  121. package/src/components/NSButton.module.css +41 -41
  122. package/src/components/NSButton.tsx +25 -25
  123. package/src/components/NSButtonBlue.module.css +4 -4
  124. package/src/components/NSButtonBlue.tsx +19 -19
  125. package/src/components/NSButtonGreen.module.css +4 -4
  126. package/src/components/NSButtonGreen.tsx +19 -19
  127. package/src/components/NSButtonRed.module.css +4 -4
  128. package/src/components/NSButtonRed.tsx +19 -19
  129. package/src/components/NSCard.module.css +114 -114
  130. package/src/components/NSCard.tsx +63 -63
  131. package/src/components/NSCardScreenshot.module.css +41 -41
  132. package/src/components/NSCardScreenshot.tsx +31 -31
  133. package/src/components/NSChartColumn.module.css +7 -7
  134. package/src/components/NSChartColumn.tsx +106 -106
  135. package/src/components/NSChartDoughnut.tsx +108 -108
  136. package/src/components/NSChartPie.tsx +105 -105
  137. package/src/components/NSChartRange.tsx +14 -14
  138. package/src/components/NSChartTable.module.css +21 -21
  139. package/src/components/NSChartTable.tsx +94 -94
  140. package/src/components/NSCopy.tsx +67 -67
  141. package/src/components/NSCopyBox.module.css +43 -43
  142. package/src/components/NSCopyBox.tsx +41 -41
  143. package/src/components/NSDialog.module.css +110 -110
  144. package/src/components/NSDialog.tsx +57 -57
  145. package/src/components/NSDialogDelete.tsx +26 -26
  146. package/src/components/NSDialogInfo.tsx +36 -36
  147. package/src/components/NSDialogPageSelection.module.css +103 -103
  148. package/src/components/NSDialogPageSelection.tsx +223 -223
  149. package/src/components/NSDownTimer.module.css +55 -55
  150. package/src/components/NSDownTimer.tsx +77 -77
  151. package/src/components/NSDownload.module.css +46 -46
  152. package/src/components/NSDownload.tsx +63 -63
  153. package/src/components/NSElectronicCard.module.css +60 -60
  154. package/src/components/NSElectronicCard.tsx +46 -46
  155. package/src/components/NSEntityCardBackground.module.css +27 -27
  156. package/src/components/NSEntityCardBackground.tsx +36 -36
  157. package/src/components/NSFilterBox.module.css +55 -55
  158. package/src/components/NSFilterBox.tsx +360 -360
  159. package/src/components/NSFilterItem.module.css +23 -23
  160. package/src/components/NSFilterItem.tsx +72 -72
  161. package/src/components/NSFooter.module.css +123 -123
  162. package/src/components/NSFooter.tsx +316 -316
  163. package/src/components/NSHeader.module.css +291 -291
  164. package/src/components/NSHeader.tsx +250 -250
  165. package/src/components/NSHeaderScreenshot.module.css +35 -35
  166. package/src/components/NSHeaderScreenshot.tsx +39 -39
  167. package/src/components/NSLabel.module.css +15 -15
  168. package/src/components/NSLabel.tsx +29 -29
  169. package/src/components/NSLabelErrorNotifier.module.css +2 -2
  170. package/src/components/NSLabelErrorNotifier.tsx +32 -32
  171. package/src/components/NSLayout.module.css +13 -13
  172. package/src/components/NSLayout.tsx +100 -100
  173. package/src/components/NSLine.module.css +12 -12
  174. package/src/components/NSLine.tsx +15 -15
  175. package/src/components/NSLink.module.css +36 -36
  176. package/src/components/NSLink.tsx +25 -25
  177. package/src/components/NSLinkBlue.tsx +20 -20
  178. package/src/components/NSLinkGreen.tsx +5 -5
  179. package/src/components/NSLinkRed.tsx +5 -5
  180. package/src/components/NSListGrouped.module.css +72 -72
  181. package/src/components/NSListGrouped.tsx +112 -112
  182. package/src/components/NSListProduct.tsx +45 -45
  183. package/src/components/NSLoading.module.css +30 -30
  184. package/src/components/NSLoading.tsx +19 -19
  185. package/src/components/NSMenuAction.module.css +78 -78
  186. package/src/components/NSMenuAction.tsx +89 -89
  187. package/src/components/NSMenuButton.module.css +44 -44
  188. package/src/components/NSMenuButton.tsx +148 -148
  189. package/src/components/NSNoData.module.css +9 -9
  190. package/src/components/NSNoData.tsx +24 -24
  191. package/src/components/NSPagination.module.css +85 -85
  192. package/src/components/NSPagination.tsx +183 -183
  193. package/src/components/NSPanel.module.css +46 -46
  194. package/src/components/NSPanel.tsx +19 -19
  195. package/src/components/NSPanelAccordion.module.css +4 -4
  196. package/src/components/NSPanelAccordion.tsx +51 -51
  197. package/src/components/NSRange.module.css +66 -66
  198. package/src/components/NSRange.tsx +83 -83
  199. package/src/components/NSRepeater.tsx +179 -179
  200. package/src/components/NSSection.module.css +10 -10
  201. package/src/components/NSSection.tsx +23 -23
  202. package/src/components/NSSectionCards.module.css +38 -38
  203. package/src/components/NSSectionCards.tsx +51 -51
  204. package/src/components/NSSectionTiles.module.css +10 -10
  205. package/src/components/NSSectionTiles.tsx +25 -25
  206. package/src/components/NSSectionTitle.tsx +21 -21
  207. package/src/components/NSSpace.tsx +28 -28
  208. package/src/components/NSTabPage.module.css +59 -59
  209. package/src/components/NSTabPage.tsx +78 -78
  210. package/src/components/NSTable.module.css +261 -260
  211. package/src/components/NSTable.tsx +477 -477
  212. package/src/components/NSTag.module.css +52 -52
  213. package/src/components/NSTag.tsx +78 -78
  214. package/src/components/NSTile.module.css +77 -77
  215. package/src/components/NSTile.tsx +27 -27
  216. package/src/components/NSTimelineMonthly.module.css +71 -71
  217. package/src/components/NSTimelineMonthly.tsx +44 -44
  218. package/src/components/NSTitle.module.css +15 -15
  219. package/src/components/NSTitle.tsx +19 -19
  220. package/src/formatter/BackColorFormatter.tsx +23 -23
  221. package/src/formatter/BaseColumnFormatter.ts +16 -16
  222. package/src/formatter/BooleanFormatter.ts +22 -22
  223. package/src/formatter/DateFormatter.ts +20 -20
  224. package/src/formatter/DateTimeFormatter.ts +20 -20
  225. package/src/formatter/DurationFormatter.ts +13 -13
  226. package/src/formatter/EmailFormatter.ts +13 -13
  227. package/src/formatter/EnumFormatter.ts +13 -13
  228. package/src/formatter/FloatFormatter.ts +16 -16
  229. package/src/formatter/ForeColorFormatter.tsx +24 -24
  230. package/src/formatter/IDFormatter.tsx +30 -30
  231. package/src/formatter/IPFormatter.ts +13 -13
  232. package/src/formatter/IntegerFormatter.ts +16 -16
  233. package/src/formatter/JsonFormatter.ts +14 -14
  234. package/src/formatter/MoneyFormatter.ts +16 -16
  235. package/src/formatter/PhoneFormatter.ts +13 -13
  236. package/src/formatter/StringFormatter.ts +22 -22
  237. package/src/formatter/TimeFormatter.ts +21 -21
  238. package/src/formatter/UnknowFormatter.ts +18 -14
  239. package/src/index.tsx +7 -7
  240. package/src/main.ts +184 -184
  241. package/src/pages/NSNotFoundPage.module.css +17 -17
  242. package/src/pages/NSNotFoundPage.tsx +11 -11
  243. package/src/pages/NSUpdating.module.css +35 -35
  244. package/src/pages/NSUpdating.tsx +32 -32
  245. package/src/props/IBaseComponentProps.ts +8 -8
  246. package/src/props/IHeaderIconProps.ts +10 -10
  247. package/src/props/IHeaderProps.ts +7 -7
  248. package/src/props/IImageProps.ts +4 -4
  249. package/src/props/ILinkProps.ts +5 -5
  250. package/src/props/IValidationNumberProps.ts +4 -4
  251. package/src/props/IValidationProps.ts +7 -7
  252. package/src/props/IValidationRegexProps.ts +4 -4
  253. package/src/props/IValidationStringProps.ts +4 -4
  254. package/src/routing/INSRouterMaker.ts +6 -6
  255. package/src/routing/INSRouterProps.ts +5 -5
  256. package/src/routing/INSRouterState.ts +5 -5
  257. package/src/routing/NSRouterMaker.tsx +33 -33
  258. package/src/routing/Notifier.ts +79 -79
  259. package/tsconfig.json +43 -43
@@ -1,45 +1,45 @@
1
- // todo move to its own probject: this is Timify
2
-
3
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
4
- import { Color } from "../Color"
5
- import Styles from './NSTimelineMonthly.module.css';
6
- export interface NSdata
7
- {
8
- title: string;
9
- value: number;
10
- percentage: number;
11
- }
12
- export interface NSTimelineMonthlyProps extends IBaseComponentProps
13
- {
14
- data: NSdata[];
15
- title?: string;
16
- }
17
-
18
- export function NSTimelineMonthly(props: NSTimelineMonthlyProps)
19
- {
20
- function getPercentage(value: number): string
21
- {
22
- let percentage = (value * 100) / 24;
23
- return percentage.toString() + "%";
24
- }
25
- return (
26
- <>
27
- <div className={`${Styles.ns_parent} ${props.classList?.join(" ")} `} style={props.style}>
28
- <h5 className={Styles.ns_time_line_title}>{props.title}</h5>
29
- <div className={Styles.ns_time_line_monthly}>
30
- {
31
- props.data.map((card, index) => (
32
- <div className={Styles.ns_time_line_monthly_card} key={`NSTimelineMonthly_div_key_${index}`}>
33
- <h5 className={Styles.ns_time_line_monthly_card_week_day}>{card.title}</h5>
34
- <span className={Styles.ns_time_line_cards_hour}>{card.value}</span>
35
- <div className={Styles.ns_time_line_monthly_card_parent_chart}>
36
- <div className={Styles.ns_time_line_monthly_card_bar} style={{ width: getPercentage(card.value), background: Color.getColor(card.percentage) }}>bar</div>
37
- </div>
38
- </div>
39
- ))
40
- }
41
- </div>
42
- </div>
43
- </>
44
- );
1
+ // todo move to its own probject: this is Timify
2
+
3
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
4
+ import { Color } from "../Color"
5
+ import Styles from './NSTimelineMonthly.module.css';
6
+ export interface NSdata
7
+ {
8
+ title: string;
9
+ value: number;
10
+ percentage: number;
11
+ }
12
+ export interface NSTimelineMonthlyProps extends IBaseComponentProps
13
+ {
14
+ data: NSdata[];
15
+ title?: string;
16
+ }
17
+
18
+ export function NSTimelineMonthly(props: NSTimelineMonthlyProps)
19
+ {
20
+ function getPercentage(value: number): string
21
+ {
22
+ let percentage = (value * 100) / 24;
23
+ return percentage.toString() + "%";
24
+ }
25
+ return (
26
+ <>
27
+ <div className={`${Styles.ns_parent} ${props.classList?.join(" ")} `} style={props.style}>
28
+ <h5 className={Styles.ns_time_line_title}>{props.title}</h5>
29
+ <div className={Styles.ns_time_line_monthly}>
30
+ {
31
+ props.data.map((card, index) => (
32
+ <div className={Styles.ns_time_line_monthly_card} key={`NSTimelineMonthly_div_key_${index}`}>
33
+ <h5 className={Styles.ns_time_line_monthly_card_week_day}>{card.title}</h5>
34
+ <span className={Styles.ns_time_line_cards_hour}>{card.value}</span>
35
+ <div className={Styles.ns_time_line_monthly_card_parent_chart}>
36
+ <div className={Styles.ns_time_line_monthly_card_bar} style={{ width: getPercentage(card.value), background: Color.getColor(card.percentage) }}>bar</div>
37
+ </div>
38
+ </div>
39
+ ))
40
+ }
41
+ </div>
42
+ </div>
43
+ </>
44
+ );
45
45
  }
@@ -1,16 +1,16 @@
1
- .ns_title {
2
- font-size: 24px;
3
- font-weight: 700;
4
- line-height: normal;
5
- color: inherit;
6
- margin-bottom: 16px;
7
- width: 100%;
8
- text-align: center;
9
- font-family: inherit;
10
- }
11
-
12
- @media only screen and (min-width: 1024px) {
13
- .ns_title {
14
- font-size: 32px;
15
- }
1
+ .ns_title {
2
+ font-size: 24px;
3
+ font-weight: 700;
4
+ line-height: normal;
5
+ color: inherit;
6
+ margin-bottom: 16px;
7
+ width: 100%;
8
+ text-align: center;
9
+ font-family: inherit;
10
+ }
11
+
12
+ @media only screen and (min-width: 1024px) {
13
+ .ns_title {
14
+ font-size: 32px;
15
+ }
16
16
  }
@@ -1,20 +1,20 @@
1
- import Styles from './NSTitle.module.css';
2
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
-
4
- export interface NSTitleProps extends IBaseComponentProps
5
- {
6
- title: string;
7
- }
8
-
9
- export function NSTitle(props: NSTitleProps)
10
- {
11
- return (
12
- <h2
13
- id={props.id}
14
- className={`${Styles.ns_title} ${props.classList?.join(" ")}`}
15
- style={props.style}
16
- >
17
- {props.title}
18
- </h2>
19
- );
1
+ import Styles from './NSTitle.module.css';
2
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
3
+
4
+ export interface NSTitleProps extends IBaseComponentProps
5
+ {
6
+ title: string;
7
+ }
8
+
9
+ export function NSTitle(props: NSTitleProps)
10
+ {
11
+ return (
12
+ <h2
13
+ id={props.id}
14
+ className={`${Styles.ns_title} ${props.classList?.join(" ")}`}
15
+ style={props.style}
16
+ >
17
+ {props.title}
18
+ </h2>
19
+ );
20
20
  }
@@ -1,24 +1,24 @@
1
- import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
2
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
3
-
4
- export class BackColorFormatter extends BaseColumnFormatter
5
- {
6
- private formatter: BaseColumnFormatter;
7
- private colors: { [value: string]: string }
8
- constructor(formatter: BaseColumnFormatter, colors: { [value: string]: string }, width?: string)
9
- {
10
- super();
11
- this.formatter = formatter;
12
- this.colors = colors;
13
- if (width)
14
- this.width = width;
15
- }
16
- override format(value: any, column: TableColumnInfo, row: TableRowInfo<any>, printable: boolean)
17
- {
18
- let formatted = this.formatter.format(value, column, row, printable);
19
- if (!printable)
20
- if (this.colors[value])
21
- return <span style={{ background: this.colors[value], borderRadius: "16px", width: "100px", textAlign: "center" }}> {formatted} </span>;
22
- return formatted;
23
- }
1
+ import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
2
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
3
+
4
+ export class BackColorFormatter extends BaseColumnFormatter
5
+ {
6
+ private formatter: BaseColumnFormatter;
7
+ private colors: { [value: string]: string }
8
+ constructor(formatter: BaseColumnFormatter, colors: { [value: string]: string }, width?: string)
9
+ {
10
+ super();
11
+ this.formatter = formatter;
12
+ this.colors = colors;
13
+ if (width)
14
+ this.width = width;
15
+ }
16
+ override format(value: any, column: TableColumnInfo, row: TableRowInfo<any>, printable: boolean)
17
+ {
18
+ let formatted = this.formatter.format(value, column, row, printable);
19
+ if (!printable)
20
+ if (this.colors[value])
21
+ return <span style={{ background: this.colors[value], borderRadius: "16px", width: "100px", textAlign: "center" }}> {formatted} </span>;
22
+ return formatted;
23
+ }
24
24
  }
@@ -1,17 +1,17 @@
1
- import { BaseMetaColumn } from "namirasoft-core";
2
- import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
3
-
4
- export abstract class BaseColumnFormatter
5
- {
6
- public width: string = "100px";
7
- public onclick_overrided: boolean = false;
8
- abstract format(value: any, column: TableColumnInfo, row: TableRowInfo<any>, printable: boolean): any;
9
- static getColumn(column: BaseMetaColumn, formatter: BaseColumnFormatter): TableColumnInfo
10
- {
11
- return {
12
- index: 0,
13
- ...column,
14
- formatter
15
- };
16
- }
1
+ import { BaseMetaColumn } from "namirasoft-core";
2
+ import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
3
+
4
+ export abstract class BaseColumnFormatter
5
+ {
6
+ public width: string = "100px";
7
+ public onclick_overrided: boolean = false;
8
+ abstract format(value: any, column: TableColumnInfo, row: TableRowInfo<any>, printable: boolean): any;
9
+ static getColumn(column: BaseMetaColumn, formatter: BaseColumnFormatter): TableColumnInfo
10
+ {
11
+ return {
12
+ index: 0,
13
+ ...column,
14
+ formatter
15
+ };
16
+ }
17
17
  }
@@ -1,23 +1,23 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class BooleanFormatter extends BaseColumnFormatter
4
- {
5
- private true_value: string;
6
- private false_value: string;
7
- constructor(true_value: string, false_value: string, width: string = "80px")
8
- {
9
- super();
10
- this.true_value = true_value;
11
- this.false_value = false_value;
12
- if (width)
13
- this.width = width;
14
- }
15
- override format(value: any): any
16
- {
17
- if (value === true)
18
- return this.true_value;
19
- if (value === false)
20
- return this.false_value;
21
- return value;
22
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class BooleanFormatter extends BaseColumnFormatter
4
+ {
5
+ private true_value: string;
6
+ private false_value: string;
7
+ constructor(true_value: string, false_value: string, width: string = "80px")
8
+ {
9
+ super();
10
+ this.true_value = true_value;
11
+ this.false_value = false_value;
12
+ if (width)
13
+ this.width = width;
14
+ }
15
+ override format(value: any): any
16
+ {
17
+ if (value === true)
18
+ return this.true_value;
19
+ if (value === false)
20
+ return this.false_value;
21
+ return value;
22
+ }
23
23
  }
@@ -1,21 +1,21 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class DateFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "130px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- try
13
- {
14
- let date = new Date(value);
15
- return date.toDateString();
16
- } catch (e)
17
- {
18
- }
19
- return value;
20
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class DateFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "130px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ try
13
+ {
14
+ let date = new Date(value);
15
+ return date.toDateString();
16
+ } catch (e)
17
+ {
18
+ }
19
+ return value;
20
+ }
21
21
  }
@@ -1,21 +1,21 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class DateTimeFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "185px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- try
13
- {
14
- let date = new Date(value);
15
- return date.toLocaleString();
16
- } catch (e)
17
- {
18
- }
19
- return value;
20
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class DateTimeFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "185px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ try
13
+ {
14
+ let date = new Date(value);
15
+ return date.toLocaleString();
16
+ } catch (e)
17
+ {
18
+ }
19
+ return value;
20
+ }
21
21
  }
@@ -1,14 +1,14 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class DurationFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "200px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- return value;
13
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class DurationFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "200px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ return value;
13
+ }
14
14
  }
@@ -1,14 +1,14 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class EmailFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "250px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- return value;
13
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class EmailFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "250px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ return value;
13
+ }
14
14
  }
@@ -1,14 +1,14 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class EnumFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "125px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- return value;
13
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class EnumFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "125px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ return value;
13
+ }
14
14
  }
@@ -1,17 +1,17 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class FloatFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "125px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- return (value as number).toLocaleString(undefined, {
13
- minimumFractionDigits: 0,
14
- maximumFractionDigits: 100
15
- });
16
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class FloatFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "125px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ return (value as number).toLocaleString(undefined, {
13
+ minimumFractionDigits: 0,
14
+ maximumFractionDigits: 100
15
+ });
16
+ }
17
17
  }
@@ -1,25 +1,25 @@
1
- import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
2
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
3
-
4
- export class ForeColorFormatter extends BaseColumnFormatter
5
- {
6
- private formatter: BaseColumnFormatter;
7
- private colors: { [value: string]: string }
8
- constructor(formatter: BaseColumnFormatter, colors: { [value: string]: string }, width?: string)
9
- {
10
- super();
11
- this.formatter = formatter;
12
- this.colors = colors;
13
- let w = width ?? formatter.width;
14
- if (w)
15
- this.width = w;
16
- }
17
- override format(value: any, column: TableColumnInfo, row: TableRowInfo<any>, printable: boolean): any
18
- {
19
- let formatted = this.formatter.format(value, column, row, printable);
20
- if (!printable)
21
- if (this.colors[value])
22
- return <span style={{ color: this.colors[value], fontWeight: "bold" }}> {formatted} </span>;
23
- return formatted;
24
- }
1
+ import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
2
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
3
+
4
+ export class ForeColorFormatter extends BaseColumnFormatter
5
+ {
6
+ private formatter: BaseColumnFormatter;
7
+ private colors: { [value: string]: string }
8
+ constructor(formatter: BaseColumnFormatter, colors: { [value: string]: string }, width?: string)
9
+ {
10
+ super();
11
+ this.formatter = formatter;
12
+ this.colors = colors;
13
+ let w = width ?? formatter.width;
14
+ if (w)
15
+ this.width = w;
16
+ }
17
+ override format(value: any, column: TableColumnInfo, row: TableRowInfo<any>, printable: boolean): any
18
+ {
19
+ let formatted = this.formatter.format(value, column, row, printable);
20
+ if (!printable)
21
+ if (this.colors[value])
22
+ return <span style={{ color: this.colors[value], fontWeight: "bold" }}> {formatted} </span>;
23
+ return formatted;
24
+ }
25
25
  }
@@ -1,31 +1,31 @@
1
- import { BaseUUID } from "namirasoft-core";
2
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
3
- import { Globe } from "namirasoft-site-map";
4
- import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
5
-
6
- export class IDFormatter extends BaseColumnFormatter
7
- {
8
- constructor(width: string = "200px")
9
- {
10
- super();
11
- this.onclick_overrided = true;
12
- this.width = width;
13
- }
14
- override format(value: any, _: TableColumnInfo, __: TableRowInfo<any>, printable: boolean): any
15
- {
16
- if (!printable)
17
- if (BaseUUID.isValid(value))
18
- {
19
- let short = BaseUUID.getShort(value);
20
- let info = Globe.namirasoft.getByShortName(short);
21
- return (
22
- <div style={{ display: "flex", alignItems: "center" }}>
23
- <img src={info.product.logo} alt={info.product.name} style={{ width: "20px", height: "20px" }} />
24
- &nbsp;
25
- <a href={info.table.front_end.getViewLink(value + "")} target="_blank" rel="noreferrer">{value}</a >
26
- </div >
27
- );
28
- }
29
- return value;
30
- }
1
+ import { BaseUUID } from "namirasoft-core";
2
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
3
+ import { Globe } from "namirasoft-site-map";
4
+ import { TableColumnInfo, TableRowInfo } from "../components/NSTable";
5
+
6
+ export class IDFormatter extends BaseColumnFormatter
7
+ {
8
+ constructor(width: string = "200px")
9
+ {
10
+ super();
11
+ this.onclick_overrided = true;
12
+ this.width = width;
13
+ }
14
+ override format(value: any, _: TableColumnInfo, __: TableRowInfo<any>, printable: boolean): any
15
+ {
16
+ if (!printable)
17
+ if (BaseUUID.isValid(value))
18
+ {
19
+ let short = BaseUUID.getShort(value);
20
+ let info = Globe.namirasoft.getByShortName(short);
21
+ return (
22
+ <div style={{ display: "flex", alignItems: "center" }}>
23
+ <img src={info.product.logo} alt={info.product.name} style={{ width: "20px", height: "20px" }} />
24
+ &nbsp;
25
+ <a href={info.table.front_end.getViewLink(value + "")} target="_blank" rel="noreferrer">{value}</a >
26
+ </div >
27
+ );
28
+ }
29
+ return value;
30
+ }
31
31
  }
@@ -1,14 +1,14 @@
1
- import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
-
3
- export class IPFormatter extends BaseColumnFormatter
4
- {
5
- constructor(width: string = "150px")
6
- {
7
- super();
8
- this.width = width;
9
- }
10
- override format(value: any): any
11
- {
12
- return value;
13
- }
1
+ import { BaseColumnFormatter } from "./BaseColumnFormatter";
2
+
3
+ export class IPFormatter extends BaseColumnFormatter
4
+ {
5
+ constructor(width: string = "150px")
6
+ {
7
+ super();
8
+ this.width = width;
9
+ }
10
+ override format(value: any): any
11
+ {
12
+ return value;
13
+ }
14
14
  }