using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using Ropin.Inspection.Api.Common;
using Ropin.Inspection.Api.Controllers;
using Ropin.Inspection.Model;
using Ropin.Inspection.Service;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace Ropin.Inspection.Api
{

    public class TdevDevStoreLogController : BaseController
    {
        public ILogger<TdevDevStoreLogController> _logger { get; }
        private readonly ITdevDevStoreLogService _TdevDevStoreLogService;
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="TdevDevStoreLogService"></param>
        /// <param name="logger"></param>
        public TdevDevStoreLogController(ITdevDevStoreLogService TdevDevStoreLogService, ILogger<TdevDevStoreLogController> logger)
        {
            _TdevDevStoreLogService = TdevDevStoreLogService;
            _logger = logger;
        }

        /// <summary>
        /// 通过id获取业主设备日志信息
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        [HttpGet("GetDevStoreLogAsync/{id}")]
        public async Task<ApiResult> GetDevStoreLogAsync(string id)
        {
            if (string.IsNullOrEmpty(id))
            {
                return new ApiResult(ReturnCode.GeneralError);
            }
            try
            {
                var content = await _TdevDevStoreLogService.GetConditionAsync(new TdevDevStoreLogSearchModel { C_ID = id });
                return new ApiResult<TdevDevStoreLogViewModel>(content.FirstOrDefault());
            }
            catch (Exception ex)
            {
                return new ApiResult(ReturnCode.GeneralError, ex.Message);
            }
        }

        /// <summary>
        /// 获取所有业主设备日志
        /// </summary>
        /// <returns></returns>
        [HttpGet("GetDevStoreLogsAsync")]
        public async Task<ApiResult> GetDevStoreLogsAsync()
        {
            try
            {
                var contentList = await _TdevDevStoreLogService.GetAllAsync();
                return new ApiResult<IEnumerable<TdevDevStoreLogViewModel>>(contentList);
            }
            catch (Exception ex)
            {
                return new ApiResult(ReturnCode.GeneralError, ex.Message);
            }
        }

        /// <summary>
        /// 通过业主设备日志名称条件查询
        /// </summary>
        /// <param name="searchModel"></param>
        /// <returns></returns>
        [HttpPost("GetDevStoreLogsByAsync")]
        public async Task<ApiResult> GetDevStoreLogsByAsync(TdevDevStoreLogSearchModel searchModel)
        {
            if (searchModel == null)
            {
                return new ApiResult(ReturnCode.ArgsError);
            }
            searchModel.IsPagination = false;
            try
            {
                var contentList = await _TdevDevStoreLogService.GetConditionAsync(searchModel);
                return new ApiResult<PagesModel<TdevDevStoreLogViewModel>>(new PagesModel<TdevDevStoreLogViewModel>(contentList, searchModel));
            }
            catch (Exception ex)
            {
                return new ApiResult(ReturnCode.GeneralError, ex.Message);
            }
        }

        /// <summary>
        /// 创建业主设备日志
        /// </summary>
        /// <param name="content"></param>
        /// <returns></returns>
        [HttpPost("CreateDevStoreLogAsync")]
        public async Task<ApiResult> CreateDevStoreLogAsync(TdevDevStoreLogViewModel content)
        {
            if (content == null)
            {
                return new ApiResult(ReturnCode.ArgsError);
            }
            try
            {
                await _TdevDevStoreLogService.CreateOneAsync(content);
            }
            catch (Exception ex)
            {
                return new ApiResult(ReturnCode.GeneralError, ex.Message);
            }
            return new ApiResult(ReturnCode.Success);
        }

        /// <summary>
        /// 删除业主设备日志
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        [HttpDelete("DeleteDevStoreLogAsync/{id}")]
        public async Task<ApiResult> DeleteDevStoreLogAsync(string id)
        {
            if (string.IsNullOrEmpty(id))
            {
                return new ApiResult(ReturnCode.GeneralError);
            }
            try
            {
                await _TdevDevStoreLogService.DeleteAsync(id);
            }
            catch (Exception ex)
            {
                return new ApiResult(ReturnCode.GeneralError, ex.Message);
            }
            return new ApiResult(ReturnCode.Success);
        }
        /// <summary>
        /// 更新业主设备日志
        /// </summary>
        /// <param name="id"></param>
        /// <param name="updateModel"></param>
        /// <returns></returns>
        [HttpPut("UpdateDevStoreLogAsync/{id}")]
        public async Task<ApiResult> UpdateDevStoreLogAsync(string id, TdevDevStoreLogUpdateModel updateModel)
        {
            if (string.IsNullOrEmpty(id))
            {
                return new ApiResult(ReturnCode.GeneralError);
            }
            try
            {
                await _TdevDevStoreLogService.UpdateAsync(id, updateModel);
            }
            catch (Exception ex)
            {
                return new ApiResult(ReturnCode.GeneralError, ex.Message);
            }
            return new ApiResult(ReturnCode.Success);
        }

    }
}