20 Commits

Author SHA1 Message Date
clementthomas
6b8c423a63 [FIX] project_task_portal_form: fix access right error when portal user send support request 2023-04-17 08:54:06 +02:00
clementthomas
758d448ad1 [FIX] project_average_acceptable_time: view priority 2023-04-13 10:42:56 +02:00
clementthomas
2ca161594a [FIX] project_assignees: track assignees
change chatter message behaviour when change assignees
2023-04-13 10:06:13 +02:00
clementthomas
d49387ed2a [IMP] project_assignees: add notification for new assignees 2023-04-12 13:48:33 +02:00
clementthomas
66c35be70d [ADD] project_average_acceptable_time 2023-03-31 16:11:50 +02:00
clementthomas
86711f2884 [FIX] project_assignees: Fix bug when save task 2023-03-31 16:11:50 +02:00
clementthomas
3c78eb58a7 [IMP] project_task_portal_form: Current user as user_id in portal task request 2023-03-31 16:11:50 +02:00
clementthomas
9b4cef63f0 [IMP] project_assignees: chatter auto subscription to assignees 2023-03-31 16:11:50 +02:00
clementthomas
5e7af745c9 [FIX] project_task_portal_form: allow multiple uploads in portal 2023-03-31 16:11:50 +02:00
Stéphan Sainléger
ed987d03b9 [I18N] Add french translations 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
0dd04c8ec6 [IMP] Add file import field in portal task creation form 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
bab8138f11 [ADD] create `project_task_portal_form` add-on 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
75950af5a6 [ADD] create `project_request_data` add-on 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
3b045229d1 [ADD] create `project_user_default_project` add-on 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
5ad7c22034 [IMP] project_assignees: add assignee_ids field to task portal view 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
1952cd17e8 [IMP] project_timebox: add timebox fields in task portal view 2022-10-03 14:56:55 +02:00
Stéphan Sainléger
fd63ab1709 [ADD] project_timebox: create addon to estimate task effort
Adds fields to estimate the min and max time needed to solve a task.

Task: [JOI-13](https://justodooit.fr/mail/view?model=project.task&res_id=13&access_token=cca0b860-25d1-472d-9da1-76f68b01a932)
2022-08-25 17:19:31 +02:00
Stéphan Sainléger
d6fce31db5 [ADD] create `project_timesheet_funding_wish` add-on
Add timesheet line fields:
- ``funding_wish`` to inform about if the user expects a payment
for the registered time.
- ``treated`` to keep track if the timesheet line funding wish has
been taken into account.

Task: JOI-13
Signed-off-by: Valentin Lab <valentin.lab@kalysto.org>
2022-08-25 17:19:31 +02:00
Nicolas JEUDY
677999bf9f [ADD] create project_funders to track funds on tasks
Signed-off-by: Valentin Lab <valentin.lab@kalysto.org>
2022-08-25 17:19:31 +02:00
Valentin Lab
d4f7f9626d [ADD] add `project_assignees` add-on
Add a field in ``project.task`` to assign users to task. This
completes ``user_id`` field, that is then considered as the owner of
the task. Assignment becomes optional and can now target multiple
users.

Task: JOI-13
Signed-off-by: Valentin Lab <valentin.lab@kalysto.org>
2022-08-25 17:19:31 +02:00
81 changed files with 2646 additions and 25 deletions

2
.gitignore vendored Normal file
View File

@@ -0,0 +1,2 @@
*.*~
*.pyc

View File

@@ -3,7 +3,7 @@
{
"name": "project_assignees",
"version": "14.0.0.1.0",
"version": "12.0.1.0.0",
"author": "Elabore",
"website": "https://github.com/elabore-coop/project-tools",
"maintainer": "Stéphan Sainléger",
@@ -78,7 +78,9 @@ This module is maintained by Elabore.
},
# always loaded
"data": [
"data/project_assignees_data.xml",
"views/project_task.xml",
"views/portal_template.xml",
],
# only loaded in demonstration mode
"demo": [],

View File

@@ -0,0 +1,35 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<data noupdate="1">
<record id="mt_task_assignees" model="mail.message.subtype">
<field name="name">Assignees change</field>
<field name="res_model">project.task</field>
<field name="default" eval="False"/>
<field name="description">Assignees changed</field>
</record>
<record id="mt_project_task_assignees" model="mail.message.subtype">
<field name="name">Task Assignees Changed</field>
<field name="sequence">13</field>
<field name="res_model">project.project</field>
<field name="default" eval="False"/>
<field name="parent_id" eval="ref('mt_task_assignees')"/>
<field name="relation_field">project_id</field>
</record>
</data>
<!-- Template email user assigned to a task -->
<data>
<template id="message_user_assigned">
<p style="margin: 0px;">
<span>Dear <t t-esc="partner_name"/>,</span><br />
<span style="margin-top: 8px;">You have been assigned to the <t t-esc="model_description or 'document'"/> <t t-esc="object.name_get()[0][1]"/>.</span>
</p>
<p style="margin-top: 24px; margin-bottom: 16px;">
<a t-att-href="'/mail/view?model=%s&amp;res_id=%s' % (object._name, object.id)" style="background-color:#875A7B; padding: 10px; text-decoration: none; color: #fff; border-radius: 5px;">
View <t t-esc="model_description or 'document'"/>
</a>
</p>
</template>
</data>
</odoo>

View File

@@ -4,11 +4,11 @@
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-07-26 07:38+0000\n"
"PO-Revision-Date: 2022-07-26 07:38+0000\n"
"Last-Translator: \n"
"POT-Creation-Date: 2023-04-12 11:37+0000\n"
"PO-Revision-Date: 2023-04-12 11:37+0000\n"
"Last-Translator: <>\n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
@@ -16,33 +16,68 @@ msgstr ""
"Plural-Forms: \n"
#. module: project_assignees
#: model:ir.model.fields,field_description:project_assignees.field_project_task__assignee_ids
msgid "Assignees"
msgstr "Assignée à"
#: model_terms:ir.ui.view,arch_db:project_assignees.portal_my_task_assignees
msgid "<strong>Other assignees</strong>"
msgstr "<strong>Assigné à</strong>"
#. module: project_assignees
#: model:ir.model.fields,field_description:project_assignees.field_project_task__display_name
msgid "Display Name"
msgstr "Nom affiché"
#: model:mail.message.subtype,name:project_assignees.mt_task_assignees
msgid "Assignees change"
msgstr "Changement d'assignation"
#. module: project_assignees
#: model:ir.model.fields,field_description:project_assignees.field_project_task__id
msgid "ID"
#: model:mail.message.subtype,description:project_assignees.mt_task_assignees
msgid "Assignees changed"
msgstr "Changement d'assignation"
#. module: project_assignees
#: model_terms:ir.ui.view,arch_db:project_assignees.portal_my_task_assignees
msgid "Contact"
msgstr ""
#. module: project_assignees
#: model:ir.model.fields,field_description:project_assignees.field_project_task____last_update
msgid "Last Modified on"
msgstr "Dernière modification le"
#: model_terms:ir.ui.view,arch_db:project_assignees.message_user_assigned
msgid "Dear"
msgstr "Cher"
#. module: project_assignees
#: code:addons/project_assignees/models/project_task.py:0
#: model:ir.model.fields,field_description:project_assignees.field_project_task__user_id
#, python-format
msgid "Owner"
msgstr "Demandée par"
#: model:ir.model,name:project_assignees.model_mail_thread
msgid "Email Thread"
msgstr "Discussion par courriel"
#. module: project_assignees
#: model:ir.model,name:project_assignees.model_mail_tracking_value
msgid "Mail Tracking Value"
msgstr "Valeur de suivi des courriers"
#. module: project_assignees
#: model:ir.model.fields,field_description:project_assignees.field_project_task__assignee_ids
msgid "Other Assignees"
msgstr "Assigné à"
#. module: project_assignees
#: model:ir.model,name:project_assignees.model_project_task
msgid "Task"
msgstr "Tâche"
#. module: project_assignees
#: model:mail.message.subtype,name:project_assignees.mt_project_task_assignees
msgid "Task Assignees Changed"
msgstr "Changement d'assignation pour la tâche"
#. module: project_assignees
#: model_terms:ir.ui.view,arch_db:project_assignees.message_user_assigned
msgid "View"
msgstr "Vue"
#. module: project_assignees
#: code:addons/project_assignees/models/project_task.py:57
#, python-format
msgid "You have been assigned to %s"
msgstr ""
#. module: project_assignees
#: model_terms:ir.ui.view,arch_db:project_assignees.message_user_assigned
msgid "You have been assigned to the"
msgstr "Vous avez été assigné à "

View File

@@ -1,10 +1,106 @@
from odoo import models, fields, _
from odoo import models, fields, _, api
class MailTracking(models.Model):
_inherit = 'mail.tracking.value'
@api.model
def create_tracking_values(self, initial_value, new_value, col_name, col_info, track_sequence):
"""
Track values of assignees changes in chatter
"""
if col_name == 'assignee_ids':
values = {'field': col_name, 'field_desc': col_info['string'], 'field_type': col_info['type'], 'track_sequence': track_sequence}
if initial_value:
values.update({
'old_value_char': ', '.join([i.name for i in initial_value]),
})
else:
values.update({
'old_value_char': '',
})
values.update({
'new_value_char': ', '.join([i.name for i in new_value])
})
return values
return super(MailTracking, self).create_tracking_values(initial_value, new_value, col_name, col_info, track_sequence)
class Task(models.Model):
_inherit = "project.task"
user_id = fields.Many2one(string=_("Owner"))
assignee_ids = fields.Many2many('res.users', 'assignee_ids_rel', string='Assignees')
assignee_ids = fields.Many2many('res.users', 'assignee_ids_rel', string='Other Assignees', track_visibility='change')
@api.multi
def subscribe_and_notify_assignees(self, new_assignee_ids=None):
for task in self:
# Use assignees on parameter if exists
if new_assignee_ids:
assignees = self.env['res.users'].browse(new_assignee_ids)
else:
assignees = task.assignee_ids
# Subscribe partners
partner_ids = [a.partner_id.id for a in assignees]
task.message_subscribe(partner_ids)
# Send notification to assignees
view = self.env['ir.ui.view'].browse(self.env['ir.model.data'].xmlid_to_res_id('project_assignees.message_user_assigned'))
model_description = self.env['ir.model']._get(task._name).display_name
for assignee in assignees:
values = {
'object': task,
'model_description': model_description,
'partner_name':assignee.name_get()[0][1]
}
assignation_msg = view.render(values, engine='ir.qweb', minimal_qcontext=True)
assignation_msg = self.env['mail.thread']._replace_local_links(assignation_msg)
task.message_notify(
subject=_('You have been assigned to %s') % task.display_name,
body=assignation_msg,
partner_ids=[(4, assignee.partner_id.id)],
record_name=task.display_name,
notif_layout='mail.mail_notification_light',
model_description=model_description,
)
@api.multi
def write(self, vals):
# Notify only new assignees
if 'assignee_ids' in vals:
new_assignee_ids = vals['assignee_ids'][0][2].copy()
for a in self.assignee_ids:
if a.id in new_assignee_ids:
new_assignee_ids.remove(a.id)
self.subscribe_and_notify_assignees(new_assignee_ids)
result = super(Task, self).write(vals)
return result
@api.model
def create(self, vals):
task = super(Task, self).create(vals)
task.subscribe_and_notify_assignees()
return task
@api.multi
def _track_subtype(self, init_values):
self.ensure_one()
# keep notification of new task when creating a new task
res = super(Task, self)._track_subtype(init_values)
if res == 'project.mt_task_new':
return res
# if assignees change, notify it
if len(init_values) == 1 and 'assignee_ids' in init_values:
return 'project_assignees.mt_task_assignees'
return super(Task, self)._track_subtype(init_values)

View File

@@ -0,0 +1,25 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<template id="portal_my_task_assignees" name="My Task: Assignees" inherit_id="project.portal_my_task" priority="40">
<xpath expr="//div[hasclass('flex-grow-0')]/../../.." position="inside">
<div class="col-12 col-md-6 pb-2" t-if="task.assignee_ids">
<strong>Other assignees</strong>
<div class="row">
<t t-foreach="task.assignee_ids" t-as="assignee">
<div class="col flex-grow-0 pr-3">
<img t-if="assignee.image" class="rounded-circle mt-1 o_portal_contact_img" t-att-src="image_data_uri(assignee.image)" alt="Contact" />
<img t-else="" class="rounded-circle mt-1 o_portal_contact_img" src="/web/static/src/img/user_menu_avatar.png" alt="Contact" />
</div>
<div class="col pl-md-0">
<strong>
<span t-field="assignee.name" />
</strong>
<span t-field="assignee.email" />
<span t-field="assignee.phone" />
</div>
</t>
</div>
</div>
</xpath>
</template>
</odoo>

View File

@@ -0,0 +1,45 @@
=================
project_assignees
=================
Add multiple assignees field to project task
Installation
============
Use Odoo normal procedure to install add-ons to install
``project_assignees``.
Known issues / Roadmap
======================
Bug Tracker
===========
Bugs are tracked on `our issues website
<https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Images
------
* Elabore: `Icon <https://elabore.coop/web/image/res.company/1/logo?unique=f3db262>`_.
Contributors
------------
* Stéphan Sainléger <https://github.com/stephansainleger>
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.

View File

@@ -0,0 +1,3 @@
# -*- coding: utf-8 -*-
from . import models, controllers

View File

@@ -0,0 +1,93 @@
# Copyright 2022 Stéphan Sainléger (Elabore)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_average_acceptable_time",
"version": "12.0.1.0.0",
"author": "Elabore",
"website": "https://github.com/elabore-coop/project-tools",
"maintainer": "Clément Thomas",
"license": "AGPL-3",
"category": "Tools",
"summary": "Task validation without customer agreement",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
=================
project_average_acceptable_time
=================
Installation
============
Install ``project_average_acceptable_time``, all dependencies will be installed by default.
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website
<https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Images
------
* Elabore: `Icon <https://elabore.coop/web/image/res.company/1/logo?unique=f3db262>`_.
Contributors
------------
* Clément Thomas
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.
""",
# any module necessary for this one to work correctly
"depends": [
"base",
"project",
"project_user_default_project"
],
"qweb": [
# "static/src/xml/*.xml",
],
"external_dependencies": {
"python": [],
},
# always loaded
"data": [
"views/project_project.xml",
"views/portal_home_template.xml"
],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1,2 @@
from . import custom_portal

View File

@@ -0,0 +1,21 @@
# Copyright 2020 Lokavaluto ()
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from odoo.http import request, route
from odoo.addons.portal.controllers.portal import CustomerPortal
class CustomCustomerPortal(CustomerPortal):
@route(["/my/account"], type="http", auth="user", website=True)
def account(self, redirect=None, **post):
self.OPTIONAL_BILLING_FIELDS.append("average_acceptable_time")
response = super(CustomCustomerPortal, self).account(redirect, **post)
if post and request.httprequest.method == "POST":
error, error_message = self.details_form_validate(post)
if not error:
user = request.env.user
if user.default_project_id and post["average_acceptable_time"]:
user.default_project_id.average_acceptable_time = post["average_acceptable_time"]
return response

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

View File

@@ -0,0 +1,46 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_average_acceptable_time
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2023-03-31 09:33+0000\n"
"PO-Revision-Date: 2023-03-31 09:33+0000\n"
"Last-Translator: <>\n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_average_acceptable_time
#: model_terms:ir.ui.view,arch_db:project_average_acceptable_time.portal_my_home_average_acceptable_time
msgid "<b>Average acceptable time</b>:"
msgstr "<b>Temps moyen acceptable</b>:"
#. module: project_average_acceptable_time
#: model_terms:ir.ui.view,arch_db:project_average_acceptable_time.portal_my_home_average_acceptable_time
msgid "Average acceptable time"
msgstr "Temps moyen acceptable"
#. module: project_average_acceptable_time
#: model_terms:ir.ui.view,arch_db:project_average_acceptable_time.project_project_view_kanban_inherit_average_acceptable_time
msgid "<span>Average acceptable time:&amp;nbsp;</span>"
msgstr "<span>Temps moyen acceptable&amp;nbsp;:&amp;nbsp;</span>"
#. module: project_average_acceptable_time
#: model:ir.model.fields,field_description:project_average_acceptable_time.field_project_project__average_acceptable_time
msgid "Average acceptable time"
msgstr "Temps moyen acceptable"
#. module: project_average_acceptable_time
#: model_terms:ir.ui.view,arch_db:project_average_acceptable_time.portal_my_details_average_acceptable_time
msgid "Average acceptable time (h)"
msgstr "Temps moyen acceptable (h)"
#. module: project_average_acceptable_time
#: model:ir.model,name:project_average_acceptable_time.model_project_project
msgid "Project"
msgstr "Projet"

View File

@@ -0,0 +1,2 @@
from . import project_project

View File

@@ -0,0 +1,10 @@
from odoo import models, fields, _, api
class Project(models.Model):
_inherit = "project.project"
average_acceptable_time = fields.Float('Average acceptable time')

View File

@@ -0,0 +1,26 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Template /my/home -->
<template id="portal_my_home_average_acceptable_time" name="Portal My Home: Average acceptable time" inherit_id="portal.portal_layout" priority="40">
<xpath expr="//div[hasclass('o_portal_my_details')]" position="inside">
<hr class="mt-1 mb-0"/>
<b>Average acceptable time</b>: <t t-esc="user_id.default_project_id.average_acceptable_time" t-options="{'widget': 'float_time'}"/>
</xpath>
</template>
<!-- Template /my/account -->
<template id="portal_my_details_average_acceptable_time" name="Portal My details: Average acceptable time" inherit_id="portal.portal_my_details">
<xpath expr="//input[@name='redirect']" position="before">
<div t-attf-class="form-group #{error.get('average_acceptable_time') and 'o_has_error' or ''} col-xl-6">
<label class="col-form-label" for="average_acceptable_time">Average acceptable time (h)</label>
<input
type="text"
name="average_acceptable_time"
t-attf-class="form-control #{error.get('average_acceptable_time') and 'is-invalid' or ''}"
t-att-value="average_acceptable_time or user_id.default_project_id.average_acceptable_time"
t-options="{'widget': 'float_time'}"
/>
</div>
</xpath>
</template>
</odoo>

View File

@@ -0,0 +1,31 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!--Project KANBAN -->
<record id="project_project_view_kanban_inherit_average_acceptable_time" model="ir.ui.view">
<field name="name">project.project.kanban.inherit.average.acceptable.time</field>
<field name="model">project.project</field>
<field name="inherit_id" ref="project.view_project_kanban"/>
<field name="priority">999</field>
<field name="arch" type="xml">
<xpath expr="//div[@class='o_project_kanban_main']" position="inside">
<div class="o_project_kanban_boxes">
<span>Average acceptable time:<![CDATA[&nbsp;]]></span>
<field name="average_acceptable_time" widget="float_time"/>
</div>
</xpath>
</field>
</record>
<!-- Project FORM -->
<record id="project_project_form_inherit_average_acceptable_time" model="ir.ui.view">
<field name="name">project.project.form.inherit.average.acceptable.time</field>
<field name="model">project.project</field>
<field name="inherit_id" ref="project.edit_project"/>
<field name="arch" type="xml">
<field name="subtask_project_id" position="after">
<field name="average_acceptable_time" widget="float_time"/>
</field>
</field>
</record>
</odoo>

View File

@@ -0,0 +1,46 @@
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
===============
project_funders
===============
Add list of funder and corresponding amount to project task.
Installation
============
Use Odoo normal module installation procedure to install
``project_funders``.
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Nicolas Jeudy <https://github.com/njeudy>
* Valentin Lab
Funders
-------
The development of this module has been financially supported by:
* Alusage (https://alusage.fr)
Maintainer
----------
This module is maintained by Alusage and Elabore.

View File

@@ -0,0 +1 @@
from . import models

View File

@@ -0,0 +1,87 @@
# Copyright 2022 Nicolas Jeudy (Alusage)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_funders",
"version": "12.0.0.1.0",
"author": "Alusage",
"website": "https://alusage.fr",
"data": [
# "security/security.xml",
# "security/ir.model.access.csv",
# "views/menu.xml",
# "data/data.xml",
],
"author": "Alusage, Elabore",
"maintainer": "Nicolas Jeudy",
"license": "AGPL-3",
"category": "Tools",
"summary": " Odoo module.",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
===============
project_funders
===============
Add list of funder and corresponding amount to project task.
Installation
============
Use Odoo normal module installation procedure to install
``project_funders``.
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Nicolas Jeudy <https://github.com/njeudy>
* Valentin Lab
Funders
-------
The development of this module has been financially supported by:
* Alusage (https://alusage.fr)
Maintainer
----------
This module is maintained by Alusage and Elabore.
""",
# any module necessary for this one to work correctly
"depends": ["base", "project"],
"qweb": [
# "static/src/xml/*.xml",
],
"external_dependencies": {
"python": [],
},
# always loaded
"data": ["security/ir.model.access.csv", "views/project_task_view.xml"],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

105
project_funders/i18n/fr.po Normal file
View File

@@ -0,0 +1,105 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_funders
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-07-26 06:53+0000\n"
"PO-Revision-Date: 2022-07-26 06:53+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_task__amount_total
msgid "Amount Total"
msgstr "Montant total"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__create_uid
msgid "Created by"
msgstr "Créé par"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__create_date
msgid "Created on"
msgstr "Créé le"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__display_name
#: model:ir.model.fields,field_description:project_funders.field_project_task__display_name
msgid "Display Name"
msgstr "Nom affiché"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__partner_id
msgid "Funder"
msgstr "Financeur"
#. module: project_funders
#: model:ir.model,name:project_funders.model_project_funder
msgid "Funder and amount for tasks"
msgstr "Financeur et montant sur les taches"
#. module: project_funders
#: model_terms:ir.ui.view,arch_db:project_funders.view_task_form2_inherit_project
msgid "Funder(s)"
msgstr "Financeur(s)"
#. module: project_funders
#: model_terms:ir.ui.view,arch_db:project_funders.view_task_kanban_inherit_project_funders
msgid "Funds:"
msgstr "Fonds&nbsp;:"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__id
#: model:ir.model.fields,field_description:project_funders.field_project_task__id
msgid "ID"
msgstr "ID"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder____last_update
#: model:ir.model.fields,field_description:project_funders.field_project_task____last_update
msgid "Last Modified on"
msgstr "Dernière modification le"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__write_uid
msgid "Last Updated by"
msgstr "Derniere modifiation par"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__write_date
msgid "Last Updated on"
msgstr "Dernière mise à jour le"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__name
msgid "Name"
msgstr "Nom"
#. module: project_funders
#: model:ir.model,name:project_funders.model_project_task
#: model:ir.model.fields,field_description:project_funders.field_project_funder__task_id
msgid "Task"
msgstr "Tâche"
#. module: project_funders
#: model_terms:ir.ui.view,arch_db:project_funders.view_task_form2_inherit_project
msgid "Total"
msgstr "Total"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__amount
msgid "Untaxed Amount"
msgstr "Montant HT"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_task__funder_ids
msgid "funder"
msgstr "Financeur"

View File

@@ -0,0 +1,105 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_funders
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-07-26 07:41+0000\n"
"PO-Revision-Date: 2022-07-26 07:41+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_task__amount_total
msgid "Amount Total"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__create_uid
msgid "Created by"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__create_date
msgid "Created on"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__display_name
#: model:ir.model.fields,field_description:project_funders.field_project_task__display_name
msgid "Display Name"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__partner_id
msgid "Funder"
msgstr ""
#. module: project_funders
#: model:ir.model,name:project_funders.model_project_funder
msgid "Funder and amount for tasks"
msgstr ""
#. module: project_funders
#: model_terms:ir.ui.view,arch_db:project_funders.view_task_form2_inherit_project
msgid "Funder(s)"
msgstr ""
#. module: project_funders
#: model_terms:ir.ui.view,arch_db:project_funders.view_task_kanban_inherit_project_funders
msgid "Funds:"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__id
#: model:ir.model.fields,field_description:project_funders.field_project_task__id
msgid "ID"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder____last_update
#: model:ir.model.fields,field_description:project_funders.field_project_task____last_update
msgid "Last Modified on"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__write_uid
msgid "Last Updated by"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__write_date
msgid "Last Updated on"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__name
msgid "Name"
msgstr ""
#. module: project_funders
#: model:ir.model,name:project_funders.model_project_task
#: model:ir.model.fields,field_description:project_funders.field_project_funder__task_id
msgid "Task"
msgstr ""
#. module: project_funders
#: model_terms:ir.ui.view,arch_db:project_funders.view_task_form2_inherit_project
msgid "Total"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_funder__amount
msgid "Untaxed Amount"
msgstr ""
#. module: project_funders
#: model:ir.model.fields,field_description:project_funders.field_project_task__funder_ids
msgid "funder"
msgstr ""

View File

@@ -0,0 +1,2 @@
from . import project_funders
from . import project_task

View File

@@ -0,0 +1,16 @@
from odoo import _, api, fields, models
class ProjectFunders(models.Model):
_name = "project.funder"
_description = "Funder and amount for tasks"
name = fields.Char(compute="_compute_name", string="Name")
partner_id = fields.Many2one("res.partner", string="Funder", required=True)
amount = fields.Float("Untaxed Amount", required=True)
task_id = fields.Many2one("project.task", string="Task")
@api.depends("partner_id", "amount")
def _compute_name(self):
for record in self:
record.name = "%s (%s)" % (record.partner_id.name, record.amount)

View File

@@ -0,0 +1,13 @@
from odoo import _, api, fields, models
class ProjectTask(models.Model):
_inherit = "project.task"
funder_ids = fields.One2many("project.funder", "task_id", string="funder")
amount_total = fields.Float(compute="_compute_amount_total", string="Amount Total")
@api.depends("funder_ids")
def _compute_amount_total(self):
for record in self:
record.amount_total = sum(record.funder_ids.mapped("amount"))

View File

@@ -0,0 +1,2 @@
id,name,model_id/id,group_id/id,perm_read,perm_write,perm_create,perm_unlink
access_project_funder_all,project.funder.all,model_project_funder,,1,1,1,1
1 id name model_id/id group_id/id perm_read perm_write perm_create perm_unlink
2 access_project_funder_all project.funder.all model_project_funder 1 1 1 1

View File

@@ -0,0 +1,47 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<record id="view_task_form2_inherit_project" model="ir.ui.view">
<field name="name">project.task.view.form.inherit</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="project.view_task_form2"/>
<field name="arch" type="xml">
<xpath expr="//notebook" position="inside">
<page name="funders" string="Funder(s)">
<field name="funder_ids" context="{'default_task_id': active_id}">
<tree editable="bottom">
<field name="task_id" invisible="1"/>
<field name="partner_id"/>
<field name="amount"/>
</tree>
</field>
<group>
<group class="oe_subtotal_footer oe_right" name="project_hours">
<span>
<label class="font-weight-bold" for="amount_total" string="Total"/>
</span>
<field name="amount_total" nolabel="1"/>
</group>
</group>
</page>
</xpath>
</field>
</record>
<record id="view_task_kanban_inherit_project_funders" model="ir.ui.view">
<field name="name">project.task.view.kanban.inherit</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="project.view_task_kanban"/>
<field name="arch" type="xml">
<field name="active" position="after">
<field name="amount_total"/>
</field>
<field name="tag_ids" position="after">
<span attrs="{'invisible': [('amount_total', '=', 0)]}">
Funds: <field name="amount_total"/>
</span>
</field>
</field>
</record>
</odoo>

View File

@@ -0,0 +1,45 @@
====================
project_request_data
====================
Add several fields in tasks, that provide several data on the request
Installation
============
Use Odoo normal module installation procedure to install ``project_request_data``.
- To configure the services, go to Project > Configuration > Task Services
- To configure the request types, go to Project > Configuration > Request Types
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger (https://github.com/stephansainleger)
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.

View File

@@ -0,0 +1 @@
from . import models

View File

@@ -0,0 +1,92 @@
# Copyright 2022 Stéphan Sainléger (Elabore)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_request_data",
"version": "12.0.1.0.0",
"author": "Elabore",
"website": "https://elabore.coop",
"maintainer": "Stéphan Sainléger",
"license": "AGPL-3",
"category": "Project",
"summary": "Add several fields in tasks, that provide several data on the request",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
====================
project_request_data
====================
Add several fields in tasks, that provide several data on the request
Installation
============
Use Odoo normal module installation procedure to install ``project_request_data``.
- To configure the services, go to Project > Configuration > Task Services
- To configure the request types, go to Project > Configuration > Request Types
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger (https://github.com/stephansainleger)
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.
""",
# any module necessary for this one to work correctly
"depends": [
"base",
"project",
],
"qweb": [
# "static/src/xml/*.xml",
],
"external_dependencies": {
"python": [],
},
# always loaded
"data": [
"security/ir.model.access.csv",
"views/project_task.xml",
"views/request_type.xml",
"views/task_service.xml",
"views/portal_template.xml",
],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

View File

@@ -0,0 +1,116 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_request_data
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-08-26 12:51+0000\n"
"PO-Revision-Date: 2022-08-26 12:51+0000\n"
"Last-Translator: <>\n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_request_data
#: model_terms:ir.ui.view,arch_db:project_request_data.portal_my_task_request_data
msgid "<strong>Request type:</strong>"
msgstr "<strong>Type de demande :</strong>"
#. module: project_request_data
#: model_terms:ir.ui.view,arch_db:project_request_data.portal_my_task_request_data
msgid "<strong>Service:</strong>"
msgstr "<strong>Service :</strong>"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__create_uid
#: model:ir.model.fields,field_description:project_request_data.field_task_service__create_uid
msgid "Created by"
msgstr "Créé par"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__create_date
#: model:ir.model.fields,field_description:project_request_data.field_task_service__create_date
msgid "Created on"
msgstr "Créé le"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__display_name
#: model:ir.model.fields,field_description:project_request_data.field_task_service__display_name
msgid "Display Name"
msgstr "Nom affiché"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__id
#: model:ir.model.fields,field_description:project_request_data.field_task_service__id
msgid "ID"
msgstr ""
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type____last_update
#: model:ir.model.fields,field_description:project_request_data.field_task_service____last_update
msgid "Last Modified on"
msgstr "Dernière modification le"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__write_uid
#: model:ir.model.fields,field_description:project_request_data.field_task_service__write_uid
msgid "Last Updated by"
msgstr "Dernière mise à jour par"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__write_date
#: model:ir.model.fields,field_description:project_request_data.field_task_service__write_date
msgid "Last Updated on"
msgstr "Dernière mise à jour le"
#. module: project_request_data
#: model:ir.model,name:project_request_data.model_request_type
#: model:ir.model.fields,field_description:project_request_data.field_project_task__request_type_id
msgid "Request Type"
msgstr "Type de demande"
#. module: project_request_data
#: model:ir.actions.act_window,name:project_request_data.act_request_types_list
#: model:ir.ui.menu,name:project_request_data.menu_request_types
#: model_terms:ir.ui.view,arch_db:project_request_data.request_type_view_tree
msgid "Request Types"
msgstr "Types de demande"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__sequence
#: model:ir.model.fields,field_description:project_request_data.field_task_service__sequence
msgid "Sequence"
msgstr "Séquence"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_project_task__service_id
msgid "Service"
msgstr "Service"
#. module: project_request_data
#: model:ir.model,name:project_request_data.model_project_task
msgid "Task"
msgstr "Tâche"
#. module: project_request_data
#: model:ir.actions.act_window,name:project_request_data.act_task_services_list
#: model:ir.ui.menu,name:project_request_data.menu_task_services
#: model_terms:ir.ui.view,arch_db:project_request_data.task_service_view_tree
msgid "Task Services"
msgstr "Services"
#. module: project_request_data
#: model:ir.model,name:project_request_data.model_task_service
msgid "Task service"
msgstr "Service"
#. module: project_request_data
#: model:ir.model.fields,field_description:project_request_data.field_request_type__name
#: model:ir.model.fields,field_description:project_request_data.field_task_service__name
msgid "name"
msgstr "nom"

View File

@@ -0,0 +1,3 @@
from . import task_service
from . import request_type
from . import project_task

View File

@@ -0,0 +1,9 @@
from odoo import models, fields
class Task(models.Model):
_inherit = "project.task"
service_id = fields.Many2one('task.service', string='Service')
request_type_id = fields.Many2one('request.type', string='Request Type')

View File

@@ -0,0 +1,9 @@
from odoo import models, fields
class RequestType(models.Model):
_name = "request.type"
_description = "Request Type"
name = fields.Char('name', required=True)
sequence = fields.Integer()

View File

@@ -0,0 +1,9 @@
from odoo import models, fields
class TaskService(models.Model):
_name = "task.service"
_description = "Task service"
name = fields.Char('name', required=True)
sequence = fields.Integer()

View File

@@ -0,0 +1,5 @@
id,name,model_id/id,group_id/id,perm_read,perm_write,perm_create,perm_unlink
access_task_service_user,project.task_service.user,model_task_service,,1,0,0,0
access_task_service_manager,project.task_service.manager,model_task_service,project.group_project_manager,1,1,1,1
access_request_type_user,project.request_type.user,model_request_type,,1,0,0,0
access_request_type_manager,project.request_type.manager,model_request_type,project.group_project_manager,1,1,1,1
1 id name model_id/id group_id/id perm_read perm_write perm_create perm_unlink
2 access_task_service_user project.task_service.user model_task_service 1 0 0 0
3 access_task_service_manager project.task_service.manager model_task_service project.group_project_manager 1 1 1 1
4 access_request_type_user project.request_type.user model_request_type 1 0 0 0
5 access_request_type_manager project.request_type.manager model_request_type project.group_project_manager 1 1 1 1

View File

@@ -0,0 +1,17 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<template id="portal_my_task_request_data" name="My Task: Request Data" inherit_id="project.portal_my_task" priority="40">
<xpath expr="//t[@t-set='card_body']/div[hasclass('row','mb-4')]" position="after">
<div id="request_data" class="row mb-4">
<div class="col-12 col-md-6" t-if="task.service_id">
<strong>Service:</strong>
<span t-field="task.service_id" />
</div>
<div class="col-12 col-md-6" t-if="task.request_type_id">
<strong>Request type:</strong>
<span t-field="task.request_type_id" />
</div>
</div>
</xpath>
</template>
</odoo>

View File

@@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<record id="view_task_form2_request_data" model="ir.ui.view">
<field name="name">project.task.form.request.data</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="project.view_task_form2" />
<field name="priority" eval="99" />
<field name="arch" type="xml">
<xpath expr="//field[@name='tag_ids']" position="before">
<field name="service_id" widget="selection" />
<field name="request_type_id" widget="selection" />
</xpath>
</field>
</record>
</odoo>

View File

@@ -0,0 +1,23 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="request_type_view_tree" model="ir.ui.view">
<field name="name">request.type.view.tree</field>
<field name="model">request.type</field>
<field name="arch" type="xml">
<tree string="Request Types" editable="top" default_order="sequence">
<field name="sequence" widget="handle" />
<field name="name" />
</tree>
</field>
</record>
<record id="act_request_types_list" model="ir.actions.act_window">
<field name="name">Request Types</field>
<field name="res_model">request.type</field>
<field name="view_mode">tree</field>
</record>
<menuitem id="menu_request_types" action="act_request_types_list" parent="project.menu_project_config" sequence="99" name="Request Types" />
</odoo>

View File

@@ -0,0 +1,23 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="task_service_view_tree" model="ir.ui.view">
<field name="name">task.service.view.tree</field>
<field name="model">task.service</field>
<field name="arch" type="xml">
<tree string="Task Services" editable="top" default_order="sequence">
<field name="sequence" widget="handle" />
<field name="name" />
</tree>
</field>
</record>
<record id="act_task_services_list" model="ir.actions.act_window">
<field name="name">Task Services</field>
<field name="res_model">task.service</field>
<field name="view_mode">tree</field>
</record>
<menuitem id="menu_task_services" action="act_task_services_list" parent="project.menu_project_config" sequence="99" name="Task Services" />
</odoo>

2
project_task_portal_form/.gitignore vendored Normal file
View File

@@ -0,0 +1,2 @@
*.*~
*pyc

View File

@@ -0,0 +1,7 @@
=====================
project_task_portal_form
=====================
Add a portal form to create project tasks
This is an Odoo addon.

View File

@@ -0,0 +1,3 @@
# -*- coding: utf-8 -*-
from . import controllers

View File

@@ -0,0 +1,86 @@
# Copyright 2022 Stéphan Sainléger (Elabore)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_task_portal_form",
"version": "12.0.1.1.0",
"author": "Elabore",
"website": "https://elabore.coop",
"maintainer": "Stéphan Sainléger",
"license": "AGPL-3",
"category": "Tools",
"summary": "Add a portal form to create project tasks",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
========================
project_task_portal_form
========================
Add a portal form to create project tasks
Installation
============
Use Odoo normal module installation procedure to install
``project_task_portal_form``.
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.
""",
# any module necessary for this one to work correctly
"depends": [
"base",
"project",
"project_request_data",
"project_user_default_project",
],
"qweb": [],
"external_dependencies": {
"python": [],
},
# always loaded
"data": [
"views/portal_task_creation_form.xml",
],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1,3 @@
# -*- coding: utf-8 -*-
from . import portal_task_creation

View File

@@ -0,0 +1,118 @@
# Copyright 2020 Lokavaluto ()
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
import base64
from odoo import http
from odoo.http import request
from odoo.addons.portal.controllers.portal import CustomerPortal
class PortalTaskCreation(CustomerPortal):
_TASK_CREATION_FIELDS = [
"name",
"service_id",
"request_type_id",
"small_description",
"access",
"bug_report",
"priority",
]
# Variable to update to add other fields in child classes
_EXTRA_FIELDS = []
def _taskform_get_page_view_values(self, partner, access_token, **kwargs):
values = {
"page_name": "portal_task_form",
"partner": partner,
}
return self._get_page_view_values(
partner,
access_token,
values,
"my_task_creation_history",
False,
**kwargs
)
def _get_task_priorities(self):
priorities = []
for id, name in request.env['project.task']._fields['priority'].selection:
value = {
"id": id,
"name": name
}
priorities.append(value)
return priorities
@http.route(
["/task/form"],
type="http",
auth="user",
website=True,
)
def portal_task_creation(self, access_token=None, redirect=None, **kw):
values = self._task_get_page_view_values(request.env.user.partner_id, access_token, **kw)
request_types = request.env["request.type"].sudo().search([])
task_services = request.env["task.service"].sudo().search([])
priorities = self._get_task_priorities()
error = dict()
error_message = []
values.update(
{
"request_types": request_types,
"task_services": task_services,
"priorities": priorities,
"error": error,
"error_message": error_message,
}
)
return request.render("project_task_portal_form.portal_task_creation_form", values)
def _compute_form_data(self, data):
values = {}
for field in self._TASK_CREATION_FIELDS:
if data.get(field):
values[field] = data.pop(field)
for field in self._EXTRA_FIELDS:
if data.get(field):
values[field] = data.pop(field)
description = ""
if values.get("small_description", False):
description = description + "<b>DESCRIPTION:</b><br/>" + values["small_description"]
if values.get("access", False):
description = description + "<br/><br/><b>ACCESS:</b><br/>" + values["access"]
if values.get("bug_report", False):
description = description + "<br/><br/><b>BUG REPORT:</b><br/>" + values["bug_report"]
values["description"] = description
values["attachments"] = request.httprequest.files.getlist("attachment")
return values
@http.route(
["/task/create"],
type="http",
auth="public",
methods=['POST'],
website=True,
)
def create_task(self, **kwargs):
# Get form values
user = request.env.user
values = self._compute_form_data(kwargs)
values["project_id"] = user.default_project_id.id
values["partner_id"] = user.partner_id.id
values["user_id"] = user.id
# Create task
task_id = request.env["project.task"].sudo().create(values) #use sudo to avoid access error on resource calendar when user_id is set
# Add attachments
for file in values.get("attachments", False):
attachment_value = {
'name': file.filename,
'datas': base64.encodestring(file.read()),
'datas_fname': file.filename,
'res_model': "project.task",
'res_id': task_id,
}
request.env['ir.attachment'].sudo().create(attachment_value)
return request.render("project_task_portal_form.portal_task_created", {})

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

View File

@@ -0,0 +1,124 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_task_portal_form
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-09-22 09:34+0000\n"
"PO-Revision-Date: 2022-09-22 09:34+0000\n"
"Last-Translator: <>\n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "<br/>\n"
" Task created"
msgstr "<br/>\n"
" Tâche créée"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "<span>Be precise. If there is a bug/error, please describe how to reproduce it</span>"
msgstr "<span>Soyez précis. Si vous avez une erreur, veuillez décrire le scénario pour la reproduire</span>"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "<span>Link toward error or additional information</span>"
msgstr "<span>Lien vers l'erreur ou des informations supplémentaires</span>"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "<span>Paste here the complete error message (ex: error code Odoo)</span>"
msgstr "<span>COpier ici le message d'erreur complet (ex: error code Odoo)</span>"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Access"
msgstr "Accès"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "Back to my Home\n"
" <span class=\"fa fa-long-arrow-right\"/>"
msgstr "Retour sur mon espace\n"
" <span class=\"fa fa-long-arrow-right\"/>"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Bug report"
msgstr "Rapport de bug"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Choose a priority..."
msgstr "Choisir la priorité..."
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Choose a service..."
msgstr "Choisir le logiciel"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Choose a type..."
msgstr "Choisir un type de demande"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Description"
msgstr "Description"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Priority"
msgstr "Priorité"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Request type"
msgstr "Type de demande"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Service"
msgstr "Logiciel"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Submit\n"
" <span class=\"fa fa-long-arrow-right\"/>"
msgstr "Soumettre\n"
" <span class=\"fa fa-long-arrow-right\"/>"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "Task created"
msgstr "Tâche créée"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Task creation form"
msgstr "Formulaire de création de tâche"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "Thanks for request!\n"
" <br/>\n"
" A new task has been saved and you can keep track on your request handling from your portal account!\n"
" <br/>"
msgstr "Merci pour votre demande !\n"
" <br/>\n"
" Une nouvelle tâche a été créée et vous pouvez suivre votre demande depuis votre compte portail !\n"
" <br/>"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Title"
msgstr "Titre"

View File

@@ -0,0 +1,118 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_task_portal_form
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-09-22 09:35+0000\n"
"PO-Revision-Date: 2022-09-22 09:35+0000\n"
"Last-Translator: <>\n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "<br/>\n"
" Task created"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "<span>Be precise. If there is a bug/error, please describe how to reproduce it</span>"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "<span>Link toward error or additional information</span>"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "<span>Paste here the complete error message (ex: error code Odoo)</span>"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Access"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "Back to my Home\n"
" <span class=\"fa fa-long-arrow-right\"/>"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Bug report"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Choose a priority..."
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Choose a service..."
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Choose a type..."
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Description"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Priority"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Request type"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Service"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Submit\n"
" <span class=\"fa fa-long-arrow-right\"/>"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "Task created"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Task creation form"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_created
msgid "Thanks for request!\n"
" <br/>\n"
" A new task has been saved and you can keep track on your request handling from your portal account!\n"
" <br/>"
msgstr ""
#. module: project_task_portal_form
#: model_terms:ir.ui.view,arch_db:project_task_portal_form.portal_task_creation_form
msgid "Title"
msgstr ""

View File

@@ -0,0 +1,141 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<template id="portal_task_creation_form" name="Portal: Task creation form">
<t t-call="portal.portal_layout">
<!-- <div id="wrap" class="col-lg-6 container"></div> -->
<t t-set="additional_title">Task creation form</t>
<form
action="/task/create"
method="post"
accept-charset="UTF-8"
class="s_website_form col-md-12 mt32"
data-model_name="project.task"
data-force_action=""
data-success_page=""
enctype="multipart/form-data">
<div class="oe_structure" id="oe_structure_portal_task_creation_form_1" />
<input type="hidden" name="csrf_token" t-att-value="request.csrf_token()" />
<div class="row">
<div t-attf-class="form-group #{error.get('name') and 'o_has_error' or ''} col-xl-12">
<label class="col-form-label" for="name">Title</label>
<label class="text-danger"> *</label>
<input type="text" name="name" t-attf-class="form-control #{error.get('name') and 'is-invalid' or ''}" t-att-value="name" required="True" />
</div>
</div>
<div class="row">
<div t-attf-class="form-group #{error.get('request_type_id') and 'o_has_error' or ''} col-xl-6">
<label class="col-form-label" for="request_type_id">Request type</label>
<label class="text-danger"> *</label>
<select name="request_type_id" t-attf-class="form-control" required="True">
<option value="">Choose a type...</option>
<t t-foreach="request_types or []" t-as="request_type">
<option t-att-value="request_type.id">
<t t-esc="request_type.name" />
</option>
</t>
</select>
</div>
<div t-attf-class="form-group #{error.get('service_id') and 'o_has_error' or ''} col-xl-6">
<label class="col-form-label" for="service_id">Service</label>
<label class="text-danger"> *</label>
<select name="service_id" t-attf-class="form-control" required="True">
<option value="">Choose a service...</option>
<t t-foreach="task_services or []" t-as="task_service">
<option t-att-value="task_service.id">
<t t-esc="task_service.name" />
</option>
</t>
</select>
</div>
</div>
<div class="row">
<div t-attf-class="form-group #{error.get('small_description') and 'o_has_error' or ''} col-xl-12">
<label class="col-form-label" for="small_description">Description</label>
<label class="text-danger"> *</label>
<textarea rows="4" name="small_description" t-attf-class="form-control #{error.get('small_description') and 'is-invalid' or ''}" t-att-value="small_description" required="True" />
<span>Be precise. If there is a bug/error, please describe how to reproduce it</span>
</div>
</div>
<div class="row">
<div t-attf-class="form-group #{error.get('access') and 'o_has_error' or ''} col-xl-12">
<label class="col-form-label" for="access">Access</label>
<input type="text" name="access" t-attf-class="form-control #{error.get('access') and 'is-invalid' or ''}" t-att-value="access" />
<span>Link toward error or additional information</span>
</div>
</div>
<div class="row">
<div t-attf-class="form-group #{error.get('bug_report') and 'o_has_error' or ''} col-xl-12">
<label class="col-form-label" for="bug_report">Bug report</label>
<textarea rows="4" name="bug_report" t-attf-class="form-control #{error.get('bug_report') and 'is-invalid' or ''}" t-att-value="bug_report" />
<span>Paste here the complete error message (ex: error code Odoo)</span>
</div>
</div>
<!-- ## IMPORT FILE -->
<div class="form-group form-field form-field-binary" data-model-field="false" data-optional="true">
<label class="col-form-label" for="attachment">
<span>Join document</span>
</label>
<i>
<input type="file" name="attachment" multiple="true" data-show-upload="true" data-show-caption="true" data-show-preview="true" />
</i>
<p class="form-text text-muted">
<i>Join a screenshot to your request or any other helpfull document.</i>
<br />
</p>
</div>
<div class="row">
<div t-attf-class="form-group #{error.get('priority') and 'o_has_error' or ''} col-xl-6">
<label class="col-form-label" for="priority">Priority</label>
<label class="text-danger"> *</label>
<select name="priority" t-attf-class="form-control" required="True">
<option value="">Choose a priority...</option>
<t t-foreach="priorities or []" t-as="priority">
<option t-att-value="priority['id']">
<t t-esc="priority['name']" />
</option>
</t>
</select>
</div>
</div>
<div class="clearfix">
<br />
<button type="submit" class="btn btn-primary float-right mb32 ">
Submit
<span class="fa fa-long-arrow-right" />
</button>
</div>
<div class="oe_structure" id="oe_structure_portal_task_creation_form_2" />
</form>
</t>
</template>
<template id="portal_task_created" name="Portal: Task created">
<t t-call="portal.portal_layout">
<t t-set="additional_title">Task created</t>
<form action="/my/tasks" method="post">
<input type="hidden" name="csrf_token" t-att-value="request.csrf_token()" />
<h3>
<br />
Task created
</h3>
<div>
<p>
Thanks for request!
<br />
A new task has been saved and you can keep track on your request handling from your portal account!
<br />
</p>
</div>
<div class="clearfix">
<br />
<button type="submit" class="btn btn-primary float-right mb32 ">
Back to my Tasks
<span class="fa fa-long-arrow-right" />
</button>
</div>
</form>
</t>
</template>
</odoo>

View File

@@ -0,0 +1,47 @@
===============
project_timebox
===============
Add timebox field in tasks to estimate resolution effort.
Installation
============
Use Odoo normal module installation procedure to install ``project_timebox``.
To configure the timeboxes, go to Project > Configuration > Timeboxes
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger (https://github.com/stephansainleger)
* Nicolas Jeudy (https://github.com/njeudy)
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
* Mycéliandre (https://myceliandre.fr)
* Lokavaluto (https://lokavaluto.fr)
Maintainer
----------
This module is maintained by Elabore.

View File

@@ -0,0 +1 @@
from . import models

View File

@@ -0,0 +1,93 @@
# Copyright 2022 Stéphan Sainléger (Elabore)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_timebox",
"version": "12.0.1.0.0",
"author": "Elabore",
"website": "https://elabore.coop",
"maintainer": "Stéphan Sainléger",
"license": "AGPL-3",
"category": "Project",
"summary": "Add timebox field in tasks to estimate resolution effort.",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
===============
project_timebox
===============
Add timebox field in tasks to estimate resolution effort.
Installation
============
Use Odoo normal module installation procedure to install ``project_timebox``.
To configure the timeboxes, go to Project > Configuration > Timeboxes
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger (https://github.com/stephansainleger)
* Nicolas Jeudy (https://github.com/njeudy)
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
* Mycéliandre (https://myceliandre.fr)
* Lokavaluto (https://lokavaluto.fr)
Maintainer
----------
This module is maintained by Elabore.
""",
# any module necessary for this one to work correctly
"depends": [
"base",
"project",
],
"qweb": [
# "static/src/xml/*.xml",
],
"external_dependencies": {
"python": [],
},
# always loaded
"data": [
"security/ir.model.access.csv",
"views/project_task.xml",
"views/timebox.xml",
"views/portal_template.xml",
],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

101
project_timebox/i18n/fr.po Normal file
View File

@@ -0,0 +1,101 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_timebox
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-08-01 09:34+0000\n"
"PO-Revision-Date: 2022-08-01 09:34+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_timebox
#: model_terms:ir.ui.view,arch_db:project_timebox.portal_my_task_timebox
msgid "<strong>Timebox Max:</strong>"
msgstr "<strong>Temps estimé maxi :</strong>"
#. module: project_timebox
#: model_terms:ir.ui.view,arch_db:project_timebox.portal_my_task_timebox
msgid "<strong>Timebox Min:</strong>"
msgstr "<strong>Temps estimé mini :</strong>"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_timebox__create_uid
msgid "Created by"
msgstr "Créé par"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_timebox__create_date
msgid "Created on"
msgstr "Créé le"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_project_task__display_name
#: model:ir.model.fields,field_description:project_timebox.field_timebox__display_name
msgid "Display Name"
msgstr "Nom affiché"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_project_task__id
#: model:ir.model.fields,field_description:project_timebox.field_timebox__id
msgid "ID"
msgstr ""
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_project_task____last_update
#: model:ir.model.fields,field_description:project_timebox.field_timebox____last_update
msgid "Last Modified on"
msgstr "Dernière modification le"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_timebox__write_uid
msgid "Last Updated by"
msgstr "Dernière mise à jour par"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_timebox__write_date
msgid "Last Updated on"
msgstr "Dernière mise à jour le"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_timebox__sequence
msgid "Sequence"
msgstr "Séquence"
#. module: project_timebox
#: model:ir.model,name:project_timebox.model_project_task
msgid "Task"
msgstr "Tâche"
#. module: project_timebox
#: model:ir.model,name:project_timebox.model_timebox
msgid "Timebox"
msgstr "Estimation"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_project_task__timebox_max_id
msgid "Timebox Max"
msgstr "Estimation haute"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_project_task__timebox_min_id
msgid "Timebox Min"
msgstr "Estimation basse"
#. module: project_timebox
#: model:ir.actions.act_window,name:project_timebox.act_timeboxes_list
#: model:ir.ui.menu,name:project_timebox.menu_timeboxes
#: model_terms:ir.ui.view,arch_db:project_timebox.timebox_view_tree
msgid "Timeboxes"
msgstr "Estimations"
#. module: project_timebox
#: model:ir.model.fields,field_description:project_timebox.field_timebox__name
msgid "name"
msgstr "nom"

View File

@@ -0,0 +1,2 @@
from . import timebox
from . import project_task

View File

@@ -0,0 +1,9 @@
from odoo import models, fields
class Task(models.Model):
_inherit = "project.task"
timebox_min_id = fields.Many2one('timebox', string='Timebox Min')
timebox_max_id = fields.Many2one('timebox', string='Timebox Max')

View File

@@ -0,0 +1,9 @@
from odoo import models, fields
class Task(models.Model):
_name = "timebox"
_description = "Timebox"
name = fields.Char('name', required=True)
sequence = fields.Integer()

View File

@@ -0,0 +1,3 @@
id,name,model_id/id,group_id/id,perm_read,perm_write,perm_create,perm_unlink
access_timebox_user,project.timebox.user,model_timebox,,1,0,0,0
access_timebox_manager,project.timebox.manager,model_timebox,project.group_project_manager,1,1,1,1
1 id name model_id/id group_id/id perm_read perm_write perm_create perm_unlink
2 access_timebox_user project.timebox.user model_timebox 1 0 0 0
3 access_timebox_manager project.timebox.manager model_timebox project.group_project_manager 1 1 1 1

View File

@@ -0,0 +1,17 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<template id="portal_my_task_timebox" name="My Task: Timebox" inherit_id="project.portal_my_task" priority="40">
<xpath expr="//t[@t-set='card_body']/div[hasclass('row','mb-4')]" position="after">
<div id="timebox" class="row mb-2">
<div class="col-12 col-md-6" t-if="task.timebox_min_id">
<strong>Timebox Min:</strong>
<span t-field="task.timebox_min_id" />
</div>
<div class="col-12 col-md-6" t-if="task.timebox_max_id">
<strong>Timebox Max:</strong>
<span t-field="task.timebox_max_id" />
</div>
</div>
</xpath>
</template>
</odoo>

View File

@@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<record id="view_task_form2_timebox" model="ir.ui.view">
<field name="name">project.task.form.timebox</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="project.view_task_form2" />
<field name="priority" eval="99" />
<field name="arch" type="xml">
<xpath expr="//field[@name='date_deadline']" position="after">
<field name="timebox_min_id" widget="selection" />
<field name="timebox_max_id" widget="selection" />
</xpath>
</field>
</record>
</odoo>

View File

@@ -0,0 +1,23 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="timebox_view_tree" model="ir.ui.view">
<field name="name">timebox.view.tree</field>
<field name="model">timebox</field>
<field name="arch" type="xml">
<tree string="Timeboxes" editable="top" default_order="sequence">
<field name="sequence" widget="handle" />
<field name="name" />
</tree>
</field>
</record>
<record id="act_timeboxes_list" model="ir.actions.act_window">
<field name="name">Timeboxes</field>
<field name="res_model">timebox</field>
<field name="view_mode">tree</field>
</record>
<menuitem id="menu_timeboxes" action="act_timeboxes_list" parent="project.menu_project_config" sequence="99" name="Timeboxes" />
</odoo>

View File

@@ -0,0 +1,47 @@
==============================
project_timesheet_funding_wish
==============================
Add a funding wish select field to timesheet line.
Installation
============
Use Odoo normal procedure to install add-ons to install
``project_timesheet_funding_wish``.
Known issues / Roadmap
======================
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In
case of trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Images
------
* Elabore: `Icon <https://elabore.coop/web/image/res.company/1/logo?unique=f3db262>`_.
Contributors
------------
* Stéphan Sainléger <https://github.com/stephansainleger>
* Valentin Lab <valentin.lab@kalysto.org>
* Nicolas Jeudy <https://github.com/njeudy>
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.

View File

@@ -0,0 +1 @@
from . import models

View File

@@ -0,0 +1,88 @@
# Copyright 2022 Stéphan Sainléger (Elabore)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_timesheet_funding_wish",
"version": "12.0.1.0.0",
"author": "Elabore",
"website": "https://github.com/elabore-coop/project-tools",
"maintainer": "Stéphan Sainléger",
"license": "AGPL-3",
"category": "Tools",
"summary": "Add a funding wish select field to timesheet line.",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
==============================
project_timesheet_funding_wish
==============================
Add a funding wish select field to timesheet line.
Installation
============
Use Odoo normal procedure to install add-ons to install
``project_timesheet_funding_wish``.
Known issues / Roadmap
======================
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In
case of trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Images
------
* Elabore: `Icon <https://elabore.coop/web/image/res.company/1/logo?unique=f3db262>`_.
Contributors
------------
* Stéphan Sainléger <https://github.com/stephansainleger>
* Valentin Lab <valentin.lab@kalysto.org>
* Nicolas Jeudy <https://github.com/njeudy>
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.
""",
# any module necessary for this one to work correctly
"depends": [
"base",
"hr_timesheet",
],
"qweb": [
# "static/src/xml/*.xml",
],
"external_dependencies": {
"python": [],
},
# always loaded
"data": [
"views/hr_timesheet.xml",
],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

View File

@@ -0,0 +1,65 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_timesheet_funding_wish
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-07-25 17:02+0000\n"
"PO-Revision-Date: 2022-07-25 17:02+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_timesheet_funding_wish
#: model:ir.model,name:project_timesheet_funding_wish.model_account_analytic_line
msgid "Analytic Line"
msgstr "Ligne analytique"
#. module: project_timesheet_funding_wish
#: model:ir.model.fields,field_description:project_timesheet_funding_wish.field_account_analytic_line__display_name
msgid "Display Name"
msgstr "Nom affiché"
#. module: project_timesheet_funding_wish
#: model:ir.model.fields.selection,name:project_timesheet_funding_wish.selection__account_analytic_line__funding_wish__free
msgid "Free"
msgstr "Offert"
#. module: project_timesheet_funding_wish
#: code:addons/project_timesheet_funding_wish/models/hr_timesheet.py:0
#: model:ir.model.fields,field_description:project_timesheet_funding_wish.field_account_analytic_line__funding_wish
#, python-format
msgid "Funding wish"
msgstr "Type de financement"
#. module: project_timesheet_funding_wish
#: model:ir.model.fields,field_description:project_timesheet_funding_wish.field_account_analytic_line__id
msgid "ID"
msgstr ""
#. module: project_timesheet_funding_wish
#: model:ir.model.fields,field_description:project_timesheet_funding_wish.field_account_analytic_line____last_update
msgid "Last Modified on"
msgstr "Dernière modification le"
#. module: project_timesheet_funding_wish
#: model:ir.model.fields.selection,name:project_timesheet_funding_wish.selection__account_analytic_line__funding_wish__accepted
msgid "Payment accepted"
msgstr "Paiement accepté"
#. module: project_timesheet_funding_wish
#: model:ir.model.fields.selection,name:project_timesheet_funding_wish.selection__account_analytic_line__funding_wish__expected
msgid "Payment expected"
msgstr "Paiement attendu"
#. module: project_timesheet_funding_wish
#: code:addons/project_timesheet_funding_wish/models/hr_timesheet.py:0
#: model:ir.model.fields,field_description:project_timesheet_funding_wish.field_account_analytic_line__treated
#, python-format
msgid "Treated"
msgstr "Traité"

View File

@@ -0,0 +1 @@
from . import hr_timesheet

View File

@@ -0,0 +1,16 @@
from odoo import _, fields, models
class AccountAnalyticLine(models.Model):
_inherit = "account.analytic.line"
funding_wish = fields.Selection(
[
("free", "Free"),
("accepted", "Payment accepted"),
("expected", "Payment expected"),
],
string=_("Funding wish"),
copy=False,
)
treated = fields.Boolean(string=_("Treated"), copy=False)

View File

@@ -0,0 +1,27 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="hr_timesheet_line_tree_funding_view" model="ir.ui.view">
<field name="name">hr.timesheet.line.tree.funding.view</field>
<field name="model">account.analytic.line</field>
<field name="inherit_id" ref="hr_timesheet.hr_timesheet_line_tree" />
<field name="arch" type="xml">
<xpath expr="//field[@name='date']" position="after">
<field name="treated" />
<field name="funding_wish" />
</xpath>
</field>
</record>
<record id="view_task_form2_inherited_funding" model="ir.ui.view">
<field name="name">view.task.form2.inherited.funding</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="hr_timesheet.view_task_form2_inherited" />
<field name="arch" type="xml">
<xpath expr="//field[@name='timesheet_ids']/tree/field[@name='date']" position="after">
<field name="treated" />
<field name="funding_wish" />
</xpath>
</field>
</record>
</odoo>

View File

@@ -0,0 +1,2 @@
*.*~
*pyc

View File

@@ -0,0 +1,44 @@
============================
project_user_default_project
============================
Add default project field in user model
Installation
============
Use Odoo normal module installation procedure to install
``project_user_default_project``.
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.

View File

@@ -0,0 +1,3 @@
# -*- coding: utf-8 -*-
from . import models

View File

@@ -0,0 +1,86 @@
# Copyright 2022 Stéphan Sainléger (Elabore)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "project_user_default_project",
"version": "12.0.1.0.0",
"author": "Elabore",
"website": "https://elabore.coop",
"maintainer": "Stéphan Sainléger",
"license": "AGPL-3",
"category": "Tools",
"summary": "Add default project field in user model",
"description": """
:image: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
============================
project_user_default_project
============================
Add default project field in user model
Installation
============
Use Odoo normal module installation procedure to install
``project_user_default_project``.
Known issues / Roadmap
======================
None yet.
Bug Tracker
===========
Bugs are tracked on `our issues website <https://github.com/elabore-coop/project-tools/issues>`_. In case of
trouble, please check there if your issue has already been
reported. If you spotted it first, help us smashing it by providing a
detailed and welcomed feedback.
Credits
=======
Contributors
------------
* Stéphan Sainléger
Funders
-------
The development of this module has been financially supported by:
* Elabore (https://elabore.coop)
Maintainer
----------
This module is maintained by Elabore.
""",
# any module necessary for this one to work correctly
"depends": [
"base", "project",
],
"qweb": [
# "static/src/xml/*.xml",
],
"external_dependencies": {
"python": [],
},
# always loaded
"data": [
"views/res_users_views.xml",
],
# only loaded in demonstration mode
"demo": [],
"js": [],
"css": [],
"installable": True,
# Install this module automatically if all dependency have been previously
# and independently installed. Used for synergetic or glue modules.
"auto_install": False,
"application": False,
}

View File

@@ -0,0 +1 @@
This directory should contain the *.po for Odoo translation.

View File

@@ -0,0 +1,27 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * project_user_default_project
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-08-25 15:58+0000\n"
"PO-Revision-Date: 2022-08-25 15:58+0000\n"
"Last-Translator: <>\n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: project_user_default_project
#: model:ir.model.fields,field_description:project_user_default_project.field_res_users__default_project_id
msgid "Default Project"
msgstr "Projet par défaut"
#. module: project_user_default_project
#: model:ir.model,name:project_user_default_project.model_res_users
msgid "Users"
msgstr "Utilisateurs"

View File

@@ -0,0 +1 @@
from . import res_users

View File

@@ -0,0 +1,6 @@
from odoo import _, api, fields, models
class Users(models.Model):
_inherit = "res.users"
default_project_id = fields.Many2one('project.project', string='Default Project')

View File

@@ -0,0 +1,13 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<record id="view_users_form_inherit_default_project" model="ir.ui.view">
<field name="name">view.users.form.inherit.default.project</field>
<field name="model">res.users</field>
<field name="inherit_id" ref="base.view_users_form" />
<field name="arch" type="xml">
<xpath expr="//field[@name='action_id']" position="after">
<field name="default_project_id" />
</xpath>
</field>
</record>
</odoo>