How do I apply part styling to a nested Vaadin component? Vaadin components expose "parts" for styling in their published APIs.
Specifically, the vaadin-upload
component hosts another component, vaadin-upload-file
. I can style the main vaadin-upload component alright, but how do I reach the parts of the nested vaadin-upload-file component?
E.g. for the "name" part of vaadin-upload-file
I unsuccessfully tried CSS selectors like
[part="name"] { ... // plain, as if it were passed through
vaadin-upload-file[part="name"] { ... // qualified with the component name
[part="file-list"][part="name"] { ... // qualified by the part of vaadin-upload that hosts the file list
:host([part="file-list"]) [part="name"] { ... // same with :host() selector
This is all in the style of the component that deploys vaadin-upload
.
As the answer made its way to me on a different path, here is the solution for SO:
You can only apply styles to Vaadin components and their sub-components using a custom theme.
Here is a slightly extended way to set this up using a parent theme.
frontend/themes/<my-theme-name>/
components
(to style Vaadin components)styles.css
(even empty)theme.json
with contents but there are other keys for theme.json likeimportCss
,documentCss
orassets
frontend/themes/<my-theme-name>/components/vaadin-upload.css
:frontend/themes/<my-theme-name>/components/vaadin-upload-file.css
:This applies to Vaadin21 (e.g. in Vaadin19 using a parent theme is not working this way).