@elementor/editor-components 3.35.0-454 → 3.35.0-456
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.
- package/dist/index.js +25 -13
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +22 -10
- package/dist/index.mjs.map +1 -1
- package/package.json +22 -22
- package/src/components/errors.ts +6 -0
- package/src/components/instance-editing-panel/override-prop-control.tsx +9 -1
- package/src/components/overridable-props/overridable-prop-indicator.tsx +5 -7
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@elementor/editor-components",
|
|
3
3
|
"description": "Elementor editor components",
|
|
4
|
-
"version": "3.35.0-
|
|
4
|
+
"version": "3.35.0-456",
|
|
5
5
|
"private": false,
|
|
6
6
|
"author": "Elementor Team",
|
|
7
7
|
"homepage": "https://elementor.com/",
|
|
@@ -40,30 +40,30 @@
|
|
|
40
40
|
"dev": "tsup --config=../../tsup.dev.ts"
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@elementor/editor": "3.35.0-
|
|
44
|
-
"@elementor/editor-canvas": "3.35.0-
|
|
45
|
-
"@elementor/editor-controls": "3.35.0-
|
|
46
|
-
"@elementor/editor-documents": "3.35.0-
|
|
47
|
-
"@elementor/editor-editing-panel": "3.35.0-
|
|
48
|
-
"@elementor/editor-elements": "3.35.0-
|
|
49
|
-
"@elementor/editor-elements-panel": "3.35.0-
|
|
50
|
-
"@elementor/editor-mcp": "3.35.0-
|
|
51
|
-
"@elementor/editor-panels": "3.35.0-
|
|
52
|
-
"@elementor/editor-props": "3.35.0-
|
|
53
|
-
"@elementor/editor-styles-repository": "3.35.0-
|
|
54
|
-
"@elementor/editor-ui": "3.35.0-
|
|
55
|
-
"@elementor/editor-v1-adapters": "3.35.0-
|
|
56
|
-
"@elementor/http-client": "3.35.0-
|
|
43
|
+
"@elementor/editor": "3.35.0-456",
|
|
44
|
+
"@elementor/editor-canvas": "3.35.0-456",
|
|
45
|
+
"@elementor/editor-controls": "3.35.0-456",
|
|
46
|
+
"@elementor/editor-documents": "3.35.0-456",
|
|
47
|
+
"@elementor/editor-editing-panel": "3.35.0-456",
|
|
48
|
+
"@elementor/editor-elements": "3.35.0-456",
|
|
49
|
+
"@elementor/editor-elements-panel": "3.35.0-456",
|
|
50
|
+
"@elementor/editor-mcp": "3.35.0-456",
|
|
51
|
+
"@elementor/editor-panels": "3.35.0-456",
|
|
52
|
+
"@elementor/editor-props": "3.35.0-456",
|
|
53
|
+
"@elementor/editor-styles-repository": "3.35.0-456",
|
|
54
|
+
"@elementor/editor-ui": "3.35.0-456",
|
|
55
|
+
"@elementor/editor-v1-adapters": "3.35.0-456",
|
|
56
|
+
"@elementor/http-client": "3.35.0-456",
|
|
57
57
|
"@elementor/icons": "^1.63.0",
|
|
58
|
-
"@elementor/mixpanel": "3.35.0-
|
|
59
|
-
"@elementor/query": "3.35.0-
|
|
60
|
-
"@elementor/schema": "3.35.0-
|
|
61
|
-
"@elementor/store": "3.35.0-
|
|
58
|
+
"@elementor/mixpanel": "3.35.0-456",
|
|
59
|
+
"@elementor/query": "3.35.0-456",
|
|
60
|
+
"@elementor/schema": "3.35.0-456",
|
|
61
|
+
"@elementor/store": "3.35.0-456",
|
|
62
62
|
"@elementor/ui": "1.36.17",
|
|
63
|
-
"@elementor/utils": "3.35.0-
|
|
63
|
+
"@elementor/utils": "3.35.0-456",
|
|
64
64
|
"@wordpress/i18n": "^5.13.0",
|
|
65
|
-
"@elementor/editor-notifications": "3.35.0-
|
|
66
|
-
"@elementor/editor-current-user": "3.35.0-
|
|
65
|
+
"@elementor/editor-notifications": "3.35.0-456",
|
|
66
|
+
"@elementor/editor-current-user": "3.35.0-456"
|
|
67
67
|
},
|
|
68
68
|
"peerDependencies": {
|
|
69
69
|
"react": "^18.3.1",
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { createError } from '@elementor/utils';
|
|
2
|
+
|
|
3
|
+
export const OverrideControlInnerElementNotFoundError = createError< { componentId: number; elementId: string } >( {
|
|
4
|
+
code: 'override_control_inner_element_not_found',
|
|
5
|
+
message: `Component inner element not found for override control. The element may have been deleted without updating the overridable props, or the component has not finished rendering yet.`,
|
|
6
|
+
} );
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
SettingsField,
|
|
11
11
|
useElement,
|
|
12
12
|
} from '@elementor/editor-editing-panel';
|
|
13
|
-
import { type Control, getElementType } from '@elementor/editor-elements';
|
|
13
|
+
import { type Control, getContainer, getElementType } from '@elementor/editor-elements';
|
|
14
14
|
import { Stack } from '@elementor/ui';
|
|
15
15
|
|
|
16
16
|
import { useControlsByWidgetType } from '../../hooks/use-controls-by-widget-type';
|
|
@@ -35,6 +35,7 @@ import { type OriginPropFields, type OverridableProp } from '../../types';
|
|
|
35
35
|
import { getPropTypeForComponentOverride } from '../../utils/get-prop-type-for-component-override';
|
|
36
36
|
import { resolveOverridePropValue } from '../../utils/resolve-override-prop-value';
|
|
37
37
|
import { ControlLabel } from '../control-label';
|
|
38
|
+
import { OverrideControlInnerElementNotFoundError } from '../errors';
|
|
38
39
|
|
|
39
40
|
type Props = {
|
|
40
41
|
overridableProp: OverridableProp;
|
|
@@ -131,6 +132,13 @@ function OverrideControl( { overridableProp, overrides }: Props ) {
|
|
|
131
132
|
|
|
132
133
|
const { elementId, widgetType, elType, propKey } = overridableProp.originPropFields ?? overridableProp;
|
|
133
134
|
|
|
135
|
+
const elementContainer = getContainer( elementId );
|
|
136
|
+
if ( ! elementContainer ) {
|
|
137
|
+
throw new OverrideControlInnerElementNotFoundError( {
|
|
138
|
+
context: { componentId: componentInstanceId, elementId },
|
|
139
|
+
} );
|
|
140
|
+
}
|
|
141
|
+
|
|
134
142
|
const type = elType === 'widget' ? widgetType : elType;
|
|
135
143
|
const elementType = getElementType( type );
|
|
136
144
|
|
|
@@ -2,7 +2,7 @@ import * as React from 'react';
|
|
|
2
2
|
import { useBoundProp } from '@elementor/editor-controls';
|
|
3
3
|
import { useElement } from '@elementor/editor-editing-panel';
|
|
4
4
|
import { getWidgetsCache } from '@elementor/editor-elements';
|
|
5
|
-
import { type TransformablePropValue } from '@elementor/editor-props';
|
|
5
|
+
import { type PropType, type TransformablePropValue } from '@elementor/editor-props';
|
|
6
6
|
import { bindPopover, bindTrigger, Popover, Tooltip, usePopupState } from '@elementor/ui';
|
|
7
7
|
import { __ } from '@wordpress/i18n';
|
|
8
8
|
|
|
@@ -16,14 +16,12 @@ import { Indicator } from './indicator';
|
|
|
16
16
|
import { OverridablePropForm } from './overridable-prop-form';
|
|
17
17
|
import { getOverridableProp } from './utils/get-overridable-prop';
|
|
18
18
|
|
|
19
|
-
const FORBIDDEN_KEYS = [ '_cssid', 'attributes' ];
|
|
20
|
-
|
|
21
19
|
export function OverridablePropIndicator() {
|
|
22
|
-
const {
|
|
20
|
+
const { propType } = useBoundProp();
|
|
23
21
|
const componentId = useCurrentComponentId();
|
|
24
22
|
const overridableProps = useOverridableProps( componentId );
|
|
25
23
|
|
|
26
|
-
if ( ! isPropAllowed(
|
|
24
|
+
if ( ! isPropAllowed( propType ) || ! componentId || ! overridableProps ) {
|
|
27
25
|
return null;
|
|
28
26
|
}
|
|
29
27
|
|
|
@@ -133,6 +131,6 @@ export function Content( { componentId, overridableProps }: Props ) {
|
|
|
133
131
|
);
|
|
134
132
|
}
|
|
135
133
|
|
|
136
|
-
function isPropAllowed(
|
|
137
|
-
return
|
|
134
|
+
function isPropAllowed( propType: PropType ) {
|
|
135
|
+
return propType.meta.overridable !== false;
|
|
138
136
|
}
|