summaryrefslogtreecommitdiff
path: root/public/assets/js/vendor
diff options
context:
space:
mode:
Diffstat (limited to 'public/assets/js/vendor')
-rw-r--r--public/assets/js/vendor/dataUriToBlob.js58
-rw-r--r--public/assets/js/vendor/view/formview.js96
2 files changed, 107 insertions, 47 deletions
diff --git a/public/assets/js/vendor/dataUriToBlob.js b/public/assets/js/vendor/dataUriToBlob.js
new file mode 100644
index 0000000..80189b8
--- /dev/null
+++ b/public/assets/js/vendor/dataUriToBlob.js
@@ -0,0 +1,58 @@
+var dataUriToUint8Array = function(uri){
+ var data = uri.split(',')[1];
+ var bytes = atob(data);
+ var buf = new ArrayBuffer(bytes.length);
+ var u8 = new Uint8Array(buf);
+ for (var i = 0; i < bytes.length; i++) {
+ u8[i] = bytes.charCodeAt(i);
+ }
+ return u8
+}
+
+window.dataUriToBlob = (function(){
+/**
+ * Blob constructor.
+ */
+
+var Blob = window.Blob;
+
+/**
+ * ArrayBufferView support.
+ */
+
+var hasArrayBufferView = new Blob([new Uint8Array(100)]).size == 100;
+
+/**
+ * Return a `Blob` for the given data `uri`.
+ *
+ * @param {String} uri
+ * @return {Blob}
+ * @api public
+ */
+
+var dataUriToBlob = function(uri){
+ var data = uri.split(',')[1];
+ var bytes = atob(data);
+ var buf = new ArrayBuffer(bytes.length);
+ var arr = new Uint8Array(buf);
+ for (var i = 0; i < bytes.length; i++) {
+ arr[i] = bytes.charCodeAt(i);
+ }
+
+ if (!hasArrayBufferView) arr = buf;
+ var blob = new Blob([arr], { type: mime(uri) });
+ blob.slice = blob.slice || blob.webkitSlice;
+ return blob;
+};
+
+/**
+ * Return data uri mime type.
+ */
+
+function mime(uri) {
+ return uri.split(';')[0].slice(5);
+}
+
+return dataUriToBlob;
+
+})()
diff --git a/public/assets/js/vendor/view/formview.js b/public/assets/js/vendor/view/formview.js
index 6b03849..923e212 100644
--- a/public/assets/js/vendor/view/formview.js
+++ b/public/assets/js/vendor/view/formview.js
@@ -90,44 +90,28 @@ var FormView = View.extend({
var action = typeof this.action == "function" ? this.action() : this.action
if (! action) return
- var data = this.serialize()
- var request = $.ajax({
- url: action,
- type: this.method,
- data: data,
- headers: { "csrf-token": $("[name=_csrf]").attr("value") },
- contentType: data instanceof FormData ? false : "application/json",
- dataType: "json",
- processData: false,
- success: function(response){
- if (response.error) {
- var errors = []
- if (response.error.errors) {
- for (var key in response.error.errors) {
- errors.push(response.error.errors[key].message);
- }
- } else {
- errors.push(response.error)
- }
- if (errorCallback) {
- errorCallback(errors)
- }
- else {
- this.showErrors(errors)
- }
- return
- }
- if (successCallback) {
- successCallback(response)
- }
- if (this.success) {
- this.success(response)
- }
- }.bind(this),
- error: function(response){
+ var data = this.serialize()
+ var headers = new Headers()
+ headers.append("csrf-token", $("[name=_csrf]").attr("value"))
+ if (typeof data === "string") {
+ headers.append("content-type", "application/json")
+ }
+
+ fetch(action, {
+ method: this.method.toUpperCase(),
+ headers: headers,
+ credentials: 'same-origin',
+ body: data,
+ }).then(raw => raw.json())
+ .then(response => {
+ if (response.error) {
var errors = []
- for (var key in response.error.errors) {
- errors.push(response.error.errors[key].message);
+ if (response.error.errors) {
+ for (var key in response.error.errors) {
+ errors.push(response.error.errors[key].message);
+ }
+ } else {
+ errors.push(response.error)
}
if (errorCallback) {
errorCallback(errors)
@@ -135,17 +119,35 @@ var FormView = View.extend({
else {
this.showErrors(errors)
}
- }.bind(this),
- complete: function(response){
- if (this.useMinotaur) {
- Minotaur.hide()
- }
- }.bind(this),
+ return
+ }
+ if (successCallback) {
+ successCallback(response)
+ }
+ if (this.success) {
+ this.success(response)
+ }
+ }).catch(response => {
+ var errors = []
+ for (var key in response.error.errors) {
+ errors.push(response.error.errors[key].message);
+ }
+ if (errorCallback) {
+ errorCallback(errors)
+ }
+ else {
+ this.showErrors(errors)
+ }
})
-
- if (this.useMinotaur) {
- Minotaur.show()
- }
+// complete: function(response){
+// if (this.useMinotaur) {
+// Minotaur.hide()
+// }
+// }
+//
+// if (this.useMinotaur) {
+// Minotaur.show()
+// }
this.beforeSend && this.beforeSend()
},