123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 |
- 'use strict';
- /**
- * controllers for process
- */
- app.controller('processDefinedCtrl', ["$scope", "$stateParams", "$modal", "Restangular", "SweetAlert", "api_bpm", function ($scope, $stateParams, $modal, Restangular, SweetAlert, api_bpm) {
-
- console.log($stateParams);
- if(angular.isString($stateParams.modelId)&&$stateParams.modelId!=""){
- $scope.modelId = $stateParams.modelId;
- api_bpm.modelsource($stateParams.modelId).then(function(data){
- if(data){
- var myData = Restangular.stripRestangular(data);
- if(myData.data){
- bpmnJS.openDiagram(myData.data);
- }
- }
- });
- }
- var bpmnJS= new window.BpmnJS({
- container: angular.element('#js-drop-zone'),
- canvas:angular.element('#js-canvas'),
- propertiesPanel: angular.element('#js-properties-panel')
- });
- $scope.createNewDiagram = function(){
- bpmnJS.createNewDiagram();
- }
- $scope.openDiagram = function(xml){
- bpmnJS.openDiagram(xml);
- }
- var setEncoded = function(link, name, data) {
- var encodedData = encodeURIComponent(data);
- if (data) {
- link.addClass('active').attr({
- 'href': 'data:application/bpmn20-xml;charset=UTF-8,' + encodedData,
- 'download': name
- });
- } else {
- link.removeClass('active');
- }
- }
- $scope.downloadDiagram = function(){
- bpmnJS.saveDiagram(function(err, xml) {
- setEncoded(angular.element('#js-download-diagram'), 'diagram.bpmn', err ? null : xml);
- });
- }
- $scope.deploy = function(){
- bpmnJS.saveDiagram(function(err, xml) {
- if(err){
- }else{
- var data = {
- 'json_xml':xml
- };
- if(angular.isDefined($scope.modelId)){
- data.modelId=$scope.modelId;
- api_bpm.deploy(data).then(function(response){
- console.log(response);
- });
- }else{
- var modalInstance = $modal.open({
- templateUrl: 'assets/views/process/tpl/modal_process.html',
- controller: function($scope, $modalInstance, title, Alert){
- $scope.title = title;
- $scope.ok = function() {
- if(angular.isUndefined($scope.data.key)||$scope.data.key==""){
- Alert.swal({
- title: "流程信息不能为空",
- text: "请将相关信息填写完全!",
- type: "error"
- });
- }else{
- $modalInstance.close($scope.data);
- }
- }
- $scope.cancel = function() {
- $modalInstance.dismiss('cancel');
- };
- },
- size:'sm',
- resolve: {
- title: function(){
- return "配置流程属性";
- },
- Alert: function(){
- return SweetAlert;
- }
- }
- });
- modalInstance.result.then(function(processData) {
- if(processData){
- angular.extend(processData, data);
- api_bpm.deploy(data).then(function(response){
- console.log(response);
- });
- }else{
- }
- });
- }
- }
- });
- }
- $scope.save = function(){
- bpmnJS.saveDiagram(function(err, xml) {
- if(err){
- }else{
- var data = {
- 'json_xml':xml
- };
- if(angular.isDefined($scope.modelId)){
- var modelId=$scope.modelId;
- api_bpm.savemodel(modelId, data).then(function(response){
- console.log(response);
- });
- }else{
- console.log()
- }
-
- }
- });
- }
- if (!window.FileList || !window.FileReader) {
- window.alert(
- 'Looks like you use an older browser that does not support drag and drop. ' +
- 'Try using Chrome, Firefox or the Internet Explorer > 10.');
- } else {
- bpmnJS.registerFileDrop(angular.element('#js-drop-zone'), bpmnJS.openDiagram);
- }
- }]);
- app.controller('processDefinedListCtrl', ["$scope", "$state", "$timeout", "$interval", "SweetAlert", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm", function ($scope, $state, $timeout, $interval, SweetAlert, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm) {
- $scope.gridOptions = {};
- $scope.gridOptions.data = 'myData';
- $scope.gridOptions.enableColumnResizing = true;
- $scope.gridOptions.enableFiltering = true;
- $scope.gridOptions.enableGridMenu = true;
- $scope.gridOptions.showGridFooter = true;
- $scope.gridOptions.showColumnFooter = true;
- $scope.gridOptions.fastWatch = true;
- $scope.gridOptions.rowIdentity = function(row) {
- return row.id;
- };
- $scope.gridOptions.getRowIdentity = function(row) {
- return row.id;
- };
- $scope.gridOptions.columnDefs = [
- { name:'id', width:100, enableFiltering:false},
- { name:'deploymentId', displayName:'部署Id', width:100, enableFiltering:false},
- { name:'name', displayName:'名称', width:100 },
- { name:'key', displayName:'KEY', width:200 },
- { name:'version', displayName:'版本号', width:100},
- { name:'最后更新时间',field:'lastUpdateTime', cellFilter:'date', width:150, type:'date', enableFiltering:false },
- { name:'创建时间',field:'createTime', cellFilter: 'date', width:150, type:'date', enableFiltering:false},
- { name:'操作', cellTemplate:'<a class="btn btn-sm btn-info" ng-click="grid.appScope.pdList.selectRowFunction(row.entity)"><i class="fa fa-pencil-square-o"/></a><a class="btn btn-sm btn-warning" ng-click="grid.appScope.pdList.removeRowFunction(row.entity)"><i class="fa fa-trash"/></a>', enableFiltering:false}
- ];
- $scope.gridOptions.importerDataAddCallback = function( grid, newObjects ) {
- $scope.myData = $scope.myData.concat( newObjects );
- };
- $scope.gridOptions.onRegisterApi = function(gridApi){
- $scope.gridApi = gridApi;
- //gridApi.selection.on.rowSelectionChanged($scope, selectRowFunction);
- };
- this.selectRowFunction = function(data){
- console.log(data);
- $state.go('app.process.modeler',{modelId:data.id});
- };
- this.removeRowFunction = function(data){
- //TODO $translate('key')
- SweetAlert.swal({
- title: "确认删除?",
- text: "删除以后,你将不能恢复该数据!",
- type: "warning",
- cancelButtonText: "取消",
- showCancelButton: true,
- confirmButtonColor: "#DD6B55",
- confirmButtonText: "确认删除!"
- }, function (isConfirm) {
- if (isConfirm) {
- api_bpm.removemodel(data.id).then(function(response){
- if(response){
- $scope.refreshData();
- SweetAlert.swal({
- title: "删除成功!",
- confirmButtonColor: "#007AFF"
- });
- }
- });
- }else{
-
- }
-
- });
-
- }
- $scope.callsPending = 0;
- var i = 0;
- $scope.refreshData = function(){
- $scope.myData = [];
- var start = new Date();
- var sec = $interval(function () {
- $scope.callsPending++;
- api_bpm.list().then(function(data){
- $scope.callsPending--;
- var myData = Restangular.stripRestangular(data);
- $scope.myData = myData.data;
- });
- }, 200, 10);
- var timeout = $timeout(function() {
- $interval.cancel(sec);
- $scope.left = '';
- }, 2000);
- $scope.$on('$destroy', function(){
- $timeout.cancel(timeout);
- $interval.cancel(sec);
- });
- };
- $scope.refreshData();
- }]);
|