我想对我的主动管理员启用的rails应用程序进行一些分析。为此,我需要在布局文件中的<script>
标记之前粘贴一些<noscript>
和</body>
代码。不幸的是,我无法做到这一点,因为application.html
布局文件似乎无效,因为ActiveAdmin会呈现自己的布局文件。
是否有可以插入自定义html代码的钩子/地方?
答案 0 :(得分:6)
使用ActiveAdmin 0.6.0和Rails 4.0.5进行测试。
您还可以覆盖活动管理员使用的arbre视图来呈现页脚。在active_admin
初始化程序中添加:
# config/initializers/active_admin.rb
require 'admin/analytics_footer'
ActiveAdmin.setup do |config|
config.namespace :admin do |admin|
config.view_factory.footer = Admin::AnalyticsFooter
end
end
定义视图:
# lib/admin/analytics_footer.rb
module Admin
class AnalyticsFooter < ActiveAdmin::Views::Footer
def build
super
render('layouts/analytics')
end
end
end
并将您的ga跟踪代码放在app/views/layouts/_analytics.html.erb
中。服务器重新启动后,代码段应显示在页面末尾的页脚内。
答案 1 :(得分:2)
好吧,首先你需要将存储库克隆到rails应用程序中,通常你会把它放在供应商目录中但是rails会抛出这个令人讨厌的警告,它会弃用供应商目录样式dir的使用,它如果您要使用3. *版本进行生产并不重要,那么只需在rails应用程序中的vendor或lib目录中执行此操作。
git clone git://github.com/gregbell/active_admin.git
现在更改您的Gemfile
并从您设置的目录中加载gem
gem 'activeadmin', :path => 'lib/activeadmin'
现在您拥有了自己的版本的activeadmin,因此无论您需要编辑什么,都可以直接从该目录进行编辑,包括更改与其捆绑的默认布局。
很少提及建议:
虽然此方法允许您更加自定义活动管理员,但您完全了解要将其更新为更新版本,您需要在必要时进行一些git pull
和合并。
我在jquery-ui-rails插件中使用了这个方法,并且使用了另一个gem,它的工作非常精彩,而且如果你想要添加你想要的宝石本身,你可以贡献宝石。 祝你好运!
----编辑----
正如您在评论中指出的那样,activeadmin并不能完全按照您的预期工作,但不用担心它仍然是一个简单的解决方案。
在引擎盖下,activeadmin使用一个名为arbre
的东西,由同一个开发人员创建和维护。
https://github.com/gregbell/arbre
,它只是ruby的DOM
库。
所以你需要做的是:
转到刚刚克隆的lib/active_admin/views/footer.rb
这是activeadmin应用程序的页脚,正如您可以在build
方法中看到的那样,您可以在add_scripts
方法和下面添加
def add_scripts
script :src => 'http://yoursource.com'
end
我不完全确定arbre
语法如何流动,但不难理解。
答案 2 :(得分:0)
这对我有用。我在activeadmin网站(https://activeadmin.info/10-custom-pages.html)上找到了它。
# app/admin/calendar.rb
ActiveAdmin.register_page "Calendar" do
index do
render partial: 'calendar'
end
end
# app/views/admin/calendar/_calendar.html.erb
<h1>Hello</h1>
<script>
</script>