Bundled output for commit 1bb8b48a01 [skip ci]
This commit is contained in:
parent
1bb8b48a01
commit
813bfb5643
3 changed files with 63 additions and 52 deletions
29
mithril.js
29
mithril.js
|
|
@ -182,12 +182,15 @@ if (typeof window !== "undefined") {
|
|||
var PromisePolyfill = global.Promise
|
||||
} else {
|
||||
}
|
||||
var buildQueryString = function(object) {
|
||||
var buildQueryString = function(object, dataKeys0) {
|
||||
if (Object.prototype.toString.call(object) !== "[object Object]") return ""
|
||||
var args = []
|
||||
for (var key0 in object) {
|
||||
dataKeys0 = dataKeys0 || Object.keys(object)
|
||||
for (var i = 0; i < dataKeys0.length; i++) {
|
||||
var key0 = dataKeys0[i]
|
||||
destructure(key0, object[key0])
|
||||
}
|
||||
|
||||
return args.join("&")
|
||||
function destructure(key0, value) {
|
||||
if (Array.isArray(value)) {
|
||||
|
|
@ -207,6 +210,7 @@ var _8 = function($window, Promise) {
|
|||
var callbackCount = 0
|
||||
var oncompletion
|
||||
function setCompletionCallback(callback) {oncompletion = callback}
|
||||
|
||||
function finalizer() {
|
||||
var count = 0
|
||||
function complete() {if (--count === 0 && typeof oncompletion === "function") oncompletion()}
|
||||
|
|
@ -242,9 +246,10 @@ var _8 = function($window, Promise) {
|
|||
if (typeof args.serialize !== "function") args.serialize = typeof FormData !== "undefined" && args.data instanceof FormData ? function(value) {return value} : JSON.stringify
|
||||
if (typeof args.deserialize !== "function") args.deserialize = deserialize
|
||||
if (typeof args.extract !== "function") args.extract = extract
|
||||
args.url = interpolate(args.url, args.data)
|
||||
if (useBody) args.data = args.serialize(args.data)
|
||||
else args.url = assemble(args.url, args.data)
|
||||
var dataKeys = args.data && Object.keys(args.data)
|
||||
args.url = interpolate(args.url, args.data, dataKeys)
|
||||
if (useBody) args.data = args.serialize(args.data, dataKeys)
|
||||
else args.url = assemble(args.url, args.data, dataKeys)
|
||||
var xhr = new $window.XMLHttpRequest()
|
||||
xhr.open(args.method, args.url, typeof args.async === "boolean" ? args.async : true, typeof args.user === "string" ? args.user : undefined, typeof args.password === "string" ? args.password : undefined)
|
||||
if (args.serialize === JSON.stringify && useBody) {
|
||||
|
|
@ -307,20 +312,26 @@ var _8 = function($window, Promise) {
|
|||
})
|
||||
return args.background === true? promise0 : finalize(promise0)
|
||||
}
|
||||
function interpolate(url, data) {
|
||||
function interpolate(url, data, dataKeys) {
|
||||
if (data == null) return url
|
||||
var tokens = url.match(/:[^\/]+/gi) || []
|
||||
for (var i = 0; i < tokens.length; i++) {
|
||||
var key = tokens[i].slice(1)
|
||||
if (data[key] != null) {
|
||||
url = url.replace(tokens[i], data[key])
|
||||
delete data[key]
|
||||
|
||||
if (Array.isArray(dataKeys)) {
|
||||
var keyIndex = dataKeys.indexOf(key)
|
||||
if (keyIndex > -1) {
|
||||
dataKeys.splice(keyIndex)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return url
|
||||
}
|
||||
function assemble(url, data) {
|
||||
var querystring = buildQueryString(data)
|
||||
function assemble(url, data, dataKeys) {
|
||||
var querystring = buildQueryString(data, dataKeys)
|
||||
if (querystring !== "") {
|
||||
var prefix = url.indexOf("?") < 0 ? "?" : "&"
|
||||
url += prefix + querystring
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue