bananas-commerce-admin 0.2.2 → 0.2.5

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 (361) hide show
  1. package/README.md +4 -8
  2. package/dist/cjs/Admin.js +54 -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/DialogContext.js +82 -0
  41. package/dist/cjs/contexts/DialogContext.js.map +1 -0
  42. package/dist/cjs/contexts/I18nContext.js +58 -18
  43. package/dist/cjs/contexts/I18nContext.js.map +1 -0
  44. package/dist/cjs/contexts/RouterContext.js +52 -44
  45. package/dist/cjs/contexts/RouterContext.js.map +1 -0
  46. package/dist/cjs/contexts/UserContext.js +96 -43
  47. package/dist/cjs/contexts/UserContext.js.map +1 -0
  48. package/dist/cjs/extensions/bananas/components/PasswordChangeForm.js +45 -32
  49. package/dist/cjs/extensions/bananas/components/PasswordChangeForm.js.map +1 -0
  50. package/dist/cjs/extensions/bananas/index.js +3 -2
  51. package/dist/cjs/extensions/bananas/index.js.map +1 -0
  52. package/dist/cjs/extensions/bananas/pages/me/list.js +10 -9
  53. package/dist/cjs/extensions/bananas/pages/me/list.js.map +1 -0
  54. package/dist/cjs/extensions/fulfillment/components/AddressInfo.js +8 -6
  55. package/dist/cjs/extensions/fulfillment/components/AddressInfo.js.map +1 -0
  56. package/dist/cjs/extensions/fulfillment/components/ContactInfo.js +9 -7
  57. package/dist/cjs/extensions/fulfillment/components/ContactInfo.js.map +1 -0
  58. package/dist/cjs/extensions/fulfillment/components/RecipientCard.js +14 -12
  59. package/dist/cjs/extensions/fulfillment/components/RecipientCard.js.map +1 -0
  60. package/dist/cjs/extensions/fulfillment/components/ShipmentAccordion.js +124 -65
  61. package/dist/cjs/extensions/fulfillment/components/ShipmentAccordion.js.map +1 -0
  62. package/dist/cjs/extensions/fulfillment/components/ShipmentCard.js +19 -17
  63. package/dist/cjs/extensions/fulfillment/components/ShipmentCard.js.map +1 -0
  64. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationButtons.js +32 -19
  65. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationButtons.js.map +1 -0
  66. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationIcon.js +23 -11
  67. package/dist/cjs/extensions/fulfillment/components/ShipmentDestinationIcon.js.map +1 -0
  68. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsCard.js +73 -46
  69. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsCard.js.map +1 -0
  70. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsTable.js +49 -27
  71. package/dist/cjs/extensions/fulfillment/components/ShipmentItemsTable.js.map +1 -0
  72. package/dist/cjs/extensions/fulfillment/components/ShipmentRow.js +12 -10
  73. package/dist/cjs/extensions/fulfillment/components/ShipmentRow.js.map +1 -0
  74. package/dist/cjs/extensions/fulfillment/components/order/OrderAccordion.js +244 -0
  75. package/dist/cjs/extensions/fulfillment/components/order/OrderAccordion.js.map +1 -0
  76. package/dist/cjs/extensions/fulfillment/components/order/OrderItemsTable.js +96 -0
  77. package/dist/cjs/extensions/fulfillment/components/order/OrderItemsTable.js.map +1 -0
  78. package/dist/cjs/extensions/fulfillment/components/order/OrderStateChip.js +98 -0
  79. package/dist/cjs/extensions/fulfillment/components/order/OrderStateChip.js.map +1 -0
  80. package/dist/cjs/extensions/fulfillment/index.js +59 -12
  81. package/dist/cjs/extensions/fulfillment/index.js.map +1 -0
  82. package/dist/cjs/extensions/fulfillment/pages/order/list.js +50 -36
  83. package/dist/cjs/extensions/fulfillment/pages/order/list.js.map +1 -0
  84. package/dist/cjs/extensions/fulfillment/pages/recipient/detail.js +7 -5
  85. package/dist/cjs/extensions/fulfillment/pages/recipient/detail.js.map +1 -0
  86. package/dist/cjs/extensions/fulfillment/pages/shipment/detail.js +57 -42
  87. package/dist/cjs/extensions/fulfillment/pages/shipment/detail.js.map +1 -0
  88. package/dist/cjs/extensions/fulfillment/pages/shipment/list.js +35 -31
  89. package/dist/cjs/extensions/fulfillment/pages/shipment/list.js.map +1 -0
  90. package/dist/cjs/extensions/fulfillment/types/order.js +3 -0
  91. package/dist/cjs/extensions/fulfillment/types/order.js.map +1 -0
  92. package/dist/cjs/extensions/fulfillment/types/recipient.js +1 -0
  93. package/dist/cjs/extensions/fulfillment/types/recipient.js.map +1 -0
  94. package/dist/cjs/extensions/fulfillment/types/shipment.js +1 -0
  95. package/dist/cjs/extensions/fulfillment/types/shipment.js.map +1 -0
  96. package/dist/cjs/extensions/fulfillment/types/util.js +1 -0
  97. package/dist/cjs/extensions/fulfillment/types/util.js.map +1 -0
  98. package/dist/cjs/extensions/pos/components/PurchaseRow.js +13 -11
  99. package/dist/cjs/extensions/pos/components/PurchaseRow.js.map +1 -0
  100. package/dist/cjs/extensions/pos/components/ReceiptCard.js +99 -44
  101. package/dist/cjs/extensions/pos/components/ReceiptCard.js.map +1 -0
  102. package/dist/cjs/extensions/pos/components/ReceiptLine.js +17 -12
  103. package/dist/cjs/extensions/pos/components/ReceiptLine.js.map +1 -0
  104. package/dist/cjs/extensions/pos/components/ReceiptTable.js +168 -43
  105. package/dist/cjs/extensions/pos/components/ReceiptTable.js.map +1 -0
  106. package/dist/cjs/extensions/pos/components/SearchBar.js +40 -25
  107. package/dist/cjs/extensions/pos/components/SearchBar.js.map +1 -0
  108. package/dist/cjs/extensions/pos/index.js +57 -12
  109. package/dist/cjs/extensions/pos/index.js.map +1 -0
  110. package/dist/cjs/extensions/pos/pages/purchase/detail.js +31 -20
  111. package/dist/cjs/extensions/pos/pages/purchase/detail.js.map +1 -0
  112. package/dist/cjs/extensions/pos/pages/purchase/list.js +39 -32
  113. package/dist/cjs/extensions/pos/pages/purchase/list.js.map +1 -0
  114. package/dist/cjs/extensions/pos/types/purchase.js +1 -0
  115. package/dist/cjs/extensions/pos/types/purchase.js.map +1 -0
  116. package/dist/cjs/extensions/pos/types/receipt.js +8 -0
  117. package/dist/cjs/extensions/pos/types/receipt.js.map +1 -0
  118. package/dist/cjs/forms/LoginForm.js +31 -30
  119. package/dist/cjs/forms/LoginForm.js.map +1 -0
  120. package/dist/cjs/hooks/useAsyncError.js +5 -4
  121. package/dist/cjs/hooks/useAsyncError.js.map +1 -0
  122. package/dist/cjs/hooks/useLocalStorage.js +8 -7
  123. package/dist/cjs/hooks/useLocalStorage.js.map +1 -0
  124. package/dist/cjs/index.js +1 -0
  125. package/dist/cjs/index.js.map +1 -0
  126. package/dist/cjs/pages/DashboardPage.js +4 -3
  127. package/dist/cjs/pages/DashboardPage.js.map +1 -0
  128. package/dist/cjs/pages/LoginPage.js +12 -10
  129. package/dist/cjs/pages/LoginPage.js.map +1 -0
  130. package/dist/cjs/router/Router.js +25 -19
  131. package/dist/cjs/router/Router.js.map +1 -0
  132. package/dist/cjs/router/routes.js +8 -7
  133. package/dist/cjs/router/routes.js.map +1 -0
  134. package/dist/cjs/types/index.js +1 -0
  135. package/dist/cjs/types/index.js.map +1 -0
  136. package/dist/cjs/util/format_purchase_number.js +2 -1
  137. package/dist/cjs/util/format_purchase_number.js.map +1 -0
  138. package/dist/cjs/util/get_cookie.js +4 -3
  139. package/dist/cjs/util/get_cookie.js.map +1 -0
  140. package/dist/cjs/util/index.js +10 -7
  141. package/dist/cjs/util/index.js.map +1 -0
  142. package/dist/cjs/util/is_email.js +1 -0
  143. package/dist/cjs/util/is_email.js.map +1 -0
  144. package/dist/cjs/util/is_positive_integer.js +2 -1
  145. package/dist/cjs/util/is_positive_integer.js.map +1 -0
  146. package/dist/cjs/util/select_styles.js +24 -7
  147. package/dist/cjs/util/select_styles.js.map +1 -0
  148. package/dist/esm/Admin.js +20 -16
  149. package/dist/esm/Admin.js.map +1 -0
  150. package/dist/esm/App.js +15 -3
  151. package/dist/esm/App.js.map +1 -0
  152. package/dist/esm/api.js +125 -63
  153. package/dist/esm/api.js.map +1 -0
  154. package/dist/esm/components/Branding.js +4 -2
  155. package/dist/esm/components/Branding.js.map +1 -0
  156. package/dist/esm/components/Hamburger.js +17 -5
  157. package/dist/esm/components/Hamburger.js.map +1 -0
  158. package/dist/esm/components/Link.js +6 -4
  159. package/dist/esm/components/Link.js.map +1 -0
  160. package/dist/esm/components/Logo.js +4 -2
  161. package/dist/esm/components/Logo.js.map +1 -0
  162. package/dist/esm/components/NavBar.js +38 -21
  163. package/dist/esm/components/NavBar.js.map +1 -0
  164. package/dist/esm/components/NavBarItem.js +8 -6
  165. package/dist/esm/components/NavBarItem.js.map +1 -0
  166. package/dist/esm/components/NavBarRoutes.js +19 -14
  167. package/dist/esm/components/NavBarRoutes.js.map +1 -0
  168. package/dist/esm/components/ProgressBar.js +3 -1
  169. package/dist/esm/components/ProgressBar.js.map +1 -0
  170. package/dist/esm/components/TitleBar.js +9 -8
  171. package/dist/esm/components/TitleBar.js.map +1 -0
  172. package/dist/esm/components/User.js +24 -11
  173. package/dist/esm/components/User.js.map +1 -0
  174. package/dist/esm/containers/Content.js +5 -3
  175. package/dist/esm/containers/Content.js.map +1 -0
  176. package/dist/esm/containers/ErrorScreen.js +10 -8
  177. package/dist/esm/containers/ErrorScreen.js.map +1 -0
  178. package/dist/esm/containers/LoadingScreen.js +56 -41
  179. package/dist/esm/containers/LoadingScreen.js.map +1 -0
  180. package/dist/esm/containers/PageErrorBoundary.js +33 -13
  181. package/dist/esm/containers/PageErrorBoundary.js.map +1 -0
  182. package/dist/esm/containers/PageLoader.js +124 -34
  183. package/dist/esm/containers/PageLoader.js.map +1 -0
  184. package/dist/esm/contexts/ApiContext.js +49 -12
  185. package/dist/esm/contexts/ApiContext.js.map +1 -0
  186. package/dist/esm/contexts/DialogContext.js +51 -0
  187. package/dist/esm/contexts/DialogContext.js.map +1 -0
  188. package/dist/esm/contexts/I18nContext.js +55 -15
  189. package/dist/esm/contexts/I18nContext.js.map +1 -0
  190. package/dist/esm/contexts/RouterContext.js +47 -39
  191. package/dist/esm/contexts/RouterContext.js.map +1 -0
  192. package/dist/esm/contexts/UserContext.js +93 -40
  193. package/dist/esm/contexts/UserContext.js.map +1 -0
  194. package/dist/esm/extensions/bananas/components/PasswordChangeForm.js +32 -19
  195. package/dist/esm/extensions/bananas/components/PasswordChangeForm.js.map +1 -0
  196. package/dist/esm/extensions/bananas/index.js +3 -2
  197. package/dist/esm/extensions/bananas/index.js.map +1 -0
  198. package/dist/esm/extensions/bananas/pages/me/list.js +3 -2
  199. package/dist/esm/extensions/bananas/pages/me/list.js.map +1 -0
  200. package/dist/esm/extensions/fulfillment/components/AddressInfo.js +5 -3
  201. package/dist/esm/extensions/fulfillment/components/AddressInfo.js.map +1 -0
  202. package/dist/esm/extensions/fulfillment/components/ContactInfo.js +5 -3
  203. package/dist/esm/extensions/fulfillment/components/ContactInfo.js.map +1 -0
  204. package/dist/esm/extensions/fulfillment/components/RecipientCard.js +6 -4
  205. package/dist/esm/extensions/fulfillment/components/RecipientCard.js.map +1 -0
  206. package/dist/esm/extensions/fulfillment/components/ShipmentAccordion.js +109 -50
  207. package/dist/esm/extensions/fulfillment/components/ShipmentAccordion.js.map +1 -0
  208. package/dist/esm/extensions/fulfillment/components/ShipmentCard.js +8 -6
  209. package/dist/esm/extensions/fulfillment/components/ShipmentCard.js.map +1 -0
  210. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationButtons.js +27 -14
  211. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationButtons.js.map +1 -0
  212. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationIcon.js +18 -6
  213. package/dist/esm/extensions/fulfillment/components/ShipmentDestinationIcon.js.map +1 -0
  214. package/dist/esm/extensions/fulfillment/components/ShipmentItemsCard.js +54 -27
  215. package/dist/esm/extensions/fulfillment/components/ShipmentItemsCard.js.map +1 -0
  216. package/dist/esm/extensions/fulfillment/components/ShipmentItemsTable.js +40 -18
  217. package/dist/esm/extensions/fulfillment/components/ShipmentItemsTable.js.map +1 -0
  218. package/dist/esm/extensions/fulfillment/components/ShipmentRow.js +8 -6
  219. package/dist/esm/extensions/fulfillment/components/ShipmentRow.js.map +1 -0
  220. package/dist/esm/extensions/fulfillment/components/order/OrderAccordion.js +239 -0
  221. package/dist/esm/extensions/fulfillment/components/order/OrderAccordion.js.map +1 -0
  222. package/dist/esm/extensions/fulfillment/components/order/OrderItemsTable.js +91 -0
  223. package/dist/esm/extensions/fulfillment/components/order/OrderItemsTable.js.map +1 -0
  224. package/dist/esm/extensions/fulfillment/components/order/OrderStateChip.js +70 -0
  225. package/dist/esm/extensions/fulfillment/components/order/OrderStateChip.js.map +1 -0
  226. package/dist/esm/extensions/fulfillment/index.js +61 -14
  227. package/dist/esm/extensions/fulfillment/index.js.map +1 -0
  228. package/dist/esm/extensions/fulfillment/pages/order/list.js +40 -26
  229. package/dist/esm/extensions/fulfillment/pages/order/list.js.map +1 -0
  230. package/dist/esm/extensions/fulfillment/pages/recipient/detail.js +4 -2
  231. package/dist/esm/extensions/fulfillment/pages/recipient/detail.js.map +1 -0
  232. package/dist/esm/extensions/fulfillment/pages/shipment/detail.js +38 -23
  233. package/dist/esm/extensions/fulfillment/pages/shipment/detail.js.map +1 -0
  234. package/dist/esm/extensions/fulfillment/pages/shipment/list.js +24 -20
  235. package/dist/esm/extensions/fulfillment/pages/shipment/list.js.map +1 -0
  236. package/dist/esm/extensions/fulfillment/types/order.js +2 -0
  237. package/dist/esm/extensions/fulfillment/types/order.js.map +1 -0
  238. package/dist/esm/extensions/fulfillment/types/recipient.js +1 -0
  239. package/dist/esm/extensions/fulfillment/types/recipient.js.map +1 -0
  240. package/dist/esm/extensions/fulfillment/types/shipment.js +1 -0
  241. package/dist/esm/extensions/fulfillment/types/shipment.js.map +1 -0
  242. package/dist/esm/extensions/fulfillment/types/util.js +1 -0
  243. package/dist/esm/extensions/fulfillment/types/util.js.map +1 -0
  244. package/dist/esm/extensions/pos/components/PurchaseRow.js +8 -6
  245. package/dist/esm/extensions/pos/components/PurchaseRow.js.map +1 -0
  246. package/dist/esm/extensions/pos/components/ReceiptCard.js +83 -28
  247. package/dist/esm/extensions/pos/components/ReceiptCard.js.map +1 -0
  248. package/dist/esm/extensions/pos/components/ReceiptLine.js +11 -6
  249. package/dist/esm/extensions/pos/components/ReceiptLine.js.map +1 -0
  250. package/dist/esm/extensions/pos/components/ReceiptTable.js +159 -34
  251. package/dist/esm/extensions/pos/components/ReceiptTable.js.map +1 -0
  252. package/dist/esm/extensions/pos/components/SearchBar.js +28 -13
  253. package/dist/esm/extensions/pos/components/SearchBar.js.map +1 -0
  254. package/dist/esm/extensions/pos/index.js +58 -13
  255. package/dist/esm/extensions/pos/index.js.map +1 -0
  256. package/dist/esm/extensions/pos/pages/purchase/detail.js +23 -12
  257. package/dist/esm/extensions/pos/pages/purchase/detail.js.map +1 -0
  258. package/dist/esm/extensions/pos/pages/purchase/list.js +23 -16
  259. package/dist/esm/extensions/pos/pages/purchase/list.js.map +1 -0
  260. package/dist/esm/extensions/pos/types/purchase.js +1 -0
  261. package/dist/esm/extensions/pos/types/purchase.js.map +1 -0
  262. package/dist/esm/extensions/pos/types/receipt.js +7 -1
  263. package/dist/esm/extensions/pos/types/receipt.js.map +1 -0
  264. package/dist/esm/forms/LoginForm.js +19 -18
  265. package/dist/esm/forms/LoginForm.js.map +1 -0
  266. package/dist/esm/hooks/useAsyncError.js +4 -3
  267. package/dist/esm/hooks/useAsyncError.js.map +1 -0
  268. package/dist/esm/hooks/useLocalStorage.js +7 -6
  269. package/dist/esm/hooks/useLocalStorage.js.map +1 -0
  270. package/dist/esm/index.js +1 -0
  271. package/dist/esm/index.js.map +1 -0
  272. package/dist/esm/pages/DashboardPage.js +3 -2
  273. package/dist/esm/pages/DashboardPage.js.map +1 -0
  274. package/dist/esm/pages/LoginPage.js +5 -3
  275. package/dist/esm/pages/LoginPage.js.map +1 -0
  276. package/dist/esm/router/Router.js +17 -11
  277. package/dist/esm/router/Router.js.map +1 -0
  278. package/dist/esm/router/routes.js +7 -6
  279. package/dist/esm/router/routes.js.map +1 -0
  280. package/dist/esm/types/index.js +1 -0
  281. package/dist/esm/types/index.js.map +1 -0
  282. package/dist/esm/util/format_purchase_number.js +2 -1
  283. package/dist/esm/util/format_purchase_number.js.map +1 -0
  284. package/dist/esm/util/get_cookie.js +4 -3
  285. package/dist/esm/util/get_cookie.js.map +1 -0
  286. package/dist/esm/util/index.js +10 -7
  287. package/dist/esm/util/index.js.map +1 -0
  288. package/dist/esm/util/is_email.js +1 -0
  289. package/dist/esm/util/is_email.js.map +1 -0
  290. package/dist/esm/util/is_positive_integer.js +2 -1
  291. package/dist/esm/util/is_positive_integer.js.map +1 -0
  292. package/dist/esm/util/select_styles.js +25 -8
  293. package/dist/esm/util/select_styles.js.map +1 -0
  294. package/dist/types/Admin.d.ts +1 -1
  295. package/dist/types/App.d.ts +1 -1
  296. package/dist/types/components/Hamburger.d.ts +1 -1
  297. package/dist/types/components/Link.d.ts +1 -1
  298. package/dist/types/components/User.d.ts +4 -7
  299. package/dist/types/containers/PageErrorBoundary.d.ts +1 -1
  300. package/dist/types/containers/PageLoader.d.ts +1 -0
  301. package/dist/types/contexts/DialogContext.d.ts +7 -0
  302. package/dist/types/contexts/RouterContext.d.ts +2 -2
  303. package/dist/types/extensions/fulfillment/components/ShipmentDestinationIcon.d.ts +1 -1
  304. package/dist/types/extensions/fulfillment/components/order/OrderAccordion.d.ts +7 -0
  305. package/dist/types/extensions/fulfillment/components/order/OrderItemsTable.d.ts +9 -0
  306. package/dist/types/extensions/fulfillment/components/order/OrderStateChip.d.ts +10 -0
  307. package/dist/types/extensions/fulfillment/pages/order/list.d.ts +2 -2
  308. package/dist/types/extensions/fulfillment/types/order.d.ts +38 -0
  309. package/dist/types/extensions/fulfillment/types/shipment.d.ts +1 -1
  310. package/dist/types/extensions/pos/components/PurchaseRow.d.ts +2 -2
  311. package/dist/types/extensions/pos/components/ReceiptCard.d.ts +3 -3
  312. package/dist/types/extensions/pos/components/ReceiptLine.d.ts +1 -0
  313. package/dist/types/extensions/pos/components/ReceiptTable.d.ts +4 -3
  314. package/dist/types/extensions/pos/components/SearchBar.d.ts +1 -1
  315. package/dist/types/extensions/pos/pages/purchase/list.d.ts +2 -2
  316. package/dist/types/extensions/pos/types/purchase.d.ts +32 -6
  317. package/dist/types/extensions/pos/types/receipt.d.ts +7 -9
  318. package/dist/types/router/Router.d.ts +2 -1
  319. package/dist/types/types/index.d.ts +7 -4
  320. package/example/index.tsx +28 -9
  321. package/example/package-lock.json +7906 -1003
  322. package/example/package.json +18 -8
  323. package/example/scripts/build.js +4 -0
  324. package/example/scripts/options.js +81 -0
  325. package/{example/pages/.gitkeep → nodemon.json} +0 -0
  326. package/package.json +8 -4
  327. package/src/Admin.tsx +31 -27
  328. package/src/App.tsx +8 -4
  329. package/src/components/TitleBar.tsx +23 -18
  330. package/src/containers/Content.tsx +1 -1
  331. package/src/containers/PageLoader.tsx +32 -14
  332. package/src/contexts/DialogContext.tsx +76 -0
  333. package/src/contexts/UserContext.tsx +15 -14
  334. package/src/extensions/fulfillment/components/ShipmentAccordion.tsx +126 -116
  335. package/src/extensions/fulfillment/components/ShipmentCard.tsx +3 -9
  336. package/src/extensions/fulfillment/components/ShipmentItemsCard.tsx +42 -45
  337. package/src/extensions/fulfillment/components/order/OrderAccordion.tsx +231 -0
  338. package/src/extensions/fulfillment/components/order/OrderItemsTable.tsx +128 -0
  339. package/src/extensions/fulfillment/components/order/OrderStateChip.tsx +79 -0
  340. package/src/extensions/fulfillment/index.tsx +27 -9
  341. package/src/extensions/fulfillment/pages/order/list.tsx +43 -54
  342. package/src/extensions/fulfillment/pages/shipment/detail.tsx +47 -55
  343. package/src/extensions/fulfillment/types/order.ts +53 -0
  344. package/src/extensions/pos/components/PurchaseRow.tsx +3 -5
  345. package/src/extensions/pos/components/ReceiptCard.tsx +92 -46
  346. package/src/extensions/pos/components/ReceiptLine.tsx +6 -5
  347. package/src/extensions/pos/components/ReceiptTable.tsx +214 -73
  348. package/src/extensions/pos/index.tsx +3 -3
  349. package/src/extensions/pos/pages/purchase/detail.tsx +28 -33
  350. package/src/extensions/pos/pages/purchase/list.tsx +14 -20
  351. package/src/extensions/pos/types/purchase.ts +33 -6
  352. package/src/extensions/pos/types/receipt.ts +8 -9
  353. package/src/pages/DashboardPage.tsx +1 -1
  354. package/src/router/Router.tsx +14 -15
  355. package/src/types/index.ts +4 -1
  356. package/tsconfig.json +5 -13
  357. package/example/Dockerfile +0 -27
  358. package/example/README.md +0 -6
  359. package/example/build.js +0 -19
  360. package/example/docker-compose.yml +0 -7
  361. package/example/public/index.html +0 -14
@@ -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.5",
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
@@ -12,6 +12,7 @@ import { useUser } from "./contexts/UserContext";
12
12
  import LoginPage from "./pages/LoginPage";
13
13
  import { Router, RouterProps } from "./router/Router";
14
14
  import { LogoType, NavOverrides } from "./types";
15
+ import DialogContextProvider, { BcomDialog } from "./contexts/DialogContext";
15
16
 
16
17
  export type AdminProps = {
17
18
  logo?: LogoType;
@@ -22,18 +23,16 @@ export type AdminProps = {
22
23
  basename?: string;
23
24
  } & RouterProps;
24
25
 
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
- ) => {
26
+ const Admin: React.FC<AdminProps> = ({
27
+ logo,
28
+ title,
29
+ subtitle,
30
+ version,
31
+ nav,
32
+ extensions,
33
+ dashboard,
34
+ basename,
35
+ }) => {
37
36
  const [loaded, setLoaded] = React.useState(false);
38
37
 
39
38
  const api = useApi();
@@ -42,7 +41,10 @@ const Admin: React.FC<AdminProps> = (
42
41
 
43
42
  React.useEffect(() => {
44
43
  if (
45
- !loaded && api !== undefined && i18n !== undefined && user !== undefined
44
+ !loaded &&
45
+ api !== undefined &&
46
+ i18n !== undefined &&
47
+ user !== undefined
46
48
  ) {
47
49
  setLoaded(true);
48
50
  }
@@ -61,11 +63,12 @@ const Admin: React.FC<AdminProps> = (
61
63
  flexDirection: "column",
62
64
  }}
63
65
  >
64
- {loaded
65
- ? user !== null
66
- ? (
67
- <BrowserRouter basename={basename}>
68
- <RouterContextProvider>
66
+ {loaded ? (
67
+ user !== null ? (
68
+ <BrowserRouter basename={basename}>
69
+ <RouterContextProvider>
70
+ <DialogContextProvider>
71
+ <BcomDialog />
69
72
  <Box sx={{ display: "flex" }}>
70
73
  <NavBar
71
74
  nav={nav}
@@ -74,16 +77,17 @@ const Admin: React.FC<AdminProps> = (
74
77
  subtitle={subtitle}
75
78
  version={version}
76
79
  />
77
- <Router
78
- extensions={extensions}
79
- dashboard={dashboard}
80
- />
80
+ <Router extensions={extensions} dashboard={dashboard} />
81
81
  </Box>
82
- </RouterContextProvider>
83
- </BrowserRouter>
84
- )
85
- : <LoginPage logo={logo} title={title} />
86
- : <LoadingScreen logo={logo} loading={!loaded} />}
82
+ </DialogContextProvider>
83
+ </RouterContextProvider>
84
+ </BrowserRouter>
85
+ ) : (
86
+ <LoginPage logo={logo} title={title} />
87
+ )
88
+ ) : (
89
+ <LoadingScreen logo={logo} loading={!loaded} />
90
+ )}
87
91
  </Box>
88
92
  </>
89
93
  );
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="default"
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%",
@@ -22,9 +22,15 @@ export interface PageLoaderProps {
22
22
  route: RouteInfo;
23
23
  page: PageComponent | Promise<PageComponent>;
24
24
  request?: OpenAPI.Request;
25
+ defaultRequest?: OpenAPI.Request;
25
26
  }
26
27
 
27
- const PageLoader: React.FC<PageLoaderProps> = ({ route, page, request }) => {
28
+ const PageLoader: React.FC<PageLoaderProps> = ({
29
+ route,
30
+ page,
31
+ request,
32
+ defaultRequest,
33
+ }) => {
28
34
  const Page = React.lazy(async () => ({
29
35
  default: await Promise.resolve(page),
30
36
  }));
@@ -37,17 +43,29 @@ const PageLoader: React.FC<PageLoaderProps> = ({ route, page, request }) => {
37
43
 
38
44
  React.useEffect(() => {
39
45
  if (data === null) {
40
- api.operations[route.id].call({
41
- params: { ...params, ...request?.params },
42
- query: new URLSearchParams([
43
- ...searchParams.entries(),
44
- ...(request?.query != null
45
- ? request.query instanceof URLSearchParams
46
- ? request.query.entries()
47
- : Object.entries(request.query)
48
- : []),
49
- ]),
50
- })
46
+ const query =
47
+ Array.from(searchParams.entries()).length == 0
48
+ ? defaultRequest?.query != null
49
+ ? defaultRequest.query instanceof URLSearchParams
50
+ ? defaultRequest.query.entries()
51
+ : Object.entries(defaultRequest.query)
52
+ : []
53
+ : searchParams.entries();
54
+
55
+ api.operations[route.id]
56
+ .call({
57
+ params: { ...params, ...request?.params },
58
+ query: new URLSearchParams([
59
+ ...Array.from(query),
60
+ ...Array.from(
61
+ request?.query != null
62
+ ? request.query instanceof URLSearchParams
63
+ ? request.query.entries()
64
+ : Object.entries(request.query)
65
+ : []
66
+ ),
67
+ ]),
68
+ })
51
69
  .then(async (response) => {
52
70
  if (response.ok) {
53
71
  setData(await response.json());
@@ -55,8 +73,8 @@ const PageLoader: React.FC<PageLoaderProps> = ({ route, page, request }) => {
55
73
  throwError(
56
74
  new PageLoadFailedError(
57
75
  response,
58
- `Page data load failed with ${response.status} ${response.statusText}`,
59
- ),
76
+ `Page data load failed with ${response.status} ${response.statusText}`
77
+ )
60
78
  );
61
79
  }
62
80
  })
@@ -0,0 +1,76 @@
1
+ import React, { useContext, useState } from "react";
2
+
3
+ import Dialog from "@mui/material/Dialog";
4
+ import DialogContent from "@mui/material/DialogContent";
5
+ import DialogTitle from "@mui/material/DialogTitle";
6
+ import DialogActions from "@mui/material/DialogActions";
7
+ import Button from "@mui/material/Button";
8
+
9
+ const DialogContext = React.createContext<{
10
+ title: string;
11
+ description: string;
12
+ cb: (ok: boolean) => void;
13
+ open: boolean;
14
+ makeOpen: (title: string, description: string) => Promise<boolean>;
15
+ }>({
16
+ makeOpen: () => Promise.resolve(false),
17
+ } as any);
18
+
19
+ function DialogContextProvider(props: { children: React.ReactNode }) {
20
+ const [title, setTitle] = useState("");
21
+ const [description, setDescription] = useState("");
22
+ const [open, setOpen] = useState(false);
23
+
24
+ return (
25
+ <DialogContext.Provider
26
+ value={{
27
+ makeOpen: (title, description) => {
28
+ setTitle(title);
29
+ setDescription(description);
30
+ setOpen(true);
31
+ return new Promise((resolve) => {
32
+ const event = (e: any) => {
33
+ window.removeEventListener("dialogclick", event);
34
+ resolve(e.detail);
35
+ };
36
+
37
+ window.addEventListener("dialogclick", event);
38
+ });
39
+ },
40
+ title: title,
41
+ description: description,
42
+ open: open,
43
+ cb: (ok) => {
44
+ window.dispatchEvent(new CustomEvent("dialogclick", { detail: ok }));
45
+ setOpen(false);
46
+ },
47
+ }}
48
+ >
49
+ {props.children}
50
+ </DialogContext.Provider>
51
+ );
52
+ }
53
+
54
+ export function BcomDialog() {
55
+ const ctx = useContext(DialogContext);
56
+
57
+ return (
58
+ <Dialog open={ctx.open}>
59
+ <DialogContent>
60
+ <DialogTitle>{ctx.title}</DialogTitle>
61
+ <DialogContent>{ctx.description}</DialogContent>
62
+ <DialogActions>
63
+ <Button onClick={() => ctx.cb(false)}>Cancel</Button>
64
+ <Button onClick={() => ctx.cb(true)}>Ok</Button>
65
+ </DialogActions>
66
+ </DialogContent>
67
+ </Dialog>
68
+ );
69
+ }
70
+
71
+ export function useDialog() {
72
+ const { makeOpen } = useContext(DialogContext);
73
+ return makeOpen;
74
+ }
75
+
76
+ export default DialogContextProvider;
@@ -19,18 +19,18 @@ interface UserContext {
19
19
  changePassword: (
20
20
  oldPassword: string,
21
21
  newPassword1: string,
22
- newPassword2: string,
22
+ newPassword2: string
23
23
  ) => Promise<void>;
24
24
  }
25
25
 
26
26
  const UserContext = React.createContext<UserContext>(
27
- undefined as unknown as UserContext,
27
+ undefined as unknown as UserContext
28
28
  );
29
29
  export const useUser = () => React.useContext(UserContext);
30
30
 
31
- export const UserContextProvider: React.FC<React.PropsWithChildren<{}>> = (
32
- { children },
33
- ) => {
31
+ export const UserContextProvider: React.FC<React.PropsWithChildren<{}>> = ({
32
+ children,
33
+ }) => {
34
34
  const api = useApi();
35
35
  const [user, setUser] = useLocalStorage("user", null);
36
36
 
@@ -62,16 +62,17 @@ export const UserContextProvider: React.FC<React.PropsWithChildren<{}>> = (
62
62
  const changePassword = async (
63
63
  oldPassword: string,
64
64
  newPassword1: string,
65
- newPassword2: string,
65
+ newPassword2: string
66
66
  ) => {
67
- const response = await api?.operations["bananas.change_password:create"]
68
- .call({
69
- body: {
70
- old_password: oldPassword,
71
- new_password1: newPassword1,
72
- new_password2: newPassword2,
73
- },
74
- });
67
+ const response = await api?.operations[
68
+ "bananas.change_password:create"
69
+ ].call({
70
+ body: {
71
+ old_password: oldPassword,
72
+ new_password1: newPassword1,
73
+ new_password2: newPassword2,
74
+ },
75
+ });
75
76
 
76
77
  if (!response.ok) {
77
78
  throw new Error("Failed to change password");