Upload 1.10
This commit is contained in:
@@ -1,22 +1,40 @@
|
|||||||
import { useState } from "react";
|
import { useState } from "react";
|
||||||
|
const Button = (props) => {
|
||||||
|
return <button onClick={props.handleClick}>{props.text}</button>;
|
||||||
|
};
|
||||||
|
const StatisticsLine = ({ text, value }) => {
|
||||||
|
return (
|
||||||
|
<p>
|
||||||
|
{" "}
|
||||||
|
{text} {value}{" "}
|
||||||
|
</p>
|
||||||
|
);
|
||||||
|
};
|
||||||
const Statistics = (props) => {
|
const Statistics = (props) => {
|
||||||
if (props.good + props.neutral + props.bad === 0) {
|
if (props.good + props.neutral + props.bad === 0) {
|
||||||
return <p>No feedback given</p>;
|
return <p>No feedback given</p>;
|
||||||
} else {
|
} else {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<p>good {props.good}</p>
|
<StatisticsLine text="good" value={props.good} />
|
||||||
<p>neutral {props.neutral}</p>
|
<StatisticsLine text="neutral" value={props.neutral} />
|
||||||
<p>bad {props.bad}</p>
|
<StatisticsLine text="bad" value={props.bad} />
|
||||||
<p> all {props.good + props.neutral + props.bad}</p>
|
<StatisticsLine
|
||||||
<p>
|
text="all"
|
||||||
average{" "}
|
value={props.good + props.neutral + props.bad}
|
||||||
{(props.good - props.bad) / (props.good + props.neutral + props.bad)}
|
/>
|
||||||
</p>
|
<StatisticsLine
|
||||||
<p>
|
text="average"
|
||||||
positive{" "}
|
value={
|
||||||
{(props.good / (props.good + props.neutral + props.bad)) * 100} %
|
(props.good - props.bad) / (props.good + props.neutral + props.bad)
|
||||||
</p>
|
}
|
||||||
|
/>
|
||||||
|
<StatisticsLine
|
||||||
|
text="positive"
|
||||||
|
value={
|
||||||
|
(props.good / (props.good + props.neutral + props.bad)) * 100 + "%"
|
||||||
|
}
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -31,9 +49,9 @@ const App = () => {
|
|||||||
<div>
|
<div>
|
||||||
<h1>give feedback</h1>
|
<h1>give feedback</h1>
|
||||||
|
|
||||||
<button onClick={() => setGood(good + 1)}>good</button>
|
<Button handleClick={() => setGood(good + 1)} text="good" />
|
||||||
<button onClick={() => setNeutral(neutral + 1)}>neutral</button>
|
<Button handleClick={() => setNeutral(neutral + 1)} text="neutral" />
|
||||||
<button onClick={() => setBad(bad + 1)}>bad</button>
|
<Button handleClick={() => setBad(bad + 1)} text="bad" />
|
||||||
|
|
||||||
<h1>statistics</h1>
|
<h1>statistics</h1>
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user