@elementor/editor-canvas 0.24.0 → 0.25.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -8,12 +8,15 @@ import {
8
8
  backgroundImageSizeScalePropTypeUtil,
9
9
  backgroundOverlayPropTypeUtil,
10
10
  backgroundPropTypeUtil,
11
+ blurFilterPropTypeUtil,
11
12
  borderRadiusPropTypeUtil,
12
13
  borderWidthPropTypeUtil,
13
14
  boxShadowPropTypeUtil,
15
+ brightnessFilterPropTypeUtil,
14
16
  colorPropTypeUtil,
15
17
  colorStopPropTypeUtil,
16
18
  dimensionsPropTypeUtil,
19
+ filterPropTypeUtil,
17
20
  gradientColorStopPropTypeUtil,
18
21
  imageAttachmentIdPropType,
19
22
  imagePropTypeUtil,
@@ -267,6 +270,22 @@ describe( 'styles prop resolver', () => {
267
270
  'background-size': 'auto auto,auto auto,1400px auto,auto',
268
271
  },
269
272
  },
273
+ {
274
+ name: 'filter',
275
+ props: {
276
+ filter: filterPropTypeUtil.create( [
277
+ blurFilterPropTypeUtil.create( {
278
+ radius: sizePropTypeUtil.create( { size: 1, unit: 'px' } ),
279
+ } ),
280
+ brightnessFilterPropTypeUtil.create( {
281
+ amount: sizePropTypeUtil.create( { size: 90, unit: '%' } ),
282
+ } ),
283
+ ] ),
284
+ },
285
+ expected: {
286
+ filter: 'blur(1px) brightness(90%)',
287
+ },
288
+ },
270
289
  {
271
290
  name: 'background (url only repeat and attachment)',
272
291
  prepare: () => {
@@ -11,13 +11,14 @@ type Props = {
11
11
  element: HTMLElement;
12
12
  isSelected: boolean;
13
13
  id: string;
14
+ isSmallerOffset?: boolean;
14
15
  };
15
16
 
16
- const OverlayBox = styled( Box, { shouldForwardProp: ( prop ) => prop !== 'isSelected' } )<
17
- Pick< Props, 'isSelected' >
18
- >( ( { theme, isSelected } ) => ( {
17
+ const OverlayBox = styled( Box, {
18
+ shouldForwardProp: ( prop ) => prop !== 'isSelected' && prop !== 'isSmallerOffset',
19
+ } )< Pick< Props, 'isSelected' | 'isSmallerOffset' > >( ( { theme, isSelected, isSmallerOffset } ) => ( {
19
20
  outline: `${ isSelected ? '2px' : '1px' } solid ${ theme.palette.primary.light }`,
20
- outlineOffset: isSelected ? '-2px' : '-1px',
21
+ outlineOffset: isSelected && ! isSmallerOffset ? '-2px' : '-1px',
21
22
  pointerEvents: 'none',
22
23
  } ) );
23
24
 
@@ -26,6 +27,7 @@ export function ElementOverlay( { element, isSelected, id }: Props ) {
26
27
  const { getFloatingProps, getReferenceProps } = useInteractions( [ useHover( context ) ] );
27
28
 
28
29
  useBindReactPropsToElement( element, getReferenceProps );
30
+ const isSmallerOffset = element.offsetHeight <= 1;
29
31
 
30
32
  return (
31
33
  isVisible && (
@@ -36,6 +38,7 @@ export function ElementOverlay( { element, isSelected, id }: Props ) {
36
38
  style={ floating.styles }
37
39
  data-element-overlay={ id }
38
40
  role="presentation"
41
+ isSmallerOffset={ isSmallerOffset }
39
42
  { ...getFloatingProps() }
40
43
  />
41
44
  </FloatingPortal>
@@ -11,6 +11,7 @@ import { backgroundTransformer } from './transformers/styles/background-transfor
11
11
  import { colorStopTransformer } from './transformers/styles/color-stop-transformer';
12
12
  import { createCombineArrayTransformer } from './transformers/styles/create-combine-array-transformer';
13
13
  import { createMultiPropsTransformer } from './transformers/styles/create-multi-props-transformer';
14
+ import { filterTransformer } from './transformers/styles/filter-transformer';
14
15
  import { positionTransformer } from './transformers/styles/position-transformer';
15
16
  import { shadowTransformer } from './transformers/styles/shadow-transformer';
16
17
  import { sizeTransformer } from './transformers/styles/size-transformer';
@@ -28,6 +29,7 @@ export function initStyleTransformers() {
28
29
  ( { propKey, key } ) => `${ propKey }-${ key }`
29
30
  )
30
31
  )
32
+ .register( 'filter', filterTransformer )
31
33
  .register( 'box-shadow', createCombineArrayTransformer( ',' ) )
32
34
  .register( 'background', backgroundTransformer )
33
35
  .register( 'background-overlay', backgroundOverlayTransformer )
@@ -0,0 +1,23 @@
1
+ import { type FilterItemPropValue } from '@elementor/editor-props';
2
+
3
+ import { createTransformer } from '../create-transformer';
4
+
5
+ export const filterTransformer = createTransformer( ( filterValues: FilterItemPropValue[ 'value' ][] ) => {
6
+ if ( filterValues?.length < 1 ) {
7
+ return null;
8
+ }
9
+
10
+ return filterValues.map( mapToFilterFunctionString ).join( ' ' );
11
+ } );
12
+
13
+ const mapToFilterFunctionString = ( value: FilterItemPropValue[ 'value' ] ): string => {
14
+ if ( 'radius' in value ) {
15
+ return `blur(${ value.radius })`;
16
+ }
17
+
18
+ if ( 'amount' in value ) {
19
+ return `brightness(${ value.amount })`;
20
+ }
21
+
22
+ return '';
23
+ };