Skip to content

[doc] Add pitch for minimap default visibility#6302

Merged
sbegaudeau merged 1 commit intomasterfrom
fba/doc/minimapShap
Apr 7, 2026
Merged

[doc] Add pitch for minimap default visibility#6302
sbegaudeau merged 1 commit intomasterfrom
fba/doc/minimapShap

Conversation

@florianbarbin
Copy link
Copy Markdown
Contributor

Bug: #6295

Pull request template

General purpose

What is the main goal of this pull request?

  • Bug fixes
  • New features
  • Documentation
  • Cleanup
  • Tests
  • Build / releng

Project management

  • Has the pull request been added to the relevant project and milestone? (Only if you know that your work is part of a specific iteration such as the current one)
  • Have the priority: and pr: labels been added to the pull request? (In case of doubt, start with the labels priority: low and pr: to review later)
  • Have the relevant issues been added to the pull request?
  • Have the relevant labels been added to the issues? (area:, difficulty:, type:)
  • Have the relevant issues been added to the same project and milestone as the pull request?
  • Has the CHANGELOG.adoc been updated to reference the relevant issues?
  • Have the relevant API breaks been described in the CHANGELOG.adoc? (Including changes in the GraphQL API)
  • In case of a change with a visual impact, are there any screenshots in the CHANGELOG.adoc? For example in doc/screenshots/2022.5.0-my-new-feature.png

Architectural decision records (ADR)

  • Does the title of the commit contributing the ADR start with [doc]?
  • Are the ADRs mentioned in the relevant section of the CHANGELOG.adoc?

Dependencies

  • Are the new / upgraded dependencies mentioned in the relevant section of the CHANGELOG.adoc?
  • Are the new dependencies justified in the CHANGELOG.adoc?

Frontend

This section is not relevant if your contribution does not come with changes to the frontend.

General purpose

  • Is the code properly tested? (Plain old JavaScript tests for business code and tests based on React Testing Library for the components)

Typing

We need to improve the typing of our code, as such, we require every contribution to come with proper TypeScript typing for both changes contributing new files and those modifying existing files.
Please ensure that the following statements are true for each file created or modified (this may require you to improve code outside of your contribution).

  • Variables have a proper type
  • Functions’ arguments have a proper type
  • Functions’ return type are specified
  • Hooks are properly typed:
    • useMutation<DATA_TYPE, VARIABLE_TYPE>(…)
    • useQuery<DATA_TYPE, VARIABLE_TYPE>(…)
    • useSubscription<DATA_TYPE, VARIABLE_TYPE>(…)
    • useMachine<CONTEXT_TYPE, EVENTS_TYPE>(…)
    • useState<STATE_TYPE>(…)
  • All components have a proper typing for their props
  • No useless optional chaining with ?. (if the GraphQL API specifies that a field cannot be null, do not treat it has potentially null for example)
  • Nullable values have a proper type (for example let diagram: Diagram | null = null;)

Backend

This section is not relevant if your contribution does not come with changes to the backend.

General purpose

  • Are all the event handlers tested?
  • Are the event processor tested?
  • Is the business code (services) tested?
  • Are diagram layout changes tested?

Architecture

  • Are data structure classes properly separated from behavioral classes?
  • Are all the relevant fields final?
  • Is any data structure mutable? If so, please write a comment indicating why
  • Are behavioral classes either stateless or side effect free?

Review

How to test this PR?

Please describe here the various use cases to test this pull request

  • Has the Kiwi TCMS test suite been updated with tests for this contribution?

@florianbarbin florianbarbin added this to the 2026.5.0 milestone Mar 17, 2026
@florianbarbin florianbarbin linked an issue Mar 17, 2026 that may be closed by this pull request
@florianbarbin florianbarbin force-pushed the fba/doc/minimapShap branch 2 times, most recently from 2dd2c2c to f0c80b1 Compare March 18, 2026 16:36
@florianbarbin florianbarbin changed the base branch from master to cooldown March 19, 2026 08:25
@frouene frouene force-pushed the fba/doc/minimapShap branch from 10004fb to 4b41004 Compare March 27, 2026 08:15
@frouene
Copy link
Copy Markdown
Contributor

frouene commented Mar 27, 2026

I've updated the shape to fit the new format with pitches

@frouene frouene changed the base branch from cooldown to master March 27, 2026 08:17
@frouene frouene force-pushed the fba/doc/minimapShap branch from 4b41004 to aa66237 Compare March 27, 2026 08:20
Copy link
Copy Markdown
Member

@sbegaudeau sbegaudeau left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What about the existing values in local storage? How are they removed?

:status: proposed
:consulted: Florian Rouëné
:informed: Florian Rouëné
:deciders: Stéphane Bégaudeau
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • It's funny that I'm the decider yet I am not affected this PR nor asked to review it
  • Commits for pitches and adrs uses the doc tag and are not assigned to the issue to not close it
  • The pitch is not merged nor accepted yet the work seems to be done already


== Problem

Currently, the minimap visibility is controlled by a global `localStorage` setting. If a user hides the minimap on one diagram, it remains hidden on all diagrams. Furthermore, diagram specifiers have no way to define a default state for their diagram via the View DSL.
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One sentence per line (the same comment can be repeated for the whole file)

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No it's not done, far from it. I'll do it myself to make this pitch move forward.


1. **View DSL integration:** Add a property to the View DSL, on the `DiagramDescription` to set the initial `showMinimap` state.
2. **State Lookup:** On diagram component mount, the app checks for a user preference in `localStorage` keyed by the diagram ID. If null, it falls back to the default View DSL value.
3. **Removal of Global Key:** Deprecate the existing global `sirius-diagram-mini-map-visibility` key to prevent state pollution.
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remove or deprecate?

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is still written deprecate...

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done


boolean canHandle(IEditingContext editingContext, DiagramContext diagramContext, DiagramDescription diagramDescription);

boolean showMinimap(IEditingContext editingContext, DiagramContext diagramContext, DiagramDescription diagramDescription);
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why showMinimap? It does not show the minimap, it computes the minimap visibility.

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I propose minimapVisible

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's a function, it should start with a verb, something like isMinimapVisible

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The service will have be named isMinimapVisible (I moved the code in another Draft PR) but the field in the graphQL API and description will be named minimapVisible. It is the case for autoLayout

@sbegaudeau sbegaudeau changed the title [6295] Add shape for minimap default visibility [6295] Add pitch for minimap default visibility Mar 27, 2026
@florianbarbin florianbarbin changed the title [6295] Add pitch for minimap default visibility [doc] Add pitch for minimap default visibility Mar 30, 2026

== Rabbit holes
* **Diagram Identification:** If IDs are non-persistent (transient diagrams), the user preference will be lost.
* **Storage Bloat:** If a user views thousands of diagrams, `localStorage` will accumulate thousands of small keys. We should consider to delete the oldest keys when deleting a diagram.
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will require an answer at the technical level (I don't need an ADR for that but it will have to be fixed in the code), we can't just create stuff on the machine of the end users without any cleanup solution.

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The problem here (which also applies to the delete preference ask) is that someone else might have already deleted the project or representation.

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So, at the technical level, we will need at least to track the last time we had to interact with the data in question. If we did not use some local storage data for a year, we can probably delete it

* **Nice-to-have:** A "Reset to Default" button in the UI to clear the `localStorage` override.

== Rabbit holes
* **Diagram Identification:** If IDs are non-persistent (transient diagrams), the user preference will be lost.
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Those are not related, the representation can be transient and its id stable over time

@sbegaudeau sbegaudeau force-pushed the fba/doc/minimapShap branch from 6c7c593 to f7d1c1b Compare April 7, 2026 08:36
Bug: #6295
Signed-off-by: Florian Barbin <florian.barbin@obeosoft.com>
@sbegaudeau sbegaudeau force-pushed the fba/doc/minimapShap branch from f7d1c1b to f8bb85d Compare April 7, 2026 08:36
@sbegaudeau sbegaudeau merged commit bc56f62 into master Apr 7, 2026
2 checks passed
@sbegaudeau sbegaudeau deleted the fba/doc/minimapShap branch April 7, 2026 08:41
@sbegaudeau sbegaudeau self-assigned this Apr 7, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants