Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
ActiveAdmin Better Practices@関西Ruby会議06
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
KUROKI Shinsuke
July 11, 2015
Programming
400
0
Share
ActiveAdmin Better Practices@関西Ruby会議06
KUROKI Shinsuke
July 11, 2015
More Decks by KUROKI Shinsuke
See All by KUROKI Shinsuke
冴えてるRailsエンジニアの育て方
skuroki
7
11k
伝わるコードレビューのために
skuroki
5
7.3k
進行中の開発プロジェクトで増えていくテストを自動で回し続けるために行ったいくつかのこと
skuroki
11
45k
Refactoring Ruby Edition in-house reading
skuroki
0
220
ActiveDecorator導入の話
skuroki
5
260k
Other Decks in Programming
See All in Programming
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
11
3.1k
タクシーアプリ『GO』の バックエンド開発のおける AI利活用と若者のすべて
pyama86
3
1.8k
Moments When Things Go Wrong
aurimas
3
130
Lessons from Spec-Driven Development
simas
PRO
0
100
誰も頼んでない機能を出荷した話
zekutax
0
150
New "Type" system on PicoRuby
pocke
1
390
今さら聞けないCancellationToken
htkym
0
210
Augmenting AI with the Power of Jakarta EE
ivargrimstad
0
410
Why Laravel apps break—Mastering the fundamentals to keep them maintainable
kentaroutakeda
1
320
技術記事、AIに書かせるか、自分で書くか? 〜それでも私が自分の手で書く理由〜 / #QiitaConference
jnchito
2
1.2k
oxlintはeslint/typescript-eslintを置き換えられるのか
shomafujita
2
290
Copilot CLI の継戦能力を高める コンテキスト管理
nozomutu
1
1.1k
Featured
See All Featured
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
170
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
240
We Are The Robots
honzajavorek
0
240
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
230
Claude Code のすすめ
schroneko
67
220k
Ruling the World: When Life Gets Gamed
codingconduct
0
240
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
580
Docker and Python
trallard
47
3.9k
ラッコキーワード サービス紹介資料
rakko
1
3.5M
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.3k
Transcript
ActiveAdmin Better Practices 2015/07/11 株式会社Aiming 黒木慎介
自己紹介 • 株式会社Aimingのエンジニア(大阪web 開発チームのリーダー) • Railsなどを使ってオンラインゲーム運営 を助けるものをいろいろ作っています • Ruby/Rails歴5年 •
今年の5月から大阪スタジオに勤務してい ます
提供 Aimingは関西Ruby会議06に協賛しています!
目次 • ActiveAdmin概要 • TIPS初級編 • TIPS中級編 • TIPS上級編
ActiveAdmin概要 • 少ない記述量で定型的なCRUDの画面と処 理を実装できるgem – CRUD=データの登録・閲覧・更新 • 管理ツールを作るのに使ってます • 規模はかなりでかいです…
例えばこんなmodel
こういうのを書くと
こんなんとか
こんなんとか
こんなんができます
もうちょっと書くとこんな感じ
便利そうに見えるが… • 定型的なCRUD以外の処理をさせようとす るととたんにドはまりしたりする – 管理ツールの開発をしていると、定型的な CRUDでは満たせない要求が必ず出てくる – ActiveAdminで管理ツールを作る時には、い かにこのはまりを回避するかが重要になる
自分が感じるActiveAdminの問題点 • 使い始めにつまづきやすいところがある – 公式サイトが更新されていない – Rubygemsへのリリース頻度が低く、1.x系 は未だにpreのまま • コードをかなり読み込んで構造を理解し
ないと対処法がわからないことが結構あ る
まあいろいろありますが • 知っていれば回避できる問題もあるので、 それを知ってもらいたい、というのが今 日の発表の趣旨 • Bestとはいえない手段が必要なときもあ るけど、Betterな手段で不幸を回避して、 ProgrammingをEnjoyしましょう
TIPS初級編1 • ActiveAdminでググると、 activeadmin.infoという公式サイトっぽ いものがヒットする • しかし、これを読んではいけない
どういうこと? • ここでgithubのレポジトリを見てみま しょう • https://github.com/activeadmin/activ eadmin#documentation
None
どういうこと? • activeadmin.infoのドキュメントはあま り更新されていなくて、記述が古くなっ ているところが結構ある • Githubのレポジトリのdocs以下を見ま しょう
TIPS初級編2 • Rails4系に対応しているのは、1.x系だけ • しかし、1.x系はまだpreのバージョンし か出ていないので、バージョンの指定を しないと、0.x系のものを取ってきてしま う – 依存性を解決できなくてbundleがこける
Gemfileの書き方 • gem ‘activeadmin’ # NG • gem ‘activeadmin’, github:
‘activeadmin’ # OK • gem ‘activeadmin’, ‘~> 1.0.0.pre1’ #OK
TIPS中級編 • 定型的なCRUDではない処理をする場合の カスタマイズの仕方を知ろう
カスタマイズが必要なケース • 特定のmodelクラスのCRUDではない処理 を行う場合 • ModelクラスがActiveRecord::Baseの子 クラスではない場合 – CSV読むとか •
ActiveRecordを拡張するgemを使ってい て、CRUDのやり方が変わっている場合 – 複数DBとか
カスタマイズの代表的なやり方 • register_page(例を示します) • controller do … end • member_action
/ collection_action
register_pageの例
register_pageの例
register_pageの例
TIPS上級編 • ActiveAdminのページのレイアウトをい じるのは難しい • レイアウトのテンプレートファイルがど こかにあるわけではない • ActiveAdminのviewクラス(arbre)につい て理解しよう
arbre(あるぶる) • HTMLをDSLで書くためのgem • ActiveAdminの開発初期にview部分が抽 出されたもの • ActiveAdminのviewクラスは、arbreの拡 張として、複数定義されている •
ActiveAdminのviewは、これらのクラス を組み合わせて描画されている
None
None
例題 • データを表示するtableの中で active_decoratorで定義したメソッドを 使った表示を行いたい • 普通にやろうとすると、tableに渡す前段 階でdecorateを呼んであげる必要がある – コードがごちゃっとしがち
None
見た目をいじる流れ • カスタマイズしたい部分のHTMLのタグの idなどを確認する • bundle openからのgrepでみつける • モンキーパッチを書く
おさらい • ActiveAdmin概要 • TIPS初級編 – ドキュメントはGithubを見よう – Rails4なら1.0.0.pre1以上を使おう •
TIPS中級編 – カスタマイズのやり方を知ろう • TIPS上級編 – viewの構成を知ろう
他にも • あれやこれやあります – decoratorの使い方とか – 関連を含めたtableやfilterの書き方とか – メニューの並び順制御とか •
続きはQiitaで – http://qiita.com/skuroki@github – まだ書いてないネタもたくさんあります
おしまい • ありがとうございました • AimingはRailsエンジニアを募集しています! – Ruby/Rails未経験者採用実績あります • 勉強会会場提供もやってます –
グランフロント!駅近!便利!