-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[discuss] New Platform style support for plugins #42185
Comments
Pinging @elastic/kibana-design |
Pinging @elastic/kibana-operations |
Pinging @elastic/kibana-platform |
In practice, we only need the following from a load order perspective
Generally we'd prefer the latter approach you mention, and that Kibana ONLY loads the css files for the plugins on the current page. There have been cases where we've been very worried about bleedy CSS. I'd highly suggest talking with @thompsongl. We're in the early stages of moving EUI (and Kibana) to a more modularized system. He can give you the full overview. The above will be fine in the short term, but likely we can work together on something more flexible for you long term. |
We also need to consider the building aspect of SCSS. Currently, this is baked into uiExports and the legacy server code ( Should this be coupled to the server process at all? Seems like moving this into the optimizer / build process would make more sense so that we don't need to ship sass with our distributable. In terms of the plugin API, it may make sense to go with a convention-over-configuration approach here, similar to how the webpack bundling works by directory structure. For example, instead of specifying a JavaScript API to define SCSS entrypoints, we could require all plugins to simply have a single The Platform could then handle loading the compiled CSS on the page. Our first pass could be very dumb (just load everything) and we could make this more sophisticated as we go (load and unload CSS based on the app on the page). One caveat here is that plugins can have more than one application, so there's not exactly a one-to-one mapping from a single CSS output to a single application. The other caveat is that plugins may add CSS that is actually used by UI that doesn't live inside an application (eg. embeddables, chrome nav controls, global toasts or modal UI). One thing I want to make clear is that what the Platform Team needs from the Operations Team is mostly the migration of the build-side of SCSS files, not the browser loading aspect. |
@joshdover, knowing most plugin authors desire to move back to CSS in JS for multiple reasons, including CSS module support. I am thinking there might be a quick near-term solution without being blocked on the new build system. If we can remove the new platform plugins from being included in the optimizer build in production, we can then re-introduce the CSS loader into Webpack. This would have the added benefit of immediately reducing the number of CSS files in production, as well as beginning to slowly trim down the optimizer as plugins are migrated. Thoughts? |
I'm a big fan of that option. Another benefit is that we can defer loading CSS that isn't used yet via async imports that we already have for application bundles. |
@mistic lets discuss this next week. |
This issue is now being tracked as part of #53532 |
Before the initial SCSS support, all styles were loaded with JS as with most modern web applications. Given the ever-increasing optimization times in produce, we chose to remove styles from Webpack and ship them at CSS in the build. When loading the styles, we went the simplest route which was to load all plugin CSS files on Kibana load. This was fine when a few plugins were using it, but that has not scaled.
Given that we need to add styles support to the new platform, we need to give some thought as to how we would like to see them handled. Here are a few options:
A route which concatenates all plugin styles into a single request
Pro:
Cons:
Leave it to the plugin to asynchronously load styles
Pro:
Con:
I prefer the latter approach. It would keep the request size and style parsing to a minimum and would best scale as more plugins are added. However, I would like to hear some other folks opinion before moving forward.
The text was updated successfully, but these errors were encountered: