2
0
mirror of https://github.com/frappe/books.git synced 2025-01-05 16:12:21 +00:00

refactor setupwizard

This commit is contained in:
Faris Ansari 2018-03-30 22:32:28 +05:30
parent 29a666b60e
commit 5c6ed0cbb1
2 changed files with 137 additions and 127 deletions

View File

@ -1,48 +1,52 @@
module.exports = [ const countryList = Object.keys(require('../fixtures/countryInfo.json')).sort();
{
module.exports = {
fields: [ fields: [
{ {
"fieldname": "country", "fieldname": "file",
"label": "Country", "label": "File",
"fieldtype": "Data", "fieldtype": "File",
"required": 1 "required": 1,
} "directory": 1
],
title: 'Select Country'
}, },
{ {
fields: [ "fieldname": "country",
"label": "Country",
"fieldtype": "Autocomplete",
"required": 1,
getList: () => countryList
},
{ {
"fieldname": "name", "fieldname": "name",
"label": "Name", "label": "Name",
"fieldtype": "Data", "fieldtype": "Data",
"required": 1 "required": 1
}, },
{ {
"fieldname": "email", "fieldname": "email",
"label": "Email", "label": "Email",
"fieldtype": "Data", "fieldtype": "Data",
"required": 1 "required": 1
}
],
title: 'Add a Profile'
}, },
{
fields: [
{ {
"fieldname": "companyName", "fieldname": "companyName",
"label": "Company Name", "label": "Company Name",
"fieldtype": "Data", "fieldtype": "Data",
"required": 1 "required": 1
}, },
{ {
"fieldname": "abbreviation", "fieldname": "abbreviation",
"label": "Abbreviation", "label": "Abbreviation",
"fieldtype": "Data", "fieldtype": "Data",
"required": 1 "required": 1
}, },
{ {
"fieldname": "bankName", "fieldname": "bankName",
"label": "Bank Name", "label": "Bank Name",
@ -50,6 +54,33 @@ module.exports = [
"required": 1 "required": 1
} }
], ],
title: 'Add your Company'
layout: [
{
title: 'Select File location',
fields: ['file']
},
{
title: 'Select Country',
fields: ['country']
},
{
title: 'Add a Profile',
fields: ['name', 'email']
},
{
title: 'Add your Company',
columns: [
{
fields: ['companyName', 'bankName']
},
{
fields: ['abbreviation']
},
]
} }
] ]
}

View File

@ -3,20 +3,44 @@ const utils = require('frappejs/client/ui/utils');
const slideConfigs = require('./config'); const slideConfigs = require('./config');
const Tree = require('frappejs/client/ui/tree'); const Tree = require('frappejs/client/ui/tree');
const FormLayout = require('frappejs/client/view/formLayout'); const FormLayout = require('frappejs/client/view/formLayout');
const Observable = require('frappejs/utils/observable');
module.exports = class SetupWizard { module.exports = class SetupWizard {
constructor({postSetup = () => {}}) { constructor() {
this.slideList = []; this.slideCount = slideConfigs.layout.length;
this.indicatorList = []; this.indicatorList = [];
this.footerLinks = {};
this.currentIndex = 0; this.currentIndex = 0;
this.data = {}; this.doc = new Observable();
this.promise = new Promise(resolve => {
this.onComplete = resolve;
});
this.footerButtons = [
{
label: 'Prev', name: 'prev',
action: this.prevSlide.bind(this),
condition: index => index !== 0
},
{
label: 'Next', name: 'next',
action: this.nextSlide.bind(this),
condition: index => index !== this.slideCount - 1
},
{
label: 'Complete', name: 'complete',
action: this.onComplete.bind(this, this.doc),
condition: index => index === this.slideCount - 1
}
];
this.postSetup = postSetup;
this.make(); this.make();
}
this.showSlide(this.currentIndex); async start() {
this.showSlide(0);
return this.promise;
} }
make() { make() {
@ -25,60 +49,39 @@ module.exports = class SetupWizard {
this.$indicators = frappe.ui.add('div', 'indicators vertical-margin align-center', this.container); this.$indicators = frappe.ui.add('div', 'indicators vertical-margin align-center', this.container);
this.makeSlides(); this.makeSlides();
this.makeLinks(); this.makeButtons();
} }
makeSlides() { makeSlides() {
slideConfigs.forEach(config => { this.formLayout = new FormLayout(Object.assign(slideConfigs, {
this.formLayout = new FormLayout(config); doc: this.doc
this.slideList.push(this.formLayout); }));
let form = this.formLayout.form; this.container.appendChild(this.formLayout.form);
this.container.appendChild(form);
let title = frappe.ui.create('h3', {
className: 'text-extra-muted',
innerHTML: config.title
})
form.insertBefore(title, form.firstChild);
slideConfigs.layout.forEach(() => {
// indicator for each section
let indicator = frappe.ui.create('span', { let indicator = frappe.ui.create('span', {
inside: this.$indicators, inside: this.$indicators,
className: 'indicator gray' className: 'indicator gray'
}) });
this.indicatorList.push(indicator); this.indicatorList.push(indicator);
}); });
} }
makeLinks() { makeButtons() {
this.linkArea = frappe.ui.add('div', 'setup-link-area align-right', this.container); this.linkArea = frappe.ui.add('div', 'setup-link-area align-right', this.container);
// this.formLayout.on('change', () => { this.footerButtons.map(link => {
// const show = this.doc._dirty && !this.doc.submitted; link.element = utils.addButton(link.label, this.linkArea, link.action);
// this.saveButton.classList.toggle('hide', !show);
// });
this.getFooterLinks().map(link => {
let $link = utils.addLink(link.label, this.linkArea, () => {
this.buildData();
link.action(this.data);
});
this.footerLinks[link.name] = $link;
})
}
buildData() {
this.data = {};
this.slideList.forEach(slide => {
Object.assign(this.data, slide.doc);
}); });
} }
showSlide(index) { showSlide(index) {
utils.activate(this.container, this.slideList[index].form, 'form-body', 'active'); this.currentIndex = index;
this.slideList[index].controlList[0].input.blur(); utils.activate(this.container, `.form-section:nth-child(${index + 1})`, '.form-section', 'active');
this.activateIndicator(index); this.activateIndicator(index);
this.showFooterLinks(index); this.showFooterLinks(index);
this.currentIndex = index;
} }
prevSlide() { prevSlide() {
@ -90,46 +93,22 @@ module.exports = class SetupWizard {
} }
activateIndicator(index) { activateIndicator(index) {
this.indicatorList.forEach(indicator => {indicator.classList.add('gray')}); this.indicatorList.forEach(indicator => indicator.classList.add('gray'));
let indicator = this.indicatorList[index]; let indicator = this.indicatorList[index];
utils.activate(this.$indicators, indicator, 'gray', 'blue', index); utils.activate(this.$indicators, indicator, '.gray', 'blue', index);
frappe.ui.removeClass(indicator, 'gray'); frappe.ui.removeClass(indicator, 'gray');
indicator.classList.remove('gray'); indicator.classList.remove('gray');
} }
showFooterLinks(index) { showFooterLinks(index) {
let mat = [1, 1, 0] this.footerButtons.map(link => {
if(index === 0) { const show = link.condition(this.currentIndex);
mat = [0, 1, 0]; if (show) {
} else if (index === this.slideList.length - 1) { link.element.classList.remove('hide');
mat = [1, 0, 1]; } else {
link.element.classList.add('hide');
} }
this.showHideLinks(mat); })
}
showHideLinks(matrix = [1, 1, 0]) {
let linkNames = this.getFooterLinks().map(link => link.name);
matrix.forEach((value, i) => {
const fn = value ? 'remove' : 'add';
this.footerLinks[linkNames[i]].classList[fn]('hide');
});
}
getFooterLinks() {
return [
{
label: 'Prev', name: 'prev',
action: this.prevSlide.bind(this)
},
{
label: 'Next', name: 'next',
action: this.nextSlide.bind(this)
},
{
label: 'Complete', name: 'complete',
action: this.postSetup.bind(this)
}
];
} }
} }