v-event-calendar
Version:
Lightweight, Vue 3 Event Calendar With Event Scheduling, Multiple Views, Drag-&-Drop, Resizing and Customizable Styling
2 lines (1 loc) • 10.6 kB
CSS
:root{--calendar-primary-color: #3b82f6;--calendar-secondary-color: #10b981;--calendar-bg-color: #f9fafb;--calendar-text-color: #374151;--calendar-border-color: #e6e7eb;--calendar-hover-color: #f0f4f8;--calendar-date-label-size: .62em;--calendar-date-font-weight: 500;--calendar-day-header-font-size: .8em;--calendar-current-time-color: #ef4444}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.calendar-view{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--calendar-bg-color);color:var(--calendar-text-color);line-height:1.5;display:flex;flex-direction:column;height:100%;-webkit-user-select:none;user-select:none;flex:1;min-height:600px}.calendar-month-grid{display:flex;flex-direction:column;height:100%;border-radius:8px;overflow:hidden}.calendar-week-grid{height:100%;display:flex;flex-direction:column;overflow:hidden;border-radius:8px;min-height:600px}.calendar-date-grid{height:100%;display:flex;flex-direction:column;overflow:hidden;min-height:600px}.grid-cols-7{display:grid;grid-template-columns:repeat(7,1fr)}.grid-template-time,.grid-template-week{display:grid;grid-template-columns:65px 1fr}.grid-template-week-header,.grid-template-week-body{display:grid;grid-template-columns:65px repeat(7,1fr)}.day-header{display:flex;justify-content:center;gap:7px;align-items:center;padding:10px;text-align:center;cursor:pointer;border-right:1px solid var(--calendar-border-color);background-color:var(--calendar-bg-color)}.day-header:last-child{border-right:0}.day-header:hover{background-color:var(--calendar-hover-color)}.day-header.today{color:var(--calendar-primary-color);font-weight:700}.day-name{font-size:var(--calendar-day-header-font-size);text-transform:uppercase;letter-spacing:.05em}.day-number{font-size:var(--calendar-day-header-font-size);font-weight:700}.month-header{display:grid;grid-template-columns:repeat(7,1fr);border-color:var(--calendar-border-color)}.month-header-cell{padding:8px 12px;text-align:center;font-size:.875em;border-bottom:1px solid var(--calendar-border-color);font-weight:600;color:var(--calendar-text-color);text-transform:uppercase;letter-spacing:.05em;border-right:1px solid var(--calendar-border-color);background-color:var(--calendar-bg-color)}.month-header-cell:last-child{border-right:0}.calendar-day{position:relative;transition:background-color .15s;cursor:pointer;display:flex;flex-direction:column;min-height:14vh;padding:5px;border-bottom:1px solid var(--calendar-border-color);background-color:var(--calendar-bg-color)}.calendar-day:hover{background-color:var(--calendar-hover-color)}.calendar-day.selected{outline:1px solid var(--calendar-primary-color);outline-offset:-1px;z-index:5}.calendar-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.calendar-day-number{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;font-weight:500;transition:background-color .15s;font-size:var(--calendar-date-label-size);font-weight:var(--calendar-date-font-weight)}.calendar-day-number.today{background-color:var(--calendar-primary-color);color:#fff}.add-event-btn{opacity:0;transition:opacity .15s;height:16px;border-radius:50%;width:16px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#6b7280;cursor:pointer}.add-event-btn:hover{background-color:#e5e7eb;color:#374151}.calendar-day:hover .add-event-btn{opacity:1}.time-slot-container{border-right:1px solid var(--calendar-border-color)}.time-slot-label{border-top:1px solid var(--calendar-border-color);font-size:.75em;color:#808690;padding-right:8px;text-align:right;display:flex;align-items:flex-start;justify-content:flex-end;padding-top:12px;background-color:var(--calendar-bg-color)}.grid-template-week .time-slot-label:first-child{border-top:0}.calendar-time-slot{padding:8px;display:flex;align-items:flex-start;justify-content:center;border-bottom:1px solid var(--calendar-border-color);position:relative;cursor:pointer;background-color:var(--calendar-bg-color)}.week-grid-border .calendar-time-slot:last-child{border-bottom:0 }.calendar-time-slot:hover{background-color:var(--calendar-hover-color)}.calendar-time-slot.drag-creating{cursor:ns-resize}.calendar-events-container{position:absolute;left:1px;right:1px;top:0;height:100%}.calendar-events-container.week-view{width:99.4%;left:2px;right:2px}.calendar-event{position:relative;padding:.1em .5em;color:#fff;font-size:.1em;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000001a;-webkit-user-select:none;user-select:none;z-index:5;border:1px solid rgba(0,0,0,.19);flex-shrink:0;border-radius:6px;min-height:20px;display:flex;align-items:center}.calendar-event.compact{font-size:.5em;padding:2px 6px;min-height:18px}.calendar-event.small-radius{border-radius:4px}.calendar-event-content{display:flex;align-items:center;justify-content:space-between;height:100%;width:100%;min-width:0}.event-title{overflow:hidden;text-overflow:ellipsis;font-size:.5em;font-weight:500;flex:1;margin-right:4px;line-height:1.2;white-space:nowrap}.event-title.multiline{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-align:center}.calendar-event-resizing{box-shadow:0 4px 12px #0003;border:2px solid rgba(59,130,246,.5);z-index:1000 ;position:relative;transition:none ;-webkit-user-select:none;user-select:none}.calendar-event-resizing .resize-handle{pointer-events:auto ;z-index:1001 }.calendar-event-resizing *{pointer-events:none}.calendar-event-resizing .resize-handle{pointer-events:all }.event-title{pointer-events:none}.calendar-event-resizing,.calendar-event-resizing *{user-select:none ;-webkit-user-select:none ;-moz-user-select:none ;-ms-user-select:none }.resize-handle{position:absolute;left:0;right:0;height:5px;opacity:0;transition:opacity .2s ease;z-index:15;display:flex;align-items:center;justify-content:center;background:#0000;border-radius:4px}.resize-handle:hover{background:#00000024}.resize-handle-top{top:-1px;cursor:n-resize}.resize-handle-bottom{bottom:-1px;cursor:s-resize}.calendar-event:not(.calendar-event-resizing):hover .resize-handle{opacity:1}.all-day-section{border-bottom:1px solid var(--calendar-border-color);border-top:1px solid var(--calendar-border-color)}.all-day-label{border-right:1px solid var(--calendar-border-color);padding:8px;font-size:.75em;text-align:right;font-weight:500;color:#9ca3af;background-color:var(--calendar-bg-color)}.all-day-event-item{margin-bottom:1px;position:absolute;z-index:10;pointer-events:all}.all-day-events{padding:4px;gap:.15em;display:flex;flex-direction:column;background-color:var(--calendar-bg-color)}.scrollable-wrapper{overflow:auto;scrollbar-gutter:stable;flex:1}.scrollable-wrapper::-webkit-scrollbar{width:0;height:0}.scrollable-wrapper.scrolling{scrollbar-width:thin}.scrollable-wrapper.scrolling::-webkit-scrollbar{width:1px;height:8px}.scrollable-wrapper.scrolling::-webkit-scrollbar-thumb{background-color:var(--calendar-border-color);border-radius:10px}.scrollable-wrapper.scrolling::-webkit-scrollbar-thumb:hover{background-color:var(--calendar-border-color)}.scrollable-wrapper.scrolling::-webkit-scrollbar-track{background-color:transparent}.current-time-indicator{position:absolute;left:0;right:-1px;height:.3px;z-index:30;pointer-events:none;display:flex;align-items:center}.current-time-indicator__dot{width:5px;height:5px;border-radius:50%;background-color:var(--calendar-current-time-color);position:absolute;left:0;z-index:31}.current-time-indicator__line{width:100%;height:1.3px;background-color:var(--calendar-current-time-color)}.add-event-hover{position:absolute;top:0;left:0;right:0;bottom:0;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center}.add-event-hover:hover{opacity:1}.add-event-icon{background-color:var(--calendar-primary-color);border-radius:4px;padding:4px;color:#fff}.calendar-event-placeholder{background-color:var(--calendar-primary-color);border:2px dashed rgba(255,255,255,.5);border-radius:6px;padding:4px 8px;color:#fff;font-size:.875em;cursor:pointer;overflow:hidden;transition:none;opacity:.8;pointer-events:none;z-index:50;position:absolute;width:100%;min-height:28px;top:1px;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}.week-grid-border{border-right:1px solid var(--calendar-border-color);border-top:1px solid var(--calendar-border-color)}.grid-template-week .week-grid-border{border-top:0}.week-grid-border:last-child{border-right:0}.month-grid-divider{border-right:1px solid var(--calendar-border-color)}.month-grid-divider:last-child{border-right:0}.week-divider{border-top:1px solid var(--calendar-border-color)}.opacity-50{opacity:.5}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.text-right{text-align:right}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.cursor-pointer{cursor:pointer}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.month-weeks-container{display:grid;grid-template-columns:1fr;height:100%;flex:1;overflow:auto}.month-week{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--calendar-border-color)}.month-week:first-child{border-top:0}.border-right{border-right:1px solid var(--calendar-border-color)}.calendar-day-cell{border-bottom:0}.all-day-events-overlay{padding:0;pointer-events:none;background-color:var(--calendar-bg-color);top:0;width:100%;height:100%;left:0;position:absolute}.multi-day-event-container{position:absolute;z-index:10;font-size:.75em;pointer-events:auto}.multi-day-event{padding-top:2px;padding-bottom:2px}.events-list{flex:1;display:flex;flex-direction:column;gap:.2em;font-size:.8em}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}@media (max-width: 768px){.calendar-view{min-height:500px}.calendar-week-grid{font-size:.875em}.calendar-time-slot{min-height:40px}.calendar-date-grid{font-size:.875em}}@media (max-width: 640px){.calendar-view{padding:12px}}@media print{.calendar-view{background:#fff ;min-height:auto}.calendar-month-grid{background:#fff }}