overleaf/services/web/public/coffee/directives/fineUpload.coffee

81 lines
2.2 KiB
CoffeeScript
Raw Normal View History

2014-06-22 12:32:15 -04:00
define [
"base"
2017-11-20 09:43:13 -05:00
"libs/fineuploader"
], (App, qq) ->
2014-06-22 12:32:15 -04:00
App.directive 'fineUpload', ($timeout) ->
return {
scope: {
multiple: "="
endpoint: "@"
waitingForResponseText: "@"
failedUploadText: "@"
uploadButtonText: "@"
dragAreaText: "@"
hintText: "@"
allowedExtensions: "="
onCompleteCallback: "="
onUploadCallback: "="
onValidateBatch: "="
onErrorCallback: "="
onSubmitCallback: "="
onCancelCallback: "="
autoUpload: "="
2014-06-22 12:32:15 -04:00
params: "="
control: "="
2014-06-22 12:32:15 -04:00
}
link: (scope, element, attrs) ->
2017-11-20 09:43:13 -05:00
console.log ">> element", element
2014-06-22 12:32:15 -04:00
multiple = scope.multiple or false
endpoint = scope.endpoint
if scope.allowedExtensions?
validation =
allowedExtensions: scope.allowedExtensions
else
validation = {}
text =
waitingForResponse: scope.waitingForResponseText or "Processing..."
failUpload: scope.failedUploadText or "Failed :("
uploadButton: scope.uploadButtonText or "Upload"
dragAreaText = scope.dragAreaText or "drag here"
hintText = scope.hintText or ""
maxConnections = scope.maxConnections or 1
2014-06-22 12:32:15 -04:00
onComplete = scope.onCompleteCallback or () ->
onUpload = scope.onUploadCallback or () ->
onError = scope.onErrorCallback or () ->
onValidateBatch = scope.onValidateBatch or () ->
onSubmit = scope.onSubmitCallback or () ->
onCancel = scope.onCancelCallback or () ->
if !scope.autoUpload?
autoUpload = true
else
autoUpload = scope.autoUpload
2014-06-22 12:32:15 -04:00
params = scope.params or {}
params._csrf = window.csrfToken
q = new qq.FineUploader
2014-06-22 12:32:15 -04:00
element: element[0]
multiple: multiple
autoUpload: autoUpload
2014-06-22 12:32:15 -04:00
disabledCancelForFormUploads: true
validation: validation
maxConnections: maxConnections
2014-06-22 12:32:15 -04:00
request:
endpoint: endpoint
forceMultipart: true
params: params
paramsInBody: false
callbacks:
onComplete: onComplete
onUpload: onUpload
onValidateBatch: onValidateBatch
onError: onError
onSubmit: onSubmit
onCancel: onCancel
2014-06-22 12:32:15 -04:00
text: text
2017-11-20 09:43:13 -05:00
# template: "qq-uploader"
template: document.getElementById('qq-uploader')
window.q = q
scope.control?.q = q
return q
2017-11-20 09:43:13 -05:00
}