Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
76 changes: 76 additions & 0 deletions maintainers.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
# maintainers.yaml
#
# @kata-containers/arch-s390x: BbolroC
# @kata-containers/arch-ppc64le: Amulyam24?
# @kata-containers/cri-o: ?
# @kata-containers/dragonball: bergwolf
# @kata-containers/rust: pmores, lifupan
# @kata-containers/amd: AdithyaKrishnan, arvindskumar99


## slack: member id, display name, or link to profile?

mappings:
# @kata-containers/arch-s390x: BbolroC
- regex: ".*s390x.*"
group: "Arch-s390x"
owners:
- fullname: "Hyounggyu Choi"
email: "[email protected]"
slackurl: "https://katacontainers.slack.com/team/U0369UMM69M"
slack: "Hyounggyu Choi"
github: "BbolroC"

# @kata-containers/arch-ppc64le: Amulyam24?
- regex: ".*ppc64le.*"
group: "Arch-ppc64le"
owners:
- fullname: "Amulya Meka"
email: "[email protected]"
slackurl: "https://katacontainers.slack.com/team/UV7RP34GK"
slack: "Amulyam24"
github: "Amulyam24"


# @kata-containers/dragonball: bergwolf
- regex: ".*dragonball.*"
group: "Dragonball"
owners:
- fullname: "Peng Tao"
email: "http://bergwolf.github.io/"
slackurl: "https://katacontainers.slack.com/team/U8709NBSM"
slack: "bergwolf"
github: "bergwolf"


# @kata-containers/rust: pmores, lifupan
- regex: ".*runtime-rs.*"
group: "Rust"
owners:
- fullname: "Pavel Mores"
email: "[email protected]"
slackurl: "https://katacontainers.slack.com/team/U03CCR6KGBC"
slack: "Pavel Mores"
github: "pmores"

- fullname: "Fupan Li"
email: "[email protected]"
slackurl: "https://katacontainers.slack.com/team/U059Y60DZPW"
slack: "fupan li"
github: "lifupan"

# @kata-containers/amd: AdithyaKrishnan, arvindskumar99
- regex: ".*(qemu-(sev(-snp)?|snp(-experimental)?)|ovmf(-sev)?).*"
group: "AMD"
owners:
- fullname: "Adithya Krishnan Kannan"
email: "[email protected]"
slackurl: "https://cloud-native.slack.com/team/U05TX2URB16"
slack: "Adi"
github: "AdithyaKrishnan"

- fullname: "Arvind Kumar"
email: "[email protected]"
slackurl: "https://cloud-native.slack.com/team/U06HXU0312P"
slack: "Arvind Kumar"
github: "arvindskumar99"
6 changes: 6 additions & 0 deletions next.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@ module.exports = {
unoptimized: true,
},
webpack: (config, { dev }) => {

config.module.rules.push({
test: /\.yml$/,
use: 'yaml-loader',
});

if (dev) {
config.devtool = false;
}
Expand Down
68 changes: 66 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@
"primereact": "^10.8.3",
"react": "^18.3.1",
"react-dom": "^18.3.1",
"react-transition-group": "^4.4.5"
"react-transition-group": "^4.4.5",
"yaml-loader": "^0.8.1"
},
"devDependencies": {
"autoprefixer": "^10.4.20",
Expand Down
123 changes: 115 additions & 8 deletions pages/index.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
import { useEffect, useState } from "react";
import React, { useEffect, useState, useRef } from "react";
import { DataTable } from "primereact/datatable";
import { Column } from "primereact/column";
import Head from "next/head";
import { weatherTemplate, getWeatherIndex } from "../components/weatherTemplate";
import { OverlayPanel } from 'primereact/overlaypanel';
import MaintainerMapping from "../maintainers.yml";


export default function Home() {
Expand Down Expand Up @@ -76,9 +78,11 @@ export default function Home() {
);
};

const maintainRefs = useRef([]);

const rowExpansionTemplate = (data) => {
const job = jobs.find((job) => job.name === data.name);

// Prepare run data
const runs = [];
for (let i = 0; i < job.runs; i++) {
Expand All @@ -88,14 +92,30 @@ export default function Home() {
url: job.urls[i],
});
}

// Find maintainers for the given job
const maintainerData = MaintainerMapping.mappings
.filter(({ regex }) => new RegExp(regex).test(job.name))
.flatMap((match) =>
match.owners.map((owner) => ({
...owner,
group: match.group,
}))
);

// Group maintainers by their group name
const groupedMaintainers = maintainerData.reduce((acc, owner) => {
if (!acc[owner.group]) {
acc[owner.group] = [];
}
acc[owner.group].push(owner);
return acc;
}, {});

return (
<div
key={`${job.name}-runs`}
className="p-3 bg-gray-100"
style={{ marginLeft: "4.5rem", marginTop: "-2.0rem" }}
>
<div>
<div key={`${job.name}-runs`} className="p-3 bg-gray-100">
{/* Display last 10 runs */}
<div className="flex flex-wrap gap-4">
{runs.length > 0 ? (
runs.map((run) => {
const emoji =
Expand All @@ -117,6 +137,93 @@ export default function Home() {
<div>No Nightly Runs associated with this job</div>
)}
</div>

{/* Display Maintainers, if there's any */}
<div className="mt-4 p-2 bg-gray-300 w-full">
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a really long section. Any way to break this up?

{Object.keys(groupedMaintainers).length > 0 ? (
<div className="grid grid-cols-2 p-2 gap-6">
{Object.entries(groupedMaintainers).map(
([group, owners], groupIndex) => (
<div key={groupIndex} className="flex flex-col max-w-xs">
{/* List the group name */}
<strong className="pl-2">{group}:</strong>
<div>
{/* List all maintainers for the group */}
{owners.map((owner, ownerIndex) => {
const badgeMaintain = `maintain-${owner.github}`;
maintainRefs.current[badgeMaintain] =
maintainRefs.current[badgeMaintain] || React.createRef();

return (
// Create the OverlayPanel with contact information.
<span key={ownerIndex}>
<span
onMouseEnter={(e) =>
maintainRefs.current[badgeMaintain].current.toggle(e)
}
>
<a
href={`https://github.com/${owner.github}`}
target="_blank"
rel="noopener noreferrer"
className="text-blue-500 underline pl-2 whitespace-nowrap"
>
{owner.fullname}
</a>
{ownerIndex < owners.length - 1 && ", "}
</span>
<OverlayPanel
ref={maintainRefs.current[badgeMaintain]}
dismissable
onMouseLeave={(e) =>
maintainRefs.current[badgeMaintain].current.toggle(e)
}
>
<ul className="bg-white border rounded shadow-lg p-2">
<li className="p-2 hover:bg-gray-200">
<span className="font-bold mr-4">Email:</span>{" "}
{owner.email}
</li>
<a
href={`https://github.com/${owner.github}`}
target="_blank"
rel="noopener noreferrer"
>
<li className="p-2 hover:bg-gray-200 flex justify-between">
<span className="font-bold mr-4">
GitHub:
</span>
<span className="text-right">
{owner.github}
</span>
</li>
</a>
<a
href={`${owner.slackurl}`}
target="_blank"
rel="noopener noreferrer"
>
<li className="p-2 hover:bg-gray-200 flex justify-between">
<span className="font-bold mr-4">Slack:</span>
<span className="text-right">
@{owner.slack}
</span>
</li>
</a>
</ul>
</OverlayPanel>
</span>
);
})}
</div>
</div>
)
)}
</div>
) : (
<div>No Maintainer Information Available</div>
)}
</div>
</div>
);
};
Expand Down
Loading