IMP: Add single menu for content browsing

* Categories and content are now available and browsable in a single menu.
* Navigation helps user to find content easily
* Cleanups for pylint and flake
This commit is contained in:
Florent THOMAS
2022-02-10 23:41:48 +01:00
parent 25ca012afc
commit 8db04e2e12
8 changed files with 398 additions and 201 deletions

View File

@@ -0,0 +1,26 @@
<?xml version="1.0"?>
<odoo>
<menuitem id="menu_main_wiki"
name="Wiki"
action="action_category_navigation"
parent="knowledge.menu_document_root"
sequence="1"/>
<menuitem id="menu_wiki"
name="Pages"
parent="knowledge.menu_document_root"
sequence="10"/>
<menuitem id="menu_page"
name="Pages"
parent="menu_wiki"
action="action_page"
sequence="20"/>
<menuitem id="menu_category"
parent="menu_wiki"
name="Categories"
action="action_category"
sequence="20" />
</odoo>

View File

@@ -1,4 +1,4 @@
<?xml version="1.0"?>
<?xml version="1.0" ?>
<odoo>
<!-- wiki tree view -->
@@ -9,9 +9,9 @@
<field name="priority">100</field>
<field name="arch" type="xml">
<tree string="Document Page">
<field name="name"/>
<field name="content_uid"/>
<field name="content_date"/>
<field name="name" />
<field name="content_uid" />
<field name="content_date" />
</tree>
</field>
</record>
@@ -22,12 +22,12 @@
<field name="model">document.page</field>
<field name="arch" type="xml">
<tree string="Document Page">
<field name="name"/>
<field name="parent_id"/>
<field name="company_id" groups="base.group_multi_company"/>
<field name="create_uid" invisible="1"/>
<field name="content_uid"/>
<field name="content_date"/>
<field name="name" />
<field name="parent_id" />
<field name="company_id" groups="base.group_multi_company" />
<field name="create_uid" invisible="1" />
<field name="content_uid" />
<field name="content_date" />
</tree>
</field>
</record>
@@ -41,27 +41,27 @@
<sheet>
<div class="oe_button_box" name="button_box">
<button name="toggle_active" type="object" groups="document_page.group_document_manager" class="oe_stat_button" icon="fa-archive">
<field name="active" widget="boolean_button" options="{'terminology': 'archive'}"/>
<field name="active" widget="boolean_button" options="{'terminology': 'archive'}" />
</button>
</div>
<field name="type" invisible="1"/>
<field name="type" invisible="1" />
<h1>
<field name="name" placeholder="Name"/>
<field name="name" placeholder="Name" />
</h1>
<group>
<div>
<field name="content" widget="html" placeholder="e.g. Once upon a time..." required="1" options="{'safe': True}"/>
<field name="content" widget="html" placeholder="e.g. Once upon a time..." required="1" options="{'safe': True}" />
</div>
</group>
<notebook>
<page name="info" string="Information">
<group>
<group>
<field name="parent_id" string="Category" required="True" context="{'default_type':'category'}"/>
<field name="company_id" groups="base.group_multi_company"/>
<field name="content_uid"/>
<field name="content_date"/>
<field name="menu_id" readonly="1" attrs="{'invisible': [('menu_id','=',False)]}"/>
<field name="parent_id" string="Category" required="True" context="{'default_type':'category'}" />
<field name="company_id" groups="base.group_multi_company" />
<field name="content_uid" />
<field name="content_date" />
<field name="menu_id" readonly="1" attrs="{'invisible': [('menu_id','=',False)]}" />
</group>
<group string="Revision" class="oe_edit_only">
<field name="draft_name" placeholder="Rev 01" required="True" class="oe_edit_only" />
@@ -72,20 +72,20 @@
<page name="history" string="History">
<field name="history_ids">
<tree>
<field name="id"/>
<field name="create_date"/>
<field name="name"/>
<field name="summary"/>
<field name="create_uid"/>
<field name="id" />
<field name="create_date" />
<field name="name" />
<field name="summary" />
<field name="create_uid" />
</tree>
</field>
</page>
</notebook>
</sheet>
<div class="oe_chatter">
<field name="message_follower_ids" widget="mail_followers"/>
<field name="activity_ids" widget="mail_activity"/>
<field name="message_ids" widget="mail_thread"/>
<field name="message_follower_ids" widget="mail_followers" />
<field name="activity_ids" widget="mail_activity" />
<field name="message_ids" widget="mail_thread" />
</div>
</form>
</field>
@@ -96,11 +96,11 @@
<field name="model">document.page</field>
<field name="arch" type="xml">
<form string="Document Page" create="0">
<field name="type" invisible="1"/>
<field name="type" invisible="1" />
<h1>
<field name="name" placeholder="Name"/>
<field name="name" placeholder="Name" />
</h1>
<field name="content" widget="html" class="oe_view_only" required="1" options='{"safe": True}'/>
<field name="content" widget="html" class="oe_view_only" required="1" options='{"safe": True}' />
</form>
</field>
</record>
@@ -111,15 +111,14 @@
<field name="model">document.page</field>
<field name="arch" type="xml">
<search string="Document Page">
<field name="name" string="Content"
filter_domain="['|', ('name','ilike',self), ('content','ilike',self)]"/>
<field name="parent_id"/>
<field name="create_uid"/>
<field name="content_uid"/>
<field name="name" string="Content" filter_domain="['|', ('name','ilike',self), ('content','ilike',self)]" />
<field name="parent_id" />
<field name="create_uid" />
<field name="content_uid" />
<group expand="0" string="Group By...">
<filter name="group_by_category" string="Category" context="{'group_by':'parent_id'}"/>
<filter name="group_by_author" string="Author" context="{'group_by':'create_uid'}"/>
<filter name="group_by_last_contributor" string="Last Contributor" context="{'group_by':'content_uid'}"/>
<filter name="group_by_category" string="Category" context="{'group_by':'parent_id'}" />
<filter name="group_by_author" string="Author" context="{'group_by':'create_uid'}" />
<filter name="group_by_last_contributor" string="Last Contributor" context="{'group_by':'content_uid'}" />
</group>
</search>
</field>
@@ -134,8 +133,8 @@
<field name="context">{'default_type': 'content'}</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="view_id" ref="view_wiki_tree"/>
<field name="search_view_id" ref="view_wiki_filter"/>
<field name="view_id" ref="view_wiki_tree" />
<field name="search_view_id" ref="view_wiki_filter" />
<field name="help" type="html">
<p class="oe_view_nocontent_create">
Click to create a new web page.
@@ -144,40 +143,26 @@
</record>
<record id="action_page_view_tree" model="ir.actions.act_window.view">
<field name="sequence" eval="0"/>
<field name="sequence" eval="0" />
<field name="view_mode">tree</field>
<field name="view_id" ref="view_wiki_tree"/>
<field name="act_window_id" ref="action_page"/>
<field name="view_id" ref="view_wiki_tree" />
<field name="act_window_id" ref="action_page" />
</record>
<record id="action_page_view_form" model="ir.actions.act_window.view">
<field name="sequence" eval="5"/>
<field name="sequence" eval="5" />
<field name="view_mode">form</field>
<field name="view_id" ref="view_wiki_form"/>
<field name="act_window_id" ref="action_page"/>
<field name="view_id" ref="view_wiki_form" />
<field name="act_window_id" ref="action_page" />
</record>
<menuitem id="menu_wiki"
name="Pages"
parent="knowledge.menu_document_root"
sequence="10"/>
<menuitem id="menu_wiki" name="Pages" parent="knowledge.menu_document_root" sequence="10" />
<menuitem id="menu_page"
name="Pages"
parent="menu_wiki"
action="action_page"
sequence="20"/>
<menuitem id="menu_page" name="Pages" parent="menu_wiki" action="action_page" sequence="20" />
<act_window
id="action_related_page_create_menu"
name="Create Menu"
res_model="document.page.create.menu"
target="new"
view_type="form"
view_mode="form"
src_model="document.page"/>
<act_window id="action_related_page_create_menu" name="Create Menu" res_model="document.page.create.menu" target="new" view_type="form" view_mode="form" src_model="document.page" />
</odoo>

View File

@@ -1,9 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<template id="assets_backend" name="document_page assets" inherit_id="web.assets_backend">
<template
id="assets_backend"
name="document_page assets"
inherit_id="web.assets_backend"
>
<xpath expr="." position="inside">
<link rel="stylesheet" href="/document_page/static/src/css/document_page.css"/>
<link
rel="stylesheet"
href="/document_page/static/src/css/document_page.css"
/>
<script
type="text/javascript"
src="/document_page/static/src/js/document_page_kanban.js"
/>
</xpath>
</template>

View File

@@ -1,4 +1,4 @@
<?xml version="1.0"?>
<?xml version="1.0" ?>
<odoo>
<!-- Category Views -->
@@ -8,16 +8,21 @@
<field name="arch" type="xml">
<form string="Category">
<sheet>
<field name="type" invisible="1"/>
<h1><field name="name" placeholder="Name"/></h1>
<field name="type" invisible="1" />
<field name="image" widget="image" class="oe_avatar" />
<div class="oe_title">
<h1>
<field name="name" placeholder="Name" />
</h1>
</div>
<group>
<group>
<field name="parent_id" string="Category" context="{'default_type':'category'}"/>
<field name="parent_id" string="Category" context="{'default_type':'category'}" />
</group>
<group>
<field name="write_uid" groups="base.group_no_one"/>
<field name="write_date" groups="base.group_no_one"/>
<field name="menu_id" groups="base.group_no_one"/>
<field name="write_uid" groups="base.group_no_one" />
<field name="write_date" groups="base.group_no_one" />
<field name="menu_id" groups="base.group_no_one" />
</group>
</group>
<notebook>
@@ -25,29 +30,147 @@
<field name="template" placeholder="e.g. Once upon a time..." />
</page>
<page string="Documents" name="documents">
<field name="content" widget="html" class="oe_view_only" options='{"safe": True}' />
<field name="content" widget="html" class="oe_view_only" options="{'safe': True}" />
</page>
</notebook>
</sheet>
<div class="oe_chatter">
<field name="message_follower_ids" widget="mail_followers"/>
<field name="activity_ids" widget="mail_activity"/>
<field name="message_ids" widget="mail_thread"/>
<field name="message_follower_ids" widget="mail_followers" />
<field name="activity_ids" widget="mail_activity" />
<field name="message_ids" widget="mail_thread" />
</div>
</form>
</field>
</record>
<record id="view_browse_top_document_filter" model="ir.ui.view">
<field name="name">document.page.category.search</field>
<field name="model">document.page</field>
<field name="inherit_id" ref="view_wiki_filter" />
<field name="arch" type="xml">
<field name="content_uid" position="after">
<separator />
<filter string="Top Level Ressources" name="no_parent_id" domain="[('parent_id', '=', False)]" />
</field>
</field>
</record>
<record id="action_browse_top_content" model="ir.actions.act_window">
<field name="name">Browse Wiki Content</field>
<field name="res_model">document.page</field>
<field name="domain">[]</field>
<field name="context">{'default_type': 'content', 'search_default_no_parent_id':1, }</field>
<field name="view_type">form</field>
<field name="view_mode">kanban,tree,form</field>
<field name="search_view_id" ref="view_browse_top_document_filter" />
</record>
<record id="action_browse_all_content" model="ir.actions.act_window">
<field name="name">Browse Wiki Content</field>
<field name="res_model">document.page</field>
<field name="domain">[]</field>
<field name="context">{'default_type': 'content', 'search_default_parent_id': [active_id] }</field>
<field name="view_type">form</field>
<field name="view_mode">kanban,tree,form</field>
<field name="search_view_id" ref="view_wiki_filter" />
</record>
<record id="view_browse_content_kanban" model="ir.ui.view">
<field name="name">document.page.browse.kanban</field>
<field name="model">document.page</field>
<field name="arch" type="xml">
<kanban>
<field name="id" />
<field name="name" />
<field name="display_name" />
<field name="create_uid" />
<field name="write_date" />
<field name="parent_id" />
<field name="content_uid" />
<field name="image" />
<field name="type" />
<field name="color" />
<templates>
<t t-name="kanban-box">
<div t-att-class="'oe_kanban_global_area' + ' oe_kanban_color_'+ (kanban_getcolor(record.color.raw_value)) + ' oe_kanban_global_click' ">
<div class="o_kanban_image">
<div class="o_kanban_image_wrapper">
<t t-if="record.type.raw_value == 'category'">
<img class="o_kanban_image" t-if="record.image.raw_value" t-att-src="kanban_image('document.page', 'image', record.id.raw_value)" t-att-alt="record.display_name" />
<span style="font-size: 64px; color: lightslategray">
<i t-if="!record.image.raw_value" class="o_kanban_image fa fa-folder-open" />
</span>
</t>
<t t-if="record.type.raw_value == 'content'">
<span style="font-size: 64px; color: lightgray">
<i class="o_kanban_image fa fa-file" />
</span>
</t>
</div>
</div>
<div class="o_kanban_details">
<div class="o_kanban_details_wrapper">
<div class="o_kanban_record_top">
<div class="o_kanban_record_title o_text_overflow">
<strong>
<field name="name" />
</strong>
<br />
<small t-if="record.parent_id.raw_value">
<img t-att-src="kanban_image('document.page', 'image', record.parent_id.raw_value)" t-att-alt="record.parent_id.display_name" width="24" height="24" />
<field name="parent_id" />
</small>
</div>
</div>
<div class="o_dropdown_kanban dropdown" groups="base.group_user">
<a role="button" class="dropdown-toggle o-no-caret btn" data-toggle="dropdown" data-display="static" href="#" aria-label="Dropdown menu" title="Dropdown menu">
<span class="fa fa-ellipsis-v" />
</a>
<div class="dropdown-menu" role="menu">
<ul class="oe_kanban_colorpicker" data-field="color" />
</div>
</div>
<div class="o_kanban_record_body">
<div class="o_kanban_tags_section">
</div>
</div>
<div class="o_kanban_record_bottom" t-if="record.type.raw_value == 'content'">
<div class="oe_kanban_bottom_left">
<field name="write_date" widget="date" />
</div>
<div class="oe_kanban_bottom_right">
<img t-att-src="kanban_image('res.users', 'image_small', record.content_uid.raw_value)" t-att-title="record.content_uid.value" t-att-alt="record.content_uid.value" width="24" height="24" class="oe_kanban_avatar" />
</div>
</div>
</div>
</div>
<div t-if="record.type.raw_value == 'category'" class="o_document_page_kanban_boxes">
<a class="o_document_page_kanban_box" name="%(action_browse_all_content)d" type="action">
</a>
</div>
</div>
</t>
</templates>
</kanban>
</field>
</record>
<record id="view_category_tree" model="ir.ui.view">
<field name="name">document.page.category.tree</field>
<field name="model">document.page</field>
<field name="arch" type="xml">
<tree string="Categories">
<field name="name"/>
<field name="parent_id"/>
<field name="create_uid" invisible="1"/>
<field name="write_uid"/>
<field name="write_date"/>
<field name="sequence" widget="handle" />
<field name="name" />
<field name="parent_id" />
<field name="create_uid" invisible="1" />
<field name="write_uid" />
<field name="write_date" />
</tree>
</field>
</record>
@@ -57,20 +180,21 @@
<field name="model">document.page</field>
<field name="arch" type="xml">
<search string="Document Category">
<field name="name" string="Content"
filter_domain="['|', ('name','ilike',self), ('template','ilike',self)]"/>
<field name="parent_id"/>
<field name="create_uid"/>
<field name="content_uid"/>
<field name="name" string="Content" filter_domain="['|', ('name','ilike',self), ('template','ilike',self)]" />
<field name="parent_id" />
<field name="create_uid" />
<field name="content_uid" />
<group expand="0" string="Group By...">
<filter name="group_by_category" string="Category" context="{'group_by':'parent_id'}"/>
<filter name="group_by_author" string="Author" context="{'group_by':'create_uid'}"/>
<filter name="group_by_last_contributor" string="Last Contributor" context="{'group_by':'content_uid'}"/>
<filter name="group_by_category" string="Category" context="{'group_by':'parent_id'}" />
<filter name="group_by_author" string="Author" context="{'group_by':'create_uid'}" />
<filter name="group_by_last_contributor" string="Last Contributor" context="{'group_by':'content_uid'}" />
</group>
</search>
</field>
</record>
<!-- Category Action -->
<record id="action_category" model="ir.actions.act_window">
<field name="name">Category</field>
@@ -79,29 +203,26 @@
<field name="context">{'default_type': 'category'}</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="view_id" ref="view_category_tree"/>
<field name="search_view_id" ref="view_document_category_filter"/>
<field name="view_id" ref="view_category_tree" />
<field name="search_view_id" ref="view_document_category_filter" />
</record>
<record id="action_category_view_tree" model="ir.actions.act_window.view">
<field name="sequence" eval="0" />
<field name="view_mode">tree</field>
<field name="view_id" ref="view_category_tree"/>
<field name="act_window_id" ref="action_category"/>
<field name="view_id" ref="view_category_tree" />
<field name="act_window_id" ref="action_category" />
</record>
<record id="action_category_view_form" model="ir.actions.act_window.view">
<field name="sequence" eval="5" />
<field name="view_mode">form</field>
<field name="view_id" ref="view_category_form"/>
<field name="act_window_id" ref="action_category"/>
<field name="view_id" ref="view_category_form" />
<field name="act_window_id" ref="action_category" />
</record>
<menuitem id="menu_category"
parent="menu_wiki"
name="Categories"
action="action_category"
sequence="20"/>
<menuitem id="menu_category" parent="menu_wiki" name="Categories" action="action_category" sequence="20" />
<menuitem id="menu_browse_content" parent="knowledge.menu_document_root" name="Browse Wiki Content" action="action_browse_top_content" sequence="5" />
</odoo>