@inventreedb/ui 0.0.1

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 (541) hide show
  1. package/.babelrc +8 -0
  2. package/.linguirc +55 -0
  3. package/README.md +17 -0
  4. package/index.html +15 -0
  5. package/lib/enums/ApiEndpoints.tsx +233 -0
  6. package/lib/enums/ModelType.tsx +38 -0
  7. package/lib/enums/Roles.tsx +25 -0
  8. package/lib/functions/Api.tsx +42 -0
  9. package/lib/functions/Plugins.tsx +27 -0
  10. package/lib/index.ts +11 -0
  11. package/lib/types/Auth.tsx +51 -0
  12. package/lib/types/Core.tsx +13 -0
  13. package/lib/types/Filters.tsx +69 -0
  14. package/lib/types/Forms.tsx +185 -0
  15. package/lib/types/Modals.tsx +17 -0
  16. package/lib/types/Plugins.tsx +68 -0
  17. package/lib/types/Server.tsx +8 -0
  18. package/lib/types/Settings.tsx +55 -0
  19. package/lib/types/Tables.tsx +69 -0
  20. package/lib/types/User.tsx +62 -0
  21. package/netlify.toml +22 -0
  22. package/package.json +125 -0
  23. package/playwright/global-setup.ts +45 -0
  24. package/playwright.config.ts +99 -0
  25. package/public/inventree.svg +291 -0
  26. package/src/App.tsx +35 -0
  27. package/src/assets/inventree.svg +1 -0
  28. package/src/components/Boundary.tsx +43 -0
  29. package/src/components/SplashScreen.tsx +35 -0
  30. package/src/components/barcodes/BarcodeCameraInput.tsx +207 -0
  31. package/src/components/barcodes/BarcodeInput.tsx +127 -0
  32. package/src/components/barcodes/BarcodeKeyboardInput.tsx +50 -0
  33. package/src/components/barcodes/BarcodeScanDialog.tsx +101 -0
  34. package/src/components/barcodes/BarcodeScanItem.tsx +23 -0
  35. package/src/components/barcodes/QRCode.tsx +211 -0
  36. package/src/components/buttons/ActionButton.tsx +61 -0
  37. package/src/components/buttons/AddItemButton.tsx +10 -0
  38. package/src/components/buttons/AdminButton.tsx +91 -0
  39. package/src/components/buttons/ButtonMenu.tsx +33 -0
  40. package/src/components/buttons/CopyButton.tsx +52 -0
  41. package/src/components/buttons/PrimaryActionButton.tsx +40 -0
  42. package/src/components/buttons/PrintingActions.tsx +191 -0
  43. package/src/components/buttons/RemoveRowButton.tsx +22 -0
  44. package/src/components/buttons/SSOButton.tsx +53 -0
  45. package/src/components/buttons/ScanButton.tsx +27 -0
  46. package/src/components/buttons/SegmentedIconControl.tsx +51 -0
  47. package/src/components/buttons/SplitButton.css.ts +19 -0
  48. package/src/components/buttons/SplitButton.tsx +111 -0
  49. package/src/components/buttons/SpotlightButton.tsx +22 -0
  50. package/src/components/buttons/StarredToggleButton.tsx +62 -0
  51. package/src/components/buttons/YesNoButton.tsx +42 -0
  52. package/src/components/calendar/Calendar.tsx +193 -0
  53. package/src/components/calendar/OrderCalendar.tsx +209 -0
  54. package/src/components/charts/colors.tsx +12 -0
  55. package/src/components/charts/tooltipFormatter.tsx +12 -0
  56. package/src/components/dashboard/DashboardLayout.tsx +327 -0
  57. package/src/components/dashboard/DashboardMenu.tsx +136 -0
  58. package/src/components/dashboard/DashboardWidget.tsx +82 -0
  59. package/src/components/dashboard/DashboardWidgetDrawer.tsx +130 -0
  60. package/src/components/dashboard/DashboardWidgetLibrary.tsx +189 -0
  61. package/src/components/dashboard/widgets/ColorToggleWidget.tsx +28 -0
  62. package/src/components/dashboard/widgets/GetStartedWidget.tsx +19 -0
  63. package/src/components/dashboard/widgets/LanguageSelectWidget.tsx +28 -0
  64. package/src/components/dashboard/widgets/NewsWidget.tsx +143 -0
  65. package/src/components/dashboard/widgets/QueryCountDashboardWidget.tsx +134 -0
  66. package/src/components/details/Details.tsx +514 -0
  67. package/src/components/details/DetailsBadge.tsx +20 -0
  68. package/src/components/details/DetailsImage.tsx +462 -0
  69. package/src/components/details/ItemDetails.tsx +17 -0
  70. package/src/components/editors/NotesEditor.tsx +232 -0
  71. package/src/components/editors/TemplateEditor/CodeEditor/CodeEditor.tsx +158 -0
  72. package/src/components/editors/TemplateEditor/CodeEditor/index.tsx +12 -0
  73. package/src/components/editors/TemplateEditor/PdfPreview/PdfPreview.tsx +90 -0
  74. package/src/components/editors/TemplateEditor/PdfPreview/index.tsx +12 -0
  75. package/src/components/editors/TemplateEditor/TemplateEditor.tsx +425 -0
  76. package/src/components/editors/TemplateEditor/index.tsx +3 -0
  77. package/src/components/errors/ClientError.tsx +28 -0
  78. package/src/components/errors/GenericErrorPage.tsx +73 -0
  79. package/src/components/errors/NotAuthenticated.tsx +12 -0
  80. package/src/components/errors/NotFound.tsx +12 -0
  81. package/src/components/errors/PermissionDenied.tsx +12 -0
  82. package/src/components/errors/ServerError.tsx +13 -0
  83. package/src/components/forms/ApiForm.tsx +718 -0
  84. package/src/components/forms/AuthFormOptions.tsx +39 -0
  85. package/src/components/forms/AuthenticationForm.tsx +332 -0
  86. package/src/components/forms/HostOptionsForm.tsx +96 -0
  87. package/src/components/forms/InstanceOptions.tsx +178 -0
  88. package/src/components/forms/StandaloneField.tsx +55 -0
  89. package/src/components/forms/fields/ApiFormField.tsx +281 -0
  90. package/src/components/forms/fields/ChoiceField.tsx +86 -0
  91. package/src/components/forms/fields/DateField.tsx +79 -0
  92. package/src/components/forms/fields/DependentField.tsx +91 -0
  93. package/src/components/forms/fields/IconField.tsx +353 -0
  94. package/src/components/forms/fields/NestedObjectField.tsx +45 -0
  95. package/src/components/forms/fields/RelatedModelField.tsx +339 -0
  96. package/src/components/forms/fields/TableField.tsx +275 -0
  97. package/src/components/forms/fields/TextField.tsx +81 -0
  98. package/src/components/images/ApiImage.tsx +35 -0
  99. package/src/components/images/Thumbnail.tsx +52 -0
  100. package/src/components/importer/ImportDataSelector.tsx +433 -0
  101. package/src/components/importer/ImporterColumnSelector.tsx +244 -0
  102. package/src/components/importer/ImporterDrawer.tsx +173 -0
  103. package/src/components/importer/ImporterImportProgress.tsx +45 -0
  104. package/src/components/items/ActionDropdown.tsx +290 -0
  105. package/src/components/items/ApiIcon.css.ts +13 -0
  106. package/src/components/items/ApiIcon.tsx +32 -0
  107. package/src/components/items/AttachmentLink.tsx +79 -0
  108. package/src/components/items/ColorToggle.tsx +34 -0
  109. package/src/components/items/DashboardItem.tsx +33 -0
  110. package/src/components/items/DocInfo.tsx +20 -0
  111. package/src/components/items/DocTooltip.tsx +98 -0
  112. package/src/components/items/ErrorItem.tsx +17 -0
  113. package/src/components/items/Expand.tsx +14 -0
  114. package/src/components/items/GettingStartedCarousel.css.ts +30 -0
  115. package/src/components/items/GettingStartedCarousel.tsx +49 -0
  116. package/src/components/items/InfoItem.tsx +64 -0
  117. package/src/components/items/InvenTreeLogo.tsx +24 -0
  118. package/src/components/items/LanguageSelect.tsx +43 -0
  119. package/src/components/items/LanguageToggle.tsx +37 -0
  120. package/src/components/items/MenuLinks.tsx +113 -0
  121. package/src/components/items/OnlyStaff.tsx +10 -0
  122. package/src/components/items/ProgressBar.tsx +45 -0
  123. package/src/components/items/StylishText.tsx +59 -0
  124. package/src/components/items/TitleWithDoc.tsx +26 -0
  125. package/src/components/items/UnavailableIndicator.tsx +5 -0
  126. package/src/components/items/inventree.svg +1 -0
  127. package/src/components/modals/AboutInvenTreeModal.tsx +203 -0
  128. package/src/components/modals/LicenseModal.tsx +116 -0
  129. package/src/components/modals/QrModal.tsx +21 -0
  130. package/src/components/modals/ServerInfoModal.tsx +136 -0
  131. package/src/components/nav/Alerts.tsx +130 -0
  132. package/src/components/nav/BreadcrumbList.tsx +84 -0
  133. package/src/components/nav/DetailDrawer.css.ts +6 -0
  134. package/src/components/nav/DetailDrawer.tsx +105 -0
  135. package/src/components/nav/Footer.tsx +11 -0
  136. package/src/components/nav/Header.tsx +226 -0
  137. package/src/components/nav/InstanceDetail.tsx +46 -0
  138. package/src/components/nav/Layout.tsx +85 -0
  139. package/src/components/nav/MainMenu.tsx +101 -0
  140. package/src/components/nav/NavHoverMenu.tsx +15 -0
  141. package/src/components/nav/NavigationDrawer.tsx +230 -0
  142. package/src/components/nav/NavigationTree.tsx +210 -0
  143. package/src/components/nav/NotificationDrawer.tsx +231 -0
  144. package/src/components/nav/PageDetail.tsx +171 -0
  145. package/src/components/nav/PageTitle.tsx +53 -0
  146. package/src/components/nav/SearchDrawer.tsx +598 -0
  147. package/src/components/nav/SettingsHeader.tsx +50 -0
  148. package/src/components/panels/AttachmentPanel.tsx +27 -0
  149. package/src/components/panels/NotesPanel.tsx +36 -0
  150. package/src/components/panels/Panel.tsx +15 -0
  151. package/src/components/panels/PanelGroup.css.ts +10 -0
  152. package/src/components/panels/PanelGroup.tsx +292 -0
  153. package/src/components/plugins/LocateItemButton.tsx +94 -0
  154. package/src/components/plugins/PluginContext.tsx +67 -0
  155. package/src/components/plugins/PluginDrawer.tsx +156 -0
  156. package/src/components/plugins/PluginInterface.tsx +34 -0
  157. package/src/components/plugins/PluginPanel.tsx +37 -0
  158. package/src/components/plugins/PluginSettingsPanel.tsx +34 -0
  159. package/src/components/plugins/PluginSource.tsx +48 -0
  160. package/src/components/plugins/PluginUIFeature.tsx +174 -0
  161. package/src/components/plugins/PluginUIFeatureTypes.ts +78 -0
  162. package/src/components/plugins/RemoteComponent.tsx +137 -0
  163. package/src/components/render/Build.tsx +54 -0
  164. package/src/components/render/Company.tsx +114 -0
  165. package/src/components/render/Generic.tsx +49 -0
  166. package/src/components/render/Instance.tsx +240 -0
  167. package/src/components/render/InstanceFromUrl.tsx +33 -0
  168. package/src/components/render/ModelType.tsx +293 -0
  169. package/src/components/render/Order.tsx +124 -0
  170. package/src/components/render/Part.tsx +109 -0
  171. package/src/components/render/Plugin.tsx +21 -0
  172. package/src/components/render/Report.tsx +29 -0
  173. package/src/components/render/StatusRenderer.tsx +178 -0
  174. package/src/components/render/Stock.tsx +84 -0
  175. package/src/components/render/User.tsx +42 -0
  176. package/src/components/settings/FactCollection.tsx +31 -0
  177. package/src/components/settings/FactItem.tsx +17 -0
  178. package/src/components/settings/SettingItem.tsx +176 -0
  179. package/src/components/settings/SettingList.tsx +217 -0
  180. package/src/components/wizards/OrderPartsWizard.tsx +473 -0
  181. package/src/components/wizards/WizardDrawer.tsx +188 -0
  182. package/src/contexts/ApiContext.tsx +31 -0
  183. package/src/contexts/LanguageContext.tsx +155 -0
  184. package/src/contexts/ThemeContext.tsx +58 -0
  185. package/src/contexts/colorSchema.tsx +67 -0
  186. package/src/defaults/actions.tsx +87 -0
  187. package/src/defaults/backendMappings.tsx +32 -0
  188. package/src/defaults/defaultHostList.tsx +4 -0
  189. package/src/defaults/defaults.tsx +38 -0
  190. package/src/defaults/formatters.tsx +176 -0
  191. package/src/defaults/links.tsx +193 -0
  192. package/src/defaults/templates.tsx +53 -0
  193. package/src/forms/BomForms.tsx +26 -0
  194. package/src/forms/BuildForms.tsx +615 -0
  195. package/src/forms/CommonForms.tsx +89 -0
  196. package/src/forms/CompanyForms.tsx +133 -0
  197. package/src/forms/ImporterForms.tsx +20 -0
  198. package/src/forms/PartForms.tsx +281 -0
  199. package/src/forms/PurchaseOrderForms.tsx +779 -0
  200. package/src/forms/ReturnOrderForms.tsx +263 -0
  201. package/src/forms/SalesOrderForms.tsx +408 -0
  202. package/src/forms/StockForms.tsx +1296 -0
  203. package/src/forms/selectionListFields.tsx +120 -0
  204. package/src/functions/api.tsx +61 -0
  205. package/src/functions/auth.tsx +574 -0
  206. package/src/functions/conversion.tsx +42 -0
  207. package/src/functions/events.tsx +6 -0
  208. package/src/functions/forms.tsx +173 -0
  209. package/src/functions/icons.tsx +294 -0
  210. package/src/functions/loading.tsx +29 -0
  211. package/src/functions/navigation.tsx +20 -0
  212. package/src/functions/notifications.tsx +101 -0
  213. package/src/functions/tables.tsx +26 -0
  214. package/src/functions/uid.tsx +15 -0
  215. package/src/functions/urls.tsx +58 -0
  216. package/src/hooks/UseCalendar.tsx +178 -0
  217. package/src/hooks/UseDashboardItems.tsx +118 -0
  218. package/src/hooks/UseDataExport.tsx +125 -0
  219. package/src/hooks/UseDataOutput.tsx +109 -0
  220. package/src/hooks/UseFilter.tsx +67 -0
  221. package/src/hooks/UseFilterSet.tsx +24 -0
  222. package/src/hooks/UseForm.tsx +161 -0
  223. package/src/hooks/UseGenerator.tsx +92 -0
  224. package/src/hooks/UseImportSession.tsx +139 -0
  225. package/src/hooks/UseInstance.tsx +137 -0
  226. package/src/hooks/UseInstanceName.tsx +14 -0
  227. package/src/hooks/UseModal.tsx +38 -0
  228. package/src/hooks/UsePlaceholder.tsx +66 -0
  229. package/src/hooks/UsePluginPanels.tsx +123 -0
  230. package/src/hooks/UsePluginUIFeature.tsx +95 -0
  231. package/src/hooks/UsePlugins.tsx +45 -0
  232. package/src/hooks/UseSelectedRows.tsx +37 -0
  233. package/src/hooks/UseStatusCodes.tsx +50 -0
  234. package/src/hooks/UseTable.tsx +145 -0
  235. package/src/hooks/UseWizard.tsx +133 -0
  236. package/src/locales/ar/messages.d.ts +4 -0
  237. package/src/locales/ar/messages.po +10695 -0
  238. package/src/locales/ar/messages.ts +1 -0
  239. package/src/locales/bg/messages.d.ts +4 -0
  240. package/src/locales/bg/messages.po +10695 -0
  241. package/src/locales/bg/messages.ts +1 -0
  242. package/src/locales/cs/messages.d.ts +4 -0
  243. package/src/locales/cs/messages.po +10695 -0
  244. package/src/locales/cs/messages.ts +1 -0
  245. package/src/locales/da/messages.d.ts +4 -0
  246. package/src/locales/da/messages.po +10695 -0
  247. package/src/locales/da/messages.ts +1 -0
  248. package/src/locales/de/messages.d.ts +4 -0
  249. package/src/locales/de/messages.po +10695 -0
  250. package/src/locales/de/messages.ts +1 -0
  251. package/src/locales/el/messages.d.ts +4 -0
  252. package/src/locales/el/messages.po +10695 -0
  253. package/src/locales/el/messages.ts +1 -0
  254. package/src/locales/en/messages.d.ts +4 -0
  255. package/src/locales/en/messages.po +10689 -0
  256. package/src/locales/en/messages.ts +1 -0
  257. package/src/locales/es/messages.d.ts +4 -0
  258. package/src/locales/es/messages.po +10695 -0
  259. package/src/locales/es/messages.ts +1 -0
  260. package/src/locales/es_MX/messages.d.ts +4 -0
  261. package/src/locales/es_MX/messages.po +10695 -0
  262. package/src/locales/es_MX/messages.ts +1 -0
  263. package/src/locales/et/messages.d.ts +4 -0
  264. package/src/locales/et/messages.po +10695 -0
  265. package/src/locales/et/messages.ts +1 -0
  266. package/src/locales/fa/messages.d.ts +4 -0
  267. package/src/locales/fa/messages.po +10695 -0
  268. package/src/locales/fa/messages.ts +1 -0
  269. package/src/locales/fi/messages.d.ts +4 -0
  270. package/src/locales/fi/messages.po +10695 -0
  271. package/src/locales/fi/messages.ts +1 -0
  272. package/src/locales/fr/messages.d.ts +4 -0
  273. package/src/locales/fr/messages.po +10695 -0
  274. package/src/locales/fr/messages.ts +1 -0
  275. package/src/locales/he/messages.d.ts +4 -0
  276. package/src/locales/he/messages.po +10695 -0
  277. package/src/locales/he/messages.ts +1 -0
  278. package/src/locales/hi/messages.d.ts +4 -0
  279. package/src/locales/hi/messages.po +10695 -0
  280. package/src/locales/hi/messages.ts +1 -0
  281. package/src/locales/hu/messages.d.ts +4 -0
  282. package/src/locales/hu/messages.po +10695 -0
  283. package/src/locales/hu/messages.ts +1 -0
  284. package/src/locales/id/messages.po +10695 -0
  285. package/src/locales/it/messages.d.ts +4 -0
  286. package/src/locales/it/messages.po +10695 -0
  287. package/src/locales/it/messages.ts +1 -0
  288. package/src/locales/ja/messages.d.ts +4 -0
  289. package/src/locales/ja/messages.po +10695 -0
  290. package/src/locales/ja/messages.ts +1 -0
  291. package/src/locales/ko/messages.d.ts +4 -0
  292. package/src/locales/ko/messages.po +10695 -0
  293. package/src/locales/ko/messages.ts +1 -0
  294. package/src/locales/lt/messages.d.ts +4 -0
  295. package/src/locales/lt/messages.po +10695 -0
  296. package/src/locales/lt/messages.ts +1 -0
  297. package/src/locales/lv/messages.d.ts +4 -0
  298. package/src/locales/lv/messages.po +10695 -0
  299. package/src/locales/lv/messages.ts +1 -0
  300. package/src/locales/nl/messages.d.ts +4 -0
  301. package/src/locales/nl/messages.po +10695 -0
  302. package/src/locales/nl/messages.ts +1 -0
  303. package/src/locales/no/messages.d.ts +4 -0
  304. package/src/locales/no/messages.po +10695 -0
  305. package/src/locales/no/messages.ts +1 -0
  306. package/src/locales/pl/messages.d.ts +4 -0
  307. package/src/locales/pl/messages.po +10695 -0
  308. package/src/locales/pl/messages.ts +1 -0
  309. package/src/locales/pseudo-LOCALE/messages.d.ts +4 -0
  310. package/src/locales/pseudo-LOCALE/messages.po +8003 -0
  311. package/src/locales/pseudo-LOCALE/messages.ts +1 -0
  312. package/src/locales/pt/messages.d.ts +4 -0
  313. package/src/locales/pt/messages.po +10696 -0
  314. package/src/locales/pt/messages.ts +1 -0
  315. package/src/locales/pt_BR/messages.d.ts +4 -0
  316. package/src/locales/pt_BR/messages.po +10695 -0
  317. package/src/locales/pt_BR/messages.ts +1 -0
  318. package/src/locales/ro/messages.po +10695 -0
  319. package/src/locales/ro/messages.ts +1 -0
  320. package/src/locales/ru/messages.d.ts +4 -0
  321. package/src/locales/ru/messages.po +10695 -0
  322. package/src/locales/ru/messages.ts +1 -0
  323. package/src/locales/sk/messages.d.ts +4 -0
  324. package/src/locales/sk/messages.po +10695 -0
  325. package/src/locales/sk/messages.ts +1 -0
  326. package/src/locales/sl/messages.d.ts +4 -0
  327. package/src/locales/sl/messages.po +10695 -0
  328. package/src/locales/sl/messages.ts +1 -0
  329. package/src/locales/sr/messages.d.ts +4 -0
  330. package/src/locales/sr/messages.po +10695 -0
  331. package/src/locales/sr/messages.ts +1 -0
  332. package/src/locales/sv/messages.d.ts +4 -0
  333. package/src/locales/sv/messages.po +10695 -0
  334. package/src/locales/sv/messages.ts +1 -0
  335. package/src/locales/th/messages.d.ts +4 -0
  336. package/src/locales/th/messages.po +10695 -0
  337. package/src/locales/th/messages.ts +1 -0
  338. package/src/locales/tr/messages.d.ts +4 -0
  339. package/src/locales/tr/messages.po +10695 -0
  340. package/src/locales/tr/messages.ts +1 -0
  341. package/src/locales/uk/messages.d.ts +3 -0
  342. package/src/locales/uk/messages.po +10695 -0
  343. package/src/locales/uk/messages.ts +1 -0
  344. package/src/locales/vi/messages.d.ts +4 -0
  345. package/src/locales/vi/messages.po +10695 -0
  346. package/src/locales/vi/messages.ts +1 -0
  347. package/src/locales/zh_Hans/messages.d.ts +4 -0
  348. package/src/locales/zh_Hans/messages.po +10695 -0
  349. package/src/locales/zh_Hans/messages.ts +1 -0
  350. package/src/locales/zh_Hant/messages.d.ts +4 -0
  351. package/src/locales/zh_Hant/messages.po +10695 -0
  352. package/src/locales/zh_Hant/messages.ts +1 -0
  353. package/src/main.css.ts +148 -0
  354. package/src/main.tsx +123 -0
  355. package/src/pages/Auth/ChangePassword.tsx +84 -0
  356. package/src/pages/Auth/Layout.tsx +74 -0
  357. package/src/pages/Auth/LoggedIn.tsx +21 -0
  358. package/src/pages/Auth/Login.tsx +133 -0
  359. package/src/pages/Auth/Logout.tsx +16 -0
  360. package/src/pages/Auth/MFA.tsx +36 -0
  361. package/src/pages/Auth/MFASetup.tsx +38 -0
  362. package/src/pages/Auth/Register.tsx +28 -0
  363. package/src/pages/Auth/Reset.tsx +30 -0
  364. package/src/pages/Auth/ResetPassword.tsx +48 -0
  365. package/src/pages/Auth/VerifyEmail.tsx +34 -0
  366. package/src/pages/ErrorPage.tsx +26 -0
  367. package/src/pages/Index/Home.tsx +12 -0
  368. package/src/pages/Index/Scan.tsx +258 -0
  369. package/src/pages/Index/Settings/AccountSettings/AccountDetailPanel.tsx +162 -0
  370. package/src/pages/Index/Settings/AccountSettings/QrRegistrationForm.tsx +38 -0
  371. package/src/pages/Index/Settings/AccountSettings/SecurityContent.tsx +713 -0
  372. package/src/pages/Index/Settings/AccountSettings/UserPanel.tsx +24 -0
  373. package/src/pages/Index/Settings/AccountSettings/UserThemePanel.tsx +207 -0
  374. package/src/pages/Index/Settings/AccountSettings/useConfirm.tsx +117 -0
  375. package/src/pages/Index/Settings/AdminCenter/CurrencyManagementPanel.tsx +111 -0
  376. package/src/pages/Index/Settings/AdminCenter/Index.tsx +251 -0
  377. package/src/pages/Index/Settings/AdminCenter/LabelTemplatePanel.tsx +23 -0
  378. package/src/pages/Index/Settings/AdminCenter/MachineManagementPanel.tsx +110 -0
  379. package/src/pages/Index/Settings/AdminCenter/PartParameterPanel.tsx +29 -0
  380. package/src/pages/Index/Settings/AdminCenter/PluginManagementPanel.tsx +84 -0
  381. package/src/pages/Index/Settings/AdminCenter/ReportTemplatePanel.tsx +38 -0
  382. package/src/pages/Index/Settings/AdminCenter/StocktakePanel.tsx +31 -0
  383. package/src/pages/Index/Settings/AdminCenter/TaskManagementPanel.tsx +73 -0
  384. package/src/pages/Index/Settings/AdminCenter/UnitManagementPanel.tsx +74 -0
  385. package/src/pages/Index/Settings/AdminCenter/UserManagementPanel.tsx +49 -0
  386. package/src/pages/Index/Settings/SystemSettings.tsx +339 -0
  387. package/src/pages/Index/Settings/UserSettings.tsx +143 -0
  388. package/src/pages/Notifications.tsx +134 -0
  389. package/src/pages/build/BuildDetail.tsx +579 -0
  390. package/src/pages/build/BuildIndex.tsx +100 -0
  391. package/src/pages/company/CompanyDetail.tsx +352 -0
  392. package/src/pages/company/CustomerDetail.tsx +13 -0
  393. package/src/pages/company/ManufacturerDetail.tsx +13 -0
  394. package/src/pages/company/ManufacturerPartDetail.tsx +307 -0
  395. package/src/pages/company/SupplierDetail.tsx +13 -0
  396. package/src/pages/company/SupplierPartDetail.tsx +433 -0
  397. package/src/pages/core/CoreIndex.tsx +50 -0
  398. package/src/pages/core/GroupDetail.tsx +97 -0
  399. package/src/pages/core/UserDetail.tsx +193 -0
  400. package/src/pages/part/CategoryDetail.tsx +369 -0
  401. package/src/pages/part/PartAllocationPanel.tsx +40 -0
  402. package/src/pages/part/PartDetail.tsx +1071 -0
  403. package/src/pages/part/PartPricingPanel.tsx +155 -0
  404. package/src/pages/part/PartSchedulingDetail.tsx +315 -0
  405. package/src/pages/part/PartStocktakeDetail.tsx +285 -0
  406. package/src/pages/part/PartSupplierDetail.tsx +31 -0
  407. package/src/pages/part/pricing/BomPricingPanel.tsx +269 -0
  408. package/src/pages/part/pricing/PriceBreakPanel.tsx +182 -0
  409. package/src/pages/part/pricing/PricingOverviewPanel.tsx +338 -0
  410. package/src/pages/part/pricing/PricingPanel.tsx +82 -0
  411. package/src/pages/part/pricing/PurchaseHistoryPanel.tsx +134 -0
  412. package/src/pages/part/pricing/SaleHistoryPanel.tsx +95 -0
  413. package/src/pages/part/pricing/SupplierPricingPanel.tsx +80 -0
  414. package/src/pages/part/pricing/VariantPricingPanel.tsx +112 -0
  415. package/src/pages/purchasing/PurchaseOrderDetail.tsx +547 -0
  416. package/src/pages/purchasing/PurchasingIndex.tsx +131 -0
  417. package/src/pages/sales/ReturnOrderDetail.tsx +529 -0
  418. package/src/pages/sales/SalesIndex.tsx +148 -0
  419. package/src/pages/sales/SalesOrderDetail.tsx +593 -0
  420. package/src/pages/sales/SalesOrderShipmentDetail.tsx +385 -0
  421. package/src/pages/stock/LocationDetail.tsx +413 -0
  422. package/src/pages/stock/StockDetail.tsx +951 -0
  423. package/src/router.tsx +213 -0
  424. package/src/states/ApiState.tsx +85 -0
  425. package/src/states/IconState.tsx +94 -0
  426. package/src/states/LocalState.tsx +181 -0
  427. package/src/states/SettingsState.tsx +206 -0
  428. package/src/states/StatusState.tsx +55 -0
  429. package/src/states/UserState.tsx +202 -0
  430. package/src/states/states.tsx +69 -0
  431. package/src/tables/Column.tsx +29 -0
  432. package/src/tables/ColumnRenderers.tsx +320 -0
  433. package/src/tables/ColumnSelect.tsx +39 -0
  434. package/src/tables/Filter.tsx +297 -0
  435. package/src/tables/FilterSelectDrawer.tsx +358 -0
  436. package/src/tables/InvenTreeTable.tsx +750 -0
  437. package/src/tables/InvenTreeTableHeader.tsx +257 -0
  438. package/src/tables/RowActions.tsx +176 -0
  439. package/src/tables/RowExpansionIcon.tsx +16 -0
  440. package/src/tables/Search.tsx +42 -0
  441. package/src/tables/TableHoverCard.tsx +91 -0
  442. package/src/tables/bom/BomTable.tsx +590 -0
  443. package/src/tables/bom/UsedInTable.tsx +114 -0
  444. package/src/tables/build/BuildAllocatedStockTable.tsx +233 -0
  445. package/src/tables/build/BuildLineTable.tsx +800 -0
  446. package/src/tables/build/BuildOrderTable.tsx +226 -0
  447. package/src/tables/build/BuildOrderTestTable.tsx +265 -0
  448. package/src/tables/build/BuildOutputTable.tsx +599 -0
  449. package/src/tables/company/AddressTable.tsx +211 -0
  450. package/src/tables/company/CompanyTable.tsx +176 -0
  451. package/src/tables/company/ContactTable.tsx +182 -0
  452. package/src/tables/core/UserTable.tsx +88 -0
  453. package/src/tables/general/AttachmentTable.tsx +404 -0
  454. package/src/tables/general/BarcodeScanTable.tsx +124 -0
  455. package/src/tables/general/ExtraLineItemTable.tsx +174 -0
  456. package/src/tables/machine/MachineListTable.tsx +634 -0
  457. package/src/tables/machine/MachineTypeTable.tsx +395 -0
  458. package/src/tables/notifications/NotificationTable.tsx +60 -0
  459. package/src/tables/part/ParametricPartTable.tsx +297 -0
  460. package/src/tables/part/PartBuildAllocationsTable.tsx +128 -0
  461. package/src/tables/part/PartCategoryTable.tsx +208 -0
  462. package/src/tables/part/PartCategoryTemplateTable.tsx +157 -0
  463. package/src/tables/part/PartParameterTable.tsx +226 -0
  464. package/src/tables/part/PartParameterTemplateTable.tsx +168 -0
  465. package/src/tables/part/PartPurchaseOrdersTable.tsx +163 -0
  466. package/src/tables/part/PartSalesAllocationsTable.tsx +130 -0
  467. package/src/tables/part/PartTable.tsx +423 -0
  468. package/src/tables/part/PartTestTemplateTable.tsx +290 -0
  469. package/src/tables/part/PartThumbTable.tsx +230 -0
  470. package/src/tables/part/PartVariantTable.tsx +52 -0
  471. package/src/tables/part/RelatedPartTable.tsx +182 -0
  472. package/src/tables/part/SelectionListTable.tsx +134 -0
  473. package/src/tables/plugin/PluginErrorTable.tsx +58 -0
  474. package/src/tables/plugin/PluginListTable.tsx +440 -0
  475. package/src/tables/purchasing/ManufacturerPartParameterTable.tsx +136 -0
  476. package/src/tables/purchasing/ManufacturerPartTable.tsx +158 -0
  477. package/src/tables/purchasing/PurchaseOrderLineItemTable.tsx +424 -0
  478. package/src/tables/purchasing/PurchaseOrderTable.tsx +193 -0
  479. package/src/tables/purchasing/SupplierPartTable.tsx +281 -0
  480. package/src/tables/purchasing/SupplierPriceBreakTable.tsx +222 -0
  481. package/src/tables/sales/ReturnOrderLineItemTable.tsx +271 -0
  482. package/src/tables/sales/ReturnOrderTable.tsx +201 -0
  483. package/src/tables/sales/SalesOrderAllocationTable.tsx +330 -0
  484. package/src/tables/sales/SalesOrderLineItemTable.tsx +508 -0
  485. package/src/tables/sales/SalesOrderShipmentTable.tsx +225 -0
  486. package/src/tables/sales/SalesOrderTable.tsx +212 -0
  487. package/src/tables/settings/ApiTokenTable.tsx +203 -0
  488. package/src/tables/settings/BarcodeScanHistoryTable.tsx +281 -0
  489. package/src/tables/settings/CustomStateTable.tsx +226 -0
  490. package/src/tables/settings/CustomUnitsTable.tsx +125 -0
  491. package/src/tables/settings/ErrorTable.tsx +170 -0
  492. package/src/tables/settings/ExportSessionTable.tsx +60 -0
  493. package/src/tables/settings/FailedTasksTable.tsx +103 -0
  494. package/src/tables/settings/GroupTable.tsx +240 -0
  495. package/src/tables/settings/ImportSessionTable.tsx +175 -0
  496. package/src/tables/settings/PendingTasksTable.tsx +63 -0
  497. package/src/tables/settings/ProjectCodeTable.tsx +115 -0
  498. package/src/tables/settings/ScheduledTasksTable.tsx +62 -0
  499. package/src/tables/settings/StocktakeReportTable.tsx +111 -0
  500. package/src/tables/settings/TemplateTable.tsx +404 -0
  501. package/src/tables/settings/UserTable.tsx +329 -0
  502. package/src/tables/stock/InstalledItemsTable.tsx +146 -0
  503. package/src/tables/stock/LocationTypesTable.tsx +132 -0
  504. package/src/tables/stock/StockItemTable.tsx +707 -0
  505. package/src/tables/stock/StockItemTestResultTable.tsx +487 -0
  506. package/src/tables/stock/StockLocationTable.tsx +208 -0
  507. package/src/tables/stock/StockTrackingTable.tsx +244 -0
  508. package/src/theme.ts +5 -0
  509. package/src/views/DesktopAppView.tsx +28 -0
  510. package/src/views/MainView.tsx +38 -0
  511. package/src/views/MobileAppView.tsx +43 -0
  512. package/tests/baseFixtures.ts +93 -0
  513. package/tests/defaults.ts +18 -0
  514. package/tests/helpers.ts +122 -0
  515. package/tests/login.ts +97 -0
  516. package/tests/pages/pui_build.spec.ts +373 -0
  517. package/tests/pages/pui_company.spec.ts +40 -0
  518. package/tests/pages/pui_core.spec.ts +26 -0
  519. package/tests/pages/pui_dashboard.spec.ts +64 -0
  520. package/tests/pages/pui_part.spec.ts +413 -0
  521. package/tests/pages/pui_purchase_order.spec.ts +388 -0
  522. package/tests/pages/pui_sales_order.spec.ts +224 -0
  523. package/tests/pages/pui_scan.spec.ts +114 -0
  524. package/tests/pages/pui_stock.spec.ts +259 -0
  525. package/tests/pui_exporting.spec.ts +124 -0
  526. package/tests/pui_forms.spec.ts +131 -0
  527. package/tests/pui_general.spec.ts +60 -0
  528. package/tests/pui_login.spec.ts +74 -0
  529. package/tests/pui_modals.spec.ts +144 -0
  530. package/tests/pui_plugins.spec.ts +216 -0
  531. package/tests/pui_printing.spec.ts +149 -0
  532. package/tests/pui_settings.spec.ts +285 -0
  533. package/tests/pui_tables.spec.ts +65 -0
  534. package/tests/settings/selectionList.spec.ts +103 -0
  535. package/tests/settings.ts +54 -0
  536. package/tsconfig.json +25 -0
  537. package/tsconfig.lib.json +13 -0
  538. package/tsconfig.node.json +11 -0
  539. package/vite-env.d.ts +11 -0
  540. package/vite.config.ts +98 -0
  541. package/vite.lib.config.ts +50 -0
@@ -0,0 +1,290 @@
1
+ import { t } from '@lingui/core/macro';
2
+ import {
3
+ Button,
4
+ type FloatingPosition,
5
+ Indicator,
6
+ type IndicatorProps,
7
+ Menu,
8
+ Tooltip
9
+ } from '@mantine/core';
10
+ import { modals } from '@mantine/modals';
11
+ import {
12
+ IconChevronDown,
13
+ IconCopy,
14
+ IconDotsVertical,
15
+ IconEdit,
16
+ IconLink,
17
+ IconQrcode,
18
+ IconTrash,
19
+ IconUnlink
20
+ } from '@tabler/icons-react';
21
+ import { type ReactNode, useMemo } from 'react';
22
+
23
+ import type { ModelType } from '@lib/enums/ModelType';
24
+ import { identifierString } from '../../functions/conversion';
25
+ import { InvenTreeIcon } from '../../functions/icons';
26
+ import { InvenTreeQRCode, QRCodeLink, QRCodeUnlink } from '../barcodes/QRCode';
27
+ import { StylishText } from './StylishText';
28
+
29
+ export type ActionDropdownItem = {
30
+ icon?: ReactNode;
31
+ name?: string;
32
+ tooltip?: string;
33
+ disabled?: boolean;
34
+ hidden?: boolean;
35
+ onClick: (event?: any) => void;
36
+ indicator?: Omit<IndicatorProps, 'children'>;
37
+ };
38
+
39
+ /**
40
+ * A simple Menu component which renders a set of actions.
41
+ *
42
+ * If no "active" actions are provided, the menu will not be rendered
43
+ */
44
+ export function ActionDropdown({
45
+ icon,
46
+ tooltip,
47
+ tooltipPosition,
48
+ actions,
49
+ disabled = false,
50
+ hidden = false,
51
+ noindicator = false
52
+ }: {
53
+ icon: ReactNode;
54
+ tooltip: string;
55
+ tooltipPosition?: FloatingPosition;
56
+ actions: ActionDropdownItem[];
57
+ disabled?: boolean;
58
+ hidden?: boolean;
59
+ noindicator?: boolean;
60
+ }) {
61
+ const hasActions = useMemo(() => {
62
+ return actions.some((action) => !action.hidden);
63
+ }, [actions]);
64
+
65
+ const indicatorProps = useMemo(() => {
66
+ return actions.find((action) => action.indicator);
67
+ }, [actions]);
68
+
69
+ const menuName: string = useMemo(() => {
70
+ return identifierString(`action-menu-${tooltip}`);
71
+ }, [tooltip]);
72
+
73
+ return !hidden && hasActions ? (
74
+ <Menu position='bottom-end' key={menuName}>
75
+ <Indicator disabled={!indicatorProps} {...indicatorProps?.indicator}>
76
+ <Menu.Target>
77
+ <Tooltip
78
+ label={tooltip}
79
+ hidden={!tooltip}
80
+ position={tooltipPosition ?? 'bottom'}
81
+ >
82
+ <Button
83
+ variant={noindicator ? 'transparent' : 'light'}
84
+ disabled={disabled}
85
+ aria-label={menuName}
86
+ p='0'
87
+ size='sm'
88
+ rightSection={
89
+ noindicator ? null : <IconChevronDown stroke={1.5} />
90
+ }
91
+ styles={{
92
+ section: { margin: 0 }
93
+ }}
94
+ >
95
+ {icon}
96
+ </Button>
97
+ </Tooltip>
98
+ </Menu.Target>
99
+ </Indicator>
100
+ <Menu.Dropdown>
101
+ {actions.map((action) => {
102
+ const id: string = identifierString(`${menuName}-${action.name}`);
103
+ return action.hidden ? null : (
104
+ <Indicator
105
+ disabled={!action.indicator}
106
+ {...action.indicator}
107
+ key={action.name}
108
+ >
109
+ <Tooltip
110
+ label={action.tooltip}
111
+ hidden={!action.tooltip}
112
+ position='left'
113
+ >
114
+ <Menu.Item
115
+ aria-label={id}
116
+ leftSection={action.icon}
117
+ onClick={action.onClick}
118
+ disabled={action.disabled}
119
+ >
120
+ {action.name}
121
+ </Menu.Item>
122
+ </Tooltip>
123
+ </Indicator>
124
+ );
125
+ })}
126
+ </Menu.Dropdown>
127
+ </Menu>
128
+ ) : null;
129
+ }
130
+
131
+ export function OptionsActionDropdown({
132
+ actions = [],
133
+ tooltip = t`Options`,
134
+ hidden = false
135
+ }: Readonly<{
136
+ actions: ActionDropdownItem[];
137
+ tooltip?: string;
138
+ hidden?: boolean;
139
+ }>) {
140
+ return (
141
+ <ActionDropdown
142
+ icon={<IconDotsVertical />}
143
+ tooltip={tooltip}
144
+ actions={actions}
145
+ hidden={hidden}
146
+ noindicator
147
+ />
148
+ );
149
+ }
150
+
151
+ // Dropdown menu for barcode actions
152
+ export function BarcodeActionDropdown({
153
+ model,
154
+ pk,
155
+ hash = null,
156
+ actions = [],
157
+ perm: permission = true
158
+ }: Readonly<{
159
+ model: ModelType;
160
+ pk: number;
161
+ hash?: boolean | null;
162
+ actions?: ActionDropdownItem[];
163
+ perm?: boolean;
164
+ }>) {
165
+ const hidden = hash === null;
166
+ const prop = { model, pk, hash };
167
+ return (
168
+ <ActionDropdown
169
+ tooltip={t`Barcode Actions`}
170
+ icon={<IconQrcode />}
171
+ actions={[
172
+ GeneralBarcodeAction({
173
+ mdl_prop: prop,
174
+ title: t`View Barcode`,
175
+ icon: <IconQrcode />,
176
+ tooltip: t`View barcode`,
177
+ ChildItem: InvenTreeQRCode
178
+ }),
179
+ GeneralBarcodeAction({
180
+ hidden: hidden || hash || !permission,
181
+ mdl_prop: prop,
182
+ title: t`Link Barcode`,
183
+ icon: <IconLink />,
184
+ tooltip: t`Link a custom barcode to this item`,
185
+ ChildItem: QRCodeLink
186
+ }),
187
+ GeneralBarcodeAction({
188
+ hidden: hidden || !hash || !permission,
189
+ mdl_prop: prop,
190
+ title: t`Unlink Barcode`,
191
+ icon: <IconUnlink />,
192
+ tooltip: t`Unlink custom barcode`,
193
+ ChildItem: QRCodeUnlink
194
+ }),
195
+ ...actions
196
+ ]}
197
+ />
198
+ );
199
+ }
200
+
201
+ export type QrCodeType = {
202
+ model: ModelType;
203
+ pk: number;
204
+ hash?: boolean | null;
205
+ };
206
+
207
+ function GeneralBarcodeAction({
208
+ hidden = false,
209
+ mdl_prop,
210
+ title,
211
+ icon,
212
+ tooltip,
213
+ ChildItem
214
+ }: {
215
+ hidden?: boolean;
216
+ mdl_prop: QrCodeType;
217
+ title: string;
218
+ icon: ReactNode;
219
+ tooltip: string;
220
+ ChildItem: any;
221
+ }): ActionDropdownItem {
222
+ const onClick = () => {
223
+ modals.open({
224
+ title: <StylishText size='xl'>{title}</StylishText>,
225
+ children: <ChildItem mdl_prop={mdl_prop} />
226
+ });
227
+ };
228
+
229
+ return {
230
+ icon: icon,
231
+ name: title,
232
+ tooltip: tooltip,
233
+ onClick: onClick,
234
+ hidden: hidden
235
+ };
236
+ }
237
+
238
+ // Common action button for editing an item
239
+ export function EditItemAction(props: ActionDropdownItem): ActionDropdownItem {
240
+ return {
241
+ ...props,
242
+ icon: <IconEdit color='blue' />,
243
+ name: t`Edit`,
244
+ tooltip: props.tooltip ?? t`Edit item`
245
+ };
246
+ }
247
+
248
+ // Common action button for deleting an item
249
+ export function DeleteItemAction(
250
+ props: ActionDropdownItem
251
+ ): ActionDropdownItem {
252
+ return {
253
+ ...props,
254
+ icon: <IconTrash color='red' />,
255
+ name: t`Delete`,
256
+ tooltip: props.tooltip ?? t`Delete item`
257
+ };
258
+ }
259
+
260
+ export function HoldItemAction(props: ActionDropdownItem): ActionDropdownItem {
261
+ return {
262
+ ...props,
263
+ icon: <InvenTreeIcon icon='hold' iconProps={{ color: 'orange' }} />,
264
+ name: t`Hold`,
265
+ tooltip: props.tooltip ?? t`Hold`
266
+ };
267
+ }
268
+
269
+ export function CancelItemAction(
270
+ props: ActionDropdownItem
271
+ ): ActionDropdownItem {
272
+ return {
273
+ ...props,
274
+ icon: <InvenTreeIcon icon='cancel' iconProps={{ color: 'red' }} />,
275
+ name: t`Cancel`,
276
+ tooltip: props.tooltip ?? t`Cancel`
277
+ };
278
+ }
279
+
280
+ // Common action button for duplicating an item
281
+ export function DuplicateItemAction(
282
+ props: ActionDropdownItem
283
+ ): ActionDropdownItem {
284
+ return {
285
+ ...props,
286
+ icon: <IconCopy color='green' />,
287
+ name: t`Duplicate`,
288
+ tooltip: props.tooltip ?? t`Duplicate item`
289
+ };
290
+ }
@@ -0,0 +1,13 @@
1
+ import { style } from '@vanilla-extract/css';
2
+
3
+ export const icon = style({
4
+ fontStyle: 'normal',
5
+ fontWeight: 'normal',
6
+ fontVariant: 'normal',
7
+ textTransform: 'none',
8
+ lineHeight: 1,
9
+ width: 'fit-content',
10
+ // Better font rendering
11
+ WebkitFontSmoothing: 'antialiased',
12
+ MozOsxFontSmoothing: 'grayscale'
13
+ });
@@ -0,0 +1,32 @@
1
+ import { useIconState } from '../../states/IconState';
2
+ import * as classes from './ApiIcon.css';
3
+
4
+ type ApiIconProps = {
5
+ name: string;
6
+ size?: number;
7
+ };
8
+
9
+ export const ApiIcon = ({ name: _name, size = 22 }: ApiIconProps) => {
10
+ const [iconPackage, name, variant] = _name.split(':');
11
+ const icon = useIconState(
12
+ (s) => s.packagesMap[iconPackage]?.icons[name]?.variants[variant]
13
+ );
14
+
15
+ const unicode = icon ? String.fromCodePoint(Number.parseInt(icon, 16)) : '';
16
+
17
+ if (!unicode && _name !== '') {
18
+ console.warn(`ApiIcon not found: '${_name}'`);
19
+ }
20
+
21
+ return (
22
+ <i
23
+ className={classes.icon}
24
+ style={{
25
+ fontFamily: `inventree-icon-font-${iconPackage}`,
26
+ fontSize: size
27
+ }}
28
+ >
29
+ {unicode}
30
+ </i>
31
+ );
32
+ };
@@ -0,0 +1,79 @@
1
+ import { Anchor, Group } from '@mantine/core';
2
+ import {
3
+ IconFile,
4
+ IconFileTypeCsv,
5
+ IconFileTypeDoc,
6
+ IconFileTypePdf,
7
+ IconFileTypeXls,
8
+ IconFileTypeZip,
9
+ IconLink,
10
+ IconPhoto
11
+ } from '@tabler/icons-react';
12
+ import { type ReactNode, useMemo } from 'react';
13
+ import { generateUrl } from '../../functions/urls';
14
+
15
+ /**
16
+ * Return an icon based on the provided filename
17
+ */
18
+ export function attachmentIcon(attachment: string): ReactNode {
19
+ const sz = 18;
20
+ const suffix = attachment.split('.').pop()?.toLowerCase() ?? '';
21
+ switch (suffix) {
22
+ case 'pdf':
23
+ return <IconFileTypePdf size={sz} />;
24
+ case 'csv':
25
+ return <IconFileTypeCsv size={sz} />;
26
+ case 'xls':
27
+ case 'xlsx':
28
+ return <IconFileTypeXls size={sz} />;
29
+ case 'doc':
30
+ case 'docx':
31
+ return <IconFileTypeDoc size={sz} />;
32
+ case 'zip':
33
+ case 'tar':
34
+ case 'gz':
35
+ case '7z':
36
+ return <IconFileTypeZip size={sz} />;
37
+ case 'png':
38
+ case 'jpg':
39
+ case 'jpeg':
40
+ case 'gif':
41
+ case 'bmp':
42
+ case 'tif':
43
+ case 'webp':
44
+ return <IconPhoto size={sz} />;
45
+ default:
46
+ return <IconFile size={sz} />;
47
+ }
48
+ }
49
+
50
+ /**
51
+ * Render a link to a file attachment, with icon and text
52
+ * @param attachment : string - The attachment filename
53
+ */
54
+ export function AttachmentLink({
55
+ attachment,
56
+ external
57
+ }: Readonly<{
58
+ attachment: string;
59
+ external?: boolean;
60
+ }>): ReactNode {
61
+ const text = external ? attachment : attachment.split('/').pop();
62
+
63
+ const url = useMemo(() => {
64
+ if (external) {
65
+ return attachment;
66
+ }
67
+
68
+ return generateUrl(attachment);
69
+ }, [attachment, external]);
70
+
71
+ return (
72
+ <Group justify='left' gap='sm' wrap='nowrap'>
73
+ {external ? <IconLink /> : attachmentIcon(attachment)}
74
+ <Anchor href={url} target='_blank' rel='noopener noreferrer'>
75
+ {text}
76
+ </Anchor>
77
+ </Group>
78
+ );
79
+ }
@@ -0,0 +1,34 @@
1
+ import {
2
+ ActionIcon,
3
+ Group,
4
+ Tooltip,
5
+ useMantineColorScheme
6
+ } from '@mantine/core';
7
+ import { IconMoonStars, IconSun } from '@tabler/icons-react';
8
+
9
+ import { t } from '@lingui/core/macro';
10
+ import { vars } from '../../theme';
11
+
12
+ export function ColorToggle() {
13
+ const { colorScheme, toggleColorScheme } = useMantineColorScheme();
14
+
15
+ return (
16
+ <Group justify='center'>
17
+ <Tooltip label={t`Toggle color scheme`}>
18
+ <ActionIcon
19
+ onClick={toggleColorScheme}
20
+ size='lg'
21
+ style={{
22
+ color:
23
+ colorScheme === 'dark'
24
+ ? vars.colors.yellow[4]
25
+ : vars.colors.blue[6]
26
+ }}
27
+ variant='transparent'
28
+ >
29
+ {colorScheme === 'dark' ? <IconSun /> : <IconMoonStars />}
30
+ </ActionIcon>
31
+ </Tooltip>
32
+ </Group>
33
+ );
34
+ }
@@ -0,0 +1,33 @@
1
+ import { Group, LoadingOverlay, Paper, Text } from '@mantine/core';
2
+
3
+ import * as classes from '../../main.css';
4
+
5
+ export interface StatisticItemProps {
6
+ title: string;
7
+ value: string;
8
+ }
9
+
10
+ export function StatisticItem({
11
+ id,
12
+ data,
13
+ isLoading
14
+ }: Readonly<{
15
+ id: string;
16
+ data: StatisticItemProps;
17
+ isLoading: boolean;
18
+ }>) {
19
+ return (
20
+ <Paper withBorder p='xs' key={id} pos='relative'>
21
+ <LoadingOverlay visible={isLoading} overlayProps={{ blur: 2 }} />
22
+ <Group justify='space-between'>
23
+ <Text size='xs' c='dimmed' className={classes.dashboardItemTitle}>
24
+ {data.title}
25
+ </Text>
26
+ </Group>
27
+
28
+ <Group align='flex-end' gap='xs' mt={25}>
29
+ <Text className={classes.dashboardItemValue}>{data.value}</Text>
30
+ </Group>
31
+ </Paper>
32
+ );
33
+ }
@@ -0,0 +1,20 @@
1
+ import { IconInfoCircle } from '@tabler/icons-react';
2
+
3
+ import { type BaseDocProps, DocTooltip } from './DocTooltip';
4
+
5
+ interface DocInfoProps extends BaseDocProps {
6
+ size?: number;
7
+ }
8
+
9
+ export function DocInfo({
10
+ size = 18,
11
+ text,
12
+ detail,
13
+ link
14
+ }: Readonly<DocInfoProps>) {
15
+ return (
16
+ <DocTooltip text={text} detail={detail} link={link}>
17
+ <IconInfoCircle size={size} />
18
+ </DocTooltip>
19
+ );
20
+ }
@@ -0,0 +1,98 @@
1
+ import { Trans } from '@lingui/react/macro';
2
+ import { Anchor, Container, HoverCard, ScrollArea, Text } from '@mantine/core';
3
+ import { useEffect, useRef, useState } from 'react';
4
+
5
+ import * as classes from '../../main.css';
6
+
7
+ export interface BaseDocProps {
8
+ text: string | JSX.Element;
9
+ detail?: string | JSX.Element;
10
+ link?: string;
11
+ docchildren?: React.ReactNode;
12
+ }
13
+
14
+ export interface DocTooltipProps extends BaseDocProps {
15
+ children: React.ReactNode;
16
+ }
17
+
18
+ export function DocTooltip({
19
+ children,
20
+ text,
21
+ detail,
22
+ link,
23
+ docchildren
24
+ }: Readonly<DocTooltipProps>) {
25
+ return (
26
+ <HoverCard
27
+ shadow='md'
28
+ openDelay={200}
29
+ closeDelay={200}
30
+ withinPortal={true}
31
+ classNames={{ dropdown: classes.docHover }}
32
+ >
33
+ <HoverCard.Target>
34
+ <div>{children}</div>
35
+ </HoverCard.Target>
36
+ <HoverCard.Dropdown>
37
+ <ConstBody
38
+ text={text}
39
+ detail={detail}
40
+ docchildren={docchildren}
41
+ link={link}
42
+ />
43
+ </HoverCard.Dropdown>
44
+ </HoverCard>
45
+ );
46
+ }
47
+
48
+ function ConstBody({
49
+ text,
50
+ detail,
51
+ docchildren,
52
+ link
53
+ }: Readonly<{
54
+ text: string | JSX.Element;
55
+ detail?: string | JSX.Element;
56
+ docchildren?: React.ReactNode;
57
+ link?: string;
58
+ }>) {
59
+ const [height, setHeight] = useState(0);
60
+ const ref = useRef(null);
61
+
62
+ // dynamically set height of scroll area based on content to remove unnecessary scroll bar
63
+ useEffect(() => {
64
+ if (ref.current == null) return;
65
+
66
+ const height = ref.current['clientHeight'];
67
+ if (height > 250) {
68
+ setHeight(250);
69
+ } else {
70
+ setHeight(height + 1);
71
+ }
72
+ });
73
+
74
+ return (
75
+ <Container maw={400} p={0}>
76
+ <Text>{text}</Text>
77
+ {(detail || docchildren) && (
78
+ <ScrollArea h={height} mah={250}>
79
+ <div ref={ref}>
80
+ {detail && (
81
+ <Text size='xs' c='dimmed'>
82
+ {detail}
83
+ </Text>
84
+ )}
85
+ {docchildren}
86
+ </div>
87
+ </ScrollArea>
88
+ )}
89
+ {link && (
90
+ <Anchor href={link} target='_blank'>
91
+ <Text size={'sm'}>
92
+ <Trans>Read More</Trans>
93
+ </Text>
94
+ </Anchor>
95
+ )}
96
+ </Container>
97
+ );
98
+ }
@@ -0,0 +1,17 @@
1
+ import { t } from '@lingui/core/macro';
2
+ import { Alert, Text } from '@mantine/core';
3
+
4
+ export function ErrorItem({
5
+ id,
6
+ error
7
+ }: Readonly<{ id: string; error?: any }>) {
8
+ const error_message = error?.message || error?.toString() || t`Unknown error`;
9
+
10
+ return (
11
+ <>
12
+ <Alert color='red' title={t`An error occurred`}>
13
+ <Text>{error_message}</Text>
14
+ </Alert>
15
+ </>
16
+ );
17
+ }
@@ -0,0 +1,14 @@
1
+ import type { ReactNode } from 'react';
2
+
3
+ /**
4
+ * A component that expands to fill the available space
5
+ */
6
+ export default function Expand({
7
+ children,
8
+ flex
9
+ }: {
10
+ children: ReactNode;
11
+ flex?: number;
12
+ }) {
13
+ return <div style={{ flexGrow: flex ?? 1 }}>{children}</div>;
14
+ }
@@ -0,0 +1,30 @@
1
+ import { rem } from '@mantine/core';
2
+ import { style } from '@vanilla-extract/css';
3
+
4
+ import { vars } from '../../theme';
5
+
6
+ export const card = style({
7
+ height: rem(170),
8
+ display: 'flex',
9
+ flexDirection: 'column',
10
+ justifyContent: 'space-between',
11
+ alignItems: 'flex-start',
12
+ backgroundSize: 'cover',
13
+ backgroundPosition: 'center'
14
+ });
15
+
16
+ export const title = style({
17
+ fontWeight: 900,
18
+ lineHeight: 1.2,
19
+ fontSize: rem(32),
20
+ marginTop: 0,
21
+ [vars.lightSelector]: { color: vars.colors.dark[5] },
22
+ [vars.darkSelector]: { color: vars.colors.white[0] }
23
+ });
24
+
25
+ export const category = style({
26
+ opacity: 0.7,
27
+ fontWeight: 700,
28
+ [vars.lightSelector]: { color: vars.colors.dark[5] },
29
+ [vars.darkSelector]: { color: vars.colors.white[0] }
30
+ });