@accounter/client
Version:
Accounter client application
1 lines • 10.3 kB
JavaScript
import{s as e}from"./dist-C51EwTaa.js";import{i as t,o as n}from"./utils-DdVdMk8X.js";import{D as r,Io as i,Lo as a,Q as o,Rn as s,Xn as c,r as l,ra as u,t as d}from"./error-handling-Dpfd9svJ.js";import{_t as f,a as p,c as m,d as h,f as g,ft as _,ht as v,i as y,l as b,m as x,n as ee,o as S,p as C,pt as w,r as T,t as E}from"./select-CrsvQyhZ.js";import{t as D}from"./button-Dzp2INW0.js";import{K as te,Lt as O,N as k,W as A,a as j,c as M,i as N,m as P,n as F,o as I,r as L,s as R,t as z,u as B}from"./table--bF0wbxq.js";var V=f(`banknote-arrow-down`,[[`path`,{d:`M12 18H4a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2v5`,key:`x6cv4u`}],[`path`,{d:`m16 19 3 3 3-3`,key:`1ibux0`}],[`path`,{d:`M18 12h.01`,key:`yjnet6`}],[`path`,{d:`M19 16v6`,key:`tddt3s`}],[`path`,{d:`M6 12h.01`,key:`c2rlol`}],[`circle`,{cx:`12`,cy:`12`,r:`2`,key:`1c9p78`}]]),H=f(`banknote-arrow-up`,[[`path`,{d:`M12 18H4a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2v5`,key:`x6cv4u`}],[`path`,{d:`M18 12h.01`,key:`yjnet6`}],[`path`,{d:`M19 22v-6`,key:`qhmiwi`}],[`path`,{d:`m22 19-3-3-3 3`,key:`rn6bg2`}],[`path`,{d:`M6 12h.01`,key:`c2rlol`}],[`circle`,{cx:`12`,cy:`12`,r:`2`,key:`1c9p78`}]]),U=e(n(),1),W=t();function G({transaction:e}){return(0,W.jsx)(`div`,{className:`flex flex-col justify-center`,children:e.eventDate?O(new Date(e.eventDate),`dd/MM/yyyy`):`-`})}function K({transaction:e}){let{isInterest:t,amount:n}=e,r=(0,U.useMemo)(()=>Number(n.raw)<0,[n.raw]);return(0,W.jsx)(`div`,{className:`flex items-center gap-2`,children:t?(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)(V,{className:`size-4 text-red-600`}),(0,W.jsx)(k,{variant:`outline`,className:`bg-red-50 text-red-700`,children:`Interest`})]}):r?(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)(H,{className:`size-4 text-green-600`}),(0,W.jsx)(k,{variant:`outline`,className:`bg-green-50 text-green-700`,children:`Deposit`})]}):(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)(V,{className:`size-4 text-red-600`}),(0,W.jsx)(k,{variant:`outline`,className:`bg-red-50 text-red-700`,children:`Withdrawal`})]})})}function q({transaction:e}){return(0,W.jsx)(`div`,{className:`flex flex-col justify-center font-mono ${Number(e.amount.raw)<0?`text-green-700`:`text-red-500`}`,children:e.amount.formatted})}function J({transaction:e}){return(0,W.jsx)(`div`,{className:`flex flex-col justify-center font-mono font-semibold`,children:(0,U.useMemo)(()=>{let{currency:t}=e.amount;return new Intl.NumberFormat(`en-US`,{style:`currency`,currency:t,minimumFractionDigits:2,maximumFractionDigits:2}).format(e.cumulativeBalance)},[e.cumulativeBalance,e.amount])})}function Y({transaction:e}){return(0,W.jsx)(`div`,{className:`flex flex-col justify-center font-mono font-semibold`,children:(0,U.useMemo)(()=>{let{currency:t}=e.amount;return new Intl.NumberFormat(`en-US`,{style:`currency`,currency:t,minimumFractionDigits:2,maximumFractionDigits:2}).format(e.totalInterest)},[e.totalInterest,e.amount])})}function X({transaction:e}){return(0,W.jsx)(`div`,{className:`flex flex-col justify-center font-mono text-muted-foreground`,children:(0,U.useMemo)(()=>new Intl.NumberFormat(`en-US`,{style:`currency`,currency:e.localCurrency,minimumFractionDigits:2,maximumFractionDigits:2}).format(e.localAmount),[e.localAmount,e.localCurrency])})}function Z({transaction:e}){return(0,W.jsx)(`div`,{className:`flex flex-col justify-center font-mono font-semibold text-muted-foreground`,children:(0,U.useMemo)(()=>new Intl.NumberFormat(`en-US`,{style:`currency`,currency:e.localCurrency,minimumFractionDigits:2,maximumFractionDigits:2}).format(e.localCumulativeBalance),[e.localCumulativeBalance,e.localCurrency])})}var Q=[{id:`date`,accessorKey:`eventDate`,sortingFn:e=>e.original.eventDate?new Date(e.original.eventDate).getTime():0,header:({column:e})=>(0,W.jsxs)(D,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[`Date`,e.getIsSorted()&&(e.getIsSorted()===`asc`?(0,W.jsx)(w,{className:`ml-2 h-4 w-4`}):(0,W.jsx)(v,{className:`ml-2 h-4 w-4`}))]}),cell:({row:e})=>(0,W.jsx)(G,{transaction:e.original})},{id:`indicator`,accessorKey:`amount.raw`,header:`Type`,cell:({row:e})=>(0,W.jsx)(K,{transaction:e.original})},{id:`amount`,accessorKey:`amount.raw`,header:({column:e})=>(0,W.jsxs)(D,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[`Origin Amount`,e.getIsSorted()&&(e.getIsSorted()===`asc`?(0,W.jsx)(w,{className:`ml-2 h-4 w-4`}):(0,W.jsx)(v,{className:`ml-2 h-4 w-4`}))]}),cell:({row:e})=>(0,W.jsx)(q,{transaction:e.original})},{id:`cumulativeBalance`,accessorKey:`cumulativeBalance`,header:({column:e})=>(0,W.jsxs)(D,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[`Origin Balance`,e.getIsSorted()&&(e.getIsSorted()===`asc`?(0,W.jsx)(w,{className:`ml-2 h-4 w-4`}):(0,W.jsx)(v,{className:`ml-2 h-4 w-4`}))]}),cell:({row:e})=>(0,W.jsx)(J,{transaction:e.original})},{id:`totalInterest`,accessorKey:`totalInterest`,header:({column:e})=>(0,W.jsxs)(D,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[`Interest`,e.getIsSorted()&&(e.getIsSorted()===`asc`?(0,W.jsx)(w,{className:`ml-2 h-4 w-4`}):(0,W.jsx)(v,{className:`ml-2 h-4 w-4`}))]}),cell:({row:e})=>(0,W.jsx)(Y,{transaction:e.original})},{id:`localAmount`,accessorKey:`localAmount`,header:({column:e})=>(0,W.jsxs)(D,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[`Local Amount`,e.getIsSorted()&&(e.getIsSorted()===`asc`?(0,W.jsx)(w,{className:`ml-2 h-4 w-4`}):(0,W.jsx)(v,{className:`ml-2 h-4 w-4`}))]}),cell:({row:e})=>(0,W.jsx)(X,{transaction:e.original})},{id:`localCumulativeBalance`,accessorKey:`localCumulativeBalance`,header:({column:e})=>(0,W.jsxs)(D,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[`Local Balance`,e.getIsSorted()&&(e.getIsSorted()===`asc`?(0,W.jsx)(w,{className:`ml-2 h-4 w-4`}):(0,W.jsx)(v,{className:`ml-2 h-4 w-4`}))]}),cell:({row:e})=>(0,W.jsx)(Z,{transaction:e.original})}],ne=`assignChargeToDeposit`,$=()=>{let[{fetching:e},t]=i(o);return{assigning:e,assignChargeToDeposit:(0,U.useCallback)(async e=>{let n=`Error assigning charge ${e.chargeId} to deposit ${e.depositId}`,r=`${ne}-${e.chargeId}`;l.loading(`Assigning to deposit`,{id:r});try{let i=d(await t(e),n,r);i&&l.success(`Success`,{id:r,description:`Charge assigned to deposit ${i.assignChargeToDeposit.id}`})}catch(e){console.error(`${n}: ${e}`),l.error(`Error`,{id:r,description:n,duration:1e5,closeButton:!0})}},[t])}};function re({depositId:e,chargeId:t,refetch:n}){let[i,o]=(0,U.useState)(!1),[s,c]=(0,U.useState)(void 0),[{data:l}]=a({query:r,pause:!i}),{assigning:u,assignChargeToDeposit:d}=$(),f=(0,U.useMemo)(()=>(l?.allDeposits??[]).filter(t=>t.isOpen&&t.id!==e),[l?.allDeposits,e]),_=(0,U.useCallback)(async()=>{s&&(await d({chargeId:t,depositId:s}),o(!1),c(void 0),n?.())},[d,s,n,t]);return(0,U.useEffect)(()=>{i&&c(void 0)},[i]),(0,W.jsxs)(m,{open:i,onOpenChange:o,children:[(0,W.jsx)(x,{children:(0,W.jsx)(D,{variant:`ghost`,size:`sm`,children:`Reassign`})}),(0,W.jsxs)(b,{children:[(0,W.jsx)(g,{children:(0,W.jsx)(C,{children:`Reassign Transaction`})}),(0,W.jsx)(`div`,{className:`space-y-4`,children:(0,W.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,W.jsx)(S,{htmlFor:`target-deposit-select`,children:`Target Deposit`}),(0,W.jsxs)(E,{value:s,onValueChange:e=>c(e),children:[(0,W.jsx)(y,{className:`min-w-[220px]`,children:(0,W.jsx)(p,{id:`target-deposit-select`,placeholder:f.length?`Select deposit`:`No open deposits`})}),(0,W.jsx)(ee,{children:f.map(e=>(0,W.jsxs)(T,{value:e.id,children:[e.id,` (`,e.currency,`)`]},e.id))})]})]})}),(0,W.jsx)(h,{children:(0,W.jsx)(D,{variant:`secondary`,disabled:!s||u,onClick:_,children:u?`Reassigning…`:`Reassign`})})]})]})}function ie(e,t){let{getId:n,getChargeId:r,getAmount:i}=t,a=new Map;for(let t of e){let e=r(t);if(!e)continue;let n=a.get(e)??[];n.push(t),a.has(e)||a.set(e,n)}let o=new Set;for(let[,e]of a)if(e.length>1){let t=[...e].sort((e,t)=>Math.abs(i(t))-Math.abs(i(e)));for(let e=1;e<t.length;e++)o.add(n(t[e]))}return o}var ae={[s.Eur]:`eur`,[s.Gbp]:`gbp`,[s.Cad]:`cad`,[s.Jpy]:`jpy`,[s.Aud]:`aud`,[s.Sek]:`sek`,[s.Usd]:`usd`};function oe({depositId:e,enableReassign:t=!1,refetch:n}){let{userContext:r}=(0,U.useContext)(te),[i,o]=(0,U.useState)([{id:`date`,desc:!1}]),[{data:l,fetching:d}]=a({query:u,variables:{depositId:e}}),f=(0,U.useMemo)(()=>{if(!l?.deposit?.metadata.transactions)return[];let e=l.deposit.metadata.transactions.map(e=>A(c,e)),t=ie(e,{getId:e=>e.id,getChargeId:e=>e.chargeId,getAmount:e=>Number(e.amount.raw??0)}),n=[...e].sort((e,t)=>(e.eventDate?new Date(e.eventDate).getTime():0)-(t.eventDate?new Date(t.eventDate).getTime():0)),i=0,a=0,o=0;return n.map(e=>{let n=null,c=ae[e.amount.currency];c&&(n=e.debitExchangeRates?.[c]??e.eventExchangeRates?.[c]??null);let l=Number(e.amount.raw),u=l*(n??1),d=r?.context.defaultLocalCurrency??s.Ils,f=t.has(e.id);return f?a+=l:(i+=l,o+=u),{...e,cumulativeBalance:i,localCumulativeBalance:o,localAmount:u,localCurrency:d,totalInterest:a,isInterest:f}})},[l?.deposit,r]),p=(0,U.useMemo)(()=>{let i=r?.context.defaultLocalCurrency??s.Ils,a=l?.deposit?.currency&&l.deposit.currency===i?Q.filter(e=>e.id!==`amount`&&e.id!==`cumulativeBalance`):Q,o=t?[{id:`actions`,header:`Actions`,cell:({row:t})=>(0,W.jsx)(re,{depositId:e,chargeId:t.original.chargeId,refetch:n})}]:[];return[...a,...o]},[t,e,n,l?.deposit?.currency,r?.context.defaultLocalCurrency]),m=M({data:f,columns:p,getCoreRowModel:B(),onSortingChange:o,getSortedRowModel:P(),state:{sorting:i}});return d?(0,W.jsx)(`div`,{className:`flex h-64 w-full items-center justify-center`,children:(0,W.jsx)(_,{className:`size-10 animate-spin`})}):(0,W.jsxs)(z,{children:[(0,W.jsx)(j,{children:m.getHeaderGroups().map(e=>(0,W.jsx)(I,{children:e.headers.map(e=>(0,W.jsx)(N,{colSpan:e.colSpan,children:e.isPlaceholder?null:R(e.column.columnDef.header,e.getContext())},e.id))},e.id))}),(0,W.jsx)(F,{children:m.getRowModel().rows?.length?m.getRowModel().rows.map(e=>(0,W.jsx)(I,{children:e.getVisibleCells().map(e=>(0,W.jsx)(L,{children:R(e.column.columnDef.cell,e.getContext())},e.id))},e.id)):(0,W.jsx)(I,{children:(0,W.jsx)(L,{colSpan:p.length,className:`h-24 text-center`,children:`No transactions in this deposit.`})})})]})}export{$ as n,oe as t};