Conditional to Draw Certain Items from REST To Corresponding Tabbed DataTable
Conditional to Draw Certain Items from REST To Corresponding Tabbed DataTable
Hello,
I have a tabbed DataTable which I am populating through GETTING SharePoint list items through a REST API, everything on this SharePoint list is organized by a column/field with the title Department. In my tabbed DataTable each tab represents a different department. If Department == IT then it would post to the IT tab table. I cannot figure out how to write this conditional, do I call it in my success function of my AJAX call or in the actual DataTable function itself.
Here is an example of my JSON from the REST call:
{
"d": {
"results": [
{
"User": {
"Id": 79,
"Title": "Piers Charlotte"
},
"Monday": "2021-03-15T04:00:00Z",
"MondayStatus": "P",
"MondayLocation": "Office",
"TuesdayStatus": "P",
"TuesdayLocation": "Office",
"WednesdayStatus": "P",
"WednesdayLocation": "Office",
"ThursdayStatus": "P",
"ThursdayLocation": "Office",
"FridayStatus": "P",
"FridayLocation": "Office",
"Tuesday": "2021-03-16T04:00:00Z",
"Wednesday": "2021-03-17T04:00:00Z",
"Thursday": "2021-03-18T04:00:00Z",
"Friday": "2021-03-19T04:00:00Z",
"Sunday": "2021-03-14T05:00:00Z",
"Locations": "Mar-15: Office, Mar-16: Office, Mar-17: Office, Mar-18: Office, Mar-19: Office",
"Department": "IT"
},
{
"User": {
"Id": 76,
"Title": "Rokurou Aran"
},
"Monday": "2021-03-15T04:00:00Z",
"MondayStatus": "P",
"MondayLocation": "Office",
"TuesdayStatus": "P",
"TuesdayLocation": "Office",
"WednesdayStatus": "P",
"WednesdayLocation": "Office",
"ThursdayStatus": "P",
"ThursdayLocation": "Office",
"FridayStatus": "P",
"FridayLocation": "Office",
"Tuesday": "2021-03-16T04:00:00Z",
"Wednesday": "2021-03-17T04:00:00Z",
"Thursday": "2021-03-18T04:00:00Z",
"Friday": "2021-03-19T04:00:00Z",
"Sunday": "2021-03-14T05:00:00Z",
"Locations": "Mar-15: Office, Mar-16: Office, Mar-17: Office, Mar-18: Office, Mar-19: Office",
"Department": "HR"
}
]
}
}
Here is my DataTable (putting it into a JSFiddle because it is too long to insert into post):
https://jsfiddle.net/x5zan69b/
Answers
Is this the same question as your other thread?
Please don’t post duplicate questions.
There are some choices. The solution you use is based on your environment and solution. Some options
Kevin
My apologies I made a new question because this one sat untouched for so long. I figured it was because I did not provide a working test case which I then took the time to create to ensure best feedback from y'all as possible. Ok, I will try and create a new test case with above suggestion. I am just confused as to how different AJAX calls will work since I am calling all from the same list
Its just that no one has had the chance to answer. We would definitely tell you that a test case is needed:)
Kevin
That would depend on your server environment. Are you able to send parameters with the department to filter the results?
Kevin
Here is an example of the more than one AJAX call, I am unsure what you mean by calling the "keys" in the success function. Could I create a switch to use within the loadData function?
My server environment is SharePoint
So the environment I am pulling it from is a SharePoint list located on the same level site collection. With this, I would only think I would need one AJAX request. I am seeing like 11 different requests in my Network Tab, all pulling the same information.
I came up with
but this doesn't populate anything to to the DataTable and leaves no errors. So I am confused.
There are lots of ways to handle this. They all use generic Javascript techniques and the best technique to use is based on your overall solution.
One way is to loop through all the data similar to what you have and add each row individually to the table using
row.add()
, nos
after row. Something like this:I'm making some assumptions that the table IDs are all lower case and match the department name in the JSON data. Notice the removal of the chained
.draw()
. You will want to draw the table once after all the rows are added. Maybe when showing the tab. The code snippet might need work but I think its close.Kevin