Calendar/wwwroot/css/calendar-v2.css
Janus C. H. Knudsen b3f47e93e8 New renders+css
2025-12-06 01:22:04 +01:00

238 lines
4.9 KiB
CSS

:root {
--hour-height: 60px;
--header-height: 60px;
--time-axis-width: 60px;
--grid-columns: 5;
--color-border: #e0e0e0;
--color-surface: #fff;
--color-text: #333;
--color-text-secondary: #666;
--color-primary: #1976d2;
--color-hour-line: #e0e0e0;
--color-current-time: #f44336;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
background: #f5f5f5;
}
.calendar-wrapper {
height: 100vh;
display: flex;
flex-direction: column;
}
swp-calendar {
display: grid;
grid-template-rows: auto 1fr;
height: 100%;
background: var(--color-surface);
}
/* Nav */
swp-calendar-nav {
display: flex;
gap: 16px;
padding: 12px 16px;
border-bottom: 1px solid var(--color-border);
align-items: center;
}
swp-nav-button {
padding: 8px 16px;
border: 1px solid var(--color-border);
border-radius: 4px;
cursor: pointer;
background: var(--color-surface);
}
swp-nav-button:hover { background: #f0f0f0; }
swp-week-info {
margin-left: auto;
text-align: right;
}
swp-week-number {
font-weight: 600;
display: block;
}
swp-date-range {
font-size: 12px;
color: var(--color-text-secondary);
}
/* Container */
swp-calendar-container {
display: grid;
grid-template-columns: var(--time-axis-width) 1fr;
grid-template-rows: auto 1fr;
overflow: hidden;
}
swp-header-spacer {
grid-column: 1;
grid-row: 1;
background: var(--color-surface);
border-right: 1px solid var(--color-border);
border-bottom: 1px solid var(--color-border);
}
/* Time axis */
swp-time-axis {
grid-column: 1;
grid-row: 2;
border-right: 1px solid var(--color-border);
background: var(--color-surface);
overflow: hidden;
}
swp-time-axis-content {
display: flex;
flex-direction: column;
}
swp-hour-marker {
height: var(--hour-height);
padding: 4px 8px;
font-size: 11px;
color: var(--color-text-secondary);
text-align: right;
}
/* Grid container */
swp-grid-container {
grid-column: 2;
grid-row: 1 / 3;
display: grid;
grid-template-rows: auto 1fr;
overflow: hidden;
}
/* Header */
swp-calendar-header {
display: grid;
grid-template-columns: repeat(var(--grid-columns), 1fr);
grid-auto-rows: auto;
border-bottom: 1px solid var(--color-border);
background: var(--color-surface);
}
/* Single level: date only */
swp-calendar-header[data-levels="date"] > swp-day-header { grid-row: 1; }
/* Two levels: resource + date */
swp-calendar-header[data-levels="resource date"] > swp-resource-header { grid-row: 1; }
swp-calendar-header[data-levels="resource date"] > swp-day-header { grid-row: 2; }
/* Three levels: team + resource + date */
swp-calendar-header[data-levels="team resource date"] > swp-team-header { grid-row: 1; }
swp-calendar-header[data-levels="team resource date"] > swp-resource-header { grid-row: 2; }
swp-calendar-header[data-levels="team resource date"] > swp-day-header { grid-row: 3; }
swp-day-header {
padding: 8px;
text-align: center;
border-right: 1px solid var(--color-border);
}
swp-day-header:last-child { border-right: none; }
swp-day-name {
display: block;
font-size: 11px;
color: var(--color-text-secondary);
text-transform: uppercase;
}
swp-day-date {
display: block;
font-size: 24px;
font-weight: 300;
}
swp-team-header {
padding: 10px;
text-align: center;
background: #e3f2fd;
color: #1565c0;
font-weight: 500;
border-right: 1px solid var(--color-border);
border-bottom: 1px solid var(--color-border);
}
swp-resource-header {
padding: 8px;
text-align: center;
background: #fafafa;
font-size: 13px;
border-right: 1px solid var(--color-border);
border-bottom: 1px solid var(--color-border);
}
/* Scrollable content */
swp-scrollable-content {
overflow: auto;
}
swp-time-grid {
position: relative;
min-height: calc(15 * var(--hour-height));
}
swp-grid-lines {
position: absolute;
inset: 0;
background: repeating-linear-gradient(
to bottom,
transparent,
transparent calc(var(--hour-height) - 1px),
var(--color-hour-line) calc(var(--hour-height) - 1px),
var(--color-hour-line) var(--hour-height)
);
}
swp-day-columns {
position: absolute;
inset: 0;
display: grid;
grid-template-columns: repeat(var(--grid-columns), 1fr);
}
swp-day-column {
position: relative;
border-right: 1px solid var(--color-border);
}
swp-day-column:last-child { border-right: none; }
swp-events-layer {
position: absolute;
inset: 0;
}
/* Events */
swp-event {
position: absolute;
background: var(--color-primary);
color: white;
border-radius: 4px;
padding: 4px 6px;
font-size: 12px;
overflow: hidden;
}
swp-event-time {
display: block;
font-size: 10px;
opacity: 0.9;
}
swp-event-title {
display: block;
font-weight: 500;
}