1
0
Fork 0
Dieser Commit ist enthalten in:
Angus McLeod 2017-10-15 11:58:22 +08:00
Ursprung e859e3efa2
Commit 897cc0b60e
11 geänderte Dateien mit 224 neuen und 160 gelöschten Zeilen

Datei anzeigen

@ -25,7 +25,9 @@ export default {
ApplicationRoute.reopen({ ApplicationRoute.reopen({
redirect() { redirect() {
this.transitionTo('custom'); this.transitionTo('custom');
} },
model() {}
}); });
WizardStep.reopen({ WizardStep.reopen({

Datei anzeigen

@ -39,7 +39,7 @@ class CustomWizard::AdminController < ::ApplicationController
def custom_wizards def custom_wizards
rows = PluginStoreRow.where(plugin_name: 'custom_wizard').order(:id) rows = PluginStoreRow.where(plugin_name: 'custom_wizard').order(:id)
wizards = [*rows].map { |r| CustomWizard::Wizard.new(r.value) } wizards = [*rows].map { |r| CustomWizard::Template.new(r.value) }
render json: success_json.merge(wizards: wizards) render json: success_json.merge(wizards: wizards)
end end

Datei anzeigen

@ -4,6 +4,7 @@ class CustomWizard::WizardController < ::ApplicationController
end end
def index def index
puts "USING PROPER CONTROLLER"
respond_to do |format| respond_to do |format|
format.json do format.json do
wizard = CustomWizard::Builder.new(current_user, params[:wizard_id].underscore).build wizard = CustomWizard::Builder.new(current_user, params[:wizard_id].underscore).build

Datei anzeigen

@ -4,13 +4,12 @@ class CustomWizard::Builder
def initialize(user, wizard_id) def initialize(user, wizard_id)
data = PluginStore.get('custom_wizard', wizard_id) data = PluginStore.get('custom_wizard', wizard_id)
@custom_wizard = CustomWizard::Wizard.new(data) @template = CustomWizard::Template.new(data)
@wizard = Wizard.new(user, @wizard = CustomWizard::Wizard.new(user,
id: wizard_id, id: wizard_id,
save_submissions: data['save_submissions'], save_submissions: data['save_submissions'],
multiple_submissions: data['multiple_submissions'], multiple_submissions: data['multiple_submissions'],
background: data["background"], background: data["background"]
custom: true
) )
end end
@ -28,9 +27,9 @@ class CustomWizard::Builder
end end
def build def build
unless (@wizard.completed? && !@custom_wizard.respond_to?(:multiple_submissions)) || unless (@wizard.completed? && !@template.respond_to?(:multiple_submissions)) ||
!@custom_wizard.steps !@template.steps
@custom_wizard.steps.each do |s| @template.steps.each do |s|
@wizard.append_step(s['id']) do |step| @wizard.append_step(s['id']) do |step|
step.title = s['title'] if s['title'] step.title = s['title'] if s['title']
step.description = s['description'] if s['description'] step.description = s['description'] if s['description']
@ -180,6 +179,8 @@ class CustomWizard::Builder
end end
end end
puts "BUILDER: #{@wizard.respond_to?(:multiple_submissions)}"
@wizard @wizard
end end
end end

31
lib/step_updater.rb Normale Datei
Datei anzeigen

@ -0,0 +1,31 @@
class CustomWizard::StepUpdater
include ActiveModel::Model
attr_accessor :refresh_required, :fields, :result, :step
def initialize(current_user, wizard, step, fields)
@current_user = current_user
@wizard = wizard
@step = step
@refresh_required = false
@fields = fields
end
def update
@step.updater.call(self) if @step.present? && @step.updater.present?
if success?
UserHistory.create(action: UserHistory.actions[:custom_wizard_step],
context: @wizard.id,
subject: @step.id)
end
end
def success?
@errors.blank?
end
def refresh_required?
@refresh_required
end
end

14
lib/template.rb Normale Datei
Datei anzeigen

@ -0,0 +1,14 @@
class CustomWizard::Template
attr_reader :id, :name, :steps, :background, :save_submissions, :multiple_submissions, :custom
def initialize(data)
data = data.is_a?(String) ? ::JSON.parse(data) : data
@id = data['id']
@name = data['name']
@background = data['background']
@save_submissions = data['save_submissions']
@multiple_submissions = data['multiple_submissions']
@steps = data['steps']
end
end

Datei anzeigen

@ -1,15 +1,80 @@
require_dependency 'wizard/step'
require_dependency 'wizard/field'
require_dependency 'wizard/step_updater'
require_dependency 'wizard/builder'
class CustomWizard::Wizard class CustomWizard::Wizard
attr_reader :id, :name, :steps, :background, :save_submissions, :multiple_submissions, :custom attr_reader :steps, :user
attr_accessor :id, :background, :save_submissions, :multiple_submissions
def initialize(data) def initialize(user, attrs = {})
data = data.is_a?(String) ? ::JSON.parse(data) : data @steps = []
@id = data['id'] @user = user
@name = data['name'] @first_step = nil
@background = data['background'] @id = attrs[:id] if attrs[:id]
@save_submissions = data['save_submissions'] @save_submissions = attrs[:save_submissions] if attrs[:save_submissions]
@multiple_submissions = data['multiple_submissions'] @multiple_submissions = attrs[:multiple_submissions] if attrs[:multiple_submissions]
@steps = data['steps'] @background = attrs[:background] if attrs[:background]
@custom = true end
def create_step(step_name)
::Wizard::Step.new(step_name)
end
def append_step(step)
step = create_step(step) if step.is_a?(String)
yield step if block_given?
last_step = @steps.last
@steps << step
# If it's the first step
if @steps.size == 1
@first_step = step
step.index = 0
elsif last_step.present?
last_step.next = step
step.previous = last_step
step.index = last_step.index + 1
end
end
def start
completed = ::UserHistory.where(
acting_user_id: @user.id,
action: ::UserHistory.actions[:custom_wizard_step]
).where(context: @steps.map(&:id))
.uniq.pluck(:context)
@steps.each do |s|
return s unless completed.include?(s.id)
end
@first_step
end
def completed_steps?(steps)
steps = [steps].flatten.uniq
completed = ::UserHistory.where(
acting_user_id: @user.id,
action: ::UserHistory.actions[:custom_wizard_step]
).where(context: steps)
.distinct.order(:context).pluck(:context)
steps.sort == completed
end
def create_updater(step_id, fields)
step = @steps.find { |s| s.id == step_id.dasherize }
wizard = self
CustomWizard::StepUpdater.new(@user, wizard, step, fields)
end
def completed?
completed_steps?(@steps.map(&:id))
end end
end end

80
lib/wizard_edits.rb Normale Datei
Datei anzeigen

@ -0,0 +1,80 @@
require_dependency 'wizard/field'
require_dependency 'wizard/step'
::Wizard::Field.class_eval do
attr_reader :label, :description, :key, :min_length
def initialize(attrs)
attrs = attrs || {}
@id = attrs[:id]
@type = attrs[:type]
@required = !!attrs[:required]
@label = attrs[:label]
@description = attrs[:description]
@key = attrs[:key]
@min_length = attrs[:min_length]
@value = attrs[:value]
@choices = []
end
end
class ::Wizard::Step
attr_accessor :title, :description, :key
end
::WizardSerializer.class_eval do
attributes :id, :background, :completed
def id
object.id
end
def background
object.background
end
def completed
object.completed?
end
def include_completed?
object.completed? && !object.multiple_submissions && !scope.current_user.admin?
end
def include_start?
object.start && include_steps?
end
def include_steps?
!include_completed?
end
end
::WizardStepSerializer.class_eval do
def title
return object.title if object.title
I18n.t("#{object.key || i18n_key}.title", default: '')
end
def description
return object.description if object.description
I18n.t("#{object.key || i18n_key}.description", default: '')
end
end
::WizardFieldSerializer.class_eval do
def label
return object.label if object.label
I18n.t("#{object.key || i18n_key}.label", default: '')
end
def description
return object.description if object.description
I18n.t("#{object.key || i18n_key}.description", default: '')
end
def placeholder
I18n.t("#{object.key || i18n_key}.placeholder", default: '')
end
end

152
plugin.rb
Datei anzeigen

@ -10,6 +10,8 @@ config.assets.paths << Rails.root.join("plugins", "discourse-custom-wizard", "as
config.assets.paths << Rails.root.join("plugins", "discourse-custom-wizard", "assets", "stylesheets", "wizard") config.assets.paths << Rails.root.join("plugins", "discourse-custom-wizard", "assets", "stylesheets", "wizard")
after_initialize do after_initialize do
UserHistory.actions[:custom_wizard_step] = 100
require_dependency "application_controller" require_dependency "application_controller"
module ::CustomWizard module ::CustomWizard
class Engine < ::Rails::Engine class Engine < ::Rails::Engine
@ -18,13 +20,6 @@ after_initialize do
end end
end end
load File.expand_path('../lib/builder.rb', __FILE__)
load File.expand_path('../lib/field.rb', __FILE__)
load File.expand_path('../lib/wizard.rb', __FILE__)
load File.expand_path('../app/controllers/wizard.rb', __FILE__)
load File.expand_path('../app/controllers/steps.rb', __FILE__)
load File.expand_path('../app/controllers/admin.rb', __FILE__)
CustomWizard::Engine.routes.draw do CustomWizard::Engine.routes.draw do
get ':wizard_id' => 'wizard#index' get ':wizard_id' => 'wizard#index'
get ':wizard_id/steps' => 'steps#index' get ':wizard_id/steps' => 'steps#index'
@ -51,138 +46,13 @@ after_initialize do
end end
end end
require_dependency 'wizard' load File.expand_path('../lib/builder.rb', __FILE__)
require_dependency 'wizard/step' load File.expand_path('../lib/field.rb', __FILE__)
require_dependency 'wizard/step_updater' load File.expand_path('../lib/step_updater.rb', __FILE__)
require_dependency 'wizard/field' load File.expand_path('../lib/template.rb', __FILE__)
load File.expand_path('../lib/wizard.rb', __FILE__)
::Wizard.class_eval do load File.expand_path('../lib/wizard_edits.rb', __FILE__)
attr_accessor :id, :background, :save_submissions, :multiple_submissions load File.expand_path('../controllers/wizard.rb', __FILE__)
load File.expand_path('../controllers/steps.rb', __FILE__)
def initialize(user, attrs = {}) load File.expand_path('../controllers/admin.rb', __FILE__)
@steps = []
@user = user
@first_step = nil
@max_topics_to_require_completion = 15
@id = attrs[:id] if attrs[:id]
@save_submissions = attrs[:save_submissions] if attrs[:save_submissions]
@multiple_submissions = attrs[:multiple_submissions] if attrs[:multiple_submissions]
@background = attrs[:background] if attrs[:background]
@custom = attrs[:custom] if attrs[:custom]
end
def completed?
completed_steps?(@steps.map(&:id))
end
def completed_steps?(steps)
steps = [steps].flatten.uniq
completed = UserHistory.where(
acting_user_id: @user.id,
action: UserHistory.actions[:wizard_step]
).where(context: steps)
.distinct.order(:context).pluck(:context)
steps.sort == completed
end
def start
completed = UserHistory.where(
acting_user_id: @user.id,
action: UserHistory.actions[:wizard_step]
).where(context: @steps.map(&:id))
.uniq.pluck(:context)
# First uncompleted step
steps = @custom ? @steps : steps_with_fields
steps.each do |s|
return s unless completed.include?(s.id)
end
@first_step
end
end
::Wizard::Field.class_eval do
attr_reader :label, :description, :key, :min_length
def initialize(attrs)
attrs = attrs || {}
@id = attrs[:id]
@type = attrs[:type]
@required = !!attrs[:required]
@label = attrs[:label]
@description = attrs[:description]
@key = attrs[:key]
@min_length = attrs[:min_length]
@value = attrs[:value]
@choices = []
end
end
class ::Wizard::Step
attr_accessor :title, :description, :key
end
class ::Wizard::StepUpdater
attr_accessor :result, :step
end
::WizardSerializer.class_eval do
attributes :id, :background, :completed
def id
object.id
end
def background
object.background
end
def completed
object.completed?
end
def include_completed?
object.completed? && !object.multiple_submissions && !scope.current_user.admin?
end
def include_start?
object.start && include_steps?
end
def include_steps?
!include_completed?
end
end
::WizardStepSerializer.class_eval do
def title
return object.title if object.title
I18n.t("#{object.key || i18n_key}.title", default: '')
end
def description
return object.description if object.description
I18n.t("#{object.key || i18n_key}.description", default: '')
end
end
::WizardFieldSerializer.class_eval do
def label
return object.label if object.label
I18n.t("#{object.key || i18n_key}.label", default: '')
end
def description
return object.description if object.description
I18n.t("#{object.key || i18n_key}.description", default: '')
end
def placeholder
I18n.t("#{object.key || i18n_key}.placeholder", default: '')
end
end
end end