0

В моем приложении RoR я пытаюсь отобразить информацию из связанных таблиц в представлении.Ruby on Rails: Использование функций для извлечения данных из модели

У меня есть таблицы с данными, такими как это:

Email 
id  subject 
1  This week's work 
2  Presentation 
3  Spreadsheets 

Recipients 
email_id  group_id 
1    2 
2    2 
3    1 
1    3 

Groups 
id  name 
1   Managers 
2   Employees 
3   Directors 

Contactgroups 
group_id  contact_id 
1    1 
2    1 
1    3 
3    2 

Contacts 
id   email 
1   Gary 
2   Dave 
3   Annie 

То, что я пытаюсь сделать, это отобразить список групп, которые были отправлены по электронной почте, а также каждый член группы. Например, электронная почта 1 «Работа на этой неделе» была отправлена ​​группам 1 «Менеджеры» и 3 «Директорам», группа «Менеджеры» состоит из контактов Гэри и Энни, а группа «Директора» состоит из контакта «Дейв». Поэтому на странице show.html.erb я хочу отобразить данные электронной почты, а также группы, которые были отправлены, и каждый из их контактов.

Для того, чтобы сделать это, на show.html.erb странице у меня есть код:

<p> 
    <strong>Groups Sent To:</strong></br> 
    <% @recipients.each do |recipient| %> 
     <%= recipient.group.name %> 
     <% for i in 0..count_group_members(recipient.group.id)-1 do %> 
      <%= group_member_name(recipient.group.id, i) %> 
     <% end %></br> 
    <% end %> 
</p> 

И в моем emails_controller У меня есть код:

class EmailsController < ApplicationController 
    helper_method :count_group_members, :group_member_name 
    def index 
     @useraccounts = Useraccount.where(user_id: session[:user_id]) 
     accountsarray = [0] 
     @useraccounts.each do |f| 
      accountsarray << f.account_id 
     end 
     # find all emails where the account_id is in the array - and so belongs to the user 
     @emails = Email.where(account_id: [accountsarray]) 
    end 
    def show 
     @email = Email.find(params[:id]) 
     @account = Account.find_by_id(@email.account_id) 
     @recipients = Recipient.where(email_id: @email.id) 
    end 
    def new 
     @email = Email.new 
     @email.recipients.build 
     @useraccounts = Useraccount.where(user_id: session[:user_id]) 
    end 
    def edit 
     @email = Email.find(params[:id]) 
     @useraccounts = Useraccount.where(user_id: session[:user_id]) 
    end 
    def create 
     @email = Email.new(email_params) 
     if @email.save 
      redirect_to @email 
     else 
      render 'new' 
     end 
    end 
    def update 
     @email = Email.find(params[:id]) 
     if @email.update(email_params) 
      redirect_to @email 
     else 
      render 'edit' 
     end 
    end 
    def destroy 
     @email = Email.find(params[:id]) 
     @email.destroy 
     redirect_to emails_path 
    end 
    def count_group_members(group) 
     Contactgroup.where(group_id: group).count 
    end 
    def group_member_name(group, i) 
     contact = Contactgroup.where(group_id: group).offset(i).pluck(:contact_id) 
     Contact.where(id: contact).pluck(:firstname) 
    end 
    private 
    def email_params 
     params.require(:email).permit(:subject, :message, :account_id, { contact_ids: [] }, { group_ids: [] }) 
    end 
end 

Проблема с этим состоит в том, что на show.html.erb посмотреть, как пользователь видит следующую информацию:

Группы Отправлено:

Менеджеры [ "Гэри", "Энни"] [ "Энни"]

директоров [ "Dave"]

Когда я хочу, чтобы отобразить как:

Группы Sent To:

Менеджеры Гэри, Энни

Режиссеры Дэйв

Может кто-нибудь, пожалуйста, помогите мне с этим?

ответ

0

Все, что мне нужно сделать, это изменить следующие строки в моем контроллере:

def group_member_name(group, i) 
    contact = Contactgroup.where(group_id: group).offset(i).pluck(:contact_id) 
    Contact.find_by_id(contact).firstname 
end