From 5116834c5473fa4eea70a6bdcc05593dd78b0bf4 Mon Sep 17 00:00:00 2001 From: Cheton Wu <447801+cheton@users.noreply.github.com> Date: Tue, 8 Oct 2024 11:54:07 +0800 Subject: [PATCH] docs: ensure `ToastManager` is layered above `PortalManager` to enable adding toast notifications within a portal (#936) --- packages/react-docs/pages/_app.page.js | 40 ++++++------- .../components/portal-manager/index.page.mdx | 24 ++++---- .../components/toast-manager/index.page.mdx | 58 +++++++++---------- .../getting-started/usage/index.page.mdx | 42 +++++++------- 4 files changed, 81 insertions(+), 83 deletions(-) diff --git a/packages/react-docs/pages/_app.page.js b/packages/react-docs/pages/_app.page.js index 719d9ec62a..f82d399f56 100644 --- a/packages/react-docs/pages/_app.page.js +++ b/packages/react-docs/pages/_app.page.js @@ -133,31 +133,31 @@ const App = (props) => { theme={customTheme} useCSSBaseline > - - &:first-of-type': { - mt: '4x', // the space to the top edge of the screen - }, - '[data-toast-placement^="bottom"] > &:last-of-type': { - mb: '4x', // the space to the bottom edge of the screen - }, - '[data-toast-placement$="left"] > &': { - ml: '4x', // the space to the left edge of the screen - }, - '[data-toast-placement$="right"] > &': { - mr: '4x', // the space to the right edge of the screen - }, + &:first-of-type': { + mt: '4x', // the space to the top edge of the screen }, - }} - > + '[data-toast-placement^="bottom"] > &:last-of-type': { + mb: '4x', // the space to the bottom edge of the screen + }, + '[data-toast-placement$="left"] > &': { + ml: '4x', // the space to the left edge of the screen + }, + '[data-toast-placement$="right"] > &': { + mr: '4x', // the space to the right edge of the screen + }, + }, + }} + > + - - + + diff --git a/packages/react-docs/pages/components/portal-manager/index.page.mdx b/packages/react-docs/pages/components/portal-manager/index.page.mdx index 86306f1ac0..5f796eda76 100644 --- a/packages/react-docs/pages/components/portal-manager/index.page.mdx +++ b/packages/react-docs/pages/components/portal-manager/index.page.mdx @@ -4,20 +4,20 @@ ## Setup -To incorporate with `PortalManager`, wrap your root component with the `PortalManager` component. This provides a context that the `usePortalManager` Hook can access. +First, import the necessary components: -```jsx disabled -import { TonicProvider, PortalManager } from '@tonic-ui/react'; +```js +import { + PortalManager, +} from '@tonic-ui/react'; +``` -function App() { - return ( - - - {/* Your app goes here */} - - - ); -} +Next, wrap your application with `PortalManager`: + +```jsx disabled + + + ``` Once `PortalManager` is set up, any component can use the `usePortalManager` Hook to create and manage portals. diff --git a/packages/react-docs/pages/components/toast-manager/index.page.mdx b/packages/react-docs/pages/components/toast-manager/index.page.mdx index c2dfdf6645..428ba5b441 100644 --- a/packages/react-docs/pages/components/toast-manager/index.page.mdx +++ b/packages/react-docs/pages/components/toast-manager/index.page.mdx @@ -4,38 +4,36 @@ ## Setup -To use `ToastManager`, you should wrap your root component with it, along with the `TonicProvider` component, as shown in the example below: +First, import the `ToastManager` component: -```jsx disabled -import { TonicProvider, ToastManager } from '@tonic-ui/react'; +```jsx +import { ToastManager } from '@tonic-ui/react'; +``` -function App() { - return ( - - &:first-of-type': { - mt: '4x', // the space to the top edge of the screen - }, - '[data-toast-placement^="bottom"] > &:last-of-type': { - mb: '4x', // the space to the bottom edge of the screen - }, - '[data-toast-placement$="left"] > &': { - ml: '4x', // the space to the left edge of the screen - }, - '[data-toast-placement$="right"] > &': { - mr: '4x', // the space to the right edge of the screen - }, - }, - }} - placement="bottom-right" - > - {/* Your app goes here */} - - - ); -} +Next, wrap your application with `ToastManager`: + +```jsx disabled + &:first-of-type': { + mt: '4x', // the space to the top edge of the screen + }, + '[data-toast-placement^="bottom"] > &:last-of-type': { + mb: '4x', // the space to the bottom edge of the screen + }, + '[data-toast-placement$="left"] > &': { + ml: '4x', // the space to the left edge of the screen + }, + '[data-toast-placement$="right"] > &': { + mr: '4x', // the space to the right edge of the screen + }, + }, + }} + placement="bottom-right" +> + + ``` Once `ToastManager` is set up, you can use the `useToastManager` Hook to create and manage toasts from any component: diff --git a/packages/react-docs/pages/getting-started/usage/index.page.mdx b/packages/react-docs/pages/getting-started/usage/index.page.mdx index 6eee356bd6..3762570495 100644 --- a/packages/react-docs/pages/getting-started/usage/index.page.mdx +++ b/packages/react-docs/pages/getting-started/usage/index.page.mdx @@ -45,9 +45,9 @@ import { Global, css } from '@emotion/react'; import React from 'react'; import { Box, - TonicProvider, PortalManager, // allows you to create and manage portals in the application ToastManager, // allows you to create and manage toasts in the application + TonicProvider, colorStyle, theme, useColorMode, @@ -69,30 +69,30 @@ function App(props) { theme={theme} useCSSBaseline={true} // If `true`, apply CSS reset and base styles > - - &:first-of-type': { - mt: '4x', // the space to the top edge of the screen - }, - '[data-toast-placement^="bottom"] > &:last-of-type': { - mb: '4x', // the space to the bottom edge of the screen - }, - '[data-toast-placement$="left"] > &': { - ml: '4x', // the space to the left edge of the screen - }, - '[data-toast-placement$="right"] > &': { - mr: '4x', // the space to the right edge of the screen - }, + &:first-of-type': { + mt: '4x', // the space to the top edge of the screen + }, + '[data-toast-placement^="bottom"] > &:last-of-type': { + mb: '4x', // the space to the bottom edge of the screen + }, + '[data-toast-placement$="left"] > &': { + ml: '4x', // the space to the left edge of the screen + }, + '[data-toast-placement$="right"] > &': { + mr: '4x', // the space to the right edge of the screen }, - }} - > + }, + }} + > + - - + + ); }