ComunicWeb/assets/js/common/functionsSchema.js

755 lines
12 KiB
JavaScript
Raw Normal View History

/**
* Comunic WebApp schema
*
* @author Pierre HUBERT
*/
/**
* ComunicWeb main object
*/
var ComunicWeb = {
2017-05-22 18:06:17 +02:00
/**
* Configuration inclusion
*/
__config: ComunicConfig,
/**
* List of available pages
*/
pagesList:{},
2017-05-22 18:06:17 +02:00
/**
* Common functions
*/
common:{
/**
* Application system functions
*/
system:{
2017-05-25 15:46:38 +02:00
/**
* Initializate the application
*/
2017-06-14 11:46:10 +02:00
init: function(openPage){},
2017-05-25 15:46:38 +02:00
/**
* Restart the application
*/
restart: function(){},
2017-06-14 11:46:10 +02:00
/**
* Reset the application
*/
reset: function(complete, openPage){},
2017-05-22 18:06:17 +02:00
},
/**
* API functions
*/
api: {
/**
* Make an API request
*/
makeAPIrequest: function(apiURI, params, requireLoginTokens, nextAction){},
},
2017-06-14 11:46:10 +02:00
/**
* Global cache management system
*/
cacheManager:{
//TODO : implement
},
2017-05-22 18:06:17 +02:00
/**
* Langs functions
*/
langs: {
/**
* Return current language
*/
getCurrentLanguage: function(){},
/**
* Include and install specified language
*/
installLanguage: function(languageID){},
/**
* Initializate languages
*/
initLanguages: function(){},
/**
* Return a string in correct language
*/
getTranslatedText: function(stringName, stringParams){},
},
/**
* Messages functions
*/
messages: {
/**
* Create and return a callout element
*/
createCalloutElem: function(calloutTitle, calloutMessage, calloutType){},
},
/**
* Error functions
*/
error:{
/**
* Submit an error
*/
submitError: function(errorLevel, errorMessage, errorCode, errorData){},
/**
* Handle and show a fatal error
*/
fatalError: function(errorMessage, errorCode, errorData){},
/**
* Handle a 404 not found error
*/
pageNotFound: function(additionnalData, targetElement){},
},
/**
* URL functions
*/
url:{
/**
* Return current URL opened on the website
*/
getCurrentWebsiteURL: function(){},
/**
* Change the current website URI
*/
changeURI: function(newTitle, newURI){},
},
/**
* Page functions
*/
page: {
/**
* Empty current page
*/
emptyPage: function(createWrapper){},
/**
* Show a full wait splash screen
*
* @param {String} message A message to explain the reason of the splash screen (optionnal)
*/
showWaitSplashScreen: function(message){},
/**
* Show a transparent wait splash screen
*/
2017-06-07 16:55:47 +02:00
showTransparentWaitSplashScreen: function(target){},
2017-05-22 18:06:17 +02:00
/**
* Open a page
*/
openPage: function(pageURI, additionnalData){},
/**
* Prepare a template load by specifying datas
*/
prepareLoadTemplate: function(){},
/**
* Load, parse and show an HTML template
*/
getAndShowTemplate: function(targetElem, dataTemplate, templateURI, nextAction, cleanContener){},
/**
* Convert a JSON object into html elements
*/
convertJSONobjectTOhtmlElement: function(parentNodeChilds, values){},
/**
* Get and show a JSON template
*/
getAndShowJSONtemplate: function(targetElem, templateURI, additionalData, afterParsingJSONtemplate, cleanContener){},
},
/**
* Functions to check data input in forms
*/
formChecker: {
2017-05-25 15:46:38 +02:00
/**
* Check an input
*/
checkInput: function(input, inFormGroup){},
2017-05-22 18:06:17 +02:00
},
/**
* Notification system
*/
notificationSystem: {
/**
* Display a notification
*/
showNotification: function(message, notifType, notifDuration, notifTitle){},
},
/**
* Network common requests
*/
network: {
/**
* @var {object} Cache contener
*/
cache: {},
/**
* Make a get request
*/
getRequest: function(url, cache, GETnextAction){},
2017-06-14 11:46:10 +02:00
/**
* Empty network cache
*/
emptyCache: function(){},
/**
* Update the status of the network
*/
setStatus: function(success){},
2017-05-22 18:06:17 +02:00
},
/**
* Operations on JS files
*/
jsFiles:{
/**
* Include a Javascript file
*/
includeFile: function(fileURL){},
/**
* Execute some source code contained in a variable
*/
executeJSsource: function(source){},
},
2017-06-03 14:25:21 +02:00
/**
* The date library
*/
date:{
//TODO: implement
},
2017-05-22 18:06:17 +02:00
},
/**
* Debug functions
*/
debug:{
/**
* @var {Object} Internal log variable
*/
__log: {},
/**
* Display message on browser console
*/
logMessage: function(message){},
/**
* Save a new log message
*/
saveLogMessage: function(message){},
/**
* Get log content in a string
*/
getLogContent: function(){},
/**
* Display Comunic Logo on the developper console
*/
displayComunicLogo: function(){},
2017-05-22 18:06:17 +02:00
},
/**
* User functions
*/
user:{
/**
* Login tokens storage controller
*/
loginTokens: {
/**
* Set User tokens
*/
setUserTokens: function(tokens, storageType){},
/**
* Check if there is any login tokens available
*/
checkLoginTokens: function(){},
/**
* Get login tokens
*/
getLoginTokens: function(){},
/**
* Perform user logout
*/
deleteLoginTokens: function(){},
},
/**
* Manage user login
*/
userLogin: {
/**
* @var {Boolean} Store user login state (true by default)
*/
__userLogin: true,
/**
* @var {Integer} Store the current user ID
*/
__userID: 0,
/**
* Tell if user is logged in or not
*/
getUserLoginState: function(){},
/**
* Get user ID (if logged in)
*/
getUserID: function(){},
/**
* Try to get and store current user ID
*/
getCurrentUserId: function(afterGetCurrentUserID){},
/**
* Refresh the user login state
*/
refreshLoginState: function(afterLogin){},
/**
* Try to login user
*/
loginUser: function(usermail, userpassword, permanentLogin, afterLogin){},
/**
* Logout user
*/
logoutUser: function(afterLogout){},
},
/**
* Get user infos
*/
userInfos: {
2017-05-25 15:46:38 +02:00
/**
* @var {String} User infos cache
*/
usersInfos: {},
/**
* Get user informations
*/
2017-05-27 15:35:10 +02:00
getUserInfos: function(userID, afterGetUserInfos, forceRequest){},
2017-05-25 15:46:38 +02:00
2017-05-27 15:11:30 +02:00
/**
* Get multiple users informations
*/
2017-05-27 15:35:10 +02:00
getMultipleUsersInfos: function(usersID, afterGetUserInfos, forceRequest){},
2017-05-27 15:11:30 +02:00
2017-05-25 15:46:38 +02:00
/**
* Empty user informations cache
* Remove all entries from user informations cache
*/
2017-05-25 15:53:41 +02:00
emptyUserInfosCache: function(){},
2017-06-05 14:35:28 +02:00
/**
* Given a query, search for users and return the result
*/
search: function(query, afterSearch){},
2017-06-13 16:42:09 +02:00
/**
* Given user IDs (in an array) the function return their names in a string
*/
getNames: function(usersID, afterNames){},
2017-06-14 11:46:10 +02:00
/**
* Get advanced informations about a user
*/
getAdvancedInfos: function(userID, callback){},
/**
* Get the user ID specified by its folder name
*/
getIDfromPath: function(path, callback){},
2017-06-14 11:46:10 +02:00
/**
* Empty users cache
*/
emptyCache: function(){},
2017-05-22 18:06:17 +02:00
},
},
/**
* Application components
*/
components: {
/**
* Menubar
*/
menuBar: {
/**
* Menu bar object - common methods
*/
common:{
2017-05-25 15:53:41 +02:00
/**
* Display menu bar
*/
display: function(){},
/**
* Initializate a menubar
*/
init: function(menuContainer){},
/**
* Reset a specified menubar
*/
reset: function(menuBar){},
},
/**
* Not authenticated menu bar components
*/
notAuthenticated: {
2017-05-25 15:53:41 +02:00
/**
* Add not-authenticated user specific elements
*/
addElements: function(container){},
},
/**
* Menubar for authenticated users complements
*/
authenticated:{
2017-05-25 15:53:41 +02:00
/**
* Add authenticated user specific elements
*/
addElements: function(container){},
/**
* Add dropdown menu
*/
addDropdown: function(navbarElem){},
2017-06-03 15:41:04 +02:00
/**
* Add user friends toggle button
*/
addFriendListButton: function(navbarElem){},
2017-05-25 15:53:41 +02:00
/**
* Add user name element
*/
addUserName: function(navbarElem){},
2017-05-26 11:38:37 +02:00
/**
* Add search form element
*/
addSearchForm: function(navbarElem){},
},
2017-05-22 18:06:17 +02:00
},
2017-05-24 16:37:41 +02:00
/**
* Mails caching component
*/
mailCaching: {
2017-05-25 15:53:41 +02:00
/**
* @var Mail caching variable name
*/
__mailCachingVarName: "lastLoginMail",
/**
* Get current cached value
*/
get: function(){},
/**
* Set a new mail value
*/
set: function(mail){},
2017-05-26 12:01:54 +02:00
},
/**
* Search form component
*/
searchForm: {
//TODO : implement
},
2017-05-24 16:37:41 +02:00
2017-05-28 13:48:19 +02:00
/**
* Friends list
*/
2017-05-31 16:51:52 +02:00
friends: {
/**
* Friends list caching system
*/
list:{
2017-06-14 11:46:10 +02:00
//TODO : implement
2017-05-31 16:51:52 +02:00
},
/**
* Friends bar
*/
bar:{
2017-06-14 11:46:10 +02:00
//TODO : implement
2017-05-31 16:51:52 +02:00
},
2017-06-03 18:18:43 +02:00
},
/**
2017-06-07 19:24:48 +02:00
* Conversations
2017-06-03 18:18:43 +02:00
*/
2017-06-07 19:24:48 +02:00
conversations:{
2017-06-03 18:18:43 +02:00
/**
2017-06-07 19:24:48 +02:00
* Conversations manager
2017-06-03 18:18:43 +02:00
*/
manager:{
//TODO : implement
},
2017-06-05 10:12:38 +02:00
/**
2017-06-07 19:24:48 +02:00
* Conversations list windo
2017-06-05 10:12:38 +02:00
*/
list:{
//TODO : implement
},
/**
2017-06-07 19:24:48 +02:00
* Conversations windows manager
2017-06-05 10:12:38 +02:00
*/
windows:{
2017-06-14 11:46:10 +02:00
//TODO : implement
2017-06-05 10:12:38 +02:00
},
/**
* Conversation chat window functions
*/
chatWindows: {
//TODO : implement
},
/**
2017-06-07 19:24:48 +02:00
* Interface between conversation UI and the API
*/
2017-06-14 11:46:10 +02:00
interface:{
//TODO : implement
},
/**
* Opened conversations caching system
*/
cachingOpened:{
//TODO : implement
},
/**
* Conversation service file
*/
service:{
//TODO : implement
},
/**
* Conversations utilities
*/
utils:{
//TODO : implement
}
2017-06-03 18:18:43 +02:00
},
2017-06-05 16:03:14 +02:00
/**
* User selector
*/
userSelect:{
//TODO : implement
2017-06-20 13:29:15 +02:00
},
/**
* Emoji functions
*/
emoji:{
/**
* Emoji parser system
*/
parser: {
//TODO : implement
},
/**
* Emojies list
*/
list: {
//TODO : implement
},
2017-06-20 13:29:15 +02:00
},
2017-06-21 12:10:22 +02:00
/**
* Modern textarea handler
*/
textarea: {
},
2017-05-22 18:06:17 +02:00
},
/**
* Pages controllers
*/
pages:{
/**
* Home page
*/
home: {
/**
* Common homes functions
*/
home:{
/**
* Open home page
*/
openHomePage: function(additionnalData, targetElement){},
},
2017-05-22 18:12:50 +02:00
/**
* Landing home page
*/
landingPage:{
2017-05-25 15:53:41 +02:00
/**
* Display home landing page
*/
display: function(targetElement){},
2017-05-22 18:12:50 +02:00
}
2017-05-22 18:06:17 +02:00
},
/**
* User page
*/
userPage: {
/**
* Main user page
*/
main: {
/**
* Open user page
*/
open: function(params, target){},
/**
* Open user page specified by user ID
*/
openUserPage: function(id, params, target){},
/**
* Display a user page
*/
displayUserPage: function(infos, params, target){},
},
/**
* Page with access forbidden
*/
accessForbidden: {
/**
* Display the page for user with forbidden access
*/
2017-12-17 19:14:19 +01:00
display: function(id, params, target){},
2017-12-17 19:14:19 +01:00
/**
* Show basic user informations
*/
showBasicInfos: function(userInfos, target){},
},
2017-12-20 19:18:18 +01:00
/**
* Handle the rendering of the friendship status
*/
friendshipStatus: {
/**
* Display the friendship status
*/
display: function(userID, target){},
//TODO : implement
},
2017-12-23 14:52:01 +01:00
/**
* Display user profile informations
*/
profileInfos: {
//TODO : implement
}
},
2017-05-22 18:06:17 +02:00
/**
* Login controller
*/
login:{
/**
* Open login page
*/
openLoginPage: function(additionnalData, targetElement){},
/**
* Perform user login
*/
loginSubmit: function(){},
/**
* Display login error message
*
* @return {Boolean} True for a success
*/
displayLoginError: function(){},
2017-05-22 18:06:17 +02:00
},
/**
* Logout controller
*/
logout: {
/**
* Open logout page and perform logout
*/
openLogoutPage: function(additionnalData, targetElement){},
},
},
};