0
0
Fork 1
Spiegel von https://github.com/paviliondev/discourse-custom-wizard.git synchronisiert 2024-11-25 18:50:27 +01:00
Dieser Commit ist enthalten in:
Angus McLeod 2017-10-07 10:27:38 +08:00
Ursprung 9f40821db0
Commit a43f4b1344
24 geänderte Dateien mit 226 neuen und 115 gelöschten Zeilen

Datei anzeigen

@ -44,7 +44,7 @@ class CustomWizard::AdminController < ::ApplicationController
def find_wizard def find_wizard
params.require(:wizard_id) params.require(:wizard_id)
wizard = PluginStore.get('custom_wizard', params[:wizard_id]) wizard = PluginStore.get('custom_wizard', params[:wizard_id].underscore)
render json: success_json.merge(wizard: wizard) render json: success_json.merge(wizard: wizard)
end end
@ -60,7 +60,7 @@ class CustomWizard::AdminController < ::ApplicationController
def find_submissions def find_submissions
params.require(:wizard_id) params.require(:wizard_id)
wizard = PluginStore.get('custom_wizard_submissions', params[:wizard_id]) wizard = PluginStore.get('custom_wizard_submissions', params[:wizard_id].underscore)
render json: success_json.merge(submissions: submissions) render json: success_json.merge(submissions: submissions)
end end

Datei anzeigen

@ -2,7 +2,7 @@ class CustomWizard::StepsController < ApplicationController
before_action :ensure_logged_in before_action :ensure_logged_in
def update def update
wizard = CustomWizard::Builder.new(current_user, params[:wizard_id]).build wizard = CustomWizard::Builder.new(current_user, params[:wizard_id].underscore).build
updater = wizard.create_updater(params[:step_id], params[:fields]) updater = wizard.create_updater(params[:step_id], params[:fields])
updater.update updater.update

Datei anzeigen

@ -6,7 +6,7 @@ class CustomWizard::WizardController < ::ApplicationController
def index def index
respond_to do |format| respond_to do |format|
format.json do format.json do
wizard = CustomWizard::Builder.new(current_user, params[:wizard_id]).build wizard = CustomWizard::Builder.new(current_user, params[:wizard_id].underscore).build
render_serialized(wizard, WizardSerializer) render_serialized(wizard, WizardSerializer)
end end
format.html {} format.html {}

Datei anzeigen

@ -8,7 +8,6 @@ export default Ember.Component.extend({
@observes('field.id') @observes('field.id')
init() { init() {
this._super(...arguments); this._super(...arguments);
if (!this.get('field.choices')) { if (!this.get('field.choices')) {
this.set('field.choices', Ember.A()); this.set('field.choices', Ember.A());
} }

Datei anzeigen

@ -6,23 +6,25 @@ export default Ember.Component.extend({
currentAction: null, currentAction: null,
@on('init') @on('init')
@observes('step.id') @observes('step')
setup() { setup() {
this._super(...arguments); this._super(...arguments);
const fields = this.get('step.fields'); const fields = this.get('step.fields') || [];
const actions = this.get('step.actions'); const actions = this.get('step.actions') || [];
this.set('currentField', fields[0]); this.set('currentField', fields[0]);
this.set('currentAction', actions[0]); this.set('currentAction', actions[0]);
}, },
@computed('step.fields.[]', 'currentField') @computed('step.fields.[]', 'currentField')
fieldLinks(fields, current) { fieldLinks(fields, current) {
if (!fields) return;
return fields.map((f) => { return fields.map((f) => {
if (f) { if (f) {
let link = { const id = f.get('id');
id: f.get('id'), const label = f.get('label');
label: f.get('label')
}; let link = { id, label: label || id };
let classes = 'btn'; let classes = 'btn';
if (current && f.get('id') === current.get('id')) { if (current && f.get('id') === current.get('id')) {
@ -38,12 +40,14 @@ export default Ember.Component.extend({
@computed('step.actions.[]', 'currentAction') @computed('step.actions.[]', 'currentAction')
actionLinks(actions, current) { actionLinks(actions, current) {
if (!actions) return;
return actions.map((a) => { return actions.map((a) => {
if (a) { if (a) {
let link = { const id = a.get('id');
id: a.get('id'), const label = a.get('label');
label: a.get('label')
}; let link = { id, label: label || id };
let classes = 'btn'; let classes = 'btn';
if (current && a.get('id') === current.get('id')) { if (current && a.get('id') === current.get('id')) {
@ -62,7 +66,7 @@ export default Ember.Component.extend({
const fields = this.get('step.fields'); const fields = this.get('step.fields');
const newNum = fields.length + 1; const newNum = fields.length + 1;
const field = Ember.Object.create({ const field = Ember.Object.create({
id: `field-${newNum}`, label: `Field ${newNum}` id: `field-${newNum}`
}); });
fields.pushObject(field); fields.pushObject(field);
this.set('currentField', field); this.set('currentField', field);
@ -72,7 +76,7 @@ export default Ember.Component.extend({
const actions = this.get('step.actions'); const actions = this.get('step.actions');
const newNum = actions.length + 1; const newNum = actions.length + 1;
const action = Ember.Object.create({ const action = Ember.Object.create({
id: `action-${newNum}`, label: `Action ${newNum}` id: `action-${newNum}`
}); });
actions.pushObject(action); actions.pushObject(action);
this.set('currentAction', action); this.set('currentAction', action);

Datei anzeigen

@ -6,13 +6,13 @@ export default Ember.Controller.extend({
stepLinks(steps, currentStep) { stepLinks(steps, currentStep) {
return steps.map((s) => { return steps.map((s) => {
if (s) { if (s) {
let link = { const id = s.get('id');
id: s.get('id'), const title = s.get('title');
title: s.get('title')
}; let link = { id, title: title || id };
let classes = 'btn'; let classes = 'btn';
if (currentStep && s.get('id') === currentStep.get('id')) { if (currentStep && id === currentStep.get('id')) {
classes += ' btn-primary'; classes += ' btn-primary';
}; };
@ -23,21 +23,25 @@ export default Ember.Controller.extend({
}); });
}, },
@computed('model.id') @computed('model.id', 'model.name')
wizardUrl(wizardId) { wizardUrl(wizardId) {
return window.location.origin + '/wizard/custom/' + wizardId; return window.location.origin + '/wizard/custom/' + Ember.String.dasherize(wizardId);
}, },
actions: { actions: {
save() { save() {
this.get('model').save().then(() => { this.get('model').save().then(() => {
this.send("refreshRoute"); if (this.get('newWizard')) {
this.send("refreshAllWizards");
} else {
this.send("refreshWizard");
}
}); });
}, },
remove() { remove() {
this.get('model').remove().then(() => { this.get('model').remove().then(() => {
this.transitionToRoute('adminWizardsCustom'); this.send("refreshAllWizards");
}); });
}, },
@ -47,10 +51,8 @@ export default Ember.Controller.extend({
const step = Ember.Object.create({ const step = Ember.Object.create({
fields: Ember.A(), fields: Ember.A(),
actions: Ember.A(), actions: Ember.A(),
title: `Step ${newNum}`,
id: `step-${newNum}` id: `step-${newNum}`
}); });
steps.pushObject(step); steps.pushObject(step);
this.set('currentStep', step); this.set('currentStep', step);
}, },
@ -58,6 +60,7 @@ export default Ember.Controller.extend({
removeStep(stepId) { removeStep(stepId) {
const steps = this.get('model.steps'); const steps = this.get('model.steps');
steps.removeObject(steps.findBy('id', stepId)); steps.removeObject(steps.findBy('id', stepId));
this.set('currentStep', steps[steps.length - 1]);
}, },
changeStep(stepId) { changeStep(stepId) {

Datei anzeigen

@ -0,0 +1,5 @@
import { registerUnbound } from 'discourse-common/lib/helpers';
registerUnbound('dasherize', function(string) {
return Ember.String.dasherize(string);
});

Datei anzeigen

@ -1,37 +1,57 @@
import { default as computed } from 'ember-addons/ember-computed-decorators'; import { observes, on } from 'ember-addons/ember-computed-decorators';
import { ajax } from 'discourse/lib/ajax'; import { ajax } from 'discourse/lib/ajax';
const CustomWizard = Discourse.Model.extend({ const CustomWizard = Discourse.Model.extend({
init() { @on('init')
setup() {
const id = this.get('id'); const id = this.get('id');
if (id) this.set('existingId', id); if (id) this.set('existingId', id);
}, },
@computed('name') @observes('name')
id: (name) => name ? Ember.String.dasherize(name) : null, updateId() {
const name = this.get('name');
this.set('id', name.underscore());
},
save() { save() {
const stepsObj = this.get('steps'); const stepsObj = this.get('steps');
let steps = []; let steps = [];
stepsObj.forEach((s) => { stepsObj.forEach((s) => {
if (!s.title && !s.translation_key) return;
let step = { let step = {
id: Ember.String.dasherize(s.title), id: (s.title || s.translation_key.split('.').pop()).underscore(),
title: s.title,
banner: s.banner,
description: s.description,
fields: [], fields: [],
actions: [] actions: []
}; };
if (s.title) step['title'] = s.title;
if (s.translation_key) step['translation_key'] = s.translation_key;
if (s.banner) step['banner'] = s.banner;
if (s.description) step['description'] = s.description;
const fields = s.get('fields'); const fields = s.get('fields');
fields.forEach((f) => { fields.forEach((f) => {
f.set('id', Ember.String.dasherize(f.get('label'))); const fl = f.get('label');
const fkey = f.get('translation_key');
if (!fl && !fkey) return;
f.set('id', (fl || fkey.split('.').pop()).underscore());
if (f.get('type') === 'dropdown') { if (f.get('type') === 'dropdown') {
const choices = f.get('choices'); const choices = f.get('choices');
choices.forEach((c) => { choices.forEach((c) => {
c.set('id', c.get('label')); const cl = c.get('label');
const ckey = c.get('translation_key');
if (!cl && !ckey) return;
c.set('id', (cl || ckey.split('.').pop()).underscore());
}); });
} }
@ -39,7 +59,9 @@ const CustomWizard = Discourse.Model.extend({
}); });
s.actions.forEach((a) => { s.actions.forEach((a) => {
a.set('id', Ember.String.dasherize(a.get('label'))); const al = a.get('label');
if (!al) return;
a.set('id', al.underscore());
step['actions'].push(a); step['actions'].push(a);
}); });
@ -48,8 +70,9 @@ const CustomWizard = Discourse.Model.extend({
const id = this.get('id'); const id = this.get('id');
const name = this.get('name'); const name = this.get('name');
const background = this.get('background');
const save_submissions = this.get('save_submissions'); const save_submissions = this.get('save_submissions');
let wizard = { id, name, save_submissions, steps }; let wizard = { id, name, background, save_submissions, steps };
const existingId = this.get('existingId'); const existingId = this.get('existingId');
if (existingId && existingId !== id) { if (existingId && existingId !== id) {
@ -93,13 +116,13 @@ CustomWizard.reopenClass({
create(w) { create(w) {
const wizard = this._super.apply(this); const wizard = this._super.apply(this);
let steps = Ember.A(); let steps = Ember.A();
let props = { steps }; let props = { steps };
if (w) { if (w) {
props['id'] = w.id; props['id'] = w.id;
props['name'] = w.name; props['name'] = w.name;
props['background'] = w.background;
if (w.steps) { if (w.steps) {
w.steps.forEach((s) => { w.steps.forEach((s) => {
@ -125,6 +148,7 @@ CustomWizard.reopenClass({
steps.pushObject(Ember.Object.create({ steps.pushObject(Ember.Object.create({
id: s.id, id: s.id,
translation_key: s.translation_key,
title: s.title, title: s.title,
description: s.description, description: s.description,
banner: s.banner, banner: s.banner,
@ -134,7 +158,11 @@ CustomWizard.reopenClass({
}); });
}; };
} else { } else {
props['id'] = '';
props['name'] = '';
props['background'] = '';
props['save_submissions'] = true; props['save_submissions'] = true;
props['steps'] = Ember.A();
}; };
wizard.setProperties(props); wizard.setProperties(props);

Datei anzeigen

@ -4,12 +4,12 @@ import { ajax } from 'discourse/lib/ajax';
export default Discourse.Route.extend({ export default Discourse.Route.extend({
model(params) { model(params) {
if (params.wizard_id === 'new') { if (params.wizard_id === 'new') {
this.set('new', true); this.set('newWizard', true);
return CustomWizard.create(); return CustomWizard.create();
} }
this.set('new', false); this.set('newWizard', false);
const wizard = this.modelFor('admin-wizards-custom').findBy('id', params.wizard_id); const wizard = this.modelFor('admin-wizards-custom').findBy('id', params.wizard_id.underscore());
if (!wizard) return this.transitionTo('adminWizardsCustom.index'); if (!wizard) return this.transitionTo('adminWizardsCustom.index');
return wizard; return wizard;
@ -21,14 +21,17 @@ export default Discourse.Route.extend({
}, },
setupController(controller, model) { setupController(controller, model) {
let props = { new: this.get('new'), model }; const newWizard = this.get('newWizard');
const steps = model.get('steps'); const steps = model.get('steps') || [];
if (steps[0]) props['currentStep'] = steps[0]; controller.setProperties({
controller.setProperties(props); newWizard,
model,
currentStep: steps[0]
});
}, },
actions: { actions: {
refreshRoute() { refreshWizard() {
this.refresh(); this.refresh();
} }
} }

Datei anzeigen

@ -5,10 +5,11 @@ export default Discourse.Route.extend({
return CustomWizard.findAll(); return CustomWizard.findAll();
}, },
afterModel(model, transition) { afterModel(model) {
if (transition.intent.name !== 'adminWizard' && model.length > 0) { const transitionToWizard = this.get('transitionToWizard');
this.transitionTo('adminWizard', model[0].id); if (transitionToWizard === 'last' && model.length) {
} this.transitionTo('adminWizard', model[model.length - 1].id);
};
}, },
setupController(controller, model){ setupController(controller, model){
@ -16,10 +17,9 @@ export default Discourse.Route.extend({
}, },
actions: { actions: {
willTransition(transition) { refreshAllWizards() {
if (transition.intent.name === 'adminWizardsCustom') { this.set('transitionToWizard', 'last');
this.refresh(); this.refresh();
}
} }
} }
}); });

Datei anzeigen

@ -1,5 +1 @@
export default Discourse.Route.extend({ export default Discourse.Route.extend();
redirect() {
this.transitionTo('adminWizardsCustom');
}
});

Datei anzeigen

@ -4,12 +4,21 @@
{{i18n 'admin.wizard.header'}} {{i18n 'admin.wizard.header'}}
</div> </div>
<div class="setting">
<div class="setting-label">
<h3>{{i18n 'admin.wizard.background'}}</h3>
</div>
<div class="setting-value">
{{input name="background" value=model.background placeholderKey="admin.wizard.background_placeholder"}}
</div>
</div>
<div class="setting"> <div class="setting">
<div class="setting-label"> <div class="setting-label">
<h3>{{i18n 'admin.wizard.name'}}</h3> <h3>{{i18n 'admin.wizard.name'}}</h3>
</div> </div>
<div class="setting-value"> <div class="setting-value">
{{text-field name="name" value=model.name placeholderKey="admin.wizard.name_placeholder"}} {{input name="name" value=model.name placeholderKey="admin.wizard.name_placeholder"}}
</div> </div>
</div> </div>
@ -39,11 +48,13 @@
{{d-button action='addStep' label='admin.wizard.add' icon='plus'}} {{d-button action='addStep' label='admin.wizard.add' icon='plus'}}
</div> </div>
{{wizard-custom-step step=currentStep fieldTypes=model.fieldTypes}} {{#if currentStep}}
{{wizard-custom-step step=currentStep fieldTypes=model.fieldTypes}}
{{/if}}
<div class='buttons'> <div class='buttons'>
<button {{action "save"}} disabled={{disableSave}} class='btn btn-primary'>{{i18n 'admin.wizard.save'}}</button> <button {{action "save"}} disabled={{disableSave}} class='btn btn-primary'>{{i18n 'admin.wizard.save'}}</button>
{{#unless new}} {{#unless newWizard}}
<button {{action "remove"}} class='btn btn-danger'>{{d-icon "trash-o"}}{{i18n 'admin.wizard.remove'}}</button> <button {{action "remove"}} class='btn btn-danger'>{{d-icon "trash-o"}}{{i18n 'admin.wizard.remove'}}</button>
{{/unless}} {{/unless}}
<span class="saving {{unless savingStatus 'hidden'}}">{{savingStatus}}</span> <span class="saving {{unless savingStatus 'hidden'}}">{{savingStatus}}</span>

Datei anzeigen

@ -1,9 +1,9 @@
<div class='row'> <div class='row'>
<div class='content-list span6'> <div class='content-list wizard-list'>
<ul> <ul>
{{#each model as |w|}} {{#each model as |w|}}
<li> <li>
{{#link-to "adminWizard" w.id}}{{w.name}}{{/link-to}} {{#link-to "adminWizard" (dasherize w.id)}}{{w.name}}{{/link-to}}
</li> </li>
{{/each}} {{/each}}
</ul> </ul>

Datei anzeigen

@ -1,5 +1,5 @@
<div class='row'> <div class='row'>
<div class='content-list span6'> <div class='wizard-list'>
<ul> <ul>
{{#each model as |s|}} {{#each model as |s|}}
<li> <li>

Datei anzeigen

@ -1,3 +1,12 @@
<div class="setting">
<div class="setting-label">
<h3>{{i18n 'admin.wizard.translation'}}</h3>
</div>
<div class="setting-value">
{{input name="translation_key" value=field.translation_key placeholderKey="admin.wizard.field.translation_placeholder"}}
</div>
</div>
<div class="setting"> <div class="setting">
<div class="setting-label"> <div class="setting-label">
<h3>{{i18n 'admin.wizard.field.label'}}</h3> <h3>{{i18n 'admin.wizard.field.label'}}</h3>

Datei anzeigen

@ -1,3 +1,12 @@
<div class="setting">
<div class="setting-label">
<h3>{{i18n 'admin.wizard.translation'}}</h3>
</div>
<div class="setting-value">
{{input name="translation_key" value=step.translation_key placeholderKey="admin.wizard.step.translation_placeholder"}}
</div>
</div>
<div class="setting"> <div class="setting">
<div class="setting-label"> <div class="setting-label">
<h3>{{i18n 'admin.wizard.step.title'}}</h3> <h3>{{i18n 'admin.wizard.step.title'}}</h3>
@ -21,7 +30,7 @@
<h3>{{i18n 'admin.wizard.step.description'}}</h3> <h3>{{i18n 'admin.wizard.step.description'}}</h3>
</div> </div>
<div class="setting-value"> <div class="setting-value">
{{textarea name="description" value=step.description placeholderKey="admin.wizard.step.description_placeholder"}} {{textarea name="description" value=step.description placeholder=(i18n "admin.wizard.step.description_placeholder")}}
</div> </div>
</div> </div>

Datei anzeigen

@ -1,12 +0,0 @@
{{#if showCanvas}}
{{wizard-canvas}}
{{/if}}
<div class='wizard-column'>
<div class='wizard-column-contents'>
{{outlet}}
</div>
<div class='wizard-footer'>
<div class='discourse-logo'></div>
</div>
</div>

Datei anzeigen

@ -35,6 +35,11 @@ export default {
}, },
setupController(controller, model) { setupController(controller, model) {
console.log(model)
Ember.run.scheduleOnce('afterRender', this, function(){
$('body.custom-wizard').css('background', model.get('background'));
});
controller.setProperties({ controller.setProperties({
customWizard: true, customWizard: true,
siteInfo: model.get('siteInfo') siteInfo: model.get('siteInfo')
@ -59,6 +64,10 @@ export default {
StepRoute.reopen({ StepRoute.reopen({
afterModel(model) { afterModel(model) {
if (!model) {
return document.location = getUrl("/");
}
const wizard = this.modelFor('application'); const wizard = this.modelFor('application');
return model.set("wizardId", wizard.id); return model.set("wizardId", wizard.id);
} }
@ -69,7 +78,7 @@ export default {
const src = this.get('step.banner'); const src = this.get('step.banner');
if (!src) return; if (!src) return;
if (src.indexOf('/uploads/') > -1) { if (src.indexOf('/uploads/') > -1 || src.indexOf('/images/') > -1) {
return getUrl(src); return getUrl(src);
} else { } else {
return getUrl(`/images/wizard/${src}`); return getUrl(`/images/wizard/${src}`);

Datei anzeigen

@ -3,6 +3,11 @@
float: left; float: left;
} }
.wizard-list {
float: left;
width: 250px;
}
.new-wizard { .new-wizard {
margin-top: 15px; margin-top: 15px;
} }
@ -34,15 +39,15 @@
min-width: 49%; min-width: 49%;
.setting-label { .setting-label {
width: 20%; width: 90px;
}
.setting-value span {
font-size: 0.929em;
} }
&.full { &.full {
width: 100%; width: 100%;
.setting-label {
width: 75px;
}
} }
} }
} }

Datei anzeigen

@ -8,6 +8,8 @@ en:
submissions_label: "Submissions" submissions_label: "Submissions"
name: "Name" name: "Name"
name_placeholder: "name of the wizard" name_placeholder: "name of the wizard"
background: "Background"
background_placeholder: "Background css property"
save_submissions: "Save" save_submissions: "Save"
save_submissions_label: "Save wizard submissions" save_submissions_label: "Save wizard submissions"
save: "Save Changes" save: "Save Changes"
@ -15,14 +17,16 @@ en:
header: "Wizard" header: "Wizard"
add: "Add" add: "Add"
url: "Url" url: "Url"
translation: "Translation"
step: step:
header: "Steps" header: "Steps"
title: "Title" title: "Title"
title_placeholder: "This will appear at the top of the step" title_placeholder: "Overrides title translation"
banner: "Banner" banner: "Banner"
banner_placeholder: "Image url" banner_placeholder: "Image url"
description: "Description" description: "Description"
description_placeholder: "This will appear underneath the title and / or title" description_placeholder: "Overrides description translation"
translation_placeholder: "Translation key for step"
field: field:
header: "Fields" header: "Fields"
label: "Label" label: "Label"
@ -32,6 +36,7 @@ en:
add_choice: "Add" add_choice: "Add"
required: "Required" required: "Required"
required_label: "Field is Required" required_label: "Field is Required"
translation_placeholder: "Translation key for field"
action: action:
header: "Actions" header: "Actions"
label: "Label" label: "Label"

Datei anzeigen

@ -1,3 +1,11 @@
en: en:
custom_wizard: custom_wizard:
title: "Wizard" title: "Wizard"
new_wizard:
step_1:
title: "Translated title"
description: "Translated description"
field_1:
label: "Translated field title"
description: "Translated field description"

Datei anzeigen

@ -6,6 +6,7 @@ class CustomWizard::Builder
@wizard = Wizard.new(user) @wizard = Wizard.new(user)
@wizard.id = wizard_id @wizard.id = wizard_id
@wizard.save_submissions = data['save_submissions'] @wizard.save_submissions = data['save_submissions']
@wizard.background = data["background"]
end end
def self.sorted_handlers def self.sorted_handlers
@ -25,14 +26,22 @@ class CustomWizard::Builder
@custom_wizard.steps.each do |s| @custom_wizard.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.banner = s['banner'] if s['banner'] step.banner = s['banner'] if s['banner']
step.translation_key = s['translation_key'] if s['translation_key']
s['fields'].each do |f| s['fields'].each do |f|
field = step.add_field(id: f['id'], params = {
type: f['type'], id: f['id'],
label: f['label'], type: f['type'],
description: f['description'], required: f['required']
required: f['required']) }
params[:label] = f['label'] if f['label']
params[:description] = f['description'] if f['description']
params[:translation_key] = f['translation_key'] if f['translation_key']
field = step.add_field(params)
if f['type'] == 'dropdown' if f['type'] == 'dropdown'
f['choices'].each do |c| f['choices'].each do |c|

Datei anzeigen

@ -62,11 +62,11 @@ after_initialize do
end end
class ::Wizard class ::Wizard
attr_accessor :id, :save_submissions attr_accessor :id, :background, :save_submissions
end end
class ::Wizard::Step class ::Wizard::Step
attr_accessor :title attr_accessor :title, :description, :translation_key
end end
class ::Wizard::StepUpdater class ::Wizard::StepUpdater
@ -75,7 +75,7 @@ after_initialize do
require_dependency 'wizard/field' require_dependency 'wizard/field'
Wizard::Field.class_eval do Wizard::Field.class_eval do
attr_reader :label, :description attr_reader :label, :description, :translation_key
def initialize(attrs) def initialize(attrs)
attrs = attrs || {} attrs = attrs || {}
@ -85,38 +85,49 @@ after_initialize do
@required = !!attrs[:required] @required = !!attrs[:required]
@label = attrs[:label] @label = attrs[:label]
@description = attrs[:description] @description = attrs[:description]
@translation_key = attrs[:translation_key]
@value = attrs[:value] @value = attrs[:value]
@choices = [] @choices = []
end end
end end
add_to_serializer(:wizard, :id) { object.id } ::WizardSerializer.class_eval do
attributes :id, :background
def id
object.id
end
def background
object.background
end
def include_start?
object.start
end
end
::WizardStepSerializer.class_eval do ::WizardStepSerializer.class_eval do
def title def title
if object.title return object.title if object.title
object.title I18n.t("#{object.translation_key || i18n_key}.title", default: '')
else end
I18n.t("#{i18n_key}.title", default: '')
end def description
return object.description if object.description
I18n.t("#{object.translation_key || i18n_key}.description", default: '')
end end
end end
::WizardFieldSerializer.class_eval do ::WizardFieldSerializer.class_eval do
def label def label
if object.label return object.label if object.label
object.label I18n.t("#{object.translation_key || i18n_key}.label", default: '')
else
I18n.t("#{i18n_key}.label", default: '')
end
end end
def description def description
if object.description return object.description if object.description
object.description I18n.t("#{object.translation_key || i18n_key}.description", default: '')
else
I18n.t("#{i18n_key}.description", default: '')
end
end end
end end
end end

Datei anzeigen

@ -1,3 +1,12 @@
.custom-wizard { .custom-wizard {
background-color: #f4f4f4; background-color: initial;
}
.custom-wizard .wizard-step-description {
line-height: 1.7;
}
.custom-wizard .wizard-column .wizard-step-banner {
width: initial;
max-width: 660px;
} }