taiga-front/app/styles/modules/backlog/taskboard-table.scss

239 lines
5.0 KiB
SCSS

//Table basic shared vars
$column-width: 300px;
$column-flex: 1;
$column-shrink: 0;
$column-margin: 0 10px 0 0;
@mixin fold {
.taskboard-task {
background: none;
border: 0;
margin: 0;
min-height: 0;
.taskboard-task-inner {
padding: .1rem;
}
.taskboard-tagline,
.taskboard-text {
display: none;
}
.avatar {
height: 35px;
width: 35px;
}
.icon {
display: none;
}
}
&.task-column,
.task-column {
align-content: flex-start;
display: flex;
flex-direction: column;
flex-flow: row wrap;
}
.avatar-task-link {
display: block;
}
.avatar-assigned-to {
display: none;
}
}
.taskboard-table {
display: flex;
flex-direction: column;
height: 100%;
overflow: hidden;
width: 100%;
.taskboard-task {
&.readonly {
cursor: auto;
}
&.gu-mirror {
opacity: 1;
.avatar-task-link {
display: none;
}
}
}
}
.taskboard-table-header {
margin-bottom: .5rem;
min-height: 40px;
position: relative;
width: 100%;
.taskboard-table-inner {
display: flex;
overflow: hidden;
position: absolute;
}
.task-colum-name {
@include font-size(medium);
align-items: center;
background: $mass-white;
border-top: 3px solid $gray-light;
color: $gray;
display: flex;
flex-basis: $column-width;
flex-grow: $column-flex;
flex-shrink: $column-shrink;
justify-content: space-between;
margin: $column-margin;
max-width: $column-width;
padding: .5rem 1rem;
position: relative;
text-transform: uppercase;
width: $column-width;
&:last-child {
margin-right: 0;
}
&.column-fold {
align-items: center;
justify-content: center;
padding: .3rem 0;
span {
display: none;
}
.hfold,
.hunfold {
margin: 0;
}
}
}
tg-svg {
display: block;
margin-right: .3rem;
svg {
@include font-size(medium);
fill: $gray-light;
transition: fill .2s linear;
}
&:hover {
cursor: pointer;
svg {
fill: $primary;
}
}
&.hfold,
&.hunfold {
display: inline-block;
svg {
transform: rotate(90deg);
}
}
}
}
.taskboard-table-body {
height: 100%;
overflow: auto;
width: 100%;
.task-column {
flex-basis: $column-width;
flex-grow: $column-flex;
flex-shrink: $column-shrink;
margin: $column-margin;
max-width: $column-width;
width: $column-width;
&:last-child {
margin-right: 0;
}
}
.row-fold {
@include fold;
}
.column-fold {
@include fold;
.taskboard-task {
max-width: 40px;
width: 40px;
}
}
.task-row {
display: flex;
margin-bottom: .5rem;
min-height: 10rem;
width: 100%;
&.blocked {
.taskboard-userstory-box {
background: rgba($red, .6);
}
.taskboard-userstory-box svg,
.taskboard-userstory-box svg:hover,
.points-value,
.points-value:hover {
color: $white;
transition: color .3s linear;
}
.taskboard-tasks-box {
background: rgba($red, .1);
}
}
&.row-fold {
min-height: 0;
.us-title {
@include ellipsis(100%);
}
.points-value,
.icon-add,
.icon-bulk {
display: none;
}
}
}
.taskboard-userstory-box {
padding: .5rem .5rem .5rem 1.5rem;
}
.avatar-task-link {
display: none;
}
.avatar-assigned-to {
display: block;
}
.icon {
transition: fill .2s linear;
}
tg-svg {
cursor: pointer;
display: block;
position: absolute;
right: .5rem;
top: .7rem;
&:hover {
svg {
fill: $primary;
}
}
&.add-action {
right: 2rem;
}
&.fold-action {
left: 0;
right: inherit;
top: 1rem;
}
}
}
.taskboard-userstory-box {
position: relative;
.us-title {
@include font-size(normal);
@include font-type(text);
margin-bottom: 0;
margin-right: 3rem;
}
.points-value {
@include font-size(small);
color: $gray-light;
span {
margin-right: .1rem;
}
}
}