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.
		
		
		
		
		
			
		
			
				
					
					
						
							288 lines
						
					
					
						
							8.7 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							288 lines
						
					
					
						
							8.7 KiB
						
					
					
				| /* Licensed under the Apache License, Version 2.0 (the "License"); | |
|  * you may not use this file except in compliance with the License. | |
|  * You may obtain a copy of the License at | |
|  * | |
|  *      http://www.apache.org/licenses/LICENSE-2.0 | |
|  * | |
|  * Unless required by applicable law or agreed to in writing, software | |
|  * distributed under the License is distributed on an "AS IS" BASIS, | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
|  * See the License for the specific language governing permissions and | |
|  * limitations under the License. | |
|  */ | |
| 'use strict'; | |
| 
 | |
| angular.module('flowableModeler') | |
|   .controller('AppDefinitionsCtrl', ['$rootScope', '$scope', '$translate', '$http', '$timeout','$location', '$modal', function ($rootScope, $scope, $translate, $http, $timeout, $location, $modal) { | |
| 
 | |
|       // Main page (needed for visual indicator of current page) | |
|       $rootScope.setMainPageById('apps'); | |
| 
 | |
| 	  $scope.model = { | |
|         filters: [ | |
|             {id: 'apps', labelKey: 'APPS'} | |
| 		], | |
| 
 | |
| 		sorts: [ | |
| 	        {id: 'modifiedDesc', labelKey: 'MODIFIED-DESC'}, | |
| 	        {id: 'modifiedAsc', labelKey: 'MODIFIED-ASC'}, | |
| 	        {id: 'nameAsc', labelKey: 'NAME-ASC'}, | |
| 	        {id: 'nameDesc', labelKey: 'NAME-DESC'} | |
| 		] | |
| 	  }; | |
| 
 | |
| 	  if ($rootScope.appFilter) { | |
| 		  $scope.model.activeFilter = $rootScope.appFilter.filter; | |
| 		  $scope.model.activeSort = $rootScope.appFilter.sort; | |
| 		  $scope.model.filterText = $rootScope.appFilter.filterText; | |
| 
 | |
| 	  } else { | |
| 		  // By default, show first filter and use first sort | |
| 	      $scope.model.activeFilter = $scope.model.filters[0]; | |
| 	      $scope.model.activeSort = $scope.model.sorts[0]; | |
| 	      $rootScope.appFilter = { | |
| 	    		  filter: $scope.model.activeFilter, | |
| 	    		  sort: $scope.model.activeSort, | |
| 	    		  filterText: '' | |
| 	      }; | |
| 	  } | |
| 
 | |
| 	  $scope.activateFilter = function(filter) { | |
| 		  $scope.model.activeFilter = filter; | |
| 		  $rootScope.appFilter.filter = filter; | |
| 		  $scope.loadApps(); | |
| 	  }; | |
| 
 | |
| 	  $scope.activateSort = function(sort) { | |
| 		  $scope.model.activeSort = sort; | |
| 		  $rootScope.appFilter.sort = sort; | |
| 		  $scope.loadApps(); | |
| 	  }; | |
| 
 | |
| 	  $scope.loadApps = function() { | |
| 		  $scope.model.loading = true; | |
| 
 | |
| 		  var params = { | |
| 		      filter: $scope.model.activeFilter.id, | |
| 		      sort: $scope.model.activeSort.id, | |
| 		      modelType: 3 | |
| 		  }; | |
| 
 | |
| 		  if ($scope.model.filterText && $scope.model.filterText != '') { | |
| 		    params.filterText = $scope.model.filterText; | |
| 		  } | |
| 
 | |
| 		  $http({method: 'GET', url: FLOWABLE.APP_URL.getModelsUrl(), params: params}). | |
| 		  	success(function(data, status, headers, config) { | |
| 	    		$scope.model.apps = data; | |
| 	    		$scope.model.loading = false; | |
| 	        }). | |
| 	        error(function(data, status, headers, config) { | |
| 	           $scope.model.loading = false; | |
| 	        }); | |
| 	  }; | |
| 
 | |
| 	  var timeoutFilter = function() { | |
| 	    $scope.model.isFilterDelayed = true; | |
| 	    $timeout(function() { | |
| 	        $scope.model.isFilterDelayed = false; | |
| 	        if($scope.model.isFilterUpdated) { | |
| 	          $scope.model.isFilterUpdated = false; | |
| 	          timeoutFilter(); | |
| 	        } else { | |
| 	          $scope.model.filterText = $scope.model.pendingFilterText; | |
| 	          $rootScope.appFilter.filterText = $scope.model.filterText; | |
| 	          $scope.loadApps(); | |
| 	        } | |
| 	    }, 500); | |
| 	  }; | |
| 
 | |
| 	  $scope.filterDelayed = function() { | |
| 	    if($scope.model.isFilterDelayed) { | |
| 	      $scope.model.isFilterUpdated = true; | |
| 	    } else { | |
| 	      timeoutFilter(); | |
| 	    } | |
| 	  }; | |
| 
 | |
| 	  $scope.createApp = function() { | |
| 
 | |
|           _internalCreateModal({ | |
| 			  template: 'views/popup/app-definition-create.html?version=' + Date.now(), | |
| 			  scope: $scope | |
| 		  }, $modal, $scope); | |
| 	  }; | |
| 
 | |
| 	  $scope.showAppDetails = function(app) { | |
| 	    if (app) { | |
| 	      $location.path("/apps/" + app.id); | |
| 	    } | |
| 	  }; | |
| 
 | |
| 	  $scope.editAppDetails = function(app) { | |
|         if (app) { | |
|           $location.path("/app-editor/" + app.id); | |
|         } | |
|       }; | |
| 
 | |
|       $scope.importAppDefinition = function () { | |
|           _internalCreateModal({ | |
|               template: 'views/popup/app-definitions-import.html?version=' + Date.now() | |
|           }, $modal, $scope); | |
|       }; | |
| 
 | |
| 	  // Finally, load initial forms | |
| 	  $scope.loadApps(); | |
|   }]); | |
| 
 | |
| 
 | |
| angular.module('flowableModeler') | |
|     .controller('CreateNewAppCtrl', ['$rootScope', '$scope', '$http', '$location', '$translate', function ($rootScope, $scope, $http, $location, $translate) { | |
| 
 | |
|         $scope.model = { | |
|             loading: false, | |
|             app: { | |
|                 name: '', | |
|                 key: '', | |
|                 description: '', | |
|                 modelType: 3 | |
|             } | |
|         }; | |
| 
 | |
|         $scope.ok = function () { | |
| 
 | |
|             if (!$scope.model.app.name || $scope.model.app.name.length == 0 || | |
|             	!$scope.model.app.key || $scope.model.app.key.length == 0) { | |
|             	 | |
|                 return; | |
|             } | |
| 
 | |
|             $scope.model.loading = true; | |
| 
 | |
|             $http({method: 'POST', url: FLOWABLE.APP_URL.getModelsUrl(), data: $scope.model.app}). | |
|                 success(function (data, status, headers, config) { | |
|                     $scope.$hide(); | |
| 
 | |
|                     $scope.model.loading = false; | |
|                     $location.path("/app-editor/" + data.id); | |
| 
 | |
|                 }). | |
|                 error(function (response, status, headers, config) { | |
|                     $scope.model.loading = false; | |
| 					 | |
| 					if (response && response.message && response.message.length > 0) { | |
| 						$scope.model.errorMessage = response.message; | |
| 					} | |
|                 }); | |
|         }; | |
| 
 | |
|         $scope.cancel = function () { | |
|             if (!$scope.model.loading) { | |
|                 $scope.$hide(); | |
|             } | |
|         }; | |
|     }]); | |
| 
 | |
| angular.module('flowableModeler') | |
|     .controller('DuplicateAppCtrl', ['$rootScope', '$scope', '$http', '$location', '$translate', function ($rootScope, $scope, $http, $location, $translate) { | |
| 
 | |
|         $scope.model = { | |
|             loading: false, | |
|             app: { | |
|                 id: '', | |
|                 name: '', | |
|                 key: '', | |
|                 description: '', | |
|                 modelType: 3 | |
|             } | |
|         }; | |
| 
 | |
|         if ($scope.originalModel) { | |
|             //clone the model | |
|             $scope.model.app.name = $scope.originalModel.app.name; | |
|             $scope.model.app.key = $scope.originalModel.app.key; | |
|             $scope.model.app.description = $scope.originalModel.app.description; | |
|             $scope.model.app.modelType = $scope.originalModel.app.modelType; | |
|             $scope.model.app.id = $scope.originalModel.app.id; | |
|         } | |
| 
 | |
|         $scope.ok = function () { | |
| 
 | |
|             if (!$scope.model.app.name || $scope.model.app.name.length == 0) { | |
|                 return; | |
|             } | |
| 
 | |
|             $scope.model.loading = true; | |
| 
 | |
|             $http({method: 'POST', url: FLOWABLE.APP_URL.getCloneModelsUrl($scope.model.app.id), data: $scope.model.app}). | |
|                 success(function (data, status, headers, config) { | |
|                     $scope.$hide(); | |
| 
 | |
|                     $scope.model.loading = false; | |
|                     $location.path("/app-editor/" + data.id); | |
| 
 | |
|                 }). | |
|                 error(function (response, status, headers, config) { | |
|                     $scope.model.loading = false; | |
|                     $scope.model.errorMessage = response.message; | |
|                 }); | |
|         }; | |
| 
 | |
|         $scope.cancel = function () { | |
|             if (!$scope.model.loading) { | |
|                 $scope.$hide(); | |
|             } | |
|         }; | |
|     }]); | |
| 
 | |
| angular.module('flowableModeler') | |
| .controller('ImportAppDefinitionCtrl', ['$rootScope', '$scope', '$http', 'Upload', '$location', function ($rootScope, $scope, $http, Upload, $location) { | |
| 
 | |
|   $scope.model = { | |
|        loading: false, | |
|        renewIdmIds: false | |
|   }; | |
| 
 | |
|   $scope.onFileSelect = function($files, isIE) { | |
| 
 | |
|       for (var i = 0; i < $files.length; i++) { | |
|           var file = $files[i]; | |
| 
 | |
|           var url; | |
|           if (isIE) { | |
|              url = FLOWABLE.APP_URL.getAppDefinitionTextImportUrl($scope.model.renewIdmIds); | |
|           } else { | |
|               url = FLOWABLE.APP_URL.getAppDefinitionImportUrl($scope.model.renewIdmIds); | |
|           } | |
|           Upload.upload({ | |
|               url: url, | |
|               method: 'POST', | |
|               file: file | |
|           }).progress(function(evt) { | |
| 	      $scope.model.loading = true; | |
|               $scope.model.uploadProgress = parseInt(100.0 * evt.loaded / evt.total); | |
| 
 | |
|           }).success(function(data, status, headers, config) { | |
|               $scope.model.loading = false; | |
| 
 | |
|               $location.path("/apps/" + data.id); | |
|               $scope.$hide(); | |
| 
 | |
|           }).error(function(data, status, headers, config) { | |
| 
 | |
|               if (data && data.message) { | |
|                   $scope.model.errorMessage = data.message; | |
|               } | |
| 
 | |
|               $scope.model.error = true; | |
|               $scope.model.loading = false; | |
|           }); | |
|       } | |
|   }; | |
| 
 | |
|   $scope.cancel = function () { | |
|       if(!$scope.model.loading) { | |
|           $scope.$hide(); | |
|       } | |
|   }; | |
| }]);
 | |
| 
 |