fullcalendar.css 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413
  1. /*!
  2. * FullCalendar v3.4.0 Stylesheet
  3. * Docs & License: https://fullcalendar.io/
  4. * (c) 2017 Adam Shaw
  5. */
  6. .fc {
  7. direction: ltr;
  8. text-align: left;
  9. }
  10. .fc-rtl {
  11. text-align: right;
  12. }
  13. body .fc { /* extra precedence to overcome jqui */
  14. font-size: 1em;
  15. }
  16. /* Colors
  17. --------------------------------------------------------------------------------------------------*/
  18. .fc-unthemed th,
  19. .fc-unthemed td,
  20. .fc-unthemed thead,
  21. .fc-unthemed tbody,
  22. .fc-unthemed .fc-divider,
  23. .fc-unthemed .fc-row,
  24. .fc-unthemed .fc-content, /* for gutter border */
  25. .fc-unthemed .fc-popover,
  26. .fc-unthemed .fc-list-view,
  27. .fc-unthemed .fc-list-heading td {
  28. border-color: #ddd;
  29. }
  30. .fc-unthemed .fc-popover {
  31. background-color: #fff;
  32. }
  33. .fc-unthemed .fc-divider,
  34. .fc-unthemed .fc-popover .fc-header,
  35. .fc-unthemed .fc-list-heading td {
  36. background: #eee;
  37. }
  38. .fc-unthemed .fc-popover .fc-header .fc-close {
  39. color: #666;
  40. }
  41. .fc-unthemed td.fc-today {
  42. background: #fcf8e3;
  43. }
  44. .fc-highlight { /* when user is selecting cells */
  45. background: #bce8f1;
  46. opacity: .3;
  47. }
  48. .fc-bgevent { /* default look for background events */
  49. background: rgb(143, 223, 130);
  50. opacity: .3;
  51. }
  52. .fc-nonbusiness { /* default look for non-business-hours areas */
  53. /* will inherit .fc-bgevent's styles */
  54. background: #d7d7d7;
  55. }
  56. .fc-unthemed .fc-disabled-day {
  57. background: #d7d7d7;
  58. opacity: .3;
  59. }
  60. .ui-widget .fc-disabled-day { /* themed */
  61. background-image: none;
  62. }
  63. /* Icons (inline elements with styled text that mock arrow icons)
  64. --------------------------------------------------------------------------------------------------*/
  65. .fc-icon {
  66. display: inline-block;
  67. height: 1em;
  68. line-height: 1em;
  69. font-size: 1em;
  70. text-align: center;
  71. overflow: hidden;
  72. font-family: "Courier New", Courier, monospace;
  73. /* don't allow browser text-selection */
  74. -webkit-touch-callout: none;
  75. -webkit-user-select: none;
  76. -khtml-user-select: none;
  77. -moz-user-select: none;
  78. -ms-user-select: none;
  79. user-select: none;
  80. }
  81. /*
  82. Acceptable font-family overrides for individual icons:
  83. "Arial", sans-serif
  84. "Times New Roman", serif
  85. NOTE: use percentage font sizes or else old IE chokes
  86. */
  87. .fc-icon:after {
  88. position: relative;
  89. }
  90. .fc-icon-left-single-arrow:after {
  91. content: "\02039";
  92. font-weight: bold;
  93. font-size: 200%;
  94. top: -7%;
  95. }
  96. .fc-icon-right-single-arrow:after {
  97. content: "\0203A";
  98. font-weight: bold;
  99. font-size: 200%;
  100. top: -7%;
  101. }
  102. .fc-icon-left-double-arrow:after {
  103. content: "\000AB";
  104. font-size: 160%;
  105. top: -7%;
  106. }
  107. .fc-icon-right-double-arrow:after {
  108. content: "\000BB";
  109. font-size: 160%;
  110. top: -7%;
  111. }
  112. .fc-icon-left-triangle:after {
  113. content: "\25C4";
  114. font-size: 125%;
  115. top: 3%;
  116. }
  117. .fc-icon-right-triangle:after {
  118. content: "\25BA";
  119. font-size: 125%;
  120. top: 3%;
  121. }
  122. .fc-icon-down-triangle:after {
  123. content: "\25BC";
  124. font-size: 125%;
  125. top: 2%;
  126. }
  127. .fc-icon-x:after {
  128. content: "\000D7";
  129. font-size: 200%;
  130. top: 6%;
  131. }
  132. /* Buttons (styled <button> tags, normalized to work cross-browser)
  133. --------------------------------------------------------------------------------------------------*/
  134. .fc button {
  135. /* force height to include the border and padding */
  136. -moz-box-sizing: border-box;
  137. -webkit-box-sizing: border-box;
  138. box-sizing: border-box;
  139. /* dimensions */
  140. margin: 0;
  141. height: 2.1em;
  142. padding: 0 .6em;
  143. /* text & cursor */
  144. font-size: 1em; /* normalize */
  145. white-space: nowrap;
  146. cursor: pointer;
  147. }
  148. /* Firefox has an annoying inner border */
  149. .fc button::-moz-focus-inner { margin: 0; padding: 0; }
  150. .fc-state-default { /* non-theme */
  151. border: 1px solid;
  152. }
  153. .fc-state-default.fc-corner-left { /* non-theme */
  154. border-top-left-radius: 4px;
  155. border-bottom-left-radius: 4px;
  156. }
  157. .fc-state-default.fc-corner-right { /* non-theme */
  158. border-top-right-radius: 4px;
  159. border-bottom-right-radius: 4px;
  160. }
  161. /* icons in buttons */
  162. .fc button .fc-icon { /* non-theme */
  163. position: relative;
  164. top: -0.05em; /* seems to be a good adjustment across browsers */
  165. margin: 0 .2em;
  166. vertical-align: middle;
  167. }
  168. /*
  169. button states
  170. borrowed from twitter bootstrap (http://twitter.github.com/bootstrap/)
  171. */
  172. .fc-state-default {
  173. background-color: #f5f5f5;
  174. background-image: -moz-linear-gradient(top, #ffffff, #e6e6e6);
  175. background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), to(#e6e6e6));
  176. background-image: -webkit-linear-gradient(top, #ffffff, #e6e6e6);
  177. background-image: -o-linear-gradient(top, #ffffff, #e6e6e6);
  178. background-image: linear-gradient(to bottom, #ffffff, #e6e6e6);
  179. background-repeat: repeat-x;
  180. border-color: #e6e6e6 #e6e6e6 #bfbfbf;
  181. border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);
  182. color: #333;
  183. text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75);
  184. box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
  185. }
  186. .fc-state-hover,
  187. .fc-state-down,
  188. .fc-state-active,
  189. .fc-state-disabled {
  190. color: #333333;
  191. background-color: #e6e6e6;
  192. }
  193. .fc-state-hover {
  194. color: #333333;
  195. text-decoration: none;
  196. background-position: 0 -15px;
  197. -webkit-transition: background-position 0.1s linear;
  198. -moz-transition: background-position 0.1s linear;
  199. -o-transition: background-position 0.1s linear;
  200. transition: background-position 0.1s linear;
  201. }
  202. .fc-state-down,
  203. .fc-state-active {
  204. background-color: #cccccc;
  205. background-image: none;
  206. box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.05);
  207. }
  208. .fc-state-disabled {
  209. cursor: default;
  210. background-image: none;
  211. opacity: 0.65;
  212. box-shadow: none;
  213. }
  214. /* Buttons Groups
  215. --------------------------------------------------------------------------------------------------*/
  216. .fc-button-group {
  217. display: inline-block;
  218. }
  219. /*
  220. every button that is not first in a button group should scootch over one pixel and cover the
  221. previous button's border...
  222. */
  223. .fc .fc-button-group > * { /* extra precedence b/c buttons have margin set to zero */
  224. float: left;
  225. margin: 0 0 0 -1px;
  226. }
  227. .fc .fc-button-group > :first-child { /* same */
  228. margin-left: 0;
  229. }
  230. /* Popover
  231. --------------------------------------------------------------------------------------------------*/
  232. .fc-popover {
  233. position: absolute;
  234. box-shadow: 0 2px 6px rgba(0,0,0,.15);
  235. }
  236. .fc-popover .fc-header { /* TODO: be more consistent with fc-head/fc-body */
  237. padding: 2px 4px;
  238. }
  239. .fc-popover .fc-header .fc-title {
  240. margin: 0 2px;
  241. }
  242. .fc-popover .fc-header .fc-close {
  243. cursor: pointer;
  244. }
  245. .fc-ltr .fc-popover .fc-header .fc-title,
  246. .fc-rtl .fc-popover .fc-header .fc-close {
  247. float: left;
  248. }
  249. .fc-rtl .fc-popover .fc-header .fc-title,
  250. .fc-ltr .fc-popover .fc-header .fc-close {
  251. float: right;
  252. }
  253. /* unthemed */
  254. .fc-unthemed .fc-popover {
  255. border-width: 1px;
  256. border-style: solid;
  257. }
  258. .fc-unthemed .fc-popover .fc-header .fc-close {
  259. font-size: .9em;
  260. margin-top: 2px;
  261. }
  262. /* jqui themed */
  263. .fc-popover > .ui-widget-header + .ui-widget-content {
  264. border-top: 0; /* where they meet, let the header have the border */
  265. }
  266. /* Misc Reusable Components
  267. --------------------------------------------------------------------------------------------------*/
  268. .fc-divider {
  269. border-style: solid;
  270. border-width: 1px;
  271. }
  272. hr.fc-divider {
  273. height: 0;
  274. margin: 0;
  275. padding: 0 0 2px; /* height is unreliable across browsers, so use padding */
  276. border-width: 1px 0;
  277. }
  278. .fc-clear {
  279. clear: both;
  280. }
  281. .fc-bg,
  282. .fc-bgevent-skeleton,
  283. .fc-highlight-skeleton,
  284. .fc-helper-skeleton {
  285. /* these element should always cling to top-left/right corners */
  286. position: absolute;
  287. top: 0;
  288. left: 0;
  289. right: 0;
  290. }
  291. .fc-bg {
  292. bottom: 0; /* strech bg to bottom edge */
  293. }
  294. .fc-bg table {
  295. height: 100%; /* strech bg to bottom edge */
  296. }
  297. /* Tables
  298. --------------------------------------------------------------------------------------------------*/
  299. .fc table {
  300. width: 100%;
  301. box-sizing: border-box; /* fix scrollbar issue in firefox */
  302. table-layout: fixed;
  303. border-collapse: collapse;
  304. border-spacing: 0;
  305. font-size: 1em; /* normalize cross-browser */
  306. }
  307. .fc th {
  308. text-align: center;
  309. }
  310. .fc th,
  311. .fc td {
  312. border-style: solid;
  313. border-width: 1px;
  314. padding: 0;
  315. vertical-align: top;
  316. }
  317. .fc td.fc-today {
  318. border-style: double; /* overcome neighboring borders */
  319. }
  320. /* Internal Nav Links
  321. --------------------------------------------------------------------------------------------------*/
  322. a[data-goto] {
  323. cursor: pointer;
  324. }
  325. a[data-goto]:hover {
  326. text-decoration: underline;
  327. }
  328. /* Fake Table Rows
  329. --------------------------------------------------------------------------------------------------*/
  330. .fc .fc-row { /* extra precedence to overcome themes w/ .ui-widget-content forcing a 1px border */
  331. /* no visible border by default. but make available if need be (scrollbar width compensation) */
  332. border-style: solid;
  333. border-width: 0;
  334. }
  335. .fc-row table {
  336. /* don't put left/right border on anything within a fake row.
  337. the outer tbody will worry about this */
  338. border-left: 0 hidden transparent;
  339. border-right: 0 hidden transparent;
  340. /* no bottom borders on rows */
  341. border-bottom: 0 hidden transparent;
  342. }
  343. .fc-row:first-child table {
  344. border-top: 0 hidden transparent; /* no top border on first row */
  345. }
  346. /* Day Row (used within the header and the DayGrid)
  347. --------------------------------------------------------------------------------------------------*/
  348. .fc-row {
  349. position: relative;
  350. }
  351. .fc-row .fc-bg {
  352. z-index: 1;
  353. }
  354. /* highlighting cells & background event skeleton */
  355. .fc-row .fc-bgevent-skeleton,
  356. .fc-row .fc-highlight-skeleton {
  357. bottom: 0; /* stretch skeleton to bottom of row */
  358. }
  359. .fc-row .fc-bgevent-skeleton table,
  360. .fc-row .fc-highlight-skeleton table {
  361. height: 100%; /* stretch skeleton to bottom of row */
  362. }
  363. .fc-row .fc-highlight-skeleton td,
  364. .fc-row .fc-bgevent-skeleton td {
  365. border-color: transparent;
  366. }
  367. .fc-row .fc-bgevent-skeleton {
  368. z-index: 2;
  369. }
  370. .fc-row .fc-highlight-skeleton {
  371. z-index: 3;
  372. }
  373. /*
  374. row content (which contains day/week numbers and events) as well as "helper" (which contains
  375. temporary rendered events).
  376. */
  377. .fc-row .fc-content-skeleton {
  378. position: relative;
  379. z-index: 4;
  380. padding-bottom: 2px; /* matches the space above the events */
  381. }
  382. .fc-row .fc-helper-skeleton {
  383. z-index: 5;
  384. }
  385. .fc-row .fc-content-skeleton td,
  386. .fc-row .fc-helper-skeleton td {
  387. /* see-through to the background below */
  388. background: none; /* in case <td>s are globally styled */
  389. border-color: transparent;
  390. /* don't put a border between events and/or the day number */
  391. border-bottom: 0;
  392. }
  393. .fc-row .fc-content-skeleton tbody td, /* cells with events inside (so NOT the day number cell) */
  394. .fc-row .fc-helper-skeleton tbody td {
  395. /* don't put a border between event cells */
  396. border-top: 0;
  397. }
  398. /* Scrolling Container
  399. --------------------------------------------------------------------------------------------------*/
  400. .fc-scroller {
  401. -webkit-overflow-scrolling: touch;
  402. }
  403. /* TODO: move to agenda/basic */
  404. .fc-scroller > .fc-day-grid,
  405. .fc-scroller > .fc-time-grid {
  406. position: relative; /* re-scope all positions */
  407. width: 100%; /* hack to force re-sizing this inner element when scrollbars appear/disappear */
  408. }
  409. /* Global Event Styles
  410. --------------------------------------------------------------------------------------------------*/
  411. .fc-event {
  412. position: relative; /* for resize handle and other inner positioning */
  413. display: block; /* make the <a> tag block */
  414. font-size: .85em;
  415. line-height: 1.3;
  416. border-radius: 3px;
  417. border: 1px solid #3a87ad; /* default BORDER color */
  418. font-weight: normal; /* undo jqui's ui-widget-header bold */
  419. }
  420. .fc-event,
  421. .fc-event-dot {
  422. background-color: #3a87ad; /* default BACKGROUND color */
  423. }
  424. /* overpower some of bootstrap's and jqui's styles on <a> tags */
  425. .fc-event,
  426. .fc-event:hover,
  427. .ui-widget .fc-event {
  428. color: #fff; /* default TEXT color */
  429. text-decoration: none; /* if <a> has an href */
  430. }
  431. .fc-event[href],
  432. .fc-event.fc-draggable {
  433. cursor: pointer; /* give events with links and draggable events a hand mouse pointer */
  434. }
  435. .fc-not-allowed, /* causes a "warning" cursor. applied on body */
  436. .fc-not-allowed .fc-event { /* to override an event's custom cursor */
  437. cursor: not-allowed;
  438. }
  439. .fc-event .fc-bg { /* the generic .fc-bg already does position */
  440. z-index: 1;
  441. background: #fff;
  442. opacity: .25;
  443. }
  444. .fc-event .fc-content {
  445. position: relative;
  446. z-index: 2;
  447. }
  448. /* resizer (cursor AND touch devices) */
  449. .fc-event .fc-resizer {
  450. position: absolute;
  451. z-index: 4;
  452. }
  453. /* resizer (touch devices) */
  454. .fc-event .fc-resizer {
  455. display: none;
  456. }
  457. .fc-event.fc-allow-mouse-resize .fc-resizer,
  458. .fc-event.fc-selected .fc-resizer {
  459. /* only show when hovering or selected (with touch) */
  460. display: block;
  461. }
  462. /* hit area */
  463. .fc-event.fc-selected .fc-resizer:before {
  464. /* 40x40 touch area */
  465. content: "";
  466. position: absolute;
  467. z-index: 9999; /* user of this util can scope within a lower z-index */
  468. top: 50%;
  469. left: 50%;
  470. width: 40px;
  471. height: 40px;
  472. margin-left: -20px;
  473. margin-top: -20px;
  474. }
  475. /* Event Selection (only for touch devices)
  476. --------------------------------------------------------------------------------------------------*/
  477. .fc-event.fc-selected {
  478. z-index: 9999 !important; /* overcomes inline z-index */
  479. box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
  480. }
  481. .fc-event.fc-selected.fc-dragging {
  482. box-shadow: 0 2px 7px rgba(0, 0, 0, 0.3);
  483. }
  484. /* Horizontal Events
  485. --------------------------------------------------------------------------------------------------*/
  486. /* bigger touch area when selected */
  487. .fc-h-event.fc-selected:before {
  488. content: "";
  489. position: absolute;
  490. z-index: 3; /* below resizers */
  491. top: -10px;
  492. bottom: -10px;
  493. left: 0;
  494. right: 0;
  495. }
  496. /* events that are continuing to/from another week. kill rounded corners and butt up against edge */
  497. .fc-ltr .fc-h-event.fc-not-start,
  498. .fc-rtl .fc-h-event.fc-not-end {
  499. margin-left: 0;
  500. border-left-width: 0;
  501. padding-left: 1px; /* replace the border with padding */
  502. border-top-left-radius: 0;
  503. border-bottom-left-radius: 0;
  504. }
  505. .fc-ltr .fc-h-event.fc-not-end,
  506. .fc-rtl .fc-h-event.fc-not-start {
  507. margin-right: 0;
  508. border-right-width: 0;
  509. padding-right: 1px; /* replace the border with padding */
  510. border-top-right-radius: 0;
  511. border-bottom-right-radius: 0;
  512. }
  513. /* resizer (cursor AND touch devices) */
  514. /* left resizer */
  515. .fc-ltr .fc-h-event .fc-start-resizer,
  516. .fc-rtl .fc-h-event .fc-end-resizer {
  517. cursor: w-resize;
  518. left: -1px; /* overcome border */
  519. }
  520. /* right resizer */
  521. .fc-ltr .fc-h-event .fc-end-resizer,
  522. .fc-rtl .fc-h-event .fc-start-resizer {
  523. cursor: e-resize;
  524. right: -1px; /* overcome border */
  525. }
  526. /* resizer (mouse devices) */
  527. .fc-h-event.fc-allow-mouse-resize .fc-resizer {
  528. width: 7px;
  529. top: -1px; /* overcome top border */
  530. bottom: -1px; /* overcome bottom border */
  531. }
  532. /* resizer (touch devices) */
  533. .fc-h-event.fc-selected .fc-resizer {
  534. /* 8x8 little dot */
  535. border-radius: 4px;
  536. border-width: 1px;
  537. width: 6px;
  538. height: 6px;
  539. border-style: solid;
  540. border-color: inherit;
  541. background: #fff;
  542. /* vertically center */
  543. top: 50%;
  544. margin-top: -4px;
  545. }
  546. /* left resizer */
  547. .fc-ltr .fc-h-event.fc-selected .fc-start-resizer,
  548. .fc-rtl .fc-h-event.fc-selected .fc-end-resizer {
  549. margin-left: -4px; /* centers the 8x8 dot on the left edge */
  550. }
  551. /* right resizer */
  552. .fc-ltr .fc-h-event.fc-selected .fc-end-resizer,
  553. .fc-rtl .fc-h-event.fc-selected .fc-start-resizer {
  554. margin-right: -4px; /* centers the 8x8 dot on the right edge */
  555. }
  556. /* DayGrid events
  557. ----------------------------------------------------------------------------------------------------
  558. We use the full "fc-day-grid-event" class instead of using descendants because the event won't
  559. be a descendant of the grid when it is being dragged.
  560. */
  561. .fc-day-grid-event {
  562. margin: 1px 2px 0; /* spacing between events and edges */
  563. padding: 0 1px;
  564. }
  565. tr:first-child > td > .fc-day-grid-event {
  566. margin-top: 2px; /* a little bit more space before the first event */
  567. }
  568. .fc-day-grid-event.fc-selected:after {
  569. content: "";
  570. position: absolute;
  571. z-index: 1; /* same z-index as fc-bg, behind text */
  572. /* overcome the borders */
  573. top: -1px;
  574. right: -1px;
  575. bottom: -1px;
  576. left: -1px;
  577. /* darkening effect */
  578. background: #000;
  579. opacity: .25;
  580. }
  581. .fc-day-grid-event .fc-content { /* force events to be one-line tall */
  582. white-space: nowrap;
  583. overflow: hidden;
  584. }
  585. .fc-day-grid-event .fc-time {
  586. font-weight: bold;
  587. }
  588. /* resizer (cursor devices) */
  589. /* left resizer */
  590. .fc-ltr .fc-day-grid-event.fc-allow-mouse-resize .fc-start-resizer,
  591. .fc-rtl .fc-day-grid-event.fc-allow-mouse-resize .fc-end-resizer {
  592. margin-left: -2px; /* to the day cell's edge */
  593. }
  594. /* right resizer */
  595. .fc-ltr .fc-day-grid-event.fc-allow-mouse-resize .fc-end-resizer,
  596. .fc-rtl .fc-day-grid-event.fc-allow-mouse-resize .fc-start-resizer {
  597. margin-right: -2px; /* to the day cell's edge */
  598. }
  599. /* Event Limiting
  600. --------------------------------------------------------------------------------------------------*/
  601. /* "more" link that represents hidden events */
  602. a.fc-more {
  603. margin: 1px 3px;
  604. font-size: .85em;
  605. cursor: pointer;
  606. text-decoration: none;
  607. }
  608. a.fc-more:hover {
  609. text-decoration: underline;
  610. }
  611. .fc-limited { /* rows and cells that are hidden because of a "more" link */
  612. display: none;
  613. }
  614. /* popover that appears when "more" link is clicked */
  615. .fc-day-grid .fc-row {
  616. z-index: 1; /* make the "more" popover one higher than this */
  617. }
  618. .fc-more-popover {
  619. z-index: 2;
  620. width: 220px;
  621. }
  622. .fc-more-popover .fc-event-container {
  623. padding: 10px;
  624. }
  625. /* Now Indicator
  626. --------------------------------------------------------------------------------------------------*/
  627. .fc-now-indicator {
  628. position: absolute;
  629. border: 0 solid red;
  630. }
  631. /* Utilities
  632. --------------------------------------------------------------------------------------------------*/
  633. .fc-unselectable {
  634. -webkit-user-select: none;
  635. -khtml-user-select: none;
  636. -moz-user-select: none;
  637. -ms-user-select: none;
  638. user-select: none;
  639. -webkit-touch-callout: none;
  640. -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  641. }
  642. /* Toolbar
  643. --------------------------------------------------------------------------------------------------*/
  644. .fc-toolbar {
  645. text-align: center;
  646. }
  647. .fc-toolbar.fc-header-toolbar {
  648. margin-bottom: 1em;
  649. }
  650. .fc-toolbar.fc-footer-toolbar {
  651. margin-top: 1em;
  652. }
  653. .fc-toolbar .fc-left {
  654. float: left;
  655. }
  656. .fc-toolbar .fc-right {
  657. float: right;
  658. }
  659. .fc-toolbar .fc-center {
  660. display: inline-block;
  661. }
  662. /* the things within each left/right/center section */
  663. .fc .fc-toolbar > * > * { /* extra precedence to override button border margins */
  664. float: left;
  665. margin-left: .75em;
  666. }
  667. /* the first thing within each left/center/right section */
  668. .fc .fc-toolbar > * > :first-child { /* extra precedence to override button border margins */
  669. margin-left: 0;
  670. }
  671. /* title text */
  672. .fc-toolbar h2 {
  673. margin: 0;
  674. }
  675. /* button layering (for border precedence) */
  676. .fc-toolbar button {
  677. position: relative;
  678. }
  679. .fc-toolbar .fc-state-hover,
  680. .fc-toolbar .ui-state-hover {
  681. z-index: 2;
  682. }
  683. .fc-toolbar .fc-state-down {
  684. z-index: 3;
  685. }
  686. .fc-toolbar .fc-state-active,
  687. .fc-toolbar .ui-state-active {
  688. z-index: 4;
  689. }
  690. .fc-toolbar button:focus {
  691. z-index: 5;
  692. }
  693. /* View Structure
  694. --------------------------------------------------------------------------------------------------*/
  695. /* undo twitter bootstrap's box-sizing rules. normalizes positioning techniques */
  696. /* don't do this for the toolbar because we'll want bootstrap to style those buttons as some pt */
  697. .fc-view-container *,
  698. .fc-view-container *:before,
  699. .fc-view-container *:after {
  700. -webkit-box-sizing: content-box;
  701. -moz-box-sizing: content-box;
  702. box-sizing: content-box;
  703. }
  704. .fc-view, /* scope positioning and z-index's for everything within the view */
  705. .fc-view > table { /* so dragged elements can be above the view's main element */
  706. position: relative;
  707. z-index: 1;
  708. }
  709. /* BasicView
  710. --------------------------------------------------------------------------------------------------*/
  711. /* day row structure */
  712. .fc-basicWeek-view .fc-content-skeleton,
  713. .fc-basicDay-view .fc-content-skeleton {
  714. /* there may be week numbers in these views, so no padding-top */
  715. padding-bottom: 1em; /* ensure a space at bottom of cell for user selecting/clicking */
  716. }
  717. .fc-basic-view .fc-body .fc-row {
  718. min-height: 4em; /* ensure that all rows are at least this tall */
  719. }
  720. /* a "rigid" row will take up a constant amount of height because content-skeleton is absolute */
  721. .fc-row.fc-rigid {
  722. overflow: hidden;
  723. }
  724. .fc-row.fc-rigid .fc-content-skeleton {
  725. position: absolute;
  726. top: 0;
  727. left: 0;
  728. right: 0;
  729. }
  730. /* week and day number styling */
  731. .fc-day-top.fc-other-month {
  732. opacity: 0.3;
  733. }
  734. .fc-basic-view .fc-week-number,
  735. .fc-basic-view .fc-day-number {
  736. padding: 2px;
  737. }
  738. .fc-basic-view th.fc-week-number,
  739. .fc-basic-view th.fc-day-number {
  740. padding: 0 2px; /* column headers can't have as much v space */
  741. }
  742. .fc-ltr .fc-basic-view .fc-day-top .fc-day-number { float: right; }
  743. .fc-rtl .fc-basic-view .fc-day-top .fc-day-number { float: left; }
  744. .fc-ltr .fc-basic-view .fc-day-top .fc-week-number { float: left; border-radius: 0 0 3px 0; }
  745. .fc-rtl .fc-basic-view .fc-day-top .fc-week-number { float: right; border-radius: 0 0 0 3px; }
  746. .fc-basic-view .fc-day-top .fc-week-number {
  747. min-width: 1.5em;
  748. text-align: center;
  749. background-color: #f2f2f2;
  750. color: #808080;
  751. }
  752. /* when week/day number have own column */
  753. .fc-basic-view td.fc-week-number {
  754. text-align: center;
  755. }
  756. .fc-basic-view td.fc-week-number > * {
  757. /* work around the way we do column resizing and ensure a minimum width */
  758. display: inline-block;
  759. min-width: 1.25em;
  760. }
  761. /* AgendaView all-day area
  762. --------------------------------------------------------------------------------------------------*/
  763. .fc-agenda-view .fc-day-grid {
  764. position: relative;
  765. z-index: 2; /* so the "more.." popover will be over the time grid */
  766. }
  767. .fc-agenda-view .fc-day-grid .fc-row {
  768. min-height: 3em; /* all-day section will never get shorter than this */
  769. }
  770. .fc-agenda-view .fc-day-grid .fc-row .fc-content-skeleton {
  771. padding-bottom: 1em; /* give space underneath events for clicking/selecting days */
  772. }
  773. /* TimeGrid axis running down the side (for both the all-day area and the slot area)
  774. --------------------------------------------------------------------------------------------------*/
  775. .fc .fc-axis { /* .fc to overcome default cell styles */
  776. vertical-align: middle;
  777. padding: 0 4px;
  778. white-space: nowrap;
  779. }
  780. .fc-ltr .fc-axis {
  781. text-align: right;
  782. }
  783. .fc-rtl .fc-axis {
  784. text-align: left;
  785. }
  786. .ui-widget td.fc-axis {
  787. font-weight: normal; /* overcome jqui theme making it bold */
  788. }
  789. /* TimeGrid Structure
  790. --------------------------------------------------------------------------------------------------*/
  791. .fc-time-grid-container, /* so scroll container's z-index is below all-day */
  792. .fc-time-grid { /* so slats/bg/content/etc positions get scoped within here */
  793. position: relative;
  794. z-index: 1;
  795. }
  796. .fc-time-grid {
  797. min-height: 100%; /* so if height setting is 'auto', .fc-bg stretches to fill height */
  798. }
  799. .fc-time-grid table { /* don't put outer borders on slats/bg/content/etc */
  800. border: 0 hidden transparent;
  801. }
  802. .fc-time-grid > .fc-bg {
  803. z-index: 1;
  804. }
  805. .fc-time-grid .fc-slats,
  806. .fc-time-grid > hr { /* the <hr> AgendaView injects when grid is shorter than scroller */
  807. position: relative;
  808. z-index: 2;
  809. }
  810. .fc-time-grid .fc-content-col {
  811. position: relative; /* because now-indicator lives directly inside */
  812. }
  813. .fc-time-grid .fc-content-skeleton {
  814. position: absolute;
  815. z-index: 3;
  816. top: 0;
  817. left: 0;
  818. right: 0;
  819. }
  820. /* divs within a cell within the fc-content-skeleton */
  821. .fc-time-grid .fc-business-container {
  822. position: relative;
  823. z-index: 1;
  824. }
  825. .fc-time-grid .fc-bgevent-container {
  826. position: relative;
  827. z-index: 2;
  828. }
  829. .fc-time-grid .fc-highlight-container {
  830. position: relative;
  831. z-index: 3;
  832. }
  833. .fc-time-grid .fc-event-container {
  834. position: relative;
  835. z-index: 4;
  836. }
  837. .fc-time-grid .fc-now-indicator-line {
  838. z-index: 5;
  839. }
  840. .fc-time-grid .fc-helper-container { /* also is fc-event-container */
  841. position: relative;
  842. z-index: 6;
  843. }
  844. /* TimeGrid Slats (lines that run horizontally)
  845. --------------------------------------------------------------------------------------------------*/
  846. .fc-time-grid .fc-slats td {
  847. height: 1.5em;
  848. border-bottom: 0; /* each cell is responsible for its top border */
  849. }
  850. .fc-time-grid .fc-slats .fc-minor td {
  851. border-top-style: dotted;
  852. }
  853. .fc-time-grid .fc-slats .ui-widget-content { /* for jqui theme */
  854. background: none; /* see through to fc-bg */
  855. }
  856. /* TimeGrid Highlighting Slots
  857. --------------------------------------------------------------------------------------------------*/
  858. .fc-time-grid .fc-highlight-container { /* a div within a cell within the fc-highlight-skeleton */
  859. position: relative; /* scopes the left/right of the fc-highlight to be in the column */
  860. }
  861. .fc-time-grid .fc-highlight {
  862. position: absolute;
  863. left: 0;
  864. right: 0;
  865. /* top and bottom will be in by JS */
  866. }
  867. /* TimeGrid Event Containment
  868. --------------------------------------------------------------------------------------------------*/
  869. .fc-ltr .fc-time-grid .fc-event-container { /* space on the sides of events for LTR (default) */
  870. margin: 0 2.5% 0 2px;
  871. }
  872. .fc-rtl .fc-time-grid .fc-event-container { /* space on the sides of events for RTL */
  873. margin: 0 2px 0 2.5%;
  874. }
  875. .fc-time-grid .fc-event,
  876. .fc-time-grid .fc-bgevent {
  877. position: absolute;
  878. z-index: 1; /* scope inner z-index's */
  879. }
  880. .fc-time-grid .fc-bgevent {
  881. /* background events always span full width */
  882. left: 0;
  883. right: 0;
  884. }
  885. /* Generic Vertical Event
  886. --------------------------------------------------------------------------------------------------*/
  887. .fc-v-event.fc-not-start { /* events that are continuing from another day */
  888. /* replace space made by the top border with padding */
  889. border-top-width: 0;
  890. padding-top: 1px;
  891. /* remove top rounded corners */
  892. border-top-left-radius: 0;
  893. border-top-right-radius: 0;
  894. }
  895. .fc-v-event.fc-not-end {
  896. /* replace space made by the top border with padding */
  897. border-bottom-width: 0;
  898. padding-bottom: 1px;
  899. /* remove bottom rounded corners */
  900. border-bottom-left-radius: 0;
  901. border-bottom-right-radius: 0;
  902. }
  903. /* TimeGrid Event Styling
  904. ----------------------------------------------------------------------------------------------------
  905. We use the full "fc-time-grid-event" class instead of using descendants because the event won't
  906. be a descendant of the grid when it is being dragged.
  907. */
  908. .fc-time-grid-event {
  909. overflow: hidden; /* don't let the bg flow over rounded corners */
  910. }
  911. .fc-time-grid-event.fc-selected {
  912. /* need to allow touch resizers to extend outside event's bounding box */
  913. /* common fc-selected styles hide the fc-bg, so don't need this anyway */
  914. overflow: visible;
  915. }
  916. .fc-time-grid-event.fc-selected .fc-bg {
  917. display: none; /* hide semi-white background, to appear darker */
  918. }
  919. .fc-time-grid-event .fc-content {
  920. overflow: hidden; /* for when .fc-selected */
  921. }
  922. .fc-time-grid-event .fc-time,
  923. .fc-time-grid-event .fc-title {
  924. padding: 0 1px;
  925. }
  926. .fc-time-grid-event .fc-time {
  927. font-size: .85em;
  928. white-space: nowrap;
  929. }
  930. /* short mode, where time and title are on the same line */
  931. .fc-time-grid-event.fc-short .fc-content {
  932. /* don't wrap to second line (now that contents will be inline) */
  933. white-space: nowrap;
  934. }
  935. .fc-time-grid-event.fc-short .fc-time,
  936. .fc-time-grid-event.fc-short .fc-title {
  937. /* put the time and title on the same line */
  938. display: inline-block;
  939. vertical-align: top;
  940. }
  941. .fc-time-grid-event.fc-short .fc-time span {
  942. display: none; /* don't display the full time text... */
  943. }
  944. .fc-time-grid-event.fc-short .fc-time:before {
  945. content: attr(data-start); /* ...instead, display only the start time */
  946. }
  947. .fc-time-grid-event.fc-short .fc-time:after {
  948. content: "\000A0-\000A0"; /* seperate with a dash, wrapped in nbsp's */
  949. }
  950. .fc-time-grid-event.fc-short .fc-title {
  951. font-size: .85em; /* make the title text the same size as the time */
  952. padding: 0; /* undo padding from above */
  953. }
  954. /* resizer (cursor device) */
  955. .fc-time-grid-event.fc-allow-mouse-resize .fc-resizer {
  956. left: 0;
  957. right: 0;
  958. bottom: 0;
  959. height: 8px;
  960. overflow: hidden;
  961. line-height: 8px;
  962. font-size: 11px;
  963. font-family: monospace;
  964. text-align: center;
  965. cursor: s-resize;
  966. }
  967. .fc-time-grid-event.fc-allow-mouse-resize .fc-resizer:after {
  968. content: "=";
  969. }
  970. /* resizer (touch device) */
  971. .fc-time-grid-event.fc-selected .fc-resizer {
  972. /* 10x10 dot */
  973. border-radius: 5px;
  974. border-width: 1px;
  975. width: 8px;
  976. height: 8px;
  977. border-style: solid;
  978. border-color: inherit;
  979. background: #fff;
  980. /* horizontally center */
  981. left: 50%;
  982. margin-left: -5px;
  983. /* center on the bottom edge */
  984. bottom: -5px;
  985. }
  986. /* Now Indicator
  987. --------------------------------------------------------------------------------------------------*/
  988. .fc-time-grid .fc-now-indicator-line {
  989. border-top-width: 1px;
  990. left: 0;
  991. right: 0;
  992. }
  993. /* arrow on axis */
  994. .fc-time-grid .fc-now-indicator-arrow {
  995. margin-top: -5px; /* vertically center on top coordinate */
  996. }
  997. .fc-ltr .fc-time-grid .fc-now-indicator-arrow {
  998. left: 0;
  999. /* triangle pointing right... */
  1000. border-width: 5px 0 5px 6px;
  1001. border-top-color: transparent;
  1002. border-bottom-color: transparent;
  1003. }
  1004. .fc-rtl .fc-time-grid .fc-now-indicator-arrow {
  1005. right: 0;
  1006. /* triangle pointing left... */
  1007. border-width: 5px 6px 5px 0;
  1008. border-top-color: transparent;
  1009. border-bottom-color: transparent;
  1010. }
  1011. /* List View
  1012. --------------------------------------------------------------------------------------------------*/
  1013. /* possibly reusable */
  1014. .fc-event-dot {
  1015. display: inline-block;
  1016. width: 10px;
  1017. height: 10px;
  1018. border-radius: 5px;
  1019. }
  1020. /* view wrapper */
  1021. .fc-rtl .fc-list-view {
  1022. direction: rtl; /* unlike core views, leverage browser RTL */
  1023. }
  1024. .fc-list-view {
  1025. border-width: 1px;
  1026. border-style: solid;
  1027. }
  1028. /* table resets */
  1029. .fc .fc-list-table {
  1030. table-layout: auto; /* for shrinkwrapping cell content */
  1031. }
  1032. .fc-list-table td {
  1033. border-width: 1px 0 0;
  1034. padding: 8px 14px;
  1035. }
  1036. .fc-list-table tr:first-child td {
  1037. border-top-width: 0;
  1038. }
  1039. /* day headings with the list */
  1040. .fc-list-heading {
  1041. border-bottom-width: 1px;
  1042. }
  1043. .fc-list-heading td {
  1044. font-weight: bold;
  1045. }
  1046. .fc-ltr .fc-list-heading-main { float: left; }
  1047. .fc-ltr .fc-list-heading-alt { float: right; }
  1048. .fc-rtl .fc-list-heading-main { float: right; }
  1049. .fc-rtl .fc-list-heading-alt { float: left; }
  1050. /* event list items */
  1051. .fc-list-item.fc-has-url {
  1052. cursor: pointer; /* whole row will be clickable */
  1053. }
  1054. .fc-list-item:hover td {
  1055. background-color: #f5f5f5;
  1056. }
  1057. .fc-list-item-marker,
  1058. .fc-list-item-time {
  1059. white-space: nowrap;
  1060. width: 1px;
  1061. }
  1062. /* make the dot closer to the event title */
  1063. .fc-ltr .fc-list-item-marker { padding-right: 0; }
  1064. .fc-rtl .fc-list-item-marker { padding-left: 0; }
  1065. .fc-list-item-title a {
  1066. /* every event title cell has an <a> tag */
  1067. text-decoration: none;
  1068. color: inherit;
  1069. }
  1070. .fc-list-item-title a[href]:hover {
  1071. /* hover effect only on titles with hrefs */
  1072. text-decoration: underline;
  1073. }
  1074. /* message when no events */
  1075. .fc-list-empty-wrap2 {
  1076. position: absolute;
  1077. top: 0;
  1078. left: 0;
  1079. right: 0;
  1080. bottom: 0;
  1081. }
  1082. .fc-list-empty-wrap1 {
  1083. width: 100%;
  1084. height: 100%;
  1085. display: table;
  1086. }
  1087. .fc-list-empty {
  1088. display: table-cell;
  1089. vertical-align: middle;
  1090. text-align: center;
  1091. }
  1092. .fc-unthemed .fc-list-empty { /* theme will provide own background */
  1093. background-color: #eee;
  1094. }