summaryrefslogtreecommitdiff
path: root/addons/mail/static/src/components/activity_box
diff options
context:
space:
mode:
Diffstat (limited to 'addons/mail/static/src/components/activity_box')
-rw-r--r--addons/mail/static/src/components/activity_box/activity_box.js64
-rw-r--r--addons/mail/static/src/components/activity_box/activity_box.scss45
-rw-r--r--addons/mail/static/src/components/activity_box/activity_box.xml45
3 files changed, 154 insertions, 0 deletions
diff --git a/addons/mail/static/src/components/activity_box/activity_box.js b/addons/mail/static/src/components/activity_box/activity_box.js
new file mode 100644
index 00000000..ca191694
--- /dev/null
+++ b/addons/mail/static/src/components/activity_box/activity_box.js
@@ -0,0 +1,64 @@
+odoo.define('mail/static/src/components/activity_box/activity_box.js', function (require) {
+'use strict';
+
+const components = {
+ Activity: require('mail/static/src/components/activity/activity.js'),
+};
+const useShouldUpdateBasedOnProps = require('mail/static/src/component_hooks/use_should_update_based_on_props/use_should_update_based_on_props.js');
+const useStore = require('mail/static/src/component_hooks/use_store/use_store.js');
+
+const { Component } = owl;
+
+class ActivityBox extends Component {
+
+ /**
+ * @override
+ */
+ constructor(...args) {
+ super(...args);
+ useShouldUpdateBasedOnProps();
+ useStore(props => {
+ const chatter = this.env.models['mail.chatter'].get(props.chatterLocalId);
+ const thread = chatter && chatter.thread;
+ return {
+ chatter: chatter ? chatter.__state : undefined,
+ thread: thread && thread.__state,
+ };
+ });
+ }
+
+ //--------------------------------------------------------------------------
+ // Public
+ //--------------------------------------------------------------------------
+
+ /**
+ * @returns {Chatter}
+ */
+ get chatter() {
+ return this.env.models['mail.chatter'].get(this.props.chatterLocalId);
+ }
+
+ //--------------------------------------------------------------------------
+ // Handlers
+ //--------------------------------------------------------------------------
+
+ /**
+ * @private
+ */
+ _onClickTitle() {
+ this.chatter.toggleActivityBoxVisibility();
+ }
+
+}
+
+Object.assign(ActivityBox, {
+ components,
+ props: {
+ chatterLocalId: String,
+ },
+ template: 'mail.ActivityBox',
+});
+
+return ActivityBox;
+
+});
diff --git a/addons/mail/static/src/components/activity_box/activity_box.scss b/addons/mail/static/src/components/activity_box/activity_box.scss
new file mode 100644
index 00000000..64e99347
--- /dev/null
+++ b/addons/mail/static/src/components/activity_box/activity_box.scss
@@ -0,0 +1,45 @@
+// ------------------------------------------------------------------
+// Layout
+// ------------------------------------------------------------------
+
+.o_ActivityBox_title {
+ display: flex;
+ align-items: center;
+ flex: 0 0 auto;
+ margin-top: map-get($spacers, 4);
+ margin-bottom: map-get($spacers, 4);
+}
+
+.o_ActivityBox_titleBadge {
+ padding: map-get($spacers, 0) map-get($spacers, 2);
+}
+
+.o_ActivityBox_titleBadges {
+ margin-inline-end: map-get($spacers, 3);
+}
+
+.o_ActivityBox_titleLine {
+ flex: 1 1 auto;
+ width: auto;
+}
+
+.o_ActivityBox_titleText {
+ margin: map-get($spacers, 0) map-get($spacers, 3);
+}
+
+// ------------------------------------------------------------------
+// Style
+// ------------------------------------------------------------------
+
+.o_ActivityBox_title {
+ font-weight: bold;
+}
+
+.o_ActivityBox_titleBadge {
+ font-size: 11px;
+}
+
+.o_ActivityBox_titleLine {
+ border-color: gray('400');
+ border-style: dashed;
+}
diff --git a/addons/mail/static/src/components/activity_box/activity_box.xml b/addons/mail/static/src/components/activity_box/activity_box.xml
new file mode 100644
index 00000000..900b5634
--- /dev/null
+++ b/addons/mail/static/src/components/activity_box/activity_box.xml
@@ -0,0 +1,45 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<templates xml:space="preserve">
+
+ <t t-name="mail.ActivityBox" owl="1">
+ <div class="o_ActivityBox">
+ <t t-if="chatter and chatter.thread">
+ <a role="button" class="o_ActivityBox_title btn" t-on-click="_onClickTitle">
+ <hr class="o_ActivityBox_titleLine" />
+ <span class="o_ActivityBox_titleText">
+ <i class="fa fa-fw" t-att-class="chatter.isActivityBoxVisible ? 'fa-caret-down' : 'fa-caret-right'"/>
+ Planned activities
+ </span>
+ <t t-if="!chatter.isActivityBoxVisible">
+ <span class="o_ActivityBox_titleBadges">
+ <t t-if="chatter.thread.overdueActivities.length > 0">
+ <span class="o_ActivityBox_titleBadge badge rounded-circle badge-danger">
+ <t t-esc="chatter.thread.overdueActivities.length"/>
+ </span>
+ </t>
+ <t t-if="chatter.thread.todayActivities.length > 0">
+ <span class="o_ActivityBox_titleBadge badge rounded-circle badge-warning">
+ <t t-esc="chatter.thread.todayActivities.length"/>
+ </span>
+ </t>
+ <t t-if="chatter.thread.futureActivities.length > 0">
+ <span class="o_ActivityBox_titleBadge badge rounded-circle badge-success">
+ <t t-esc="chatter.thread.futureActivities.length"/>
+ </span>
+ </t>
+ </span>
+ </t>
+ <hr class="o_ActivityBox_titleLine" />
+ </a>
+ <t t-if="chatter.isActivityBoxVisible">
+ <div class="o_ActivityList">
+ <t t-foreach="chatter.thread.activities" t-as="activity" t-key="activity.localId">
+ <Activity class="o_ActivityBox_activity" activityLocalId="activity.localId"/>
+ </t>
+ </div>
+ </t>
+ </t>
+ </div>
+ </t>
+
+</templates>