mirror of
https://github.com/OCA/web.git
synced 2025-02-22 13:21:25 +02:00
[IMP] web_group_expand: black, isort
This commit is contained in:
committed by
BT-aestebanez
parent
ce88ab6418
commit
c7225dbe71
@@ -4,47 +4,61 @@ odoo.define("web.web_group_expand", function(require) {
|
||||
var qweb = require("web.core").qweb;
|
||||
|
||||
require("web.ListController").include({
|
||||
start: function () {
|
||||
start: function() {
|
||||
this.$expandGroupButtons = $(qweb.render("web_group_expand.Buttons"));
|
||||
this.$expandGroupButtons.find("#oe_group_by_expand").on(
|
||||
"click", this.expandAllGroups.bind(this)
|
||||
);
|
||||
this.$expandGroupButtons.find("#oe_group_by_collapse").on(
|
||||
"click", this.collapseAllGroups.bind(this)
|
||||
);
|
||||
this.$expandGroupButtons
|
||||
.find("#oe_group_by_expand")
|
||||
.on("click", this.expandAllGroups.bind(this));
|
||||
this.$expandGroupButtons
|
||||
.find("#oe_group_by_collapse")
|
||||
.on("click", this.collapseAllGroups.bind(this));
|
||||
return this._super.apply(this, arguments);
|
||||
},
|
||||
|
||||
renderPager: function ($node) {
|
||||
renderPager: function($node) {
|
||||
this._super.apply(this, arguments);
|
||||
this.$expandGroupButtons.toggleClass("o_hidden", !this.renderer.isGrouped);
|
||||
$node.append(this.$expandGroupButtons);
|
||||
},
|
||||
|
||||
expandAllGroups: function () {
|
||||
expandAllGroups: function() {
|
||||
// We expand layer by layer. So first we need to find the highest
|
||||
// layer that's not already fully expanded.
|
||||
var layer = this.renderer.state.data;
|
||||
while (layer.length) {
|
||||
var closed = layer.filter(function (group) {return !group.isOpen;});
|
||||
var closed = layer.filter(function(group) {
|
||||
return !group.isOpen;
|
||||
});
|
||||
if (closed.length) {
|
||||
// This layer is not completely expanded, expand it
|
||||
this._toggleGroups(closed);
|
||||
break;
|
||||
}
|
||||
// This layer is completely expanded, move to the next
|
||||
layer = _.flatten(layer.map(function (group) {return group.data;}), true);
|
||||
layer = _.flatten(
|
||||
layer.map(function(group) {
|
||||
return group.data;
|
||||
}),
|
||||
true
|
||||
);
|
||||
}
|
||||
},
|
||||
|
||||
collapseAllGroups: function () {
|
||||
collapseAllGroups: function() {
|
||||
// We collapse layer by layer. So first we need to find the deepest
|
||||
// layer that's not already fully collapsed.
|
||||
var layer = this.renderer.state.data
|
||||
.filter(function (group) {return group.isOpen;});
|
||||
var layer = this.renderer.state.data.filter(function(group) {
|
||||
return group.isOpen;
|
||||
});
|
||||
while (layer.length) {
|
||||
var next = _.flatten(layer.map(function (group) {return group.data;}), true)
|
||||
.filter(function (group) {return group.isOpen;});
|
||||
var next = _.flatten(
|
||||
layer.map(function(group) {
|
||||
return group.data;
|
||||
}),
|
||||
true
|
||||
).filter(function(group) {
|
||||
return group.isOpen;
|
||||
});
|
||||
if (!next.length) {
|
||||
// Next layer is fully collapsed, so collapse this one
|
||||
this._toggleGroups(layer);
|
||||
@@ -54,19 +68,24 @@ odoo.define("web.web_group_expand", function(require) {
|
||||
}
|
||||
},
|
||||
|
||||
_toggleGroups: function (groups) {
|
||||
_toggleGroups: function(groups) {
|
||||
var self = this;
|
||||
var defs = groups.map(function (group) {
|
||||
var defs = groups.map(function(group) {
|
||||
return self.model.toggleGroup(group.id);
|
||||
});
|
||||
$.when(...defs).then(this.update.bind(this, {}, {keepSelection: true, reload: false}));
|
||||
}
|
||||
$.when(...defs).then(
|
||||
this.update.bind(this, {}, {keepSelection: true, reload: false})
|
||||
);
|
||||
},
|
||||
});
|
||||
|
||||
require("web.ListRenderer").include({
|
||||
updateState: function () {
|
||||
updateState: function() {
|
||||
var res = this._super.apply(this, arguments);
|
||||
$("nav.oe_group_by_expand_buttons").toggleClass("o_hidden", !this.isGrouped);
|
||||
$("nav.oe_group_by_expand_buttons").toggleClass(
|
||||
"o_hidden",
|
||||
!this.isGrouped
|
||||
);
|
||||
return res;
|
||||
},
|
||||
});
|
||||
|
||||
@@ -1,15 +1,19 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<templates>
|
||||
<t t-name="web_group_expand.Buttons">
|
||||
<nav class="btn-group oe_group_by_expand_buttons o_hidden">
|
||||
<button class="btn btn-secondary fa fa-expand"
|
||||
id="oe_group_by_expand"
|
||||
title="Expand groups"
|
||||
type="button" />
|
||||
<button class="btn btn-secondary fa fa-compress"
|
||||
id="oe_group_by_collapse"
|
||||
title="Collapse groups"
|
||||
type="button" />
|
||||
<button
|
||||
class="btn btn-secondary fa fa-expand"
|
||||
id="oe_group_by_expand"
|
||||
title="Expand groups"
|
||||
type="button"
|
||||
/>
|
||||
<button
|
||||
class="btn btn-secondary fa fa-compress"
|
||||
id="oe_group_by_collapse"
|
||||
title="Collapse groups"
|
||||
type="button"
|
||||
/>
|
||||
</nav>
|
||||
</t>
|
||||
</templates>
|
||||
|
||||
Reference in New Issue
Block a user