Skip to content

Commit

Permalink
add styling schema and an option to somehow hardcode some values
Browse files Browse the repository at this point in the history
  • Loading branch information
ionlizarazu committed Mar 13, 2024
1 parent d5eecca commit 931ab08
Show file tree
Hide file tree
Showing 4 changed files with 206 additions and 17 deletions.
46 changes: 42 additions & 4 deletions src/View.jsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,58 @@
import React from 'react';
import config from '@plone/volto/registry';
import CountUp from 'react-countup';
import { Segment } from 'semantic-ui-react';
import { withBlockExtensions } from '@plone/volto/helpers';

const CountUpBlockView = ({ data, className }) => {
const { delay = 2 } = data;
const values = config.blocks.blocksConfig['countUpBlock'].schemaValues;
const {
delay = values.delay ?? 0,
duration = values.duration ?? 2,
prefix = values.prefix ?? '',
suffix = values.suffix ?? '',
decimal = values.decimal ?? ',',
decimals = values.decimals ?? 0,
separator = values.separator ?? '',
basic = values.basic ?? false,
inverted = values.inverted ?? false,
compact = values.compact ?? false,
circular = values.circular ?? false,
floated = values.floated ?? false,
textAlign = values.textAlign ?? false,
color = values.color ?? '',
size = values.size ?? '',
} = data;

const countUpData = {
delay,
duration,
prefix,
suffix,
decimal,
decimals,
separator,
};

const segmentData = {
basic,
inverted,
compact,
circular,
floated,
textAlign,
size,
color,
};

// Title config
const { title, titleTag, titlePosition = 'above' } = data;
const TitleTag = titleTag || 'h2';

return (
<Segment className={className}>
<Segment className={className} {...segmentData}>
{title && titlePosition === 'above' && <TitleTag>{title}</TitleTag>}

<CountUp {...data} delay={delay} />
<CountUp {...data} {...countUpData} />
{title && titlePosition === 'below' && <TitleTag>{title}</TitleTag>}
</Segment>
);
Expand Down
47 changes: 47 additions & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,53 @@ const applyConfig = (config) => {
['h4', 'h4'],
['strong', 'strong'],
],
schemaEditable: {
time: ['duration', 'delay'],
extras: ['prefix', 'suffix'],
decimals: ['decimal', 'decimals'],
thousands: ['separator'],
styling: [
'basic',
'inverted',
'compact',
'circular',
'floated',
'textAlign',
'color',
],
},
schemaValues: {
duration: 2,
delay: 0,
prefix: '',
suffix: '',
decimal: ',',
decimals: 0,
separator: '',
basic: false,
inverted: false,
compact: false,
circular: false,
floated: false,
textAlign: false,
color: '',
},
colors: [
{ name: 'transparent', value: 'transparent' },
{ name: 'grey', value: 'grey' },
{ name: 'black', value: 'black' },
{ name: 'red', value: 'red' },
{ name: 'green', value: 'green' },
{ name: 'blue', value: 'blue' },
{ name: 'yellow', value: 'yellow' },
{ name: 'orange', value: 'orange' },
{ name: 'olive', value: 'olive' },
{ name: 'teal', value: 'teal' },
{ name: 'violet', value: 'violet' },
{ name: 'purple', value: 'purple' },
{ name: 'pink', value: 'pink' },
{ name: 'brown', value: 'brown' },
],
};

return config;
Expand Down
40 changes: 40 additions & 0 deletions src/messages.js
Original file line number Diff line number Diff line change
Expand Up @@ -107,5 +107,45 @@ const messages = defineMessages({
id: 'Below',
defaultMessage: 'Below',
},
basic: {
id: 'Basic',
defaultMessage: 'Basic',
},
inverted: {
id: 'Inverted',
defaultMessage: 'Inverted',
},
compact: {
id: 'Compact',
defaultMessage: 'Compact',
},
circular: {
id: 'Circular',
defaultMessage: 'Circular',
},
floated: {
id: 'Floated',
defaultMessage: 'Floated',
},
textAlign: {
id: 'Text align',
defaultMessage: 'Text align',
},
center: {
id: 'Center',
defaultMessage: 'Center',
},
left: {
id: 'Left',
defaultMessage: 'Left',
},
right: {
id: 'Right',
defaultMessage: 'Right',
},
color: {
id: 'Color',
defaultMessage: 'Color',
},
});
export default messages;
90 changes: 77 additions & 13 deletions src/schema.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,26 @@ import config from '@plone/volto/registry';
import messages from './messages.js';

export const CountUpBlockSchema = (intl, data) => {
const countUpConfig = config.blocks.blocksConfig['countUpBlock'];
const decimals =
data.start % 1 !== 0 || data.end % 1 !== 0 ? ['decimal', 'decimals'] : [];
const thousands = data.start >= 1000 || data.end >= 1000 ? ['separator'] : [];
(data.start % 1 !== 0 || data.end % 1 !== 0) &&
countUpConfig.schemaEditable.decimals.length
? countUpConfig.schemaEditable.decimals
: [];
const thousands =
(data.start >= 1000 || data.end >= 1000) &&
countUpConfig.schemaEditable.thousands.length
? countUpConfig.schemaEditable.thousands
: [];
const time = countUpConfig.schemaEditable.time?.length
? [
{
id: 'time',
title: 'Time config',
fields: countUpConfig.schemaEditable.time,
},
]
: [];
const separator =
decimals.length || thousands.length
? [
Expand All @@ -15,6 +32,24 @@ export const CountUpBlockSchema = (intl, data) => {
},
]
: [];
const extras = countUpConfig.schemaEditable.extras?.length
? [
{
id: 'extras',
title: 'Extra config',
fields: countUpConfig.schemaEditable.extras,
},
]
: [];
const styling = countUpConfig.schemaEditable.extras?.length
? [
{
id: 'styling',
title: 'Style config',
fields: countUpConfig.schemaEditable.styling,
},
]
: [];
return {
title: intl.formatMessage(messages.countupblockconfig),
fieldsets: [
Expand All @@ -23,17 +58,10 @@ export const CountUpBlockSchema = (intl, data) => {
title: 'Default',
fields: ['start', 'end'],
},
{
id: 'time',
title: 'Time config',
fields: ['duration', 'delay'],
},
...time,
...separator,
{
id: 'extras',
title: 'Extra config',
fields: ['prefix', 'suffix'],
},
...extras,
...styling,
{
id: 'title',
title: 'Title',
Expand All @@ -48,7 +76,7 @@ export const CountUpBlockSchema = (intl, data) => {
},
titleTag: {
title: intl.formatMessage(messages.titleTags),
choices: config.blocks.blocksConfig['countUpBlock'].titleTags,
choices: countUpConfig.titleTags,
},
titlePosition: {
title: intl.formatMessage(messages.titlePosition),
Expand Down Expand Up @@ -101,6 +129,42 @@ export const CountUpBlockSchema = (intl, data) => {
title: intl.formatMessage(messages.separator),
type: 'string',
},
basic: {
title: intl.formatMessage(messages.basic),
type: 'boolean',
},
inverted: {
title: intl.formatMessage(messages.inverted),
type: 'boolean',
},
compact: {
title: intl.formatMessage(messages.compact),
type: 'boolean',
},
circular: {
title: intl.formatMessage(messages.circular),
type: 'boolean',
},
floated: {
title: intl.formatMessage(messages.floated),
choices: [
['left', intl.formatMessage(messages.left)],
['right', intl.formatMessage(messages.right)],
],
},
textAlign: {
title: intl.formatMessage(messages.textAlign),
choices: [
['left', intl.formatMessage(messages.left)],
['right', intl.formatMessage(messages.right)],
['center', intl.formatMessage(messages.center)],
],
},
color: {
title: intl.formatMessage(messages.color),
widget: 'color_picker',
colors: countUpConfig.colors,
},
},
required: ['start', 'end'],
};
Expand Down

0 comments on commit 931ab08

Please sign in to comment.