Skip to content

Commit

Permalink
Get variants from blocksConfig
Browse files Browse the repository at this point in the history
This is needed for when we want to add more columns variants from outside this addon
  • Loading branch information
razvanMiu committed Mar 23, 2021
1 parent 7cb3839 commit 075eebc
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 4 deletions.
7 changes: 6 additions & 1 deletion src/ColumnsBlock/ColumnsBlockEdit.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ import ColumnVariations from './ColumnVariations';
import EditBlockWrapper from './EditBlockWrapper';

import { COLUMNSBLOCK } from '@eeacms/volto-columns-block/constants';
import { variants } from '@eeacms/volto-columns-block/grid';
import { variants as defaultVariants } from '@eeacms/volto-columns-block/grid';
import { makeStyleSchema, getStyle } from '@eeacms/volto-columns-block/Styles';

import tuneSVG from '@plone/volto/icons/column.svg';
Expand Down Expand Up @@ -211,20 +211,25 @@ class ColumnsBlockEdit extends React.Component {
};

getColumnsBlockSchema = () => {
const variants =
config.blocks.blocksConfig?.[COLUMNSBLOCK]?.variants || defaultVariants;
const schema = ColumnsBlockSchema();
const { data } = this.props;
const { blocks_layout = {} } = data.data || {};
const nrOfColumns = (blocks_layout?.items || []).length;
const available_variants = variants.filter(
({ defaultData }) => defaultData?.gridCols?.length === nrOfColumns,
);

schema.properties.gridCols.choices = available_variants.map(
({ defaultData, title }) => [defaultData?.gridCols, title],
);
return schema;
};

componentDidUpdate(prevProps) {
const variants =
config.blocks.blocksConfig?.[COLUMNSBLOCK]?.variants || defaultVariants;
const cols = this.props.data.data?.blocks_layout?.items || [];
const prevCols = prevProps.data.data?.blocks_layout?.items || [];

Expand Down
13 changes: 10 additions & 3 deletions src/Widgets/LayoutSelectWidget.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,17 +6,20 @@
import React, { Component } from 'react';
import { compose } from 'redux';
import { injectIntl } from 'react-intl';

import loadable from '@loadable/component';

import { isEqual } from 'lodash';
import { variants } from '../grid';

import { FormFieldWrapper, Icon } from '@plone/volto/components';
import {
DropdownIndicator,
selectTheme,
customSelectStyles,
} from '@plone/volto/components/manage/Widgets/SelectStyling';
import config from '@plone/volto/registry';

import { variants as defaultVariants } from '../grid';
import { COLUMNSBLOCK } from '@eeacms/volto-columns-block/constants';

import checkSVG from '@plone/volto/icons/check.svg';

const ReactSelectLib = loadable.lib(() => import('react-select'));
Expand All @@ -30,6 +33,8 @@ const variantToGridCols = (v) => {
};

export const Option = (props) => {
const variants =
config.blocks.blocksConfig?.[COLUMNSBLOCK]?.variants || defaultVariants;
return (
<ReactSelectLib>
{({ components }) => {
Expand Down Expand Up @@ -59,6 +64,8 @@ export const Option = (props) => {

const SingleValue = (props) => {
const { children, className, cx, getStyles, isDisabled, innerProps } = props;
const variants =
config.blocks.blocksConfig?.[COLUMNSBLOCK]?.variants || defaultVariants;

const variant = variants.find((v) =>
gridColsAreEqual(variantToGridCols(v), props.data.value),
Expand Down

0 comments on commit 075eebc

Please sign in to comment.