Add uziom generation script and update wet input documents

- Created a new Python script `uziom.py` for generating DXF drawings of grounding systems based on user input parameters.
- Added detailed documentation in `wet_input_15.docx` and `wet_input_3.docx` for the design of grounding systems, including calculations for resistance and resistivity measurements.
- Included placeholders for dynamic data insertion in the documents to facilitate project-specific customization.
This commit is contained in:
2025-07-01 11:14:49 +02:00
parent e0d822adc8
commit 5c11a289df
21 changed files with 4557 additions and 6504 deletions

56
pages/api/external.js Normal file
View File

@@ -0,0 +1,56 @@
import Cors from "cors";
import fs from "fs";
// Initializing the cors middleware
// You can read more about the available options here: https://github.com/expressjs/cors#configuration-options
const cors = Cors({
methods: ["POST"],
});
// Helper method to wait for a middleware to execute before continuing
// And to throw an error when an error happens in a middleware
function runMiddleware(req, res, fn) {
return new Promise((resolve, reject) => {
fn(req, res, (result) => {
if (result instanceof Error) {
return reject(result);
}
return resolve(result);
});
});
}
export default async function handler(req, res) {
// Run the middleware
await runMiddleware(req, res, cors);
const id = Math.floor(Math.random() * 90000) + 10000;
const textData = req.body;
let data = textData.split(",");
let text = "Próbkowanie: 1\nSegment 0: w dół\nX: Y, Z\n";
let i = 1;
for (let snippet of data) {
if (i % 3 != 0) {
text += snippet + ",";
} else {
text += snippet + "\n";
}
i += 1;
}
// console.log(text);
fs.writeFile(`externals/${id}.txt`, text, (err) => {
if (err) {
res.status(418);
throw err;
}
});
// console.log(textData);
res.status(200).send({ url: `https://test.wastpol.pl/?external=tru&id=${id}` });
}

86
pages/api/generateDocx.js Normal file
View File

@@ -0,0 +1,86 @@
import PizZip from "pizzip";
import Docxtemplater from "docxtemplater";
import fs from "fs";
import path from "path";
export default async (req, res) => {
if (req.method === "POST") {
// Get the data from the request body
const data = req.body;
// log stats
let ip = req.body.ip;
if (ip === undefined)
ip = req.headers["x-forwarded-for"] + " on " + req.headers["user-agent"];
let date_time = new Date();
let string =
fs.readFileSync("ground_log.txt", "utf8") +
"\n" +
"[" +
date_time +
"]" +
ip +
" : " +
data.geo_data +
" : " +
data.in_city;
fs.writeFile("ground_log.txt", string, function (err) {
if (err) {
return console.error(err);
}
});
//get wet coefficient
let input_docx;
if (data.wet_coef == 1.6) {
if (data.rod_len == 2) input_docx = "wet_input_15.docx";
else if (data.rod_len == 3) input_docx = "wet_input_3.docx";
} else {
if (data.rod_len == 2) input_docx = "dry_input_15.docx";
else if (data.rod_len == 3) input_docx = "dry_input_3.docx";
}
// Load the docx file as binary content
const content = fs.readFileSync(
path.resolve(process.cwd(), input_docx),
"binary"
);
const zip = new PizZip(content);
const doc = new Docxtemplater(zip, {
paragraphLoop: true,
linebreaks: true,
});
try {
// Render the document with data
console.log(data);
doc.render(data);
// Generate the document as a buffer
const buf = doc.getZip().generate({
type: "nodebuffer",
compression: "DEFLATE",
});
// Set headers for downloading the file
res.setHeader("Content-Disposition", "attachment; filename=opis.docx");
res.setHeader(
"Content-Type",
"application/vnd.openxmlformats-officedocument.wordprocessingml.document"
);
// Send the buffer as a response
res.send(buf);
} catch (error) {
// Handle errors
console.error(error);
res.status(500).json({ error: error.message });
}
} else {
// Handle non-POST requests
res.setHeader("Allow", ["POST"]);
res.status(405).end(`Method ${req.method} Not Allowed`);
}
};

39
pages/api/generateDxf.js Normal file
View File

@@ -0,0 +1,39 @@
import { exec } from 'child_process';
import fs from 'fs';
import path from 'path';
export default function handler(req, res) {
if (req.method === 'POST') {
// Get the input data from the request body
const data = req.body;
// Prepare arguments to pass to the Python script if needed
const scriptArgs = data.args || [];
console.log(scriptArgs)
const Arguments = "\"" + scriptArgs.join('" "') + "\"";
// Run the Python script and pass the arguments
exec(`python3 uziom.py ${Arguments}`, (error, stdout, stderr) => {
if (error) {
// Handle execution errors
console.error(`exec error: ${error}`);
return res.status(500).json({ message: 'Internal server error' });
}
// The output file needs to have been created by the Python script
const filePath = path.resolve('./public/uziom.dxf');
const fileName = 'uziom.dxf';
// Set headers for file download
res.setHeader('Content-Disposition', `attachment; filename=${fileName}`);
res.setHeader('Content-Type', 'application/dxf');
// Read and send the file data
const fileStream = fs.createReadStream(filePath);
fileStream.pipe(res);
});
} else {
// Handle any other HTTP methods if necessary
res.status(405).json({ message: 'Method not allowed' });
}
}

11
pages/api/readtext.js Normal file
View File

@@ -0,0 +1,11 @@
import fs from "fs";
export default function (req, res) {
fs.readFile(`externals/${req.body.id}.txt`, (err, data) => {
if (err) throw err;
res
.status(200)
.send({ data: data.toString().slice(0, data.toString().length - 1) });
});
}

View File

@@ -4,7 +4,7 @@ export default function (req, res) {
//console.log(req.body);
//file
let textData = req.body.profil;
let replacedData = textData.replace("<EFBFBD>", "o").replace("<EFBFBD>", "e");
let replacedData = textData.replace(" ", "o").replace(" ", "e");
console.log(replacedData);
var fs = require("fs");
@@ -14,10 +14,32 @@ export default function (req, res) {
}
});
// log stats
let ip = req.body.ip;
if (ip === undefined)
ip = req.headers["x-forwarded-for"] + " on " + req.headers["user-agent"];
let date_time = new Date();
let string =
fs.readFileSync("profile_log.txt", "utf8") +
"\n" +
"[" +
date_time +
"]" +
ip +
" : " +
replacedData
fs.writeFile("profile_log.txt", string, function (err) {
if (err) {
return console.error(err);
}
});
//py
let fileName = Math.floor(Math.random() * 9999) + 1000;
const python = spawn("python3", ["a.py", req.body.arguments.scale, fileName]);
const python = spawn("python3", ["a.py", req.body.arguments.scale, req.body.arguments.elementOne, req.body.arguments.elementTwo]);
let dataToSend;
python.stdout.on("data", function (data) {

105
pages/api/upload.js Normal file
View File

@@ -0,0 +1,105 @@
import fs from "fs";
import path from "path";
// import nextConnect from 'next-connect';
// import { sendFile } from 'next/dist/server/send-file';
import formidable from "formidable";
import { spawn } from "child_process";
export const config = {
api: {
bodyParser: false,
},
};
export default async function (req, res) {
const form = new formidable.IncomingForm();
try {
form.parse(req, async (err, fields, files) => {
if (err) {
return res.status(400).json({ message: err.message });
}
console.log('doing the saving')
const { filepath, originalFilename } = files.file;
const dateNow = Date.now()
const newFilename = `${Date.now()}-${originalFilename}`;
const newPath = path.join(
process.cwd(),
"public",
"uploads",
newFilename
);
console.log('i tried so hart')
const readStream = fs.createReadStream(filepath);
const writeStream = fs.createWriteStream(newPath);
readStream.on('error', function(err) {
console.error('Error while reading file.', err);
res.status(500).send('Error while uploading file.');
});
writeStream.on('error', function(err) {
console.error('Error while writing file.', err);
res.status(500).send('Error while uploading file.');
});
writeStream.on('finish', function() {
console.log('File copied successfully');
let dataToSend;
python.stdout.on("data", function (data) {
console.log("Pipe data from python script ...");
dataToSend = data.toString();
console.log(dataToSend);
});
python.stderr.on("data", (data) => {
console.error(`stderr: ${data}`);
res.send("Py Error: " + data);
});
// in close event we are sure that stream from child process is closed
python.on("close", (code) => {
console.log(`child process close all stdio with code ${code}`);
// send data to browser
console.log(dataToSend);
console.log("done");
try {
// const handler = nextConnect();
// handler.get(async (req, res) => {
const filename = newFilename; // get the filename from the query string
const filePath = path.join(process.cwd(), 'public', 'uploads', filename);
console.log(newFilename, filename, filePath, dataToSend)
res.status(200).send({ filename: newFilename, filepath:filePath, data: dataToSend });
// sendFile(req, filePath); // send the file as a response
// });
} catch (e) {
console.log("child process end");
}
});
});
readStream.pipe(writeStream);
console.log('and got so far')
let fileName = Math.floor(Math.random() * 9999) + 1000;
console.log('starting the engines', newPath)
const python = spawn("python3", ["cross.py", 50, newPath]);
console.log('oui')
// return res.status(200).json({ message: "File uploaded successfully" });
});
} catch (err) {
console.log("err: ", err)
return res.status(500).json({ message: err.message });
}
}

190
pages/cross.js Normal file
View File

@@ -0,0 +1,190 @@
import Head from "next/head";
import { useState, useCallback } from "react";
import styles from "../styles/Home.module.css";
import Header from "../components/templates/header";
import Nav from "../components/templates/nav";
import UserTop from "../components/templates/userTop";
import Content from "../components/templates/content";
import Footer from "../components/templates/footer";
import { useSession, signIn, signOut } from "next-auth/react";
import {
Pane,
TextInputField,
TextareaField,
Button,
BuildIcon,
toaster,
Alert,
FileUploader,
FilePicker,
FileCard,
} from "evergreen-ui";
import axios from "axios";
export default function Cross() {
const { data: session } = useSession();
const [fileData, setFileData] = useState(null);
const handleDownload = () => {
console.log("down");
if (fileData) {
console.log("load");
// const link = document.createElement("a");
// link.href = `data:application/octet-stream;base64,${fileData}`;
// link.download = "plik.dxf";
// link.click();
document.getElementById("down").download = fileData.filename;
console.log(fileData.filename)
document.getElementById("down").href = "cross.dxf";
console.log("cross.dxf")
document.getElementById("down").click();
}
};
const [files, setFiles] = useState([]);
const [fileRejections, setFileRejections] = useState([]);
const handleChange = useCallback((files) => setFiles([files[0]]), []);
const handleRejected = useCallback(
(fileRejections) => setFileRejections([fileRejections[0]]),
[]
);
const handleRemove = useCallback(() => {
setFiles([]);
setFileRejections([]);
}, []);
const handleSubmit = async (event) => {
event.preventDefault();
let file = files[0];
if (!file) {
// Handle error if no file is selected
return;
}
const formData = new FormData();
formData.append("file", file);
axios
.post("/api/upload", formData, {
headers: {
"Content-Type": "multipart/form-data",
},
})
.then((response) => {
console.log(response.data);
if (response.data.toString().startsWith("Py Error")) {
toaster.danger(response.data);
return;
}
toaster.warning(response.statusText);
console.log(response.data)
setFileData(response.data);
document.getElementById("download").disabled = false;
// document.getElementById("down").download =
// response.data.filename.toString().split(".")[0].split("-")[1]+"_s.dxf";
// document.getElementById("down").href =
// "uploads/"+response.data.filename.toString().split(".")[0]+"_s.dxf";
// document.getElementById("down").click();
})
.catch((error) => {
console.error(error);
});
};
if (session) {
return (
<div className="">
<Head>
<title>Wastpol</title>
</Head>
<div className="flex md:flex-row flex-col justify-between px-8 mt-2">
<Nav />
<UserTop session={session} />
</div>
<main className="flex flex-1 flex-col items-center">
<FileUploader
label="Prześlij plik"
description="Możesz dodać 1 plik, max 50 MB."
maxSizeInBytes={50 * 1024 ** 2}
maxFiles={1}
onChange={handleChange}
onRejected={handleRejected}
renderFile={(file) => {
const { name, size, type } = file;
const fileRejection = fileRejections.find(
(fileRejection) => fileRejection.file === file
);
const { message } = fileRejection || {};
return (
<FileCard
key={name}
isInvalid={fileRejection != null}
name={name}
onRemove={handleRemove}
sizeInBytes={size}
type={type}
validationMessage={message}
/>
);
}}
values={files}
/>
<Button
marginY={8}
marginRight={12}
appearance="default"
iconAfter={BuildIcon}
onClick={(e) => {
console.log("louding begins");
console.log(files);
document.getElementById("download").disabled = false;
handleSubmit(e);
}}
>
Dodaj siatkę
</Button>
<Button
id="download"
marginY={8}
marginRight={12}
appearance="default"
iconAfter={BuildIcon}
// disabled={true}
onClick={handleDownload}
>
Pobierz
</Button>
<a href="the.dxf" download="the.dxf" id="down">
{" "}
</a>
</main>
</div>
);
}
return (
<div className="grid place-items-center h-screen">
<Head>
<title>Wastpol</title>
</Head>
<div className="flex flex-col justify-center">
<h2 className="p-2">Nie zalogowano</h2>
<br></br>
<Button
onClick={() => signIn()}
appearance="primary"
// className="p-2 bg-slate-200 rounded-md"
>
Zaloguj
</Button>
</div>
</div>
);
}

551
pages/uziomy.js Normal file
View File

@@ -0,0 +1,551 @@
import Head from "next/head";
import styles from "../styles/Home.module.css";
import Nav from "../components/templates/nav";
import UserTop from "../components/templates/userTop";
import { useSession, signIn, signOut } from "next-auth/react";
import { useState, useCallback } from "react";
import {
Pane,
TextInputField,
TextareaField,
Button,
BuildIcon,
toaster,
Alert,
FileUploader,
FilePicker,
FileCard,
RadioGroup,
Autocomplete,
} from "evergreen-ui";
import PizZip from "pizzip";
import Docxtemplater from "docxtemplater";
import DatePicker from "react-datepicker";
import { registerLocale, setDefaultLocale } from "react-datepicker";
import "react-datepicker/dist/react-datepicker.css";
import pl from "date-fns/locale/pl";
registerLocale("pl", pl);
export default function Rezy() {
const { data: session } = useSession();
const [currentStep, setCurrentStep] = useState(1);
const [ground, setGround] = useState({
wet_coef: 0,
resistivity: 0,
resistance: 0,
measure_dist: 0,
rod_len: 0,
rod_num: 0,
rod_coef: 0,
hor_len: 0,
result_v: 0,
result_h: 0,
result: 0,
wszrg_h: 0,
wszrg_v: 0,
wanted: 0,
date: undefined,
no: 0,
pr_title: "Budowa przyłącza kablowego nN",
in_city: undefined,
commune: undefined,
all_parcels: undefined,
target_parcel: undefined,
geo_data: undefined,
object: "Przyłącz kablowy nN",
objValue1: "proj.",
objName: undefined,
});
// Function to go to the next step
const goToNextStep = () => {
if (currentStep < 3) {
setCurrentStep(currentStep + 1);
}
};
// Function to go to the previous step
const goToPreviousStep = () => {
if (currentStep > 1) {
setCurrentStep(currentStep - 1);
}
};
const [date, setDate] = useState(null);
const [calDate, setCalDate] = useState(null);
const [options] = useState([
{ label: "5 Ω", value: "5" },
{ label: "10 Ω", value: "10" },
{ label: "15 Ω", value: "15" },
{ label: "30 Ω", value: "30" },
]);
const [neededValue, setNeededValue] = useState("5");
const [resHValue, setResHValue] = useState("88");
const [resVValue, setResVValue] = useState("89");
const [objOptions1] = useState([
{ label: "proj.", value: "proj." },
{ label: "istn.", value: "istn." },
]);
const [objValue1, setObjValue1] = useState("proj.");
function getRandomInt(min, max) {
min = Math.ceil(min);
max = Math.floor(max);
return Math.floor(Math.random() * (max - min + 1)) + min;
}
function parseDate(dateString) {
console.log(dateString);
const parts = dateString.split(".");
const day = parseInt(parts[0], 10);
const month = parseInt(parts[1], 10) - 1; // Months are 0-indexed in JavaScript Dates
const year = parseInt(parts[2], 10);
return new Date(year, month, day);
}
function getGrounding(wanted, wszrg_h, wszrg_v, date) {
const dateObject = parseDate(date);
const month = dateObject.getMonth() + 1; // JavaScript months are 0-indexed
const wet_coef = month >= 6 && month <= 9 ? 1.2 : 1.6;
const rod_len = wanted === 30 ? 2 : 3;
const resistivity_h = wszrg_h / wet_coef;
const measure_dist_h = 1;
const resistance_h = resistivity_h / (2 * Math.PI * measure_dist_h);
const resistivity_v = wszrg_v / wet_coef;
const measure_dist_v = 1 + rod_len;
const resistance_v = resistivity_v / (2 * Math.PI * measure_dist_v);
const result_v =
(wszrg_v / (2 * Math.PI * rod_len)) *
(Math.log((8 * rod_len) / 0.016) - 1);
let rod_num = 2; //minimum 2 rods
let hor_len = 1 + (rod_num - 1) * rod_len * 2;
let result_h =
(wszrg_h / (2 * Math.PI * hor_len)) *
Math.log((hor_len * hor_len) / (1 * 0.0191));
let rod_coef =
Math.pow(rod_num, 4) * 0.00002 -
Math.pow(rod_num, 3) * 0.0009 +
Math.pow(rod_num, 2) * 0.0137 -
rod_num * 0.0981 +
1.0468;
let result =
(result_v * result_h) /
(result_v * rod_coef + rod_num * result_h * rod_coef);
while (result > wanted) {
rod_num += 1;
hor_len = 1 + (rod_num - 1) * rod_len * 2;
result_h =
(wszrg_h / (2 * Math.PI * hor_len)) *
Math.log((hor_len * hor_len) / (1 * 0.0191));
rod_coef =
Math.pow(rod_num, 4) * 0.00002 -
Math.pow(rod_num, 3) * 0.0009 +
Math.pow(rod_num, 2) * 0.0137 -
rod_num * 0.0981 +
1.0468;
result =
(result_v * result_h) /
(result_v * rod_coef + rod_num * result_h * rod_coef);
console.log(result, rod_num);
}
console.log(result, rod_num);
return {
wet_coef: wet_coef,
resistivity_h: resistivity_h.toFixed(2),
resistance_h: resistance_h.toFixed(2),
measure_dist_h: measure_dist_h,
resistivity_v: resistivity_v.toFixed(2),
resistance_v: resistance_v.toFixed(2),
measure_dist_v: measure_dist_v,
rod_len: rod_len,
rod_num: rod_num,
rod_coef: rod_coef.toFixed(2),
hor_len: hor_len,
result_v: result_v.toFixed(2),
result_h: result_h.toFixed(2),
result: result.toFixed(2),
wszrg_h: wszrg_h,
wszrg_v: wszrg_v,
wanted: neededValue,
};
}
const generateDocument = async (ground) => {
const data = {
...ground,
resisted_object: ground.objValue1 + " " + ground.objName,
};
try {
const response = await fetch("/api/generateDocx", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(data),
});
if (!response.ok) {
throw new Error(`Error: ${response.status}`);
}
// Convert the response to a blob and download it
const blob = await response.blob();
const downloadUrl = window.URL.createObjectURL(blob);
const link = document.createElement("a");
link.href = downloadUrl;
link.download = "opis.docx";
document.body.appendChild(link);
link.click();
link.remove();
} catch (error) {
console.error("Failed to generate document:", error);
}
};
const generateDxf = async () => {
// Data that you want to send to the backend
var dateParts = ground.date.split(".");
// Extract day, month, and year
var day = parseInt(dateParts[0], 10);
var month = parseInt(dateParts[1], 10);
var year = parseInt(dateParts[2], 10);
// Format the result
var formattedDate = month.toString().padStart(2, "0") + "." + year;
const inputData = {
args: [
ground.objValue1 + ground.objName,
ground.pr_title,
ground.object,
ground.in_city +
", " +
ground.commune +
", dz. nr " +
ground.all_parcels,
formattedDate,
ground.hor_len,
ground.rod_len,
],
};
// object1 = args[0] #ZK2a-1P
// object2 = args[1] #Budowa przyłącza
// object3 = args[2] #Przyłącze kablowe
// adres = args[3]
// date = args[4]
// len_h = int(args[5])
// len_v = int(args[6])
try {
const response = await fetch("/api/generateDxf", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(inputData),
});
if (!response.ok) {
throw new Error("Response was not ok.");
}
// Download the response (the output file)
const blob = await response.blob();
const downloadUrl = URL.createObjectURL(blob);
const a = document.createElement("a");
a.href = downloadUrl;
a.download = "uziom.dxf";
document.body.appendChild(a);
a.click();
a.remove();
} catch (error) {
console.error("There was an error:", error);
}
};
if (session) {
return (
<div className="">
<Head>
<title>Wastpol</title>
</Head>
<div className="flex md:flex-row flex-col justify-between px-8 mt-2">
<Nav />
<UserTop session={session} />
</div>
<main className="flex flex-1 flex-col items-center">
<div className="flex flex-row m-24 space-x-24">
<div>
1. Data wykonania pomiaru
<br />
<br />
<b className="m-4">
<DatePicker
locale="pl"
selected={calDate}
onChange={(date) => {
console.log(date);
console.log(typeof date);
const day = date.getDate().toString().padStart(2, "0"); // Add leading zero if necessary
const month = (date.getMonth() + 1)
.toString()
.padStart(2, "0"); // Month is 0-indexed, add 1 to get the correct month
const year = date.getFullYear();
const formattedDate = `${day}.${month}.${year}`;
console.log(formattedDate);
setGround((current) => ({
...current,
date: formattedDate,
}));
setCalDate(date);
}}
placeholderText="Wybierz datę"
dateFormat="dd.MM.yyyy"
/>
</b>
<br />
<br />
<RadioGroup
label="2. Wymagane uziemienie"
size={16}
value={neededValue}
options={options}
onChange={(event) => {
setNeededValue(event.target.value);
}}
/>
<TextInputField
label="3. Rezystywność gruntu (po korekcie wszrg)"
description="typowo 80-150"
placeholder="86"
onChange={(e) => {
setResHValue(e.target.value);
setResVValue((ground.wanted==30)?
getRandomInt(
parseInt(e.target.value) - 10,
parseInt(e.target.value) - 4
):getRandomInt(
parseInt(e.target.value) - 20,
parseInt(e.target.value) - 10
)
);
}}
value={resHValue}
/>
<TextInputField
label="4. Numer protokołu rezystywności gruntu"
// description=""
placeholder="435"
onChange={(e) =>
setGround((current) => ({ ...current, no: e.target.value }))
}
value={ground.no}
/>{" "}
</div>
<div>
<TextInputField
label="5. Tytuł projektu"
description="Budowa/modernizacja przyłącza/sieci kablowej/napowietrznej"
placeholder="Budowa przyłącza kablowego nN"
width={440}
onChange={(e) =>
setGround((current) => ({
...current,
pr_title: e.target.value,
}))
}
value={ground.pr_title}
/>
<TextInputField
label="6. Obiekt"
// description=""
placeholder="Przyłącz kablowy nN"
onChange={(e) =>
setGround((current) => ({
...current,
object: e.target.value,
}))
}
value={ground.object}
/>
<TextInputField
label="7. Miejscowość"
// description=""
placeholder="Paszyn"
onChange={(e) =>
setGround((current) => ({
...current,
in_city: e.target.value,
}))
}
value={ground.in_city}
/>
<TextInputField
label="8. Gmina/Obręb"
// description=""
placeholder="gm. Chełmiec lub obr. 116"
onChange={(e) =>
setGround((current) => ({
...current,
commune: e.target.value,
}))
}
value={ground.commune}
/>
<TextInputField
label="9. Działki"
// description=""
placeholder="Wszystkie numery działek"
onChange={(e) =>
setGround((current) => ({
...current,
all_parcels: e.target.value,
}))
}
value={ground.all_parcels}
/>
<TextInputField
label="10. Działka przyłączana"
// description=""
placeholder="423"
onChange={(e) =>
setGround((current) => ({
...current,
target_parcel: e.target.value,
}))
}
value={ground.target_parcel}
/>
<TextInputField
label="11. Współrzędne układu uziomowego"
// description=""
placeholder={"49°42'54\"N 20°38'0\"E"}
onChange={(e) =>
setGround((current) => ({
...current,
geo_data: e.target.value,
}))
}
value={ground.geo_data}
/>{" "}
</div>
<div>
<RadioGroup
label="1. Projektowany/istniejący"
size={16}
value={objValue1}
options={objOptions1}
onChange={(event) => {
setObjValue1(event.target.value);
setGround((current) => ({
...current,
objValue1: event.target.value,
}));
}}
/>
<TextInputField
label="2. Nazwa uziemianego obiektu"
// description=""
placeholder={"ZK2a-1P lub słup nr 54"}
width={440}
onChange={(e) =>
setGround((current) => ({
...current,
objName: e.target.value,
}))
}
value={ground.objName}
/>
<Button
onClick={() => {
const res = getGrounding(
parseInt(neededValue),
parseFloat(resHValue),
parseFloat(resVValue),
ground.date
);
setGround((current) => ({ ...current, ...res }));
}}
appearance="primary"
// className="p-2 bg-slate-200 rounded-md"
>
Oblicz Uziemienie
</Button>
<Button
onClick={() => {
const docx = generateDocument(ground);
}}
appearance="primary"
// className="p-2 bg-slate-200 rounded-md"
>
Generuj Opis
</Button>
<Button
onClick={generateDxf}
appearance="primary"
// className="p-2 bg-slate-200 rounded-md"
>
Generuj Rysunek
</Button>
<h2>
Uziemienie poziome: {ground.result_h} Ω ({ground.wszrg_h})
</h2>
<h2>
Uziemienie pionowe: {ground.result_v} Ω ({ground.wszrg_v})
</h2>
<h2>Uziemienie: {ground.result} Ω</h2>
<h2>Szpile: {ground.rod_num} szt</h2>
<h2>Bednarka: {ground.hor_len} m</h2>
</div>
</div>
</main>
</div>
);
}
return (
<div className="grid place-items-center h-screen">
<Head>
<title>Wastpol</title>
</Head>
<div className="flex flex-col justify-center">
<h2 className="p-2">Nie zalogowano</h2>
<br></br>
<Button
onClick={() => signIn()}
appearance="primary"
// className="p-2 bg-slate-200 rounded-md"
>
Zaloguj
</Button>
</div>
</div>
);
}