Common Structure
View objects expose a number of fields, they are optional unless specified otherwise.
name(обязательный параметр)- only useful as a mnemonic/description of the view when looking for one in a list of some sort
model- the model linked to the view, if applicable (it doesn’t for QWeb views)
priorityclient programs can request views by
id, or by(model, type). For the latter, all the views for the right type and model will be searched, and the one with the lowestprioritynumber will be returned (it is the «default view»).priorityalso defines the order of application during view inheritancearch- the description of the view’s layout
groups_idMany2manyfield to the groups allowed to view/use the current viewinherit_id- the current view’s parent view, see Наследование., unset by default
mode- inheritance mode, see Наследование.. If
inherit_idis unset themodecan only beprimary. Ifinherit_idis set,extensionby default but can be explicitly set toprimary application- website feature defining togglable views. By default, views are always applied
banner_routea route address to be fetched and prepended to the view.
Если этот атрибут установлен то данный url контроллера будет запрошен и отображен поверх представления. Ответ json от контроллера должен содержать ключ «html».
Если html содержит тег <link> таблицы стилей, он будет удален и добавлен в <head>.
Для взаимодействия с бекэндом вы можете использовать теги <a type=»action»> . Пожалуйста обратите внимание в документации на метод _onActionClicked класса AbstractController (addons/web/static/src/js/views/abstract_controller.js) для того чтобы узнать об этом поподробнее.
Только те представления, которые расширяют AbstractView и AbstractController могут использовать атрибуты, например такие как Forms, Kanban, Lists, …
Пример:
<tree banner_route="/module_name/hello" />
class MyController(odoo.http.Controller): @http.route('/module_name/hello', auth='user', type='json') def hello(self): return { 'html': """ <div> <link href="/module_name/static/src/css/banner.css" rel="stylesheet"> <h1>hello, world</h1> </div> """ }
Наследование.
Соответствие представления
- if a view is requested by
(model, type), the view with the right model and type,mode=primaryand the lowest priority is matched - when a view is requested by
id, if its mode is notprimaryits closest parent with modeprimaryis matched
Разрешение представления
Разрешение генерирует финальный arch для запрошенного/совпадающего primary представления:
- если представление имеет предка и родительский элемент полностью опознан, тогда применяются спецификации наследования текущего представления
- Если у представления нет родителя, его
archиспользуется как есть - дочерние элементы текущего представления с режимом
extensionищутся, и их спецификации наследования применяются сначала в глубину (применяется дочернее представление, затем его дочерние элементы, затем его родные элементы)
Результатом применения представлений дочерних элементов является финальный вариант arch
Определение наследования
Определение наследования состоит из элемента локатора, для поиска наследуемого элемента в родительском представлении и дочернего элемента, который будет использоваться для изменения унаследованного элемента.
Существует три типа локаторов для поиска целевого элемента:
- директива
xpathс атрибутомexpr.expr- выражение XPath expression2 , примененное к текущемуarch, первый узел, который он находит и является искомым - директива
fieldс атрибутомname, находит первое вхождениеfieldс тем жеname. Все остальные атрибуты игнорируются при совпадении - любой другой элемент: первый элемент с тем же именем и идентичными атрибутами (игнорируются атрибуты
positionиversion) и будет искомым
Определение наследования может иметь необязательный атрибут position, определяющий, каким образом должен быть найден нужный узел для дальнейшего изменения:
inside(по умолчанию)- содержимое определенного наследования добавляется к найденному узлу
replace- содержимое определенного наследования заменяет найденный узел. Любой текстовый узел, содержащий только
$ 0внутри содержимого спецификации, будет заменен полной копией найденного узла, эффективно обернув найденный узел. after- содержимое определенного наследования добавляется к родительскому элементу найденного узла сразу после этого узла
before- Содержимое определения наследования добавляется к родительскому элементу найденного узла перед ним
attributesв определении наследования должны быть элементы
attributeс атрибутомnameи содержимым, наличие которого не является обязательным:- если у элемента
attributeесть содержимое, в найденном узле создается новый атрибут, после егоname, с текстом элементаattributeкак значением - если у элемента
attributeнет тела, атрибут, указанный после егоname, удаляется из найденного узла. Если такой атрибут отсутствует, возникает ошибка
- если у элемента
Additionally, the position move can be used as a direct child of a spec
with a inside, replace, after or before position attribute
to move a node.
<xpath expr="//@target" position="after">
<xpath expr="//@node" position="move"/>
</xpath>
<field name="target_field" position="after">
<field name="my_field" position="move"/>
</field>
Определения представления применяются последовательно.
Lists
Корневым элементом представления List является <tree>3. Корень представления может иметь следующие атрибуты:
editableпо умолчанию выбор строки представления списка открывает соответствующее представление Form. Атрибуты
editableдают возможность редактировать данные прямо в представлении List.Допустимыми значениями являются
topиbottom, в результате чего новые записи появляются соответственно в верхней или нижней части списка.Внутреннее устройство представление Form является производным представления List. Большинство атрибутов допустимы представлением Form, и точно таким же образом, кнопки принимаются представлениями List, хотя они могут не иметь никакого значения, если представление List недоступно для редактирования
default_orderoverrides the ordering of the view, replacing the model’s default order. The value is a comma-separated list of fields, postfixed by
descto sort in reverse order:<tree default_order="sequence,name desc">
colorsНе рекомендуется, начиная с версии 9.0: replaced by
decoration-{$name}fontsНе рекомендуется, начиная с версии 9.0: replaced by
decoration-{$name}decoration-{$name}позволяют изменять стиль текста строки на основе атрибутов связанной записи.
Значения - это выражения Python. Для каждой записи выражение вычисляется по атрибутам записи как значениям контекста и если вычисление возвращает
true, то соответствующий стиль применяется к строке. Другими значениями контекста являютсяuid(id текущего пользователя) иcurrent_date(текущая дата в виде строки формыyyyy-MM-dd).{$name}can bebf(font-weight: bold),it(font-style: italic), or any bootstrap contextual color (danger,info,muted,primary,successorwarning).create,edit,delete- непозволяет изменять соответствующее действие в представлении, устанавливая нужный атрибут на
false limit- the default size of a page. It should be a positive integer
on_writeonly makes sense on an
editablelist. Should be the name of a method on the list’s model. The method will be called with theidof a record after having created or edited that record (in database).The method should return a list of ids of other records to load or update.
stringalternative translatable label for the view
Не рекомендуется, начиная с версии 8.0: not displayed anymore
Допустимыми дочерними элементами представления List являются:
Forms
Представления Form используются для отображения данных одной записи. Их корневой элемент - <form>. Они состоит из обычного HTML с дополнительными структурными и семантическими компонентами.
Структурные компоненты
Структурные компоненты обеспечивают структуру или «визуальные» функции с небольшим количеством логики. Они используются как элементы или наборы элементов в представлениях Form.
notebookопределяет секцию с вкладками. Каждая вкладка определяется через дочерний элемент
page.pageэлементы могут иметь следующие атрибуты:string(обязательный параметр)- the title of the tab
accesskey- an HTML accesskey
attrs- standard dynamic attributes based on record values
Примечание
Помните что
notebookне должен находится внутриgroupgroupиспользуется для определения расположения столбцов в представлениях Form. По умолчанию группы определяют 2 столбца, а большинство прямых потомков групп занимают один столбец. Прямые прямые потомки
fieldпо умолчанию отображают значениеlabel, аlabelиfeildимеютcolspanпо 1 каждому.Количество столбцов в
groupможно настроить с помощью атрибутаcol, количество столбцов, взятых элементом, можно настроить с помощьюcolspan.Дочерние элементы располагаются горизонтально (пытаются заполнить следующий столбец перед сменой строки).
Группы могут иметь атрибут
строка, который отображается как название группыnewline- полезен только внутри элементов
group, рано заканчивает текущую строку и сразу переключается на новую строку (без предварительного заполнения любого оставшегося столбца) separator- небольшой горизонтальный интервал с атрибутом
stringведет себя как заголовок раздела sheet- может использоваться в качестве прямого потомка для
formпридания представлению Form более компактный вид, превращая его как бы в бумажный лист header- в сочетании с
sheet, обеспечивает область во всю ширину над основным блоком, как правило, используется для отображения кнопок рабочего процесса и виджетов состояния
Семантические компоненты
Семантические компоненты выступают в качестве связующих звеньев и позволяют взаимодействовать с системой Odoo. Допустимыми семантическими компонентами являются:
buttonинициирует вызов функции внутри системы Odoo, аналогично кнопки представления List. Кроме того, можно указать следующий атрибут:
special- для представлений Form открывается диалоговом режиме:
saveсохранить запись и закрыть ,cancelзакрывает без сохранения.
fieldrenders (and allow edition of, possibly) a single field of the current record. Possible attributes are:
name(обязательный параметр)- имя отображаемого поля
widget- поля разный внешний вид по умолчанию в зависимости от их типа (например
Char,Many2one). Атрибутыwidgetпозволяют использовать другой метод визуализации и контекст. options- Параметр конфигурации объекта JSON для виджета поля (включая виджеты по умолчанию)
classКласс HTML для установки на сгенерированный элемент, классы
field:oe_inline- предотвратить обычный разрыв строки после полей
oe_left,oe_right- floats это свойство CSS будет применено к полю с соответствующим направлением
oe_read_only,oe_edit_only- отображает поле только в соответствующем режиме формы
oe_no_button- avoids displaying the navigation button in a
Many2one oe_avatar- для полей изображений, отображает изображения как аватары (имеет форму квадрата, максимальный размер 90x90 и некоторые декораторы)
groups- отображает поле только для определенных пользователей
on_changeвызывает указанный метод, когда значение этого поля редактируется, может генерировать обновления других полей или отображать предупреждения для пользователя
Не рекомендуется, начиная с версии 8.0: Используйте декоратор
odoo.api.onchange()внутри самой моделиattrs- динамические мета-параметры, основанные на значениях записи
domain- только для реляционных полей, фильтры, применяемые при отображении существующих записей
context- только для реляционных полей, контекст для запроса возможных значений
readonly- Отображать поле как в режиме только для чтения, так и в режиме редактирования, но никогда не позволяет редактировать его самого
required- генерирует ошибку и предотвращает сохранение записи, если поле не имеет значения
nolabel- не отображать метку поля автоматически, имеет смысл только в том случае, если поле является прямым потомком элемента
group placeholder- показывает вспомогательное сообщение пустых полях. Может заменять метки полей в сложных формах. Не должны быть похожи на уже введенные данные , так как пользователи могут путать текст заполнитель с заполненными полями
mode- для
One2many, режим отображения (тип представления) для использования связанных записей поля. Может иметь одно из следующих значенийtree,form,kanbanилиgraph. по умолчанияtree(отображается в виде списка) help- Подсказка, отображаемая для пользователей при наведении курсора на поле или его метку
filename- для полей с типом binary, имя поля, предоставляющего имя файла
password- указывает, что поле
Charхранит пароль и что его данные не должны отображаться
Graphs
Представление Graph используется для визуализации сводных данных по нескольким записям или группам записей. Его корневым элементом является ``<graph> ``, который может принимать следующие атрибуты:
type- каждое из этих значений
bar(по умолчанию),pieиline, это тип используемого графика stacked- используется только для графика с типом
bar. Если таковой тип присутствует установлен вTrue, то колонки будут объеденены в группы
Единственным допустимым элементом в представлении Graph является field, которое может иметь следующие атрибуты:
name(обязательный атрибут)- имя поля для использования представлении. Если используется для группировки (а не объединения)
title(необязательный параметр)- строка отображаемая вверху представления.
typeуказывает, должно ли поле использоваться как критерий группировки или как агрегированное значение внутри группы. Возможные значения:
row(по умолчанию)- группирует по указанному полю. Все типы графиков поддерживают по крайней мере один уровень группировки, некоторые могут поддерживать больше.
col- авторизован в представлениях Graph, но используется только в pivot таблицах
measure- поле для агрегирования внутри группы
interval- применяется к
dateиdatetimeполям, группирует по указанным интервалам (day,week,month,quarterилиyear)вместо группировки по указанному времени (фиксированные значения секунд) или дате (фиксированные значения дней).
измерения автоматически генерируются из полей модели; используются только агрегируемые поля. Эти измерения также сортируются в алфавитном порядке по строке поля.
Предупреждение
агрегирование представлений Graph выполняется по содержимому базы данных, не сохраняемые поля функций нельзя использовать в представлениях Graph
Pivots
Представление Pivot используется для визуализации объединенных данных как pivot таблицы. Его корневым элементом является <pivot>, который может принимать следующие атрибуты:
disable_linking- Установите
True, чтобы удалить ссылки ячеек таблицы на представление List. display_quantity- Установите
true, чтобы отображать колонку количества по умолчанию. default_orderИмя измерения и порядок сортировки (asc или desc) для использования по умолчанию в представлении.
<pivot default_order="foo asc"> <field name="foo" type="measure"/> </pivot>
Единственным допустимым элементом в представлении Pivot является field, которое может иметь следующие атрибуты:
name(обязательный атрибут)- имя поля для использования представлении. Если используется для группировки (а не объединения)
string- имя, которое будет использоваться для отображения поля в представлении Pivot, переопределяет атрибут поля
stringв Python. typeуказывает, должно ли поле использоваться как критерий группировки или как агрегированное значение внутри группы. Возможные значения:
row(по умолчанию)- группировка по указанному полю, каждая группа получает свою строку.
col- создает группы колонок
measure- поле для агрегирования внутри группы
interval- применяется к
dateиdatetimeполям, группирует по указанным интервалам (day,week,month,quarterилиyear)вместо группировки по указанному времени (фиксированные значения секунд) или дате (фиксированные значения дней).
invisible- если
true, поле не появится в активных измерениях ни в выбираемых (полезно для полей, которые не имеет смысла агрегировать, такие как поля в разных единицах, например, € и $).
измерения автоматически генерируются из полей модели; используются только агрегируемые поля. Эти измерения также сортируются в алфавитном порядке по строке поля.
Предупреждение
так же как и представление Graph, Pivot делает выборку из базы данных, не сохраняемые поля функций нельзя использовать в представлениях Pivot
В представлении Pivot field может иметь атрибут widget который диктует его формат. widget - это средством форматирования поля, наиболее интересными из которых являются date, datetime, float_time, и monetary.
Например, Pivot представление расписания может быть определено как:
<pivot string="Timesheet">
<field name="employee_id" type="row"/>
<field name="date" interval="month" type="col"/>
<field name="unit_amount" type="measure" widget="float_time"/>
</pivot>
Kanban
Представление Kanban являет собой визуализацию канбан доску: она отображает записи как « карты», и призваны заполнить промежуточную нишу между представлением List и нередактируемым представлением Form. Записи могут быть сгруппированы в столбцы для использования для визуализации рабочего процесса или в его манипуляции (например для отображения задач или управления прогрессом работ) или не группироваться (используются просто для визуализации записей).
Примечание
Представление Kanban загрузит и отобразит не более десяти столбцов. Любой столбец после этого будет свернут (но все же может быть открыт пользователем).
Корневым элементом представления Kanban является <kanban>, он может использовать следующие атрибуты:
default_group_by- указывает на то, следует ли группировать представление Kanban, если группировка не указана с помощью действия или текущего поиска. Должно быть именем поля, по которому нужно группировать, если никакая другая группировка не указана
default_order- порядок сортировки карточек, если пользователь еще не отсортировал записи (через представление List)
class- добавляет HTML-классы к корневому элементу HTML представления Kanban
group_create- определяет видим ли элемент «Добавить новую колонку». По умолчанию:
true. group_delete- определяет могут ли группы быть удалены через контекстное меню. По умолчанию:
true. group_edit- определяет могут ли группы быть отредактированы через контекстное меню. По умолчанию:
true. archivable- определяет могут ли записи колонки быть заархивированы/восстановлены если поле
activeопределено в модели. По умолчанию:true. quick_createопределяет следует ли создавать записи без переключения на представление Form. По умолчанию,
quick_createвключено, когда представление Kanban сгруппировано поmany2one,selection,charилиbooleanполям и отключено, если нет.Установите
trueчтобы всегда разрешать, иfalseвсегда отключать.
Допустимые дочерние элементы представления:
fieldобъявляет поля для агрегирования или для использования в kanban *логике *. Если поле просто отображается в представлении Kanban, его не нужно предварительно объявлять.
Допустимые атрибуты:
name(обязательный атрибут)- имя требуемого поля
progressbarобъявляет элемент прогрессбара, который будет находится сверху канбан колонки.
Допустимые атрибуты:
field(обязательный параметр)- имя поля, значения которого используются для учета записей столбца в прогресбаре
colors(обязательный параметр)- JSON mapping the above field values to either «danger», «warning» or «success» colors
sum_field(необязательный параметр)- имя поля, значения записей в столбце которого будут суммироваться и отображаться рядом с прогресбаром (если опущено, отображает общее количество записей)
templatesопределяет список QWeb шаблонов. Определение карточек может быть разбито на несколько шаблонов для большей наглядности, но представления Kanban должны определять хотя бы один корневой шаблон
kanban-box, который будет отображаться один раз для каждой записи.Представление Kanban использует в основном javascript qweb и предоставляет следующие контекстные переменные:
widget- текущий класс
KanbanRecord(), может быть испльзован для доступа к мета-информации. Эти методы так же доступны прямо из контекста шаблона и не требуют доступа черезwidget record- объект со всеми запрошенными полями в качестве атрибутов. Каждое поле имеет два атрибута
valueиraw_value, первое форматируется в соответствии с текущими пользовательскими параметрами, второе является прямым значением изread()(кроме полейdateиdatetimeкоторые форматируются на базе локали пользователя) read_only_modeназвание говорит само за себя
Кнопки и поля
Пока большинство Kanban шаблонов это стандартный QWeb, представление Kanban специальные элементы
field,buttonиa:- by default fields are replaced by their formatted value, unless they match specific kanban view widgets
кнопки и ссылки с атрибутом
typeстали выполнять операции, связанные с Odoo, а не их стандартную функцию HTML. Возможные типы:action,object- стандартное поведение для Odoo buttons, можно использовать большинство атрибутов, относящихся к стандартным кнопкам Odoo.
open- открывает запись карточки в представлении Form в режиме только для чтения
edit- открывает запись карты в представлении Form в редактируемом режиме
delete- удаляет запись карты и удаляет карту
Если вы хотите расширить представление Kanban смотрите :js:class::[UNKNOWN NODE title_reference].
Calendar
Представление Calendar записи как события в однодневном, недельном или месячном календарях. Его корневым элементом является <calendar>. Допустимыми атрибутами в представлении Calendar являются:
date_start(обязательный атрибут)- имя поля записи, содержащее дату начала события
date_stop- имя поля записи, содержащее дату окончания события, если указана
date_stop, записи становятся подвижными (с помощью перетаскивания) непосредственно в представлении Calendar date_delay- альтернатива
date_stop, указывает продолжительность события, а не его дату окончания (едица: день) color- имя поля записи, используемое для цветового разделения. Записи в одного сегмента в представлении Calendar подсвечиваются тем же цветом, значения цветов распределяются псевдо-случайным образом. На боковой панели отображается легенда
readonly_form_view_id- view to open in readonly mode
form_view_id- ссылка на id представления, которое будет открываться когда пользователь захочет создать или отредактировать запись. Обратите внимание, что если этот атрибут не установлен, представление Calendar будет пытать обратиться к идентификатору представления Form в текущем закрепленным за этим действием, если таковое существует.
event_open_popup- Если для параметра
event_open_popupзадано значениеtrue, представление Calendar будет открывать события (или записи) вFormViewDialog. В противном случае он откроет события в новом представлении From (с помощьюdo_action) quick_add- включает быстрое создание событий при клике: запрашивает у пользователя
nameи пытается создать новое событие именно с тем временем, куда был произведен клик. Возвращается к вышеописанному диалоговому окну, если быстрое создание не удалось выполнить all_day- имя поля типа Boolean, указывающее, отмечено ли соответствующее событие как занимающее целый день (продолжительность не имеет значения)
mode- Режим отображения по умолчанию при загрузке представления Calendar. Допустимые атрибуты:
day,week,month <field>объявляет поля для объединения или для использования в логике kanban . Если указано то поле просто отображается в карточке Calendar.
Поля могут иметь следующие дополнительные атрибуты:
invisible- use «True» to hide the value in the cards
avatar_field- only for x2many field, to display the avatar instead the display_name in the cards
write_modelandwrite_field- you can add a filter and save the result in the defined model, the filter is added in the sidebar
templatesопределяет QWeb шаблон
calendar-box. Определение карточек может быть разбито на несколько шаблонов для большей наглядности, которые будут рендерится для каждой записи.Представление Kanban использует в основном javascript qweb и предоставляет следующие контекстные переменные:
widget- текущий класс
KanbanRecord(), может быть использован для доступа к некоторой метаинформации. Эти методы также доступны прямо в контексте шаблона и нет необходимость иметь доступ кwidgetgetColorдля преобразования числа определяющего цветgetAvatarsдля смены изображения аватраdisplayFieldsсписок скрытых полей record- объект атрибутами которого являются запрошенные поля. Каждое поле имеет два атрибута
valueиraw_value event- объект события
format- метод для преобразования значений в читаемую строку с пользовательскими параметрами
fields- определение параметров всех полей модели
user_context- название говорит само за себя
read_only_mode- название говорит само за себя
Gantt
Представления Gantt предназначены для формирования диаграмм Ганта (они, как правило, применяются для планирования).
Корневым элементом представлений Gantt является ``<gantt /> ``, у него нет потомков, но он может принимать следующие атрибуты:
date_start(обязательный атрибут)- Имя поля, указывающего на дату начала события для каждой записи.
date_stopname of the field providing the end duration of the event for each record. Can be replaced by
date_delay. One (and only one) ofdate_stopanddate_delaymust be provided.If the field is
Falsefor a record, it’s assumed to be a «point event» and the end date will be set to the start datedate_delay- name of the field providing the duration of the event
duration_unit- one of
minute,hour(default),day,week,month,year default_group_by- имя поля для группировки задач
typeganttclassic gantt view (default)consolidatevalues of the first children are consolidated in the gantt’s taskplanningchildren are displayed in the gantt’s taskconsolidation- имя поля для отображения значения консолидации в ячейке записи
consolidation_max- dictionary with the «group by» field as key and the maximum consolidation
value that can be reached before displaying the cell in red
(e.g.
{"user_id": 100}) consolidation_excludename of the field that describe if the task has to be excluded from the consolidation if set to true it displays a striped zone in the consolidation line
Предупреждение
The dictionnary definition must use double-quotes,
{'user_id': 100}is not a valid valuecreate,edit- непозволяет изменять соответствующее действие в представлении, устанавливая нужный атрибут на
false string- string to display next to the consolidation value, if not specified, the label of the consolidation field will be used
fold_last_level- If a value is set, the last grouping level is folded
round_dnd_dates- enables rounding the task’s start and end dates to the nearest scale marks
drag_resize- resizing of the tasks, default is
true progress- имя поля, предоставляющего процент завершения события записи, от 0 до 100
Diagram
Представление Diagram может использоваться для отображения ориентированных графов записей. Корневой элемент <diagram> и не имеет атрибутов.
Допустимые дочерние элементы представления Ddiagram:
node(обязательный параметр, 1)Определяет узлы графа. Его атрибуты:
object- узел модели Odoo
shape- Условное сопоставление фигуры с цветами и шрифтами в the list view. Единственной допустимой фигурой является
rectangle(фигура по умолчанию - элипс) bgcolor- тоже что и
shape, но условно сопостявляет фоновый цвет для узлов. По умолчанию цвет фона - белый, единственной допустимой альтернативой являетсяgrey.
arrow(обязательный параметр, 1)Определяет направленные ребра графа. Его атрибуты:
object(обязательный параметр)- Модель Odoo в качестве ребра
source(обязательный параметр)Many2oneполе модели ребра которая указывает на запись, которая является начальной точкой ребраdestination(обязательный параметр)Many2oneполе модели ребра которая указывает на запись, которая является конечной точкой ребраlabel- Список атрибутов Python (в виде цитируемых строк). Соответствующие значения атрибутов будут объединены и отображены как метка ребра
label- Примечание для диаграммы, атрибут
stringопределяет содержание примечания. Каждаяlabelвыводится как параграф в заголовке диаграммы.
Dashboard
Как представления Pivot и Graph, представление Dashboard используется для отображения агрегированных данных. Тем не менее, в Dashboard могут быть вложенные представления, что позволяет более полно и интересно взглянуть на выбранный набор данных.
Предупреждение
The Dashboard view is only available in Odoo Enterprise.
Представление Dashboard может отображать вложенные представления, множества для полей (через домен), или даже формулы (выражения, которые включают в себя один или несколько множеств). Вот простой пример представления Dashboard:
<dashboard>
<view type="graph" ref="sale_report.view_order_product_graph"/>
<group string="Sale">
<aggregate name="price_total" field="price_total" widget="monetary"/>
<aggregate name="order_id" field="order_id" string="Orders"/>
<formula name="price_average" string="Price Average"
value="record.price_total / record.order_id" widget="percentage"/>
</group>
<view type="pivot" ref="sale_report.view_order_product_pivot"/>
</dashboard>
Корневым элементом представления Dashboard является <dashboard>. Он не принимает атрибутов.
Существует 5 допустимых тегов и представлении Dashboard:
viewопределяет вложенные представления.
Допустимые атрибуты:
type(обязательный атрибут)- Тип вложенного представления. Например graph или pivot.
ref(необязательный атрибут)- xml id представления. Если не указан, то будет использовано представление по умолчанию для модели.
name(необязательный атрибут)- Строка, которая идентифицирует этот элемент. В основном это полезно при использования в качестве цели для xpath.
groupопределяет расположение столбцов. На самом деле это очень похоже на элемент группы в представлении Form.
Допустимые атрибуты:
string(необязательный атрибут)- Описание которое будет отображаться в названии группы.
colspan(необязательный атрибут)- Количество колонок в группе, по умолчанию 6.
col(необязательный атрибут)- Количество столбцов, охватываемых этой группой (имеет смысл только внутри другой группы). По умолчанию 6.
aggregateобъявляет множество. Это значение множества для данного поля в текущем домене.
Обратите внимание что тег
aggregatesиспользуются внутри тега ``group `` (иначе стиль не будет применен должным образом).Допустимые атрибуты:
field(обязательный параметр)Имя поля, используемого для вычисления множества. Возможные типы поля:
integer(оператором по умолчанию является сумма)float(оператором по умолчанию является сумма)many2one(оператором по умолчанию является количество )
name(обязательный параметр)- Строка идентифицирующая данное множество (полезно для использования в формулах)
string(необязательный атрибут)- Краткое описание, которое будет отображаться над значением. Если не указанно, то будет показано содержимое поля
string.
domain(необязательный параметр)- Дополнительное ограничение на набор записей, которые мы хотим использовать во множестве. Этот домен будет объединен с текущим доменом.
domain_label(необязательный параметр)- Когда пользователь нажимает на множество с доменом, он будет добавлен в представление Search как отдельный запрос. Строка, отображаемая для этого запроса, может быть настроена с помощью этого атрибута.
group_operator(необязательный параметр)Действительный идентификатор агрегатной функции PostgreSQL, который будет использоваться при объединении значений(см. https://www.postgresql.org/docs/9.5/static/functions-aggregate.html). Если не указано иное, по умолчанию используется
group_operatorиз определения поля. Обратите внимание, что множество значений полей не будет достигнуто, если значение ``group_operator `` равно «».Примечание
Специальная агрегатная функция
count_distinct(определенная в odoo) может быть здесь задействована<aggregate name="price_total_max" field="price_total" group_operator="max"/>
col(необязательный атрибут)- Количество столбцов, охватываемых этим тегом (имеет смысл только внутри группы). По умолчанию 1.
widget(необязательный параметр)- Виджет для форматирования значения (как, атрибут
widgetдля полей). Например,monetary.
help(необязательный параметр)- Справочное сообщение для отображения во всплывающей подсказке (эквивалент параметра help для поля в Python)
measure(необязательный атрибут)Этот атрибут представляет собой имя поля, описывающего меру, которая должна использоваться в представлениях Graph и Pivot при клике на множество. Специальное значение
__count__может использоваться, чтобы задействовать измерение счета.<aggregate name="total_ojects" string="Total Objects" field="id" group_operator="count" measure="__count__"/>
clickable(необязательный атрибут)- Логическое значение, указывающее, должено ли это множество быть кликабельным или нет (по умолчанию true). Нажатие на кликабельное множество изменит показатели, используемые вложенными представлениями, и добавит значение атрибута домена (если есть) в представление Search.
value_label(необязательный параметр)- Строка, расположенная справа от значения множества. Например, может быть полезно указать его единицу измерения.
formulaобъявляет производное значение. Формулы - это значения, рассчитанные из множеств.
Обратите внимание, что как и множества, формулы должны использоваться внутри тега группы (иначе стиль не будет применен должным образом).
Допустимые атрибуты:
value(обязательный атрибут)- Строковое выражение, которое будет исполнятся с помощью встроенного средства запуска Python (в веб-клиенте). Каждое множество может использоваться в контексте переменной
record. Например,record.price_total / record.order_id.
name(необязательный атрибут)- Строка идентифицирующая данную формулу
string(необязательный атрибут)- Краткое описание которое будет отображаться поверх формулы.
col(необязательный атрибут)- Количество столбцов, охватываемых этим тегом (имеет смысл только внутри группы). По умолчанию 1.
widget(необязательный параметр)- Виджет для форматирования значения (как, атрибут
widgetдля полей). Например,monetary. По умолчанию этоfloat.
help(необязательный параметр)- Справочное сообщение для отображения во всплывающей подсказке (эквивалент параметра help для поля в Python)
value_label(необязательный параметр)- Строка, расположенная справа от значения формулы. Например, может быть полезно указать единицу измерения значения формулы.
widgetОбъявляет специализированный виджет, который будет использоваться для отображения информации. Этот механизм похож на виджеты в представлении Form.
Допустимые атрибуты:
name(обязательный параметр)- Строка, определяющая, какой виджет должен быть создан. Представление будет смотреть в ` widget_registry``, чтобы получить правильный класс.
col(необязательный атрибут)- Количество столбцов, охватываемых этим тегом (имеет смысл только внутри группы). По умолчанию 1.
Cohort
Представление Cohort используется для отображения и понимания того, как некоторые данные изменяются в течение определенного периода времени. Например, представьте, что для данного бизнеса клиенты могут подписаться на какой-либо сервис. Затем в представлении Cohort может отображаться общее количество подписок в месяц и изучаться частота, с которой клиенты отказываются от использования сервиса (отток). Если кликнуть на ячейку, представление Cohort перенаправит вас на новое действие, в котором вы увидите только записи, содержащиеся во временном интервале ячейки; это действие содержит представление List и представление Form.
Предупреждение
The Cohort view is only available in Odoo Enterprise.
Примечание
По умолчанию в представлении Cohort будет использоваться те же представления List и Form, что и в действии. Вы можете передать представление List и представление Form в контекст действия, чтобы установить/переопределить представления, которые будут использоваться (ключи контекста для переопределения form_view_id и list_view_id)
Вот пример простого определения представления Cohort:
<cohort string="Subscription" date_start="date_start" date_stop="date" interval="month"/>
Корневым элементом представления Cohort является <cohort>, он принимает следующие атрибуты:
string(обязательный атрибут)- Описание представления
date_start(обязательный атрибут)- Валидное поле date или datetime. Это поле понимается представлением как дата начала записи
date_stop(обязательный атрибут)- Валидное поле date или datetime. Это поле понимается представлением как дата окончания записи. Это поле, которое будет определять отток (churn).
mode(необязательный атрибут)- Строка для описания режима. Это может быть либо
churn, либо``retention`` (по умолчанию). Режимchurnбудет начинаться с 0% и накапливаться со временем, тогда какretentionбудет начинаться с 100% и уменьшаться со временем.
timeline(необязательный атрибут)- Строка для описания временной шкалы. Значение может быть либо
backward, либоforward(по умолчанию).forwardбудет отображать данные отdate_startдоdate_stop, тогда какforwardбудет отображать данные отdate_stopдоdate_start(когдаdate_startнаходится в будущем/дальше чемdate_stop).
interval(необязательный атрибут)- Строка для описания временного интервала. Может принимать значения
day,week,month(по умолчанию) илиyear.
measure(необязательный атрибут)- Поле, которое можно агрегировать. Это поле будет использоваться для вычисления значений для каждой ячейки. Если не определено, то представление Cohort просто высчитает количество вхождений.
Activity
The Activity view is used to display the activities linked to the records. The data are displayed in a chart with the records forming the rows and the activity types the columns. When clicking on a cell, a detailed description of all activities of the same type for the record is displayed.
Предупреждение
Представление Activity доступно только тогда, когда установлен модуль mail, и остальные модели наследуют mail.activity.mixin.
For example, here is a very simple Activity view:
<activity string="Activities"/>
The root element of the Activity view is <activity>, it accepts the following attributes:
string(обязательный атрибут)- Описание представления
Search
Представления Search отличаются от предыдущих типов представлений тем, что они не отображают *content *: хотя они применяются к определенной модели, они используются для фильтрации содержимого другого представления (как правило, е представления-агрегаторы, например Lists or Graphs). Не смотря на это различие, они определяются одинаково.
Корневым элементом представлений поиска является <search>. Он не принимает атрибутов.
Допустимые дочерние элементы в представлении Search:
fieldПоля определяют домены или контексты со значениями, который вводят пользователи. Когда создаются поисковые домены, домены полей составляются друг с другом и с фильтрами, используя оператор AND.
Поля могут иметь следующие атрибуты:
name- имя поля для фильтрации
string- описание поля
operatorпо умолчанию, поля генерируют домен по следующему шаблону
[(name, operator, provided_value)]гдеnameимя поляprovided_valueзначение предоставленное пользователем, возможно отфильтрованный или преобразованный (например, ожидается, что пользователь предоставит метку значения поляselection, а не само значение).Атрибут
operatorпозволяет переопределять оператор по умолчанию, который зависит от типа поля (например,=для полей с типомfloat, ноilikeдля полей с типомchar)filter_domainполный домен, который можно использовать в качестве домена поиска поля, может использовать переменную
selfдля вставки предоставленного значения в пользовательский домен. Может использоваться для генерации значительно более гибких доменов, чем только «оператор» (например, поиск по нескольким полям одновременно)Если указаны оба
operator, иfilter_domain, то приоритет имеетfilter_domain.contextallows adding context keys, including the user-provided value (which as for
domainis available as aselfvariable). By default, fields don’t generate domains.Примечание
домен и контекст включены и оба генерируются, если указан
context. Чтобы только генерировать значения контекста, установитеfilter_domainв пустой список:filter_domain = "[]"groups- сделать поле доступным только для определенных пользователей
widget- используйте конкретный виджет поиска для поля (единственный случай использования в стандарте Odoo 8.0 - это виджет
selectionдля полейMany2one) domain- если поле может обеспечить автодополнение (например
Many2one), отфильтрует возможные результаты завершения.
filterфильтр - это предопределенный переключатель в представлении Search, его можно включить или отключить. Его основная цель добавление данных в контекст поиска (контекст, передаваемый в представление данных для поиска/фильтрации), или для добавления новых разделов в фильтр поиска.
Фильтры могут иметь следующие атрибуты:
string(обязательный параметр)- описание фильтра
domain(необязательный параметр)- домен Odoo domain, будет добавлен к домену действия как часть поискового домена.
date(необязательный параметр)the name of a field of type
dateordatetime. Using this attribute has the effect to create a set of filters available in a submenu of the filters menu.Пример:
<filter name="filter_create_date" date="create_date" string="Creation Date"/>
The example above allows to easily search for records with creation date field values in one of the periods below.
Create Date > Today This Week This Month This Quarter This Year -------------- Yesterday Last Week Last Month Last Quarter Last Year -------------- Last 7 Days Last 30 Days Last 365 Days
Note that the generated domains are dynamic and can be saved as such (via the favorites menu).
default_period(необязательный параметр)имеет смысл только для фильтра с непустым атрибутом
date. определяет, какой период активирован, если фильтр входит в набор фильтров по умолчанию, активируется при инициализации представления. Если значение не указано, по умолчанию используетсяthis_month.To choose among the following options: today, this_week, this_month, this_quarter, this_year, yesterday, last_week, last_month, last_quarter, last_year, last_7_days, last_30_days, last_365_days
Пример:
<filter name="filter_create_date" date="create_date" string="Creation Date" default_period="this_week"/>
contextсловарь Python, объединенный с доменом действия для создания домена поиска
The key
group_bycan be used to define a groupby available in the „Group By“ menu. The „group_by“ value can be a valid field name or a list of field names.<filter name="groupby_category" string="Category" context = {'group_by': 'category_id'}/>Определенная выше группировка позволяет группировать данные по категориям.
Когда тип поля
dateилиdatetime, фильтр генерирует подменю для меню «Группировать по», в котором доступны следующие параметры интервала:day,week,month,quarter,year.Если фильтр находится в наборе фильтров по умолчанию, активированном при инициализации представления, записи по умолчанию сгруппированы по месяцам. Это можно изменить с помощью синтаксиса
date_field:interval, как в следующем примере.Пример:
<filter name="groupby_create_date" string="Creation Date" context = {'group_by': 'create_date:week'}/>name- логическое имя фильтра, может использоваться для включить его по умолчанию, также может использоваться как hook наследования
help- более длинный пояснительный текст для фильтра, может отображаться в виде всплывающей подсказки
groups- делает фильтр доступным только для определенных пользователей
Совет
Добавлено в версии 7.0.
Последовательности фильтров (без разделения) рассматриваются как включенные композиции: они будут состоять из операторов
ИЛИ, а не обычногоИ.<filter domain="[('state', '=', 'draft')]"/> <filter domain="[('state', '=', 'done')]"/>
Если выбраны оба фильтра, выберет записи,
stateкоторых равенdraftилиdone, но<filter domain="[('state', '=', 'draft')]"/> <separator/> <filter domain="[('delay', '<', 15)]"/>
если выбраны оба фильтра, выберет записи,
stateкоторых являетсяdraftиdelayменьше чем 15.separator- может использоваться для разделения групп фильтров в простых представлениях Search
group- может использоваться для разделения групп фильтров, более читаемых, чем
separatorв сложных представлениях Search
Значения Search по умолчанию
Search fields and filters can be configured through the action’s context
using search_default_name keys. For fields, the value should be the
value to set in the field, for filters it’s a boolean value. For instance,
assuming foo is a field and bar is a filter an action context of:
{
'search_default_foo': 'acro',
'search_default_bar': 1
}
автоматически активирует фильтр bar и ищет поле foo для acro.
QWeb
QWeb views are standard QWeb templates inside a view’s
arch. They don’t have a specific root element.
A QWeb view can only contain a single template4, and the template’s name must match the view’s complete (including module name) external id.
template should be used as a shortcut to define QWeb views.
hasclass(*classes) узел будет попадать под выборку, если он узел имеет все указанные классы