package excelize

import (
	"path/filepath"
	"testing"

	"github.com/stretchr/testify/assert"
)

func TestAddShape(t *testing.T) {
	f, err := prepareTestBook1()
	if !assert.NoError(t, err) {
		t.FailNow()
	}

	assert.NoError(t, f.AddShape("Sheet1", "A30", `{"type":"rect","paragraph":[{"text":"Rectangle","font":{"color":"CD5C5C"}},{"text":"Shape","font":{"bold":true,"color":"2980B9"}}]}`))
	assert.NoError(t, f.AddShape("Sheet1", "B30", `{"type":"rect","paragraph":[{"text":"Rectangle"},{}]}`))
	assert.NoError(t, f.AddShape("Sheet1", "C30", `{"type":"rect","paragraph":[]}`))
	assert.EqualError(t, f.AddShape("Sheet3", "H1", `{
		"type": "ellipseRibbon",
		"color":
		{
			"line": "#4286f4",
			"fill": "#8eb9ff"
		},
		"paragraph": [
		{
			"font":
			{
				"bold": true,
				"italic": true,
				"family": "Times New Roman",
				"size": 36,
				"color": "#777777",
				"underline": "single"
			}
		}],
		"height": 90
	}`), "sheet Sheet3 is not exist")
	assert.EqualError(t, f.AddShape("Sheet3", "H1", ""), "unexpected end of JSON input")
	assert.EqualError(t, f.AddShape("Sheet1", "A", `{
		"type": "rect",
		"paragraph": [
		{
			"text": "Rectangle",
			"font":
			{
				"color": "CD5C5C"
			}
		},
		{
			"text": "Shape",
			"font":
			{
				"bold": true,
				"color": "2980B9"
			}
		}]
	}`), `cannot convert cell "A" to coordinates: invalid cell name "A"`)
	assert.NoError(t, f.SaveAs(filepath.Join("test", "TestAddShape1.xlsx")))

	// Test add first shape for given sheet.
	f = NewFile()
	assert.NoError(t, f.AddShape("Sheet1", "A1", `{
		"type": "ellipseRibbon",
		"color":
		{
			"line": "#4286f4",
			"fill": "#8eb9ff"
		},
		"paragraph": [
		{
			"font":
			{
				"bold": true,
				"italic": true,
				"family": "Times New Roman",
				"size": 36,
				"color": "#777777",
				"underline": "single"
			}
		}],
		"height": 90,
		"line":
		{
			"width": 1.2
		}
	}`))
	assert.NoError(t, f.SaveAs(filepath.Join("test", "TestAddShape2.xlsx")))
}