artabro/wire/modules/Inputfield/InputfieldImage/InputfieldImage.scss
2024-08-27 11:35:37 +02:00

966 lines
17 KiB
SCSS

$activeColor: #3eb998;
$deleteColor: #e83561;
$errorColor: #FC3A3F;
$gridMargin: 0 0.6em 0.6em 0;
$itemPadding: 0.4em;
$focusPointCircleSize: 40px;
.InputfieldImage {
.InputfieldHeader {
.InputfieldImageListToggle {
// toggles between grid, left and list mode
float: right;
padding-right: 0.75em;
position: relative;
&--active {
opacity: 0.5;
}
&:first-child {
// offset from far right side
padding-right: 1em;
}
}
.InputfieldImageSizeSlider {
float: right;
width: 100px;
position: relative;
top: 8px;
right: 1em;
.ui-slider-handle {
outline: none;
}
}
}
&.InputfieldFileEmpty,
&.InputfieldStateCollapsed {
.InputfieldImageListToggle,
.InputfieldImageSizeSlider {
// prevents display of toggles and slider when there are no images visible
display: none;
}
}
}
// error listing
.InputfieldImageErrors {
padding-left: 0;
margin-left: 0;
li {
margin-bottom: .5em;
margin-top: 0;
color: white;
background-color: $errorColor;
padding: .3em .5em;
}
}
// The <ul> element containing li.gridImage items and .InputfieldImageEdit
.gridImages {
list-style: none;
padding-left: 0;
position: relative;
margin: 0;
margin-right: -.6em;
display: block;
list-style: none;
}
.gridImage .gridImage__overflow, // grid view(s)
.InputfieldImageEditAll .gridImage .gridImage__overflow img, // list view
.InputfieldImageEdit__image { // clicked image in editor in grid view
// the following creates a checkerboard pattern (for seeing transparency)
background-color: #fefefe;
background-image: linear-gradient(45deg, #cbcbcb 25%, transparent 25%, transparent 75%, #cbcbcb 75%, #cbcbcb), linear-gradient(45deg, #cbcbcb 25%, transparent 25%, transparent 75%, #cbcbcb 75%, #cbcbcb);
background-size: 16px 16px;
background-position: 0 0, 8px 8px;
}
// An individual image grid item
.gridImage {
list-style: none;
position: relative;
display: inline-block;
@at-root li#{&} {
// overwrite .content li
display: inline-block;
margin: $gridMargin;
}
box-shadow: 0 1px 3px rgba(black, 0.2);
border-radius: 2px;
background: #fff;
padding: $itemPadding;
vertical-align: top;
border: 1px dashed transparent; // to have the placeholder item the same size
&__overflow {
width: 100%;
height: 100%;
overflow: hidden;
position: relative;
& > img {
position: absolute;
top: 50%;
left: 50%;
//transition: transform ease .3s;
-ms-transform: translate3d(-50%, -50%, 0);
transform: translate3d(-50%, -50%, 0);
}
}
&.gridImagePlaceholder {
.gridImage__overflow {
background: #fff;
}
}
&.ui-sortable-placeholder {
display: inline-block;
border-radius: 2px;
border: 1px dashed #ccc;
padding: $itemPadding;
visibility: visible !important;
vertical-align: top;
background-color: transparent;
box-shadow: none;
&::after {
//replacement for image
content: " ";
display: block;
}
}
&__hover {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
padding: $itemPadding;
}
&__inner {
position: relative;
width: 100%;
height: 100%;
.gridImage:hover & {
background: rgba(#3eb998, .7);
}
}
&__resize {
position: absolute;
display: block;
height: 100%;
width: 100%;
line-height: 130px;
text-align: center;
color: white;
font-size: 1.3em;
cursor: move;
text-shadow: 0px 0px 7px rgba(#3eb998, .7);
&.pw-resizing {
text-shadow: none;
background: rgba(0,0,0,0.7);
}
}
&__progress {
/* Reset the default appearance */
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
/* Get rid of default border in Firefox. */
border: none;
color: $activeColor;
width: 100%;
height: 10px;
background: transparent;
position: absolute;
bottom: 0;
left: 0;
&::-webkit-progress-bar {
background-color: inherit;
}
&[value]::-webkit-progress-value {
background-color: $activeColor;
}
&[value]::-moz-progress-bar {
background-color: $activeColor;
}
&[value='-1'] {
background-color: $deleteColor;
}
}
// &__trash {
&__btn {
// position: absolute;
position: relative;
float: left;
background: white;
padding: .2em .6em;
color: #aaa;
z-index: 2;
cursor: pointer;
@at-root .gridImage #{&} {
display: none;
}
&--single {
display: block !important;
position: static;
}
& > input {
display: none;
}
.gridImage:hover & {
display: block;
}
@at-root .gridImage:hover #{&}:hover {
// overwrite a:hover
display: block;
color: $deleteColor;
background-color: white;
}
}
&__edit {
// The "Edit" link
position: absolute;
display: block;
height: 100%;
width: 100%;
line-height: 130px;
text-align: center;
color: white !important;
font-size: 1.3em;
cursor: move;
text-shadow: 0px 0px 7px rgba(#3eb998, .7);
span {
cursor: pointer;
}
display: none;
.gridImage:hover & {
display: block;
}
&:hover {
color: white;
}
}
&__tooltip {
// tooltip that appears above a hovered .gridImage
pointer-events: none;
position: absolute;
bottom: 100%;
padding: 20px;
-webkit-filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.1));
filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.1));
left: 50%;
//transform: translate(-50%, 0) perspective(1px) scale(1.01);
transform: translate(-50%, 0);
margin-bottom: 12px;
background: #fff;
z-index: 110;
box-shadow: 0 0 1px rgba(black, 0.25);
opacity: 0;
transition: opacity .2s 02;
.gridImage:hover & {
display: block;
opacity: 1;
transition: opacity .2s 1s;
}
.InputfieldImageSorting & {
display: none !important;
}
input {
pointer-events: none;
}
table {
margin: 0;
border-spacing: 10px 0;
border-collapse: separate;
th {
color: black;
font-weight: bold;
text-align: right;
}
th, td {
border: none !important;
background: white !important;
}
}
&:after {
top: 100%;
left: 50%;
border: solid transparent;
content: " ";
height: 0;
width: 0;
position: absolute;
pointer-events: none;
border-color: rgba(#fff, 0);
border-top-color: #fff;
border-width: 10px;
margin-left: -10px;
}
}
&.gridImageEditing {
// highlights the current image being edited
.gridImage__inner {
background: rgba($activeColor, .5);
}
}
&--active {
background-color: $activeColor;
& .gridImage__inner {
background: rgba($activeColor, .5);
}
& .gridImage__btn {
background-color: $activeColor;
color: white;
&:hover {
background-color: $activeColor;
}
}
&:hover .gridImage__btn:hover {
background-color: $activeColor;
}
}
&--delete {
// gridImage item marked for deletion
background-color: $deleteColor;
@at-root .InputfieldImageEditSingle.gridImage--delete {
background-color: transparent;
.InputfieldImageEdit__inner {
outline: 3px solid $deleteColor;
}
}
& .gridImage__trash {
background-color: $deleteColor;
color: white;
display: block;
&:hover {
background-color: $deleteColor;
}
}
&:hover .gridImage__edit {
display: none;
}
&:hover .gridImage__trash:hover {
background-color: $deleteColor;
color: white;
}
&:hover .gridImage__inner {
background: rgba($deleteColor, 0.3);
}
}
}
// A type of item that appears in a ul.gridImages but is not itself a .gridImage.
// It contains the image enlargement, file, edit buttons, and description/tags fields.
.InputfieldImageEdit {
position: relative;
display: none;
&--active,
&Single {
display: block;
}
&__core {
// when both description and custom fields are present, this prevents them from having no margin between them
margin-bottom: 0.5em;
}
&__inner {
position: relative;
display: flex;
flex-flow: row;
margin: 1em .6em 1em 0;
-webkit-filter: drop-shadow(0 1px 3px rgba(black, 0.2));
filter: drop-shadow(0 1px 3px rgba(black, 0.2));
background-color: white;
}
&__close {
cursor: pointer;
position: absolute;
font-size: 1.4em;
right: .5em;
top: 0;
color: #ccc !important;
text-decoration: none !important;
.InputfieldFileSingle & {
display: none;
}
}
&__trash-single {
cursor: pointer;
position: absolute;
font-size: 1.4em;
right: 0;
top: 0;
color: #aaa !important;
text-decoration: none !important;
&:hover {
color: $deleteColor;
}
}
&__arrow {
// arrow that points up to the item being edited
bottom: 100%;
content: " ";
height: 0;
width: 0;
position: absolute;
pointer-events: none;
border: .5em solid rgba(white, 0);
border-bottom-color: white;
transform: translate(-50%, 0);
}
&__imagewrapper {
display: inline-block;
display: flex;
vertical-align: top;
// align-items: center;
justify-content: space-around;
width: 300px;
border-right: 1px solid #eee;
min-height: 1em;
padding: 20px;
& > div {
// Fix for Firefox not respecting aspect ratio on images
width: 100%;
position: relative;
}
.detail {
text-align: center;
margin-top: 2px;
}
.detail-upload {
display: block;
opacity: 0;
}
.detail-focus {
display: none;
}
&:hover .detail-upload {
opacity: 0.7;
}
& > div.focusWrap .detail-upload {
display: none;
}
& > div.focusWrap .detail-focus {
display: block;
opacity: 0.7;
}
}
&__replace img {
// dragging new img on top of old one
opacity: 0.5;
}
&__edit {
display: inline-block;
vertical-align: top;
min-height: 100%;
padding: 20px;
flex-grow: 1;
.InputfieldFileDescription,
.InputfieldFileTags {
input {
width: 100%;
}
}
}
&__image {
position: relative;
margin: 0 auto;
height: auto;
cursor: zoom-in;
max-width: 100%;
}
&__name {
font-weight: bold;
display: inline-block;
margin-right: .5em !important;
/* These are technically the same, but use both */
overflow-wrap: break-word;
word-wrap: break-word;
-ms-word-break: break-all;
/* This is the dangerous one in WebKit, as it breaks things wherever */
word-break: break-all;
/* Instead use this non-standard one: */
word-break: break-word;
/* Adds a hyphen where the word breaks, if supported (No Blink) */
-ms-hyphens: auto;
-moz-hyphens: auto;
-webkit-hyphens: auto;
hyphens: auto;
cursor: pointer;
}
&__info {
font-size: .9em;
color: #ccc;
white-space: nowrap;
}
&__buttons {
margin: 1em 0 0.5em 0;
button {
margin-bottom: 0.5em;
a, a:hover {
text-decoration: none;
}
}
}
.InputfieldFileDescription + .InputfieldFileTags {
margin-top: 0.5em;
}
}
.gridImage__overflow .focusArea,
.InputfieldImageEdit .focusArea {
display: none;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
color: #fff;
cursor: default;
&.focusActive {
display: block;
overflow: hidden;
}
.focusCircle {
cursor: move;
width: $focusPointCircleSize;
height: $focusPointCircleSize;
margin: ($focusPointCircleSize * -1 / 2 + 0px) !important;
// border: 3px solid #fff;
// background-color: rgba(255,255,255,0.3);
border: 3px solid #EB1D61;
border-radius: 50%;
background-color: rgba(255, 255, 255, 0.6);
background-image: url(); // 4x4 px magenta
background-position: 15px 15px;
background-repeat: no-repeat;
}
}
.InputfieldImage .ImageData {
// element in a .gridImage item that contains the details and editable content
display: none;
}
.InputfieldImageValidExtensions {
margin-left: 1em;
}
.InputfieldImageUpload {
position: relative;
margin: 1em 0 0;
& .AjaxUploadDropHere {
display: none;
position: absolute;
top: 0;
right: 0;
opacity: 0.75;
cursor: pointer;
.ie-no-drop & {
display: none;
visibility: hidden;
}
}
.InputfieldImageRefresh {
margin-bottom: 0;
}
}
.AdminThemeUikit .InputfieldImageValidExtensions {
position: relative;
top: -15px;
}
// Narrow mode applies when width of Inputfield is under 500px
.InputfieldImageNarrow {
.InputfieldHeader .InputfieldImageSizeSlider {
width: 50px;
}
.InputfieldImageEdit {
// the image editor becomes stacked when narrow mode is active
&__inner {
display: block;
padding-top: 0.5em;
}
&__imagewrapper {
display: block;
width: 100%;
padding-bottom: 0;
}
&__edit {
width: 100%;
padding-top: 0;
.InputfieldImageEdit__buttons,
.InputfieldImageEdit__info {
display: block;
text-align: center;
}
}
&__name {
margin: 0;
display: block;
text-align: center;
}
}
.InputfieldImageUpload {
.AjaxUploadDropHere {
display: none !important;
}
}
}
.InputfieldFileSingle .gridImages .gridImage img,
.InputfieldRenderValueMode .gridImages .gridImage img {
cursor: zoom-in;
}
/*****************************************************************************************
* The "Edit All" mode is the "list" mode where edit inputs are showing for all images
* This is the opposite of the grid mode, but we use all the same elements from .gridImage
*
*/
.InputfieldImageEditAll {
.gridImage {
display: block;
width: 100%;
// clearfix
&:before,
&:after {
content: "";
display: table;
border-collapse: collapse;
}
&:after {
clear: both;
}
&__overflow {
position: relative;
z-index: 2;
top: 0;
left: 0;
float: left;
background: none; // initial
display: block;
height: auto !important;
width: 23%;
overflow: visible;
cursor: move;
padding: 10px;
padding-right: 0;
& > img {
display: block;
position: static !important;
top: 0;
left: 0;
transition: none;
-ms-transform: none;
transform: none;
width: 100%;
max-width: 100% !important;
height: initial !important;
cursor: move;
}
& > .focusArea {
position: absolute;
top: 10px; // to match padding of __overflow
left: 10px;
}
}
.ImageData {
position: relative;
float: left;
display: block;
width: 77%;
padding-left: 20px;
padding-right: 10px;
z-index: 3;
.InputfieldFileDescription {
margin-bottom: 0.5em;
}
.InputfieldImageEdit__name {
margin-bottom: 0;
margin-top: 1em;
position: relative;
z-index: 100;
cursor: pointer;
}
.InputfieldFileSort {
display: none;
}
input {
position: relative;
z-index: 4;
}
}
&.gridImagePlaceholder {
.gridImage__overflow {
background: #fff;
}
}
&__inner {
.gridImage__edit {
display: none;
}
}
&:hover .gridImage__inner {
background: none; // initial;
}
.InputfieldImageEdit {
&__core {
input {
width: 100%;
}
}
}
&__resize {
margin-top: 10px;
color: $deleteColor;
text-shadow: none;
}
&__progress {
bottom: 10px;
margin-left: 10px;
}
&.gridImageUploading {
.gridImage__overflow {
margin-bottom: 10px;
}
.gridImage__inner {
overflow: hidden;
}
}
&__btn {
z-index: 5;
display: block !important;
top: 0;
right: 0;
float: right;
background: transparent;
}
&__edit {
display: none;
}
&__tooltip {
display: none !important;
}
&--delete {
background-color: $deleteColor;
border-bottom: 8px solid transparent;
height: 45px;
overflow: hidden;
.gridImage__overflow {
display: none;
}
.ImageData {
padding-left: 10px;
width: 100%;
}
.ImageData .InputfieldImageEdit__name {
color: rgba(255, 255, 255, 0.6);
margin-top: 3px;
text-decoration: line-through;
}
.InputfieldImageEdit__info {
color: rgba(255, 255, 255, 0.4);
}
.InputfieldImageEdit__buttons,
.InputfieldImageEdit__core,
.InputfieldImageEdit__additional {
display: none;
}
.gridImage__btn {
color: white;
}
&:hover .gridImage__btn:hover {
color: white;
background-color: $deleteColor;
}
&:hover .gridImage__hover,
.gridImage__hover {
background: rgba(255, 255, 255, 0);
}
} // &--delete
} // .gridImage
// Edit All narrow mode, we stack the image and editor features on top of each other
&.InputfieldImageNarrow {
.gridImage {
&__overflow {
display: block;
width: 100% !important;
height: auto !important;
padding: 0;
img {
width: 100% !important;
height: auto !important;
}
> .focusArea { // #728
top: 0;
left: 0;
}
}
.ImageData {
padding: 0;
width: 100% !important;
display: block;
.InputfieldImageEdit__name {
margin-top: 0.5em;
}
.InputfieldImageEdit__name,
.InputfieldImageEdit__buttons,
.InputfieldImageEdit__info {
text-align: center;
display: block;
}
}
} // .gridImage
} // .InputfieldImageNarrow
} // .InputfieldImageEditAll
.InputfieldFileActionNote {
display: none;
white-space: nowrap;
}
.InputfieldImageList {
// for .svg images
.gridImage__overflow.landscape {
img { height: 100%; }
}
.gridImage__overflow.portrait {
img { width: 100%; }
}
}
.InputfieldImageList[data-ragged="1"] {
// for .svg images
.gridImage__overflow.portrait {
img { width: auto; height: 100%; }
}
}
/* todo: 3.0.190 improves touch support but needs further testing
.gridImage__edit { display:block !important; }
.gridImage__edit span { display:none; }
.gridImage__edit:hover span { display:inline; }
*/