ekm-ui 0.3.71 → 0.3.74

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.
@@ -10,7 +10,21 @@ Browserslist: caniuse-lite is outdated. Please run:
10
10
  npx update-browserslist-db@latest
11
11
  Why you should do it regularly: https://github.com/browserslist/update-db#readme
12
12
  DTS Build start
13
- DTS ⚡️ Build success in 64856ms
13
+ [warn] ▲ [WARNING] Duplicate "className" attribute in JSX element [duplicate-object-key]
14
+
15
+ src/product-picker/product-listing.tsx:74:14:
16
+  74 │ className="h-10 w-10 rounded-sm"
17
+ ╵ ~~~~~~~~~
18
+
19
+ The original "className" attribute is here:
20
+
21
+ src/product-picker/product-listing.tsx:67:14:
22
+  67 │ className="h-10 w-10 rounded-md"
23
+ ╵ ~~~~~~~~~
24
+
25
+
26
+ "HiArchive", "HiCurrencyDollar", "HiInbox", "HiLogout", "HiOutlineTicket", "HiShoppingBag", "HiUserCircle", "HiUsers" and "HiViewGrid" are imported from external module "react-icons/hi" but never used in "dist/chunk-256SAVHD.mjs".
27
+ DTS ⚡️ Build success in 71244ms
14
28
  DTS dist/index.d.ts 2.98 KB
15
29
  DTS dist/footer-heart-icon.d.ts 70.00 B
16
30
  DTS dist/accordion.d.ts 1.84 KB
@@ -74,47 +88,30 @@ Browserslist: caniuse-lite is outdated. Please run:
74
88
  DTS dist/file-picker/file-listing.d.ts 991.00 B
75
89
  DTS dist/product-picker/product-listing.d.ts 991.00 B
76
90
  DTS dist/rich-text-editor/index.d.ts 613.00 B
77
- [warn] ▲ [WARNING] Duplicate "className" attribute in JSX element [duplicate-object-key]
78
-
79
- src/product-picker/product-listing.tsx:74:14:
80
-  74 │ className="h-10 w-10 rounded-sm"
81
- ╵ ~~~~~~~~~
82
-
83
- The original "className" attribute is here:
84
-
85
- src/product-picker/product-listing.tsx:67:14:
86
-  67 │ className="h-10 w-10 rounded-md"
87
- ╵ ~~~~~~~~~
88
-
89
-
90
- "HiArchive", "HiCurrencyDollar", "HiInbox", "HiLogout", "HiOutlineTicket", "HiShoppingBag", "HiUserCircle", "HiUsers" and "HiViewGrid" are imported from external module "react-icons/hi" but never used in "dist/chunk-256SAVHD.mjs".
91
- ESM dist/file-picker/file-picker.css 123.52 KB
92
- ESM dist/layout/layout.css 123.52 KB
93
- ESM dist/product-picker/product-drawer.css 123.52 KB
94
91
  ESM dist/stacked-list-item.css 123.53 KB
92
+ ESM dist/drag-and-drop.css 123.52 KB
95
93
  ESM dist/table-result-block.css 123.53 KB
96
94
  ESM dist/index.css 123.52 KB
97
95
  ESM dist/card-payment-block.css 123.53 KB
98
- ESM dist/drag-and-drop.css 123.52 KB
99
- ESM dist/file-picker/file-picker.css.map 175.29 KB
100
- ESM dist/layout/layout.css.map 175.29 KB
101
- ESM dist/product-picker/product-drawer.css.map 175.29 KB
96
+ ESM dist/layout/layout.css 123.52 KB
97
+ ESM dist/product-picker/product-drawer.css 123.52 KB
98
+ ESM dist/file-picker/file-picker.css 123.52 KB
102
99
  ESM dist/stacked-list-item.css.map 175.28 KB
100
+ ESM dist/drag-and-drop.css.map 175.28 KB
103
101
  ESM dist/table-result-block.css.map 175.28 KB
104
- ESM dist/index.css.map 175.28 KB
105
102
  ESM dist/card-payment-block.css.map 175.28 KB
103
+ ESM dist/index.css.map 175.28 KB
106
104
  ESM dist/chunk-23SJGKDR.mjs 1.34 KB
107
105
  ESM dist/rich-text-editor/index.mjs 159.00 B
108
- ESM dist/drag-and-drop.css.map 175.28 KB
109
106
  ESM dist/search/search.mjs 184.00 B
110
107
  ESM dist/sidebar/sidebar.mjs 154.00 B
111
108
  ESM dist/sort/sort.mjs 180.00 B
112
- ESM dist/table-header/table-header.mjs 291.00 B
113
109
  ESM dist/toast/index.mjs 192.00 B
110
+ ESM dist/table-header/table-header.mjs 291.00 B
114
111
  ESM dist/tooltip/tooltip.mjs 154.00 B
115
112
  ESM dist/featurePageComponents/mini-feature-block.mjs 740.00 B
116
- ESM dist/file-picker/file-listing.mjs 223.00 B
117
113
  ESM dist/file-picker/file-picker.mjs 1.91 KB
114
+ ESM dist/file-picker/file-listing.mjs 223.00 B
118
115
  ESM dist/layout/layout.mjs 1.90 KB
119
116
  ESM dist/navbar/navbar.mjs 184.00 B
120
117
  ESM dist/pagination/pagination.mjs 160.00 B
@@ -159,14 +156,14 @@ Browserslist: caniuse-lite is outdated. Please run:
159
156
  ESM dist/dashboard-notification.mjs 243.00 B
160
157
  ESM dist/date-range-picker.mjs 356.00 B
161
158
  ESM dist/drag-and-drop.mjs 1.85 KB
162
- ESM dist/chunk-4S3NZSBU.mjs 26.60 KB
159
+ ESM dist/chunk-HZTQAUGX.mjs 26.60 KB
163
160
  ESM dist/chunk-PPMW7YAZ.mjs 5.48 KB
164
161
  ESM dist/chunk-Q365BFES.mjs 3.53 KB
165
162
  ESM dist/chunk-EHJJX6ZZ.mjs 1.81 KB
166
163
  ESM dist/chunk-ZJATBQ3X.mjs 2.04 KB
167
- ESM dist/chunk-N7RKCR3X.mjs 2.31 KB
168
- ESM dist/chunk-ASCPOK5F.mjs 2.13 KB
169
164
  ESM dist/chunk-CEK5K5TU.mjs 75.16 KB
165
+ ESM dist/chunk-UUWBHZKH.mjs 2.32 KB
166
+ ESM dist/chunk-ASCPOK5F.mjs 2.13 KB
170
167
  ESM dist/chunk-LQQDRIZN.mjs 3.79 KB
171
168
  ESM dist/chunk-256SAVHD.mjs 10.39 KB
172
169
  ESM dist/chunk-VPLCWU7T.mjs 6.54 KB
@@ -194,9 +191,9 @@ Browserslist: caniuse-lite is outdated. Please run:
194
191
  ESM dist/chunk-REFCK56T.mjs 3.34 KB
195
192
  ESM dist/chunk-ZT7KDTGF.mjs 1.69 KB
196
193
  ESM dist/chunk-47S6AX7M.mjs 725.00 B
194
+ ESM dist/chunk-FRIXS4BL.mjs 56.39 KB
197
195
  ESM dist/chunk-PJMH47GY.mjs 1004.00 B
198
196
  ESM dist/chunk-DZABAR36.mjs 1.05 KB
199
- ESM dist/chunk-FRIXS4BL.mjs 56.39 KB
200
197
  ESM dist/chunk-XUXHB434.mjs 981.00 B
201
198
  ESM dist/chunk-F6ZWBNIM.mjs 1.16 KB
202
199
  ESM dist/chunk-PT4DPY4L.mjs 591.00 B
@@ -225,17 +222,20 @@ Browserslist: caniuse-lite is outdated. Please run:
225
222
  ESM dist/chunk-QHJF4QWW.mjs 3.88 KB
226
223
  ESM dist/chunk-GBY2NNWZ.mjs 19.89 KB
227
224
  ESM dist/chunk-PUJZGK7Y.mjs 15.70 KB
225
+ ESM dist/layout/layout.css.map 175.29 KB
226
+ ESM dist/product-picker/product-drawer.css.map 175.29 KB
227
+ ESM dist/file-picker/file-picker.css.map 175.29 KB
228
228
  ESM dist/chunk-23SJGKDR.mjs.map 71.00 B
229
229
  ESM dist/rich-text-editor/index.mjs.map 51.00 B
230
230
  ESM dist/search/search.mjs.map 51.00 B
231
231
  ESM dist/sidebar/sidebar.mjs.map 51.00 B
232
232
  ESM dist/sort/sort.mjs.map 51.00 B
233
- ESM dist/table-header/table-header.mjs.map 51.00 B
234
233
  ESM dist/toast/index.mjs.map 51.00 B
234
+ ESM dist/table-header/table-header.mjs.map 51.00 B
235
235
  ESM dist/tooltip/tooltip.mjs.map 51.00 B
236
236
  ESM dist/featurePageComponents/mini-feature-block.mjs.map 1.53 KB
237
- ESM dist/file-picker/file-listing.mjs.map 51.00 B
238
237
  ESM dist/file-picker/file-picker.mjs.map 51.00 B
238
+ ESM dist/file-picker/file-listing.mjs.map 51.00 B
239
239
  ESM dist/layout/layout.mjs.map 51.00 B
240
240
  ESM dist/navbar/navbar.mjs.map 51.00 B
241
241
  ESM dist/pagination/pagination.mjs.map 51.00 B
@@ -280,12 +280,12 @@ Browserslist: caniuse-lite is outdated. Please run:
280
280
  ESM dist/dashboard-notification.mjs.map 51.00 B
281
281
  ESM dist/date-range-picker.mjs.map 51.00 B
282
282
  ESM dist/drag-and-drop.mjs.map 51.00 B
283
+ ESM dist/chunk-HZTQAUGX.mjs.map 71.82 KB
283
284
  ESM dist/chunk-PPMW7YAZ.mjs.map 14.21 KB
284
- ESM dist/chunk-4S3NZSBU.mjs.map 71.83 KB
285
285
  ESM dist/chunk-Q365BFES.mjs.map 9.87 KB
286
286
  ESM dist/chunk-EHJJX6ZZ.mjs.map 5.17 KB
287
287
  ESM dist/chunk-ZJATBQ3X.mjs.map 4.65 KB
288
- ESM dist/chunk-N7RKCR3X.mjs.map 5.52 KB
288
+ ESM dist/chunk-UUWBHZKH.mjs.map 5.52 KB
289
289
  ESM dist/chunk-ASCPOK5F.mjs.map 4.30 KB
290
290
  ESM dist/chunk-LQQDRIZN.mjs.map 8.11 KB
291
291
  ESM dist/chunk-256SAVHD.mjs.map 24.60 KB
@@ -314,9 +314,9 @@ Browserslist: caniuse-lite is outdated. Please run:
314
314
  ESM dist/chunk-REFCK56T.mjs.map 7.67 KB
315
315
  ESM dist/chunk-ZT7KDTGF.mjs.map 2.43 KB
316
316
  ESM dist/chunk-47S6AX7M.mjs.map 1.51 KB
317
+ ESM dist/chunk-FRIXS4BL.mjs.map 56.85 KB
317
318
  ESM dist/chunk-PJMH47GY.mjs.map 1.90 KB
318
319
  ESM dist/chunk-DZABAR36.mjs.map 2.13 KB
319
- ESM dist/chunk-FRIXS4BL.mjs.map 56.85 KB
320
320
  ESM dist/chunk-XUXHB434.mjs.map 3.21 KB
321
321
  ESM dist/chunk-F6ZWBNIM.mjs.map 2.59 KB
322
322
  ESM dist/chunk-PT4DPY4L.mjs.map 998.00 B
@@ -346,4 +346,4 @@ Browserslist: caniuse-lite is outdated. Please run:
346
346
  ESM dist/chunk-GBY2NNWZ.mjs.map 117.04 KB
347
347
  ESM dist/chunk-PUJZGK7Y.mjs.map 62.53 KB
348
348
  ESM dist/chunk-CEK5K5TU.mjs.map 709.95 KB
349
- ESM ⚡️ Build success in 72934ms
349
+ ESM ⚡️ Build success in 73106ms
package/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # ekm-ui
2
2
 
3
+ ## 0.3.74
4
+
5
+ ### Patch Changes
6
+
7
+ - d5fb5216: Entry point change to package json
8
+
9
+ ## 0.3.72
10
+
11
+ ### Patch Changes
12
+
13
+ - 474ebaaa: Fixed Toast z-index, Fixed Stacked List Component
14
+
3
15
  ## 0.3.71
4
16
 
5
17
  ### Patch Changes
@@ -1,10 +1,10 @@
1
- export { g as CardPaymentBlock } from './chunk-4S3NZSBU.mjs';
1
+ export { g as CardPaymentBlock } from './chunk-HZTQAUGX.mjs';
2
2
  import './chunk-PPMW7YAZ.mjs';
3
3
  import './chunk-Q365BFES.mjs';
4
4
  import './chunk-EHJJX6ZZ.mjs';
5
5
  import './chunk-ZJATBQ3X.mjs';
6
6
  import './chunk-CEK5K5TU.mjs';
7
- import './chunk-N7RKCR3X.mjs';
7
+ import './chunk-UUWBHZKH.mjs';
8
8
  import './chunk-ASCPOK5F.mjs';
9
9
  import './chunk-LQQDRIZN.mjs';
10
10
  import './chunk-256SAVHD.mjs';
@@ -27,8 +27,8 @@ import { BiSearch } from 'react-icons/bi';
27
27
  import { FaTimesCircle } from 'react-icons/fa';
28
28
  import Gr from 'pluralize';
29
29
 
30
- function je({cardPayment:e,enablePayPal:r}){return jsxs(a$6,{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:[r&&jsx(a$7,{id:"creditDebitCard",name:"paymentType",value:"creditDebitCard"}),jsx(a$8,{htmlFor:"creditDebitCard",children:"Pay by Credit or Debit card"})]}),jsxs("div",{className:r?"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"})]})]}),e&&jsxs(Fragment,{children:[jsxs("div",{className:"grid grid-cols-1 content-start gap-6 md:grid-cols-2",children:[jsx(a$9,{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$a,{id:"nameOnCard",name:"nameOnCard",placeholder:"Your name",type:"text",required:!0})}),jsx(a$9,{label:"Card Number *",htmlFor:"cardNumber",helperText:"This is the long number on the front of your credit or debit card.",children:jsx(a$a,{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$9,{label:"Expiry Date *",htmlFor:"nameOnCard",helperText:"The expiry date as it appears on your card.",children:jsx(a$a,{id:"nameOnCard",name:"nameOnCard",placeholder:"MM / YY",type:"text",required:!0})}),jsx(a$9,{label:"Security Code (CVC) *",htmlFor:"cardNumber",helperText:"The last three digits on the back of your card\u2019s signature strip.",children:jsx(a$a,{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:""})]})]}),r&&jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[jsx(a$7,{id:"PayPal",name:"paymentType",value:"PayPal"}),jsx(a$8,{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 $e(){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 gr({children:e,hasHeader:r}){let[s,u]=useState(!1),[E,P]=useState(!1);return useMemo(()=>{a$b()&&!s&&P(!0);},[s]),jsxs(Fragment,{children:[jsx(a$c,{onMenuButtonClick:()=>{u(!s);},showCloseButton:E,avatarImg:"https://avatars.githubusercontent.com/u/49406022?v=4"}),jsxs("div",{className:"flex",children:[jsx(b$1,{collapsed:s,children:jsx($e,{})}),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 ${r?"":"p-4"}`,children:e}),jsx(a$d,{companyName:"EKM"})]})]})]})}var Y=e(a$1());var f=Object.freeze({NONE:"none",OVER:"drag-over",UPLOADING:"uploading",ERROR:"error",SUCCESS:"success"}),Er=Object.freeze({[f.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",[f.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",[f.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",[f.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",[f.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"}),Cr=["png","webp","jpg","gif","jpeg"];function Je(e,r){let s=!r||r.length===0?Cr:r;if(!e||e.length===0)return !1;let u=e.split(".").pop().toLowerCase();return s.includes(u)}function oe({subtitle:e="PNG, WEBP, JPG, JPEG or GIF",filetypes:r,uploaded:s,exitCallback:u,callback:E,errorCallback:P,pickerCallback:O}){let[d,c]=useState(f.NONE);useEffect(()=>{Object.values(f).includes(s)&&(c(s),setTimeout(()=>{s===f.ERROR&&P?P():c(f.NONE);},2e3));},[s]);let C=p=>{p.preventDefault(),c(f.OVER);},y=p=>{p.preventDefault(),u&&u(),c(f.NONE);},k=p=>{p.preventDefault(),Je(p.dataTransfer.files[0].name,r)?(c(f.UPLOADING),E(p.dataTransfer.files[0])):(c(f.ERROR),setTimeout(()=>{P();},2e3));},J=p=>{Je(p.target.files[0].name,r)?c(f.UPLOADING):c(f.ERROR),E(p.target.files[0]);},h=()=>{O&&O();},T=()=>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:e}),O&&jsx("div",{className:"mt-5",children:jsxs(a$5,{color:"info",onClick:h,children:[jsx(BiSearch,{className:"mr-2"}),"Browse File Manager"]})})]}),N=()=>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"})})}),L=()=>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..."})})]}),b=()=>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"})})]}),z=()=>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"})})]}),i=()=>{switch(d){case f.OVER:return N();case f.UPLOADING:return L();case f.ERROR:return b();case f.SUCCESS:return z();default:return T()}};return jsx("div",{onDragEnter:p=>p.preventDefault(),onDragOver:C,onDrop:k,onDragLeave:y,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 ${Er[d]}`,children:[i(),d===f.NONE&&jsx("input",{id:"dropzone-file",type:"file",className:"hidden",onChange:J})]})})}oe.propTypes={filetypes:Y.default.arrayOf(Y.default.string),subtitle:Y.default.string,uploaded:Y.default.oneOf(["none","success","error"]).isRequired,exitCallback:Y.default.func,errorCallback:Y.default.func.isRequired,callback:Y.default.func.isRequired,pickerCallback:Y.default.func};oe.displayName="DragAndDrop";var X=e(a$1());var Ze="/admin/api/common/directoryinformation/",t=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"}),Rr=Object.freeze({mode:t.LOADING,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1});function Ar(e,r){switch(r.type){case t.EMPTY:return {mode:t.EMPTY,actionBtnTxt:"Add Image",actionBtnColor:"blue",listSize:"h-5/6",listBorder:"",searchDisabled:!0};case t.LOADING:return Rr;case t.LOADED:return {mode:t.LOADED,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[68.666667%]",listBorder:"border",searchDisabled:!1};case t.LOADED_NO_DRAG:return {mode:t.LOADED_NO_DRAG,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[87.666667%]",listBorder:"border",searchDisabled:!1};case t.SEARCH_RESULTS:return {mode:t.SEARCH_RESULTS,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case t.SEARCH_EMPTY:return {mode:t.SEARCH_EMPTY,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+r.page)}}function Me({appUrl:e,uri:r,show:s,hideDrag:u=!1,onClose:E,callback:P}){let O=useRef(),[d,c]=useReducer(Ar,{mode:t.LOADING,footerBorder:"border-t"}),[C,y]=useState(0),k=useRef(1),[J,h]=useState(!1),[T,N]=useState(!1),L=useRef({pages:0,totalEntries:0}),[b,z]=useState(!1),[i,p]=useState(null),[l,M]=useState(null),[me,q]=useState([]),[pe,G]=useState("none");useEffect(()=>{s&&(c({type:t.LOADING}),M(null),L.current={pages:0,totalEntries:0},ee(),Z(1));},[s]),useEffect(()=>{s&&(k.current=1,Z(),N(!1));},[i]),useEffect(()=>{l&&M(null),T&&N(!1);},[d.mode]);let ee=()=>{q([]),G("none"),z(!1),M(null),N(!1);},Z=(x=0)=>f$1(this,null,function*(){try{let _=x===0?k.current:x,re=(i==null?void 0:i.length)>0?`&FileNameIncludesString=${i}`:"&FileNameIncludesString=",j=yield (yield fetch(`${e}${Ze}?CurrentPage=${_}&PageSize=10&Uri=${r}${re}`,{method:"GET",credentials:"same-origin",headers:{"Content-Type":"application/json"}})).json();if((i==null?void 0:i.length)>0&&c({type:t.SEARCH_RESULTS}),j.Items.Data.length>0&&_>1?q(Re=>[...Re,...j.Items.Data]):q(j.Items.Data),L.current={pages:j.Items.NumberOfPages,totalEntries:j.Items.Total},y(j.Items.NumberOfPages),(i==null?void 0:i.length)>0)c({type:j.Items.Data.length>0?t.SEARCH_RESULTS:t.SEARCH_EMPTY});else {let Re=u?t.LOADED_NO_DRAG:t.LOADED;c({type:j.Items.Data.length>0?Re:t.EMPTY});}G("none"),z(!1),h(!1);}catch(_){c({type:(i==null?void 0:i.length)===0?t.SEARCH_EMPTY:t.EMPTY});}}),De=x=>{hidedrag||(h(!0),O.current.removeFocus(),x.preventDefault());},_e=x=>{hidedrag||h(!1);},n=x=>{var ge;let _=(ge=x.text)!=null?ge:"",re=i!=null?i:"";p(x.text),(re.length>0&&_.length===0||re.length===0&&_.length>0&&d.mode!==t.LOADING)&&c({type:t.LOADING});},v=()=>{N(!0),h(!1),G("none");},I=()=>{P(`https://files.ekmcdn.com/${l.Uri}`),D();},D=()=>{ee(),E();},S=x=>f$1(this,null,function*(){if(x==null){G("error"),v();return}try{let _=yield Or(x),re={Path:`/${r}/`,Name:x.name,Bytes:Ir(_),ForceOverwriteFile:!0};(yield fetch(`${e}${Ze}`,{method:"POST",credentials:"same-origin",headers:{"Content-Type":"application/json"},body:JSON.stringify(re)})).status===200?(G("success"),p(null),O.current.clear(),q([]),N(!1),Z(1)):G("error");}catch(_){G("error");}}),W=x=>{switch(x.type){case"FETCH_DATA":z(x.payload),k.current<L.current.pages&&!b&&(z(!0),k.current=k.current+1,Z());break;case"SELECTION":M(x.payload),N(!1);break;}},er=()=>{switch(d.mode){case t.EMPTY:return jsx(kr,{});case t.LOADING:return jsx(Tr,{});case t.SEARCH_RESULTS:case t.LOADED:case t.LOADED_NO_DRAG:return jsx(a$j,{border:d.listSize,files:me,isMore:k.current<L.current.pages,selected:l==null?void 0:l.Name,page:k.current,pages:C,callback:W});case t.SEARCH_EMPTY:return jsx(Lr,{});}},rr=()=>jsxs(Fragment,{children:[jsx(a$4,{id:"file-search",ref:O,placeholder:"Search your images",disabled:d.searchDisabled,callback:n}),jsxs("div",{className:"mt-4 mb-4",children:[T&&jsxs(a$i,{type:"danger",onDismiss:()=>{N(!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."})]}),d.mode!==t.SEARCH_RESULTS&&d.mode!==t.SEARCH_EMPTY&&!u&&jsx("div",{className:"h-68",children:jsx(oe,{uploaded:pe,callback:S,errorCallback:v})}),(d.mode===t.SEARCH_RESULTS||d.mode===t.SEARCH_EMPTY)&&(i==null?void 0:i.length)>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400",children:`Showing results for..."${i}"`})]}),er()]}),tr=()=>jsx("div",{className:"h-[90.666667%] w-[93.666667%] z-50 absolute",children:jsx(oe,{uploaded:pe,exitCallback:_e,callback:S,errorCallback:v})});return jsxs(a$3,{show:s,onClose:D,title:"File Picker",onHide:()=>{},children:[jsxs("div",{className:"h-full",onDragEnter:De,children:[s&&J&&!hidedrag&&tr(),s&&rr()]}),jsxs("div",{className:"grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$5,{color:"light",onClick:D,children:"Close"}),jsx(a$5,{color:d.actionBtnColor,onClick:I,disabled:l==null,children:d.actionBtnTxt})]})]})}Me.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};Me.displayName="FilePicker";function kr(){return jsxs("div",{className:"flex flex-col items-center justify-center mt-5",children:[jsx("h1",{children:jsx(BsFillImageFill,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 font-semibold text-2xl 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 Tr(){return jsx("div",{className:"h-2/3 overflow-y-auto flex items-center justify-center",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(Pr,{})}),jsx("p",{className:"mt-4 font-semibold text-2xl 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 Lr(){return jsx("div",{className:"h-5/6 overflow-y-auto flex items-center justify-center",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 font-semibold text-2xl 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 Pr(){return jsxs("div",{role:"status",children:[jsxs("svg",{"aria-hidden":"true",className:"inline w-14 h-14 text-gray-200 animate-spin dark:text-gray-600 fill-blue-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 Or(e){return f$1(this,null,function*(){return new Uint8Array(yield wr(e))})}function wr(e){return new Promise((r,s)=>{let u=new FileReader;u.onloadend=E=>r(E.target.result),u.onerror=E=>s(E),u.readAsArrayBuffer(e);})}function Ir(e){return btoa(Array.from(e).map(r=>String.fromCharCode(r)).join(""))}var se=e(a$1());function K({title:e,message:r,icon:s,children:u}){return jsx(a$e,{icon:s||jsx(a$f,{}),title:e,text:r,children:u})}K.propTypes={title:se.PropTypes.string.isRequired,message:se.PropTypes.string,useSpinner:se.PropTypes.bool,icon:se.PropTypes.node,children:se.PropTypes.node};K.displayName="TableResultBlock";var ce=e(a$1());var a=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",SELECTED:"SELECTED",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY"}),_r=[{display:"Name",value:"NME"},{display:"Category",value:"CAT"}],Ur=Object.freeze({mode:a.LOADING,listSize:"h-5/6",listBorder:"",searchDisabled:!1});function Yr(e){return [...[...e.orig].filter(s=>!e.remove.includes(s)),...e.add]}function zr(e,r){switch(r.type){case a.EMPTY:return {mode:a.EMPTY,listSize:"h-5/6",listBorder:"",searchDisabled:!0};case a.LOADING:return Ur;case a.LOADED:return {mode:a.LOADED,listSize:"h-[87.333333%]",listBorder:"border",searchDisabled:!1};case a.SELECTED:return {mode:a.SELECTED,listSize:"h-[80%]",listBorder:"border",searchDisabled:!1};case a.SEARCH_RESULTS:return {mode:a.SEARCH_RESULTS,listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case a.SEARCH_EMPTY:return {mode:a.SEARCH_EMPTY,listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+r.page)}}var Ge=forwardRef(function({show:r,preSelected:s=[],onClose:u,requestCallback:E,callback:P},O){let d=useRef(),c=useRef(!1),[C,y]=useReducer(zr,{mode:a.LOADING,footerBorder:"border-t"}),[k,J]=useState(0),h=useRef(1),T=useRef({pages:0,totalEntries:0}),[N,L]=useState(!1),[b$1,z]=useState({text:"",category:{display:"Name",value:"NME"}}),[i,p]=useState([]),[l,M]=useState({orig:[],add:[],remove:[],isAll:!1});useEffect(()=>{r&&(y({type:a.LOADING}),T.current={pages:0,totalEntries:0},me(),q(1),M(b(a$2({},l),{orig:s})),c.current=!0);},[r]),useEffect(()=>{r&&C.mode===c.current&&(h.current=1,q());},[b$1.text,b$1.category.display]);let me=()=>{p([]),M({orig:[],add:[],remove:[],isAll:!1}),L(!1);},q=(n=0)=>{let v=n===0?h.current:n;E({SearchText:b$1.text,PageSize:11,Page:v,SearchType:b$1.category.display});};useImperativeHandle(O,()=>({responseHandler:n=>{var v,I,D;try{((v=b$1.text)==null?void 0:v.length)>0&&y({type:a.SEARCH_RESULTS}),n.Result.Data.length>0&&h.current>1?p(S=>[...S,...n.Result.Data]):p(n.Result.Data),T.current={pages:n.Result.NumberOfPages,totalEntries:n.Result.Total},J(n.Result.NumberOfPages),((I=b$1.text)==null?void 0:I.length)>0?y({type:n.Result.Data.length>0?a.SEARCH_RESULTS:a.SEARCH_EMPTY}):y({type:n.Result.Data.length>0?a.LOADED:a.EMPTY}),l.orig.length+l.add.length-l.remove.length>0&&y({type:a.SELECTED}),L(!1);}catch(S){console.error("Error fetching products",S),y({type:((D=b$1.text)==null?void 0:D.length)===0?a.SEARCH_EMPTY:a.EMPTY});}}}));let pe=n=>{var D,S;let v=(D=n.text)!=null?D:"",I=(S=b$1.text)!=null?S:"";z(n),(I.length>0&&v.length===0||I.length===0&&v.length>0&&C.mode!==a.LOADING)&&y({type:a.LOADING});},G=()=>{P(l),ee();},ee=()=>{me(),c.current=!1,u();},Z=n=>{switch(n.type){case"FETCH_DATA":L(n.payload),h.current<T.current.pages&&!N&&(L(!0),h.current=h.current+1,q());break;case"SELECTION":let v=l.add.find(B=>B===n.payload)!=null,I=l.remove.find(B=>B===n.payload)!=null,D=l.orig.find(B=>B===n.payload)!=null,S=[...l.remove],W=[...l.add];D&&!I?S.push(n.payload):D&&I?S=[...S].filter(B=>B!==n.payload):!D&&!v?W.push(n.payload):!D&&v&&(W=[...W].filter(B=>B!==n.payload)),M(b(a$2({},l),{add:W,remove:S})),l.orig.length+W.length-S.length>0&&y({type:a.SELECTED});break;case"DESELECT_ALL":M(b(a$2({},l),{orig:[],add:[],remove:[]})),y({type:a.LOADED});break;}},De=()=>{switch(C.mode){case a.EMPTY:return jsx(K,{icon:jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:"You Have No Products",message:"Your products will appear here",spinner:!1});case a.LOADING:return jsx(K,{title:"Loading Products",message:"Please wait this may take a few minutes",spinner:!0});case a.SEARCH_RESULTS:case a.SELECTED:case a.LOADED:return jsx(a$g,{border:C.listSize,products:i,isMore:h.current<T.current.pages,selected:Yr(l),page:h.current,pages:k,callback:Z});case a.SEARCH_EMPTY:return jsx(K,{icon:jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:"No Products Found",message:"No products were found matching your search"});}};return jsxs(a$3,{show:r,onClose:ee,title:"File Picker",onHide:()=>{},children:[jsx("div",{className:"h-full",children:r&&(()=>jsxs(Fragment,{children:[l.orig.length+l.add.length-l.remove.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:[`${Gr("product",l.orig.length+l.add.length-l.remove.length,!0)} selected.`,jsx("span",{onClick:()=>Z({type:"DESELECT_ALL",payload:null}),className:"cursor-pointer text-primary-600 hover:underline",children:" Clear Selection."})]})}),jsx(a$4,{id:"file-search",ref:d,categories:_r,placeholder:"Search your images",disabled:C.searchDisabled,callback:pe}),jsx("div",{className:"mt-4 mb-4",children:(C.mode===a.SEARCH_RESULTS||C.mode===a.SEARCH_EMPTY)&&b$1.text.length>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400",children:`Showing results for..."${b$1.text}"`})}),De()]}))()}),jsxs("div",{className:"grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$5,{color:"light",onClick:ee,children:"Close"}),jsx(a$5,{color:"success",onClick:G,disabled:i.length===0,children:"Add Products"})]})]})});Ge.propTypes={show:ce.default.bool.isRequired,preSelected:ce.default.array,onClose:ce.default.func.isRequired,callback:ce.default.func.isRequired};Ge.displayName="ProductPicker";function Qe({id:e,title:r,text:s,avatarShow:u,avatarColor:E,avatarBorder:P,children:O,badgeText:d,badgeColor:c,icon:C}){function y(J){var h=J.split(" "),T=h[0],N=h[h.length-1],L=T.charAt(0);if(T!==N)var b=N.charAt(0);else var b="";return [L,b]}let k=y(r);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:[u&&jsx(a$h,{placeholderInitials:k,color:E,border:P}),C&&C,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:r}),d&&jsx(Badge,{color:c||"info",children:d})]}),jsx("p",{className:"mt-1 flex text-xs text-gray-500 dark:text-gray-400",children:jsx("span",{className:"relative truncate",children:s})})]})]}),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:O})})]},e)}Qe.displayName="StackedListItem";
30
+ function je({cardPayment:e,enablePayPal:r}){return jsxs(a$6,{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:[r&&jsx(a$7,{id:"creditDebitCard",name:"paymentType",value:"creditDebitCard"}),jsx(a$8,{htmlFor:"creditDebitCard",children:"Pay by Credit or Debit card"})]}),jsxs("div",{className:r?"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"})]})]}),e&&jsxs(Fragment,{children:[jsxs("div",{className:"grid grid-cols-1 content-start gap-6 md:grid-cols-2",children:[jsx(a$9,{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$a,{id:"nameOnCard",name:"nameOnCard",placeholder:"Your name",type:"text",required:!0})}),jsx(a$9,{label:"Card Number *",htmlFor:"cardNumber",helperText:"This is the long number on the front of your credit or debit card.",children:jsx(a$a,{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$9,{label:"Expiry Date *",htmlFor:"nameOnCard",helperText:"The expiry date as it appears on your card.",children:jsx(a$a,{id:"nameOnCard",name:"nameOnCard",placeholder:"MM / YY",type:"text",required:!0})}),jsx(a$9,{label:"Security Code (CVC) *",htmlFor:"cardNumber",helperText:"The last three digits on the back of your card\u2019s signature strip.",children:jsx(a$a,{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:""})]})]}),r&&jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[jsx(a$7,{id:"PayPal",name:"paymentType",value:"PayPal"}),jsx(a$8,{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 $e(){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 gr({children:e,hasHeader:r}){let[s,u]=useState(!1),[E,P]=useState(!1);return useMemo(()=>{a$b()&&!s&&P(!0);},[s]),jsxs(Fragment,{children:[jsx(a$c,{onMenuButtonClick:()=>{u(!s);},showCloseButton:E,avatarImg:"https://avatars.githubusercontent.com/u/49406022?v=4"}),jsxs("div",{className:"flex",children:[jsx(b$1,{collapsed:s,children:jsx($e,{})}),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 ${r?"":"p-4"}`,children:e}),jsx(a$d,{companyName:"EKM"})]})]})]})}var Y=e(a$1());var f=Object.freeze({NONE:"none",OVER:"drag-over",UPLOADING:"uploading",ERROR:"error",SUCCESS:"success"}),Er=Object.freeze({[f.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",[f.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",[f.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",[f.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",[f.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"}),Cr=["png","webp","jpg","gif","jpeg"];function Je(e,r){let s=!r||r.length===0?Cr:r;if(!e||e.length===0)return !1;let u=e.split(".").pop().toLowerCase();return s.includes(u)}function oe({subtitle:e="PNG, WEBP, JPG, JPEG or GIF",filetypes:r,uploaded:s,exitCallback:u,callback:E,errorCallback:P,pickerCallback:O}){let[d,c]=useState(f.NONE);useEffect(()=>{Object.values(f).includes(s)&&(c(s),setTimeout(()=>{s===f.ERROR&&P?P():c(f.NONE);},2e3));},[s]);let C=p=>{p.preventDefault(),c(f.OVER);},y=p=>{p.preventDefault(),u&&u(),c(f.NONE);},k=p=>{p.preventDefault(),Je(p.dataTransfer.files[0].name,r)?(c(f.UPLOADING),E(p.dataTransfer.files[0])):(c(f.ERROR),setTimeout(()=>{P();},2e3));},J=p=>{Je(p.target.files[0].name,r)?c(f.UPLOADING):c(f.ERROR),E(p.target.files[0]);},h=()=>{O&&O();},T=()=>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:e}),O&&jsx("div",{className:"mt-5",children:jsxs(a$5,{color:"info",onClick:h,children:[jsx(BiSearch,{className:"mr-2"}),"Browse File Manager"]})})]}),N=()=>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"})})}),L=()=>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..."})})]}),b=()=>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"})})]}),z=()=>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"})})]}),i=()=>{switch(d){case f.OVER:return N();case f.UPLOADING:return L();case f.ERROR:return b();case f.SUCCESS:return z();default:return T()}};return jsx("div",{onDragEnter:p=>p.preventDefault(),onDragOver:C,onDrop:k,onDragLeave:y,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 ${Er[d]}`,children:[i(),d===f.NONE&&jsx("input",{id:"dropzone-file",type:"file",className:"hidden",onChange:J})]})})}oe.propTypes={filetypes:Y.default.arrayOf(Y.default.string),subtitle:Y.default.string,uploaded:Y.default.oneOf(["none","success","error"]).isRequired,exitCallback:Y.default.func,errorCallback:Y.default.func.isRequired,callback:Y.default.func.isRequired,pickerCallback:Y.default.func};oe.displayName="DragAndDrop";var X=e(a$1());var Ze="/admin/api/common/directoryinformation/",t=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"}),Rr=Object.freeze({mode:t.LOADING,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1});function Ar(e,r){switch(r.type){case t.EMPTY:return {mode:t.EMPTY,actionBtnTxt:"Add Image",actionBtnColor:"blue",listSize:"h-5/6",listBorder:"",searchDisabled:!0};case t.LOADING:return Rr;case t.LOADED:return {mode:t.LOADED,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[68.666667%]",listBorder:"border",searchDisabled:!1};case t.LOADED_NO_DRAG:return {mode:t.LOADED_NO_DRAG,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[87.666667%]",listBorder:"border",searchDisabled:!1};case t.SEARCH_RESULTS:return {mode:t.SEARCH_RESULTS,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case t.SEARCH_EMPTY:return {mode:t.SEARCH_EMPTY,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+r.page)}}function Me({appUrl:e,uri:r,show:s,hideDrag:u=!1,onClose:E,callback:P}){let O=useRef(),[d,c]=useReducer(Ar,{mode:t.LOADING,footerBorder:"border-t"}),[C,y]=useState(0),k=useRef(1),[J,h]=useState(!1),[T,N]=useState(!1),L=useRef({pages:0,totalEntries:0}),[b,z]=useState(!1),[i,p]=useState(null),[l,M]=useState(null),[me,q]=useState([]),[pe,G]=useState("none");useEffect(()=>{s&&(c({type:t.LOADING}),M(null),L.current={pages:0,totalEntries:0},ee(),Z(1));},[s]),useEffect(()=>{s&&(k.current=1,Z(),N(!1));},[i]),useEffect(()=>{l&&M(null),T&&N(!1);},[d.mode]);let ee=()=>{q([]),G("none"),z(!1),M(null),N(!1);},Z=(x=0)=>f$1(this,null,function*(){try{let _=x===0?k.current:x,re=(i==null?void 0:i.length)>0?`&FileNameIncludesString=${i}`:"&FileNameIncludesString=",j=yield (yield fetch(`${e}${Ze}?CurrentPage=${_}&PageSize=10&Uri=${r}${re}`,{method:"GET",credentials:"same-origin",headers:{"Content-Type":"application/json"}})).json();if((i==null?void 0:i.length)>0&&c({type:t.SEARCH_RESULTS}),j.Items.Data.length>0&&_>1?q(Re=>[...Re,...j.Items.Data]):q(j.Items.Data),L.current={pages:j.Items.NumberOfPages,totalEntries:j.Items.Total},y(j.Items.NumberOfPages),(i==null?void 0:i.length)>0)c({type:j.Items.Data.length>0?t.SEARCH_RESULTS:t.SEARCH_EMPTY});else {let Re=u?t.LOADED_NO_DRAG:t.LOADED;c({type:j.Items.Data.length>0?Re:t.EMPTY});}G("none"),z(!1),h(!1);}catch(_){c({type:(i==null?void 0:i.length)===0?t.SEARCH_EMPTY:t.EMPTY});}}),De=x=>{hidedrag||(h(!0),O.current.removeFocus(),x.preventDefault());},_e=x=>{hidedrag||h(!1);},n=x=>{var ge;let _=(ge=x.text)!=null?ge:"",re=i!=null?i:"";p(x.text),(re.length>0&&_.length===0||re.length===0&&_.length>0&&d.mode!==t.LOADING)&&c({type:t.LOADING});},v=()=>{N(!0),h(!1),G("none");},I=()=>{P(`https://files.ekmcdn.com/${l.Uri}`),D();},D=()=>{ee(),E();},S=x=>f$1(this,null,function*(){if(x==null){G("error"),v();return}try{let _=yield Or(x),re={Path:`/${r}/`,Name:x.name,Bytes:Ir(_),ForceOverwriteFile:!0};(yield fetch(`${e}${Ze}`,{method:"POST",credentials:"same-origin",headers:{"Content-Type":"application/json"},body:JSON.stringify(re)})).status===200?(G("success"),p(null),O.current.clear(),q([]),N(!1),Z(1)):G("error");}catch(_){G("error");}}),W=x=>{switch(x.type){case"FETCH_DATA":z(x.payload),k.current<L.current.pages&&!b&&(z(!0),k.current=k.current+1,Z());break;case"SELECTION":M(x.payload),N(!1);break;}},er=()=>{switch(d.mode){case t.EMPTY:return jsx(kr,{});case t.LOADING:return jsx(Tr,{});case t.SEARCH_RESULTS:case t.LOADED:case t.LOADED_NO_DRAG:return jsx(a$j,{border:d.listSize,files:me,isMore:k.current<L.current.pages,selected:l==null?void 0:l.Name,page:k.current,pages:C,callback:W});case t.SEARCH_EMPTY:return jsx(Lr,{});}},rr=()=>jsxs(Fragment,{children:[jsx(a$4,{id:"file-search",ref:O,placeholder:"Search your images",disabled:d.searchDisabled,callback:n}),jsxs("div",{className:"mt-4 mb-4",children:[T&&jsxs(a$i,{type:"danger",onDismiss:()=>{N(!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."})]}),d.mode!==t.SEARCH_RESULTS&&d.mode!==t.SEARCH_EMPTY&&!u&&jsx("div",{className:"h-68",children:jsx(oe,{uploaded:pe,callback:S,errorCallback:v})}),(d.mode===t.SEARCH_RESULTS||d.mode===t.SEARCH_EMPTY)&&(i==null?void 0:i.length)>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400",children:`Showing results for..."${i}"`})]}),er()]}),tr=()=>jsx("div",{className:"h-[90.666667%] w-[93.666667%] z-50 absolute",children:jsx(oe,{uploaded:pe,exitCallback:_e,callback:S,errorCallback:v})});return jsxs(a$3,{show:s,onClose:D,title:"File Picker",onHide:()=>{},children:[jsxs("div",{className:"h-full",onDragEnter:De,children:[s&&J&&!hidedrag&&tr(),s&&rr()]}),jsxs("div",{className:"grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$5,{color:"light",onClick:D,children:"Close"}),jsx(a$5,{color:d.actionBtnColor,onClick:I,disabled:l==null,children:d.actionBtnTxt})]})]})}Me.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};Me.displayName="FilePicker";function kr(){return jsxs("div",{className:"flex flex-col items-center justify-center mt-5",children:[jsx("h1",{children:jsx(BsFillImageFill,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 font-semibold text-2xl 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 Tr(){return jsx("div",{className:"h-2/3 overflow-y-auto flex items-center justify-center",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(Pr,{})}),jsx("p",{className:"mt-4 font-semibold text-2xl 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 Lr(){return jsx("div",{className:"h-5/6 overflow-y-auto flex items-center justify-center",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 font-semibold text-2xl 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 Pr(){return jsxs("div",{role:"status",children:[jsxs("svg",{"aria-hidden":"true",className:"inline w-14 h-14 text-gray-200 animate-spin dark:text-gray-600 fill-blue-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 Or(e){return f$1(this,null,function*(){return new Uint8Array(yield wr(e))})}function wr(e){return new Promise((r,s)=>{let u=new FileReader;u.onloadend=E=>r(E.target.result),u.onerror=E=>s(E),u.readAsArrayBuffer(e);})}function Ir(e){return btoa(Array.from(e).map(r=>String.fromCharCode(r)).join(""))}var se=e(a$1());function K({title:e,message:r,icon:s,children:u}){return jsx(a$e,{icon:s||jsx(a$f,{}),title:e,text:r,children:u})}K.propTypes={title:se.PropTypes.string.isRequired,message:se.PropTypes.string,useSpinner:se.PropTypes.bool,icon:se.PropTypes.node,children:se.PropTypes.node};K.displayName="TableResultBlock";var ce=e(a$1());var a=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",SELECTED:"SELECTED",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY"}),_r=[{display:"Name",value:"NME"},{display:"Category",value:"CAT"}],Ur=Object.freeze({mode:a.LOADING,listSize:"h-5/6",listBorder:"",searchDisabled:!1});function Yr(e){return [...[...e.orig].filter(s=>!e.remove.includes(s)),...e.add]}function zr(e,r){switch(r.type){case a.EMPTY:return {mode:a.EMPTY,listSize:"h-5/6",listBorder:"",searchDisabled:!0};case a.LOADING:return Ur;case a.LOADED:return {mode:a.LOADED,listSize:"h-[87.333333%]",listBorder:"border",searchDisabled:!1};case a.SELECTED:return {mode:a.SELECTED,listSize:"h-[80%]",listBorder:"border",searchDisabled:!1};case a.SEARCH_RESULTS:return {mode:a.SEARCH_RESULTS,listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case a.SEARCH_EMPTY:return {mode:a.SEARCH_EMPTY,listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+r.page)}}var Ge=forwardRef(function({show:r,preSelected:s=[],onClose:u,requestCallback:E,callback:P},O){let d=useRef(),c=useRef(!1),[C,y]=useReducer(zr,{mode:a.LOADING,footerBorder:"border-t"}),[k,J]=useState(0),h=useRef(1),T=useRef({pages:0,totalEntries:0}),[N,L]=useState(!1),[b$1,z]=useState({text:"",category:{display:"Name",value:"NME"}}),[i,p]=useState([]),[l,M]=useState({orig:[],add:[],remove:[],isAll:!1});useEffect(()=>{r&&(y({type:a.LOADING}),T.current={pages:0,totalEntries:0},me(),q(1),M(b(a$2({},l),{orig:s})),c.current=!0);},[r]),useEffect(()=>{r&&C.mode===c.current&&(h.current=1,q());},[b$1.text,b$1.category.display]);let me=()=>{p([]),M({orig:[],add:[],remove:[],isAll:!1}),L(!1);},q=(n=0)=>{let v=n===0?h.current:n;E({SearchText:b$1.text,PageSize:11,Page:v,SearchType:b$1.category.display});};useImperativeHandle(O,()=>({responseHandler:n=>{var v,I,D;try{((v=b$1.text)==null?void 0:v.length)>0&&y({type:a.SEARCH_RESULTS}),n.Result.Data.length>0&&h.current>1?p(S=>[...S,...n.Result.Data]):p(n.Result.Data),T.current={pages:n.Result.NumberOfPages,totalEntries:n.Result.Total},J(n.Result.NumberOfPages),((I=b$1.text)==null?void 0:I.length)>0?y({type:n.Result.Data.length>0?a.SEARCH_RESULTS:a.SEARCH_EMPTY}):y({type:n.Result.Data.length>0?a.LOADED:a.EMPTY}),l.orig.length+l.add.length-l.remove.length>0&&y({type:a.SELECTED}),L(!1);}catch(S){console.error("Error fetching products",S),y({type:((D=b$1.text)==null?void 0:D.length)===0?a.SEARCH_EMPTY:a.EMPTY});}}}));let pe=n=>{var D,S;let v=(D=n.text)!=null?D:"",I=(S=b$1.text)!=null?S:"";z(n),(I.length>0&&v.length===0||I.length===0&&v.length>0&&C.mode!==a.LOADING)&&y({type:a.LOADING});},G=()=>{P(l),ee();},ee=()=>{me(),c.current=!1,u();},Z=n=>{switch(n.type){case"FETCH_DATA":L(n.payload),h.current<T.current.pages&&!N&&(L(!0),h.current=h.current+1,q());break;case"SELECTION":let v=l.add.find(B=>B===n.payload)!=null,I=l.remove.find(B=>B===n.payload)!=null,D=l.orig.find(B=>B===n.payload)!=null,S=[...l.remove],W=[...l.add];D&&!I?S.push(n.payload):D&&I?S=[...S].filter(B=>B!==n.payload):!D&&!v?W.push(n.payload):!D&&v&&(W=[...W].filter(B=>B!==n.payload)),M(b(a$2({},l),{add:W,remove:S})),l.orig.length+W.length-S.length>0&&y({type:a.SELECTED});break;case"DESELECT_ALL":M(b(a$2({},l),{orig:[],add:[],remove:[]})),y({type:a.LOADED});break;}},De=()=>{switch(C.mode){case a.EMPTY:return jsx(K,{icon:jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:"You Have No Products",message:"Your products will appear here",spinner:!1});case a.LOADING:return jsx(K,{title:"Loading Products",message:"Please wait this may take a few minutes",spinner:!0});case a.SEARCH_RESULTS:case a.SELECTED:case a.LOADED:return jsx(a$g,{border:C.listSize,products:i,isMore:h.current<T.current.pages,selected:Yr(l),page:h.current,pages:k,callback:Z});case a.SEARCH_EMPTY:return jsx(K,{icon:jsx(HiClipboardList,{className:"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400"}),title:"No Products Found",message:"No products were found matching your search"});}};return jsxs(a$3,{show:r,onClose:ee,title:"File Picker",onHide:()=>{},children:[jsx("div",{className:"h-full",children:r&&(()=>jsxs(Fragment,{children:[l.orig.length+l.add.length-l.remove.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:[`${Gr("product",l.orig.length+l.add.length-l.remove.length,!0)} selected.`,jsx("span",{onClick:()=>Z({type:"DESELECT_ALL",payload:null}),className:"cursor-pointer text-primary-600 hover:underline",children:" Clear Selection."})]})}),jsx(a$4,{id:"file-search",ref:d,categories:_r,placeholder:"Search your images",disabled:C.searchDisabled,callback:pe}),jsx("div",{className:"mt-4 mb-4",children:(C.mode===a.SEARCH_RESULTS||C.mode===a.SEARCH_EMPTY)&&b$1.text.length>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400",children:`Showing results for..."${b$1.text}"`})}),De()]}))()}),jsxs("div",{className:"grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$5,{color:"light",onClick:ee,children:"Close"}),jsx(a$5,{color:"success",onClick:G,disabled:i.length===0,children:"Add Products"})]})]})});Ge.propTypes={show:ce.default.bool.isRequired,preSelected:ce.default.array,onClose:ce.default.func.isRequired,callback:ce.default.func.isRequired};Ge.displayName="ProductPicker";function Qe({id:e,title:r,text:s,avatarShow:u,avatarColor:E,avatarBorder:P,children:O,badgeText:d,badgeColor:c,icon:C}){function y(J){var h=J.split(" "),T=h[0],N=h[h.length-1],L=T.charAt(0);if(T!==N)var b=N.charAt(0);else var b="";return L+b}let k=y(r);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:[u&&jsx(a$h,{placeholderInitials:k,color:E,border:P}),C&&C,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:r}),d&&jsx(Badge,{color:c||"info",children:d})]}),jsx("p",{className:"mt-1 flex text-xs text-gray-500 dark:text-gray-400",children:jsx("span",{className:"relative truncate",children:s})})]})]}),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:O})})]},e)}Qe.displayName="StackedListItem";
31
31
 
32
32
  export { Qe as a, gr as b, oe as c, Me as d, K as e, Ge as f, je as g };
33
33
  //# sourceMappingURL=out.js.map
34
- //# sourceMappingURL=chunk-4S3NZSBU.mjs.map
34
+ //# sourceMappingURL=chunk-HZTQAUGX.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../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-drawer.tsx","../src/stacked-list-item.tsx"],"names":["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","useEffect","BsCloudUpload","BsFillCheckCircleFill","BiSearch","FaTimesCircle","import_prop_types","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","useRef","useReducer","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","cp","__async","page","searchUri","data","loadedState","error","handleDragEnter","handleDragLeave","handleSearchRequest","searchTerm","_a","text","s","handleDropError","handleUseImage","handleClose","handleFileUpload","file","arr","getAsByteArray","payload","getBase64","handleListActions","calculateListSize","renderList","EmptyPlaceholder","LoadingPlaceholder","Listing","SearchEmptyPlaceholder","renderContent","Search","AlertBanner","renderOversizedDropZone","Drawer","Spinner","readFile","resolve","reject","reader","event","b","TableResultBlock","title","message","icon","NoResultsBlock","useImperativeHandle","forwardRef","HiClipboardList","pluralize","searchCategories","calculateSelectedProducts","obj","x","ProductPickerReducer","ProductPicker","preSelected","requestCallback","ref","isViewableRef","products","setProducts","session","setSession","getProducts","__spreadProps","__spreadValues","response","_b","_c","handleProductSelection","added","removed","preExisted","rem","add","Badge","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 { 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 { Navbar, Sidebar, LoveFooter } from \"../\";\nimport { useMemo, useState } from \"react\";\nimport isSmallScreen from \"../helpers/is-small-screen\";\nimport { SidebarItems } from \"../../shared/sidebar-items\";\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 { useEffect, useState } from \"react\";\nimport { BsCloudUpload, BsFillCheckCircleFill } from \"react-icons/bs\";\nimport { BiSearch } from \"react-icons/bi\";\nimport { FaTimesCircle } from \"react-icons/fa\";\nimport { Button } from \"./index\";\nimport PropTypes from \"prop-types\";\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-5\">\n <Button color=\"info\" 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\"","// @ts-nocheck\nimport { useEffect, useRef, useState, useReducer } from 'react'\nimport { Drawer } from '../drawer'\nimport { Button } from '../button'\nimport { AlertBanner } from '../alert-banner'\nimport { Search } from '../search/search'\nimport { DragAndDrop } from '../drag-and-drop'\nimport { BsFillImageFill } from 'react-icons/bs'\nimport { HiOutlineSearch } from 'react-icons/hi'\nimport Listing from './file-listing'\nimport PropTypes from 'prop-types'\n\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: 'blue',\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-[87.666667%]',\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\n/**\n * IMPORTANT TO NOTE\n * The parent/calling component is responsible for fetching the files. This component should not reallyknow\n * what the files are, just how to display them. This means that searching and pagination logic should also\n * be handled by the parent/calling component\n */\n\nexport function FilePicker({ appUrl, uri, show, hideDrag = false, onClose, callback }) {\n const searchFieldRef = useRef()\n const [state, dispatch] = useReducer(FilePickerReducer, { mode: Status.LOADING, footerBorder: 'border-t' })\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(null)\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(1)\n }\n }, [show])\n\n useEffect(() => {\n if (show) {\n currentPageRef.current = 1\n getFiles()\n setErr(false)\n }\n }, [search])\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 }\n\n const getFiles = async (cp = 0) => {\n try {\n let page = cp === 0 ? currentPageRef.current : cp\n let searchUri = search?.length > 0 ? `&FileNameIncludesString=${search}` : `&FileNameIncludesString=`\n const response = await fetch(`${appUrl}${apiUrl}?CurrentPage=${page}&PageSize=10&Uri=${uri}${searchUri}`, {\n method: 'GET',\n credentials: 'same-origin',\n headers: { 'Content-Type': 'application/json' },\n })\n const data = await response.json()\n if (search?.length > 0) dispatch({ type: Status.SEARCH_RESULTS })\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 = { pages: data.Items.NumberOfPages, totalEntries: data.Items.Total }\n setTotalPages(data.Items.NumberOfPages)\n\n if (search?.length > 0) {\n dispatch({ type: data.Items.Data.length > 0 ? Status.SEARCH_RESULTS : Status.SEARCH_EMPTY })\n } else {\n const loadedState = hideDrag ? Status.LOADED_NO_DRAG : Status.LOADED\n dispatch({ type: data.Items.Data.length > 0 ? loadedState : Status.EMPTY })\n }\n\n setUploadedImage('none')\n\n setFetchData(false)\n setDragging(false)\n } catch (error) {\n dispatch({ type: search?.length === 0 ? Status.SEARCH_EMPTY : Status.EMPTY })\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(searchTerm.text)\n if ((s.length > 0 && text.length === 0) || (s.length === 0 && text.length > 0 && state.mode !== Status.LOADING))\n dispatch({ type: Status.LOADING })\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 clearState()\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 arr = await getAsByteArray(file)\n const payload = {\n Path: `/${uri}/`,\n Name: file.name,\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(null)\n searchFieldRef.current.clear()\n // dispatch({ type: Status.LOADED })\n setFiles([])\n setErr(false)\n getFiles(1)\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 (currentPageRef.current < listAttributeRef.current.pages && !fetchData) {\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()\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 (state.mode === Status.SEARCH_RESULTS || state.mode === Status.LOADED_NO_DRAG) {\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 id=\"file-search\" ref={searchFieldRef} placeholder=\"Search your images\" disabled={state.searchDisabled} callback={handleSearchRequest} />\n <div className=\"mt-4 mb-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 && state.mode !== Status.SEARCH_EMPTY && !hideDrag && (\n <div className=\"h-68\">\n <DragAndDrop uploaded={uploadedImage} callback={handleFileUpload} errorCallback={handleDropError} />\n </div>\n )}\n {(state.mode === Status.SEARCH_RESULTS || state.mode === Status.SEARCH_EMPTY) && search?.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400\">{`Showing results for...\"${search}\"`}</span>\n )}\n </div>\n\n {renderList()}\n </>\n )\n\n const renderOversizedDropZone = () => (\n <div className=\"h-[90.666667%] w-[93.666667%] z-50 absolute\">\n <DragAndDrop uploaded={uploadedImage} exitCallback={handleDragLeave} callback={handleFileUpload} errorCallback={handleDropError} />\n </div>\n )\n\n return (\n <Drawer show={show} onClose={handleClose} title=\"File Picker\" onHide={() => {}}>\n <div className=\"h-full\" onDragEnter={handleDragEnter}>\n {show && dragging && !hidedrag && renderOversizedDropZone()}\n {show && renderContent()}\n </div>\n <div className={`grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600`} style={{ marginTop: '-50px' }}>\n <Button color=\"light\" onClick={handleClose}>\n Close\n </Button>\n <Button color={state.actionBtnColor} onClick={handleUseImage} disabled={selected == null}>\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 assosiated 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=\"flex flex-col items-center justify-center mt-5\">\n <h1>\n <BsFillImageFill className=\"text-9xl text-gray-700\" />\n </h1>\n <p className=\"mt-4 font-semibold text-2xl text-gray-900\">You Have No Images</p>\n <p className=\"mt-4 text-sm text-gray-500\">Images will appear here when you upload them</p>\n </div>\n )\n}\n\nfunction LoadingPlaceholder() {\n return (\n <div className=\"h-2/3 overflow-y-auto flex items-center justify-center\">\n <div className=\"flex flex-col items-center justify-center\">\n <h1>\n <Spinner />\n </h1>\n <p className=\"mt-4 font-semibold text-2xl text-gray-900\">Loading Files</p>\n <p className=\"mt-4 text-sm text-gray-500\">Don't worry, this won't take long...</p>\n </div>\n </div>\n )\n}\n\nfunction SearchEmptyPlaceholder() {\n return (\n <div className=\"h-5/6 overflow-y-auto flex items-center justify-center\">\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 font-semibold text-2xl text-gray-900\">No Files Found</p>\n <p className=\"mt-4 text-sm text-gray-500\">No files were found matching your search</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 w-14 h-14 text-gray-200 animate-spin dark:text-gray-600 fill-blue-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","//@ts-nocheck\nimport { Spinner, NoResultsBlock } from '.';\nimport {PropTypes} from \"prop-types\";\n\n\n\nexport function TableResultBlock({ title, message, icon, children }) {\n return (\n <NoResultsBlock icon={icon ? icon :<Spinner /> } title={title} text={message}>\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 { useEffect, useRef, useState, useReducer, useImperativeHandle, forwardRef } from 'react'\nimport { Drawer } from '../drawer'\nimport { Button } from '../button'\nimport { Search} from '../search/search'\nimport { TableResultBlock } from '../table-result-block'\nimport { HiClipboardList } from 'react-icons/hi'\nimport { Listing } from './product-listing'\nimport PropTypes from 'prop-types'\nimport pluralize from 'pluralize'\n\nconst Status = Object.freeze({\n EMPTY: 'EMPTY',\n SEARCH_LOADING: 'SEARCH-LOADING',\n LOADING: 'LOADING',\n LOADED: 'LOADED',\n SELECTED: 'SELECTED',\n SEARCH_RESULTS: 'SEARCH-RESULTS',\n SEARCH_EMPTY: 'SEARCH-EMPTY',\n})\n\nconst searchCategories = [\n {\n display: 'Name',\n value: 'NME',\n },\n {\n display: 'Category',\n value: 'CAT',\n },\n]\n\nconst initialState = Object.freeze({\n mode: Status.LOADING,\n listSize: 'h-5/6',\n listBorder: '',\n searchDisabled: false,\n})\n\nfunction calculateSelectedProducts(obj) {\n const mutatedOriginalArray = [...obj.orig].filter((x) => {\n return !obj.remove.includes(x)\n })\n return [...mutatedOriginalArray, ...obj.add]\n}\n\nfunction ProductPickerReducer(state, action) {\n switch (action.type) {\n case Status.EMPTY:\n return {\n mode: Status.EMPTY,\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 listSize: 'h-[87.333333%]',\n listBorder: 'border',\n searchDisabled: false,\n }\n case Status.SELECTED:\n return { mode: Status.SELECTED, listSize: 'h-[80%]', listBorder: 'border', searchDisabled: false }\n case Status.SEARCH_RESULTS:\n return {\n mode: Status.SEARCH_RESULTS,\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 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\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({ show, preSelected = [], onClose, requestCallback, callback }, ref) {\n const searchFieldRef = useRef()\n const isViewableRef = useRef(false)\n const [state, dispatch] = useReducer(ProductPickerReducer, { mode: Status.LOADING, footerBorder: 'border-t' })\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({ text: '', category: { display: 'Name', value: 'NME' } })\n const [products, setProducts] = useState([])\n // Selected State\n const [session, setSession] = useState({ orig: [], add: [], remove: [], isAll: false }) // handles DEFAULT selection sessions\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([])\n listAttributeRef.current = { pages: 0, totalEntries: 0 }\n clearState()\n getProducts(1)\n setSession({ ...session, orig: preSelected })\n isViewableRef.current = true\n }\n }, [show])\n\n useEffect(() => {\n if (show && state.mode === isViewableRef.current) {\n currentPageRef.current = 1\n getProducts()\n }\n }, [search.text, search.category.display])\n\n const clearState = () => {\n setProducts([])\n setSession({ orig: [], add: [], remove: [], isAll: false })\n setFetchData(false)\n }\n\n const getProducts = (cp = 0) => {\n let page = cp === 0 ? currentPageRef.current : cp\n requestCallback({\n SearchText: search.text,\n PageSize: 11,\n Page: page,\n SearchType: search.category.display,\n })\n }\n\n useImperativeHandle(ref, () => ({\n responseHandler: (response) => {\n try {\n if (search.text?.length > 0) dispatch({ type: Status.SEARCH_RESULTS })\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 = { pages: response.Result.NumberOfPages, totalEntries: response.Result.Total }\n setTotalPages(response.Result.NumberOfPages)\n\n if (search.text?.length > 0) {\n dispatch({ type: response.Result.Data.length > 0 ? Status.SEARCH_RESULTS : Status.SEARCH_EMPTY })\n } else {\n dispatch({ type: response.Result.Data.length > 0 ? Status.LOADED : Status.EMPTY })\n }\n if (session.orig.length + session.add.length - session.remove.length > 0) dispatch({ type: Status.SELECTED })\n setFetchData(false)\n } catch (error) {\n console.error('Error fetching products', error)\n dispatch({ type: search.text?.length === 0 ? Status.SEARCH_EMPTY : Status.EMPTY })\n }\n },\n }))\n\n const handleSearchRequest = (searchTerm) => {\n const text = searchTerm.text ?? ''\n const s = search.text ?? ''\n setSearch(searchTerm)\n if ((s.length > 0 && text.length === 0) || (s.length === 0 && text.length > 0 && state.mode !== Status.LOADING))\n dispatch({ type: Status.LOADING })\n }\n\n const handleProductSelection = () => {\n callback(session)\n handleClose()\n }\n\n const handleClose = () => {\n clearState()\n isViewableRef.current = false\n onClose()\n }\n\n const handleListActions = (action) => {\n switch (action.type) {\n case 'FETCH_DATA':\n setFetchData(action.payload)\n if (currentPageRef.current < listAttributeRef.current.pages && !fetchData) {\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()\n }\n break\n case 'SELECTION':\n const added = session.add.find((x) => x === action.payload) != null\n const removed = session.remove.find((x) => x === action.payload) != null\n const preExisted = session.orig.find((x) => x === action.payload) != null\n let rem = [...session.remove]\n let add = [...session.add]\n if (preExisted && !removed) {\n rem.push(action.payload)\n } else if (preExisted && removed) {\n rem = [...rem].filter((x) => x !== action.payload)\n } else if (!preExisted && !added) {\n add.push(action.payload)\n } else if (!preExisted && added) {\n add = [...add].filter((x) => x !== action.payload)\n }\n\n setSession({ ...session, add: add, remove: rem })\n if (session.orig.length + add.length - rem.length > 0) dispatch({ type: Status.SELECTED })\n break\n case 'DESELECT_ALL':\n setSession({ ...session, orig: [], add: [], remove: [] })\n dispatch({ type: Status.LOADED })\n break\n default:\n break\n }\n }\n\n const renderList = () => {\n switch (state.mode) {\n case Status.EMPTY:\n return (\n <TableResultBlock\n icon={<HiClipboardList className=\"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400\" />}\n title=\"You Have No Products\"\n message=\"Your products will appear here\"\n spinner={false}\n />\n )\n case Status.LOADING:\n return <TableResultBlock title=\"Loading Products\" message=\"Please wait this may take a few minutes\" spinner />\n case Status.SEARCH_RESULTS:\n case Status.SELECTED:\n case Status.LOADED:\n return (\n <Listing\n border={state.listSize}\n products={products}\n isMore={currentPageRef.current < listAttributeRef.current.pages}\n selected={calculateSelectedProducts(session)}\n page={currentPageRef.current}\n pages={totalPages}\n callback={handleListActions}\n />\n )\n case Status.SEARCH_EMPTY:\n return (\n <TableResultBlock\n icon={<HiClipboardList className=\"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400\" />}\n title=\"No Products Found\"\n message=\"No products were found matching your search\"\n />\n )\n\n default:\n break\n }\n }\n\n const renderContent = () => (\n <>\n {session.orig.length + session.add.length - session.remove.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('product', session.orig.length + session.add.length - session.remove.length, true)} selected.`}\n <span\n onClick={() => handleListActions({ type: 'DESELECT_ALL', payload: null })}\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={searchCategories}\n placeholder=\"Search your images\"\n disabled={state.searchDisabled}\n callback={handleSearchRequest}\n />\n <div className=\"mt-4 mb-4\">\n {(state.mode === Status.SEARCH_RESULTS || state.mode === Status.SEARCH_EMPTY) && search.text.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400\">{`Showing results for...\"${search.text}\"`}</span>\n )}\n </div>\n {renderList()}\n </>\n )\n\n return (\n <Drawer show={show} onClose={handleClose} title=\"File Picker\" onHide={() => {}}>\n <div className=\"h-full\">{show && renderContent()}</div>\n <div className={`grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600`} style={{ marginTop: '-50px' }}>\n <Button color=\"light\" onClick={handleClose}>\n Close\n </Button>\n <Button color=\"success\" onClick={handleProductSelection} disabled={products.length === 0}>\n Add Products\n </Button>\n </div>\n </Drawer>\n )\n})\n\nProductPicker.propTypes = {\n /** Show the drawer */\n show: PropTypes.bool.isRequired,\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 /** Callback to return the selected products {orig - preselected, add - newly added, remove -items removed from pre-selected} */\n callback: PropTypes.func.isRequired,\n}\n\nProductPicker.displayName = 'ProductPicker'\n","//@ts-nocheck\nimport { Avatar } from \"./\";\nimport { Badge } from \"flowbite-react\";\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"]}
@@ -0,0 +1,11 @@
1
+ import { createContext, useState, useEffect, useCallback, Fragment, useContext } from 'react';
2
+ import { Transition } from '@headlessui/react';
3
+ import v from 'clsx';
4
+ import { HiCheck, HiXCircle, HiInformationCircle, HiExclamationTriangle } from 'react-icons/hi2';
5
+ import { jsxs, jsx } from 'react/jsx-runtime';
6
+
7
+ var i=createContext(void 0);function b({children:r}){let[a,n]=useState([]);useEffect(()=>{if(a.length>1){let t=setTimeout(()=>n(s=>s.slice(1)),1e3);return ()=>clearTimeout(t)}if(a.length>0){let t=setTimeout(()=>n(s=>s.slice(1)),2e3);return ()=>clearTimeout(t)}},[a]);let l=useCallback(function(t){n(s=>[...s,t]);},[n]);return jsxs(i.Provider,{value:l,children:[r,jsx("div",{"aria-live":"assertive",className:"pointer-events-none fixed inset-0 right-0 z-50 flex flex-col items-end px-4 py-6 sm:items-end sm:p-6",children:a.map(t=>jsx(h,{type:t.type,text:t.text}))})]})}b.displayName="ToastProvider";function h({type:r,text:a}){return jsx(Transition,{show:!0,as:Fragment,enter:"transform ease-out duration-300 transition",enterFrom:"translate-y-2 opacity-0 sm:translate-y-0 sm:translate-x-2",enterTo:"translate-y-0 opacity-100 sm:translate-x-0",leave:"transition ease-in duration-100",leaveFrom:"opacity-100",leaveTo:"opacity-0",children:jsxs("div",{className:"mb-4 flex w-full max-w-xs items-center rounded-lg bg-white p-4 text-gray-500 shadow dark:bg-gray-800 dark:text-gray-400",role:"alert",children:[jsxs("div",{className:v("inline-flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg",{success:"bg-green-100 text-green-500 dark:bg-green-800 dark:text-green-200",error:"bg-red-100 text-red-500 dark:bg-red-800 dark:text-red-200",info:"bg-blue-100 text-blue-500 dark:bg-blue-800 dark:text-blue-200",warning:"bg-yellow-100 text-yellow-500 dark:bg-yellow-800 dark:text-yellow-200"}[r]),children:[{success:jsx(HiCheck,{className:"h-5 w-5"}),error:jsx(HiXCircle,{className:"h-5 w-5"}),info:jsx(HiInformationCircle,{className:"h-5 w-5"}),warning:jsx(HiExclamationTriangle,{className:"h-5 w-5"})}[r],jsx("span",{className:"sr-only",children:"Check icon"})]}),jsx("div",{className:"ml-3 text-sm font-normal",children:a})]})})}function P(){let r=useContext(i);if(r===void 0)throw new Error("useToast must be used within a ToastProvider");return r}
8
+
9
+ export { i as a, b, P as c };
10
+ //# sourceMappingURL=out.js.map
11
+ //# sourceMappingURL=chunk-UUWBHZKH.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/toast/index.tsx"],"names":["Fragment","createContext","useCallback","useContext","useEffect","useState","Transition","clsx","HiCheck","HiXCircle","HiInformationCircle","HiExclamationTriangle","jsx","jsxs","ToastContext","ToastProvider","children","toasts","setToasts","timer","addToast","toast","Toast","type","text","useToast","context"],"mappings":"AAAA,OACE,YAAAA,EACA,iBAAAC,EACA,eAAAC,EACA,cAAAC,EACA,aAAAC,EACA,YAAAC,MACK,QACP,OAAS,cAAAC,MAAkB,oBAC3B,OAAOC,MAAU,OACjB,OACE,WAAAC,EACA,aAAAC,EACA,uBAAAC,EACA,yBAAAC,MACK,kBAkCH,OAOM,OAAAC,EAPN,QAAAC,MAAA,oBAhCG,IAAMC,EAAeb,EAE1B,MAAS,EAEJ,SAASc,EAAc,CAAE,SAAAC,CAAS,EAAkC,CACzE,GAAM,CAACC,EAAQC,CAAS,EAAIb,EAAuB,CAAC,CAAC,EAErDD,EAAU,IAAM,CACd,GAAIa,EAAO,OAAS,EAAG,CACrB,IAAME,EAAQ,WACZ,IAAMD,EAAWD,GAAWA,EAAO,MAAM,CAAC,CAAC,EAC3C,GACF,EACA,MAAO,IAAM,aAAaE,CAAK,EAEjC,GAAIF,EAAO,OAAS,EAAG,CACrB,IAAME,EAAQ,WACZ,IAAMD,EAAWD,GAAWA,EAAO,MAAM,CAAC,CAAC,EAC3C,GACF,EACA,MAAO,IAAM,aAAaE,CAAK,EAEnC,EAAG,CAACF,CAAM,CAAC,EAEX,IAAMG,EAAWlB,EACf,SAAUmB,EAAmB,CAC3BH,EAAWD,GAAW,CAAC,GAAGA,EAAQI,CAAK,CAAC,CAC1C,EACA,CAACH,CAAS,CACZ,EAEA,OACEL,EAACC,EAAa,SAAb,CAAsB,MAAOM,EAC3B,UAAAJ,EACDJ,EAAC,OACC,YAAU,YACV,UAAU,kGAET,SAAAK,EAAO,IAAKI,GACXT,EAACU,EAAA,CAAM,KAAMD,EAAM,KAAM,KAAMA,EAAM,KAAM,CAC5C,EACH,GACF,CAEJ,CAEAN,EAAc,YAAc,gBAO5B,SAASO,EAAM,CAAE,KAAAC,EAAM,KAAAC,CAAK,EAAe,CACzC,OACEZ,EAACN,EAAA,CACC,KAAM,GACN,GAAIN,EACJ,MAAM,6CACN,UAAU,4DACV,QAAQ,6CACR,MAAM,kCACN,UAAU,cACV,QAAQ,YAER,SAAAa,EAAC,OACC,UAAU,0HACV,KAAK,QAEL,UAAAA,EAAC,OACC,UAAWN,EACT,2EACA,CACE,QACE,oEACF,MACE,4DACF,KAAM,gEACN,QACE,uEACJ,EAAEgB,CAAI,CACR,EAGE,WACE,QAASX,EAACJ,EAAA,CAAQ,UAAU,UAAU,EACtC,MAAOI,EAACH,EAAA,CAAU,UAAU,UAAU,EACtC,KAAMG,EAACF,EAAA,CAAoB,UAAU,UAAU,EAC/C,QAASE,EAACD,EAAA,CAAsB,UAAU,UAAU,CACtD,EAAEY,CAAI,EAERX,EAAC,QAAK,UAAU,UAAU,sBAAU,GACtC,EACAA,EAAC,OAAI,UAAU,2BAA4B,SAAAY,EAAK,GAClD,EACF,CAEJ,CAEO,SAASC,GAAW,CACzB,IAAMC,EAAUvB,EAAWW,CAAY,EACvC,GAAIY,IAAY,OACd,MAAM,IAAI,MAAM,8CAA8C,EAEhE,OAAOA,CACT","sourcesContent":["import {\n Fragment,\n createContext,\n useCallback,\n useContext,\n useEffect,\n useState,\n} from \"react\";\nimport { Transition } from \"@headlessui/react\";\nimport clsx from \"clsx\";\nimport {\n HiCheck,\n HiXCircle,\n HiInformationCircle,\n HiExclamationTriangle,\n} from \"react-icons/hi2\";\n\nexport const ToastContext = createContext<\n ((toast: ToastEvent) => void) | undefined\n>(undefined);\n\nexport function ToastProvider({ children }: { children: React.ReactNode }) {\n const [toasts, setToasts] = useState<ToastEvent[]>([]);\n\n useEffect(() => {\n if (toasts.length > 1) {\n const timer = setTimeout(\n () => setToasts((toasts) => toasts.slice(1)),\n 1000\n );\n return () => clearTimeout(timer);\n }\n if (toasts.length > 0) {\n const timer = setTimeout(\n () => setToasts((toasts) => toasts.slice(1)),\n 2000\n );\n return () => clearTimeout(timer);\n }\n }, [toasts]);\n\n const addToast = useCallback(\n function (toast: ToastEvent) {\n setToasts((toasts) => [...toasts, toast]);\n },\n [setToasts]\n );\n\n return (\n <ToastContext.Provider value={addToast}>\n {children}\n <div\n aria-live=\"assertive\"\n className=\"pointer-events-none fixed inset-0 right-0 flex flex-col items-end px-4 py-6 sm:items-end sm:p-6\"\n >\n {toasts.map((toast: ToastEvent) => (\n <Toast type={toast.type} text={toast.text} />\n ))}\n </div>\n </ToastContext.Provider>\n );\n}\n\nToastProvider.displayName = \"ToastProvider\"\n\ntype ToastEvent = {\n type: \"success\" | \"error\" | \"warning\" | \"info\";\n text: string;\n};\n\nfunction Toast({ type, text }: ToastEvent) {\n return (\n <Transition\n show={true}\n as={Fragment}\n enter=\"transform ease-out duration-300 transition\"\n enterFrom=\"translate-y-2 opacity-0 sm:translate-y-0 sm:translate-x-2\"\n enterTo=\"translate-y-0 opacity-100 sm:translate-x-0\"\n leave=\"transition ease-in duration-100\"\n leaveFrom=\"opacity-100\"\n leaveTo=\"opacity-0\"\n >\n <div\n className=\"mb-4 flex w-full max-w-xs items-center rounded-lg bg-white p-4 text-gray-500 shadow dark:bg-gray-800 dark:text-gray-400\"\n role=\"alert\"\n >\n <div\n className={clsx(\n \"inline-flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg\",\n {\n success:\n \"bg-green-100 text-green-500 dark:bg-green-800 dark:text-green-200\",\n error:\n \"bg-red-100 text-red-500 dark:bg-red-800 dark:text-red-200\",\n info: \"bg-blue-100 text-blue-500 dark:bg-blue-800 dark:text-blue-200\",\n warning:\n \"bg-yellow-100 text-yellow-500 dark:bg-yellow-800 dark:text-yellow-200\",\n }[type]\n )}\n >\n {\n {\n success: <HiCheck className=\"h-5 w-5\" />,\n error: <HiXCircle className=\"h-5 w-5\" />,\n info: <HiInformationCircle className=\"h-5 w-5\" />,\n warning: <HiExclamationTriangle className=\"h-5 w-5\" />,\n }[type]\n }\n <span className=\"sr-only\">Check icon</span>\n </div>\n <div className=\"ml-3 text-sm font-normal\">{text}</div>\n </div>\n </Transition>\n );\n}\n\nexport function useToast() {\n const context = useContext(ToastContext);\n if (context === undefined) {\n throw new Error(\"useToast must be used within a ToastProvider\");\n }\n return context;\n}\n"]}
1
+ {"version":3,"sources":["../src/toast/index.tsx"],"names":["Fragment","createContext","useCallback","useContext","useEffect","useState","Transition","clsx","HiCheck","HiXCircle","HiInformationCircle","HiExclamationTriangle","jsx","jsxs","ToastContext","ToastProvider","children","toasts","setToasts","timer","addToast","toast","Toast","type","text","useToast","context"],"mappings":"AAAA,OACE,YAAAA,EACA,iBAAAC,EACA,eAAAC,EACA,cAAAC,EACA,aAAAC,EACA,YAAAC,MACK,QACP,OAAS,cAAAC,MAAkB,oBAC3B,OAAOC,MAAU,OACjB,OACE,WAAAC,EACA,aAAAC,EACA,uBAAAC,EACA,yBAAAC,MACK,kBAkCH,OAOM,OAAAC,EAPN,QAAAC,MAAA,oBAhCG,IAAMC,EAAeb,EAE1B,MAAS,EAEJ,SAASc,EAAc,CAAE,SAAAC,CAAS,EAAkC,CACzE,GAAM,CAACC,EAAQC,CAAS,EAAIb,EAAuB,CAAC,CAAC,EAErDD,EAAU,IAAM,CACd,GAAIa,EAAO,OAAS,EAAG,CACrB,IAAME,EAAQ,WACZ,IAAMD,EAAWD,GAAWA,EAAO,MAAM,CAAC,CAAC,EAC3C,GACF,EACA,MAAO,IAAM,aAAaE,CAAK,EAEjC,GAAIF,EAAO,OAAS,EAAG,CACrB,IAAME,EAAQ,WACZ,IAAMD,EAAWD,GAAWA,EAAO,MAAM,CAAC,CAAC,EAC3C,GACF,EACA,MAAO,IAAM,aAAaE,CAAK,EAEnC,EAAG,CAACF,CAAM,CAAC,EAEX,IAAMG,EAAWlB,EACf,SAAUmB,EAAmB,CAC3BH,EAAWD,GAAW,CAAC,GAAGA,EAAQI,CAAK,CAAC,CAC1C,EACA,CAACH,CAAS,CACZ,EAEA,OACEL,EAACC,EAAa,SAAb,CAAsB,MAAOM,EAC3B,UAAAJ,EACDJ,EAAC,OACC,YAAU,YACV,UAAU,uGAET,SAAAK,EAAO,IAAKI,GACXT,EAACU,EAAA,CAAM,KAAMD,EAAM,KAAM,KAAMA,EAAM,KAAM,CAC5C,EACH,GACF,CAEJ,CAEAN,EAAc,YAAc,gBAO5B,SAASO,EAAM,CAAE,KAAAC,EAAM,KAAAC,CAAK,EAAe,CACzC,OACEZ,EAACN,EAAA,CACC,KAAM,GACN,GAAIN,EACJ,MAAM,6CACN,UAAU,4DACV,QAAQ,6CACR,MAAM,kCACN,UAAU,cACV,QAAQ,YAER,SAAAa,EAAC,OACC,UAAU,0HACV,KAAK,QAEL,UAAAA,EAAC,OACC,UAAWN,EACT,2EACA,CACE,QACE,oEACF,MACE,4DACF,KAAM,gEACN,QACE,uEACJ,EAAEgB,CAAI,CACR,EAGE,WACE,QAASX,EAACJ,EAAA,CAAQ,UAAU,UAAU,EACtC,MAAOI,EAACH,EAAA,CAAU,UAAU,UAAU,EACtC,KAAMG,EAACF,EAAA,CAAoB,UAAU,UAAU,EAC/C,QAASE,EAACD,EAAA,CAAsB,UAAU,UAAU,CACtD,EAAEY,CAAI,EAERX,EAAC,QAAK,UAAU,UAAU,sBAAU,GACtC,EACAA,EAAC,OAAI,UAAU,2BAA4B,SAAAY,EAAK,GAClD,EACF,CAEJ,CAEO,SAASC,GAAW,CACzB,IAAMC,EAAUvB,EAAWW,CAAY,EACvC,GAAIY,IAAY,OACd,MAAM,IAAI,MAAM,8CAA8C,EAEhE,OAAOA,CACT","sourcesContent":["import {\n Fragment,\n createContext,\n useCallback,\n useContext,\n useEffect,\n useState,\n} from \"react\";\nimport { Transition } from \"@headlessui/react\";\nimport clsx from \"clsx\";\nimport {\n HiCheck,\n HiXCircle,\n HiInformationCircle,\n HiExclamationTriangle,\n} from \"react-icons/hi2\";\n\nexport const ToastContext = createContext<\n ((toast: ToastEvent) => void) | undefined\n>(undefined);\n\nexport function ToastProvider({ children }: { children: React.ReactNode }) {\n const [toasts, setToasts] = useState<ToastEvent[]>([]);\n\n useEffect(() => {\n if (toasts.length > 1) {\n const timer = setTimeout(\n () => setToasts((toasts) => toasts.slice(1)),\n 1000\n );\n return () => clearTimeout(timer);\n }\n if (toasts.length > 0) {\n const timer = setTimeout(\n () => setToasts((toasts) => toasts.slice(1)),\n 2000\n );\n return () => clearTimeout(timer);\n }\n }, [toasts]);\n\n const addToast = useCallback(\n function (toast: ToastEvent) {\n setToasts((toasts) => [...toasts, toast]);\n },\n [setToasts]\n );\n\n return (\n <ToastContext.Provider value={addToast}>\n {children}\n <div\n aria-live=\"assertive\"\n className=\"pointer-events-none fixed inset-0 right-0 z-50 flex flex-col items-end px-4 py-6 sm:items-end sm:p-6\"\n >\n {toasts.map((toast: ToastEvent) => (\n <Toast type={toast.type} text={toast.text} />\n ))}\n </div>\n </ToastContext.Provider>\n );\n}\n\nToastProvider.displayName = \"ToastProvider\";\n\ntype ToastEvent = {\n type: \"success\" | \"error\" | \"warning\" | \"info\";\n text: string;\n};\n\nfunction Toast({ type, text }: ToastEvent) {\n return (\n <Transition\n show={true}\n as={Fragment}\n enter=\"transform ease-out duration-300 transition\"\n enterFrom=\"translate-y-2 opacity-0 sm:translate-y-0 sm:translate-x-2\"\n enterTo=\"translate-y-0 opacity-100 sm:translate-x-0\"\n leave=\"transition ease-in duration-100\"\n leaveFrom=\"opacity-100\"\n leaveTo=\"opacity-0\"\n >\n <div\n className=\"mb-4 flex w-full max-w-xs items-center rounded-lg bg-white p-4 text-gray-500 shadow dark:bg-gray-800 dark:text-gray-400\"\n role=\"alert\"\n >\n <div\n className={clsx(\n \"inline-flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg\",\n {\n success:\n \"bg-green-100 text-green-500 dark:bg-green-800 dark:text-green-200\",\n error:\n \"bg-red-100 text-red-500 dark:bg-red-800 dark:text-red-200\",\n info: \"bg-blue-100 text-blue-500 dark:bg-blue-800 dark:text-blue-200\",\n warning:\n \"bg-yellow-100 text-yellow-500 dark:bg-yellow-800 dark:text-yellow-200\",\n }[type]\n )}\n >\n {\n {\n success: <HiCheck className=\"h-5 w-5\" />,\n error: <HiXCircle className=\"h-5 w-5\" />,\n info: <HiInformationCircle className=\"h-5 w-5\" />,\n warning: <HiExclamationTriangle className=\"h-5 w-5\" />,\n }[type]\n }\n <span className=\"sr-only\">Check icon</span>\n </div>\n <div className=\"ml-3 text-sm font-normal\">{text}</div>\n </div>\n </Transition>\n );\n}\n\nexport function useToast() {\n const context = useContext(ToastContext);\n if (context === undefined) {\n throw new Error(\"useToast must be used within a ToastProvider\");\n }\n return context;\n}\n"]}
@@ -1,10 +1,10 @@
1
- export { c as DragAndDrop } from './chunk-4S3NZSBU.mjs';
1
+ export { c as DragAndDrop } from './chunk-HZTQAUGX.mjs';
2
2
  import './chunk-PPMW7YAZ.mjs';
3
3
  import './chunk-Q365BFES.mjs';
4
4
  import './chunk-EHJJX6ZZ.mjs';
5
5
  import './chunk-ZJATBQ3X.mjs';
6
6
  import './chunk-CEK5K5TU.mjs';
7
- import './chunk-N7RKCR3X.mjs';
7
+ import './chunk-UUWBHZKH.mjs';
8
8
  import './chunk-ASCPOK5F.mjs';
9
9
  import './chunk-LQQDRIZN.mjs';
10
10
  import './chunk-256SAVHD.mjs';
@@ -1,10 +1,10 @@
1
- export { d as FilePicker } from '../chunk-4S3NZSBU.mjs';
1
+ export { d as FilePicker } from '../chunk-HZTQAUGX.mjs';
2
2
  import '../chunk-PPMW7YAZ.mjs';
3
3
  import '../chunk-Q365BFES.mjs';
4
4
  import '../chunk-EHJJX6ZZ.mjs';
5
5
  import '../chunk-ZJATBQ3X.mjs';
6
6
  import '../chunk-CEK5K5TU.mjs';
7
- import '../chunk-N7RKCR3X.mjs';
7
+ import '../chunk-UUWBHZKH.mjs';
8
8
  import '../chunk-ASCPOK5F.mjs';
9
9
  import '../chunk-LQQDRIZN.mjs';
10
10
  import '../chunk-256SAVHD.mjs';
package/dist/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- export { g as CardPaymentBlock, c as DragAndDrop, d as FilePicker, b as Layout, f as ProductPicker, a as StackedListItem, e as TableResultBlock } from './chunk-4S3NZSBU.mjs';
1
+ export { g as CardPaymentBlock, c as DragAndDrop, d as FilePicker, b as Layout, f as ProductPicker, a as StackedListItem, e as TableResultBlock } from './chunk-HZTQAUGX.mjs';
2
2
  export { a as RichTextEditor } from './chunk-PPMW7YAZ.mjs';
3
3
  export { a as Search } from './chunk-Q365BFES.mjs';
4
4
  export { b as Sidebar } from './chunk-EHJJX6ZZ.mjs';
5
5
  export { a as Sort } from './chunk-ZJATBQ3X.mjs';
6
6
  export { a as TableHeader } from './chunk-CEK5K5TU.mjs';
7
- export { b as ToastProvider, c as useToast } from './chunk-N7RKCR3X.mjs';
7
+ export { b as ToastProvider, c as useToast } from './chunk-UUWBHZKH.mjs';
8
8
  export { a as ToolTip } from './chunk-ASCPOK5F.mjs';
9
9
  import './chunk-LQQDRIZN.mjs';
10
10
  export { a as Navbar } from './chunk-256SAVHD.mjs';
@@ -1,10 +1,10 @@
1
- export { b as Layout } from '../chunk-4S3NZSBU.mjs';
1
+ export { b as Layout } from '../chunk-HZTQAUGX.mjs';
2
2
  import '../chunk-PPMW7YAZ.mjs';
3
3
  import '../chunk-Q365BFES.mjs';
4
4
  import '../chunk-EHJJX6ZZ.mjs';
5
5
  import '../chunk-ZJATBQ3X.mjs';
6
6
  import '../chunk-CEK5K5TU.mjs';
7
- import '../chunk-N7RKCR3X.mjs';
7
+ import '../chunk-UUWBHZKH.mjs';
8
8
  import '../chunk-ASCPOK5F.mjs';
9
9
  import '../chunk-LQQDRIZN.mjs';
10
10
  import '../chunk-256SAVHD.mjs';
@@ -1,10 +1,10 @@
1
- export { f as ProductPicker } from '../chunk-4S3NZSBU.mjs';
1
+ export { f as ProductPicker } from '../chunk-HZTQAUGX.mjs';
2
2
  import '../chunk-PPMW7YAZ.mjs';
3
3
  import '../chunk-Q365BFES.mjs';
4
4
  import '../chunk-EHJJX6ZZ.mjs';
5
5
  import '../chunk-ZJATBQ3X.mjs';
6
6
  import '../chunk-CEK5K5TU.mjs';
7
- import '../chunk-N7RKCR3X.mjs';
7
+ import '../chunk-UUWBHZKH.mjs';
8
8
  import '../chunk-ASCPOK5F.mjs';
9
9
  import '../chunk-LQQDRIZN.mjs';
10
10
  import '../chunk-256SAVHD.mjs';
@@ -1,10 +1,10 @@
1
- export { a as StackedListItem } from './chunk-4S3NZSBU.mjs';
1
+ export { a as StackedListItem } from './chunk-HZTQAUGX.mjs';
2
2
  import './chunk-PPMW7YAZ.mjs';
3
3
  import './chunk-Q365BFES.mjs';
4
4
  import './chunk-EHJJX6ZZ.mjs';
5
5
  import './chunk-ZJATBQ3X.mjs';
6
6
  import './chunk-CEK5K5TU.mjs';
7
- import './chunk-N7RKCR3X.mjs';
7
+ import './chunk-UUWBHZKH.mjs';
8
8
  import './chunk-ASCPOK5F.mjs';
9
9
  import './chunk-LQQDRIZN.mjs';
10
10
  import './chunk-256SAVHD.mjs';
@@ -1,10 +1,10 @@
1
- export { e as TableResultBlock } from './chunk-4S3NZSBU.mjs';
1
+ export { e as TableResultBlock } from './chunk-HZTQAUGX.mjs';
2
2
  import './chunk-PPMW7YAZ.mjs';
3
3
  import './chunk-Q365BFES.mjs';
4
4
  import './chunk-EHJJX6ZZ.mjs';
5
5
  import './chunk-ZJATBQ3X.mjs';
6
6
  import './chunk-CEK5K5TU.mjs';
7
- import './chunk-N7RKCR3X.mjs';
7
+ import './chunk-UUWBHZKH.mjs';
8
8
  import './chunk-ASCPOK5F.mjs';
9
9
  import './chunk-LQQDRIZN.mjs';
10
10
  import './chunk-256SAVHD.mjs';
@@ -1,4 +1,4 @@
1
- export { a as ToastContext, b as ToastProvider, c as useToast } from '../chunk-N7RKCR3X.mjs';
1
+ export { a as ToastContext, b as ToastProvider, c as useToast } from '../chunk-UUWBHZKH.mjs';
2
2
  import '../chunk-23SJGKDR.mjs';
3
3
  //# sourceMappingURL=out.js.map
4
4
  //# sourceMappingURL=index.mjs.map
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "ekm-ui",
3
- "version": "0.3.71",
3
+ "version": "0.3.74",
4
4
  "sideEffects": [
5
5
  "**/*.css"
6
6
  ],
7
7
  "main": "./dist/index.mjs",
8
8
  "types": "./dist/index.d.ts",
9
9
  "exports": {
10
- ".": "./dist",
10
+ ".": "./dist/index.mjs",
11
11
  "./styles.css": "./dist/index.css"
12
12
  },
13
13
  "license": "MIT",
@@ -37,7 +37,7 @@ export function StackedListItem({
37
37
  } else {
38
38
  var lastLetter = "";
39
39
  }
40
- return [firstLetter, lastLetter];
40
+ return firstLetter + lastLetter;
41
41
  }
42
42
 
43
43
  let avatarLetters = getFirstAndLastLetters(title);
@@ -77,4 +77,4 @@ export function StackedListItem({
77
77
  );
78
78
  }
79
79
 
80
- StackedListItem.displayName = "StackedListItem"
80
+ StackedListItem.displayName = "StackedListItem";
@@ -51,7 +51,7 @@ export function ToastProvider({ children }: { children: React.ReactNode }) {
51
51
  {children}
52
52
  <div
53
53
  aria-live="assertive"
54
- className="pointer-events-none fixed inset-0 right-0 flex flex-col items-end px-4 py-6 sm:items-end sm:p-6"
54
+ className="pointer-events-none fixed inset-0 right-0 z-50 flex flex-col items-end px-4 py-6 sm:items-end sm:p-6"
55
55
  >
56
56
  {toasts.map((toast: ToastEvent) => (
57
57
  <Toast type={toast.type} text={toast.text} />
@@ -61,7 +61,7 @@ export function ToastProvider({ children }: { children: React.ReactNode }) {
61
61
  );
62
62
  }
63
63
 
64
- ToastProvider.displayName = "ToastProvider"
64
+ ToastProvider.displayName = "ToastProvider";
65
65
 
66
66
  type ToastEvent = {
67
67
  type: "success" | "error" | "warning" | "info";
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../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-drawer.tsx","../src/stacked-list-item.tsx"],"names":["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","useEffect","BsCloudUpload","BsFillCheckCircleFill","BiSearch","FaTimesCircle","import_prop_types","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","useRef","useReducer","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","cp","__async","page","searchUri","data","loadedState","error","handleDragEnter","handleDragLeave","handleSearchRequest","searchTerm","_a","text","s","handleDropError","handleUseImage","handleClose","handleFileUpload","file","arr","getAsByteArray","payload","getBase64","handleListActions","calculateListSize","renderList","EmptyPlaceholder","LoadingPlaceholder","Listing","SearchEmptyPlaceholder","renderContent","Search","AlertBanner","renderOversizedDropZone","Drawer","Spinner","readFile","resolve","reject","reader","event","b","TableResultBlock","title","message","icon","NoResultsBlock","useImperativeHandle","forwardRef","HiClipboardList","pluralize","searchCategories","calculateSelectedProducts","obj","x","ProductPickerReducer","ProductPicker","preSelected","requestCallback","ref","isViewableRef","products","setProducts","session","setSession","getProducts","__spreadProps","__spreadValues","response","_b","_c","handleProductSelection","added","removed","preExisted","rem","add","Badge","StackedListItem","id","avatarShow","avatarColor","avatarBorder","badgeText","badgeColor","getFirstAndLastLetters","str","words","firstWord","lastWord","firstLetter","lastLetter","avatarLetters","Avatar"],"mappings":"6zBAEA,OAAS,gBAAAA,OAAoB,iBAevB,OAqCM,YAAAC,GArCN,OAAAC,EAIM,QAAAC,MAJN,oBATC,SAASC,GAAiB,CAC/B,YAAAC,EACA,aAAAC,CACF,EAGG,CACD,OACEH,EAACI,GAAA,CAAK,UAAU,sBACd,UAAAL,EAAC,MAAG,UAAU,wCAAwC,2BAAe,EACrEA,EAAC,OAAI,UAAU,0CACb,SAAAC,EAAC,YAAS,UAAU,6BAA6B,GAAG,QAClD,UAAAA,EAAC,OAAI,UAAU,sBACb,UAAAA,EAAC,OAAI,UAAU,0BACZ,UAAAG,GACCJ,EAACM,GAAA,CACC,GAAG,kBACH,KAAK,cACL,MAAM,kBACR,EAGFN,EAACO,GAAA,CAAM,QAAQ,kBAAkB,uCAEjC,GACF,EACAN,EAAC,OAAI,UAAWG,EAAe,kBAAoB,aACjD,UAAAJ,EAAC,OACC,IAAI,uDACJ,IAAI,iBACN,EACAA,EAAC,OACC,IAAI,6DACJ,IAAI,uBACN,EACAA,EAAC,OACC,IAAI,0DACJ,IAAI,oBACN,EACAA,EAAC,OACC,IAAI,uDACJ,IAAI,iBACN,GACF,GACF,EACCG,GACCF,EAAAF,GAAA,CACE,UAAAE,EAAC,OAAI,UAAU,sDACb,UAAAD,EAACQ,GAAA,CACC,MAAM,iBACN,QAAQ,aACR,WAAW,6EAEX,SAAAR,EAACS,GAAA,CACC,GAAG,aACH,KAAK,aACL,YAAY,YACZ,KAAK,OACL,SAAQ,GACV,EACF,EACAT,EAACQ,GAAA,CACC,MAAM,gBACN,QAAQ,aACR,WAAW,qEAEX,SAAAR,EAACS,GAAA,CACC,GAAG,aACH,KAAK,aACL,YAAY,sBACZ,KAAK,SACL,UAAWX,GACX,SAAQ,GACV,EACF,GACF,EACAG,EAAC,OAAI,UAAU,qEACb,UAAAD,EAACQ,GAAA,CACC,MAAM,gBACN,QAAQ,aACR,WAAW,8CAEX,SAAAR,EAACS,GAAA,CACC,GAAG,aACH,KAAK,aACL,YAAY,UACZ,KAAK,OACL,SAAQ,GACV,EACF,EACAT,EAACQ,GAAA,CACC,MAAM,wBACN,QAAQ,aACR,WAAW,yEAEX,SAAAR,EAACS,GAAA,CACC,GAAG,aACH,KAAK,aACL,YAAY,MACZ,KAAK,OACL,UAAWX,GACX,SAAQ,GACV,EACF,EACAE,EAAC,OACC,UAAU,mCACV,IAAI,+DACJ,IAAI,GACN,GACF,GACF,EAEDI,GACCH,EAAC,OAAI,UAAU,sBACb,UAAAA,EAAC,OAAI,UAAU,0BACb,UAAAD,EAACM,GAAA,CAAM,GAAG,SAAS,KAAK,cAAc,MAAM,SAAS,EACrDN,EAACO,GAAA,CAAM,QAAQ,SAAS,kBAAM,GAChC,EACAP,EAAC,OAAI,UAAU,OACb,SAAAA,EAAC,OACC,IAAI,yDACJ,IAAI,cACN,EACF,GACF,GAEJ,EACF,GACF,CAEJ,CAEAE,GAAiB,YAAc,mBC3I/B,OAAS,WAAAQ,GAAS,YAAAC,OAAgB,QCDlC,OAAS,WAAAC,MAAe,iBAExB,OACE,cAAAC,GAEA,cAAAC,GACA,cAAAC,GACA,gBAAAC,GACA,iBAAAC,GACA,SAAAC,GACA,kBAAAC,GACA,UAAAC,OACK,kBAOC,cAAApB,EA0BA,QAAAC,OA1BA,oBALD,SAASoB,IAAe,CAC7B,IAAMC,EAAc,IACpB,OACErB,GAACW,EAAQ,MAAR,CACC,UAAAX,GAACW,EAAQ,UAAR,CACC,UAAAZ,EAACY,EAAQ,KAAR,CACC,KAAK,IACL,KAAMC,GACN,UAAmBS,IAAR,IAAsB,+BAAiC,GACnE,qBAED,EACAtB,EAACY,EAAQ,KAAR,CACC,KAAK,YACL,KAAMM,GACN,UACkBI,IAAhB,YAA8B,+BAAiC,GAElE,oBAED,EACAtB,EAACY,EAAQ,KAAR,CACC,KAAK,UACL,KAAMK,GACN,MAAM,KACN,UACgBK,IAAd,UAA4B,+BAAiC,GAEhE,kBAED,EACArB,GAACW,EAAQ,SAAR,CAAiB,KAAMI,GAAc,MAAM,SAC1C,UAAAhB,EAACY,EAAQ,KAAR,CACC,KAAK,iBACL,UACsBU,IAApB,gBACI,+BACA,GAEP,iBAED,EACAtB,EAACY,EAAQ,KAAR,CACC,KAAK,iBACL,UAC4BU,IAA1B,sBACI,+BACA,GAEP,kBAED,EACAtB,EAACY,EAAQ,KAAR,CACC,KAAK,kBACL,UAC4BU,IAA1B,sBACI,+BACA,GAEP,oBAED,GACF,EACAtB,EAACY,EAAQ,KAAR,CACC,KAAK,YACL,KAAMQ,GACN,UACkBE,IAAhB,YAA8B,+BAAiC,GAElE,oBAED,GACF,EACArB,GAACW,EAAQ,UAAR,CACC,UAAAZ,EAACY,EAAQ,KAAR,CACC,KAAK,gDACL,KAAME,GACP,gBAED,EACAd,EAACY,EAAQ,KAAR,CAAa,KAAK,8BAA8B,KAAMO,GAAgB,sBAEvE,EACAnB,EAACY,EAAQ,KAAR,CACC,KAAK,sDACL,KAAMG,GACP,0BAED,GACF,GACF,CAEJ,CDrFI,mBAAAhB,GACE,OAAAC,GAWE,QAAAC,OAZJ,oBAXG,SAASsB,GAAO,CAAE,SAAAC,EAAU,UAAAC,CAAU,EAAU,CACrD,GAAM,CAACC,EAAoBC,CAAqB,EAAIhB,GAAS,EAAK,EAC5D,CAACiB,EAAuBC,CAAwB,EAAIlB,GAAS,EAAK,EAExE,OAAAD,GAAQ,IAAM,CACRoB,GAAc,GAAK,CAACJ,GACtBG,EAAyB,EAAI,CAEjC,EAAG,CAACH,CAAkB,CAAC,EAGrBzB,GAAAF,GAAA,CACE,UAAAC,GAAC+B,GAAA,CACC,kBAAmB,IAAM,CACvBJ,EAAsB,CAACD,CAAkB,CAC3C,EACA,gBAAiBE,EACjB,UAAU,uDACZ,EACA3B,GAAC,OAAI,UAAU,OACb,UAAAD,GAACY,GAAA,CAAQ,UAAWc,EAClB,SAAA1B,GAACqB,GAAA,EAAa,EAChB,EACApB,GAAC,OAAI,UAAU,gCACb,UAAAD,GAAC,QACC,UAAW,+FACRyB,EAAoB,GAAR,QAGd,SAAAD,EACH,EACAxB,GAACgC,GAAA,CAAW,YAAY,MAAM,GAChC,GACF,GACF,CAEJ,CE7CA,OAAS,aAAAC,GAAW,YAAAtB,OAAgB,QACpC,OAAS,iBAAAuB,GAAe,yBAAAC,OAA6B,iBACrD,OAAS,YAAAC,OAAgB,iBACzB,OAAS,iBAAAC,OAAqB,iBAE9B,IAAAC,EAAsB,SAkGhB,cAAAtC,EACA,QAAAC,MADA,oBAhGN,IAAMsC,EAAa,OAAO,OAAO,CAC/B,KAAM,OACN,KAAM,YACN,UAAW,YACX,MAAO,QACP,QAAS,SACX,CAAC,EAEKC,GAAmB,OAAO,OAAO,CACrC,CAACD,EAAW,IAAI,EACd,8JACF,CAACA,EAAW,IAAI,EACd,8JACF,CAACA,EAAW,SAAS,EACnB,8JACF,CAACA,EAAW,KAAK,EACf,0JACF,CAACA,EAAW,OAAO,EACjB,iKACJ,CAAC,EAEKE,GAAmB,CAAC,MAAO,OAAQ,MAAO,MAAO,MAAM,EAE7D,SAASC,GAAcC,EAAUC,EAAW,CAC1C,IAAIC,EACF,CAACD,GAAaA,EAAU,SAAW,EAAIH,GAAmBG,EAC5D,GAAI,CAACD,GAAYA,EAAS,SAAW,EAAG,MAAO,GAE/C,IAAIG,EAAMH,EAAS,MAAM,GAAG,EAAE,IAAI,EAAE,YAAY,EAChD,OAAOE,EAAO,SAASC,CAAG,CAC5B,CAEO,SAASC,GAAY,CAC1B,SAAAC,EAAW,8BACX,UAAAJ,EACA,SAAAK,EACA,aAAAC,EACA,SAAAC,EACA,cAAAC,EACA,eAAAC,CACF,EAAG,CACD,GAAM,CAACC,EAAWC,CAAY,EAAI5C,GAAS4B,EAAW,IAAI,EAE1DN,GAAU,IAAM,CACD,OAAO,OAAOM,CAAU,EAAE,SAASU,CAAQ,IAGtDM,EAAaN,CAAQ,EACrB,WAAW,IAAM,CACXA,IAAaV,EAAW,OAASa,EACnCA,EAAc,EAIdG,EAAahB,EAAW,IAAI,CAEhC,EAAG,GAAI,EAEX,EAAG,CAACU,CAAQ,CAAC,EAEb,IAAMO,EAAkBC,GAAM,CAC5BA,EAAE,eAAe,EACjBF,EAAahB,EAAW,IAAI,CAC9B,EAEMmB,EAAkBD,GAAM,CAC5BA,EAAE,eAAe,EACbP,GAAcA,EAAa,EAC/BK,EAAahB,EAAW,IAAI,CAC9B,EAEMoB,EAAcF,GAAM,CACxBA,EAAE,eAAe,EACbf,GAAce,EAAE,aAAa,MAAM,CAAC,EAAE,KAAMb,CAAS,GACvDW,EAAahB,EAAW,SAAS,EACjCY,EAASM,EAAE,aAAa,MAAM,CAAC,CAAC,IAEhCF,EAAahB,EAAW,KAAK,EAC7B,WAAW,IAAM,CACfa,EAAc,CAChB,EAAG,GAAI,EAEX,EAEMQ,EAAuBH,GAAM,CACjCf,GAAce,EAAE,OAAO,MAAM,CAAC,EAAE,KAAMb,CAAS,EAC3CW,EAAahB,EAAW,SAAS,EACjCgB,EAAahB,EAAW,KAAK,EACjCY,EAASM,EAAE,OAAO,MAAM,CAAC,CAAC,CAC5B,EAEMI,EAAyB,IAAM,CAC/BR,GAAgBA,EAAe,CACrC,EACMS,EAAoB,IACxB7D,EAAC,OAAI,UAAU,sDACb,UAAAD,EAACkC,GAAA,CAAc,UAAU,6CAA6C,EACtEjC,EAAC,KAAE,UAAU,qDACX,UAAAD,EAAC,QAAK,UAAU,gBAAgB,2BAAe,EAAO,qBACxD,EACAA,EAAC,KAAE,UAAU,2CAA4C,SAAAgD,EAAS,EACjEK,GACCrD,EAAC,OAAI,UAAU,OACb,SAAAC,EAAC8D,EAAA,CAAO,MAAM,OAAO,QAASF,EAC5B,UAAA7D,EAACoC,GAAA,CAAS,UAAU,OAAO,EAAE,uBAE/B,EACF,GAEJ,EAGI4B,EAAkB,IACtBhE,EAAC,OAAI,UAAU,sDACb,SAAAA,EAAC,KAAE,UAAU,qDACX,SAAAA,EAAC,QAAK,UAAU,gBAAgB,+BAAmB,EACrD,EACF,EAGIiE,EAAuB,IAC3BhE,EAAC,OAAI,UAAU,sDACb,UAAAA,EAAC,OACC,cAAY,OACZ,UAAU,sEACV,QAAQ,cACR,KAAK,OACL,MAAM,6BAEN,UAAAD,EAAC,QACC,EAAE,+WACF,KAAK,eACP,EACAA,EAAC,QACC,EAAE,glBACF,KAAK,cACP,GACF,EACAA,EAAC,KAAE,UAAU,qDACX,SAAAA,EAAC,QAAK,UAAU,gBAAgB,wBAAY,EAC9C,GACF,EAGIkE,EAAmB,IACvBjE,EAAC,OAAI,UAAU,sDACb,UAAAD,EAACqC,GAAA,CAAc,UAAU,2CAA2C,EACpErC,EAAC,KAAE,UAAU,mDACX,SAAAA,EAAC,QAAK,UAAU,gBAAgB,4BAAgB,EAClD,GACF,EAGImE,EAAqB,IACzBlE,EAAC,OAAI,UAAU,sDACb,UAAAD,EAACmC,GAAA,CAAsB,UAAU,+CAA+C,EAChFnC,EAAC,KAAE,UAAU,uDACX,SAAAA,EAAC,QAAK,UAAU,gBAAgB,oBAAQ,EAC1C,GACF,EAGIoE,EAAkB,IAAM,CAC5B,OAAQd,EAAW,CACjB,KAAKf,EAAW,KACd,OAAOyB,EAAgB,EACzB,KAAKzB,EAAW,UACd,OAAO0B,EAAqB,EAC9B,KAAK1B,EAAW,MACd,OAAO2B,EAAiB,EAC1B,KAAK3B,EAAW,QACd,OAAO4B,EAAmB,EAC5B,QACE,OAAOL,EAAkB,CAC7B,CACF,EAEA,OACE9D,EAAC,OACC,YAAcyD,GAAMA,EAAE,eAAe,EACrC,WAAYD,EACZ,OAAQG,EACR,YAAaD,EACb,UAAU,iDAEV,SAAAzD,EAAC,SACC,QAAQ,gBACR,UAAW,4GAA4GuC,GAAiBc,CAAS,IAEhJ,UAAAc,EAAgB,EAChBd,IAAcf,EAAW,MACxBvC,EAAC,SACC,GAAG,gBACH,KAAK,OACL,UAAU,SACV,SAAU4D,EACZ,GAEJ,EACF,CAEJ,CAEAb,GAAY,UAAY,CAEtB,UAAW,EAAAsB,QAAU,QAAQ,EAAAA,QAAU,MAAM,EAE7C,SAAU,EAAAA,QAAU,OAEpB,SAAU,EAAAA,QAAU,MAAM,CAAC,OAAQ,UAAW,OAAO,CAAC,EAAE,WAGxD,aAAc,EAAAA,QAAU,KAExB,cAAe,EAAAA,QAAU,KAAK,WAE9B,SAAU,EAAAA,QAAU,KAAK,WAEzB,eAAgB,EAAAA,QAAU,IAC5B,EAEAtB,GAAY,YAAc,cCpO1B,OAAS,aAAAd,GAAW,UAAAqC,GAAQ,YAAA3D,EAAU,cAAA4D,OAAkB,QAMxD,OAAS,mBAAAC,OAAuB,iBAChC,OAAS,mBAAAC,OAAuB,iBAEhC,IAAAnC,EAAsB,SAoRP,OAyBX,YAAAvC,GAzBW,OAAAC,EA6BL,QAAAC,MA7BK,oBAjRf,IAAMyE,GAAS,0CACTC,EAAS,OAAO,OAAO,CAC3B,MAAO,QACP,eAAgB,iBAChB,QAAS,UACT,OAAQ,SACR,eAAgB,iBAChB,eAAgB,iBAChB,aAAc,eACd,aAAc,QACd,SAAU,UACZ,CAAC,EAEKC,GAAe,OAAO,OAAO,CACjC,KAAMD,EAAO,QACb,aAAc,WACd,eAAgB,UAChB,SAAU,QACV,WAAY,GACZ,eAAgB,EAClB,CAAC,EAED,SAASE,GAAkBC,EAAOC,EAAQ,CACxC,OAAQA,EAAO,KAAM,CACnB,KAAKJ,EAAO,MACV,MAAO,CACL,KAAMA,EAAO,MACb,aAAc,YACd,eAAgB,OAChB,SAAU,QACV,WAAY,GACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,QACV,OAAOC,GACT,KAAKD,EAAO,OACV,MAAO,CACL,KAAMA,EAAO,OACb,aAAc,WACd,eAAgB,UAChB,SAAU,iBACV,WAAY,SACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,eACV,MAAO,CACL,KAAMA,EAAO,eACb,aAAc,WACd,eAAgB,UAChB,SAAU,iBACV,WAAY,SACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,eACV,MAAO,CACL,KAAMA,EAAO,eACb,aAAc,WACd,eAAgB,UAChB,SAAU,QACV,WAAY,SACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,aACV,MAAO,CACL,KAAMA,EAAO,aACb,aAAc,WACd,eAAgB,UAChB,SAAU,QACV,WAAY,GACZ,eAAgB,EAClB,EACF,QACE,MAAM,IAAI,MAAM,8BAAgCI,EAAO,IAAU,CACrE,CACF,CASO,SAASC,GAAW,CAAE,OAAAC,EAAQ,IAAAC,EAAK,KAAAC,EAAM,SAAAC,EAAW,GAAO,QAAAC,EAAS,SAAAlC,CAAS,EAAG,CACrF,IAAMmC,EAAiBhB,GAAO,EACxB,CAACQ,EAAOS,CAAQ,EAAIhB,GAAWM,GAAmB,CAAE,KAAMF,EAAO,QAAS,aAAc,UAAW,CAAC,EACpG,CAACa,EAAYC,CAAa,EAAI9E,EAAS,CAAC,EACxC+E,EAAiBpB,GAAO,CAAC,EACzB,CAACqB,EAAUC,CAAW,EAAIjF,EAAS,EAAK,EACxC,CAACkF,EAAKC,CAAM,EAAInF,EAAS,EAAK,EAC9BoF,EAAmBzB,GAAO,CAAE,MAAO,EAAG,aAAc,CAAE,CAAC,EACvD,CAAC0B,EAAWC,CAAY,EAAItF,EAAS,EAAK,EAC1C,CAACuF,EAAQC,CAAS,EAAIxF,EAAS,IAAI,EACnC,CAACyF,EAAUC,CAAW,EAAI1F,EAAS,IAAI,EACvC,CAAC2F,GAAOC,CAAQ,EAAI5F,EAAS,CAAC,CAAC,EAC/B,CAAC6F,GAAeC,CAAgB,EAAI9F,EAAS,MAAM,EAEzDsB,GAAU,IAAM,CAEVkD,IACFI,EAAS,CAAE,KAAMZ,EAAO,OAAQ,CAAC,EACjC0B,EAAY,IAAI,EAChBN,EAAiB,QAAU,CAAE,MAAO,EAAG,aAAc,CAAE,EACvDW,GAAW,EACXC,EAAS,CAAC,EAEd,EAAG,CAACxB,CAAI,CAAC,EAETlD,GAAU,IAAM,CACVkD,IACFO,EAAe,QAAU,EACzBiB,EAAS,EACTb,EAAO,EAAK,EAEhB,EAAG,CAACI,CAAM,CAAC,EAEXjE,GAAU,IAAM,CACVmE,GAAUC,EAAY,IAAI,EAC1BR,GAAKC,EAAO,EAAK,CACvB,EAAG,CAAChB,EAAM,IAAI,CAAC,EAEf,IAAM4B,GAAa,IAAM,CACvBH,EAAS,CAAC,CAAC,EACXE,EAAiB,MAAM,EACvBR,EAAa,EAAK,EAClBI,EAAY,IAAI,EAChBP,EAAO,EAAK,CACd,EAEMa,EAAW,CAAOC,EAAK,IAAMC,GAAA,sBACjC,GAAI,CACF,IAAIC,EAAOF,IAAO,EAAIlB,EAAe,QAAUkB,EAC3CG,IAAYb,GAAA,YAAAA,EAAQ,QAAS,EAAI,2BAA2BA,IAAW,2BAMrEc,EAAO,MALI,MAAM,MAAM,GAAG/B,IAASP,kBAAsBoC,qBAAwB5B,IAAM6B,KAAa,CACxG,OAAQ,MACR,YAAa,cACb,QAAS,CAAE,eAAgB,kBAAmB,CAChD,CAAC,GAC2B,KAAK,EAWjC,IAVIb,GAAA,YAAAA,EAAQ,QAAS,GAAGX,EAAS,CAAE,KAAMZ,EAAO,cAAe,CAAC,EAC5DqC,EAAK,MAAM,KAAK,OAAS,GAAKF,EAAO,EACvCP,EAAUD,IAAU,CAAC,GAAGA,GAAO,GAAGU,EAAK,MAAM,IAAI,CAAC,EAElDT,EAASS,EAAK,MAAM,IAAI,EAG1BjB,EAAiB,QAAU,CAAE,MAAOiB,EAAK,MAAM,cAAe,aAAcA,EAAK,MAAM,KAAM,EAC7FvB,EAAcuB,EAAK,MAAM,aAAa,GAElCd,GAAA,YAAAA,EAAQ,QAAS,EACnBX,EAAS,CAAE,KAAMyB,EAAK,MAAM,KAAK,OAAS,EAAIrC,EAAO,eAAiBA,EAAO,YAAa,CAAC,MACtF,CACL,IAAMsC,GAAc7B,EAAWT,EAAO,eAAiBA,EAAO,OAC9DY,EAAS,CAAE,KAAMyB,EAAK,MAAM,KAAK,OAAS,EAAIC,GAActC,EAAO,KAAM,CAAC,EAG5E8B,EAAiB,MAAM,EAEvBR,EAAa,EAAK,EAClBL,EAAY,EAAK,CACnB,OAASsB,EAAP,CACA3B,EAAS,CAAE,MAAMW,GAAA,YAAAA,EAAQ,UAAW,EAAIvB,EAAO,aAAeA,EAAO,KAAM,CAAC,CAC9E,CACF,GAEMwC,GAAmB1D,GAAM,CACzB,WACJmC,EAAY,EAAI,EAChBN,EAAe,QAAQ,YAAY,EACnC7B,EAAE,eAAe,EACnB,EAEM2D,GAAmB3D,GAAM,CACzB,UACJmC,EAAY,EAAK,CACnB,EAEMyB,EAAuBC,GAAe,CA9L9C,IAAAC,GA+LI,IAAMC,GAAOD,GAAAD,EAAW,OAAX,KAAAC,GAAmB,GAC1BE,GAAIvB,GAAA,KAAAA,EAAU,GACpBC,EAAUmB,EAAW,IAAI,GACpBG,GAAE,OAAS,GAAKD,EAAK,SAAW,GAAOC,GAAE,SAAW,GAAKD,EAAK,OAAS,GAAK1C,EAAM,OAASH,EAAO,UACrGY,EAAS,CAAE,KAAMZ,EAAO,OAAQ,CAAC,CACrC,EAEM+C,EAAkB,IAAM,CAC5B5B,EAAO,EAAI,EACXF,EAAY,EAAK,EACjBa,EAAiB,MAAM,CACzB,EAEMkB,EAAiB,IAAM,CAC3BxE,EAAS,4BAA4BiD,EAAS,KAAK,EACnDwB,EAAY,CACd,EAEMA,EAAc,IAAM,CACxBlB,GAAW,EACXrB,EAAQ,CACV,EAEMwC,EAA0BC,GAASjB,GAAA,sBACvC,GAAIiB,GAAQ,KAAM,CAChBrB,EAAiB,OAAO,EACxBiB,EAAgB,EAChB,OAGF,GAAI,CACF,IAAMK,EAAM,MAAMC,GAAeF,CAAI,EAC/BG,GAAU,CACd,KAAM,IAAI/C,KACV,KAAM4C,EAAK,KACX,MAAOI,GAAUH,CAAG,EACpB,mBAAoB,EACtB,GACY,MAAM,MAAM,GAAG9C,IAASP,KAAU,CAC5C,OAAQ,OACR,YAAa,cACb,QAAS,CAAE,eAAgB,kBAAmB,EAC9C,KAAM,KAAK,UAAUuD,EAAO,CAC9B,CAAC,GAEO,SAAW,KACjBxB,EAAiB,SAAS,EAC1BN,EAAU,IAAI,EACdb,EAAe,QAAQ,MAAM,EAE7BiB,EAAS,CAAC,CAAC,EACXT,EAAO,EAAK,EACZa,EAAS,CAAC,GAEVF,EAAiB,OAAO,CAE5B,OAASS,EAAP,CACAT,EAAiB,OAAO,CAC1B,CACF,GAEM0B,EAAqBpD,GAAW,CACpC,OAAQA,EAAO,KAAM,CACnB,IAAK,aACHkB,EAAalB,EAAO,OAAO,EACvBW,EAAe,QAAUK,EAAiB,QAAQ,OAAS,CAACC,IAE9DC,EAAa,EAAI,EACjBP,EAAe,QAAUA,EAAe,QAAU,EAClDiB,EAAS,GAEX,MACF,IAAK,YACHN,EAAYtB,EAAO,OAAO,EAC1Be,EAAO,EAAK,EACZ,MACF,QACE,KACJ,CACF,EAEMsC,EAAoB,IACnBvC,EAEDf,EAAM,OAASH,EAAO,OAAe,QACrCG,EAAM,OAASH,EAAO,gBAAkBG,EAAM,OAASH,EAAO,eACzD,QAEAG,EAAM,SANEA,EAAM,SAUnBuD,GAAa,IAAM,CACvB,OAAQvD,EAAM,KAAM,CAClB,KAAKH,EAAO,MACV,OAAO3E,EAACsI,GAAA,EAAiB,EAC3B,KAAK3D,EAAO,QACV,OAAO3E,EAACuI,GAAA,EAAmB,EAC7B,KAAK5D,EAAO,eACZ,KAAKA,EAAO,OACZ,KAAKA,EAAO,eACV,OACE3E,EAACwI,GAAA,CACC,OAAQ1D,EAAM,SACd,MAAOwB,GACP,OAAQZ,EAAe,QAAUK,EAAiB,QAAQ,MAC1D,SAAUK,GAAA,YAAAA,EAAU,KACpB,KAAMV,EAAe,QACrB,MAAOF,EACP,SAAU2C,EACZ,EAEJ,KAAKxD,EAAO,aACV,OAAO3E,EAACyI,GAAA,EAAuB,EACjC,QACE,KACJ,CACF,EAEMC,GAAgB,IACpBzI,EAAAF,GAAA,CACE,UAAAC,EAAC2I,GAAA,CAAO,GAAG,cAAc,IAAKrD,EAAgB,YAAY,qBAAqB,SAAUR,EAAM,eAAgB,SAAUuC,EAAqB,EAC9IpH,EAAC,OAAI,UAAU,YACZ,UAAA4F,GACC5F,EAAC2I,GAAA,CACC,KAAK,SACL,UAAW,IAAM,CACf9C,EAAO,EAAK,CACd,EAEA,UAAA9F,EAAC,KAAE,UAAU,gBAAgB,sCAA0B,EACvDA,EAAC,KAAE,oEAAwD,GAC7D,EAED8E,EAAM,OAASH,EAAO,gBAAkBG,EAAM,OAASH,EAAO,cAAgB,CAACS,GAC9EpF,EAAC,OAAI,UAAU,OACb,SAAAA,EAAC+C,GAAA,CAAY,SAAUyD,GAAe,SAAUqB,EAAkB,cAAeH,EAAiB,EACpG,GAEA5C,EAAM,OAASH,EAAO,gBAAkBG,EAAM,OAASH,EAAO,gBAAiBuB,GAAA,YAAAA,EAAQ,QAAS,GAChGlG,EAAC,QAAK,UAAU,oEAAqE,mCAA0BkG,KAAU,GAE7H,EAECmC,GAAW,GACd,EAGIQ,GAA0B,IAC9B7I,EAAC,OAAI,UAAU,8CACb,SAAAA,EAAC+C,GAAA,CAAY,SAAUyD,GAAe,aAAcY,GAAiB,SAAUS,EAAkB,cAAeH,EAAiB,EACnI,EAGF,OACEzH,EAAC6I,GAAA,CAAO,KAAM3D,EAAM,QAASyC,EAAa,MAAM,cAAc,OAAQ,IAAM,CAAC,EAC3E,UAAA3H,EAAC,OAAI,UAAU,SAAS,YAAakH,GAClC,UAAAhC,GAAQQ,GAAY,CAAC,UAAYkD,GAAwB,EACzD1D,GAAQuD,GAAc,GACzB,EACAzI,EAAC,OAAI,UAAW,yFAA0F,MAAO,CAAE,UAAW,OAAQ,EACpI,UAAAD,EAAC+D,EAAA,CAAO,MAAM,QAAQ,QAAS6D,EAAa,iBAE5C,EACA5H,EAAC+D,EAAA,CAAO,MAAOe,EAAM,eAAgB,QAAS6C,EAAgB,SAAUvB,GAAY,KACjF,SAAAtB,EAAM,aACT,GACF,GACF,CAEJ,CAEAE,GAAW,UAAY,CAErB,OAAQ,EAAAX,QAAU,OAAO,WAEzB,IAAK,EAAAA,QAAU,OAAO,WAEtB,KAAM,EAAAA,QAAU,KAAK,WAErB,SAAU,EAAAA,QAAU,KAEpB,QAAS,EAAAA,QAAU,KAAK,WAExB,SAAU,EAAAA,QAAU,KAAK,UAC3B,EAEAW,GAAW,YAAc,aAGzB,SAASsD,IAAmB,CAC1B,OACErI,EAAC,OAAI,UAAU,iDACb,UAAAD,EAAC,MACC,SAAAA,EAACwE,GAAA,CAAgB,UAAU,yBAAyB,EACtD,EACAxE,EAAC,KAAE,UAAU,4CAA4C,8BAAkB,EAC3EA,EAAC,KAAE,UAAU,6BAA6B,wDAA4C,GACxF,CAEJ,CAEA,SAASuI,IAAqB,CAC5B,OACEvI,EAAC,OAAI,UAAU,yDACb,SAAAC,EAAC,OAAI,UAAU,4CACb,UAAAD,EAAC,MACC,SAAAA,EAAC+I,GAAA,EAAQ,EACX,EACA/I,EAAC,KAAE,UAAU,4CAA4C,yBAAa,EACtEA,EAAC,KAAE,UAAU,6BAA6B,gDAAoC,GAChF,EACF,CAEJ,CAEA,SAASyI,IAAyB,CAChC,OACEzI,EAAC,OAAI,UAAU,yDACb,SAAAC,EAAC,OAAI,UAAU,4CACb,UAAAD,EAAC,MACC,SAAAA,EAACyE,GAAA,CAAgB,UAAU,yBAAyB,EACtD,EACAzE,EAAC,KAAE,UAAU,4CAA4C,0BAAc,EACvEA,EAAC,KAAE,UAAU,6BAA6B,oDAAwC,GACpF,EACF,CAEJ,CAEA,SAAS+I,IAAU,CACjB,OACE9I,EAAC,OAAI,KAAK,SACR,UAAAA,EAAC,OACC,cAAY,OACZ,UAAU,+EACV,QAAQ,cACR,KAAK,OACL,MAAM,6BAEN,UAAAD,EAAC,QACC,EAAE,+WACF,KAAK,eACP,EACAA,EAAC,QACC,EAAE,glBACF,KAAK,cACP,GACF,EACAA,EAAC,QAAK,UAAU,UAAU,sBAAU,GACtC,CAEJ,CAIA,SAAegI,GAAeF,EAAM,QAAAjB,GAAA,sBAClC,OAAO,IAAI,WAAW,MAAMmC,GAASlB,CAAI,CAAC,CAC5C,GAEA,SAASkB,GAASlB,EAAM,CACtB,OAAO,IAAI,QAAQ,CAACmB,EAASC,IAAW,CACtC,IAAMC,EAAS,IAAI,WACnBA,EAAO,UAAaC,GAAUH,EAAQG,EAAM,OAAO,MAAM,EACzDD,EAAO,QAAWtD,GAAQqD,EAAOrD,CAAG,EACpCsD,EAAO,kBAAkBrB,CAAI,CAC/B,CAAC,CACH,CAEA,SAASI,GAAUlB,EAAM,CAEvB,OAAO,KACL,MAAM,KAAKA,CAAI,EACZ,IAAKqC,GAAM,OAAO,aAAaA,CAAC,CAAC,EACjC,KAAK,EAAE,CACZ,CACF,CCjdA,IAAA/G,GAAwB,SAMe,cAAAtC,OAAA,oBAFhC,SAASsJ,EAAiB,CAAE,MAAAC,EAAO,QAAAC,EAAS,KAAAC,EAAM,SAAAjI,CAAS,EAAG,CACnE,OACExB,GAAC0J,GAAA,CAAe,KAAMD,GAAazJ,GAAC+I,GAAA,EAAQ,EAAK,MAAOQ,EAAO,KAAMC,EAClE,SAAAhI,EACD,CAEN,CAEA8H,EAAiB,UAAY,CAE3B,MAAO,aAAU,OAAO,WAExB,QAAS,aAAU,OAEnB,WAAY,aAAU,KACtB,KAAK,aAAU,KACf,SAAU,aAAU,IACtB,EAEAA,EAAiB,YAAc,mBCxB/B,OAAS,aAAArH,GAAW,UAAAqC,GAAQ,YAAA3D,GAAU,cAAA4D,GAAY,uBAAAoF,GAAqB,cAAAC,OAAkB,QAKzF,OAAS,mBAAAC,OAAuB,iBAEhC,IAAAvH,GAAsB,SACtB,OAAOwH,OAAe,YA8NJ,OAqCd,YAAA/J,GArCc,OAAAC,EAwCR,QAAAC,OAxCQ,oBA5NlB,IAAM0E,EAAS,OAAO,OAAO,CAC3B,MAAO,QACP,eAAgB,iBAChB,QAAS,UACT,OAAQ,SACR,SAAU,WACV,eAAgB,iBAChB,aAAc,cAChB,CAAC,EAEKoF,GAAmB,CACvB,CACE,QAAS,OACT,MAAO,KACT,EACA,CACE,QAAS,WACT,MAAO,KACT,CACF,EAEMnF,GAAe,OAAO,OAAO,CACjC,KAAMD,EAAO,QACb,SAAU,QACV,WAAY,GACZ,eAAgB,EAClB,CAAC,EAED,SAASqF,GAA0BC,EAAK,CAItC,MAAO,CAAC,GAHqB,CAAC,GAAGA,EAAI,IAAI,EAAE,OAAQC,GAC1C,CAACD,EAAI,OAAO,SAASC,CAAC,CAC9B,EACgC,GAAGD,EAAI,GAAG,CAC7C,CAEA,SAASE,GAAqBrF,EAAOC,EAAQ,CAC3C,OAAQA,EAAO,KAAM,CACnB,KAAKJ,EAAO,MACV,MAAO,CACL,KAAMA,EAAO,MACb,SAAU,QACV,WAAY,GACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,QACV,OAAOC,GACT,KAAKD,EAAO,OACV,MAAO,CACL,KAAMA,EAAO,OACb,SAAU,iBACV,WAAY,SACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,SACV,MAAO,CAAE,KAAMA,EAAO,SAAU,SAAU,UAAW,WAAY,SAAU,eAAgB,EAAM,EACnG,KAAKA,EAAO,eACV,MAAO,CACL,KAAMA,EAAO,eACb,SAAU,QACV,WAAY,SACZ,eAAgB,EAClB,EACF,KAAKA,EAAO,aACV,MAAO,CACL,KAAMA,EAAO,aACb,SAAU,QACV,WAAY,GACZ,eAAgB,EAClB,EACF,QACE,MAAM,IAAI,MAAM,8BAAgCI,EAAO,IAAU,CACrE,CACF,CASO,IAAMqF,GAAgBR,GAAW,SAAuB,CAAE,KAAAzE,EAAM,YAAAkF,EAAc,CAAC,EAAG,QAAAhF,EAAS,gBAAAiF,EAAiB,SAAAnH,CAAS,EAAGoH,EAAK,CAClI,IAAMjF,EAAiBhB,GAAO,EACxBkG,EAAgBlG,GAAO,EAAK,EAC5B,CAACQ,EAAOS,CAAQ,EAAIhB,GAAW4F,GAAsB,CAAE,KAAMxF,EAAO,QAAS,aAAc,UAAW,CAAC,EACvG,CAACa,EAAYC,CAAa,EAAI9E,GAAS,CAAC,EACxC+E,EAAiBpB,GAAO,CAAC,EACzByB,EAAmBzB,GAAO,CAAE,MAAO,EAAG,aAAc,CAAE,CAAC,EACvD,CAAC0B,EAAWC,CAAY,EAAItF,GAAS,EAAK,EAC1C,CAACuF,EAAQC,CAAS,EAAIxF,GAAS,CAAE,KAAM,GAAI,SAAU,CAAE,QAAS,OAAQ,MAAO,KAAM,CAAE,CAAC,EACxF,CAAC8J,EAAUC,CAAW,EAAI/J,GAAS,CAAC,CAAC,EAErC,CAACgK,EAASC,CAAU,EAAIjK,GAAS,CAAE,KAAM,CAAC,EAAG,IAAK,CAAC,EAAG,OAAQ,CAAC,EAAG,MAAO,EAAM,CAAC,EAEtFsB,GAAU,IAAM,CAEVkD,IACFI,EAAS,CAAE,KAAMZ,EAAO,OAAQ,CAAC,EAEjCoB,EAAiB,QAAU,CAAE,MAAO,EAAG,aAAc,CAAE,EACvDW,GAAW,EACXmE,EAAY,CAAC,EACbD,EAAWE,GAAAC,GAAA,GAAKJ,GAAL,CAAc,KAAMN,CAAY,EAAC,EAC5CG,EAAc,QAAU,GAE5B,EAAG,CAACrF,CAAI,CAAC,EAETlD,GAAU,IAAM,CACVkD,GAAQL,EAAM,OAAS0F,EAAc,UACvC9E,EAAe,QAAU,EACzBmF,EAAY,EAEhB,EAAG,CAAC3E,EAAO,KAAMA,EAAO,SAAS,OAAO,CAAC,EAEzC,IAAMQ,GAAa,IAAM,CACvBgE,EAAY,CAAC,CAAC,EACdE,EAAW,CAAE,KAAM,CAAC,EAAG,IAAK,CAAC,EAAG,OAAQ,CAAC,EAAG,MAAO,EAAM,CAAC,EAC1D3E,EAAa,EAAK,CACpB,EAEM4E,EAAc,CAACjE,EAAK,IAAM,CAC9B,IAAIE,EAAOF,IAAO,EAAIlB,EAAe,QAAUkB,EAC/C0D,EAAgB,CACd,WAAYpE,EAAO,KACnB,SAAU,GACV,KAAMY,EACN,WAAYZ,EAAO,SAAS,OAC9B,CAAC,CACH,EAEAyD,GAAoBY,EAAK,KAAO,CAC9B,gBAAkBS,GAAa,CA9InC,IAAAzD,EAAA0D,EAAAC,EA+IM,GAAI,GACE3D,EAAArB,EAAO,OAAP,YAAAqB,EAAa,QAAS,GAAGhC,EAAS,CAAE,KAAMZ,EAAO,cAAe,CAAC,EACjEqG,EAAS,OAAO,KAAK,OAAS,GAAKtF,EAAe,QAAU,EAC9DgF,EAAaD,GAAa,CAAC,GAAGA,EAAU,GAAGO,EAAS,OAAO,IAAI,CAAC,EAEhEN,EAAYM,EAAS,OAAO,IAAI,EAGlCjF,EAAiB,QAAU,CAAE,MAAOiF,EAAS,OAAO,cAAe,aAAcA,EAAS,OAAO,KAAM,EACvGvF,EAAcuF,EAAS,OAAO,aAAa,IAEvCC,EAAA/E,EAAO,OAAP,YAAA+E,EAAa,QAAS,EACxB1F,EAAS,CAAE,KAAMyF,EAAS,OAAO,KAAK,OAAS,EAAIrG,EAAO,eAAiBA,EAAO,YAAa,CAAC,EAEhGY,EAAS,CAAE,KAAMyF,EAAS,OAAO,KAAK,OAAS,EAAIrG,EAAO,OAASA,EAAO,KAAM,CAAC,EAE/EgG,EAAQ,KAAK,OAASA,EAAQ,IAAI,OAASA,EAAQ,OAAO,OAAS,GAAGpF,EAAS,CAAE,KAAMZ,EAAO,QAAS,CAAC,EAC5GsB,EAAa,EAAK,CACpB,OAASiB,EAAP,CACA,QAAQ,MAAM,0BAA2BA,CAAK,EAC9C3B,EAAS,CAAE,OAAM2F,EAAAhF,EAAO,OAAP,YAAAgF,EAAa,UAAW,EAAIvG,EAAO,aAAeA,EAAO,KAAM,CAAC,CACnF,CACF,CACF,EAAE,EAEF,IAAM0C,GAAuBC,GAAe,CAxK9C,IAAAC,EAAA0D,EAyKI,IAAMzD,GAAOD,EAAAD,EAAW,OAAX,KAAAC,EAAmB,GAC1BE,GAAIwD,EAAA/E,EAAO,OAAP,KAAA+E,EAAe,GACzB9E,EAAUmB,CAAU,GACfG,EAAE,OAAS,GAAKD,EAAK,SAAW,GAAOC,EAAE,SAAW,GAAKD,EAAK,OAAS,GAAK1C,EAAM,OAASH,EAAO,UACrGY,EAAS,CAAE,KAAMZ,EAAO,OAAQ,CAAC,CACrC,EAEMwG,EAAyB,IAAM,CACnChI,EAASwH,CAAO,EAChB/C,GAAY,CACd,EAEMA,GAAc,IAAM,CACxBlB,GAAW,EACX8D,EAAc,QAAU,GACxBnF,EAAQ,CACV,EAEM8C,EAAqBpD,GAAW,CACpC,OAAQA,EAAO,KAAM,CACnB,IAAK,aACHkB,EAAalB,EAAO,OAAO,EACvBW,EAAe,QAAUK,EAAiB,QAAQ,OAAS,CAACC,IAE9DC,EAAa,EAAI,EACjBP,EAAe,QAAUA,EAAe,QAAU,EAClDmF,EAAY,GAEd,MACF,IAAK,YACH,IAAMO,EAAQT,EAAQ,IAAI,KAAMT,GAAMA,IAAMnF,EAAO,OAAO,GAAK,KACzDsG,EAAUV,EAAQ,OAAO,KAAMT,GAAMA,IAAMnF,EAAO,OAAO,GAAK,KAC9DuG,EAAaX,EAAQ,KAAK,KAAMT,GAAMA,IAAMnF,EAAO,OAAO,GAAK,KACjEwG,EAAM,CAAC,GAAGZ,EAAQ,MAAM,EACxBa,EAAM,CAAC,GAAGb,EAAQ,GAAG,EACrBW,GAAc,CAACD,EACjBE,EAAI,KAAKxG,EAAO,OAAO,EACduG,GAAcD,EACvBE,EAAM,CAAC,GAAGA,CAAG,EAAE,OAAQrB,GAAMA,IAAMnF,EAAO,OAAO,EACxC,CAACuG,GAAc,CAACF,EACzBI,EAAI,KAAKzG,EAAO,OAAO,EACd,CAACuG,GAAcF,IACxBI,EAAM,CAAC,GAAGA,CAAG,EAAE,OAAQtB,GAAMA,IAAMnF,EAAO,OAAO,GAGnD6F,EAAWE,GAAAC,GAAA,GAAKJ,GAAL,CAAc,IAAKa,EAAK,OAAQD,CAAI,EAAC,EAC5CZ,EAAQ,KAAK,OAASa,EAAI,OAASD,EAAI,OAAS,GAAGhG,EAAS,CAAE,KAAMZ,EAAO,QAAS,CAAC,EACzF,MACF,IAAK,eACHiG,EAAWE,GAAAC,GAAA,GAAKJ,GAAL,CAAc,KAAM,CAAC,EAAG,IAAK,CAAC,EAAG,OAAQ,CAAC,CAAE,EAAC,EACxDpF,EAAS,CAAE,KAAMZ,EAAO,MAAO,CAAC,EAChC,MACF,QACE,KACJ,CACF,EAEM0D,GAAa,IAAM,CACvB,OAAQvD,EAAM,KAAM,CAClB,KAAKH,EAAO,MACV,OACE3E,EAACsJ,EAAA,CACC,KAAMtJ,EAAC6J,GAAA,CAAgB,UAAU,kDAAkD,EACnF,MAAM,uBACN,QAAQ,iCACR,QAAS,GACX,EAEJ,KAAKlF,EAAO,QACV,OAAO3E,EAACsJ,EAAA,CAAiB,MAAM,mBAAmB,QAAQ,0CAA0C,QAAO,GAAC,EAC9G,KAAK3E,EAAO,eACZ,KAAKA,EAAO,SACZ,KAAKA,EAAO,OACV,OACE3E,EAACwI,GAAA,CACC,OAAQ1D,EAAM,SACd,SAAU2F,EACV,OAAQ/E,EAAe,QAAUK,EAAiB,QAAQ,MAC1D,SAAUiE,GAA0BW,CAAO,EAC3C,KAAMjF,EAAe,QACrB,MAAOF,EACP,SAAU2C,EACZ,EAEJ,KAAKxD,EAAO,aACV,OACE3E,EAACsJ,EAAA,CACC,KAAMtJ,EAAC6J,GAAA,CAAgB,UAAU,kDAAkD,EACnF,MAAM,oBACN,QAAQ,8CACV,EAGJ,QACE,KACJ,CACF,EAgCA,OACE5J,GAAC6I,GAAA,CAAO,KAAM3D,EAAM,QAASyC,GAAa,MAAM,cAAc,OAAQ,IAAM,CAAC,EAC3E,UAAA5H,EAAC,OAAI,UAAU,SAAU,SAAAmF,IAhCP,IACpBlF,GAAAF,GAAA,CACG,UAAA4K,EAAQ,KAAK,OAASA,EAAQ,IAAI,OAASA,EAAQ,OAAO,OAAS,GAClE3K,EAAC,OAAI,UAAU,4DACb,SAAAC,GAAC,KAAE,UAAU,sCACV,aAAG6J,GAAU,UAAWa,EAAQ,KAAK,OAASA,EAAQ,IAAI,OAASA,EAAQ,OAAO,OAAQ,EAAI,cAC/F3K,EAAC,QACC,QAAS,IAAMmI,EAAkB,CAAE,KAAM,eAAgB,QAAS,IAAK,CAAC,EACxE,UAAU,kDACV,6BAAoB,GACxB,EACF,EAEFnI,EAAC2I,GAAA,CACC,GAAG,cACH,IAAKrD,EACL,WAAYyE,GACZ,YAAY,qBACZ,SAAUjF,EAAM,eAChB,SAAUuC,GACZ,EACArH,EAAC,OAAI,UAAU,YACX,UAAA8E,EAAM,OAASH,EAAO,gBAAkBG,EAAM,OAASH,EAAO,eAAiBuB,EAAO,KAAK,OAAS,GACpGlG,EAAC,QAAK,UAAU,oEAAqE,mCAA0BkG,EAAO,QAAQ,EAElI,EACCmC,GAAW,GACd,GAKiD,EAAE,EACjDpI,GAAC,OAAI,UAAW,yFAA0F,MAAO,CAAE,UAAW,OAAQ,EACpI,UAAAD,EAAC+D,EAAA,CAAO,MAAM,QAAQ,QAAS6D,GAAa,iBAE5C,EACA5H,EAAC+D,EAAA,CAAO,MAAM,UAAU,QAASoH,EAAwB,SAAUV,EAAS,SAAW,EAAG,wBAE1F,GACF,GACF,CAEJ,CAAC,EAEDL,GAAc,UAAY,CAExB,KAAM,GAAA/F,QAAU,KAAK,WAErB,YAAa,GAAAA,QAAU,MAEvB,QAAS,GAAAA,QAAU,KAAK,WAExB,SAAU,GAAAA,QAAU,KAAK,UAC3B,EAEA+F,GAAc,YAAc,gBCjU5B,OAAS,SAAAqB,OAAa,iBAiDZ,cAAAzL,EAQA,QAAAC,OARA,oBAlCH,SAASyL,GAAgB,CAC9B,GAAAC,EACA,MAAApC,EACA,KAAA/B,EACA,WAAAoE,EACA,YAAAC,EACA,aAAAC,EACA,SAAAtK,EACA,UAAAuK,EACA,WAAAC,EACA,KAAAvC,CACF,EAAU,CACR,SAASwC,EAAuBC,EAAa,CAC3C,IAAIC,EAAQD,EAAI,MAAM,GAAG,EACrBE,EAAYD,EAAM,CAAC,EACnBE,EAAWF,EAAMA,EAAM,OAAS,CAAC,EACjCG,EAAcF,EAAU,OAAO,CAAC,EACpC,GAAIA,IAAcC,EAChB,IAAIE,EAAaF,EAAS,OAAO,CAAC,MAElC,KAAIE,EAAa,GAEnB,MAAO,CAACD,EAAaC,CAAU,CACjC,CAEA,IAAIC,EAAgBP,EAAuB1C,CAAK,EAEhD,OACEtJ,GAAC,MAEC,UAAU,2FAEV,UAAAA,GAAC,OAAI,UAAU,8CACZ,UAAA2L,GACC5L,EAACyM,GAAA,CACC,oBAAqBD,EACrB,MAAOX,EACP,OAAQC,EACV,EAEDrC,GAAQA,EACTxJ,GAAC,OAAI,UAAU,oBACb,UAAAA,GAAC,OAAI,UAAU,aACb,UAAAD,EAAC,KAAE,UAAU,+DACV,SAAAuJ,EACH,EACCwC,GACC/L,EAACyL,GAAA,CAAM,MAAOO,GAAc,OAAS,SAAAD,EAAU,GAEnD,EACA/L,EAAC,KAAE,UAAU,qDACX,SAAAA,EAAC,QAAK,UAAU,oBAAqB,SAAAwH,EAAK,EAC5C,GACF,GACF,EACAxH,EAAC,OAAI,UAAU,2CACb,SAAAA,EAAC,OAAI,UAAU,mCAAoC,SAAAwB,EAAS,EAC9D,IA5BKmK,CA6BP,CAEJ,CAEAD,GAAgB,YAAc","sourcesContent":["// @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 { Navbar, Sidebar, LoveFooter } from \"../\";\nimport { useMemo, useState } from \"react\";\nimport isSmallScreen from \"../helpers/is-small-screen\";\nimport { SidebarItems } from \"../../shared/sidebar-items\";\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 { useEffect, useState } from \"react\";\nimport { BsCloudUpload, BsFillCheckCircleFill } from \"react-icons/bs\";\nimport { BiSearch } from \"react-icons/bi\";\nimport { FaTimesCircle } from \"react-icons/fa\";\nimport { Button } from \"./index\";\nimport PropTypes from \"prop-types\";\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-5\">\n <Button color=\"info\" 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\"","// @ts-nocheck\nimport { useEffect, useRef, useState, useReducer } from 'react'\nimport { Drawer } from '../drawer'\nimport { Button } from '../button'\nimport { AlertBanner } from '../alert-banner'\nimport { Search } from '../search/search'\nimport { DragAndDrop } from '../drag-and-drop'\nimport { BsFillImageFill } from 'react-icons/bs'\nimport { HiOutlineSearch } from 'react-icons/hi'\nimport Listing from './file-listing'\nimport PropTypes from 'prop-types'\n\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: 'blue',\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-[87.666667%]',\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\n/**\n * IMPORTANT TO NOTE\n * The parent/calling component is responsible for fetching the files. This component should not reallyknow\n * what the files are, just how to display them. This means that searching and pagination logic should also\n * be handled by the parent/calling component\n */\n\nexport function FilePicker({ appUrl, uri, show, hideDrag = false, onClose, callback }) {\n const searchFieldRef = useRef()\n const [state, dispatch] = useReducer(FilePickerReducer, { mode: Status.LOADING, footerBorder: 'border-t' })\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(null)\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(1)\n }\n }, [show])\n\n useEffect(() => {\n if (show) {\n currentPageRef.current = 1\n getFiles()\n setErr(false)\n }\n }, [search])\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 }\n\n const getFiles = async (cp = 0) => {\n try {\n let page = cp === 0 ? currentPageRef.current : cp\n let searchUri = search?.length > 0 ? `&FileNameIncludesString=${search}` : `&FileNameIncludesString=`\n const response = await fetch(`${appUrl}${apiUrl}?CurrentPage=${page}&PageSize=10&Uri=${uri}${searchUri}`, {\n method: 'GET',\n credentials: 'same-origin',\n headers: { 'Content-Type': 'application/json' },\n })\n const data = await response.json()\n if (search?.length > 0) dispatch({ type: Status.SEARCH_RESULTS })\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 = { pages: data.Items.NumberOfPages, totalEntries: data.Items.Total }\n setTotalPages(data.Items.NumberOfPages)\n\n if (search?.length > 0) {\n dispatch({ type: data.Items.Data.length > 0 ? Status.SEARCH_RESULTS : Status.SEARCH_EMPTY })\n } else {\n const loadedState = hideDrag ? Status.LOADED_NO_DRAG : Status.LOADED\n dispatch({ type: data.Items.Data.length > 0 ? loadedState : Status.EMPTY })\n }\n\n setUploadedImage('none')\n\n setFetchData(false)\n setDragging(false)\n } catch (error) {\n dispatch({ type: search?.length === 0 ? Status.SEARCH_EMPTY : Status.EMPTY })\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(searchTerm.text)\n if ((s.length > 0 && text.length === 0) || (s.length === 0 && text.length > 0 && state.mode !== Status.LOADING))\n dispatch({ type: Status.LOADING })\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 clearState()\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 arr = await getAsByteArray(file)\n const payload = {\n Path: `/${uri}/`,\n Name: file.name,\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(null)\n searchFieldRef.current.clear()\n // dispatch({ type: Status.LOADED })\n setFiles([])\n setErr(false)\n getFiles(1)\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 (currentPageRef.current < listAttributeRef.current.pages && !fetchData) {\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()\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 (state.mode === Status.SEARCH_RESULTS || state.mode === Status.LOADED_NO_DRAG) {\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 id=\"file-search\" ref={searchFieldRef} placeholder=\"Search your images\" disabled={state.searchDisabled} callback={handleSearchRequest} />\n <div className=\"mt-4 mb-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 && state.mode !== Status.SEARCH_EMPTY && !hideDrag && (\n <div className=\"h-68\">\n <DragAndDrop uploaded={uploadedImage} callback={handleFileUpload} errorCallback={handleDropError} />\n </div>\n )}\n {(state.mode === Status.SEARCH_RESULTS || state.mode === Status.SEARCH_EMPTY) && search?.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400\">{`Showing results for...\"${search}\"`}</span>\n )}\n </div>\n\n {renderList()}\n </>\n )\n\n const renderOversizedDropZone = () => (\n <div className=\"h-[90.666667%] w-[93.666667%] z-50 absolute\">\n <DragAndDrop uploaded={uploadedImage} exitCallback={handleDragLeave} callback={handleFileUpload} errorCallback={handleDropError} />\n </div>\n )\n\n return (\n <Drawer show={show} onClose={handleClose} title=\"File Picker\" onHide={() => {}}>\n <div className=\"h-full\" onDragEnter={handleDragEnter}>\n {show && dragging && !hidedrag && renderOversizedDropZone()}\n {show && renderContent()}\n </div>\n <div className={`grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600`} style={{ marginTop: '-50px' }}>\n <Button color=\"light\" onClick={handleClose}>\n Close\n </Button>\n <Button color={state.actionBtnColor} onClick={handleUseImage} disabled={selected == null}>\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 assosiated 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=\"flex flex-col items-center justify-center mt-5\">\n <h1>\n <BsFillImageFill className=\"text-9xl text-gray-700\" />\n </h1>\n <p className=\"mt-4 font-semibold text-2xl text-gray-900\">You Have No Images</p>\n <p className=\"mt-4 text-sm text-gray-500\">Images will appear here when you upload them</p>\n </div>\n )\n}\n\nfunction LoadingPlaceholder() {\n return (\n <div className=\"h-2/3 overflow-y-auto flex items-center justify-center\">\n <div className=\"flex flex-col items-center justify-center\">\n <h1>\n <Spinner />\n </h1>\n <p className=\"mt-4 font-semibold text-2xl text-gray-900\">Loading Files</p>\n <p className=\"mt-4 text-sm text-gray-500\">Don't worry, this won't take long...</p>\n </div>\n </div>\n )\n}\n\nfunction SearchEmptyPlaceholder() {\n return (\n <div className=\"h-5/6 overflow-y-auto flex items-center justify-center\">\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 font-semibold text-2xl text-gray-900\">No Files Found</p>\n <p className=\"mt-4 text-sm text-gray-500\">No files were found matching your search</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 w-14 h-14 text-gray-200 animate-spin dark:text-gray-600 fill-blue-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","//@ts-nocheck\nimport { Spinner, NoResultsBlock } from '.';\nimport {PropTypes} from \"prop-types\";\n\n\n\nexport function TableResultBlock({ title, message, icon, children }) {\n return (\n <NoResultsBlock icon={icon ? icon :<Spinner /> } title={title} text={message}>\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 { useEffect, useRef, useState, useReducer, useImperativeHandle, forwardRef } from 'react'\nimport { Drawer } from '../drawer'\nimport { Button } from '../button'\nimport { Search} from '../search/search'\nimport { TableResultBlock } from '../table-result-block'\nimport { HiClipboardList } from 'react-icons/hi'\nimport { Listing } from './product-listing'\nimport PropTypes from 'prop-types'\nimport pluralize from 'pluralize'\n\nconst Status = Object.freeze({\n EMPTY: 'EMPTY',\n SEARCH_LOADING: 'SEARCH-LOADING',\n LOADING: 'LOADING',\n LOADED: 'LOADED',\n SELECTED: 'SELECTED',\n SEARCH_RESULTS: 'SEARCH-RESULTS',\n SEARCH_EMPTY: 'SEARCH-EMPTY',\n})\n\nconst searchCategories = [\n {\n display: 'Name',\n value: 'NME',\n },\n {\n display: 'Category',\n value: 'CAT',\n },\n]\n\nconst initialState = Object.freeze({\n mode: Status.LOADING,\n listSize: 'h-5/6',\n listBorder: '',\n searchDisabled: false,\n})\n\nfunction calculateSelectedProducts(obj) {\n const mutatedOriginalArray = [...obj.orig].filter((x) => {\n return !obj.remove.includes(x)\n })\n return [...mutatedOriginalArray, ...obj.add]\n}\n\nfunction ProductPickerReducer(state, action) {\n switch (action.type) {\n case Status.EMPTY:\n return {\n mode: Status.EMPTY,\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 listSize: 'h-[87.333333%]',\n listBorder: 'border',\n searchDisabled: false,\n }\n case Status.SELECTED:\n return { mode: Status.SELECTED, listSize: 'h-[80%]', listBorder: 'border', searchDisabled: false }\n case Status.SEARCH_RESULTS:\n return {\n mode: Status.SEARCH_RESULTS,\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 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\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({ show, preSelected = [], onClose, requestCallback, callback }, ref) {\n const searchFieldRef = useRef()\n const isViewableRef = useRef(false)\n const [state, dispatch] = useReducer(ProductPickerReducer, { mode: Status.LOADING, footerBorder: 'border-t' })\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({ text: '', category: { display: 'Name', value: 'NME' } })\n const [products, setProducts] = useState([])\n // Selected State\n const [session, setSession] = useState({ orig: [], add: [], remove: [], isAll: false }) // handles DEFAULT selection sessions\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([])\n listAttributeRef.current = { pages: 0, totalEntries: 0 }\n clearState()\n getProducts(1)\n setSession({ ...session, orig: preSelected })\n isViewableRef.current = true\n }\n }, [show])\n\n useEffect(() => {\n if (show && state.mode === isViewableRef.current) {\n currentPageRef.current = 1\n getProducts()\n }\n }, [search.text, search.category.display])\n\n const clearState = () => {\n setProducts([])\n setSession({ orig: [], add: [], remove: [], isAll: false })\n setFetchData(false)\n }\n\n const getProducts = (cp = 0) => {\n let page = cp === 0 ? currentPageRef.current : cp\n requestCallback({\n SearchText: search.text,\n PageSize: 11,\n Page: page,\n SearchType: search.category.display,\n })\n }\n\n useImperativeHandle(ref, () => ({\n responseHandler: (response) => {\n try {\n if (search.text?.length > 0) dispatch({ type: Status.SEARCH_RESULTS })\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 = { pages: response.Result.NumberOfPages, totalEntries: response.Result.Total }\n setTotalPages(response.Result.NumberOfPages)\n\n if (search.text?.length > 0) {\n dispatch({ type: response.Result.Data.length > 0 ? Status.SEARCH_RESULTS : Status.SEARCH_EMPTY })\n } else {\n dispatch({ type: response.Result.Data.length > 0 ? Status.LOADED : Status.EMPTY })\n }\n if (session.orig.length + session.add.length - session.remove.length > 0) dispatch({ type: Status.SELECTED })\n setFetchData(false)\n } catch (error) {\n console.error('Error fetching products', error)\n dispatch({ type: search.text?.length === 0 ? Status.SEARCH_EMPTY : Status.EMPTY })\n }\n },\n }))\n\n const handleSearchRequest = (searchTerm) => {\n const text = searchTerm.text ?? ''\n const s = search.text ?? ''\n setSearch(searchTerm)\n if ((s.length > 0 && text.length === 0) || (s.length === 0 && text.length > 0 && state.mode !== Status.LOADING))\n dispatch({ type: Status.LOADING })\n }\n\n const handleProductSelection = () => {\n callback(session)\n handleClose()\n }\n\n const handleClose = () => {\n clearState()\n isViewableRef.current = false\n onClose()\n }\n\n const handleListActions = (action) => {\n switch (action.type) {\n case 'FETCH_DATA':\n setFetchData(action.payload)\n if (currentPageRef.current < listAttributeRef.current.pages && !fetchData) {\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()\n }\n break\n case 'SELECTION':\n const added = session.add.find((x) => x === action.payload) != null\n const removed = session.remove.find((x) => x === action.payload) != null\n const preExisted = session.orig.find((x) => x === action.payload) != null\n let rem = [...session.remove]\n let add = [...session.add]\n if (preExisted && !removed) {\n rem.push(action.payload)\n } else if (preExisted && removed) {\n rem = [...rem].filter((x) => x !== action.payload)\n } else if (!preExisted && !added) {\n add.push(action.payload)\n } else if (!preExisted && added) {\n add = [...add].filter((x) => x !== action.payload)\n }\n\n setSession({ ...session, add: add, remove: rem })\n if (session.orig.length + add.length - rem.length > 0) dispatch({ type: Status.SELECTED })\n break\n case 'DESELECT_ALL':\n setSession({ ...session, orig: [], add: [], remove: [] })\n dispatch({ type: Status.LOADED })\n break\n default:\n break\n }\n }\n\n const renderList = () => {\n switch (state.mode) {\n case Status.EMPTY:\n return (\n <TableResultBlock\n icon={<HiClipboardList className=\"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400\" />}\n title=\"You Have No Products\"\n message=\"Your products will appear here\"\n spinner={false}\n />\n )\n case Status.LOADING:\n return <TableResultBlock title=\"Loading Products\" message=\"Please wait this may take a few minutes\" spinner />\n case Status.SEARCH_RESULTS:\n case Status.SELECTED:\n case Status.LOADED:\n return (\n <Listing\n border={state.listSize}\n products={products}\n isMore={currentPageRef.current < listAttributeRef.current.pages}\n selected={calculateSelectedProducts(session)}\n page={currentPageRef.current}\n pages={totalPages}\n callback={handleListActions}\n />\n )\n case Status.SEARCH_EMPTY:\n return (\n <TableResultBlock\n icon={<HiClipboardList className=\"mb-4 h-16 w-16 text-gray-500 dark:text-gray-400\" />}\n title=\"No Products Found\"\n message=\"No products were found matching your search\"\n />\n )\n\n default:\n break\n }\n }\n\n const renderContent = () => (\n <>\n {session.orig.length + session.add.length - session.remove.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('product', session.orig.length + session.add.length - session.remove.length, true)} selected.`}\n <span\n onClick={() => handleListActions({ type: 'DESELECT_ALL', payload: null })}\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={searchCategories}\n placeholder=\"Search your images\"\n disabled={state.searchDisabled}\n callback={handleSearchRequest}\n />\n <div className=\"mt-4 mb-4\">\n {(state.mode === Status.SEARCH_RESULTS || state.mode === Status.SEARCH_EMPTY) && search.text.length > 0 && (\n <span className=\"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400\">{`Showing results for...\"${search.text}\"`}</span>\n )}\n </div>\n {renderList()}\n </>\n )\n\n return (\n <Drawer show={show} onClose={handleClose} title=\"File Picker\" onHide={() => {}}>\n <div className=\"h-full\">{show && renderContent()}</div>\n <div className={`grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600`} style={{ marginTop: '-50px' }}>\n <Button color=\"light\" onClick={handleClose}>\n Close\n </Button>\n <Button color=\"success\" onClick={handleProductSelection} disabled={products.length === 0}>\n Add Products\n </Button>\n </div>\n </Drawer>\n )\n})\n\nProductPicker.propTypes = {\n /** Show the drawer */\n show: PropTypes.bool.isRequired,\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 /** Callback to return the selected products {orig - preselected, add - newly added, remove -items removed from pre-selected} */\n callback: PropTypes.func.isRequired,\n}\n\nProductPicker.displayName = 'ProductPicker'\n","//@ts-nocheck\nimport { Avatar } from \"./\";\nimport { Badge } from \"flowbite-react\";\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"]}
@@ -1,11 +0,0 @@
1
- import { createContext, useState, useEffect, useCallback, Fragment, useContext } from 'react';
2
- import { Transition } from '@headlessui/react';
3
- import v from 'clsx';
4
- import { HiCheck, HiXCircle, HiInformationCircle, HiExclamationTriangle } from 'react-icons/hi2';
5
- import { jsxs, jsx } from 'react/jsx-runtime';
6
-
7
- var i=createContext(void 0);function b({children:r}){let[a,n]=useState([]);useEffect(()=>{if(a.length>1){let t=setTimeout(()=>n(s=>s.slice(1)),1e3);return ()=>clearTimeout(t)}if(a.length>0){let t=setTimeout(()=>n(s=>s.slice(1)),2e3);return ()=>clearTimeout(t)}},[a]);let l=useCallback(function(t){n(s=>[...s,t]);},[n]);return jsxs(i.Provider,{value:l,children:[r,jsx("div",{"aria-live":"assertive",className:"pointer-events-none fixed inset-0 right-0 flex flex-col items-end px-4 py-6 sm:items-end sm:p-6",children:a.map(t=>jsx(h,{type:t.type,text:t.text}))})]})}b.displayName="ToastProvider";function h({type:r,text:a}){return jsx(Transition,{show:!0,as:Fragment,enter:"transform ease-out duration-300 transition",enterFrom:"translate-y-2 opacity-0 sm:translate-y-0 sm:translate-x-2",enterTo:"translate-y-0 opacity-100 sm:translate-x-0",leave:"transition ease-in duration-100",leaveFrom:"opacity-100",leaveTo:"opacity-0",children:jsxs("div",{className:"mb-4 flex w-full max-w-xs items-center rounded-lg bg-white p-4 text-gray-500 shadow dark:bg-gray-800 dark:text-gray-400",role:"alert",children:[jsxs("div",{className:v("inline-flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg",{success:"bg-green-100 text-green-500 dark:bg-green-800 dark:text-green-200",error:"bg-red-100 text-red-500 dark:bg-red-800 dark:text-red-200",info:"bg-blue-100 text-blue-500 dark:bg-blue-800 dark:text-blue-200",warning:"bg-yellow-100 text-yellow-500 dark:bg-yellow-800 dark:text-yellow-200"}[r]),children:[{success:jsx(HiCheck,{className:"h-5 w-5"}),error:jsx(HiXCircle,{className:"h-5 w-5"}),info:jsx(HiInformationCircle,{className:"h-5 w-5"}),warning:jsx(HiExclamationTriangle,{className:"h-5 w-5"})}[r],jsx("span",{className:"sr-only",children:"Check icon"})]}),jsx("div",{className:"ml-3 text-sm font-normal",children:a})]})})}function P(){let r=useContext(i);if(r===void 0)throw new Error("useToast must be used within a ToastProvider");return r}
8
-
9
- export { i as a, b, P as c };
10
- //# sourceMappingURL=out.js.map
11
- //# sourceMappingURL=chunk-N7RKCR3X.mjs.map