OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
openproject/app/assets/javascripts/angular/timelines/directives/timeline-container-directiv...

89 lines
3.2 KiB

//-- copyright
// OpenProject is a project management system.
// Copyright (C) 2012-2014 the OpenProject Foundation (OPF)
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License version 3.
//
// OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
// Copyright (C) 2006-2013 Jean-Philippe Lang
// Copyright (C) 2010-2013 the ChiliProject Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//
// See doc/COPYRIGHT.rdoc for more details.
//++
angular.module('openproject.timelines.directives')
.directive('timelineContainer', ['$window', 'Timeline', function($window, Timeline) {
var getInitialOutlineExpansion = function(timelineOptions) {
var initialOutlineExpansion = timelineOptions.initial_outline_expansion;
if (initialOutlineExpansion && initialOutlineExpansion >= 0) {
return initialOutlineExpansion;
} else {
return 0;
}
};
setTimelinesWidth = function(scope) {
var contentElement = angular.element('#content');
if (contentElement.length > 0) {
scope.timelineWidth = contentElement.width();
}
};
return {
restrict: 'E',
replace: true,
controller: ['$scope', function($scope) {
this.showError = function(errorMessage) {
$scope.errorMessage = errorMessage;
};
}],
transclude: true,
template: '<div ng-style="{ width: timelineWidth }">' +
'<div ng-hide="!!errorMessage" ng-transclude id="{{timelineContainerElementId}}"/>' +
'<div ng-if="!!errorMessage" ng-bind="errorMessage" class="flash error"/>' +
'</div>',
link: function(scope) {
scope.timelineContainerElementId = 'timeline-container-' + (++scope.timelineContainerCount);
// Hide charts until tables are drawn
scope.underConstruction = true;
// Create timeline object
scope.timeline = Timeline.create(scope.timelineOptions);
// Set initial expansion index
scope.timeline.expansionIndex = getInitialOutlineExpansion(scope.timelineOptions);
// As part of a wiki the timeline container would have to stick to the wiki's width
// limitation. We set the timeline width programmatically to bypass the width
// limitation.
if (angular.element('.wiki-content').length > 0) {
setTimelinesWidth(scope);
angular.element($window).bind('resize', function() {
scope.$apply(function() {
setTimelinesWidth(scope);
});
});
}
}
};
}]);