diff --git a/src/layouts/app/pages/PetVet/index.js b/src/layouts/app/pages/PetVet/index.js index d54d54cb..87486e7e 100644 --- a/src/layouts/app/pages/PetVet/index.js +++ b/src/layouts/app/pages/PetVet/index.js @@ -1,4 +1,5 @@ import { Component } from 'pet-dex-utilities'; +import TextArea from '../../../../components/TextArea'; import Button from '../../../../components/Button'; import Radio from '../../../../components/RadioButton'; import Vaccine from '../../../../components/Vaccine'; @@ -35,11 +36,12 @@ const html = `

Cuidados especiais

-
-
+ +
+
@@ -78,19 +80,20 @@ export default function PetVetPage({ vaccines = [] } = {}) { const $footer = this.selected.get('footer'); const $specialCareRadio = this.selected.get('special-care-radio'); + const $specialCareText = this.selected.get('special-care-text'); const $neuteredRadio = this.selected.get('neutered-radio'); const $cardGroup = this.selected.get('card-group'); this.vaccine = new Vaccine({ vaccines }); this.vaccine.mount($cardGroup); - createAndMount({ + const notSpecialCare = createAndMount({ name: 'specialCare', text: 'Não', mountTo: $specialCareRadio, value: 'notSpecialCare', }); - createAndMount({ + const specialCare = createAndMount({ name: 'specialCare', text: 'Sim', mountTo: $specialCareRadio, @@ -109,6 +112,24 @@ export default function PetVetPage({ vaccines = [] } = {}) { value: 'neutered', }); + this.specialCareText = new TextArea({ + name: 'specialCareText', + placeholder: 'Escreva o cuidado especial', + maxLength: 500, + required: true, + }); + + specialCare.listen('change', () => { + this.specialCareText.mount($specialCareText); + this.specialCareText.selected + .get('textarea') + .classList.add('petvet-page__textarea'); + }); + notSpecialCare.listen('change', () => { + this.specialCareText.selected.get('textarea').value = ''; + this.specialCareText.unmount($specialCareText); + }); + this.button = new Button({ text: 'Concluir', isFullWidth: false, @@ -128,11 +149,14 @@ export default function PetVetPage({ vaccines = [] } = {}) { const emitForm = () => { const neuteredValue = document.forms[0].elements.neutered.value; const specialCareValue = document.forms[1].elements.specialCare.value; + const specialCareText = this.specialCareText.selected.get('textarea').value; if (!neuteredValue || !specialCareValue) return; + if (getBooleanValue(specialCareValue) && !specialCareText) return; form.isNeutered = getBooleanValue(neuteredValue); form.isSpecialCare = getBooleanValue(specialCareValue); + form.specialCareText = specialCareText; form.vaccines = this.vaccine.listVaccines(); this.emit('submit', form); diff --git a/src/layouts/app/pages/PetVet/index.scss b/src/layouts/app/pages/PetVet/index.scss index f0136cd4..01dc378f 100644 --- a/src/layouts/app/pages/PetVet/index.scss +++ b/src/layouts/app/pages/PetVet/index.scss @@ -62,6 +62,10 @@ align-items: center; } + &__textarea { + margin-top: 1.6rem; + } + &__card-content { width: 100%; diff --git a/src/layouts/app/pages/PetVet/index.spec.js b/src/layouts/app/pages/PetVet/index.spec.js index 751d6b32..0ca03009 100644 --- a/src/layouts/app/pages/PetVet/index.spec.js +++ b/src/layouts/app/pages/PetVet/index.spec.js @@ -96,6 +96,56 @@ describe('PetVetPage', () => { expect(trueRadio).toBeChecked(); expect(falseRadio).not.toBeChecked(); }); + + it('shows the text area when special care "yes" radio is selected', async () => { + renderPetVetPage(argsWithVaccineEmpty); + + const specialCareYesRadio = screen.getByLabelText( + 'cuidados-especiais-sim', + ); + await userEvent.click(specialCareYesRadio); + + const textArea = screen.getByPlaceholderText( + 'Escreva o cuidado especial', + ); + expect(textArea).toBeInTheDocument(); + }); + + it('hides the text area when special care "no" radio is selected', async () => { + renderPetVetPage(argsWithVaccineEmpty); + + const specialCareYesRadio = screen.getByLabelText( + 'cuidados-especiais-sim', + ); + const specialCareNoRadio = screen.getByLabelText( + 'cuidados-especiais-não', + ); + + await userEvent.click(specialCareYesRadio); + const textArea = screen.getByPlaceholderText( + 'Escreva o cuidado especial', + ); + expect(textArea).toBeInTheDocument(); + + await userEvent.click(specialCareNoRadio); + expect(textArea).not.toBeInTheDocument(); + }); + + it('allows text input in the text area', async () => { + renderPetVetPage(argsWithVaccineEmpty); + + const specialCareYesRadio = screen.getByLabelText( + 'cuidados-especiais-sim', + ); + await userEvent.click(specialCareYesRadio); + + const textArea = screen.getByPlaceholderText( + 'Escreva o cuidado especial', + ); + await userEvent.type(textArea, 'Necessita de cuidados especiais'); + + expect(textArea).toHaveValue('Necessita de cuidados especiais'); + }); }); describe('vaccine component', () => { @@ -127,10 +177,15 @@ describe('PetVetPage', () => { await userEvent.click(neuteredYesRadio); await userEvent.click(specialCareYesRadio); + const textArea = screen.getByPlaceholderText( + 'Escreva o cuidado especial', + ); + await userEvent.type(textArea, 'Necessita de cuidados especiais'); + const formExpected = { isNeutered: true, isSpecialCare: true, - specialCareText: '', + specialCareText: 'Necessita de cuidados especiais', vaccines: mockVaccines.map(mapVaccine), }; @@ -158,6 +213,26 @@ describe('PetVetPage', () => { expect(callBackEmit).not.toHaveBeenCalled(); }); + it('does not emit the form data when special care "yes" radio is selected but the text area is empty', async () => { + const petVetPage = renderPetVetPage(argsWithVaccineEmpty); + + const neuteredYesRadio = screen.getByLabelText('castrado-sim'); + const specialCareYesRadio = screen.getByLabelText( + 'cuidados-especiais-sim', + ); + + await userEvent.click(neuteredYesRadio); + await userEvent.click(specialCareYesRadio); + + const callBackEmit = vi.fn(); + petVetPage.listen('submit', callBackEmit); + + const button = screen.getByRole('button'); + await userEvent.click(button); + + expect(callBackEmit).not.toHaveBeenCalled(); + }); + it('does not emit the form data when neutered radio are not check', async () => { const petVetPage = renderPetVetPage(argsWithVaccine);