Skip to content

Commit

Permalink
fix(ui): avoid reseting the "selected" state on all field change - WF…
Browse files Browse the repository at this point in the history
…-155

We want to disable the component "selected" state when the style of the
component is changed (like when the user changes the background). But
actually, this is done when **any** of `evaluatedFields` changes.

The fix was simply to run the behavior only when a "Style" field change.
So I just tweaked a bit the `watch` source in `ComponentProxy`.
  • Loading branch information
madeindjs committed Jan 7, 2025
1 parent dc8618b commit 4822f5d
Showing 1 changed file with 28 additions and 17 deletions.
45 changes: 28 additions & 17 deletions src/ui/src/renderer/ComponentProxy.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,12 @@
import { PropType, VNode, computed, h, inject, provide, ref, watch } from "vue";
import { getTemplate } from "@/core/templateMap";
import injectionKeys from "@/injectionKeys";
import { Component, InstancePath, InstancePathItem } from "@/writerTypes";
import {
Component,
FieldCategory,
InstancePath,
InstancePathItem,
} from "@/writerTypes";
import ChildlessPlaceholder from "./ChildlessPlaceholder.vue";
import ComponentProxy from "./ComponentProxy.vue";
import RenderError from "./RenderError.vue";
Expand Down Expand Up @@ -38,8 +43,7 @@ export default {
!component.value.isCodeManaged &&
component.value.type !== "root" &&
component.value.type !== "workflows_root" &&
wf.getComponentDefinition(component.value.type)?.toolkit !==
"workflows",
componentDefinition.value?.toolkit !== "workflows",
);
const isParentSuitable = (parentId, childType) => {
Expand Down Expand Up @@ -157,6 +161,13 @@ export default {
"data-writer-instance-path": flattenedInstancePath,
};
const componentDefinition = computed(() =>
wf.getComponentDefinition(component.value.type),
);
const componentDefinitionFields = computed(
() => componentDefinition.value?.fields,
);
/*
Selected stylesheet class is removed if changes are made,
for the developer to appreciate the changes. Particularly important
Expand All @@ -170,13 +181,17 @@ export default {
isSelected.value = isNowSelected;
},
);
watch(
() => evaluatedFields,
() => {
isSelected.value = false;
},
{ deep: true },
);
// keep track on style fields changed to remove the "selected" state if a style change (it helps the user to see his modifications)
const styleFields = computed(() => {
return Object.entries(componentDefinitionFields.value)
.filter(([, value]) => value.category === FieldCategory.Style)
.reduce<Record<string, unknown>>((acc, [key]) => {
acc[key] = evaluatedFields[key].value;
return acc;
}, {});
});
watch(styleFields, () => (isSelected.value = false));
const isChildless = computed(() => children.value.length == 0);
const isVisible = computed(() =>
Expand Down Expand Up @@ -258,9 +273,7 @@ export default {
});
const fieldBasedStyleVars = computed(() => {
const fields = wf.getComponentDefinition(
component.value.type,
)?.fields;
const fields = componentDefinitionFields.value;
if (!fields) return;
const styleVars = {};
Object.keys(fields).forEach((key) => {
Expand All @@ -273,16 +286,14 @@ export default {
const fieldBasedCssClasses = computed(() => {
const CSS_CLASSES_FIELD_KEY = "cssClasses";
const fields = wf.getComponentDefinition(
component.value.type,
)?.fields;
const fields = componentDefinitionFields.value;
if (!fields) return;
if (
!fields[CSS_CLASSES_FIELD_KEY] ||
!evaluatedFields[CSS_CLASSES_FIELD_KEY]
)
return;
const cssStr: string = evaluatedFields[CSS_CLASSES_FIELD_KEY].value;
const cssStr = String(evaluatedFields[CSS_CLASSES_FIELD_KEY].value);
const cssClassesArr = cssStr?.split(" ").map((s) => s.trim());
const cssClasses = {};
cssClassesArr.forEach((key) => {
Expand Down

0 comments on commit 4822f5d

Please sign in to comment.