mirror of
https://github.com/frappe/books.git
synced 2025-01-07 09:04:13 +00:00
refactor setupwizard
This commit is contained in:
parent
29a666b60e
commit
5c6ed0cbb1
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
}
|
||||||
|
127
setup/index.js
127
setup/index.js
@ -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)
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user