Difference between revisions of "User:Abel/common.js"

From Wikibase Personal data
Jump to navigation Jump to search
m
m
Line 52: Line 52:
 
         return read.split('.').reduce(indexcheck, array);
 
         return read.split('.').reduce(indexcheck, array);
 
}
 
}
*/
 
  
//|||||||||||||||||||||[ db objects  ]|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
 
     
 
  
    var personal = {};
+
var PersonalDataDataBaseName = "pdio";
    var indexedDB = window.indexedDB ;
+
var Pete = {id: 11345, name: {first: "Pete", last: "Rock"}, age: 52};
    var indexedDBVersion = "2";
 
    var Pete = {id: '11345', name: {first: "Pete", last: "Rock"}, age: '52'};
 
  
    personal.indexedDB = {};
+
addRecord(PersonalDataDataBaseName, Pete);
    personal.indexedDB.db = null;
+
recordUpdate(PersonalDataDataBaseName, Pete, 'phone', '+313555777');
   
 
  
     personal.indexedDB.onupgradeneeded = function() {
+
function addRecord(pddbname, record){
 +
  var pddb = window.indexedDB.open(pddbname, 1);
 +
 
 +
  pddb.addEventListener('error', (event) => {
 +
     console.log('Request error:', pddb.error);
 +
  }, false);
 +
 
 +
  pddb.onupgradeneeded = function() {
 
     var db = pddb.result;
 
     var db = pddb.result;
     var store = db.createObjectStore("personalDataIO", {keyPath: "id"});
+
     var store = db.createObjectStore("MyObjectStore", {keyPath: "id"});
 
     var index = store.createIndex("NameIndex", ["name.last", "name.first"]);
 
     var index = store.createIndex("NameIndex", ["name.last", "name.first"]);
     };
+
  };
//|||||||||||||||||||||||||||[ Error ]|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
+
 
     
+
  pddb.onsuccess = function() {
      
+
     var db = pddb.result;
     personal.indexedDB.onerror = function(arr){
+
    var tx = db.transaction("MyObjectStore", "readwrite");
        console.log(arr);
+
    var store = tx.objectStore("MyObjectStore");
 +
    var index = store.index("NameIndex"); 
 +
 
 +
     store.put(record);
 +
 
 +
     var recordcheck = index.get([record.name.first, record.name.last]);
 +
    recordcheck.onsuccess = function() {
 +
      console.log(recordcheck);
 
     }
 
     }
  
 +
    tx.oncomplete = function() {
 +
      db.close();
 +
    }; 
 +
  };
 +
};
  
//|||||||||||||||||||||||||||[ Open database ]|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
+
function recordUpdate(pddbname, record, field, value){
     
 
   
 
    personal.indexedDB.open = function(){
 
        // open database of
 
        var request = indexedDB.open("personalDataIO");
 
       
 
        request.onsuccess = function(e){
 
            //
 
            personal.indexedDB.db = e.target.result;
 
            var db = personal.indexedDB.db;
 
           
 
            //object stores are created in setVersion transactions
 
            if(indexedDBVersion!=db.version){
 
                var setDBVersion = db.setVersion(indexedDBVersion);
 
               
 
                //object store is created onsuccess
 
                setDBVersion.onerror = personal.indexedDB.onerror;
 
               
 
                setDBVersion.onsuccess = function(e){
 
                    if(db.objectStoreNames.contains("personalDataIO")){
 
                        // db.openObjectStore("personalDataIO");
 
                    } else {
 
                        var store = db.createObjectStore("personalDataIO",{autoIncrement:true});
 
                    }
 
                    store.createIndex("NameIndex", ["name.last", "name.first"]);
 
                    personal.indexedDB.recordAll();
 
                };
 
            }else{
 
                personal.indexedDB.recordAll();
 
            }
 
        };
 
        request.onerror = personal.indexedDB.onerror;
 
    };//end open
 
   
 
  
//|||||||||||||||||||||||||||||[ Add new record ]|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
+
  var pddb = window.indexedDB.open(pddbname, 1);
     
 
  
    //add Items
+
  pddb.addEventListener('error', (event) => {
        personal.indexedDB.recordAdd = function(recordObject){
+
    console.log('Request error:', pddb.error);
            var db = personal.indexedDB.db;
+
  }, false);
            var trans = db.transaction(["personalDataIO"],IDBTransaction.READ_WRITE);
 
            var store = trans.objectStore("personalDataIO");
 
            var request = store.put(recordObject);
 
           
 
            request.onsuccess = function(e){
 
                personal.indexedDB.recordAll();
 
            };
 
            request.onerror = function(e){
 
                console.log('Error adding: '+e);
 
            };
 
        };
 
       
 
  
//|||||||||||||||||||||||||||||[ Add new property to existing record ]|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
+
  pddb.onupgradeneeded = function() {
     
+
    var db = pddb.result;
        //get Items
+
    var store = db.createObjectStore("MyObjectStore", {keyPath: "id"});
        personal.indexedDB.recordAppend = function(Uname, field, value){
+
    var index = store.createIndex("NameIndex", ["name.last", "name.first"]);
 +
  };
  
            var db = personal.indexedDB.db;
+
  pddb.onsuccess = function() {
            var trans = db.transaction("personalDataIO");
+
        // Start a new transaction
            var store = trans.objectStore("personalDataIO");
+
        var db = pddb.result;
           
+
        var tx = db.transaction("MyObjectStore", "readwrite");
            var index = store.index(uname);
+
        var store = tx.objectStore("MyObjectStore");
            index.get(uname).onsuccess = function(e){                   
+
        var index = store.index("NameIndex");
                var nit = e.target.result;
 
                nit.field = value;
 
                recordAdd(nit);
 
            };                                                               
 
        };
 
   
 
//|||||||||||||||||||||||||||||[ Init wrapper ]|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
 
               
 
        function init() {
 
            personal.indexedDB.open();
 
        }
 
  
//||||||||||||||||||||||||||||||[ Get Record by name]||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
+
        var getRecord = index.get([record.name.first, record.name.last]);
     
+
        getRecord.onsuccess = function() {
            personal.indexedDB.recordGet = function(uname) {
+
          console.log("updating");
            var db = personal.indexedDB.db;
+
             getRecord.result.field = value;   // => "Bob"
            var trans = db.transaction("personalDataIO");
+
            store.put(getRecord.result);
            var store = trans.objectStore("personalDataIO");
 
           
 
            var index = store.index(uname);
 
            console.log(index);
 
         
 
             index.get(uname).onsuccess = function(e){                   
 
                console.log(e.target);
 
                /*/ $('#results').append('<li>'+e.target.result+'</li>'); /*///
 
          };
 
                                                                           
 
        }     
 
  
 +
            getRecordAgain = index.get([record.name.first, record.name.last]);
 +
            getRecordAgain.onsuccess = function() {
 +
                console.log("hey there" + getRecordAgain);  // => "Bob"
 +
                if ( getRecordAgain.result.field == value ) {
 +
                  console.log("update succeeded");
 +
                } else {
 +
                  console.log("update unsuccessful");
 +
                }
 +
              }; 
 +
            };
  
//||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
 
       
 
  
//||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
+
      // Close the db when the transaction is done
         
+
      tx.oncomplete = function() {
        init();
+
         db.close();
 
+
      };
         personal.indexedDB.recordAdd(Pete);
+
    };
        personal.indexedDB.recordAppend(["Pete", "Rock"], 'telephone', '+123-XXX');
+
  };
        personal.indexedDB.recordGet(["Pete", "Rock"]);
 

Revision as of 23:28, 26 April 2019

console.log('+');

/*

var personal_data_id = 421;

var wbEStruct = {
		subclassOfRelations: 'claims.P4', // location of P3 relations in wbEntity
		IDPropLoc:	'mainsnak.datavalue.value', // location of ID properties in related entity
		IDName:		'numeric-id', // ID property name which checked 
		qIDPropName: 'id'
				}; 

// check if we are on a page of a loaded Entity
if ( typeof mw.config.values.wbEntity !=  "undefined" ) {
	console.log( "entity is defined" )
	// get wbEntity as json
	var obj = JSON.parse ( mw.config.values.wbEntity );
	console.log( "parsed object" )
	// check if we have P3 relations and iterate through
	if ( typeof check( obj, wbEStruct["subclassOfRelations"] ) != "undefined" ) {
		console.log( "object has 'subclass of' relations" );
		for( var i = 0; i < dive( obj, wbEStruct["subclassOfRelations"] ).length; i++ ) {
			console.log("dived in");		
			// check if we have controller id constructed from wbEntity 
			if( dive( dive( obj, wbEStruct["subclassOfRelations"])[i] , wbEStruct["IDPropLoc"])[wbEStruct["IDName"]] === personal_data_id ) {
				console.log( "it's a storable personal data" )		
				var qId = obj[wbEStruct["qIDPropName"]];
				

                                console.log(qId);

			}
		}
	}
	// Else let's do nothing;
}

function indexinterpolate(obj,i) { return  (obj[i] != undefined) ? obj[i] : obj}; 

// helper function for checking a part of an array exists
function indexcheck(obj,i) {  return  (obj[i] != undefined) ? obj[i] : undefined };

// dive selects matrix.a.b.c.d from the array called matrix and 'a.b.c.d' as string
// if a.b.c.d does not exists, it returns the substructure until the substructure exists, if d does not exist, it returns matrix.a.b.c e.g.

function dive(array, read){
	return read.split('.').reduce(indexinterpolate, array);
}

function check(array, read){
        return read.split('.').reduce(indexcheck, array);
}


var PersonalDataDataBaseName = "pdio";
var Pete = {id: 11345, name: {first: "Pete", last: "Rock"}, age: 52};

addRecord(PersonalDataDataBaseName, Pete);
recordUpdate(PersonalDataDataBaseName, Pete, 'phone', '+313555777');

function addRecord(pddbname, record){
  var pddb = window.indexedDB.open(pddbname, 1);

  pddb.addEventListener('error', (event) => {
    console.log('Request error:', pddb.error);
  }, false);

  pddb.onupgradeneeded = function() {
    var db = pddb.result;
    var store = db.createObjectStore("MyObjectStore", {keyPath: "id"});
    var index = store.createIndex("NameIndex", ["name.last", "name.first"]);
  };

  pddb.onsuccess = function() {
    var db = pddb.result;
    var tx = db.transaction("MyObjectStore", "readwrite");
    var store = tx.objectStore("MyObjectStore");
    var index = store.index("NameIndex");  
  
    store.put(record);

    var recordcheck = index.get([record.name.first, record.name.last]);
    recordcheck.onsuccess = function() {
      console.log(recordcheck);
    }

    tx.oncomplete = function() {
      db.close();
    };  
  };
};

function recordUpdate(pddbname, record, field, value){

  var pddb = window.indexedDB.open(pddbname, 1);

  pddb.addEventListener('error', (event) => {
    console.log('Request error:', pddb.error);
  }, false);

  pddb.onupgradeneeded = function() {
    var db = pddb.result;
    var store = db.createObjectStore("MyObjectStore", {keyPath: "id"});
    var index = store.createIndex("NameIndex", ["name.last", "name.first"]);
  };

  pddb.onsuccess = function() {
        // Start a new transaction
        var db = pddb.result;
        var tx = db.transaction("MyObjectStore", "readwrite");
        var store = tx.objectStore("MyObjectStore");
        var index = store.index("NameIndex");

        var getRecord = index.get([record.name.first, record.name.last]);
        getRecord.onsuccess = function() {
          console.log("updating");
            getRecord.result.field = value;   // => "Bob"
            store.put(getRecord.result);

            getRecordAgain = index.get([record.name.first, record.name.last]);
            getRecordAgain.onsuccess = function() {
                console.log("hey there" + getRecordAgain);   // => "Bob"
                if ( getRecordAgain.result.field == value ) { 
                  console.log("update succeeded");
                } else {
                  console.log("update unsuccessful");
                }
              };   
            };


      // Close the db when the transaction is done
      tx.oncomplete = function() {
        db.close();
      };
    };
  };