jeyroik / extas-grades
Provides grades logic
Requires
Requires (Dev)
This package is auto-updated.
Last update: 2024-10-29 06:41:37 UTC
README
Описание
Пакет позволяет организовать вычисление любых составных параметров - оценок.
Оценка
- это параметр, который высчитывается на основании каких-либо коэффициентов.Коэффициент
- это параметр, который вычисляется на основании простых слагаемых. Не рекомендуется рассчитывать коэффициент на основании других коэффициентов - для этого есть оценки.Слагаемое
- это простой параметр, который либо имеет статическое значение, либо вычисляется бес использования других слагаемых/коэффициентов/оценок.
Все три сущности имеют единый интерфейс, что позволяет организовать их размещение любым удобным образом.
Установка
Пакет предоставляет несколько плагинов по-умолчанию для запуска расчётов термов (слагаемых), коэффициентов и оценок.
Чтобы эти плагины установить, их необходимо импортировать:
extas.json
{ "import": { "from": { "extas/grades": { "plugins": "*" } }, "parameters": { "on_miss_package": { "name": "on_miss_package", "value": "continue" }, "on_miss_section": { "name": "on_miss_section", "value": "throw" } } } }
Инициализация и установка extas'a:
# vendor/bin/extas init
# vendor/bin/extas install
Запуск тестов:
# composer test
Использование
- Создайте (или установите) термы (слагаемые). 1.1. Создайте (или установите) калькуляторы термов.
- Создайте (или установите) коэффициенты. 2.1. Создайте (или установите) калькуляторы коэффициентов.
- Создайте (или установите) грейды (оценки). 3.1. Создайте (или установите) калькуляторы грейдов.
# php -S 0.0.0.0:8080 -t vendor/jeyroik/extas-api/public
# curl localhost:8080/api/jsonrpc -d '{"method":"grade.calculate", "params": {"names":["grade1"], "tag":"some.tag"}}'
В результате выполнения запроса будет выполнен расчёт оценки grade1
.
Ответ будет примерно следующим:
{ "id": "<request.id>", "jsonrpc": "2.0", "result": { "grades": { "grade1": { "<grade.name>": "<grade.value>" } } } }
Использование со стандартными плагинами
Стандартные плагины ориентируются на теги термов, а именно:
grade.term.*
,grade.term.<grade>
- теги для термов (слагаемых).grade.coefficient.*
,grade.coefficient.<grade>
- теги для коэффициентов.grade.self.*
,grade.self.<grade>
- теги для грейдов (оценок).
Учитывая эту информацию, пройдите шаги из инструкции выше.
Использование вайлдкарда
"Плагины по-умолчанию" предоставляют возможность использования общего вайлдкарда для тегов - *
.
Данный нюанс позволяет "протаскивать" в ответ значение любых слагаемых и коэффициентов, если это требуется.
Допустим, есть терм с именем term1
, для которого вычислено значение public
и который имеет тег *
.
В ответе (для запроса, указанного выше) его можно будет увидеть среди данных грейда:
{ "id": "<request.id>", "jsonrpc": "2.0", "result": { "grades": { "grade1": { "<grade.name>": "<grade.value>", "term1": "public" } } } }