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/frontend/app/timelines/directives/timeline-container-directiv...

69 lines
2.5 KiB

//-- copyright
// OpenProject is a project management system.
// Copyright (C) 2012-2017 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-2017 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.
//++
module.exports = function($window, Timeline) {
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;
};
}],
scope: { timelineId: '@' },
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.timelineId;
// 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);
});
});
}
}
};
};