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

Feat: Loadout Profiles (Draft) #1145

Conversation

Mnemotechnician
Copy link
Contributor

@Mnemotechnician Mnemotechnician commented Oct 26, 2024

Description

This is a draft for an implementation of a solution for loadout profile loading/saving and per-job loadout preferences proposed as in a result of the discussion in #1136.

This PR adds loadout profiles. Each player can have an unlimited number of profiles associated with them. Each profile has a name and a list of items included in it. The player can create per-job loadout preferences, which would make the game automatically load a specific profile instead of their currently chosen one.

This also refactors some parts of the loadouts code that I got particularly mad about.

TODO

  • Backend support (partial)
    • Basic DB/OOP model support
    • DB/OOP character profile conversions
    • Automatic loadout profile loading based on the players job
    • Per-character default loadout profiles
    • Better DB migrations (migrate existing loadouts to the new system, if possible)
  • Frontend support:
    • Make the client not crash
    • Hide the loadouts tab container when no profile is chosen, and propose the player to create a new profile or select one instead
    • Display the current profile in the character editor
    • Support for creating, renaming, and removing profiles
    • Loadout job preferences dialog (or maybe that could be implemented as selectors in the jobs tab instead - we'll see)
  • Testing
  • Something else I guess

Media

TODO

image

Changelog

TODO cl

@github-actions github-actions bot added Changes: C# Changes any cs files Changes: Localization Changes any ftl files Changes: UI Changes any XAML files Changes: YML Changes any yml files labels Oct 26, 2024
@SimpleStation14 SimpleStation14 changed the title Feat: Loadout Profiles (draft) Feat: Loadout Profiles (Draft) Oct 26, 2024
@VMSolidus
Copy link
Member

We have already collectively decided among all of the Einstein Engines maintainers that we wish to go with the solution proposed by Danger Revolution at #1136 (comment) , and will not be going with the solution you have proposed. Since nobody is currently working on Danger Revolution's proposal, you are more than welcome to work on it if you wish.

@Mnemotechnician
Copy link
Contributor Author

We have already collectively decided among all of the Einstein Engines maintainers that we wish to go with the solution proposed by Danger Revolution at #1136 (comment) , and will not be going with the solution you have proposed. Since nobody is currently working on Danger Revolution's proposal, you are more than welcome to work on it if you wish.

Please read the PR description or code for once. This IS the danger's solution.

@VMSolidus
Copy link
Member

We have already collectively decided among all of the Einstein Engines maintainers that we wish to go with the solution proposed by Danger Revolution at #1136 (comment) , and will not be going with the solution you have proposed. Since nobody is currently working on Danger Revolution's proposal, you are more than welcome to work on it if you wish.

Please read the PR description or code for once. This IS the danger's solution.

It was not clear that you were making Danger's solution, because you mentioned limited profile numbers in the PR description, I apologize for the misunderstanding. This is fine.

@Mnemotechnician
Copy link
Contributor Author

Although- it would seem I miscalculated a bit, and danger proposed slightly more than I was aiming for with this PR - I was intending to create something like subprofiles, rather than complete separate character profiles. I can close it and maybe begin anew later, if I- get some motivation to do so.

angelofallars pushed a commit to angelofallars/Einstein-Engines that referenced this pull request Jan 18, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Changes: C# Changes any cs files Changes: Localization Changes any ftl files Changes: UI Changes any XAML files Changes: YML Changes any yml files
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants