slims up the position-panel margin, fixes Popup self-awareness issues

This commit is contained in:
Jarrod Flesch
2020-07-01 17:56:42 -04:00
parent 2f60a527da
commit 4e1749c56d
9 changed files with 66 additions and 12 deletions

View File

@@ -42,13 +42,16 @@ const Popup = (props) => {
const { y: buttonYCoord } = buttonRef.current.getBoundingClientRect();
const windowWidth = window.innerWidth;
const distanceToRightEdge = windowWidth - (contentRightEdge + contentWidth);
const distanceToRightEdge = windowWidth - contentRightEdge;
const distanceToLeftEdge = contentRightEdge - contentWidth;
if (distanceToRightEdge <= 0) {
if (horizontalAlign === 'left' && distanceToRightEdge <= 0) {
setForceHorizontalAlign('right');
} else if (distanceToLeftEdge <= 0) {
} else if (horizontalAlign === 'right' && distanceToLeftEdge <= 0) {
setForceHorizontalAlign('left');
} else if (horizontalAlign === 'center' && (distanceToLeftEdge <= contentWidth / 2 || distanceToRightEdge <= contentWidth / 2)) {
if (distanceToRightEdge > distanceToLeftEdge) setForceHorizontalAlign('left');
else setForceHorizontalAlign('right');
} else {
setForceHorizontalAlign(null);
}

View File

@@ -13,7 +13,7 @@ $controls-top-adjustment: base(.1);
}
&__controls {
padding-right: base(1.25);
padding-right: base(.65);
display: flex;
flex-direction: column;
justify-content: center;
@@ -49,9 +49,18 @@ $controls-top-adjustment: base(.1);
text-align: center;
color: $color-gray;
}
@include large-break {
padding-right: base(1);
&__controls {
padding-right: base(.75);
}
}
}
// External scopes
.field-type.flexible {
.position-panel {
&__controls-container {

View File

@@ -94,6 +94,7 @@
.action-panel__controls {
opacity: 1;
visibility: visible;
z-index: $z-nav;
}
}

View File

@@ -13,8 +13,21 @@
background-color: $color-background-gray;
}
&__image {
svg,
img {
max-width: 100%;
}
}
&__label {
margin-top: base(.25);
font-weight: 600;
text-align: center;
white-space: initial;
}
@include mid-break {
width: unset;
}
}

View File

@@ -7,8 +7,8 @@
display: flex;
flex-wrap: wrap;
align-items: center;
min-width: 300px;
max-width: 450px;
min-width: 450px;
max-width: 80vw;
max-height: 300px;
position: relative;
}

View File

@@ -0,0 +1,8 @@
@import '../../../../../scss/styles.scss';
.block-selector {
@include mid-break {
min-width: 80vw;
}
}

View File

@@ -28,7 +28,7 @@
.field-type.repeater {
.field-type.repeater__add-button-wrap {
margin-left: base(3.25);
margin-left: base(2.65);
}
.field-type.repeater__header {

View File

@@ -1,6 +1,10 @@
import React from 'react';
import React, { useState } from 'react';
import { v4 as uuid } from 'uuid';
const DefaultBlockImage = () => {
const [patternID] = useState(`pattern${uuid()}`);
const [imageID] = useState(`image${uuid()}`);
return (
<svg
width="82"
@@ -12,22 +16,22 @@ const DefaultBlockImage = () => {
x="0.713013"
width="80.574"
height="52.7791"
fill="url(#pattern0)"
fill={`url(#${patternID})`}
/>
<defs>
<pattern
id="pattern0"
id={`${patternID}`}
patternContentUnits="objectBoundingBox"
width="1"
height="1"
>
<use
xlinkHref="#image0"
xlinkHref={`#${imageID}`}
transform="scale(0.00387597 0.00591716)"
/>
</pattern>
<image
id="image0"
id={imageID}
width="258"
height="169"
xlinkHref=""