Merge pull request #3100 from Icinga/feature/expandable-content

Implement persistent "Show more" spoilers
This commit is contained in:
lippserd 2017-11-27 14:44:15 +01:00 committed by GitHub
commit 8f1f8d4471
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 93 additions and 0 deletions

View File

@ -33,6 +33,7 @@ class JavaScript
'js/icinga/behavior/form.js', 'js/icinga/behavior/form.js',
'js/icinga/behavior/actiontable.js', 'js/icinga/behavior/actiontable.js',
'js/icinga/behavior/flyover.js', 'js/icinga/behavior/flyover.js',
'js/icinga/behavior/expandable.js',
'js/icinga/behavior/selectable.js' 'js/icinga/behavior/selectable.js'
); );

View File

@ -459,3 +459,48 @@ ul.tree li a.error:hover {
cursor: pointer; cursor: pointer;
} }
} }
input[type="checkbox"].expandable-toggle {
display: none;
& + label {
float: right;
margin-right: 1em;
cursor: pointer;
user-select: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
}
& ~ .expandable-content {
clear: right; // Because the label is floating right
}
&:checked ~ .expandable-content {
-webkit-transition: opacity 0.2s linear;
-moz-transition: opacity 0.2s linear;
-o-transition: opacity 0.2s linear;
transition: opacity 0.2s linear;
}
&:not(:checked) ~ .expandable-content {
height: 0;
opacity: 0;
visibility: hidden;
-webkit-transition: opacity 0.2s linear, visibility 0.2s;
-moz-transition: opacity 0.2s linear, visibility 0.2s;
-o-transition: opacity 0.2s linear, visibility 0.2s;
transition: opacity 0.2s linear, visibility 0.2s;
}
&:checked ~ label .expandable-expand-label {
display: none;
}
&:not(:checked) ~ label .expandable-collapse-label {
display: none;
}
}

View File

@ -0,0 +1,47 @@
/* Icinga Web 2 | (c) 2017 Icinga Development Team | GPLv2+ */
/**
* Icinga.Behavior.Expandable
*
* Initially collapsed, but expandable content
*/
(function(Icinga, $) {
'use strict';
var expandedExpandables = {};
function Expandable(icinga) {
Icinga.EventListener.call(this, icinga);
this.on('rendered', this.onRendered, this);
this.on('click', this.onClick, this);
}
Expandable.prototype = new Icinga.EventListener();
Expandable.prototype.onRendered = function(event) {
$(event.target).find('.expandable-toggle').each(function() {
var $this = $(this);
if (typeof expandedExpandables['#' + $this.attr('id')] !== 'undefined') {
$this.prop('checked', true);
}
});
};
Expandable.prototype.onClick = function(event) {
var $expandableToggle = $(event.target);
if ($expandableToggle.prop('checked')) {
expandedExpandables['#' + $expandableToggle.attr('id')] = null;
} else {
delete expandedExpandables['#' + $expandableToggle.attr('id')];
}
};
Icinga.Behaviors = Icinga.Behaviors || {};
Icinga.Behaviors.Expandable = Expandable;
}) (Icinga, jQuery);