- Add dedicatedPage flag to integration registry (25 true, 50 false) - Delete hardcoded nextjs/react/vue/wordpress route pages (wrong metadata) - Hub page routes non-dedicated integrations to /integrations/script-tag - Add 301 redirects for 50 removed slugs → /integrations/script-tag - Migrate guide content from TSX to MDX (content/integrations/*.mdx) - Add gray-matter, next-mdx-remote, remark-gfm dependencies - Add content loader (lib/integration-content.ts) matching ciphera-website pattern - Add prebuild script for integration guide index generation - Sitemap reduced from 83 to 35 URLs with real lastmod dates - Remove seoDescription from registry (now in MDX frontmatter)
43 lines
1.1 KiB
Plaintext
43 lines
1.1 KiB
Plaintext
---
|
|
title: "Ruby on Rails"
|
|
description: "Add Pulse analytics to your Ruby on Rails app. ERB layout integration."
|
|
category: "backend"
|
|
brandColor: "#D30001"
|
|
officialUrl: "https://guides.rubyonrails.org"
|
|
relatedIds: ["laravel", "django", "jekyll"]
|
|
date: "2026-03-28"
|
|
---
|
|
|
|
Add the Pulse script to your application layout with a production environment guard.
|
|
|
|
---
|
|
|
|
## Add to your application layout
|
|
|
|
Use an `if` guard to only load the script in production.
|
|
|
|
<CodeBlock filename="app/views/layouts/application.html.erb">{`<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
|
|
<% if Rails.env.production? %>
|
|
<script
|
|
defer
|
|
data-domain="your-site.com"
|
|
src="https://pulse.ciphera.net/script.js"
|
|
></script>
|
|
<% end %>
|
|
|
|
<title><%= yield(:title) || "My Rails App" %></title>
|
|
<%= csrf_meta_tags %>
|
|
<%= stylesheet_link_tag "application" %>
|
|
</head>
|
|
<body>
|
|
<%= yield %>
|
|
</body>
|
|
</html>`}</CodeBlock>
|
|
|
|
For more details, see the [Rails layout docs](https://guides.rubyonrails.org/layouts_and_rendering.html).
|