我正在寻找具有以下特征的预约应用程序: - 用户可以是服务提供商或买家 - 服务提供商设置他们的可用性(但只能将他们的可用性设置为最多提前 6 个月) - 然后买家可以基于预约关于这些可用性 - 每个预约,根据服务类型,需要不同的时间 - 根据买家选择的预约,根据服务需要多长时间显示一组不同的可用性
我已经构建了以下内容: - 一个TimeSlot
模型,我在其中创建了许多基于 astart_time
和end_time
属性的通用 30 分钟时间段。为了使这些时间段延长到未来 6 个月,我每天运行一个后台作业,创建所有必要的新时间段
class TimeSlot < ActiveRecord::Base
has_many :user_time_slots
# ... more methods below
end
- 一个UserTimeSlots
模型,基本上代表他们可以设置的服务提供商的可用性。因此,当他们创建 user_time_slot 时,他们本质上是在说他们当时可用。
class UserTimeSlot < ActiveRecord::Base
belongs_to :time_slot
belongs_to :service_provider, :class_name => "User"
belongs_to :appointment
end
-Appointment
具有许多 user_time_slots 的模型。它有很多,因为约会属于需要一定时间的time_required
服务(服务的属性),并且它可能跨越多个连续的user_time_slots。
class Appointment < ActiveRecord::Base
has_many :user_time_slots
belongs_to :buyer, :class_name => "User"
belongs_to :service_provider, :class_name => "User"
belongs_to :service
end
-Service
具有许多约会并属于创建该服务的服务提供商的模型。
class Service < ActiveRecord::Base
has_many :appointments
belongs_to :service_provider, :class_name => "User"
end
这个领域模型有效;但是,由于以下原因,我想知道是否有更好的方法来做到这一点:
每天使用后台作业在我的后端创建 TimeSlot 记录对我来说似乎有点笨拙 - TimeSlots 的唯一目的是有一个开始和结束时间,然后与之关联。
- 一旦用户(买方)选择了他们想要的服务,我不确定如何有效地找到 x 个连续的 user_time_slots,因此可用于预约(例如,如果我有 30 分钟的时间间隔并且用户选择了一个需要 3 小时的约会,我必须找到 6 个连续的时间段)。例如,如果用户单击服务实例,我将不得不 1) 获得该服务所需的时间(很容易做到)和 2) 我必须找到所有用户的 user_time_slots 并收集他们的关联time_slots,然后将每个时间槽的开始和结束时间相互比较以找到连续的时间。这对我来说似乎迭代太多了,而且这似乎会使我的应用程序陷入困境!
有没有人有更好的方法或解决方案来做到这一点(特别是围绕寻找连续时隙的主题)?