Skip to content

Commit

Permalink
Merge pull request #12 from trechriron/trentin-fix-form-text-page-1
Browse files Browse the repository at this point in the history
Fixed form validation, updated text page.
  • Loading branch information
trechriron authored Dec 8, 2023
2 parents 7f9b7a2 + d19e71c commit 5c0b65d
Show file tree
Hide file tree
Showing 2 changed files with 70 additions and 21 deletions.
62 changes: 43 additions & 19 deletions src/App/DevFormComponent.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -73,24 +73,14 @@
padding: "5px",
},
};

const [formData, setFormData] = useState({
phase1: '',
phase2: '',
phase3: '',
phase4: '',
phase5: '',
checkbox1: false,
checkbox2: false,
checkbox3: false,
checkbox4: false,
checkbox5: false,

const checkboxLabels = {
label1: 'Use Managed RPC Service (Enterprise)',
label2: 'Use Private RPC Service',
label3: 'Use Managed Indexer (Enterprise)',
label4: 'Use Private Indexer',
label5: 'Use Fast Auth Onboarding',
});
}

const dropDownItems = [
{ value: "0", label: "Please select..." },
Expand All @@ -110,7 +100,21 @@
{ value: "250k", label: "250k calls per month" },
];

const [callValue, setCallValue] = useState("");
const [bannerMessage, setBannerMessage] = useState(<div></div>);
const [callValue, setCallValue] = useState("");
const [formSuccess, setFormSuccess] = useState(false);
const [formData, setFormData] = useState({
phase1: '',
phase2: '',
phase3: '',
phase4: '',
phase5: '',
checkbox1: false,
checkbox2: false,
checkbox3: false,
checkbox4: false,
checkbox5: false,
});

const handleChange = (e) => {
const { name, value, type, checked } = e.target;
Expand All @@ -124,11 +128,26 @@ const handleChange = (e) => {
};

const handleSubmit = (e) => {
props.submitDeveloperProfile(formData);
};
const emptyValuesArray = []
Object.entries(formData).map(([key, value]) => {
if (key.includes('phase') && value === '') {
emptyValuesArray.push(1);
};
});
if (emptyValuesArray.length > 0) {
setFormSuccess(false);
setBannerMessage(<h3 style={{fontWeight: "bold",color: "red"}}>Please select calls for all Phases!</h3>);
} else {
setFormSuccess(true);
props.submitDeveloperProfile(formData);
};

};

console.log(formData);
console.log(callValue);
console.log(formSuccess);

return (
<div>
<div style={formStyles.row}>
Expand All @@ -145,14 +164,14 @@ const handleChange = (e) => {
</div>
</div>
<div style={formStyles.columnTextRight}>
<p style={formStyles.paragraph}>The number provided = the number of active users per minute. The pulldown lists have generic thresholds you can choose to get a close idea of what your expendentitures will be at common thresholds. You can break down your estimate into 5 phases.
<p style={formStyles.paragraph}>The number provided = the number of active users per minute. The pulldown lists have generic thresholds you can choose to get a close idea of what your expendentitures will be at common thresholds. You should choose values for all 5 phases for this demo.
</p>
<p style={formStyles.paragraph}>
Please check the boxes that apply to your project. If you are unsure, leave the box unchecked.
</p>
</div>
</div>

<form onSubmit={handleSubmit}>
{/* Dropdown per phase */}
<div style={formStyles.rowFields}>
Expand Down Expand Up @@ -190,11 +209,16 @@ const handleChange = (e) => {
checked={formData[`checkbox${index + 1}`]}
onChange={handleChange}
/>
{formData[`label${index + 1}`]}
{checkboxLabels[`label${index + 1}`]}
</label>
</div>
))}
</div>

{/* Banner Alert */}
<div style={formStyles.rowFields}>
{bannerMessage}
</div>

{/* Submit Button */}
<div style={formStyles.rowFields}>
Expand Down
29 changes: 27 additions & 2 deletions src/App/DevResultText.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,37 @@ const devTextStyles = {
},
};

const basicText = (<p style={devTextStyles.body}>Please enter the following information to estimate the cost of your project...</p>);
const checkboxLabels = [
'Use Managed RPC Service (Enterprise)',
'Use Private RPC Service',
'Use Managed Indexer (Enterprise)',
'Use Private Indexer',
'Use Fast Auth Onboarding',
];

const developerProfile = props.developerProfile;

const basicText = (<p style={devTextStyles.body}>Thank you for submitting your metrics. Following is a breakdown of projected costs across phases.</p>);

const valuesText = Object.entries(developerProfile).map(([key, value]) => {
if (key.includes("phase") && value !=='') {
const phaseNumString = key.slice(-1);
const phaseString = `Phase ${phaseNumString}`;
return (<p id={key}>In {phaseString} you selected {value} calls per month.</p>);
}
if (key.includes("checkbox") && value === true) {
const checkboxNumString = key.slice(-1);
const index = parseInt(checkboxNumString) - 1;
const checkboxString = `Checkbox ${checkboxNumString}`;
return (<p id={key}>Because you selected {checkboxString} we are including costs for: {checkboxLabels[index]}.</p>);
}
});

return (
<div>
<div style={devTextStyles.body}>
{basicText}
{basicText}
{valuesText}
</div>
</div>
);

0 comments on commit 5c0b65d

Please sign in to comment.