mirror of
https://github.com/frappe/erpnext.git
synced 2026-05-18 12:39:18 +00:00
* feat: initial SPA setup for banking * wip: bring over new banking module * feat: added Espresso design tokens * feat: button styles * fix: add all ink colors * wip: espresso design system changes * feat: button and badge espresso components * fix: button styling for reconcile * feat: Espresso progress bar * feat: Espresso toggle switch * feat: Espresso tabs design * fix: vertical tab support * fix: button sizing across modals * feat: Espresso style table layout * feat: Espresso tooltip * feat: Espresso elevations and checkbox * feat: Dialog with Espresso styles * feat: Espresso textarea * fix: input styles * fix: colors on bank picker * fix: breadcrumb styling * fix: bank picker styling * feat: create doctypes and fields for bank reconciliation * feat: APIs for banking * fix: use date format parser * fix: font styling to match Espresso * wip: settings modal * feat: settings dialog component * fix: icons and invalid requests * feat: preferences tab * fix: adjust icon stroke width to 1.5 * feat: rule configuration in settings * fix: remove sheet component * feat: alert and error banner component * feat: dropdown in Espresso * feat: popover and select in Espresso * fix: cleanup more styles * fix: match size of link fields * feat: command styling * fix: remove unused style tokens * fix: styles for global date picker dropdown * fix: styles for match and reconcile * feat: table Espresso component * feat: remove all other design tokens * fix: remove unused tokens * fix: form elements * fix: remove unused styles and fix filters in bank transaction list * feat: fetch bank rec doctypes for filtering * fix: record payment modal * feat: support for dark mode switching * fix: move bank logos to public folder * feat: add support for RTL * feat: support for RTL * chore: send layout direction in dev boot * fix: make checkbox work in RTL * feat: dark mode support * fix: dark mode style * feat: bank logos in dark mode * feat: dark mode bank logos * chore: use dark mode bank logos everywhere * chore: move rule evaluation to controller * chore: add tests for bank transaction rules * fix: move deps to fix actions errors * fix: move tw-animate-css to deps * fix: remove shadcn * fix: do not open modal if no transactions selected * fix: add translation strings * feat: add banner on existing bank reconciliation tool * feat: bank statement import * fix: translations and layout directions * fix: validation for transaction matching rule * fix: styles * fix: show conflicting transactions in alert * fix: show help text for new banking module forms * feat: show total debits and credits * fix: dark mode colors in automatic config * feat: add keyboard shortcuts help * feat: added keyboard shortcut for settings * fix: decrease size of progress bar * chore: bump packages * feat: add tests for statement import * fix: settings dialog * fix: show banner on small screens * fix: show banner when no bank account set
105 lines
2.4 KiB
TypeScript
105 lines
2.4 KiB
TypeScript
import * as React from "react"
|
|
import { cva, type VariantProps } from "class-variance-authority"
|
|
|
|
import { cn } from "@/lib/utils"
|
|
|
|
const alertVariants = cva(
|
|
"relative w-full rounded-lg border px-4 py-3.5 text-base grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-1 [&>svg]:text-current",
|
|
{
|
|
variants: {
|
|
variant: {
|
|
subtle: "bg-surface-white",
|
|
outline: "border border-outline-gray-3",
|
|
},
|
|
theme: {
|
|
gray: "text-ink-gray-8",
|
|
blue: "text-ink-blue-3",
|
|
green: "text-ink-green-3",
|
|
red: "text-ink-red-3",
|
|
amber: "text-ink-amber-3",
|
|
}
|
|
},
|
|
compoundVariants: [
|
|
// Subtle alerts
|
|
{
|
|
theme: "gray",
|
|
variant: "subtle",
|
|
className: "bg-surface-gray-2 border-outline-gray-1"
|
|
},
|
|
{
|
|
theme: "blue",
|
|
variant: "subtle",
|
|
className: "bg-surface-blue-2 border-surface-blue-2"
|
|
},
|
|
{
|
|
theme: "green",
|
|
variant: "subtle",
|
|
className: "bg-surface-green-2 border-surface-green-2"
|
|
},
|
|
{
|
|
theme: "red",
|
|
variant: "subtle",
|
|
className: "bg-surface-red-2 border-surface-red-2"
|
|
},
|
|
{
|
|
theme: "amber",
|
|
variant: "subtle",
|
|
className: "bg-surface-amber-2 border-surface-amber-2"
|
|
}
|
|
],
|
|
defaultVariants: {
|
|
variant: "subtle",
|
|
theme: "gray",
|
|
},
|
|
}
|
|
)
|
|
|
|
export type AlertProps = React.ComponentProps<"div"> & VariantProps<typeof alertVariants>
|
|
|
|
function Alert({
|
|
className,
|
|
variant,
|
|
theme,
|
|
...props
|
|
}: AlertProps) {
|
|
return (
|
|
<div
|
|
data-slot="alert"
|
|
role="alert"
|
|
className={cn(alertVariants({ variant, theme }), className)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
function AlertTitle({ className, ...props }: React.ComponentProps<"div">) {
|
|
return (
|
|
<div
|
|
data-slot="alert-title"
|
|
className={cn(
|
|
"col-start-2 min-h-4 text-ink-gray-8 font-medium text-p-base",
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
function AlertDescription({
|
|
className,
|
|
...props
|
|
}: React.ComponentProps<"div">) {
|
|
return (
|
|
<div
|
|
data-slot="alert-description"
|
|
className={cn(
|
|
"text-ink-gray-6 col-start-2 grid justify-items-start gap-1 text-p-base",
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
export { Alert, AlertTitle, AlertDescription }
|