2016-10-12 16:43:51 +00:00
function inputPhoneMini ( a , c ) { this . container = a ; this . nav _container = c } inputPhoneMini . prototype = { container : this . container , nav _container : this . nav _container , selected : null , handler : null , defaultData : { contact : null , sexe : "2" , age : "." , studies : "0" , loc : "." , reltype : "9" , reltypeSpecial : "" , unknown : ! 1 , timestamp : 0 , valid : ! 1 } } ;
2016-10-17 08:14:50 +00:00
inputPhoneMini . prototype . fieldsToStorage = function ( ) { console . group ( "[phone.mini] fields to storage" ) ; for ( var a = $$ ( '[data-sublink="phone"] article.mini-relation-panel .mini-fiche-relation' ) , c = 0 ; c < a . length ; c ++ ) { var b = ( new FormDeflater ( a [ c ] , [ "input" , "select" ] , [ "data-name" ] ) ) . deflate ( ) , e = crc32 ( JSON . stringify ( b ) ) , d = lsi . get ( "p_mini-fiches" , b . uid ) ; if ( ! 1 !== d ) { if ( null != d && null != d . hash && d . hash == e ) return ; console . warn ( "> MINI UPDATE" ) ; b = { uid : parseInt ( b . uid ) , contact : parseInt ( b . uid ) , sexe : b . sexe , age : b . age , studies : b . studies ,
2016-10-17 09:45:25 +00:00
reltype : b . reltype , reltypeSpecial : b . reltypeSpecial , loc : b . loc , unknown : null != b . unknown , hash : e } ; b . valid = this . check ( b ) ; 0 < diff ( d , b , [ "hash" , "valid" , "timestamp" ] ) . length ? ( console . log ( diff ( d , b , [ "hash" , "valid" , "timestamp" ] ) ) , console . warn ( "> MINI UPDATE" ) , b . timestamp = Date . now ( ) ) : void 0 == d . timestamp && ( b . timestamp = this . defaultData . timestamp ) ; lsi . set ( "p_mini-fiches" , b . uid , b ) } } console . groupEnd ( ) } ;
2016-10-12 16:43:51 +00:00
inputPhoneMini . prototype . add = function ( a ) { if ( null == a || null == a . uid ) return ! 1 ; a . age = null != a . age ? a . age : this . defaultData . age ; a . sexe = null != a . sexe ? a . sexe : this . defaultData . sexe ; a . studies = null != a . studies ? a . studies : this . defaultData . studies ; a . reltype = null != a . reltype ? a . reltype : this . defaultData . reltype ; a . reltypeSpecial = null != a . reltypeSpecial ? a . reltypeSpecial : this . defaultData . reltypeSpecial ; a . loc = null != a . loc ? a . loc : this . defaultData . loc ; a . unknown = null != a . unknown ? a . unknown : this . defaultData . unknown ; var c = lsi . get ( "p_contacts" ,
a . uid ) ; if ( ! 1 === c ) return ! 1 ; if ( ! isNaN ( c . existing ) ) { var b = lsi . get ( "p_friends" , c . existing ) ; c . username = b . name ; a . contact = c . uid ; a . age = b . age ; a . sexe = b . sexe ; a . loc = b . dist ; isNaN ( b . reltype ) ? ( a . reltype = 10 , a . reltypeSpecial = b . reltype ) : ( a . reltype = b . reltype , a . reltypeSpecial = "" ) ; null != b . studies1 && ( a . studies = b . studies1 ) } this . container . innerHTML += pMiniFicheBuilder . build ( { name : c . username , countcall : c . countcall , countsms : c . countsms , uid : a . uid , reltypespecial : a . reltypeSpecial } ) ; c = $ ( '[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="' +
a . uid + '"] ~ h5>span>select[data-name="studies"]>option[value="' + a . studies + '"]' ) ; null != c && c . setAttribute ( "selected" , "selected" ) ; c = $ ( '[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="' + a . uid + '"] ~ h5>span>select[data-name="age"]>option[value="' + a . age + '"]' ) ; null != c && c . setAttribute ( "selected" , "selected" ) ; b = $$ ( '[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="' + a . uid + '"] ~ h5>input[type="radio"][data-name="sexe"]' ) ; for ( c = 0 ; c < b . length ; c ++ ) b [ c ] . value ==
a . sexe ? b [ c ] . setAttribute ( "checked" , "checked" ) : b [ c ] . removeAttribute ( "checked" ) ; b = $$ ( '[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="' + a . uid + '"] ~ h5>input[type="radio"][data-name="reltype"]' ) ; for ( c = 0 ; c < b . length ; c ++ ) b [ c ] . value == a . reltype ? b [ c ] . setAttribute ( "checked" , "checked" ) : b [ c ] . removeAttribute ( "checked" ) ; b = $$ ( '[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="' + a . uid + '"] ~ h5>input[type="radio"][data-name="loc"]' ) ; for ( c = 0 ; c < b . length ; c ++ ) b [ c ] . value ==
a . loc ? b [ c ] . setAttribute ( "checked" , "checked" ) : b [ c ] . removeAttribute ( "checked" ) ; c = $ ( '[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="' + a . uid + '"] ~ h5>input[type="checkbox"][data-name="unknown"]' ) ; null != c && a . unknown && c . setAttribute ( "checked" , "checked" ) } ;
2016-10-14 09:38:46 +00:00
inputPhoneMini . prototype . storageToFields = function ( ) { console . group ( "[phone.mini] storage to fields" ) ; var a = lsi . get ( "p_mini-fiches" , this . selected ) ; if ( null === a ) { if ( null === this . selected ) return a = lsi . keys ( "p_mini-fiches" ) , 0 < a . length ? ( this . selected = a [ 0 ] , this . storageToFields ( ) ) : ! 1 ; this . updateNavBar ( ) ; return ! 1 } this . container . innerHTML = "" ; this . add ( a ) ; this . updateNavBar ( ) ; console . groupEnd ( ) } ;
2016-10-12 16:43:51 +00:00
inputPhoneMini . prototype . sync = function ( ) { console . group ( "[phone.mini] synchronisation" ) ; var a = lsi [ "export" ] ( "p_contacts" ) , c ; ficheIndexes = lsi . keys ( "p_fiches" ) ; for ( c in ficheIndexes ) delete a [ ficheIndexes [ c ] ] ; for ( var b in a ) { var e = 0 == a [ b ] . username . length ? b . toString ( ) + "-" : b ; c = lsi . get ( "p_mini-fiches" , e ) ; null == c && ( c = this . defaultData , c . contact = a [ b ] . uid , c . valid = ! 1 ) ; c . uid = parseInt ( b ) ; lsi . set ( "p_mini-fiches" , e , c ) } c = lsi [ "export" ] ( "p_mini-fiches" ) ; if ( null == c [ this . selected ] ) for ( b in c ) if ( ! isNaN ( b ) ) { this . selected =
parseInt ( b ) ; break } console . groupEnd ( ) } ; inputPhoneMini . prototype . nav = function ( a ) { if ( ! ( a instanceof Element && a . getData ( "n" ) ) || isNaN ( a . getData ( "n" ) ) || "p_nav-mini" != a . parentNode . id ) return ! 1 ; for ( var c = $$ ( '[data-sublink="phone"] #p_nav-mini > span.active' ) , b = 0 ; b < c . length ; b ++ ) c [ b ] . remClass ( "active" ) ; a . addClass ( "active" ) ; this . selected = parseInt ( a . getData ( "n" ) ) } ;
inputPhoneMini . prototype . updateNavBar = function ( ) { var a = lsi [ "export" ] ( "p_mini-fiches" ) ; this . nav _container . innerHTML = "" ; var c = 0 , b ; for ( b in a ) isNaN ( b ) || ( this . nav _container . innerHTML += '<span data-n="' + b + '">' + ++ c + "</span>" ) ; for ( b in a ) isNaN ( b ) || ( c = $ ( '[data-sublink="phone"] #p_nav-mini [data-n="' + a [ b ] . uid + '"]' ) , null != c && ( ! 0 === a [ b ] . valid ? c . addClass ( "done" ) : c . remClass ( "done" ) ) ) ; this . nav ( $ ( '[data-sublink="phone"] #p_nav-mini [data-n="' + this . selected + '"]' ) ) } ;
inputPhoneMini . prototype . check = function ( a ) { return a . unknown ? ! 0 : "" == a . sexe || "." == a . studies || "." == a . age || "" == a . loc || "" == a . reltype || "10" == a . reltype && 2 > a . reltypeSpecial . length ? ! 1 : ! 0 } ; inputPhoneMini . prototype . attach = function ( a ) { console . group ( "[phone.mini] attaching events" ) ; lsi . createDataset ( "p_mini-fiches" ) ; this . storageToFields ( ) ; this . handler = a ; this . nav _container . addEventListener ( "click" , function ( a ) { this . nav ( a . target ) ; this . handler ( a . target ) } . bind ( this ) , ! 1 ) ; console . groupEnd ( ) } ;