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/components/wp-relations/wp-relations.directive.ts

148 lines
4.6 KiB

//-- copyright
// OpenProject is a project management system.
// Copyright (C) 2012-2015 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.
//++
import {wpTabsModule} from '../../angular-modules';
import {WorkPackageRelationGroup} from './wp-relation-group/wp-relation-group.service';
import {WorkPackageNotificationService} from '../wp-edit/wp-notification.service';
import {WorkPackageResource} from '../api/api-v3/hal-resources/work-package-resource.service';
const iconArrowClasses = ['icon-arrow-up1', 'icon-arrow-down1'];
export class WorkPackageRelationsController {
public btnTitle:string;
public btnIcon:string = '<i class="icon-hierarchy icon-add"></i>';
public workPackage:WorkPackageResource;
public relationGroup:WorkPackageRelationGroup;
public focusElementIndex:number = -2;
public wpToAddId:number = null;
public expand:boolean = false;
public text:any;
private _initialExpand:boolean;
public get stateClass():string {
return iconArrowClasses[+!!this.expand];
}
public get groupExpanded() {
if (angular.isUndefined(this._initialExpand) && !this.relationGroup.isEmpty) {
this._initialExpand = this.expand = !this.relationGroup.isEmpty;
}
return this.expand;
}
constructor(protected $scope,
protected I18n,
protected wpNotificationsService:WorkPackageNotificationService,
protected NotificationsService) {
this.text = {
title: I18n.t('js.relation_labels.' + this.relationGroup.id),
table: {
subject: I18n.t('js.work_packages.properties.subject'),
status: I18n.t('js.work_packages.properties.status'),
assignee: I18n.t('js.work_packages.properties.assignee')
},
relations: {
empty: I18n.t('js.relations.empty'),
remove: I18n.t('js.relations.remove')
}
};
if (this.relationGroup.id === 'parent') {
this.btnIcon = '<i class="icon-hierarchy icon-edit"></i>';
}
}
public addRelation() {
this.relationGroup.addWpRelation(this.wpToAddId)
.then(() => {
this.wpToAddId = null;
this.handleSuccess(-1);
})
.catch(error => this.wpNotificationsService.handleErrorResponse(error, this.workPackage));
}
public canRemoveRelation(relation?):boolean {
return this.relationGroup.canRemoveRelation(relation);
}
public removeRelation(relation) {
this.relationGroup.removeWpRelation(relation)
.then(index => {
this.handleSuccess(index);
})
.catch(error => this.wpNotificationsService.handleErrorResponse(error, this.workPackage));
}
public toggleExpand() {
this.expand = !this.expand;
}
public isFocused(index:number) {
return index === this.focusElementIndex;
}
public updateFocus(index:number) {
var length = this.relationGroup.relations.length;
if (length == 0) {
this.focusElementIndex = -1;
}
else {
this.focusElementIndex = (index < length) ? index : length - 1;
}
this.$scope.$evalAsync(() => this.$scope.$broadcast('updateFocus'));
}
private handleSuccess(index) {
this.updateFocus(index);
this.$scope.$emit('workPackagesRefreshInBackground');
}
}
function wpRelationsDirective() {
return {
restrict: 'E',
replace: true,
templateUrl: '/components/wp-relations/wp-relations.directive.html',
scope: {
relationGroup: '=',
workPackage: '=',
btnTitle: '=buttonTitle',
},
controller: WorkPackageRelationsController,
controllerAs: '$ctrl',
bindToController: true,
};
}
wpTabsModule.directive('wpRelations', wpRelationsDirective);