From 3751379f1e9a4c215fb6eb898b4ccc67659b9ace Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Tue, 10 May 2022 21:51:50 +0700 Subject: initial commit 2 --- .../notification_request/notification_request.js | 94 ++++++++++++++++++++++ .../notification_request/notification_request.scss | 77 ++++++++++++++++++ .../notification_request/notification_request.xml | 31 +++++++ 3 files changed, 202 insertions(+) create mode 100644 addons/mail/static/src/components/notification_request/notification_request.js create mode 100644 addons/mail/static/src/components/notification_request/notification_request.scss create mode 100644 addons/mail/static/src/components/notification_request/notification_request.xml (limited to 'addons/mail/static/src/components/notification_request') diff --git a/addons/mail/static/src/components/notification_request/notification_request.js b/addons/mail/static/src/components/notification_request/notification_request.js new file mode 100644 index 00000000..54dcbbd4 --- /dev/null +++ b/addons/mail/static/src/components/notification_request/notification_request.js @@ -0,0 +1,94 @@ +odoo.define('mail/static/src/components/notification_request/notification_request.js', function (require) { +'use strict'; + +const components = { + PartnerImStatusIcon: require('mail/static/src/components/partner_im_status_icon/partner_im_status_icon.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 NotificationRequest extends Component { + + /** + * @override + */ + constructor(...args) { + super(...args); + useShouldUpdateBasedOnProps(); + useStore(props => { + return { + isDeviceMobile: this.env.messaging.device.isMobile, + partnerRoot: this.env.messaging.partnerRoot + ? this.env.messaging.partnerRoot.__state + : undefined, + }; + }); + } + + //-------------------------------------------------------------------------- + // Public + //-------------------------------------------------------------------------- + + /** + * @returns {string} + */ + getHeaderText() { + return _.str.sprintf( + this.env._t("%s has a request"), + this.env.messaging.partnerRoot.nameOrDisplayName + ); + } + + //-------------------------------------------------------------------------- + // Private + //-------------------------------------------------------------------------- + + /** + * Handle the response of the user when prompted whether push notifications + * are granted or denied. + * + * @private + * @param {string} value + */ + _handleResponseNotificationPermission(value) { + // manually force recompute because the permission is not in the store + this.env.messaging.messagingMenu.update(); + if (value !== 'granted') { + this.env.services['bus_service'].sendNotification( + this.env._t("Permission denied"), + this.env._t("Odoo will not have the permission to send native notifications on this device.") + ); + } + } + + //-------------------------------------------------------------------------- + // Handlers + //-------------------------------------------------------------------------- + + /** + * @private + */ + _onClick() { + const windowNotification = this.env.browser.Notification; + const def = windowNotification && windowNotification.requestPermission(); + if (def) { + def.then(this._handleResponseNotificationPermission.bind(this)); + } + if (!this.env.messaging.device.isMobile) { + this.env.messaging.messagingMenu.close(); + } + } + +} + +Object.assign(NotificationRequest, { + components, + props: {}, + template: 'mail.NotificationRequest', +}); + +return NotificationRequest; + +}); diff --git a/addons/mail/static/src/components/notification_request/notification_request.scss b/addons/mail/static/src/components/notification_request/notification_request.scss new file mode 100644 index 00000000..e2fcb81d --- /dev/null +++ b/addons/mail/static/src/components/notification_request/notification_request.scss @@ -0,0 +1,77 @@ +// ------------------------------------------------------------------ +// Layout +// ------------------------------------------------------------------ + +.o_NotificationRequest { + @include o-mail-notification-list-item-layout(); +} + +.o_NotificationRequest_content { + @include o-mail-notification-list-item-content-layout(); +} + +.o_NotificationRequest_core { + @include o-mail-notification-list-item-core-layout(); +} + +.o_NotificationRequest_coreItem { + @include o-mail-notification-list-item-core-item-layout(); +} + +.o_NotificationRequest_header { + @include o-mail-notification-list-item-header-layout(); +} + +.o_NotificationRequest_image { + @include o-mail-notification-list-item-image-layout(); +} + +.o_NotificationRequest_imageContainer { + @include o-mail-notification-list-item-image-container-layout(); +} + +.o_NotificationRequest_inlineText { + @include o-mail-notification-list-item-inline-text-layout(); +} + +.o_NotificationRequest_name { + @include o-mail-notification-list-item-name-layout(); +} + +.o_NotificationRequest_partnerImStatusIcon { + @include o-mail-notification-list-item-partner-im-status-icon-layout(); +} + +.o_NotificationRequest_sidebar { + @include o-mail-notification-list-item-sidebar-layout(); +} + +// ------------------------------------------------------------------ +// Style +// ------------------------------------------------------------------ + +.o_NotificationRequest { + @include o-mail-notification-list-item-style(); + + &:hover { + .o_NotificationRequest_partnerImStatusIcon { + @include o-mail-notification-list-item-hover-partner-im-status-icon-style(); + } + } +} + +.o_NotificationRequest_core { + @include o-mail-notification-list-item-core-style(); +} + +.o_NotificationRequest_image { + @include o-mail-notification-list-item-image-style(); +} + +.o_NotificationRequest_name { + @include o-mail-notification-list-item-bold-style(); +} + +.o_NotificationRequest_partnerImStatusIcon { + @include o-mail-notification-list-item-partner-im-status-icon-style(); +} diff --git a/addons/mail/static/src/components/notification_request/notification_request.xml b/addons/mail/static/src/components/notification_request/notification_request.xml new file mode 100644 index 00000000..f59c671a --- /dev/null +++ b/addons/mail/static/src/components/notification_request/notification_request.xml @@ -0,0 +1,31 @@ + + + + +
+
+
+ Avatar of OdooBot + +
+
+
+
+ + + +
+
+ + Enable desktop notifications to chat. + +
+
+
+
+ +
-- cgit v1.2.3