Skip to content

Commit

Permalink
Fixed stakeholder map display (#395)
Browse files Browse the repository at this point in the history
  • Loading branch information
mlhaufe authored Oct 11, 2024
1 parent c8444a5 commit 85768c1
Showing 1 changed file with 20 additions and 19 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ const config = useAppConfig(),
if (getSolutionError.value)
$eventBus.$emit('page-error', getSolutionError.value);
const { data: stakeholders, refresh, status, error: getStakeholdersError } = await useFetch<Stakeholder[]>(`/api/stakeholders`, {
const { data: stakeholders, refresh: refreshStakeholders, status, error: getStakeholdersError } = await useFetch<Stakeholder[]>(`/api/stakeholders`, {
query: { solutionId },
transform: (data) => data.map((item) => {
item.lastModified = new Date(item.lastModified)
Expand All @@ -32,20 +32,6 @@ const { data: stakeholders, refresh, status, error: getStakeholdersError } = awa
if (getStakeholdersError.value)
$eventBus.$emit('page-error', getStakeholdersError.value);
// watch the stakeholders and re-render the chart
watch(stakeholders, async () => {
const groupStakeholders = Object.groupBy(stakeholders.value!, ({ segmentation }) => segmentation ?? 'unknown'),
clientGroup = groupStakeholders.Client ?? [],
vendorGroup = groupStakeholders.Vendor ?? [];
clientMap.value!.textContent = chartDefinition(clientGroup, StakeholderSegmentation.CLIENT)
vendorMap.value!.textContent = chartDefinition(vendorGroup, StakeholderSegmentation.VENDOR)
await mermaid.run({
nodes: [clientMap.value!, vendorMap.value!]
})
});
enum themeMap {
light = 'default',
dark = 'dark'
Expand Down Expand Up @@ -73,6 +59,21 @@ const chartDefinition = (stakeholders: Stakeholder[], category: StakeholderSegme
const clientMap = ref<HTMLElement>(),
vendorMap = ref<HTMLElement>();
const renderChart = async () => {
const groupStakeholders = Object.groupBy(stakeholders.value!, ({ segmentation }) => segmentation ?? 'unknown'),
clientGroup = groupStakeholders.Client ?? [],
vendorGroup = groupStakeholders.Vendor ?? [];
clientMap.value!.textContent = chartDefinition(clientGroup, StakeholderSegmentation.CLIENT)
vendorMap.value!.textContent = chartDefinition(vendorGroup, StakeholderSegmentation.VENDOR)
await mermaid.run({
nodes: [clientMap.value!, vendorMap.value!]
})
}
watch(stakeholders, renderChart);
const onCreate = async (data: Stakeholder) => {
await $fetch(`/api/stakeholders`, {
method: 'POST',
Expand All @@ -82,7 +83,7 @@ const onCreate = async (data: Stakeholder) => {
}
}).catch((e) => $eventBus.$emit('page-error', e))
refresh()
refreshStakeholders()
}
const onUpdate = async (data: Stakeholder) => {
Expand All @@ -94,7 +95,7 @@ const onUpdate = async (data: Stakeholder) => {
}
}).catch((e) => $eventBus.$emit('page-error', e))
refresh()
refreshStakeholders()
}
const onDelete = async (id: string) => {
Expand All @@ -103,7 +104,7 @@ const onDelete = async (id: string) => {
body: { solutionId }
}).catch((e) => $eventBus.$emit('page-error', e))
refresh()
refreshStakeholders()
}
</script>

Expand All @@ -114,7 +115,7 @@ const onDelete = async (id: string) => {
groups or roles. Example: instead of "Jane Doe", use "Project Manager".
</p>

<TabView>
<TabView @tab-change="(e) => refreshStakeholders()">
<TabPanel header="Stakeholders">
<XDataTable :viewModel="{
name: 'text',
Expand Down

0 comments on commit 85768c1

Please sign in to comment.