/* 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. */ angular.module('flowableModeler') .controller('AppDefinitionCtrl', ['$rootScope', '$scope', '$translate', '$http', '$location', '$routeParams', '$modal', '$popover', '$timeout', function ($rootScope, $scope, $translate, $http, $location, $routeParams, $modal, $popover, $timeout) { // Main page (needed for visual indicator of current page) $rootScope.setMainPageById('apps'); // Initialize model $scope.model = { // Store the main model id, this points to the current version of a model, // even when we're showing history latestModelId: $routeParams.modelId, activeTab: 'bpmn' }; $scope.tabs = [ { id: 'bpmn', title: 'BPMN models' }, { id: 'cmmn', title: 'CMMN models' } ]; $scope.loadApp = function() { var url; var definitionUrl; if ($routeParams.modelHistoryId) { url = FLOWABLE.APP_URL.getModelHistoryUrl($routeParams.modelId, $routeParams.modelHistoryId); definitionUrl = FLOWABLE.APP_URL.getAppDefinitionHistoryUrl($routeParams.modelId, $routeParams.modelHistoryId); } else { url = FLOWABLE.APP_URL.getModelUrl($routeParams.modelId); definitionUrl = FLOWABLE.APP_URL.getAppDefinitionUrl($routeParams.modelId); $scope.model.appExportUrl = FLOWABLE.APP_URL.getAppDefinitionExportUrl($routeParams.modelId); $scope.model.appBarExportUrl = FLOWABLE.APP_URL.getAppDefinitionBarExportUrl($routeParams.modelId); } $http({method: 'GET', url: url}). success(function(data, status, headers, config) { $scope.model.app = data; $scope.loadVersions(); }).error(function(data, status, headers, config) { $scope.returnToList(); }); $http({method: 'GET', url: definitionUrl}). success(function(data, status, headers, config) { $scope.model.appDefinition = data; }); }; $scope.useAsNewVersion = function() { _internalCreateModal({ template: 'views/popup/model-use-as-new-version.html', scope: $scope }, $modal, $scope); }; $scope.loadVersions = function() { var params = { includeLatestVersion: !$scope.model.app.latestVersion }; $http({method: 'GET', url: FLOWABLE.APP_URL.getModelHistoriesUrl($scope.model.latestModelId), params: params}). success(function(data, status, headers, config) { if ($scope.model.app.latestVersion) { if (!data.data) { data.data = []; } data.data.unshift($scope.model.app); } $scope.model.versions = data; }); }; $scope.showVersion = function(version) { if (version) { if (version.latestVersion) { $location.path("/apps/" + $scope.model.latestModelId); } else { // Show latest version, no history-suffix needed in URL $location.path("/apps/" + $scope.model.latestModelId + "/history/" + version.id); } } }; $scope.returnToList = function() { $location.path("/apps/"); }; $scope.openEditor = function() { $location.path("/app-editor/" + $scope.model.latestModelId); }; $scope.editApp = function() { _internalCreateModal({ template: 'views/popup/model-edit.html', scope: $scope }, $modal, $scope); }; $scope.duplicateApp = function () { var modalInstance = _internalCreateModal({ template: 'views/popup/app-definition-duplicate.html?version=' + Date.now() }, $modal, $scope); modalInstance.$scope.originalModel = $scope.model; }; $scope.deleteApp = function() { // User is owner of the app definition and the app definition is deployed /*_internalCreateModal({ template: 'views/popup/app-definition-delete.html?version=' + Date.now(), scope: $scope }, $modal, $scope);*/ _internalCreateModal({ template: 'views/popup/model-delete.html?version=' + Date.now(), scope: $scope }, $modal, $scope); }; $scope.publish = function() { _internalCreateModal({ template: 'views/popup/app-definition-publish.html?version=' + Date.now(), scope: $scope }, $modal, $scope); }; $scope.shareApp = function() { _internalCreateModal({ template: 'views/popup/model-share.html?version=' + Date.now(), scope: $scope }, $modal, $scope); }; $scope.importAppDefinition = function () { _internalCreateModal({ template: 'views/popup/app-definition-import.html?version=' + Date.now(), scope: $scope }, $modal, $scope); }; $scope.toggleHistory = function($event) { if(!$scope.historyState) { var state = {}; $scope.historyState = state; // Create popover state.popover = $popover(angular.element($event.target), { template: 'views/popover/history.html', placement: 'bottom-right', show: true, scope: $scope, container: 'body' }); var destroy = function() { state.popover.destroy(); delete $scope.historyState; }; // When popup is hidden or scope is destroyed, hide popup state.popover.$scope.$on('tooltip.hide', destroy); $scope.$on('$destroy', destroy); } }; $scope.loadApp(); }]); angular.module('flowableModeler') .controller('PublishAppDefinitionPopupCtrl', ['$rootScope', '$scope', '$http', '$route', '$translate', function ($rootScope, $scope, $http, $route, $translate) { $scope.popup = { loading: false, comment: '' }; $scope.ok = function (force) { $scope.popup.loading = true; var data = { comment: $scope.popup.comment }; if (force !== undefined && force !== null && force === true) { data.force = true; } delete $scope.popup.error; $http({method: 'POST', url: FLOWABLE.APP_URL.getAppDefinitionPublishUrl($scope.model.app.id), data: data}). success(function(data, status, headers, config) { $scope.$hide(); if (data.error) { $scope.popup.loading = false; $scope.addAlert(data.errorDescription, 'error'); } else { $scope.popup.loading = false; $route.reload(); $scope.addAlertPromise($translate('APP.ALERT.PUBLISH-CONFIRM'), 'info'); } }). error(function(data, status, headers, config) { $scope.popup.loading = false; $scope.$hide(); $scope.addAlertPromise($translate('APP.ALERT.PUBLISH-ERROR'), 'error'); }); }; $scope.cancel = function () { if (!$scope.popup.loading) { $scope.$hide(); } }; }]); angular.module('flowableModeler') .controller('DeleteAppDefinitionPopupCtrl', ['$rootScope', '$scope', '$http', '$translate', function ($rootScope, $scope, $http, $translate) { $scope.popup = { loading: false, cascade: 'false' }; $scope.ok = function () { $scope.popup.loading = true; var params = { // Explicit string-check because radio-values cannot be js-booleans cascade : $scope.popup.cascade === 'true', deleteRuntimeApp: true }; $http({method: 'DELETE', url: FLOWABLE.APP_URL.getModelUrl($scope.model.app.id), params: params}). success(function(data, status, headers, config) { $scope.$hide(); $scope.popup.loading = false; $scope.addAlertPromise($translate('APP.ALERT.DELETE-CONFIRM'), 'info'); $scope.returnToList(); }). error(function(data, status, headers, config) { $scope.$hide(); $scope.popup.loading = false; }); }; $scope.cancel = function () { if (!$scope.popup.loading) { $scope.$hide(); } }; }]); angular.module('flowableModeler') .controller('ImportNewVersionAppDefinitionCtrl', ['$rootScope', '$scope', '$http', 'Upload', '$route', function ($rootScope, $scope, $http, Upload, $route) { $scope.popup = { loading: false, renewIdmIds: false }; $scope.onFileSelect = function($files, isIE) { $scope.popup.loading = true; for (var i = 0; i < $files.length; i++) { var file = $files[i]; var url; if (isIE) { url = FLOWABLE.APP_URL.getAppDefinitionModelTextImportUrl($scope.model.app.id, $scope.popup.renewIdmIds); } else { url = FLOWABLE.APP_URL.getAppDefinitionModelImportUrl($scope.model.app.id, $scope.popup.renewIdmIds); } Upload.upload({ url: url, method: 'POST', file: file }).progress(function(evt) { $scope.popup.uploadProgress = parseInt(100.0 * evt.loaded / evt.total); }).success(function(data, status, headers, config) { $scope.popup.loading = false; $route.reload(); $scope.$hide(); }).error(function(data, status, headers, config) { if (data && data.message) { $scope.popup.errorMessage = data.message; } $scope.popup.error = true; $scope.popup.loading = false; }); } }; $scope.cancel = function () { if (!$scope.popup.loading) { $scope.$hide(); } }; }]);