Skip to content

Commit

Permalink
Steps added to density calculator
Browse files Browse the repository at this point in the history
Steps added to density calculator in physics section.
  • Loading branch information
singhnaveen098 committed Apr 22, 2022
1 parent 517ac20 commit b905736
Show file tree
Hide file tree
Showing 3 changed files with 70 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -481,7 +481,7 @@ Surface of an object is microscopically irreguler, thats why, when any two objec
A fluid's density is defined as its mass per unit volume.`,
formula: "ρ = m/V",
process:
"In general, liquids are less dense than solids and gases are less dense than liquids. This is due to the fact that solids have densely packed particles, liquids are materials where particles can slide around one another, and gases have particles that are free to move all over the place. Density is denoted by symbol ρ (rho) and the unit of mass density is (kg/m3).",
"In general, liquids are less dense than solids and gases are less dense than liquids. This is due to the fact that solids have densely packed particles, liquids are materials where particles can slide around one another, and gases have particles that are free to move all over the place. Density is denoted by symbol ρ (rho) and the unit of mass density is (kg/m3). It is calculated by mass(m) upon volume(V).",
siunit: "kg m⁻³",
dimension: "M L⁻³",
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ function FluidCalculator() {
A fluid's density is defined as its mass per unit volume.`,
formula: "ρ = m/V",
process:
"In general, liquids are less dense than solids and gases are less dense than liquids. This is due to the fact that solids have densely packed particles, liquids are materials where particles can slide around one another, and gases have particles that are free to move all over the place. Density is denoted by symbol ρ (rho) and the unit of mass density is (kg/m3).",
"In general, liquids are less dense than solids and gases are less dense than liquids. This is due to the fact that solids have densely packed particles, liquids are materials where particles can slide around one another, and gases have particles that are free to move all over the place. Density is denoted by symbol ρ (rho) and the unit of mass density is (kg/m3). It is calculated by mass(m) upon volume(V).",
siunit: "kg m⁻³",
dimension: "M L⁻³",
},
Expand Down Expand Up @@ -88,38 +88,101 @@ function FluidCalculator() {
const [result, setResult] = useState(null);
const [mass, setMass] = useState(null);
const [vol, setVol] = useState(null);
const [showSolution, setShowSolution] = useState(false);
const [showModal, setShowModal] = useState(false);

const roundToTwo = (num) => {
return +(Math.round(num + "e+2") + "e-2");
}

const givenValues = {
mass: mass,
volume: vol,
};

const insertValues = `${mass}/${vol}`;

const handleClick = () => {
let res = mass / vol;
setResult(res);
setResult(null);
setShowSolution(false);
if (mass !== null && vol !== null) {
if(mass < 0 || vol < 0){
alert(
"Please Enter valid values for Mass and Volume."
);
}
else{
let res = mass / vol;
setShowSolution(true);
setResult(roundToTwo(res));
}
} else {
setShowModal(true);
}
};

const handleReset = () => {
setResult(null);
setMass(null);
setVol(null);
setShowSolution(false);
};

return (
<React.Fragment>
{/* <Navbar/> */}
<Modal show={showModal} class="modal-dialog modal-dialog-centered">
<Modal.Header>
Please Enter all values to get Proper answer
</Modal.Header>
<Modal.Footer>
<Button
onClick={() => setShowModal(false)}
class="btn btn-primary btn-sm"
>
Close
</Button>
</Modal.Footer>
</Modal>
<Form>
<Form.Group className="mb-3" controlId="mass">
<Form.Label> Mass (in kgs)</Form.Label>
<Form.Control
onChange={(e) => setMass(e.target.value)}
onChange={(e) => {
setMass(e.target.value);
setResult(null);
setShowSolution(false);
}}
type="number"
placeholder="Enter mass of the object"
value={mass === null ? "" : mass}
/>
</Form.Group>
<Form.Group className="mb-3" controlId="volume">
<Form.Label> Volume (in m³)</Form.Label>
<Form.Control
onChange={(e) => setVol(e.target.value)}
onChange={(e) => {
setVol(e.target.value)
setResult(null);
setShowSolution(false);
}}
type="number"
placeholder="Enter volume of the object"
value={vol === null ? "" : vol}
/>
</Form.Group>
{showSolution ? (
<Form.Group className="mb-3" controlId="acceleration">
<Solution
givenValues={givenValues}
formula="m/V"
toFind="Density ρ"
insertValues={insertValues}
result={result}
/>
</Form.Group>
) : null}

<Form.Group className="mb-3" controlId="density">
<Form.Label>Density</Form.Label>
<Form.Control
Expand Down
1 change: 1 addition & 0 deletions funwithphysics/src/Components/Solution/allSIUnits.js
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ export const SI = {
'Final Height (h₂)':"m",
k:"N/m",
Density:"kg m⁻³",
"Density ρ": "kg m⁻³",
Height1:"m",
Height2:"m",
Pressure1:"Pascal",
Expand Down

0 comments on commit b905736

Please sign in to comment.