Send a request to the server to create the group

This commit is contained in:
Pierre HUBERT
2018-07-02 08:42:55 +02:00
parent 7ff7bceca3
commit 28cb1e22e7
6 changed files with 197 additions and 25 deletions

View File

@ -993,7 +993,21 @@ var ComunicWeb = {
//TODO : implement
}
}
},
/**
* Groups component
*/
groups: {
/**
* API interface
*/
interface: {
//TODO : implement
},
},
},
@ -1189,7 +1203,14 @@ var ComunicWeb = {
*/
main: {
//TODO : implement
}
},
/**
* Create a group page
*/
create: {
//TODO : implement
},
}
},

View File

@ -0,0 +1,25 @@
/**
* Groups API interface
*
* @author Pierre HUBERT
*/
ComunicWeb.components.groups.interface = {
/**
* Create a group
*
* @param {String} name The name of the group to create
* @param {Function} callback
*/
create: function(name, callback){
//Perform a request over the API
var apiURI = "groups/create";
var params = {
name: name
};
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, callback);
}
};

View File

@ -6,7 +6,7 @@
ComunicWeb.pages.groups.main = {
/**
/**
* Open settings page
*
* @param {object} args Optionnal arguments
@ -14,29 +14,34 @@ ComunicWeb.pages.groups.main = {
*/
open: function(args, target){
//Determine which page / group should be opened
if(!args.subfolder)
var page = "main";
else {
//Determine which page / group should be opened
if(!args.subfolder)
var page = "main";
else {
//Extract the name of the page from the URL
if(!args.subfolder.includes("/"))
var page = args.subfolder;
else {
var page = args.subfolder.split("/")[0];
}
//Extract the name of the page from the URL
if(!args.subfolder.includes("/"))
var page = args.subfolder;
else {
var page = args.subfolder.split("/")[0];
}
}
}
//Check if the main page has to be opened
if(page == "main"){
ComunicWeb.pages.groups.pages.main.open(target);
}
//Check if the main page has to be opened
if(page == "main" && signed_in()){
ComunicWeb.pages.groups.pages.main.open(target);
}
//Else the page was not found
else
ComunicWeb.common.error.pageNotFound(args, target);
}
//Check if the page to create a group has to be opened
else if (page == "create" && signed_in()){
ComunicWeb.pages.groups.pages.create.open(target);
}
//Else the page was not found
else
ComunicWeb.common.error.pageNotFound(args, target);
}
};

View File

@ -0,0 +1,89 @@
/**
* Create a group page
*
* @author Pierre HUBERT
*/
ComunicWeb.pages.groups.pages.create = {
/**
* Open the page
*
* @param {HTMLElement} target The target of the page
*/
open: function(target){
//Update page title
document.title = "Create a group";
//Create page container
var pageContainer = createElem2({
appendTo: target,
type: "div",
class: "create-group-page"
});
//Form container
var formContainer = createElem2({
appendTo: pageContainer,
type: "form",
});
//Form title
createElem2({
appendTo: formContainer,
type: "h3",
innerHTML: "Create a group"
})
//Group name input
var nameInput = createFormGroup({
target: formContainer,
label: "Group name",
placeholder: "The name of the group",
type: "text"
});
//Add submit button
var submitContainer = createElem2({
appendTo: formContainer,
type: "div",
class: "submit-button-container"
});
createElem2({
appendTo: submitContainer,
type: "input",
elemType: "submit",
class: "btn btn-primary",
value: "Create"
});
//Handle form submit
formContainer.onsubmit = function(){
//Check user inputs
if(!ComunicWeb.common.formChecker.checkInput(nameInput, true)){
notify("Please specify the name of the group!", "danger");
return false;
}
//Perform a request on the server to create the group
ComunicWeb.components.groups.interface.create(nameInput.value, function(res){
//Check for errors
if(res.error){
return notify("An error occured while trying to create the group!", "danger");
}
//Redirect to the group page
openPage("groups/" + res.id);
});
//Prevent default behavior
return false;
}
}
};