@sbcrmweb/sbcrmweb-tma-core 0.0.59

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 (239) hide show
  1. package/README.md +419 -0
  2. package/dist/cjs/components/TMAActionBar/TMAActionBar.d.ts +10 -0
  3. package/dist/cjs/components/TMAActionBar/TMAActionBar.d.ts.map +1 -0
  4. package/dist/cjs/components/TMAActionBar/TMAActionBar.js +40 -0
  5. package/dist/cjs/components/TMABannersFeed/StoryDrawer.d.ts +12 -0
  6. package/dist/cjs/components/TMABannersFeed/StoryDrawer.d.ts.map +1 -0
  7. package/dist/cjs/components/TMABannersFeed/StoryDrawer.js +121 -0
  8. package/dist/cjs/components/TMABannersFeed/StoryProgress.d.ts +11 -0
  9. package/dist/cjs/components/TMABannersFeed/StoryProgress.d.ts.map +1 -0
  10. package/dist/cjs/components/TMABannersFeed/StoryProgress.js +81 -0
  11. package/dist/cjs/components/TMABannersFeed/TMABannerFeed.d.ts +28 -0
  12. package/dist/cjs/components/TMABannersFeed/TMABannerFeed.d.ts.map +1 -0
  13. package/dist/cjs/components/TMABannersFeed/TMABannerFeed.js +87 -0
  14. package/dist/cjs/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts +5 -0
  15. package/dist/cjs/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts.map +1 -0
  16. package/dist/cjs/components/TMABannersFeed/TMABannerFeedPropsContext.js +11 -0
  17. package/dist/cjs/components/TMABannersFeed/TMAStoryDrawer.d.ts +11 -0
  18. package/dist/cjs/components/TMABannersFeed/TMAStoryDrawer.d.ts.map +1 -0
  19. package/dist/cjs/components/TMABannersFeed/TMAStoryDrawer.js +126 -0
  20. package/dist/cjs/components/TMABannersFeed/propsContext.d.ts +5 -0
  21. package/dist/cjs/components/TMABannersFeed/propsContext.d.ts.map +1 -0
  22. package/dist/cjs/components/TMABannersFeed/propsContext.js +10 -0
  23. package/dist/cjs/components/TMABarChart/ItemTooltip.d.ts +12 -0
  24. package/dist/cjs/components/TMABarChart/ItemTooltip.d.ts.map +1 -0
  25. package/dist/cjs/components/TMABarChart/ItemTooltip.js +39 -0
  26. package/dist/cjs/components/TMABarChart/TMABarChart.d.ts +10 -0
  27. package/dist/cjs/components/TMABarChart/TMABarChart.d.ts.map +1 -0
  28. package/dist/cjs/components/TMABarChart/TMABarChart.js +131 -0
  29. package/dist/cjs/components/TMABaseSection/TMABaseSection.d.ts +7 -0
  30. package/dist/cjs/components/TMABaseSection/TMABaseSection.d.ts.map +1 -0
  31. package/dist/cjs/components/TMABaseSection/TMABaseSection.js +18 -0
  32. package/dist/cjs/components/TMACell/TMACell.d.ts +12 -0
  33. package/dist/cjs/components/TMACell/TMACell.d.ts.map +1 -0
  34. package/dist/cjs/components/TMACell/TMACell.js +18 -0
  35. package/dist/cjs/components/TMACellList/TMACellList.d.ts +6 -0
  36. package/dist/cjs/components/TMACellList/TMACellList.d.ts.map +1 -0
  37. package/dist/cjs/components/TMACellList/TMACellList.js +18 -0
  38. package/dist/cjs/components/TMACheckbox/TMACheckbox.d.ts +7 -0
  39. package/dist/cjs/components/TMACheckbox/TMACheckbox.d.ts.map +1 -0
  40. package/dist/cjs/components/TMACheckbox/TMACheckbox.js +11 -0
  41. package/dist/cjs/components/TMACounter/TMACountInput.d.ts +9 -0
  42. package/dist/cjs/components/TMACounter/TMACountInput.d.ts.map +1 -0
  43. package/dist/cjs/components/TMACounter/TMACountInput.js +36 -0
  44. package/dist/cjs/components/TMACounter/TMACounter.d.ts +11 -0
  45. package/dist/cjs/components/TMACounter/TMACounter.d.ts.map +1 -0
  46. package/dist/cjs/components/TMACounter/TMACounter.js +33 -0
  47. package/dist/cjs/components/TMADrawerFilter/TMADrawerFilter.d.ts +29 -0
  48. package/dist/cjs/components/TMADrawerFilter/TMADrawerFilter.d.ts.map +1 -0
  49. package/dist/cjs/components/TMADrawerFilter/TMADrawerFilter.js +47 -0
  50. package/dist/cjs/components/TMADrawerFilter/TMARightDrawerFilter.d.ts +4 -0
  51. package/dist/cjs/components/TMADrawerFilter/TMARightDrawerFilter.d.ts.map +1 -0
  52. package/dist/cjs/components/TMADrawerFilter/TMARightDrawerFilter.js +12 -0
  53. package/dist/cjs/components/TMADrawerFilter/TMATopDrawerFilter.d.ts +4 -0
  54. package/dist/cjs/components/TMADrawerFilter/TMATopDrawerFilter.d.ts.map +1 -0
  55. package/dist/cjs/components/TMADrawerFilter/TMATopDrawerFilter.js +11 -0
  56. package/dist/cjs/components/TMADrawerHeader/TMADrawerHeader.d.ts +6 -0
  57. package/dist/cjs/components/TMADrawerHeader/TMADrawerHeader.d.ts.map +1 -0
  58. package/dist/cjs/components/TMADrawerHeader/TMADrawerHeader.js +29 -0
  59. package/dist/cjs/components/TMALoadable/TMALoadable.d.ts +15 -0
  60. package/dist/cjs/components/TMALoadable/TMALoadable.d.ts.map +1 -0
  61. package/dist/cjs/components/TMALoadable/TMALoadable.js +25 -0
  62. package/dist/cjs/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts +34 -0
  63. package/dist/cjs/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts.map +1 -0
  64. package/dist/cjs/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.js +188 -0
  65. package/dist/cjs/components/TMASelect/TMASelect.d.ts +20 -0
  66. package/dist/cjs/components/TMASelect/TMASelect.d.ts.map +1 -0
  67. package/dist/cjs/components/TMASelect/TMASelect.js +152 -0
  68. package/dist/cjs/components/TMASelect/TMASelectOption.d.ts +8 -0
  69. package/dist/cjs/components/TMASelect/TMASelectOption.d.ts.map +1 -0
  70. package/dist/cjs/components/TMASelect/TMASelectOption.js +15 -0
  71. package/dist/cjs/components/TMAStatisticsCard/TMAStatisticsCard.d.ts +12 -0
  72. package/dist/cjs/components/TMAStatisticsCard/TMAStatisticsCard.d.ts.map +1 -0
  73. package/dist/cjs/components/TMAStatisticsCard/TMAStatisticsCard.js +30 -0
  74. package/dist/cjs/components/TMATabs/TMATabs.d.ts +14 -0
  75. package/dist/cjs/components/TMATabs/TMATabs.d.ts.map +1 -0
  76. package/dist/cjs/components/TMATabs/TMATabs.js +32 -0
  77. package/dist/cjs/components/TMATextField/TMATextField.d.ts +9 -0
  78. package/dist/cjs/components/TMATextField/TMATextField.d.ts.map +1 -0
  79. package/dist/cjs/components/TMATextField/TMATextField.js +30 -0
  80. package/dist/cjs/components/TMATextWithTitle/TMATextWithTitle.d.ts +7 -0
  81. package/dist/cjs/components/TMATextWithTitle/TMATextWithTitle.d.ts.map +1 -0
  82. package/dist/cjs/components/TMATextWithTitle/TMATextWithTitle.js +21 -0
  83. package/dist/cjs/components/TMAToast/TMAToast.d.ts +14 -0
  84. package/dist/cjs/components/TMAToast/TMAToast.d.ts.map +1 -0
  85. package/dist/cjs/components/TMAToast/TMAToast.js +45 -0
  86. package/dist/cjs/components/TMATooltip/TMATooltip.d.ts +11 -0
  87. package/dist/cjs/components/TMATooltip/TMATooltip.d.ts.map +1 -0
  88. package/dist/cjs/components/TMATooltip/TMATooltip.js +12 -0
  89. package/dist/cjs/components/index.d.ts +28 -0
  90. package/dist/cjs/components/index.d.ts.map +1 -0
  91. package/dist/cjs/components/index.js +55 -0
  92. package/dist/cjs/context/BackButtonContext/BackButtonContext.d.ts +7 -0
  93. package/dist/cjs/context/BackButtonContext/BackButtonContext.d.ts.map +1 -0
  94. package/dist/cjs/context/BackButtonContext/BackButtonContext.js +16 -0
  95. package/dist/cjs/context/index.d.ts +2 -0
  96. package/dist/cjs/context/index.d.ts.map +1 -0
  97. package/dist/cjs/context/index.js +17 -0
  98. package/dist/cjs/context/theme.d.ts +7 -0
  99. package/dist/cjs/context/theme.d.ts.map +1 -0
  100. package/dist/cjs/context/theme.js +16 -0
  101. package/dist/cjs/fonts.d.ts +4 -0
  102. package/dist/cjs/fonts.d.ts.map +1 -0
  103. package/dist/cjs/fonts.js +80 -0
  104. package/dist/cjs/hooks/index.d.ts +3 -0
  105. package/dist/cjs/hooks/index.d.ts.map +1 -0
  106. package/dist/cjs/hooks/index.js +23 -0
  107. package/dist/cjs/hooks/useBackButton.d.ts +2 -0
  108. package/dist/cjs/hooks/useBackButton.d.ts.map +1 -0
  109. package/dist/cjs/hooks/useBackButton.js +28 -0
  110. package/dist/cjs/hooks/useTMALongPress.d.ts +13 -0
  111. package/dist/cjs/hooks/useTMALongPress.d.ts.map +1 -0
  112. package/dist/cjs/hooks/useTMALongPress.js +63 -0
  113. package/dist/cjs/index.d.ts +7 -0
  114. package/dist/cjs/index.d.ts.map +1 -0
  115. package/dist/cjs/index.js +50 -0
  116. package/dist/cjs/theme.d.ts +541 -0
  117. package/dist/cjs/theme.d.ts.map +1 -0
  118. package/dist/cjs/theme.js +769 -0
  119. package/dist/components/TMAActionBar/TMAActionBar.d.ts +10 -0
  120. package/dist/components/TMAActionBar/TMAActionBar.d.ts.map +1 -0
  121. package/dist/components/TMAActionBar/TMAActionBar.js +33 -0
  122. package/dist/components/TMABannersFeed/StoryDrawer.d.ts +12 -0
  123. package/dist/components/TMABannersFeed/StoryDrawer.d.ts.map +1 -0
  124. package/dist/components/TMABannersFeed/StoryDrawer.js +114 -0
  125. package/dist/components/TMABannersFeed/StoryProgress.d.ts +11 -0
  126. package/dist/components/TMABannersFeed/StoryProgress.d.ts.map +1 -0
  127. package/dist/components/TMABannersFeed/StoryProgress.js +77 -0
  128. package/dist/components/TMABannersFeed/TMABannerFeed.d.ts +28 -0
  129. package/dist/components/TMABannersFeed/TMABannerFeed.d.ts.map +1 -0
  130. package/dist/components/TMABannersFeed/TMABannerFeed.js +80 -0
  131. package/dist/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts +5 -0
  132. package/dist/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts.map +1 -0
  133. package/dist/components/TMABannersFeed/TMABannerFeedPropsContext.js +7 -0
  134. package/dist/components/TMABannersFeed/TMAStoryDrawer.d.ts +11 -0
  135. package/dist/components/TMABannersFeed/TMAStoryDrawer.d.ts.map +1 -0
  136. package/dist/components/TMABannersFeed/TMAStoryDrawer.js +119 -0
  137. package/dist/components/TMABannersFeed/propsContext.d.ts +5 -0
  138. package/dist/components/TMABannersFeed/propsContext.d.ts.map +1 -0
  139. package/dist/components/TMABannersFeed/propsContext.js +6 -0
  140. package/dist/components/TMABarChart/ItemTooltip.d.ts +12 -0
  141. package/dist/components/TMABarChart/ItemTooltip.d.ts.map +1 -0
  142. package/dist/components/TMABarChart/ItemTooltip.js +33 -0
  143. package/dist/components/TMABarChart/TMABarChart.d.ts +10 -0
  144. package/dist/components/TMABarChart/TMABarChart.d.ts.map +1 -0
  145. package/dist/components/TMABarChart/TMABarChart.js +91 -0
  146. package/dist/components/TMABaseSection/TMABaseSection.d.ts +7 -0
  147. package/dist/components/TMABaseSection/TMABaseSection.d.ts.map +1 -0
  148. package/dist/components/TMABaseSection/TMABaseSection.js +11 -0
  149. package/dist/components/TMACell/TMACell.d.ts +12 -0
  150. package/dist/components/TMACell/TMACell.d.ts.map +1 -0
  151. package/dist/components/TMACell/TMACell.js +11 -0
  152. package/dist/components/TMACellList/TMACellList.d.ts +6 -0
  153. package/dist/components/TMACellList/TMACellList.d.ts.map +1 -0
  154. package/dist/components/TMACellList/TMACellList.js +11 -0
  155. package/dist/components/TMACheckbox/TMACheckbox.d.ts +7 -0
  156. package/dist/components/TMACheckbox/TMACheckbox.d.ts.map +1 -0
  157. package/dist/components/TMACheckbox/TMACheckbox.js +7 -0
  158. package/dist/components/TMACounter/TMACountInput.d.ts +9 -0
  159. package/dist/components/TMACounter/TMACountInput.d.ts.map +1 -0
  160. package/dist/components/TMACounter/TMACountInput.js +34 -0
  161. package/dist/components/TMACounter/TMACounter.d.ts +11 -0
  162. package/dist/components/TMACounter/TMACounter.d.ts.map +1 -0
  163. package/dist/components/TMACounter/TMACounter.js +26 -0
  164. package/dist/components/TMADrawerFilter/TMADrawerFilter.d.ts +29 -0
  165. package/dist/components/TMADrawerFilter/TMADrawerFilter.d.ts.map +1 -0
  166. package/dist/components/TMADrawerFilter/TMADrawerFilter.js +40 -0
  167. package/dist/components/TMADrawerFilter/TMARightDrawerFilter.d.ts +4 -0
  168. package/dist/components/TMADrawerFilter/TMARightDrawerFilter.d.ts.map +1 -0
  169. package/dist/components/TMADrawerFilter/TMARightDrawerFilter.js +8 -0
  170. package/dist/components/TMADrawerFilter/TMATopDrawerFilter.d.ts +4 -0
  171. package/dist/components/TMADrawerFilter/TMATopDrawerFilter.d.ts.map +1 -0
  172. package/dist/components/TMADrawerFilter/TMATopDrawerFilter.js +7 -0
  173. package/dist/components/TMADrawerHeader/TMADrawerHeader.d.ts +6 -0
  174. package/dist/components/TMADrawerHeader/TMADrawerHeader.d.ts.map +1 -0
  175. package/dist/components/TMADrawerHeader/TMADrawerHeader.js +22 -0
  176. package/dist/components/TMALoadable/TMALoadable.d.ts +15 -0
  177. package/dist/components/TMALoadable/TMALoadable.d.ts.map +1 -0
  178. package/dist/components/TMALoadable/TMALoadable.js +18 -0
  179. package/dist/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts +34 -0
  180. package/dist/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts.map +1 -0
  181. package/dist/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.js +181 -0
  182. package/dist/components/TMASelect/TMASelect.d.ts +20 -0
  183. package/dist/components/TMASelect/TMASelect.d.ts.map +1 -0
  184. package/dist/components/TMASelect/TMASelect.js +145 -0
  185. package/dist/components/TMASelect/TMASelectOption.d.ts +8 -0
  186. package/dist/components/TMASelect/TMASelectOption.d.ts.map +1 -0
  187. package/dist/components/TMASelect/TMASelectOption.js +8 -0
  188. package/dist/components/TMAStatisticsCard/TMAStatisticsCard.d.ts +12 -0
  189. package/dist/components/TMAStatisticsCard/TMAStatisticsCard.d.ts.map +1 -0
  190. package/dist/components/TMAStatisticsCard/TMAStatisticsCard.js +23 -0
  191. package/dist/components/TMATabs/TMATabs.d.ts +14 -0
  192. package/dist/components/TMATabs/TMATabs.d.ts.map +1 -0
  193. package/dist/components/TMATabs/TMATabs.js +25 -0
  194. package/dist/components/TMATextField/TMATextField.d.ts +9 -0
  195. package/dist/components/TMATextField/TMATextField.d.ts.map +1 -0
  196. package/dist/components/TMATextField/TMATextField.js +23 -0
  197. package/dist/components/TMATextWithTitle/TMATextWithTitle.d.ts +7 -0
  198. package/dist/components/TMATextWithTitle/TMATextWithTitle.d.ts.map +1 -0
  199. package/dist/components/TMATextWithTitle/TMATextWithTitle.js +14 -0
  200. package/dist/components/TMAToast/TMAToast.d.ts +14 -0
  201. package/dist/components/TMAToast/TMAToast.d.ts.map +1 -0
  202. package/dist/components/TMAToast/TMAToast.js +38 -0
  203. package/dist/components/TMATooltip/TMATooltip.d.ts +11 -0
  204. package/dist/components/TMATooltip/TMATooltip.d.ts.map +1 -0
  205. package/dist/components/TMATooltip/TMATooltip.js +5 -0
  206. package/dist/components/index.d.ts +28 -0
  207. package/dist/components/index.d.ts.map +1 -0
  208. package/dist/components/index.js +25 -0
  209. package/dist/context/BackButtonContext/BackButtonContext.d.ts +7 -0
  210. package/dist/context/BackButtonContext/BackButtonContext.d.ts.map +1 -0
  211. package/dist/context/BackButtonContext/BackButtonContext.js +12 -0
  212. package/dist/context/index.d.ts +2 -0
  213. package/dist/context/index.d.ts.map +1 -0
  214. package/dist/context/index.js +1 -0
  215. package/dist/context/theme.d.ts +7 -0
  216. package/dist/context/theme.d.ts.map +1 -0
  217. package/dist/context/theme.js +10 -0
  218. package/dist/fonts.d.ts +4 -0
  219. package/dist/fonts.d.ts.map +1 -0
  220. package/dist/fonts.js +74 -0
  221. package/dist/hooks/index.d.ts +3 -0
  222. package/dist/hooks/index.d.ts.map +1 -0
  223. package/dist/hooks/index.js +2 -0
  224. package/dist/hooks/useBackButton.d.ts +2 -0
  225. package/dist/hooks/useBackButton.d.ts.map +1 -0
  226. package/dist/hooks/useBackButton.js +24 -0
  227. package/dist/hooks/useTMALongPress.d.ts +13 -0
  228. package/dist/hooks/useTMALongPress.d.ts.map +1 -0
  229. package/dist/hooks/useTMALongPress.js +61 -0
  230. package/dist/index.d.ts +7 -0
  231. package/dist/index.d.ts.map +1 -0
  232. package/dist/index.js +6 -0
  233. package/dist/theme.d.ts +541 -0
  234. package/dist/theme.d.ts.map +1 -0
  235. package/dist/theme.js +766 -0
  236. package/fonts/Inter.ttf +0 -0
  237. package/fonts/SF-Pro.ttf +0 -0
  238. package/fonts/SFMono-Medium.otf +0 -0
  239. package/package.json +65 -0
@@ -0,0 +1,181 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useState, useMemo } from 'react';
4
+ import Autocomplete from '@mui/material/Autocomplete';
5
+ import Stack from '@mui/material/Stack';
6
+ import TextField from '@mui/material/TextField';
7
+ import Chip from '@mui/material/Chip';
8
+ import { Divider, styled } from '@mui/material';
9
+ import ClickAwayListener from '@mui/material/ClickAwayListener';
10
+ import CheckRoundedIcon from '@mui/icons-material/CheckRounded';
11
+ import ExpandMoreRoundedIcon from '@mui/icons-material/ExpandMoreRounded';
12
+ import Typography from '@mui/material/Typography';
13
+ import { CloseRounded } from '@mui/icons-material';
14
+ import { BASE_SPACING } from '../../theme';
15
+ var TMAMultiSelectWithTagsVariants;
16
+ (function (TMAMultiSelectWithTagsVariants) {
17
+ TMAMultiSelectWithTagsVariants["DEFAULT"] = "default";
18
+ TMAMultiSelectWithTagsVariants["DOWN_TAGS"] = "downTags";
19
+ })(TMAMultiSelectWithTagsVariants || (TMAMultiSelectWithTagsVariants = {}));
20
+ export const StyledAutocomplete = styled(Autocomplete)(({ theme, isWritable, isExpandIconNeed = true, variant }) => theme.unstable_sx({
21
+ minHeight: 52,
22
+ height: 'auto',
23
+ '& .MuiFormControl-root, .MuiInputBase-root': {
24
+ minHeight: 52,
25
+ height: 'auto !important',
26
+ },
27
+ '& .MuiInputBase-root': {
28
+ py: '8px !important',
29
+ pl: '8px !important',
30
+ display: 'flex',
31
+ gap: 4 / BASE_SPACING,
32
+ height: 'auto',
33
+ },
34
+ '& .MuiChip-root': {
35
+ py: 1,
36
+ px: 12 / BASE_SPACING,
37
+ height: 36,
38
+ borderRadius: 6 / 4,
39
+ mx: 0,
40
+ my: 0,
41
+ '& .MuiChip-label': {
42
+ px: 0,
43
+ typography: 'subheadline2SemiBold',
44
+ },
45
+ '& .MuiChip-deleteIcon': {
46
+ width: 16,
47
+ height: 16,
48
+ ml: 1,
49
+ mr: 0,
50
+ },
51
+ },
52
+ '& .MuiAutocomplete-input': {
53
+ ...(!isWritable && {
54
+ display: 'none',
55
+ }),
56
+ },
57
+ ...(variant === TMAMultiSelectWithTagsVariants.DOWN_TAGS && {
58
+ '& .MuiChip-root': {
59
+ display: 'none',
60
+ },
61
+ '& .MuiInputBase-root': {
62
+ p: 2,
63
+ pb: 3,
64
+ },
65
+ }),
66
+ '& .MuiAutocomplete-endAdornment': {
67
+ mr: 1,
68
+ '& .MuiIconButton-root': {
69
+ '& .MuiSvgIcon-root': {
70
+ m: 0,
71
+ },
72
+ },
73
+ ...(!isExpandIconNeed && {
74
+ display: 'none !important',
75
+ }),
76
+ },
77
+ }));
78
+ const StyledChips = styled(Chip)(({ theme }) => theme.unstable_sx({
79
+ height: 24,
80
+ bgcolor: theme.palette.plain_background.main,
81
+ color: theme.palette.plain_foreground.main,
82
+ '& .MuiChip-label': {
83
+ typography: theme.typography.subheadline2Bold,
84
+ },
85
+ '& .MuiSvgIcon-root': {
86
+ color: theme.palette.subtitle_text_color.main,
87
+ },
88
+ }));
89
+ const selectIconSx = { color: 'hint_color.main', mr: 2 };
90
+ export const TMAMultiSelectWithTags = ({ options, defaultValue, placeholder, label, onChange, onInputChange, error, disabled, variant = 'default', isWritable = false, selectedOptions, isExpandIconNeed = true, inputValue, isMultiple = true, filterOptions, }) => {
91
+ const [isOpen, setIsOpen] = useState(false);
92
+ const [internalInputValue, setInternalInputValue] = useState('');
93
+ const currentValue = useMemo(() => {
94
+ return selectedOptions ?? defaultValue ?? [];
95
+ }, [selectedOptions, defaultValue]);
96
+ const handleInputChange = (event, value, reason) => {
97
+ if (inputValue === undefined) {
98
+ setInternalInputValue(value);
99
+ }
100
+ if (reason === 'reset') {
101
+ return;
102
+ }
103
+ onInputChange?.(event, value, reason);
104
+ };
105
+ return (_jsx(ClickAwayListener, { onClickAway: () => setIsOpen(false), children: _jsxs(Stack, { children: [_jsx(Typography, { px: 2, pb: 1, variant: "caption1Regular", color: "section_header_text_color.main", children: label }), _jsx(StyledAutocomplete, { sx: (theme) => ({
106
+ ...(error && {
107
+ '& .MuiFormControl-root': {
108
+ border: `1.5px solid ${theme.palette.destructive_text_color.main}`,
109
+ },
110
+ }),
111
+ }), disabled: disabled, multiple: isMultiple, inputValue: inputValue ?? internalInputValue, value: currentValue, open: isOpen, onOpen: () => setIsOpen(true), onClose: () => setIsOpen(false), options: options.map((option) => option.value), getOptionLabel: (option) => options.find((o) => o.value === option)?.label || '', isWritable: isWritable, variant: variant, isExpandIconNeed: isExpandIconNeed, filterOptions: filterOptions ? filterOptions : (opts) => opts, renderOption: (props, option, state, ownerState) => {
112
+ // eslint-disable-next-line react/prop-types
113
+ const { key, ...optionProps } = props;
114
+ const { index } = state;
115
+ return [
116
+ _jsxs(Stack, { width: "100%", component: "li", ...optionProps, children: [_jsx(Typography, { variant: "textRegular", children: ownerState.getOptionLabel(option) }), _jsx(CheckRoundedIcon, { color: "link_color", sx: { visibility: state.selected ? 'visible' : 'hidden' } })] }, key),
117
+ index < options.length - 1 && (_jsx(Divider, { sx: { mx: 2, my: 1, opacity: 0.35, borderBottomWidth: '2px' } }, `divider-${index}`)),
118
+ ];
119
+ }, onChange: (event, value) => onChange(value), onInputChange: handleInputChange, renderInput: (params) => {
120
+ return (
121
+ // @ts-ignore
122
+ _jsx(TextField, { ...params, placeholder: placeholder }));
123
+ }, popupIcon: _jsx(ExpandMoreRoundedIcon, { sx: selectIconSx }), slotProps: {
124
+ paper: {
125
+ sx: {
126
+ my: 1,
127
+ borderRadius: 3,
128
+ maxHeight: '50vh',
129
+ overflow: 'auto',
130
+ backgroundImage: 'none',
131
+ boxShadow: '0px 2px 1px -1px rgba(0,0,0,0.2), 0px 1px 1px 0px rgba(0,0,0,0.14), 0px 1px 3px 0px rgba(0,0,0,0.12)',
132
+ '& li': {
133
+ '&.MuiAutocomplete-option': {
134
+ justifyContent: 'space-between',
135
+ alignItems: 'center',
136
+ flexDirection: 'row',
137
+ minHeight: 48,
138
+ },
139
+ '&:focus': {
140
+ backgroundColor: 'transparent !important',
141
+ },
142
+ '&:hover': {
143
+ backgroundColor: 'transparent !important',
144
+ },
145
+ '&.MuiAutocomplete-option[aria-selected="true"]': {
146
+ backgroundColor: 'transparent !important',
147
+ },
148
+ '&.Mui-focused': {
149
+ backgroundColor: 'transparent !important',
150
+ },
151
+ },
152
+ },
153
+ },
154
+ popper: {
155
+ placement: 'bottom-start',
156
+ disablePortal: false,
157
+ modifiers: [
158
+ {
159
+ name: 'preventOverflow',
160
+ enabled: true,
161
+ options: {
162
+ boundary: 'viewport',
163
+ padding: 8,
164
+ },
165
+ },
166
+ {
167
+ name: 'flip',
168
+ enabled: true,
169
+ options: {
170
+ fallbackPlacements: ['top-start', 'bottom-start'],
171
+ },
172
+ },
173
+ ],
174
+ },
175
+ } }), variant === TMAMultiSelectWithTagsVariants.DOWN_TAGS &&
176
+ currentValue instanceof Array &&
177
+ currentValue.length > 0 && (_jsx(Stack, { direction: "row", paddingY: 1, gap: 0.75, flexWrap: "wrap", children: currentValue.map((option) => (_jsx(StyledChips, { label: options.find((el) => el.value === option)?.label, deleteIcon: _jsx(CloseRounded, {}), onDelete: () => {
178
+ const newValue = currentValue.filter((item) => item !== option);
179
+ onChange(newValue);
180
+ } }, option))) }))] }) }));
181
+ };
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { SelectProps } from '@mui/material/Select';
3
+ export type TMASelectOptionItem<Value> = {
4
+ label: string | React.ReactNode;
5
+ value: Value;
6
+ };
7
+ export type TMASelectProps<Value> = SelectProps & {
8
+ label: string;
9
+ labelVariant?: any;
10
+ placeholder?: string;
11
+ name: string;
12
+ value: Value;
13
+ hasError?: boolean;
14
+ onChange?: (event: any) => void;
15
+ isMultiple?: boolean;
16
+ options: TMASelectOptionItem<Value>[];
17
+ defaultValue?: Value;
18
+ };
19
+ export declare const TMASelect: <Value extends string>(props: TMASelectProps<Value>) => React.ReactElement;
20
+ //# sourceMappingURL=TMASelect.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMASelect.d.ts","sourceRoot":"","sources":["../../../src/components/TMASelect/TMASelect.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA2C,MAAM,OAAO,CAAC;AAChE,OAAe,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAQ3D,MAAM,MAAM,mBAAmB,CAAC,KAAK,IAAI;IACvC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC;IAChC,KAAK,EAAE,KAAK,CAAC;CACd,CAAC;AACF,MAAM,MAAM,cAAc,CAAC,KAAK,IAAI,WAAW,GAAG;IAChD,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,KAAK,CAAC;IACb,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,IAAI,CAAC;IAChC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,OAAO,EAAE,mBAAmB,CAAC,KAAK,CAAC,EAAE,CAAC;IACtC,YAAY,CAAC,EAAE,KAAK,CAAC;CACtB,CAAC;AAIF,eAAO,MAAM,SAAS,GAAI,KAAK,SAAS,MAAM,SAAU,cAAc,CAAC,KAAK,CAAC,KAAG,KAAK,CAAC,YA+LrF,CAAC"}
@@ -0,0 +1,145 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useCallback, useState, useEffect } from 'react';
4
+ import Select from '@mui/material/Select';
5
+ import { FormControl, InputLabel, MenuItem, Stack } from '@mui/material';
6
+ import Typography from '@mui/material/Typography';
7
+ import ExpandMoreRoundedIcon from '@mui/icons-material/ExpandMoreRounded';
8
+ import ExpandLessRoundedIcon from '@mui/icons-material/ExpandLessRounded';
9
+ import Divider from '@mui/material/Divider';
10
+ import { TMASelectOption } from './TMASelectOption';
11
+ const selectIconSx = { color: 'hint_color.main', mr: 2 };
12
+ export const TMASelect = (props) => {
13
+ const { label, name, placeholder = '', value, hasError, onChange, isMultiple, options, disabled, ...selectProps } = props;
14
+ const renderValue = useCallback((selected) => {
15
+ if (!selected || selected === '') {
16
+ return placeholder;
17
+ }
18
+ const option = options.find(({ value }) => value === selected);
19
+ return option ? option.label : placeholder;
20
+ }, [options, placeholder]);
21
+ const [selectOpened, setSelectOpened] = useState(false);
22
+ useEffect(() => {
23
+ if (selectOpened) {
24
+ if (typeof window !== 'undefined' && 'visualViewport' in window) {
25
+ document.activeElement?.blur();
26
+ }
27
+ }
28
+ }, [selectOpened]);
29
+ const handleSelectClick = disabled ? () => { } : () => setSelectOpened(!selectOpened);
30
+ const handleClose = () => setSelectOpened(false);
31
+ return (_jsxs(Stack, { direction: "column", alignItems: "stretch", children: [_jsx(InputLabel, { sx: { pl: 2, pb: 1 }, children: _jsx(Stack, { direction: "row", alignItems: "center", children: _jsx(Typography, { variant: "caption1Regular", color: "hint_color", children: label }) }) }), _jsx(FormControl, { children: _jsx(Select, { id: `input-${name}`, label: label, error: hasError, value: value, multiple: Boolean(isMultiple), onClick: handleSelectClick, open: selectOpened, onClose: handleClose, onChange: onChange, disableUnderline: !hasError, variant: "filled", MenuProps: {
32
+ anchorOrigin: {
33
+ vertical: 'bottom',
34
+ horizontal: 'left',
35
+ },
36
+ transformOrigin: {
37
+ vertical: 'top',
38
+ horizontal: 'left',
39
+ },
40
+ PaperProps: {
41
+ sx: {
42
+ marginTop: 1,
43
+ maxHeight: '50vh',
44
+ overflow: 'auto',
45
+ borderRadius: 3,
46
+ backgroundImage: 'none',
47
+ boxShadow: '0px 2px 1px -1px rgba(0,0,0,0.2), 0px 1px 1px 0px rgba(0,0,0,0.14), 0px 1px 3px 0px rgba(0,0,0,0.12)',
48
+ '&::-webkit-scrollbar': {
49
+ width: '6px',
50
+ },
51
+ '&::-webkit-scrollbar-track': {
52
+ background: 'transparent',
53
+ },
54
+ '&::-webkit-scrollbar-thumb': {
55
+ background: 'rgba(0,0,0,0.2)',
56
+ borderRadius: '3px',
57
+ },
58
+ '&::-webkit-scrollbar-thumb:hover': {
59
+ background: 'rgba(0,0,0,0.3)',
60
+ },
61
+ '& .MuiMenuItem-root': {
62
+ minHeight: 48,
63
+ '&:focus': {
64
+ backgroundColor: 'transparent !important',
65
+ },
66
+ '&:hover': {
67
+ backgroundColor: 'transparent !important',
68
+ },
69
+ '&.Mui-selected': {
70
+ backgroundColor: 'transparent !important',
71
+ },
72
+ '&.Mui-focusVisible': {
73
+ backgroundColor: 'transparent !important',
74
+ },
75
+ '& .MuiTouchRipple-root': {
76
+ display: 'none !important',
77
+ },
78
+ },
79
+ '& .MuiTouchRipple-root': {
80
+ display: 'none !important',
81
+ },
82
+ '& *': {
83
+ '& .MuiTouchRipple-root': {
84
+ display: 'none !important',
85
+ },
86
+ },
87
+ },
88
+ },
89
+ disableScrollLock: true,
90
+ disablePortal: true,
91
+ }, sx: {
92
+ height: 52,
93
+ alignItems: 'center',
94
+ borderRadius: 3,
95
+ overflow: 'hidden',
96
+ transition: 'none !important',
97
+ '&:hover': {
98
+ backgroundColor: 'inherit',
99
+ },
100
+ '&:focus': {
101
+ backgroundColor: 'inherit',
102
+ },
103
+ '&.Mui-focused': {
104
+ backgroundColor: 'inherit',
105
+ },
106
+ '.MuiSelect-select': {
107
+ py: 2,
108
+ overflow: 'hidden',
109
+ '&:focus': {
110
+ backgroundColor: 'transparent !important',
111
+ },
112
+ },
113
+ '& .MuiSelect-icon': {
114
+ overflow: 'hidden',
115
+ transition: 'none !important',
116
+ },
117
+ '& .MuiTouchRipple-root': {
118
+ display: 'none !important',
119
+ },
120
+ '& .MuiButtonBase-root': {
121
+ '& .MuiTouchRipple-root': {
122
+ display: 'none !important',
123
+ },
124
+ },
125
+ '& *': {
126
+ '& .MuiTouchRipple-root': {
127
+ display: 'none !important',
128
+ },
129
+ },
130
+ '& .MuiOutlinedInput-notchedOutline': {
131
+ border: 'none',
132
+ },
133
+ '&:hover .MuiOutlinedInput-notchedOutline': {
134
+ border: 'none',
135
+ },
136
+ '&.Mui-focused .MuiOutlinedInput-notchedOutline': {
137
+ border: 'none',
138
+ },
139
+ }, IconComponent: () => (selectOpened
140
+ ? _jsx(ExpandLessRoundedIcon, { sx: selectIconSx })
141
+ : _jsx(ExpandMoreRoundedIcon, { sx: selectIconSx })), renderValue: (selected) => renderValue(selected), disabled: disabled, ...selectProps, children: options.map((option, index) => [
142
+ _jsx(MenuItem, { value: option.value, children: _jsx(TMASelectOption, { fieldValue: option.value, title: option.label, value: value }) }, option.value),
143
+ index < options.length - 1 && (_jsx(Divider, { sx: { mx: 2, opacity: 0.35, borderBottomWidth: '2px' } }, `divider-${index}`)),
144
+ ]) }) })] }));
145
+ };
@@ -0,0 +1,8 @@
1
+ import { ReactNode } from 'react';
2
+ export type TMASelectOptionProps = {
3
+ fieldValue?: any;
4
+ title?: string | ReactNode | undefined;
5
+ value?: any;
6
+ };
7
+ export declare const TMASelectOption: ({ fieldValue, title, value, }: TMASelectOptionProps) => import("react/jsx-runtime").JSX.Element;
8
+ //# sourceMappingURL=TMASelectOption.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMASelectOption.d.ts","sourceRoot":"","sources":["../../../src/components/TMASelect/TMASelectOption.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAKlC,MAAM,MAAM,oBAAoB,GAAG;IACjC,UAAU,CAAC,EAAE,GAAG,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,CAAC;IACvC,KAAK,CAAC,EAAE,GAAG,CAAC;CACb,CAAC;AAEF,eAAO,MAAM,eAAe,kCAEzB,oBAAoB,4CAiBtB,CAAC"}
@@ -0,0 +1,8 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import Stack from '@mui/material/Stack';
4
+ import Typography from '@mui/material/Typography';
5
+ import CheckRoundedIcon from '@mui/icons-material/CheckRounded';
6
+ export const TMASelectOption = ({ fieldValue, title, value, }) => {
7
+ return (_jsxs(Stack, { width: "100%", justifyContent: "space-between", alignItems: "center", direction: "row", children: [_jsx(Typography, { variant: "textRegular", children: title }), _jsx(CheckRoundedIcon, { color: "link_color", sx: { visibility: value === fieldValue ? 'visible' : 'hidden' } })] }));
8
+ };
@@ -0,0 +1,12 @@
1
+ import React from "react";
2
+ import { StackProps } from "@mui/material/Stack";
3
+ export interface StatisticsCardProps extends StackProps {
4
+ title: string;
5
+ value: string;
6
+ shouldShowPin?: boolean;
7
+ sx?: StackProps["sx"];
8
+ isLoading?: boolean;
9
+ }
10
+ export declare const StyliedPinBox: import("@emotion/styled").StyledComponent<import("@mui/system").BoxOwnProps<import("@mui/material/styles").Theme> & Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import("@mui/system").BoxOwnProps<import("@mui/material/styles").Theme>> & import("@mui/system").MUIStyledCommonProps<import("@mui/material/styles").Theme>, {}, {}>;
11
+ export declare const TMAStatisticsCard: ({ title, value, shouldShowPin, sx, isLoading, ...props }: StatisticsCardProps) => import("react/jsx-runtime").JSX.Element;
12
+ //# sourceMappingURL=TMAStatisticsCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMAStatisticsCard.d.ts","sourceRoot":"","sources":["../../../src/components/TMAStatisticsCard/TMAStatisticsCard.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAc,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAKxD,MAAM,WAAW,mBAAoB,SAAQ,UAAU;IACrD,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,EAAE,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;IACtB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,aAAa,oXAKvB,CAAC;AAEJ,eAAO,MAAM,iBAAiB,6DAAsE,mBAAmB,4CA+BtH,CAAA"}
@@ -0,0 +1,23 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import Box from "@mui/material/Box";
4
+ import Typography from "@mui/material/Typography";
5
+ import Stack from "@mui/material/Stack";
6
+ import { BASE_SPACING } from "../../theme";
7
+ import { styled } from "@mui/material/styles";
8
+ import { TMALoadable } from "../TMALoadable/TMALoadable";
9
+ export const StyliedPinBox = styled(Box)(({ theme }) => theme.unstable_sx({
10
+ width: 6,
11
+ height: 6,
12
+ borderRadius: "50%",
13
+ bgcolor: "link_color.main",
14
+ }));
15
+ export const TMAStatisticsCard = ({ title, value, shouldShowPin = false, sx, isLoading, ...props }) => {
16
+ return (_jsxs(Stack, { gap: 4 / BASE_SPACING, sx: {
17
+ backgroundColor: "bg_color.main",
18
+ borderRadius: 3,
19
+ py: 2,
20
+ px: 12 / BASE_SPACING,
21
+ ...sx,
22
+ }, ...props, children: [_jsx(Typography, { variant: "subheadline1Semibold", color: "hint_color", children: title }), _jsx(TMALoadable, { isLoading: isLoading, isFullHeight: false, size: 24, sx: { alignItems: 'flex-start' }, children: _jsxs(Stack, { direction: "row", alignItems: "center", gap: 1, children: [_jsx(Typography, { variant: "textSemibold", color: "text_color", children: value }), shouldShowPin && _jsx(StyliedPinBox, {})] }) })] }));
23
+ };
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ import { TabsProps } from '@mui/material/Tabs';
3
+ import { TabProps } from '@mui/material/Tab';
4
+ export interface TMATabItem extends TabProps {
5
+ label: string;
6
+ isDisabled?: boolean;
7
+ }
8
+ export interface TMATabsProps extends TabsProps {
9
+ value: number;
10
+ onChange: (event: React.SyntheticEvent, newValue: number) => void;
11
+ tabs: TMATabItem[];
12
+ }
13
+ export declare const TMATabs: ({ value, onChange, tabs, sx, ...props }: TMATabsProps) => import("react/jsx-runtime").JSX.Element;
14
+ //# sourceMappingURL=TMATabs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMATabs.d.ts","sourceRoot":"","sources":["../../../src/components/TMATabs/TMATabs.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAa,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAY,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,UAAW,SAAQ,QAAQ;IAC1C,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,YAAa,SAAQ,SAAS;IAC7C,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,cAAc,EAAE,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAClE,IAAI,EAAE,UAAU,EAAE,CAAC;CACpB;AAED,eAAO,MAAM,OAAO,4CAMjB,YAAY,4CAwCd,CAAC"}
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import Tabs from '@mui/material/Tabs';
3
+ import Tab from '@mui/material/Tab';
4
+ export const TMATabs = ({ value, onChange, tabs, sx, ...props }) => {
5
+ return (_jsx(Tabs, { variant: "fullWidth", value: value, onChange: onChange, "aria-label": "custom tabs", sx: {
6
+ '& .MuiTabs-indicator': {
7
+ backgroundColor: 'button_color.main',
8
+ height: 3,
9
+ borderTopLeftRadius: 4,
10
+ borderTopRightRadius: 4,
11
+ },
12
+ alignSelf: 'center',
13
+ ...sx,
14
+ }, ...props, children: tabs.map((tab, index) => (_jsx(Tab, { label: tab.label, disabled: tab.isDisabled, sx: {
15
+ textTransform: 'none',
16
+ fontSize: 17,
17
+ fontWeight: value === index ? 700 : 510,
18
+ color: value === index
19
+ ? 'button_color.main'
20
+ : 'secondary_hint_color.main',
21
+ '&.Mui-selected': {
22
+ color: 'button_color.main',
23
+ },
24
+ } }, index))) }));
25
+ };
@@ -0,0 +1,9 @@
1
+ import { ReactElement } from 'react';
2
+ import { TextFieldProps as MuiTextFieldProps } from '@mui/material';
3
+ export type TMATextFieldProps = MuiTextFieldProps & {
4
+ hasClearButton?: boolean;
5
+ onChange?: (value: string) => void;
6
+ HintIcon?: ReactElement;
7
+ };
8
+ export declare const TMATextField: ({ hasClearButton, label, onChange, value, fullWidth, HintIcon, ...props }: TMATextFieldProps) => import("react/jsx-runtime").JSX.Element;
9
+ //# sourceMappingURL=TMATextField.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMATextField.d.ts","sourceRoot":"","sources":["../../../src/components/TMATextField/TMATextField.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAIL,cAAc,IAAI,iBAAiB,EAGpC,MAAM,eAAe,CAAC;AAGvB,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,GAAG;IAClD,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,QAAQ,CAAC,EAAE,YAAY,CAAC;CACzB,CAAC;AAEF,eAAO,MAAM,YAAY,8EAQtB,iBAAiB,4CA4CnB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { IconButton, InputLabel, TextField as MuiTextField, Stack, Typography, } from '@mui/material';
3
+ import CloseIcon from '@mui/icons-material/CloseRounded';
4
+ export const TMATextField = ({ hasClearButton, label, onChange, value, fullWidth, HintIcon, ...props }) => {
5
+ return (_jsxs(Stack, { direction: "column", alignItems: "stretch", ...(fullWidth && { flexGrow: 1 } || {}), children: [_jsx(InputLabel, { sx: { pl: 2, pb: 1 }, children: _jsxs(Stack, { direction: "row", alignItems: "center", gap: 1, children: [_jsx(Typography, { variant: "caption1Regular", color: "hint_color", children: label }), HintIcon && HintIcon] }) }), _jsx(MuiTextField, { onChange: (event) => onChange ? onChange(event.target.value) : null, value: value, ...props, slotProps: {
6
+ input: {
7
+ endAdornment: hasClearButton && Boolean(value) ? (_jsx(IconButton, { onClick: () => onChange ? onChange('') : null, sx: {
8
+ width: 24,
9
+ height: 24,
10
+ position: 'absolute',
11
+ backgroundColor: 'plain_background.main',
12
+ borderRadius: 100,
13
+ right: 16,
14
+ top: 12,
15
+ '& svg': {
16
+ width: 16,
17
+ height: 16,
18
+ color: 'plain_foreground.main',
19
+ },
20
+ }, children: _jsx(CloseIcon, {}) })) : undefined,
21
+ },
22
+ } })] }));
23
+ };
@@ -0,0 +1,7 @@
1
+ export type TMATextWithTitleProps = {
2
+ title: string;
3
+ text: string;
4
+ maxLines?: number;
5
+ };
6
+ export declare const TMATextWithTitle: ({ title, text, maxLines, }: TMATextWithTitleProps) => import("react/jsx-runtime").JSX.Element;
7
+ //# sourceMappingURL=TMATextWithTitle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMATextWithTitle.d.ts","sourceRoot":"","sources":["../../../src/components/TMATextWithTitle/TMATextWithTitle.tsx"],"names":[],"mappings":"AAMA,MAAM,MAAM,qBAAqB,GAAG;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,gBAAgB,+BAI1B,qBAAqB,4CAwBvB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import Stack from '@mui/material/Stack';
3
+ import Typography from '@mui/material/Typography';
4
+ import { BASE_SPACING } from '../../theme';
5
+ const MAX_LINES = 2;
6
+ export const TMATextWithTitle = ({ title, text, maxLines = MAX_LINES, }) => {
7
+ return (_jsxs(Stack, { width: "100%", gap: 2 / BASE_SPACING, direction: "column", children: [_jsx(Typography, { variant: "subheadline2Regular", color: "hint_color.main", children: title }), _jsx(Typography, { color: "text_color.main", variant: "textRegular", sx: {
8
+ display: '-webkit-box',
9
+ overflow: 'hidden',
10
+ textOverflow: 'ellipsis',
11
+ WebkitBoxOrient: 'vertical',
12
+ WebkitLineClamp: maxLines,
13
+ }, children: text })] }));
14
+ };
@@ -0,0 +1,14 @@
1
+ import { SnackbarProps } from '@mui/material/Snackbar';
2
+ export interface TMAToastProps extends SnackbarProps {
3
+ message: string;
4
+ type: 'success' | 'error' | 'warning' | 'info';
5
+ closeText?: string;
6
+ }
7
+ export declare const IconMap: {
8
+ success: import("react/jsx-runtime").JSX.Element;
9
+ error: import("react/jsx-runtime").JSX.Element;
10
+ warning: import("react/jsx-runtime").JSX.Element;
11
+ info: import("react/jsx-runtime").JSX.Element;
12
+ };
13
+ export declare const TMAToast: ({ open, onClose, message, type, closeText, }: TMAToastProps) => import("react/jsx-runtime").JSX.Element;
14
+ //# sourceMappingURL=TMAToast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMAToast.d.ts","sourceRoot":"","sources":["../../../src/components/TMAToast/TMAToast.tsx"],"names":[],"mappings":"AAEA,OAAiB,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAWjE,MAAM,WAAW,aAAc,SAAQ,aAAa;IAClD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,SAAS,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IAC/C,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,OAAO;;;;;CAKnB,CAAC;AAEF,eAAO,MAAM,QAAQ,iDAMlB,aAAa,4CAkDf,CAAC"}
@@ -0,0 +1,38 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import Snackbar from '@mui/material/Snackbar';
3
+ import Stack from '@mui/material/Stack';
4
+ import Typography from '@mui/material/Typography';
5
+ import CheckCircle from '@mui/icons-material/CheckCircleOutline';
6
+ import Error from '@mui/icons-material/ErrorOutline';
7
+ import Warning from '@mui/icons-material/Warning';
8
+ import Info from '@mui/icons-material/Info';
9
+ import Button from '@mui/material/Button';
10
+ import { useTheme } from '@mui/material/styles';
11
+ import { BASE_SPACING } from '../../theme';
12
+ export const IconMap = {
13
+ success: _jsx(CheckCircle, { sx: { color: 'destructive_text_color.main' } }),
14
+ error: _jsx(Error, { sx: { color: 'destructive_text_color.main' } }),
15
+ warning: _jsx(Warning, { sx: { color: 'destructive_text_color.main' } }),
16
+ info: _jsx(Info, { sx: { color: 'destructive_text_color.main' } }),
17
+ };
18
+ export const TMAToast = ({ open, onClose, message, type, closeText = 'Ок', }) => {
19
+ const theme = useTheme();
20
+ const Icon = IconMap[type];
21
+ return (_jsx(Snackbar, { open: open, onClose: onClose, sx: {
22
+ width: 'calc(100% - 40px)',
23
+ mx: 'auto',
24
+ bottom: 8,
25
+ }, anchorOrigin: {
26
+ vertical: 'bottom',
27
+ horizontal: 'center',
28
+ }, children: _jsxs(Stack, { bgcolor: "surface_dark.main", width: "100%", direction: "row", alignItems: "center", justifyContent: "space-between", gap: 12 / BASE_SPACING, sx: {
29
+ backdropFilter: 'blur(56px)',
30
+ borderRadius: 3,
31
+ py: 10 / BASE_SPACING,
32
+ pl: 14 / BASE_SPACING,
33
+ pr: 15 / BASE_SPACING,
34
+ }, children: [Icon, _jsx(Typography, { color: "white", variant: "caption1Regular", children: message }), _jsx(Button, { variant: "text", onClick: (e) => onClose?.(e, 'clickaway'), sx: {
35
+ typography: 'textRegular',
36
+ color: `${theme.palette.toast_accent_color.main} !important`,
37
+ }, children: closeText })] }) }));
38
+ };
@@ -0,0 +1,11 @@
1
+ import { SvgIconTypeMap, SxProps } from '@mui/material';
2
+ import { OverridableComponent } from '@mui/material/OverridableComponent';
3
+ import { TooltipProps } from '@mui/material/Tooltip';
4
+ export type TMATooltipProps = TooltipProps & {
5
+ Icon?: OverridableComponent<SvgIconTypeMap<{}, "svg">> & {
6
+ muiName: string;
7
+ };
8
+ iconSx?: SxProps;
9
+ };
10
+ export declare const TMATooltip: ({ title, arrow, disableHoverListener, disableFocusListener, enterTouchDelay, children }: TMATooltipProps) => import("react/jsx-runtime").JSX.Element;
11
+ //# sourceMappingURL=TMATooltip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TMATooltip.d.ts","sourceRoot":"","sources":["../../../src/components/TMATooltip/TMATooltip.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAgB,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAE9D,MAAM,MAAM,eAAe,GAAG,YAAY,GAAG;IAC3C,IAAI,CAAC,EAAE,oBAAoB,CAAC,cAAc,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,GAAG;QACvD,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,UAAU,4FAOpB,eAAe,4CAYjB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import Tooltip from '@mui/material/Tooltip';
3
+ export const TMATooltip = ({ title, arrow = true, disableHoverListener = true, disableFocusListener = true, enterTouchDelay = 10, children }) => {
4
+ return (_jsx(Tooltip, { arrow: arrow, disableHoverListener: disableHoverListener, disableFocusListener: disableFocusListener, enterTouchDelay: enterTouchDelay, title: title, children: children }));
5
+ };