﻿using Google.Apis.Sheets.v4.Data;
using System;
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class GoogleSheetValues : MonoBehaviour
{
    public GoogleSheetIO sheetService;
    public String sheetID;
    public String pageName = "";
    public String cellRange = "";
    [Serializable]
    public class Data
    {
        public List<String> columns;
    }
    public List<Data> rows;
    private ValueRange GoogleValues()
    {
        ValueRange valueRange = new ValueRange();
        valueRange.Values = new List<IList<object>>();
        valueRange.MajorDimension = "ROWS";
        foreach (Data d in rows)
        {
            var oblist = new List<object>();
            foreach (String s in d.columns)
            {
                oblist.Add(s);
            }
            valueRange.Values.Add(oblist);
        }
        return valueRange;
    }
    public void AppendGoogleValues()
    {
        sheetService.AppendData(sheetID, GoogleValues(), pageName + "!" + cellRange);
    }
    public void GetGoogleValues()
    {
        ValueRange valueRange = sheetService.GetData(sheetID, pageName + "!" + cellRange);
        rows = new List<Data>();
        for (int i1 = 0; i1 < valueRange.Values.Count; i1++)
        {
            Data data = new Data();
            IList<object> l = valueRange.Values[i1];
            data.columns = new List<String>();
            for (int i2 = 0; i2 < l.Count; i2++)
            {
                data.columns[i2] = l[i2].ToString();
            }
            rows[i1] = data;
        }
    }
    public void ChangeGoogleValue(int row, int column, String value)
    {
        row -= 1;
        column -= 1;
        if (rows.Count > row && rows[row].columns.Count > column)
        {
            rows[row].columns[column] = value;
        }
        else
        {
            throw new System.ArgumentException("Row and column index must be within List range");
        }
    }
    public void ChangeRowSize(int rowSize)
    {
        int rowChange = rowSize - rows.Count;
        for (int i = 0; i < Math.Abs(rowChange); i++)
        {
            if (rowChange > 0)
            {
                rows.Add(new Data());
            }else {
                rows.RemoveAt(rows.Count);
            }
        }
    }
    public void ChangeColumnSize(int columnSize)
    {
        int columnChange = columnSize - rows[0].columns.Count;
        foreach (Data d in rows)
        {
            for (int i = 0; i < Math.Abs(columnChange); i++)
            {
                if (columnChange > 0)
                {
                    d.columns.Add("");
                }
                else
                {
                    d.columns.RemoveAt(d.columns.Count);
                }
            }
            
        }
    }
}
