<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://docs.deansoffice.ru/wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ivanov</id>
		<title>DOF - Вклад участника [ru]</title>
		<link rel="self" type="application/atom+xml" href="http://docs.deansoffice.ru/wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ivanov"/>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/ru/%D0%A1%D0%BB%D1%83%D0%B6%D0%B5%D0%B1%D0%BD%D0%B0%D1%8F:%D0%92%D0%BA%D0%BB%D0%B0%D0%B4/Ivanov"/>
		<updated>2026-04-12T17:30:13Z</updated>
		<subtitle>Вклад участника</subtitle>
		<generator>MediaWiki 1.30.2</generator>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/schedule&amp;diff=3205</id>
		<title>Разработка:im/schedule</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/schedule&amp;diff=3205"/>
				<updated>2018-11-30T09:42:26Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: /* Права плагина */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = schedule&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
== Раписание учебных занятий ==&lt;br /&gt;
Плагин предназначен для ввода и отображения информации по расписанию учебных занятий.&lt;br /&gt;
&lt;br /&gt;
=== Интерфейс расписания учебных занятий ===&lt;br /&gt;
Основной интерфейс раписания усебных занятий выглядит следующим образом:&lt;br /&gt;
[[Изображение:Selection 058.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
Фильтр позволяет выбрать учебный период и увидеть список всех шаблонов, созданных в этом учебном периоде.&lt;br /&gt;
Доступны следующие способы отображения шаблонов.&lt;br /&gt;
&lt;br /&gt;
==== По времени ====&lt;br /&gt;
[[Изображение:Selection 059.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
==== По учащимся ====&lt;br /&gt;
[[Изображение:Selection 060.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
==== По преподавателям ====&lt;br /&gt;
[[Изображение:Selection 061.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
==== По номеру кабинета ====&lt;br /&gt;
[[Изображение:Selection 062.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
=== Отчет о нагрузке шаблонов ===&lt;br /&gt;
Отчет включает себя два подотчета, один из которых отображает нагруженность учебных процессов, второй - пересечение шаблонов.&lt;br /&gt;
&lt;br /&gt;
==== Нагруженность учебных процессов ====&lt;br /&gt;
[[Изображение:Selection 063.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
==== Пересечение шаблонов  ====&lt;br /&gt;
Пересечение шаблонов может быть по следующим параметрам:&lt;br /&gt;
* По учителям&lt;br /&gt;
* Ученикам&lt;br /&gt;
* По кабинету&lt;br /&gt;
[[Изображение:Selection 065.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
=== Интерфейс управления шаблоном раписания ===&lt;br /&gt;
&lt;br /&gt;
==== Интерфейс создания/редактирования шаблона расписания: ====&lt;br /&gt;
[[Изображение:Selection 066.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
==== Интерфейс просмотра шаблона расписания: ====&lt;br /&gt;
[[Изображение:Selection 067.png‎||350px|center|]]&lt;br /&gt;
&lt;br /&gt;
== API ==&lt;br /&gt;
&lt;br /&gt;
=== Перехватываемые события ===&lt;br /&gt;
Список перехватываемых событий:&lt;br /&gt;
&lt;br /&gt;
==== im/obj/get_object_url ====&lt;br /&gt;
&lt;br /&gt;
''Обязательные параметры (mixedvar):''&lt;br /&gt;
* storage == schtemplates&lt;br /&gt;
* action == view&lt;br /&gt;
&lt;br /&gt;
''Дополнительные параметры (mixedvar):''&lt;br /&gt;
* urlparams - в виде массива&lt;br /&gt;
&lt;br /&gt;
''возвращаемые значения:''&lt;br /&gt;
* Возвращает ссылку на просмотр шаблона&lt;br /&gt;
&lt;br /&gt;
=== Конфиги ===&lt;br /&gt;
Список конфигов со значениями по умолчанию:&lt;br /&gt;
&lt;br /&gt;
==== enabled ====&lt;br /&gt;
''Флаг включения плагина''&lt;br /&gt;
* type = checkbox&lt;br /&gt;
* code = enabled&lt;br /&gt;
* value = 1&lt;br /&gt;
&lt;br /&gt;
=== Права плагина ===&lt;br /&gt;
Список прав:&lt;br /&gt;
Начиная с версии 3.1.15b (3.5.3a) добавлено новое право &amp;quot;Право доступа к интерфейсу массовых действий с шаблонами расписания&amp;quot; (im schedule bulk:edit).&lt;br /&gt;
==== create_schedule ====&lt;br /&gt;
Право на создание расписания&lt;br /&gt;
''Роли по умолчанию:''&lt;br /&gt;
* Управляющий (manager)&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:sync/personstom&amp;diff=3204</id>
		<title>Разработка:sync/personstom</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:sync/personstom&amp;diff=3204"/>
				<updated>2018-09-21T08:43:52Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = persons&lt;br /&gt;
| type = sync&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
Синхронизация добавляемых в адресную книгу персон со списком пользователей Moodle.&lt;br /&gt;
&lt;br /&gt;
* Создание пользователя при добавлении персоны в справочник и запись id пользователя в справочник (если установлен флаг синхронизации)&lt;br /&gt;
* Обновление профиля пользователя при обновлении записи в справочнике (если установлен флаг синхронизации)&lt;br /&gt;
* Удаление пользователя из Moodle при отметке персоны как удаленной в справочнике&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Конфиг плагина ==&lt;br /&gt;
&lt;br /&gt;
Настройки конфига по умолчанию:&lt;br /&gt;
&lt;br /&gt;
// принудительная смена логина&lt;br /&gt;
&lt;br /&gt;
'''$sync_personstom['autochangelogin'] = false;''' //выключена&lt;br /&gt;
&lt;br /&gt;
// пытаться ли автоматически совершить привязку пользователя к персоне, сопоставляя обе записи по полю email&lt;br /&gt;
&lt;br /&gt;
'''$sync_personstom['autolink_by_email'] = true;'''&lt;br /&gt;
&lt;br /&gt;
// если настроена автоматическая привязка по email,&lt;br /&gt;
&lt;br /&gt;
// и найдено несколько подходящих вариантов &lt;br /&gt;
&lt;br /&gt;
// (в Moodle есть опция, разрешающая регистрировать пользователей с одинаковым email)&lt;br /&gt;
&lt;br /&gt;
// 0 - не привязывать&lt;br /&gt;
&lt;br /&gt;
// 1 - создать еще одного пользователя ( только если в moodle разрешено заводить несколько пользователей с одинаковым email ) &lt;br /&gt;
&lt;br /&gt;
// 2 - привязать к любому&lt;br /&gt;
&lt;br /&gt;
'''$sync_personstom['autolink_double'] = 0;'''&lt;br /&gt;
&lt;br /&gt;
// причины, позволяющие синхронизировать персону ЭД в Moodle&lt;br /&gt;
&lt;br /&gt;
// person_is_active:       true        - активация персоны является поводом синхронизировать персону ЭД в Moodle&lt;br /&gt;
&lt;br /&gt;
//                         false       - активация персоны не является поводом синхронизировать персону ЭД в Moodle&lt;br /&gt;
&lt;br /&gt;
// contract_is_active:     true        - активация договора является поводом синхронизировать студента по договору в Moodle&lt;br /&gt;
&lt;br /&gt;
//                         false       - активация договора не является поводом синхронизировать студента по договору в Moodle&lt;br /&gt;
&lt;br /&gt;
// cpassed_is_active:      true        - активация подписки на дисциплину является поводом синхронизировать студента по подписке в Moodle&lt;br /&gt;
&lt;br /&gt;
//                         false       - активация подписки на дисциплину не является поводом синхронизировать студента по подписке в Moodle&lt;br /&gt;
&lt;br /&gt;
// eagreeement_is_active:  true        - активация договора с сотрудником является поводом синхронизировать студента по подписке в Moodle&lt;br /&gt;
&lt;br /&gt;
//                         false       - активация договора с сотрудником не является поводом синхронизировать студента по подписке в Moodle&lt;br /&gt;
&lt;br /&gt;
// appointment_is_active:  true или [] - активация должностного назначения является поводом синхронизировать сотрудника в Moodle&lt;br /&gt;
&lt;br /&gt;
//                                       если массив не пуст, то значения воспринимаются как идентификаторы должностей, по которым дозволена синхронизация&lt;br /&gt;
&lt;br /&gt;
//                         false       - активация должностного назначения не является поводом синхронизировать сотрудника в Moodle&lt;br /&gt;
&lt;br /&gt;
'''$sync_personstom['sync_reason'] = [&lt;br /&gt;
    'person_is_active' =&amp;gt; false,&lt;br /&gt;
    'contract_is_active' =&amp;gt; true,&lt;br /&gt;
    'cpassed_is_active' =&amp;gt; false,&lt;br /&gt;
    'eagreeement_is_active' =&amp;gt; true,&lt;br /&gt;
    'appointment_is_active' =&amp;gt; false&lt;br /&gt;
];'''&lt;br /&gt;
&lt;br /&gt;
Для переопределения конфига необходимо положить файл переопределения cfg.php в {hostname}/www/data/dof/cfg/sync/personstom/ и выдать права 777.&lt;br /&gt;
&lt;br /&gt;
== Настройки плагина ==&lt;br /&gt;
&lt;br /&gt;
* mdlgroup_name_template&lt;br /&gt;
Шаблон для формирования названия группы в курсе Moodle. По умолчанию имеет значение &amp;quot;{TEACHER_FULLNAME_INITIALS} {AGE_NAME} {CSTREAM_NAME}&amp;quot;, где TEACHER_FULLNAME_INITIALS - фамилия преподавателя с инициалами, AGE_NAME - имя учебного периода, CSTREAM_NAME - название учебного процесса&lt;br /&gt;
&lt;br /&gt;
* unenrol_mode&lt;br /&gt;
Поведение при отписке пользователя от курса. По умолчанию имеет значение &amp;quot;always_unenrol&amp;quot;. Может иметь 2 значения:&lt;br /&gt;
 - always_unenrol - всегда удалять подписку плагина&lt;br /&gt;
 - with_manual_creation_unenrol - заменять подписку плагина на ручную при наличии дополнительных ролей и отсутствии других подписок&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:sync/personstom&amp;diff=3199</id>
		<title>Разработка:sync/personstom</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:sync/personstom&amp;diff=3199"/>
				<updated>2018-09-04T07:33:28Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = persons&lt;br /&gt;
| type = sync&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
Синхронизация добавляемых в адресную книгу персон со списком пользователей Moodle.&lt;br /&gt;
&lt;br /&gt;
* Создание пользователя при добавлении персоны в справочник и запись id пользователя в справочник (если установлен флаг синхронизации)&lt;br /&gt;
* Обновление профиля пользователя при обновлении записи в справочнике (если установлен флаг синхронизации)&lt;br /&gt;
* Удаление пользователя из Moodle при отметке персоны как удаленной в справочнике&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Настройки плагина ==&lt;br /&gt;
&lt;br /&gt;
* mdlgroup_name_template&lt;br /&gt;
Шаблон для формирования названия группы в курсе Moodle. По умолчанию имеет значение &amp;quot;{TEACHER_FULLNAME_INITIALS} {AGE_NAME} {CSTREAM_NAME}&amp;quot;, где TEACHER_FULLNAME_INITIALS - фамилия преподавателя с инициалами, AGE_NAME - имя учебного периода, CSTREAM_NAME - название учебного процесса&lt;br /&gt;
&lt;br /&gt;
* unenrol_mode&lt;br /&gt;
Поведение при отписке пользователя от курса. По умолчанию имеет значение &amp;quot;always_unenrol&amp;quot;. Может иметь 2 значения:&lt;br /&gt;
 - always_unenrol - всегда удалять подписку плагина&lt;br /&gt;
 - with_manual_creation_unenrol - заменять подписку плагина на ручную при наличии дополнительных ролей и отсутствии других подписок&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal&amp;diff=3037</id>
		<title>Разработка:im/journal</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal&amp;diff=3037"/>
				<updated>2017-04-13T10:10:30Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: /* Отчеты о фактической нагрузке */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = journal&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
= Классный журнал =&lt;br /&gt;
В журнале можно выставлять оценки и вводить отчет о проведенном уроке.&lt;br /&gt;
== Список занятий ==&lt;br /&gt;
Включает в себя три страницы: информацию о текущем дне, список занятий в целом и поиск занятий по конкретной персоне.&lt;br /&gt;
Каждая страница содержит соответствующую ей навигацию.&lt;br /&gt;
====Список занятий за текущий день====&lt;br /&gt;
При заходе с главной страницы при нажатии на ссылку &amp;quot;Журнал&amp;quot; пользователь попадает именно на эту страницу, с нее начинается работа со списком занятий. &lt;br /&gt;
&lt;br /&gt;
В начале страницы отображается секция навигации, с помощью которой пользователь может перейти на просмотр списка занятий в целом, поиск занятий по персоне или просмотреть отчет по фактической нагрузке.&lt;br /&gt;
&lt;br /&gt;
Далее отображаются все уроки пользователя за сегодняшний день. Если уроков нет секция остается пустой.&lt;br /&gt;
&lt;br /&gt;
После этого отображается секция нагрузки пользователя. В ней пользователь может просмотреть всю информацию о своих табельных нагрузках: подразделение, к которому относится табель, табельный номер, ставка в часах фактическая и указанная и табеле, а также список всех активных учебных процессов, которые преподает пользователь. Каждая табельная нагрузка выводится в отдельной таблице.&lt;br /&gt;
====Список занятий в целом====&lt;br /&gt;
В начале страницы отображается секция навигации, с помощью которой пользователь может вернутся обратно на страницу списка занятий за день, а также перейти на страницу поиска занятий по персоне.&lt;br /&gt;
&lt;br /&gt;
После навигации пользователь видит два календарика, где он может выбрать как один определенный день, так и целый период, за который он хочет просмотреть список занятий. &lt;br /&gt;
&lt;br /&gt;
Далее отображается список занятий за указанный день или период.&lt;br /&gt;
&lt;br /&gt;
====Поиск занятий по персоне====&lt;br /&gt;
&lt;br /&gt;
На этой странице пользователь видит текстовое поле для ввода фамилии (а может даже имени и отчества) персоны и кнопку &amp;quot;Найти&amp;quot;. Если по запросу были найдены персоны, он выведет их в виде списка. Кликнув на искомую персону пользователя перекинет на страницу просмотра списка занятий в целом, но уже по конкретной персоне.&lt;br /&gt;
&lt;br /&gt;
== Журнал группы ==&lt;br /&gt;
Страница принимает обязательный параметр id учебного процесса.&lt;br /&gt;
&lt;br /&gt;
Под панелью навигации выводится надпись &amp;quot;Журнал группы&amp;quot;.&lt;br /&gt;
Ниже таблица с информацией о потоке - программа, предмет, группа, преподаватель. Справа от этой таблицы размещена  ссылка &amp;quot;Новый урок&amp;quot;. Нажатие на нее позволяет создать новый отчет об уроке. Над этой ссылкой будут выводиться сообщения об ошибках сохранения данных из таблицы оценок.&lt;br /&gt;
&lt;br /&gt;
Ниже отображаются две таблицы - таблица оценок и, справа от нее, таблица уроков. Обе таблицы сделаны максимально похожими на соответствующие таблицы в бумажном &amp;quot;Классном журнале&amp;quot;. Таблицы связаны друг с другом, содержат в себе темы с directmap=1&lt;br /&gt;
&lt;br /&gt;
Таблица уроков содержит в себе темы и события связанные с указанным учебным процессом, кроме удаленных. Если же тема не связана с событием или событие не связано с темой они также отображаются в таблице, но без соответствующей информации.&lt;br /&gt;
&lt;br /&gt;
Таблица оценок события и темы отображаются также как и в таблице уроков, кроме замененных событий и событий без тем. Дата в таблице оценок отображаются только в том случае, если для созданной темы создано событие, если у темы события нет, отображается полностью его название. &lt;br /&gt;
&lt;br /&gt;
При нажатии на дату в таблице оценок, происходит перемещение к соответствующей строке отчета об уроке. При нажатии на иконку редактирования отображается форма заполнения оценок и посещаемости.&lt;br /&gt;
&lt;br /&gt;
=== Таблица оценок. ===&lt;br /&gt;
&lt;br /&gt;
Если таблица уроков пуста, то в таблице оценок нет ни одной колонки с датой.&lt;br /&gt;
&lt;br /&gt;
Если журнал заполнен, то в верхней строке отображаются названия месяцев, ниже номера дней месяцев, на которые приходились занятия. Каждое число месяца - ссылка, при нажатии на которую происходит переход на соответствующую этому дню строку таблицы уроков.&lt;br /&gt;
&lt;br /&gt;
Сразу под числом расположен значок редактирования. Он также выполнен в виде ссылки. При нажатии на него страница перезагружается в режиме формы ввода оценок и выставления присутствия учеников на уроке, который проходил в тот день, по значку под числом которого щелкнули.&lt;br /&gt;
&lt;br /&gt;
В колонке этого дня, напротив фамилии каждого ученика появляются три поля. Поле выбора из списка - для проставления оценки, поле переключатель - для отметки присутствия на уроке и поле переключатель - для отметки обучения учащегося на уроке. &lt;br /&gt;
&lt;br /&gt;
В выборе оценок из списка, отображаются те оценки, что прописаны в шкале оценок указанной темы. Если в теме шкала отсутствует, то шкала берется из связанного с темой предмета, если же и там шкалы нет, то задается стандартная от 1 до 5.&lt;br /&gt;
&lt;br /&gt;
Далее отображается галочка &amp;quot;н&amp;quot;, при нажатии на которую учащийся помечается как отсутствующий на уроке. Если же мы хотим указать учащегося как присутствующего галочку просто не ставим. Если кому-то была выставлена и оценка и отметка об отсутствии на уроке, на против его фамилии можно будет увидеть оценку с буквой &amp;quot;н&amp;quot;. Однако перед сохранением будет выведено предупреждение о том, что выставлена оценка отсутствующему ученику. Под уведомлением будут две кнопки - &amp;quot;Продолжить&amp;quot; и &amp;quot;Отменить&amp;quot;. При нажатии на &amp;quot;Продолжить&amp;quot; сценарий сохранения будет выполнен. Нажатие на другую кнопку вызовет отмену процедуры сохранения и возврат к форме с несохраненными изменениями.&lt;br /&gt;
&lt;br /&gt;
Замыкает тройку галочка &amp;quot;н/о&amp;quot;, которая показывает обучался ли учащийся на этом уроке или нет. В отличие от галочки &amp;quot;н&amp;quot;, которая помечает присутствие или отсутствие учащегося на уроке, галочка &amp;quot;н/о&amp;quot; или &amp;quot;не обучался&amp;quot;, что ученик в данный момент времени вообще не обучался на данном уроке по какой-либо причине(начал обучатся не со всеми, закончил обучатся раньше, взял академический отпуск, находится на лечении в санатории или больнице и т.д). Появляется эта галочка только в том случае, если присутствие или отсутствие у учащегося не проставлено.&lt;br /&gt;
&lt;br /&gt;
При переключении в режим формы под таблицей появляется надпись &amp;quot;Внимание! До нажатия кнопки &amp;quot;сохранить&amp;quot; оценки не сохраняются...&amp;quot;, под которой также появится галочка о подтверждения проведения урока и три кнопки - &amp;quot;Сохранить&amp;quot;, &amp;quot;Сохранить и продолжить&amp;quot;, &amp;quot;Восстановить&amp;quot;. &lt;br /&gt;
Нажатие на первую кнопку сохраняет изменения, сделанные в форме и перезагружает страницу в режим просмотра. Вторая - сохраняет сделанные изменения, но страница остается в режиме формы - можно продолжать ввод. Третья кнопка отменяет сделанные изменения. Все введенные,  но несохраненные данные удаляются из формы. Форма перегружается с отображением последних сохраненных изменений.&lt;br /&gt;
&lt;br /&gt;
Если ученику была выставлена оценка, а затем отменена - в форме было выбрано пустое поле, то ранее выбранная оценка будет удалена. Если оценка была изменена, то оценка будет обновлена. Каждое из этих действий, а также выставление статуса присутствия на уроке, будет выполнено через издание приказа.&lt;br /&gt;
Если редактируется контрольная точка без события, то в форме показываеются только поля выставления оценки. Поле присутствия на уроке не показывается и статус присутствия не сохраняется.&lt;br /&gt;
Контрольная точка без события выводится в таблице оценок без даты. Вместо даты выводится название КТ.&lt;br /&gt;
Если пользователь нажал галочку отметки проведения урока, то вместе с приказом о посещаемости событие помечается как состоявшееся.&lt;br /&gt;
&lt;br /&gt;
Что происходит в процессе сохранения.&lt;br /&gt;
После того как нажата одна из кнопок, сохраняющая внесенные изменения происходит&lt;br /&gt;
&lt;br /&gt;
* формирование приказа регистрации присутствия учеников на уроке. В него сохраняются данные о всех учениках потока, их статусы присутствия, id события, статус присутствия на котором выставляется. Также вместе с приказом идет отметка о проведении урока. &lt;br /&gt;
* применение приказа и сохранение статусов учеников в соответствующих таблицах.&lt;br /&gt;
&lt;br /&gt;
Если были выставлены оценки. То в дополнение к вышеописанным действиям происходят следующие действия:&lt;br /&gt;
* формирование приказа регистрации выставления оценок только тем ученикам, которые их получили на уроке. В приказе сохраняются: точное время выставления оценки, id КТ, за которую выставлена оценка, id преподавателя (из /storage/persons), который выставил оценку, ученики, которые получили оценку, и соответствующие им оценки, статус оценки, id подписки ученика на поток.&lt;br /&gt;
* применение приказа и сохранение оценок в соответствующих таблицах.&lt;br /&gt;
&lt;br /&gt;
Примечание: Если у учащегося была проставлена галочка &amp;quot;н/о&amp;quot;, то данные по этому ученику в приказ не сохраняются &lt;br /&gt;
&lt;br /&gt;
После создания отчета об уроке, происходит возврат на главную страницу журнала и таблица оценок загружается в режиме формы того дня, отчет для которого был создан. Если этот день выходит за границы видимости окна, то происходит перемещение таблицы оценок таким образом, чтобы нужная колонка оказалась видимой. После редактирования отчета об уроке таблица оценок загружается в режиме просмотра. Если день, для которого происходило редактирование отчета выходит за границы видимости, то происходит перемещение таблицы оценок таким образом, чтобы нужная колонка оказалась видимой.&lt;br /&gt;
&lt;br /&gt;
=== Таблица уроков. ===&lt;br /&gt;
Представляет собой таблицу из семи столбцов.&lt;br /&gt;
# Порядковый номер урока.&lt;br /&gt;
# Дата проведения урока в формате дд.мм.гг&lt;br /&gt;
# Тема урока. Если отображается событие без темы, данная ячейка пустая.&lt;br /&gt;
# Домашнее задание. Если отображается событие без темы или пользователь ничего не вводил в поле домашнего задания, данная ячейка пустая.&lt;br /&gt;
# Время на домашнее задание. Аналогично со столбцом &amp;quot;Домашнее задание&amp;quot;&lt;br /&gt;
# Примечание. Аналогично со столбцом &amp;quot;Домашнее задание&amp;quot;. На данный момент не используется, ввиду сокращения размеров таблицы &lt;br /&gt;
# Статус урока. Если отображается тема без события, данная ячейка пустая. Если событие зафиксировано как состоявшееся, ниже пишется персона проводившая событие.&lt;br /&gt;
&lt;br /&gt;
Уроки в таблице сортируются по датам, сверху вниз по возрастанию, как и положено в бумажном журнале.&lt;br /&gt;
Под датой располагается значок редактирования информации об уроке, выполненный в виде ссылки. При щелчке по нему открывается новая страница с формой редактирования урока. Все поля формы заполнены соответствующей информацией. Ее можно изменить, а изменения сохранить.&lt;br /&gt;
Эта же страница открывается при щелчке по ссылке &amp;quot;Новый урок&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
=== Страница редактирования урока. ===&lt;br /&gt;
Вверху страницы, под строкой навигации, выводится надпись &amp;quot;Журнал группы&amp;quot;.&lt;br /&gt;
Ниже выводится форма ввода информации об уроке. &lt;br /&gt;
&lt;br /&gt;
Первой отображается секция создания события. Здесь можно выбрать создавать событие или нет (если создается тема без события), если да, то можно выбрать форму проведения урока (очно/дистанционно) и дату проведения. Если событие редактируется, то эти поля изменить нельзя. Если у пользователя нет прав для создания события, то данная секция не отображается.&lt;br /&gt;
&lt;br /&gt;
Следом идет секция для создания темы урока. Сначала мы выбираем как мы создаем тему:&lt;br /&gt;
* Не создавать новую тему - если событие создается без темы&lt;br /&gt;
* Выбрать тему из планирования - если к событию мы привязываем существующую уже созданную тему.&lt;br /&gt;
* Создать собственную тему - создает новую тему на планирование по учебному процессу&lt;br /&gt;
В третьем варианте, при создании новой темы пользователь может либо выбрать родительские темы, откуда он будет наследовать название своей темы (поле &amp;quot;Что пройдено на уроке&amp;quot;, необязательно к заполнению, но пользователь может ввести что-то свое), либо заполнить поле Что пройдено на уроке&amp;quot;. Далее пользователь заполняет все оставшееся поля по мере необходимости.&lt;br /&gt;
&lt;br /&gt;
В самом низу расположены две кнопки - &amp;quot;Сохранить&amp;quot; и &amp;quot;Отмена&amp;quot;. При нажатии на вторую происходит возврат на главную страницу журнала без сохранения внесенных изменений. После нажатия на кнопку &amp;quot;Сохранить&amp;quot; происходит сохранение введенных данных в соответствующих таблицах. О результатах операции сохранения информирует надпись, выводимая под кнопками. Еще ниже появляется ссылка &amp;quot;назад&amp;quot; для возврата на главную страницу журнала. В случае возврата после сохранения данных, таблица оценок загружается в режиме редактирования данных на дату только что сохраненного урока.&lt;br /&gt;
&lt;br /&gt;
Правее формы редактирования урока расположено окно с полосами прокрутки, в котором можно просмотреть темы уже проведенных уроков.&lt;br /&gt;
Они выводятся в видет таблицы из трех столбцов, в которых указываются соответственно дата, тема урока и домашнее задание.&lt;br /&gt;
&lt;br /&gt;
В зависимости от заполненности полей ввода возможны разные варианты обработки введенных данных.&lt;br /&gt;
&lt;br /&gt;
{|border=1&lt;br /&gt;
 |id темы&lt;br /&gt;
 |id события&lt;br /&gt;
 |создание события&lt;br /&gt;
 |создание темы&lt;br /&gt;
 |как обрабатывается&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |ничего не создается&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |ничего не создается. Форма подгружает выбранную тему для редактирования&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы с указанными пользователем данными без события&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |создается новое событие с указанными пользователем данными без темы&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |создается новое событие с указанными пользователем данными и привязкой к выбранной теме&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы и новая темы с указанными пользователем данными связанные друг с другом&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |ничего не создается и не редактируется&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |Выбранная тема привязывается к указанному событию&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы с указанными пользователем данными и привязывается к указанному событию&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |существующая&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |редактируется указанная тема&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |существующая&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |создается новое событие с указанными пользователем данными, к которому привязывается указанная тема. Тему можно отредактировать&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |существующая&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |редактируется указанная тема, событие не редактируется&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
=== Ведомость итоговых оценок ===&lt;br /&gt;
На данной странице можно выставить итоговые оценки учащимся и завершить обучение потока. Страница принимает обязательный параметр id - id идущего  или завершенного потока.&lt;br /&gt;
&lt;br /&gt;
Вверху страныцы отображается форма, где отображены ученики, которые обучаются на данном потоке. Напротив каждого можно выбрать итоговую оценку, выставляемую учащемуся. Итоговые оценки берутся из шкалы дисциплины приписанной к данному потоку. Под ведомостью стоит галочка подтвержения оценок, без нее оценки не сохранятся. Делее стоит галочка завершения обучения если необходимо завершить поток, При завершении потока все подписки на дисциплину переводятся в один из конечных статусов. Если поток уже завершен, то галочка не показывается, вместо нее предупреждение. После завершения потока оценки также можно выставить, но они уже будут идти как переэкзаменовка. &lt;br /&gt;
&lt;br /&gt;
После того как мы выставили оценки и нажали на кнопку сохранить формируется приказ о выставленни итоговых оценок. На основе этого приказа сохраняются оценки, после чего на новой странице показывается шаблон ведомости в том виде, в котом она будет распечатана. &lt;br /&gt;
После первого сохранения оценок эта ведомость также становится доступна для печати. &lt;br /&gt;
&lt;br /&gt;
Перейти на эту страницу можно со страницы Журнала группы.&lt;br /&gt;
&lt;br /&gt;
== Отчеты ==&lt;br /&gt;
=== Отчеты о фактической нагрузке ===&lt;br /&gt;
&lt;br /&gt;
Позволяют просмотреть статистику о нагрузке учителей за определенный период. [[ Разработка:im/reports#Отчеты о фактической нагрузке | Подробнее ]]&lt;br /&gt;
&lt;br /&gt;
Для просмотра отчета по любой персоне необходимо право im/journal view:salfactors.&lt;br /&gt;
&lt;br /&gt;
Для просмотра своего отчета необходимо право im/journal view:salfactors/own.&lt;br /&gt;
&lt;br /&gt;
Для просмотра истории по отчетам (данные сроком более 2 месяцев) необходимо право view:salfactors_history.&lt;br /&gt;
&lt;br /&gt;
=== Отчеты по замененным урокам ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Приказы ==&lt;br /&gt;
=== Приказ о закрытии зарплатного периода ===&lt;br /&gt;
&lt;br /&gt;
==== Структура приказа о закрытии зарплатного периода ====&lt;br /&gt;
Данные приказа:&lt;br /&gt;
* reportid - id сформированного [[ Разработка:im/reports#Отчеты о фактической нагрузке | отчета по фактической нагркзке ]]&lt;br /&gt;
&lt;br /&gt;
==== Формирование приказа о переводе ====&lt;br /&gt;
При формировании приказа также формируется отчет по фактической нагрузке с тем же указанным промежутком и в тоже указанное время исполнение, что и в приказе. &lt;br /&gt;
&lt;br /&gt;
==== Подписание приказа о переводе ====&lt;br /&gt;
Подписание приказа происходит сразу же после его формирование.&lt;br /&gt;
&lt;br /&gt;
=== Исполнение приказа о переводе ===&lt;br /&gt;
По крону. Возможно позже будет реализовано вручную.&lt;br /&gt;
&lt;br /&gt;
Генерирует приказ по фактической нагрузке. После этого фиксирует все дни подразделения и его дочерних подразделений.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== События ==&lt;br /&gt;
* itog_grade_was_set - генерируется во время выставления итоговой оценки не зависимо от того, происходит первичное выставление оценки или повторное через ведомость пересдачи&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Уведомления ==&lt;br /&gt;
&lt;br /&gt;
==== Уведомление учащегося об оценке ====&lt;br /&gt;
&lt;br /&gt;
Отправка уведомлений после выставления оценки в электронном деканате осуществляется в случае, если включена настройка в подразделении.&lt;br /&gt;
&lt;br /&gt;
Для отправки уведомлений об оценке полученной впервые по дисциплине, необходимо установить настройку send_grade_notification в значение 1. В качестве темы письма будет использоваться текст из настройки grade_notification_subject, в качестве основного текста письма будет использована настройка grade_notification_text.&lt;br /&gt;
&lt;br /&gt;
Для отправки уведомления об оценке полученной через ведомость пересдачи, необходимо установить настройку send_reoffset_notification в значение 1. В качестве темы письма будет использоваться текст из настройки reoffset_notification_subject, в качестве основного текста письма будет использована настройка reoffset_notification_text.&lt;br /&gt;
&lt;br /&gt;
В теме и тексте письма можно использовать следующие подстановки:&lt;br /&gt;
* [PERSONFULLNAME] - ФИО учащегося&lt;br /&gt;
* [DISCIPLINE] - Наименование дисциплины&lt;br /&gt;
* [GRADE] - полученная оценка&lt;br /&gt;
&lt;br /&gt;
=Права=&lt;br /&gt;
&lt;br /&gt;
* '''datamanage''' - глобальное право (администратор)&lt;br /&gt;
* '''view_journal''' - право на просмотр журнала учебного процесса (учитель курса или завуч)&lt;br /&gt;
* '''view_all_journals''' - право на просмотр всех журналов (может просматривать общую информацию и личные данные)&lt;br /&gt;
* '''view_all_journals_department''' - право на просмотр всех журналов подразделения (может просматривать общую информацию и личные данные)&lt;br /&gt;
* '''can_complete_lesson''' - право отметить проведение урока (учитель урока или завуч)&lt;br /&gt;
* '''create_schevent''' - право на создание события (завуч и учитель на потоке, если есть переменная в конфиге)&lt;br /&gt;
* '''control_journal''' - право на проверку журнала (завуч)&lt;br /&gt;
* '''give_grade''' - право на выставление оценки (учитель на потоке или завуч)&lt;br /&gt;
* '''give_itog_grades''' - право выставить итоговые оценки (поток завершён и пользователь - учитель на потоке)&lt;br /&gt;
* '''view_events''' - право просматривать свое расписание (учитель)&lt;br /&gt;
* '''give_attendance''' - право на отметку посещаемости (учитель урока или завуч)&lt;br /&gt;
* '''give_theme_event''' - право указать тему для события (только событие в статусе &amp;quot;запланирован&amp;quot; или &amp;quot;отложено на неопределенный срок&amp;quot;, а пользователь - завуч или учитель потока)&lt;br /&gt;
* '''edit_plans''' - право редактировать КТ (КТ не &amp;quot;зафиксирована&amp;quot; и ((КТ завершена или событие состоялось), а пользователь - завуч) или пользователь может выставлять оценки)&lt;br /&gt;
* '''replace_schevent''' - право формирование замены события (учитель на потоке или завуч)&lt;br /&gt;
&lt;br /&gt;
= API =&lt;br /&gt;
В этом разделе описаны функции для работы со страницами &amp;quot;журнал группы&amp;quot; и &amp;quot;список журналов&amp;quot;. Здесь содержится только краткое описание функций и их параметров. Если вас интересует их внутренняя логика, то обратитесь к разделу [[Разработка:im/journal#Подробное описание работы функций|Подробное описание]]. Аргументы всех функций перечислены именно в том порядке, в котором их следует передавать.&lt;br /&gt;
=== Журнал группы ===&lt;br /&gt;
В этом разделе собраны все функции, которые относятся к странице &amp;quot;журнал группы&amp;quot;&lt;br /&gt;
==== Класс dof_im_journal_tablegrades ====&lt;br /&gt;
Класс отрисовки школьного журнала&lt;br /&gt;
===== print_texttable() =====&lt;br /&gt;
Вывести страницу журнала - просмотр оценок, или редактирование&lt;br /&gt;
&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $editid  - id редактируемого учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $eventid - id учебного события, которое будет редактировано (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* null&lt;br /&gt;
===== check_permissions() =====&lt;br /&gt;
Проверяет разрешения на редактирование оценок для текущего пользователя&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true/false - есть или нет разрешения на редактирование оценок&lt;br /&gt;
==== Класс dof_im_journal_templans_table ====&lt;br /&gt;
Класс для отрисовки таблицы тематического планирования в классном журнале&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
 &lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== print_table() =====&lt;br /&gt;
Выводит таблицу тематического планирования на экран&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
*  true если операция вывода прошла успешно, или false если при выводе возникли ошибки&lt;br /&gt;
==== Класс dof_im_journal_edittopic ====&lt;br /&gt;
Класс для создания или редактирования одной темы на странице планирования уроков&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $planid - id элемента учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
* $eventid - id учебного события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== get_topic() =====&lt;br /&gt;
Возвращает объект с полями, необходимыми для заполнения формы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* object - объект с полями для вставки в форму, или false в случае ошибки&lt;br /&gt;
===== create_topic() =====&lt;br /&gt;
Создает новый элемент тематического планирования&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $checkpoint - контрольная точка из таблицы [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $event - заранее заготовленный объект для таблицы [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи из таблицы schevents или false в случае ошибки&lt;br /&gt;
===== save_topic() =====&lt;br /&gt;
Обновляет существующий или создает новый элемент тематического планирования&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $checkpoint (object) - объект для обновления или создания записи в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $event (object) - объект для обновления или создания записи в таблице [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true, если все записи успешно обновлены&lt;br /&gt;
* (int), id новой записи, если она была добавлена&lt;br /&gt;
* false в случае ошибки&lt;br /&gt;
===== print_table() =====&lt;br /&gt;
Формирует таблицу тематического планирования в правой части страницы журнала&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
*  true если операция вывода прошла успешно, или false если при выводе возникли ошибки&lt;br /&gt;
===== get_anchor_id() =====&lt;br /&gt;
Возвращает метку времени, которая будет создана для нового урока, чтобы осуществить корректное перенаправление на страницу журнала&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $time - (int) время создания нового события: метка времени в формате unixtime&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - метка времени для перенаправления&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_rawdata ====&lt;br /&gt;
Класс для подготовки сырых исходных данных для формирования школьного журнала и ему подобных документов&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
Конструктор - определяет с каким учебным потоком будет вестись работа&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_process_gradesform ====&lt;br /&gt;
Класс для проверки и обработки оценок из формы&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
Конструктор класса. Осуществляет все проверки и записывает данные во внутреннее поле.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $gradedata (array) - массив $_POST из формы&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== process_form() =====&lt;br /&gt;
Обработать все данные, пришедшие из формы: установить посещаемость, выставить оценки и сформировать приказы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* false в случае неудачи. В случае успеха производит редирект на страницу журнала&lt;br /&gt;
==== Класс dof_im_journal_presence ====&lt;br /&gt;
Класс для обработки информации о посещаемости &lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== presence_students() =====&lt;br /&gt;
Формирует массив присутствия учеников&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* массив вида [id_ученика]=&amp;gt;статус_присутствия&lt;br /&gt;
===== absence_students() =====&lt;br /&gt;
Формирует массив отсутствующих студентов&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $away - массив id отсутствующих учеников&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* массив вида [id_ученика]=&amp;gt;статус_присутствия&lt;br /&gt;
==== Дополнительные функции ====&lt;br /&gt;
===== dof_im_journal_format_date() =====&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date (int) - метка времення для преобразования.&lt;br /&gt;
* $format (string) - формат выводимой даты. По умолчанию 'dmy'.&lt;br /&gt;
* $url (string) - Указывается, если необходимо получить дату как ссылку. По умолчанию NULL&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) строка с отформатированной датой&lt;br /&gt;
===== dof_im_journal_date_edit() =====&lt;br /&gt;
Возвращает отформатироанную дату и значок редактирования как ссылку&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date (int) - метка времени&lt;br /&gt;
* $format (string) - формат выводимой даты. По умолчанию 'dmy'&lt;br /&gt;
* $durl (string) - путь ссылки для даты, если не указана - дата выводится как просто строка. По умолчанию null.&lt;br /&gt;
* $eurl (string) - путь ссылки для значка, если не указана значок не показывается По умолчанию null.&lt;br /&gt;
* $imgsubdate (bool) - вывести значок под датой или рядом по умолчанию true (выводит значок под датой)&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - строка с отформатированной датой&lt;br /&gt;
=== Список журналов ===&lt;br /&gt;
==== Класс dof_im_journal_listjournals ====&lt;br /&gt;
Этот класс содержит функции для работы со страницей списка журналов&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
===== set_data() =====&lt;br /&gt;
Заполняет начальной информацией внутренние поля объекта&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid (int) - id подразделения (таблица [[Разработка:storages/departments|departments]]). По умолчанию 0.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true если все нормально или false в случае ошибки&lt;br /&gt;
===== get_data() =====&lt;br /&gt;
Возвращает собранные данные&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - массив структурных подразделений&lt;br /&gt;
===== get_journals() =====&lt;br /&gt;
Получить все журнлы занесенных подразделений&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true если все нормально или false в случае ошибки&lt;br /&gt;
&lt;br /&gt;
=== Журнал занятий ===&lt;br /&gt;
==== Класс dof_im_journal_show_events ====&lt;br /&gt;
Этот класс содержит функции для работы с журналом занятий&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $depid - идентификатор подразделения&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
===== set_data =====&lt;br /&gt;
Заполняет параметры класса начальной информацией&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date - массив, состоящий из даты начала и даты окончания:&lt;br /&gt;
** [date_from] - дата начала&lt;br /&gt;
** [date_to] - дата окончания&lt;br /&gt;
* $teacherid - идентификатор преподавателя&lt;br /&gt;
* $studentid - идентификатор студента&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true если операция прошла успешно&lt;br /&gt;
&lt;br /&gt;
===== get_string_event =====&lt;br /&gt;
Получение строки для вывода одного занятия. &lt;br /&gt;
При проверке статуса события, выполняется проверка статуса на момент проведения самого события&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event - объект события&lt;br /&gt;
* $show_all - вывод подробной таблицы&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив для строчки события&lt;br /&gt;
&lt;br /&gt;
===== get_table_events =====&lt;br /&gt;
Возвращает события одного дня&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $display - ражим отображения(по времени, по учителям, по ученикам)&lt;br /&gt;
** [time] - по времени&lt;br /&gt;
** [students] - по ученикам&lt;br /&gt;
** [teachers] - по учителям&lt;br /&gt;
* $show_all - вывод подробной таблицы&lt;br /&gt;
* $implied - вывод мнимых событий&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_table_unmarked_events =====&lt;br /&gt;
Возвращает события одного дня&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $display - ражим отображения(по времени, по учителям, по ученикам)&lt;br /&gt;
** [time] - по времени&lt;br /&gt;
** [students] - по ученикам&lt;br /&gt;
** [teachers] - по учителям&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_string_appointment =====&lt;br /&gt;
Получение строки для вывода одного предмето-класса&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $cstream - объект учебного процесса (предмето-класса)&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив для строчки события&lt;br /&gt;
&lt;br /&gt;
===== get_table_teaching_load =====&lt;br /&gt;
Возвращает учебную нагрузку учителя&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
''Возвращаемые значения:'' array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_data_for_export =====&lt;br /&gt;
Сбор данных для экспорта в csv&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
''Возвращаемые значения:'' &lt;br /&gt;
* array - данные для экспорта&lt;br /&gt;
&lt;br /&gt;
===== get_string_for_export =====&lt;br /&gt;
Создание массива данных об учениках&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event - объект урока&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив с данными&lt;br /&gt;
&lt;br /&gt;
== Подробное описание работы функций ==&lt;br /&gt;
В этом разделе описывается подробная работа всех публичных и внутренних методов для классов журнала. Если вам требуется только краткая справка по API, то обратитесь к разделу [[Разработка:im/journal#API|API]].&lt;br /&gt;
=== Для журнала группы ===&lt;br /&gt;
==== Класс dof_im_journal_tablegrades ====&lt;br /&gt;
&lt;br /&gt;
===== Описание print_texttable() =====&lt;br /&gt;
[[#print_texttable()|Описание API]].&lt;br /&gt;
&lt;br /&gt;
Итоговая функция, выводящая всю собранную информацию на экран. &lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# собирает всю информацию при помощи функции [[Разработка:im/journal#Описание get_all_form()|get_all_form()]]&lt;br /&gt;
# обращается к плагину templater для представления информации в html-формате&lt;br /&gt;
# функцией print выводит результат работы templater'а на экран.&lt;br /&gt;
===== Описание check_permissions() =====&lt;br /&gt;
[[#check_permissions()|Описание API]].&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем учебный поток. Если поток не найден - возвращаем false.&lt;br /&gt;
# проверяем статус учебного потока. Если он не равен значению &amp;quot;go&amp;quot;, то возвращаем false.&lt;br /&gt;
# проверяем, имеет ли текущий пользователь права редактирования. Если нет, то возвращаем false.&lt;br /&gt;
# если все проверки пройдены успешно, то возвращаем true.&lt;br /&gt;
===== Описание get_all_form() =====&lt;br /&gt;
Возвращает объект формы для вставки в templater. Таблица в шаблоне формируется по столбцам, т. е. сначала выводится контрольная точка в тем. планировании, а затем оценки всех учеников за это событие (как при заполнении обычного школьного журнала).&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $editid (int) - id редактируемого учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $eventid (int) - id редактируемого учебного события в таблице [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) объект нужной структуры для построения шаблона&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# собираем в объект все стандартные надписи для таблицы&lt;br /&gt;
# собираем все запланированные активные контрольные точки учебного потока&lt;br /&gt;
# создадим массивы для названий месяцев и дат&lt;br /&gt;
# собираем в массив информацию по ученикам. Если параметр $editid не равен нулю, то в столбце оценок для редактируемой даты вместо оценки выводим форму.&lt;br /&gt;
# собираем в результурующий массив названия месяцев и дат &lt;br /&gt;
# если нужно распечатать форму - устанавливаем стандартные html-теги начала и конца формы&lt;br /&gt;
# возвращаем результат&lt;br /&gt;
&lt;br /&gt;
===== Описание get_cell_form() =====&lt;br /&gt;
Возвращает редактируемую ячейку таблицы журнала.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons.&lt;br /&gt;
* $cpassedid (int) - id учебной программы&lt;br /&gt;
* $oldgrade (int) - старая оценка (если есть). По умолчанию null.&lt;br /&gt;
* $gradeid (int) - id оценки в таблице cpgrades . По умолчанию 0&lt;br /&gt;
* $eventid (int) - id учебного события в таблице [[Разработка:storages/schevents|schevents]].&lt;br /&gt;
* $scale (string) - шкала всех возможных оценок через запятую. По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - строка с html-кодом формы редактирования оценки.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
Вся форма редактирования оценки представляет собой маленькую таблицу. С левой стороны находится форма выбора оценки, а справа галочка для отметки отсутствующего ученика (верхняя ячейка) и пояснение к ней (нижняя ячейка).&lt;br /&gt;
# получаем все допустимые варианты оценок для данного задания из параметра scale.&lt;br /&gt;
# из этих вариантов оценки составляем html-элемент формы типа SELECT.&lt;br /&gt;
# если за задание уже есть ранее выставленная, старая оценка, то делаем ее оценкой по умолчанию&lt;br /&gt;
# узнаем статус присутствия ученика на занятии, и в зависимсости от этого проставляем галочку над буквой &amp;quot;н&amp;quot;. Форма с возможностью отмечания отсутствующих учеников отображается только для контрольных точек для которых есть события.&lt;br /&gt;
# возвращаем результат одной строкой.&lt;br /&gt;
===== Описание get_cell_string() =====&lt;br /&gt;
Получить текстовое содержимое ячейки оценки.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons&lt;br /&gt;
* $plan (object) - объект содержащий данные об элементе тематического планирования (таблица [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $gradedata (object) - данные об оценке По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) html-код оценки, либо специальный знак пробела, чтобы в таблице было видно пустую ячейку&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
# узнаем данные о посещаемости: получаем id события, если оно есть&lt;br /&gt;
#* если событие есть, узнаем, был ли ученик на занятии&lt;br /&gt;
# находим оценку&lt;br /&gt;
#* если ученик был на занятии и получил оценку - выводим оценку&lt;br /&gt;
#* если ученик был на занятии и не получил оценку - выводим символ пробела&lt;br /&gt;
#* если ученик отсутствовал на занятии и нет оценки, то выводим букву &amp;quot;н&amp;quot;&lt;br /&gt;
#* если ученик отсутствовал на занятии и получил оценку - выводим оценку, и букву &amp;quot;н&amp;quot; рядом с ней&lt;br /&gt;
&lt;br /&gt;
===== Описание get_one_cell() =====&lt;br /&gt;
Возвращает данные в одной клетке журнала. Определяет какой тип ячейки выводить: для редактирования или текстовую.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons&lt;br /&gt;
* $plan (object) - объект содержащий контрольную точку с событием  из тем. планирования (таблица [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $gradedata (object) - объект содержащий данные об оценке (таблица cpgrades)&lt;br /&gt;
* $cpassedid (int) - id подписки (таблица cpassed)&lt;br /&gt;
* $editid (int) - id редактируемого в текущий момент элемента из тем. планирования&lt;br /&gt;
* $eventid (int) - id редактируемого в текущий момент события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
* $scale (string) = По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) строка с html-кодом формы редактирования оценки, либо сама оценка, либо статус &amp;quot;отсутствовал&amp;quot;&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# сравниваем, совпадают ли id выводимой и редактируемой в данной момент контрольной точки&lt;br /&gt;
#* если id совпадают - то выводим форму редактирования оценки&lt;br /&gt;
#** если за это задание оценка уже была ранее выставлена, то выводим форму с установленной ранее оценкой&lt;br /&gt;
#** если за задание еще нет оценки - то выводим форму без предустановленных значений&lt;br /&gt;
#* если id не совпадают то выводим оценку текстом (либо статус &amp;quot;отсутствовал&amp;quot;, либо пустую клетку, в зависимости от того был ли ученик на уроке, и получил ли он оценку)&lt;br /&gt;
===== Описание get_line_for_student() =====&lt;br /&gt;
Возвращает строку таблицы журнала для одного ученика.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $i (int) - порядковый номер ученика в группе&lt;br /&gt;
* $student (object) - объект с данными об ученике из таблицы persons&lt;br /&gt;
* $cpasseds (array) - массив объектов, содержащий все подписки учеников этого потока&lt;br /&gt;
* $plans (array) -  массив объектов, содержащий все контрольные точки текущего курса (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $editid (int) - id редактируемой в данный момент контрольной точки&lt;br /&gt;
* $eventid (int) - id редактируемого в данный момент события (или 0, если события нет) Таблица [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - информация об ученике: его ФИО, и оценки по всем контрольным точкам, а также сведения о посещаемости&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект для итоговых данных&lt;br /&gt;
# записываем в соответствующие поля итогового объекта порядковый номер ученика, и его ФИО&lt;br /&gt;
# перебираем все переданные подписки ищем ту, которая относится к переданному ученику&lt;br /&gt;
# записываем в итоговый объект id его подписки&lt;br /&gt;
# создаем массив для оценок и собираем оценки ученика:&lt;br /&gt;
#* перебираем все контрольные переданные точки ($plans)&lt;br /&gt;
#* для каждой контрольной точки создаем объект оценки&lt;br /&gt;
#* получаем значение оценки за просматриваемую контрольную точку&lt;br /&gt;
#* при помощи функции [[Разработка:im/journal#Описание get_one_cell()|get_one_cell()]] получаем оформленный html-код оценки&lt;br /&gt;
#* записываем полученный объект в массив оценок&lt;br /&gt;
# добавляем массив оценок в итоговый объект&lt;br /&gt;
# возвращаем итоговый объект&lt;br /&gt;
===== Описание get_lines_for_students() =====&lt;br /&gt;
Возвращает массив строк с ФИО и оценками для всех учеников&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans (array) - массив всех контрольных точек учебного потока из таблицы plans&lt;br /&gt;
* $editid (int) - id редактируемой в данный момент контрольной точки (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $eventid (int) - id редактируемого в данный момент события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) информация о всех учениках учебного потока или false, если ни одного ученика нет&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все подписки учебного потока, чтобы потом установить связи с оценками&lt;br /&gt;
# получаем учеников учебного потока&lt;br /&gt;
# присваиваем каждому ученику порядковый номер,&lt;br /&gt;
# получаем информацию по каждому ученику функцией [[#Описание get_line_for_student()|get_line_for_student()]] и заносим объект с информацией о нем в массив&lt;br /&gt;
# возвращаем получившийся массив &lt;br /&gt;
===== Описание create_datesstring() =====&lt;br /&gt;
Создает верхнюю строку журнала с названиями месяцев и списком дат в пригодном для обработки плагином templater виде.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans - список всех контрольных точек учебного потока из таблицы [[Разработка:storages/plans|plans]].&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект, содержащий массив с данными для шаблонизатора&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
Даты в электронном журнале должны будут проставляться как и в обычном классном журнале: верхняя строка - месяцы обучения, нижняя строка - даты проведенных или запланированных уроков, а также четвертные или годовые оценки.&lt;br /&gt;
Для того чтобы организовать такой внешний вид для электронного журнала мы должны воспользоваться параметром colspan для html-таблицы журнала, и расположить тем самым месяцы точно над датами проведенных уроков. Для этой задачи в этой функции мы создаем объект следующей структуры:&lt;br /&gt;
* ''(возвращаемый объект)''&lt;br /&gt;
** ''monthtitle'' - массив объектов, каждый из которых имеет свойства ''mtitle'' - название месяца, и ''mcolspan'' - количество ячеек с датами проведенных уроков в этом месяце&lt;br /&gt;
** ''monthdate'' - строка с датой проведенного урока, либо название контрольной точки.&lt;br /&gt;
&lt;br /&gt;
# получаем строку форматированных дат уроков при помощи функции [[#Описание generate_all_dates()|generate_all_dates()]]&lt;br /&gt;
# перебираем все события и собираем массивы дат и названий месяцев&lt;br /&gt;
#* если просматриваемая дата не находится в том же месяце, что и предыдущая, то дополняем массив месяцев&lt;br /&gt;
# прибавляем счетчик дат в месяце&lt;br /&gt;
# записываем новую дату в итоговый массив&lt;br /&gt;
# возвращаем итоговый массив&lt;br /&gt;
===== Описание generate_all_dates() =====&lt;br /&gt;
Вызывается из [[#Описание create_datesstring()|create_datesstring()]]. Получить отформатированные даты для журнала&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans - массив всех контрольных точек учебного потока (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - отформатированные даты для вывода в журнал&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получим событие из таблицы schevents, которое относится к данной теме тематического планирования&lt;br /&gt;
# если событие есть - то покажем дату&lt;br /&gt;
# если события нет - только название контрольной точки&lt;br /&gt;
&lt;br /&gt;
===== Описание generate_single_date() =====&lt;br /&gt;
Вызывается из [[#Описание generate_all_dates|generate_all_dates]] Создает один объект даты для журнала.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plan (object) - объект из таблицы [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $date (string) - метка времени для события или контрольной точки&lt;br /&gt;
* $event (object) - Объект из таблицы [[Разработка:storages/schevents|schevents]]. По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) дата в нужном для templater'a формате&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# устанавливаем путь (html-якорь) к теме в планирования на странице&lt;br /&gt;
# Определяем, id события которое будет редактировано. Если события нет, то передаем 0.&lt;br /&gt;
# записываем якорь с ссылкой в объект&lt;br /&gt;
# возвращаем объект&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_templans_table ====&lt;br /&gt;
===== Описание get_topics() =====&lt;br /&gt;
Возвращает массив объектов c необходимыми свойствами для вставки в таблицу schevents&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив тем входящих в планирование&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все контрольные точки учебного потока&lt;br /&gt;
# формируем объект с нужными полями для каждой контрольной точки&lt;br /&gt;
# возвращаем получившийся массив объектов&lt;br /&gt;
===== Описание get_empty_topic() =====&lt;br /&gt;
Возвращает &amp;quot;пустой&amp;quot; объект отчета об уроке &lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект для вставки в таблицу [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* создаем объект с необходимым списком пустых полей и возвращаем его&lt;br /&gt;
===== Описание table_data() =====&lt;br /&gt;
Возвращает массив строк данных отформатированных для вывода с помощью moodle-функции print_table()&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив с данными для распечатки таблицы, либо false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли для переданного потока элементы тематического планирования.&lt;br /&gt;
#* если их нет - то возвращаем false&lt;br /&gt;
# формируем массив строк таблицы&lt;br /&gt;
# проставляем html-якоря для каждой контрольной точки на странице оценок&lt;br /&gt;
# добавляем ссылки на редактирования элементов учебного плана&lt;br /&gt;
# возвращаем получившийся массив&lt;br /&gt;
==== Класс dof_im_journal_edittopic ====&lt;br /&gt;
===== Описание get_topic() =====&lt;br /&gt;
[[#get_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* Проверяем, указан ли id контрольной точки. &lt;br /&gt;
** Если не указан - возврящаем пустую тему.&lt;br /&gt;
** Если указан - пробуем извлечь контрольную точку по такому id&lt;br /&gt;
*** Если контрольную точку извлечь не удалось - то возвращаем false&lt;br /&gt;
*** Если удалось - то возвращаем заполненный отчет об уроке&lt;br /&gt;
===== Описание save_topic() =====&lt;br /&gt;
[[#save_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем есть ли у нас данные в переменной $event для обновления или создания события. Если нет - то возвращаем false.&lt;br /&gt;
# определяем тип действия, которое надо совершить&lt;br /&gt;
#* если указан planid для события - то создаем новое событие для существующей контрольной точки&lt;br /&gt;
#* если нет id для контрольной точки - создаем новое событие и новую контрольную точку&lt;br /&gt;
#* в остальных случаях - обновляем контрольную точку и событие: вычисляем новую относительную дату, и обновляем записи в таблицах [[Разработка:storages/schevents|schevents]] и [[Разработка:storages/plans|plans]]&lt;br /&gt;
===== Описание create_topic() =====&lt;br /&gt;
[[#create_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем новый элемент тематического планирования в таблице plans (если это не удалось - то возвращаем false)&lt;br /&gt;
# добавляем в переданное событие id контрольной точки&lt;br /&gt;
# создаем событие из переданного объекта $event (если событие не создано - удаляем ранее созданный элемент тематического планирования)&lt;br /&gt;
# возвращаем id события&lt;br /&gt;
===== Описание create_checkpoint() =====&lt;br /&gt;
Создает и сохраняет запись в таблице plans&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $point (object) - данные для сохранения в таблицу [[Разработка:storages/plans|plans]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи или false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли у нас все необходимые для создания записи&lt;br /&gt;
# получаем id учебного потока&lt;br /&gt;
# получаем дату начала обучения&lt;br /&gt;
# создаем заготовку для объекта контрольной точки&lt;br /&gt;
# вычисляем относительную дату контрольной точки&lt;br /&gt;
# заносим данные в базу&lt;br /&gt;
===== Описание create_event() =====&lt;br /&gt;
Создает объект события и сохраняет его в schevents&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event (object) - данные для сохранения&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи в таблице событий или false.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли у нас все необходимые для создания записи&lt;br /&gt;
# получаем id учебного потока&lt;br /&gt;
# получаем id преподавателя в таблице persons&lt;br /&gt;
# создаем объект нужного формата и заносим туда все данные&lt;br /&gt;
# записываем данные в базу&lt;br /&gt;
==== Класс dof_im_journal_rawdata ====&lt;br /&gt;
''Поля:''&lt;br /&gt;
* dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* csid - id учебного потока в таблице сstreams&lt;br /&gt;
===== Описание get_checkpoints() =====&lt;br /&gt;
Получить все контрольные точки одного учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - массив объектов из таблицы plans или false &lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем id учебного потока из таблицы cstreams&lt;br /&gt;
# выбираем из таблицы plans все записи, у которых поле cstreamid равно id учебного потока, и тип связи &amp;quot;cstreams&amp;quot;&lt;br /&gt;
# сортируем их в хронологическом порядке&lt;br /&gt;
# возвращаем получившийся массив&lt;br /&gt;
&lt;br /&gt;
===== Описание get_students() =====&lt;br /&gt;
Получить всех учеников указанного учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив записей из таблицы persons или false&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем список пройденных дисциплин&lt;br /&gt;
# перебираем все подписки и запоминаем id ученика для каждой из них&lt;br /&gt;
# извлекаем из таблицы persons учеников, чьи id были извлечены из подписок&lt;br /&gt;
&lt;br /&gt;
===== Описание get_teacherid() =====&lt;br /&gt;
Получить id преподавателя учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id преподавателя или false в случае неудачи&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* id преподавателя всегда берется только из записи учебного потока из таблицы cstreams&lt;br /&gt;
==== Класс dof_im_journal_process_gradesform ====&lt;br /&gt;
''Поля:''&lt;br /&gt;
* gradedata - (object) все оценки и сопутствующая им информация&lt;br /&gt;
* mypost - (array) непроверенные данные пришедшие из массива $_POST. Используются только для составления повторного запроса на сохранение данных.&lt;br /&gt;
===== Описание __construct =====&lt;br /&gt;
[[#Класс dof_im_journal_rawdata|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект, в который мы будем складывать все проверенные данные, пришедшие из формы&lt;br /&gt;
# проверяем скалярные данные: все числовые идентификаторы, и отдельные строки, и после проверки записываем их в итоговый объект&lt;br /&gt;
# теперь, зная cstreamid из проверенных скалярных данных вызываем родительский конструктор&lt;br /&gt;
# проверяем массивы, пришедшие из формы: &lt;br /&gt;
#* данные об отсутствующих учениках&lt;br /&gt;
#* массив оценок &lt;br /&gt;
#* массив идентификаторов подписок (таблица cpassed)&lt;br /&gt;
#* узнаем id оценок для изменения их статуса&lt;br /&gt;
# записываем все проверенные данные в итоговый массив&lt;br /&gt;
# определяем тип действия, которое надо совершить: &lt;br /&gt;
#* сохранить данные&lt;br /&gt;
#* сохранить данные и продолжить редактирование&lt;br /&gt;
#* восстановить исходные значения&lt;br /&gt;
# записываем исходный массив (непроверенный) в поле объекта, если потом понадобится еще раз отправить данные после подтверждения&lt;br /&gt;
===== Описание process_form() =====&lt;br /&gt;
[[#process_form()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# в самом начале проверяем тип действия, которое надо совершить. Если этим действием является &amp;quot;отменить изменения&amp;quot;, то не переходим к сохранению оценок и сразуже выполняем перенаправление на страницу журнала. В остальных случаях идем дальше:&lt;br /&gt;
# проверяем, установлено ли у кого-нибудь из учеников одновременно &amp;quot;н&amp;quot; и оценка. Если это так - то перенаправим пользователя на страницу с сообщением об этом, и попросим его подтвердить такой выбор.&lt;br /&gt;
#* если пользователь согласен с изменениями, которые он сделал, то все выставленые им оценки и сведения о посещаемости сохраняются&lt;br /&gt;
#* если же нет - то происходит отмена всех изменений&lt;br /&gt;
# в случае, когда никаких предупреждений нет - сначала формируем приказ для оценок&lt;br /&gt;
# затем приказ о посещаемости&lt;br /&gt;
# если все действия произведены успешно - производим редирект. Если же возникли ошибки - сообщаем об этом&lt;br /&gt;
&lt;br /&gt;
===== Описание generate_order_grades() =====&lt;br /&gt;
Сформировать приказ об изменении состояния учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true если приказ успешно сформирован, и false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем id подразделения в таблице departments&lt;br /&gt;
# определяем тип действия, которое нужно совершить с оценкой&lt;br /&gt;
# обращаемся к функциям выставления, либо удаления оценки&lt;br /&gt;
===== Описание order_set_grade() =====&lt;br /&gt;
Формирует приказ - установить оценку. &lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid (int) - id подразделения в таблице [[Разработка:storages/departments|departments]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true в случае успеха и false в случае неудачи&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# подключаем методы работы с приказом&lt;br /&gt;
# создаем объект для записи&lt;br /&gt;
# сохраняем автора приказа, подразделение, к которому он относится, дату создания приказа&lt;br /&gt;
# добавляем данные, которые определяют назначение приказа&lt;br /&gt;
# сохраняем приказ в БД, в таблицу orders&lt;br /&gt;
# подписываем приказ&lt;br /&gt;
# исполняем приказ&lt;br /&gt;
Методы order_delete_grade и order_update_grade работают по такому же принципу.&lt;br /&gt;
===== Описание get_grades_fororder() =====&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $type - тип действия, которое необходимо будет произвести над оценкой. Возможные значения: ''set_grade'' и ''delete_grade''.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект, содержащий список оценок и все идентификаторы для формирования приказа.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект для итоговых данных&lt;br /&gt;
# записываем в него дату, id учителя (в таблице persons) и id контрольной точки (в таблице plans&lt;br /&gt;
# перебираем все оценки из внутреннего массива с проверенными данными&lt;br /&gt;
# определяем тип действия, которое над ней нужно совершить&lt;br /&gt;
# в зависимости от типа действия (установление или удаление оценки) записываем в объект оценки нужные идентификаторы&lt;br /&gt;
# упаковываем оценки в итоговый массив и возвращаем его&lt;br /&gt;
=== Для списка журналов ===&lt;br /&gt;
==== Класс dof_im_journal_listjournals ====&lt;br /&gt;
Этот класс служит для сбора и вывода информации по всем структурным подразделениям. Информация выводится древовидно: самый верхний уровень - подразделение, затем учебные программы, затем учебные периоды, элементы учебной программы, и в самом конце - журналы учебного потока.&lt;br /&gt;
''Поля:''&lt;br /&gt;
* dof - - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $departments массив структуры&lt;br /&gt;
    array(&lt;br /&gt;
    [departmentid] =&amp;gt; obj  -&amp;gt; departmentname = 'department_name'&lt;br /&gt;
                      obj  -&amp;gt; programms = array(&lt;br /&gt;
      [programmid]   =&amp;gt; obj1 -&amp;gt; programmname = 'programm_name'&lt;br /&gt;
                        obj1 -&amp;gt; ages = array(&lt;br /&gt;
        [agenum]       =&amp;gt; obj2 -&amp;gt; agename = 'age_name'&lt;br /&gt;
                          obj2 -&amp;gt; items = array(&lt;br /&gt;
          [itemid]       =&amp;gt; obj3 -&amp;gt; itemname = 'item_name'&lt;br /&gt;
                            obj3 -&amp;gt; cstreams = array(&lt;br /&gt;
            [cstreamid]    =&amp;gt; obj4 -&amp;gt; cstreamname = 'cstream_name'&lt;br /&gt;
                                    )''// конец массива cstreams''&lt;br /&gt;
                                  )''// конец массива items''&lt;br /&gt;
                                )''// конец массива ages''&lt;br /&gt;
                              )''// конец массива programms''&lt;br /&gt;
         )''// конец общего массива''&lt;br /&gt;
    содержит данные для вставку в темплатер после добавления еще одного уровня:&lt;br /&gt;
    $fortemplater-&amp;gt;departments = $this-&amp;gt;departments;&lt;br /&gt;
В общем виде сбор данных выглядит так: &lt;br /&gt;
# сначала собирается информация по структурному подразделению (одному или нескольким), и информация по ним записывается в итоговый объект&lt;br /&gt;
# затем получаются все программы учебного подразделения, информация по ним записывается в итоговый массив&lt;br /&gt;
# извлекается и записывается в итоговый объект список учебных периодов &lt;br /&gt;
# для каждого учебного периода получаются элементы учебной программы, которые изучаются в нем&lt;br /&gt;
# для каждого элемента учебной программы получаются учебные потоки&lt;br /&gt;
# для каждого учебного потока получается его журнал&lt;br /&gt;
===== Описание set_data() =====&lt;br /&gt;
[[#set_data()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* получаем id структурного подразделения из таблицы departments.&lt;br /&gt;
** если оно есть - то получаем информацию только по нему&lt;br /&gt;
** если получили 0 вместо id подразделения - то выводим информацию по всем подразделениям&lt;br /&gt;
&lt;br /&gt;
===== Описание get_journals_department() =====&lt;br /&gt;
Возвращает журналы одного подразделения&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid - id подразделения в таблице [[Разработка:storages/departments|departments]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - набор журналов &lt;br /&gt;
* (bool) - false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все программы, за которые отвечает подразделение&lt;br /&gt;
# для каждой программы получаем все ее журналы&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal&amp;diff=3036</id>
		<title>Разработка:im/journal</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal&amp;diff=3036"/>
				<updated>2017-04-13T10:10:03Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: /* Отчеты о фактической нагрузке */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = journal&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
= Классный журнал =&lt;br /&gt;
В журнале можно выставлять оценки и вводить отчет о проведенном уроке.&lt;br /&gt;
== Список занятий ==&lt;br /&gt;
Включает в себя три страницы: информацию о текущем дне, список занятий в целом и поиск занятий по конкретной персоне.&lt;br /&gt;
Каждая страница содержит соответствующую ей навигацию.&lt;br /&gt;
====Список занятий за текущий день====&lt;br /&gt;
При заходе с главной страницы при нажатии на ссылку &amp;quot;Журнал&amp;quot; пользователь попадает именно на эту страницу, с нее начинается работа со списком занятий. &lt;br /&gt;
&lt;br /&gt;
В начале страницы отображается секция навигации, с помощью которой пользователь может перейти на просмотр списка занятий в целом, поиск занятий по персоне или просмотреть отчет по фактической нагрузке.&lt;br /&gt;
&lt;br /&gt;
Далее отображаются все уроки пользователя за сегодняшний день. Если уроков нет секция остается пустой.&lt;br /&gt;
&lt;br /&gt;
После этого отображается секция нагрузки пользователя. В ней пользователь может просмотреть всю информацию о своих табельных нагрузках: подразделение, к которому относится табель, табельный номер, ставка в часах фактическая и указанная и табеле, а также список всех активных учебных процессов, которые преподает пользователь. Каждая табельная нагрузка выводится в отдельной таблице.&lt;br /&gt;
====Список занятий в целом====&lt;br /&gt;
В начале страницы отображается секция навигации, с помощью которой пользователь может вернутся обратно на страницу списка занятий за день, а также перейти на страницу поиска занятий по персоне.&lt;br /&gt;
&lt;br /&gt;
После навигации пользователь видит два календарика, где он может выбрать как один определенный день, так и целый период, за который он хочет просмотреть список занятий. &lt;br /&gt;
&lt;br /&gt;
Далее отображается список занятий за указанный день или период.&lt;br /&gt;
&lt;br /&gt;
====Поиск занятий по персоне====&lt;br /&gt;
&lt;br /&gt;
На этой странице пользователь видит текстовое поле для ввода фамилии (а может даже имени и отчества) персоны и кнопку &amp;quot;Найти&amp;quot;. Если по запросу были найдены персоны, он выведет их в виде списка. Кликнув на искомую персону пользователя перекинет на страницу просмотра списка занятий в целом, но уже по конкретной персоне.&lt;br /&gt;
&lt;br /&gt;
== Журнал группы ==&lt;br /&gt;
Страница принимает обязательный параметр id учебного процесса.&lt;br /&gt;
&lt;br /&gt;
Под панелью навигации выводится надпись &amp;quot;Журнал группы&amp;quot;.&lt;br /&gt;
Ниже таблица с информацией о потоке - программа, предмет, группа, преподаватель. Справа от этой таблицы размещена  ссылка &amp;quot;Новый урок&amp;quot;. Нажатие на нее позволяет создать новый отчет об уроке. Над этой ссылкой будут выводиться сообщения об ошибках сохранения данных из таблицы оценок.&lt;br /&gt;
&lt;br /&gt;
Ниже отображаются две таблицы - таблица оценок и, справа от нее, таблица уроков. Обе таблицы сделаны максимально похожими на соответствующие таблицы в бумажном &amp;quot;Классном журнале&amp;quot;. Таблицы связаны друг с другом, содержат в себе темы с directmap=1&lt;br /&gt;
&lt;br /&gt;
Таблица уроков содержит в себе темы и события связанные с указанным учебным процессом, кроме удаленных. Если же тема не связана с событием или событие не связано с темой они также отображаются в таблице, но без соответствующей информации.&lt;br /&gt;
&lt;br /&gt;
Таблица оценок события и темы отображаются также как и в таблице уроков, кроме замененных событий и событий без тем. Дата в таблице оценок отображаются только в том случае, если для созданной темы создано событие, если у темы события нет, отображается полностью его название. &lt;br /&gt;
&lt;br /&gt;
При нажатии на дату в таблице оценок, происходит перемещение к соответствующей строке отчета об уроке. При нажатии на иконку редактирования отображается форма заполнения оценок и посещаемости.&lt;br /&gt;
&lt;br /&gt;
=== Таблица оценок. ===&lt;br /&gt;
&lt;br /&gt;
Если таблица уроков пуста, то в таблице оценок нет ни одной колонки с датой.&lt;br /&gt;
&lt;br /&gt;
Если журнал заполнен, то в верхней строке отображаются названия месяцев, ниже номера дней месяцев, на которые приходились занятия. Каждое число месяца - ссылка, при нажатии на которую происходит переход на соответствующую этому дню строку таблицы уроков.&lt;br /&gt;
&lt;br /&gt;
Сразу под числом расположен значок редактирования. Он также выполнен в виде ссылки. При нажатии на него страница перезагружается в режиме формы ввода оценок и выставления присутствия учеников на уроке, который проходил в тот день, по значку под числом которого щелкнули.&lt;br /&gt;
&lt;br /&gt;
В колонке этого дня, напротив фамилии каждого ученика появляются три поля. Поле выбора из списка - для проставления оценки, поле переключатель - для отметки присутствия на уроке и поле переключатель - для отметки обучения учащегося на уроке. &lt;br /&gt;
&lt;br /&gt;
В выборе оценок из списка, отображаются те оценки, что прописаны в шкале оценок указанной темы. Если в теме шкала отсутствует, то шкала берется из связанного с темой предмета, если же и там шкалы нет, то задается стандартная от 1 до 5.&lt;br /&gt;
&lt;br /&gt;
Далее отображается галочка &amp;quot;н&amp;quot;, при нажатии на которую учащийся помечается как отсутствующий на уроке. Если же мы хотим указать учащегося как присутствующего галочку просто не ставим. Если кому-то была выставлена и оценка и отметка об отсутствии на уроке, на против его фамилии можно будет увидеть оценку с буквой &amp;quot;н&amp;quot;. Однако перед сохранением будет выведено предупреждение о том, что выставлена оценка отсутствующему ученику. Под уведомлением будут две кнопки - &amp;quot;Продолжить&amp;quot; и &amp;quot;Отменить&amp;quot;. При нажатии на &amp;quot;Продолжить&amp;quot; сценарий сохранения будет выполнен. Нажатие на другую кнопку вызовет отмену процедуры сохранения и возврат к форме с несохраненными изменениями.&lt;br /&gt;
&lt;br /&gt;
Замыкает тройку галочка &amp;quot;н/о&amp;quot;, которая показывает обучался ли учащийся на этом уроке или нет. В отличие от галочки &amp;quot;н&amp;quot;, которая помечает присутствие или отсутствие учащегося на уроке, галочка &amp;quot;н/о&amp;quot; или &amp;quot;не обучался&amp;quot;, что ученик в данный момент времени вообще не обучался на данном уроке по какой-либо причине(начал обучатся не со всеми, закончил обучатся раньше, взял академический отпуск, находится на лечении в санатории или больнице и т.д). Появляется эта галочка только в том случае, если присутствие или отсутствие у учащегося не проставлено.&lt;br /&gt;
&lt;br /&gt;
При переключении в режим формы под таблицей появляется надпись &amp;quot;Внимание! До нажатия кнопки &amp;quot;сохранить&amp;quot; оценки не сохраняются...&amp;quot;, под которой также появится галочка о подтверждения проведения урока и три кнопки - &amp;quot;Сохранить&amp;quot;, &amp;quot;Сохранить и продолжить&amp;quot;, &amp;quot;Восстановить&amp;quot;. &lt;br /&gt;
Нажатие на первую кнопку сохраняет изменения, сделанные в форме и перезагружает страницу в режим просмотра. Вторая - сохраняет сделанные изменения, но страница остается в режиме формы - можно продолжать ввод. Третья кнопка отменяет сделанные изменения. Все введенные,  но несохраненные данные удаляются из формы. Форма перегружается с отображением последних сохраненных изменений.&lt;br /&gt;
&lt;br /&gt;
Если ученику была выставлена оценка, а затем отменена - в форме было выбрано пустое поле, то ранее выбранная оценка будет удалена. Если оценка была изменена, то оценка будет обновлена. Каждое из этих действий, а также выставление статуса присутствия на уроке, будет выполнено через издание приказа.&lt;br /&gt;
Если редактируется контрольная точка без события, то в форме показываеются только поля выставления оценки. Поле присутствия на уроке не показывается и статус присутствия не сохраняется.&lt;br /&gt;
Контрольная точка без события выводится в таблице оценок без даты. Вместо даты выводится название КТ.&lt;br /&gt;
Если пользователь нажал галочку отметки проведения урока, то вместе с приказом о посещаемости событие помечается как состоявшееся.&lt;br /&gt;
&lt;br /&gt;
Что происходит в процессе сохранения.&lt;br /&gt;
После того как нажата одна из кнопок, сохраняющая внесенные изменения происходит&lt;br /&gt;
&lt;br /&gt;
* формирование приказа регистрации присутствия учеников на уроке. В него сохраняются данные о всех учениках потока, их статусы присутствия, id события, статус присутствия на котором выставляется. Также вместе с приказом идет отметка о проведении урока. &lt;br /&gt;
* применение приказа и сохранение статусов учеников в соответствующих таблицах.&lt;br /&gt;
&lt;br /&gt;
Если были выставлены оценки. То в дополнение к вышеописанным действиям происходят следующие действия:&lt;br /&gt;
* формирование приказа регистрации выставления оценок только тем ученикам, которые их получили на уроке. В приказе сохраняются: точное время выставления оценки, id КТ, за которую выставлена оценка, id преподавателя (из /storage/persons), который выставил оценку, ученики, которые получили оценку, и соответствующие им оценки, статус оценки, id подписки ученика на поток.&lt;br /&gt;
* применение приказа и сохранение оценок в соответствующих таблицах.&lt;br /&gt;
&lt;br /&gt;
Примечание: Если у учащегося была проставлена галочка &amp;quot;н/о&amp;quot;, то данные по этому ученику в приказ не сохраняются &lt;br /&gt;
&lt;br /&gt;
После создания отчета об уроке, происходит возврат на главную страницу журнала и таблица оценок загружается в режиме формы того дня, отчет для которого был создан. Если этот день выходит за границы видимости окна, то происходит перемещение таблицы оценок таким образом, чтобы нужная колонка оказалась видимой. После редактирования отчета об уроке таблица оценок загружается в режиме просмотра. Если день, для которого происходило редактирование отчета выходит за границы видимости, то происходит перемещение таблицы оценок таким образом, чтобы нужная колонка оказалась видимой.&lt;br /&gt;
&lt;br /&gt;
=== Таблица уроков. ===&lt;br /&gt;
Представляет собой таблицу из семи столбцов.&lt;br /&gt;
# Порядковый номер урока.&lt;br /&gt;
# Дата проведения урока в формате дд.мм.гг&lt;br /&gt;
# Тема урока. Если отображается событие без темы, данная ячейка пустая.&lt;br /&gt;
# Домашнее задание. Если отображается событие без темы или пользователь ничего не вводил в поле домашнего задания, данная ячейка пустая.&lt;br /&gt;
# Время на домашнее задание. Аналогично со столбцом &amp;quot;Домашнее задание&amp;quot;&lt;br /&gt;
# Примечание. Аналогично со столбцом &amp;quot;Домашнее задание&amp;quot;. На данный момент не используется, ввиду сокращения размеров таблицы &lt;br /&gt;
# Статус урока. Если отображается тема без события, данная ячейка пустая. Если событие зафиксировано как состоявшееся, ниже пишется персона проводившая событие.&lt;br /&gt;
&lt;br /&gt;
Уроки в таблице сортируются по датам, сверху вниз по возрастанию, как и положено в бумажном журнале.&lt;br /&gt;
Под датой располагается значок редактирования информации об уроке, выполненный в виде ссылки. При щелчке по нему открывается новая страница с формой редактирования урока. Все поля формы заполнены соответствующей информацией. Ее можно изменить, а изменения сохранить.&lt;br /&gt;
Эта же страница открывается при щелчке по ссылке &amp;quot;Новый урок&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
=== Страница редактирования урока. ===&lt;br /&gt;
Вверху страницы, под строкой навигации, выводится надпись &amp;quot;Журнал группы&amp;quot;.&lt;br /&gt;
Ниже выводится форма ввода информации об уроке. &lt;br /&gt;
&lt;br /&gt;
Первой отображается секция создания события. Здесь можно выбрать создавать событие или нет (если создается тема без события), если да, то можно выбрать форму проведения урока (очно/дистанционно) и дату проведения. Если событие редактируется, то эти поля изменить нельзя. Если у пользователя нет прав для создания события, то данная секция не отображается.&lt;br /&gt;
&lt;br /&gt;
Следом идет секция для создания темы урока. Сначала мы выбираем как мы создаем тему:&lt;br /&gt;
* Не создавать новую тему - если событие создается без темы&lt;br /&gt;
* Выбрать тему из планирования - если к событию мы привязываем существующую уже созданную тему.&lt;br /&gt;
* Создать собственную тему - создает новую тему на планирование по учебному процессу&lt;br /&gt;
В третьем варианте, при создании новой темы пользователь может либо выбрать родительские темы, откуда он будет наследовать название своей темы (поле &amp;quot;Что пройдено на уроке&amp;quot;, необязательно к заполнению, но пользователь может ввести что-то свое), либо заполнить поле Что пройдено на уроке&amp;quot;. Далее пользователь заполняет все оставшееся поля по мере необходимости.&lt;br /&gt;
&lt;br /&gt;
В самом низу расположены две кнопки - &amp;quot;Сохранить&amp;quot; и &amp;quot;Отмена&amp;quot;. При нажатии на вторую происходит возврат на главную страницу журнала без сохранения внесенных изменений. После нажатия на кнопку &amp;quot;Сохранить&amp;quot; происходит сохранение введенных данных в соответствующих таблицах. О результатах операции сохранения информирует надпись, выводимая под кнопками. Еще ниже появляется ссылка &amp;quot;назад&amp;quot; для возврата на главную страницу журнала. В случае возврата после сохранения данных, таблица оценок загружается в режиме редактирования данных на дату только что сохраненного урока.&lt;br /&gt;
&lt;br /&gt;
Правее формы редактирования урока расположено окно с полосами прокрутки, в котором можно просмотреть темы уже проведенных уроков.&lt;br /&gt;
Они выводятся в видет таблицы из трех столбцов, в которых указываются соответственно дата, тема урока и домашнее задание.&lt;br /&gt;
&lt;br /&gt;
В зависимости от заполненности полей ввода возможны разные варианты обработки введенных данных.&lt;br /&gt;
&lt;br /&gt;
{|border=1&lt;br /&gt;
 |id темы&lt;br /&gt;
 |id события&lt;br /&gt;
 |создание события&lt;br /&gt;
 |создание темы&lt;br /&gt;
 |как обрабатывается&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |ничего не создается&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |ничего не создается. Форма подгружает выбранную тему для редактирования&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы с указанными пользователем данными без события&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |создается новое событие с указанными пользователем данными без темы&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |создается новое событие с указанными пользователем данными и привязкой к выбранной теме&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы и новая темы с указанными пользователем данными связанные друг с другом&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |ничего не создается и не редактируется&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |Выбранная тема привязывается к указанному событию&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы с указанными пользователем данными и привязывается к указанному событию&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |существующая&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |редактируется указанная тема&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |существующая&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |создается новое событие с указанными пользователем данными, к которому привязывается указанная тема. Тему можно отредактировать&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |существующая&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |редактируется указанная тема, событие не редактируется&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
=== Ведомость итоговых оценок ===&lt;br /&gt;
На данной странице можно выставить итоговые оценки учащимся и завершить обучение потока. Страница принимает обязательный параметр id - id идущего  или завершенного потока.&lt;br /&gt;
&lt;br /&gt;
Вверху страныцы отображается форма, где отображены ученики, которые обучаются на данном потоке. Напротив каждого можно выбрать итоговую оценку, выставляемую учащемуся. Итоговые оценки берутся из шкалы дисциплины приписанной к данному потоку. Под ведомостью стоит галочка подтвержения оценок, без нее оценки не сохранятся. Делее стоит галочка завершения обучения если необходимо завершить поток, При завершении потока все подписки на дисциплину переводятся в один из конечных статусов. Если поток уже завершен, то галочка не показывается, вместо нее предупреждение. После завершения потока оценки также можно выставить, но они уже будут идти как переэкзаменовка. &lt;br /&gt;
&lt;br /&gt;
После того как мы выставили оценки и нажали на кнопку сохранить формируется приказ о выставленни итоговых оценок. На основе этого приказа сохраняются оценки, после чего на новой странице показывается шаблон ведомости в том виде, в котом она будет распечатана. &lt;br /&gt;
После первого сохранения оценок эта ведомость также становится доступна для печати. &lt;br /&gt;
&lt;br /&gt;
Перейти на эту страницу можно со страницы Журнала группы.&lt;br /&gt;
&lt;br /&gt;
== Отчеты ==&lt;br /&gt;
=== Отчеты о фактической нагрузке ===&lt;br /&gt;
&lt;br /&gt;
Позволяют просмотреть статистику о нагрузке учителей за определенный период. [[ Разработка:im/reports#Отчеты о фактической нагрузке | Подробнее ]]&lt;br /&gt;
Для просмотра отчета по любой персоне необходимо право im/journal view:salfactors.&lt;br /&gt;
Для просмотра своего отчета необходимо право im/journal view:salfactors/own.&lt;br /&gt;
Для просмотра истории по отчетам (данные сроком более 2 месяцев) необходимо право view:salfactors_history.&lt;br /&gt;
&lt;br /&gt;
=== Отчеты по замененным урокам ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Приказы ==&lt;br /&gt;
=== Приказ о закрытии зарплатного периода ===&lt;br /&gt;
&lt;br /&gt;
==== Структура приказа о закрытии зарплатного периода ====&lt;br /&gt;
Данные приказа:&lt;br /&gt;
* reportid - id сформированного [[ Разработка:im/reports#Отчеты о фактической нагрузке | отчета по фактической нагркзке ]]&lt;br /&gt;
&lt;br /&gt;
==== Формирование приказа о переводе ====&lt;br /&gt;
При формировании приказа также формируется отчет по фактической нагрузке с тем же указанным промежутком и в тоже указанное время исполнение, что и в приказе. &lt;br /&gt;
&lt;br /&gt;
==== Подписание приказа о переводе ====&lt;br /&gt;
Подписание приказа происходит сразу же после его формирование.&lt;br /&gt;
&lt;br /&gt;
=== Исполнение приказа о переводе ===&lt;br /&gt;
По крону. Возможно позже будет реализовано вручную.&lt;br /&gt;
&lt;br /&gt;
Генерирует приказ по фактической нагрузке. После этого фиксирует все дни подразделения и его дочерних подразделений.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== События ==&lt;br /&gt;
* itog_grade_was_set - генерируется во время выставления итоговой оценки не зависимо от того, происходит первичное выставление оценки или повторное через ведомость пересдачи&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Уведомления ==&lt;br /&gt;
&lt;br /&gt;
==== Уведомление учащегося об оценке ====&lt;br /&gt;
&lt;br /&gt;
Отправка уведомлений после выставления оценки в электронном деканате осуществляется в случае, если включена настройка в подразделении.&lt;br /&gt;
&lt;br /&gt;
Для отправки уведомлений об оценке полученной впервые по дисциплине, необходимо установить настройку send_grade_notification в значение 1. В качестве темы письма будет использоваться текст из настройки grade_notification_subject, в качестве основного текста письма будет использована настройка grade_notification_text.&lt;br /&gt;
&lt;br /&gt;
Для отправки уведомления об оценке полученной через ведомость пересдачи, необходимо установить настройку send_reoffset_notification в значение 1. В качестве темы письма будет использоваться текст из настройки reoffset_notification_subject, в качестве основного текста письма будет использована настройка reoffset_notification_text.&lt;br /&gt;
&lt;br /&gt;
В теме и тексте письма можно использовать следующие подстановки:&lt;br /&gt;
* [PERSONFULLNAME] - ФИО учащегося&lt;br /&gt;
* [DISCIPLINE] - Наименование дисциплины&lt;br /&gt;
* [GRADE] - полученная оценка&lt;br /&gt;
&lt;br /&gt;
=Права=&lt;br /&gt;
&lt;br /&gt;
* '''datamanage''' - глобальное право (администратор)&lt;br /&gt;
* '''view_journal''' - право на просмотр журнала учебного процесса (учитель курса или завуч)&lt;br /&gt;
* '''view_all_journals''' - право на просмотр всех журналов (может просматривать общую информацию и личные данные)&lt;br /&gt;
* '''view_all_journals_department''' - право на просмотр всех журналов подразделения (может просматривать общую информацию и личные данные)&lt;br /&gt;
* '''can_complete_lesson''' - право отметить проведение урока (учитель урока или завуч)&lt;br /&gt;
* '''create_schevent''' - право на создание события (завуч и учитель на потоке, если есть переменная в конфиге)&lt;br /&gt;
* '''control_journal''' - право на проверку журнала (завуч)&lt;br /&gt;
* '''give_grade''' - право на выставление оценки (учитель на потоке или завуч)&lt;br /&gt;
* '''give_itog_grades''' - право выставить итоговые оценки (поток завершён и пользователь - учитель на потоке)&lt;br /&gt;
* '''view_events''' - право просматривать свое расписание (учитель)&lt;br /&gt;
* '''give_attendance''' - право на отметку посещаемости (учитель урока или завуч)&lt;br /&gt;
* '''give_theme_event''' - право указать тему для события (только событие в статусе &amp;quot;запланирован&amp;quot; или &amp;quot;отложено на неопределенный срок&amp;quot;, а пользователь - завуч или учитель потока)&lt;br /&gt;
* '''edit_plans''' - право редактировать КТ (КТ не &amp;quot;зафиксирована&amp;quot; и ((КТ завершена или событие состоялось), а пользователь - завуч) или пользователь может выставлять оценки)&lt;br /&gt;
* '''replace_schevent''' - право формирование замены события (учитель на потоке или завуч)&lt;br /&gt;
&lt;br /&gt;
= API =&lt;br /&gt;
В этом разделе описаны функции для работы со страницами &amp;quot;журнал группы&amp;quot; и &amp;quot;список журналов&amp;quot;. Здесь содержится только краткое описание функций и их параметров. Если вас интересует их внутренняя логика, то обратитесь к разделу [[Разработка:im/journal#Подробное описание работы функций|Подробное описание]]. Аргументы всех функций перечислены именно в том порядке, в котором их следует передавать.&lt;br /&gt;
=== Журнал группы ===&lt;br /&gt;
В этом разделе собраны все функции, которые относятся к странице &amp;quot;журнал группы&amp;quot;&lt;br /&gt;
==== Класс dof_im_journal_tablegrades ====&lt;br /&gt;
Класс отрисовки школьного журнала&lt;br /&gt;
===== print_texttable() =====&lt;br /&gt;
Вывести страницу журнала - просмотр оценок, или редактирование&lt;br /&gt;
&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $editid  - id редактируемого учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $eventid - id учебного события, которое будет редактировано (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* null&lt;br /&gt;
===== check_permissions() =====&lt;br /&gt;
Проверяет разрешения на редактирование оценок для текущего пользователя&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true/false - есть или нет разрешения на редактирование оценок&lt;br /&gt;
==== Класс dof_im_journal_templans_table ====&lt;br /&gt;
Класс для отрисовки таблицы тематического планирования в классном журнале&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
 &lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== print_table() =====&lt;br /&gt;
Выводит таблицу тематического планирования на экран&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
*  true если операция вывода прошла успешно, или false если при выводе возникли ошибки&lt;br /&gt;
==== Класс dof_im_journal_edittopic ====&lt;br /&gt;
Класс для создания или редактирования одной темы на странице планирования уроков&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $planid - id элемента учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
* $eventid - id учебного события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== get_topic() =====&lt;br /&gt;
Возвращает объект с полями, необходимыми для заполнения формы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* object - объект с полями для вставки в форму, или false в случае ошибки&lt;br /&gt;
===== create_topic() =====&lt;br /&gt;
Создает новый элемент тематического планирования&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $checkpoint - контрольная точка из таблицы [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $event - заранее заготовленный объект для таблицы [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи из таблицы schevents или false в случае ошибки&lt;br /&gt;
===== save_topic() =====&lt;br /&gt;
Обновляет существующий или создает новый элемент тематического планирования&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $checkpoint (object) - объект для обновления или создания записи в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $event (object) - объект для обновления или создания записи в таблице [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true, если все записи успешно обновлены&lt;br /&gt;
* (int), id новой записи, если она была добавлена&lt;br /&gt;
* false в случае ошибки&lt;br /&gt;
===== print_table() =====&lt;br /&gt;
Формирует таблицу тематического планирования в правой части страницы журнала&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
*  true если операция вывода прошла успешно, или false если при выводе возникли ошибки&lt;br /&gt;
===== get_anchor_id() =====&lt;br /&gt;
Возвращает метку времени, которая будет создана для нового урока, чтобы осуществить корректное перенаправление на страницу журнала&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $time - (int) время создания нового события: метка времени в формате unixtime&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - метка времени для перенаправления&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_rawdata ====&lt;br /&gt;
Класс для подготовки сырых исходных данных для формирования школьного журнала и ему подобных документов&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
Конструктор - определяет с каким учебным потоком будет вестись работа&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_process_gradesform ====&lt;br /&gt;
Класс для проверки и обработки оценок из формы&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
Конструктор класса. Осуществляет все проверки и записывает данные во внутреннее поле.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $gradedata (array) - массив $_POST из формы&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== process_form() =====&lt;br /&gt;
Обработать все данные, пришедшие из формы: установить посещаемость, выставить оценки и сформировать приказы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* false в случае неудачи. В случае успеха производит редирект на страницу журнала&lt;br /&gt;
==== Класс dof_im_journal_presence ====&lt;br /&gt;
Класс для обработки информации о посещаемости &lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== presence_students() =====&lt;br /&gt;
Формирует массив присутствия учеников&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* массив вида [id_ученика]=&amp;gt;статус_присутствия&lt;br /&gt;
===== absence_students() =====&lt;br /&gt;
Формирует массив отсутствующих студентов&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $away - массив id отсутствующих учеников&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* массив вида [id_ученика]=&amp;gt;статус_присутствия&lt;br /&gt;
==== Дополнительные функции ====&lt;br /&gt;
===== dof_im_journal_format_date() =====&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date (int) - метка времення для преобразования.&lt;br /&gt;
* $format (string) - формат выводимой даты. По умолчанию 'dmy'.&lt;br /&gt;
* $url (string) - Указывается, если необходимо получить дату как ссылку. По умолчанию NULL&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) строка с отформатированной датой&lt;br /&gt;
===== dof_im_journal_date_edit() =====&lt;br /&gt;
Возвращает отформатироанную дату и значок редактирования как ссылку&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date (int) - метка времени&lt;br /&gt;
* $format (string) - формат выводимой даты. По умолчанию 'dmy'&lt;br /&gt;
* $durl (string) - путь ссылки для даты, если не указана - дата выводится как просто строка. По умолчанию null.&lt;br /&gt;
* $eurl (string) - путь ссылки для значка, если не указана значок не показывается По умолчанию null.&lt;br /&gt;
* $imgsubdate (bool) - вывести значок под датой или рядом по умолчанию true (выводит значок под датой)&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - строка с отформатированной датой&lt;br /&gt;
=== Список журналов ===&lt;br /&gt;
==== Класс dof_im_journal_listjournals ====&lt;br /&gt;
Этот класс содержит функции для работы со страницей списка журналов&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
===== set_data() =====&lt;br /&gt;
Заполняет начальной информацией внутренние поля объекта&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid (int) - id подразделения (таблица [[Разработка:storages/departments|departments]]). По умолчанию 0.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true если все нормально или false в случае ошибки&lt;br /&gt;
===== get_data() =====&lt;br /&gt;
Возвращает собранные данные&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - массив структурных подразделений&lt;br /&gt;
===== get_journals() =====&lt;br /&gt;
Получить все журнлы занесенных подразделений&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true если все нормально или false в случае ошибки&lt;br /&gt;
&lt;br /&gt;
=== Журнал занятий ===&lt;br /&gt;
==== Класс dof_im_journal_show_events ====&lt;br /&gt;
Этот класс содержит функции для работы с журналом занятий&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $depid - идентификатор подразделения&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
===== set_data =====&lt;br /&gt;
Заполняет параметры класса начальной информацией&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date - массив, состоящий из даты начала и даты окончания:&lt;br /&gt;
** [date_from] - дата начала&lt;br /&gt;
** [date_to] - дата окончания&lt;br /&gt;
* $teacherid - идентификатор преподавателя&lt;br /&gt;
* $studentid - идентификатор студента&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true если операция прошла успешно&lt;br /&gt;
&lt;br /&gt;
===== get_string_event =====&lt;br /&gt;
Получение строки для вывода одного занятия. &lt;br /&gt;
При проверке статуса события, выполняется проверка статуса на момент проведения самого события&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event - объект события&lt;br /&gt;
* $show_all - вывод подробной таблицы&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив для строчки события&lt;br /&gt;
&lt;br /&gt;
===== get_table_events =====&lt;br /&gt;
Возвращает события одного дня&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $display - ражим отображения(по времени, по учителям, по ученикам)&lt;br /&gt;
** [time] - по времени&lt;br /&gt;
** [students] - по ученикам&lt;br /&gt;
** [teachers] - по учителям&lt;br /&gt;
* $show_all - вывод подробной таблицы&lt;br /&gt;
* $implied - вывод мнимых событий&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_table_unmarked_events =====&lt;br /&gt;
Возвращает события одного дня&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $display - ражим отображения(по времени, по учителям, по ученикам)&lt;br /&gt;
** [time] - по времени&lt;br /&gt;
** [students] - по ученикам&lt;br /&gt;
** [teachers] - по учителям&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_string_appointment =====&lt;br /&gt;
Получение строки для вывода одного предмето-класса&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $cstream - объект учебного процесса (предмето-класса)&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив для строчки события&lt;br /&gt;
&lt;br /&gt;
===== get_table_teaching_load =====&lt;br /&gt;
Возвращает учебную нагрузку учителя&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
''Возвращаемые значения:'' array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_data_for_export =====&lt;br /&gt;
Сбор данных для экспорта в csv&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
''Возвращаемые значения:'' &lt;br /&gt;
* array - данные для экспорта&lt;br /&gt;
&lt;br /&gt;
===== get_string_for_export =====&lt;br /&gt;
Создание массива данных об учениках&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event - объект урока&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив с данными&lt;br /&gt;
&lt;br /&gt;
== Подробное описание работы функций ==&lt;br /&gt;
В этом разделе описывается подробная работа всех публичных и внутренних методов для классов журнала. Если вам требуется только краткая справка по API, то обратитесь к разделу [[Разработка:im/journal#API|API]].&lt;br /&gt;
=== Для журнала группы ===&lt;br /&gt;
==== Класс dof_im_journal_tablegrades ====&lt;br /&gt;
&lt;br /&gt;
===== Описание print_texttable() =====&lt;br /&gt;
[[#print_texttable()|Описание API]].&lt;br /&gt;
&lt;br /&gt;
Итоговая функция, выводящая всю собранную информацию на экран. &lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# собирает всю информацию при помощи функции [[Разработка:im/journal#Описание get_all_form()|get_all_form()]]&lt;br /&gt;
# обращается к плагину templater для представления информации в html-формате&lt;br /&gt;
# функцией print выводит результат работы templater'а на экран.&lt;br /&gt;
===== Описание check_permissions() =====&lt;br /&gt;
[[#check_permissions()|Описание API]].&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем учебный поток. Если поток не найден - возвращаем false.&lt;br /&gt;
# проверяем статус учебного потока. Если он не равен значению &amp;quot;go&amp;quot;, то возвращаем false.&lt;br /&gt;
# проверяем, имеет ли текущий пользователь права редактирования. Если нет, то возвращаем false.&lt;br /&gt;
# если все проверки пройдены успешно, то возвращаем true.&lt;br /&gt;
===== Описание get_all_form() =====&lt;br /&gt;
Возвращает объект формы для вставки в templater. Таблица в шаблоне формируется по столбцам, т. е. сначала выводится контрольная точка в тем. планировании, а затем оценки всех учеников за это событие (как при заполнении обычного школьного журнала).&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $editid (int) - id редактируемого учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $eventid (int) - id редактируемого учебного события в таблице [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) объект нужной структуры для построения шаблона&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# собираем в объект все стандартные надписи для таблицы&lt;br /&gt;
# собираем все запланированные активные контрольные точки учебного потока&lt;br /&gt;
# создадим массивы для названий месяцев и дат&lt;br /&gt;
# собираем в массив информацию по ученикам. Если параметр $editid не равен нулю, то в столбце оценок для редактируемой даты вместо оценки выводим форму.&lt;br /&gt;
# собираем в результурующий массив названия месяцев и дат &lt;br /&gt;
# если нужно распечатать форму - устанавливаем стандартные html-теги начала и конца формы&lt;br /&gt;
# возвращаем результат&lt;br /&gt;
&lt;br /&gt;
===== Описание get_cell_form() =====&lt;br /&gt;
Возвращает редактируемую ячейку таблицы журнала.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons.&lt;br /&gt;
* $cpassedid (int) - id учебной программы&lt;br /&gt;
* $oldgrade (int) - старая оценка (если есть). По умолчанию null.&lt;br /&gt;
* $gradeid (int) - id оценки в таблице cpgrades . По умолчанию 0&lt;br /&gt;
* $eventid (int) - id учебного события в таблице [[Разработка:storages/schevents|schevents]].&lt;br /&gt;
* $scale (string) - шкала всех возможных оценок через запятую. По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - строка с html-кодом формы редактирования оценки.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
Вся форма редактирования оценки представляет собой маленькую таблицу. С левой стороны находится форма выбора оценки, а справа галочка для отметки отсутствующего ученика (верхняя ячейка) и пояснение к ней (нижняя ячейка).&lt;br /&gt;
# получаем все допустимые варианты оценок для данного задания из параметра scale.&lt;br /&gt;
# из этих вариантов оценки составляем html-элемент формы типа SELECT.&lt;br /&gt;
# если за задание уже есть ранее выставленная, старая оценка, то делаем ее оценкой по умолчанию&lt;br /&gt;
# узнаем статус присутствия ученика на занятии, и в зависимсости от этого проставляем галочку над буквой &amp;quot;н&amp;quot;. Форма с возможностью отмечания отсутствующих учеников отображается только для контрольных точек для которых есть события.&lt;br /&gt;
# возвращаем результат одной строкой.&lt;br /&gt;
===== Описание get_cell_string() =====&lt;br /&gt;
Получить текстовое содержимое ячейки оценки.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons&lt;br /&gt;
* $plan (object) - объект содержащий данные об элементе тематического планирования (таблица [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $gradedata (object) - данные об оценке По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) html-код оценки, либо специальный знак пробела, чтобы в таблице было видно пустую ячейку&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
# узнаем данные о посещаемости: получаем id события, если оно есть&lt;br /&gt;
#* если событие есть, узнаем, был ли ученик на занятии&lt;br /&gt;
# находим оценку&lt;br /&gt;
#* если ученик был на занятии и получил оценку - выводим оценку&lt;br /&gt;
#* если ученик был на занятии и не получил оценку - выводим символ пробела&lt;br /&gt;
#* если ученик отсутствовал на занятии и нет оценки, то выводим букву &amp;quot;н&amp;quot;&lt;br /&gt;
#* если ученик отсутствовал на занятии и получил оценку - выводим оценку, и букву &amp;quot;н&amp;quot; рядом с ней&lt;br /&gt;
&lt;br /&gt;
===== Описание get_one_cell() =====&lt;br /&gt;
Возвращает данные в одной клетке журнала. Определяет какой тип ячейки выводить: для редактирования или текстовую.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons&lt;br /&gt;
* $plan (object) - объект содержащий контрольную точку с событием  из тем. планирования (таблица [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $gradedata (object) - объект содержащий данные об оценке (таблица cpgrades)&lt;br /&gt;
* $cpassedid (int) - id подписки (таблица cpassed)&lt;br /&gt;
* $editid (int) - id редактируемого в текущий момент элемента из тем. планирования&lt;br /&gt;
* $eventid (int) - id редактируемого в текущий момент события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
* $scale (string) = По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) строка с html-кодом формы редактирования оценки, либо сама оценка, либо статус &amp;quot;отсутствовал&amp;quot;&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# сравниваем, совпадают ли id выводимой и редактируемой в данной момент контрольной точки&lt;br /&gt;
#* если id совпадают - то выводим форму редактирования оценки&lt;br /&gt;
#** если за это задание оценка уже была ранее выставлена, то выводим форму с установленной ранее оценкой&lt;br /&gt;
#** если за задание еще нет оценки - то выводим форму без предустановленных значений&lt;br /&gt;
#* если id не совпадают то выводим оценку текстом (либо статус &amp;quot;отсутствовал&amp;quot;, либо пустую клетку, в зависимости от того был ли ученик на уроке, и получил ли он оценку)&lt;br /&gt;
===== Описание get_line_for_student() =====&lt;br /&gt;
Возвращает строку таблицы журнала для одного ученика.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $i (int) - порядковый номер ученика в группе&lt;br /&gt;
* $student (object) - объект с данными об ученике из таблицы persons&lt;br /&gt;
* $cpasseds (array) - массив объектов, содержащий все подписки учеников этого потока&lt;br /&gt;
* $plans (array) -  массив объектов, содержащий все контрольные точки текущего курса (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $editid (int) - id редактируемой в данный момент контрольной точки&lt;br /&gt;
* $eventid (int) - id редактируемого в данный момент события (или 0, если события нет) Таблица [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - информация об ученике: его ФИО, и оценки по всем контрольным точкам, а также сведения о посещаемости&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект для итоговых данных&lt;br /&gt;
# записываем в соответствующие поля итогового объекта порядковый номер ученика, и его ФИО&lt;br /&gt;
# перебираем все переданные подписки ищем ту, которая относится к переданному ученику&lt;br /&gt;
# записываем в итоговый объект id его подписки&lt;br /&gt;
# создаем массив для оценок и собираем оценки ученика:&lt;br /&gt;
#* перебираем все контрольные переданные точки ($plans)&lt;br /&gt;
#* для каждой контрольной точки создаем объект оценки&lt;br /&gt;
#* получаем значение оценки за просматриваемую контрольную точку&lt;br /&gt;
#* при помощи функции [[Разработка:im/journal#Описание get_one_cell()|get_one_cell()]] получаем оформленный html-код оценки&lt;br /&gt;
#* записываем полученный объект в массив оценок&lt;br /&gt;
# добавляем массив оценок в итоговый объект&lt;br /&gt;
# возвращаем итоговый объект&lt;br /&gt;
===== Описание get_lines_for_students() =====&lt;br /&gt;
Возвращает массив строк с ФИО и оценками для всех учеников&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans (array) - массив всех контрольных точек учебного потока из таблицы plans&lt;br /&gt;
* $editid (int) - id редактируемой в данный момент контрольной точки (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $eventid (int) - id редактируемого в данный момент события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) информация о всех учениках учебного потока или false, если ни одного ученика нет&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все подписки учебного потока, чтобы потом установить связи с оценками&lt;br /&gt;
# получаем учеников учебного потока&lt;br /&gt;
# присваиваем каждому ученику порядковый номер,&lt;br /&gt;
# получаем информацию по каждому ученику функцией [[#Описание get_line_for_student()|get_line_for_student()]] и заносим объект с информацией о нем в массив&lt;br /&gt;
# возвращаем получившийся массив &lt;br /&gt;
===== Описание create_datesstring() =====&lt;br /&gt;
Создает верхнюю строку журнала с названиями месяцев и списком дат в пригодном для обработки плагином templater виде.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans - список всех контрольных точек учебного потока из таблицы [[Разработка:storages/plans|plans]].&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект, содержащий массив с данными для шаблонизатора&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
Даты в электронном журнале должны будут проставляться как и в обычном классном журнале: верхняя строка - месяцы обучения, нижняя строка - даты проведенных или запланированных уроков, а также четвертные или годовые оценки.&lt;br /&gt;
Для того чтобы организовать такой внешний вид для электронного журнала мы должны воспользоваться параметром colspan для html-таблицы журнала, и расположить тем самым месяцы точно над датами проведенных уроков. Для этой задачи в этой функции мы создаем объект следующей структуры:&lt;br /&gt;
* ''(возвращаемый объект)''&lt;br /&gt;
** ''monthtitle'' - массив объектов, каждый из которых имеет свойства ''mtitle'' - название месяца, и ''mcolspan'' - количество ячеек с датами проведенных уроков в этом месяце&lt;br /&gt;
** ''monthdate'' - строка с датой проведенного урока, либо название контрольной точки.&lt;br /&gt;
&lt;br /&gt;
# получаем строку форматированных дат уроков при помощи функции [[#Описание generate_all_dates()|generate_all_dates()]]&lt;br /&gt;
# перебираем все события и собираем массивы дат и названий месяцев&lt;br /&gt;
#* если просматриваемая дата не находится в том же месяце, что и предыдущая, то дополняем массив месяцев&lt;br /&gt;
# прибавляем счетчик дат в месяце&lt;br /&gt;
# записываем новую дату в итоговый массив&lt;br /&gt;
# возвращаем итоговый массив&lt;br /&gt;
===== Описание generate_all_dates() =====&lt;br /&gt;
Вызывается из [[#Описание create_datesstring()|create_datesstring()]]. Получить отформатированные даты для журнала&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans - массив всех контрольных точек учебного потока (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - отформатированные даты для вывода в журнал&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получим событие из таблицы schevents, которое относится к данной теме тематического планирования&lt;br /&gt;
# если событие есть - то покажем дату&lt;br /&gt;
# если события нет - только название контрольной точки&lt;br /&gt;
&lt;br /&gt;
===== Описание generate_single_date() =====&lt;br /&gt;
Вызывается из [[#Описание generate_all_dates|generate_all_dates]] Создает один объект даты для журнала.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plan (object) - объект из таблицы [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $date (string) - метка времени для события или контрольной точки&lt;br /&gt;
* $event (object) - Объект из таблицы [[Разработка:storages/schevents|schevents]]. По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) дата в нужном для templater'a формате&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# устанавливаем путь (html-якорь) к теме в планирования на странице&lt;br /&gt;
# Определяем, id события которое будет редактировано. Если события нет, то передаем 0.&lt;br /&gt;
# записываем якорь с ссылкой в объект&lt;br /&gt;
# возвращаем объект&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_templans_table ====&lt;br /&gt;
===== Описание get_topics() =====&lt;br /&gt;
Возвращает массив объектов c необходимыми свойствами для вставки в таблицу schevents&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив тем входящих в планирование&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все контрольные точки учебного потока&lt;br /&gt;
# формируем объект с нужными полями для каждой контрольной точки&lt;br /&gt;
# возвращаем получившийся массив объектов&lt;br /&gt;
===== Описание get_empty_topic() =====&lt;br /&gt;
Возвращает &amp;quot;пустой&amp;quot; объект отчета об уроке &lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект для вставки в таблицу [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* создаем объект с необходимым списком пустых полей и возвращаем его&lt;br /&gt;
===== Описание table_data() =====&lt;br /&gt;
Возвращает массив строк данных отформатированных для вывода с помощью moodle-функции print_table()&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив с данными для распечатки таблицы, либо false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли для переданного потока элементы тематического планирования.&lt;br /&gt;
#* если их нет - то возвращаем false&lt;br /&gt;
# формируем массив строк таблицы&lt;br /&gt;
# проставляем html-якоря для каждой контрольной точки на странице оценок&lt;br /&gt;
# добавляем ссылки на редактирования элементов учебного плана&lt;br /&gt;
# возвращаем получившийся массив&lt;br /&gt;
==== Класс dof_im_journal_edittopic ====&lt;br /&gt;
===== Описание get_topic() =====&lt;br /&gt;
[[#get_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* Проверяем, указан ли id контрольной точки. &lt;br /&gt;
** Если не указан - возврящаем пустую тему.&lt;br /&gt;
** Если указан - пробуем извлечь контрольную точку по такому id&lt;br /&gt;
*** Если контрольную точку извлечь не удалось - то возвращаем false&lt;br /&gt;
*** Если удалось - то возвращаем заполненный отчет об уроке&lt;br /&gt;
===== Описание save_topic() =====&lt;br /&gt;
[[#save_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем есть ли у нас данные в переменной $event для обновления или создания события. Если нет - то возвращаем false.&lt;br /&gt;
# определяем тип действия, которое надо совершить&lt;br /&gt;
#* если указан planid для события - то создаем новое событие для существующей контрольной точки&lt;br /&gt;
#* если нет id для контрольной точки - создаем новое событие и новую контрольную точку&lt;br /&gt;
#* в остальных случаях - обновляем контрольную точку и событие: вычисляем новую относительную дату, и обновляем записи в таблицах [[Разработка:storages/schevents|schevents]] и [[Разработка:storages/plans|plans]]&lt;br /&gt;
===== Описание create_topic() =====&lt;br /&gt;
[[#create_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем новый элемент тематического планирования в таблице plans (если это не удалось - то возвращаем false)&lt;br /&gt;
# добавляем в переданное событие id контрольной точки&lt;br /&gt;
# создаем событие из переданного объекта $event (если событие не создано - удаляем ранее созданный элемент тематического планирования)&lt;br /&gt;
# возвращаем id события&lt;br /&gt;
===== Описание create_checkpoint() =====&lt;br /&gt;
Создает и сохраняет запись в таблице plans&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $point (object) - данные для сохранения в таблицу [[Разработка:storages/plans|plans]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи или false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли у нас все необходимые для создания записи&lt;br /&gt;
# получаем id учебного потока&lt;br /&gt;
# получаем дату начала обучения&lt;br /&gt;
# создаем заготовку для объекта контрольной точки&lt;br /&gt;
# вычисляем относительную дату контрольной точки&lt;br /&gt;
# заносим данные в базу&lt;br /&gt;
===== Описание create_event() =====&lt;br /&gt;
Создает объект события и сохраняет его в schevents&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event (object) - данные для сохранения&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи в таблице событий или false.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли у нас все необходимые для создания записи&lt;br /&gt;
# получаем id учебного потока&lt;br /&gt;
# получаем id преподавателя в таблице persons&lt;br /&gt;
# создаем объект нужного формата и заносим туда все данные&lt;br /&gt;
# записываем данные в базу&lt;br /&gt;
==== Класс dof_im_journal_rawdata ====&lt;br /&gt;
''Поля:''&lt;br /&gt;
* dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* csid - id учебного потока в таблице сstreams&lt;br /&gt;
===== Описание get_checkpoints() =====&lt;br /&gt;
Получить все контрольные точки одного учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - массив объектов из таблицы plans или false &lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем id учебного потока из таблицы cstreams&lt;br /&gt;
# выбираем из таблицы plans все записи, у которых поле cstreamid равно id учебного потока, и тип связи &amp;quot;cstreams&amp;quot;&lt;br /&gt;
# сортируем их в хронологическом порядке&lt;br /&gt;
# возвращаем получившийся массив&lt;br /&gt;
&lt;br /&gt;
===== Описание get_students() =====&lt;br /&gt;
Получить всех учеников указанного учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив записей из таблицы persons или false&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем список пройденных дисциплин&lt;br /&gt;
# перебираем все подписки и запоминаем id ученика для каждой из них&lt;br /&gt;
# извлекаем из таблицы persons учеников, чьи id были извлечены из подписок&lt;br /&gt;
&lt;br /&gt;
===== Описание get_teacherid() =====&lt;br /&gt;
Получить id преподавателя учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id преподавателя или false в случае неудачи&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* id преподавателя всегда берется только из записи учебного потока из таблицы cstreams&lt;br /&gt;
==== Класс dof_im_journal_process_gradesform ====&lt;br /&gt;
''Поля:''&lt;br /&gt;
* gradedata - (object) все оценки и сопутствующая им информация&lt;br /&gt;
* mypost - (array) непроверенные данные пришедшие из массива $_POST. Используются только для составления повторного запроса на сохранение данных.&lt;br /&gt;
===== Описание __construct =====&lt;br /&gt;
[[#Класс dof_im_journal_rawdata|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект, в который мы будем складывать все проверенные данные, пришедшие из формы&lt;br /&gt;
# проверяем скалярные данные: все числовые идентификаторы, и отдельные строки, и после проверки записываем их в итоговый объект&lt;br /&gt;
# теперь, зная cstreamid из проверенных скалярных данных вызываем родительский конструктор&lt;br /&gt;
# проверяем массивы, пришедшие из формы: &lt;br /&gt;
#* данные об отсутствующих учениках&lt;br /&gt;
#* массив оценок &lt;br /&gt;
#* массив идентификаторов подписок (таблица cpassed)&lt;br /&gt;
#* узнаем id оценок для изменения их статуса&lt;br /&gt;
# записываем все проверенные данные в итоговый массив&lt;br /&gt;
# определяем тип действия, которое надо совершить: &lt;br /&gt;
#* сохранить данные&lt;br /&gt;
#* сохранить данные и продолжить редактирование&lt;br /&gt;
#* восстановить исходные значения&lt;br /&gt;
# записываем исходный массив (непроверенный) в поле объекта, если потом понадобится еще раз отправить данные после подтверждения&lt;br /&gt;
===== Описание process_form() =====&lt;br /&gt;
[[#process_form()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# в самом начале проверяем тип действия, которое надо совершить. Если этим действием является &amp;quot;отменить изменения&amp;quot;, то не переходим к сохранению оценок и сразуже выполняем перенаправление на страницу журнала. В остальных случаях идем дальше:&lt;br /&gt;
# проверяем, установлено ли у кого-нибудь из учеников одновременно &amp;quot;н&amp;quot; и оценка. Если это так - то перенаправим пользователя на страницу с сообщением об этом, и попросим его подтвердить такой выбор.&lt;br /&gt;
#* если пользователь согласен с изменениями, которые он сделал, то все выставленые им оценки и сведения о посещаемости сохраняются&lt;br /&gt;
#* если же нет - то происходит отмена всех изменений&lt;br /&gt;
# в случае, когда никаких предупреждений нет - сначала формируем приказ для оценок&lt;br /&gt;
# затем приказ о посещаемости&lt;br /&gt;
# если все действия произведены успешно - производим редирект. Если же возникли ошибки - сообщаем об этом&lt;br /&gt;
&lt;br /&gt;
===== Описание generate_order_grades() =====&lt;br /&gt;
Сформировать приказ об изменении состояния учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true если приказ успешно сформирован, и false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем id подразделения в таблице departments&lt;br /&gt;
# определяем тип действия, которое нужно совершить с оценкой&lt;br /&gt;
# обращаемся к функциям выставления, либо удаления оценки&lt;br /&gt;
===== Описание order_set_grade() =====&lt;br /&gt;
Формирует приказ - установить оценку. &lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid (int) - id подразделения в таблице [[Разработка:storages/departments|departments]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true в случае успеха и false в случае неудачи&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# подключаем методы работы с приказом&lt;br /&gt;
# создаем объект для записи&lt;br /&gt;
# сохраняем автора приказа, подразделение, к которому он относится, дату создания приказа&lt;br /&gt;
# добавляем данные, которые определяют назначение приказа&lt;br /&gt;
# сохраняем приказ в БД, в таблицу orders&lt;br /&gt;
# подписываем приказ&lt;br /&gt;
# исполняем приказ&lt;br /&gt;
Методы order_delete_grade и order_update_grade работают по такому же принципу.&lt;br /&gt;
===== Описание get_grades_fororder() =====&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $type - тип действия, которое необходимо будет произвести над оценкой. Возможные значения: ''set_grade'' и ''delete_grade''.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект, содержащий список оценок и все идентификаторы для формирования приказа.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект для итоговых данных&lt;br /&gt;
# записываем в него дату, id учителя (в таблице persons) и id контрольной точки (в таблице plans&lt;br /&gt;
# перебираем все оценки из внутреннего массива с проверенными данными&lt;br /&gt;
# определяем тип действия, которое над ней нужно совершить&lt;br /&gt;
# в зависимости от типа действия (установление или удаление оценки) записываем в объект оценки нужные идентификаторы&lt;br /&gt;
# упаковываем оценки в итоговый массив и возвращаем его&lt;br /&gt;
=== Для списка журналов ===&lt;br /&gt;
==== Класс dof_im_journal_listjournals ====&lt;br /&gt;
Этот класс служит для сбора и вывода информации по всем структурным подразделениям. Информация выводится древовидно: самый верхний уровень - подразделение, затем учебные программы, затем учебные периоды, элементы учебной программы, и в самом конце - журналы учебного потока.&lt;br /&gt;
''Поля:''&lt;br /&gt;
* dof - - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $departments массив структуры&lt;br /&gt;
    array(&lt;br /&gt;
    [departmentid] =&amp;gt; obj  -&amp;gt; departmentname = 'department_name'&lt;br /&gt;
                      obj  -&amp;gt; programms = array(&lt;br /&gt;
      [programmid]   =&amp;gt; obj1 -&amp;gt; programmname = 'programm_name'&lt;br /&gt;
                        obj1 -&amp;gt; ages = array(&lt;br /&gt;
        [agenum]       =&amp;gt; obj2 -&amp;gt; agename = 'age_name'&lt;br /&gt;
                          obj2 -&amp;gt; items = array(&lt;br /&gt;
          [itemid]       =&amp;gt; obj3 -&amp;gt; itemname = 'item_name'&lt;br /&gt;
                            obj3 -&amp;gt; cstreams = array(&lt;br /&gt;
            [cstreamid]    =&amp;gt; obj4 -&amp;gt; cstreamname = 'cstream_name'&lt;br /&gt;
                                    )''// конец массива cstreams''&lt;br /&gt;
                                  )''// конец массива items''&lt;br /&gt;
                                )''// конец массива ages''&lt;br /&gt;
                              )''// конец массива programms''&lt;br /&gt;
         )''// конец общего массива''&lt;br /&gt;
    содержит данные для вставку в темплатер после добавления еще одного уровня:&lt;br /&gt;
    $fortemplater-&amp;gt;departments = $this-&amp;gt;departments;&lt;br /&gt;
В общем виде сбор данных выглядит так: &lt;br /&gt;
# сначала собирается информация по структурному подразделению (одному или нескольким), и информация по ним записывается в итоговый объект&lt;br /&gt;
# затем получаются все программы учебного подразделения, информация по ним записывается в итоговый массив&lt;br /&gt;
# извлекается и записывается в итоговый объект список учебных периодов &lt;br /&gt;
# для каждого учебного периода получаются элементы учебной программы, которые изучаются в нем&lt;br /&gt;
# для каждого элемента учебной программы получаются учебные потоки&lt;br /&gt;
# для каждого учебного потока получается его журнал&lt;br /&gt;
===== Описание set_data() =====&lt;br /&gt;
[[#set_data()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* получаем id структурного подразделения из таблицы departments.&lt;br /&gt;
** если оно есть - то получаем информацию только по нему&lt;br /&gt;
** если получили 0 вместо id подразделения - то выводим информацию по всем подразделениям&lt;br /&gt;
&lt;br /&gt;
===== Описание get_journals_department() =====&lt;br /&gt;
Возвращает журналы одного подразделения&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid - id подразделения в таблице [[Разработка:storages/departments|departments]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - набор журналов &lt;br /&gt;
* (bool) - false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все программы, за которые отвечает подразделение&lt;br /&gt;
# для каждой программы получаем все ее журналы&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal&amp;diff=3035</id>
		<title>Разработка:im/journal</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal&amp;diff=3035"/>
				<updated>2017-04-13T10:06:31Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = journal&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
= Классный журнал =&lt;br /&gt;
В журнале можно выставлять оценки и вводить отчет о проведенном уроке.&lt;br /&gt;
== Список занятий ==&lt;br /&gt;
Включает в себя три страницы: информацию о текущем дне, список занятий в целом и поиск занятий по конкретной персоне.&lt;br /&gt;
Каждая страница содержит соответствующую ей навигацию.&lt;br /&gt;
====Список занятий за текущий день====&lt;br /&gt;
При заходе с главной страницы при нажатии на ссылку &amp;quot;Журнал&amp;quot; пользователь попадает именно на эту страницу, с нее начинается работа со списком занятий. &lt;br /&gt;
&lt;br /&gt;
В начале страницы отображается секция навигации, с помощью которой пользователь может перейти на просмотр списка занятий в целом, поиск занятий по персоне или просмотреть отчет по фактической нагрузке.&lt;br /&gt;
&lt;br /&gt;
Далее отображаются все уроки пользователя за сегодняшний день. Если уроков нет секция остается пустой.&lt;br /&gt;
&lt;br /&gt;
После этого отображается секция нагрузки пользователя. В ней пользователь может просмотреть всю информацию о своих табельных нагрузках: подразделение, к которому относится табель, табельный номер, ставка в часах фактическая и указанная и табеле, а также список всех активных учебных процессов, которые преподает пользователь. Каждая табельная нагрузка выводится в отдельной таблице.&lt;br /&gt;
====Список занятий в целом====&lt;br /&gt;
В начале страницы отображается секция навигации, с помощью которой пользователь может вернутся обратно на страницу списка занятий за день, а также перейти на страницу поиска занятий по персоне.&lt;br /&gt;
&lt;br /&gt;
После навигации пользователь видит два календарика, где он может выбрать как один определенный день, так и целый период, за который он хочет просмотреть список занятий. &lt;br /&gt;
&lt;br /&gt;
Далее отображается список занятий за указанный день или период.&lt;br /&gt;
&lt;br /&gt;
====Поиск занятий по персоне====&lt;br /&gt;
&lt;br /&gt;
На этой странице пользователь видит текстовое поле для ввода фамилии (а может даже имени и отчества) персоны и кнопку &amp;quot;Найти&amp;quot;. Если по запросу были найдены персоны, он выведет их в виде списка. Кликнув на искомую персону пользователя перекинет на страницу просмотра списка занятий в целом, но уже по конкретной персоне.&lt;br /&gt;
&lt;br /&gt;
== Журнал группы ==&lt;br /&gt;
Страница принимает обязательный параметр id учебного процесса.&lt;br /&gt;
&lt;br /&gt;
Под панелью навигации выводится надпись &amp;quot;Журнал группы&amp;quot;.&lt;br /&gt;
Ниже таблица с информацией о потоке - программа, предмет, группа, преподаватель. Справа от этой таблицы размещена  ссылка &amp;quot;Новый урок&amp;quot;. Нажатие на нее позволяет создать новый отчет об уроке. Над этой ссылкой будут выводиться сообщения об ошибках сохранения данных из таблицы оценок.&lt;br /&gt;
&lt;br /&gt;
Ниже отображаются две таблицы - таблица оценок и, справа от нее, таблица уроков. Обе таблицы сделаны максимально похожими на соответствующие таблицы в бумажном &amp;quot;Классном журнале&amp;quot;. Таблицы связаны друг с другом, содержат в себе темы с directmap=1&lt;br /&gt;
&lt;br /&gt;
Таблица уроков содержит в себе темы и события связанные с указанным учебным процессом, кроме удаленных. Если же тема не связана с событием или событие не связано с темой они также отображаются в таблице, но без соответствующей информации.&lt;br /&gt;
&lt;br /&gt;
Таблица оценок события и темы отображаются также как и в таблице уроков, кроме замененных событий и событий без тем. Дата в таблице оценок отображаются только в том случае, если для созданной темы создано событие, если у темы события нет, отображается полностью его название. &lt;br /&gt;
&lt;br /&gt;
При нажатии на дату в таблице оценок, происходит перемещение к соответствующей строке отчета об уроке. При нажатии на иконку редактирования отображается форма заполнения оценок и посещаемости.&lt;br /&gt;
&lt;br /&gt;
=== Таблица оценок. ===&lt;br /&gt;
&lt;br /&gt;
Если таблица уроков пуста, то в таблице оценок нет ни одной колонки с датой.&lt;br /&gt;
&lt;br /&gt;
Если журнал заполнен, то в верхней строке отображаются названия месяцев, ниже номера дней месяцев, на которые приходились занятия. Каждое число месяца - ссылка, при нажатии на которую происходит переход на соответствующую этому дню строку таблицы уроков.&lt;br /&gt;
&lt;br /&gt;
Сразу под числом расположен значок редактирования. Он также выполнен в виде ссылки. При нажатии на него страница перезагружается в режиме формы ввода оценок и выставления присутствия учеников на уроке, который проходил в тот день, по значку под числом которого щелкнули.&lt;br /&gt;
&lt;br /&gt;
В колонке этого дня, напротив фамилии каждого ученика появляются три поля. Поле выбора из списка - для проставления оценки, поле переключатель - для отметки присутствия на уроке и поле переключатель - для отметки обучения учащегося на уроке. &lt;br /&gt;
&lt;br /&gt;
В выборе оценок из списка, отображаются те оценки, что прописаны в шкале оценок указанной темы. Если в теме шкала отсутствует, то шкала берется из связанного с темой предмета, если же и там шкалы нет, то задается стандартная от 1 до 5.&lt;br /&gt;
&lt;br /&gt;
Далее отображается галочка &amp;quot;н&amp;quot;, при нажатии на которую учащийся помечается как отсутствующий на уроке. Если же мы хотим указать учащегося как присутствующего галочку просто не ставим. Если кому-то была выставлена и оценка и отметка об отсутствии на уроке, на против его фамилии можно будет увидеть оценку с буквой &amp;quot;н&amp;quot;. Однако перед сохранением будет выведено предупреждение о том, что выставлена оценка отсутствующему ученику. Под уведомлением будут две кнопки - &amp;quot;Продолжить&amp;quot; и &amp;quot;Отменить&amp;quot;. При нажатии на &amp;quot;Продолжить&amp;quot; сценарий сохранения будет выполнен. Нажатие на другую кнопку вызовет отмену процедуры сохранения и возврат к форме с несохраненными изменениями.&lt;br /&gt;
&lt;br /&gt;
Замыкает тройку галочка &amp;quot;н/о&amp;quot;, которая показывает обучался ли учащийся на этом уроке или нет. В отличие от галочки &amp;quot;н&amp;quot;, которая помечает присутствие или отсутствие учащегося на уроке, галочка &amp;quot;н/о&amp;quot; или &amp;quot;не обучался&amp;quot;, что ученик в данный момент времени вообще не обучался на данном уроке по какой-либо причине(начал обучатся не со всеми, закончил обучатся раньше, взял академический отпуск, находится на лечении в санатории или больнице и т.д). Появляется эта галочка только в том случае, если присутствие или отсутствие у учащегося не проставлено.&lt;br /&gt;
&lt;br /&gt;
При переключении в режим формы под таблицей появляется надпись &amp;quot;Внимание! До нажатия кнопки &amp;quot;сохранить&amp;quot; оценки не сохраняются...&amp;quot;, под которой также появится галочка о подтверждения проведения урока и три кнопки - &amp;quot;Сохранить&amp;quot;, &amp;quot;Сохранить и продолжить&amp;quot;, &amp;quot;Восстановить&amp;quot;. &lt;br /&gt;
Нажатие на первую кнопку сохраняет изменения, сделанные в форме и перезагружает страницу в режим просмотра. Вторая - сохраняет сделанные изменения, но страница остается в режиме формы - можно продолжать ввод. Третья кнопка отменяет сделанные изменения. Все введенные,  но несохраненные данные удаляются из формы. Форма перегружается с отображением последних сохраненных изменений.&lt;br /&gt;
&lt;br /&gt;
Если ученику была выставлена оценка, а затем отменена - в форме было выбрано пустое поле, то ранее выбранная оценка будет удалена. Если оценка была изменена, то оценка будет обновлена. Каждое из этих действий, а также выставление статуса присутствия на уроке, будет выполнено через издание приказа.&lt;br /&gt;
Если редактируется контрольная точка без события, то в форме показываеются только поля выставления оценки. Поле присутствия на уроке не показывается и статус присутствия не сохраняется.&lt;br /&gt;
Контрольная точка без события выводится в таблице оценок без даты. Вместо даты выводится название КТ.&lt;br /&gt;
Если пользователь нажал галочку отметки проведения урока, то вместе с приказом о посещаемости событие помечается как состоявшееся.&lt;br /&gt;
&lt;br /&gt;
Что происходит в процессе сохранения.&lt;br /&gt;
После того как нажата одна из кнопок, сохраняющая внесенные изменения происходит&lt;br /&gt;
&lt;br /&gt;
* формирование приказа регистрации присутствия учеников на уроке. В него сохраняются данные о всех учениках потока, их статусы присутствия, id события, статус присутствия на котором выставляется. Также вместе с приказом идет отметка о проведении урока. &lt;br /&gt;
* применение приказа и сохранение статусов учеников в соответствующих таблицах.&lt;br /&gt;
&lt;br /&gt;
Если были выставлены оценки. То в дополнение к вышеописанным действиям происходят следующие действия:&lt;br /&gt;
* формирование приказа регистрации выставления оценок только тем ученикам, которые их получили на уроке. В приказе сохраняются: точное время выставления оценки, id КТ, за которую выставлена оценка, id преподавателя (из /storage/persons), который выставил оценку, ученики, которые получили оценку, и соответствующие им оценки, статус оценки, id подписки ученика на поток.&lt;br /&gt;
* применение приказа и сохранение оценок в соответствующих таблицах.&lt;br /&gt;
&lt;br /&gt;
Примечание: Если у учащегося была проставлена галочка &amp;quot;н/о&amp;quot;, то данные по этому ученику в приказ не сохраняются &lt;br /&gt;
&lt;br /&gt;
После создания отчета об уроке, происходит возврат на главную страницу журнала и таблица оценок загружается в режиме формы того дня, отчет для которого был создан. Если этот день выходит за границы видимости окна, то происходит перемещение таблицы оценок таким образом, чтобы нужная колонка оказалась видимой. После редактирования отчета об уроке таблица оценок загружается в режиме просмотра. Если день, для которого происходило редактирование отчета выходит за границы видимости, то происходит перемещение таблицы оценок таким образом, чтобы нужная колонка оказалась видимой.&lt;br /&gt;
&lt;br /&gt;
=== Таблица уроков. ===&lt;br /&gt;
Представляет собой таблицу из семи столбцов.&lt;br /&gt;
# Порядковый номер урока.&lt;br /&gt;
# Дата проведения урока в формате дд.мм.гг&lt;br /&gt;
# Тема урока. Если отображается событие без темы, данная ячейка пустая.&lt;br /&gt;
# Домашнее задание. Если отображается событие без темы или пользователь ничего не вводил в поле домашнего задания, данная ячейка пустая.&lt;br /&gt;
# Время на домашнее задание. Аналогично со столбцом &amp;quot;Домашнее задание&amp;quot;&lt;br /&gt;
# Примечание. Аналогично со столбцом &amp;quot;Домашнее задание&amp;quot;. На данный момент не используется, ввиду сокращения размеров таблицы &lt;br /&gt;
# Статус урока. Если отображается тема без события, данная ячейка пустая. Если событие зафиксировано как состоявшееся, ниже пишется персона проводившая событие.&lt;br /&gt;
&lt;br /&gt;
Уроки в таблице сортируются по датам, сверху вниз по возрастанию, как и положено в бумажном журнале.&lt;br /&gt;
Под датой располагается значок редактирования информации об уроке, выполненный в виде ссылки. При щелчке по нему открывается новая страница с формой редактирования урока. Все поля формы заполнены соответствующей информацией. Ее можно изменить, а изменения сохранить.&lt;br /&gt;
Эта же страница открывается при щелчке по ссылке &amp;quot;Новый урок&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
=== Страница редактирования урока. ===&lt;br /&gt;
Вверху страницы, под строкой навигации, выводится надпись &amp;quot;Журнал группы&amp;quot;.&lt;br /&gt;
Ниже выводится форма ввода информации об уроке. &lt;br /&gt;
&lt;br /&gt;
Первой отображается секция создания события. Здесь можно выбрать создавать событие или нет (если создается тема без события), если да, то можно выбрать форму проведения урока (очно/дистанционно) и дату проведения. Если событие редактируется, то эти поля изменить нельзя. Если у пользователя нет прав для создания события, то данная секция не отображается.&lt;br /&gt;
&lt;br /&gt;
Следом идет секция для создания темы урока. Сначала мы выбираем как мы создаем тему:&lt;br /&gt;
* Не создавать новую тему - если событие создается без темы&lt;br /&gt;
* Выбрать тему из планирования - если к событию мы привязываем существующую уже созданную тему.&lt;br /&gt;
* Создать собственную тему - создает новую тему на планирование по учебному процессу&lt;br /&gt;
В третьем варианте, при создании новой темы пользователь может либо выбрать родительские темы, откуда он будет наследовать название своей темы (поле &amp;quot;Что пройдено на уроке&amp;quot;, необязательно к заполнению, но пользователь может ввести что-то свое), либо заполнить поле Что пройдено на уроке&amp;quot;. Далее пользователь заполняет все оставшееся поля по мере необходимости.&lt;br /&gt;
&lt;br /&gt;
В самом низу расположены две кнопки - &amp;quot;Сохранить&amp;quot; и &amp;quot;Отмена&amp;quot;. При нажатии на вторую происходит возврат на главную страницу журнала без сохранения внесенных изменений. После нажатия на кнопку &amp;quot;Сохранить&amp;quot; происходит сохранение введенных данных в соответствующих таблицах. О результатах операции сохранения информирует надпись, выводимая под кнопками. Еще ниже появляется ссылка &amp;quot;назад&amp;quot; для возврата на главную страницу журнала. В случае возврата после сохранения данных, таблица оценок загружается в режиме редактирования данных на дату только что сохраненного урока.&lt;br /&gt;
&lt;br /&gt;
Правее формы редактирования урока расположено окно с полосами прокрутки, в котором можно просмотреть темы уже проведенных уроков.&lt;br /&gt;
Они выводятся в видет таблицы из трех столбцов, в которых указываются соответственно дата, тема урока и домашнее задание.&lt;br /&gt;
&lt;br /&gt;
В зависимости от заполненности полей ввода возможны разные варианты обработки введенных данных.&lt;br /&gt;
&lt;br /&gt;
{|border=1&lt;br /&gt;
 |id темы&lt;br /&gt;
 |id события&lt;br /&gt;
 |создание события&lt;br /&gt;
 |создание темы&lt;br /&gt;
 |как обрабатывается&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |ничего не создается&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |ничего не создается. Форма подгружает выбранную тему для редактирования&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы с указанными пользователем данными без события&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |создается новое событие с указанными пользователем данными без темы&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |создается новое событие с указанными пользователем данными и привязкой к выбранной теме&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |0&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы и новая темы с указанными пользователем данными связанные друг с другом&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Не создавать новую тему&lt;br /&gt;
 |ничего не создается и не редактируется&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Выбрать тему из планирования&lt;br /&gt;
 |Выбранная тема привязывается к указанному событию&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |0&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |выбрано: Создать собственную тему&lt;br /&gt;
 |создается новая темы с указанными пользователем данными и привязывается к указанному событию&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |существующая&lt;br /&gt;
 |не выбрано&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |редактируется указанная тема&lt;br /&gt;
 |-&lt;br /&gt;
 |0&lt;br /&gt;
 |существующая&lt;br /&gt;
 |выбрано&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |создается новое событие с указанными пользователем данными, к которому привязывается указанная тема. Тему можно отредактировать&lt;br /&gt;
 |-&lt;br /&gt;
 |существующая&lt;br /&gt;
 |существующая&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |нет выбора&lt;br /&gt;
 |редактируется указанная тема, событие не редактируется&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
=== Ведомость итоговых оценок ===&lt;br /&gt;
На данной странице можно выставить итоговые оценки учащимся и завершить обучение потока. Страница принимает обязательный параметр id - id идущего  или завершенного потока.&lt;br /&gt;
&lt;br /&gt;
Вверху страныцы отображается форма, где отображены ученики, которые обучаются на данном потоке. Напротив каждого можно выбрать итоговую оценку, выставляемую учащемуся. Итоговые оценки берутся из шкалы дисциплины приписанной к данному потоку. Под ведомостью стоит галочка подтвержения оценок, без нее оценки не сохранятся. Делее стоит галочка завершения обучения если необходимо завершить поток, При завершении потока все подписки на дисциплину переводятся в один из конечных статусов. Если поток уже завершен, то галочка не показывается, вместо нее предупреждение. После завершения потока оценки также можно выставить, но они уже будут идти как переэкзаменовка. &lt;br /&gt;
&lt;br /&gt;
После того как мы выставили оценки и нажали на кнопку сохранить формируется приказ о выставленни итоговых оценок. На основе этого приказа сохраняются оценки, после чего на новой странице показывается шаблон ведомости в том виде, в котом она будет распечатана. &lt;br /&gt;
После первого сохранения оценок эта ведомость также становится доступна для печати. &lt;br /&gt;
&lt;br /&gt;
Перейти на эту страницу можно со страницы Журнала группы.&lt;br /&gt;
&lt;br /&gt;
== Отчеты ==&lt;br /&gt;
=== Отчеты о фактической нагрузке ===&lt;br /&gt;
&lt;br /&gt;
Позволяют просмотреть статистику о нагрузке учителей за определенный период. [[ Разработка:im/reports#Отчеты о фактической нагрузке | Подробнее ]]&lt;br /&gt;
&lt;br /&gt;
=== Отчеты по замененным урокам ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Приказы ==&lt;br /&gt;
=== Приказ о закрытии зарплатного периода ===&lt;br /&gt;
&lt;br /&gt;
==== Структура приказа о закрытии зарплатного периода ====&lt;br /&gt;
Данные приказа:&lt;br /&gt;
* reportid - id сформированного [[ Разработка:im/reports#Отчеты о фактической нагрузке | отчета по фактической нагркзке ]]&lt;br /&gt;
&lt;br /&gt;
==== Формирование приказа о переводе ====&lt;br /&gt;
При формировании приказа также формируется отчет по фактической нагрузке с тем же указанным промежутком и в тоже указанное время исполнение, что и в приказе. &lt;br /&gt;
&lt;br /&gt;
==== Подписание приказа о переводе ====&lt;br /&gt;
Подписание приказа происходит сразу же после его формирование.&lt;br /&gt;
&lt;br /&gt;
=== Исполнение приказа о переводе ===&lt;br /&gt;
По крону. Возможно позже будет реализовано вручную.&lt;br /&gt;
&lt;br /&gt;
Генерирует приказ по фактической нагрузке. После этого фиксирует все дни подразделения и его дочерних подразделений.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== События ==&lt;br /&gt;
* itog_grade_was_set - генерируется во время выставления итоговой оценки не зависимо от того, происходит первичное выставление оценки или повторное через ведомость пересдачи&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Уведомления ==&lt;br /&gt;
&lt;br /&gt;
==== Уведомление учащегося об оценке ====&lt;br /&gt;
&lt;br /&gt;
Отправка уведомлений после выставления оценки в электронном деканате осуществляется в случае, если включена настройка в подразделении.&lt;br /&gt;
&lt;br /&gt;
Для отправки уведомлений об оценке полученной впервые по дисциплине, необходимо установить настройку send_grade_notification в значение 1. В качестве темы письма будет использоваться текст из настройки grade_notification_subject, в качестве основного текста письма будет использована настройка grade_notification_text.&lt;br /&gt;
&lt;br /&gt;
Для отправки уведомления об оценке полученной через ведомость пересдачи, необходимо установить настройку send_reoffset_notification в значение 1. В качестве темы письма будет использоваться текст из настройки reoffset_notification_subject, в качестве основного текста письма будет использована настройка reoffset_notification_text.&lt;br /&gt;
&lt;br /&gt;
В теме и тексте письма можно использовать следующие подстановки:&lt;br /&gt;
* [PERSONFULLNAME] - ФИО учащегося&lt;br /&gt;
* [DISCIPLINE] - Наименование дисциплины&lt;br /&gt;
* [GRADE] - полученная оценка&lt;br /&gt;
&lt;br /&gt;
=Права=&lt;br /&gt;
&lt;br /&gt;
* '''datamanage''' - глобальное право (администратор)&lt;br /&gt;
* '''view_journal''' - право на просмотр журнала учебного процесса (учитель курса или завуч)&lt;br /&gt;
* '''view_all_journals''' - право на просмотр всех журналов (может просматривать общую информацию и личные данные)&lt;br /&gt;
* '''view_all_journals_department''' - право на просмотр всех журналов подразделения (может просматривать общую информацию и личные данные)&lt;br /&gt;
* '''can_complete_lesson''' - право отметить проведение урока (учитель урока или завуч)&lt;br /&gt;
* '''create_schevent''' - право на создание события (завуч и учитель на потоке, если есть переменная в конфиге)&lt;br /&gt;
* '''control_journal''' - право на проверку журнала (завуч)&lt;br /&gt;
* '''give_grade''' - право на выставление оценки (учитель на потоке или завуч)&lt;br /&gt;
* '''give_itog_grades''' - право выставить итоговые оценки (поток завершён и пользователь - учитель на потоке)&lt;br /&gt;
* '''view_events''' - право просматривать свое расписание (учитель)&lt;br /&gt;
* '''give_attendance''' - право на отметку посещаемости (учитель урока или завуч)&lt;br /&gt;
* '''give_theme_event''' - право указать тему для события (только событие в статусе &amp;quot;запланирован&amp;quot; или &amp;quot;отложено на неопределенный срок&amp;quot;, а пользователь - завуч или учитель потока)&lt;br /&gt;
* '''edit_plans''' - право редактировать КТ (КТ не &amp;quot;зафиксирована&amp;quot; и ((КТ завершена или событие состоялось), а пользователь - завуч) или пользователь может выставлять оценки)&lt;br /&gt;
* '''replace_schevent''' - право формирование замены события (учитель на потоке или завуч)&lt;br /&gt;
&lt;br /&gt;
= API =&lt;br /&gt;
В этом разделе описаны функции для работы со страницами &amp;quot;журнал группы&amp;quot; и &amp;quot;список журналов&amp;quot;. Здесь содержится только краткое описание функций и их параметров. Если вас интересует их внутренняя логика, то обратитесь к разделу [[Разработка:im/journal#Подробное описание работы функций|Подробное описание]]. Аргументы всех функций перечислены именно в том порядке, в котором их следует передавать.&lt;br /&gt;
=== Журнал группы ===&lt;br /&gt;
В этом разделе собраны все функции, которые относятся к странице &amp;quot;журнал группы&amp;quot;&lt;br /&gt;
==== Класс dof_im_journal_tablegrades ====&lt;br /&gt;
Класс отрисовки школьного журнала&lt;br /&gt;
===== print_texttable() =====&lt;br /&gt;
Вывести страницу журнала - просмотр оценок, или редактирование&lt;br /&gt;
&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $editid  - id редактируемого учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $eventid - id учебного события, которое будет редактировано (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* null&lt;br /&gt;
===== check_permissions() =====&lt;br /&gt;
Проверяет разрешения на редактирование оценок для текущего пользователя&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true/false - есть или нет разрешения на редактирование оценок&lt;br /&gt;
==== Класс dof_im_journal_templans_table ====&lt;br /&gt;
Класс для отрисовки таблицы тематического планирования в классном журнале&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
 &lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== print_table() =====&lt;br /&gt;
Выводит таблицу тематического планирования на экран&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
*  true если операция вывода прошла успешно, или false если при выводе возникли ошибки&lt;br /&gt;
==== Класс dof_im_journal_edittopic ====&lt;br /&gt;
Класс для создания или редактирования одной темы на странице планирования уроков&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:''&lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $planid - id элемента учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
* $eventid - id учебного события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== get_topic() =====&lt;br /&gt;
Возвращает объект с полями, необходимыми для заполнения формы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* object - объект с полями для вставки в форму, или false в случае ошибки&lt;br /&gt;
===== create_topic() =====&lt;br /&gt;
Создает новый элемент тематического планирования&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $checkpoint - контрольная точка из таблицы [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $event - заранее заготовленный объект для таблицы [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи из таблицы schevents или false в случае ошибки&lt;br /&gt;
===== save_topic() =====&lt;br /&gt;
Обновляет существующий или создает новый элемент тематического планирования&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $checkpoint (object) - объект для обновления или создания записи в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $event (object) - объект для обновления или создания записи в таблице [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true, если все записи успешно обновлены&lt;br /&gt;
* (int), id новой записи, если она была добавлена&lt;br /&gt;
* false в случае ошибки&lt;br /&gt;
===== print_table() =====&lt;br /&gt;
Формирует таблицу тематического планирования в правой части страницы журнала&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
*  true если операция вывода прошла успешно, или false если при выводе возникли ошибки&lt;br /&gt;
===== get_anchor_id() =====&lt;br /&gt;
Возвращает метку времени, которая будет создана для нового урока, чтобы осуществить корректное перенаправление на страницу журнала&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $time - (int) время создания нового события: метка времени в формате unixtime&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - метка времени для перенаправления&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_rawdata ====&lt;br /&gt;
Класс для подготовки сырых исходных данных для формирования школьного журнала и ему подобных документов&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
Конструктор - определяет с каким учебным потоком будет вестись работа&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_process_gradesform ====&lt;br /&gt;
Класс для проверки и обработки оценок из формы&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
Конструктор класса. Осуществляет все проверки и записывает данные во внутреннее поле.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $gradedata (array) - массив $_POST из формы&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== process_form() =====&lt;br /&gt;
Обработать все данные, пришедшие из формы: установить посещаемость, выставить оценки и сформировать приказы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* false в случае неудачи. В случае успеха производит редирект на страницу журнала&lt;br /&gt;
==== Класс dof_im_journal_presence ====&lt;br /&gt;
Класс для обработки информации о посещаемости &lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $csid - id учебного потока&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
===== presence_students() =====&lt;br /&gt;
Формирует массив присутствия учеников&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* массив вида [id_ученика]=&amp;gt;статус_присутствия&lt;br /&gt;
===== absence_students() =====&lt;br /&gt;
Формирует массив отсутствующих студентов&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $away - массив id отсутствующих учеников&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* массив вида [id_ученика]=&amp;gt;статус_присутствия&lt;br /&gt;
==== Дополнительные функции ====&lt;br /&gt;
===== dof_im_journal_format_date() =====&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date (int) - метка времення для преобразования.&lt;br /&gt;
* $format (string) - формат выводимой даты. По умолчанию 'dmy'.&lt;br /&gt;
* $url (string) - Указывается, если необходимо получить дату как ссылку. По умолчанию NULL&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) строка с отформатированной датой&lt;br /&gt;
===== dof_im_journal_date_edit() =====&lt;br /&gt;
Возвращает отформатироанную дату и значок редактирования как ссылку&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date (int) - метка времени&lt;br /&gt;
* $format (string) - формат выводимой даты. По умолчанию 'dmy'&lt;br /&gt;
* $durl (string) - путь ссылки для даты, если не указана - дата выводится как просто строка. По умолчанию null.&lt;br /&gt;
* $eurl (string) - путь ссылки для значка, если не указана значок не показывается По умолчанию null.&lt;br /&gt;
* $imgsubdate (bool) - вывести значок под датой или рядом по умолчанию true (выводит значок под датой)&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - строка с отформатированной датой&lt;br /&gt;
=== Список журналов ===&lt;br /&gt;
==== Класс dof_im_journal_listjournals ====&lt;br /&gt;
Этот класс содержит функции для работы со страницей списка журналов&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
===== set_data() =====&lt;br /&gt;
Заполняет начальной информацией внутренние поля объекта&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid (int) - id подразделения (таблица [[Разработка:storages/departments|departments]]). По умолчанию 0.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true если все нормально или false в случае ошибки&lt;br /&gt;
===== get_data() =====&lt;br /&gt;
Возвращает собранные данные&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - массив структурных подразделений&lt;br /&gt;
===== get_journals() =====&lt;br /&gt;
Получить все журнлы занесенных подразделений&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true если все нормально или false в случае ошибки&lt;br /&gt;
&lt;br /&gt;
=== Журнал занятий ===&lt;br /&gt;
==== Класс dof_im_journal_show_events ====&lt;br /&gt;
Этот класс содержит функции для работы с журналом занятий&lt;br /&gt;
===== __construct() =====&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $depid - идентификатор подразделения&lt;br /&gt;
''Возвращаемые значения:'' нет&lt;br /&gt;
&lt;br /&gt;
===== set_data =====&lt;br /&gt;
Заполняет параметры класса начальной информацией&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $date - массив, состоящий из даты начала и даты окончания:&lt;br /&gt;
** [date_from] - дата начала&lt;br /&gt;
** [date_to] - дата окончания&lt;br /&gt;
* $teacherid - идентификатор преподавателя&lt;br /&gt;
* $studentid - идентификатор студента&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true если операция прошла успешно&lt;br /&gt;
&lt;br /&gt;
===== get_string_event =====&lt;br /&gt;
Получение строки для вывода одного занятия. &lt;br /&gt;
При проверке статуса события, выполняется проверка статуса на момент проведения самого события&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event - объект события&lt;br /&gt;
* $show_all - вывод подробной таблицы&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив для строчки события&lt;br /&gt;
&lt;br /&gt;
===== get_table_events =====&lt;br /&gt;
Возвращает события одного дня&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $display - ражим отображения(по времени, по учителям, по ученикам)&lt;br /&gt;
** [time] - по времени&lt;br /&gt;
** [students] - по ученикам&lt;br /&gt;
** [teachers] - по учителям&lt;br /&gt;
* $show_all - вывод подробной таблицы&lt;br /&gt;
* $implied - вывод мнимых событий&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_table_unmarked_events =====&lt;br /&gt;
Возвращает события одного дня&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $display - ражим отображения(по времени, по учителям, по ученикам)&lt;br /&gt;
** [time] - по времени&lt;br /&gt;
** [students] - по ученикам&lt;br /&gt;
** [teachers] - по учителям&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_string_appointment =====&lt;br /&gt;
Получение строки для вывода одного предмето-класса&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $cstream - объект учебного процесса (предмето-класса)&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив для строчки события&lt;br /&gt;
&lt;br /&gt;
===== get_table_teaching_load =====&lt;br /&gt;
Возвращает учебную нагрузку учителя&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
''Возвращаемые значения:'' array - набор журналов или bool - false&lt;br /&gt;
&lt;br /&gt;
===== get_data_for_export =====&lt;br /&gt;
Сбор данных для экспорта в csv&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
''Возвращаемые значения:'' &lt;br /&gt;
* array - данные для экспорта&lt;br /&gt;
&lt;br /&gt;
===== get_string_for_export =====&lt;br /&gt;
Создание массива данных об учениках&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event - объект урока&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array - массив с данными&lt;br /&gt;
&lt;br /&gt;
== Подробное описание работы функций ==&lt;br /&gt;
В этом разделе описывается подробная работа всех публичных и внутренних методов для классов журнала. Если вам требуется только краткая справка по API, то обратитесь к разделу [[Разработка:im/journal#API|API]].&lt;br /&gt;
=== Для журнала группы ===&lt;br /&gt;
==== Класс dof_im_journal_tablegrades ====&lt;br /&gt;
&lt;br /&gt;
===== Описание print_texttable() =====&lt;br /&gt;
[[#print_texttable()|Описание API]].&lt;br /&gt;
&lt;br /&gt;
Итоговая функция, выводящая всю собранную информацию на экран. &lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# собирает всю информацию при помощи функции [[Разработка:im/journal#Описание get_all_form()|get_all_form()]]&lt;br /&gt;
# обращается к плагину templater для представления информации в html-формате&lt;br /&gt;
# функцией print выводит результат работы templater'а на экран.&lt;br /&gt;
===== Описание check_permissions() =====&lt;br /&gt;
[[#check_permissions()|Описание API]].&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем учебный поток. Если поток не найден - возвращаем false.&lt;br /&gt;
# проверяем статус учебного потока. Если он не равен значению &amp;quot;go&amp;quot;, то возвращаем false.&lt;br /&gt;
# проверяем, имеет ли текущий пользователь права редактирования. Если нет, то возвращаем false.&lt;br /&gt;
# если все проверки пройдены успешно, то возвращаем true.&lt;br /&gt;
===== Описание get_all_form() =====&lt;br /&gt;
Возвращает объект формы для вставки в templater. Таблица в шаблоне формируется по столбцам, т. е. сначала выводится контрольная точка в тем. планировании, а затем оценки всех учеников за это событие (как при заполнении обычного школьного журнала).&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $editid (int) - id редактируемого учебного плана в таблице [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $eventid (int) - id редактируемого учебного события в таблице [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) объект нужной структуры для построения шаблона&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# собираем в объект все стандартные надписи для таблицы&lt;br /&gt;
# собираем все запланированные активные контрольные точки учебного потока&lt;br /&gt;
# создадим массивы для названий месяцев и дат&lt;br /&gt;
# собираем в массив информацию по ученикам. Если параметр $editid не равен нулю, то в столбце оценок для редактируемой даты вместо оценки выводим форму.&lt;br /&gt;
# собираем в результурующий массив названия месяцев и дат &lt;br /&gt;
# если нужно распечатать форму - устанавливаем стандартные html-теги начала и конца формы&lt;br /&gt;
# возвращаем результат&lt;br /&gt;
&lt;br /&gt;
===== Описание get_cell_form() =====&lt;br /&gt;
Возвращает редактируемую ячейку таблицы журнала.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons.&lt;br /&gt;
* $cpassedid (int) - id учебной программы&lt;br /&gt;
* $oldgrade (int) - старая оценка (если есть). По умолчанию null.&lt;br /&gt;
* $gradeid (int) - id оценки в таблице cpgrades . По умолчанию 0&lt;br /&gt;
* $eventid (int) - id учебного события в таблице [[Разработка:storages/schevents|schevents]].&lt;br /&gt;
* $scale (string) - шкала всех возможных оценок через запятую. По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - строка с html-кодом формы редактирования оценки.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
Вся форма редактирования оценки представляет собой маленькую таблицу. С левой стороны находится форма выбора оценки, а справа галочка для отметки отсутствующего ученика (верхняя ячейка) и пояснение к ней (нижняя ячейка).&lt;br /&gt;
# получаем все допустимые варианты оценок для данного задания из параметра scale.&lt;br /&gt;
# из этих вариантов оценки составляем html-элемент формы типа SELECT.&lt;br /&gt;
# если за задание уже есть ранее выставленная, старая оценка, то делаем ее оценкой по умолчанию&lt;br /&gt;
# узнаем статус присутствия ученика на занятии, и в зависимсости от этого проставляем галочку над буквой &amp;quot;н&amp;quot;. Форма с возможностью отмечания отсутствующих учеников отображается только для контрольных точек для которых есть события.&lt;br /&gt;
# возвращаем результат одной строкой.&lt;br /&gt;
===== Описание get_cell_string() =====&lt;br /&gt;
Получить текстовое содержимое ячейки оценки.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons&lt;br /&gt;
* $plan (object) - объект содержащий данные об элементе тематического планирования (таблица [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $gradedata (object) - данные об оценке По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) html-код оценки, либо специальный знак пробела, чтобы в таблице было видно пустую ячейку&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
# узнаем данные о посещаемости: получаем id события, если оно есть&lt;br /&gt;
#* если событие есть, узнаем, был ли ученик на занятии&lt;br /&gt;
# находим оценку&lt;br /&gt;
#* если ученик был на занятии и получил оценку - выводим оценку&lt;br /&gt;
#* если ученик был на занятии и не получил оценку - выводим символ пробела&lt;br /&gt;
#* если ученик отсутствовал на занятии и нет оценки, то выводим букву &amp;quot;н&amp;quot;&lt;br /&gt;
#* если ученик отсутствовал на занятии и получил оценку - выводим оценку, и букву &amp;quot;н&amp;quot; рядом с ней&lt;br /&gt;
&lt;br /&gt;
===== Описание get_one_cell() =====&lt;br /&gt;
Возвращает данные в одной клетке журнала. Определяет какой тип ячейки выводить: для редактирования или текстовую.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $studentid (int) - id ученика в таблице persons&lt;br /&gt;
* $plan (object) - объект содержащий контрольную точку с событием  из тем. планирования (таблица [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $gradedata (object) - объект содержащий данные об оценке (таблица cpgrades)&lt;br /&gt;
* $cpassedid (int) - id подписки (таблица cpassed)&lt;br /&gt;
* $editid (int) - id редактируемого в текущий момент элемента из тем. планирования&lt;br /&gt;
* $eventid (int) - id редактируемого в текущий момент события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
* $scale (string) = По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) строка с html-кодом формы редактирования оценки, либо сама оценка, либо статус &amp;quot;отсутствовал&amp;quot;&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# сравниваем, совпадают ли id выводимой и редактируемой в данной момент контрольной точки&lt;br /&gt;
#* если id совпадают - то выводим форму редактирования оценки&lt;br /&gt;
#** если за это задание оценка уже была ранее выставлена, то выводим форму с установленной ранее оценкой&lt;br /&gt;
#** если за задание еще нет оценки - то выводим форму без предустановленных значений&lt;br /&gt;
#* если id не совпадают то выводим оценку текстом (либо статус &amp;quot;отсутствовал&amp;quot;, либо пустую клетку, в зависимости от того был ли ученик на уроке, и получил ли он оценку)&lt;br /&gt;
===== Описание get_line_for_student() =====&lt;br /&gt;
Возвращает строку таблицы журнала для одного ученика.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $i (int) - порядковый номер ученика в группе&lt;br /&gt;
* $student (object) - объект с данными об ученике из таблицы persons&lt;br /&gt;
* $cpasseds (array) - массив объектов, содержащий все подписки учеников этого потока&lt;br /&gt;
* $plans (array) -  массив объектов, содержащий все контрольные точки текущего курса (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $editid (int) - id редактируемой в данный момент контрольной точки&lt;br /&gt;
* $eventid (int) - id редактируемого в данный момент события (или 0, если события нет) Таблица [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - информация об ученике: его ФИО, и оценки по всем контрольным точкам, а также сведения о посещаемости&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект для итоговых данных&lt;br /&gt;
# записываем в соответствующие поля итогового объекта порядковый номер ученика, и его ФИО&lt;br /&gt;
# перебираем все переданные подписки ищем ту, которая относится к переданному ученику&lt;br /&gt;
# записываем в итоговый объект id его подписки&lt;br /&gt;
# создаем массив для оценок и собираем оценки ученика:&lt;br /&gt;
#* перебираем все контрольные переданные точки ($plans)&lt;br /&gt;
#* для каждой контрольной точки создаем объект оценки&lt;br /&gt;
#* получаем значение оценки за просматриваемую контрольную точку&lt;br /&gt;
#* при помощи функции [[Разработка:im/journal#Описание get_one_cell()|get_one_cell()]] получаем оформленный html-код оценки&lt;br /&gt;
#* записываем полученный объект в массив оценок&lt;br /&gt;
# добавляем массив оценок в итоговый объект&lt;br /&gt;
# возвращаем итоговый объект&lt;br /&gt;
===== Описание get_lines_for_students() =====&lt;br /&gt;
Возвращает массив строк с ФИО и оценками для всех учеников&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans (array) - массив всех контрольных точек учебного потока из таблицы plans&lt;br /&gt;
* $editid (int) - id редактируемой в данный момент контрольной точки (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
* $eventid (int) - id редактируемого в данный момент события (таблица [[Разработка:storages/schevents|schevents]])&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) информация о всех учениках учебного потока или false, если ни одного ученика нет&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все подписки учебного потока, чтобы потом установить связи с оценками&lt;br /&gt;
# получаем учеников учебного потока&lt;br /&gt;
# присваиваем каждому ученику порядковый номер,&lt;br /&gt;
# получаем информацию по каждому ученику функцией [[#Описание get_line_for_student()|get_line_for_student()]] и заносим объект с информацией о нем в массив&lt;br /&gt;
# возвращаем получившийся массив &lt;br /&gt;
===== Описание create_datesstring() =====&lt;br /&gt;
Создает верхнюю строку журнала с названиями месяцев и списком дат в пригодном для обработки плагином templater виде.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans - список всех контрольных точек учебного потока из таблицы [[Разработка:storages/plans|plans]].&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект, содержащий массив с данными для шаблонизатора&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
&lt;br /&gt;
Даты в электронном журнале должны будут проставляться как и в обычном классном журнале: верхняя строка - месяцы обучения, нижняя строка - даты проведенных или запланированных уроков, а также четвертные или годовые оценки.&lt;br /&gt;
Для того чтобы организовать такой внешний вид для электронного журнала мы должны воспользоваться параметром colspan для html-таблицы журнала, и расположить тем самым месяцы точно над датами проведенных уроков. Для этой задачи в этой функции мы создаем объект следующей структуры:&lt;br /&gt;
* ''(возвращаемый объект)''&lt;br /&gt;
** ''monthtitle'' - массив объектов, каждый из которых имеет свойства ''mtitle'' - название месяца, и ''mcolspan'' - количество ячеек с датами проведенных уроков в этом месяце&lt;br /&gt;
** ''monthdate'' - строка с датой проведенного урока, либо название контрольной точки.&lt;br /&gt;
&lt;br /&gt;
# получаем строку форматированных дат уроков при помощи функции [[#Описание generate_all_dates()|generate_all_dates()]]&lt;br /&gt;
# перебираем все события и собираем массивы дат и названий месяцев&lt;br /&gt;
#* если просматриваемая дата не находится в том же месяце, что и предыдущая, то дополняем массив месяцев&lt;br /&gt;
# прибавляем счетчик дат в месяце&lt;br /&gt;
# записываем новую дату в итоговый массив&lt;br /&gt;
# возвращаем итоговый массив&lt;br /&gt;
===== Описание generate_all_dates() =====&lt;br /&gt;
Вызывается из [[#Описание create_datesstring()|create_datesstring()]]. Получить отформатированные даты для журнала&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plans - массив всех контрольных точек учебного потока (из таблицы [[Разработка:storages/plans|plans]])&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - отформатированные даты для вывода в журнал&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получим событие из таблицы schevents, которое относится к данной теме тематического планирования&lt;br /&gt;
# если событие есть - то покажем дату&lt;br /&gt;
# если события нет - только название контрольной точки&lt;br /&gt;
&lt;br /&gt;
===== Описание generate_single_date() =====&lt;br /&gt;
Вызывается из [[#Описание generate_all_dates|generate_all_dates]] Создает один объект даты для журнала.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $plan (object) - объект из таблицы [[Разработка:storages/plans|plans]]&lt;br /&gt;
* $date (string) - метка времени для события или контрольной точки&lt;br /&gt;
* $event (object) - Объект из таблицы [[Разработка:storages/schevents|schevents]]. По умолчанию null.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) дата в нужном для templater'a формате&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# устанавливаем путь (html-якорь) к теме в планирования на странице&lt;br /&gt;
# Определяем, id события которое будет редактировано. Если события нет, то передаем 0.&lt;br /&gt;
# записываем якорь с ссылкой в объект&lt;br /&gt;
# возвращаем объект&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_im_journal_templans_table ====&lt;br /&gt;
===== Описание get_topics() =====&lt;br /&gt;
Возвращает массив объектов c необходимыми свойствами для вставки в таблицу schevents&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив тем входящих в планирование&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все контрольные точки учебного потока&lt;br /&gt;
# формируем объект с нужными полями для каждой контрольной точки&lt;br /&gt;
# возвращаем получившийся массив объектов&lt;br /&gt;
===== Описание get_empty_topic() =====&lt;br /&gt;
Возвращает &amp;quot;пустой&amp;quot; объект отчета об уроке &lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект для вставки в таблицу [[Разработка:storages/schevents|schevents]]&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* создаем объект с необходимым списком пустых полей и возвращаем его&lt;br /&gt;
===== Описание table_data() =====&lt;br /&gt;
Возвращает массив строк данных отформатированных для вывода с помощью moodle-функции print_table()&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив с данными для распечатки таблицы, либо false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли для переданного потока элементы тематического планирования.&lt;br /&gt;
#* если их нет - то возвращаем false&lt;br /&gt;
# формируем массив строк таблицы&lt;br /&gt;
# проставляем html-якоря для каждой контрольной точки на странице оценок&lt;br /&gt;
# добавляем ссылки на редактирования элементов учебного плана&lt;br /&gt;
# возвращаем получившийся массив&lt;br /&gt;
==== Класс dof_im_journal_edittopic ====&lt;br /&gt;
===== Описание get_topic() =====&lt;br /&gt;
[[#get_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* Проверяем, указан ли id контрольной точки. &lt;br /&gt;
** Если не указан - возврящаем пустую тему.&lt;br /&gt;
** Если указан - пробуем извлечь контрольную точку по такому id&lt;br /&gt;
*** Если контрольную точку извлечь не удалось - то возвращаем false&lt;br /&gt;
*** Если удалось - то возвращаем заполненный отчет об уроке&lt;br /&gt;
===== Описание save_topic() =====&lt;br /&gt;
[[#save_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем есть ли у нас данные в переменной $event для обновления или создания события. Если нет - то возвращаем false.&lt;br /&gt;
# определяем тип действия, которое надо совершить&lt;br /&gt;
#* если указан planid для события - то создаем новое событие для существующей контрольной точки&lt;br /&gt;
#* если нет id для контрольной точки - создаем новое событие и новую контрольную точку&lt;br /&gt;
#* в остальных случаях - обновляем контрольную точку и событие: вычисляем новую относительную дату, и обновляем записи в таблицах [[Разработка:storages/schevents|schevents]] и [[Разработка:storages/plans|plans]]&lt;br /&gt;
===== Описание create_topic() =====&lt;br /&gt;
[[#create_topic()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем новый элемент тематического планирования в таблице plans (если это не удалось - то возвращаем false)&lt;br /&gt;
# добавляем в переданное событие id контрольной точки&lt;br /&gt;
# создаем событие из переданного объекта $event (если событие не создано - удаляем ранее созданный элемент тематического планирования)&lt;br /&gt;
# возвращаем id события&lt;br /&gt;
===== Описание create_checkpoint() =====&lt;br /&gt;
Создает и сохраняет запись в таблице plans&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $point (object) - данные для сохранения в таблицу [[Разработка:storages/plans|plans]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи или false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли у нас все необходимые для создания записи&lt;br /&gt;
# получаем id учебного потока&lt;br /&gt;
# получаем дату начала обучения&lt;br /&gt;
# создаем заготовку для объекта контрольной точки&lt;br /&gt;
# вычисляем относительную дату контрольной точки&lt;br /&gt;
# заносим данные в базу&lt;br /&gt;
===== Описание create_event() =====&lt;br /&gt;
Создает объект события и сохраняет его в schevents&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $event (object) - данные для сохранения&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id новой записи в таблице событий или false.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# проверяем, есть ли у нас все необходимые для создания записи&lt;br /&gt;
# получаем id учебного потока&lt;br /&gt;
# получаем id преподавателя в таблице persons&lt;br /&gt;
# создаем объект нужного формата и заносим туда все данные&lt;br /&gt;
# записываем данные в базу&lt;br /&gt;
==== Класс dof_im_journal_rawdata ====&lt;br /&gt;
''Поля:''&lt;br /&gt;
* dof - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* csid - id учебного потока в таблице сstreams&lt;br /&gt;
===== Описание get_checkpoints() =====&lt;br /&gt;
Получить все контрольные точки одного учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - массив объектов из таблицы plans или false &lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем id учебного потока из таблицы cstreams&lt;br /&gt;
# выбираем из таблицы plans все записи, у которых поле cstreamid равно id учебного потока, и тип связи &amp;quot;cstreams&amp;quot;&lt;br /&gt;
# сортируем их в хронологическом порядке&lt;br /&gt;
# возвращаем получившийся массив&lt;br /&gt;
&lt;br /&gt;
===== Описание get_students() =====&lt;br /&gt;
Получить всех учеников указанного учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив записей из таблицы persons или false&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем список пройденных дисциплин&lt;br /&gt;
# перебираем все подписки и запоминаем id ученика для каждой из них&lt;br /&gt;
# извлекаем из таблицы persons учеников, чьи id были извлечены из подписок&lt;br /&gt;
&lt;br /&gt;
===== Описание get_teacherid() =====&lt;br /&gt;
Получить id преподавателя учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (int) - id преподавателя или false в случае неудачи&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* id преподавателя всегда берется только из записи учебного потока из таблицы cstreams&lt;br /&gt;
==== Класс dof_im_journal_process_gradesform ====&lt;br /&gt;
''Поля:''&lt;br /&gt;
* gradedata - (object) все оценки и сопутствующая им информация&lt;br /&gt;
* mypost - (array) непроверенные данные пришедшие из массива $_POST. Используются только для составления повторного запроса на сохранение данных.&lt;br /&gt;
===== Описание __construct =====&lt;br /&gt;
[[#Класс dof_im_journal_rawdata|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект, в который мы будем складывать все проверенные данные, пришедшие из формы&lt;br /&gt;
# проверяем скалярные данные: все числовые идентификаторы, и отдельные строки, и после проверки записываем их в итоговый объект&lt;br /&gt;
# теперь, зная cstreamid из проверенных скалярных данных вызываем родительский конструктор&lt;br /&gt;
# проверяем массивы, пришедшие из формы: &lt;br /&gt;
#* данные об отсутствующих учениках&lt;br /&gt;
#* массив оценок &lt;br /&gt;
#* массив идентификаторов подписок (таблица cpassed)&lt;br /&gt;
#* узнаем id оценок для изменения их статуса&lt;br /&gt;
# записываем все проверенные данные в итоговый массив&lt;br /&gt;
# определяем тип действия, которое надо совершить: &lt;br /&gt;
#* сохранить данные&lt;br /&gt;
#* сохранить данные и продолжить редактирование&lt;br /&gt;
#* восстановить исходные значения&lt;br /&gt;
# записываем исходный массив (непроверенный) в поле объекта, если потом понадобится еще раз отправить данные после подтверждения&lt;br /&gt;
===== Описание process_form() =====&lt;br /&gt;
[[#process_form()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# в самом начале проверяем тип действия, которое надо совершить. Если этим действием является &amp;quot;отменить изменения&amp;quot;, то не переходим к сохранению оценок и сразуже выполняем перенаправление на страницу журнала. В остальных случаях идем дальше:&lt;br /&gt;
# проверяем, установлено ли у кого-нибудь из учеников одновременно &amp;quot;н&amp;quot; и оценка. Если это так - то перенаправим пользователя на страницу с сообщением об этом, и попросим его подтвердить такой выбор.&lt;br /&gt;
#* если пользователь согласен с изменениями, которые он сделал, то все выставленые им оценки и сведения о посещаемости сохраняются&lt;br /&gt;
#* если же нет - то происходит отмена всех изменений&lt;br /&gt;
# в случае, когда никаких предупреждений нет - сначала формируем приказ для оценок&lt;br /&gt;
# затем приказ о посещаемости&lt;br /&gt;
# если все действия произведены успешно - производим редирект. Если же возникли ошибки - сообщаем об этом&lt;br /&gt;
&lt;br /&gt;
===== Описание generate_order_grades() =====&lt;br /&gt;
Сформировать приказ об изменении состояния учебного потока&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' нет&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* true если приказ успешно сформирован, и false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем id подразделения в таблице departments&lt;br /&gt;
# определяем тип действия, которое нужно совершить с оценкой&lt;br /&gt;
# обращаемся к функциям выставления, либо удаления оценки&lt;br /&gt;
===== Описание order_set_grade() =====&lt;br /&gt;
Формирует приказ - установить оценку. &lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid (int) - id подразделения в таблице [[Разработка:storages/departments|departments]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) true в случае успеха и false в случае неудачи&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# подключаем методы работы с приказом&lt;br /&gt;
# создаем объект для записи&lt;br /&gt;
# сохраняем автора приказа, подразделение, к которому он относится, дату создания приказа&lt;br /&gt;
# добавляем данные, которые определяют назначение приказа&lt;br /&gt;
# сохраняем приказ в БД, в таблицу orders&lt;br /&gt;
# подписываем приказ&lt;br /&gt;
# исполняем приказ&lt;br /&gt;
Методы order_delete_grade и order_update_grade работают по такому же принципу.&lt;br /&gt;
===== Описание get_grades_fororder() =====&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $type - тип действия, которое необходимо будет произвести над оценкой. Возможные значения: ''set_grade'' и ''delete_grade''.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) - объект, содержащий список оценок и все идентификаторы для формирования приказа.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# создаем объект для итоговых данных&lt;br /&gt;
# записываем в него дату, id учителя (в таблице persons) и id контрольной точки (в таблице plans&lt;br /&gt;
# перебираем все оценки из внутреннего массива с проверенными данными&lt;br /&gt;
# определяем тип действия, которое над ней нужно совершить&lt;br /&gt;
# в зависимости от типа действия (установление или удаление оценки) записываем в объект оценки нужные идентификаторы&lt;br /&gt;
# упаковываем оценки в итоговый массив и возвращаем его&lt;br /&gt;
=== Для списка журналов ===&lt;br /&gt;
==== Класс dof_im_journal_listjournals ====&lt;br /&gt;
Этот класс служит для сбора и вывода информации по всем структурным подразделениям. Информация выводится древовидно: самый верхний уровень - подразделение, затем учебные программы, затем учебные периоды, элементы учебной программы, и в самом конце - журналы учебного потока.&lt;br /&gt;
''Поля:''&lt;br /&gt;
* dof - - объект класса [[Разработка:lib/dof.php|dof_control]]&lt;br /&gt;
* $departments массив структуры&lt;br /&gt;
    array(&lt;br /&gt;
    [departmentid] =&amp;gt; obj  -&amp;gt; departmentname = 'department_name'&lt;br /&gt;
                      obj  -&amp;gt; programms = array(&lt;br /&gt;
      [programmid]   =&amp;gt; obj1 -&amp;gt; programmname = 'programm_name'&lt;br /&gt;
                        obj1 -&amp;gt; ages = array(&lt;br /&gt;
        [agenum]       =&amp;gt; obj2 -&amp;gt; agename = 'age_name'&lt;br /&gt;
                          obj2 -&amp;gt; items = array(&lt;br /&gt;
          [itemid]       =&amp;gt; obj3 -&amp;gt; itemname = 'item_name'&lt;br /&gt;
                            obj3 -&amp;gt; cstreams = array(&lt;br /&gt;
            [cstreamid]    =&amp;gt; obj4 -&amp;gt; cstreamname = 'cstream_name'&lt;br /&gt;
                                    )''// конец массива cstreams''&lt;br /&gt;
                                  )''// конец массива items''&lt;br /&gt;
                                )''// конец массива ages''&lt;br /&gt;
                              )''// конец массива programms''&lt;br /&gt;
         )''// конец общего массива''&lt;br /&gt;
    содержит данные для вставку в темплатер после добавления еще одного уровня:&lt;br /&gt;
    $fortemplater-&amp;gt;departments = $this-&amp;gt;departments;&lt;br /&gt;
В общем виде сбор данных выглядит так: &lt;br /&gt;
# сначала собирается информация по структурному подразделению (одному или нескольким), и информация по ним записывается в итоговый объект&lt;br /&gt;
# затем получаются все программы учебного подразделения, информация по ним записывается в итоговый массив&lt;br /&gt;
# извлекается и записывается в итоговый объект список учебных периодов &lt;br /&gt;
# для каждого учебного периода получаются элементы учебной программы, которые изучаются в нем&lt;br /&gt;
# для каждого элемента учебной программы получаются учебные потоки&lt;br /&gt;
# для каждого учебного потока получается его журнал&lt;br /&gt;
===== Описание set_data() =====&lt;br /&gt;
[[#set_data()|Описание API]]&lt;br /&gt;
&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
* получаем id структурного подразделения из таблицы departments.&lt;br /&gt;
** если оно есть - то получаем информацию только по нему&lt;br /&gt;
** если получили 0 вместо id подразделения - то выводим информацию по всем подразделениям&lt;br /&gt;
&lt;br /&gt;
===== Описание get_journals_department() =====&lt;br /&gt;
Возвращает журналы одного подразделения&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $departmentid - id подразделения в таблице [[Разработка:storages/departments|departments]]&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) - набор журналов &lt;br /&gt;
* (bool) - false в случае ошибки&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
# получаем все программы, за которые отвечает подразделение&lt;br /&gt;
# для каждой программы получаем все ее журналы&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:storages/programmitems&amp;diff=3034</id>
		<title>Разработка:storages/programmitems</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:storages/programmitems&amp;diff=3034"/>
				<updated>2017-04-13T09:52:52Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: /* Задания */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = programmitems&lt;br /&gt;
| type = storages&lt;br /&gt;
}}&lt;br /&gt;
=Таблица в базе данных=&lt;br /&gt;
''programmitems'' - элементы учебной программы - учебные дисциплины/предметы. &lt;br /&gt;
&lt;br /&gt;
====Подробный формат полей в таблице:====&lt;br /&gt;
* programmid - учебная программа в таблице [[Разработка:storages/programms | programms ]]&lt;br /&gt;
* agenum - номер учебного периода, от начала обучения по программе на который назначена дисциплина. Для необязательных дисциплин возможен 0, тогда студент может &amp;quot;взять&amp;quot; дисциплину в любом семестре.&lt;br /&gt;
* courseclsid - id по таблице coursecls (таблица пока не предусмотрена), предназначен для объединения однородных дисциплин. Однородность дисциплин может быть четырех уровней (записываются внутри таблицы coursecls): &lt;br /&gt;
** 1 - одинаковые дисциплины изучаемые в составе различных учебных программ, &lt;br /&gt;
** 2 - разные ступени изучения одной дисциплины, &lt;br /&gt;
** 3 - дисциплины, относящиеся к одной науке, &lt;br /&gt;
** 4 - категории (общественные, естественные, технические). Сама таблица coursecls пока не реализована, а поле зарезервировано на будущее.&lt;br /&gt;
* name - название дисциплины (текстовое поле)&lt;br /&gt;
* code - код дисциплины (текстовое поле, необязательное, при указании проверяется уникальность). Если код не указан - то вместо него подставляется id записи.&lt;br /&gt;
* mdlcourse - id курса в moodle&lt;br /&gt;
* type - тип предмета:&lt;br /&gt;
** ''required''- обязательный&lt;br /&gt;
** ''recommended'' - рекомендованный&lt;br /&gt;
** ''free'' - по выбору&lt;br /&gt;
* required - обязательный курс (0/1) На основании этого поля ориентируемся, нужно ли обязательно подписывать или нет, а предыдущий больше информационный. Например, даже обязательный курс, который планируется разделить на подгруппы может не требовать автоматической подписки.&lt;br /&gt;
* maxcredit - зачетные единицы трудоемкости (максимальное количество кредитов за курс, ЗЕТ)&lt;br /&gt;
* maxduration - максимальная продолжительность курса от начальной подписки (в секундах). Если не установлено - продолжительность неограничена.  Учебные потоки  всегда завершается автоматически с закрытием учебного периода, к которому они относятся.&lt;br /&gt;
* hours - часов всего&lt;br /&gt;
* hourstheory - часов лекций (Лек)&lt;br /&gt;
* hourspractice - часов практики (Пр)&lt;br /&gt;
* eduweeks - количество учебных недель/циклов (каждая соответствует одному циклу в расписании) продолжительности курса, если не указано, учебные процессы наследуют из ages.&lt;br /&gt;
* instrlevelid - id уровня компоненты - &lt;br /&gt;
** 1 - федеральная, &lt;br /&gt;
** 2 - региональная, &lt;br /&gt;
** 3 - учебного заведения, &lt;br /&gt;
** 4 - кафедры&lt;br /&gt;
* gradelevel - уровень оценки&lt;br /&gt;
** ''notused'' - оценка не идет в кондуит&lt;br /&gt;
** ''discipline'' - дисциплина&lt;br /&gt;
** ''coursework'' - курсовая работа&lt;br /&gt;
** ''practice'' - практика&lt;br /&gt;
** ''finalexam'' - междисциплинарный экзамен&lt;br /&gt;
** ''diplom'' - дипломная работа&lt;br /&gt;
* scale - диапазон или перечисленные через запятую возможной итоговой оценки, пустая строка если оценка не предусмотрена.  Оценка может быть и дробной. Диапазон задается двумя числами через дефис: худшая_оценка_-_лучшая_оценка_. Например 5-1. 5 - самый плохой балл. 1 - самый лучший. Если задается не диапазон, а интервал, то оценки перечисляются через запятую: 5, 4.5, 4, 3.5, 3, 2.5, 2, 1.5, 1.&lt;br /&gt;
* mingrade - минимальная (для диапазона) или начальная слева-направа начиная с единицы (для перечисления) оценка, при которой курс считается завершенным. Если не указано, курс считается завершенным при выставлении любой оценки.&lt;br /&gt;
* sname - название в источнике/стандарте&lt;br /&gt;
* scode - код в источнике/стандарте&lt;br /&gt;
* status - список статусов указан в одноименном плагине рабочих процессов  [[Разработка:workflows/programmitems | programmitems ]] &lt;br /&gt;
* departmentid - структурное подразделение в таблице [[Разработка:storages/departments | departments ]], ответственное за реализацию дисциплины&lt;br /&gt;
* about - описание дисциплины&lt;br /&gt;
* notice - заметка о дисциплины для внутреннего пользования&lt;br /&gt;
* controltypeid - тип итогового контроля по данному курсу&lt;br /&gt;
* hoursweek - часов в неделю&lt;br /&gt;
* explanatory - пояснительная записка&lt;br /&gt;
* gradesyncenabled - разрешать синхронизацию оценок для данной дисциплины&lt;br /&gt;
* incjournwithoutgrade - при синхронизации оценок вносить в ведомость на момент ее заполнения студентов не имеющих оценки&lt;br /&gt;
* incjournwithunsatisfgrade - при синхронизации оценок вносить в ведомость на момент ее заполнения студентов имеющих неудовлетворительные оценки&lt;br /&gt;
* altgradeitem - id из grades_items (если не указано, то при синхронизации оценок берется оценка из итоговой оценки курса, который указан в mdlcourse)&lt;br /&gt;
* metasyncon - включена ли синхронизация с метадисциплиной&lt;br /&gt;
* metaprogrammitemid - id метадисциплины для синхронизации&lt;br /&gt;
* billingtext - цена дисциплины&lt;br /&gt;
* billingrules - &lt;br /&gt;
* salfactor - поправочный зарплатный коэффициент&lt;br /&gt;
* hourslab - часов лабораторных (Лаб)&lt;br /&gt;
* hoursind - часов самостоятельной работы слушателя (СРС)&lt;br /&gt;
* hourscontrol - часов контроля (Контроль)&lt;br /&gt;
* autohours (0/1) - &amp;quot;Автоматически расчитывать количества Часов всего&amp;quot; (галочка рядом с полем &amp;quot;Часов всего&amp;quot;). Если установлена, при сохранении, в поле hours записывается сумма: hourstheory+hourslab+hourspractice+hoursind+hourscontrol&lt;br /&gt;
* hoursclassroom - часов аудиторных - поле отображается, но не редактируется. При сохранении автоматически вычисляется как сумма: hourstheory+hourslab+hourspractice&lt;br /&gt;
&lt;br /&gt;
=Дополнительные методы:=&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===='''get_pitem_by_code($code)'''====&lt;br /&gt;
&lt;br /&gt;
Ищет дисциплины по коду дисциплины.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $code(string) - код дисциплины.&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (object) объект дисциплины.&lt;br /&gt;
* (bool) false если дисциплина не найдена.&lt;br /&gt;
&lt;br /&gt;
===='''get_pitems_list($programmid, $agenum=false, $status = null)'''====&lt;br /&gt;
&lt;br /&gt;
Ищет список дисциплин, относящихся к учебной программе и учебному периоду.&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (int) $programmid - id учебной программы из таблицы [[Разработка:storages/programms|programms]].&lt;br /&gt;
* (int) $agenum - порядковый номер периода или false, обозначающий получение дисциплин отсортированных в порядке возрастания периодав и по названию внутри них, по умолчанию false&lt;br /&gt;
* (str) $status - статус, по умолчанию null&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) список дисциплин.&lt;br /&gt;
* (bool) false если дисциплины не найдены.&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
По SQL-запросу находим список дисциплин и возвращаем результат.&lt;br /&gt;
&lt;br /&gt;
===='''get_maxagenum($programmid)'''====&lt;br /&gt;
&lt;br /&gt;
Получить количество периодов для данной учебной программы&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* $programmid - id учебной программы из таблицы [[Разработка:storages/programms|programms]].&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* false - если не нашлось не одной записи&lt;br /&gt;
* 0 - если нашлись только записи с agenum=0, то есть необязательные&lt;br /&gt;
* в остальных случаях возвращается целое число - максимальное кол-во дисциплин в данном периоде&lt;br /&gt;
''Структура работы:''&lt;br /&gt;
По sql-запросу производится поиск максимального значения agenum среди записей с выбранных programmid.&lt;br /&gt;
&lt;br /&gt;
===='''get_gradelevels()'''====&lt;br /&gt;
&lt;br /&gt;
Возвращает список всех возможных уровней оценки&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array&lt;br /&gt;
&lt;br /&gt;
===='''get_gradelevel_name($value)'''====&lt;br /&gt;
&lt;br /&gt;
Возвращает название уровня оценки по его обозначению&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (str) $value обозначение уровня оценки в БД&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* string&lt;br /&gt;
&lt;br /&gt;
===='''get_types()'''====&lt;br /&gt;
&lt;br /&gt;
Возвращает все возможные типы дисциплины&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* array&lt;br /&gt;
&lt;br /&gt;
===='''get_type_name($value)'''====&lt;br /&gt;
&lt;br /&gt;
Возвращает название типа по его идентификатору в базе&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (str) $value &lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* string&lt;br /&gt;
&lt;br /&gt;
===='''is_positive_grade($programmitemid, $grade)'''====&lt;br /&gt;
&lt;br /&gt;
Определяет является ли переданная оценка положительной(достаточной, для продолжения обучения)&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (int) $programmitemid - id предмета, по которому выставляется итоговая оценка&lt;br /&gt;
* (str) $grade - выставляемая оценка&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* bool&lt;br /&gt;
&lt;br /&gt;
===='''analyze_grade_scale($pitem, $grade)'''====&lt;br /&gt;
&lt;br /&gt;
Определяет является ли переданная оценка допустимой для шкалы текущего предмета&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (obj) $pitem - объект из таблицы [[Разработка:storages/programmitems | programmitems]]&lt;br /&gt;
* (str) $grade - выставляемая оценка&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* bool&lt;br /&gt;
&lt;br /&gt;
===='''is_grade_valid($id, $grade, $scale=null)'''====&lt;br /&gt;
&lt;br /&gt;
Определяет допустима ли переданная оценка для данной дисциплины&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (int) $id - id предмета в таблице [[Разработка:storages/programmitems | programmitems]]&lt;br /&gt;
* (str) $grade - выставляемая оценка&lt;br /&gt;
* (str) $scale - шкала оценок, если она указывается вручную, по умолчанию null&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* bool&lt;br /&gt;
&lt;br /&gt;
===='''set_status_deleted($id)'''====&lt;br /&gt;
&lt;br /&gt;
Переводит дисциплину в статус &amp;quot;удален&amp;quot;&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (int) $id - id дисциплины&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* bool (true - если поток удачно завершен и false в остальных случаях)&lt;br /&gt;
&lt;br /&gt;
===='''get_hours_sum($programmitemids)'''====&lt;br /&gt;
&lt;br /&gt;
Получить суммарное количество часов и ЗЕТ по нескольким предметам&lt;br /&gt;
&lt;br /&gt;
''Аргументы:'' &lt;br /&gt;
* (array) $programmitemids - массив id из таблицы programmitems&lt;br /&gt;
* (int) $id - id дисциплины&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (bool) - false в случае ошибки&lt;br /&gt;
* (object) - или объект с полями:&lt;br /&gt;
** -&amp;gt;maxcredit&lt;br /&gt;
** -&amp;gt;hours&lt;br /&gt;
** -&amp;gt;hourstheory&lt;br /&gt;
** -&amp;gt;hourspractice&lt;br /&gt;
** -&amp;gt;hoursweek&lt;br /&gt;
** -&amp;gt;hourslab&lt;br /&gt;
** -&amp;gt;hoursind&lt;br /&gt;
** -&amp;gt;hourscontrol&lt;br /&gt;
** -&amp;gt;hoursclassroom&lt;br /&gt;
&lt;br /&gt;
===Планы:===&lt;br /&gt;
&lt;br /&gt;
=События=&lt;br /&gt;
В этом разделе описан список всех событий, которые генерируются, перехватываются и обрабатываются этим плагином.&lt;br /&gt;
====Перехватываемые события====&lt;br /&gt;
{| border=&amp;quot;1&amp;quot;&lt;br /&gt;
 |+ Таблица событий, которые перехватывает этот плагин&lt;br /&gt;
 ! Тип плагина&lt;br /&gt;
 ! Код плагина&lt;br /&gt;
 ! Код события&lt;br /&gt;
 ! Доп. данные&lt;br /&gt;
 ! Пояснение&lt;br /&gt;
 |-&lt;br /&gt;
 |colspan=5 align=center | ''Этот плагин не перехватывает никаких событий''&lt;br /&gt;
 |}&lt;br /&gt;
====Генерируемые события====&lt;br /&gt;
{| border=&amp;quot;1&amp;quot;&lt;br /&gt;
 |+ Таблица событий, которые генерирует этот плагин&lt;br /&gt;
 ! Тип плагина&lt;br /&gt;
 ! Код плагина&lt;br /&gt;
 ! Код события&lt;br /&gt;
 ! Доп. данные&lt;br /&gt;
 ! Пояснение&lt;br /&gt;
 |-&lt;br /&gt;
 |storage&lt;br /&gt;
 |programmitems&lt;br /&gt;
 |insert&lt;br /&gt;
 |Массив, содержащий в поле &amp;quot;new&amp;quot; объект с данными для вставки в таблицу.&lt;br /&gt;
''Пример:'' array('new' =&amp;gt; $dataobject)&lt;br /&gt;
 |Генерируется каждый раз при вставке новой записи в таблицу programmitems.&lt;br /&gt;
 |-&lt;br /&gt;
 |storage&lt;br /&gt;
 |programmitems&lt;br /&gt;
 |update&lt;br /&gt;
 |Массив, содержащий в поле &amp;quot;new&amp;quot; обновленный объект, и в поле &amp;quot;old&amp;quot; объект со старыми данными, до обновления записи.&lt;br /&gt;
''Пример:'' array('old' =&amp;gt; $dataobject_old, 'new' =&amp;gt; $dataobject_new)&lt;br /&gt;
 |Генерируется каждый раз при обновлении записи в таблице programmitems.&lt;br /&gt;
 |-&lt;br /&gt;
 |storage&lt;br /&gt;
 |programmitems&lt;br /&gt;
 |delete&lt;br /&gt;
 |Массив, содержащий в поле &amp;quot;old&amp;quot; объект с данными, которые удаляются из таблицы&lt;br /&gt;
''Пример:'' array('old' =&amp;gt; $dataobject)&lt;br /&gt;
 |Генерируется каждый раз при удалении записи из таблицы programmitems.&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
=Задания=&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;1&amp;quot;&lt;br /&gt;
 |+ Таблица заданий, которые выполняет этот плагин&lt;br /&gt;
 ! Код задания&lt;br /&gt;
 ! Дополнительный параметр&lt;br /&gt;
 ! Пояснение&lt;br /&gt;
 |-&lt;br /&gt;
 |change_mcourse_in_programmitem&lt;br /&gt;
 |Обязателен. Указывается id дисциплины. В mixedvar необходим параметр mdlcourse.&lt;br /&gt;
 |'''Только для внутреннего использования системой'''. Находит все активные подписки на дисциплины в указанной дисциплине, после чего каждую из них приостанавливает. Меняет курс Moodle в дисциплине. Возобновляет приостановленные подписки. Посылается из формы смены курса Moodle на странице просмотра дисциплины.&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
[[Категория:Плагины обработки todo | storages/programmitems]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Периодические задания=&lt;br /&gt;
{| border=&amp;quot;1&amp;quot;&lt;br /&gt;
 |+ Таблица периодических заданий, которые выполняет этот плагин&lt;br /&gt;
 ! Метод, выполняющий периодическое задание&lt;br /&gt;
 ! Параметры&lt;br /&gt;
 ! Пояснение&lt;br /&gt;
 ! Режим нагрузки&lt;br /&gt;
 |-&lt;br /&gt;
 |check_deleted_courses&lt;br /&gt;
 |Без параметров&lt;br /&gt;
 |Поиск дисциплин с удаленным курсами, отвязка удаленных курсов от дисциплин&lt;br /&gt;
 |loan=2&lt;br /&gt;
 |}&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/programmitems&amp;diff=3033</id>
		<title>Разработка:im/programmitems</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/programmitems&amp;diff=3033"/>
				<updated>2017-04-13T09:44:54Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: /* Экран добавления зависимостей */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = programmitems&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
== Учебные предметы ==&lt;br /&gt;
Этот плагин предназначен для работы с учебными предметами. Работает на основе типового плагина im/ages.&lt;br /&gt;
=== Экран просмотра списка предметов ===&lt;br /&gt;
Экран представляет собой таблицу со списком учебных предметов. В таблице присутствуют поля:&lt;br /&gt;
* ''Название'' &lt;br /&gt;
* ''Название в стандарте''&lt;br /&gt;
* ''Код''&lt;br /&gt;
* ''Код в стандарте''&lt;br /&gt;
* ''Программа'' - к какой учебной программе принадлежит предмет&lt;br /&gt;
* ''Подразделение'' - к какому подразделению принадлежит предмет&lt;br /&gt;
* ''Статус'' - статус предмета. Статусы предметов описаны в плагине [[Разработка:workflows/programmitems|workflows/programmitems]]&lt;br /&gt;
* ''Тип'' - обязательный, рекомендованный, по выбору&lt;br /&gt;
* ''Обязательный'' - обязательна ли дисциплина&lt;br /&gt;
* ''Очки'' - количество очков, полученное за прохождение дисциплины (в кредитной системе)&lt;br /&gt;
* ''Количество недель''&lt;br /&gt;
* ''Длительность''&lt;br /&gt;
* ''Часов всего''&lt;br /&gt;
* ''Часов теории''&lt;br /&gt;
* ''Часов практики''&lt;br /&gt;
* ''Уровень компоненты'' - региональная, федеральная, и т. д.&lt;br /&gt;
* ''Описание'' - краткое описание предмета&lt;br /&gt;
* ''Заметки'' - заметки для персонала&lt;br /&gt;
* ''Тип итогового контроля'' - поле пока что не отображается&lt;br /&gt;
* ''Действия'' - просмотреть, или редактировать (если пользователь имеет права редактирования). В будущем предусмотрено удаление. Добавление зависимостей&lt;br /&gt;
&lt;br /&gt;
Также можно производить поиск по параметрам: название предмета, или его код. Просмотр списка предметов происходит постранично (по умолчанию - 10 записей на странице).&lt;br /&gt;
&lt;br /&gt;
=== Экран просмотра одного предмета ===&lt;br /&gt;
На этом экране отображается информация об одном учебном предмете.&lt;br /&gt;
&lt;br /&gt;
=== Экран просмотра списка предметов по программе ===&lt;br /&gt;
В этом разделе отображается полный состав учебной программы. Предметы группируются по параллелям. В заголовке указаны ссылки на создание учебных потоков по параллели и периоду. &lt;br /&gt;
&lt;br /&gt;
Для каждой дисциплины доступны следующие действия:&lt;br /&gt;
* Просмотреть информацию&lt;br /&gt;
* Редактировать&lt;br /&gt;
* Посмотреть тематическое планирование&lt;br /&gt;
* Посмотреть подписки&lt;br /&gt;
* Добавить зависимости&lt;br /&gt;
&lt;br /&gt;
=== Экран создания/редактирования предмета ===&lt;br /&gt;
Экран создания и редактирования учебного предмета представляет собой форму со списком полей. Назначение и описание полей совпадают с описанием полей в плагине [[Разработка:storages/programmitems#Подробный формат полей в таблице:|storages/programmitems]].&lt;br /&gt;
В будущем поля будут разбиты на 2 категории: обязательные и дополнительные.&lt;br /&gt;
&lt;br /&gt;
Поля &amp;quot;название&amp;quot; и &amp;quot;код&amp;quot; являются обязательными. Помимо этого, при создании или редактировании формы действуют следующие ограничения:&lt;br /&gt;
&lt;br /&gt;
'''При создании'''&lt;br /&gt;
* Нельзя указать номер периода, в котором идет предмет, больше, чем максимальное количество периодов в программе, в которую он добавляется.&lt;br /&gt;
* Нельзя создать предмет без привязки к учебному подразделению и программе&lt;br /&gt;
* Поле &amp;quot;код предмета&amp;quot; должно быть уникальным&lt;br /&gt;
&lt;br /&gt;
'''При редактировании'''&lt;br /&gt;
* Нельзя указать номер периода, в котором идет предмет, больше, чем максимальное количество периодов в программе, в которую он добавляется.&lt;br /&gt;
* Нельзя создать предмет без привязки к учебному подразделению и программе&lt;br /&gt;
* Поле &amp;quot;код предмета&amp;quot; должно быть уникальным&lt;br /&gt;
* Нельзя изменить поле &amp;quot;подразделение&amp;quot;&lt;br /&gt;
* Нельзя изменить поле &amp;quot;учебная программа&amp;quot;&lt;br /&gt;
&lt;br /&gt;
В будущем планируется добавить для редактирования поля &amp;quot;курс в moodle&amp;quot; и &amp;quot;тип итогового контроля&amp;quot; &lt;br /&gt;
&lt;br /&gt;
=== Экран добавления зависимостей ===&lt;br /&gt;
Позволяет добавлять дисциплины предусловия для указанной дисциплины с указанием характера зависимости (выбор из заданных).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Привязка курсов Moodle к дисциплинам ===&lt;br /&gt;
При редактировании дисциплины можно указать курс в Moodle, с которым будет связана эта дисциплина. При активации учебных процессов будет происходить подписка в курс, привязанный к дисциплине, по которой идет учебный процесс. Преподавателю дисциплины будет назначена роль Учитель, обучающимся - роль Студент.&lt;br /&gt;
Отвязать курс от дисциплины или сменить курс можно в интерфейсе просмотра дисциплины. После отправки запроса на смену/удаление привязки будет создана задача, которая будет выполнена  во время запуска скрипта выполнения отложенных задач. В этот момент произойдет отписка пользователей из старого курса и подписка в новый курс.&lt;br /&gt;
Реализован механизм отслеживания удаления курсов в Moodle, которые были связаны с дисциплинами в деканате. Механизм отслеживания запускается по расписанию в режиме нагрузки loan=2.&lt;br /&gt;
&lt;br /&gt;
== API ==&lt;br /&gt;
Здесь описаны функции для работы со списком учебных предметов.&lt;br /&gt;
===== get_listing() =====&lt;br /&gt;
&lt;br /&gt;
''Параметры:''&lt;br /&gt;
* $limitfrom - с какой записи начинать вывод&lt;br /&gt;
* $limitnum - сколько записей выводить на одной странице&lt;br /&gt;
* $conds - Обьект, содержащий данные с условиями выборки, в формате ''поле_БД-&amp;gt;значение'' по умолчанию пустой массив&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (array) массив записей из базы, или false в случае ошибки&lt;br /&gt;
&lt;br /&gt;
===== form() =====&lt;br /&gt;
Возвращает форму создания/редактирования учебного предмета с начальными данными&lt;br /&gt;
&lt;br /&gt;
''Параметры:''&lt;br /&gt;
* $id - id учебной программы в таблице [[Разработка:storages/programmitems|programmitems]], для редактирования которой вызывается форма. По умолчанию NULL (создается новый предмет).&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* [[Разработка:moodleQuickForm|moodleQuickForm]] object - объект формы, с загруженными в нее исходными данными.&lt;br /&gt;
&lt;br /&gt;
===== showlist() =====&lt;br /&gt;
Возвращает html-код списка предметов.&lt;br /&gt;
&lt;br /&gt;
''Параметры:''&lt;br /&gt;
* $list - массив записей из таблицы [[Разработка:storages/programmitems|programmitems]] для отображения.&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - html-код или false в случае ошибки&lt;br /&gt;
&lt;br /&gt;
===== show_id() =====&lt;br /&gt;
Возвращает html-код отображения информации об одном учебном предмете&lt;br /&gt;
&lt;br /&gt;
''Параметры:''&lt;br /&gt;
* $id - id записи в таблице [[Разработка:storages/programmitems|programmitems]]&lt;br /&gt;
&lt;br /&gt;
''Возвращаемые значения:''&lt;br /&gt;
* (string) - html-код или false в случае ошибки&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/reports&amp;diff=2968</id>
		<title>Разработка:im/reports</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/reports&amp;diff=2968"/>
				<updated>2017-01-16T16:14:22Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = reports&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
= Отчеты =&lt;br /&gt;
Этот интерфейс позволяет просматривать и редактировать информацию об отчетах системы. &lt;br /&gt;
&lt;br /&gt;
== Общий интерфейс ==&lt;br /&gt;
=== Просмотр списка отчетов === &lt;br /&gt;
Отчеты выводятся списком, каждая строчка в котором отображает информацию об одном отчете. Посередине отображается форма заказа отчета с возможностью заказа отчета за определенный период и в определенное время сбора. Под формой отображается таблица отчетов.&lt;br /&gt;
&lt;br /&gt;
Таблица содержит следующие поля:&lt;br /&gt;
Название&lt;br /&gt;
* Действия - ссылки на просмотр и удаление отчета&lt;br /&gt;
* Название &lt;br /&gt;
* Дата заказа&lt;br /&gt;
* Начало сбора&lt;br /&gt;
* Завершение сбора&lt;br /&gt;
* Заказчик - персона, заказавшая отчет&lt;br /&gt;
* Статус - список возможных статусов&lt;br /&gt;
&lt;br /&gt;
Пользователь попадает на эту страницу, только если у него есть право просматривать отчеты определенного типа своего подразделения (в этом случае необходимо указать дополнительный параметр - id подразделения), либо имеет право видеть все отчеты.&lt;br /&gt;
&lt;br /&gt;
=== Просмотр одного отчета ===&lt;br /&gt;
Эта страница предоставляет информацию об одном отчете.&lt;br /&gt;
&lt;br /&gt;
Формируется в зависимости от данных отчета определенного типа и заданного в соответствующем плагине шаблона.&lt;br /&gt;
&lt;br /&gt;
=== Удаление отчета ===&lt;br /&gt;
&lt;br /&gt;
== Типы отчетов ==&lt;br /&gt;
&lt;br /&gt;
=== Отчеты о фактической нагрузке ===&lt;br /&gt;
Представляют собой статистику о преподавательской нагрузке. &lt;br /&gt;
&lt;br /&gt;
При заказе имеют дополнительные поля:&lt;br /&gt;
* Прогноз и корректировка нагрузки&lt;br /&gt;
* Взять корректировку из - список отчетов из которых берется корректировка по предыдущему месяцу.&lt;br /&gt;
&lt;br /&gt;
==== Просмотр отчетов ====&lt;br /&gt;
Просмотр отчета имеет две таблицы. &lt;br /&gt;
&lt;br /&gt;
Первая из них общая информация:&lt;br /&gt;
* Подразделение - подразделение, в котором был заказан отчет&lt;br /&gt;
* Дата заказа - когда отчет был заказан&lt;br /&gt;
* Дата начала сбора - когда отчет можно собирать&lt;br /&gt;
* Дата сборки - когда отчет был собран&lt;br /&gt;
&lt;br /&gt;
Вторая таблица отображает статистику:&lt;br /&gt;
* ФИО преподавателя&lt;br /&gt;
* Договор - номер договора&lt;br /&gt;
* Табельный номер - в назначении на должность&lt;br /&gt;
* Недельная табельная нагрузка - ставка в часах, указанная в назначении на должность&lt;br /&gt;
* Недельная назначенная нагрузка - количество часов в неделю всех учебных процессов преподавателя&lt;br /&gt;
* Плановая нагрузка - запланированные занятия за указанный период, не включает в себя замененные и отмененные занятия&lt;br /&gt;
* Исполненная нагрузка - все проведенные преподавателем занятия за указанный период, включая и те, что он проводил по замене&lt;br /&gt;
* Перенесенных/отложенных занятий - замененные или отложенные преподавателем занятия&lt;br /&gt;
* Отмененных занятий - отмененные администратором занятия&lt;br /&gt;
* Зарплатные часы - количество зарплатных часов с учетом надбавок. Для режима прогноза с корректировкой добавляется еще прогноз текущего месяца((кол-во зарплатных часов*кол-во дней месяца/кол-во отработтанных учителем дней)-кол-во зарплатных часов)&lt;br /&gt;
* Поправка за предыдущий месяц(только для отчетов с прогнозом и корректировкой) - кол-во зарплатных часов с 26 по конец месяца минус прогноз за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Зарплатные часы имеют ссылку при нажатии на которую открывается сводная статистика по одному учителю. В режиме прогноза и корректировки статистика имеет три секции:&lt;br /&gt;
&lt;br /&gt;
'''Поправка за предыдущий месяц'''&lt;br /&gt;
&lt;br /&gt;
Отображает таблицу занятий с 26 по конец месяца. Под ней расположена информация:&lt;br /&gt;
&lt;br /&gt;
Выплачено по прогнозу за последние числа предыдущего месяца&lt;br /&gt;
&lt;br /&gt;
Фактически отработано в последних числах предыдущего месяца&lt;br /&gt;
&lt;br /&gt;
Поправка за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
'''Зарплатные часы за 1-25 числа месяца'''&lt;br /&gt;
&lt;br /&gt;
Отображает таблицу уроков:&lt;br /&gt;
* Дата - число, на которое создано занятие&lt;br /&gt;
* Начало занятия - время, на которое создано занятие&lt;br /&gt;
* Время занятия - продолжительность занятия&lt;br /&gt;
* Академические часы&lt;br /&gt;
* Индивидуальное занятие - факт индивидуального занятия да/нет&lt;br /&gt;
* Кол-во учащихся/Коэффициент - кол-во активных учащихся в процессе и коэффициент надбавки за них&lt;br /&gt;
* Коэффициент дисциплины&lt;br /&gt;
* Коэффициент по учащимся - коэффициент каждой подписки на программу учащихся процесса&lt;br /&gt;
* Коэффициент по группам - коэффициент каждой группы процесса&lt;br /&gt;
* Коэффициент учебного процесса&lt;br /&gt;
* Коэффициент расписания&lt;br /&gt;
* Проведение занятия по факту&lt;br /&gt;
* Зарплатные часы&lt;br /&gt;
&lt;br /&gt;
Внизу таблицы расположена информация об общем количестве проведенных занятий и зарплатных часов.&lt;br /&gt;
&lt;br /&gt;
'''Итого к выплате'''&lt;br /&gt;
&lt;br /&gt;
Поправка за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
Зарплатные часы за 1-25 числа месяца&lt;br /&gt;
&lt;br /&gt;
Прогноз на конец месяца&lt;br /&gt;
&lt;br /&gt;
Итого к выплате&lt;br /&gt;
&lt;br /&gt;
В обычном режиме отображается только таблица зарплатных часов.&lt;br /&gt;
&lt;br /&gt;
==== Экспорт отчетов ====&lt;br /&gt;
&lt;br /&gt;
Позволяет скачать статистику в отдельный csv-файл. Структура файла:&lt;br /&gt;
* ФИО преподавателя&lt;br /&gt;
* Договор - номер договора&lt;br /&gt;
* Табельный номер - в назначении на должность&lt;br /&gt;
* Недельная табельная нагрузка - ставка в часах, указанная в назначении на должность&lt;br /&gt;
* Недельная назначенная нагрузка - количество часов в неделю всех учебных процессов преподавателя&lt;br /&gt;
* Плановая нагрузка - запланированные занятия за указанный период, не включает в себя замененные и отмененные занятия&lt;br /&gt;
* Исполненная нагрузка - все проведенные преподавателем занятия за указанный период, включая и те, что он проводил по замене&lt;br /&gt;
* Перенесенных/отложенных занятий - замененные или отложенные преподавателем занятия&lt;br /&gt;
* Отмененных занятий - отмененные администратором занятия&lt;br /&gt;
* Зарплатные часы - количество зарплатных часов с учетом надбавок. Для режима прогноза с корректировкой добавляется еще прогноз текущего месяца(кол-во зарплатных часов деленное на 6)&lt;br /&gt;
* Поправка за предыдущий месяц(только для отчетов с прогнозом и корректировкой) - кол-во зарплатных часов с 26 по конец месяца минус прогноз за предыдущий месяц&lt;br /&gt;
* url - ссылка на страницу просмотра статистики по учителю&lt;br /&gt;
* events - список всех занятий с коэффициентами.&lt;br /&gt;
&lt;br /&gt;
=== Отчеты по замененным урокам ===&lt;br /&gt;
Сформировать отчет можно в интерфейсе Журнал→Отчет по замененным занятиям.&lt;br /&gt;
== Описание интерфейса ==&lt;br /&gt;
Интерфейс состоит из 3 блоков:&lt;br /&gt;
* блок с информацией о параметрах отчета (подразделение, период, данные за который отражены в отчете, дата начала сбора отчета)&lt;br /&gt;
* фильтр данных&lt;br /&gt;
* непосредственно данные отчета&lt;br /&gt;
Отчет представлен в двух вариантах:&lt;br /&gt;
* данные сформированы по конечным заменам: одна запись — одна замена&lt;br /&gt;
* данные сгруппированы по преподавателям, проводившим замены&lt;br /&gt;
[[Файл:Dof_im_journal_reports_replacedevents.png]]&lt;br /&gt;
&lt;br /&gt;
== Данные, представленные в отчете ==&lt;br /&gt;
Стандартный отчет:&lt;br /&gt;
* Запланированная дата проведения занятия&lt;br /&gt;
* ФИО пропустившего преподавателя (со ссылками на персону и договор)&lt;br /&gt;
* ссылка на пропущенную дисциплину&lt;br /&gt;
* ссылки на учебный процесс, в рамках которого происходит замена, ссылки на персоны, участвующие в этом процессе&lt;br /&gt;
* дата проведения замены&lt;br /&gt;
* ФИО заменяющего преподавателя (со ссылками на персону и договор)&lt;br /&gt;
* ссылка на новую дисциплину&lt;br /&gt;
* зарплатные часы по новой дисциплине&lt;br /&gt;
* тип замененного занятия (замена другим временем, замена другим преподавателем)&lt;br /&gt;
Отчет с группировкой по преподавателям:&lt;br /&gt;
* ссылка на персону, заменяющую занятие, с указанием идентификатора в ЭД, е-мейла, общей суммы фактических и зарплатных часов по заменам&lt;br /&gt;
* ссылка на договор&lt;br /&gt;
* табельный номер&lt;br /&gt;
* суммы фактических и зарплатных часов по заменам по табельному номеру&lt;br /&gt;
* дата проведения замены&lt;br /&gt;
* ссылка на учебный процесс, с указанием дисциплины и преподавателя, ведущего занятия&lt;br /&gt;
* зарплатный коэффициент&lt;br /&gt;
* фактические часы по занятию&lt;br /&gt;
* зарплатные часы по занятию&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Краткий отчет по преподавателям ===&lt;br /&gt;
=== Полный отчет по преподавателям ===&lt;br /&gt;
=== Краткий отчет по учащимся ===&lt;br /&gt;
=== Полный отчет по учащимся ===&lt;br /&gt;
&lt;br /&gt;
= API =&lt;br /&gt;
Здесь описаны функции для работы со списком учебных периодов.&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/reports&amp;diff=2967</id>
		<title>Разработка:im/reports</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/reports&amp;diff=2967"/>
				<updated>2017-01-16T16:13:01Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = reports&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
= Отчеты =&lt;br /&gt;
Этот интерфейс позволяет просматривать и редактировать информацию об отчетах системы. &lt;br /&gt;
&lt;br /&gt;
== Общий интерфейс ==&lt;br /&gt;
=== Просмотр списка отчетов === &lt;br /&gt;
Отчеты выводятся списком, каждая строчка в котором отображает информацию об одном отчете. Посередине отображается форма заказа отчета с возможностью заказа отчета за определенный период и в определенное время сбора. Под формой отображается таблица отчетов.&lt;br /&gt;
&lt;br /&gt;
Таблица содержит следующие поля:&lt;br /&gt;
Название&lt;br /&gt;
* Действия - ссылки на просмотр и удаление отчета&lt;br /&gt;
* Название &lt;br /&gt;
* Дата заказа&lt;br /&gt;
* Начало сбора&lt;br /&gt;
* Завершение сбора&lt;br /&gt;
* Заказчик - персона, заказавшая отчет&lt;br /&gt;
* Статус - список возможных статусов&lt;br /&gt;
&lt;br /&gt;
Пользователь попадает на эту страницу, только если у него есть право просматривать отчеты определенного типа своего подразделения (в этом случае необходимо указать дополнительный параметр - id подразделения), либо имеет право видеть все отчеты.&lt;br /&gt;
&lt;br /&gt;
=== Просмотр одного отчета ===&lt;br /&gt;
Эта страница предоставляет информацию об одном отчете.&lt;br /&gt;
&lt;br /&gt;
Формируется в зависимости от данных отчета определенного типа и заданного в соответствующем плагине шаблона.&lt;br /&gt;
&lt;br /&gt;
=== Удаление отчета ===&lt;br /&gt;
&lt;br /&gt;
== Типы отчетов ==&lt;br /&gt;
&lt;br /&gt;
=== Отчеты о фактической нагрузке ===&lt;br /&gt;
Представляют собой статистику о преподавательской нагрузке. &lt;br /&gt;
&lt;br /&gt;
При заказе имеют дополнительные поля:&lt;br /&gt;
* Прогноз и корректировка нагрузки&lt;br /&gt;
* Взять корректировку из - список отчетов из которых берется корректировка по предыдущему месяцу.&lt;br /&gt;
&lt;br /&gt;
==== Просмотр отчетов ====&lt;br /&gt;
Просмотр отчета имеет две таблицы. &lt;br /&gt;
&lt;br /&gt;
Первая из них общая информация:&lt;br /&gt;
* Подразделение - подразделение, в котором был заказан отчет&lt;br /&gt;
* Дата заказа - когда отчет был заказан&lt;br /&gt;
* Дата начала сбора - когда отчет можно собирать&lt;br /&gt;
* Дата сборки - когда отчет был собран&lt;br /&gt;
&lt;br /&gt;
Вторая таблица отображает статистику:&lt;br /&gt;
* ФИО преподавателя&lt;br /&gt;
* Договор - номер договора&lt;br /&gt;
* Табельный номер - в назначении на должность&lt;br /&gt;
* Недельная табельная нагрузка - ставка в часах, указанная в назначении на должность&lt;br /&gt;
* Недельная назначенная нагрузка - количество часов в неделю всех учебных процессов преподавателя&lt;br /&gt;
* Плановая нагрузка - запланированные занятия за указанный период, не включает в себя замененные и отмененные занятия&lt;br /&gt;
* Исполненная нагрузка - все проведенные преподавателем занятия за указанный период, включая и те, что он проводил по замене&lt;br /&gt;
* Перенесенных/отложенных занятий - замененные или отложенные преподавателем занятия&lt;br /&gt;
* Отмененных занятий - отмененные администратором занятия&lt;br /&gt;
* Зарплатные часы - количество зарплатных часов с учетом надбавок. Для режима прогноза с корректировкой добавляется еще прогноз текущего месяца((кол-во зарплатных часов*кол-во дней месяца/кол-во отработтанных учителем дней)-кол-во зарплатных часов)&lt;br /&gt;
* Поправка за предыдущий месяц(только для отчетов с прогнозом и корректировкой) - кол-во зарплатных часов с 26 по конец месяца минус прогноз за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Зарплатные часы имеют ссылку при нажатии на которую открывается сводная статистика по одному учителю. В режиме прогноза и корректировки статистика имеет три секции:&lt;br /&gt;
&lt;br /&gt;
'''Поправка за предыдущий месяц'''&lt;br /&gt;
&lt;br /&gt;
Отображает таблицу занятий с 26 по конец месяца. Под ней расположена информация:&lt;br /&gt;
&lt;br /&gt;
Выплачено по прогнозу за последние числа предыдущего месяца&lt;br /&gt;
&lt;br /&gt;
Фактически отработано в последних числах предыдущего месяца&lt;br /&gt;
&lt;br /&gt;
Поправка за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
'''Зарплатные часы за 1-25 числа месяца'''&lt;br /&gt;
&lt;br /&gt;
Отображает таблицу уроков:&lt;br /&gt;
* Дата - число, на которое создано занятие&lt;br /&gt;
* Начало занятия - время, на которое создано занятие&lt;br /&gt;
* Время занятия - продолжительность занятия&lt;br /&gt;
* Академические часы&lt;br /&gt;
* Индивидуальное занятие - факт индивидуального занятия да/нет&lt;br /&gt;
* Кол-во учащихся/Коэффициент - кол-во активных учащихся в процессе и коэффициент надбавки за них&lt;br /&gt;
* Коэффициент дисциплины&lt;br /&gt;
* Коэффициент по учащимся - коэффициент каждой подписки на программу учащихся процесса&lt;br /&gt;
* Коэффициент по группам - коэффициент каждой группы процесса&lt;br /&gt;
* Коэффициент учебного процесса&lt;br /&gt;
* Коэффициент расписания&lt;br /&gt;
* Проведение занятия по факту&lt;br /&gt;
* Зарплатные часы&lt;br /&gt;
&lt;br /&gt;
Внизу таблицы расположена информация об общем количестве проведенных занятий и зарплатных часов.&lt;br /&gt;
&lt;br /&gt;
'''Итого к выплате'''&lt;br /&gt;
&lt;br /&gt;
Поправка за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
Зарплатные часы за 1-25 числа месяца&lt;br /&gt;
&lt;br /&gt;
Прогноз на конец месяца&lt;br /&gt;
&lt;br /&gt;
Итого к выплате&lt;br /&gt;
&lt;br /&gt;
В обычном режиме отображается только таблица зарплатных часов.&lt;br /&gt;
&lt;br /&gt;
==== Экспорт отчетов ====&lt;br /&gt;
&lt;br /&gt;
Позволяет скачать статистику в отдельный csv-файл. Структура файла:&lt;br /&gt;
* ФИО преподавателя&lt;br /&gt;
* Договор - номер договора&lt;br /&gt;
* Табельный номер - в назначении на должность&lt;br /&gt;
* Недельная табельная нагрузка - ставка в часах, указанная в назначении на должность&lt;br /&gt;
* Недельная назначенная нагрузка - количество часов в неделю всех учебных процессов преподавателя&lt;br /&gt;
* Плановая нагрузка - запланированные занятия за указанный период, не включает в себя замененные и отмененные занятия&lt;br /&gt;
* Исполненная нагрузка - все проведенные преподавателем занятия за указанный период, включая и те, что он проводил по замене&lt;br /&gt;
* Перенесенных/отложенных занятий - замененные или отложенные преподавателем занятия&lt;br /&gt;
* Отмененных занятий - отмененные администратором занятия&lt;br /&gt;
* Зарплатные часы - количество зарплатных часов с учетом надбавок. Для режима прогноза с корректировкой добавляется еще прогноз текущего месяца(кол-во зарплатных часов деленное на 6)&lt;br /&gt;
* Поправка за предыдущий месяц(только для отчетов с прогнозом и корректировкой) - кол-во зарплатных часов с 26 по конец месяца минус прогноз за предыдущий месяц&lt;br /&gt;
* url - ссылка на страницу просмотра статистики по учителю&lt;br /&gt;
* events - список всех занятий с коэффициентами.&lt;br /&gt;
&lt;br /&gt;
=== Отчеты по замененным урокам ===&lt;br /&gt;
Сформировать отчет можно в интерфейсе Журнал→Отчет по замененным занятиям.&lt;br /&gt;
== Описание интерфейса ==&lt;br /&gt;
Интерфейс состоит из 3 блоков:&lt;br /&gt;
блок с информацией о параметрах отчета (подразделение, период, данные за который отражены в отчете, дата начала сбора отчета)&lt;br /&gt;
фильтр данных&lt;br /&gt;
непосредственно данные отчета&lt;br /&gt;
Отчет представлен в двух вариантах:&lt;br /&gt;
1. данные сформированы по конечным заменам: одна запись — одна замена&lt;br /&gt;
2. данные сгруппированы по преподавателям, проводившим замены&lt;br /&gt;
[[Файл:Dof_im_journal_reports_replacedevents.png]]&lt;br /&gt;
&lt;br /&gt;
== Данные, представленные в отчете ==&lt;br /&gt;
Стандартный отчет:&lt;br /&gt;
Запланированная дата проведения занятия&lt;br /&gt;
ФИО пропустившего преподавателя (со ссылками на персону и договор)&lt;br /&gt;
ссылка на пропущенную дисциплину&lt;br /&gt;
ссылки на учебный процесс, в рамках которого происходит замена, ссылки на персоны, участвующие в этом процессе&lt;br /&gt;
дата проведения замены&lt;br /&gt;
ФИО заменяющего преподавателя (со ссылками на персону и договор)&lt;br /&gt;
ссылка на новую дисциплину&lt;br /&gt;
зарплатные часы по новой дисциплине&lt;br /&gt;
тип замененного занятия (замена другим временем, замена другим преподавателем)&lt;br /&gt;
Отчет с группировкой по преподавателям:&lt;br /&gt;
ссылка на персону, заменяющую занятие, с указанием идентификатора в ЭД, е-мейла, общей суммы фактических и зарплатных часов по заменам&lt;br /&gt;
ссылка на договор&lt;br /&gt;
табельный номер&lt;br /&gt;
суммы фактических и зарплатных часов по заменам по табельному номеру&lt;br /&gt;
дата проведения замены&lt;br /&gt;
ссылка на учебный процесс, с указанием дисциплины и преподавателя, ведущего занятия&lt;br /&gt;
зарплатный коэффициент&lt;br /&gt;
фактические часы по занятию&lt;br /&gt;
зарплатные часы по занятию&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Краткий отчет по преподавателям ===&lt;br /&gt;
=== Полный отчет по преподавателям ===&lt;br /&gt;
=== Краткий отчет по учащимся ===&lt;br /&gt;
=== Полный отчет по учащимся ===&lt;br /&gt;
&lt;br /&gt;
= API =&lt;br /&gt;
Здесь описаны функции для работы со списком учебных периодов.&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/reports&amp;diff=2966</id>
		<title>Разработка:im/reports</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/reports&amp;diff=2966"/>
				<updated>2017-01-16T16:09:12Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = reports&lt;br /&gt;
| type = im&lt;br /&gt;
}}&lt;br /&gt;
= Отчеты =&lt;br /&gt;
Этот интерфейс позволяет просматривать и редактировать информацию об отчетах системы. &lt;br /&gt;
&lt;br /&gt;
== Общий интерфейс ==&lt;br /&gt;
=== Просмотр списка отчетов === &lt;br /&gt;
Отчеты выводятся списком, каждая строчка в котором отображает информацию об одном отчете. Посередине отображается форма заказа отчета с возможностью заказа отчета за определенный период и в определенное время сбора. Под формой отображается таблица отчетов.&lt;br /&gt;
&lt;br /&gt;
Таблица содержит следующие поля:&lt;br /&gt;
Название&lt;br /&gt;
* Действия - ссылки на просмотр и удаление отчета&lt;br /&gt;
* Название &lt;br /&gt;
* Дата заказа&lt;br /&gt;
* Начало сбора&lt;br /&gt;
* Завершение сбора&lt;br /&gt;
* Заказчик - персона, заказавшая отчет&lt;br /&gt;
* Статус - список возможных статусов&lt;br /&gt;
&lt;br /&gt;
Пользователь попадает на эту страницу, только если у него есть право просматривать отчеты определенного типа своего подразделения (в этом случае необходимо указать дополнительный параметр - id подразделения), либо имеет право видеть все отчеты.&lt;br /&gt;
&lt;br /&gt;
=== Просмотр одного отчета ===&lt;br /&gt;
Эта страница предоставляет информацию об одном отчете.&lt;br /&gt;
&lt;br /&gt;
Формируется в зависимости от данных отчета определенного типа и заданного в соответствующем плагине шаблона.&lt;br /&gt;
&lt;br /&gt;
=== Удаление отчета ===&lt;br /&gt;
&lt;br /&gt;
== Типы отчетов ==&lt;br /&gt;
&lt;br /&gt;
=== Отчеты о фактической нагрузке ===&lt;br /&gt;
Представляют собой статистику о преподавательской нагрузке. &lt;br /&gt;
&lt;br /&gt;
При заказе имеют дополнительные поля:&lt;br /&gt;
* Прогноз и корректировка нагрузки&lt;br /&gt;
* Взять корректировку из - список отчетов из которых берется корректировка по предыдущему месяцу.&lt;br /&gt;
&lt;br /&gt;
==== Просмотр отчетов ====&lt;br /&gt;
Просмотр отчета имеет две таблицы. &lt;br /&gt;
&lt;br /&gt;
Первая из них общая информация:&lt;br /&gt;
* Подразделение - подразделение, в котором был заказан отчет&lt;br /&gt;
* Дата заказа - когда отчет был заказан&lt;br /&gt;
* Дата начала сбора - когда отчет можно собирать&lt;br /&gt;
* Дата сборки - когда отчет был собран&lt;br /&gt;
&lt;br /&gt;
Вторая таблица отображает статистику:&lt;br /&gt;
* ФИО преподавателя&lt;br /&gt;
* Договор - номер договора&lt;br /&gt;
* Табельный номер - в назначении на должность&lt;br /&gt;
* Недельная табельная нагрузка - ставка в часах, указанная в назначении на должность&lt;br /&gt;
* Недельная назначенная нагрузка - количество часов в неделю всех учебных процессов преподавателя&lt;br /&gt;
* Плановая нагрузка - запланированные занятия за указанный период, не включает в себя замененные и отмененные занятия&lt;br /&gt;
* Исполненная нагрузка - все проведенные преподавателем занятия за указанный период, включая и те, что он проводил по замене&lt;br /&gt;
* Перенесенных/отложенных занятий - замененные или отложенные преподавателем занятия&lt;br /&gt;
* Отмененных занятий - отмененные администратором занятия&lt;br /&gt;
* Зарплатные часы - количество зарплатных часов с учетом надбавок. Для режима прогноза с корректировкой добавляется еще прогноз текущего месяца((кол-во зарплатных часов*кол-во дней месяца/кол-во отработтанных учителем дней)-кол-во зарплатных часов)&lt;br /&gt;
* Поправка за предыдущий месяц(только для отчетов с прогнозом и корректировкой) - кол-во зарплатных часов с 26 по конец месяца минус прогноз за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Зарплатные часы имеют ссылку при нажатии на которую открывается сводная статистика по одному учителю. В режиме прогноза и корректировки статистика имеет три секции:&lt;br /&gt;
&lt;br /&gt;
'''Поправка за предыдущий месяц'''&lt;br /&gt;
&lt;br /&gt;
Отображает таблицу занятий с 26 по конец месяца. Под ней расположена информация:&lt;br /&gt;
&lt;br /&gt;
Выплачено по прогнозу за последние числа предыдущего месяца&lt;br /&gt;
&lt;br /&gt;
Фактически отработано в последних числах предыдущего месяца&lt;br /&gt;
&lt;br /&gt;
Поправка за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
'''Зарплатные часы за 1-25 числа месяца'''&lt;br /&gt;
&lt;br /&gt;
Отображает таблицу уроков:&lt;br /&gt;
* Дата - число, на которое создано занятие&lt;br /&gt;
* Начало занятия - время, на которое создано занятие&lt;br /&gt;
* Время занятия - продолжительность занятия&lt;br /&gt;
* Академические часы&lt;br /&gt;
* Индивидуальное занятие - факт индивидуального занятия да/нет&lt;br /&gt;
* Кол-во учащихся/Коэффициент - кол-во активных учащихся в процессе и коэффициент надбавки за них&lt;br /&gt;
* Коэффициент дисциплины&lt;br /&gt;
* Коэффициент по учащимся - коэффициент каждой подписки на программу учащихся процесса&lt;br /&gt;
* Коэффициент по группам - коэффициент каждой группы процесса&lt;br /&gt;
* Коэффициент учебного процесса&lt;br /&gt;
* Коэффициент расписания&lt;br /&gt;
* Проведение занятия по факту&lt;br /&gt;
* Зарплатные часы&lt;br /&gt;
&lt;br /&gt;
Внизу таблицы расположена информация об общем количестве проведенных занятий и зарплатных часов.&lt;br /&gt;
&lt;br /&gt;
'''Итого к выплате'''&lt;br /&gt;
&lt;br /&gt;
Поправка за предыдущий месяц&lt;br /&gt;
&lt;br /&gt;
Зарплатные часы за 1-25 числа месяца&lt;br /&gt;
&lt;br /&gt;
Прогноз на конец месяца&lt;br /&gt;
&lt;br /&gt;
Итого к выплате&lt;br /&gt;
&lt;br /&gt;
В обычном режиме отображается только таблица зарплатных часов.&lt;br /&gt;
&lt;br /&gt;
==== Экспорт отчетов ====&lt;br /&gt;
&lt;br /&gt;
Позволяет скачать статистику в отдельный csv-файл. Структура файла:&lt;br /&gt;
* ФИО преподавателя&lt;br /&gt;
* Договор - номер договора&lt;br /&gt;
* Табельный номер - в назначении на должность&lt;br /&gt;
* Недельная табельная нагрузка - ставка в часах, указанная в назначении на должность&lt;br /&gt;
* Недельная назначенная нагрузка - количество часов в неделю всех учебных процессов преподавателя&lt;br /&gt;
* Плановая нагрузка - запланированные занятия за указанный период, не включает в себя замененные и отмененные занятия&lt;br /&gt;
* Исполненная нагрузка - все проведенные преподавателем занятия за указанный период, включая и те, что он проводил по замене&lt;br /&gt;
* Перенесенных/отложенных занятий - замененные или отложенные преподавателем занятия&lt;br /&gt;
* Отмененных занятий - отмененные администратором занятия&lt;br /&gt;
* Зарплатные часы - количество зарплатных часов с учетом надбавок. Для режима прогноза с корректировкой добавляется еще прогноз текущего месяца(кол-во зарплатных часов деленное на 6)&lt;br /&gt;
* Поправка за предыдущий месяц(только для отчетов с прогнозом и корректировкой) - кол-во зарплатных часов с 26 по конец месяца минус прогноз за предыдущий месяц&lt;br /&gt;
* url - ссылка на страницу просмотра статистики по учителю&lt;br /&gt;
* events - список всех занятий с коэффициентами.&lt;br /&gt;
&lt;br /&gt;
=== Отчеты по замененным урокам ===&lt;br /&gt;
Сформировать отчет можно в интерфейсе Журнал→Отчет по замененным занятиям (ссылка на описание интерфейса http://docs.deansoffice.ru/ru/%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:im/journal#.D0.9E.D1.82.D1.87.D0.B5.D1.82.D1.8B_.D0.BF.D0.BE_.D0.B7.D0.B0.D0.BC.D0.B5.D0.BD.D0.B5.D0.BD.D0.BD.D1.8B.D0.BC_.D1.83.D1.80.D0.BE.D0.BA.D0.B0.D0.BC.&lt;br /&gt;
== Описание интерфейса ==&lt;br /&gt;
Интерфейс состоит из 3 блоков:&lt;br /&gt;
блок с информацией о параметрах отчета (подразделение, период, данные за который отражены в отчете, дата начала сбора отчета)&lt;br /&gt;
фильтр данных&lt;br /&gt;
непосредственно данные отчета&lt;br /&gt;
Отчет представлен в двух вариантах:&lt;br /&gt;
1. данные сформированы по конечным заменам: одна запись — одна замена&lt;br /&gt;
2. данные сгруппированы по преподавателям, проводившим замены&lt;br /&gt;
[[Файл:Dof_im_journal_reports_replacedevents.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Краткий отчет по преподавателям ===&lt;br /&gt;
=== Полный отчет по преподавателям ===&lt;br /&gt;
=== Краткий отчет по учащимся ===&lt;br /&gt;
=== Полный отчет по учащимся ===&lt;br /&gt;
&lt;br /&gt;
= API =&lt;br /&gt;
Здесь описаны функции для работы со списком учебных периодов.&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A4%D0%B0%D0%B9%D0%BB:Dof_im_journal_reports_replacedevents.png&amp;diff=2965</id>
		<title>Файл:Dof im journal reports replacedevents.png</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A4%D0%B0%D0%B9%D0%BB:Dof_im_journal_reports_replacedevents.png&amp;diff=2965"/>
				<updated>2017-01-16T16:08:33Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	<entry>
		<id>http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:storages/reports&amp;diff=2964</id>
		<title>Разработка:storages/reports</title>
		<link rel="alternate" type="text/html" href="http://docs.deansoffice.ru/wiki/index.php?title=%D0%A0%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%BA%D0%B0:storages/reports&amp;diff=2964"/>
				<updated>2017-01-16T16:00:25Z</updated>
		
		<summary type="html">&lt;p&gt;Ivanov: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox_Plugin&lt;br /&gt;
| name = reports&lt;br /&gt;
| type = storages&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
===Таблица в базе данных===&lt;br /&gt;
''reports'' - Отчеты о деятельности учителей и учеников. Изначально через интерфейс &amp;quot;заказывается&amp;quot; отчет(полный или краткий) по учителям или ученикам и лишь потом с использованием КРОНА отчет формируется(срабатывание крона раз в сутки по умолчанию)&lt;br /&gt;
&lt;br /&gt;
====Подробный формат полей в таблице:====&lt;br /&gt;
* plugintype - тип плагина (storage,im....)&lt;br /&gt;
* plugincode - код плагтна&lt;br /&gt;
* code - код отчета внутри плагина.&lt;br /&gt;
* name - название отчета русскими буквами. Генерируется в момент создания&lt;br /&gt;
* personid -  id из талицы [[Разработка:storages/persons | persons ]] того,кто запросил отчет&lt;br /&gt;
* requestdate - когда запросил отчет&lt;br /&gt;
* completedate - когда отчет был завершен&lt;br /&gt;
* crondate - время, раньше которого отчёт не будет собираться(иными словами, когда отчету начать собираться)&lt;br /&gt;
* status (пока без workflow) - requested(запрошен), completed(сформирован), error(ошибка)&lt;br /&gt;
* departmentid, - id подразделения из талицы [[Разработка:storages/departments | departments ]], которому принадлежит отчет&lt;br /&gt;
* objectid - id объекта по которому запрашивается отчет(необязательно) &lt;br /&gt;
* begindate- с какого периода собираются данные для отчета(необязательно) &lt;br /&gt;
* enddate - по какой период собираются данные для отчета(необязательно) &lt;br /&gt;
* requestdata - дополнительные данные для формирования отчета (будет хранится сериализованный объект). Текст, 64 килобайта. Индекс не * создавать(необязательно) &lt;br /&gt;
* filepath - относительный путь к файлу. имя файла - это id записи. Расширение dat.&lt;br /&gt;
&lt;br /&gt;
=== Правила составления отчетов ===&lt;br /&gt;
Все классы, собирающие данные для отчетов должны наследоваться от класса dof_storage_reports_basereport. Файл с классом сбора данных для отчета должен находиться в папке плагина:&lt;br /&gt;
&lt;br /&gt;
    /'''reports'''/&amp;lt;''код_отчета''&amp;gt;/'''init.php'''&lt;br /&gt;
&lt;br /&gt;
и называться &lt;br /&gt;
&lt;br /&gt;
    '''dof_'''''&amp;lt;код плагина&amp;gt;'''''_'''''&amp;lt;название плагина&amp;gt;'''''_report_'''''&amp;lt;код отчета&amp;gt;''&lt;br /&gt;
==== Пример ====&lt;br /&gt;
Для отчета с кодом &amp;quot;studentshort&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Путь к файлу:&lt;br /&gt;
    /dof/sync/mreports/reports/'''studentshort'''/init.php&lt;br /&gt;
Название класса:&lt;br /&gt;
    dof_'''sync'''_'''mreports'''_report_'''studentshort'''&lt;br /&gt;
&lt;br /&gt;
==== Класс dof_storage_reports_basereport ====&lt;br /&gt;
&lt;br /&gt;
===== plugintype() ===== &lt;br /&gt;
Абстрактный метод. В нем устанавливается тип плагина, в котором находится класс отчета.&lt;br /&gt;
===== plugincode() =====&lt;br /&gt;
Абстрактный метод. В нем устанавливается код плагина, в котором находится класс отчета.&lt;br /&gt;
=====  code() ===== &lt;br /&gt;
Абстрактный метод.  Код самого отчета. В одном плагине не должно быть двух отчетов с одинаковым кодом.&lt;br /&gt;
===== name() =====&lt;br /&gt;
Абстрактный метод. Полное название отчета. Может генерироваться во время сбора данных по отчету.&lt;br /&gt;
===== save() =====&lt;br /&gt;
Метод, создающий структуру объекта для вставки в базу. Метод вызывается автоматически, и его не следует переопределять без необходимости. Если нужно дополнить или изменить логику сохранения данных - то переопределяется метод save_data().&lt;br /&gt;
===== save_data() =====&lt;br /&gt;
Метод, которые следует переопределить в дочернем классе, если нужно добавить новые данные в объект отчета. &lt;br /&gt;
Входные параметры:&lt;br /&gt;
* (object) $report - объект данных для отчета.&lt;br /&gt;
Возвращаемые значения:&lt;br /&gt;
* (object) $report - дополненный объект с данеными для отчета.&lt;br /&gt;
===== generate() =====&lt;br /&gt;
Эта функция запускает процес сбора данных для отчета.&lt;br /&gt;
===== load() =====&lt;br /&gt;
Загрузить данные для отчета из базы данных&lt;br /&gt;
===== load_file() =====&lt;br /&gt;
Загрузить данные для отчета из файла&lt;br /&gt;
===== load_data() =====&lt;br /&gt;
Дополнительный метод, который переопределяется в дочерних классах отчетов, и определяет каким именно образом будут обрабатываться данные из файла отчета.&lt;br /&gt;
===== generate_data (protected) =====&lt;br /&gt;
Метод, предусмотренный для расширения логики генерации файла в дочерних классах.&lt;br /&gt;
===== add_report_css =====&lt;br /&gt;
Метод, предусмотренный для добавления css файлов до печати шапки документа. Переопределяется в дочернем классе.&lt;br /&gt;
===== add_report_js =====&lt;br /&gt;
Метод, предусмотренный для добавления js файлов до печати шапки документа. Переопределяется в дочернем классе.&lt;br /&gt;
===== templater_csv_show_header =====&lt;br /&gt;
Поддержка отчетом заголовков в csv-формате.&lt;/div&gt;</summary>
		<author><name>Ivanov</name></author>	</entry>

	</feed>