@ -78,8 +78,11 @@ define([
var CREATE _ID = "createProfile" ;
var CREATE _ID = "createProfile" ;
var HEADER _ID = "header" ;
var HEADER _ID = "header" ;
var HEADER _RIGHT _ID = "rightside" ;
var HEADER _RIGHT _ID = "rightside" ;
var CREATE _INVITE _BUTTON = 'inviteButton' ;
var VIEW _PROFILE _BUTTON = 'viewProfileButton' ;
var createEditableInput = function ( $block , name , ph , getValue , setValue , realtime ) {
var createEditableInput = function ( $block , name , ph , getValue , setValue , realtime , fallbackValue ) {
fallbackValue = fallbackValue || '' ; // don't ever display 'null' or 'undefined'
var lastVal ;
var lastVal ;
getValue ( function ( value ) {
getValue ( function ( value ) {
lastVal = value ;
lastVal = value ;
@ -104,7 +107,7 @@ define([
if ( err ) { return void console . error ( err ) ; }
if ( err ) { return void console . error ( err ) ; }
Cryptpad . whenRealtimeSyncs ( realtime , function ( ) {
Cryptpad . whenRealtimeSyncs ( realtime , function ( ) {
lastVal = newVal ;
lastVal = newVal ;
Cryptpad . log ( Messages . _getKey ( 'profile_fieldSaved' , [ newVal ] ) ) ;
Cryptpad . log ( Messages . _getKey ( 'profile_fieldSaved' , [ newVal || fallbackValue ] ) ) ;
editing = false ;
editing = false ;
} ) ;
} ) ;
} ) ;
} ) ;
@ -150,8 +153,69 @@ define([
createEditableInput ( $block , DISPLAYNAME _ID , placeholder , 32 , getValue , setValue , rt ) ;
createEditableInput ( $block , DISPLAYNAME _ID , placeholder , 32 , getValue , setValue , rt ) ;
} ;
} ;
* /
* /
var addCreateInviteLinkButton = function ( $container ) {
var obj = APP . lm . proxy ;
var proxy = Cryptpad . getProxy ( ) ;
var userViewHash = Cryptpad . find ( proxy , [ 'profile' , 'view' ] ) ;
if ( ! APP . readOnly || ! obj . curveKey || userViewHash === window . location . hash . slice ( 1 ) ) {
console . log ( "edit mode or missing curve key, or you're viewing your own profile" ) ;
return ;
}
// sanitize user inputs
var unsafeName = obj . name || '' ;
console . log ( unsafeName ) ;
var name = Cryptpad . fixHTML ( unsafeName ) || Messages . anonymous ;
console . log ( name ) ;
console . log ( "Creating invite button" ) ;
var $button = $ ( "<button>" , {
id : CREATE _INVITE _BUTTON ,
title : Messages . profile _inviteButtonTitle ,
} )
. addClass ( 'btn btn-success' )
. text ( Messages . profile _inviteButton )
. click ( function ( e ) {
Cryptpad . confirm ( Messages . _getKey ( 'profile_inviteExplanation' , [ name ] ) , function ( yes ) {
if ( ! yes ) { return ; }
console . log ( obj . curveKey ) ;
Cryptpad . alert ( "TODO" ) ;
// TODO create a listmap object using your curve keys
// TODO fill the listmap object with your invite data
// TODO generate link to invite object
// TODO copy invite link to clipboard
} , null , true ) ;
} )
. appendTo ( $container ) ;
} ;
var addViewButton = function ( $container ) {
if ( ! Cryptpad . isLoggedIn ( ) || window . location . hash ) {
return ;
}
var hash = Cryptpad . find ( Cryptpad . getProxy ( ) , [ 'profile' , 'view' ] ) ;
var url = '/profile/#' + hash ;
var $button = $ ( '<button>' , {
'class' : 'btn btn-success' ,
id : VIEW _PROFILE _BUTTON ,
} )
. text ( Messages . profile _viewMyProfile )
. click ( function ( ) {
window . open ( url , '_blank' ) ;
} ) ;
$container . append ( $button ) ;
} ;
var addDisplayName = function ( $container ) {
var addDisplayName = function ( $container ) {
var $block = $ ( '<div>' , { id : DISPLAYNAME _ID } ) . appendTo ( $container ) ;
var $block = $ ( '<div>' , { id : DISPLAYNAME _ID } ) . appendTo ( $container ) ;
var getValue = function ( cb ) {
var getValue = function ( cb ) {
cb ( APP . lm . proxy . name ) ;
cb ( APP . lm . proxy . name ) ;
} ;
} ;
@ -161,6 +225,8 @@ define([
getValue ( function ( value ) {
getValue ( function ( value ) {
$span . text ( value || Messages . anonymous ) ;
$span . text ( value || Messages . anonymous ) ;
} ) ;
} ) ;
addCreateInviteLinkButton ( $block ) ;
return ;
return ;
}
}
var setValue = function ( value , cb ) {
var setValue = function ( value , cb ) {
@ -168,7 +234,7 @@ define([
cb ( ) ;
cb ( ) ;
} ;
} ;
var rt = Cryptpad . getStore ( ) . getProxy ( ) . info . realtime ;
var rt = Cryptpad . getStore ( ) . getProxy ( ) . info . realtime ;
createEditableInput ( $block , DISPLAYNAME _ID , placeholder , getValue , setValue , rt );
createEditableInput ( $block , DISPLAYNAME _ID , placeholder , getValue , setValue , rt , Messages . anonymous );
} ;
} ;
var addLink = function ( $container ) {
var addLink = function ( $container ) {
@ -330,9 +396,18 @@ define([
$container . append ( $block ) ;
$container . append ( $block ) ;
} ;
} ;
var onReady = function ( ) {
var onReady = function ( ) {
APP . $container . find ( '#' + CREATE _ID ) . remove ( ) ;
APP . $container . find ( '#' + CREATE _ID ) . remove ( ) ;
var obj = APP . lm && APP . lm . proxy ;
if ( ! APP . readOnly ) {
var pubKeys = Cryptpad . getPublicKeys ( ) ;
if ( pubKeys && pubKeys . curve ) {
obj . curveKey = pubKeys . curve ;
}
}
if ( ! APP . initialized ) {
if ( ! APP . initialized ) {
var $header = $ ( '<div>' , { id : HEADER _ID } ) . appendTo ( APP . $container ) ;
var $header = $ ( '<div>' , { id : HEADER _ID } ) . appendTo ( APP . $container ) ;
addAvatar ( $header ) ;
addAvatar ( $header ) ;
@ -340,6 +415,7 @@ define([
addDisplayName ( $rightside ) ;
addDisplayName ( $rightside ) ;
addLink ( $rightside ) ;
addLink ( $rightside ) ;
addDescription ( APP . $container ) ;
addDescription ( APP . $container ) ;
addViewButton ( APP . $container ) ; //$rightside);
addPublicKey ( APP . $container ) ;
addPublicKey ( APP . $container ) ;
APP . initialized = true ;
APP . initialized = true ;
}
}
@ -377,7 +453,7 @@ define([
if ( obj . profile && obj . profile . view && obj . profile . edit ) {
if ( obj . profile && obj . profile . view && obj . profile . edit ) {
return void andThen ( obj . profile . edit ) ;
return void andThen ( obj . profile . edit ) ;
}
}
// If the user doesn't have a public profile, ask him if he wants to create one
// If the user doesn't have a public profile, ask them if they want to create one
var todo = function ( ) {
var todo = function ( ) {
var secret = Cryptpad . getSecrets ( ) ;
var secret = Cryptpad . getSecrets ( ) ;
obj . profile = { } ;
obj . profile = { } ;