@ -0,0 +1,48 @@ |
|||
.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg |
|||
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html |
|||
:alt: License: AGPL-3 |
|||
|
|||
POS Booking Order |
|||
================= |
|||
The module helps you to book orders from Shop,Bar/Restaurant in POS.User can create pickup or delivery orders,later confirm booked orders to POS orders |
|||
|
|||
Configuration |
|||
============= |
|||
No additional configuration required |
|||
|
|||
Company |
|||
------- |
|||
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__ |
|||
|
|||
License |
|||
------- |
|||
GNU Affero General Public License v3.0 (AGPL v3) |
|||
(http://www.gnu.org/licenses/agpl-3.0-standalone.html) |
|||
|
|||
Credits |
|||
------- |
|||
Developer: (v17) Ranjith R @cybrosys |
|||
(v12) Varsha Vivek @cybrosys |
|||
|
|||
Contacts |
|||
-------- |
|||
* Mail Contact : odoo@cybrosys.com |
|||
* Website : https://cybrosys.com |
|||
|
|||
Bug Tracker |
|||
----------- |
|||
Bugs are tracked on GitHub Issues. In case of trouble, please check there if |
|||
your issue has already been reported. |
|||
|
|||
Maintainer |
|||
========== |
|||
.. image:: https://cybrosys.com/images/logo.png |
|||
:target: https://cybrosys.com |
|||
|
|||
This module is maintained by Cybrosys Technologies. |
|||
|
|||
For support and more information, please visit `Our Website <https://cybrosys.com/>`__ |
|||
|
|||
Further information |
|||
=================== |
|||
HTML Description: `<static/description/index.html>`__ |
@ -0,0 +1,22 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from . import models |
@ -0,0 +1,60 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
{ |
|||
'name': 'POS Booking Order', |
|||
'version': '17.0.1.0.0', |
|||
'category': 'Point of Sale', |
|||
'summary': """From a POS session, users can create pickup or |
|||
delivery orders, which they can then confirm as POS orders.""", |
|||
'description': """The module helps you to book orders from Shop, |
|||
Bar/Restaurant in POS.User can create pickup or delivery |
|||
orders,later confirm booked orders to POS orders.""", |
|||
'author': 'Cybrosys Techno Solutions', |
|||
'company': 'Cybrosys Techno Solutions', |
|||
'maintainer': 'Cybrosys Techno Solutions', |
|||
'website': "https://www.cybrosys.com", |
|||
'depends': ['base', 'point_of_sale'], |
|||
'data': ['security/ir.model.access.csv', |
|||
'data/ir_sequence_data.xml', |
|||
'views/pos_config_views.xml', |
|||
'views/book_order_views.xml', |
|||
'views/pos_order_views.xml' |
|||
], |
|||
'assets': { |
|||
'point_of_sale._assets_pos': [ |
|||
'pos_book_order/static/src/xml/Buttons.xml', |
|||
'pos_book_order/static/src/xml/BookOrderPopup.xml', |
|||
'pos_book_order/static/src/xml/BookedOrdersScreen.xml', |
|||
'pos_book_order/static/src/xml/OrderReceipt.xml', |
|||
'pos_book_order/static/src/js/BookOrderPopup.js', |
|||
'pos_book_order/static/src/js/BookOrderButton.js', |
|||
'pos_book_order/static/src/js/BookedOrdersButton.js', |
|||
'pos_book_order/static/src/js/BookedOrdersScreen.js', |
|||
'pos_book_order/static/src/js/models.js', |
|||
], |
|||
}, |
|||
'images': ['static/description/banner.png'], |
|||
'license': 'AGPL-3', |
|||
'installable': True, |
|||
'auto_install': False, |
|||
'application': False, |
|||
} |
@ -0,0 +1,11 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<odoo> |
|||
<!--This record for adding sequence to book.order--> |
|||
<record id="sequence_book_order" model="ir.sequence"> |
|||
<field name="name">Book Order</field> |
|||
<field name="code">book.order</field> |
|||
<field name="prefix">POS/BO/</field> |
|||
<field name="padding">4</field> |
|||
<field name="company_id" eval="False"/> |
|||
</record> |
|||
</odoo> |
@ -0,0 +1,7 @@ |
|||
## Module <pos_book_order> |
|||
|
|||
#### 11.01.2024 |
|||
#### Version 17.0.1.0.0 |
|||
##### ADD |
|||
- Initial Commit for POS Booking Order |
|||
|
@ -0,0 +1,25 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from . import book_order |
|||
from . import book_order_line |
|||
from . import pos_config |
|||
from . import pos_order |
@ -0,0 +1,192 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from odoo import api, fields, models |
|||
from odoo.fields import Command |
|||
|
|||
|
|||
class BookOrder(models.Model): |
|||
""" |
|||
Model for managing booked orders in the POS system. |
|||
""" |
|||
_name = 'book.order' |
|||
_description = "Point of Sale Booked Orders" |
|||
|
|||
@api.model |
|||
def _amount_line_tax(self, line, fiscal_position_id): |
|||
""" Calculates the tax amount of the order line. |
|||
:param line: Order line record |
|||
:param fiscal_position_id: Fiscal position account for order |
|||
:return float: Total tax amount as float |
|||
""" |
|||
taxes = line.tax_ids.filtered( |
|||
lambda t: t.company_id.id == line.order_id.company_id.id) |
|||
taxes = fiscal_position_id.map_tax(taxes) |
|||
price = line.price_unit * (1 - (line.discount or 0.0) / 100.0) |
|||
taxes = taxes.compute_all(price, |
|||
line.order_id.pricelist_id.currency_id, |
|||
line.qty, product=line.product_id, |
|||
partner=line.order_id.partner_id or False)[ |
|||
'taxes'] |
|||
return sum(tax.get('amount', 0.0) for tax in taxes) |
|||
|
|||
name = fields.Char(string='Booking Ref', readonly=True, |
|||
help="Name of the booked order", |
|||
copy=False, default='/') |
|||
company_id = fields.Many2one('res.company', string='Company', |
|||
help="Company of the booked order", |
|||
default=lambda self: self.env.user.company_id) |
|||
date_quotation = fields.Datetime(string='Quotation Date', |
|||
help="Quotation created date", |
|||
readonly=True, index=True, |
|||
default=fields.Datetime.now) |
|||
date_order = fields.Date(string='Order Date', help="Order created date", |
|||
readonly=True, index=True, |
|||
default=fields.Date.today()) |
|||
amount_tax = fields.Float(compute='_compute_amount_all', string='Taxes', |
|||
help="Tax amount for the order", |
|||
dig06its=0, default=1.2) |
|||
amount_total = fields.Float(compute='_compute_amount_all', string='Total', |
|||
help="Total amount of the order", |
|||
digits=0) |
|||
book_line_ids = fields.One2many('book.order.line', |
|||
'order_id', |
|||
help="Order Line of book orders", |
|||
string='Order Lines', |
|||
copy=True) |
|||
partner_id = fields.Many2one('res.partner', string='Customer', |
|||
help="Partner of the order", |
|||
change_default=True, index=True) |
|||
state = fields.Selection([('draft', 'New'), |
|||
('confirmed', 'Confirmed')], |
|||
string='Status', readonly=True, copy=False, |
|||
help="Current status of the order", |
|||
default='draft') |
|||
note = fields.Text(string='Internal Notes', |
|||
help="Enter any notes regarding order") |
|||
fiscal_position_id = fields.Many2one('account.fiscal.position', |
|||
help="Fiscal position account " |
|||
"for order", |
|||
string='Fiscal Position') |
|||
pickup_date = fields.Datetime(string='Pickup Date', readonly=True, |
|||
help="Picking date of the order") |
|||
deliver_date = fields.Datetime(string='Deliver Date', readonly=True, |
|||
help="Delivering date of the order") |
|||
phone = fields.Char('Contact no', help='Phone of customer for delivery') |
|||
delivery_address = fields.Char(string='Delivery Address', |
|||
help='Address of customer for delivery') |
|||
pricelist_id = fields.Many2one('product.pricelist', |
|||
string='Pricelist', |
|||
help="Pricelist of the order") |
|||
|
|||
@api.depends('book_line_ids.price_subtotal_incl', |
|||
'book_line_ids.discount') |
|||
def _compute_amount_all(self): |
|||
""" To compute total amount with tax and without tax """ |
|||
for order in self: |
|||
order.amount_tax = 0.0 |
|||
currency = self.env.company.currency_id |
|||
order.amount_tax = currency.round( |
|||
sum(self._amount_line_tax(line, order.fiscal_position_id) for |
|||
line in order.book_line_ids)) |
|||
amount_untaxed = currency.round( |
|||
sum(line.price_subtotal for line in order.book_line_ids)) |
|||
order.amount_total = order.amount_tax + amount_untaxed |
|||
|
|||
@api.model |
|||
def create(self, vals): |
|||
""" Inherited create function to generate sequence number |
|||
for booker orders |
|||
:return record: created record |
|||
""" |
|||
if vals.get('name', '/') == '/': |
|||
vals['name'] = self.env['ir.sequence'].next_by_code( |
|||
'book.order') or '/' |
|||
return super(BookOrder, self).create(vals) |
|||
|
|||
def action_confirm(self): |
|||
""" Function to confirm the book order""" |
|||
self.write({ |
|||
'state': 'confirmed', |
|||
}) |
|||
|
|||
@api.model |
|||
def create_booked_order(self, partner, phone, address, date, price_list, |
|||
product, note, pickup_date, delivery_date): |
|||
""" It creates a booked order based on the value in the booking popup |
|||
in PoS ui. |
|||
partner(int): id of partner |
|||
phone(string): contact number of customer |
|||
address(string): contact address of the customer |
|||
date(date): ordered date |
|||
price_list(int): price list id of order |
|||
product(dict): dictionary values with product ids and quantity |
|||
note(string): Order note |
|||
pickup(date): pickup date of the booked order |
|||
delivery(date): delivery date of the booked order |
|||
""" |
|||
order = self.create({ |
|||
'partner_id': partner, |
|||
'phone': phone, |
|||
'delivery_address': address, |
|||
'pricelist_id': price_list if price_list else False, |
|||
'date_quotation': fields.Date.today(), |
|||
'book_line_ids': [Command.create({ |
|||
'product_id': product['product_id'][i], |
|||
'qty': product['qty'][i], |
|||
'price_unit': product['price'][i], |
|||
}) for i in range(len(product['product_id']))], |
|||
'note': note, |
|||
}) |
|||
if pickup_date: |
|||
order.write({'pickup_date': pickup_date + ' 00:00:00'}) |
|||
if delivery_date: |
|||
order.write({'deliver_date': delivery_date + ' 00:00:00'}) |
|||
|
|||
@api.model |
|||
def all_orders(self): |
|||
""" To fetch all draft stage orders to PoS Booked orders screen |
|||
:return dict: A list of dictionaries containing information |
|||
about each order |
|||
""" |
|||
values = [] |
|||
for rec in self.search([('state', '=', 'draft')]): |
|||
products = [] |
|||
for line in rec.book_line_ids: |
|||
products.append({ |
|||
'id': line.product_id.id, |
|||
'qty': line.qty, |
|||
'price': line.price_unit |
|||
}) |
|||
values.append({'id': rec.id, |
|||
'name': rec.name, |
|||
'partner_id': rec.partner_id.id, |
|||
'partner_name': rec.partner_id.name, |
|||
'address': rec.delivery_address, |
|||
'note': rec.note, |
|||
'phone': rec.phone, |
|||
'date': rec.date_quotation, |
|||
'pickup': rec.pickup_date, |
|||
'deliver': rec.deliver_date, |
|||
'products': products, |
|||
'total': rec.amount_total |
|||
}) |
|||
return values |
@ -0,0 +1,86 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from odoo import api, fields, models |
|||
|
|||
|
|||
class BookOrderLine(models.Model): |
|||
""" For managing order lines of booked order """ |
|||
_name = "book.order.line" |
|||
_description = "Lines of Point of Sale Booked Order" |
|||
_rec_name = "product_id" |
|||
|
|||
company_id = fields.Many2one('res.company', string='Company', |
|||
help="Company of the booked order", |
|||
default=lambda self: self.env.user.company_id) |
|||
product_id = fields.Many2one('product.product', |
|||
help="Select products for ordering", |
|||
string='Product', |
|||
domain=[('sale_ok', '=', True)], |
|||
required=True, change_default=True) |
|||
price_unit = fields.Float(string='Unit Price', |
|||
help="Unite price of selected product", digits=0) |
|||
qty = fields.Float(string='Quantity', default=1, |
|||
help="Enter how much quantity of product want ") |
|||
price_subtotal = fields.Float(compute='_compute_amount_line_all', |
|||
digits=0, |
|||
help="Sub total amount of each order line" |
|||
"without tax", |
|||
string='Subtotal w/o Tax') |
|||
price_subtotal_incl = fields.Float(compute='_compute_amount_line_all', |
|||
digits=0, string='Subtotal', |
|||
help="Sub total amount of each order " |
|||
"line with tax") |
|||
discount = fields.Float(string='Discount (%)', digits=0, default=0.0, |
|||
help="You can apply discount for each product") |
|||
order_id = fields.Many2one('book.order', string='Order Ref', |
|||
help="Relation to book order field", |
|||
ondelete='cascade') |
|||
tax_ids = fields.Many2many('account.tax', string='Taxes', |
|||
readonly=True, help="Taxes for each line") |
|||
tax_after_fiscal_position_ids = fields.Many2many( |
|||
'account.tax', 'account_tax_rel', 'uid', |
|||
'tag_id', string='Taxes', help="Fiscal position after entering " |
|||
"the tax") |
|||
|
|||
@api.depends('price_unit', 'tax_ids', 'qty', 'discount', 'product_id') |
|||
def _compute_amount_line_all(self): |
|||
""" To compute tax included and excluded subtotal in each line""" |
|||
for line in self: |
|||
currency = self.env.company.currency_id |
|||
taxes = line.tax_ids.filtered( |
|||
lambda tax: tax.company_id.id == line.order_id.company_id.id) |
|||
fiscal_position_id = line.order_id.fiscal_position_id |
|||
if fiscal_position_id: |
|||
taxes = fiscal_position_id.map_tax(taxes, line.product_id, |
|||
line.order_id.partner_id) |
|||
price = line.price_unit * (1 - (line.discount or 0.0) / 100.0) |
|||
line.price_subtotal = line.price_subtotal_incl = price * line.qty |
|||
if taxes: |
|||
taxes = taxes.compute_all(price, currency, line.qty, |
|||
product=line.product_id, |
|||
partner=line.order_id.partner_i or |
|||
False) |
|||
line.price_subtotal = taxes['total_excluded'] |
|||
line.price_subtotal_incl = taxes['total_included'] |
|||
|
|||
line.price_subtotal = currency.round(line.price_subtotal) |
|||
line.price_subtotal_incl = currency.round(line.price_subtotal_incl) |
@ -0,0 +1,30 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class PosConfig(models.Model): |
|||
"""POS configuration settings""" |
|||
_inherit = 'pos.config' |
|||
|
|||
enable = fields.Boolean(string="Enable Book Orders", |
|||
help="Enable if you want to book order from pos") |
@ -0,0 +1,46 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Ranjith R (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from odoo import api, fields, models |
|||
|
|||
|
|||
class PosOrder(models.Model): |
|||
"""Inherited model for pos order,all confirmed booking orders are converted |
|||
as pos orders""" |
|||
_inherit = 'pos.order' |
|||
|
|||
booking_ref_id = fields.Many2one( |
|||
'book.order', string='Booking Ref', |
|||
help="Booked order reference for the pos order") |
|||
|
|||
@api.model |
|||
def _order_fields(self, ui_order): |
|||
"""Overriding to pass value of booked order ref to PoS order |
|||
ui_order(dict): dictionary of pos order field values |
|||
dict: returns dictionary of pos order field values |
|||
""" |
|||
order_fields = super(PosOrder, self)._order_fields(ui_order) |
|||
if ui_order.get('is_booked'): |
|||
order_fields['booking_ref_id'] = ui_order.get('booked_data')['id'] |
|||
self.env['book.order'].browse( |
|||
ui_order.get('booked_data')['id']).write( |
|||
{'state': 'confirmed'}) |
|||
return order_fields |
|
After Width: | Height: | Size: 36 KiB |
After Width: | Height: | Size: 3.6 KiB |
After Width: | Height: | Size: 310 B |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 576 B |
After Width: | Height: | Size: 733 B |
After Width: | Height: | Size: 911 B |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 673 B |
After Width: | Height: | Size: 11 KiB |
After Width: | Height: | Size: 878 B |
After Width: | Height: | Size: 653 B |
After Width: | Height: | Size: 905 B |
After Width: | Height: | Size: 839 B |
After Width: | Height: | Size: 427 B |
After Width: | Height: | Size: 627 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 988 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 80 KiB |
After Width: | Height: | Size: 3.2 KiB |
After Width: | Height: | Size: 565 B |
After Width: | Height: | Size: 26 KiB |
After Width: | Height: | Size: 43 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 4.0 KiB |
After Width: | Height: | Size: 38 KiB |
After Width: | Height: | Size: 4.3 KiB |
After Width: | Height: | Size: 87 KiB |
After Width: | Height: | Size: 80 KiB |
After Width: | Height: | Size: 95 KiB |
After Width: | Height: | Size: 78 KiB |
After Width: | Height: | Size: 164 KiB |
After Width: | Height: | Size: 81 KiB |
After Width: | Height: | Size: 78 KiB |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 81 KiB |
After Width: | Height: | Size: 85 KiB |
After Width: | Height: | Size: 85 KiB |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 118 KiB |
After Width: | Height: | Size: 120 KiB |
After Width: | Height: | Size: 193 KiB |
After Width: | Height: | Size: 200 KiB |
After Width: | Height: | Size: 211 KiB |
After Width: | Height: | Size: 68 KiB |
After Width: | Height: | Size: 206 KiB |
After Width: | Height: | Size: 125 KiB |
After Width: | Height: | Size: 134 KiB |
After Width: | Height: | Size: 95 KiB |
After Width: | Height: | Size: 327 KiB |
After Width: | Height: | Size: 44 KiB |
After Width: | Height: | Size: 12 KiB |
@ -0,0 +1,691 @@ |
|||
<!DOCTYPE html> |
|||
<html lang="en"> |
|||
|
|||
<head> |
|||
<meta charset="UTF-8"> |
|||
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
|||
<title>Odoo App 3 Index</title> |
|||
<!-- Bootstrap CSS --> |
|||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/css/bootstrap.min.css" |
|||
integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous"> |
|||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.1/css/all.min.css"> |
|||
<link rel="preconnect" href="https://fonts.googleapis.com"> |
|||
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> |
|||
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap" rel="stylesheet"> |
|||
</head> |
|||
<body> |
|||
<section> |
|||
<div class="container" style="font-family: 'Inter', sans-serif !important;background-color: #fff !important;"> |
|||
<div class="row"> |
|||
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between flex-wrap align-items-sm-center" |
|||
style="border-bottom:1px solid rgba(0, 0, 0, 0.22)"> |
|||
<div class="my-3"> |
|||
<img src="assets/misc/Cybrosys R.png" style="width:auto !important; height:40px !important"> |
|||
</div> |
|||
<div class="my-3 d-flex align-items-center"> |
|||
<div class="text-center" |
|||
style="background-color:#017E84 !important;font-size: 0.8rem !important; color:#fff !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;"> |
|||
Community |
|||
</div> |
|||
<div class="text-center" |
|||
style="background-color:#875A7B !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important;min-width: 120px !important;"> |
|||
Enterprise |
|||
</div> |
|||
<div class="text-center" |
|||
style="background-color:#7C7BAD !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;"> |
|||
Odoo.sh |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="row"> |
|||
<div class="col-sm-12 col-md-12 col-lg-12 text-center d-flex align-items-center flex-column" |
|||
style="margin: 80px 0px !important;"> |
|||
<h1 style="font-size: 2.8rem;font-weight: 700; color: |
|||
#1A202C;"> |
|||
POS Booking Order</h1> |
|||
<p class="my-3 mb-4" |
|||
style="max-width: 80%; font-weight: 400 !important; line-height: 32px; color: #718096;"> |
|||
Book orders for customers in the POS |
|||
</p> |
|||
<div style="width: 80%; margin-top: 3rem;"> |
|||
<img src="assets/screenshots/hero.gif" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="container mt-5 mb-5"> |
|||
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> |
|||
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#714b67 !important">Key Highlights |
|||
</p> |
|||
</div> |
|||
<div class="row py-4"> |
|||
<div class="col-md-6 col-sm-12 p-3"> |
|||
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px; |
|||
background: #FFF; |
|||
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> |
|||
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; |
|||
display: flex; justify-content: center; align-items: center; |
|||
margin-right: 10px; flex-shrink: 0;"> |
|||
<i class="fa-solid fa-star " style="color: #fff;font-size:14px;"></i> |
|||
</div> |
|||
<div> |
|||
<p style="color: #1A202C;font-weight: 600; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Booking orders from Shop,Bar/Restaurant in POS.</p> |
|||
<p class="m-0" style="color:#718096">Option to enter booking from customers in pos. |
|||
</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-6 col-sm-12 p-3"> |
|||
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px; |
|||
background: #FFF; |
|||
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> |
|||
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; |
|||
display: flex; justify-content: center; align-items: center; |
|||
margin-right: 10px; flex-shrink: 0;"> |
|||
<i class="fa-solid fa-star " style="color: #fff;font-size:14px;"></i> |
|||
</div> |
|||
<div> |
|||
<p style="color: #1A202C;font-weight: 600; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Available both pickup and delivery options.</p> |
|||
<p class="m-0" style="color:#718096">Can choose type order both pickup and delivery. |
|||
</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-6 col-sm-12 p-3"> |
|||
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px; |
|||
background: #FFF; |
|||
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> |
|||
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; |
|||
display: flex; justify-content: center; align-items: center; |
|||
margin-right: 10px; flex-shrink: 0;"> |
|||
<i class="fa-solid fa-star " style="color: #fff;font-size:14px;"></i> |
|||
</div> |
|||
<div> |
|||
<p style="color: #1A202C;font-weight: 600; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Shows booked order details in order receipt and order.</p> |
|||
<p class="m-0" style="color:#718096">Details of the booking are printed in receipt |
|||
</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="container rounded" > |
|||
<ul class="nav nav-tabs d-flex" style="width: fit-content;margin: 0 auto;gap: 1rem;"> |
|||
<li class="col text-center py-2 text-nowrap " |
|||
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a |
|||
class="active show" data-toggle="tab" href="#tab1" |
|||
style="color: #fff;font-weight: 500; background-color: #714B67; text-decoration: none;"> |
|||
<i class="fa-regular fa-image pr-2" style="color: #fff;"></i> |
|||
Screenshots</a></li> |
|||
<li class="col text-center py-2 text-nowrap " |
|||
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a |
|||
data-toggle="tab" href="#tab2" |
|||
style="color: #fff;font-weight: 500; text-decoration: none;"><i |
|||
class="fa-solid fa-star pr-2" style="color: #fff;"></i>Features</a></li> |
|||
<li class="col text-center py-2 text-nowrap " |
|||
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a |
|||
data-toggle="tab" href="#tab3" |
|||
style="color: #fff;font-weight: 500; text-decoration: none; background-color: #714B67;"><i |
|||
class="fa-solid fa-book-open pr-2" style="color: #fff;"></i>Released Notes</a></li> |
|||
</ul> |
|||
<div class="tab-content" style="background-color: rgba(121, 113, 119, 0.04);"> |
|||
<div id="tab1" class="tab-pane fade in active show"> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot1.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">Go to PoS Settings -> |
|||
Enable Booking orders. After enabling this, the options to book |
|||
orders and screen of booked orders will show in POS |
|||
session.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot2.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> |
|||
While clicking the booking order button it will open a |
|||
popup,that will book the order.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot3.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> |
|||
We have two options for the booking order are picking or |
|||
delivery.Upon selecting the pickup option, |
|||
it shows a field to enter pickup date.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot4.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">When selected deliver option, it displays two fields to |
|||
enter delivery date and delivery address.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot5.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">Non-confirmed booked orders are can see here.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot6.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> |
|||
Can view order lines & customer assigned with order details |
|||
on confirming POS order</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot7.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">In the case of picking order, the order receipt will be |
|||
shown as below.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot8.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">In the case of delivery order, the order receipt will be |
|||
shown as below. Delivery date and address are specified</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot9.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">Confirmed or paid booked orders are highlighted.</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
|||
<div |
|||
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="row justify-content-center p-3 w-100 m-0"> |
|||
<img src="assets/screenshots/Screenshot10.png" class="img-responsive" width="100%" height="auto"> |
|||
</div> |
|||
<div class="px-3"> |
|||
<h4 class="mt-2" |
|||
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">The Book order ref will be updated on PoS Order</h4> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div id="tab2" class="tab-pane fade"> |
|||
<div class="col-mg-12" style="padding: 1rem 4rem;"> |
|||
<ul style="list-style: none; padding: 1rem 0;font-weight: 500;"> |
|||
<li class="py-3" |
|||
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" |
|||
width="16px"></span>Booking orders from Shop,Bar/Restaurant in POS. |
|||
</li> |
|||
<li class="py-3" |
|||
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" |
|||
width="16px"></span>Available both pickup and delivery options. |
|||
</li> |
|||
<li class="py-3" |
|||
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" |
|||
width="16px"></span>Shows booked order details in order receipt and order. |
|||
</li> |
|||
</ul> |
|||
</div> |
|||
</div> |
|||
<div id="tab3" class="tab-pane fade"> |
|||
<div class="col-mg-12 active" style="padding: 1rem 4rem;"> |
|||
<div class="py-3" |
|||
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
|||
<div class="d-flex mb-3" style="font-size: 0.8rem; font-weight: 500;"><span>Version |
|||
17.0.1.0.0</span><span class="px-2">|</span><span |
|||
style="color: #714B67;font-weight: 600;">Released on:11th Jan 2024</span> |
|||
</div> |
|||
<p class="m-0" |
|||
style=" color:#718096!important; font-size:1rem !important;line-height: 28px;"> |
|||
|
|||
Initial Commit for POS Booking Order.</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="container mt-5"> |
|||
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5"> |
|||
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Related Products</p> |
|||
</div> |
|||
</div> |
|||
<div id="myCarousel" class="carousel slide py-3" data-ride="carousel"> |
|||
<div class="carousel-inner"> |
|||
<div class="carousel-item active"> |
|||
<div class="row p-4"> |
|||
<div class="col"> |
|||
<div class="p-3"> |
|||
<a href="https://apps.odoo.com/apps/modules/17.0/salesperson_pos_order_line/" |
|||
style="color: #000; text-decoration: none;"> |
|||
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
|||
<div style="width: 300px; "> |
|||
<img src="assets/modules/1.jpg" |
|||
alt="" width="100%" |
|||
height="auto"> |
|||
|
|||
</div> |
|||
<p class="text-center pt-2 text-black font-weight-bold"> |
|||
Sales Person On POS Order Line</p> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<div class="col"> |
|||
<div class="p-3"> |
|||
<a href="https://apps.odoo.com/apps/modules/17.0/point_of_sale_logo/" |
|||
style="color: #000; text-decoration: none;"> |
|||
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
|||
<div style="width: 300px; "> |
|||
<img src="assets/modules/2.png" |
|||
alt="" width="100%" |
|||
height="auto"> |
|||
|
|||
</div> |
|||
<p class="text-center pt-2 text-black font-weight-bold"> |
|||
Point of Sale Logo</p> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<div class="col"> |
|||
<div class="p-3"> |
|||
<a href="https://apps.odoo.com/apps/modules/17.0/oh_appraisal/" |
|||
style="color: #000; text-decoration: none;"> |
|||
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
|||
<div style="width: 300px; "> |
|||
<img src="assets/modules/3.jpg" |
|||
alt="" width="100%" |
|||
height="auto"> |
|||
|
|||
</div> |
|||
<p class="text-center pt-2 text-black font-weight-bold"> |
|||
Open HRMS Employee Appraisal</p> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="carousel-item"> |
|||
<div class="row p-4"> |
|||
<div class="col"> |
|||
<div class="p-3"> |
|||
<a href="https://apps.odoo.com/apps/modules/17.0/master_search/" |
|||
style="color: #000; text-decoration: none;"> |
|||
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
|||
<div style="width: 300px; "> |
|||
<img src="assets/modules/4.jpg" |
|||
alt="" width="100%" |
|||
height="auto"> |
|||
|
|||
</div> |
|||
<p class="text-center pt-2 text-black font-weight-bold"> |
|||
Global Search</p> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<div class="col"> |
|||
<div class="p-3"> |
|||
<a href="https://apps.odoo.com/apps/modules/17.0/education_core/" |
|||
style="color: #000; text-decoration: none;"> |
|||
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
|||
<div style="width: 300px;"> |
|||
<img src="assets/modules/5.jpg" |
|||
alt="" width="100%" |
|||
height="auto"> |
|||
|
|||
</div> |
|||
<p class="text-center pt-2 text-black font-weight-bold"> |
|||
Educational ERP Core</p> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<div class="col"> |
|||
<div class="p-3"> |
|||
<a href="https://apps.odoo.com/apps/modules/17.0/odoo_parking_management/" |
|||
style="color: #000; text-decoration: none;"> |
|||
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
|||
<div style="width: 300px;"> |
|||
<img src="assets/modules/6.jpg" |
|||
alt="" width="100%" |
|||
height="auto"> |
|||
</div> |
|||
<p class="text-center pt-2 text-black font-weight-bold"> |
|||
Parking Management</p> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<a class="carousel-control-prev" href="#myCarousel" |
|||
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="#myCarousel" |
|||
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 class="container mt-5"> |
|||
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> |
|||
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Our Services</p> |
|||
|
|||
</div> |
|||
</div> |
|||
<div class="container my-5"> |
|||
<div class="row py-3"> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#13EA36 ; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/cogs.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Customization</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#DBC711; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/wrench.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Implementation</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#FF6B6B ; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/lifebuoy.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Support</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#FFA801 ; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/user.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Hire Odoo Developer</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> |
|||
|
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#54A0FF; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/puzzle.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Integration</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#6D7680 ; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/update.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Migration</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#786FA6 ; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/consultation.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Consultancy</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;position: relative;border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#F8A5C2 ; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/training.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Implementation</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-4 col-sm-6 px-4 py-4"> |
|||
<div |
|||
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
|||
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
|||
<div style="background-color:#E6BE26; border-radius: 50%; padding: 15px; width: 68px; |
|||
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
|||
<img src="assets/icons/license.png" alt="service-icon" width="38px" height="auto"> |
|||
</div> |
|||
</div> |
|||
<p style="margin-top: 20px; font-weight: bold;">Odoo Licensing Consultancy</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="container mt-5"> |
|||
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> |
|||
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Our Industries</p> |
|||
|
|||
</div> |
|||
</div> |
|||
<div class="container"> |
|||
<div class="row my-5 py-4"> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100 " |
|||
style="border-right: 1px solid rgb(209, 209, 209); border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; box-shadow: 6px 0 10px rgba(228, 227, 227, 0.373);"> |
|||
<img src="assets/icons/trading-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Trading</p> |
|||
<p>Easily procure and sell your products</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgb(209, 209, 209); padding: 30px;"> |
|||
<img src="assets/icons/pos-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">POS</p> |
|||
<p>Easy configuration and convivial experience</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgba(0, 0, 0, 0.2); padding: 30px; box-shadow: 0 5px 10px rgba(228, 227, 227, 0.373)"> |
|||
<img src="assets/icons/education-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Education</p> |
|||
<p>A platform for educational management</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style="border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; "> |
|||
<img src="assets/icons/manufacturing-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Manufacturing</p> |
|||
<p>Plan, track and schedule your operations</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;"> |
|||
<img src="assets/icons/ecom-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">E-commerce & Website</p> |
|||
<p>Mobile friendly, awe-inspiring product pages</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;box-shadow: 0 -5px 10px rgba(228, 227, 227, 0.373);"> |
|||
<img src="assets/icons/service-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Service Management</p> |
|||
<p>Keep track of services and invoice</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px; "> |
|||
<img src="assets/icons/restaurant-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Restaurant</p> |
|||
<p>Run your bar or restaurant methodically</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-3 col-sm-6 p-0"> |
|||
<div class="d-flex flex-column h-100" |
|||
style=" padding: 30px;box-shadow: -5px 0 10px rgba(228, 227, 227, 0.373);"> |
|||
<img src="assets/icons/hotel-black.png" width="42px" height="auto" alt=""> |
|||
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
|||
font-size: 1.2rem; margin-bottom: 2px;">Hotel Management</p> |
|||
<p>An all-inclusive hotel management application</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="container mt-5"> |
|||
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5"> |
|||
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Support</p> |
|||
</div> |
|||
</div> |
|||
<div class="container my-5"> |
|||
<div class="row" style="background-color: #FFFAFE;"> |
|||
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center" |
|||
style="border-right: 1px solid #D9D9D9;"> |
|||
<div style="padding: 30px;"> |
|||
<div class="d-flex align-items-center"> |
|||
<img src="assets/misc/support (1) 1.svg" alt="" width="60px" style="margin-right: 12px;"> |
|||
<div style="padding: 0px 8px;"> |
|||
<span |
|||
style="color: #714B67;font-size: 24px;font-weight: 600;padding-bottom: 1rem;">Need |
|||
Help?</span> |
|||
<p class="m-0" style="color:#718096;">Got questions or need help? Get in touch.</p> |
|||
<div style="font-weight: 400;"><span><img src="assets/misc/support-email.svg" alt="" |
|||
width="18px" |
|||
style="filter: invert(1);margin-right: 0.8rem;"></span>odoo@cybrosys.com |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center"> |
|||
<div style="padding: 30px;"> |
|||
<div class="d-flex align-items-center"> |
|||
<img src="assets/misc/whatsapp 1.svg" alt="" width="60px" style="margin-right: 12px;"> |
|||
<div> |
|||
<span style="color: #714B67;font-size: 24px;font-weight: 600;">WhatsApp</span> |
|||
<p class="m-0" style="color:#718096;">Say hi to us on WhatsApp!</p> |
|||
<div style="font-weight: 400; font-size: 16px;"><span><img src="assets/misc/phone.svg" |
|||
alt="" width="14px" |
|||
style="filter: invert(1); margin-right: 0.8rem;"></span>+91 |
|||
99456767686</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</section> |
|||
<!-- Optional JavaScript --> |
|||
<!-- jQuery first, then Popper.js, then Bootstrap JS --> |
|||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> |
|||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script> |
|||
</body> |
|||
</html> |
@ -0,0 +1,59 @@ |
|||
/** @odoo-module **/ |
|||
/* |
|||
* This file is used to register the a new button for booking orders with selected partner and products. |
|||
*/ |
|||
/** @odoo-module **/ |
|||
|
|||
import { _t } from "@web/core/l10n/translation"; |
|||
import { ProductScreen } from "@point_of_sale/app/screens/product_screen/product_screen"; |
|||
import { useService } from "@web/core/utils/hooks"; |
|||
import { Component } from "@odoo/owl"; |
|||
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
|||
import { BookOrderPopup } from "./BookOrderPopup"; |
|||
import { ErrorPopup } from "@point_of_sale/app/errors/popups/error_popup"; |
|||
|
|||
|
|||
|
|||
export class BookOrderButton extends Component { |
|||
static template = "pos_book_order.BookOrderButton"; |
|||
|
|||
setup() { |
|||
this.pos = usePos(); |
|||
this.popup = useService("popup"); |
|||
} |
|||
async onClick() { |
|||
// by clicking the booking order button, it will check whether at least one product and the selected customer or not, after that it will display popup.
|
|||
var order=this.pos.selectedOrder |
|||
var order_lines = order.orderlines; |
|||
var partner = order.partner |
|||
if (partner == null) { |
|||
this.pos.popup.add(ErrorPopup, { |
|||
title: _t("Please Select the Customer"), |
|||
body: _t( |
|||
"You need to select a customer for using this option" |
|||
), |
|||
}); |
|||
} else if (order_lines.length == 0) { |
|||
this.pos.popup.add(ErrorPopup, { |
|||
title: _t("Order line is empty"), |
|||
body: _t( |
|||
"Please select at least one product" |
|||
), |
|||
}); |
|||
} else { |
|||
await this.pos.popup.add(BookOrderPopup, { |
|||
title: _t("Book Order"), |
|||
partner:partner, |
|||
order:order, |
|||
currentDate: new Date().toISOString().split('T')[0], |
|||
}); |
|||
} |
|||
} |
|||
} |
|||
|
|||
ProductScreen.addControlButton({ |
|||
component: BookOrderButton, |
|||
condition: function () { |
|||
return this.pos.config.enable; |
|||
}, |
|||
}); |
@ -0,0 +1,81 @@ |
|||
/** @odoo-module */ |
|||
|
|||
import { AbstractAwaitablePopup } from "@point_of_sale/app/popup/abstract_awaitable_popup"; |
|||
import { _t } from "@web/core/l10n/translation"; |
|||
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
|||
import { useRef } from "@odoo/owl"; |
|||
import { useService } from "@web/core/utils/hooks"; |
|||
|
|||
|
|||
/** |
|||
* This class represents a custom popup for capturing signatures in the Point of Sale. |
|||
* It extends the AbstractAwaitablePopup class. |
|||
*/ |
|||
export class BookOrderPopup extends AbstractAwaitablePopup { |
|||
static template = "pos_book_order.BookOrderPopup"; |
|||
static defaultProps = { |
|||
confirmText: _t("Save"), |
|||
cancelText: _t("Discard"), |
|||
clearText: _t("Clear"), |
|||
title: "", |
|||
body: "", |
|||
}; |
|||
setup() { |
|||
super.setup(); |
|||
this.pos = usePos(); |
|||
this.orm = useService("orm"); |
|||
this.order = this.pos.selectedOrder |
|||
this.pickup_date = useRef("pickUpDate") |
|||
this.order_note= useRef("orderNote") |
|||
this.delivery_date= useRef("deliveryDate") |
|||
this.pickup= useRef("pickup_radio") |
|||
this.delivery= useRef("deliver_radio") |
|||
this.Method_pickup= useRef("Method_pickup") |
|||
this.Method_deliver= useRef("Method_deliver") |
|||
} |
|||
showHide(){ |
|||
if(this.pickup.el.checked){ |
|||
this.Method_pickup.el.style.display='block' |
|||
this.Method_deliver.el.style.display='none' |
|||
} |
|||
if(this.delivery.el.checked){ |
|||
this.Method_pickup.el.style.display='none' |
|||
this.Method_deliver.el.style.display='block' |
|||
} |
|||
console.log(this.delivery.el.checked) |
|||
console.log(this.pickup.el.checked) |
|||
} |
|||
|
|||
async confirm() { |
|||
// on clicking confirm button of popup a new book order with draft stage will created from the backend
|
|||
var pickup_date = this.pickup_date.el.value; |
|||
var delivery_date = this.delivery_date.el.value; |
|||
var order_note = this.order_note.el.value; |
|||
var partner = this.order.partner.id; |
|||
var address = this.order.partner.address; |
|||
var phone = this.order.partner.phone; |
|||
var date = this.order.date_order; |
|||
var line = this.order.orderlines; |
|||
if(this.order.pricelist){ |
|||
var price_list = this.order.pricelist.id; |
|||
} |
|||
else{ |
|||
var price_list = false; |
|||
} |
|||
var product = { |
|||
'product_id': [], |
|||
'qty': [], |
|||
'price':[] |
|||
}; |
|||
for (var i = 0; i < line.length; i++) { |
|||
product['product_id'].push(line[i].product.id) |
|||
product['qty'].push(line[i].quantity) |
|||
product['price'].push(line[i].price) |
|||
}; |
|||
await this.orm.call( |
|||
"book.order", "create_booked_order", [partner, phone, address, date, price_list,product, order_note, pickup_date, delivery_date], {} |
|||
) |
|||
this.cancel(); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,31 @@ |
|||
/** @odoo-module **/ |
|||
/* |
|||
* This file is used to register the a new button to see booked orders data. |
|||
*/ |
|||
import { Component } from "@odoo/owl"; |
|||
import { useService } from "@web/core/utils/hooks"; |
|||
import { ProductScreen } from "@point_of_sale/app/screens/product_screen/product_screen"; |
|||
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
|||
|
|||
class BookedOrdersButton extends Component { |
|||
static template = 'pos_book_order.BookedOrdersButton'; |
|||
setup() { |
|||
this.orm = useService("orm"); |
|||
this.pos = usePos(); |
|||
} |
|||
async onClick() { |
|||
// fetch all booked order in draft stage to screen
|
|||
var self = this |
|||
await this.orm.call( |
|||
"book.order", "all_orders", [], {} |
|||
).then(function(result) { |
|||
self.pos.showScreen('BookedOrdersScreen', { |
|||
data: result |
|||
}); |
|||
}) |
|||
} |
|||
} |
|||
ProductScreen.addControlButton({ |
|||
component: BookedOrdersButton, |
|||
condition: () => true |
|||
}) |
@ -0,0 +1,43 @@ |
|||
/** @odoo-module **/ |
|||
/* |
|||
* This file is used to register a new screen for Booked orders. |
|||
*/ |
|||
import { registry } from "@web/core/registry"; |
|||
import { TicketScreen } from "@point_of_sale/app/screens/ticket_screen/ticket_screen"; |
|||
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
|||
import { useService } from "@web/core/utils/hooks"; |
|||
|
|||
class BookedOrdersScreen extends TicketScreen { |
|||
static template = "pos_book_order.BookedOrdersScreen"; |
|||
setup() { |
|||
super.setup(); |
|||
this.pos = usePos(); |
|||
this.orm = useService("orm"); |
|||
} |
|||
back() { |
|||
// on clicking the back button it will redirected Product screen
|
|||
this.pos.showScreen('ProductScreen'); |
|||
} |
|||
async _Confirm(ev) { |
|||
// On clicking confirm button on each order a order will create with corresponding partner and products,user can do the payment
|
|||
var self = this |
|||
var data = ev |
|||
await this.orm.call('book.order', 'action_confirm',[data.id],{}) |
|||
var order=this.pos.add_new_order(); |
|||
for (var i of data.products) { |
|||
var product = self.pos.db.get_product_by_id(i['id']) |
|||
var qty = i['qty'] |
|||
order.add_product(product, { |
|||
quantity: qty, |
|||
price: i['price'] |
|||
}) |
|||
} |
|||
var partner_id = data.partner_id |
|||
order.set_partner(this.pos.db.get_partner_by_id(partner_id)); |
|||
this.pos.selectedOrder.is_booked = true |
|||
this.pos.selectedOrder.booked_data = data |
|||
this.pos.selectedOrder.booking_ref_id = data.id |
|||
this.pos.showScreen('ProductScreen'); |
|||
} |
|||
} |
|||
registry.category("pos_screens").add("BookedOrdersScreen", BookedOrdersScreen); |
@ -0,0 +1,46 @@ |
|||
/** @odoo-module **/ |
|||
/* |
|||
* This file is used to add some fields to order class for some reference. |
|||
*/ |
|||
|
|||
import { Order } from "@point_of_sale/app/store/models"; |
|||
import { patch } from "@web/core/utils/patch"; |
|||
|
|||
patch(Order.prototype, { |
|||
/** |
|||
* Override the setup method to initialize custom signature properties. |
|||
* @param {Object} options - Options passed to the setup method. |
|||
*/ |
|||
setup(options) { |
|||
super.setup(...arguments); |
|||
if (options.json) { |
|||
this.booking_ref_id= options.json.booking_ref_id || false; |
|||
this.is_booked = options.json.is_booked || false; |
|||
this.booked_data = options.json.booked_data || undefined; |
|||
} |
|||
}, |
|||
/** |
|||
* Initialize the order object from a JSON representation. |
|||
* @param {Object} json - JSON data representing the order. |
|||
*/ |
|||
init_from_JSON(json) { |
|||
super.init_from_JSON(...arguments); |
|||
// this function is overrided for assigning json value to this
|
|||
super.init_from_JSON(...arguments); |
|||
this.booking_ref_id= json.booking_ref_id; |
|||
this.is_booked = json.is_booked; |
|||
this.booked_data = json.booked_data |
|||
}, |
|||
/** |
|||
* Export the order object as a JSON representation. |
|||
* @returns {Object} JSON data representing the order. |
|||
*/ |
|||
export_as_JSON() { |
|||
// this function is overrided for assign this to json for new field
|
|||
const json = super.export_as_JSON(...arguments); |
|||
json.booking_ref_id=this.booking_ref_id |
|||
json.booked_data = this.booked_data; |
|||
json.is_booked = this.is_booked; |
|||
return json; |
|||
}, |
|||
}); |
@ -0,0 +1,132 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<templates id="template" xml:space="preserve"> |
|||
<!--This is used for creating a popup for booking orders--> |
|||
<t t-name="pos_book_order.BookOrderPopup"> |
|||
<div class="popup popup-confirm"> |
|||
<div class="modal-header"> |
|||
<h4 class="modal-title title drag-handle"> |
|||
<t t-esc="props.title"/> |
|||
</h4> |
|||
</div> |
|||
<main class="modal-body"> |
|||
<t t-if="props.partner"> |
|||
<label style="margin-right: 298px;">AMOUNT TOTAL</label> |
|||
<div> |
|||
<input class='form-control booking_field' name="amount" |
|||
type='text' |
|||
style="height:34px;border-radius:5px;" |
|||
t-att-value="order.get_total_with_tax()" |
|||
readonly="1"/> |
|||
</div> |
|||
<br/> |
|||
<br/> |
|||
<label style="margin-right: 333px;">CUSTOMER</label> |
|||
<div> |
|||
<input class='form-control booking_field' name="name" |
|||
type='text' |
|||
style="height:34px;border-radius:5px;" |
|||
t-att-value="props.partner.name" readonly="1"/> |
|||
</div> |
|||
<br/> |
|||
<br/> |
|||
<label style="margin-right: 185px;">PHONE CONTACT FOR DELIVERY(*)</label> |
|||
<div> |
|||
<input class='form-control booking_field' name="phone" |
|||
type='text' id="phone" |
|||
style="height:34px;border-radius:5px;" |
|||
t-att-value="props.partner.phone" |
|||
data-is-required="true"/> |
|||
</div> |
|||
</t> |
|||
<div class="radio" |
|||
style="width:100%;float: left;text-align: center;font-size: 23px;"> |
|||
<label>Pickup</label> |
|||
<input type="radio" name="method" id="pickup" |
|||
style="width: auto;min-height: auto;margin-right: 28px;" |
|||
checked="checked" value="pickup" t-ref="pickup_radio" |
|||
t-on-click="showHide"/> |
|||
<label>Deliver</label> |
|||
<input type="radio" name="method" id="deliver" |
|||
style="width: auto;min-height: auto;" |
|||
value="deliver" t-ref="deliver_radio" |
|||
t-on-click="showHide"/> |
|||
</div> |
|||
<t t-if="order.pricelist"> |
|||
<label style="margin-right: 324px;">PRICELIST(*)</label> |
|||
<div> |
|||
<input class='form-control booking_field' |
|||
name="pricelist" type='text' |
|||
style="height:34px;border-radius:5px;" |
|||
t-att-value="order.pricelist.display_name " |
|||
readonly="1"/> |
|||
</div> |
|||
<br/> |
|||
<br/> |
|||
</t> |
|||
<label style="margin-right: 293px;">BOOKING DATE(*)</label> |
|||
<div> |
|||
<input type="date" id='BookingDate' name="order_date" |
|||
class='form-control booking_field' |
|||
maxlength="10" |
|||
t-att-value="props.currentDate"/> |
|||
</div> |
|||
<br/> |
|||
<br/> |
|||
<label style="margin-right: 324px;">ORDER NOTE</label> |
|||
<div> |
|||
<textarea |
|||
t-ref="orderNote" |
|||
rows="1" cols="30" name="order_note" |
|||
class="form-control order_note" |
|||
placeholder="Enter your notes here..."/> |
|||
</div> |
|||
<br/> |
|||
<br/> |
|||
<div id="Method_pickup" t-ref="Method_pickup"> |
|||
<label style="margin-right: 317px;">PICKUP DATE</label> |
|||
<div> |
|||
<input t-ref="pickUpDate" |
|||
name="pickup_date" |
|||
class='form-control booking_field' |
|||
id="pickup_date" type='date' |
|||
style="height:34px;border-radius:5px;"/> |
|||
</div> |
|||
</div> |
|||
<div id="Method_deliver" style="display:none" |
|||
t-ref="Method_deliver"> |
|||
<label style="margin-right: 301px;">DELIVERY DATE</label> |
|||
<div> |
|||
<input t-ref="deliveryDate" |
|||
name="deliver_date" |
|||
class='form-control booking_field' |
|||
id="deliver_date" type='date' |
|||
style="height:34px;border-radius:5px;"/> |
|||
</div> |
|||
<br/> |
|||
<br/> |
|||
<t t-if="props.partner"> |
|||
<label style="margin-right: 271px;">DELIVERY ADDRESS(*)</label> |
|||
<div> |
|||
<input class='form-control booking_field' |
|||
name="delivery_address" type='text' |
|||
id="delivery_address" |
|||
t-att-value="props.partner.address" |
|||
data-is-required="true"/> |
|||
</div> |
|||
</t> |
|||
</div> |
|||
|
|||
</main> |
|||
<footer class="footer modal-footer"> |
|||
<div class="button confirm btn btn-lg btn-primary" |
|||
t-on-click="confirm"> |
|||
<t t-esc="props.confirmText"/> |
|||
</div> |
|||
<div class="button cancel btn btn-lg btn-secondary" |
|||
t-on-click="cancel"> |
|||
<t t-esc="props.cancelText"/> |
|||
</div> |
|||
</footer> |
|||
</div> |
|||
</t> |
|||
</templates> |
@ -0,0 +1,134 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<templates id="template" xml:space="preserve"> |
|||
<!--This is used for creating a new screen for showing booked orders--> |
|||
<t t-name="pos_book_order.BookedOrdersScreen" owl="1"> |
|||
<div class="partnerlist-screen screen"> |
|||
<div class="screen-content"> |
|||
<div class="top-content"> |
|||
<div class="button back" t-on-click="back"> |
|||
<i class="fa fa-angle-double-left"/> |
|||
Back |
|||
</div> |
|||
</div> |
|||
<table class="partner-list table table-striped w-100"> |
|||
<thead> |
|||
<tr> |
|||
<th class="py-2">Order Ref.</th> |
|||
<th class="py-2">Customer</th> |
|||
<th class="py-2">Contact No.</th> |
|||
<th class="py-2">Order Date</th> |
|||
<th class="py-2">Pickup Date</th> |
|||
<th class="py-2">Delivery Date</th> |
|||
<th class="py-2">Address</th> |
|||
<th class="py-2">Total</th> |
|||
<th class="py-2">Confirm</th> |
|||
</tr> |
|||
</thead> |
|||
<tbody class="partner-list-contents"> |
|||
<t t-foreach="props.data" |
|||
t-as="order" |
|||
t-key="order.id"> |
|||
<tr> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Order Ref.</div> |
|||
<div> |
|||
<t t-esc="order.name"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Customer</div> |
|||
<div> |
|||
<t t-esc="order.partner_name"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Contact No.</div> |
|||
<div> |
|||
<t t-esc="order.phone"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Order Date.</div> |
|||
<div> |
|||
<t t-esc="order.date"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Pickup Date</div> |
|||
<div t-if="order.pickup"> |
|||
<t t-esc="order.pickup"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Delivery Date</div> |
|||
<div t-if="order.deliver"> |
|||
<t t-esc="order.deliver"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col wide" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Address</div> |
|||
<div> |
|||
<t t-esc="order.address"/> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<div t-if="env.isMobile">Total</div> |
|||
<div> |
|||
<t t-esc="order.total"> |
|||
</t> |
|||
</div> |
|||
</div> |
|||
</td> |
|||
<td> |
|||
<div class="col" |
|||
t-att-class="{ highlight: isHighlighted(order) }"> |
|||
<button class="confirm-button" |
|||
name="confirm_order" |
|||
id="confirm_order" |
|||
t-on-click="() => this._Confirm(order)"> |
|||
Confirm Order |
|||
</button> |
|||
</div> |
|||
</td> |
|||
</tr> |
|||
|
|||
</t> |
|||
<t t-if="props.data.length==0"> |
|||
<div class="empty-order-list" |
|||
style="text-align: center; margin: 48px;color: #80848F;"> |
|||
<i role="img" aria-label="Shopping cart" |
|||
title="Shopping cart" |
|||
class="fa fa-shopping-cart"> |
|||
</i> |
|||
<h1>No orders found</h1> |
|||
</div> |
|||
</t> |
|||
</tbody> |
|||
</table> |
|||
</div> |
|||
</div> |
|||
</t> |
|||
</templates> |
@ -0,0 +1,18 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<templates id="template" xml:space="preserve"> |
|||
<!-- This button for booking orders--> |
|||
<t t-name="pos_book_order.BookOrderButton" owl="1"> |
|||
<div class="control-button o_pricelist_button btn btn-light rounded-0 fw-bolder" |
|||
t-on-click="onClick"> |
|||
<i class='fa fa-book'/> |
|||
<span class="label">Booking</span> |
|||
</div> |
|||
</t> |
|||
<!-- This button for seeing booked orders--> |
|||
<t t-name="pos_book_order.BookedOrdersButton" owl="1"> |
|||
<div class="control-button o_pricelist_button btn btn-light rounded-0 fw-bolder" |
|||
t-on-click="onClick"> |
|||
Booked Orders |
|||
</div> |
|||
</t> |
|||
</templates> |
@ -0,0 +1,45 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<template id="receipt_template" xml:space="preserve"> |
|||
<!--This is used for adding some more data to pos receipt based on the booked order--> |
|||
<t t-name="BookOrderReceipt" t-inherit="point_of_sale.OrderReceipt" |
|||
t-inherit-mode="extension" owl="1"> |
|||
<xpath expr="//div[hasclass('before-footer')]" position="after"> |
|||
<t t-set="order" t-value="this.env.services.pos.get_order()"/> |
|||
<t t-if="order.is_booked"> |
|||
<hr/> |
|||
<div> |
|||
Booking Ref: |
|||
<span t-esc="order.booked_data.name" |
|||
class="pos-receipt-right-align"/> |
|||
</div> |
|||
<div> |
|||
Contact No.: |
|||
<span t-esc="order.booked_data.phone" |
|||
class="pos-receipt-right-align"/> |
|||
</div> |
|||
<div> |
|||
Order Note: |
|||
<span t-esc="order.booked_data.note"/> |
|||
</div> |
|||
<t t-if="order.booked_data.pickup"> |
|||
<div> |
|||
Pickup Date: |
|||
<span t-esc="order.booked_data.pickup" |
|||
class="pos-receipt-right-align"/> |
|||
</div> |
|||
</t> |
|||
<t t-if="order.booked_data.deliver"> |
|||
<div> |
|||
Delivery Date: |
|||
<span t-esc="order.booked_data.deliver" |
|||
class="pos-receipt-right-align"/> |
|||
</div> |
|||
<div> |
|||
Delivery address: |
|||
<span t-esc="order.booked_data.address"/> |
|||
</div> |
|||
</t> |
|||
</t> |
|||
</xpath> |
|||
</t> |
|||
</template> |
@ -0,0 +1,103 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<odoo> |
|||
<!-- This record for creating form view for book.order--> |
|||
<record id="book_order_view_form" model="ir.ui.view"> |
|||
<field name="name">book.order.view.form</field> |
|||
<field name="model">book.order</field> |
|||
<field name="arch" type="xml"> |
|||
<form string="Point of Sale Quotations" create="false"> |
|||
<header> |
|||
<field name="state" widget="statusbar" |
|||
statusbar_visible="draft,confirmed"/> |
|||
</header> |
|||
<sheet> |
|||
<group> |
|||
<group> |
|||
<field name="name"/> |
|||
<field name="date_order"/> |
|||
<field name="date_quotation"/> |
|||
<field name="pickup_date"/> |
|||
<field name="pricelist_id"/> |
|||
</group> |
|||
<group> |
|||
<field name="partner_id"/> |
|||
<field name="phone"/> |
|||
<field name="delivery_address"/> |
|||
<field name="deliver_date"/> |
|||
</group> |
|||
<notebook colspan="4"> |
|||
<page string="Products"> |
|||
<field name="book_line_ids" colspan="4" |
|||
nolabel="1"> |
|||
<tree string="Order lines" |
|||
editable="bottom"> |
|||
<field name="product_id"/> |
|||
<field name="qty"/> |
|||
<field name="price_unit" |
|||
widget="monetary"/> |
|||
<field name="discount" |
|||
widget="monetary"/> |
|||
<field name="tax_after_fiscal_position_ids" |
|||
widget="many2many_tags"/> |
|||
<field name="price_subtotal" |
|||
widget="monetary"/> |
|||
<field name="price_subtotal_incl" |
|||
widget="monetary"/> |
|||
</tree> |
|||
</field> |
|||
<group class="oe_subtotal_footer oe_right" |
|||
colspan="2" name="order_total"> |
|||
<field name="amount_tax" widget="monetary"/> |
|||
<div class="oe_subtotal_footer_separator oe_inline"> |
|||
<label for="amount_total"/> |
|||
</div> |
|||
<field name="amount_total" nolabel="1" |
|||
class="oe_subtotal_footer_separator" |
|||
widget="monetary"/> |
|||
</group> |
|||
</page> |
|||
<page string="Notes"> |
|||
<field name="note"/> |
|||
</page> |
|||
</notebook> |
|||
</group> |
|||
</sheet> |
|||
</form> |
|||
</field> |
|||
</record> |
|||
<!-- this record for creating tree view for book.order--> |
|||
<record id="book_order_view_tree" model="ir.ui.view"> |
|||
<field name="name">book.order.view.tree</field> |
|||
<field name="model">book.order</field> |
|||
<field name="arch" type="xml"> |
|||
<tree string="Point of Sale Quotations" create="false" |
|||
decoration-danger="state == 'draft'" |
|||
decoration-success="state == 'confirmed'"> |
|||
<field name="name"/> |
|||
<field name="partner_id"/> |
|||
<field name="pickup_date"/> |
|||
<field name="deliver_date"/> |
|||
<field name="amount_total"/> |
|||
<field name="state"/> |
|||
</tree> |
|||
</field> |
|||
</record> |
|||
<!-- this record for creating menu action for book.order--> |
|||
<record id="book_order_action" model="ir.actions.act_window"> |
|||
<field name="name">Booking Orders</field> |
|||
<field name="res_model">book.order</field> |
|||
<field name="view_mode">tree,form</field> |
|||
<field name="help" type="html"> |
|||
<p> |
|||
Use this menu to browse previous booking orders and to record |
|||
new booking orders. |
|||
</p> |
|||
</field> |
|||
</record> |
|||
<menuitem id="book_order_menu" |
|||
name="Booking Orders" |
|||
parent="point_of_sale.menu_point_of_sale" |
|||
action="book_order_action" |
|||
sequence="0" |
|||
groups="point_of_sale.group_pos_manager,point_of_sale.group_pos_user"/> |
|||
</odoo> |
@ -0,0 +1,24 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<odoo> |
|||
<!-- This record is for adding a field in pos configuration for allowing booking order--> |
|||
<record id="pos_config_view_form" model="ir.ui.view"> |
|||
<field name="name">pos.config.view.form.inherit.book.order</field> |
|||
<field name="model">pos.config</field> |
|||
<field name="inherit_id" ref="point_of_sale.pos_config_view_form"/> |
|||
<field name="arch" type="xml"> |
|||
<xpath expr="//setting[@id='other_devices']" position="after"> |
|||
<div class="col-12 col-lg-6 o_setting_box"> |
|||
<div class="o_setting_left_pane"> |
|||
<field name="enable"/> |
|||
</div> |
|||
<div class="o_setting_right_pane"> |
|||
<label for="enable" string="Booking Orders"/> |
|||
<div class="text-muted"> |
|||
Allow booking orders |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</xpath> |
|||
</field> |
|||
</record> |
|||
</odoo> |
@ -0,0 +1,14 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!-- This record for adding a booked order reference field to pos order form view --> |
|||
<record id="view_pos_pos_form" model="ir.ui.view"> |
|||
<field name="name">pos.order.view.form.inherit.book.order</field> |
|||
<field name="model">pos.order</field> |
|||
<field name="inherit_id" ref="point_of_sale.view_pos_pos_form"/> |
|||
<field name="arch" type="xml"> |
|||
<field name="partner_id" position="after"> |
|||
<field name="booking_ref_id"/> |
|||
</field> |
|||
</field> |
|||
</record> |
|||
</odoo> |