mirror of
				https://github.com/Gnucash/gnucash.git
				synced 2025-02-25 18:55:30 -06:00 
			
		
		
		
	Bug 797051 - Overwrite prices without warning
Currently if you add a price and a price already exists for that commodity/currency/day combination it will silently replace that price. The same is also true for editing a prices if you decide to change the date. To overcome this add a gnc-warning which allows the response to be saved temporary or permanently.
This commit is contained in:
		| @@ -44,6 +44,7 @@ | ||||
| #include "gnc-session.h" | ||||
| #include "gnc-ui.h" | ||||
| #include "gnc-ui-util.h" | ||||
| #include "gnc-warnings.h" | ||||
| #include "guile-util.h" | ||||
| #include "engine-helpers.h" | ||||
|  | ||||
| @@ -93,6 +94,7 @@ gnc_prices_set_changed (PriceEditDialog *pedit_dialog, gboolean changed) | ||||
|     pedit_dialog->changed = changed; | ||||
|  | ||||
|     gtk_widget_set_sensitive (pedit_dialog->apply_button, changed); | ||||
|     gtk_widget_set_sensitive (pedit_dialog->ok_button, changed); | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -192,6 +194,56 @@ price_to_gui (PriceEditDialog *pedit_dialog) | ||||
| } | ||||
|  | ||||
|  | ||||
| static gboolean | ||||
| pedit_dialog_replace_found_price (PriceEditDialog *pedit_dialog, | ||||
|                                   const gnc_commodity *commodity, | ||||
|                                   const gnc_commodity *currency, time64 t) | ||||
| { | ||||
|     gboolean price_found = FALSE; | ||||
|     GNCPrice *test_price = gnc_pricedb_lookup_day_t64 (pedit_dialog->price_db, | ||||
|                                                        commodity, currency, t); | ||||
|  | ||||
|     if (test_price) | ||||
|     { | ||||
|         if (pedit_dialog->is_new) // new price | ||||
|             price_found = TRUE; | ||||
|         else // edit price | ||||
|         { | ||||
|             if (!gnc_price_equal (test_price, pedit_dialog->price)) | ||||
|                 price_found = TRUE; | ||||
|         } | ||||
|         gnc_price_unref (test_price); | ||||
|     } | ||||
|  | ||||
|     if (price_found) | ||||
|     { | ||||
|         gint response; | ||||
|         GtkWidget *dialog; | ||||
|         gchar *message = _("Are you sure you want to replace the existing price?"); | ||||
|  | ||||
|         dialog = gtk_message_dialog_new (GTK_WINDOW (pedit_dialog->dialog), | ||||
|                                          GTK_DIALOG_DESTROY_WITH_PARENT, | ||||
|                                          GTK_MESSAGE_QUESTION, | ||||
|                                          GTK_BUTTONS_NONE, | ||||
|                                          "%s", _("Replace price?")); | ||||
|         gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG(dialog), | ||||
|                         "%s", message); | ||||
|  | ||||
|         gtk_dialog_add_buttons (GTK_DIALOG(dialog), | ||||
|                               _("_Cancel"), GTK_RESPONSE_CANCEL, | ||||
|                               _("_Replace"), GTK_RESPONSE_YES, | ||||
|                                (gchar *)NULL); | ||||
|         gtk_dialog_set_default_response (GTK_DIALOG(dialog), GTK_RESPONSE_YES); | ||||
|         response = gnc_dialog_run (GTK_DIALOG(dialog), GNC_PREF_WARN_PRICE_QUOTES_REPLACE); | ||||
|         gtk_widget_destroy (dialog); | ||||
|  | ||||
|         if (response == GTK_RESPONSE_CANCEL) | ||||
|             return FALSE; | ||||
|     } | ||||
|     return TRUE; | ||||
| } | ||||
|  | ||||
|  | ||||
| static const char * | ||||
| gui_to_price (PriceEditDialog *pedit_dialog) | ||||
| { | ||||
| @@ -229,6 +281,9 @@ gui_to_price (PriceEditDialog *pedit_dialog) | ||||
|     value = gnc_amount_edit_get_amount | ||||
|             (GNC_AMOUNT_EDIT (pedit_dialog->price_edit)); | ||||
|  | ||||
|     // test for existing price on same day | ||||
|     if (pedit_dialog_replace_found_price (pedit_dialog, commodity, currency, date)) | ||||
|     { | ||||
|         if (!pedit_dialog->price) | ||||
|             pedit_dialog->price = gnc_price_create (pedit_dialog->book); | ||||
|         gnc_price_begin_edit (pedit_dialog->price); | ||||
| @@ -239,10 +294,14 @@ gui_to_price (PriceEditDialog *pedit_dialog) | ||||
|         gnc_price_set_typestr (pedit_dialog->price, type); | ||||
|         gnc_price_set_value (pedit_dialog->price, value); | ||||
|         gnc_price_commit_edit (pedit_dialog->price); | ||||
|  | ||||
|     g_free(name_space); | ||||
|  | ||||
|         g_free (name_space); | ||||
|         return NULL; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         g_free (name_space); | ||||
|         return "CANCEL"; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -271,26 +330,32 @@ pedit_dialog_response_cb (GtkDialog *dialog, gint response, gpointer data) | ||||
|     PriceEditDialog *pedit_dialog = data; | ||||
|     GNCPrice *new_price = NULL; | ||||
|     const char *error_str; | ||||
|     gboolean price_is_ok = TRUE; | ||||
|  | ||||
|     if ((response == GTK_RESPONSE_OK) || (response == GTK_RESPONSE_APPLY)) | ||||
|     { | ||||
|         error_str = gui_to_price (pedit_dialog); | ||||
|         if (error_str) | ||||
|         if (g_strcmp0 (error_str, "CANCEL") == 0) | ||||
|             price_is_ok = FALSE; | ||||
|         else if (error_str) | ||||
|         { | ||||
|             gnc_warning_dialog (GTK_WINDOW (pedit_dialog->dialog), "%s", error_str); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         gnc_prices_set_changed (pedit_dialog, FALSE); | ||||
|         if (TRUE == pedit_dialog->is_new) | ||||
|         if (price_is_ok) | ||||
|         { | ||||
|             if (pedit_dialog->is_new) | ||||
|                 gnc_pricedb_add_price (pedit_dialog->price_db, pedit_dialog->price); | ||||
|         } | ||||
|  | ||||
|             gnc_gui_refresh_all (); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (response == GTK_RESPONSE_APPLY) | ||||
|     { | ||||
|         if (price_is_ok) | ||||
|         { | ||||
|             new_price = gnc_price_clone (pedit_dialog->price, pedit_dialog->book); | ||||
|             pedit_dialog->is_new = TRUE; | ||||
| @@ -298,6 +363,7 @@ pedit_dialog_response_cb (GtkDialog *dialog, gint response, gpointer data) | ||||
|             gnc_price_unref (pedit_dialog->price); | ||||
|             pedit_dialog->price = new_price; | ||||
|         } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         gnc_save_window_size(GNC_PREFS_GROUP, GTK_WINDOW(pedit_dialog->dialog)); | ||||
| @@ -475,11 +541,12 @@ gnc_price_pedit_dialog_create (GtkWidget *parent, | ||||
|  | ||||
|     w = GTK_WIDGET(gtk_builder_get_object (builder, "pd_apply_button")); | ||||
|     pedit_dialog->apply_button = w; | ||||
|     gnc_prices_set_changed (pedit_dialog, FALSE); | ||||
|  | ||||
|     w = GTK_WIDGET(gtk_builder_get_object (builder, "pd_ok_button")); | ||||
|     pedit_dialog->ok_button = w; | ||||
|  | ||||
|     gnc_prices_set_changed (pedit_dialog, FALSE); | ||||
|  | ||||
|     gtk_builder_connect_signals_full (builder, gnc_builder_connect_full_func, pedit_dialog); | ||||
|  | ||||
|     g_object_unref(G_OBJECT(builder)); | ||||
|   | ||||
| @@ -34,6 +34,11 @@ | ||||
|       <summary>Delete multiple price quotes</summary> | ||||
|       <description>This dialog is presented before allowing you to delete multiple price quotes at one time.</description> | ||||
|     </key> | ||||
|     <key name="price-quotes-replace" type="i"> | ||||
|       <default>0</default> | ||||
|       <summary>Replace existing price</summary> | ||||
|       <description>This dialog is presented before allowing you to replace an existing price.</description> | ||||
|     </key> | ||||
|     <key name="reg-is-acct-pay-rec" type="i"> | ||||
|       <default>0</default> | ||||
|       <summary>Edit account payable/accounts receivable register</summary> | ||||
| @@ -127,6 +132,11 @@ | ||||
|       <summary>Delete multiple price quotes</summary> | ||||
|       <description>This dialog is presented before allowing you to delete multiple price quotes at one time.</description> | ||||
|     </key> | ||||
|     <key name="price-quotes-replace" type="i"> | ||||
|       <default>0</default> | ||||
|       <summary>Replace existing price</summary> | ||||
|       <description>This dialog is presented before allowing you to replace an existing price.</description> | ||||
|     </key> | ||||
|     <key name="reg-is-acct-pay-rec" type="i"> | ||||
|       <default>0</default> | ||||
|       <summary>Edit account payable/accounts receivable register</summary> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user