-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.js
51 lines (46 loc) · 2.03 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//inject directives and services.
var app = angular.module('fileUpload', ['ngFileUpload']);
app.controller('MyCtrl', ['$scope', 'Upload', function ($scope, Upload) {
// full reference - https://github.com/danialfarid/ng-file-upload
// upload later on form submit or something similar
$scope.submit = function() {
if (angular.isDefined($scope.form.file) && $scope.form.file.$valid && $scope.file) {
$scope.upload($scope.file);
}
if (angular.isDefined($scope.form.files) && $scope.form.files.$valid && $scope.files) {
$scope.uploadFiles($scope.files);
}
};
// upload on file select or drop
$scope.upload = function (file) {
Upload.upload({
url: 'upload.cfm',
data: {file: file, 'username': $scope.username || 'cure'}
}).then(function (resp) {
console.log('Success ' + resp.config.data.file.name + ' uploaded. Response: ' + resp.data);
}, function (resp) {
console.log('Error status: ' + resp.status);
}, function (evt) {
var progressPercentage = parseInt(100.0 * evt.loaded / evt.total);
console.log('progress: ' + progressPercentage + '% ' + evt.config.data.file.name);
});
};
// for multiple files:
$scope.uploadFiles = function (files) {
if (files && files.length) {
for (var i = 0; i < files.length; i++) {
Upload.upload({
url: 'upload.cfm',
data: {file: files[i], 'username': $scope.username || 'cure'}
}).then(function (resp) {
console.log('Success ' + resp.config.data.file.name + ' uploaded. Response: ' + resp.data);
}, function (resp) {
console.log('Error status: ' + resp.status);
}, function (evt) {
var progressPercentage = parseInt(100.0 * evt.loaded / evt.total);
console.log('progress: ' + progressPercentage + '% ' + evt.config.data.file.name);
});
}
}
};
}]);