DISCONTINUATION OF PROJECT. This project will no longer be maintained by Intel. Intel will not provide or guarantee development of or support for this project, including but not limited to, maintenance, bug fixes, new releases or updates. Patches to this project are no longer accepted by Intel. In an effort to support the developer community, Intel has made this project available under the terms of the Apache License, Version 2. If you have an ongoing need to use this project, are interested in independently developing it, or would like to maintain patches for the community, please create your own fork of the project.
For persistent caching of data between application sessions.
This object is intended to provide local storage for data to speed up applications. It can be used as in conjunction with, or as an alternative to the HTML5 local database. Its methods provide features similar to browser cookies and file caching.
For cookies, the «intention is that you would use setCookie to
save string data in name-value pairs. Cookies persist between application
sessions. Data values may be retrieved using the getCookie command
or from the getCookieList command as soon as the
intel.xdk.device.ready
event is fired.
The media cache commands are meant to provide quicker access to files such as videos and images. Adding files to the media cache will expedite access to them when the application runs. These are files that are cached across sessions and are not in your application bundle. See the section on events below for more information about events fired from the cache section of intel.xdk.
- addToMediaCache — This command will get a file from the Internet and cache it locally on the device.
- addToMediaCacheExt — This command will get a file from the Internet and cache it locally on the device.
- clearAllCookies — This method will clear all data stored using the setCookie method.
- clearMediaCache — This command will remove all files from the local cache on the device.
- getCookie — This method will retrieve the value of a cookie previously saved using the setCookie command.
- getCookieList — This method will return an array containing the names of all the previously saved cookies using the setCookie command.
- getMediaCacheList — This method will get an array containing all the names of all the previously cached files.
- getMediaCacheLocalURL — This method will return an url that you can use to access a cached media file.
- removeCookie — This method will clear data previously saved using the setCookie method.
- removeFromMediaCache — This command will remove a file from the local cache on the device.
- setCookie — Call this method to set a chunk of data that will persist from session to session.
- intel.xdk.cache.media.add — Fires when data is cached
- intel.xdk.cache.media.clear — Fired once all files are removed from the local file cache
- intel.xdk.cache.media.remove — Fired when data is removed from the cache
- intel.xdk.cache.media.update — Fired repeatedly to track caching progress
This command will get a file from the Internet and cache it locally on the device.
intel.xdk.cache.addToMediaCache(url);
This command will get a file from the Internet and cache it locally on the
device. It can then be referenced in a special directory named _mediacache
off
the root of the bundle. Once this command is run, the
intel.xdk.cache.media.add event is fired. If there is already a
file cached with that name it is overwritten.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
- url: The url of the file to cache.
- intel.xdk.cache.media.add: This event is fired once this command is run. It will return an event object that contains the URL of the remote file cached.
intel.xdk.cache.addToMediaCache(urlToCache);
function cacheUpdated(e)
{
alert(e.url + " cached successfully");
}
document.addEventListener("intel.xdk.cache.media.add", cacheUpdated, false);
This command will get a file from the Internet and cache it locally on the device.
intel.xdk.cache.addToMediaCacheExt(url,id);
This command will get a file from the Internet and cache it locally on the
device. It can then be referenced in a special directory named _mediacache
off
the root of the bundle. As this method is executed, the
intel.xdk.cache.media.update event is fired repeatedly to track
the progress of the file caching. If there is already a file cached with that
name it is overwritten. As the file is cached by this method, a unique id is
returned in order to identify their origin. This command will replace the
depreciated command addToMediaCache.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
- url: The url of the file to cache.
- id: A unique identifier for the cache request.
- intel.xdk.cache.media.update: This event is fired as this method runs. It will return an event object that contains several parameters. The first parameter is the URL of the remote file cached. The second is the unique ID assigned when the command was called. The third is the current number of bytes downloaded and cached so far, and the final parameter is the total number of bytes in the file.
- intel.xdk.cache.media.add: This event is fired once the file is successfully cached.
intel.xdk.cache.addToMediaCacheExt(urlToCache,uniqueID);
function cacheUpdated(evt)
{
var outString = "";
outString += "current bytes downloaded: " + evt.current;
outString += " total bytes in download: " + evt.total;
var percentage = evt.current/evt.total;
outString += " percentage downloaded: " + percentage + "%";
outString += " the unique id is: " + evt.id ;
outString += "the URL is: " + evt.url;
alert(outString);
}
function cacheComplete(evt)
{
var outString = "";
outString += "The procedure succeeded (" + evt.success + ") ";
outString += " the unique id is: " + evt.id ;
outString += "the URL is: " + evt.url;
alert(outString);
}
document.addEventListener("intel.xdk.cache.media.update", cacheUpdated, false);
document.addEventListener("intel.xdk.cache.media.add", cacheComplete, false);
- This command will get a file from the Internet and cache it locally on the device.
This method will clear all data stored using the setCookie method.
intel.xdk.cache.clearAllCookies();
This method will clear all data stored using the setCookie method.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
intel.xdk.cache.clearAllCookies();
This command will remove all files from the local cache on the device.
intel.xdk.cache.clearMediaCache();
This command will remove all files from the local cache on the device. Once this command is run the intel.xdk.cache.media.clear event is fired.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
- intel.xdk.cache.media.clear: This event is fired once all files are removed from the local cahce of the device.
intel.xdk.cache.clearMediaCache();
function cacheCleared()
{
alert("cache cleared successfully");
}
This method will retrieve the value of a cookie previously saved using the setCookie command.
intel.xdk.cache.getCookie(name);
This method will get the value of a cookie previously saved using the
setCookie command. If no such cookie exists, the value returned
will be undefined
.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
name: The unique name for the data to retrieve.
var value = intel.xdk.cache.getCookie("userid");
This method will return an array containing the names of all the previously saved cookies using the setCookie command.
var dataArray = intel.xdk.cache.getCookieList();
This method will return an array containing all the names of all the previously saved cookies using the setCookie command. These names can then be used in calls to getCookie.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
dataArray: An array of all the unique names of previously saved data.
var cookiesArray = intel.xdk.cache.getCookieList();
for (var x=0; x < cookiesArray.length; x++)
{
alert(cookiesArray[x]+":"+intel.xdk.cache.getCookie(cookiesArray[x]));
}
This method will get an array containing all the names of all the previously cached files.
var cacheArray = intel.xdk.cache.getMediaCacheList();
This method will get an array containing all the names of all the previously cached files using the addToMediaCache command. These names can then be used in calls to getMediaCacheLocalURL.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
cacheArray: An array of URLs that have been cached on the device using the addToMediaCache method.
var cacheArray = intel.xdk.cache.getMediaCacheList();
for (var x=0; x < cacheArray.length; x++)
{
alert( cacheArray[x] + " " +
intel.xdk.cache.getMediaCacheLocalURL(cacheArray[x]) );
}
This method will return an url that you can use to access a cached media file.
var localURL = intel.xdk.cache.getMediaCacheLocalURL(url);
This method will return an url that you can use to access the cached media file.
If the requested URL is not cached, the value returned will be undefined
.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
- url: The remote URL of the file that was cached.
- localURL: The local URL of the cached file on the device itself.
var localurl =
intel.xdk.cache.getMediaCacheLocalURL("http://myweb.com/image/logo.gif");
This method will clear data previously saved using the setCookie method.
intel.xdk.cache.removeCookie(name);
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
name: The unique name of the data to remove.
intel.xdk.cache.removeCookie("userid");
This command will remove a file from the local cache on the device.
intel.xdk.cache.removeFromMediaCache(url)
This command will remove a file from the local cache on the device. Once this command is run the intel.xdk.cache.media.remove event is fired.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
- url: The url of the file to remove from the local cache.
- intel.xdk.cache.media.remove: This event is fired once a cached file has been successfully removed. It will return an event object that contains the URL of the original URL of the removed file.
intel.xdk.cache.removeFromMediaCache(urlToRemove);
function cacheUpdated(e)
{
alert(e.url + " removed successfully");
}
document.addEventListener("intel.xdk.cache.media.remove", cacheUpdated, false);
Call this method to set a chunk of data that will persist from session to session.
intel.xdk.cache.setCookie(name,value,expirationDays);
Call this method to set a chunk of data that will persist from session to session. The data is automatically purged once the expiration date lapses. The data can be retrieved using the getCookie command.
Please note that cookie names may not include periods.
- Apple iOS
- Google Android
- Microsoft Windows 8 - BETA
- Microsoft Windows Phone 8 - BETA
- name: A unique name for the data to save. The name parameter may not contain periods or underscores.
- value: The data to save. The data will be saved as a string. An undefined variable will be saved as an empty string.
- expirationDays: The number of days until the data is automatically removed from the device. Pass a -1 to make sure the application never automatically expires data. Pass a 0 to make the cookie a "session cookie" that is removed once the application is closed.
function saveInfo() {
//add a cookie
var name = prompt('Enter information name:');
var value = prompt('Enter information value:');
var daysTillExpiry = prompt('Days until cookie expires (-1 for never):');
try
{
if (name.indexOf('.')== -1)
{
intel.xdk.cache.setCookie(name,value,daysTillExpiry);
}
else
{
alert('cookie names may not include a period');
}
}
catch(e)
{
alert("error in saveInfo: " + e.message);
}
}
Fires when data is cached
This event fires once a file is added to the local file cache using the intel.xdk.cache.addToMediaCache command. The url property on the event object will contain the URL of the remote file cached.
Fired once all files are removed from the local file cache
This event fires once all files are removed from the local file cache using the intel.xdk.cache.clearMediaCache command.
Fired when data is removed from the cache
This event fires once a file is removed from the local file cache using the intel.xdk.cache.removeFromMediaCache command.
Fired repeatedly to track caching progress
This event is fired repeatedly as the intel.xdk.cache.addToMediaCacheExt method runs. It will return an event object that contains several parameters. The first parameter is the URL of the remote file cached. The second is the unique ID assigned when the command was called. The third is the current number of bytes downloaded and cached so far, and the final parameter is the total number of bytes in the file.