-
-
Notifications
You must be signed in to change notification settings - Fork 4.2k
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
Vue settings apps #9938
Comments
I just realized we'll have this issue more probably when we move less 'isolated' stuff to vue. Like the share sidebar part. And the contacts menu etc. They all live somewhere in core/js. |
@rullzer independant apps do not need routes :) |
@skjnldsv sure. But it is not about independant apps.
If we'd make them all small independant apps. We'd get a real complex build script I guess. |
It is, they're just apps that are rendering on a div, they're here on every page :)
The sidebar is also just an app, but needs to be pluggable and usable by others apps For the settings, let's keep our php and keep registering our components with php so the script is properly loaded. We don't need to convert this to vue I think :) |
Maybe breaking our core/server into multiple pages would already help: https://webpack.js.org/concepts/entry-points/#multi-page-application |
@ChristophWurst yes, it's planned! :)
I disagree. Having each app their own script is far better I think. |
But separate apps will also mean we have to maintain all the dependencies individually. That's a lot of work, even when using dependabot. |
@ChristophWurst yes it will be. especially when our components will have their own repo as well :) |
@skjnldsv that would of course result in a massive amount of js. Like the contacts menu now is <14 kb. But if everything is bundled it would become at least 100kb. There is still a lot of old jquery/handlebars to get rid of. Like again let me point to the example with the authtokens: https://github.com/nextcloud/server/blob/master/settings/js/authtoken_view.js That is in the settings apps. But how will we include this properly? Do we then add another small vue app inside the settings app? |
Why would it be bigger? Vue is supposed to make our code simpler :)
The main settings ≠ users+apps vue app. |
I think we should at least have a common vue app for all the settings that are part of the core |
@juliushaertl I disagree, the 'plugin' system we have for every app to register their component via php is very efficient. If we want to migrate parts of this, we can create a new app for the settings and add route for full views like the user settings, but other way, I think we should keep thing separate. I prefer not having one big app for every settings and multiple independant modules that are easier to maintain and can't be broken by another issue :) |
Hm, good point, that would also break the possibility to easily add separate setting sections to one settings category. |
ah well. So because we ship all libs for each vue app. Don't get me wrong I love the isolation. But right now vue does create large files. Like https://github.com/nextcloud/server/blob/master/apps/oauth2/js/oauth2.js for the oauth is pretty big compared to https://github.com/nextcloud/server/blob/7b8063a2424ea9f9d87493a23074b62afdd57854/apps/oauth2/js/setting-admin.js Sure I moved some stuff to js that was in php before. But it is mainly from shipping all the libs. I can easily imagine if we do this on the main page as well. And load the contactmenu, sharing sidebar, comments sidebar, version sidebar, files app etc. It can count up quickly in the amount of JS we will load. |
For the main page we could maybe build a core vue app and use v-pre for the content, so other vue apps can just put their stuff in their without interfering with the contactsmenu, etc. Not sure if that would work like that, @skjnldsv ? |
@rullzer then let's not compile the vue lib in it and only load it once for the whole site? Nonetheless, you forgot that vue also includes the templates. And if we want to be fair, removing all of our jQuery mess would probably lighten our load as well :)
We could, but I don't like having a js injecting uncompiled html element. I mean, what's the point then? |
So we ship a global vue version for the vue apps included in the server repo and all other apps should basically bundle their own vue into their apps? Makes sense to me. 👍 |
Obviously this could be harder as this would require to always have the same vue version for ALL of our apps. If we get a major update, we'll have to update all of our apps :) |
yeah lets for now first go with small apps even if they are bigger. In theory we could tell the browser anyways to cache this for a looooong time. I actually like the '1 small app 1 function' kind of thing. Makes it simpler! |
Of course this still would need some decision how to store it then. Like where do we put the authtoken code if we want to migrate that to vue? |
Just as a reference, with dynamic import, webpack will only load the import it needs instead of the whole bundle. :) |
This is fixed by @ChristophWurst with his multiple entrypoints thingy |
Right now the vue settings app already has 2 routes (one for the users page and one for the apps page).
However since we'd like to move more settings stuff (like the apptoken stuff since it still uses handlebars etc) to vue as well. It would be great to find a solution to this issue.
The main problem is that the current router handles different urls fine. However. It it mounted on the
#content
div. Which is the outer diff.The text was updated successfully, but these errors were encountered: