EVT_TOOL_RANGE(ID_PREVIEW, ID_EXIT, EditorFrame::OnToolbar)
EVT_MENU_RANGE(ID_NEWDIALOG, ID_NEWSYBNODE + 1000, EditorFrame::OnNewNode)
EVT_MENU_RANGE(ID_CUT, ID_COPY, EditorFrame::OnClipboardAction)
+ EVT_CLOSE(EditorFrame::OnCloseWindow)
END_EVENT_TABLE()
ms_Instance = this;
m_Clipboard = NULL;
+ m_Modified = FALSE;
wxConfigBase *cfg = wxConfigBase::Get();
void EditorFrame::LoadFile(const wxString& filename)
{
+ if (!AskToSave()) return;
+
delete m_Resource;
m_FileName = "";
m_Resource = new wxXmlDocument;
+ m_Modified = FALSE;
if (!m_Resource->Load(filename))
{
{
m_FileName = filename;
RefreshTree();
- SetTitle("wxrcedit - " + wxFileNameFromPath(m_FileName));
}
+ RefreshTitle();
}
void EditorFrame::SaveFile(const wxString& filename)
{
m_FileName = filename;
- SetTitle("wxrcedit - " + wxFileNameFromPath(m_FileName));
- if (!m_Resource->Save(filename, wxXML_IO_LIBXML))
- wxLogError("Error saving " + filename);
+ if (!m_Resource->Save(filename))
+ wxLogError(_("Error saving ") + filename);
+ else
+ m_Modified = FALSE;
+
+ RefreshTitle();
}
void EditorFrame::NewFile()
{
+ if (!AskToSave()) return;
+
delete m_Resource;
m_FileName = "";
m_Resource = new wxXmlDocument;
- m_Resource->SetRoot(new wxXmlNode(wxXML_ELEMENT_NODE, "resource"));
+ m_Resource->SetRoot(new wxXmlNode(wxXML_ELEMENT_NODE, _("resource")));
+ m_Modified = FALSE;
RefreshTree();
- SetTitle("unnamed");
+ RefreshTitle();
+}
+
+
+
+void EditorFrame::RefreshTitle()
+{
+ wxString s;
+ if (m_Modified) s << _T("* ");
+ s << _("wxrcedit");
+ if (!m_FileName)
+ s << _T(" - ") << wxFileNameFromPath(m_FileName);
+ SetTitle(s);
}
+
+static void RecursivelyExpand(wxTreeCtrl *t, wxTreeItemId item)
+{
+ t->Expand(item);
+ long cookie;
+ wxTreeItemId id = t->GetFirstChild(item, cookie);
+ while (id.IsOk())
+ {
+ RecursivelyExpand(t, id);
+ id = t->GetNextChild(item, cookie);
+ }
+}
+
bool EditorFrame::SelectNode(wxXmlNode *node, wxTreeItemId *root)
{
if (root == NULL)
nd = (dt) ? dt->Node : NULL;
if (nd == node)
{
+ RecursivelyExpand(m_TreeCtrl, *root);
m_TreeCtrl->SelectItem(item);
m_TreeCtrl->EnsureVisible(item);
- return TRUE;
+ return TRUE;
}
if (m_TreeCtrl->ItemHasChildren(item) && SelectNode(node, &item))
- return TRUE;
+ return TRUE;
item = m_TreeCtrl->GetNextChild(*root, cookie);
}
+
return FALSE;
}
int icon = NodeHandler::Find(m_SelectedNode)->GetTreeIcon(m_SelectedNode);
m_TreeCtrl->SetItemImage(sel, icon);
}
-}
-
-
-
-static void RecursivelyExpand(wxTreeCtrl *t, wxTreeItemId item)
-{
- t->Expand(item);
- long cookie;
- wxTreeItemId id = t->GetFirstChild(item, cookie);
- while (id.IsOk())
+
+ if (!m_Modified)
{
- RecursivelyExpand(t, id);
- id = t->GetNextChild(item, cookie);
+ m_Modified = TRUE;
+ RefreshTitle();
}
+
+ PreviewFrame::Get()->MakeDirty();
}
+
+
void EditorFrame::OnTreeSel(wxTreeEvent& event)
{
XmlTreeData *dt = (XmlTreeData*)(m_TreeCtrl->GetItemData(event.GetItem()));
case ID_OPEN :
{
+ wxString cwd = wxGetCwd(); // workaround for 2.2
wxString name = wxFileSelector(_("Open XML resource"), _T(""), _T(""), _T(""), _("XML resources (*.xrc)|*.xrc"), wxOPEN | wxFILE_MUST_EXIST);
+ wxSetWorkingDirectory(cwd);
if (!name.IsEmpty())
LoadFile(name);
break;
case ID_SAVEAS :
{
+ wxString cwd = wxGetCwd(); // workaround for 2.2
wxString name = wxFileSelector(_("Save as"), _T(""), m_FileName, _T(""), _("XML resources (*.xrc)|*.xrc"), wxSAVE | wxOVERWRITE_PROMPT);
+ wxSetWorkingDirectory(cwd);
if (!name.IsEmpty())
SaveFile((m_FileName = name));
break;
}
}
+
+
+
+bool EditorFrame::AskToSave()
+ // asks the user to save current document (if modified)
+ // returns FALSE if user cancelled the action, TRUE of he choosed
+ // 'yes' or 'no'
+{
+ if (!m_Modified) return TRUE;
+
+ int res = wxMessageBox(_("File modified. Do you want to save changes?"), _("Save changes"),
+ wxYES_NO | wxCANCEL | wxCENTRE | wxICON_QUESTION);
+ if (res == wxYES)
+ SaveFile(m_FileName);
+ return (res != wxCANCEL);
+}
+
+
+
+void EditorFrame::OnCloseWindow(wxCloseEvent&)
+{
+ if (!AskToSave()) return;
+ Destroy();
+}