Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Input and i18n refactor #57

Open
62 tasks done
mohsin-r opened this issue Sep 23, 2024 · 2 comments
Open
62 tasks done

Input and i18n refactor #57

mohsin-r opened this issue Sep 23, 2024 · 2 comments
Assignees
Labels
enhancement New feature or request epic Priority: High This task is high priority and should be tackled soon

Comments

@mohsin-r
Copy link
Member

mohsin-r commented Sep 23, 2024

RAMP4 Config Editor: Input and i18n refactor

What is this?

The original code for the config editor was written in a rush. As such, the inputs have a lot of duplicate code. Now that we are working towards switching all inputs from hardcoded English to i18n, this seems like a ripe opportunity to refactor input code and make it cleaner. This involves creating our own custom input.vue and checkbox.vue which has the code for handling all input types, the header, and the small information icon. Then, each input simply calls these components. Therefore, the number of lines of code for each input goes from approximately 4-5 -> 1-2. Another aspect of this refactor would be to update all v-model code to the new recommended defineModel() method.

Progress

This will track which files have completed the switch to i18n and custom input components.

  • components
    • fixtures
      • appbar
        • appbar.vue
        • groups.vue
      • areas-of-interest
        • areas-of-interest.vue
      • basemap
        • basemap.vue
      • details
        • details.vue
      • export
        • export-component.vue
        • export.vue
      • geosearch
        • disabled-search-types.vue
        • geosearch.vue
        • service-urls.vue
        • settings.vue
      • grid
        • controls.vue
        • field-map.vue
        • grid.vue
        • layers.vue
        • merge-grids.vue
        • options.vue
      • help
        • help.vue
      • hilight
        • hilight.vue
      • layer-reorder
        • layer-reorder.vue
      • legend
        • children.vue
        • controls.vue
        • header-controls.vue
        • legend.vue
        • symbology-stack.vue
      • mapnav
        • items.vue
        • mapnav.vue
      • metadata
        • metadata.vue
      • northarrow
        • northarrow.vue
      • overviewmap
        • overviewmap.vue
      • scrollguard
        • scrollguard.vue
      • settings
        • settings.vue
      • wizard
        • wizard.vue
      • fixtures.vue
      • panel-teleport.vue
    • helpers
      • collapsible.vue
      • extent.vue
      • input-header.vue
      • list.vue
    • layers
      • controls.vue
      • draw-order.vue
      • field-metadata.vue
      • fixtures.vue
      • layers.vue
      • metadata.vue
      • state.vue
      • style-legends.vue
      • sublayers.vue
    • map
      • basemaps.vue
      • caption.vue
      • extent-sets.vue
      • lod-sets.vue
      • map.vue
      • tile-schemas.vue
    • loading.vue
    • navbar.vue
    • options.vue
    • panels.vue
    • preview.vue
    • starting-fixtures.vue
    • system.vue
  • config-editor.vue
@mohsin-r mohsin-r added enhancement New feature or request Priority: High This task is high priority and should be tackled soon labels Sep 23, 2024
@mohsin-r mohsin-r self-assigned this Sep 23, 2024
@james-rae
Copy link
Member

Ideas from a rarely-Vue and non-RESPECT dev.

  1. That's a LOT of files. Is it possible to just have a generic "config-ui" template that can be passed some sort of metadata definition object that tells it how to assemble itself? Sort of like what your doing here, but branched out to handle the generic control sets. I'm in no position to know what kind of roadblocks this would cause. Also could be you can't do that level of nesting (essentially having to name generic sub-templates in your metadata which then become real templates that bind correctly to the overall ramp config in the store). Anyway, all I'm really saying is from the outside it looks like this codebase is a lot of boilerplate with small tweaks to define it for each section of the config; if there's a nice way to remove it, great. If it's needed to keep things sane, all good.
  2. Does Respect Editor do anything similar to what your proposing? Or alternately can this approach be applied to the Respect Editor? Thought here is we should strive to have a unified development approach to both editors (and also apply to the soon to be built "Highchart Editor Resolving Many Accessibility Nuances" app). This means a dev who knows how to deal with one can pivot to the other two projects without needing to learn a new paradigm.

@mohsin-r
Copy link
Member Author

That's a LOT of files. Is it possible to just have a generic "config-ui" template that can be passed some sort of metadata definition object that tells it how to assemble itself?

I had this idea in the beginning, where you'd pass in your schema into the component and it would auto build out the UI. Then the app would work even if we revamped the schema for whatever reason. Its difficult to say whether this is worth a shot, mainly because there are a ton of small edge cases that are coded in into the individual templates. You'd need a bunch of ifs for specific cases. For example, for every object you just need inputs for its fields, but then for extents, you also need the extent picker and linking between the map and config extent. Similarly, how would a generic editor code in an autolegend where you have a relationship between the layer and legend configs? We also have some lists that get converted to object key-value pairs, and so on. So the feeling I have is RAMP is too complex to have a generic nested object parsing UI template.
This refactor attempts to take a middle ground, where boilerplate at the input level is abstracted out but we still parse the objects individually, if that makes sense.

Does Respect Editor do anything similar to what your proposing? Or alternately can this approach be applied to the Respect Editor? Thought here is we should strive to have a unified development approach to both editors

The feel of Respect is very different to this. The templates for each type of editor (map, image, slideshow, chart, etc.) are very different and there isn't really any duplicate/boilerplate code. Additionally, the RAMP schema is far more complex than the Storylines schema (and hence has a lot more inputs). The other thing is RESPECT is meant to be a standalone app, whereas this works as something that can be both standalone and embedded into something else. All these factors mean that unified development approach may not make sense. However, I agree that we should have this editor and the Highchart Editor be similar in their development approach.

A lot of the above thoughts are half-baked, so feel free to retort if anything is nonsense.

@mohsin-r mohsin-r added the epic label Oct 8, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request epic Priority: High This task is high priority and should be tackled soon
Projects
None yet
Development

No branches or pull requests

2 participants