スリ飯屋MaLankaのフリーエンジニアな日々

このブログでは、フリーランス5期目となる自身の実体験から、フリーランスエンジニアになるためのノウハウ、ブログや沖縄移住、スリランカの最新情報について発信します。

【ActiveAdmin】has_many + nested_attributes_for + allow_destroyなassociation_formで生成される削除ボタンをカスタマイズする

※記事内に提携先企業のアフィリエイト広告(リンク、バナー等)、Google広告を含む場合があります


【ActiveAdmin】has_many + nested_attributes_for + allow_destroyなassociation_formで生成される削除ボタンをカスタマイズする


こんにちは、現役沖縄フリーランスエンジニアのmah(MaLanka)です。


このブログでは、

僕がIT未経験から約1年でフリーランスエンジニアになるまでの過程、

ノウハウなどを書いていきます。


今回は、


  • 【ActiveAdmin】has_many + nested_attributes_for + allow_destroyなassociation_formで生成される削除ボタンをカスタマイズする


について書いていきます。




【ActiveAdmin】has_many + nested_attributes_for + allow_destroyなassociation_formで生成される削除ボタンをカスタマイズする



ActiveAdminの、

has_many + accepts_nested_attributes_forを使ったassociation_formで、

allow_destroy: true を追加すると、

削除ボタン(check_box)が生成されますが、

そのデフォルトの削除ボタンをカスタマイズしたい時があります。



これをカスタマイズする方法をご説明します。




結論


「allow_destroy: true」 を使わず、

f.inputのname属性に 「:_destroy」 を指定すればOK。


あとはオプションをつければOKです。



form do |f|
  f.inputs 'Contract' do
    # 親モデル Contract
  end
  
  # 子モデル Option
  f.has_many :options, do |o| # allow_destroy: trueは不要
    o.input :_destroy # こうすると削除ボタンが生成される

    # ラベルを変更するなら下記のような感じ
    o.input :_destroy, label: I18n.t('delete.label')

    # disabledにするなら下記のような感じ
    o.input :_destroy, label: I18n.t('delete.label'), input_html: { disabled: true }
  end
end


  • ラベルを「削除」に変更したボタン




また、

この削除ボタンは、

子モデルから「:_destroy」というname属性として送信するので、

permit_paramsに :_destroyを追加しないと動作しないです。


忘れないようにしましょう。


ActiveAdmin.register Contract do
  # Contractが親モデル Optionが子モデルとする
  # Contractモデルに、accepts_nested_attributes_for [:options] を記述済
  # 下記のように、削除する子モデルの複数形_attributes: [:_destroy]を追加する

  permit_params :options_attributes [:_destroy]

  form do |f|
    f.inputs 'Contract' do
      # 親モデル Contract
    end
  
    # 子モデル Option
    f.has_many :options, do |o| # allow_destroy: trueは不要
      o.input :_destroy # こうすると削除ボタンが生成される

      # ラベルを変更するなら下記
      o.input :_destroy, label: 'ラベルをカスタマイズ'
    end
  end
end


以上です。




RailsやRubyを学びたい人へ


RailsやRubyを学びたい人は、

RailsHack(レイルズハック)という、

最近できた新しいプログラミングスクール(今なら通常価格69,800円が、早期割で29,800円!)か、

Udemy で下記のコースを受講すると良いです★


✅1. フルスタックエンジニアが教える 即戦力Railsエンジニア養成講座

✅2. 【はむ式】ハンズオンで学ぶRuby on Rails 6【Dockerにも触れられる】 <- おすすめ。ハムさんはReactやTypeScriptの教材も非常に丁寧。

✅3. はじめてのRuby on Rails入門-RubyとRailsを基礎から学びWebアプリケーションをネットに公開しよう




また、

Udemy は定期的にセールをやっていますし(90%OFFとかもザラ)、

「30日間なら返金できる」ので、

満足できなかった時でも安心です。



【公式】RailsHack(レイルズハック)

【公式】Udemyで学んでみる




最後に


下記の表に、

フリーランスエンジニア向けの人気エージェントをまとめてみました。


エージェント選びで悩んでいる方は是非参考にしてみてくださいね★





あわせて読みたい


www.malanka.tech


www.malanka.tech


www.malanka.tech


www.malanka.tech