@accounter/client
Version:
Accounter client application
1 lines • 24 kB
JavaScript
import{s as e}from"./dist-C51EwTaa.js";import{i as t,o as n}from"./utils-DdVdMk8X.js";import{Ao as r,Do as i,Eo as a,Jt as o,Lo as s,Mo as c,No as l,Oo as u,Or as d,Rn as f,To as p,jo as m,ko as h,r as g,wo as ee}from"./error-handling-Dpfd9svJ.js";import{n as te,s as ne,t as re}from"./routes-DUvpW9-n.js";import{_t as _,ft as ie,ht as v,pt as y}from"./select-CrsvQyhZ.js";import{n as b,t as x}from"./charges-table-CNFGsVad.js";import{t as ae}from"./funnel-BFbxpUGW.js";import{t as S}from"./button-Dzp2INW0.js";import{K as C,Lt as w,U as oe,V as se,W as T,a as ce,c as le,d as ue,i as de,l as E,m as D,n as O,o as k,r as A,s as j,t as M,u as N,wt as fe}from"./table--bF0wbxq.js";import{Ft as pe,N as me,P as he,Pr as P,Sn as F,Tt as ge,Ut as I,Wt as L,_r as _e,cn as ve,ct as ye,di as R,dt as be,fn as z,gr as B,hr as V,ni as H,nn as U,ri as W,xr as G}from"./index-CL8-JoMZ.js";import{t as K}from"./use-url-query-BCNbSvLg.js";import{t as xe}from"./page-layout-DoLDsSrs.js";import{n as Se}from"./charges-filters-CENHQ5jv.js";var Ce=_(`chart-column`,[[`path`,{d:`M3 3v16a2 2 0 0 0 2 2h16`,key:`c24i48`}],[`path`,{d:`M18 17V9`,key:`2bz60n`}],[`path`,{d:`M13 17V5`,key:`1frdt8`}],[`path`,{d:`M8 17v-3`,key:`17ska0`}]]),we=_(`file-digit`,[[`path`,{d:`M4 12V4a2 2 0 0 1 2-2h8a2.4 2.4 0 0 1 1.706.706l3.588 3.588A2.4 2.4 0 0 1 20 8v12a2 2 0 0 1-2 2`,key:`jrl274`}],[`path`,{d:`M14 2v5a1 1 0 0 0 1 1h5`,key:`wfsgrz`}],[`path`,{d:`M10 16h2v6`,key:`1bxocy`}],[`path`,{d:`M10 22h4`,key:`ceow96`}],[`rect`,{x:`2`,y:`16`,width:`4`,height:`6`,rx:`2`,key:`r45zd0`}]]),q=e(n(),1),J=t(),Te=({data:e,toggleMergeCharge:t,mergeSelectedCharges:n})=>{let r=T(a,e),[i,o]=(0,q.useState)(!0);return(0,J.jsxs)(P,{className:`p-6`,children:[(0,J.jsx)(`div`,{className:`flex items-center justify-between`,children:(0,J.jsxs)(`h2`,{className:`text-lg font-semibold flex items-center gap-2`,children:[(0,J.jsx)(S,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>o(e=>!e),disabled:!r||r.businessTrips.length===0,children:i?(0,J.jsx)(W,{className:`size-5`}):(0,J.jsx)(H,{className:`size-5`})}),`Business Trips`]})}),i&&r&&(0,J.jsx)(x,{data:r.businessTrips,isAllOpened:!1,toggleMergeCharge:t,mergeSelectedCharges:n})]})};function Y(e){switch(e){case`C`:case`M`:return`Self Invoice`;case`H`:return`Single Doc By Law`;case`I`:return`Palestinian Customer`;case`K`:return`Petty Cash`;case`L1`:return`Unidentified Customer`;case`L2`:return`Unidentified Zero or Exempt`;case`P`:return`Palestinian Supplier`;case`R`:return`Import`;case`S1`:case`T`:return`Regular`;case`S2`:return`Zero or Exempt`;case`Y`:return`Export`;default:return`Unknown`}}var Ee=e=>{let t=e.reduce((e,t)=>(e[t.recordType]||={recordType:t.recordType,count:0,vatTotal:0,totalBeforeVat:0},e[t.recordType].count++,e[t.recordType].vatTotal+=t.roundedLocalVatAfterDeduction?.raw??0,e[t.recordType].totalBeforeVat+=t.taxReducedLocalAmount?.raw??0,e),{});return Object.values(t)},De=({records:e})=>{let t=(0,q.useMemo)(()=>Ee(e??[]),[e]);return(0,J.jsx)(`div`,{className:`overflow-x-auto`,children:(0,J.jsxs)(`table`,{className:`w-full`,children:[(0,J.jsx)(`thead`,{children:(0,J.jsxs)(`tr`,{className:`border-b border-border text-left`,children:[(0,J.jsx)(`th`,{className:`pb-3 text-sm font-medium text-muted-foreground`,children:`Record Type`}),(0,J.jsx)(`th`,{className:`pb-3 text-sm font-medium text-muted-foreground text-right`,children:`Count`}),(0,J.jsx)(`th`,{className:`pb-3 text-sm font-medium text-muted-foreground text-right`,children:`Total Before VAT`}),(0,J.jsx)(`th`,{className:`pb-3 text-sm font-medium text-muted-foreground text-right`,children:`VAT Total`})]})}),(0,J.jsx)(`tbody`,{children:t.map(e=>(0,J.jsxs)(`tr`,{className:`border-b border-border/50`,children:[(0,J.jsxs)(`td`,{className:`py-3 text-sm font-medium`,children:[Y(e.recordType),` (`,e.recordType,`)`]}),(0,J.jsx)(`td`,{className:`py-3 text-sm text-right`,children:e.count}),(0,J.jsx)(`td`,{className:`py-3 text-sm text-right`,children:G(e.totalBeforeVat,f.Ils)}),(0,J.jsx)(`td`,{className:`py-3 text-sm text-right`,children:G(e.vatTotal,f.Ils)})]},e.recordType))})]})})};function Oe({data:e}){let{chargeId:t,chargeAccountantStatus:n}=T(p,e);return(0,J.jsx)(`td`,{children:(0,J.jsx)(be,{value:n??void 0,chargeId:t})})}var X=E(),Z=[X.accessor(e=>T(u,e.data).recordType,{id:`recordType`,header:`Record Type`,cell:e=>{let t=e.getValue();return(0,J.jsx)(`p`,{className:`whitespace-wrap`,children:`${Y(t)} (${t})`})}}),X.accessor(e=>T(u,e.data).business?.name??``,{id:`business`,header:`Business`,cell:e=>{let t=T(u,e.row.original.data);return(0,J.jsxs)(`div`,{className:`flex flex-col gap-1`,children:[t.business?.id?(0,J.jsx)(ne,{to:re.BUSINESSES.DETAIL(t.business.id),target:`_blank`,rel:`noreferrer`,onClick:e=>e.stopPropagation(),className:`inline-flex items-center font-semibold`,children:t.business.name}):(0,J.jsx)(`span`,{children:t.business?.name}),t.vatNumber&&(0,J.jsx)(`span`,{className:`text-[10px] text-gray-500`,children:t.vatNumber})]})}}),X.display({id:`invoice`,header:`Invoice`,cell:e=>{let t=T(u,e.row.original.data);return t.image?(0,J.jsx)(`a`,{href:t.image,target:`_blank`,rel:`noreferrer`,children:(0,J.jsx)(`img`,{alt:`missing img`,src:t.image,height:80,width:80})}):null}}),X.accessor(e=>T(u,e.data).documentSerial??``,{id:`documentSerial`,header:`Invoice Serial#`,cell:e=>{let t=T(u,e.row.original.data);return(0,J.jsxs)(`div`,{className:`flex flex-col`,children:[(0,J.jsx)(`span`,{children:e.getValue()}),t.allocationNumber&&(0,J.jsxs)(`span`,{className:`text-xs`,children:[`(`,t.allocationNumber,`)`]})]})}}),X.accessor(e=>T(u,e.data).documentDate??``,{id:`documentDate`,header:`Invoice Date`,cell:e=>e.getValue()}),X.accessor(e=>T(u,e.data).chargeDate??``,{id:`chargeDate`,header:`Transaction Date`,cell:e=>e.getValue()}),X.accessor(e=>T(u,e.data).amount.raw??0,{id:`amount`,header:`Amount`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).amount.formatted})}),X.accessor(e=>T(u,e.data).localAmount?.raw??0,{id:`localAmount`,header:`Amount ₪`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).localAmount?.formatted})}),X.accessor(e=>T(u,e.data).localVat?.raw??0,{id:`localVat`,header:`VAT`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).localVat?.formatted})}),X.accessor(e=>T(u,e.data).localVatAfterDeduction?.raw??0,{id:`localVatAfterDeduction`,header:`VAT ₪`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).localVatAfterDeduction?.formatted})}),X.accessor(e=>T(u,e.data).foreignVatAfterDeduction?.raw??0,{id:`foreignVatAfterDeduction`,header:`Actual VAT`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).foreignVatAfterDeduction?.formatted})}),X.accessor(e=>T(u,e.data).roundedLocalVatAfterDeduction?.raw??0,{id:`roundedLocalVatAfterDeduction`,header:`Rounded VAT`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).roundedLocalVatAfterDeduction?.formatted})}),X.accessor(e=>e.cumulativeVat,{id:`cumulativeVat`,header:`Cumulative VAT`,cell:e=>(0,J.jsxs)(`span`,{className:`whitespace-nowrap`,children:[`₪ `,V(e.getValue(),0)]})}),X.accessor(e=>T(u,e.data).taxReducedLocalAmount?.raw??0,{id:`taxReducedLocalAmount`,header:`Amount without VAT ₪`,cell:e=>(0,J.jsx)(`span`,{className:`whitespace-nowrap`,children:T(u,e.row.original.data).taxReducedLocalAmount?.formatted})}),X.accessor(e=>e.cumulativeAmount,{id:`cumulativeAmount`,header:`Cumulative Amount without VAT ₪`,cell:e=>(0,J.jsxs)(`span`,{className:`whitespace-nowrap`,children:[`₪ `,V(e.getValue(),0)]})}),X.display({id:`accountantApproval`,header:`Accountant Approval`,cell:e=>(0,J.jsx)(Oe,{data:T(u,e.row.original.data)})}),X.display({id:`actions`,header:`Edit`,cell:e=>{let t=T(u,e.row.original.data);return(0,J.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,J.jsx)(L,{toggleExpansion:()=>e.row.toggleExpanded(),isExpanded:e.row.getIsExpanded()}),(0,J.jsx)(I,{toggleMergeSelected:()=>e.row.original.toggleMergeCharge(t.chargeId),mergeSelected:e.row.original.mergeSelectedCharges.has(t.chargeId)}),(0,J.jsx)(U,{chargeId:t.chargeId})]})}})],ke=({data:e,toggleMergeCharge:t,mergeSelectedCharges:n})=>{let{expenses:r}=T(i,e)??{expenses:[]},[a,o]=(0,q.useState)(!0),[s,c]=(0,q.useState)([]),[l,d]=(0,q.useState)({}),[f,p]=(0,q.useState)({}),[m,h]=(0,q.useState)(`detailed`),g=le({data:(0,q.useMemo)(()=>{let e=0,i=0;return r.map(r=>(e+=r.taxReducedLocalAmount?.raw??0,i+=r.roundedLocalVatAfterDeduction?.raw??0,{data:r,toggleMergeCharge:t,mergeSelectedCharges:n,cumulativeVat:i,cumulativeAmount:e}))},[r,t,n]),columns:Z,getCoreRowModel:N(),onSortingChange:c,getSortedRowModel:D(),onColumnVisibilityChange:d,onExpandedChange:p,getExpandedRowModel:ue(),state:{sorting:s,columnVisibility:l,expanded:f}});return(0,J.jsxs)(P,{className:`p-6`,children:[(0,J.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,J.jsxs)(`h2`,{className:`text-lg font-semibold flex items-center gap-2`,children:[(0,J.jsx)(S,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>o(e=>!e),children:a?(0,J.jsx)(W,{className:`size-5`}):(0,J.jsx)(H,{className:`size-5`})}),`Expenses`]}),a&&(0,J.jsxs)(`div`,{className:`flex gap-2`,children:[(0,J.jsxs)(S,{variant:m===`detailed`?`default`:`outline`,size:`sm`,onClick:()=>h(`detailed`),children:[(0,J.jsx)(R,{className:`h-4 w-4 mr-2`}),`Detailed`]}),(0,J.jsxs)(S,{variant:m===`summarized`?`default`:`outline`,size:`sm`,onClick:()=>h(`summarized`),children:[(0,J.jsx)(Ce,{className:`h-4 w-4 mr-2`}),`Summarized`]})]})]}),a&&(m===`detailed`?(0,J.jsxs)(M,{children:[(0,J.jsx)(ce,{children:g.getHeaderGroups().map(e=>(0,J.jsx)(k,{children:e.headers.map(e=>(0,J.jsx)(de,{colSpan:e.colSpan,children:e.isPlaceholder?null:(0,J.jsxs)(S,{variant:`ghost`,onClick:e.column.getToggleSortingHandler(),className:`h-auto p-0 hover:bg-transparent`,children:[j(e.column.columnDef.header,e.getContext()),{asc:(0,J.jsx)(y,{className:`size-5`}),desc:(0,J.jsx)(v,{className:`size-5`})}[e.column.getIsSorted()]??null]})},e.id))},e.id))}),(0,J.jsx)(O,{children:g.getRowModel().rows?.length?g.getRowModel().rows.map(e=>{let t=T(u,e.original.data);return(0,J.jsxs)(q.Fragment,{children:[(0,J.jsx)(k,{"data-state":e.getIsSelected()&&`selected`,children:e.getVisibleCells().map(e=>(0,J.jsx)(A,{children:j(e.column.columnDef.cell,e.getContext())},e.id))}),e.getIsExpanded()&&(0,J.jsx)(k,{children:(0,J.jsx)(A,{colSpan:Z.length,children:(0,J.jsx)(F,{style:{width:`100%`},withBorder:!0,shadow:`lg`,children:(0,J.jsx)(b,{chargeID:t.chargeId,fetching:!!t})})})})]},e.id)}):(0,J.jsx)(k,{children:(0,J.jsx)(A,{colSpan:Z.length,className:`h-24 text-center`,children:`No results.`})})})]}):(0,J.jsx)(De,{records:r}))]})},Q=E(),$=[Q.accessor(e=>T(r,e.data).recordType,{id:`recordType`,header:`Record Type`,cell:e=>{let t=e.getValue();return(0,J.jsx)(`p`,{className:`whitespace-wrap`,children:`${Y(t)} (${t})`})}}),Q.accessor(e=>T(r,e.data).business?.name??``,{id:`business`,header:`Business`,cell:e=>{let t=T(r,e.row.original.data);return(0,J.jsxs)(`div`,{className:`flex flex-col gap-1`,children:[t.business?.id?(0,J.jsx)(ne,{to:re.BUSINESSES.DETAIL(t.business.id),target:`_blank`,rel:`noreferrer`,onClick:e=>e.stopPropagation(),className:`inline-flex items-center font-semibold`,children:t.business.name}):(0,J.jsx)(`span`,{children:t.business?.name}),t.vatNumber&&(0,J.jsx)(`span`,{className:`text-[10px] text-gray-500`,children:t.vatNumber})]})}}),Q.display({id:`invoice`,header:`Invoice`,cell:e=>{let t=T(r,e.row.original.data);return t.image?(0,J.jsx)(`a`,{href:t.image,target:`_blank`,rel:`noreferrer`,children:(0,J.jsx)(`img`,{alt:`missing img`,src:t.image,height:80,width:80})}):null}}),Q.accessor(e=>T(r,e.data).documentSerial??``,{id:`documentSerial`,header:`Invoice Serial#`,cell:e=>{let t=T(r,e.row.original.data);return(0,J.jsxs)(`div`,{className:`flex flex-col`,children:[(0,J.jsx)(`span`,{children:e.getValue()}),t.allocationNumber&&(0,J.jsxs)(`span`,{className:`text-xs`,children:[`(`,t.allocationNumber,`)`]})]})}}),Q.accessor(e=>T(r,e.data).documentDate??``,{id:`documentDate`,header:`Invoice Date`,cell:e=>e.getValue()}),Q.accessor(e=>T(r,e.data).chargeDate??``,{id:`chargeDate`,header:`Transaction Date`,cell:e=>e.getValue()}),Q.accessor(e=>T(r,e.data).taxReducedForeignAmount?.raw??0,{id:`amount`,header:`Amount`,cell:e=>T(r,e.row.original.data).taxReducedForeignAmount?.formatted??``}),Q.accessor(e=>T(r,e.data).taxReducedLocalAmount?.raw??0,{id:`localAmount`,header:`Amount ₪`,cell:e=>T(r,e.row.original.data).taxReducedLocalAmount?.formatted??``}),Q.accessor(e=>e.cumulativeAmount,{id:`cumulativeAmount`,header:`Cumulative Amount ₪`,cell:e=>(0,J.jsxs)(`span`,{className:`whitespace-nowrap`,children:[`₪ `,V(e.getValue(),0)]})}),Q.display({id:`accountantApproval`,header:`Accountant Approval`,cell:e=>(0,J.jsx)(Oe,{data:T(r,e.row.original.data)})}),Q.display({id:`actions`,header:`Edit`,cell:e=>{let t=T(r,e.row.original.data);return(0,J.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,J.jsx)(L,{toggleExpansion:()=>e.row.toggleExpanded(),isExpanded:e.row.getIsExpanded()}),(0,J.jsx)(I,{toggleMergeSelected:()=>e.row.original.toggleMergeCharge(t.chargeId),mergeSelected:e.row.original.mergeSelectedCharges.has(t.chargeId)}),(0,J.jsx)(U,{chargeId:t.chargeId})]})}})],Ae=({data:e,toggleMergeCharge:t,mergeSelectedCharges:n})=>{let{income:i}=T(h,e)??{income:[]},[a,o]=(0,q.useState)(!0),[s,c]=(0,q.useState)([]),[l,u]=(0,q.useState)({}),[d,f]=(0,q.useState)({}),[p,m]=(0,q.useState)(`detailed`),g=le({data:(0,q.useMemo)(()=>{let e=0;return i.map(r=>(e+=r.taxReducedLocalAmount?.raw??0,{data:r,toggleMergeCharge:t,mergeSelectedCharges:n,cumulativeAmount:e}))},[i,t,n]),columns:$,getCoreRowModel:N(),onSortingChange:c,getSortedRowModel:D(),onColumnVisibilityChange:u,onExpandedChange:f,getExpandedRowModel:ue(),state:{sorting:s,columnVisibility:l,expanded:d}});return(0,J.jsxs)(P,{className:`p-6`,children:[(0,J.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,J.jsxs)(`h2`,{className:`text-lg font-semibold flex items-center gap-2`,children:[(0,J.jsx)(S,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>o(e=>!e),children:a?(0,J.jsx)(W,{className:`size-5`}):(0,J.jsx)(H,{className:`size-5`})}),`Income`]}),a&&(0,J.jsxs)(`div`,{className:`flex gap-2`,children:[(0,J.jsxs)(S,{variant:p===`detailed`?`default`:`outline`,size:`sm`,onClick:()=>m(`detailed`),children:[(0,J.jsx)(R,{className:`h-4 w-4 mr-2`}),`Detailed`]}),(0,J.jsxs)(S,{variant:p===`summarized`?`default`:`outline`,size:`sm`,onClick:()=>m(`summarized`),children:[(0,J.jsx)(Ce,{className:`h-4 w-4 mr-2`}),`Summarized`]})]})]}),a&&(p===`detailed`?(0,J.jsxs)(M,{children:[(0,J.jsx)(ce,{children:g.getHeaderGroups().map(e=>(0,J.jsx)(k,{children:e.headers.map(e=>(0,J.jsx)(de,{colSpan:e.colSpan,children:e.isPlaceholder?null:(0,J.jsxs)(S,{variant:`ghost`,onClick:e.column.getToggleSortingHandler(),className:`h-auto p-0 hover:bg-transparent`,children:[j(e.column.columnDef.header,e.getContext()),{asc:(0,J.jsx)(y,{className:`size-5`}),desc:(0,J.jsx)(v,{className:`size-5`})}[e.column.getIsSorted()]??null]})},e.id))},e.id))}),(0,J.jsx)(O,{children:g.getRowModel().rows?.length?g.getRowModel().rows.map(e=>{let t=T(r,e.original.data);return(0,J.jsxs)(q.Fragment,{children:[(0,J.jsx)(k,{"data-state":e.getIsSelected()&&`selected`,children:e.getVisibleCells().map(e=>(0,J.jsx)(A,{children:j(e.column.columnDef.cell,e.getContext())},e.id))}),e.getIsExpanded()&&(0,J.jsx)(k,{children:(0,J.jsx)(A,{colSpan:$.length,children:(0,J.jsx)(F,{style:{width:`100%`},withBorder:!0,shadow:`lg`,children:(0,J.jsx)(b,{chargeID:t.chargeId,fetching:!!t})})})})]},e.id)}):(0,J.jsx)(k,{children:(0,J.jsx)(A,{colSpan:$.length,className:`h-24 text-center`,children:`No results.`})})})]}):(0,J.jsx)(De,{records:i}))]})},je=({data:e,toggleMergeCharge:t,mergeSelectedCharges:n})=>{let r=T(m,e),[i,a]=(0,q.useState)(!0);return(0,J.jsxs)(P,{className:`p-6`,children:[(0,J.jsx)(`div`,{className:`flex items-center justify-between`,children:(0,J.jsxs)(`h2`,{className:`text-lg font-semibold flex items-center gap-2`,children:[(0,J.jsx)(S,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>a(e=>!e),disabled:!r||r.differentMonthDoc.length===0,children:i?(0,J.jsx)(W,{className:`size-5`}):(0,J.jsx)(H,{className:`size-5`})}),`Misc Charges (which are not on the above tables)`]})}),i&&r&&(0,J.jsx)(x,{data:r.differentMonthDoc,isAllOpened:!1,toggleMergeCharge:t,mergeSelectedCharges:n})]})},Me=({data:e,toggleMergeCharge:t,mergeSelectedCharges:n})=>{let r=T(c,e),[i,a]=(0,q.useState)(!0);return(0,J.jsxs)(P,{className:`p-6`,children:[(0,J.jsx)(`div`,{className:`flex items-center justify-between`,children:(0,J.jsxs)(`h2`,{className:`text-lg font-semibold flex items-center gap-2`,children:[(0,J.jsx)(S,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>a(e=>!e),disabled:!r||r.missingInfo.length===0,children:i?(0,J.jsx)(W,{className:`size-5`}):(0,J.jsx)(H,{className:`size-5`})}),`Missing Info`]})}),i&&r&&(0,J.jsx)(x,{data:r.missingInfo,isAllOpened:!1,toggleMergeCharge:t,mergeSelectedCharges:n})]})},Ne=({filter:{monthDate:e,financialEntityId:t},isLoading:n})=>{let[{data:r,fetching:i,error:a},o]=s({query:B(d),pause:!0,variables:{monthDate:e,financialEntityId:t}});return(0,q.useEffect)(()=>{if(a){let e=`Error generating PCN874 file`;console.error(`${e}: ${a}`),g.error(`Error`,{description:e,duration:5e3,closeButton:!0})}},[a]),(0,q.useEffect)(()=>{r&&_e(new File([r.pcnFile.reportContent],`pcn874.txt`,{type:`text/plain`}))},[r]),(0,J.jsx)(ge,{content:`Generate and Download PCN874 File`,children:(0,J.jsx)(S,{disabled:i||n,variant:`outline`,size:`icon`,className:`size-7.5`,onClick:o,children:(0,J.jsx)(we,{className:`size-5`})})})},Pe=({data:e})=>{let t=T(l,e),n=(0,q.useMemo)(()=>t?.expenses??[],[t?.expenses]),r=(0,q.useMemo)(()=>t?.income??[],[t?.income]),i=(0,q.useMemo)(()=>r.reduce((e,t)=>e+(t.taxReducedLocalAmount?.raw??0),0),[r]),a=(0,q.useMemo)(()=>r.reduce((e,t)=>e+(t.roundedLocalVatAfterDeduction?.raw??0),0),[r]),o=(0,q.useMemo)(()=>r.filter(e=>(e.roundedLocalVatAfterDeduction?.raw??0)===0).reduce((e,t)=>e+(t.taxReducedLocalAmount?.raw??0),0),[r]),s=(0,q.useMemo)(()=>n.filter(e=>e.isProperty).reduce((e,t)=>e+(t.taxReducedLocalAmount?.raw??0),0),[n]),c=(0,q.useMemo)(()=>a-n.reduce((e,t)=>e+(t.roundedLocalVatAfterDeduction?.raw??0),0),[a,n]);return(0,J.jsxs)(P,{className:`p-6`,children:[(0,J.jsx)(`h2`,{className:`text-lg font-semibold mb-4`,children:`Report Summary`}),(0,J.jsxs)(`div`,{className:`grid gap-4 sm:grid-cols-2 lg:grid-cols-3`,children:[(0,J.jsxs)(`div`,{className:`space-y-1`,children:[(0,J.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Taxable Sales Total`}),(0,J.jsx)(`p`,{className:`text-2xl font-bold`,children:G(i,f.Ils)})]}),(0,J.jsxs)(`div`,{className:`space-y-1`,children:[(0,J.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Taxable Sales VAT`}),(0,J.jsx)(`p`,{className:`text-2xl font-bold`,children:G(a,f.Ils)})]}),(0,J.jsxs)(`div`,{className:`space-y-1`,children:[(0,J.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Zero / Exempt Sales`}),(0,J.jsx)(`p`,{className:`text-2xl font-bold`,children:G(o,f.Ils)})]}),(0,J.jsxs)(`div`,{className:`space-y-1`,children:[(0,J.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Equipment Inputs`}),(0,J.jsx)(`p`,{className:`text-2xl font-bold`,children:G(s,f.Ils)})]}),(0,J.jsxs)(`div`,{className:`space-y-1`,children:[(0,J.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Total VAT Amount`}),(0,J.jsx)(`p`,{className:`text-2xl font-bold`,children:G(c,f.Ils)})]})]})]})},Fe=e(fe(),1);function Ie({filter:e,setFilter:t,closeModal:n}){let{control:r,handleSubmit:i,setValue:a}=oe({defaultValues:{...e}}),{selectableAdminBusinesses:s,fetching:c}=me(),l=e=>{t(e),n()};function u(){t(),n()}function d(e){a(`monthDate`,w(new Date(e.getFullYear(),e.getMonth(),15),`yyyy-MM-dd`))}return(0,J.jsxs)(J.Fragment,{children:[c?(0,J.jsx)(`div`,{children:`Loading...`}):(0,J.jsx)(`div`,{}),(0,J.jsxs)(`form`,{onSubmit:i(l),children:[(0,J.jsx)(se,{name:`financialEntityId`,control:r,defaultValue:void 0,render:({field:e,fieldState:t})=>(0,J.jsx)(z,{...e,data:s,value:e.value,disabled:c,label:`Report Issuer (Admin Business)`,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,error:t.error?.message})}),(0,J.jsx)(se,{name:`chargesType`,control:r,defaultValue:e.chargesType,render:({field:e,fieldState:t})=>(0,J.jsx)(z,{...e,data:Se,value:e.value??o.All,label:`Charge Type`,placeholder:`Filter income/expense`,maxDropdownHeight:160,error:t.error?.message})}),(0,J.jsx)(pe,{defaultValue:e?.monthDate?new Date(e.monthDate):new Date,defaultDate:e?.monthDate?new Date(e.monthDate):new Date,onChange:d,popoverProps:{withinPortal:!0}}),(0,J.jsxs)(`div`,{className:`flex justify-center mt-5 gap-3`,children:[(0,J.jsx)(`button`,{type:`submit`,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,J.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,J.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 Le({filter:e,setFilter:t}){let[n,r]=(0,q.useState)(!1),{get:i,set:a}=K(),{userContext:o}=(0,q.useContext)(C);function s(n){n||={financialEntityId:o?.context.adminBusinessId??e.financialEntityId,monthDate:w(new Date,`yyyy-MM-15`)},(0,Fe.default)(n,e)||t(n)}return(0,q.useEffect)(()=>{let t=te(e??{});t!==i(`vatMonthlyReportFilters`)&&a(`vatMonthlyReportFilters`,t)},[e,i,a]),(0,J.jsxs)(J.Fragment,{children:[(0,J.jsx)(he,{opened:n,onClose:()=>r(!1),content:(0,J.jsx)(Ie,{filter:e,setFilter:s,closeModal:()=>r(!1)})}),(0,J.jsx)(S,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>r(!0),children:(0,J.jsx)(ae,{className:`size-5`})})]})}var Re=()=>{let{get:e}=K(),{setFiltersContext:t}=(0,q.useContext)(ve),{userContext:n}=(0,q.useContext)(C),[r,i]=(0,q.useState)(e(`vatMonthlyReportFilters`)?JSON.parse(decodeURIComponent(e(`vatMonthlyReportFilters`))):{financialEntityId:n?.context.adminBusinessId??``,monthDate:w(new Date,`yyyy-MM-15`)}),[a,c]=(0,q.useState)([]);(0,q.useEffect)(()=>{(!r.financialEntityId||r.financialEntityId===``)&&n?.context.adminBusinessId&&i({...r,financialEntityId:n.context.adminBusinessId})},[r,n?.context.adminBusinessId]);let[{data:l,fetching:u}]=s({query:B(ee),variables:{filters:r},pause:r.financialEntityId===``}),d=(0,q.useCallback)(e=>{a.includes(e)?c(a.filter(t=>t!==e)):c([...a,e])},[a]);function f(){c([])}(0,q.useEffect)(()=>{t((0,J.jsxs)(`div`,{className:`flex flex-row gap-2`,children:[(0,J.jsx)(Ne,{filter:r,isLoading:u}),(0,J.jsx)(Le,{filter:{...r},setFilter:i}),(0,J.jsx)(ye,{selected:a.map(e=>({id:e,onChange:()=>{}})),resetMerge:f})]}))},[l,r,u,t,a]);let p=(0,q.useMemo)(()=>new Set(a),[a]);return(0,J.jsx)(xe,{title:`VAT Monthly Report${r.monthDate?`, ${w(new Date(r.monthDate),`MMMM yyyy`)}`:``}`,children:u?(0,J.jsx)(ie,{className:`h-10 w-10 animate-spin mr-2 self-center`}):(0,J.jsx)(`div`,{className:`min-h-screen`,children:(0,J.jsxs)(`div`,{className:`space-y-4`,children:[r.financialEntityId&&r.monthDate&&(0,J.jsx)(Pe,{data:l?.vatReport}),r.chargesType!==o.Expense&&(0,J.jsx)(Ae,{data:l?.vatReport,toggleMergeCharge:d,mergeSelectedCharges:p}),r.chargesType!==o.Income&&(0,J.jsx)(ke,{data:l?.vatReport,toggleMergeCharge:d,mergeSelectedCharges:p}),(0,J.jsx)(Me,{data:l?.vatReport,toggleMergeCharge:d,mergeSelectedCharges:p}),(0,J.jsx)(Te,{data:l?.vatReport,toggleMergeCharge:d,mergeSelectedCharges:p}),(0,J.jsx)(je,{data:l?.vatReport,toggleMergeCharge:d,mergeSelectedCharges:p})]})})})};export{Re as VatMonthlyReport};