OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/app/assets/stylesheets/timelines.css

562 lines
14 KiB

//-- copyright
// OpenProject is a project management system.
//
// Copyright (C) 2012-2013 the OpenProject Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License version 3.
//
// See doc/COPYRIGHT.rdoc for more details.
//++
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ General and initialization │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
.select2-choices {
width: 500px;
}
li.select2-result.select2-visible-selected-parent {
display:list-item;
}
.timeline {
clear: both;
overflow: auto;
border: 1px solid black;
}
.tl-under-construction {
background: url("../../../assets/loadingAnimation.gif") no-repeat center;
border: 1px solid #ddd;
height: 48px;
}
.tl-under-construction * {
visibility: hidden;
}
.tl-invisible {
visibility: hidden;
}
.tl-hidden-info {
display: none;
}
#timeline_select {
margin-top: 2px;
margin-bottom: 8px;
}
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ Timeline forms. │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
#specialForm {
display: block;
padding-bottom: 5px;
}
#content .timelines_edit_form .tl-form-overflow {
overflow: visible;
}
.tl-space-both, .tl-space-after {
margin-right: 1em;
}
.tl-space-both, .tl-space-before {
margin-left: 1em;
}
#content .timelines_edit_form fieldset.collapsible.header_collapsible {
margin-bottom: 1em;
}
.select2-choices {
width: 500px;
}
#s2id_reporting_reported_project_status_id,
#s2id_reporting_reporting_to_project_id,
#s2id_timeline_select,
#s2id_timeline_options_columns,
#s2id_timeline_options_initial_outline_expansion,
#s2id_timeline_options_zoom_factor,
#s2id_project_association_select_project_b_id,
#s2id_timeline_options_grouping_one_sort,
#s2id_timeline_options_project_sort,
#s2id_timeline_options_grouping_two_sort {
width: 250px;
}
#project-search-container .select2-container {
margin-left: 0px;
}
.select2-container {
vertical-align: middle;
margin-left: 5px;
}
#s2id_timeline_options_compare_to_relative_unit,
#s2id_timeline_options_planning_element_time_relative_one_unit,
#s2id_timeline_options_planning_element_time_relative_two_unit {
margin-right: 1em;
}
.timelines_edit_form .calendar-trigger {
margin-right: 1em;
}
.timelines_edit_form input {
margin-left: 1em;
}
#timeline_options_compare_to_relative {
padding-right: 5px;
text-align: right;
width: 40px;
}
#content .tabular label {
float: none;
display: inline-block;
width: 250px;
padding-right: 5px;
vertical-align: middle;
}
#content .tabular input {
min-height: 22px;
}
#content .tabular .select2-input {
min-height: auto;
}
#content .tabular .select2-container {
vertical-align: middle;
}
#content .tabular .twoBlocks {
width: 500px;
}
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ Timeline toolbar & icons. │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
.tl-toolbar {
float: right;
margin: 10px;
}
.tl-toolbar .tl-toolbar-container {
float: left;
margin-left: 6px;
}
/* IE9 interprets this as baseline from inherited css, although it must
not be applied in anything that is not display:table-cell */
.tl-toolbar-container * {
vertical-align: bottom;
}
.tl-icon-postponed {
cursor: default;
background: url("../assets/bullet_red.png") no-repeat center;
}
.tl-icon-preponed {
cursor: default;
background: url("../assets/bullet_green.png") no-repeat center;
}
.tl-icon-added {
cursor: default;
background: url("../assets/added.png") no-repeat center;
display: inline;
width: 16px;
background-position: 2px 2px;
}
.tl-icon-deleted {
cursor: default;
background: url("../assets/deleted.png") no-repeat center;
display: inline;
width: 16px;
background-position: 2px 2px;
}
.tl-icon-changed {
cursor: default;
background: url("../assets/arrow_left_right.png") no-repeat center;
display: inline;
width: 16px;
background-position: 2px 2px;
}
.tl-icon-calendar {
cursor: default;
background: url("../assets/calendar.png") no-repeat center;
display: inline;
width: 16px;
}
.tl-icon-zoomin {
background: url("../../../assets/zoom_in.png") no-repeat center;
}
.tl-icon-zoomout {
background: url("../../../assets/zoom_out.png") no-repeat center;
}
.tl-icon-outline {
background: url("../assets/outline.png") no-repeat center;
}
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ Timeline tree │ *
* ├───────────────────────────────────────────────────────────────────┤ *
* │ I don't like the #content either, but ChiliProject decided it │ *
* │ would be a great idea to define a high-specificity rule for table │ *
* │ headers. │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
a.tl-discreet-link, input.tl-discreet-link {
color: #4b4b4b;
font-weight: normal;
}
a.tl-discreet-link:hover, input.icon:hover {
color: #008BD0;
text-decoration: underline;
}
#content .timeline table {
border: 0;
padding: 0;
margin: 0;
border-collapse: collapse;
border-spacing: 0;
}
#content .timeline table { page-break-inside:auto; }
#content .timeline tr { page-break-inside:avoid; page-break-after:auto }
#content .timeline thead { display:table-header-group }
#content .timeline tfoot { display:table-footer-group }
#content .timeline table td,
#content .timeline table th {
margin: 0;
padding-bottom: 0;
padding-left: 6px;
padding-right: 6px;
padding-top: 0;
border-bottom: 0;
border-left: 1px solid black;
border-right: 0;
border-top: 0;
white-space: nowrap;
vertical-align: middle;
}
.timeline thead {
}
#content .timeline table th {
color: black;
vertical-align: bottom;
font-weight: bold;
border-bottom: 1px solid black;
}
.timelines-attributes th {
width: 20%;
}
.timelines-attributes td {
width: 80%;
}
.tl-historical {
line-height: 8px;
text-decoration: line-through;
white-space: nowrap;
}
.tl-current {
line-height: 18px;
padding-bottom: 8px;
}
.tl-postponed {
color: red;
}
.tl-preponed {
color: green;
}
.tl-expanded > a {
background: url("../assets/arrow_expanded.png") no-repeat center;
}
.tl-collapsed > a {
background: url("../assets/arrow_collapsed.png") no-repeat center;
}
.tl-expanded > a, .tl-collapsed > a {
text-indent: -999em;
display: block;
height: 16px;
width: 16px;
position: relative;
left: -16px;
float: left;
}
.tl-expanded > span, .tl-collapsed > span {
padding-right: 0px;
position: relative;
left: -16px;
}
#content table td.tl-indent-0 { padding-left: 16px; }
#content table td.tl-indent-1 { padding-left: 28px; }
#content table td.tl-indent-2 { padding-left: 40px; }
#content table td.tl-indent-3 { padding-left: 52px; }
#content table td.tl-indent-4 { padding-left: 64px; }
#content table td.tl-indent-5 { padding-left: 76px; }
#content table td.tl-indent-6 { padding-left: 88px; }
#content table td.tl-indent-7 { padding-left: 100px; }
.tl-left-main {
border-right: 1px solid black;
line-height: 20px;
}
.tl-column {
left: 100px;
}
#content .tl-word-ellipsis {
overflow:hidden;
text-overflow:ellipsis;
display: inline-block;
}
#content table th.tl-first-column, #content table td.tl-first-column {
text-align: left;
border-left: 0;
}
#content .tl-left-main table td {
padding-top: 8px;
padding-bottom: 1px;
vertical-align: middle;
}
#content table tr.tl-project-row td {
border-top: 1px solid black;
padding-top: 6px;
padding-bottom: 6px;
}
#content table tr.tl-first-row td {
padding-top: 6px;
}
#content table tr.tl-last-row td {
padding-bottom: 12px;
}
#content table tr.tl-project-row td {
border-top: 1px solid black;
padding-top: 6px;
padding-bottom: 6px;
}
#content table td.tl-grouping {
padding-left: 4px;
font-size: 125%;
line-height: 20px;
color: #000000; /* #e20074; <-- magenta */
font-weight: bold;
background-color: #dddddd;
border-bottom: 1px solid black;
border-top: 1px solid black;
border-left: 0;
}
a:hover.tl-project, a.tl-project, .tl-project {
font-weight: bold;
}
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ Div floating layout │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
.tl-left {
float: left;
}
.tl-right {
float: right;
}
.tl-decoration {
/* height: 48px; */
}
.tl-chart {
overflow-y: hidden;
overflow-x: scroll;
}
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ Tooltip │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
.tl-tooltip {
display: none;
position: absolute;
min-width: 20px;
padding: 5px;
z-index: 1000;
filter: alpha(opacity=90);
-khtml-opacity: 0.9;
-moz-opacity: 0.9;
opacity: 0.9;
}
.tl-tooltip.fade.in {
filter: alpha(opacity=90);
-khtml-opacity: 0.9;
-moz-opacity: 0.9;
opacity: 0.9;
}
.tl-tooltip.above .tl-tooltip-arrow {
bottom: 0;
left: 16px;
margin-left: -5px;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-top: 5px solid #000000;
}
.tl-tooltip.left .tl-tooltip-arrow {
top: 50%;
right: 0;
margin-top: -5px;
border-top: 5px solid transparent;
border-bottom: 5px solid transparent;
border-left: 5px solid #000000;
}
.tl-tooltip.below .tl-tooltip-arrow {
top: 0;
left: 50%;
margin-left: -5px;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid #000000;
}
.tl-tooltip.right .tl-tooltip-arrow {
top: 50%;
left: 0;
margin-top: -5px;
border-top: 5px solid transparent;
border-bottom: 5px solid transparent;
border-right: 5px solid #000000;
}
.tl-tooltip-inner {
padding: 3px 8px;
background-color: #000000;
color: #ffffff;
text-align: left;
max-width: 200px;
text-decoration: none;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
}
.tl-tooltip-arrow {
position: absolute;
width: 0;
height: 0;
}
/* ╭───────────────────────────────────────────────────────────────────╮ *
* │ Printing │ *
* ╰───────────────────────────────────────────────────────────────────╯ */
@media print {
.tl-historical {
text-decoration:line-through;
}
#content table {
max-width: 900px;
}
#content .tl-word-ellipsis {
overflow:hidden;
text-wrap: ellipsis;
max-width: 250px !important;
display: inline-block;
}
#content .action_menu_main,
#content .tl-toolbar-container,
#content .flash,
#content .tl-chart,
#content .tl-scrollcontainer,
#content form {
display: none;
}
.timeline {
overflow: visible;
}
#content h2 {
border: none;
}
#content .tl-left,
#content .tl-left table {
/*width: 100%;*/
}
#content .tl-left table {
border-left: 0;
border-right: 0;
}
/* #content .timeline table th */
#content .timeline tr {
border-bottom: 1px dashed gray;
}
#content .timeline thead {
border-top: 0;
border-bottom: 1px solid black;
}
#content .tl-project-row .tl-responsible { font-weight: bold; }
.tl-invisible { display: 0; }
#content .timeline,
#content .tl-left-main {
border: 0;
}
}
/* Icons for activity view */
dt.timelines\2F planning-element {
background-image: url(../assets/new_planning_element.png);
}
.ui-dialog { overflow: visible; }
#ui-dialog-closer {
background-image: url("../assets/modal_close.png");
cursor: pointer;
height: 33px;
position: absolute;
right: -15px;
top: -15px;
width: 33px;
z-index: 5000;
}
#history .journal {
background: none;
}