mirror of
https://github.com/ansible/awx.git
synced 2026-01-23 07:28:02 -03:30
60 lines
1.3 KiB
JavaScript
60 lines
1.3 KiB
JavaScript
const templateUrl = require('~components/layout/side-nav.partial.html');
|
|
|
|
let $document;
|
|
|
|
function atSideNavLink (scope, element, attrs, ctrl) {
|
|
scope.layoutVm = ctrl;
|
|
|
|
$document.on('click', (e) => {
|
|
if ($(e.target).parents('.at-Layout-side').length === 0) {
|
|
scope.$emit('clickOutsideSideNav');
|
|
}
|
|
});
|
|
}
|
|
|
|
function AtSideNavController ($scope, $window) {
|
|
const vm = this || {};
|
|
const breakpoint = 700;
|
|
|
|
vm.isExpanded = false;
|
|
|
|
vm.toggleExpansion = () => {
|
|
vm.isExpanded = !vm.isExpanded;
|
|
};
|
|
|
|
$scope.$watch('layoutVm.currentState', () => {
|
|
if ($window.innerWidth <= breakpoint) {
|
|
vm.isExpanded = false;
|
|
}
|
|
});
|
|
|
|
$scope.$on('clickOutsideSideNav', () => {
|
|
if ($window.innerWidth <= breakpoint) {
|
|
vm.isExpanded = false;
|
|
}
|
|
});
|
|
}
|
|
|
|
AtSideNavController.$inject = ['$scope', '$window'];
|
|
|
|
function atSideNav (_$document_) {
|
|
$document = _$document_;
|
|
|
|
return {
|
|
restrict: 'E',
|
|
replace: true,
|
|
require: '^^atLayout',
|
|
controller: AtSideNavController,
|
|
controllerAs: 'vm',
|
|
link: atSideNavLink,
|
|
transclude: true,
|
|
templateUrl,
|
|
scope: {
|
|
}
|
|
};
|
|
}
|
|
|
|
atSideNav.$inject = ['$document'];
|
|
|
|
export default atSideNav;
|