mirror of
https://github.com/spacedriveapp/spacedrive.git
synced 2026-02-20 07:37:26 -05:00
* WIP * Some minor fixes for light theme - Fix `useIsDark` not reading the initial theme value (only reacting to theme changes) - Fix `Inspector` always showing a dark image when no item was selected - Fix `Thumb` video extension using black text on light theme * Improve form error messages - Fix `addLocationDialog` not registering the path input - Remove `@hookform/error-message` * Fix Dialog not respecting max-width - Fix ErrorMessage animation jumping * A lot of misc fixes - Implement an `useExplorerItemData` (cleaner fix for thumbnail flicker) - Fix broken image showing for `Thumb` due a rece condition when props are updated - Implement an `ExternalObject` component that hacks an alternative for `onLoad` and `onError` events for <object> - Fix `Overview` broken layout when `Inspector` is open and window is small - Improve `IndexerRuleEditor` UX in `AddLocationDialog` - Improve the way `IndexerRuleEditor` handles rules deletion - Fix `IndexerRuleEditor` closing the the new rule form even when the rule creation fails - Add an editable prop to `IndexerRuleEditor` to disable all editable functions - Fix `getIcon` fallbacking to Document instead of the dark version of an icon if it exists - Add some missing colors to white theme * Format * Fix Backup restore key dialog not resetting after error * Feedback * Format * Normalize imports * Fix ColorPicker export * Fix Thumb video ext not showing in MediaView with show square thumbnails - Fix AddLocationDialog Error resetting when changing IndexRules
51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
import { Clipboard } from 'phosphor-react';
|
|
import { Button, Dialog, Input, UseDialogProps, dialogManager, useDialog } from '@sd/ui';
|
|
import { useZodForm } from '@sd/ui/src/forms';
|
|
|
|
interface Props extends UseDialogProps {
|
|
title: string; // dialog title
|
|
description?: string; // description of the dialog
|
|
value: string; // value to be displayed as text or in an input box
|
|
label?: string; // button label
|
|
inputBox?: boolean; // whether the dialog should display the `value` in a disabled input box or as text
|
|
}
|
|
|
|
const AlertDialog = (props: Props) => {
|
|
// maybe a copy-to-clipboard button would be beneficial too
|
|
return (
|
|
<Dialog
|
|
title={props.title}
|
|
form={useZodForm()}
|
|
dialog={useDialog(props)}
|
|
description={props.description}
|
|
ctaLabel={props.label !== undefined ? props.label : 'Done'}
|
|
onCancelled={false}
|
|
>
|
|
{props.inputBox ? (
|
|
<Input
|
|
value={props.value}
|
|
disabled
|
|
className="mt-3"
|
|
right={
|
|
<Button
|
|
type="button"
|
|
onClick={() => {
|
|
navigator.clipboard.writeText(props.value);
|
|
}}
|
|
size="icon"
|
|
>
|
|
<Clipboard className="h-4 w-4" />
|
|
</Button>
|
|
}
|
|
/>
|
|
) : (
|
|
<div className="text-sm">{props.value}</div>
|
|
)}
|
|
</Dialog>
|
|
);
|
|
};
|
|
|
|
export function showAlertDialog(props: Omit<Props, 'id'>) {
|
|
dialogManager.create((dp) => <AlertDialog {...dp} {...props} />);
|
|
}
|