Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 | 3x 77x 77x 1x 77x 77x 77x 1x | import { Alert, Button } from "react-bootstrap";
import { useBackend, useBackendMutation } from "main/utils/useBackend";
const objectToAxiosParams = (courseId) => ({
url: `/api/courses/hidePermissionWarning?courseId=${courseId}`,
method: "POST",
});
export function CourseWarningBanner({ courseId, orgName }) {
const { data: warnings } = useBackend(
[`/api/courses/warnings/${courseId}`],
{
method: "GET",
url: `/api/courses/warnings/${courseId}`,
},
undefined,
true,
{
placeholderData: { showOrganizationAgeWarning: false },
staleTime: "static",
},
);
const hideWarningMutation = useBackendMutation(
() => objectToAxiosParams(courseId),
{},
// Stryker disable next-line ArrayDeclaration,StringLiteral : cache key string equality is an implementation detail
[`/api/courses/warnings/${courseId}`],
);
const permission = warnings?.defaultBasePermission;
const showPermissionWarning =
permission &&
permission !== "none" &&
permission !== "null" &&
// Stryker disable next-line OptionalChaining : placeholder data ensures warnings is never null
!warnings?.hideBasePermissionWarning;
return (
<>
{warnings?.showOrganizationAgeWarning && (
<Alert variant="warning">
Warning: This GitHub Organization is less than 30 days old. You will
experience difficulties enrolling more than 50 students in a day.
</Alert>
)}
{showPermissionWarning && (
<Alert variant="warning">
Warning: the organization setting for Default Base Permission is not
the recommended value of None. This means that students in the
organization may be able to access other students' private
repos.
{orgName && (
<Alert.Link
href={`https://github.com/organizations/${orgName}/settings/member_privileges`}
target="_blank"
rel="noopener noreferrer"
>
You can change that setting here
</Alert.Link>
)}
<Button
variant="warning"
size="sm"
data-testid="CourseWarningBanner-dismiss-button"
onClick={() => hideWarningMutation.mutate()}
>
Dismiss
</Button>
</Alert>
)}
</>
);
}
|