@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.
- package/README.md +419 -0
- package/dist/cjs/components/TMAActionBar/TMAActionBar.d.ts +10 -0
- package/dist/cjs/components/TMAActionBar/TMAActionBar.d.ts.map +1 -0
- package/dist/cjs/components/TMAActionBar/TMAActionBar.js +40 -0
- package/dist/cjs/components/TMABannersFeed/StoryDrawer.d.ts +12 -0
- package/dist/cjs/components/TMABannersFeed/StoryDrawer.d.ts.map +1 -0
- package/dist/cjs/components/TMABannersFeed/StoryDrawer.js +121 -0
- package/dist/cjs/components/TMABannersFeed/StoryProgress.d.ts +11 -0
- package/dist/cjs/components/TMABannersFeed/StoryProgress.d.ts.map +1 -0
- package/dist/cjs/components/TMABannersFeed/StoryProgress.js +81 -0
- package/dist/cjs/components/TMABannersFeed/TMABannerFeed.d.ts +28 -0
- package/dist/cjs/components/TMABannersFeed/TMABannerFeed.d.ts.map +1 -0
- package/dist/cjs/components/TMABannersFeed/TMABannerFeed.js +87 -0
- package/dist/cjs/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts +5 -0
- package/dist/cjs/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts.map +1 -0
- package/dist/cjs/components/TMABannersFeed/TMABannerFeedPropsContext.js +11 -0
- package/dist/cjs/components/TMABannersFeed/TMAStoryDrawer.d.ts +11 -0
- package/dist/cjs/components/TMABannersFeed/TMAStoryDrawer.d.ts.map +1 -0
- package/dist/cjs/components/TMABannersFeed/TMAStoryDrawer.js +126 -0
- package/dist/cjs/components/TMABannersFeed/propsContext.d.ts +5 -0
- package/dist/cjs/components/TMABannersFeed/propsContext.d.ts.map +1 -0
- package/dist/cjs/components/TMABannersFeed/propsContext.js +10 -0
- package/dist/cjs/components/TMABarChart/ItemTooltip.d.ts +12 -0
- package/dist/cjs/components/TMABarChart/ItemTooltip.d.ts.map +1 -0
- package/dist/cjs/components/TMABarChart/ItemTooltip.js +39 -0
- package/dist/cjs/components/TMABarChart/TMABarChart.d.ts +10 -0
- package/dist/cjs/components/TMABarChart/TMABarChart.d.ts.map +1 -0
- package/dist/cjs/components/TMABarChart/TMABarChart.js +131 -0
- package/dist/cjs/components/TMABaseSection/TMABaseSection.d.ts +7 -0
- package/dist/cjs/components/TMABaseSection/TMABaseSection.d.ts.map +1 -0
- package/dist/cjs/components/TMABaseSection/TMABaseSection.js +18 -0
- package/dist/cjs/components/TMACell/TMACell.d.ts +12 -0
- package/dist/cjs/components/TMACell/TMACell.d.ts.map +1 -0
- package/dist/cjs/components/TMACell/TMACell.js +18 -0
- package/dist/cjs/components/TMACellList/TMACellList.d.ts +6 -0
- package/dist/cjs/components/TMACellList/TMACellList.d.ts.map +1 -0
- package/dist/cjs/components/TMACellList/TMACellList.js +18 -0
- package/dist/cjs/components/TMACheckbox/TMACheckbox.d.ts +7 -0
- package/dist/cjs/components/TMACheckbox/TMACheckbox.d.ts.map +1 -0
- package/dist/cjs/components/TMACheckbox/TMACheckbox.js +11 -0
- package/dist/cjs/components/TMACounter/TMACountInput.d.ts +9 -0
- package/dist/cjs/components/TMACounter/TMACountInput.d.ts.map +1 -0
- package/dist/cjs/components/TMACounter/TMACountInput.js +36 -0
- package/dist/cjs/components/TMACounter/TMACounter.d.ts +11 -0
- package/dist/cjs/components/TMACounter/TMACounter.d.ts.map +1 -0
- package/dist/cjs/components/TMACounter/TMACounter.js +33 -0
- package/dist/cjs/components/TMADrawerFilter/TMADrawerFilter.d.ts +29 -0
- package/dist/cjs/components/TMADrawerFilter/TMADrawerFilter.d.ts.map +1 -0
- package/dist/cjs/components/TMADrawerFilter/TMADrawerFilter.js +47 -0
- package/dist/cjs/components/TMADrawerFilter/TMARightDrawerFilter.d.ts +4 -0
- package/dist/cjs/components/TMADrawerFilter/TMARightDrawerFilter.d.ts.map +1 -0
- package/dist/cjs/components/TMADrawerFilter/TMARightDrawerFilter.js +12 -0
- package/dist/cjs/components/TMADrawerFilter/TMATopDrawerFilter.d.ts +4 -0
- package/dist/cjs/components/TMADrawerFilter/TMATopDrawerFilter.d.ts.map +1 -0
- package/dist/cjs/components/TMADrawerFilter/TMATopDrawerFilter.js +11 -0
- package/dist/cjs/components/TMADrawerHeader/TMADrawerHeader.d.ts +6 -0
- package/dist/cjs/components/TMADrawerHeader/TMADrawerHeader.d.ts.map +1 -0
- package/dist/cjs/components/TMADrawerHeader/TMADrawerHeader.js +29 -0
- package/dist/cjs/components/TMALoadable/TMALoadable.d.ts +15 -0
- package/dist/cjs/components/TMALoadable/TMALoadable.d.ts.map +1 -0
- package/dist/cjs/components/TMALoadable/TMALoadable.js +25 -0
- package/dist/cjs/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts +34 -0
- package/dist/cjs/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts.map +1 -0
- package/dist/cjs/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.js +188 -0
- package/dist/cjs/components/TMASelect/TMASelect.d.ts +20 -0
- package/dist/cjs/components/TMASelect/TMASelect.d.ts.map +1 -0
- package/dist/cjs/components/TMASelect/TMASelect.js +152 -0
- package/dist/cjs/components/TMASelect/TMASelectOption.d.ts +8 -0
- package/dist/cjs/components/TMASelect/TMASelectOption.d.ts.map +1 -0
- package/dist/cjs/components/TMASelect/TMASelectOption.js +15 -0
- package/dist/cjs/components/TMAStatisticsCard/TMAStatisticsCard.d.ts +12 -0
- package/dist/cjs/components/TMAStatisticsCard/TMAStatisticsCard.d.ts.map +1 -0
- package/dist/cjs/components/TMAStatisticsCard/TMAStatisticsCard.js +30 -0
- package/dist/cjs/components/TMATabs/TMATabs.d.ts +14 -0
- package/dist/cjs/components/TMATabs/TMATabs.d.ts.map +1 -0
- package/dist/cjs/components/TMATabs/TMATabs.js +32 -0
- package/dist/cjs/components/TMATextField/TMATextField.d.ts +9 -0
- package/dist/cjs/components/TMATextField/TMATextField.d.ts.map +1 -0
- package/dist/cjs/components/TMATextField/TMATextField.js +30 -0
- package/dist/cjs/components/TMATextWithTitle/TMATextWithTitle.d.ts +7 -0
- package/dist/cjs/components/TMATextWithTitle/TMATextWithTitle.d.ts.map +1 -0
- package/dist/cjs/components/TMATextWithTitle/TMATextWithTitle.js +21 -0
- package/dist/cjs/components/TMAToast/TMAToast.d.ts +14 -0
- package/dist/cjs/components/TMAToast/TMAToast.d.ts.map +1 -0
- package/dist/cjs/components/TMAToast/TMAToast.js +45 -0
- package/dist/cjs/components/TMATooltip/TMATooltip.d.ts +11 -0
- package/dist/cjs/components/TMATooltip/TMATooltip.d.ts.map +1 -0
- package/dist/cjs/components/TMATooltip/TMATooltip.js +12 -0
- package/dist/cjs/components/index.d.ts +28 -0
- package/dist/cjs/components/index.d.ts.map +1 -0
- package/dist/cjs/components/index.js +55 -0
- package/dist/cjs/context/BackButtonContext/BackButtonContext.d.ts +7 -0
- package/dist/cjs/context/BackButtonContext/BackButtonContext.d.ts.map +1 -0
- package/dist/cjs/context/BackButtonContext/BackButtonContext.js +16 -0
- package/dist/cjs/context/index.d.ts +2 -0
- package/dist/cjs/context/index.d.ts.map +1 -0
- package/dist/cjs/context/index.js +17 -0
- package/dist/cjs/context/theme.d.ts +7 -0
- package/dist/cjs/context/theme.d.ts.map +1 -0
- package/dist/cjs/context/theme.js +16 -0
- package/dist/cjs/fonts.d.ts +4 -0
- package/dist/cjs/fonts.d.ts.map +1 -0
- package/dist/cjs/fonts.js +80 -0
- package/dist/cjs/hooks/index.d.ts +3 -0
- package/dist/cjs/hooks/index.d.ts.map +1 -0
- package/dist/cjs/hooks/index.js +23 -0
- package/dist/cjs/hooks/useBackButton.d.ts +2 -0
- package/dist/cjs/hooks/useBackButton.d.ts.map +1 -0
- package/dist/cjs/hooks/useBackButton.js +28 -0
- package/dist/cjs/hooks/useTMALongPress.d.ts +13 -0
- package/dist/cjs/hooks/useTMALongPress.d.ts.map +1 -0
- package/dist/cjs/hooks/useTMALongPress.js +63 -0
- package/dist/cjs/index.d.ts +7 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +50 -0
- package/dist/cjs/theme.d.ts +541 -0
- package/dist/cjs/theme.d.ts.map +1 -0
- package/dist/cjs/theme.js +769 -0
- package/dist/components/TMAActionBar/TMAActionBar.d.ts +10 -0
- package/dist/components/TMAActionBar/TMAActionBar.d.ts.map +1 -0
- package/dist/components/TMAActionBar/TMAActionBar.js +33 -0
- package/dist/components/TMABannersFeed/StoryDrawer.d.ts +12 -0
- package/dist/components/TMABannersFeed/StoryDrawer.d.ts.map +1 -0
- package/dist/components/TMABannersFeed/StoryDrawer.js +114 -0
- package/dist/components/TMABannersFeed/StoryProgress.d.ts +11 -0
- package/dist/components/TMABannersFeed/StoryProgress.d.ts.map +1 -0
- package/dist/components/TMABannersFeed/StoryProgress.js +77 -0
- package/dist/components/TMABannersFeed/TMABannerFeed.d.ts +28 -0
- package/dist/components/TMABannersFeed/TMABannerFeed.d.ts.map +1 -0
- package/dist/components/TMABannersFeed/TMABannerFeed.js +80 -0
- package/dist/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts +5 -0
- package/dist/components/TMABannersFeed/TMABannerFeedPropsContext.d.ts.map +1 -0
- package/dist/components/TMABannersFeed/TMABannerFeedPropsContext.js +7 -0
- package/dist/components/TMABannersFeed/TMAStoryDrawer.d.ts +11 -0
- package/dist/components/TMABannersFeed/TMAStoryDrawer.d.ts.map +1 -0
- package/dist/components/TMABannersFeed/TMAStoryDrawer.js +119 -0
- package/dist/components/TMABannersFeed/propsContext.d.ts +5 -0
- package/dist/components/TMABannersFeed/propsContext.d.ts.map +1 -0
- package/dist/components/TMABannersFeed/propsContext.js +6 -0
- package/dist/components/TMABarChart/ItemTooltip.d.ts +12 -0
- package/dist/components/TMABarChart/ItemTooltip.d.ts.map +1 -0
- package/dist/components/TMABarChart/ItemTooltip.js +33 -0
- package/dist/components/TMABarChart/TMABarChart.d.ts +10 -0
- package/dist/components/TMABarChart/TMABarChart.d.ts.map +1 -0
- package/dist/components/TMABarChart/TMABarChart.js +91 -0
- package/dist/components/TMABaseSection/TMABaseSection.d.ts +7 -0
- package/dist/components/TMABaseSection/TMABaseSection.d.ts.map +1 -0
- package/dist/components/TMABaseSection/TMABaseSection.js +11 -0
- package/dist/components/TMACell/TMACell.d.ts +12 -0
- package/dist/components/TMACell/TMACell.d.ts.map +1 -0
- package/dist/components/TMACell/TMACell.js +11 -0
- package/dist/components/TMACellList/TMACellList.d.ts +6 -0
- package/dist/components/TMACellList/TMACellList.d.ts.map +1 -0
- package/dist/components/TMACellList/TMACellList.js +11 -0
- package/dist/components/TMACheckbox/TMACheckbox.d.ts +7 -0
- package/dist/components/TMACheckbox/TMACheckbox.d.ts.map +1 -0
- package/dist/components/TMACheckbox/TMACheckbox.js +7 -0
- package/dist/components/TMACounter/TMACountInput.d.ts +9 -0
- package/dist/components/TMACounter/TMACountInput.d.ts.map +1 -0
- package/dist/components/TMACounter/TMACountInput.js +34 -0
- package/dist/components/TMACounter/TMACounter.d.ts +11 -0
- package/dist/components/TMACounter/TMACounter.d.ts.map +1 -0
- package/dist/components/TMACounter/TMACounter.js +26 -0
- package/dist/components/TMADrawerFilter/TMADrawerFilter.d.ts +29 -0
- package/dist/components/TMADrawerFilter/TMADrawerFilter.d.ts.map +1 -0
- package/dist/components/TMADrawerFilter/TMADrawerFilter.js +40 -0
- package/dist/components/TMADrawerFilter/TMARightDrawerFilter.d.ts +4 -0
- package/dist/components/TMADrawerFilter/TMARightDrawerFilter.d.ts.map +1 -0
- package/dist/components/TMADrawerFilter/TMARightDrawerFilter.js +8 -0
- package/dist/components/TMADrawerFilter/TMATopDrawerFilter.d.ts +4 -0
- package/dist/components/TMADrawerFilter/TMATopDrawerFilter.d.ts.map +1 -0
- package/dist/components/TMADrawerFilter/TMATopDrawerFilter.js +7 -0
- package/dist/components/TMADrawerHeader/TMADrawerHeader.d.ts +6 -0
- package/dist/components/TMADrawerHeader/TMADrawerHeader.d.ts.map +1 -0
- package/dist/components/TMADrawerHeader/TMADrawerHeader.js +22 -0
- package/dist/components/TMALoadable/TMALoadable.d.ts +15 -0
- package/dist/components/TMALoadable/TMALoadable.d.ts.map +1 -0
- package/dist/components/TMALoadable/TMALoadable.js +18 -0
- package/dist/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts +34 -0
- package/dist/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.d.ts.map +1 -0
- package/dist/components/TMAMultiSelectWithTags/TMAMultiSelectWithTags.js +181 -0
- package/dist/components/TMASelect/TMASelect.d.ts +20 -0
- package/dist/components/TMASelect/TMASelect.d.ts.map +1 -0
- package/dist/components/TMASelect/TMASelect.js +145 -0
- package/dist/components/TMASelect/TMASelectOption.d.ts +8 -0
- package/dist/components/TMASelect/TMASelectOption.d.ts.map +1 -0
- package/dist/components/TMASelect/TMASelectOption.js +8 -0
- package/dist/components/TMAStatisticsCard/TMAStatisticsCard.d.ts +12 -0
- package/dist/components/TMAStatisticsCard/TMAStatisticsCard.d.ts.map +1 -0
- package/dist/components/TMAStatisticsCard/TMAStatisticsCard.js +23 -0
- package/dist/components/TMATabs/TMATabs.d.ts +14 -0
- package/dist/components/TMATabs/TMATabs.d.ts.map +1 -0
- package/dist/components/TMATabs/TMATabs.js +25 -0
- package/dist/components/TMATextField/TMATextField.d.ts +9 -0
- package/dist/components/TMATextField/TMATextField.d.ts.map +1 -0
- package/dist/components/TMATextField/TMATextField.js +23 -0
- package/dist/components/TMATextWithTitle/TMATextWithTitle.d.ts +7 -0
- package/dist/components/TMATextWithTitle/TMATextWithTitle.d.ts.map +1 -0
- package/dist/components/TMATextWithTitle/TMATextWithTitle.js +14 -0
- package/dist/components/TMAToast/TMAToast.d.ts +14 -0
- package/dist/components/TMAToast/TMAToast.d.ts.map +1 -0
- package/dist/components/TMAToast/TMAToast.js +38 -0
- package/dist/components/TMATooltip/TMATooltip.d.ts +11 -0
- package/dist/components/TMATooltip/TMATooltip.d.ts.map +1 -0
- package/dist/components/TMATooltip/TMATooltip.js +5 -0
- package/dist/components/index.d.ts +28 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +25 -0
- package/dist/context/BackButtonContext/BackButtonContext.d.ts +7 -0
- package/dist/context/BackButtonContext/BackButtonContext.d.ts.map +1 -0
- package/dist/context/BackButtonContext/BackButtonContext.js +12 -0
- package/dist/context/index.d.ts +2 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +1 -0
- package/dist/context/theme.d.ts +7 -0
- package/dist/context/theme.d.ts.map +1 -0
- package/dist/context/theme.js +10 -0
- package/dist/fonts.d.ts +4 -0
- package/dist/fonts.d.ts.map +1 -0
- package/dist/fonts.js +74 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +2 -0
- package/dist/hooks/useBackButton.d.ts +2 -0
- package/dist/hooks/useBackButton.d.ts.map +1 -0
- package/dist/hooks/useBackButton.js +24 -0
- package/dist/hooks/useTMALongPress.d.ts +13 -0
- package/dist/hooks/useTMALongPress.d.ts.map +1 -0
- package/dist/hooks/useTMALongPress.js +61 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/theme.d.ts +541 -0
- package/dist/theme.d.ts.map +1 -0
- package/dist/theme.js +766 -0
- package/fonts/Inter.ttf +0 -0
- package/fonts/SF-Pro.ttf +0 -0
- package/fonts/SFMono-Medium.otf +0 -0
- 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
|
+
};
|