blob: 1793698657481c422253e48632b7c7d075f7680f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
odoo.define('mail/static/src/components/notification_group/notification_group.js', function (require) {
'use strict';
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;
const { useRef } = owl.hooks;
class NotificationGroup extends Component {
/**
* @override
*/
constructor(...args) {
super(...args);
useShouldUpdateBasedOnProps();
useStore(props => {
const group = this.env.models['mail.notification_group'].get(props.notificationGroupLocalId);
return {
group: group ? group.__state : undefined,
};
});
/**
* Reference of the "mark as read" button. Useful to disable the
* top-level click handler when clicking on this specific button.
*/
this._markAsReadRef = useRef('markAsRead');
}
//--------------------------------------------------------------------------
// Public
//--------------------------------------------------------------------------
/**
* @returns {mail.notification_group}
*/
get group() {
return this.env.models['mail.notification_group'].get(this.props.notificationGroupLocalId);
}
/**
* @returns {string|undefined}
*/
image() {
if (this.group.notification_type === 'email') {
return '/mail/static/src/img/smiley/mailfailure.jpg';
}
}
//--------------------------------------------------------------------------
// Handlers
//--------------------------------------------------------------------------
/**
* @private
* @param {MouseEvent} ev
*/
_onClick(ev) {
const markAsRead = this._markAsReadRef.el;
if (markAsRead && markAsRead.contains(ev.target)) {
// handled in `_onClickMarkAsRead`
return;
}
this.group.openDocuments();
if (!this.env.messaging.device.isMobile) {
this.env.messaging.messagingMenu.close();
}
}
/**
* @private
* @param {MouseEvent} ev
*/
_onClickMarkAsRead(ev) {
this.group.openCancelAction();
if (!this.env.messaging.device.isMobile) {
this.env.messaging.messagingMenu.close();
}
}
}
Object.assign(NotificationGroup, {
props: {
notificationGroupLocalId: String,
},
template: 'mail.NotificationGroup',
});
return NotificationGroup;
});
|