namirasoft-site-react 1.4.1 → 1.4.3

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 (305) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +7 -7
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +70 -70
  5. package/dist/Validator.js.map +1 -1
  6. package/dist/components/NSAccordion.js.map +1 -1
  7. package/dist/components/NSAccordion.module.css +4 -4
  8. package/dist/components/NSActionMenu.js +2 -2
  9. package/dist/components/NSActionMenu.js.map +1 -1
  10. package/dist/components/NSActionMenu.module.css +75 -75
  11. package/dist/components/NSAssistantButton.module.css +130 -130
  12. package/dist/components/NSBarAction.module.css +87 -87
  13. package/dist/components/NSBarHeroBanner.module.css +42 -42
  14. package/dist/components/NSBarNotification.js.map +1 -1
  15. package/dist/components/NSBarNotification.module.css +34 -34
  16. package/dist/components/NSBarTitle.module.css +9 -9
  17. package/dist/components/NSBox.module.css +124 -124
  18. package/dist/components/NSBoxBoolean.js.map +1 -1
  19. package/dist/components/NSBoxBoolean.module.css +74 -74
  20. package/dist/components/NSBoxCombo.js.map +1 -1
  21. package/dist/components/NSBoxCombo.module.css +6 -6
  22. package/dist/components/NSBoxDate.js.map +1 -1
  23. package/dist/components/NSBoxDate.module.css +42 -42
  24. package/dist/components/NSBoxDateTime.js.map +1 -1
  25. package/dist/components/NSBoxDateTime.module.css +43 -43
  26. package/dist/components/NSBoxDouble.js.map +1 -1
  27. package/dist/components/NSBoxDuration.js.map +1 -1
  28. package/dist/components/NSBoxEmail.js.map +1 -1
  29. package/dist/components/NSBoxEntity.js.map +1 -1
  30. package/dist/components/NSBoxEntity.module.css +25 -25
  31. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  32. package/dist/components/NSBoxFile.js.map +1 -1
  33. package/dist/components/NSBoxFile.module.css +4 -4
  34. package/dist/components/NSBoxIPV4.js.map +1 -1
  35. package/dist/components/NSBoxIPV6.js.map +1 -1
  36. package/dist/components/NSBoxInteger.js.map +1 -1
  37. package/dist/components/NSBoxLabel.module.css +12 -12
  38. package/dist/components/NSBoxPassword.js.map +1 -1
  39. package/dist/components/NSBoxPhone.js.map +1 -1
  40. package/dist/components/NSBoxPrice.js.map +1 -1
  41. package/dist/components/NSBoxRadio.js.map +1 -1
  42. package/dist/components/NSBoxRadio.module.css +65 -65
  43. package/dist/components/NSBoxSearch.js.map +1 -1
  44. package/dist/components/NSBoxString.js.map +1 -1
  45. package/dist/components/NSBoxTextArea.js.map +1 -1
  46. package/dist/components/NSBoxTextArea.module.css +78 -78
  47. package/dist/components/NSBoxTime.js.map +1 -1
  48. package/dist/components/NSButton.d.ts +0 -1
  49. package/dist/components/NSButton.module.css +28 -28
  50. package/dist/components/NSButtonBlue.module.css +4 -4
  51. package/dist/components/NSButtonGreen.module.css +4 -4
  52. package/dist/components/NSButtonRed.module.css +4 -4
  53. package/dist/components/NSCard.module.css +108 -108
  54. package/dist/components/NSCardScreenshot.module.css +41 -41
  55. package/dist/components/NSChartColumn.module.css +7 -7
  56. package/dist/components/NSChartTable.module.css +21 -21
  57. package/dist/components/NSCopyToClipboard.js.map +1 -1
  58. package/dist/components/NSCopyToClipboard.module.css +43 -39
  59. package/dist/components/NSDialog.module.css +72 -72
  60. package/dist/components/NSDownTimer.js.map +1 -1
  61. package/dist/components/NSDownTimer.module.css +62 -62
  62. package/dist/components/NSDownload.js.map +1 -1
  63. package/dist/components/NSDownload.module.css +46 -46
  64. package/dist/components/NSElectronicCard.js.map +1 -1
  65. package/dist/components/NSElectronicCard.module.css +60 -60
  66. package/dist/components/NSEntityBar.module.css +77 -77
  67. package/dist/components/NSEntityCardBackground.module.css +27 -27
  68. package/dist/components/NSFilterBox.js.map +1 -1
  69. package/dist/components/NSFilterBox.module.css +47 -47
  70. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  71. package/dist/components/NSFilterItem.module.css +23 -23
  72. package/dist/components/NSFooter.js.map +1 -1
  73. package/dist/components/NSFooter.module.css +123 -123
  74. package/dist/components/NSGroupedList.js.map +1 -1
  75. package/dist/components/NSGroupedList.module.css +72 -72
  76. package/dist/components/NSHeader.js.map +1 -1
  77. package/dist/components/NSHeader.module.css +286 -286
  78. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  79. package/dist/components/NSInfoDialog.d.ts +0 -1
  80. package/dist/components/NSLayout.js.map +1 -1
  81. package/dist/components/NSLayout.module.css +13 -13
  82. package/dist/components/NSLine.module.css +12 -12
  83. package/dist/components/NSLink.module.css +36 -36
  84. package/dist/components/NSLoading.module.css +29 -29
  85. package/dist/components/NSNoData.module.css +8 -8
  86. package/dist/components/NSPageSelectionModal.d.ts +1 -0
  87. package/dist/components/NSPageSelectionModal.js +1 -1
  88. package/dist/components/NSPageSelectionModal.js.map +1 -1
  89. package/dist/components/NSPageSelectionModal.module.css +102 -102
  90. package/dist/components/NSPagination.js.map +1 -1
  91. package/dist/components/NSPagination.module.css +101 -101
  92. package/dist/components/NSPanel.module.css +46 -46
  93. package/dist/components/NSRange.module.css +66 -66
  94. package/dist/components/NSRepeater.js.map +1 -1
  95. package/dist/components/NSSection.module.css +10 -10
  96. package/dist/components/NSSectionBars.module.css +10 -10
  97. package/dist/components/NSSectionCards.module.css +38 -38
  98. package/dist/components/NSTabPage.module.css +59 -59
  99. package/dist/components/NSTable.js +4 -5
  100. package/dist/components/NSTable.js.map +1 -1
  101. package/dist/components/NSTable.module.css +289 -289
  102. package/dist/components/NSTag.module.css +52 -52
  103. package/dist/components/NSTimeTable.module.css +6 -6
  104. package/dist/components/NSTimelineMonthly.module.css +71 -71
  105. package/dist/components/NSTitle.module.css +15 -15
  106. package/dist/formatter/DateFormatter.js.map +1 -1
  107. package/dist/formatter/DateTimeFormatter.js.map +1 -1
  108. package/dist/formatter/TimeFormatter.js.map +1 -1
  109. package/dist/pages/NSNotFoundPage.module.css +18 -18
  110. package/dist/pages/NSUpdating.module.css +35 -35
  111. package/dist/routing/NSRouterMaker.d.ts +0 -1
  112. package/dist/routing/Notifier.d.ts +0 -1
  113. package/dist/routing/Notifier.js.map +1 -1
  114. package/package.json +72 -72
  115. package/public/index.html +38 -38
  116. package/src/App.css +16 -16
  117. package/src/App.tsx +184 -184
  118. package/src/Color.tsx +10 -10
  119. package/src/CopyToClipboard.ts +6 -6
  120. package/src/Validator.ts +117 -117
  121. package/src/components/NSAccordion.module.css +4 -4
  122. package/src/components/NSAccordion.tsx +51 -51
  123. package/src/components/NSActionMenu.module.css +75 -75
  124. package/src/components/NSActionMenu.tsx +89 -89
  125. package/src/components/NSAssistantButton.module.css +130 -130
  126. package/src/components/NSAssistantButton.tsx +70 -70
  127. package/src/components/NSBarAction.module.css +87 -87
  128. package/src/components/NSBarAction.tsx +92 -92
  129. package/src/components/NSBarHeroBanner.module.css +42 -42
  130. package/src/components/NSBarHeroBanner.tsx +61 -61
  131. package/src/components/NSBarNotification.module.css +34 -34
  132. package/src/components/NSBarNotification.tsx +85 -85
  133. package/src/components/NSBarTitle.module.css +9 -9
  134. package/src/components/NSBarTitle.tsx +28 -28
  135. package/src/components/NSBox.module.css +124 -124
  136. package/src/components/NSBoxBoolean.module.css +74 -74
  137. package/src/components/NSBoxBoolean.tsx +108 -108
  138. package/src/components/NSBoxCombo.module.css +6 -6
  139. package/src/components/NSBoxCombo.tsx +135 -135
  140. package/src/components/NSBoxDate.module.css +42 -42
  141. package/src/components/NSBoxDate.tsx +86 -86
  142. package/src/components/NSBoxDateTime.module.css +43 -43
  143. package/src/components/NSBoxDateTime.tsx +87 -87
  144. package/src/components/NSBoxDouble.tsx +90 -90
  145. package/src/components/NSBoxDuration.tsx +90 -90
  146. package/src/components/NSBoxEmail.tsx +103 -103
  147. package/src/components/NSBoxEntity.module.css +25 -25
  148. package/src/components/NSBoxEntity.tsx +181 -181
  149. package/src/components/NSBoxEnum.tsx +56 -56
  150. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  151. package/src/components/NSBoxErrorNotifier.tsx +32 -32
  152. package/src/components/NSBoxFile.module.css +4 -4
  153. package/src/components/NSBoxFile.tsx +124 -124
  154. package/src/components/NSBoxIPV4.tsx +95 -95
  155. package/src/components/NSBoxIPV6.tsx +92 -92
  156. package/src/components/NSBoxInteger.tsx +88 -88
  157. package/src/components/NSBoxLabel.module.css +12 -12
  158. package/src/components/NSBoxLabel.tsx +29 -29
  159. package/src/components/NSBoxPassword.tsx +88 -88
  160. package/src/components/NSBoxPhone.tsx +90 -90
  161. package/src/components/NSBoxPrice.tsx +90 -90
  162. package/src/components/NSBoxRadio.module.css +65 -65
  163. package/src/components/NSBoxRadio.tsx +105 -105
  164. package/src/components/NSBoxSearch.tsx +105 -105
  165. package/src/components/NSBoxString.tsx +104 -104
  166. package/src/components/NSBoxTextArea.module.css +78 -78
  167. package/src/components/NSBoxTextArea.tsx +110 -110
  168. package/src/components/NSBoxTime.tsx +90 -90
  169. package/src/components/NSButton.module.css +28 -28
  170. package/src/components/NSButton.tsx +23 -23
  171. package/src/components/NSButtonBlue.module.css +4 -4
  172. package/src/components/NSButtonBlue.tsx +11 -11
  173. package/src/components/NSButtonGreen.module.css +4 -4
  174. package/src/components/NSButtonGreen.tsx +10 -10
  175. package/src/components/NSButtonRed.module.css +4 -4
  176. package/src/components/NSButtonRed.tsx +10 -10
  177. package/src/components/NSCard.module.css +108 -108
  178. package/src/components/NSCard.tsx +71 -71
  179. package/src/components/NSCardScreenshot.module.css +41 -41
  180. package/src/components/NSCardScreenshot.tsx +31 -31
  181. package/src/components/NSChartColumn.module.css +7 -7
  182. package/src/components/NSChartColumn.tsx +106 -106
  183. package/src/components/NSChartPie.tsx +104 -104
  184. package/src/components/NSChartRange.tsx +16 -16
  185. package/src/components/NSChartTable.module.css +21 -21
  186. package/src/components/NSChartTable.tsx +94 -94
  187. package/src/components/NSCopyToClipboard.module.css +43 -39
  188. package/src/components/NSCopyToClipboard.tsx +38 -38
  189. package/src/components/NSDeleteDialog.tsx +26 -26
  190. package/src/components/NSDialog.module.css +72 -72
  191. package/src/components/NSDialog.tsx +46 -46
  192. package/src/components/NSDownTimer.module.css +62 -62
  193. package/src/components/NSDownTimer.tsx +77 -77
  194. package/src/components/NSDownload.module.css +46 -46
  195. package/src/components/NSDownload.tsx +62 -62
  196. package/src/components/NSElectronicCard.module.css +60 -60
  197. package/src/components/NSElectronicCard.tsx +45 -45
  198. package/src/components/NSEntityBar.module.css +77 -77
  199. package/src/components/NSEntityBar.tsx +27 -27
  200. package/src/components/NSEntityCardBackground.module.css +27 -27
  201. package/src/components/NSEntityCardBackground.tsx +34 -34
  202. package/src/components/NSFilterBox.module.css +47 -47
  203. package/src/components/NSFilterBox.tsx +352 -352
  204. package/src/components/NSFilterBoxDialog.module.css +36 -36
  205. package/src/components/NSFilterBoxDialog.tsx +74 -74
  206. package/src/components/NSFilterItem.module.css +23 -23
  207. package/src/components/NSFilterItem.tsx +73 -73
  208. package/src/components/NSFooter.module.css +123 -123
  209. package/src/components/NSFooter.tsx +200 -200
  210. package/src/components/NSGroupedList.module.css +72 -72
  211. package/src/components/NSGroupedList.tsx +107 -107
  212. package/src/components/NSHeader.module.css +286 -286
  213. package/src/components/NSHeader.tsx +243 -243
  214. package/src/components/NSHeaderScreenshot.module.css +35 -35
  215. package/src/components/NSHeaderScreenshot.tsx +38 -38
  216. package/src/components/NSInfoDialog.tsx +36 -36
  217. package/src/components/NSLayout.module.css +13 -13
  218. package/src/components/NSLayout.tsx +90 -90
  219. package/src/components/NSLine.module.css +12 -12
  220. package/src/components/NSLine.tsx +15 -15
  221. package/src/components/NSLink.module.css +36 -36
  222. package/src/components/NSLink.tsx +25 -25
  223. package/src/components/NSLinkBlue.tsx +20 -20
  224. package/src/components/NSLinkGreen.tsx +5 -5
  225. package/src/components/NSLinkRed.tsx +5 -5
  226. package/src/components/NSLoading.module.css +29 -29
  227. package/src/components/NSLoading.tsx +19 -19
  228. package/src/components/NSNoData.module.css +8 -8
  229. package/src/components/NSNoData.tsx +24 -24
  230. package/src/components/NSPageSelectionModal.module.css +102 -102
  231. package/src/components/NSPageSelectionModal.tsx +227 -226
  232. package/src/components/NSPagination.module.css +101 -101
  233. package/src/components/NSPagination.tsx +189 -189
  234. package/src/components/NSPanel.module.css +46 -46
  235. package/src/components/NSPanel.tsx +19 -19
  236. package/src/components/NSProductList.tsx +43 -43
  237. package/src/components/NSRange.module.css +66 -66
  238. package/src/components/NSRange.tsx +82 -82
  239. package/src/components/NSRepeater.tsx +175 -175
  240. package/src/components/NSSection.module.css +10 -10
  241. package/src/components/NSSection.tsx +23 -23
  242. package/src/components/NSSectionBars.module.css +10 -10
  243. package/src/components/NSSectionBars.tsx +25 -25
  244. package/src/components/NSSectionCards.module.css +38 -38
  245. package/src/components/NSSectionCards.tsx +51 -51
  246. package/src/components/NSSectionTitle.tsx +21 -21
  247. package/src/components/NSSpace.tsx +28 -28
  248. package/src/components/NSTabPage.module.css +59 -59
  249. package/src/components/NSTabPage.tsx +53 -53
  250. package/src/components/NSTable.module.css +289 -289
  251. package/src/components/NSTable.tsx +424 -422
  252. package/src/components/NSTag.module.css +52 -52
  253. package/src/components/NSTag.tsx +73 -73
  254. package/src/components/NSTimeTable.module.css +6 -6
  255. package/src/components/NSTimeTable.tsx +49 -49
  256. package/src/components/NSTimelineMonthly.module.css +71 -71
  257. package/src/components/NSTimelineMonthly.tsx +42 -42
  258. package/src/components/NSTitle.module.css +15 -15
  259. package/src/components/NSTitle.tsx +19 -19
  260. package/src/formatter/BackColorFormatter.tsx +20 -20
  261. package/src/formatter/BaseColumnFormatter.ts +14 -14
  262. package/src/formatter/BooleanFormatter.ts +20 -20
  263. package/src/formatter/DateFormatter.ts +15 -15
  264. package/src/formatter/DateTimeFormatter.ts +15 -15
  265. package/src/formatter/DurationFormatter.ts +8 -8
  266. package/src/formatter/EmailFormatter.ts +8 -8
  267. package/src/formatter/EnumFormatter.ts +8 -8
  268. package/src/formatter/FloatFormatter.ts +8 -8
  269. package/src/formatter/ForeColorFormatter.tsx +20 -20
  270. package/src/formatter/ForeignIDFormatter.ts +8 -8
  271. package/src/formatter/IDFormatter.ts +8 -8
  272. package/src/formatter/IPFormatter.ts +8 -8
  273. package/src/formatter/IntegerFormatter.ts +8 -8
  274. package/src/formatter/JsonFormatter.ts +8 -8
  275. package/src/formatter/MoneyFormatter.ts +8 -8
  276. package/src/formatter/PhoneFormatter.ts +8 -8
  277. package/src/formatter/StringFormatter.ts +8 -8
  278. package/src/formatter/TimeFormatter.ts +16 -16
  279. package/src/formatter/UnknowFormatter.ts +8 -8
  280. package/src/index.tsx +7 -7
  281. package/src/main.ts +114 -114
  282. package/src/pages/NSNotFoundPage.module.css +18 -18
  283. package/src/pages/NSNotFoundPage.tsx +11 -11
  284. package/src/pages/NSUpdating.module.css +35 -35
  285. package/src/pages/NSUpdating.tsx +32 -32
  286. package/src/props/IBaseComponentProps.ts +8 -8
  287. package/src/props/IHeaderIconProps.ts +10 -10
  288. package/src/props/IHeaderProps.ts +7 -7
  289. package/src/props/IImageProps.ts +4 -4
  290. package/src/props/ILinkProps.ts +5 -5
  291. package/src/props/IValidationNumberProps.ts +4 -4
  292. package/src/props/IValidationProps.ts +7 -7
  293. package/src/props/IValidationRegexProps.ts +4 -4
  294. package/src/props/IValidationStringProps.ts +4 -4
  295. package/src/routing/INSRouterMaker.ts +6 -6
  296. package/src/routing/INSRouterProps.ts +5 -5
  297. package/src/routing/INSRouterState.ts +5 -5
  298. package/src/routing/NSRouterMaker.tsx +33 -33
  299. package/src/routing/Notifier.ts +79 -79
  300. package/tsconfig.json +43 -43
  301. package/dist/App.css +0 -17
  302. package/dist/components/NSRadioButton.d.ts +0 -25
  303. package/dist/components/NSRadioButton.js +0 -49
  304. package/dist/components/NSRadioButton.js.map +0 -1
  305. package/dist/index.css +0 -6
@@ -1,227 +1,228 @@
1
- import React, { Component, createRef } from 'react';
2
- import { NSButtonBlue } from './NSButtonBlue';
3
- import { NSBoxString } from './NSBoxString';
4
- import { NSSpace, NSSpaceSizeType } from './NSSpace';
5
- import Styles from './NSPageSelectionModal.module.css';
6
- import { NSBoxRadio } from './NSBoxRadio';
7
-
8
- export interface NSPageSelectionModalProps<RowType>
9
- {
10
- current_page: number;
11
- max_page: number;
12
- onClose: () => void;
13
- getItems: (page: number, selected: boolean) => Promise<RowType[]>;
14
- onFinish: (items: RowType[]) => void;
15
- }
16
-
17
- interface NSPageSelectionModalState
18
- {
19
- selectedRadio: string;
20
- }
21
-
22
- export class NSPageSelectionModal<RowType> extends Component<NSPageSelectionModalProps<RowType>, NSPageSelectionModalState>
23
- {
24
- private toastRef: React.RefObject<HTMLDivElement> = createRef();
25
- private NSBoxBoolean_CurrentPage: React.RefObject<NSBoxRadio> = createRef();
26
- private NSBoxBoolean_SelectedItems: React.RefObject<NSBoxRadio> = createRef();
27
- private NSBoxBoolean_CustomPage: React.RefObject<NSBoxRadio> = createRef();
28
- private NSBoxBoolean_AllPage: React.RefObject<NSBoxRadio> = createRef();
29
- private NSBoxString_Pages: React.RefObject<NSBoxString> = createRef();
30
-
31
- constructor(props: NSPageSelectionModalProps<RowType>)
32
- {
33
- super(props);
34
- this.state = {
35
- selectedRadio: 'current_page'
36
- };
37
- this.onClickOutside = this.onClickOutside.bind(this);
38
- this.handleRadioChange = this.handleRadioChange.bind(this);
39
- }
40
- override componentDidMount(): void
41
- {
42
- document.addEventListener('mousedown', this.onClickOutside);
43
- }
44
- override componentWillUnmount(): void
45
- {
46
- document.removeEventListener('mousedown', this.onClickOutside);
47
- }
48
- parseCustomPage(pages_value: string): number[]
49
- {
50
- let ans: number[] = [];
51
- let pages = pages_value.split(',').map(p => p.trim()).filter(p => p);
52
- for (let i = 0; i < pages.length; i++)
53
- {
54
- const element = pages[i];
55
- if (element.includes("-"))
56
- {
57
- let ps = element.split('-').map(p => p.trim());
58
- if (ps.length === 2)
59
- {
60
- let from = parseInt(ps[0]);
61
- let to = parseInt(ps[1]);
62
- for (let p = from; p <= to; p++)
63
- ans.push(p);
64
- }
65
- else
66
- throw new Error("Parse Error for : " + element);
67
- }
68
- else
69
- {
70
- let p = parseInt(element);
71
- ans.push(p);
72
- }
73
- }
74
- ans.forEach(p =>
75
- {
76
- if (p < 1)
77
- throw new Error("Page number must be more than equal to 1");
78
- if (p > this.props.max_page)
79
- throw new Error("Page number must be less than equal to " + this.props.max_page);
80
- })
81
- return ans;
82
- }
83
- private onClickOutside(event: MouseEvent)
84
- {
85
- if (this.toastRef.current && !this.toastRef.current.contains(event.target as Node))
86
- {
87
- this.props.onClose();
88
- }
89
- }
90
- private handleRadioChange(selectedRadio: string)
91
- {
92
- this.setState({ selectedRadio });
93
- }
94
- override render()
95
- {
96
- return (
97
- <>
98
- {
99
- <>
100
- <div className={Styles.ns_print_container} ref={this.toastRef}>
101
- <div className={Styles.ns_header_print}>
102
- <img
103
- src="https://static.namirasoft.com/image/concept/close/blue.svg"
104
- alt="Close"
105
- width={24}
106
- height={24}
107
- onClick={(e) =>
108
- {
109
- e.stopPropagation();
110
- this.props.onClose();
111
- }}
112
- className={Styles.ns_close_icon}
113
- />
114
- <div className={Styles.ns_print_title}>
115
- <img
116
- src="https://static.namirasoft.com/image/concept/print/blue.svg"
117
- alt="Print"
118
- width={24}
119
- height={24}
120
- />
121
- <h2 className='m-0'>Page Selection</h2>
122
- </div>
123
- <NSSpace size={NSSpaceSizeType.SMALL} />
124
- <p className={Styles.ns_print_description}>Please select which pages you want to continue with</p>
125
- <NSSpace size={NSSpaceSizeType.SMALL} />
126
- <div className={Styles.ns_parent_checkboxs}>
127
- <NSBoxRadio
128
- defaultValue={true}
129
- ref={this.NSBoxBoolean_CurrentPage}
130
- title={"Current page"}
131
- required={false}
132
- name={"PageSelection"}
133
- isSelected={this.state.selectedRadio === 'current_page'}
134
- onClick={() => this.handleRadioChange('current_page')}
135
- />
136
- <NSBoxRadio
137
- ref={this.NSBoxBoolean_SelectedItems}
138
- title={"Only Selected Items"}
139
- required={false}
140
- name={"PageSelection"}
141
- isSelected={this.state.selectedRadio === 'selected_items'}
142
- onClick={() => this.handleRadioChange('selected_items')}
143
- />
144
- <NSBoxRadio
145
- ref={this.NSBoxBoolean_CustomPage}
146
- title={"Custom Pages"}
147
- required={false}
148
- name={"PageSelection"}
149
- isSelected={this.state.selectedRadio === 'custom_page'}
150
- onClick={() => this.handleRadioChange('custom_page')}
151
- />
152
- <NSBoxRadio
153
- ref={this.NSBoxBoolean_AllPage}
154
- title={"All Pages"}
155
- required={false}
156
- name={"PageSelection"}
157
- isSelected={this.state.selectedRadio === 'all_page'}
158
- onClick={() => this.handleRadioChange('all_page')}
159
- />
160
- </div>
161
- <NSSpace size={NSSpaceSizeType.MICRO} />
162
- {this.state.selectedRadio === 'custom_page' && (
163
- <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
164
- getError={value =>
165
- {
166
- try
167
- {
168
- this.parseCustomPage(value);
169
- return null;
170
- } catch (error: any)
171
- {
172
- return error.message;
173
- }
174
- }} />
175
- )}
176
- <NSSpace size={NSSpaceSizeType.SMALL} />
177
- <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
178
- {
179
- try
180
- {
181
- let items: RowType[] = [];
182
- if (this.NSBoxBoolean_CurrentPage.current?.getValue())
183
- {
184
- let is = await this.props.getItems(this.props.current_page, false);
185
- items.push(...is);
186
- }
187
- else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
188
- {
189
- let is = await this.props.getItems(this.props.current_page, true);
190
- items.push(...is);
191
- }
192
- else if (this.NSBoxBoolean_CustomPage.current?.getValue())
193
- {
194
- let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
195
- let pages = this.parseCustomPage(pages_value);
196
-
197
- for (let p = 0; p < pages.length; p++)
198
- {
199
- let is = await this.props.getItems(pages[p], false);
200
- items.push(...is);
201
- }
202
- }
203
- else if (this.NSBoxBoolean_AllPage.current?.getValue())
204
- {
205
- for (let p = 1; p <= this.props.max_page; p++)
206
- {
207
- let is = await this.props.getItems(p, false);
208
- items.push(...is);
209
- }
210
- }
211
- else
212
- { }
213
- this.props.onFinish(items);
214
- } catch (error)
215
- {
216
- // todo
217
- }
218
- }} />
219
- </div>
220
- </div>
221
- <div className={Styles.ns_toast_background}></div>
222
- </>
223
- }
224
- </>
225
- );
226
- }
1
+ import React, { Component, createRef } from 'react';
2
+ import { NSButtonBlue } from './NSButtonBlue';
3
+ import { NSBoxString } from './NSBoxString';
4
+ import { NSSpace, NSSpaceSizeType } from './NSSpace';
5
+ import Styles from './NSPageSelectionModal.module.css';
6
+ import { NSBoxRadio } from './NSBoxRadio';
7
+
8
+ export interface NSPageSelectionModalProps<RowType>
9
+ {
10
+ current_page: number;
11
+ max_page: number;
12
+ onClose: () => void;
13
+ getItems: (page: number, selected: boolean) => Promise<RowType[]>;
14
+ onFinish: (items: RowType[]) => void;
15
+ icon?: string;
16
+ }
17
+
18
+ interface NSPageSelectionModalState
19
+ {
20
+ selectedRadio: string;
21
+ }
22
+
23
+ export class NSPageSelectionModal<RowType> extends Component<NSPageSelectionModalProps<RowType>, NSPageSelectionModalState>
24
+ {
25
+ private toastRef: React.RefObject<HTMLDivElement> = createRef();
26
+ private NSBoxBoolean_CurrentPage: React.RefObject<NSBoxRadio> = createRef();
27
+ private NSBoxBoolean_SelectedItems: React.RefObject<NSBoxRadio> = createRef();
28
+ private NSBoxBoolean_CustomPage: React.RefObject<NSBoxRadio> = createRef();
29
+ private NSBoxBoolean_AllPage: React.RefObject<NSBoxRadio> = createRef();
30
+ private NSBoxString_Pages: React.RefObject<NSBoxString> = createRef();
31
+
32
+ constructor(props: NSPageSelectionModalProps<RowType>)
33
+ {
34
+ super(props);
35
+ this.state = {
36
+ selectedRadio: 'current_page'
37
+ };
38
+ this.onClickOutside = this.onClickOutside.bind(this);
39
+ this.handleRadioChange = this.handleRadioChange.bind(this);
40
+ }
41
+ override componentDidMount(): void
42
+ {
43
+ document.addEventListener('mousedown', this.onClickOutside);
44
+ }
45
+ override componentWillUnmount(): void
46
+ {
47
+ document.removeEventListener('mousedown', this.onClickOutside);
48
+ }
49
+ parseCustomPage(pages_value: string): number[]
50
+ {
51
+ let ans: number[] = [];
52
+ let pages = pages_value.split(',').map(p => p.trim()).filter(p => p);
53
+ for (let i = 0; i < pages.length; i++)
54
+ {
55
+ const element = pages[i];
56
+ if (element.includes("-"))
57
+ {
58
+ let ps = element.split('-').map(p => p.trim());
59
+ if (ps.length === 2)
60
+ {
61
+ let from = parseInt(ps[0]);
62
+ let to = parseInt(ps[1]);
63
+ for (let p = from; p <= to; p++)
64
+ ans.push(p);
65
+ }
66
+ else
67
+ throw new Error("Parse Error for : " + element);
68
+ }
69
+ else
70
+ {
71
+ let p = parseInt(element);
72
+ ans.push(p);
73
+ }
74
+ }
75
+ ans.forEach(p =>
76
+ {
77
+ if (p < 1)
78
+ throw new Error("Page number must be more than equal to 1");
79
+ if (p > this.props.max_page)
80
+ throw new Error("Page number must be less than equal to " + this.props.max_page);
81
+ })
82
+ return ans;
83
+ }
84
+ private onClickOutside(event: MouseEvent)
85
+ {
86
+ if (this.toastRef.current && !this.toastRef.current.contains(event.target as Node))
87
+ {
88
+ this.props.onClose();
89
+ }
90
+ }
91
+ private handleRadioChange(selectedRadio: string)
92
+ {
93
+ this.setState({ selectedRadio });
94
+ }
95
+ override render()
96
+ {
97
+ return (
98
+ <>
99
+ {
100
+ <>
101
+ <div className={Styles.ns_print_container} ref={this.toastRef}>
102
+ <div className={Styles.ns_header_print}>
103
+ <img
104
+ src="https://static.namirasoft.com/image/concept/close/blue.svg"
105
+ alt="Close"
106
+ width={24}
107
+ height={24}
108
+ onClick={(e) =>
109
+ {
110
+ e.stopPropagation();
111
+ this.props.onClose();
112
+ }}
113
+ className={Styles.ns_close_icon}
114
+ />
115
+ <div className={Styles.ns_print_title}>
116
+ <img
117
+ src={this.props.icon && this.props.icon}
118
+ alt="Print"
119
+ width={24}
120
+ height={24}
121
+ />
122
+ <h2 className='m-0'>Page Selection</h2>
123
+ </div>
124
+ <NSSpace size={NSSpaceSizeType.SMALL} />
125
+ <p className={Styles.ns_print_description}>Please select which pages you want to continue with</p>
126
+ <NSSpace size={NSSpaceSizeType.SMALL} />
127
+ <div className={Styles.ns_parent_checkboxs}>
128
+ <NSBoxRadio
129
+ defaultValue={true}
130
+ ref={this.NSBoxBoolean_CurrentPage}
131
+ title={"Current page"}
132
+ required={false}
133
+ name={"PageSelection"}
134
+ isSelected={this.state.selectedRadio === 'current_page'}
135
+ onClick={() => this.handleRadioChange('current_page')}
136
+ />
137
+ <NSBoxRadio
138
+ ref={this.NSBoxBoolean_SelectedItems}
139
+ title={"Only Selected Items"}
140
+ required={false}
141
+ name={"PageSelection"}
142
+ isSelected={this.state.selectedRadio === 'selected_items'}
143
+ onClick={() => this.handleRadioChange('selected_items')}
144
+ />
145
+ <NSBoxRadio
146
+ ref={this.NSBoxBoolean_CustomPage}
147
+ title={"Custom Pages"}
148
+ required={false}
149
+ name={"PageSelection"}
150
+ isSelected={this.state.selectedRadio === 'custom_page'}
151
+ onClick={() => this.handleRadioChange('custom_page')}
152
+ />
153
+ <NSBoxRadio
154
+ ref={this.NSBoxBoolean_AllPage}
155
+ title={"All Pages"}
156
+ required={false}
157
+ name={"PageSelection"}
158
+ isSelected={this.state.selectedRadio === 'all_page'}
159
+ onClick={() => this.handleRadioChange('all_page')}
160
+ />
161
+ </div>
162
+ <NSSpace size={NSSpaceSizeType.MICRO} />
163
+ {this.state.selectedRadio === 'custom_page' && (
164
+ <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
165
+ getError={value =>
166
+ {
167
+ try
168
+ {
169
+ this.parseCustomPage(value);
170
+ return null;
171
+ } catch (error: any)
172
+ {
173
+ return error.message;
174
+ }
175
+ }} />
176
+ )}
177
+ <NSSpace size={NSSpaceSizeType.SMALL} />
178
+ <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
179
+ {
180
+ try
181
+ {
182
+ let items: RowType[] = [];
183
+ if (this.NSBoxBoolean_CurrentPage.current?.getValue())
184
+ {
185
+ let is = await this.props.getItems(this.props.current_page, false);
186
+ items.push(...is);
187
+ }
188
+ else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
189
+ {
190
+ let is = await this.props.getItems(this.props.current_page, true);
191
+ items.push(...is);
192
+ }
193
+ else if (this.NSBoxBoolean_CustomPage.current?.getValue())
194
+ {
195
+ let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
196
+ let pages = this.parseCustomPage(pages_value);
197
+
198
+ for (let p = 0; p < pages.length; p++)
199
+ {
200
+ let is = await this.props.getItems(pages[p], false);
201
+ items.push(...is);
202
+ }
203
+ }
204
+ else if (this.NSBoxBoolean_AllPage.current?.getValue())
205
+ {
206
+ for (let p = 1; p <= this.props.max_page; p++)
207
+ {
208
+ let is = await this.props.getItems(p, false);
209
+ items.push(...is);
210
+ }
211
+ }
212
+ else
213
+ { }
214
+ this.props.onFinish(items);
215
+ } catch (error)
216
+ {
217
+ // todo
218
+ }
219
+ }} />
220
+ </div>
221
+ </div>
222
+ <div className={Styles.ns_toast_background}></div>
223
+ </>
224
+ }
225
+ </>
226
+ );
227
+ }
227
228
  }