wn.pages['setup-wizard'].onload = function(wrapper) { erpnext.wiz = new wn.wiz.Wizard({ parent: wrapper, title: wn._("ERPNext Setup Guide"), slides: [ // User { title: wn._("The First User"), fields: [ {"fieldname": "first_name", "label": wn._("First Name"), "fieldtype": "Data", reqd:1}, {"fieldname": "last_name", "label": wn._("Last Name"), "fieldtype": "Data", reqd:1}, ], help: wn._('The first user will become the System Manager (you can change that later).') }, // Organization { title: wn._("The Organization"), fields: [ {fieldname:'company_name', label: wn._('Company Name'), fieldtype:'Data', reqd:1, placeholder: 'e.g. "My Company LLC"'}, {fieldname:'company_abbr', label: wn._('Company Abbreviation'), fieldtype:'Data', placeholder:'e.g. "MC"',reqd:1}, {fieldname:'company_tagline', label: wn._('What does it do?'), fieldtype:'Data', placeholder:'e.g. "Build tools for builders"',reqd:1}, ], help: wn._('The name of your company for which you are setting up this system.'), onload: function(slide) { slide.get_input("company_name").on("change", function() { var parts = slide.get_input("company_name").val().split(" "); var abbr = $.map(parts, function(p) { return p ? p.substr(0,1) : null }).join(""); slide.get_input("company_abbr").val(abbr.toUpperCase()); }); } }, // Country { title: wn._("Country, Timezone and Currency"), fields: [ {fieldname:'country', label: wn._('Country'), reqd:1, options: "", fieldtype: 'Select'}, {fieldname:'currency', label: wn._('Default Currency'), reqd:1, options: "", fieldtype: 'Select'}, {fieldname:'timezone', label: wn._('Time Zone'), reqd:1, options: "", fieldtype: 'Select'}, ], help: wn._('Select your home country and check the timezone and currency.'), onload: function(slide, form) { wn.call({ method:"webnotes.country_info.get_country_timezone_info", callback: function(data) { erpnext.country_info = data.message.country_info; erpnext.all_timezones = data.message.all_timezones; slide.get_input("country").empty() .add_options([""].concat(keys(erpnext.country_info).sort())); slide.get_input("currency").empty() .add_options(wn.utils.unique([""].concat($.map(erpnext.country_info, function(opts, country) { return opts.currency; }))).sort()); slide.get_input("timezone").empty() .add_options([""].concat(erpnext.all_timezones)); } }) slide.get_input("country").on("change", function() { var country = slide.get_input("country").val(); var $timezone = slide.get_input("timezone"); $timezone.empty(); // add country specific timezones first if(country){ var timezone_list = erpnext.country_info[country].timezones || []; $timezone.add_options(timezone_list.sort()); slide.get_input("currency").val(erpnext.country_info[country].currency); } // add all timezones at the end, so that user has the option to change it to any timezone $timezone.add_options([""].concat(erpnext.all_timezones)); }); } }, // Logo { title: wn._("Logo and Letter Heads"), help: wn._('Upload your letter head and logo - you can edit them later.'), html: '

' + wn._('Upload Logo') + '


' +'

' + wn._('Upload Letter Head') + '

', onload: function(slide) { wn.upload.make({ parent: slide.$wrapper.find(".upload-area-letter-head").css({"margin-left": "10px"}), on_attach: function(fileobj) { console.log(fileobj); } }); wn.upload.make({ parent: slide.$wrapper.find(".upload-area-logo").css({"margin-left": "10px"}), on_attach: function(fileobj) { console.log(fileobj); } }); } }, // Taxes { "title": wn._("Add Taxes"), "help": wn._("List your tax heads (e.g. VAT, Excise) (upto 3) and their standard rates. This will create a standard template, you can edit and add more later."), "fields": [ {fieldtype:"Data", fieldname:"tax_1", label:"Tax 1", placeholder:"e.g. VAT"}, {fieldtype:"Data", fieldname:"tax_rate_1", label:"Rate for Tax 1 (%)", placeholder:"e.g. 5"}, {fieldtype:"Data", fieldname:"tax_2", label:"Tax 2", placeholder:"e.g. Customs Duty"}, {fieldtype:"Data", fieldname:"tax_rate_2", label:"Rate for Tax 2 (%)", placeholder:"e.g. 5"}, {fieldtype:"Data", fieldname:"tax_3", label:"Tax 3", placeholder:"e.g. Excise"}, {fieldtype:"Data", fieldname:"tax_rate_3", label:"Rate for Tax 3 (%)", placeholder:"e.g. 5"}, ], onload: function(slide) { slide.form.fields_dict.tax_rate_1.$wrapper.css("margin-left", "50%"); slide.form.fields_dict.tax_rate_2.$wrapper.css("margin-left", "50%"); slide.form.fields_dict.tax_rate_3.$wrapper.css("margin-left", "50%"); } } // ] }) } wn.pages['setup-wizard'].onshow = function(wrapper) { erpnext.wiz.show(wn.get_route()[1] || "0"); } wn.provide("wn.wiz"); wn.wiz.Wizard = Class.extend({ init: function(opts) { $.extend(this, opts); this.slide_dict = {}; wn.set_route("setup-wizard", "0"); }, show: function(id) { id = cint(id); if(this.current_slide && this.current_slide.id===id) return; if(!this.slide_dict[id]) { this.slide_dict[id] = new wn.wiz.WizardSlide($.extend(this.slides[id], {wiz:this, id:id})); this.slide_dict[id].make(); } if(this.current_slide) this.current_slide.$wrapper.toggle(false); this.current_slide = this.slide_dict[id]; this.current_slide.$wrapper.toggle(true); }, }); wn.wiz.WizardSlide = Class.extend({ init: function(opts) { $.extend(this, opts); }, make: function() { var me = this; this.$wrapper = $(repl('
\
%(main_title)s: %(title)s
\
\
\
\
\
\
\

%(title)s

%(help)s

\
\
\ \
\
', {help:this.help, title:this.title, main_title:this.wiz.title, width: (flt(this.id + 1) / this.wiz.slides.length) * 100})) .appendTo(this.wiz.parent); this.body = this.$wrapper.find(".form")[0]; if(this.fields) { this.form = new wn.ui.FieldGroup({ fields: this.fields, body: this.body }); this.form.make(); } else { $(this.body).html(this.html) } if(this.id > 0) { this.$prev = $("") .click(function() { wn.set_route("setup-wizard", me.id-1 + ""); }) .appendTo(this.$wrapper.find(".footer")) .css({"margin-right": "5px"}); } if(this.id+1 < this.wiz.slides.length) { this.$next = $("") .click(function() { wn.set_route("setup-wizard", me.id+1 + ""); }) .appendTo(this.$wrapper.find(".footer")); } else { this.$complete = $("") .click(function() { me.wiz.complete(); }).appendTo(this.$wrapper.find(".footer")); } if(this.onload) { this.onload(this); } }, get_input: function(fn) { return this.form.get_input(fn); } })