@accounter/client
Version:
Accounter client application
1 lines • 12.4 kB
JavaScript
import{s as e}from"./dist-C51EwTaa.js";import{i as t,o as n}from"./utils-DdVdMk8X.js";import{Jt as r,Lo as i,en as a,nn as o,r as s,x as c}from"./error-handling-Dpfd9svJ.js";import{i as l,n as u}from"./routes-DUvpW9-n.js";import{o as d,s as f}from"./select-CrsvQyhZ.js";import{t as p}from"./funnel-BFbxpUGW.js";import{t as m}from"./button-Dzp2INW0.js";import{B as h,Et as g,F as _,K as v,L as y,Lt as b,Ot as x,P as S,R as C,Tt as w,U as T,wt as E,z as D}from"./table--bF0wbxq.js";import{t as O}from"./sub-BIcSj2Zu.js";import{t as k}from"./MultiSelect-HTEIN3wg.js";import{Er as A,It as j,Nt as M,P as N,fn as P,ft as F,pt as I,un as L,vn as R,w as z,yt as B,zt as V}from"./index-CL8-JoMZ.js";import{t as H}from"./use-url-query-BCNbSvLg.js";var U=e(E(),1),W=e(n(),1),G=()=>{let[{data:e,fetching:t,error:n},r]=i({query:c});n&&(console.error(`Error fetching business trips: ${n}`),s.error(`Error`,{description:`Unable to fetch business trips`}));let a=(0,W.useMemo)(()=>[...e?.allBusinessTrips??[]].sort((e,t)=>e.name>t.name?1:-1),[e]);return{fetching:t,refresh:()=>r(),businessTrips:a,selectableBusinessTrips:(0,W.useMemo)(()=>a.map(e=>({value:e.id,label:e.name})),[a])}},K=t(),q=[{value:a.AbsAmount,label:`Abs Amount`},{value:a.Amount,label:`Amount`},{value:a.Date,label:`Date`}],J=[{label:`All`,value:r.All},{label:`Income`,value:r.Income},{label:`Expense`,value:r.Expense}],Y=[{label:`Bank Deposit`,value:o.BankDeposit},{label:`Business Trip`,value:o.BusinessTrip},{label:`Common`,value:o.Common},{label:`Conversion`,value:o.Conversion},{label:`Credit Card Bank`,value:o.CreditcardBank},{label:`Dividend`,value:o.Dividend},{label:`Financial`,value:o.Financial},{label:`Foreign Securities`,value:o.ForeignSecurities},{label:`Internal Transfer`,value:o.Internal},{label:`Monthly VAT`,value:o.Vat},{label:`Salary`,value:o.Payroll}];function X({filter:e,setFilter:t,closeModal:n}){let{userContext:i}=(0,W.useContext)(v),o=T({defaultValues:{byOwners:i?.context.adminBusinessId?[i.context.adminBusinessId]:void 0,sortBy:{field:a.Date,asc:!1},toAnyDate:b(new Date,`yyyy-MM-dd`),fromAnyDate:b(O(new Date,{years:1}),`yyyy-MM-dd`),...e}}),{control:s,handleSubmit:c,watch:l}=o,[u,p]=(0,W.useState)(e.sortBy?.asc??!1),[m,E]=(0,W.useState)(!!e.sortBy?.field),{selectableFinancialEntities:N,fetching:R}=M(),{selectableTags:z,fetching:H}=V(),{selectableBusinessTrips:U,fetching:X}=G(),Z=l(`sortBy.field`);(0,W.useEffect)(()=>{Z&&!m?E(!0):!Z&&m&&E(!1)},[Z,m]);let $=e=>{u!=null&&e.sortBy?.field&&(e.sortBy.asc=u),t(e),n()};function ee(){t({}),p(!1),n()}return(0,K.jsxs)(K.Fragment,{children:[R?(0,K.jsx)(`div`,{children:`Loading...`}):(0,K.jsx)(`div`,{}),(0,K.jsx)(S,{...o,children:(0,K.jsxs)(`form`,{onSubmit:c($),children:[(0,K.jsxs)(L,{cols:2,children:[(0,K.jsx)(y,{name:`byOwners`,control:s,defaultValue:e.byOwners,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Owners`}),(0,K.jsx)(_,{children:(0,K.jsx)(k,{...e,data:N,value:e.value??[],disabled:R,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,withinPortal:!0})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`byBusinesses`,control:s,defaultValue:e.byBusinesses,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Financial Entities`}),(0,K.jsx)(_,{children:(0,K.jsx)(k,{...e,data:N,value:e.value??[],disabled:R,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,withinPortal:!0})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`byTags`,control:s,defaultValue:e.byTags,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Tags`}),(0,K.jsx)(_,{children:(0,K.jsx)(k,{...e,data:z,itemComponent:I,value:e.value??[],disabled:H,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,withinPortal:!0,filter:(e,t,n)=>n.label?.toLowerCase().includes(e.toLowerCase().trim())||n.description?.toLowerCase().includes(e.toLowerCase().trim())})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`fromAnyDate`,control:s,defaultValue:e.fromAnyDate,rules:{pattern:{value:A,message:`Date must be in format yyyy-mm-dd`}},render:({field:e,fieldState:t})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{htmlFor:`from-any-date`,children:`From Date`}),(0,K.jsx)(_,{children:(0,K.jsx)(B,{id:`from-any-date`,value:e.value??void 0,onChange:t=>{t!==e.value&&e.onChange(t)},"aria-invalid":!!t.error})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`toAnyDate`,control:s,defaultValue:e.toAnyDate,rules:{pattern:{value:A,message:`Date must be in format yyyy-mm-dd`}},render:({field:e,fieldState:t})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{htmlFor:`to-any-date`,children:`To Date`}),(0,K.jsx)(_,{children:(0,K.jsx)(B,{id:`to-any-date`,value:e.value??void 0,onChange:t=>{t!==e.value&&e.onChange(t)},"aria-invalid":!!t.error})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`chargesType`,control:s,defaultValue:e.chargesType,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Income / Expense`}),(0,K.jsx)(_,{children:(0,K.jsx)(P,{...e,data:J,value:e.value??r.All,disabled:R,placeholder:`Filter income/expense`,maxDropdownHeight:160,withinPortal:!0})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`byChargeTypes`,control:s,defaultValue:e.byChargeTypes,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Charge Type`}),(0,K.jsx)(_,{children:(0,K.jsx)(k,{...e,data:Y,value:e.value??[],placeholder:`All charge types`,maxDropdownHeight:160,searchable:!0,withinPortal:!0})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`byBusinessTrips`,control:s,defaultValue:e.byBusinessTrips,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Business Trips`}),(0,K.jsx)(_,{children:(0,K.jsx)(k,{...e,data:U,value:e.value??[],disabled:X,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,withinPortal:!0})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`sortBy.field`,control:s,defaultValue:e.sortBy?.field??a.Date,render:({field:t})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Field to sort by`}),(0,K.jsx)(_,{children:(0,K.jsx)(P,{...t,data:q,placeholder:`Scroll to see all options`,maxDropdownHeight:160,searchable:!0,rightSectionProps:{style:{width:`5rem`}},withinPortal:!0,rightSection:(0,K.jsxs)(`div`,{className:`flex flex-row items-center gap-1`,children:[(0,K.jsx)(j,{defaultChecked:e.sortBy?.asc??!1,checked:u??!1,disabled:!m,onCheckedChange:p}),(0,K.jsx)(`span`,{className:`text-xs`,children:u?`ASC`:`DESC`})]})})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`accountantStatus`,control:s,defaultValue:e.accountantStatus,render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Accountant Status`}),(0,K.jsx)(_,{children:(0,K.jsx)(k,{...e,value:e.value??[],itemComponent:Q,data:Object.values(F),disabled:R,placeholder:`All`,maxDropdownHeight:160,withinPortal:!0})}),(0,K.jsx)(h,{})]})}),(0,K.jsx)(y,{name:`freeText`,control:s,rules:{minLength:{value:2,message:`Must be at least 2 characters`}},render:({field:e})=>(0,K.jsxs)(C,{className:`h-min`,children:[(0,K.jsx)(D,{children:`Free Text`}),(0,K.jsx)(_,{children:(0,K.jsx)(f,{...e,value:e.value??``})}),(0,K.jsx)(h,{})]})}),(0,K.jsxs)(`div`,{className:`flex flex-col gap-2 mt-4 rounded-lg border p-3 shadow-sm space-y-2`,children:[(0,K.jsx)(d,{children:`Missing Information:`}),(0,K.jsx)(y,{control:o.control,name:`withoutInvoice`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Without Invoice`})}),(0,K.jsx)(_,{children:(0,K.jsx)(j,{defaultChecked:e.withoutInvoice??!1,onCheckedChange:t.onChange})})]})}),(0,K.jsx)(y,{control:o.control,name:`withoutReceipt`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Without Receipts`})}),(0,K.jsx)(_,{children:(0,K.jsx)(j,{defaultChecked:e.withoutReceipt??!1,onCheckedChange:t.onChange})})]})}),(0,K.jsx)(y,{control:o.control,name:`withoutDocuments`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Without Documents`})}),(0,K.jsx)(_,{children:(0,K.jsx)(j,{defaultChecked:e.withoutDocuments??!1,onCheckedChange:t.onChange})})]})}),(0,K.jsx)(y,{control:o.control,name:`withOpenDocuments`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`With Open Documents`})}),(0,K.jsx)(_,{children:(0,K.jsxs)(w,{children:[(0,K.jsx)(x,{children:(0,K.jsx)(j,{defaultChecked:e.withOpenDocuments??!1,onCheckedChange:t.onChange})}),(0,K.jsx)(g,{children:(0,K.jsx)(`p`,{children:`Show only charges with documents that are currently open`})})]})})]})}),(0,K.jsx)(y,{control:o.control,name:`withoutTransactions`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Without Transactions`})}),(0,K.jsx)(_,{children:(0,K.jsx)(j,{defaultChecked:e.withoutTransactions??!1,onCheckedChange:t.onChange})})]})}),(0,K.jsx)(y,{control:o.control,name:`withMissingCounterparty`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Missing Counterparty`})}),(0,K.jsx)(_,{children:(0,K.jsxs)(w,{children:[(0,K.jsx)(x,{children:(0,K.jsx)(j,{defaultChecked:e.withMissingCounterparty??!1,onCheckedChange:t.onChange})}),(0,K.jsx)(g,{children:(0,K.jsx)(`p`,{children:`Show charges with a transaction missing a business, or a document missing a creditor / debtor`})})]})})]})}),(0,K.jsx)(y,{control:o.control,name:`unbalanced`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Unbalanced businesses`})}),(0,K.jsx)(_,{children:(0,K.jsx)(j,{defaultChecked:e.unbalanced??!1,onCheckedChange:t.onChange})})]})}),(0,K.jsx)(y,{control:o.control,name:`withoutLedger`,render:({field:t})=>(0,K.jsxs)(C,{className:`flex flex-row items-center justify-between`,children:[(0,K.jsx)(`div`,{className:`space-y-0.5`,children:(0,K.jsx)(D,{children:`Without ledger`})}),(0,K.jsx)(_,{children:(0,K.jsx)(j,{defaultChecked:e.withoutLedger??!1,onCheckedChange:t.onChange})})]})})]})]}),(0,K.jsxs)(`div`,{className:`flex justify-center mt-5 gap-3`,children:[(0,K.jsx)(`button`,{type:`submit`,disabled:R||H,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,K.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:ee,children:`Clear`}),(0,K.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 Z({filter:e={},setFilter:t,activePage:n,setPage:r,totalPages:i=1,initiallyOpened:a=!1}){let[o,s]=(0,W.useState)(a),[c,d]=(0,W.useState)(!l(e)),{get:f,set:h}=H();return(0,W.useEffect)(()=>{let e=n>0?n.toFixed(0):null;e!==f(`page`)&&h(`page`,e)},[n,f,h]),(0,W.useEffect)(()=>{let t=u(e);t!==f(`chargesFilters`)&&(h(`chargesFilters`,t),h(`page`),r(0))},[e,f,h,r]),(0,K.jsxs)(`div`,{className:`flex flex-row gap-5 items-center`,children:[(0,K.jsx)(N,{opened:o,onClose:()=>s(!1),content:(0,K.jsx)(X,{filter:e,setFilter:(0,W.useCallback)(n=>{(0,U.default)(n,e)||(t(n),d(!l(n)))},[e,t]),closeModal:()=>s(!1)}),modalSize:`xl`}),i>1&&(0,K.jsx)(z,{className:`flex-fit w-fit mx-0`,currentPageIndex:n,onChange:r,totalPages:i}),(0,K.jsx)(R,{inline:!0,size:16,disabled:!c,children:(0,K.jsx)(m,{variant:`outline`,size:`icon`,className:`size-7.5`,onClick:()=>s(!0),children:(0,K.jsx)(p,{className:`size-5`})})})]})}var Q=(0,W.forwardRef)(({bgColor:e,label:t,color:n,icon:r,...i},a)=>(0,K.jsxs)(m,{ref:a,...i,variant:`ghost`,size:`sm`,className:`h-7 p-0 ${e}`,title:t,children:[(0,K.jsx)(r,{className:`h-3.5 w-3.5 ${n}`}),t]}));Q.displayName=`AccountantStatusMultiSelectItem`;export{J as n,Z as t};