ekm-ui 0.3.28 → 0.3.31

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/.turbo/turbo-build.log +69 -69
  2. package/CHANGELOG.md +7 -0
  3. package/dist/card-payment-block.css +1 -1
  4. package/dist/card-payment-block.css.map +1 -1
  5. package/dist/card-payment-block.d.ts +3 -0
  6. package/dist/card-payment-block.mjs +14 -16
  7. package/dist/chunk-2GCEP5W6.mjs +9 -0
  8. package/dist/chunk-2GCEP5W6.mjs.map +1 -0
  9. package/dist/chunk-ANWYP5U5.mjs +30 -0
  10. package/dist/chunk-ANWYP5U5.mjs.map +1 -0
  11. package/dist/chunk-BKPA5PRE.mjs +8 -0
  12. package/dist/chunk-BKPA5PRE.mjs.map +1 -0
  13. package/dist/chunk-F6ZWBNIM.mjs +9 -0
  14. package/dist/chunk-F6ZWBNIM.mjs.map +1 -0
  15. package/dist/{chunk-WU66HPYP.mjs → chunk-MTR65QZV.mjs} +3 -3
  16. package/dist/chunk-MTR65QZV.mjs.map +1 -0
  17. package/dist/chunk-QOVVHEU2.mjs +9 -0
  18. package/dist/chunk-QOVVHEU2.mjs.map +1 -0
  19. package/dist/chunk-XGHRMSFX.mjs +12 -0
  20. package/dist/chunk-XGHRMSFX.mjs.map +1 -0
  21. package/dist/chunk-XMWWV2CX.mjs +11 -0
  22. package/dist/chunk-XMWWV2CX.mjs.map +1 -0
  23. package/dist/chunk-ZWJSMASL.mjs +11 -0
  24. package/dist/chunk-ZWJSMASL.mjs.map +1 -0
  25. package/dist/{chunk-Y5K3JRRK.mjs → chunk-ZYRUFOAX.mjs} +3 -3
  26. package/dist/chunk-ZYRUFOAX.mjs.map +1 -0
  27. package/dist/dashboard-notification.mjs +3 -1
  28. package/dist/drag-and-drop.css +2 -0
  29. package/dist/drag-and-drop.css.map +1 -0
  30. package/dist/drag-and-drop.d.ts +4 -1
  31. package/dist/drag-and-drop.mjs +50 -1
  32. package/dist/draggable-stacked-list-item.mjs +3 -1
  33. package/dist/dropdown.d.ts +4 -0
  34. package/dist/dropdown.mjs +1 -1
  35. package/dist/file-picker/file-picker.css +2 -0
  36. package/dist/file-picker/file-picker.css.map +1 -0
  37. package/dist/file-picker/file-picker.mjs +44 -2
  38. package/dist/fixed-alert.mjs +3 -1
  39. package/dist/form-row.mjs +3 -1
  40. package/dist/index.css +1 -1
  41. package/dist/index.css.map +1 -1
  42. package/dist/index.mjs +14 -16
  43. package/dist/input-copy.mjs +3 -1
  44. package/dist/layout/layout.css +1 -1
  45. package/dist/layout/layout.css.map +1 -1
  46. package/dist/layout/layout.mjs +14 -16
  47. package/dist/loading-button.d.ts +2 -1
  48. package/dist/loading-button.mjs +1 -1
  49. package/dist/mini-feature-block.mjs +3 -1
  50. package/dist/modal.d.ts +3 -0
  51. package/dist/modal.mjs +1 -1
  52. package/dist/stacked-list-item.css +1 -1
  53. package/dist/stacked-list-item.css.map +1 -1
  54. package/dist/stacked-list-item.mjs +14 -16
  55. package/package.json +1 -1
  56. package/src/card-payment-block.tsx +7 -2
  57. package/src/dashboard-notification.tsx +1 -1
  58. package/src/drag-and-drop.tsx +118 -80
  59. package/src/draggable-stacked-list-item.tsx +2 -1
  60. package/src/dropdown.tsx +3 -1
  61. package/src/fixed-alert.tsx +2 -2
  62. package/src/form-row.tsx +1 -1
  63. package/src/input-copy.tsx +2 -1
  64. package/src/loading-button.tsx +5 -5
  65. package/src/mini-feature-block.tsx +6 -2
  66. package/src/modal.tsx +4 -0
  67. package/dist/chunk-4AISL4YA.mjs +0 -12
  68. package/dist/chunk-4AISL4YA.mjs.map +0 -1
  69. package/dist/chunk-BIU2AAPZ.mjs +0 -9
  70. package/dist/chunk-BIU2AAPZ.mjs.map +0 -1
  71. package/dist/chunk-FJQEJBBY.mjs +0 -8
  72. package/dist/chunk-FJQEJBBY.mjs.map +0 -1
  73. package/dist/chunk-KJPNVM7M.mjs +0 -16
  74. package/dist/chunk-KJPNVM7M.mjs.map +0 -1
  75. package/dist/chunk-L6TUZV6O.mjs +0 -11
  76. package/dist/chunk-L6TUZV6O.mjs.map +0 -1
  77. package/dist/chunk-LWDFKEBO.mjs +0 -9
  78. package/dist/chunk-LWDFKEBO.mjs.map +0 -1
  79. package/dist/chunk-MA4QT7NM.mjs +0 -18
  80. package/dist/chunk-MA4QT7NM.mjs.map +0 -1
  81. package/dist/chunk-N3423LIB.mjs +0 -12
  82. package/dist/chunk-N3423LIB.mjs.map +0 -1
  83. package/dist/chunk-S4LI5APF.mjs +0 -11
  84. package/dist/chunk-S4LI5APF.mjs.map +0 -1
  85. package/dist/chunk-T2OVPC6F.mjs +0 -9
  86. package/dist/chunk-T2OVPC6F.mjs.map +0 -1
  87. package/dist/chunk-WU66HPYP.mjs.map +0 -1
  88. package/dist/chunk-Y5K3JRRK.mjs.map +0 -1
@@ -1,16 +0,0 @@
1
- import { a as a$1, b } from './chunk-EHJJX6ZZ.mjs';
2
- import { a as a$2 } from './chunk-256SAVHD.mjs';
3
- import { a as a$3 } from './chunk-OT256LE6.mjs';
4
- import { a } from './chunk-LWDFKEBO.mjs';
5
- import { a as a$4 } from './chunk-YJKULMWM.mjs';
6
- import { Card, Radio, Label, TextInput, Badge, Sidebar } from 'flowbite-react';
7
- import { HiCreditCard } from 'react-icons/hi';
8
- import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
9
- import { useState, useMemo } from 'react';
10
- import { HiChartPie, HiTag, HiShoppingBag, HiPaintBrush, HiStar, HiDocument, HiRocketLaunch, HiGlobeAlt } from 'react-icons/hi2';
11
-
12
- function X({cardPayment:a$1,enablePayPal:i}){return jsxs(Card,{className:"border-0 shadow-sm ",children:[jsx("h3",{className:"text-lg font-semibold dark:text-white",children:"Billing Details"}),jsx("div",{className:"flex items-center justify-between border-b-2 pb-4",children:jsxs("fieldset",{className:"flex w-full flex-col gap-4",id:"radio",children:[jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[i&&jsx(Radio,{defaultChecked:!0,id:"creditDebitCard",name:"paymentType",value:"creditDebitCard"}),jsx(Label,{htmlFor:"creditDebitCard",children:"Pay by Credit or Debit card"})]}),jsxs("div",{className:i?"ml-6 flex gap-2":"flex gap-2",children:[jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/visa.png",alt:"VISA Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/mastercard.png",alt:"MasterCard Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/maestro.png",alt:"Maestro Card Logo"}),jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/amex.png",alt:"AMEX Card Logo"})]})]}),a$1&&jsxs(Fragment,{children:[jsxs("div",{className:"grid grid-cols-1 content-start gap-6 sm:grid-cols-2",children:[jsx(a,{label:"Name on Card *",htmlFor:"nameOnCard",helperText:"This is your name as is appears on the front of your credit or debit card.",children:jsx(TextInput,{id:"nameOnCard",name:"nameOnCard",placeholder:"Your name",type:"text",required:!0})}),jsx(a,{label:"Card Number *",htmlFor:"cardNumber",helperText:"This is the long number on the front of your credit or debit card.",children:jsx(TextInput,{id:"nameOnCard",name:"nameOnCard",placeholder:"0000 0000 0000 0000",type:"number",rightIcon:HiCreditCard,required:!0})})]}),jsxs("div",{className:"grid grid-cols-1 content-start gap-6 sm:grid-cols-4",children:[jsx(a,{label:"Expiry Date *",htmlFor:"nameOnCard",helperText:"The expiry date as it appears on your card.",children:jsx(TextInput,{id:"nameOnCard",name:"nameOnCard",placeholder:"MM / YY",type:"text",required:!0})}),jsx(a,{label:"Security Code (CVC) *",htmlFor:"cardNumber",helperText:"The last three digits on the back of your card\u2019s signature strip.",children:jsx(TextInput,{id:"nameOnCard",name:"nameOnCard",placeholder:"123",type:"number",rightIcon:HiCreditCard,required:!0})})]})]}),i&&jsxs("div",{className:"flex flex-col gap-2",children:[jsxs("div",{className:"flex items-center gap-2",children:[jsx(Radio,{id:"PayPal",name:"paymentType",value:"PayPal"}),jsx(Label,{htmlFor:"PayPal",children:"PayPal"})]}),jsx("div",{className:"ml-6",children:jsx("img",{src:"https://shared.ekmcdn.com/images/uifw/cards/paypal.png",alt:"PayPal Icon"})})]})]})})]})}function F(){return jsxs(Sidebar.Items,{children:[jsxs(Sidebar.ItemGroup,{children:[jsx(Sidebar.Item,{href:"/",icon:HiChartPie,className:"bg-gray-100 dark:bg-gray-700",children:"Dashboard"}),jsx(Sidebar.Item,{href:"/products",icon:HiTag,className:"",children:"Products"}),jsx(Sidebar.Item,{href:"/orders",icon:HiShoppingBag,label:"27",className:"",children:"Orders"}),jsxs(Sidebar.Collapse,{icon:HiPaintBrush,label:"Design",children:[jsx(Sidebar.Item,{href:"/design/design",className:"",children:"Theme"}),jsx(Sidebar.Item,{href:"/design/editor",className:"",children:"Editor"}),jsx(Sidebar.Item,{href:"/theme/webpages",className:"",children:"Webpages"})]}),jsx(Sidebar.Item,{href:"/features",icon:HiStar,className:"",children:"Features"})]}),jsxs(Sidebar.ItemGroup,{children:[jsx(Sidebar.Item,{href:"https://github.com/themesberg/flowbite-react/",icon:HiDocument,children:"Docs"}),jsx(Sidebar.Item,{href:"https://flowbite-react.com/",icon:HiRocketLaunch,children:"What's New"}),jsx(Sidebar.Item,{href:"https://github.com/themesberg/flowbite-react/issues",icon:HiGlobeAlt,children:"Support Centre"})]})]})}function Z({children:a,hasHeader:i}){let[s,f]=useState(!1),[g,x]=useState(!1);return useMemo(()=>{a$1()&&!s&&x(!0);},[s]),jsxs(Fragment,{children:[jsx(a$2,{onMenuButtonClick:()=>{f(!s);},showCloseButton:g,avatarImg:"https://avatars.githubusercontent.com/u/49406022?v=4"}),jsxs("div",{className:"flex",children:[jsx(b,{collapsed:s,children:jsx(F,{})}),jsxs("div",{className:"flex w-3/4 flex-grow flex-col",children:[jsx("main",{className:`"relative dark:bg-gray-900" flex h-full flex-grow flex-col gap-4 overflow-y-auto bg-gray-50 ${i?"":"p-4"}`,children:a}),jsx(a$3,{})]})]})]})}function j({id:a,title:i,text:s,avatarShow:f,avatarColor:g,avatarBorder:x,children:A,badgeText:I,badgeColor:H,icon:N}){function R(M){var b=M.split(" "),S=b[0],w=b[b.length-1],E=S.charAt(0);if(S!==w)var k=w.charAt(0);else var k="";return [E,k]}let O=R(i);return jsxs("li",{className:"hover:bg-gray-90 relative flex justify-between gap-x-6 px-4 py-5 dark:hover:bg-gray-900",children:[jsxs("div",{className:"flex min-w-0 flex-auto items-center gap-x-4",children:[f&&jsx(a$4,{placeholderInitials:O,color:g,border:x}),N&&N,jsxs("div",{className:"min-w-0 flex-auto",children:[jsxs("div",{className:"flex gap-2",children:[jsx("p",{className:"truncate text-sm font-semibold text-gray-900 dark:text-white",children:i}),I&&jsx(Badge,{color:H||"info",children:I})]}),jsx("p",{className:"mt-1 flex text-xs text-gray-500 dark:text-gray-400",children:jsx("span",{className:"relative truncate",children:s})})]})]}),jsx("div",{className:"flex flex-shrink-0 items-center gap-x-4",children:jsx("div",{className:"sm:flex sm:flex-col sm:items-end",children:A})})]},a)}
13
-
14
- export { j as a, Z as b, X as c };
15
- //# sourceMappingURL=out.js.map
16
- //# sourceMappingURL=chunk-KJPNVM7M.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/card-payment-block.tsx","../src/layout/layout.tsx","../shared/sidebar-items.tsx","../src/stacked-list-item.tsx"],"names":["TextInput","Card","Radio","Label","HiCreditCard","Fragment","jsx","jsxs","CardPaymentBlock","cardPayment","enablePayPal","FormRow","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","Badge","StackedListItem","id","title","text","avatarShow","avatarColor","avatarBorder","badgeText","badgeColor","icon","getFirstAndLastLetters","str","words","firstWord","lastWord","firstLetter","lastLetter","avatarLetters","Avatar"],"mappings":"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","sourcesContent":["import { FormRow } from \"./index\";\nimport { TextInput, Card, Radio, Label } from \"flowbite-react\";\nimport { HiCreditCard } from \"react-icons/hi\";\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-lg font-semibold dark:text-white\">Billing Details</h3>\n <div className=\"flex items-center justify-between border-b-2 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 defaultChecked\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 sm: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-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=\"number\"\n rightIcon={HiCreditCard}\n required\n />\n </FormRow>\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","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 />\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 { 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"]}
@@ -1,11 +0,0 @@
1
- import { a } from './chunk-PUJZGK7Y.mjs';
2
- import { e as e$1, c, b, a as a$1 } from './chunk-23SJGKDR.mjs';
3
- import { FaTimes } from 'react-icons/fa';
4
- import { variantProps } from 'classname-variants/react';
5
- import { jsx, jsxs } from 'react/jsx-runtime';
6
-
7
- var e=e$1(a());var h=variantProps({base:"relative p-4 w-full max-h-full ",variants:{size:{xsm:"max-w-md",sm:"max-w-xl",md:"max-w-2xl",lg:"max-w-3xl"},defaultVariants:{size:"md"}}});function o(w){var l=w,{children:t,show:a=!0}=l,d=c(l,["children","show"]);if(!a)return jsx("div",{});let b$1=()=>jsxs("div",{className:"flex items-center justify-between p-4 md:p-5 border-b rounded-t dark:border-gray-600",children:[jsx("h3",{className:"text-xl font-semibold text-gray-900 dark:text-white",children:d.title}),s()]}),s=(c=!1)=>jsxs("button",{type:"button",className:`${c&&"absolute top-3 end-2.5"} 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`,"data-modal-hide":"default-modal",onClick:d.onClose,children:[jsx(FaTimes,{}),jsx("span",{className:"sr-only",children:"Close modal"})]});return jsx("div",{id:"default-modal",tabIndex:"-1","aria-hidden":"true",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",role:"dialog",children:jsx("div",b(a$1({},h(d)),{children:jsxs("div",{className:"relative bg-white rounded-lg shadow dark:bg-gray-700",children:[d.title?b$1():s(!0),t]})}))})}function f({children:t}){return jsx("div",{children:t})}function x({children:t,border:a=!0}){return jsx("div",{className:`flex items-center p-4 md:p-5 ${a&&"border-t"} border-gray-200 rounded-b dark:border-gray-600`,children:t})}o.Body=f;o.Footer=x;o.defaultProps={size:"md"};o.propTypes={title:e.default.string,show:e.default.bool,size:e.default.oneOf(["xsm","sm","md","lg"]),onClose:e.default.func.isRequired,children:e.default.node.isRequired};f.propTypes={children:e.default.node.isRequired};x.propTypes={border:e.default.bool,children:e.default.node.isRequired};
8
-
9
- export { o as a, f as b, x as c };
10
- //# sourceMappingURL=out.js.map
11
- //# sourceMappingURL=chunk-L6TUZV6O.mjs.map
@@ -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","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,uDACZ,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,EAAK,EAAG,CACvD,OAAOjB,EAAC,OAAI,UAAW,gCAAgCiB,GAAU,4DAA8D,SAAAX,EAAS,CAC1I,CAEAH,EAAM,KAAOY,EACbZ,EAAM,OAASa,EAEfb,EAAM,aAAe,CACnB,KAAM,IACR,EAEAA,EAAM,UAAY,CAEhB,MAAO,EAAAe,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,EAEAH,EAAU,UAAY,CAEpB,SAAU,EAAAG,QAAU,KAAK,UAC3B,EAEAF,EAAY,UAAY,CAEtB,OAAQ,EAAAE,QAAU,KAClB,SAAU,EAAAA,QAAU,KAAK,UAC3B","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 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 }) {\n return <div className={`flex items-center 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}\n"]}
@@ -1,9 +0,0 @@
1
- import l from 'clsx';
2
- import { Label } from 'flowbite-react';
3
- import { jsxs, jsx } from 'react/jsx-runtime';
4
-
5
- function d({children:s,label:o,htmlFor:e,helperText:r,className:n,errorText:t}){return jsxs("div",{className:l("grid grid-cols-1 content-start gap-y-2",n),children:[jsx(Label,{htmlFor:e,color:t&&"failure",children:o}),s,r&&!t&&jsx("span",{className:"text-xs font-normal text-gray-500 dark:text-gray-400",children:r}),t&&jsx("span",{className:"text-xs font-normal text-red-500 dark:text-red-500",children:t})]})}
6
-
7
- export { d as a };
8
- //# sourceMappingURL=out.js.map
9
- //# sourceMappingURL=chunk-LWDFKEBO.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/form-row.tsx"],"names":["clsx","Label","jsx","jsxs","FormRow","children","label","htmlFor","helperText","className","errorText"],"mappings":"AAAA,OAAOA,MAAU,OACjB,OAAS,SAAAC,MAAa,iBAoBlB,OACE,OAAAC,EADF,QAAAC,MAAA,oBATG,SAASC,EAAQ,CACtB,SAAAC,EACA,MAAAC,EACA,QAAAC,EACA,WAAAC,EACA,UAAAC,EACA,UAAAC,CACF,EAAU,CACR,OACEP,EAAC,OAAI,UAAWH,EAAK,yCAA0CS,CAAS,EACtE,UAAAP,EAACD,EAAA,CAAM,QAASM,EAAS,MAAOG,GAAa,UAC1C,SAAAJ,EACH,EACCD,EACAG,GAAc,CAACE,GACdR,EAAC,QAAK,UAAU,uDACb,SAAAM,EACH,EAEDE,GACCR,EAAC,QAAK,UAAU,qDACb,SAAAQ,EACH,GAEJ,CAEJ","sourcesContent":["import clsx from \"clsx\";\nimport { Label } from \"flowbite-react\";\n\ntype Props = {\n children: React.ReactNode;\n label: string;\n htmlFor: string;\n helperText?: String;\n className?: string;\n errorText?: string;\n};\n\nexport function FormRow({\n children,\n label,\n htmlFor,\n helperText,\n className,\n errorText,\n}: Props) {\n return (\n <div className={clsx(\"grid grid-cols-1 content-start gap-y-2\", className)}>\n <Label htmlFor={htmlFor} color={errorText && \"failure\"}>\n {label}\n </Label>\n {children}\n {helperText && !errorText && (\n <span className=\"text-xs font-normal text-gray-500 dark:text-gray-400\">\n {helperText}\n </span>\n )}\n {errorText && (\n <span className=\"text-xs font-normal text-red-500 dark:text-red-500\">\n {errorText}\n </span>\n )}\n </div>\n );\n}\n"]}
@@ -1,18 +0,0 @@
1
- import { a as a$3 } from './chunk-XFCPRHEY.mjs';
2
- import { a as a$6 } from './chunk-BRWFUWH7.mjs';
3
- import { a as a$5 } from './chunk-4AISL4YA.mjs';
4
- import { a as a$1 } from './chunk-QRNTMHBL.mjs';
5
- import { a as a$4 } from './chunk-TWLN46WO.mjs';
6
- import { a as a$2 } from './chunk-CEALW6RO.mjs';
7
- import { a } from './chunk-PUJZGK7Y.mjs';
8
- import { e as e$1, f } from './chunk-23SJGKDR.mjs';
9
- import { useRef, useReducer, useState, useEffect } from 'react';
10
- import { BsFillImageFill } from 'react-icons/bs';
11
- import { HiOutlineSearch } from 'react-icons/hi';
12
- import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
13
-
14
- var g=e$1(a());var q="/admin/api/common/directoryinformation/",e=Object.freeze({EMPTY:"EMPTY",SEARCH_LOADING:"SEARCH-LOADING",LOADING:"LOADING",LOADED:"LOADED",LOADED_NO_DRAG:"LOADED_NO_DRAG",SEARCH_RESULTS:"SEARCH-RESULTS",SEARCH_EMPTY:"SEARCH-EMPTY",UPLOAD_ERROR:"ERROR",DRAGGING:"DRAGGING"}),ue=Object.freeze({mode:e.LOADING,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1});function fe(o,l){switch(l.type){case e.EMPTY:return {mode:e.EMPTY,actionBtnTxt:"Add Image",actionBtnColor:"blue",listSize:"h-5/6",listBorder:"",searchDisabled:!0};case e.LOADING:return ue;case e.LOADED:return {mode:e.LOADED,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[68.666667%]",listBorder:"border",searchDisabled:!1};case e.LOADED_NO_DRAG:return {mode:e.LOADED_NO_DRAG,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-[87.666667%]",listBorder:"border",searchDisabled:!1};case e.SEARCH_RESULTS:return {mode:e.SEARCH_RESULTS,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"border",searchDisabled:!1};case e.SEARCH_EMPTY:return {mode:e.SEARCH_EMPTY,actionBtnTxt:"I Accept",actionBtnColor:"success",listSize:"h-5/6",listBorder:"",searchDisabled:!1};default:throw new Error("Unknown file picker state: "+l.page)}}function pe({appUrl:o,uri:l,show:c,hideDrag:h=!1,onClose:S,callback:Z}){let T=useRef(),[a,E]=useReducer(fe,{mode:e.LOADING,footerBorder:"border-t"}),[J,K]=useState(0),u=useRef(1),[Q,C]=useState(!1),[I,f$1]=useState(!1),y=useRef({pages:0,totalEntries:0}),[V,R]=useState(!1),[r,k]=useState(null),[D,N]=useState(null),[W,x]=useState([]),[F,p]=useState("none");useEffect(()=>{c&&(E({type:e.LOADING}),N(null),y.current={pages:0,totalEntries:0},M(),b(1));},[c]),useEffect(()=>{c&&(u.current=1,b(),f$1(!1));},[r]),useEffect(()=>{D&&N(null),I&&f$1(!1);},[a.mode]);let M=()=>{x([]),p("none"),R(!1),N(null),f$1(!1);},b=(s=0)=>f(this,null,function*(){try{let i=s===0?u.current:s,A=(r==null?void 0:r.length)>0?`&FileNameIncludesString=${r}`:"&FileNameIncludesString=",d=yield (yield fetch(`${o}${q}?CurrentPage=${i}&PageSize=10&Uri=${l}${A}`,{method:"GET",credentials:"same-origin",headers:{"Content-Type":"application/json"}})).json();if((r==null?void 0:r.length)>0&&E({type:e.SEARCH_RESULTS}),d.Items.Data.length>0&&i>1?x(_=>[..._,...d.Items.Data]):x(d.Items.Data),y.current={pages:d.Items.NumberOfPages,totalEntries:d.Items.Total},K(d.Items.NumberOfPages),(r==null?void 0:r.length)>0)E({type:d.Items.Data.length>0?e.SEARCH_RESULTS:e.SEARCH_EMPTY});else {let _=h?e.LOADED_NO_DRAG:e.LOADED;E({type:d.Items.Data.length>0?_:e.EMPTY});}p("none"),R(!1),C(!1);}catch(i){E({type:(r==null?void 0:r.length)===0?e.SEARCH_EMPTY:e.EMPTY});}}),X=s=>{hidedrag||(C(!0),T.current.removeFocus(),s.preventDefault());},ee=s=>{hidedrag||C(!1);},te=s=>{var L;let i=(L=s.text)!=null?L:"",A=r!=null?r:"";k(s.text),(A.length>0&&i.length===0||A.length===0&&i.length>0&&a.mode!==e.LOADING)&&E({type:e.LOADING});},P=()=>{f$1(!0),C(!1),p("none");},re=()=>{Z(`https://files.ekmcdn.com/${D.Uri}`),v();},v=()=>{M(),S();},U=s=>f(this,null,function*(){if(s==null){p("error"),P();return}try{let i=yield Ae(s),A={Path:`/${l}/`,Name:s.name,Bytes:Ce(i),ForceOverwriteFile:!0};(yield fetch(`${o}${q}`,{method:"POST",credentials:"same-origin",headers:{"Content-Type":"application/json"},body:JSON.stringify(A)})).status===200?(p("success"),k(null),T.current.clear(),x([]),f$1(!1),b(1)):p("error");}catch(i){p("error");}}),ae=s=>{switch(s.type){case"FETCH_DATA":R(s.payload),u.current<y.current.pages&&!V&&(R(!0),u.current=u.current+1,b());break;case"SELECTION":N(s.payload),f$1(!1);break;}},se=()=>{switch(a.mode){case e.EMPTY:return jsx(ge,{});case e.LOADING:return jsx(he,{});case e.SEARCH_RESULTS:case e.LOADED:case e.LOADED_NO_DRAG:return jsx(a$6,{border:a.listSize,files:W,isMore:u.current<y.current.pages,selected:D==null?void 0:D.Name,page:u.current,pages:J,callback:ae});case e.SEARCH_EMPTY:return jsx(Ee,{});}},ne=()=>jsxs(Fragment,{children:[jsx(a$3,{id:"file-search",ref:T,placeholder:"Search your images",disabled:a.searchDisabled,callback:te}),jsxs("div",{className:"mt-4 mb-4",children:[I&&jsxs(a$4,{type:"danger",onDismiss:()=>{f$1(!1);},children:[jsx("p",{className:"font-semibold",children:"File could not be uploaded"}),jsx("p",{children:"There was an error uploading the file. Please try again."})]}),a.mode!==e.SEARCH_RESULTS&&a.mode!==e.SEARCH_EMPTY&&!h&&jsx("div",{className:"h-68",children:jsx(a$5,{uploaded:F,callback:U,errorCallback:P})}),(a.mode===e.SEARCH_RESULTS||a.mode===e.SEARCH_EMPTY)&&(r==null?void 0:r.length)>0&&jsx("span",{className:"ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400",children:`Showing results for..."${r}"`})]}),se()]}),oe=()=>jsx("div",{className:"h-[90.666667%] w-[93.666667%] z-50 absolute",children:jsx(a$5,{uploaded:F,exitCallback:ee,callback:U,errorCallback:P})});return jsxs(a$1,{show:c,onClose:v,title:"File Picker",onHide:()=>{},children:[jsxs("div",{className:"h-full",onDragEnter:X,children:[c&&Q&&!hidedrag&&oe(),c&&ne()]}),jsxs("div",{className:"grid grid-cols-2 grid-flow-col gap-4 bottom-0 mt-0 pt-2 bg-white dark:border-gray-600",style:{marginTop:"-50px"},children:[jsx(a$2,{color:"light",onClick:v,children:"Close"}),jsx(a$2,{color:a.actionBtnColor,onClick:re,disabled:D==null,children:a.actionBtnTxt})]})]})}pe.propTypes={appUrl:g.default.string.isRequired,uri:g.default.string.isRequired,show:g.default.bool.isRequired,hideDrag:g.default.bool,onClose:g.default.func.isRequired,callback:g.default.func.isRequired};function ge(){return jsxs("div",{className:"flex flex-col items-center justify-center mt-5",children:[jsx("h1",{children:jsx(BsFillImageFill,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 font-semibold text-2xl text-gray-900",children:"You Have No Images"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"Images will appear here when you upload them"})]})}function he(){return jsx("div",{className:"h-2/3 overflow-y-auto flex items-center justify-center",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(De,{})}),jsx("p",{className:"mt-4 font-semibold text-2xl text-gray-900",children:"Loading Files"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"Don't worry, this won't take long..."})]})})}function Ee(){return jsx("div",{className:"h-5/6 overflow-y-auto flex items-center justify-center",children:jsxs("div",{className:"flex flex-col items-center justify-center",children:[jsx("h1",{children:jsx(HiOutlineSearch,{className:"text-9xl text-gray-700"})}),jsx("p",{className:"mt-4 font-semibold text-2xl text-gray-900",children:"No Files Found"}),jsx("p",{className:"mt-4 text-sm text-gray-500",children:"No files were found matching your search"})]})})}function De(){return jsxs("div",{role:"status",children:[jsxs("svg",{"aria-hidden":"true",className:"inline w-14 h-14 text-gray-200 animate-spin dark:text-gray-600 fill-blue-600",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"currentColor"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentFill"})]}),jsx("span",{className:"sr-only",children:"Loading..."})]})}function Ae(o){return f(this,null,function*(){return new Uint8Array(yield Se(o))})}function Se(o){return new Promise((l,c)=>{let h=new FileReader;h.onloadend=S=>l(S.target.result),h.onerror=S=>c(S),h.readAsArrayBuffer(o);})}function Ce(o){return btoa(Array.from(o).map(l=>String.fromCharCode(l)).join(""))}
15
-
16
- export { pe as a };
17
- //# sourceMappingURL=out.js.map
18
- //# sourceMappingURL=chunk-MA4QT7NM.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/file-picker/file-picker.tsx"],"names":["useEffect","useRef","useState","useReducer","BsFillImageFill","HiOutlineSearch","import_prop_types","Fragment","jsx","jsxs","apiUrl","Status","initialState","FilePickerReducer","state","action","FilePicker","appUrl","uri","show","hideDrag","onClose","callback","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","e","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","DragAndDrop","renderOversizedDropZone","Drawer","Button","PropTypes","Spinner","readFile","resolve","reject","reader","event","b"],"mappings":"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","sourcesContent":["// @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\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"]}
@@ -1,12 +0,0 @@
1
- import { a } from './chunk-PUJZGK7Y.mjs';
2
- import { e as e$1, c, 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 { jsxs, jsx } from 'react/jsx-runtime';
7
-
8
- var e=e$1(a());var f=createContext(),P=variantProps({base:"text-white focus:ring-4 focus:outline-none focus:ring-blue-300 font-medium text-sm py-2.5 text-center inline-flex items-center",variants:{color:{blue:"bg-blue-700 hover:bg-blue-800 dark:bg-blue-600 dark:hover:bg-blue-700 focus:ring-blue-300",gray:"bg-gray-700 hover:bg-gray-800 dark:bg-gray-600 dark:hover:bg-gray-700 focus:ring-gray-300",green:"bg-green-700 hover:bg-green-800 dark:bg-green-600 dark:hover:bg-green-700 focus:ring-green-300",red:"bg-red-700 hover:bg-red-800 dark:bg-red-600 dark:hover:bg-red-700 focus:ring-red-300",yellow:"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(u){var l=u,{children:d}=l,r=c(l,["children"]);let[i,a]=useState(t.CLOSED),w=()=>{a(i===t.CLOSED?t.OPEN:t.CLOSED);};return useEffect(()=>{let g=h=>{h.target.id!==r.id&&a(t.CLOSED);};return document.addEventListener("click",g),()=>{document.removeEventListener("click",g);}},[]),jsxs(f.Provider,{value:{showDropdown:i,setShowDropdown:a},children:[jsxs("button",b(a$1({id:r.id},P(r)),{"data-dropdown-toggle":`${r.id}-dropdown`,type:"button",onClick:w,children:[r.label,r.type==="rect"&&jsx(BiChevronDown,{})]})),jsx("div",{id:`${r.id}-dropdown`,className:`z-10 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:d})})]})}function m(){return jsx("li",{children:jsx("hr",{className:"h-px my-2 bg-gray-200 border-0 dark:bg-gray-700"})})}function s({callback:d,children:r}){let u=useContext(f);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:()=>{u.setShowDropdown(!1),d();},children:r})})}n.Divider=m;n.Item=s;n.propTypes={id:e.default.string.isRequired,children:e.default.oneOfType([e.default.shape({type:e.default.oneOf([s])}),e.default.arrayOf(e.default.shape({type:e.default.oneOf([m])}))]).isRequired,type:e.default.oneOf(["rect","round"]),size:e.default.oneOf(["sm","md","lg","rsm","rmd","rlg"]),color:e.default.oneOf(["blue","gray","green","red","yellow"]),label:e.default.oneOfType([e.default.string,e.default.node]).isRequired,callback:e.default.func.isRequired};n.defaultProps={type:"rect",size:"md",color:"blue",label:"Dropdown"};s.propTypes={callback:e.default.func.isRequired};n.displayName="Dropdown";
9
-
10
- export { n as a, m as b, s as c };
11
- //# sourceMappingURL=out.js.map
12
- //# sourceMappingURL=chunk-N3423LIB.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","_a","_b","children","props","__objRest","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: 'text-white focus:ring-4 focus:outline-none focus:ring-blue-300 font-medium text-sm py-2.5 text-center inline-flex items-center',\n variants: {\n color: {\n blue: 'bg-blue-700 hover:bg-blue-800 dark:bg-blue-600 dark:hover:bg-blue-700 focus:ring-blue-300',\n gray: 'bg-gray-700 hover:bg-gray-800 dark:bg-gray-600 dark:hover:bg-gray-700 focus:ring-gray-300',\n green: 'bg-green-700 hover:bg-green-800 dark:bg-green-600 dark:hover:bg-green-700 focus:ring-green-300',\n red: 'bg-red-700 hover:bg-red-800 dark:bg-red-600 dark:hover:bg-red-700 focus:ring-red-300',\n yellow: '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({ children, ...props }) {\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 === props.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 <DropdownContext.Provider value={{ showDropdown, setShowDropdown }}>\n <button id={props.id} {...buttonProps(props)} data-dropdown-toggle={`${props.id}-dropdown`} type=\"button\" onClick={handleShowDropdown}>\n {props.label}\n {props.type === 'rect' && <BiChevronDown />}\n </button>\n <div\n id={`${props.id}-dropdown`}\n className={`z-10 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 )\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.oneOfType([\n PropTypes.shape({ type: PropTypes.oneOf([DropdownItem]), }),\n PropTypes.arrayOf(PropTypes.shape({ type: PropTypes.oneOf([DropdownDivider]) }))\n ]).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', '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 /** Returns value of the selected item */\n callback: PropTypes.func.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\";"]}
@@ -1,11 +0,0 @@
1
- import { a } from './chunk-PUJZGK7Y.mjs';
2
- import { e, c, b, a as a$1 } from './chunk-23SJGKDR.mjs';
3
- import { jsx, jsxs } from 'react/jsx-runtime';
4
-
5
- var n=e(a());var s=Object.freeze({success:" text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2",danger:" text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2"}),g=Object.freeze({success:" cursor-not-allowed opacity-50 text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2",danger:" cursor-not-allowed opacity-50 text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2"});function l(C){var o=C,{children:c$1}=o,e=c(o,["children"]);let b$1=()=>jsxs("svg",{"aria-hidden":"true",role:"status",className:"mr-3 inline h-4 w-4 animate-spin text-white",viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsx("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",fill:"#E5E7EB"}),jsx("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",fill:"currentColor"})]});return jsx("button",b(a$1({className:`group flex items-center justify-center p-0.5 text-center font-medium relative focus:z-10 focus:outline-none
6
- ${e.color?e.isLoading?g[e.color]:s[e.color]:e.isLoading?g.success:s.success}
7
- `},e),{disabled:e.isLoading,children:jsxs("span",{className:"flex items-center transition-all duration-200 rounded-md text-sm px-4 py-2",children:[e.isLoading&&b$1(),c$1]})}))}l.propTypes={color:n.default.string,isLoading:n.default.bool};l.displayName="LoadingButton";
8
-
9
- export { l as a };
10
- //# sourceMappingURL=out.js.map
11
- //# sourceMappingURL=chunk-S4LI5APF.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/loading-button.tsx"],"names":["import_prop_types","jsx","jsxs","buttonColors","disabledButtonColors","LoadingButton","_a","_b","children","props","__objRest","renderLoader","__spreadProps","__spreadValues","PropTypes"],"mappings":"uGACA,IAAAA,EAAsB,OAkBlB,OAQE,OAAAC,EARF,QAAAC,MAAA,oBAhBJ,IAAMC,EAAe,OAAO,OAAO,CACjC,QACE,yMACF,OACE,4LACJ,CAAC,EAEKC,EAAuB,OAAO,OAAO,CACzC,QACE,uOACF,OACE,0NACJ,CAAC,EAEM,SAASC,EAAcC,EAAwB,CAAxB,IAAAC,EAAAD,EAAE,UAAAE,CAjBhC,EAiB8BD,EAAeE,EAAAC,EAAfH,EAAe,CAAb,aAC9B,IAAMI,EAAe,IACnBT,EAAC,OACC,cAAY,OACZ,KAAK,SACL,UAAU,8CACV,QAAQ,cACR,KAAK,OACL,MAAM,6BAEN,UAAAD,EAAC,QACC,EAAE,+WACF,KAAK,UACP,EACAA,EAAC,QACC,EAAE,glBACF,KAAK,eACP,GACF,EAGF,OACIA,EAAC,SAAAW,EAAAC,EAAA,CACC,UAAW;AAAA,YAEPJ,EAAM,MACFA,EAAM,UACJL,EAAqBK,EAAM,KAAK,EAChCN,EAAaM,EAAM,KAAK,EAC1BA,EAAM,UACNL,EAAqB,QACrBD,EAAa;AAAA,WAGjBM,GAZL,CAaC,SAAUA,EAAM,UAEhB,SAAAP,EAAC,QAAK,UAAU,6EACb,UAAAO,EAAM,WAAaE,EAAa,EAChCH,GACH,GACF,CAEN,CAEAH,EAAc,UAAY,CAExB,MAAO,EAAAS,QAAU,OAEjB,UAAW,EAAAA,QAAU,IACvB,EAEAT,EAAc,YAAc","sourcesContent":["//@ts-nocheck\nimport PropTypes from 'prop-types'\n\nconst buttonColors = Object.freeze({\n success:\n ' text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2',\n danger:\n ' text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2',\n})\n\nconst disabledButtonColors = Object.freeze({\n success:\n ' cursor-not-allowed opacity-50 text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2',\n danger:\n ' cursor-not-allowed opacity-50 text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2',\n})\n\nexport function LoadingButton({ children, ...props }) {\n const renderLoader = () => (\n <svg\n aria-hidden=\"true\"\n role=\"status\"\n className=\"mr-3 inline h-4 w-4 animate-spin text-white\"\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=\"#E5E7EB\"\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=\"currentColor\"\n />\n </svg>\n )\n\n return (\n <button\n className={`group flex items-center justify-center p-0.5 text-center font-medium relative focus:z-10 focus:outline-none \n ${\n props.color\n ? props.isLoading\n ? disabledButtonColors[props.color]\n : buttonColors[props.color]\n : props.isLoading\n ? disabledButtonColors.success\n : buttonColors.success\n }\n `}\n {...props}\n disabled={props.isLoading}\n >\n <span className=\"flex items-center transition-all duration-200 rounded-md text-sm px-4 py-2\">\n {props.isLoading && renderLoader()}\n {children}\n </span>\n </button>\n )\n}\n\nLoadingButton.propTypes = {\n /** String for color of loading button */\n color: PropTypes.string,\n /** Bool for spinner on button */\n isLoading: PropTypes.bool,\n}\n\nLoadingButton.displayName = \"LoadingButton\";\n"]}
@@ -1,9 +0,0 @@
1
- import { Card } from 'flowbite-react';
2
- import { HiXMark } from 'react-icons/hi2';
3
- import { jsxs, jsx } from 'react/jsx-runtime';
4
-
5
- function m({title:a,text:o,onClose:s,children:i,type:r,imgURL:l}){return jsxs(Card,{className:"relative shadow-sm",children:[jsx("div",{onClick:s,className:"absolute right-2 top-2 cursor-pointer rounded p-1 transition hover:bg-gray-200 hover:dark:bg-gray-600 ",children:jsx(HiXMark,{className:"h-6 w-6 text-gray-400 dark:text-gray-300"})}),jsxs("div",{className:`flex flex-col gap-4 ${r=="lg"?"items-center justify-center ":"sm:flex-row"}`,children:[jsx("div",{className:"flex-shrink-0",children:jsx("img",{src:l,alt:"",className:`h-16 w-16 rounded-md border border-gray-200 ${r=="lg"?"h-28 w-28 object-cover object-center":""}`})}),jsxs("div",{className:`${r=="lg"?"flex flex-col items-center":""}`,children:[jsx("p",{className:`mb-1 text-lg font-semibold dark:text-white ${r=="lg"?"text-center":""}`,children:a}),jsx("p",{className:`mb-6 text-gray-500 dark:text-gray-400 ${r=="lg"?"text-center":""}`,children:o}),i]})]})]})}m.displayName="DashboardNotification";
6
-
7
- export { m as a };
8
- //# sourceMappingURL=out.js.map
9
- //# sourceMappingURL=chunk-T2OVPC6F.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/dashboard-notification.tsx"],"names":["Card","HiXMark","jsx","jsxs","DashboardNotification","title","text","onClose","children","type","imgURL"],"mappings":"AACA,OAAS,QAAAA,MAAY,iBACrB,OAAS,WAAAC,MAAe,kBAyBhB,cAAAC,EAgBA,QAAAC,MAhBA,oBAdD,SAASC,EAAsB,CACpC,MAAAC,EACA,KAAAC,EACA,QAAAC,EACA,SAAAC,EACA,KAAAC,EACA,OAAAC,CACF,EAAU,CACR,OACEP,EAACH,EAAA,CAAK,UAAW,qBACf,UAAAE,EAAC,OACC,QAASK,EACT,UAAU,yGAEV,SAAAL,EAACD,EAAA,CAAQ,UAAU,2CAA2C,EAChE,EACAE,EAAC,OACC,UAAW,wBACTM,GAAQ,KAAO,+BAAiC,gBAGlD,UAAAP,EAAC,OAAI,UAAU,gBACb,SAAAA,EAAC,OACC,IAAKQ,EACL,IAAI,GACJ,UAAW,gDACTD,GAAQ,KAAO,uCAAyC,KAE5D,EACF,EACAN,EAAC,OAAI,UAAW,GAAGM,GAAQ,KAAO,6BAA+B,KAC/D,UAAAP,EAAC,KACC,UAAW,8CACTO,GAAQ,KAAO,cAAgB,KAGhC,SAAAJ,EACH,EACAH,EAAC,KACC,UAAW,yCACTO,GAAQ,KAAO,cAAgB,KAGhC,SAAAH,EACH,EACCE,GACH,GACF,GACF,CAEJ,CAEAJ,EAAsB,YAAc","sourcesContent":["import clsx from \"clsx\";\nimport { Card } from \"flowbite-react\";\nimport { HiXMark } from \"react-icons/hi2\";\n\ntype Props = {\n onClose: () => void;\n title: string;\n text: string;\n children: JSX.Element;\n imgURL: string;\n type: \"sm\" | \"lg\";\n};\n\nexport function DashboardNotification({\n title,\n text,\n onClose,\n children,\n type,\n imgURL,\n}: Props) {\n return (\n <Card className={`relative shadow-sm`}>\n <div\n onClick={onClose}\n className=\"absolute right-2 top-2 cursor-pointer rounded p-1 transition hover:bg-gray-200 hover:dark:bg-gray-600 \"\n >\n <HiXMark className=\"h-6 w-6 text-gray-400 dark:text-gray-300\" />\n </div>\n <div\n className={`flex flex-col gap-4 ${\n type == \"lg\" ? \"items-center justify-center \" : \"sm:flex-row\"\n }`}\n >\n <div className=\"flex-shrink-0\">\n <img\n src={imgURL}\n alt=\"\"\n className={`h-16 w-16 rounded-md border border-gray-200 ${\n type == \"lg\" ? \"h-28 w-28 object-cover object-center\" : \"\"\n }`}\n />\n </div>\n <div className={`${type == \"lg\" ? \"flex flex-col items-center\" : \"\"}`}>\n <p\n className={`mb-1 text-lg font-semibold dark:text-white ${\n type == \"lg\" ? \"text-center\" : \"\"\n }`}\n >\n {title}\n </p>\n <p\n className={`mb-6 text-gray-500 dark:text-gray-400 ${\n type == \"lg\" ? \"text-center\" : \"\"\n }`}\n >\n {text}\n </p>\n {children}\n </div>\n </div>\n </Card>\n );\n}\n\nDashboardNotification.displayName = \"DashboardNotification\";\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/fixed-alert.tsx"],"names":["Button","clsx","jsx","jsxs","FixedAlert","title","text","buttonText","position"],"mappings":"AAAA,OAAS,UAAAA,MAAc,iBACvB,OAAOC,MAAU,OAoBX,OACE,OAAAC,EADF,QAAAC,MAAA,oBAXC,SAASC,EAAW,CAAE,MAAAC,EAAO,KAAAC,EAAM,WAAAC,EAAY,SAAAC,CAAS,EAAU,CACvE,OACEL,EAAC,OACC,UAAWF,EACT,gIACA,CACE,IAAK,QACL,OAAQ,UACV,EAAEO,CAAQ,CACZ,EAEA,UAAAL,EAAC,OAAI,UAAU,GACb,UAAAD,EAAC,KAAE,UAAU,0DACV,SAAAG,EACH,EACAH,EAAC,KAAE,UAAU,+CAAgD,SAAAI,EAAK,GACpE,EACCC,GACCL,EAACF,EAAA,CACC,MAAM,UACN,KAAK,KACL,UAAU,sDAET,SAAAO,EACH,GAEJ,CAEJ","sourcesContent":["import { Button } from \"flowbite-react\";\nimport clsx from \"clsx\";\n\ntype Props = {\n title: string;\n text: string;\n buttonText: string;\n position: \"top\" | \"bottom\";\n};\n\nexport function FixedAlert({ title, text, buttonText, position }: Props) {\n return (\n <div\n className={clsx(\n \"fixed left-0 flex w-full flex-wrap items-center justify-between gap-2 bg-yellow-50 px-5 py-4 dark:bg-gray-800 sm:flex-nowrap \",\n {\n top: \"top-0\",\n bottom: \"bottom-0\",\n }[position]\n )}\n >\n <div className=\"\">\n <p className=\"mb-1 font-semibold text-yellow-700 dark:text-yellow-300\">\n {title}\n </p>\n <p className=\"text-sm text-yellow-800 dark:text-yellow-400\">{text}</p>\n </div>\n {buttonText && (\n <Button\n color=\"success\"\n size=\"sm\"\n className=\"flex-shrink-0 dark:bg-yellow-300 dark:text-gray-800\"\n >\n {buttonText}\n </Button>\n )}\n </div>\n );\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/draggable-stacked-list-item.tsx"],"names":["ToggleSwitch","HiEllipsisVertical","useSortable","CSS","jsx","jsxs","DraggableStackedListItem","id","title","children","toggleCallback","toggleChecked","attributes","listeners","setNodeRef","transform","transition","styles","__spreadProps","__spreadValues"],"mappings":"gDAAA,OAAS,gBAAAA,MAAoB,iBAC7B,OAAS,sBAAAC,MAA0B,kBACnC,OAAS,eAAAC,MAAmB,oBAC5B,OAAS,OAAAC,MAAW,qBAsCV,OACE,OAAAC,EADF,QAAAC,MAAA,oBA5BH,SAASC,EAAyB,CACvC,GAAAC,EACA,MAAAC,EACA,SAAAC,EACA,eAAAC,EACA,cAAAC,CACF,EAAU,CACR,GAAM,CAAE,WAAAC,EAAY,UAAAC,EAAW,WAAAC,EAAY,UAAAC,EAAW,WAAAC,CAAW,EAC/Dd,EAAY,CAAE,GAAIK,CAAG,CAAC,EAElBU,EAAS,CACb,UAAWd,EAAI,UAAU,SAASY,CAAS,EAC3C,WAAAC,CACF,EAEA,OACEX,EAAC,MAEC,UAAU,2FAEV,UAAAD,EAAC,MAAAc,EAAAC,IAAA,CACC,UAAU,8CACV,IAAKL,EACL,MAAOG,GACHL,GACAC,GALL,CAOC,SAAAR,EAAC,OAAI,UAAU,sCACb,UAAAA,EAAC,OAAI,UAAU,oCACb,UAAAD,EAACH,EAAA,CAAmB,UAAU,uDAAuD,EACrFG,EAACH,EAAA,CAAmB,UAAU,8DAA8D,GAC9F,EACAG,EAACJ,EAAA,CACC,MAAOQ,EACP,SAAUE,EACV,QAASC,EACX,GACF,GACF,EACAP,EAAC,OAAI,UAAU,2CACb,SAAAA,EAAC,OAAI,UAAU,mCAAoC,SAAAK,EAAS,EAC9D,IAxBKF,CAyBP,CAEJ","sourcesContent":["import { ToggleSwitch } from \"flowbite-react\";\nimport { HiEllipsisVertical } from \"react-icons/hi2\";\nimport { useSortable } from \"@dnd-kit/sortable\";\nimport { CSS } from \"@dnd-kit/utilities\";\n\ntype Props = {\n id: number;\n title: string;\n children?: JSX.Element;\n toggleCallback: () => void;\n toggleChecked: boolean;\n};\n\nexport function DraggableStackedListItem({\n id,\n title,\n children,\n toggleCallback,\n toggleChecked,\n}: Props) {\n const { attributes, listeners, setNodeRef, transform, transition } =\n useSortable({ id: id });\n\n const styles = {\n transform: CSS.Transform.toString(transform),\n transition,\n };\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\n className=\"flex min-w-0 flex-auto items-center gap-x-4\"\n ref={setNodeRef}\n style={styles}\n {...attributes}\n {...listeners}\n >\n <div className=\"flex min-w-0 flex-auto items-center\">\n <div className=\"relative mr-4 h-6 w-6 cursor-grab\">\n <HiEllipsisVertical className=\"absolute h-6 w-auto text-gray-500 dark:text-gray-400\" />\n <HiEllipsisVertical className=\"absolute left-2 h-6 w-auto text-gray-500 dark:text-gray-400\" />\n </div>\n <ToggleSwitch\n label={title}\n onChange={toggleCallback}\n checked={toggleChecked}\n />\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"]}