using System;
using System.Linq;
using System.Net.Http;
using System.Web.Http;
namespace Project
{
    public class ItemController : BaseController
    {
        // PUT api/values/5
        public void Put(int id, [FromBody] string value)
        {
        }
        // DELETE api/values/5
        public void Delete(int id)
        {
        }
        [HttpGet]
        public string Test()
        {
            return "test";
        }
        [HttpGet]
        public HttpResponseMessage Find()
        {
            //로그인이 되어있지않다면 로그인을 가져온다
            MethodResult result;
            result = View();
            var gets = Request.GetQueryNameValuePairs();// GetParameters(data);
            var key_search = gets.Where(t => t.Key == "search").FirstOrDefault();
            var model = GetGlobalModel();
            var getParams = Request.GetQueryNameValuePairs();// GetParameters(data);
            //기본값을 찾아서 없애줘야한다
            var searchkey = string.Empty;
            if (key_search.Key != null && key_search.Value.isEmpty() == false) searchkey = key_search.Value.Trim();
            var tbody = new System.Text.StringBuilder();
            //테이블데이터생성
            var itemcnt = 0;
            if (searchkey.isEmpty() == false)
            {
                var db = new EEEntitiesMain();
                var rows = db.vFindSID.Where(t => t.sid.Contains(searchkey) || t.name.Contains(searchkey) || t.model.Contains(searchkey));
                itemcnt = rows.Count();
                foreach (var item in rows)
                {
                    tbody.AppendLine("
");
                    tbody.AppendLine($"| {item.Location}");
                    tbody.AppendLine($" | {item.sid}");
                    tbody.AppendLine($" | {item.name}");
                    tbody.AppendLine($" | {item.model}");
                    if (item.price == null)
                        tbody.AppendLine($" | --");
                    else
                    {
                        var price = (double)item.price / 1000.0;
                        
                        tbody.AppendLine($" | {price.ToString("N0")}");
                    }
                        
                    tbody.AppendLine($" | {item.manu}");
                    tbody.AppendLine($" | {item.supply}");
                    if (item.remark.Length > 10)
                        tbody.AppendLine($" | {item.remark.Substring(0, 10)}...");
                    else
                        tbody.AppendLine($" | {item.remark}");
                    tbody.AppendLine(" | 
");
                }
            }
            //아잍쳄이 없는경우
            if (itemcnt == 0)
            {
                tbody.AppendLine("");
                tbody.AppendLine("| 자료가 없습니다");
                tbody.AppendLine(" | 
");
            }
            var contents = result.Content.Replace("{search}", searchkey);
            contents = contents.Replace("{tabledata}", tbody.ToString());
            contents = contents.Replace("{cnt}", itemcnt.ToString());
            //공용값 적용
            ApplyCommonValue(ref contents);
            //최종문자 적용
            result.Content = contents;
            var resp = new HttpResponseMessage()
            {
                Content = new StringContent(
              result.Content,
              System.Text.Encoding.UTF8,
              "text/html")
            };
            return resp;
        }
        [HttpGet]
        public HttpResponseMessage Index()
        {
            //로그인이 되어있지않다면 로그인을 가져온다
            MethodResult result;
            result = View();
            var model = GetGlobalModel();
            var getParams = Request.GetQueryNameValuePairs();// GetParameters(data);
            //기본값을 찾아서 없애줘야한다
            var contents = result.Content;
            //공용값 적용
            ApplyCommonValue(ref contents);
            //최종문자 적용
            result.Content = contents;
            var resp = new HttpResponseMessage()
            {
                Content = new StringContent(
              result.Content,
              System.Text.Encoding.UTF8,
              "text/html")
            };
            return resp;
        }
    }
}