228 lines
5.5 KiB
SCSS
228 lines
5.5 KiB
SCSS
@mixin flat-connector-before($length: 44px) {
|
|
&::before {
|
|
content: '';
|
|
position: absolute;
|
|
top: 48%;
|
|
left: -$length;
|
|
border-top: 2px solid var(--border-color, $border-color);
|
|
width: $length;
|
|
height: 1px;
|
|
}
|
|
}
|
|
|
|
@mixin build-content($border-radius: 30px) {
|
|
display: inline-block;
|
|
padding: 8px 10px 9px;
|
|
width: 100%;
|
|
border: 1px solid var(--border-color, $border-color);
|
|
border-radius: $border-radius;
|
|
background-color: var(--white, $white);
|
|
|
|
&:hover {
|
|
background-color: var(--gray-50, $gray-50);
|
|
border: 1px solid $dropdown-toggle-active-border-color;
|
|
color: var(--gl-text-color, $gl-text-color);
|
|
}
|
|
}
|
|
|
|
@mixin mini-pipeline-graph-color(
|
|
$color-background-default,
|
|
$color-background-hover-focus,
|
|
$color-background-active,
|
|
$color-foreground-default,
|
|
$color-foreground-hover-focus,
|
|
$color-foreground-active
|
|
) {
|
|
background-color: $color-background-default;
|
|
border-color: $color-foreground-default;
|
|
|
|
svg {
|
|
fill: $color-foreground-default;
|
|
}
|
|
|
|
&:hover,
|
|
&:focus {
|
|
background-color: $color-background-hover-focus;
|
|
border-color: $color-foreground-hover-focus;
|
|
|
|
svg {
|
|
fill: $color-foreground-hover-focus;
|
|
}
|
|
}
|
|
|
|
&:active {
|
|
background-color: $color-background-active;
|
|
border-color: $color-foreground-active;
|
|
|
|
svg {
|
|
fill: $color-foreground-active;
|
|
}
|
|
}
|
|
|
|
&:focus {
|
|
box-shadow: 0 0 4px 1px $blue-300;
|
|
}
|
|
}
|
|
|
|
@mixin mini-pipeline-item() {
|
|
border-radius: 100px;
|
|
background-color: var(--white, $white);
|
|
border-width: 1px;
|
|
border-style: solid;
|
|
width: $ci-action-icon-size;
|
|
height: $ci-action-icon-size;
|
|
margin: 0;
|
|
padding: 0;
|
|
position: relative;
|
|
vertical-align: middle;
|
|
|
|
&:hover,
|
|
&:active,
|
|
&:focus {
|
|
outline: none;
|
|
border-width: 2px;
|
|
}
|
|
|
|
// Dropdown button animation in mini pipeline graph
|
|
&.ci-status-icon-success {
|
|
@include mini-pipeline-graph-color(var(--white, $white), $green-100, $green-200, $green-500, $green-600, $green-700);
|
|
}
|
|
|
|
&.ci-status-icon-failed {
|
|
@include mini-pipeline-graph-color(var(--white, $white), $red-100, $red-200, $red-500, $red-600, $red-700);
|
|
}
|
|
|
|
&.ci-status-icon-pending,
|
|
&.ci-status-icon-waiting-for-resource,
|
|
&.ci-status-icon-success-with-warnings {
|
|
@include mini-pipeline-graph-color(var(--white, $white), $orange-50, $orange-100, $orange-500, $orange-600, $orange-700);
|
|
}
|
|
|
|
&.ci-status-icon-running {
|
|
@include mini-pipeline-graph-color(var(--white, $white), $blue-100, $blue-200, $blue-500, $blue-600, $blue-700);
|
|
}
|
|
|
|
&.ci-status-icon-canceled,
|
|
&.ci-status-icon-scheduled,
|
|
&.ci-status-icon-disabled,
|
|
&.ci-status-icon-manual {
|
|
@include mini-pipeline-graph-color(var(--white, $white), $gray-500, $gray-700, $gray-900, $gray-950, $black);
|
|
}
|
|
|
|
&.ci-status-icon-preparing,
|
|
&.ci-status-icon-created,
|
|
&.ci-status-icon-not-found,
|
|
&.ci-status-icon-skipped {
|
|
@include mini-pipeline-graph-color(var(--white, $white), var(--gray-100, $gray-100), var(--gray-200, $gray-200), var(--gray-400, $gray-400), var(--gray-500, $gray-500), var(--gray-600, $gray-600));
|
|
}
|
|
}
|
|
|
|
/**
|
|
Action icons inside dropdowns:
|
|
- mini graph in pipelines table
|
|
- dropdown in big graph
|
|
- mini graph in MR widget pipeline
|
|
- mini graph in Commit widget pipeline
|
|
*/
|
|
@mixin pipeline-graph-dropdown-menu() {
|
|
width: 240px;
|
|
max-width: 240px;
|
|
|
|
// override dropdown.scss
|
|
&.dropdown-menu li button,
|
|
&.dropdown-menu li a.ci-action-icon-container {
|
|
padding: 0;
|
|
text-align: center;
|
|
}
|
|
|
|
.ci-action-icon-container {
|
|
position: absolute;
|
|
right: 8px;
|
|
top: 8px;
|
|
|
|
&.ci-action-icon-wrapper {
|
|
height: $ci-action-dropdown-button-size;
|
|
width: $ci-action-dropdown-button-size;
|
|
border-radius: 50%;
|
|
display: block;
|
|
|
|
&:hover {
|
|
box-shadow: inset 0 0 0 0.0625rem $dropdown-toggle-active-border-color;
|
|
background-color: var(--gray-50, $gray-50);
|
|
}
|
|
|
|
.spinner,
|
|
svg {
|
|
width: $ci-action-dropdown-svg-size;
|
|
height: $ci-action-dropdown-svg-size;
|
|
position: relative;
|
|
top: 1px;
|
|
vertical-align: initial;
|
|
}
|
|
}
|
|
}
|
|
|
|
// SVGs in the commit widget and mr widget
|
|
a.ci-action-icon-container.ci-action-icon-wrapper svg {
|
|
top: 5px;
|
|
}
|
|
|
|
.scrollable-menu {
|
|
padding: 0;
|
|
max-height: 245px;
|
|
overflow: auto;
|
|
}
|
|
|
|
li {
|
|
position: relative;
|
|
|
|
// ensure .mini-pipeline-graph-dropdown-item has hover style when action-icon is hovered
|
|
&:hover > .mini-pipeline-graph-dropdown-item,
|
|
&:hover > .ci-job-component > .mini-pipeline-graph-dropdown-item {
|
|
@extend .mini-pipeline-graph-dropdown-item:hover;
|
|
}
|
|
|
|
// link to the build
|
|
.mini-pipeline-graph-dropdown-item {
|
|
align-items: center;
|
|
clear: both;
|
|
display: flex;
|
|
font-weight: normal;
|
|
line-height: $line-height-base;
|
|
white-space: nowrap;
|
|
|
|
// Match dropdown.scss for all `a` tags
|
|
&.non-details-job-component {
|
|
padding: $gl-padding-8 $gl-btn-horz-padding;
|
|
}
|
|
|
|
.ci-job-name-component {
|
|
align-items: center;
|
|
display: flex;
|
|
flex: 1;
|
|
}
|
|
|
|
.ci-status-icon {
|
|
@include gl-mr-3;
|
|
|
|
position: relative;
|
|
|
|
> svg {
|
|
width: $pipeline-dropdown-status-icon-size;
|
|
height: $pipeline-dropdown-status-icon-size;
|
|
margin: 3px 0;
|
|
position: relative;
|
|
overflow: visible;
|
|
display: block;
|
|
}
|
|
}
|
|
|
|
&:hover,
|
|
&:focus {
|
|
outline: none;
|
|
text-decoration: none;
|
|
background-color: var(--gray-100, $gray-50);
|
|
}
|
|
}
|
|
}
|
|
}
|