# Integrating with Rails This page explains how to integrate Shoelace with a Rails app. This is a community-maintained document. For questions about this integration, please [ask the community](https://discord.gg/mg8f26C). ## Requirements This integration has been tested with the following: - Rails >= 6 - Node >= 12.10 - Webpacker >= 5 ## Instructions To get started using Shoelace with Rails, the following packages must be installed. ```bash yarn add @shoelace-style/shoelace copy-webpack-plugin ``` ### Importing the Default Theme The next step is to import Shoelace's default theme (stylesheet) in `app/javascript/stylesheets/application.scss`. ```css @import '~@shoelace-style/shoelace/dist/shoelace/shoelace'; ``` ### Importing Required Scripts After importing the theme, you'll need to import the JavaScript files for Shoelace. Add the following code to `app/javascript/packs/application.js`. ```js import '../stylesheets/application.scss' import { defineCustomElements, setAssetPath } from '@shoelace-style/shoelace' // ... // This enables all web components for the current page setAssetPath(document.currentScript.src) defineCustomElements() ``` ?> This will import all Shoelace components for convenience. To selectively import components, refer to the [Using webpack](/getting-started/installation?id=using-webpack) section of the docs. ### webpack Config Next we need to add Shoelace's icons to the final build output. To do this, modify `config/webpack/environment.js` to look like this. ```js const { environment } = require('@rails/webpacker') // Shoelace config const path = require('path') const CopyPlugin = require('copy-webpack-plugin') // Add shoelace icons to webpack's build process environment.plugins.append( 'CopyPlugin', new CopyPlugin({ patterns: [ { from: path.resolve( __dirname, '../../node_modules/@shoelace-style/shoelace/dist/shoelace/icons' ), to: path.resolve(__dirname, '../../public/packs/js/icons') } ] }) ) module.exports = environment ``` ### Adding Pack Tags The final step is to add the corresponding `pack_tags` to the page. You should have the following `tags` in the `` section of `app/views/layouts/application.html.erb`. ```html <%= stylesheet_pack_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %> <%= javascript_pack_tag 'application', 'data-turbolinks-track': 'reload' %> <%= yield %> ``` Now you can start using Shoelace components with Rails! ## Additional Resources - There is a third-party [example repo](https://github.com/ParamagicDev/rails-shoelace-example), courtesy of [ParamagicDev](https://github.com/ParamagicDev) available to help you get started. - If you would like to avoid repeating this process, check out the associated [Railsbyte for Shoelace](https://railsbytes.com/templates/X8BsEb).