Browse Source

Nov 16 : [ADD] Initial Commit 'user_weather_notification'

pull/295/head
RisvanaCybro 1 year ago
parent
commit
c74e0cd331
  1. 48
      user_weather_notification/README.rst
  2. 23
      user_weather_notification/__init__.py
  3. 53
      user_weather_notification/__manifest__.py
  4. 22
      user_weather_notification/controllers/__init__.py
  5. 70
      user_weather_notification/controllers/user_weather_notification.py
  6. 6
      user_weather_notification/doc/RELEASE_NOTES.md
  7. 22
      user_weather_notification/models/__init__.py
  8. 52
      user_weather_notification/models/res_users.py
  9. BIN
      user_weather_notification/static/description/assets/icons/check.png
  10. BIN
      user_weather_notification/static/description/assets/icons/chevron.png
  11. BIN
      user_weather_notification/static/description/assets/icons/cogs.png
  12. BIN
      user_weather_notification/static/description/assets/icons/consultation.png
  13. BIN
      user_weather_notification/static/description/assets/icons/ecom-black.png
  14. BIN
      user_weather_notification/static/description/assets/icons/education-black.png
  15. BIN
      user_weather_notification/static/description/assets/icons/hotel-black.png
  16. BIN
      user_weather_notification/static/description/assets/icons/insta_feed_snippet_icon.png
  17. BIN
      user_weather_notification/static/description/assets/icons/license.png
  18. BIN
      user_weather_notification/static/description/assets/icons/lifebuoy.png
  19. BIN
      user_weather_notification/static/description/assets/icons/logo.png
  20. BIN
      user_weather_notification/static/description/assets/icons/manufacturing-black.png
  21. BIN
      user_weather_notification/static/description/assets/icons/pos-black.png
  22. BIN
      user_weather_notification/static/description/assets/icons/puzzle.png
  23. BIN
      user_weather_notification/static/description/assets/icons/restaurant-black.png
  24. BIN
      user_weather_notification/static/description/assets/icons/service-black.png
  25. BIN
      user_weather_notification/static/description/assets/icons/trading-black.png
  26. BIN
      user_weather_notification/static/description/assets/icons/training.png
  27. BIN
      user_weather_notification/static/description/assets/icons/update.png
  28. BIN
      user_weather_notification/static/description/assets/icons/user.png
  29. BIN
      user_weather_notification/static/description/assets/icons/wrench.png
  30. BIN
      user_weather_notification/static/description/assets/misc/categories.png
  31. BIN
      user_weather_notification/static/description/assets/misc/check-box.png
  32. BIN
      user_weather_notification/static/description/assets/misc/compass.png
  33. BIN
      user_weather_notification/static/description/assets/misc/corporate.png
  34. BIN
      user_weather_notification/static/description/assets/misc/customer-support.png
  35. BIN
      user_weather_notification/static/description/assets/misc/cybrosys-logo.png
  36. BIN
      user_weather_notification/static/description/assets/misc/features.png
  37. BIN
      user_weather_notification/static/description/assets/misc/logo.png
  38. BIN
      user_weather_notification/static/description/assets/misc/pictures.png
  39. BIN
      user_weather_notification/static/description/assets/misc/pie-chart.png
  40. BIN
      user_weather_notification/static/description/assets/misc/right-arrow.png
  41. BIN
      user_weather_notification/static/description/assets/misc/star.png
  42. BIN
      user_weather_notification/static/description/assets/misc/support.png
  43. BIN
      user_weather_notification/static/description/assets/misc/whatsapp.png
  44. BIN
      user_weather_notification/static/description/assets/modules/1.png
  45. BIN
      user_weather_notification/static/description/assets/modules/2.png
  46. BIN
      user_weather_notification/static/description/assets/modules/3.png
  47. BIN
      user_weather_notification/static/description/assets/modules/4.png
  48. BIN
      user_weather_notification/static/description/assets/modules/5.jpg
  49. BIN
      user_weather_notification/static/description/assets/modules/6.png
  50. BIN
      user_weather_notification/static/description/assets/screenshots/hero.gif
  51. BIN
      user_weather_notification/static/description/assets/screenshots/screen_2.png
  52. BIN
      user_weather_notification/static/description/assets/screenshots/screen_3.png
  53. BIN
      user_weather_notification/static/description/assets/screenshots/screen_4.png
  54. BIN
      user_weather_notification/static/description/assets/screenshots/screen_5.png
  55. BIN
      user_weather_notification/static/description/assets/screenshots/screen_6.png
  56. BIN
      user_weather_notification/static/description/assets/screenshots/screen_7.png
  57. BIN
      user_weather_notification/static/description/assets/screenshots/screen_8.png
  58. BIN
      user_weather_notification/static/description/banner.png
  59. BIN
      user_weather_notification/static/description/icon.png
  60. 528
      user_weather_notification/static/description/index.html
  61. BIN
      user_weather_notification/static/src/img/weather_card.jpg
  62. 78
      user_weather_notification/static/src/js/weather_notification.js
  63. 47
      user_weather_notification/static/src/xml/weather_notification_templates.xml
  64. 27
      user_weather_notification/views/res_users_views.xml

48
user_weather_notification/README.rst

@ -0,0 +1,48 @@
.. image:: https://img.shields.io/badge/license-LGPL--3-green.svg
:target: https://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
User Weather Notification
=========================
The "User Weather Notification" Odoo app is a module designed to provide weather updates and notifications within the Odoo ERP system. It allows users to receive real-time weather information based on their specified locations and preferences. Here's a summary and description of the app
Configuration
=============
- www.odoo.com/documentation/16.0/setup/install.html
- Install our custom addon
License
-------
General Public License, Version 3 (LGPL v3).
(https://www.gnu.org/licenses/lgpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developer:(V16) Vishnu Vijayan KK, Contact: odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
Bug Tracker
-----------
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported.
Maintainer
==========
.. image:: https://cybrosys.com/images/logo.png
:target: https://cybrosys.com
This module is maintained by Cybrosys Technologies.
For support and more information, please visit `Our Website <https://cybrosys.com/>`__
Further information
===================
HTML Description: `<static/description/index.html>`__

23
user_weather_notification/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Vishnu Vijayan KK (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import controllers
from . import models

53
user_weather_notification/__manifest__.py

@ -0,0 +1,53 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Vishnu Vijayan KK (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': 'User Weather Notification',
'version': '16.0.1.0.0',
'category': 'Productivity',
'summary': """The User Weather Notification Odoo app is an extension module
that integrates weather forecasting functionality into the Odoo ERP system'""",
'description': """The User Weather Notification app enhances the usability
of the Odoo platform by integrating weather data and alerts. It enables
users to stay informed about weather conditions and receive timely
notifications based on their chosen locations'""",
'author': "Cybrosys Techno Solutions",
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': ['web'],
'data': ['views/res_users_views.xml'],
'assets': {
'web.assets_backend': [
'user_weather_notification/static/src/js/weather_notification.js',
'user_weather_notification/static/src'
'/xml/weather_notification_templates.xml',
],
},
'external_dependencies': {
'python': ['geocoder'],
},
'images': ['static/description/banner.png'],
'license': 'LGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

22
user_weather_notification/controllers/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Vishnu Vijayan KK (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import user_weather_notification

70
user_weather_notification/controllers/user_weather_notification.py

@ -0,0 +1,70 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Vishnu Vijayan KK (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
import geocoder
import requests
from odoo import http
from odoo.http import request
class WeatherNotification(http.Controller):
"""
Controller class for fetching weather details based on location.
This class provides a controller to fetch weather information based on the
user's location setting.
It supports both automatic and manual location settings.
"""
@http.route('/weather/notification/check', type='json', auth="public",
methods=['POST'])
def weather_notification(self):
"""
Controller for fetching weather data
:return: Dictionary of weather information
:rtype: dict
"""
weather_data = {'data': False}
if request.env.user.api_key:
if request.env.user.location_set == 'auto':
try:
response = geocoder.ip('me')
if response.status_code == 200:
lat = round(response.latlng[0], 2)
lng = round(response.latlng[1], 2)
url = 'https://api.openweathermap.org/data/2.5' \
'/weather?lat=%s&lon=%s&appid=%s' % (
lat, lng, request.env.user.api_key)
weather = requests.get(url)
if weather.status_code == 200:
weather_data = weather.json()
except Exception:
pass
elif request.env.user.location_set == 'manual':
try:
url = 'https://api.openweathermap.org/data/2.5' \
'/weather?q=%s&appid=%s' % (
request.env.user.city, request.env.user.api_key)
city_req = requests.get(url)
if city_req.status_code == 200:
weather_data = city_req.json()
except Exception:
pass
return weather_data

6
user_weather_notification/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <user_weather_notification>
#### 26.10.2023
#### Version 16.0.1.0.0
#### ADD
- Initial commit for User Weather Notification

22
user_weather_notification/models/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Vishnu Vijayan KK (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import res_users

52
user_weather_notification/models/res_users.py

@ -0,0 +1,52 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Vishnu Vijayan KK (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
import requests
from odoo import api, fields, models, _
from odoo.exceptions import ValidationError
class ResUsers(models.Model):
"""
Extends the 'res.users' model to include additional fields related to
weather information.
"""
_inherit = "res.users"
api_key = fields.Char(string='API Key', help="API key from OpenWeatherMap")
location_set = fields.Selection(selection=[
('auto', 'Use Browser Location'),
('manual', 'Manual Location'),
], string="Set Location", default='auto',
help="Setting and managing locations")
city = fields.Char(string='City', help="City of the user")
@api.constrains('city')
def _check_city(self):
"""Constraints to check city is valid or not"""
for rec in self:
if rec.api_key:
url = ('https://api.openweathermap.org/data/2.5/weather?q=%s'
'&appid=%s') % (
rec.city, rec.api_key)
city_check = requests.get(url).json()
if city_check['cod'] != 200:
raise ValidationError(_(city_check['message']))

BIN
user_weather_notification/static/description/assets/icons/check.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

BIN
user_weather_notification/static/description/assets/icons/chevron.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

BIN
user_weather_notification/static/description/assets/icons/cogs.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
user_weather_notification/static/description/assets/icons/consultation.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
user_weather_notification/static/description/assets/icons/ecom-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

BIN
user_weather_notification/static/description/assets/icons/education-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

BIN
user_weather_notification/static/description/assets/icons/hotel-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

BIN
user_weather_notification/static/description/assets/icons/insta_feed_snippet_icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 28 KiB

BIN
user_weather_notification/static/description/assets/icons/license.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
user_weather_notification/static/description/assets/icons/lifebuoy.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
user_weather_notification/static/description/assets/icons/logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

BIN
user_weather_notification/static/description/assets/icons/manufacturing-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

BIN
user_weather_notification/static/description/assets/icons/pos-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

BIN
user_weather_notification/static/description/assets/icons/puzzle.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

BIN
user_weather_notification/static/description/assets/icons/restaurant-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

BIN
user_weather_notification/static/description/assets/icons/service-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

BIN
user_weather_notification/static/description/assets/icons/trading-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

BIN
user_weather_notification/static/description/assets/icons/training.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

BIN
user_weather_notification/static/description/assets/icons/update.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
user_weather_notification/static/description/assets/icons/user.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

BIN
user_weather_notification/static/description/assets/icons/wrench.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
user_weather_notification/static/description/assets/misc/categories.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

BIN
user_weather_notification/static/description/assets/misc/check-box.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
user_weather_notification/static/description/assets/misc/compass.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

BIN
user_weather_notification/static/description/assets/misc/corporate.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
user_weather_notification/static/description/assets/misc/customer-support.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

BIN
user_weather_notification/static/description/assets/misc/cybrosys-logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

BIN
user_weather_notification/static/description/assets/misc/features.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

BIN
user_weather_notification/static/description/assets/misc/logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

BIN
user_weather_notification/static/description/assets/misc/pictures.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

BIN
user_weather_notification/static/description/assets/misc/pie-chart.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
user_weather_notification/static/description/assets/misc/right-arrow.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

BIN
user_weather_notification/static/description/assets/misc/star.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

BIN
user_weather_notification/static/description/assets/misc/support.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

BIN
user_weather_notification/static/description/assets/misc/whatsapp.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

BIN
user_weather_notification/static/description/assets/modules/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

BIN
user_weather_notification/static/description/assets/modules/2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

BIN
user_weather_notification/static/description/assets/modules/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

BIN
user_weather_notification/static/description/assets/modules/4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 91 KiB

BIN
user_weather_notification/static/description/assets/modules/5.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 93 KiB

BIN
user_weather_notification/static/description/assets/modules/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 66 KiB

BIN
user_weather_notification/static/description/assets/screenshots/hero.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 153 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 87 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 106 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_7.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 298 KiB

BIN
user_weather_notification/static/description/assets/screenshots/screen_8.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 55 KiB

BIN
user_weather_notification/static/description/banner.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

BIN
user_weather_notification/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

528
user_weather_notification/static/description/index.html

@ -0,0 +1,528 @@
<div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;">
<!-- TITLE BAR -->
<div class="d-flex align-items-center justify-content-between" style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;">
<img src="assets/misc/cybrosys-logo.png" width="42" height="42" style="width: 42px; height: 42px;" />
<div>
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" class="mr-2">
<i class="fa fa-check mr-1"></i>Community
</div>
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" class="mr-2">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
<!-- END OF TITLE BAR -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<!-- APP HERO -->
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
User Weather Notification
</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">A Module For User Weather Notification.</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/hero.gif" class="img-responsive" style="width: 100%; margin-left: auto; margin-right: auto;" />
</div>
</div>
</div>
</div>
<!-- NAVIGATION SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/compass.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Explore This
Module</h2>
</div>
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;">
<div class="col-sm-12 col-md-6 my-3">
<a href="#overview">
<div class="d-flex justify-content-between align-items-center" style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn
more about this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36" />
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#features">
<div class="d-flex justify-content-between align-items-center" style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View
features of this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36" />
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#screenshots">
<div class="d-flex justify-content-between align-items-center" style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View
screenshots for this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36" />
</div>
</a>
</div>
</div>
<!-- END OF NAVIGATION SECTION -->
<!-- OVERVIEW SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pie-chart.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Overview
</h2>
</div>
<div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 py-4">
As we know, many industries are depending on weather conditions like manufacturing, Event Management,
Construction etc. So we believe our concept of weather module can be used in these industries to
understand and plan their works according to the weather condition. This module is a starter to think
and explore the opportunity to bring the advanced features in Odoo.You must install the python
package geocoder in order to install this module "pip3 install geocoder".
</div>
</div>
<!-- END OF OVERVIEW SECTION -->
<!-- FEATURES SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="features">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/features.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Features
</h2>
</div>
<div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2" />
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">The user will get the weather notification.</span>
</div>
<div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2" />
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">The user can configure their weather notification.</span>
</div>
</div>
</div>
<!-- END OF FEATURES SECTION -->
<!-- SCREENSHOTS SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="screenshots">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pictures.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Screenshots
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Single Click Weather Report</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
User can easily find the weather report from a single click. Summary of the weather conditions is
displayed on the weather board. The user will easily get weather updates, state of climate and current
temperature etc.
</p>
<img src="assets/screenshots/screen_2.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Configuration
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">User must provide API Key for openweathermap and select auto location or manual location.
</p>
<img src="assets/screenshots/screen_3.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">For manual location user must enter a valid city of openweathermap api.
</p>
<img src="assets/screenshots/screen_4.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<img src="assets/screenshots/screen_5.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Required Openweathermap API</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">In order to access the Openweathermap API,
it is mandatory to have an active account with them. You will need to create an account with Openweathermap in order to generate the API Key.</p>
<img src="assets/screenshots/screen_6.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">Once you have created the account, access your API keys, start by clicking on your account and then selecting "My API Keys".</p>
<img src="assets/screenshots/screen_7.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">Once you navigate to the "My API Keys" page, you can easily retrieve your API Key and use it as necessary.</p>
<img src="assets/screenshots/screen_8.png" class="img-thumbnail">
</div>
</div>
</div>
<!-- END OF SCREENSHOTS SECTION -->
<!-- RELATED PRODUCTS -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/categories.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Related
Products
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner" style="padding: 30px;">
<div class="carousel-item" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/project_dashboard_odoo/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/1.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/agriculture_management_odoo/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/2.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/geoip_website_redirect/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item active" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/statement_report/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/4.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/pdf_report_with_sign/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/5.jpg">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/fleet_rental_dashboard/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/6.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev" style="width:35px; color:#000"> <span class="carousel-control-prev-icon"><i class="fa fa-chevron-left" style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1" data-slide="next" style="width:35px; color:#000">
<span class="carousel-control-next-icon"><i class="fa fa-chevron-right" style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF RELATED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our Services
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3" style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</div>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our
Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/trading-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/pos-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/education-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/manufacturing-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/ecom-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/service-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/restaurant-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center" style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/hotel-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</div>
<!-- END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2" style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4" style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/support.png" height="48" width="48" style="width: 42px; height: 42px;" />
</div>
<div>
<h4>Need Help?</h4>
<p style="line-height: 100%;">Got questions or need help?
Get in touch.</p>
<a href="mailto:odoo@cybrosys.com">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
odoo@cybrosys.com</p>
</a>
</div>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4" style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/whatsapp.png" height="52" width="52" style="width: 52px; height: 52px;" />
</div>
<div>
<h4>WhatsApp</h4>
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p>
<a href="https://api.whatsapp.com/send?phone=918606827707">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
+91 86068
27707</p>
</a>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center">
<img src="assets/misc/logo.png" width="144" height="31" style="width:144px; height: 31px; margin-top: 40px;" />
</div>
</div>
</div>
<!-- END OF SUPPORT -->

BIN
user_weather_notification/static/src/img/weather_card.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

78
user_weather_notification/static/src/js/weather_notification.js

@ -0,0 +1,78 @@
/** @odoo-module **/
import { Dropdown } from "@web/core/dropdown/dropdown";
import { DropdownItem } from "@web/core/dropdown/dropdown_item";
import { CheckBox } from "@web/core/checkbox/checkbox";
import { browser } from "@web/core/browser/browser";
import { registry } from "@web/core/registry";
import { useService } from "@web/core/utils/hooks";
import { session } from "@web/session";
import { Component } from "@odoo/owl";
var ajax = require('web.ajax');
const { onWillStart } = owl;
/**Component for displaying weather information in the user menu. **/
export class WeatherMenu extends Component {
setup() {
this.user = useService("user");
this.session = session;
onWillStart(async () => {
/**Updating weather data at initial time **/
const weather_data = await this.fetch_data();
if (weather_data.hasOwnProperty("data")) {
this.session.name = '';
this.session.main = '';
this.session.description = 'Configure Notification Settings';
this.session.temp = '';
} else {
this.session.name = weather_data.name;
this.session.main = weather_data.weather[0].main;
this.session.description = weather_data.weather[0].description;
this.session.temp =
Math.round(weather_data.main['temp'] - 273.15);
}
});
const { origin } = browser.location;
const { userId } = this.user;
}
async getElements() {
/**Updating weather data while loading template**/
const self = this;
const weather_data = await self.fetch_data();
if (weather_data.hasOwnProperty("data")) {
self.session.name = '';
self.session.main = '';
self.session.description = 'Configure Notification Settings';
self.session.temp = '';
} else {
self.session.name = weather_data.name;
self.session.main = weather_data.weather[0].main;
self.session.description = weather_data.weather[0].description;
self.session.temp = Math.round(weather_data.main['temp'] - 273.15);
}
}
fetch_data() {
/**Fetching weather data using jsonrpc call**/
return new Promise(function(resolve, reject) {
var self = this;
ajax.jsonRpc('/weather/notification/check', 'call', {}).
then(function(data) {
resolve(data);
})
});
}
}
WeatherMenu.template = "user_weather_notification.UserMenuS";
WeatherMenu.components = {
Dropdown,
DropdownItem,
CheckBox
};
/**
Component for displaying weather information in the system tray.
**/
export const systrayItem = {
Component: WeatherMenu,
};
registry.category("systray").add("user_weather_notification.user_menus",
systrayItem, {
sequence: 0
});

47
user_weather_notification/static/src/xml/weather_notification_templates.xml

@ -0,0 +1,47 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--
This XML file defines a template for displaying weather notifications in a user menu.
-->
<templates xml:space="preserve">
<t t-name="user_weather_notification.UserMenuS" owl="1">
<Dropdown togglerClass="'py-1 py-lg-0'">
<!-- Dropdown component -->
<t t-set="datas" t-value="getElements()"/>
<t t-set-slot="toggler">
<i class="fa fa-cloud" style="color:blue;"/>
</t>
<div class="padding"
style="overflow:hidden;width:285px;height:165px;">
<!-- Weather card container -->
<div class="card">
<img class=""
src="user_weather_notification/static/src/img/weather_card.jpg"
alt="Card image cap"/>
<div class="card-img-overlay" style="height:110px;">
<h3 class="card-title text-white m-b-0 dl"><span t-esc="session.name"/></h3>
<small class="card-text text-white font-light"><span t-esc="session.main"/></small>
</div>
<div class="card-body weather-small">
<!-- Weather details -->
<div class="row">
<div class="col-8 b-r align-self-center">
<div class="d-flex">
<div class="display-6 text-info">
<i class="mdi mdi-weather-pouring"/>
</div>
<div class="m-l-20">
<!-- Temperature and description -->
<h1 class="font-light text-info m-b-0"
t-if="session.temp"><span t-esc="session.temp"/>
<sup>0</sup>C</h1>
<small><span t-esc="session.description"/></small>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</Dropdown>
</t>
</templates>

27
user_weather_notification/views/res_users_views.xml

@ -0,0 +1,27 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!--
This XML file defines a customization to the Odoo user interface for the
'res.users' model.
It adds a new page after 'Preferences' for Weather Settings, allowing users to
input their API key.
-->
<record id="view_users_form" model="ir.ui.view">
<field name="name">res.users.view.form.inherit.user.weather.notification</field>
<field name="model">res.users</field>
<field name="type">form</field>
<field name="inherit_id" ref="base.view_users_form"/>
<field name="arch" type="xml">
<xpath expr="//page[@name='preferences']" position="after">
<page string="Weather Settings" name="oauth">
<group>
<field name="api_key"/>
<field name="location_set"/>
<field name="city" attrs="{'invisible':[
('location_set', '!=', 'manual')]}"/>
</group>
</page>
</xpath>
</field>
</record>
</odoo>
Loading…
Cancel
Save