This doc contains information that will help you migrate your code from an older version of SMUI to a newer one. Things that you will need to change in your existing code will be written here. It would also be helpful to check the MDC changelog if the upstream MDC versions has changed between SMUI versions.
SMUI 8 has migrated to Svelte 5's new Runes mode. As such, it expects things like snippets and only some props are bindable.
Note to Devs: update indexOf()
with $state
arrays or items to findIndex()
to avoid bugs.
Note to Devs: remove x = x;
statements after push()
and the like. They aren't needed anymore with Svelte 5's new $state rune.
- Svelte 5 is required! Svelte 4 will not work.
- Events have been renamed, removing colons and adopting CamelCase. (ex: SMUISwitch:change to SMUISwitchChange)
- Event modifiers are now wrapper functions, exported from
@smui/common/events
. - Slots must be migrated to snippets.
- The deprecated "MDC" events have been removed. All event names should be migrated to the corresponding "SMUI" event names.
- The "Fixation" theme now uses Tahoma as its large header font.
- Select no longer defaults the value to an empty string, meaning you must either set the value given to it to an empty string or provide a key function that returns an empty string for an undefined value.
- TabBar now expects a
tab
snippet instead of usinglet:tab
. - Chips' Set now expects a
chip
snippet instead of usinglet:chip
. - Chips' Set key function is now required to return
string
, notstring | number
. - SegmentedButton now expects a
segment
snippet instead of usinglet:segment
. classAdderBuilder
is no longer available. Instead, theClassAdder
component is exported.- Svelte 5 doesn't seem to provide a way to reuse components the way classAdderBuilder needs. The version in beta.2 and before works only on the first render, but props were not reactive.
- Event listeners for DOM events no longer need to use the CustomEvent type. They can use the correct type, like MouseEvent and KeyboardEvent.
- New premade theme, "Bubblegum".
- Chip Input
- A new component!
SMUI 7 migrated to upstream MDC 14.0 from 13.0: https://github.com/material-components/material-components-web/blob/master/CHANGELOG.md#1400-2022-04-27
I spent a day flexing every graphic design muscle in my body, and made some THEMES! SMUI 7 can now be styled with a custom theme, the default theme, or brand spanking new premade themes. This makes it much easier to get started with SMUI.
- Tooling now must be Svelte-aware. This means adding conditional export names to Rollup and Webpack config. See installation docs.
- SMUI 7 (after v7.0.0-beta.9) is no longer compatible with Svelte 3. It now requires Svelte 4.
- If you had started using
component={Svg}
, you need to usetag="svg"
after v7.0.0-beta.12. - The
@smui/common/elements
components are gone. Just set thetag
prop on components now (like<Button tag="div">
).- Internally, they are replaced with the
SmuiElement
component exported from@smui/common
. It takes atag
prop and creates an element dynamically with that tag name. You shouldn't ever need to useSmuiElement
directly.
- Internally, they are replaced with the
- The "*ComponentDev" types (like
MenuComponentDev
) are gone. You can now use the component as its type. Components that can take acomponent
ortag
prop (likeButton
) have required generic arguments that you can use to tell it which tag you're using. - If you're using
classAdderBuilder
, you need to usekeyof SmuiElementMap
instead ofstring
as its generic argument. - The
dispatch
function in@smui/common
will now throw an error if either theEvent
object is not available or theelement
is not provided. - The
Input
component from the@smui/textfield
now setsvalue
toNumber.NaN
when the input is empty.
- Autocomplete
- The
SMUIAutocomplete:selected
event is now cancelable.
- The
- Banner
- New
autoClose
prop. - New
SMUIBanner:actionClicked
event. It is fired when an action is clicked andautoClose
isfalse
.
- New
- Bottom App Bar
- A new component!
- Dialog
- New
sheet
prop. - New
noContentPadding
prop.
- New
- FAB
- New
focusRing
prop. Use this to support rendering focused FABs in High Contrast Mode.
- New
- List
- New
disabledItemsFocusable
prop. - New
wrapper
prop on Item. This should be used for items that only act as the container of a nested list. - New
focusItemAtIndex
function.
- New
- Menu
- New
SMUIMenu:closedProgrammatically
event.
- New
- Menu Surface
- New
SMUIMenuSurface:opening
event. - New
openBottomBias
prop.
- New
- Slider
valueToAriaValueTextFn
now gets athumb
argument.- New
hideFocusStylesForPointerEvents
prop. Comes from upstream. - New
minRange
prop to limit selectable range.
- Switch
- New
focusRing
prop. Use this to support rendering focused switches in High Contrast Mode.
- New
SMUI 6 migrated to upstream MDC 13.0 from 11.0: https://github.com/material-components/material-components-web/blob/master/CHANGELOG.md#1300-2021-09-24
- For
@smui/common
,@smui/textfield
,@smui/select
, and@smui/snackbar
, if you ever import something like@smui/snackbar/kitchen/index
or@smui/textfield/helper-text/index
, you need to remove the/index
from the end of that import. (This does not apply to Sass imports.)- Here's a regex you can use in VS Code to search for these: @smui/(common|textfield|select|snackbar)/[\w-]+/index
- The '/styled' import endpoints have been removed. You will need to import the '/index' endpoint from Sass yourself if you were using the Advanced Styling Method.
- Switch
- No longer emits "change" event, use "SMUISwitch:change" event instead.
- MDC events are now dispatched with "SMUI" instead of "MDC" prefix. They are dispatched as both though, so your code shouldn't break. You should still update your code to use the new "SMUI" prefix anyway.
- There's no longer any required Vite config. Big thanks to Ben McCann for clearing up my misconceptions and helping me fix the package.json files.
- Accordion
- A new component!
- Autocomplete
- A new component! Huge shoutout to Lorenzo Fiore who originally authored the component!
- Badge
- A new component!
- Common
- New announce function in the "internal" export.
- Paper
- New variants!
- Switch
- No longer needs
valueKey
prop. - Default color is now "primary".
- No longer needs
- TypeScript!!! You don't need to use TypeScript, but you do need to use the TypeScript preprocessor for Svelte.
- Events have been renamed from like "SMUI:component:sub-component:event" to "SMUIComponentSubComponent:event".
- Elemental components (from @smui/common) should be imported as named imports from
@smui/common/elements
instead, so that they have the right types. - The
/bare
import paths have been removed. (The default import path has been unstyled since v4.)
- Event modifiers have changed to use "$" instead of ":" (
on:click$capture={handler}
), so that all events, even MDC events, can be bound with modifiers.- The old ":" syntax will still work, it will just give a warning in the console.
Components no longer import styles from their "index.js" files. If you were using "/bare" before, you don't need to anymore. If you were relying on styles being imported, you now need to use the "/styled" endpoint for components.
Check out the new smui-theme package. It can help you with your themes.
SMUI 3.1 migrated to upstream MDC 11.0 from 10.0: https://github.com/material-components/material-components-web/blob/master/CHANGELOG.md#1100-2021-04-15
You should update your MDC dependencies to 11.0 as well.
- MDC-Web chips trailing actions class changed.
- MDC-Web list classes changed.
- Banner
- Add focus trap on the banner.
- Dialog
- New
fullscreen
prop. - New
over
slot.
- New
- Menu Surface
- New
maxHeight
prop. - New
horizontallyCenteredOnViewport
prop.
- New
- Slider
- Rounds values to correct decimal places based on
step
prop.
- Rounds values to correct decimal places based on
- Tooltip
- New
attachScrollHandler
andremoveScrollHandler
functions for adding additional scrollable elements to handle. Both accept a function.
- New
You will need to migrate to Dart Sass. node-sass
is no longer supported, as it is deprecated and too old now.
npm un -D node-sass
npm i -D sass
SMUI 3 migrated to upstream MDC 10.0 from 4.0: https://github.com/material-components/material-components-web/blob/master/CHANGELOG.md#1000-2021-02-05
There are newly updated instructiong for using SMUI in Sapper.
- MDC-Web migrated to the "@use" syntax, so mixins, functions, and variables are namespaced by the "@use" statement now instead of a prefix.
- Theming has changed, so you'll need to update your "_smui-theme.scss" file. Follow this guide.
- Chips
- You now need to use
let:chip
on the set and pass it to the chip with{chip}
. - Chips now export LeadingIcon, TrailingIcon, and TrailingAction, instead of Icon.
- Removed
selected
prop on Chip.selected
prop on Chips is now the only way to set the selected chip(s), and it/they should be identical to one/some of the entries inchips
(pass objects by reference). - Don't provide any
tabindex
props to any of the Chips, Texts, or the Set. They will manage their own tabindex. - On TrailingAction, use
icon$class
to add classes to the icon element.
- You now need to use
- Data Table
numeric
prop on Cell should now also be set on Head Cells.
- Dialog
- Open state is now controled by an
open
prop, instead ofopen
andclose
functions. There are alsoisOpen
andsetOpen
functions. - Lists should now be placed below
Content
element, rather than being theContent
component. For selection from a list, use the newselection
prop on the dialog. - Slider dialogs are styled a bit differently. See the demo.
- Open state is now controled by an
- Icon Button
- No longer emit 'MDCIconButtonToggle:change' event without the
toggle
prop. Instead, listen for click event.
- No longer emit 'MDCIconButtonToggle:change' event without the
- Linear Progress
- Removed
reversed
prop.
- Removed
- List
radiolist
andchecklist
props renamed toradioList
andcheckList
.
- Menu Surface
- Anchor action now takes
addClass
andremoveClass
instead ofclassForward
(like Ripple).
- Anchor action now takes
- Ripple
- Ripple's options have changed considerably.
- Select
- This is almost completely rewritten. You will need to migrate code for it. Check out the demo page.
- Helper Text in no longer a component. Instead, a
svelte:fragment
with text now goes inside the component in the "helper" slot. Its ID and ARIA attributes are set automatically. - Removed
withLeadingIcon
andselectedIndex
props. - You no longer need
withLeadingIcon
. Instead, put Icon into the "leadingIcon" slot. - You should now set
required
prop on the Select instead ofinput$required
.
- Slider
displayMarkers
prop renamed totickMarks
.step
now defaults to 1 (same as the range HTML input).
- Tab
- Removed
active
andfocusOnActivate
props. (No longer needed, since TabBar controls them.)
- Removed
- TabBar
- Removed
activeIndex
prop.active
prop is now the only way to set the active tab, and it should be identical to one of the entries intabs
(pass objects by reference).
- Removed
- Textfield
- This is almost completely rewritten. You will need to migrate code for it. Check out the demo page.
- Helper Text and Character Counter now go inside the component in the "helper" slot. Their IDs and ARIA attributes are set automatically.
- Character Counter in a
textarea
Textfield goes in the "internalCounter" slot. - Removed
fullwidth
,dense
,withLeadingIcon
, andwithTrailingIcon
props. - You no longer need
withLeadingIcon
orwithTrailingIcon
. Instead, put Icons into the "leadingIcon" and "trailingIcon" slots. - You should now set
required
prop on the Textfield instead ofinput$required
. - Manual setup now requires passing the sub-components into Textfield with
input
,floatingLabel
,lineRipple
, andnotchedOutline
props.
- Paper
- New
paper-color
mixin.
- New
- Switch
- New
color
prop.
- New
- All components have a
getElement
function that will return their top level DOM element. - All components now forward all events, and only listen for them if bounded.
- They can also take event modifiers with the ":" syntax istead of "|" (
on:click:capture={handler}
).
New Components
- Banners
- Circular Progress
- Layout Grids
- Segmented Buttons
- Tooltips
- Touch Target Wrappers
New Features in Existing Components
- Chips
- New
nonInteractive
prop on Set. - New
shouldFocusPrimaryActionOnClick
prop on Chip.
- New
- Common
- Icon now takes a
component
prop.
- Icon now takes a
- Data Table
- New
stickyHeader
prop. - New
columnId
prop on Cell (defaults to an automatic ID). - New
rowId
prop on Row (defaults to an automatic ID). - Pagination
- Progress Indicator
- Column Sort Buttons
- New
- Dialog
- New
selection
prop.
- New
- Drawer
- New
fixed
prop (defaults to true). - New
isOpen
function.
- New
- FAB
- New
touch
prop.
- New
- Form Field
- New
noWrap
prop.
- New
- Icon Button
- New
ariaLabelOn
andariaLabelOff
props for toggle buttons.
- New
- Menu
- New
isOpen
function. - New
setOpen
function. - New
setDefaultFocusState
function.
- New
- Menu Surface
- New
fullWidth
prop. - New
anchorMargin
prop. - New
MDCMenuSurface:closing
event.
- New
- Select
- New
hiddenInput
prop. - New
key
prop for using objects as options.
- New
- Slider
- New
range
,start
,end
props for range sliders. - New
valueToAriaValueTextFn
prop for updating the ARIA value attribute.
- New
- TabBar
- New
tabScroller$align
prop.
- New
- Textfield
- New
prefix
andsuffix
props. - New
validateOnValueChange
prop. - New
input$resizable={false}
prop to disable textarea resizing. - New
helperLine$
"$" props passed to the helper line.
- New
- Top App Bar
- New
scrollTarget
prop.
- New
If you have trouble upgrading with these instructions, you can raise an issue on GitHub.
SMUI 2 migrated to upstream MDC 4.0 from 3.0: https://github.com/material-components/material-components-web/blob/master/CHANGELOG.md#400-2019-11-02-1
- Chips
- Text component is now required.
- Now use their own Text and Icon components. The common ones will not work.
- Icon no longer requires
trailing
prop. That is the default. - Checkmark component is no longer required. It is added automatically.
- Menu and Menu Surface
- hoistMenuToBody function removed.
- Select
enchanced
prop is removed. All selects are enhanced now.selected
prop on Option is no longer required and probably should not be used.- You now need to pass a class into
anchor$class
andmenu$class
with a width value set.
- Button
- No longer has a
dense
prop. Use the mixin from MDC.
- No longer has a