2024-04-18 14:13:33 +00:00
|
|
|
import BaseStyle from 'primevue/base/style';
|
|
|
|
|
2024-05-01 08:26:48 +00:00
|
|
|
const theme = ({ dt }) => `
|
|
|
|
.p-datepicker {
|
|
|
|
display: inline-flex;
|
|
|
|
max-width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-input {
|
|
|
|
flex: 1 1 auto;
|
|
|
|
width: 1%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker:has(.p-datepicker-dropdown) .p-datepicker-input {
|
|
|
|
border-top-right-radius: 0;
|
|
|
|
border-bottom-right-radius: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-dropdown {
|
|
|
|
cursor: pointer;
|
|
|
|
display: inline-flex;
|
|
|
|
cursor: pointer;
|
|
|
|
user-select: none;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
|
|
|
overflow: hidden;
|
|
|
|
position: relative;
|
|
|
|
width: ${dt('datepicker.dropdown.width')};
|
|
|
|
border-top-right-radius: ${dt('rounded.base')};
|
|
|
|
border-bottom-right-radius: ${dt('rounded.base')};
|
|
|
|
background: ${dt('datepicker.dropdown.background')};
|
|
|
|
border: 1px solid ${dt('datepicker.dropdown.border.color')};
|
|
|
|
border-left: 0 none;
|
|
|
|
background: ${dt('datepicker.dropdown.background')};
|
|
|
|
transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, outline-color ${dt('transition.duration')};
|
|
|
|
outline-color: transparent;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-dropdown:not(:disabled):hover {
|
|
|
|
background: ${dt('datepicker.dropdown.hover.background')};
|
|
|
|
border-color: ${dt('datepicker.dropdown.hover.border.color')};
|
|
|
|
background: ${dt('datepicker.dropdown.hover.background')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-dropdown:not(:disabled):active {
|
|
|
|
background: ${dt('datepicker.dropdown.active.background')};
|
|
|
|
border-color: ${dt('datepicker.dropdown.active.border.color')};
|
|
|
|
background: ${dt('datepicker.dropdown.active.background')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-dropdown:focus-visible {
|
|
|
|
outline: ${dt('focus.ring.width')} ${dt('focus.ring.style')} ${dt('focus.ring.color')};
|
|
|
|
outline-offset: ${dt('focus.ring.offset')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker:has(.p-datepicker-input-icon) {
|
|
|
|
position: relative;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker:has(.p-datepicker-input-icon) .p-datepicker-input {
|
|
|
|
padding-right: 2.5rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-input-icon {
|
|
|
|
cursor: pointer;
|
|
|
|
position: absolute;
|
|
|
|
top: 50%;
|
|
|
|
right: .75rem;
|
|
|
|
margin-top: -.5rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-fluid .p-datepicker {
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-fluid .p-datepicker-input {
|
|
|
|
width: 1%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker .p-datepicker-panel {
|
|
|
|
min-width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-panel {
|
|
|
|
width: auto;
|
|
|
|
padding: 0.75rem;
|
|
|
|
background: ${dt('datepicker.background')};
|
|
|
|
color: ${dt('datepicker.color')};
|
|
|
|
border: 1px solid ${dt('datepicker.border.color')};
|
|
|
|
border-radius: ${dt('rounded.base')};
|
|
|
|
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-panel-inline {
|
|
|
|
display: inline-block;
|
|
|
|
overflow-x: auto;
|
|
|
|
box-shadow: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-header {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: space-between;
|
|
|
|
padding: 0 0 0.5rem 0;
|
|
|
|
font-weight: 500;
|
|
|
|
background: ${dt('datepicker.header.background')};
|
|
|
|
color: ${dt('datepicker.header.color')};
|
|
|
|
border-bottom: 1px solid ${dt('datepicker.header.border.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-title {
|
|
|
|
margin: 0 auto;
|
|
|
|
line-height: 1.75rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-view-year,
|
|
|
|
.p-datepicker-view-month {
|
|
|
|
font-weight: 500;
|
|
|
|
padding: 0.25rem;
|
|
|
|
transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, box-shadow ${dt('transition.duration')}, outline-color ${dt('transition.duration')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-view-month {
|
|
|
|
margin-right: 0.5rem;
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.view.month.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-view-year {
|
|
|
|
margin-right: 0.5rem;
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.view.year.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-view-month:enabled:hover {
|
2024-05-05 17:35:03 +00:00
|
|
|
background: ${dt('datepicker.view.month.hover.background')};
|
|
|
|
color: ${dt('datepicker.view.month.hover.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-view-year:enabled:hover {
|
2024-05-05 17:35:03 +00:00
|
|
|
background: ${dt('datepicker.view.year.hover.background')};
|
|
|
|
color: ${dt('datepicker.view.year.hover.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-datepicker-container {
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-datepicker-container .p-datepicker-datepicker {
|
|
|
|
flex: 1 1 auto;
|
|
|
|
border-left: 1px solid ${dt('datepicker.group.border.color')};
|
|
|
|
padding-right: 0.75rem;
|
|
|
|
padding-left: 0.75rem;
|
|
|
|
padding-top: 0;
|
|
|
|
padding-bottom: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-datepicker-container .p-datepicker-datepicker:first-child {
|
|
|
|
padding-left: 0;
|
|
|
|
border-left: 0 none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-datepicker-container .p-datepicker-datepicker:last-child {
|
|
|
|
padding-right: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-day-view {
|
|
|
|
width: 100%;
|
|
|
|
border-collapse: collapse;
|
|
|
|
font-size: 1rem;
|
|
|
|
margin: 0.5rem 0 0 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-weekday-cell {
|
|
|
|
padding: 0.25rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-weekday {
|
|
|
|
font-weight: 500;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-day-cell {
|
|
|
|
padding: 0.25rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-day {
|
|
|
|
display: flex;
|
|
|
|
justify-content: center;
|
|
|
|
align-items: center;
|
|
|
|
cursor: pointer;
|
|
|
|
margin: 0 auto;
|
|
|
|
overflow: hidden;
|
|
|
|
position: relative;
|
|
|
|
width: 2rem;
|
|
|
|
height: 2rem;
|
|
|
|
border-radius: 50%;
|
|
|
|
transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, box-shadow ${dt('transition.duration')}, outline-color ${dt('transition.duration')};
|
|
|
|
border: 1px solid transparent;
|
|
|
|
outline-color: transparent;
|
|
|
|
color: ${dt('datepicker.date.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-day:not(.p-datepicker-day-selected):not(.p-disabled):hover {
|
|
|
|
background: ${dt('datepicker.date.hover.background')};
|
|
|
|
color: ${dt('datepicker.date.hover.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-day:focus-visible {
|
|
|
|
outline: 1px solid ${dt('focus.ring.color')};
|
|
|
|
outline-offset: ${dt('focus.ring.offset')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-day-selected {
|
|
|
|
background: ${dt('datepicker.date.selected.background')};
|
|
|
|
color: ${dt('datepicker.date.selected.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-today > .p-datepicker-day {
|
|
|
|
background: ${dt('datepicker.today.background')};
|
|
|
|
color: ${dt('datepicker.today.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-today > .p-datepicker-day-selected {
|
|
|
|
background: ${dt('datepicker.date.selected.background')};
|
|
|
|
color: ${dt('datepicker.date.selected.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-month-view {
|
|
|
|
margin: 0.5rem 0 0 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-month {
|
|
|
|
width: 33.3%;
|
|
|
|
display: inline-flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
|
|
|
cursor: pointer;
|
|
|
|
overflow: hidden;
|
|
|
|
position: relative;
|
|
|
|
padding: 0.25rem;
|
|
|
|
transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, box-shadow ${dt('transition.duration')}, outline-color ${dt('transition.duration')};
|
|
|
|
border-radius: ${dt('rounded.base')};
|
|
|
|
outline-color: transparent;
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.date.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-month:not(.p-disabled):not(.p-datepicker-month-selected):hover {
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.date.hover.color')};
|
|
|
|
background: ${dt('datepicker.date.hover.background')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-month-selected {
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.date.selected.color')};
|
|
|
|
background: ${dt('datepicker.date.selected.background')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-month:not(.p-disabled):focus-visible {
|
|
|
|
outline: ${dt('focus.ring.width')} solid ${dt('focus.ring.color')};
|
|
|
|
outline-offset: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-year-view {
|
|
|
|
margin: 0.5rem 0 0 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-year {
|
|
|
|
width: 50%;
|
|
|
|
display: inline-flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
|
|
|
cursor: pointer;
|
|
|
|
overflow: hidden;
|
|
|
|
position: relative;
|
|
|
|
padding: 0.25rem;
|
|
|
|
transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, box-shadow ${dt('transition.duration')}, outline-color ${dt('transition.duration')};
|
|
|
|
border-radius: ${dt('rounded.base')};
|
|
|
|
outline-color: transparent;
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.date.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-year:not(.p-disabled):not(.p-datepicker-year-selected):hover {
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.date.hover.color')};
|
|
|
|
background: ${dt('datepicker.date.hover.background')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-year-selected {
|
2024-05-05 17:35:03 +00:00
|
|
|
color: ${dt('datepicker.date.selected.color')};
|
|
|
|
background: ${dt('datepicker.date.selected.background')};
|
2024-05-01 08:26:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-year:not(.p-disabled):focus-visible {
|
|
|
|
outline: ${dt('focus.ring.width')} solid ${dt('focus.ring.color')};
|
|
|
|
outline-offset: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-buttonbar {
|
|
|
|
display: flex;
|
|
|
|
justify-content: space-between;
|
|
|
|
align-items: center;
|
|
|
|
padding: 0.5rem 0 0 0;
|
|
|
|
border-top: 1px solid ${dt('datepicker.buttonbar.border.color')};
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-buttonbar .p-button {
|
|
|
|
width: auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-time-picker {
|
|
|
|
display: flex;
|
|
|
|
justify-content: center;
|
|
|
|
align-items: center;
|
2024-05-05 17:35:03 +00:00
|
|
|
border-top: 1px solid ${dt('datepicker.time.picker.border.color')};
|
2024-05-01 08:26:48 +00:00
|
|
|
padding: 0;
|
|
|
|
}
|
|
|
|
|
2024-05-05 17:35:03 +00:00
|
|
|
.p-datepicker-datepicker-group + .p-datepicker-time-picker {
|
2024-05-01 08:26:48 +00:00
|
|
|
margin-top: 0.5rem;
|
|
|
|
padding-top: 0.5rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-time-picker > div {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
flex-direction: column;
|
|
|
|
padding: 0 0.5rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-time-picker button:last-child {
|
|
|
|
margin-top: 0.2em;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-time-picker span {
|
|
|
|
font-size: 1rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.p-datepicker-timeonly .p-datepicker-time-picker {
|
|
|
|
border-top: 0 none;
|
|
|
|
}
|
|
|
|
`;
|
|
|
|
|
2024-04-18 14:13:33 +00:00
|
|
|
const inlineStyles = {
|
|
|
|
root: ({ props }) => ({ position: props.appendTo === 'self' ? 'relative' : undefined })
|
|
|
|
};
|
|
|
|
|
|
|
|
const classes = {
|
|
|
|
root: ({ props, state }) => [
|
|
|
|
'p-datepicker p-component p-inputwrapper',
|
|
|
|
{
|
|
|
|
'p-invalid': props.invalid,
|
|
|
|
'p-inputwrapper-filled': props.modelValue,
|
|
|
|
'p-inputwrapper-focus': state.focused,
|
|
|
|
'p-focus': state.focused || state.overlayVisible
|
|
|
|
}
|
|
|
|
],
|
2024-05-06 15:23:01 +00:00
|
|
|
pcInput: 'p-datepicker-input',
|
2024-05-03 20:26:53 +00:00
|
|
|
dropdown: 'p-datepicker-dropdown',
|
2024-04-18 14:13:33 +00:00
|
|
|
inputIconContainer: 'p-datepicker-input-icon-container',
|
|
|
|
inputIcon: 'p-datepicker-input-icon',
|
|
|
|
panel: ({ instance, props }) => [
|
|
|
|
'p-datepicker-panel p-component',
|
|
|
|
{
|
|
|
|
'p-datepicker-panel-inline': props.inline,
|
|
|
|
'p-disabled': props.disabled,
|
|
|
|
'p-datepicker-timeonly': props.timeOnly,
|
|
|
|
'p-ripple-disabled': instance.$primevue.config.ripple === false
|
|
|
|
}
|
|
|
|
],
|
2024-05-03 20:26:53 +00:00
|
|
|
calendarContainer: 'p-datepicker-calendar-container',
|
2024-04-18 14:13:33 +00:00
|
|
|
calendar: 'p-datepicker-calendar',
|
|
|
|
header: 'p-datepicker-header',
|
2024-05-06 15:23:01 +00:00
|
|
|
pcPreviousButton: 'p-datepicker-prev-button',
|
2024-04-18 14:13:33 +00:00
|
|
|
title: 'p-datepicker-title',
|
2024-05-03 20:26:53 +00:00
|
|
|
viewMonth: 'p-datepicker-view-month p-link',
|
|
|
|
viewYear: 'p-datepicker-view-year p-link',
|
|
|
|
decade: 'p-datepicker-decade',
|
2024-05-06 15:23:01 +00:00
|
|
|
pcNextButton: 'p-datepicker-next-button',
|
2024-05-03 20:26:53 +00:00
|
|
|
dayView: 'p-datepicker-day-view',
|
2024-04-18 14:13:33 +00:00
|
|
|
weekHeader: 'p-datepicker-weekheader p-disabled',
|
|
|
|
weekNumber: 'p-datepicker-weeknumber',
|
2024-05-03 20:26:53 +00:00
|
|
|
weekLabelContainer: 'p-disabled', //TODO:
|
|
|
|
weekDayCell: 'p-datepicker-weekday-cell',
|
|
|
|
weekDay: 'p-date-picker-weekday',
|
|
|
|
dayCell: ({ date }) => ['p-datepicker-day-cell', { 'p-datepicker-other-month': date.otherMonth, 'p-datepicker-today': date.today }],
|
|
|
|
day: ({ instance, props, date }) => ['p-datepicker-day', { 'p-datepicker-day-selected': instance.isSelected(date) && date.selectable, 'p-disabled': props.disabled || !date.selectable }],
|
|
|
|
monthView: 'p-datepicker-month-view',
|
2024-04-18 14:13:33 +00:00
|
|
|
month: ({ instance, props, month, index }) => ['p-datepicker-month', { 'p-datepicker-month-selected': instance.isMonthSelected(index), 'p-disabled': props.disabled || !month.selectable }],
|
2024-05-03 20:26:53 +00:00
|
|
|
yearView: 'p-datepicker-year-view',
|
2024-04-18 14:13:33 +00:00
|
|
|
year: ({ instance, props, year }) => ['p-datepicker-year', { 'p-datepicker-year-selected': instance.isYearSelected(year.value), 'p-disabled': props.disabled || !year.selectable }],
|
|
|
|
timePicker: 'p-datepicker-time-picker',
|
|
|
|
hourPicker: 'p-datepicker-hour-picker',
|
2024-05-06 15:23:01 +00:00
|
|
|
pcIncrementButton: 'p-datepicker-increment-button',
|
|
|
|
pcDecrementButton: 'p-datepicker-decrement-button',
|
2024-05-03 20:26:53 +00:00
|
|
|
separator: 'p-datepicker-separator',
|
2024-05-06 13:10:25 +00:00
|
|
|
minutePicker: 'p-datepicker-minute-picker',
|
|
|
|
secondPicker: 'p-datepicker-second-picker',
|
|
|
|
ampmPicker: 'p-datepicker-ampm-picker',
|
2024-04-18 14:13:33 +00:00
|
|
|
buttonbar: 'p-datepicker-buttonbar',
|
2024-05-06 15:23:01 +00:00
|
|
|
pcTodayButton: 'p-datepicker-today-button',
|
|
|
|
pcClearButton: 'p-datepicker-clear-button'
|
2024-04-18 14:13:33 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export default BaseStyle.extend({
|
|
|
|
name: 'datepicker',
|
2024-05-01 08:26:48 +00:00
|
|
|
theme,
|
2024-04-18 14:13:33 +00:00
|
|
|
classes,
|
|
|
|
inlineStyles
|
|
|
|
});
|