mirror of
https://github.com/guohuadeng/app-odoo.git
synced 2025-02-23 04:11:36 +02:00
add ui enhance
This commit is contained in:
11
app_ui_enhance/static/src/css/app_ui_enhance.css
Normal file
11
app_ui_enhance/static/src/css/app_ui_enhance.css
Normal file
@@ -0,0 +1,11 @@
|
||||
.tree_search_item {
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.tree_search_item .selected a:before {
|
||||
font-family: FontAwesome;
|
||||
position: absolute;
|
||||
left: 6px;
|
||||
top: 3px;
|
||||
content: "";
|
||||
}
|
||||
257
app_ui_enhance/static/src/js/pivot.js
Normal file
257
app_ui_enhance/static/src/js/pivot.js
Normal file
@@ -0,0 +1,257 @@
|
||||
odoo.define('app_ui_enhance.pivot', function (require) {
|
||||
"use strict";
|
||||
|
||||
var time = require('web.time');
|
||||
var core = require('web.core');
|
||||
var data = require('web.data');
|
||||
var session = require('web.session');
|
||||
var utils = require('web.utils');
|
||||
var Model = require('web.Model');
|
||||
var PivotView = require('web.PivotView');
|
||||
var datepicker = require('web.datepicker');
|
||||
|
||||
var _t = core._t;
|
||||
var _lt = core._lt;
|
||||
var QWeb = core.qweb;
|
||||
|
||||
PivotView.include({
|
||||
|
||||
init: function() {
|
||||
this._super.apply(this, arguments);
|
||||
this.ts_fields = [];
|
||||
},
|
||||
|
||||
tgl_on_button_click: function (event) {
|
||||
var self = this;
|
||||
var $target = $(event.target),
|
||||
field, key, first_item;
|
||||
|
||||
field = $target.parent().data('field');
|
||||
key = $target.parent().data('key');
|
||||
|
||||
if (field == -1) {
|
||||
first_item = $target.parent().parent().children('.tgl_first_item.selected');
|
||||
if (!first_item.length) {
|
||||
$target.parent().parent().children('li').removeClass('selected')
|
||||
}
|
||||
} else {
|
||||
first_item = $target.parent().parent().children('.tgl_first_item').removeClass('selected');
|
||||
}
|
||||
|
||||
$target.parent().toggleClass('selected');
|
||||
this.tgl_search()
|
||||
event.stopPropagation();
|
||||
|
||||
},
|
||||
|
||||
|
||||
render_buttons: function($node) {
|
||||
var self = this;
|
||||
var ts_context = this.context.tree_search;
|
||||
|
||||
this._super.apply(this, arguments);
|
||||
|
||||
var l10n = _t.database.parameters;
|
||||
var datepickers_options = {
|
||||
pickTime: false,
|
||||
startDate: moment({ y: 1900 }),
|
||||
endDate: moment().add(200, "y"),
|
||||
calendarWeeks: true,
|
||||
icons : {
|
||||
time: 'fa fa-clock-o',
|
||||
date: 'fa fa-calendar',
|
||||
up: 'fa fa-chevron-up',
|
||||
down: 'fa fa-chevron-down'
|
||||
},
|
||||
language : moment.locale(),
|
||||
format : time.strftime_to_moment_format(l10n.date_format),
|
||||
}
|
||||
|
||||
// Dropdown list
|
||||
|
||||
$(QWeb.render("TGL.TreeSearch.Placeholder", {})).appendTo($node);
|
||||
|
||||
_.each(ts_context, function(item){
|
||||
var field = _.find(self.fields, function(value, key, list){
|
||||
return value.type == 'many2one' && value.relation && key === item.name;
|
||||
});
|
||||
|
||||
if (field) {
|
||||
self.ts_fields.push(item.name);
|
||||
|
||||
new Model(field.relation).query(['id', 'display_name']).filter(new data.CompoundDomain(item.domain, field.domain)).context(new data.CompoundContext()).order_by('app_sequence').all().then(function (result) {
|
||||
var $multi_search = $(QWeb.render("TGL.TreeSearch.Item", {'widget': {
|
||||
'string': item.string,
|
||||
'key': item.name,
|
||||
'class_name': 'app_multi_item_' + item.name,
|
||||
'fields': result,
|
||||
}}))
|
||||
|
||||
$multi_search.find('li').click(self.tgl_on_button_click.bind(self));
|
||||
|
||||
setTimeout(function(){
|
||||
$multi_search.appendTo($('.treesearch_placeholder'));
|
||||
}, 2000);
|
||||
});
|
||||
}
|
||||
});
|
||||
// self.$buttons.find('.app-search').remove();
|
||||
|
||||
var date_fields = [];
|
||||
// 增加参数控制app_ui_show_search_date
|
||||
new Model('ir.config_parameter').call('search_read', [[['key', '=', 'app_ui_show_search_date']], ['value']]).then(function (show) {
|
||||
if (show.length >= 1 && (show[0]['value'] == "True")) {
|
||||
_.each(self.fields, function (value, key, list) {
|
||||
if (value.store && value.type === "datetime" || value.type === "date") {
|
||||
date_fields.push([key, value.string]);
|
||||
}
|
||||
});
|
||||
|
||||
if (date_fields.length > 0) {
|
||||
self.$search_button = $(QWeb.render('odooApp.buttons', {'date_fields': date_fields}))
|
||||
self.$search_button.find('.app_start_date').datetimepicker(datepickers_options);
|
||||
self.$search_button.find('.app_end_date').datetimepicker(datepickers_options);
|
||||
self.$search_button.find('.app_start_date').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_button.find('.app_end_date').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_button.find('.app_select_field').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
setTimeout(function () {
|
||||
self.$search_button.insertBefore($('.treesearch_placeholder'));
|
||||
}, 500);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
var number_fields = [];
|
||||
|
||||
// 增加参数控制app_ui_show_search_number
|
||||
new Model('ir.config_parameter').call('search_read', [[['key', '=', 'app_ui_show_search_number']], ['value']]).then(function (show) {
|
||||
if (show.length >= 1 && (show[0]['value'] == "True")) {
|
||||
number_fields = [];
|
||||
_.each(self.fields, function (value, key, list) {
|
||||
if (value.string && value.string.length > 1 && value.store && (value.type === "integer" || value.type === "float" || value.type === "monetary")) {
|
||||
number_fields.push([key, value.string]);
|
||||
}
|
||||
});
|
||||
|
||||
if (number_fields.length > 0) {
|
||||
self.$search_range = $(QWeb.render('odooApp.SearchRange', {'number_fields': number_fields}))
|
||||
self.$search_range.find('.app_select_range_field').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_range.find('.app_start_range').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_range.find('.app_end_range').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
setTimeout(function () {
|
||||
self.$search_range.insertBefore($('.treesearch_placeholder'));
|
||||
}, 500);
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
|
||||
do_search: function(domain, context, group_by) {
|
||||
var self = this;
|
||||
this.last_domain = domain;
|
||||
this.last_context = context;
|
||||
this.last_group_by = group_by;
|
||||
this.old_search = _.bind(this._super, this);
|
||||
return self.tgl_search();
|
||||
},
|
||||
|
||||
tgl_search: function() {
|
||||
var self = this;
|
||||
var domain = [], value, value_tmp;
|
||||
|
||||
_.each(self.ts_fields, function(field){
|
||||
value = $('.app_item_' + field).val();
|
||||
|
||||
var select_fields = $('.app_multi_item_' + field).children('.selected'),
|
||||
select_value = [];
|
||||
if (select_fields.length > 0) {
|
||||
_.each(select_fields, function(item){
|
||||
value_tmp = $(item).data('field');
|
||||
if (value_tmp > 0) {
|
||||
select_value.push($(item).data('field'));
|
||||
}
|
||||
});
|
||||
if (select_value.length) {
|
||||
domain.push([field, 'in', select_value]);
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
// 注意,date和datetime型的处理是不同的,已处理完
|
||||
if (self.$search_button) {
|
||||
var start_date = self.$search_button.find('.app_start_date').val(),
|
||||
end_date = self.$search_button.find('.app_end_date').val(),
|
||||
field = self.$search_button.find('.app_select_field').val(),
|
||||
field_type = 'datetime';
|
||||
var tz = session.user_context.tz,
|
||||
start_utc,
|
||||
end_utc;
|
||||
|
||||
_.each(self.columns, function (value, key, list) {
|
||||
if (value.name == field) {
|
||||
field_type = value.type;
|
||||
return false;
|
||||
}
|
||||
});
|
||||
|
||||
moment.locale(tz);
|
||||
var l10n = _t.database.parameters;
|
||||
if (start_date) {
|
||||
if (field_type == 'date') {
|
||||
//日期类型,无须utc处理
|
||||
start_date = moment(moment(start_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD');
|
||||
domain.push([field, '>=', start_date]);
|
||||
} else {
|
||||
//日期时间,处理utc
|
||||
start_date = moment(moment(start_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD 00:00:00');
|
||||
start_utc = moment(start_date)
|
||||
domain.push([field, '>=', start_utc]);
|
||||
}
|
||||
}
|
||||
if (end_date) {
|
||||
if (field_type == 'date') {
|
||||
end_date = moment(moment(end_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD');
|
||||
domain.push([field, '<=', end_date]);
|
||||
} else {
|
||||
end_date = moment(moment(end_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD 00:00:00');
|
||||
end_utc = moment(end_date)
|
||||
domain.push([field, '<=', end_utc]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (self.$search_range) {
|
||||
var start_range = self.$search_range.find('.app_start_range').val(),
|
||||
end_range = self.$search_range.find('.app_end_range').val(),
|
||||
range_field = self.$search_range.find('.app_select_range_field').val();
|
||||
|
||||
if (start_range) {
|
||||
domain.push([range_field, '>=', parseInt(start_range)]);
|
||||
}
|
||||
if (end_range) {
|
||||
domain.push([range_field, '<=', parseInt(end_range)]);
|
||||
}
|
||||
}
|
||||
// console.log(domain);
|
||||
var compound_domain = new data.CompoundDomain(self.last_domain, domain);
|
||||
self.dataset.domain = compound_domain.eval();
|
||||
return self.old_search(compound_domain, self.last_context, self.last_group_by);
|
||||
},
|
||||
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
271
app_ui_enhance/static/src/js/tree.js
Normal file
271
app_ui_enhance/static/src/js/tree.js
Normal file
@@ -0,0 +1,271 @@
|
||||
odoo.define('app_ui_enhance.tree', function (require) {
|
||||
"use strict";
|
||||
|
||||
var time = require('web.time');
|
||||
var core = require('web.core');
|
||||
var data = require('web.data');
|
||||
var session = require('web.session');
|
||||
var utils = require('web.utils');
|
||||
var Model = require('web.Model');
|
||||
var ListView = require('web.ListView');
|
||||
var datepicker = require('web.datepicker');
|
||||
var ViewManager = require('web.ViewManager')
|
||||
var _t = core._t;
|
||||
var _lt = core._lt;
|
||||
var QWeb = core.qweb;
|
||||
|
||||
ListView.include({
|
||||
|
||||
init: function(parent, dataset, view_id, options) {
|
||||
this._super.apply(this, arguments);
|
||||
this.ts_context = dataset.context.tree_search;
|
||||
this.fields_range = dataset.context.fields_range;
|
||||
this.ts_fields = [];
|
||||
},
|
||||
|
||||
on_button_click: function (event) {
|
||||
var self = this;
|
||||
var $target = $(event.target),
|
||||
field, key, first_item;
|
||||
|
||||
field = $target.parent().data('field');
|
||||
key = $target.parent().data('key');
|
||||
|
||||
if (field == -1) {
|
||||
first_item = $target.parent().parent().children('.tgl_first_item.selected');
|
||||
if (!first_item.length) {
|
||||
$target.parent().parent().children('li').removeClass('selected')
|
||||
}
|
||||
} else {
|
||||
first_item = $target.parent().parent().children('.tgl_first_item').removeClass('selected');
|
||||
}
|
||||
|
||||
$target.parent().toggleClass('selected');
|
||||
this.tgl_search()
|
||||
event.stopPropagation();
|
||||
|
||||
},
|
||||
|
||||
render_buttons: function($node) {
|
||||
var self = this;
|
||||
this._super.apply(this, arguments);
|
||||
|
||||
var l10n = _t.database.parameters;
|
||||
var datepickers_options = {
|
||||
pickTime: false,
|
||||
startDate: moment({ y: 1900 }),
|
||||
endDate: moment().add(200, "y"),
|
||||
calendarWeeks: true,
|
||||
icons : {
|
||||
time: 'fa fa-clock-o',
|
||||
date: 'fa fa-calendar',
|
||||
up: 'fa fa-chevron-up',
|
||||
down: 'fa fa-chevron-down'
|
||||
},
|
||||
language : moment.locale(),
|
||||
format : time.strftime_to_moment_format(l10n.date_format),
|
||||
}
|
||||
|
||||
self.$buttons.find('.app-search').remove();
|
||||
|
||||
var date_fields = [];
|
||||
// 增加参数控制app_ui_show_search_date
|
||||
new Model('ir.config_parameter').call('search_read', [[['key', '=', 'app_ui_show_search_date']], ['value']]).then(function (show) {
|
||||
if (show.length >= 1 && (show[0]['value'] == "True")) {
|
||||
_.each(self.columns, function (value, key, list) {
|
||||
if (value.store && value.type === "datetime" || value.type === "date") {
|
||||
date_fields.push([value.name, value.string, value.type]);
|
||||
}
|
||||
});
|
||||
if (date_fields.length > 0) {
|
||||
self.$search_button = $(QWeb.render('odooApp.buttons', {'date_fields': date_fields}))
|
||||
self.$search_button.find('.app_start_date').datetimepicker(datepickers_options);
|
||||
self.$search_button.find('.app_end_date').datetimepicker(datepickers_options);
|
||||
// self.$search_button.find('.app_search_date_rate').click(function() {
|
||||
// self.tgl_search();
|
||||
// });
|
||||
self.$search_button.find('.app_start_date').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_button.find('.app_end_date').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_button.find('.app_select_field').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_button.appendTo(self.$buttons);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
var number_fields = [];
|
||||
|
||||
// 增加参数控制app_ui_show_search_number
|
||||
new Model('ir.config_parameter').call('search_read', [[['key', '=', 'app_ui_show_search_number']], ['value']]).then(function (show) {
|
||||
if (show.length >= 1 && (show[0]['value'] == "True")) {
|
||||
_.each(self.columns, function (value, key, list) {
|
||||
if (value.string && value.string.length > 1 && value.store && (value.type === "integer" || value.type === "float" || value.type === "monetary")) {
|
||||
number_fields.push([value.name, value.string]);
|
||||
}
|
||||
});
|
||||
|
||||
if (number_fields.length == 0) {
|
||||
if (self.fields_range) {
|
||||
number_fields = self.fields_range;
|
||||
}
|
||||
}
|
||||
if (number_fields.length > 0) {
|
||||
self.$search_range = $(QWeb.render('odooApp.SearchRange', {'number_fields': number_fields}))
|
||||
// self.$search_range.find('.app_search_date_range').click(function() {
|
||||
// self.tgl_search();
|
||||
// });
|
||||
self.$search_range.find('.app_select_range_field').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_range.find('.app_start_range').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_range.find('.app_end_range').on('change', function () {
|
||||
self.tgl_search();
|
||||
});
|
||||
self.$search_range.appendTo(self.$buttons);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
// Dropdown list
|
||||
_.each(this.ts_context, function(item){
|
||||
var field = _.find(self.columns, function(column){
|
||||
return column.type == 'many2one' && column.relation && column.name === item.name;
|
||||
});
|
||||
if (field) {
|
||||
self.ts_fields.push(item.name);
|
||||
new Model(field.relation).query(['id', 'display_name']).filter(new data.CompoundDomain(item.domain, field.domain)).context(new data.CompoundContext()).all().then(function (result) {
|
||||
// var single_search = $(QWeb.render('odooApp.selection', {
|
||||
// 'string': item.string,
|
||||
// 'class_name': 'app_item_' + item.name,
|
||||
// 'fields': result,
|
||||
// }));
|
||||
if (!$('.after_control_panel').length) {
|
||||
// $(QWeb.render('odooApp.after_control_panel', {})).appendTo($('.o_control_panel'));
|
||||
// $(QWeb.render('odooApp.after_control_panel', {})).appendTo($('.o_cp_left'));
|
||||
|
||||
// $(QWeb.render('odooApp.after_control_panel', {})).appendTo(self.$buttons);
|
||||
|
||||
var multi_search = $(QWeb.render("TGL.TreeSearch.Item", {'widget': {
|
||||
'string': item.string,
|
||||
'key': item.name,
|
||||
'class_name': 'app_multi_item_' + item.name,
|
||||
'fields': result,
|
||||
}}))
|
||||
|
||||
multi_search.find('li').click(self.on_button_click.bind(self));
|
||||
multi_search.appendTo(self.$buttons);
|
||||
}
|
||||
// single_search.appendTo($('.after_control_panel'));
|
||||
// $('.app_item_' + item.name).on('change', function() {
|
||||
// self.tgl_search();
|
||||
// })
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
},
|
||||
|
||||
do_search: function(domain, context, group_by) {
|
||||
var self = this;
|
||||
this.last_domain = domain;
|
||||
this.last_context = context;
|
||||
this.last_group_by = group_by;
|
||||
this.old_search = _.bind(this._super, this);
|
||||
return self.tgl_search();
|
||||
},
|
||||
|
||||
tgl_search: function() {
|
||||
var self = this;
|
||||
var domain = [], value, value_tmp;
|
||||
|
||||
_.each(self.ts_fields, function(field){
|
||||
value = $('.app_item_' + field).val();
|
||||
|
||||
var select_fields = $('.app_multi_item_' + field).children('.selected'),
|
||||
select_value = [];
|
||||
if (select_fields.length > 0) {
|
||||
_.each(select_fields, function(item){
|
||||
value_tmp = $(item).data('field');
|
||||
if (value_tmp > 0) {
|
||||
select_value.push($(item).data('field'));
|
||||
}
|
||||
});
|
||||
if (select_value.length) {
|
||||
domain.push([field, 'in', select_value]);
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
// 注意,date和datetime型的处理是不同的,已处理完
|
||||
if (self.$search_button) {
|
||||
var start_date = self.$search_button.find('.app_start_date').val(),
|
||||
end_date = self.$search_button.find('.app_end_date').val(),
|
||||
field = self.$search_button.find('.app_select_field').val(),
|
||||
field_type = 'datetime';
|
||||
var tz = session.user_context.tz,
|
||||
start_utc,
|
||||
end_utc;
|
||||
|
||||
_.each(self.columns, function (value, key, list) {
|
||||
if (value.name == field) {
|
||||
field_type = value.type;
|
||||
return false;
|
||||
}
|
||||
});
|
||||
|
||||
moment.locale(tz);
|
||||
var l10n = _t.database.parameters;
|
||||
if (start_date) {
|
||||
if (field_type === 'date') {
|
||||
//日期类型,无须utc处理
|
||||
start_date = moment(moment(start_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD');
|
||||
domain.push([field, '>=', start_date]);
|
||||
} else {
|
||||
//日期时间,处理utc
|
||||
start_date = moment(moment(start_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD 00:00:00');
|
||||
start_utc = moment(start_date)
|
||||
domain.push([field, '>=', start_utc]);
|
||||
}
|
||||
}
|
||||
if (end_date) {
|
||||
if (field_type === 'date') {
|
||||
end_date = moment(moment(end_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD');
|
||||
domain.push([field, '<=', end_date]);
|
||||
} else {
|
||||
end_date = moment(moment(end_date, time.strftime_to_moment_format(l10n.date_format))).format('YYYY-MM-DD 00:00:00');
|
||||
end_utc = moment(end_date)
|
||||
domain.push([field, '<=', end_utc]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (self.$search_range) {
|
||||
var start_range = self.$search_range.find('.app_start_range').val(),
|
||||
end_range = self.$search_range.find('.app_end_range').val(),
|
||||
range_field = self.$search_range.find('.app_select_range_field').val();
|
||||
|
||||
if (start_range) {
|
||||
domain.push([range_field, '>=', parseInt(start_range)]);
|
||||
}
|
||||
if (end_range) {
|
||||
domain.push([range_field, '<=', parseInt(end_range)]);
|
||||
}
|
||||
}
|
||||
// console.log(domain);
|
||||
var compound_domain = new data.CompoundDomain(self.last_domain, domain);
|
||||
self.dataset.domain = compound_domain.eval();
|
||||
return self.old_search(compound_domain, self.last_context, self.last_group_by);
|
||||
},
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
101
app_ui_enhance/static/src/xml/pivot_view.xml
Normal file
101
app_ui_enhance/static/src/xml/pivot_view.xml
Normal file
@@ -0,0 +1,101 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<templates id="template" xml:space="preserve">
|
||||
<!--日期类型搜索-->
|
||||
<t t-name="odooApp.buttons">
|
||||
<div class="app-search btn-group btn-group-sm" >
|
||||
<!-- <div style="margin-left: 10px; margin-top: 2px;"> -->
|
||||
<div style="margin-left: 0px; margin-top: 2px; padding-right: 10px;">
|
||||
<span style="float: left;">
|
||||
|
||||
<select class="app_select_field form-control" style="height: 30px;" >
|
||||
<option t-foreach="date_fields" t-as="field" t-att-value="field[0]" t-att-type="field[2]">
|
||||
<t t-esc="field[1]"/>
|
||||
</option>
|
||||
</select>
|
||||
</span>
|
||||
|
||||
<span style="float: left; margin-left: 2px;">
|
||||
<input style="height: 30px;" class="app_start_date form-control" size="15" placeholder="Start date" type="text" />
|
||||
</span>
|
||||
|
||||
<span style="float: left; margin-left: 2px;">
|
||||
<input style="height: 30px;" class="app_end_date form-control" size="15" placeholder="End date" type="text" />
|
||||
</span>
|
||||
|
||||
<!-- <button style="margin-left: 2px; padding: 5px 10px;" class="app_search_date_rate btn btn-primary" title="Field">Lọc</button> -->
|
||||
</div>
|
||||
</div>
|
||||
<!-- <br></br> -->
|
||||
</t>
|
||||
<!--数值范围搜索-->
|
||||
<t t-name="odooApp.SearchRange">
|
||||
<div class="app-search btn-group btn-group-sm" >
|
||||
<!-- <div style="margin-left: 10px; margin-top: 2px;"> -->
|
||||
<div style="margin-left: 0px; margin-top: 2px; padding-right: 10px;">
|
||||
<span style="float: left;">
|
||||
|
||||
<select class="app_select_range_field form-control" style="height: 30px;" >
|
||||
<option t-foreach="number_fields" t-as="field" t-att-value="field[0]">
|
||||
<t t-esc="field[1]"/>
|
||||
</option>
|
||||
</select>
|
||||
</span>
|
||||
|
||||
<span style="float: left; margin-left: 2px;">
|
||||
<input style="height: 30px;" class="app_start_range form-control" size="6" placeholder="From" type="text" />
|
||||
</span>
|
||||
|
||||
<span style="float: left; margin-left: 2px;">
|
||||
<input style="height: 30px;" class="app_end_range form-control" size="6" placeholder="To" type="text" />
|
||||
</span>
|
||||
|
||||
<!-- <button style="margin-left: 2px; padding: 5px 10px;" class="app_search_date_range btn btn-primary" title="Field">Lọc</button> -->
|
||||
</div>
|
||||
</div>
|
||||
<br></br>
|
||||
</t>
|
||||
|
||||
<t t-name="odooApp.after_control_panel">
|
||||
<!-- <div class="after_control_panel" style="width: 100%; text-align: center;" /> -->
|
||||
<div class="after_control_panel" />
|
||||
</t>
|
||||
|
||||
<t t-name="odooApp.selection">
|
||||
<div class=" btn-group btn-group-sm" >
|
||||
<div style="text-align: left">
|
||||
<strong><span t-esc="string"/></strong>
|
||||
<div style="margin-left: 0px; margin-top: 0px;">
|
||||
|
||||
<select t-att-class="class_name" style="height: 30px;" >
|
||||
<option value="0">All</option>
|
||||
<option t-foreach="fields" t-as="field" t-att-value="field.id">
|
||||
<t t-esc="field.display_name"/>
|
||||
</option>
|
||||
</select>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</t>
|
||||
|
||||
<t t-name="TGL.TreeSearch.Placeholder">
|
||||
<div class="treesearch_placeholder" />
|
||||
</t>
|
||||
|
||||
<t t-name="TGL.TreeSearch.Item">
|
||||
<div class="btn-group btn-group-sm tree_search_item" style="padding-right: 2px;">
|
||||
<button class="btn btn-primary dropdown-toggle form-control" data-toggle="dropdown">
|
||||
<t t-esc="widget.string" /> <span class="caret"></span>
|
||||
</button>
|
||||
<ul t-att-class="widget.class_name+' dropdown-menu'" style="max-height: 450px; overflow-y: auto;">
|
||||
<li data-field="-1" class="tgl_first_item selected" ><a>All</a></li>
|
||||
<li t-foreach="widget.fields" t-as="value" t-att-data-field="value.id" t-att-data-key="widget.key">
|
||||
<a><t t-esc="value.display_name"/></a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
</t>
|
||||
|
||||
|
||||
</templates>
|
||||
Reference in New Issue
Block a user