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 FiAccountExpensesController : Controller
|
{
|
private readonly ILogger<FiAccountExpensesController> _logger;
|
private readonly IFiAccountService _fiAccountService;
|
private readonly ILiaotianService _liaotianService;
|
|
private readonly IFiAccountRecordService _iFiAccountRecordService;
|
private readonly IFiSubjectService _ifiSubjectService;
|
private readonly IPltPageService _pltPageService;
|
|
|
public FiAccountExpensesController(ILogger<FiAccountExpensesController> logger, IFiAccountService fiAccountService, ILiaotianService liaotianService, IFiAccountRecordService iFiAccountRecordService, IFiSubjectService ifiSubjectService
|
, IPltPageService pltPageService)
|
{
|
_logger = logger;
|
_fiAccountService = fiAccountService;
|
_liaotianService = liaotianService;
|
_iFiAccountRecordService = iFiAccountRecordService;
|
_ifiSubjectService = ifiSubjectService;
|
_pltPageService = pltPageService;
|
}
|
|
|
|
public IActionResult Index()
|
{
|
var curentuser = JsonConvert.DeserializeObject<PltUser>(HttpContext.Session.GetString("User"));
|
ViewData["curentuser"] = curentuser;
|
List<ActionEntity> actionlist = new List<ActionEntity>();
|
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);
|
var pageEntities = _pltPageService.GetUserPage(curentuser.Id, "/FiAccountExpenses/Index/");
|
var pageEntities1 = pageEntities.Where(x => x.PageMethod == "01").ToList();
|
foreach (var pageEntity in pageEntities1)
|
{
|
ActionEntity actionEntity1 = new ActionEntity();
|
actionEntity1.OpenType = pageEntity.OpenType;
|
actionEntity1.ActionUrl = "";
|
actionEntity1.ActionFun = pageEntity.PageShortcut;
|
actionEntity1.PageIco = pageEntity.PageIco;
|
actionEntity1.ActionName = pageEntity.PageName;
|
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().Where(x => x.Subjecttype == "02").Select(x => new { code = x.Id, label = x.Subjectname }).ToList();
|
return View();
|
}
|
|
|
public IActionResult GetList(FiAccountRecordDTOSearch search)
|
{
|
var curentuser = JsonConvert.DeserializeObject<PltUser>(HttpContext.Session.GetString("User"));
|
ViewData["curentuser"] = curentuser;
|
search.RecordTypeId = "2";
|
search.Creater = "1111";
|
return new JsonResult(_iFiAccountRecordService.SearchByPaging(search));
|
}
|
|
|
|
|
|
public IActionResult Edit(string id = null)
|
{
|
var curentuser = JsonConvert.DeserializeObject<PltUser>(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 == "02").ToList();
|
|
|
|
ViewData.Model = fiAccountRecordDTO;
|
return View();
|
}
|
|
|
/// <summary>
|
/// 保存
|
/// </summary>
|
/// <param name="data">岗位实体类对象</param>
|
/// <returns></returns>
|
///
|
[HttpPost]
|
public IActionResult Save(FiAccountRecordDTO data)
|
{
|
var curentuser = JsonConvert.DeserializeObject<PltUser>(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 = "2";//支出
|
//data.Department = "";
|
|
//resultEntity = _iFiAccountRecordService.save(data);
|
|
firmAccount.AllExpenses = (firmAccount.AllExpenses ?? 0) + data.Money;
|
firmAccount.Balance = (firmAccount.Balance ?? 0) - data.Money;
|
|
data.AccountMoney = firmAccount.Balance;
|
|
resultEntity = _iFiAccountRecordService.save(data);
|
|
resultEntity = _fiAccountService.save(firmAccount);
|
scope.Complete();
|
}
|
|
|
|
return new JsonResult(resultEntity);
|
}
|
|
|
public IActionResult Check(string id = null)
|
{
|
var curentuser = JsonConvert.DeserializeObject<PltUser>(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();
|
}
|
|
}
|
}
|