@elementor/editor-variables 3.35.0-493 → 3.35.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.
package/dist/index.d.mts CHANGED
@@ -86,7 +86,7 @@ declare const service: {
86
86
  id: any;
87
87
  variable: any;
88
88
  }>;
89
- batchSave: (originalVariables: TVariablesList, currentVariables: TVariablesList) => Promise<{
89
+ batchSave: (originalVariables: TVariablesList, currentVariables: TVariablesList, deletedVariables: string[]) => Promise<{
90
90
  success: boolean;
91
91
  watermark: any;
92
92
  operations: number;
package/dist/index.d.ts CHANGED
@@ -86,7 +86,7 @@ declare const service: {
86
86
  id: any;
87
87
  variable: any;
88
88
  }>;
89
- batchSave: (originalVariables: TVariablesList, currentVariables: TVariablesList) => Promise<{
89
+ batchSave: (originalVariables: TVariablesList, currentVariables: TVariablesList, deletedVariables: string[]) => Promise<{
90
90
  success: boolean;
91
91
  watermark: any;
92
92
  operations: number;
package/dist/index.js CHANGED
@@ -266,7 +266,7 @@ var generateTempId = () => {
266
266
  var isTempId = (id2) => {
267
267
  return id2.startsWith("tmp-");
268
268
  };
269
- var buildOperationsArray = (originalVariables, currentVariables) => {
269
+ var buildOperationsArray = (originalVariables, currentVariables, deletedVariables) => {
270
270
  const operations = [];
271
271
  Object.entries(currentVariables).forEach(([id2, variable]) => {
272
272
  if (isTempId(id2)) {
@@ -286,30 +286,25 @@ var buildOperationsArray = (originalVariables, currentVariables) => {
286
286
  ...original.label !== variable.label && { label: variable.label },
287
287
  ...original.value !== variable.value && { value: variable.value }
288
288
  });
289
- } else if (!variable.deleted && (original.label !== variable.label || original.value !== variable.value || original.order !== variable.order)) {
289
+ } else if (!variable.deleted && (original.label !== variable.label || original.value !== variable.value || original.order !== variable.order || original.type !== variable.type)) {
290
290
  operations.push({
291
291
  type: "update",
292
292
  id: id2,
293
293
  variable: {
294
294
  ...original.label !== variable.label && { label: variable.label },
295
295
  ...original.value !== variable.value && { value: variable.value },
296
- ...original.order !== variable.order && { order: variable.order }
296
+ ...original.order !== variable.order && { order: variable.order },
297
+ ...original.type !== variable.type && { type: variable.type }
297
298
  }
298
299
  });
299
300
  }
300
301
  }
301
302
  });
302
- Object.entries(originalVariables).forEach(([id2, variable]) => {
303
- if (isTempId(id2) || variable.deleted) {
304
- return;
305
- }
306
- const currentVariable = currentVariables[id2];
307
- if (!currentVariable || currentVariable.deleted) {
308
- operations.push({
309
- type: "delete",
310
- id: id2
311
- });
312
- }
303
+ deletedVariables.forEach((id2) => {
304
+ operations.push({
305
+ type: "delete",
306
+ id: id2
307
+ });
313
308
  });
314
309
  return operations.filter((op) => {
315
310
  const id2 = op.id || op.variable?.id;
@@ -579,8 +574,8 @@ var service = {
579
574
  };
580
575
  });
581
576
  },
582
- batchSave: (originalVariables, currentVariables) => {
583
- const operations = buildOperationsArray(originalVariables, currentVariables);
577
+ batchSave: (originalVariables, currentVariables, deletedVariables) => {
578
+ const operations = buildOperationsArray(originalVariables, currentVariables, deletedVariables);
584
579
  const batchPayload = { operations, watermark: storage.state.watermark };
585
580
  if (operations.length === 0) {
586
581
  return Promise.resolve({
@@ -1032,7 +1027,7 @@ var useVariablesManagerState = () => {
1032
1027
  const handleSave = (0, import_react5.useCallback)(async () => {
1033
1028
  const originalVariables = getVariables(false);
1034
1029
  setIsSaving(true);
1035
- const result = await service.batchSave(originalVariables, variables);
1030
+ const result = await service.batchSave(originalVariables, variables, deletedVariables);
1036
1031
  if (result.success) {
1037
1032
  await service.load();
1038
1033
  const updatedVariables = service.variables();
@@ -1041,7 +1036,7 @@ var useVariablesManagerState = () => {
1041
1036
  setIsDirty(false);
1042
1037
  }
1043
1038
  return { success: result.success };
1044
- }, [variables]);
1039
+ }, [variables, deletedVariables]);
1045
1040
  const filteredVariables = (0, import_react5.useCallback)(() => {
1046
1041
  const list = variablesToList(variables).filter((v) => !v.deleted);
1047
1042
  const typeFiltered = applySelectionFilters(list, getVariableTypes());
@@ -1771,7 +1766,7 @@ var { panel, usePanelActions } = (0, import_editor_panels.__createPanel)({
1771
1766
  onOpen: () => {
1772
1767
  (0, import_editor_v1_adapters.changeEditMode)(id);
1773
1768
  },
1774
- onClose: () => {
1769
+ onClose: async () => {
1775
1770
  (0, import_editor_v1_adapters.changeEditMode)("edit");
1776
1771
  },
1777
1772
  isOpenPreviousElement: true
@@ -3422,6 +3417,9 @@ var trackOpenVariablePopover = (path, variableType) => {
3422
3417
  });
3423
3418
  };
3424
3419
 
3420
+ // src/mcp/index.ts
3421
+ var import_editor_mcp3 = require("@elementor/editor-mcp");
3422
+
3425
3423
  // src/mcp/manage-variable-tool.ts
3426
3424
  var import_editor_mcp2 = require("@elementor/editor-mcp");
3427
3425
  var import_schema3 = require("@elementor/schema");
@@ -3534,6 +3532,9 @@ function getServiceActions(svc) {
3534
3532
 
3535
3533
  // src/mcp/index.ts
3536
3534
  function initMcp() {
3535
+ if (!(0, import_editor_mcp3.isAngieAvailable)()) {
3536
+ return;
3537
+ }
3537
3538
  initManageVariableTool();
3538
3539
  initVariablesResource();
3539
3540
  }