613 lines
15 KiB
CSS
613 lines
15 KiB
CSS
/**
|
|
* Views styling
|
|
*/
|
|
|
|
@import "../base/variables.pcss.css";
|
|
|
|
/* @group Forms */
|
|
|
|
/**
|
|
* Claro positions the summary absolutely, but does not have a way to ignore
|
|
* details without a summary so we make one up.
|
|
*
|
|
* @todo Neither a fieldset without legend nor a details without summary is
|
|
* valid HTML markup in any way. Refactor Views UI to not produce such invalid
|
|
* markup.
|
|
*/
|
|
details.fieldset-no-legend {
|
|
padding-top: 0;
|
|
}
|
|
|
|
/**
|
|
* Being extra safe here and scoping this to the add view wizard form (where
|
|
* a layout problem occurs for the Display format details if we don't fix its
|
|
* padding), but it's probably safe to just let it apply everywhere.
|
|
*/
|
|
.views-ui-dialog input.form-submit,
|
|
.views-admin a.button,
|
|
.views-ui-dialog a.button {
|
|
margin-top: 0;
|
|
margin-right: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
[dir="rtl"] .views-ui-dialog input.form-submit,
|
|
[dir="rtl"] .views-admin a.button,
|
|
[dir="rtl"] .views-ui-dialog a.button {
|
|
margin-right: 1em;
|
|
margin-left: 0;
|
|
}
|
|
[dir="rtl"] .views-ui-dialog input.form-submit:first-child,
|
|
[dir="rtl"] .views-admin a.button:first-child,
|
|
[dir="rtl"] .views-ui-dialog a.button:first-child {
|
|
margin-right: 0;
|
|
}
|
|
|
|
.views-ui-dialog .form--flex {
|
|
display: flex;
|
|
overflow: hidden;
|
|
flex-wrap: wrap;
|
|
}
|
|
|
|
.views-ui-dialog .form-item {
|
|
margin-top: var(--space-m);
|
|
margin-bottom: var(--space-m);
|
|
}
|
|
.views-ui-dialog .form-type--boolean {
|
|
margin-right: 0;
|
|
margin-left: 0;
|
|
}
|
|
.views-ui-dialog .form-type--boolean .form-boolean {
|
|
top: 0;
|
|
float: none;
|
|
margin: 0 0.25rem 0 0; /* LTR */
|
|
transform: none;
|
|
}
|
|
[dir="rtl"] .views-ui-dialog .form-type--boolean .form-boolean {
|
|
margin-right: 0;
|
|
margin-left: 0.25rem;
|
|
}
|
|
|
|
.views-ui-dialog .form-boolean-group .form-type--boolean {
|
|
margin-top: 0.4em;
|
|
margin-bottom: 0.4em;
|
|
}
|
|
|
|
.views-ui-dialog .form-item:first-of-type.description {
|
|
margin: 0 0 var(--space-l) 0;
|
|
padding-bottom: var(--space-s);
|
|
border-bottom: 0.0625rem solid var(--color-lightgray);
|
|
font-weight: bold;
|
|
}
|
|
|
|
/* So "remove" link appears next to the checkbox. */
|
|
.views-ui-dialog .draggable .form-type--checkbox {
|
|
display: inline-block;
|
|
margin: 0 0.25rem;
|
|
}
|
|
|
|
.views-ui-dialog .form-element {
|
|
min-height: calc(((var(--input-padding-vertical--small) + var(--input-border-size)) * 2) + var(--input-line-height--small)); /* iOS. */
|
|
padding: var(--input-padding-vertical--small) var(--input-padding-horizontal--small);
|
|
font-size: var(--input-font-size--small);
|
|
line-height: var(--input-line-height--small);
|
|
}
|
|
.views-ui-dialog .form-element--type-select {
|
|
padding-right: calc((var(--space-m) * 2) + var(--input-border-size) * 2);
|
|
background-position: 100% 56%;
|
|
}
|
|
/**
|
|
* Elements must communicate width to table rendering.
|
|
* @todo revisit in https://drupal.org/node/3135457
|
|
*/
|
|
.views-ui-dialog td .form-element {
|
|
width: auto;
|
|
}
|
|
|
|
/* @group Dependent options */
|
|
|
|
/* This is necessary to supercede the Claro .form-item
|
|
* reset declaration that sets the margin to zero.
|
|
*/
|
|
.form-item-options-expose-required,
|
|
.form-item-options-expose-label,
|
|
.form-item-options-expose-description {
|
|
margin-left: 1.5em; /* LTR */
|
|
}
|
|
[dir="rtl"] .form-item-options-expose-required,
|
|
[dir="rtl"] .form-item-options-expose-label,
|
|
[dir="rtl"] .form-item-options-expose-description {
|
|
margin-right: 1.5em;
|
|
margin-left: 0;
|
|
}
|
|
|
|
.views-admin-dependent .form-item .form-item,
|
|
.views-admin-dependent .form-type-checkboxes,
|
|
.views-admin-dependent .form-type-radios,
|
|
.views-admin-dependent .form-item .form-item,
|
|
.form-item-options-expose-required,
|
|
.form-item-options-expose-label,
|
|
.form-item-options-expose-description {
|
|
margin-top: 6px;
|
|
margin-bottom: 6px;
|
|
}
|
|
|
|
.views-admin-dependent .form-type-radio,
|
|
.views-admin-dependent .form-radios .form-item {
|
|
margin-top: 2px;
|
|
margin-bottom: 2px;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Lists */
|
|
|
|
.views-admin .item-list ul {
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
.views-admin .links li {
|
|
padding-right: 0; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-admin .links li {
|
|
padding-left: 0;
|
|
}
|
|
|
|
.views-admin .button .links li {
|
|
padding-right: 12px; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-admin .button .links li {
|
|
padding-left: 12px;
|
|
}
|
|
|
|
.views-display-top__extra-actions-wrapper {
|
|
margin: calc(var(--space-xs) / 2) var(--space-xs) var(--space-xs);
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Tables */
|
|
|
|
.views-ui-rearrange-filter-form td,
|
|
.views-ui-rearrange-filter-form th {
|
|
vertical-align: top;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Attachment details */
|
|
|
|
#edit-display-settings-title {
|
|
color: #008bcb;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Attachment details tabs
|
|
*
|
|
* The tabs that switch between sections
|
|
*
|
|
* @todo this group contains lots of duplicates from core styles because Claro
|
|
* has its custom markup for views tabs. Some of these could be removed after
|
|
* https://www.drupal.org/node/3051605 has been solved.
|
|
*/
|
|
|
|
.views-tabs {
|
|
display: flex;
|
|
overflow: visible;
|
|
flex-wrap: wrap;
|
|
margin: 0 var(--space-l) 0 0; /* LTR */
|
|
padding: 0;
|
|
list-style: none;
|
|
text-align: left; /* LTR */
|
|
border-bottom: 0 none;
|
|
}
|
|
[dir="rtl"] .views-tabs {
|
|
margin-right: 0;
|
|
margin-left: var(--space-l);
|
|
text-align: right;
|
|
}
|
|
.views-tabs .views-display-deleted-link {
|
|
text-decoration: line-through;
|
|
}
|
|
.views-tabs li,
|
|
.views-tabs li.is-active {
|
|
width: auto;
|
|
padding: 0;
|
|
border: 0;
|
|
background: transparent;
|
|
}
|
|
.views-tabs li.add ul.action-list li {
|
|
margin: 0;
|
|
}
|
|
.views-tabs li {
|
|
margin: 0 5px 5px 6px; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-tabs li {
|
|
margin-right: 6px;
|
|
margin-left: 5px;
|
|
}
|
|
.views-tabs li + li {
|
|
border-top: 0;
|
|
}
|
|
.views-tabs li:hover {
|
|
padding-left: 0; /* LTR */
|
|
border: 0;
|
|
}
|
|
[dir="rtl"] .views-tabs li:hover {
|
|
padding-right: 0;
|
|
}
|
|
.views-tabs a {
|
|
display: inline-block;
|
|
padding: 10px;
|
|
border: var(--input-border-size) solid #cbcbcb;
|
|
border-radius: 7px;
|
|
font-size: small;
|
|
line-height: 1.3333;
|
|
}
|
|
|
|
/* Display a red border if the display doesn't validate. */
|
|
.views-tabs li.is-active a.is-active.error,
|
|
.views-tabs .error {
|
|
padding: 8px;
|
|
border: 2px solid #ed541d;
|
|
}
|
|
.views-tabs a:focus {
|
|
outline: none;
|
|
}
|
|
.views-tabs li a {
|
|
text-decoration: none;
|
|
background-color: #fff;
|
|
}
|
|
.views-tabs li a:hover,
|
|
.views-tabs li.is-active a,
|
|
.views-tabs li.is-active a.is-active {
|
|
color: #fff;
|
|
background-color: #555;
|
|
}
|
|
.views-tabs .add {
|
|
position: relative;
|
|
}
|
|
.views-tabs .add a {
|
|
padding: 9px 13px 9px 9px;
|
|
color: var(--color-davysgray);
|
|
border: none;
|
|
border-radius: var(--base-border-radius);
|
|
background-color: transparent;
|
|
font-size: var(--font-size-base);
|
|
font-weight: 700;
|
|
}
|
|
.views-tabs .add a::before {
|
|
display: inline-block;
|
|
width: 1em;
|
|
height: calc(1em - (var(--input-border-size) * 2));
|
|
content: "";
|
|
/* Copy of icon from .action-link--icon-plus */
|
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' stroke-width='2' stroke='%23545560'%3E%3Cpath d='m3 8h10'/%3E%3Cpath d='m8 3v10'/%3E%3C/svg%3E");
|
|
}
|
|
.views-tabs .add a:hover {
|
|
color: var(--color-absolutezero-hover);
|
|
background-color: var(--color-bgblue-hover);
|
|
}
|
|
.views-tabs .add a:hover::before {
|
|
/* Copy of icon from .action-link--icon-plus:hover */
|
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' stroke-width='2' stroke='%230036b1'%3E%3Cpath d='m3 8h10'/%3E%3Cpath d='m8 3v10'/%3E%3C/svg%3E");
|
|
}
|
|
.views-tabs .add a:focus {
|
|
background-color: var(--color-bgblue-active);
|
|
box-shadow: 0 0 0 3px #26a769;
|
|
}
|
|
.views-tabs .add.open a {
|
|
color: var(--color-white);
|
|
background-color: var(--color-absolutezero);
|
|
}
|
|
.views-tabs .add.open a::before {
|
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' stroke-width='2' stroke='%23FFFFFF'%3E%3Cpath d='m3 8h10'/%3E%3Cpath d='m8 3v10'/%3E%3C/svg%3E");
|
|
}
|
|
/* Hide core icon, added via JS that isn't accessible via theme function. */
|
|
.views-tabs .add .icon.add {
|
|
display: none;
|
|
}
|
|
.views-tabs .action-list {
|
|
position: absolute;
|
|
z-index: 50;
|
|
top: 38px;
|
|
left: -2px; /* LTR */
|
|
margin: 0;
|
|
box-shadow: var(--details-box-shadow);
|
|
}
|
|
[dir="rtl"] .views-tabs .action-list {
|
|
right: 0;
|
|
left: auto;
|
|
}
|
|
.views-tabs .action-list li {
|
|
display: block;
|
|
}
|
|
.views-tabs .action-list li {
|
|
border-width: 0 1px;
|
|
border-style: solid;
|
|
border-color: #cbcbcb;
|
|
background-color: #fff;
|
|
}
|
|
.views-tabs .action-list li:first-child {
|
|
border-width: 1px 1px 0;
|
|
border-radius: 0 var(--base-border-radius) 0 0; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-tabs .action-list li:first-child {
|
|
border-radius: 0 0 0 var(--base-border-radius);
|
|
}
|
|
.views-tabs .action-list li:last-child,
|
|
.views-displays .action-list li:last-child {
|
|
padding-bottom: 0.4rem;
|
|
border-width: 0 1px 1px;
|
|
border-bottom-right-radius: var(--button-border-radius-size);
|
|
border-bottom-left-radius: var(--button-border-radius-size);
|
|
}
|
|
.views-tabs__action-list-button {
|
|
width: 100%;
|
|
margin: 0;
|
|
padding: var(--space-s) var(--space-l);
|
|
text-align: left;
|
|
border: medium none;
|
|
border-radius: 0;
|
|
background: none repeat scroll 0 0 transparent;
|
|
font-weight: normal;
|
|
}
|
|
/* RTL required for precedence over core's styles. */
|
|
[dir="rtl"] .views-tabs__action-list-button {
|
|
margin: 0;
|
|
}
|
|
.views-tabs__action-list-button.button:hover,
|
|
.views-tabs__action-list-button.button:focus {
|
|
color: var(--color-white);
|
|
background-color: var(--color-absolutezero);
|
|
}
|
|
/* Remove outline provided by default styling */
|
|
.views-tabs__action-list-button:not(:focus) {
|
|
box-shadow: none;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Attachment buckets
|
|
*
|
|
* These are the individual "buckets," or boxes, inside the display settings area
|
|
*/
|
|
|
|
.views-ui-display-tab-bucket .links {
|
|
padding: 2px 6px 4px;
|
|
}
|
|
|
|
.views-ui-display-tab-bucket .links li + li {
|
|
margin-left: 3px; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-ui-display-tab-bucket .links li + li {
|
|
margin-right: 3px;
|
|
margin-left: 0;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Rearrange filter criteria */
|
|
|
|
.views-ui-rearrange-filter-form tr {
|
|
border-bottom: 0;
|
|
}
|
|
.views-ui-rearrange-filter-form tr:first-of-type {
|
|
border-top: 0.0625rem solid var(--color-lightgray);
|
|
}
|
|
.views-ui-rearrange-filter-form tr:not(.draggable):hover {
|
|
background: inherit;
|
|
}
|
|
.views-ui-rearrange-filter-form .action-links {
|
|
float: left;
|
|
margin: 0 0 1em;
|
|
padding: 0;
|
|
}
|
|
.views-ui-rearrange-filter-form .tabledrag-toggle-weight-wrapper {
|
|
float: right;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form .tabledrag-cell {
|
|
position: relative;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form [id^="views-row"] {
|
|
border: medium none;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form tr td:last-child {
|
|
border-right: medium none; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-ui-rearrange-filter-form tr td:last-child {
|
|
border-right: initial;
|
|
border-left: medium none;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form .filter-group-operator-row {
|
|
border-right: 1px solid transparent !important;
|
|
border-left: 1px solid transparent !important;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form tr.drag td {
|
|
background-color: #fe7 !important;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form tr.drag-previous td {
|
|
background-color: #ffb !important;
|
|
}
|
|
|
|
.views-ui-rearrange-filter-form .draggable td {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Live preview elements */
|
|
|
|
.views-query-info pre {
|
|
margin-top: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
/* @group Query info table */
|
|
|
|
.views-query-info table {
|
|
border-radius: 7px;
|
|
-webkit-border-horizontal-spacing: 1px;
|
|
-webkit-border-vertical-spacing: 1px;
|
|
}
|
|
|
|
.views-query-info table tr td:last-child {
|
|
/* Fixes a Claro style that bleeds down into this table unnecessarily */
|
|
border-right: 0 none; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-query-info table tr td:last-child {
|
|
border-right: initial;
|
|
border-left: 0 none;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @end */
|
|
|
|
/* @group Add view */
|
|
|
|
.form-item-page-create,
|
|
.form-item-block-create {
|
|
margin-top: 13px;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Modal dialog box
|
|
*
|
|
* The contents of the popup dialog on the views edit form.
|
|
*/
|
|
|
|
.filterable-option .form-item.form-type-checkbox {
|
|
padding-top: 4px;
|
|
/* This selector is aggressive because Claro's reset for .form-items is aggressive. */
|
|
padding-bottom: 4px;
|
|
padding-left: 4px; /* LTR */
|
|
}
|
|
[dir="rtl"] .filterable-option .form-item.form-type-checkbox {
|
|
padding-right: 4px;
|
|
padding-left: 8px;
|
|
}
|
|
|
|
/* @end */
|
|
|
|
/* @group Grouping styles
|
|
*
|
|
* For grouping related form elements together, mainly used with exposed
|
|
* filters.
|
|
*/
|
|
.views-config-group-region {
|
|
display: table;
|
|
margin: var(--space-l) 0;
|
|
border: 0.0625rem solid var(--color-lightgray);
|
|
border-collapse: collapse;
|
|
}
|
|
.views-config-group-region .views-group-box {
|
|
position: relative;
|
|
display: table-cell;
|
|
padding: var(--space-l);
|
|
border: 0.0625rem solid var(--color-lightgray);
|
|
}
|
|
.views-config-group-region .views-group-box--operator {
|
|
padding-right: var(--space-xl);
|
|
border-right-width: 0;
|
|
}
|
|
[dir="rtl"] .views-config-group-region .views-group-box--operator {
|
|
padding-right: var(--space-l);
|
|
padding-left: var(--space-xl);
|
|
border-right-width: 0.0625rem;
|
|
border-left-width: 0;
|
|
}
|
|
.views-config-group-region .views-group-box--value {
|
|
padding: 0;
|
|
border-left-width: 0; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-config-group-region .views-group-box--value {
|
|
border-right-width: 0;
|
|
border-left-width: 0.0625rem;
|
|
}
|
|
.views-config-group-region .views-group-box--value > .form-item {
|
|
margin-right: var(--space-l); /* LTR */
|
|
margin-left: var(--space-xl); /* LTR */
|
|
}
|
|
[dir="rtl"] .views-config-group-region .views-group-box--value > .form-item {
|
|
margin-right: var(--space-xl); /* LTR */
|
|
margin-left: var(--space-l); /* LTR */
|
|
}
|
|
.views-config-group-region .views-group-box--value > .form-item::before {
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
width: 0.0625rem;
|
|
height: 100%;
|
|
content: "";
|
|
border-left: 0.0625rem solid var(--color-lightgray);
|
|
}
|
|
[dir="rtl"] .views-config-group-region .views-group-box--value > .form-item::before {
|
|
right: 0;
|
|
}
|
|
.views-config-group-region .views-group-box--value > .form-item::after {
|
|
position: absolute;
|
|
z-index: 1;
|
|
top: 3.8rem;
|
|
left: calc(0 - var(--space-m)); /* LTR */
|
|
padding: 0 0.3rem 0.3rem 0.4rem; /* LTR */
|
|
content: ">";
|
|
color: var(--color-oldsilver);
|
|
border: 0.0625rem solid var(--color-lightgray);
|
|
background: #fff;
|
|
font-size: var(--font-size-h1);
|
|
font-weight: bold;
|
|
line-height: var(--font-size-h1);
|
|
}
|
|
|
|
[dir="rtl"] .views-config-group-region .views-group-box--value > .form-item::after {
|
|
right: calc(0 - var(--space-m));
|
|
left: auto;
|
|
padding-right: 0.4rem;
|
|
padding-left: 0.3rem;
|
|
}
|
|
|
|
@media all and (-ms-high-contrast: active), (-ms-high-contrast: none) {
|
|
/**
|
|
* Remove borders from IE11 filter config in IE11, as it does not fully support
|
|
* the CSS needed to size and position them properly. This results in a
|
|
* slightly different presentation for IE11, but one that users are accustomed
|
|
* to with the Seven theme.
|
|
*/
|
|
.views-config-group-region .views-group-box--value > .form-item::before,
|
|
.views-config-group-region .views-group-box--value > .form-item::after {
|
|
content: "";
|
|
border: none;
|
|
}
|
|
.views-config-group-region,
|
|
.views-config-group-region .views-group-box {
|
|
border: none;
|
|
}
|
|
|
|
/**
|
|
* IE11 has trouble correctly using `justify-content: space-between` when a
|
|
* flex item has the `.visually-hidden` class. This addresses the issue and
|
|
* the end result is the extra action button remains in it's own column on
|
|
* wrap, which matches the experience when using the Seven theme.
|
|
*/
|
|
.views-display-top {
|
|
flex-wrap: nowrap;
|
|
justify-content: flex-start;
|
|
}
|
|
.views-display-top__extra-actions-wrapper {
|
|
margin-left: auto; /* LTR */
|
|
}
|
|
[dir="rtl"] .views-display-top__extra-actions-wrapper {
|
|
margin-right: auto;
|
|
margin-left: calc(var(--space-xs) / 2);
|
|
}
|
|
}
|