BaseEquipmentGroupService.cs 5.71 KB
using Hh.Mes.Common.log;
using Hh.Mes.Common.Request;
using Hh.Mes.POJO.Response;
using Hh.Mes.POJO.WebEntity;
using Hh.Mes.Service.Repository;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq.Expressions;

namespace Hh.Mes.Service.WebService.Equipment
{
    public class BaseEquipmentGroupService : RepositorySqlSugar<BaseEquipmentGroup>
    {
        public dynamic DelByIds(int[] ids)
        {
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                var response = new Response();

                Context.Ado.BeginTran();
                foreach (var item in ids)
                {
                    var path = Context.Queryable<BaseEquipmentGroup>().Where(x => x.id == item).Select(x => x.path).First();
                    Context.Deleteable<BaseEquipmentGroup>().Where(x => x.path.StartsWith(path)).ExecuteCommand();
                }
                Context.Ado.CommitTran();
                return response.ResponseSuccess();
            });
        }

        private string GetNodePath(int? nodeId, string? path = null)
        {
            if (nodeId == null)
            {
                return string.Empty;
            }

            var currentPath = path ?? $"{nodeId}";
            var parentId = Context.Queryable<BaseEquipmentGroup>().Where(x => x.id == nodeId).Select(x => x.parentId).First();
            if (parentId == null)
            {
                return currentPath;
            }
            currentPath = string.IsNullOrWhiteSpace(currentPath) ? $"{parentId}" : $"{parentId}.{currentPath}";
            return GetNodePath((int)parentId, currentPath);
        }

        public dynamic Ins(BaseEquipmentGroup baseEquipmentGroup)
        {
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                var response = new Response();
                baseEquipmentGroup.id = Context.Insertable(baseEquipmentGroup).ExecuteReturnIdentity();
                var parentPath = GetNodePath(baseEquipmentGroup.parentId);
                baseEquipmentGroup.path = string.IsNullOrWhiteSpace(parentPath)
                ? $"{baseEquipmentGroup.parentId}"
                : $"{parentPath}.{baseEquipmentGroup.id}";
                Context.Updateable<BaseEquipmentGroup>().SetColumns(x => new BaseEquipmentGroup
                {
                    path = baseEquipmentGroup.path,
                }).Where(x => x.id == baseEquipmentGroup.id).ExecuteCommand();
                return response.ResponseSuccess();
            });
        }

        public dynamic Load(PageReq pageReq, BaseEquipmentGroup entity)
        {
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                var result = new Response<List<BaseEquipmentGroup>>();
                var query = Context.Queryable<BaseEquipmentGroup>().Where(LinqWhere(entity));
                //Exel为ture就不分页,因为导出的话是全部导出
                if (pageReq != null)
                {
                    int total = 0;
                    result.Result = query.Select(x => new BaseEquipmentGroup
                    {
                        id = x.id,
                        code = x.code,
                        name = x.name,
                        parentId = x.parentId,
                        parentName = SqlFunc.Subqueryable<BaseEquipmentGroup>().Where(s => s.id == x.parentId).Select(s => s.name),
                        remark = x.remark
                    }).ToOffsetPage(pageReq.page, pageReq.limit, ref total);
                    result.Count = total;
                }
                else
                {
                    result.Result = query.ToList();
                    result.Count = result.Result.Count;
                }
                return result;
            }, "list");
        }

        public List<BaseEquipmentGroup> LoadAll()
        {
            return Context.Queryable<BaseEquipmentGroup>().ToList();
        }

        public dynamic Upd(BaseEquipmentGroup baseEquipmentGroup)
        {
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                var response = new Response();
                var parentPath = GetNodePath(baseEquipmentGroup.parentId);
                baseEquipmentGroup.path = string.IsNullOrWhiteSpace(parentPath)
                ? $"{baseEquipmentGroup.parentId}"
                : $"{parentPath}.{baseEquipmentGroup.id}";
                Context.Updateable<BaseEquipmentGroup>().SetColumns(x => new BaseEquipmentGroup
                {
                    code = baseEquipmentGroup.code,
                    name = baseEquipmentGroup.name,
                    path = baseEquipmentGroup.path,
                    remark = baseEquipmentGroup.remark,
                    parentId = baseEquipmentGroup.parentId,
                }).Where(x => x.id == baseEquipmentGroup.id).ExecuteCommand();
                return response.ResponseSuccess();
            });
        }

        public Expression<Func<BaseEquipmentGroup, bool>> LinqWhere(BaseEquipmentGroup model)
        {
            var exp = Expressionable.Create<BaseEquipmentGroup>();
            //数据过滤条件
            if (!string.IsNullOrWhiteSpace(model.code))
            {
                exp.And(x => x.code.Contains(model.code));
            }
            if (!string.IsNullOrWhiteSpace(model.name))
            {
                exp.And(x => x.name.Contains(model.name));
            }
            if (model.parentId != default)
            {
                var parentPath = Context.Queryable<BaseEquipmentGroup>().Where(s => s.id == model.parentId).Select(s => s.path).First();
                exp.And(x => x.path.StartsWith(parentPath) || x.id == model.parentId);
            }
            return exp.ToExpression();//拼接表达式
        }
    }
}