Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/aslam97/react-confirm-dialog

React Confirm Dialog
https://github.com/aslam97/react-confirm-dialog

alert-dialog radix-ui shadcn-ui

Last synced: about 3 hours ago
JSON representation

React Confirm Dialog

Awesome Lists containing this project

README

        

# React Confirm Dialog






A flexible and customizable confirm dialog component for React applications, built with accessibility in mind.

## Features

- Easy to use with the `useConfirm` hook
- Fully customizable appearance and behavior
- Supports custom actions
- Seamless integration with Shadcn UI

## Installation

Install the package from npm:

```bash
npm install @omit/react-confirm-dialog
```

## Usage

### 1. Wrap your app with the ConfirmDialogProvider

```jsx
import { ConfirmDialogProvider } from '@omit/react-confirm-dialog'

function App() {
return (
{/* Your app components */}
)
}
```

### 2. Use the useConfirm hook in your components

```jsx
import { useConfirm } from '@omit/react-confirm-dialog'

function YourComponent() {
const confirm = useConfirm()

const handleClick = async () => {
const isConfirmed = await confirm({
title: 'Delete Item',
description: 'Are you sure you want to delete this item?',
confirmText: 'Delete',
cancelText: 'Cancel'
})

if (isConfirmed) {
// Perform delete action
}
}

return Delete
}
```

### 3. Update your Tailwind configuration

Add the library classes to your `tailwind.config.js`:

```js
module.exports = {
content: [
'./node_modules/@omit/react-confirm-dialog/dist/index.js'
// ... your other content paths
]
// ... other configurations
}
```

## Configuration for Non-Shadcn UI Users

If you're not using Shadcn UI, follow these additional steps:

### 1. Update your tailwind.config.js

```js
module.exports = {
theme: {
extend: {
colors: {
border: 'hsl(var(--border))',
input: 'hsl(var(--input))',
ring: 'hsl(var(--ring))',
background: 'hsl(var(--background))',
foreground: 'hsl(var(--foreground))',
primary: {
DEFAULT: 'hsl(var(--primary))',
foreground: 'hsl(var(--primary-foreground))'
},
secondary: {
DEFAULT: 'hsl(var(--secondary))',
foreground: 'hsl(var(--secondary-foreground))'
},
destructive: {
DEFAULT: 'hsl(var(--destructive))',
foreground: 'hsl(var(--destructive-foreground))'
},
muted: {
DEFAULT: 'hsl(var(--muted))',
foreground: 'hsl(var(--muted-foreground))'
},
accent: {
DEFAULT: 'hsl(var(--accent))',
foreground: 'hsl(var(--accent-foreground))'
}
}
}
},
plugins: [require('tailwindcss-animate')]
}
```

### 2. Add CSS variables

Add these CSS variables to your main CSS file (or get your colors from [Shadcn UI](https://ui.shadcn.com/themes)):

```css
@layer base {
:root {
--background: 0 0% 100%;
--foreground: 240 10% 3.9%;
--primary: 240 5.9% 10%;
--primary-foreground: 0 0% 98%;
--secondary: 240 4.8% 95.9%;
--secondary-foreground: 240 5.9% 10%;
--muted: 240 4.8% 95.9%;
--muted-foreground: 240 3.8% 46.1%;
--accent: 240 4.8% 95.9%;
--accent-foreground: 240 5.9% 10%;
--destructive: 0 84.2% 60.2%;
--destructive-foreground: 0 0% 98%;
--border: 240 5.9% 90%;
--input: 240 5.9% 90%;
--ring: 240 5.9% 10%;
--radius: 0.5rem;
}

.dark {
--background: 240 10% 3.9%;
--foreground: 0 0% 98%;
--primary: 0 0% 98%;
--primary-foreground: 240 5.9% 10%;
--secondary: 240 3.7% 15.9%;
--secondary-foreground: 0 0% 98%;
--muted: 240 3.7% 15.9%;
--muted-foreground: 240 5% 64.9%;
--accent: 240 3.7% 15.9%;
--accent-foreground: 0 0% 98%;
--destructive: 0 62.8% 30.6%;
--destructive-foreground: 0 0% 98%;
--border: 240 3.7% 15.9%;
--input: 240 3.7% 15.9%;
--ring: 240 4.9% 83.9%;
}
}
```

## Advanced Usage

### Custom Content Slot

You can add additional content between the description and actions:

```jsx
handleClick = async () => {
const isConfirmed = await confirm({
title: 'Custom Content',
description: 'This dialog includes custom content.',
contentSlot:
})
}
```

### Custom Actions

The library supports custom actions API that provides access to the dialog's configuration:

```jsx
const handleClick = async () => {
const isConfirmed = await confirm({
title: 'Custom Actions',
customActions: ({ confirm, cancel, config, setConfig }) => (


{
setConfig((prev) => ({ ...prev, title: 'Updated Title' }))
}}
>
Update Title

Confirm
Cancel

)
})
}
```

### Dynamic Configuration Updates

You can update the dialog's configuration even after it's opened:

```jsx
const confirm = useConfirm()

confirm.updateConfig((prev) => ({
...prev,
description: 'Updated description'
}))
```

### Default Options

You can set default options for all confirm dialogs in your app:

```jsx

{/* Your app components */}

```

## API Reference

### ConfirmOptions

The `confirm` function accepts an options object with the following properties:

```typescript
interface ConfirmOptions {
// Content
title?: ReactNode
description?: ReactNode
contentSlot?: ReactNode
icon?: ReactNode

// Button Text
confirmText?: string
cancelText?: string

// Custom Actions
customActions?: LegacyCustomActions | EnhancedCustomActions

// Button Props
confirmButton?: ComponentPropsWithRef
cancelButton?: ComponentPropsWithRef | null

// Component Props
alertDialogOverlay?: ComponentPropsWithRef
alertDialogContent?: ComponentPropsWithRef
alertDialogHeader?: ComponentPropsWithRef
alertDialogTitle?: ComponentPropsWithRef
alertDialogDescription?: ComponentPropsWithRef
alertDialogFooter?: ComponentPropsWithRef
}
```

## Tailwind CSS Intellisense

To enable class name completion for the `className` prop, add this to your editor settings:

```diff
{
"tailwindCSS.experimental.classRegex": [
"class:\\s*?[\"'`]([^\"'`]*).*?,",
+ "className:\\s*[\"']([^\"']*)[\"']"
]
}
```

## Related Projects

- [Minimal Tiptap Editor](https://github.com/Aslam97/shadcn-minimal-tiptap)
- [React Fancy Switch](https://github.com/Aslam97/react-fancy-switch)

## License

This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.