/// <summary> /// Добавить в запрос условие соответсвующее полю "До даты" /// </summary> private void GetLogicStateCriteria(WriteoffWaybillLogicState logicState, WaybillDateType dateType, DateTime?priorToDate, ref ICriteria <WriteoffWaybill> crit) { if (dateType != WaybillDateType.Date) { return; } switch (logicState) { case WriteoffWaybillLogicState.All: break; case WriteoffWaybillLogicState.ExceptNotAccepted: crit.Where(x => x.AcceptanceDate <= priorToDate); break; case WriteoffWaybillLogicState.NotAccepted: crit.Where(x => x.AcceptanceDate > priorToDate || x.AcceptanceDate == null); break; case WriteoffWaybillLogicState.ReadyToWriteoff: crit.Where(x => x.AcceptanceDate <= priorToDate); break; case WriteoffWaybillLogicState.Writtenoff: crit.Where(x => x.WriteoffDate <= priorToDate); break; default: throw new Exception("Непредусмотренный статус накладной."); } }
/// <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="writeoffWaybillSubQuery">Подзапрос на видимые накладные</param> /// <param name="dateType">Тип даты</param> /// <param name="priorToDate">Параметр "До даты"</param> /// <returns>Список накладных</returns> public IEnumerable <WriteoffWaybill> GetList(WriteoffWaybillLogicState logicState, ISubCriteria <WriteoffWaybill> writeoffWaybillSubQuery, 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 <WriteoffWaybill>(); GetDateTypeCriteria(startDate, endDate, dateType, ref crit); GetLogicStateCriteria(logicState, dateType, priorToDate, ref crit); crit.PropertyIn(x => x.Id, writeoffWaybillSubQuery) .PropertyIn(x => x.SenderStorage.Id, storageSubQuery) .PropertyIn(x => x.Curator.Id, curatorSubQuery) .OrderByAsc(x => x.Id); if (dateType != WaybillDateType.Date) { var stateList = GetStatelistForWriteoffWaybill(logicState); crit.OneOf(x => x.State, stateList); } if (storageIdList != null) { crit.OneOf(x => x.SenderStorage.Id, storageIdList); } if (curatorIdList != null) { crit.OneOf(x => x.Curator.Id, curatorIdList); } return(crit.SetFirstResult(100 * (pageNumber - 1)).SetMaxResults(100).ToList <WriteoffWaybill>()); }
/// <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 <WriteoffWaybill> GetList(WriteoffWaybillLogicState 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 <WriteoffWaybill> writeoffWaybillSubQuery = 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 <WriteoffWaybill>()); } 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 <WriteoffWaybill>()); } switch (user.GetPermissionDistributionType(Permission.WriteoffWaybill_List_Details)) { case PermissionDistributionType.All: writeoffWaybillSubQuery = writeoffWaybillRepository.GetWriteoffWaybillSubQueryByAllPermission(); break; case PermissionDistributionType.Teams: writeoffWaybillSubQuery = writeoffWaybillRepository.GetWriteoffWaybillSubQueryByTeamPermission(user.Id); break; case PermissionDistributionType.Personal: writeoffWaybillSubQuery = writeoffWaybillRepository.GetWriteoffWaybillSubQueryByPersonalPermission(user.Id); break; case PermissionDistributionType.None: return(new List <WriteoffWaybill>()); } return(writeoffWaybillRepository.GetList(logicState, writeoffWaybillSubQuery, storageIdList, storageSubQuery, curatorIdList, curatorSubQuery, startDate, endDate, pageNumber, dateType, priorToDate)); }
/// <summary> /// Получение статусов накладной списания /// </summary> private IEnumerable <WriteoffWaybillState> GetStatelistForWriteoffWaybill(WriteoffWaybillLogicState state) { var result = new List <WriteoffWaybillState>(); switch (state) { case WriteoffWaybillLogicState.All: result.Add(WriteoffWaybillState.ArticlePending); result.Add(WriteoffWaybillState.ConflictsInArticle); result.Add(WriteoffWaybillState.Draft); result.Add(WriteoffWaybillState.ReadyToAccept); result.Add(WriteoffWaybillState.ReadyToWriteoff); result.Add(WriteoffWaybillState.Writtenoff); break; case WriteoffWaybillLogicState.ExceptNotAccepted: result.Add(WriteoffWaybillState.ArticlePending); result.Add(WriteoffWaybillState.ConflictsInArticle); result.Add(WriteoffWaybillState.ReadyToWriteoff); result.Add(WriteoffWaybillState.Writtenoff); break; case WriteoffWaybillLogicState.NotAccepted: result.Add(WriteoffWaybillState.Draft); result.Add(WriteoffWaybillState.ReadyToAccept); break; case WriteoffWaybillLogicState.ReadyToWriteoff: result.Add(WriteoffWaybillState.ArticlePending); result.Add(WriteoffWaybillState.ConflictsInArticle); result.Add(WriteoffWaybillState.ReadyToWriteoff); result.Add(WriteoffWaybillState.Writtenoff); break; case WriteoffWaybillLogicState.Writtenoff: result.Add(WriteoffWaybillState.Writtenoff); break; } return(result); }