首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为chakra-ui上的Modal创建变体样式

为chakra-ui上的Modal创建变体样式
EN

Stack Overflow用户
提问于 2021-07-10 04:05:00
回答 1查看 589关注 0票数 1

我想用创建一个Modal变体,并设置默认的宽度和背景颜色(以及其他东西)。我找不到确切说明如何做到这一点的文档,但我认为使用variants将是可行的方法。

我已经在代码沙盒上做了最好的尝试:https://codesandbox.io/s/vigilant-germain-u3mkx

任何建议都将受到欢迎。

EN

回答 1

Stack Overflow用户

发布于 2021-08-17 09:45:19

代码语言:javascript
复制
import {
  ChakraProvider,
  Modal,
  extendTheme,
  Button,
  useDisclosure,
  ModalOverlay,
  ModalContent,
  ModalHeader,
  ModalFooter,
  ModalCloseButton,
  ModalBody
} from "@chakra-ui/react";
import "./styles.css";

const theme = extendTheme({
  components: {
    Modal: {
      baseStyle: (props) => ({
        dialog: {
          maxWidth: ["95%", "95%", "95%"],
          minWidth: "95%",
          bg: "#00ff00"
        }
      })
    }
  }
});

export default function App() {
  const { isOpen, onOpen, onClose } = useDisclosure();

  return (
    <ChakraProvider theme={theme}>
      <Button onClick={onOpen}>Open Modal</Button>

      <Modal isOpen={isOpen} onClose={onClose} variant="wide">
        <ModalOverlay />
        <ModalContent>
          <ModalHeader>Modal Title</ModalHeader>
          <ModalCloseButton />
          <ModalBody>
            <p>Test</p>
          </ModalBody>

          <ModalFooter>
            <Button colorScheme="blue" mr={3} onClick={onClose}>
              Close
            </Button>
            <Button variant="ghost">Secondary Action</Button>
          </ModalFooter>
        </ModalContent>
      </Modal>
    </ChakraProvider>
  );
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68322212

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档