Spiegel von
https://github.com/paviliondev/discourse-custom-wizard.git
synchronisiert 2024-11-09 20:02:54 +01:00
ceef3f4bc9
* Re structure builder logic to allow for step conditionality Concerns - Performance. Look at whether the additional build in the steps controller can be reduced - Does not work if applied to the last step. - Certain conditions will not work with the first step(?) - How should this be scoped to known functionality? * Add indexes and conditions to steps and fields * Complete and add spec * Complete backend * Complete step conditionality and field indexing * Fix failing spec * Update coverage * Apply rubocop * Apply prettier * Apply prettier to wizard js * Fix schema issues created in merge * Remove setting label for force_final * Improve client wizard cache naming * Improve steps controller and spec conditionality * Improve final step attribute naming * Fix failing spec * Linting * Add one more final step test * Linting * Fix eslint issues * Apply prettier * Linting, syntax, merge and copy cleanups * Update wizard-admin.scss * Fix template linting * Rubocop fixes
83 Zeilen
1,4 KiB
Ruby
83 Zeilen
1,4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class CustomWizard::StepSerializer < ::ApplicationSerializer
|
|
|
|
attributes :id,
|
|
:index,
|
|
:next,
|
|
:previous,
|
|
:description,
|
|
:title,
|
|
:banner,
|
|
:permitted,
|
|
:permitted_message,
|
|
:final
|
|
|
|
has_many :fields, serializer: ::CustomWizard::FieldSerializer, embed: :objects
|
|
|
|
def id
|
|
object.id
|
|
end
|
|
|
|
def index
|
|
object.index
|
|
end
|
|
|
|
def next
|
|
object.next.id if object.next.present?
|
|
end
|
|
|
|
def include_next?
|
|
object.next.present?
|
|
end
|
|
|
|
def previous
|
|
object.previous.id if object.previous.present?
|
|
end
|
|
|
|
def include_previous?
|
|
object.previous.present?
|
|
end
|
|
|
|
def i18n_key
|
|
@i18n_key ||= "wizard.step.#{object.id}".underscore
|
|
end
|
|
|
|
def title
|
|
return PrettyText.cook(object.title) if object.title
|
|
PrettyText.cook(I18n.t("#{object.key || i18n_key}.title", default: ''))
|
|
end
|
|
|
|
def include_title?
|
|
title.present?
|
|
end
|
|
|
|
def description
|
|
return object.description if object.description
|
|
PrettyText.cook(I18n.t("#{object.key || i18n_key}.description", default: '', base_url: Discourse.base_url))
|
|
end
|
|
|
|
def include_description?
|
|
description.present?
|
|
end
|
|
|
|
def banner
|
|
object.banner
|
|
end
|
|
|
|
def include_banner?
|
|
object.banner.present?
|
|
end
|
|
|
|
def permitted
|
|
object.permitted
|
|
end
|
|
|
|
def permitted_message
|
|
object.permitted_message
|
|
end
|
|
|
|
def final
|
|
object.final?
|
|
end
|
|
end
|