/// <summary> /// Добавить в запрос условие соответсвующее полю "До даты" /// </summary> private void GetLogicStateCriteria(ReturnFromClientWaybillLogicState logicState, WaybillDateType dateType, DateTime?priorToDate, ref ICriteria <ReturnFromClientWaybill> crit) { if (dateType != WaybillDateType.Date) { return; } switch (logicState) { case ReturnFromClientWaybillLogicState.All: break; case ReturnFromClientWaybillLogicState.ExceptNotAccepted: crit.Where(x => x.AcceptanceDate <= priorToDate); break; case ReturnFromClientWaybillLogicState.NotAccepted: crit.Where(x => x.AcceptanceDate > priorToDate || x.AcceptanceDate == null); break; case ReturnFromClientWaybillLogicState.Accepted: crit.Where(x => x.AcceptanceDate <= priorToDate); break; case ReturnFromClientWaybillLogicState.Receipted: crit.Where(x => x.ReceiptDate <= priorToDate); break; default: throw new Exception("Непредусмотренный статус накладной."); } }
/// <summary> /// Получение списка накладных по МХ, кураторам и клиентам в диапозоне дат /// </summary> /// <param name="logicState">Статус накладной</param> /// <param name="returnFromClientWaybillSubQuery">Подзапрос на видимые накладные</param> /// <param name="storageIdList">Список кодов МХ</param> /// <param name="storageSubQuery">Подзапрос на видимые МХ</param> /// <param name="curatorIdList">Список кодов кураторов</param> /// <param name="curatorSubQuery">Подзапрос на видимых кураторов</param> /// <param name="clientIdList">Список кодов выбранных клиентов. (Подзапроса нет, т.к. они или видны все или не видны вовсе)</param> /// <param name="startDate">Начало интервала</param> /// <param name="endDate">Конец интервала</param> /// <param name="dateType">Тип даты</param> /// <param name="priorToDate">Параметр "До даты"</param> /// <returns>Список накладных</returns> public IEnumerable <ReturnFromClientWaybill> GetList(ReturnFromClientWaybillLogicState logicState, ISubCriteria <ReturnFromClientWaybill> returnFromClientWaybillSubQuery, IEnumerable <short> storageIdList, ISubCriteria <Storage> storageSubQuery, IEnumerable <int> curatorIdList, ISubCriteria <User> curatorSubQuery, IEnumerable <int> clientIdList, DateTime startDate, DateTime endDate, int pageNumber, WaybillDateType dateType, DateTime?priorToDate) { var crit = Query <ReturnFromClientWaybill>(); GetDateTypeCriteria(startDate, endDate, dateType, ref crit); GetLogicStateCriteria(logicState, dateType, priorToDate, ref crit); crit.PropertyIn(x => x.Id, returnFromClientWaybillSubQuery) .PropertyIn(x => x.RecipientStorage.Id, storageSubQuery) .PropertyIn(x => x.Curator.Id, curatorSubQuery) .OrderByAsc(x => x.Id); if (dateType != WaybillDateType.Date) { var stateList = GetStateListForReturnFromClientWaybill(logicState); crit.OneOf(x => x.State, stateList); } if (storageIdList != null) { crit.OneOf(x => x.RecipientStorage.Id, storageIdList); } if (curatorIdList != null) { crit.OneOf(x => x.Curator.Id, curatorIdList); } if (clientIdList != null) { // т.к. напрямую не может разрезолвить путь "Deal.Client.Id". var sq = SubQuery <Deal>() .OneOf(x => x.Client.Id, clientIdList) .Select(x => x.Id); crit.PropertyIn(x => x.Deal.Id, sq); } return(crit.SetFirstResult(100 * (pageNumber - 1)).SetMaxResults(100).ToList <ReturnFromClientWaybill>()); }
/// <summary> /// Получение параметров фильтрации для подгрузки накладных возврата /// </summary> private IEnumerable <ReturnFromClientWaybillState> GetStateListForReturnFromClientWaybill(ReturnFromClientWaybillLogicState state) { var result = new List <ReturnFromClientWaybillState>(); switch (state) { case ReturnFromClientWaybillLogicState.All: result.Add(ReturnFromClientWaybillState.Accepted); result.Add(ReturnFromClientWaybillState.Draft); result.Add(ReturnFromClientWaybillState.ReadyToAccept); result.Add(ReturnFromClientWaybillState.Receipted); break; case ReturnFromClientWaybillLogicState.ExceptNotAccepted: result.Add(ReturnFromClientWaybillState.Accepted); result.Add(ReturnFromClientWaybillState.Receipted); break; case ReturnFromClientWaybillLogicState.NotAccepted: result.Add(ReturnFromClientWaybillState.Draft); result.Add(ReturnFromClientWaybillState.ReadyToAccept); break; case ReturnFromClientWaybillLogicState.Accepted: result.Add(ReturnFromClientWaybillState.Accepted); result.Add(ReturnFromClientWaybillState.Receipted); break; case ReturnFromClientWaybillLogicState.Receipted: result.Add(ReturnFromClientWaybillState.Receipted); break; } return(result); }
/// <summary> /// Получение списка накладных /// </summary> /// <param name="logicState">Статус накладной</param> /// <param name="storageIdList">Список кодов мест хранения</param> /// <param name="storagePermission">Право, которым определяются доступные места хранения</param> /// <param name="curatorIdList">Список кодов кураторов</param> /// <param name="curatorPermission">Право, которым определяются доступные пользователи</param> /// <param name="clientIdList">Список кодов клиентов</param> /// <param name="clientPermission">Право, которым определяются доступные клиенты</param> /// <param name="startDate">Начальная дата</param> /// <param name="endDate">Конечная дата</param> /// <param name="pageNumber">Номер страницы, первая 1.</param> /// <param name="dateType">Тип даты</param> /// <param name="priorToDate">Параметр "До даты"</param> /// <param name="user">Пользователь</param> /// <returns>Список накладных</returns> public IEnumerable <ReturnFromClientWaybill> GetList(ReturnFromClientWaybillLogicState logicState, IEnumerable <short> storageIdList, Permission storagePermission, IEnumerable <int> curatorIdList, Permission curatorPermission, IEnumerable <int> clientIdList, Permission clientPermission, DateTime startDate, DateTime endDate, int pageNumber, WaybillDateType dateType, DateTime?priorToDate, User user) { ISubCriteria <Storage> storageSubQuery = null; ISubCriteria <User> curatorSubQuery = null; ISubCriteria <ReturnFromClientWaybill> returnFromClientWaybillSubQuery = null; switch (user.GetPermissionDistributionType(storagePermission)) { case PermissionDistributionType.All: storageSubQuery = storageRepository.GetStorageSubQueryByAllPermission(); break; case PermissionDistributionType.Teams: storageSubQuery = storageRepository.GetStorageSubQueryByTeamPermission(user.Id); break; case PermissionDistributionType.None: return(new List <ReturnFromClientWaybill>()); } switch (user.GetPermissionDistributionType(curatorPermission)) { case PermissionDistributionType.All: curatorSubQuery = userRepository.GetUserSubQueryByAllPermission(); break; case PermissionDistributionType.Teams: curatorSubQuery = userRepository.GetUserSubQueryByTeamPermission(user.Id); break; case PermissionDistributionType.None: return(new List <ReturnFromClientWaybill>()); } switch (user.GetPermissionDistributionType(Permission.ReturnFromClientWaybill_List_Details)) { case PermissionDistributionType.All: returnFromClientWaybillSubQuery = returnFromClientWaybillRepository.GetReturnFromClientWaybillSubQueryByAllPermission(); break; case PermissionDistributionType.Teams: returnFromClientWaybillSubQuery = returnFromClientWaybillRepository.GetReturnFromClientWaybillSubQueryByTeamPermission(user.Id); break; case PermissionDistributionType.Personal: returnFromClientWaybillSubQuery = returnFromClientWaybillRepository.GetReturnFromClientWaybillSubQueryByPersonalPermission(user.Id); break; case PermissionDistributionType.None: return(new List <ReturnFromClientWaybill>()); } switch (user.GetPermissionDistributionType(clientPermission)) { case PermissionDistributionType.None: return(new List <ReturnFromClientWaybill>()); case PermissionDistributionType.All: break; } return(returnFromClientWaybillRepository.GetList(logicState, returnFromClientWaybillSubQuery, storageIdList, storageSubQuery, curatorIdList, curatorSubQuery, clientIdList, startDate, endDate, pageNumber, dateType, priorToDate)); }