Chris@17: /** Chris@17: * @file media_library.theme.css Chris@17: * Chris@17: * @todo Move into the Seven theme when this module is marked as stable. Chris@17: * @see https://www.drupal.org/project/drupal/issues/2980769 Chris@17: */ Chris@17: Chris@18: .media-library-wrapper { Chris@18: margin: -1em; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Reuse or build on vertical tabs styling for the media library menu. Chris@18: * https://www.drupal.org/project/drupal/issues/3023767 Chris@18: */ Chris@18: .media-library-menu { Chris@18: display: block; Chris@18: width: 600px; Chris@18: max-width: 20%; Chris@18: margin: 0; /* LTR */ Chris@18: padding: 0; Chris@18: border-bottom: 1px solid #ccc; Chris@18: background-color: #e6e5e1; Chris@18: line-height: 1; Chris@18: } Chris@18: [dir="rtl"] .media-library-menu { Chris@18: margin: 0; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Use a class instead of the li element. Chris@18: * https://www.drupal.org/project/drupal/issues/3029227 Chris@18: */ Chris@18: .media-library-menu li { Chris@18: display: block; Chris@18: } Chris@18: Chris@18: .media-library-menu__link { Chris@18: position: relative; Chris@18: display: block; Chris@18: box-sizing: border-box; Chris@18: padding: 15px; Chris@18: text-decoration: none; Chris@18: border-bottom: 1px solid #b3b2ad; Chris@18: background-color: #f2f2f0; Chris@18: text-shadow: 0 1px hsla(0, 0%, 100%, 0.6); Chris@18: } Chris@18: Chris@18: .media-library-menu__link:active, Chris@18: .media-library-menu__link:hover, Chris@18: .media-library-menu__link:focus { Chris@18: background: #fcfcfa; Chris@18: text-shadow: none; Chris@18: } Chris@18: Chris@18: .media-library-menu__link:focus, Chris@18: .media-library-menu__link:active { Chris@18: outline: none; Chris@18: } Chris@18: Chris@18: .media-library-menu__link.active { Chris@18: z-index: 1; Chris@18: margin-right: -1px; /* LTR */ Chris@18: color: #000; Chris@18: border-right: 1px solid #fcfcfa; /* LTR */ Chris@18: border-bottom: 1px solid #b3b2ad; Chris@18: background-color: #fff; Chris@18: box-shadow: 0 5px 5px -5px hsla(0, 0%, 0%, 0.3); Chris@18: } Chris@18: [dir="rtl"] .media-library-menu__link.active { Chris@18: margin-right: 0; Chris@18: margin-left: -1px; Chris@18: border-right: 0; Chris@18: border-left: 1px solid #fcfcfa; Chris@18: } Chris@18: Chris@18: .media-library-content { Chris@18: width: 100%; Chris@18: padding: 1em; Chris@18: border-left: 1px solid #b3b2ad; /* LTR */ Chris@18: outline: none; Chris@18: } Chris@18: [dir="rtl"] .media-library-content { Chris@18: border-right: 1px solid #b3b2ad; Chris@18: border-left: 0; Chris@18: } Chris@18: Chris@18: /* Generic media add form styles. */ Chris@18: .media-library-add-form--without-input .form-item { Chris@18: margin: 0 0 1em; Chris@18: } Chris@18: Chris@18: /** Chris@18: * Remove outline from added media container. Chris@18: * Chris@18: * The added media container receives focus after adding new media, but since Chris@18: * it is not an interactive element it does not need an outline. Chris@18: */ Chris@18: .media-library-add-form__added-media { Chris@18: outline: none; Chris@18: } Chris@18: Chris@18: .media-library-add-form__input-wrapper { Chris@18: padding: 16px; Chris@18: border: 1px solid #bfbfbf; Chris@18: border-radius: 2px; Chris@18: background: #fcfcfa; Chris@18: } Chris@18: Chris@18: /* Style the media add upload form. */ Chris@18: .media-library-add-form--upload.media-library-add-form--without-input .form-item-upload { Chris@18: margin-bottom: 0; Chris@18: } Chris@18: Chris@18: .media-library-add-form .file-upload-help { Chris@18: margin: 8px 0 0; Chris@18: } Chris@18: Chris@18: .media-library-add-form__description { Chris@18: margin: 0; Chris@18: } Chris@18: Chris@18: /* Style the media add oEmbed form. */ Chris@18: .media-library-add-form--oembed .media-library-add-form__input-wrapper { Chris@18: display: flex; Chris@18: } Chris@18: Chris@18: @media screen and (max-width: 37.5em) { Chris@18: .media-library-add-form--oembed .media-library-add-form__input-wrapper { Chris@18: display: block; Chris@18: } Chris@18: } Chris@18: Chris@18: .media-library-add-form--oembed.media-library-add-form--without-input .form-item-url { Chris@18: margin-bottom: 0; Chris@18: } Chris@18: Chris@18: .media-library-add-form-oembed-url { Chris@18: width: 100%; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Remove .button when styles are moved to the seven theme in Chris@18: * https://www.drupal.org/project/drupal/issues/2980769 Chris@18: */ Chris@18: .button.media-library-add-form-oembed-submit { Chris@18: align-self: center; Chris@18: } Chris@18: Chris@18: /* Media add form selection styles. */ Chris@18: .media-library-add-form__selected-media { Chris@18: margin-top: 1em; Chris@18: } Chris@18: Chris@18: /* Change to padding to account for the negative margin for flex grid. */ Chris@18: .media-library-add-form__selected-media .details-wrapper { Chris@18: padding: 0 10px 1em 10px; Chris@18: } Chris@18: Chris@18: .media-library-add-form__selected-media .media-library-item .field--name-thumbnail img { Chris@18: height: 100px; Chris@18: } Chris@18: Chris@18: /* Generic media library view styles. */ Chris@18: .media-library-select-all { Chris@18: margin: 10px 0 10px 0; Chris@18: } Chris@18: Chris@18: .media-library-select-all input { Chris@18: margin-right: 10px; Chris@18: } Chris@18: Chris@17: .media-library-views-form__header .form-item { Chris@17: margin-right: 8px; Chris@17: } Chris@17: Chris@17: .media-library-view .form-actions { Chris@17: margin: 0.75em 0; Chris@17: } Chris@17: Chris@17: .media-library-view .media-library-view--form-actions { Chris@17: clear: left; Chris@18: align-self: flex-end; Chris@17: margin: 0.75em 0; Chris@17: } Chris@17: Chris@18: /** Chris@18: * Override the table display of the visually hidden labels. Chris@18: * Chris@18: * The width, height and overflow properties in the styles for the Chris@18: * .visually-hidden class do not work correctly if the element has a table Chris@18: * display. Chris@18: */ Chris@18: .media-library-item label { Chris@18: display: inline-block; Chris@18: } Chris@18: Chris@18: /* Media library widget view styles. */ Chris@18: .media-library-wrapper .media-library-view { Chris@18: position: relative; Chris@18: display: flex; Chris@18: flex-wrap: wrap; Chris@18: justify-content: space-between; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Remove order and reorder the views header and filters via a views Chris@18: * template in https://www.drupal.org/project/drupal/issues/3035994 Chris@18: */ Chris@18: .media-library-wrapper .view-header { Chris@18: align-self: flex-end; Chris@18: order: 2; Chris@18: margin: 8px 0; Chris@18: text-align: right; /* LTR */ Chris@18: } Chris@18: [dir="rtl"] .media-library-wrapper .view-header { Chris@18: text-align: left; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Remove order and reorder the views header and filters via a views Chris@18: * template in https://www.drupal.org/project/drupal/issues/3035994 Chris@18: */ Chris@18: .media-library-wrapper .media-library-view .view-filters { Chris@18: order: 1; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Remove order and reorder the views header and filters via a views Chris@18: * template in https://www.drupal.org/project/drupal/issues/3035994 Chris@18: */ Chris@18: .media-library-wrapper .media-library-view .view-content { Chris@18: flex: 0 0 100%; Chris@18: order: 3; Chris@18: } Chris@18: Chris@18: /** Chris@18: * @todo Remove order and reorder the views header and filters via a views Chris@18: * template in https://www.drupal.org/project/drupal/issues/3035994 Chris@18: */ Chris@18: .media-library-wrapper .media-library-view .pager { Chris@18: order: 4; Chris@18: } Chris@18: Chris@18: .media-library-wrapper .views-display-link { Chris@18: margin: 0; Chris@18: padding-left: 22px; /* LTR */ Chris@18: color: #333; Chris@18: line-height: 16px; Chris@18: } Chris@18: [dir="rtl"] .media-library-wrapper .views-display-link { Chris@18: padding-right: 22px; Chris@18: padding-left: 0; Chris@18: } Chris@18: Chris@18: .media-library-wrapper .views-display-link-widget { Chris@18: margin-right: 15px; Chris@18: background: url(../../../misc/icons/333333/grid.svg) left 0 no-repeat; /* LTR */ Chris@18: } Chris@18: [dir="rtl"] .media-library-wrapper .views-display-link-widget { Chris@18: background-position: right 0; Chris@18: } Chris@18: Chris@18: .media-library-wrapper .views-display-link-widget_table { Chris@18: background: url(../../../misc/icons/333333/table.svg) left 0 no-repeat; /* LTR */ Chris@18: } Chris@18: [dir="rtl"] .media-library-wrapper .views-display-link-widget_table { Chris@18: background-position: right 0; Chris@18: } Chris@18: Chris@18: /* Media library item grid styles. */ Chris@18: .media-library-views-form { Chris@18: margin: 0 -8px; Chris@18: } Chris@18: Chris@18: /** Chris@18: * Fix the negative margin of the grid. Chris@18: * Chris@18: * We need to fix the negative margin of the grid for table based displays and Chris@18: * form elements that should not be part of the grid. Chris@18: * Chris@18: * @todo: Remove when new wrapper is added to apply negative margins in Chris@18: * https://www.drupal.org/project/drupal/issues/3038489 Chris@18: */ Chris@18: .media-library-views-form__header, Chris@18: .media-library-select-all, Chris@18: .media-library-views-form > .views-table { Chris@18: margin: 0 8px; Chris@18: } Chris@18: Chris@18: .media-library-item--grid { Chris@18: justify-content: center; Chris@18: box-sizing: border-box; Chris@18: width: 50%; Chris@18: padding: 8px; Chris@18: vertical-align: top; Chris@18: background: #fff; Chris@18: } Chris@18: Chris@18: .media-library-item--grid:before { Chris@18: position: absolute; Chris@18: top: 7px; Chris@18: left: 7px; Chris@18: width: calc(100% - 16px); Chris@18: height: calc(100% - 16px); Chris@18: content: ""; Chris@18: transition: border-color 0.2s, color 0.2s, background 0.2s; Chris@18: border: 1px solid #dbdbdb; Chris@18: } Chris@18: Chris@18: /* The selected items in the add form should be shown a bit smaller. */ Chris@18: .media-library-add-form__selected-media .media-library-item--small { Chris@18: width: 33.3%; Chris@18: } Chris@18: Chris@18: @media screen and (min-width: 45em) { Chris@18: .media-library-item--grid { Chris@18: width: 33.3%; Chris@18: } Chris@18: Chris@18: /* Change the width for the modal and widget since there is less space. */ Chris@18: .media-library-widget-modal .media-library-item--grid, Chris@18: .media-library-selection .media-library-item--grid { Chris@18: width: 50%; Chris@18: } Chris@18: Chris@18: /* The selected items in the add form should be shown a bit smaller. */ Chris@18: .media-library-add-form__selected-media .media-library-item--small { Chris@18: width: 25%; Chris@18: } Chris@18: } Chris@18: Chris@18: @media screen and (min-width: 60em) { Chris@18: .media-library-item--grid { Chris@18: width: 25%; Chris@18: } Chris@18: Chris@18: /* Change the width for the modal and widget since there is less space. */ Chris@18: .media-library-widget-modal .media-library-item--grid, Chris@18: .media-library-selection .media-library-item--grid { Chris@18: width: 33.3%; Chris@18: } Chris@18: Chris@18: /* The selected items in the add form should be shown a bit smaller. */ Chris@18: .media-library-add-form__selected-media .media-library-item--small { Chris@18: width: 16.6%; Chris@18: } Chris@18: } Chris@18: Chris@18: @media screen and (min-width: 77em) { Chris@18: .media-library-item--grid { Chris@18: width: 16.6%; Chris@18: } Chris@18: Chris@18: /* Change the width for the modal and widget since there is less space. */ Chris@18: .media-library-widget-modal .media-library-item--grid, Chris@18: .media-library-selection .media-library-item--grid { Chris@18: width: 25%; Chris@18: } Chris@18: Chris@18: /* The selected items in the add form should be shown a bit smaller. */ Chris@18: .media-library-add-form__selected-media .media-library-item--small { Chris@18: width: 16.6%; Chris@18: } Chris@18: } Chris@18: Chris@18: .media-library-item--grid .field--name-thumbnail { Chris@17: overflow: hidden; Chris@17: text-align: center; Chris@18: background-color: #ebebeb; Chris@17: } Chris@17: Chris@18: .media-library-item--grid .field--name-thumbnail img { Chris@17: height: 180px; Chris@17: object-fit: contain; Chris@17: object-position: center center; Chris@17: } Chris@17: Chris@18: .media-library-item--grid.is-hover:before, Chris@18: .media-library-item--grid.checked:before, Chris@18: .media-library-item--grid.is-focus:before { Chris@18: top: 5px; Chris@18: left: 5px; Chris@18: border-width: 3px; Chris@17: border-color: #40b6ff; Chris@17: border-radius: 3px; Chris@17: } Chris@17: Chris@18: .media-library-item--grid.checked:before { Chris@17: border-color: #0076c0; Chris@17: } Chris@17: Chris@18: .media-library-item--grid .js-click-to-select-checkbox input { Chris@17: width: 30px; Chris@17: height: 30px; Chris@17: } Chris@17: Chris@18: .media-library-item--grid .js-click-to-select-checkbox .form-item { Chris@17: margin: 0; Chris@17: } Chris@17: Chris@18: /* Media library item table styles. */ Chris@18: .media-library-item--table img { Chris@18: max-width: 100px; Chris@18: height: auto; Chris@18: } Chris@18: Chris@18: /* Media library entity view display styles. */ Chris@17: .media-library-item__preview { Chris@17: padding-bottom: 34px; Chris@17: } Chris@17: Chris@17: .media-library-item__status { Chris@18: padding: 5px 10px; Chris@17: color: #e4e4e4; Chris@18: background: #666; Chris@18: font-size: 12px; Chris@17: font-style: italic; Chris@17: } Chris@17: Chris@17: .media-library-item__attributes { Chris@17: position: absolute; Chris@17: bottom: 0; Chris@17: display: block; Chris@18: overflow: hidden; Chris@17: max-width: calc(100% - 10px); Chris@17: max-height: calc(100% - 50px); Chris@18: padding: 5px; Chris@17: background: white; Chris@17: } Chris@17: Chris@17: .media-library-item__name { Chris@17: font-size: 14px; Chris@17: } Chris@17: Chris@17: .media-library-item__name a { Chris@17: display: block; Chris@18: overflow: hidden; Chris@17: margin: 2px; Chris@17: white-space: nowrap; Chris@18: text-decoration: underline; Chris@17: text-overflow: ellipsis; Chris@17: } Chris@17: Chris@17: .media-library-item__attributes:hover .media-library-item__name a, Chris@17: .media-library-item__name a:focus, Chris@18: .media-library-item--grid.is-focus .media-library-item__name a, Chris@18: .media-library-item--grid.checked .media-library-item__name a { Chris@17: white-space: normal; Chris@17: } Chris@17: Chris@17: .media-library-item__name a:focus { Chris@18: margin: 0; Chris@17: border: 2px solid; Chris@17: } Chris@17: Chris@17: .media-library-item__type { Chris@18: color: #696969; Chris@17: font-size: 12px; Chris@17: } Chris@17: Chris@17: .media-library-item--disabled { Chris@17: opacity: 0.5; Chris@17: } Chris@17: Chris@18: /* Media library widget styles. */ Chris@17: .media-library-widget { Chris@17: position: relative; Chris@17: } Chris@17: Chris@18: /** Chris@18: * @todo Change to .media-library-open-button when styles are moved to the Chris@18: * seven theme in https://www.drupal.org/project/drupal/issues/2980769 Chris@18: */ Chris@18: .button.media-library-open-button { Chris@18: margin-bottom: 1em; Chris@18: margin-left: 0; /* LTR */ Chris@18: } Chris@18: [dir="rtl"] .button.media-library-open-button { Chris@18: margin-right: 0; Chris@18: margin-left: 1em; Chris@18: } Chris@18: Chris@17: .media-library-widget__toggle-weight { Chris@17: position: absolute; Chris@18: top: 5px; Chris@17: right: 5px; Chris@17: } Chris@17: Chris@18: /* Add negative margin for flex grid. */ Chris@18: .media-library-selection { Chris@18: margin: 1em -8px; Chris@18: } Chris@18: Chris@18: /* Media library widget weight field styles. */ Chris@18: .media-library-item--grid .form-item { Chris@17: margin: 0.75em; Chris@17: } Chris@17: Chris@18: /* Media library widget remove button styles. */ Chris@18: .media-library-item__remove, Chris@18: .media-library-item__remove:hover, Chris@18: .media-library-item__remove:focus, Chris@18: .media-library-item__remove.button, Chris@18: .media-library-item__remove.button:first-child, Chris@18: .media-library-item__remove.button:disabled, Chris@18: .media-library-item__remove.button:disabled:active, Chris@18: .media-library-item__remove.button:hover, Chris@18: .media-library-item__remove.button:focus { Chris@17: position: absolute; Chris@17: z-index: 1; Chris@18: top: 10px; Chris@18: right: 10px; Chris@17: width: 24px; Chris@17: height: 24px; Chris@17: margin: 5px; Chris@17: padding: 0; Chris@18: transition: 0.2s border-color; Chris@18: color: transparent; Chris@17: border: 2px solid #ccc; Chris@17: border-radius: 20px; Chris@18: background: url("../../../misc/icons/787878/ex.svg") #fff center no-repeat; Chris@18: background-size: 16px 16px; Chris@17: text-shadow: none; Chris@17: } Chris@17: Chris@18: .media-library-item__remove:hover, Chris@18: .media-library-item__remove:focus, Chris@18: .media-library-item__remove.button:hover, Chris@18: .media-library-item__remove.button:focus, Chris@18: .media-library-item__remove.button:disabled:active { Chris@17: border-color: #40b6ff; Chris@17: } Chris@17: Chris@18: /** Chris@18: * Style the added media item container. Chris@18: * Chris@18: * The added media container receives screen reader focus since it is has the Chris@18: * role 'listitem'. Since it is not an interactive element, it does not need Chris@18: * an outline. Chris@18: */ Chris@18: .media-library-add-form__media { Chris@18: position: relative; Chris@17: display: flex; Chris@18: padding: 1em 0; Chris@18: border-bottom: 1px solid #c0c0c0; Chris@18: outline: none; Chris@17: } Chris@17: Chris@18: /* Do not show the top padding for the first item. */ Chris@18: .media-library-add-form__media:first-child { Chris@18: padding-top: 0; Chris@17: } Chris@17: Chris@18: /** Chris@18: * Change the position of the remove button for the first item. Chris@18: * Chris@18: * The first item doesn't have a top padding, change the location of the remove Chris@18: * button as well. Chris@18: */ Chris@18: .media-library-add-form__media:first-child .media-library-add-form__remove-button[type="submit"] { Chris@18: top: 5px; Chris@18: } Chris@18: Chris@18: /* Do not show the bottom border and padding for the last item. */ Chris@18: .media-library-add-form__media:last-child { Chris@18: padding-bottom: 0; Chris@18: border-bottom: 0; Chris@17: } Chris@17: Chris@17: /* @todo Remove in https://www.drupal.org/project/drupal/issues/2987921 */ Chris@18: .media-library-add-form__source-field .file, Chris@18: .media-library-add-form__source-field .button, Chris@18: .media-library-add-form__source-field .image-preview, Chris@18: .media-library-add-form__source-field .form-type-managed-file > label, Chris@18: .media-library-add-form__source-field .file-size { Chris@17: display: none; Chris@17: } Chris@17: Chris@18: .media-library-add-form__preview { Chris@17: display: flex; Chris@17: align-items: center; Chris@17: justify-content: center; Chris@18: width: 220px; Chris@18: margin-right: 20px; /* LTR */ Chris@18: background: #ebebeb; Chris@18: } Chris@18: [dir="rtl"] .media-library-add-form__preview { Chris@18: margin-right: 0; Chris@18: margin-left: 20px; Chris@17: } Chris@17: Chris@18: /** Chris@18: * @todo Remove [type="submit"] when styles are moved to the seven theme in Chris@18: * https://www.drupal.org/project/drupal/issues/2980769 Chris@18: */ Chris@18: .media-library-add-form__remove-button[type="submit"] { Chris@18: position: absolute; Chris@18: top: 25px; Chris@18: right: 6px; /* LTR */ Chris@18: width: auto; Chris@18: margin: 0; Chris@18: padding: 2px 20px 2px 2px; /* LTR */ Chris@18: text-transform: lowercase; Chris@18: color: transparent; Chris@18: border: 0; Chris@18: border-radius: 0; Chris@18: background: transparent url(../../../misc/icons/787878/ex.svg) right 2px no-repeat; /* LTR */ Chris@18: font-weight: normal; Chris@18: line-height: 16px; Chris@18: } Chris@18: [dir="rtl"] .media-library-add-form__remove-button[type="submit"] { Chris@18: right: auto; Chris@18: left: 13px; Chris@18: padding: 2px 2px 2px 20px; Chris@18: background-position: left 2px; Chris@18: } Chris@18: Chris@18: .media-library-add-form__remove-button:focus, Chris@18: .media-library-add-form__remove-button.button:disabled, Chris@18: .media-library-add-form__remove-button.button:disabled:active, Chris@18: .media-library-add-form__remove-button.button:focus { Chris@18: color: #787878; Chris@18: border: 0; Chris@18: background: transparent url(../../../misc/icons/787878/ex.svg) right 2px no-repeat; /* LTR */ Chris@18: } Chris@18: [dir="rtl"] .media-library-add-form__remove-button:focus, Chris@18: [dir="rtl"] .media-library-add-form__remove-button.button:disabled, Chris@18: [dir="rtl"] .media-library-add-form__remove-button.button:disabled:active, Chris@18: [dir="rtl"] .media-library-add-form__remove-button.button:focus { Chris@18: background-position: left 2px; Chris@18: } Chris@18: Chris@18: .media-library-add-form__remove-button:hover, Chris@18: .media-library-add-form__remove-button.button:hover { Chris@18: color: #e00; Chris@18: border: 0; Chris@18: background: transparent url(../../../misc/icons/ee0000/ex.svg) right 2px no-repeat; /* LTR */ Chris@18: box-shadow: none; Chris@18: } Chris@18: [dir="rtl"] .media-library-add-form__remove-button:hover, Chris@18: [dir="rtl"] .media-library-add-form__remove-button.button:hover { Chris@18: background-position: left 2px; Chris@17: } Chris@17: Chris@17: /* @todo Remove or re-work in https://www.drupal.org/node/2985168 */ Chris@17: .media-library-widget .media-library-item__name a, Chris@18: .media-library-view--widget .media-library-item__name a, Chris@18: .media-library-add-form__selected-media .media-library-item__name a { Chris@18: text-decoration: none; Chris@17: color: black; Chris@17: }