#include <gtk/gtk.h>
#include <glib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>

#include "mmyth_ui.h"
#include "mmyth_recordui.h"

/* GMyth library includes */
#include <gmyth/gmyth_scheduler.h>
#include <gmyth/gmyth_util.h>

enum {
	START_DATE_COLUMN = 0,
	TITLE_COLUMN,
	CHAN_ID_COLUMN,
	END_TIME_COLUMN,
	RECORD_ID_COLUMN,
	BASENAME_COLUMN,
	N_COLUMNS
};

gboolean
mmyth_recordui_reload_all (MMythRecordUI *recordui)
{
	gboolean res = FALSE;

	res = mmyth_recordui_reload_schedule (recordui);
		
	res = res & mmyth_recordui_reload_record (recordui);
	
	
	if (!res)
		g_warning ("[%s] Error while reloading schedule and recording content", __FUNCTION__);
		
	return res;
}

gboolean
mmyth_recordui_reload_schedule (MMythRecordUI *recordui)
{
	gint new_row = 0;
	ScheduleInfo *schedule_info;
	GList *schedule_list;
	GtkTreeIter iter;
     gchar *start_date_time = NULL;
    gchar *end_date_time = NULL;
    GString *str_aux = g_string_new("");
	gint res;

	gtk_tree_store_clear(recordui->sch_tree_store);	

	res = gmyth_scheduler_get_schedule_list(recordui->scheduler, &(schedule_list));
	if (res < 0) {
		g_warning ("[%s] Retrieved NULL list of scheduled data from database", 
                   __FUNCTION__);
		return FALSE;
	}

	for ( ; schedule_list; schedule_list = schedule_list->next) {
 	  	schedule_info = (ScheduleInfo*) schedule_list->data;

  	  	gtk_tree_store_insert(recordui->sch_tree_store, &iter, NULL, new_row++);
        
        start_date_time = gmyth_util_time_to_string_from_time_val(schedule_info->start_time);
        end_date_time = gmyth_util_time_to_string_from_time_val(schedule_info->end_time);
        
        g_string_printf(str_aux, "%d", schedule_info->channel_id);
        
	  	gtk_tree_store_set(recordui->sch_tree_store, &iter,
	  		START_DATE_COLUMN, start_date_time, 
	  		TITLE_COLUMN, schedule_info->title->str,
	  		CHAN_ID_COLUMN, str_aux->str,
	  		END_TIME_COLUMN, end_date_time, //It doesn't appear
	  		RECORD_ID_COLUMN, schedule_info->record_id, 
			-1); //the last line is a hidden item to be used in searching tasks
 	}
  	
  	g_debug ("[%s] %d lines added to schedule list UI", __FUNCTION__, new_row);
  	
    /* free allocated memory */
    if(!start_date_time)
        g_free(start_date_time);
    if(!end_date_time)
        g_free(end_date_time);
    g_string_free(str_aux,  FALSE);
    
  	return TRUE;
}

gboolean
mmyth_recordui_reload_record (MMythRecordUI *recordui)
{
	gint new_row = 0;
	RecordedInfo *recorded_info;
	GList *record_list = NULL;
	GtkTreeIter iter;
    gchar *start_date_time = NULL;
    gchar *end_date_time = NULL;
    GString *str_aux = g_string_new("");
	gint res;
	
	gtk_tree_store_clear(recordui->rec_tree_store);		

	res = gmyth_scheduler_get_recorded_list(recordui->scheduler, &record_list);
	if (res < 0) {
		g_warning ("[%s] Retrieved NULL list of recorded data from database", __FUNCTION__);
		return FALSE;
	}
	
	for (; record_list; record_list = record_list->next) {
 	  	recorded_info = (RecordedInfo*) record_list->data;

  	  	gtk_tree_store_insert(recordui->rec_tree_store, &iter, NULL, new_row++);

        start_date_time = gmyth_util_time_to_string_from_time_val(recorded_info->start_time);
        end_date_time = gmyth_util_time_to_string_from_time_val(recorded_info->end_time);

        g_string_printf(str_aux, "%d", recorded_info->channel_id);

	  	gtk_tree_store_set(recordui->rec_tree_store, &iter,
	  		START_DATE_COLUMN, start_date_time, 
	  		TITLE_COLUMN, recorded_info->title->str,
	  		CHAN_ID_COLUMN, str_aux->str,
	  		END_TIME_COLUMN, end_date_time, //It doesn't appear
	  		RECORD_ID_COLUMN, recorded_info->record_id,
			BASENAME_COLUMN, recorded_info->basename->str, -1); 
            //the last line is a hidden item to be used in searching tasks	  		
  	}
  	
  	g_debug ("[%s] %d lines added to record list UI", __FUNCTION__, new_row);

     /* free allocated memory */
    if( NULL != start_date_time)
        g_free(start_date_time);
    if( NULL != end_date_time)
        g_free(end_date_time);
    g_string_free(str_aux,  FALSE);
  	  	
  	return TRUE;
}


MMythRecordUI*
mmyth_recordui_new( GMythBackendInfo* backend_info )
{
	MMythRecordUI *recordui = g_new0 (MMythRecordUI, 1);

	g_return_val_if_fail( backend_info != NULL, NULL );

	recordui->backend_info = backend_info;
	
	recordui->scrolled_window = gtk_scrolled_window_new (NULL, NULL);
	gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (recordui->scrolled_window),
			GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);

	recordui->viewport = gtk_viewport_new (NULL, NULL);
  	gtk_container_add (GTK_CONTAINER (recordui->scrolled_window), recordui->viewport);

  	recordui->notebook = gtk_notebook_new ();
  	gtk_container_set_border_width (GTK_CONTAINER (recordui->notebook), 1);
  	gtk_notebook_set_scrollable (GTK_NOTEBOOK (recordui->notebook), TRUE);
  	gtk_notebook_popup_enable (GTK_NOTEBOOK (recordui->notebook));
  	gtk_container_add (GTK_CONTAINER (recordui->viewport), recordui->notebook);
  	gtk_notebook_popup_disable(GTK_NOTEBOOK (recordui->notebook));

	/* Schedule tab */
  	recordui->sch_scrolled_window = gtk_scrolled_window_new (NULL, NULL);
  	gtk_container_add (GTK_CONTAINER (recordui->notebook), recordui->sch_scrolled_window);
  	gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (recordui->sch_scrolled_window), 
                                    GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
  	gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (recordui->sch_scrolled_window), 
                                         GTK_SHADOW_IN);

    /* The basename column in the sched_tree_store is not being used*/
  	recordui->sch_tree_store = 
        gtk_tree_store_new (N_COLUMNS, G_TYPE_STRING, G_TYPE_STRING,
  		                    G_TYPE_STRING, G_TYPE_STRING, G_TYPE_INT, G_TYPE_STRING );
    
  	recordui->sch_treeview = 
        gtk_tree_view_new_with_model(GTK_TREE_MODEL(recordui->sch_tree_store));
  	gtk_container_add (GTK_CONTAINER (recordui->sch_scrolled_window), 
                       recordui->sch_treeview);
  	recordui->sch_renderer = gtk_cell_renderer_text_new();
  	//g_object_set(G_OBJECT(renderer1), "foreground", "green", "background", "black", NULL);
  	recordui->sch_column1 = 
        gtk_tree_view_column_new_with_attributes("Start time", recordui->sch_renderer, 
                                                 "text", START_DATE_COLUMN, NULL);
  	gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->sch_treeview), 
                                recordui->sch_column1); 
  	recordui->sch_column2 = 
        gtk_tree_view_column_new_with_attributes("Title", recordui->sch_renderer, 
                                                 "text", TITLE_COLUMN, NULL);
  	gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->sch_treeview), 
                                recordui->sch_column2);
  	recordui->sch_column3 = 
        gtk_tree_view_column_new_with_attributes("Channel", recordui->sch_renderer, 
                                                 "text", CHAN_ID_COLUMN, NULL);
  	gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->sch_treeview), 
                                recordui->sch_column3);
  	gtk_tree_view_column_set_resizable(recordui->sch_column1, TRUE);
  	gtk_tree_view_column_set_resizable(recordui->sch_column2, TRUE);
  	gtk_tree_view_column_set_resizable(recordui->sch_column3, TRUE);
  	gtk_tree_view_column_set_reorderable(recordui->sch_column1, TRUE);
  	gtk_tree_view_column_set_reorderable(recordui->sch_column2, TRUE);
  	gtk_tree_view_column_set_reorderable(recordui->sch_column3, TRUE);  	  	  	  	
//  recordui->sch_column4 = 
//      gtk_tree_view_column_new_with_attributes("", recordui->sch_renderer, "text", END_TIME_COLUMN, NULL);
//  gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->sch_treeview), 
//                                            recordui->sch_column4);

  	recordui->sch_label = gtk_label_new (("Schedule"));
  	gtk_notebook_set_tab_label (GTK_NOTEBOOK (recordui->notebook), 
                                gtk_notebook_get_nth_page (
                                               GTK_NOTEBOOK (recordui->notebook), 0), 
                                recordui->sch_label);

  // Record items  tab
  //   g_object_set(G_OBJECT(renderer2), "foreground", "blue", NULL);
  	recordui->rec_scrolled_window = gtk_scrolled_window_new (NULL, NULL);
  	gtk_container_add (GTK_CONTAINER (recordui->notebook), 
                       recordui->rec_scrolled_window);
  	gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (recordui->rec_scrolled_window), 
                                    GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
  	gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (recordui->rec_scrolled_window), 
                                         GTK_SHADOW_IN);

  	recordui->rec_tree_store = 
        gtk_tree_store_new (N_COLUMNS, G_TYPE_STRING, G_TYPE_STRING,
                	        G_TYPE_STRING, G_TYPE_STRING, G_TYPE_INT, G_TYPE_STRING);
  	recordui->rec_treeview = 
        gtk_tree_view_new_with_model(GTK_TREE_MODEL(recordui->rec_tree_store));
  	gtk_container_add (GTK_CONTAINER (recordui->rec_scrolled_window), 
                       recordui->rec_treeview);
  	recordui->rec_renderer = gtk_cell_renderer_text_new();
  	//g_object_set(G_OBJECT(renderer1), "foreground", "green", "background", "black", NULL);
 
  	recordui->rec_column1 = 
        gtk_tree_view_column_new_with_attributes("Start time", recordui->rec_renderer, 
                                                 "text", START_DATE_COLUMN, NULL);
  	gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->rec_treeview), 
                                recordui->rec_column1);
  	recordui->rec_column2 = 
        gtk_tree_view_column_new_with_attributes("Title", recordui->rec_renderer, 
                                                 "text", TITLE_COLUMN, NULL);
  	gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->rec_treeview), 
                                recordui->rec_column2);
  	recordui->rec_column3 = 
        gtk_tree_view_column_new_with_attributes("Channel", recordui->rec_renderer, 
                                                 "text", CHAN_ID_COLUMN, NULL);
  	gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->rec_treeview), 
                                recordui->rec_column3);
  	gtk_tree_view_column_set_resizable(recordui->rec_column1, TRUE);
  	gtk_tree_view_column_set_resizable(recordui->rec_column2, TRUE);
  	gtk_tree_view_column_set_resizable(recordui->rec_column3, TRUE);
  	gtk_tree_view_column_set_reorderable(recordui->rec_column1, TRUE);
  	gtk_tree_view_column_set_reorderable(recordui->rec_column2, TRUE);
  	gtk_tree_view_column_set_reorderable(recordui->rec_column3, TRUE);
//  recordui->rec_column4 = gtk_tree_view_column_new_with_attributes("", recordui->rec_renderer, "text", END_TIME_COLUMN, NULL);
//  gtk_tree_view_append_column(GTK_TREE_VIEW(recordui->rec_treeview), recordui->rec_column4);

  	recordui->rec_label = gtk_label_new (("Recorded"));
  	gtk_notebook_set_tab_label (GTK_NOTEBOOK (recordui->notebook), 
                                gtk_notebook_get_nth_page (
                                      GTK_NOTEBOOK (recordui->notebook), 1), 
                                recordui->rec_label);
  
  	// Gets the mmyth scheduler manager
  	recordui->scheduler = gmyth_scheduler_new ( backend_info );
    
    /* init connection to the backend */
    gmyth_scheduler_connect (recordui->scheduler, recordui->scheduler->backend_info);
    
	return recordui;
}

void
mmyth_recordui_free (MMythRecordUI *recordui)
{
	// FIXME: Release memory here!
    /* close connection to the backend */
    gmyth_scheduler_disconnect (recordui->scheduler);
}

void
mmyth_recordui_delete_selected (GtkButton *button, MMythRecordUI *recordui)
{
	GtkTreeSelection *selection;
	GtkTreeModel *list_store;
	GtkTreeIter iter;
	int index;
	int curr_page = 0;
	
	curr_page = gtk_notebook_get_current_page(GTK_NOTEBOOK(recordui->notebook));

	if ( curr_page == 0) {
		selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(recordui->sch_treeview));
		if (selection != NULL) {
			gtk_tree_selection_get_selected(selection, &list_store, &iter);
			gtk_tree_model_get(list_store, &iter, RECORD_ID_COLUMN, &index, -1);
			gmyth_scheduler_delete_schedule(recordui->scheduler, index);
			mmyth_recordui_reload_schedule (recordui);
			return;
		}
			
	} else if (curr_page == 1) {
		selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(recordui->rec_treeview));
		if (selection != NULL) {
			gtk_tree_selection_get_selected(selection, &list_store, &iter);
			gtk_tree_model_get(list_store, &iter, RECORD_ID_COLUMN, &index, -1);
			gmyth_scheduler_delete_recorded(recordui->scheduler, index);
			mmyth_recordui_reload_record (recordui);
			return;
		}
	}
	
	g_warning ("[%s] None element was removed from the list", __FUNCTION__);
}

/* FIXME: change this function name, it is returning the 
 * basename_column that represents the nuv filename of 
 * the recorded content */
gchar*
mmyth_recordui_get_selected_recorded (MMythRecordUI *recordui)
{
	GtkTreeSelection *selection = NULL;
	GtkTreeModel *list_store = NULL;
	GtkTreeIter iter;
	gchar *path = NULL;

	/* returning nuv filename, basename_column */
	selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(recordui->rec_treeview));
	if (gtk_tree_selection_get_selected (selection, &list_store, &iter)) {
		gtk_tree_model_get(list_store, &iter, BASENAME_COLUMN, &path, -1);
	}

	// FIXME: MOVE THIS TO OTHER PLACE
	return path;
}