Rails 5でスタッフの勤務表/スケジューリングアプリを構築しようとしています。アイデアは、各スタッフメンバーがログインして勤務可能な日を入力できるユーザーアカウントを持ち、上司がシフトを予約できるようにすることです可用性に基づいています。そのようなサイトの良い例はhttps://www.findmyshift.com/です。
サイトの主要部分はカレンダーであり、各ユーザーはカレンダーの独自のインスタンスを持っています。各ユーザーは、カレンダー テーブルに独自の行を持ち、各行に曜日が表示されます。
FullCalendar や dhtmlxScheduler など、いくつかのプラグインを調べましたが、ゼロからやってみることにしました。このRailscastに基づいて基本的なカレンダーを作成することができました。これは問題なく動作します。この 3 つの主要な部分は次のとおりです。
home_controller.rb:
class HomeController < ApplicationController
def index
@date = params[:date] ? Date.parse(params[:date]) : Date.today
end
end
index.html.erb:
<div id="roster">
<h2 id="month">
<%= link_to "<", date: @date.prev_week %>
<%= @date.strftime("%B %Y") %>
<%= link_to ">", date: @date.next_week %>
</h2>
<%= calendar @date do |date| %>
<%= date.day %>
<% end %>
</div>
calendar_helper.rb:
module CalendarHelper
def calendar(date = Date.today, &block)
Calendar.new(self, date, block).table
end
class Calendar < Struct.new(:view, :date, :callback)
HEADER = %w[Monday Tuesday Wednesday Thursday Friday Saturday Sunday]
START_DAY = :monday
delegate :content_tag, to: :view
def table
content_tag :table, class: "calendar" do
header + week_rows
end
end
def header
content_tag :tr do
HEADER.map { |day| content_tag :th, day }.join.html_safe
end
end
def week_rows
weeks.map do |week|
content_tag :tr do
week.map { |day| day_cell(day) }.join.html_safe
end
end.join.html_safe
end
def day_cell(day)
content_tag :td, view.capture(day, &callback), class: day_classes(day)
end
def day_classes(day)
classes = []
classes << "today" if day == Date.today
classes << "notmonth" if day.month != date.month
classes.empty? ? nil : classes.join(" ")
end
def weeks
first = date.beginning_of_week(START_DAY)
last = date.end_of_week(START_DAY)
(first..last).to_a.in_groups_of(7)
end
end
end
繰り返しますが、これはすべて正常に機能します。1 週間の行が表示され、矢印で時間を前後に移動できます。私が望むのは、ユーザーごとに1週間の行を持つことです。ビューテンプレートで各ユーザーのカレンダーを単純にレンダリングできることは承知していますが、これにはヘッダー、週セレクター、週行のすべてが含まれます。同じテーブルの一部として、1 つのヘッダーと週のセレクター、次に各ユーザーの週の行が必要です。
私の推測では、calendar_helper.rb のどこかに各ユーザーを反復処理して、ユーザーごとに行を追加する必要がありますが、どのように進めればよいかわかりません。どんな助けでも大歓迎です:)
編集:
最初の画像は私が今持っているもので、2 番目の画像は私が達成したいものです - ユーザー数に基づいて動的にレンダリングされる、カレンダーの週の行の複数のインスタンス。