fixed json header added and added boot clean options
This commit is contained in:
parent
0b75b3efb5
commit
f0918dce75
|
@ -83,6 +83,9 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
* boot.cordova.flag = The window flag which is set when cordova is booted. (default: 'FFCordovaDevice')
|
* boot.cordova.flag = The window flag which is set when cordova is booted. (default: 'FFCordovaDevice')
|
||||||
* boot.angular.enable = Auto bootstrap angular modules. (default: true)
|
* boot.angular.enable = Auto bootstrap angular modules. (default: true)
|
||||||
* boot.angular.modules = The angular modules to boot. (default: empty)
|
* boot.angular.modules = The angular modules to boot. (default: empty)
|
||||||
|
* boot.cleanup.enable = Auto cleanup the loader html tags. (default: true)
|
||||||
|
* boot.cleanup.timeout = Cleanup after timeout(in ms) so css effects are done. (default: 1000)
|
||||||
|
* boot.cleanup.tags = The array of tag ids to remove. (default: empty)
|
||||||
* server.url = The server url like 'https://myhost', when null the user will get promted to input it. (default: null)
|
* server.url = The server url like 'https://myhost', when null the user will get promted to input it. (default: null)
|
||||||
* server.assets = The server path to the assets resources definition file, is required (default: null)
|
* server.assets = The server path to the assets resources definition file, is required (default: null)
|
||||||
* server.timeout = The timeout to download the server resources. (default: 4096)
|
* server.timeout = The timeout to download the server resources. (default: 4096)
|
||||||
|
@ -214,6 +217,11 @@ Add unit tests for any new or changed functionality. Lint and test your code.
|
||||||
|
|
||||||
## Release History
|
## Release History
|
||||||
|
|
||||||
|
### 0.2.1
|
||||||
|
* Fixed clearCache method to added json header.
|
||||||
|
* Added url to non 200 http status error message.
|
||||||
|
* Added boot.cleanup.tags options.
|
||||||
|
|
||||||
### 0.2.0
|
### 0.2.0
|
||||||
* Moved error.style and question.style to css file.
|
* Moved error.style and question.style to css file.
|
||||||
* Changed dist with extra css/js folder.
|
* Changed dist with extra css/js folder.
|
||||||
|
|
|
@ -64,6 +64,11 @@
|
||||||
enable: true,
|
enable: true,
|
||||||
modules: []
|
modules: []
|
||||||
},
|
},
|
||||||
|
cleanup: {
|
||||||
|
enable: true,
|
||||||
|
timeout: 1000,
|
||||||
|
tags: []
|
||||||
|
}
|
||||||
},
|
},
|
||||||
server: {
|
server: {
|
||||||
url: null,
|
url: null,
|
||||||
|
@ -355,7 +360,7 @@
|
||||||
|
|
||||||
cb(null, httpRequest);
|
cb(null, httpRequest);
|
||||||
} else if (httpRequest.readyState === 4) {
|
} else if (httpRequest.readyState === 4) {
|
||||||
cb('Wrong status '+httpRequest.status);
|
cb('Wrong status '+httpRequest.status+' of '+url);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
httpRequest.open('GET', url, true);
|
httpRequest.open('GET', url, true);
|
||||||
|
@ -1003,6 +1008,7 @@
|
||||||
options.error.handler(err);
|
options.error.handler(err);
|
||||||
} else {
|
} else {
|
||||||
utilDebug('start done in '+(new Date().getTime()-startTime)+' ms.'); // last debug line TODO: move bootAngular to onjsloaded
|
utilDebug('start done in '+(new Date().getTime()-startTime)+' ms.'); // last debug line TODO: move bootAngular to onjsloaded
|
||||||
|
bootCleanup(); // move after ang.
|
||||||
bootAngular(function(err) {
|
bootAngular(function(err) {
|
||||||
if (err !== null) { return options.error.handler(err); }
|
if (err !== null) { return options.error.handler(err); }
|
||||||
if (typeof cbArgu === 'function') {
|
if (typeof cbArgu === 'function') {
|
||||||
|
@ -1094,10 +1100,40 @@
|
||||||
}
|
}
|
||||||
var resources = JSON.parse(httpRequest.responseText).data.resources;
|
var resources = JSON.parse(httpRequest.responseText).data.resources;
|
||||||
cleanupCache(resources,false,cb);
|
cleanupCache(resources,false,cb);
|
||||||
});
|
}, true); // TODO: create resourcesListFetch();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Boot cleanup removed the html tags by id after the timeout.
|
||||||
|
*
|
||||||
|
* note: sync function
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
var bootCleanup = function() {
|
||||||
|
if (options.boot.cleanup.enable !== true) {
|
||||||
|
utilDebug('bootCleanup disabled by options');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (options.boot.cleanup.tags.length === 0) {
|
||||||
|
utilDebug('bootCleanup disabled by no tags ids.');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
utilDebug('bootCleanup after '+options.boot.cleanup.timeout+' ms.');
|
||||||
|
setTimeout ( function () {
|
||||||
|
utilDebug('bootCleanup run');
|
||||||
|
for (var tagIdx in options.boot.cleanup.tags) {
|
||||||
|
var tagId = options.boot.cleanup.tags[tagIdx];
|
||||||
|
var tag = document.getElementById(tagId);
|
||||||
|
if (tag !== null) {
|
||||||
|
tag.parentNode.removeChild(tag);
|
||||||
|
utilDebug('bootCleanup removed '+tagId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, options.boot.cleanup.timeout);
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Boots angular modules if enabled.
|
* Boots angular modules if enabled.
|
||||||
*
|
*
|
||||||
|
|
|
@ -3,13 +3,18 @@
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8"/>
|
<meta charset="UTF-8"/>
|
||||||
<title>Loading</title>
|
<title>Loading</title>
|
||||||
<link rel="stylesheet" type="text/css" href="/static/spa-loader.css" />
|
<link id="ffCleanupCss" rel="stylesheet" type="text/css" href="/static/spa-loader.css" />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<script><%- inlineScript %></script>
|
<script id="ffCleanupScript"><%- inlineScript %></script>
|
||||||
<script>
|
<script id="ffCleanupConfig">
|
||||||
|
//FFSpaLoader.options.cache.css = false;
|
||||||
|
//FFSpaLoader.options.cache.dss = false;
|
||||||
FFSpaLoader.options.debug.enable = true;
|
FFSpaLoader.options.debug.enable = true;
|
||||||
FFSpaLoader.options.boot.angular.modules.push('exampleUI');
|
FFSpaLoader.options.boot.angular.modules.push('exampleUI');
|
||||||
|
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupCss');
|
||||||
|
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupScript');
|
||||||
|
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupConfig');
|
||||||
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
||||||
FFSpaLoader.options.server.header.response['X-My-Api'] = 'noknok';
|
FFSpaLoader.options.server.header.response['X-My-Api'] = 'noknok';
|
||||||
FFSpaLoader.start();
|
FFSpaLoader.start();
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "es5-ff-spa-loader",
|
"name": "es5-ff-spa-loader",
|
||||||
"version": "0.2.0",
|
"version": "0.2.1",
|
||||||
"description": "Javascript Single Page Application Loader",
|
"description": "Javascript Single Page Application Loader",
|
||||||
"main": "es5-ff-spa-loader.js",
|
"main": "es5-ff-spa-loader.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
Loading…
Reference in a new issue