namirasoft-site-react 1.4.112 → 1.4.113

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (270) hide show
  1. package/.dockerignore +86 -86
  2. package/.env.template +10 -10
  3. package/Dockerfile +18 -18
  4. package/config-overrides.js +72 -71
  5. package/dist/App.css +58 -0
  6. package/dist/components/NSAccordion.module.css +4 -4
  7. package/dist/components/NSActionMenu.js +2 -2
  8. package/dist/components/NSActionMenu.module.css +101 -101
  9. package/dist/components/NSAssistantButton.module.css +135 -135
  10. package/dist/components/NSBarAction.module.css +97 -97
  11. package/dist/components/NSBarAlert.module.css +69 -69
  12. package/dist/components/NSBarHeroBanner.module.css +42 -42
  13. package/dist/components/NSBarNotification.module.css +34 -34
  14. package/dist/components/NSBarTitle.module.css +9 -9
  15. package/dist/components/NSBox.module.css +126 -126
  16. package/dist/components/NSBoxBoolean.module.css +88 -88
  17. package/dist/components/NSBoxCombo.module.css +6 -6
  18. package/dist/components/NSBoxCopy.module.css +43 -43
  19. package/dist/components/NSBoxDate.module.css +56 -56
  20. package/dist/components/NSBoxDateTime.module.css +51 -51
  21. package/dist/components/NSBoxEntity.module.css +21 -21
  22. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  23. package/dist/components/NSBoxFile.module.css +4 -4
  24. package/dist/components/NSBoxLabel.module.css +14 -14
  25. package/dist/components/NSBoxRadio.module.css +70 -70
  26. package/dist/components/NSBoxTextArea.module.css +83 -83
  27. package/dist/components/NSButton.module.css +42 -42
  28. package/dist/components/NSButtonBlue.module.css +4 -4
  29. package/dist/components/NSButtonGreen.module.css +4 -4
  30. package/dist/components/NSButtonRed.module.css +4 -4
  31. package/dist/components/NSCard.module.css +114 -114
  32. package/dist/components/NSCardScreenshot.module.css +41 -41
  33. package/dist/components/NSChartColumn.module.css +7 -7
  34. package/dist/components/NSChartPie.module.css +0 -0
  35. package/dist/components/NSChartTable.module.css +21 -21
  36. package/dist/components/NSCopyToClipboard.d.ts +7 -0
  37. package/dist/components/NSCopyToClipboard.js +13 -0
  38. package/dist/components/NSCopyToClipboard.js.map +1 -0
  39. package/dist/components/NSCopyToClipboard.module.css +44 -0
  40. package/dist/components/NSDialog.module.css +106 -106
  41. package/dist/components/NSDownTimer.module.css +55 -55
  42. package/dist/components/NSDownload.module.css +46 -46
  43. package/dist/components/NSElectronicCard.module.css +60 -60
  44. package/dist/components/NSEntityBar.module.css +77 -77
  45. package/dist/components/NSEntityCardBackground.module.css +27 -27
  46. package/dist/components/NSFilterBox.module.css +62 -62
  47. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  48. package/dist/components/NSFilterItem.module.css +23 -23
  49. package/dist/components/NSFooter.module.css +123 -123
  50. package/dist/components/NSGroupedList.module.css +72 -72
  51. package/dist/components/NSHeader.module.css +291 -291
  52. package/dist/components/NSHeaderScreenshot.module.css +35 -35
  53. package/dist/components/NSLayout.module.css +13 -13
  54. package/dist/components/NSLine.module.css +12 -12
  55. package/dist/components/NSLink.module.css +36 -36
  56. package/dist/components/NSLoading.module.css +30 -30
  57. package/dist/components/NSNoData.module.css +8 -8
  58. package/dist/components/NSPageSelectionModal.module.css +103 -103
  59. package/dist/components/NSPagination.module.css +110 -110
  60. package/dist/components/NSPanel.module.css +46 -46
  61. package/dist/components/NSRadioButton.d.ts +25 -0
  62. package/dist/components/NSRadioButton.js +49 -0
  63. package/dist/components/NSRadioButton.js.map +1 -0
  64. package/dist/components/NSRange.module.css +66 -66
  65. package/dist/components/NSSection.module.css +10 -10
  66. package/dist/components/NSSectionBars.module.css +10 -10
  67. package/dist/components/NSSectionCards.module.css +38 -38
  68. package/dist/components/NSTabPage.module.css +59 -59
  69. package/dist/components/NSTable.module.css +290 -290
  70. package/dist/components/NSTag.module.css +52 -52
  71. package/dist/components/NSTimeTable.module.css +6 -6
  72. package/dist/components/NSTimelineMonthly.module.css +71 -71
  73. package/dist/components/NSTitle.module.css +15 -15
  74. package/dist/formatter/ForeignIDFormatter.d.ts +4 -0
  75. package/dist/formatter/ForeignIDFormatter.js +7 -0
  76. package/dist/formatter/ForeignIDFormatter.js.map +1 -0
  77. package/dist/index.css +6 -0
  78. package/dist/pages/NSNotFoundPage.module.css +17 -17
  79. package/dist/pages/NSUpdating.module.css +35 -35
  80. package/package.json +75 -75
  81. package/public/index.html +38 -38
  82. package/src/App.css +57 -57
  83. package/src/App.tsx +372 -372
  84. package/src/Color.tsx +10 -10
  85. package/src/CopyToClipboard.ts +6 -6
  86. package/src/Validator.ts +117 -117
  87. package/src/components/NSAccordion.module.css +4 -4
  88. package/src/components/NSAccordion.tsx +51 -51
  89. package/src/components/NSActionMenu.module.css +101 -101
  90. package/src/components/NSActionMenu.tsx +90 -90
  91. package/src/components/NSAssistantButton.module.css +135 -135
  92. package/src/components/NSAssistantButton.tsx +70 -70
  93. package/src/components/NSBarAction.module.css +97 -97
  94. package/src/components/NSBarAction.tsx +89 -89
  95. package/src/components/NSBarAlert.module.css +69 -69
  96. package/src/components/NSBarAlert.tsx +30 -30
  97. package/src/components/NSBarHeroBanner.module.css +42 -42
  98. package/src/components/NSBarHeroBanner.tsx +61 -61
  99. package/src/components/NSBarNotification.module.css +34 -34
  100. package/src/components/NSBarNotification.tsx +87 -87
  101. package/src/components/NSBarTitle.module.css +9 -9
  102. package/src/components/NSBarTitle.tsx +29 -29
  103. package/src/components/NSBox.module.css +126 -126
  104. package/src/components/NSBoxBoolean.module.css +88 -88
  105. package/src/components/NSBoxBoolean.tsx +124 -124
  106. package/src/components/NSBoxBooleans.tsx +159 -159
  107. package/src/components/NSBoxCombo.module.css +6 -6
  108. package/src/components/NSBoxCombo.tsx +151 -151
  109. package/src/components/NSBoxCopy.module.css +43 -43
  110. package/src/components/NSBoxCopy.tsx +41 -41
  111. package/src/components/NSBoxDate.module.css +56 -56
  112. package/src/components/NSBoxDate.tsx +88 -88
  113. package/src/components/NSBoxDateTime.module.css +51 -51
  114. package/src/components/NSBoxDateTime.tsx +89 -89
  115. package/src/components/NSBoxDouble.tsx +92 -92
  116. package/src/components/NSBoxDuration.tsx +92 -92
  117. package/src/components/NSBoxEmail.tsx +103 -103
  118. package/src/components/NSBoxEntity.module.css +21 -21
  119. package/src/components/NSBoxEntity.tsx +197 -197
  120. package/src/components/NSBoxEnum.tsx +55 -55
  121. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  122. package/src/components/NSBoxErrorNotifier.tsx +32 -32
  123. package/src/components/NSBoxFile.module.css +4 -4
  124. package/src/components/NSBoxFile.tsx +124 -124
  125. package/src/components/NSBoxIPV4.tsx +97 -97
  126. package/src/components/NSBoxIPV6.tsx +94 -94
  127. package/src/components/NSBoxInteger.tsx +94 -94
  128. package/src/components/NSBoxLabel.module.css +14 -14
  129. package/src/components/NSBoxLabel.tsx +29 -29
  130. package/src/components/NSBoxPassword.tsx +90 -90
  131. package/src/components/NSBoxPhone.tsx +97 -97
  132. package/src/components/NSBoxPrice.tsx +92 -92
  133. package/src/components/NSBoxRadio.module.css +70 -70
  134. package/src/components/NSBoxRadio.tsx +111 -111
  135. package/src/components/NSBoxSearch.tsx +107 -107
  136. package/src/components/NSBoxString.tsx +106 -106
  137. package/src/components/NSBoxTextArea.module.css +83 -83
  138. package/src/components/NSBoxTextArea.tsx +112 -112
  139. package/src/components/NSBoxTime.tsx +92 -92
  140. package/src/components/NSButton.module.css +42 -42
  141. package/src/components/NSButton.tsx +25 -25
  142. package/src/components/NSButtonBlue.module.css +4 -4
  143. package/src/components/NSButtonBlue.tsx +19 -19
  144. package/src/components/NSButtonGreen.module.css +4 -4
  145. package/src/components/NSButtonGreen.tsx +19 -19
  146. package/src/components/NSButtonRed.module.css +4 -4
  147. package/src/components/NSButtonRed.tsx +19 -19
  148. package/src/components/NSCard.module.css +114 -114
  149. package/src/components/NSCard.tsx +63 -63
  150. package/src/components/NSCardScreenshot.module.css +41 -41
  151. package/src/components/NSCardScreenshot.tsx +31 -31
  152. package/src/components/NSChartColumn.module.css +7 -7
  153. package/src/components/NSChartColumn.tsx +106 -106
  154. package/src/components/NSChartDoughnut.tsx +108 -108
  155. package/src/components/NSChartPie.tsx +105 -105
  156. package/src/components/NSChartRange.tsx +16 -16
  157. package/src/components/NSChartTable.module.css +21 -21
  158. package/src/components/NSChartTable.tsx +94 -94
  159. package/src/components/NSCopy.tsx +67 -67
  160. package/src/components/NSDeleteDialog.tsx +26 -26
  161. package/src/components/NSDialog.module.css +106 -106
  162. package/src/components/NSDialog.tsx +56 -56
  163. package/src/components/NSDownTimer.module.css +55 -55
  164. package/src/components/NSDownTimer.tsx +77 -77
  165. package/src/components/NSDownload.module.css +46 -46
  166. package/src/components/NSDownload.tsx +62 -62
  167. package/src/components/NSElectronicCard.module.css +60 -60
  168. package/src/components/NSElectronicCard.tsx +45 -45
  169. package/src/components/NSEntityBar.module.css +77 -77
  170. package/src/components/NSEntityBar.tsx +27 -27
  171. package/src/components/NSEntityCardBackground.module.css +27 -27
  172. package/src/components/NSEntityCardBackground.tsx +34 -34
  173. package/src/components/NSFilterBox.module.css +62 -62
  174. package/src/components/NSFilterBox.tsx +360 -360
  175. package/src/components/NSFilterBoxDialog.module.css +36 -36
  176. package/src/components/NSFilterBoxDialog.tsx +74 -74
  177. package/src/components/NSFilterItem.module.css +23 -23
  178. package/src/components/NSFilterItem.tsx +73 -73
  179. package/src/components/NSFooter.module.css +123 -123
  180. package/src/components/NSFooter.tsx +289 -289
  181. package/src/components/NSGroupedList.module.css +72 -72
  182. package/src/components/NSGroupedList.tsx +115 -115
  183. package/src/components/NSHeader.module.css +291 -291
  184. package/src/components/NSHeader.tsx +250 -250
  185. package/src/components/NSHeaderScreenshot.module.css +35 -35
  186. package/src/components/NSHeaderScreenshot.tsx +38 -38
  187. package/src/components/NSInfoDialog.tsx +36 -36
  188. package/src/components/NSLayout.module.css +13 -13
  189. package/src/components/NSLayout.tsx +109 -109
  190. package/src/components/NSLine.module.css +12 -12
  191. package/src/components/NSLine.tsx +15 -15
  192. package/src/components/NSLink.module.css +36 -36
  193. package/src/components/NSLink.tsx +25 -25
  194. package/src/components/NSLinkBlue.tsx +20 -20
  195. package/src/components/NSLinkGreen.tsx +5 -5
  196. package/src/components/NSLinkRed.tsx +5 -5
  197. package/src/components/NSLoading.module.css +30 -30
  198. package/src/components/NSLoading.tsx +20 -20
  199. package/src/components/NSNoData.module.css +8 -8
  200. package/src/components/NSNoData.tsx +24 -24
  201. package/src/components/NSPageSelectionModal.module.css +103 -103
  202. package/src/components/NSPageSelectionModal.tsx +228 -228
  203. package/src/components/NSPagination.module.css +110 -110
  204. package/src/components/NSPagination.tsx +191 -191
  205. package/src/components/NSPanel.module.css +46 -46
  206. package/src/components/NSPanel.tsx +19 -19
  207. package/src/components/NSProductList.tsx +43 -43
  208. package/src/components/NSRange.module.css +66 -66
  209. package/src/components/NSRange.tsx +81 -81
  210. package/src/components/NSRepeater.tsx +179 -179
  211. package/src/components/NSSection.module.css +10 -10
  212. package/src/components/NSSection.tsx +23 -23
  213. package/src/components/NSSectionBars.module.css +10 -10
  214. package/src/components/NSSectionBars.tsx +25 -25
  215. package/src/components/NSSectionCards.module.css +38 -38
  216. package/src/components/NSSectionCards.tsx +51 -51
  217. package/src/components/NSSectionTitle.tsx +21 -21
  218. package/src/components/NSSpace.tsx +28 -28
  219. package/src/components/NSTabPage.module.css +59 -59
  220. package/src/components/NSTabPage.tsx +78 -78
  221. package/src/components/NSTable.module.css +290 -290
  222. package/src/components/NSTable.tsx +436 -436
  223. package/src/components/NSTag.module.css +52 -52
  224. package/src/components/NSTag.tsx +78 -78
  225. package/src/components/NSTimeTable.module.css +6 -6
  226. package/src/components/NSTimeTable.tsx +49 -49
  227. package/src/components/NSTimelineMonthly.module.css +71 -71
  228. package/src/components/NSTimelineMonthly.tsx +42 -42
  229. package/src/components/NSTitle.module.css +15 -15
  230. package/src/components/NSTitle.tsx +19 -19
  231. package/src/formatter/BackColorFormatter.tsx +22 -22
  232. package/src/formatter/BaseColumnFormatter.ts +16 -16
  233. package/src/formatter/BooleanFormatter.ts +22 -22
  234. package/src/formatter/DateFormatter.ts +20 -20
  235. package/src/formatter/DateTimeFormatter.ts +20 -20
  236. package/src/formatter/DurationFormatter.ts +13 -13
  237. package/src/formatter/EmailFormatter.ts +13 -13
  238. package/src/formatter/EnumFormatter.ts +13 -13
  239. package/src/formatter/FloatFormatter.ts +16 -16
  240. package/src/formatter/ForeColorFormatter.tsx +22 -22
  241. package/src/formatter/IDFormatter.tsx +28 -28
  242. package/src/formatter/IPFormatter.ts +13 -13
  243. package/src/formatter/IntegerFormatter.ts +16 -16
  244. package/src/formatter/JsonFormatter.ts +14 -14
  245. package/src/formatter/MoneyFormatter.ts +16 -16
  246. package/src/formatter/PhoneFormatter.ts +13 -13
  247. package/src/formatter/StringFormatter.ts +13 -13
  248. package/src/formatter/TimeFormatter.ts +21 -21
  249. package/src/formatter/UnknowFormatter.ts +14 -14
  250. package/src/index.tsx +7 -7
  251. package/src/main.ts +117 -117
  252. package/src/pages/NSNotFoundPage.module.css +17 -17
  253. package/src/pages/NSNotFoundPage.tsx +11 -11
  254. package/src/pages/NSUpdating.module.css +35 -35
  255. package/src/pages/NSUpdating.tsx +32 -32
  256. package/src/props/IBaseComponentProps.ts +8 -8
  257. package/src/props/IHeaderIconProps.ts +10 -10
  258. package/src/props/IHeaderProps.ts +7 -7
  259. package/src/props/IImageProps.ts +4 -4
  260. package/src/props/ILinkProps.ts +5 -5
  261. package/src/props/IValidationNumberProps.ts +4 -4
  262. package/src/props/IValidationProps.ts +7 -7
  263. package/src/props/IValidationRegexProps.ts +4 -4
  264. package/src/props/IValidationStringProps.ts +4 -4
  265. package/src/routing/INSRouterMaker.ts +6 -6
  266. package/src/routing/INSRouterProps.ts +5 -5
  267. package/src/routing/INSRouterState.ts +5 -5
  268. package/src/routing/NSRouterMaker.tsx +33 -33
  269. package/src/routing/Notifier.ts +79 -79
  270. package/tsconfig.json +43 -43
@@ -1,229 +1,229 @@
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
- {/* todo: input id for check when click on labels */}
129
- <NSBoxRadio
130
- defaultValue={true}
131
- ref={this.NSBoxBoolean_CurrentPage}
132
- title={"Current page"}
133
- required={false}
134
- name={"PageSelection"}
135
- isSelected={this.state.selectedRadio === 'current_page'}
136
- onClicked={() => this.handleRadioChange('current_page')}
137
- />
138
- <NSBoxRadio
139
- ref={this.NSBoxBoolean_SelectedItems}
140
- title={"Only Selected Items"}
141
- required={false}
142
- name={"PageSelection"}
143
- isSelected={this.state.selectedRadio === 'selected_items'}
144
- onClicked={() => this.handleRadioChange('selected_items')}
145
- />
146
- <NSBoxRadio
147
- ref={this.NSBoxBoolean_CustomPage}
148
- title={"Custom Pages"}
149
- required={false}
150
- name={"PageSelection"}
151
- isSelected={this.state.selectedRadio === 'custom_page'}
152
- onClicked={() => this.handleRadioChange('custom_page')}
153
- />
154
- <NSBoxRadio
155
- ref={this.NSBoxBoolean_AllPage}
156
- title={"All Pages"}
157
- required={false}
158
- name={"PageSelection"}
159
- isSelected={this.state.selectedRadio === 'all_page'}
160
- onClicked={() => this.handleRadioChange('all_page')}
161
- />
162
- </div>
163
- <NSSpace size={NSSpaceSizeType.MICRO} />
164
- {this.state.selectedRadio === 'custom_page' && (
165
- <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
166
- getError={value =>
167
- {
168
- try
169
- {
170
- this.parseCustomPage(value);
171
- return null;
172
- } catch (error: any)
173
- {
174
- return error.message;
175
- }
176
- }} />
177
- )}
178
- <NSSpace size={NSSpaceSizeType.SMALL} />
179
- <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
180
- {
181
- try
182
- {
183
- let items: RowType[] = [];
184
- if (this.NSBoxBoolean_CurrentPage.current?.getValue())
185
- {
186
- let is = await this.props.getItems(this.props.current_page, false);
187
- items.push(...is);
188
- }
189
- else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
190
- {
191
- let is = await this.props.getItems(this.props.current_page, true);
192
- items.push(...is);
193
- }
194
- else if (this.NSBoxBoolean_CustomPage.current?.getValue())
195
- {
196
- let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
197
- let pages = this.parseCustomPage(pages_value);
198
-
199
- for (let p = 0; p < pages.length; p++)
200
- {
201
- let is = await this.props.getItems(pages[p], false);
202
- items.push(...is);
203
- }
204
- }
205
- else if (this.NSBoxBoolean_AllPage.current?.getValue())
206
- {
207
- for (let p = 1; p <= this.props.max_page; p++)
208
- {
209
- let is = await this.props.getItems(p, false);
210
- items.push(...is);
211
- }
212
- }
213
- else
214
- { }
215
- this.props.onFinish(items);
216
- } catch (error)
217
- {
218
- // todo
219
- }
220
- }} />
221
- </div>
222
- </div>
223
- <div className={Styles.ns_toast_background}></div>
224
- </>
225
- }
226
- </>
227
- );
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
+ 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
+ {/* todo: input id for check when click on labels */}
129
+ <NSBoxRadio
130
+ defaultValue={true}
131
+ ref={this.NSBoxBoolean_CurrentPage}
132
+ title={"Current page"}
133
+ required={false}
134
+ name={"PageSelection"}
135
+ isSelected={this.state.selectedRadio === 'current_page'}
136
+ onClicked={() => this.handleRadioChange('current_page')}
137
+ />
138
+ <NSBoxRadio
139
+ ref={this.NSBoxBoolean_SelectedItems}
140
+ title={"Only Selected Items"}
141
+ required={false}
142
+ name={"PageSelection"}
143
+ isSelected={this.state.selectedRadio === 'selected_items'}
144
+ onClicked={() => this.handleRadioChange('selected_items')}
145
+ />
146
+ <NSBoxRadio
147
+ ref={this.NSBoxBoolean_CustomPage}
148
+ title={"Custom Pages"}
149
+ required={false}
150
+ name={"PageSelection"}
151
+ isSelected={this.state.selectedRadio === 'custom_page'}
152
+ onClicked={() => this.handleRadioChange('custom_page')}
153
+ />
154
+ <NSBoxRadio
155
+ ref={this.NSBoxBoolean_AllPage}
156
+ title={"All Pages"}
157
+ required={false}
158
+ name={"PageSelection"}
159
+ isSelected={this.state.selectedRadio === 'all_page'}
160
+ onClicked={() => this.handleRadioChange('all_page')}
161
+ />
162
+ </div>
163
+ <NSSpace size={NSSpaceSizeType.MICRO} />
164
+ {this.state.selectedRadio === 'custom_page' && (
165
+ <NSBoxString ref={this.NSBoxString_Pages} classList={[Styles.ns_w_box_string]} required={false} title="Custom Pages"
166
+ getError={value =>
167
+ {
168
+ try
169
+ {
170
+ this.parseCustomPage(value);
171
+ return null;
172
+ } catch (error: any)
173
+ {
174
+ return error.message;
175
+ }
176
+ }} />
177
+ )}
178
+ <NSSpace size={NSSpaceSizeType.SMALL} />
179
+ <NSButtonBlue style={{ width: "100%" }} title='Apply' onClick={async () =>
180
+ {
181
+ try
182
+ {
183
+ let items: RowType[] = [];
184
+ if (this.NSBoxBoolean_CurrentPage.current?.getValue())
185
+ {
186
+ let is = await this.props.getItems(this.props.current_page, false);
187
+ items.push(...is);
188
+ }
189
+ else if (this.NSBoxBoolean_SelectedItems.current?.getValue())
190
+ {
191
+ let is = await this.props.getItems(this.props.current_page, true);
192
+ items.push(...is);
193
+ }
194
+ else if (this.NSBoxBoolean_CustomPage.current?.getValue())
195
+ {
196
+ let pages_value = this.NSBoxString_Pages.current?.getValue() ?? "";
197
+ let pages = this.parseCustomPage(pages_value);
198
+
199
+ for (let p = 0; p < pages.length; p++)
200
+ {
201
+ let is = await this.props.getItems(pages[p], false);
202
+ items.push(...is);
203
+ }
204
+ }
205
+ else if (this.NSBoxBoolean_AllPage.current?.getValue())
206
+ {
207
+ for (let p = 1; p <= this.props.max_page; p++)
208
+ {
209
+ let is = await this.props.getItems(p, false);
210
+ items.push(...is);
211
+ }
212
+ }
213
+ else
214
+ { }
215
+ this.props.onFinish(items);
216
+ } catch (error)
217
+ {
218
+ // todo
219
+ }
220
+ }} />
221
+ </div>
222
+ </div>
223
+ <div className={Styles.ns_toast_background}></div>
224
+ </>
225
+ }
226
+ </>
227
+ );
228
+ }
229
229
  }
@@ -1,111 +1,111 @@
1
- .ns_pagination_container {
2
- display: flex;
3
- flex-direction: row;
4
- align-items: center;
5
- justify-content: center;
6
- text-align: left;
7
- font-size: 14px;
8
- justify-items: center;
9
- width: 100%;
10
- max-width: max-content;
11
- flex-wrap: wrap;
12
- gap: 16px 0;
13
- }
14
-
15
- .ns_select_number_parent {
16
- font-weight: 500;
17
- border-radius: 50px;
18
- height: 32px;
19
- width: 32px;
20
- text-align: center;
21
- display: flex;
22
- justify-content: center;
23
- align-items: center;
24
- }
25
-
26
- .ns_paginate_link {
27
- color: rgba(20, 27, 92, 1);
28
- text-decoration: none;
29
- font-size: 14px;
30
- font-weight: 600;
31
- line-height: 22px;
32
- font-family: inherit;
33
- }
34
-
35
- .ns_select_number {
36
- color: rgba(20, 27, 92, 1);
37
- font-weight: 500;
38
- background-color: rgb(255, 255, 255);
39
- border: 2px solid rgba(20, 27, 92, 1);
40
- border-radius: 50px;
41
- border-radius: 50px;
42
- height: 32px;
43
- width: 32px;
44
- text-align: center;
45
- display: flex;
46
- justify-content: center;
47
- align-items: center;
48
- }
49
-
50
- .ns_pagination_left_ellipses {
51
- padding-bottom: 10px;
52
- }
53
-
54
- .ns_pagination_left_ellipses a {
55
- color: rgba(20, 27, 92, 1);
56
- font-size: 24px;
57
- font-weight: 700;
58
- }
59
-
60
- .ns_pagination_right_ellipses {
61
- padding-bottom: 10px;
62
- }
63
-
64
- .ns_pagination_right_ellipses a {
65
- color: rgba(20, 27, 92, 1);
66
- font-size: 24px;
67
- font-weight: 700;
68
- }
69
-
70
- .ns_pagination_info {
71
- margin-left: 12px;
72
- width: fit-content;
73
- min-width: 140px;
74
- height: 48px;
75
- display: flex;
76
- flex-direction: row;
77
- justify-content: center;
78
- gap: 12px;
79
- min-width: 248px;
80
- }
81
-
82
- .ns_pagination_info h6 {
83
- background-color: rgb(255, 255, 255);
84
- width: 124px;
85
- display: flex;
86
- align-items: center;
87
- justify-content: center;
88
- height: 100%;
89
- color: rgba(20, 27, 92, 1);
90
- padding-left: 16px 24px;
91
- text-align: center;
92
- border-radius: 8px;
93
- border: 1px solid black;
94
- }
95
-
96
- .ns_pagination_combobox div {
97
- width: 74px;
98
- margin: 0;
99
- padding: 0;
100
- }
101
-
102
- .ns_pagination_combobox span {
103
- margin: 0
104
- }
105
-
106
- @media only screen and (min-width: 480px) {
107
- .ns_pagination_container {
108
- justify-content: space-between;
109
- flex-wrap: nowrap;
110
- }
1
+ .ns_pagination_container {
2
+ display: flex;
3
+ flex-direction: row;
4
+ align-items: center;
5
+ justify-content: center;
6
+ text-align: left;
7
+ font-size: 14px;
8
+ justify-items: center;
9
+ width: 100%;
10
+ max-width: max-content;
11
+ flex-wrap: wrap;
12
+ gap: 16px 0;
13
+ }
14
+
15
+ .ns_select_number_parent {
16
+ font-weight: 500;
17
+ border-radius: 50px;
18
+ height: 32px;
19
+ width: 32px;
20
+ text-align: center;
21
+ display: flex;
22
+ justify-content: center;
23
+ align-items: center;
24
+ }
25
+
26
+ .ns_paginate_link {
27
+ color: rgba(20, 27, 92, 1);
28
+ text-decoration: none;
29
+ font-size: 14px;
30
+ font-weight: 600;
31
+ line-height: 22px;
32
+ font-family: inherit;
33
+ }
34
+
35
+ .ns_select_number {
36
+ color: rgba(20, 27, 92, 1);
37
+ font-weight: 500;
38
+ background-color: rgb(255, 255, 255);
39
+ border: 2px solid rgba(20, 27, 92, 1);
40
+ border-radius: 50px;
41
+ border-radius: 50px;
42
+ height: 32px;
43
+ width: 32px;
44
+ text-align: center;
45
+ display: flex;
46
+ justify-content: center;
47
+ align-items: center;
48
+ }
49
+
50
+ .ns_pagination_left_ellipses {
51
+ padding-bottom: 10px;
52
+ }
53
+
54
+ .ns_pagination_left_ellipses a {
55
+ color: rgba(20, 27, 92, 1);
56
+ font-size: 24px;
57
+ font-weight: 700;
58
+ }
59
+
60
+ .ns_pagination_right_ellipses {
61
+ padding-bottom: 10px;
62
+ }
63
+
64
+ .ns_pagination_right_ellipses a {
65
+ color: rgba(20, 27, 92, 1);
66
+ font-size: 24px;
67
+ font-weight: 700;
68
+ }
69
+
70
+ .ns_pagination_info {
71
+ margin-left: 12px;
72
+ width: fit-content;
73
+ min-width: 140px;
74
+ height: 48px;
75
+ display: flex;
76
+ flex-direction: row;
77
+ justify-content: center;
78
+ gap: 12px;
79
+ min-width: 248px;
80
+ }
81
+
82
+ .ns_pagination_info h6 {
83
+ background-color: rgb(255, 255, 255);
84
+ width: 124px;
85
+ display: flex;
86
+ align-items: center;
87
+ justify-content: center;
88
+ height: 100%;
89
+ color: rgba(20, 27, 92, 1);
90
+ padding-left: 16px 24px;
91
+ text-align: center;
92
+ border-radius: 8px;
93
+ border: 1px solid black;
94
+ }
95
+
96
+ .ns_pagination_combobox div {
97
+ width: 74px;
98
+ margin: 0;
99
+ padding: 0;
100
+ }
101
+
102
+ .ns_pagination_combobox span {
103
+ margin: 0
104
+ }
105
+
106
+ @media only screen and (min-width: 480px) {
107
+ .ns_pagination_container {
108
+ justify-content: space-between;
109
+ flex-wrap: nowrap;
110
+ }
111
111
  }