Browse Source

Dec 26 : [ADD] Initial Commit 'google_search_in_odoo'

pull/299/head
RisvanaCybro 1 year ago
parent
commit
c1df2a8eb6
  1. 47
      google_search_in_odoo/README.rst
  2. 22
      google_search_in_odoo/__init__.py
  3. 49
      google_search_in_odoo/__manifest__.py
  4. 6
      google_search_in_odoo/doc/RELEASE_NOTES.md
  5. 22
      google_search_in_odoo/models/__init__.py
  6. 72
      google_search_in_odoo/models/res_config_settings.py
  7. BIN
      google_search_in_odoo/static/description/assets/icons/chatgpt.png
  8. BIN
      google_search_in_odoo/static/description/assets/icons/check.png
  9. BIN
      google_search_in_odoo/static/description/assets/icons/chevron.png
  10. BIN
      google_search_in_odoo/static/description/assets/icons/close.png
  11. BIN
      google_search_in_odoo/static/description/assets/icons/cogs.png
  12. BIN
      google_search_in_odoo/static/description/assets/icons/consultation.png
  13. BIN
      google_search_in_odoo/static/description/assets/icons/ecom-black.png
  14. BIN
      google_search_in_odoo/static/description/assets/icons/education-black.png
  15. BIN
      google_search_in_odoo/static/description/assets/icons/hotel-black.png
  16. BIN
      google_search_in_odoo/static/description/assets/icons/license.png
  17. BIN
      google_search_in_odoo/static/description/assets/icons/lifebuoy.png
  18. BIN
      google_search_in_odoo/static/description/assets/icons/manufacturing-black.png
  19. BIN
      google_search_in_odoo/static/description/assets/icons/pos-black.png
  20. BIN
      google_search_in_odoo/static/description/assets/icons/puzzle.png
  21. BIN
      google_search_in_odoo/static/description/assets/icons/restaurant-black.png
  22. BIN
      google_search_in_odoo/static/description/assets/icons/service-black.png
  23. BIN
      google_search_in_odoo/static/description/assets/icons/trading-black.png
  24. BIN
      google_search_in_odoo/static/description/assets/icons/training.png
  25. BIN
      google_search_in_odoo/static/description/assets/icons/update.png
  26. BIN
      google_search_in_odoo/static/description/assets/icons/user.png
  27. BIN
      google_search_in_odoo/static/description/assets/icons/wrench.png
  28. BIN
      google_search_in_odoo/static/description/assets/misc/categories.png
  29. BIN
      google_search_in_odoo/static/description/assets/misc/check-box.png
  30. BIN
      google_search_in_odoo/static/description/assets/misc/compass.png
  31. BIN
      google_search_in_odoo/static/description/assets/misc/corporate.png
  32. BIN
      google_search_in_odoo/static/description/assets/misc/customer-support.png
  33. BIN
      google_search_in_odoo/static/description/assets/misc/cybrosys-logo.png
  34. BIN
      google_search_in_odoo/static/description/assets/misc/features.png
  35. BIN
      google_search_in_odoo/static/description/assets/misc/logo.png
  36. BIN
      google_search_in_odoo/static/description/assets/misc/pictures.png
  37. BIN
      google_search_in_odoo/static/description/assets/misc/pie-chart.png
  38. BIN
      google_search_in_odoo/static/description/assets/misc/right-arrow.png
  39. BIN
      google_search_in_odoo/static/description/assets/misc/star.png
  40. BIN
      google_search_in_odoo/static/description/assets/misc/support.png
  41. BIN
      google_search_in_odoo/static/description/assets/misc/whatsapp.png
  42. BIN
      google_search_in_odoo/static/description/assets/modules/1.png
  43. BIN
      google_search_in_odoo/static/description/assets/modules/2.png
  44. BIN
      google_search_in_odoo/static/description/assets/modules/3.png
  45. BIN
      google_search_in_odoo/static/description/assets/modules/4.png
  46. BIN
      google_search_in_odoo/static/description/assets/modules/5.png
  47. BIN
      google_search_in_odoo/static/description/assets/modules/6.png
  48. BIN
      google_search_in_odoo/static/description/assets/screenshots/1.png
  49. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_01.png
  50. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_02.png
  51. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_03.png
  52. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_04.png
  53. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_search_01.png
  54. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_search_02.png
  55. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_search_03.png
  56. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_search_04.png
  57. BIN
      google_search_in_odoo/static/description/assets/screenshots/google_search_05.png
  58. BIN
      google_search_in_odoo/static/description/assets/screenshots/hero.gif
  59. BIN
      google_search_in_odoo/static/description/assets/screenshots/search.png
  60. BIN
      google_search_in_odoo/static/description/assets/screenshots/search1.png
  61. BIN
      google_search_in_odoo/static/description/banner.jpg
  62. BIN
      google_search_in_odoo/static/description/icon.png
  63. 659
      google_search_in_odoo/static/description/index.html
  64. 75
      google_search_in_odoo/static/src/css/google_search.css
  65. 64
      google_search_in_odoo/static/src/js/google_search.js
  66. 28
      google_search_in_odoo/static/src/xml/google_search.xml
  67. 55
      google_search_in_odoo/views/res_config_settings_views.xml

47
google_search_in_odoo/README.rst

@ -0,0 +1,47 @@
.. 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
Google Search Systray
=====================
This module will helps to browse anything in Odoo itself
Installation
============
- www.odoo.com/documentation/16.0/setup/install.html
- Install our custom addon
License
-------
Lesser General Public License, Version 3 (LGPL-3).
(https://www.gnu.org/licenses/lgpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developer:
(V16) Sruthi Pavithran, Contact: odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@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
google_search_in_odoo/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Sruthi pavithran (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 models

49
google_search_in_odoo/__manifest__.py

@ -0,0 +1,49 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Sruthi pavithran (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': "Google Search Systray",
'version': '16.0.1.0.0',
'category': "Extra Tools",
'summary': """Manage to browse anything in Odoo itself""",
'description': """This module will helps to browse anything in
Odoo itself""",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': ['base', 'base_setup'],
'data': [
'views/res_config_settings_views.xml',
],
'assets': {
'web.assets_backend': [
'google_search_in_odoo/static/src/xml/google_search.xml',
'google_search_in_odoo/static/src/js/google_search.js',
'google_search_in_odoo/static/src/css/google_search.css'
],
},
'license': 'LGPL-3',
'images': ['static/description/banner.jpg'],
'installable': True,
'application': True,
'auto_install': False,
}

6
google_search_in_odoo/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <google_search_in_odoo>
#### 06.12.2023
#### Version 16.0.1.0.0
#### ADD
- Initial Commit for Google Search Systray

22
google_search_in_odoo/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: Sruthi pavithran (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_config_settings

72
google_search_in_odoo/models/res_config_settings.py

@ -0,0 +1,72 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Sruthi pavithran (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
class ResConfigSettings(models.TransientModel):
"""Add field to configuration settings"""
_inherit = 'res.config.settings'
google_search = fields.Boolean(
string='Allow the users to synchronize the google search',
config_parameter='google_search_in_odoo.enable_google_search',
help="For synchronizing the google search")
ser_client_api = fields.Char(
"API Key",
config_parameter='google_search_in_odoo.ser_client_api',
help="Google search api key")
ser_client_engine = fields.Char(
"Search Engine",
config_parameter='google_search_in_odoo.ser_client_engine',
help="Search engine ID")
@api.model
def google_search_config(self, input_data):
"""Create function to get google custom search api response"""
api_key = self.env['ir.config_parameter'].sudo().get_param(
'google_search_in_odoo.ser_client_api')
search_engine = self.env['ir.config_parameter'].sudo().get_param(
'google_search_in_odoo.ser_client_engine')
google_search = self.env['ir.config_parameter'].sudo().get_param(
'google_search_in_odoo.enable_google_search')
if not google_search:
return {
'error': 'Please Enable Google Search.'
}
else:
if not api_key and not search_engine:
return {
'error': 'Please provide API key and Search engine ID.'
}
base_url = 'https://www.googleapis.com/customsearch/v1'
params = {
'q': input_data,
'key': api_key,
'cx': search_engine,
'num': 10,
}
response = requests.get(base_url, params=params)
if response.status_code == 200:
data = response.json()
items = data.get('items', [])
return items

BIN
google_search_in_odoo/static/description/assets/icons/chatgpt.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

BIN
google_search_in_odoo/static/description/assets/icons/close.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 93 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 83 KiB

BIN
google_search_in_odoo/static/description/assets/modules/5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 82 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_01.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_02.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_03.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 216 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_04.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 134 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_search_01.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 273 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_search_02.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 162 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_search_03.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_search_04.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/google_search_05.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 263 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 290 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/search.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 113 KiB

BIN
google_search_in_odoo/static/description/assets/screenshots/search1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 112 KiB

BIN
google_search_in_odoo/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 92 KiB

BIN
google_search_in_odoo/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

659
google_search_in_odoo/static/description/index.html

@ -0,0 +1,659 @@
<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>
</div>
<!-- END OF TITLE BAR -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
Google Search Systray</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">
Manage to Browse Anything in Odoo Itself</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">
This module will help to browse anything in Odoo itself.
</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;">Available in Odoo 16.0 Community & Enterprise</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;">Access Google Search in Systray</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;">Easy to Set up API Key and Client Search Engine of Google Search</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;">You Can Simply type your Question and get Answers from Google to Odoo Interface</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;">
Google Search Integration with Odoo
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
For Generating Credentials Click the button and go to
(https://developers.google.com/custom-search/v1/overview)
Platform.</p>
<img src="assets/screenshots/search.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Click on the Get a Key option to get the Api.
<img src="assets/screenshots/google_search_01.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Create a new Project to Get the Key.</p>
<img src="assets/screenshots/google_search_02.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Create a new Project to Get the Key.</p>
<img src="assets/screenshots/google_search_02.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Click on the Programmable Search Engine Control Panel for
Getting Search Engine ID</p>
<img src="assets/screenshots/google_search_05.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Create a new Programmable Search Engine/p>
<img src="assets/screenshots/google_search_03.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Create a new Programmable Search Engine</p>
<img src="assets/screenshots/google_search_03.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
Enter the Api Credentials.</p>
<img src="assets/screenshots/search1.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
We can access Google Search from systray.</p>
<img src="assets/screenshots/google_02.png" class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
When the credentials are null and also the response null an
error popup arises.</p>
<img src="assets/screenshots/google_04.png"
class="img-thumbnail">
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">
When we're clicking on systray we can have an input interface
for entering the question and getting the response from Google
Search.</p>
<img src="assets/screenshots/google_03.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/advanced_dynamic_dashboard/"
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/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/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/agriculture_management_odoo/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/5.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/product_image_suggestion/"
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 -->
<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 -->

75
google_search_in_odoo/static/src/css/google_search.css

@ -0,0 +1,75 @@
.toggle-icon{
padding: 10px;
margin-bottom: 18px;
}
.search{
border-top-right-radius: 32px !important;
border-bottom-right-radius: 32px !important;
background-color: #fff;
}
.google{
border-top-left-radius: 32px !important;
border-bottom-left-radius: 32px !important;
background-color: #fff;
}
.input-group-prepend {
margin-right: -2px !important;
}
.input-group-append {
margin-left: -2px !important;
}
.form-control:focus {
color: #495057;
background-color: #fff;
border-color: #ced4da;
outline: 0;
box-shadow: 0 0 0 0 !important;
}
.form-control{
border-right: 0 !important;
border-left: 0 !important;
background-color: #fff;
}
.container {
position: relative;
width: 100%;
overflow: hidden;
/* 16:9 Aspect Ratio */
}
.google_result{
background-color: #fff;
width: 500px;
height: 500px;
z-index:2;
position: absolute;
margin-top:28px;
border: 4px solid black;
overflow: auto;
}
.google_result > div {
background-color: #fff;
border: 1px solid #ccc;
padding: 10px;
margin: 10px 0;
border-radius: 4px;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}
.header {
font-size: 1.5rem;
font-weight: bold;
}
.link {
color: #1a0dab;
text-decoration: underline;
}
.link:hover {
color: #0d0d0d;
}
.content {
font-size: 0.9rem;
color: #545454;
}

64
google_search_in_odoo/static/src/js/google_search.js

@ -0,0 +1,64 @@
/** @odoo-module **/
import SystrayMenu from 'web.SystrayMenu';
import Widget from 'web.Widget';
import { _t } from "@web/core/l10n/translation";
import Dialog from 'web.Dialog';
var rpc = require('web.rpc');
var GoogleSearchWidget = Widget.extend({
template: 'SearchSystray',
events: {
'keydown #search_text': '_onClick',
},
/**
* @override
*/
init: function () {
this._super.apply(this, arguments);
},
_onClick: function (event) {
// Get response from google based on the search value and display result on the template
var input = this.$el.find('#search_text')[0];
const resultsDiv = this.$el.find('.google_result')[0];
if (event.key === "Enter" && input.value.trim() !== '') {
rpc.query({
model: 'res.config.settings',
method: 'google_search_config',
args: [input.value],
}).then(result => {
if (result.error) {
Dialog.alert(this, _t(result.error));
} else if (result === null) {
Dialog.alert(this, _t('Limit exceeded for Queries and Queries per day'));
} else {
resultsDiv.innerHTML = '';
for (let i = 0; i < result.length; i++) {
const resultItem = document.createElement("div");
const titleText = document.createTextNode(result[i].title);
const titleElement = document.createElement("h2");
titleElement.classList.add("header")
titleElement.appendChild(titleText);
const linkElement = document.createElement("a");
linkElement.classList.add("link")
linkElement.href = result[i].link;
linkElement.textContent = result[i].link;
const snippetText = document.createTextNode(result[i].snippet);
const snippetElement = document.createElement("p");
snippetElement.classList.add("content")
snippetElement.appendChild(snippetText);
resultItem.appendChild(titleElement);
resultItem.appendChild(linkElement);
resultItem.appendChild(snippetElement);
resultsDiv.appendChild(resultItem);
}
resultsDiv.style.display = 'block';
}
});
} else {
resultsDiv.style.display = 'none';
}
}
});
SystrayMenu.Items.push(GoogleSearchWidget);
export default GoogleSearchWidget;

28
google_search_in_odoo/static/src/xml/google_search.xml

@ -0,0 +1,28 @@
<?xml version="1.0" encoding="UTF-8" ?>
<templates>
<!-- Template Google Search Output-->
<t t-name="SearchSystray">
<div class="toggle-icon" role="button">
<t>
<div class="input-group col-sm-7 input-group-lg"
id="google_search" style="height:2px">
<div class="input-group-prepend">
<span class="input-group-text google">
<img src="https://img.icons8.com/color/48/000000/google-logo.png"
style="height:12px;"/>
</span>
</div>
<input type="text" id="search_text" class="form-control"
style="height:23px;"/>
<div class="input-group-append">
<span class="input-group-text search">
<img src="https://img.icons8.com/nolan/48/000000/search.png"
style="height:12px;"/>
</span>
</div>
</div>
<div class="google_result" style="display: none"/>
</t>
</div>
</t>
</templates>

55
google_search_in_odoo/views/res_config_settings_views.xml

@ -0,0 +1,55 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Inherit res config settings view-->
<record id="res_config_settings_view_form" model="ir.ui.view">
<field name="name">
res.config.settings.view.form.inherit.google.search.in.odoo
</field>
<field name="model">res.config.settings</field>
<field name="inherit_id"
ref="base_setup.res_config_settings_view_form"/>
<field name="arch" type="xml">
<xpath expr="//div[@name='integration']" position="inside">
<div class="col-12 col-lg-6 o_setting_box"
id="sync_google_search_setting">
<div class="o_setting_left_pane">
<field name="google_search"/>
</div>
<div class="o_setting_right_pane">
<label string="Google Search"
for="google_search"/>
<div class="text-muted">
Synchronize your search with Google Search
</div>
<div class="content-group"
attrs="{'invisible': [('google_search','=',False)]}">
<div class="mt16 row">
<label for="ser_client_api" string="API Key"
class="col-3 col-lg-3 o_light_label"/>
<field name="ser_client_api" nolabel="1"/>
</div>
<div class="mt16 row">
<label for="ser_client_engine"
string="Client Search Engine"
class="col-3 col-lg-3 o_light_label"/>
<field name="ser_client_engine" nolabel="1"/>
</div>
<div class="content-group mt16">
<div role="alert"
class="alert alert-warning">
Create a Custom Search Api
<a role="button"
href="https://developers.google.com/custom-search/v1/overview"
class="btn btn-link btn-success o_activity_link mr8">
<i class="fa fa-arrow-right"/>
Click Here
</a>
</div>
</div>
</div>
</div>
</div>
</xpath>
</field>
</record>
</odoo>
Loading…
Cancel
Save