ekm-ui 0.4.22 → 0.4.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/.turbo/turbo-build.log +54 -54
  2. package/CHANGELOG.md +12 -0
  3. package/dist/button.js +1 -1
  4. package/dist/card-payment-block.js +9 -9
  5. package/dist/chunk-4HCWPWEE.js +11 -0
  6. package/dist/chunk-4HCWPWEE.js.map +1 -0
  7. package/dist/{chunk-JNHB4YNM.js → chunk-F3BF3KTV.js} +2 -2
  8. package/dist/{chunk-E2DMQCPM.js → chunk-JB5PNJCD.js} +5 -5
  9. package/dist/chunk-JB5PNJCD.js.map +1 -0
  10. package/dist/{chunk-3ER6WKA7.js → chunk-JTV6HMWW.js} +2 -2
  11. package/dist/chunk-JTV6HMWW.js.map +1 -0
  12. package/dist/{chunk-HQIKNKIV.js → chunk-SDIXMJRI.js} +2 -2
  13. package/dist/chunk-VOFMZ77E.js +11 -0
  14. package/dist/chunk-VOFMZ77E.js.map +1 -0
  15. package/dist/{chunk-JHGOFDVG.js → chunk-XABECXZS.js} +1 -1
  16. package/dist/chunk-XABECXZS.js.map +1 -0
  17. package/dist/{chunk-G2WGEIWK.js → chunk-Y5DEGGVQ.js} +1 -1
  18. package/dist/chunk-Y5DEGGVQ.js.map +1 -0
  19. package/dist/{chunk-WTBH4TDX.js → chunk-Z44LYPKH.js} +1 -1
  20. package/dist/chunk-Z44LYPKH.js.map +1 -0
  21. package/dist/country-picker/country-modal.js +9 -9
  22. package/dist/date-range-picker.js +2 -2
  23. package/dist/drag-and-drop.js +9 -9
  24. package/dist/featurePageComponents/feature-page-group.js +1 -1
  25. package/dist/featurePageComponents/mini-feature-block.js.map +1 -1
  26. package/dist/file-picker/file-picker.js +9 -9
  27. package/dist/fixed-alert.js +2 -2
  28. package/dist/image-thumbnail.js +1 -1
  29. package/dist/index.js +9 -9
  30. package/dist/layout/layout.js +9 -9
  31. package/dist/modal.d.ts +4 -1
  32. package/dist/modal.js +1 -1
  33. package/dist/product-picker/product-listing.js +1 -1
  34. package/dist/product-picker/product-modal.js +9 -9
  35. package/dist/stacked-list-item.js +9 -9
  36. package/dist/table-result-block.js +9 -9
  37. package/dist/video-modal.js +1 -1
  38. package/package.json +1 -1
  39. package/src/button.tsx +1 -1
  40. package/src/featurePageComponents/feature-page-group.tsx +1 -0
  41. package/src/featurePageComponents/mini-feature-block.tsx +1 -0
  42. package/src/image-thumbnail.tsx +1 -0
  43. package/src/modal.tsx +6 -4
  44. package/src/product-picker/product-listing.tsx +6 -6
  45. package/src/product-picker/product-modal.tsx +5 -2
  46. package/src/video-modal.tsx +1 -0
  47. package/dist/chunk-2I24LCEG.js +0 -11
  48. package/dist/chunk-2I24LCEG.js.map +0 -1
  49. package/dist/chunk-3ER6WKA7.js.map +0 -1
  50. package/dist/chunk-E2DMQCPM.js.map +0 -1
  51. package/dist/chunk-G2WGEIWK.js.map +0 -1
  52. package/dist/chunk-JHGOFDVG.js.map +0 -1
  53. package/dist/chunk-WTBH4TDX.js.map +0 -1
  54. package/dist/chunk-XUMA37J7.js +0 -11
  55. package/dist/chunk-XUMA37J7.js.map +0 -1
  56. /package/dist/{chunk-JNHB4YNM.js.map → chunk-F3BF3KTV.js.map} +0 -0
  57. /package/dist/{chunk-HQIKNKIV.js.map → chunk-SDIXMJRI.js.map} +0 -0
@@ -1,4 +1,4 @@
1
- import { a as a$i } from './chunk-3ER6WKA7.js';
1
+ import { a as a$i } from './chunk-JTV6HMWW.js';
2
2
  import { a as a$f } from './chunk-7XYO4SF6.js';
3
3
  import { a as a$9, b as b$1 } from './chunk-HVNLAQA6.js';
4
4
  import { a as a$j } from './chunk-U26NV6PE.js';
@@ -8,7 +8,7 @@ import { a as a$5 } from './chunk-TBJGGVSZ.js';
8
8
  import { a as a$e } from './chunk-AO5TGD7T.js';
9
9
  import { a as a$8 } from './chunk-GUK5N5Z2.js';
10
10
  import { a as a$b } from './chunk-ESJIQMQJ.js';
11
- import { a as a$2 } from './chunk-XUMA37J7.js';
11
+ import { a as a$2 } from './chunk-4HCWPWEE.js';
12
12
  import { a as a$d } from './chunk-AVTJXS4U.js';
13
13
  import { a as a$c } from './chunk-NDDDT4TO.js';
14
14
  import { a as a$4 } from './chunk-ER5CL77P.js';
@@ -16,7 +16,7 @@ import { a as a$7 } from './chunk-E4USZ2Q3.js';
16
16
  import { a as a$6 } from './chunk-F47A36U7.js';
17
17
  import { a as a$h } from './chunk-5SEJVYKM.js';
18
18
  import { a as a$g } from './chunk-2OPJLYW6.js';
19
- import { a as a$3 } from './chunk-2I24LCEG.js';
19
+ import { a as a$3 } from './chunk-VOFMZ77E.js';
20
20
  import { a as a$1 } from './chunk-6LHL364H.js';
21
21
  import { e, f as f$1 } from './chunk-Z4LPO673.js';
22
22
  import { Badge, Sidebar } from 'flowbite-react';
@@ -29,8 +29,8 @@ import { BsCloudUpload, BsFillCheckCircleFill, BsFillImageFill } from 'react-ico
29
29
  import { FaTimesCircle } from 'react-icons/fa';
30
30
  import jr from 'pluralize';
31
31
 
32
- function Je({cardPayment:r,enablePayPal:e}){return jsxs(a$4,{className:"border-0 shadow-sm ",children:[jsx("h3",{className:"text-xl font-semibold dark:text-white",children:"Billing Details"}),jsx("div",{className:"flex items-center justify-between pb-4",children:jsxs("fieldset",{className:"flex w-full flex-col gap-4",id:"radio",children:[jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[e&&jsx(a$5,{id:"creditDebitCard",name:"paymentType",value:"creditDebitCard"}),jsx(a$6,{htmlFor:"creditDebitCard",children:"Pay by Credit or Debit card"})]}),jsxs("div",{className:e?"ml-6 flex gap-2":"flex gap-2",children:[jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/visa.png",alt:"VISA Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/mastercard.png",alt:"MasterCard Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/maestro.png",alt:"Maestro Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/amex.png",alt:"AMEX Card Logo"})]})]}),r&&jsxs(Fragment,{children:[jsxs("div",{className:"grid grid-cols-1 content-start gap-6 md:grid-cols-2",children:[jsx(a$7,{label:"Name on Card *",htmlFor:"nameOnCard",helperText:"This is your name as is appears on the front of your credit or debit card.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"Your name",type:"text",required:!0})}),jsx(a$7,{label:"Card Number *",htmlFor:"cardNumber",helperText:"This is the long number on the front of your credit or debit card.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"0000 0000 0000 0000",type:"number",rightIcon:HiCreditCard,required:!0})})]}),jsxs("div",{className:"grid grid-cols-1 content-start gap-6 sm:grid-cols-3 md:grid-cols-4",children:[jsx(a$7,{label:"Expiry Date *",htmlFor:"nameOnCard",helperText:"The expiry date as it appears on your card.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"MM / YY",type:"text",required:!0})}),jsx(a$7,{label:"Security Code (CVC) *",htmlFor:"cardNumber",helperText:"The last three digits on the back of your card\u2019s signature strip.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"123",type:"text",rightIcon:HiCreditCard,required:!0})}),jsx("img",{className:"mt-7 hidden h-auto w-16 sm:block",src:"https://shared.ekmcdn.com/images/rise/cvc-reminder-image.png",alt:""})]})]}),e&&jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[jsx(a$5,{id:"PayPal",name:"paymentType",value:"PayPal"}),jsx(a$6,{htmlFor:"PayPal",children:"PayPal"})]}),jsx("div",{className:"ml-6",children:jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/paypal.png",alt:"PayPal Icon"})})]})]})})]})}Je.displayName="CardPaymentBlock";function We(){return jsxs(Sidebar.Items,{children:[jsxs(Sidebar.ItemGroup,{children:[jsx(Sidebar.Item,{href:"/",icon:HiChartPie,className:"bg-gray-100 dark:bg-gray-700",children:"Dashboard"}),jsx(Sidebar.Item,{href:"/products",icon:HiTag,className:"",children:"Products"}),jsx(Sidebar.Item,{href:"/orders",icon:HiShoppingBag,label:"27",className:"",children:"Orders"}),jsxs(Sidebar.Collapse,{icon:HiPaintBrush,label:"Design",children:[jsx(Sidebar.Item,{href:"/design/design",className:"",children:"Theme"}),jsx(Sidebar.Item,{href:"/design/editor",className:"",children:"Editor"}),jsx(Sidebar.Item,{href:"/theme/webpages",className:"",children:"Webpages"})]}),jsx(Sidebar.Item,{href:"/features",icon:HiStar,className:"",children:"Features"})]}),jsxs(Sidebar.ItemGroup,{children:[jsx(Sidebar.Item,{href:"https://github.com/themesberg/flowbite-react/",icon:HiDocument,children:"Docs"}),jsx(Sidebar.Item,{href:"https://flowbite-react.com/",icon:HiRocketLaunch,children:"What's New"}),jsx(Sidebar.Item,{href:"https://github.com/themesberg/flowbite-react/issues",icon:HiGlobeAlt,children:"Support Centre"})]})]})}function Cr({children:r,hasHeader:e}){let[o,s]=useState(!1),[v,R]=useState(!1);return useMemo(()=>{a$9()&&!o&&R(!0);},[o]),jsxs(Fragment,{children:[jsx(a$a,{onMenuButtonClick:()=>{s(!o);},showCloseButton:v,avatarImg:"https://avatars.githubusercontent.com/u/49406022?v=4"}),jsxs("div",{className:"flex",children:[jsx(b$1,{collapsed:o,children:jsx(We,{})}),jsxs("div",{className:"flex w-3/4 flex-grow flex-col",children:[jsx("main",{className:`"relative dark:bg-gray-900" flex h-full flex-grow flex-col gap-4 overflow-y-auto bg-gray-50 ${e?"":"p-4"}`,children:r}),jsx(a$b,{companyName:"EKM"})]})]})]})}var q=e(a$1(),1);var b=Object.freeze({NONE:"none",OVER:"drag-over",UPLOADING:"uploading",ERROR:"error",SUCCESS:"success"}),Lr=Object.freeze({[b.NONE]:"border-gray-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-gray-600 dark:hover:border-gray-500 dark:hover:bg-gray-600",[b.OVER]:"border-blue-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-blue-600 dark:hover:border-blue-500 dark:hover:bg-blue-600",[b.UPLOADING]:"border-blue-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-blue-600 dark:hover:border-blue-500 dark:hover:bg-blue-600",[b.ERROR]:"border-red-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-red-600 dark:hover:border-red-500 dark:hover:bg-red-600",[b.SUCCESS]:"border-green-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-green-600 dark:hover:border-green-500 dark:hover:bg-green-600"}),Pr=["png","webp","jpg","gif","jpeg"];function Ke(r,e){let o=!e||e.length===0?Pr:e;if(!r||r.length===0)return !1;let s=r.split(".").pop().toLowerCase();return o.includes(s)}function se({subtitle:r="PNG, WEBP, JPG, JPEG or GIF",filetypes:e,uploaded:o,exitCallback:s,callback:v,errorCallback:R,pickerCallback:D}){let[l,m]=useState(b.NONE);useEffect(()=>{Object.values(b).includes(o)&&(m(o),setTimeout(()=>{o===b.ERROR&&R?R():m(b.NONE);},2e3));},[o]);let w=t=>{t.preventDefault(),m(b.OVER);},B=t=>{t.preventDefault(),s&&s(),m(b.NONE);},n=t=>{t.preventDefault(),Ke(t.dataTransfer.files[0].name,e)?(m(b.UPLOADING),v(t.dataTransfer.files[0])):(m(b.ERROR),setTimeout(()=>{R();},2e3));},y=t=>{Ke(t.target.files[0].name,e)?m(b.UPLOADING):m(b.ERROR),v(t.target.files[0]);},x=()=>{D&&D();},O=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsx(BsCloudUpload,{className:"h-12 w-12 text-gray-400 dark:text-gray-500"}),jsxs("p",{className:"mb-2 mt-5 text-sm text-gray-500 dark:text-gray-400",children:[jsx("span",{className:"font-semibold",children:"Click to upload"})," or drag and drop"]}),jsx("p",{className:"text-xs text-gray-500 dark:text-gray-400",children:r}),D&&jsx("div",{className:"mt-3 mb-3",children:jsxs(a$3,{color:"default",onClick:x,children:[jsx(BiSearch,{className:"mr-2"}),"Browse File Manager"]})})]}),S=()=>jsx("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:jsx("p",{className:"mb-2 mt-5 text-sm text-blue-500 dark:text-blue-400",children:jsx("span",{className:"font-semibold",children:"Drop here to upload"})})}),C=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsxs("svg",{"aria-hidden":"true",className:"mr-2 inline h-10 w-10 animate-spin text-gray-200 dark:text-gray-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]}),jsx("p",{className:"mb-2 mt-5 text-sm text-blue-500 dark:text-blue-400",children:jsx("span",{className:"font-semibold",children:"Uploading..."})})]}),_=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsx(FaTimesCircle,{className:"h-12 w-12 text-red-400 dark:text-red-500"}),jsx("p",{className:"mb-2 mt-5 text-sm text-red-500 dark:text-red-400",children:jsx("span",{className:"font-semibold",children:"Unable to upload"})})]}),H=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsx(BsFillCheckCircleFill,{className:"h-12 w-12 text-green-400 dark:text-green-500"}),jsx("p",{className:"mb-2 mt-5 text-sm text-green-500 dark:text-green-400",children:jsx("span",{className:"font-semibold",children:"Uploaded"})})]}),A=()=>{switch(l){case b.OVER:return S();case b.UPLOADING:return C();case b.ERROR:return _();case b.SUCCESS:return H();default:return O()}};return jsx("div",{onDragEnter:t=>t.preventDefault(),onDragOver:w,onDrop:n,onDragLeave:B,className:"flex h-full w-full items-center justify-center",children:jsxs("label",{htmlFor:"dropzone-file",className:`flex h-full w-full cursor-pointer flex-col items-center justify-center rounded-lg border-2 border-dashed ${Lr[l]}`,children:[A(),l===b.NONE&&jsx("input",{id:"dropzone-file",type:"file",className:"hidden",onChange:y})]})})}se.propTypes={filetypes:q.default.arrayOf(q.default.string),subtitle:q.default.string,uploaded:q.default.oneOf(["none","success","error"]).isRequired,exitCallback:q.default.func,errorCallback:q.default.func.isRequired,callback:q.default.func.isRequired,pickerCallback:q.default.func};se.displayName="DragAndDrop";var X=e(a$1(),1);var er="/admin/api/common/directoryinformation/",a=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",LOADED_NO_DRAG:"LOADED_NO_DRAG",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY",UPLOAD_ERROR:"ERROR",DRAGGING:"DRAGGING"}),Tr=Object.freeze({mode:a.LOADING,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1});function Br(r,e){switch(e.type){case a.EMPTY:return {mode:a.EMPTY,actionBtnTxt:"Add Image",actionBtnColor:"default",listSize:"h-5/6",listBorder:"",searchDisabled:!0};case a.LOADING:return Tr;case a.LOADED:return {mode:a.LOADED,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[68.666667%]",listBorder:"border",searchDisabled:!1};case a.LOADED_NO_DRAG:return {mode:a.LOADED_NO_DRAG,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[85%]",listBorder:"border",searchDisabled:!1};case a.SEARCH_RESULTS:return {mode:a.SEARCH_RESULTS,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case a.SEARCH_EMPTY:return {mode:a.SEARCH_EMPTY,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+e.page)}}function He({appUrl:r,uri:e,show:o,hideDrag:s=!1,onClose:v,callback:R}){let D=useRef(),[l,m]=useReducer(Br,{mode:a.LOADING,footerBorder:"border-t"}),[w,B]=useState(0),n=useRef(1),[y,x]=useState(!1),[O,S]=useState(!1),C=useRef({pages:0,totalEntries:0}),[_,H]=useState(!1),[A,t]=useState(""),[u,k]=useState(null),[j,ee]=useState([]),[ce,G]=useState("none");useEffect(()=>{o&&(m({type:a.LOADING}),k(null),C.current={pages:0,totalEntries:0},Ne(),c(""));},[o]),useEffect(()=>{u&&k(null),O&&S(!1);},[l.mode]);let Ne=()=>{ee([]),G("none"),H(!1),k(null),S(!1),t(""),n.current=1;},c=p=>f$1(this,null,function*(){let M=n.current;try{let J=(p==null?void 0:p.length)>0?`&FileNameIncludesString=${p}`:"&FileNameIncludesString=",Y=yield (yield fetch(`${r}${er}?CurrentPage=${M}&PageSize=10&Uri=${e}${J}`,{method:"GET",credentials:"same-origin",headers:{"Content-Type":"application/json"}})).json();if(Y.Items.Data.length>0&&M>1?ee(Re=>[...Re,...Y.Items.Data]):ee(Y.Items.Data),C.current={pages:Y.Items.NumberOfPages,totalEntries:Y.Items.Total},B(Y.Items.NumberOfPages),(p==null?void 0:p.length)>0)m({type:Y.Items.Data.length>0?a.SEARCH_RESULTS:a.SEARCH_EMPTY});else {let Re=s?a.LOADED_NO_DRAG:a.LOADED;m({type:Y.Items.Data.length>0?Re:a.EMPTY});}G("none"),H(!1),x(!1);}catch(J){m({type:(p==null?void 0:p.length)===0?a.SEARCH_EMPTY:a.EMPTY});}}),L=p=>{s||(x(!0),D.current.removeFocus(),p.preventDefault());},re=p=>{s||x(!1);},$=p=>{var de;let M=(de=p.text)!=null?de:"",J=A!=null?A:"";t(M),(J.length>0&&M.length===0||J.length===0&&M.length>0&&l.mode!==a.LOADING)&&m({type:a.LOADING}),n.current=1,O&&S(!1),c(M);},te=()=>{S(!0),x(!1),G("none");},ir=()=>{R(`https://files.ekmcdn.com/${u.Uri}`),ve();},ve=()=>{v();},ze=p=>f$1(this,null,function*(){if(p==null){G("error"),te();return}try{let M=zr(p.name),J=yield Ur(p),de={Path:`/${e}/`,Name:M,Bytes:Yr(J),ForceOverwriteFile:!0};(yield fetch(`${r}${er}`,{method:"POST",credentials:"same-origin",headers:{"Content-Type":"application/json"},body:JSON.stringify(de)})).status===200?(G("success"),t(""),D.current.clear(),n.current=1,ee([]),S(!1),c("")):G("error");}catch(M){G("error");}}),nr=p=>{switch(p.type){case"FETCH_DATA":H(p.payload),n.current<C.current.pages&&!_&&(H(!0),n.current=n.current+1,c(A));break;case"SELECTION":k(p.payload),S(!1);break;}},cr=()=>{switch(l.mode){case a.EMPTY:return jsx(_r,{});case a.LOADING:return jsx(Hr,{});case a.SEARCH_RESULTS:case a.LOADED:case a.LOADED_NO_DRAG:return jsx(a$j,{border:l.listSize,files:j,isMore:n.current<C.current.pages,selected:u==null?void 0:u.Name,page:n.current,pages:w,callback:nr});case a.SEARCH_EMPTY:return jsx(Mr,{});}},dr=()=>jsxs(Fragment,{children:[jsx(a$f,{id:"file-search",ref:D,placeholder:"Search your images",disabled:l.searchDisabled,callback:$,additionalClasses:"pt-4"}),jsxs("div",{className:"mb-4 mt-4",children:[O&&jsxs(a$h,{type:"danger",onDismiss:()=>{S(!1);},children:[jsx("p",{className:"font-semibold",children:"File could not be uploaded"}),jsx("p",{children:"There was an error uploading the file. Please try again."})]}),l.mode!==a.SEARCH_RESULTS&&l.mode!==a.SEARCH_EMPTY&&!s&&jsx("div",{className:"h-68",children:jsx(se,{uploaded:ce,callback:ze,errorCallback:te})}),(l.mode===a.SEARCH_RESULTS||l.mode===a.SEARCH_EMPTY)&&(A==null?void 0:A.length)>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2",children:`Showing results for..."${A}"`})]}),cr()]});return jsxs(a$c,{show:o,onClose:ve,title:"File Picker",onHide:()=>{},children:[jsxs("div",{className:"h-full",onDragEnter:L,children:[o&&y&&!s&&(()=>jsx("div",{className:"absolute z-50 h-[90.666667%] w-[93.666667%]",children:jsx(se,{uploaded:ce,exitCallback:re,callback:ze,errorCallback:te})}))(),o&&dr()]}),jsxs("div",{className:"bottom-0 grid grid-flow-col grid-cols-2 gap-4 bg-white pt-2 dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$3,{color:"light",onClick:ve,children:"Close"}),jsx(a$3,{color:l.actionBtnColor,onClick:ir,disabled:u==null,children:l.actionBtnTxt})]})]})}He.propTypes={appUrl:X.default.string.isRequired,uri:X.default.string.isRequired,show:X.default.bool.isRequired,hideDrag:X.default.bool,onClose:X.default.func.isRequired,callback:X.default.func.isRequired};He.displayName="FilePicker";function _r(){return jsxs("div",{className:"mt-5 flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(BsFillImageFill,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 text-2xl font-semibold text-gray-900",children:"You Have No Images"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"Images will appear here when you upload them"})]})}function Hr(){return jsx("div",{className:"flex h-2/3 items-center justify-center overflow-y-auto",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(Fr,{})}),jsx("p",{className:"mt-4 text-2xl font-semibold text-gray-900",children:"Loading Files"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"Don't worry, this won't take long..."})]})})}function Mr(){return jsx("div",{className:"flex h-5/6 items-center justify-center overflow-y-auto",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(HiOutlineSearch,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 text-2xl font-semibold text-gray-900",children:"No Files Found"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"No files were found matching your search"})]})})}function Fr(){return jsxs("div",{role:"status",children:[jsxs("svg",{"aria-hidden":"true",className:"inline h-14 w-14 animate-spin fill-blue-600 text-gray-200 dark:text-gray-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]}),jsx("span",{className:"sr-only",children:"Loading..."})]})}function Ur(r){return f$1(this,null,function*(){return new Uint8Array(yield Gr(r))})}function Gr(r){return new Promise((e,o)=>{let s=new FileReader;s.onloadend=v=>e(v.target.result),s.onerror=v=>o(v),s.readAsArrayBuffer(r);})}function Yr(r){return btoa(Array.from(r).map(e=>String.fromCharCode(e)).join(""))}function zr(r){return r.replace(/[^a-z0-9_\.-]/gi,"_").toLowerCase()}var le=e(a$1(),1);function K({title:r,message:e,icon:o,children:s}){return jsx(a$d,{icon:o||jsx(a$e,{}),title:r,text:e,children:s})}K.propTypes={title:le.PropTypes.string.isRequired,message:le.PropTypes.string,useSpinner:le.PropTypes.bool,icon:le.PropTypes.node,children:le.PropTypes.node};K.displayName="TableResultBlock";var ie=e(a$1(),1);var d=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY"}),ye=[{display:"Name",value:"Name"},{display:"Category",value:"Category"},{display:"Product Code",value:"ProductCode"}],tr=Object.freeze({mode:d.LOADING,searchDisabled:!1});function Xr(r,e){switch(e.type){case d.EMPTY:return {mode:d.EMPTY,searchDisabled:!0};case d.LOADING:return tr;case d.LOADED:return {mode:d.LOADED,searchDisabled:!1};case d.SEARCH_RESULTS:return {mode:d.SEARCH_RESULTS,searchDisabled:!1};case d.SEARCH_EMPTY:return {mode:d.SEARCH_EMPTY,searchDisabled:!1};default:throw new Error("Unknown file picker state: "+e.page)}}var Ue=forwardRef(function({preSelected:e=[],onClose:o,productCodeEnabled:s,requestCallback:v,callback:R},D){let l=useRef(),[m,w]=useReducer(Xr,tr),[B,n]=useState(0),y=useRef(1),x=useRef({pages:0,totalEntries:0}),[O,S]=useState(!1),[C,_]=useState({text:"",category:ye[0]}),[H,A]=useState([]),[t,u]=useState(new Set([]));useEffect(()=>{k("",ye[0].value),u(new Set(e));},[]);let k=(c,L)=>{v({SearchText:c||"",PageSize:11,Page:y.current,SearchType:L});};useImperativeHandle(D,()=>({responseHandler:c=>{var L,re;try{c.Result.Data.length>0&&y.current>1?A($=>[...$,...c.Result.Data]):A(c.Result.Data),x.current={pages:c.Result.NumberOfPages,totalEntries:c.Result.Total},n(c.Result.NumberOfPages),((L=C.text)==null?void 0:L.length)>0?w({type:c.Result.Data.length>0?d.SEARCH_RESULTS:d.SEARCH_EMPTY}):w({type:c.Result.Data.length>0?d.LOADED:d.EMPTY}),S(!1);}catch($){console.error("Error fetching products",$),w({type:((re=C.text)==null?void 0:re.length)===0?d.SEARCH_EMPTY:d.EMPTY});}}}));let j=c=>{var $,te;let L=($=c.text)!=null?$:"",re=(te=C.text)!=null?te:"";(L!=re||c.category.value!=C.category.value)&&(y.current=1,w({type:d.LOADING}),k(L,c.category.value)),_({text:L,category:c.category});},ee=()=>{R(Array.from(t));},ce=c=>{switch(c.type){case"FETCH_DATA":S(c.payload),y.current<x.current.pages&&!O&&(S(!0),y.current=y.current+1,k());break;case"SELECTION":t.has(c.payload)?(t.delete(c.payload),u(L=>new Set(L))):(t.add(c.payload),u(L=>new Set(L)));break;case"DESELECT_ALL":u(new Set([]));break;}},G=()=>{switch(m.mode){case d.EMPTY:return jsx(Fe,{title:"You Have No Products",msg:"Your products will appear here"});case d.LOADING:return jsx(Fe,{title:"Loading Products",msg:"Don't worry, this won't take long...",showSpinner:!0});case d.SEARCH_RESULTS:case d.LOADED:return jsx(a$i,{products:H,isMore:y.current<x.current.pages,selected:t,page:y.current,pages:B,callback:ce});case d.SEARCH_EMPTY:return jsx(Fe,{title:"No Products Found",msg:"No products were found matching your search",blockHeight:"h-[460px]"});}},Ne=()=>jsxs(Fragment,{children:[t.size>0&&jsx("div",{className:"mb-4 rounded-md border border-orange-200 bg-yellow-50 p-4",children:jsxs("p",{className:"text-center text-sm text-yellow-800",children:[`${jr("product",t.size,!0)} selected.`,jsx("span",{onClick:()=>ce({type:"DESELECT_ALL",payload:null}),className:"cursor-pointer text-primary-600 hover:underline",children:" Clear Selection."})]})}),jsx(a$f,{id:"file-search",ref:l,categories:s?ye:ye.filter(c=>c.value!=="ProductCode"),placeholder:"Search your products",disabled:m.searchDisabled,callback:j}),jsx("div",{className:"mb-4 mt-4",children:(m.mode===d.SEARCH_RESULTS||m.mode===d.SEARCH_EMPTY)&&C.text.length>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2",children:`Showing results for..."${C.text}"`})}),G()]});return jsxs(a$2,{show:!0,onClose:o,title:"Choose Products",size:"lg",children:[jsx(a$2.Body,{children:jsx("div",{className:"h-full",children:Ne()})}),jsx(a$2.Footer,{children:jsxs("div",{className:"flex-grow grid grid-col-2 grid-flow-col gap-4",children:[jsx(a$3,{color:"light",onClick:o,children:"Close"}),jsx(a$3,{color:"success",onClick:ee,disabled:t.size===0,children:"Add Products"})]})})]})}),Fe=({title:r,msg:e,blockHeight:o="h-[500px]",showSpinner:s=!1})=>jsx("div",{className:`${o} flex items-center justify-center`,children:jsx(K,{icon:!s&&jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:r,message:e,spinner:s})});Ue.propTypes={preSelected:ie.default.array,onClose:ie.default.func.isRequired,productCodeEnabled:ie.default.bool,requestCallback:ie.default.func.isRequired,callback:ie.default.func.isRequired};Ue.displayName="ProductPicker";var ne=e(a$1(),1);var f=Object.freeze({EMPTY:"EMPTY",LOADING:"LOADING",LOADED:"LOADED",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY"}),or=Object.freeze({mode:f.LOADING,searchDisabled:!1});function at(r,e){switch(e.type){case f.EMPTY:return {mode:f.EMPTY,searchDisabled:!0};case f.LOADING:return or;case f.LOADED:return {mode:f.LOADED,searchDisabled:!1};case f.SEARCH_RESULTS:return {mode:f.SEARCH_RESULTS,searchDisabled:!1};case f.SEARCH_EMPTY:return {mode:f.SEARCH_EMPTY,searchDisabled:!1};default:throw new Error("Unknown file picker state: "+e.page)}}function sr({initialLoadComplete:r,allCountryData:e,preSelected:o=[],onClose:s,callback:v}){let[R,D]=useReducer(at,or),[l,m]=useState(""),[w,B]=useState([]),[n,y]=useState([]),x=useRef([]);useEffect(()=>{((e==null?void 0:e.length)>0||r)&&(x.current=e,S(""));},[e]),useEffect(()=>{y(o);},[o]);let O=t=>{var j;let u=(j=t.text)!=null?j:"",k=l!=null?l:"";u!=k&&(D({type:f.LOADING}),S(u)),m(u);},S=t=>{let u=t?x.current.filter(k=>k.Country.toLowerCase().includes(t.toLowerCase())):x.current;(u==null?void 0:u.length)>0?(B(u),D({type:(t==null?void 0:t.length)>0?f.SEARCH_RESULTS:f.LOADED})):(B([]),D({type:(t==null?void 0:t.length)>0?f.SEARCH_EMPTY:f.EMPTY}));},C=()=>{v(n);},_=(t,u)=>{let k=u?n.filter(j=>j.CountryCode!=t.CountryCode):[...n,t];y(k);},H=()=>{switch(R.mode){case f.EMPTY:return jsx(Ye,{title:"No Countries",msg:"Available countries will appear here"});case f.LOADING:return jsx(Ye,{title:"Loading Countries",msg:"Don't worry, this won't take long...",showSpinner:!0});case f.SEARCH_RESULTS:case f.LOADED:return jsx(a$k,{countryData:w,selectedCountries:n,countrySelectCallback:_});case f.SEARCH_EMPTY:return jsx(Ye,{title:"No Countries Found",msg:"No countries were found matching your search",blockHeight:"h-[460px]"});}},A=()=>jsxs(Fragment,{children:[(n==null?void 0:n.length)>0&&jsx("div",{className:"mb-4 rounded-md border border-orange-200 bg-yellow-50 p-4",children:jsxs("p",{className:"text-center text-sm text-yellow-800",children:[`${jr("country",n==null?void 0:n.length,!0)} selected.`,jsx("span",{onClick:()=>y([]),className:"cursor-pointer text-primary-600 hover:underline",children:" Clear Selection."})]})}),jsx(a$f,{id:"locationSearch",placeholder:"Search for countries",disabled:R.searchDisabled,callback:O}),jsx("div",{className:"mb-4 mt-4",children:(R.mode===f.SEARCH_RESULTS||R.mode===f.SEARCH_EMPTY)&&l.length>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2",children:`Showing results for..."${l}"`})}),H()]});return jsxs(a$2,{show:!0,onClose:s,title:"Choose Locations",size:"md",children:[jsx(a$2.Body,{children:jsx("div",{className:"h-full",children:A()})}),jsx(a$2.Footer,{children:jsxs("div",{className:"flex-grow grid grid-col-2 grid-flow-col gap-4",children:[jsx(a$3,{color:"light",onClick:s,children:"Close"}),jsx(a$3,{color:"success",onClick:C,disabled:(n==null?void 0:n.length)===0,children:"Add Locations"})]})})]})}var Ye=({title:r,msg:e,blockHeight:o="h-[500px]",showSpinner:s=!1})=>jsx("div",{className:`${o} flex items-center justify-center`,children:jsx(K,{icon:!s&&jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:r,message:e,spinner:s})});sr.propTypes={initialLoadComplete:ne.default.bool.isRequired,allCountryData:ne.default.array.isRequired,preSelected:ne.default.array.isRequired,onClose:ne.default.func.isRequired,callback:ne.default.func.isRequired};function lr({id:r,title:e,text:o,avatarShow:s,avatarColor:v,avatarBorder:R,children:D,badgeText:l,badgeColor:m,icon:w}){function B(y){var x=y.split(" "),O=x[0],S=x[x.length-1],C=O.charAt(0);if(O!==S)var _=S.charAt(0);else var _="";return C+_}let n=B(e);return jsxs("li",{className:"hover:bg-gray-90 relative flex justify-between gap-x-6 px-4 py-5 dark:hover:bg-gray-900",children:[jsxs("div",{className:"flex min-w-0 flex-auto items-center gap-x-4",children:[s&&jsx(a$g,{placeholderInitials:n,color:v,border:R}),w&&w,jsxs("div",{className:"min-w-0 flex-auto",children:[jsxs("div",{className:"flex gap-2",children:[jsx("p",{className:"truncate text-sm font-semibold text-gray-900 dark:text-white",children:e}),l&&jsx(Badge,{color:m||"info",children:l})]}),jsx("p",{className:"mt-1 flex text-xs text-gray-500 dark:text-gray-400",children:jsx("span",{className:"relative truncate",children:o})})]})]}),jsx("div",{className:"flex flex-shrink-0 items-center gap-x-4",children:jsx("div",{className:"sm:flex sm:flex-col sm:items-end",children:D})})]},r)}lr.displayName="StackedListItem";
32
+ function Je({cardPayment:r,enablePayPal:e}){return jsxs(a$4,{className:"border-0 shadow-sm ",children:[jsx("h3",{className:"text-xl font-semibold dark:text-white",children:"Billing Details"}),jsx("div",{className:"flex items-center justify-between pb-4",children:jsxs("fieldset",{className:"flex w-full flex-col gap-4",id:"radio",children:[jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[e&&jsx(a$5,{id:"creditDebitCard",name:"paymentType",value:"creditDebitCard"}),jsx(a$6,{htmlFor:"creditDebitCard",children:"Pay by Credit or Debit card"})]}),jsxs("div",{className:e?"ml-6 flex gap-2":"flex gap-2",children:[jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/visa.png",alt:"VISA Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/mastercard.png",alt:"MasterCard Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/maestro.png",alt:"Maestro Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/amex.png",alt:"AMEX Card Logo"})]})]}),r&&jsxs(Fragment,{children:[jsxs("div",{className:"grid grid-cols-1 content-start gap-6 md:grid-cols-2",children:[jsx(a$7,{label:"Name on Card *",htmlFor:"nameOnCard",helperText:"This is your name as is appears on the front of your credit or debit card.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"Your name",type:"text",required:!0})}),jsx(a$7,{label:"Card Number *",htmlFor:"cardNumber",helperText:"This is the long number on the front of your credit or debit card.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"0000 0000 0000 0000",type:"number",rightIcon:HiCreditCard,required:!0})})]}),jsxs("div",{className:"grid grid-cols-1 content-start gap-6 sm:grid-cols-3 md:grid-cols-4",children:[jsx(a$7,{label:"Expiry Date *",htmlFor:"nameOnCard",helperText:"The expiry date as it appears on your card.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"MM / YY",type:"text",required:!0})}),jsx(a$7,{label:"Security Code (CVC) *",htmlFor:"cardNumber",helperText:"The last three digits on the back of your card\u2019s signature strip.",children:jsx(a$8,{id:"nameOnCard",name:"nameOnCard",placeholder:"123",type:"text",rightIcon:HiCreditCard,required:!0})}),jsx("img",{className:"mt-7 hidden h-auto w-16 sm:block",src:"https://shared.ekmcdn.com/images/rise/cvc-reminder-image.png",alt:""})]})]}),e&&jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[jsx(a$5,{id:"PayPal",name:"paymentType",value:"PayPal"}),jsx(a$6,{htmlFor:"PayPal",children:"PayPal"})]}),jsx("div",{className:"ml-6",children:jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/paypal.png",alt:"PayPal Icon"})})]})]})})]})}Je.displayName="CardPaymentBlock";function We(){return jsxs(Sidebar.Items,{children:[jsxs(Sidebar.ItemGroup,{children:[jsx(Sidebar.Item,{href:"/",icon:HiChartPie,className:"bg-gray-100 dark:bg-gray-700",children:"Dashboard"}),jsx(Sidebar.Item,{href:"/products",icon:HiTag,className:"",children:"Products"}),jsx(Sidebar.Item,{href:"/orders",icon:HiShoppingBag,label:"27",className:"",children:"Orders"}),jsxs(Sidebar.Collapse,{icon:HiPaintBrush,label:"Design",children:[jsx(Sidebar.Item,{href:"/design/design",className:"",children:"Theme"}),jsx(Sidebar.Item,{href:"/design/editor",className:"",children:"Editor"}),jsx(Sidebar.Item,{href:"/theme/webpages",className:"",children:"Webpages"})]}),jsx(Sidebar.Item,{href:"/features",icon:HiStar,className:"",children:"Features"})]}),jsxs(Sidebar.ItemGroup,{children:[jsx(Sidebar.Item,{href:"https://github.com/themesberg/flowbite-react/",icon:HiDocument,children:"Docs"}),jsx(Sidebar.Item,{href:"https://flowbite-react.com/",icon:HiRocketLaunch,children:"What's New"}),jsx(Sidebar.Item,{href:"https://github.com/themesberg/flowbite-react/issues",icon:HiGlobeAlt,children:"Support Centre"})]})]})}function Cr({children:r,hasHeader:e}){let[o,s]=useState(!1),[v,R]=useState(!1);return useMemo(()=>{a$9()&&!o&&R(!0);},[o]),jsxs(Fragment,{children:[jsx(a$a,{onMenuButtonClick:()=>{s(!o);},showCloseButton:v,avatarImg:"https://avatars.githubusercontent.com/u/49406022?v=4"}),jsxs("div",{className:"flex",children:[jsx(b$1,{collapsed:o,children:jsx(We,{})}),jsxs("div",{className:"flex w-3/4 flex-grow flex-col",children:[jsx("main",{className:`"relative dark:bg-gray-900" flex h-full flex-grow flex-col gap-4 overflow-y-auto bg-gray-50 ${e?"":"p-4"}`,children:r}),jsx(a$b,{companyName:"EKM"})]})]})]})}var q=e(a$1(),1);var b=Object.freeze({NONE:"none",OVER:"drag-over",UPLOADING:"uploading",ERROR:"error",SUCCESS:"success"}),Lr=Object.freeze({[b.NONE]:"border-gray-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-gray-600 dark:hover:border-gray-500 dark:hover:bg-gray-600",[b.OVER]:"border-blue-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-blue-600 dark:hover:border-blue-500 dark:hover:bg-blue-600",[b.UPLOADING]:"border-blue-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-blue-600 dark:hover:border-blue-500 dark:hover:bg-blue-600",[b.ERROR]:"border-red-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-red-600 dark:hover:border-red-500 dark:hover:bg-red-600",[b.SUCCESS]:"border-green-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-green-600 dark:hover:border-green-500 dark:hover:bg-green-600"}),Pr=["png","webp","jpg","gif","jpeg"];function Ke(r,e){let o=!e||e.length===0?Pr:e;if(!r||r.length===0)return !1;let s=r.split(".").pop().toLowerCase();return o.includes(s)}function se({subtitle:r="PNG, WEBP, JPG, JPEG or GIF",filetypes:e,uploaded:o,exitCallback:s,callback:v,errorCallback:R,pickerCallback:D}){let[l,m]=useState(b.NONE);useEffect(()=>{Object.values(b).includes(o)&&(m(o),setTimeout(()=>{o===b.ERROR&&R?R():m(b.NONE);},2e3));},[o]);let w=t=>{t.preventDefault(),m(b.OVER);},B=t=>{t.preventDefault(),s&&s(),m(b.NONE);},n=t=>{t.preventDefault(),Ke(t.dataTransfer.files[0].name,e)?(m(b.UPLOADING),v(t.dataTransfer.files[0])):(m(b.ERROR),setTimeout(()=>{R();},2e3));},x=t=>{Ke(t.target.files[0].name,e)?m(b.UPLOADING):m(b.ERROR),v(t.target.files[0]);},C=()=>{D&&D();},O=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsx(BsCloudUpload,{className:"h-12 w-12 text-gray-400 dark:text-gray-500"}),jsxs("p",{className:"mb-2 mt-5 text-sm text-gray-500 dark:text-gray-400",children:[jsx("span",{className:"font-semibold",children:"Click to upload"})," or drag and drop"]}),jsx("p",{className:"text-xs text-gray-500 dark:text-gray-400",children:r}),D&&jsx("div",{className:"mt-3 mb-3",children:jsxs(a$3,{color:"default",onClick:C,children:[jsx(BiSearch,{className:"mr-2"}),"Browse File Manager"]})})]}),S=()=>jsx("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:jsx("p",{className:"mb-2 mt-5 text-sm text-blue-500 dark:text-blue-400",children:jsx("span",{className:"font-semibold",children:"Drop here to upload"})})}),y=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsxs("svg",{"aria-hidden":"true",className:"mr-2 inline h-10 w-10 animate-spin text-gray-200 dark:text-gray-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]}),jsx("p",{className:"mb-2 mt-5 text-sm text-blue-500 dark:text-blue-400",children:jsx("span",{className:"font-semibold",children:"Uploading..."})})]}),_=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsx(FaTimesCircle,{className:"h-12 w-12 text-red-400 dark:text-red-500"}),jsx("p",{className:"mb-2 mt-5 text-sm text-red-500 dark:text-red-400",children:jsx("span",{className:"font-semibold",children:"Unable to upload"})})]}),H=()=>jsxs("div",{className:"flex flex-col items-center justify-center pb-6 pt-5",children:[jsx(BsFillCheckCircleFill,{className:"h-12 w-12 text-green-400 dark:text-green-500"}),jsx("p",{className:"mb-2 mt-5 text-sm text-green-500 dark:text-green-400",children:jsx("span",{className:"font-semibold",children:"Uploaded"})})]}),A=()=>{switch(l){case b.OVER:return S();case b.UPLOADING:return y();case b.ERROR:return _();case b.SUCCESS:return H();default:return O()}};return jsx("div",{onDragEnter:t=>t.preventDefault(),onDragOver:w,onDrop:n,onDragLeave:B,className:"flex h-full w-full items-center justify-center",children:jsxs("label",{htmlFor:"dropzone-file",className:`flex h-full w-full cursor-pointer flex-col items-center justify-center rounded-lg border-2 border-dashed ${Lr[l]}`,children:[A(),l===b.NONE&&jsx("input",{id:"dropzone-file",type:"file",className:"hidden",onChange:x})]})})}se.propTypes={filetypes:q.default.arrayOf(q.default.string),subtitle:q.default.string,uploaded:q.default.oneOf(["none","success","error"]).isRequired,exitCallback:q.default.func,errorCallback:q.default.func.isRequired,callback:q.default.func.isRequired,pickerCallback:q.default.func};se.displayName="DragAndDrop";var X=e(a$1(),1);var er="/admin/api/common/directoryinformation/",a=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",LOADED_NO_DRAG:"LOADED_NO_DRAG",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY",UPLOAD_ERROR:"ERROR",DRAGGING:"DRAGGING"}),Tr=Object.freeze({mode:a.LOADING,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1});function Br(r,e){switch(e.type){case a.EMPTY:return {mode:a.EMPTY,actionBtnTxt:"Add Image",actionBtnColor:"default",listSize:"h-5/6",listBorder:"",searchDisabled:!0};case a.LOADING:return Tr;case a.LOADED:return {mode:a.LOADED,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[68.666667%]",listBorder:"border",searchDisabled:!1};case a.LOADED_NO_DRAG:return {mode:a.LOADED_NO_DRAG,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[85%]",listBorder:"border",searchDisabled:!1};case a.SEARCH_RESULTS:return {mode:a.SEARCH_RESULTS,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case a.SEARCH_EMPTY:return {mode:a.SEARCH_EMPTY,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+e.page)}}function He({appUrl:r,uri:e,show:o,hideDrag:s=!1,onClose:v,callback:R}){let D=useRef(),[l,m]=useReducer(Br,{mode:a.LOADING,footerBorder:"border-t"}),[w,B]=useState(0),n=useRef(1),[x,C]=useState(!1),[O,S]=useState(!1),y=useRef({pages:0,totalEntries:0}),[_,H]=useState(!1),[A,t]=useState(""),[u,k]=useState(null),[j,ee]=useState([]),[ce,G]=useState("none");useEffect(()=>{o&&(m({type:a.LOADING}),k(null),y.current={pages:0,totalEntries:0},Ne(),c(""));},[o]),useEffect(()=>{u&&k(null),O&&S(!1);},[l.mode]);let Ne=()=>{ee([]),G("none"),H(!1),k(null),S(!1),t(""),n.current=1;},c=p=>f$1(this,null,function*(){let M=n.current;try{let J=(p==null?void 0:p.length)>0?`&FileNameIncludesString=${p}`:"&FileNameIncludesString=",Y=yield (yield fetch(`${r}${er}?CurrentPage=${M}&PageSize=10&Uri=${e}${J}`,{method:"GET",credentials:"same-origin",headers:{"Content-Type":"application/json"}})).json();if(Y.Items.Data.length>0&&M>1?ee(Re=>[...Re,...Y.Items.Data]):ee(Y.Items.Data),y.current={pages:Y.Items.NumberOfPages,totalEntries:Y.Items.Total},B(Y.Items.NumberOfPages),(p==null?void 0:p.length)>0)m({type:Y.Items.Data.length>0?a.SEARCH_RESULTS:a.SEARCH_EMPTY});else {let Re=s?a.LOADED_NO_DRAG:a.LOADED;m({type:Y.Items.Data.length>0?Re:a.EMPTY});}G("none"),H(!1),C(!1);}catch(J){m({type:(p==null?void 0:p.length)===0?a.SEARCH_EMPTY:a.EMPTY});}}),L=p=>{s||(C(!0),D.current.removeFocus(),p.preventDefault());},re=p=>{s||C(!1);},$=p=>{var de;let M=(de=p.text)!=null?de:"",J=A!=null?A:"";t(M),(J.length>0&&M.length===0||J.length===0&&M.length>0&&l.mode!==a.LOADING)&&m({type:a.LOADING}),n.current=1,O&&S(!1),c(M);},te=()=>{S(!0),C(!1),G("none");},ir=()=>{R(`https://files.ekmcdn.com/${u.Uri}`),ve();},ve=()=>{v();},ze=p=>f$1(this,null,function*(){if(p==null){G("error"),te();return}try{let M=zr(p.name),J=yield Ur(p),de={Path:`/${e}/`,Name:M,Bytes:Yr(J),ForceOverwriteFile:!0};(yield fetch(`${r}${er}`,{method:"POST",credentials:"same-origin",headers:{"Content-Type":"application/json"},body:JSON.stringify(de)})).status===200?(G("success"),t(""),D.current.clear(),n.current=1,ee([]),S(!1),c("")):G("error");}catch(M){G("error");}}),nr=p=>{switch(p.type){case"FETCH_DATA":H(p.payload),n.current<y.current.pages&&!_&&(H(!0),n.current=n.current+1,c(A));break;case"SELECTION":k(p.payload),S(!1);break;}},cr=()=>{switch(l.mode){case a.EMPTY:return jsx(_r,{});case a.LOADING:return jsx(Hr,{});case a.SEARCH_RESULTS:case a.LOADED:case a.LOADED_NO_DRAG:return jsx(a$j,{border:l.listSize,files:j,isMore:n.current<y.current.pages,selected:u==null?void 0:u.Name,page:n.current,pages:w,callback:nr});case a.SEARCH_EMPTY:return jsx(Mr,{});}},dr=()=>jsxs(Fragment,{children:[jsx(a$f,{id:"file-search",ref:D,placeholder:"Search your images",disabled:l.searchDisabled,callback:$,additionalClasses:"pt-4"}),jsxs("div",{className:"mb-4 mt-4",children:[O&&jsxs(a$h,{type:"danger",onDismiss:()=>{S(!1);},children:[jsx("p",{className:"font-semibold",children:"File could not be uploaded"}),jsx("p",{children:"There was an error uploading the file. Please try again."})]}),l.mode!==a.SEARCH_RESULTS&&l.mode!==a.SEARCH_EMPTY&&!s&&jsx("div",{className:"h-68",children:jsx(se,{uploaded:ce,callback:ze,errorCallback:te})}),(l.mode===a.SEARCH_RESULTS||l.mode===a.SEARCH_EMPTY)&&(A==null?void 0:A.length)>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2",children:`Showing results for..."${A}"`})]}),cr()]});return jsxs(a$c,{show:o,onClose:ve,title:"File Picker",onHide:()=>{},children:[jsxs("div",{className:"h-full",onDragEnter:L,children:[o&&x&&!s&&(()=>jsx("div",{className:"absolute z-50 h-[90.666667%] w-[93.666667%]",children:jsx(se,{uploaded:ce,exitCallback:re,callback:ze,errorCallback:te})}))(),o&&dr()]}),jsxs("div",{className:"bottom-0 grid grid-flow-col grid-cols-2 gap-4 bg-white pt-2 dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$3,{color:"light",onClick:ve,children:"Close"}),jsx(a$3,{color:l.actionBtnColor,onClick:ir,disabled:u==null,children:l.actionBtnTxt})]})]})}He.propTypes={appUrl:X.default.string.isRequired,uri:X.default.string.isRequired,show:X.default.bool.isRequired,hideDrag:X.default.bool,onClose:X.default.func.isRequired,callback:X.default.func.isRequired};He.displayName="FilePicker";function _r(){return jsxs("div",{className:"mt-5 flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(BsFillImageFill,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 text-2xl font-semibold text-gray-900",children:"You Have No Images"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"Images will appear here when you upload them"})]})}function Hr(){return jsx("div",{className:"flex h-2/3 items-center justify-center overflow-y-auto",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(Fr,{})}),jsx("p",{className:"mt-4 text-2xl font-semibold text-gray-900",children:"Loading Files"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"Don't worry, this won't take long..."})]})})}function Mr(){return jsx("div",{className:"flex h-5/6 items-center justify-center overflow-y-auto",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(HiOutlineSearch,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 text-2xl font-semibold text-gray-900",children:"No Files Found"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"No files were found matching your search"})]})})}function Fr(){return jsxs("div",{role:"status",children:[jsxs("svg",{"aria-hidden":"true",className:"inline h-14 w-14 animate-spin fill-blue-600 text-gray-200 dark:text-gray-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]}),jsx("span",{className:"sr-only",children:"Loading..."})]})}function Ur(r){return f$1(this,null,function*(){return new Uint8Array(yield Gr(r))})}function Gr(r){return new Promise((e,o)=>{let s=new FileReader;s.onloadend=v=>e(v.target.result),s.onerror=v=>o(v),s.readAsArrayBuffer(r);})}function Yr(r){return btoa(Array.from(r).map(e=>String.fromCharCode(e)).join(""))}function zr(r){return r.replace(/[^a-z0-9_\.-]/gi,"_").toLowerCase()}var le=e(a$1(),1);function K({title:r,message:e,icon:o,children:s}){return jsx(a$d,{icon:o||jsx(a$e,{}),title:r,text:e,children:s})}K.propTypes={title:le.PropTypes.string.isRequired,message:le.PropTypes.string,useSpinner:le.PropTypes.bool,icon:le.PropTypes.node,children:le.PropTypes.node};K.displayName="TableResultBlock";var ie=e(a$1(),1);var d=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY"}),ye=[{display:"Name",value:"Name"},{display:"Category",value:"Category"},{display:"Product Code",value:"ProductCode"}],tr=Object.freeze({mode:d.LOADING,searchDisabled:!1});function Xr(r,e){switch(e.type){case d.EMPTY:return {mode:d.EMPTY,searchDisabled:!0};case d.LOADING:return tr;case d.LOADED:return {mode:d.LOADED,searchDisabled:!1};case d.SEARCH_RESULTS:return {mode:d.SEARCH_RESULTS,searchDisabled:!1};case d.SEARCH_EMPTY:return {mode:d.SEARCH_EMPTY,searchDisabled:!1};default:throw new Error("Unknown file picker state: "+e.page)}}var Ue=forwardRef(function({preSelected:e=[],onClose:o,productCodeEnabled:s,requestCallback:v,callback:R},D){let l=useRef(),[m,w]=useReducer(Xr,tr),[B,n]=useState(0),x=useRef(1),C=useRef({pages:0,totalEntries:0}),[O,S]=useState(!1),[y,_]=useState({text:"",category:ye[0]}),[H,A]=useState([]),[t,u]=useState(new Set([]));useEffect(()=>{k("",ye[0].value),u(new Set(e));},[]);let k=(c,L)=>{v({SearchText:c||"",PageSize:11,Page:x.current,SearchType:L});};useImperativeHandle(D,()=>({responseHandler:c=>{var L,re;try{c.Result.Data.length>0&&x.current>1?A($=>[...$,...c.Result.Data]):A(c.Result.Data),C.current={pages:c.Result.NumberOfPages,totalEntries:c.Result.Total},n(c.Result.NumberOfPages),((L=y.text)==null?void 0:L.length)>0?w({type:c.Result.Data.length>0?d.SEARCH_RESULTS:d.SEARCH_EMPTY}):w({type:c.Result.Data.length>0?d.LOADED:d.EMPTY}),S(!1);}catch($){console.error("Error fetching products",$),w({type:((re=y.text)==null?void 0:re.length)===0?d.SEARCH_EMPTY:d.EMPTY});}}}));let j=c=>{var $,te;let L=($=c.text)!=null?$:"",re=(te=y.text)!=null?te:"";(L!=re||c.category.value!=y.category.value)&&(x.current=1,w({type:d.LOADING}),k(L,c.category.value)),_({text:L,category:c.category});},ee=()=>{R(Array.from(t));},ce=c=>{switch(c.type){case"FETCH_DATA":S(c.payload),x.current<C.current.pages&&!O&&(S(!0),x.current=x.current+1,k(y.text,y.category.value));break;case"SELECTION":t.has(c.payload)?(t.delete(c.payload),u(L=>new Set(L))):(t.add(c.payload),u(L=>new Set(L)));break;case"DESELECT_ALL":u(new Set([]));break;}},G=()=>{switch(m.mode){case d.EMPTY:return jsx(Fe,{title:"You Have No Products",msg:"Your products will appear here"});case d.LOADING:return jsx(Fe,{title:"Loading Products",msg:"Don't worry, this won't take long...",showSpinner:!0});case d.SEARCH_RESULTS:case d.LOADED:return jsx(a$i,{products:H,isMore:x.current<C.current.pages,selected:t,page:x.current,pages:B,callback:ce});case d.SEARCH_EMPTY:return jsx(Fe,{title:"No Products Found",msg:"No products were found matching your search",blockHeight:"h-[460px]"});}},Ne=()=>jsxs(Fragment,{children:[t.size>0&&jsx("div",{className:"mb-4 rounded-md border border-orange-200 bg-yellow-50 p-4",children:jsxs("p",{className:"text-center text-sm text-yellow-800",children:[`${jr("product",t.size,!0)} selected.`,jsx("span",{id:"btnClear",onClick:()=>ce({type:"DESELECT_ALL",payload:null}),className:"cursor-pointer text-primary-600 hover:underline",children:" Clear Selection."})]})}),jsx(a$f,{id:"file-search",ref:l,categories:s?ye:ye.filter(c=>c.value!=="ProductCode"),placeholder:"Search your products",disabled:m.searchDisabled,callback:j}),jsx("div",{className:"mb-4 mt-4",children:(m.mode===d.SEARCH_RESULTS||m.mode===d.SEARCH_EMPTY)&&y.text.length>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2",children:`Showing results for..."${y.text}"`})}),G()]});return jsxs(a$2,{show:!0,onClose:o,title:"Choose Products",size:"lg",id:"productSelectModal",children:[jsx(a$2.Body,{children:jsx("div",{className:"h-full",children:Ne()})}),jsx(a$2.Footer,{children:jsxs("div",{className:"flex-grow grid grid-col-2 grid-flow-col gap-4",children:[jsx(a$3,{id:"btnClose",color:"light",onClick:o,children:"Close"}),jsx(a$3,{id:"btnAdd",color:"success",onClick:ee,disabled:t.size===0,children:"Add Products"})]})})]})}),Fe=({title:r,msg:e,blockHeight:o="h-[500px]",showSpinner:s=!1})=>jsx("div",{className:`${o} flex items-center justify-center`,children:jsx(K,{icon:!s&&jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:r,message:e,spinner:s})});Ue.propTypes={preSelected:ie.default.array,onClose:ie.default.func.isRequired,productCodeEnabled:ie.default.bool,requestCallback:ie.default.func.isRequired,callback:ie.default.func.isRequired};Ue.displayName="ProductPicker";var ne=e(a$1(),1);var f=Object.freeze({EMPTY:"EMPTY",LOADING:"LOADING",LOADED:"LOADED",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY"}),or=Object.freeze({mode:f.LOADING,searchDisabled:!1});function at(r,e){switch(e.type){case f.EMPTY:return {mode:f.EMPTY,searchDisabled:!0};case f.LOADING:return or;case f.LOADED:return {mode:f.LOADED,searchDisabled:!1};case f.SEARCH_RESULTS:return {mode:f.SEARCH_RESULTS,searchDisabled:!1};case f.SEARCH_EMPTY:return {mode:f.SEARCH_EMPTY,searchDisabled:!1};default:throw new Error("Unknown file picker state: "+e.page)}}function sr({initialLoadComplete:r,allCountryData:e,preSelected:o=[],onClose:s,callback:v}){let[R,D]=useReducer(at,or),[l,m]=useState(""),[w,B]=useState([]),[n,x]=useState([]),C=useRef([]);useEffect(()=>{((e==null?void 0:e.length)>0||r)&&(C.current=e,S(""));},[e]),useEffect(()=>{x(o);},[o]);let O=t=>{var j;let u=(j=t.text)!=null?j:"",k=l!=null?l:"";u!=k&&(D({type:f.LOADING}),S(u)),m(u);},S=t=>{let u=t?C.current.filter(k=>k.Country.toLowerCase().includes(t.toLowerCase())):C.current;(u==null?void 0:u.length)>0?(B(u),D({type:(t==null?void 0:t.length)>0?f.SEARCH_RESULTS:f.LOADED})):(B([]),D({type:(t==null?void 0:t.length)>0?f.SEARCH_EMPTY:f.EMPTY}));},y=()=>{v(n);},_=(t,u)=>{let k=u?n.filter(j=>j.CountryCode!=t.CountryCode):[...n,t];x(k);},H=()=>{switch(R.mode){case f.EMPTY:return jsx(Ye,{title:"No Countries",msg:"Available countries will appear here"});case f.LOADING:return jsx(Ye,{title:"Loading Countries",msg:"Don't worry, this won't take long...",showSpinner:!0});case f.SEARCH_RESULTS:case f.LOADED:return jsx(a$k,{countryData:w,selectedCountries:n,countrySelectCallback:_});case f.SEARCH_EMPTY:return jsx(Ye,{title:"No Countries Found",msg:"No countries were found matching your search",blockHeight:"h-[460px]"});}},A=()=>jsxs(Fragment,{children:[(n==null?void 0:n.length)>0&&jsx("div",{className:"mb-4 rounded-md border border-orange-200 bg-yellow-50 p-4",children:jsxs("p",{className:"text-center text-sm text-yellow-800",children:[`${jr("country",n==null?void 0:n.length,!0)} selected.`,jsx("span",{onClick:()=>x([]),className:"cursor-pointer text-primary-600 hover:underline",children:" Clear Selection."})]})}),jsx(a$f,{id:"locationSearch",placeholder:"Search for countries",disabled:R.searchDisabled,callback:O}),jsx("div",{className:"mb-4 mt-4",children:(R.mode===f.SEARCH_RESULTS||R.mode===f.SEARCH_EMPTY)&&l.length>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2",children:`Showing results for..."${l}"`})}),H()]});return jsxs(a$2,{show:!0,onClose:s,title:"Choose Locations",size:"md",children:[jsx(a$2.Body,{children:jsx("div",{className:"h-full",children:A()})}),jsx(a$2.Footer,{children:jsxs("div",{className:"flex-grow grid grid-col-2 grid-flow-col gap-4",children:[jsx(a$3,{color:"light",onClick:s,children:"Close"}),jsx(a$3,{color:"success",onClick:y,disabled:(n==null?void 0:n.length)===0,children:"Add Locations"})]})})]})}var Ye=({title:r,msg:e,blockHeight:o="h-[500px]",showSpinner:s=!1})=>jsx("div",{className:`${o} flex items-center justify-center`,children:jsx(K,{icon:!s&&jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:r,message:e,spinner:s})});sr.propTypes={initialLoadComplete:ne.default.bool.isRequired,allCountryData:ne.default.array.isRequired,preSelected:ne.default.array.isRequired,onClose:ne.default.func.isRequired,callback:ne.default.func.isRequired};function lr({id:r,title:e,text:o,avatarShow:s,avatarColor:v,avatarBorder:R,children:D,badgeText:l,badgeColor:m,icon:w}){function B(x){var C=x.split(" "),O=C[0],S=C[C.length-1],y=O.charAt(0);if(O!==S)var _=S.charAt(0);else var _="";return y+_}let n=B(e);return jsxs("li",{className:"hover:bg-gray-90 relative flex justify-between gap-x-6 px-4 py-5 dark:hover:bg-gray-900",children:[jsxs("div",{className:"flex min-w-0 flex-auto items-center gap-x-4",children:[s&&jsx(a$g,{placeholderInitials:n,color:v,border:R}),w&&w,jsxs("div",{className:"min-w-0 flex-auto",children:[jsxs("div",{className:"flex gap-2",children:[jsx("p",{className:"truncate text-sm font-semibold text-gray-900 dark:text-white",children:e}),l&&jsx(Badge,{color:m||"info",children:l})]}),jsx("p",{className:"mt-1 flex text-xs text-gray-500 dark:text-gray-400",children:jsx("span",{className:"relative truncate",children:o})})]})]}),jsx("div",{className:"flex flex-shrink-0 items-center gap-x-4",children:jsx("div",{className:"sm:flex sm:flex-col sm:items-end",children:D})})]},r)}lr.displayName="StackedListItem";
33
33
 
34
34
  export { lr as a, Cr as b, se as c, He as d, K as e, Ue as f, sr as g, Je as h };
35
35
  //# sourceMappingURL=out.js.map
36
- //# sourceMappingURL=chunk-E2DMQCPM.js.map
36
+ //# sourceMappingURL=chunk-JB5PNJCD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/stacked-list-item.tsx","../src/card-payment-block.tsx","../src/layout/layout.tsx","../shared/sidebar-items.tsx","../src/drag-and-drop.tsx","../src/file-picker/file-picker.tsx","../src/table-result-block.tsx","../src/product-picker/product-modal.tsx","../src/country-picker/country-modal.tsx"],"names":["Badge","HiCreditCard","Fragment","jsx","jsxs","CardPaymentBlock","cardPayment","enablePayPal","Card","Radio","Label","FormRow","TextInput","useMemo","useState","Sidebar","HiChartPie","HiDocument","HiGlobeAlt","HiPaintBrush","HiShoppingBag","HiTag","HiRocketLaunch","HiStar","SidebarItems","currentPage","Layout","children","hasHeader","isSidebarCollapsed","setIsSidebarCollapsed","showNavbarCloseButton","setShowNavbarCloseButton","is_small_screen_default","Navbar","LoveFooter","import_prop_types","useEffect","BiSearch","BsCloudUpload","BsFillCheckCircleFill","FaTimesCircle","DragStates","DragStateClasses","defaultFileTypes","isValidFormat","filename","filetypes","ftypes","ext","DragAndDrop","subtitle","uploaded","exitCallback","callback","errorCallback","pickerCallback","dragState","setDragState","handleDragOver","e","handleDragExit","handleDrop","handleFileSelection","handleLaunchFilePicker","renderNormalState","Button","renderOverState","renderUploadingState","renderErrorState","renderSuccessState","renderViewState","PropTypes","useReducer","useRef","BsFillImageFill","HiOutlineSearch","apiUrl","Status","initialState","FilePickerReducer","state","action","FilePicker","appUrl","uri","show","hideDrag","onClose","searchFieldRef","dispatch","totalPages","setTotalPages","currentPageRef","dragging","setDragging","err","setErr","listAttributeRef","fetchData","setFetchData","search","setSearch","selected","setSelected","files","setFiles","uploadedImage","setUploadedImage","clearState","getFiles","searchText","__async","page","searchUri","data","loadedState","error","handleDragEnter","handleDragLeave","handleSearchRequest","searchTerm","_a","text","s","handleDropError","handleUseImage","handleClose","handleFileUpload","file","newName","sanitiseFilename","arr","getAsByteArray","payload","getBase64","handleListActions","calculateListSize","renderList","EmptyPlaceholder","LoadingPlaceholder","Listing","SearchEmptyPlaceholder","renderContent","Search","AlertBanner","Drawer","Spinner","readFile","resolve","reject","reader","event","b","fileName","TableResultBlock","title","message","icon","NoResultsBlock","pluralize","forwardRef","useImperativeHandle","HiClipboardList","searchCategories","ProductPickerReducer","ProductPicker","preSelected","productCodeEnabled","requestCallback","ref","products","setProducts","getProducts","searchCategory","response","_b","newSearchText","oldSearchText","handleProductSelection","prevState","NoResultsView","Modal","msg","blockHeight","showSpinner","CountryPickerReducer","CountryPicker","initialLoadComplete","allCountryData","displayedCountries","setDisplayedCountries","selectedCountries","setSelectedCountries","allCountriesRef","performSearch","newCountries","c","handleAddLocations","handleCountrySelection","details","CountryListing","StackedListItem","id","avatarShow","avatarColor","avatarBorder","badgeText","badgeColor","getFirstAndLastLetters","str","words","firstWord","lastWord","firstLetter","lastLetter","avatarLetters","Avatar"],"mappings":"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","sourcesContent":["//@ts-nocheck\nimport { Badge } from \"flowbite-react\";\nimport { Avatar } from \"./\";\n\ntype Props = {\n id: number;\n title: string;\n text?: string | JSX.Element;\n avatarShow?: boolean;\n avatarColor?: string;\n avatarBorder?: string;\n children?: JSX.Element;\n badgeColor?: string;\n badgeText?: string;\n icon?: JSX.Element;\n};\n\nexport function StackedListItem({\n id,\n title,\n text,\n avatarShow,\n avatarColor,\n avatarBorder,\n children,\n badgeText,\n badgeColor,\n icon,\n}: Props) {\n function getFirstAndLastLetters(str: string) {\n var words = str.split(\" \");\n var firstWord = words[0];\n var lastWord = words[words.length - 1];\n var firstLetter = firstWord.charAt(0);\n if (firstWord !== lastWord) {\n var lastLetter = lastWord.charAt(0);\n } else {\n var lastLetter = \"\";\n }\n return firstLetter + lastLetter;\n }\n\n let avatarLetters = getFirstAndLastLetters(title);\n\n return (\n <li\n key={id}\n className=\"hover:bg-gray-90 relative flex justify-between gap-x-6 px-4 py-5 dark:hover:bg-gray-900\"\n >\n <div className=\"flex min-w-0 flex-auto items-center gap-x-4\">\n {avatarShow && (\n <Avatar\n placeholderInitials={avatarLetters}\n color={avatarColor}\n border={avatarBorder}\n />\n )}\n {icon && icon}\n <div className=\"min-w-0 flex-auto\">\n <div className=\"flex gap-2\">\n <p className=\"truncate text-sm font-semibold text-gray-900 dark:text-white\">\n {title}\n </p>\n {badgeText && (\n <Badge color={badgeColor || \"info\"}>{badgeText}</Badge>\n )}\n </div>\n <p className=\"mt-1 flex text-xs text-gray-500 dark:text-gray-400\">\n <span className=\"relative truncate\">{text}</span>\n </p>\n </div>\n </div>\n <div className=\"flex flex-shrink-0 items-center gap-x-4\">\n <div className=\"sm:flex sm:flex-col sm:items-end\">{children}</div>\n </div>\n </li>\n );\n}\n\nStackedListItem.displayName = \"StackedListItem\";\n","// @ts-nocheck\nimport { FormRow } from \"./index\";\nimport { HiCreditCard } from \"react-icons/hi\";\nimport { TextInput } from \"./textinput\";\nimport { Card } from \"./card\";\nimport { Label } from \"./label\";\nimport { Radio } from \"./radio\";\n\nexport function CardPaymentBlock({\n cardPayment,\n enablePayPal,\n}: {\n cardPayment?: boolean;\n enablePayPal?: boolean;\n}) {\n return (\n <Card className=\"border-0 shadow-sm\t\">\n <h3 className=\"text-xl font-semibold dark:text-white\">Billing Details</h3>\n <div className=\"flex items-center justify-between pb-4\">\n <fieldset className=\"flex w-full flex-col gap-4\" id=\"radio\">\n <div className=\"flex flex-col gap-2\">\n <div className=\"flex items-center gap-2\">\n {enablePayPal && (\n <Radio\n id=\"creditDebitCard\"\n name=\"paymentType\"\n value=\"creditDebitCard\"\n />\n )}\n\n <Label htmlFor=\"creditDebitCard\">\n Pay by Credit or Debit card\n </Label>\n </div>\n <div className={enablePayPal ? \"ml-6 flex gap-2\" : \"flex gap-2\"}>\n <img\n src=\"https://shared.ekmcdn.com/images/uifw/cards/visa.png\"\n alt=\"VISA Card Logo\"\n />\n <img\n src=\"https://shared.ekmcdn.com/images/uifw/cards/mastercard.png\"\n alt=\"MasterCard Card Logo\"\n />\n <img\n src=\"https://shared.ekmcdn.com/images/uifw/cards/maestro.png\"\n alt=\"Maestro Card Logo\"\n />\n <img\n src=\"https://shared.ekmcdn.com/images/uifw/cards/amex.png\"\n alt=\"AMEX Card Logo\"\n />\n </div>\n </div>\n {cardPayment && (\n <>\n <div className=\"grid grid-cols-1 content-start gap-6 md:grid-cols-2\">\n <FormRow\n label=\"Name on Card *\"\n htmlFor=\"nameOnCard\"\n helperText=\"This is your name as is appears on the front of your credit or debit card.\"\n >\n <TextInput\n id=\"nameOnCard\"\n name=\"nameOnCard\"\n placeholder=\"Your name\"\n type=\"text\"\n required\n />\n </FormRow>\n <FormRow\n label=\"Card Number *\"\n htmlFor=\"cardNumber\"\n helperText=\"This is the long number on the front of your credit or debit card.\"\n >\n <TextInput\n id=\"nameOnCard\"\n name=\"nameOnCard\"\n placeholder=\"0000 0000 0000 0000\"\n type=\"number\"\n rightIcon={HiCreditCard}\n required\n />\n </FormRow>\n </div>\n <div className=\"grid grid-cols-1 content-start gap-6 sm:grid-cols-3 md:grid-cols-4\">\n <FormRow\n label=\"Expiry Date *\"\n htmlFor=\"nameOnCard\"\n helperText=\"The expiry date as it appears on your card.\"\n >\n <TextInput\n id=\"nameOnCard\"\n name=\"nameOnCard\"\n placeholder=\"MM / YY\"\n type=\"text\"\n required\n />\n </FormRow>\n <FormRow\n label=\"Security Code (CVC) *\"\n htmlFor=\"cardNumber\"\n helperText=\"The last three digits on the back of your card’s signature strip.\"\n >\n <TextInput\n id=\"nameOnCard\"\n name=\"nameOnCard\"\n placeholder=\"123\"\n type=\"text\"\n rightIcon={HiCreditCard}\n required\n />\n </FormRow>\n <img\n className=\"mt-7 hidden h-auto w-16 sm:block\"\n src=\"https://shared.ekmcdn.com/images/rise/cvc-reminder-image.png\"\n alt=\"\"\n />\n </div>\n </>\n )}\n {enablePayPal && (\n <div className=\"flex flex-col gap-2\">\n <div className=\"flex items-center gap-2\">\n <Radio id=\"PayPal\" name=\"paymentType\" value=\"PayPal\" />\n <Label htmlFor=\"PayPal\">PayPal</Label>\n </div>\n <div className=\"ml-6\">\n <img\n src=\"https://shared.ekmcdn.com/images/uifw/cards/paypal.png\"\n alt=\"PayPal Icon\"\n />\n </div>\n </div>\n )}\n </fieldset>\n </div>\n </Card>\n );\n}\n\nCardPaymentBlock.displayName = \"CardPaymentBlock\";\n","import { useMemo, useState } from \"react\";\nimport { LoveFooter, Navbar, Sidebar } from \"../\";\nimport { SidebarItems } from \"../../shared/sidebar-items\";\nimport isSmallScreen from \"../helpers/is-small-screen\";\n\ntype Props = {\n children: JSX.Element;\n hasHeader?: boolean;\n};\n\nexport function Layout({ children, hasHeader }: Props) {\n const [isSidebarCollapsed, setIsSidebarCollapsed] = useState(false);\n const [showNavbarCloseButton, setShowNavbarCloseButton] = useState(false);\n\n useMemo(() => {\n if (isSmallScreen() && !isSidebarCollapsed) {\n setShowNavbarCloseButton(true);\n }\n }, [isSidebarCollapsed]);\n\n return (\n <>\n <Navbar\n onMenuButtonClick={() => {\n setIsSidebarCollapsed(!isSidebarCollapsed);\n }}\n showCloseButton={showNavbarCloseButton}\n avatarImg=\"https://avatars.githubusercontent.com/u/49406022?v=4\"\n />\n <div className=\"flex\">\n <Sidebar collapsed={isSidebarCollapsed}>\n <SidebarItems />\n </Sidebar>\n <div className=\"flex w-3/4 flex-grow flex-col\">\n <main\n className={`\"relative dark:bg-gray-900\" flex h-full flex-grow flex-col gap-4 overflow-y-auto bg-gray-50 ${\n !hasHeader ? \"p-4\" : \"\"\n }`}\n >\n {children}\n </main>\n <LoveFooter companyName=\"EKM\" />\n </div>\n </div>\n </>\n );\n}\n","import { Sidebar } from \"flowbite-react\";\n\nimport {\n HiChartPie,\n HiClipboard,\n HiDocument,\n HiGlobeAlt,\n HiPaintBrush,\n HiShoppingBag,\n HiTag,\n HiRocketLaunch,\n HiStar,\n} from \"react-icons/hi2\";\n\nexport function SidebarItems() {\n const currentPage = \"/\" as string;\n return (\n <Sidebar.Items>\n <Sidebar.ItemGroup>\n <Sidebar.Item\n href=\"/\"\n icon={HiChartPie}\n className={\"/\" === currentPage ? \"bg-gray-100 dark:bg-gray-700\" : \"\"}\n >\n Dashboard\n </Sidebar.Item>\n <Sidebar.Item\n href=\"/products\"\n icon={HiTag}\n className={\n \"/products\" === currentPage ? \"bg-gray-100 dark:bg-gray-700\" : \"\"\n }\n >\n Products\n </Sidebar.Item>\n <Sidebar.Item\n href=\"/orders\"\n icon={HiShoppingBag}\n label=\"27\"\n className={\n \"/orders\" === currentPage ? \"bg-gray-100 dark:bg-gray-700\" : \"\"\n }\n >\n Orders\n </Sidebar.Item>\n <Sidebar.Collapse icon={HiPaintBrush} label=\"Design\">\n <Sidebar.Item\n href=\"/design/design\"\n className={\n \"/design/theme\" === currentPage\n ? \"bg-gray-100 dark:bg-gray-700\"\n : \"\"\n }\n >\n Theme\n </Sidebar.Item>\n <Sidebar.Item\n href=\"/design/editor\"\n className={\n \"/e-commerce/billing\" === currentPage\n ? \"bg-gray-100 dark:bg-gray-700\"\n : \"\"\n }\n >\n Editor\n </Sidebar.Item>\n <Sidebar.Item\n href=\"/theme/webpages\"\n className={\n \"/e-commerce/invoice\" === currentPage\n ? \"bg-gray-100 dark:bg-gray-700\"\n : \"\"\n }\n >\n Webpages\n </Sidebar.Item>\n </Sidebar.Collapse>\n <Sidebar.Item\n href=\"/features\"\n icon={HiStar}\n className={\n \"/features\" === currentPage ? \"bg-gray-100 dark:bg-gray-700\" : \"\"\n }\n >\n Features\n </Sidebar.Item>\n </Sidebar.ItemGroup>\n <Sidebar.ItemGroup>\n <Sidebar.Item\n href=\"https://github.com/themesberg/flowbite-react/\"\n icon={HiDocument}\n >\n Docs\n </Sidebar.Item>\n <Sidebar.Item href=\"https://flowbite-react.com/\" icon={HiRocketLaunch}>\n What's New\n </Sidebar.Item>\n <Sidebar.Item\n href=\"https://github.com/themesberg/flowbite-react/issues\"\n icon={HiGlobeAlt}\n >\n Support Centre\n </Sidebar.Item>\n </Sidebar.ItemGroup>\n </Sidebar.Items>\n );\n}\n","// @ts-nocheck\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport { BiSearch } from \"react-icons/bi\";\nimport { BsCloudUpload, BsFillCheckCircleFill } from \"react-icons/bs\";\nimport { FaTimesCircle } from \"react-icons/fa\";\nimport { Button } from \"./index\";\n\nconst DragStates = Object.freeze({\n NONE: \"none\",\n OVER: \"drag-over\",\n UPLOADING: \"uploading\",\n ERROR: \"error\",\n SUCCESS: \"success\",\n});\n\nconst DragStateClasses = Object.freeze({\n [DragStates.NONE]:\n \"border-gray-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-gray-600 dark:hover:border-gray-500 dark:hover:bg-gray-600\",\n [DragStates.OVER]:\n \"border-blue-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-blue-600 dark:hover:border-blue-500 dark:hover:bg-blue-600\",\n [DragStates.UPLOADING]:\n \"border-blue-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-blue-600 dark:hover:border-blue-500 dark:hover:bg-blue-600\",\n [DragStates.ERROR]:\n \"border-red-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-red-600 dark:hover:border-red-500 dark:hover:bg-red-600\",\n [DragStates.SUCCESS]:\n \"border-green-300 bg-gray-50 dark:hover:bg-gray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-green-600 dark:hover:border-green-500 dark:hover:bg-green-600\",\n});\n\nconst defaultFileTypes = [\"png\", \"webp\", \"jpg\", \"gif\", \"jpeg\"];\n\nfunction isValidFormat(filename, filetypes) {\n let ftypes =\n !filetypes || filetypes.length === 0 ? defaultFileTypes : filetypes;\n if (!filename || filename.length === 0) return false;\n\n let ext = filename.split(\".\").pop().toLowerCase();\n return ftypes.includes(ext);\n}\n\nexport function DragAndDrop({\n subtitle = \"PNG, WEBP, JPG, JPEG or GIF\",\n filetypes,\n uploaded,\n exitCallback,\n callback,\n errorCallback,\n pickerCallback,\n}) {\n const [dragState, setDragState] = useState(DragStates.NONE);\n\n useEffect(() => {\n let exists = Object.values(DragStates).includes(uploaded);\n\n if (exists) {\n setDragState(uploaded);\n setTimeout(() => {\n if (uploaded === DragStates.ERROR && errorCallback) {\n errorCallback();\n } else {\n // may need to do this only if not in file picker mode\n //NOTE: May need to add a file picker mode!\n setDragState(DragStates.NONE);\n }\n }, 2000);\n }\n }, [uploaded]);\n\n const handleDragOver = (e) => {\n e.preventDefault();\n setDragState(DragStates.OVER);\n };\n\n const handleDragExit = (e) => {\n e.preventDefault();\n if (exitCallback) exitCallback();\n setDragState(DragStates.NONE);\n };\n\n const handleDrop = (e) => {\n e.preventDefault();\n if (isValidFormat(e.dataTransfer.files[0].name, filetypes)) {\n setDragState(DragStates.UPLOADING);\n callback(e.dataTransfer.files[0]);\n } else {\n setDragState(DragStates.ERROR);\n setTimeout(() => {\n errorCallback();\n }, 2000);\n }\n };\n\n const handleFileSelection = (e) => {\n isValidFormat(e.target.files[0].name, filetypes)\n ? setDragState(DragStates.UPLOADING)\n : setDragState(DragStates.ERROR);\n callback(e.target.files[0]);\n };\n\n const handleLaunchFilePicker = () => {\n if (pickerCallback) pickerCallback();\n };\n const renderNormalState = () => (\n <div className=\"flex flex-col items-center justify-center pb-6 pt-5\">\n <BsCloudUpload className=\"h-12 w-12 text-gray-400 dark:text-gray-500\" />\n <p className=\"mb-2 mt-5 text-sm text-gray-500 dark:text-gray-400\">\n <span className=\"font-semibold\">Click to upload</span> or drag and drop\n </p>\n <p className=\"text-xs text-gray-500 dark:text-gray-400\">{subtitle}</p>\n {pickerCallback && (\n <div className=\"mt-3 mb-3\">\n <Button color=\"default\" onClick={handleLaunchFilePicker}>\n <BiSearch className=\"mr-2\" />\n Browse File Manager\n </Button>\n </div>\n )}\n </div>\n );\n\n const renderOverState = () => (\n <div className=\"flex flex-col items-center justify-center pb-6 pt-5\">\n <p className=\"mb-2 mt-5 text-sm text-blue-500 dark:text-blue-400\">\n <span className=\"font-semibold\">Drop here to upload</span>\n </p>\n </div>\n );\n\n const renderUploadingState = () => (\n <div className=\"flex flex-col items-center justify-center pb-6 pt-5\">\n <svg\n aria-hidden=\"true\"\n className=\"mr-2 inline h-10 w-10 animate-spin text-gray-200 dark:text-gray-600\"\n viewBox=\"0 0 100 101\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z\"\n fill=\"currentFill\"\n />\n </svg>\n <p className=\"mb-2 mt-5 text-sm text-blue-500 dark:text-blue-400\">\n <span className=\"font-semibold\">Uploading...</span>\n </p>\n </div>\n );\n\n const renderErrorState = () => (\n <div className=\"flex flex-col items-center justify-center pb-6 pt-5\">\n <FaTimesCircle className=\"h-12 w-12 text-red-400 dark:text-red-500\" />\n <p className=\"mb-2 mt-5 text-sm text-red-500 dark:text-red-400\">\n <span className=\"font-semibold\">Unable to upload</span>\n </p>\n </div>\n );\n\n const renderSuccessState = () => (\n <div className=\"flex flex-col items-center justify-center pb-6 pt-5\">\n <BsFillCheckCircleFill className=\"h-12 w-12 text-green-400 dark:text-green-500\" />\n <p className=\"mb-2 mt-5 text-sm text-green-500 dark:text-green-400\">\n <span className=\"font-semibold\">Uploaded</span>\n </p>\n </div>\n );\n\n const renderViewState = () => {\n switch (dragState) {\n case DragStates.OVER:\n return renderOverState();\n case DragStates.UPLOADING:\n return renderUploadingState();\n case DragStates.ERROR:\n return renderErrorState();\n case DragStates.SUCCESS:\n return renderSuccessState();\n default:\n return renderNormalState();\n }\n };\n\n return (\n <div\n onDragEnter={(e) => e.preventDefault()}\n onDragOver={handleDragOver}\n onDrop={handleDrop}\n onDragLeave={handleDragExit}\n className=\"flex h-full w-full items-center justify-center\"\n >\n <label\n htmlFor=\"dropzone-file\"\n className={`flex h-full w-full cursor-pointer flex-col items-center justify-center rounded-lg border-2 border-dashed ${DragStateClasses[dragState]}`}\n >\n {renderViewState()}\n {dragState === DragStates.NONE && (\n <input\n id=\"dropzone-file\"\n type=\"file\"\n className=\"hidden\"\n onChange={handleFileSelection}\n />\n )}\n </label>\n </div>\n );\n}\n\nDragAndDrop.propTypes = {\n /** Array of stings which contain the allowed file types that the component will accept */\n filetypes: PropTypes.arrayOf(PropTypes.string),\n /** displays subtitle on dropzone */\n subtitle: PropTypes.string,\n /** send the outcome of the upload process back to the drag and drop component */\n uploaded: PropTypes.oneOf([\"none\", \"success\", \"error\"]).isRequired,\n\n /** Returns when mouse exists the drop-zone. This provides an actionable trigger seperate to the callback */\n exitCallback: PropTypes.func,\n /** Returns when a file fails the internal validation check. This provides an actionable trigger seperate to both the exitcallback and callback */\n errorCallback: PropTypes.func.isRequired,\n /** Returns the image file */\n callback: PropTypes.func.isRequired,\n /** Returns when the file picker button is clicked */\n pickerCallback: PropTypes.func,\n};\n\nDragAndDrop.displayName = \"DragAndDrop\";\n","// @ts-nocheck\nimport PropTypes from \"prop-types\";\nimport { useEffect, useReducer, useRef, useState } from \"react\";\nimport { BsFillImageFill } from \"react-icons/bs\";\nimport { HiOutlineSearch } from \"react-icons/hi\";\nimport { AlertBanner } from \"../alert-banner\";\nimport { Button } from \"../button\";\nimport { DragAndDrop } from \"../drag-and-drop\";\nimport { Drawer } from \"../drawer\";\nimport { Search } from \"../search/search\";\nimport Listing from \"./file-listing\";\n\nconst apiUrl = \"/admin/api/common/directoryinformation/\";\nconst Status = Object.freeze({\n EMPTY: \"EMPTY\",\n SEARCH_LOADING: \"SEARCH-LOADING\",\n LOADING: \"LOADING\",\n LOADED: \"LOADED\",\n LOADED_NO_DRAG: \"LOADED_NO_DRAG\",\n SEARCH_RESULTS: \"SEARCH-RESULTS\",\n SEARCH_EMPTY: \"SEARCH-EMPTY\",\n UPLOAD_ERROR: \"ERROR\",\n DRAGGING: \"DRAGGING\",\n});\n\nconst initialState = Object.freeze({\n mode: Status.LOADING,\n actionBtnTxt: \"I Accept\",\n actionBtnColor: \"success\",\n listSize: \"h-5/6\",\n listBorder: \"\",\n searchDisabled: false,\n});\n\nfunction FilePickerReducer(state, action) {\n switch (action.type) {\n case Status.EMPTY:\n return {\n mode: Status.EMPTY,\n actionBtnTxt: 'Add Image',\n actionBtnColor: 'default',\n listSize: 'h-5/6',\n listBorder: '',\n searchDisabled: true,\n };\n case Status.LOADING:\n return initialState;\n case Status.LOADED:\n return {\n mode: Status.LOADED,\n actionBtnTxt: \"I Accept\",\n actionBtnColor: \"success\",\n listSize: \"h-[68.666667%]\",\n listBorder: \"border\",\n searchDisabled: false,\n };\n case Status.LOADED_NO_DRAG:\n return {\n mode: Status.LOADED_NO_DRAG,\n actionBtnTxt: \"I Accept\",\n actionBtnColor: \"success\",\n listSize: \"h-[85%]\",\n listBorder: \"border\",\n searchDisabled: false,\n };\n case Status.SEARCH_RESULTS:\n return {\n mode: Status.SEARCH_RESULTS,\n actionBtnTxt: \"I Accept\",\n actionBtnColor: \"success\",\n listSize: \"h-5/6\",\n listBorder: \"border\",\n searchDisabled: false,\n };\n case Status.SEARCH_EMPTY:\n return {\n mode: Status.SEARCH_EMPTY,\n actionBtnTxt: \"I Accept\",\n actionBtnColor: \"success\",\n listSize: \"h-5/6\",\n listBorder: \"\",\n searchDisabled: false,\n };\n default:\n throw new Error(\"Unknown file picker state: \" + action.page ?? \"\");\n }\n}\n\nexport function FilePicker({\n appUrl,\n uri,\n show,\n hideDrag = false,\n onClose,\n callback,\n}) {\n const searchFieldRef = useRef();\n const [state, dispatch] = useReducer(FilePickerReducer, {\n mode: Status.LOADING,\n footerBorder: \"border-t\",\n });\n const [totalPages, setTotalPages] = useState(0);\n const currentPageRef = useRef(1);\n const [dragging, setDragging] = useState(false);\n const [err, setErr] = useState(false);\n const listAttributeRef = useRef({ pages: 0, totalEntries: 0 });\n const [fetchData, setFetchData] = useState(false);\n const [search, setSearch] = useState('');\n const [selected, setSelected] = useState(null);\n const [files, setFiles] = useState([]);\n const [uploadedImage, setUploadedImage] = useState(\"none\");\n\n useEffect(() => {\n // Workaround to ensure the drawer is cleared when it is first opened as its always on the DOM!\n if (show) {\n dispatch({ type: Status.LOADING });\n setSelected(null);\n listAttributeRef.current = { pages: 0, totalEntries: 0 };\n clearState();\n getFiles('');\n }\n }, [show]);\n\n useEffect(() => {\n if (selected) setSelected(null);\n if (err) setErr(false);\n }, [state.mode]);\n\n const clearState = () => {\n setFiles([]);\n setUploadedImage(\"none\");\n setFetchData(false);\n setSelected(null);\n setErr(false);\n setSearch('')\n currentPageRef.current = 1\n };\n\n const getFiles = async (searchText) => {\n const page = currentPageRef.current\n try {\n const searchUri =\n searchText?.length > 0\n ? `&FileNameIncludesString=${searchText}`\n : `&FileNameIncludesString=`;\n const response = await fetch(\n `${appUrl}${apiUrl}?CurrentPage=${page}&PageSize=10&Uri=${uri}${searchUri}`,\n {\n method: \"GET\",\n credentials: \"same-origin\",\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n const data = await response.json();\n if (data.Items.Data.length > 0 && page > 1) {\n setFiles((files) => [...files, ...data.Items.Data]);\n } else {\n setFiles(data.Items.Data);\n }\n\n listAttributeRef.current = {\n pages: data.Items.NumberOfPages,\n totalEntries: data.Items.Total,\n };\n setTotalPages(data.Items.NumberOfPages);\n\n if (searchText?.length > 0) {\n dispatch({\n type:\n data.Items.Data.length > 0\n ? Status.SEARCH_RESULTS\n : Status.SEARCH_EMPTY,\n });\n } else {\n const loadedState = hideDrag ? Status.LOADED_NO_DRAG : Status.LOADED;\n dispatch({\n type: data.Items.Data.length > 0 ? loadedState : Status.EMPTY,\n });\n }\n\n setUploadedImage(\"none\");\n\n setFetchData(false);\n setDragging(false);\n } catch (error) {\n dispatch({\n type: searchText?.length === 0 ? Status.SEARCH_EMPTY : Status.EMPTY,\n });\n }\n };\n\n const handleDragEnter = (e) => {\n if (hideDrag) return\n setDragging(true)\n searchFieldRef.current.removeFocus()\n e.preventDefault()\n }\n\n const handleDragLeave = (e) => {\n if (hideDrag) return\n setDragging(false)\n }\n\n const handleSearchRequest = (searchTerm) => {\n const text = searchTerm.text ?? \"\";\n const s = search ?? \"\";\n setSearch(text);\n if (\n (s.length > 0 && text.length === 0) ||\n (s.length === 0 && text.length > 0 && state.mode !== Status.LOADING)\n )\n dispatch({ type: Status.LOADING });\n currentPageRef.current = 1;\n if (err) setErr(false);\n getFiles(text)\n };\n\n const handleDropError = () => {\n setErr(true);\n setDragging(false);\n setUploadedImage(\"none\");\n };\n\n const handleUseImage = () => {\n callback(`https://files.ekmcdn.com/${selected.Uri}`);\n handleClose();\n };\n\n const handleClose = () => {\n onClose();\n };\n\n const handleFileUpload = async (file) => {\n if (file == null) {\n setUploadedImage(\"error\");\n handleDropError();\n return;\n }\n\n try {\n const newName = sanitiseFilename(file.name)\n const arr = await getAsByteArray(file)\n const payload = {\n Path: `/${uri}/`,\n Name: newName,\n Bytes: getBase64(arr),\n ForceOverwriteFile: true,\n };\n const res = await fetch(`${appUrl}${apiUrl}`, {\n method: \"POST\",\n credentials: \"same-origin\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify(payload),\n });\n\n if (res.status === 200) {\n setUploadedImage(\"success\");\n setSearch('');\n searchFieldRef.current.clear();\n currentPageRef.current = 1\n setFiles([]);\n setErr(false);\n getFiles('');\n } else {\n setUploadedImage(\"error\");\n }\n } catch (error) {\n setUploadedImage(\"error\");\n }\n };\n\n const handleListActions = (action) => {\n switch (action.type) {\n case \"FETCH_DATA\":\n setFetchData(action.payload);\n if (\n currentPageRef.current < listAttributeRef.current.pages &&\n !fetchData\n ) {\n // pass in the current page + 1 to get the next page of data then change state as the state is not updated immediately\n setFetchData(true);\n currentPageRef.current = currentPageRef.current + 1;\n getFiles(search);\n }\n break;\n case \"SELECTION\":\n setSelected(action.payload);\n setErr(false);\n break;\n default:\n break;\n }\n };\n\n const calculateListSize = () => {\n if (!err) return state.listSize;\n\n if (state.mode === Status.LOADED) return \"h-2/4\";\n if (\n state.mode === Status.SEARCH_RESULTS ||\n state.mode === Status.LOADED_NO_DRAG\n ) {\n return \"h-2/3\";\n } else {\n return state.listSize;\n }\n };\n\n const renderList = () => {\n switch (state.mode) {\n case Status.EMPTY:\n return <EmptyPlaceholder />;\n case Status.LOADING:\n return <LoadingPlaceholder />;\n case Status.SEARCH_RESULTS:\n case Status.LOADED:\n case Status.LOADED_NO_DRAG:\n return (\n <Listing\n border={state.listSize}\n files={files}\n isMore={currentPageRef.current < listAttributeRef.current.pages}\n selected={selected?.Name}\n page={currentPageRef.current}\n pages={totalPages}\n callback={handleListActions}\n />\n );\n case Status.SEARCH_EMPTY:\n return <SearchEmptyPlaceholder />;\n default:\n break;\n }\n };\n\n const renderContent = () => (\n <>\n <Search\n id=\"file-search\"\n ref={searchFieldRef}\n placeholder=\"Search your images\"\n disabled={state.searchDisabled}\n callback={handleSearchRequest}\n additionalClasses=\"pt-4\"\n />\n <div className=\"mb-4 mt-4\">\n {err && (\n <AlertBanner\n type=\"danger\"\n onDismiss={() => {\n setErr(false);\n }}\n >\n <p className=\"font-semibold\">File could not be uploaded</p>\n <p>There was an error uploading the file. Please try again.</p>\n </AlertBanner>\n )}\n {state.mode !== Status.SEARCH_RESULTS &&\n state.mode !== Status.SEARCH_EMPTY &&\n !hideDrag && (\n <div className=\"h-68\">\n <DragAndDrop\n uploaded={uploadedImage}\n callback={handleFileUpload}\n errorCallback={handleDropError}\n />\n </div>\n )}\n {(state.mode === Status.SEARCH_RESULTS ||\n state.mode === Status.SEARCH_EMPTY) &&\n search?.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2\">{`Showing results for...\"${search}\"`}</span>\n )}\n </div>\n\n {renderList()}\n </>\n );\n\n const renderOversizedDropZone = () => (\n <div className=\"absolute z-50 h-[90.666667%] w-[93.666667%]\">\n <DragAndDrop\n uploaded={uploadedImage}\n exitCallback={handleDragLeave}\n callback={handleFileUpload}\n errorCallback={handleDropError}\n />\n </div>\n );\n\n return (\n <Drawer\n show={show}\n onClose={handleClose}\n title=\"File Picker\"\n onHide={() => {}}\n >\n <div className=\"h-full\" onDragEnter={handleDragEnter}>\n {show && dragging && !hideDrag && renderOversizedDropZone()}\n {show && renderContent()}\n </div>\n <div\n className={`bottom-0 grid grid-flow-col grid-cols-2 gap-4 bg-white pt-2 dark:border-gray-600`}\n style={{ marginTop: \"-50px\" }}\n >\n <Button color=\"light\" onClick={handleClose}>\n Close\n </Button>\n <Button\n color={state.actionBtnColor}\n onClick={handleUseImage}\n disabled={selected == null}\n >\n {state.actionBtnTxt}\n </Button>\n </div>\n </Drawer>\n );\n}\n\nFilePicker.propTypes = {\n /** The url of the app */\n appUrl: PropTypes.string.isRequired,\n /** The uri of the folder to display */\n uri: PropTypes.string.isRequired,\n /** Show the drawer */\n show: PropTypes.bool.isRequired,\n /** Hides the the drag and drop and associated functionality */\n hideDrag: PropTypes.bool,\n /** Callback to close the drawer */\n onClose: PropTypes.func.isRequired,\n /** Callback to return the selected image */\n callback: PropTypes.func.isRequired,\n};\n\nFilePicker.displayName = \"FilePicker\";\n\n// HELPER FUNCTIONAL COMPONENTS FOR FILE PICKER\nfunction EmptyPlaceholder() {\n return (\n <div className=\"mt-5 flex flex-col items-center justify-center\">\n <h1>\n <BsFillImageFill className=\"text-9xl text-gray-700\" />\n </h1>\n <p className=\"mt-4 text-2xl font-semibold text-gray-900\">\n You Have No Images\n </p>\n <p className=\"mt-4 text-sm text-gray-500\">\n Images will appear here when you upload them\n </p>\n </div>\n );\n}\n\nfunction LoadingPlaceholder() {\n return (\n <div className=\"flex h-2/3 items-center justify-center overflow-y-auto\">\n <div className=\"flex flex-col items-center justify-center\">\n <h1>\n <Spinner />\n </h1>\n <p className=\"mt-4 text-2xl font-semibold text-gray-900\">\n Loading Files\n </p>\n <p className=\"mt-4 text-sm text-gray-500\">\n Don't worry, this won't take long...\n </p>\n </div>\n </div>\n );\n}\n\nfunction SearchEmptyPlaceholder() {\n return (\n <div className=\"flex h-5/6 items-center justify-center overflow-y-auto\">\n <div className=\"flex flex-col items-center justify-center\">\n <h1>\n <HiOutlineSearch className=\"text-9xl text-gray-700\" />\n </h1>\n <p className=\"mt-4 text-2xl font-semibold text-gray-900\">\n No Files Found\n </p>\n <p className=\"mt-4 text-sm text-gray-500\">\n No files were found matching your search\n </p>\n </div>\n </div>\n );\n}\n\nfunction Spinner() {\n return (\n <div role=\"status\">\n <svg\n aria-hidden=\"true\"\n className=\"inline h-14 w-14 animate-spin fill-blue-600 text-gray-200 dark:text-gray-600\"\n viewBox=\"0 0 100 101\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z\"\n fill=\"currentFill\"\n />\n </svg>\n <span className=\"sr-only\">Loading...</span>\n </div>\n );\n}\n\n// HELPER FUNCTIONS FOR FILE PICKER\n\nasync function getAsByteArray(file) {\n return new Uint8Array(await readFile(file));\n}\n\nfunction readFile(file) {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onloadend = (event) => resolve(event.target.result);\n reader.onerror = (err) => reject(err);\n reader.readAsArrayBuffer(file);\n });\n}\n\nfunction getBase64(data) {\n // Helper Funtions to convert a file to a base 64 byte array.\n return btoa(\n Array.from(data)\n .map((b) => String.fromCharCode(b))\n .join(\"\")\n );\n}\n\nfunction sanitiseFilename(fileName) {\n return fileName.replace(/[^a-z0-9_\\.-]/gi, '_').toLowerCase()\n}\n","//@ts-nocheck\nimport { PropTypes } from \"prop-types\";\nimport { NoResultsBlock, Spinner } from \".\";\n\nexport function TableResultBlock({ title, message, icon, children }) {\n return (\n <NoResultsBlock\n icon={icon ? icon : <Spinner />}\n title={title}\n text={message}\n >\n {children}\n </NoResultsBlock>\n );\n}\n\nTableResultBlock.propTypes = {\n /** Main title for block */\n title: PropTypes.string.isRequired,\n /** sub title to display */\n message: PropTypes.string,\n /** true and the spinner will be shown use spinner or search icon */\n useSpinner: PropTypes.bool,\n icon: PropTypes.node,\n children: PropTypes.node,\n};\n\nTableResultBlock.displayName = \"TableResultBlock\";\n","// @ts-nocheck\nimport pluralize from \"pluralize\";\nimport PropTypes from \"prop-types\";\nimport {\n forwardRef,\n useEffect,\n useImperativeHandle,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { HiClipboardList } from \"react-icons/hi\";\nimport { Button } from \"../button\";\nimport { Search } from \"../search/search\";\nimport { TableResultBlock } from \"../table-result-block\";\nimport { Listing } from \"./product-listing\";\nimport { Modal } from \"../modal\";\n\nconst Status = Object.freeze({\n EMPTY: \"EMPTY\",\n SEARCH_LOADING: \"SEARCH-LOADING\",\n LOADING: \"LOADING\",\n LOADED: \"LOADED\",\n SEARCH_RESULTS: \"SEARCH-RESULTS\",\n SEARCH_EMPTY: \"SEARCH-EMPTY\",\n});\n\nconst searchCategories = [\n {\n display: \"Name\",\n value: \"Name\",\n },\n {\n display: \"Category\",\n value: \"Category\",\n },\n {\n display: \"Product Code\",\n value: \"ProductCode\",\n },\n];\n\nconst initialState = Object.freeze({\n mode: Status.LOADING,\n searchDisabled: false,\n});\n\nfunction ProductPickerReducer(state, action) {\n switch (action.type) {\n case Status.EMPTY:\n return {\n mode: Status.EMPTY,\n searchDisabled: true,\n };\n case Status.LOADING:\n return initialState;\n case Status.LOADED:\n return {\n mode: Status.LOADED,\n searchDisabled: false,\n };\n case Status.SEARCH_RESULTS:\n return {\n mode: Status.SEARCH_RESULTS,\n searchDisabled: false,\n };\n case Status.SEARCH_EMPTY:\n return {\n mode: Status.SEARCH_EMPTY,\n searchDisabled: false,\n };\n default:\n throw new Error(\"Unknown file picker state: \" + action.page ?? \"\");\n }\n}\n\n/**\n * IMPORTANT TO NOTE\n * The parent/calling component is responsible for fetching the products. This component should not really know\n * what the products are, just how to display them. This means that searching and pagination logic should also\n * be handled by the parent/calling component eg: fetching the products and passing them to this component.\n */\n\nexport const ProductPicker = forwardRef(function ProductPicker(\n { preSelected = [], onClose, productCodeEnabled, requestCallback, callback },\n ref\n) {\n const searchFieldRef = useRef();\n const [state, dispatch] = useReducer(ProductPickerReducer, initialState);\n const [totalPages, setTotalPages] = useState(0);\n const currentPageRef = useRef(1);\n const listAttributeRef = useRef({ pages: 0, totalEntries: 0 });\n const [fetchData, setFetchData] = useState(false);\n const [search, setSearch] = useState({\n text: \"\",\n category: searchCategories[0],\n });\n const [products, setProducts] = useState([]);\n // Selected State\n const [selected, setSelected] = useState(new Set([]))\n\n useEffect(() => {\n getProducts('', searchCategories[0].value);\n setSelected(new Set(preSelected))\n }, []);\n\n const getProducts = (searchText, searchCategory) => {\n requestCallback({\n SearchText: searchText || '',\n PageSize: 11,\n Page: currentPageRef.current,\n SearchType: searchCategory,\n });\n };\n\n useImperativeHandle(ref, () => ({\n responseHandler: (response) => {\n try {\n if (response.Result.Data.length > 0 && currentPageRef.current > 1) {\n setProducts((products) => [...products, ...response.Result.Data]);\n } else {\n setProducts(response.Result.Data);\n }\n\n listAttributeRef.current = {\n pages: response.Result.NumberOfPages,\n totalEntries: response.Result.Total,\n };\n setTotalPages(response.Result.NumberOfPages);\n\n if (search.text?.length > 0) {\n dispatch({\n type:\n response.Result.Data.length > 0\n ? Status.SEARCH_RESULTS\n : Status.SEARCH_EMPTY,\n });\n } else {\n dispatch({\n type:\n response.Result.Data.length > 0 ? Status.LOADED : Status.EMPTY,\n });\n }\n setFetchData(false);\n } catch (error) {\n console.error(\"Error fetching products\", error);\n dispatch({\n type: search.text?.length === 0 ? Status.SEARCH_EMPTY : Status.EMPTY,\n });\n }\n },\n }));\n\n const handleSearchRequest = (searchTerm) => {\n const newSearchText = searchTerm.text ?? \"\";\n const oldSearchText = search.text ?? \"\";\n if (newSearchText != oldSearchText || searchTerm.category.value != search.category.value) {\n currentPageRef.current = 1;\n dispatch({ type: Status.LOADING });\n getProducts(newSearchText, searchTerm.category.value)\n }\n setSearch({text: newSearchText, category: searchTerm.category});\n };\n\n const handleProductSelection = () => {\n callback(Array.from(selected));\n };\n\n const handleListActions = (action) => {\n switch (action.type) {\n case \"FETCH_DATA\":\n setFetchData(action.payload);\n if (\n currentPageRef.current < listAttributeRef.current.pages &&\n !fetchData\n ) {\n // pass in the current page + 1 to get the next page of data then change state as the state is not updated immediately\n setFetchData(true);\n currentPageRef.current = currentPageRef.current + 1;\n getProducts(search.text, search.category.value);\n }\n break;\n case \"SELECTION\":\n if (selected.has(action.payload)) {\n selected.delete(action.payload)\n setSelected(prevState => new Set(prevState)) \n } else {\n selected.add(action.payload)\n setSelected(prevState => new Set(prevState))\n }\n break;\n case \"DESELECT_ALL\":\n setSelected(new Set([]))\n break;\n default:\n break;\n }\n };\n\n const renderList = () => {\n switch (state.mode) {\n case Status.EMPTY:\n return (\n <NoResultsView\n title=\"You Have No Products\"\n msg=\"Your products will appear here\"\n />\n );\n case Status.LOADING:\n return (\n <NoResultsView\n title=\"Loading Products\"\n msg=\"Don't worry, this won't take long...\"\n showSpinner={true}\n />\n );\n case Status.SEARCH_RESULTS:\n case Status.LOADED:\n return (\n <Listing\n products={products}\n isMore={currentPageRef.current < listAttributeRef.current.pages}\n selected={selected}\n page={currentPageRef.current}\n pages={totalPages}\n callback={handleListActions}\n />\n );\n case Status.SEARCH_EMPTY:\n return (\n <NoResultsView\n title=\"No Products Found\"\n msg=\"No products were found matching your search\"\n blockHeight=\"h-[460px]\"\n />\n );\n\n default:\n break;\n }\n };\n\n const renderContent = () => (\n <>\n {selected.size > 0 && (\n <div className=\"mb-4 rounded-md border border-orange-200 bg-yellow-50 p-4\">\n <p className=\"text-center text-sm text-yellow-800\">\n {`${pluralize(\"product\", selected.size, true)} selected.`}\n <span\n id=\"btnClear\"\n onClick={() =>\n handleListActions({ type: \"DESELECT_ALL\", payload: null })\n }\n className=\"cursor-pointer text-primary-600 hover:underline\"\n >{` Clear Selection.`}</span>\n </p>\n </div>\n )}\n <Search\n id=\"file-search\"\n ref={searchFieldRef}\n categories={ productCodeEnabled ? searchCategories : searchCategories.filter(c => c.value !== 'ProductCode')}\n placeholder=\"Search your products\"\n disabled={state.searchDisabled}\n callback={handleSearchRequest}\n />\n <div className=\"mb-4 mt-4\">\n {(state.mode === Status.SEARCH_RESULTS ||\n state.mode === Status.SEARCH_EMPTY) &&\n search.text.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2\">{`Showing results for...\"${search.text}\"`}</span>\n )}\n </div>\n {renderList()}\n </>\n );\n\n return (\n <Modal\n show={true}\n onClose={onClose}\n title=\"Choose Products\"\n size=\"lg\"\n id=\"productSelectModal\"\n >\n <Modal.Body>\n <div className=\"h-full\">{renderContent()}</div>\n </Modal.Body>\n <Modal.Footer>\n <div className={`flex-grow grid grid-col-2 grid-flow-col gap-4`}>\n <Button id=\"btnClose\" color=\"light\" onClick={onClose}>\n Close\n </Button>\n <Button\n id=\"btnAdd\"\n color=\"success\"\n onClick={handleProductSelection}\n disabled={selected.size === 0}\n >\n Add Products\n </Button>\n </div>\n </Modal.Footer> \n </Modal>\n );\n});\n\nconst NoResultsView =({title, msg, blockHeight=\"h-[500px]\", showSpinner = false}) => {\n return (\n <div className={`${blockHeight} flex items-center justify-center`}>\n <TableResultBlock\n icon={!showSpinner && <HiClipboardList className=\"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400\" />}\n title={title}\n message={msg}\n spinner={showSpinner}\n />\n </div>\n )\n}\n\nProductPicker.propTypes = {\n /** Array of integers representing the product id's of currently selected products */\n preSelected: PropTypes.array,\n /** Callback to close the drawer */\n onClose: PropTypes.func.isRequired,\n /** Whether product codes are enabled on the shop */\n productCodeEnabled: PropTypes.bool,\n /** Callback to request a refresh of the displayed products */\n requestCallback: PropTypes.func.isRequired,\n /** Callback to return the selected products ids in an array */\n callback: PropTypes.func.isRequired,\n};\n\nProductPicker.displayName = \"ProductPicker\";\n","// @ts-nocheck\nimport pluralize from \"pluralize\";\nimport PropTypes from \"prop-types\";\nimport {\n useEffect,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { HiClipboardList } from \"react-icons/hi\";\nimport { Button } from \"../button\";\nimport { Search } from \"../search/search\";\nimport { TableResultBlock } from \"../table-result-block\";\nimport { Modal } from \"../modal\";\nimport { CountryListing } from \"./country-listing\";\n\nconst Status = Object.freeze({\n EMPTY: \"EMPTY\",\n LOADING: \"LOADING\",\n LOADED: \"LOADED\",\n SEARCH_RESULTS: \"SEARCH-RESULTS\",\n SEARCH_EMPTY: \"SEARCH-EMPTY\",\n});\n\nconst initialState = Object.freeze({\n mode: Status.LOADING,\n searchDisabled: false,\n});\n\nfunction CountryPickerReducer(state, action) {\n switch (action.type) {\n case Status.EMPTY:\n return {\n mode: Status.EMPTY,\n searchDisabled: true,\n };\n case Status.LOADING:\n return initialState;\n case Status.LOADED:\n return {\n mode: Status.LOADED,\n searchDisabled: false,\n };\n case Status.SEARCH_RESULTS:\n return {\n mode: Status.SEARCH_RESULTS,\n searchDisabled: false,\n };\n case Status.SEARCH_EMPTY:\n return {\n mode: Status.SEARCH_EMPTY,\n searchDisabled: false,\n };\n default:\n throw new Error(\"Unknown file picker state: \" + action.page ?? \"\");\n }\n}\n\nexport function CountryPicker({initialLoadComplete, allCountryData, preSelected = [], \n onClose, callback}) {\n const [state, dispatch] = useReducer(CountryPickerReducer, initialState);\n const [search, setSearch] = useState(\"\");\n const [displayedCountries, setDisplayedCountries] = useState([]);\n // Selected State\n const [selectedCountries, setSelectedCountries] = useState([])\n const allCountriesRef = useRef([])\n\n useEffect(() => {\n if (allCountryData?.length > 0 || initialLoadComplete) {\n allCountriesRef.current = allCountryData\n performSearch('')\n }\n }, [allCountryData])\n\n useEffect(() => {\n setSelectedCountries(preSelected)\n }, [preSelected])\n\n const handleSearchRequest = (searchTerm) => {\n const newSearchText = searchTerm.text ?? \"\";\n const oldSearchText = search ?? \"\";\n if (newSearchText != oldSearchText) {\n dispatch({ type: Status.LOADING });\n performSearch(newSearchText)\n }\n setSearch(newSearchText);\n };\n\n const performSearch = (searchText) => {\n const newCountries = searchText ? allCountriesRef.current.filter(c => c.Country.toLowerCase().includes(searchText.toLowerCase())) :\n allCountriesRef.current\n if (newCountries?.length > 0) {\n setDisplayedCountries(newCountries)\n dispatch({type: searchText?.length > 0 ? Status.SEARCH_RESULTS : Status.LOADED})\n } else {\n setDisplayedCountries([])\n dispatch({type: searchText?.length > 0 ? Status.SEARCH_EMPTY : Status.EMPTY})\n }\n\n }\n\n const handleAddLocations = () => {\n callback(selectedCountries);\n };\n\n const handleCountrySelection = (details, selected) => {\n const newCountries = selected ? selectedCountries.filter( c => c.CountryCode != details.CountryCode) :\n [...selectedCountries, details]\n setSelectedCountries(newCountries)\n}\n\n const renderList = () => {\n switch (state.mode) {\n case Status.EMPTY:\n return (\n <NoResultsView\n title=\"No Countries\"\n msg=\"Available countries will appear here\"\n />\n );\n case Status.LOADING:\n return (\n <NoResultsView\n title=\"Loading Countries\"\n msg=\"Don't worry, this won't take long...\"\n showSpinner={true}\n />\n );\n case Status.SEARCH_RESULTS:\n case Status.LOADED:\n return (\n <CountryListing\n countryData={displayedCountries}\n selectedCountries={selectedCountries}\n countrySelectCallback={handleCountrySelection}\n />\n );\n case Status.SEARCH_EMPTY:\n return (\n <NoResultsView\n title=\"No Countries Found\"\n msg=\"No countries were found matching your search\"\n blockHeight=\"h-[460px]\"\n />\n );\n\n default:\n break;\n }\n };\n\n const renderContent = () => (\n <>\n {selectedCountries?.length > 0 && (\n <div className=\"mb-4 rounded-md border border-orange-200 bg-yellow-50 p-4\">\n <p className=\"text-center text-sm text-yellow-800\">\n {`${pluralize(\"country\", selectedCountries?.length, true)} selected.`}\n <span\n onClick={() => setSelectedCountries([])}\n className=\"cursor-pointer text-primary-600 hover:underline\"\n >{` Clear Selection.`}</span>\n </p>\n </div>\n )}\n <Search\n id=\"locationSearch\"\n placeholder=\"Search for countries\"\n disabled={state.searchDisabled}\n callback={handleSearchRequest}\n />\n <div className=\"mb-4 mt-4\">\n {(state.mode === Status.SEARCH_RESULTS ||\n state.mode === Status.SEARCH_EMPTY) &&\n search.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 dark:text-gray-400 md:ms-2\">{`Showing results for...\"${search}\"`}</span>\n )}\n </div>\n {renderList()}\n </>\n );\n\n return (\n <Modal\n show={true}\n onClose={onClose}\n title=\"Choose Locations\"\n size=\"md\"\n >\n <Modal.Body>\n <div className=\"h-full\">{renderContent()}</div>\n </Modal.Body>\n <Modal.Footer>\n <div className={`flex-grow grid grid-col-2 grid-flow-col gap-4`}>\n <Button color=\"light\" onClick={onClose}>\n Close\n </Button>\n <Button\n color=\"success\"\n onClick={handleAddLocations}\n disabled={selectedCountries?.length === 0}\n >\n Add Locations\n </Button>\n </div>\n </Modal.Footer> \n </Modal>\n );\n\n}\n\nconst NoResultsView =({title, msg, blockHeight=\"h-[500px]\", showSpinner = false}) => {\n return (\n <div className={`${blockHeight} flex items-center justify-center`}>\n <TableResultBlock\n icon={!showSpinner && <HiClipboardList className=\"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400\" />}\n title={title}\n message={msg}\n spinner={showSpinner}\n />\n </div>\n )\n}\n\nCountryPicker.propTypes = {\n /** Boolean to indicate that the load of the country data that is passed to this component has been completed */\n initialLoadComplete: PropTypes.bool.isRequired,\n /** Array of all the country data in the form { ID: 383, CountryCode 'CN': Country: 'China'} */\n allCountryData: PropTypes.array.isRequired, \n /** Array of preselected countries in the form { Id: 383, CountryCode 'CN': Country: 'China'} */\n preSelected: PropTypes.array.isRequired,\n /** Callback to close the modal */\n onClose: PropTypes.func.isRequired,\n /** Callback which returns an array of the selected products in the form { Id: 383, CountryCode 'CN': Country: 'China'} */\n callback: PropTypes.func.isRequired,\n\n}"]}
@@ -5,8 +5,8 @@ import N from 'pluralize';
5
5
  import { useRef, useState, useEffect } from 'react';
6
6
  import { jsxs, jsx } from 'react/jsx-runtime';
7
7
 
8
- var o=e(a(),1);function C(e){var s,l;return `${((s=window.resourceSettings)==null?void 0:s.imageBasePath)||""}${e}?v=${((l=window.resourceSettings)==null?void 0:l.version)||""}`}function P({products:e,isMore:s,selected:l,page:f,pages:m,callback:c}){let a=useRef(),[u,g]=useState(!1);useEffect(()=>{let r=document.querySelector("#product-list");return r&&!r.hasAttribute("scroll")&&a.current.addEventListener("scroll",n),a.current!=null&&(a.current.scrollTop=0),()=>{let i=document.querySelector("#product-list");i&&i.hasAttribute("scroll")&&a.current.removeEventListener("scroll",n);}},[]);let n=()=>{if(!s)return;let r=a.current.scrollHeight-a.current.offsetHeight,i=Math.floor(a.current.scrollTop);(i==r||i+2==r||i-2==r)&&(g(!0),c({type:"FETCH_DATA",payload:!0}));},p=r=>{c({type:"SELECTION",payload:r});};return jsxs("div",{id:"product-list",ref:a,className:"h-[500px] overflow-y-auto rounded-md border",children:[(e||[]).map(r=>jsx(h,{product:r,selected:l.has(r.ProductId),callback:p},`product-row-${r.ProductId}`)),s&&f<m&&u&&jsx(k,{})]})}function h({product:e,selected:s,callback:l}){var m,c,a,u,g;let f=n=>{l(e.ProductId);};return jsxs("div",{className:`mb-1 mt-1 flex items-center pb-4 pt-4 ${s&&"bg-blue-50"} cursor-pointer justify-between border-b border-gray-100`,onClick:f,children:[jsxs("div",{className:"ml-3 flex items-center",children:[jsx("div",{className:"flex-shrink-0",children:jsx(a$1,{id:`cb-prod-${e.ProductId}`,name:e.Name,checked:s,onChange:()=>{}})}),jsx("div",{className:"ml-4",children:e.ImagePath&&e.ImageName!=="[URL-DownloadRequested]"?jsx("img",{className:"h-10 w-10 rounded-sm",src:e.ImagePath,alt:e.Name,onError:n=>{n.target.onerror=null,n.target.src=`${C("/admin/Content/images/no-image-discount.png")}`;}}):jsx("img",{src:C("/admin/Content/images/no-image-discount.png"),alt:e.Name,className:"h-10 w-10 rounded-sm"})}),jsxs("div",{className:"ml-4",children:[jsx("div",{className:" font-medium text-gray-900",children:e.Name}),((m=e.Categories)==null?void 0:m.length)>0?jsx("div",{className:"text-xs text-gray-500",children:`${e.CategoryName} & ${N("other",e.Categories.length,!0)}`}):jsx("div",{className:"text-xs text-gray-500",children:e.CategoryName})]})]}),jsx("div",{className:"ml-4 flex-shrink-0",children:jsx("span",{className:"mr-3 text-sm text-gray-500",children:`${(a=(c=globalThis.globalSettings)==null?void 0:c.CurrencySymbol)!=null?a:"\xA3"}${e.Price.toFixed((g=(u=globalThis.globalSettings)==null?void 0:u.CurrencyExponent)!=null?g:2)}`})})]})}P.propTypes={products:o.default.array,isMore:o.default.bool,selected:o.default.instanceOf(Set),page:o.default.number,pages:o.default.number,callback:o.default.func};h.propTypes={product:o.default.object,selected:o.default.bool,callback:o.default.func};function k(){return jsx("div",{className:"mb-1 mt-1 flex justify-center pb-4 pt-4",children:jsx("div",{role:"status",children:jsxs("svg",{"aria-hidden":"true",className:"inline-block h-8 w-8 animate-spin fill-gray-600 text-gray-200 dark:fill-gray-300 dark:text-gray-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]})})})}
8
+ var o=e(a(),1);function C(e){var s,l;return `${((s=window.resourceSettings)==null?void 0:s.imageBasePath)||""}${e}?v=${((l=window.resourceSettings)==null?void 0:l.version)||""}`}function P({products:e,isMore:s,selected:l,page:f,pages:m,callback:c}){let a=useRef(),[u,g]=useState(!1);useEffect(()=>{let r=document.querySelector("#product-list");return r&&!r.hasAttribute("scroll")&&a.current.addEventListener("scroll",n),a.current!=null&&(a.current.scrollTop=0),()=>{let i=document.querySelector("#product-list");i&&i.hasAttribute("scroll")&&a.current.removeEventListener("scroll",n);}},[]);let n=()=>{if(!s)return;let r=a.current.scrollHeight-a.current.offsetHeight,i=Math.floor(a.current.scrollTop);(i==r||i+2==r||i-2==r)&&(g(!0),c({type:"FETCH_DATA",payload:!0}));},h=r=>{c({type:"SELECTION",payload:r});};return jsxs("div",{id:"product-list",ref:a,className:"h-[500px] overflow-y-auto rounded-md border",children:[(e||[]).map(r=>jsx(p,{product:r,selected:l.has(r.ProductId),callback:h},`product-row-${r.ProductId}`)),s&&f<m&&u&&jsx(k,{})]})}function p({product:e,selected:s,callback:l}){var m,c,a,u,g;let f=n=>{l(e.ProductId);};return jsxs("div",{className:`mb-1 mt-1 flex items-center pb-4 pt-4 ${s&&"bg-blue-50"} cursor-pointer justify-between border-b border-gray-100 st-productRow`,onClick:f,children:[jsxs("div",{className:"ml-3 flex items-center",children:[jsx("div",{className:"flex-shrink-0",children:jsx(a$1,{id:`cb-prod-${e.ProductId}`,name:e.Name,checked:s,onChange:()=>{}})}),jsx("div",{className:"ml-4 st-image",children:e.ImagePath&&e.ImageName!=="[URL-DownloadRequested]"?jsx("img",{className:"h-10 w-10 rounded-sm",src:e.ImagePath,alt:e.Name,onError:n=>{n.target.onerror=null,n.target.src=`${C("/admin/Content/images/no-image-discount.png")}`;}}):jsx("img",{src:C("/admin/Content/images/no-image-discount.png"),alt:e.Name,className:"h-10 w-10 rounded-sm"})}),jsxs("div",{className:"ml-4",children:[jsx("div",{className:" font-medium text-gray-900 st-name",children:e.Name}),((m=e.Categories)==null?void 0:m.length)>0?jsx("div",{className:"text-xs text-gray-500 st-category",children:`${e.CategoryName} & ${N("other",e.Categories.length,!0)}`}):jsx("div",{className:"text-xs text-gray-500 st-category",children:e.CategoryName})]})]}),jsx("div",{className:"ml-4 flex-shrink-0 st-price",children:jsx("span",{className:"mr-3 text-sm text-gray-500",children:`${(a=(c=globalThis.globalSettings)==null?void 0:c.CurrencySymbol)!=null?a:"\xA3"}${e.Price.toFixed((g=(u=globalThis.globalSettings)==null?void 0:u.CurrencyExponent)!=null?g:2)}`})})]})}P.propTypes={products:o.default.array,isMore:o.default.bool,selected:o.default.instanceOf(Set),page:o.default.number,pages:o.default.number,callback:o.default.func};p.propTypes={product:o.default.object,selected:o.default.bool,callback:o.default.func};function k(){return jsx("div",{className:"mb-1 mt-1 flex justify-center pb-4 pt-4",children:jsx("div",{role:"status",children:jsxs("svg",{"aria-hidden":"true",className:"inline-block h-8 w-8 animate-spin fill-gray-600 text-gray-200 dark:fill-gray-300 dark:text-gray-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]})})})}
9
9
 
10
10
  export { P as a };
11
11
  //# sourceMappingURL=out.js.map
12
- //# sourceMappingURL=chunk-3ER6WKA7.js.map
12
+ //# sourceMappingURL=chunk-JTV6HMWW.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/product-picker/product-listing.tsx"],"names":["import_prop_types","pluralize","useEffect","useRef","useState","jsx","jsxs","BuildImageUrl","imageUrl","_a","_b","Listing","products","isMore","selected","page","pages","callback","scrollRef","showLoader","setShowLoader","element","handleScroll","offset","scroll","handleProductSelection","id","p","ProductRow","InfiniteLoader","product","_c","_d","_e","e","Checkbox","PropTypes"],"mappings":"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","sourcesContent":["// @ts-nocheck\nimport pluralize from \"pluralize\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useRef, useState } from \"react\";\nimport { Checkbox } from \"../checkbox\";\n// FOR USE WITH THE PRODUCT PICKER COMPONENT - ONLY\n\nfunction BuildImageUrl(imageUrl) {\n return `${window.resourceSettings?.imageBasePath || ''}${imageUrl}?v=${window.resourceSettings?.version || ''}`;\n}\n\nexport function Listing({\n products,\n isMore,\n selected,\n page,\n pages,\n callback,\n}) {\n const scrollRef = useRef();\n const [showLoader, setShowLoader] = useState(false);\n\n useEffect(() => {\n const element = document.querySelector(\"#product-list\");\n if (element && !element.hasAttribute(\"scroll\"))\n scrollRef.current.addEventListener(\"scroll\", handleScroll);\n if (scrollRef.current != null) scrollRef.current.scrollTop = 0;\n return () => {\n const element = document.querySelector(\"#product-list\");\n if (element && element.hasAttribute(\"scroll\"))\n scrollRef.current.removeEventListener(\"scroll\", handleScroll);\n };\n }, []);\n\n const handleScroll = () => {\n if (!isMore) return;\n const offset =\n scrollRef.current.scrollHeight - scrollRef.current.offsetHeight;\n const scroll = Math.floor(scrollRef.current.scrollTop);\n // the '-2 & +2' is used as a buffer, otherwise '==' positioning of the scroll becomes too accurate.\n if (scroll == offset || scroll + 2 == offset || scroll - 2 == offset) {\n setShowLoader(true);\n callback({ type: \"FETCH_DATA\", payload: true });\n }\n };\n\n const handleProductSelection = (id) => {\n callback({ type: \"SELECTION\", payload: id });\n };\n\n return (\n <div\n id=\"product-list\"\n ref={scrollRef}\n className={`h-[500px] overflow-y-auto rounded-md border`}\n >\n {(products || []).map((p) => {\n return (\n <ProductRow\n key={`product-row-${p.ProductId}`}\n product={p}\n selected={selected.has(p.ProductId)}\n callback={handleProductSelection}\n />\n );\n })}\n {isMore && page < pages && showLoader && <InfiniteLoader />}\n </div>\n );\n}\n\nfunction ProductRow({ product, selected, callback }) {\n const handleProductSelection = (e) => {\n callback(product.ProductId);\n };\n return (\n <div\n className={`mb-1 mt-1 flex items-center pb-4 pt-4 ${\n selected && \"bg-blue-50\"\n } cursor-pointer justify-between border-b border-gray-100 st-productRow`}\n onClick={handleProductSelection}\n >\n <div className=\"ml-3 flex items-center\">\n <div className=\"flex-shrink-0\">\n <Checkbox\n id={`cb-prod-${product.ProductId}`}\n name={product.Name}\n checked={selected}\n onChange={() => {}}\n />\n </div>\n <div className=\"ml-4 st-image\">\n {product.ImagePath && product.ImageName !== \"[URL-DownloadRequested]\" ? (\n <img\n className=\"h-10 w-10 rounded-sm\"\n src={product.ImagePath}\n alt={product.Name}\n onError={(e) => {\n e.target.onerror = null;\n e.target.src = `${BuildImageUrl(\n \"/admin/Content/images/no-image-discount.png\"\n )}`;\n }}\n />\n ) : (\n <img\n src={BuildImageUrl(\"/admin/Content/images/no-image-discount.png\")}\n alt={product.Name}\n className=\"h-10 w-10 rounded-sm\"\n />\n )}\n </div>\n <div className=\"ml-4\">\n <div className=\" font-medium text-gray-900 st-name\">{product.Name}</div>\n {product.Categories?.length > 0 ? (\n <div className=\"text-xs text-gray-500 st-category\">{`${\n product.CategoryName\n } & ${pluralize(\"other\", product.Categories.length, true)}`}</div>\n ) : (\n <div className=\"text-xs text-gray-500 st-category\">{product.CategoryName}</div>\n )}\n </div>\n </div>\n <div className=\"ml-4 flex-shrink-0 st-price\">\n <span className=\"mr-3 text-sm text-gray-500\">{`${\n globalThis.globalSettings?.CurrencySymbol ?? '£'\n }${product.Price.toFixed(\n globalThis.globalSettings?.CurrencyExponent ?? 2\n )}`}</span>\n </div>\n </div>\n );\n}\n\nListing.propTypes = {\n /** Array of products to list */\n products: PropTypes.array,\n /** Boolean to indicate if there are more products to load */\n isMore: PropTypes.bool,\n /** Set of selected ids */\n selected: PropTypes.instanceOf(Set),\n /** Current page */\n page: PropTypes.number,\n /** Total number of pages */\n pages: PropTypes.number,\n /** Callback function to handle events */\n callback: PropTypes.func,\n};\n\nProductRow.propTypes = {\n /** Product object to display */\n product: PropTypes.object,\n /** Boolean to indicate if the file is selected */\n selected: PropTypes.bool,\n /** Callback function to handle events */\n callback: PropTypes.func,\n};\n\nfunction InfiniteLoader() {\n return (\n <div className=\"mb-1 mt-1 flex justify-center pb-4 pt-4\">\n <div role=\"status\">\n <svg\n aria-hidden=\"true\"\n className=\"inline-block h-8 w-8 animate-spin fill-gray-600 text-gray-200 dark:fill-gray-300 dark:text-gray-600\"\n viewBox=\"0 0 100 101\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z\"\n fill=\"currentFill\"\n />\n </svg>\n </div>\n </div>\n );\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { a as a$3 } from './chunk-DSJ5TRZW.js';
2
2
  import { a as a$2 } from './chunk-E4USZ2Q3.js';
3
- import { a as a$4 } from './chunk-2I24LCEG.js';
3
+ import { a as a$4 } from './chunk-VOFMZ77E.js';
4
4
  import { a } from './chunk-6LHL364H.js';
5
5
  import { d, e, b as b$1, a as a$1 } from './chunk-Z4LPO673.js';
6
6
  import { createContext, useState, useRef, useEffect, useMemo } from 'react';
@@ -13,4 +13,4 @@ var P=d((Ft,X)=>{function Le(e){var t=typeof e;return e!=null&&(t=="object"||t==
13
13
 
14
14
  export { qe as a };
15
15
  //# sourceMappingURL=out.js.map
16
- //# sourceMappingURL=chunk-HQIKNKIV.js.map
16
+ //# sourceMappingURL=chunk-SDIXMJRI.js.map
@@ -0,0 +1,11 @@
1
+ import { a as a$2 } from './chunk-TJMI4DH2.js';
2
+ import { a } from './chunk-6LHL364H.js';
3
+ import { e as e$1, c, b, a as a$1 } from './chunk-Z4LPO673.js';
4
+ import { variantProps } from 'classname-variants/react';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ var e=e$1(a(),1);var v=variantProps({base:"group flex items-stretch items-center justify-center p-0.5 text-center font-medium relative focus:z-10 focus:outline-none rounded-lg",variants:{color:{default:"focus:outline-none text-white bg-blue-700 border border-transparent enabled:hover:bg-blue-800 focus:ring-blue-300 dark:bg-blue-600 dark:enabled:hover:bg-blue-700 dark:focus:ring-blue-800 rounded-lg focus:ring-2",dark:"enabled:hover:bg-gray-900 focus:ring-4 focus:ring-gray-300 dark:bg-gray-800 dark:enabled:hover:bg-gray-700 dark:focus:ring-gray-800 dark:border-gray-700",failure:"enabled:hover:bg-red-800 focus:ring-4 focus:ring-red-300 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900",gray:"text-gray-900 bg-white border border-gray-200 enabled:hover:bg-gray-100 enabled:hover:text-cyan-700 :ring-cyan-700 focus:text-cyan-700 dark:bg-transparent dark:text-gray-400 dark:border-gray-600 dark:enabled:hover:text-white dark:enabled:hover:bg-gray-700 focus:ring-2",info:"enabled:hover:bg-cyan-800 focus:ring-4 focus:ring-cyan-300 dark:bg-cyan-600 dark:enabled:hover:bg-cyan-700 dark:focus:ring-cyan-800",light:"text-gray-900 bg-white border border-gray-300 enabled:hover:bg-gray-100 focus:ring-4 focus:ring-cyan-300 dark:bg-gray-600 dark:text-white dark:border-gray-600 dark:enabled:hover:bg-gray-700 dark:enabled:hover:border-gray-700 dark:focus:ring-gray-700",success:"enabled:hover:bg-green-800 focus:ring-4 focus:ring-green-300 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800",warning:"enabled:hover:bg-yellow-500 focus:ring-4 focus:ring-yellow-300 dark:focus:ring-yellow-900"},disabled:{true:"cursor-not-allowed opacity-50",false:""},outline:{true:"border",false:""}},compoundVariants:[{variants:{color:"dark",outline:!0},className:"text-gray-800 border-gray-800 hover:text-white"},{variants:{color:"dark",outline:!1},className:"border-0 text-white bg-gray-800"},{variants:{color:"failure",outline:!0},className:"text-red-700 border-red-700 hover:text-white"},{variants:{color:"failure",outline:!1},className:"border-0 text-white bg-red-700"},{variants:{color:"info",outline:!0},className:"text-cyan-700 border-cyan-700 hover:text-white"},{variants:{color:"info",outline:!1},className:"text-white bg-cyan-700"},{variants:{color:"success",outline:!0},className:"text-green-700 border-green-700 hover:text-white"},{variants:{color:"success",outline:!1},className:"text-white bg-green-700"},{variants:{color:"warning",outline:!0},className:"text-yellow-400 border-yellow-400 hover:text-white"},{variants:{color:"warning",outline:!1},className:"text-white bg-yellow-400"},{variants:{color:"gray",outline:!0},className:"text-gray-900 bg-white hover:text-white border border-gray-200"},{variants:{color:"gray",outline:!1},className:"text-gray-900 bg-white border border-gray-200"}]}),m=Object.freeze({xs:"text-xs px-2 py-1",sm:"text-sm px-3 py-1.5",md:"text-sm px-4 py-2",lg:"text-base px-5 py-2.5",xl:"text-base px-6 py-3"});function i(k){var t=k,{color:g="default",disabled:d,outline:b$1,size:c$1="md",children:u,className:a}=t,y=c(t,["color","disabled","outline","size","children","className"]);return jsx("button",b(a$1(a$1({},v({color:g,disabled:d,outline:b$1,className:a})),y),{children:jsx("span",{className:a$2("flex items-center justify-center rounded-md transition-all duration-200",m[c$1],a),children:u})}))}i.propTypes={color:e.default.oneOf(["default","dark","failure","gray","info","light","success","warning"]),size:e.default.oneOf(["xs","sm","md","lg","xl"]),disabled:e.default.bool,outline:e.default.bool,addon:e.default.element,icon:e.default.element};i.displayName="Button";
8
+
9
+ export { i as a };
10
+ //# sourceMappingURL=out.js.map
11
+ //# sourceMappingURL=chunk-VOFMZ77E.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/button.tsx"],"names":["variantProps","import_prop_types","jsx","buttonProps","sizes","Button","_a","_b","color","disabled","outline","size","children","className","props","__objRest","__spreadProps","__spreadValues","twMerge","PropTypes"],"mappings":"6IACA,OAAS,gBAAAA,MAAoB,2BAE7B,IAAAC,EAAsB,SA4IhB,cAAAC,MAAA,oBA1IN,IAAMC,EAAcH,EAAa,CAC/B,KAAM,uIACN,SAAU,CACR,MAAO,CACL,QACE,qNACF,KAAM,2JACN,QACE,iHACF,KAAM,+QACN,KAAM,sIACN,MACE,4PACF,QACE,yHACF,QACE,2FACJ,EACA,SAAU,CACR,KAAM,gCACN,MAAO,EACT,EACA,QAAS,CACP,KAAM,SACN,MAAO,EACT,CACF,EACA,iBAAkB,CAChB,CACE,SAAU,CACR,MAAO,OACP,QAAS,EACX,EACA,UAAW,gDACb,EACA,CACE,SAAU,CACR,MAAO,OACP,QAAS,EACX,EACA,UAAW,iCACb,EACA,CACE,SAAU,CACR,MAAO,UACP,QAAS,EACX,EACA,UAAW,8CACb,EACA,CACE,SAAU,CACR,MAAO,UACP,QAAS,EACX,EACA,UAAW,gCACb,EACA,CACE,SAAU,CACR,MAAO,OACP,QAAS,EACX,EACA,UAAW,gDACb,EACA,CACE,SAAU,CACR,MAAO,OACP,QAAS,EACX,EACA,UAAW,wBACb,EACA,CACE,SAAU,CACR,MAAO,UACP,QAAS,EACX,EACA,UAAW,kDACb,EACA,CACE,SAAU,CACR,MAAO,UACP,QAAS,EACX,EACA,UAAW,yBACb,EACA,CACE,SAAU,CACR,MAAO,UACP,QAAS,EACX,EACA,UAAW,oDACb,EACA,CACE,SAAU,CACR,MAAO,UACP,QAAS,EACX,EACA,UAAW,0BACb,EACA,CACE,SAAU,CACR,MAAO,OACP,QAAS,EACX,EACA,UACE,gEACJ,EACA,CACE,SAAU,CACR,MAAO,OACP,QAAS,EACX,EACA,UAAW,+CACb,CACF,CACF,CAAC,EAEKI,EAAQ,OAAO,OAAO,CAC1B,GAAI,oBACJ,GAAI,sBACJ,GAAI,oBACJ,GAAI,wBACJ,GAAI,qBACN,CAAC,EAEM,SAASC,EAAOC,EAQpB,CARoB,IAAAC,EAAAD,EACrB,OAAAE,EAAQ,UACR,SAAAC,EACA,QAAAC,EACA,KAAAC,EAAO,KACP,SAAAC,EACA,UAAAC,CAvIF,EAiIuBN,EAOlBO,EAAAC,EAPkBR,EAOlB,CANH,QACA,WACA,UACA,OACA,WACA,cAGA,OACEL,EAAC,SAAAc,EAAAC,IAAA,GACKd,EAAY,CAAE,MAAAK,EAAO,SAAAC,EAAU,QAAAC,EAAS,UAAAG,CAAU,CAAC,GACnDC,GAFL,CAIC,SAAAZ,EAAC,QACC,UAAWgB,EACT,0EACAd,EAAMO,CAAI,EACVE,CACF,EAEC,SAAAD,EACH,GACF,CAEJ,CAEAP,EAAO,UAAY,CAEjB,MAAO,EAAAc,QAAU,MAAM,CACrB,UACA,OACA,UACA,OACA,OACA,QACA,UACA,SACF,CAAC,EAED,KAAM,EAAAA,QAAU,MAAM,CAAC,KAAM,KAAM,KAAM,KAAM,IAAI,CAAC,EAEpD,SAAU,EAAAA,QAAU,KAEpB,QAAS,EAAAA,QAAU,KAEnB,MAAO,EAAAA,QAAU,QAEjB,KAAM,EAAAA,QAAU,OAClB,EAEAd,EAAO,YAAc","sourcesContent":["//@ts-nocheck\nimport { variantProps } from \"classname-variants/react\";\nimport { twMerge } from \"tailwind-merge\";\nimport PropTypes from \"prop-types\";\n\nconst buttonProps = variantProps({\n base: \"group flex items-stretch items-center justify-center p-0.5 text-center font-medium relative focus:z-10 focus:outline-none rounded-lg\",\n variants: {\n color: {\n default:\n \"focus:outline-none text-white bg-blue-700 border border-transparent enabled:hover:bg-blue-800 focus:ring-blue-300 dark:bg-blue-600 dark:enabled:hover:bg-blue-700 dark:focus:ring-blue-800 rounded-lg focus:ring-2\",\n dark: \"enabled:hover:bg-gray-900 focus:ring-4 focus:ring-gray-300 dark:bg-gray-800 dark:enabled:hover:bg-gray-700 dark:focus:ring-gray-800 dark:border-gray-700\",\n failure:\n \"enabled:hover:bg-red-800 focus:ring-4 focus:ring-red-300 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900\",\n gray: \"text-gray-900 bg-white border border-gray-200 enabled:hover:bg-gray-100 enabled:hover:text-cyan-700 :ring-cyan-700 focus:text-cyan-700 dark:bg-transparent dark:text-gray-400 dark:border-gray-600 dark:enabled:hover:text-white dark:enabled:hover:bg-gray-700 focus:ring-2\",\n info: \"enabled:hover:bg-cyan-800 focus:ring-4 focus:ring-cyan-300 dark:bg-cyan-600 dark:enabled:hover:bg-cyan-700 dark:focus:ring-cyan-800\",\n light:\n \"text-gray-900 bg-white border border-gray-300 enabled:hover:bg-gray-100 focus:ring-4 focus:ring-cyan-300 dark:bg-gray-600 dark:text-white dark:border-gray-600 dark:enabled:hover:bg-gray-700 dark:enabled:hover:border-gray-700 dark:focus:ring-gray-700\",\n success:\n \"enabled:hover:bg-green-800 focus:ring-4 focus:ring-green-300 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800\",\n warning:\n \"enabled:hover:bg-yellow-500 focus:ring-4 focus:ring-yellow-300 dark:focus:ring-yellow-900\",\n },\n disabled: {\n true: \"cursor-not-allowed opacity-50\",\n false: \"\",\n },\n outline: {\n true: \"border\",\n false: \"\",\n },\n },\n compoundVariants: [\n {\n variants: {\n color: \"dark\",\n outline: true,\n },\n className: \"text-gray-800 border-gray-800 hover:text-white\",\n },\n {\n variants: {\n color: \"dark\",\n outline: false,\n },\n className: \"border-0 text-white bg-gray-800\",\n },\n {\n variants: {\n color: \"failure\",\n outline: true,\n },\n className: \"text-red-700 border-red-700 hover:text-white\",\n },\n {\n variants: {\n color: \"failure\",\n outline: false,\n },\n className: \"border-0 text-white bg-red-700\",\n },\n {\n variants: {\n color: \"info\",\n outline: true,\n },\n className: \"text-cyan-700 border-cyan-700 hover:text-white\",\n },\n {\n variants: {\n color: \"info\",\n outline: false,\n },\n className: \"text-white bg-cyan-700\",\n },\n {\n variants: {\n color: \"success\",\n outline: true,\n },\n className: \"text-green-700 border-green-700 hover:text-white\",\n },\n {\n variants: {\n color: \"success\",\n outline: false,\n },\n className: \"text-white bg-green-700\",\n },\n {\n variants: {\n color: \"warning\",\n outline: true,\n },\n className: \"text-yellow-400 border-yellow-400 hover:text-white\",\n },\n {\n variants: {\n color: \"warning\",\n outline: false,\n },\n className: \"text-white bg-yellow-400\",\n },\n {\n variants: {\n color: \"gray\",\n outline: true,\n },\n className:\n \"text-gray-900 bg-white hover:text-white border border-gray-200\",\n },\n {\n variants: {\n color: \"gray\",\n outline: false,\n },\n className: \"text-gray-900 bg-white border border-gray-200\",\n },\n ],\n});\n\nconst sizes = Object.freeze({\n xs: \"text-xs px-2 py-1\",\n sm: \"text-sm px-3 py-1.5\",\n md: \"text-sm px-4 py-2\",\n lg: \"text-base px-5 py-2.5\",\n xl: \"text-base px-6 py-3\",\n});\n\nexport function Button({\n color = \"default\",\n disabled,\n outline,\n size = \"md\",\n children,\n className,\n ...props\n}) {\n return (\n <button\n {...buttonProps({ color, disabled, outline, className })}\n {...props}\n >\n <span\n className={twMerge(\n \"flex items-center justify-center rounded-md transition-all duration-200\",\n sizes[size],\n className\n )}\n >\n {children}\n </span>\n </button>\n );\n}\n\nButton.propTypes = {\n /** String for color of button */\n color: PropTypes.oneOf([\n \"default\",\n \"dark\",\n \"failure\",\n \"gray\",\n \"info\",\n \"light\",\n \"success\",\n \"warning\",\n ]),\n /** String to determine the size of the badge. \"xs, sm, md, lg, xl\" */\n size: PropTypes.oneOf([\"xs\", \"sm\", \"md\", \"lg\", \"xl\"]),\n /** Bool to disable button */\n disabled: PropTypes.bool,\n /** Bool to outline button */\n outline: PropTypes.bool,\n /** element for addon on button */\n addon: PropTypes.element,\n /** element for icon on button */\n icon: PropTypes.element,\n};\n\nButton.displayName = \"Button\";\n"]}
@@ -5,4 +5,4 @@ function n({children:o,title:s,description:a}){return jsx(Disclosure,{children:j
5
5
 
6
6
  export { n as a };
7
7
  //# sourceMappingURL=out.js.map
8
- //# sourceMappingURL=chunk-JHGOFDVG.js.map
8
+ //# sourceMappingURL=chunk-XABECXZS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/featurePageComponents/feature-page-group.tsx"],"names":["Disclosure","jsx","jsxs","FeaturePageGroup","children","title","description"],"mappings":"AACA,OAAS,cAAAA,MAAkB,oBAajB,OACE,OAAAC,EADF,QAAAC,MAAA,oBALH,SAASC,EAAiB,CAAE,SAAAC,EAAU,MAAAC,EAAO,YAAAC,CAAY,EAAU,CACxE,OACEL,EAACD,EAAA,CACC,SAAAE,EAAC,WACC,UAAAA,EAAC,OAAI,UAAU,0CACb,UAAAA,EAAC,OACC,UAAAD,EAAC,MAAG,UAAU,wBAAyB,SAAAI,EAAM,EAC7CJ,EAAC,KAAE,UAAU,sCAAuC,SAAAK,EAAY,GAClE,EACAL,EAACD,EAAW,OAAX,CAAkB,UAAU,6SAC3B,SAAAC,EAAC,KAAE,qBAAS,EACd,GACF,EACAA,EAACD,EAAW,MAAX,CAAiB,UAAU,QAC1B,SAAAC,EAAC,OAAI,UAAU,yBAA0B,SAAAG,EAAS,EACpD,GACF,EACF,CAEJ","sourcesContent":["//@ts-nocheck\nimport { Disclosure } from \"@headlessui/react\";\n\ntype Props = {\n title: string;\n description: string;\n children: JSX.Element;\n};\n\nexport function FeaturePageGroup({ children, title, description }: Props) {\n return (\n <Disclosure>\n <section>\n <div className=\"flex items-center justify-between gap-2\">\n <div>\n <h4 className=\"text-xl font-semibold\">{title}</h4>\n <p className=\"text-base font-normal text-gray-500\">{description}</p>\n </div>\n <Disclosure.Button className=\"mb-2 mr-2 rounded-lg border border-gray-700 px-5 py-2.5 text-center text-sm font-medium text-gray-700 hover:bg-gray-800 hover:text-white focus:outline-none focus:ring-4 focus:ring-gray-300 dark:border-gray-500 dark:text-gray-500 dark:hover:bg-gray-500 dark:hover:text-white dark:focus:ring-gray-800\">\n <p>View More</p>\n </Disclosure.Button>\n </div>\n <Disclosure.Panel className=\"mt-6 \">\n <div className=\"grid grid-cols-3 gap-7\">{children}</div>\n </Disclosure.Panel>\n </section>\n </Disclosure>\n );\n}\n"]}
@@ -7,4 +7,4 @@ function y({onClose:i,children:n,show:r}){return jsx(Transition.Root,{show:r,as:
7
7
 
8
8
  export { y as a };
9
9
  //# sourceMappingURL=out.js.map
10
- //# sourceMappingURL=chunk-G2WGEIWK.js.map
10
+ //# sourceMappingURL=chunk-Y5DEGGVQ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/video-modal.tsx"],"names":["Dialog","Transition","XMarkIcon","Fragment","jsx","jsxs","VideoModal","onClose","children","show"],"mappings":"AACA,OAAS,UAAAA,EAAQ,cAAAC,MAAkB,oBACnC,OAAS,aAAAC,MAAiB,8BAC1B,OAAS,YAAAC,MAAgB,QAqBf,cAAAC,EAgBQ,QAAAC,MAhBR,oBAbH,SAASC,EAAW,CAAE,QAAAC,EAAS,SAAAC,EAAU,KAAAC,CAAK,EAAU,CAC7D,OACEL,EAACH,EAAW,KAAX,CAAgB,KAAMQ,EAAM,GAAIN,EAC/B,SAAAE,EAACL,EAAA,CAAO,GAAG,MAAM,UAAU,iBAAiB,QAASO,EACnD,UAAAH,EAACH,EAAW,MAAX,CACC,GAAIE,EACJ,MAAM,wBACN,UAAU,YACV,QAAQ,cACR,MAAM,uBACN,UAAU,cACV,QAAQ,YAER,SAAAC,EAAC,OAAI,UAAU,6DAA6D,EAC9E,EAEAA,EAAC,OAAI,UAAU,qCACb,SAAAA,EAAC,OAAI,UAAU,8EACb,SAAAA,EAACH,EAAW,MAAX,CACC,GAAIE,EACJ,MAAM,wBACN,UAAU,uDACV,QAAQ,yCACR,MAAM,uBACN,UAAU,yCACV,QAAQ,uDAER,SAAAE,EAACL,EAAO,MAAP,CAAa,UAAU,qHACtB,UAAAI,EAAC,OAAI,UAAU,mDACb,SAAAC,EAAC,UACC,KAAK,SACL,UAAU,kIACV,QAASE,EAET,UAAAH,EAAC,QAAK,UAAU,UAAU,iBAAK,EAC/BA,EAACF,EAAA,CAAU,UAAU,UAAU,cAAY,OAAO,GACpD,EACF,EACCM,GACH,EACF,EACF,EACF,GACF,EACF,CAEJ","sourcesContent":["//@ts-nocheck\nimport { Dialog, Transition } from \"@headlessui/react\";\nimport { XMarkIcon } from \"@heroicons/react/24/outline\";\nimport { Fragment } from \"react\";\n\ntype Props = {\n onClose: () => void;\n show: boolean;\n children: JSX.Element;\n};\n\nexport function VideoModal({ onClose, children, show }: Props) {\n return (\n <Transition.Root show={show} as={Fragment}>\n <Dialog as=\"div\" className=\"relative z-10 \" onClose={onClose}>\n <Transition.Child\n as={Fragment}\n enter=\"ease-out duration-300\"\n enterFrom=\"opacity-0\"\n enterTo=\"opacity-100\"\n leave=\"ease-in duration-200\"\n leaveFrom=\"opacity-100\"\n leaveTo=\"opacity-0\"\n >\n <div className=\"fixed inset-0 bg-gray-500 bg-opacity-75 transition-opacity\" />\n </Transition.Child>\n\n <div className=\"fixed inset-0 z-10 overflow-y-auto\">\n <div className=\"flex min-h-full items-center justify-center p-4 text-center sm:items-center\">\n <Transition.Child\n as={Fragment}\n enter=\"ease-out duration-300\"\n enterFrom=\"opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95\"\n enterTo=\"opacity-100 translate-y-0 sm:scale-100\"\n leave=\"ease-in duration-200\"\n leaveFrom=\"opacity-100 translate-y-0 sm:scale-100\"\n leaveTo=\"opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95\"\n >\n <Dialog.Panel className=\"relative w-full max-w-5xl transform overflow-hidden rounded-lg bg-white text-left shadow-xl transition-all sm:my-8\">\n <div className=\"absolute right-0 top-0 hidden pr-4 pt-4 sm:block\">\n <button\n type=\"button\"\n className=\"rounded-md bg-white text-gray-400 hover:text-gray-500 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2\"\n onClick={onClose}\n >\n <span className=\"sr-only\">Close</span>\n <XMarkIcon className=\"h-6 w-6\" aria-hidden=\"true\" />\n </button>\n </div>\n {children}\n </Dialog.Panel>\n </Transition.Child>\n </div>\n </div>\n </Dialog>\n </Transition.Root>\n );\n}\n"]}
@@ -6,4 +6,4 @@ function n({imgURL:r,imgName:i,imgSize:o,isChecked:a,deleteCallback:s}){return j
6
6
 
7
7
  export { n as a };
8
8
  //# sourceMappingURL=out.js.map
9
- //# sourceMappingURL=chunk-WTBH4TDX.js.map
9
+ //# sourceMappingURL=chunk-Z44LYPKH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/image-thumbnail.tsx"],"names":["Checkbox","HiTrash","jsx","jsxs","ImageThumbnail","imgURL","imgName","imgSize","isChecked","deleteCallback"],"mappings":"AACA,OAAS,YAAAA,MAAgB,iBACzB,OAAS,WAAAC,MAAe,kBAmBlB,OACE,OAAAC,EADF,QAAAC,MAAA,oBATC,SAASC,EAAe,CAC7B,OAAAC,EACA,QAAAC,EACA,QAAAC,EACA,UAAAC,EACA,eAAAC,CACF,EAAU,CACR,OACEN,EAAC,OAAI,UAAU,uBACb,UAAAA,EAAC,OAAI,UAAU,4BACb,UAAAD,EAACF,EAAA,CACC,GAAG,iBACH,UAAU,uCACV,QAASQ,EACX,EACAN,EAAC,OAAI,IAAKG,EAAQ,IAAI,GAAG,UAAU,kBAAkB,EACrDH,EAAC,OACC,UAAU,6KACV,QAASO,EAET,SAAAP,EAACD,EAAA,CAAQ,UAAU,uBAAuB,EAC5C,GACF,EACAC,EAAC,KAAE,UAAU,2CAA4C,SAAAI,EAAQ,EACjEJ,EAAC,KAAE,UAAU,uDACV,SAAAK,EACH,GACF,CAEJ","sourcesContent":["//@ts-nocheck\nimport { Checkbox } from \"flowbite-react\";\nimport { HiTrash } from \"react-icons/hi2\";\n\ntype Props = {\n imgURL: string;\n imgName: string;\n imgSize: string;\n isChecked?: boolean;\n deleteCallback: () => void;\n};\n\nexport function ImageThumbnail({\n imgURL,\n imgName,\n imgSize,\n isChecked,\n deleteCallback,\n}: Props) {\n return (\n <div className=\"w-32 overflow-hidden\">\n <div className=\"group relative rounded-lg\">\n <Checkbox\n id=\"imageThumbnail\"\n className=\"absolute left-1 top-1 cursor-pointer\"\n checked={isChecked}\n />\n <img src={imgURL} alt=\"\" className=\"mb-2 rounded-lg\" />\n <div\n className=\"absolute bottom-1 right-1 flex h-8 w-8 cursor-pointer items-center justify-center rounded-full border border-red-700 bg-white opacity-0 transition group-hover:opacity-100\"\n onClick={deleteCallback}\n >\n <HiTrash className=\"h-4 w-4 text-red-700\" />\n </div>\n </div>\n <p className=\"truncate text-center text-sm font-medium\">{imgName}</p>\n <p className=\"dark:text-dark-400 text-center text-sm text-gray-500\">\n {imgSize}\n </p>\n </div>\n );\n}\n"]}