Browse Source

Aug 11 : [ADD] Initial Commit 'systray_world_clock'

pull/280/head
RisvanaCybro 2 years ago
parent
commit
13e29a7a2e
  1. 50
      systray_world_clock/README.rst
  2. 22
      systray_world_clock/__init__.py
  3. 54
      systray_world_clock/__manifest__.py
  4. 6
      systray_world_clock/doc/RELEASE_NOTES.md
  5. 22
      systray_world_clock/models/__init__.py
  6. 52
      systray_world_clock/models/systray_world_clock_config.py
  7. 2
      systray_world_clock/security/ir.model.access.csv
  8. BIN
      systray_world_clock/static/description/assets/icons/check.png
  9. BIN
      systray_world_clock/static/description/assets/icons/chevron.png
  10. BIN
      systray_world_clock/static/description/assets/icons/cogs.png
  11. BIN
      systray_world_clock/static/description/assets/icons/consultation.png
  12. BIN
      systray_world_clock/static/description/assets/icons/ecom-black.png
  13. BIN
      systray_world_clock/static/description/assets/icons/education-black.png
  14. BIN
      systray_world_clock/static/description/assets/icons/hotel-black.png
  15. BIN
      systray_world_clock/static/description/assets/icons/license.png
  16. BIN
      systray_world_clock/static/description/assets/icons/lifebuoy.png
  17. BIN
      systray_world_clock/static/description/assets/icons/logo.png
  18. BIN
      systray_world_clock/static/description/assets/icons/manufacturing-black.png
  19. BIN
      systray_world_clock/static/description/assets/icons/pos-black.png
  20. BIN
      systray_world_clock/static/description/assets/icons/puzzle.png
  21. BIN
      systray_world_clock/static/description/assets/icons/restaurant-black.png
  22. BIN
      systray_world_clock/static/description/assets/icons/service-black.png
  23. BIN
      systray_world_clock/static/description/assets/icons/trading-black.png
  24. BIN
      systray_world_clock/static/description/assets/icons/training.png
  25. BIN
      systray_world_clock/static/description/assets/icons/update.png
  26. BIN
      systray_world_clock/static/description/assets/icons/user.png
  27. BIN
      systray_world_clock/static/description/assets/icons/wrench.png
  28. BIN
      systray_world_clock/static/description/assets/modules/budget_image.png
  29. BIN
      systray_world_clock/static/description/assets/modules/credit_image.png
  30. BIN
      systray_world_clock/static/description/assets/modules/employee_image.png
  31. BIN
      systray_world_clock/static/description/assets/modules/export_image.png
  32. BIN
      systray_world_clock/static/description/assets/modules/gantt_image.png
  33. BIN
      systray_world_clock/static/description/assets/modules/quotation_image.png
  34. BIN
      systray_world_clock/static/description/assets/screenshots/clocks.png
  35. BIN
      systray_world_clock/static/description/assets/screenshots/hero.gif
  36. BIN
      systray_world_clock/static/description/assets/screenshots/settings.png
  37. BIN
      systray_world_clock/static/description/banner.jpg
  38. BIN
      systray_world_clock/static/description/icon.png
  39. 575
      systray_world_clock/static/description/index.html
  40. 168
      systray_world_clock/static/src/js/systray_world_clock.js
  41. 129
      systray_world_clock/static/src/scss/systray_world_clock.scss
  42. 90
      systray_world_clock/static/src/xml/systray_world_clock.xml
  43. 15
      systray_world_clock/views/systray_world_clock_config_views.xml

50
systray_world_clock/README.rst

@ -0,0 +1,50 @@
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
Systray World Clock
===================
Module enables user to add world clocks of selected timezones in the systray
dropdown.
Configuration
=============
The desired timezone and title for the clocks can be configured in the settings
page.
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
License
-------
GNU AFFERO GENERAL PUBLIC LICENSE, Version 3 (AGPLv3)
(http://www.gnu.org/licenses/agpl-3.0-standalone.html)
Credits
-------
* Developer: (V15) Abhijith PG, 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>`__

22
systray_world_clock/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Abhijith PG (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL 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 AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import models

54
systray_world_clock/__manifest__.py

@ -0,0 +1,54 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Abhijith PG (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL 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 AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': "Systray World Clock",
'version': '15.0.1.0.0',
'category': 'Productivity',
'summary': """Keep track of the time in different countries around the
world.""",
'description': """This module adds a world clock in the systray which
displays the time in different countries around the world. The time zone
can be customized in the settings""",
'author': "Cybrosys Techno Solutions",
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': ['base'],
'data': [
'security/ir.model.access.csv',
'views/systray_world_clock_config_views.xml',
],
'assets': {
'web.assets_backend': [
'systray_world_clock/static/src/js/systray_world_clock.js',
'systray_world_clock/static/src/scss/systray_world_clock.scss'
],
'web.assets_qweb': [
'systray_world_clock/static/src/xml/systray_world_clock.xml'
],
},
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': True,
}

6
systray_world_clock/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <systray_world_clock>
#### 01.08.2023
#### Version 15.0.1.0.0
#### ADD
- Initial commit for Systray World Clock

22
systray_world_clock/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: Abhijith PG (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL 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 AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import systray_world_clock_config

52
systray_world_clock/models/systray_world_clock_config.py

@ -0,0 +1,52 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Abhijith PG (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL 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 AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
import pytz
from datetime import datetime
from odoo import api, fields, models
from odoo.addons.base.models.res_partner import _tz_get
class SystrayWorldClockConfig(models.Model):
"""A model representing the configuration of a world clock in the systray.
"""
_name = 'systray.world.clock.config'
_description = 'Systray World Clock Configuration'
name = fields.Char(string='Location', required=True,
help='Location associated with this clock.')
tz = fields.Selection(_tz_get, required=True, string='Timezone',
help='Timezone of the clock.')
offset = fields.Float(string="Offset",
help='The time difference between the timezone and '
'UTC, in hours.')
@api.onchange('tz')
def _onchange_tz(self):
"""Calculate the time offset between the selected timezone and UTC.
This method is called automatically whenever the timezone field is
changed.
"""
if self.tz:
utc_dt = pytz.utc.localize(datetime.utcnow())
tz = pytz.timezone(self.tz)
local_dt = utc_dt.astimezone(tz)
self.offset = local_dt.utcoffset().total_seconds() / 3600

2
systray_world_clock/security/ir.model.access.csv

@ -0,0 +1,2 @@
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_systray_world_clock_config_user,access.systray.world.clock.config.user,model_systray_world_clock_config,base.group_user,1,1,1,1
1 id name model_id:id group_id:id perm_read perm_write perm_create perm_unlink
2 access_systray_world_clock_config_user access.systray.world.clock.config.user model_systray_world_clock_config base.group_user 1 1 1 1

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
systray_world_clock/static/description/assets/modules/budget_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 59 KiB

BIN
systray_world_clock/static/description/assets/modules/credit_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

BIN
systray_world_clock/static/description/assets/modules/employee_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

BIN
systray_world_clock/static/description/assets/modules/export_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

BIN
systray_world_clock/static/description/assets/modules/gantt_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
systray_world_clock/static/description/assets/modules/quotation_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

BIN
systray_world_clock/static/description/assets/screenshots/clocks.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 378 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 81 KiB

BIN
systray_world_clock/static/description/assets/screenshots/settings.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

BIN
systray_world_clock/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 79 KiB

BIN
systray_world_clock/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.4 KiB

575
systray_world_clock/static/description/index.html

@ -0,0 +1,575 @@
<div class="container" style="padding: 1rem !important; margin-bottom: 1rem !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between"
style="border-bottom: 1px solid #d5d5d5;">
<div class="my-3">
<img src="./assets/icons/logo.png" style="width: auto !important; height: 40px !important;">
</div>
<div class="my-3 d-flex align-items-center">
<div
style="background-color: #7C7BAD !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Community
</div>
<div style="background-color: #875A7B !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div style="background-color: #017E84 !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
</div>
</div>
<div class="container" style="padding: 0rem 1.5rem 4rem !important">
<div class="row" style="height: 900px !important;">
<div class="col-sm-12 col-md-12 col-lg-12"
style="padding: 4rem 1rem !important; background-color: #714B67 !important; height: 600px !important; border-radius: 20px !important;">
<h1
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #FFFFFF !important; font-size: 3.5rem !important; text-align: center !important;">
Systray World Clock</h1>
<p
style="font-family: 'Montserrat', sans-serif !important; font-weight: 300 !important; color: #FFFFFF !important; font-size: 1.4rem !important; text-align: center !important;">
The World Clock in the Systray.
</p>
<img src="./assets/screenshots/hero.gif" class="img-responsive" width="100%" height="auto" />
</div>
</div>
<div class="row">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin-bottom: 2rem !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-compass mr-2"></i>Explore this module
</h2>
</div>
<div class="col-md-6">
<a href="#overview" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Overview</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
Learn more about this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#features" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Features</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
View features of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#screenshots" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Screenshots</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
See key screenshots of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
</div>
<div class="row" id="overview">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-pie-chart mr-2"></i>Overview
</h2>
</div>
<div class="col-mg-12 pl-3">
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important; line-height: 30px !important;">
This module provides users with a systray world clock feature
that allows them to track time zones for different cities
around the world.</p>
</div>
</div>
<div class="row" id="features">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-star mr-2"></i>Features
</h2>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Can add different timezones.
</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Displays the digital and analogue time. </h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Clock faces changes color at nighttime.</h4>
</div>
</div>
</div>
<div class="row" id="screenshots">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-image mr-2"></i>Screenshots
</h2>
</div>
<div class="col-lg-12 my-2">
<h4 class="mt-2"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
The Clocks will appear like this.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
The globe icon in systray opens the interface with all the clocks configured in the settings. The settings button opens the configuration page.</p>
<img src="assets/screenshots/clocks.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-2">
<h4 class="mt-2"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Settings.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Configure the Location and Timezone here.</p>
<img src="assets/screenshots/settings.png"
class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
</div>
<!-- SUGGESTED PRODUCTS -->
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center"
style="text-align: center; padding: 2.5rem 1rem !important;">
<h2 style="color: #212529 !important;">Suggested Products</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner">
<div class="carousel-item active" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/export_stockinfo_xls/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/export_image.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/15.0/custom_gantt_view/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/gantt_image.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/15.0/sales_credit_limit/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/credit_image.png">
</div>
</a>
</div>
</div>
<div class="carousel-item" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/base_account_budget/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/budget_image.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/15.0/product_to_quotation/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/quotation_image.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/15.0/employee_documents_expiry/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/employee_image.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev"
style="left:-25px;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="right:-25px;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 SUGGESTED PRODUCTS -->
<!-- OUR SERVICES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Services</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</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: #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>
</section>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Industries</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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>
</section>
<!-- END OF OUR INDUSTRIES -->
<!-- FOOTER -->
<!-- Footer Section -->
<section class="container" style="margin: 5rem auto 2rem;">
<div class="row" style="max-width:1540px;">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Need Help?</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
</div>
<!-- Contact Cards -->
<div class="row d-flex justify-content-center align-items-center"
style="max-width:1540px; margin: 0 auto 2rem auto;">
<div class="col-lg-12" style="padding: 0rem 3rem 2rem; border-radius: 10px; margin-right: 3rem; ">
<div class="row mt-4">
<div class="col-lg-6">
<a href="mailto:odoo@cybrosys.com" target="_blank" class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #4d4d4d; color: #FFF; border-radius: 4px;"><i
class="fa fa-envelope mr-2"></i>odoo@cybrosys.com</a>
</div>
<div class="col-lg-6">
<a href="https://api.whatsapp.com/send?phone=918606827707" target="_blank"
class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #25D366; color: #FFF; border-radius: 4px;"><i
class="fa fa-whatsapp mr-2"></i>+91 86068 27707</a>
</div>
</div>
</div>
</div>
<!-- End of Contact Cards -->
</section>
<!-- Footer -->
<section class="oe_container" style="padding: 2rem 3rem 1rem;">
<div class="row" style="max-width:1540px; margin: 0 auto; margin-right: 3rem; ">
<!-- Logo -->
<div class="col-lg-12 d-flex justify-content-center align-items-center" style="margin-top: 3rem;">
<img src="https://www.cybrosys.com/images/logo.png" width="200px" height="auto" />
</div>
<!-- End of Logo -->
<div class="col-lg-12">
<hr
style="margin-top: 3rem;background: linear-gradient(90deg, rgba(2,0,36,0) 0%, rgba(229,229,229,1) 33%, rgba(229,229,229,1) 58%, rgba(0,212,255,0) 100%); height: 2px; border-style: none;">
<!-- End of Footer Section -->
</div>
</div>
</section>
<!-- END OF FOOTER -->
</div>

168
systray_world_clock/static/src/js/systray_world_clock.js

@ -0,0 +1,168 @@
/** @odoo-module **/
import core from 'web.core';
import SystrayMenu from 'web.SystrayMenu';
import Widget from 'web.Widget';
var QWeb = core.qweb;
var ClockWidget = Widget.extend({
template: 'Systray_clock',
events: {
'show.bs.dropdown': 'onClickWorldClock',
'hide.bs.dropdown': 'stopTimer',
'click .settings': 'onClickSettings'
},
/**
* Fetch data from the server to display the world clocks. Uses the RPC
* method to search and read data from the 'systray.world.clock.config'
* model with an empty domain and retrieves the 'name', 'tz', and
* 'offset' fields. The function then assigns the retrieved clock
* configurations to the ClockWidget instance's 'ClockConfigIds' property.
*
* @returns {Promise} A promise that resolves with the clock
* configurations retrieved from the server.
*/
willStart: function () {
var self = this;
return self._rpc({
model: 'systray.world.clock.config',
method: 'search_read',
domain: [],
fields: ['name', 'tz', 'offset']
}).then(function (ClockConfigs) {
self.ClockConfigIds = ClockConfigs;
});
},
/**
* This function is called when the icon is clicked on the systray menu.
* Selects the clock container from the DOM, and then renders the clock
* interface and starts the interval timer to keep the clock updated.
*/
onClickWorldClock: function (ev) {
ev.stopPropagation();
this.clocksContainer = this.el.querySelector('#clocks_container');
this.renderClock();
this.intrvl = setInterval(() => {
this.renderClock();
}, 1000);
},
// Calculating time based on the offset
calcTime: function (offset) {
const d = new Date(),
utc = d.getTime() + (d.getTimezoneOffset() * 60000);
const nd = new Date(utc + (3600000 * offset));
const options = {
year: 'numeric',
month: 'numeric',
day: 'numeric',
hour: 'numeric',
minute: 'numeric',
hour12: true
};
return [nd, nd.toLocaleString('en-US', options)];
},
// Rendering the clock interface
renderClock: function () {
var interfaceTemplate;
// checks if no clocks are displayed.
if (!this.el.querySelector('.time-info')) {
if (this.ClockConfigIds.length > 0) {
this.clocksContainer.innerHTML = '';
}
this.clockRendered = false;
}
//calculates the time for each clock and updates the
// corresponding analogue clock display and digital time information.
for (let clock of this.ClockConfigIds) {
let offsetStr = clock.offset.toString().replace('.', '_');
let currentClockClass = 'clock' + offsetStr;
if (!this.clockRendered) {
interfaceTemplate = QWeb.render("AnalogueInterface", {
currentClockClass: currentClockClass,
country: clock.name
});
}
if (interfaceTemplate) {
this.clocksContainer.innerHTML += interfaceTemplate;
}
/**
* Updates the analogue time of a clock based on its time zone
* offset and renders it on the webpage.
*
* Behavior:
*
* *Uses calcTime function to calculate the current time of the
* clock based on its time zone offset.
*
* *Calculates the angle for each of the clock hands (hour,
* minute, and second) based on the current time.
*
* *Rotates each clock hand to the calculated
* angle using CSS transform: rotate() property.
*
* *Updates the digital time of the clock in the webpage by
* setting the HTML of #digital-info element with localestring.
*
* *Checks the current time and adds/removes night-clock class
* to the clock container based on whether it is daytime or
* nighttime.
*/
this.updateAnalogueTime = function () {
const [nd, localestring] = this.calcTime(clock.offset);
var hoursArr = this.el.querySelectorAll('.' + currentClockClass + ' .hours');
var minutesArr = this.el.querySelectorAll('.' + currentClockClass + ' .minutes');
var secondsArr = this.el.querySelectorAll('.' + currentClockClass + ' .seconds');
let h = (nd.getHours() % 12) + nd.getMinutes() / 59;
let m = nd.getMinutes();
let s = nd.getSeconds();
h *= 30;
m *= 6;
s *= 6;
/**
* This function takes in a target element and a value, and
* sets the rotation style of the target element to the
* given value.
* @param target
* @param val
*/
const rotation = (target, val) => {
target.style.transform = `rotate(${val}deg)`;
};
hoursArr.forEach(hours => rotation(hours, h));
minutesArr.forEach(minutes => rotation(minutes, m));
secondsArr.forEach(seconds => rotation(seconds, s));
$('#clocks_container .' + currentClockClass + '#digital-info').html(localestring);
if (18 <= nd.getHours() || nd.getHours() < 6) {
$('#clocks_container .clock.' + currentClockClass).addClass('night-clock');
}
else {
$('#clocks_container .' + currentClockClass).removeClass('night-clock');
}
};
// to update time in the clocks_container
this.updateTime = function () {
this.updateAnalogueTime();
};
this.updateTime();
}
this.clockRendered = true;
},
/**
* Stops the interval timer that updates the clocks when the dropdown is
* hidden. It clears the interval timer using the clearInterval method.
*/
stopTimer: function () {
clearInterval(this.intrvl);
},
// opens settings
onClickSettings: function (ev) {
ev.stopPropagation();
this.do_action({
type: 'ir.actions.act_window',
name: 'Clock Settings',
res_model: 'systray.world.clock.config',
view_mode: 'list, form',
views: [[false, 'list'], [false, 'form']]
});
}
});
SystrayMenu.Items.push(ClockWidget);

129
systray_world_clock/static/src/scss/systray_world_clock.scss

@ -0,0 +1,129 @@
.systray_clock_dropdown {
padding: 2em;
width: 1100px;
.settings {
position: absolute;
color: #fff;
left: 80em;
background-color: #71639e;
border: solid #71639e;
}
}
#clocks_container {
display: flex;
justify-content: space-evenly;
flex-wrap: wrap;
.time-info {
padding: 10px 30px;
margin: 2em 0;
min-height: 50px;
border: 1px solid #dddddd;
border-radius: 10px;
background-color: transparent;
}
}
.clocks_container:not(:last-child) {
padding: 10px;
min-height: 50px;
border-bottom: 1px solid #9DA1AA;
background-color: transparent;
}
.clocks_container > p {
font-size: 20px;
}
//button
:root {
--primary-light: #8abdff;
--primary: #6d5dfc;
--primary-dark: #5b0eeb;
--white: #FFFFFF;
--greyLight-1: #E4EBF5;
--greyLight-2: #c8d0e7;
--greyLight-3: #bec8e4;
--greyDark: #9baacf;
}
$shadow: .3rem .3rem .6rem var(--greyLight-2),
-.2rem -.2rem .5rem var(--white);
$inner-shadow: inset .2rem .2rem .5rem var(--greyLight-2),
inset -.2rem -.2rem .5rem var(--white);
/* CLOCK */
.clock {
grid-column: 2 / 3;
grid-row: 1 / 3;
width: 12rem;
height: 12rem;
justify-self: center;
box-shadow: $shadow;
border-radius: 50%;
display: flex;
justify-content: center;
align-items: center;
position: relative;
.hand {
position: absolute;
transform-origin: bottom;
bottom: 6rem;
border-radius: .2rem;
z-index: 200;
}
.hours {
width: .4rem;
height: 3.2rem;
background: var(--greyLight-3);
}
.minutes {
width: .4rem;
height: 4.6rem;
background: var(--greyDark);
}
.seconds {
width: .2rem;
height: 5.2rem;
background: var(--primary);
}
.point {
position: absolute;
width: .8rem;
height: .8rem;
border-radius: 50%;
background: var(--primary);
z-index: 300;
}
.in-border {
width: 95%;
height: 95%;
border-radius: 50%;
display: flex;
position: relative;
box-shadow: $inner-shadow;
.center {
width: 60%;
height: 60%;
position: absolute;
box-shadow: inset 1px 1px 1px var(--greyLight-2),
inset -1px -1px 1px var(--white);
border-radius: 50%;
top: 20%;
left: 20%;
filter: blur(1px);
}
div.digit {
position: absolute;
inset: 1px;
text-align: center;
transform: rotate(calc(var(--i) * (360deg / 12)));
span {
display: inline-block;
font-size: 80%;
font-weight: 600;
transform: rotate(calc(var(--i) * (-360deg / 12)));
}
}
}
}
.night-clock {
background-color: black;
color: white;
}

90
systray_world_clock/static/src/xml/systray_world_clock.xml

@ -0,0 +1,90 @@
<?xml version="1.0" encoding="UTF-8" ?>
<templates>
<!-- Template for a clock icon to be displayed in the system tray. It
contains a dropdown menu that displays the world clocks. The clock
icon has a cog icon that can be clicked to access the clock settings.-->
<t t-name="Systray_clock">
<div class="o_systray_clock dropdown">
<a class="dropdown-toggle o-no-caret" data-toggle="dropdown"
aria-expanded="false" href="#" title="World Clock">
<i class="fa fa-fw fa-globe"/>
</a>
<div class="systray_clock_dropdown
dropdown-menu dropdown-menu-right"
role="menu">
<i title="Settings" class="settings fa fa-fw fa-cog"/>
<div id="clocks_container" class="container">
<div class="dropdown-item-text text-center d-flex
justify-content-center o_no_activity">
<span>No clocks configured. Please add a clock in the
settings.
</span>
</div>
</div>
</div>
</div>
</t>
<!--Template for the analogue clock interface. It displays the location,
current time and an analogue clock with hour, minute, and second
hands.-->
<t t-name="AnalogueInterface">
<div class="time-info">
<div class="d-flex flex-column align-items-center pb-3">
<span id="country-name">
<h4 t-out="country" style="text-align: center;"/>
</span>
<span id="digital-info" t-att-class="currentClockClass">
<h6 style="text-align: center"/>
</span>
</div>
<div id="analogue-info">
<div t-att-class="'ex-border clock ' + currentClockClass">
<span class="point"/>
<span class="hand hours"/>
<span class="hand minutes"/>
<span class="hand seconds"/>
<div class="in-border">
<div class="digit one" style="--i: 1">
<span>1</span>
</div>
<div class="digit two" style="--i: 2">
<span>2</span>
</div>
<div class="digit three" style="--i: 3">
<span>3</span>
</div>
<div class="digit four" style="--i: 4">
<span>4</span>
</div>
<div class="digit five" style="--i: 5">
<span>5</span>
</div>
<div class="digit six" style="--i: 6">
<span>6</span>
</div>
<div class="digit seven" style="--i: 7">
<span>7</span>
</div>
<div class="digit eight" style="--i: 8">
<span>8</span>
</div>
<div class="digit nine" style="--i: 9">
<span>9</span>
</div>
<div class="digit ten" style="--i: 10">
<span>10</span>
</div>
<div class="digit eleven" style="--i: 11">
<span>11</span>
</div>
<div class="digit twelve" style="--i: 12">
<span>12</span>
</div>
<div class="center"/>
</div>
</div>
</div>
</div>
</t>
</templates>

15
systray_world_clock/views/systray_world_clock_config_views.xml

@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- Settings tree view to manage world clock configurations -->
<record id="systray_world_clock_config_view_tree" model="ir.ui.view">
<field name="name">systray.world.clock.config.view.tree</field>
<field name="model">systray.world.clock.config</field>
<field name="arch" type="xml">
<tree editable="bottom">
<field name="name"/>
<field name="tz"/>
<field name="offset" invisible="1"/>
</tree>
</field>
</record>
</odoo>
Loading…
Cancel
Save