diff options
Diffstat (limited to 'src/ui/ui_contacts.cpp')
| -rw-r--r-- | src/ui/ui_contacts.cpp | 30 |
1 files changed, 27 insertions, 3 deletions
diff --git a/src/ui/ui_contacts.cpp b/src/ui/ui_contacts.cpp index dbe6625..d680ae8 100644 --- a/src/ui/ui_contacts.cpp +++ b/src/ui/ui_contacts.cpp @@ -5,6 +5,7 @@ #include "ui.hpp" #include "imgui.h" #include "administration.hpp" +#include "administration_writer.hpp" #include "locales.hpp" static view_state current_view_state = view_state::LIST; @@ -259,7 +260,14 @@ static void draw_contact_list() ImGui::Separator(); if (ImGui::Button(localize("form.yes"), ImVec2(120, 0))) { - administration_contact_remove(selected_for_removal); + if (administration_contact_remove(selected_for_removal)) { + if (administration_writer_delete_entry(selected_for_removal.id)) { + ui_set_status(localize("status.saved")); + } + else { + ui_set_status_error(localize("status.saveFailed")); + } + } ImGui::CloseCurrentPopup(); } ImGui::SameLine(); @@ -286,7 +294,15 @@ static void ui_draw_contacts_create() // Save button ImGui::Spacing(); if (ImGui::Button(localize("form.save"))) { - administration_contact_add(active_contact); + if (administration_contact_add(active_contact)) { + if (administration_writer_save_contact_blocking(active_contact)) { + ui_set_status(localize("status.saved")); + } + else { + ui_set_status_error(localize("status.saveFailed")); + } + } + current_view_state = view_state::LIST; } if (!can_save) ImGui::EndDisabled(); @@ -305,7 +321,15 @@ static void ui_draw_contacts_update() // Save button ImGui::Spacing(); if (ImGui::Button(localize("form.save"))) { - administration_contact_update(active_contact); + if (administration_contact_update(active_contact)) { + if (administration_writer_save_contact_blocking(active_contact)) { + ui_set_status(localize("status.saved")); + } + else { + ui_set_status_error(localize("status.saveFailed")); + } + } + current_view_state = view_state::LIST; } if (!can_save) ImGui::EndDisabled(); |
