kanbanworkflowstimelinescrumrubyroadmapproject-planningproject-managementopenprojectangularissue-trackerifcgantt-chartganttbug-trackerboardsbcf
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.
562 lines
14 KiB
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;
|
|
}
|
|
|