Skip to content

Commit

Permalink
feat: checkbox for inversion of visibility value
Browse files Browse the repository at this point in the history
* feat: implement reverse option
  • Loading branch information
FabienArcellier committed Aug 19, 2024
1 parent 505f6f0 commit eadc576
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 1 deletion.
21 changes: 21 additions & 0 deletions src/ui/src/builder/BuilderSettingsVisibility.vue
Original file line number Diff line number Diff line change
Expand Up @@ -47,9 +47,24 @@
setVisibleValue(
component.id,
(ev.target as HTMLInputElement).value,
component.visibleReversed,
)
"
/>
<div class="flexRow">
<input
type="checkbox"
:checked="component.visibleReversed"
@input="
(ev: Event) =>
setVisibleValue(
component.id,
component.visible,
(ev.target as HTMLInputElement).checked,
)
"
/><span>Reverse</span>
</div>
<div class="desc">
Reference a state or context element that will evaluate to
true or false. Reference the element directly, i.e. use
Expand Down Expand Up @@ -87,4 +102,10 @@ const component = computed(() => wf.getComponentById(ssbm.getSelectedId()));
.content {
padding: 16px 12px 12px 12px;
}
.flexRow {
display: flex;
flex-direction: row;
gap: 8px;
}
</style>
3 changes: 3 additions & 0 deletions src/ui/src/builder/useComponentActions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -695,6 +695,7 @@ export function useComponentActions(wf: Core, ssbm: BuilderManager) {
function setVisibleValue(
componentId: Component["id"],
visible: Component["visible"],
reversed: boolean = false,
) {
const component = wf.getComponentById(componentId);
if (!component) return;
Expand All @@ -704,8 +705,10 @@ export function useComponentActions(wf: Core, ssbm: BuilderManager) {

if (visible === true && typeof component.visible != "undefined") {
delete component.visible;
delete component.visibleReversed;
} else {
component.visible = visible;
component.visibleReversed = reversed;
}

ssbm.registerPostMutation(component);
Expand Down
3 changes: 2 additions & 1 deletion src/ui/src/renderer/useEvaluator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,8 @@ export function useEvaluator(wf: Core) {
component.visible as string,
instancePath,
);
return !!evaluated;

return component.visibleReversed === true ? !evaluated : !!evaluated;
}

return {
Expand Down
1 change: 1 addition & 0 deletions src/ui/src/writerTypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export type Component = {
isCodeManaged?: boolean;
handlers?: Record<string, string>;
visible?: boolean | string;
visibleReversed?: boolean;
binding?: {
eventType: string;
stateRef: string;
Expand Down
1 change: 1 addition & 0 deletions src/writer/core_ui.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ class Component(BaseModel):
parentId: Optional[str] = None
handlers: Optional[Dict[str, str]] = None
visible: Optional[Union[bool, str]] = None
visibleReversed: Optional[Union[bool]] = None
binding: Optional[Dict] = None

def to_dict(self) -> Dict:
Expand Down

0 comments on commit eadc576

Please sign in to comment.