ImageUpload: client side Scripte
[kivitendo-erp.git] / js / kivi.FileDB.js
1 namespace("kivi.FileDB", function(ns) {
2   "use strict";
3
4   const database = 'kivi';
5   const store    = 'files';
6   const db_version = 1;
7
8   // IndexedDB
9   const indexedDB = window.indexedDB || window.webkitIndexedDB || window.mozIndexedDB || window.OIndexedDB || window.msIndexedDB;
10
11   // Create/open database
12   let db;
13   let request = indexedDB.open(database, db_version);
14   request.onupgradeneeded = (event) => {
15     ns.create_image_store(event.target.result);
16   };
17   request.onerror = ns.onerror;
18   request.aftersuccess = [];
19   request.onsuccess = () => {
20     db = request.result;
21
22     db.onerror = (event) => {
23       console.error("Error creating/accessing IndexedDB database");
24       console.error(event);
25     };
26
27     // Interim solution for Google Chrome to create an objectStore. Will be deprecated
28     if (db.setVersion) {
29       if (db.version != db_version) {
30         let setVersion = db.setVersion(db_version);
31         setVersion.onsuccess = () =>  {
32           ns.create_image_store(db);
33         };
34       }
35     }
36
37     request.aftersuccess.forEach(f => f());
38   };
39
40   ns.create_image_store = function (db) {
41     db.createObjectStore(store, { autoIncrement : true });
42   };
43
44   ns.store_image = function (blob, filename, success) {
45     let put_request = ns.open_store("readwrite").add(blob, filename);
46
47     put_request.onsuccess = success;
48     put_request.on_error = ns.onerror;
49   };
50
51   ns.retrieve_image = function(key, success) {
52     let get_request = ns.open_store().objectStore(store).get(key);
53
54     get_request.onsuccess = success;
55     get_request.onerror = request.onerror;
56   };
57
58   ns.retrieve_all = function(success) {
59     let request = ns.open_store().getAll();
60     request.onsuccess = (event) => { success(event.target.result); };
61     request.onerror = ns.error;
62   };
63
64   ns.retrieve_all_keys = function(success) {
65     let request = ns.open_store().getAllKeys();
66     request.onsuccess = (event) => { success(event.target.result); };
67     request.onerror = ns.error;
68   };
69
70   ns.delete_all= function() {
71     ns.retrieve_all_keys((keys) => {
72       keys.forEach((key) => ns.delete_key(key));
73     });
74   };
75
76   ns.delete_key= function(key, success) {
77     let request = ns.open_store("readwrite").delete(key);
78     request.onsuccess = (event) => { if (success) success(event.target.result); };
79     request.onerror = ns.error;
80   };
81
82   ns.open_store = function(mode = "readonly")  {
83     return db.transaction([store], mode).objectStore(store);
84   };
85
86   ns.onerror = (event) => {
87     console.error("Error creating/accessing IndexedDB database");
88     console.error(event.errorState);
89   };
90
91   ns.with_db = function(success) {
92     if (db && db_version == db.version) {
93       success();
94     } else {
95       // assume the page load db init isn't done yet and push it onto the success
96       request.aftersuccess.push(success);
97     }
98   };
99 });