Skip to content
This repository was archived by the owner on Sep 14, 2022. It is now read-only.

Commit 9c6115d

Browse files
committed
feat: add Messages component
1 parent 39a1937 commit 9c6115d

File tree

2 files changed

+41
-0
lines changed

2 files changed

+41
-0
lines changed

src/components/Message.tsx

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
import React from "react";
2+
import { Alert } from "react-bootstrap";
3+
import type { FC } from "react";
4+
import type { Linter } from "eslint";
5+
6+
interface Props {
7+
message: Linter.LintMessage;
8+
}
9+
10+
export const Message: FC<Props> = ({ message }) => {
11+
const { line, column, message: lintMsg, ruleId, fatal } = message;
12+
13+
return (
14+
<Alert variant={fatal ? "danger" : "primary"}>
15+
{`${line}:${column} - ${lintMsg} (${ruleId})`}
16+
</Alert>
17+
);
18+
};

src/components/Messages.tsx

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
import React from "react";
2+
import { Message } from "@/components/Message";
3+
import { Alert } from "react-bootstrap";
4+
import type { FC } from "react";
5+
import type {Linter} from "eslint";
6+
7+
interface Props {
8+
messages?: Linter.LintMessage[];
9+
}
10+
11+
export const Messages: FC<Props> = ({ messages }) => {
12+
if (messages?.length === 0) {
13+
return <Alert variant="success"> Lint Free :) </Alert>;
14+
}
15+
16+
return (
17+
<>
18+
{messages?.map((message, index) => (
19+
<Message key={index} message={message} />
20+
))}
21+
</>
22+
);
23+
};

0 commit comments

Comments
 (0)