summaryrefslogtreecommitdiff
path: root/addons/mail/static/src/components/notification_request
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/mail/static/src/components/notification_request
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/mail/static/src/components/notification_request')
-rw-r--r--addons/mail/static/src/components/notification_request/notification_request.js94
-rw-r--r--addons/mail/static/src/components/notification_request/notification_request.scss77
-rw-r--r--addons/mail/static/src/components/notification_request/notification_request.xml31
3 files changed, 202 insertions, 0 deletions
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 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<templates xml:space="preserve">
+
+ <t t-name="mail.NotificationRequest" owl="1">
+ <div class="o_NotificationRequest" t-on-click="_onClick">
+ <div class="o_NotificationRequest_sidebar">
+ <div class="o_NotificationRequest_imageContainer o_NotificationRequest_sidebarItem">
+ <img class="o_NotificationRequest_image rounded-circle" src="/mail/static/src/img/odoobot.png" alt="Avatar of OdooBot"/>
+ <PartnerImStatusIcon
+ class="o_NotificationRequest_partnerImStatusIcon"
+ t-att-class="{ 'o-mobile': env.messaging.device.isMobile }"
+ partnerLocalId="env.messaging.partnerRoot.localId"
+ />
+ </div>
+ </div>
+ <div class="o_NotificationRequest_content">
+ <div class="o_NotificationRequest_header">
+ <span class="o_NotificationRequest_name" t-att-class="{ 'o-mobile': env.messaging.device.isMobile }">
+ <t t-esc="getHeaderText()"/>
+ </span>
+ </div>
+ <div class="o_NotificationRequest_core">
+ <span class="o_NotificationRequest_coreItem o_NotificationRequest_inlineText">
+ Enable desktop notifications to chat.
+ </span>
+ </div>
+ </div>
+ </div>
+ </t>
+
+</templates>