namirasoft-site-react 1.3.347 → 1.3.349

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 (363) hide show
  1. package/.dockerignore +86 -86
  2. package/Dockerfile +18 -18
  3. package/config-overrides.js +70 -70
  4. package/dist/assets/images/404 image.svg +9 -9
  5. package/dist/assets/images/404 image_mobile.svg +9 -9
  6. package/dist/assets/images/arrow.svg +3 -3
  7. package/dist/assets/images/danger.svg +3 -3
  8. package/dist/assets/images/exit.svg +3 -3
  9. package/dist/assets/images/icon-input-copy.svg +3 -3
  10. package/dist/assets/images/icon-input-date.svg +9 -9
  11. package/dist/assets/images/icon-input-duration.svg +9 -9
  12. package/dist/assets/images/icon-input-email.svg +9 -9
  13. package/dist/assets/images/icon-input-float.svg +9 -9
  14. package/dist/assets/images/icon-input-integer.svg +9 -9
  15. package/dist/assets/images/icon-input-ip.svg +9 -9
  16. package/dist/assets/images/icon-input-phone.svg +9 -9
  17. package/dist/assets/images/icon-input-price.svg +9 -9
  18. package/dist/assets/images/icon-input-search.svg +3 -3
  19. package/dist/assets/images/icon-input-string.svg +9 -9
  20. package/dist/assets/images/icon-input-text.svg +9 -9
  21. package/dist/assets/images/icon-input-time.svg +9 -9
  22. package/dist/assets/images/icon-select-box.svg +3 -3
  23. package/dist/assets/images/logo.svg +9 -9
  24. package/dist/assets/images/menu.svg +3 -3
  25. package/dist/assets/images/namira.svg +9 -9
  26. package/dist/assets/images/rectangle.svg +3 -3
  27. package/dist/components/NSActionMenu.js +2 -2
  28. package/dist/components/NSActionMenu.module.css +75 -75
  29. package/dist/components/NSAssistantButton.module.css +133 -133
  30. package/dist/components/NSBarAction.module.css +87 -87
  31. package/dist/components/NSBarHeroBanner.module.css +42 -42
  32. package/dist/components/NSBarNotification.module.css +34 -34
  33. package/dist/components/NSBarTitle.module.css +9 -9
  34. package/dist/components/NSBox.module.css +123 -123
  35. package/dist/components/NSBoxBoolean.module.css +53 -53
  36. package/dist/components/NSBoxCombo.module.css +16 -16
  37. package/dist/components/NSBoxDate.module.css +39 -39
  38. package/dist/components/NSBoxEntity.module.css +25 -25
  39. package/dist/components/NSBoxErrorNotifier.module.css +2 -2
  40. package/dist/components/NSBoxLabel.module.css +12 -12
  41. package/dist/components/NSBoxOTP.module.css +10 -10
  42. package/dist/components/NSBoxTextArea.module.css +76 -76
  43. package/dist/components/NSButton.module.css +27 -27
  44. package/dist/components/NSButtonBlue.module.css +4 -4
  45. package/dist/components/NSButtonGreen.module.css +4 -4
  46. package/dist/components/NSButtonRed.module.css +4 -4
  47. package/dist/components/NSCard.module.css +108 -108
  48. package/dist/components/NSCopyToClipboard.module.css +39 -39
  49. package/dist/components/NSElectronicCard.module.css +60 -60
  50. package/dist/components/NSEntityBar.module.css +77 -77
  51. package/dist/components/NSEntityCardBackground.module.css +27 -27
  52. package/dist/components/NSFilterBox.d.ts +1 -0
  53. package/dist/components/NSFilterBox.js +7 -7
  54. package/dist/components/NSFilterBox.js.map +1 -1
  55. package/dist/components/NSFilterBox.module.css +47 -47
  56. package/dist/components/NSFilterBoxDialog.module.css +36 -36
  57. package/dist/components/NSFilterItem.module.css +23 -23
  58. package/dist/components/NSFooter.js +1 -1
  59. package/dist/components/NSFooter.js.map +1 -1
  60. package/dist/components/NSFooter.module.css +123 -123
  61. package/dist/components/NSGroupedList.module.css +72 -72
  62. package/dist/components/NSHeader.js +1 -1
  63. package/dist/components/NSHeader.js.map +1 -1
  64. package/dist/components/NSHeader.module.css +271 -271
  65. package/dist/components/NSLayout.module.css +13 -13
  66. package/dist/components/NSLink.module.css +36 -36
  67. package/dist/components/NSLoading.module.css +29 -29
  68. package/dist/components/NSModal.js +2 -2
  69. package/dist/components/NSModal.module.css +70 -70
  70. package/dist/components/NSNoData.module.css +8 -8
  71. package/dist/components/NSPageSelectionModal.module.css +102 -102
  72. package/dist/components/NSPagination.module.css +101 -101
  73. package/dist/components/NSPanel.module.css +46 -46
  74. package/dist/components/NSRadioButton.module.css +61 -61
  75. package/dist/components/NSSection.module.css +10 -10
  76. package/dist/components/NSSectionBars.module.css +10 -10
  77. package/dist/components/NSSectionCards.module.css +38 -38
  78. package/dist/components/NSTabPage.module.css +57 -57
  79. package/dist/components/NSTable.module.css +253 -253
  80. package/dist/components/NSTag.module.css +44 -44
  81. package/dist/components/NSTitle.module.css +15 -15
  82. package/dist/components/NSVerification.module.css +22 -22
  83. package/dist/main.d.ts +0 -1
  84. package/dist/main.js +0 -1
  85. package/dist/main.js.map +1 -1
  86. package/dist/pages/NSNotFoundPage.module.css +18 -18
  87. package/package.json +67 -67
  88. package/public/index.html +38 -38
  89. package/src/App.css +16 -16
  90. package/src/App.tsx +166 -166
  91. package/src/CopyToClipboard.ts +6 -6
  92. package/src/Validator.ts +110 -110
  93. package/src/assets/images/404 image.svg +9 -9
  94. package/src/assets/images/404 image_mobile.svg +9 -9
  95. package/src/assets/images/arrow.svg +3 -3
  96. package/src/assets/images/danger.svg +3 -3
  97. package/src/assets/images/exit.svg +3 -3
  98. package/src/assets/images/icon-input-copy.svg +3 -3
  99. package/src/assets/images/icon-input-date.svg +9 -9
  100. package/src/assets/images/icon-input-duration.svg +9 -9
  101. package/src/assets/images/icon-input-email.svg +9 -9
  102. package/src/assets/images/icon-input-float.svg +9 -9
  103. package/src/assets/images/icon-input-integer.svg +9 -9
  104. package/src/assets/images/icon-input-ip.svg +9 -9
  105. package/src/assets/images/icon-input-phone.svg +9 -9
  106. package/src/assets/images/icon-input-price.svg +9 -9
  107. package/src/assets/images/icon-input-search.svg +3 -3
  108. package/src/assets/images/icon-input-string.svg +9 -9
  109. package/src/assets/images/icon-input-text.svg +9 -9
  110. package/src/assets/images/icon-input-time.svg +9 -9
  111. package/src/assets/images/icon-select-box.svg +3 -3
  112. package/src/assets/images/logo.svg +9 -9
  113. package/src/assets/images/menu.svg +3 -3
  114. package/src/assets/images/namira.svg +9 -9
  115. package/src/assets/images/rectangle.svg +3 -3
  116. package/src/components/NSActionMenu.module.css +75 -75
  117. package/src/components/NSActionMenu.tsx +88 -88
  118. package/src/components/NSAssistantButton.module.css +133 -133
  119. package/src/components/NSAssistantButton.tsx +74 -74
  120. package/src/components/NSBarAction.module.css +87 -87
  121. package/src/components/NSBarAction.tsx +86 -86
  122. package/src/components/NSBarHeroBanner.module.css +42 -42
  123. package/src/components/NSBarHeroBanner.tsx +61 -61
  124. package/src/components/NSBarNotification.module.css +34 -34
  125. package/src/components/NSBarNotification.tsx +63 -63
  126. package/src/components/NSBarTitle.module.css +9 -9
  127. package/src/components/NSBarTitle.tsx +28 -28
  128. package/src/components/NSBox.module.css +123 -123
  129. package/src/components/NSBoxBoolean.module.css +53 -53
  130. package/src/components/NSBoxBoolean.tsx +84 -84
  131. package/src/components/NSBoxCombo.module.css +16 -16
  132. package/src/components/NSBoxCombo.tsx +132 -132
  133. package/src/components/NSBoxDate.module.css +39 -39
  134. package/src/components/NSBoxDate.tsx +83 -83
  135. package/src/components/NSBoxDateTime.tsx +83 -83
  136. package/src/components/NSBoxDouble.tsx +88 -88
  137. package/src/components/NSBoxDuration.tsx +88 -88
  138. package/src/components/NSBoxEmail.tsx +104 -104
  139. package/src/components/NSBoxEntity.module.css +25 -25
  140. package/src/components/NSBoxEntity.tsx +178 -178
  141. package/src/components/NSBoxEnum.tsx +56 -56
  142. package/src/components/NSBoxErrorNotifier.module.css +2 -2
  143. package/src/components/NSBoxErrorNotifier.tsx +33 -33
  144. package/src/components/NSBoxIPV4.tsx +93 -93
  145. package/src/components/NSBoxIPV6.tsx +90 -90
  146. package/src/components/NSBoxInteger.tsx +86 -86
  147. package/src/components/NSBoxLabel.module.css +12 -12
  148. package/src/components/NSBoxLabel.tsx +29 -29
  149. package/src/components/NSBoxOTP.module.css +10 -10
  150. package/src/components/NSBoxOTP.tsx +65 -65
  151. package/src/components/NSBoxPassword.tsx +86 -86
  152. package/src/components/NSBoxPhone.tsx +88 -88
  153. package/src/components/NSBoxPrice.tsx +88 -88
  154. package/src/components/NSBoxSearch.tsx +103 -103
  155. package/src/components/NSBoxString.tsx +103 -103
  156. package/src/components/NSBoxTextArea.module.css +76 -76
  157. package/src/components/NSBoxTextArea.tsx +106 -106
  158. package/src/components/NSBoxTime.tsx +88 -88
  159. package/src/components/NSButton.module.css +27 -27
  160. package/src/components/NSButton.tsx +23 -23
  161. package/src/components/NSButtonBlue.module.css +4 -4
  162. package/src/components/NSButtonBlue.tsx +12 -12
  163. package/src/components/NSButtonGreen.module.css +4 -4
  164. package/src/components/NSButtonGreen.tsx +11 -11
  165. package/src/components/NSButtonRed.module.css +4 -4
  166. package/src/components/NSButtonRed.tsx +11 -11
  167. package/src/components/NSCard.module.css +108 -108
  168. package/src/components/NSCard.tsx +70 -70
  169. package/src/components/NSCopyToClipboard.module.css +39 -39
  170. package/src/components/NSCopyToClipboard.tsx +35 -35
  171. package/src/components/NSElectronicCard.module.css +60 -60
  172. package/src/components/NSElectronicCard.tsx +47 -47
  173. package/src/components/NSEntityBar.module.css +77 -77
  174. package/src/components/NSEntityBar.tsx +27 -27
  175. package/src/components/NSEntityCardBackground.module.css +27 -27
  176. package/src/components/NSEntityCardBackground.tsx +34 -34
  177. package/src/components/NSFilterBox.module.css +47 -47
  178. package/src/components/NSFilterBox.tsx +373 -374
  179. package/src/components/NSFilterBoxDialog.module.css +36 -36
  180. package/src/components/NSFilterBoxDialog.tsx +74 -74
  181. package/src/components/NSFilterItem.module.css +23 -23
  182. package/src/components/NSFilterItem.tsx +72 -72
  183. package/src/components/NSFooter.module.css +123 -123
  184. package/src/components/NSFooter.tsx +196 -196
  185. package/src/components/NSGroupedList.module.css +72 -72
  186. package/src/components/NSGroupedList.tsx +107 -107
  187. package/src/components/NSHeader.module.css +271 -271
  188. package/src/components/NSHeader.tsx +235 -235
  189. package/src/components/NSLayout.module.css +13 -13
  190. package/src/components/NSLayout.tsx +82 -82
  191. package/src/components/NSLine.tsx +18 -18
  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 +29 -29
  198. package/src/components/NSLoading.tsx +19 -19
  199. package/src/components/NSModal.module.css +70 -70
  200. package/src/components/NSModal.tsx +49 -49
  201. package/src/components/NSNoData.module.css +8 -8
  202. package/src/components/NSNoData.tsx +24 -24
  203. package/src/components/NSPageSelectionModal.module.css +102 -102
  204. package/src/components/NSPageSelectionModal.tsx +228 -228
  205. package/src/components/NSPagination.module.css +101 -101
  206. package/src/components/NSPagination.tsx +190 -190
  207. package/src/components/NSPanel.module.css +46 -46
  208. package/src/components/NSPanel.tsx +19 -19
  209. package/src/components/NSRadioButton.module.css +61 -61
  210. package/src/components/NSRadioButton.tsx +100 -100
  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 +57 -57
  220. package/src/components/NSTabPage.tsx +53 -53
  221. package/src/components/NSTable.module.css +253 -253
  222. package/src/components/NSTable.tsx +361 -361
  223. package/src/components/NSTag.module.css +44 -44
  224. package/src/components/NSTag.tsx +49 -49
  225. package/src/components/NSTitle.module.css +15 -15
  226. package/src/components/NSTitle.tsx +19 -19
  227. package/src/components/NSVerification.module.css +22 -22
  228. package/src/components/NSVerification.tsx +41 -41
  229. package/src/index.tsx +7 -7
  230. package/src/main.ts +78 -79
  231. package/src/pages/NSNotFoundPage.module.css +18 -18
  232. package/src/pages/NSNotFoundPage.tsx +11 -11
  233. package/src/props/IBaseComponentProps.ts +8 -8
  234. package/src/props/IHeaderIconProps.ts +9 -9
  235. package/src/props/IHeaderProps.ts +6 -6
  236. package/src/props/IImageProps.ts +4 -4
  237. package/src/props/ILinkProps.ts +5 -5
  238. package/src/props/IValidationNumberProps.ts +4 -4
  239. package/src/props/IValidationProps.ts +7 -7
  240. package/src/props/IValidationRegexProps.ts +4 -4
  241. package/src/props/IValidationStringProps.ts +4 -4
  242. package/src/routing/INSRouterMaker.ts +6 -6
  243. package/src/routing/INSRouterProps.ts +5 -5
  244. package/src/routing/INSRouterState.ts +5 -5
  245. package/src/routing/NSRouterMaker.tsx +33 -33
  246. package/src/routing/Notifier.ts +79 -79
  247. package/tsconfig.json +43 -43
  248. package/dist/App.css +0 -17
  249. package/dist/assets/images/1.png +0 -0
  250. package/dist/assets/images/2.png +0 -0
  251. package/dist/assets/images/3.png +0 -0
  252. package/dist/assets/images/4.png +0 -0
  253. package/dist/assets/images/5.jpg +0 -0
  254. package/dist/assets/images/icon-export.svg +0 -3
  255. package/dist/assets/images/icon-input-id.svg +0 -9
  256. package/dist/assets/images/icon-refresh.svg +0 -3
  257. package/dist/components/NSAccess.d.ts +0 -2
  258. package/dist/components/NSAccess.js +0 -8
  259. package/dist/components/NSAccess.js.map +0 -1
  260. package/dist/components/NSAccess.module.css +0 -39
  261. package/dist/components/NSBoxText.d.ts +0 -25
  262. package/dist/components/NSBoxText.js +0 -56
  263. package/dist/components/NSBoxText.js.map +0 -1
  264. package/dist/components/NSInput.module.css +0 -74
  265. package/dist/components/NSInputDate.d.ts +0 -21
  266. package/dist/components/NSInputDate.js +0 -41
  267. package/dist/components/NSInputDate.js.map +0 -1
  268. package/dist/components/NSInputDate.module.css +0 -42
  269. package/dist/components/NSInputDuration.d.ts +0 -23
  270. package/dist/components/NSInputDuration.js +0 -42
  271. package/dist/components/NSInputDuration.js.map +0 -1
  272. package/dist/components/NSInputEmail.d.ts +0 -22
  273. package/dist/components/NSInputEmail.js +0 -43
  274. package/dist/components/NSInputEmail.js.map +0 -1
  275. package/dist/components/NSInputErrorNotifier.d.ts +0 -5
  276. package/dist/components/NSInputErrorNotifier.js +0 -7
  277. package/dist/components/NSInputErrorNotifier.js.map +0 -1
  278. package/dist/components/NSInputErrorNotifier.module.css +0 -3
  279. package/dist/components/NSInputFloat.d.ts +0 -22
  280. package/dist/components/NSInputFloat.js +0 -41
  281. package/dist/components/NSInputFloat.js.map +0 -1
  282. package/dist/components/NSInputIP.d.ts +0 -22
  283. package/dist/components/NSInputIP.js +0 -43
  284. package/dist/components/NSInputIP.js.map +0 -1
  285. package/dist/components/NSInputInteger.d.ts +0 -22
  286. package/dist/components/NSInputInteger.js +0 -41
  287. package/dist/components/NSInputInteger.js.map +0 -1
  288. package/dist/components/NSInputPassword.d.ts +0 -22
  289. package/dist/components/NSInputPassword.js +0 -42
  290. package/dist/components/NSInputPassword.js.map +0 -1
  291. package/dist/components/NSInputPhone.d.ts +0 -22
  292. package/dist/components/NSInputPhone.js +0 -38
  293. package/dist/components/NSInputPhone.js.map +0 -1
  294. package/dist/components/NSInputPrice.d.ts +0 -22
  295. package/dist/components/NSInputPrice.js +0 -41
  296. package/dist/components/NSInputPrice.js.map +0 -1
  297. package/dist/components/NSInputSearch.d.ts +0 -22
  298. package/dist/components/NSInputSearch.js +0 -41
  299. package/dist/components/NSInputSearch.js.map +0 -1
  300. package/dist/components/NSInputString.d.ts +0 -22
  301. package/dist/components/NSInputString.js +0 -42
  302. package/dist/components/NSInputString.js.map +0 -1
  303. package/dist/components/NSInputText.d.ts +0 -22
  304. package/dist/components/NSInputText.js +0 -42
  305. package/dist/components/NSInputText.js.map +0 -1
  306. package/dist/components/NSInputTime.d.ts +0 -22
  307. package/dist/components/NSInputTime.js +0 -43
  308. package/dist/components/NSInputTime.js.map +0 -1
  309. package/dist/components/NSLayoutAction.d.ts +0 -5
  310. package/dist/components/NSLayoutAction.js +0 -20
  311. package/dist/components/NSLayoutAction.js.map +0 -1
  312. package/dist/components/NSLayoutAction.module.css +0 -88
  313. package/dist/components/NSLayoutHeroBanner.d.ts +0 -2
  314. package/dist/components/NSLayoutHeroBanner.js +0 -8
  315. package/dist/components/NSLayoutHeroBanner.js.map +0 -1
  316. package/dist/components/NSLayoutHeroBanner.module.css +0 -43
  317. package/dist/components/NSLayoutTitle.d.ts +0 -2
  318. package/dist/components/NSLayoutTitle.js +0 -11
  319. package/dist/components/NSLayoutTitle.js.map +0 -1
  320. package/dist/components/NSLayoutTitle.module.css +0 -10
  321. package/dist/components/NSNotification.d.ts +0 -21
  322. package/dist/components/NSNotification.js +0 -37
  323. package/dist/components/NSNotification.js.map +0 -1
  324. package/dist/components/NSNotification.module.css +0 -32
  325. package/dist/components/NSPrintModal.d.ts +0 -15
  326. package/dist/components/NSPrintModal.js +0 -35
  327. package/dist/components/NSPrintModal.js.map +0 -1
  328. package/dist/components/NSPrintModal.module.css +0 -82
  329. package/dist/components/NSSelectBox.d.ts +0 -24
  330. package/dist/components/NSSelectBox.js +0 -61
  331. package/dist/components/NSSelectBox.js.map +0 -1
  332. package/dist/components/NSSelectBox.module.css +0 -42
  333. package/dist/index.css +0 -6
  334. package/dist/pages/NSLoginPage.d.ts +0 -6
  335. package/dist/pages/NSLoginPage.js +0 -8
  336. package/dist/pages/NSLoginPage.js.map +0 -1
  337. package/dist/pages/NSLoginPage.module.css +0 -20
  338. package/dist/props/BaseComponentProps.d.ts +0 -6
  339. package/dist/props/BaseComponentProps.js +0 -2
  340. package/dist/props/BaseComponentProps.js.map +0 -10
  341. package/dist/props/INamirasoftProps.d.ts +0 -4
  342. package/dist/props/INamirasoftProps.js +0 -2
  343. package/dist/props/INamirasoftProps.js.map +0 -1
  344. package/dist/props/ImageProps.d.ts +0 -4
  345. package/dist/props/ImageProps.js +0 -2
  346. package/dist/props/ImageProps.js.map +0 -10
  347. package/dist/props/LinkProps.d.ts +0 -5
  348. package/dist/props/LinkProps.js +0 -2
  349. package/dist/props/LinkProps.js.map +0 -10
  350. package/dist/props/ValidationNumberProps.d.ts +0 -4
  351. package/dist/props/ValidationNumberProps.js +0 -2
  352. package/dist/props/ValidationNumberProps.js.map +0 -10
  353. package/dist/props/ValidationProps.d.ts +0 -6
  354. package/dist/props/ValidationProps.js +0 -2
  355. package/dist/props/ValidationProps.js.map +0 -10
  356. package/dist/props/ValidationRegexProps.d.ts +0 -4
  357. package/dist/props/ValidationRegexProps.js +0 -2
  358. package/dist/props/ValidationRegexProps.js.map +0 -1
  359. package/dist/props/ValidationStringProps.d.ts +0 -4
  360. package/dist/props/ValidationStringProps.js +0 -2
  361. package/dist/props/ValidationStringProps.js.map +0 -10
  362. package/src/pages/NSLoginPage.module.css +0 -20
  363. package/src/pages/NSLoginPage.tsx +0 -31
@@ -1,197 +1,197 @@
1
- "use client";
2
-
3
- import React from "react";
4
- import Styles from "./NSFooter.module.css";
5
- import { NamirasoftAPILinkServer, FilterLinkFullRow } from 'namirasoft-api-link';
6
- import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
- import { IStorageLocal, CacheService } from "namirasoft-core";
8
-
9
- export interface INSFooterProps extends IBaseComponentProps
10
- {
11
- scope: string;
12
- name: string;
13
- logo: string;
14
- isLoggedIn: () => boolean;
15
- }
16
-
17
- export interface NSFooterState
18
- {
19
- filters: FilterLinkFullRow[];
20
- selected: FilterLinkFullRow | null;
21
- }
22
-
23
- export class NSFooter extends React.Component<INSFooterProps, NSFooterState>
24
- {
25
- private cache: CacheService<{
26
- rows: FilterLinkFullRow[];
27
- count: number;
28
- }>;
29
- constructor(props: INSFooterProps)
30
- {
31
- super(props);
32
- this.state = {
33
- filters: [],
34
- selected: null
35
- };
36
- this.hasChild = this.hasChild.bind(this);
37
- this.render_menu = this.render_menu.bind(this);
38
- this.render_menuItem = this.render_menuItem.bind(this);
39
- this.cache = new CacheService<{
40
- rows: FilterLinkFullRow[];
41
- count: number;
42
- }>("ns-footer", 720, new IStorageLocal(), async () =>
43
- {
44
- let server = new NamirasoftAPILinkServer(console.error);
45
- return server.filter.ListFilterLinks(this.props.scope, this.props.name, null, null, null);
46
- });
47
- }
48
- override componentDidMount(): void
49
- {
50
- this.cache.get().then(filters =>
51
- {
52
- this.setState({ filters: filters.rows });
53
- }).catch(() => { });
54
- }
55
- private getFilters(): FilterLinkFullRow[]
56
- {
57
- let loggedin = this.props.isLoggedIn();
58
- let ans = this.state.filters?.filter(f =>
59
- {
60
- if (f.link)
61
- {
62
- if (loggedin)
63
- return f.link.private;
64
- return f.link.public;
65
- }
66
- return true;
67
- }) ?? [];
68
-
69
- while (true)
70
- {
71
- let old_length = ans.length;
72
- ans = ans.filter(f =>
73
- {
74
- if (f.link?.url)
75
- return true;
76
- return ans.filter(x => x.parent_id == f.id).length > 0;
77
- });
78
- let new_length = ans.length;
79
- if (old_length == new_length)
80
- break;
81
- }
82
-
83
- return ans;
84
- }
85
- private hasChild(id: number): boolean
86
- {
87
- return this.getFilters().filter(f => f.parent_id === id).length > 0;
88
- }
89
- override render()
90
- {
91
- return (
92
- <footer id={this.props.id}
93
- className={`${Styles.ns_footer} ${this.props.classList?.join(" ")}`}
94
- style={this.props.style}
95
- >
96
- <div className={`container ${Styles.ns_package_footer}`}>
97
- <div className={`${Styles.ns_footer_parent_items}`}>
98
- <div className={`${Styles.ns_footer_project_logo_tablet}`}>
99
- <a href="/">
100
- <img src={this.props.logo} alt='Logo' width={80} height={80} />
101
- </a>
102
- </div>
103
- <div className={`${Styles.ns_footer_menu_container}`}>
104
- {this.render_menu(0, null)}
105
- </div>
106
- <div className={`${Styles.ns_footer_namira_logo_tablet}`}>
107
- <div className="d-flex flex-row gap-3">
108
- <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/site/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
109
- <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/account/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
110
- </div>
111
- <div className="d-flex flex-row gap-1 w-100 justify-content-center align-items-center">
112
- <a style={{ cursor: "pointer" }} href="https://ca.linkedin.com/company/namira-software-corporation" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/linkedin/white.svg" alt="Communicate with Namirasoft Via LinkedIn" width={24} height={24} /></a>
113
- <a href="https://instagram.com/namira.software.corporation?igshid=MzRlODBiNWFlZA==" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/instagram/white.svg" alt="Communicate with Namirasoft Via Instagram" width={24} height={24} /></a>
114
- <a href="support@namirasoft.com" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/email/white.svg" alt="Communicate with Namirasoft Via Email" width={24} height={24} /></a>
115
- <a href="https://www.google.com/maps/place//@49.2781041,-123.1354814,14z/data=!4m2!3m1!1s0x0:0x18f70365c7a2f0fa?entry=s&sa=X" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/location/white.svg" alt="Communicate with Namirasoft in Person" width={24} height={24} /></a>
116
- </div>
117
- </div>
118
- </div>
119
- <div className={`${Styles.ns_footer_logos_mobile}`}>
120
- <div className="d-flex flex-column gap-4">
121
- <div className="d-flex flex-row gap-3">
122
- <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/site/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
123
- <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/account/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
124
- </div>
125
- <div className="d-flex flex-row gap-1 w-100 justify-content-center align-items-center">
126
- <a href="https://ca.linkedin.com/company/namira-software-corporation" target="_blank" ><img src="https://static.namirasoft.com/image/concept/social/linkedin/white.svg" alt="Communicate with Namirasoft Via LinkedIn" width={24} height={24} /></a>
127
- <a href="https://instagram.com/namira.software.corporation?igshid=MzRlODBiNWFlZA==" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/instagram/white.svg" alt="Communicate with Namirasoft Via Instagram" width={24} height={24} /></a>
128
- <a href="support@namirasoft.com" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/email/white.svg" alt="Communicate with Namirasoft Via Email" width={24} height={24} /></a>
129
- <a href="https://www.google.com/maps/place//@49.2781041,-123.1354814,14z/data=!4m2!3m1!1s0x0:0x18f70365c7a2f0fa?entry=s&sa=X" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/location/white.svg" alt="Communicate with Namirasoft in Person" width={24} height={24} /></a>
130
- </div>
131
- </div>
132
- </div>
133
- <div className={`${Styles.ns_footer_copyright}`}>
134
- <span> ©Copyright 2010 - {new Date().getFullYear()} </span>{" "}
135
- <a href="https://namirasoft.com/" target="_blank" rel="noopener noreferrer"> Namira Software Corporation</a>. {" "}
136
- <span > All rights reserved. </span>
137
- </div>
138
- </div>
139
- </footer >
140
- );
141
- }
142
- private render_menu(level: number, parent_id: number | null)
143
- {
144
- let fs: FilterLinkFullRow[] = this.getFilters().filter(f => f.parent_id === parent_id);
145
- return (
146
- <>
147
- {
148
- (fs?.map(f => this.render_menuItem(level, f)))
149
- }
150
- </>
151
- );
152
- }
153
- private render_menuItem(level: number, filter: FilterLinkFullRow)
154
- {
155
- if (this.hasChild(filter.id))
156
- {
157
- return (<>
158
- <ul
159
- id={`dropdown_parent${filter.id}`}>
160
- <span className={Styles.ns_footer_list_title}> {filter.name} </span>
161
- {this.render_menu(1, filter.id)}
162
- </ul>
163
- </>
164
- );
165
- }
166
- else if (level === 0)
167
- {
168
- return (<>
169
- <ul
170
- key={filter.id}
171
- id={`dropdown_parent${filter.id}`}>
172
- {filter.name}
173
- </ul>
174
- </>
175
- );
176
- }
177
- else
178
- {
179
- let href = filter.link?.url;
180
- if (process.env.REACT_APP_STANDALONE)
181
- if (href)
182
- {
183
- let url = new URL(href);
184
- url.host = window.location.host;
185
- url.protocol = window.location.protocol;
186
- href = url.toString();
187
- }
188
- return (
189
- <li className="mb-2">
190
- <a key={filter.id} href={href}>
191
- {filter.name}
192
- </a>
193
- </li>
194
- );
195
- }
196
- }
1
+ "use client";
2
+
3
+ import React from "react";
4
+ import Styles from "./NSFooter.module.css";
5
+ import { NamirasoftAPILinkServer, FilterLinkFullRow } from 'namirasoft-api-link';
6
+ import { IBaseComponentProps } from "../props/IBaseComponentProps";
7
+ import { IStorageLocal, CacheService } from "namirasoft-core";
8
+
9
+ export interface INSFooterProps extends IBaseComponentProps
10
+ {
11
+ scope: string;
12
+ name: string;
13
+ logo: string;
14
+ isLoggedIn: () => boolean;
15
+ }
16
+
17
+ export interface NSFooterState
18
+ {
19
+ filters: FilterLinkFullRow[];
20
+ selected: FilterLinkFullRow | null;
21
+ }
22
+
23
+ export class NSFooter extends React.Component<INSFooterProps, NSFooterState>
24
+ {
25
+ private cache: CacheService<{
26
+ rows: FilterLinkFullRow[];
27
+ count: number;
28
+ }>;
29
+ constructor(props: INSFooterProps)
30
+ {
31
+ super(props);
32
+ this.state = {
33
+ filters: [],
34
+ selected: null
35
+ };
36
+ this.hasChild = this.hasChild.bind(this);
37
+ this.render_menu = this.render_menu.bind(this);
38
+ this.render_menuItem = this.render_menuItem.bind(this);
39
+ this.cache = new CacheService<{
40
+ rows: FilterLinkFullRow[];
41
+ count: number;
42
+ }>("ns-footer", 720, new IStorageLocal(), async () =>
43
+ {
44
+ let server = new NamirasoftAPILinkServer(console.error);
45
+ return server.filter.ListFilterLinks(this.props.scope, this.props.name, null, null, null);
46
+ }, () => { });
47
+ }
48
+ override componentDidMount(): void
49
+ {
50
+ this.cache.get().then(filters =>
51
+ {
52
+ this.setState({ filters: filters.rows });
53
+ }).catch(() => { });
54
+ }
55
+ private getFilters(): FilterLinkFullRow[]
56
+ {
57
+ let loggedin = this.props.isLoggedIn();
58
+ let ans = this.state.filters?.filter(f =>
59
+ {
60
+ if (f.link)
61
+ {
62
+ if (loggedin)
63
+ return f.link.private;
64
+ return f.link.public;
65
+ }
66
+ return true;
67
+ }) ?? [];
68
+
69
+ while (true)
70
+ {
71
+ let old_length = ans.length;
72
+ ans = ans.filter(f =>
73
+ {
74
+ if (f.link?.url)
75
+ return true;
76
+ return ans.filter(x => x.parent_id == f.id).length > 0;
77
+ });
78
+ let new_length = ans.length;
79
+ if (old_length == new_length)
80
+ break;
81
+ }
82
+
83
+ return ans;
84
+ }
85
+ private hasChild(id: number): boolean
86
+ {
87
+ return this.getFilters().filter(f => f.parent_id === id).length > 0;
88
+ }
89
+ override render()
90
+ {
91
+ return (
92
+ <footer id={this.props.id}
93
+ className={`${Styles.ns_footer} ${this.props.classList?.join(" ")}`}
94
+ style={this.props.style}
95
+ >
96
+ <div className={`container ${Styles.ns_package_footer}`}>
97
+ <div className={`${Styles.ns_footer_parent_items}`}>
98
+ <div className={`${Styles.ns_footer_project_logo_tablet}`}>
99
+ <a href="/">
100
+ <img src={this.props.logo} alt='Logo' width={80} height={80} />
101
+ </a>
102
+ </div>
103
+ <div className={`${Styles.ns_footer_menu_container}`}>
104
+ {this.render_menu(0, null)}
105
+ </div>
106
+ <div className={`${Styles.ns_footer_namira_logo_tablet}`}>
107
+ <div className="d-flex flex-row gap-3">
108
+ <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/site/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
109
+ <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/account/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
110
+ </div>
111
+ <div className="d-flex flex-row gap-1 w-100 justify-content-center align-items-center">
112
+ <a style={{ cursor: "pointer" }} href="https://ca.linkedin.com/company/namira-software-corporation" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/linkedin/white.svg" alt="Communicate with Namirasoft Via LinkedIn" width={24} height={24} /></a>
113
+ <a href="https://instagram.com/namira.software.corporation?igshid=MzRlODBiNWFlZA==" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/instagram/white.svg" alt="Communicate with Namirasoft Via Instagram" width={24} height={24} /></a>
114
+ <a href="support@namirasoft.com" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/email/white.svg" alt="Communicate with Namirasoft Via Email" width={24} height={24} /></a>
115
+ <a href="https://www.google.com/maps/place//@49.2781041,-123.1354814,14z/data=!4m2!3m1!1s0x0:0x18f70365c7a2f0fa?entry=s&sa=X" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/location/white.svg" alt="Communicate with Namirasoft in Person" width={24} height={24} /></a>
116
+ </div>
117
+ </div>
118
+ </div>
119
+ <div className={`${Styles.ns_footer_logos_mobile}`}>
120
+ <div className="d-flex flex-column gap-4">
121
+ <div className="d-flex flex-row gap-3">
122
+ <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/site/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
123
+ <a href="/"><img src="https://static.namirasoft.com/image/namirasoft/account/logo/circle.png" alt='Namira Software Corporation Logo' width={48} height={48} /></a>
124
+ </div>
125
+ <div className="d-flex flex-row gap-1 w-100 justify-content-center align-items-center">
126
+ <a href="https://ca.linkedin.com/company/namira-software-corporation" target="_blank" ><img src="https://static.namirasoft.com/image/concept/social/linkedin/white.svg" alt="Communicate with Namirasoft Via LinkedIn" width={24} height={24} /></a>
127
+ <a href="https://instagram.com/namira.software.corporation?igshid=MzRlODBiNWFlZA==" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/instagram/white.svg" alt="Communicate with Namirasoft Via Instagram" width={24} height={24} /></a>
128
+ <a href="support@namirasoft.com" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/email/white.svg" alt="Communicate with Namirasoft Via Email" width={24} height={24} /></a>
129
+ <a href="https://www.google.com/maps/place//@49.2781041,-123.1354814,14z/data=!4m2!3m1!1s0x0:0x18f70365c7a2f0fa?entry=s&sa=X" target="_blank"><img src="https://static.namirasoft.com/image/concept/social/location/white.svg" alt="Communicate with Namirasoft in Person" width={24} height={24} /></a>
130
+ </div>
131
+ </div>
132
+ </div>
133
+ <div className={`${Styles.ns_footer_copyright}`}>
134
+ <span> ©Copyright 2010 - {new Date().getFullYear()} </span>{" "}
135
+ <a href="https://namirasoft.com/" target="_blank" rel="noopener noreferrer"> Namira Software Corporation</a>. {" "}
136
+ <span > All rights reserved. </span>
137
+ </div>
138
+ </div>
139
+ </footer >
140
+ );
141
+ }
142
+ private render_menu(level: number, parent_id: number | null)
143
+ {
144
+ let fs: FilterLinkFullRow[] = this.getFilters().filter(f => f.parent_id === parent_id);
145
+ return (
146
+ <>
147
+ {
148
+ (fs?.map(f => this.render_menuItem(level, f)))
149
+ }
150
+ </>
151
+ );
152
+ }
153
+ private render_menuItem(level: number, filter: FilterLinkFullRow)
154
+ {
155
+ if (this.hasChild(filter.id))
156
+ {
157
+ return (<>
158
+ <ul
159
+ id={`dropdown_parent${filter.id}`}>
160
+ <span className={Styles.ns_footer_list_title}> {filter.name} </span>
161
+ {this.render_menu(1, filter.id)}
162
+ </ul>
163
+ </>
164
+ );
165
+ }
166
+ else if (level === 0)
167
+ {
168
+ return (<>
169
+ <ul
170
+ key={filter.id}
171
+ id={`dropdown_parent${filter.id}`}>
172
+ {filter.name}
173
+ </ul>
174
+ </>
175
+ );
176
+ }
177
+ else
178
+ {
179
+ let href = filter.link?.url;
180
+ if (process.env.REACT_APP_STANDALONE)
181
+ if (href)
182
+ {
183
+ let url = new URL(href);
184
+ url.host = window.location.host;
185
+ url.protocol = window.location.protocol;
186
+ href = url.toString();
187
+ }
188
+ return (
189
+ <li className="mb-2">
190
+ <a key={filter.id} href={href}>
191
+ {filter.name}
192
+ </a>
193
+ </li>
194
+ );
195
+ }
196
+ }
197
197
  }
@@ -1,73 +1,73 @@
1
- .ns_group_list_parent {
2
- width: 100%;
3
- max-width: 560px;
4
- border-radius: 8px;
5
- border: solid 1px #B2BBD9;
6
- background-color: #fff;
7
- padding-bottom: 16px;
8
- height: 360px;
9
- overflow: auto;
10
- position: absolute;
11
- z-index: 10;
12
- margin-top: 50px;
13
- }
14
-
15
- .ns_group_list_parent::-webkit-scrollbar {
16
- width: 1rem;
17
- }
18
-
19
- .ns_group_list_parent::-webkit-scrollbar-track {
20
- box-shadow: inset 0 0 6px #E8EBF6;
21
- }
22
-
23
- .ns_group_list_parent::-webkit-scrollbar-thumb {
24
- background-color: #A1A4B0;
25
- border-radius: 8px;
26
- }
27
-
28
- .ns_group_list {
29
- list-style-type: none;
30
- color: #141B5C;
31
- padding: 0;
32
- margin: 0;
33
- display: flex;
34
- flex-direction: column;
35
- align-items: flex-start;
36
- justify-content: flex-start;
37
- font-size: 16px;
38
- font-weight: 700;
39
- width: 100%;
40
- }
41
-
42
- .ns_group_category {
43
- border-bottom: solid 1px currentColor;
44
- width: 100%;
45
- display: flex;
46
- justify-content: space-between;
47
- padding: 10px 8px;
48
- }
49
-
50
- .ns_group_list li {
51
- width: 100%;
52
- }
53
-
54
- .ns_group_item {
55
- cursor: pointer;
56
- padding: 6px 0 6px 24px;
57
- font-size: 16px;
58
- font-weight: 300;
59
- color: #141B5C;
60
- border-bottom: solid 1px currentColor;
61
- width: 100%;
62
- display: inline-block;
63
- transition: all 0.1s;
64
- }
65
-
66
- .ns_group_item:hover {
67
- background-color: #B2BBD9;
68
- font-weight: 700;
69
- }
70
-
71
- .ns_block {
72
- display: block;
1
+ .ns_group_list_parent {
2
+ width: 100%;
3
+ max-width: 560px;
4
+ border-radius: 8px;
5
+ border: solid 1px #B2BBD9;
6
+ background-color: #fff;
7
+ padding-bottom: 16px;
8
+ height: 360px;
9
+ overflow: auto;
10
+ position: absolute;
11
+ z-index: 10;
12
+ margin-top: 50px;
13
+ }
14
+
15
+ .ns_group_list_parent::-webkit-scrollbar {
16
+ width: 1rem;
17
+ }
18
+
19
+ .ns_group_list_parent::-webkit-scrollbar-track {
20
+ box-shadow: inset 0 0 6px #E8EBF6;
21
+ }
22
+
23
+ .ns_group_list_parent::-webkit-scrollbar-thumb {
24
+ background-color: #A1A4B0;
25
+ border-radius: 8px;
26
+ }
27
+
28
+ .ns_group_list {
29
+ list-style-type: none;
30
+ color: #141B5C;
31
+ padding: 0;
32
+ margin: 0;
33
+ display: flex;
34
+ flex-direction: column;
35
+ align-items: flex-start;
36
+ justify-content: flex-start;
37
+ font-size: 16px;
38
+ font-weight: 700;
39
+ width: 100%;
40
+ }
41
+
42
+ .ns_group_category {
43
+ border-bottom: solid 1px currentColor;
44
+ width: 100%;
45
+ display: flex;
46
+ justify-content: space-between;
47
+ padding: 10px 8px;
48
+ }
49
+
50
+ .ns_group_list li {
51
+ width: 100%;
52
+ }
53
+
54
+ .ns_group_item {
55
+ cursor: pointer;
56
+ padding: 6px 0 6px 24px;
57
+ font-size: 16px;
58
+ font-weight: 300;
59
+ color: #141B5C;
60
+ border-bottom: solid 1px currentColor;
61
+ width: 100%;
62
+ display: inline-block;
63
+ transition: all 0.1s;
64
+ }
65
+
66
+ .ns_group_item:hover {
67
+ background-color: #B2BBD9;
68
+ font-weight: 700;
69
+ }
70
+
71
+ .ns_block {
72
+ display: block;
73
73
  }