-
Notifications
You must be signed in to change notification settings - Fork 638
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
[WIP] New Vue Web UI #1933
Draft
Tofandel
wants to merge
84
commits into
xoseperez:dev
Choose a base branch
from
Tofandel:dev
base: dev
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
[WIP] New Vue Web UI #1933
Changes from 1 commit
Commits
Show all changes
84 commits
Select commit
Hold shift + click to select a range
6b172e8
[WIP] Create a new web ui with vue
Tofandel 230f627
Configured webpack compilation (outputs image in dist/index.html.gz)
Tofandel a8672f3
Move each tab to its own component
Tofandel e139e42
Add environment conditional compilation
Tofandel 907b7c7
Make Form and Input components
Tofandel 0e7335e
New favicon
Tofandel 81cdc76
New favicon
Tofandel c14f03f
Added compile mode for dev +
Tofandel 101c152
Harmonize ws api
Tofandel 7e455b0
Merge branch 'dev' into dev
Tofandel 8e57f4f
Continue template conversion + some styling
Tofandel 3d7189c
Merge remote-tracking branch 'origin/dev' into dev
Tofandel 99400a7
Convert OOP to schema arrays
Tofandel 6e7f90f
Restore start parameter
Tofandel 221bb37
First test unit
Tofandel bb822f7
Add test unit for input
Tofandel 1a6878a
Form unit tests
Tofandel 5c9a717
Designing menu + start grid conversion
Tofandel b15ba1e
Moving alexa integration to it's own tab + Add hint component
Tofandel 15b1ef0
Populating websocket data
Tofandel 4cdcc69
Implement module visibility
Tofandel 15c2dc6
New switch styling + repeater improvements
Tofandel ae997d5
More ws schema refactor
Tofandel d28cb84
Merge branch 'dev' into dev
Tofandel 2c90d11
Added multiselect support
Tofandel a8a0394
Finished all common tabs except sensor
Tofandel 9e9521a
PWA initial setup
Tofandel 5266284
PWA initial setup
Tofandel 508af01
Fix pwa compilation (npm run build:pwa)
Tofandel 066e527
Fix typos
Tofandel a4cadb6
Fix compile errors
Tofandel c5947a4
Fix compile errors
Tofandel 88a29e1
Fix compile errors
Tofandel 9263b1f
Add codeowners
Tofandel 769be42
Add codeowners
Tofandel f3b6565
More ws refactor
Tofandel 60cb976
More ws refactor
Tofandel 6222903
Add favicons + generate pwa icons automatically
Tofandel 3f6e9b3
Add favicons + generate pwa icons automatically
Tofandel b8d00e6
Add favicons + generate pwa icons automatically
Tofandel 2cb0059
Fix conditional loading of pwa
Tofandel 41a2ecf
Replace gif loader by css
Tofandel c4500a3
Add package info for pwa
Tofandel 0e7a486
Refactor integrations
Tofandel bb54a26
Refactor integrations
Tofandel 3f88649
Refactor features
Tofandel 75849f9
Make a vue data table component and code diff analysis to send the data
Tofandel 8e250b0
Multiple fixes + finish features refactor
Tofandel 65e06b9
Merge branch 'dev' into dev
Tofandel e77d0bb
Merge branch 'dev' into dev
Tofandel 7f5e3ea
Work on the PWA
Tofandel c875953
Merge remote-tracking branch 'origin/dev' into dev
Tofandel ae0172d
Move from webpack-conditional-loader to webpack-preprocessor-loader
Tofandel 4045365
Working device scanner
Tofandel 751d621
Style pwa with element-ui
Tofandel 58e1ec5
Add authentication modal
Tofandel e68de35
Add wifi status + refresh info
Tofandel d38b5e8
Add uploader
Tofandel 03f2b03
Add uploader
Tofandel d7f68e3
Add pwa mocking device for 127.0.0.1
Tofandel 74022d8
Improve uploader
Tofandel 3efd905
Update dependencies + optimizations
Tofandel 830761c
Merge branch 'dev' into dev
Tofandel dc202a5
Implement changes of 13.6 to 14.2 in vue ui
Tofandel f7c62f3
Restore scheduler visible and fix rfm69 visible
Tofandel 39ff17b
Fix wifi schema
Tofandel 9dbf4be
Fix relay schema
Tofandel 4af5993
Add ws disconnection dialog
Tofandel 2708706
Various bug fixes
Tofandel 2b1c8f1
Cleanup debug messages
Tofandel ddc7215
Cleanup debug logs
Tofandel 7ac8ae8
Restore debug line break
Tofandel fa8e609
Restore debug line break
Tofandel 4054100
Added hardcode check for wifi
Tofandel 3694b16
New underscore notation for non settings in api
Tofandel 7c16335
Improve schema + fixes
Tofandel b352284
Add options for button + fix build error
Tofandel 17d0bc9
Move options to button + fixes
Tofandel 7c0ac08
Add codacity lint rules + implements websocket callback
Tofandel cf0e786
WIP refactor json buffer alloc + ws action callback
Tofandel ecc04d3
More api and ui rework + test of better allocation
Tofandel 0376955
Merge branch 'dev' of https://github.com/xoseperez/espurna into dev
Tofandel 6e18585
Remove some useless diff
Tofandel 9c9caf0
Fix some merge errors
Tofandel File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note that I was kind of doing the same thing, hardcoded 7 can also be (sizeof(keys)/sizeof(keys[0]))
I changed the behaviour of wifi settings, getSetting() will return hardcoded default.
stored
flag is to avoid removing hard-coded entry accidentally, since on ui reload it will appear again anywayThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I just didn't want to use copyFrom because it was removed from version 6 of the arduino Json lib (Using v5 but if ever we move away)
Also not sure but doesn't it double the ram usage for the array (define + clone, seems redundant)
Edit: Never mind, add also clones the value
I don't get the stored flag
Don't
if (!getSetting({"ssid", index}, _wifiSSID(index)).length()) break;
prevent it from ever being set to false anyway, by not sending wifis that are not set?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See https://arduinojson.org/v6/doc/upgrade/#copyarray
When we have
WIFI1_SSID=something
, getsetting is never emptyThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh I finally got it, so the WIFI can be hardcoded with defines and this flag tells us if it comes from the define or not
But can't they be overwritten? The defines acting just as a default value
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, see
code/espurna/wifi_config.h
They are hard-coded defaults, we can't erase them. It is still possible to "shadow" them, either by setting indexed setting to something else or setting "" empty value
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Okay so I got it all but then there might be an issue, if you overwrite the settings the delete button will still be disabled, but it shouldn't (it wouldn't technically delete it, but would reset it to default)
So maybe just changing the name of the button to 'Reset to default' instead of 'Delete' but the API wouldn't know the default value and would need to retrieve it again
Having a hardcoded flag sometimes complicates things more than it simpifies it :p
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Kind of like that. You can always hit reset-all button though, I guess there could be a specific 'reset wifi settings' one.
pre 1.14.2 versions read hardcoded settings on boot, overwriting runtime settings with those values, so it had the same problem only delayed until the next reset
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
btw, not to speculate on code improvements regarding arduinojson:
#1957 (comment)
you can use it as a local library and build program on host. you can repeat the code from above for yourself, array size does not change when we copyfrom() or add individually, it only stores pointers since it is array of pointers.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah that's what I figured, so there is no difference between the two? It's a matter of personal preference then, taking into account that some schemas are variable with macros (defines), is it possible to create an array with macro conditional to copy from?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
True, effectively it would be the exact same code generated for v5:
https://github.com/bblanchon/ArduinoJson/blob/v5.13.4/src/ArduinoJson/JsonArray.hpp#L151
Slightly different for v6
https://github.com/bblanchon/ArduinoJson/blob/8f8c82d400a2e860e538eed8f92674330186f76f/src/ArduinoJson/Array/Utilities.hpp#L47
But [index] access is also available in v5 (not sure what empty values are though, nulls?)