Added components, authentication and authorization
This commit is contained in:
@@ -0,0 +1,187 @@
|
||||
@import "tailwindcss";
|
||||
|
||||
@theme {
|
||||
--color-background: hsl(var(--background));
|
||||
--color-foreground: hsl(var(--foreground));
|
||||
|
||||
--color-card: hsl(var(--card));
|
||||
--color-card-foreground: hsl(var(--card-foreground));
|
||||
|
||||
--color-popover: hsl(var(--popover));
|
||||
--color-popover-foreground: hsl(var(--popover-foreground));
|
||||
|
||||
--color-primary: hsl(var(--primary));
|
||||
--color-primary-foreground: hsl(var(--primary-foreground));
|
||||
|
||||
--color-secondary: hsl(var(--secondary));
|
||||
--color-secondary-foreground: hsl(var(--secondary-foreground));
|
||||
|
||||
--color-muted: hsl(var(--muted));
|
||||
--color-muted-foreground: hsl(var(--muted-foreground));
|
||||
|
||||
--color-accent: hsl(var(--accent));
|
||||
--color-accent-foreground: hsl(var(--accent-foreground));
|
||||
|
||||
--color-destructive: hsl(var(--destructive));
|
||||
--color-destructive-foreground: hsl(var(--destructive-foreground));
|
||||
|
||||
--color-border: hsl(var(--border));
|
||||
--color-input: hsl(var(--input));
|
||||
--color-ring: hsl(var(--ring));
|
||||
|
||||
--radius-lg: var(--radius);
|
||||
--radius-md: calc(var(--radius) - 2px);
|
||||
--radius-sm: calc(var(--radius) - 4px);
|
||||
}
|
||||
|
||||
@layer base {
|
||||
:root {
|
||||
--background: 0 0% 100%;
|
||||
--foreground: 222.2 84% 4.9%;
|
||||
--card: 0 0% 100%;
|
||||
--card-foreground: 222.2 84% 4.9%;
|
||||
--popover: 0 0% 100%;
|
||||
--popover-foreground: 222.2 84% 4.9%;
|
||||
--primary: 222.2 47.4% 11.2%;
|
||||
--primary-foreground: 210 40% 98%;
|
||||
--secondary: 210 40% 96.1%;
|
||||
--secondary-foreground: 222.2 47.4% 11.2%;
|
||||
--muted: 210 40% 96.1%;
|
||||
--muted-foreground: 215.4 16.3% 46.9%;
|
||||
--accent: 210 40% 96.1%;
|
||||
--accent-foreground: 222.2 47.4% 11.2%;
|
||||
--destructive: 0 84.2% 60.2%;
|
||||
--destructive-foreground: 210 40% 98%;
|
||||
--border: 214.3 31.8% 91.4%;
|
||||
--input: 214.3 31.8% 91.4%;
|
||||
--ring: 222.2 84% 4.9%;
|
||||
--radius: 0.5rem;
|
||||
}
|
||||
|
||||
.dark {
|
||||
--background: 222.2 84% 4.9%;
|
||||
--foreground: 210 40% 98%;
|
||||
--card: 222.2 84% 4.9%;
|
||||
--card-foreground: 210 40% 98%;
|
||||
--popover: 222.2 84% 4.9%;
|
||||
--popover-foreground: 210 40% 98%;
|
||||
--primary: 210 40% 98%;
|
||||
--primary-foreground: 222.2 47.4% 11.2%;
|
||||
--secondary: 217.2 32.6% 17.5%;
|
||||
--secondary-foreground: 210 40% 98%;
|
||||
--muted: 217.2 32.6% 17.5%;
|
||||
--muted-foreground: 215 20.2% 65.1%;
|
||||
--accent: 217.2 32.6% 17.5%;
|
||||
--accent-foreground: 210 40% 98%;
|
||||
--destructive: 0 62.8% 30.6%;
|
||||
--destructive-foreground: 210 40% 98%;
|
||||
--border: 217.2 32.6% 17.5%;
|
||||
--input: 217.2 32.6% 17.5%;
|
||||
--ring: 212.7 26.8% 83.9%;
|
||||
}
|
||||
}
|
||||
|
||||
@layer base {
|
||||
* {
|
||||
@apply border-border;
|
||||
}
|
||||
|
||||
body {
|
||||
@apply bg-background text-foreground;
|
||||
}
|
||||
}
|
||||
|
||||
/* ── Calendar component ───────────────────────────────────────────────── */
|
||||
@layer components {
|
||||
.cal-dow {
|
||||
@apply text-xs font-medium text-muted-foreground py-1;
|
||||
}
|
||||
|
||||
.cal-day {
|
||||
@apply h-9 w-full rounded-md text-sm text-center
|
||||
text-foreground bg-transparent
|
||||
hover:bg-accent hover:text-accent-foreground
|
||||
focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring
|
||||
transition-colors cursor-pointer;
|
||||
}
|
||||
|
||||
.cal-day-selected {
|
||||
@apply bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground;
|
||||
}
|
||||
|
||||
.cal-day-today {
|
||||
@apply font-semibold underline underline-offset-2;
|
||||
}
|
||||
|
||||
.cal-nav {
|
||||
@apply text-lg leading-none;
|
||||
}
|
||||
|
||||
/* ── Month / year quick-pick grid ── */
|
||||
.cal-view-btn {
|
||||
@apply h-9 w-full rounded-md text-sm text-center
|
||||
text-foreground bg-transparent
|
||||
hover:bg-accent hover:text-accent-foreground
|
||||
focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring
|
||||
transition-colors cursor-pointer;
|
||||
}
|
||||
|
||||
.cal-view-btn-selected {
|
||||
@apply bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground;
|
||||
}
|
||||
|
||||
/* ── CalendarRange day states ── */
|
||||
.calr-day {
|
||||
@apply h-9 w-full text-sm text-center text-foreground
|
||||
transition-colors cursor-pointer focus-visible:outline-none
|
||||
focus-visible:ring-2 focus-visible:ring-ring;
|
||||
}
|
||||
|
||||
/* Plain days (no range involvement) */
|
||||
.calr-day-plain {
|
||||
@apply rounded-md hover:bg-accent hover:text-accent-foreground;
|
||||
}
|
||||
|
||||
/* Start cap — primary, rounded left only */
|
||||
.calr-day-start {
|
||||
@apply rounded-l-md bg-primary text-primary-foreground
|
||||
hover:bg-primary;
|
||||
}
|
||||
|
||||
/* End cap — primary, rounded right only */
|
||||
.calr-day-end {
|
||||
@apply rounded-r-md bg-primary text-primary-foreground
|
||||
hover:bg-primary;
|
||||
}
|
||||
|
||||
/* Days strictly between start and end */
|
||||
.calr-day-mid {
|
||||
@apply rounded-none bg-accent text-accent-foreground
|
||||
hover:bg-accent;
|
||||
}
|
||||
}
|
||||
|
||||
/* ── Select – custom caret via background SVG ─────────────────────────── */
|
||||
@layer components {
|
||||
select.appearance-none {
|
||||
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
|
||||
background-repeat: no-repeat;
|
||||
background-position: right 0.75rem center;
|
||||
padding-right: 2.25rem;
|
||||
}
|
||||
}
|
||||
|
||||
/* ── TimePicker – hide number spinner arrows ──────────────────────────── */
|
||||
@layer utilities {
|
||||
input[type=number].timepicker-hour,
|
||||
input[type=number].timepicker-minute {
|
||||
-moz-appearance: textfield;
|
||||
}
|
||||
input[type=number].timepicker-hour::-webkit-outer-spin-button,
|
||||
input[type=number].timepicker-hour::-webkit-inner-spin-button,
|
||||
input[type=number].timepicker-minute::-webkit-outer-spin-button,
|
||||
input[type=number].timepicker-minute::-webkit-inner-spin-button {
|
||||
-webkit-appearance: none;
|
||||
margin: 0;
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user