diff options
-rw-r--r-- | js/io/system/chromeapi.js | 17 | ||||
-rwxr-xr-x | js/io/system/coreioapi.js | 46 |
2 files changed, 53 insertions, 10 deletions
diff --git a/js/io/system/chromeapi.js b/js/io/system/chromeapi.js index 04e62b11..6bf6b9fe 100644 --- a/js/io/system/chromeapi.js +++ b/js/io/system/chromeapi.js | |||
@@ -25,8 +25,14 @@ exports.ChromeApi = Montage.create(Object.prototype, { | |||
25 | if (window.webkitRequestFileSystem) { | 25 | if (window.webkitRequestFileSystem) { |
26 | //Current way to init Chrome's fileSystem API | 26 | //Current way to init Chrome's fileSystem API |
27 | window.webkitRequestFileSystem(window.PERSISTENT, size*1024*1024, function (fs) { | 27 | window.webkitRequestFileSystem(window.PERSISTENT, size*1024*1024, function (fs) { |
28 | //Storing reference to instance | ||
28 | this.fileSystem = fs; | 29 | this.fileSystem = fs; |
29 | }.bind(this)); | 30 | //Dispatching action ready event |
31 | var readyEvent = document.createEvent("CustomEvent"); | ||
32 | readyEvent.initEvent('ready', true, true); | ||
33 | this.dispatchEvent(readyEvent); | ||
34 | }.bind(this), function (e) {return false}); //Returns false on error (not able to init) | ||
35 | // | ||
30 | return true; | 36 | return true; |
31 | } else { | 37 | } else { |
32 | //No fileSystem API | 38 | //No fileSystem API |
@@ -93,6 +99,15 @@ exports.ChromeApi = Montage.create(Object.prototype, { | |||
93 | enumerable: true, | 99 | enumerable: true, |
94 | value: function() { | 100 | value: function() { |
95 | } | 101 | } |
102 | }, | ||
103 | //////////////////////////////////////////////////////////////////// | ||
104 | // | ||
105 | getLocalLibrary: { | ||
106 | enumerable: false, | ||
107 | value: function () { | ||
108 | // | ||
109 | return {}; | ||
110 | } | ||
96 | } | 111 | } |
97 | //////////////////////////////////////////////////////////////////// | 112 | //////////////////////////////////////////////////////////////////// |
98 | //////////////////////////////////////////////////////////////////// | 113 | //////////////////////////////////////////////////////////////////// |
diff --git a/js/io/system/coreioapi.js b/js/io/system/coreioapi.js index 73d9fa76..3fb9374a 100755 --- a/js/io/system/coreioapi.js +++ b/js/io/system/coreioapi.js | |||
@@ -26,15 +26,6 @@ exports.CoreIoApi = Montage.create(Component, { | |||
26 | enumerable: false, | 26 | enumerable: false, |
27 | value: function () { | 27 | value: function () { |
28 | //////////////////////////////////////////////////////////// | 28 | //////////////////////////////////////////////////////////// |
29 | //Getting reference of chrome file system API | ||
30 | this.chromeFileSystem = ChromeApi; | ||
31 | //Sending size in MBs for file system storage | ||
32 | if (this.chromeFileSystem.init(20)) { | ||
33 | //Available | ||
34 | } else { | ||
35 | //Not available | ||
36 | } | ||
37 | //////////////////////////////////////////////////////////// | ||
38 | //Checking for local storage of URL for IO | 29 | //Checking for local storage of URL for IO |
39 | if (window.localStorage['ioRootUrl']) { | 30 | if (window.localStorage['ioRootUrl']) { |
40 | //Getting URL from local storage | 31 | //Getting URL from local storage |
@@ -46,8 +37,45 @@ exports.CoreIoApi = Montage.create(Component, { | |||
46 | this.ioServiceDetected = false; | 37 | this.ioServiceDetected = false; |
47 | } | 38 | } |
48 | //////////////////////////////////////////////////////////// | 39 | //////////////////////////////////////////////////////////// |
40 | //Getting reference of chrome file system API | ||
41 | this.chromeFileSystem = ChromeApi; | ||
42 | //Sending size in MBs for file system storage | ||
43 | var chromeFs = this.chromeFileSystem.init(20); | ||
44 | //Checking for availability of API | ||
45 | if (chromeFs) { | ||
46 | this.chromeFileSystem.addEventListener('ready', this, false); | ||
47 | } else { | ||
48 | //Error, Chrome File System API not detected | ||
49 | } | ||
50 | //////////////////////////////////////////////////////////// | ||
49 | } | 51 | } |
50 | }, | 52 | }, |
53 | //////////////////////////////////////////////////////////////////// | ||
54 | // | ||
55 | handleReady: { | ||
56 | enumerable: false, | ||
57 | value: function (e) { | ||
58 | this.chromeFileSystem.removeEventListener('ready', this, false); | ||
59 | this.chromeNinjaLibrary = this.chromeFileSystem.getLocalLibrary(); | ||
60 | } | ||
61 | }, | ||
62 | //////////////////////////////////////////////////////////////////// | ||
63 | // | ||
64 | _chromeNinjaLibrary: { | ||
65 | enumerable: false, | ||
66 | value: null | ||
67 | }, | ||
68 | //////////////////////////////////////////////////////////////////// | ||
69 | // | ||
70 | chromeNinjaLibrary: { | ||
71 | enumerable: false, | ||
72 | get: function() { | ||
73 | return this._chromeNinjaLibrary; | ||
74 | }, | ||
75 | set: function(value) { | ||
76 | this._chromeNinjaLibrary = value; | ||
77 | } | ||
78 | }, | ||
51 | //////////////////////////////////////////////////////////////////// | 79 | //////////////////////////////////////////////////////////////////// |
52 | // | 80 | // |
53 | _chromeFileSystem: { | 81 | _chromeFileSystem: { |