using DTO; using IServices; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; using Newtonsoft.Json; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using System.Transactions; using zhengcaioa.IService; using zhengcaioa.Models; namespace zhengcaioa.Controllers.Finance { [CheckLogin] public class FiAccountIncomeController : Controller { private readonly ILogger _logger; private readonly IFiAccountService _fiAccountService; private readonly ILiaotianService _liaotianService; private readonly IFiAccountRecordService _iFiAccountRecordService; private readonly IFiSubjectService _ifiSubjectService; public FiAccountIncomeController(ILogger logger, IFiAccountService fiAccountService, ILiaotianService liaotianService, IFiAccountRecordService iFiAccountRecordService, IFiSubjectService ifiSubjectService) { _logger = logger; _fiAccountService = fiAccountService; _liaotianService = liaotianService; _iFiAccountRecordService = iFiAccountRecordService; _ifiSubjectService = ifiSubjectService; } public IActionResult Index() { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; List actionlist = new List(); ActionEntity actionEntity = new ActionEntity(); actionEntity.OpenType = 0; actionEntity.ActionUrl = ""; actionEntity.ActionFun = "Search"; actionEntity.PageIco = "fa fa-search"; actionEntity.ActionName = "查询"; actionlist.Add(actionEntity); ActionEntity actionEntity1 = new ActionEntity(); actionEntity1.OpenType = 0; actionEntity1.ActionUrl = ""; actionEntity1.ActionFun = "Add"; actionEntity1.PageIco = "fa fa-plus"; actionEntity1.ActionName = "新增"; actionlist.Add(actionEntity1); ActionEntity actionEntity2 = new ActionEntity(); actionEntity2.OpenType = 0; actionEntity2.ActionUrl = ""; actionEntity2.ActionFun = "PrintDetail"; actionEntity2.PageIco = "fa fa-plus"; actionEntity2.ActionName = "打印明细"; actionlist.Add(actionEntity2); ViewData["ActionInfo"] = actionlist; ViewBag.accounttype = _liaotianService.GetSYScode("fi_account", "accounttype").Select(x => new { code = x.CodeSn, label = x.Comments }).ToList(); ViewBag.FiSubject = _ifiSubjectService.GetList().Where(x=>x.Subjecttype=="01").Select(x => new { code = x.Id, label = x.Subjectname }).ToList(); return View(); } public IActionResult GetList(FiAccountRecordDTOSearch search) { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; search.RecordTypeId = "1"; return new JsonResult(_iFiAccountRecordService.SearchByPaging(search)); } /// /// 获取市 /// /// 账户类型 /// /// [CheckLogin] public string getAccount(string Accounttype = "") { var shi = _fiAccountService.GetList().Where(x=>x.Accounttype== Accounttype); return JsonConvert.SerializeObject(shi); } public IActionResult Edit(string id = null) { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; FiAccountRecordDTO fiAccountRecordDTO = new FiAccountRecordDTO(); if (!String.IsNullOrEmpty(id)) { fiAccountRecordDTO = _iFiAccountRecordService.Get(id); fiAccountRecordDTO.Accounttype = _fiAccountService.Get(fiAccountRecordDTO.AccountId).Accounttype; } ViewBag.accounttype = _liaotianService.GetSYScode("fi_account", "accounttype"); ViewBag.FiSubject = _ifiSubjectService.GetList().Where(x => x.Subjecttype == "01").ToList(); ViewData.Model = fiAccountRecordDTO; return View(); } /// /// 保存 /// /// 岗位实体类对象 /// /// [HttpPost] public IActionResult Save(FiAccountRecordDTO data) { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; data.RecStatus = "A"; if (String.IsNullOrEmpty(data.Id)) { data.Creater = curentuser.Id; data.Createtime = DateTime.Now; } data.Modifier = curentuser.Id; data.Modifytime = DateTime.Now; ResultEntity resultEntity = new ResultEntity(); resultEntity.Result = false; using (TransactionScope scope = new TransactionScope()) { FiAccountDTO firmAccount = _fiAccountService.Get(data.AccountId); data.RecordTypeId = "1";//收入 data.Department = ""; resultEntity = _iFiAccountRecordService.save(data); firmAccount.AllIncome = (firmAccount.AllIncome ?? 0) + data.Money ; firmAccount.Balance = (firmAccount.Balance??0) + data.Money; resultEntity = _fiAccountService.save(firmAccount); scope.Complete(); } return new JsonResult(resultEntity); } public IActionResult Check(string id = null) { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; FiAccountRecordDTO fiAccountRecordDTO = new FiAccountRecordDTO(); if (!String.IsNullOrEmpty(id)) { fiAccountRecordDTO = _iFiAccountRecordService.Get(id); FiAccountDTO fiAccountDTO=_fiAccountService.Get(fiAccountRecordDTO.AccountId); fiAccountRecordDTO.Accounttype = fiAccountDTO.Accounttype; fiAccountRecordDTO.AccounttypeName = _liaotianService.GetSYScode("fi_account", "accounttype").Where(x => x.CodeSn == fiAccountRecordDTO.Accounttype).FirstOrDefault().Comments; fiAccountRecordDTO.SubjectName = _ifiSubjectService.GetList().Where(x => x.Id == fiAccountRecordDTO.SubjectId).FirstOrDefault().Subjectname; fiAccountRecordDTO.AccountName = fiAccountDTO.Accountname; } ViewData.Model = fiAccountRecordDTO; return View(); } public IActionResult PrintAll(string RecordTypeId = "") { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; List actionlist = new List(); ActionEntity actionEntity = new ActionEntity(); actionEntity.OpenType = 0; actionEntity.ActionUrl = ""; actionEntity.ActionFun = "Search"; actionEntity.PageIco = "fa fa-search"; actionEntity.ActionName = "查询"; actionlist.Add(actionEntity); ActionEntity actionEntity1 = new ActionEntity(); actionEntity1.OpenType = 0; actionEntity1.ActionUrl = ""; actionEntity1.ActionFun = "Print"; actionEntity1.PageIco = "fa fa-plus"; actionEntity1.ActionName = "打印"; actionlist.Add(actionEntity1); ViewData["ActionInfo"] = actionlist; ViewBag.accounttype = _liaotianService.GetSYScode("fi_account", "accounttype").Select(x => new { code = x.CodeSn, label = x.Comments }).ToList(); ViewBag.FiSubject = _ifiSubjectService.GetList().Select(x => new { code = x.Id, label = x.Subjectname }).ToList(); ViewBag.RecordTypeId = _liaotianService.GetSYScode("fi_account_record", "RecordTypeId").Select(x => new { code = x.CodeSn, label = x.Comments }).ToList(); ViewBag.RecordTypeId1 = RecordTypeId; return View(); } public IActionResult GetListPrint(FiAccountRecordDTOSearch search) { var curentuser = JsonConvert.DeserializeObject(HttpContext.Session.GetString("User")); ViewData["curentuser"] = curentuser; //search.RecordTypeId = "1"; return new JsonResult(_iFiAccountRecordService.SearchByPaging(search)); } public IActionResult print(FiAccountRecordDTOSearch search) { search.rows = 10000; search.page = 1; List fiAccountRecordDTOs = _iFiAccountRecordService.SearchByPaging(search).DataList as List; ViewBag.listLiaotianDTO = fiAccountRecordDTOs; decimal? shouru = fiAccountRecordDTOs.Where(x => x.RecordTypeId == "1").Sum(x => x.Money); decimal? zhichu = fiAccountRecordDTOs.Where(x => x.RecordTypeId == "2").Sum(x => x.Money); ViewBag.shourusum = shouru.HasValue? shouru.Value.ToString("F2") : "0.00"; ViewBag.zhichusum = zhichu.HasValue ? zhichu.Value.ToString("F2") : "0.00"; return View(); } } }