Make the style editor commit its own changes. Fixes some issues where changes made in the style editor would fail to update the rest of the program.
Originally committed to SVN as r5754.
This commit is contained in:
parent
a75aa7a633
commit
c7d0ce60ee
3 changed files with 64 additions and 94 deletions
|
@ -78,15 +78,25 @@ static wxTextCtrl *num_text_ctrl(wxWindow *parent, double value, wxSize size = w
|
|||
return new wxTextCtrl(parent, -1, "", wxDefaultPosition, size, 0, NumValidator(wxString::Format("%0.3g", value), true, false));
|
||||
}
|
||||
|
||||
DialogStyleEditor::DialogStyleEditor (wxWindow *parent, AssStyle *style, agi::Context *c, bool local, AssStyleStorage *store, bool newStyle)
|
||||
DialogStyleEditor::DialogStyleEditor(wxWindow *parent, AssStyle *style, agi::Context *c, AssStyleStorage *store, bool copy_style)
|
||||
: wxDialog (parent, -1, _("Style Editor"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER, "DialogStyleEditor")
|
||||
, c(c)
|
||||
, isLocal(local)
|
||||
, isNew(newStyle)
|
||||
, is_new(false)
|
||||
, style(style)
|
||||
, work(new AssStyle(*style))
|
||||
, store(store)
|
||||
{
|
||||
if (copy_style) {
|
||||
is_new = true;
|
||||
style = this->style = new AssStyle(*style);
|
||||
style->name += _(" - Copy");
|
||||
}
|
||||
else if (!style) {
|
||||
is_new = true;
|
||||
style = this->style = new AssStyle;
|
||||
}
|
||||
|
||||
work.reset(new AssStyle(*style));
|
||||
|
||||
SetIcon(BitmapToIcon(GETIMAGE(style_toolbutton_24)));
|
||||
|
||||
// Prepare control values
|
||||
|
@ -332,30 +342,29 @@ DialogStyleEditor::DialogStyleEditor (wxWindow *parent, AssStyle *style, agi::Co
|
|||
}
|
||||
|
||||
DialogStyleEditor::~DialogStyleEditor() {
|
||||
if (is_new)
|
||||
delete style;
|
||||
}
|
||||
|
||||
/// @brief Update appearances of a renamed style in \r tags
|
||||
void ReplaceStyle(wxString tag, int, AssOverrideParameter* param, void *userData) {
|
||||
static void ReplaceStyle(wxString tag, int, AssOverrideParameter* param, void *userData) {
|
||||
wxArrayString strings = *((wxArrayString*)userData);
|
||||
if (tag == "\\r" && param->GetType() == VARDATA_TEXT && param->Get<wxString>() == strings[0]) {
|
||||
param->Set(strings[1]);
|
||||
}
|
||||
}
|
||||
|
||||
/// @brief Maybe apply changs and maybe close the dialog
|
||||
/// @param apply Should changes be applied?
|
||||
/// @param close Should the dialog be closed?
|
||||
void DialogStyleEditor::Apply(bool apply, bool close) {
|
||||
if (apply) {
|
||||
wxString newStyleName = StyleName->GetValue();
|
||||
|
||||
// Get list of existing styles
|
||||
wxArrayString styles = isLocal ? c->ass->GetStyles() : store->GetNames();
|
||||
wxArrayString styles = store ? store->GetNames() : c->ass->GetStyles();
|
||||
|
||||
// Check if style name is unique
|
||||
for (unsigned int i=0;i<styles.Count();i++) {
|
||||
if (newStyleName.CmpNoCase(styles[i]) == 0) {
|
||||
if ((isLocal && (c->ass->GetStyle(styles[i]) != style)) || (!isLocal && (store->GetStyle(styles[i]) != style))) {
|
||||
if ((store && store->GetStyle(styles[i]) != style) || c->ass->GetStyle(styles[i]) != style) {
|
||||
wxMessageBox("There is already a style with this name. Please choose another name.", "Style name conflict.", wxICON_ERROR|wxOK);
|
||||
return;
|
||||
}
|
||||
|
@ -365,11 +374,9 @@ void DialogStyleEditor::Apply (bool apply, bool close) {
|
|||
// Style name change
|
||||
bool did_rename = false;
|
||||
if (work->name != newStyleName) {
|
||||
if (!isNew && isLocal) {
|
||||
if (!store && !is_new && work->name != "Default") {
|
||||
// See if user wants to update style name through script
|
||||
int answer = wxNO;
|
||||
if (work->name != "Default")
|
||||
answer = wxMessageBox(_("Do you want to change all instances of this style in the script to this new name?"), _("Update script?"), wxYES_NO | wxCANCEL);
|
||||
int answer = wxMessageBox(_("Do you want to change all instances of this style in the script to this new name?"), _("Update script?"), wxYES_NO | wxCANCEL);
|
||||
|
||||
if (answer == wxCANCEL) return;
|
||||
|
||||
|
@ -397,7 +404,14 @@ void DialogStyleEditor::Apply (bool apply, bool close) {
|
|||
|
||||
*style = *work;
|
||||
style->UpdateData();
|
||||
if (isLocal)
|
||||
if (is_new) {
|
||||
if (store)
|
||||
store->style.push_back(style);
|
||||
else
|
||||
c->ass->InsertStyle(style);
|
||||
is_new = false;
|
||||
}
|
||||
if (!store)
|
||||
c->ass->Commit(_("style change"), AssFile::COMMIT_STYLES | (did_rename ? AssFile::COMMIT_DIAG_FULL : 0));
|
||||
|
||||
// Update preview
|
||||
|
|
|
@ -60,13 +60,10 @@ class DialogStyleEditor : public wxDialog {
|
|||
agi::Context *c;
|
||||
agi::scoped_ptr<PersistLocation> persist;
|
||||
|
||||
/// DOCME
|
||||
bool isLocal;
|
||||
|
||||
/// If true, the style was just created and so the user should not be
|
||||
/// asked if they want to change any existing lines should they rename
|
||||
/// the style
|
||||
bool isNew;
|
||||
bool is_new;
|
||||
|
||||
/// DOCME
|
||||
AssStyle *style;
|
||||
|
@ -151,10 +148,13 @@ class DialogStyleEditor : public wxDialog {
|
|||
void OnPreviewTextChange(wxCommandEvent &event);
|
||||
void OnPreviewColourChange(wxCommandEvent &event);
|
||||
|
||||
/// @brief Maybe apply changes and maybe close the dialog
|
||||
/// @param apply Should changes be applied?
|
||||
/// @param close Should the dialog be closed?
|
||||
void Apply(bool apply,bool close);
|
||||
void OnSetColor(int n, wxCommandEvent& evt);
|
||||
|
||||
public:
|
||||
DialogStyleEditor(wxWindow *parent,AssStyle *style, agi::Context *c,bool local,AssStyleStorage *store,bool newStyle=false);
|
||||
DialogStyleEditor(wxWindow *parent, AssStyle *style, agi::Context *c, AssStyleStorage *store, bool copy_style);
|
||||
~DialogStyleEditor();
|
||||
};
|
||||
|
|
|
@ -481,12 +481,10 @@ void DialogStyleManager::OnStorageEdit (wxCommandEvent &) {
|
|||
int n = StorageList->GetSelections(selections);
|
||||
if (n == 1) {
|
||||
AssStyle *selStyle = styleStorageMap[selections[0]];
|
||||
DialogStyleEditor editor(this,selStyle,c,false,&Store);
|
||||
if (editor.ShowModal()) {
|
||||
DialogStyleEditor(this, selStyle, c, &Store, false).ShowModal();
|
||||
StorageList->SetString(selections[0],selStyle->name);
|
||||
Store.Save(CatalogList->GetString(CatalogList->GetSelection()));
|
||||
}
|
||||
}
|
||||
UpdateMoveButtons();
|
||||
}
|
||||
|
||||
|
@ -496,11 +494,9 @@ void DialogStyleManager::OnCurrentEdit (wxCommandEvent &) {
|
|||
int n = CurrentList->GetSelections(selections);
|
||||
if (n == 1) {
|
||||
AssStyle *selStyle = styleMap[selections[0]];
|
||||
DialogStyleEditor editor(this,selStyle,c,true,&Store);
|
||||
if (editor.ShowModal()) {
|
||||
DialogStyleEditor(this, selStyle, c, 0, false).ShowModal();
|
||||
CurrentList->SetString(selections[0],selStyle->name);
|
||||
}
|
||||
}
|
||||
UpdateMoveButtons();
|
||||
}
|
||||
|
||||
|
@ -606,21 +602,10 @@ void DialogStyleManager::OnStorageCopy (wxCommandEvent &) {
|
|||
wxArrayInt selections;
|
||||
StorageList->GetSelections(selections);
|
||||
if (selections.size() == 0) return;
|
||||
AssStyle *temp = new AssStyle(*(styleStorageMap.at(selections[0])));
|
||||
|
||||
wxString newName = _("Copy of ");
|
||||
newName += temp->name;
|
||||
temp->name = newName;
|
||||
|
||||
DialogStyleEditor editor(this,temp,c,false,&Store,true);
|
||||
int modified = editor.ShowModal();
|
||||
if (modified) {
|
||||
Store.style.push_back(temp);
|
||||
DialogStyleEditor(this, styleStorageMap[selections[0]], c, &Store, true).ShowModal();
|
||||
Store.Save(CatalogList->GetString(CatalogList->GetSelection()));
|
||||
LoadStorageStyles();
|
||||
StorageList->SetStringSelection(temp->name); // the copy/delete/copy-to-local buttons stay disabled after this?
|
||||
}
|
||||
else delete temp;
|
||||
UpdateMoveButtons();
|
||||
}
|
||||
|
||||
|
@ -630,21 +615,8 @@ void DialogStyleManager::OnCurrentCopy (wxCommandEvent &) {
|
|||
CurrentList->GetSelections(selections);
|
||||
if (selections.size() == 0) return;
|
||||
|
||||
AssStyle *temp = new AssStyle(styleMap.at(selections[0])->GetEntryData());
|
||||
wxString newName = _("Copy of ");
|
||||
newName += temp->name;
|
||||
temp->name = newName;
|
||||
|
||||
DialogStyleEditor editor(this,temp,c,true,&Store,true);
|
||||
int modified = editor.ShowModal();
|
||||
if (modified) {
|
||||
c->ass->InsertStyle(temp);
|
||||
DialogStyleEditor(this, styleMap[selections[0]], c, 0, true).ShowModal();
|
||||
LoadCurrentStyles(c->ass);
|
||||
CurrentList->SetStringSelection(temp->name); // but even without this, the copy/delete/copy-to-storage buttons stay enabled?
|
||||
}
|
||||
else delete temp;
|
||||
|
||||
c->ass->Commit(_("style copy"), AssFile::COMMIT_STYLES);
|
||||
UpdateMoveButtons();
|
||||
}
|
||||
|
||||
|
@ -750,32 +722,16 @@ void DialogStyleManager::PasteToStorage() {
|
|||
|
||||
/// @brief Storage new
|
||||
void DialogStyleManager::OnStorageNew (wxCommandEvent &) {
|
||||
AssStyle *temp = new AssStyle;
|
||||
|
||||
DialogStyleEditor editor(this,temp,c,false,&Store,true);
|
||||
int modified = editor.ShowModal();
|
||||
if (modified) {
|
||||
Store.style.push_back(temp);
|
||||
DialogStyleEditor(this, 0, c, &Store, false).ShowModal();
|
||||
Store.Save(CatalogList->GetString(CatalogList->GetSelection()));
|
||||
LoadStorageStyles();
|
||||
StorageList->SetStringSelection(temp->name);
|
||||
}
|
||||
else delete temp;
|
||||
UpdateMoveButtons();
|
||||
}
|
||||
|
||||
/// @brief Current new
|
||||
void DialogStyleManager::OnCurrentNew (wxCommandEvent &) {
|
||||
AssStyle *temp = new AssStyle;
|
||||
|
||||
DialogStyleEditor editor(this,temp,c,true,&Store,true);
|
||||
int modified = editor.ShowModal();
|
||||
if (modified) {
|
||||
c->ass->InsertStyle(temp);
|
||||
DialogStyleEditor(this,0, c, 0, false).ShowModal();
|
||||
LoadCurrentStyles(c->ass);
|
||||
CurrentList->SetStringSelection(temp->name);
|
||||
}
|
||||
else delete temp;
|
||||
UpdateMoveButtons();
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue