Browse Source

DEC 02 : [ADD] Initial Commit 'fountain_widget_many2one'

pull/295/head
Shijin V 1 year ago
parent
commit
0556955ef3
  1. 47
      fountain_widget_many2one/README.rst
  2. 21
      fountain_widget_many2one/__init__.py
  3. 53
      fountain_widget_many2one/__manifest__.py
  4. 6
      fountain_widget_many2one/doc/RELEASE_NOTES.md
  5. BIN
      fountain_widget_many2one/static/description/assets/icons/check.png
  6. BIN
      fountain_widget_many2one/static/description/assets/icons/chevron.png
  7. BIN
      fountain_widget_many2one/static/description/assets/icons/cogs.png
  8. BIN
      fountain_widget_many2one/static/description/assets/icons/consultation.png
  9. BIN
      fountain_widget_many2one/static/description/assets/icons/ecom-black.png
  10. BIN
      fountain_widget_many2one/static/description/assets/icons/education-black.png
  11. BIN
      fountain_widget_many2one/static/description/assets/icons/hotel-black.png
  12. BIN
      fountain_widget_many2one/static/description/assets/icons/license.png
  13. BIN
      fountain_widget_many2one/static/description/assets/icons/lifebuoy.png
  14. BIN
      fountain_widget_many2one/static/description/assets/icons/manufacturing-black.png
  15. BIN
      fountain_widget_many2one/static/description/assets/icons/pos-black.png
  16. BIN
      fountain_widget_many2one/static/description/assets/icons/puzzle.png
  17. BIN
      fountain_widget_many2one/static/description/assets/icons/restaurant-black.png
  18. BIN
      fountain_widget_many2one/static/description/assets/icons/service-black.png
  19. BIN
      fountain_widget_many2one/static/description/assets/icons/trading-black.png
  20. BIN
      fountain_widget_many2one/static/description/assets/icons/training.png
  21. BIN
      fountain_widget_many2one/static/description/assets/icons/update.png
  22. BIN
      fountain_widget_many2one/static/description/assets/icons/user.png
  23. BIN
      fountain_widget_many2one/static/description/assets/icons/wrench.png
  24. BIN
      fountain_widget_many2one/static/description/assets/misc/categories.png
  25. BIN
      fountain_widget_many2one/static/description/assets/misc/check-box.png
  26. BIN
      fountain_widget_many2one/static/description/assets/misc/compass.png
  27. BIN
      fountain_widget_many2one/static/description/assets/misc/corporate.png
  28. BIN
      fountain_widget_many2one/static/description/assets/misc/customer-support.png
  29. BIN
      fountain_widget_many2one/static/description/assets/misc/cybrosys-logo.png
  30. BIN
      fountain_widget_many2one/static/description/assets/misc/features.png
  31. BIN
      fountain_widget_many2one/static/description/assets/misc/logo.png
  32. BIN
      fountain_widget_many2one/static/description/assets/misc/pictures.png
  33. BIN
      fountain_widget_many2one/static/description/assets/misc/pie-chart.png
  34. BIN
      fountain_widget_many2one/static/description/assets/misc/right-arrow.png
  35. BIN
      fountain_widget_many2one/static/description/assets/misc/star.png
  36. BIN
      fountain_widget_many2one/static/description/assets/misc/support.png
  37. BIN
      fountain_widget_many2one/static/description/assets/misc/whatsapp.png
  38. BIN
      fountain_widget_many2one/static/description/assets/modules/1.png
  39. BIN
      fountain_widget_many2one/static/description/assets/modules/2.png
  40. BIN
      fountain_widget_many2one/static/description/assets/modules/3.png
  41. BIN
      fountain_widget_many2one/static/description/assets/modules/4.png
  42. BIN
      fountain_widget_many2one/static/description/assets/modules/5.png
  43. BIN
      fountain_widget_many2one/static/description/assets/modules/6.jpg
  44. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot1.png
  45. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot2.png
  46. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot3.png
  47. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot4.png
  48. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot5.png
  49. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot6.png
  50. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot7.png
  51. BIN
      fountain_widget_many2one/static/description/assets/screenshots/screenshot8.png
  52. BIN
      fountain_widget_many2one/static/description/assets/screenshots/v16-hero.gif
  53. BIN
      fountain_widget_many2one/static/description/banner.png
  54. BIN
      fountain_widget_many2one/static/description/icon.png
  55. 719
      fountain_widget_many2one/static/description/index.html
  56. 11
      fountain_widget_many2one/static/src/css/fountain_widget_many2one.css
  57. 8
      fountain_widget_many2one/static/src/css/fountain_widget_many2one.scss
  58. 9
      fountain_widget_many2one/static/src/js/fountain_widget_component.js
  59. 67
      fountain_widget_many2one/static/src/js/fountain_widget_many2one.js
  60. 38
      fountain_widget_many2one/static/src/xml/fountain_widget_component.xml
  61. 41
      fountain_widget_many2one/static/src/xml/fountain_widget_many2one.xml

47
fountain_widget_many2one/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
Fountain Widget
===============
* This module introduce a new widget that is used to select the many2one field in fountain manner.
Configuration
=============
No additional configurations needed.
License
-------
Lesser General Public License, Version 3 (LGPL v3).
(https://www.gnu.org/licenses/lgpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
Developer: (V16) Anusha C ,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 https://www.cybrosys.com
Further information
===================
HTML Description: `<static/description/index.html>`__

21
fountain_widget_many2one/__init__.py

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

53
fountain_widget_many2one/__manifest__.py

@ -0,0 +1,53 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Anusha C (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": "Fountain Widget",
"version": "16.0.1.0.0",
"category": 'Extra Tools',
"summary": "This widget is used to select the many2one field in fountain "
"manner.",
"description": "This is a widget for many2one fields. By using this "
"widget we can select record in a fountain manner. It "
"generates dynamic dropdown menus with hierarchical options "
"and thus Supports parent-child relationships between "
"dropdown options.",
"author": "Cybrosys Techno Solutions",
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': 'https://www.cybrosys.com',
"depends": ['base'],
'assets': {
'web.assets_backend': [
'fountain_widget_many2one/static/src/js/fountain_widget_many2one.js',
'fountain_widget_many2one/static/src/xml/fountain_widget_many2one.xml',
'fountain_widget_many2one/static/src/css/fountain_widget_many2one.css',
'fountain_widget_many2one/static/src/css/fountain_widget_many2one.scss',
'fountain_widget_many2one/static/src/xml/fountain_widget_component.xml',
'fountain_widget_many2one/static/src/js/fountain_widget_component.js',
],
},
'images': ['static/description/banner.png'],
'license': 'LGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

6
fountain_widget_many2one/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <fountain_widget_many2one>
#### 02.12.2023
#### Version 16.0.1.0.0
##### ADD
- Initial Commit for Fountain Widget

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 65 KiB

BIN
fountain_widget_many2one/static/description/assets/modules/6.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 93 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 180 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 276 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 162 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 165 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 168 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 174 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot7.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 176 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/screenshot8.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 166 KiB

BIN
fountain_widget_many2one/static/description/assets/screenshots/v16-hero.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 MiB

BIN
fountain_widget_many2one/static/description/banner.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 68 KiB

BIN
fountain_widget_many2one/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

719
fountain_widget_many2one/static/description/index.html

@ -0,0 +1,719 @@
<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: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div
style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
<!-- END OF TITLE BAR -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<!-- APP HERO -->
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
Fountain Widget</h1>
<p
style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">
This Widget is Used to Select the Many2one Field in Fountain
Manner.</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/v16-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 is a widget for many2one fields having parent and child relation. By using this widget we can select
record in fountain manner.
</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: 40px; margin-bottom: 40px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Community, Odoo.sh &amp;
Enterprise Support.</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;"> Generates dynamic dropdown menus with hierarchical options.</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;"> Provides an interactive user interface for selecting options.</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;">Supports saving selected data to the database.</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;"> Fetches data from the backend in real-time.</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;">Organizes options in a hierarchical structure.</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;">Supports parent-child relationships between dropdown options.</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;">
The provided screenshot displays a standard Many2One field for
product category in Odoo.
</h3>
<img src="assets/screenshots/screenshot1.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Add 'widget="fountain_widget"' to the view of Many2One field,
you can do so either through the user interface (UI) or via
code. Here's how to achieve it through the UI, by
editing the form view.
</h3>
<img src="assets/screenshots/screenshot2.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
After adding the widget to the Many2One field in Odoo, you will
have a new custom dropdown functionality to display hierarchical
data.
</h3>
<img src="assets/screenshots/screenshot3.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
When you click on the field, the parent records will be
displayed first in the dropdown.
</h3>
<img src="assets/screenshots/screenshot4.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
An arrow icon indicates records that have child records.
Clicking on that record will open a dropdown containing its
child records.</h3>
<img src="assets/screenshots/screenshot5.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
The hierarchical structure continues for records with child
records, with each click opening another dropdown for the child
records, maintaining the hierarchy.</h3>
<img src="assets/screenshots/screenshot6.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
In addition to clicking, the field's value also updates
according to the selected record. Finally, you can save the record with the selected values in the
Many2One field.</h3>
<img src="assets/screenshots/screenshot7.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
After saving, you will see the updated value in the Many2One
field.
</h3>
<img src="assets/screenshots/screenshot8.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/field_timepicker/"
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/one2many_mass_select_delete/#"
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/one2many_search_widget/#"
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/model_viewer_widget/#"
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/widget_preview_image/#"
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/image_capture_upload_widget/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/6.jpg">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev"
style="width:35px; color:#000"> <span
class="carousel-control-prev-icon"><i
class="fa fa-chevron-left"
style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1"
data-slide="next" style="width:35px; color:#000">
<span class="carousel-control-next-icon"><i
class="fa fa-chevron-right"
style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF RELATED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our Services
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</div>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our
Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/trading-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/pos-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/education-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/manufacturing-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/ecom-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/service-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/restaurant-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/hotel-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</div>
<!-- END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/support.png" height="48" width="48"
style="width: 42px; height: 42px;"/>
</div>
<div>
<h4>Need Help?</h4>
<p style="line-height: 100%;">Got questions or need help?
Get in touch.</p>
<a href="mailto:odoo@cybrosys.com">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
odoo@cybrosys.com</p>
</a>
</div>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/whatsapp.png" height="52" width="52"
style="width: 52px; height: 52px;"/>
</div>
<div>
<h4>WhatsApp</h4>
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p>
<a href="https://api.whatsapp.com/send?phone=918606827707">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
+91 86068
27707</p>
</a>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center">
<img src="assets/misc/logo.png" width="144" height="31"
style="width:144px; height: 31px; margin-top: 40px;"/>
</div>
</div>
</div>
<!-- END OF SUPPORT -->

11
fountain_widget_many2one/static/src/css/fountain_widget_many2one.css

@ -0,0 +1,11 @@
.divMargin{
margin-right: 11px;
border-right: 1px solid black;
padding-right: 10px;
}
.dropdown-item-text {
display: block;
padding: 3px 20px;
color: #495057;
position: relative;
}

8
fountain_widget_many2one/static/src/css/fountain_widget_many2one.scss

@ -0,0 +1,8 @@
.icon_style{
&::after{
content: "\f061";
font-family: 'FontAwesome';
position: absolute;
right: 0px;
}
}

9
fountain_widget_many2one/static/src/js/fountain_widget_component.js

@ -0,0 +1,9 @@
/** @odoo-module **/
import { Dropdown } from "@web/core/dropdown/dropdown";
//Extending the Dropdown and adding the inputData into the props
export class FountainDropdown extends Dropdown { }
FountainDropdown.template = "fountain.Dropdown"
FountainDropdown.props = {
...Dropdown.props,
inputData: { type: Object, optional: true }
}

67
fountain_widget_many2one/static/src/js/fountain_widget_many2one.js

@ -0,0 +1,67 @@
/** @odoo-module **/
import { Component, useState, useEffect, onWillStart } from "@odoo/owl";
import { registry } from "@web/core/registry";
import { standardFieldProps } from "@web/views/fields/standard_field_props";
import { Dropdown } from "@web/core/dropdown/dropdown";
import { DropdownItem } from "@web/core/dropdown/dropdown_item";
import { FountainDropdown } from "./fountain_widget_component"
import { useService } from '@web/core/utils/hooks';
export class FountainWidget extends Component {
//Extending component and creating a new widget
setup() {
this.orm = useService('orm');
useEffect(() => { this.state.inputData = this.props.record.data[this.props.name] }, () => [this.props])
this.state = useState({
childMenu: {},
inputData: this.props.record.data[this.props.name]
});
onWillStart(async () => {
this.state.category = await this.orm.searchRead(this.props.record.fields[this.props.id].relation, []);
});
this.index = 0
}
// Function for returning the data to be inserted in the input
get inputData() {
return {
input: this.state.inputData[1]
}
}
// Function to get parent records
get parentMenu() {
return this.state.category.filter(item => !item.parent_id)
}
// Function to get child records
get childKeys() {
return Object.keys(this.state.childMenu)
}
// Click function of the options
onClickDropDown(parent_id, index = 0) {
if (this.index >= index) {
let childLength = this.childKeys.length
while (index < childLength) {
const keyIndex = this.childKeys[index]
delete this.state.childMenu[keyIndex]
childLength--
}
}
let obj = this.state.category.filter(item => item.parent_id[0] === parent_id)
if (!this.state.childMenu.hasOwnProperty(parent_id) && obj.length > 0) {
this.state.childMenu[parent_id] = obj
this.index = index;
}
this.props.update([parent_id])
return obj
}
}
FountainWidget.template = 'FountainWidgetField';
FountainWidget.components = {
Dropdown,
DropdownItem,
FountainDropdown,
};
FountainWidget.props = {
...standardFieldProps,
};
FountainWidget.supportedTypes = ["many2one"];
registry.category("fields").add("fountain_widget", FountainWidget);

38
fountain_widget_many2one/static/src/xml/fountain_widget_component.xml

@ -0,0 +1,38 @@
<?xml version="1.0" encoding="UTF-8" ?>
<templates xml:space="preserve">
<!--Changing the button into an input-->
<t t-name="fountain.Dropdown" owl="1">
<div class="o-dropdown dropdown"
t-att-class="props.class"
t-attf-class="
{{ directionCaretClass || ''}}
{{ state.open ? 'show' : ''}}
{{ !showCaret ? 'o-dropdown--no-caret' : '' }}"
t-ref="root">
<input style="width:100%;"
class="dropdown-toggle o_input"
t-attf-class="
{{props.togglerClass || ''}}
{{parentDropdown ? 'dropdown-item' : ''}}"
t-on-click.stop="onTogglerClick"
t-on-mouseenter="onTogglerMouseEnter"
t-att-title="props.title"
t-att-data-hotkey="props.hotkey"
t-att-data-tooltip="props.tooltip"
t-att-tabindex="props.skipTogglerTabbing ? -1 : 0"
t-att-aria-expanded="state.open ? 'true' : 'false'"
t-att-value="props.inputData.input"
t-ref="togglerRef">
<t t-slot="toggler"/>
</input>
<div t-if="state.open"
class="o-dropdown--menu dropdown-menu d-block"
t-att-class="props.menuClass"
role="menu"
t-ref="menuRef"
style="min-width: unset;">
<t t-slot="default"/>
</div>
</div>
</t>
</templates>

41
fountain_widget_many2one/static/src/xml/fountain_widget_many2one.xml

@ -0,0 +1,41 @@
<?xml version="1.0" encoding="utf-8"?>
<templates>
<t t-name="FountainWidgetField" owl="1">
<!-- Template containing the dropdown component-->
<FountainDropdown inputData="inputData">
<div style="display: flex;">
<div class="divMargin">
<t t-foreach="parentMenu" t-as="category"
t-key="category.id">
<t t-if="category.child_id.length > 0">
<t t-set="parent_class" t-value="'icon_style'"/>
</t>
<option class="dropdown-item-text"
t-on-click.stop.prevent="() => this.onClickDropDown(category.id)"
t-attf-class="#{parent_class}">
<t t-esc="category.name"/>
</option>
<li class="dropdown-divider" role="separator"/>
</t>
</div>
<div t-foreach="childKeys" t-as="cKeys"
t-key="cKeys" class="divMargin">
<t t-foreach="state.childMenu[cKeys]" t-as="child"
t-key="child.id">
<t t-log="child.child_id.length"/>
<t t-if="child.child_id.length > 0">
<t t-set="child_class" t-value="'icon_style'"/>
</t>
<option class="dropdown-item-text"
t-on-click.stop.prevent="() => this.onClickDropDown(child.id, cKeys_index +1)"
t-attf-class="#{child_class}">
<t t-esc="child.name"/>
</option>
<t t-set="child_class" t-value=""/>
<li class="dropdown-divider" role="separator"/>
</t>
</div>
</div>
</FountainDropdown>
</t>
</templates>
Loading…
Cancel
Save