mirror of
https://github.com/LukeHagar/developer.sailpoint.com.git
synced 2025-12-10 04:19:42 +00:00
added pagination logic to ambassador page
This commit is contained in:
@@ -79,6 +79,13 @@ const config = {
|
|||||||
darkTheme: darkCodeTheme,
|
darkTheme: darkCodeTheme,
|
||||||
additionalLanguages: ['http', 'java', 'ruby', 'php', 'csharp'],
|
additionalLanguages: ['http', 'java', 'ruby', 'php', 'csharp'],
|
||||||
},
|
},
|
||||||
|
mermaid: {
|
||||||
|
options: {
|
||||||
|
er: {
|
||||||
|
layoutDirection: 'RL'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
|
|
||||||
plugins: plugins,
|
plugins: plugins,
|
||||||
|
|||||||
@@ -12,9 +12,14 @@ export default function AmbassadorCards({
|
|||||||
const [loadingCards, setLoadingCards] = React.useState(true);
|
const [loadingCards, setLoadingCards] = React.useState(true);
|
||||||
|
|
||||||
const getPosts = async () => {
|
const getPosts = async () => {
|
||||||
const data = await getAmbassadors(expert);
|
let data = await getAmbassadors(expert, 1, 0);
|
||||||
|
|
||||||
const resultset = []
|
const resultset = []
|
||||||
|
|
||||||
|
if (data.meta) {
|
||||||
|
let count = 0
|
||||||
|
while (count < data.meta.total) {
|
||||||
|
data = await getAmbassadors(expert, 50, count);
|
||||||
|
count += 50
|
||||||
if (data.members) {
|
if (data.members) {
|
||||||
const memberDetails = await getAmbassadorDetails(data.members.map(item => item.id))
|
const memberDetails = await getAmbassadorDetails(data.members.map(item => item.id))
|
||||||
for (const member of data.members) {
|
for (const member of data.members) {
|
||||||
@@ -23,12 +28,19 @@ export default function AmbassadorCards({
|
|||||||
resultset.push(await getMemberList(member, memberDetail))
|
resultset.push(await getMemberList(member, memberDetail))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
setCardData(undefined);
|
||||||
|
setLoadingCards(false);
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
resultset.sort((a, b) => a.date - b.date)
|
resultset.sort((a, b) => a.date - b.date)
|
||||||
setCardData(resultset);
|
setCardData(resultset);
|
||||||
|
|
||||||
} else {
|
|
||||||
setCardData(undefined);
|
|
||||||
}
|
|
||||||
setLoadingCards(false);
|
setLoadingCards(false);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -10,16 +10,16 @@ export async function getTopPosts() {
|
|||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
export async function getAmbassadors(expert) {
|
export async function getAmbassadors(expert, limit, offset) {
|
||||||
try {
|
try {
|
||||||
if (expert) {
|
if (expert) {
|
||||||
const response = await fetch(
|
const response = await fetch(
|
||||||
discourseBaseURL() + 'groups/ambassador_expert/members.json',
|
discourseBaseURL() + 'groups/ambassador_expert/members.json?limit=' + limit + '&offset=' + offset,
|
||||||
);
|
);
|
||||||
return await response.json();
|
return await response.json();
|
||||||
} else {
|
} else {
|
||||||
const response = await fetch(
|
const response = await fetch(
|
||||||
discourseBaseURL() + 'groups/ambassador/members.json',
|
discourseBaseURL() + 'groups/ambassador/members.json?limit=' + limit + '&offset=' + offset,
|
||||||
);
|
);
|
||||||
return await response.json();
|
return await response.json();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user