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.
		
		
		
		
		
			
		
			
				
					
					
						
							136 lines
						
					
					
						
							5.4 KiB
						
					
					
				
			
		
		
	
	
							136 lines
						
					
					
						
							5.4 KiB
						
					
					
				/* | 
						|
 * Activiti Modeler component part of the Activiti project | 
						|
 * Copyright 2005-2014 Alfresco Software, Ltd. All rights reserved. | 
						|
 *  | 
						|
 * This library is free software; you can redistribute it and/or | 
						|
 * modify it under the terms of the GNU Lesser General Public | 
						|
 * License as published by the Free Software Foundation; either | 
						|
 * version 2.1 of the License, or (at your option) any later version. | 
						|
 * | 
						|
 * This library 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 | 
						|
 * Lesser General Public License for more details. | 
						|
 | 
						|
 * You should have received a copy of the GNU Lesser General Public | 
						|
 * License along with this library; if not, write to the Free Software | 
						|
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA | 
						|
 */ | 
						|
 | 
						|
angular.module('activitiModeler').controller('ActivitiSignalDefinitionsCtrl', ['$scope', '$modal', function ($scope, $modal) { | 
						|
 | 
						|
    // Config for the modal window | 
						|
    var opts = { | 
						|
        template: 'editor-app/configuration/properties/signal-definitions-popup.html?version=' + Date.now(), | 
						|
        scope: $scope | 
						|
    }; | 
						|
 | 
						|
    // Open the dialog | 
						|
    $modal(opts); | 
						|
}]); | 
						|
 | 
						|
//Need a separate controller for the modal window due to https://github.com/angular-ui/bootstrap/issues/259 | 
						|
// Will be fixed in a newer version of Angular UI | 
						|
angular.module('activitiModeler').controller('ActivitiSignalDefinitionsPopupCtrl', | 
						|
    ['$scope', '$q', '$translate', '$timeout', function ($scope, $q, $translate, $timeout) { | 
						|
 | 
						|
        // Put json representing signal definitions on scope | 
						|
        if ($scope.property.value !== undefined && $scope.property.value !== null && $scope.property.value.length > 0) { | 
						|
 | 
						|
            if ($scope.property.value.constructor == String) { | 
						|
                $scope.signalDefinitions = JSON.parse($scope.property.value); | 
						|
            } | 
						|
            else { | 
						|
                // Note that we clone the json object rather then setting it directly, | 
						|
                // this to cope with the fact that the user can click the cancel button and no changes should have happened | 
						|
                $scope.signalDefinitions = angular.copy($scope.property.value); | 
						|
            } | 
						|
 | 
						|
        } else { | 
						|
            $scope.signalDefinitions = []; | 
						|
        } | 
						|
 | 
						|
        // Array to contain selected signal definitions (yes - we only can select one, but ng-grid isn't smart enough) | 
						|
        $scope.selectedSignals = []; | 
						|
        $scope.translationsRetrieved = false; | 
						|
 | 
						|
        $scope.labels = {}; | 
						|
 | 
						|
        var idPromise = $translate('PROPERTY.SIGNALDEFINITIONS.ID'); | 
						|
        var namePromise = $translate('PROPERTY.SIGNALDEFINITIONS.NAME'); | 
						|
        var scopePromise = $translate('PROPERTY.SIGNALDEFINITIONS.SCOPE'); | 
						|
 | 
						|
        $q.all([idPromise, namePromise, scopePromise]).then(function (results) { | 
						|
 | 
						|
            $scope.labels.idLabel = results[0]; | 
						|
            $scope.labels.nameLabel = results[1]; | 
						|
            $scope.labels.scopeLabel = results[2]; | 
						|
            $scope.translationsRetrieved = true; | 
						|
 | 
						|
            // Config for grid | 
						|
            $scope.gridOptions = { | 
						|
                data: 'signalDefinitions', | 
						|
                headerRowHeight: 28, | 
						|
                enableRowSelection: true, | 
						|
                enableRowHeaderSelection: false, | 
						|
                multiSelect: false, | 
						|
                keepLastSelected : false, | 
						|
                selectedItems: $scope.selectedSignals, | 
						|
                columnDefs: [ | 
						|
                    {field: 'id', displayName: $scope.labels.idLabel}, | 
						|
                    {field: 'name', displayName: $scope.labels.nameLabel}, | 
						|
                    {field: 'scope', displayName: $scope.labels.scopeLabel}] | 
						|
            }; | 
						|
        }); | 
						|
 | 
						|
        // Click handler for add button | 
						|
        $scope.addNewSignalDefinition = function () { | 
						|
            var newSignalDefinition = {id: '', name: '', scope: 'global'}; | 
						|
 | 
						|
            $scope.signalDefinitions.push(newSignalDefinition); | 
						|
            $timeout(function () { | 
						|
            	$scope.gridOptions.selectItem($scope.signalDefinitions.length - 1, true); | 
						|
            }); | 
						|
        }; | 
						|
 | 
						|
        // Click handler for remove button | 
						|
        $scope.removeSignalDefinition = function () { | 
						|
            if ($scope.selectedSignals && $scope.selectedSignals.length > 0) { | 
						|
            	var index = $scope.signalDefinitions.indexOf($scope.selectedSignals[0]); | 
						|
                $scope.gridOptions.selectItem(index, false); | 
						|
                $scope.signalDefinitions.splice(index, 1); | 
						|
 | 
						|
                $scope.selectedSignals.length = 0; | 
						|
                if (index < $scope.signalDefinitions.length) { | 
						|
                    $scope.gridOptions.selectItem(index + 1, true); | 
						|
                } else if ($scope.signalDefinitions.length > 0) { | 
						|
                    $scope.gridOptions.selectItem(index - 1, true); | 
						|
                } | 
						|
            } | 
						|
        }; | 
						|
 | 
						|
        // Click handler for save button | 
						|
        $scope.save = function () { | 
						|
 | 
						|
            if ($scope.signalDefinitions.length > 0) { | 
						|
                $scope.property.value = $scope.signalDefinitions; | 
						|
            } else { | 
						|
                $scope.property.value = null; | 
						|
            } | 
						|
 | 
						|
            $scope.updatePropertyInModel($scope.property); | 
						|
            $scope.close(); | 
						|
        }; | 
						|
 | 
						|
        $scope.cancel = function () { | 
						|
            $scope.property.mode = 'read'; | 
						|
            $scope.$hide(); | 
						|
        }; | 
						|
 | 
						|
        // Close button handler | 
						|
        $scope.close = function () { | 
						|
            $scope.property.mode = 'read'; | 
						|
            $scope.$hide(); | 
						|
        }; | 
						|
 | 
						|
    }]); |