Tips & Troubleshooting
Useful information to use while developing your add-on UI's with Spectrum.
Tips
Using icons
You can import and use an icon from the Spectrum icon libraries provided in the icons-workflow
and icons-ui
libraries.
- icons-workflow - icons representing graphical metaphors such as a document, share symbol, trash can, etc.
- icons-ui - icons that are parts of a component definition like an X, magnifying glass or checkmark.
To use these icons, first add the associated library to your project by installing them from the command line, or via the package.json
, then import them into your JS. For example:
Copied to your clipboard"@spectrum-web-components/icons-ui": "0.39.4","@spectrum-web-components/icons-workflow": "0.39.4",
Then import and use them; for instance:
Copied to your clipboardimport "@spectrum-web-components/icons-workflow/icons/sp-icon-play-circle.js;"import '@spectrum-web-components/icons-ui/icons/sp-icon-arrow75.js';
Copied to your clipboard<sp-icon-play-circle size="s"></sp-icon-play-circle><sp-icon-arrow75 size="m"></sp-icon-arrow75>
NOTE: Icons adhere to the Spectrum Design t-shirt sizing, with a default of size="m"
(for medium).
You can also use the [sp-icon]
package and specify an image directly via the src
attribute, either with the image reference, or a data URL. Both are shown below for an example:
Copied to your clipboard<sp-icon src="icon-144x144.png"/><sp-iconsize="l"label="Previous"src=""/>
You can also supply an svg
to the <sp-icon>
component, as shown below:
Copied to your clipboard<sp-icon><svgxmlns="http://www.w3.org/2000/svg"viewBox="0 0 22 22"role="img"fill="currentColor"height="18"width="18"aria-hidden="true"><pathd="M19.75,10.04h-15l5.97-5.97a.483.483,0,0,0,0-.7l-.35-.36a.513.513,0,0,0-.71,0L2.24,10.44a.513.513,0,0,0,0,.71l7.39,7.84a.513.513,0,0,0,.71,0l.35-.35a.513.513,0,0,0,0-.71L4.76,11.5H19.75a.25.25,0,0,0,.25-.25v-.96A.25.25,0,0,0,19.75,10.04Z"></path></svg></sp-icon>
Using an iconset reference from one of the icons-workflow
or icons-ui
packages in the name
on an sp-icon
should no longer be used (ie: <sp-icon name="ui:Arrow100"></sp-icon>
), since it's deprecated. Use the specific named import mentioned in the first bullet above, instead.
Spectrum sizing
In Spectrum, there are two main sizing concepts to understand:
- scale - the overall size of all of the components on the page, ie: medium for desktop, or large for touch, for instance.
- t-shirt sizes - the size of a specific component, set as a variant or modifier to that component (ie:
size="m"
). Note: a component with a t-shirt sizing is still affected byscale
.
Fonts
There are a set of Adobe Clean fonts automatically injected by the Add-on UI SDK for use in your add-ons. You can see which are available by checking the documentation. You can also see them while running an add-on via the browser developer tools, as shown in the following:
Debugging
- Use the browser developer tools to inspect the HTML, and search for the
add-on-iframe-slot
element to find the add-on specific code container. - From the developer tools, click into the variables in the stylesheets to see their values.
- Dig into the
node_modules/@spectrum-web-components
folder and view the component details to help better understand why an issue might be happening. - Use the API tab in the component reference or the Storybook to locate the details around the supported events.
Styling with Spectrum CSS
Use Spectrum CSS variables for padding, gaps between controls, and general layout. In addition, since Spectrum Web Components do not include any specific components for typography, you can also use variables to style the typography.
Some benefits to using Spectrum CSS variables to style your components over absolute values:
- By using Spectrum CSS global variables, you can ensure your UI aligns with the Spectrum design system, and if the design system changes, your UI will automatically update to the new design system.
- Using Spectrum CSS variables to style your UI allows you to easily update the styles across your entire application by simply updating the value of the variable. If you decide to change a color used throught your app, for example, you can update the value of a single Spectrum CSS variable, and all the elements that use that variable will be updated automatically.
Layout and typography styling
Layout - the layout of your add-on can be adjusted by using global variables defined in the
@spectrum-web-components/styles/express/spectrum-core-global.css
folder in thenode_modules
of your add-on.Some general guidelines
--spectrum-global-dimension-static-size-*
variables should be used when the dimension needs to be consistent across different elements or components, such as a uniform padding or margin throughout the application. It should also be used when a dimension needs to be adjusted based on a specific context, such as a container element or viewport size.--spectrum-global-static-size-*
variables should be used for values that are not necessarily consistent across the application, but need to be adjusted based on the content or use case. In general, these variables are typically used for text-related styles that may vary based on content or context.To summarize:
Use
--spectrum-global-dimension-static-size
variables for for dimensions such aswidth
,height
,padding
,margin
, or general spacing variables.Use
--spectrum-global-static-size
variables for things likefont-size
,line-height
,border-radius
, etc.
Color variables are provided as part of the
theme
imports. The color value’s contrast with the background increases as the value increases, so colors progressively get darker in a light theme, and lighter in a dark theme (ie:--spectrum-global-color-purple-600
is lighter than--spectrum-global-color-purple-900
in alight
theme but darker in adark
theme). Preview the color palette in the reference for more details.TIP: Use theme-specific color variables, such as those defined in the light theme for Express, located in the CSS files in your
@spectrum-web-components/styles/express/*
folder, for general uses of color in your add-on. For example, when the color will be applied to text, icons, or the borders of a component. Use static color variables defined in the overalltheme.js
when the color should be fixed and not dependent on the theme. The typical naming scheme is:--spectrum-global-color-purple-600
and--spectrum-global-color-static-purple-600
, respectively.Typography classes can be used to control your typography elements by importing the
typography.css
. For instance:Copied to your clipboardimport "@spectrum-web-components/styles/typography.css";<div className="spectrum-Typography"><p className="spectrum-Heading spectrum-Heading--sizeL">This is a custom large header text</p></div></h3>Note: by default, typography components do not include any outer margins, but adding the
spectrum-Typography
class to your container will provide margins to the typography components within it. You can try out this codepen to see an example of this, by removing thespectrum-Typography
from thediv
and adding it back to see the difference in the margins. It also illustrates some of the typography classes for example usage.Overriding variables: you can override the Spectrum CSS variables as needed in your add-on as well, by setting the name of the spectrum variable to a new value, for instance:
Copied to your clipboard--spectrum-global-dimension-font-size-150: 16px;
Component modifier variables
Components have a set of variables defined to use for modifying properties specific to that particular component. They are prefixed with --mod-*
, and should be used when you want to customize the styling of a specific component.
These variables are particularly useful in cases where you want to use a component in multiple places with different styles. By using custom variables, you can easily adjust the styling of a component in one place, and have those changes apply to all instances of the component throughout your application.
In the sample app, you used custom modifiers for a few of the components, including to modify the Slider font size, some Swatch border properties and to adjust the Switch component, for reference.
A list of the prefixed custom properties for each UI component can be found in the Spectrum CSS repo's mods.md
file for each component. For instance the swatch component modifiers are listed here, and the slider component modifiers here.
An example of their usage to modify the Slider is provided below for a reminder of what they look like:
Copied to your clipboard.color-well {cursor: pointer;--mod-swatch-border-thickness: var(--spectrum-divider-thickness-small);--mod-swatch-border-color: var(--spectrum-global-color-gray-200);}
Troubleshooting
Known issues
Spectrum Web Component version conflicts
You must use matching component versions for all Spectrum Web Components (or swc-react components) in your
package.json
or you will receive errors that are often not clear to determine the cause, so save yourself time and double check this if you're having issues running your add-on.This is mentioned in this tutorial a couple of times, but there is a known issue seen when using
@spectrum-web-components
(or@swc-react
) packages with version0.40.3
. At the moment0.39.4
is a stable version that should work if you suspect a component version issue.Picker flicker
Currently there's a known issue with the
swc-react
Picker component in versions0.36.*-0.40.*
where you will see the UI flicker when clicking it.
Troubleshooting FAQ
This section is provided to help troubleshoot any errors you may encounter while following this tutorial.
Why do I see registry errors in the console when running my add-on, for instance:
Uncaught DOMException: Failed to execute 'define' on 'CustomElementRegistry': the name "sp-icon-chevron100" has already been used with this registry
andBase.dev.js:164 Attempted to redefine <sp-icon-chevron100>. This usually indicates that multiple versions of the same web component were loaded onto a single page. https://opensource.adobe.com/spectrum-web-components/registry-conflicts
This is probably due to mismatched versions of the
@spectrum-web-components
(or@swc-react
) packages being used in yourpackage.json
. Don't forget to runnpm install
after updating yourpackage.json
to match the versions.Solution: open your
package.json
file and set all of the versions to the same one (ie:0.39.4
). You can always reference the sample projects as needed.Why do I see the following error when trying to build or start my add-on with the CLI?
ERROR in ./node_modules/@spectrum-web-components/button/src/Button.dev.js 145:6-78 Module not found: Error: Can't resolve '@spectrum-web-components/progress-circle/sp-progress-circle.js' in '/Users/hollyschinsky/spectrum-workshop-2023/workshop-projects/bingo-card-addon-react-start/node_modules/@spectrum-web-components/button/src' ... Field 'browser' doesn't contain a valid alias configuration resolve as module
Solution: there's a known issue seen when using
@spectrum-web-components
(or@swc-react
) packages with version0.40.3
, which is the latest version that are installed at the time of writing this tutorial, unfortunately. The solution is to update the versions of all components used in yourpackage.json
file to a known stable one like0.39.4
. Don't forget to runnpm install
after updating to ensure the stable versions are installed before trying to build and run your add-on again.Is there a general solution to try when something doesn't work right with the CLI?
Solution: try running
npx clear-npx-cache
to ensure the latest CLI version is installed, then run the CLI commands again.Why isn't the CLI building the output to the
dist
folder as I would expect? Did I forget to include awebpack.config.js
file in the root of my project?Solution: make sure your
webpack.config.js
is in the root of your project and not thesrc
folder. You could also double check to ensure your project has the dependencies needed to use webpack. You could also try to replace yourpackage.json
file with the one from the provided project.I'm building a react-based add-on and it's not building correctly. Does the
scripts
object in thepackage.json
of my add-on ensure the--use webpack
parameter is used?Solution: ensure your
package.json
has the followingscripts
block. If it doesn't, it will not use webpack to build and start, package etc.Copied to your clipboard"scripts": {"clean": "ccweb-add-on-scripts clean","build": "ccweb-add-on-scripts build --use webpack","start": "ccweb-add-on-scripts start --use webpack","package": "ccweb-add-on-scripts package --use webpack"}Are all of my components wrapped within an opening and closing
<sp-theme>
or<Theme>
tag?Solution: make sure all your UI components are surrounded by the corresponding opening and closing theme tags for either Spectrum Web Components or
swc-react
, or you will not see the components rendered properly.
Still having issues? Ping me on discord (username hollyschinsky
) or email me at hschinsk@adobe.com for help.
Resources
The following list of resources can be used to learn more about using Adobe's Spectrum Design System:
- Example codepens
- Adobe Express UX Guidelines
- Adobe Spectrum Storybook Web Components Storybook
- Adobe Spectrum Tokens Visualizer
- Adobe Spectrum XD Plugin
- Adobe Spectrum Figma plugin
- Adobe Spectrum CDN Bundle
- Reminder: you should only use this option for quick testing, but note that it will default to the Spectrum base theme unless you include the Express theme bundles specifically. See the example codepens for details.
- Add-on Code Samples
- Color Wheel