mirror of
https://github.com/Gnucash/gnucash.git
synced 2025-02-25 18:55:30 -06:00
Make similar changes to price import CSV assistant
This commit is contained in:
parent
2b9b3d4a5e
commit
8ed40078b0
@ -66,6 +66,7 @@ Click on 'Forward' to proceed or 'Cancel' to Abort Import.</property>
|
|||||||
</object>
|
</object>
|
||||||
<packing>
|
<packing>
|
||||||
<property name="page_type">intro</property>
|
<property name="page_type">intro</property>
|
||||||
|
<property name="title" translatable="yes">Price Import Assistant</property>
|
||||||
<property name="complete">True</property>
|
<property name="complete">True</property>
|
||||||
<property name="has_padding">False</property>
|
<property name="has_padding">False</property>
|
||||||
</packing>
|
</packing>
|
||||||
@ -1042,7 +1043,7 @@ For example
|
|||||||
</child>
|
</child>
|
||||||
</object>
|
</object>
|
||||||
<packing>
|
<packing>
|
||||||
<property name="page_type">intro</property>
|
<property name="title" translatable="yes">Import Preview</property>
|
||||||
<property name="complete">True</property>
|
<property name="complete">True</property>
|
||||||
<property name="has_padding">False</property>
|
<property name="has_padding">False</property>
|
||||||
</packing>
|
</packing>
|
||||||
|
@ -93,7 +93,7 @@ public:
|
|||||||
void assist_finish ();
|
void assist_finish ();
|
||||||
void assist_compmgr_close ();
|
void assist_compmgr_close ();
|
||||||
|
|
||||||
void file_confirm_cb ();
|
void file_selection_changed_cb ();
|
||||||
|
|
||||||
void preview_settings_delete ();
|
void preview_settings_delete ();
|
||||||
void preview_settings_save ();
|
void preview_settings_save ();
|
||||||
@ -190,7 +190,7 @@ extern "C"
|
|||||||
void csv_price_imp_assist_prepare_cb (GtkAssistant *assistant, GtkWidget *page, CsvImpPriceAssist* info);
|
void csv_price_imp_assist_prepare_cb (GtkAssistant *assistant, GtkWidget *page, CsvImpPriceAssist* info);
|
||||||
void csv_price_imp_assist_close_cb (GtkAssistant *gtkassistant, CsvImpPriceAssist* info);
|
void csv_price_imp_assist_close_cb (GtkAssistant *gtkassistant, CsvImpPriceAssist* info);
|
||||||
void csv_price_imp_assist_finish_cb (GtkAssistant *gtkassistant, CsvImpPriceAssist* info);
|
void csv_price_imp_assist_finish_cb (GtkAssistant *gtkassistant, CsvImpPriceAssist* info);
|
||||||
void csv_price_imp_file_confirm_cb (GtkWidget *button, CsvImpPriceAssist *info);
|
void csv_price_imp_file_selection_changed_cb (GtkFileChooser *chooser, CsvImpPriceAssist *info);
|
||||||
void csv_price_imp_preview_del_settings_cb (GtkWidget *button, CsvImpPriceAssist *info);
|
void csv_price_imp_preview_del_settings_cb (GtkWidget *button, CsvImpPriceAssist *info);
|
||||||
void csv_price_imp_preview_save_settings_cb (GtkWidget *button, CsvImpPriceAssist *info);
|
void csv_price_imp_preview_save_settings_cb (GtkWidget *button, CsvImpPriceAssist *info);
|
||||||
void csv_price_imp_preview_settings_sel_changed_cb (GtkComboBox *combo, CsvImpPriceAssist *info);
|
void csv_price_imp_preview_settings_sel_changed_cb (GtkComboBox *combo, CsvImpPriceAssist *info);
|
||||||
@ -228,9 +228,9 @@ csv_price_imp_assist_finish_cb (GtkAssistant *assistant, CsvImpPriceAssist* info
|
|||||||
info->assist_finish ();
|
info->assist_finish ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void csv_price_imp_file_confirm_cb (GtkWidget *button, CsvImpPriceAssist *info)
|
void csv_price_imp_file_selection_changed_cb (GtkFileChooser *chooser, CsvImpPriceAssist *info)
|
||||||
{
|
{
|
||||||
info->file_confirm_cb();
|
info->file_selection_changed_cb();
|
||||||
}
|
}
|
||||||
|
|
||||||
void csv_price_imp_preview_del_settings_cb (GtkWidget *button, CsvImpPriceAssist *info)
|
void csv_price_imp_preview_del_settings_cb (GtkWidget *button, CsvImpPriceAssist *info)
|
||||||
@ -500,18 +500,9 @@ CsvImpPriceAssist::CsvImpPriceAssist ()
|
|||||||
/* File chooser Page */
|
/* File chooser Page */
|
||||||
file_page = GTK_WIDGET(gtk_builder_get_object (builder, "file_page"));
|
file_page = GTK_WIDGET(gtk_builder_get_object (builder, "file_page"));
|
||||||
file_chooser = gtk_file_chooser_widget_new (GTK_FILE_CHOOSER_ACTION_OPEN);
|
file_chooser = gtk_file_chooser_widget_new (GTK_FILE_CHOOSER_ACTION_OPEN);
|
||||||
g_signal_connect (G_OBJECT(file_chooser), "file-activated",
|
|
||||||
G_CALLBACK(csv_price_imp_file_confirm_cb), this);
|
g_signal_connect (G_OBJECT(file_chooser), "selection-changed",
|
||||||
auto button = gtk_button_new_with_mnemonic (_("_OK"));
|
G_CALLBACK(csv_price_imp_file_selection_changed_cb), this);
|
||||||
gtk_widget_set_size_request (button, 100, -1);
|
|
||||||
gtk_widget_show (button);
|
|
||||||
auto h_box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
|
|
||||||
gtk_box_set_homogeneous (GTK_BOX (h_box), TRUE);
|
|
||||||
gtk_widget_set_hexpand (GTK_WIDGET(h_box), TRUE);
|
|
||||||
gtk_box_pack_start (GTK_BOX(h_box), button, FALSE, FALSE, 0);
|
|
||||||
gtk_file_chooser_set_extra_widget (GTK_FILE_CHOOSER(file_chooser), h_box);
|
|
||||||
g_signal_connect (G_OBJECT(button), "clicked",
|
|
||||||
G_CALLBACK(csv_price_imp_file_confirm_cb), this);
|
|
||||||
|
|
||||||
auto box = GTK_WIDGET(gtk_builder_get_object (builder, "file_page"));
|
auto box = GTK_WIDGET(gtk_builder_get_object (builder, "file_page"));
|
||||||
gtk_box_pack_start (GTK_BOX(box), file_chooser, TRUE, TRUE, 6);
|
gtk_box_pack_start (GTK_BOX(box), file_chooser, TRUE, TRUE, 6);
|
||||||
@ -676,15 +667,17 @@ CsvImpPriceAssist::~CsvImpPriceAssist ()
|
|||||||
* Code related to the file chooser page
|
* Code related to the file chooser page
|
||||||
**************************************************/
|
**************************************************/
|
||||||
|
|
||||||
/* csv_price_imp_file_confirm_cb
|
/* csv_price_imp_file_selection_changed_cb
|
||||||
*
|
*
|
||||||
* call back for ok button in file chooser widget
|
* call back for file chooser widget
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
CsvImpPriceAssist::file_confirm_cb ()
|
CsvImpPriceAssist::file_selection_changed_cb ()
|
||||||
{
|
{
|
||||||
|
gtk_assistant_set_page_complete (csv_imp_asst, file_page, false);
|
||||||
|
|
||||||
auto file_name = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER(file_chooser));
|
auto file_name = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER(file_chooser));
|
||||||
if (!file_name)
|
if (!file_name || g_file_test (file_name, G_FILE_TEST_IS_DIR))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto filepath = gnc_uri_get_path (file_name);
|
auto filepath = gnc_uri_get_path (file_name);
|
||||||
@ -700,36 +693,7 @@ CsvImpPriceAssist::file_confirm_cb ()
|
|||||||
g_free (file_name);
|
g_free (file_name);
|
||||||
g_free (starting_dir);
|
g_free (starting_dir);
|
||||||
|
|
||||||
/* Load the file into parse_data. */
|
gtk_assistant_set_page_complete (csv_imp_asst, file_page, true);
|
||||||
price_imp = std::unique_ptr<GncPriceImport>(new GncPriceImport);
|
|
||||||
/* Assume data is CSV. User can later override to Fixed Width if needed */
|
|
||||||
try
|
|
||||||
{
|
|
||||||
price_imp->file_format (GncImpFileFormat::CSV);
|
|
||||||
price_imp->load_file (m_file_name);
|
|
||||||
price_imp->tokenize (true);
|
|
||||||
}
|
|
||||||
catch (std::ifstream::failure& e)
|
|
||||||
{
|
|
||||||
/* File loading failed ... */
|
|
||||||
gnc_error_dialog (GTK_WINDOW(csv_imp_asst), "%s", e.what());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
catch (std::range_error &e)
|
|
||||||
{
|
|
||||||
/* Parsing failed ... */
|
|
||||||
gnc_error_dialog (GTK_WINDOW(csv_imp_asst), "%s", _(e.what()));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
/* Get settings store and populate */
|
|
||||||
preview_populate_settings_combo();
|
|
||||||
gtk_combo_box_set_active (settings_combo, 0);
|
|
||||||
|
|
||||||
// set over_write to false as default
|
|
||||||
price_imp->over_write (false);
|
|
||||||
|
|
||||||
auto num = gtk_assistant_get_current_page (csv_imp_asst);
|
|
||||||
gtk_assistant_set_current_page (csv_imp_asst, num + 1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1742,6 +1706,10 @@ void CsvImpPriceAssist::preview_validate_settings ()
|
|||||||
void
|
void
|
||||||
CsvImpPriceAssist::assist_file_page_prepare ()
|
CsvImpPriceAssist::assist_file_page_prepare ()
|
||||||
{
|
{
|
||||||
|
/* Disable the Forward Assistant Button */
|
||||||
|
gtk_assistant_set_page_complete (csv_imp_asst, file_page, false);
|
||||||
|
gtk_assistant_set_page_complete (csv_imp_asst, preview_page, false);
|
||||||
|
|
||||||
/* Set the default directory */
|
/* Set the default directory */
|
||||||
auto starting_dir = gnc_get_default_directory (GNC_PREFS_GROUP);
|
auto starting_dir = gnc_get_default_directory (GNC_PREFS_GROUP);
|
||||||
if (starting_dir)
|
if (starting_dir)
|
||||||
@ -1754,11 +1722,51 @@ CsvImpPriceAssist::assist_file_page_prepare ()
|
|||||||
void
|
void
|
||||||
CsvImpPriceAssist::assist_preview_page_prepare ()
|
CsvImpPriceAssist::assist_preview_page_prepare ()
|
||||||
{
|
{
|
||||||
/* Disable the Forward Assistant Button */
|
auto go_back = false;
|
||||||
gtk_assistant_set_page_complete (csv_imp_asst, preview_page, false);
|
|
||||||
|
|
||||||
/* Load the data into the treeview. */
|
/* Load the file into parse_data, reset it if altrady loaded. */
|
||||||
preview_refresh_table ();
|
if (price_imp)
|
||||||
|
price_imp.reset();
|
||||||
|
|
||||||
|
/* Load the file into parse_data. */
|
||||||
|
price_imp = std::unique_ptr<GncPriceImport>(new GncPriceImport);
|
||||||
|
/* Assume data is CSV. User can later override to Fixed Width if needed */
|
||||||
|
try
|
||||||
|
{
|
||||||
|
price_imp->file_format (GncImpFileFormat::CSV);
|
||||||
|
price_imp->load_file (m_file_name);
|
||||||
|
price_imp->tokenize (true);
|
||||||
|
}
|
||||||
|
catch (std::ifstream::failure& e)
|
||||||
|
{
|
||||||
|
/* File loading failed ... */
|
||||||
|
gnc_error_dialog (GTK_WINDOW(csv_imp_asst), "%s", e.what());
|
||||||
|
go_back = true;
|
||||||
|
}
|
||||||
|
catch (std::range_error &e)
|
||||||
|
{
|
||||||
|
/* Parsing failed ... */
|
||||||
|
gnc_error_dialog (GTK_WINDOW(csv_imp_asst), "%s", _(e.what()));
|
||||||
|
go_back = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (go_back)
|
||||||
|
gtk_assistant_previous_page (csv_imp_asst);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Get settings store and populate */
|
||||||
|
preview_populate_settings_combo();
|
||||||
|
gtk_combo_box_set_active (settings_combo, 0);
|
||||||
|
|
||||||
|
// set over_write to false as default
|
||||||
|
price_imp->over_write (false);
|
||||||
|
|
||||||
|
/* Disable the Forward Assistant Button */
|
||||||
|
gtk_assistant_set_page_complete (csv_imp_asst, preview_page, false);
|
||||||
|
|
||||||
|
/* Load the data into the treeview. */
|
||||||
|
g_idle_add ((GSourceFunc)csv_imp_preview_queue_rebuild_table, this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
Loading…
Reference in New Issue
Block a user