Fixed app name interpolation for : GUI_App, MainFrame, MsgDialog, Preferences, Tab and UpdateDialogs
+ added edit_tooltip(), wich replaces Slic3r for SLIC3R_APP_KEY
This commit is contained in:
parent
afbe0d9e60
commit
7560de0704
11 changed files with 33 additions and 17 deletions
|
@ -213,7 +213,7 @@ void PrintConfigDef::init_fff_params()
|
||||||
|
|
||||||
def = this->add("clip_multipart_objects", coBool);
|
def = this->add("clip_multipart_objects", coBool);
|
||||||
def->label = L("Clip multi-part objects");
|
def->label = L("Clip multi-part objects");
|
||||||
def->tooltip = L("When printing multi-material objects, this settings will make slic3r "
|
def->tooltip = L("When printing multi-material objects, this settings will make Slic3r "
|
||||||
"to clip the overlapping object parts one by the other "
|
"to clip the overlapping object parts one by the other "
|
||||||
"(2nd part will be clipped by the 1st, 3rd part will be clipped by the 1st and 2nd etc).");
|
"(2nd part will be clipped by the 1st, 3rd part will be clipped by the 1st and 2nd etc).");
|
||||||
def->mode = comExpert;
|
def->mode = comExpert;
|
||||||
|
|
|
@ -100,6 +100,7 @@ wxString Field::get_tooltip_text(const wxString& default_string)
|
||||||
{
|
{
|
||||||
wxString tooltip_text("");
|
wxString tooltip_text("");
|
||||||
wxString tooltip = _(m_opt.tooltip);
|
wxString tooltip = _(m_opt.tooltip);
|
||||||
|
edit_tooltip(tooltip);
|
||||||
if (tooltip.length() > 0)
|
if (tooltip.length() > 0)
|
||||||
tooltip_text = tooltip + "\n" + _(L("default value")) + "\t: " +
|
tooltip_text = tooltip + "\n" + _(L("default value")) + "\t: " +
|
||||||
(boost::iends_with(m_opt_id, "_gcode") ? "\n" : "") + default_string +
|
(boost::iends_with(m_opt_id, "_gcode") ? "\n" : "") + default_string +
|
||||||
|
|
|
@ -663,7 +663,7 @@ void GUI_App::add_config_menu(wxMenuBar *menu)
|
||||||
Bind(wxEVT_UPDATE_UI, [this](wxUpdateUIEvent& evt) { evt.Check(get_mode() == comAdvanced); }, config_id_base + ConfigMenuModeAdvanced);
|
Bind(wxEVT_UPDATE_UI, [this](wxUpdateUIEvent& evt) { evt.Check(get_mode() == comAdvanced); }, config_id_base + ConfigMenuModeAdvanced);
|
||||||
Bind(wxEVT_UPDATE_UI, [this](wxUpdateUIEvent& evt) { evt.Check(get_mode() == comExpert); }, config_id_base + ConfigMenuModeExpert);
|
Bind(wxEVT_UPDATE_UI, [this](wxUpdateUIEvent& evt) { evt.Check(get_mode() == comExpert); }, config_id_base + ConfigMenuModeExpert);
|
||||||
|
|
||||||
local_menu->AppendSubMenu(mode_menu, _(L("Mode")), _(L("Slic3r View Mode")));
|
local_menu->AppendSubMenu(mode_menu, _(L("Mode")), wxString::Format(_(L("%s View Mode")), SLIC3R_APP_NAME));
|
||||||
local_menu->AppendSeparator();
|
local_menu->AppendSeparator();
|
||||||
local_menu->Append(config_id_base + ConfigMenuLanguage, _(L("Change Application &Language")));
|
local_menu->Append(config_id_base + ConfigMenuLanguage, _(L("Change Application &Language")));
|
||||||
local_menu->AppendSeparator();
|
local_menu->AppendSeparator();
|
||||||
|
|
|
@ -360,7 +360,7 @@ void MainFrame::init_menubar()
|
||||||
append_menu_item(fileMenu, wxID_ANY, _(L("&Repair STL file")) + dots, _(L("Automatically repair an STL file")),
|
append_menu_item(fileMenu, wxID_ANY, _(L("&Repair STL file")) + dots, _(L("Automatically repair an STL file")),
|
||||||
[this](wxCommandEvent&) { repair_stl(); }, "wrench");
|
[this](wxCommandEvent&) { repair_stl(); }, "wrench");
|
||||||
fileMenu->AppendSeparator();
|
fileMenu->AppendSeparator();
|
||||||
append_menu_item(fileMenu, wxID_EXIT, _(L("&Quit")), _(L("Quit Slic3r")),
|
append_menu_item(fileMenu, wxID_EXIT, _(L("&Quit")), wxString::Format(_(L("Quit %s")), SLIC3R_APP_NAME),
|
||||||
[this](wxCommandEvent&) { Close(false); });
|
[this](wxCommandEvent&) { Close(false); });
|
||||||
|
|
||||||
Bind(wxEVT_UPDATE_UI, [this](wxUpdateUIEvent& evt) { evt.Enable(m_plater != nullptr); }, item_open->GetId());
|
Bind(wxEVT_UPDATE_UI, [this](wxUpdateUIEvent& evt) { evt.Enable(m_plater != nullptr); }, item_open->GetId());
|
||||||
|
@ -497,9 +497,11 @@ void MainFrame::init_menubar()
|
||||||
//# wxTheApp->check_version(1);
|
//# wxTheApp->check_version(1);
|
||||||
//# });
|
//# });
|
||||||
//# $versioncheck->Enable(wxTheApp->have_version_check);
|
//# $versioncheck->Enable(wxTheApp->have_version_check);
|
||||||
append_menu_item(helpMenu, wxID_ANY, _(L("Slic3r &Website")), _(L("Open the Slic3r website in your browser")),
|
append_menu_item(helpMenu, wxID_ANY, wxString::Format(_(L("%s &Website")), SLIC3R_APP_NAME),
|
||||||
|
wxString::Format(_(L("Open the %s website in your browser")), SLIC3R_APP_NAME),
|
||||||
[this](wxCommandEvent&) { wxLaunchDefaultBrowser("http://slic3r.org/"); });
|
[this](wxCommandEvent&) { wxLaunchDefaultBrowser("http://slic3r.org/"); });
|
||||||
append_menu_item(helpMenu, wxID_ANY, _(L("Slic3r &Manual")), _(L("Open the Slic3r manual in your browser")),
|
append_menu_item(helpMenu, wxID_ANY, wxString::Format(_(L("%s &Manual")), SLIC3R_APP_NAME),
|
||||||
|
wxString::Format(_(L("Open the %s manual in your browser")), SLIC3R_APP_NAME),
|
||||||
[this](wxCommandEvent&) { wxLaunchDefaultBrowser("http://manual.slic3r.org/"); });
|
[this](wxCommandEvent&) { wxLaunchDefaultBrowser("http://manual.slic3r.org/"); });
|
||||||
helpMenu->AppendSeparator();
|
helpMenu->AppendSeparator();
|
||||||
append_menu_item(helpMenu, wxID_ANY, _(L("System &Info")), _(L("Show system information")),
|
append_menu_item(helpMenu, wxID_ANY, _(L("System &Info")), _(L("Show system information")),
|
||||||
|
|
|
@ -70,7 +70,8 @@ MsgDialog::~MsgDialog() {}
|
||||||
// ErrorDialog
|
// ErrorDialog
|
||||||
|
|
||||||
ErrorDialog::ErrorDialog(wxWindow *parent, const wxString &msg)
|
ErrorDialog::ErrorDialog(wxWindow *parent, const wxString &msg)
|
||||||
: MsgDialog(parent, _(L("Slic3r error")), _(L("Slic3r has encountered an error")),
|
: MsgDialog(parent, wxString::Format(_(L("%s error")), SLIC3R_APP_NAME),
|
||||||
|
wxString::Format(_(L("%s has encountered an error")), SLIC3R_APP_NAME),
|
||||||
wxID_NONE)
|
wxID_NONE)
|
||||||
, msg(msg)
|
, msg(msg)
|
||||||
{
|
{
|
||||||
|
|
|
@ -307,7 +307,10 @@ void OptionsGroup::append_line(const Line& line, wxStaticText** full_Label/* = n
|
||||||
}
|
}
|
||||||
|
|
||||||
Line OptionsGroup::create_single_option_line(const Option& option) const {
|
Line OptionsGroup::create_single_option_line(const Option& option) const {
|
||||||
Line retval{ _(option.opt.label), _(option.opt.tooltip) };
|
// Line retval{ _(option.opt.label), _(option.opt.tooltip) };
|
||||||
|
wxString tooltip = _(option.opt.tooltip);
|
||||||
|
edit_tooltip(tooltip);
|
||||||
|
Line retval{ _(option.opt.label), tooltip };
|
||||||
Option tmp(option);
|
Option tmp(option);
|
||||||
tmp.opt.label = std::string("");
|
tmp.opt.label = std::string("");
|
||||||
retval.append_option(tmp);
|
retval.append_option(tmp);
|
||||||
|
|
|
@ -127,7 +127,7 @@ void PreferencesDialog::accept()
|
||||||
{
|
{
|
||||||
if (m_values.find("no_defaults") != m_values.end() ||
|
if (m_values.find("no_defaults") != m_values.end() ||
|
||||||
m_values.find("use_legacy_opengl") != m_values.end()) {
|
m_values.find("use_legacy_opengl") != m_values.end()) {
|
||||||
warning_catcher(this, _(L("You need to restart Slic3r to make the changes effective.")));
|
warning_catcher(this, wxString::Format(_(L("You need to restart %s to make the changes effective.")), SLIC3R_APP_NAME));
|
||||||
}
|
}
|
||||||
|
|
||||||
auto app_config = get_app_config();
|
auto app_config = get_app_config();
|
||||||
|
|
|
@ -1770,9 +1770,9 @@ void TabPrinter::build_printhost(ConfigOptionsGroup *optgroup)
|
||||||
|
|
||||||
line.widget = [this, ca_file_hint] (wxWindow* parent) {
|
line.widget = [this, ca_file_hint] (wxWindow* parent) {
|
||||||
auto txt = new wxStaticText(parent, wxID_ANY, wxString::Format("%s\n\n\t%s",
|
auto txt = new wxStaticText(parent, wxID_ANY, wxString::Format("%s\n\n\t%s",
|
||||||
_(L("HTTPS CA File:\n\
|
wxString::Format(_(L("HTTPS CA File:\n\
|
||||||
\tOn this system, Slic3r uses HTTPS certificates from the system Certificate Store or Keychain.\n\
|
\tOn this system, %s uses HTTPS certificates from the system Certificate Store or Keychain.\n\
|
||||||
\tTo use a custom CA file, please import your CA file into Certificate Store / Keychain.")),
|
\tTo use a custom CA file, please import your CA file into Certificate Store / Keychain.")), SLIC3R_APP_NAME),
|
||||||
ca_file_hint));
|
ca_file_hint));
|
||||||
txt->SetFont(Slic3r::GUI::wxGetApp().normal_font());
|
txt->SetFont(Slic3r::GUI::wxGetApp().normal_font());
|
||||||
auto sizer = new wxBoxSizer(wxHORIZONTAL);
|
auto sizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
|
@ -109,7 +109,8 @@ MsgUpdateConfig::~MsgUpdateConfig() {}
|
||||||
// MsgDataIncompatible
|
// MsgDataIncompatible
|
||||||
|
|
||||||
MsgDataIncompatible::MsgDataIncompatible(const std::unordered_map<std::string, wxString> &incompats) :
|
MsgDataIncompatible::MsgDataIncompatible(const std::unordered_map<std::string, wxString> &incompats) :
|
||||||
MsgDialog(nullptr, _(L("Slic3r incompatibility")), _(L("Slic3r configuration is incompatible")), wxID_NONE)
|
MsgDialog(nullptr, wxString::Format(_(L("%s incompatibility")), SLIC3R_APP_NAME),
|
||||||
|
wxString::Format(_(L("%s configuration is incompatible")), SLIC3R_APP_NAME), wxID_NONE)
|
||||||
{
|
{
|
||||||
logo->SetBitmap(create_scaled_bitmap(this, "Slic3r_192px_grayscale.png", 192));
|
logo->SetBitmap(create_scaled_bitmap(this, "Slic3r_192px_grayscale.png", 192));
|
||||||
|
|
||||||
|
@ -117,9 +118,9 @@ MsgDataIncompatible::MsgDataIncompatible(const std::unordered_map<std::string, w
|
||||||
"This version of %s is not compatible with currently installed configuration bundles.\n"
|
"This version of %s is not compatible with currently installed configuration bundles.\n"
|
||||||
"This probably happened as a result of running an older %s after using a newer one.\n\n"
|
"This probably happened as a result of running an older %s after using a newer one.\n\n"
|
||||||
|
|
||||||
"You may either exit Slic3r and try again with a newer version, or you may re-run the initial configuration. "
|
"You may either exit %s and try again with a newer version, or you may re-run the initial configuration. "
|
||||||
"Doing so will create a backup snapshot of the existing configuration before installing files compatible with this Slic3r.\n"
|
"Doing so will create a backup snapshot of the existing configuration before installing files compatible with this %s.\n"
|
||||||
)), SLIC3R_APP_NAME, SLIC3R_APP_NAME));
|
)), SLIC3R_APP_NAME, SLIC3R_APP_NAME, SLIC3R_APP_NAME, SLIC3R_APP_NAME));
|
||||||
text->Wrap(CONTENT_WIDTH * wxGetApp().em_unit());
|
text->Wrap(CONTENT_WIDTH * wxGetApp().em_unit());
|
||||||
content_sizer->Add(text);
|
content_sizer->Add(text);
|
||||||
|
|
||||||
|
@ -144,7 +145,7 @@ MsgDataIncompatible::MsgDataIncompatible(const std::unordered_map<std::string, w
|
||||||
content_sizer->Add(versions);
|
content_sizer->Add(versions);
|
||||||
content_sizer->AddSpacer(2*VERT_SPACING);
|
content_sizer->AddSpacer(2*VERT_SPACING);
|
||||||
|
|
||||||
auto *btn_exit = new wxButton(this, wxID_EXIT, _(L("Exit Slic3r")));
|
auto *btn_exit = new wxButton(this, wxID_EXIT, wxString::Format(_(L("Exit %s")), SLIC3R_APP_NAME));
|
||||||
btn_sizer->Add(btn_exit);
|
btn_sizer->Add(btn_exit);
|
||||||
btn_sizer->AddSpacer(HORIZ_SPACING);
|
btn_sizer->AddSpacer(HORIZ_SPACING);
|
||||||
auto *btn_reconf = new wxButton(this, wxID_REPLACE, _(L("Re-configure")));
|
auto *btn_reconf = new wxButton(this, wxID_REPLACE, _(L("Re-configure")));
|
||||||
|
@ -187,7 +188,7 @@ MsgDataLegacy::MsgDataLegacy() :
|
||||||
auto *text2 = new wxStaticText(this, wxID_ANY, _(L("For more information please visit our wiki page:")));
|
auto *text2 = new wxStaticText(this, wxID_ANY, _(L("For more information please visit our wiki page:")));
|
||||||
static const wxString url("https://github.com/prusa3d/Slic3r/wiki/Slic3r-PE-1.40-configuration-update");
|
static const wxString url("https://github.com/prusa3d/Slic3r/wiki/Slic3r-PE-1.40-configuration-update");
|
||||||
// The wiki page name is intentionally not localized:
|
// The wiki page name is intentionally not localized:
|
||||||
auto *link = new wxHyperlinkCtrl(this, wxID_ANY, "Slic3r PE 1.40 configuration update", CONFIG_UPDATE_WIKI_URL);
|
auto *link = new wxHyperlinkCtrl(this, wxID_ANY, wxString::Format("%s 1.40 configuration update", SLIC3R_APP_NAME), CONFIG_UPDATE_WIKI_URL);
|
||||||
content_sizer->Add(text2);
|
content_sizer->Add(text2);
|
||||||
content_sizer->Add(link);
|
content_sizer->Add(link);
|
||||||
content_sizer->AddSpacer(VERT_SPACING);
|
content_sizer->AddSpacer(VERT_SPACING);
|
||||||
|
|
|
@ -267,6 +267,13 @@ void wxDataViewTreeCtrlComboPopup::OnDataViewTreeCtrlSelection(wxCommandEvent& e
|
||||||
cmb->SetText(selected);
|
cmb->SetText(selected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// edit tooltip : change Slic3r to SLIC3R_APP_KEY
|
||||||
|
// Temporary workaround for localization
|
||||||
|
void edit_tooltip(wxString& tooltip)
|
||||||
|
{
|
||||||
|
tooltip.Replace("Slic3r", SLIC3R_APP_KEY, true);
|
||||||
|
}
|
||||||
|
|
||||||
/* Function for rescale of buttons in Dialog under MSW if dpi is changed.
|
/* Function for rescale of buttons in Dialog under MSW if dpi is changed.
|
||||||
* btn_ids - vector of buttons identifiers
|
* btn_ids - vector of buttons identifiers
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -32,6 +32,7 @@ wxMenuItem* append_menu_radio_item(wxMenu* menu, int id, const wxString& string,
|
||||||
std::function<void(wxCommandEvent& event)> cb, wxEvtHandler* event_handler);
|
std::function<void(wxCommandEvent& event)> cb, wxEvtHandler* event_handler);
|
||||||
|
|
||||||
class wxDialog;
|
class wxDialog;
|
||||||
|
void edit_tooltip(wxString& tooltip);
|
||||||
void msw_buttons_rescale(wxDialog* dlg, const int em_unit, const std::vector<int>& btn_ids);
|
void msw_buttons_rescale(wxDialog* dlg, const int em_unit, const std::vector<int>& btn_ids);
|
||||||
int em_unit(wxWindow* win);
|
int em_unit(wxWindow* win);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue