{"version":3,"sources":["webpack:///src/app/modules/document-v2/pages/modal-select-layout/modal-select-layout.component.ts","webpack:///src/app/modules/document-v2/pages/modal-select-layout/modal-select-layout.component.html","webpack:///src/app/modules/document-v2/pages/modal-select-layout/modal-select-layout.component.scss","webpack:///src/app/modules/document-v2/pages/model-list-favorite-document/model-list-favorite-document.component.ts","webpack:///src/app/modules/document-v2/pages/model-list-favorite-document/model-list-favorite-document.component.html","webpack:///src/app/modules/document-v2/pages/model-list-favorite-document/model-list-favorite-document.component.scss","webpack:///src/app/modules/document-v2/pages/attestation/attestation.service.ts","webpack:///src/app/modules/document-v2/pages/model-add-favorite-document/model-add-favorite-document.component.ts","webpack:///src/app/modules/document-v2/pages/model-add-favorite-document/model-add-favorite-document.component.html","webpack:///src/app/modules/document-v2/pages/model-add-favorite-document/model-add-favorite-document.component.scss","webpack:///src/app/modules/document-v2/pages/orientation/orientation.service.ts","webpack:///src/app/modules/document-v2/document.component.ts","webpack:///src/app/modules/document-v2/document.component.html","webpack:///src/app/modules/document-v2/document.component.scss","webpack:///src/app/modules/document-v2/guards/document.guard.ts","webpack:///src/app/modules/document-v2/pages/confirmation/confirmation.component.html","webpack:///src/app/modules/document-v2/pages/confirmation/confirmation.component.ts","webpack:///src/app/modules/document-v2/pages/confirmation/confirmation.component.scss","webpack:///src/app/modules/document-v2/pages/listing/listing.component.html","webpack:///src/app/modules/document-v2/pages/listing/listing.component.ts","webpack:///src/app/modules/document-v2/pages/listing/listing.component.scss","webpack:///src/app/modules/document-v2/pages/prescription/upload-pdf.component.html","webpack:///src/app/modules/document-v2/pages/prescription/upload-pdf.component.ts","webpack:///src/app/modules/document-v2/pages/prescription/upload-pdf.component.scss","webpack:///src/app/modules/document-v2/pages/retention-confirmation/retention-confirmation.component.html","webpack:///src/app/modules/document-v2/pages/modal-search/modal-search.component.ts","webpack:///src/app/modules/document-v2/pages/modal-search/modal-search.component.html","webpack:///src/app/modules/document-v2/pages/modal-search/modal-search.component.scss","webpack:///src/app/modules/document-v2/pages/retention-confirmation/retention-confirmation.component.ts","webpack:///src/app/modules/document-v2/pages/retention-confirmation/retention-confirmation.component.scss","webpack:///src/app/modules/document-v2/document-v2-routing.module.ts","webpack:///src/app/modules/document-v2/pages/attestation/attestation.component.ts","webpack:///src/app/modules/document-v2/pages/attestation/attestation.component.html","webpack:///src/app/modules/document-v2/pages/attestation/attestation.component.scss","webpack:///src/app/modules/document-v2/pages/exam-v2/exam-v2.component.ts","webpack:///src/app/modules/document-v2/pages/exam-v2/exam-v2.component.html","webpack:///src/app/modules/document-v2/pages/exam-v2/exam-v2.component.scss","webpack:///src/app/modules/document-v2/pages/infusion-protocol/infusion-protocol.component.ts","webpack:///src/app/modules/document-v2/pages/infusion-protocol/infusion-protocol.component.html","webpack:///src/app/modules/document-v2/pages/infusion-protocol/infusion-protocol.component.scss","webpack:///src/app/modules/document-v2/pages/model-list-favorite-document/model-list-favorite-document-cid-view/model-list-favorite-document-cid-view.component.ts","webpack:///src/app/modules/document-v2/pages/model-list-favorite-document/model-list-favorite-document-cid-view/model-list-favorite-document-cid-view.component.html","webpack:///src/app/modules/document-v2/pages/model-list-favorite-document/model-list-favorite-document-cid-view/model-list-favorite-document-cid-view.component.scss","webpack:///src/app/modules/document-v2/pages/orientation/orientation.component.ts","webpack:///src/app/modules/document-v2/pages/orientation/orientation.component.html","webpack:///src/app/modules/document-v2/pages/orientation/orientation.component.scss","webpack:///src/app/modules/document-v2/pages/prescription-rennova/prescription-rennova.component.html","webpack:///src/app/modules/document-v2/pages/prescription-rennova/prescription-rennova.component.ts","webpack:///src/app/modules/document-v2/pages/prescription-rennova/prescription-rennova.component.scss","webpack:///src/app/modules/document-v2/pages/prescription/navigation.component.ts","webpack:///src/app/modules/document-v2/pages/prescription/navigation.component.scss","webpack:///src/app/modules/document-v2/pages/prescription/prescription.component.html","webpack:///src/app/modules/document-v2/pages/prescription/prescription.component.ts","webpack:///src/app/modules/document-v2/pages/prescription/prescription.component.scss","webpack:///src/app/modules/document-v2/pages/prescription/unsigned-prescription-modal.component.ts","webpack:///src/app/modules/document-v2/pages/prescription/unsigned-prescription-modal.component.html","webpack:///src/app/modules/document-v2/pages/prescription/unsigned-prescription-modal.component.scss","webpack:///src/app/modules/document-v2/document-v2.module.ts","webpack:///src/app/modules/document-v2/pages/modal-iframe/modal-iframe.component.ts","webpack:///src/app/modules/document-v2/pages/modal-iframe/modal-iframe.component.html","webpack:///src/app/modules/document-v2/pages/modal-iframe/modal-iframe.component.scss"],"names":["modalService","fb","viewFormAndress","isVeterinarian","layout","showPrescriberCpf","selectLayout","patientDoesNotHaveAddress","colorSetting","this","tplModal","create","nzContent","tplContent","nzFooter","tplFooter","nzClosable","nzWidth","nzMaskClosable","nzOnOk","nzOnCancel","form","group","uf","required","city","complement","number","street","neighborhood","cep","afterOpen","subscribe","setBackgroundColorFooter","elements","document","getElementsByClassName","setAttribute","footer","markFormGroup","valid","emitEventAndCloseModal","emit","addressValue","value","close","destroy","I","static","selector","template","modalRef","crService","toast","hideEdit","selectEvent","editEvent","deleteEvent","typesOfDocuments","loadingSearchMedicament","item","active","updateMedicaments","hide","id","arrayText","reduce","acc","val","attestationDays","getAttestationsDays","find","label","typeOfActivity","getTypesOfActivity","prescription","medicament","medicaments","ean","medicamentsCR","searchMedicament","toPromise","length","medicamentCR","name","nome","prescriptionTypeId","typeCr","type","laboratory","laboratorio","description","apresentacaoCustomizada","medicamentId","principle","principio","error","console","log","notify","encapsulation","None","AttestationService","http","attestation","code","put","apiRoot","post","prescriberId","get","params","filter","patientId","attestationId","delete","providedIn","prescriptionModelService","orientationModelService","examModelService","attestationModelService","notification","HTTP_STATUS_CONFLICT","documentType","message","saveDocumentModel","documentModelForm","loading","payload","cid","documentModel","items","map","prescriber","userId","then","onSuccessCreateFavorite","catch","onFailureCreateFavorite","err","buildPrescriptionForm","buildExamForm","buildAttestationForm","buildOrientationForm","setDocumentModel","setPrescritpionModel","setExamModel","setAttestationModel","setOrientationModel","patchValue","forEach","m","addPrescription","quantity","prescribedQuantity","justification","setValue","titleOrientation","title","orientations","accumulator","currentValue","medication","version","observation","text","dosage","unitOfMeasurement","medicamentosFormCtrl","push","formMedicamentos","status","OrientationService","orientation","orientationId","router","route","healthProfessionalService","patientService","petService","prescriptionService","attestationService","examService","orientationService","victaProtocolService","authService","documentService","manipulatedProfileService","nzModalService","themeService","coreService","cdf","stateService","zone","actualDate","Date","nzBackfill","isPatientNotFound","patientCpf","search","signed","adding","documentTypes","exam","tabDefault","isMobile","isLoadingSearchPatient","destroyed$","ReplaySubject","documentForm","patientForm","_id","cpf","backendVersion$","getBackendVersion","event","isViewPortMobile","rennovaFeature","patient","JSON","parse","localStorage","getItem","removeItem","getPrescriberData","user","response","profileId","petId","snapshot","queryParams","responsePlus","decode","modalSendDocumentComponent","createTplModal","isPet","navigate","getManipulatedProfile","getDocument","fillForm","documentTypeSelected","detectChanges","onChange","modelId","selectedDocumentModel","getDocumentModel","features","some","f","data","isRennova","frontendVersion","Boolean","getManipulatedProfileById","manipulatedProfile","disable","documentsModel","getById","examList","local","healthProfessional","pet","routeConfig","path","manipulatedprofile","toggleAdding","getHealthProfessional","commercialData","initialState","addPatient","modal","show","backdrop","keyboard","content","updateListPatientEvent","onChangePatient","openModalAddPatientEvent","consult","showModalAddPatient","openModalSelectPetEvent","showModalSelectPet","loadingSpinnerEvent","isResponsible","existingPatient","class","pets","responsible","submit","isAdding","doNotShowAgainPetDataConfirmationModal","updatePatientInformation","openEditPetDataModal","showModalSearch","isConfirmation","p","update","emitEvent","getPetsByResponsible","prescriberPets","hasDependent","addPetPatient","onClose","reset","patients","replace","inputValue","valueChanges","pipe","debounceTime","distinctUntilChanged","tap","switchMap","getPatients","res","handleResponse","takeUntil","catchError","source","arr","startWith","match","of","valueWithoutCharacters","transform","fullCpf","onlyNumbers","getPetsByResponsibleCpf","getPatientByCpf","res1","getPets","getPatientsByUserId","patientInfo","responsibleExists","isOnlyNumbers","fullname","documentSaved","saveDocument","doc","getRawValue","valueCid","productsRennova","products","save","take","warn","cidValues","selectPrescriptionLayout","previewPdf","getActiveTheme","generateAndOpenPdf","signPdf","url","getUrlToSignDocument","victaFeature","window","location","href","method","responsibleDoesNotHaveAddress","modalSelectLayout","async","updatedPatient","updateAddressPatient","savedDocumentAndPreviewPdfOrSignPdf","dateOfBirth","DateUtils","isUnderAge","isNull","address","isUndefined","isEmpty","Promise","resolve","reject","restData","dataPatient","src","height","width","onLoad","matches","resetForm","next","complete","cd","toLocaleLowerCase","run","obj","professionalType","Object","keys","constructor","groups","getProtocols","protocol","documentsTemplate","getListDocumentsTemplates","showFavoritePrescriptionsModel","model","confirm","nzTitle","deleteDocumentModel","deleteById","getListByPrescriberId","documentTemplate","msg","getFormError","modelSaved","undefined","a","nativeAsync","DocumentGuard","state","isPrescriber","userType","pharmacyService","cdr","ngZone","quantidade","allChecked","indeterminate","quantities","getCurrentNavigation","extras","prescriptionCode","getCompleteUser","getPrescriptionbyCode","hasFarmaRennovaFeature","availableQuantity","array","every","allUnChecked","checkedNumber","completeUser","getPharmacyByUserId","pharmacyId","extraData","refreshStatus","specialties","s","join","medicinesRetained","saveRetentionFeedback","openModalBuyerData","nzComponentParams","instance","getContentComponent","saveRetention","cpfBuyer","retention","dispensationCode","downloadPrescriptionPdf","getProfessionalTypeName","initLoading","loadingMore","showPrescriptionTab","showDoctorTab","showPatientTab","prescriptions","param","requests","getPrescriptionsPatient","UploadPdfComponent","pdfService","fileList","target","files","file","postFilePdf","unsignedPrescriptionModal","ModalSearchComponent","retentionService","buyerService","getRetentionByCode","setInfoInMedicamentsRetained","buyer","telephone","cellphone","identity","getBuyerByCpf","medicamentRetained","preWriter","regionalCouncil","contact","getRegionalCouncilLabel","regionalCouncilNumber","nascimento","hoje","diferencaAnos","getFullYear","getMonth","getDate","getElementById","setItem","routes","component","canActivate","DocumentV2RoutingModule","imports","forChild","exports","formEmitter","onShowModelListFavoriteDocument","showModelForm","showCardTextBox","showCardCid","attestationForm","showPatientCpf","init","resetValidationsDescription","attestationModel","addControl","control","clearValidators","setErrors","setValidators","updateValueAndValidity","showCardDataExams","examModel","buildForm","verifyShowCards","hasJustification","groupExam","showTuss","exams","showModalListVictaProtocols","protocols","changes","protocolSelected","addProtocol","infusion","controls","phasesGroups","phases","phase","protocolGroup","protocolIndex","removeAt","ModelListFavoriteDocumentCidViewComponent","showButtonSerene","rows","orientationForm","hasCid","trim","split","orientationModel","addProductForm","product","existsProduct","formProduct","buildFormProductItem","index","descriptions","fullDescription","concentration","bulk","toUpperCase","resetValidationsObservation","at","NavigationComponent","_router","navbarBackGround","brandBackGround","disableNavigation","logout","isLoggedIn","isLoggedOut","isThemeActiveReceitaDigital","setTheme","medicamentsFormCtrl","hasObservation","prescriptionModel","removeEmptyMedicaments","manipuled","formGroup","editing","listemDosage","selectedMedicament","disabled","i","formMedicaments","onAddProtocol","UnsignedPrescriptionModalComponent","nzWrapClassName","DocumentV2Module","declarations","PatientsModule","forRoot","providers","Subject","iframe","contentWindow","e"],"mappings":"mMAWa,EAA0B,MAoBrC,YAAoBA,EAAsCC,GAAtC,KAAAD,eAAsC,KAAAC,KAlBjD,KAAAC,iBAAkB,EAClB,KAAAC,gBAAiB,EAU1B,KAAAC,OAAS,SACT,KAAAC,mBAAoB,EAEpB,KAAAC,aAAe,IAAI,IAMnB,eACEC,GAA4B,EAC5BJ,GAAiB,EACjBK,GAEAC,KAAKD,aAAeA,EACpBC,KAAKN,eAAiBA,EACtBM,KAAKC,SAAWD,KAAKT,aAAaW,OAAO,CACvCC,UAAWH,KAAKI,WAChBC,SAAUL,KAAKM,UACfC,YAAY,EACZC,QAASV,EAA4B,IAAM,IAC3CW,gBAAgB,EAChBC,OAAQ,OACRC,WAAY,SAGVb,GACFE,KAAKP,iBAAkB,EACvBO,KAAKY,KAAOZ,KAAKR,GAAGqB,MAAM,CACxBC,GAAI,CAAC,GAAI,IAAWC,UACpBC,KAAM,CAAC,GAAI,IAAWD,UACtBE,WAAY,CAAC,IACbC,OAAQ,CAAC,GAAI,IAAWH,UACxBI,OAAQ,CAAC,GAAI,IAAWJ,UACxBK,aAAc,CAAC,GAAI,IAAWL,UAC9BM,IAAK,CAAC,GAAI,IAAWN,aAGvBf,KAAKP,iBAAkB,EAGzBO,KAAKC,SAASqB,UAAUC,UAAUA,KAChCvB,KAAKwB,6BAIT,2BACE,MAAMC,EAAWC,SAASC,uBAAuB,oBAC7CF,IACEzB,KAAKD,aACP0B,EAAS,GAAGG,aAAa,QAAS,qBAAqB5B,KAAKD,aAAa8B,UAEzEJ,EAAS,GAAGG,aAAa,QAAS,6CAKxC,SACsB,YAAhB5B,KAAKL,QAAwBK,KAAKP,iBACpC,OAAAqC,EAAA,GAAc9B,KAAKY,MACfZ,KAAKY,KAAKmB,OACZ/B,KAAKgC,0BAGPhC,KAAKgC,yBAIT,yBACEhC,KAAKH,aAAaoC,KAAK,CACrBtC,OAAQK,KAAKL,OACbuC,aAAclC,KAAKY,KAAOZ,KAAKY,KAAKuB,MAAQ,OAE9CnC,KAAKoC,QAGP,QACEpC,KAAKC,SAASmC,QACdpC,KAAKC,SAASoC,Y,4BAlGG,K,MAHZ,M,sCAWN,EAAAC,I,uBACA,EAAAA,I,sBACA,EAAAA,I,kBAIA,KAAS,MAAC,aAAc,CAAEC,QAAQ,M,iBAGlC,KAAS,MAAC,YAAa,CAAEA,QAAQ,OAVvB,EAA0B,aALtC,YAAU,CACTC,SAAU,0BACVC,SCRa,0oD,QCAA,+hD,iCF+BqB,IAA4B,OApBnD,I,oJGGA,EAAkC,MAe7C,YACSC,EACCC,EACAC,GAFD,KAAAF,WACC,KAAAC,YACA,KAAAC,QAdD,KAAAC,UAAW,EACV,KAAAC,YAAc,IAAI,IAClB,KAAAC,UAAY,IAAI,IAChB,KAAAC,YAAc,IAAI,IAI5B,KAAAC,iBAAmB,CAAC,mBAAc,QAAS,WAAY,UAEvD,KAAAC,yBAA0B,EAQ1B,aAAaC,GACXA,EAAKC,QAAUD,EAAKC,OAGtB,eAAeD,GACS,iBAAlBA,EAAKzB,gBACD1B,KAAKqD,kBAAkBF,GAE/BnD,KAAK8C,YAAYb,KAAKkB,GACtBnD,KAAK0C,SAASY,OAGhB,aAAaH,GACW,iBAAlBA,EAAKzB,gBACD1B,KAAKqD,kBAAkBF,GAE/BnD,KAAK+C,UAAUd,KAAKkB,GACpBnD,KAAK0C,SAASY,OAGhB,SAASH,GACPnD,KAAKgD,YAAYf,KAAKkB,EAAKI,IAG7B,QAAQC,GACN,OAAOA,EAAUC,OAAOA,CAACC,EAAKC,IAASD,EAAM,GAAGA,MAAQC,IAAQA,EAAM,IAGxE,wBAAwBC,GACtB,OAAO,IAAaC,sBAAsBC,KAAKX,GAAQA,EAAKhB,QAAUyB,GAAiBG,OAAS,GAGlG,uBAAuBC,GACrB,OAAO,IAAaC,qBAAqBH,KAAKX,GAAQA,EAAKhB,QAAU6B,GAAgBD,OAAS,GAGhG,wBAAwBG,GACtB,UAAW,MAAMC,KAAcD,EAAaE,YAC1C,GAAMD,EAAWE,IAAK,CACpBrE,KAAKkD,yBAA0B,EAC/B,IACE,MAAMoB,QAAsBtE,KAAK2C,UAAU4B,iBAAiBJ,EAAWE,KAAKG,YAC5E,GAAIF,EAAcG,OAAS,EAAG,CAC5B,MAAMC,EAAeJ,EAAc,GACnCH,EAAWQ,KAAOD,EAAaE,KAC/BT,EAAWU,mBAAqBH,EAAaG,mBAC7CV,EAAWW,OAASJ,EAAaI,OACjCX,EAAWY,KAAO,iBAClBZ,EAAWa,WAAaN,EAAaO,YACrCd,EAAWe,YAAcR,EAAaS,wBACtChB,EAAWiB,aAAeV,EAAanB,GACvCY,EAAWkB,UAAYX,EAAaY,WAEtC,MAAOC,GACPC,QAAQC,IAAIF,GACZvF,KAAK4C,MAAM8C,OAAO,QAAS,2C,QAE3B1F,KAAKkD,yBAA0B,QAGjCiB,EAAWY,KAAO,c,4BA5FjB,K,MAHA,K,MAMA,M,2CASN,EAAAzC,I,oBACA,EAAAA,I,oBACA,EAAAA,I,gBACA,EAAAA,I,mBACA,M,iBACA,M,mBACA,M,mBAEA,KAAS,MAAC,kBATA,EAAkC,aAN9C,YAAU,CACTE,SAAU,uCACVC,SCVa,o6JDYbkD,cAAe,KAAkBC,K,QEZpB,qrE,iCF8BM,IACE,IACJ,OAlBN,I,4HGDAC,EAAkB,MAC7B,YAAoBC,GAAA,KAAAA,OAEb,KAAKC,GACV,OAAIA,EAAYC,KACPhG,KAAK8F,KAAKG,IAAI,GAAG,IAAYC,sBAAyBH,EAAYC,OAAQD,GAE5E/F,KAAK8F,KAAKK,KAAK,GAAG,IAAYD,qBAAyBH,GAGzD,6BAA6BK,GAClC,OAAOpG,KAAK8F,KAAKO,IAAmB,GAAG,IAAYH,qBAAyB,CAC1EI,OAAQ,CAAEF,kBAIP,kCAAkCA,EAAsBG,GAC7D,OAAOvG,KAAK8F,KAAKO,IAAS,GAAG,IAAYH,iCAAoCE,IAAgB,CAC3FE,OAAQC,IAIL,2BAA2BC,GAChC,OAAOxG,KAAK8F,KAAKO,IAAmB,GAAG,IAAYH,qBAAyB,CAC1EI,OAAQ,CAAEE,eAId,2BAA2BA,EAAmBD,GAC5C,OAAOvG,KAAK8F,KAAKO,IAAS,GAAG,IAAYH,8BAAqCM,IAAa,CACzFF,OAAQC,IAIZ,eAAeP,GACb,OAAOhG,KAAK8F,KAAKO,IAAI,GAAG,IAAYH,sBAAyBF,KAG/D,YAAYO,GACV,OAAOvG,KAAK8F,KACTO,IAAmB,GAAG,IAAYH,4BAAgC,CACjEI,OAAQC,IAET/B,YAGL,OAAOiC,GACL,OAAOzG,KAAK8F,KAAKY,OAAO,GAAG,IAAYR,sBAAyBO,O,4BA3D3D,MAYIZ,EAAkB,aAH9B,YAAW,CACVc,WAAY,S,iCAGc,OADfd,I,8MCKA,EAAiC,MAa5C,YACSnD,EACCkE,EACAC,EACAC,EACAC,EACAC,GALD,KAAAtE,WACC,KAAAkE,2BACA,KAAAC,0BACA,KAAAC,mBACA,KAAAC,0BACA,KAAAC,eAlBD,KAAAC,qBAAuB,IAGvB,KAAAC,aAAe,GAGxB,KAAAjE,iBAAmB,CAAC,mBAAc,QAAS,WAAY,UAEvD,KAAAkE,QAAU,GAoNV,KAAAC,kBAAoB,KAClB,IACE,OAAAtF,EAAA,GAAc9B,KAAKqH,mBACnBrH,KAAKsH,SAAU,EACf,MAAMC,EAAUvH,KAAKqH,kBAAkBlF,MAQvC,GAPAoF,EAAQC,IAAMxH,KAAKyH,cAAcD,IAC7B,IACKxH,KAAKyH,cAAcD,IACtBE,MAAO1H,KAAKyH,cAAcD,IAAIE,MAAMC,IAAIxE,GAAQA,EAAKI,KAEvD,KAEAvD,KAAKqH,kBAAkBtF,MACzB,OAAQ/B,KAAKkH,cACX,KAAKlH,KAAKiD,iBAAiB,GACzBjD,KAAK4G,yBACF1G,OAAOqH,EAASvH,KAAK4H,YAAc5H,KAAK4H,WAAWC,QACnDC,KAAKA,IAAM9H,KAAK+H,2BAChBC,MAAMzC,GAASvF,KAAKiI,wBAAwB1C,IAC/C,MAEF,KAAKvF,KAAKiD,iBAAiB,GACzBjD,KAAK8G,iBACF5G,OAAO,IACHF,KAAKyH,iBACLF,IAEJO,KAAKA,IAAM9H,KAAK+H,2BAChBC,MAAMzC,GAASvF,KAAKiI,wBAAwB1C,IAC/C,MAEF,KAAKvF,KAAKiD,iBAAiB,GACzBjD,KAAK+G,wBACF7G,OAAOqH,GACPO,KAAKA,IAAM9H,KAAK+H,2BAChBC,MAAMzC,GAASvF,KAAKiI,wBAAwB1C,IAC/C,MAEF,KAAKvF,KAAKiD,iBAAiB,GACzBjD,KAAK6G,wBACF3G,OAAOqH,GACPO,KAAKA,IAAM9H,KAAK+H,2BAChBC,MAAMzC,GAASvF,KAAKiI,wBAAwB1C,IAIrDvF,KAAKsH,SAAU,EACf,MAAOY,GACPlI,KAAKsH,SAAU,EACftH,KAAKmH,QAAUe,EAAI3C,MAAM4B,QACzB3B,QAAQC,IAAIyC,KAzPhB,WACE,OAAQlI,KAAKkH,cACX,KAAKlH,KAAKiD,iBAAiB,GACzBjD,KAAKmI,wBACL,MACF,KAAKnI,KAAKiD,iBAAiB,GACzBjD,KAAKoI,gBACL,MACF,KAAKpI,KAAKiD,iBAAiB,GACzBjD,KAAKqI,uBACL,MAEF,KAAKrI,KAAKiD,iBAAiB,GACzBjD,KAAKsI,uBAGTtI,KAAKuI,mBAGP,mBACMvI,KAAKkH,eAAiBlH,KAAKiD,iBAAiB,GAC9CjD,KAAKwI,uBACIxI,KAAKkH,eAAiBlH,KAAKiD,iBAAiB,GACrDjD,KAAKyI,eACIzI,KAAKkH,eAAiBlH,KAAKiD,iBAAiB,GACrDjD,KAAK0I,sBACI1I,KAAKkH,eAAiBlH,KAAKiD,iBAAiB,IACrDjD,KAAK2I,sBAIT,uBACM3I,KAAKyH,gBACPzH,KAAKqH,kBAAkBuB,WAAW,CAAEhB,WAAY5H,KAAK4H,cAAe5H,KAAKyH,gBACzEzH,KAAKyH,cAAcrD,YAAYyE,QAAQC,IACrC9I,KAAK+I,gBAAgB,IAChBD,EACHlE,KAAMkE,EAAEnE,KACRpB,GAAIuF,EAAE1D,aACNE,UAAWwD,EAAEzD,UACbJ,YAAa6D,EAAE9D,WACfX,IAAKyE,EAAEzE,IACPc,wBAAyB2D,EAAE5D,YAC3B8D,SAAUF,EAAEG,mBACZlE,KAAM+D,EAAE/D,UAMhB,eACE,GAAI/E,KAAKyH,gBACPzH,KAAKqH,kBAAkBuB,WAAW,CAAEhB,WAAY5H,KAAK4H,cAAe5H,KAAKyH,gBACrEzH,KAAKyH,cAAcyB,eAAe,CACpC,MAAM/G,EAAQnC,KAAKyH,cAAcyB,cAAczF,OAAOA,CACnDC,EAAKC,IAASD,EAAM,GAAGA,MAAQC,IAAQA,EACxC,IAEF3D,KAAKqH,kBAAkBhB,IAAI,QAAQ8C,SAAShH,IAKlD,sBACE,GAAInC,KAAKyH,cAAe,CACtBzH,KAAKqH,kBAAkBuB,WAAW,CAChCQ,iBAAkBpJ,KAAKyH,cAAc4B,MACrCzB,WAAY5H,KAAK4H,cACd5H,KAAKyH,gBAEV,MAAMtF,EAAQnC,KAAKyH,cAAc6B,aAAa7F,OAAOA,CAClD8F,EAAaC,IAAiBD,EAAc,KAAOC,GAEtDxJ,KAAKqH,kBAAkBhB,IAAI,QAAQ8C,SAAShH,IAIhD,sBACE,GAAInC,KAAKyH,cAAe,CACtBzH,KAAKqH,kBAAkBuB,WAAW,CAAEhB,WAAY5H,KAAK4H,cAAe5H,KAAKyH,gBACzE,MAAMtF,EAC+B,KAAnCnC,KAAKyH,cAAcvC,YACflF,KAAKyH,cAAcvC,YAAYzB,OAAOA,CACnC8F,EAAaC,IAAiBD,EAAc,KAAOC,GAEtD,GACNxJ,KAAKqH,kBAAkBhB,IAAI,QAAQ8C,SAAShH,IAIxC,wBACNnC,KAAKqH,kBAAoB,IAAI,IAAU,CACrCgC,MAAO,IAAI,IAAY,GAAI,IAAWtI,UACtC6G,WAAY,IAAI,IAAY,IAC5B6B,WAAY,IAAI,IAAY,IAC5BrF,YAAa,IAAI,IAAU,GAAI,IAAWrD,UAC1C2I,QAAS,IAAI,IAAY,QACzBC,YAAa,IAAI,IAAY,MAIzB,uBACN3J,KAAKqH,kBAAoB,IAAI,IAAU,CACrCgC,MAAO,IAAI,IAAY,GAAI,IAAWtI,UACtCqI,iBAAkB,IAAI,IAAY,GAAI,IAAWrI,UACjD6G,WAAY,IAAI,IAAY,IAC5BgC,KAAM,IAAI,IAAY,IACtBN,aAAc,IAAI,IAAY,GAAI,IAAWvI,UAC7C2I,QAAS,IAAI,IAAY,UAIrB,uBACN1J,KAAKqH,kBAAoB,IAAI,IAAU,CACrCgC,MAAO,IAAI,IAAY,GAAI,IAAWtI,UACtC6G,WAAY,IAAI,IAAY,IAC5BgC,KAAM,IAAI,IAAY,IACtB1E,YAAa,IAAI,IAAY,IAC7BwE,QAAS,IAAI,IAAY,QACzB9F,gBAAiB,IAAI,IACrBI,eAAgB,IAAI,MAIhB,gBACNhE,KAAKqH,kBAAoB,IAAI,IAAU,CACrCgC,MAAO,IAAI,IAAY,GAAI,IAAWtI,UACtC6I,KAAM,IAAI,IAAY,IACtBF,QAAS,IAAI,IAAY,UAItB,iBAAgB,KACrB9E,EAAI,GACJrB,EAAE,UACF+B,EAAS,YACTL,EAAW,IACXZ,EAAG,wBACHc,EAAuB,OACvB0E,EAAS,GAAE,SACXb,EAAW,EAAC,KACZjE,EAAI,kBACJ+E,EAAiB,mBACjBjF,EAAkB,OAClBC,IAEA9E,KAAK+J,qBAAqBC,KACxBhK,KAAKiK,iBAAiB,CACpBtF,KAAMC,EACNQ,aAAc7B,EACd8B,UAAWC,EACXN,WAAYC,EACZZ,IAAKA,EACLa,YAAaC,EACb0E,SACAb,WACAjE,OACA+E,oBACAjF,qBACAC,YAGJ9E,KAAKqH,kBAAkBhB,IAAI,cAAc8C,SAAS,MAGpD,kBAAiB,KACfxE,EAAI,aACJS,EAAY,UACZC,EAAS,WACTL,EAAU,IACVX,EAAG,SACH2E,EAAQ,YACR9D,EAAW,OACX2E,EAAM,KACN9E,EAAI,kBACJ+E,EAAiB,mBACjBjF,EAAkB,OAClBC,IAEA,OAAO,IAAI,IAAU,CACnBH,KAAM,IAAI,IAAYA,GACtBS,aAAc,IAAI,IAAYA,GAC9B6D,mBAAoB,IAAI,IAAYD,GACpCa,OAAQ,IAAI,IAAYA,GACxB3E,YAAa,IAAI,IAAYA,GAC7BG,UAAW,IAAI,IAAYA,GAC3BL,WAAY,IAAI,IAAYA,GAC5BX,IAAK,IAAI,IAAYA,GACrBU,KAAM,IAAI,IAAYA,GACtB+E,kBAAmB,IAAI,IAAYA,GACnCjF,mBAAoB,IAAI,IAAYA,GACpCC,OAAQ,IAAI,IAAYA,KAI5B,QAAQtB,GACN,OAAOA,EAAUC,OAAOA,CAACC,EAAKC,IAASD,EAAM,GAAGA,MAAQC,IAAQA,EAAM,IAyDxE,0BACE3D,KAAK0C,SAASY,OACdtD,KAAKgH,aAAatB,OAAO,UAAW,UAAW,UAAU1F,KAAKkH,kCAGhE,wBAAwB3B,GAClBA,EAAM2E,SAAWlK,KAAKiH,qBACxBjH,KAAKgH,aAAatB,OAChB,UACA,gBACA,qEAGF1F,KAAKgH,aAAatB,OAAO,UAAW,QAAS,gDAIjD,2BACE,OAAkB1F,KAAKqH,kBAAkBhB,IAAI,iB,4BAjTxC,K,MAIA,K,MADA,K,MADA,K,MADA,K,MAHA,M,oCAiBN,EAAA/D,I,oBACA,EAAAA,I,qBACA,EAAAA,I,oBACA,EAAAA,KANU,EAAiC,aAL7C,YAAU,CACTE,SAAU,sCACVC,SCfa,i0E,QCAA,k2J,iCFgCM,IACiB,IACD,IACP,IACO,IACX,OAnBb,I,4HGNA0H,EAAkB,MAC7B,YAAoBrE,GAAA,KAAAA,OAEb,KAAKsE,GACV,OAAIA,EAAYpE,KACPhG,KAAK8F,KAAKG,IAAI,GAAG,IAAYC,sBAA6BkE,EAAYpE,OAAQoE,GAEhFpK,KAAK8F,KAAKK,KAAK,GAAG,IAAYD,qBAA6BkE,GAG7D,kCAAkChE,EAAsBG,GAC7D,OAAOvG,KAAK8F,KAAKO,IAAS,GAAG,IAAYH,iCAA6BE,IAAgB,CACpFE,OAAQC,IAIL,mBAAmBC,GACxB,OAAOxG,KAAK8F,KAAKO,IAAmB,GAAG,IAAYH,qBAA6B,CAC9EI,OAAQ,CAAEE,eAId,2BAA2BA,EAAmBD,GAC5C,OAAOvG,KAAK8F,KAAKO,IAAS,GAAG,IAAYH,8BAA0BM,IAAa,CAAEF,OAAQC,IAG5F,eAAeP,GACb,OAAOhG,KAAK8F,KAAKO,IAAI,GAAG,IAAYH,sBAA6BF,KAGnE,YAAYO,GACV,OAAOvG,KAAK8F,KACTO,IAAmB,GAAG,IAAYH,4BAAoC,CACrEI,OAAQC,IAET/B,YAGL,OAAO6F,GACL,OAAOrK,KAAK8F,KAAKY,OAAO,GAAG,IAAYR,sBAA6BmE,O,4BAhD/D,MASIF,EAAkB,aAH9B,YAAW,CACVxD,WAAY,S,iCAGc,OADfwD,I,yzBCqEA,GAAiB,MAwD5B,YACUG,EACAC,EACA/K,EACAgL,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAlE,EACAG,EACAD,EACAD,EACAkE,EACA/D,EACAgE,EACAC,EACAC,EACA3L,EACA4L,EACAC,EACAC,EACAC,EACAC,EACAC,EACA7I,GA1BA,KAAA2H,SACA,KAAAC,QACA,KAAA/K,KACA,KAAAgL,4BACA,KAAAC,iBACA,KAAAC,aACA,KAAAC,sBACA,KAAAC,qBACA,KAAAC,cACA,KAAAC,qBACA,KAAAlE,2BACA,KAAAG,0BACA,KAAAD,mBACA,KAAAD,0BACA,KAAAkE,uBACA,KAAA/D,eACA,KAAAgE,cACA,KAAAC,kBACA,KAAAC,4BACA,KAAA3L,eACA,KAAA4L,iBACA,KAAAC,eACA,KAAAC,cACA,KAAAC,MACA,KAAAC,eACA,KAAAC,OACA,KAAA7I,YAlFV,KAAA8I,WAAa,IAAIC,KACjB,KAAAC,YAAa,EACb,KAAAC,mBAAoB,EACZ,KAAAC,WAAa,GAErB,KAAAC,QAAS,EACT,KAAAxE,SAAU,EACV,KAAAyE,QAAS,EAaT,KAAAC,QAAS,EACT,KAAA/I,iBAAmB,CAAC,mBAAc,QAAS,WAAY,SAAU,4BACjE,KAAAgJ,cAAgB,CACd/H,aAAc,mBACdgI,KAAM,QACNnG,YAAa,WACbqE,YAAa,SACb,qBAAsB,4BAGxB,KAAA+B,WAAa,mBAEb,KAAAC,UAAW,EACX,KAAAC,wBAAyB,EACzB,KAAAnJ,yBAA0B,EAclB,KAAAoJ,WAAqC,IAAIC,EAAA,EAoC/CvM,KAAKwM,aAAexM,KAAKR,GAAGqB,MAAM,IAClCb,KAAKyM,YAAczM,KAAKR,GAAGqB,MAAM,CAC/B6L,IAAK,CAAC,MACNC,IAAK,CAAC,MACNhI,KAAM,CAAC,GAAI,CAAC,IAAW5D,aAEzBf,KAAK4M,gBAAkB5M,KAAKqL,YAAYwB,oBAvC1C,SAASC,GACP9M,KAAKoM,SAAWpM,KAAKqL,YAAY0B,mBA0CnC,iBACE/M,KAAKmM,WAAanM,KAAKgN,eAAiB,2BAAuB,mBAC/DhN,KAAKkH,aAAelH,KAAKgN,eAAiBhN,KAAKiD,iBAAiB,GAAKjD,KAAKiD,iBAAiB,GAE3FjD,KAAKsH,SAAU,EAEf,MAAM2F,EAAUC,KAAKC,MAAMC,aAAaC,QAAQ,YAC5CJ,IACFjN,KAAKyM,YAAY7D,WAAWqE,GAC5BjN,KAAKiN,QAAUA,EACfG,aAAaE,WAAW,YAG1BtN,KAAKuN,kBAAkBvN,KAAKwN,KAAKd,KACjC,MAAM,KACJ1G,EAAI,SACJyH,EAAQ,aACRvG,EAAY,UACZwG,EAAS,UACTlH,EAAS,MACTmH,GACE3N,KAAKuK,MAAMqD,SAASC,YAExB,GAAI7H,GAAQyH,IAAajH,GAAamH,GAAQ,CAC5C,MAAMG,EAAe,KAAYC,OAAoBN,GACxB,cAAzBK,EAAa3G,SAAoD,oBAAzB2G,EAAa3G,QACvDnH,KAAKgO,2BAA2BC,eAAejI,EAAMQ,GAAamH,EAAO,CAAEO,QAASP,KAEpF3N,KAAKgH,aAAatB,OAAO,QAAS,8BAClCF,QAAQC,IAAIgI,GACZzN,KAAKsK,OAAO6D,SAAS,CAAC,YAAanI,EAAM,UAIzC0H,GACF1N,KAAKoO,sBAAsBV,GAG7B,MAAMnK,EAAKvD,KAAKuK,MAAMqD,SAAStH,OAAO/C,KAAQkK,GAAYzH,EAC1D,GAAIzC,EACF,IACE,MAAM7B,QAAiB1B,KAAKiL,gBAAgBoD,YAAY9K,EAAI2D,GAClC,iBAAtBxF,EAASA,gBACL1B,KAAKqD,kBAAkB3B,GAE/B1B,KAAKsO,SAAS5M,GAEV1B,KAAKiL,gBAAgBsD,sBACvBvO,KAAKkH,aAAelH,KAAKiL,gBAAgBsD,qBACzCvO,KAAKmM,WAAanM,KAAKiL,gBAAgBsD,uBAEvCvO,KAAKkH,aAAelH,KAAKgN,eAAiB,2BAAuBtL,EAASqD,KAC1E/E,KAAKmM,WAAanM,KAAKgN,eAAiB,2BAAuBtL,EAASqD,MAE1E/E,KAAKsH,SAAU,EACftH,KAAKsL,IAAIkD,gBACT,MAAOtG,GACP1C,QAAQD,MAAM2C,GACdlI,KAAKsK,OAAO6D,SAAS,CAAC,kBAI1BnO,KAAKyO,WACLzO,KAAK0O,QAAU1O,KAAKuK,MAAMqD,SAAStH,OAAOoI,QAC1C,MAAM3J,EAAO/E,KAAKuK,MAAMqD,SAAStH,OAAOY,aAEpClH,KAAK0O,SACP1O,KAAKgM,QAAS,EACdhM,KAAKkH,aAAelH,KAAKiM,cAAclH,GACvC/E,KAAK2O,4BAA8B3O,KAAK4O,oBAC/B5O,KAAKiL,gBAAgBwB,cAC9BzM,KAAKgM,QAAS,EACdhM,KAAKyM,YAAczM,KAAKiL,gBAAgBwB,YACxCzM,KAAKkH,aAAelH,KAAKiL,gBAAgBsD,qBACzCvO,KAAKmM,WAAanM,KAAKiL,gBAAgBsD,qBACvCvO,KAAKiL,gBAAgBwB,YAAc,MAGrCzM,KAAKsH,SAAU,EACftH,KAAKsL,IAAIkD,gBAGX,wBACExO,KAAKsL,IAAIkD,gBAGX,WACE,OAAOxO,KAAKgL,YAAYwC,OAG1B,2BACE,OAAOxN,KAAKwN,MAAQxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,kBAAXA,EAAEpK,MAGrD,mBACE,OAAO3E,KAAKwN,MAAQxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,UAAXA,EAAEpK,MAGrD,oBACE,OAAO3E,KAAKwN,MAAQxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,WAAXA,EAAEpK,MAGrD,qBACE,OACE3E,KAAKwN,MACLxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,YAAXA,EAAEpK,OAC/B3E,KAAKuL,aAAayD,MAClBhP,KAAKuL,aAAayD,KAAKC,UAI3B,gCACE,OAAOjP,KAAKwN,MAAQxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,yBAAXA,EAAEpK,MAGrD,sBACE,OAAO3E,KAAKqL,YAAY6D,gBAG1B,qBACE,OAAOC,QAAQnP,KAAKuK,MAAMqD,SAASoB,KAAqB,gBAG1D,kBACE,OAAQhP,KAAKiN,UAAYjN,KAAKiN,QAAQN,KAAQ3M,KAAKN,eAC/C,gCACA,0BAGN,kBACE,OAAOM,KAAKyM,YAAYpG,IAAI,QAAQlE,MAG9B,sBAAsBuL,GAC5B1N,KAAKkL,0BAA0BkE,0BAA0B1B,GAAWnM,UAAU8N,IAC5ErP,KAAKyM,YAAY7D,WAAW,IAAKyG,EAAmBpC,UACpDjN,KAAKqP,mBAAqBA,EAC1BrP,KAAKiD,iBAAmB,CAACjD,KAAKiD,iBAAiB,IAC/CjD,KAAKgM,QAAS,EACdhM,KAAKyM,YAAY6C,YAKb,yBACN,IAAIC,EAEJ,OAAQvP,KAAKkH,cACX,KAAKlH,KAAKiD,iBAAiB,GACzBsM,QAAuBvP,KAAK4G,yBAAyB4I,QAAQxP,KAAK0O,SAClE,MACF,KAAK1O,KAAKiD,iBAAiB,GACzBsM,QAAuBvP,KAAK8G,iBAAiB0I,QAAQxP,KAAK0O,SAC1D,MACF,KAAK1O,KAAKiD,iBAAiB,GACzBsM,QAAuBvP,KAAK+G,wBAAwByI,QAAQxP,KAAK0O,SACjE,MACF,KAAK1O,KAAKiD,iBAAiB,GACzBsM,QAAuBvP,KAAK6G,wBAAwB2I,QAAQxP,KAAK0O,SAGrE,OAAOa,EAGT,eACE,OAAIvP,KAAK2O,sBACA3O,KAAK2O,sBAAsBc,SAE7BzP,KAAK0B,UAAY1B,KAAK0B,SAAS+N,SAGhC,SAAS/N,GACf1B,KAAK0P,MAAQhO,EAASgO,MACtB1P,KAAK4H,WAAalG,EAASiO,mBAC3B3P,KAAKyM,YAAY7D,WAAWlH,EAASuL,SAAWvL,EAASkO,KACzD5P,KAAKiN,QAAUvL,EAASuL,SAAWvL,EAASkO,IAE5C5P,KAAK0B,SAAWA,EAC6B,aAAzC1B,KAAKuK,MAAMqD,SAASiC,YAAYC,MAClC9P,KAAK+L,OAA6B,aAApBrK,EAASwI,OACnBxI,EAASqO,qBACX/P,KAAKiD,iBAAmB,CAACjD,KAAKiD,iBAAiB,IAC/CjD,KAAKyM,YAAY6C,oBAGZ5N,EAASsE,YACTtE,EAASwI,QAGlBlK,KAAKgQ,eAGC,kBAAkBnI,GACxB7H,KAAKwK,0BAA0ByF,sBAAsBpI,GAAQtG,UAAUqG,IACrE5H,KAAK4H,WAAaA,EAClB5H,KAAK0P,MAAQ1P,KAAK4H,YAAc5H,KAAK4H,WAAWsI,eAAe,KAInE,gBAAgBvD,GACd,MAAMwD,EAAe,CACnB3C,KAAMxN,KAAKwN,KACX5F,WAAY5H,KAAK4H,WACjBwI,YAAY,EACZzD,OAEI0D,EAAQrQ,KAAKT,aAAa+Q,KAAK,IAAsB,CACzDH,eACAI,SAAU,SACVC,UAAU,IAGZH,EAAMI,QAAQC,uBAAuBnP,UAAU0L,IAC7CjN,KAAKyM,YAAY7D,WAAWqE,GAC5BjN,KAAK2Q,gBAAgB1D,GACrBjN,KAAKiN,QAAUA,EACfjN,KAAKiL,gBAAgBwB,YAAczM,KAAKyM,cAE1C4D,EAAMI,QAAQG,yBAAyBrP,UAAUsP,GAAW7Q,KAAK8Q,oBAAoBD,IACrFR,EAAMI,QAAQM,wBAAwBxP,UAAUsP,GAAW7Q,KAAKgR,mBAAmBH,IACnFR,EAAMI,QAAQQ,oBAAoB1P,UAAU+F,GAAYtH,KAAKsH,QAAUA,GAGjE,oBAAoBuJ,GAC1B,MAAMV,EAAe,CACnBvI,WAAY5H,KAAK4H,WACjBqF,QAAS4D,EAAQ5D,QACjBiE,cAAeL,EAAQK,cACvBC,gBAAiBN,EAAQM,iBAEbnR,KAAKT,aAAa+Q,KAAK,IAA0B,CAC7Dc,MAAO,WACPjB,eACAI,SAAU,SACVC,UAAU,IAENC,QAAQC,uBAAuBnP,UAAU0L,IAC7CjN,KAAKyM,YAAY7D,WAAWqE,GAC5BjN,KAAKiN,QAAUA,EACfjN,KAAKiL,gBAAgBwB,YAAczM,KAAKyM,YACxCzM,KAAKyM,YAAYpG,IAAI,OAAO8C,SAAS8D,EAAQP,KAC7C1M,KAAKgM,QAAS,IAIV,mBAAmB6E,GACzB,MAAMV,EAAe,CACnBvI,WAAY5H,KAAK4H,WACjByJ,KAAMR,EAAQ5D,QAAQoE,KACtBC,YAAaT,EAAQ5D,SAEjBoD,EAAQrQ,KAAKT,aAAa+Q,KAAK,IAAyB,CAC5DH,eACAI,SAAU,SACVC,UAAU,IAGZH,EAAMI,QAAQc,OAAOhQ,UAAUA,EAAGqO,MAAK4B,eACrCxR,KAAKyM,YAAY7D,WAAWgH,GAC5B5P,KAAKiN,QAAU2C,EACV4B,GACHxR,KAAK2Q,gBAAgBf,GAGvBS,EAAM/M,SAIV,eAC4C,OAAtCtD,KAAKyM,YAAYpG,IAAI,OAAOlE,MAC9BnC,KAAKgH,aAAatB,OAAO,UAAW,QAAS,uDAE7C1F,KAAKgM,QAAUhM,KAAKgM,OAIxB,gBAAgBiB,GACd,GAAKA,EAAQP,IAEN,GAAI1M,KAAKN,eAAgB,CAC9B,MAAM,uCAAE+R,GAA2CxE,EAE9CwE,EAGHzR,KAAK0R,yBAAyBzE,GAF9BjN,KAAK2R,qBAAqB1E,QAK5BjN,KAAK0R,yBAAyBzE,QAV9BjN,KAAK4R,gBAAgB5R,KAAK6L,YAc9B,yBAAyBoB,GACvBjN,KAAKiN,QAAUA,EACfjN,KAAKyM,YAAYpG,IAAI,OAAO8C,SAAS8D,EAAQP,KAC7C1M,KAAKgM,QAAS,EACdhM,KAAKiL,gBAAgBwB,YAAczM,KAAKyM,YAG1C,qBAAqBmD,GACnB,MAAMO,EAAe,CAAEP,MAAKlQ,gBAAgB,EAAMmS,gBAAgB,GAE5DxB,EAAQrQ,KAAKT,aAAa+Q,KAAK,IAAuB,CAC1DH,eACAiB,MAAO,GACPb,SAAU,SACVC,UAAU,IAGZH,EAAMI,QAAQc,OAAOhQ,UAAUuQ,IAC7B9R,KAAK0K,WAAWqH,OAAOD,EAAEpF,IAAKoF,EAAG9R,KAAK4H,WAAW8E,KAAKnL,UAAUA,KAE5DvB,KAAKiN,QAAU6E,EACf9R,KAAKyM,YAAY7D,WAAW5I,KAAKiN,QAAS,CAAE+E,WAAW,IACvDhS,KAAKgM,QAAS,EACdhM,KAAKwK,0BACFyH,qBAAqBH,EAAER,YAAY5E,KACnCnL,UAAU2Q,IACT,MAAMC,EAAeD,EAAepD,KAAKgD,GAAKA,EAAEpF,MAAQkD,EAAIlD,KACvDyF,GACHnS,KAAKoS,cAAcN,KAGzBzB,EAAM/M,OACNtD,KAAKgH,aAAatB,OAAO,UAAW,UAAW,2BAEjDwC,IACE1C,QAAQD,MAAM2C,GACdlI,KAAKgH,aAAatB,OAAO,QAAS,QAAS,0BAKjD2K,EAAMI,QAAQ4B,QAAQ9Q,UAAUA,KAC9BvB,KAAKyM,YAAY6F,QACjBtS,KAAKiN,QAAU,OAKnB,oBAAoB2C,GAClB,UACQ5P,KAAKwK,0BAA0B4H,cAAcxC,EAAIlD,KAAKlI,YAC5D,MAAO0D,GACP1C,QAAQD,MAAM2C,IAIlB,eACElI,KAAKuS,SAAW,GAChBvS,KAAKyM,YACFpG,IAAI,QACJ8C,SAASnJ,KAAKyM,YAAYpG,IAAI,QAAQlE,MAAMqQ,QAAQ,2BAA4B,KAGrF,WACE,IAAIC,EAAa,GAEjBzS,KAAKyM,YACFpG,IAAI,QACJqM,aAAaC,KACZ,OAAAC,EAAA,GAAa,KACb,OAAAC,EAAA,KACA,OAAAC,EAAA,GAAI3Q,GAAUsQ,EAAatQ,GAC3B,OAAA4Q,EAAA,GAAU5Q,GAASnC,KAAKgT,YAAY7Q,IACpC,OAAAwF,EAAA,GAAKsL,IACH,GAAIA,EAAK,CACP,GAAIjT,KAAKN,eAAgB,CACvB,MAAM,KAAE2R,EAAI,SAAEkB,GAAaU,EAC3B,GAAI5B,EAAM,CAER,GAAIA,EAAK3E,IACP,MAAO,CAAC2E,GAIV,GAAIA,EAAK5M,OAAS,EAChB,OAAO4M,EAKX,OAAOrR,KAAKkT,eAAeT,IAAcF,GAI3C,OAAIU,EAAIvG,IACC,CAACuG,GAINA,EAAIxO,OAAS,EACRwO,EAIFjT,KAAKkT,eAAeT,GAE3BzS,KAAKyM,YAAYpG,IAAI,OAAO8C,SAAS,QAGzC,OAAAgK,EAAA,GAAUnT,KAAKsM,YACf,OAAA8G,EAAA,IAAYlL,EAAKmL,KACf,IAAIC,EAAM,GAIV,OAHmB,MAAfpL,EAAIgC,SACNoJ,EAAMtT,KAAKkT,eAAeT,IAErBY,EAAOV,KAAK,OAAAY,EAAA,GAAUD,OAGhC/R,UAAUgR,IACTvS,KAAKuS,SAAWA,IAId,YAAYpQ,GAClB,OAAkC,MAA3BA,EAAMqR,MAAM,YAGb,YAAYrR,GAClB,IAAKA,GAASA,EAAMsC,OAAS,EAC3B,OAAO,OAAAgP,EAAA,GAAG,MAGZ,IAAKtR,GAASA,EAAMsC,OAAS,EAC3B,OAAO,OAAAgP,EAAA,GAAG,MAGZ,MAAMC,OAA6B,KAAkBC,UAAUxR,GAGzDyR,EAFc5T,KAAK6T,YAAYH,IAE4B,KAAlCA,EAAuBjP,OAEtD,OAAIzE,KAAKN,eACHkU,EAEK5T,KAAK0K,WAAWoJ,wBAAwBJ,GAAwBf,KACrE,OAAAhL,EAAA,GAAIsL,KAAU5B,KAAM4B,KACpB,OAAAF,EAAA,GAAUE,GACJA,EAAI5B,KAAK5M,OACJ,OAAAgP,EAAA,GAAGR,GAGLjT,KAAKyK,eACTsJ,gBAAgBL,GAChBf,KAAK,OAAAhL,EAAA,GAAIqM,KAAWzB,SAAUyB,QAMhChU,KAAKwK,0BAA0ByJ,QAAQ9R,GAAOwQ,KAAK,OAAAhL,EAAA,GAAIsL,KAAU5B,KAAM4B,MAG5EW,EACK5T,KAAKyK,eAAesJ,gBAAgBL,GAGtC1T,KAAKwK,0BAA0B0J,oBAAoB/R,EAAOnC,KAAKwN,KAAKd,KAGrE,eAAeyH,EAAqBC,GAAoB,GAC9D,MAAMzH,OAAU,KAAkBgH,UAAUQ,GACtCE,EAAgBrU,KAAK6T,YAAYlH,GAEvC,IAAK0H,EACH,OAAIrU,KAAKN,eACA,CACL,CACEiN,IAAK,KACL2H,SACE,uKAeV,GAAID,GAAgC,KAAf1H,EAAIlI,OAAe,CACtCzE,KAAK6L,WAAac,EAClB,IAAI2H,EAAW,oBAAoBH,0DASnC,OARInU,KAAKN,iBAEL4U,EADEF,EACS,gCAA6BD,qDAE7B,gCAA6BA,kDAIrC,CAAC,CAAExH,IAAK,KAAM2H,cAIzB,UAAUxI,GACR9L,KAAK8L,OAASA,EAIhB,uCACE,MAAMyI,QAAsBvU,KAAKwU,aAAaxU,KAAKkH,cACzB,qBAAtBlH,KAAKkH,aACPlH,KAAKgH,aAAatB,OAAO,UAAW,sCAAiC,IAErE1F,KAAKgH,aAAatB,OAAO,UAAW,GAAG1F,KAAKkH,kCAAmC,IAEjFlH,KAAKsK,OAAO6D,SAAS,CAAC,YAAaoG,EAAcvO,KAAM,SAIjD,mBAAmBkB,GACzB,IACE,MAAMuN,EAAMzU,KAAKwM,aAAakI,cACxBzH,EAAUjN,KAAKyM,YAAYtK,MAiBjC,IAAIoS,EACJ,OAjBIvU,KAAKN,eACP+U,EAAI7E,IAAM3C,EAEVwH,EAAIxH,QAAUA,EAGhBwH,EAAI/E,MAAQ1P,KAAK0P,MACjB+E,EAAIzO,KAAOhG,KAAK0B,UAAY1B,KAAK0B,SAASsE,KAE1CyO,EAAIjN,IAAMxH,KAAK2U,SAEX3U,KAAKgN,iBACPyH,EAAIG,gBAAkBH,EAAII,gBACnBJ,EAAII,UAIL3N,GACN,IAAK,mBACL,IAAK,2BACHqN,QAAsBvU,KAAK2K,oBACxBmK,KAAK,CAAElN,WAAY5H,KAAKwN,KAAKd,OAAQ+H,IACrC9B,KAAK,OAAAoC,EAAA,GAAK,IACVvQ,YACH+P,EAAcxP,KAAO/E,KAAKgN,eAAiB,qBAAuB,eAClEhN,KAAKiL,gBAAgBsD,qBAAuBvO,KAAKkH,aACjD,MACF,IAAK,WACHqN,QAAsBvU,KAAK4K,mBACxBkK,KAAK,CAAElN,WAAY5H,KAAKwN,KAAKd,OAAQ+H,IACrCjQ,YACH+P,EAAcxP,KAAO,cACrB/E,KAAKiL,gBAAgBsD,qBAAuBvO,KAAKkH,aACjD,MACF,IAAK,QACHqN,QAAsBvU,KAAK6K,YAAYiK,KAAK,CAAElN,WAAY5H,KAAKwN,KAAKd,OAAQ+H,IAAOjQ,YACnF+P,EAAcxP,KAAO,OACrB/E,KAAKiL,gBAAgBsD,qBAAuBvO,KAAKkH,aACjD,MACF,IAAK,SACH,IAAKlH,KAAKwM,aAAazK,MAGrB,OAFA/B,KAAKgH,aAAatB,OAAO,UAAW,QAAS,iDAC7C1F,KAAKsH,SAAU,EACR,KAETiN,QAAsBvU,KAAK8K,mBACxBgK,KAAK,CAAElN,WAAY5H,KAAKwN,KAAKd,OAAQ+H,IACrCjQ,YACH+P,EAAcxP,KAAO,cACrB/E,KAAKiL,gBAAgBsD,qBAAuBvO,KAAKkH,aACjD,MACF,QAGE,OAFA1B,QAAQwP,KAAK,0BAA2BhV,KAAKkH,cAC7ClH,KAAKsH,SAAU,EACR,KAEX,OAAOiN,EACP,MAAOrM,GAeP,MAdmB,MAAfA,EAAIgC,OACNlK,KAAKgH,aAAatB,OAChB,QACA,2BACAwC,EAAI3C,MAAMA,OAAS2C,EAAI3C,MAAMA,MAAM4B,SAGrCnH,KAAKgH,aAAatB,OAChB,QACA,OACA,uCAAuC1F,KAAKkH,gBAGhDlH,KAAKsH,SAAU,EACTY,GAIV,eACE,GAAIlI,KAAKwM,aAAanG,IAAI,QAAUrG,KAAKwM,aAAanG,IAAI,OAAOlE,MAAO,CACtE,MAAM8S,EAAYjV,KAAKwM,aAAanG,IAAI,OAAOlE,MAC/C,MAAO,IACF8S,EACHvN,MAAOuN,EAAUvN,MAAMC,IAAIxE,GAAQA,EAAKI,KAG5C,OAAO,KAIT,0BACE,GAAIvD,KAAKkH,eAAiBlH,KAAKiM,cAAc/H,aAC3ClE,KAAKkV,yBAAyB,gBAE9B,IACElV,KAAKsH,SAAU,EACf,MAAMiN,QAAsBvU,KAAKwU,aAAaxU,KAAKkH,oBAC7ClH,KAAKmV,WAAWZ,GACtB,MAAOrM,GACP1C,QAAQD,MAAM2C,G,QAEdlI,KAAKsH,SAAU,GAMb,iBAAiBiN,EAAoB5U,EAAS,IACpD,IACEK,KAAKsH,SAAU,EACf3H,EAAc,MAAIK,KAAKoL,aAAagK,iBAAiBzQ,WAC/C3E,KAAKiL,gBAAgBoK,mBAAmBd,EAAcvO,KAAMrG,GAClEK,KAAKsK,OAAO6D,SAAS,CAAC,YAAaoG,EAAcvO,KAAM,SACvD,MAAOkC,GACP1C,QAAQD,MAAM2C,GAEhBlI,KAAKsH,SAAU,EAIjB,uBACE,GAAItH,KAAKkH,eAAiBlH,KAAKiM,cAAc/H,aAC3ClE,KAAKkV,yBAAyB,YACzB,CACL,IACElV,KAAKsH,SAAU,EACf,MAAMiN,QAAsBvU,KAAKwU,aAAaxU,KAAKkH,cAEnDqN,EAAc7K,QAAU,aAClB1J,KAAKsV,QAAQf,GACnB,MAAOrM,GACP1C,QAAQD,MAAM2C,GAEhBlI,KAAKsH,SAAU,GAKX,eAAc,KAAEtB,EAAI,QAAE0D,GAAW/J,EAAS,IAChDA,EAAc,MAAIK,KAAKoL,aAAagK,iBAAiBzQ,KACrD,MAAM4Q,QAAYvV,KAAKiL,gBAAgBuK,qBAAqB,CAC1DxP,OACA0D,UACA9B,WAAY5H,KAAK4H,WACjBpB,UAAWxG,KAAKyM,YAAYtK,MAAMuK,IAClC/M,SACA8V,aAAczV,KAAKyV,eAErBC,OAAOC,SAASC,KAAOL,EAGjB,yBAAyBM,GAC/B,IAAI/V,GAA4B,EAE5BE,KAAKiN,UAELnN,EADEE,KAAKiN,QAAQqE,YACatR,KAAK8V,gCAEL9V,KAAKF,6BAIrCE,KAAK+V,kBAAkB9H,eAAenO,EAA2BE,KAAKN,gBAEtEM,KAAK+V,kBAAkBlW,aAAa8S,KAAK,OAAAoC,EAAA,GAAK,IAAIxT,UAAUA,MAAAyU,IAC1DhW,KAAKsH,SAAU,EACf,IACE,MAAM,OAAE3H,EAAM,aAAEuC,GAAiB8M,EACjC,GAAe,YAAXrP,GAAwBG,EAA2B,CACrD,MAAMmW,QAAuBjW,KAAKkW,qBAAqBhU,GACnDlC,KAAKiN,QAAQqE,YACftR,KAAKiN,QAAQqE,YAAc2E,EAE3BjW,KAAKiN,QAAUgJ,SAGZjH,EAAK9M,mBACNlC,KAAKmW,oCAAoCN,EAAQ7G,GACvD,MAAO9G,GACP1C,QAAQD,MAAM2C,GACdlI,KAAKsH,SAAU,KAKrB,iBACE,QAAItH,KAAKiN,QAAQmJ,aACRC,EAAA,EAAUC,WAAWtW,KAAKiN,QAAQmJ,aAKrC,4BACN,OACE,IAAEG,OAAOvW,KAAKiN,QAAQuJ,UACtB,IAAEC,YAAYzW,KAAKiN,QAAQuJ,UAC1BxW,KAAKiN,QAAQuJ,SACZ,IAAEE,QAAQ1W,KAAKiN,QAAQuJ,QAAQnV,MAC/B,IAAEqV,QAAQ1W,KAAKiN,QAAQuJ,QAAQxV,OAC/B,IAAE0V,QAAQ1W,KAAKiN,QAAQuJ,QAAQ1V,IAI7B,gCACN,OACE,IAAEyV,OAAOvW,KAAKiN,QAAQqE,cACtB,IAAEmF,YAAYzW,KAAKiN,QAAQqE,cAC3B,IAAEiF,OAAOvW,KAAKiN,QAAQqE,YAAYkF,UAClC,IAAEC,YAAYzW,KAAKiN,QAAQqE,YAAYkF,UACtCxW,KAAKiN,QAAQqE,YAAYkF,SACxB,IAAEE,QAAQ1W,KAAKiN,QAAQqE,YAAYkF,QAAQnV,MAC3C,IAAEqV,QAAQ1W,KAAKiN,QAAQqE,YAAYkF,QAAQxV,OAC3C,IAAE0V,QAAQ1W,KAAKiN,QAAQqE,YAAYkF,QAAQ1V,IAIjD,qBAAqBoB,GACnB,OAAO,IAAIyU,QAAQA,MAAOC,EAASC,KACjC,IACE,MACMC,GAD2B9W,KAAKiN,QAAQqE,YACHtR,KAAKiN,QAAUjN,KAAKiN,QAAQqE,YACjEyF,EAAc,IACfD,EACHN,QAAS,IACJtU,IAIP0U,QADsB5W,KAAKyK,eAAesH,OAAO+E,EAASpK,IAAKqK,GAAavS,aAE5E,MAAOe,GACPvF,KAAKgH,aAAatB,OAChB,QACA,QACA,gEAEF1F,KAAKsH,SAAU,EACfuP,EAAOtR,MAMb,0CAA0CsQ,EAAgB7G,GACxD,MAAMuF,QAAsBvU,KAAKwU,aAAaxU,KAAKkH,cACpC,YAAX2O,QACI7V,KAAKmV,WAAWZ,EAAevF,SAE/BhP,KAAKsV,QAAQf,EAAevF,GAI9B,mBAAmBgI,GACzB,MAAM7G,EAAe,CACnB6G,MACAC,OAAQ,IACRC,MAAO,MAGHxU,EAAW1C,KAAKT,aAAa+Q,KAAK,KAAsB,CAC5DH,eACAI,SAAU,SACVC,UAAU,IAEZ9N,EAAS+N,QAAQ0G,OAAO5V,UAAWgU,IACjC,GAAIA,EAAK,CACP7S,EAASY,OACT,IAAI8T,EAAU7B,EAAI/B,MAAM,gBAExB,GADgB4D,EAAQ,GACX,CACXA,EAAU7B,EAAI/B,MAAM,eACP4D,EAAQ,GACrBpX,KAAKqX,YACLrX,KAAKsK,OAAO6D,SAAS,CAAC,mBAI1BnO,KAAKsH,SAAU,IAInB,cACEtH,KAAKsM,WAAWgL,MAAK,GACrBtX,KAAKsM,WAAWiL,WAGlB,YAAY5S,GACV3E,KAAK0P,MAAQ1P,KAAK4H,WAAWsI,eAAepM,KAC1C0T,GAAMA,EAAG7S,KAAK8S,sBAAwB9S,EAAK8S,qBAI/C,mBAAmBvQ,GACjBlH,KAAKkH,aAAeA,EAChBlH,KAAK0B,WAAa1B,KAAK0B,SAAS6B,IAAMvD,KAAK0B,SAASgL,OACtD1M,KAAK0B,SAAW,KAChB1B,KAAK2O,sBAAwB,KAC7B3O,KAAKiL,gBAAgBwB,YAAczM,KAAKyM,YACxCzM,KAAKiL,gBAAgBsD,qBAAuBrH,EAC5ClH,KAAKwL,KAAKkM,IAAIA,KACZ1X,KAAKsK,OAAO6D,SAAS,CAAC,qBAK5B,kBACE,MAAMwJ,EAAM3X,KAAKwM,aAAarK,MAC9B,OAAInC,KAAK4H,YAAmD,iBAArC5H,KAAK4H,WAAWgQ,kBAElC5X,KAAKyM,YAAYtK,MAAMuK,MACvB1M,KAAKyM,YAAYtK,MAAMwC,OACvB3E,KAAKwM,aAAazK,OACU,IAA5B8V,OAAOC,KAAKH,GAAKlT,QAAgBkT,EAAII,cAAgBF,QACtD7X,KAAK+L,UACH/L,KAAK0O,SAKR1O,KAAKyM,YAAYtK,MAAMwC,OACvB3E,KAAKwM,aAAazK,OACU,IAA5B8V,OAAOC,KAAKH,GAAKlT,QAAgBkT,EAAII,cAAgBF,QACtD7X,KAAK+L,UACH/L,KAAK0O,QAIH,YACN1O,KAAKyM,YAAY6F,QACjBtS,KAAKwM,aAAa8F,QAClBtS,KAAK2O,sBAAwB,KAC7B3O,KAAKgM,QAAS,EAIhB,2BACE,IACEhM,KAAKsH,SAAU,EACf,MAAM0Q,QAAehY,KAAK+K,qBAAqBkN,aAAajY,KAAK4H,WAAWgQ,kBAC5E5X,KAAKsH,SAAU,EAEDtH,KAAKT,aAAa+Q,KAAK,IAAiC,CACpEH,aAAc,CAAE6H,UAChBzH,SAAU,WAGNE,QAAQ3N,YAAYvB,UAAU2W,IAClClY,KAAK2O,sBAAwBuJ,EAC7BlY,KAAKgM,QAAS,IAEhB,MAAO9D,GACPlI,KAAKsH,SAAU,EACftH,KAAKgH,aAAatB,OAAO,UAAW,QAAS,gDAKjD,sCACE,IACE1F,KAAKsH,SAAU,EACf,MAAM6Q,QAA0BnY,KAAKoY,4BAGrC,GAFApY,KAAKsH,SAAU,EAEX6Q,EAAkB1T,OAAQ,CAC5B,MAAM0L,EAAe,CACnBjJ,aAAclH,KAAKkH,aACnBiR,qBAEFnY,KAAKqY,+BAA+BlI,QAEpCnQ,KAAKgH,aAAatB,OAChB,UACA,QACA,0CAAoC1F,KAAKkH,2DAG7C,MAAOgB,GACPlI,KAAKsH,SAAU,EACftH,KAAKgH,aAAatB,OAAO,UAAW,QAAS,wDAIzC,+BAA+ByK,GACrC,MAAME,EAAQrQ,KAAKT,aAAa+Q,KAAK,KAAoC,CACvEH,eACAI,SAAU,WAEZF,EAAMI,QAAQ3N,YAAYvB,UAAU+W,IAClCtY,KAAK2O,sBAAwB2J,EAC7BtY,KAAKgM,QAAS,IAGhBqE,EAAMI,QAAQ1N,UAAUxB,UAAU+W,IAChCtY,KAAKiL,gBAAgBwB,YAAczM,KAAKyM,YACxC6L,EAAM5W,SAAW4W,EAAM5W,UAAY,eACnC1B,KAAKsK,OAAO6D,SAAS,CAAC,kBAAmBmK,EAAM5L,IAAK4L,EAAM5W,SAAU,WAGtE2O,EAAMI,QAAQzN,YAAYzB,UAAWmN,IACnC2B,EAAM/M,OACNtD,KAAKmL,eAAeoN,QAAQ,CAC1BC,QAAS,gBACTrY,UAAW,iDAAiDH,KAAKkH,6BACjExG,OAAQsV,UACN,UACQhW,KAAKyY,oBAAoB/J,GAC/B1O,KAAKgH,aAAatB,OAAO,UAAW,UAAW,kCAC/C,MAAOwC,GACPlI,KAAKgH,aAAatB,OAAO,UAAW,QAAS,8CAGjD/E,WAAY,IAAMX,KAAKqY,+BAA+BlI,OAMpD,0BAA0BzB,GAChC,OAAQ1O,KAAKkH,cACX,KAAKlH,KAAKiD,iBAAiB,SACnBjD,KAAK4G,yBAAyB8R,WAAWhK,GAC/C,MACF,KAAK1O,KAAKiD,iBAAiB,SACnBjD,KAAK8G,iBAAiB4R,WAAWhK,GACvC,MACF,KAAK1O,KAAKiD,iBAAiB,SACnBjD,KAAK+G,wBAAwB2R,WAAWhK,GAC9C,MACF,KAAK1O,KAAKiD,iBAAiB,SACnBjD,KAAK6G,wBAAwB6R,WAAWhK,IAM5C,kCACN,IAAIyJ,EAAoB,GACxB,OAAQnY,KAAKkH,cACX,KAAKlH,KAAKiD,iBAAiB,GACzBkV,QAA0BnY,KAAK4G,yBAAyB+R,sBACtD3Y,KAAK4H,WAAWC,QAElB,MACF,KAAK7H,KAAKiD,iBAAiB,GACzBkV,QAA0BnY,KAAK8G,iBAAiB6R,sBAAsB3Y,KAAK4H,WAAWC,QACtF,MACF,KAAK7H,KAAKiD,iBAAiB,GACzBkV,QAA0BnY,KAAK+G,wBAAwB4R,sBACrD3Y,KAAK4H,WAAWC,QAElB,MACF,KAAK7H,KAAKiD,iBAAiB,GACzBkV,QAA0BnY,KAAK6G,wBAAwB8R,sBACrD3Y,KAAK4H,WAAWC,QAKtB,OAAOsQ,EAAkB5R,OAAOqS,GAAiD,SAA7BA,EAAiBlP,SAGvE,+BACE,GAAI1J,KAAKwM,aAAazK,MAAO,CAC3B/B,KAAKwM,aAAarK,MAAMyF,WAAa5H,KAAK4H,WAAWC,OACrD,MAAMsI,EAAe,CACnB1I,cAAezH,KAAKwM,aAAarK,MACjC+E,aAAclH,KAAKkH,cAErBlH,KAAKT,aAAa+Q,KAAK,KAAmC,CACxDc,MAAO,WACPjB,eACAI,SAAU,SACVC,UAAU,QAEP,CACL,MAAMqI,EAAM7Y,KAAK8Y,aAAa9Y,KAAKkH,cACnClH,KAAKgH,aAAatB,OAAO,UAAW,QAASmT,IAKjD,0BAA0BP,EAAY5J,GACpC,IACE,IAAIqK,EAAa,KAEjB,OAAQ/Y,KAAKkH,cACX,KAAKlH,KAAKiD,iBAAiB,GACzB8V,QAAmB/Y,KAAK6G,wBAAwBkL,OAAOuG,EAAO5J,GAC9D,MACF,KAAK1O,KAAKiD,iBAAiB,GACzB8V,QAAmB/Y,KAAK+G,wBAAwBgL,OAAOuG,EAAO5J,GAC9D,MACF,KAAK1O,KAAKiD,iBAAiB,GACzB8V,QAAmB/Y,KAAK8G,iBAAiBiL,OAAOuG,EAAO5J,GACvD,MAEF,QACEqK,QAAmB/Y,KAAK4G,yBAAyBmL,OAAOuG,EAAO5J,GAGnE1O,KAAK2O,2BAAwBqK,EAC7BhZ,KAAK0O,aAAUsK,EAEfhZ,KAAKgH,aAAatB,OAAO,UAAW,UAAW,4BAC/C1F,KAAKsK,OAAO6D,SAAS,CAAC,kBACtB,MAAOjG,GACP1C,QAAQD,MAAM2C,GACdlI,KAAKgH,aAAatB,OAAO,QAAS,QAAS,6BAI/C,kBACE1F,KAAKsK,OAAO6D,SAAS,CAAC,kBAGxB,8BAEE,MAAuB,0BADRnO,KAAKoL,aAAagK,iBACnBzQ,KAGR,aAAauC,GACnB,OAAQA,GACN,IAAK,mBACH,MAAO,qEACT,IAAK,QACH,MAAO,sDACT,QACE,MAAO,sCAIb,wBAAwBhD,GACtB,UAAW,MAAMC,KAAcD,EAAaE,YAC1C,GAAMD,EAAWE,IAAK,CACpBrE,KAAKkD,yBAA0B,EAC/B,IACE,MAAMoB,QAAsBtE,KAAK2C,UAAU4B,iBAAiBJ,EAAWE,KAAKG,YAC5E,GAAIF,EAAcG,OAAS,EAAG,CAC5B,MAAMC,EAAeJ,EAAc,GACnCH,EAAWQ,KAAOD,EAAaE,KAC/BT,EAAWU,mBAAqBH,EAAaG,mBAC7CV,EAAWW,OAASJ,EAAaI,OACjCX,EAAWY,KAAO,iBAClBZ,EAAWa,WAAaN,EAAaO,YACrCd,EAAWe,YAAcR,EAAaS,wBACtChB,EAAWiB,aAAeV,EAAanB,GACvCY,EAAWkB,UAAYX,EAAaY,WAEtC,MAAOC,GACPC,QAAQC,IAAIF,GACZvF,KAAKgH,aAAatB,OAAO,QAAS,2C,QAElC1F,KAAKkD,yBAA0B,QAGjCiB,EAAWY,KAAO,YAKxB,wBACE/E,KAAKiN,QAAU,KACfjN,KAAKyM,YAAY6F,U,6BA7tCI,K,MAAhB,K,MADA,K,MAKA,K,MACA,K,MAqCA,K,MAvCA,K,MA0CA,M,MATA,K,MAcA,M,MAZA,K,MALA,K,MAEA,K,MAEA,K,MAEA,K,MA1BA,K,MAZA,K,MAiCA,K,MA5BA,K,MAaA,K,MADA,K,MAHA,K,MAbA,K,MAXP,K,MAuBO,K,MApBP,K,MA2DO,O,qCAsDN,KAAS,MAAC,gB,kCAGV,KAAS,MAAC,IAA4B,CAAE/P,QAAQ,M,yBAGhD,KAAS,MAAC,KAA4B,CAAEA,QAAQ,M,mBAGhD,KAAS,MAAC,KAAsB,CAAEA,QAAQ,M,gBAK1C,IAAY,MAAC,gBAAiB,CAAC,cA4ChC,SAAA0W,EAAA,EADCC,GAAA,E,gJAiJD,aADCA,GAAA,E,wJAqMD,SAAAD,EAAA,EADCC,GAAA,E,qEACwB,M,6EAsKzB,SAAAD,EAAA,EADCC,GAAA,E,sKAYD,aADCA,GAAA,E,0JA6FD,SAAAD,EAAA,EADCC,GAAA,E,yJAkBD,aADCA,GAAA,E,+JAcD,SAAAD,EAAA,EADCC,GAAA,E,sJAmBD,aADCA,GAAA,E,4JAyGD,SAAAD,EAAA,EADCC,GAAA,E,wLA6FD,SAAAD,EAAA,EADCC,GAAA,E,0JAuBD,SAAAD,EAAA,EADCC,GAAA,E,qKA6DD,aADCA,GAAA,E,iKAmBD,aADCA,GAAA,E,iKA+CD,SAAAD,EAAA,EADCC,GAAA,E,wKArkCU,GAAiB,aAL7B,YAAU,CACT1W,SAAU,eACVC,SC9Ea,i1T,QCAA,02R,iCF0IK,IACD,IACH,IACuB,IACX,IACJ,IACS,IACD,KACP,IACO,KACM,IACD,IACP,IACO,IACH,IACR,IACD,IACI,IACU,IACb,IACE,IACF,IACD,IACR,IACS,IACR,IACK,QAnFV,I,IG1EA0W,GAAa,MACxB,YAAoB7O,EAAwBU,GAAxB,KAAAV,SAAwB,KAAAU,cAE5C,YAAYT,EAA+B6O,GACzC,MACMC,EAAiC,uBAD1BrZ,KAAKgL,YAAYwC,OACJ8L,SAI1B,OAHKD,GACHrZ,KAAKsK,OAAO6D,SAAS,CAAC,KAEjBkL,I,6BAfmC,K,MACrC,MAKIF,GAAa,aAHzB,YAAW,CACVxS,WAAY,S,iCAGgB,IAA6B,OAD9CwS,ICPE,I,wDCsBF,GAAqB,MAahC,YACU7O,EACAC,EACAS,EACAL,EACA3D,EACAuS,EACAha,EACAia,EACAC,EACA9W,EACAC,GAVA,KAAA0H,SACA,KAAAC,QACA,KAAAS,cACA,KAAAL,sBACA,KAAA3D,eACA,KAAAuS,kBACA,KAAAha,eACA,KAAAia,MACA,KAAAC,SACA,KAAA9W,YACA,KAAAC,QAvBV,KAAA8W,WAAa,EACb,KAAAC,YAAa,EACb,KAAAC,eAAgB,EAChB,KAAA1V,aAA6B,IAAI,KAGjC,KAAA2V,WAAa,GAEb,KAAAvS,SAAU,EAiBR,MAAM8R,EAAQpZ,KAAKsK,OAAOwP,uBAAuBC,OAAOX,MACpDA,IACFpZ,KAAKkE,aAAekV,EAAMlV,aAC1BlE,KAAKga,iBAAmBha,KAAKkE,aAAa8B,MAK9C,iBACEhG,KAAKsH,SAAU,EAEftH,KAAKuK,MAAMjE,OAAO/E,UAAU+E,IAC1BtG,KAAKga,iBAAmB1T,EAAc,cAElCtG,KAAKia,kBAEXja,KAAKkE,mBAAqBlE,KAAK2K,oBAC5BuP,sBAAsBla,KAAKga,kBAC3BxV,YAEHxE,KAAKqD,oBAELrD,KAAK6Z,WAAa7Z,KAAKma,uBACnBna,KAAKkE,aAAa0Q,gBAAgBjN,IAAImB,GAAKA,EAAEsR,mBAC7Cpa,KAAKkE,aAAaE,YAAYuD,IAAImB,GAAKA,EAAEsR,mBAC7Cpa,KAAKsH,SAAU,EAGjB,kBACEtH,KAAKwZ,IAAIhL,gBAGX,WACE,OAAOxO,KAAKgL,YAAYwC,OAG1B,6BACE,OAAOxN,KAAKwN,MAAQxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,kBAAXA,EAAEpK,MAGrD,gBACE,MAAM0V,EAAQra,KAAKma,uBACfna,KAAKkE,aAAa0Q,gBAClB5U,KAAKkE,aAAaE,YAChBuV,EAAaU,EAAMC,MAAMnY,IAAyB,IAAhBA,EAAMJ,OACxCwY,EAAeF,EAAMC,MAAMnY,IAAUA,EAAMJ,OACjD/B,KAAK2Z,WAAaA,EAClB3Z,KAAK4Z,eAAiBD,IAAeY,EACrCva,KAAKwa,cAAgBH,EAAM9T,OAAOpE,GAASA,EAAMJ,OAAO0C,OAIlD,wBACN,IACEzE,KAAKsH,SAAU,EAGf,GACO,aAHUtH,KAAKwN,KAAK8L,SAIvBtZ,KAAKya,mBAAqBza,KAAKuZ,gBAAgBmB,oBAAoB1a,KAAKwN,KAAKd,KAAKlI,YAClFxE,KAAK2a,WAAa3a,KAAKya,aAAa/N,QAEtC,CACE,MAAMkO,EAAY1N,KAAKC,MAAMC,aAAaC,QAAQ,eAClDrN,KAAK2a,WAAaC,EAAUD,WAGhC3a,KAAKsH,SAAU,EACf,MAAO/B,GACPvF,KAAKsH,SAAU,EACf9B,QAAQC,IAAIF,IAIhB,SAASpD,IACOnC,KAAKma,uBACfna,KAAKkE,aAAa0Q,gBAClB5U,KAAKkE,aAAaE,aAEhByE,QAAQmG,IACZA,EAAKjN,MAAQI,IAEfnC,KAAK6a,gBAGP,iBACE,OAAI7a,KAAKkE,aAAayL,oBAAsB3P,KAAKkE,aAAayL,mBAAmBmL,YACxE9a,KAAKkE,aAAayL,mBAAmBmL,YAAYnT,IAAIoT,GAAKA,EAAE1R,OAAO2R,KAAK,MAE1E,CAAC,4CAGV,WACE,MAGMC,GAHQjb,KAAKma,uBACfna,KAAKkE,aAAa0Q,gBAClB5U,KAAKkE,aAAaE,aACUmC,OAAOuC,GAAKA,EAAE/G,OACb,IAA7BkZ,EAAkBxW,OACpBzE,KAAKgH,aAAatB,OAAO,UAAW,QAAS,4BAE7C1F,KAAKma,uBACDna,KAAKkb,sBAAsBlb,KAAKkE,aAAayL,mBAAmBhD,IAAKsO,GACrEjb,KAAKmb,mBAAmBF,GAIhC,mBAAmBA,GACjB,MAAM5K,EAAQrQ,KAAKT,aAAaW,OAAgC,CAC9DC,UAAW,KACXib,kBAAmB,CACjBnO,QAASjN,KAAKkE,aAAa+I,SAE7B5M,SAAU,KACVG,QAAS,MAEXR,KAAKyZ,OAAO/B,IAAIA,KACdrH,EAAM/O,UAAUqR,KAAK,OAAAE,EAAA,MAAwBtR,UAAUA,KACrD,MAAM8Z,EAAWhL,EAAMiL,sBACnBD,GACFA,EAASE,cAAcha,UAAUoL,IAC/B3M,KAAKkb,sBAAsBvO,EAAKsO,GAChC5K,EAAMjO,cAOhB,sBAAsBoZ,EAAkBP,GACtC,MAAMtO,EAAM6O,EAAShJ,QAAQ,UAAW,IACxCxS,KAAKuY,QAAQ5L,EAAKsO,GAGpB,QAAQO,EAAkBP,GACxB,MAAMQ,EAAY,CAChBD,WACAP,qBAGFjb,KAAK2K,oBACF4N,QAAQkD,EAAWzb,KAAK2a,WAAY3a,KAAKga,kBACzClS,KAAMmL,IACDA,EAAI1N,MACNvF,KAAKgH,aAAatB,OAAO,UAAW,QAASuN,EAAI9L,SAEjDnH,KAAKsK,OAAO6D,SAAS,CAAC,oCAAoC8E,EAAIyI,uBAKtE,cACEhG,OAAOC,SAASC,KAAO,aAGzB,wBAAwB1R,GACtBlE,KAAK2K,oBAAoBgR,wBAAwBzX,EAAa8B,MAGhE,0BACE,OAAO,KAAmB4V,wBACxB5b,KAAKkE,aAAayL,mBAAmBiI,kBAIzC,0BACE,UAAW,MAAMzT,KAAcnE,KAAKkE,aAAaE,YAC/C,GAAMD,EAAWE,IACf,IACE,MAAMC,QAAsBtE,KAAK2C,UAAU4B,iBAAiBJ,EAAWE,KAAKG,YAC5E,GAAIF,EAAcG,OAAS,EAAG,CAC5B,MAAMC,EAAeJ,EAAc,GACnCH,EAAWQ,KAAOD,EAAaE,KAC/BT,EAAWU,mBAAqBH,EAAaG,mBAC7CV,EAAWW,OAASJ,EAAaI,OACjCX,EAAWY,KAAO,iBAClBZ,EAAWa,WAAaN,EAAaO,YACrCd,EAAWe,YAAcR,EAAaS,wBACtChB,EAAWiB,aAAeV,EAAanB,GACvCY,EAAWkB,UAAYX,EAAaY,WAEtC,MAAOC,GACPC,QAAQC,IAAIF,GACZvF,KAAK4C,MAAM8C,OAAO,QAAS,gDAG7BvB,EAAWY,KAAO,c,6BAvOD,K,MAAhB,K,MACA,K,MASA,K,MAFA,K,MANA,M,MAOA,K,MAVe,K,MAA8B,K,MAc7C,M,MALA,MA8CP,SAAAkU,EAAA,EADCC,GAAA,E,gJA6CD,aADCA,GAAA,E,uJA7EU,GAAqB,aALjC,YAAU,CACT1W,SAAU,mBACVC,SDnBa,6lO,QEAA,qgF,iCDoCK,IACD,IACM,IACQ,IACP,IACG,KACH,IACT,IACG,IACG,KACJ,OAxBN,IEtBE,I,iBCaF,GAAgB,MAQ3B,YACU6H,EACAC,EACAI,EACA3D,GAHA,KAAAsD,SACA,KAAAC,QACA,KAAAI,sBACA,KAAA3D,eAXV,KAAA6U,aAAc,EACd,KAAAC,aAAc,EAEd,KAAAC,qBAA+B,EAC/B,KAAAC,eAAyB,EACzB,KAAAC,gBAA0B,EAQxB,MAAM7C,EAAQpZ,KAAKsK,OAAOwP,uBAAuBC,OAAOX,MACpDA,IACFpZ,KAAKkc,cAAgB9C,EAAM8C,eAI/B,WACOlc,KAAKkc,eACRlc,KAAKuK,MAAMjE,OAAO/E,UAAU+E,IAC1B,MAAM6V,EAAQ7V,EAAc,MAC5BtG,KAAKoc,SAASD,KAKZ,SAASA,GACfnc,KAAK2K,oBAAoB0R,wBAAwBF,GAAO5a,UAAU2a,IAChElc,KAAKkc,cAAgBA,IAIzB,YAAYlC,GACVha,KAAKsK,OAAO6D,SAAS,CAAC,yBAA0B6L,IAChDha,KAAKgH,aAAatB,OAChB,UACA,gBACA,wFAIJ,wBAAwBkS,GACtB,OAAO,KAAmBgE,wBAAwBhE,K,6BAzD7B,K,MAAhB,K,MAIA,K,MADA,MASI,GAAgB,aAL5B,YAAU,CACTpV,SAAU,cACVC,SDVa,gqE,QEAA,6nB,iCDsBK,IACD,IACc,IACP,OAZb,IEbE,I,8BCUF6Z,GAAkB,MAC7B,YAAoBC,EAAgCjS,GAAhC,KAAAiS,aAAgC,KAAAjS,SAKpD,WAAWwC,GACT,MAAM0P,EAAqB1P,EAAM2P,OAAOC,MACxC1c,KAAKsK,OAAOhE,OAAO/E,UAAUA,MAAAyU,IAC3B,MAAMhQ,EAAOM,EAAa,KAC1B,GAAIkW,EAAS/X,OAAS,EAAG,CACvB,MAAMkY,EAAaH,EAAS,SACtBxc,KAAKuc,WAAWK,YAAYD,EAAM3W,GACxChG,KAAK6c,0BAA0B5O,eAAejI,Q,6BAtB7C,M,MAEA,M,oDAUN,KAAS,MAAC,KAAoC,CAAEzD,QAAQ,OAH9C+Z,GAAkB,aAL9B,YAAU,CACT9Z,SAAU,iBACVC,SDPa,s9B,QEAA,0V,iCDWmB,KAA4B,OADjD6Z,IEVE,I,8BCYFQ,GAAoB,MAC/B,YACUxS,EACD5H,EACCsE,EACA2D,GAHA,KAAAL,SACD,KAAA5H,WACC,KAAAsE,eACA,KAAA2D,sBAGV,YAEA,OAAOwR,GAES,MADdA,OAAkBnD,IAAVmD,EAAsB,GAAKA,EAAM3J,QAAQ,eAAgB,MAE/DxS,KAAK0C,SAASY,OACdtD,KAAKgH,aAAatB,OAAO,UAAW,gBAAW,iDACrB,KAAjByW,EAAM1X,QAAkC,KAAjB0X,EAAM1X,OACtCzE,KAAKoc,SAASD,IAEdnc,KAAK0C,SAASY,OACdtD,KAAKgH,aAAatB,OAAO,UAAW,gBAAW,iCAK3C,eAAeyW,GACrB,IACE,MAAMD,QAAsBlc,KAAK2K,oBAAoB0R,wBAAwBF,GAAO3X,YAEpF,GAAqB,KAAjB2X,EAAM1X,OAAe,CACvB,GAA6B,IAAzByX,EAAczX,OAMhB,YALAzE,KAAKgH,aAAatB,OAChB,UACA,gBACA,6FAKJ1F,KAAKsK,OAAO6D,SAAS,CAAC,uCAAwCgO,GAAQ,CACpE/C,MAAO,CAAE8C,cAAeA,UAG1Blc,KAAKsK,OAAO6D,SAAS,CAAC,6BAA8BgO,GAAQ,CAC1D/C,MAAO,CAAElV,aAAcgY,KAG3Blc,KAAK0C,SAASY,OACd,MAAOiC,GACPvF,KAAK0C,SAASY,OACO,MAAjBiC,EAAM2E,QACRlK,KAAKgH,aAAatB,OAAO,UAAW,gBAAWH,EAAMA,MAAM4B,Y,6BA7D1D,K,MAEA,K,MADA,K,MAEA,MAgCP,aADC+R,GAAA,E,sJAvBU4D,GAAoB,aALhC,YAAU,CACTta,SAAU,mBACVC,SCTa,4jB,QCAA,opB,iCFcK,IACC,IACK,IACO,OALpBqa,I,IGKA,GAA8B,MAMzC,YACUxS,EACAC,EACAhL,EACAwd,EACAC,EACAhS,GALA,KAAAV,SACA,KAAAC,QACA,KAAAhL,eACA,KAAAwd,mBACA,KAAAC,eACA,KAAAhS,cAGV,WACEhL,KAAKuK,MAAMjE,OAAO/E,UAAU+E,IAC1B,MAAMoV,EAAmBpV,EAAyB,iBAClDtG,KAAK+c,iBAAiBE,mBAAmBvB,GAAkBna,UAAUka,IACnEzb,KAAKyb,UAAYA,EACjBzb,KAAKkd,+BAGHld,KAAKyb,UAAUvX,aAAa+I,SAC5BjN,KAAKyb,UAAUvX,aAAa+I,QAAQN,MAAQ3M,KAAKyb,UAAUD,UAE3Dxb,KAAKmd,MAAQ,IAAI,KACjBnd,KAAKmd,MAAMxY,KAAO3E,KAAKyb,UAAUvX,aAAa+I,QAAQtI,KACtD3E,KAAKmd,MAAMxQ,IAAM3M,KAAKyb,UAAUvX,aAAa+I,QAAQN,IACrD3M,KAAKmd,MAAM3G,QAAUxW,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QACzDxW,KAAKmd,MAAMC,UAAYpd,KAAKyb,UAAUvX,aAAa+I,QAAQmQ,UAC3Dpd,KAAKmd,MAAME,UAAYrd,KAAKyb,UAAUvX,aAAa+I,QAAQoQ,UAC3Drd,KAAKmd,MAAMG,SAAWtd,KAAKyb,UAAUvX,aAAa+I,QAAQqQ,UAE1Dtd,KAAKgd,aAAaO,cAAcvd,KAAKyb,UAAUD,UAAUja,UAAU4b,IACjEnd,KAAKmd,MAAQA,QAOvB,WACE,OAAOnd,KAAKgL,YAAYwC,OAG1B,6BACE,OAAOxN,KAAKwN,MAAQxN,KAAKwN,KAAKqB,SAASC,KAAKC,GAAgB,kBAAXA,EAAEpK,MAGrD,YACE,OAAOwK,QAAQnP,KAAKyb,WAAazb,KAAKyb,UAAUvX,aAAa0L,KAG/D,iBACE,OAAOT,QACLnP,KAAKyb,WACHzb,KAAKyb,UAAUvX,aAAa+I,SAC5BjN,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,WAClC,IAAEE,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQnV,OACrD,IAAEqV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQxV,QACtD,IAAE0V,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQvV,cACtD,IAAEyV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQpV,gBACtD,IAAEsV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQtV,UACtD,IAAEwV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQrV,UACtD,IAAEuV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQuJ,QAAQ1V,MAI/D,4BACE,OAAOqO,QACLnP,KAAKyb,WACHzb,KAAKyb,UAAUvX,aAAa+I,SAC5BjN,KAAKyb,UAAUvX,aAAa+I,QAAQqE,aACpCtR,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,WAC9C,IAAEE,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQnV,OACjE,IAAEqV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQxV,QAClE,IAAE0V,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQvV,cAClE,IAAEyV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQpV,gBAClE,IAAEsV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQtV,UAClE,IAAEwV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQrV,UAClE,IAAEuV,QAAQ1W,KAAKyb,UAAUvX,aAAa+I,QAAQqE,YAAYkF,QAAQ1V,MAI3E,oBACE,OAAOqO,QACLnP,KAAKyb,WACHzb,KAAKyb,UAAUvX,aAAa0L,KAC5B5P,KAAKyb,UAAUvX,aAAa0L,IAAI0B,aAChCtR,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,WAC1C,IAAEE,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQnV,OAC7D,IAAEqV,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQxV,QAC9D,IAAE0V,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQvV,cAC9D,IAAEyV,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQpV,gBAC9D,IAAEsV,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQtV,UAC9D,IAAEwV,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQrV,UAC9D,IAAEuV,QAAQ1W,KAAKyb,UAAUvX,aAAa0L,IAAI0B,YAAYkF,QAAQ1V,MAIvE,+BACE,IAAK,MAAM0c,KAAsBxd,KAAKyb,UAAUrX,YAAa,CAC3D,MAAMD,EAAanE,KAAKyb,UAAUvX,aAAaE,YAAYmC,OACzDuC,GAAKA,EAAEzE,MAAQmZ,EAAmBnZ,KAClC,GACEF,IACFqZ,EAAmB7Y,KAAOR,EAAWQ,KACrC6Y,EAAmBnY,UAAYlB,EAAWkB,UAC1CmY,EAAmB3T,OAAS1F,EAAW0F,SAK7C,iBAAiB3F,GACf,MAAMuZ,EAAY,CAChB9Y,KAAM,GACNgI,IAAK,GACL5I,MAAO,GACP2Z,gBAAiB,CAAE3Z,MAAO,GAAI7C,OAAQ,EAAGJ,GAAI,IAC7Cga,YAAa,GACb6C,QAAS,IAeX,OAbIzZ,IACFuZ,EAAU1Z,MAAQ,KAAmB6X,wBACnC1X,EAAayL,mBAAmBiI,kBAElC6F,EAAU9Y,KAAOT,EAAayL,mBAAmBhL,KACjD8Y,EAAU9Q,IAAMzI,EAAayL,mBAAmBhD,IAChD8Q,EAAUC,gBAAgB3Z,MAAQ,KAAmB6Z,wBACnD1Z,EAAayL,mBAAmBiI,kBAElC6F,EAAUC,gBAAgBxc,OAASgD,EAAayL,mBAAmBkO,sBAAsB3c,OACzFuc,EAAUC,gBAAgB5c,GAAKoD,EAAayL,mBAAmBkO,sBAAsB/c,IAGhF2c,EAGT,gBACE,QAAuBzE,IAAnBhZ,KAAKyb,UAAyB,CAChC,MAAMrF,EAAcpW,KAAKkO,MACrBlO,KAAKyb,UAAUvX,aAAa0L,IAAIwG,YAChCpW,KAAKyb,UAAUvX,aAAa+I,QAAQmJ,YAClC0H,EAAa,IAAIpS,KAAK0K,GACtB2H,EAAO,IAAIrS,KACjB,IAAIsS,EAAgBD,EAAKE,cAAgBH,EAAWG,cAOpD,OALE,IAAIvS,KAAKqS,EAAKE,cAAeF,EAAKG,WAAYH,EAAKI,WACnD,IAAIzS,KAAKqS,EAAKE,cAAeH,EAAWI,WAAYJ,EAAWK,YAE/DH,IAEKA,EAET,OAAO,EAGT,cACEhe,KAAKsK,OAAO6D,SAAS,CAAC,6BAA6BnO,KAAKyb,UAAUvX,aAAa8B,SAGjF,uBACEhG,KAAK0C,SAASY,OACd,MAAM0W,EAAsCtY,SAAS0c,eAAe,oBAAqBjc,MACzFiL,aAAaiR,QAAQ,mBAAoBrE,GACzCha,KAAKsK,OAAO6D,SAAS,CAAC,8BAA8B6L,MAGtD,uBAAuB9V,GACDA,EAAaE,YACfF,EAAauX,UAGjC,YACEzb,KAAK0C,SAAW1C,KAAKT,aAAa+Q,KAAKwM,GAAsB,CAC3DvM,SAAU,SACVC,UAAU,IAId,YAAYjG,GACVvK,KAAKsK,OAAO6D,SAAS,CAAC,IAAI5D,Q,6BAtML,K,MAAhB,K,MAMY,K,MAEZ,M,MADA,M,MANA,MAeI,GAA8B,aAL1C,YAAU,CACT/H,SAAU,6BACVC,SJda,8zS,QKAA,02F,iCDwBK,IACD,IACO,IACI,KACJ,KACD,OAZZ,IERb,MAAM6b,GAAiB,CACrB,CACExO,KAAM,MACNyO,UAAW,GACXC,YAAa,CAACrF,KAEhB,CAAErJ,KAAM,UAAWyO,UAAW,GAAmBC,YAAa,CAACrF,KAC/D,CAAErJ,KAAM,WAAYyO,UAAW,GAAmBC,YAAa,CAACrF,KAChE,CACErJ,KAAM,oCACNyO,UAAW,GACXC,YAAa,CAACrF,KAEhB,CAAErJ,KAAM,sBAAuByO,UAAW,IAC1C,CAAEzO,KAAM,4CAA6CyO,UAAW,IAChE,CAAEzO,KAAM,+BAAgCyO,UAAW,IACnD,CAAEzO,KAAM,mBAAoByO,UAAWjC,K,IAO5BmC,GAAuB,QAAvBA,GAAuB,aAJnC,YAAS,CACRC,QAAS,CAAC,IAAaC,SAASL,KAChCM,QAAS,CAAC,QAECH,I,cCpBA,GAAoB,MAc/B,YAAoBjf,EAAyBwH,GAAzB,KAAAxH,KAAyB,KAAAwH,eAVpC,KAAAtH,gBAAiB,EAChB,KAAAmf,YAAuC,IAAI,IAC3C,KAAAC,gCAAkC,IAAI,IAEhD,KAAAC,eAAgB,EAChB,KAAAC,iBAAkB,EAClB,KAAAC,aAAc,EAKZjf,KAAKkf,gBAAkBlf,KAAKR,GAAGqB,MAAM,CACnCqE,YAAa,CAAC,GAAI,IAAWnE,UAC7Boe,eAAgB,EAAC,GACjBvf,kBAAmB,EAAC,GACpB8J,QAAS,CAAC,UAId,WACE1J,KAAKof,OAGP,OACMpf,KAAK+F,cACP/F,KAAKgf,gBACHhf,KAAK+F,YAAYb,aAAelF,KAAK+F,YAAYb,YAAY8V,KAAK,MAAMvW,OAAS,EACnFzE,KAAK+e,gBAAkB/e,KAAK+F,YAAYnC,mBAAqB5D,KAAK+F,YAAY/B,eAC1EhE,KAAK+e,eACP/e,KAAKqf,8BAEPrf,KAAKif,YAAcjf,KAAK+F,YAAYyB,KAAOxH,KAAK+F,YAAYyB,IAAIE,MAAMjD,OAAS,GAEjFzE,KAAK6e,YAAY5c,KAAKjC,KAAKkf,iBAG7B,qBACqBI,GACfA,IACFtf,KAAK+F,YAAcuZ,EACnBtf,KAAKkf,gBAAgBK,WAAW,QAASvf,KAAKR,GAAGggB,QAAQ,KACzDxf,KAAKkf,gBAAgB7Y,IAAI,SAAS8C,SAASmW,EAAiBjW,OAC5DrJ,KAAKof,QAIT,4BAA4Bjd,GAC1BnC,KAAK+e,cAAgB5c,EACjBnC,KAAK+e,gBAAkB/e,KAAKgf,iBAC9Bhf,KAAKkf,gBAAgB7Y,IAAI,eAAeoZ,kBACxCzf,KAAKkf,gBAAgB7Y,IAAI,eAAeqZ,UAAU,QAElD1f,KAAKkf,gBAAgB7Y,IAAI,eAAesZ,cAAc,CAAC,IAAW5e,WAClEf,KAAK+F,YAAc,MAErB/F,KAAKkf,gBAAgB7Y,IAAI,eAAeuZ,yBACxC5f,KAAK6e,YAAY5c,KAAKjC,KAAKkf,iBAG7B,uBAAuB/c,GACjBnC,KAAKgf,iBAAmB7c,EAC1BnC,KAAKgH,aAAatB,OAAO,UAAW,8BAA4B,KAIlE1F,KAAKgf,gBAAkB7c,EACvBnC,KAAKkf,gBAAgB7Y,IAAI,eAAe8C,SAAS,IAC5CnJ,KAAKgf,iBAAoBhf,KAAK+e,cAIjC/e,KAAKqf,+BAHLrf,KAAKkf,gBAAgB7Y,IAAI,eAAesZ,cAAc,CAAC,IAAW5e,WAClEf,KAAKkf,gBAAgB7Y,IAAI,eAAeuZ,2BAM5C,qBACE5f,KAAKif,aAAc,EACdjf,KAAKgf,iBACRhf,KAAKqf,8BAID,8BACNrf,KAAKkf,gBAAgB7Y,IAAI,eAAeoZ,kBACxCzf,KAAKkf,gBAAgB7Y,IAAI,eAAeqZ,UAAU,MAClD1f,KAAKkf,gBAAgB7Y,IAAI,eAAeuZ,2B,6BApGnC,K,MAIA,M,sCAQN,EAAAtd,I,eACA,EAAAA,I,oBACA,EAAAA,I,sBACA,EAAAA,I,mBACA,M,uCACA,M,wBAkCA,EAAAA,KAxCU,GAAoB,aALhC,YAAU,CACTE,SAAU,kBACVC,SCTa,0lD,QCAA,0e,iCF0BW,IAAmC,OAdhD,I,IGAA,GAAe,MAa1B,YAAoBjD,EAAyBwH,GAAzB,KAAAxH,KAAyB,KAAAwH,eAVpC,KAAAtH,gBAAiB,EAGhB,KAAAmf,YAAuC,IAAI,IAC3C,KAAAC,gCAAkC,IAAI,IAEhD,KAAAe,mBAAoB,EACpB,KAAAZ,aAAc,EACd,KAAAD,iBAAkB,EAIlB,WACEhf,KAAKof,OAGP,cACcU,GACRA,IACF9f,KAAKkM,KAAO4T,EACZ9f,KAAKof,QAIT,OACEpf,KAAK+f,YACL/f,KAAKkM,KAAKuD,SAAWzP,KAAKkM,KAAKuD,SAAWzP,KAAKkM,KAAKuD,SAAW,GAC/DzP,KAAKggB,kBACLhgB,KAAKsO,WACLtO,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,YACEZ,KAAKY,KAAOZ,KAAKR,GAAGqB,MAAM,CACxBmF,KAAM,CAAC,IACPmZ,eAAgB,EAAC,GACjBvf,kBAAmB,EAAC,GACpB8P,MAAO,GACPhG,QAAS,CAAC,QACV+F,SAAUzP,KAAKR,GAAG6a,MAAM,GAAI,CAAC,IAAWtZ,WACxCmI,cAAelJ,KAAKR,GAAGggB,QAAQ,MAInC,kBACMxf,KAAKkM,OACHlM,KAAKkM,KAAKuD,SAAShL,OAAS,IAC9BzE,KAAK6f,mBAAoB,EACzB7f,KAAKY,KAAKyF,IAAI,YAAYsZ,cAAc,CAAC,IAAW5e,WACpDf,KAAKY,KAAKyF,IAAI,YAAYuZ,0BAExB5f,KAAKkM,KAAK1E,KAAOxH,KAAKkM,KAAK1E,IAAIE,MAAMjD,OAAS,IAChDzE,KAAKif,aAAc,GAEjBjf,KAAKigB,qBACPjgB,KAAKgf,iBAAkB,EACvBhf,KAAKY,KAAKyF,IAAI,YAAYoZ,kBAC1Bzf,KAAKY,KAAKyF,IAAI,YAAYuZ,2BAG9B5f,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,mBACE,OACEZ,KAAKkM,KAAKhD,eACVlJ,KAAKkM,KAAKhD,cAAczE,OAAS,GACjCzE,KAAKkM,KAAKhD,cAAc4F,KAAKlF,IAAS,IAAE8M,QAAQ9M,IAIpD,WACM5J,KAAKkM,OACPlM,KAAKY,KAAKgI,WAAW5I,KAAKkM,MAC1BlM,KAAKkM,KAAKuD,SAAS5G,QAAQ4G,IACzB,MAAMyQ,EAAYlgB,KAAKR,GAAGqB,MAAM,CAC9Bsf,SAAU,CAAC1Q,EAAS0Q,UACpBC,MAAOpgB,KAAKR,GAAG6a,MAAM5K,EAAS2Q,MAAO,IAAWrf,YAEtCf,KAAKY,KAAKyF,IAAI,YAAa2D,KAAKkW,MAKlD,yBAAyB/d,GACvB,IAAKA,EAGH,OAFYnC,KAAKY,KAAKyF,IAAI,YAAaiM,aACvCtS,KAAK6f,mBAAoB,GAK3B,GADiE,IAAtC7f,KAAKY,KAAKyF,IAAI,YAAa5B,OAGpD,YADAzE,KAAKgH,aAAatB,OAAO,UAAW,8BAA4B,IAIlE1F,KAAK6f,kBAAoB1d,EACzB,MAAM+d,EAAYlgB,KAAKR,GAAGqB,MAAM,CAC9Bsf,SAAU,EAAC,GACXC,MAAOpgB,KAAKR,GAAG6a,MAAM,GAAI,IAAWtZ,YAG1Bf,KAAKY,KAAKyF,IAAI,YAAa2D,KAAKkW,GAC5ClgB,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,qBACEZ,KAAKif,aAAc,EAGrB,uBAAuB9c,GACrBnC,KAAKgf,gBAAkB7c,EAClBA,GASHnC,KAAKY,KAAKyF,IAAI,YAAYsZ,cAAc,MACxC3f,KAAKY,KAAKyF,IAAI,YAAYoZ,kBAC1Bzf,KAAKY,KAAKyF,IAAI,YAAYuZ,2BAVtB5f,KAAKkM,OACPlM,KAAKkM,KAAKhD,cAAgB,IAE5BlJ,KAAKY,KAAKyF,IAAI,iBAAiB8C,SAAS,MACxCnJ,KAAKY,KAAKyF,IAAI,QAAQ8C,SAAS,MAC/BnJ,KAAKY,KAAKyF,IAAI,YAAYsZ,cAAc,CAAC,IAAW5e,WACpDf,KAAKY,KAAKyF,IAAI,YAAYuZ,0BAM5B5f,KAAK6e,YAAY5c,KAAKjC,KAAKY,Q,6BA5IX,K,MAGX,M,+BASN,EAAA0B,I,YACA,EAAAA,I,sBACA,EAAAA,I,oBACA,EAAAA,I,mBAEA,M,uCACA,M,iBAYA,EAAAA,KAnBU,GAAe,aAL3B,YAAU,CACTE,SAAU,cACVC,SCTa,4sC,QCAA,M,iCFyBW,IAAmC,OAbhD,I,IGDA,GAAyB,MAQpC,YAA6BjD,GAAA,KAAAA,KALnB,KAAAqf,YAAuC,IAAI,IAC3C,KAAAwB,4BAAkD,IAAI,IAK9DrgB,KAAKY,KAAOZ,KAAKR,GAAGqB,MAAM,CACxByf,UAAWtgB,KAAKR,GAAG6a,MAAM,GAAI,IAAWtZ,YAI5C,WACEf,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,YAAY2f,GACV,GAAIA,EAA0B,iBAAG,CAC/B,MAAMC,EAAmBD,EAA0B,iBAAE/W,aACjDgX,GACFxgB,KAAKygB,YAAYD,IAKvB,aACaE,GACPA,GACFA,EAASJ,UAAUzX,QAAQqP,GAAYlY,KAAKygB,YAAYvI,IAI5D,gBACE,OAAOlY,KAAKY,KAAK+f,SAAoB,UAGvC,YAAYzI,GACV,MAAM0I,EAAe1I,EAAS2I,OAAOlZ,IAAKmZ,GACxC9gB,KAAKR,GAAGqB,MAAM,CACZ8D,KAAM,CAACmc,EAAMnc,MACbkF,OAAQ,CAACiX,EAAMjX,OAAQ,IAAW9I,UAClC4I,YAAa,CAACmX,EAAMnX,gBAIlBoX,EAAgB/gB,KAAKR,GAAGqB,MAAM,CAClC8D,KAAM,CAACuT,EAASvT,MAChBkc,OAAQ7gB,KAAKR,GAAG6a,MAAM,IAAIuG,MAG5B5gB,KAAKsgB,UAAUtW,KAAK+W,GAGtB,eAAeC,GACbhhB,KAAKsgB,UAAUW,SAASD,K,6BAlER,M,uCAWjB,EAAA1e,I,wBACA,EAAAA,I,mBACA,M,mCACA,M,gBAuBA,EAAAA,KA3BU,GAAyB,aALrC,YAAU,CACTE,SAAU,wBACVC,SCRa,qqF,QCAA,siB,iCFmBoB,OARtB,I,IGJAye,GAAyC,MAGpD,eAEA,c,wDAJC,EAAA5e,KADU4e,GAAyC,aALrD,YAAU,CACT1e,SAAU,4CACVC,SCJa,qc,QCAA,M,qCFOFye,I,IGMA,GAAoB,MAgB/B,YAAoB1hB,GAAA,KAAAA,KAXX,KAAAE,gBAAiB,EACjB,KAAAyhB,kBAAmB,EAClB,KAAAtC,YAAc,IAAI,IAClB,KAAAC,gCAAkC,IAAI,IAGhD,KAAAG,aAAc,EAGd,KAAAmC,KAAO,EAGLphB,KAAKqhB,gBAAkBrhB,KAAKR,GAAGqB,MAAM,CACnCwI,MAAO,CAAC,GAAI,IAAWtI,UACvB6I,KAAM,CAAC,GAAI,IAAW7I,UACtBuI,aAAc,CAAC,IACf6V,eAAgB,EAAC,GACjBvf,kBAAmB,EAAC,GACpB8J,QAAS,CAAC,UAId,WACE,GAAI1J,KAAKoK,YAAa,CACpB,MAAMf,EAAQrJ,KAAKoK,YAAYf,MAEjB,gEAAVA,IACFrJ,KAAKohB,KAAO,IAGdphB,KAAKqhB,gBAAgBhb,IAAI,SAAS8C,SAASE,GAC3C,MAAMlH,EAAQnC,KAAKoK,YAAYd,aAAa7F,OAAOA,CAChD8F,EAAaC,IAAiBD,EAAc,KAAOC,GAEtDxJ,KAAKqhB,gBAAgBhb,IAAI,QAAQ8C,SAAShH,GAC1CnC,KAAKqhB,gBAAgBhb,IAAI,gBAAgB8C,SAASnJ,KAAKoK,YAAYd,cAE/DtJ,KAAKshB,OAAOthB,KAAKoK,YAAY5C,OAC/BxH,KAAKif,aAAc,GAIvBjf,KAAKqhB,gBAAgBhb,IAAI,QAAQqM,aAAanR,UAAWqI,IACvD,GAAIA,GAAQA,EAAK2X,OAAO9c,OAAS,EAAG,CAClC,MAAMtC,EAAQyH,EAAK4X,MAAM,MACzBxhB,KAAKqhB,gBAAgBhb,IAAI,gBAAgB8C,SAAShH,QAE9CnC,KAAKqhB,gBAAgBhb,IAAI,QAAQlE,OACnCnC,KAAKqhB,gBAAgBhb,IAAI,QAAQ8C,SAAS,QAIhDnJ,KAAK6e,YAAY5c,KAAKjC,KAAKqhB,iBAG7B,qBACqBI,GACnB,GAAIA,EAAkB,CACpB,MAAMtf,EAAQsf,EAAiBnY,aAAa7F,OAAOA,CAACC,EAAKC,IAAQD,EAAM,KAAOC,GAC9E3D,KAAKqhB,gBAAgBhb,IAAI,QAAQ8C,SAAShH,GAC1CnC,KAAKqhB,gBAAgBhb,IAAI,SAAS8C,SAASsY,EAAiBpY,OAC5DrJ,KAAKqhB,gBAAgBhb,IAAI,gBAAgB8C,SAASsY,EAAiBnY,cAC/DtJ,KAAKshB,OAAOG,EAAiBja,OAC/BxH,KAAKoK,YAAcqX,EACnBzhB,KAAKif,aAAc,IAKzB,kBACE,OAAOjf,KAAKiN,UAAYjN,KAAKiN,QAAQN,IAAM,gCAA+B,0BAG5E,qBACE3M,KAAKif,aAAc,EAGrB,OAAOzX,GACL,OAAOA,GAAOA,EAAIE,OAASF,EAAIE,MAAMjD,OAAS,EAGhD,8BACEzE,KAAKohB,KAAO,GACZ,MAAM9X,EAAe,CACnB,kCACA,4KACA,mCACA,+CACA,iOACA,8CACA,6HACA,2BACA,wGACA,0BACA,6TACA,IACA,8QAEInH,EAAQmH,EAAa7F,OAAOA,CAACC,EAAKC,IAAQD,EAAM,KAAOC,GAC7D3D,KAAKqhB,gBAAgBhb,IAAI,QAAQ8C,SAAShH,GAC1CnC,KAAKqhB,gBAAgBhb,IAAI,SAAS8C,SAAS,+DAC3CnJ,KAAKqhB,gBAAgBhb,IAAI,gBAAgB8C,SAASG,GAElDtJ,KAAK6e,YAAY5c,KAAKjC,KAAKqhB,mB,6BAxHtB,M,kCAaN,EAAA/e,I,mBACA,EAAAA,I,oBAEA,EAAAA,I,sBACA,EAAAA,I,wBACA,EAAAA,I,mBACA,M,uCACA,M,wBAoDA,EAAAA,KA5DU,GAAoB,aALhC,YAAU,CACTE,SAAU,kBACVC,SCVa,y3C,QCAA,qC,iCF6BW,OAhBb,IGbE,I,iBCiBF,GAA4B,MAevC,YACUlD,EACAC,EACAwH,GAFA,KAAAzH,eACA,KAAAC,KACA,KAAAwH,eAhBA,KAAA6X,YAAuC,IAAI,IAErD,KAAAG,iBAAkB,EAElB,KAAApe,KAAOZ,KAAKR,GAAGqB,MAAM,CACnBmF,KAAM,CAAC,IACPmZ,eAAgB,EAAC,GACjBvf,kBAAmB,EAAC,GACpB8P,MAAO,CAAC,IACRhG,QAAS,CAAC,QACVmL,SAAU7U,KAAKR,GAAG6a,MAAM,GAAI,IAAWtZ,UACvC4I,YAAa,KAQf,WACE3J,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,YAAY2f,GACV,MAAMrc,EAAeqc,EAAsB,cAAKA,EAAsB,aAAE/W,aACpEtF,IACFlE,KAAKY,KAAKgI,WAAW1E,GACjBA,EAAayF,cACf3J,KAAKgf,iBAAkB,GAEzB9a,EAAa0Q,gBAAgB/L,QAAS1F,IACpCnD,KAAK0hB,eAAe,CAClBzY,mBAAoB9F,EAAK8F,mBACzB0Y,QAASxe,EAAKwe,aAMtB,6BAEgB3hB,KAAKT,aAAa+Q,KAAK,KAAiC,CACpEH,aAFmB,GAGnBI,SAAU,SACVC,UAAU,IAGNC,QAAQ3N,YAAYvB,UAAWogB,IAC/B3hB,KAAK4hB,cAAcD,EAAQhd,MAC7B3E,KAAKgH,aAAatB,OAAO,UAAW,gDAAqC,IAEzE1F,KAAK0hB,eAAe,CAClBC,cAMR,eAAexe,GACb,MAAM0e,EAAc7hB,KAAK8hB,uBACzBtc,QAAQC,IAAItC,GACZ0e,EAAYjZ,WAAW,CACrBK,mBAAoB9F,EAAK8F,mBAAqB9F,EAAK8F,mBAAqB,EACxE0Y,QAASxe,EAAKwe,UAEhB3hB,KAAK6U,SAAS7K,KAAK6X,GAGrB,cAAcE,GACZ/hB,KAAK6U,SAASoM,SAASc,GAGzB,uBACE,OAAO/hB,KAAKR,GAAGqB,MAAM,CACnBoI,mBAAoB,GACpBmR,kBAAmB,GACnBuH,QAAS,CACPjV,IAAK,CAAC,IACN/H,KAAM,CAAC,IACP+C,MAAO,CACL,CACE/C,KAAM,CAAC,IACPqd,aAAc,CACZ,CACE,CACE9c,YAAa,CAAC,IACd+c,gBAAiB,CAAC,IAClBC,cAAe,CAAC,IAChBC,KAAM,CAAC,SAMjBxY,YAAa,CAAC,OAKpB,cAAchF,GACZ,OAAO3E,KAAK6U,SAAS1S,MAAM2M,KACxB3L,GAA0BA,EAAKwe,QAAQhd,KAAKyd,gBAAkBzd,EAAKyd,eAIxE,eACE,OAAkBpiB,KAAKY,KAAKyF,IAAI,YAGlC,uBAAuBlE,GACrBnC,KAAKgf,gBAAkB7c,EACnBA,EACFnC,KAAKY,KAAKyF,IAAI,eAAesZ,cAAc,CAAC,IAAW5e,YAEvDf,KAAKY,KAAKyF,IAAI,eAAe8C,SAAS,MACtCnJ,KAAKqiB,+BAEPriB,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAGrB,8BACNZ,KAAKY,KAAKyF,IAAI,eAAeoZ,kBAC7Bzf,KAAKY,KAAKyF,IAAI,eAAeqZ,UAAU,MACvC1f,KAAKY,KAAKyF,IAAI,eAAeuZ,yBAG/B,cAAcmC,GACZ,MAAM5f,EAAQnC,KAAK6U,SAASyN,GAAGP,GAAO1b,IAAI,sBAAsBlE,MAC5DA,EAAQ,GACVnC,KAAK6U,SACFyN,GAAGP,GACH1b,IAAI,sBACJ8C,SAAShH,EAAQ,GAGxB,aAAa4f,GACX,MAAM5f,EAAQnC,KAAK6U,SAASyN,GAAGP,GAAO1b,IAAI,sBAAsBlE,MAChEnC,KAAK6U,SACFyN,GAAGP,GACH1b,IAAI,sBACJ8C,SAAShH,EAAQ,K,6BA3Jf,K,MAHW,K,MAEX,M,uCAeN,EAAAG,I,mBACA,OAFU,GAA4B,aALxC,YAAU,CACTE,SAAU,2BACVC,SDda,opF,QEAA,khC,iCDiCW,IACV,IACU,OAlBb,I,IEiGA8f,GAAmB,MAM9B,YACUvX,EACAI,EACAoX,GAFA,KAAAxX,cACA,KAAAI,eACA,KAAAoX,UAPD,KAAAC,iBAAmB,WACnB,KAAAC,iBAAkB,EAClB,KAAAC,mBAAoB,EAQ7B,YAEA,WACE,OAAO3iB,KAAKgL,YAAYwC,OAG1B,SACExN,KAAKgL,YAAY4X,SACjB5iB,KAAKwiB,QAAQrU,SAAS,CAAC,gBAGzB,iBACE,OAAOnO,KAAKgL,YAAY6X,WAG1B,kBACE,OAAO7iB,KAAKgL,YAAY8X,YAG1B,8BAEE,MAAuB,0BADR9iB,KAAKoL,aAAagK,iBACnBzQ,KAGhB,SACM3E,KAAK+iB,8BACP/iB,KAAKoL,aAAa4X,SAAS,aAE3BhjB,KAAKoL,aAAa4X,SAAS,2B,6BAxJxB,K,MACA,K,MAFO,M,gCAkHb,EAAA1gB,I,wBACA,EAAAA,I,uBACA,EAAAA,I,yBACA,EAAAA,KAJUigB,GAAmB,aA7G/B,YAAU,CACT/f,SAAU,iBACVC,SAAU,6zH,QCPG,07B,iCDyHU,IACC,IACL,OATR8f,IElHE,I,iBCmBF,GAAqB,MAiBhC,YACU/iB,EACAwH,EACAzH,GAFA,KAAAC,KACA,KAAAwH,eACA,KAAAzH,eAhBD,KAAAG,gBAAiB,EACjB,KAAAyhB,kBAAmB,EAClB,KAAAtC,YAAuC,IAAI,IAC3C,KAAAC,gCAAkC,IAAI,IAIhD,KAAA/S,QAAS,EACT,KAAAkT,aAAc,EACd,KAAAD,iBAAkB,EAShBhf,KAAKY,KAAOZ,KAAKR,GAAGqB,MAAM,CACxBmF,KAAM,CAAC,IACP+J,mBAAoB,MAACiJ,GACrBmG,eAAgB,EAAC,GACjBvf,kBAAmB,EAAC,GACpB6J,WAAY,CAAC,IACbrF,YAAapE,KAAKR,GAAG6a,MAAM,GAAI,IAAWtZ,UAC1C2O,MAAO,CAAC,IACRhG,QAAS,CAAC,QACVC,YAAa3J,KAAKR,GAAGggB,QAAQ,MAIjC,YAAYe,GACV,GAAIA,EAAsB,aAAG,CAC3B,MAAMrc,EAAeqc,EAAsB,aAAE/W,aACzCtF,IACFlE,KAAKijB,oBAAoBhC,SAAS,GAClCjhB,KAAK+L,OAAiC,aAAxB7H,EAAagG,OAC3BlK,KAAKY,KAAKgI,WAAW1E,GACjBlE,KAAKshB,WAAathB,KAAKN,iBACzBM,KAAKif,aAAc,GAGjBjf,KAAKkjB,mBACPljB,KAAKgf,iBAAkB,GAGzB9a,EAAaE,YAAYyE,QAAQC,IAC/B9I,KAAK+I,gBAAgB,IAChBD,EACHvF,GAAIuF,EAAE1D,aACNE,UAAWwD,EAAEzD,UACbJ,YAAa6D,EAAE9D,WACfG,wBAAyB2D,EAAE5D,YAC3B8D,SAAUF,EAAEG,yBAOtB,WACEjJ,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,SACE,OAAOZ,KAAKkE,aAAasD,KAAOxH,KAAKkE,aAAasD,IAAIE,MAAMjD,OAAS,EAGvE,iBACE,OACEzE,KAAKkE,aAAayF,aAClB3J,KAAKkE,aAAayF,YAAYlF,OAAS,GACvCzE,KAAKkE,aAAayF,YAAYmF,KAAKlF,IAAS,IAAE8M,QAAQ9M,IAI1D,sBACsBuZ,GAChBA,IACFnjB,KAAKkE,aAAeif,EACpBnjB,KAAKif,YAAcjf,KAAKshB,SACxBthB,KAAKgf,gBAAkBhf,KAAKkjB,iBAC5BljB,KAAKojB,uBAAuBpjB,KAAKijB,qBACjCE,EAAkB/e,YAAYyE,QAAQC,IACpC9I,KAAK+I,gBAAgB,IAChBD,EACHvF,GAAIuF,EAAE1D,aACNE,UAAWwD,EAAEzD,UACbJ,YAAa6D,EAAE9D,WACfG,wBAAyB2D,EAAE5D,YAC3B8D,SAAUF,EAAEG,wBAMpB,uBACuBoG,GACjBA,IACFrP,KAAKY,KAAKyF,IAAI,sBAAsB8C,SAASkG,EAAmB3C,KAChE1M,KAAKijB,oBAAoBhC,SAAS,GAClC5R,EAAmBjL,YAAYyE,QAAQC,IACrC9I,KAAK+I,gBAAgB,IAChBD,EACHua,WAAW,OAMnB,kBACE,OAAOrjB,KAAKiN,UAAYjN,KAAKiN,QAAQN,IAAM,gCAA+B,0BAG5E,0BACE,OAAkB3M,KAAKY,KAAKyF,IAAI,eAGlC,cAActB,GACZ,MAAMue,EAAY,IAAI,IAAU,CAC9Ble,aAAc,IAAI,IAAY,MAC9BT,KAAM,IAAI,IAAY,GAAI,IAAW5D,UACrC8I,OAAQ,IAAI,IAAY,GAAI,IAAW9I,UACvCsD,IAAK,IAAI,IAAY,IACrBgB,UAAW,IAAI,IAAY,IAC3BL,WAAY,IAAI,IAAY,IAC5BE,YAAa,IAAI,IAAY,IAC7B+D,mBAAoB,IAAI,IAAY,GACpCa,kBAAmB,IAAI,IAAY,UAAW,IAAW/I,UACzDgE,KAAM,IAAI,IAAYA,EAAM,IAAWhE,UACvC+K,OAAQ,IAAI,IAAqB,mBAAT/G,GACxBwe,QAAS,IAAI,KAAY,GACzB1e,mBAAoB,IAAI,IACxBC,OAAQ,IAAI,MAEd9E,KAAKwjB,aAAaF,GAClBtjB,KAAKijB,oBAAoBjZ,KAAKsZ,GAC9BtjB,KAAK6e,YAAY5c,KAAKjC,KAAKY,MAG7B,iBAAiBuD,EAAuBsf,GACtCtf,EAAWkC,IAAI,QAAQ8C,SAASsa,EAAmB7e,MACnDT,EAAWkC,IAAI,aAAa8C,SAASsa,EAAmBne,WACxDnB,EAAWkC,IAAI,cAAc8C,SAASsa,EAAmBxe,aACzDd,EAAWkC,IAAI,OAAO8C,SAASsa,EAAmBpf,KAClDF,EAAWkC,IAAI,eAAe8C,SAASsa,EAAmBte,yBAC1DhB,EAAWkC,IAAI,sBAAsB8C,SAAS,GAC9ChF,EAAWkC,IAAI,gBAAgB8C,SAASsa,EAAmBlgB,IAC3DY,EAAWkC,IAAI,UAAU8C,UAAS,GAClChF,EAAWkC,IAAI,WAAW8C,UAAS,GACnChF,EAAWkC,IAAI,qBAAqB8C,SAAS,WAC7ChF,EAAWkC,IAAI,sBAAsB8C,SAASsa,EAAmB5e,oBACjEV,EAAWkC,IAAI,UAAU8C,SAASsa,EAAmB3e,QAGvD,iBAAiBid,GACf/hB,KAAKijB,oBAAoBhC,SAASc,GAGpC,uBAAuB5f,GACjBnC,KAAKgf,iBAAmB7c,EAC1BnC,KAAKgH,aAAatB,OAAO,UAAW,8BAA4B,IAIlE1F,KAAKgf,gBAAkB7c,EAGzB,qBACEnC,KAAKif,aAAc,EAGb,aAAare,GACnBA,EACGyF,IAAI,UACJqM,aAAaC,KAAK,OAAAE,EAAA,MAClBtR,UAAWqI,IACLA,GAA+B,IAAvBA,EAAK2X,OAAO9c,QACvB7D,EAAKyF,IAAI,UAAU8C,SAAS,QAK5B,iBAAgB,KACtBxE,EAAI,aACJS,EAAY,UACZC,EAAS,WACTL,EAAU,IACVX,EAAG,SACH2E,EAAQ,YACR9D,EAAW,OACX2E,EAAM,WACNJ,EAAU,UACV4Z,EAAS,SACTK,GAAW,EAAK,KAChB3e,EAAI,kBACJ+E,EAAiB,mBACjBjF,EAAkB,OAClBC,IAEA,MAAMwe,EAAY,IAAI,IAAU,CAC9B3e,KAAM,IAAI,IAAYA,GACtBS,aAAc,IAAI,IAAYA,GAC9B6D,mBAAoB,IAAI,IAAYD,GACpCa,OAAQ,IAAI,IAAYA,EAAQ,IAAW9I,UAC3CmE,YAAa,IAAI,IAAYA,GAC7BG,UAAW,IAAI,IAAYA,GAC3BL,WAAY,IAAI,IAAYA,GAC5BX,IAAK,IAAI,IAAYA,GACrBoF,WAAY,IAAI,IAAYA,GAC5BT,SAAU,IAAI,IAAYA,GAC1Bqa,UAAW,IAAI,IAAYA,GAC3BK,SAAU,IAAI,IAAYA,GAC1B3e,KAAM,IAAI,IAAYA,GACtBwe,QAAS,IAAI,KAAY,GACzBzX,OAAQ,IAAI,KAAY,GACxBhC,kBAAmB,IAAI,IAAYA,GACnCjF,mBAAoB,IAAI,IAAYA,GACpCC,OAAQ,IAAI,IAAYA,KAO1B,OAJI4e,GACFJ,EAAUhU,UAGLgU,EAGD,uBAAuBL,GAC7B,IAAK,IAAIU,EAAIV,EAAoBtC,SAASlc,OAAS,EAAGkf,GAAK,EAAGA,IAAK,CAC9CV,EAAoBtC,SAASgD,GAAGxhB,MACnCwC,MACdse,EAAoBhC,SAAS0C,IAK3B,iBAAgB,GACtBpgB,EAAE,UACF+B,EAAS,YACTL,EAAW,wBACXE,EAAuB,OACvB0E,EAAS,GAAE,SACXb,EAAW,EAAC,SACZ0a,GAAW,EAAK,kBAChB5Z,EAAoB,aACjBxD,IAEHtG,KAAKijB,oBAAoBjZ,KACvBhK,KAAK4jB,gBAAgB,CACnBxe,aAAc7B,EACd8B,UAAWC,EACXN,WAAYC,EACZC,YAAaC,EACb0E,SACAb,WACA0a,WACA5Z,uBACGxD,KAKT,oCACE,MAAM6J,EAAe,CACnBpQ,aAAcC,KAAKD,cAEfsQ,EAAQrQ,KAAKT,aAAa+Q,KAAK,KAAgC,CACnEH,eACAI,SAAU,SACVC,UAAU,IAGZH,EAAMI,QAAQoT,cAActiB,UAAUA,EAAGmD,eAAcmF,SAAQb,eAC7DhJ,KAAK+I,gBAAgB,IAChBrE,EACHC,KAAMD,EAAaE,KACnBiF,OAAQA,EAAOmR,KAAK,MACpBhS,aAGFqH,EAAM/M,W,6BA/SQ,K,MAOX,K,MAGA,M,kCASN,EAAAhB,I,oBAEA,EAAAA,I,sBACA,EAAAA,I,wBACA,EAAAA,I,mBACA,M,uCACA,M,oBAEA,EAAAA,I,yBAuEA,EAAAA,I,0BAoBA,EAAAA,KApGU,GAAqB,aALjC,YAAU,CACTE,SAAU,mBACVC,SDhBa,4jE,QEAA,6pS,iCDqCC,IACU,IACA,OApBb,I,IEXAqhB,GAAkC,MAe7C,YAAoBvkB,GAAA,KAAAA,eAEpB,YAEA,eAAeyG,GAEb,OADAhG,KAAKgG,KAAOA,EACJA,EAAK,IACX,IAAK,IACL,IAAK,IACHhG,KAAKqJ,MAAQ,6BACb,MACF,IAAK,IACHrJ,KAAKqJ,MAAQ,8BACb,MACF,IAAK,IACHrJ,KAAKqJ,MAAQ,2BACb,MACF,IAAK,IACHrJ,KAAKqJ,MAAQ,sCACb,MACF,QACErJ,KAAKqJ,MAAQ,+BAGjBrJ,KAAKC,SAAWD,KAAKT,aAAaW,OAAO,CACvCC,UAAWH,KAAKI,WAChBC,SAAUL,KAAKM,UACfC,YAAY,EACZC,QAAS,IACTC,gBAAgB,EAChBE,WAAY,OACZojB,gBAAiB,8BACjBrjB,OAAQ,IAAM8E,QAAQC,IAAI,cAI9B,QACEzF,KAAKC,SAASoC,Y,6BA3DG,M,mCAUlB,KAAS,MAAC,c,kBAGV,KAAS,MAAC,aAAc,CAAEE,QAAQ,M,iBAGlC,KAAS,MAAC,YAAa,CAAEA,QAAQ,OATvBuhB,GAAkC,aAL9C,YAAU,CACTthB,SAAU,kCACVC,SCLa,id,QCAA,kxB,iCFuBqB,OAfvBqhB,I,IGoFAE,GAAgB,QAAhBA,GAAgB,aAtD5B,YAAS,CACRC,aAAc,CACZ,GACA,GACA1B,GACA,GACAuB,GACA,GACA,GACAxH,GACA,GACA,GACA,KACA,GACA,KACA,KACA,KACAQ,GACA,GACAoE,GACA,IAEFtC,QAAS,CACP,GACA,GACA2D,GACA,GACAuB,GACA,GACA,GACAxH,GACA,GACA,GACA,GACA,KACA,GACA,GACA,KACA,KACA,KACAQ,IAEF4B,QAAS,CACP,IACA,IACAD,GACA,EAAAyF,eACA,IACA,IAAiBC,QAAQ,IACzB,IAAcA,UACd,IAAYA,WAEdC,UAAW,CAACjL,OAED6K,K,4HCnFA,EAAoB,MAO/B,YAAmBthB,GAAA,KAAAA,WACjB1C,KAAKmX,OAAS,IAAIkN,EAAA,EAGpB,YAEA,OAAOC,GACL,IACE,MAAM/O,EAAM+O,EAAOC,cAAc5O,SAASC,KAC1C5V,KAAKmX,OAAOG,KAAK/B,GACjB,MAAOiP,GACPxkB,KAAKmX,OAAOG,U,4BA1BT,MAQI,EAAoB,aALhC,YAAU,CACT9U,SAAU,mBACVC,SCNa,gd,QCAA,uQ,iCFgBgB,OAPlB","file":"x","sourcesContent":["import { Component, EventEmitter, Input, TemplateRef, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { markFormGroup } from '@app/utils/markFormGroup';\nimport { NzModalRef, NzModalService } from 'ng-zorro-antd/modal';\n\n@Component({\n  selector: 'app-modal-select-layout',\n  templateUrl: './modal-select-layout.component.html',\n  styleUrls: ['./modal-select-layout.component.scss']\n})\nexport class ModalSelectLayoutComponent {\n  @Input() colorSetting: ColorSetting;\n  @Input() viewFormAndress = false;\n  @Input() isVeterinarian = false;\n\n  tplModal: NzModalRef;\n\n  @ViewChild('tplContent', { static: true })\n  tplContent: TemplateRef<{}>;\n\n  @ViewChild('tplFooter', { static: true })\n  tplFooter: TemplateRef<{}>;\n\n  layout = 'simple';\n  showPrescriberCpf = false;\n\n  selectLayout = new EventEmitter<any>();\n\n  form: FormGroup;\n\n  constructor(private modalService: NzModalService, private fb: FormBuilder) {}\n\n  createTplModal(\n    patientDoesNotHaveAddress = false,\n    isVeterinarian = false,\n    colorSetting?: ColorSetting\n  ) {\n    this.colorSetting = colorSetting;\n    this.isVeterinarian = isVeterinarian;\n    this.tplModal = this.modalService.create({\n      nzContent: this.tplContent,\n      nzFooter: this.tplFooter,\n      nzClosable: false,\n      nzWidth: patientDoesNotHaveAddress ? 900 : 600,\n      nzMaskClosable: false,\n      nzOnOk: () => {},\n      nzOnCancel: () => {}\n    });\n\n    if (patientDoesNotHaveAddress) {\n      this.viewFormAndress = true;\n      this.form = this.fb.group({\n        uf: ['', Validators.required],\n        city: ['', Validators.required],\n        complement: [''],\n        number: ['', Validators.required],\n        street: ['', Validators.required],\n        neighborhood: ['', Validators.required],\n        cep: ['', Validators.required]\n      });\n    } else {\n      this.viewFormAndress = false;\n    }\n\n    this.tplModal.afterOpen.subscribe(() => {\n      this.setBackgroundColorFooter();\n    });\n  }\n\n  setBackgroundColorFooter() {\n    const elements = document.getElementsByClassName('ant-modal-footer');\n    if (elements) {\n      if (this.colorSetting) {\n        elements[0].setAttribute('style', `background-color: ${this.colorSetting.footer}`);\n      } else {\n        elements[0].setAttribute('style', `background-color: var(--bg-modal-header)`);\n      }\n    }\n  }\n\n  submit() {\n    if (this.layout === 'special' && this.viewFormAndress) {\n      markFormGroup(this.form);\n      if (this.form.valid) {\n        this.emitEventAndCloseModal();\n      }\n    } else {\n      this.emitEventAndCloseModal();\n    }\n  }\n\n  emitEventAndCloseModal() {\n    this.selectLayout.emit({\n      layout: this.layout,\n      addressValue: this.form ? this.form.value : null\n    });\n    this.close();\n  }\n\n  close() {\n    this.tplModal.close();\n    this.tplModal.destroy();\n  }\n}\n","export default \"<ng-template #tplContent>\\n  <div class=\\\"container send-document\\\" theme>\\n    <h1 class=\\\"title\\\" [ngStyle]=\\\"{ color: colorSetting?.primary }\\\">\\n      Selecione o layout da prescrição\\n    </h1>\\n\\n    <nz-radio-group [(ngModel)]=\\\"layout\\\">\\n      <label nz-radio nzValue=\\\"simple\\\">Receita Simples</label>\\n      <label nz-radio nzValue=\\\"antimicrobial\\\">Receita de Antibiótico</label>\\n      <label nz-radio nzValue=\\\"special\\\">Receita de Controle Especial</label>\\n    </nz-radio-group>\\n\\n    <div\\n      *ngIf=\\\"layout === 'special' && viewFormAndress\\\"\\n      style=\\\"margin-top: 1rem; position: relative; width: 100%;\\\"\\n    >\\n      <form nz-form [formGroup]=\\\"form\\\" theme>\\n        <app-address-data-form\\n          [form]=\\\"form\\\"\\n          alertMsg=\\\"Para prosseguir, complete os dados obrigatórios de endereço do paciente, conforme RDC 344/98 (Anvisa)\\\"\\n          [required]=\\\"true\\\"\\n        ></app-address-data-form>\\n      </form>\\n    </div>\\n  </div>\\n</ng-template>\\n<ng-template #tplFooter>\\n  <div\\n    class=\\\"d-flex align-items-end flex-column modal-footer\\\"\\n    theme\\n    [ngStyle]=\\\"{\\n      'background-color': colorSetting?.secondary,\\n      'border-color': colorSetting?.secondary\\n    }\\\"\\n  >\\n    <div class=\\\"row\\\">\\n      <button (click)=\\\"close()\\\" class=\\\"btn btn-black\\\" [ngStyle]=\\\"{ color: colorSetting?.primary }\\\">\\n        Cancelar\\n      </button>\\n      <button\\n        (click)=\\\"submit()\\\"\\n        class=\\\"btn btn-ok\\\"\\n        [ngStyle]=\\\"{\\n          'background-color': colorSetting?.primary,\\n          'border-color': colorSetting?.primary\\n        }\\\"\\n      >\\n        OK\\n      </button>\\n    </div>\\n  </div>\\n</ng-template>\\n\";","export default \".title {\\n  text-transform: none;\\n  font-size: 35px;\\n  line-height: normal;\\n}\\n\\n.modal-footer {\\n  padding: 10px 32px;\\n  background-color: var(--bg-modal-header);\\n}\\n\\n.modal-footer .btn {\\n  font-size: 12px;\\n}\\n\\n::ng-deep .ant-modal-content {\\n  border-radius: 10px;\\n  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);\\n}\\n\\n::ng-deep .ant-modal-confirm .ant-modal-confirm-btns {\\n  float: none;\\n}\\n\\n::ng-deep .ant-input-group-addon {\\n  width: 93px;\\n}\\n\\n::ng-deep .ant-modal-footer {\\n  border-radius: 0 0 10px 10px;\\n  border-top: 0;\\n  padding: 0 !important;\\n}\\n\\n::ng-deep .ant-radio-checked .ant-radio-inner,\\n::ng-deep .ant-radio-checked .ant-radio-inner:hover {\\n  border-color: var(--bg-color-primary);\\n}\\n\\n::ng-deep .ant-radio-inner::after {\\n  background-color: var(--bg-color-primary);\\n}\\n\\n@media (max-width: 1025px) {\\n  .container.send-document {\\n    padding: 0;\\n  }\\n  .container.send-document .title {\\n    font-size: 22px;\\n    line-height: 24px;\\n  }\\n  .container.send-document .sub-title {\\n    font-size: 18px;\\n    line-height: 18px;\\n  }\\n\\n  .inputs.responsive {\\n    padding: 0;\\n  }\\n  .inputs.responsive .ant-form-item label {\\n    margin-top: 0px;\\n    font-size: 14px !important;\\n  }\\n}\\n\\n[nz-radio] {\\n  display: block;\\n  height: 32px;\\n  line-height: 32px;\\n  text-align: left;\\n  font-size: 16px;\\n}\\n\\ninput {\\n  width: 100px;\\n  margin-left: 10px;\\n}\\n\\n.column {\\n  flex-direction: column;\\n}\\n\\n.item {\\n  margin: 0;\\n}\\n\\n.horm {\\n  font-style: italic;\\n  font-size: 12px;\\n}\\n\\n.btn {\\n  font-size: 12px;\\n}\";","import { CrService } from './../../../document/services/cr.service';\nimport { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { BsModalRef } from 'ngx-bootstrap/modal';\nimport DocumentUtil from '../../utils/Document.util';\nimport { DocumentModel } from '@app/shared/models/documet-model';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\n\n@Component({\n  selector: 'app-model-list-favorite-prescription',\n  templateUrl: './model-list-favorite-document.component.html',\n  styleUrls: ['./model-list-favorite-document.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class ModelListFavoriteDocumentComponent {\n  @Input() documentsTemplate: DocumentModel[];\n  @Input() documentType: string;\n  @Input() colorSetting: ColorSetting;\n  @Input() hideEdit = false;\n  @Output() selectEvent = new EventEmitter<any>();\n  @Output() editEvent = new EventEmitter<any>();\n  @Output() deleteEvent = new EventEmitter<string>();\n\n  @ViewChild('modalHeader') modalHeader: HTMLDivElement;\n\n  typesOfDocuments = ['Prescrição', 'Exame', 'Atestado', 'Outros'];\n\n  loadingSearchMedicament = false;\n\n  constructor(\n    public modalRef: BsModalRef,\n    private crService: CrService,\n    private toast: AppToastService\n  ) {}\n\n  activeChange(item: DocumentModel) {\n    item.active = !item.active;\n  }\n\n  async onSelect(item: DocumentModel) {\n    if (item.document === 'prescription') {\n      await this.updateMedicaments(item);\n    }\n    this.selectEvent.emit(item);\n    this.modalRef.hide();\n  }\n\n  async onEdit(item: DocumentModel) {\n    if (item.document === 'prescription') {\n      await this.updateMedicaments(item);\n    }\n    this.editEvent.emit(item);\n    this.modalRef.hide();\n  }\n\n  onDelete(item: DocumentModel) {\n    this.deleteEvent.emit(item.id);\n  }\n\n  getText(arrayText: any[]): string[] {\n    return arrayText.reduce((acc, val) => (acc ? `${acc}\\n${val}` : val), '');\n  }\n\n  getLabelAttestationDays(attestationDays: string) {\n    return DocumentUtil.getAttestationsDays().find(item => item.value === attestationDays).label || '';\n  }\n\n  getLabelTypeOfActivity(typeOfActivity: string) {\n    return DocumentUtil.getTypesOfActivity().find(item => item.value === typeOfActivity).label || '';\n  }\n\n  async updateMedicaments(prescription: DocumentModel) {\n    for await (const medicament of prescription.medicaments) {\n      if (!!medicament.ean) {\n        this.loadingSearchMedicament = true;\n        try {\n          const medicamentsCR = await this.crService.searchMedicament(medicament.ean).toPromise();\n          if (medicamentsCR.length > 0) {\n            const medicamentCR = medicamentsCR[0];\n            medicament.name = medicamentCR.nome;\n            medicament.prescriptionTypeId = medicamentCR.prescriptionTypeId;\n            medicament.typeCr = medicamentCR.typeCr;\n            medicament.type = 'industrialized';\n            medicament.laboratory = medicamentCR.laboratorio;\n            medicament.description = medicamentCR.apresentacaoCustomizada;\n            medicament.medicamentId = medicamentCR.id;\n            medicament.principle = medicamentCR.principio;\n          }\n        } catch (error) {\n          console.log(error);\n          this.toast.notify('error', 'Erro ao consultar dados do medicamento.');\n        } finally {\n          this.loadingSearchMedicament = false;\n        }\n      } else {\n        medicament.type = 'free-text';\n      }\n    }\n  }\n}\n","export default \"<div class=\\\"favorite-document-modal\\\" theme>\\n  <div\\n    class=\\\"modal-header\\\"\\n    #modalHeader\\n    [ngStyle]=\\\"{\\n      'background-color': colorSetting?.primary,\\n      'border-color': colorSetting?.primary\\n    }\\\"\\n  >\\n    <h4 class=\\\"modal-title pull-left text-white\\\">Modelos de {{ documentType }}</h4>\\n    <button type=\\\"button\\\" class=\\\"close pull-right\\\" aria-label=\\\"Close\\\" (click)=\\\"modalRef.hide()\\\">\\n      <span aria-hidden=\\\"true\\\">&times;</span>\\n    </button>\\n  </div>\\n  <div class=\\\"body prescription\\\">\\n    <nz-list nzBordered>\\n      <nz-list-item *ngFor=\\\"let item of documentsTemplate\\\">\\n        <div>\\n          <div class=\\\"row header prescription align-items-center\\\">\\n            <div class=\\\"col-1\\\" (click)=\\\"activeChange(item)\\\">\\n              <i nz-icon nzType=\\\"right\\\" *ngIf=\\\"!item.active\\\" nzTheme=\\\"outline\\\"></i>\\n              <i nz-icon nzType=\\\"down\\\" *ngIf=\\\"item.active\\\" nzTheme=\\\"outline\\\"></i>\\n            </div>\\n\\n            <div class=\\\"col pt-2\\\" (click)=\\\"activeChange(item)\\\">\\n              <h6>{{ item.title }}</h6>\\n            </div>\\n\\n            <div class=\\\"p-1\\\">\\n              <button\\n                class=\\\"ok-btn btn-selecionar\\\"\\n                nz-button\\n                (click)=\\\"onSelect(item)\\\"\\n                [ngStyle]=\\\"{\\n                  'background-color': colorSetting?.primary,\\n                  'border-color': colorSetting?.primary\\n                }\\\"\\n              >\\n                Adicionar\\n              </button>\\n            </div>\\n\\n            <div class=\\\"pl-0\\\">\\n              <button (click)=\\\"onDelete(item)\\\" title=\\\"Excluir\\\" class=\\\"btn btn-trash\\\">\\n                <span class=\\\"btn-inner--icon\\\"><i class=\\\"fa fa-trash-solid position-inherit\\\"></i></span>\\n              </button>\\n            </div>\\n          </div>\\n\\n          <div *ngIf=\\\"item.active && documentType === typesOfDocuments[0]\\\">\\n            <div *ngFor=\\\"let medicament of item.medicaments\\\">\\n              <div *ngIf=\\\"medicament.type === 'industrialized' || medicament.type === 'free-text'\\\">\\n                <nz-divider></nz-divider>\\n                <p><span class=\\\"bold\\\">Nome:</span> {{ medicament.name }}</p>\\n                <p>\\n                  <span class=\\\"bold\\\" *ngIf=\\\"medicament.principle\\\">Princípio ativo:</span>\\n                  {{ medicament.principle }}\\n                </p>\\n                <p>\\n                  <span class=\\\"bold\\\" *ngIf=\\\"medicament.description\\\">Descrição:</span>\\n                  {{ medicament.description }}\\n                </p>\\n                <p><span class=\\\"bold\\\">Quantidade:</span> {{ medicament.prescribedQuantity }}</p>\\n                <p><span class=\\\"bold\\\">Posologia:</span> {{ medicament.dosage }}</p>\\n              </div>\\n              <div *ngIf=\\\"medicament.type === 'text-box'\\\">\\n                <nz-divider></nz-divider>\\n                <p *ngFor=\\\"let text of medicament?.dosage?.split('\\\\n')\\\">{{ text }}</p>\\n              </div>\\n            </div>\\n          </div>\\n          <div *ngIf=\\\"item.active && documentType === typesOfDocuments[1]\\\">\\n            <div *ngFor=\\\"let row of item.examList\\\">\\n              <div>\\n                <p class=\\\"mb-3\\\">Exames:</p>\\n                <p *ngFor=\\\"let exam of row.exams\\\">\\n                  {{ exam.name }} <span *ngIf=\\\"row?.showTuss && exam?.tuss\\\">({{ exam.tuss }})</span>\\n                </p>\\n              </div>\\n              <nz-divider></nz-divider>\\n              <div *ngIf=\\\"getText(item.justification)\\\">\\n                <p *ngFor=\\\"let j of item.justification\\\">{{ j }}</p>\\n              </div>\\n            </div>\\n          </div>\\n          <div *ngIf=\\\"item.active && documentType === typesOfDocuments[2]\\\">\\n            <div *ngIf=\\\"item?.attestationDays && item?.typeOfActivity\\\">\\n              <p class=\\\"mt-2\\\">\\n                Atesto que, necessita de\\n                <span style=\\\"font-weight: bold;\\\">{{\\n                  getLabelAttestationDays(item?.attestationDays)\\n                }}</span>\\n                de afastamento de suas atividades\\n                <span style=\\\"font-weight: bold;\\\">{{\\n                  getLabelTypeOfActivity(item?.typeOfActivity)\\n                }}</span>\\n                por motivo de doença.\\n              </p>\\n            </div>\\n\\n            <div>\\n              <nz-divider></nz-divider>\\n              <p *ngFor=\\\"let text of item?.description\\\">{{ text }}</p>\\n            </div>\\n          </div>\\n          <div *ngIf=\\\"item.active && documentType === typesOfDocuments[3]\\\">\\n            <div>\\n              <br />\\n              <p>{{ getText(item.orientations) }}</p>\\n            </div>\\n          </div>\\n          <app-model-list-favorite-document-cid-view\\n            *ngIf=\\\"item.active\\\"\\n            [item]=\\\"item\\\"\\n          ></app-model-list-favorite-document-cid-view>\\n        </div>\\n      </nz-list-item>\\n    </nz-list>\\n    <br />\\n  </div>\\n</div>\\n<ngx-loading\\n  *ngIf=\\\"loadingSearchMedicament\\\"\\n  [show]=\\\"loading\\\"\\n  [config]=\\\"{ backdropBorderRadius: '3px' }\\\"\\n></ngx-loading>\\n\";","export default \".favorite-document-modal .modal-header {\\n  font-family: \\\"probold\\\";\\n  width: 500px;\\n}\\n.favorite-document-modal .header {\\n  border-bottom: 1px solid #dcdcdc;\\n  background-color: #dcdcdc;\\n  width: 480px;\\n  min-height: 40px;\\n}\\n.favorite-document-modal .header i {\\n  cursor: pointer;\\n}\\n.favorite-document-modal .bold {\\n  font-weight: bold;\\n}\\n.favorite-document-modal p {\\n  font-size: 14px;\\n  margin: 0;\\n}\\n.favorite-document-modal .col {\\n  align-self: center;\\n}\\n@media (max-width: 575px) {\\n  .favorite-document-modal .body.prescription .ant-spin-container,\\n.favorite-document-modal .body.prescription .ant-list-item,\\n.favorite-document-modal .body.prescription .ng-star-inserted {\\n    width: 100%;\\n  }\\n  .favorite-document-modal .col-1 {\\n    display: none;\\n  }\\n  .favorite-document-modal .header.prescription {\\n    position: relative;\\n    width: 100% !important;\\n    margin: 0;\\n    height: auto;\\n    min-height: 42px;\\n  }\\n  .favorite-document-modal .header.prescription h6 {\\n    margin-right: 20px;\\n  }\\n}\\n.favorite-document-modal .action-buttons {\\n  display: flex;\\n  justify-content: center;\\n  align-items: center;\\n}\\n.favorite-document-modal .position-inherit {\\n  position: inherit !important;\\n}\\n.favorite-document-modal textarea {\\n  box-sizing: border-box;\\n  width: 100%;\\n}\\n.favorite-document-modal .btn-selecionar {\\n  color: var(--color-white);\\n  background-color: var(--bg-color-primary);\\n  border-color: var(--bg-color-primary);\\n  box-shadow: 0 4px 6px rgba(50, 50, 93, 0.11), 0 1px 3px rgba(0, 0, 0, 0.08);\\n}\\n.favorite-document-modal .btn-selecionar::-moz-selection {\\n  color: var(--color-white);\\n  background-color: var(--bg-color-secondary);\\n  border-color: var(--bg-color-secondary);\\n}\\n.favorite-document-modal .btn-selecionar:hover,\\n.favorite-document-modal .btn-selecionar:active,\\n.favorite-document-modal .btn-selecionar::selection {\\n  color: var(--color-white);\\n  background-color: var(--bg-color-secondary);\\n  border-color: var(--bg-color-secondary);\\n}\\n.favorite-document-modal .btn-edit,\\n.favorite-document-modal .btn-trash {\\n  padding: 8px;\\n}\\n.prescription ::ng-deep .ant-list-split .ant-list-item {\\n  border-bottom: none !important;\\n}\";","import { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable } from 'rxjs';\nimport { environment } from '@env/environment';\nimport { Attestation } from '@app/shared/models/attestation';\n\nexport const ATTESTATION = `attestation`;\nexport const ATTESTATION_PRESCRIBER = `attestation/prescriber`;\nexport const ATTESTATION_PATIENT_URL = `attestation/patient`;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AttestationService {\n  constructor(private http: HttpClient) {}\n\n  public save(attestation): Observable<any> {\n    if (attestation.code) {\n      return this.http.put(`${environment.apiRoot}${ATTESTATION}/${attestation.code}`, attestation);\n    }\n    return this.http.post(`${environment.apiRoot}${ATTESTATION}`, attestation);\n  }\n\n  public getAllPrescriberAttestations(prescriberId: string): Observable<Attestation[]> {\n    return this.http.get<Attestation[]>(`${environment.apiRoot}${ATTESTATION}`, {\n      params: { prescriberId }\n    });\n  }\n\n  public getAttestationsByPrescriberUserId(prescriberId: string, filter: any): Observable<any> {\n    return this.http.get<any>(`${environment.apiRoot}${ATTESTATION_PRESCRIBER}/${prescriberId}`, {\n      params: filter\n    });\n  }\n\n  public getAllPatientsAttestations(patientId: string) {\n    return this.http.get<Attestation[]>(`${environment.apiRoot}${ATTESTATION}`, {\n      params: { patientId }\n    });\n  }\n\n  getAttestationsByPatientId(patientId: string, filter: any): Observable<any> {\n    return this.http.get<any>(`${environment.apiRoot}${ATTESTATION_PATIENT_URL}/${patientId}`, {\n      params: filter\n    });\n  }\n\n  getAttestation(code: string) {\n    return this.http.get(`${environment.apiRoot}${ATTESTATION}/${code}`);\n  }\n\n  getByFilter(filter: any): Promise<Attestation[]> {\n    return this.http\n      .get<Attestation[]>(`${environment.apiRoot}${ATTESTATION}/filter`, {\n        params: filter\n      })\n      .toPromise();\n  }\n\n  delete(attestationId: number): Observable<any> {\n    return this.http.delete(`${environment.apiRoot}${ATTESTATION}/${attestationId}`);\n  }\n}\n","import { HttpErrorResponse } from '@angular/common/http';\nimport { Component, Input, OnInit } from '@angular/core';\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { markFormGroup } from '@app/utils/markFormGroup';\nimport { BsModalRef } from 'ngx-bootstrap/modal';\nimport { AttestationModelService } from '../../../document/services/attestation-model.service';\nimport { ExamModelService } from '../../../document/services/exam-model.service';\nimport { OrientationModelService } from '../../../document/services/orientation-model.service';\nimport { PrescriptionModelService } from '../../../document/services/prescription-model.service';\nimport { HealthProfessional } from './../../../../shared/models/health-professional';\n\n@Component({\n  selector: 'app-model-add-favorite-prescription',\n  templateUrl: './model-add-favorite-document.component.html',\n  styleUrls: ['./model-add-favorite-document.component.scss']\n})\nexport class ModelAddFavoriteDocumentComponent implements OnInit {\n  readonly HTTP_STATUS_CONFLICT = 409;\n\n  @Input() prescriber: HealthProfessional;\n  @Input() documentType = '';\n  @Input() documentModel: any;\n  @Input() colorSetting: ColorSetting;\n  typesOfDocuments = ['Prescrição', 'Exame', 'Atestado', 'Outros'];\n  loading: boolean;\n  message = '';\n\n  documentModelForm: FormGroup;\n  payload: any;\n  constructor(\n    public modalRef: BsModalRef,\n    private prescriptionModelService: PrescriptionModelService,\n    private orientationModelService: OrientationModelService,\n    private examModelService: ExamModelService,\n    private attestationModelService: AttestationModelService,\n    private notification: AppToastService\n  ) {}\n\n  ngOnInit() {\n    switch (this.documentType) {\n      case this.typesOfDocuments[0]:\n        this.buildPrescriptionForm();\n        break;\n      case this.typesOfDocuments[1]:\n        this.buildExamForm();\n        break;\n      case this.typesOfDocuments[2]:\n        this.buildAttestationForm();\n        break;\n\n      case this.typesOfDocuments[3]:\n        this.buildOrientationForm();\n        break;\n    }\n    this.setDocumentModel();\n  }\n\n  setDocumentModel() {\n    if (this.documentType === this.typesOfDocuments[0]) {\n      this.setPrescritpionModel();\n    } else if (this.documentType === this.typesOfDocuments[1]) {\n      this.setExamModel();\n    } else if (this.documentType === this.typesOfDocuments[2]) {\n      this.setAttestationModel();\n    } else if (this.documentType === this.typesOfDocuments[3]) {\n      this.setOrientationModel();\n    }\n  }\n\n  setPrescritpionModel() {\n    if (this.documentModel) {\n      this.documentModelForm.patchValue({ prescriber: this.prescriber, ...this.documentModel });\n      this.documentModel.medicaments.forEach(m => {\n        this.addPrescription({\n          ...m,\n          nome: m.name,\n          id: m.medicamentId,\n          principio: m.principle,\n          laboratorio: m.laboratory,\n          ean: m.ean,\n          apresentacaoCustomizada: m.description,\n          quantity: m.prescribedQuantity,\n          type: m.type\n        });\n      });\n    }\n  }\n\n  setExamModel() {\n    if (this.documentModel) {\n      this.documentModelForm.patchValue({ prescriber: this.prescriber, ...this.documentModel });\n      if (this.documentModel.justification) {\n        const value = this.documentModel.justification.reduce(\n          (acc, val) => (acc ? `${acc}\\n${val}` : val),\n          ''\n        );\n        this.documentModelForm.get('text').setValue(value);\n      }\n    }\n  }\n\n  setOrientationModel() {\n    if (this.documentModel) {\n      this.documentModelForm.patchValue({\n        titleOrientation: this.documentModel.title,\n        prescriber: this.prescriber,\n        ...this.documentModel\n      });\n      const value = this.documentModel.orientations.reduce(\n        (accumulator, currentValue) => accumulator + '\\n' + currentValue\n      );\n      this.documentModelForm.get('text').setValue(value);\n    }\n  }\n\n  setAttestationModel() {\n    if (this.documentModel) {\n      this.documentModelForm.patchValue({ prescriber: this.prescriber, ...this.documentModel });\n      const value =\n        this.documentModel.description !== ''\n          ? this.documentModel.description.reduce(\n              (accumulator, currentValue) => accumulator + '\\n' + currentValue\n            )\n          : '';\n      this.documentModelForm.get('text').setValue(value);\n    }\n  }\n\n  private buildPrescriptionForm() {\n    this.documentModelForm = new FormGroup({\n      title: new FormControl('', Validators.required),\n      prescriber: new FormControl(''),\n      medication: new FormControl(''),\n      medicaments: new FormArray([], Validators.required),\n      version: new FormControl('BETA'),\n      observation: new FormControl([])\n    });\n  }\n\n  private buildOrientationForm() {\n    this.documentModelForm = new FormGroup({\n      title: new FormControl('', Validators.required),\n      titleOrientation: new FormControl('', Validators.required),\n      prescriber: new FormControl(''),\n      text: new FormControl(''),\n      orientations: new FormControl('', Validators.required),\n      version: new FormControl('BETA')\n    });\n  }\n\n  private buildAttestationForm() {\n    this.documentModelForm = new FormGroup({\n      title: new FormControl('', Validators.required),\n      prescriber: new FormControl(''),\n      text: new FormControl(''),\n      description: new FormControl(''),\n      version: new FormControl('BETA'),\n      attestationDays: new FormControl(),\n      typeOfActivity: new FormControl()\n    });\n  }\n\n  private buildExamForm() {\n    this.documentModelForm = new FormGroup({\n      title: new FormControl('', Validators.required),\n      text: new FormControl(''),\n      version: new FormControl('BETA')\n    });\n  }\n\n  public addPrescription({\n    nome,\n    id,\n    principio,\n    laboratorio,\n    ean,\n    apresentacaoCustomizada,\n    dosage = '',\n    quantity = 1,\n    type,\n    unitOfMeasurement,\n    prescriptionTypeId,\n    typeCr\n  }): void {\n    this.medicamentosFormCtrl.push(\n      this.formMedicamentos({\n        name: nome,\n        medicamentId: id,\n        principle: principio,\n        laboratory: laboratorio,\n        ean: ean,\n        description: apresentacaoCustomizada,\n        dosage,\n        quantity,\n        type,\n        unitOfMeasurement,\n        prescriptionTypeId,\n        typeCr\n      })\n    );\n    this.documentModelForm.get('medication').setValue(null);\n  }\n\n  formMedicamentos({\n    name,\n    medicamentId,\n    principle,\n    laboratory,\n    ean,\n    quantity,\n    description,\n    dosage,\n    type,\n    unitOfMeasurement,\n    prescriptionTypeId,\n    typeCr\n  }): FormGroup {\n    return new FormGroup({\n      name: new FormControl(name),\n      medicamentId: new FormControl(medicamentId),\n      prescribedQuantity: new FormControl(quantity),\n      dosage: new FormControl(dosage),\n      description: new FormControl(description),\n      principle: new FormControl(principle),\n      laboratory: new FormControl(laboratory),\n      ean: new FormControl(ean),\n      type: new FormControl(type),\n      unitOfMeasurement: new FormControl(unitOfMeasurement),\n      prescriptionTypeId: new FormControl(prescriptionTypeId),\n      typeCr: new FormControl(typeCr)\n    });\n  }\n\n  getText(arrayText: any[]) {\n    return arrayText.reduce((acc, val) => (acc ? `${acc}\\n${val}` : val), '');\n  }\n\n  saveDocumentModel = () => {\n    try {\n      markFormGroup(this.documentModelForm);\n      this.loading = true;\n      const payload = this.documentModelForm.value;\n      payload.cid = this.documentModel.cid\n        ? {\n            ...this.documentModel.cid,\n            items: this.documentModel.cid.items.map(item => item.id)\n          }\n        : null;\n\n      if (this.documentModelForm.valid) {\n        switch (this.documentType) {\n          case this.typesOfDocuments[0]:\n            this.prescriptionModelService\n              .create(payload, this.prescriber && this.prescriber.userId)\n              .then(() => this.onSuccessCreateFavorite())\n              .catch(error => this.onFailureCreateFavorite(error));\n            break;\n\n          case this.typesOfDocuments[1]:\n            this.examModelService\n              .create({\n                ...this.documentModel,\n                ...payload\n              })\n              .then(() => this.onSuccessCreateFavorite())\n              .catch(error => this.onFailureCreateFavorite(error));\n            break;\n\n          case this.typesOfDocuments[2]:\n            this.attestationModelService\n              .create(payload)\n              .then(() => this.onSuccessCreateFavorite())\n              .catch(error => this.onFailureCreateFavorite(error));\n            break;\n\n          case this.typesOfDocuments[3]:\n            this.orientationModelService\n              .create(payload)\n              .then(() => this.onSuccessCreateFavorite())\n              .catch(error => this.onFailureCreateFavorite(error));\n            break;\n        }\n      }\n      this.loading = false;\n    } catch (err) {\n      this.loading = false;\n      this.message = err.error.message;\n      console.log(err);\n    }\n  };\n\n  onSuccessCreateFavorite() {\n    this.modalRef.hide();\n    this.notification.notify('success', 'Sucesso', `Modelo ${this.documentType} salvo com sucesso`);\n  }\n\n  onFailureCreateFavorite(error: HttpErrorResponse) {\n    if (error.status === this.HTTP_STATUS_CONFLICT) {\n      this.notification.notify(\n        'warning',\n        'Atenção',\n        'Já existe um modelo com este título. Digite outro título'\n      );\n    } else {\n      this.notification.notify('warning', 'Error', 'Ocorreu um erro ao tentar cadastrado modelo.');\n    }\n  }\n\n  get medicamentosFormCtrl(): FormArray {\n    return <FormArray>this.documentModelForm.get('medicaments');\n  }\n}\n","export default \"<div\\n  theme\\n  class=\\\"modal-header\\\"\\n  [ngStyle]=\\\"{\\n    'background-color': colorSetting?.secondary,\\n    'border-color': colorSetting?.secondary\\n  }\\\"\\n>\\n  <h4 class=\\\"modal-title pull-left text-white\\\">Cadastrar novo modelo</h4>\\n  <button type=\\\"button\\\" class=\\\"close pull-right\\\" aria-label=\\\"Close\\\" (click)=\\\"modalRef.hide()\\\">\\n    <span aria-hidden=\\\"true\\\">&times;</span>\\n  </button>\\n</div>\\n<div>\\n  <div class=\\\"modal-body\\\">\\n    <div *ngIf=\\\"message\\\">\\n      <nz-alert nzType=\\\"warning\\\" [nzMessage]=\\\"message\\\"></nz-alert>\\n      <br />\\n    </div>\\n\\n    <div class=\\\"prescription\\\" [formGroup]=\\\"documentModelForm\\\">\\n      <nz-form-item>\\n        <nz-form-label nzFor=\\\"title\\\" theme\\n          ><span [ngStyle]=\\\"{ color: colorSetting?.primary }\\\">Título</span\\n          ><span class=\\\"mandatory\\\"> *</span></nz-form-label\\n        >\\n        <nz-form-control nzHasFeedback>\\n          <input\\n            nz-input\\n            formControlName=\\\"title\\\"\\n            attr.id=\\\"title\\\"\\n            placeholder=\\\"Digite o título do modelo...\\\"\\n            [ngStyle]=\\\"{\\n              'background-color': colorSetting?.inputBackground,\\n              'border-color': colorSetting?.inputBorder\\n            }\\\"\\n            theme\\n          />\\n          <nz-form-explain\\n            *ngIf=\\\"documentModelForm.get('title').dirty && documentModelForm.get('title').errors\\\"\\n          >\\n            <ng-container *ngIf=\\\"documentModelForm.get('title').hasError('required')\\\">\\n              Campo obrigatório, por favor digite o título.\\n            </ng-container>\\n          </nz-form-explain>\\n        </nz-form-control>\\n      </nz-form-item>\\n    </div>\\n  </div>\\n  <div class=\\\"modal-footer\\\">\\n    <button\\n      class=\\\"ok-btn btn-cancel\\\"\\n      nz-button\\n      (click)=\\\"modalRef.hide()\\\"\\n      theme\\n      [ngStyle]=\\\"{ color: colorSetting?.primary }\\\"\\n    >\\n      Cancelar\\n    </button>\\n    <button\\n      theme\\n      class=\\\"ok-btn btn-salvar\\\"\\n      nz-button\\n      (click)=\\\"saveDocumentModel()\\\"\\n      [disabled]=\\\"!documentModelForm.valid\\\"\\n      [ngStyle]=\\\"{\\n        'background-color': colorSetting?.primary,\\n        'border-color': colorSetting?.primary\\n      }\\\"\\n    >\\n      Salvar <i class=\\\"fa\\\"></i>\\n    </button>\\n  </div>\\n</div>\\n<ngx-loading [show]=\\\"loading\\\" [config]=\\\"{ backdropBorderRadius: '3px' }\\\"></ngx-loading>\\n\";","export default \".modal-body {\\n  padding: 40px;\\n}\\n.modal-body input {\\n  border-radius: 10px;\\n}\\n.modal-body .btn-save {\\n  float: right;\\n  padding-top: 7px;\\n  padding-bottom: 7px;\\n  margin-top: 13px;\\n  margin-bottom: 5px;\\n}\\n.modal-body i {\\n  font-size: 24px;\\n}\\n.modal-body .mandatory {\\n  color: red;\\n}\\n.modal-body input::-webkit-input-placeholder {\\n  color: #bdc2c7;\\n}\\n::ng-deep .ant-select-selection {\\n  height: 100%;\\n}\\n.modal-header {\\n  margin: 0;\\n  font-family: \\\"probold\\\";\\n  width: 950px !important;\\n}\\n.modal-footer {\\n  margin: 0;\\n}\\n.prescription ::ng-deep .ant-drawer-left.ant-drawer-open .ant-drawer-content-wrapper {\\n  box-shadow: 0 9px 18px rgba(0, 0, 0, 0.18);\\n}\\n.prescription ::ng-deep .ant-drawer.ant-drawer-open .ant-drawer-mask {\\n  opacity: 0.11;\\n}\\n.prescription ::ng-deep .ant-drawer-body {\\n  padding-top: 0;\\n  height: 90vh;\\n  overflow: auto;\\n}\\n.prescription ::ng-deep .ant-drawer-open {\\n  top: 80px;\\n}\\n.prescription ::ng-deep .menu-drawer {\\n  top: 80px;\\n  background-color: #007260;\\n  border: 1px solid #007260;\\n}\\n.prescription ::ng-deep .menu-drawer .ant-drawer-content {\\n  background-color: transparent;\\n}\\n.prescription ::ng-deep .inner-menu {\\n  display: flex;\\n  flex-direction: column;\\n}\\n.prescription ::ng-deep .inner-menu .menu-icon {\\n  align-self: flex-end;\\n  margin: 20px 0;\\n}\\n.prescription ::ng-deep .inner-menu .menu-icon .fa {\\n  font-size: 20px;\\n  color: white;\\n}\\n.prescription ::ng-deep .inner-menu .menu li {\\n  padding: 20px 0;\\n}\\n.prescription ::ng-deep .inner-menu .menu a {\\n  color: white;\\n  font-family: \\\"problack\\\";\\n  font-size: 18px;\\n  text-transform: uppercase;\\n}\\n.prescription ::ng-deep .inner-menu .menu a:focus {\\n  text-decoration: none;\\n}\\n.prescription ::ng-deep .inner-menu .menu a .fa {\\n  margin-right: 10px;\\n}\\n.prescription ::ng-deep .medicationAutoComplete {\\n  margin-top: 17px;\\n}\\n.prescription .toolbar {\\n  display: flex;\\n}\\n.prescription .toolbar .menu-toggler {\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  padding: 0;\\n  border-radius: 0;\\n  width: 80px;\\n  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));\\n  margin: 0;\\n}\\n.prescription .toolbar .menu-toggler .fa:before {\\n  font-size: 22px;\\n}\\n.prescription .toolbar .menu-toggler,\\n.prescription .toolbar .toolbar-options {\\n  height: 80px;\\n}\\n.prescription .toolbar .toolbar-menu {\\n  flex: 1;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options {\\n  background-color: #f5f5f5;\\n  display: flex;\\n  align-items: center;\\n  justify-content: flex-end;\\n  padding-right: 40px;\\n  padding-left: 60px;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options .btn {\\n  font-family: \\\"problack\\\", sans-serif;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options .btn-green {\\n  background-color: #87ebe1;\\n  border-color: #87ebe1;\\n  color: #1b403a;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options .btn-default {\\n  background-color: #afafaf;\\n  border-color: #afafaf;\\n  color: white;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-tags {\\n  background-color: #ebebeb;\\n  height: 40px;\\n  border-radius: 0 0 10px 10px;\\n}\\n.prescription .add-prescription {\\n  padding: 20px 0;\\n  border-top: 1px solid #f5f5f5;\\n  min-height: 81px;\\n  display: flex;\\n  justify-content: center;\\n}\\n.prescription .add-prescription.adding-bg {\\n  background-color: #f5f5f5;\\n  border-top: 1px solid transparent;\\n}\\n.prescription .add-prescription .btn-add-name {\\n  background-color: var(--bg-color-primary);\\n  border: 1px solid var(--bg-color-primary);\\n  color: var(--color-white);\\n  padding: 0px 10px;\\n  margin: 10px;\\n}\\n.prescription .add-prescription .btn-add {\\n  display: flex;\\n  padding: 0 0 0 1.25rem;\\n  height: 40px;\\n  align-items: center;\\n  border-radius: 10px;\\n  overflow: hidden;\\n  border: 0;\\n  font-family: \\\"probold\\\", sans-serif;\\n}\\n.prescription .add-prescription .btn-add .btn-inner--icon {\\n  background-color: #1b403a;\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  height: 40px;\\n  width: 50px;\\n}\\n.prescription .btn-add-name {\\n  padding: 0px 10px;\\n  margin: 10px;\\n}\\n.prescription .medicationNameInput {\\n  background-color: transparent;\\n  border-color: transparent;\\n  height: 100%;\\n  box-shadow: none;\\n}\\n.prescription .free-prescription {\\n  display: flex;\\n}\\n.prescription .free-prescription .break-line {\\n  margin-left: 7px;\\n  white-space: pre-wrap;\\n}\\n.prescription textarea {\\n  resize: none;\\n  background-color: transparent;\\n  border: 0;\\n  border-radius: 0;\\n  box-shadow: none;\\n  padding-left: 12px;\\n  color: #4d4d4d;\\n  font-size: 18px;\\n}\\n.prescription textarea:hover, .prescription textarea:focus {\\n  border-color: transparent;\\n  box-shadow: none;\\n}\\ntextarea {\\n  box-sizing: border-box;\\n  width: 100%;\\n}\\n.btn-salvar,\\n.btn-salvar:hover {\\n  color: var(--color-white);\\n  background-color: var(--bg-color-primary);\\n  border-color: var(--bg-color-primary);\\n}\";","import { Orientation } from './../../../../shared/models/orientation';\nimport { Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { HttpClient } from '@angular/common/http';\nimport { environment } from '@env/environment';\n\nconst ORIENTATION_URL = 'orientation';\nexport const EXAM_PRESCRIBER = `orientation/prescriber`;\nconst EXAM_PATIENT = `orientation/patient`;\n@Injectable({\n  providedIn: 'root'\n})\nexport class OrientationService {\n  constructor(private http: HttpClient) {}\n\n  public save(orientation: Orientation) {\n    if (orientation.code) {\n      return this.http.put(`${environment.apiRoot}${ORIENTATION_URL}/${orientation.code}`, orientation);\n    }\n    return this.http.post(`${environment.apiRoot}${ORIENTATION_URL}`, orientation);\n  }\n\n  public getOrientationsByPrescriberUserId(prescriberId: string, filter: any): Observable<any> {\n    return this.http.get<any>(`${environment.apiRoot}${EXAM_PRESCRIBER}/${prescriberId}`, {\n      params: filter\n    });\n  }\n\n  public getAllPatientExams(patientId: string) {\n    return this.http.get<Orientation[]>(`${environment.apiRoot}${ORIENTATION_URL}`, {\n      params: { patientId }\n    });\n  }\n\n  getOrientationsByPatientId(patientId: string, filter: any): Observable<any> {\n    return this.http.get<any>(`${environment.apiRoot}${EXAM_PATIENT}/${patientId}`, { params: filter });\n  }\n\n  getOrientation(code: string) {\n    return this.http.get(`${environment.apiRoot}${ORIENTATION_URL}/${code}`);\n  }\n\n  getByFilter(filter: any): Promise<Orientation[]> {\n    return this.http\n      .get<Orientation[]>(`${environment.apiRoot}${ORIENTATION_URL}/filter`, {\n        params: filter\n      })\n      .toPromise();\n  }\n\n  delete(orientationId: number): Observable<any> {\n    return this.http.delete(`${environment.apiRoot}${ORIENTATION_URL}/${orientationId}`);\n  }\n}\n","import {\n  AfterContentChecked,\n  ChangeDetectorRef,\n  Component,\n  HostListener,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  ViewChild\n} from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { AuthService } from '@app/core/services/auth.service';\nimport { CoreService } from '@app/core/services/core.service';\nimport { PrescriptionService } from '@app/modules/document/services/prescription.service';\nimport { HealthProfessionalService } from '@app/modules/health-professional/services/health-professional.service';\nimport { PatientsService } from '@app/modules/patients/services/patients.service';\nimport { ManipulatedProfileService } from '@app/modules/personalized-medications/services/manipulated-profile.service';\nimport { ModalSendDocumentComponent } from '@app/shared/components/modal-send-document/modal-send-document.component';\nimport { DateUtils } from '@app/shared/data/DateUtils';\nimport { Comercial, HealthProfessional, Patient } from '@app/shared/models';\nimport { User } from '@app/shared/models/decodedLoginToken';\nimport { PetPatient } from '@app/shared/models/pet-patient';\nimport { OnlyNumbersPipe } from '@app/shared/pipes';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { StateService } from '@app/shared/services/state.service';\nimport { ThemeService } from '@app/theme';\nimport { environment } from '@env/environment';\nimport _ from 'lodash';\nimport { NzModalService } from 'ng-zorro-antd/modal';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { Observable, ReplaySubject, of } from 'rxjs';\nimport {\n  catchError,\n  debounceTime,\n  distinctUntilChanged,\n  map,\n  startWith,\n  switchMap,\n  take,\n  takeUntil,\n  tap\n} from 'rxjs/operators';\nimport { ModalListVictaProtocolComponent } from '../document/pages/modal-list-victa-protocol/modal-list-victa-protocol.component';\nimport { AttestationModelService } from '../document/services/attestation-model.service';\nimport { DocumentService } from '../document/services/document.service';\nimport { ExamModelService } from '../document/services/exam-model.service';\nimport { ExamService } from '../document/services/exam.service';\nimport { OrientationModelService } from '../document/services/orientation-model.service';\nimport { PrescriptionModelService } from '../document/services/prescription-model.service';\nimport { VictaProtocolService } from '../document/services/victa-protocol.service';\nimport { ModalEditPetComponent } from '../patients/pages/modal-edit-pet/modal-edit-pet.component';\nimport { ModalSelectPetComponent } from '../patients/pages/modal-select-pet/modal-select-pet.component';\nimport { PetPatientService } from '../patients/services/pet-patient.service';\nimport { ModalAddPatientComponent } from './../patients/pages/modal-add-patient/modal-add-patient.component';\nimport { ModalSearchComponent } from './../patients/pages/modal-search/modal-search.component';\nimport { AttestationService } from './pages/attestation/attestation.service';\nimport { ModalIframeComponent } from './pages/modal-iframe/modal-iframe.component';\nimport { ModalSelectLayoutComponent } from './pages/modal-select-layout/modal-select-layout.component';\nimport { ModelAddFavoriteDocumentComponent } from './pages/model-add-favorite-document/model-add-favorite-document.component';\nimport { ModelListFavoriteDocumentComponent } from './pages/model-list-favorite-document/model-list-favorite-document.component';\nimport { OrientationService } from './pages/orientation/orientation.service';\nimport { nativeAsync } from '@app/shared/decorators/nativeAsync';\nimport { Prescription } from '@app/shared/models/prescription';\nimport { CrService } from '../document/services/cr.service';\nimport { Base64Utils } from '@app/shared/utils/base64.utils';\n\ntype ReponsePlusDocuments = {\n  id: number;\n  downloadLink: string;\n};\n\ntype ReponsePlus = {\n  message: string;\n  documents: ReponsePlusDocuments[];\n};\n@Component({\n  selector: 'app-document',\n  templateUrl: './document.component.html',\n  styleUrls: ['./document.component.scss']\n})\nexport class DocumentComponent implements OnInit, OnDestroy, AfterContentChecked {\n  actualDate = new Date();\n  nzBackfill = false;\n  isPatientNotFound = false;\n  private patientCpf = '';\n  local: Comercial;\n  search = true;\n  loading = false;\n  signed = false;\n\n  prescriber: HealthProfessional;\n  patient: Patient;\n  patients: Patient[];\n\n  documentForm: FormGroup;\n  patientForm: FormGroup;\n  document: any;\n  manipulatedProfile: any;\n  selectedDocumentModel: any;\n  modelId: any;\n\n  adding = false;\n  typesOfDocuments = ['Prescrição', 'Exame', 'Atestado', 'Outros', 'Prescrição Rennova'];\n  documentTypes = {\n    prescription: 'Prescrição',\n    exam: 'Exame',\n    attestation: 'Atestado',\n    orientation: 'Outros',\n    'prescription-renew': 'Prescrição Rennova'\n  };\n  documentType: string;\n  tabDefault = 'Prescrição';\n  backendVersion$: Observable<string>;\n  isMobile = false;\n  isLoadingSearchPatient = false;\n  loadingSearchMedicament = false;\n\n  @ViewChild('addPatient')\n  addPatient: any;\n\n  @ViewChild(ModalSendDocumentComponent, { static: true })\n  modalSendDocumentComponent: ModalSendDocumentComponent;\n\n  @ViewChild(ModalSelectLayoutComponent, { static: true })\n  modalSelectLayout: ModalSelectLayoutComponent;\n\n  @ViewChild(ModalIframeComponent, { static: true })\n  modalIframe: ModalIframeComponent;\n\n  private destroyed$: ReplaySubject<boolean> = new ReplaySubject<boolean>();\n\n  @HostListener('window:resize', ['$event'])\n  onResize(event) {\n    this.isMobile = this.coreService.isViewPortMobile();\n  }\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private fb: FormBuilder,\n    private healthProfessionalService: HealthProfessionalService,\n    private patientService: PatientsService,\n    private petService: PetPatientService,\n    private prescriptionService: PrescriptionService,\n    private attestationService: AttestationService,\n    private examService: ExamService,\n    private orientationService: OrientationService,\n    private prescriptionModelService: PrescriptionModelService,\n    private attestationModelService: AttestationModelService,\n    private examModelService: ExamModelService,\n    private orientationModelService: OrientationModelService,\n    private victaProtocolService: VictaProtocolService,\n    private notification: AppToastService,\n    private authService: AuthService,\n    private documentService: DocumentService,\n    private manipulatedProfileService: ManipulatedProfileService,\n    private modalService: BsModalService,\n    private nzModalService: NzModalService,\n    private themeService: ThemeService,\n    private coreService: CoreService,\n    private cdf: ChangeDetectorRef,\n    private stateService: StateService,\n    private zone: NgZone,\n    private crService: CrService\n  ) {\n    this.documentForm = this.fb.group({});\n    this.patientForm = this.fb.group({\n      _id: [null],\n      cpf: [null],\n      name: ['', [Validators.required]]\n    });\n    this.backendVersion$ = this.coreService.getBackendVersion();\n  }\n\n  @nativeAsync\n  async ngOnInit() {\n    this.tabDefault = this.rennovaFeature ? 'Prescrição Rennova' : 'Prescrição';\n    this.documentType = this.rennovaFeature ? this.typesOfDocuments[4] : this.typesOfDocuments[0];\n\n    this.loading = true;\n\n    const patient = JSON.parse(localStorage.getItem('patient'));\n    if (patient) {\n      this.patientForm.patchValue(patient);\n      this.patient = patient;\n      localStorage.removeItem('patient');\n    }\n\n    this.getPrescriberData(this.user._id);\n    const {\n      code,\n      response,\n      documentType,\n      profileId,\n      patientId,\n      petId\n    } = this.route.snapshot.queryParams;\n\n    if (code && response && (patientId || petId)) {\n      const responsePlus = Base64Utils.decode<ReponsePlus>(response);\n      if (responsePlus.message === 'Signed OK' || responsePlus.message === 'Signed local OK') {\n        this.modalSendDocumentComponent.createTplModal(code, patientId || petId, { isPet: !!petId });\n      } else {\n        this.notification.notify('error', 'Erro ao assinar documento!');\n        console.log(response);\n        this.router.navigate(['/document', code, 'edit']);\n      }\n    }\n\n    if (profileId) {\n      this.getManipulatedProfile(profileId);\n    }\n\n    const id = this.route.snapshot.params.id || (!response && code);\n    if (id) {\n      try {\n        const document = await this.documentService.getDocument(id, documentType);\n        if (document.document === 'prescription') {\n          await this.updateMedicaments(document);\n        }\n        this.fillForm(document);\n\n        if (this.documentService.documentTypeSelected) {\n          this.documentType = this.documentService.documentTypeSelected;\n          this.tabDefault = this.documentService.documentTypeSelected;\n        } else {\n          this.documentType = this.rennovaFeature ? 'Prescrição Rennova' : document.type;\n          this.tabDefault = this.rennovaFeature ? 'Prescrição Rennova' : document.type;\n        }\n        this.loading = false;\n        this.cdf.detectChanges();\n      } catch (err) {\n        console.error(err);\n        this.router.navigate(['/document/new']);\n      }\n    }\n\n    this.onChange();\n    this.modelId = this.route.snapshot.params.modelId;\n    const type = this.route.snapshot.params.documentType;\n\n    if (this.modelId) {\n      this.adding = true;\n      this.documentType = this.documentTypes[type];\n      this.selectedDocumentModel = await this.getDocumentModel();\n    } else if (this.documentService.patientForm) {\n      this.adding = true;\n      this.patientForm = this.documentService.patientForm;\n      this.documentType = this.documentService.documentTypeSelected;\n      this.tabDefault = this.documentService.documentTypeSelected;\n      this.documentService.patientForm = null;\n    }\n\n    this.loading = false;\n    this.cdf.detectChanges();\n  }\n\n  ngAfterContentChecked(): void {\n    this.cdf.detectChanges();\n  }\n\n  get user(): User {\n    return this.authService.user();\n  }\n\n  get patientRecordFeature(): boolean {\n    return this.user && this.user.features.some(f => f.name === 'Prontuário');\n  }\n\n  get victaFeature(): boolean {\n    return this.user && this.user.features.some(f => f.name === 'Victa');\n  }\n\n  get sereneFeature() {\n    return this.user && this.user.features.some(f => f.name === 'Serene');\n  }\n\n  get rennovaFeature(): boolean {\n    return (\n      this.user &&\n      this.user.features.some(f => f.name === 'Rennova') &&\n      this.stateService.data &&\n      this.stateService.data.isRennova\n    );\n  }\n\n  get imprimirSemAssinarFeature() {\n    return this.user && this.user.features.some(f => f.name === 'Imprimir Sem Assinar');\n  }\n\n  get frontendVersion(): string {\n    return this.coreService.frontendVersion;\n  }\n\n  get isVeterinarian(): boolean {\n    return Boolean(this.route.snapshot.data['isVeterinarian']);\n  }\n\n  get showCpfText() {\n    return (this.patient && !this.patient.cpf) || this.isVeterinarian\n      ? 'Mostrar CPF do Responsável'\n      : 'Mostrar CPF do Paciente';\n  }\n\n  get namePatient(): string {\n    return this.patientForm.get('name').value;\n  }\n\n  private getManipulatedProfile(profileId) {\n    this.manipulatedProfileService.getManipulatedProfileById(profileId).subscribe(manipulatedProfile => {\n      this.patientForm.patchValue({ ...manipulatedProfile.patient });\n      this.manipulatedProfile = manipulatedProfile;\n      this.typesOfDocuments = [this.typesOfDocuments[0]];\n      this.adding = true;\n      this.patientForm.disable();\n    });\n  }\n\n  @nativeAsync\n  private async getDocumentModel() {\n    let documentsModel: any;\n\n    switch (this.documentType) {\n      case this.typesOfDocuments[0]:\n        documentsModel = await this.prescriptionModelService.getById(this.modelId);\n        break;\n      case this.typesOfDocuments[1]:\n        documentsModel = await this.examModelService.getById(this.modelId);\n        break;\n      case this.typesOfDocuments[2]:\n        documentsModel = await this.attestationModelService.getById(this.modelId);\n        break;\n      case this.typesOfDocuments[3]:\n        documentsModel = await this.orientationModelService.getById(this.modelId);\n        break;\n    }\n    return documentsModel;\n  }\n\n  get examList(): void {\n    if (this.selectedDocumentModel) {\n      return this.selectedDocumentModel.examList;\n    }\n    return this.document && this.document.examList;\n  }\n\n  private fillForm(document: any) {\n    this.local = document.local;\n    this.prescriber = document.healthProfessional;\n    this.patientForm.patchValue(document.patient || document.pet);\n    this.patient = document.patient || document.pet;\n\n    this.document = document;\n    if (this.route.snapshot.routeConfig.path === ':id/edit') {\n      this.signed = document.status === 'Assinada';\n      if (document.manipulatedprofile) {\n        this.typesOfDocuments = [this.typesOfDocuments[0]];\n        this.patientForm.disable();\n      }\n    } else {\n      delete document.code;\n      delete document.status;\n    }\n\n    this.toggleAdding();\n  }\n\n  private getPrescriberData(userId: string) {\n    this.healthProfessionalService.getHealthProfessional(userId).subscribe(prescriber => {\n      this.prescriber = prescriber;\n      this.local = this.prescriber && this.prescriber.commercialData[0];\n    });\n  }\n\n  showModalSearch(cpf?: string) {\n    const initialState = {\n      user: this.user,\n      prescriber: this.prescriber,\n      addPatient: true,\n      cpf\n    };\n    const modal = this.modalService.show(ModalSearchComponent, {\n      initialState,\n      backdrop: 'static',\n      keyboard: false\n    });\n\n    modal.content.updateListPatientEvent.subscribe(patient => {\n      this.patientForm.patchValue(patient);\n      this.onChangePatient(patient);\n      this.patient = patient;\n      this.documentService.patientForm = this.patientForm;\n    });\n    modal.content.openModalAddPatientEvent.subscribe(consult => this.showModalAddPatient(consult));\n    modal.content.openModalSelectPetEvent.subscribe(consult => this.showModalSelectPet(consult));\n    modal.content.loadingSpinnerEvent.subscribe(loading => (this.loading = loading));\n  }\n\n  private showModalAddPatient(consult) {\n    const initialState = {\n      prescriber: this.prescriber,\n      patient: consult.patient,\n      isResponsible: consult.isResponsible,\n      existingPatient: consult.existingPatient\n    };\n    const modal = this.modalService.show(ModalAddPatientComponent, {\n      class: 'modal-lg',\n      initialState,\n      backdrop: 'static',\n      keyboard: false\n    });\n    modal.content.updateListPatientEvent.subscribe(patient => {\n      this.patientForm.patchValue(patient);\n      this.patient = patient;\n      this.documentService.patientForm = this.patientForm;\n      this.patientForm.get('_id').setValue(patient._id);\n      this.adding = true;\n    });\n  }\n\n  private showModalSelectPet(consult) {\n    const initialState = {\n      prescriber: this.prescriber,\n      pets: consult.patient.pets,\n      responsible: consult.patient\n    };\n    const modal = this.modalService.show(ModalSelectPetComponent, {\n      initialState,\n      backdrop: 'static',\n      keyboard: false\n    });\n\n    modal.content.submit.subscribe(({ pet, isAdding }) => {\n      this.patientForm.patchValue(pet);\n      this.patient = pet;\n      if (!isAdding) {\n        this.onChangePatient(pet);\n      }\n\n      modal.hide();\n    });\n  }\n\n  toggleAdding() {\n    if (this.patientForm.get('_id').value === null) {\n      this.notification.notify('warning', 'Aviso', 'Você precisa selecionar um paciente para iniciar');\n    } else {\n      this.adding = !this.adding;\n    }\n  }\n\n  onChangePatient(patient): void {\n    if (!patient._id) {\n      this.showModalSearch(this.patientCpf);\n    } else if (this.isVeterinarian) {\n      const { doNotShowAgainPetDataConfirmationModal } = patient;\n\n      if (!doNotShowAgainPetDataConfirmationModal) {\n        this.openEditPetDataModal(patient);\n      } else {\n        this.updatePatientInformation(patient);\n      }\n    } else {\n      this.updatePatientInformation(patient);\n    }\n  }\n\n  updatePatientInformation(patient: any): void {\n    this.patient = patient;\n    this.patientForm.get('_id').setValue(patient._id);\n    this.adding = true;\n    this.documentService.patientForm = this.patientForm;\n  }\n\n  openEditPetDataModal(pet) {\n    const initialState = { pet, isVeterinarian: true, isConfirmation: false };\n\n    const modal = this.modalService.show(ModalEditPetComponent, {\n      initialState,\n      class: '',\n      backdrop: 'static',\n      keyboard: false\n    });\n\n    modal.content.submit.subscribe(p => {\n      this.petService.update(p._id, p, this.prescriber._id).subscribe(\n        () => {\n          this.patient = p;\n          this.patientForm.patchValue(this.patient, { emitEvent: false });\n          this.adding = true;\n          this.healthProfessionalService\n            .getPetsByResponsible(p.responsible._id)\n            .subscribe(prescriberPets => {\n              const hasDependent = prescriberPets.some(p => p._id === pet._id);\n              if (!hasDependent) {\n                this.addPetPatient(p);\n              }\n            });\n          modal.hide();\n          this.notification.notify('success', 'Sucesso', 'Pet salvo com sucesso!');\n        },\n        err => {\n          console.error(err);\n          this.notification.notify('error', 'Aviso', 'Erro ao salvar pet');\n        }\n      );\n    });\n\n    modal.content.onClose.subscribe(() => {\n      this.patientForm.reset();\n      this.patient = null;\n    });\n  }\n\n  @nativeAsync\n  async addPetPatient(pet: PetPatient) {\n    try {\n      await this.healthProfessionalService.addPetPatient(pet._id).toPromise();\n    } catch (err) {\n      console.error(err);\n    }\n  }\n\n  handleCancel() {\n    this.patients = [];\n    this.patientForm\n      .get('name')\n      .setValue(this.patientForm.get('name').value.replace(/(Adicionar paciente )/gim, ''));\n  }\n\n  onChange(): void {\n    let inputValue = '';\n\n    this.patientForm\n      .get('name')\n      .valueChanges.pipe(\n        debounceTime(300),\n        distinctUntilChanged(),\n        tap(value => (inputValue = value)),\n        switchMap(value => this.getPatients(value)),\n        map((res: any) => {\n          if (res) {\n            if (this.isVeterinarian) {\n              const { pets, patients } = res;\n              if (pets) {\n                // get pet by cpf\n                if (pets._id) {\n                  return [pets];\n                }\n\n                // get pets by name\n                if (pets.length > 0) {\n                  return pets;\n                }\n              }\n\n              // no pets but patients (responsible) may have been found\n              return this.handleResponse(inputValue, !!patients);\n            }\n\n            // get patient by cpf\n            if (res._id) {\n              return [res];\n            }\n\n            // get patients by name\n            if (res.length > 0) {\n              return res;\n            }\n\n            // no patients\n            return this.handleResponse(inputValue);\n          } else {\n            this.patientForm.get('_id').setValue(null);\n          }\n        }),\n        takeUntil(this.destroyed$),\n        catchError((err, source) => {\n          let arr = [];\n          if (err.status === 404) {\n            arr = this.handleResponse(inputValue);\n          }\n          return source.pipe(startWith(arr));\n        })\n      )\n      .subscribe(patients => {\n        this.patients = patients;\n      });\n  }\n\n  private onlyNumbers(value: String): Boolean {\n    return value.match(/^[0-9]+$/) != null;\n  }\n\n  private getPatients(value: string) {\n    if (!value || value.length < 3) {\n      return of(null);\n    }\n\n    if (!value || value.length < 3) {\n      return of(null);\n    }\n\n    const valueWithoutCharacters = new OnlyNumbersPipe().transform(value);\n    const onlyNumbers = this.onlyNumbers(valueWithoutCharacters);\n\n    const fullCpf = onlyNumbers && valueWithoutCharacters.length === 11;\n\n    if (this.isVeterinarian) {\n      if (fullCpf) {\n        // get pet by cpf\n        return this.petService.getPetsByResponsibleCpf(valueWithoutCharacters).pipe(\n          map(res => ({ pets: res })),\n          switchMap(res => {\n            if (res.pets.length) {\n              return of(res);\n            }\n            // if there are no pets, then try to get some patient by cpf\n            return this.patientService\n              .getPatientByCpf(valueWithoutCharacters)\n              .pipe(map(res1 => ({ patients: res1 })));\n          })\n        );\n      }\n\n      // get pets by name\n      return this.healthProfessionalService.getPets(value).pipe(map(res => ({ pets: res })));\n    }\n\n    if (fullCpf) {\n      return this.patientService.getPatientByCpf(valueWithoutCharacters);\n    }\n\n    return this.healthProfessionalService.getPatientsByUserId(value, this.user._id);\n  }\n\n  private handleResponse(patientInfo: string, responsibleExists = false) {\n    const cpf = new OnlyNumbersPipe().transform(patientInfo);\n    const isOnlyNumbers = this.onlyNumbers(cpf);\n\n    if (!isOnlyNumbers) {\n      if (this.isVeterinarian) {\n        return [\n          {\n            cpf: '-1',\n            fullname:\n              'Você não possui esse paciente em sua lista de pacientes. ' +\n              'Digite o CPF completo para prescrever uma receita e o adicionaremos automaticamente à sua lista.'\n          }\n        ];\n      }\n      return [\n        {\n          cpf: '-1',\n          fullname:\n            'Você não possui esse paciente em sua lista de pacientes. ' +\n            'Digite o CPF completo para prescrever uma receita e o adicionaremos automaticamente à sua lista.'\n        }\n      ];\n    }\n\n    if (isOnlyNumbers && cpf.length === 11) {\n      this.patientCpf = cpf;\n      let fullname = `Paciente com CPF ${patientInfo} não localizado na base. Deseja adicionar paciente?`;\n      if (this.isVeterinarian) {\n        if (responsibleExists) {\n          fullname = `Responsável/Tutor com CPF ${patientInfo} já é cadastrado na base. Deseja adicionar?`;\n        } else {\n          fullname = `Responsável/Tutor com CPF ${patientInfo} não cadastrado na base. Deseja adicionar?`;\n        }\n      }\n\n      return [{ cpf: '-1', fullname }];\n    }\n  }\n\n  setSearch(search: boolean) {\n    this.search = search;\n  }\n\n  @nativeAsync\n  async saveDocumentAndRedirectEditing() {\n    const documentSaved = await this.saveDocument(this.documentType);\n    if (this.documentType === 'Prescrição') {\n      this.notification.notify('success', `Prescrição salva com sucesso!`, '');\n    } else {\n      this.notification.notify('success', `${this.documentType} salvo com sucesso!`, '');\n    }\n    this.router.navigate(['/document', documentSaved.code, 'edit']);\n  }\n\n  @nativeAsync\n  private async saveDocument(documentType: string) {\n    try {\n      const doc = this.documentForm.getRawValue();\n      const patient = this.patientForm.value;\n      if (this.isVeterinarian) {\n        doc.pet = patient;\n      } else {\n        doc.patient = patient;\n      }\n\n      doc.local = this.local;\n      doc.code = this.document && this.document.code;\n\n      doc.cid = this.valueCid;\n\n      if (this.rennovaFeature) {\n        doc.productsRennova = doc.products;\n        delete doc.products;\n      }\n\n      let documentSaved: any;\n      switch (documentType) {\n        case 'Prescrição':\n        case 'Prescrição Rennova':\n          documentSaved = await this.prescriptionService\n            .save({ prescriber: this.user._id, ...doc })\n            .pipe(take(1))\n            .toPromise();\n          documentSaved.type = this.rennovaFeature ? 'prescription-renew' : 'prescription';\n          this.documentService.documentTypeSelected = this.documentType;\n          break;\n        case 'Atestado':\n          documentSaved = await this.attestationService\n            .save({ prescriber: this.user._id, ...doc })\n            .toPromise();\n          documentSaved.type = 'attestation';\n          this.documentService.documentTypeSelected = this.documentType;\n          break;\n        case 'Exame':\n          documentSaved = await this.examService.save({ prescriber: this.user._id, ...doc }).toPromise();\n          documentSaved.type = 'exam';\n          this.documentService.documentTypeSelected = this.documentType;\n          break;\n        case 'Outros':\n          if (!this.documentForm.valid) {\n            this.notification.notify('warning', 'Aviso', 'Orientações não pode ficar em branco');\n            this.loading = false;\n            return null;\n          }\n          documentSaved = await this.orientationService\n            .save({ prescriber: this.user._id, ...doc })\n            .toPromise();\n          documentSaved.type = 'orientation';\n          this.documentService.documentTypeSelected = this.documentType;\n          break;\n        default:\n          console.warn('Document type unknown: ', this.documentType);\n          this.loading = false;\n          return null;\n      }\n      return documentSaved;\n    } catch (err) {\n      if (err.status === 400) {\n        this.notification.notify(\n          'error',\n          'Erro ao salvar documento',\n          err.error.error && err.error.error.message\n        );\n      } else {\n        this.notification.notify(\n          'error',\n          'Erro',\n          `Erro ao salvar um documento do tipo ${this.documentType}`\n        );\n      }\n      this.loading = false;\n      throw err;\n    }\n  }\n\n  get valueCid() {\n    if (this.documentForm.get('cid') && this.documentForm.get('cid').value) {\n      const cidValues = this.documentForm.get('cid').value;\n      return {\n        ...cidValues,\n        items: cidValues.items.map(item => item.id)\n      };\n    }\n    return null;\n  }\n\n  @nativeAsync\n  async saveAndPreviewPdf() {\n    if (this.documentType === this.documentTypes.prescription) {\n      this.selectPrescriptionLayout('preview');\n    } else {\n      try {\n        this.loading = true;\n        const documentSaved = await this.saveDocument(this.documentType);\n        await this.previewPdf(documentSaved);\n      } catch (err) {\n        console.error(err);\n      } finally {\n        this.loading = false;\n      }\n    }\n  }\n\n  @nativeAsync\n  private async previewPdf(documentSaved: any, layout = {}) {\n    try {\n      this.loading = true;\n      layout['theme'] = this.themeService.getActiveTheme().name;\n      await this.documentService.generateAndOpenPdf(documentSaved.code, layout);\n      this.router.navigate(['/document', documentSaved.code, 'edit']);\n    } catch (err) {\n      console.error(err);\n    }\n    this.loading = false;\n  }\n\n  @nativeAsync\n  async saveAndSignPdf() {\n    if (this.documentType === this.documentTypes.prescription) {\n      this.selectPrescriptionLayout('sign');\n    } else {\n      try {\n        this.loading = true;\n        const documentSaved = await this.saveDocument(this.documentType);\n        // TODO remover linha após virada de chave\n        documentSaved.version = 'BETA';\n        await this.signPdf(documentSaved);\n      } catch (err) {\n        console.error(err);\n      }\n      this.loading = false;\n    }\n  }\n\n  @nativeAsync\n  private async signPdf({ code, version }, layout = {}) {\n    layout['theme'] = this.themeService.getActiveTheme().name;\n    const url = await this.documentService.getUrlToSignDocument({\n      code,\n      version,\n      prescriber: this.prescriber,\n      patientId: this.patientForm.value._id,\n      layout,\n      victaFeature: this.victaFeature\n    });\n    window.location.href = url;\n  }\n\n  private selectPrescriptionLayout(method: string) {\n    let patientDoesNotHaveAddress = false;\n\n    if (this.patient) {\n      if (this.patient.responsible) {\n        patientDoesNotHaveAddress = this.responsibleDoesNotHaveAddress();\n      } else {\n        patientDoesNotHaveAddress = this.patientDoesNotHaveAddress();\n      }\n    }\n\n    this.modalSelectLayout.createTplModal(patientDoesNotHaveAddress, this.isVeterinarian);\n\n    this.modalSelectLayout.selectLayout.pipe(take(1)).subscribe(async data => {\n      this.loading = true;\n      try {\n        const { layout, addressValue } = data;\n        if (layout === 'special' && patientDoesNotHaveAddress) {\n          const updatedPatient = await this.updateAddressPatient(addressValue);\n          if (this.patient.responsible) {\n            this.patient.responsible = updatedPatient;\n          } else {\n            this.patient = updatedPatient;\n          }\n        }\n        delete data.addressValue;\n        await this.savedDocumentAndPreviewPdfOrSignPdf(method, data);\n      } catch (err) {\n        console.error(err);\n        this.loading = false;\n      }\n    });\n  }\n\n  get isUnderAge() {\n    if (this.patient.dateOfBirth) {\n      return DateUtils.isUnderAge(this.patient.dateOfBirth);\n    }\n    return false;\n  }\n\n  private patientDoesNotHaveAddress() {\n    return (\n      _.isNull(this.patient.address) ||\n      _.isUndefined(this.patient.address) ||\n      (this.patient.address &&\n        _.isEmpty(this.patient.address.cep) &&\n        _.isEmpty(this.patient.address.city) &&\n        _.isEmpty(this.patient.address.uf))\n    );\n  }\n\n  private responsibleDoesNotHaveAddress() {\n    return (\n      _.isNull(this.patient.responsible) ||\n      _.isUndefined(this.patient.responsible) ||\n      _.isNull(this.patient.responsible.address) ||\n      _.isUndefined(this.patient.responsible.address) ||\n      (this.patient.responsible.address &&\n        _.isEmpty(this.patient.responsible.address.cep) &&\n        _.isEmpty(this.patient.responsible.address.city) &&\n        _.isEmpty(this.patient.responsible.address.uf))\n    );\n  }\n\n  updateAddressPatient(addressValue: any): Promise<Patient> {\n    return new Promise(async (resolve, reject) => {\n      try {\n        const isUpdateAndressPatiente = !this.patient.responsible;\n        const restData = isUpdateAndressPatiente ? this.patient : this.patient.responsible;\n        const dataPatient = {\n          ...restData,\n          address: {\n            ...addressValue\n          }\n        };\n        const patient = await this.patientService.update(restData._id, dataPatient).toPromise();\n        resolve(patient);\n      } catch (error) {\n        this.notification.notify(\n          'error',\n          'Error',\n          'Ocorreu um erro ao tentar atualizar endereço do paciente!'\n        );\n        this.loading = false;\n        reject(error);\n      }\n    });\n  }\n\n  @nativeAsync\n  async savedDocumentAndPreviewPdfOrSignPdf(method: string, data: {}) {\n    const documentSaved = await this.saveDocument(this.documentType);\n    if (method === 'preview') {\n      await this.previewPdf(documentSaved, data);\n    } else {\n      await this.signPdf(documentSaved, data);\n    }\n  }\n\n  private showSignatureModal(src: string) {\n    const initialState = {\n      src,\n      height: 720,\n      width: 1152\n    };\n\n    const modalRef = this.modalService.show(ModalIframeComponent, {\n      initialState,\n      backdrop: 'static',\n      keyboard: false\n    });\n    modalRef.content.onLoad.subscribe((url: string) => {\n      if (url) {\n        modalRef.hide();\n        let matches = url.match(/payload=(.*)/);\n        const payload = matches[1];\n        if (payload) {\n          matches = url.match(/code=(\\w+)&/);\n          const code = matches[1];\n          this.resetForm();\n          this.router.navigate(['/document/new']);\n        }\n      }\n\n      this.loading = false;\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed$.next(true);\n    this.destroyed$.complete();\n  }\n\n  changeLocal(name: string) {\n    this.local = this.prescriber.commercialData.find(\n      cd => cd.name.toLocaleLowerCase() === name.toLocaleLowerCase()\n    );\n  }\n\n  changeDocumentType(documentType: string) {\n    this.documentType = documentType;\n    if (this.document && (this.document.id || this.document._id)) {\n      this.document = null;\n      this.selectedDocumentModel = null;\n      this.documentService.patientForm = this.patientForm;\n      this.documentService.documentTypeSelected = documentType;\n      this.zone.run(() => {\n        this.router.navigate(['/document/new']);\n      });\n    }\n  }\n\n  get formInvalid(): boolean {\n    const obj = this.documentForm.value;\n    if (this.prescriber && this.prescriber.professionalType !== 'veterinarian') {\n      return (\n        !this.patientForm.value._id ||\n        !this.patientForm.value.name ||\n        !this.documentForm.valid ||\n        (Object.keys(obj).length === 0 && obj.constructor === Object) ||\n        this.signed ||\n        !!this.modelId\n      );\n    }\n\n    return (\n      !this.patientForm.value.name ||\n      !this.documentForm.valid ||\n      (Object.keys(obj).length === 0 && obj.constructor === Object) ||\n      this.signed ||\n      !!this.modelId\n    );\n  }\n\n  private resetForm() {\n    this.patientForm.reset();\n    this.documentForm.reset();\n    this.selectedDocumentModel = null;\n    this.adding = false;\n  }\n\n  @nativeAsync\n  async showVictaProtocols() {\n    try {\n      this.loading = true;\n      const groups = await this.victaProtocolService.getProtocols(this.prescriber.professionalType);\n      this.loading = false;\n\n      const modal = this.modalService.show(ModalListVictaProtocolComponent, {\n        initialState: { groups },\n        backdrop: 'static'\n      });\n\n      modal.content.selectEvent.subscribe(protocol => {\n        this.selectedDocumentModel = protocol;\n        this.adding = true;\n      });\n    } catch (err) {\n      this.loading = false;\n      this.notification.notify('warning', 'Aviso', 'Não foi possível recuperar protocolos');\n    }\n  }\n\n  @nativeAsync\n  async showModelListFavoriteDocument() {\n    try {\n      this.loading = true;\n      const documentsTemplate = await this.getListDocumentsTemplates();\n      this.loading = false;\n\n      if (documentsTemplate.length) {\n        const initialState = {\n          documentType: this.documentType,\n          documentsTemplate\n        };\n        this.showFavoritePrescriptionsModel(initialState);\n      } else {\n        this.notification.notify(\n          'warning',\n          'Aviso',\n          `Você ainda não possui modelos de ${this.documentType} cadastrados. Salve um modelo em Favoritos.`\n        );\n      }\n    } catch (err) {\n      this.loading = false;\n      this.notification.notify('warning', 'Aviso', 'Não foi possível recuperar a lista de modelos');\n    }\n  }\n\n  private showFavoritePrescriptionsModel(initialState: any) {\n    const modal = this.modalService.show(ModelListFavoriteDocumentComponent, {\n      initialState,\n      backdrop: 'static'\n    });\n    modal.content.selectEvent.subscribe(model => {\n      this.selectedDocumentModel = model;\n      this.adding = true;\n    });\n\n    modal.content.editEvent.subscribe(model => {\n      this.documentService.patientForm = this.patientForm;\n      model.document = model.document || 'prescription';\n      this.router.navigate(['/document/model', model._id, model.document, 'edit']);\n    });\n\n    modal.content.deleteEvent.subscribe((modelId: string) => {\n      modal.hide();\n      this.nzModalService.confirm({\n        nzTitle: 'Atenção',\n        nzContent: `Tem certeza que deseja excluir este modelo de ${this.documentType} da sua lista?`,\n        nzOnOk: async () => {\n          try {\n            await this.deleteDocumentModel(modelId);\n            this.notification.notify('success', 'Sucesso', 'Modelo excluído com sucesso');\n          } catch (err) {\n            this.notification.notify('warning', 'Aviso', 'Não foi possível excluir este item');\n          }\n        },\n        nzOnCancel: () => this.showFavoritePrescriptionsModel(initialState)\n      });\n    });\n  }\n\n  @nativeAsync\n  private async deleteDocumentModel(modelId) {\n    switch (this.documentType) {\n      case this.typesOfDocuments[0]:\n        await this.prescriptionModelService.deleteById(modelId);\n        break;\n      case this.typesOfDocuments[1]:\n        await this.examModelService.deleteById(modelId);\n        break;\n      case this.typesOfDocuments[2]:\n        await this.attestationModelService.deleteById(modelId);\n        break;\n      case this.typesOfDocuments[3]:\n        await this.orientationModelService.deleteById(modelId);\n        break;\n    }\n  }\n\n  @nativeAsync\n  private async getListDocumentsTemplates() {\n    let documentsTemplate = [];\n    switch (this.documentType) {\n      case this.typesOfDocuments[0]:\n        documentsTemplate = await this.prescriptionModelService.getListByPrescriberId(\n          this.prescriber.userId\n        );\n        break;\n      case this.typesOfDocuments[1]:\n        documentsTemplate = await this.examModelService.getListByPrescriberId(this.prescriber.userId);\n        break;\n      case this.typesOfDocuments[2]:\n        documentsTemplate = await this.attestationModelService.getListByPrescriberId(\n          this.prescriber.userId\n        );\n        break;\n      case this.typesOfDocuments[3]:\n        documentsTemplate = await this.orientationModelService.getListByPrescriberId(\n          this.prescriber.userId\n        );\n        break;\n    }\n\n    return documentsTemplate.filter(documentTemplate => documentTemplate.version === 'BETA');\n  }\n\n  showModalAddFavoriteDocument() {\n    if (this.documentForm.valid) {\n      this.documentForm.value.prescriber = this.prescriber.userId;\n      const initialState = {\n        documentModel: this.documentForm.value,\n        documentType: this.documentType\n      };\n      this.modalService.show(ModelAddFavoriteDocumentComponent, {\n        class: 'modal-lg',\n        initialState,\n        backdrop: 'static',\n        keyboard: false\n      });\n    } else {\n      const msg = this.getFormError(this.documentType);\n      this.notification.notify('warning', 'Aviso', msg);\n    }\n  }\n\n  @nativeAsync\n  async updateDocumentModel(model: any, modelId: string) {\n    try {\n      let modelSaved = null;\n\n      switch (this.documentType) {\n        case this.typesOfDocuments[3]:\n          modelSaved = await this.orientationModelService.update(model, modelId);\n          break;\n        case this.typesOfDocuments[2]:\n          modelSaved = await this.attestationModelService.update(model, modelId);\n          break;\n        case this.typesOfDocuments[1]:\n          modelSaved = await this.examModelService.update(model, modelId);\n          break;\n\n        default:\n          modelSaved = await this.prescriptionModelService.update(model, modelId);\n      }\n\n      this.selectedDocumentModel = undefined;\n      this.modelId = undefined;\n\n      this.notification.notify('success', 'Sucesso', 'Modelo salvo com sucesso');\n      this.router.navigate(['/document/new']);\n    } catch (err) {\n      console.error(err);\n      this.notification.notify('error', 'Aviso', 'Erro ao atualizar modelo');\n    }\n  }\n\n  cancelEditModel() {\n    this.router.navigate(['/document/new']);\n  }\n\n  isThemeActiveReceitaDigital() {\n    const active = this.themeService.getActiveTheme();\n    return active.name === 'theme-receita-digital';\n  }\n\n  private getFormError(documentType: string): string {\n    switch (documentType) {\n      case 'Prescrição':\n        return 'Selecione e preencha dados do medicamento ou digite um texto livre';\n      case 'Exame':\n        return 'Selecione um material e um exame para cada material';\n      default:\n        return 'Preencha os campos obrigatórios';\n    }\n  }\n\n  async updateMedicaments(prescription: Prescription) {\n    for await (const medicament of prescription.medicaments) {\n      if (!!medicament.ean) {\n        this.loadingSearchMedicament = true;\n        try {\n          const medicamentsCR = await this.crService.searchMedicament(medicament.ean).toPromise();\n          if (medicamentsCR.length > 0) {\n            const medicamentCR = medicamentsCR[0];\n            medicament.name = medicamentCR.nome;\n            medicament.prescriptionTypeId = medicamentCR.prescriptionTypeId;\n            medicament.typeCr = medicamentCR.typeCr;\n            medicament.type = 'industrialized';\n            medicament.laboratory = medicamentCR.laboratorio;\n            medicament.description = medicamentCR.apresentacaoCustomizada;\n            medicament.medicamentId = medicamentCR.id;\n            medicament.principle = medicamentCR.principio;\n          }\n        } catch (error) {\n          console.log(error);\n          this.notification.notify('error', 'Erro ao consultar dados do medicamento.');\n        } finally {\n          this.loadingSearchMedicament = false;\n        }\n      } else {\n        medicament.type = 'free-text';\n      }\n    }\n  }\n\n  clearSelectionPatient() {\n    this.patient = null;\n    this.patientForm.reset();\n  }\n}\n","export default \"<div class=\\\"page-content\\\">\\n  <app-alternative-navbar></app-alternative-navbar>\\n  <app-sidebar-menu></app-sidebar-menu>\\n  <app-rd-tabs\\n    [tabDefault]=\\\"tabDefault\\\"\\n    [isRennovaFeature]=\\\"rennovaFeature\\\"\\n    (onCLickTab)=\\\"changeDocumentType($event)\\\"\\n  ></app-rd-tabs>\\n  <section class=\\\"section container-fluid prescription d-flex flex-column justify-content-between\\\">\\n    <div class=\\\"mb-4\\\">\\n      <div class=\\\"row\\\">\\n        <div class=\\\"col-12 col-md-6 col-lg-6\\\">\\n          <nz-form-item>\\n            <nz-form-label nzFor=\\\"cpfPatient\\\">Escolha o local:</nz-form-label>\\n            <nz-form-control>\\n              <select\\n                #selectLocal\\n                class=\\\"form-control\\\"\\n                id=\\\"local\\\"\\n                [ngModel]=\\\"local?.name\\\"\\n                (ngModelChange)=\\\"changeLocal($event)\\\"\\n              >\\n                <option *ngFor=\\\"let address of prescriber?.commercialData\\\" [ngValue]=\\\"address?.name\\\">{{\\n                  address?.name\\n                }}</option>\\n              </select>\\n            </nz-form-control>\\n          </nz-form-item>\\n        </div>\\n      </div>\\n\\n      <form [formGroup]=\\\"patientForm\\\" *ngIf=\\\"!modelId\\\">\\n        <ng-container>\\n          <div class=\\\"d-flex align-items-center\\\">\\n            <nz-form-label nzFor=\\\"cpfPatient\\\">\\n              {{ patient ? 'Paciente:' : 'Escolha o paciente:' }}\\n            </nz-form-label>\\n            <nz-spin nzSimple class=\\\"ml-3\\\" *ngIf=\\\"isLoadingSearchPatient\\\"></nz-spin>\\n          </div>\\n          <div class=\\\"card\\\" style=\\\"padding: 0rem 1rem !important;margin-bottom: 8px;\\\">\\n            <div class=\\\"row mt-2\\\">\\n              <div class=\\\"col-12\\\" *ngIf=\\\"!patient\\\">\\n                <nz-form-item>\\n                  <div>\\n                    <nz-form-control>\\n                      <input\\n                        appFocus\\n                        focus=\\\"true\\\"\\n                        id=\\\"cpfPatient\\\"\\n                        [nzAutocomplete]=\\\"autoName\\\"\\n                        class=\\\"input-name\\\"\\n                        formControlName=\\\"name\\\"\\n                        maxlength=\\\"128\\\"\\n                        nz-input\\n                        [placeholder]=\\\"\\n                          isVeterinarian\\n                            ? 'Digite o CPF do responsável para buscar'\\n                            : 'Digite o CPF ou nome completo do paciente para buscar'\\n                        \\\"\\n                        [disabled]=\\\"signed\\\"\\n                      />\\n                      <nz-autocomplete\\n                        #autoName\\n                        nzBackfill\\n                        (selectionChange)=\\\"onChangePatient($event.nzValue)\\\"\\n                      >\\n                        <ng-container *ngIf=\\\"patients?.length > 0\\\">\\n                          <nz-auto-option\\n                            *ngFor=\\\"let option of patients\\\"\\n                            [nzLabel]=\\\"option.cpf !== '-1' ? option?.name || option?.fullname : ''\\\"\\n                            [nzValue]=\\\"option\\\"\\n                          >\\n                            {{ option?.name || option?.fullname }}\\n                            {{ option?.cpf !== '-1' ? (option?.cpf | formattedCpf) : '' }}\\n                            <span *ngIf=\\\"option?.responsible\\\"\\n                              >&nbsp;({{ option.responsible.name || option.responsible.fullname }}\\n                              {{ option.responsible.cpf | formattedCpf }})</span\\n                            >\\n                          </nz-auto-option>\\n                        </ng-container>\\n                      </nz-autocomplete>\\n                    </nz-form-control>\\n                  </div>\\n                </nz-form-item>\\n              </div>\\n            </div>\\n            <div class=\\\"row\\\" style=\\\"margin: 8px 0px;\\\">\\n              <div class=\\\"col-12\\\">\\n                <div class=\\\"d-flex align-items-center justify-content-center\\\" *ngIf=\\\"!patient\\\">\\n                  <app-rd-buttom-group-icon\\n                    label=\\\"Novo Paciente\\\"\\n                    icon=\\\"fa fa-plus\\\"\\n                    (onClick)=\\\"showModalSearch()\\\"\\n                  ></app-rd-buttom-group-icon>\\n                </div>\\n\\n                <div *ngIf=\\\"patient\\\">\\n                  <div\\n                    style=\\\"display: flex;align-items: center; justify-content: space-between; gap: 24px; margin-bottom: 8px;\\\"\\n                  >\\n                    <nz-form-label>\\n                      <span class=\\\"label-name-patient\\\">{{ patient.name }}</span>\\n                    </nz-form-label>\\n                    <i\\n                      nz-icon\\n                      nzType=\\\"close\\\"\\n                      nzTheme=\\\"outline\\\"\\n                      class=\\\"label-name-patient__icon\\\"\\n                      nz-tooltip=\\\"Remover paciente\\\"\\n                      (click)=\\\"clearSelectionPatient()\\\"\\n                    ></i>\\n                  </div>\\n                  <nz-form-item [formGroup]=\\\"documentForm\\\">\\n                    <label nz-checkbox formControlName=\\\"showPatientCpf\\\">\\n                      <span>\\n                        {{ showCpfText }}\\n                      </span>\\n                    </label>\\n                    <label nz-checkbox formControlName=\\\"showPrescriberCpf\\\">\\n                      <span>\\n                        Mostrar CPF do Prescritor\\n                      </span>\\n                    </label>\\n                  </nz-form-item>\\n                </div>\\n              </div>\\n            </div>\\n          </div>\\n        </ng-container>\\n      </form>\\n      <form\\n        [formGroup]=\\\"documentForm\\\"\\n        *ngIf=\\\"modelId && documentForm.value.title != undefined && documentType != typesOfDocuments[3]\\\"\\n      >\\n        <nz-form-item>\\n          <nz-form-label nzFor=\\\"title\\\">Título<span class=\\\"mandatory\\\"> *</span></nz-form-label>\\n          <nz-form-control nzHasFeedback>\\n            <input nz-input formControlName=\\\"title\\\" [attr.id]=\\\"'title'\\\" />\\n            <nz-form-explain\\n              *ngIf=\\\"documentForm?.get('title').dirty && documentForm?.get('title').errors\\\"\\n            >\\n              <ng-container *ngIf=\\\"documentForm?.get('title').hasError('required')\\\">\\n                Campo obrigatório, por favor digite o título.\\n              </ng-container>\\n            </nz-form-explain>\\n          </nz-form-control>\\n        </nz-form-item>\\n      </form>\\n\\n      <app-prescription\\n        *ngIf=\\\"documentType === typesOfDocuments[0]\\\"\\n        [manipulatedProfile]=\\\"manipulatedProfile\\\"\\n        [prescription]=\\\"document\\\"\\n        [prescriptionModel]=\\\"selectedDocumentModel\\\"\\n        [patient]=\\\"patient\\\"\\n        [isVeterinarian]=\\\"isVeterinarian\\\"\\n        (formEmitter)=\\\"documentForm = $event\\\"\\n        (onShowModelListFavoriteDocument)=\\\"showModelListFavoriteDocument()\\\"\\n        [showButtonSerene]=\\\"sereneFeature\\\"\\n      ></app-prescription>\\n\\n      <app-exam-v2\\n        *ngIf=\\\"documentType === typesOfDocuments[1]\\\"\\n        [form]=\\\"documentForm\\\"\\n        [exam]=\\\"document\\\"\\n        [examModel]=\\\"selectedDocumentModel\\\"\\n        (formEmitter)=\\\"documentForm = $event\\\"\\n        [isVeterinarian]=\\\"isVeterinarian\\\"\\n        (onShowModelListFavoriteDocument)=\\\"showModelListFavoriteDocument()\\\"\\n      ></app-exam-v2>\\n\\n      <app-attestation\\n        *ngIf=\\\"documentType === typesOfDocuments[2]\\\"\\n        [patient]=\\\"patient\\\"\\n        [attestationModel]=\\\"selectedDocumentModel\\\"\\n        [attestation]=\\\"document\\\"\\n        (formEmitter)=\\\"documentForm = $event\\\"\\n        [isVeterinarian]=\\\"isVeterinarian\\\"\\n        (onShowModelListFavoriteDocument)=\\\"showModelListFavoriteDocument()\\\"\\n      ></app-attestation>\\n\\n      <app-orientation\\n        *ngIf=\\\"documentType === typesOfDocuments[3]\\\"\\n        [orientation]=\\\"document\\\"\\n        [orientationModel]=\\\"selectedDocumentModel\\\"\\n        [patient]=\\\"patient\\\"\\n        (formEmitter)=\\\"documentForm = $event\\\"\\n        [isVeterinarian]=\\\"isVeterinarian\\\"\\n        (onShowModelListFavoriteDocument)=\\\"showModelListFavoriteDocument()\\\"\\n        [showButtonSerene]=\\\"sereneFeature\\\"\\n      ></app-orientation>\\n\\n      <app-prescription-rennova\\n        *ngIf=\\\"rennovaFeature\\\"\\n        [prescription]=\\\"document\\\"\\n        (formEmitter)=\\\"documentForm = $event\\\"\\n      ></app-prescription-rennova>\\n    </div>\\n    <div class=\\\"d-flex flex-column box-actions\\\">\\n      <nz-divider></nz-divider>\\n      <div class=\\\"d-flex align-items-center justify-content-center btns-container\\\">\\n        <nz-button-group class=\\\"d-flex\\\">\\n          <button\\n            nz-button\\n            nz-dropdown\\n            [nzDropdownMenu]=\\\"options\\\"\\n            nzTrigger=\\\"click\\\"\\n            nzPlacement=\\\"bottomRight\\\"\\n            class=\\\"btn btn-save\\\"\\n            [nzDisabled]=\\\"formInvalid\\\"\\n          >\\n            <span>Salvar</span>\\n          </button>\\n        </nz-button-group>\\n        <nz-dropdown-menu #options=\\\"nzDropdownMenu\\\">\\n          <ul nz-menu>\\n            <li nz-menu-item (click)=\\\"saveDocumentAndRedirectEditing()\\\">Salvar</li>\\n            <li nz-menu-item (click)=\\\"saveAndSignPdf()\\\">Assinar Digitalmente</li>\\n            <li\\n              nz-menu-item\\n              (click)=\\\"saveAndPreviewPdf()\\\"\\n              *ngIf=\\\"imprimirSemAssinarFeature || (isVeterinarian && !rennovaFeature)\\\"\\n            >\\n              Imprimir sem assinar\\n            </li>\\n            <li nz-menu-item (click)=\\\"showModalAddFavoriteDocument()\\\" *ngIf=\\\"!rennovaFeature\\\">\\n              Salvar como favoritos\\n            </li>\\n          </ul>\\n        </nz-dropdown-menu>\\n      </div>\\n    </div>\\n  </section>\\n</div>\\n\\n<div class=\\\"footer d-flex fixed-bottom flex-fill justify-content-end\\\">\\n  <a\\n    *ngIf=\\\"isThemeActiveReceitaDigital()\\\"\\n    class=\\\"mr-3 helpContainer\\\"\\n    href=\\\"https://ajuda.receitadigital.com\\\"\\n    ><i class=\\\"fa fa-comments mr-1\\\"></i>Fale Conosco.</a\\n  >\\n</div>\\n<ngx-loading [show]=\\\"loading\\\" [config]=\\\"{ backdropBorderRadius: '3px' }\\\"></ngx-loading>\\n<app-modal-send-document></app-modal-send-document>\\n<app-modal-select-layout></app-modal-select-layout>\\n\";","export default \"::ng-deep .ant-drawer-left.ant-drawer-open .ant-drawer-content-wrapper {\\n  box-shadow: 0 9px 18px rgba(0, 0, 0, 0.18);\\n}\\n::ng-deep .ant-drawer.ant-drawer-open .ant-drawer-mask {\\n  opacity: 0.11;\\n}\\n::ng-deep .ant-drawer-body {\\n  padding-top: 0;\\n  height: 75vh;\\n  overflow: auto;\\n}\\n::ng-deep .ant-drawer-open {\\n  top: 80px;\\n}\\n::ng-deep .menu-drawer {\\n  top: 80px;\\n  background-color: #007260;\\n  border: 1px solid #007260;\\n}\\n::ng-deep .menu-drawer .ant-drawer-content {\\n  background-color: transparent;\\n}\\n::ng-deep .inner-menu {\\n  display: flex;\\n  flex-direction: column;\\n}\\n::ng-deep .inner-menu .menu-icon {\\n  align-self: flex-end;\\n  margin: 20px 0;\\n}\\n::ng-deep .inner-menu .menu-icon .fa {\\n  font-size: 20px;\\n  color: white;\\n}\\n::ng-deep .inner-menu .menu li {\\n  padding: 20px 0;\\n}\\n::ng-deep .inner-menu .menu a {\\n  color: white;\\n  font-family: \\\"problack\\\";\\n  font-size: 18px;\\n  text-transform: uppercase;\\n}\\n::ng-deep .inner-menu .menu a:focus {\\n  text-decoration: none;\\n}\\n::ng-deep .inner-menu .menu a .fa {\\n  margin-right: 10px;\\n}\\n::ng-deep .medicationAutoComplete {\\n  margin-top: 17px;\\n}\\n.toolbar {\\n  display: flex;\\n}\\n.toolbar .menu-toggler {\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  padding: 0;\\n  border-radius: 0;\\n  width: 80px;\\n  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));\\n  margin: 0;\\n}\\n.toolbar .menu-toggler .fa:before {\\n  font-size: 22px;\\n}\\n.toolbar .menu-toggler,\\n.toolbar .toolbar-options {\\n  height: 80px;\\n}\\n.toolbar .toolbar-menu {\\n  flex: 1;\\n}\\n.toolbar .toolbar-menu .toolbar-options {\\n  background-color: #f5f5f5;\\n  display: flex;\\n  align-items: center;\\n  justify-content: flex-end;\\n  padding-right: 40px;\\n  padding-left: 60px;\\n}\\n.toolbar .toolbar-menu .toolbar-options .btn {\\n  font-family: \\\"problack\\\", sans-serif;\\n}\\n.toolbar .toolbar-menu .toolbar-options .btn-green {\\n  background-color: #87ebe1;\\n  border-color: #87ebe1;\\n  color: #1b403a;\\n}\\n.toolbar .toolbar-menu .toolbar-options .btn-default {\\n  background-color: #afafaf;\\n  border-color: #afafaf;\\n  color: white;\\n}\\n.toolbar .toolbar-menu .toolbar-tags {\\n  background-color: #ebebeb;\\n  height: 40px;\\n  border-radius: 0 0 10px 10px;\\n}\\n.prescription {\\n  padding-top: 2rem;\\n  padding-left: 9.6rem;\\n  padding-right: 10rem;\\n  height: calc(100vh - 11rem);\\n  overflow-y: auto;\\n  background-color: #f5f5f5;\\n}\\n@media (min-width: 1025px) {\\n  .prescription {\\n    height: calc(100vh - 11.6rem);\\n  }\\n}\\n.prescription .doc-type {\\n  margin-right: 25px;\\n}\\n.prescription .hospital-brand {\\n  position: relative;\\n  display: flex;\\n  align-self: flex-end;\\n  justify-content: center;\\n  flex-direction: column;\\n  align-items: center;\\n  padding-top: 15px;\\n}\\n.prescription .hospital-brand nz-dropdown {\\n  align-self: flex-end;\\n}\\n.prescription .hospital-brand .rectangles {\\n  display: flex;\\n  flex-wrap: wrap;\\n  width: 48px;\\n}\\n.prescription .hospital-brand .rectangles .rectangle {\\n  width: 24px;\\n  height: 24px;\\n}\\n.prescription .hospital-brand .rectangles .rectangle.bg-light-alt {\\n  background-color: #4d4d4d;\\n}\\n.prescription .hospital-brand .hospital-name {\\n  font-family: \\\"probold\\\";\\n  font-size: 23px;\\n  color: #4d4d4d;\\n  margin-top: 10px;\\n}\\n.prescription .hospital-brand .arrow-circle {\\n  font-size: 24px;\\n  color: #4d4d4d;\\n  position: absolute;\\n  right: 0;\\n  top: 0;\\n}\\n.prescription form .input-name {\\n  background-color: transparent;\\n  border-color: transparent;\\n  font-family: \\\"Times New Roman\\\", Times, serif, \\\"proregular\\\", \\\"Source Serif Pro\\\", \\\"sans-serif\\\";\\n  color: #585858 !important;\\n  font-size: 30px;\\n  height: auto;\\n  border-radius: 0;\\n  border-bottom: 2px solid #6e6e6e;\\n}\\n.prescription form .input-name::-moz-placeholder {\\n  color: #f6b4af;\\n}\\n.prescription form .input-name::placeholder, .prescription form .input-name {\\n  color: #f6b4af;\\n}\\n@media (max-width: 1025px) {\\n  .prescription form .input-name {\\n    font-size: 15px;\\n  }\\n}\\n.prescription form .input-name:hover, .prescription form .input-name:focus {\\n  border-bottom: 2px solid #6e6e6e;\\n  box-shadow: none;\\n}\\n.add-prescription {\\n  padding: 20px 0;\\n  border-top: 1px solid #f5f5f5;\\n  min-height: 81px;\\n  display: flex;\\n  justify-content: center;\\n}\\n@media (max-width: 1025px) {\\n  .add-prescription .btn-icon .btn-inner--text {\\n    font-size: 13px;\\n    word-break: break-word;\\n  }\\n}\\n.add-prescription.adding-bg {\\n  background-color: #f5f5f5;\\n  border-top: 1px solid transparent;\\n}\\n.add-prescription .btn-add-name {\\n  background-color: var(--bg-color-primary);\\n  border: 1px solid var(--bg-color-primary);\\n  color: var(--color-white);\\n  padding: 0px 10px;\\n  margin: 10px;\\n}\\n.add-prescription .btn-add-outiline {\\n  display: flex;\\n  padding: 0 0 0 8px;\\n  height: 40px;\\n  align-items: center;\\n  border-radius: 10px;\\n  overflow: hidden;\\n  border: 0;\\n  font-family: \\\"probold\\\", sans-serif;\\n  background-color: var(--bg-color-secondary);\\n  color: var(--color-white);\\n}\\n.add-prescription .btn-add-outiline .btn-inner--icon {\\n  background-color: var(--bg-color-primary);\\n  color: var(--color-white);\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  height: 40px;\\n  width: 50px;\\n}\\n.add-patient {\\n  border: 0;\\n  padding-left: 20px;\\n  padding-bottom: 0;\\n  min-height: 75px;\\n}\\n.footer {\\n  height: 50px;\\n  padding: 0;\\n  border: 0;\\n  z-index: 1;\\n  background-color: var(--bg-footer);\\n}\\n.footer .btn {\\n  box-shadow: none;\\n  border-radius: 0;\\n  height: 100%;\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  padding-top: 0.725rem;\\n  background-color: var(--bg-color-btn-save);\\n  color: var(--color-white);\\n}\\n@media (max-width: 1025px) {\\n  .footer .btn {\\n    font-size: 11px;\\n  }\\n}\\n.footer .btn i {\\n  margin-left: 10px;\\n}\\n.footer .btn i:before {\\n  font-size: 16px;\\n}\\n.medicationNameInput {\\n  background-color: transparent;\\n  border-color: transparent;\\n  height: 100%;\\n  box-shadow: none;\\n}\\ntextarea {\\n  resize: none;\\n  background-color: transparent;\\n  border: 0;\\n  border-radius: 0;\\n  box-shadow: none;\\n  padding-left: 12px;\\n  color: #4d4d4d;\\n  font-size: 18px;\\n}\\ntextarea:hover, textarea:focus {\\n  border-color: transparent;\\n  box-shadow: none;\\n}\\n.free-prescription {\\n  display: flex;\\n}\\n.free-prescription .break-line {\\n  margin-left: 7px;\\n  white-space: pre-wrap;\\n}\\n.toolbar {\\n  display: flex;\\n}\\n.toolbar .menu-toggler {\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  padding: 0;\\n  border-radius: 0;\\n  width: 80px;\\n  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));\\n  margin: 0;\\n}\\n.toolbar .menu-toggler .fa:before {\\n  font-size: 22px;\\n}\\n.toolbar .menu-toggler,\\n.toolbar .toolbar-options {\\n  height: 80px;\\n}\\n.toolbar .toolbar-menu {\\n  flex: 1;\\n}\\n.toolbar .toolbar-menu .toolbar-options {\\n  background-color: #f5f5f5;\\n  display: flex;\\n  align-items: center;\\n  justify-content: flex-end;\\n  padding-right: 40px;\\n  padding-left: 60px;\\n}\\n.toolbar .toolbar-menu .toolbar-options .btn {\\n  font-family: \\\"problack\\\", sans-serif;\\n}\\n.toolbar .toolbar-menu .toolbar-options .btn-green {\\n  background-color: #87ebe1;\\n  border-color: #87ebe1;\\n  color: #1b403a;\\n}\\n.toolbar .toolbar-menu .toolbar-options .btn-default {\\n  background-color: #afafaf;\\n  border-color: #afafaf;\\n  color: white;\\n}\\n.toolbar .toolbar-menu .toolbar-tags {\\n  background-color: #ebebeb;\\n  height: 40px;\\n  border-radius: 0 0 10px 10px;\\n}\\n.box-actions ::ng-deep .ant-divider-horizontal {\\n  margin: 10px 0;\\n}\\n@media (min-width: 1025px) {\\n  .box-actions .btns-container {\\n    padding-bottom: 10px;\\n  }\\n}\\n.box-actions .btns-container .btn {\\n  display: flex;\\n  padding: 0 8px 0 8px;\\n  height: 40px;\\n  align-items: center;\\n  overflow: hidden;\\n  border: 0;\\n  font-family: \\\"probold\\\", sans-serif;\\n  text-transform: capitalize;\\n}\\n.box-actions .btns-container .btn-save,\\n.box-actions .btns-container .btn-save:focus {\\n  display: flex;\\n  justify-content: center;\\n  align-items: center;\\n  width: 100px;\\n  border-radius: 10px;\\n  background-color: var(--bg-color-secondary);\\n  color: var(--color-white);\\n}\\n.box-actions .btns-container .btn-dropdown,\\n.box-actions .btns-container .btn-dropdown:focus {\\n  border-radius: 0 10px 10px 0;\\n  background-color: var(--bg-color-primary);\\n  color: var(--color-white);\\n  margin-left: -8px;\\n}\\n.box-actions .btns-container .btn:disabled {\\n  background-color: #c7c7c7;\\n  color: #707070;\\n  cursor: not-allowed;\\n}\\n@media (max-width: 1025px) {\\n  section.section.container-fluid.prescription.d-flex.flex-column {\\n    padding: 20px;\\n  }\\n\\n  .ant-form-item-children input {\\n    font-size: 16px;\\n  }\\n}\\n.label-name-patient {\\n  font-size: 16pt;\\n}\\n@media (min-width: 940px) {\\n  .label-name-patient {\\n    font-size: 28pt;\\n  }\\n}\\n.label-name-patient__icon {\\n  font-size: 12pt;\\n  cursor: pointer;\\n  color: red;\\n}\\n@media (min-width: 940px) {\\n  .label-name-patient__icon {\\n    font-size: 18pt;\\n  }\\n}\";","import { Injectable } from '@angular/core';\nimport { ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot } from '@angular/router';\nimport { AuthService } from './../../../core/services/auth.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class DocumentGuard implements CanActivate {\n  constructor(private router: Router, private authService: AuthService) {}\n\n  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {\n    const user = this.authService.user();\n    const isPrescriber = user.userType === 'healthProfessional';\n    if (!isPrescriber) {\n      this.router.navigate(['']);\n    }\n    return isPrescriber;\n  }\n}\n","export default \"<app-alternative-navbar\\n  title=\\\"Informações da Receita\\\"\\n  titleIcon=\\\"fa-assignment\\\"\\n></app-alternative-navbar>\\n<app-sidebar-menu></app-sidebar-menu>\\n\\n<div class=\\\"d-flex flex-column overflow-hidden\\\">\\n  <div class=\\\"row\\\">\\n    <div class=\\\"col-md-6 p-0\\\">\\n      <div class=\\\"toolbar bg-green flex-column\\\">\\n        <h4 class=\\\"title text-white\\\">\\n          Dados do Paciente\\n        </h4>\\n      </div>\\n      <section class=\\\"p-50 pl-80 patient\\\">\\n        <div class=\\\"row\\\">\\n          <div class=\\\"col-md-12\\\">\\n            <div class=\\\"label\\\">\\n              <ng-container *ngIf=\\\"prescription.patient as patient\\\">\\n                <div class=\\\"label\\\">\\n                  Nome: <span class=\\\"regular\\\">{{ patient.name }}</span>\\n                </div>\\n                <div class=\\\"label mt-15\\\">\\n                  CPF: <span class=\\\"regular\\\">{{ patient.cpf | mask: '000.000.000-00' }}</span>\\n                </div>\\n              </ng-container>\\n            </div>\\n            <ng-container *ngIf=\\\"prescription.healthProfessional as healthProfessional\\\">\\n              <div class=\\\"label mt-38\\\">\\n                {{ getProfessionalTypeName() }}:\\n                <span class=\\\"regular\\\">{{ healthProfessional.name }}</span>\\n              </div>\\n              <div class=\\\"label mt-15\\\">\\n                {{ healthProfessional.regionalCouncilNumber?.label }}:\\n                <span class=\\\"regular\\\"\\n                  >{{ healthProfessional.regionalCouncilNumber?.number }}/{{\\n                    healthProfessional.regionalCouncilNumber?.uf\\n                  }}</span\\n                >\\n              </div>\\n              <div class=\\\"label mt-15\\\">\\n                Especialidade:\\n                <span class=\\\"regular\\\">{{ getSpecialties() }}</span>\\n              </div>\\n            </ng-container>\\n          </div>\\n        </div>\\n      </section>\\n    </div>\\n    <div class=\\\"col-md-6 p-0\\\">\\n      <div class=\\\"toolbar bg-gray-black flex-column\\\">\\n        <h4 class=\\\"title text-white\\\">\\n          Dados da Receita\\n        </h4>\\n      </div>\\n      <section class=\\\"bg-secondary prescription\\\">\\n        <div class=\\\"row\\\">\\n          <div class=\\\"col-md-12\\\">\\n            <div class=\\\"row\\\">\\n              <div class=\\\"col-md-6\\\">\\n                <span class=\\\"code\\\">Código:</span>\\n                <span class=\\\"font-xl-36 font-light ml-1\\\">{{ prescription.code }}</span>\\n              </div>\\n              <div class=\\\"col-md-6\\\">\\n                <div class=\\\"download-pdf\\\" (click)=\\\"downloadPrescriptionPdf(prescription)\\\">\\n                  <i\\n                    nz-icon\\n                    nzType=\\\"file-pdf\\\"\\n                    nzTheme=\\\"twotone\\\"\\n                    nzTwotoneColor=\\\"#B22222\\\"\\n                    class=\\\"icon-pdf\\\"\\n                  ></i\\n                  ><br />\\n                  <span>Clique para baixar o documento assinado</span>\\n                </div>\\n              </div>\\n            </div>\\n\\n            <h4 class=\\\"subtitle mt-38\\\">\\n              Selecione abaixo as unidades de medicamentos que deseja vender. Ao confirmar a venda os\\n              medicamentos selecionados serão retidos no sistema.\\n            </h4>\\n            <label\\n              (ngModelChange)=\\\"checkAll($event)\\\"\\n              [(ngModel)]=\\\"allChecked\\\"\\n              [nzIndeterminate]=\\\"indeterminate\\\"\\n              class=\\\"custom-check select-all\\\"\\n              nz-checkbox\\n              >SELECIONAR TODOS</label\\n            >\\n          </div>\\n        </div>\\n\\n        <div class=\\\"row\\\">\\n          <div class=\\\"col-md-12\\\">\\n            <ng-container *ngFor=\\\"let medicament of prescription.medicaments; let i = index\\\">\\n              <div class=\\\"medication-container d-flex align-items-center\\\">\\n                <label\\n                  [(ngModel)]=\\\"medicament.valid\\\"\\n                  (nzCheckedChange)=\\\"refreshStatus()\\\"\\n                  class=\\\"custom-check mr-1 align-self-start\\\"\\n                  [nzDisabled]=\\\"medicament?.availableQuantity === 0\\\"\\n                  nz-checkbox\\n                ></label>\\n                <div class=\\\"medication\\\">\\n                  <pre><h4 class=\\\"title mb-0\\\">{{ i + 1 }} - {{ medicament?.name }}</h4></pre>\\n                  <pre\\n                    *ngIf=\\\"medicament?.description\\\"\\n                  ><p class=\\\"mb-0 description\\\">{{ medicament?.description }}</p></pre>\\n                  <pre>Posologia: {{ medicament?.dosage }}</pre>\\n                  <app-auto-width-input-number\\n                    [(ngModel)]=\\\"medicament.availableQuantity\\\"\\n                    [id]=\\\"'quantidade_' + i\\\"\\n                    [max]=\\\"quantities[i]\\\"\\n                    [disabled]=\\\"medicament?.availableQuantity === 0\\\"\\n                  >\\n                  </app-auto-width-input-number>\\n                </div>\\n              </div>\\n            </ng-container>\\n            <ng-container *ngFor=\\\"let productRennova of prescription.productsRennova; let i = index\\\">\\n              <div class=\\\"mt-2\\\" *ngIf=\\\"productRennova as productItem\\\">\\n                <div class=\\\"d-flex align-items-center\\\">\\n                  <label\\n                    [(ngModel)]=\\\"productItem.valid\\\"\\n                    (nzCheckedChange)=\\\"refreshStatus()\\\"\\n                    class=\\\"custom-check mr-1 align-self-start\\\"\\n                    [nzDisabled]=\\\"productItem?.prescribedQuantity === 0\\\"\\n                    nz-checkbox\\n                    style=\\\"margin-top: 2px\\\"\\n                  ></label>\\n                  <p style=\\\"font-size: 18px\\\">{{ productItem?.product?.name }}</p>\\n                </div>\\n                <div class=\\\"ml-4\\\" *ngFor=\\\"let item of productItem?.product?.items\\\">\\n                  <p>{{ item?.name }}</p>\\n                  <ul *ngIf=\\\"item?.descriptions?.length > 0\\\">\\n                    <li *ngFor=\\\"let obj of item?.descriptions\\\">\\n                      <div class=\\\"d-flex\\\">\\n                        <span style=\\\"text-align: justify; font-family: monospace;\\\">\\n                          {{ obj?.fullDescription }}\\n                        </span>\\n                      </div>\\n                    </li>\\n                  </ul>\\n                </div>\\n                <p style=\\\"font-weight: 700; text-align: justify;\\\">\\n                  {{ productItem?.product?.observation }}\\n                </p>\\n\\n                <app-auto-width-input-number\\n                  [(ngModel)]=\\\"productItem.availableQuantity\\\"\\n                  [id]=\\\"'quantidade_' + i\\\"\\n                  [max]=\\\"quantities[i]\\\"\\n                  [min]=\\\"quantities[i]\\\"\\n                  [disabled]=\\\"productItem.availableQuantity === 0\\\"\\n                >\\n                </app-auto-width-input-number>\\n              </div>\\n            </ng-container>\\n          </div>\\n        </div>\\n      </section>\\n    </div>\\n  </div>\\n\\n  <div class=\\\"footer bg-dark d-flex align-items-center fixed-bottom justify-content-end\\\">\\n    <button type=\\\"button\\\" class=\\\"btn btn-success\\\" (click)=\\\"changeRoute()\\\" theme>\\n      Voltar\\n      <i class=\\\"fa fa-undo\\\"></i>\\n    </button>\\n    <button type=\\\"button\\\" class=\\\"btn btn-success\\\" (click)=\\\"onSubmit()\\\" theme>\\n      VALIDAR SELEÇÃO {{ checkedNumber ? '(' + checkedNumber + ')' : '' }}\\n      <i class=\\\"fa fa-arrow-right\\\"></i>\\n    </button>\\n  </div>\\n</div>\\n\";","import { distinctUntilChanged } from 'rxjs/operators';\nimport { AfterViewInit, ChangeDetectorRef, Component, NgZone, OnInit } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { AuthService } from '@app/core/services/auth.service';\nimport { PharmacyService } from '@app/modules/pharmacy/services/pharmacy.service';\nimport { ModalBuyerDataComponent } from '@app/shared/modals/modal-buyer-data/modal-buyer-data.component';\nimport { HealthProfessional } from '@app/shared/models';\nimport { User } from '@app/shared/models/decodedLoginToken';\nimport { Prescription } from '@app/shared/models/prescription';\nimport { Retention } from '@app/shared/models/retention';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { NzModalService } from 'ng-zorro-antd/modal';\nimport { PrescriptionService } from '../../../document/services/prescription.service';\nimport { nativeAsync } from '@app/shared/decorators/nativeAsync';\nimport { DocumentModel } from '@app/shared/models/documet-model';\nimport { CrService } from '@app/modules/document/services/cr.service';\n\n@Component({\n  selector: 'app-confirmation',\n  templateUrl: './confirmation.component.html',\n  styleUrls: ['./confirmation.component.scss']\n})\nexport class ConfirmationComponent implements OnInit, AfterViewInit {\n  quantidade = 1;\n  allChecked = false;\n  indeterminate = false;\n  prescription: Prescription = new Prescription();\n  prescriptionCode;\n  medications;\n  quantities = [];\n  checkedNumber: number;\n  loading = false;\n  completeUser: any;\n  pharmacyId: any;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private authService: AuthService,\n    private prescriptionService: PrescriptionService,\n    private notification: AppToastService,\n    private pharmacyService: PharmacyService,\n    private modalService: NzModalService,\n    private cdr: ChangeDetectorRef,\n    private ngZone: NgZone,\n    private crService: CrService,\n    private toast: AppToastService\n  ) {\n    const state = this.router.getCurrentNavigation().extras.state;\n    if (state) {\n      this.prescription = state.prescription;\n      this.prescriptionCode = this.prescription.code;\n    }\n  }\n\n  @nativeAsync\n  async ngOnInit() {\n    this.loading = true;\n\n    this.route.params.subscribe(params => {\n      this.prescriptionCode = params['param'];\n    });\n    await this.getCompleteUser();\n\n    this.prescription = await this.prescriptionService\n      .getPrescriptionbyCode(this.prescriptionCode)\n      .toPromise();\n\n    this.updateMedicaments();\n\n    this.quantities = this.hasFarmaRennovaFeature\n      ? this.prescription.productsRennova.map(m => m.availableQuantity)\n      : this.prescription.medicaments.map(m => m.availableQuantity);\n    this.loading = false;\n  }\n\n  ngAfterViewInit(): void {\n    this.cdr.detectChanges();\n  }\n\n  get user(): User {\n    return this.authService.user();\n  }\n\n  get hasFarmaRennovaFeature(): boolean {\n    return this.user && this.user.features.some(f => f.name === 'Farma Rennova');\n  }\n\n  refreshStatus(): void {\n    const array = this.hasFarmaRennovaFeature\n      ? this.prescription.productsRennova\n      : this.prescription.medicaments;\n    const allChecked = array.every(value => value.valid === true);\n    const allUnChecked = array.every(value => !value.valid);\n    this.allChecked = allChecked;\n    this.indeterminate = !allChecked && !allUnChecked;\n    this.checkedNumber = array.filter(value => value.valid).length;\n  }\n\n  @nativeAsync\n  private async getCompleteUser() {\n    try {\n      this.loading = true;\n      const userType = this.user.userType;\n\n      switch (userType) {\n        case 'pharmacy':\n          this.completeUser = await this.pharmacyService.getPharmacyByUserId(this.user._id).toPromise();\n          this.pharmacyId = this.completeUser._id;\n          break;\n        default:\n          const extraData = JSON.parse(localStorage.getItem('extra_data'));\n          this.pharmacyId = extraData.pharmacyId;\n      }\n\n      this.loading = false;\n    } catch (error) {\n      this.loading = false;\n      console.log(error);\n    }\n  }\n\n  checkAll(value: boolean): void {\n    const array = this.hasFarmaRennovaFeature\n      ? this.prescription.productsRennova\n      : this.prescription.medicaments;\n\n    array.forEach(data => {\n      data.valid = value;\n    });\n    this.refreshStatus();\n  }\n\n  getSpecialties() {\n    if (this.prescription.healthProfessional && this.prescription.healthProfessional.specialties) {\n      return this.prescription.healthProfessional.specialties.map(s => s.title).join(', ');\n    }\n    return ['Não possui especialidades cadastradas'];\n  }\n\n  onSubmit() {\n    const array = this.hasFarmaRennovaFeature\n      ? this.prescription.productsRennova\n      : this.prescription.medicaments;\n    const medicinesRetained = array.filter(m => m.valid);\n    if (medicinesRetained.length === 0) {\n      this.notification.notify('warning', 'Aviso', 'Selecione um medicamento');\n    } else {\n      this.hasFarmaRennovaFeature\n        ? this.saveRetentionFeedback(this.prescription.healthProfessional.cpf, medicinesRetained)\n        : this.openModalBuyerData(medicinesRetained);\n    }\n  }\n\n  openModalBuyerData(medicinesRetained) {\n    const modal = this.modalService.create<ModalBuyerDataComponent>({\n      nzContent: ModalBuyerDataComponent,\n      nzComponentParams: {\n        patient: this.prescription.patient\n      },\n      nzFooter: null,\n      nzWidth: 900\n    });\n    this.ngZone.run(() => {\n      modal.afterOpen.pipe(distinctUntilChanged()).subscribe(() => {\n        const instance = modal.getContentComponent();\n        if (instance) {\n          instance.saveRetention.subscribe(cpf => {\n            this.saveRetentionFeedback(cpf, medicinesRetained);\n            modal.close();\n          });\n        }\n      });\n    });\n  }\n\n  saveRetentionFeedback(cpfBuyer: string, medicinesRetained: any[]) {\n    const cpf = cpfBuyer.replace(/[^\\d]+/g, '');\n    this.confirm(cpf, medicinesRetained);\n  }\n\n  confirm(cpfBuyer: string, medicinesRetained: any[]) {\n    const retention = {\n      cpfBuyer,\n      medicinesRetained\n    };\n\n    this.prescriptionService\n      .confirm(retention, this.pharmacyId, this.prescriptionCode)\n      .then((res: Retention) => {\n        if (res.error) {\n          this.notification.notify('warning', 'Aviso', res.message);\n        } else {\n          this.router.navigate([`document/confirmation/successful/${res.dispensationCode}`]);\n        }\n      });\n  }\n\n  changeRoute() {\n    window.location.href = '/dashboard';\n  }\n\n  downloadPrescriptionPdf(prescription) {\n    this.prescriptionService.downloadPrescriptionPdf(prescription.code);\n  }\n\n  getProfessionalTypeName() {\n    return HealthProfessional.getProfessionalTypeName(\n      this.prescription.healthProfessional.professionalType\n    );\n  }\n\n  async updateMedicaments() {\n    for await (const medicament of this.prescription.medicaments) {\n      if (!!medicament.ean) {\n        try {\n          const medicamentsCR = await this.crService.searchMedicament(medicament.ean).toPromise();\n          if (medicamentsCR.length > 0) {\n            const medicamentCR = medicamentsCR[0];\n            medicament.name = medicamentCR.nome;\n            medicament.prescriptionTypeId = medicamentCR.prescriptionTypeId;\n            medicament.typeCr = medicamentCR.typeCr;\n            medicament.type = 'industrialized';\n            medicament.laboratory = medicamentCR.laboratorio;\n            medicament.description = medicamentCR.apresentacaoCustomizada;\n            medicament.medicamentId = medicamentCR.id;\n            medicament.principle = medicamentCR.principio;\n          }\n        } catch (error) {\n          console.log(error);\n          this.toast.notify('error', 'Erro ao consultar dados do medicamento.');\n        }\n      } else {\n        medicament.type = 'free-text';\n      }\n    }\n  }\n}\n","export default \".toolbar {\\n  height: 10.94rem;\\n  display: flex;\\n}\\n.toolbar .title {\\n  font-size: 50px;\\n  margin-bottom: 32px;\\n  padding: 40px 15px 15px 35px;\\n  text-align: center;\\n}\\n.footer {\\n  padding: 0;\\n  border: 0;\\n  z-index: 1;\\n}\\n.footer .btn {\\n  box-shadow: none;\\n  border-radius: 0;\\n  height: 100%;\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  padding-top: 0.725rem;\\n}\\n.footer .btn i {\\n  margin-left: 10px;\\n}\\n.footer .btn i:before {\\n  font-size: 16px;\\n}\\n.prescription {\\n  padding: 50px 50px 50px 30px;\\n}\\n.prescription .label,\\n.prescription .subtitle {\\n  color: #4d4d4d;\\n  font-family: \\\"prolight\\\", sans-serif;\\n  font-size: 18px;\\n  padding-left: 0px;\\n}\\n.prescription .code {\\n  font-family: \\\"probold\\\";\\n}\\n.prescription .prescription-code {\\n  line-height: 1;\\n}\\n.patient {\\n  padding-top: 5.5rem !important;\\n}\\n.patient .label,\\n.patient .subtitle {\\n  color: #6f6f6f;\\n  font-family: \\\"probold\\\";\\n  font-size: 18px;\\n  padding-left: 0px;\\n}\\n.patient .regular {\\n  font-family: \\\"proregular\\\";\\n  text-transform: none;\\n}\\n.label {\\n  font-size: 18px;\\n  text-transform: uppercase;\\n}\\n.barcode img:last-of-type {\\n  margin-top: -10px;\\n}\\n.custom-check {\\n  font-size: 14px;\\n  font-family: \\\"probold\\\";\\n  color: #0b6054;\\n}\\n.custom-check.select-all ::ng-deep:not(.ant-checkbox-indeterminate) .ant-checkbox-inner {\\n  background-color: #0b6054;\\n}\\n.custom-check.select-all ::ng-deep.ant-checkbox-indeterminate .ant-checkbox-inner:after {\\n  background-color: #0b6054;\\n}\\n.custom-check.select-all ::ng-deep .ant-checkbox-checked .ant-checkbox-inner {\\n  border-color: #0b6054;\\n}\\n.custom-check ::ng-deep .ant-checkbox-inner {\\n  background-color: #fff;\\n  border: 2px solid #0b6054;\\n}\\n.custom-check ::ng-deep .ant-checkbox-checked .ant-checkbox-inner {\\n  background-color: #0b6054;\\n}\\n.medication-container {\\n  padding-left: 0;\\n}\\n.medication-container .custom-check {\\n  margin-top: 4px;\\n}\\n.medication-container:hover {\\n  background-color: transparent;\\n}\\n.uppercase {\\n  text-transform: uppercase !important;\\n}\\n.download-pdf {\\n  font-size: 40px;\\n  cursor: pointer;\\n}\\n.download-pdf span {\\n  font-size: 12px;\\n  text-transform: none !important;\\n  color: #000000;\\n  font-weight: bolder;\\n}\\n.icon-pdf {\\n  font-size: 40px;\\n  margin-left: 80px;\\n  cursor: pointer;\\n}\\n.quantity {\\n  font-size: 10px;\\n  font-family: \\\"probold\\\";\\n}\\n.quantity .title {\\n  padding: 2px 13px;\\n  background-color: #363636b3;\\n}\\n.quantity .number {\\n  padding: 2px 6px;\\n  background-color: #36363659;\\n}\";","export default \"<app-alternative-navbar title=\\\"Receitas\\\" titleIcon=\\\"fas fa-list-ul\\\"></app-alternative-navbar>\\n<app-sidebar-menu></app-sidebar-menu>\\n\\n<div class=\\\"container\\\">\\n  <div class=\\\"listing\\\">\\n    <nz-card *ngFor=\\\"let prescription of prescriptions\\\" [nzBordered]=\\\"false\\\" theme>\\n      <nz-tabset [nzTabBarExtraContent]=\\\"cardPrescription\\\">\\n        <nz-tab nzTitle=\\\"Receita\\\">\\n          <p><span class=\\\"bold\\\">Código da receita: </span>{{ prescription.code }}</p>\\n          <p>\\n            <span class=\\\"bold\\\">Data de emissão: </span\\n            >{{ prescription.createdAt | date: 'dd/MM/yyyy, HH:mm' }}\\n          </p>\\n          <p>\\n            <span class=\\\"bold\\\">Quantidade de medicamentos: </span>\\n            {{ prescription?.amountOfMedicines }}\\n          </p>\\n        </nz-tab>\\n        <nz-tab\\n          *ngIf=\\\"prescription.healthProfessional as healthProfessional\\\"\\n          [nzTitle]=\\\"getProfessionalTypeName(healthProfessional.professionalType)\\\"\\n        >\\n          <p><span class=\\\"bold\\\">Nome: </span>{{ healthProfessional.name }}</p>\\n          <p>\\n            <span class=\\\"bold\\\">{{ healthProfessional.regionalCouncilNumber.label }}: </span\\n            >{{ healthProfessional.regionalCouncilNumber?.number }} -\\n            {{ healthProfessional.regionalCouncilNumber?.uf }}\\n          </p>\\n          <p *ngIf=\\\"prescription.local as local\\\">\\n            <span class=\\\"bold\\\">Endereço: </span>{{ local.name }} - {{ local.address?.city }} /\\n            {{ local.address?.uf }}\\n          </p>\\n        </nz-tab>\\n        <nz-tab *ngIf=\\\"prescription.patient as patient\\\" nzTitle=\\\"Paciente\\\">\\n          <p><span class=\\\"bold\\\">Nome: </span>{{ patient.name }}</p>\\n          <p><span class=\\\"bold\\\">CPF: </span>{{ patient.cpf }}</p>\\n          <p>\\n            <span class=\\\"bold\\\">Endereço: </span>{{ patient.address?.city }} -\\n            {{ patient.address?.uf }}\\n          </p>\\n        </nz-tab>\\n      </nz-tabset>\\n\\n      <ng-template #cardPrescription>\\n        <button (click)=\\\"changeRoute(prescription.code)\\\" class=\\\"btn btn-success\\\" theme>\\n          Abrir receita\\n        </button>\\n      </ng-template>\\n    </nz-card>\\n  </div>\\n</div>\\n<div class=\\\"bg-dark-green\\\"></div>\\n\";","import { Component, OnInit } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { HealthProfessional } from '@app/shared/models/health-professional';\nimport { Prescription } from '@app/shared/models/prescription';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { PrescriptionService } from '../../../document/services/prescription.service';\nimport { nativeAsync } from '@app/shared/decorators/nativeAsync';\n\n@Component({\n  selector: 'app-listing',\n  templateUrl: './listing.component.html',\n  styleUrls: ['./listing.component.scss']\n})\nexport class ListingComponent implements OnInit {\n  initLoading = true;\n  loadingMore = false;\n  prescriptions: Prescription[];\n  showPrescriptionTab: Boolean = true;\n  showDoctorTab: Boolean = false;\n  showPatientTab: Boolean = false;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private prescriptionService: PrescriptionService,\n    private notification: AppToastService\n  ) {\n    const state = this.router.getCurrentNavigation().extras.state;\n    if (state) {\n      this.prescriptions = state.prescriptions;\n    }\n  }\n\n  ngOnInit() {\n    if (!this.prescriptions) {\n      this.route.params.subscribe(params => {\n        const param = params['param'];\n        this.requests(param);\n      });\n    }\n  }\n\n  private requests(param: string) {\n    this.prescriptionService.getPrescriptionsPatient(param).subscribe(prescriptions => {\n      this.prescriptions = prescriptions;\n    });\n  }\n\n  changeRoute(prescriptionCode) {\n    this.router.navigate(['/document/confirmation', prescriptionCode]);\n    this.notification.notify(\n      'warning',\n      'Atenção',\n      'Esta prescrição só é válida mediante o registro da dispensação.'\n    );\n  }\n\n  getProfessionalTypeName(professionalType: string) {\n    return HealthProfessional.getProfessionalTypeName(professionalType);\n  }\n}\n","export default \".container {\\n  display: flex;\\n  justify-content: center;\\n}\\n\\n.listing {\\n  z-index: 4;\\n  overflow: overlay;\\n  width: 500px;\\n  height: 500px;\\n  margin-top: 30px;\\n}\\n\\n.bg-dark-green {\\n  background-color: #0b6054;\\n  height: 280px;\\n  position: absolute;\\n  width: 100%;\\n  bottom: 0px;\\n}\\n\\nnz-card {\\n  border: solid;\\n  border-color: #e8e8e8;\\n  border-width: 1px;\\n  margin-bottom: 10px;\\n}\\n\\nnz-card p {\\n  margin-bottom: 0px;\\n}\\n\\nnz-card p .bold {\\n  font-weight: 600;\\n}\\n\\nnz-tabset .ant-tabs-tab {\\n  color: red;\\n}\\n\\n.btn {\\n  height: 32px;\\n  font-size: 13px;\\n  padding-top: 2px;\\n  padding-bottom: 2px;\\n}\";","export default \"<div class=\\\"page-content\\\">\\n  <app-navigation></app-navigation>\\n  <app-sidebar-menu></app-sidebar-menu>\\n  <div class=\\\"upload-content\\\">\\n    <img class=\\\"download-icon\\\" src=\\\"assets/icons/download-solid.svg\\\" />\\n    <span>O download da sua receita foi realizado com sucesso.</span>\\n    <span>\\n      Agora você precisa assinar digitalmente o PDF da receita e depois salvá-la dentro da plataforma.\\n    </span>\\n    <br /><br />\\n    <span\\n      >Obs.: Caso tenha duvidas,\\n      <a target=\\\"_blank\\\" href=\\\"/assets/file/tutorial_sign.pdf\\\">clique aqui</a> para verificar o passo a\\n      passo de como assinar a Receita</span\\n    >\\n    <br />\\n    <span>Salvar o PDF da Receita Assinado</span>\\n    <br />\\n    <input\\n      class=\\\"btn btn-primary text-white mt-50\\\"\\n      type=\\\"file\\\"\\n      (change)=\\\"uploadFile($event)\\\"\\n      placeholder=\\\"Upload file\\\"\\n      accept=\\\".pdf\\\"\\n    />\\n  </div>\\n</div>\\n\\n<app-unsigned-prescription-modal></app-unsigned-prescription-modal>\\n\";","import { Component, ViewChild } from '@angular/core';\nimport { PdfService } from '@app/modules/document/services/pdf.service';\nimport { UnsignedPrescriptionModalComponent } from '@app/modules/document/pages/prescription/unsigned-prescription-modal.component';\nimport { ActivatedRoute } from '@angular/router';\n\n@Component({\n  selector: 'app-upload-pdf',\n  templateUrl: './upload-pdf.component.html',\n  styleUrls: ['./upload-pdf.component.scss']\n})\nexport class UploadPdfComponent {\n  constructor(private pdfService: PdfService, private router: ActivatedRoute) {}\n\n  @ViewChild(UnsignedPrescriptionModalComponent, { static: true })\n  unsignedPrescriptionModal: UnsignedPrescriptionModalComponent;\n\n  uploadFile(event) {\n    const fileList: FileList = event.target.files;\n    this.router.params.subscribe(async params => {\n      const code = params['code'];\n      if (fileList.length > 0) {\n        const file: File = fileList[0];\n        await this.pdfService.postFilePdf(file, code);\n        this.unsignedPrescriptionModal.createTplModal(code);\n      }\n    });\n  }\n}\n","export default \".upload-content {\\n  height: 100vh;\\n  display: flex;\\n  flex-direction: column;\\n  justify-content: center;\\n  align-items: center;\\n  color: #3c3c3c;\\n}\\n.upload-content a {\\n  color: #1ae0c2;\\n}\\n.upload-content .download-icon {\\n  height: 4rem;\\n}\\n.btn-upload {\\n  border: none;\\n  box-sizing: border-box;\\n  background-color: #fff;\\n}\";","export default \"<div class=\\\"page-content\\\">\\n  <app-alternative-navbar title=\\\"Informações da Receita\\\"></app-alternative-navbar>\\n  <app-sidebar-menu></app-sidebar-menu>\\n  <section class=\\\"container-fluid\\\">\\n    <div class=\\\"row\\\">\\n      <div class=\\\"col sucessfull bg-green full-height\\\">\\n        <h4 class=\\\"title text-white\\\">\\n          Venda/retenção confirmada com sucesso!\\n        </h4>\\n        <div class=\\\"code text-white\\\">\\n          <span class=\\\"title-2\\\">CÓDIGO DE DISPENSAÇÃO</span>\\n          <span class=\\\"codeNumber\\\">{{ retention?.dispensationCode }}</span>\\n        </div>\\n        <br />\\n        <div class=\\\"code text-white\\\">\\n          <span class=\\\"title-2\\\">CÓDIGO DA RECEITA</span>\\n          <span class=\\\"codeNumber\\\">{{ retention?.prescription?.code }}</span>\\n        </div>\\n      </div>\\n\\n      <div class=\\\"col data-col\\\" style=\\\"    height: calc(100vh - 130px);\\\">\\n        <div class=\\\"toolbar bg-gray-black data-height text-white title\\\">\\n          <p>DADOS PARA EXPORTAÇÃO SNGPC:</p>\\n\\n          <div class=\\\"row\\\">\\n            <div class=\\\"col-md-6\\\">\\n              <span>PACIENTE</span>\\n              <br />\\n              <div class=\\\"data\\\">\\n                <span>{{\\n                  retention?.prescription?.patient?.name || retention?.prescription?.pet?.name\\n                }}</span>\\n                <div\\n                  *ngIf=\\\"hasAddress || hasAddressResponsible || hasAddressPet; else templateEmptyAddress\\\"\\n                >\\n                  <span *ngIf=\\\"!isPet\\\">\\n                    {{\\n                      retention?.prescription?.patient?.address?.street ||\\n                        retention?.prescription?.patient?.responsible?.address?.street ||\\n                        retention?.prescription?.pet?.responsible?.address?.street\\n                    }}, nº\\n                    {{\\n                      retention?.prescription?.patient?.address?.number ||\\n                        retention?.prescription?.patient?.responsible?.address?.number ||\\n                        retention?.prescription?.pet?.responsible?.address?.number\\n                    }}\\n                    {{\\n                      retention?.prescription?.patient?.address?.complement ||\\n                        retention?.prescription?.patient?.responsible?.address?.complement ||\\n                        retention?.prescription?.pet?.responsible?.address?.complement\\n                    }},\\n                    {{\\n                      retention?.prescription?.patient?.address?.city ||\\n                        retention?.prescription?.patient?.responsible?.address?.city ||\\n                        retention?.prescription?.pet?.responsible?.address?.city\\n                    }}/\\n                    {{\\n                      retention?.prescription?.patient?.address?.uf ||\\n                        retention?.prescription?.patient?.responsible?.address?.uf ||\\n                        retention?.prescription?.pet?.responsible?.address?.uf\\n                    }}\\n                  </span>\\n                  <span *ngIf=\\\"isPet\\\">\\n                    {{ retention?.prescription?.pet?.responsible?.address?.street }}, nº\\n                    {{ retention?.prescription?.pet?.responsible?.address?.number }}\\n                    {{ retention?.prescription?.pet?.responsible?.address?.complement }},\\n                    {{ retention?.prescription?.pet?.responsible?.address?.city }}/\\n                    {{ retention?.prescription?.pet?.responsible?.address?.uf }}\\n                  </span>\\n                </div>\\n                <ng-template #templateEmptyAddress>\\n                  <div>\\n                    <span>Não possui Endereço cadastrado</span>\\n                  </div>\\n                </ng-template>\\n                <span>{{ getAgePatient() }} Anos</span> <br />\\n                <span *ngIf=\\\"!isPet\\\"\\n                  >Gênero:\\n                  {{ retention?.prescription?.patient?.sex === 'M' ? 'Masculino' : 'Feminino' }}</span\\n                >\\n                <span *ngIf=\\\"isPet\\\"\\n                  >Gênero: {{ retention?.prescription?.pet?.sex === 'M' ? 'Macho' : 'Fêmea' }}</span\\n                >\\n              </div>\\n            </div>\\n            <div class=\\\"col-md-6\\\" *ngIf=\\\"!hasFarmaRennovaFeature\\\">\\n              <span>COMPRADOR</span>\\n              <br />\\n              <div class=\\\"data\\\">\\n                <span>{{ buyer?.name }}</span\\n                ><br />\\n                <span>\\n                  {{ buyer?.address?.street }}, nº {{ buyer?.address?.number }}\\n                  {{ buyer?.address?.complement }}, {{ buyer?.address?.city }}/\\n                  {{ buyer?.address?.uf }} </span\\n                ><br />\\n                <span *ngIf=\\\"buyer?.telephone\\\">Tel: {{ buyer?.telephone | formattedTel }}<br /></span>\\n                <span *ngIf=\\\"buyer?.cellphone\\\">Cel: {{ buyer?.cellphone | formattedCel }}<br /></span>\\n                <span>RG {{ buyer?.identity }}</span>\\n              </div>\\n            </div>\\n            <div class=\\\"col-md-6 mt-3\\\">\\n              <span>PRESCRITOR</span>\\n              <br />\\n              <div class=\\\"data\\\">\\n                <span>{{ getPreWriterInfo(retention?.prescription).name }}</span\\n                ><br />\\n                <span\\n                  >{{ getPreWriterInfo(retention?.prescription).regionalCouncil.label }}:\\n                  {{ getPreWriterInfo(retention?.prescription).regionalCouncil.number }}/{{\\n                    getPreWriterInfo(retention?.prescription).regionalCouncil.uf\\n                  }} </span\\n                ><br />\\n                <span>\\n                  {{ retention?.prescription?.local?.address.street }}, nº\\n                  {{ retention?.prescription?.local?.address.number }}\\n                  {{ retention?.prescription?.local?.address.complement }},\\n                  {{ retention?.prescription?.local?.address.city }}/\\n                  {{ retention?.prescription?.local?.address.uf }} </span\\n                ><br />\\n                <span *ngIf=\\\"retention?.prescription?.healthProfessional.telephone\\\"\\n                  >Tel: {{ retention?.prescription?.healthProfessional.telephone | formattedTel }}</span\\n                ><br />\\n                <span *ngIf=\\\"retention?.prescription?.healthProfessional.cellphone\\\"\\n                  >Cel: {{ retention?.prescription?.healthProfessional.cellphone | formattedCel }}</span\\n                >\\n              </div>\\n            </div>\\n          </div>\\n        </div>\\n\\n        <div class=\\\"listing\\\">\\n          <div class=\\\"text-black medicaments\\\">\\n            {{ hasFarmaRennovaFeature ? 'PRODUTOS' : 'MEDICAMENTOS' }}\\n          </div>\\n          <ng-container *ngIf=\\\"!hasFarmaRennovaFeature; else templateProdutosRennova\\\">\\n            <div class=\\\"text-black medicaments\\\" *ngFor=\\\"let medicament of retention?.medicaments\\\">\\n              <span class=\\\"title-2 name\\\">{{ medicament.name }} - {{ medicament.principle }}</span>\\n              <span class=\\\"title-2 name\\\">Posologia: {{ medicament.dosage }}</span>\\n              <div class=\\\"quantity text-white\\\">\\n                <span class=\\\"title\\\">QUANTIDADE</span>\\n                <span class=\\\"number\\\">{{ medicament.quantityRetained }}</span>\\n              </div>\\n            </div>\\n          </ng-container>\\n          <ng-template #templateProdutosRennova>\\n            <div class=\\\"text-black medicaments\\\" *ngFor=\\\"let medicament of retention?.medicaments\\\">\\n              <ng-container *ngIf=\\\"medicament?.product as product\\\">\\n                <span class=\\\"title-2 name\\\">{{ product?.name }}</span>\\n                <ng-container *ngFor=\\\"let item of product.items\\\">\\n                  <span class=\\\"title-1\\\">{{ item?.name }}</span>\\n                  <ul style=\\\"margin-bottom: 0;\\\">\\n                    <li *ngFor=\\\"let obj of item.descriptions\\\">\\n                      <div class=\\\"d-flex\\\">\\n                        <span style=\\\"text-align: justify; font-family: monospace;\\\">\\n                          {{ obj?.fullDescription }}\\n                        </span>\\n                      </div>\\n                    </li>\\n                  </ul>\\n                </ng-container>\\n                <p>{{ productItem?.observation }}</p>\\n                <div class=\\\"quantity text-white\\\" style=\\\"margin-bottom: 10px;\\\">\\n                  <span class=\\\"title\\\">QUANTIDADE</span>\\n                  <span class=\\\"number\\\">{{ medicament.quantityRetained }}</span>\\n                </div>\\n              </ng-container>\\n            </div>\\n          </ng-template>\\n        </div>\\n\\n        <div class=\\\"btns\\\">\\n          <div class=\\\"btn-medicament\\\" *ngIf=\\\"retention?.prescription?.amountOfMedicines\\\">\\n            <button class=\\\"btn btn-primary btn-md register-btn other-medicament\\\" (click)=\\\"retainAgain()\\\">\\n              SELECIONAR OUTRO MEDICAMENTO\\n            </button>\\n          </div>\\n          <div class=\\\"btn-prescription\\\">\\n            <button class=\\\"btn btn-primary btn-md register-btn other-prescription\\\" (click)=\\\"openModal()\\\">\\n              SELECIONAR OUTRA RECEITA\\n            </button>\\n          </div>\\n          <div class=\\\"btn-prescription\\\">\\n            <button\\n              class=\\\"btn btn-primary btn-md register-btn other-prescription\\\"\\n              (click)=\\\"changeRoute('dashboard')\\\"\\n            >\\n              FINALIZAR\\n            </button>\\n          </div>\\n        </div>\\n      </div>\\n    </div>\\n  </section>\\n  <app-footer></app-footer>\\n</div>\\n\";","import { Component, OnInit } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { BsModalRef } from 'ngx-bootstrap/modal';\nimport { PrescriptionService } from '../../../document/services/prescription.service';\nimport { nativeAsync } from '@app/shared/decorators/nativeAsync';\n\n@Component({\n  selector: 'app-modal-search',\n  templateUrl: './modal-search.component.html',\n  styleUrls: ['./modal-search.component.scss']\n})\nexport class ModalSearchComponent implements OnInit {\n  constructor(\n    private router: Router,\n    public modalRef: BsModalRef,\n    private notification: AppToastService,\n    private prescriptionService: PrescriptionService\n  ) {}\n\n  ngOnInit() {}\n\n  search(param: string) {\n    param = param === undefined ? '' : param.replace(/[^a-z0-9]+/gi, '');\n    if (param === '') {\n      this.modalRef.hide();\n      this.notification.notify('warning', 'Atenção', 'CPF ou Código da Receita não informado');\n    } else if (param.length === 11 || param.length === 15) {\n      this.requests(param);\n    } else {\n      this.modalRef.hide();\n      this.notification.notify('warning', 'Atenção', 'CPF ou código inválido');\n    }\n  }\n\n  @nativeAsync\n  private async requests(param: string) {\n    try {\n      const prescriptions = await this.prescriptionService.getPrescriptionsPatient(param).toPromise();\n\n      if (param.length === 11) {\n        if (prescriptions.length === 0) {\n          this.notification.notify(\n            'warning',\n            'Atenção',\n            'Não existe prescrições com medicamentos a serem dispensados para o CPF informado'\n          );\n          return;\n        }\n\n        this.router.navigate(['/prescription/listing-prescriptions/', param], {\n          state: { prescriptions: prescriptions }\n        });\n      } else {\n        this.router.navigate(['/prescription/confirmation', param], {\n          state: { prescription: prescriptions }\n        });\n      }\n      this.modalRef.hide();\n    } catch (error) {\n      this.modalRef.hide();\n      if (error.status === 404) {\n        this.notification.notify('warning', 'Atenção', error.error.message);\n      }\n    }\n  }\n}\n","export default \"<div class=\\\"modal-header\\\">\\n  <h4 class=\\\"modal-title pull-left text-white\\\">Buscar receita</h4>\\n  <button type=\\\"button\\\" class=\\\"close pull-right\\\" aria-label=\\\"Close\\\" (click)=\\\"modalRef.hide()\\\">\\n    <span aria-hidden=\\\"true\\\">&times;</span>\\n  </button>\\n</div>\\n<form (submit)=\\\"search(param.value)\\\">\\n  <div class=\\\"modal-body\\\">\\n    <p>Digite abaixo o CPF (apenas números) do paciente ou o código da receita</p>\\n    <input nz-input #param theme />\\n    <label>\\n      <i class=\\\"fa fa-arrow-right\\\" (click)=\\\"search(param.value)\\\"></i>\\n    </label>\\n  </div>\\n</form>\\n\";","export default \".modal-header {\\n  background-color: #4cbca3;\\n  font-family: \\\"probold\\\";\\n}\\n\\n.modal-body {\\n  padding: 0px;\\n  height: 170px;\\n  display: flex;\\n  align-items: center;\\n  flex-direction: column;\\n  justify-content: center;\\n}\\n\\n.modal-body input {\\n  width: 265px;\\n  height: 35px;\\n}\\n\\n.modal-body label {\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  position: relative;\\n  z-index: 1;\\n  right: -118px;\\n  top: -28px;\\n  font-size: 15px;\\n  margin: 0px;\\n  width: 30px;\\n}\\n\\n.modal-body label i {\\n  cursor: pointer;\\n}\\n\\np {\\n  color: #363636;\\n  font-size: 20px;\\n  font-family: \\\"prolight\\\";\\n  text-align: center;\\n}\";","import { Component, OnInit } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { AuthService } from '@app/core/services/auth.service';\nimport { Buyer, HealthProfessional } from '@app/shared/models';\nimport { User } from '@app/shared/models/decodedLoginToken';\nimport { Retention } from '@app/shared/models/retention';\nimport _ from 'lodash';\nimport { BsModalRef, BsModalService } from 'ngx-bootstrap/modal';\nimport { BuyerService } from '../../../document/services/buyer.service';\nimport { RetentionService } from '../../../document/services/retention.service';\nimport { ModalSearchComponent } from '../modal-search/modal-search.component';\n\n@Component({\n  selector: 'app-retention-confirmation',\n  templateUrl: './retention-confirmation.component.html',\n  styleUrls: ['./retention-confirmation.component.scss']\n})\nexport class RetentionConfirmationComponent implements OnInit {\n  retention: Retention;\n  buyer: Buyer;\n  medicamentsRetained;\n  modalRef: BsModalRef;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private modalService: BsModalService,\n    private retentionService: RetentionService,\n    private buyerService: BuyerService,\n    private authService: AuthService\n  ) {}\n\n  ngOnInit() {\n    this.route.params.subscribe(params => {\n      const dispensationCode = params['dispensationCode'];\n      this.retentionService.getRetentionByCode(dispensationCode).subscribe(retention => {\n        this.retention = retention;\n        this.setInfoInMedicamentsRetained();\n\n        if (\n          this.retention.prescription.patient &&\n          this.retention.prescription.patient.cpf === this.retention.cpfBuyer\n        ) {\n          this.buyer = new Buyer();\n          this.buyer.name = this.retention.prescription.patient.name;\n          this.buyer.cpf = this.retention.prescription.patient.cpf;\n          this.buyer.address = this.retention.prescription.patient.address;\n          this.buyer.telephone = this.retention.prescription.patient.telephone;\n          this.buyer.cellphone = this.retention.prescription.patient.cellphone;\n          this.buyer.identity = this.retention.prescription.patient.identity;\n        } else {\n          this.buyerService.getBuyerByCpf(this.retention.cpfBuyer).subscribe(buyer => {\n            this.buyer = buyer;\n          });\n        }\n      });\n    });\n  }\n\n  get user(): User {\n    return this.authService.user();\n  }\n\n  get hasFarmaRennovaFeature(): boolean {\n    return this.user && this.user.features.some(f => f.name === 'Farma Rennova');\n  }\n\n  get isPet() {\n    return Boolean(this.retention && this.retention.prescription.pet);\n  }\n\n  get hasAddress() {\n    return Boolean(\n      this.retention &&\n        this.retention.prescription.patient &&\n        this.retention.prescription.patient.address &&\n        (!_.isEmpty(this.retention.prescription.patient.address.cep) ||\n          !_.isEmpty(this.retention.prescription.patient.address.city) ||\n          !_.isEmpty(this.retention.prescription.patient.address.complement) ||\n          !_.isEmpty(this.retention.prescription.patient.address.neighborhood) ||\n          !_.isEmpty(this.retention.prescription.patient.address.number) ||\n          !_.isEmpty(this.retention.prescription.patient.address.street) ||\n          !_.isEmpty(this.retention.prescription.patient.address.uf))\n    );\n  }\n\n  get hasAddressResponsible() {\n    return Boolean(\n      this.retention &&\n        this.retention.prescription.patient &&\n        this.retention.prescription.patient.responsible &&\n        this.retention.prescription.patient.responsible.address &&\n        (!_.isEmpty(this.retention.prescription.patient.responsible.address.cep) ||\n          !_.isEmpty(this.retention.prescription.patient.responsible.address.city) ||\n          !_.isEmpty(this.retention.prescription.patient.responsible.address.complement) ||\n          !_.isEmpty(this.retention.prescription.patient.responsible.address.neighborhood) ||\n          !_.isEmpty(this.retention.prescription.patient.responsible.address.number) ||\n          !_.isEmpty(this.retention.prescription.patient.responsible.address.street) ||\n          !_.isEmpty(this.retention.prescription.patient.responsible.address.uf))\n    );\n  }\n\n  get hasAddressPet() {\n    return Boolean(\n      this.retention &&\n        this.retention.prescription.pet &&\n        this.retention.prescription.pet.responsible &&\n        this.retention.prescription.pet.responsible.address &&\n        (!_.isEmpty(this.retention.prescription.pet.responsible.address.cep) ||\n          !_.isEmpty(this.retention.prescription.pet.responsible.address.city) ||\n          !_.isEmpty(this.retention.prescription.pet.responsible.address.complement) ||\n          !_.isEmpty(this.retention.prescription.pet.responsible.address.neighborhood) ||\n          !_.isEmpty(this.retention.prescription.pet.responsible.address.number) ||\n          !_.isEmpty(this.retention.prescription.pet.responsible.address.street) ||\n          !_.isEmpty(this.retention.prescription.pet.responsible.address.uf))\n    );\n  }\n\n  setInfoInMedicamentsRetained() {\n    for (const medicamentRetained of this.retention.medicaments) {\n      const medicament = this.retention.prescription.medicaments.filter(\n        m => m.ean === medicamentRetained.ean\n      )[0];\n      if (medicament) {\n        medicamentRetained.name = medicament.name;\n        medicamentRetained.principle = medicament.principle;\n        medicamentRetained.dosage = medicament.dosage;\n      }\n    }\n  }\n\n  getPreWriterInfo(prescription) {\n    const preWriter = {\n      name: '',\n      cpf: '',\n      label: '',\n      regionalCouncil: { label: '', number: 0, uf: '' },\n      specialties: '',\n      contact: ''\n    };\n    if (prescription) {\n      preWriter.label = HealthProfessional.getProfessionalTypeName(\n        prescription.healthProfessional.professionalType\n      );\n      preWriter.name = prescription.healthProfessional.name;\n      preWriter.cpf = prescription.healthProfessional.cpf;\n      preWriter.regionalCouncil.label = HealthProfessional.getRegionalCouncilLabel(\n        prescription.healthProfessional.professionalType\n      );\n      preWriter.regionalCouncil.number = prescription.healthProfessional.regionalCouncilNumber.number;\n      preWriter.regionalCouncil.uf = prescription.healthProfessional.regionalCouncilNumber.uf;\n    }\n\n    return preWriter;\n  }\n\n  getAgePatient() {\n    if (this.retention !== undefined) {\n      const dateOfBirth = this.isPet\n        ? this.retention.prescription.pet.dateOfBirth\n        : this.retention.prescription.patient.dateOfBirth;\n      const nascimento = new Date(dateOfBirth);\n      const hoje = new Date();\n      let diferencaAnos = hoje.getFullYear() - nascimento.getFullYear();\n      if (\n        new Date(hoje.getFullYear(), hoje.getMonth(), hoje.getDate()) <\n        new Date(hoje.getFullYear(), nascimento.getMonth(), nascimento.getDate())\n      ) {\n        diferencaAnos--;\n      }\n      return diferencaAnos;\n    }\n    return 0;\n  }\n\n  retainAgain() {\n    this.router.navigate([`prescription/confirmation/${this.retention.prescription.code}`]);\n  }\n\n  validatePrescription() {\n    this.modalRef.hide();\n    const prescriptionCode = (<HTMLInputElement>document.getElementById('prescriptionCode')).value;\n    localStorage.setItem('prescriptionCode', prescriptionCode);\n    this.router.navigate([`/prescription/confirmation/${prescriptionCode}`]);\n  }\n\n  getMedicamentsRetained(prescription) {\n    const medicaments = prescription.medicaments;\n    const retention = prescription.retention;\n  }\n\n  openModal() {\n    this.modalRef = this.modalService.show(ModalSearchComponent, {\n      backdrop: 'static',\n      keyboard: false\n    });\n  }\n\n  changeRoute(route: string) {\n    this.router.navigate([`/${route}`]);\n  }\n}\n","export default \".full-height {\\n  min-height: calc(95.3vh - 100px);\\n}\\n\\n.data-height {\\n  min-height: calc(120vh - 693px);\\n}\\n\\n.sucessfull {\\n  padding-left: 0px;\\n  padding-right: 0px;\\n  padding: 40px 0px 0px 35px;\\n}\\n\\n.sucessfull .title {\\n  font-size: 50px;\\n  margin-bottom: 100px;\\n}\\n\\n.sucessfull .code {\\n  display: grid;\\n}\\n\\n.sucessfull .code .codeNumber {\\n  font-size: 42px;\\n  font-family: \\\"prolight\\\";\\n}\\n\\n.text-white .export-data {\\n  font-family: \\\"probold\\\";\\n  font-size: 18px;\\n}\\n\\n.text-white .patient,\\n.text-white .prescriber {\\n  font-family: \\\"probold\\\";\\n}\\n\\n.title-2 {\\n  font-size: 15px;\\n  font-family: \\\"probold\\\";\\n}\\n\\n.data-col {\\n  padding-left: 0px;\\n  padding-right: 0px;\\n}\\n\\n.data-col .toolbar {\\n  padding-left: 15px;\\n  padding-top: 35px;\\n}\\n\\n.data-col .toolbar .data {\\n  font-family: \\\"prolight\\\";\\n}\\n\\n.data-col .listing {\\n  overflow: auto;\\n  overflow-x: hidden;\\n  height: 35vh;\\n}\\n\\n.data-col .listing .medicaments {\\n  display: grid;\\n  padding-left: 15px;\\n  padding-top: 13px;\\n}\\n\\n.data-col .listing .medicaments .name {\\n  font-size: 14px;\\n  color: #363636;\\n}\\n\\n.data-col .listing .medicaments .description {\\n  font-size: 11px;\\n  color: #363636c4;\\n}\\n\\n.data-col .listing .medicaments .quantity {\\n  font-size: 10px;\\n  font-family: \\\"probold\\\";\\n}\\n\\n.data-col .listing .medicaments .quantity .title {\\n  padding: 2px 13px;\\n  background-color: #363636b3;\\n}\\n\\n.data-col .listing .medicaments .quantity .number {\\n  padding: 2px 6px;\\n  background-color: #36363659;\\n}\\n\\n.data-col .btns {\\n  padding-top: 0px;\\n  background-color: #80808030;\\n  display: flex;\\n  justify-content: center;\\n  align-items: center;\\n  height: 52px;\\n  font-size: 10px;\\n  position: absolute;\\n  width: 100%;\\n  bottom: 0px;\\n}\\n\\n.data-col .btns .btn-medicament {\\n  margin-right: 10px;\\n}\\n\\n.data-col .btns .btn-medicament .other-medicament {\\n  background-color: #363636;\\n  font-family: \\\"probold\\\";\\n  font-size: 10.5px;\\n}\\n\\n.data-col .btns .btn-prescription {\\n  margin-left: 10px;\\n}\\n\\n.data-col .btns .btn-prescription .other-prescription {\\n  background-color: #5ce1c2;\\n  border-color: #5ce1c2;\\n  font-family: \\\"probold\\\";\\n  font-size: 10.5px;\\n  color: #363636;\\n}\\n\\n.page-content {\\n  overflow: hidden;\\n  padding-bottom: 0px;\\n}\\n\\n.select-model {\\n  display: flex;\\n  border: solid 4px blue;\\n}\\n\\n.modal-header {\\n  background-color: #4cbca3;\\n  font-family: \\\"probold\\\";\\n}\\n\\n.modal-body {\\n  padding: 0px;\\n  height: 170px;\\n  display: flex;\\n  justify-content: center;\\n  align-items: center;\\n}\\n\\n.modal-body input {\\n  width: 320px;\\n  height: 35px;\\n  font-family: \\\"prolight\\\";\\n  font-size: 12px;\\n}\\n\\n.modal-body label {\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  position: relative;\\n  z-index: 1;\\n  right: 33px;\\n  top: 2px;\\n  font-size: 15px;\\n  margin: 0px;\\n  width: 30px;\\n}\\n\\n.modal-body label i {\\n  cursor: pointer;\\n}\";","import { NgModule } from '@angular/core';\nimport { RouterModule, Routes } from '@angular/router';\nimport { DocumentComponent } from './document.component';\nimport { DocumentGuard } from './guards/document.guard';\nimport { ConfirmationComponent } from './pages/confirmation/confirmation.component';\nimport { ListingComponent } from './pages/listing/listing.component';\nimport { UploadPdfComponent } from './pages/prescription/upload-pdf.component';\nimport { RetentionConfirmationComponent } from './pages/retention-confirmation/retention-confirmation.component';\n\nconst routes: Routes = [\n  {\n    path: 'new',\n    component: DocumentComponent,\n    canActivate: [DocumentGuard]\n  },\n  { path: ':id/new', component: DocumentComponent, canActivate: [DocumentGuard] },\n  { path: ':id/edit', component: DocumentComponent, canActivate: [DocumentGuard] },\n  {\n    path: 'model/:modelId/:documentType/edit',\n    component: DocumentComponent,\n    canActivate: [DocumentGuard]\n  },\n  { path: 'confirmation/:param', component: ConfirmationComponent },\n  { path: 'confirmation/successful/:dispensationCode', component: RetentionConfirmationComponent },\n  { path: 'listing-prescriptions/:param', component: ListingComponent },\n  { path: 'upload/:code/:id', component: UploadPdfComponent }\n];\n\n@NgModule({\n  imports: [RouterModule.forChild(routes)],\n  exports: [RouterModule]\n})\nexport class DocumentV2RoutingModule {}\n","import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { Attestation } from '@app/shared/models/attestation';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { Patient } from '@app/shared/models/patient';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\n\n@Component({\n  selector: 'app-attestation',\n  templateUrl: './attestation.component.html',\n  styleUrls: ['./attestation.component.scss']\n})\nexport class AttestationComponent implements OnInit {\n  @Input() attestation: Attestation;\n  @Input() patient: Patient;\n  @Input() colorSetting: ColorSetting;\n  @Input() isVeterinarian = false;\n  @Output() formEmitter: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();\n  @Output() onShowModelListFavoriteDocument = new EventEmitter();\n\n  showModelForm = false;\n  showCardTextBox = false;\n  showCardCid = false;\n\n  attestationForm: FormGroup;\n\n  constructor(private fb: FormBuilder, private notification: AppToastService) {\n    this.attestationForm = this.fb.group({\n      description: ['', Validators.required],\n      showPatientCpf: [false],\n      showPrescriberCpf: [false],\n      version: ['BETA']\n    });\n  }\n\n  ngOnInit() {\n    this.init();\n  }\n\n  init() {\n    if (this.attestation) {\n      this.showCardTextBox =\n        this.attestation.description && this.attestation.description.join('\\n').length > 0;\n      this.showModelForm = !!this.attestation.attestationDays && !!this.attestation.typeOfActivity;\n      if (this.showModelForm) {\n        this.resetValidationsDescription();\n      }\n      this.showCardCid = this.attestation.cid && this.attestation.cid.items.length > 0;\n    }\n    this.formEmitter.emit(this.attestationForm);\n  }\n\n  @Input()\n  set attestationModel(attestationModel: any) {\n    if (attestationModel) {\n      this.attestation = attestationModel;\n      this.attestationForm.addControl('title', this.fb.control(''));\n      this.attestationForm.get('title').setValue(attestationModel.title);\n      this.init();\n    }\n  }\n\n  handlerModelFormAttestation(value: boolean) {\n    this.showModelForm = value;\n    if (this.showModelForm && !this.showCardTextBox) {\n      this.attestationForm.get('description').clearValidators();\n      this.attestationForm.get('description').setErrors(null);\n    } else {\n      this.attestationForm.get('description').setValidators([Validators.required]);\n      this.attestation = null;\n    }\n    this.attestationForm.get('description').updateValueAndValidity();\n    this.formEmitter.emit(this.attestationForm);\n  }\n\n  handlerShowCardTextBox(value: boolean) {\n    if (this.showCardTextBox && value) {\n      this.notification.notify('warning', 'Componente já adicionado', '');\n      return;\n    }\n\n    this.showCardTextBox = value;\n    this.attestationForm.get('description').setValue('');\n    if (!this.showCardTextBox && !this.showModelForm) {\n      this.attestationForm.get('description').setValidators([Validators.required]);\n      this.attestationForm.get('description').updateValueAndValidity();\n    } else {\n      this.resetValidationsDescription();\n    }\n  }\n\n  handlerShowCardCid() {\n    this.showCardCid = true;\n    if (!this.showCardTextBox) {\n      this.resetValidationsDescription();\n    }\n  }\n\n  private resetValidationsDescription() {\n    this.attestationForm.get('description').clearValidators();\n    this.attestationForm.get('description').setErrors(null);\n    this.attestationForm.get('description').updateValueAndValidity();\n  }\n}\n","export default \"<div class=\\\"attestation\\\" [formGroup]=\\\"attestationForm\\\">\\n  <app-model-form-pre-preenchido\\n    *ngIf=\\\"showModelForm\\\"\\n    [patient]=\\\"patient\\\"\\n    [form]=\\\"attestationForm\\\"\\n    [attestationDays]=\\\"attestation?.attestationDays\\\"\\n    [typeOfActivity]=\\\"attestation?.typeOfActivity\\\"\\n    (formEmitter)=\\\"attestationForm = $event\\\"\\n    (onClickRemove)=\\\"handlerModelFormAttestation(false)\\\"\\n  ></app-model-form-pre-preenchido>\\n\\n  <app-text-box-form\\n    *ngIf=\\\"showCardTextBox\\\"\\n    [form]=\\\"attestationForm\\\"\\n    [text]=\\\"attestation?.description?.join('\\\\n')\\\"\\n    (formEmitter)=\\\"attestationForm = $event\\\"\\n    (onChangeText)=\\\"attestationForm.get('description').setValue($event)\\\"\\n    (onClickRemove)=\\\"handlerShowCardTextBox(false)\\\"\\n  ></app-text-box-form>\\n\\n  <app-cid-form\\n    [form]=\\\"attestationForm\\\"\\n    *ngIf=\\\"showCardCid\\\"\\n    [authorizedByPatient]=\\\"attestation?.cid?.authorizedByPatient\\\"\\n    [showDescription]=\\\"attestation?.cid?.showDescription\\\"\\n    [items]=\\\"attestation?.cid?.items\\\"\\n    [colorSetting]=\\\"colorSetting\\\"\\n    (onClickRemoveCardCid)=\\\"showCardCid = false\\\"\\n  ></app-cid-form>\\n</div>\\n\\n<app-add-type-options\\n  [viewTextBox]=\\\"true\\\"\\n  [viewFormAttestation]=\\\"!isVeterinarian\\\"\\n  [viewListFavoriteDocument]=\\\"true\\\"\\n  [viewShowCardCID]=\\\"!isVeterinarian\\\"\\n  [colorSetting]=\\\"colorSetting\\\"\\n  (onClickAddViewFormAttestation)=\\\"handlerModelFormAttestation(true)\\\"\\n  (onClickAddTextBox)=\\\"handlerShowCardTextBox(true)\\\"\\n  (onClickShowCardCID)=\\\"handlerShowCardCid()\\\"\\n  (onClickonShowModelListFavoriteDocument)=\\\"onShowModelListFavoriteDocument.emit()\\\"\\n  typeDocument=\\\"attestation\\\"\\n></app-add-type-options>\\n\";","export default \".attestation {\\n  color: black;\\n}\\n.attestation .font {\\n  font-size: 24px !important;\\n}\\n.attestation .underlined {\\n  text-decoration: underline;\\n}\\n.attestation .info-ipt {\\n  text-align: center;\\n  width: 135px;\\n  border: 0;\\n  border-bottom: solid 2px;\\n  outline: none;\\n}\\n.attestation .info-ipt::-webkit-input-placeholder {\\n  color: #bdc2c7;\\n}\\n.attestation .ant-select {\\n  width: 165px;\\n}\\n.attestation textarea {\\n  line-height: 2;\\n}\\np span {\\n  margin: 10px 0;\\n}\";","import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { Exam } from '@app/shared/models/exam';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport _ from 'lodash';\n\n@Component({\n  selector: 'app-exam-v2',\n  templateUrl: './exam-v2.component.html',\n  styleUrls: ['./exam-v2.component.scss']\n})\nexport class ExamV2Component implements OnInit {\n  @Input() form: FormGroup;\n  @Input() exam: Exam;\n  @Input() isVeterinarian = false;\n  @Input() colorSetting: ColorSetting;\n\n  @Output() formEmitter: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();\n  @Output() onShowModelListFavoriteDocument = new EventEmitter();\n\n  showCardDataExams = false;\n  showCardCid = false;\n  showCardTextBox = false;\n\n  constructor(private fb: FormBuilder, private notification: AppToastService) {}\n\n  ngOnInit(): void {\n    this.init();\n  }\n\n  @Input()\n  set examModel(examModel: Exam) {\n    if (examModel) {\n      this.exam = examModel;\n      this.init();\n    }\n  }\n\n  init() {\n    this.buildForm();\n    this.exam.examList = this.exam.examList ? this.exam.examList : [];\n    this.verifyShowCards();\n    this.fillForm();\n    this.formEmitter.emit(this.form);\n  }\n\n  buildForm() {\n    this.form = this.fb.group({\n      code: [''],\n      showPatientCpf: [false],\n      showPrescriberCpf: [false],\n      local: [],\n      version: ['BETA'],\n      examList: this.fb.array([], [Validators.required]),\n      justification: this.fb.control([])\n    });\n  }\n\n  verifyShowCards() {\n    if (this.exam) {\n      if (this.exam.examList.length > 0) {\n        this.showCardDataExams = true;\n        this.form.get('examList').setValidators([Validators.required]);\n        this.form.get('examList').updateValueAndValidity();\n      }\n      if (this.exam.cid && this.exam.cid.items.length > 0) {\n        this.showCardCid = true;\n      }\n      if (this.hasJustification()) {\n        this.showCardTextBox = true;\n        this.form.get('examList').clearValidators();\n        this.form.get('examList').updateValueAndValidity();\n      }\n    }\n    this.formEmitter.emit(this.form);\n  }\n\n  hasJustification(): boolean {\n    return (\n      this.exam.justification &&\n      this.exam.justification.length > 0 &&\n      this.exam.justification.some(text => !_.isEmpty(text))\n    );\n  }\n\n  fillForm() {\n    if (this.exam) {\n      this.form.patchValue(this.exam);\n      this.exam.examList.forEach(examList => {\n        const groupExam = this.fb.group({\n          showTuss: [examList.showTuss],\n          exams: this.fb.array(examList.exams, Validators.required)\n        });\n        (<FormArray>this.form.get('examList')).push(groupExam);\n      });\n    }\n  }\n\n  handlerShowCardDataExams(value: boolean) {\n    if (!value) {\n      (<FormArray>this.form.get('examList')).reset();\n      this.showCardDataExams = false;\n      return;\n    }\n\n    const exists = (<FormArray>this.form.get('examList')).length === 1;\n    if (exists) {\n      this.notification.notify('warning', 'Componente já adicionado', '');\n      return;\n    }\n\n    this.showCardDataExams = value;\n    const groupExam = this.fb.group({\n      showTuss: [false],\n      exams: this.fb.array([], Validators.required)\n    });\n\n    (<FormArray>this.form.get('examList')).push(groupExam);\n    this.formEmitter.emit(this.form);\n  }\n\n  handlerShowCardCid() {\n    this.showCardCid = true;\n  }\n\n  handlerShowCardTextBox(value: boolean) {\n    this.showCardTextBox = value;\n    if (!value) {\n      if (this.exam) {\n        this.exam.justification = [];\n      }\n      this.form.get('justification').setValue(null);\n      this.form.get('text').setValue(null);\n      this.form.get('examList').setValidators([Validators.required]);\n      this.form.get('examList').updateValueAndValidity();\n    } else {\n      this.form.get('examList').setValidators(null);\n      this.form.get('examList').clearValidators();\n      this.form.get('examList').updateValueAndValidity();\n    }\n    this.formEmitter.emit(this.form);\n  }\n}\n","export default \"<app-data-exam-form\\n  *ngIf=\\\"showCardDataExams\\\"\\n  [form]=\\\"form\\\"\\n  [isVeterinarian]=\\\"isVeterinarian\\\"\\n  [colorSetting]=\\\"colorSetting\\\"\\n  (onClickRemoveCardDataExam)=\\\"handlerShowCardDataExams(false)\\\"\\n></app-data-exam-form>\\n\\n<app-text-box-form\\n  *ngIf=\\\"showCardTextBox\\\"\\n  [form]=\\\"form\\\"\\n  [text]=\\\"exam?.justification.join('\\\\n')\\\"\\n  (onChangeText)=\\\"form.get('justification').setValue($event)\\\"\\n  (onClickRemove)=\\\"handlerShowCardTextBox(false)\\\"\\n></app-text-box-form>\\n\\n<app-cid-form\\n  *ngIf=\\\"showCardCid\\\"\\n  [form]=\\\"form\\\"\\n  [authorizedByPatient]=\\\"exam?.cid?.authorizedByPatient\\\"\\n  [showDescription]=\\\"exam?.cid?.showDescription\\\"\\n  [items]=\\\"exam?.cid?.items\\\"\\n  [colorSetting]=\\\"colorSetting\\\"\\n  (onClickRemoveCardCid)=\\\"showCardCid = false\\\"\\n></app-cid-form>\\n\\n<app-add-type-options\\n  [viewDataExams]=\\\"true\\\"\\n  [viewTextBox]=\\\"true\\\"\\n  [viewShowCardCID]=\\\"!isVeterinarian\\\"\\n  [colorSetting]=\\\"colorSetting\\\"\\n  [viewListFavoriteDocument]=\\\"true\\\"\\n  (onClickShowCardCID)=\\\"handlerShowCardCid()\\\"\\n  (onClickAddDataExams)=\\\"handlerShowCardDataExams(true)\\\"\\n  (onClickAddTextBox)=\\\"handlerShowCardTextBox(true)\\\"\\n  (onClickonShowModelListFavoriteDocument)=\\\"onShowModelListFavoriteDocument.emit()\\\"\\n></app-add-type-options>\\n\";","export default \"\";","import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { Infusion } from '@app/shared/models/infusion';\nimport { Protocol } from '@app/shared/models/protocol';\n\n@Component({\n  selector: 'app-infusion-protocol',\n  templateUrl: './infusion-protocol.component.html',\n  styleUrls: ['./infusion-protocol.component.scss']\n})\nexport class InfusionProtocolComponent implements OnInit, OnChanges {\n  @Input() colorSetting: ColorSetting;\n  @Input() protocolSelected: any;\n  @Output() formEmitter: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();\n  @Output() showModalListVictaProtocols: EventEmitter<void> = new EventEmitter<void>();\n\n  form: FormGroup;\n\n  constructor(private readonly fb: FormBuilder) {\n    this.form = this.fb.group({\n      protocols: this.fb.array([], Validators.required)\n    });\n  }\n\n  ngOnInit() {\n    this.formEmitter.emit(this.form);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['protocolSelected']) {\n      const protocolSelected = changes['protocolSelected'].currentValue;\n      if (protocolSelected) {\n        this.addProtocol(protocolSelected);\n      }\n    }\n  }\n\n  @Input()\n  set infusion(infusion: Infusion) {\n    if (infusion) {\n      infusion.protocols.forEach(protocol => this.addProtocol(protocol));\n    }\n  }\n\n  get protocols() {\n    return this.form.controls['protocols'] as FormArray;\n  }\n\n  addProtocol(protocol: Protocol) {\n    const phasesGroups = protocol.phases.map((phase: any) =>\n      this.fb.group({\n        name: [phase.name],\n        dosage: [phase.dosage, Validators.required],\n        observation: [phase.observation]\n      })\n    );\n\n    const protocolGroup = this.fb.group({\n      name: [protocol.name],\n      phases: this.fb.array([...phasesGroups])\n    });\n\n    this.protocols.push(protocolGroup);\n  }\n\n  deleteProtocol(protocolIndex: number) {\n    this.protocols.removeAt(protocolIndex);\n  }\n}\n","export default \"<form [formGroup]=\\\"form\\\">\\n  <ng-container formArrayName=\\\"protocols\\\">\\n    <div\\n      *ngFor=\\\"let protocolFormGroup of protocols.controls; let i = index\\\"\\n      [formGroup]=\\\"protocolFormGroup\\\"\\n      class=\\\"container-protocol\\\"\\n    >\\n      <div class=\\\"protocol-inputs\\\">\\n        <div *ngIf=\\\"protocolFormGroup.value as protocol\\\">\\n          <h4 class=\\\"title\\\">{{ i + 1 }}. {{ protocol.name }}</h4>\\n          <div\\n            *ngFor=\\\"let phaseFormGroup of protocolFormGroup.get('phases')['controls']; let j = index\\\"\\n            [formGroup]=\\\"phaseFormGroup\\\"\\n          >\\n            <div *ngIf=\\\"phaseFormGroup.value as phase\\\">\\n              <div *ngIf=\\\"j\\\" class=\\\"mt-4\\\"></div>\\n              <h6 *ngIf=\\\"phase.name\\\" class=\\\"title\\\">{{ phase.name }}</h6>\\n              <nz-form-item>\\n                <nz-form-control>\\n                  <textarea\\n                    [ngStyle]=\\\"{ color: colorSetting?.primary }\\\"\\n                    [id]=\\\"'dosage_' + j\\\"\\n                    appAutoSize\\n                    appFocus\\n                    nz-input\\n                    [value]=\\\"phase.dosage\\\"\\n                    disabled\\n                    class=\\\"dosage\\\"\\n                  ></textarea>\\n                </nz-form-control>\\n              </nz-form-item>\\n              <nz-form-item>\\n                <label [ngStyle]=\\\"{ color: colorSetting?.primary, 'font-weight': 'bold' }\\\"\\n                  >Observação</label\\n                >\\n                <nz-form-control>\\n                  <textarea\\n                    [ngStyle]=\\\"{ color: colorSetting?.primary, 'border-color': colorSetting?.primary }\\\"\\n                    appFocus\\n                    appAutoSize\\n                    focus=\\\"true\\\"\\n                    placeholder=\\\"Digite uma observação\\\"\\n                    formControlName=\\\"observation\\\"\\n                    nz-input\\n                    class=\\\"medicationNameInput\\\"\\n                  ></textarea>\\n                </nz-form-control>\\n              </nz-form-item>\\n            </div>\\n          </div>\\n        </div>\\n      </div>\\n      <div class=\\\"protocol-btn-remove\\\">\\n        <span class=\\\"btn-inner--icon p-5\\\" style=\\\"cursor: pointer;\\\" (click)=\\\"deleteProtocol(i)\\\"\\n          ><i class=\\\"fa fa-trash-solid\\\"></i\\n        ></span>\\n      </div>\\n    </div>\\n  </ng-container>\\n</form>\\n\\n<app-add-type-options\\n  [viewInfusion]=\\\"true\\\"\\n  [viewDataExams]=\\\"false\\\"\\n  [viewFormAttestation]=\\\"false\\\"\\n  [viewShowCardCID]=\\\"false\\\"\\n  [viewPrecriptionRenew]=\\\"false\\\"\\n  [viewIndutrialized]=\\\"false\\\"\\n  [viewListFavoriteDocument]=\\\"false\\\"\\n  [viewTextBox]=\\\"false\\\"\\n  [colorSetting]=\\\"colorSetting\\\"\\n  (onClickAddInfusion)=\\\"showModalListVictaProtocols.emit()\\\"\\n></app-add-type-options>\\n\";","export default \".container-protocol {\\n  display: flex;\\n  align-items: center;\\n  padding: 20px;\\n  color: #4d4d4d;\\n  position: relative;\\n}\\n@media (max-width: 1025px) {\\n  .container-protocol {\\n    padding: 0;\\n  }\\n}\\n.container-protocol:hover {\\n  background-color: #f5f5f5;\\n}\\n.medicationNameInput {\\n  background-color: transparent;\\n  height: 100%;\\n  box-shadow: none;\\n}\\n.container-protocol .protocol-inputs {\\n  flex: 1;\\n}\\n.border-transparent {\\n  border-color: transparent;\\n}\\n.protocol-btn-remove {\\n  max-width: 6.25rem;\\n  width: 100%;\\n}\";","import { Component, Input, OnInit } from '@angular/core';\n\n@Component({\n  selector: 'app-model-list-favorite-document-cid-view',\n  templateUrl: './model-list-favorite-document-cid-view.component.html',\n  styleUrls: ['./model-list-favorite-document-cid-view.component.scss']\n})\nexport class ModelListFavoriteDocumentCidViewComponent implements OnInit {\n  @Input() item: any;\n\n  constructor() {}\n\n  ngOnInit(): void {}\n}\n","export default \"<div *ngIf=\\\"item?.cid && item?.cid?.items?.length > 0\\\">\\n  <nz-divider></nz-divider>\\n  <div class=\\\"mt-3\\\">\\n    <div *ngFor=\\\"let cid of item?.cid?.items\\\">\\n      <label class=\\\"label-name-cid mr-3\\\">\\n        CID 10: {{ cid?.code }}\\n        <span *ngIf=\\\"item?.cid?.showDescription\\\"> - {{ cid?.description }}</span>\\n        <span *ngIf=\\\"item?.cid?.authorizedByPatient\\\"> (Autorizado pelo paciente)</span>\\n      </label>\\n    </div>\\n  </div>\\n</div>\\n\";","export default \"\";","import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { AuthService } from '@app/core/services/auth.service';\nimport { Orientation, Patient } from '@app/shared/models';\nimport { CidItem } from '@app/shared/models/CidItem';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { User } from '@app/shared/models/decodedLoginToken';\n\n@Component({\n  selector: 'app-orientation',\n  templateUrl: './orientation.component.html',\n  styleUrls: ['./orientation.component.scss']\n})\nexport class OrientationComponent implements OnInit {\n  @Input() patient: Patient;\n  @Input() orientation: Orientation;\n  // @Input() editMode = false;\n  @Input() colorSetting: ColorSetting;\n  @Input() isVeterinarian = false;\n  @Input() showButtonSerene = false;\n  @Output() formEmitter = new EventEmitter<FormGroup>();\n  @Output() onShowModelListFavoriteDocument = new EventEmitter();\n\n  orientations: string;\n  showCardCid = false;\n  orientationForm: FormGroup;\n\n  rows = 4;\n\n  constructor(private fb: FormBuilder) {\n    this.orientationForm = this.fb.group({\n      title: ['', Validators.required],\n      text: ['', Validators.required],\n      orientations: [''],\n      showPatientCpf: [false],\n      showPrescriberCpf: [false],\n      version: ['BETA']\n    });\n  }\n\n  ngOnInit() {\n    if (this.orientation) {\n      const title = this.orientation.title;\n\n      if (title === 'ORIENTAÇÕES PARA IMPORTAÇÃO DOS PRODUTOS SERENE') {\n        this.rows = 14;\n      }\n\n      this.orientationForm.get('title').setValue(title);\n      const value = this.orientation.orientations.reduce(\n        (accumulator, currentValue) => accumulator + '\\n' + currentValue\n      );\n      this.orientationForm.get('text').setValue(value);\n      this.orientationForm.get('orientations').setValue(this.orientation.orientations);\n\n      if (this.hasCid(this.orientation.cid)) {\n        this.showCardCid = true;\n      }\n    }\n\n    this.orientationForm.get('text').valueChanges.subscribe((text: string) => {\n      if (text && text.trim().length > 0) {\n        const value = text.split('\\n');\n        this.orientationForm.get('orientations').setValue(value);\n      } else {\n        if (this.orientationForm.get('text').value) {\n          this.orientationForm.get('text').setValue(null);\n        }\n      }\n    });\n    this.formEmitter.emit(this.orientationForm);\n  }\n\n  @Input()\n  set orientationModel(orientationModel: any) {\n    if (orientationModel) {\n      const value = orientationModel.orientations.reduce((acc, val) => acc + '\\n' + val);\n      this.orientationForm.get('text').setValue(value);\n      this.orientationForm.get('title').setValue(orientationModel.title);\n      this.orientationForm.get('orientations').setValue(orientationModel.orientations);\n      if (this.hasCid(orientationModel.cid)) {\n        this.orientation = orientationModel;\n        this.showCardCid = true;\n      }\n    }\n  }\n\n  get showCpfText() {\n    return this.patient && !this.patient.cpf ? 'Mostrar CPF do Responsável' : 'Mostrar CPF do Paciente';\n  }\n\n  handlerShowCardCid() {\n    this.showCardCid = true;\n  }\n\n  hasCid(cid: CidItem) {\n    return cid && cid.items && cid.items.length > 0;\n  }\n\n  applyModelOrientationSerene() {\n    this.rows = 14;\n    const orientations = [\n      '1 - PRESCRIÇÃO MÉDICA:',\n      'O paciente ou responsável legal deve possuir uma prescrição médica válida por até seis meses, contendo a quantidade necessária para esse período.',\n      '2 - CADASTRO NO SITE DO GOVERNO:',\n      '- Acesse www.gov.com.br e realize o cadastro',\n      '- Preencha o “Formulário para Importação e Uso de Produto derivado de Cannabis” com todas as informações do paciente, responsável legal, médico e produtos. Salve a autorização da Anvisa',\n      '3 - PROCURAÇÃO PARA IMPORTAÇÃO:',\n      'Se desejar, o paciente pode emitir uma procuração para que a empresa cuide de todo o trâmite de importação.',\n      '4 - ENVIO DE DOCUMENTOS:',\n      'Todos os documentos enviados pelos pacientes, com ou sem foto, devem ser enviados com frente e verso.',\n      '5 - ENTREGA DO PRODUTO:',\n      ' Após a realização e pagamento do pedido, o prazo estimado para a chegada do produto na residência do paciente é de aproximadamente 3 semanas. Esse período é necessário principalmente devido ao tempo que a Anvisa leva para verificar todos os produtos e checar novamente todos os documentos.',\n      ' ',\n      'Os critérios para a importação estão descritos na RDC nº 570/2021. O processo simplificado é válido apenas para pessoas físicas, para uso próprio, mediante prescrição médica para tratamento de saúde. O serviço é gratuito.'\n    ];\n    const value = orientations.reduce((acc, val) => acc + '\\n' + val);\n    this.orientationForm.get('text').setValue(value);\n    this.orientationForm.get('title').setValue('ORIENTAÇÕES PARA IMPORTAÇÃO DOS PRODUTOS SERENE');\n    this.orientationForm.get('orientations').setValue(orientations);\n\n    this.formEmitter.emit(this.orientationForm);\n  }\n}\n","export default \"<div class=\\\"orientation card p-2 mb-2\\\" [formGroup]=\\\"orientationForm\\\">\\n  <label for=\\\"material\\\">Título</label>\\n  <input\\n    id=\\\"title\\\"\\n    class=\\\"input-name\\\"\\n    formControlName=\\\"title\\\"\\n    nz-input\\n    placeholder=\\\"Digite o título do documento\\\"\\n    [ngStyle]=\\\"{\\n      'background-color': colorSetting?.inputBackground,\\n      'border-color': colorSetting?.inputBorder\\n    }\\\"\\n  />\\n  <label for=\\\"material\\\">Escreva o conteúdo do documento:</label>\\n  <textarea\\n    [rows]=\\\"rows\\\"\\n    nz-input\\n    formControlName=\\\"text\\\"\\n    [ngStyle]=\\\"{\\n      'background-color': colorSetting?.inputBackground,\\n      'border-color': colorSetting?.inputBorder\\n    }\\\"\\n  ></textarea>\\n</div>\\n\\n<app-cid-form\\n  *ngIf=\\\"showCardCid\\\"\\n  [form]=\\\"orientationForm\\\"\\n  [authorizedByPatient]=\\\"orientation?.cid?.authorizedByPatient\\\"\\n  [showDescription]=\\\"orientation?.cid?.showDescription\\\"\\n  [items]=\\\"orientation?.cid?.items\\\"\\n  [colorSetting]=\\\"colorSetting\\\"\\n  (onClickRemoveCardCid)=\\\"showCardCid = false\\\"\\n></app-cid-form>\\n\\n<app-add-type-options\\n  [viewListFavoriteDocument]=\\\"true\\\"\\n  [viewShowCardCID]=\\\"!isVeterinarian\\\"\\n  [viewOrientationSerene]=\\\"showButtonSerene\\\"\\n  (onClickonShowModelListFavoriteDocument)=\\\"onShowModelListFavoriteDocument.emit()\\\"\\n  (onClickShowCardCID)=\\\"handlerShowCardCid()\\\"\\n  (onClickOrientationSerene)=\\\"applyModelOrientationSerene()\\\"\\n></app-add-type-options>\\n\";","export default \"textarea {\\n  padding: 20px;\\n}\";","export default \"<form [formGroup]=\\\"form\\\">\\n  <ng-container formArrayName=\\\"products\\\">\\n    <div class=\\\"card mb-2\\\" style=\\\"color: black;\\\" *ngIf=\\\"products?.length > 0\\\">\\n      <div\\n        class=\\\"d-flex flex-column w-100\\\"\\n        *ngFor=\\\"let productFormGroup of products.controls; let i = index\\\"\\n        [formGroup]=\\\"productFormGroup\\\"\\n      >\\n        <div class=\\\"p-3\\\" *ngIf=\\\"productFormGroup?.value as productItem\\\">\\n          <div class=\\\"d-flex align-items-center justify-content-between\\\">\\n            <p style=\\\"font-size: 20px;\\\">{{ productItem.product.name }}</p>\\n            <span\\n              class=\\\"btn-exluir\\\"\\n              nzTooltipTitle=\\\"Excluir\\\"\\n              nzTooltipPlacement=\\\"top\\\"\\n              nz-tooltip\\n              (click)=\\\"deleteProduct(i)\\\"\\n              ><i class=\\\"fa fa-trash-solid\\\"></i\\n            ></span>\\n          </div>\\n          <div *ngFor=\\\"let item of productItem.product.items\\\">\\n            <p>{{ item.name }}</p>\\n            <ul *ngIf=\\\"item.descriptions.length > 0\\\">\\n              <li *ngFor=\\\"let obj of item.descriptions\\\">\\n                <div class=\\\"d-flex\\\">\\n                  <span style=\\\"text-align: justify; font-family: monospace;\\\">\\n                    {{ obj?.fullDescription }}\\n                  </span>\\n                </div>\\n              </li>\\n            </ul>\\n          </div>\\n          <p style=\\\"font-weight: 700; text-align: justify;\\\">{{ productItem.product.observation }}</p>\\n          <div class=\\\"card-medicament-footer\\\">\\n            <label>Quantidade</label>\\n            <div class=\\\"number\\\">\\n              <span class=\\\"minus\\\" (click)=\\\"minusQuantity(i)\\\">\\n                <i class=\\\"fa-solid fa-minus\\\"></i>\\n              </span>\\n              <input formControlName=\\\"prescribedQuantity\\\" type=\\\"number\\\" />\\n              <span class=\\\"plus\\\" (click)=\\\"plusQuantity(i)\\\">\\n                <i class=\\\"fa-solid fa-plus\\\"></i>\\n              </span>\\n            </div>\\n          </div>\\n        </div>\\n      </div>\\n    </div>\\n  </ng-container>\\n  <app-text-box-form\\n    *ngIf=\\\"showCardTextBox\\\"\\n    [form]=\\\"form\\\"\\n    [text]=\\\"prescription?.observation?.join('\\\\n')\\\"\\n    (formEmitter)=\\\"form = $event\\\"\\n    (onChangeText)=\\\"form.get('observation').setValue($event)\\\"\\n    (onClickRemove)=\\\"handlerShowCardTextBox(false)\\\"\\n  ></app-text-box-form>\\n</form>\\n\\n<app-add-type-options\\n  [viewPrecriptionRenew]=\\\"true\\\"\\n  [viewDataExams]=\\\"false\\\"\\n  [viewFormAttestation]=\\\"false\\\"\\n  [viewShowCardCID]=\\\"false\\\"\\n  [viewPrecriptionRenew]=\\\"false\\\"\\n  [viewIndutrialized]=\\\"false\\\"\\n  [viewListFavoriteDocument]=\\\"false\\\"\\n  (onClickAddPrecriptionRenew)=\\\"showModalAddProductRennova()\\\"\\n  (onClickAddTextBox)=\\\"handlerShowCardTextBox(true)\\\"\\n></app-add-type-options>\\n\";","import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ProductRennova } from '@app/shared/models/product-rennova';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { ModalAddProductRennovaComponent } from './../../../../shared/modals/modal-add-product-rennova/modal-add-product-rennova.component';\n\nexport interface ItemFormProduct {\n  prescribedQuantity?: number;\n  product: ProductRennova;\n}\n\n@Component({\n  selector: 'app-prescription-rennova',\n  templateUrl: './prescription-rennova.component.html',\n  styleUrls: ['./prescription-rennova.component.scss']\n})\nexport class PrescriptionRennovaComponent implements OnInit, OnChanges {\n  @Input() prescription: any;\n  @Output() formEmitter: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();\n\n  showCardTextBox = false;\n\n  form = this.fb.group({\n    code: [''],\n    showPatientCpf: [false],\n    showPrescriberCpf: [false],\n    local: [''],\n    version: ['BETA'],\n    products: this.fb.array([], Validators.required),\n    observation: []\n  });\n  constructor(\n    private modalService: BsModalService,\n    private fb: FormBuilder,\n    private notification: AppToastService\n  ) {}\n\n  ngOnInit(): void {\n    this.formEmitter.emit(this.form);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const prescription = changes['prescription'] && changes['prescription'].currentValue;\n    if (prescription) {\n      this.form.patchValue(prescription);\n      if (prescription.observation) {\n        this.showCardTextBox = true;\n      }\n      prescription.productsRennova.forEach((item: ItemFormProduct) => {\n        this.addProductForm({\n          prescribedQuantity: item.prescribedQuantity,\n          product: item.product\n        });\n      });\n    }\n  }\n\n  showModalAddProductRennova() {\n    const initialState = {};\n    const modal = this.modalService.show(ModalAddProductRennovaComponent, {\n      initialState,\n      backdrop: 'static',\n      keyboard: false\n    });\n\n    modal.content.selectEvent.subscribe((product: ProductRennova) => {\n      if (this.existsProduct(product.name)) {\n        this.notification.notify('warning', 'Produto já incluído na prescrição', ''); // TODO verificar com thais qual msg deve aparecer\n      } else {\n        this.addProductForm({\n          product\n        });\n      }\n    });\n  }\n\n  addProductForm(item: ItemFormProduct) {\n    const formProduct = this.buildFormProductItem();\n    console.log(item);\n    formProduct.patchValue({\n      prescribedQuantity: item.prescribedQuantity ? item.prescribedQuantity : 1,\n      product: item.product\n    });\n    this.products.push(formProduct);\n  }\n\n  deleteProduct(index: number) {\n    this.products.removeAt(index);\n  }\n\n  buildFormProductItem() {\n    return this.fb.group({\n      prescribedQuantity: [],\n      availableQuantity: [],\n      product: {\n        _id: [''],\n        name: [''],\n        items: [\n          {\n            name: [''],\n            descriptions: [\n              [\n                {\n                  description: [''],\n                  fullDescription: [''],\n                  concentration: [''],\n                  bulk: ['']\n                }\n              ]\n            ]\n          }\n        ],\n        observation: ['']\n      }\n    });\n  }\n\n  existsProduct(name: string) {\n    return this.products.value.some(\n      (item: ItemFormProduct) => item.product.name.toUpperCase() === name.toUpperCase()\n    );\n  }\n\n  get products(): FormArray {\n    return <FormArray>this.form.get('products');\n  }\n\n  handlerShowCardTextBox(value: boolean) {\n    this.showCardTextBox = value;\n    if (value) {\n      this.form.get('observation').setValidators([Validators.required]);\n    } else {\n      this.form.get('observation').setValue(null);\n      this.resetValidationsObservation();\n    }\n    this.formEmitter.emit(this.form);\n  }\n\n  private resetValidationsObservation() {\n    this.form.get('observation').clearValidators();\n    this.form.get('observation').setErrors(null);\n    this.form.get('observation').updateValueAndValidity();\n  }\n\n  minusQuantity(index: number) {\n    const value = this.products.at(index).get('prescribedQuantity').value;\n    if (value > 1) {\n      this.products\n        .at(index)\n        .get('prescribedQuantity')\n        .setValue(value - 1);\n    }\n  }\n  plusQuantity(index: number) {\n    const value = this.products.at(index).get('prescribedQuantity').value;\n    this.products\n      .at(index)\n      .get('prescribedQuantity')\n      .setValue(value + 1);\n  }\n}\n","export default \".card-medicament-footer label {\\n  margin-left: 10px;\\n  margin-bottom: 0;\\n  font-weight: 600;\\n  font-size: 12px;\\n}\\n.card-medicament-footer span {\\n  cursor: pointer;\\n}\\n.card-medicament-footer .minus,\\n.card-medicament-footer .plus {\\n  width: 24px;\\n  height: 24px;\\n  background: #f2f2f2;\\n  padding: 8px 5px 8px 5px;\\n  display: inline-block;\\n  vertical-align: middle;\\n  text-align: center;\\n  position: relative;\\n  background-color: #0b6054;\\n  color: white;\\n}\\n.card-medicament-footer .minus i,\\n.card-medicament-footer .plus i {\\n  position: absolute;\\n  top: 0;\\n  left: 0;\\n}\\n.card-medicament-footer .minus {\\n  border-radius: 4px 0 0 4px;\\n}\\n.card-medicament-footer .plus {\\n  border-radius: 0 4px 4px 0;\\n}\\n.card-medicament-footer input {\\n  height: 24px;\\n  width: 35px;\\n  text-align: center;\\n  font-size: 18px;\\n  border: 1px solid #ddd;\\n  display: inline-block;\\n  vertical-align: middle;\\n  font-weight: 600;\\n}\\n.btn-exluir {\\n  cursor: pointer;\\n  margin-top: -13px;\\n  font-size: 18px;\\n  color: red;\\n}\";","import { Component, Input, OnInit } from '@angular/core';\nimport { Route, Router } from '@angular/router';\nimport { AuthService } from '@app/core/services/auth.service';\nimport { ThemeService } from '@app/theme';\n\n@Component({\n  selector: 'app-navigation',\n  template: `\n    <nav class=\"navbar navbar-expand-lg navbar-light\" theme>\n      <a class=\"navbar-brand\">\n        <img\n          [src]=\"isThemeActiveReceitaDigital() ? 'assets/img/logo-03.png' : 'assets/img/mrd/logo-03.png'\"\n          [alt]=\"isThemeActiveReceitaDigital() ? 'Logo Receita Digital' : 'Logo MRD'\"\n        />\n      </a>\n      <div class=\"brand-bg bg-primary\" *ngIf=\"brandBackGround\">\n        <h4 class=\"title-semi-bold\">{{ title }}</h4>\n      </div>\n      <div class=\"navbar-text\" *ngIf=\"!brandBackGround\">\n        <h4 class=\"title-semi-bold\">{{ title }}</h4>\n      </div>\n      <div class=\"container-fluid\">\n        <button\n          class=\"navbar-toggler\"\n          type=\"button\"\n          data-toggle=\"collapse\"\n          data-target=\"#navbar-default\"\n          aria-controls=\"navbar-default\"\n          aria-expanded=\"false\"\n          aria-label=\"Toggle navigation\"\n        >\n          <span class=\"navbar-toggler-icon\"></span>\n        </button>\n        <div class=\"collapse navbar-collapse\" id=\"navbar-default\">\n          <div class=\"navbar-header\"></div>\n          <div class=\"navbar-collapse-header\">\n            <div class=\"row\">\n              <div class=\"col-6 collapse-brand\">\n                <a href=\"#\">\n                  <img src=\"assets/img/logo-03.png\" />\n                </a>\n              </div>\n              <div class=\"col-6 collapse-close\">\n                <button\n                  type=\"button\"\n                  class=\"navbar-toggler\"\n                  data-toggle=\"collapse\"\n                  data-target=\"#navbar-default\"\n                  aria-controls=\"navbar-default\"\n                  aria-expanded=\"false\"\n                  aria-label=\"Toggle navigation\"\n                >\n                  <span></span>\n                  <span></span>\n                </button>\n              </div>\n            </div>\n          </div>\n\n          <ul class=\"navbar-nav ml-lg-auto align-items-center\">\n            <ng-container *ngIf=\"isLoggedOut\">\n              <li class=\"nav-item\">\n                <a\n                  class=\"btn btn-md register-btn\"\n                  [ngClass]=\"navbarBackGround === 'bg-primary' ? 'btn-info' : 'btn-primary'\"\n                  routerLink=\"/entry/account-type\"\n                >\n                  Cadastre-se\n                </a>\n              </li>\n              <li class=\"nav-item\">\n                <a\n                  routerLink=\"/login\"\n                  class=\"btn btn-icon btn-circle\"\n                  [ngClass]=\"navbarBackGround === 'bg-primary' ? 'btn-info' : 'btn-alt-black'\"\n                >\n                  <span class=\"btn-inner--icon\"><i class=\"fa fa-user-solid\"></i></span>\n                </a>\n              </li>\n            </ng-container>\n\n            <ng-container *ngIf=\"isLoggedIn\">\n              <li class=\"nav-item\">\n                <button (click)=\"toggle()\" *ngIf=\"false\">Mudar Tema</button>\n              </li>\n              <li class=\"nav-item\">\n                <a href=\"#\" class=\"nav-link\" (click)=\"$event.preventDefault()\">\n                  <div class=\"photo\">\n                    <img\n                      *ngIf=\"user as u\"\n                      [alt]=\"u.name\"\n                      class=\"img-fluid\"\n                      src=\"/assets/img/default-avatar.png\"\n                    />\n                  </div>\n                </a>\n              </li>\n              <li class=\"nav-item\" *ngIf=\"!disableNavigation\">\n                <a\n                  routerLink=\"/entry/login\"\n                  (click)=\"logout()\"\n                  class=\"nav-link nav-link-icon logoutIcon\"\n                >\n                  <i class=\"fa fa-exit\" id=\"logout-confirmation\"></i>\n                </a>\n              </li>\n            </ng-container>\n          </ul>\n        </div>\n      </div>\n    </nav>\n  `,\n  styleUrls: ['./navigation.component.scss']\n})\nexport class NavigationComponent implements OnInit {\n  @Input() title: string;\n  @Input() navbarBackGround = 'bg-green';\n  @Input() brandBackGround = false;\n  @Input() disableNavigation = false;\n\n  constructor(\n    private authService: AuthService,\n    private themeService: ThemeService,\n    private _router: Router\n  ) {}\n\n  ngOnInit() {}\n\n  get user() {\n    return this.authService.user();\n  }\n\n  logout() {\n    this.authService.logout();\n    this._router.navigate(['entry/login']);\n  }\n\n  get isLoggedIn() {\n    return this.authService.isLoggedIn;\n  }\n\n  get isLoggedOut() {\n    return this.authService.isLoggedOut;\n  }\n\n  isThemeActiveReceitaDigital() {\n    const active = this.themeService.getActiveTheme();\n    return active.name === 'theme-receita-digital';\n  }\n\n  toggle() {\n    if (this.isThemeActiveReceitaDigital()) {\n      this.themeService.setTheme('theme-mrd');\n    } else {\n      this.themeService.setTheme('theme-receita-digital');\n    }\n  }\n}\n","export default \".navbar {\\n  padding-top: 0;\\n  padding-bottom: 0;\\n  padding-left: 0;\\n  height: 80px;\\n}\\n.navbar .btn {\\n  text-transform: uppercase;\\n  font-family: \\\"problack\\\", sans-serif;\\n  color: white;\\n}\\n.navbar .btn.register-btn {\\n  height: 40px;\\n  display: flex;\\n  align-items: center;\\n}\\n.navbar-brand {\\n  height: 100%;\\n  width: 80px;\\n  flex: 0 0 80px;\\n  justify-content: center;\\n  display: flex;\\n  align-items: center;\\n  background-color: white;\\n  margin: 0 60px 0 0;\\n}\\n.brand-bg {\\n  width: 184px;\\n  height: 66px;\\n  align-self: baseline;\\n  padding: 0 10px;\\n}\\n.brand-bg .title-semi-bold {\\n  color: white;\\n  font-size: 20px;\\n  margin-bottom: 0;\\n}\\n.navbar-text {\\n  width: 30%;\\n  padding-bottom: 0;\\n  padding-top: 0;\\n}\\n.navbar-text .title-semi-bold {\\n  margin-bottom: 0;\\n  color: white;\\n  font-size: 25px;\\n}\\n#logout-confirmation {\\n  color: white;\\n}\\n#logout-confirmation:hover {\\n  color: rgba(248, 248, 248, 0.7);\\n}\";","export default \"<div class=\\\"prescription\\\" [formGroup]=\\\"form\\\">\\n  <ng-container formArrayName=\\\"medicaments\\\">\\n    <ng-container\\n      *ngFor=\\\"let medicamentFormGroup of medicamentsFormCtrl?.controls; let i = index\\\"\\n      [formGroup]=\\\"medicamentFormGroup\\\"\\n    >\\n      <div class=\\\"medication-container\\\" *ngIf=\\\"medicamentFormGroup.value as medicament\\\">\\n        <app-medicament-form\\n          [form]=\\\"medicamentFormGroup\\\"\\n          [signed]=\\\"signed\\\"\\n          [index]=\\\"i\\\"\\n          [colorSetting]=\\\"colorSetting\\\"\\n          (onDelete)=\\\"deleteMedicament($event)\\\"\\n          (onSelect)=\\\"selectMedicament(medicamentFormGroup, $event)\\\"\\n        ></app-medicament-form>\\n      </div>\\n    </ng-container>\\n  </ng-container>\\n\\n  <app-text-box-form\\n    *ngIf=\\\"showCardTextBox\\\"\\n    [form]=\\\"form\\\"\\n    [text]=\\\"prescription?.observation?.join('\\\\n')\\\"\\n    (onChangeText)=\\\"form.get('observation').setValue($event)\\\"\\n    (onClickRemove)=\\\"handlerShowCardTextBox(false)\\\"\\n  ></app-text-box-form>\\n\\n  <app-cid-form\\n    *ngIf=\\\"showCardCid\\\"\\n    (formEmitter)=\\\"form = $event\\\"\\n    (onClickRemoveCardCid)=\\\"showCardCid = !showCardCid\\\"\\n    [authorizedByPatient]=\\\"prescription?.cid?.authorizedByPatient\\\"\\n    [showDescription]=\\\"prescription?.cid?.showDescription\\\"\\n    [items]=\\\"prescription?.cid?.items\\\"\\n    [form]=\\\"form\\\"\\n    [colorSetting]=\\\"colorSetting\\\"\\n  ></app-cid-form>\\n\\n  <app-add-type-options\\n    (onClickAddIndustrialized)=\\\"addMedicament('industrialized')\\\"\\n    (onClickAddMedicamentFreeText)=\\\"addMedicament('free-text')\\\"\\n    (onClickAddTextBox)=\\\"handlerShowCardTextBox(true)\\\"\\n    (onClickonShowModelListFavoriteDocument)=\\\"onShowModelListFavoriteDocument.emit()\\\"\\n    (onClickShowCardCID)=\\\"handlerShowCardCid()\\\"\\n    (onClickAddSereneProtocol)=\\\"handlerShowModalLibrariesProtocol()\\\"\\n    [viewIndutrialized]=\\\"true\\\"\\n    [viewMedicmanetFreeText]=\\\"true\\\"\\n    [viewTextBox]=\\\"true\\\"\\n    [viewListFavoriteDocument]=\\\"true\\\"\\n    [viewShowCardCID]=\\\"!isVeterinarian\\\"\\n    [viewPrecriptionRenew]=\\\"false\\\"\\n    [colorSetting]=\\\"colorSetting\\\"\\n    [viewSereneLibrary]=\\\"showButtonSerene\\\"\\n  ></app-add-type-options>\\n</div>\\n\";","import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { AuthService } from '@app/core/services/auth.service';\nimport { ModalProtocolsLibraryComponent } from '@app/shared/modals/modal-protocols-library/modal-protocols-library.component';\nimport { Patient } from '@app/shared/models';\nimport { ColorSetting } from '@app/shared/models/color-setting';\nimport { User } from '@app/shared/models/decodedLoginToken';\nimport { Protocol } from '@app/shared/models/library';\nimport { AppToastService } from '@app/shared/services/app-toast.service';\nimport { TypeOfMedicament } from '@app/shared/types/types';\nimport _ from 'lodash';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { distinctUntilChanged } from 'rxjs/operators';\n\n@Component({\n  selector: 'app-prescription',\n  templateUrl: './prescription.component.html',\n  styleUrls: ['./prescription.component.scss']\n})\nexport class PrescriptionComponent implements OnInit, OnChanges {\n  @Input() patient: Patient;\n  // @Input() editMode: boolean;\n  @Input() colorSetting: ColorSetting;\n  @Input() isVeterinarian = false;\n  @Input() showButtonSerene = false;\n  @Output() formEmitter: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();\n  @Output() onShowModelListFavoriteDocument = new EventEmitter();\n\n  @Input() prescription: any;\n\n  signed = false;\n  showCardCid = false;\n  showCardTextBox = false;\n\n  form: FormGroup;\n\n  constructor(\n    private fb: FormBuilder,\n    private notification: AppToastService,\n    private modalService: BsModalService\n  ) {\n    this.form = this.fb.group({\n      code: [''],\n      manipulatedprofile: [undefined],\n      showPatientCpf: [false],\n      showPrescriberCpf: [false],\n      medication: [''],\n      medicaments: this.fb.array([], Validators.required),\n      local: [''],\n      version: ['BETA'],\n      observation: this.fb.control([])\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['prescription']) {\n      const prescription = changes['prescription'].currentValue;\n      if (prescription) {\n        this.medicamentsFormCtrl.removeAt(0);\n        this.signed = prescription.status === 'Assinada';\n        this.form.patchValue(prescription);\n        if (this.hasCid() && !this.isVeterinarian) {\n          this.showCardCid = true;\n        }\n\n        if (this.hasObservation()) {\n          this.showCardTextBox = true;\n        }\n\n        prescription.medicaments.forEach(m => {\n          this.addPrescription({\n            ...m,\n            id: m.medicamentId,\n            principio: m.principle,\n            laboratorio: m.laboratory,\n            apresentacaoCustomizada: m.description,\n            quantity: m.prescribedQuantity\n          });\n        });\n      }\n    }\n  }\n\n  ngOnInit() {\n    this.formEmitter.emit(this.form);\n  }\n\n  hasCid(): boolean {\n    return this.prescription.cid && this.prescription.cid.items.length > 0;\n  }\n\n  hasObservation(): boolean {\n    return (\n      this.prescription.observation &&\n      this.prescription.observation.length > 0 &&\n      this.prescription.observation.some(text => !_.isEmpty(text))\n    );\n  }\n\n  @Input()\n  set prescriptionModel(prescriptionModel: any) {\n    if (prescriptionModel) {\n      this.prescription = prescriptionModel;\n      this.showCardCid = this.hasCid();\n      this.showCardTextBox = this.hasObservation();\n      this.removeEmptyMedicaments(this.medicamentsFormCtrl);\n      prescriptionModel.medicaments.forEach(m => {\n        this.addPrescription({\n          ...m,\n          id: m.medicamentId,\n          principio: m.principle,\n          laboratorio: m.laboratory,\n          apresentacaoCustomizada: m.description,\n          quantity: m.prescribedQuantity\n        });\n      });\n    }\n  }\n\n  @Input()\n  set manipulatedProfile(manipulatedProfile: any) {\n    if (manipulatedProfile) {\n      this.form.get('manipulatedprofile').setValue(manipulatedProfile._id);\n      this.medicamentsFormCtrl.removeAt(0);\n      manipulatedProfile.medicaments.forEach(m => {\n        this.addPrescription({\n          ...m,\n          manipuled: true\n        });\n      });\n    }\n  }\n\n  get showCpfText() {\n    return this.patient && !this.patient.cpf ? 'Mostrar CPF do Responsável' : 'Mostrar CPF do Paciente';\n  }\n\n  get medicamentsFormCtrl(): FormArray {\n    return <FormArray>this.form.get('medicaments');\n  }\n\n  addMedicament(type: TypeOfMedicament) {\n    const formGroup = new FormGroup({\n      medicamentId: new FormControl(null),\n      name: new FormControl('', Validators.required),\n      dosage: new FormControl('', Validators.required),\n      ean: new FormControl(''),\n      principle: new FormControl(''),\n      laboratory: new FormControl(''),\n      description: new FormControl(''),\n      prescribedQuantity: new FormControl(1),\n      unitOfMeasurement: new FormControl('PACKING', Validators.required),\n      type: new FormControl(type, Validators.required),\n      search: new FormControl(type === 'industrialized'),\n      editing: new FormControl(false),\n      prescriptionTypeId: new FormControl(),\n      typeCr: new FormControl()\n    });\n    this.listemDosage(formGroup);\n    this.medicamentsFormCtrl.push(formGroup);\n    this.formEmitter.emit(this.form);\n  }\n\n  selectMedicament(medicament: FormGroup, selectedMedicament: any) {\n    medicament.get('name').setValue(selectedMedicament.nome);\n    medicament.get('principle').setValue(selectedMedicament.principio);\n    medicament.get('laboratory').setValue(selectedMedicament.laboratorio);\n    medicament.get('ean').setValue(selectedMedicament.ean);\n    medicament.get('description').setValue(selectedMedicament.apresentacaoCustomizada);\n    medicament.get('prescribedQuantity').setValue(1);\n    medicament.get('medicamentId').setValue(selectedMedicament.id);\n    medicament.get('search').setValue(false);\n    medicament.get('editing').setValue(false);\n    medicament.get('unitOfMeasurement').setValue('PACKING');\n    medicament.get('prescriptionTypeId').setValue(selectedMedicament.prescriptionTypeId);\n    medicament.get('typeCr').setValue(selectedMedicament.typeCr);\n  }\n\n  deleteMedicament(index: number): void {\n    this.medicamentsFormCtrl.removeAt(index);\n  }\n\n  handlerShowCardTextBox(value: boolean) {\n    if (this.showCardTextBox && value) {\n      this.notification.notify('warning', 'Componente já adicionado', '');\n      return;\n    }\n\n    this.showCardTextBox = value;\n  }\n\n  handlerShowCardCid() {\n    this.showCardCid = true;\n  }\n\n  private listemDosage(form: FormGroup) {\n    form\n      .get('dosage')\n      .valueChanges.pipe(distinctUntilChanged())\n      .subscribe((text: string) => {\n        if (!text || text.trim().length === 0) {\n          form.get('dosage').setValue(null);\n        }\n      });\n  }\n\n  private formMedicaments({\n    name,\n    medicamentId,\n    principle,\n    laboratory,\n    ean,\n    quantity,\n    description,\n    dosage,\n    medication,\n    manipuled,\n    disabled = false,\n    type,\n    unitOfMeasurement,\n    prescriptionTypeId,\n    typeCr\n  }): FormGroup {\n    const formGroup = new FormGroup({\n      name: new FormControl(name),\n      medicamentId: new FormControl(medicamentId),\n      prescribedQuantity: new FormControl(quantity),\n      dosage: new FormControl(dosage, Validators.required),\n      description: new FormControl(description),\n      principle: new FormControl(principle),\n      laboratory: new FormControl(laboratory),\n      ean: new FormControl(ean),\n      medication: new FormControl(medication),\n      quantity: new FormControl(quantity),\n      manipuled: new FormControl(manipuled),\n      disabled: new FormControl(disabled),\n      type: new FormControl(type),\n      editing: new FormControl(false),\n      search: new FormControl(false),\n      unitOfMeasurement: new FormControl(unitOfMeasurement),\n      prescriptionTypeId: new FormControl(prescriptionTypeId),\n      typeCr: new FormControl(typeCr)\n    });\n\n    if (disabled) {\n      formGroup.disable();\n    }\n\n    return formGroup;\n  }\n\n  private removeEmptyMedicaments(medicamentsFormCtrl: FormArray): void {\n    for (let i = medicamentsFormCtrl.controls.length - 1; i >= 0; i--) {\n      const medicament = medicamentsFormCtrl.controls[i].value;\n      if (!medicament.name) {\n        medicamentsFormCtrl.removeAt(i);\n      }\n    }\n  }\n\n  private addPrescription({\n    id,\n    principio,\n    laboratorio,\n    apresentacaoCustomizada,\n    dosage = '',\n    quantity = 1,\n    disabled = false,\n    unitOfMeasurement = 'PACKING',\n    ...params\n  }: any): void {\n    this.medicamentsFormCtrl.push(\n      this.formMedicaments({\n        medicamentId: id,\n        principle: principio,\n        laboratory: laboratorio,\n        description: apresentacaoCustomizada,\n        dosage,\n        quantity,\n        disabled,\n        unitOfMeasurement,\n        ...params\n      })\n    );\n  }\n\n  handlerShowModalLibrariesProtocol() {\n    const initialState = {\n      colorSetting: this.colorSetting\n    };\n    const modal = this.modalService.show(ModalProtocolsLibraryComponent, {\n      initialState,\n      backdrop: 'static',\n      keyboard: false\n    });\n\n    modal.content.onAddProtocol.subscribe(({ medicamentCR, dosage, quantity }: Protocol) => {\n      this.addPrescription({\n        ...medicamentCR,\n        name: medicamentCR.nome,\n        dosage: dosage.join('\\n'),\n        quantity\n      });\n\n      modal.hide();\n    });\n  }\n}\n","export default \".prescription ::ng-deep .ant-drawer-left.ant-drawer-open .ant-drawer-content-wrapper {\\n  box-shadow: 0 9px 18px rgba(0, 0, 0, 0.18);\\n}\\n.prescription ::ng-deep .ant-drawer.ant-drawer-open .ant-drawer-mask {\\n  opacity: 0.11;\\n}\\n.prescription ::ng-deep .ant-drawer-body {\\n  padding-top: 0;\\n  height: 90vh;\\n  overflow: auto;\\n}\\n.prescription ::ng-deep .ant-drawer-open {\\n  top: 80px;\\n}\\n.prescription ::ng-deep .menu-drawer {\\n  top: 80px;\\n  background-color: #007260;\\n  border: 1px solid #007260;\\n}\\n.prescription ::ng-deep .menu-drawer .ant-drawer-content {\\n  background-color: transparent;\\n}\\n.prescription ::ng-deep .inner-menu {\\n  display: flex;\\n  flex-direction: column;\\n}\\n.prescription ::ng-deep .inner-menu .menu-icon {\\n  align-self: flex-end;\\n  margin: 20px 0;\\n}\\n.prescription ::ng-deep .inner-menu .menu-icon .fa {\\n  font-size: 20px;\\n  color: white;\\n}\\n.prescription ::ng-deep .inner-menu .menu li {\\n  padding: 20px 0;\\n}\\n.prescription ::ng-deep .inner-menu .menu a {\\n  color: white;\\n  font-family: \\\"problack\\\";\\n  font-size: 18px;\\n  text-transform: uppercase;\\n}\\n.prescription ::ng-deep .inner-menu .menu a:focus {\\n  text-decoration: none;\\n}\\n.prescription ::ng-deep .inner-menu .menu a .fa {\\n  margin-right: 10px;\\n}\\n.prescription ::ng-deep .medicationAutoComplete {\\n  margin-top: 17px;\\n}\\n.prescription .toolbar {\\n  display: flex;\\n}\\n.prescription .toolbar .menu-toggler {\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  padding: 0;\\n  border-radius: 0;\\n  width: 80px;\\n  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));\\n  margin: 0;\\n}\\n.prescription .toolbar .menu-toggler .fa:before {\\n  font-size: 22px;\\n}\\n.prescription .toolbar .menu-toggler,\\n.prescription .toolbar .toolbar-options {\\n  height: 80px;\\n}\\n.prescription .toolbar .toolbar-menu {\\n  flex: 1;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options {\\n  background-color: #f5f5f5;\\n  display: flex;\\n  align-items: center;\\n  justify-content: flex-end;\\n  padding-right: 40px;\\n  padding-left: 60px;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options .btn {\\n  font-family: \\\"problack\\\", sans-serif;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options .btn-green {\\n  background-color: #87ebe1;\\n  border-color: #87ebe1;\\n  color: #1b403a;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-options .btn-default {\\n  background-color: #afafaf;\\n  border-color: #afafaf;\\n  color: white;\\n}\\n.prescription .toolbar .toolbar-menu .toolbar-tags {\\n  background-color: #ebebeb;\\n  height: 40px;\\n  border-radius: 0 0 10px 10px;\\n}\\n.prescription .add-prescription {\\n  padding: 20px 0;\\n  border-top: 1px solid #f5f5f5;\\n  min-height: 81px;\\n  display: flex;\\n  justify-content: center;\\n}\\n.prescription .add-prescription.adding-bg {\\n  background-color: #f5f5f5;\\n  border-top: 1px solid transparent;\\n}\\n.prescription .add-prescription .btn-add-name {\\n  background-color: var(--bg-color-primary);\\n  border: 1px solid var(--bg-color-primary);\\n  color: var(--color-white);\\n  padding: 0px 10px;\\n  margin: 10px;\\n}\\n.prescription .add-prescription .btn-add {\\n  display: flex;\\n  padding: 0 0 0 1.25rem;\\n  height: 40px;\\n  align-items: center;\\n  border-radius: 10px;\\n  overflow: hidden;\\n  border: 0;\\n  font-family: \\\"probold\\\", sans-serif;\\n  background-color: var(--bg-color-secondary);\\n}\\n.prescription .add-prescription .btn-add .btn-inner--icon {\\n  background-color: var(--bg-color-primary);\\n  color: var(--color-white);\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  height: 40px;\\n  width: 50px;\\n}\\n.prescription .btn-add-name {\\n  padding: 0px 10px;\\n  margin: 10px;\\n}\\n.prescription .medicationNameInput,\\n.prescription .posologyNameInput,\\n.prescription .freeTextNameInput {\\n  background-color: transparent;\\n  border-color: transparent;\\n  padding: 0;\\n  color: #585858 !important;\\n}\\n.prescription .medicationNameInput::-moz-placeholder, .prescription .posologyNameInput::-moz-placeholder, .prescription .freeTextNameInput::-moz-placeholder {\\n  color: #f6b4af;\\n}\\n.prescription .medicationNameInput::placeholder, .prescription .medicationNameInput,\\n.prescription .posologyNameInput::placeholder,\\n.prescription .posologyNameInput,\\n.prescription .freeTextNameInput::placeholder,\\n.prescription .freeTextNameInput {\\n  color: #f6b4af;\\n}\\n.prescription .posologyNameInput {\\n  font-size: 15px;\\n  font-weight: 600;\\n}\\n.prescription .freeTextNameInput {\\n  font-size: 15px;\\n  font-weight: 600;\\n}\\n@media (max-width: 1025px) {\\n  .prescription .freeTextNameInput {\\n    font-size: 12px;\\n  }\\n}\\n.prescription .medicationNameInput {\\n  font-size: 20px;\\n  height: 40px;\\n  border-radius: 0;\\n  border-bottom: 2px solid #6e6e6e;\\n}\\n@media (max-width: 1025px) {\\n  .prescription .medicationNameInput {\\n    font-size: 15px;\\n  }\\n}\\n.prescription .medicationNameInput:hover, .prescription .medicationNameInput:focus {\\n  border-bottom: 2px solid #6e6e6e;\\n}\\n.prescription .free-prescription {\\n  display: flex;\\n}\\n.prescription .free-prescription .break-line {\\n  margin-left: 7px;\\n  white-space: pre-wrap;\\n}\\n.prescription textarea {\\n  resize: none;\\n  background-color: transparent;\\n  border: 0;\\n  border-radius: 0;\\n  box-shadow: none;\\n  padding-left: 12px;\\n  color: #4d4d4d;\\n  font-size: 18px;\\n}\\n.prescription textarea:hover, .prescription textarea:focus {\\n  border-color: transparent;\\n  box-shadow: none;\\n}\\n.btn-add-outiline {\\n  display: flex;\\n  padding: 0 0 0 8px;\\n  height: 40px;\\n  align-items: center;\\n  border-radius: 10px;\\n  overflow: hidden;\\n  border: 0;\\n  font-family: \\\"probold\\\", sans-serif;\\n  background-color: var(--bg-color-secondary);\\n  color: var(--color-white);\\n}\\n.btn-add-outiline .btn-inner--icon {\\n  background-color: var(--bg-color-primary);\\n  color: var(--color-white);\\n  display: flex;\\n  align-items: center;\\n  justify-content: center;\\n  height: 40px;\\n  width: 50px;\\n}\\n.header-card-medicament {\\n  display: flex;\\n  justify-content: space-between;\\n  align-items: center;\\n}\\n.header-card-medicament .header-card-title {\\n  flex: 1;\\n  font-size: 14px;\\n  font-weight: 700;\\n  color: var(--bg-color-primary);\\n}\\n.header-card-medicament .header-card-actions {\\n  display: flex;\\n  justify-content: space-between;\\n  align-items: center;\\n  position: relative;\\n}\\n.header-card-medicament .header-card-actions span {\\n  cursor: pointer;\\n}\\n.header-card-medicament .header-card-actions span.cancel-editing {\\n  position: absolute;\\n  top: -4px;\\n  left: -24px;\\n  font-size: 18px;\\n}\\n.header-card-medicament .container-input-search-editing {\\n  width: 97%;\\n}\\n@media (max-width: 1025px) {\\n  .header-card-medicament .container-input-search-editing {\\n    width: 90%;\\n  }\\n}\\n.card-medicament-body .activePrinciples {\\n  font-family: \\\"prolight\\\", sans-serif;\\n  font-size: 13px;\\n  color: #4d4d4d;\\n  margin: 14px 0;\\n}\\n.card-medicament-footer label {\\n  margin-left: 10px;\\n  margin-bottom: 0;\\n  font-weight: 600;\\n  font-size: 12px;\\n}\\n.card-medicament-footer span {\\n  cursor: pointer;\\n}\\n.card-medicament-footer .minus,\\n.card-medicament-footer .plus {\\n  width: 24px;\\n  height: 24px;\\n  background: #f2f2f2;\\n  padding: 8px 5px 8px 5px;\\n  display: inline-block;\\n  vertical-align: middle;\\n  text-align: center;\\n  position: relative;\\n  background-color: #0b6054;\\n  color: white;\\n}\\n.card-medicament-footer .minus i,\\n.card-medicament-footer .plus i {\\n  position: absolute;\\n  top: 0;\\n  left: 0;\\n}\\n.card-medicament-footer .minus {\\n  border-radius: 4px 0 0 4px;\\n}\\n.card-medicament-footer .plus {\\n  border-radius: 0 4px 4px 0;\\n}\\n.card-medicament-footer input {\\n  height: 24px;\\n  width: 35px;\\n  text-align: center;\\n  font-size: 18px;\\n  border: 1px solid #ddd;\\n  display: inline-block;\\n  vertical-align: middle;\\n  font-weight: 600;\\n}\\n.box-add-type-medicament {\\n  display: flex;\\n  justify-content: space-around;\\n  align-items: center;\\n  margin-top: 10px;\\n}\\n@media (min-width: 1025px) {\\n  .box-add-type-medicament {\\n    width: 200px;\\n    justify-content: space-between;\\n  }\\n}\\n.box-add-type-medicament ::ng-deep .ant-btn-circle,\\n.box-add-type-medicament ::ng-deep .ant-btn-circle-outline {\\n  min-width: 50px;\\n}\\n.box-add-type-medicament ::ng-deep .ant-btn-icon-only {\\n  width: 50px;\\n  height: 50px;\\n  background-color: var(--bg-color-secondary);\\n  color: var(--bg-color-primary);\\n  box-shadow: 0px 3px 15px 5px rgba(0, 0, 0, 0.15);\\n}\\n.box-add-type-medicament ::ng-deep .ant-btn .anticon {\\n  font-size: 24px;\\n}\\n.box-add-type-medicament ::ng-deep .ant-btn:hover,\\n.box-add-type-medicament ::ng-deep .ant-btn:focus {\\n  border-color: var(--bg-color-secondary);\\n}\\n.icon-trash {\\n  color: #ff0000;\\n}\\n.card-cid {\\n  padding: 0.5rem;\\n}\\n.card-cid .card-cid-header {\\n  display: flex;\\n  justify-content: space-between;\\n}\\n.card-cid .card-cid-header span {\\n  flex: 1;\\n}\\n.card-cid .card-cid-header i {\\n  font-size: 13px;\\n}\\n.card-cid .card-cid-content .continer-input {\\n  display: flex;\\n  align-items: center;\\n}\\n.card-cid .card-cid-content .continer-input input {\\n  height: 37px;\\n  border-radius: 3px;\\n}\\n.card-cid .card-cid-content .continer-input button {\\n  padding: 5px;\\n}\\n.card-cid .card-cid-content::ng-deep .ant-checkbox-wrapper {\\n  margin-top: 0;\\n  margin-left: 0;\\n}\\n.card-cid .label-checkbox {\\n  font-size: 14px;\\n}\";","import { Component, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { NzModalRef, NzModalService } from 'ng-zorro-antd/modal';\n\n@Component({\n  selector: 'app-unsigned-prescription-modal',\n  templateUrl: './unsigned-prescription-modal.component.html',\n  styleUrls: ['./unsigned-prescription-modal.component.scss']\n})\nexport class UnsignedPrescriptionModalComponent implements OnInit {\n  tplModal: NzModalRef;\n\n  @ViewChild('tplTitle')\n  tplTitle: TemplateRef<{}>;\n\n  @ViewChild('tplContent', { static: true })\n  tplContent: TemplateRef<{}>;\n\n  @ViewChild('tplFooter', { static: true })\n  tplFooter: TemplateRef<{}>;\n\n  title: string;\n  code: string;\n\n  constructor(private modalService: NzModalService) {}\n\n  ngOnInit() {}\n\n  createTplModal(code: string) {\n    this.code = code;\n    switch (code[0]) {\n      case 'P':\n      case 'I':\n        this.title = 'Receita salva com sucesso!';\n        break;\n      case 'A':\n        this.title = 'Atestado salvo com sucesso!';\n        break;\n      case 'E':\n        this.title = 'Exame salvo com sucesso!';\n        break;\n      case 'O':\n        this.title = 'Orientação salva com sucesso!';\n        break;\n      default:\n        this.title = 'Documento salvo com sucesso!';\n    }\n\n    this.tplModal = this.modalService.create({\n      nzContent: this.tplContent,\n      nzFooter: this.tplFooter,\n      nzClosable: false,\n      nzWidth: 650,\n      nzMaskClosable: false,\n      nzOnCancel: () => {},\n      nzWrapClassName: 'modal-unsigned-prescription',\n      nzOnOk: () => console.log('Click ok')\n    });\n  }\n\n  close(): void {\n    this.tplModal.destroy();\n  }\n}\n","export default \"<ng-template #tplContent>\\n  <div class=\\\"container\\\">\\n    <h4 class=\\\"title text-primary\\\">\\n      {{ title }}\\n    </h4>\\n    <p>Código do documento: {{ code }}</p>\\n    <br />\\n  </div>\\n</ng-template>\\n<ng-template #tplFooter>\\n  <div class=\\\"container d-flex align-items-end flex-column modal-footer\\\" theme>\\n    <div class=\\\"row\\\">\\n      <button (click)=\\\"close()\\\" class=\\\"btn btn-ok\\\" theme>\\n        Ok\\n      </button>\\n    </div>\\n  </div>\\n</ng-template>\\n\";","export default \".title {\\n  text-transform: none;\\n  font-size: 50px;\\n  line-height: normal;\\n}\\n\\np {\\n  color: #363636;\\n  font-size: 20px;\\n  font-family: \\\"prolight\\\";\\n}\\n\\n.print-without-sign {\\n  font-size: 12px;\\n  color: #1b403a;\\n  margin-bottom: 0;\\n}\\n\\n.print-without-sign a:not(.btn) {\\n  font-family: \\\"problack\\\";\\n  text-decoration: underline;\\n}\\n\\n.modal-footer {\\n  padding: 10px 32px;\\n  background-color: var(--bg-modal-header);\\n}\\n\\n.modal-footer .btn {\\n  font-size: 12px;\\n}\\n\\n::ng-deep .ant-modal-body {\\n  text-align: center;\\n  padding-bottom: 0;\\n}\\n\\n::ng-deep .ant-modal-content {\\n  border-radius: 10px;\\n  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);\\n}\\n\\n::ng-deep .ant-modal-footer {\\n  border-radius: 0 0 10px 10px;\\n  border-top: 0;\\n  padding: 0 !important;\\n}\";","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { SharedModule } from '@app/shared';\nimport { ComponentsModule } from '@app/shared/components/components.module';\nimport { NzCardModule, NzDropDownModule, NzToolTipModule } from 'ng-zorro-antd';\nimport { NzCarouselModule } from 'ng-zorro-antd/carousel';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\nimport { NzPopoverModule } from 'ng-zorro-antd/popover';\nimport { NzProgressModule } from 'ng-zorro-antd/progress';\nimport { NzSkeletonModule } from 'ng-zorro-antd/skeleton';\nimport { NzSpinModule } from 'ng-zorro-antd/spin';\nimport { NzUploadModule } from 'ng-zorro-antd/upload';\nimport { ModalModule } from 'ngx-bootstrap/modal';\nimport { NgxLoadingModule } from 'ngx-loading';\nimport { NgxMaskModule } from 'ngx-mask';\nimport { PatientsModule } from '../patients/patients.module';\nimport { DocumentV2RoutingModule } from './document-v2-routing.module';\nimport { DocumentComponent } from './document.component';\nimport { DocumentGuard } from './guards/document.guard';\nimport { AttestationComponent } from './pages/attestation/attestation.component';\nimport { ConfirmationComponent } from './pages/confirmation/confirmation.component';\nimport { ExamV2Component } from './pages/exam-v2/exam-v2.component';\nimport { InfusionProtocolComponent } from './pages/infusion-protocol/infusion-protocol.component';\nimport { ListingComponent } from './pages/listing/listing.component';\nimport { ModalIframeComponent } from './pages/modal-iframe/modal-iframe.component';\nimport { ModalSearchComponent } from './pages/modal-search/modal-search.component';\nimport { ModalSelectLayoutComponent } from './pages/modal-select-layout/modal-select-layout.component';\nimport { ModelAddFavoriteDocumentComponent } from './pages/model-add-favorite-document/model-add-favorite-document.component';\nimport { ModelListFavoriteDocumentCidViewComponent } from './pages/model-list-favorite-document/model-list-favorite-document-cid-view/model-list-favorite-document-cid-view.component';\nimport { ModelListFavoriteDocumentComponent } from './pages/model-list-favorite-document/model-list-favorite-document.component';\nimport { OrientationComponent } from './pages/orientation/orientation.component';\nimport { PrescriptionRennovaComponent } from './pages/prescription-rennova/prescription-rennova.component';\nimport { NavigationComponent } from './pages/prescription/navigation.component';\nimport { PrescriptionComponent } from './pages/prescription/prescription.component';\nimport { UnsignedPrescriptionModalComponent } from './pages/prescription/unsigned-prescription-modal.component';\nimport { UploadPdfComponent } from './pages/prescription/upload-pdf.component';\nimport { RetentionConfirmationComponent } from './pages/retention-confirmation/retention-confirmation.component';\n\n@NgModule({\n  declarations: [\n    PrescriptionComponent,\n    InfusionProtocolComponent,\n    NavigationComponent,\n    ConfirmationComponent,\n    UnsignedPrescriptionModalComponent,\n    RetentionConfirmationComponent,\n    ListingComponent,\n    UploadPdfComponent,\n    AttestationComponent,\n    DocumentComponent,\n    ModalIframeComponent,\n    OrientationComponent,\n    ModelAddFavoriteDocumentComponent,\n    ModelListFavoriteDocumentComponent,\n    ModalSelectLayoutComponent,\n    ModalSearchComponent,\n    ExamV2Component,\n    ModelListFavoriteDocumentCidViewComponent,\n    PrescriptionRennovaComponent\n  ],\n  exports: [\n    PrescriptionComponent,\n    InfusionProtocolComponent,\n    NavigationComponent,\n    ConfirmationComponent,\n    UnsignedPrescriptionModalComponent,\n    RetentionConfirmationComponent,\n    ListingComponent,\n    UploadPdfComponent,\n    AttestationComponent,\n    ExamV2Component,\n    DocumentComponent,\n    ModalIframeComponent,\n    OrientationComponent,\n    PrescriptionRennovaComponent,\n    ModelAddFavoriteDocumentComponent,\n    ModelListFavoriteDocumentComponent,\n    ModalSelectLayoutComponent,\n    ModalSearchComponent\n  ],\n  imports: [\n    CommonModule,\n    SharedModule,\n    DocumentV2RoutingModule,\n    PatientsModule,\n    ComponentsModule,\n    NgxLoadingModule.forRoot({}),\n    NgxMaskModule.forRoot(),\n    ModalModule.forRoot()\n  ],\n  providers: [DocumentGuard]\n})\nexport class DocumentV2Module {}\n","import { Component, OnInit } from '@angular/core';\nimport { BsModalRef } from 'ngx-bootstrap/modal';\nimport { Subject } from 'rxjs';\n\n@Component({\n  selector: 'app-modal-iframe',\n  templateUrl: './modal-iframe.component.html',\n  styleUrls: ['./modal-iframe.component.scss']\n})\nexport class ModalIframeComponent implements OnInit {\n  public onLoad: Subject<string>;\n\n  src: string;\n  height: number;\n  width: number;\n\n  constructor(public modalRef: BsModalRef) {\n    this.onLoad = new Subject();\n  }\n\n  ngOnInit() {}\n\n  onload(iframe: any) {\n    try {\n      const url = iframe.contentWindow.location.href;\n      this.onLoad.next(url);\n    } catch (e) {\n      this.onLoad.next();\n    }\n  }\n}\n","export default \"<div [style.width.px]=\\\"width\\\">\\n  <div class=\\\"modal-header\\\">\\n    <button type=\\\"button\\\" class=\\\"close pull-right\\\" aria-label=\\\"Close\\\" (click)=\\\"modalRef.hide()\\\">\\n      <span aria-hidden=\\\"true\\\">&times;</span>\\n    </button>\\n  </div>\\n  <div class=\\\"modal-body\\\">\\n    <iframe\\n      #iframe\\n      title=\\\"Assinatura Digital\\\"\\n      [src]=\\\"src | safe\\\"\\n      [height]=\\\"height\\\"\\n      [width]=\\\"width\\\"\\n      (load)=\\\"onload(iframe)\\\"\\n    ></iframe>\\n  </div>\\n</div>\\n\";","export default \".modal-header {\\n  background-color: #f5f7fa;\\n  padding: 0px;\\n}\\n\\n.modal-body {\\n  padding: 0px;\\n  display: flex;\\n  align-items: center;\\n  flex-direction: column;\\n  justify-content: center;\\n}\\n\\n.modal-content {\\n  align-items: center !important;\\n}\";"]}