bananas-commerce-admin 0.2.2 → 0.2.4

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 (355) hide show
  1. package/README.md +4 -8
  2. package/dist/cjs/Admin.js +28 -27
  3. package/dist/cjs/Admin.js.map +1 -0
  4. package/dist/cjs/App.js +23 -11
  5. package/dist/cjs/App.js.map +1 -0
  6. package/dist/cjs/api.js +125 -65
  7. package/dist/cjs/api.js.map +1 -0
  8. package/dist/cjs/components/Branding.js +10 -8
  9. package/dist/cjs/components/Branding.js.map +1 -0
  10. package/dist/cjs/components/Hamburger.js +23 -11
  11. package/dist/cjs/components/Hamburger.js.map +1 -0
  12. package/dist/cjs/components/Link.js +9 -7
  13. package/dist/cjs/components/Link.js.map +1 -0
  14. package/dist/cjs/components/Logo.js +5 -3
  15. package/dist/cjs/components/Logo.js.map +1 -0
  16. package/dist/cjs/components/NavBar.js +48 -31
  17. package/dist/cjs/components/NavBar.js.map +1 -0
  18. package/dist/cjs/components/NavBarItem.js +16 -14
  19. package/dist/cjs/components/NavBarItem.js.map +1 -0
  20. package/dist/cjs/components/NavBarRoutes.js +23 -18
  21. package/dist/cjs/components/NavBarRoutes.js.map +1 -0
  22. package/dist/cjs/components/ProgressBar.js +5 -3
  23. package/dist/cjs/components/ProgressBar.js.map +1 -0
  24. package/dist/cjs/components/TitleBar.js +18 -17
  25. package/dist/cjs/components/TitleBar.js.map +1 -0
  26. package/dist/cjs/components/User.js +34 -21
  27. package/dist/cjs/components/User.js.map +1 -0
  28. package/dist/cjs/containers/Content.js +8 -6
  29. package/dist/cjs/containers/Content.js.map +1 -0
  30. package/dist/cjs/containers/ErrorScreen.js +21 -19
  31. package/dist/cjs/containers/ErrorScreen.js.map +1 -0
  32. package/dist/cjs/containers/LoadingScreen.js +64 -49
  33. package/dist/cjs/containers/LoadingScreen.js.map +1 -0
  34. package/dist/cjs/containers/PageErrorBoundary.js +33 -14
  35. package/dist/cjs/containers/PageErrorBoundary.js.map +1 -0
  36. package/dist/cjs/containers/PageLoader.js +129 -40
  37. package/dist/cjs/containers/PageLoader.js.map +1 -0
  38. package/dist/cjs/contexts/ApiContext.js +53 -16
  39. package/dist/cjs/contexts/ApiContext.js.map +1 -0
  40. package/dist/cjs/contexts/I18nContext.js +58 -18
  41. package/dist/cjs/contexts/I18nContext.js.map +1 -0
  42. package/dist/cjs/contexts/RouterContext.js +52 -44
  43. package/dist/cjs/contexts/RouterContext.js.map +1 -0
  44. package/dist/cjs/contexts/UserContext.js +96 -43
  45. package/dist/cjs/contexts/UserContext.js.map +1 -0
  46. package/dist/cjs/extensions/bananas/components/PasswordChangeForm.js +45 -32
  47. package/dist/cjs/extensions/bananas/components/PasswordChangeForm.js.map +1 -0
  48. package/dist/cjs/extensions/bananas/index.js +3 -2
  49. package/dist/cjs/extensions/bananas/index.js.map +1 -0
  50. package/dist/cjs/extensions/bananas/pages/me/list.js +10 -9
  51. package/dist/cjs/extensions/bananas/pages/me/list.js.map +1 -0
  52. package/dist/cjs/extensions/fulfillment/components/AddressInfo.js +8 -6
  53. package/dist/cjs/extensions/fulfillment/components/AddressInfo.js.map +1 -0
  54. package/dist/cjs/extensions/fulfillment/components/ContactInfo.js +9 -7
  55. package/dist/cjs/extensions/fulfillment/components/ContactInfo.js.map +1 -0
  56. package/dist/cjs/extensions/fulfillment/components/RecipientCard.js +14 -12
  57. package/dist/cjs/extensions/fulfillment/components/RecipientCard.js.map +1 -0
  58. package/dist/cjs/extensions/fulfillment/components/ShipmentAccordion.js +124 -65
  59. package/dist/cjs/extensions/fulfillment/components/ShipmentAccordion.js.map +1 -0
  60. package/dist/cjs/extensions/fulfillment/components/ShipmentCard.js +19 -17
  61. package/dist/cjs/extensions/fulfillment/components/ShipmentCard.js.map +1 -0
  62. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationButtons.js +32 -19
  63. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationButtons.js.map +1 -0
  64. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationIcon.js +23 -11
  65. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationIcon.js.map +1 -0
  66. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsCard.js +73 -46
  67. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsCard.js.map +1 -0
  68. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsTable.js +49 -27
  69. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsTable.js.map +1 -0
  70. package/dist/cjs/extensions/fulfillment/components/ShipmentRow.js +12 -10
  71. package/dist/cjs/extensions/fulfillment/components/ShipmentRow.js.map +1 -0
  72. package/dist/cjs/extensions/fulfillment/components/order/OrderAccordion.js +212 -0
  73. package/dist/cjs/extensions/fulfillment/components/order/OrderAccordion.js.map +1 -0
  74. package/dist/cjs/extensions/fulfillment/components/order/OrderItemsTable.js +96 -0
  75. package/dist/cjs/extensions/fulfillment/components/order/OrderItemsTable.js.map +1 -0
  76. package/dist/cjs/extensions/fulfillment/components/order/OrderStateChip.js +98 -0
  77. package/dist/cjs/extensions/fulfillment/components/order/OrderStateChip.js.map +1 -0
  78. package/dist/cjs/extensions/fulfillment/index.js +59 -12
  79. package/dist/cjs/extensions/fulfillment/index.js.map +1 -0
  80. package/dist/cjs/extensions/fulfillment/pages/order/list.js +50 -36
  81. package/dist/cjs/extensions/fulfillment/pages/order/list.js.map +1 -0
  82. package/dist/cjs/extensions/fulfillment/pages/recipient/detail.js +7 -5
  83. package/dist/cjs/extensions/fulfillment/pages/recipient/detail.js.map +1 -0
  84. package/dist/cjs/extensions/fulfillment/pages/shipment/detail.js +57 -42
  85. package/dist/cjs/extensions/fulfillment/pages/shipment/detail.js.map +1 -0
  86. package/dist/cjs/extensions/fulfillment/pages/shipment/list.js +35 -31
  87. package/dist/cjs/extensions/fulfillment/pages/shipment/list.js.map +1 -0
  88. package/dist/cjs/extensions/fulfillment/types/order.js +3 -0
  89. package/dist/cjs/extensions/fulfillment/types/order.js.map +1 -0
  90. package/dist/cjs/extensions/fulfillment/types/recipient.js +1 -0
  91. package/dist/cjs/extensions/fulfillment/types/recipient.js.map +1 -0
  92. package/dist/cjs/extensions/fulfillment/types/shipment.js +1 -0
  93. package/dist/cjs/extensions/fulfillment/types/shipment.js.map +1 -0
  94. package/dist/cjs/extensions/fulfillment/types/util.js +1 -0
  95. package/dist/cjs/extensions/fulfillment/types/util.js.map +1 -0
  96. package/dist/cjs/extensions/pos/components/PurchaseRow.js +13 -11
  97. package/dist/cjs/extensions/pos/components/PurchaseRow.js.map +1 -0
  98. package/dist/cjs/extensions/pos/components/ReceiptCard.js +45 -43
  99. package/dist/cjs/extensions/pos/components/ReceiptCard.js.map +1 -0
  100. package/dist/cjs/extensions/pos/components/ReceiptLine.js +17 -12
  101. package/dist/cjs/extensions/pos/components/ReceiptLine.js.map +1 -0
  102. package/dist/cjs/extensions/pos/components/ReceiptTable.js +137 -41
  103. package/dist/cjs/extensions/pos/components/ReceiptTable.js.map +1 -0
  104. package/dist/cjs/extensions/pos/components/SearchBar.js +40 -25
  105. package/dist/cjs/extensions/pos/components/SearchBar.js.map +1 -0
  106. package/dist/cjs/extensions/pos/index.js +57 -12
  107. package/dist/cjs/extensions/pos/index.js.map +1 -0
  108. package/dist/cjs/extensions/pos/pages/purchase/detail.js +28 -20
  109. package/dist/cjs/extensions/pos/pages/purchase/detail.js.map +1 -0
  110. package/dist/cjs/extensions/pos/pages/purchase/list.js +39 -32
  111. package/dist/cjs/extensions/pos/pages/purchase/list.js.map +1 -0
  112. package/dist/cjs/extensions/pos/types/purchase.js +1 -0
  113. package/dist/cjs/extensions/pos/types/purchase.js.map +1 -0
  114. package/dist/cjs/extensions/pos/types/receipt.js +8 -0
  115. package/dist/cjs/extensions/pos/types/receipt.js.map +1 -0
  116. package/dist/cjs/forms/LoginForm.js +31 -30
  117. package/dist/cjs/forms/LoginForm.js.map +1 -0
  118. package/dist/cjs/hooks/useAsyncError.js +5 -4
  119. package/dist/cjs/hooks/useAsyncError.js.map +1 -0
  120. package/dist/cjs/hooks/useLocalStorage.js +8 -7
  121. package/dist/cjs/hooks/useLocalStorage.js.map +1 -0
  122. package/dist/cjs/index.js +1 -0
  123. package/dist/cjs/index.js.map +1 -0
  124. package/dist/cjs/pages/DashboardPage.js +4 -3
  125. package/dist/cjs/pages/DashboardPage.js.map +1 -0
  126. package/dist/cjs/pages/LoginPage.js +12 -10
  127. package/dist/cjs/pages/LoginPage.js.map +1 -0
  128. package/dist/cjs/router/Router.js +25 -19
  129. package/dist/cjs/router/Router.js.map +1 -0
  130. package/dist/cjs/router/routes.js +8 -7
  131. package/dist/cjs/router/routes.js.map +1 -0
  132. package/dist/cjs/types/index.js +1 -0
  133. package/dist/cjs/types/index.js.map +1 -0
  134. package/dist/cjs/util/format_purchase_number.js +2 -1
  135. package/dist/cjs/util/format_purchase_number.js.map +1 -0
  136. package/dist/cjs/util/get_cookie.js +4 -3
  137. package/dist/cjs/util/get_cookie.js.map +1 -0
  138. package/dist/cjs/util/index.js +10 -7
  139. package/dist/cjs/util/index.js.map +1 -0
  140. package/dist/cjs/util/is_email.js +1 -0
  141. package/dist/cjs/util/is_email.js.map +1 -0
  142. package/dist/cjs/util/is_positive_integer.js +2 -1
  143. package/dist/cjs/util/is_positive_integer.js.map +1 -0
  144. package/dist/cjs/util/select_styles.js +24 -7
  145. package/dist/cjs/util/select_styles.js.map +1 -0
  146. package/dist/esm/Admin.js +17 -16
  147. package/dist/esm/Admin.js.map +1 -0
  148. package/dist/esm/App.js +15 -3
  149. package/dist/esm/App.js.map +1 -0
  150. package/dist/esm/api.js +125 -63
  151. package/dist/esm/api.js.map +1 -0
  152. package/dist/esm/components/Branding.js +4 -2
  153. package/dist/esm/components/Branding.js.map +1 -0
  154. package/dist/esm/components/Hamburger.js +17 -5
  155. package/dist/esm/components/Hamburger.js.map +1 -0
  156. package/dist/esm/components/Link.js +6 -4
  157. package/dist/esm/components/Link.js.map +1 -0
  158. package/dist/esm/components/Logo.js +4 -2
  159. package/dist/esm/components/Logo.js.map +1 -0
  160. package/dist/esm/components/NavBar.js +38 -21
  161. package/dist/esm/components/NavBar.js.map +1 -0
  162. package/dist/esm/components/NavBarItem.js +8 -6
  163. package/dist/esm/components/NavBarItem.js.map +1 -0
  164. package/dist/esm/components/NavBarRoutes.js +19 -14
  165. package/dist/esm/components/NavBarRoutes.js.map +1 -0
  166. package/dist/esm/components/ProgressBar.js +3 -1
  167. package/dist/esm/components/ProgressBar.js.map +1 -0
  168. package/dist/esm/components/TitleBar.js +9 -8
  169. package/dist/esm/components/TitleBar.js.map +1 -0
  170. package/dist/esm/components/User.js +24 -11
  171. package/dist/esm/components/User.js.map +1 -0
  172. package/dist/esm/containers/Content.js +5 -3
  173. package/dist/esm/containers/Content.js.map +1 -0
  174. package/dist/esm/containers/ErrorScreen.js +10 -8
  175. package/dist/esm/containers/ErrorScreen.js.map +1 -0
  176. package/dist/esm/containers/LoadingScreen.js +56 -41
  177. package/dist/esm/containers/LoadingScreen.js.map +1 -0
  178. package/dist/esm/containers/PageErrorBoundary.js +33 -13
  179. package/dist/esm/containers/PageErrorBoundary.js.map +1 -0
  180. package/dist/esm/containers/PageLoader.js +124 -34
  181. package/dist/esm/containers/PageLoader.js.map +1 -0
  182. package/dist/esm/contexts/ApiContext.js +49 -12
  183. package/dist/esm/contexts/ApiContext.js.map +1 -0
  184. package/dist/esm/contexts/I18nContext.js +55 -15
  185. package/dist/esm/contexts/I18nContext.js.map +1 -0
  186. package/dist/esm/contexts/RouterContext.js +47 -39
  187. package/dist/esm/contexts/RouterContext.js.map +1 -0
  188. package/dist/esm/contexts/UserContext.js +93 -40
  189. package/dist/esm/contexts/UserContext.js.map +1 -0
  190. package/dist/esm/extensions/bananas/components/PasswordChangeForm.js +32 -19
  191. package/dist/esm/extensions/bananas/components/PasswordChangeForm.js.map +1 -0
  192. package/dist/esm/extensions/bananas/index.js +3 -2
  193. package/dist/esm/extensions/bananas/index.js.map +1 -0
  194. package/dist/esm/extensions/bananas/pages/me/list.js +3 -2
  195. package/dist/esm/extensions/bananas/pages/me/list.js.map +1 -0
  196. package/dist/esm/extensions/fulfillment/components/AddressInfo.js +5 -3
  197. package/dist/esm/extensions/fulfillment/components/AddressInfo.js.map +1 -0
  198. package/dist/esm/extensions/fulfillment/components/ContactInfo.js +5 -3
  199. package/dist/esm/extensions/fulfillment/components/ContactInfo.js.map +1 -0
  200. package/dist/esm/extensions/fulfillment/components/RecipientCard.js +6 -4
  201. package/dist/esm/extensions/fulfillment/components/RecipientCard.js.map +1 -0
  202. package/dist/esm/extensions/fulfillment/components/ShipmentAccordion.js +109 -50
  203. package/dist/esm/extensions/fulfillment/components/ShipmentAccordion.js.map +1 -0
  204. package/dist/esm/extensions/fulfillment/components/ShipmentCard.js +8 -6
  205. package/dist/esm/extensions/fulfillment/components/ShipmentCard.js.map +1 -0
  206. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationButtons.js +27 -14
  207. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationButtons.js.map +1 -0
  208. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationIcon.js +18 -6
  209. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationIcon.js.map +1 -0
  210. package/dist/esm/extensions/fulfillment/components/ShipmentItemsCard.js +54 -27
  211. package/dist/esm/extensions/fulfillment/components/ShipmentItemsCard.js.map +1 -0
  212. package/dist/esm/extensions/fulfillment/components/ShipmentItemsTable.js +40 -18
  213. package/dist/esm/extensions/fulfillment/components/ShipmentItemsTable.js.map +1 -0
  214. package/dist/esm/extensions/fulfillment/components/ShipmentRow.js +8 -6
  215. package/dist/esm/extensions/fulfillment/components/ShipmentRow.js.map +1 -0
  216. package/dist/esm/extensions/fulfillment/components/order/OrderAccordion.js +207 -0
  217. package/dist/esm/extensions/fulfillment/components/order/OrderAccordion.js.map +1 -0
  218. package/dist/esm/extensions/fulfillment/components/order/OrderItemsTable.js +91 -0
  219. package/dist/esm/extensions/fulfillment/components/order/OrderItemsTable.js.map +1 -0
  220. package/dist/esm/extensions/fulfillment/components/order/OrderStateChip.js +70 -0
  221. package/dist/esm/extensions/fulfillment/components/order/OrderStateChip.js.map +1 -0
  222. package/dist/esm/extensions/fulfillment/index.js +61 -14
  223. package/dist/esm/extensions/fulfillment/index.js.map +1 -0
  224. package/dist/esm/extensions/fulfillment/pages/order/list.js +40 -26
  225. package/dist/esm/extensions/fulfillment/pages/order/list.js.map +1 -0
  226. package/dist/esm/extensions/fulfillment/pages/recipient/detail.js +4 -2
  227. package/dist/esm/extensions/fulfillment/pages/recipient/detail.js.map +1 -0
  228. package/dist/esm/extensions/fulfillment/pages/shipment/detail.js +38 -23
  229. package/dist/esm/extensions/fulfillment/pages/shipment/detail.js.map +1 -0
  230. package/dist/esm/extensions/fulfillment/pages/shipment/list.js +24 -20
  231. package/dist/esm/extensions/fulfillment/pages/shipment/list.js.map +1 -0
  232. package/dist/esm/extensions/fulfillment/types/order.js +2 -0
  233. package/dist/esm/extensions/fulfillment/types/order.js.map +1 -0
  234. package/dist/esm/extensions/fulfillment/types/recipient.js +1 -0
  235. package/dist/esm/extensions/fulfillment/types/recipient.js.map +1 -0
  236. package/dist/esm/extensions/fulfillment/types/shipment.js +1 -0
  237. package/dist/esm/extensions/fulfillment/types/shipment.js.map +1 -0
  238. package/dist/esm/extensions/fulfillment/types/util.js +1 -0
  239. package/dist/esm/extensions/fulfillment/types/util.js.map +1 -0
  240. package/dist/esm/extensions/pos/components/PurchaseRow.js +8 -6
  241. package/dist/esm/extensions/pos/components/PurchaseRow.js.map +1 -0
  242. package/dist/esm/extensions/pos/components/ReceiptCard.js +28 -26
  243. package/dist/esm/extensions/pos/components/ReceiptCard.js.map +1 -0
  244. package/dist/esm/extensions/pos/components/ReceiptLine.js +11 -6
  245. package/dist/esm/extensions/pos/components/ReceiptLine.js.map +1 -0
  246. package/dist/esm/extensions/pos/components/ReceiptTable.js +128 -32
  247. package/dist/esm/extensions/pos/components/ReceiptTable.js.map +1 -0
  248. package/dist/esm/extensions/pos/components/SearchBar.js +28 -13
  249. package/dist/esm/extensions/pos/components/SearchBar.js.map +1 -0
  250. package/dist/esm/extensions/pos/index.js +58 -13
  251. package/dist/esm/extensions/pos/index.js.map +1 -0
  252. package/dist/esm/extensions/pos/pages/purchase/detail.js +20 -12
  253. package/dist/esm/extensions/pos/pages/purchase/detail.js.map +1 -0
  254. package/dist/esm/extensions/pos/pages/purchase/list.js +23 -16
  255. package/dist/esm/extensions/pos/pages/purchase/list.js.map +1 -0
  256. package/dist/esm/extensions/pos/types/purchase.js +1 -0
  257. package/dist/esm/extensions/pos/types/purchase.js.map +1 -0
  258. package/dist/esm/extensions/pos/types/receipt.js +7 -1
  259. package/dist/esm/extensions/pos/types/receipt.js.map +1 -0
  260. package/dist/esm/forms/LoginForm.js +19 -18
  261. package/dist/esm/forms/LoginForm.js.map +1 -0
  262. package/dist/esm/hooks/useAsyncError.js +4 -3
  263. package/dist/esm/hooks/useAsyncError.js.map +1 -0
  264. package/dist/esm/hooks/useLocalStorage.js +7 -6
  265. package/dist/esm/hooks/useLocalStorage.js.map +1 -0
  266. package/dist/esm/index.js +1 -0
  267. package/dist/esm/index.js.map +1 -0
  268. package/dist/esm/pages/DashboardPage.js +3 -2
  269. package/dist/esm/pages/DashboardPage.js.map +1 -0
  270. package/dist/esm/pages/LoginPage.js +5 -3
  271. package/dist/esm/pages/LoginPage.js.map +1 -0
  272. package/dist/esm/router/Router.js +17 -11
  273. package/dist/esm/router/Router.js.map +1 -0
  274. package/dist/esm/router/routes.js +7 -6
  275. package/dist/esm/router/routes.js.map +1 -0
  276. package/dist/esm/types/index.js +1 -0
  277. package/dist/esm/types/index.js.map +1 -0
  278. package/dist/esm/util/format_purchase_number.js +2 -1
  279. package/dist/esm/util/format_purchase_number.js.map +1 -0
  280. package/dist/esm/util/get_cookie.js +4 -3
  281. package/dist/esm/util/get_cookie.js.map +1 -0
  282. package/dist/esm/util/index.js +10 -7
  283. package/dist/esm/util/index.js.map +1 -0
  284. package/dist/esm/util/is_email.js +1 -0
  285. package/dist/esm/util/is_email.js.map +1 -0
  286. package/dist/esm/util/is_positive_integer.js +2 -1
  287. package/dist/esm/util/is_positive_integer.js.map +1 -0
  288. package/dist/esm/util/select_styles.js +25 -8
  289. package/dist/esm/util/select_styles.js.map +1 -0
  290. package/dist/types/Admin.d.ts +1 -1
  291. package/dist/types/App.d.ts +1 -1
  292. package/dist/types/components/Hamburger.d.ts +1 -1
  293. package/dist/types/components/Link.d.ts +1 -1
  294. package/dist/types/components/User.d.ts +4 -7
  295. package/dist/types/containers/PageErrorBoundary.d.ts +1 -1
  296. package/dist/types/containers/PageLoader.d.ts +1 -0
  297. package/dist/types/contexts/RouterContext.d.ts +2 -2
  298. package/dist/types/extensions/fulfillment/components/ShipmentDestinationIcon.d.ts +1 -1
  299. package/dist/types/extensions/fulfillment/components/order/OrderAccordion.d.ts +7 -0
  300. package/dist/types/extensions/fulfillment/components/order/OrderItemsTable.d.ts +9 -0
  301. package/dist/types/extensions/fulfillment/components/order/OrderStateChip.d.ts +10 -0
  302. package/dist/types/extensions/fulfillment/pages/order/list.d.ts +2 -2
  303. package/dist/types/extensions/fulfillment/types/order.d.ts +38 -0
  304. package/dist/types/extensions/fulfillment/types/shipment.d.ts +1 -1
  305. package/dist/types/extensions/pos/components/PurchaseRow.d.ts +2 -2
  306. package/dist/types/extensions/pos/components/ReceiptCard.d.ts +3 -3
  307. package/dist/types/extensions/pos/components/ReceiptLine.d.ts +1 -0
  308. package/dist/types/extensions/pos/components/ReceiptTable.d.ts +4 -3
  309. package/dist/types/extensions/pos/components/SearchBar.d.ts +1 -1
  310. package/dist/types/extensions/pos/pages/purchase/list.d.ts +2 -2
  311. package/dist/types/extensions/pos/types/purchase.d.ts +27 -6
  312. package/dist/types/extensions/pos/types/receipt.d.ts +7 -9
  313. package/dist/types/router/Router.d.ts +2 -1
  314. package/dist/types/types/index.d.ts +7 -4
  315. package/example/index.tsx +28 -9
  316. package/example/package.json +18 -8
  317. package/example/scripts/build.js +4 -0
  318. package/example/scripts/options.js +81 -0
  319. package/{example/pages/.gitkeep → nodemon.json} +0 -0
  320. package/package.json +8 -4
  321. package/src/Admin.tsx +36 -36
  322. package/src/App.tsx +8 -4
  323. package/src/components/TitleBar.tsx +23 -18
  324. package/src/containers/Content.tsx +1 -1
  325. package/src/containers/PageLoader.tsx +32 -14
  326. package/src/contexts/UserContext.tsx +15 -14
  327. package/src/extensions/fulfillment/components/ShipmentAccordion.tsx +126 -116
  328. package/src/extensions/fulfillment/components/ShipmentCard.tsx +3 -9
  329. package/src/extensions/fulfillment/components/ShipmentItemsCard.tsx +42 -45
  330. package/src/extensions/fulfillment/components/order/OrderAccordion.tsx +213 -0
  331. package/src/extensions/fulfillment/components/order/OrderItemsTable.tsx +128 -0
  332. package/src/extensions/fulfillment/components/order/OrderStateChip.tsx +79 -0
  333. package/src/extensions/fulfillment/index.tsx +27 -9
  334. package/src/extensions/fulfillment/pages/order/list.tsx +43 -54
  335. package/src/extensions/fulfillment/pages/shipment/detail.tsx +47 -55
  336. package/src/extensions/fulfillment/types/order.ts +53 -0
  337. package/src/extensions/pos/components/PurchaseRow.tsx +3 -5
  338. package/src/extensions/pos/components/ReceiptCard.tsx +50 -47
  339. package/src/extensions/pos/components/ReceiptLine.tsx +6 -5
  340. package/src/extensions/pos/components/ReceiptTable.tsx +183 -78
  341. package/src/extensions/pos/index.tsx +3 -3
  342. package/src/extensions/pos/pages/purchase/detail.tsx +29 -34
  343. package/src/extensions/pos/pages/purchase/list.tsx +14 -20
  344. package/src/extensions/pos/types/purchase.ts +28 -6
  345. package/src/extensions/pos/types/receipt.ts +8 -9
  346. package/src/pages/DashboardPage.tsx +1 -1
  347. package/src/router/Router.tsx +14 -15
  348. package/src/types/index.ts +4 -1
  349. package/tsconfig.json +5 -13
  350. package/example/Dockerfile +0 -27
  351. package/example/README.md +0 -6
  352. package/example/build.js +0 -19
  353. package/example/docker-compose.yml +0 -7
  354. package/example/package-lock.json +0 -1762
  355. package/example/public/index.html +0 -14
@@ -0,0 +1,38 @@
1
+ export type OrderDestinationType = "HOME" | "STORE" | "SERVICE_POINT" | "LOCKER";
2
+ export type OrderStateType = "PENDING" | "CONFIRMED" | "SENT" | "IN_TRANSIT" | "READY_FOR_PICKUP" | "DELIVERED" | "CANCELLED";
3
+ export interface OrderListItem {
4
+ shipment_reference: string;
5
+ purchase_number: number;
6
+ email: string;
7
+ phone?: string;
8
+ option_name: string;
9
+ carrier: string;
10
+ destination_type: OrderDestinationType;
11
+ name: string;
12
+ tracking_number: string;
13
+ state: OrderStateType;
14
+ }
15
+ export interface OrderDetail {
16
+ option_name: string;
17
+ destination_type: OrderDestinationType;
18
+ state: OrderStateType;
19
+ destination_reference?: string;
20
+ name: string;
21
+ care_of: string;
22
+ street_address: string;
23
+ street_address2: string;
24
+ postal_code: string;
25
+ city: string;
26
+ country_code: string;
27
+ region: string;
28
+ items: OrderItem[];
29
+ shipment: {
30
+ carrier: string;
31
+ tracking_number: string;
32
+ } | null;
33
+ }
34
+ export interface OrderItem {
35
+ code: string;
36
+ name: string | null;
37
+ quantity: number;
38
+ }
@@ -1,4 +1,4 @@
1
- export declare type ShipmentDestinationType = "HOME" | "STORE" | "SERVICE_POINT" | "LOCKER";
1
+ export type ShipmentDestinationType = "HOME" | "STORE" | "SERVICE_POINT" | "LOCKER";
2
2
  export interface ShipmentListItem {
3
3
  shipment_reference: string;
4
4
  purchase_number: number;
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
- import { Purchase } from "../types/purchase";
2
+ import { PurchaseDetail } from "../types/purchase";
3
3
  interface PurchaseRowProps {
4
- purchase: Purchase;
4
+ purchase: PurchaseDetail;
5
5
  }
6
6
  export declare const PurchaseRow: React.FC<PurchaseRowProps>;
7
7
  export {};
@@ -1,8 +1,8 @@
1
1
  import React from "react";
2
- import { Receipt, ReceiptLine } from "../types/receipt";
2
+ import { Line, PurchaseDetail } from "../types/purchase";
3
3
  interface ReceiptCardProps {
4
- receipt: Receipt;
5
- refund?: (lines: ReceiptLine[]) => void;
4
+ purchase: PurchaseDetail;
5
+ refund?: (lines: Line[]) => void;
6
6
  }
7
7
  export declare const ReceiptCard: React.FC<ReceiptCardProps>;
8
8
  export {};
@@ -1,6 +1,7 @@
1
1
  import React from "react";
2
2
  import { ReceiptLine as ReceiptLineType } from "../types/receipt";
3
3
  interface ReceiptLineProps {
4
+ currency: string;
4
5
  line: ReceiptLineType;
5
6
  editable?: boolean;
6
7
  onSelect?: (selected: boolean) => void;
@@ -1,8 +1,9 @@
1
1
  import React from "react";
2
- import { ReceiptLine } from "../types/receipt";
2
+ import { Line } from "../types/purchase";
3
3
  export interface ReceiptTableProps {
4
- lines: ReceiptLine[];
4
+ currency: string;
5
+ lines: Line[];
5
6
  editable?: boolean;
6
- onSelect?: (selected: ReceiptLine[]) => void;
7
+ onSelect?: (selected: Line[]) => void;
7
8
  }
8
9
  export declare const ReceiptTable: React.FC<ReceiptTableProps>;
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- export declare type SearchInput = {
2
+ export type SearchInput = {
3
3
  email: string;
4
4
  } | {
5
5
  phone: string;
@@ -1,6 +1,6 @@
1
- import { Purchase } from "../../types/purchase";
2
1
  import { PageComponent } from "../../../../types";
2
+ import { PurchaseDetail } from "../../types/purchase";
3
3
  declare const PurchaseListPage: PageComponent<{
4
- results: Purchase[];
4
+ results: PurchaseDetail[];
5
5
  }>;
6
6
  export default PurchaseListPage;
@@ -1,18 +1,39 @@
1
1
  import { Receipt } from "./receipt";
2
- export interface Purchase {
3
- number: string;
2
+ export interface PurchaseDetail {
3
+ number: number;
4
4
  checkout_session?: string;
5
5
  main_payment_identifier?: string;
6
6
  date_initiated: string;
7
7
  date_confirmed: string;
8
- currency?: string;
8
+ currency: string;
9
9
  site_code: string;
10
10
  locale: string;
11
11
  country_code: string;
12
12
  email: string;
13
13
  phone?: string;
14
- }
15
- export interface PurchaseDetail {
16
- purchase: Purchase;
14
+ total_debit_amount: string;
15
+ total_remaining_amount: string;
16
+ total_discount_amount: string;
17
+ total_tax_amount: string;
17
18
  receipts: Receipt[];
19
+ lines: Line[];
20
+ }
21
+ export interface Line {
22
+ line_number: number;
23
+ item_type: string;
24
+ title: string;
25
+ reference: string;
26
+ quantity: number;
27
+ unit_price: string;
28
+ total_amount: string;
29
+ debit_amount: string;
30
+ remaining_amount: string;
31
+ adjustments: Adjustment[];
32
+ }
33
+ export interface Adjustment {
34
+ adjustment_type: "CANCELLATION" | "RETURN" | "REFUND" | "DISCOUNT";
35
+ title: string;
36
+ receipt_number: number | null;
37
+ quantity: number;
38
+ total_amount: string;
18
39
  }
@@ -1,17 +1,15 @@
1
+ export declare enum ReceiptIntention {
2
+ Payment = 1,
3
+ Cancellation = 2,
4
+ Refund = 3
5
+ }
1
6
  export interface Receipt {
2
- number: string;
7
+ number: number | null;
3
8
  total_amount: string;
4
9
  total_discount_amount: string;
5
10
  total_tax_amount: string;
6
11
  date_settled?: string;
7
- /**
8
- * | | Intention |
9
- * | - | ------------ |
10
- * | 1 | payment |
11
- * | 2 | cancellation |
12
- * | 3 | refund |
13
- */
14
- intention: 1 | 2 | 3;
12
+ intention: ReceiptIntention;
15
13
  lines: ReceiptLine[];
16
14
  }
17
15
  export interface ReceiptLine {
@@ -2,9 +2,10 @@ import React from "react";
2
2
  import { RouteInfo } from "../contexts/RouterContext";
3
3
  import { PageComponent } from "../types";
4
4
  import { OpenAPI } from "openapi-types";
5
- export declare type RouterExtensionPageHit = PageComponent | Promise<PageComponent> | {
5
+ export type RouterExtensionPageHit = PageComponent | Promise<PageComponent> | {
6
6
  page: PageComponent | Promise<PageComponent>;
7
7
  request?: OpenAPI.Request;
8
+ defaultRequest?: OpenAPI.Request;
8
9
  };
9
10
  export interface RouterExtension {
10
11
  app: string;
@@ -1,11 +1,14 @@
1
1
  /// <reference types="react" />
2
2
  declare module "swagger-client";
3
- export declare type LogoType = boolean | string | React.ElementType;
4
- export declare type PageProps<T = unknown> = {
3
+ export type LogoType = boolean | string | React.ElementType;
4
+ export type PageProps<T = unknown> = {
5
5
  data: T;
6
6
  };
7
- export declare type PageComponent<T = unknown> = React.ComponentType<PageProps<T>>;
8
- export declare type NavOverrides = Record<string, {
7
+ export type PageComponent<T = unknown> = React.ComponentType<PageProps<T>> & {
8
+ requiredQuery?: URLSearchParams;
9
+ defaultQuery?: URLSearchParams;
10
+ };
11
+ export type NavOverrides = Record<string, {
9
12
  icon?: LogoType;
10
13
  title?: string;
11
14
  } | null | undefined | false>;
package/example/index.tsx CHANGED
@@ -1,20 +1,39 @@
1
- import React from "react";
2
- import ReactDOM from "react-dom";
3
1
  import * as Bananas from "bananas-commerce-admin";
2
+ import React from "react";
3
+ import ReactDOM from "react-dom/client";
4
4
 
5
- ReactDOM.render(
5
+ import { createTheme } from "@mui/material/styles";
6
+
7
+ ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
6
8
  <React.StrictMode>
7
9
  <Bananas.App
10
+ basename={process.env.BASE_URL}
8
11
  api={{
9
- schema: "http://localhost:8123/_/admin/api/v1/openapi.json",
10
- server: "http://localhost:8123/_/admin/api/v1/",
12
+ schema: "/_/admin/api/v1/openapi.json",
13
+ server: new URL("/_/admin/api/v1/", location.origin),
14
+ }}
15
+ nav={{
16
+ ...Bananas.pos.navigation,
17
+ ...Bananas.fulfillment.navigation,
11
18
  }}
12
- nav={{}}
13
- extensions={[Bananas.bananasRouterExtension, Bananas.posRouterExtension]}
19
+ extensions={[
20
+ Bananas.bananas.router,
21
+ Bananas.pos.router,
22
+ Bananas.fulfillment.router,
23
+ ]}
14
24
  pages={async (route) => {
15
25
  return (await import(`./pages/${route.page}`)).default;
16
26
  }}
27
+ theme={createTheme({
28
+ palette: {
29
+ primary: {
30
+ main: "#7b61ff",
31
+ },
32
+ secondary: {
33
+ main: "#00bcd4",
34
+ },
35
+ },
36
+ })}
17
37
  />
18
- </React.StrictMode>,
19
- document.getElementById("root") as HTMLElement,
38
+ </React.StrictMode>
20
39
  );
@@ -1,9 +1,8 @@
1
1
  {
2
- "name": "bananas-commerce-admin-example",
2
+ "name": "bananas-commerce-example-admin",
3
3
  "version": "0.1.0",
4
4
  "private": true,
5
- "description": "Bananas-commerce admin interface and building blocks",
6
- "type": "module",
5
+ "description": "Bananas Commerce Admin Example App",
7
6
  "keywords": [
8
7
  "admin",
9
8
  "bananas",
@@ -13,27 +12,38 @@
13
12
  "bananas-commerce",
14
13
  "bananas-commerce-admin"
15
14
  ],
15
+ "type": "module",
16
16
  "author": "Elias Sjögreen",
17
17
  "scripts": {
18
- "build": "node build.js"
18
+ "build": "node ./scripts/build.js",
19
+ "build:watch": "node ./scripts/build.js --watch",
20
+ "serve": "live-server --port=3000 --no-browser --proxy=/_/:http://localhost:8000/_/ --mount=/:./public/ ./public/index.html",
21
+ "serve:watch": "npm run build:watch & npm run serve"
19
22
  },
20
23
  "devDependencies": {
21
24
  "@esbuild-plugins/node-globals-polyfill": "^0.1.1",
22
25
  "@esbuild-plugins/node-modules-polyfill": "^0.1.4",
23
- "@types/lodash": "^4.14.182",
26
+ "@node-rs/xxhash": "^1.2.1",
24
27
  "@types/node": "^16.11.43",
25
28
  "@types/react": "^17.0.0",
26
29
  "@types/react-dom": "^17.0.0",
27
- "esbuild": "^0.15.14",
30
+ "esbuild": "^0.15.18",
31
+ "esbuild-plugin-svgr": "^1.0.1",
32
+ "live-server": "^1.2.2",
28
33
  "typescript": "^4.7.4"
29
34
  },
30
35
  "dependencies": {
36
+ "@apidevtools/swagger-parser": "^10.1.0",
37
+ "@emotion/react": "^11.10.5",
38
+ "@emotion/styled": "^11.10.5",
31
39
  "@mui/icons-material": "^5.8.4",
32
40
  "@mui/lab": "^5.0.0-alpha.89",
33
41
  "@mui/material": "^5.8.7",
34
42
  "@mui/system": "^5.8.7",
35
43
  "bananas-commerce-admin": "file:..",
36
- "react": "^17.0.0",
37
- "react-dom": "^17.0.0"
44
+ "notistack": "^2.0.8",
45
+ "react": "file:../node_modules/react",
46
+ "react-dom": "^18.2.0",
47
+ "react-router-dom": "^6.4.5"
38
48
  }
39
49
  }
@@ -0,0 +1,4 @@
1
+ import { build } from "esbuild";
2
+ import { options } from "./options.js";
3
+
4
+ await build(options);
@@ -0,0 +1,81 @@
1
+ import { NodeModulesPolyfillPlugin } from "@esbuild-plugins/node-modules-polyfill";
2
+ import { NodeGlobalsPolyfillPlugin } from "@esbuild-plugins/node-globals-polyfill";
3
+ import svgrPlugin from "esbuild-plugin-svgr";
4
+ import path from "node:path";
5
+
6
+ const htmlTemplate = (entrypoint) =>
7
+ `<!DOCTYPE html>
8
+ <html lang="en">
9
+ <head>
10
+ <meta charset="utf-8" />
11
+ <meta name="viewport" content="initial-scale=1, width=device-width" />
12
+ <script type="module">
13
+ globalThis.process ??= {};
14
+ globalThis.process.env ??= {};
15
+ globalThis.process.env.SENTRY_DSN = \`<!--# echo var="SENTRY_DSN" -->\`;
16
+ globalThis.process.env.SENTRY_ENVIRONMENT = \`<!--# echo var="SENTRY_ENVIRONMENT" -->\`;
17
+ </script>
18
+ <script type="module" src="${path.join(
19
+ process.env.BASE_URL ?? "/",
20
+ entrypoint
21
+ )}"></script>
22
+ <title>Admin</title>
23
+ </head>
24
+ <body>
25
+ <noscript>You need to enable JavaScript to run this app.</noscript>
26
+ <div id="root"></div>
27
+ </body>
28
+ </html>
29
+ `;
30
+
31
+ export const options = {
32
+ entryPoints: ["./index.tsx"],
33
+ outdir: "./public/",
34
+ logLevel: "info",
35
+ chunkNames: "[name]-[hash]",
36
+ publicPath: process.env.BASE_URL ?? "/",
37
+ target: "es6",
38
+ format: "esm",
39
+ bundle: true,
40
+ splitting: true,
41
+ treeShaking: true,
42
+ sourcemap: true,
43
+ minify: true,
44
+ metafile: true,
45
+ define: {
46
+ "process.env.NODE_ENV": `"${process.env.NODE_ENV ?? "development"}"`,
47
+ "process.env.BASE_URL":
48
+ process.env.BASE_URL != undefined
49
+ ? `"${process.env.BASE_URL}"`
50
+ : "undefined",
51
+ },
52
+ plugins: [
53
+ svgrPlugin(),
54
+ NodeModulesPolyfillPlugin(),
55
+ NodeGlobalsPolyfillPlugin({
56
+ process: true,
57
+ buffer: true,
58
+ }),
59
+ {
60
+ name: "create-index-plugin",
61
+ async setup(build) {
62
+ const fs = await import("node:fs/promises");
63
+ const { xxh32 } = await import("@node-rs/xxhash");
64
+
65
+ build.onEnd(async (result) => {
66
+ const source = await fs.readFile("./public/index.js", {
67
+ encoding: "utf-8",
68
+ });
69
+ const filename = `index-${xxh32(source)
70
+ .toString(36)
71
+ .toUpperCase()}.js`;
72
+ await Promise.all([
73
+ fs.writeFile(`./public/${filename}`, source),
74
+ fs.writeFile("./public/index.html", htmlTemplate(filename)),
75
+ ]);
76
+ });
77
+ },
78
+ },
79
+ ],
80
+ watch: process.argv.includes("-w") || process.argv.includes("--watch"),
81
+ };
File without changes
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bananas-commerce-admin",
3
- "version": "0.2.2",
3
+ "version": "0.2.4",
4
4
  "description": "Bananas-commerce admin interface and building blocks",
5
5
  "keywords": [
6
6
  "admin",
@@ -23,6 +23,8 @@
23
23
  }
24
24
  },
25
25
  "scripts": {
26
+ "dev": "npm run build:esm:watch & npm run build:watch --prefix ./example & npm run serve --prefix ./example",
27
+ "dev:install": "npm i && npx npm-install-peers && npm i --prefix ./example",
26
28
  "build": "npm run build:esm && npm run build:cjs",
27
29
  "build:esm": "tsc",
28
30
  "build:esm:watch": "npm run build:esm -- --watch",
@@ -30,8 +32,8 @@
30
32
  "build:cjs:watch": "npm run build:cjs -- --watch"
31
33
  },
32
34
  "devDependencies": {
33
- "@types/react": "^17.0.0",
34
- "@types/react-dom": "^17.0.0",
35
+ "@types/react": "^18.0.26",
36
+ "@types/react-dom": "^18.0.9",
35
37
  "openapi-types": "^12.0.0",
36
38
  "typescript": "^4.7.4"
37
39
  },
@@ -43,8 +45,10 @@
43
45
  "@mui/lab": "^5.0.0-alpha.89",
44
46
  "@mui/material": "^5.8.7",
45
47
  "@mui/system": "^5.8.7",
48
+ "mui-chips-input": "^1.3.1",
46
49
  "notistack": "^2.0.5",
47
- "react": "^17.0.0",
50
+ "react": "^18.2.0",
51
+ "react-dom": "^18.2.0",
48
52
  "react-router-dom": "^6.3.0"
49
53
  },
50
54
  "dependencies": {
package/src/Admin.tsx CHANGED
@@ -22,18 +22,16 @@ export type AdminProps = {
22
22
  basename?: string;
23
23
  } & RouterProps;
24
24
 
25
- const Admin: React.FC<AdminProps> = (
26
- {
27
- logo,
28
- title,
29
- subtitle,
30
- version,
31
- nav,
32
- extensions,
33
- dashboard,
34
- basename,
35
- },
36
- ) => {
25
+ const Admin: React.FC<AdminProps> = ({
26
+ logo,
27
+ title,
28
+ subtitle,
29
+ version,
30
+ nav,
31
+ extensions,
32
+ dashboard,
33
+ basename,
34
+ }) => {
37
35
  const [loaded, setLoaded] = React.useState(false);
38
36
 
39
37
  const api = useApi();
@@ -42,7 +40,10 @@ const Admin: React.FC<AdminProps> = (
42
40
 
43
41
  React.useEffect(() => {
44
42
  if (
45
- !loaded && api !== undefined && i18n !== undefined && user !== undefined
43
+ !loaded &&
44
+ api !== undefined &&
45
+ i18n !== undefined &&
46
+ user !== undefined
46
47
  ) {
47
48
  setLoaded(true);
48
49
  }
@@ -61,29 +62,28 @@ const Admin: React.FC<AdminProps> = (
61
62
  flexDirection: "column",
62
63
  }}
63
64
  >
64
- {loaded
65
- ? user !== null
66
- ? (
67
- <BrowserRouter basename={basename}>
68
- <RouterContextProvider>
69
- <Box sx={{ display: "flex" }}>
70
- <NavBar
71
- nav={nav}
72
- logo={logo}
73
- title={title}
74
- subtitle={subtitle}
75
- version={version}
76
- />
77
- <Router
78
- extensions={extensions}
79
- dashboard={dashboard}
80
- />
81
- </Box>
82
- </RouterContextProvider>
83
- </BrowserRouter>
84
- )
85
- : <LoginPage logo={logo} title={title} />
86
- : <LoadingScreen logo={logo} loading={!loaded} />}
65
+ {loaded ? (
66
+ user !== null ? (
67
+ <BrowserRouter basename={basename}>
68
+ <RouterContextProvider>
69
+ <Box sx={{ display: "flex" }}>
70
+ <NavBar
71
+ nav={nav}
72
+ logo={logo}
73
+ title={title}
74
+ subtitle={subtitle}
75
+ version={version}
76
+ />
77
+ <Router extensions={extensions} dashboard={dashboard} />
78
+ </Box>
79
+ </RouterContextProvider>
80
+ </BrowserRouter>
81
+ ) : (
82
+ <LoginPage logo={logo} title={title} />
83
+ )
84
+ ) : (
85
+ <LoadingScreen logo={logo} loading={!loaded} />
86
+ )}
87
87
  </Box>
88
88
  </>
89
89
  );
package/src/App.tsx CHANGED
@@ -10,10 +10,14 @@ import { I18nContextProvider } from "./contexts/I18nContext";
10
10
  import { SnackbarProvider } from "notistack";
11
11
 
12
12
  type AppProps = {
13
- api: ApiClient | string | URL | {
14
- schema: string | URL;
15
- server?: string | URL;
16
- };
13
+ api:
14
+ | ApiClient
15
+ | string
16
+ | URL
17
+ | {
18
+ schema: string | URL;
19
+ server?: string | URL;
20
+ };
17
21
  theme?: Partial<Theme> | ((outerTheme: Theme) => Theme);
18
22
  } & AdminProps;
19
23
 
@@ -13,9 +13,11 @@ export interface TitleBarProps {
13
13
  title?: React.ReactNode;
14
14
  }
15
15
 
16
- export const TitleBar: React.FC<React.PropsWithChildren<TitleBarProps>> = (
17
- { back = false, title, children },
18
- ) => {
16
+ export const TitleBar: React.FC<React.PropsWithChildren<TitleBarProps>> = ({
17
+ back = false,
18
+ title,
19
+ children,
20
+ }) => {
19
21
  const theme = useTheme();
20
22
  const { navigate } = useRouter();
21
23
 
@@ -27,6 +29,7 @@ export const TitleBar: React.FC<React.PropsWithChildren<TitleBarProps>> = (
27
29
  <AppBar
28
30
  sx={{
29
31
  flexGrow: 1,
32
+ backgroundColor: theme.palette.background.paper,
30
33
  borderBottomWidth: 1,
31
34
  borderBottomStyle: "solid",
32
35
  borderBottomColor: theme.palette.divider,
@@ -36,21 +39,23 @@ export const TitleBar: React.FC<React.PropsWithChildren<TitleBarProps>> = (
36
39
  >
37
40
  <Toolbar>
38
41
  <Box sx={{ display: "flex", flexGrow: 1, alignItems: "center" }}>
39
- {back
40
- ? (
41
- <IconButton
42
- size="large"
43
- edge="start"
44
- color="inherit"
45
- aria-label="back"
46
- sx={{ mr: 2 }}
47
- onClick={() => navigate(back as string | number | RouteInfo)}
48
- >
49
- <ArrowBackIcon />
50
- </IconButton>
51
- )
52
- : null}
53
- {title ? <Typography variant="h6">{title}</Typography> : null}
42
+ {back ? (
43
+ <IconButton
44
+ size="large"
45
+ edge="start"
46
+ color="inherit"
47
+ aria-label="back"
48
+ sx={{ mr: 2 }}
49
+ onClick={() => navigate(back as string | number | RouteInfo)}
50
+ >
51
+ <ArrowBackIcon />
52
+ </IconButton>
53
+ ) : null}
54
+ {title ? (
55
+ <Typography color={theme.palette.text.primary} variant="h6">
56
+ {title}
57
+ </Typography>
58
+ ) : null}
54
59
  </Box>
55
60
  {children}
56
61
  </Toolbar>
@@ -11,7 +11,7 @@ const Content: React.FC<React.PropsWithChildren<{}>> = ({ children }) => {
11
11
  container
12
12
  sx={{
13
13
  position: "relative",
14
- padding: 2,
14
+ padding: 3,
15
15
  minWidth: 600,
16
16
  overflow: "scroll",
17
17
  height: "100%",