@accounter/client
Version:
Accounter client application
1 lines • 11.1 kB
JavaScript
import{s as e}from"./dist-C51EwTaa.js";import{i as t,o as n}from"./utils-DdVdMk8X.js";import{Lo as r,or as i}from"./error-handling-Dpfd9svJ.js";import{i as a,n as o}from"./routes-DUvpW9-n.js";import{ft as s}from"./select-CrsvQyhZ.js";import{t as c}from"./arrow-up-down-BcUE5_dQ.js";import{t as l}from"./funnel-BFbxpUGW.js";import{t as u}from"./button-Dzp2INW0.js";import{B as d,F as f,K as p,L as m,Lt as h,P as g,R as _,U as v,Y as ee,a as y,c as b,i as x,m as te,n as S,o as C,p as w,r as T,s as E,t as D,u as O,wt as k,z as A}from"./table--bF0wbxq.js";import{t as j}from"./sub-BIcSj2Zu.js";import{t as M}from"./MultiSelect-HTEIN3wg.js";import{Bt as N,Er as P,It as F,Nt as I,P as L,T as R,cn as z,cr as B,dr as V,on as H,or as U,sr as W,un as G,vn as K,yt as q}from"./index-CL8-JoMZ.js";import{t as J}from"./use-url-query-BCNbSvLg.js";import{t as Y}from"./page-layout-DoLDsSrs.js";var X=e(n(),1),Z=e(k(),1),Q=t();function ne({filter:e,setFilter:t,closeModal:n}){let{userContext:r}=(0,X.useContext)(p),i=v({defaultValues:{ownerIDs:r?.context.adminBusinessId?[r.context.adminBusinessId]:void 0,toDate:h(new Date,`yyyy-MM-dd`),fromDate:h(j(new Date,{years:1}),`yyyy-MM-dd`),...e}}),{control:a,handleSubmit:o}=i,{selectableFinancialEntities:s,fetching:c}=I(),l=e=>{t(e),n()};function u(){t({}),n()}return(0,Q.jsxs)(Q.Fragment,{children:[c?(0,Q.jsx)(`div`,{children:`Loading...`}):(0,Q.jsx)(`div`,{}),(0,Q.jsx)(g,{...i,children:(0,Q.jsxs)(`form`,{onSubmit:o(l),children:[(0,Q.jsxs)(G,{cols:2,children:[(0,Q.jsx)(m,{name:`ownerIDs`,control:a,defaultValue:e.ownerIDs,render:({field:e,fieldState:t})=>(0,Q.jsxs)(_,{children:[(0,Q.jsx)(A,{children:`Owners`}),(0,Q.jsx)(f,{children:(0,Q.jsx)(M,{...e,data:s,value:e.value??[],disabled:c,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,error:t.error?.message,withinPortal:!0})}),(0,Q.jsx)(d,{})]})}),(0,Q.jsx)(m,{name:`businessIDs`,control:a,defaultValue:e.businessIDs,render:({field:e,fieldState:t})=>(0,Q.jsxs)(_,{children:[(0,Q.jsx)(A,{children:`Financial Entities`}),(0,Q.jsx)(f,{children:(0,Q.jsx)(M,{...e,data:s,value:e.value??[],disabled:c,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,error:t.error?.message,withinPortal:!0})}),(0,Q.jsx)(d,{})]})}),(0,Q.jsx)(m,{name:`fromDate`,control:a,defaultValue:e.fromDate,rules:{pattern:{value:P,message:`Date must be in format yyyy-mm-dd`}},render:({field:e,fieldState:t})=>(0,Q.jsxs)(_,{children:[(0,Q.jsx)(A,{htmlFor:`documents-from-date`,children:`From Date`}),(0,Q.jsx)(f,{children:(0,Q.jsx)(q,{id:`documents-from-date`,onChange:t=>{t!==e.value&&e.onChange(t)},value:e.value??void 0,"aria-invalid":!!t.error})}),(0,Q.jsx)(d,{})]})}),(0,Q.jsx)(m,{name:`toDate`,control:a,defaultValue:e.toDate,rules:{pattern:{value:P,message:`Date must be in format yyyy-mm-dd`}},render:({field:e,fieldState:t})=>(0,Q.jsxs)(_,{children:[(0,Q.jsx)(A,{htmlFor:`documents-to-date`,children:`To Date`}),(0,Q.jsx)(f,{children:(0,Q.jsx)(q,{id:`documents-to-date`,onChange:t=>{t!==e.value&&e.onChange(t)},value:e.value??void 0,"aria-invalid":!!t.error})}),(0,Q.jsx)(d,{})]})}),(0,Q.jsx)(m,{name:`unmatched`,control:a,render:({field:t})=>(0,Q.jsxs)(_,{className:`flex flex-row items-center justify-between rounded-lg border p-3 shadow-sm`,children:[(0,Q.jsx)(`div`,{className:`space-y-0.5`,children:(0,Q.jsx)(A,{children:`Unmatched only`})}),(0,Q.jsx)(f,{children:(0,Q.jsx)(F,{defaultChecked:e.unmatched??!1,onCheckedChange:t.onChange})})]})})]}),(0,Q.jsxs)(`div`,{className:`flex justify-center mt-5 gap-3`,children:[(0,Q.jsx)(`button`,{type:`submit`,disabled:c,className:`text-white bg-indigo-500 border-0 py-2 px-8 focus:outline-hidden hover:bg-indigo-600 rounded-sm text-lg`,children:`Filter`}),(0,Q.jsx)(`button`,{type:`button`,className:`text-white bg-orange-500 border-0 py-2 px-8 focus:outline-hidden hover:bg-orange-600 rounded-sm text-lg`,onClick:u,children:`Clear`}),(0,Q.jsx)(`button`,{type:`button`,className:`text-white bg-rose-500 border-0 py-2 px-8 focus:outline-hidden hover:bg-rose-600 rounded-sm text-lg`,onClick:n,children:`Cancel`})]})]})})]})}function re({filter:e={},setFilter:t,initiallyOpened:n=!1}){let[r,i]=(0,X.useState)(n),[s,c]=(0,X.useState)(!a(e)),{get:d,set:f}=J();return(0,X.useEffect)(()=>{let t=o(e);t!==d(`documentsFilters`)&&f(`documentsFilters`,t)},[e,d,f]),(0,Q.jsxs)(`div`,{className:`flex flex-row gap-5 items-center`,children:[(0,Q.jsx)(L,{opened:r,onClose:()=>i(!1),content:(0,Q.jsx)(ne,{filter:e,setFilter:(0,X.useCallback)(n=>{(0,Z.default)(n,e)||(t(n),c(!a(n)))},[e,t]),closeModal:()=>i(!1)}),modalSize:`xl`}),(0,Q.jsx)(K,{inline:!0,size:16,disabled:!s,children:(0,Q.jsx)(u,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>i(!0),children:(0,Q.jsx)(l,{className:`size-5`})})})]})}var $=[{accessorKey:`__typename`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`Type`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>{let{__typename:t}=e.original;return(0,Q.jsx)(`div`,{className:`text-left font-medium`,children:t})}},{accessorKey:`image`,header:()=>(0,Q.jsx)(`div`,{className:`text-left`,children:`Image`}),cell:({row:e})=>{let{image:t}=e.original;return(0,Q.jsx)(`div`,{className:`text-left font-medium`,children:t?(0,Q.jsx)(`img`,{alt:`missing img`,src:t?.toString(),height:80,width:80}):`No image`})}},{accessorKey:`file`,header:()=>(0,Q.jsx)(`div`,{className:`text-left`,children:`File`}),cell:({row:e})=>{let{file:t}=e.original;return(0,Q.jsx)(`div`,{className:`text-left font-medium`,children:t&&(0,Q.jsx)(u,{variant:`outline`,size:`sm`,asChild:!0,children:(0,Q.jsx)(`a`,{target:`_blank`,rel:`noreferrer`,href:t?.toString(),children:`Open`})})})}},{accessorKey:`date`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`Date`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>`date`in e.original&&e.original.date?(0,Q.jsx)(`div`,{className:`text-left font-medium`,children:h(new Date(e.original.date),`dd/MM/yy`)}):null},{accessorKey:`serialNumber`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`Serial Number`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>`serialNumber`in e.original&&e.original.serialNumber?(0,Q.jsx)(`div`,{className:`text-left font-medium`,children:e.original.serialNumber}):null},{accessorKey:`vat.raw`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`VAT`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>`vat`in e.original&&e.original.vat?.formatted?(0,Q.jsx)(`div`,{className:`text-left font-medium whitespace-nowrap`,children:e.original.vat.formatted}):null},{accessorKey:`amount.raw`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`Amount`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>`amount`in e.original&&e.original.amount?.formatted?(0,Q.jsx)(`div`,{className:`text-left font-medium whitespace-nowrap`,children:e.original.amount.formatted}):null},{accessorKey:`creditor.name`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`Creditor`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>`creditor`in e.original&&e.original.creditor?.name?(0,Q.jsx)(`div`,{className:`text-left font-medium whitespace-nowrap`,children:e.original.creditor.name}):null},{accessorKey:`debtor.name`,header:({column:e})=>(0,Q.jsxs)(u,{variant:`ghost`,onClick:()=>e.toggleSorting(e.getIsSorted()===`asc`),children:[(0,Q.jsx)(`div`,{className:`text-left`,children:`Debtor`}),(0,Q.jsx)(c,{className:`ml-2 h-4 w-4`})]}),cell:({row:e})=>`debtor`in e.original&&e.original.debtor?.name?(0,Q.jsx)(`div`,{className:`text-left font-medium whitespace-nowrap`,children:e.original.debtor.name}):null},{accessorKey:`charge.transactions[0].id`,header:()=>(0,Q.jsx)(`div`,{className:`text-left`,children:`Related Transaction`}),cell:({row:e})=>e.original.charge?.transactions?.[0]?.id?(0,Q.jsx)(H,{items:e.original.charge?.transactions??[],columns:[{title:`Transaction Amount`,value:e=>e?.amount.formatted},{title:`Transaction Created At`,value:e=>e?.eventDate?h(new Date(e.eventDate),`dd/MM/yy`):null},{title:`Transaction Effective Date`,value:e=>e?.effectiveDate?h(new Date(e.effectiveDate),`dd/MM/yy`):null},{title:`Transaction Description`,value:e=>e?.sourceDescription}]}):`No Related Transaction`}],ie=()=>{let[e,t]=(0,X.useState)(null),[n,a]=(0,X.useState)(!1),{get:o}=J(),c=o(`documentsFilters`),l=(0,X.useMemo)(()=>{if(c)try{return JSON.parse(decodeURIComponent(c))}catch{return}},[c]),[d,f]=(0,X.useState)(l),[p,m]=(0,X.useState)([]),[h,g]=(0,X.useState)({}),{setFiltersContext:_}=(0,X.useContext)(z),[{data:v,fetching:k},A]=r({query:i,variables:{filters:d??{}},pause:!0});(0,X.useEffect)(()=>{d&&A()},[d,A]);let j=b({data:v?.documentsByFilters??[],columns:$,getCoreRowModel:O(),getPaginationRowModel:w(),onSortingChange:m,getSortedRowModel:te(),onColumnVisibilityChange:g,state:{sorting:p,columnVisibility:h}}),M=j.getState().pagination.pageIndex;return(0,X.useEffect)(()=>{_((0,Q.jsxs)(`div`,{className:`flex flex-row gap-x-5`,children:[(0,Q.jsx)(N,{table:j}),(0,Q.jsx)(re,{filter:d,setFilter:f,initiallyOpened:!d})]}))},[j,k,d,_,f,l,M]),(0,Q.jsx)(Y,{title:`Documents`,description:`All documents`,headerActions:(0,Q.jsxs)(`div`,{className:`flex items-center py-4 gap-4`,children:[(0,Q.jsxs)(U,{children:[(0,Q.jsx)(V,{asChild:!0,children:(0,Q.jsx)(u,{className:`ml-auto`,children:`Columns`})}),(0,Q.jsx)(B,{align:`end`,children:j.getAllColumns().filter(e=>e.getCanHide()).map(e=>(0,Q.jsx)(W,{className:`capitalize`,checked:e.getIsVisible(),onCheckedChange:t=>e.toggleVisibility(!!t),children:e.id},e.id))})]}),(0,Q.jsx)(u,{onClick:()=>a(!0),children:`Upload Documents`})]}),children:k?(0,Q.jsx)(s,{className:`h-10 w-10 animate-spin mr-2 self-center`}):(0,Q.jsxs)(Q.Fragment,{children:[(0,Q.jsx)(R,{open:n,onOpenChange:a,onChange:A}),e&&(0,Q.jsx)(L,{modalSize:`45%`,content:(0,Q.jsx)(ee,{src:e}),opened:!!e,onClose:()=>t(null)}),(0,Q.jsxs)(D,{children:[(0,Q.jsx)(y,{children:j.getHeaderGroups().map(e=>(0,Q.jsx)(C,{children:e.headers.map(e=>(0,Q.jsx)(x,{children:e.isPlaceholder?null:E(e.column.columnDef.header,e.getContext())},e.id))},e.id))}),(0,Q.jsx)(S,{children:j.getRowModel().rows?.length?j.getRowModel().rows.map(e=>(0,Q.jsx)(C,{"data-state":e.getIsSelected()&&`selected`,children:e.getVisibleCells().map(e=>(0,Q.jsx)(T,{children:E(e.column.columnDef.cell,e.getContext())},e.id))},e.id)):(0,Q.jsx)(C,{children:(0,Q.jsx)(T,{colSpan:$.length,className:`h-24 text-center`,children:`No results.`})})})]})]})})};export{ie as DocumentsReport};