Различия
Показаны различия между двумя версиями страницы.
| Предыдущая версия справа и слева Предыдущая версия Следующая версия | Предыдущая версия | ||
| product:linq:gantt:example_1 [27.11.2020 11:10] – mayn | product:linq:gantt:example_1 [04.02.2021 20:15] (текущий) – [Последовательность настройки] mayn | ||
|---|---|---|---|
| Строка 1: | Строка 1: | ||
| ====== Как вывести " | ====== Как вывести " | ||
| - | <callout type=" | ||
| - | Статья в разработке!! | ||
| - | </ | ||
| - | ===== Вывод колонок «Отклонение от базового плана» и «Статус отклонения» ===== | + | =====Глоссарий |
| - | ====Глоссарий ==== | + | |
| * LINQ (Language Integrated Query) – простой SQL-подобный язык запросов к источнику данных. | * LINQ (Language Integrated Query) – простой SQL-подобный язык запросов к источнику данных. | ||
| * БП – Базовый план. | * БП – Базовый план. | ||
| Строка 12: | Строка 8: | ||
| * ФДО – Фактическая дата окончания | * ФДО – Фактическая дата окончания | ||
| - | ==== Последовательность | + | ===== Последовательность |
| - Перейдите на страницу «Администрирование». | - Перейдите на страницу «Администрирование». | ||
| - | - Перейдите на страницу «Источники LINQ» создания источников данных с помощью LINQ-запросов. | + | - Перейдите на страницу «Источники LINQ» создания источников данных с помощью LINQ-запросов. |
| - | - Нажмите «Пересоздать контекст». | + | - Нажмите «Пересоздать контекст». |
| - | - Нажмите «Новый источник данных», | + | - Нажмите «Новый источник данных», |
| - | - В поле «Название» на странице создания источника данных через LINQ-запрос укажите «Расчет отклонения от базового плана» (без кавычек). | + | - В поле «Название» на странице создания источника данных через LINQ-запрос укажите «Расчет отклонения от базового плана» (без кавычек). |
| - В поле «Запрос» полностью удалите код тестового запроса. | - В поле «Запрос» полностью удалите код тестового запроса. | ||
| - | - В поле «Запрос» полностью скопируйте код из файла | + | - В поле «Запрос» полностью скопируйте код |
| + | Поле " | ||
| + | Содержит разницу (отклонение) в РАБОЧИХ днях между соответствующими плановой или | ||
| + | - Если у объекта есть УДО и ФДО, то отклонение = ФДО – УДО. | ||
| + | - Если у объекта есть УДО, но нет ФДО, то отклонение = ПДО – УДО. | ||
| + | - Если у объекта нет УДО, то расчет не производится. В соответствующей ячейке поля содержится пустое значение (не 0, а именно пустое значение). | ||
| + | - Положительные значения говорят о просрочке, отрицательные – об опережении утвержденного срока в БП. | ||
| + | |||
| + | Поле " | ||
| + | - Если значение поля " | ||
| + | - Если значение поля " | ||
| + | - Если значение поля " | ||
| + | - Если значение поля " | ||
| + | */ | ||
| + | |||
| + | var objectID = parameters.GetValueOrDefault< | ||
| + | var deviation = dataContext.Projects | ||
| + | .Where(p => p.BaselinePlanEndDate != null && p.GetParentHierarchy< | ||
| + | .OrderBy(p => p.Name) | ||
| + | .Select(a => new {a.Id, | ||
| + | a.Name, | ||
| + | a.SystemEndDate, | ||
| + | a.BaselinePlanEndDate, | ||
| + | a.ActualEndDate, | ||
| + | a.CalendarId | ||
| + | }) | ||
| + | .ToList() | ||
| + | .Select(b => new {b.Id, | ||
| + | b.Name, | ||
| + | b.SystemEndDate, | ||
| + | b.BaselinePlanEndDate, | ||
| + | b.ActualEndDate, | ||
| + | deviationPlan = Math.Round(b.ActualEndDate != null ? workCalendars.GetWorkCalendar(b.CalendarId).GetWorktimeDays(b.BaselinePlanEndDate.Value.Date, | ||
| + | } | ||
| + | ) | ||
| + | .ToList() | ||
| + | .Select(c => new {c.Id, | ||
| + | c.Name, | ||
| + | c.SystemEndDate, | ||
| + | c.BaselinePlanEndDate, | ||
| + | c.ActualEndDate, | ||
| + | c.deviationPlan, | ||
| + | deviationStatus1 = c.deviationPlan <= 7 ? 1 : 0, | ||
| + | deviationStatus2 = c.deviationPlan > 7 && c.deviationPlan <= 14 ? 2 : 0, | ||
| + | deviationStatus3 = c.deviationPlan > 14 ? 3 : 0}) | ||
| + | |||
| + | .ToList() | ||
| + | .Select(d => new {ObjectId = d.Id, | ||
| + | d.Name, | ||
| + | d.SystemEndDate, | ||
| + | d.BaselinePlanEndDate, | ||
| + | d.ActualEndDate, | ||
| + | deviationPlan = d.deviationPlan, | ||
| + | deviationStatus = d.deviationStatus1 + d.deviationStatus2 + d.deviationStatus3}) | ||
| + | | ||
| + | return deviation;</ | ||
| - Во второй вкладке браузера перейдите в карточку любого объекта системы, | - Во второй вкладке браузера перейдите в карточку любого объекта системы, | ||
| - | - Скопируйте в адресной строке ID этого объекта (после uid=). | + | - Скопируйте в адресной строке ID этого объекта (после uid=). |
| - Переключитесь обратно на первую вкладку браузера, | - Переключитесь обратно на первую вкладку браузера, | ||
| - | - Замените ID из строки кода: \\ На скопированный вами ID ранее (шаг 9). Это необходимо для первичного запуска кода запроса, | + | - Замените ID из строки кода |
| - | - Активируйте опцию «Может использоваться в диаграмме Ганта» | + | - Активируйте опцию «Может использоваться в диаграмме Ганта» |
| - Нажмите кнопку «Сделать запрос и сохранить». | - Нажмите кнопку «Сделать запрос и сохранить». | ||
| - Дождитесь, | - Дождитесь, | ||
| - | - Убедитесь, | + | - Убедитесь, |
| - Закройте страницу сохраненного источника данных «Расчет отклонения от базового плана». | - Закройте страницу сохраненного источника данных «Расчет отклонения от базового плана». | ||
| - | - Перейдите на страницу «Администрирование» -> «Диаграмма Ганта». | + | - Перейдите на страницу «Администрирование» -> «Диаграмма Ганта». |
| - | - В разделе «Настройка полей из LINQ-запроса» -> запрос «Расчет отклонения от базового плана» -> «Настроить». | + | - В разделе «Настройка полей из LINQ-запроса» -> запрос «Расчет отклонения от базового плана» -> «Настроить». |
| - | - Произведите следующие настройки: | + | - Произведите следующие настройки: |
| - | - Активируйте чекбоксы в поле у полей «deviationPlan» и «deviationStatus». | + | - Активируйте чекбоксы в поле |
| * deviationPlan: | * deviationPlan: | ||
| * Псевдоним - «Отклонение от БП» (без кавычек). Можете указать свое название поля с количеством дней отклонения, | * Псевдоним - «Отклонение от БП» (без кавычек). Можете указать свое название поля с количеством дней отклонения, | ||
| Строка 45: | Строка 96: | ||
| * Для красного индикатора укажите условие «= 3» (без кавычек) Можете указать свой цвет индикатора, | * Для красного индикатора укажите условие «= 3» (без кавычек) Можете указать свой цвет индикатора, | ||
| - Нажмите кнопку «Сохранить». | - Нажмите кнопку «Сохранить». | ||
| - | - Убедитесь, | + | - Убедитесь, |
| - | + | ||
| - | На странице «Настройка диаграммы Ганта» отображены | + | |
| - | ==== Появились ли поля в диаграмме Ганта? ==== | + | ===== Появились ли поля в диаграмме Ганта? |
| - Перейдите в диаграмму Ганта любого объекта системы. | - Перейдите в диаграмму Ганта любого объекта системы. | ||
| - Раскройте выпадающий список у любой из колонок диаграммы Ганта, наведя курсор мыши на шапку колонки и нажав на . | - Раскройте выпадающий список у любой из колонок диаграммы Ганта, наведя курсор мыши на шапку колонки и нажав на . | ||
| - | - Наведите курсор мыши на команду «Пользовательские столбцы» и активируйте чекбоксы «Отклонение от БП» и «Статус отклонения». | + | - Наведите курсор мыши на команду «Пользовательские столбцы» и активируйте чекбоксы «Отклонение от БП» и «Статус отклонения». |
| - | - Убедитесь, | + | - Убедитесь, |
| ==== Настройка представления поле в Ганте ==== | ==== Настройка представления поле в Ганте ==== | ||
| - Настройте порядок новых полей среди других колонок табличной части диаграммы Ганта. | - Настройте порядок новых полей среди других колонок табличной части диаграммы Ганта. | ||
| - | - При необходимости сохраните настройки представления, | + | - При необходимости сохраните настройки представления, |
| - Если данные в колонках полностью отсутствуют, | - Если данные в колонках полностью отсутствуют, | ||
| - Данные в колонках LINQ-запросов («Отклонение от БП» и «Статус отклонения») обновляются в 3 случаях: | - Данные в колонках LINQ-запросов («Отклонение от БП» и «Статус отклонения») обновляются в 3 случаях: | ||