Refactor RA options page
Preface
Basically since the first time I had to work on the RA options I hated them. But refactoring isn't exactly simple for such a large passage either, and it is complex enough that it is easy to make things worse.
Problem
The widget style approach and a lot of sub-classing leads to several problems:
- It is very hard to follow the control flow, both for rendering and changing settings. Even simple actions jump around multiple layers of inheritance.
- We cannot use any of our DOM tooling we developed for the rest of the game.
- This also leads to the RA UI looking very different from the rest of the game.
- The logic for allowed values, etc. and the UI rendering are very mixed together.
- Everything is in one file (~5000 lines!), making syntax highlighting struggle and things hard to find.
All this leads to the current RA options page being very annoying to work with:
- Every change is an ordeal, first figuring out what is happening (which takes much more work than other option pages), then finding a way to add the required changes in the limiting framework.
-
rulesAssistantOptions.js
is one of the worst in the number of TS errors, and other code style tools aren't exactly happy either.
Taken together, the RA options page is one of the most complex passages we have, for what is basically just another options page.
Solutions
- Just split
rulesAssistantOptions.js
into multiple files- Pros:
- Least amount of work
- Cons:
- Only solves editor performance and to a degree model/view separation.
- Pros:
- Refactor the options to a page similar to the
Options
passage, using mostlyApp.UI.OptionsGroup
.- Pros:
-
App.UI.OptionsGroup
exists and works well.
-
- Cons:
- There are a number of option variants (target, multi list) which do not exist anywhere else, which would need to be added to
App.UI.OptionsGroup
- RA options setting have a number of similarities (
No default setting
), which would need to be hacked into a new options page.
- There are a number of option variants (target, multi list) which do not exist anywhere else, which would need to be added to
- Pros:
- Use a data-driven approach: A data structure which holds all options, and separate code for rendering the options.
- Pros:
- Model & View are neatly separated. Including into different files.
- It may be possible to attach other data to the rules (Though that would need to be it's own discussion)
- Cons:
- None from me
- One such implementation is !12214.
- This specific implementation does have some problems, mainly about proper typing.
- Pros:
- Some different approach?
What do you think?
If you have opinions or ideas, please comment.
Whatever is decided, I don't have an enormous amount of spare time, so it'll take a while either way.