2016-08-25 13:14:56 -04:00
|
|
|
require_dependency 'wizard/step'
|
|
|
|
require_dependency 'wizard/field'
|
2016-09-14 16:36:08 -04:00
|
|
|
require_dependency 'wizard/step_updater'
|
2016-08-25 13:14:56 -04:00
|
|
|
|
|
|
|
class Wizard
|
2016-09-14 16:36:08 -04:00
|
|
|
attr_reader :steps, :user
|
2016-08-25 13:14:56 -04:00
|
|
|
|
2016-09-09 16:51:07 -04:00
|
|
|
def initialize(user)
|
2016-08-25 13:14:56 -04:00
|
|
|
@steps = []
|
2016-09-09 16:51:07 -04:00
|
|
|
@user = user
|
2016-09-14 16:36:08 -04:00
|
|
|
@first_step = nil
|
2016-08-25 13:14:56 -04:00
|
|
|
end
|
|
|
|
|
2016-09-07 18:04:01 -04:00
|
|
|
def create_step(step_name)
|
|
|
|
Step.new(step_name)
|
2016-08-25 13:14:56 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def append_step(step)
|
2016-09-07 18:04:01 -04:00
|
|
|
step = create_step(step) if step.is_a?(String)
|
|
|
|
|
|
|
|
yield step if block_given?
|
|
|
|
|
2016-08-25 13:14:56 -04:00
|
|
|
last_step = @steps.last
|
|
|
|
|
|
|
|
@steps << step
|
|
|
|
|
|
|
|
# If it's the first step
|
|
|
|
if @steps.size == 1
|
2016-09-14 16:36:08 -04:00
|
|
|
@first_step = step
|
2016-08-25 13:14:56 -04:00
|
|
|
step.index = 0
|
|
|
|
elsif last_step.present?
|
|
|
|
last_step.next = step
|
|
|
|
step.previous = last_step
|
|
|
|
step.index = last_step.index + 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-09-14 16:36:08 -04:00
|
|
|
def steps_with_fields
|
2016-10-14 05:09:55 -04:00
|
|
|
@steps_with_fields ||= @steps.select(&:has_fields?)
|
2016-09-14 16:36:08 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def start
|
|
|
|
completed = UserHistory.where(
|
|
|
|
action: UserHistory.actions[:wizard_step],
|
|
|
|
context: steps_with_fields.map(&:id)
|
|
|
|
).uniq.pluck(:context)
|
|
|
|
|
|
|
|
# First uncompleted step
|
|
|
|
steps_with_fields.each do |s|
|
|
|
|
return s unless completed.include?(s.id)
|
|
|
|
end
|
|
|
|
|
|
|
|
@first_step
|
|
|
|
end
|
|
|
|
|
2016-09-12 14:43:00 -04:00
|
|
|
def create_updater(step_id, fields)
|
2016-10-14 05:09:55 -04:00
|
|
|
step = @steps.find { |s| s.id == step_id.dasherize }
|
2016-09-12 14:43:00 -04:00
|
|
|
Wizard::StepUpdater.new(@user, step, fields)
|
2016-08-25 13:14:56 -04:00
|
|
|
end
|
2016-09-09 16:51:07 -04:00
|
|
|
|
2016-09-14 16:36:08 -04:00
|
|
|
def completed?
|
|
|
|
completed_steps?(steps_with_fields.map(&:id))
|
|
|
|
end
|
|
|
|
|
|
|
|
def completed_steps?(steps)
|
|
|
|
steps = [steps].flatten.uniq
|
|
|
|
|
|
|
|
completed = UserHistory.where(
|
|
|
|
action: UserHistory.actions[:wizard_step],
|
|
|
|
context: steps
|
|
|
|
).distinct.order(:context).pluck(:context)
|
|
|
|
|
|
|
|
steps.sort == completed
|
|
|
|
end
|
|
|
|
|
|
|
|
def requires_completion?
|
|
|
|
return false unless SiteSetting.wizard_enabled?
|
|
|
|
|
2016-10-18 11:44:25 -04:00
|
|
|
|
2016-10-14 05:09:55 -04:00
|
|
|
first_admin = User.where(admin: true)
|
|
|
|
.where.not(id: Discourse.system_user.id)
|
|
|
|
.where.not(auth_token_updated_at: nil)
|
|
|
|
.order(:auth_token_updated_at)
|
2016-09-14 16:36:08 -04:00
|
|
|
|
2016-11-01 03:24:07 -04:00
|
|
|
if @user.present? && first_admin.first == @user && (Topic.count < 15)
|
|
|
|
!Wizard::Builder.new(@user).build.completed?
|
|
|
|
else
|
|
|
|
false
|
|
|
|
end
|
2016-10-18 11:44:25 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def self.user_requires_completion?(user)
|
2016-11-01 03:24:07 -04:00
|
|
|
self.new(user).requires_completion?
|
2016-09-14 16:36:08 -04:00
|
|
|
end
|
|
|
|
|
2016-08-25 13:14:56 -04:00
|
|
|
end
|