saleor-dashboard/src/components/VisibilityCard/DateVisibilitySelector.tsx
Dominik Żegleń 62817568a7
Use MacawUI (#1229)
* Replace withStyleswith useStyles (#1100)

* Replace withStyleswith useStyles

* Update messages

* Use rem as a spacing unit (#1101)

* Use rems as spacing units

* Fix visual bugs

* Update stories

* Use macaw-ui as theme provider (#1108)

* Use macaw ui as a theme provider

* Add react-dom to aliases

* Fix jest module resolution

* Update useTheme hook usage

* Fix test wrapper

* Use macaw from git repo

* Fix CI

* Update stories

* Fix aliasing

* Extract savebar to macaw ui (#1146)

* wip

* Use savebar from macaw

* Use confirm button from macaw

* Improve file structure

* Use sidebar context from macaw

* Update macaw

* Update macaw version

* Remove savebar from storybook

* Update stories

* Use alerts and notifications from macaw (#1166)

* Use alerts from macaw

* Add notifications from macaw

* Update stories

* Pin macaw version

* Encapsulate limit reached in one component

* Remove unused imports

* Use backlinks from macaw (#1183)

* Use backlink from macaw

* Update macaw version

* Use macaw sidebar (#1148)

* Use sidebar from macaw

* Use shipped logo

* Use lowercase

* Update stories

* Use user chip from macaw (#1191)

* Use user chip from macaw

* Use dedicated components for menu items

* Simplify code

* Bump version and fix types (#1210)

* Rename onBack to onClick

* Rename UserChip to UserChipMenu

* Rename IMenuItem to SidebarMenuItem

* Update macaw version

* Fix tables after changes in macaw (#1220)

* Update macaw version

* Update changelog

* Update stories

* Fix after rebase

* Update to macaw 0.2.0

* Lint files

* Update macaw to 0.2.2
2021-07-21 10:59:52 +02:00

83 lines
1.7 KiB
TypeScript

import closeIcon from "@assets/images/close-thin.svg";
import { Typography } from "@material-ui/core";
import { makeStyles } from "@saleor/macaw-ui";
import React, { useState } from "react";
import FormSpacer from "../FormSpacer";
const CLOSE_ICON_SIZE = 14;
const useStyles = makeStyles(
theme => ({
buttonText: {
color: theme.palette.primary.main,
cursor: "pointer",
fontSize: 14,
marginBottom: theme.spacing(1),
paddingBottom: 10,
paddingTop: 0
},
container: {
alignItems: "baseline",
display: "flex",
flexDirection: "row",
justifyContent: "space-between"
},
icon: {
cursor: "pointer",
marginLeft: theme.spacing(2)
}
}),
{ name: "DateVisibilitySelector" }
);
interface Props {
buttonText: string;
children: React.ReactNode;
onInputClose: () => void;
}
const DateVisibilitySelector = ({
buttonText,
children,
onInputClose
}: Props) => {
const classes = useStyles({});
const [showInput, setShowInput] = useState<boolean>(false);
const handleCloseIconClick = () => {
setShowInput(false);
onInputClose();
};
if (!showInput) {
return (
<Typography
className={classes.buttonText}
onClick={() => setShowInput(true)}
>
{buttonText}
</Typography>
);
}
return (
<>
<div className={classes.container}>
{children}
<div className={classes.icon} onClick={handleCloseIconClick}>
<img
src={closeIcon}
alt="close icon"
width={CLOSE_ICON_SIZE}
height={CLOSE_ICON_SIZE}
/>
</div>
</div>
<FormSpacer />
</>
);
};
export default DateVisibilitySelector;