tellform/public/modules/forms/directives/edit-submissions-form.client.directive.js

121 lines
5.3 KiB
JavaScript
Raw Normal View History

2015-08-18 21:44:36 +00:00
'use strict';
2016-04-28 23:47:50 +00:00
angular.module('forms').directive('editSubmissionsFormDirective', ['$rootScope', '$http',
2016-04-27 20:02:01 +00:00
function ($rootScope, $http) {
2015-08-18 21:44:36 +00:00
return {
2016-04-27 20:02:01 +00:00
templateUrl: 'modules/forms/views/directiveViews/form/edit-submissions-form.client.view.html',
2015-08-18 21:44:36 +00:00
restrict: 'E',
scope: {
myform:'=',
user:'='
},
controller: function($scope){
$scope.table = {
masterChecker: false,
rows: []
2015-08-18 21:44:36 +00:00
};
/*
** Table Functions
*/
$scope.isAtLeastOneChecked = function(){
for(var i=0; i<$scope.table.rows.length; i++){
if($scope.table.rows[i].selected) return true;
}
return false;
};
$scope.toggleAllCheckers = function(){
for(var i=0; i<$scope.table.rows.length; i++){
$scope.table.rows[i].selected = $scope.table.masterChecker;
}
};
$scope.toggleObjSelection = function($event, description) {
$event.stopPropagation();
};
$scope.rowClicked = function(row_index) {
$scope.table.rows[row_index].selected = !$scope.table.rows[row_index].selected;
};
/*
* Form Submission Methods
*/
//Fetch and display submissions of Form
$scope.initFormSubmissions = function(){
$http.get('/forms/'+$scope.myform._id+'/submissions')
.success(function(data, status, headers){
var _tmpSubFormFields,
defaultFormFields = _.cloneDeep($scope.myform.form_fields);
2015-11-12 22:24:26 +00:00
// console.log('before textField2: '+data[0].form_fields[1].fieldValue);
2016-04-28 23:47:50 +00:00
//Iterate through form's submissions
for(var i=0; i<data.length; i++){
2015-11-12 22:24:26 +00:00
for(var x=0; x<data[i].form_fields; x++){
2016-04-17 02:45:17 +00:00
var oldValue = data[i].form_fields[x].fieldValue || '';
2015-11-12 22:24:26 +00:00
data[i].form_fields[x] = _.merge(defaultFormFields, data[i].form_fields);
data[i].form_fields[x].fieldValue = oldValue;
}
data[i].selected = false;
}
2015-11-12 22:24:26 +00:00
// console.log('after textField2: '+data[0].form_fields[1].fieldValue);
$scope.table.rows = data;
// console.log('form submissions successfully fetched');
// console.log( JSON.parse(JSON.stringify($scope.submissions)) ) ;
// console.log( JSON.parse(JSON.stringify($scope.myform.form_fields)) );
})
.error(function(err){
console.error('Could not fetch form submissions.\nError: '+err);
2016-04-28 23:47:50 +00:00
});
};
2015-09-15 22:21:49 +00:00
2015-08-18 21:44:36 +00:00
//Delete selected submissions of Form
$scope.deleteSelectedSubmissions = function(){
2015-08-18 21:44:36 +00:00
var delete_ids = _.chain($scope.table.rows).filter(function(row){
return !!row.selected;
}).pluck('_id').value();
2016-04-28 23:47:50 +00:00
$http({ url: '/forms/'+$scope.myform._id+'/submissions',
2015-08-18 21:44:36 +00:00
method: 'DELETE',
data: {deleted_submissions: delete_ids},
headers: {'Content-Type': 'application/json;charset=utf-8'}
}).success(function(data, status, headers){
//Remove deleted ids from table
var tmpArray = [];
for(var i=0; i<$scope.table.rows.length; i++){
if(!$scope.table.rows[i].selected){
tmpArray.push($scope.table.rows[i]);
}
}
$scope.table.rows = tmpArray;
})
.error(function(err){
console.log('Could not delete form submissions.\nError: ');
console.log(err);
console.error = err;
2016-04-28 23:47:50 +00:00
});
2015-08-18 21:44:36 +00:00
};
//Export selected submissions of Form
$scope.exportSubmissions = function(type){
var fileMIMETypeMap = {
'xls': 'vnd.openxmlformats-officedocument.spreadsheetml.sheet',
'json': 'json',
'csv': 'csv',
};
var blob = new Blob([document.getElementById('table-submission-data').innerHTM], {
type: 'application/'+fileMIMETypeMap[type]+';charset=utf-8'
});
saveAs(blob, $scope.myform.title+'_sumbissions_export_'+Date.now()+'.'+type);
};
}
};
}
2016-04-17 02:45:17 +00:00
]);