[MIG][12.0] web_dashboard_tile
- refactor tile category - improve description - add legalsylvain as maintainer - update code and translation
|
Before Width: | Height: | Size: 340 B |
|
Before Width: | Height: | Size: 264 B |
|
Before Width: | Height: | Size: 287 B |
|
Before Width: | Height: | Size: 283 B |
|
Before Width: | Height: | Size: 24 KiB |
|
Before Width: | Height: | Size: 20 KiB |
|
Before Width: | Height: | Size: 305 B |
@@ -1,141 +0,0 @@
|
||||
// @@@ web_dashboard_tile custom JS @@@
|
||||
//#############################################################################
|
||||
//
|
||||
// Copyright (C) 2010-2013 OpenERP s.a. (<http://www.openerp.com>)
|
||||
// Copyright (C) 2014 initOS GmbH & Co. KG (<http://initos.com>)
|
||||
// Copyright (C) 2018 Iván Todorovich (<ivan.todorovich@gmail.com>)
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as published
|
||||
// by the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// 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 for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
//
|
||||
//#############################################################################
|
||||
|
||||
odoo.define('web_dashboard_tile', function (require) {
|
||||
"use strict";
|
||||
|
||||
var core = require('web.core');
|
||||
var data = require('web.data');
|
||||
var FavoriteMenu = require('web.FavoriteMenu');
|
||||
var ActionManager = require('web.ActionManager');
|
||||
var ViewManager = require('web.ViewManager');
|
||||
var Model = require('web.DataModel');
|
||||
var session = require('web.session');
|
||||
var pyeval = require('web.pyeval');
|
||||
var _t = core._t;
|
||||
var QWeb = core.qweb;
|
||||
|
||||
|
||||
FavoriteMenu.include({
|
||||
|
||||
prepare_dropdown_menu: function (filters) {
|
||||
var self = this;
|
||||
this._super(filters);
|
||||
var am = this.findAncestor(function (a) {
|
||||
return a instanceof ActionManager;
|
||||
});
|
||||
if (am && am.get_inner_widget() instanceof ViewManager) {
|
||||
this.view_manager = am.get_inner_widget();
|
||||
this.add_to_dashboard_tile_available = true;
|
||||
this.$('.o_favorites_menu').append(QWeb.render('SearchView.addtodashboardtile'));
|
||||
this.$add_to_dashboard_tile = this.$('.o_add_to_dashboard_tile');
|
||||
this.$add_dashboard_tile_btn = this.$add_to_dashboard_tile.eq(1).find('button');
|
||||
this.$add_dashboard_tile_input = this.$add_to_dashboard_tile.eq(0).find('input');
|
||||
this.$add_dashboard_tile_link = this.$('.o_add_to_dashboard_tile_link');
|
||||
var title = this.searchview.get_title();
|
||||
this.$add_dashboard_tile_input.val(title);
|
||||
this.$add_dashboard_tile_link.click(function (e) {
|
||||
e.preventDefault();
|
||||
self.toggle_dashboard_tile_menu();
|
||||
});
|
||||
this.$add_dashboard_tile_btn.click(this.proxy('add_dashboard_tile'));
|
||||
}
|
||||
},
|
||||
|
||||
toggle_dashboard_tile_menu: function (is_open) {
|
||||
this.$add_dashboard_tile_link
|
||||
.toggleClass('o_closed_menu', !(_.isUndefined(is_open)) ? !is_open : undefined)
|
||||
.toggleClass('o_open_menu', is_open);
|
||||
this.$add_to_dashboard_tile.toggle(is_open);
|
||||
if (this.$add_dashboard_tile_link.hasClass('o_open_menu')) {
|
||||
this.$add_dashboard_tile_input.focus();
|
||||
}
|
||||
},
|
||||
|
||||
close_menus: function () {
|
||||
if (this.add_to_dashboard_tile_available) {
|
||||
this.toggle_dashboard_tile_menu(false);
|
||||
}
|
||||
this._super();
|
||||
},
|
||||
|
||||
add_dashboard_tile: function () {
|
||||
var self = this;
|
||||
|
||||
var search_data = this.searchview.build_search_data(),
|
||||
context = new data.CompoundContext(this.searchview.dataset.get_context() || []),
|
||||
domain = new data.CompoundDomain(this.searchview.dataset.get_domain() || []);
|
||||
_.each(search_data.contexts, context.add, context);
|
||||
_.each(search_data.domains, domain.add, domain);
|
||||
|
||||
context.add({
|
||||
group_by: pyeval.eval('groupbys', search_data.groupbys || [])
|
||||
});
|
||||
|
||||
context.add(this.view_manager.active_view.controller.get_context());
|
||||
|
||||
var c = pyeval.eval('context', context);
|
||||
for(var k in c) {
|
||||
if (c.hasOwnProperty(k) && /^search_default_/.test(k)) {
|
||||
delete c[k];
|
||||
}
|
||||
}
|
||||
|
||||
this.toggle_dashboard_tile_menu(false);
|
||||
|
||||
c.dashboard_merge_domains_contexts = false;
|
||||
var d = pyeval.eval('domain', domain),
|
||||
tile = new Model('tile.tile'),
|
||||
name = self.$add_dashboard_tile_input.val();
|
||||
|
||||
var private_filter = !this.$('#oe_searchview_custom_public').prop('checked');
|
||||
if (_.isEmpty(name)){
|
||||
this.do_warn(_t("Error"), _t("Filter name is required."));
|
||||
return false;
|
||||
}
|
||||
|
||||
// Don't save user_context keys in the custom filter, otherwise end
|
||||
// up with e.g. wrong uid or lang stored *and used in subsequent
|
||||
// reqs*
|
||||
var ctx = context;
|
||||
_(_.keys(session.user_context)).each(function (key) {
|
||||
delete ctx[key];
|
||||
});
|
||||
|
||||
var vals = {
|
||||
name: name,
|
||||
user_id: private_filter ? session.uid : false,
|
||||
model_id: self.view_manager.active_view.controller.model,
|
||||
//context: context,
|
||||
domain: d,
|
||||
action_id: self.action_id || false,
|
||||
};
|
||||
|
||||
// FIXME: current context?
|
||||
return tile.call('add', [vals]).done(function (id) {
|
||||
self.do_notify(_t("Success"), _t("Tile is created"));
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
112
web_dashboard_tile/static/src/js/web_dashboard_tile.js
Normal file
@@ -0,0 +1,112 @@
|
||||
/*
|
||||
Copyright (C) 2010-2013 OpenERP s.a. (<http://www.openerp.com>)
|
||||
Copyright (C) 2014 initOS GmbH & Co. KG (<http://initos.com>)
|
||||
Copyright (C) 2018 Iván Todorovich (<ivan.todorovich@gmail.com>)
|
||||
Copyright (C) 2019-Today GRAP (http://www.grap.coop)
|
||||
@author: Sylvain LE GAL (https://twitter.com/legalsylvain)
|
||||
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
||||
*/
|
||||
|
||||
|
||||
odoo.define('web_dashboard_tile', function (require) {
|
||||
'use strict';
|
||||
var core = require('web.core');
|
||||
var FavoriteMenu = require('web.FavoriteMenu');
|
||||
var Domain = require('web.Domain');
|
||||
var qweb = core.qweb;
|
||||
var _t = core._t;
|
||||
|
||||
FavoriteMenu.include({
|
||||
|
||||
start: function () {
|
||||
var self = this;
|
||||
if (this.action_id === undefined) {
|
||||
return this._super();
|
||||
}
|
||||
if (this.action.type === 'ir.actions.act_window') {
|
||||
this.add_to_dashboard_available = true;
|
||||
this.$('.o_favorites_menu').append(qweb.render('SearchView.addtodashboardtile'));
|
||||
this.$add_to_dashboard_tile = this.$('.o_add_to_dashboard_tile');
|
||||
this.$add_to_dashboard_tile_name = this.$('.o_add_to_dashboard_tile_name')[0];
|
||||
|
||||
// Add event on button and link clicks
|
||||
this.$add_to_dashboard_tile_link = this.$('.o_add_to_dashboard_tile_link');
|
||||
this.$add_to_dashboard_tile_link.click(function (e) {
|
||||
e.preventDefault();
|
||||
self._toggleDashboardTileMenu();
|
||||
});
|
||||
this.$add_to_dashboard_tile_button = this.$('.o_add_to_dashboard_tile_button');
|
||||
this.$add_to_dashboard_tile_button.click(this.proxy('_addDashboardTile'));
|
||||
|
||||
// Add categories to the select list
|
||||
this.$add_to_dashboard_tile_category = this.$('.o_add_to_dashboard_tile_category')[0];
|
||||
this._rpc({
|
||||
model: 'tile.category',
|
||||
method: 'search_read',
|
||||
args: [[], ['id', 'name']],
|
||||
}).then(function (res) {
|
||||
res.forEach(function(item){
|
||||
var newOption = document.createElement("option");
|
||||
newOption.text = item.name;
|
||||
newOption.value = item.id;
|
||||
self.$add_to_dashboard_tile_category.appendChild(newOption);
|
||||
});
|
||||
});
|
||||
}
|
||||
return this._super();
|
||||
},
|
||||
|
||||
_toggleDashboardTileMenu: function (isOpen) {
|
||||
this.$add_to_dashboard_tile_link
|
||||
.toggleClass('o_closed_menu', !(_.isUndefined(isOpen)) ? !isOpen : undefined)
|
||||
.toggleClass('o_open_menu', isOpen);
|
||||
this.$add_to_dashboard_tile.toggle(isOpen);
|
||||
if (this.$add_to_dashboard_tile_link.hasClass('o_open_menu')) {
|
||||
this.$add_to_dashboard_tile_name.focus();
|
||||
}
|
||||
},
|
||||
|
||||
_addDashboardTile: function () {
|
||||
var self = this;
|
||||
var tile_name = this.$add_to_dashboard_tile_name.value;
|
||||
var tile_category_id = this.$add_to_dashboard_tile_category.value;
|
||||
|
||||
if (!tile_name.length){
|
||||
this.do_warn(_t("Error"), _t("Name Field is required."));
|
||||
this.$add_to_dashboard_tile_name.focus();
|
||||
return;
|
||||
}
|
||||
|
||||
var search_data = this.searchview.build_search_data();
|
||||
var domain = this.action.domain ? this.action.domain.slice(0) : [];
|
||||
|
||||
_.each(search_data.domains, function (d) {
|
||||
domain.push.apply(domain, Domain.prototype.stringToArray(d));
|
||||
});
|
||||
|
||||
return this._rpc({
|
||||
route: '/web_dashboard_tile/create_tile',
|
||||
params: {
|
||||
model_name: self.action.res_model,
|
||||
name: tile_name,
|
||||
category_id: tile_category_id,
|
||||
domain: domain,
|
||||
action_id: this.action_id,
|
||||
},
|
||||
}).then(function (res) {
|
||||
if (res) {
|
||||
self.do_notify(
|
||||
_.str.sprintf(_t("'%s' added to the overview dashboard"), tile_name),
|
||||
_t('Please refresh your browser for the changes to take effect.')
|
||||
);
|
||||
self._toggleDashboardTileMenu(false);
|
||||
} else {
|
||||
self.do_warn(_t("Could not add new element to the overview dashboard"));
|
||||
}
|
||||
});
|
||||
|
||||
},
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
@@ -1,13 +0,0 @@
|
||||
<template>
|
||||
<t t-name="SearchView.addtodashboardtile">
|
||||
<li class="o_add_to_dashboard_tile_link o_closed_menu">
|
||||
<a href="#">Add to Dashboard Tile</a>
|
||||
</li>
|
||||
<li class="o_add_to_dashboard_tile">
|
||||
<input class="o_add_to_dashboard_input" type="text"/>
|
||||
</li>
|
||||
<li class="o_add_to_dashboard_tile">
|
||||
<button type="button" class="btn btn-primary btn-sm o_add_to_dashboard_button">Add</button>
|
||||
</li>
|
||||
</t>
|
||||
</template>
|
||||
19
web_dashboard_tile/static/src/xml/web_dashboard_tile.xml
Normal file
@@ -0,0 +1,19 @@
|
||||
<template>
|
||||
<t t-name="SearchView.addtodashboardtile">
|
||||
|
||||
<a href="#" class="dropdown-item o_add_to_dashboard_tile_link o_closed_menu">Add to the Overview Dashboard</a>
|
||||
<div class="dropdown-item-text o_add_to_dashboard_tile">
|
||||
Name
|
||||
<input class="o_input o_required_modifier o_add_to_dashboard_tile_name" type="text"/>
|
||||
</div>
|
||||
<div class="dropdown-item-text o_add_to_dashboard_tile">
|
||||
Category
|
||||
<select class="o_input o_required_modifier o_add_to_dashboard_tile_category">
|
||||
</select>
|
||||
</div>
|
||||
<div class="dropdown-item-text o_add_to_dashboard_tile">
|
||||
<button type="button" class="btn btn-primary o_add_to_dashboard_tile_button">Add</button>
|
||||
</div>
|
||||
|
||||
</t>
|
||||
</template>
|
||||