2.9 KiB
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.
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.
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
.
@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
.
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 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.
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 <head>
section of app/views/layouts/application.html.erb
.
<!DOCTYPE html>
<html>
<head>
<!-- ... -->
<%= stylesheet_pack_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %>
<%= javascript_pack_tag 'application', 'data-turbolinks-track': 'reload' %>
</head>
<body><%= yield %></body>
</html>
Now you can start using Shoelace components with Rails!
Additional Resources
- There is a third-party example repo, courtesy of ParamagicDev available to help you get started.
- If you would like to avoid repeating this process, check out the associated Railsbyte for Shoelace.