adds styles for block search popup

This commit is contained in:
Jarrod Flesch
2020-06-26 09:38:29 -04:00
parent 7265d63403
commit a4d0608f56
13 changed files with 223 additions and 68 deletions

View File

@@ -0,0 +1,9 @@
<svg width="82" height="53" viewBox="0 0 82 53" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="0.713013" width="80.574" height="52.7791" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="scale(0.00387597 0.00591716)"/>
</pattern>
<image id="image0" width="258" height="169" xlink:href=""/>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.4 KiB

View File

@@ -1,22 +1,21 @@
import React from 'react';
import PropTypes from 'prop-types';
import SearchIcon from '../../../../../graphics/Search';
import './index.scss';
const baseClass = 'block-search';
const BlockSearch = (props) => {
const {} = props;
const BlockSearch = () => {
return (
<div className={baseClass}>
Search...
<input
className={`${baseClass}__input`}
placeholder="Search for a block"
/>
<SearchIcon />
</div>
);
};
BlockSearch.defaultProps = {};
BlockSearch.propTypes = {};
export default BlockSearch;

View File

@@ -1 +1,20 @@
@import '../../../../../../scss/styles';
@import '../../../shared.scss';
$icon-width: base(1);
$icon-margin: base(.25);
.block-search {
position: relative;
&__input {
@include formInput;
padding-right: calc(#{$icon-width} + #{$icon-margin} * 2);
}
.search {
position: absolute;
right: 0;
width: $icon-width;
margin: 0 $icon-margin;
}
}

View File

@@ -0,0 +1,47 @@
import React from 'react';
import PropTypes from 'prop-types';
import FallbackBlockImage from '../../../../../graphics/FallbackBlockImage';
import './index.scss';
const baseClass = 'block-selection';
const BlockSelection = (props) => {
const { addRow, addRowIndex, block } = props;
const { labels, slug, blockImage } = block;
return (
<div
className={baseClass}
role="button"
tabIndex={0}
onClick={() => addRow(addRowIndex, slug)}
>
<div className={`${baseClass}__image`}>
<FallbackBlockImage />
</div>
<div className={`${baseClass}__label`}>{labels.singular}</div>
</div>
);
};
BlockSelection.defaultProps = {
addRow: undefined,
addRowIndex: 0,
};
BlockSelection.propTypes = {
addRow: PropTypes.func,
addRowIndex: PropTypes.number,
block: PropTypes.shape({
labels: PropTypes.shape({
singular: PropTypes.string,
}),
slug: PropTypes.string,
blockImage: PropTypes.string,
}).isRequired,
};
export default BlockSelection;

View File

@@ -0,0 +1,26 @@
@import '../../../../../../scss/styles';
.block-selection {
display: inline-flex;
flex-direction: column;
flex-wrap: wrap;
width: 33%;
padding: base(.75) base(.5);
cursor: pointer;
&:hover {
background-color: $color-background-gray;
}
&__image {
svg {
width: 100%;
height: auto;
}
}
&__label {
margin-top: base(.25);
font-weight: 600;
}
}

View File

@@ -1,7 +1,7 @@
import React from 'react';
import PropTypes from 'prop-types';
import SelectableBlock from '../SelectableBlock';
import BlockSelection from '../BlockSelection';
import './index.scss';
@@ -14,14 +14,13 @@ const BlocksContainer = (props) => {
<div className={baseClass}>
{blocks?.map((block, index) => {
return (
<SelectableBlock
<BlockSelection
key={index}
block={block}
{...remainingProps}
/>
);
})}
Blocks to choose from...
</div>
);
};

View File

@@ -1 +1,6 @@
@import '../../../../../../scss/styles';
.blocks-container {
width: 100%;
margin-top: base(1);
}

View File

@@ -1,32 +0,0 @@
import React from 'react';
import PropTypes from 'prop-types';
const baseClass = 'selectable-block';
const SelectableBlock = (props) => {
const { addRow, addRowIndex, block } = props;
const { labels, slug } = block;
return (
<div
className={baseClass}
role="button"
onClick={() => addRow(addRowIndex, slug)}
>
{labels.singular}
</div>
);
};
SelectableBlock.defaultProps = {
addRow: undefined,
addRowIndex: 0,
};
SelectableBlock.propTypes = {
addRow: PropTypes.func,
addRowIndex: PropTypes.number,
};
export default SelectableBlock;

View File

@@ -14,7 +14,7 @@ import { useRenderedFields } from '../../RenderFields';
import Error from '../../Error';
import useFieldType from '../../useFieldType';
import Popup from '../../../elements/Popup';
import BlocksContainer from './BlockSelector/BlocksContainer';
import BlockSelector from './BlockSelector';
import { flexible } from '../../../../../fields/validations';
import './index.scss';
@@ -213,7 +213,7 @@ const Flexible = (props) => {
</Button>
)}
>
<BlocksContainer
<BlockSelector
blocks={blocks}
addRow={addRow}
addRowIndex={addRowIndex}

View File

@@ -0,0 +1,40 @@
import React from 'react';
const FallbackBlockImage = () => {
return (
<svg
width="82"
height="53"
viewBox="0 0 82 53"
fill="none"
>
<rect
x="0.713013"
width="80.574"
height="52.7791"
fill="url(#pattern0)"
/>
<defs>
<pattern
id="pattern0"
patternContentUnits="objectBoundingBox"
width="1"
height="1"
>
<use
xlinkHref="#image0"
transform="scale(0.00387597 0.00591716)"
/>
</pattern>
<image
id="image0"
width="258"
height="169"
xlinkHref=""
/>
</defs>
</svg>
);
};
export default FallbackBlockImage;

View File

@@ -0,0 +1,34 @@
import React from 'react';
const Search = () => {
return (
<svg
width="25"
height="26"
viewBox="0 0 25 26"
fill="none"
xmlns="http://www.w3.org/2000/svg"
className="search"
>
<circle
cx="11.2069"
cy="10.9135"
r="5"
stroke="#333333"
strokeWidth="2"
className="stroke"
/>
<line
x1="14.914"
y1="14.2063"
x2="20.5002"
y2="19.7925"
stroke="#333333"
strokeWidth="2"
className="stroke"
/>
</svg>
);
};
export default Search;