ekm-ui 0.3.74 → 0.3.78
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.
- package/.turbo/turbo-build.log +128 -128
- package/CHANGELOG.md +12 -0
- package/dist/accordion.d.ts +28 -21
- package/dist/accordion.mjs +1 -1
- package/dist/alert-banner.mjs +1 -1
- package/dist/avatar.mjs +1 -1
- package/dist/badge.mjs +1 -1
- package/dist/breadcrumb.mjs +1 -1
- package/dist/card-payment-block.css +1 -1
- package/dist/card-payment-block.css.map +1 -1
- package/dist/card-payment-block.mjs +46 -46
- package/dist/checkbox.mjs +1 -1
- package/dist/chunk-2OTVEVU7.mjs +11 -0
- package/dist/chunk-2OTVEVU7.mjs.map +1 -0
- package/dist/{chunk-47S6AX7M.mjs → chunk-2PW7KHXJ.mjs} +1 -1
- package/dist/chunk-2PW7KHXJ.mjs.map +1 -0
- package/dist/{chunk-CMA7TSQG.mjs → chunk-35VEFUPA.mjs} +4 -4
- package/dist/chunk-35VEFUPA.mjs.map +1 -0
- package/dist/{chunk-ZWJSMASL.mjs → chunk-3AGRJPPN.mjs} +3 -3
- package/dist/chunk-3AGRJPPN.mjs.map +1 -0
- package/dist/{chunk-MRJOYGDD.mjs → chunk-3TAXDPV6.mjs} +2 -2
- package/dist/{chunk-MRJOYGDD.mjs.map → chunk-3TAXDPV6.mjs.map} +1 -1
- package/dist/{chunk-5DQUZENZ.mjs → chunk-6F3XKP3G.mjs} +2 -2
- package/dist/chunk-6F3XKP3G.mjs.map +1 -0
- package/dist/{chunk-HEKVJKLH.mjs → chunk-6UK5Y6KZ.mjs} +2 -2
- package/dist/{chunk-HEKVJKLH.mjs.map → chunk-6UK5Y6KZ.mjs.map} +1 -1
- package/dist/{chunk-EWNPNF2B.mjs → chunk-76V2THLN.mjs} +3 -3
- package/dist/chunk-76V2THLN.mjs.map +1 -0
- package/dist/chunk-7GLTVVKS.mjs +12 -0
- package/dist/chunk-7GLTVVKS.mjs.map +1 -0
- package/dist/{chunk-UUWBHZKH.mjs → chunk-7MH2LXFV.mjs} +4 -4
- package/dist/{chunk-UUWBHZKH.mjs.map → chunk-7MH2LXFV.mjs.map} +1 -1
- package/dist/{chunk-7YKZ7D7U.mjs → chunk-ATNP3Z6G.mjs} +2 -2
- package/dist/{chunk-25FJ277C.mjs → chunk-AYH56CFA.mjs} +3 -3
- package/dist/chunk-AYH56CFA.mjs.map +1 -0
- package/dist/{chunk-NEJOZRKV.mjs → chunk-BK5RX7N5.mjs} +2 -2
- package/dist/chunk-BK5RX7N5.mjs.map +1 -0
- package/dist/{chunk-F6ZWBNIM.mjs → chunk-CIUW5YZ7.mjs} +2 -2
- package/dist/chunk-CIUW5YZ7.mjs.map +1 -0
- package/dist/{chunk-WMFTYTMD.mjs → chunk-CZC4EJOD.mjs} +3 -3
- package/dist/chunk-CZC4EJOD.mjs.map +1 -0
- package/dist/{chunk-CEK5K5TU.mjs → chunk-D3VRYN5H.mjs} +4 -4
- package/dist/chunk-D3VRYN5H.mjs.map +1 -0
- package/dist/{chunk-W3DRXKTC.mjs → chunk-DBTYTFGU.mjs} +2 -2
- package/dist/chunk-DBTYTFGU.mjs.map +1 -0
- package/dist/{chunk-JCWSMIVA.mjs → chunk-E6KQBM7F.mjs} +2 -2
- package/dist/chunk-E6KQBM7F.mjs.map +1 -0
- package/dist/{chunk-5FPVCRAI.mjs → chunk-ECOC3JRK.mjs} +1 -1
- package/dist/{chunk-5FPVCRAI.mjs.map → chunk-ECOC3JRK.mjs.map} +1 -1
- package/dist/{chunk-3LINEESX.mjs → chunk-EH3ZVEVT.mjs} +1 -1
- package/dist/chunk-EH3ZVEVT.mjs.map +1 -0
- package/dist/{chunk-YJKULMWM.mjs → chunk-EX5FMSQL.mjs} +2 -2
- package/dist/chunk-EX5FMSQL.mjs.map +1 -0
- package/dist/{chunk-ASCPOK5F.mjs → chunk-FVUORQJX.mjs} +4 -4
- package/dist/chunk-FVUORQJX.mjs.map +1 -0
- package/dist/{chunk-WFRV27QA.mjs → chunk-G5A3E5IG.mjs} +3 -3
- package/dist/chunk-G5A3E5IG.mjs.map +1 -0
- package/dist/{chunk-2IL2LP47.mjs → chunk-HOCKBMTF.mjs} +3 -3
- package/dist/chunk-HOCKBMTF.mjs.map +1 -0
- package/dist/{chunk-FRIXS4BL.mjs → chunk-JPF3K5TD.mjs} +1 -1
- package/dist/chunk-JPF3K5TD.mjs.map +1 -0
- package/dist/{chunk-AYXC2DCM.mjs → chunk-K2G6O2LX.mjs} +3 -3
- package/dist/chunk-K2G6O2LX.mjs.map +1 -0
- package/dist/chunk-LVJYP46A.mjs +9 -0
- package/dist/chunk-LVJYP46A.mjs.map +1 -0
- package/dist/{chunk-VQ3MZS4J.mjs → chunk-MPIWXVKP.mjs} +2 -2
- package/dist/chunk-MPIWXVKP.mjs.map +1 -0
- package/dist/{chunk-DZABAR36.mjs → chunk-NJC2WLYK.mjs} +2 -2
- package/dist/chunk-NJC2WLYK.mjs.map +1 -0
- package/dist/{chunk-5CGIKL2Y.mjs → chunk-OG6UBKMG.mjs} +2 -2
- package/dist/chunk-OG6UBKMG.mjs.map +1 -0
- package/dist/chunk-PEODF7PL.mjs +34 -0
- package/dist/chunk-PEODF7PL.mjs.map +1 -0
- package/dist/{chunk-FAFXVD4P.mjs → chunk-PJZVMYPN.mjs} +4 -4
- package/dist/chunk-PJZVMYPN.mjs.map +1 -0
- package/dist/{chunk-KEIDXVZB.mjs → chunk-PT4IH2KW.mjs} +2 -2
- package/dist/chunk-PT4IH2KW.mjs.map +1 -0
- package/dist/{chunk-MXH3TZWM.mjs → chunk-QFECX4D6.mjs} +1 -1
- package/dist/chunk-QFECX4D6.mjs.map +1 -0
- package/dist/{chunk-5VH26DHQ.mjs → chunk-QMFUWXJJ.mjs} +1 -1
- package/dist/chunk-QMFUWXJJ.mjs.map +1 -0
- package/dist/chunk-R4A5DO7E.mjs +12 -0
- package/dist/chunk-R4A5DO7E.mjs.map +1 -0
- package/dist/{chunk-LQQDRIZN.mjs → chunk-RGCO6BCU.mjs} +3 -3
- package/dist/chunk-RGCO6BCU.mjs.map +1 -0
- package/dist/{chunk-PPMW7YAZ.mjs → chunk-SFSA2WUE.mjs} +28 -28
- package/dist/chunk-SFSA2WUE.mjs.map +1 -0
- package/dist/{chunk-XUXHB434.mjs → chunk-SM4TG5VI.mjs} +1 -1
- package/dist/chunk-SM4TG5VI.mjs.map +1 -0
- package/dist/{chunk-D6H235SZ.mjs → chunk-UPAA75QA.mjs} +1 -1
- package/dist/chunk-UPAA75QA.mjs.map +1 -0
- package/dist/{chunk-256SAVHD.mjs → chunk-W3XYS7M3.mjs} +1 -1
- package/dist/{chunk-256SAVHD.mjs.map → chunk-W3XYS7M3.mjs.map} +1 -1
- package/dist/chunk-X2JENUDV.mjs +16 -0
- package/dist/chunk-X2JENUDV.mjs.map +1 -0
- package/dist/chunk-XBWUYKZW.mjs +10 -0
- package/dist/chunk-XBWUYKZW.mjs.map +1 -0
- package/dist/{chunk-Q365BFES.mjs → chunk-YJINOUZ7.mjs} +1 -1
- package/dist/chunk-YJINOUZ7.mjs.map +1 -0
- package/dist/{chunk-4IKXV4FQ.mjs → chunk-Z5YZVKS5.mjs} +2 -2
- package/dist/{chunk-ZHCGY4YB.mjs → chunk-ZO5NWKNY.mjs} +2 -2
- package/dist/{chunk-ZHCGY4YB.mjs.map → chunk-ZO5NWKNY.mjs.map} +1 -1
- package/dist/color-picker.mjs +1 -1
- package/dist/dashboard-notification.mjs +1 -1
- package/dist/date-range-picker.mjs +4 -4
- package/dist/drag-and-drop.css +1 -1
- package/dist/drag-and-drop.css.map +1 -1
- package/dist/drag-and-drop.mjs +46 -46
- package/dist/draggable-stacked-list-item.mjs +2 -2
- package/dist/drawer.mjs +1 -1
- package/dist/dropdown.mjs +1 -1
- package/dist/feature-cards/feature-card.mjs +2 -2
- package/dist/featurePageComponents/feature-page-group.mjs +1 -1
- package/dist/file-picker/file-listing.d.ts +1 -1
- package/dist/file-picker/file-listing.mjs +2 -2
- package/dist/file-picker/file-picker.css +1 -1
- package/dist/file-picker/file-picker.css.map +1 -1
- package/dist/file-picker/file-picker.d.ts +2 -2
- package/dist/file-picker/file-picker.mjs +46 -46
- package/dist/fixed-alert.mjs +1 -1
- package/dist/footer-heart-icon.mjs +1 -1
- package/dist/form-row.mjs +2 -2
- package/dist/index.css +1 -1
- package/dist/index.css.map +1 -1
- package/dist/index.mjs +46 -46
- package/dist/input-copy.mjs +2 -2
- package/dist/label.mjs +1 -1
- package/dist/layout/layout.css +1 -1
- package/dist/layout/layout.css.map +1 -1
- package/dist/layout/layout.mjs +46 -46
- package/dist/loading-button.mjs +1 -1
- package/dist/love-footer.mjs +2 -2
- package/dist/mini-feature-block.mjs +2 -2
- package/dist/modal.mjs +1 -1
- package/dist/navbar/navbar.mjs +1 -1
- package/dist/no-results-block.d.ts +1 -1
- package/dist/no-results-block.mjs +1 -1
- package/dist/page-header.mjs +2 -2
- package/dist/pagination/pagination.mjs +1 -1
- package/dist/product-picker/product-drawer.css +1 -1
- package/dist/product-picker/product-drawer.css.map +1 -1
- package/dist/product-picker/product-drawer.mjs +46 -46
- package/dist/product-picker/product-listing.d.ts +1 -1
- package/dist/product-picker/product-listing.mjs +2 -2
- package/dist/progress-bar.mjs +1 -1
- package/dist/radio.mjs +1 -1
- package/dist/rich-text-editor/index.mjs +1 -1
- package/dist/search/search.mjs +1 -1
- package/dist/select.mjs +1 -1
- package/dist/sort/sort.mjs +1 -1
- package/dist/spinner.mjs +1 -1
- package/dist/stacked-list-item.css +1 -1
- package/dist/stacked-list-item.css.map +1 -1
- package/dist/stacked-list-item.mjs +46 -46
- package/dist/table-header/table-header.mjs +3 -3
- package/dist/table-result-block.css +1 -1
- package/dist/table-result-block.css.map +1 -1
- package/dist/table-result-block.mjs +46 -46
- package/dist/text-row.mjs +1 -1
- package/dist/textarea.mjs +1 -1
- package/dist/textinput.mjs +1 -1
- package/dist/toast/index.mjs +1 -1
- package/dist/toggleswitch.mjs +1 -1
- package/dist/tooltip/tooltip.mjs +1 -1
- package/dist/video-dashboard-notification.mjs +1 -1
- package/dist/video-modal.mjs +1 -1
- package/package.json +4 -2
- package/src/accordion.tsx +120 -58
- package/src/alert-banner.tsx +78 -56
- package/src/avatar.tsx +71 -49
- package/src/badge.tsx +38 -30
- package/src/breadcrumb.tsx +28 -21
- package/src/checkbox.tsx +28 -20
- package/src/color-picker.tsx +2 -4
- package/src/dashboard-notification.tsx +1 -2
- package/src/date-range-picker.tsx +208 -139
- package/src/drag-and-drop.tsx +4 -4
- package/src/draggable-stacked-list-item.tsx +2 -2
- package/src/drawer.tsx +2 -2
- package/src/dropdown.tsx +91 -73
- package/src/featurePageComponents/feature-page-group.tsx +0 -1
- package/src/file-picker/file-listing.tsx +86 -38
- package/src/file-picker/file-picker.tsx +296 -212
- package/src/fixed-alert.tsx +2 -5
- package/src/footer-heart-icon.tsx +31 -7
- package/src/form-row.tsx +1 -1
- package/src/index.tsx +1 -1
- package/src/input-copy.tsx +1 -1
- package/src/label.tsx +12 -6
- package/src/layout/layout.tsx +2 -2
- package/src/loading-button.tsx +21 -21
- package/src/mini-feature-block.tsx +2 -6
- package/src/modal.tsx +46 -34
- package/src/navbar/navbar.tsx +1 -1
- package/src/no-results-block.tsx +7 -3
- package/src/page-header.tsx +13 -8
- package/src/pagination/pagination.tsx +1 -1
- package/src/product-picker/product-drawer.tsx +226 -144
- package/src/product-picker/product-listing.tsx +84 -45
- package/src/progress-bar.tsx +39 -25
- package/src/radio.tsx +11 -11
- package/src/rich-text-editor/headless-editor.ts +5 -5
- package/src/search/search.tsx +4 -4
- package/src/select.tsx +2 -3
- package/src/sort/sort.tsx +33 -31
- package/src/spinner.tsx +3 -3
- package/src/stacked-list-item.tsx +1 -1
- package/src/table-header/table-header.tsx +114 -90
- package/src/table-result-block.tsx +12 -10
- package/src/text-row.tsx +1 -1
- package/src/textarea.tsx +27 -24
- package/src/textinput.tsx +31 -28
- package/src/toast/index.tsx +4 -4
- package/src/toggleswitch.tsx +3 -1
- package/src/tooltip/tooltip.tsx +1 -1
- package/src/video-dashboard-notification.tsx +0 -2
- package/src/video-modal.tsx +2 -5
- package/dist/chunk-25FJ277C.mjs.map +0 -1
- package/dist/chunk-2IL2LP47.mjs.map +0 -1
- package/dist/chunk-3LINEESX.mjs.map +0 -1
- package/dist/chunk-47S6AX7M.mjs.map +0 -1
- package/dist/chunk-5CGIKL2Y.mjs.map +0 -1
- package/dist/chunk-5DQUZENZ.mjs.map +0 -1
- package/dist/chunk-5VH26DHQ.mjs.map +0 -1
- package/dist/chunk-ASCPOK5F.mjs.map +0 -1
- package/dist/chunk-AYXC2DCM.mjs.map +0 -1
- package/dist/chunk-CEK5K5TU.mjs.map +0 -1
- package/dist/chunk-CMA7TSQG.mjs.map +0 -1
- package/dist/chunk-CZNQ24DQ.mjs +0 -16
- package/dist/chunk-CZNQ24DQ.mjs.map +0 -1
- package/dist/chunk-D6H235SZ.mjs.map +0 -1
- package/dist/chunk-DZABAR36.mjs.map +0 -1
- package/dist/chunk-EWNPNF2B.mjs.map +0 -1
- package/dist/chunk-F6ZWBNIM.mjs.map +0 -1
- package/dist/chunk-FAFXVD4P.mjs.map +0 -1
- package/dist/chunk-FRIXS4BL.mjs.map +0 -1
- package/dist/chunk-HZTQAUGX.mjs +0 -34
- package/dist/chunk-HZTQAUGX.mjs.map +0 -1
- package/dist/chunk-JACXLYPD.mjs +0 -12
- package/dist/chunk-JACXLYPD.mjs.map +0 -1
- package/dist/chunk-JCWSMIVA.mjs.map +0 -1
- package/dist/chunk-KEIDXVZB.mjs.map +0 -1
- package/dist/chunk-LQQDRIZN.mjs.map +0 -1
- package/dist/chunk-MXH3TZWM.mjs.map +0 -1
- package/dist/chunk-NEJOZRKV.mjs.map +0 -1
- package/dist/chunk-PPMW7YAZ.mjs.map +0 -1
- package/dist/chunk-Q365BFES.mjs.map +0 -1
- package/dist/chunk-REFCK56T.mjs +0 -12
- package/dist/chunk-REFCK56T.mjs.map +0 -1
- package/dist/chunk-VPLCWU7T.mjs +0 -9
- package/dist/chunk-VPLCWU7T.mjs.map +0 -1
- package/dist/chunk-VQ3MZS4J.mjs.map +0 -1
- package/dist/chunk-W3DRXKTC.mjs.map +0 -1
- package/dist/chunk-WFRV27QA.mjs.map +0 -1
- package/dist/chunk-WLJEFSES.mjs +0 -10
- package/dist/chunk-WLJEFSES.mjs.map +0 -1
- package/dist/chunk-WMFTYTMD.mjs.map +0 -1
- package/dist/chunk-XUXHB434.mjs.map +0 -1
- package/dist/chunk-YJKULMWM.mjs.map +0 -1
- package/dist/chunk-ZJATBQ3X.mjs +0 -10
- package/dist/chunk-ZJATBQ3X.mjs.map +0 -1
- package/dist/chunk-ZWJSMASL.mjs.map +0 -1
- /package/dist/{chunk-7YKZ7D7U.mjs.map → chunk-ATNP3Z6G.mjs.map} +0 -0
- /package/dist/{chunk-4IKXV4FQ.mjs.map → chunk-Z5YZVKS5.mjs.map} +0 -0
|
@@ -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":"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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"]}
|
package/dist/chunk-JACXLYPD.mjs
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { a } from './chunk-PUJZGK7Y.mjs';
|
|
2
|
-
import { e, c } from './chunk-23SJGKDR.mjs';
|
|
3
|
-
import { createContext, useRef, useState, useContext, useEffect, Children, cloneElement } from 'react';
|
|
4
|
-
import { HiChevronUp, HiChevronDown } from 'react-icons/hi';
|
|
5
|
-
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
6
|
-
|
|
7
|
-
var r=e(a());var u=createContext();function y(g){var t=g,{children:d}=t;c(t,["children"]);let n=useRef([]),[o,a]=useState(null),c$1=s=>{a(o===s?null:s);},p=s=>{n.current.push(s);},m=()=>n.current;return jsx(u.Provider,{value:{currentlyShowing:o,handleSelection:c$1,addPanelOrder:p,getPanelList:m},children:d})}function b(g){var t=g,{children:d}=t,e=c(t,["children"]);let n=useContext(u);return useEffect(()=>{n.addPanelOrder(e.id);},[]),jsx("div",{id:`${e.id}-panel`,"data-accordion":"collapse",children:Children.map(d,o=>cloneElement(o,{id:e.id}))})}function x(g){var t=g,{children:d}=t,e=c(t,["children"]);let n=useContext(u),o=p=>{n.handleSelection(e.id);},a=n.getPanelList(),c$1=a[a.length-1]===e.id;return jsx("h2",{id:`${e.id}-title`,children:jsxs("button",{type:"button",className:`flex items-center justify-between w-full p-5 font-medium text-left border ${c$1&&n.currentlyShowing!==e.id?"border-b-1":"border-b-0"} border-gray-200 ${a[0]===e.id?"rounded-t-xl":c$1&&n.currentlyShowing!==e.id?"rounded-b-xl":"rounded-none"} ${n.currentlyShowing===e.id&&"bg-gray-100"}
|
|
8
|
-
dark:focus:ring-gray-800 dark:border-gray-700 hover:bg-gray-100 dark:hover:bg-gray-800 text-gray-500 dark:text-gray-400`,"data-accordion-target":`#${e.id}-title`,"aria-expanded":"true","aria-controls":`${e.id}-title`,onClick:o,children:[jsx("span",{children:d}),n.currentlyShowing===`${e.id}`?jsx(HiChevronUp,{className:"w-6 h-6"}):jsx(HiChevronDown,{className:"w-6 h-6"})]})})}function f(g){var t=g,{children:d}=t,e=c(t,["children"]);let n=useContext(u),o=n.getPanelList();return jsx("div",{className:e.id!==n.currentlyShowing?"hidden":"","aria-labelledby":"accordion-collapse-heading-1",children:jsx("div",{className:`p-5 border ${o[o.length-1]===e.id&&n.currentlyShowing===e.id?"rounded-b-xl border-b-1":"border-b-0"} border-gray-200 dark:border-gray-700 dark:bg-gray-900`,children:d})})}y.Panel=b;y.Title=x;y.Content=f;y.propTypes={children:r.default.shape({type:r.default.arrayOf([b])}).isRequired};b.propTypes={id:r.default.string.isRequired,children:r.default.oneOfType([r.default.shape({type:r.default.oneOf([x])}),r.default.shape({type:r.default.oneOf([f])})]).isRequired};f.propTypes={children:r.default.oneOfType([r.default.elementType])};
|
|
9
|
-
|
|
10
|
-
export { u as a, y as b, b as c, x as d, f as e };
|
|
11
|
-
//# sourceMappingURL=out.js.map
|
|
12
|
-
//# sourceMappingURL=chunk-JACXLYPD.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/accordion.tsx"],"names":["import_prop_types","useState","createContext","useContext","useEffect","useRef","cloneElement","Children","HiChevronDown","HiChevronUp","jsx","jsxs","AccordionContext","Accordion","_a","_b","children","props","__objRest","panelListRef","currentlyShowing","setCurrentlyShowing","handleSelection","id","addPanelOrder","getPanelList","AccordionPanel","context","child","AccordionTitle","e","panelList","isLastPanel","AccordionContent","PropTypes"],"mappings":"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","sourcesContent":["//@ts-nocheck\nimport { useState, createContext, useContext, useEffect, useRef, cloneElement, Children } from 'react'\nimport { HiChevronDown, HiChevronUp } from 'react-icons/hi'\nimport PropTypes from 'prop-types'\nexport const AccordionContext = createContext()\n\nexport function Accordion({ children, ...props }) {\n const panelListRef = useRef([])\n const [currentlyShowing, setCurrentlyShowing] = useState(null)\n\n const handleSelection = (id) => {\n if (currentlyShowing === id) {\n setCurrentlyShowing(null)\n } else {\n setCurrentlyShowing(id)\n }\n }\n\n const addPanelOrder = (id) => {\n panelListRef.current.push(id)\n }\n\n const getPanelList = () => {\n return panelListRef.current\n }\n\n return <AccordionContext.Provider value={{ currentlyShowing, handleSelection, addPanelOrder, getPanelList }}>{children}</AccordionContext.Provider>\n}\n\nexport function AccordionPanel({ children, ...props }) {\n const context = useContext(AccordionContext)\n useEffect(() => {\n context.addPanelOrder(props.id)\n }, [])\n\n return (\n <div id={`${props.id}-panel`} data-accordion=\"collapse\">\n {Children.map(children, (child) => {\n return cloneElement(child, { id: props.id })\n })}\n </div>\n )\n}\n\nexport function AccordionTitle({ children, ...props }) {\n const context = useContext(AccordionContext)\n\n const handleSelection = (e) => {\n context.handleSelection(props.id)\n }\n\n const panelList = context.getPanelList()\n const isLastPanel = panelList[panelList.length - 1] === props.id\n\n return (\n <h2 id={`${props.id}-title`}>\n <button\n type=\"button\"\n className={`flex items-center justify-between w-full p-5 font-medium text-left border ${\n isLastPanel && context.currentlyShowing !== props.id ? 'border-b-1' : 'border-b-0'\n } border-gray-200 ${\n panelList[0] === props.id ? 'rounded-t-xl' : isLastPanel && context.currentlyShowing !== props.id ? 'rounded-b-xl' : 'rounded-none'\n } ${context.currentlyShowing === props.id && 'bg-gray-100'}\n dark:focus:ring-gray-800 dark:border-gray-700 hover:bg-gray-100 dark:hover:bg-gray-800 text-gray-500 dark:text-gray-400`}\n data-accordion-target={`#${props.id}-title`}\n aria-expanded=\"true\"\n aria-controls={`${props.id}-title`}\n onClick={handleSelection}\n >\n <span>{children}</span>\n {context.currentlyShowing === `${props.id}` ? <HiChevronUp className=\"w-6 h-6\" /> : <HiChevronDown className=\"w-6 h-6\" />}\n </button>\n </h2>\n )\n}\n\nexport function AccordionContent({ children, ...props }) {\n const context = useContext(AccordionContext)\n const panelList = context.getPanelList()\n return (\n <div className={props.id !== context.currentlyShowing ? 'hidden' : ''} aria-labelledby=\"accordion-collapse-heading-1\">\n <div\n className={`p-5 border ${\n panelList[panelList.length - 1] === props.id && context.currentlyShowing === props.id ? 'rounded-b-xl border-b-1' : 'border-b-0'\n } border-gray-200 dark:border-gray-700 dark:bg-gray-900`}\n >\n {children}\n </div>\n </div>\n )\n}\n\nAccordion.Panel = AccordionPanel\nAccordion.Title = AccordionTitle\nAccordion.Content = AccordionContent\n\nAccordion.propTypes = {\n /** Components to be rendered as Part of the Compound Component, each panel is a seperate accordion section*/\n children: PropTypes.shape({ type: PropTypes.arrayOf([AccordionPanel]) }).isRequired,\n}\n\nAccordionPanel.propTypes = {\n /** Unique id for the dropdown */\n id: PropTypes.string.isRequired,\n /** Components to be rendered as Part of the Compound Component*/\n children: PropTypes.oneOfType([\n PropTypes.shape({ type: PropTypes.oneOf([AccordionTitle]) }),\n PropTypes.shape({ type: PropTypes.oneOf([AccordionContent]) }),\n ]).isRequired,\n}\n\nAccordionContent.propTypes = {\n /** Components held within the Content section of the AccordionPanel*/\n children: PropTypes.oneOfType([PropTypes.elementType]),\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/breadcrumb.tsx"],"names":["import_prop_types","HiOutlineChevronRight","jsx","jsxs","Breadcrumb","children","BreadcrumbHome","href","BreadcrumbItem","PropTypes"],"mappings":"kFAEA,IAAAA,EAAsB,OADtB,OAAS,yBAAAC,MAA6B,iBAMhC,cAAAC,EAsBF,QAAAC,MAtBE,oBAHC,SAASC,EAAW,CAAE,SAAAC,CAAS,EAAG,CACvC,OACEH,EAAC,OAAI,UAAU,OAAO,aAAW,aAC/B,SAAAA,EAAC,MAAG,UAAU,kDAAmD,SAAAG,EAAS,EAC5E,CAEJ,CACO,SAASC,EAAe,CAAE,KAAAC,EAAM,SAAAF,CAAS,EAAG,CACjD,OACEH,EAAC,MAAG,UAAU,2BACX,SAAAK,EACCL,EAAC,KACC,UAAU,kJACV,KAAMK,EAEL,SAAAF,EACH,EAEAH,EAAC,QAAK,UAAU,yEAA0E,SAAAG,EAAS,EAEvG,CAEJ,CACO,SAASG,EAAe,CAAE,KAAAD,EAAM,SAAAF,CAAS,EAAG,CACjD,OACEF,EAAC,MAAG,UAAU,2BACZ,UAAAD,EAACD,EAAA,CAAsB,UAAU,iBAAiB,EACjDM,EACCL,EAAC,KACC,UAAU,kJACV,KAAMK,EAEL,SAAAF,EACH,EAEAH,EAAC,QAAK,UAAU,yEAAyE,cAAY,2BAClG,SAAAG,EACH,GAEJ,CAEJ,CAEAD,EAAW,KAAOE,EAClBF,EAAW,KAAOI,EAElBJ,EAAW,UAAY,CAEnB,SAAU,EAAAK,QAAU,KAAK,UAC7B,EAEAH,EAAe,UAAY,CAEzB,KAAM,EAAAG,QAAU,OAChB,SAAU,EAAAA,QAAU,OAAO,UAC7B,EAEAD,EAAe,UAAY,CAEzB,KAAM,EAAAC,QAAU,OAChB,SAAU,EAAAA,QAAU,OAAO,UAC7B,EAEAL,EAAW,YAAc","sourcesContent":["//@ts-nocheck\nimport { HiOutlineChevronRight } from 'react-icons/hi'\nimport PropTypes from 'prop-types'\n\nexport function Breadcrumb({ children }) {\n return (\n <nav className=\"flex\" aria-label=\"Breadcrumb\">\n <ol className=\"inline-flex items-center space-x-1 md:space-x-3\">{children}</ol>\n </nav>\n )\n}\nexport function BreadcrumbHome({ href, children }) {\n return (\n <li className=\"inline-flex items-center\">\n {href ? (\n <a\n className=\"flex items-center text-sm font-medium text-gray-700 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white cursor-pointer hover:underline\"\n href={href}\n >\n {children}\n </a>\n ) : (\n <span className=\"flex items-center text-sm font-medium text-gray-700 dark:text-gray-400\">{children}</span>\n )}\n </li>\n )\n}\nexport function BreadcrumbItem({ href, children }) {\n return (\n <li className=\"inline-flex items-center\">\n <HiOutlineChevronRight className=\"w-3 h-3 mr-2.5\" />\n {href ? (\n <a\n className=\"flex items-center text-sm font-medium text-gray-700 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white cursor-pointer hover:underline\"\n href={href}\n >\n {children}\n </a>\n ) : (\n <span className=\"flex items-center text-sm font-medium text-gray-700 dark:text-gray-400\" data-testid=\"flowbite-breadcrumb-item\">\n {children}\n </span>\n )}\n </li>\n )\n}\n\nBreadcrumb.Home = BreadcrumbHome\nBreadcrumb.Item = BreadcrumbItem\n\nBreadcrumb.propTypes = {\n /** Beadcrumb compound elements that make up the breadcrumb This is always Breadcrumb.Home and one or more of Breadcrumb.Item*/\n children: PropTypes.node.isRequired\n}\n\nBreadcrumbHome.propTypes = {\n /** Elements to show in the breadcrumb usually this will be an icon with just a string */\n href: PropTypes.string,\n children: PropTypes.string.isRequired\n}\n\nBreadcrumbItem.propTypes = {\n /** Elements to show in the breadcrumb usually this will be just a string */\n href: PropTypes.string,\n children: PropTypes.string.isRequired\n}\n\nBreadcrumb.displayName = \"Breadcrumb\";"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/alert-banner.tsx"],"names":["import_prop_types","variantProps","FaTimes","FaInfoCircle","FaCheckCircle","FaExclamationCircle","FaExclamationTriangle","jsx","jsxs","alertProps","dismissProps","AlertBanner","children","type","showIcon","onDismiss","rounded","renderIcon","__spreadProps","__spreadValues","PropTypes"],"mappings":"gGAKA,IAAAA,EAAsB,OAHtB,OAAS,gBAAAC,MAAoB,2BAE7B,OAAS,WAAAC,EAAS,gBAAAC,EAAc,iBAAAC,EAAe,uBAAAC,EAAqB,yBAAAC,MAA6B,iBAgDlF,cAAAC,EAmBP,QAAAC,MAnBO,oBA7Cf,IAAMC,EAAaR,EAAa,CAC9B,KAAM,gBACN,SAAU,CACR,KAAM,CACJ,KAAM,2GACN,QAAS,2GACT,QAAS,gHACT,OAAQ,sGACR,QAAS,oHACX,EACA,KAAM,CACJ,GAAI,UACJ,GAAI,UACJ,GAAI,SACN,EACA,QAAS,CACP,KAAM,aACN,MAAO,cACT,EACA,gBAAiB,CACf,KAAM,OACN,QAAS,GACT,KAAM,IACR,CACF,CACF,CAAC,EAEKS,EAAeT,EAAa,CAChC,KAAM,wGACN,SAAU,CACR,KAAM,CACJ,KAAM,6HACN,QAAS,6HACT,QAAS,mIACT,OAAQ,wHACR,QAAS,sIACX,CACF,CACF,CAAC,EAEM,SAASU,EAAY,CAAE,SAAAC,EAAU,KAAAC,EAAM,SAAAC,EAAU,UAAAC,EAAW,QAAAC,CAAO,EAAG,CAE3E,IAAMC,EAAa,IAAM,CACvB,OAAQJ,EAAM,CACZ,IAAK,OACH,OAAON,EAACJ,EAAA,EAAa,EACvB,IAAK,UACH,OAAOI,EAACH,EAAA,EAAc,EACxB,IAAK,SACH,OAAOG,EAACF,EAAA,EAAoB,EAC9B,IAAK,UACH,OAAOE,EAACD,EAAA,EAAsB,EAChC,QACE,OAAOC,EAACJ,EAAA,EAAa,CACzB,CACF,EAEA,OACEK,EAAC,MAAAU,EAAAC,EAAA,GAAQV,EAAW,CAAE,KAAAI,EAAM,QAAAG,CAAQ,CAAC,GAApC,CAAuC,KAAK,QAC1C,UAAAF,GAAYP,EAAC,OAAI,UAAU,yCAA0C,SAAAU,EAAW,EAAE,EACnFV,EAAC,QAAK,UAAU,UAAW,SAAAM,EAAK,EAC/BD,GAAYL,EAAC,OAAK,SAAAK,EAAS,EAE3BG,GACCP,EAAC,SAAAU,EAAAC,EAAA,CAAO,KAAK,UAAaT,EAAa,CAAE,KAAAG,CAAK,CAAC,GAA9C,CAAiD,sBAAoB,WAAW,aAAW,QAAQ,QAASE,EAC3G,UAAAR,EAAC,QAAK,UAAU,UAAU,iBAAK,EAC/BA,EAACL,EAAA,EAAQ,IACX,IAEJ,CAEJ,CAEAS,EAAY,aAAe,CACvB,SAAU,GACV,QAAS,EACb,EAEAA,EAAY,UAAY,CAEpB,KAAM,EAAAS,QAAU,MAAM,CAAC,OAAQ,UAAW,UAAW,QAAQ,CAAC,EAAE,WAEhE,SAAU,EAAAA,QAAU,KAEpB,UAAW,EAAAA,QAAU,KAErB,QAAS,EAAAA,QAAU,KAEnB,SAAU,EAAAA,QAAU,KAAK,UAC7B,EAEAT,EAAY,YAAc","sourcesContent":["//@ts-nocheck\n\nimport { variantProps } from 'classname-variants/react'\nimport { FaTimes } from 'react-icons/fa'\nimport { FaTimes, FaInfoCircle, FaCheckCircle, FaExclamationCircle, FaExclamationTriangle } from 'react-icons/fa'\nimport PropTypes from 'prop-types'\n\nconst alertProps = variantProps({\n base: 'flex p-4 mb-4',\n variants: {\n type: {\n info: 'text-blue-800 border border-blue-300 bg-blue-50 dark:bg-gray-800 dark:text-blue-400 dark:border-blue-800',\n default: 'text-gray-800 border border-gray-300 bg-gray-50 dark:bg-gray-800 dark:text-gray-400 dark:border-gray-800',\n success: 'text-green-800 border border-green-300 bg-green-50 dark:bg-gray-800 dark:text-green-400 dark:border-green-800',\n danger: 'text-red-800 border border-red-300 bg-red-50 dark:bg-gray-800 dark:text-red-400 dark:border-red-800',\n warning: 'text-yellow-800 border border-yellow-300 bg-yellow-50 dark:bg-gray-800 dark:text-yellow-400 dark:border-yellow-800',\n },\n size: {\n sm: 'text-sm',\n md: 'text-md',\n lg: 'text-lg',\n },\n rounded: {\n true: 'rounded-lg',\n false: 'rounded-none',\n },\n defaultVariants: {\n type: 'info',\n rounded: true,\n size: 'md',\n },\n },\n})\n\nconst dismissProps = variantProps({\n base: 'ml-auto -mx-1.5 -my-1.5 rounded-lg focus:ring-2 p-1.5 inline-flex items-center justify-center h-8 w-8',\n variants: {\n type: {\n info: ' bg-blue-50 text-blue-500 focus:ring-blue-400 hover:bg-blue-200 dark:bg-gray-800 dark:text-blue-400 dark:hover:bg-gray-700',\n default: ' bg-grey-50 text-gray-500 focus:ring-gray-400 hover:bg-gray-200 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700',\n success: ' bg-green-50 text-green-500 focus:ring-green-400 hover:bg-green-200 dark:bg-green-800 dark:text-green-400 dark:hover:bg-gray-700',\n danger: ' bg-red-50 text-red-500 focus:ring-red-400 hover:bg-red-200 dark:bg-gray-800 dark:text-red-400 dark:hover:bg-gray-700',\n warning: ' bg-yellow-50 text-yellow-500 focus:ring-yellow-400 hover:bg-yellow-200 dark:bg-gray-800 dark:text-yellow-400 dark:hover:bg-gray-700',\n },\n },\n})\n\nexport function AlertBanner({ children, type, showIcon, onDismiss, rounded}) {\n\n const renderIcon = () => {\n switch (type) {\n case 'info':\n return <FaInfoCircle />\n case 'success':\n return <FaCheckCircle />\n case 'danger':\n return <FaExclamationCircle />\n case 'warning':\n return <FaExclamationTriangle />\n default:\n return <FaInfoCircle />\n }\n }\n\n return (\n <div {...alertProps({ type, rounded })} role=\"alert\">\n {showIcon && <div className=\"flex-shrink-0 inline w-4 h-4 mr-3 mt-1\">{renderIcon()}</div>}\n <span className=\"sr-only\">{type}</span>\n {children && <div>{children}</div>}\n\n {onDismiss && (\n <button type=\"button\" {...dismissProps({ type })} data-dismiss-target=\"#alert-1\" aria-label=\"Close\" onClick={onDismiss}>\n <span className=\"sr-only\">Close</span>\n <FaTimes />\n </button>\n )}\n </div>\n )\n}\n\nAlertBanner.defaultProps = {\n showIcon: true,\n rounded: true,\n}\n\nAlertBanner.propTypes = {\n /** Type of Alert */\n type: PropTypes.oneOf(['info', 'success', 'warning', 'danger']).isRequired,\n /** Determins if the icon assosiated with the alert type should be shown (defaults to true) */\n showIcon: PropTypes.bool,\n /** Function to be called when Alert is dismissed */\n onDismiss: PropTypes.func,\n /** Whether Alert should have rounded corners */\n rounded: PropTypes.bool,\n /** Components to be rendered as Part of the Compound Component*/\n children: PropTypes.node.isRequired,\n}\n\nAlertBanner.displayName = \"AlertBanner\"\n\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/file-picker/file-listing.tsx"],"names":["useEffect","useRef","import_prop_types","jsx","jsxs","Listing","border","files","isMore","selected","page","pages","callback","scrollRef","element","handleScroll","offset","scroll","handleImageSelection","fileName","f","FileRow","InfiniteLoader","file","Radio","writeDate","PropTypes","date","d","months","err"],"mappings":"2HACA,OAAS,aAAAA,EAAW,UAAAC,MAAc,QAElC,IAAAC,EAAsB,OAgClB,OAEW,OAAAC,EAFX,QAAAC,MAAA,oBA5BW,SAARC,EAAyB,CAAE,OAAAC,EAAQ,MAAAC,EAAO,OAAAC,EAAQ,SAAAC,EAAU,KAAAC,EAAM,MAAAC,EAAO,SAAAC,CAAS,EAAG,CAC1F,IAAMC,EAAYZ,EAAO,EAEzBD,EAAU,IAAM,CACd,IAAMc,EAAU,SAAS,cAAc,gBAAgB,EACvD,OAAIA,GAAW,CAACA,EAAQ,aAAa,QAAQ,GAAGD,EAAU,QAAQ,iBAAiB,SAAUE,CAAY,EACrGF,EAAU,SAAW,OAAMA,EAAU,QAAQ,UAAY,GACtD,IAAM,CACX,IAAMC,EAAU,SAAS,cAAc,gBAAgB,EACnDA,GAAWA,EAAQ,aAAa,QAAQ,GAAGD,EAAU,QAAQ,oBAAoB,SAAUE,CAAY,CAC7G,CACF,EAAG,CAAC,CAAC,EAEL,IAAMA,EAAe,IAAM,CACzB,GAAI,CAACP,EAAQ,OACb,IAAMQ,EAASH,EAAU,QAAQ,aAAeA,EAAU,QAAQ,aAC5DI,EAAS,KAAK,MAAMJ,EAAU,QAAQ,SAAS,GAEjDI,GAAUD,GAAUC,EAAS,GAAKD,GAAUC,EAAS,GAAKD,IAC5DJ,EAAS,CAAE,KAAM,aAAc,QAAS,EAAK,CAAC,CAElD,EAEMM,EAAwBC,GAAa,CACzCP,EAAS,CAAE,KAAM,YAAa,QAASH,IAAaU,EAAW,GAAKA,CAAS,CAAC,CAChF,EAEA,OACEf,EAAC,OAAI,GAAG,gBAAgB,IAAKS,EAAW,UAAW,GAAGP,sCAClD,WAAAC,GAAS,CAAC,GAAG,IAAKa,GACXjB,EAACkB,EAAA,CAAmC,KAAMD,EAAG,SAAUX,IAAaW,EAAE,KAAM,SAAUF,GAAxE,YAAYE,EAAE,MAAgF,CACpH,EACAZ,GAAUE,EAAOC,GAASR,EAACmB,EAAA,EAAe,GAC7C,CAEJ,CAEA,SAASD,EAAQ,CAAE,KAAAE,EAAM,SAAAd,EAAW,GAAO,SAAAG,CAAS,EAAG,CACrD,OACER,EAAC,OACC,UAAW,yCAAyCK,GAAY,uEAChE,QAAS,IAAM,CACbG,EAASW,CAAI,CACf,EAEA,UAAAnB,EAAC,OAAI,UAAU,yBACb,UAAAD,EAAC,OAAI,UAAU,gBACb,SAAAA,EAACqB,EAAA,CAAM,GAAID,EAAK,KAAM,KAAMA,EAAK,KAAM,QAASd,EAAU,SAAQ,GAAC,EACrE,EACAN,EAAC,OAAI,UAAU,OACb,SAAAA,EAAC,OAAI,UAAU,uBAAuB,IAAK,4BAA4BoB,EAAK,MAAO,IAAI,GAAG,EAC5F,EACAnB,EAAC,OAAI,UAAU,OACb,UAAAD,EAAC,OAAI,UAAU,6BAA8B,SAAAoB,EAAK,KAAK,EACtDA,EAAK,MAAQpB,EAAC,OAAI,UAAU,wBAAyB,SAAAoB,EAAK,KAAK,GAClE,GACF,EACApB,EAAC,OAAI,UAAU,qBACb,SAAAA,EAAC,QAAK,UAAU,6BAA8B,SAAAsB,EAAUF,EAAK,aAAa,EAAE,EAC9E,GACF,CAEJ,CAEAlB,EAAQ,UAAY,CAElB,OAAQ,EAAAqB,QAAU,OAElB,MAAO,EAAAA,QAAU,MAEjB,OAAQ,EAAAA,QAAU,KAElB,SAAU,EAAAA,QAAU,OAEpB,KAAM,EAAAA,QAAU,OAEhB,MAAO,EAAAA,QAAU,OAEjB,SAAU,EAAAA,QAAU,IACtB,EAEAL,EAAQ,UAAY,CAElB,KAAM,EAAAK,QAAU,OAEhB,SAAU,EAAAA,QAAU,KAEpB,SAAU,EAAAA,QAAU,IACtB,EAEA,SAASJ,GAAiB,CACxB,OACEnB,EAAC,OAAI,UAAU,0CACb,SAAAA,EAAC,OAAI,KAAK,SACR,SAAAC,EAAC,OACC,cAAY,OACZ,UAAU,sGACV,QAAQ,cACR,KAAK,OACL,MAAM,6BAEN,UAAAD,EAAC,QACC,EAAE,+WACF,KAAK,eACP,EACAA,EAAC,QACC,EAAE,glBACF,KAAK,cACP,GACF,EACF,EACF,CAEJ,CAEA,SAASsB,EAAUE,EAAM,CACvB,GAAI,CACF,IAAMC,EAAI,IAAI,KAAKD,CAAI,EACjBE,EAAS,CAAC,UAAW,WAAY,QAAS,QAAS,MAAO,OAAQ,OAAQ,SAAU,YAAa,UAAW,WAAY,UAAU,EACxI,OAAOD,EAAE,QAAQ,EAAI,IAAMC,EAAOD,EAAE,SAAS,CAAC,EAAI,IAAMA,EAAE,YAAY,CACxE,OAASE,EAAP,CACA,MAAO,SACT,CACF","sourcesContent":["// @ts-nocheck\nimport { useEffect, useRef } from 'react'\nimport { Radio } from '../radio'\nimport PropTypes from 'prop-types'\n\n// FOR USE WITH THE FILE PICKER COMPONENT - ONLY\n\nexport default function Listing({ border, files, isMore, selected, page, pages, callback }) {\n const scrollRef = useRef()\n\n useEffect(() => {\n const element = document.querySelector('#img-file-list')\n if (element && !element.hasAttribute('scroll')) scrollRef.current.addEventListener('scroll', handleScroll)\n if (scrollRef.current != null) scrollRef.current.scrollTop = 0\n return () => {\n const element = document.querySelector('#img-file-list')\n if (element && element.hasAttribute('scroll')) scrollRef.current.removeEventListener('scroll', handleScroll)\n }\n }, [])\n\n const handleScroll = () => {\n if (!isMore) return\n const offset = scrollRef.current.scrollHeight - scrollRef.current.offsetHeight\n const scroll = Math.floor(scrollRef.current.scrollTop)\n // the '-2 & +2' is used as a buffer, otherwise '==' positioning of the scroll becomes too accurate.\n if (scroll == offset || scroll + 2 == offset || scroll - 2 == offset) {\n callback({ type: 'FETCH_DATA', payload: true })\n }\n }\n\n const handleImageSelection = (fileName) => {\n callback({ type: 'SELECTION', payload: selected === fileName ? '' : fileName })\n }\n\n return (\n <div id=\"img-file-list\" ref={scrollRef} className={`${border} border rounded-md overflow-y-auto`}>\n {(files || []).map((f) => {\n return <FileRow key={`file-row-${f.Name}`} file={f} selected={selected === f.Name} callback={handleImageSelection} />\n })}\n {isMore && page < pages && <InfiniteLoader />}\n </div>\n )\n}\n\nfunction FileRow({ file, selected = false, callback }) {\n return (\n <div\n className={`flex items-center pt-4 pb-4 mt-1 mb-1 ${selected && 'bg-blue-50'} justify-between border-b border-gray-100 cursor-pointer`}\n onClick={() => {\n callback(file)\n }}\n >\n <div className=\"flex items-center ml-3\">\n <div className=\"flex-shrink-0\">\n <Radio id={file.Name} name={file.Name} checked={selected} readOnly />\n </div>\n <div className=\"ml-4\">\n <img className=\"h-10 w-10 rounded-md\" src={`https://files.ekmcdn.com/${file.Uri}`} alt=\"\" />\n </div>\n <div className=\"ml-4\">\n <div className=\" font-medium text-gray-900\">{file.Name}</div>\n {file.Size && <div className=\"text-xs text-gray-500\">{file.Size}</div>}\n </div>\n </div>\n <div className=\"ml-4 flex-shrink-0\">\n <span className=\"text-sm mr-3 text-gray-500\">{writeDate(file.LastWriteTime)}</span>\n </div>\n </div>\n )\n}\n\nListing.propTypes = {\n /** Border style to use*/\n border: PropTypes.string,\n /** Array of files to list */\n files: PropTypes.array,\n /** Boolean to indicate if there are more files to load */\n isMore: PropTypes.bool,\n /** Name of the selected file */\n selected: PropTypes.string,\n /** Current page */\n page: PropTypes.number,\n /** Total number of pages */\n pages: PropTypes.number,\n /** Callback function to handle events */\n callback: PropTypes.func,\n}\n\nFileRow.propTypes = {\n /** File object to display */\n file: PropTypes.object,\n /** Boolean to indicate if the file is selected */\n selected: PropTypes.bool,\n /** Callback function to handle events */\n callback: PropTypes.func,\n}\n\nfunction InfiniteLoader() {\n return (\n <div className=\"flex justify-center pt-4 pb-4 mt-1 mb-1\">\n <div role=\"status\">\n <svg\n aria-hidden=\"true\"\n className=\"inline-block w-8 h-8 text-gray-200 animate-spin dark:text-gray-600 fill-gray-600 dark:fill-gray-300\"\n viewBox=\"0 0 100 101\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z\"\n fill=\"currentFill\"\n />\n </svg>\n </div>\n </div>\n )\n}\n\nfunction writeDate(date) {\n try {\n const d = new Date(date)\n const months = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']\n return d.getDate() + ' ' + months[d.getMonth()] + ' ' + d.getFullYear()\n } catch (err) {\n return 'Unknown'\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/radio.tsx"],"names":["import_prop_types","forwardRef","jsx","Radio","props","ref","__spreadValues","PropTypes"],"mappings":"yFAEA,IAAAA,EAAsB,OADtB,OAAS,cAAAC,MAAkB,QAKrB,cAAAC,MAAA,oBAFC,IAAMC,EAAQF,EAAW,SAAeG,EAAOC,EAAK,CACzD,OACIH,EAAC,QAAAI,EAAA,CACC,GAAIF,EAAM,GACV,IAAKC,EACL,KAAK,QACL,UAAW,4LACTD,EAAM,UAAY,gBAEhBA,EACN,CAEN,CAAC,EAEDD,EAAM,UAAY,CAEhB,GAAI,EAAAI,QAAU,OAAO,WAErB,QAAS,EAAAA,QAAU,KAEnB,SAAU,EAAAA,QAAU,KAEpB,SAAU,EAAAA,QAAU,IACtB,EAEAJ,EAAM,YAAc","sourcesContent":["//@ts-nocheck\nimport { forwardRef } from \"react\";\nimport PropTypes from \"prop-types\";\n\nexport const Radio = forwardRef(function Radio(props, ref) {\n return (\n <input\n id={props.id}\n ref={ref}\n type=\"radio\"\n className={`h-4 w-4 rounded-full border-gray-300 bg-gray-100 text-blue-600 focus:ring-2 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-700 dark:ring-offset-gray-800 dark:focus:ring-blue-600 ${\n props.disabled && \"opacity-50\"\n }`}\n {...props}\n />\n );\n});\n\nRadio.propTypes = {\n /** Id for Radio */ \n id: PropTypes.string.isRequired,\n /** Bool to determine if radio has been checked */\n checked: PropTypes.bool,\n /** Bool to disable radio */\n disabled: PropTypes.bool,\n /** function to handle checked value */\n onChange: PropTypes.func,\n};\n\nRadio.displayName = \"Radio\";\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/page-header.tsx"],"names":["jsx","jsxs","PageHeader","children","title","text","breadcrumbs","Breadcrumb","bc","i"],"mappings":"oCAcQ,OAKU,OAAAA,EALV,QAAAC,MAAA,oBAJD,SAASC,EAAW,CAAE,SAAAC,EAAU,MAAAC,EAAO,KAAAC,EAAM,YAAAC,CAAY,EAAU,CACxE,OACEN,EAAC,OAAI,UAAU,mHACb,SAAAC,EAAC,OAAI,UAAU,qFACb,UAAAA,EAAC,OACC,UAAAD,EAACO,EAAA,CAAW,aAAW,6BACnB,UAAAD,GAAe,CAAC,GAAG,IAAI,CAACE,EAAIC,IACxBA,IAAM,EAENT,EAACO,EAAW,KAAX,CAAiC,KAAMC,EAAG,QACxC,SAAAA,EAAG,WADgBA,EAAG,OAEzB,EAKFR,EAACO,EAAW,KAAX,CAAiC,KAAMC,EAAG,QACxC,SAAAA,EAAG,WADgBA,EAAG,OAEzB,CAEH,EACH,EACAR,EAAC,MAAG,UAAU,iFAAkF,SAAAI,EAAM,EACtGJ,EAAC,KAAE,UAAU,wDAAyD,SAAAK,EAAK,GAC7E,EAEAL,EAAC,OAAI,UAAU,iFAAkF,SAAAG,EAAS,GAC5G,EACF,CAEJ,CAEAD,EAAW,YAAc","sourcesContent":["//@ts-nocheck\nimport { Breadcrumb } from \"./breadcrumb\";\n\ntype Props = {\n title: string;\n text?: string | Element[];\n children?: JSX.Element;\n breadcrumbs: Array<{ linkLabel: string; linkURL: string }>;\n};\n\nexport function PageHeader({ children, title, text, breadcrumbs }: Props) {\n return (\n <div className=\"border-b bg-white p-8 shadow-sm dark:border-gray-700 dark:bg-gray-800 lg:flex lg:items-center lg:justify-between\">\n <div className=\"flex w-full flex-wrap items-center justify-between gap-x-8 gap-y-4 sm:flex-nowrap \">\n <div>\n <Breadcrumb aria-label=\"Default breadcrumb example\">\n {(breadcrumbs || []).map((bc, i) => {\n if (i === 0) {\n return (\n <Breadcrumb.Home key={bc.linkURL} href={bc.linkURL}>\n {bc.linkLabel}\n </Breadcrumb.Home>\n )\n }\n\n return (\n <Breadcrumb.Item key={bc.linkURL} href={bc.linkURL}>\n {bc.linkLabel}\n </Breadcrumb.Item>\n )\n })}\n </Breadcrumb>\n <h2 className=\"mt-2 text-xl font-semibold leading-7 text-gray-900 dark:text-white sm:truncate\">{title}</h2>\n <p className=\" text-sm font-normal text-gray-500 dark:text-gray-400\">{text}</p>\n </div>\n\n <div className=\"mt-1 flex flex-shrink-0 flex-col sm:mt-0 sm:flex-row sm:flex-wrap sm:space-x-6\">{children}</div>\n </div>\n </div>\n )\n}\n\nPageHeader.displayName = \"PageHeader\""]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/rich-text-editor/index.tsx","../src/rich-text-editor/headless-editor.ts"],"names":["CKEditor","useEffect","useState","FaBold","FaItalic","FaRemoveFormat","FaStrikethrough","FaUnderline","DecoupledEditorBase","Alignment","Autoformat","BlockQuote","Bold","Code","CodeBlock","Essentials","Heading","Image","ImageCaption","ImageResize","ImageStyle","ImageToolbar","Indent","IndentBlock","Italic","Link","List","ListProperties","Paragraph","PasteFromOffice","PictureEditing","RemoveFormat","Strikethrough","Table","TableToolbar","TextTransformation","Underline","HeadlessEditor","headless_editor_default","jsx","jsxs","RichTextEditor","props","editor","setEditor","e","selectedText","range","text","item","Toolbar","__spreadProps","__spreadValues","className","writer","root","additionalItems","EditorToolbarButton","commandName","commandValue","label","command","isOn","setIsOn","isEnabled","setIsEnabled","handleValueChange","handleIsEnabledChange","classNames","iconMap"],"mappings":"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","sourcesContent":["import { CKEditor } from \"@ckeditor/ckeditor5-react\";\nimport React, { useEffect, useState } from \"react\";\nimport {\n FaBold,\n FaItalic,\n FaRemoveFormat,\n FaStrikethrough,\n FaUnderline,\n} from \"react-icons/fa\";\nimport HeadlessEditor from \"./headless-editor\";\n\ntype AdditionalProps = {\n onDataChange?: (data: string) => void;\n selectedText?: string | null;\n onSelectedTextChange?: (text: string | null) => void;\n additionalToolbarItems?: React.ReactNode;\n};\n\nexport function RichTextEditor(\n props: Omit<CKEditor<HeadlessEditor>[\"props\"], \"editor\"> & AdditionalProps\n) {\n const [editor, setEditor] = useState<HeadlessEditor | null>(null);\n\n useEffect(() => {\n editor?.listenTo(editor?.model.document.selection, \"change:range\", (e) => {\n const selectedText = editor?.model.document.selection;\n const range = selectedText?.getFirstRange();\n if (range) {\n let text = \"\";\n for (const item of range.getItems()) {\n // @ts-ignore\n text += item.data;\n }\n if (props.onSelectedTextChange) {\n props.onSelectedTextChange(text);\n }\n }\n });\n\n editor?.model.document.on(\"change:data\", () => {\n if (props.onDataChange) {\n props.onDataChange(editor?.getData() || \"\");\n }\n });\n }, [editor, props.onDataChange, props.onSelectedTextChange]);\n\n return (\n <div className=\"mb-4 w-full rounded-lg border border-gray-200 bg-gray-50 dark:border-gray-600 dark:bg-gray-700\">\n <Toolbar editor={editor} additionalItems={props.additionalToolbarItems} />\n <CKEditor\n editor={HeadlessEditor}\n {...props}\n onReady={(editor) => {\n setEditor(editor);\n // @ts-ignore\n window.editor = editor;\n const className =\n \"px-4 py-2 bg-white rounded-b-lg dark:bg-gray-800 block w-full text-sm text-gray-800 bg-white border-0 dark:bg-gray-800 focus:ring-0 dark:text-white dark:placeholder-gray-400\";\n\n editor.editing.view.change((writer) => {\n const root = editor.editing.view.document.getRoot();\n if (root) {\n writer.removeClass(\n [\n \"ck-content\",\n \"ck-editor__editable\",\n \"ck-rounded-corners\",\n \"ck-editor__editable_inline\",\n ],\n root\n );\n writer.addClass(className, root);\n }\n });\n }}\n />\n </div>\n );\n}\n\nfunction Toolbar({\n editor,\n additionalItems,\n}: {\n editor: HeadlessEditor | null;\n additionalItems?: React.ReactNode;\n}) {\n return (\n <div className=\"flex items-center justify-between border-b px-3 py-2 dark:border-gray-600\">\n <div className=\"flex flex-wrap items-center divide-gray-200 dark:divide-gray-600 sm:divide-x\">\n <div className=\"flex items-center space-x-2 sm:pr-4\">\n {additionalItems}\n <EditorToolbarButton\n commandName=\"bold\"\n label=\"Bold\"\n editor={editor}\n />\n <EditorToolbarButton\n commandName=\"italic\"\n label=\"Italic\"\n editor={editor}\n />\n <EditorToolbarButton\n commandName=\"underline\"\n label=\"Underline\"\n editor={editor}\n />\n <EditorToolbarButton\n commandName=\"strikethrough\"\n label=\"Strikethrough\"\n editor={editor}\n />\n <EditorToolbarButton\n commandName=\"removeFormat\"\n label=\"Remove format\"\n editor={editor}\n />\n </div>\n </div>\n </div>\n );\n}\n\nfunction EditorToolbarButton({\n editor,\n commandName,\n commandValue = null,\n label,\n}: {\n editor: HeadlessEditor | null;\n commandName: keyof typeof iconMap;\n commandValue?: string | null;\n label: string;\n}) {\n const command = editor ? editor.commands.get(commandName) : null;\n const [isOn, setIsOn] = useState(false);\n const [isEnabled, setIsEnabled] = useState(true);\n\n useEffect(() => {\n if (!command) {\n return;\n }\n\n function handleValueChange() {\n if (typeof command?.value === \"boolean\") {\n setIsOn(!!command.value);\n } else {\n setIsOn(commandValue === command?.value);\n }\n }\n\n function handleIsEnabledChange() {\n setIsEnabled(command?.isEnabled || false);\n }\n\n command.on(\"change:value\", handleValueChange);\n command.on(\"change:isEnabled\", handleIsEnabledChange);\n\n handleValueChange();\n handleIsEnabledChange();\n\n return function cleanup() {\n command.off(\"change:value\", handleValueChange);\n command.off(\"change:isEnabled\", handleIsEnabledChange);\n };\n }, [command]);\n\n const classNames = [\"custom-editor-button\"];\n\n if (isEnabled) {\n classNames.push(\n isOn\n ? \"custom-editor-button--fill bg-gray-100 text-gray-900 dark:bg-gray-600 dark:text-white\"\n : \"\"\n );\n } else {\n classNames.push(\"custom-editor-button--disabled\");\n }\n\n classNames.push(\n \"mr-2 cursor-pointer rounded p-2 text-gray-500 hover:bg-gray-100 hover:text-gray-900 dark:text-gray-400 dark:hover:bg-gray-600 dark:hover:text-white\"\n );\n\n return (\n <div className=\"border-r\">\n <button\n className={classNames.join(\" \")}\n onClick={() => {\n if (!editor) {\n return;\n }\n if (commandValue) {\n editor.execute(commandName, { value: commandValue });\n } else {\n editor.execute(commandName);\n }\n\n editor.editing.view.focus();\n }}\n >\n <span className=\"sr-only\">{label}</span>\n {iconMap[commandName]}\n </button>\n </div>\n );\n}\n\n// Icon map to map from the command name to the icon\nconst iconMap = {\n bold: <FaBold />,\n italic: <FaItalic />,\n underline: <FaUnderline />,\n strikethrough: <FaStrikethrough />,\n removeFormat: <FaRemoveFormat />,\n};\n","// https://github.com/ckeditor/ckeditor5-demos/blob/master/headless/index.js\n\nimport DecoupledEditorBase from \"@ckeditor/ckeditor5-editor-decoupled/src/decouplededitor\";\n\nimport Alignment from \"@ckeditor/ckeditor5-alignment/src/alignment\";\nimport Autoformat from \"@ckeditor/ckeditor5-autoformat/src/autoformat\";\nimport BlockQuote from \"@ckeditor/ckeditor5-block-quote/src/blockquote\";\nimport Bold from \"@ckeditor/ckeditor5-basic-styles/src/bold\";\nimport Code from \"@ckeditor/ckeditor5-basic-styles/src/code\";\nimport CodeBlock from \"@ckeditor/ckeditor5-code-block/src/codeblock\";\nimport Essentials from \"@ckeditor/ckeditor5-essentials/src/essentials\";\nimport Heading from \"@ckeditor/ckeditor5-heading/src/heading\";\nimport Image from \"@ckeditor/ckeditor5-image/src/image\";\nimport ImageCaption from \"@ckeditor/ckeditor5-image/src/imagecaption\";\nimport ImageResize from \"@ckeditor/ckeditor5-image/src/imageresize\";\nimport ImageStyle from \"@ckeditor/ckeditor5-image/src/imagestyle\";\nimport ImageToolbar from \"@ckeditor/ckeditor5-image/src/imagetoolbar\";\nimport Indent from \"@ckeditor/ckeditor5-indent/src/indent\";\nimport IndentBlock from \"@ckeditor/ckeditor5-indent/src/indentblock\";\nimport Italic from \"@ckeditor/ckeditor5-basic-styles/src/italic\";\nimport Link from \"@ckeditor/ckeditor5-link/src/link\";\nimport List from \"@ckeditor/ckeditor5-list/src/list\";\nimport ListProperties from \"@ckeditor/ckeditor5-list/src/listproperties\";\nimport Paragraph from \"@ckeditor/ckeditor5-paragraph/src/paragraph\";\nimport PasteFromOffice from \"@ckeditor/ckeditor5-paste-from-office/src/pastefromoffice\";\nimport PictureEditing from \"@ckeditor/ckeditor5-image/src/pictureediting\";\nimport RemoveFormat from \"@ckeditor/ckeditor5-remove-format/src/removeformat\";\nimport Strikethrough from \"@ckeditor/ckeditor5-basic-styles/src/strikethrough\";\nimport Table from \"@ckeditor/ckeditor5-table/src/table\";\nimport TableToolbar from \"@ckeditor/ckeditor5-table/src/tabletoolbar\";\nimport TextTransformation from \"@ckeditor/ckeditor5-typing/src/texttransformation\";\nimport Underline from \"@ckeditor/ckeditor5-basic-styles/src/underline\";\n\nclass HeadlessEditor extends DecoupledEditorBase {}\n\nHeadlessEditor.builtinPlugins = [\n Alignment,\n Autoformat,\n BlockQuote,\n Bold,\n Code,\n CodeBlock,\n Essentials,\n Heading,\n Image,\n ImageCaption,\n ImageResize,\n ImageStyle,\n ImageToolbar,\n Indent,\n IndentBlock,\n Italic,\n Link,\n List,\n ListProperties,\n Paragraph,\n PasteFromOffice,\n PictureEditing,\n RemoveFormat,\n Strikethrough,\n Table,\n TableToolbar,\n TextTransformation,\n Underline,\n];\n\n// Editor configuration.\nHeadlessEditor.defaultConfig = {\n // TODO: Figure out why typescript doesn't like these properties.\n // @ts-ignore\n codeBlock: {\n languages: [\n { language: \"css\", label: \"CSS\" },\n { language: \"html\", label: \"HTML\" },\n { language: \"javascript\", label: \"JavaScript\" },\n { language: \"php\", label: \"PHP\" },\n ],\n },\n image: {\n resizeUnit: \"px\",\n toolbar: [\n \"imageStyle:inline\",\n \"imageStyle:wrapText\",\n \"imageStyle:breakText\",\n \"|\",\n \"toggleImageCaption\",\n \"imageTextAlternative\",\n ],\n },\n table: {\n contentToolbar: [\"tableColumn\", \"tableRow\", \"mergeTableCells\"],\n },\n language: \"en\",\n};\n\nexport default HeadlessEditor;\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/search/search.tsx"],"names":["import_prop_types","useState","useRef","useCallback","useEffect","forwardRef","useImperativeHandle","Fragment","jsx","jsxs","useDebounceEffect","effect","delay","deps","instanceRef","handlerRef","callback","Search","id","categories","placeholder","disabled","initialValue","reference","state","setState","currentSearchValue","setCurrentSearchValue","hidden","setHidden","__spreadProps","__spreadValues","handleSearchChange","handleTypeChange","selection","handleKeyDown","ref","handleClickOutside","e","renderDropdown","x","PropTypes"],"mappings":"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","sourcesContent":["//@ts-nocheck\nimport {\n useState,\n useRef,\n useCallback,\n useEffect,\n forwardRef,\n useImperativeHandle,\n} from \"react\";\nimport PropTypes from \"prop-types\";\n\nfunction useDebounceEffect(effect, delay, deps) {\n const instanceRef = useRef(0);\n const handlerRef = useRef(null);\n const callback = useCallback(effect, deps);\n\n useEffect(() => {\n if (instanceRef.current === 0) {\n instanceRef.current = 1;\n } else {\n handlerRef.current = setTimeout(() => {\n callback();\n }, delay);\n }\n return () => {\n clearTimeout(handlerRef.current);\n };\n }, [callback, delay]);\n}\n\nexport const Search = forwardRef(function Search(\n {\n id,\n categories = [],\n delay = 1500,\n placeholder = \"Enter a keyword to search...\",\n callback,\n disabled = false,\n initialValue = \"\",\n },\n reference\n) {\n // Create state based on config\n const [state, setState] = useState({\n text: null,\n category: categories?.length > 0 ? categories[0] : null,\n });\n const [currentSearchValue, setCurrentSearchValue] = useState(initialValue);\n const [hidden, setHidden] = useState(true);\n\n useImperativeHandle(reference, () => ({\n clear: () => {\n setCurrentSearchValue(\"\");\n setState({ ...state, text: \"\" });\n },\n removeFocus: () => {\n document.getElementById(`${id}-search-input`).blur();\n },\n }));\n\n const handleSearchChange = (e) => {\n setCurrentSearchValue(e.target.value);\n setState({ ...state, text: e.target.value });\n };\n\n const handleTypeChange = (e, selection) => {\n e.preventDefault();\n setState({ ...state, category: selection });\n setHidden(true);\n };\n\n const handleKeyDown = (e) => {\n if ((e.charCode || e.keyCode) === 13) {\n e.preventDefault();\n }\n };\n\n useDebounceEffect(\n () => {\n callback(state);\n },\n delay,\n [state.text, state.category]\n );\n useEffect(() => {\n if (initialValue !== currentSearchValue)\n setCurrentSearchValue(initialValue);\n }, [initialValue]);\n\n const ref = useRef(null);\n useEffect(() => {\n const handleClickOutside = (e) => {\n if (ref.current && !ref.current.contains(e.target)) {\n setHidden(true);\n }\n };\n\n document.addEventListener(\"click\", handleClickOutside, true);\n return () => {\n document.removeEventListener(\"click\", handleClickOutside, true);\n };\n }, []);\n\n const renderDropdown = () => (\n <>\n <button\n id={`${id}-dropdown-button`}\n data-dropdown-toggle=\"dropdown\"\n className=\"absolute right-0 top-0 z-10 inline-flex flex-shrink-0 items-center rounded-r-lg border border-gray-300 bg-white p-2.5 px-4 py-2.5 text-center text-sm font-medium text-gray-900 hover:bg-gray-200 focus:outline-none focus:ring-4 focus:ring-gray-300 dark:border-gray-700 dark:bg-gray-600 dark:text-white dark:hover:bg-gray-700 dark:focus:ring-gray-800\"\n type=\"button\"\n onClick={() => setHidden(!hidden)}\n >\n {state.category.display}\n <svg\n className=\"ml-2.5 h-2.5 w-2.5\"\n aria-hidden=\"true\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 10 6\"\n >\n <path\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n d=\"m1 1 4 4 4-4\"\n />\n </svg>\n </button>\n <div\n id={`${id}-dropdown`}\n ref={ref}\n className={`z-10 ${\n hidden ? \"hidden\" : \"\"\n } absolute right-0 w-44 divide-y divide-gray-100 rounded-r-lg bg-white shadow dark:bg-gray-700`}\n >\n <ul\n className=\"py-2 text-sm text-gray-700 dark:text-gray-200\"\n aria-labelledby=\"dropdown-button\"\n >\n {(categories || []).map((x) => {\n return (\n <li key={`gst-${x.display}`}>\n <a\n href=\"#\"\n className=\"block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white\"\n onClick={(e) => handleTypeChange(e, x)}\n >\n {x.display}\n </a>\n </li>\n );\n })}\n </ul>\n </div>\n </>\n );\n\n return (\n <div className=\"flex\">\n <div className=\"relative w-full\">\n <input\n ref={reference}\n placeholder={placeholder}\n value={currentSearchValue}\n aria-label=\"search\"\n aria-describedby=\"Search\"\n onChange={handleSearchChange}\n onKeyDown={handleKeyDown}\n disabled={disabled}\n id={`${id}-search-input`}\n className=\"block w-full rounded-lg border border-r-2 border-gray-300 border-r-gray-300 bg-gray-50 p-2.5 text-sm text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:border-blue-500\"\n />\n {categories?.length > 0 && renderDropdown()}\n </div>\n </div>\n );\n});\n\nSearch.propTypes = {\n /** Optional List of categories that the search term can be applied to. If supplied\n * the categories appear on the far right of the search input in a drop down list, otherwise it is hidden.\n */\n categories: PropTypes.arrayOf(\n PropTypes.shape({\n /**\n * The text shown to the user in the dropdown.\n */\n display: PropTypes.string.isRequired,\n /**\n * The value set when the item is selected.\n */\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number])\n .isRequired,\n })\n ),\n /**\n * The delay between requests made to the server when typing in milliseconds.\n */\n delay: PropTypes.number,\n /**\n * Optional placeholder for the search field.\n */\n placeholder: PropTypes.string,\n /**\n * Callback with the search object for use in the application the format is:\n * { text: '', category: {display:\"\", value:\"\"} }. Note: category is null if no options are provided.\n */\n callback: PropTypes.func.isRequired,\n /**\n * If set to true, the text in the search box cannot be changed\n */\n disabled: PropTypes.bool,\n /**\n * If set, will be the value in the search bar when it first loads.\n * If not set, the search bar will just be empty.\n */\n initialValue: PropTypes.string,\n};\n\nSearch.displayName = \"Search\";\n"]}
|
package/dist/chunk-REFCK56T.mjs
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { a } from './chunk-PUJZGK7Y.mjs';
|
|
2
|
-
import { e as e$1, b, a as a$1 } from './chunk-23SJGKDR.mjs';
|
|
3
|
-
import { variantProps } from 'classname-variants/react';
|
|
4
|
-
import { createContext, useState, useEffect, useContext } from 'react';
|
|
5
|
-
import { BiChevronDown } from 'react-icons/bi';
|
|
6
|
-
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
7
|
-
|
|
8
|
-
var e=e$1(a());var y=createContext(),P=variantProps({base:"focus:ring-4 focus:outline-none focus:ring-blue-300 font-medium text-sm py-2.5 text-center inline-flex items-center dark:text-white",variants:{color:{blue:"text-white bg-blue-700 hover:bg-blue-800 dark:bg-blue-600 dark:hover:bg-blue-700 focus:ring-blue-300",gray:"text-white bg-gray-400 hover:bg-gray-600 dark:bg-gray-600 dark:hover:bg-gray-700 focus:ring-gray-300",lightGray:"text-slate-700 bg-white focus:ring-slate-300 border border-gray-300 dark:bg-gray-700 dark:border-gray-600 focus:ring-blue-300",green:"text-white bg-green-700 hover:bg-green-800 dark:bg-green-600 dark:hover:bg-green-700 focus:ring-green-300",red:"text-white bg-red-700 hover:bg-red-800 dark:bg-red-600 dark:hover:bg-red-700 focus:ring-red-300",yellow:"text-white bg-yellow-700 hover:bg-yellow-800 dark:bg-yellow-600 dark:hover:bg-yellow-700 focus:ring-yellow-300"},size:{sm:"px-5 py-1.5",md:"px-5 py-2.5",lg:"px-5 py-3.5",rsm:"px-2.5 py-2.5",rmd:"px-3.5 py-3.5",rlg:"px-4.5 py-4.5"},type:{rect:"rounded-lg",round:"rounded-full"},defaultVariants:{color:"blue",size:"md",type:"rect"}}}),t=Object.freeze({OPEN:"open",CLOSED:"closed"});function n({id:o,label:a,type:d,color:p,size:m,children:h}){let[i,l]=useState(t.CLOSED),v=()=>{l(i===t.CLOSED?t.OPEN:t.CLOSED);};return useEffect(()=>{let s=f=>{f.target.id!==o&&l(t.CLOSED);};return document.addEventListener("click",s),()=>{document.removeEventListener("click",s);}},[]),jsx("div",{className:"relative",children:jsxs(y.Provider,{value:{showDropdown:i,setShowDropdown:l},children:[jsxs("button",b(a$1({id:o},P({color:p,size:m,type:d})),{"data-dropdown-toggle":`${o}-dropdown`,type:"button",onClick:v,children:[a,d==="rect"&&jsx(BiChevronDown,{className:"pointer-events-none"})]})),jsx("div",{id:`${o}-dropdown`,className:`z-50 mt-2 absolute ${i===t.OPEN?"":"hidden"} bg-white divide-y divide-gray-100 rounded-lg shadow w-44 dark:bg-gray-700`,children:jsx("ul",{className:"py-2 text-sm text-gray-700 dark:text-gray-200","aria-labelledby":"dropdownDefaultButton",children:h})})]})})}function w(){return jsx("li",{children:jsx("hr",{className:"h-px my-2 bg-gray-200 border-0 dark:bg-gray-700"})})}function g({callback:o,children:a}){let d=useContext(y);return jsx("li",{children:jsx("div",{className:"block px-4 py-2 cursor-pointer hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white",onClick:()=>{d.setShowDropdown(!1),o();},children:a})})}n.Divider=w;n.Item=g;n.propTypes={id:e.default.string.isRequired,children:e.default.node.isRequired,type:e.default.oneOf(["rect","round"]),size:e.default.oneOf(["sm","md","lg","rsm","rmd","rlg"]),color:e.default.oneOf(["blue","gray","lightGray","green","red","yellow"]),label:e.default.oneOfType([e.default.string,e.default.node]).isRequired};n.defaultProps={type:"rect",size:"md",color:"blue",label:"Dropdown"};g.propTypes={callback:e.default.func.isRequired};n.displayName="Dropdown";w.displayName="Dropdown.Divider";g.displayName="Dropdown.Item";
|
|
9
|
-
|
|
10
|
-
export { n as a, w as b, g as c };
|
|
11
|
-
//# sourceMappingURL=out.js.map
|
|
12
|
-
//# sourceMappingURL=chunk-REFCK56T.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/dropdown.tsx"],"names":["import_prop_types","variantProps","useState","createContext","useContext","useEffect","BiChevronDown","jsx","jsxs","DropdownContext","buttonProps","DropdownState","Dropdown","id","label","type","color","size","children","showDropdown","setShowDropdown","handleShowDropdown","handleClickOutside","e","__spreadProps","__spreadValues","DropdownDivider","DropdownItem","callback","context","PropTypes"],"mappings":"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","sourcesContent":["//@ts-nocheck\nimport { variantProps } from 'classname-variants/react'\nimport { useState, createContext, useContext, useEffect, useRef } from 'react'\nimport { BiChevronDown } from 'react-icons/bi'\nimport PropTypes from 'prop-types'\nconst DropdownContext = createContext()\n\n// BUTTON CLASSES\nconst buttonProps = variantProps({\n base: 'focus:ring-4 focus:outline-none focus:ring-blue-300 font-medium text-sm py-2.5 text-center inline-flex items-center dark:text-white',\n variants: {\n color: {\n blue: 'text-white bg-blue-700 hover:bg-blue-800 dark:bg-blue-600 dark:hover:bg-blue-700 focus:ring-blue-300',\n gray: 'text-white bg-gray-400 hover:bg-gray-600 dark:bg-gray-600 dark:hover:bg-gray-700 focus:ring-gray-300',\n lightGray:\n 'text-slate-700 bg-white focus:ring-slate-300 border border-gray-300 dark:bg-gray-700 dark:border-gray-600 focus:ring-blue-300',\n green: 'text-white bg-green-700 hover:bg-green-800 dark:bg-green-600 dark:hover:bg-green-700 focus:ring-green-300',\n red: 'text-white bg-red-700 hover:bg-red-800 dark:bg-red-600 dark:hover:bg-red-700 focus:ring-red-300',\n yellow: 'text-white bg-yellow-700 hover:bg-yellow-800 dark:bg-yellow-600 dark:hover:bg-yellow-700 focus:ring-yellow-300',\n },\n size: {\n sm: 'px-5 py-1.5',\n md: 'px-5 py-2.5',\n lg: 'px-5 py-3.5',\n // WORKAROUND: Compound variants don't work with classname-variants/react (revisit later)\n rsm: 'px-2.5 py-2.5',\n rmd: 'px-3.5 py-3.5',\n rlg: 'px-4.5 py-4.5',\n },\n type: {\n rect: 'rounded-lg',\n round: 'rounded-full',\n },\n defaultVariants: {\n color: 'blue',\n size: 'md',\n type: 'rect',\n },\n },\n})\n\nconst DropdownState = Object.freeze({\n OPEN: 'open',\n CLOSED: 'closed',\n})\n\nexport function Dropdown({ id, label, type, color, size, children }) {\n const [showDropdown, setShowDropdown] = useState(DropdownState.CLOSED)\n const handleShowDropdown = () => {\n const currState = showDropdown\n setShowDropdown(currState === DropdownState.CLOSED ? DropdownState.OPEN : DropdownState.CLOSED)\n }\n\n useEffect(() => {\n const handleClickOutside = (e) => {\n if (e.target.id === id) return\n setShowDropdown(DropdownState.CLOSED)\n }\n\n document.addEventListener('click', handleClickOutside)\n\n return () => {\n document.removeEventListener('click', handleClickOutside)\n }\n }, [])\n\n return (\n <div className=\"relative\">\n <DropdownContext.Provider value={{ showDropdown, setShowDropdown }}>\n <button id={id} {...buttonProps({ color, size, type })} data-dropdown-toggle={`${id}-dropdown`} type=\"button\" onClick={handleShowDropdown}>\n {label}\n {type === 'rect' && <BiChevronDown className=\"pointer-events-none\" />}\n </button>\n <div\n id={`${id}-dropdown`}\n className={`z-50 mt-2 absolute ${\n showDropdown === DropdownState.OPEN ? '' : 'hidden'\n } bg-white divide-y divide-gray-100 rounded-lg shadow w-44 dark:bg-gray-700`}\n >\n <ul className=\"py-2 text-sm text-gray-700 dark:text-gray-200\" aria-labelledby=\"dropdownDefaultButton\">\n {children}\n </ul>\n </div>\n </DropdownContext.Provider>\n </div>\n )\n}\n\nexport function DropdownDivider() {\n return (\n <li>\n <hr className=\"h-px my-2 bg-gray-200 border-0 dark:bg-gray-700\" />\n </li>\n )\n}\n\nexport function DropdownItem({ callback, children }) {\n const context = useContext(DropdownContext)\n\n const handleSelection = () => {\n context.setShowDropdown(false)\n callback()\n }\n return (\n <li>\n <div className=\"block px-4 py-2 cursor-pointer hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white\" onClick={handleSelection}>\n {children}\n </div>\n </li>\n )\n}\n\nDropdown.Divider = DropdownDivider\nDropdown.Item = DropdownItem\n\nDropdown.propTypes = {\n /** Unique id for the dropdown */\n id: PropTypes.string.isRequired,\n /** Components to be rendered as Part of the Compound Component*/\n children: PropTypes.node.isRequired,\n /** Shape of the button rectangle or round */\n type: PropTypes.oneOf(['rect', 'round']),\n /** Size of the button sm,md,lg used for rectangle and rsm, rmd, rlg used for a round button */\n size: PropTypes.oneOf(['sm', 'md', 'lg', 'rsm', 'rmd', 'rlg']),\n /** Colour of the button based upon predefined values */\n color: PropTypes.oneOf(['blue', 'gray', 'lightGray', 'green', 'red', 'yellow']),\n /** Rectangle should have a text label eg:'Dropdown' and a round type should take an icon element eg:'...' */\n label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n}\nDropdown.defaultProps = {\n type: 'rect',\n size: 'md',\n color: 'blue',\n label: 'Dropdown',\n}\nDropdownItem.propTypes = {\n /** Returns value of the dropdown item selected*/\n callback: PropTypes.func.isRequired,\n}\n\nDropdown.displayName = 'Dropdown'\nDropdownDivider.displayName = 'Dropdown.Divider'\nDropdownItem.displayName = 'Dropdown.Item'\n"]}
|
package/dist/chunk-VPLCWU7T.mjs
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import i from 'clsx';
|
|
2
|
-
import { useMemo } from 'react';
|
|
3
|
-
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
4
|
-
|
|
5
|
-
function y(o,l=0){return [...Array(o).keys()].map(r=>r+l)}function k({pageSize:o,total:l,current:r,onChange:d,loading:h}){let b=Math.min((r-1)*o+1,l),p=Math.min(b+o-1,l),a=Math.ceil(l/o),v=useMemo(()=>a>5&&r>=4,[a,r]),x=useMemo(()=>a>5&&r<a-3,[a,r]),n=[];return a<=5?n=y(a,1):x?n=y(5,Math.max(r-2,1)):n=y(5,a-4),jsx("div",{className:"w-full",children:jsx("div",{className:"relative overflow-hidden rounded-b-lg bg-white dark:bg-gray-800",children:jsxs("nav",{className:" flex flex-wrap items-start justify-between gap-x-4 gap-y-2 md:items-center","aria-label":"Table navigation",children:[jsxs("div",{className:"flex w-full justify-between md:hidden",children:[jsxs("button",{disabled:r===1,className:i(r===1&&"cursor-not-allowed","ml-0 flex h-full items-center justify-center rounded-lg border border-gray-300 bg-white px-3 py-1.5 text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"),onClick:()=>d(r-1,o),children:[jsx("svg",{className:"h-5 w-5","aria-hidden":"true",fill:"currentColor",viewBox:"0 0 20 20",xmlns:"http://www.w3.org/2000/svg",children:jsx("path",{fillRule:"evenodd",d:"M12.707 5.293a1 1 0 010 1.414L9.414 10l3.293 3.293a1 1 0 01-1.414 1.414l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 0z",clipRule:"evenodd"})}),jsx("span",{className:"leading-none",children:"Previous"})]}),jsxs("button",{disabled:r===a,className:i(r===a&&"cursor-not-allowed","flex h-full items-center justify-center rounded-lg border border-gray-300 bg-white px-3 py-1.5 leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"),children:[jsx("span",{children:"Next"}),jsx("svg",{className:"h-5 w-5","aria-hidden":"true",fill:"currentColor",viewBox:"0 0 20 20",xmlns:"http://www.w3.org/2000/svg",children:jsx("path",{fillRule:"evenodd",d:"M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z",clipRule:"evenodd"})})]})]}),jsxs("div",{className:"hidden items-center space-x-3 md:flex",children:[jsx("label",{htmlFor:"rows",className:"text-sm font-normal text-gray-500 dark:text-gray-400",children:"Rows per page"}),jsxs("select",{id:"rows",className:"block rounded-lg border border-gray-300 bg-gray-50 py-1.5 pl-3.5 pr-6 text-sm text-gray-900 focus:border-primary-500 focus:ring-primary-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:border-primary-500 dark:focus:ring-primary-500",onChange:s=>d(1,Number(s.target.value)),value:o,children:[jsx("option",{value:10,children:"10"}),jsx("option",{value:25,children:"25"}),jsx("option",{value:50,children:"50"}),jsx("option",{value:100,children:"100"})]}),jsx("span",{className:"pt-1 text-sm font-normal text-gray-500 dark:text-gray-400",children:!h&&jsxs(Fragment,{children:[jsxs("span",{className:"font-semibold text-gray-900 dark:text-white",children:["Showing ",jsx(Fragment,{children:l===0?0:b})," to ",jsx(Fragment,{children:p})]})," ","of"," ",jsx("span",{className:"font-semibold text-gray-900 dark:text-white",children:l})]})})]}),jsxs("ul",{className:"hidden items-stretch -space-x-px md:inline-flex",children:[jsx("li",{children:jsxs("button",{disabled:r===1,className:i(r===1&&"cursor-not-allowed","ml-0 flex h-full items-center justify-center rounded-l-lg border border-gray-300 bg-white px-3 py-1.5 text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"),onClick:()=>d(r-1,o),children:[jsx("span",{className:"sr-only",children:"Previous"}),jsx("svg",{className:"h-5 w-5","aria-hidden":"true",fill:"currentColor",viewBox:"0 0 20 20",xmlns:"http://www.w3.org/2000/svg",children:jsx("path",{fillRule:"evenodd",d:"M12.707 5.293a1 1 0 010 1.414L9.414 10l3.293 3.293a1 1 0 01-1.414 1.414l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 0z",clipRule:"evenodd"})})]})}),v&&jsxs(Fragment,{children:[jsx("li",{children:jsx("button",{className:i(r===1&&"cursor-not-allowed","flex items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"),onClick:()=>d(1,o),children:"1"})}),jsx("li",{className:"flex cursor-default items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400",children:"..."})]}),n.map(s=>jsx("li",{children:jsx("button",{onClick:()=>d(s,o),className:i("flex items-center justify-center border px-3 py-2 text-sm leading-tight",s===r?"z-10 border-primary-300 bg-primary-50 text-primary-600 hover:bg-primary-100 hover:text-primary-700 dark:border-gray-700 dark:bg-gray-700 dark:text-white":"border-gray-300 bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"),children:s})},s)),x&&jsxs(Fragment,{children:[jsx("li",{className:"flex cursor-default items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400",children:"..."}),jsx("li",{children:jsx("button",{className:"flex items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white",onClick:()=>d(a,o),children:a})})]}),jsx("li",{children:jsxs("button",{disabled:r===a,onClick:()=>d(r+1,o),className:i(r===a&&"cursor-not-allowed","flex h-full items-center justify-center rounded-r-lg border border-gray-300 bg-white px-3 py-1.5 leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"),children:[jsx("span",{className:"sr-only",children:"Next"}),jsx("svg",{className:"h-5 w-5","aria-hidden":"true",fill:"currentColor",viewBox:"0 0 20 20",xmlns:"http://www.w3.org/2000/svg",children:jsx("path",{fillRule:"evenodd",d:"M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z",clipRule:"evenodd"})})]})})]})]})})})}
|
|
6
|
-
|
|
7
|
-
export { k as a };
|
|
8
|
-
//# sourceMappingURL=out.js.map
|
|
9
|
-
//# sourceMappingURL=chunk-VPLCWU7T.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/pagination/pagination.tsx"],"names":["clsx","useMemo","Fragment","jsx","jsxs","range","size","startAt","i","Pagination","pageSize","total","current","onChange","loading","from","to","totalPages","showJumpPrev","showJumpNext","pages","e","page"],"mappings":"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","sourcesContent":["import clsx from \"clsx\";\nimport { useMemo } from \"react\";\n\n\nexport type PaginationProps = {\n pageSize: number;\n total: number;\n current: number;\n onChange: (page: number, pageSize: number) => void;\n loading?: boolean;\n};\n\nfunction range(size: number, startAt = 0): number[] {\n return [...Array(size).keys()].map((i) => i + startAt);\n}\n\nexport function Pagination({\n pageSize,\n total,\n current,\n onChange,\n loading,\n}: PaginationProps) {\n // Calculate the values that are displayed\n const from = Math.min((current - 1) * pageSize + 1, total);\n const to = Math.min(from + pageSize - 1, total);\n const totalPages = Math.ceil(total / pageSize);\n\n const showJumpPrev = useMemo(() => {\n return totalPages > 5 && current >= 4;\n }, [totalPages, current]);\n\n const showJumpNext = useMemo(() => {\n return totalPages > 5 && current < totalPages - 3;\n }, [totalPages, current]);\n\n let pages: number[] = [];\n\n if (totalPages <= 5) {\n pages = range(totalPages, 1);\n } else if (showJumpNext) {\n pages = range(5, Math.max(current - 2, 1));\n } else {\n pages = range(5, totalPages - 4);\n }\n\n return (\n <div className=\"w-full\">\n <div className=\"relative overflow-hidden rounded-b-lg bg-white dark:bg-gray-800\">\n <nav\n className=\" flex flex-wrap items-start justify-between gap-x-4 gap-y-2 md:items-center\"\n aria-label=\"Table navigation\"\n >\n <div className=\"flex w-full justify-between md:hidden\">\n <button\n disabled={current === 1}\n className={clsx(\n current === 1 && \"cursor-not-allowed\",\n \"ml-0 flex h-full items-center justify-center rounded-lg border border-gray-300 bg-white px-3 py-1.5 text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n )}\n onClick={() => onChange(current - 1, pageSize)}\n >\n <svg\n className=\"h-5 w-5\"\n aria-hidden=\"true\"\n fill=\"currentColor\"\n viewBox=\"0 0 20 20\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M12.707 5.293a1 1 0 010 1.414L9.414 10l3.293 3.293a1 1 0 01-1.414 1.414l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 0z\"\n clipRule=\"evenodd\"\n ></path>\n </svg>\n <span className=\"leading-none\">Previous</span>\n </button>\n\n <button\n disabled={current === totalPages}\n className={clsx(\n current === totalPages && \"cursor-not-allowed\",\n \"flex h-full items-center justify-center rounded-lg border border-gray-300 bg-white px-3 py-1.5 leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n )}\n >\n <span>Next</span>\n <svg\n className=\"h-5 w-5\"\n aria-hidden=\"true\"\n fill=\"currentColor\"\n viewBox=\"0 0 20 20\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z\"\n clipRule=\"evenodd\"\n ></path>\n </svg>\n </button>\n </div>\n <div className=\"hidden items-center space-x-3 md:flex\">\n <label\n htmlFor=\"rows\"\n className=\"text-sm font-normal text-gray-500 dark:text-gray-400\"\n >\n Rows per page\n </label>\n <select\n id=\"rows\"\n className=\"block rounded-lg border border-gray-300 bg-gray-50 py-1.5 pl-3.5 pr-6 text-sm text-gray-900 focus:border-primary-500 focus:ring-primary-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:border-primary-500 dark:focus:ring-primary-500\"\n onChange={(e) => onChange(1, Number(e.target.value))}\n value={pageSize}\n >\n <option value={10}>10</option>\n <option value={25}>25</option>\n <option value={50}>50</option>\n <option value={100}>100</option>\n </select>\n <span className=\"pt-1 text-sm font-normal text-gray-500 dark:text-gray-400\">\n {!loading && (\n <>\n <span className=\"font-semibold text-gray-900 dark:text-white\">\n Showing <>{total === 0 ? 0 : from}</> to <>{to}</>\n </span>{\" \"}\n of{\" \"}\n <span className=\"font-semibold text-gray-900 dark:text-white\">\n {total}\n </span>\n </>\n )}\n </span>\n </div>\n <ul className=\"hidden items-stretch -space-x-px md:inline-flex\">\n <li>\n <button\n disabled={current === 1}\n className={clsx(\n current === 1 && \"cursor-not-allowed\",\n \"ml-0 flex h-full items-center justify-center rounded-l-lg border border-gray-300 bg-white px-3 py-1.5 text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n )}\n onClick={() => onChange(current - 1, pageSize)}\n >\n <span className=\"sr-only\">Previous</span>\n <svg\n className=\"h-5 w-5\"\n aria-hidden=\"true\"\n fill=\"currentColor\"\n viewBox=\"0 0 20 20\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M12.707 5.293a1 1 0 010 1.414L9.414 10l3.293 3.293a1 1 0 01-1.414 1.414l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 0z\"\n clipRule=\"evenodd\"\n ></path>\n </svg>\n </button>\n </li>\n {showJumpPrev && (\n <>\n <li>\n <button\n className={clsx(\n current === 1 && \"cursor-not-allowed\",\n \"flex items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n )}\n onClick={() => onChange(1, pageSize)}\n >\n 1\n </button>\n </li>\n <li className=\"flex cursor-default items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400\">\n ...\n </li>\n </>\n )}\n {pages.map((page) => (\n <li key={page}>\n <button\n onClick={() => onChange(page, pageSize)}\n className={clsx(\n \"flex items-center justify-center border px-3 py-2 text-sm leading-tight\",\n page === current\n ? \"z-10 border-primary-300 bg-primary-50 text-primary-600 hover:bg-primary-100 hover:text-primary-700 dark:border-gray-700 dark:bg-gray-700 dark:text-white\"\n : \"border-gray-300 bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n )}\n >\n {page}\n </button>\n </li>\n ))}\n {showJumpNext && (\n <>\n <li className=\"flex cursor-default items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400\">\n ...\n </li>\n <li>\n <button\n className=\"flex items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n onClick={() => onChange(totalPages, pageSize)}\n >\n {totalPages}\n </button>\n </li>\n </>\n )}\n <li>\n <button\n disabled={current === totalPages}\n onClick={() => onChange(current + 1, pageSize)}\n className={clsx(\n current === totalPages && \"cursor-not-allowed\",\n \"flex h-full items-center justify-center rounded-r-lg border border-gray-300 bg-white px-3 py-1.5 leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white\"\n )}\n >\n <span className=\"sr-only\">Next</span>\n <svg\n className=\"h-5 w-5\"\n aria-hidden=\"true\"\n fill=\"currentColor\"\n viewBox=\"0 0 20 20\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z\"\n clipRule=\"evenodd\"\n ></path>\n </svg>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n </div>\n );\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/drawer.tsx"],"names":["useEffect","useCallback","useState","FBDrawer","HiXMark","jsx","jsxs","Drawer","show","onClose","children","title","drawer","setDrawer","drawerCallback","node","element","options"],"mappings":"AAEA,OAAS,aAAAA,EAAW,eAAAC,EAAa,YAAAC,MAAgB,QAEjD,OAAS,UAAUC,MAAgB,WACnC,OAAS,WAAAC,MAAe,kBAkDhB,cAAAC,EAMA,QAAAC,MANA,oBAzCD,SAASC,EAAO,CAAE,KAAAC,EAAM,QAAAC,EAAS,SAAAC,EAAU,MAAAC,CAAM,EAAU,CAChE,GAAM,CAACC,EAAQC,CAAS,EAAIX,EAA0B,EAChDY,EAAiBb,EAAac,GAAc,CAChD,GAAIA,IAAS,KAAM,CACjB,IAAIC,EAAUD,EACd,IAAME,EAAyB,CAC7B,UAAW,QACX,SAAU,GACV,cAAe,GACf,KAAM,GACN,WAAY,GACZ,gBACE,kEACF,OAAQR,CACV,EACMG,EAAS,IAAIT,EAASa,EAASC,CAAO,EAC5C,OAAAJ,EAAUD,CAAM,EACTA,EAEX,EAAG,CAAC,CAAC,EAEL,OAAAZ,EAAU,IAAM,CACTY,IAGDJ,EACFI,EAAO,KAAK,EAEZA,EAAO,KAAK,EAEhB,EAAG,CAACJ,EAAMI,CAAM,CAAC,EAGfN,EAAC,OACC,IAAKQ,EACL,GAAG,gBACH,UAAU,qJACV,SAAU,GACV,kBAAgB,qBAEhB,UAAAR,EAAC,OAAI,UAAU,2BACb,UAAAD,EAAC,MACC,GAAG,kBACH,UAAU,6IAET,SAAAM,EACH,EACAL,EAAC,UACC,QAASG,EACT,GAAG,qBACH,KAAK,SACL,gBAAc,iBACd,UAAU,+LAEV,UAAAJ,EAACD,EAAA,CAAQ,UAAU,aAAa,EAChCC,EAAC,QAAK,UAAU,UAAU,sBAAU,GACtC,GACF,EACAA,EAAC,OAAI,UAAU,iCAAkC,SAAAK,EAAS,GAC5D,CAEJ,CAEAH,EAAO,YAAc","sourcesContent":["// THIS DRAWER IS FROM THE FLOWBITE LIBRARY PAGE\n\nimport { useEffect, useCallback, useState } from \"react\";\nimport type { DrawerInterface, DrawerOptions } from \"flowbite\";\nimport { Drawer as FBDrawer } from \"flowbite\";\nimport { HiXMark } from \"react-icons/hi2\";\n\ntype Props = {\n show: boolean;\n onClose: () => void;\n children: JSX.Element;\n title: string;\n};\n\nexport function Drawer({ show, onClose, children, title }: Props) {\n const [drawer, setDrawer] = useState<DrawerInterface>();\n const drawerCallback = useCallback((node: any) => {\n if (node !== null) {\n var element = node;\n const options: DrawerOptions = {\n placement: \"right\",\n backdrop: true,\n bodyScrolling: false,\n edge: false,\n edgeOffset: \"\",\n backdropClasses:\n \"bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30\",\n onHide: onClose,\n };\n const drawer = new FBDrawer(element, options);\n setDrawer(drawer);\n return drawer;\n }\n }, []);\n\n useEffect(() => {\n if (!drawer) {\n return;\n }\n if (show) {\n drawer.show();\n } else {\n drawer.hide();\n }\n }, [show, drawer]);\n\n return (\n <div\n ref={drawerCallback}\n id=\"EKM-ui-drawer\"\n className=\"fixed right-0 top-0 z-40 h-screen w-[90%] translate-x-full overflow-y-auto bg-white transition-transform dark:bg-gray-800 sm:max-w-lg md:w-[500px]\"\n tabIndex={-1}\n aria-labelledby=\"drawer-right-label\"\n >\n <div className=\"absolute w-full bg-white\">\n <h5\n id=\"drawer-js-label\"\n className=\"inline-flex w-full items-center border-b-2 p-4\t text-lg font-semibold text-gray-900 dark:border-gray-900 dark:bg-gray-900 dark:text-white\"\n >\n {title}\n </h5>\n <button\n onClick={onClose}\n id=\"drawer-hide-button\"\n type=\"button\"\n aria-controls=\"drawer-example\"\n className=\"absolute right-2.5 top-2.5 inline-flex items-center rounded-lg bg-transparent p-1.5 text-sm text-gray-400 hover:bg-gray-200 hover:text-gray-900 dark:hover:bg-gray-600 dark:hover:text-white\"\n >\n <HiXMark className=\"h-auto w-6\" />\n <span className=\"sr-only\">Close menu</span>\n </button>\n </div>\n <div className=\"flex h-full flex-col p-4 pt-20\">{children}</div>\n </div>\n );\n}\n\nDrawer.displayName = \"Drawer\"\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/mini-feature-block.tsx"],"names":["jsx","jsxs","MiniFeatureBlock","title","text","icon","badgeColor","badgeText","Badge"],"mappings":"yCAoBM,cAAAA,EAME,QAAAC,MANF,oBATC,SAASC,EAAiB,CAC/B,MAAAC,EACA,KAAAC,EACA,KAAAC,EACA,WAAAC,EACA,UAAAC,CACF,EAAU,CACR,OACEN,EAAC,OAAI,UAAU,yCACb,UAAAD,EAAC,OACC,UAAU,iDACV,IAAKK,EACL,IAAKF,EACP,EACAF,EAAC,OAAI,UAAU,eACb,UAAAA,EAAC,OAAI,UAAU,oBACb,UAAAD,EAAC,KAAE,UAAU,gEACV,SAAAG,EACH,EACCI,GACCP,EAAC,OAAI,UAAU,OACf,SAAAA,EAACQ,EAAA,CACA,MAAOF,EAEL,SAAAC,EACH,EACA,GAEJ,EACAP,EAAC,KAAE,UAAU,2CAA4C,SAAAI,EAAK,GAChE,GACF,CAEJ","sourcesContent":["//@ts-nocheck\nimport { Badge } from \"./badge\";\n\ntype Props = {\n title: string;\n text: string;\n icon: string;\n badgeColor?: string;\n badgeText?: string;\n};\n\nexport function MiniFeatureBlock({\n title,\n text,\n icon,\n badgeColor,\n badgeText,\n}: Props) {\n return (\n <div className=\"flex flex-col items-center sm:flex-row\">\n <img\n className=\"mb-2 h-20 w-20 rounded-lg object-cover sm:mb-0\"\n src={icon}\n alt={title}\n />\n <div className=\"mb-1 sm:ml-4\">\n <div className=\"flex items-center\">\n <p className=\"text-sm font-semibold leading-6 text-gray-900 dark:text-white\">\n {title}\n </p>\n {badgeText && (\n <div className=\"ml-2\"> \n <Badge\n color={badgeColor} \n >\n {badgeText}\n </Badge>\n </div>\n )}\n </div>\n <p className=\"text-sm text-gray-500 dark:text-gray-400\">{text}</p>\n </div>\n </div>\n );\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/select.tsx"],"names":["import_prop_types","forwardRef","Fragment","jsx","jsxs","Select","props","ref","__spreadProps","__spreadValues","o","PropTypes"],"mappings":"2FAEA,IAAAA,EAAsB,OADtB,OAAS,cAAAC,MAAkB,QAKvB,mBAAAC,EAEI,OAAAC,EAFJ,QAAAC,MAAA,oBAFG,IAAMC,EAASJ,EAAW,SAAgBK,EAAOC,EAAK,CAC3D,OACEH,EAAAF,EAAA,CACG,UAAAI,EAAM,OACLH,EAAC,SACC,QAAS,GAAGG,EAAM,YAClB,UAAU,+DAET,SAAAA,EAAM,MACT,EAEFH,EAAC,SAAAK,EAAAC,EAAA,CACC,GAAI,GAAGH,EAAM,YACb,IAAKC,EACL,UAAU,uQACND,GAJL,CAMG,UAAAA,EAAM,SAAW,CAAC,GAAG,IAAKI,GAExBP,EAAC,UAEC,MAAOO,EAAE,MACT,SAAUA,EAAE,SACZ,SAAUA,EAAE,SACZ,OAAQA,EAAE,OAET,SAAAA,EAAE,SANE,GAAGJ,EAAM,MAAMI,EAAE,OAOxB,CAEH,GACH,GACF,CAEJ,CAAC,EAEDL,EAAO,UAAY,CAEjB,GAAI,EAAAM,QAAU,OAAO,WAErB,MAAO,EAAAA,QAAU,OAEjB,aAAc,EAAAA,QAAU,UAAU,CAAC,EAAAA,QAAU,OAAQ,EAAAA,QAAU,MAAM,CAAC,EACnE,WAEH,QAAS,EAAAA,QAAU,QACjB,EAAAA,QAAU,MAAM,CACd,MAAO,EAAAA,QAAU,UAAU,CAAC,EAAAA,QAAU,OAAQ,EAAAA,QAAU,MAAM,CAAC,EAC5D,WACH,QAAS,EAAAA,QAAU,OAAO,UAC5B,CAAC,CACH,EAAE,WAEF,SAAU,EAAAA,QAAU,KAAK,UAC3B,EAEAN,EAAO,YAAc","sourcesContent":["//@ts-nocheck\nimport { forwardRef } from \"react\";\nimport PropTypes from \"prop-types\";\n\nexport const Select = forwardRef(function Select(props, ref) {\n return (\n <>\n {props.label && (\n <label\n htmlFor={`${props.id}-select`}\n className=\"mb-2 block text-sm font-medium text-gray-900 dark:text-white\"\n >\n {props.label}\n </label>\n )}\n <select\n id={`${props.id}-select`}\n ref={ref}\n className=\"block w-full rounded-lg border border-gray-300 bg-gray-50 p-2.5 text-sm text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:border-blue-500 dark:focus:ring-blue-500\"\n {...props}\n >\n {(props.options || []).map((o) => {\n return (\n <option\n key={`${props.id}-${o.value}`}\n value={o.value}\n disabled={o.disabled}\n selected={o.selected}\n hidden={o.hidden}\n >\n {o.display}\n </option>\n );\n })}\n </select>\n </>\n );\n});\n\nSelect.propTypes = {\n /** Unique id for the dropdown */\n id: PropTypes.string.isRequired,\n /** Optional label for the dropdown */\n label: PropTypes.string,\n /** Optional inital selected value must match the value of an element of an object in the options array. (defaults to first value in the list)*/\n defaultValue: PropTypes.oneOfType([PropTypes.string, PropTypes.number])\n .isRequired,\n /** Array of objects with value and display properties */\n options: PropTypes.arrayOf(\n PropTypes.shape({\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number])\n .isRequired,\n display: PropTypes.string.isRequired,\n })\n ).isRequired,\n /** Callback function when the dropdown value changes */\n onChange: PropTypes.func.isRequired,\n};\n\nSelect.displayName = \"Select\";\n"]}
|
package/dist/chunk-WLJEFSES.mjs
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { a as a$1 } from './chunk-PUJZGK7Y.mjs';
|
|
2
|
-
import { e } from './chunk-23SJGKDR.mjs';
|
|
3
|
-
import { forwardRef } from 'react';
|
|
4
|
-
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
5
|
-
|
|
6
|
-
var a=e(a$1());var t=forwardRef(function(e,l){return jsx("div",{className:e.className&&e.className,children:jsxs("label",{className:`relative mb-5 inline-flex items-center ${e.disabled&&"cursor-not-allowed opacity-50"}`,children:[jsx("input",{id:e.id,ref:l,type:"checkbox",className:"peer sr-only",onChange:e.onChange,name:e.name}),jsx("div",{className:"peer h-6 w-11 rounded-full bg-gray-200 after:absolute after:start-[2px] after:top-0.5 after:h-5 after:w-5 after:rounded-full after:border after:border-gray-300 after:bg-white after:transition-all after:content-[''] peer-checked:bg-blue-600 peer-checked:after:translate-x-full peer-checked:after:border-white rtl:peer-checked:after:-translate-x-full dark:border-gray-600 dark:bg-gray-700"}),e.label&&jsx("span",{class:"ms-3 text-sm font-medium text-gray-900 dark:text-gray-300",children:e.label})]})})});t.propTypes={id:a.default.string.isRequired,checked:a.default.bool,disabled:a.default.bool,onChange:a.default.func,label:a.default.string};t.displayName="ToggleSwitch";
|
|
7
|
-
|
|
8
|
-
export { t as a };
|
|
9
|
-
//# sourceMappingURL=out.js.map
|
|
10
|
-
//# sourceMappingURL=chunk-WLJEFSES.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/toggleswitch.tsx"],"names":["import_prop_types","forwardRef","jsx","jsxs","ToggleSwitch","props","ref","PropTypes"],"mappings":"kFAEA,IAAAA,EAAsB,OADtB,OAAS,cAAAC,MAAkB,QAMpB,OAKG,OAAAC,EALH,QAAAC,MAAA,oBAHA,IAAMC,EAAeH,EAAW,SAAsBI,EAAOC,EAAK,CACvE,OACEJ,EAAC,OAAI,UAAWG,EAAM,WAAaA,EAAM,UACtC,SAAAF,EAAC,SACE,UAAW,0CACTE,EAAM,UAAY,kCAGpB,UAAAH,EAAC,SACC,GAAIG,EAAM,GACV,IAAKC,EACL,KAAK,WACL,UAAW,eACX,SAAUD,EAAM,SAChB,KAAMA,EAAM,KACZ,EACFH,EAAC,OAAI,UAAU,qYAAqY,EACnZG,EAAM,OACLH,EAAC,QAAK,MAAM,4DACT,SAAAG,EAAM,MACT,GAEJ,EACF,CAEN,CAAC,EAEDD,EAAa,UAAY,CAEvB,GAAI,EAAAG,QAAU,OAAO,WAErB,QAAS,EAAAA,QAAU,KAEnB,SAAU,EAAAA,QAAU,KAEpB,SAAU,EAAAA,QAAU,KACpB,MAAO,EAAAA,QAAU,MACnB,EAEAH,EAAa,YAAc","sourcesContent":["//@ts-nocheck\nimport { forwardRef } from \"react\";\nimport PropTypes from \"prop-types\";\n\nexport const ToggleSwitch = forwardRef(function ToggleSwitch(props, ref) {\n return (\n <div className={props.className && props.className}>\n <label\n className={`relative mb-5 inline-flex items-center ${\n props.disabled && \"cursor-not-allowed opacity-50\"\n }`}\n >\n <input\n id={props.id}\n ref={ref}\n type=\"checkbox\"\n className={`peer sr-only`}\n onChange={props.onChange}\n name={props.name}\n />\n <div className=\"peer h-6 w-11 rounded-full bg-gray-200 after:absolute after:start-[2px] after:top-0.5 after:h-5 after:w-5 after:rounded-full after:border after:border-gray-300 after:bg-white after:transition-all after:content-[''] peer-checked:bg-blue-600 peer-checked:after:translate-x-full peer-checked:after:border-white rtl:peer-checked:after:-translate-x-full dark:border-gray-600 dark:bg-gray-700\" />\n {props.label && (\n <span class=\"ms-3 text-sm font-medium text-gray-900 dark:text-gray-300\">\n {props.label}\n </span>\n )}\n </label>\n </div>\n );\n});\n\nToggleSwitch.propTypes = {\n /** Id for Toggle switch */\n id: PropTypes.string.isRequired,\n /** Bool to determine if ToggleSwitch has been checked */\n checked: PropTypes.bool,\n /** Bool to disable toggle switch */\n disabled: PropTypes.bool,\n /** function to handle checked value */\n onChange: PropTypes.func,\n label: PropTypes.string,\n};\n\nToggleSwitch.displayName = \"ToggleSwitch\";\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/modal.tsx"],"names":["import_prop_types","FaTimes","variantProps","jsx","jsxs","modalProps","Modal","_a","_b","children","show","props","__objRest","renderHeadedModal","renderCloseButton","isHeadless","__spreadProps","__spreadValues","ModalBody","ModalFooter","border","alignment","PropTypes"],"mappings":"uGAGA,IAAAA,EAAsB,OAFtB,OAAS,WAAAC,MAAe,iBACxB,OAAS,gBAAAC,MAAoB,2BAmBT,cAAAC,EAGhB,QAAAC,MAHgB,oBAhBpB,IAAMC,EAAaH,EAAa,CAC9B,KAAM,kCACN,SAAU,CACR,KAAM,CACJ,IAAK,WACL,GAAI,WACJ,GAAI,YACJ,GAAI,WACN,EACA,gBAAiB,CACf,KAAM,IACR,CACF,CACF,CAAC,EAEM,SAASI,EAAMC,EAAqC,CAArC,IAAAC,EAAAD,EAAE,UAAAE,EAAU,KAAAC,EAAO,EApBzC,EAoBsBF,EAA4BG,EAAAC,EAA5BJ,EAA4B,CAA1B,WAAU,SAChC,GAAI,CAACE,EAAM,OAAOP,EAAC,QAAI,EAEvB,IAAMU,EAAoB,IACxBT,EAAC,OAAI,UAAU,uFACb,UAAAD,EAAC,MAAG,UAAU,sDAAuD,SAAAQ,EAAM,MAAM,EAChFG,EAAkB,GACrB,EAGIA,EAAoB,CAACC,EAAa,KACtCX,EAAC,UACC,KAAK,SACL,UAAW,GACTW,GAAc,sNAEhB,kBAAgB,gBAChB,QAASJ,EAAM,QAEf,UAAAR,EAACF,EAAA,EAAQ,EACTE,EAAC,QAAK,UAAU,UAAU,uBAAW,GACvC,EAGF,OACEA,EAAC,OACC,GAAG,gBACH,SAAS,KACT,cAAY,OACZ,UAAU,oNACV,KAAK,SAEL,SAAAA,EAAC,MAAAa,EAAAC,EAAA,GAAQZ,EAAWM,CAAK,GAAxB,CACC,SAAAP,EAAC,OAAI,UAAU,sEACZ,UAAAO,EAAM,MAAQE,EAAkB,EAAIC,EAAkB,EAAI,EAC1DL,GACH,GACF,EACF,CAEJ,CAEO,SAASS,EAAU,CAAE,SAAAT,CAAS,EAAG,CACtC,OAAON,EAAC,OAAK,SAAAM,EAAS,CACxB,CAEO,SAASU,EAAY,CAAE,SAAAV,EAAU,OAAAW,EAAS,GAAM,UAAAC,EAAY,QAAS,EAAG,CAC7E,OAAOlB,EAAC,OAAI,UAAW,cAAckB,GAAa,UAAY,oBAAoBA,GAAa,QAAU,mBAAmBA,GAAa,SAAW,sCAAsCD,GAAU,4DAA8D,SAAAX,EAAS,CAC7Q,CAEAH,EAAM,KAAOY,EACbZ,EAAM,OAASa,EAEfb,EAAM,aAAe,CACnB,KAAM,IACR,EAEAA,EAAM,UAAY,CAEhB,MAAO,EAAAgB,QAAU,OAEjB,KAAM,EAAAA,QAAU,KAEhB,KAAM,EAAAA,QAAU,MAAM,CAAC,MAAO,KAAM,KAAM,IAAI,CAAC,EAE/C,QAAS,EAAAA,QAAU,KAAK,WAExB,SAAU,EAAAA,QAAU,KAAK,UAC3B,EAEAJ,EAAU,UAAY,CAEpB,SAAU,EAAAI,QAAU,KAAK,UAC3B,EAEAH,EAAY,UAAY,CAEtB,OAAQ,EAAAG,QAAU,KAClB,SAAU,EAAAA,QAAU,KAAK,WACzB,UAAW,EAAAA,QAAU,MAAM,CAAC,OAAQ,SAAU,OAAO,CAAC,CACxD,EAEAhB,EAAM,YAAc,QACpBa,EAAY,YAAc,cAC1BD,EAAU,YAAc","sourcesContent":["//@ts-nocheck\nimport { FaTimes } from 'react-icons/fa'\nimport { variantProps } from 'classname-variants/react'\nimport PropTypes from 'prop-types'\n\nconst modalProps = variantProps({\n base: 'relative p-4 w-full max-h-full ',\n variants: {\n size: {\n xsm: 'max-w-md',\n sm: 'max-w-xl',\n md: 'max-w-2xl',\n lg: 'max-w-3xl',\n },\n defaultVariants: {\n size: 'md',\n },\n },\n})\n\nexport function Modal({ children, show = true, ...props }) {\n if (!show) return <div />\n\n const renderHeadedModal = () => (\n <div className=\"flex items-center justify-between p-4 md:p-5 border-b rounded-t dark:border-gray-600\">\n <h3 className=\"text-xl font-semibold text-gray-900 dark:text-white\">{props.title}</h3>\n {renderCloseButton()}\n </div>\n )\n\n const renderCloseButton = (isHeadless = false) => (\n <button\n type=\"button\"\n className={`${\n isHeadless && 'absolute top-3 end-2.5'\n } text-gray-400 bg-transparent hover:bg-gray-200 hover:text-gray-900 rounded-lg text-sm w-8 h-8 ms-auto inline-flex justify-center items-center dark:hover:bg-gray-600 dark:hover:text-white`}\n data-modal-hide=\"default-modal\"\n onClick={props.onClose}\n >\n <FaTimes />\n <span className=\"sr-only\">Close modal</span>\n </button>\n )\n\n return (\n <div\n id=\"default-modal\"\n tabIndex=\"-1\"\n aria-hidden=\"true\"\n className=\"overflow-y-auto overflow-x-hidden fixed top-0 right-0 left-0 z-50 justify-center items-center w-full md:inset-0 h-[calc(100%-1rem)] max-h-full flex bg-gray-900 bg-opacity-50 dark:bg-gray-900 dark:bg-opacity-50\"\n role=\"dialog\"\n >\n <div {...modalProps(props)}>\n <div className=\"relative pt-4 pl-4 pr-4 bg-white rounded-lg shadow dark:bg-gray-700\">\n {props.title ? renderHeadedModal() : renderCloseButton(true)}\n {children}\n </div>\n </div>\n </div>\n )\n}\n\nexport function ModalBody({ children }) {\n return <div>{children}</div>\n}\n\nexport function ModalFooter({ children, border = true, alignment = \"center\" }) {\n return <div className={`flex gap-4 ${alignment == 'center' && 'justify-center'} ${alignment == 'left' && 'justify-start'} ${alignment == 'right' && 'justify-end'} items-end p-4 md:p-5 ${border && 'border-t'} border-gray-200 rounded-b dark:border-gray-600`}>{children}</div>\n}\n\nModal.Body = ModalBody\nModal.Footer = ModalFooter\n\nModal.defaultProps = {\n size: 'md',\n}\n\nModal.propTypes = {\n /** Tile of the modal not providing a title makes this a headless modal */\n title: PropTypes.string,\n /** Whether or not the modal is visible */\n show: PropTypes.bool,\n /** Size of the modal */\n size: PropTypes.oneOf(['xsm', 'sm', 'md', 'lg']),\n /** Callback for the close action */\n onClose: PropTypes.func.isRequired,\n /** Modal.Body and Modal.Footer compounds used to build up the modal. The footer is optional */\n children: PropTypes.node.isRequired,\n}\n\nModalBody.propTypes = {\n /** Markup to make up the Modal content */\n children: PropTypes.node.isRequired,\n}\n\nModalFooter.propTypes = {\n /** Markup to make up the Modal Footer */\n border: PropTypes.bool,\n children: PropTypes.node.isRequired,\n alignment: PropTypes.oneOf(['left', 'center', 'right']),\n}\n\nModal.displayName = \"Modal\"\nModalFooter.displayName = \"ModalFooter\"\nModalBody.displayName = \"ModalBody\"\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/color-picker.tsx"],"names":["useState","useRef","useEffect","SketchPicker","jsx","jsxs","ColorPicker","defaultColour","onChange","onComplete","ref","handleClickOutside","e","setShowPicker","showPicker","colour","setColour","handleChange","color","hex","handleChangeComplete","toggleShowPicker"],"mappings":"AAAA,OAAS,YAAAA,EAAU,UAAAC,EAAQ,aAAAC,MAAiB,QAC5C,OAAS,gBAAAC,MAAoB,cA4CzB,OACE,OAAAC,EADF,QAAAC,MAAA,oBApCG,SAASC,EAAY,CAC1B,cAAAC,EAAgB,UAChB,SAAAC,EACA,WAAAC,CACF,EAAU,CACR,IAAMC,EAAMT,EAAY,IAAI,EAC5BC,EAAU,IAAM,CACd,IAAMS,EAAsBC,GAAkB,CACxCF,EAAI,SAAW,CAACA,EAAI,QAAQ,SAASE,EAAE,MAAM,GAC/CC,EAAc,EAAK,CAEvB,EAEA,gBAAS,iBAAiB,QAASF,EAAoB,EAAI,EACpD,IAAM,CACX,SAAS,oBAAoB,QAASA,EAAoB,EAAI,CAChE,CACF,EAAG,CAAC,CAAC,EAEL,GAAM,CAACG,EAAYD,CAAa,EAAIb,EAAS,EAAK,EAC5C,CAACe,EAAQC,CAAS,EAAIhB,EAASO,CAAa,EAC5CU,EAAgBC,GAAe,CACnC,IAAMC,EAAMD,EAAM,IAClBF,EAAUG,CAAG,EACTX,GAAY,MAAMA,EAASW,CAAG,CACpC,EAEMC,EAAwBF,GAAe,CAEvCT,GAAc,MAAMA,EAAWS,EAAM,GAAG,CAC9C,EACMG,EAAmB,IAAM,CAC7BR,EAAc,CAACC,CAAU,CAC3B,EAEA,OACET,EAAC,OAAI,UAAU,WACb,UAAAD,EAAC,UACC,KAAK,SACL,UAAU,2DACV,MAAO,CACL,gBAAiB,GAAGW,GACtB,EACA,QAASM,EACV,EACAP,GACCV,EAAC,OAAI,IAAKM,EACR,SAAAN,EAACD,EAAA,CACC,UAAU,wBACV,aAAY,GACZ,MAAOY,EACP,SAAUE,EACV,iBAAkBG,EACpB,EACF,GAEJ,CAEJ,CAEAd,EAAY,YAAc","sourcesContent":["import { useState, useRef, useEffect } from \"react\";\nimport { SketchPicker } from \"react-color\";\n\ntype Props = {\n defaultColour?: string;\n onChange?: Function;\n onComplete?: Function; // To reduce renders in the parent this cb is best, depending upon the context it is called\n};\n\nexport function ColorPicker({\n defaultColour = \"#ff00ff\",\n onChange,\n onComplete,\n}: Props) {\n const ref = useRef<any>(null);\n useEffect(() => {\n const handleClickOutside = (e: MouseEvent) => {\n if (ref.current && !ref.current.contains(e.target)) {\n setShowPicker(false);\n }\n };\n\n document.addEventListener(\"click\", handleClickOutside, true);\n return () => {\n document.removeEventListener(\"click\", handleClickOutside, true);\n };\n }, []);\n\n const [showPicker, setShowPicker] = useState(false);\n const [colour, setColour] = useState(defaultColour);\n const handleChange = (color: any) => {\n const hex = color.hex;\n setColour(hex);\n if (onChange != null) onChange(hex);\n };\n\n const handleChangeComplete = (color: any) => {\n // We don't set the colour here as it is done in onChange\n if (onComplete != null) onComplete(color.hex);\n };\n const toggleShowPicker = () => {\n setShowPicker(!showPicker);\n };\n\n return (\n <div className=\"relative\">\n <button\n type=\"button\"\n className=\" h-6 w-6 rounded-md border border-solid border-slate-300\"\n style={{\n backgroundColor: `${colour}`,\n }}\n onClick={toggleShowPicker}\n ></button>\n {showPicker && (\n <div ref={ref}>\n <SketchPicker\n className=\"absolute right-0 z-10\"\n disableAlpha\n color={colour}\n onChange={handleChange}\n onChangeComplete={handleChangeComplete}\n />\n </div>\n )}\n </div>\n );\n}\n\nColorPicker.displayName = \"ColorPicker\"\n\n\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/avatar.tsx"],"names":["import_prop_types","jsx","avatarSize","fontSize","colorMap","Avatar","_a","_b","children","img","size","placeholderInitials","rounded","props","__objRest","bgColor","__spreadValues","twMerge","__spreadProps","PropTypes"],"mappings":"gJAEA,IAAAA,EAAsB,OAkDlB,cAAAC,MAAA,oBAhDJ,IAAMC,EAAa,OAAO,OAAO,CAC/B,GAAI,UACJ,GAAI,UACJ,GAAI,YACJ,GAAI,YACJ,GAAI,WACN,CAAC,EAEKC,EAAW,OAAO,OAAO,CAC7B,GAAI,UACJ,GAAI,UACJ,GAAI,UACJ,GAAI,WACJ,GAAI,UACN,CAAC,EAEGC,EAAW,OAAO,OAAO,CAC3B,EAAG,aACH,EAAG,aACH,EAAG,aACH,EAAG,aACH,EAAG,aACH,EAAG,aACH,EAAG,aACH,EAAG,cACH,EAAG,cACH,EAAG,cACH,EAAG,cACH,EAAG,cACH,EAAG,cACH,EAAG,cACH,EAAG,eACH,EAAG,eACH,EAAG,eACH,EAAG,eACH,EAAG,eACH,EAAG,eACH,EAAG,gBACH,EAAG,gBACH,EAAG,gBACH,EAAG,gBACH,EAAG,gBACH,EAAG,eACL,CAAC,EAEM,SAASC,EAAOC,EAAiE,CAAjE,IAAAC,EAAAD,EAAE,UAAAE,EAAU,IAAAC,EAAK,KAAAC,EAAM,oBAAAC,EAAqB,QAAAC,CAjDnE,EAiDuBL,EAAwDM,EAAAC,EAAxDP,EAAwD,CAAtD,WAAU,MAAK,OAAM,sBAAqB,YACjE,IAAMQ,EAAUJ,IAAwB,GAAKP,EAASO,EAAoB,CAAC,EAAE,YAAY,CAAC,EAAI,cAC9F,OAAOF,EACLR,EAAC,MAAAe,EAAA,CACC,IAAKP,EACL,UAAWQ,EAAQ,0DAA2DP,EAAOR,EAAWQ,CAAI,EAAI,YAAaE,EAAU,eAAiB,YAAY,GACxJC,EACL,EAEDZ,EAAC,MAAAiB,EAAAF,EAAA,CACC,UAAWC,EACT,mEACAF,EACAL,EAAOR,EAAWQ,CAAI,EAAI,YAAaE,EAAU,eAAiB,YACpE,GACIC,GANL,CAQC,SAAAZ,EAAC,QAAK,UAAWgB,EAAQ,mCAAoCP,EAAOP,EAASO,CAAI,EAAI,SAAS,EAAI,SAAAC,EAAoB,YAAY,EAAE,GACtI,CAEJ,CAEAN,EAAO,YAAc,SAErBA,EAAO,UAAY,CAEjB,IAAK,EAAAc,QAAU,OAEf,KAAM,EAAAA,QAAU,OAEhB,oBAAqB,EAAAA,QAAU,OAAO,WAEtC,QAAS,EAAAA,QAAU,IACrB","sourcesContent":["//@ts-nocheck\nimport { twMerge } from 'tailwind-merge'\nimport PropTypes from 'prop-types'\n\nconst avatarSize = Object.freeze({\n xs: 'w-6 h-6',\n sm: 'w-8 h-8',\n md: 'w-10 h-10',\n lg: 'w-20 h-20',\n xl: 'w-36 h-36',\n})\n\nconst fontSize = Object.freeze({\n xs: 'text-xs',\n sm: 'text-sm',\n md: 'text-lg',\n lg: 'text-3xl',\n xl: 'text-7xl',\n})\n\nvar colorMap = Object.freeze({\n A: 'bg-red-200',\n B: 'bg-red-200',\n C: 'bg-red-200',\n D: 'bg-red-200',\n E: 'bg-red-200',\n F: 'bg-red-200',\n G: 'bg-red-200',\n H: 'bg-pink-200',\n I: 'bg-pink-200',\n J: 'bg-pink-200',\n K: 'bg-pink-200',\n L: 'bg-pink-200',\n M: 'bg-pink-200',\n N: 'bg-pink-200',\n O: 'bg-green-200',\n P: 'bg-green-200',\n Q: 'bg-green-200',\n R: 'bg-green-200',\n S: 'bg-green-200',\n T: 'bg-green-200',\n U: 'bg-orange-200',\n V: 'bg-orange-200',\n W: 'bg-orange-200',\n X: 'bg-orange-200',\n Y: 'bg-orange-200',\n Z: 'bg-orange-200',\n})\n\nexport function Avatar({ children, img, size, placeholderInitials, rounded, ...props }) {\n const bgColor = placeholderInitials !== \"\" ? colorMap[placeholderInitials[0].toUpperCase()] : 'bg-gray-100'\n return img ? (\n <img\n src={img}\n className={twMerge('flex justify-center items-center space-x-4 object-cover', size ? avatarSize[size] : 'w-10 h-10', rounded ? \"rounded-full\" : \"rounded-lg\")}\n {...props}\n ></img>\n ) : (\n <div\n className={twMerge(\n 'relative inline-flex items-center justify-center overflow-hidden',\n bgColor,\n size ? avatarSize[size] : 'w-10 h-10', rounded ? \"rounded-full\" : \"rounded-lg\"\n )}\n {...props}\n >\n <span className={twMerge('text-gray-600 dark:text-gray-300', size ? fontSize[size] : 'text-md')}>{placeholderInitials.toUpperCase()}</span>\n </div>\n )\n}\n\nAvatar.displayName = \"Avatar\";\n\nAvatar.propTypes = {\n /** String for file path of image */\n img: PropTypes.string,\n /** String to determine the size of the avatar. \"xs, sm, md, lg, xl\" */\n size: PropTypes.string,\n /** String for intials of name inputted */\n placeholderInitials: PropTypes.string.isRequired,\n /** Boolean to determine if avatar is circular */\n rounded: PropTypes.bool,\n}\n"]}
|