/// <summary> /// Получение списка накладных по МХ, кураторам в диапозоне дат /// </summary> /// <param name="logicState">Статус накладной</param> /// <param name="stateList">Список статусов, которые могут иметь накладные</param> /// <param name="storageIdList">Список кодов МХ</param> /// <param name="storageSubQuery">Подзапрос на видимые МХ</param> /// <param name="curatorIdList">Список кодов кураторов</param> /// <param name="curatorSubQuery">Подзапрос на видимых кураторов</param> /// <param name="startDate">Начало интервала</param> /// <param name="endDate">Конец интервала</param> /// <param name="movementWaybillSubQuery">Подзапрос на видимые накладные</param> /// <param name="dateType">Тип даты</param> /// <param name="priorToDate">Параметр "До даты"</param> /// <returns>Список накладных</returns> public IEnumerable <MovementWaybill> GetList(MovementWaybillLogicState logicState, ISubCriteria <MovementWaybill> movementWaybillSubQuery, IEnumerable <short> storageIdList, ISubCriteria <Storage> storageSubQuery, IEnumerable <int> curatorIdList, ISubCriteria <User> curatorSubQuery, DateTime startDate, DateTime endDate, int pageNumber, WaybillDateType dateType, DateTime?priorToDate) { var crit = Query <MovementWaybill>(); GetDateTypeCriteria(startDate, endDate, dateType, ref crit); GetLogicStateCriteria(logicState, dateType, priorToDate, ref crit); crit.PropertyIn(x => x.Id, movementWaybillSubQuery) .Or(y => y.PropertyIn(x => x.SenderStorage.Id, storageSubQuery), y => y.PropertyIn(x => x.RecipientStorage.Id, storageSubQuery)) .PropertyIn(x => x.Curator.Id, curatorSubQuery) .OrderByAsc(x => x.Id); if (dateType != WaybillDateType.Date) { var stateList = GetStatelistForMovementWaybill(logicState); crit.OneOf(x => x.State, stateList); } if (storageIdList != null) { crit.Or(y => y.OneOf(x => x.SenderStorage.Id, storageIdList), y => y.OneOf(x => x.RecipientStorage.Id, storageIdList)); } if (curatorIdList != null) { crit.OneOf(x => x.Curator.Id, curatorIdList); } return(crit.SetFirstResult(100 * (pageNumber - 1)).SetMaxResults(100).ToList <MovementWaybill>()); }
/// <summary> /// Получение списка накладных /// </summary> /// <param name="logicState">Статус накладной</param> /// <param name="storageIdList">Список кодов мест хранения</param> /// <param name="storagePermission">Право, которым определяются доступные места хранения</param> /// <param name="curatorIdList">Список кодов кураторов</param> /// <param name="curatorPermission">Право, которым определяются доступные пользователи</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 <MovementWaybill> GetList(MovementWaybillLogicState logicState, IEnumerable <short> storageIdList, Permission storagePermission, IEnumerable <int> curatorIdList, Permission curatorPermission, DateTime startDate, DateTime endDate, int pageNumber, WaybillDateType dateType, DateTime?priorToDate, User user) { ISubCriteria <Storage> storageSubQuery = null; ISubCriteria <User> curatorSubQuery = null; ISubCriteria <MovementWaybill> movementWaybillSubQuery = 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 <MovementWaybill>()); } 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 <MovementWaybill>()); } switch (user.GetPermissionDistributionType(Permission.MovementWaybill_List_Details)) { case PermissionDistributionType.All: movementWaybillSubQuery = movementWaybillRepository.GetMovementWaybillSubQueryByAllPermission(); break; case PermissionDistributionType.Teams: movementWaybillSubQuery = movementWaybillRepository.GetMovementWaybillSubQueryByTeamPermission(user.Id); break; case PermissionDistributionType.Personal: movementWaybillSubQuery = movementWaybillRepository.GetMovementWaybillSubQueryByPersonalPermission(user.Id); break; case PermissionDistributionType.None: return(new List <MovementWaybill>()); } return(movementWaybillRepository.GetList(logicState, movementWaybillSubQuery, storageIdList, storageSubQuery, curatorIdList, curatorSubQuery, startDate, endDate, pageNumber, dateType, priorToDate)); }
/// <summary> /// Добавить в запрос условие соответсвующее полю "До даты" /// </summary> private void GetLogicStateCriteria(MovementWaybillLogicState logicState, WaybillDateType dateType, DateTime?priorToDate, ref ICriteria <MovementWaybill> crit) { if (dateType != WaybillDateType.Date) { return; } switch (logicState) { case MovementWaybillLogicState.All: break; case MovementWaybillLogicState.Accepted: crit.Where(x => x.AcceptanceDate <= priorToDate); break; case MovementWaybillLogicState.NotReceipted: crit.Where(x => x.ReceiptDate > priorToDate || x.ReceiptDate == null); break; case MovementWaybillLogicState.NotShipped: crit.Where(x => x.ShippingDate > priorToDate || x.ShippingDate == null); break; case MovementWaybillLogicState.AcceptedNotReceipted: crit.Where(x => (x.AcceptanceDate <= priorToDate) && (x.ReceiptDate > priorToDate || x.ReceiptDate == null)); break; case MovementWaybillLogicState.Shipped: crit.Where(x => x.ShippingDate <= priorToDate); break; case MovementWaybillLogicState.NotAccepted: crit.Where(x => x.AcceptanceDate > priorToDate || x.AcceptanceDate == null); break; case MovementWaybillLogicState.AcceptedNotShipped: crit.Where(x => (x.AcceptanceDate <= priorToDate) && (x.ShippingDate > priorToDate || x.ShippingDate == null)); break; case MovementWaybillLogicState.ShippedNotReceipted: crit.Where(x => (x.ShippingDate <= priorToDate) && (x.ReceiptDate > priorToDate || x.ReceiptDate == null)); break; case MovementWaybillLogicState.Receipted: crit.Where(x => x.ReceiptDate <= priorToDate); break; default: throw new Exception("Непредусмотренный статус накладной."); } }
/// <summary> /// Получение статусов накладной перемещения /// </summary> private IEnumerable <MovementWaybillState> GetStatelistForMovementWaybill(MovementWaybillLogicState state) { var result = new List <MovementWaybillState>(); switch (state) { case MovementWaybillLogicState.All: result.Add(MovementWaybillState.ArticlePending); result.Add(MovementWaybillState.ConflictsInArticle); result.Add(MovementWaybillState.ReadyToShip); result.Add(MovementWaybillState.ReceiptedAfterDivergences); result.Add(MovementWaybillState.ReceiptedWithDivergences); result.Add(MovementWaybillState.ReceiptedWithoutDivergences); result.Add(MovementWaybillState.ShippedBySender); result.Add(MovementWaybillState.Draft); result.Add(MovementWaybillState.ReadyToAccept); break; case MovementWaybillLogicState.Accepted: result.Add(MovementWaybillState.ArticlePending); result.Add(MovementWaybillState.ConflictsInArticle); result.Add(MovementWaybillState.ReadyToShip); result.Add(MovementWaybillState.ReceiptedAfterDivergences); result.Add(MovementWaybillState.ReceiptedWithDivergences); result.Add(MovementWaybillState.ReceiptedWithoutDivergences); result.Add(MovementWaybillState.ShippedBySender); break; case MovementWaybillLogicState.NotReceipted: result.Add(MovementWaybillState.Draft); result.Add(MovementWaybillState.ReadyToAccept); result.Add(MovementWaybillState.ArticlePending); result.Add(MovementWaybillState.ConflictsInArticle); result.Add(MovementWaybillState.ReadyToShip); result.Add(MovementWaybillState.ShippedBySender); break; case MovementWaybillLogicState.NotShipped: result.Add(MovementWaybillState.Draft); result.Add(MovementWaybillState.ReadyToAccept); result.Add(MovementWaybillState.ArticlePending); result.Add(MovementWaybillState.ConflictsInArticle); result.Add(MovementWaybillState.ReadyToShip); break; case MovementWaybillLogicState.AcceptedNotReceipted: result.Add(MovementWaybillState.ArticlePending); result.Add(MovementWaybillState.ConflictsInArticle); result.Add(MovementWaybillState.ReadyToShip); result.Add(MovementWaybillState.ShippedBySender); break; case MovementWaybillLogicState.Shipped: result.Add(MovementWaybillState.ShippedBySender); result.Add(MovementWaybillState.ReceiptedAfterDivergences); result.Add(MovementWaybillState.ReceiptedWithDivergences); result.Add(MovementWaybillState.ReceiptedWithoutDivergences); break; case MovementWaybillLogicState.NotAccepted: result.Add(MovementWaybillState.Draft); result.Add(MovementWaybillState.ReadyToAccept); break; case MovementWaybillLogicState.AcceptedNotShipped: result.Add(MovementWaybillState.ArticlePending); result.Add(MovementWaybillState.ConflictsInArticle); result.Add(MovementWaybillState.ReadyToShip); break; case MovementWaybillLogicState.ShippedNotReceipted: result.Add(MovementWaybillState.ShippedBySender); break; case MovementWaybillLogicState.Receipted: result.Add(MovementWaybillState.ReceiptedAfterDivergences); result.Add(MovementWaybillState.ReceiptedWithDivergences); result.Add(MovementWaybillState.ReceiptedWithoutDivergences); break; } return(result); }