@chakra-ui/react#DrawerCloseButton JavaScript Examples
The following examples show how to use
@chakra-ui/react#DrawerCloseButton.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: components.js From idena-web with MIT License | 6 votes |
export function Drawer({isCloseable = true, children, ...props}) {
const maxWidth = useBreakpointValue(['auto', 360])
const drawerSize = useBreakpointValue(['full', 'xs'])
const closeButtonSize = useBreakpointValue(['lg', 'md'])
const drawerPromotion = React.useState()
return (
<DrawerPromotionContext.Provider value={drawerPromotion}>
<ChakraDrawer placement="right" {...props}>
<DrawerOverlay bg="xblack.080" />
<DrawerContent
px={8}
pt={[4, 12]}
pb={4}
size={drawerSize}
maxW={maxWidth}
>
{isCloseable && (
<DrawerCloseButton
size={closeButtonSize}
color={['brandBlue.100', 'initial']}
/>
)}
{children}
</DrawerContent>
<DrawerPromotion
left={maxWidth > 0 ? `calc(50% - ${maxWidth / 2}px)` : '50%'}
/>
</ChakraDrawer>
</DrawerPromotionContext.Provider>
)
}
Example #2
Source File: ConferenceCard.js From codeursenseine.com with MIT License | 4 votes |
ConferenceCard = ({ conference, speakers }) => {
const { isOpen, onOpen, onClose } = useDisclosure();
const capitalizeFirstLetter = (string) =>
string.charAt(0).toUpperCase() + string.slice(1);
if (conference?.childMdx?.frontmatter?.type === "break") {
return (
<Card variant="primary" mt={2}>
<Stack align="center">
<Text>{conference?.childMdx?.frontmatter?.title}</Text>
</Stack>
</Card>
);
}
return (
<Stack>
<Grid
templateColumns={["repeat(1, 1fr)", "repeat(1, 1fr) repeat(1, 4fr)"]}
mt={3}
>
<Stack mr={3}>
<Flex
display={["none", "flex"]}
flexDirection="column"
justifyContent="space-between"
h="100%"
borderColor="blue.50"
borderStyle="solid"
borderTopWidth={1}
borderBottomWidth={1}
>
<Text color="blue.600">
{conference.childMdx.frontmatter.startHour}
</Text>
<Text color="blue.600">
{conference.childMdx.frontmatter.endHour}
</Text>
</Flex>
<Stack display={["block", "none"]} mb={2}>
<Text color="blue.600">
{`${conference.childMdx.frontmatter.startHour} - ${conference.childMdx.frontmatter.endHour}`}
</Text>
</Stack>
{conference.childMdx.frontmatter.isKeynote && (
<Badge colorScheme="brand" width="fit-content">
Keynote
</Badge>
)}
</Stack>
<Card
borderLeftWidth={2}
borderLeftColor="brand.600"
onClick={onOpen}
w="full"
isLink
>
<Heading fontSize="md">
{conference.childMdx.frontmatter.title}
</Heading>
{speakers?.map((speaker) => (
<SpeakerPreview
key={speaker.childMdx.frontmatter.slug}
speaker={speaker}
/>
))}
<Center>
<Button
colorScheme="brand"
variant="link"
width="fit-content"
mt={2}
>
Voir les détails et s'inscrire
</Button>
</Center>
</Card>
</Grid>
<Drawer size="md" isOpen={isOpen} placement="right" onClose={onClose}>
<DrawerOverlay>
<DrawerContent>
<DrawerCloseButton />
<DrawerHeader>
<Stack alignItems="center" display="flex" flexDirection="row">
<Text fontSize="sm" mt={2}>
{capitalizeFirstLetter(
dayjs(conference.childMdx.frontmatter.eventDate).format(
"dddd D MMM"
)
)}{" "}
{`${conference.childMdx.frontmatter.startHour} - ${conference.childMdx.frontmatter.endHour}`}
</Text>
{conference.childMdx.frontmatter.isKeynote && (
<Badge
ml={3}
h="fit-content"
colorScheme="brand"
width="fit-content"
>
Keynote
</Badge>
)}
</Stack>
<Text>{conference.childMdx.frontmatter.title}</Text>
<Stack mt={3}>
{speakers?.map((speaker) => (
<SpeakerPreview
key={speaker.childMdx.frontmatter.slug}
speaker={speaker}
/>
))}
</Stack>
</DrawerHeader>
<DrawerBody overflow="auto">
<MDXRenderer>{conference.childMdx.body}</MDXRenderer>
</DrawerBody>
{conference.childMdx.frontmatter.meetupLink && (
<DrawerFooter display="flex" flexDirection="column">
<Button isFullWidth variant="outline" mb={3} onClick={onClose}>
Fermer
</Button>
<Button
colorScheme="brand"
as={Link}
target="_blank"
to={conference.childMdx.frontmatter.meetupLink}
isFullWidth
>
S'inscrire
</Button>
</DrawerFooter>
)}
</DrawerContent>
</DrawerOverlay>
</Drawer>
</Stack>
);
}
Example #3
Source File: containers.js From idena-web with MIT License | 4 votes |
export function VotingInspector({onTerminate, ...contract}) {
const [result, setResult] = React.useState({})
const {isOpen, onOpen, onClose} = useDisclosure()
const {isOpen: isOpenContract, onToggle: onToggleContract} = useDisclosure()
return (
<>
<Button
bg="blue.50"
rightIcon="info"
variant="ghost"
colorScheme="blue"
onClick={onOpen}
>
Open inspector
</Button>
<ChakraDrawer isOpen={isOpen} size="lg" onClose={onClose}>
<DrawerOverlay bg="xblack.080" />
<DrawerContent px={8} py={12} overflowY="auto">
<DrawerCloseButton />
<DrawerHeader>
<Heading fontSize="lg" fontWeight={500} mb={2}>
Inspector
</Heading>
</DrawerHeader>
<DrawerBody fontSize="md">
<Stack spacing={4} w="lg">
<Stack>
<Flex align="center">
<Heading fontSize="base" fontWeight={500} my={4}>
Contract
</Heading>
<IconButton
icon="chevron-down"
size="sm"
fontSize="lg"
ml={1}
onClick={onToggleContract}
/>
</Flex>
<Collapse isOpen={isOpenContract}>
<Debug>{contract}</Debug>
</Collapse>
<Box mt={2}>
<Heading fontSize="base" fontWeight={500} my={4}>
readonlyCall
</Heading>
<Stack
as="form"
spacing={3}
onSubmit={async e => {
e.preventDefault()
const {
readonlyCallMethod,
readonlyCallMethodFormat,
readonlyCallArgs,
} = e.target.elements
setResult(
await createContractReadonlyCaller(contract)(
readonlyCallMethod.value,
readonlyCallMethodFormat.value,
JSON.parse(readonlyCallArgs.value || '[]')
)
)
}}
>
<Stack isInline spacing={2} justify="space-between">
<Input
id="readonlyCallMethod"
placeholder="readonlyCallMethod method"
/>
<Input
id="readonlyCallMethodFormat"
placeholder="format"
w={100}
/>
</Stack>
<Input
id="readonlyCallArgs"
placeholder="readonlyCall args"
/>
<SecondaryButton type="submit" ml="auto">
Readonly call
</SecondaryButton>
</Stack>
</Box>
<Box>
<Heading fontSize="base" fontWeight={500} my={4}>
readKey
</Heading>
<Stack
as="form"
spacing={3}
onSubmit={async e => {
e.preventDefault()
const {readKey, readKeyFormat} = e.target.elements
setResult(
await createContractDataReader(contract.contractHash)(
readKey.value,
readKeyFormat.value
)
)
}}
>
<Stack isInline>
<Input id="readKey" placeholder="readKey key" />
<Input id="readKeyFormat" placeholder="format" w={100} />
</Stack>
<SecondaryButton
type="submit"
ml="auto"
onClick={async () => {}}
>
Read data
</SecondaryButton>
</Stack>
</Box>
<Box>
<Heading fontSize="base" fontWeight={500} my={4}>
txReceipt
</Heading>
<Stack
as="form"
spacing={3}
onSubmit={async e => {
e.preventDefault()
setResult(
await callRpc(
'bcn_txReceipt',
e.target.elements.txHash.value
)
)
}}
>
<Stack isInline>
<Input id="txHash" placeholder="txHash" />
</Stack>
<SecondaryButton
type="submit"
ml="auto"
onClick={async () => {}}
>
Show receipt
</SecondaryButton>
</Stack>
</Box>
<Box>
<Heading fontSize="base" fontWeight={500} my={4}>
contract_getStake
</Heading>
<Stack
as="form"
spacing={3}
onSubmit={async e => {
e.preventDefault()
setResult(
await callRpc(
'contract_getStake',
contract.contractHash
)
)
}}
>
<Stack isInline>
<Input
value={contract.contractHash}
isReadonly
isDisabled
/>
</Stack>
<SecondaryButton
type="submit"
ml="auto"
onClick={async () => {}}
>
Get stake
</SecondaryButton>
</Stack>
</Box>
<Box ml="auto" mt={6}>
<PrimaryButton
colorScheme="red"
variant="solid"
_active={{}}
onClick={onTerminate}
>
Terminate contact
</PrimaryButton>
</Box>
</Stack>
<Debug>{result}</Debug>
</Stack>
</DrawerBody>
</DrawerContent>
</ChakraDrawer>
</>
)
}
Example #4
Source File: showreel.js From react-table-library with MIT License | 4 votes |
Component = () => {
const [data, setData] = React.useState({ nodes });
//* Theme *//
const chakraTheme = getTheme({
...DEFAULT_OPTIONS,
striped: true,
});
const customTheme = {
Table: `
--data-table-library_grid-template-columns: 64px repeat(5, minmax(0, 1fr));
margin: 16px 0px;
`,
};
const theme = useTheme([chakraTheme, customTheme]);
//* Resize *//
const resize = { resizerHighlight: '#dee2e6' };
//* Pagination *//
const pagination = usePagination(data, {
state: {
page: 0,
size: 4,
},
onChange: onPaginationChange,
});
function onPaginationChange(action, state) {
console.log(action, state);
}
//* Search *//
const [search, setSearch] = React.useState('');
useCustom('search', data, {
state: { search },
onChange: onSearchChange,
});
function onSearchChange(action, state) {
console.log(action, state);
pagination.fns.onSetPage(0);
}
//* Filter *//
const [isHide, setHide] = React.useState(false);
useCustom('filter', data, {
state: { isHide },
onChange: onFilterChange,
});
function onFilterChange(action, state) {
console.log(action, state);
pagination.fns.onSetPage(0);
}
//* Select *//
const select = useRowSelect(data, {
onChange: onSelectChange,
});
function onSelectChange(action, state) {
console.log(action, state);
}
//* Tree *//
const tree = useTree(
data,
{
onChange: onTreeChange,
},
{
clickType: TreeExpandClickTypes.ButtonClick,
treeYLevel: 1,
treeIcon: {
margin: '4px',
iconDefault: null,
iconRight: <FaChevronRight />,
iconDown: <FaChevronDown />,
},
},
);
function onTreeChange(action, state) {
console.log(action, state);
}
//* Sort *//
const sort = useSort(
data,
{
onChange: onSortChange,
},
{
sortIcon: {
iconDefault: null,
iconUp: <FaChevronUp />,
iconDown: <FaChevronDown />,
},
sortFns: {
TASK: (array) => array.sort((a, b) => a.name.localeCompare(b.name)),
DEADLINE: (array) => array.sort((a, b) => a.deadline - b.deadline),
TYPE: (array) => array.sort((a, b) => a.type.localeCompare(b.type)),
COMPLETE: (array) => array.sort((a, b) => a.isComplete - b.isComplete),
TASKS: (array) => array.sort((a, b) => (a.nodes || []).length - (b.nodes || []).length),
},
},
);
function onSortChange(action, state) {
console.log(action, state);
}
//* Drawer *//
const [drawerId, setDrawerId] = React.useState(null);
const [edited, setEdited] = React.useState('');
const handleEdit = (event) => {
setEdited(event.target.value);
};
const handleCancel = () => {
setEdited('');
setDrawerId(null);
};
const handleSave = () => {
const node = findNodeById(data.nodes, drawerId);
const editedNode = { ...node, name: edited };
const nodes = insertNode(data.nodes, editedNode);
setData({
nodes,
});
setEdited('');
setDrawerId(null);
};
//* Modal *//
const [modalOpened, setModalOpened] = React.useState(false);
//* Custom Modifiers *//
let modifiedNodes = data.nodes;
// search
modifiedNodes = modifiedNodes.filter((node) =>
node.name.toLowerCase().includes(search.toLowerCase()),
);
// filter
modifiedNodes = isHide ? modifiedNodes.filter((node) => !node.isComplete) : modifiedNodes;
//* Columns *//
const COLUMNS = [
{
label: 'Task',
renderCell: (item) => item.name,
resize,
sort: { sortKey: 'TASK' },
select: {
renderHeaderCellSelect: () => (
<Checkbox
colorScheme="teal"
isChecked={select.state.all}
isIndeterminate={!select.state.all && !select.state.none}
onChange={select.fns.onToggleAll}
/>
),
renderCellSelect: (item) => (
<Checkbox
colorScheme="teal"
style={{ backgroundColor: '#ffffff' }}
isChecked={select.state.ids.includes(item.id)}
onChange={() => select.fns.onToggleById(item.id)}
/>
),
},
tree: true,
},
{
label: 'Deadline',
renderCell: (item) =>
item.deadline.toLocaleDateString('en-US', {
year: 'numeric',
month: '2-digit',
day: '2-digit',
}),
resize,
sort: { sortKey: 'DEADLINE' },
},
{ label: 'Type', renderCell: (item) => item.type, resize, sort: { sortKey: 'TYPE' } },
{
label: 'Complete',
renderCell: (item) => item.isComplete.toString(),
resize,
sort: { sortKey: 'COMPLETE' },
},
{
label: 'Tasks',
renderCell: (item) => (
<div style={{ display: 'flex', justifyContent: 'space-between', alignItems: 'center' }}>
<span>{item.nodes?.length}</span>
<IconButton
aria-label="edit"
icon={<FaPen />}
size="xs"
variant="ghost"
colorScheme="teal"
onClick={() => setDrawerId(item.id)}
/>
</div>
),
resize,
sort: { sortKey: 'TASKS' },
},
];
return (
<>
<Modal isOpen={modalOpened} onClose={() => setModalOpened(false)}>
<ModalOverlay />
<ModalContent>
<ModalHeader>Not all features included here, but we got ...</ModalHeader>
<ModalCloseButton />
<ModalBody>
<div>
<Checkbox colorScheme="teal" isChecked>
Resize
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Sort
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Search
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Filter
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Select
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Tree
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Drawer on Edit
</Checkbox>
</div>
<div>
<Checkbox colorScheme="teal" isChecked>
Pagination
</Checkbox>
</div>
</ModalBody>
</ModalContent>
</Modal>
{/* Form */}
<HStack m={3}>
<Button colorScheme="teal" onClick={() => setModalOpened(true)}>
Features?
</Button>
<InputGroup>
<InputLeftElement
pointerEvents="none"
children={<FaSearch style={{ color: '#4a5568' }} />}
/>
<Input
placeholder="Search Task"
value={search}
onChange={(event) => setSearch(event.target.value)}
/>
</InputGroup>
<Checkbox
style={{ whiteSpace: 'nowrap' }}
colorScheme="teal"
isChecked={isHide}
onChange={(event) => setHide(event.target.checked)}
>
Hide Complete
</Checkbox>
</HStack>
{/* Table */}
<Box p={3} borderWidth="1px" borderRadius="lg">
<CompactTable
columns={COLUMNS}
data={{ ...data, nodes: modifiedNodes }}
theme={theme}
layout={{ custom: true }}
select={select}
tree={tree}
sort={sort}
pagination={pagination}
/>
</Box>
<br />
<HStack justify="flex-end">
<IconButton
aria-label="previous page"
icon={<FaChevronLeft />}
colorScheme="teal"
variant="ghost"
disabled={pagination.state.page === 0}
onClick={() => pagination.fns.onSetPage(pagination.state.page - 1)}
/>
{pagination.state.getPages(modifiedNodes).map((_, index) => (
<Button
key={index}
colorScheme="teal"
variant={pagination.state.page === index ? 'solid' : 'ghost'}
onClick={() => pagination.fns.onSetPage(index)}
>
{index + 1}
</Button>
))}
<IconButton
aria-label="next page"
icon={<FaChevronRight />}
colorScheme="teal"
variant="ghost"
disabled={pagination.state.page + 1 === pagination.state.getTotalPages(data.nodes)}
onClick={() => pagination.fns.onSetPage(pagination.state.page + 1)}
/>
</HStack>
<Drawer isOpen={drawerId} onClose={handleCancel} placement="right">
<DrawerOverlay />
<DrawerContent>
<DrawerCloseButton />
<DrawerHeader>Create your account</DrawerHeader>
<DrawerBody>
<Text>Name: </Text>
<Input
autoFocus
value={
edited || fromTreeToList(data.nodes).find((node) => node.id === drawerId)?.name
}
onChange={handleEdit}
data-autofocus
/>
</DrawerBody>
<DrawerFooter>
<Button variant="outline" mr={3} onClick={handleCancel}>
Cancel
</Button>
<Button onClick={handleSave} colorScheme="teal">
Save
</Button>
</DrawerFooter>
</DrawerContent>
</Drawer>
</>
);
}