@xanui/ui 1.1.16 → 1.1.17

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 (266) hide show
  1. package/Accordion/index.js +3 -18
  2. package/Accordion/index.js.map +1 -1
  3. package/Accordion/index.mjs +2 -15
  4. package/Accordion/index.mjs.map +1 -1
  5. package/Alert/index.js +5 -24
  6. package/Alert/index.js.map +1 -1
  7. package/Alert/index.mjs +2 -19
  8. package/Alert/index.mjs.map +1 -1
  9. package/Avatar/index.js +2 -13
  10. package/Avatar/index.js.map +1 -1
  11. package/Avatar/index.mjs +2 -11
  12. package/Avatar/index.mjs.map +1 -1
  13. package/Badge/index.js +2 -12
  14. package/Badge/index.js.map +1 -1
  15. package/Badge/index.mjs +2 -10
  16. package/Badge/index.mjs.map +1 -1
  17. package/Box/index.js +2 -12
  18. package/Box/index.js.map +1 -1
  19. package/Box/index.mjs +2 -10
  20. package/Box/index.mjs.map +1 -1
  21. package/Button/index.js +4 -17
  22. package/Button/index.js.map +1 -1
  23. package/Button/index.mjs +2 -13
  24. package/Button/index.mjs.map +1 -1
  25. package/ButtonGroup/index.js +2 -12
  26. package/ButtonGroup/index.js.map +1 -1
  27. package/ButtonGroup/index.mjs +2 -10
  28. package/ButtonGroup/index.mjs.map +1 -1
  29. package/Calendar/index.js +16 -35
  30. package/Calendar/index.js.map +1 -1
  31. package/Calendar/index.mjs +2 -19
  32. package/Calendar/index.mjs.map +1 -1
  33. package/CalendarInput/index.js +4 -23
  34. package/CalendarInput/index.js.map +1 -1
  35. package/CalendarInput/index.mjs +2 -19
  36. package/CalendarInput/index.mjs.map +1 -1
  37. package/Checkbox/index.js +2 -16
  38. package/Checkbox/index.js.map +1 -1
  39. package/Checkbox/index.mjs +2 -14
  40. package/Checkbox/index.mjs.map +1 -1
  41. package/Chip/index.js +3 -14
  42. package/Chip/index.js.map +1 -1
  43. package/Chip/index.mjs +2 -11
  44. package/Chip/index.mjs.map +1 -1
  45. package/CircleProgress/index.js +2 -13
  46. package/CircleProgress/index.js.map +1 -1
  47. package/CircleProgress/index.mjs +2 -11
  48. package/CircleProgress/index.mjs.map +1 -1
  49. package/ClickOutside/index.js +2 -13
  50. package/ClickOutside/index.js.map +1 -1
  51. package/ClickOutside/index.mjs +2 -11
  52. package/ClickOutside/index.mjs.map +1 -1
  53. package/Collaps/index.js +2 -12
  54. package/Collaps/index.js.map +1 -1
  55. package/Collaps/index.mjs +2 -10
  56. package/Collaps/index.mjs.map +1 -1
  57. package/Container/index.js +2 -12
  58. package/Container/index.js.map +1 -1
  59. package/Container/index.mjs +2 -10
  60. package/Container/index.mjs.map +1 -1
  61. package/Datatable/FilterBox.js +10 -28
  62. package/Datatable/FilterBox.js.map +1 -1
  63. package/Datatable/FilterBox.mjs +7 -23
  64. package/Datatable/FilterBox.mjs.map +1 -1
  65. package/Datatable/Row.js +11 -30
  66. package/Datatable/Row.js.map +1 -1
  67. package/Datatable/Row.mjs +7 -24
  68. package/Datatable/Row.mjs.map +1 -1
  69. package/Datatable/SelectedBox.js +5 -17
  70. package/Datatable/SelectedBox.js.map +1 -1
  71. package/Datatable/SelectedBox.mjs +4 -14
  72. package/Datatable/SelectedBox.mjs.map +1 -1
  73. package/Datatable/Table.js +4 -16
  74. package/Datatable/Table.js.map +1 -1
  75. package/Datatable/Table.mjs +2 -12
  76. package/Datatable/Table.mjs.map +1 -1
  77. package/Datatable/TableHead.js +18 -25
  78. package/Datatable/TableHead.js.map +1 -1
  79. package/Datatable/TableHead.mjs +18 -23
  80. package/Datatable/TableHead.mjs.map +1 -1
  81. package/Datatable/index.d.ts +2 -67
  82. package/Datatable/index.js +21 -36
  83. package/Datatable/index.js.map +1 -1
  84. package/Datatable/index.mjs +20 -33
  85. package/Datatable/index.mjs.map +1 -1
  86. package/Datatable/types.d.ts +69 -0
  87. package/Divider/index.js +2 -12
  88. package/Divider/index.js.map +1 -1
  89. package/Divider/index.mjs +2 -10
  90. package/Divider/index.mjs.map +1 -1
  91. package/Drawer/index.js +4 -16
  92. package/Drawer/index.js.map +1 -1
  93. package/Drawer/index.mjs +2 -12
  94. package/Drawer/index.mjs.map +1 -1
  95. package/Form/index.js +2 -13
  96. package/Form/index.js.map +1 -1
  97. package/Form/index.mjs +2 -11
  98. package/Form/index.mjs.map +1 -1
  99. package/GridContainer/index.js +2 -12
  100. package/GridContainer/index.js.map +1 -1
  101. package/GridContainer/index.mjs +2 -10
  102. package/GridContainer/index.mjs.map +1 -1
  103. package/GridItem/index.js +2 -12
  104. package/GridItem/index.js.map +1 -1
  105. package/GridItem/index.mjs +2 -10
  106. package/GridItem/index.mjs.map +1 -1
  107. package/IconButton/index.js +3 -15
  108. package/IconButton/index.js.map +1 -1
  109. package/IconButton/index.mjs +2 -12
  110. package/IconButton/index.mjs.map +1 -1
  111. package/Image/index.js +2 -13
  112. package/Image/index.js.map +1 -1
  113. package/Image/index.mjs +2 -11
  114. package/Image/index.mjs.map +1 -1
  115. package/Input/index.js +3 -15
  116. package/Input/index.js.map +1 -1
  117. package/Input/index.mjs +2 -12
  118. package/Input/index.mjs.map +1 -1
  119. package/Label/index.js +2 -12
  120. package/Label/index.js.map +1 -1
  121. package/Label/index.mjs +2 -10
  122. package/Label/index.mjs.map +1 -1
  123. package/Layer/index.js +4 -17
  124. package/Layer/index.js.map +1 -1
  125. package/Layer/index.mjs +2 -13
  126. package/Layer/index.mjs.map +1 -1
  127. package/LineProgress/index.js +2 -13
  128. package/LineProgress/index.js.map +1 -1
  129. package/LineProgress/index.mjs +2 -11
  130. package/LineProgress/index.mjs.map +1 -1
  131. package/List/index.js +2 -12
  132. package/List/index.js.map +1 -1
  133. package/List/index.mjs +2 -10
  134. package/List/index.mjs.map +1 -1
  135. package/ListItem/index.js +3 -14
  136. package/ListItem/index.js.map +1 -1
  137. package/ListItem/index.mjs +2 -11
  138. package/ListItem/index.mjs.map +1 -1
  139. package/LoadingBox/index.js +3 -14
  140. package/LoadingBox/index.js.map +1 -1
  141. package/LoadingBox/index.mjs +2 -11
  142. package/LoadingBox/index.mjs.map +1 -1
  143. package/Menu/index.js +3 -16
  144. package/Menu/index.js.map +1 -1
  145. package/Menu/index.mjs +2 -13
  146. package/Menu/index.mjs.map +1 -1
  147. package/Modal/index.d.ts +1 -1
  148. package/Modal/index.js +3 -15
  149. package/Modal/index.js.map +1 -1
  150. package/Modal/index.mjs +2 -12
  151. package/Modal/index.mjs.map +1 -1
  152. package/NoSSR/index.js +2 -10
  153. package/NoSSR/index.js.map +1 -1
  154. package/NoSSR/index.mjs +2 -8
  155. package/NoSSR/index.mjs.map +1 -1
  156. package/Option/index.js +3 -13
  157. package/Option/index.js.map +1 -1
  158. package/Option/index.mjs +2 -10
  159. package/Option/index.mjs.map +1 -1
  160. package/Paper/index.js +2 -12
  161. package/Paper/index.js.map +1 -1
  162. package/Paper/index.mjs +2 -10
  163. package/Paper/index.mjs.map +1 -1
  164. package/Portal/index.js +2 -13
  165. package/Portal/index.js.map +1 -1
  166. package/Portal/index.mjs +2 -11
  167. package/Portal/index.mjs.map +1 -1
  168. package/Radio/index.js +3 -15
  169. package/Radio/index.js.map +1 -1
  170. package/Radio/index.mjs +2 -12
  171. package/Radio/index.mjs.map +1 -1
  172. package/Scrollbar/index.js +2 -13
  173. package/Scrollbar/index.js.map +1 -1
  174. package/Scrollbar/index.mjs +2 -11
  175. package/Scrollbar/index.mjs.map +1 -1
  176. package/Select/index.js +5 -22
  177. package/Select/index.js.map +1 -1
  178. package/Select/index.mjs +2 -17
  179. package/Select/index.mjs.map +1 -1
  180. package/Stack/index.js +2 -12
  181. package/Stack/index.js.map +1 -1
  182. package/Stack/index.mjs +2 -10
  183. package/Stack/index.mjs.map +1 -1
  184. package/Switch/index.js +2 -13
  185. package/Switch/index.js.map +1 -1
  186. package/Switch/index.mjs +2 -11
  187. package/Switch/index.mjs.map +1 -1
  188. package/Tab/index.js +3 -15
  189. package/Tab/index.js.map +1 -1
  190. package/Tab/index.mjs +2 -12
  191. package/Tab/index.mjs.map +1 -1
  192. package/Table/index.js +3 -14
  193. package/Table/index.js.map +1 -1
  194. package/Table/index.mjs +2 -11
  195. package/Table/index.mjs.map +1 -1
  196. package/TableBody/index.js +2 -12
  197. package/TableBody/index.js.map +1 -1
  198. package/TableBody/index.mjs +2 -10
  199. package/TableBody/index.mjs.map +1 -1
  200. package/TableCell/index.js +2 -12
  201. package/TableCell/index.js.map +1 -1
  202. package/TableCell/index.mjs +2 -10
  203. package/TableCell/index.mjs.map +1 -1
  204. package/TableFooter/index.js +2 -12
  205. package/TableFooter/index.js.map +1 -1
  206. package/TableFooter/index.mjs +2 -10
  207. package/TableFooter/index.mjs.map +1 -1
  208. package/TableHead/index.js +2 -12
  209. package/TableHead/index.js.map +1 -1
  210. package/TableHead/index.mjs +2 -10
  211. package/TableHead/index.mjs.map +1 -1
  212. package/TablePagination/index.d.ts +1 -0
  213. package/TablePagination/index.js +14 -35
  214. package/TablePagination/index.js.map +1 -1
  215. package/TablePagination/index.mjs +12 -31
  216. package/TablePagination/index.mjs.map +1 -1
  217. package/TableRow/index.js +2 -12
  218. package/TableRow/index.js.map +1 -1
  219. package/TableRow/index.mjs +2 -10
  220. package/TableRow/index.mjs.map +1 -1
  221. package/Tabs/index.js +3 -14
  222. package/Tabs/index.js.map +1 -1
  223. package/Tabs/index.mjs +3 -12
  224. package/Tabs/index.mjs.map +1 -1
  225. package/Text/index.js +2 -12
  226. package/Text/index.js.map +1 -1
  227. package/Text/index.mjs +2 -10
  228. package/Text/index.mjs.map +1 -1
  229. package/Toast/index.js +4 -18
  230. package/Toast/index.js.map +1 -1
  231. package/Toast/index.mjs +2 -14
  232. package/Toast/index.mjs.map +1 -1
  233. package/Tooltip/index.js +3 -14
  234. package/Tooltip/index.js.map +1 -1
  235. package/Tooltip/index.mjs +2 -11
  236. package/Tooltip/index.mjs.map +1 -1
  237. package/ViewBox/index.js +3 -14
  238. package/ViewBox/index.js.map +1 -1
  239. package/ViewBox/index.mjs +2 -11
  240. package/ViewBox/index.mjs.map +1 -1
  241. package/index.js +1 -116
  242. package/index.js.map +1 -1
  243. package/index.mjs +1 -56
  244. package/index.mjs.map +1 -1
  245. package/package.json +11 -2
  246. package/readme.md +104 -104
  247. package/useAlert/index.js +5 -19
  248. package/useAlert/index.js.map +1 -1
  249. package/useAlert/index.mjs +2 -14
  250. package/useAlert/index.mjs.map +1 -1
  251. package/useBlurCss/index.js +2 -10
  252. package/useBlurCss/index.js.map +1 -1
  253. package/useBlurCss/index.mjs +2 -8
  254. package/useBlurCss/index.mjs.map +1 -1
  255. package/useCorner/index.js +2 -7
  256. package/useCorner/index.js.map +1 -1
  257. package/useCorner/index.mjs +1 -4
  258. package/useCorner/index.mjs.map +1 -1
  259. package/useLayer/index.js +3 -14
  260. package/useLayer/index.js.map +1 -1
  261. package/useLayer/index.mjs +2 -11
  262. package/useLayer/index.mjs.map +1 -1
  263. package/useModal/index.js +3 -14
  264. package/useModal/index.js.map +1 -1
  265. package/useModal/index.mjs +2 -11
  266. package/useModal/index.mjs.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Calendar/index.tsx"],"sourcesContent":["\"use client\";\r\nimport { useEffect, useRef, useState } from 'react';\r\nimport Stack from '../Stack'\r\nimport IconButton from '../IconButton';\r\nimport IconKeyboardArrowRight from '@xanui/icons/KeyboardArrowRight';\r\nimport IconKeyboardArrowLeft from '@xanui/icons/KeyboardArrowLeft';\r\nimport Text from '../Text';\r\nimport Button from '../Button';\r\nimport ResetIcon from '@xanui/icons/Replay';\r\nimport ViewBox from '../ViewBox';\r\nimport { UseColorTemplateColor, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\n\r\nexport type CalendarProps = {\r\n value?: Date | null;\r\n onChange?: (date: Date | null) => void;\r\n viewMode?: useBreakpointPropsType<\"year\" | \"month\" | \"day\">;\r\n onButtonClick?: (mode: CalendarProps[\"viewMode\"], value: CalendarProps[\"value\"]) => void;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\n\r\nconst ShowYears = ({ color, year, today, boxWidth, onClick }: any) => {\r\n let years: any[] = []\r\n const selectedRef: any = useRef(null)\r\n for (let y = 1900; y < today.getFullYear() + 40; y++) {\r\n const selected = year == y\r\n years.push(<Stack\r\n key={y}\r\n sx={{\r\n width: (boxWidth - 12) / 3,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n p: .1\r\n }}\r\n className='calender-year-item'\r\n >\r\n <Button\r\n color={selected ? color : \"default\"}\r\n className='calender-year-button'\r\n size='small'\r\n corner=\"circle\"\r\n ref={selected ? selectedRef : null}\r\n onClick={() => onClick(y)}\r\n variant={selected ? \"fill\" : \"text\"}\r\n >\r\n {y}\r\n </Button>\r\n </Stack>)\r\n }\r\n\r\n useEffect(() => {\r\n if (selectedRef?.current) {\r\n selectedRef?.current.scrollIntoView({ behavior: \"smooth\", block: \"center\", inline: \"nearest\" })\r\n }\r\n }, [])\r\n\r\n return (\r\n <Stack\r\n sx={{\r\n flexWrap: \"wrap\",\r\n flexDirection: \"row\",\r\n overflow: \"hidden\",\r\n overflowY: \"auto\"\r\n }}\r\n className='calender-years'\r\n >\r\n {years}\r\n </Stack>\r\n )\r\n}\r\n\r\n\r\nconst Calendar = ({ value, ...rest }: CalendarProps) => {\r\n let [{ onChange, viewMode: VMode, onButtonClick, color }] = useInterface<any>(\"Calender\", rest, {})\r\n const _p: any = {}\r\n if (VMode) _p.VMode = VMode\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n color = p.color || \"brand\"\r\n\r\n let [viewMode, setViewMode] = useState<any>(p.VMode || \"day\");\r\n let [selectedDate, setSelectedDate] = useState(new Date());\r\n selectedDate = value instanceof Date ? value : selectedDate\r\n const [currentDate, setCurrentDate] = useState(selectedDate);\r\n const year = currentDate.getFullYear()\r\n const month = currentDate.getMonth()\r\n const daysInMonth = 32 - new Date(year, month, 32).getDate()\r\n const today = new Date();\r\n const btnWidth = 32\r\n const boxWidth = btnWidth * 7\r\n\r\n const showCalendar = () => {\r\n\r\n let firstDay = (new Date(year, month)).getDay();\r\n let rows = []\r\n\r\n let date = 1;\r\n for (let i = 0; i < 6; i++) {\r\n let row = []\r\n for (let j = 0; j < 7; j++) {\r\n if (i === 0 && j < firstDay) {\r\n row.push(<Stack\r\n width={btnWidth}\r\n height={btnWidth}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n key={date + j + i}\r\n >\r\n </Stack>)\r\n } else if (date > daysInMonth) {\r\n break;\r\n } else {\r\n let isToday = date === today.getDate() && year === today.getFullYear() && month === today.getMonth()\r\n let isSelected = date === selectedDate.getDate() && year === selectedDate.getFullYear() && month === selectedDate.getMonth()\r\n\r\n let css: any = {}\r\n if (isToday) {\r\n css = {\r\n variant: \"outline\",\r\n color: color\r\n }\r\n }\r\n\r\n if (isSelected) {\r\n css = {\r\n variant: \"fill\",\r\n color: color\r\n }\r\n }\r\n\r\n row.push(<Stack\r\n sx={{\r\n width: btnWidth,\r\n height: btnWidth,\r\n alignItems: \"center\",\r\n justifyContent: \"center\"\r\n }}\r\n key={date + j + i}\r\n className='calender-day-item'\r\n >\r\n <IconButton\r\n className='calender-day-button'\r\n variant={isSelected ? \"fill\" : \"text\"}\r\n color={isToday ? color : \"default\"}\r\n {...css}\r\n data-value={date}\r\n onClick={(e: any) => {\r\n let d = e.target.getAttribute(\"data-value\")\r\n if (!d) return\r\n let selectedDate = new Date(year, month, parseInt(d))\r\n onChange ? onChange(selectedDate) : setSelectedDate(selectedDate)\r\n onButtonClick && onButtonClick(\"day\", selectedDate)\r\n }}\r\n >\r\n {date}\r\n </IconButton>\r\n </Stack>)\r\n date++;\r\n }\r\n }\r\n rows.push(<Stack flexRow key={\"row\" + i} className='calender-day-row'>\r\n {row}\r\n </Stack>);\r\n }\r\n return rows\r\n }\r\n\r\n const showMonth = () => {\r\n let months: any[] = []\r\n const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\r\n for (let m = 0; m < monthNames.length; m++) {\r\n const selected = currentDate.getMonth() === m\r\n\r\n months.push(<Stack\r\n key={m}\r\n width={(boxWidth - 12) / 2}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n p={.1}\r\n className='calender-months-item'\r\n >\r\n <Button\r\n color={selected ? color : \"default\"}\r\n className='calender-month-button'\r\n size='small'\r\n corner=\"circle\"\r\n variant={selected ? \"fill\" : 'text'}\r\n onClick={() => {\r\n const v = new Date(currentDate.getFullYear(), m)\r\n setCurrentDate(v)\r\n setViewMode(\"day\")\r\n onButtonClick && onButtonClick(\"month\", v)\r\n }}\r\n sx={{\r\n color: selected ? \"brand.text\" : \"text.primary\"\r\n }}\r\n >\r\n {monthNames[m]}\r\n </Button>\r\n </Stack>)\r\n }\r\n\r\n return (\r\n <Stack\r\n className='calender-months'\r\n sx={{\r\n flexWrap: \"wrap\",\r\n overflow: \"hidden\",\r\n overflowY: \"auto\",\r\n flexDirection: \"row\"\r\n }}\r\n >\r\n {months}\r\n </Stack>\r\n )\r\n }\r\n\r\n let view: any = null\r\n switch (viewMode) {\r\n case \"year\":\r\n view = <ShowYears\r\n color={color}\r\n today={today}\r\n year={year}\r\n boxWidth={boxWidth}\r\n onClick={(y: any) => {\r\n currentDate.setFullYear(y)\r\n setCurrentDate(currentDate)\r\n setViewMode(\"month\")\r\n onButtonClick && onButtonClick(\"year\", currentDate)\r\n }}\r\n />\r\n break;\r\n case \"month\":\r\n view = showMonth()\r\n break;\r\n default:\r\n view = (<>\r\n <Stack flexRow className='calender-week-container'>\r\n {\r\n ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (\r\n <Stack\r\n key={day + idx}\r\n width={btnWidth}\r\n height={btnWidth}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n >\r\n <Text\r\n fontWeight={500}\r\n fontSize=\"button\"\r\n color=\"text.secondary\"\r\n >\r\n {day}\r\n </Text>\r\n </Stack>\r\n ))\r\n }\r\n </Stack>\r\n {showCalendar()}\r\n </>\r\n )\r\n break;\r\n }\r\n\r\n return (\r\n <ViewBox\r\n className='calender-root'\r\n maxHeight={308}\r\n width={250}\r\n radius={1}\r\n bgcolor=\"background.primary\"\r\n startContent={\r\n <Stack className='calender-header' flexRow alignItems=\"center\" justifyContent=\"space-between\" p={1}>\r\n <Text\r\n fontWeight=\"bold\"\r\n cursor=\"pointer\"\r\n onClick={() => setViewMode(viewMode !== 'day' ? \"day\" : \"year\")}\r\n flex={1}\r\n >\r\n {currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' })}\r\n </Text>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date())\r\n onChange ? onChange(new Date()) : setSelectedDate(new Date())\r\n }}\r\n >\r\n <ResetIcon fontSize={20} />\r\n </IconButton>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1))\r\n }}\r\n >\r\n <IconKeyboardArrowLeft />\r\n </IconButton>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1))\r\n }}\r\n >\r\n <IconKeyboardArrowRight />\r\n </IconButton>\r\n </Stack>\r\n }\r\n >\r\n <Stack height=\"100%\" p={.5} className='calender-container'>\r\n {view}\r\n </Stack>\r\n </ViewBox>\r\n );\r\n};\r\n\r\nexport default Calendar;"],"names":[],"mappings":";;;;;;;;;;;;;;AAqBA;;AAEI;AACA;AACI;AACA;AAGQ;AACA;AACA;AACA;AACH;;;;;;;AAuBT;AAGY;AACA;AACA;AACA;AACH;AAMb;AAGA;AAAkB;;;AAGd;AAAW;AACX;AAAW;AACX;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAII;;;AAIA;;AAEI;;AAEQ;;AAQG;;;;;;;;AAQC;AACI;AACA;;;;AAKJ;AACI;AACA;;;AAIR;AAEQ;AACA;AACA;AACA;;;AAaI;;AACA;AACA;AACA;;AAMZ;;;AAGR;;AAIJ;AACJ;;;;AAKI;;AAGI;AAeY;;;AAGA;;;;;;AAeJ;AACA;AACA;AACA;;AAMhB;;;AAII;;AAOY;;;AAGA;AACJ;;AAGR;;;AAGA;AACI;;;;AAkDgB;AACA;AACJ;AASI;;AAUA;;AAa5B;;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Calendar/index.tsx"],"sourcesContent":["\"use client\";\nimport { useEffect, useRef, useState } from 'react';\nimport Stack from '../Stack'\nimport IconButton from '../IconButton';\nimport IconKeyboardArrowRight from '@xanui/icons/KeyboardArrowRight';\nimport IconKeyboardArrowLeft from '@xanui/icons/KeyboardArrowLeft';\nimport Text from '../Text';\nimport Button from '../Button';\nimport ResetIcon from '@xanui/icons/Replay';\nimport ViewBox from '../ViewBox';\nimport { UseColorTemplateColor, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\n\nexport type CalendarProps = {\n value?: Date | null;\n onChange?: (date: Date | null) => void;\n viewMode?: useBreakpointPropsType<\"year\" | \"month\" | \"day\">;\n onButtonClick?: (mode: CalendarProps[\"viewMode\"], value: CalendarProps[\"value\"]) => void;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n}\n\n\nconst ShowYears = ({ color, year, today, boxWidth, onClick }: any) => {\n let years: any[] = []\n const selectedRef: any = useRef(null)\n for (let y = 1900; y < today.getFullYear() + 40; y++) {\n const selected = year == y\n years.push(<Stack\n key={y}\n sx={{\n width: (boxWidth - 12) / 3,\n alignItems: \"center\",\n justifyContent: \"center\",\n p: .1\n }}\n className='calender-year-item'\n >\n <Button\n color={selected ? color : \"default\"}\n className='calender-year-button'\n size='small'\n corner=\"circle\"\n ref={selected ? selectedRef : null}\n onClick={() => onClick(y)}\n variant={selected ? \"fill\" : \"text\"}\n >\n {y}\n </Button>\n </Stack>)\n }\n\n useEffect(() => {\n if (selectedRef?.current) {\n selectedRef?.current.scrollIntoView({ behavior: \"smooth\", block: \"center\", inline: \"nearest\" })\n }\n }, [])\n\n return (\n <Stack\n sx={{\n flexWrap: \"wrap\",\n flexDirection: \"row\",\n overflow: \"hidden\",\n overflowY: \"auto\"\n }}\n className='calender-years'\n >\n {years}\n </Stack>\n )\n}\n\n\nconst Calendar = ({ value, ...rest }: CalendarProps) => {\n let [{ onChange, viewMode: VMode, onButtonClick, color }] = useInterface<any>(\"Calender\", rest, {})\n const _p: any = {}\n if (VMode) _p.VMode = VMode\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n color = p.color || \"brand\"\n\n let [viewMode, setViewMode] = useState<any>(p.VMode || \"day\");\n let [selectedDate, setSelectedDate] = useState(new Date());\n selectedDate = value instanceof Date ? value : selectedDate\n const [currentDate, setCurrentDate] = useState(selectedDate);\n const year = currentDate.getFullYear()\n const month = currentDate.getMonth()\n const daysInMonth = 32 - new Date(year, month, 32).getDate()\n const today = new Date();\n const btnWidth = 32\n const boxWidth = btnWidth * 7\n\n const showCalendar = () => {\n\n let firstDay = (new Date(year, month)).getDay();\n let rows = []\n\n let date = 1;\n for (let i = 0; i < 6; i++) {\n let row = []\n for (let j = 0; j < 7; j++) {\n if (i === 0 && j < firstDay) {\n row.push(<Stack\n width={btnWidth}\n height={btnWidth}\n alignItems=\"center\"\n justifyContent=\"center\"\n key={date + j + i}\n >\n </Stack>)\n } else if (date > daysInMonth) {\n break;\n } else {\n let isToday = date === today.getDate() && year === today.getFullYear() && month === today.getMonth()\n let isSelected = date === selectedDate.getDate() && year === selectedDate.getFullYear() && month === selectedDate.getMonth()\n\n let css: any = {}\n if (isToday) {\n css = {\n variant: \"outline\",\n color: color\n }\n }\n\n if (isSelected) {\n css = {\n variant: \"fill\",\n color: color\n }\n }\n\n row.push(<Stack\n sx={{\n width: btnWidth,\n height: btnWidth,\n alignItems: \"center\",\n justifyContent: \"center\"\n }}\n key={date + j + i}\n className='calender-day-item'\n >\n <IconButton\n className='calender-day-button'\n variant={isSelected ? \"fill\" : \"text\"}\n color={isToday ? color : \"default\"}\n {...css}\n data-value={date}\n onClick={(e: any) => {\n let d = e.target.getAttribute(\"data-value\")\n if (!d) return\n let selectedDate = new Date(year, month, parseInt(d))\n onChange ? onChange(selectedDate) : setSelectedDate(selectedDate)\n onButtonClick && onButtonClick(\"day\", selectedDate)\n }}\n >\n {date}\n </IconButton>\n </Stack>)\n date++;\n }\n }\n rows.push(<Stack flexRow key={\"row\" + i} className='calender-day-row'>\n {row}\n </Stack>);\n }\n return rows\n }\n\n const showMonth = () => {\n let months: any[] = []\n const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\n for (let m = 0; m < monthNames.length; m++) {\n const selected = currentDate.getMonth() === m\n\n months.push(<Stack\n key={m}\n width={(boxWidth - 12) / 2}\n alignItems=\"center\"\n justifyContent=\"center\"\n p={.1}\n className='calender-months-item'\n >\n <Button\n color={selected ? color : \"default\"}\n className='calender-month-button'\n size='small'\n corner=\"circle\"\n variant={selected ? \"fill\" : 'text'}\n onClick={() => {\n const v = new Date(currentDate.getFullYear(), m)\n setCurrentDate(v)\n setViewMode(\"day\")\n onButtonClick && onButtonClick(\"month\", v)\n }}\n sx={{\n color: selected ? \"brand.text\" : \"text.primary\"\n }}\n >\n {monthNames[m]}\n </Button>\n </Stack>)\n }\n\n return (\n <Stack\n className='calender-months'\n sx={{\n flexWrap: \"wrap\",\n overflow: \"hidden\",\n overflowY: \"auto\",\n flexDirection: \"row\"\n }}\n >\n {months}\n </Stack>\n )\n }\n\n let view: any = null\n switch (viewMode) {\n case \"year\":\n view = <ShowYears\n color={color}\n today={today}\n year={year}\n boxWidth={boxWidth}\n onClick={(y: any) => {\n currentDate.setFullYear(y)\n setCurrentDate(currentDate)\n setViewMode(\"month\")\n onButtonClick && onButtonClick(\"year\", currentDate)\n }}\n />\n break;\n case \"month\":\n view = showMonth()\n break;\n default:\n view = (<>\n <Stack flexRow className='calender-week-container'>\n {\n ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (\n <Stack\n key={day + idx}\n width={btnWidth}\n height={btnWidth}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Text\n fontWeight={500}\n fontSize=\"button\"\n color=\"text.secondary\"\n >\n {day}\n </Text>\n </Stack>\n ))\n }\n </Stack>\n {showCalendar()}\n </>\n )\n break;\n }\n\n return (\n <ViewBox\n className='calender-root'\n maxHeight={308}\n width={250}\n radius={1}\n bgcolor=\"background.primary\"\n startContent={\n <Stack className='calender-header' flexRow alignItems=\"center\" justifyContent=\"space-between\" p={1}>\n <Text\n fontWeight=\"bold\"\n cursor=\"pointer\"\n onClick={() => setViewMode(viewMode !== 'day' ? \"day\" : \"year\")}\n flex={1}\n >\n {currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' })}\n </Text>\n <IconButton\n color=\"default\"\n variant='text'\n size={28}\n onClick={() => {\n setCurrentDate(new Date())\n onChange ? onChange(new Date()) : setSelectedDate(new Date())\n }}\n >\n <ResetIcon fontSize={20} />\n </IconButton>\n <IconButton\n color=\"default\"\n variant='text'\n size={28}\n onClick={() => {\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1))\n }}\n >\n <IconKeyboardArrowLeft />\n </IconButton>\n <IconButton\n color=\"default\"\n variant='text'\n size={28}\n onClick={() => {\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1))\n }}\n >\n <IconKeyboardArrowRight />\n </IconButton>\n </Stack>\n }\n >\n <Stack height=\"100%\" p={.5} className='calender-container'>\n {view}\n </Stack>\n </ViewBox>\n );\n};\n\nexport default Calendar;"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
@@ -1,30 +1,11 @@
1
- "use client";
2
- 'use strict';
3
-
4
- var tslib = require('tslib');
5
- var jsxRuntime = require('react/jsx-runtime');
6
- var index = require('../Input/index.js');
7
- var index$3 = require('../Menu/index.js');
8
- var React = require('react');
9
- var index$5 = require('../Calendar/index.js');
10
- var index$1 = require('../Stack/index.js');
11
- var index$4 = require('../ClickOutside/index.js');
12
- var CalendarIcon = require('@xanui/icons/CalendarMonth');
13
- var index$2 = require('../IconButton/index.js');
14
- var ClearIcon = require('@xanui/icons/Clear');
15
- var core = require('@xanui/core');
16
-
17
- const CalenderInput = (props) => {
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),index=require('../Input/index.js'),index$3=require('../Menu/index.js'),React=require('react'),index$5=require('../Calendar/index.js'),index$1=require('../Stack/index.js'),index$4=require('../ClickOutside/index.js'),CalendarIcon=require('@xanui/icons/CalendarMonth'),index$2=require('../IconButton/index.js'),ClearIcon=require('@xanui/icons/Clear'),core=require('@xanui/core');const CalenderInput = (props) => {
18
2
  let [_a] = core.useInterface("CanlendarInput", props, {}), { value, onChange, getInputValue, slotProps, placeholder } = _a, inputProps = tslib.__rest(_a, ["value", "onChange", "getInputValue", "slotProps", "placeholder"]);
19
3
  const [target, setTarget] = React.useState();
20
4
  const inputRef = React.useRef(null);
21
- return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index, Object.assign({ readOnly: true, onClick: () => setTarget(target ? null : inputRef === null || inputRef === void 0 ? void 0 : inputRef.current), startIcon: jsxRuntime.jsx(CalendarIcon, {}) }, inputProps, { endIcon: jsxRuntime.jsx(jsxRuntime.Fragment, { children: value && jsxRuntime.jsx(index$1, { children: jsxRuntime.jsx(index$2, { color: "default", size: 28, variant: "text", onClick: () => {
5
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index.default, Object.assign({ readOnly: true, onClick: () => setTarget(target ? null : inputRef === null || inputRef === void 0 ? void 0 : inputRef.current), startIcon: jsxRuntime.jsx(CalendarIcon, {}) }, inputProps, { endIcon: jsxRuntime.jsx(jsxRuntime.Fragment, { children: value && jsxRuntime.jsx(index$1.default, { children: jsxRuntime.jsx(index$2.default, { color: "default", size: 28, variant: "text", onClick: () => {
22
6
  onChange && onChange(null);
23
- }, children: jsxRuntime.jsx(ClearIcon, { fontSize: 20 }) }) }) }), cursor: "pointer", containerRef: inputRef, value: getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString("en-US") : "") })), jsxRuntime.jsx(index$3, Object.assign({ target: target, placement: "bottom-left", bgcolor: "transparent" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.menu, { children: jsxRuntime.jsx(index$4, { onClickOutside: () => setTarget(null), children: jsxRuntime.jsx(index$5, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.calender, { value: value, onChange: (e) => {
7
+ }, children: jsxRuntime.jsx(ClearIcon, { fontSize: 20 }) }) }) }), cursor: "pointer", containerRef: inputRef, value: getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString("en-US") : "") })), jsxRuntime.jsx(index$3.default, Object.assign({ target: target, placement: "bottom-left", bgcolor: "transparent" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.menu, { children: jsxRuntime.jsx(index$4.default, { onClickOutside: () => setTarget(null), children: jsxRuntime.jsx(index$5.default, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.calender, { value: value, onChange: (e) => {
24
8
  setTarget(null);
25
9
  onChange && onChange(e);
26
10
  } })) }) }))] }));
27
- };
28
-
29
- module.exports = CalenderInput;
30
- //# sourceMappingURL=index.js.map
11
+ };exports.default=CalenderInput;//# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/CalendarInput/index.tsx"],"sourcesContent":["\"use client\";\r\nimport Input, { InputProps } from '../Input'\r\nimport Menu, { MenuProps } from '../Menu'\r\nimport { useRef, useState } from 'react'\r\nimport Calendar, { CalendarProps } from '../Calendar'\r\nimport Stack from '../Stack'\r\nimport ClickOutside from '../ClickOutside'\r\nimport CalendarIcon from '@xanui/icons/CalendarMonth';\r\nimport IconButton from '../IconButton'\r\nimport ClearIcon from '@xanui/icons/Clear';\r\nimport { useInterface } from '@xanui/core'\r\n\r\nexport type CalenderInpurProps = Omit<InputProps, \"value\" | \"onChange\" | \"slotProps\"> & {\r\n value?: CalendarProps[\"value\"];\r\n onChange?: CalendarProps[\"onChange\"];\r\n getInputValue?: (value?: Date | null) => string;\r\n slotProps?: {\r\n input?: InputProps['slotProps'];\r\n calender?: CalendarProps;\r\n menu?: MenuProps;\r\n }\r\n}\r\n\r\nconst CalenderInput = (props: CalenderInpurProps) => {\r\n let [{ value, onChange, getInputValue, slotProps, placeholder, ...inputProps }] = useInterface<any>(\"CanlendarInput\", props, {})\r\n const [target, setTarget] = useState<any>()\r\n const inputRef: any = useRef(null)\r\n\r\n return (\r\n <>\r\n <Input\r\n readOnly\r\n onClick={() => setTarget(target ? null : inputRef?.current)}\r\n startIcon={<CalendarIcon />}\r\n {...inputProps}\r\n endIcon={<>\r\n {value && <Stack>\r\n <IconButton\r\n color=\"default\"\r\n size={28}\r\n variant=\"text\"\r\n onClick={() => {\r\n onChange && onChange(null)\r\n }}\r\n >\r\n <ClearIcon fontSize={20} />\r\n </IconButton>\r\n </Stack>}\r\n </>}\r\n cursor=\"pointer\"\r\n containerRef={inputRef}\r\n value={getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString(\"en-US\") : \"\")}\r\n />\r\n <Menu\r\n target={target}\r\n placement=\"bottom-left\"\r\n bgcolor=\"transparent\"\r\n {...slotProps?.menu}\r\n >\r\n <ClickOutside onClickOutside={() => setTarget(null)}>\r\n <Calendar\r\n {...slotProps?.calender}\r\n value={value}\r\n onChange={(e) => {\r\n setTarget(null)\r\n onChange && onChange(e)\r\n }}\r\n />\r\n </ClickOutside>\r\n </Menu>\r\n </>\r\n )\r\n}\r\n\r\nexport default CalenderInput"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAuBA;;;AAGI;AAEA;AAc4B;;;AAuBJ;AACJ;AAMxB;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/CalendarInput/index.tsx"],"sourcesContent":["\"use client\";\nimport Input, { InputProps } from '../Input'\nimport Menu, { MenuProps } from '../Menu'\nimport { useRef, useState } from 'react'\nimport Calendar, { CalendarProps } from '../Calendar'\nimport Stack from '../Stack'\nimport ClickOutside from '../ClickOutside'\nimport CalendarIcon from '@xanui/icons/CalendarMonth';\nimport IconButton from '../IconButton'\nimport ClearIcon from '@xanui/icons/Clear';\nimport { useInterface } from '@xanui/core'\n\nexport type CalenderInpurProps = Omit<InputProps, \"value\" | \"onChange\" | \"slotProps\"> & {\n value?: CalendarProps[\"value\"];\n onChange?: CalendarProps[\"onChange\"];\n getInputValue?: (value?: Date | null) => string;\n slotProps?: {\n input?: InputProps['slotProps'];\n calender?: CalendarProps;\n menu?: MenuProps;\n }\n}\n\nconst CalenderInput = (props: CalenderInpurProps) => {\n let [{ value, onChange, getInputValue, slotProps, placeholder, ...inputProps }] = useInterface<any>(\"CanlendarInput\", props, {})\n const [target, setTarget] = useState<any>()\n const inputRef: any = useRef(null)\n\n return (\n <>\n <Input\n readOnly\n onClick={() => setTarget(target ? null : inputRef?.current)}\n startIcon={<CalendarIcon />}\n {...inputProps}\n endIcon={<>\n {value && <Stack>\n <IconButton\n color=\"default\"\n size={28}\n variant=\"text\"\n onClick={() => {\n onChange && onChange(null)\n }}\n >\n <ClearIcon fontSize={20} />\n </IconButton>\n </Stack>}\n </>}\n cursor=\"pointer\"\n containerRef={inputRef}\n value={getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString(\"en-US\") : \"\")}\n />\n <Menu\n target={target}\n placement=\"bottom-left\"\n bgcolor=\"transparent\"\n {...slotProps?.menu}\n >\n <ClickOutside onClickOutside={() => setTarget(null)}>\n <Calendar\n {...slotProps?.calender}\n value={value}\n onChange={(e) => {\n setTarget(null)\n onChange && onChange(e)\n }}\n />\n </ClickOutside>\n </Menu>\n </>\n )\n}\n\nexport default CalenderInput"],"names":["useInterface","__rest","useState","useRef","_jsxs","_Fragment","_jsx","Input","Stack","IconButton","Menu","ClickOutside","Calendar"],"mappings":"igBAuBA,MAAM,aAAa,GAAG,CAAC,KAAyB,KAAI;IAChD,IAAI,CAAA,EAAA,CAAA,GAA8EA,iBAAY,CAAM,gBAAgB,EAAE,KAAK,EAAE,EAAE,CAAC,EAA3H,EAAE,KAAK,EAAE,QAAQ,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAA,GAAA,EAAiB,EAAZ,UAAU,GAAAC,YAAA,CAAA,EAAA,EAAvE,CAAA,OAAA,EAAA,UAAA,EAAA,eAAA,EAAA,WAAA,EAAA,aAAA,CAAyE,CAAkD;IAChI,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAGC,cAAQ,EAAO;AAC3C,IAAA,MAAM,QAAQ,GAAQC,YAAM,CAAC,IAAI,CAAC;AAElC,IAAA,QACIC,eAAA,CAAAC,mBAAA,EAAA,EAAA,QAAA,EAAA,CACIC,cAAA,CAACC,aAAK,EAAA,MAAA,CAAA,MAAA,CAAA,EACF,QAAQ,EAAA,IAAA,EACR,OAAO,EAAE,MAAM,SAAS,CAAC,MAAM,GAAG,IAAI,GAAG,QAAQ,KAAA,IAAA,IAAR,QAAQ,KAAA,MAAA,GAAA,MAAA,GAAR,QAAQ,CAAE,OAAO,CAAC,EAC3D,SAAS,EAAED,cAAA,CAAC,YAAY,EAAA,EAAA,CAAG,EAAA,EACvB,UAAU,EAAA,EACd,OAAO,EAAEA,cAAA,CAAAD,mBAAA,EAAA,EAAA,QAAA,EACJ,KAAK,IAAIC,cAAA,CAACE,eAAK,cACZF,cAAA,CAACG,eAAU,EAAA,EACP,KAAK,EAAC,SAAS,EACf,IAAI,EAAE,EAAE,EACR,OAAO,EAAC,MAAM,EACd,OAAO,EAAE,MAAK;AACV,gCAAA,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC;4BAC9B,CAAC,EAAA,QAAA,EAEDH,eAAC,SAAS,EAAA,EAAC,QAAQ,EAAE,EAAE,EAAA,CAAI,EAAA,CAClB,EAAA,CACT,EAAA,CACT,EACH,MAAM,EAAC,SAAS,EAChB,YAAY,EAAE,QAAQ,EACtB,KAAK,EAAE,aAAa,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,KAAK,GAAG,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAA,CAAA,CAChG,EACFA,cAAA,CAACI,eAAI,kBACD,MAAM,EAAE,MAAM,EACd,SAAS,EAAC,aAAa,EACvB,OAAO,EAAC,aAAa,EAAA,EACjB,SAAS,aAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,IAAI,EAAA,EAAA,QAAA,EAEnBJ,eAACK,eAAY,EAAA,EAAC,cAAc,EAAE,MAAM,SAAS,CAAC,IAAI,CAAC,EAAA,QAAA,EAC/CL,cAAA,CAACM,eAAQ,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACD,SAAS,KAAA,IAAA,IAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,QAAQ,EAAA,EACvB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,KAAI;4BACZ,SAAS,CAAC,IAAI,CAAC;AACf,4BAAA,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC;AAC3B,wBAAA,CAAC,EAAA,CAAA,CACH,EAAA,CACS,EAAA,CAAA,CACZ,CAAA,EAAA,CACR;AAEX"}
@@ -1,18 +1,4 @@
1
- "use client";
2
- import { __rest } from 'tslib';
3
- import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
4
- import Input from '../Input/index.mjs';
5
- import Menu from '../Menu/index.mjs';
6
- import { useState, useRef } from 'react';
7
- import Calendar from '../Calendar/index.mjs';
8
- import Stack from '../Stack/index.mjs';
9
- import ClickOutside from '../ClickOutside/index.mjs';
10
- import CalendarIcon from '@xanui/icons/CalendarMonth';
11
- import IconButton from '../IconButton/index.mjs';
12
- import ClearIcon from '@xanui/icons/Clear';
13
- import { useInterface } from '@xanui/core';
14
-
15
- const CalenderInput = (props) => {
1
+ import {__rest}from'tslib';import {jsxs,Fragment,jsx}from'react/jsx-runtime';import Input from'../Input/index.mjs';import Menu from'../Menu/index.mjs';import {useState,useRef}from'react';import Calendar from'../Calendar/index.mjs';import Stack from'../Stack/index.mjs';import ClickOutside from'../ClickOutside/index.mjs';import CalendarIcon from'@xanui/icons/CalendarMonth';import IconButton from'../IconButton/index.mjs';import ClearIcon from'@xanui/icons/Clear';import {useInterface}from'@xanui/core';const CalenderInput = (props) => {
16
2
  let [_a] = useInterface("CanlendarInput", props, {}), { value, onChange, getInputValue, slotProps, placeholder } = _a, inputProps = __rest(_a, ["value", "onChange", "getInputValue", "slotProps", "placeholder"]);
17
3
  const [target, setTarget] = useState();
18
4
  const inputRef = useRef(null);
@@ -22,7 +8,4 @@ const CalenderInput = (props) => {
22
8
  setTarget(null);
23
9
  onChange && onChange(e);
24
10
  } })) }) }))] }));
25
- };
26
-
27
- export { CalenderInput as default };
28
- //# sourceMappingURL=index.mjs.map
11
+ };export{CalenderInput as default};//# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/CalendarInput/index.tsx"],"sourcesContent":["\"use client\";\r\nimport Input, { InputProps } from '../Input'\r\nimport Menu, { MenuProps } from '../Menu'\r\nimport { useRef, useState } from 'react'\r\nimport Calendar, { CalendarProps } from '../Calendar'\r\nimport Stack from '../Stack'\r\nimport ClickOutside from '../ClickOutside'\r\nimport CalendarIcon from '@xanui/icons/CalendarMonth';\r\nimport IconButton from '../IconButton'\r\nimport ClearIcon from '@xanui/icons/Clear';\r\nimport { useInterface } from '@xanui/core'\r\n\r\nexport type CalenderInpurProps = Omit<InputProps, \"value\" | \"onChange\" | \"slotProps\"> & {\r\n value?: CalendarProps[\"value\"];\r\n onChange?: CalendarProps[\"onChange\"];\r\n getInputValue?: (value?: Date | null) => string;\r\n slotProps?: {\r\n input?: InputProps['slotProps'];\r\n calender?: CalendarProps;\r\n menu?: MenuProps;\r\n }\r\n}\r\n\r\nconst CalenderInput = (props: CalenderInpurProps) => {\r\n let [{ value, onChange, getInputValue, slotProps, placeholder, ...inputProps }] = useInterface<any>(\"CanlendarInput\", props, {})\r\n const [target, setTarget] = useState<any>()\r\n const inputRef: any = useRef(null)\r\n\r\n return (\r\n <>\r\n <Input\r\n readOnly\r\n onClick={() => setTarget(target ? null : inputRef?.current)}\r\n startIcon={<CalendarIcon />}\r\n {...inputProps}\r\n endIcon={<>\r\n {value && <Stack>\r\n <IconButton\r\n color=\"default\"\r\n size={28}\r\n variant=\"text\"\r\n onClick={() => {\r\n onChange && onChange(null)\r\n }}\r\n >\r\n <ClearIcon fontSize={20} />\r\n </IconButton>\r\n </Stack>}\r\n </>}\r\n cursor=\"pointer\"\r\n containerRef={inputRef}\r\n value={getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString(\"en-US\") : \"\")}\r\n />\r\n <Menu\r\n target={target}\r\n placement=\"bottom-left\"\r\n bgcolor=\"transparent\"\r\n {...slotProps?.menu}\r\n >\r\n <ClickOutside onClickOutside={() => setTarget(null)}>\r\n <Calendar\r\n {...slotProps?.calender}\r\n value={value}\r\n onChange={(e) => {\r\n setTarget(null)\r\n onChange && onChange(e)\r\n }}\r\n />\r\n </ClickOutside>\r\n </Menu>\r\n </>\r\n )\r\n}\r\n\r\nexport default CalenderInput"],"names":[],"mappings":";;;;;;;;;;;;;;AAuBA;;;AAGI;AAEA;AAc4B;;;AAuBJ;AACJ;AAMxB;;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/CalendarInput/index.tsx"],"sourcesContent":["\"use client\";\nimport Input, { InputProps } from '../Input'\nimport Menu, { MenuProps } from '../Menu'\nimport { useRef, useState } from 'react'\nimport Calendar, { CalendarProps } from '../Calendar'\nimport Stack from '../Stack'\nimport ClickOutside from '../ClickOutside'\nimport CalendarIcon from '@xanui/icons/CalendarMonth';\nimport IconButton from '../IconButton'\nimport ClearIcon from '@xanui/icons/Clear';\nimport { useInterface } from '@xanui/core'\n\nexport type CalenderInpurProps = Omit<InputProps, \"value\" | \"onChange\" | \"slotProps\"> & {\n value?: CalendarProps[\"value\"];\n onChange?: CalendarProps[\"onChange\"];\n getInputValue?: (value?: Date | null) => string;\n slotProps?: {\n input?: InputProps['slotProps'];\n calender?: CalendarProps;\n menu?: MenuProps;\n }\n}\n\nconst CalenderInput = (props: CalenderInpurProps) => {\n let [{ value, onChange, getInputValue, slotProps, placeholder, ...inputProps }] = useInterface<any>(\"CanlendarInput\", props, {})\n const [target, setTarget] = useState<any>()\n const inputRef: any = useRef(null)\n\n return (\n <>\n <Input\n readOnly\n onClick={() => setTarget(target ? null : inputRef?.current)}\n startIcon={<CalendarIcon />}\n {...inputProps}\n endIcon={<>\n {value && <Stack>\n <IconButton\n color=\"default\"\n size={28}\n variant=\"text\"\n onClick={() => {\n onChange && onChange(null)\n }}\n >\n <ClearIcon fontSize={20} />\n </IconButton>\n </Stack>}\n </>}\n cursor=\"pointer\"\n containerRef={inputRef}\n value={getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString(\"en-US\") : \"\")}\n />\n <Menu\n target={target}\n placement=\"bottom-left\"\n bgcolor=\"transparent\"\n {...slotProps?.menu}\n >\n <ClickOutside onClickOutside={() => setTarget(null)}>\n <Calendar\n {...slotProps?.calender}\n value={value}\n onChange={(e) => {\n setTarget(null)\n onChange && onChange(e)\n }}\n />\n </ClickOutside>\n </Menu>\n </>\n )\n}\n\nexport default CalenderInput"],"names":["_jsxs","_Fragment","_jsx"],"mappings":"ufAuBA,MAAM,aAAa,GAAG,CAAC,KAAyB,KAAI;IAChD,IAAI,CAAA,EAAA,CAAA,GAA8E,YAAY,CAAM,gBAAgB,EAAE,KAAK,EAAE,EAAE,CAAC,EAA3H,EAAE,KAAK,EAAE,QAAQ,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAA,GAAA,EAAiB,EAAZ,UAAU,GAAA,MAAA,CAAA,EAAA,EAAvE,CAAA,OAAA,EAAA,UAAA,EAAA,eAAA,EAAA,WAAA,EAAA,aAAA,CAAyE,CAAkD;IAChI,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,EAAO;AAC3C,IAAA,MAAM,QAAQ,GAAQ,MAAM,CAAC,IAAI,CAAC;AAElC,IAAA,QACIA,IAAA,CAAAC,QAAA,EAAA,EAAA,QAAA,EAAA,CACIC,GAAA,CAAC,KAAK,EAAA,MAAA,CAAA,MAAA,CAAA,EACF,QAAQ,EAAA,IAAA,EACR,OAAO,EAAE,MAAM,SAAS,CAAC,MAAM,GAAG,IAAI,GAAG,QAAQ,KAAA,IAAA,IAAR,QAAQ,KAAA,MAAA,GAAA,MAAA,GAAR,QAAQ,CAAE,OAAO,CAAC,EAC3D,SAAS,EAAEA,GAAA,CAAC,YAAY,EAAA,EAAA,CAAG,EAAA,EACvB,UAAU,EAAA,EACd,OAAO,EAAEA,GAAA,CAAAD,QAAA,EAAA,EAAA,QAAA,EACJ,KAAK,IAAIC,GAAA,CAAC,KAAK,cACZA,GAAA,CAAC,UAAU,EAAA,EACP,KAAK,EAAC,SAAS,EACf,IAAI,EAAE,EAAE,EACR,OAAO,EAAC,MAAM,EACd,OAAO,EAAE,MAAK;AACV,gCAAA,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC;4BAC9B,CAAC,EAAA,QAAA,EAEDA,IAAC,SAAS,EAAA,EAAC,QAAQ,EAAE,EAAE,EAAA,CAAI,EAAA,CAClB,EAAA,CACT,EAAA,CACT,EACH,MAAM,EAAC,SAAS,EAChB,YAAY,EAAE,QAAQ,EACtB,KAAK,EAAE,aAAa,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,KAAK,GAAG,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAA,CAAA,CAChG,EACFA,GAAA,CAAC,IAAI,kBACD,MAAM,EAAE,MAAM,EACd,SAAS,EAAC,aAAa,EACvB,OAAO,EAAC,aAAa,EAAA,EACjB,SAAS,aAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,IAAI,EAAA,EAAA,QAAA,EAEnBA,IAAC,YAAY,EAAA,EAAC,cAAc,EAAE,MAAM,SAAS,CAAC,IAAI,CAAC,EAAA,QAAA,EAC/CA,GAAA,CAAC,QAAQ,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACD,SAAS,KAAA,IAAA,IAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,QAAQ,EAAA,EACvB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,KAAI;4BACZ,SAAS,CAAC,IAAI,CAAC;AACf,4BAAA,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC;AAC3B,wBAAA,CAAC,EAAA,CAAA,CACH,EAAA,CACS,EAAA,CAAA,CACZ,CAAA,EAAA,CACR;AAEX"}
package/Checkbox/index.js CHANGED
@@ -1,15 +1,4 @@
1
- "use client";
2
- 'use strict';
3
-
4
- var tslib = require('tslib');
5
- var jsxRuntime = require('react/jsx-runtime');
6
- var React = require('react');
7
- var core = require('@xanui/core');
8
- var CheckIcon = require('@xanui/icons/CheckBox');
9
- var UnCheckIcon = require('@xanui/icons/CheckBoxOutlineBlank');
10
- var IndeterminateCheckBoxIcon = require('@xanui/icons/IndeterminateCheckBox');
11
-
12
- const Checkbox = React.forwardRef((props, ref) => {
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),React=require('react'),core=require('@xanui/core'),CheckIcon=require('@xanui/icons/CheckBox'),UnCheckIcon=require('@xanui/icons/CheckBoxOutlineBlank'),IndeterminateCheckBoxIcon=require('@xanui/icons/IndeterminateCheckBox');const Checkbox = React.forwardRef((props, ref) => {
13
2
  let [_a] = core.useInterface("Checkbox", props, {}), { color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange } = _a, rest = tslib.__rest(_a, ["color", "size", "checkIcon", "uncheckIcon", "checked", "indeterminate", "disabled", "onChange"]);
14
3
  const _p = {};
15
4
  if (checkIcon)
@@ -52,7 +41,4 @@ const Checkbox = React.forwardRef((props, ref) => {
52
41
  } }, rest === null || rest === void 0 ? void 0 : rest.sx), children: checked ? (checkIcon || jsxRuntime.jsx(CheckIcon, {})) : (uncheckIcon || jsxRuntime.jsx(UnCheckIcon, {})) }), jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { component: 'input', ref: ref, readOnly: true, type: "checkbox", checked: checked, sxr: {
53
42
  display: "none!important"
54
43
  } }))] }));
55
- });
56
-
57
- module.exports = Checkbox;
58
- //# sourceMappingURL=index.js.map
44
+ });exports.default=Checkbox;//# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { useState, ReactElement } from 'react';\r\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport CheckIcon from '@xanui/icons/CheckBox'\r\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\r\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\r\n\r\n\r\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\r\n checkIcon?: useBreakpointPropsType<ReactElement>;\r\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\r\n indeterminate?: useBreakpointPropsType<boolean>;\r\n checked?: boolean;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\r\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\r\n const _p: any = {}\r\n if (checkIcon) _p.checkIcon = checkIcon\r\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\r\n if (indeterminate) _p.indeterminate = indeterminate\r\n if (size) _p.size = size\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n\r\n checkIcon = p.checkIcon\r\n uncheckIcon = p.uncheckIcon\r\n indeterminate = p.indeterminate\r\n size = p.size\r\n color = p.color\r\n\r\n const [c, set] = useState(false)\r\n checked ??= c\r\n size ??= \"medium\"\r\n color ??= \"brand\"\r\n\r\n onChange = onChange || (() => set(!c));\r\n if (indeterminate) {\r\n checked = true\r\n checkIcon = <IndeterminateCheckBoxIcon />\r\n }\r\n\r\n let sizes: any = {\r\n small: 22,\r\n medium: 24,\r\n large: 32\r\n }\r\n\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n return (\r\n <>\r\n <Tag\r\n baseClass='checkbox'\r\n onClick={() => {\r\n onChange && onChange()\r\n }}\r\n sxr={{\r\n height: size,\r\n width: size,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n color: checked ? color : \"text.secondary\",\r\n cursor: \"pointer\",\r\n disabled: disabled,\r\n \"& svg\": {\r\n fontSize: size\r\n },\r\n ...rest?.sx\r\n }}\r\n >\r\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\r\n </Tag>\r\n <Tag\r\n {...rest}\r\n component='input'\r\n ref={ref}\r\n readOnly\r\n type=\"checkbox\"\r\n checked={checked}\r\n sxr={{\r\n display: \"none!important\"\r\n }}\r\n />\r\n </>\r\n )\r\n})\r\n\r\nexport default Checkbox\r\n"],"names":[],"mappings":";;;;;;;;;;;AAiBA;AACI;;AAEA;AAAe;AACf;AAAiB;AACjB;AAAmB;AACnB;AAAU;AACV;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;;;;;AAOA;;;AAGI;;AAGJ;AACI;AACA;AACA;;;AAIA;;AAGJ;;;AAiBoB;;AAeJ;;AAKpB;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\"use client\";\nimport React, { useState, ReactElement } from 'react';\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport CheckIcon from '@xanui/icons/CheckBox'\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\n\n\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\n checkIcon?: useBreakpointPropsType<ReactElement>;\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\n indeterminate?: useBreakpointPropsType<boolean>;\n checked?: boolean;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n}\n\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\n const _p: any = {}\n if (checkIcon) _p.checkIcon = checkIcon\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\n if (indeterminate) _p.indeterminate = indeterminate\n if (size) _p.size = size\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n\n checkIcon = p.checkIcon\n uncheckIcon = p.uncheckIcon\n indeterminate = p.indeterminate\n size = p.size\n color = p.color\n\n const [c, set] = useState(false)\n checked ??= c\n size ??= \"medium\"\n color ??= \"brand\"\n\n onChange = onChange || (() => set(!c));\n if (indeterminate) {\n checked = true\n checkIcon = <IndeterminateCheckBoxIcon />\n }\n\n let sizes: any = {\n small: 22,\n medium: 24,\n large: 32\n }\n\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n return (\n <>\n <Tag\n baseClass='checkbox'\n onClick={() => {\n onChange && onChange()\n }}\n sxr={{\n height: size,\n width: size,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n color: checked ? color : \"text.secondary\",\n cursor: \"pointer\",\n disabled: disabled,\n \"& svg\": {\n fontSize: size\n },\n ...rest?.sx\n }}\n >\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\n </Tag>\n <Tag\n {...rest}\n component='input'\n ref={ref}\n readOnly\n type=\"checkbox\"\n checked={checked}\n sxr={{\n display: \"none!important\"\n }}\n />\n </>\n )\n})\n\nexport default Checkbox\n"],"names":["useInterface","__rest","useBreakpointProps","useState","_jsx","_jsxs","_Fragment","Tag"],"mappings":"wWAiBA,MAAM,QAAQ,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC,KAAoB,EAAE,GAAoB,KAAI;AAC7E,IAAA,IAAI,CAAA,EAAA,CAAA,GAAiGA,iBAAY,CAAM,UAAU,EAAE,KAAK,EAAE,EAAE,CAAC,EAAxI,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,QAAQ,EAAA,GAAA,EAAW,EAAN,IAAI,GAAAC,YAAA,CAAA,EAAA,EAA1F,CAAA,OAAA,EAAA,MAAA,EAAA,WAAA,EAAA,aAAA,EAAA,SAAA,EAAA,eAAA,EAAA,UAAA,EAAA,UAAA,CAA4F,CAA4C;IAC7I,MAAM,EAAE,GAAQ,EAAE;AAClB,IAAA,IAAI,SAAS;AAAE,QAAA,EAAE,CAAC,SAAS,GAAG,SAAS;AACvC,IAAA,IAAI,WAAW;AAAE,QAAA,EAAE,CAAC,WAAW,GAAG,WAAW;AAC7C,IAAA,IAAI,aAAa;AAAE,QAAA,EAAE,CAAC,aAAa,GAAG,aAAa;AACnD,IAAA,IAAI,IAAI;AAAE,QAAA,EAAE,CAAC,IAAI,GAAG,IAAI;AACxB,IAAA,IAAI,KAAK;AAAE,QAAA,EAAE,CAAC,KAAK,GAAG,KAAK;AAC3B,IAAA,MAAM,CAAC,GAAQC,uBAAkB,CAAC,EAAE,CAAC;AAErC,IAAA,SAAS,GAAG,CAAC,CAAC,SAAS;AACvB,IAAA,WAAW,GAAG,CAAC,CAAC,WAAW;AAC3B,IAAA,aAAa,GAAG,CAAC,CAAC,aAAa;AAC/B,IAAA,IAAI,GAAG,CAAC,CAAC,IAAI;AACb,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK;IAEf,MAAM,CAAC,CAAC,EAAE,GAAG,CAAC,GAAGC,cAAQ,CAAC,KAAK,CAAC;IAChC,OAAO,KAAA,IAAA,IAAP,OAAO,KAAA,MAAA,GAAP,OAAO,IAAP,OAAO,GAAK,CAAC,CAAA;IACb,IAAI,KAAA,IAAA,IAAJ,IAAI,KAAA,MAAA,GAAJ,IAAI,IAAJ,IAAI,GAAK,QAAQ,CAAA;IACjB,KAAK,KAAA,IAAA,IAAL,KAAK,KAAA,MAAA,GAAL,KAAK,IAAL,KAAK,GAAK,OAAO,CAAA;AAEjB,IAAA,QAAQ,GAAG,QAAQ,KAAK,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,IAAI,aAAa,EAAE;QACf,OAAO,GAAG,IAAI;AACd,QAAA,SAAS,GAAGC,cAAA,CAAC,yBAAyB,EAAA,EAAA,CAAG;IAC7C;AAEA,IAAA,IAAI,KAAK,GAAQ;AACb,QAAA,KAAK,EAAE,EAAE;AACT,QAAA,MAAM,EAAE,EAAE;AACV,QAAA,KAAK,EAAE;KACV;IAED,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,KAAK,CAAC,IAAI,CAAC,EAAE;AACzC,QAAA,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;IACtB;AAEA,IAAA,QACIC,eAAA,CAAAC,mBAAA,EAAA,EAAA,QAAA,EAAA,CACIF,cAAA,CAACG,QAAG,EAAA,EACA,SAAS,EAAC,UAAU,EACpB,OAAO,EAAE,MAAK;oBACV,QAAQ,IAAI,QAAQ,EAAE;gBAC1B,CAAC,EACD,GAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EACC,MAAM,EAAE,IAAI,EACZ,KAAK,EAAE,IAAI,EACX,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,QAAQ,EACpB,cAAc,EAAE,QAAQ,EACxB,KAAK,EAAE,OAAO,GAAG,KAAK,GAAG,gBAAgB,EACzC,MAAM,EAAE,SAAS,EACjB,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE;AACL,wBAAA,QAAQ,EAAE;qBACb,EAAA,EACE,IAAI,KAAA,IAAA,IAAJ,IAAI,KAAA,MAAA,GAAA,MAAA,GAAJ,IAAI,CAAE,EAAE,CAAA,EAAA,QAAA,EAGd,OAAO,IAAI,SAAS,IAAIH,cAAA,CAAC,SAAS,EAAA,EAAA,CAAG,KAAK,WAAW,IAAIA,cAAA,CAAC,WAAW,KAAG,CAAC,EAAA,CACxE,EACNA,cAAA,CAACG,QAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,IAAI,EAAA,EACR,SAAS,EAAC,OAAO,EACjB,GAAG,EAAE,GAAG,EACR,QAAQ,EAAA,IAAA,EACR,IAAI,EAAC,UAAU,EACf,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE;AACD,oBAAA,OAAO,EAAE;iBACZ,EAAA,CAAA,CACH,CAAA,EAAA,CACH;AAEX,CAAC"}
@@ -1,13 +1,4 @@
1
- "use client";
2
- import { __rest } from 'tslib';
3
- import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
4
- import React, { useState } from 'react';
5
- import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
6
- import CheckIcon from '@xanui/icons/CheckBox';
7
- import UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank';
8
- import IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';
9
-
10
- const Checkbox = React.forwardRef((props, ref) => {
1
+ import {__rest}from'tslib';import {jsx,jsxs,Fragment}from'react/jsx-runtime';import React,{useState}from'react';import {useInterface,useBreakpointProps,Tag}from'@xanui/core';import CheckIcon from'@xanui/icons/CheckBox';import UnCheckIcon from'@xanui/icons/CheckBoxOutlineBlank';import IndeterminateCheckBoxIcon from'@xanui/icons/IndeterminateCheckBox';const Checkbox = React.forwardRef((props, ref) => {
11
2
  let [_a] = useInterface("Checkbox", props, {}), { color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange } = _a, rest = __rest(_a, ["color", "size", "checkIcon", "uncheckIcon", "checked", "indeterminate", "disabled", "onChange"]);
12
3
  const _p = {};
13
4
  if (checkIcon)
@@ -50,7 +41,4 @@ const Checkbox = React.forwardRef((props, ref) => {
50
41
  } }, rest === null || rest === void 0 ? void 0 : rest.sx), children: checked ? (checkIcon || jsx(CheckIcon, {})) : (uncheckIcon || jsx(UnCheckIcon, {})) }), jsx(Tag, Object.assign({}, rest, { component: 'input', ref: ref, readOnly: true, type: "checkbox", checked: checked, sxr: {
51
42
  display: "none!important"
52
43
  } }))] }));
53
- });
54
-
55
- export { Checkbox as default };
56
- //# sourceMappingURL=index.mjs.map
44
+ });export{Checkbox as default};//# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { useState, ReactElement } from 'react';\r\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport CheckIcon from '@xanui/icons/CheckBox'\r\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\r\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\r\n\r\n\r\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\r\n checkIcon?: useBreakpointPropsType<ReactElement>;\r\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\r\n indeterminate?: useBreakpointPropsType<boolean>;\r\n checked?: boolean;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\r\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\r\n const _p: any = {}\r\n if (checkIcon) _p.checkIcon = checkIcon\r\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\r\n if (indeterminate) _p.indeterminate = indeterminate\r\n if (size) _p.size = size\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n\r\n checkIcon = p.checkIcon\r\n uncheckIcon = p.uncheckIcon\r\n indeterminate = p.indeterminate\r\n size = p.size\r\n color = p.color\r\n\r\n const [c, set] = useState(false)\r\n checked ??= c\r\n size ??= \"medium\"\r\n color ??= \"brand\"\r\n\r\n onChange = onChange || (() => set(!c));\r\n if (indeterminate) {\r\n checked = true\r\n checkIcon = <IndeterminateCheckBoxIcon />\r\n }\r\n\r\n let sizes: any = {\r\n small: 22,\r\n medium: 24,\r\n large: 32\r\n }\r\n\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n return (\r\n <>\r\n <Tag\r\n baseClass='checkbox'\r\n onClick={() => {\r\n onChange && onChange()\r\n }}\r\n sxr={{\r\n height: size,\r\n width: size,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n color: checked ? color : \"text.secondary\",\r\n cursor: \"pointer\",\r\n disabled: disabled,\r\n \"& svg\": {\r\n fontSize: size\r\n },\r\n ...rest?.sx\r\n }}\r\n >\r\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\r\n </Tag>\r\n <Tag\r\n {...rest}\r\n component='input'\r\n ref={ref}\r\n readOnly\r\n type=\"checkbox\"\r\n checked={checked}\r\n sxr={{\r\n display: \"none!important\"\r\n }}\r\n />\r\n </>\r\n )\r\n})\r\n\r\nexport default Checkbox\r\n"],"names":[],"mappings":";;;;;;;;;AAiBA;AACI;;AAEA;AAAe;AACf;AAAiB;AACjB;AAAmB;AACnB;AAAU;AACV;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;;;;;AAOA;;;AAGI;;AAGJ;AACI;AACA;AACA;;;AAIA;;AAGJ;;;AAiBoB;;AAeJ;;AAKpB;;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\"use client\";\nimport React, { useState, ReactElement } from 'react';\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport CheckIcon from '@xanui/icons/CheckBox'\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\n\n\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\n checkIcon?: useBreakpointPropsType<ReactElement>;\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\n indeterminate?: useBreakpointPropsType<boolean>;\n checked?: boolean;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n}\n\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\n const _p: any = {}\n if (checkIcon) _p.checkIcon = checkIcon\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\n if (indeterminate) _p.indeterminate = indeterminate\n if (size) _p.size = size\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n\n checkIcon = p.checkIcon\n uncheckIcon = p.uncheckIcon\n indeterminate = p.indeterminate\n size = p.size\n color = p.color\n\n const [c, set] = useState(false)\n checked ??= c\n size ??= \"medium\"\n color ??= \"brand\"\n\n onChange = onChange || (() => set(!c));\n if (indeterminate) {\n checked = true\n checkIcon = <IndeterminateCheckBoxIcon />\n }\n\n let sizes: any = {\n small: 22,\n medium: 24,\n large: 32\n }\n\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n return (\n <>\n <Tag\n baseClass='checkbox'\n onClick={() => {\n onChange && onChange()\n }}\n sxr={{\n height: size,\n width: size,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n color: checked ? color : \"text.secondary\",\n cursor: \"pointer\",\n disabled: disabled,\n \"& svg\": {\n fontSize: size\n },\n ...rest?.sx\n }}\n >\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\n </Tag>\n <Tag\n {...rest}\n component='input'\n ref={ref}\n readOnly\n type=\"checkbox\"\n checked={checked}\n sxr={{\n display: \"none!important\"\n }}\n />\n </>\n )\n})\n\nexport default Checkbox\n"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
package/Chip/index.js CHANGED
@@ -1,12 +1,4 @@
1
- 'use strict';
2
-
3
- var tslib = require('tslib');
4
- var jsxRuntime = require('react/jsx-runtime');
5
- var React = require('react');
6
- var core = require('@xanui/core');
7
- var index = require('../useCorner/index.js');
8
-
9
- const Chip = React.forwardRef((props, ref) => {
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),React=require('react'),core=require('@xanui/core'),index=require('../useCorner/index.js');const Chip = React.forwardRef((props, ref) => {
10
2
  let [_a] = core.useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = tslib.__rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
11
3
  const _p = {};
12
4
  if (label)
@@ -32,7 +24,7 @@ const Chip = React.forwardRef((props, ref) => {
32
24
  corner = p.corner || "circle";
33
25
  size = p.size || "medium";
34
26
  rest.sx = rest.sx || {};
35
- const cornerCss = index(corner);
27
+ const cornerCss = index.default(corner);
36
28
  const template = core.useColorTemplate(color, variant);
37
29
  const sizes = {
38
30
  small: {
@@ -70,7 +62,4 @@ const Chip = React.forwardRef((props, ref) => {
70
62
  alignItems: "center",
71
63
  flexBox: true
72
64
  }, children: label }), endIcon] })));
73
- });
74
-
75
- module.exports = Chip;
76
- //# sourceMappingURL=index.js.map
65
+ });exports.default=Chip;//# sourceMappingURL=index.js.map
package/Chip/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport useCorner, { UseCornerTypes } from '../useCorner'\r\n\r\n\r\n\r\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\r\n label: useBreakpointPropsType<string | ReactElement>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n corner?: useBreakpointPropsType<UseCornerTypes>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\n\r\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\r\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\r\n const _p: any = {}\r\n if (label) _p.label = label\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (corner) _p.corner = corner\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n\r\n label = p.label\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color || \"brand\"\r\n variant = p.variant || \"fill\"\r\n corner = p.corner || \"circle\"\r\n size = p.size || \"medium\"\r\n rest.sx = (rest as any).sx || {};\r\n\r\n const cornerCss = useCorner(corner)\r\n const template = useColorTemplate(color, variant)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 24,\r\n gap: .5,\r\n px: startIcon || endIcon ? .8 : 1,\r\n fontSize: \"small\"\r\n },\r\n medium: {\r\n height: 32,\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n fontSize: 'button',\r\n },\r\n large: {\r\n height: 40,\r\n fontSize: 'text',\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n }\r\n }\r\n\r\n return (\r\n <Tag\r\n {...cornerCss}\r\n {...template.primary}\r\n {...(sizes[size as any] || {})}\r\n {...rest}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n transition: \"background .3s\",\r\n overflow: \"hidden\",\r\n\r\n \"& > *\": {\r\n flex: \"0 0 auto\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n },\r\n }}\r\n baseClass='chip'\r\n ref={ref}\r\n >\r\n {startIcon}\r\n <Tag\r\n sxr={{\r\n alignItems: \"center\",\r\n flexBox: true\r\n }}\r\n >{label}</Tag>\r\n {endIcon}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Chip\r\n"],"names":["useInterface","__rest","useBreakpointProps","useCorner","useColorTemplate","_jsxs","Tag","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport useCorner, { UseCornerTypes } from '../useCorner'\n\n\n\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\n label: useBreakpointPropsType<string | ReactElement>;\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n variant?: useBreakpointPropsType<UseColorTemplateType>;\n corner?: useBreakpointPropsType<UseCornerTypes>;\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\n}\n\n\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\n const _p: any = {}\n if (label) _p.label = label\n if (startIcon) _p.startIcon = startIcon\n if (endIcon) _p.endIcon = endIcon\n if (color) _p.color = color\n if (variant) _p.variant = variant\n if (corner) _p.corner = corner\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n\n label = p.label\n startIcon = p.startIcon\n endIcon = p.endIcon\n color = p.color || \"brand\"\n variant = p.variant || \"fill\"\n corner = p.corner || \"circle\"\n size = p.size || \"medium\"\n rest.sx = (rest as any).sx || {};\n\n const cornerCss = useCorner(corner)\n const template = useColorTemplate(color, variant)\n\n const sizes: any = {\n small: {\n height: 24,\n gap: .5,\n px: startIcon || endIcon ? .8 : 1,\n fontSize: \"small\"\n },\n medium: {\n height: 32,\n gap: 1,\n px: startIcon || endIcon ? .8 : 1.5,\n fontSize: 'button',\n },\n large: {\n height: 40,\n fontSize: 'text',\n gap: 1,\n px: startIcon || endIcon ? .8 : 1.5,\n }\n }\n\n return (\n <Tag\n {...cornerCss}\n {...template.primary}\n {...(sizes[size as any] || {})}\n {...rest}\n sxr={{\n display: \"inline-flex\",\n flexDirection: \"row\",\n alignItems: \"center\",\n transition: \"background .3s\",\n overflow: \"hidden\",\n\n \"& > *\": {\n flex: \"0 0 auto\",\n textOverflow: \"ellipsis\",\n whiteSpace: \"nowrap\",\n overflow: \"hidden\",\n },\n }}\n baseClass='chip'\n ref={ref}\n >\n {startIcon}\n <Tag\n sxr={{\n alignItems: \"center\",\n flexBox: true\n }}\n >{label}</Tag>\n {endIcon}\n </Tag>\n )\n})\n\nexport default Chip\n"],"names":["useInterface","__rest","useBreakpointProps","useCorner","useColorTemplate","_jsxs","Tag","_jsx"],"mappings":"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"}
package/Chip/index.mjs CHANGED
@@ -1,10 +1,4 @@
1
- import { __rest } from 'tslib';
2
- import { jsxs, jsx } from 'react/jsx-runtime';
3
- import React from 'react';
4
- import { useInterface, useBreakpointProps, useColorTemplate, Tag } from '@xanui/core';
5
- import useCorner from '../useCorner/index.mjs';
6
-
7
- const Chip = React.forwardRef((props, ref) => {
1
+ import {__rest}from'tslib';import {jsxs,jsx}from'react/jsx-runtime';import React from'react';import {useInterface,useBreakpointProps,useColorTemplate,Tag}from'@xanui/core';import useCorner from'../useCorner/index.mjs';const Chip = React.forwardRef((props, ref) => {
8
2
  let [_a] = useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = __rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
9
3
  const _p = {};
10
4
  if (label)
@@ -68,7 +62,4 @@ const Chip = React.forwardRef((props, ref) => {
68
62
  alignItems: "center",
69
63
  flexBox: true
70
64
  }, children: label }), endIcon] })));
71
- });
72
-
73
- export { Chip as default };
74
- //# sourceMappingURL=index.mjs.map
65
+ });export{Chip as default};//# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport useCorner, { UseCornerTypes } from '../useCorner'\r\n\r\n\r\n\r\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\r\n label: useBreakpointPropsType<string | ReactElement>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n corner?: useBreakpointPropsType<UseCornerTypes>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\n\r\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\r\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\r\n const _p: any = {}\r\n if (label) _p.label = label\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (corner) _p.corner = corner\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n\r\n label = p.label\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color || \"brand\"\r\n variant = p.variant || \"fill\"\r\n corner = p.corner || \"circle\"\r\n size = p.size || \"medium\"\r\n rest.sx = (rest as any).sx || {};\r\n\r\n const cornerCss = useCorner(corner)\r\n const template = useColorTemplate(color, variant)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 24,\r\n gap: .5,\r\n px: startIcon || endIcon ? .8 : 1,\r\n fontSize: \"small\"\r\n },\r\n medium: {\r\n height: 32,\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n fontSize: 'button',\r\n },\r\n large: {\r\n height: 40,\r\n fontSize: 'text',\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n }\r\n }\r\n\r\n return (\r\n <Tag\r\n {...cornerCss}\r\n {...template.primary}\r\n {...(sizes[size as any] || {})}\r\n {...rest}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n transition: \"background .3s\",\r\n overflow: \"hidden\",\r\n\r\n \"& > *\": {\r\n flex: \"0 0 auto\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n },\r\n }}\r\n baseClass='chip'\r\n ref={ref}\r\n >\r\n {startIcon}\r\n <Tag\r\n sxr={{\r\n alignItems: \"center\",\r\n flexBox: true\r\n }}\r\n >{label}</Tag>\r\n {endIcon}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Chip\r\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport useCorner, { UseCornerTypes } from '../useCorner'\n\n\n\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\n label: useBreakpointPropsType<string | ReactElement>;\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n variant?: useBreakpointPropsType<UseColorTemplateType>;\n corner?: useBreakpointPropsType<UseCornerTypes>;\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\n}\n\n\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\n const _p: any = {}\n if (label) _p.label = label\n if (startIcon) _p.startIcon = startIcon\n if (endIcon) _p.endIcon = endIcon\n if (color) _p.color = color\n if (variant) _p.variant = variant\n if (corner) _p.corner = corner\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n\n label = p.label\n startIcon = p.startIcon\n endIcon = p.endIcon\n color = p.color || \"brand\"\n variant = p.variant || \"fill\"\n corner = p.corner || \"circle\"\n size = p.size || \"medium\"\n rest.sx = (rest as any).sx || {};\n\n const cornerCss = useCorner(corner)\n const template = useColorTemplate(color, variant)\n\n const sizes: any = {\n small: {\n height: 24,\n gap: .5,\n px: startIcon || endIcon ? .8 : 1,\n fontSize: \"small\"\n },\n medium: {\n height: 32,\n gap: 1,\n px: startIcon || endIcon ? .8 : 1.5,\n fontSize: 'button',\n },\n large: {\n height: 40,\n fontSize: 'text',\n gap: 1,\n px: startIcon || endIcon ? .8 : 1.5,\n }\n }\n\n return (\n <Tag\n {...cornerCss}\n {...template.primary}\n {...(sizes[size as any] || {})}\n {...rest}\n sxr={{\n display: \"inline-flex\",\n flexDirection: \"row\",\n alignItems: \"center\",\n transition: \"background .3s\",\n overflow: \"hidden\",\n\n \"& > *\": {\n flex: \"0 0 auto\",\n textOverflow: \"ellipsis\",\n whiteSpace: \"nowrap\",\n overflow: \"hidden\",\n },\n }}\n baseClass='chip'\n ref={ref}\n >\n {startIcon}\n <Tag\n sxr={{\n alignItems: \"center\",\n flexBox: true\n }}\n >{label}</Tag>\n {endIcon}\n </Tag>\n )\n})\n\nexport default Chip\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
@@ -1,12 +1,4 @@
1
- "use client";
2
- 'use strict';
3
-
4
- var tslib = require('tslib');
5
- var jsxRuntime = require('react/jsx-runtime');
6
- var React = require('react');
7
- var core = require('@xanui/core');
8
-
9
- const CircleProgress = React.forwardRef((_a, ref) => {
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),React=require('react'),core=require('@xanui/core');const CircleProgress = React.forwardRef((_a, ref) => {
10
2
  var _b, _c, _d, _e;
11
3
  var { children } = _a, props = tslib.__rest(_a, ["children"]);
12
4
  let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = core.useInterface("CircleProgress", props, {});
@@ -123,7 +115,4 @@ const CircleProgress = React.forwardRef((_a, ref) => {
123
115
  maxHeight: size - (thumbSize + 8),
124
116
  }
125
117
  }, children: children })] }));
126
- });
127
-
128
- module.exports = CircleProgress;
129
- //# sourceMappingURL=index.js.map
118
+ });exports.default=CircleProgress;//# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { ReactElement, useId } from \"react\"\r\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\n\r\nexport type CircleProgressProps = {\r\n children?: ReactElement;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n thumbSize?: useBreakpointPropsType<number>;\r\n trackSize?: useBreakpointPropsType<number>;\r\n value?: useBreakpointPropsType<number>;\r\n hideTrack?: useBreakpointPropsType<boolean>;\r\n showPercentage?: useBreakpointPropsType<boolean>;\r\n speed?: useBreakpointPropsType<number>;\r\n}\r\n\r\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\r\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n if (trackColor) _p.trackColor = trackColor\r\n if (thumbColor) _p.thumbColor = thumbColor\r\n if (size) _p.size = size\r\n if (thumbSize) _p.thumbSize = thumbSize\r\n if (trackSize) _p.trackSize = trackSize\r\n if (value) _p.value = value\r\n if (hideTrack) _p.hideTrack = hideTrack\r\n if (showPercentage) _p.showPercentage = showPercentage\r\n if (speed) _p.speed = speed\r\n const p: any = useBreakpointProps(_p)\r\n\r\n color = p.color ?? \"brand\"\r\n trackColor = p.trackColor\r\n thumbColor = p.thumbColor\r\n size = p.size ?? \"medium\"\r\n thumbSize = p.thumbSize ?? 4\r\n trackSize = p.trackSize\r\n value = p.value\r\n hideTrack = p.hideTrack\r\n showPercentage = p.showPercentage\r\n speed = p.speed ?? 1.3\r\n\r\n if (trackColor === 'default') {\r\n trackColor = \"divider\"\r\n }\r\n\r\n if (thumbColor === 'default') {\r\n thumbColor = \"divider.secondary\"\r\n }\r\n\r\n\r\n let sizes: any = {\r\n small: 24,\r\n medium: 32,\r\n large: 44\r\n }\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n let isVal = typeof value === 'number'\r\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\r\n const animdash = \"anim\" + useId().replace(\":\", \"\")\r\n if (isVal && (value as number) > 100) value = 100\r\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\r\n const percent = circumference - ((value || 0) / 100) * circumference\r\n\r\n if (showPercentage && !children) {\r\n children = <Tag\r\n sxr={{\r\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\r\n fontSize: size / 4\r\n }}\r\n >{value}%</Tag>\r\n }\r\n\r\n return (\r\n <Tag\r\n baseClass='circle-progress'\r\n sxr={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n \"& svg[class='circle-progress-svg']\": {\r\n zIndex: 1,\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n width: \"100%\",\r\n height: \"100%\",\r\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\r\n transformOrigin: isVal ? \"center\" : \"initial\",\r\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\r\n [`@keyframes ${animrotate}`]: {\r\n \"100%\": {\r\n transform: \"rotate(360deg)\"\r\n }\r\n },\r\n \"& circle.circle-progress-thumb\": {\r\n\r\n strokeDasharray: circumference,\r\n strokeDashoffset: percent,\r\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\r\n fill: \"none\",\r\n strokeWidth: thumbSize,\r\n strokeLinecap: \"round\",\r\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\r\n [`@keyframes ${animdash}`]: {\r\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\r\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\r\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\r\n }\r\n },\r\n \"& circle.circle-progress-track\": {\r\n fill: \"none\",\r\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\r\n strokeWidth: trackSize ?? thumbSize,\r\n }\r\n },\r\n width: size,\r\n height: size,\r\n position: \"relative\"\r\n }}\r\n ref={ref}\r\n >\r\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\r\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\r\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\r\n </svg>\r\n {!!children && <Tag\r\n baseClass=\"circle-progress-content\"\r\n sxr={{\r\n zIndex: 2,\r\n width: size - thumbSize,\r\n height: size - thumbSize,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n '& *': {\r\n maxWidth: size - (thumbSize + 8),\r\n maxHeight: size - (thumbSize + 8),\r\n }\r\n }}\r\n >\r\n {children}\r\n </Tag>}\r\n </Tag >\r\n )\r\n})\r\n\r\nexport default CircleProgress\r\n\r\n"],"names":[],"mappings":";;;;;;;;AAkBA;;AAAyC;AACrC;;AAEA;AAAW;AACX;AAAgB;AAChB;AAAgB;AAChB;AAAU;AACV;AAAe;AACf;AAAe;AACf;AAAW;AACX;AAAe;AACf;AAAoB;AACpB;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAIA;;;AAKA;AACI;AACA;AACA;;;AAGA;;AAGJ;AACA;AACA;AACA;;AACA;AACA;AAEA;AACI;AAEQ;;;;;AAUA;AACA;AACA;AACA;AACI;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACI;AACI;AACH;AACJ;AACD;AAEI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIC;AACJ;AACD;AACI;AACA;AACA;AACH;AACJ;AACD;AACA;AACA;AACH;AAUO;;;AAGA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;AAMjB;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\"use client\";\nimport React, { ReactElement, useId } from \"react\"\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\n\nexport type CircleProgressProps = {\n children?: ReactElement;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n thumbSize?: useBreakpointPropsType<number>;\n trackSize?: useBreakpointPropsType<number>;\n value?: useBreakpointPropsType<number>;\n hideTrack?: useBreakpointPropsType<boolean>;\n showPercentage?: useBreakpointPropsType<boolean>;\n speed?: useBreakpointPropsType<number>;\n}\n\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\n const _p: any = {}\n if (color) _p.color = color\n if (trackColor) _p.trackColor = trackColor\n if (thumbColor) _p.thumbColor = thumbColor\n if (size) _p.size = size\n if (thumbSize) _p.thumbSize = thumbSize\n if (trackSize) _p.trackSize = trackSize\n if (value) _p.value = value\n if (hideTrack) _p.hideTrack = hideTrack\n if (showPercentage) _p.showPercentage = showPercentage\n if (speed) _p.speed = speed\n const p: any = useBreakpointProps(_p)\n\n color = p.color ?? \"brand\"\n trackColor = p.trackColor\n thumbColor = p.thumbColor\n size = p.size ?? \"medium\"\n thumbSize = p.thumbSize ?? 4\n trackSize = p.trackSize\n value = p.value\n hideTrack = p.hideTrack\n showPercentage = p.showPercentage\n speed = p.speed ?? 1.3\n\n if (trackColor === 'default') {\n trackColor = \"divider\"\n }\n\n if (thumbColor === 'default') {\n thumbColor = \"divider.secondary\"\n }\n\n\n let sizes: any = {\n small: 24,\n medium: 32,\n large: 44\n }\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n let isVal = typeof value === 'number'\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\n const animdash = \"anim\" + useId().replace(\":\", \"\")\n if (isVal && (value as number) > 100) value = 100\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\n const percent = circumference - ((value || 0) / 100) * circumference\n\n if (showPercentage && !children) {\n children = <Tag\n sxr={{\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\n fontSize: size / 4\n }}\n >{value}%</Tag>\n }\n\n return (\n <Tag\n baseClass='circle-progress'\n sxr={{\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n \"& svg[class='circle-progress-svg']\": {\n zIndex: 1,\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\n transformOrigin: isVal ? \"center\" : \"initial\",\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\n [`@keyframes ${animrotate}`]: {\n \"100%\": {\n transform: \"rotate(360deg)\"\n }\n },\n \"& circle.circle-progress-thumb\": {\n\n strokeDasharray: circumference,\n strokeDashoffset: percent,\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\n fill: \"none\",\n strokeWidth: thumbSize,\n strokeLinecap: \"round\",\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\n [`@keyframes ${animdash}`]: {\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\n }\n },\n \"& circle.circle-progress-track\": {\n fill: \"none\",\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\n strokeWidth: trackSize ?? thumbSize,\n }\n },\n width: size,\n height: size,\n position: \"relative\"\n }}\n ref={ref}\n >\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\n </svg>\n {!!children && <Tag\n baseClass=\"circle-progress-content\"\n sxr={{\n zIndex: 2,\n width: size - thumbSize,\n height: size - thumbSize,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n '& *': {\n maxWidth: size - (thumbSize + 8),\n maxHeight: size - (thumbSize + 8),\n }\n }}\n >\n {children}\n </Tag>}\n </Tag >\n )\n})\n\nexport default CircleProgress\n\n"],"names":["__rest","useInterface","useBreakpointProps","useId","_jsxs","Tag","_jsx"],"mappings":"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"}
@@ -1,10 +1,4 @@
1
- "use client";
2
- import { __rest } from 'tslib';
3
- import { jsxs, jsx } from 'react/jsx-runtime';
4
- import React, { useId } from 'react';
5
- import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
6
-
7
- const CircleProgress = React.forwardRef((_a, ref) => {
1
+ import {__rest}from'tslib';import {jsxs,jsx}from'react/jsx-runtime';import React,{useId}from'react';import {useInterface,useBreakpointProps,Tag}from'@xanui/core';const CircleProgress = React.forwardRef((_a, ref) => {
8
2
  var _b, _c, _d, _e;
9
3
  var { children } = _a, props = __rest(_a, ["children"]);
10
4
  let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface("CircleProgress", props, {});
@@ -121,7 +115,4 @@ const CircleProgress = React.forwardRef((_a, ref) => {
121
115
  maxHeight: size - (thumbSize + 8),
122
116
  }
123
117
  }, children: children })] }));
124
- });
125
-
126
- export { CircleProgress as default };
127
- //# sourceMappingURL=index.mjs.map
118
+ });export{CircleProgress as default};//# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { ReactElement, useId } from \"react\"\r\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\n\r\nexport type CircleProgressProps = {\r\n children?: ReactElement;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n thumbSize?: useBreakpointPropsType<number>;\r\n trackSize?: useBreakpointPropsType<number>;\r\n value?: useBreakpointPropsType<number>;\r\n hideTrack?: useBreakpointPropsType<boolean>;\r\n showPercentage?: useBreakpointPropsType<boolean>;\r\n speed?: useBreakpointPropsType<number>;\r\n}\r\n\r\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\r\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n if (trackColor) _p.trackColor = trackColor\r\n if (thumbColor) _p.thumbColor = thumbColor\r\n if (size) _p.size = size\r\n if (thumbSize) _p.thumbSize = thumbSize\r\n if (trackSize) _p.trackSize = trackSize\r\n if (value) _p.value = value\r\n if (hideTrack) _p.hideTrack = hideTrack\r\n if (showPercentage) _p.showPercentage = showPercentage\r\n if (speed) _p.speed = speed\r\n const p: any = useBreakpointProps(_p)\r\n\r\n color = p.color ?? \"brand\"\r\n trackColor = p.trackColor\r\n thumbColor = p.thumbColor\r\n size = p.size ?? \"medium\"\r\n thumbSize = p.thumbSize ?? 4\r\n trackSize = p.trackSize\r\n value = p.value\r\n hideTrack = p.hideTrack\r\n showPercentage = p.showPercentage\r\n speed = p.speed ?? 1.3\r\n\r\n if (trackColor === 'default') {\r\n trackColor = \"divider\"\r\n }\r\n\r\n if (thumbColor === 'default') {\r\n thumbColor = \"divider.secondary\"\r\n }\r\n\r\n\r\n let sizes: any = {\r\n small: 24,\r\n medium: 32,\r\n large: 44\r\n }\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n let isVal = typeof value === 'number'\r\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\r\n const animdash = \"anim\" + useId().replace(\":\", \"\")\r\n if (isVal && (value as number) > 100) value = 100\r\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\r\n const percent = circumference - ((value || 0) / 100) * circumference\r\n\r\n if (showPercentage && !children) {\r\n children = <Tag\r\n sxr={{\r\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\r\n fontSize: size / 4\r\n }}\r\n >{value}%</Tag>\r\n }\r\n\r\n return (\r\n <Tag\r\n baseClass='circle-progress'\r\n sxr={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n \"& svg[class='circle-progress-svg']\": {\r\n zIndex: 1,\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n width: \"100%\",\r\n height: \"100%\",\r\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\r\n transformOrigin: isVal ? \"center\" : \"initial\",\r\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\r\n [`@keyframes ${animrotate}`]: {\r\n \"100%\": {\r\n transform: \"rotate(360deg)\"\r\n }\r\n },\r\n \"& circle.circle-progress-thumb\": {\r\n\r\n strokeDasharray: circumference,\r\n strokeDashoffset: percent,\r\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\r\n fill: \"none\",\r\n strokeWidth: thumbSize,\r\n strokeLinecap: \"round\",\r\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\r\n [`@keyframes ${animdash}`]: {\r\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\r\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\r\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\r\n }\r\n },\r\n \"& circle.circle-progress-track\": {\r\n fill: \"none\",\r\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\r\n strokeWidth: trackSize ?? thumbSize,\r\n }\r\n },\r\n width: size,\r\n height: size,\r\n position: \"relative\"\r\n }}\r\n ref={ref}\r\n >\r\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\r\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\r\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\r\n </svg>\r\n {!!children && <Tag\r\n baseClass=\"circle-progress-content\"\r\n sxr={{\r\n zIndex: 2,\r\n width: size - thumbSize,\r\n height: size - thumbSize,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n '& *': {\r\n maxWidth: size - (thumbSize + 8),\r\n maxHeight: size - (thumbSize + 8),\r\n }\r\n }}\r\n >\r\n {children}\r\n </Tag>}\r\n </Tag >\r\n )\r\n})\r\n\r\nexport default CircleProgress\r\n\r\n"],"names":[],"mappings":";;;;;;AAkBA;;AAAyC;AACrC;;AAEA;AAAW;AACX;AAAgB;AAChB;AAAgB;AAChB;AAAU;AACV;AAAe;AACf;AAAe;AACf;AAAW;AACX;AAAe;AACf;AAAoB;AACpB;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAIA;;;AAKA;AACI;AACA;AACA;;;AAGA;;AAGJ;AACA;AACA;AACA;;AACA;AACA;AAEA;AACI;AAEQ;;;;;AAUA;AACA;AACA;AACA;AACI;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACI;AACI;AACH;AACJ;AACD;AAEI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIC;AACJ;AACD;AACI;AACA;AACA;AACH;AACJ;AACD;AACA;AACA;AACH;AAUO;;;AAGA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;AAMjB;;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\"use client\";\nimport React, { ReactElement, useId } from \"react\"\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\n\nexport type CircleProgressProps = {\n children?: ReactElement;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n thumbSize?: useBreakpointPropsType<number>;\n trackSize?: useBreakpointPropsType<number>;\n value?: useBreakpointPropsType<number>;\n hideTrack?: useBreakpointPropsType<boolean>;\n showPercentage?: useBreakpointPropsType<boolean>;\n speed?: useBreakpointPropsType<number>;\n}\n\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\n const _p: any = {}\n if (color) _p.color = color\n if (trackColor) _p.trackColor = trackColor\n if (thumbColor) _p.thumbColor = thumbColor\n if (size) _p.size = size\n if (thumbSize) _p.thumbSize = thumbSize\n if (trackSize) _p.trackSize = trackSize\n if (value) _p.value = value\n if (hideTrack) _p.hideTrack = hideTrack\n if (showPercentage) _p.showPercentage = showPercentage\n if (speed) _p.speed = speed\n const p: any = useBreakpointProps(_p)\n\n color = p.color ?? \"brand\"\n trackColor = p.trackColor\n thumbColor = p.thumbColor\n size = p.size ?? \"medium\"\n thumbSize = p.thumbSize ?? 4\n trackSize = p.trackSize\n value = p.value\n hideTrack = p.hideTrack\n showPercentage = p.showPercentage\n speed = p.speed ?? 1.3\n\n if (trackColor === 'default') {\n trackColor = \"divider\"\n }\n\n if (thumbColor === 'default') {\n thumbColor = \"divider.secondary\"\n }\n\n\n let sizes: any = {\n small: 24,\n medium: 32,\n large: 44\n }\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n let isVal = typeof value === 'number'\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\n const animdash = \"anim\" + useId().replace(\":\", \"\")\n if (isVal && (value as number) > 100) value = 100\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\n const percent = circumference - ((value || 0) / 100) * circumference\n\n if (showPercentage && !children) {\n children = <Tag\n sxr={{\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\n fontSize: size / 4\n }}\n >{value}%</Tag>\n }\n\n return (\n <Tag\n baseClass='circle-progress'\n sxr={{\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n \"& svg[class='circle-progress-svg']\": {\n zIndex: 1,\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\n transformOrigin: isVal ? \"center\" : \"initial\",\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\n [`@keyframes ${animrotate}`]: {\n \"100%\": {\n transform: \"rotate(360deg)\"\n }\n },\n \"& circle.circle-progress-thumb\": {\n\n strokeDasharray: circumference,\n strokeDashoffset: percent,\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\n fill: \"none\",\n strokeWidth: thumbSize,\n strokeLinecap: \"round\",\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\n [`@keyframes ${animdash}`]: {\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\n }\n },\n \"& circle.circle-progress-track\": {\n fill: \"none\",\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\n strokeWidth: trackSize ?? thumbSize,\n }\n },\n width: size,\n height: size,\n position: \"relative\"\n }}\n ref={ref}\n >\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\n </svg>\n {!!children && <Tag\n baseClass=\"circle-progress-content\"\n sxr={{\n zIndex: 2,\n width: size - thumbSize,\n height: size - thumbSize,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n '& *': {\n maxWidth: size - (thumbSize + 8),\n maxHeight: size - (thumbSize + 8),\n }\n }}\n >\n {children}\n </Tag>}\n </Tag >\n )\n})\n\nexport default CircleProgress\n\n"],"names":["_jsxs","_jsx"],"mappings":"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"}