Merged in [16589] from rjsparks@nostrum.com:
Show a calendar of upcoming meetings. Fixes #2719. - Legacy-Id: 16602 Note: SVN reference [16589] has been migrated to Git commit d3b70a46b882979fabb82972921a6ad177c06b08
This commit is contained in:
parent
2418459afc
commit
4e131f1f2e
900
ietf/externals/static/fullcalendar/core/main.css
vendored
Normal file
900
ietf/externals/static/fullcalendar/core/main.css
vendored
Normal file
|
@ -0,0 +1,900 @@
|
|||
/*!
|
||||
FullCalendar Core Package v4.2.0
|
||||
Docs & License: https://fullcalendar.io/
|
||||
(c) 2019 Adam Shaw
|
||||
*/
|
||||
.fc {
|
||||
direction: ltr;
|
||||
text-align: left; }
|
||||
|
||||
.fc-rtl {
|
||||
text-align: right; }
|
||||
|
||||
body .fc {
|
||||
/* extra precedence to overcome jqui */
|
||||
font-size: 1em; }
|
||||
|
||||
/* Colors
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-highlight {
|
||||
/* when user is selecting cells */
|
||||
background: #bce8f1;
|
||||
opacity: .3; }
|
||||
|
||||
.fc-bgevent {
|
||||
/* default look for background events */
|
||||
background: #8fdf82;
|
||||
opacity: .3; }
|
||||
|
||||
.fc-nonbusiness {
|
||||
/* default look for non-business-hours areas */
|
||||
/* will inherit .fc-bgevent's styles */
|
||||
background: #d7d7d7; }
|
||||
|
||||
/* Popover
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-popover {
|
||||
position: absolute;
|
||||
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15); }
|
||||
|
||||
.fc-popover .fc-header {
|
||||
/* TODO: be more consistent with fc-head/fc-body */
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
padding: 2px 4px; }
|
||||
|
||||
.fc-rtl .fc-popover .fc-header {
|
||||
flex-direction: row-reverse; }
|
||||
|
||||
.fc-popover .fc-header .fc-title {
|
||||
margin: 0 2px; }
|
||||
|
||||
.fc-popover .fc-header .fc-close {
|
||||
cursor: pointer;
|
||||
opacity: 0.65;
|
||||
font-size: 1.1em; }
|
||||
|
||||
/* Misc Reusable Components
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-divider {
|
||||
border-style: solid;
|
||||
border-width: 1px; }
|
||||
|
||||
hr.fc-divider {
|
||||
height: 0;
|
||||
margin: 0;
|
||||
padding: 0 0 2px;
|
||||
/* height is unreliable across browsers, so use padding */
|
||||
border-width: 1px 0; }
|
||||
|
||||
.fc-bg,
|
||||
.fc-bgevent-skeleton,
|
||||
.fc-highlight-skeleton,
|
||||
.fc-mirror-skeleton {
|
||||
/* these element should always cling to top-left/right corners */
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0; }
|
||||
|
||||
.fc-bg {
|
||||
bottom: 0;
|
||||
/* strech bg to bottom edge */ }
|
||||
|
||||
.fc-bg table {
|
||||
height: 100%;
|
||||
/* strech bg to bottom edge */ }
|
||||
|
||||
/* Tables
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc table {
|
||||
width: 100%;
|
||||
box-sizing: border-box;
|
||||
/* fix scrollbar issue in firefox */
|
||||
table-layout: fixed;
|
||||
border-collapse: collapse;
|
||||
border-spacing: 0;
|
||||
font-size: 1em;
|
||||
/* normalize cross-browser */ }
|
||||
|
||||
.fc th {
|
||||
text-align: center; }
|
||||
|
||||
.fc th,
|
||||
.fc td {
|
||||
border-style: solid;
|
||||
border-width: 1px;
|
||||
padding: 0;
|
||||
vertical-align: top; }
|
||||
|
||||
.fc td.fc-today {
|
||||
border-style: double;
|
||||
/* overcome neighboring borders */ }
|
||||
|
||||
/* Internal Nav Links
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
a[data-goto] {
|
||||
cursor: pointer; }
|
||||
|
||||
a[data-goto]:hover {
|
||||
text-decoration: underline; }
|
||||
|
||||
/* Fake Table Rows
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc .fc-row {
|
||||
/* extra precedence to overcome themes forcing a 1px border */
|
||||
/* no visible border by default. but make available if need be (scrollbar width compensation) */
|
||||
border-style: solid;
|
||||
border-width: 0; }
|
||||
|
||||
.fc-row table {
|
||||
/* don't put left/right border on anything within a fake row.
|
||||
the outer tbody will worry about this */
|
||||
border-left: 0 hidden transparent;
|
||||
border-right: 0 hidden transparent;
|
||||
/* no bottom borders on rows */
|
||||
border-bottom: 0 hidden transparent; }
|
||||
|
||||
.fc-row:first-child table {
|
||||
border-top: 0 hidden transparent;
|
||||
/* no top border on first row */ }
|
||||
|
||||
/* Day Row (used within the header and the DayGrid)
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-row {
|
||||
position: relative; }
|
||||
|
||||
.fc-row .fc-bg {
|
||||
z-index: 1; }
|
||||
|
||||
/* highlighting cells & background event skeleton */
|
||||
.fc-row .fc-bgevent-skeleton,
|
||||
.fc-row .fc-highlight-skeleton {
|
||||
bottom: 0;
|
||||
/* stretch skeleton to bottom of row */ }
|
||||
|
||||
.fc-row .fc-bgevent-skeleton table,
|
||||
.fc-row .fc-highlight-skeleton table {
|
||||
height: 100%;
|
||||
/* stretch skeleton to bottom of row */ }
|
||||
|
||||
.fc-row .fc-highlight-skeleton td,
|
||||
.fc-row .fc-bgevent-skeleton td {
|
||||
border-color: transparent; }
|
||||
|
||||
.fc-row .fc-bgevent-skeleton {
|
||||
z-index: 2; }
|
||||
|
||||
.fc-row .fc-highlight-skeleton {
|
||||
z-index: 3; }
|
||||
|
||||
/*
|
||||
row content (which contains day/week numbers and events) as well as "mirror" (which contains
|
||||
temporary rendered events).
|
||||
*/
|
||||
.fc-row .fc-content-skeleton {
|
||||
position: relative;
|
||||
z-index: 4;
|
||||
padding-bottom: 2px;
|
||||
/* matches the space above the events */ }
|
||||
|
||||
.fc-row .fc-mirror-skeleton {
|
||||
z-index: 5; }
|
||||
|
||||
.fc .fc-row .fc-content-skeleton table,
|
||||
.fc .fc-row .fc-content-skeleton td,
|
||||
.fc .fc-row .fc-mirror-skeleton td {
|
||||
/* see-through to the background below */
|
||||
/* extra precedence to prevent theme-provided backgrounds */
|
||||
background: none;
|
||||
/* in case <td>s are globally styled */
|
||||
border-color: transparent; }
|
||||
|
||||
.fc-row .fc-content-skeleton td,
|
||||
.fc-row .fc-mirror-skeleton td {
|
||||
/* don't put a border between events and/or the day number */
|
||||
border-bottom: 0; }
|
||||
|
||||
.fc-row .fc-content-skeleton tbody td,
|
||||
.fc-row .fc-mirror-skeleton tbody td {
|
||||
/* don't put a border between event cells */
|
||||
border-top: 0; }
|
||||
|
||||
/* Scrolling Container
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-scroller {
|
||||
-webkit-overflow-scrolling: touch; }
|
||||
|
||||
/* TODO: move to timegrid/daygrid */
|
||||
.fc-scroller > .fc-day-grid,
|
||||
.fc-scroller > .fc-time-grid {
|
||||
position: relative;
|
||||
/* re-scope all positions */
|
||||
width: 100%;
|
||||
/* hack to force re-sizing this inner element when scrollbars appear/disappear */ }
|
||||
|
||||
/* Global Event Styles
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-event {
|
||||
position: relative;
|
||||
/* for resize handle and other inner positioning */
|
||||
display: block;
|
||||
/* make the <a> tag block */
|
||||
font-size: .85em;
|
||||
line-height: 1.4;
|
||||
border-radius: 3px;
|
||||
border: 1px solid #3788d8; }
|
||||
|
||||
.fc-event,
|
||||
.fc-event-dot {
|
||||
background-color: #3788d8;
|
||||
/* default BACKGROUND color */ }
|
||||
|
||||
.fc-event,
|
||||
.fc-event:hover {
|
||||
color: #fff;
|
||||
/* default TEXT color */
|
||||
text-decoration: none;
|
||||
/* if <a> has an href */ }
|
||||
|
||||
.fc-event[href],
|
||||
.fc-event.fc-draggable {
|
||||
cursor: pointer;
|
||||
/* give events with links and draggable events a hand mouse pointer */ }
|
||||
|
||||
.fc-not-allowed,
|
||||
.fc-not-allowed .fc-event {
|
||||
/* to override an event's custom cursor */
|
||||
cursor: not-allowed; }
|
||||
|
||||
.fc-event .fc-content {
|
||||
position: relative;
|
||||
z-index: 2; }
|
||||
|
||||
/* resizer (cursor AND touch devices) */
|
||||
.fc-event .fc-resizer {
|
||||
position: absolute;
|
||||
z-index: 4; }
|
||||
|
||||
/* resizer (touch devices) */
|
||||
.fc-event .fc-resizer {
|
||||
display: none; }
|
||||
|
||||
.fc-event.fc-allow-mouse-resize .fc-resizer,
|
||||
.fc-event.fc-selected .fc-resizer {
|
||||
/* only show when hovering or selected (with touch) */
|
||||
display: block; }
|
||||
|
||||
/* hit area */
|
||||
.fc-event.fc-selected .fc-resizer:before {
|
||||
/* 40x40 touch area */
|
||||
content: "";
|
||||
position: absolute;
|
||||
z-index: 9999;
|
||||
/* user of this util can scope within a lower z-index */
|
||||
top: 50%;
|
||||
left: 50%;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
margin-left: -20px;
|
||||
margin-top: -20px; }
|
||||
|
||||
/* Event Selection (only for touch devices)
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-event.fc-selected {
|
||||
z-index: 9999 !important;
|
||||
/* overcomes inline z-index */
|
||||
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); }
|
||||
|
||||
.fc-event.fc-selected:after {
|
||||
content: "";
|
||||
position: absolute;
|
||||
z-index: 1;
|
||||
/* same z-index as fc-bg, behind text */
|
||||
/* overcome the borders */
|
||||
top: -1px;
|
||||
right: -1px;
|
||||
bottom: -1px;
|
||||
left: -1px;
|
||||
/* darkening effect */
|
||||
background: #000;
|
||||
opacity: .25; }
|
||||
|
||||
/* Event Dragging
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-event.fc-dragging.fc-selected {
|
||||
box-shadow: 0 2px 7px rgba(0, 0, 0, 0.3); }
|
||||
|
||||
.fc-event.fc-dragging:not(.fc-selected) {
|
||||
opacity: .75; }
|
||||
|
||||
/* Horizontal Events
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
/* bigger touch area when selected */
|
||||
.fc-h-event.fc-selected:before {
|
||||
content: "";
|
||||
position: absolute;
|
||||
z-index: 3;
|
||||
/* below resizers */
|
||||
top: -10px;
|
||||
bottom: -10px;
|
||||
left: 0;
|
||||
right: 0; }
|
||||
|
||||
/* events that are continuing to/from another week. kill rounded corners and butt up against edge */
|
||||
.fc-ltr .fc-h-event.fc-not-start,
|
||||
.fc-rtl .fc-h-event.fc-not-end {
|
||||
margin-left: 0;
|
||||
border-left-width: 0;
|
||||
padding-left: 1px;
|
||||
/* replace the border with padding */
|
||||
border-top-left-radius: 0;
|
||||
border-bottom-left-radius: 0; }
|
||||
|
||||
.fc-ltr .fc-h-event.fc-not-end,
|
||||
.fc-rtl .fc-h-event.fc-not-start {
|
||||
margin-right: 0;
|
||||
border-right-width: 0;
|
||||
padding-right: 1px;
|
||||
/* replace the border with padding */
|
||||
border-top-right-radius: 0;
|
||||
border-bottom-right-radius: 0; }
|
||||
|
||||
/* resizer (cursor AND touch devices) */
|
||||
/* left resizer */
|
||||
.fc-ltr .fc-h-event .fc-start-resizer,
|
||||
.fc-rtl .fc-h-event .fc-end-resizer {
|
||||
cursor: w-resize;
|
||||
left: -1px;
|
||||
/* overcome border */ }
|
||||
|
||||
/* right resizer */
|
||||
.fc-ltr .fc-h-event .fc-end-resizer,
|
||||
.fc-rtl .fc-h-event .fc-start-resizer {
|
||||
cursor: e-resize;
|
||||
right: -1px;
|
||||
/* overcome border */ }
|
||||
|
||||
/* resizer (mouse devices) */
|
||||
.fc-h-event.fc-allow-mouse-resize .fc-resizer {
|
||||
width: 7px;
|
||||
top: -1px;
|
||||
/* overcome top border */
|
||||
bottom: -1px;
|
||||
/* overcome bottom border */ }
|
||||
|
||||
/* resizer (touch devices) */
|
||||
.fc-h-event.fc-selected .fc-resizer {
|
||||
/* 8x8 little dot */
|
||||
border-radius: 4px;
|
||||
border-width: 1px;
|
||||
width: 6px;
|
||||
height: 6px;
|
||||
border-style: solid;
|
||||
border-color: inherit;
|
||||
background: #fff;
|
||||
/* vertically center */
|
||||
top: 50%;
|
||||
margin-top: -4px; }
|
||||
|
||||
/* left resizer */
|
||||
.fc-ltr .fc-h-event.fc-selected .fc-start-resizer,
|
||||
.fc-rtl .fc-h-event.fc-selected .fc-end-resizer {
|
||||
margin-left: -4px;
|
||||
/* centers the 8x8 dot on the left edge */ }
|
||||
|
||||
/* right resizer */
|
||||
.fc-ltr .fc-h-event.fc-selected .fc-end-resizer,
|
||||
.fc-rtl .fc-h-event.fc-selected .fc-start-resizer {
|
||||
margin-right: -4px;
|
||||
/* centers the 8x8 dot on the right edge */ }
|
||||
|
||||
/* DayGrid events
|
||||
----------------------------------------------------------------------------------------------------
|
||||
We use the full "fc-day-grid-event" class instead of using descendants because the event won't
|
||||
be a descendant of the grid when it is being dragged.
|
||||
*/
|
||||
.fc-day-grid-event {
|
||||
margin: 1px 2px 0;
|
||||
/* spacing between events and edges */
|
||||
padding: 0 1px; }
|
||||
|
||||
tr:first-child > td > .fc-day-grid-event {
|
||||
margin-top: 2px;
|
||||
/* a little bit more space before the first event */ }
|
||||
|
||||
.fc-mirror-skeleton tr:first-child > td > .fc-day-grid-event {
|
||||
margin-top: 0;
|
||||
/* except for mirror skeleton */ }
|
||||
|
||||
.fc-day-grid-event .fc-content {
|
||||
/* force events to be one-line tall */
|
||||
white-space: nowrap;
|
||||
overflow: hidden; }
|
||||
|
||||
.fc-day-grid-event .fc-time {
|
||||
font-weight: bold; }
|
||||
|
||||
/* resizer (cursor devices) */
|
||||
/* left resizer */
|
||||
.fc-ltr .fc-day-grid-event.fc-allow-mouse-resize .fc-start-resizer,
|
||||
.fc-rtl .fc-day-grid-event.fc-allow-mouse-resize .fc-end-resizer {
|
||||
margin-left: -2px;
|
||||
/* to the day cell's edge */ }
|
||||
|
||||
/* right resizer */
|
||||
.fc-ltr .fc-day-grid-event.fc-allow-mouse-resize .fc-end-resizer,
|
||||
.fc-rtl .fc-day-grid-event.fc-allow-mouse-resize .fc-start-resizer {
|
||||
margin-right: -2px;
|
||||
/* to the day cell's edge */ }
|
||||
|
||||
/* Event Limiting
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
/* "more" link that represents hidden events */
|
||||
a.fc-more {
|
||||
margin: 1px 3px;
|
||||
font-size: .85em;
|
||||
cursor: pointer;
|
||||
text-decoration: none; }
|
||||
|
||||
a.fc-more:hover {
|
||||
text-decoration: underline; }
|
||||
|
||||
.fc-limited {
|
||||
/* rows and cells that are hidden because of a "more" link */
|
||||
display: none; }
|
||||
|
||||
/* popover that appears when "more" link is clicked */
|
||||
.fc-day-grid .fc-row {
|
||||
z-index: 1;
|
||||
/* make the "more" popover one higher than this */ }
|
||||
|
||||
.fc-more-popover {
|
||||
z-index: 2;
|
||||
width: 220px; }
|
||||
|
||||
.fc-more-popover .fc-event-container {
|
||||
padding: 10px; }
|
||||
|
||||
/* Now Indicator
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-now-indicator {
|
||||
position: absolute;
|
||||
border: 0 solid red; }
|
||||
|
||||
/* Utilities
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-unselectable {
|
||||
-webkit-user-select: none;
|
||||
-khtml-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
-webkit-touch-callout: none;
|
||||
-webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
|
||||
|
||||
/*
|
||||
TODO: more distinction between this file and common.css
|
||||
*/
|
||||
/* Colors
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-unthemed th,
|
||||
.fc-unthemed td,
|
||||
.fc-unthemed thead,
|
||||
.fc-unthemed tbody,
|
||||
.fc-unthemed .fc-divider,
|
||||
.fc-unthemed .fc-row,
|
||||
.fc-unthemed .fc-content,
|
||||
.fc-unthemed .fc-popover,
|
||||
.fc-unthemed .fc-list-view,
|
||||
.fc-unthemed .fc-list-heading td {
|
||||
border-color: #ddd; }
|
||||
|
||||
.fc-unthemed .fc-popover {
|
||||
background-color: #fff; }
|
||||
|
||||
.fc-unthemed .fc-divider,
|
||||
.fc-unthemed .fc-popover .fc-header,
|
||||
.fc-unthemed .fc-list-heading td {
|
||||
background: #eee; }
|
||||
|
||||
.fc-unthemed td.fc-today {
|
||||
background: #fcf8e3; }
|
||||
|
||||
.fc-unthemed .fc-disabled-day {
|
||||
background: #d7d7d7;
|
||||
opacity: .3; }
|
||||
|
||||
/* Icons
|
||||
--------------------------------------------------------------------------------------------------
|
||||
from https://feathericons.com/ and built with IcoMoon
|
||||
*/
|
||||
@font-face {
|
||||
font-family: 'fcicons';
|
||||
src: url("data:application/x-font-ttf;charset=utf-8;base64,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") format("truetype");
|
||||
font-weight: normal;
|
||||
font-style: normal; }
|
||||
.fc-icon {
|
||||
/* use !important to prevent issues with browser extensions that change fonts */
|
||||
font-family: 'fcicons' !important;
|
||||
speak: none;
|
||||
font-style: normal;
|
||||
font-weight: normal;
|
||||
font-variant: normal;
|
||||
text-transform: none;
|
||||
line-height: 1;
|
||||
/* Better Font Rendering =========== */
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale; }
|
||||
|
||||
.fc-icon-chevron-left:before {
|
||||
content: "\e900"; }
|
||||
|
||||
.fc-icon-chevron-right:before {
|
||||
content: "\e901"; }
|
||||
|
||||
.fc-icon-chevrons-left:before {
|
||||
content: "\e902"; }
|
||||
|
||||
.fc-icon-chevrons-right:before {
|
||||
content: "\e903"; }
|
||||
|
||||
.fc-icon-minus-square:before {
|
||||
content: "\e904"; }
|
||||
|
||||
.fc-icon-plus-square:before {
|
||||
content: "\e905"; }
|
||||
|
||||
.fc-icon-x:before {
|
||||
content: "\e906"; }
|
||||
|
||||
.fc-icon {
|
||||
display: inline-block;
|
||||
width: 1em;
|
||||
height: 1em;
|
||||
text-align: center; }
|
||||
|
||||
/* Buttons
|
||||
--------------------------------------------------------------------------------------------------
|
||||
Lots taken from Flatly (MIT): https://bootswatch.com/4/flatly/bootstrap.css
|
||||
*/
|
||||
/* reset */
|
||||
.fc-button {
|
||||
border-radius: 0;
|
||||
overflow: visible;
|
||||
text-transform: none;
|
||||
margin: 0;
|
||||
font-family: inherit;
|
||||
font-size: inherit;
|
||||
line-height: inherit; }
|
||||
|
||||
.fc-button:focus {
|
||||
outline: 1px dotted;
|
||||
outline: 5px auto -webkit-focus-ring-color; }
|
||||
|
||||
.fc-button {
|
||||
-webkit-appearance: button; }
|
||||
|
||||
.fc-button:not(:disabled) {
|
||||
cursor: pointer; }
|
||||
|
||||
.fc-button::-moz-focus-inner {
|
||||
padding: 0;
|
||||
border-style: none; }
|
||||
|
||||
/* theme */
|
||||
.fc-button {
|
||||
display: inline-block;
|
||||
font-weight: 400;
|
||||
color: #212529;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
background-color: transparent;
|
||||
border: 1px solid transparent;
|
||||
padding: 0.4em 0.65em;
|
||||
font-size: 1em;
|
||||
line-height: 1.5;
|
||||
border-radius: 0.25em; }
|
||||
|
||||
.fc-button:hover {
|
||||
color: #212529;
|
||||
text-decoration: none; }
|
||||
|
||||
.fc-button:focus {
|
||||
outline: 0;
|
||||
-webkit-box-shadow: 0 0 0 0.2rem rgba(44, 62, 80, 0.25);
|
||||
box-shadow: 0 0 0 0.2rem rgba(44, 62, 80, 0.25); }
|
||||
|
||||
.fc-button:disabled {
|
||||
opacity: 0.65; }
|
||||
|
||||
/* "primary" coloring */
|
||||
.fc-button-primary {
|
||||
color: #fff;
|
||||
background-color: #2C3E50;
|
||||
border-color: #2C3E50; }
|
||||
|
||||
.fc-button-primary:hover {
|
||||
color: #fff;
|
||||
background-color: #1e2b37;
|
||||
border-color: #1a252f; }
|
||||
|
||||
.fc-button-primary:focus {
|
||||
-webkit-box-shadow: 0 0 0 0.2rem rgba(76, 91, 106, 0.5);
|
||||
box-shadow: 0 0 0 0.2rem rgba(76, 91, 106, 0.5); }
|
||||
|
||||
.fc-button-primary:disabled {
|
||||
color: #fff;
|
||||
background-color: #2C3E50;
|
||||
border-color: #2C3E50; }
|
||||
|
||||
.fc-button-primary:not(:disabled):active,
|
||||
.fc-button-primary:not(:disabled).fc-button-active {
|
||||
color: #fff;
|
||||
background-color: #1a252f;
|
||||
border-color: #151e27; }
|
||||
|
||||
.fc-button-primary:not(:disabled):active:focus,
|
||||
.fc-button-primary:not(:disabled).fc-button-active:focus {
|
||||
-webkit-box-shadow: 0 0 0 0.2rem rgba(76, 91, 106, 0.5);
|
||||
box-shadow: 0 0 0 0.2rem rgba(76, 91, 106, 0.5); }
|
||||
|
||||
/* icons within buttons */
|
||||
.fc-button .fc-icon {
|
||||
vertical-align: middle;
|
||||
font-size: 1.5em; }
|
||||
|
||||
/* Buttons Groups
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-button-group {
|
||||
position: relative;
|
||||
display: -webkit-inline-box;
|
||||
display: -ms-inline-flexbox;
|
||||
display: inline-flex;
|
||||
vertical-align: middle; }
|
||||
|
||||
.fc-button-group > .fc-button {
|
||||
position: relative;
|
||||
-webkit-box-flex: 1;
|
||||
-ms-flex: 1 1 auto;
|
||||
flex: 1 1 auto; }
|
||||
|
||||
.fc-button-group > .fc-button:hover {
|
||||
z-index: 1; }
|
||||
|
||||
.fc-button-group > .fc-button:focus,
|
||||
.fc-button-group > .fc-button:active,
|
||||
.fc-button-group > .fc-button.fc-button-active {
|
||||
z-index: 1; }
|
||||
|
||||
.fc-button-group > .fc-button:not(:first-child) {
|
||||
margin-left: -1px; }
|
||||
|
||||
.fc-button-group > .fc-button:not(:last-child) {
|
||||
border-top-right-radius: 0;
|
||||
border-bottom-right-radius: 0; }
|
||||
|
||||
.fc-button-group > .fc-button:not(:first-child) {
|
||||
border-top-left-radius: 0;
|
||||
border-bottom-left-radius: 0; }
|
||||
|
||||
/* Popover
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-unthemed .fc-popover {
|
||||
border-width: 1px;
|
||||
border-style: solid; }
|
||||
|
||||
/* List View
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-unthemed .fc-list-item:hover td {
|
||||
background-color: #f5f5f5; }
|
||||
|
||||
/* Toolbar
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-toolbar {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center; }
|
||||
|
||||
.fc-toolbar.fc-header-toolbar {
|
||||
margin-bottom: 1.5em; }
|
||||
|
||||
.fc-toolbar.fc-footer-toolbar {
|
||||
margin-top: 1.5em; }
|
||||
|
||||
/* inner content */
|
||||
.fc-toolbar > * > :not(:first-child) {
|
||||
margin-left: .75em; }
|
||||
|
||||
.fc-toolbar h2 {
|
||||
font-size: 1.75em;
|
||||
margin: 0; }
|
||||
|
||||
/* View Structure
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-view-container {
|
||||
position: relative; }
|
||||
|
||||
/* undo twitter bootstrap's box-sizing rules. normalizes positioning techniques */
|
||||
/* don't do this for the toolbar because we'll want bootstrap to style those buttons as some pt */
|
||||
.fc-view-container *,
|
||||
.fc-view-container *:before,
|
||||
.fc-view-container *:after {
|
||||
-webkit-box-sizing: content-box;
|
||||
-moz-box-sizing: content-box;
|
||||
box-sizing: content-box; }
|
||||
|
||||
.fc-view,
|
||||
.fc-view > table {
|
||||
/* so dragged elements can be above the view's main element */
|
||||
position: relative;
|
||||
z-index: 1; }
|
||||
|
||||
@media print {
|
||||
.fc {
|
||||
max-width: 100% !important; }
|
||||
|
||||
/* Global Event Restyling
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-event {
|
||||
background: #fff !important;
|
||||
color: #000 !important;
|
||||
page-break-inside: avoid; }
|
||||
|
||||
.fc-event .fc-resizer {
|
||||
display: none; }
|
||||
|
||||
/* Table & Day-Row Restyling
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc th,
|
||||
.fc td,
|
||||
.fc hr,
|
||||
.fc thead,
|
||||
.fc tbody,
|
||||
.fc-row {
|
||||
border-color: #ccc !important;
|
||||
background: #fff !important; }
|
||||
|
||||
/* kill the overlaid, absolutely-positioned components */
|
||||
/* common... */
|
||||
.fc-bg,
|
||||
.fc-bgevent-skeleton,
|
||||
.fc-highlight-skeleton,
|
||||
.fc-mirror-skeleton,
|
||||
.fc-bgevent-container,
|
||||
.fc-business-container,
|
||||
.fc-highlight-container,
|
||||
.fc-mirror-container {
|
||||
display: none; }
|
||||
|
||||
/* don't force a min-height on rows (for DayGrid) */
|
||||
.fc tbody .fc-row {
|
||||
height: auto !important;
|
||||
/* undo height that JS set in distributeHeight */
|
||||
min-height: 0 !important;
|
||||
/* undo the min-height from each view's specific stylesheet */ }
|
||||
|
||||
.fc tbody .fc-row .fc-content-skeleton {
|
||||
position: static;
|
||||
/* undo .fc-rigid */
|
||||
padding-bottom: 0 !important;
|
||||
/* use a more border-friendly method for this... */ }
|
||||
|
||||
.fc tbody .fc-row .fc-content-skeleton tbody tr:last-child td {
|
||||
/* only works in newer browsers */
|
||||
padding-bottom: 1em;
|
||||
/* ...gives space within the skeleton. also ensures min height in a way */ }
|
||||
|
||||
.fc tbody .fc-row .fc-content-skeleton table {
|
||||
/* provides a min-height for the row, but only effective for IE, which exaggerates this value,
|
||||
making it look more like 3em. for other browers, it will already be this tall */
|
||||
height: 1em; }
|
||||
|
||||
/* Undo month-view event limiting. Display all events and hide the "more" links
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-more-cell,
|
||||
.fc-more {
|
||||
display: none !important; }
|
||||
|
||||
.fc tr.fc-limited {
|
||||
display: table-row !important; }
|
||||
|
||||
.fc td.fc-limited {
|
||||
display: table-cell !important; }
|
||||
|
||||
.fc-popover {
|
||||
display: none;
|
||||
/* never display the "more.." popover in print mode */ }
|
||||
|
||||
/* TimeGrid Restyling
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
/* undo the min-height 100% trick used to fill the container's height */
|
||||
.fc-time-grid {
|
||||
min-height: 0 !important; }
|
||||
|
||||
/* don't display the side axis at all ("all-day" and time cells) */
|
||||
.fc-timeGrid-view .fc-axis {
|
||||
display: none; }
|
||||
|
||||
/* don't display the horizontal lines */
|
||||
.fc-slats,
|
||||
.fc-time-grid hr {
|
||||
/* this hr is used when height is underused and needs to be filled */
|
||||
display: none !important;
|
||||
/* important overrides inline declaration */ }
|
||||
|
||||
/* let the container that holds the events be naturally positioned and create real height */
|
||||
.fc-time-grid .fc-content-skeleton {
|
||||
position: static; }
|
||||
|
||||
/* in case there are no events, we still want some height */
|
||||
.fc-time-grid .fc-content-skeleton table {
|
||||
height: 4em; }
|
||||
|
||||
/* kill the horizontal spacing made by the event container. event margins will be done below */
|
||||
.fc-time-grid .fc-event-container {
|
||||
margin: 0 !important; }
|
||||
|
||||
/* TimeGrid *Event* Restyling
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
/* naturally position events, vertically stacking them */
|
||||
.fc-time-grid .fc-event {
|
||||
position: static !important;
|
||||
margin: 3px 2px !important; }
|
||||
|
||||
/* for events that continue to a future day, give the bottom border back */
|
||||
.fc-time-grid .fc-event.fc-not-end {
|
||||
border-bottom-width: 1px !important; }
|
||||
|
||||
/* indicate the event continues via "..." text */
|
||||
.fc-time-grid .fc-event.fc-not-end:after {
|
||||
content: "..."; }
|
||||
|
||||
/* for events that are continuations from previous days, give the top border back */
|
||||
.fc-time-grid .fc-event.fc-not-start {
|
||||
border-top-width: 1px !important; }
|
||||
|
||||
/* indicate the event is a continuation via "..." text */
|
||||
.fc-time-grid .fc-event.fc-not-start:before {
|
||||
content: "..."; }
|
||||
|
||||
/* time */
|
||||
/* undo a previous declaration and let the time text span to a second line */
|
||||
.fc-time-grid .fc-event .fc-time {
|
||||
white-space: normal !important; }
|
||||
|
||||
/* hide the the time that is normally displayed... */
|
||||
.fc-time-grid .fc-event .fc-time span {
|
||||
display: none; }
|
||||
|
||||
/* ...replace it with a more verbose version (includes AM/PM) stored in an html attribute */
|
||||
.fc-time-grid .fc-event .fc-time:after {
|
||||
content: attr(data-full); }
|
||||
|
||||
/* Vertical Scroller & Containers
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
/* kill the scrollbars and allow natural height */
|
||||
.fc-scroller,
|
||||
.fc-day-grid-container,
|
||||
.fc-time-grid-container {
|
||||
/* */
|
||||
overflow: visible !important;
|
||||
height: auto !important; }
|
||||
|
||||
/* kill the horizontal border/padding used to compensate for scrollbars */
|
||||
.fc-row {
|
||||
border: 0 !important;
|
||||
margin: 0 !important; }
|
||||
|
||||
/* Button Controls
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
.fc-button-group,
|
||||
.fc button {
|
||||
display: none;
|
||||
/* don't display any button-related controls */ } }
|
8679
ietf/externals/static/fullcalendar/core/main.js
vendored
Normal file
8679
ietf/externals/static/fullcalendar/core/main.js
vendored
Normal file
File diff suppressed because it is too large
Load diff
5
ietf/externals/static/fullcalendar/core/main.min.css
vendored
Normal file
5
ietf/externals/static/fullcalendar/core/main.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
9
ietf/externals/static/fullcalendar/core/main.min.js
vendored
Normal file
9
ietf/externals/static/fullcalendar/core/main.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
69
ietf/externals/static/fullcalendar/daygrid/main.css
vendored
Normal file
69
ietf/externals/static/fullcalendar/daygrid/main.css
vendored
Normal file
|
@ -0,0 +1,69 @@
|
|||
/*!
|
||||
FullCalendar Day Grid Plugin v4.2.0
|
||||
Docs & License: https://fullcalendar.io/
|
||||
(c) 2019 Adam Shaw
|
||||
*/
|
||||
/* DayGridView
|
||||
--------------------------------------------------------------------------------------------------*/
|
||||
/* day row structure */
|
||||
.fc-dayGridWeek-view .fc-content-skeleton,
|
||||
.fc-dayGridDay-view .fc-content-skeleton {
|
||||
/* there may be week numbers in these views, so no padding-top */
|
||||
padding-bottom: 1em;
|
||||
/* ensure a space at bottom of cell for user selecting/clicking */ }
|
||||
|
||||
.fc-dayGrid-view .fc-body .fc-row {
|
||||
min-height: 4em;
|
||||
/* ensure that all rows are at least this tall */ }
|
||||
|
||||
/* a "rigid" row will take up a constant amount of height because content-skeleton is absolute */
|
||||
.fc-row.fc-rigid {
|
||||
overflow: hidden; }
|
||||
|
||||
.fc-row.fc-rigid .fc-content-skeleton {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0; }
|
||||
|
||||
/* week and day number styling */
|
||||
.fc-day-top.fc-other-month {
|
||||
opacity: 0.3; }
|
||||
|
||||
.fc-dayGrid-view .fc-week-number,
|
||||
.fc-dayGrid-view .fc-day-number {
|
||||
padding: 2px; }
|
||||
|
||||
.fc-dayGrid-view th.fc-week-number,
|
||||
.fc-dayGrid-view th.fc-day-number {
|
||||
padding: 0 2px;
|
||||
/* column headers can't have as much v space */ }
|
||||
|
||||
.fc-ltr .fc-dayGrid-view .fc-day-top .fc-day-number {
|
||||
float: right; }
|
||||
|
||||
.fc-rtl .fc-dayGrid-view .fc-day-top .fc-day-number {
|
||||
float: left; }
|
||||
|
||||
.fc-ltr .fc-dayGrid-view .fc-day-top .fc-week-number {
|
||||
float: left;
|
||||
border-radius: 0 0 3px 0; }
|
||||
|
||||
.fc-rtl .fc-dayGrid-view .fc-day-top .fc-week-number {
|
||||
float: right;
|
||||
border-radius: 0 0 0 3px; }
|
||||
|
||||
.fc-dayGrid-view .fc-day-top .fc-week-number {
|
||||
min-width: 1.5em;
|
||||
text-align: center;
|
||||
background-color: #f2f2f2;
|
||||
color: #808080; }
|
||||
|
||||
/* when week/day number have own column */
|
||||
.fc-dayGrid-view td.fc-week-number {
|
||||
text-align: center; }
|
||||
|
||||
.fc-dayGrid-view td.fc-week-number > * {
|
||||
/* work around the way we do column resizing and ensure a minimum width */
|
||||
display: inline-block;
|
||||
min-width: 1.25em; }
|
1639
ietf/externals/static/fullcalendar/daygrid/main.js
vendored
Normal file
1639
ietf/externals/static/fullcalendar/daygrid/main.js
vendored
Normal file
File diff suppressed because it is too large
Load diff
5
ietf/externals/static/fullcalendar/daygrid/main.min.css
vendored
Normal file
5
ietf/externals/static/fullcalendar/daygrid/main.min.css
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
/*!
|
||||
FullCalendar Day Grid Plugin v4.2.0
|
||||
Docs & License: https://fullcalendar.io/
|
||||
(c) 2019 Adam Shaw
|
||||
*/.fc-dayGridDay-view .fc-content-skeleton,.fc-dayGridWeek-view .fc-content-skeleton{padding-bottom:1em}.fc-dayGrid-view .fc-body .fc-row{min-height:4em}.fc-row.fc-rigid{overflow:hidden}.fc-row.fc-rigid .fc-content-skeleton{position:absolute;top:0;left:0;right:0}.fc-day-top.fc-other-month{opacity:.3}.fc-dayGrid-view .fc-day-number,.fc-dayGrid-view .fc-week-number{padding:2px}.fc-dayGrid-view th.fc-day-number,.fc-dayGrid-view th.fc-week-number{padding:0 2px}.fc-ltr .fc-dayGrid-view .fc-day-top .fc-day-number{float:right}.fc-rtl .fc-dayGrid-view .fc-day-top .fc-day-number{float:left}.fc-ltr .fc-dayGrid-view .fc-day-top .fc-week-number{float:left;border-radius:0 0 3px}.fc-rtl .fc-dayGrid-view .fc-day-top .fc-week-number{float:right;border-radius:0 0 0 3px}.fc-dayGrid-view .fc-day-top .fc-week-number{min-width:1.5em;text-align:center;background-color:#f2f2f2;color:grey}.fc-dayGrid-view td.fc-week-number{text-align:center}.fc-dayGrid-view td.fc-week-number>*{display:inline-block;min-width:1.25em}
|
20
ietf/externals/static/fullcalendar/daygrid/main.min.js
vendored
Normal file
20
ietf/externals/static/fullcalendar/daygrid/main.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
|
@ -2085,6 +2085,10 @@ def upcoming(request):
|
|||
|
||||
p.group_list.sort(key=lambda g: g.acronym)
|
||||
|
||||
meetings = list(meetings)
|
||||
for m in meetings:
|
||||
m.end = m.date+datetime.timedelta(days=m.days)
|
||||
|
||||
# add menu entries
|
||||
menu_entries = get_menu_entries(request)
|
||||
selected_menu_entry = 'upcoming'
|
||||
|
|
|
@ -960,3 +960,14 @@ blockquote {
|
|||
margin-bottom: 1.5em;
|
||||
}
|
||||
|
||||
/* === Fullcalendar================================================ */
|
||||
|
||||
a.fc-event, .fc-event, .fc-content, .fc-title, .fc-event-container {
|
||||
background-color: #9772ff; /* light primary colour from the palette */
|
||||
border-color: #9772ff;
|
||||
}
|
||||
|
||||
.fc-button {
|
||||
/* same as button-primary */
|
||||
background-image: linear-gradient(rgb(107, 91, 173) 0px, rgb(80, 68, 135) 100%)
|
||||
}
|
||||
|
|
|
@ -6,6 +6,9 @@
|
|||
|
||||
{% block pagehead %}
|
||||
<link rel="stylesheet" href="{% static "jquery.tablesorter/css/theme.bootstrap.min.css" %}">
|
||||
<link rel="stylesheet" href="{% static "fullcalendar/core/main.css" %}">
|
||||
<link rel="stylesheet" href="{% static "fullcalendar/daygrid/main.css" %}">
|
||||
|
||||
{% endblock %}
|
||||
|
||||
{% block bodyAttrs %}data-spy="scroll" data-target="#affix"{% endblock %}
|
||||
|
@ -139,9 +142,55 @@
|
|||
|
||||
</div>
|
||||
</div>
|
||||
<div id="calendar" style="width:60%; margin:auto;"></div>
|
||||
{% endblock %}
|
||||
|
||||
{% block js %}
|
||||
<script src="{% static "jquery.tablesorter/js/jquery.tablesorter.combined.min.js" %}"></script>
|
||||
<script src="{% static 'ietf/js/toggle-visibility.js' %}"></script>
|
||||
<script src="{% static 'fullcalendar/core/main.js' %}"></script>
|
||||
<script src="{% static 'fullcalendar/daygrid/main.js' %}"></script>
|
||||
<script>
|
||||
|
||||
document.addEventListener('DOMContentLoaded', function() {
|
||||
var calendarEl = document.getElementById('calendar');
|
||||
|
||||
var calendar = new FullCalendar.Calendar(calendarEl, {
|
||||
aspectRatio: 1.35,
|
||||
plugins: [ 'dayGrid' ],
|
||||
events: [
|
||||
{% for meeting in meetings %}
|
||||
{% if meeting.type_id == 'ietf' %}
|
||||
{
|
||||
title: 'IETF - {{ meeting.number }}',
|
||||
start: '{{meeting.date}}',
|
||||
end: '{{meeting.end}}',
|
||||
url: '{% url 'ietf.meeting.views.agenda' num=meeting.number %}'
|
||||
}{% if not forloop.last %}, {% endif %}
|
||||
{% else %}
|
||||
{% for session in meeting.session_set.all %}
|
||||
{% for tsa in session.timeslotassignments.all %}
|
||||
{
|
||||
title: '{{session.group.acronym}} - {{tsa.timeslot.time|date:"H:i"}} {{meeting.time_zone}}',
|
||||
start: '{{meeting.date}}',
|
||||
end: '{{meeting.end}}',
|
||||
url: '{% url 'ietf.meeting.views.session_details' num=meeting.number acronym=session.group.acronym %}'
|
||||
}{% if not forloop.last %}, {% endif %}
|
||||
{% endfor %}
|
||||
{% if not forloop.last %}, {% endif %}
|
||||
{% endfor %}
|
||||
{% if not forloop.last %}, {% endif %}
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
],
|
||||
eventRender: function(info) {
|
||||
$(info.el).tooltip({title: info.event.title});
|
||||
},
|
||||
timeFormat: 'H:mm',
|
||||
});
|
||||
|
||||
calendar.render();
|
||||
});
|
||||
|
||||
</script>
|
||||
{% endblock %}
|
||||
|
|
Loading…
Reference in a new issue