diff --git a/vehicle/OVMS.V3/components/ovms_webserver/src/web_cfg_init.cpp b/vehicle/OVMS.V3/components/ovms_webserver/src/web_cfg_init.cpp
index a45f3e36b..dc0672df3 100644
--- a/vehicle/OVMS.V3/components/ovms_webserver/src/web_cfg_init.cpp
+++ b/vehicle/OVMS.V3/components/ovms_webserver/src/web_cfg_init.cpp
@@ -57,6 +57,79 @@ static const char *TAG = "webserver";
#ifdef WEBSRV_HAVE_SETUPWIZARD
+struct wizard_info_t {
+ const char *title, *desc;
+};
+static const int wizard_count = 5;
+static const wizard_info_t wizards[wizard_count] = {
+ {"Secure Module", "Secure module access" },
+ {"Connect to Internet", "Connect module to internet (via Wifi)"},
+#ifdef CONFIG_OVMS_COMP_OTA
+ {"Update Firmware", "Update to latest firmware version"},
+#else
+ {NULL,NULL},
+#endif
+ {"Vehicle & Server", "Configure vehicle type and server"},
+#ifdef CONFIG_OVMS_COMP_CELLULAR
+ {"Cellular Modem", "Configure cellular modem (if equipped)"}
+#else
+ {NULL,NULL}
+#endif
+};
+
+static int WizardNumber( int wizardNo)
+{
+ int count = 0;
+ for (int i = 0; i < wizardNo; ++i) {
+ if (wizards[i].desc)
+ ++count;
+ }
+ return count;
+}
+// Returns the active wizard pages (the number of the last page)
+static inline int WizardCount()
+{
+ return WizardNumber(wizard_count);
+}
+
+/**
+ * Returns the setup wizard header.
+ * Indexed from 1.
+ * Has the current one bolded and previous ones checked.
+ */
+static std::string WizardStatus(int wizardNo)
+{
+ --wizardNo;
+ std::ostringstream os;
+ os << "
Quick setup wizard
"
+ "";
+ for (int i = 0; i < wizard_count; ++i) {
+ if (!wizards[i].desc)
+ continue;
+ os << "- ";
+ bool isStrong = (i == wizardNo);
+ if (isStrong)
+ os << "";
+ os << wizards[i].desc;
+ if (i < wizardNo)
+ os << "✔";
+ else if (isStrong)
+ os << "";
+ os << "
";
+ }
+ os << "
";
+ return os.str();
+}
+
+static std::string WizardFormHeader(int wizardNo)
+{
+ std::ostringstream os;
+ const char *title = wizards[wizardNo-1].title;
+ os << "Step " << WizardNumber(wizardNo) << '/' << WizardCount() << ": "
+ << (title ? title : "(not included)");
+ return os.str();
+}
+
/**
* HandleCfgInit: /cfg/init: setup wizard dispatcher
*/
@@ -415,15 +488,7 @@ std::string OvmsWebServer::CfgInit1(PageEntry_t& p, PageContext_t& c, std::strin
}
// Wizard status:
- c.alert("info",
- "Quick setup wizard
"
- ""
- "- Secure module access
"
- "- Connect module to internet (via Wifi)
"
- "- Update to latest firmware version
"
- "- Configure vehicle type and server
"
- "- Configure cellular modem (if equipped)
"
- "
");
+ c.alert("info", WizardStatus(1).c_str());
// create some random passwords:
std::ostringstream pwsugg;
@@ -434,7 +499,7 @@ std::string OvmsWebServer::CfgInit1(PageEntry_t& p, PageContext_t& c, std::strin
pwsugg << "";
// generate form:
- c.panel_start("primary", "Step 1/5: Secure Module");
+ c.panel_start("primary", WizardFormHeader(1).c_str());
c.print(
"Your module may currently be accessed by anyone in Wifi range using the default"
@@ -564,18 +629,10 @@ std::string OvmsWebServer::CfgInit2(PageEntry_t& p, PageContext_t& c, std::strin
}
// Wizard status:
- c.alert("info",
- "
Quick setup wizard
"
- ""
- "- Secure module access ✔
"
- "- Connect module to internet (via Wifi)
"
- "- Update to latest firmware version
"
- "- Configure vehicle type and server
"
- "- Configure cellular modem (if equipped)
"
- "
");
+ c.alert("info", WizardStatus(2).c_str());
// generate form:
- c.panel_start("primary", "Step 2/5: Connect to Internet");
+ c.panel_start("primary", WizardFormHeader(2).c_str());
c.print(
"Your module now needs an internet connection to download the latest firmware"
@@ -829,18 +886,10 @@ std::string OvmsWebServer::CfgInit3(PageEntry_t& p, PageContext_t& c, std::strin
}
// Wizard status:
- c.alert("info",
- "
Quick setup wizard
"
- ""
- "- Secure module access ✔
"
- "- Connect module to internet (via Wifi) ✔
"
- "- Update to latest firmware version
"
- "- Configure vehicle type and server
"
- "- Configure cellular modem (if equipped)
"
- "
");
+ c.alert("info", WizardStatus(3).c_str());
// form:
- c.panel_start("primary", "Step 3/5: Update Firmware");
+ c.panel_start("primary", WizardFormHeader(3).c_str());
c.form_start(p.uri);
c.input_radio_start("Update server", "server");
c.input_radio_option("server", "Asia-Pacific (openvehicles.com)",
@@ -1027,18 +1076,10 @@ std::string OvmsWebServer::CfgInit4(PageEntry_t& p, PageContext_t& c, std::strin
}
// Wizard status:
- c.alert("info",
- "Quick setup wizard
"
- ""
- "- Secure module access ✔
"
- "- Connect module to internet (via Wifi) ✔
"
- "- Update to latest firmware version ✔
"
- "- Configure vehicle type and server
"
- "- Configure cellular modem (if equipped)
"
- "
");
+ c.alert("info", WizardStatus(4).c_str());
// form:
- c.panel_start("primary", "Step 4/5: Vehicle & Server");
+ c.panel_start("primary", WizardFormHeader(4).c_str());
c.form_start(p.uri);
c.input_select_start("Vehicle type", "vehicletype");
@@ -1207,18 +1248,10 @@ std::string OvmsWebServer::CfgInit5(PageEntry_t& p, PageContext_t& c, std::strin
}
// Wizard status:
- c.alert("info",
- "Quick setup wizard
"
- ""
- "- Secure module access ✔
"
- "- Connect module to internet (via Wifi) ✔
"
- "- Update to latest firmware version ✔
"
- "- Configure vehicle type and server ✔
"
- "- Configure cellular modem (if equipped)
"
- "
");
+ c.alert("info", WizardStatus(5).c_str());
// form:
- c.panel_start("primary", "Step 5/5: Cellular Modem");
+ c.panel_start("primary", WizardFormHeader(5).c_str());
c.form_start(p.uri);
std::string iccid = StdMetrics.ms_m_net_mdm_iccid->AsString();