UNPKG

@accounter/client

Version:
1 lines • 10 kB
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,Ka as a,Lo as o,Mn as s,Rn as c,r as l,t as u}from"./error-handling-Dpfd9svJ.js";import{a as d,c as f,d as p,dt as m,f as ee,ht as h,i as g,l as te,mt as ne,n as _,p as v,r as y,s as b,t as x}from"./select-CrsvQyhZ.js";import{t as S}from"./bank-deposits-BPOCIHu5.js";import{t as C}from"./pencil-i7-vyfzU.js";import{t as w}from"./button-Dzp2INW0.js";import{B as T,D as E,Et as re,L as D,N as O,Ot as k,P as A,R as j,Tt as M,U as N,a as P,c as F,d as I,h as L,i as R,k as z,kt as B,m as V,n as H,o as U,r as W,s as G,t as K,u as q,v as J,z as Y}from"./table--bF0wbxq.js";var X=e(n(),1),ie=`createDeposit`,ae=()=>{let[{fetching:e},t]=i(s);return{creating:e,createDeposit:(0,X.useCallback)(async e=>{let n=`Error creating new deposit ${e.name}`,r=`${ie}-${e.name}-${e.currency}-${e.openDate}-${e.accountId??`noAccount`}`;l.loading(`Creating deposit`,{id:r});try{let i=u(await t(e),n,r);if(i)return l.success(`Deposit created`,{id:r,description:`Deposit ${i.createDeposit.id} (${i.createDeposit.currency}) created successfully`}),i.createDeposit.id}catch(e){console.error(`${n}: ${e}`),l.error(`Error`,{id:r,description:n,duration:1e5,closeButton:!0})}return null},[t])}},oe=`updateDeposit`,se=()=>{let[{fetching:e},t]=i(a);return{updating:e,updateDeposit:(0,X.useCallback)(async e=>{let n=`Error updating deposit`,r=`${oe}-${e.id}`;l.loading(`Updating deposit…`,{id:r});try{if(u(await t(e),n,r))return l.success(`Deposit updated`,{id:r}),!0}catch(e){console.error(`${n}: ${e}`),l.error(`Error`,{id:r,description:n,duration:1e5,closeButton:!0})}return!1},[t])}},Z=t(),Q=E({name:z().min(1,`Name is required`),currency:J(Object.values(c),{error:`Currency is required`}),openDate:z().min(1,`Open date is required`)}),ce=E({name:z().min(1,`Name is required`),openDate:z().min(1,`Open date is required`),closeDate:z().optional()});function le({onSuccess:e,onClose:t}){let{creating:n,createDeposit:r}=ae(),i=N({resolver:L(Q),defaultValues:{name:``,currency:``,openDate:``}}),a=async n=>{await r({name:n.name,currency:n.currency,openDate:n.openDate})&&(e?.(),t())};return(0,Z.jsx)(A,{...i,children:(0,Z.jsxs)(`form`,{onSubmit:i.handleSubmit(a),className:`space-y-4`,children:[(0,Z.jsx)(D,{control:i.control,name:`name`,render:({field:e})=>(0,Z.jsxs)(j,{children:[(0,Z.jsx)(Y,{children:`Name`}),(0,Z.jsx)(b,{...e,placeholder:`e.g. High-Yield Savings 2025`,disabled:n}),(0,Z.jsx)(T,{})]})}),(0,Z.jsx)(D,{control:i.control,name:`currency`,render:({field:e})=>(0,Z.jsxs)(j,{children:[(0,Z.jsx)(Y,{children:`Currency`}),(0,Z.jsxs)(x,{onValueChange:e.onChange,value:e.value,disabled:n,children:[(0,Z.jsx)(g,{children:(0,Z.jsx)(d,{placeholder:`Select currency`})}),(0,Z.jsx)(_,{children:Object.values(c).map(e=>(0,Z.jsx)(y,{value:e,children:e},e))})]}),(0,Z.jsx)(T,{})]})}),(0,Z.jsx)(D,{control:i.control,name:`openDate`,render:({field:e})=>(0,Z.jsxs)(j,{children:[(0,Z.jsx)(Y,{children:`Open Date`}),(0,Z.jsx)(b,{...e,type:`date`,disabled:n}),(0,Z.jsx)(T,{})]})}),(0,Z.jsxs)(p,{children:[(0,Z.jsx)(w,{type:`button`,variant:`outline`,onClick:t,disabled:n,children:`Cancel`}),(0,Z.jsx)(w,{type:`submit`,disabled:n,children:n?`Creating…`:`Create Deposit`})]})]})})}function ue({deposit:e,onSuccess:t,onClose:n}){let{updating:r,updateDeposit:i}=se(),a=N({resolver:L(ce),defaultValues:{name:e.name,openDate:e.openDate??``,closeDate:e.closeDate??``}});(0,X.useEffect)(()=>{a.reset({name:e.name,openDate:e.openDate??``,closeDate:e.closeDate??``})},[e,a]);let o=async r=>{await i({id:e.id,name:r.name,openDate:r.openDate,closeDate:r.closeDate||null})&&(t?.(),n())},s=async()=>{let r=B(new Date);a.setValue(`closeDate`,r),await i({id:e.id,name:a.getValues(`name`),openDate:a.getValues(`openDate`),closeDate:r})&&(t?.(),n())},c=async()=>{a.setValue(`closeDate`,``),await i({id:e.id,name:a.getValues(`name`),openDate:a.getValues(`openDate`),closeDate:null})&&(t?.(),n())};return(0,Z.jsx)(A,{...a,children:(0,Z.jsxs)(`form`,{onSubmit:a.handleSubmit(o),className:`space-y-4`,children:[(0,Z.jsx)(D,{control:a.control,name:`name`,render:({field:e})=>(0,Z.jsxs)(j,{children:[(0,Z.jsx)(Y,{children:`Name`}),(0,Z.jsx)(b,{...e,disabled:r}),(0,Z.jsx)(T,{})]})}),(0,Z.jsxs)(`div`,{className:`grid grid-cols-2 gap-4`,children:[(0,Z.jsx)(D,{control:a.control,name:`openDate`,render:({field:e})=>(0,Z.jsxs)(j,{children:[(0,Z.jsx)(Y,{children:`Open Date`}),(0,Z.jsx)(b,{...e,type:`date`,disabled:r}),(0,Z.jsx)(T,{})]})}),(0,Z.jsx)(D,{control:a.control,name:`closeDate`,render:({field:e})=>(0,Z.jsxs)(j,{children:[(0,Z.jsx)(Y,{children:`Close Date`}),(0,Z.jsx)(b,{...e,type:`date`,disabled:r}),(0,Z.jsx)(T,{})]})})]}),(0,Z.jsxs)(`div`,{className:`flex items-center justify-between pt-2 border-t`,children:[e.isOpen?(0,Z.jsx)(w,{type:`button`,variant:`destructive`,size:`sm`,onClick:s,disabled:r,children:`Close Deposit`}):(0,Z.jsx)(w,{type:`button`,variant:`outline`,size:`sm`,onClick:c,disabled:r,children:`Re-open Deposit`}),(0,Z.jsxs)(`div`,{className:`flex gap-2`,children:[(0,Z.jsx)(w,{type:`button`,variant:`outline`,onClick:n,disabled:r,children:`Cancel`}),(0,Z.jsx)(w,{type:`submit`,disabled:r,children:r?`Saving…`:`Save Changes`})]})]})]})})}function $({open:e,onOpenChange:t,deposit:n,onSuccess:r}){let i=!!n;return(0,Z.jsx)(f,{open:e,onOpenChange:t,children:(0,Z.jsxs)(te,{className:`max-w-md`,children:[(0,Z.jsx)(ee,{children:(0,Z.jsx)(v,{children:i?`Edit Deposit`:`New Deposit`})}),i?(0,Z.jsx)(ue,{deposit:n,onSuccess:r,onClose:()=>t(!1)}):(0,Z.jsx)(le,{onSuccess:r,onClose:()=>t(!1)})]})})}function de(){let[{data:e,fetching:t},n]=o({query:r}),[i,a]=(0,X.useState)([{id:`openDate`,desc:!1}]),[s,c]=(0,X.useState)(!1),[l,u]=(0,X.useState)(null),d=(0,X.useMemo)(()=>(e?.allDeposits??[]).map(e=>({id:e.id,name:e.name,currency:e.currency??null,openDate:e.openDate??null,closeDate:e.closeDate??null,isOpen:e.isOpen,currentBalanceRaw:e.metadata.currentBalance?.raw??0,currentBalanceFormatted:e.metadata.currentBalance?.formatted??``,totalDepositRaw:e.metadata.totalDeposit?.raw??0,totalDepositFormatted:e.metadata.totalDeposit?.formatted??``,totalInterestRaw:e.metadata.totalInterest?.raw??0,totalInterestFormatted:e.metadata.totalInterest?.formatted??``})),[e]),f=(0,X.useRef)([{id:`expander`,header:()=>null,cell:({row:e})=>(0,Z.jsx)(w,{variant:`ghost`,size:`icon`,onClick:()=>e.toggleExpanded(),"aria-label":e.getIsExpanded()?`Collapse`:`Expand`,children:e.getIsExpanded()?(0,Z.jsx)(h,{}):(0,Z.jsx)(ne,{})}),enableSorting:!1},{accessorKey:`name`,header:`Deposit Name`,cell:e=>(0,Z.jsx)(`span`,{className:`font-mono text-xs`,children:e.getValue()})},{accessorKey:`currency`,header:`Currency`},{accessorKey:`isOpen`,header:`Status`,cell:e=>e.getValue()?(0,Z.jsx)(O,{className:`bg-green-600 text-white`,variant:`secondary`,children:`Open`}):(0,Z.jsx)(O,{variant:`secondary`,children:`Closed`}),sortingFn:(e,t)=>Number(e.original.isOpen)-Number(t.original.isOpen)},{accessorKey:`openDate`,header:`Open Date`,cell:e=>(0,Z.jsx)(`span`,{children:e.getValue()})},{accessorKey:`closeDate`,header:`Close Date`,cell:e=>(0,Z.jsx)(`span`,{children:e.getValue()??`-`}),sortingFn:(e,t)=>{let n=e.original.closeDate??``,r=t.original.closeDate??``;return n.localeCompare(r)}},{id:`totalDeposit`,header:`Total Deposit`,accessorFn:e=>e.totalDepositRaw,cell:e=>(0,Z.jsx)(`span`,{className:`tabular-nums`,children:e.row.original.totalDepositFormatted}),sortingFn:(e,t)=>e.original.totalDepositRaw-t.original.totalDepositRaw},{id:`currentBalance`,header:`Current Balance`,accessorFn:e=>e.currentBalanceRaw,cell:e=>(0,Z.jsx)(`span`,{className:`tabular-nums`,children:e.row.original.currentBalanceFormatted}),sortingFn:(e,t)=>e.original.currentBalanceRaw-t.original.currentBalanceRaw},{id:`totalInterest`,header:`Total Interest`,accessorFn:e=>e.totalInterestRaw,cell:e=>(0,Z.jsx)(`span`,{className:`tabular-nums`,children:e.row.original.totalInterestFormatted}),sortingFn:(e,t)=>e.original.totalInterestRaw-t.original.totalInterestRaw},{id:`actions`,header:()=>null,cell:({row:e})=>(0,Z.jsxs)(M,{children:[(0,Z.jsx)(k,{asChild:!0,children:(0,Z.jsx)(w,{variant:`ghost`,size:`icon`,onClick:t=>{t.stopPropagation(),u(e.original)},"aria-label":`Edit deposit`,children:(0,Z.jsx)(C,{className:`h-4 w-4`})})}),(0,Z.jsx)(re,{children:`Edit deposit`})]}),enableSorting:!1}]).current,p=F({data:d,columns:f,state:{sorting:i},onSortingChange:a,getCoreRowModel:q(),getSortedRowModel:V(),getExpandedRowModel:I(),getRowCanExpand:()=>!0});return(0,Z.jsxs)(`div`,{className:`max-w-[95vw]`,children:[(0,Z.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,Z.jsx)(`h1`,{className:`text-2xl font-semibold`,children:`Bank Deposits`}),(0,Z.jsxs)(w,{onClick:()=>c(!0),children:[(0,Z.jsx)(m,{className:`mr-2 h-4 w-4`}),`New Deposit`]})]}),(0,Z.jsx)(`div`,{className:`mt-6 overflow-hidden rounded-md border`,children:(0,Z.jsxs)(K,{children:[(0,Z.jsx)(P,{children:p.getHeaderGroups().map(e=>(0,Z.jsx)(U,{children:e.headers.map(e=>(0,Z.jsx)(R,{colSpan:e.colSpan,children:e.isPlaceholder?null:G(e.column.columnDef.header,e.getContext())},e.id))},e.id))}),(0,Z.jsx)(H,{children:t?(0,Z.jsx)(U,{children:(0,Z.jsx)(W,{colSpan:f.length,className:`h-24 text-center`,children:`Loading...`})}):p.getRowModel().rows?.length?p.getRowModel().rows.map(e=>(0,Z.jsxs)(Z.Fragment,{children:[(0,Z.jsx)(U,{"data-state":e.getIsSelected()&&`selected`,children:e.getVisibleCells().map(e=>(0,Z.jsx)(W,{children:G(e.column.columnDef.cell,e.getContext())},e.id))},e.id),e.getIsExpanded()?(0,Z.jsx)(U,{children:(0,Z.jsx)(W,{colSpan:f.length,children:(0,Z.jsx)(S,{depositId:e.original.id,enableReassign:!0,refetch:n})})}):null]})):(0,Z.jsx)(U,{children:(0,Z.jsx)(W,{colSpan:f.length,className:`h-24 text-center`,children:`No results.`})})})]})}),(0,Z.jsx)($,{open:s,onOpenChange:c,onSuccess:()=>n({requestPolicy:`network-only`})}),(0,Z.jsx)($,{open:!!l,onOpenChange:e=>{e||u(null)},deposit:l??void 0,onSuccess:()=>n({requestPolicy:`network-only`})})]})}export{de as DepositsScreen};