活动管理员 - 如何在标记之前添加自定义脚本?

时间:2013-02-17 21:14:24

标签: ruby-on-rails activeadmin

我想对我的主动管理员启用的rails应用程序进行一些分析。为此,我需要在布局文件中的<script>标记之前粘贴一些<noscript></body>代码。不幸的是,我无法做到这一点,因为application.html布局文件似乎无效,因为ActiveAdmin会呈现自己的布局文件。

是否有可以插入自定义html代码的钩子/地方?

3 个答案:

答案 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 dir中的此文件

这是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>