Difference between revisions of "User:Abel/experimental.js"
Jump to navigation
Jump to search
m |
m |
||
(13 intermediate revisions by the same user not shown) | |||
Line 2: | Line 2: | ||
// Experimental Main | // Experimental Main | ||
console.log("'⌣'"); | console.log("'⌣'"); | ||
+ | |||
var mwEStruct = { | var mwEStruct = { | ||
wbXntity: 'config.values.wbEntity' | wbXntity: 'config.values.wbEntity' | ||
Line 8: | Line 9: | ||
language = "en", | language = "en", | ||
− | + | WBEStructure = { | |
subclassOfRelations: 'claims.P4', // location of P4 relations in wbEntity | subclassOfRelations: 'claims.P4', // location of P4 relations in wbEntity | ||
defaultValRelation: 'claims.P108', | defaultValRelation: 'claims.P108', | ||
Line 19: | Line 20: | ||
}, | }, | ||
− | + | Relational_id_list = { | |
− | controller_id: [ | + | controller_id: [ WBEStructure['instanceOfRelations'], WBEStructure['IDPropLoc'], WBEStructure['IDName'], 96 ], |
− | personal_data_id: [ | + | personal_data_id: [ WBEStructure['subclassOfRelations'], WBEStructure['IDPropLoc'], WBEStructure['IDName'], 421 ], |
− | interface_button_id: [ | + | interface_button_id: [ WBEStructure ['instanceOfRelations'], WBEStructure['IDPropLoc'], WBEStructure['IDName'], 487 ] |
− | } | + | }, |
− | + | PDWikibaseProcessor, | |
+ | PDindexedDB, | ||
+ | PDOOUI, | ||
+ | Current_entity; | ||
− | |||
− | |||
− | |||
− | + | // JQ.'when' loads the current scripts asynchronously, continues when loading is 'done' | |
+ | $.when( | ||
+ | $.getScript( "//wiki.personaldata.io/w/index.php?title=User:Abel/WbProcessor.js&action=raw&ctype=text/javascript" ), | ||
+ | $.getScript( "//wiki.personaldata.io/w/index.php?title=User:Abel/PersonalData.js&action=raw&ctype=text/javascript" ), | ||
+ | $.getScript( "//wiki.personaldata.io/w/index.php?title=User:Abel/OOInterface.js&action=raw&ctype=text/javascript" ), | ||
+ | $.Deferred( function( deferred ){ | ||
+ | $( deferred.resolve ); | ||
+ | }) | ||
+ | ).done( function(){ | ||
− | console.log( | + | console.log('Main thread'); |
− | |||
− | + | // WBproc reads current mediawiki Entity upon instantiation | |
− | + | PDWikibaseProcessor = new WikibaseProcessorContainer(mw, mwEStruct['wbXntity']); | |
− | // | + | // PDxDB takes mediawiki, reads user name from it, creates a hash, and 'checks in' the user upon instantiation |
− | // | + | // (i.e. read record belonging to user, if it does not exist, create it) |
− | + | PDindexedDB = new IndexedDBContainer( mw ); | |
− | // | + | |
− | + | // Contains classes for creating UI elements, no instantiation consequences | |
− | + | PDOOUI = new InterfaceMediaContainer( PDWikibaseProcessor, PDindexedDB ); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | // Check if the current entity belongs to any path of interest. | |
− | + | // For each element in object argument, a corresponding element in the return object will contain one of the following: | |
+ | // - undefined - the path didn't exist even partly) | ||
+ | // - [ value or object ] - if the path existed fully, it returns what is at the end of the path. If last element in path is a value, it will return the value if found | ||
− | + | Current_entity = PDWikibaseProcessor.checkentity( Relational_id_list ); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | // Business logicish part. | |
− | + | // If any path of interest returned anything... | |
− | + | if ( Current_entity != undefined ) { | |
− | + | Object.keys(Current_entity).forEach( function ( entity_checked ){ | |
− | + | //... for each path that returned something | |
− | + | if ( Current_entity[entity_checked] != undefined ){ | |
+ | if ( Object.keys( Current_entity[entity_checked] ).length > 0 ) { | ||
+ | PDOOUI.renderInterface( entity_checked ); | ||
+ | //... call the OOUI renderer to render what belongs to this input | ||
} | } | ||
} | } | ||
− | + | }); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | + | }); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− |
Latest revision as of 11:14, 24 May 2019
// License: GPL
// Experimental Main
console.log("'⌣'");
var mwEStruct = {
wbXntity: 'config.values.wbEntity'
},
language = "en",
WBEStructure = {
subclassOfRelations: 'claims.P4', // location of P4 relations in wbEntity
defaultValRelation: 'claims.P108',
concernsRelation: 'claims.P110',
instanceOfRelations: 'claims.P3',
IDPropLoc: 'mainsnak.datavalue.value', // location of ID properties in related entity
IDName: 'numeric-id', // ID property name which checked
qIDPropName: 'id',
standardValue: 'labels' + '.' + language + '.' + 'value'
},
Relational_id_list = {
controller_id: [ WBEStructure['instanceOfRelations'], WBEStructure['IDPropLoc'], WBEStructure['IDName'], 96 ],
personal_data_id: [ WBEStructure['subclassOfRelations'], WBEStructure['IDPropLoc'], WBEStructure['IDName'], 421 ],
interface_button_id: [ WBEStructure ['instanceOfRelations'], WBEStructure['IDPropLoc'], WBEStructure['IDName'], 487 ]
},
PDWikibaseProcessor,
PDindexedDB,
PDOOUI,
Current_entity;
// JQ.'when' loads the current scripts asynchronously, continues when loading is 'done'
$.when(
$.getScript( "//wiki.personaldata.io/w/index.php?title=User:Abel/WbProcessor.js&action=raw&ctype=text/javascript" ),
$.getScript( "//wiki.personaldata.io/w/index.php?title=User:Abel/PersonalData.js&action=raw&ctype=text/javascript" ),
$.getScript( "//wiki.personaldata.io/w/index.php?title=User:Abel/OOInterface.js&action=raw&ctype=text/javascript" ),
$.Deferred( function( deferred ){
$( deferred.resolve );
})
).done( function(){
console.log('Main thread');
// WBproc reads current mediawiki Entity upon instantiation
PDWikibaseProcessor = new WikibaseProcessorContainer(mw, mwEStruct['wbXntity']);
// PDxDB takes mediawiki, reads user name from it, creates a hash, and 'checks in' the user upon instantiation
// (i.e. read record belonging to user, if it does not exist, create it)
PDindexedDB = new IndexedDBContainer( mw );
// Contains classes for creating UI elements, no instantiation consequences
PDOOUI = new InterfaceMediaContainer( PDWikibaseProcessor, PDindexedDB );
// Check if the current entity belongs to any path of interest.
// For each element in object argument, a corresponding element in the return object will contain one of the following:
// - undefined - the path didn't exist even partly)
// - [ value or object ] - if the path existed fully, it returns what is at the end of the path. If last element in path is a value, it will return the value if found
Current_entity = PDWikibaseProcessor.checkentity( Relational_id_list );
// Business logicish part.
// If any path of interest returned anything...
if ( Current_entity != undefined ) {
Object.keys(Current_entity).forEach( function ( entity_checked ){
//... for each path that returned something
if ( Current_entity[entity_checked] != undefined ){
if ( Object.keys( Current_entity[entity_checked] ).length > 0 ) {
PDOOUI.renderInterface( entity_checked );
//... call the OOUI renderer to render what belongs to this input
}
}
});
}
});