-
Notifications
You must be signed in to change notification settings - Fork 6
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
Theme not being saved upon close/open #8
Comments
Hi there, I would be happy to take a look at this one if it's still available - if the issue could be assigned to me that would be great. |
sure, thanks for your interest! |
@Spydr06 Just wanted to check how you wanted to approach this. Basically the way I see it, this bug is caused by two issues:
For each of the issues I would propose the following: Saving I think it should be straightforward enough to add some sort of json / yml config file with the relevant enum that the user wishes to choose for their theme. I think you are using some form of json for the saved layouts so I think it makes sense to continue using json here? Also, just wanted to check if you had a preference as to where this config should be saved - maybe at the root of the install. Loading This one is a little trickier because the logic for selecting a theme is quite closely coupled with the UI code (i.e., gaction_change_theme takes in a SimpleAction parameter and is initialised with default values in the ACTIONS array). What we can do is extract some of the logic from "gaction_change_theme" into a more generic function called "change_theme", and have "gaction_change_theme" call this - then, in the intialise method of "Application" we can call "change_theme" without having to pass in a SimpleAction, which as far as I can see is a UI specific thing. The only question remains for me is where the UI value is initialised - because I have tried doing this locally with a hard-coded value and while the theme did change, the UI dropdown was still set to "System Preference". If you could let me know where in the code I could go to change this that would be much appreciated! Let me know if you are happy with the above approach and I can get cracking on it! |
Yes that's how I'd implement it too it too @toadkarter
|
Apols for the late reply - yes that all sounds good, I'm working away at it now :) |
@toadkarter awesome, I'm looking forward to it. Have fun :D |
@Spydr06 I've just finished up the serialization / deserialization part of this task and am moving onto saving / loading the actual theme. I just had two quick questions on this.
Thanks in advance for your help! |
|
Excellent, thanks! I will give this a go now |
author toadkarter <[email protected]> 1696714738 +0100 committer toadkarter <[email protected]> 1696751330 +0100 parent 3b28ab6 author toadkarter <[email protected]> 1696714738 +0100 committer toadkarter <[email protected]> 1696751324 +0100 # This is the 1st commit message: Adds serialized settings file that saves theme state. # This is the commit message Spydr06#2: #Adding functionality for saving theme to config file. # This is the commit message Spydr06#3: #Loading custom theme if a new window has been created. # This is the commit message Spydr06#4: #Setting initial radio button state to what is in the settings when loading Theme. # This is the commit message Spydr06#5: #Changing settings file to save in the OS specific config directory. # This is the commit message Spydr06#6: #Adding Fedora dependencies to Readme. # This is the commit message Spydr06#7: #adding code of conduct # This is the commit message Spydr06#8: #edit code of conduct # This is the commit message Spydr06#9: #edit code of conduct # This is the commit message Spydr06#10: #chore: made Rust CI workflow # This is the commit message Spydr06#11: #added explanatory comments to rust_ci.yml # This is the commit message Spydr06#12: #updated checkout action # This is the commit message Spydr06#13: #used official cargo deny action # This is the commit message Spydr06#14: #use nightly toolchain # This is the commit message Spydr06#15: #Update INSTALL.md # This is the commit message Spydr06#16: #Bump version number # This is the commit message Spydr06#17: #Bump version number to `0.1.2` # This is the commit message Spydr06#18: #new examples # This is the commit message Spydr06#19: #Add macos install instructions # This is the commit message Spydr06#20: #ci: added libadwaita build steps to get CI jobs working # This is the commit message Spydr06#21: #added nsi script # This is the commit message Spydr06#22: #changed directories # This is the commit message Spydr06#23: #added relative path # This is the commit message Spydr06#24: #Delete nsi script directory # This is the commit message Spydr06#25: #Implement mux and demux # This is the commit message Spydr06#26: #add docs for mux, demux # This is the commit message Spydr06#27: #cargo fmt #fix clippy issues encoder decoder examples fix CI issues with `cargo audit` and `cargo deny` improve rendering of connection being drawn add d flip flop, d latch, fix t flip flop Fix examples, add q and !q to flip flops Add docs for flip flops run cargo fmt fix macos shortcuts Update README.md cmd+backspace for deletion on mac Add build instructions for libadwaita Fixing up imports
theme resets every time i open
The text was updated successfully, but these errors were encountered: