{"version":3,"sources":["Lib/variables.js","Lib/utils.js","Lib/axios.js","Pages/Home/Section/renew/Popup.js","theme.js","Components/User/Mate/reserve.js","Components/Common/input.js","Components/Common/button.js","Components/modal.js","Pages/Home/Section/reserve.js","Pages/Home/Section/renew/MainNumber.js","Pages/Home/Section/renew/main.js","Pages/Home/Section/renew/video.js","Pages/Home/Section/renew/guide.js","Pages/Home/Section/renew/banner.js","Pages/Home/home.styled.js","Pages/Home/Section/renew/siteBanner.js","Pages/Home/Section/renew/numberCount.js","Pages/Home/Section/partners.js","Pages/Home/home.js","Lib/Api/app.js","Lib/Api/auth.js","Lib/middleware.js","Reducer/Modules/app.js","Reducer/Modules/auth.js","Pages/Home/home.container.js","Pages/NotFound.js","Pages/Auth/AuthPages/Login/login.styled.js","Components/Common/tab.js","Components/Common/text.js","Components/Common/container.js","Lib/regex.js","Components/Reserve/step.js","Components/Reserve/editStep.js","Components/newModal.js","Pages/Auth/AuthPages/Login/KakaoLogin.js","Pages/Auth/AuthPages/Login/login.js","Pages/Auth/AuthPages/Login/login.container.js","Pages/Auth/AuthPages/MainRegister/main.js","Pages/Auth/AuthPages/MainRegister/main.styled.js","Pages/Auth/AuthPages/MainRegister/main.container.js","Pages/Auth/AuthPages/Register/register.styled.js","Pages/Policy/Terms/terms.styled.js","Pages/Policy/Terms/terms.js","Pages/Policy/Terms/terms.container.js","Pages/Policy/Privacy/privacy.styled.js","Pages/Policy/Privacy/privacy.js","Pages/Policy/Privacy/privacy.container.js","Pages/Policy/Marketing/marketing.styled.js","Pages/Policy/Marketing/marketing.js","Pages/Policy/Marketing/marketing.container.js","Pages/Policy/Essential/Normal/normal.styled.js","Pages/Policy/Essential/Normal/normal.js","Pages/Policy/Essential/Normal/normal.container.js","Pages/Policy/Essential/Sensitive/sensitive.styled.js","Pages/Policy/Essential/Sensitive/sensitive.js","Pages/Policy/Essential/Sensitive/sensitive.container.js","Pages/Policy/Selective/Normal/normal.styled.js","Pages/Policy/Selective/Normal/normal.js","Pages/Policy/Selective/Normal/normal.container.js","Pages/Policy/Selective/Sensitive/sensitive.styled.js","Pages/Policy/Selective/Sensitive/sensitive.js","Pages/Policy/Selective/Sensitive/sensitive.container.js","Pages/Policy/Advertisement/advertisement.styled.js","Pages/Policy/Advertisement/advertisement.js","Pages/Policy/Advertisement/advertisement.container.js","Pages/Auth/AuthPages/Register/register.js","Pages/Auth/AuthPages/Register/register.container.js","Pages/Auth/AuthPages/Logout/index.js","Pages/Auth/AuthPages/Find/find.styled.js","Pages/Auth/AuthPages/Find/find.js","Pages/Auth/AuthPages/Find/find.container.js","Pages/Auth/AuthPages/Mate/mate.styled.js","Components/User/Mate/auth.js","Pages/Auth/AuthPages/Mate/mate.js","Pages/Auth/AuthPages/Mate/mate.container.js","Pages/Auth/AuthPages/Normal/normal.styled.js","Components/User/Normal/auth.js","Components/User/Normal/statistics.js","Components/User/Normal/navi.js","Pages/Auth/AuthPages/Profile/profile.styled.js","Pages/Guide/guide.styled.js","Pages/Auth/AuthPages/Profile/profile.js","Pages/Auth/AuthPages/Card/card.styled.js","Pages/Auth/AuthPages/Card/card.js","Pages/Auth/AuthPages/Card/cardInfoCheck.js","Pages/Auth/AuthPages/Profile/profileInfoCheck.js","Components/Columns/normal.js","Pages/Auth/AuthPages/Normal/normal.js","Pages/Auth/AuthPages/Normal/normal.container.js","Pages/Auth/AuthPages/Pending/pending.styled.js","Pages/Auth/AuthPages/Pending/pending.js","Pages/Auth/AuthPages/Pending/pending.container.js","Pages/Auth/auth.js","Pages/Auth/auth.styled.js","Pages/Auth/auth.container.js","Pages/Company/company.styled.js","Pages/Company/Section/fst.js","Pages/Company/Section/snd.js","Pages/Company/Section/trd.js","Pages/Company/Section/fth.js","Pages/Company/Section/fifth.js","Pages/Company/Section/sth.js","Pages/Company/company.js","Pages/Company/company.container.js","Pages/Faq/faq.styled.js","Pages/Faq/faq.js","Pages/Faq/faq.container.js","Pages/Product/ProductPages/Buy/buy.styled.js","Pages/Product/ProductPages/Buy/buy.js","Pages/Product/ProductPages/Buy/buy.container.js","Pages/Product/product.js","Pages/Product/product.container.js","Pages/Reserve/reserve.styled.js","Pages/Apply/Ready/ready.styled.js","Pages/LongtermCare/longTermCare.js","Pages/Success/success.js","Pages/Manual/Service/servicePDF.js","Pages/Manual/Service/service.js","Pages/Manual/Platform/platformPDF.js","Pages/Manual/Platform/platform.js","Pages/Manual/MateEduVideo/VideoList/Video1.js","Pages/Manual/MateEduVideo/VideoList/Video2.js","Pages/Manual/MateEduVideo/VideoList/Video3.js","Pages/Manual/MateEduVideo/VideoList/Video4.js","Pages/Manual/MateEduVideo/eduVideo.js","Pages/NewsEvent/List/list.styled.js","Pages/Review/List/list.styled.js","Components/Columns/user.js","Pages/NewsEvent/List/list.js","Lib/Api/newsEvent.js","Reducer/Modules/newsEvent.js","Pages/NewsEvent/List/list.container.js","Pages/NewsEvent/Info/info.styled.js","Components/Common/block.js","Pages/NewsEvent/Info/info.js","Pages/NewsEvent/Info/info.container.js","Pages/NewsEvent/index.js","Reducer/Modules/review.js","Lib/Api/review.js","Pages/Review/Add/add.styled.js","Components/Templates/Review/header.js","Pages/Review/Add/add.js","Pages/Review/Add/add.container.js","Pages/Review/List/list.js","Pages/Review/List/list.container.js","Pages/Review/MyList/mylist.styled.js","Pages/Review/MyList/mylist.js","Pages/Review/MyList/mylist.container.js","Pages/Apply/Ready/ready.js","Pages/Apply/Form/form.styled.js","Pages/Apply/Form/form.js","Pages/Apply/MateApplyForm/mateApply.styled.js","Pages/Apply/MateApplyForm/mateApply.js","Pages/Guide/Section/nav.js","Pages/Guide/Section/concept.js","Pages/Guide/Section/detail.js","Pages/Guide/Section/usage.js","Pages/Guide/Section/merit.js","Pages/Guide/Section/withmate.js","Pages/Guide/Section/banner.js","Pages/Guide/guide.js","Pages/Guide/guide.container.js","Pages/Nemt/nemt.styled.js","Pages/Nemt/nemt.js","Pages/Nemt/nemt.container.js","Pages/Reserve/patientListModal.js","Pages/Reserve/mateListModal.js","Pages/Reserve/cardListModal.js","Pages/Reserve/reserve.js","Pages/MetLife/MetLifeLanding/Section/reserve.js","Pages/MetLife/MetLifeLanding/Section/renew/main.js","Pages/MetLife/MetLifeLanding/Section/renew/guide.js","Pages/MetLife/MetLifeLanding/home.styled.js","Pages/MetLife/MetLifeLanding/Section/renew/numberCount.js","Pages/MetLife/MetLifeLanding/Section/partners.js","Pages/MetLife/MetLifeLanding/home.js","Pages/MetLife/MetLifeLanding/home.container.js","Pages/MetLife/MetLifeGuide/guide.styled.js","Pages/MetLife/MetLifeGuide/Section/nav.js","Pages/MetLife/MetLifeGuide/Section/concept.js","Pages/MetLife/MetLifeGuide/Section/detail.js","Pages/MetLife/MetLifeGuide/Section/usage.js","Pages/MetLife/MetLifeGuide/Section/merit.js","Pages/MetLife/MetLifeGuide/Section/withmate.js","Pages/MetLife/MetLifeGuide/Section/banner.js","Pages/MetLife/MetLifeGuide/guide.js","Pages/MetLife/MetLifeGuide/guide.container.js","Pages/MetLife/Review/review.styled.js","Pages/MetLife/Review/review.js","Pages/MetLife/Review/review.container.js","Pages/MetLife/NewsEvent/List/list.styled.js","Pages/MetLife/NewsEvent/List/list.js","Pages/MetLife/NewsEvent/List/list.container.js","Pages/MetLife/NewsEvent/Info/info.styled.js","Pages/MetLife/NewsEvent/Info/info.js","Pages/MetLife/NewsEvent/Info/info.container.js","Pages/MetLife/NewsEvent/index.js","Pages/MetLife/Faq/faq.styled.js","Pages/MetLife/Faq/faq.js","Pages/MetLife/Faq/faq.container.js","Pages/MetLife/MetLifePolicy/Privacy/privacy.styled.js","Pages/MetLife/MetLifePolicy/Privacy/privacy.js","Pages/MetLife/MetLifePolicy/Privacy/privacy.container.js","Pages/MetLife/MetLifePolicy/Terms/terms.styled.js","Pages/MetLife/MetLifePolicy/Terms/terms.js","Pages/MetLife/MetLifePolicy/Terms/terms.container.js","Pages/Big5Department/department.js","Components/Templates/Nav/nav.js","Components/Templates/Nav/nav.styled.js","Components/Templates/Nav/nav.container.js","Components/Templates/MetLifeNav/nav.js","Components/Templates/MetLifeNav/nav.styled.js","Components/Templates/MetLifeNav/nav.container.js","Components/Templates/Footer/footer.js","Components/Templates/Footer/footer.styled.js","Components/Templates/Footer/footer.container.js","App.js","serviceWorker.js","Reducer/index.js","index.js","Pages/Home/Section/renew/img/new-gov-care.png","Pages/Auth/AuthPages/Login/o2.png","Pages/Auth/AuthPages/Login/o.png","Pages/Success/login_bg.png","Pages/Success/checkpoint.png","Styles/index.js","Styles sync //.scss$"],"names":["USER","MATE","LOCAL","KAKAO","ASSIST","UNEMER","ScrollTop","prevProps","this","props","location","window","scrollTo","children","React","PureComponent","withRouter","currencyFormatter","currency","reg","n","test","replace","combineDateAndTime","date","time","minute","length","moment","format","toDate","colorParserByStatus","status","axios","defaults","withCredentials","client","create","headers","post","paramsSerializer","params","qs","stringify","indices","baseURL","interceptors","request","use","config","error","Promise","reject","response","localStorage","clear","reload","Popup","useState","popupData","setPopupData","isOpen","setIsOpen","setLoading","setError","VISITED_BEFORE_DATE","Number","getItem","VISITED_NOW_DATE","Date","getDate","useEffect","get","then","now","validPopups","data","filter","popup","startDate","endDate","isPublic","console","log","catch","handleClose","onRequestClose","style","modalStyles","PopupContainer","PopupImage","src","photo","alt","CloseStyle","Close","onClick","setItem","String","styled","div","img","span","overlay","backgroundColor","content","width","height","margin","padding","borderRadius","top","left","transform","fontSize","sizeHandler","size","ColorPallete","blue50","blue100","green100","dark100","dark80","dark70","dark60","dark50","dark30","dark20","dark10","NoCatchedList","list","detailHandler","onRefresh","FullContainer","Inner","NoCatchTitle","RefreshButton","ListConatiner","Array","isArray","map","item","serviceType","productInfo","usePro","useBasic","service","serviceName","name","key","_id","toString","patient","reserveDate","destination","shortStarting","call","onDetail","ReserveItem","usageTime","ItemContainer","TitleSection","ItemColumn","ItemTitle","ItemContents","color","ContentSection","DetailButton","EmptyList","p","hiddenMobile","DivisionLine","big","x_small","small","BorderDivisionLine","Pallete","WithmateLabelText","WithmateLabel","required","rest","WithmateInput","InputTextButton","WithamteInputWithButton","withValue","inputConfig","buttonName","onButton","BorderFlexWrapper","WithmateTextarea","TextArea","middle","WithmateSelect","FlexWrapper","withHalf","StyledHotFix","WithmateDatePicker","WithmateValue","WithmateValueTip","FullWidthButton","a","border","bg","HalfWidthButton","RadiusFullWidthButton","RadiusHalfWidthButton","ButtonWrapper","half","MateReserveInfoModal","visibleHandler","info","onCatch","Container","ModalBlock","ModalTitle","ModalCloseButtons","ModalLabel","ModalInfo","transport","proPrice","basicPrice","WhiteButton","ModalFlexbox","paddingLeft","sex","marginBottom","comment","MateCallStatusModal","onNext","starting","contact","type","getNextStatus","BlueButton","ShareCarRequestModal","inputHandler","onSave","ModalLargeBlock","FlexBox","className","placeholder","value","corp","onChange","ev","target","address","manager","FlexFullBox","message","EmergencyCorpSearchModal","keyword","TableWrapper","TableHeaderWrapper","FlexColumn","addr1","includes","addr2","index","TableRowWrapper","EmptyTable","CardModal","state","modal","componentDidMount","modalValidation","lastTime","JSON","parse","subtract","setState","onClose","onCloseToday","id","Top","Title","Bottom","display","justifyContent","paddingTop","marginTop","MessageRow","history","push","EndBottom","CloseToday","CloseNow","ManagerModal","pathname","EventModal","NoticeModal","onCloseToday2","ContentRow","textAlign","MetlifeModal","MetlifePopup","BottomImage","WarningRow","WarningContentRow","Reserve","reserveModal","reserveInfo","refreshing","fetchList","debounce","mateId","resolve","onCatchCall","auth","warning","put","callId","result","success","SpinWrapper","MainNumber","SwiperCore","Navigation","Pagination","Autoplay","UserMain","UserMainContainer","UserMainInnerContainer","TitleSticker","WithmateSpecRow","GooglePlayButton","open","marginRight","BottomSection","ReserveButton","CallButton","swal","fire","title","text","icon","confirmButtonText","cancelButtonText","showCancelButton","isConfirmed","document","href","HighLight","ButtonCommon","GPButtonCommon","br","UserVideoSection","VideoSectionContainer","VideoSectionInnerContainer","VideoArea","controls","loop","autoplay","muted","playsinline","h4","UserGuideSection","UserGuideContainer","UserGuideInnerContainer","UserGuideTitle","UserGuideStepWrapper","TextStep","ImgStep","MainStepRow","webArrow","mArrow","source","description","num","MainStep","MainStepWrapper","MainStepImageSection","MainStepTextSection","StepIndex","StepTitle","StepDescription","split","word","KeepBr","UserMainBanner","goPage","BannerContainer","Description","LinkButton","HomeStyledContainer","UserMainTitleDeco","PartnerContainer","PartnerInnerContainer","PartnerTitle","PartnerListRow","PartnerItem","IntroduceSection","MobileBr","Withmate","UserNumberCount","RollingContainer","NumberLabel","faHospitalUser","paddingRight","end","suffix","fontWeight","faUsers","faRectangleList","SatisfactionContainer","SatisfactionLabel","ReviewContainer","direction","spaceBetween","slidesPerView","breakpoints","768","pagination","clickable","navigation","modules","allowTouchMove","threshold","delay","speed","ReviewMainContainer","ReviewMainInnerContainer","ImgStyle","alignItems","e","label","WithmatePartners","baseUrl","fstRow","sndRow","trdRow","fthRow","ftfRow","paddingBottom","HomePage","searchModal","emergencyList","emergencyKeyword","requestModal","requestInfo","onShareRequest","userType","prevState","modifyUserInfo","imageUpload","file","formData","FormData","append","register","termsOfUse","privacyPolicy","essentialGeneral","essentialSensitive","selectiveGeneral","selectiveSensitive","selectiveAdvertise","password","code","identify","reason","marketing","connection","recommenderName","longtermCare","birth","email","urlSource","search","addPatient","relate","age","environment","caution","addCard","userName","cardName","cardNum","year","month","getCardInfo","cardId","fetchCard","deleteCard","modifyCard","getMateInfo","fetchMate","getPatientInfo","patientId","fetchPatient","deletePatient","modifyPatient","checkAuth","onAddLongTermCare","userId","createReduxThunk","SUCCESS","FAILURE","dispatch","refreshToken","decoded","jwt","decode","authAPI","accessToken","payload","meta","getUserInfo","appAPI","getServiceInfo","buyTicket","serviceReserve","getReserveList","getReserveInfo","page","reserveId","getContractPartners","acceptCall","cancelCall","completeCall","modifyReserve","cancelReserve","editViewType","createAction","input","editResrveForm","editContractForm","editBuyForm","editUserForm","editReserveDetailView","editReserveLatestView","editCallPage","appReducer","handleActions","action","produce","draft","loading","addTime","payMethod","_","isEmpty","l","count","userInfo","serviceInfo","reserveForm","report","reserve","unemergency","assist","contractForm","buyForm","mateCallPage","mateCallList","reserveList","mateReserveList","mateViewType","mateReserveLatest","mateReserveDetail","payHistory","partners","contractServices","login","logout","checkUserId","findPassword","modifyPassword","newPassword","withdrawlUser","withdrawlKakao","confirmEmailAuth","verificationCode","editAuth","editLoginForm","editRegisterForm","editAddPatientForm","editAddCardForm","editFindPasswordForm","editPasswordForm","initialState","allowed","ticket","loginForm","registerForm","agree","longTermCare","longTermCareInfo","patientList","patientInfo","addPatientForm","cardList","cardInfo","addCardForm","findForm","passwordForm","reNewPassword","infoForm","mateInfo","authReducer","region","gradePresence","gradeLevel","HomeContainer","prevList","fetchPartners","connect","app","editForm","editLatest","editDetail","NotFoundPage","verticalAlign","LoginStyledContainer","TabContainer","Tab","active","H1","h1","bold","h2","h3","h5","h6","isNotNumber","celluarValidate","phone","result2","lang","weekdays","weekdaysShort","EditStep1","inputDeepHandler","setDestination","setStarting","onTab","tab","deepType","onSex","disabled","undefined","Option","reserveHotFix","some","r","parseFloat","nativeEvent","preventDefault","fix","EditStep2","onModify","sick","onCalendar","meetDate","locale","inputReadOnly","disabledDate","current","add","holidayKR","isSolarHoliday","meetTime","numValue","meetMinute","usingPoint","RelativeWrapper","SigleButtonWrapper","SigleButton","AlertMessage","customStyles","zIndex","boxShadow","right","bottom","CustomModal","addEventListener","onCheckSize","visible","body","overflow","componentWillUnmount","removeEventListener","windowWidth","innerWidth","windowHeight","innerHeight","innerContent","getElementById","childrenId","clientHeight","maxWidth","onAfterOpen","CommonWithmateModal","onCancel","onOk","ModalInnerContainer","noClose","CloseButton","CommonModalTitle","CommonModalSubtitle","wordBreak","cancelText","confirmText","NoramlReserveEditModal","step","NewHandleReportModal","WideModalTitle","AlertText","care","medicine","nextSchedule","mateComment","doctorComment","NoReportModal","ReportMoal","timeline","selectedServiceName","ReportInfoBlock","createdAt","ReportDescription","complete","diff","receipt","mode","Item","start","arrived","careStart","careDone","treatmentStart","treatmentDone","careStart_second","careDone_second","treatmentStart_second","treatmentDone_second","careStart_third","careDone_third","treatmentStart_third","treatmentDone_third","backStart","onlyMobile","withSub","Kakao","KakaoLogin","onEdit","checkUser","gender","modalTitle","modalInfo","loginWithKakao","that","Auth","scope","setAccessToken","access_token","API","url","kakao_account","fail","viewToShow","ButtonWrap","ButtonWrap2","Component","Styled","KakaoLoginImg","KakaoLoginImgM","LoginComponent","onPressEnter","LoginPage","goBack","MainComponent","MainRegisterStyledContainer","MainRegisterPage","RegisterStyledContainer","TermsStyledContainer","component","TermsComponent","TermsContainer","isComponent","PrivacyStyledContainer","PrivacyComponent","PrivacyContainer","MarketingStyledContainer","MarketingComponent","class","MarketingContainer","NromalStyledContainer","EssentialComponent","NormalContainer","SensitiveComponent","SensitiveContainer","NormalComponent","SensitiveStyledContainer","AdvertisementStyledContainer","AdvertisementComponent","AdvertisementContainer","RegisterComponent","createdAuthCode","authCodeCheck","vaildated","handleCheckAllChange","checkAll","onSendMailHandler","event","alert","onCheckHandler","notification","pageOneValidator","pageSndValidator","onRegister","repassword","validator","isEmail","setPhoto","originFileObj","formCompleteStatus","valid","Agree","checked","AgreeLinkText","cursor","maxLength","marginLeft","borderColor","outline","Alert","RegisterPage","LogoutPage","StyledFindContainer","Find","editFindForm","onFind","setTimeout","FindPage","StyledMateContainer","UserPhoto","GuideRowWrapper","GuideRowWrapper2","GuideContainer","GuideDescriptionSectionTitle","GuideDescriptionSection","GuideDescriptionSectionContent","StudyButton","InputFilter","keywordHandler","FilterWrapper","CalleList","onRow","reserveCode","Mate","reservedFilter","onRowModal","rowDetail","handleReportModal","callList","syncStep","componentDidUpdate","match","d","reportId","noReportModal","updateBasicInfo","newPhoto","modify","editPassword","withdrawl","temp","tabHandler","onNextProcess","startOf","valueOf","unemergencyService","doReceipt","doStart","doArrive","doCare","doCareDone","doBackStart","doComplete","openReportForm","assistService","err","onAddReport","filteredList","toLowerCase","m","hidden","accept","files","click","URL","createObjectURL","doProducts","link","footer","flex","GuideBlock","GuideBlock2","Filter","MatePage","StyledNormalContainer","PointBoxRow","PointBox","PointBox2","PointBox3","PointContent","PointBoxTitle","PointTotal","PointHistoryRow","PointHistoryNameRow","PointHistoryValueRow","NoHistory","ReserveList","onDetailModal","onMateModal","onReport","onMate","mate","confirm","UserStatistics","pro","basic","UserContainer","UserNavigation","onPatientModal","NaviWrapper","ProfileStyledContainer","StyledContainer","GuideNavContainer","InnerContainer","GuideNavWrapper","NavTab","GuideConceptContainer","GuideConceptTitle","DesktopBr","MeritContainer","MeritHeaderWrapper","MeritCardList","MeritCardWrapper","MeritCardNumber","MeritCardTitleRow","MeritCardDesc","GuideDetailContainer","GuideDetailServiceCardWrapper","GuideDetailServiceCard","GuideCardImage","GuideCardSpecTitle","GuideCardSpecRow","GuideCardName","GuideCardType","GuideCardDescription","GuideDetailSubFlexWrapper","GuideDetailSubFlexbox","GuideUsingContainer","GuideUsingSubFlexWrapper","GuideUsageFlexbox","WithmateContainer","FlexDivWrapper","HiddenType","mHidden","BigSideBox","SmallSideBox","WithmateBg","WithmateTitle","position","background","WebkitOverflowScrolling","NewProfileComponent","onStarting","daum","Postcode","oncomplete","sido","sigungu","bname","roadAddress","buildingName","onProfile","ariaHideApp","trim","CardStyledContainer","onCard","YMWrapper","ModifyProfileComponent","stopPropagation","patientColumn","onDelete","dataIndex","align","render","EditOutlined","DeleteOutlined","cardColumn","slice","NormalUser","paidFilter","kakaoModal","selected","cancelModal","modifyModal","detailModalPage","reserveDetailModal","mateModal","serviceStatus","serviceModal","addHalfTime","totalPro","totalBasic","pointUsingHistory","pointAddHistory","couponAddHistory","patientModal","patientModifyModal","cardModal","cardModifyModal","appointedCode","patientModalOff","patientModifyModalOff","cardModalOff","cardModifyModalOff","fetchUserInfo","reserves","actionType","callStatus","onRematch","warn","confirmReserve","onViewReport","onReportMoal","onPatientModifyModal","onCardModal","onCardModifyModal","row","html","onFetchPatientInfo","onPatientModify","onPatientDelete","onCardModify","onCardDelete","kakaoUnlink","onAddCoupon","couponName","couponValue","handleChange","dataSource","columns","pageSize","Password","point","addedAt","leftValue","usedAt","CouponInput","review","starCount","score","renderStarIcon","onStarClick","NormalPage","StyledPendingContainer","Pending","PendingPage","dsipatch","AuthPage","exact","path","Login","Logout","Register","Main","Normal","NotFound","AuthStyledContainer","AuthPages","StyledCompanyContainer","FstBlock","SndBlock","TrdBlock","FthBlock","data-aos","data-aos-anchor-placement","data-aos-duration","CoCompany","StyledCoCompany","SthSection","Company","CompanyPage","StyledFaqContainer","Panel","FAQ","hash","to","scroll","el","scrollIntoView","behavior","block","expandIconPosition","bordered","expandIcon","isActive","rotate","header","rowIndex","PanelHeader","PanelContent","FAQContainer","StyledBuyContainer","BuyTicket","edit","payment","defaultPrice","totalPrice","IMP","init","request_pay","pg","pay_method","merchant_uid","amount","buyer_email","buyer_name","buyer_tel","m_redirect_url","rsp","productCode","paid_amount","productId","merchantUid","impUid","imp_uid","unit","paidStatus","paid","card_name","bankName","bank_name","cardQuota","card_quota","buyerEmail","discount","min","max","val","formatter","BuyTicketPage","ProductRenderPages","Buy","ProductPages","ReservePageContainer","ResrevePageInnerContainer","smallPadding","mobileBg","mobieBg","ReserveTopCover","isMain","TopBannerSubDescription","TopBannerSection","TopBannerText","TopBannerDescription","StepSectionContainer","StepButtonWrapper","StepButton","button","UnderLineText","StepArrow","NextStepGudieContainer","useBg","NextStepEmoj","NextStepTitle","NextStepArrowDown","ServiceSectionContainer","ServiceSectionTitle","ServiceSectionDescription","ServiceCardList","ServiceCardWrapper","on","ServiceCardButton","ServiceTypeSectionContainer","gap","ServiceTypeWrapper","ServiceTypeCardWrapper","ServiceTypeCardImg","ServiceTypeName","ServiceTypeDescription","NextStepButton","LastStepButton","FormContainer","FormWrapper","FormMainTitle","FormMainAlert","ServiceName","Sexes","LabelDescription","FlexFormWrapper","ResultFormWrapper","LabelAndValueRow","LabelValue","PriceValue","PriceDetailLabel","PriceDetailValue","DashAndText","CongraturateLogo","DoneResultWrapper","MobileStepImage","TopWrapper","BottomWrapper","MediumText","Noti","ApplyButton","FlexTitle","Contact","ContactTime","Link","LongTermCareComponent","onLongTermCare","SuccessComponent","backgroundImage","Background","Checkpoint","textAlgn","ServicePDF","iFrameHeight","frameBorder","ManualComponent","PlatformPDF","EduVideo1","allow","allowFullScreen","EduVideo2","EduVideo3","EduVideo4","StyledListContainer","HeaderButton","CountDisplay","CollapseContainer","CollapseHeader","CollapseTab","CollapseTabOnlyDesktop","PanelField","onlyDesktop","Star","ReviewTextWrapper","ReviewText","MyReview","ReviewMobileInfo","ReviewerName","newsEvent","Event","rowKey","newsEventList","addNewsEvent","url2","urlSource2","getNewsEventInfo","newsEventId","newsEventAPI","fetchNewsEvent","newsEventInfo","InfoContainer","StyledInfoContainer","InfoBlock","borderBottom","fetchInfo","Label","objectFit","whiteSpace","float","ValueBox","NewsEvent","List","Info","addReview","editReview","reviewId","reviewList","reviewPage","StyledAddContainer","WritePaper","FormHeader","FormTitle","FormSubtitle","FormTypeWrapper","FormTypeBlock","FormTypeDesc","FormDescription","StarImg","FormButtonWrapper","FormButton","FormTitleRowWrapper","FormRowTitle","CheckboxGroup","HeaderContainer","HeaderWrapper","HeaderBlock","HeaderTitle","HeaderDescription","MainImageWrapper","MainImage","CommentPageHeader","desc","AddComment","star","useAgain","corpSatisfied","corpSatisfiedReason","doctorSatisfied","doctorSatisfiedReason","hope","checkReserveValidation","reviewStatus","starHandler","nextValue","prevValue","onAddReview","PaddingDiv","AddCommentPageContainer","getReserve","PerPage","CommentList","total","pageCnt","renderStar","fill","getAutoTitle","rate","user","parseInt","reply","CommentListPage","TableContainer","TableHeader","TableTitle","TableSubTitle","TableBody","TableRow","TableField","desktopOnly","TableButton","EmptyWrapper","EmptyImage","EmptyText","MyReviewList","onReserve","done_list","substr","MyCommentListPage","fetchReserveList","ReadyApplyPage","LargeText","InputWrapper","InputLabel","StyledInput","FormImgWrapper","photoFst","photoSnd","fileFst","fileSnd","photoFstValue","photoSndValue","fileFstValue","fileSndValue","onSpin","MateFormPage","fetchForm","form","sendForm","careCareer","question","_info","MateApplyPage","handleTrimChange","onAddress","editApply","onSendApply","connection_etc","activity_area","drive","care_experience","insurance","privacy","license_photo","image","join","si","GuideNav","activeTab","GuideConcept","GuideDetail","spec1","spec2","spec3","spec4","GuideCard","GuideUsage","Merit","number","MeritCard","Block","bigMargin","noMargin","GuideBanner","GuideBannerContainer","GuidePage","reserveType","mobile_menu","onRoute","popoverVisible","NemtTitleWrapper","NemtTitle","NemtServiceWrapper","NemtServiceFlexWrapper","NemtBox","NemtColumnBox","NemtBoxTitle","NemtServiceImageWrapper","NemtInfobox","NemtDescription","NemtPage","NemtContainer","onCheck","PatientProfileListComponent","onChoose","reservedStarting","walk","onChangeCheckbox","onUpdatePatient","hideOnSinglePage","mateListColumn","sorter","b","localeCompare","photoURL","mateList","getList","onUpdateMate","CardListComponent","onUpdateCard","ReservationPage","big5","local","corpBy","zzz","alzhe","chooseMate","fetchItemList","prevParams","usePoint","onPrevSetting","patientProfileListModal","onPrevSetting2","mateListModal","onPrevSetting3","cardListModal","isOption","onSelectService","isZzz","isAlzhe","reservedDestination","reservedShortStarting","shortDestination","reservedShortDestination","goSecondStep","querySelector","getClientRects","scrollY","goNextButton","onDestination","stepHandler","currentStep","recommender","recommenderContact","guardContact","mateGender","reserveTime","reserveMinute","mateName","installment","totalFee","proDiscount","basicDiscount","product","stepHandler2","prevStep","patientProfileListModalOff","mateListModalOff","cardListModalOff","mateContact","emoj","logo","onSelect","CustomButtonWrapper","BannerSection","StepSection","NextGuider","ServiceSection","mBg","Card","ServiceTypeSection","ServiceTypeCard","BasicForm","MainForm","allowClear","readonly","hour","ConfirmForm","_transport","_service","_point","DoneForm","DepartmentComponent","isChecked","setIsChecked","Set","checkedItems","setCheckedItems","checkedItemHandler","box","has","delete","parentNode","checkHandler","NavComponent","menu","onMobileMenuHandler","activeClassName","NavStyledContainer","NavContainer","FooterComponent","darkMode","indexOf","startsWith","rel","FooterStyledContainer","FooterContainer","Modal","setAppElement","App","AOS","Home","Product","Privacy","Terms","Marketing","EssentialNormal","EssentialSensitive","SelectiveNormal","SelectiveSensitive","Advertisement","MateReady","MateApplyForm_v2","MateApplyForm","ReviewList","ReviewMylist","ReviewAdd","LongTermCare","Success","SManual","PManual","EduVideo","MetLife","MetLifeNemt","MetLifeReviewList","MetLifeNewsEvent","MetLifeFAQ","MetLifePrivacy","MetLifeTerms","Department","Nemt","Boolean","hostname","reducers","combineReducers","store","createStore","applyMiddleware","thunk","ReactDOM","navigator","serviceWorker","ready","registration","unregister","module","exports","req","require","keys","forEach","webpackContext","webpackContextResolve","__webpack_require__","o","Error","Object"],"mappings":"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","file":"static/js/main.7c1942a8.chunk.js","sourcesContent":["export const BASE_URL = 'https://server.withmate.kr';\nexport const DEV = false;\n\n// info\nexport const COMPANY_NANE = 'WITHMATE';\nexport const COMPANY_NANE_EN = 'withmate';\nexport const CONTACT_TEL = '010-xxxx-xxxx';\nexport const CONTACT_EMAIL = 'withmate@mail.com';\nexport const CUSTOMER_SERVICE = 'customer@withmate.com';\nexport const USER = 'user';\nexport const MATE = 'mate';\nexport const LOCAL = 'local';\nexport const KAKAO = 'kakao';\nexport const ASSIST = 'assist';\nexport const UNEMER = 'unemergency';\nexport const HAPPYCARE = 'happycare';\n","import React from 'react';\nimport { withRouter } from 'react-router-dom';\nimport moment from 'moment';\nimport { UNEMER } from '../Lib/variables';\n\nclass ScrollTop extends React.PureComponent {\n    componentDidUpdate(prevProps) {\n        if (this.props.location !== prevProps.location) {\n            window.scrollTo(0, 0);\n        }\n    }\n    render() {\n        return <>{this.props.children}</>;\n    }\n}\nexport default withRouter(ScrollTop);\n\nexport const currencyFormatter = currency => {\n    if (currency === 0) return 0;\n\n    var reg = /(^[+-]?\\d+)(\\d{3})/;\n    var n = currency + '';\n\n    while (reg.test(n)) n = n.replace(reg, '$1' + ',' + '$2');\n\n    return n;\n};\n\nexport const timeFormatter = ({ hour, minute = '00' }) => {\n    const year = moment().format('YYYY').toString();\n    const month = moment().format('MM').toString();\n    const date = moment().format('DD').toString();\n\n    if (hour && hour.length <= 1) hour = '0' + hour;\n    if (minute && minute.length <= 1) minute = '0' + minute;\n    return year + month + date + ' ' + hour + minute + '00';\n};\n\nexport const datetimeFormatter = ({ date, hour, minute = '00' }) => {\n    const year = moment(date).format('YYYY').toString();\n    const month = moment(date).format('MM').toString();\n    const _date = moment(date).format('DD').toString();\n\n    if (hour && hour.length <= 1) hour = '0' + hour;\n    if (minute && minute.length <= 1) minute = '0' + minute;\n    return year + month + _date + ' ' + hour + minute + '00';\n};\n\nexport const combineDateAndTime = ({ date, time, minute }) => {\n    if (time && time.length === 1) time = '0' + time;\n    if (minute && minute.length === 1) minute = '0' + minute;\n\n    return moment(moment(date).format('YYYYMMDD') + ' ' + time + minute + '00').toDate();\n};\n\nexport const serviceParser = service => {\n    switch (service) {\n        case 'assist':\n            return '병원 동행 Basic';\n        case 'unemergency':\n            return '병원 동행 Pro';\n        case 'happycare':\n            return '해피케어';\n    }\n};\n\nexport const getNextStatus = (type, status) => {\n    if (type === 'unemergency') {\n        switch (status) {\n            case '예약접수':\n                return '';\n            case '예약완료':\n                return '접선';\n            case '접선':\n                return '병원 출발';\n            case '병원 출발':\n                return '병원 도착';\n            case '병원 도착':\n                return '진료 시작';\n            case '진료 시작':\n                return '진료 종료';\n            case '진료 종료':\n                return '귀가 시작';\n            case '자택 출발':\n                return '서비스 종료';\n            case '서비스 종료':\n                return '종료된 서비스';\n        }\n    }\n\n    if (type === 'assist') {\n        switch (status) {\n            case '예약접수':\n                return '';\n            case '예약완료':\n                return '접선';\n            case '접선':\n                return '진료 시작';\n            case '진료 시작':\n                return '진료 종료';\n            case '진료 종료':\n                return '서비스 종료';\n            case '서비스 종료':\n                return '종료된 서비스';\n        }\n    }\n\n    if (type === 'happycare') {\n        switch (status) {\n            case '예약완료':\n                return '접선';\n            case '접선':\n                return '진료 시작';\n            case '진료 시작':\n                return '진료 종료';\n            case '진료 종료':\n                return '서비스 종료';\n            case '서비스 종료':\n                return '종료된 서비스';\n        }\n    }\n};\n\nexport const getTotal = (service, addTime, transport) => {\n    if (transport === 'withcar' && service === UNEMER) {\n        return getWithcarPrice(addTime);\n    } else if (service === UNEMER) {\n        return 20000 * addTime + (transport === 'own' ? 20000 : 0);\n    } else {\n        return 15000 * addTime;\n    }\n};\n\nexport const colorParserByStatus = status => {\n    switch (status) {\n        case '접수대기':\n            return '#161616';\n        case '예약접수':\n            return '#43b30c';\n        case '예약완료':\n            return '#3bc1ff';\n        case '서비스 종료':\n            return '#ff5500';\n        default:\n            return '#606060';\n    }\n};\n\nexport const getWithcarPrice = time => {\n    switch (time) {\n        case 1:\n            return 93500;\n        case 1.5:\n            return 93500 + 93500 / 2;\n        case 2:\n            return 143000;\n        case 2.5:\n            return 143000 + 93500 / 2;\n        case 3:\n            return 181500;\n        case 3.5:\n            return 181500 + 93500 / 2;\n        case 4:\n            return 220000;\n        case 4.5:\n            return 220000 + 93500 / 2;\n        case 5:\n            return 264000;\n        case 5.5:\n            return 264000 + 93500 / 2;\n        case 6:\n            return 308000;\n        case 6.5:\n            return 308000 + 93500 / 2;\n        case 7:\n            return 352000;\n        case 7.5:\n            return 352000 + 93500 / 2;\n        case 8:\n            return 396000;\n    }\n};\n","import axios from 'axios';\nimport qs from 'qs';\nimport { BASE_URL, DEV } from './variables';\naxios.defaults.withCredentials = true;\nconst client = axios.create({\n    headers: {\n        post: {\n            'Content-Type': 'application/x-www-form-urlencoded',\n        },\n        // withCredentials: true,\n    },\n    paramsSerializer: function (params) {\n        return qs.stringify(params, { indices: false });\n    },\n    baseURL: DEV === 'beta' ? `https://beta.server.withmate.kr` : DEV ? '/' : BASE_URL,\n});\n\nclient.interceptors.request.use(\n    config => {\n        // const token = localStorage.getItem('accessToken');\n        // config.headers = {\n        //     Authorization: `Bearer ${token}`,\n        // };\n        return config;\n    },\n    error => {\n        return Promise.reject(error);\n    },\n);\n// 인터셉터 설정\nclient.interceptors.response.use(\n    response => {\n        return response;\n    },\n    error => {\n        if (error && error.request && error.request.status === 403) {\n            localStorage.clear();\n            window.location.reload();\n        }\n        return error;\n    },\n);\n\nexport default client;\n","import React, { useEffect, useState } from 'react';\nimport Modal from 'react-modal';\nimport styled from 'styled-components';\nimport axios from '../../../../Lib/axios';\n\nconst Popup = () => {\n    const [popupData, setPopupData] = useState(null);\n    const [isOpen, setIsOpen] = useState(false);\n    const [loading, setLoading] = useState(true);\n    const [error, setError] = useState(null);\n\n    // 이전 방문 날짜 (로컬스토리지에서 가져오기, 숫자로 변환)\n    const VISITED_BEFORE_DATE = Number(localStorage.getItem('VisitCookie'));\n    // 현재 날짜 (일 단위)\n    const VISITED_NOW_DATE = new Date().getDate();\n\n    useEffect(() => {\n        // 팝업 오늘 하루 닫기 체크\n        if (VISITED_BEFORE_DATE === VISITED_NOW_DATE) {\n            setIsOpen(false);\n            setLoading(false);\n            return;\n        }\n\n        setLoading(true);\n        axios\n            .get('/v1/popup/list')\n            .then(response => {\n                const now = new Date();\n\n                // startDate와 endDate를 비교하여 유효한 팝업 필터링\n                const validPopups = response.data.data.filter(popup => {\n                    const startDate = new Date(popup.startDate);\n                    const endDate = new Date(popup.endDate);\n\n                    return popup.isPublic && now >= startDate && now <= endDate;\n                });\n\n                if (validPopups.length > 0) {\n                    setPopupData(validPopups[0]);\n                    setIsOpen(true);\n                } else {\n                    console.log('유효한 팝업이 없습니다.');\n                }\n                setLoading(false);\n            })\n            .catch(error => {\n                console.error('팝업 데이터를 불러오는 중 오류 발생:', error);\n                setError(error);\n                setLoading(false);\n            });\n    }, [VISITED_BEFORE_DATE, VISITED_NOW_DATE]);\n\n    // 오늘 하루 닫기\n    const handleDayClose = () => {\n        localStorage.setItem('VisitCookie', String(VISITED_NOW_DATE)); // 숫자 -> 문자열로 변환하여 저장\n        setIsOpen(false);\n    };\n\n    const handleClose = () => {\n        setIsOpen(false);\n    };\n\n    return (\n        <Modal isOpen={isOpen} onRequestClose={handleClose} style={modalStyles}>\n            {popupData && (\n                <PopupContainer>\n                    <PopupImage src={popupData.photo} alt='팝업 이미지' />\n                    <CloseStyle>\n                        <Close onClick={handleDayClose}>오늘 하루 닫기</Close>\n                        <Close onClick={handleClose}>닫기</Close>\n                    </CloseStyle>\n                </PopupContainer>\n            )}\n        </Modal>\n    );\n};\n\nexport default Popup;\n\nconst PopupContainer = styled.div`\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n    padding: 5px;\n    background: #282828;\n    border-radius: 10px;\n    text-align: center;\n\n    @media (max-width: 768px) {\n        width: auto;\n        height: 400px;\n    }\n`;\n\nconst PopupImage = styled.img`\n    max-width: 100%;\n    height: 400px;\n    border-radius: 8px;\n\n    @media (max-width: 768px) {\n        width: auto;\n        height: 350px;\n    }\n`;\n\nconst CloseStyle = styled.div`\n    display: flex;\n    justify-content: space-between;\n    background-color: #282828;\n    width: 100%;\n    margin-top: 10px;\n    padding: 5px;\n    border-radius: 0 0 15px 15px;\n    color: #ffffff;\n    font-size: 13px;\n`;\n\nconst Close = styled.span`\n    cursor: pointer;\n`;\n\nconst modalStyles = {\n    overlay: {\n        backgroundColor: 'rgba(0, 0, 0, 0.5)',\n    },\n    content: {\n        width: '350px',\n        height: 'fit-content',\n        margin: 'auto',\n        padding: '0',\n        borderRadius: '10px',\n        top: '50%',\n        left: '50%',\n        transform: 'translate(-50%, -50%)',\n    },\n};\n","export const gray = ['#f8f9fa', '#f1f3f5', '#e9ecef', '#dee2e6', '#ced4da', '#adb5bd', '#868e96', '#495057', '#343a40', '#212529'];\nexport const cyan = ['#e3fafc', '#c5f6fa', '#99e9f2', '#66d9e8', '#3bc9db', '#22b8cf', '#15aabf', '#1098ad', '#0c8599', '#0b7285'];\nexport const red = ['#fff5f5', '#ffe3e3', '#ffc9c9', '#ffa8a8', '#ff8787', '#ff6b6b', '#fa5252', '#f03e3e', '#e03131', '#c92a2a'];\nexport const yellow = ['#fff9db', '#fff3bf', '#ffec99', '#ffe066', '#ffd43b', '#fcc419', '#fab005', '#f59f00', '#f08c00', '#e67700'];\nexport const blue = ['#e7f5ff', '#d0ebff', '#a5d8ff', '#74c0fc', '#4dabf7', '#339af0', '#228be6', '#1c7ed6', '#1971c2', '#1864ab'];\nexport const grape = ['#f8f0fc', '#f3d9fa', '#eebefa', '#e599f7', '#da77f2', '#cc5de8', '#be4bdb', '#ae3ec9', '#9c36b5', '#862e9c'];\nexport const borderColor = '#e8e8e8';\n\nexport const fontSize = {\n    b8: '8px',\n    b10: '10px',\n    b12: '12px',\n    b14: '14px',\n    b16: '16px',\n    b18: '18px',\n    b20: '20px',\n    b22: '22px',\n    b24: '24px',\n    b26: '26px',\n    b28: '28px',\n    b30: '30px',\n    b32: '32px',\n    b34: '34px',\n};\n\nexport const sizeHandler = size => {\n    return size + 'px';\n};\nexport const mainColor = '#3bc1ff';\nexport const mainBoldColor = '#4dabf7';\nexport const bgDarkColor = '#212529';\n\nconst ColorPallete = {\n    blue50: '#3bc1ff',\n    blue100: '#4dabf7',\n    green100: '#49a938',\n    dark100: '#161616',\n    dark80: 'rgba(0,0,0,0.8)',\n    dark70: 'rgba(0,0,0,0.7)',\n    dark60: '#a6a6a6',\n    dark50: '#e9e9e9',\n    dark30: '#ececec',\n    dark20: '#dddddd',\n    dark10: '#f5f5f5',\n};\n\nexport default ColorPallete;\n","import React from 'react';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport Popup from '../../../Pages/Home/Section/renew/Popup';\n\n// utils\nimport { sizeHandler, mainColor } from '../../../theme';\nimport { UNEMER } from '../../../Lib/variables';\n\nexport const NoCatchedList = ({ list, detailHandler, data, onRefresh }) => {\n    return (\n        <FullContainer>\n            {/* <Popup /> */}\n            <Inner>\n                <NoCatchTitle>\n                    실시간 예약 내역\n                    <RefreshButton onClick={onRefresh}>새로고침</RefreshButton>\n                </NoCatchTitle>\n                <ListConatiner>\n                    {list && Array.isArray(list) && list.length > 0 ? (\n                        list.map(item => {\n                            const serviceType =\n                                !item.productInfo || !item.productInfo.usePro || !item.productInfo.useBasic ? '' : item.service === UNEMER ? 'Pro' : 'Basic';\n                            const serviceName = (item.productInfo && item.productInfo.name && item.service && item.productInfo.name + serviceType) || '-';\n                            return (\n                                <ReserveItem\n                                    key={item._id.toString()}\n                                    serviceType={item.service}\n                                    service={serviceName}\n                                    name={item.patient}\n                                    reserveDate={moment(item.reserveDate).format('MM월 DD일 HH시mm분')}\n                                    destination={item.destination || '-'}\n                                    shortStarting={item.shortStarting || '-'}\n                                    status={item.call.status}\n                                    onDetail={() => {\n                                        detailHandler(item);\n                                    }}\n                                />\n                            );\n                        })\n                    ) : (\n                        <EmptyList>현재 예약내역이 없습니다.</EmptyList>\n                    )}\n                </ListConatiner>\n            </Inner>\n        </FullContainer>\n    );\n};\n\nconst ReserveItem = ({ service, name, reserveDate, shortStarting, destination, serviceType, status, onDetail, usageTime }) => (\n    <ItemContainer>\n        <TitleSection>\n            <ItemColumn>\n                <ItemTitle>서비스 명</ItemTitle>\n                <ItemContents style={{ color: mainColor }}>{service}</ItemContents>\n            </ItemColumn>\n        </TitleSection>\n\n        <ContentSection>\n            <ItemColumn>\n                <ItemTitle>환자 성함</ItemTitle>\n                <ItemContents>{name}</ItemContents>\n            </ItemColumn>\n            <ItemColumn>\n                <ItemTitle>병원 진료 예약 시간</ItemTitle>\n                <ItemContents>{reserveDate}</ItemContents>\n            </ItemColumn>\n            {serviceType === UNEMER && (\n                <ItemColumn>\n                    <ItemTitle>자택 주소</ItemTitle>\n                    <ItemContents>{shortStarting}</ItemContents>\n                </ItemColumn>\n            )}\n            <ItemColumn>\n                <ItemTitle>병원 주소</ItemTitle>\n                <ItemContents>{destination}</ItemContents>\n            </ItemColumn>\n        </ContentSection>\n\n        <ItemColumn>\n            <DetailButton onClick={onDetail}>\n                <span>자세히보기</span>\n            </DetailButton>\n        </ItemColumn>\n    </ItemContainer>\n);\n\nconst TitleSection = styled.div``;\n\nconst ContentSection = styled.div`\n    flex: 1;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    justify-content: flex-start;\n\n    width: 300px;\n    height: 316px;\n    overflow-y: scroll;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none; /* Chrome, Safari, Opera*/\n    }\n`;\n\nconst EmptyList = styled.p`\n    font-size: 20px;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 16px;\n    position: relative;\n`;\n\nconst FullContainer = styled.div`\n    width: 100%;\n    height: 100vh;\n    background: linear-gradient(to top, #3bc1ff, #5b62f5);\n`;\n\nconst Inner = styled.div`\n    max-width: 1024px;\n    height: 100%;\n    max-height: 628px;\n\n    margin: 0 auto;\n    background-image: url('/assets/images/w_main.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: 120px;\n    padding-bottom: 120px;\n\n    @media (max-width: 1080px) {\n        padding-left: 16px;\n        padding-right: 16px;\n    }\n\n    @media (max-width: 768px) {\n        padding-top: 40px;\n        background: transparent;\n    }\n`;\n\nconst NoCatchTitle = styled.p`\n    font-size: 28px;\n    font-weight: bold;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 24px;\n    position: relative;\n\n    @media (max-width: 480px) {\n        margin-bottom: 16px;\n    }\n`;\n\nconst RefreshButton = styled.span`\n    position: absolute;\n    margin-left: 8px;\n    top: 16px;\n\n    font-size: 14px;\n    color: #161616;\n    text-decoration: underline;\n    cursor: pointer;\n`;\n\nconst ListConatiner = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: flex-start;\n    flex-wrap: wrap;\n\n    > div:nth-child(3n) {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        > div:nth-child(3n) {\n            margin-right: 16px;\n        }\n\n        > div:nth-child(2n) {\n            margin-right: 0px;\n        }\n    }\n\n    @media (max-width: 480px) {\n        > div:nth-child(3n) {\n            margin-right: 0px;\n        }\n\n        flex-direction: column;\n        justify-content: center;\n    }\n`;\n\nconst ItemContainer = styled.div`\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    justify-content: center;\n\n    width: 340px;\n    height: 340px;\n    overflow: scroll;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none; /* Chrome, Safari, Opera*/\n    }\n\n    padding: 20px;\n    margin-bottom: 16px;\n    margin-right: 16px;\n\n    border-radius: 4px;\n    box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n    background-color: #ffffff;\n\n    @media (max-width: 768px) {\n        margin-bottom: 16px;\n    }\n\n    @media (max-width: 480px) {\n        width: 100%;\n        max-width: initial;\n        margin-right: 0px;\n    }\n`;\n\nconst ItemTitle = styled.p`\n    color: #a7a7a7;\n    font-size: ${sizeHandler(12)};\n    font-weight: bold;\n    margin: 0px;\n    padding: 0px;\n\n    @media (max-width: 430px) {\n        font-size: ${sizeHandler(11)};\n    }\n`;\n\nconst ItemContents = styled.p`\n    font-size: ${sizeHandler(14)};\n    font-weight: bold;\n    color: #606060;\n    margin: 0px;\n    padding: 0px;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n\n    @media (max-width: 430px) {\n        font-size: ${sizeHandler(12)};\n        margin-bottom: 4px;\n    }\n`;\n\nconst ItemColumn = styled.div`\n    width: 100%;\n    margin-bottom: 6px;\n\n    @media (max-width: 768px) {\n        display: ${props => (props.hiddenMobile ? 'none' : 'block')};\n        width: 100%;\n    }\n`;\n\nconst DetailButton = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    width: 100%;\n    height: 44px;\n\n    border-radius: 4px;\n    border: 1px solid ${mainColor};\n    cursor: pointer;\n    transition: all 0.3s;\n    text-align: center;\n\n    span {\n        font-size: ${sizeHandler(14)};\n        font-weight: bold;\n        color: ${mainColor};\n        text-align: center;\n\n        @media (max-width: 430px) {\n            font-size: ${sizeHandler(12)};\n        }\n    }\n\n    &:hover {\n        background-color: ${mainColor};\n        span {\n            color: white;\n        }\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n        height: 34px;\n        font-size: ${sizeHandler(12)};\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport { Input, Select, DatePicker, TimePicker } from 'antd';\n\nimport Pallete from '../../theme';\n\nconst DivisionLine = styled.div`\n    width: 100%;\n    height: ${props => (props.big ? '32px' : props.x_small ? '8px' : props.small ? '16px' : '24px')};\n\n    @media (max-width: 480px) {\n        height: ${props => (props.big ? '24px' : props.x_small ? '4px' : props.small ? '8px' : '16px')};\n    }\n`;\n\nconst BorderDivisionLine = styled.div`\n    width: 100%;\n    height: 1px;\n    background-color: ${Pallete.dark50};\n\n    margin-top: ${props => (props.x_small ? '4px' : props.small ? '8px' : '12px')};\n    margin-bottom: ${props => (props.x_small ? '4px' : props.small ? '8px' : '12px')};\n`;\n\nconst WithmateLabelText = styled.div`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.54;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n\n    > span {\n        color: ${Pallete.blue50};\n    }\n\n    @media (max-width: 480px) {\n        font-size: 12px;\n    }\n`;\n\nconst WithmateLabel = ({ children, required, ...rest }) => {\n    return (\n        <WithmateLabelText {...rest}>\n            {required && <span>* </span>}\n            {children}\n        </WithmateLabelText>\n    );\n};\n\nWithmateLabel.propTypes = {\n    required: PropTypes.bool,\n};\n\nconst WithmateInput = styled(Input)`\n    width: 100%;\n    height: 46px;\n    line-height: 44px;\n    ${props => props.small && `max-width: 102px; height: 32px; line-height: 29px;`}\n\n    margin-bottom: 0px;\n\n    color: ${Pallete.dark100};\n    font-size: 14px;\n    font-weight: normal;\n\n    border-radius: 4px;\n    border: 1px solid ${Pallete.dark50} !important;\n    background-color: #ffffff;\n\n    @media (max-width: 480px) {\n        font-size: 12px;\n        border: 1px solid ${Pallete.dark50} !important;\n    }\n\n    &.ant-input {\n        width: 100%;\n        height: 46px;\n        line-height: 44px;\n\n        margin-bottom: 0px;\n\n        color: ${Pallete.dark100};\n        font-size: 14px;\n        font-weight: normal;\n\n        border-radius: 4px;\n        border: 1px solid ${Pallete.dark50} !important;\n        background-color: #ffffff;\n\n        &::placeholder {\n            color: ${Pallete.dark60};\n            font-size: 14px;\n            font-weight: normal;\n        }\n\n        @media (max-width: 480px) {\n            font-size: 12px;\n            border: 1px solid ${Pallete.dark50} !important;\n\n            &::placeholder {\n                font-size: 12px;\n            }\n        }\n    }\n\n    &:focus {\n        border: 1px solid ${Pallete.blue100} !important;\n        transition: all 0.3s;\n        box-shadow: none;\n        outline: 0;\n    }\n\n    &:disabled {\n        background-color: ${Pallete.dark10};\n    }\n\n    &.ant-input-affix-wrapper-disabled {\n        background-color: #f5f5f5;\n    }\n\n    &.ant-input-affix-wrapper {\n        height: 46px;\n        line-height: 43px;\n        padding: 0px 11px;\n\n        ${props => props.small && `max-width: 102px; height: 32px; line-height: 29px;`}\n\n        .ant-input {\n            width: 100% !important;\n            height: 100%;\n            line-height: 43px;\n\n            color: ${Pallete.dark100};\n            font-size: 14px;\n            font-weight: normal;\n\n            border: 0px !important;\n            &::placeholder {\n                color: ${Pallete.dark60};\n                font-size: 14px;\n                font-weight: normal;\n            }\n\n            &:focus {\n                border: 1px solid ${Pallete.blue100} !important;\n                transition: all 0.3s;\n                box-shadow: none;\n                outline: 0;\n            }\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n                line-height: 43px;\n\n                &:focus {\n                    border: 1px solid ${Pallete.dark50} !important;\n                }\n\n                &::placeholder {\n                    font-size: 12px;\n                }\n            }\n            &:disabled {\n                background-color: ${Pallete.dark10};\n            }\n        }\n\n        .ant-input-suffix {\n            font-size: 14px;\n            font-weight: normal;\n            font-stretch: normal;\n            text-align: right;\n            color: ${Pallete.dark100};\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n            }\n        }\n    }\n`;\n\nconst InputTextButton = styled.span`\n    display: inline-block;\n    min-width: 50px;\n\n    height: 46px;\n    line-height: 44px;\n\n    padding-left: 6px;\n    padding-right: 6px;\n\n    font-size: 11px;\n    font-weight: normal;\n    color: ${Pallete.dark60};\n    text-align: center;\n    cursor: pointer;\n\n    transition: all 0.3s;\n\n    &:hover {\n        color: ${Pallete.dark100};\n    }\n`;\n\nconst InputValue = styled.div`\n    flex: 1;\n    height: 46px;\n    line-height: 44px;\n\n    padding-left: 11px;\n    padding-right: 11px;\n\n    font-size: 14px;\n    font-weight: normal;\n    color: ${props => (props.withValue ? Pallete.dark100 : Pallete.dark60)};\n`;\n\nconst WithamteInputWithButton = ({ inputConfig, buttonName, onButton }) => {\n    return (\n        <BorderFlexWrapper>\n            <WithmateInput {...inputConfig} />\n            {onButton && typeof onButton === 'function' && <InputTextButton onClick={onButton}>{buttonName}</InputTextButton>}\n        </BorderFlexWrapper>\n    );\n};\n\nWithamteInputWithButton.propTypes = {\n    inputConfig: PropTypes.object,\n    buttonName: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n    onButton: PropTypes.func,\n};\n\nconst HalfWithmateInput = styled(WithmateInput)`\n    width: calc(50% - 4px);\n`;\n\nconst WithmateTextarea = styled(Input.TextArea)`\n    &.ant-input {\n        width: 100%;\n        height: 240px;\n        ${props => props.middle && `min-height: 110px; max-height: 110px;`}\n        ${props => props.small && `min-height: 88px; max-height: 88px;`}\n\n        color: ${Pallete.dark100};\n        font-size: 14px;\n        font-weight: normal;\n\n        border-radius: 4px;\n        border: 1px solid ${Pallete.dark50} !important;\n        background-color: #ffffff;\n\n        margin-bottom: 8px;\n        padding: 8px;\n\n        &::placeholder {\n            color: ${Pallete.dark60};\n            font-size: 14px;\n            font-weight: normal;\n        }\n\n        @media (max-width: 480px) {\n            font-size: 12px;\n            &::placeholder {\n                font-size: 12px;\n            }\n        }\n\n        &:focus {\n            border: 1px solid ${Pallete.blue100} !important;\n            transition: all 0.3s;\n            box-shadow: none;\n            outline: 0;\n        }\n\n        &:disabled {\n            background-color: ${Pallete.dark10};\n        }\n\n        @media (max-width: 480px) {\n            min-height: 140px;\n            ${props => props.middle && `min-height: 110px; max-height: 110px;`}\n            ${props => props.small && `min-height: 88px; max-height: 88px;`}\n\n            padding: 4px 11px;\n            border: 1px solid ${Pallete.dark50} !important;\n\n            &:focus {\n                border: 1px solid ${Pallete.dark50} !important;\n            }\n        }\n    }\n`;\n\nconst WithmateSelect = styled(Select)`\n    &.ant-select {\n        // margin-bottom: 8px;\n        width: 100%;\n        height: 46px;\n        border-radius: 4px;\n\n        .ant-select-selector {\n            height: 100%;\n        }\n    }\n\n    &.ant-select .ant-select-selector {\n        height: 100% !important;\n        line-height: 43px;\n    }\n\n    &.ant-select-single .ant-select-selector .ant-select-selection-item,\n    &.ant-select-single .ant-select-selector .ant-select-selection-placeholder {\n        line-height: 43px;\n    }\n\n    &.ant-select-single .ant-select-selector .ant-select-selection-item,\n    &.ant-select-single .ant-select-selector .ant-select-selection-placeholder {\n        line-height: 43px;\n    }\n\n    &.ant-select:not(.ant-select-customize-input) .ant-select-selector {\n        border: 1px solid #e9e9e9;\n        border-radius: 4px;\n    }\n\n    .ant-select-selector .ant-select-selection-search-input {\n        height: 100%;\n        line-height: 43px;\n    }\n\n    &.ant-select.ant-select-enabled {\n        width: 100%;\n    }\n\n    .ant-select-selection.ant-select-selection--single {\n        border: 1px solid ${Pallete.dark50} !important;\n        width: 100%;\n        height: 46px;\n        border-radius: 4px;\n    }\n\n    .ant-select-selection__rendered {\n        height: 100%;\n        width: 100%;\n        display: flex;\n        align-items: center;\n\n        .ant-select-selection__placeholder {\n            font-size: 14px;\n            font-weight: normal;\n            font-stretch: normal;\n            text-align: left;\n            color: ${Pallete.dark60};\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n            }\n        }\n    }\n\n    .ant-select-selection-selected-value {\n        min-width: 50%;\n        font-size: 14px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.46;\n        text-align: left;\n        color: ${Pallete.dark100};\n\n        @media (max-width: 480px) {\n            font-size: 12px;\n        }\n    }\n\n    &.ant-select-disabled {\n        width: 100%;\n    }\n`;\n\nconst HalfWithmateSelect = styled(WithmateSelect)`\n    width: calc(50% - 4px);\n`;\n\nconst FlexWrapper = styled.div`\n    display: flex;\n    align-items: center;\n\n    ${props =>\n        props.withHalf\n            ? `\n        > div, p {\n            width: calc(50% - 4px) !important;\n            margin-right: 8px;\n        }\n    `\n            : ''}\n\n    > div:last-child {\n        margin-right: 0px;\n    }\n`;\n\nconst BorderFlexWrapper = styled(FlexWrapper)`\n    border: 1px solid ${Pallete.dark50};\n    border-radius: 4px;\n    overflow: hidden;\n\n    input.ant-input {\n        margin-bottom: 0px !important;\n        border: 0px !important;\n    }\n`;\n\nconst FlexDiv = styled.div`\n    width: calc(50% - 4px);\n`;\n\nconst StyledHotFix = styled.p`\n    font-size: 11px;\n    color: ${Pallete.blue100};\n    font-weight: normal;\n\n    margin-bottom: 4px;\n`;\n\nconst WithmateDatePicker = styled(DatePicker)`\n    &.ant-picker {\n        width: 100%;\n        height: 46px;\n        line-height: 43px;\n        border: 1px solid #e9e9e9;\n        padding: 0px;\n        padding-left: 11px;\n        padding-right: 11px;\n        border-radius: 4px;\n\n        > div {\n            height: 100%;\n        }\n\n        > div > input {\n            height: 100%;\n            font-size: 14px;\n            font-weight: normal;\n            font-stretch: normal;\n            font-style: normal;\n            line-height: 1.46;\n            text-align: left;\n            color: rgba(0, 0, 0, 0.7);\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n            }\n        }\n    }\n`;\n\nconst WithmateTimepicker = styled(TimePicker)`\n    &.ant-picker {\n        width: 100%;\n        height: 46px;\n        line-height: 43px;\n        border: 1px solid #e9e9e9;\n        padding: 0px;\n        padding-left: 11px;\n        padding-right: 11px;\n        border-radius: 4px;\n\n        > div {\n            height: 100%;\n        }\n\n        > div > input {\n            height: 100%;\n            font-size: 14px;\n            font-weight: normal;\n            font-stretch: normal;\n            font-style: normal;\n            line-height: 1.46;\n            text-align: left;\n            color: rgba(0, 0, 0, 0.7);\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n            }\n        }\n    }\n`;\n\nconst WithmateValue = styled.p`\n    margin-bottom: 4px;\n\n    font-size: 13px;\n    color: ${Pallete.blue50};\n    font-weight: bold;\n`;\n\nconst WithmateValueTip = styled.p`\n    margin-bottom: 0px;\n\n    font-size: 11px;\n    color: ${Pallete.dark60};\n    font-weight: normal;\n`;\n\nexport {\n    BorderDivisionLine,\n    WithamteInputWithButton,\n    DivisionLine,\n    WithmateLabel,\n    WithmateInput,\n    HalfWithmateInput,\n    WithmateTextarea,\n    WithmateSelect,\n    FlexWrapper,\n    FlexDiv,\n    HalfWithmateSelect,\n    StyledHotFix,\n    WithmateDatePicker,\n    WithmateValue,\n    WithmateValueTip,\n    WithmateTimepicker,\n};\n","import React from 'react';\nimport styled from 'styled-components';\n\nimport Pallete from '../../theme';\n\nconst FullWidthButton = styled.a`\n    display: block;\n    width: 100%;\n    height: 40px;\n    line-height: 40px;\n    border-radius: 4px;\n\n    cursor: pointer;\n\n    font-size: 13px;\n    font-weight: normal;\n    text-align: center;\n    font-weight: bold;\n\n    ${props =>\n        props.border\n            ? `\n        border: 1px solid ${Pallete.dark50};\n        color: ${Pallete.blue50}\n    `\n            : ''}\n\n    background-color: ${props => (props.bg ? props.bg : Pallete.blue50)};\n    color: #ffffff;\n`;\n\nconst HalfWidthButton = styled(FullWidthButton)`\n    width: calc(50% - 4px);\n`;\n\nconst RadiusFullWidthButton = styled(FullWidthButton)`\n    max-width: 280px;\n    height: 72px;\n    line-height: 72px;\n    border-radius: 50vh;\n\n    font-size: 22px;\n    font-weight: bold;\n    letter-spacing: -0.5px;\n`;\n\nconst RadiusHalfWidthButton = styled(RadiusFullWidthButton)`\n    max-width: calc(50% - 4px);\n    margin-right: 8px;\n\n    @media (max-width: 480px) {\n        width: 100%;\n        max-width: 280px;\n\n        height: 55px;\n        line-height: 55px;\n        font-size: 16px;\n        letter-spacing: -0.1px;\n\n        margin-right: 0px;\n        margin-bottom: 8px;\n    }\n`;\n\nconst ButtonWrapper = styled.div`\n    width: 100%;\n\n    display: flex;\n    align-items: center;\n\n    ${props =>\n        props.half\n            ? `\n        > a {\n            width: calc(50% - 4px);\n        }\n        > a:nth-child(1) {\n            margin-right: 8px;\n        }\n    `\n            : ''}\n`;\n\nexport { FullWidthButton, HalfWidthButton, ButtonWrapper, RadiusFullWidthButton, RadiusHalfWidthButton };\n","import React from 'react';\nimport { withRouter } from 'react-router';\nimport moment from 'moment';\nimport styled from 'styled-components';\nimport { Input } from 'antd';\n\nimport { DivisionLine } from '../Components/Common/input';\nimport { FullWidthButton } from '../Components/Common/button';\n\n// theme\nimport Pallete, { mainColor } from '../theme';\n\n// utils\nimport { serviceParser, getNextStatus, getTotal, currencyFormatter } from '../Lib/utils';\n\nexport default class Modal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        const now = moment().valueOf();\n        const begin = moment('20220923 180000').valueOf(); // 02. 24 ~\n        const end = moment('20220925 180000').valueOf(); // ~ 03. 31\n\n        if (now > begin && now < end) {\n            this.modalValidation();\n        }\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('modal') && typeof JSON.parse(localStorage.getItem('modal')) === 'object' && JSON.parse(localStorage.getItem('modal')) !== null\n                ? JSON.parse(localStorage.getItem('modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container\n                    id='event-popup'\n                    onClick={e => {\n                        if (e.target.id === 'event-popup') {\n                            this.onClose();\n                        }\n                    }}\n                >\n                    <ModalBlock\n                        onClick={e => {\n                            e.preventDefault();\n                        }}\n                    >\n                        <Top style={{ marginBottom: '16px' }}>\n                            <Title>서버 업데이트 대비 서버점검 안내</Title>\n                        </Top>\n                        <Bottom>\n                            <ContentRow>2022. 09. 23 더 편리한 서비스</ContentRow>\n                            <ContentRow>제공을 위헤 업데이트를 진행할 예정입니다.</ContentRow>\n                            <ContentRow>아래 명시한 기간동안 정상적인 서비스 이용에 어려움이</ContentRow>\n                            <ContentRow>있을수 있습니다. 성원에 보답하는 위드메이트가 되겠습니다.</ContentRow>\n\n                            <WarningRow>※ 서버점검 기간</WarningRow>\n                            <WarningContentRow>22. 09. 23 18:00 ~ 22. 09. 25 18:00</WarningContentRow>\n\n                            <div style={{ height: '8px' }} />\n                            <MessageRow>국민 모두 힘을 합치면 코로나 사태 극복 가능합니다.</MessageRow>\n                            <MessageRow>코로나19 극복, 위드메이트가 앞장서겠습니다.</MessageRow>\n                            {/* <BottomImage /> */}\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\nexport class RadiationModal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        // localStorage.clear();\n        // const now = moment().valueOf();\n        // const begin = moment('20200223 235959').valueOf(); // 02. 24 ~\n        // const end = moment('20200331 190000').valueOf(); // ~ 03. 31\n\n        // if (now > begin && now < end) {\n        //     this.modalValidation();\n        // }\n        this.modalValidation();\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('radiation-modal') &&\n            typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n            JSON.parse(localStorage.getItem('radiation-modal')) !== null\n                ? JSON.parse(localStorage.getItem('radiation-modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('radiation-modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container id='event-popup'>\n                    <ModalBlock>\n                        <Top>\n                            <Title>투석 & 방사선 치료 동행 서비스 안내</Title>\n                        </Top>\n                        <Bottom>\n                            <BottomImage />\n                            <ContentRow style={{ textAlign: 'center' }}>투석 & 방사선 치료 병원 동행 서비스가 필요하신 분들은</ContentRow>\n                            <ContentRow style={{ textAlign: 'center' }}>고객센터 전화를 통해 서비스 상담을 받으실 수 있습니다.</ContentRow>\n                            <MessageRow style={{ textAlign: 'center', cursor: 'pointer' }}>\n                                <a href='tel:070-4300-9075'>고객센터 번호 ☞ 070-4300-9075</a>\n                            </MessageRow>\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\n// class EventModal extends React.PureComponent {\n//     state = {\n//         modal: false,\n//     };\n\n//     componentDidMount = () => {\n//         this.modalValidation();\n//     };\n\n//     modalValidation = () => {\n//         const { lastTime } =\n//             localStorage.getItem('radiation-modal') &&\n//             typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n//             JSON.parse(localStorage.getItem('radiation-modal')) !== null\n//                 ? JSON.parse(localStorage.getItem('radiation-modal'))\n//                 : {\n//                       lastTime: moment().subtract('day', 1).toDate(),\n//                   };\n\n//         if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n//             this.setState({ modal: true });\n//         }\n//     };\n\n//     onClose = () => {\n//         localStorage.setItem('radiation-modal', null);\n//         this.setState({ modal: false });\n//     };\n\n//     onCloseToday = () => {\n//         localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n//         this.setState({ modal: false });\n//     };\n\n//     render() {\n//         if (this.state.modal) {\n//             return (\n//                 <Container id='event-popup'>\n//                     <ModalBlock>\n//                         <Top>\n//                             <Title>위드메이트, 이제 포항에서 만나보세요!</Title>\n//                         </Top>\n//                         <Bottom>\n//                             <BottomImage />\n//                             <ContentRow>\n//                                 위드메이트가 <span>한동대학교 ICT 창업팀</span>과 협력하여 포항시를 시작으로 경상권 정식 서비스를 시작합니다. 경상권 서비스 시작\n//                                 전, <span>포항시 대상 시범 서비스</span>와 <span>사전 수요 조사</span>가 진행됩니다. (회원 가입 완료 고객님 대상)\n//                             </ContentRow>\n//                             <br />\n//                             <ContentRow>\n//                                 서비스 신청 시 '자택 주소' 또는 '병원 주소'가 <span>'포항시'에 해당하는 모든 고객님께 30% 할인 혜택</span>이 적용되며, 설문에\n//                                 참여해주시는 모든 경상권 거주 고객님께 <span>20% 할인 쿠폰</span>과 추첨을 통한 <span>스타벅스 기프티콘</span>을 드립니다.{' '}\n//                             </ContentRow>\n\n//                             <div style={{ marginTop: '16px', marginBottom: '16px' }}>\n//                                 <MessageRow>\n//                                     <a\n//                                         onClick={() => {\n//                                             this.onClose();\n//                                             this.props.history.push('/user/register');\n//                                         }}\n//                                     >\n//                                         설문 전 회원가입 먼저 하기 {'>'}\n//                                     </a>\n//                                 </MessageRow>\n//                                 <MessageRow>\n//                                     <a\n//                                         href='https://docs.google.com/forms/d/e/1FAIpQLSfX6N8E0-fPVHXDFQN0iKUCjpZNP_cHl4e1kDRwEORk9NmtCw/viewform'\n//                                         target='_blank'\n//                                     >\n//                                         쿠폰(설문 조사) 링크 {'>'}\n//                                     </a>\n//                                 </MessageRow>\n//                             </div>\n\n//                             <ContentRow style={{ textIndent: '0px' }}>여러분의 소중한 지인에게 병원 동행 서비스를 알려주세요!</ContentRow>\n//                         </Bottom>\n//                         <EndBottom>\n//                             <CloseToday>\n//                                 <span onClick={this.onCloseToday}>\n//                                     <i className='fas fa-check' />\n//                                 </span>\n//                                 <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n//                             </CloseToday>\n//                             <CloseNow onClick={this.onClose}>닫기</CloseNow>\n//                         </EndBottom>\n//                     </ModalBlock>\n//                 </Container>\n//             );\n//         } else {\n//             return <></>;\n//         }\n//     }\n// }\n\nexport const MateReserveInfoModal = ({ visibleHandler, info, onCatch }) => {\n    const serviceType = !info.productInfo || !info.productInfo.usePro || !info.productInfo.useBasic ? '' : info.service === 'unemergency' ? 'Pro' : 'Basic';\n    const serviceName = (info.productInfo && info.productInfo.name && info.service && info.productInfo.name + serviceType) || '-';\n\n    return (\n        <Container>\n            <ModalBlock>\n                <ModalTitle>\n                    예약 상세내용\n                    <ModalCloseButtons onClick={visibleHandler} src='/assets/images/close.png' alt='close-button' />\n                </ModalTitle>\n                <ModalLabel>서비스명</ModalLabel>\n                <ModalInfo>{serviceName}</ModalInfo>\n                <ModalLabel>병원 진료 예약 시간</ModalLabel>\n                <ModalInfo>{moment(info.reserveDate).format('YYYY년 MM월 DD일, HH시 mm분')}</ModalInfo>\n                <ModalLabel>총 예상 소요 시간</ModalLabel>\n                <ModalInfo>{info.usageTime || 0}시간</ModalInfo>\n                {info && info.shortStarting ? (\n                    <>\n                        <ModalLabel>자택 주소</ModalLabel>\n                        <ModalInfo>{info.shortStarting}</ModalInfo>\n                    </>\n                ) : null}\n                <ModalLabel>병원 주소</ModalLabel>\n                <ModalInfo>{info.destination}</ModalInfo>\n                <ModalLabel>이동수단</ModalLabel>\n                <ModalInfo>\n                    {info.transport && info.transport === 'withcar'\n                        ? '차량 호출'\n                        : info.transport && info.transport === 'own'\n                        ? '본인소유 자차 이용'\n                        : '대중교통(택시 등) 이용'}\n                </ModalInfo>\n                <ModalLabel>예상 비용</ModalLabel>\n                <ModalInfo>\n                    {(info.transport && info.transport === 'own' ? 20000 : 0) +\n                        (info.productInfo &&\n                            info.service &&\n                            (info.service === 'unemergency' ? info.productInfo.proPrice : info.productInfo.basicPrice ? info.productInfo.basicPrice : 0) *\n                                info.usageTime)}\n                    원\n                </ModalInfo>\n\n                <WhiteButton onClick={onCatch}>예약 접수하기</WhiteButton>\n                <ModalFlexbox>\n                    <div>\n                        <ModalLabel>이용자 성함</ModalLabel>\n                        <ModalInfo>{info.patient}</ModalInfo>\n                    </div>\n                    <div>\n                        <ModalLabel style={{ paddingLeft: '0px' }}>이용자 성별</ModalLabel>\n                        <ModalInfo style={{ paddingLeft: '0px' }}>{info.sex}</ModalInfo>\n                    </div>\n                </ModalFlexbox>\n                <ModalFlexbox>\n                    <div>\n                        <ModalLabel>추가 요청 사항</ModalLabel>\n                        <ModalInfo style={{ marginBottom: '24px' }}>{info.comment || '-'}</ModalInfo>\n                    </div>\n                </ModalFlexbox>\n            </ModalBlock>\n        </Container>\n    );\n};\n\nexport const MateCallStatusModal = ({ visibleHandler, info, onNext }) => {\n    const serviceType = !info.productInfo || !info.productInfo.usePro || !info.productInfo.useBasic ? '' : info.service === 'unemergency' ? 'Pro' : 'Basic';\n    const serviceName = (info.productInfo && info.productInfo.name && info.service && info.productInfo.name + serviceType) || '-';\n\n    return (\n        <Container>\n            <ModalBlock>\n                <ModalTitle>\n                    예약 상세내용 및 관리\n                    <ModalCloseButtons onClick={visibleHandler} src='/assets/images/close.png' alt='close-button' />\n                </ModalTitle>\n                <ModalLabel>서비스 명</ModalLabel>\n                <ModalInfo>{serviceName}</ModalInfo>\n                <ModalLabel>병원 진료 예약 시간</ModalLabel>\n                <ModalInfo>{moment(info.reserveDate).format('YYYY년 MM월 DD일, HH시 mm분')}</ModalInfo>\n                <ModalLabel>총 예상 소요 시간</ModalLabel>\n                <ModalInfo>{info.usageTime || 0}시간</ModalInfo>\n                <ModalLabel>병원 주소</ModalLabel>\n                <ModalInfo>{info.destination}</ModalInfo>\n                {info.service === 'unemergency' && (\n                    <>\n                        <ModalLabel>이동 수단</ModalLabel>\n                        <ModalInfo>{info.transport === 'own' ? '자차 이용' : info.transport === 'common' ? '대중교통' : '-'}</ModalInfo>\n                    </>\n                )}\n                {info && info.starting && (\n                    <>\n                        <ModalLabel>자택 주소</ModalLabel>\n                        <ModalInfo>{info.starting}</ModalInfo>\n                    </>\n                )}\n                {info.call && info.call.status !== '예약접수' && (\n                    <>\n                        <ModalFlexbox>\n                            <div>\n                                <ModalLabel>이용자 성함</ModalLabel>\n                                <ModalInfo>{info.patient}</ModalInfo>\n                            </div>\n                            <div>\n                                <ModalLabel style={{ paddingLeft: '0px' }}>이용자 성별</ModalLabel>\n                                <ModalInfo style={{ paddingLeft: '0px' }}>{info.sex}</ModalInfo>\n                            </div>\n                        </ModalFlexbox>\n                        <ModalLabel>이용자 연락처</ModalLabel>\n                        <ModalInfo>{info.contact}</ModalInfo>\n\n                        {/* <ModalLabel>보호자 연락처</ModalLabel>\n                        <ModalInfo>{(info.buyer && info.buyer.contact) || '-'}</ModalInfo> */}\n                    </>\n                )}\n\n                <ModalLabel>추가 요청 사항</ModalLabel>\n                <ModalInfo style={{ marginBottom: '24px' }}>{info.comment || '-'}</ModalInfo>\n\n                {info.call && info.call.status !== '서비스 종료' && info.call.status !== '예약접수' && (\n                    <WhiteButton onClick={onNext}>{getNextStatus(info.service, info.call.status)}</WhiteButton>\n                )}\n                {info.call && info.call.status === '서비스 종료' && <WhiteButton onClick={onNext}>서비스 리포트 작성</WhiteButton>}\n\n                <BlueButton style={{ marginBottom: '24px' }} onClick={visibleHandler}>\n                    닫기\n                </BlueButton>\n            </ModalBlock>\n        </Container>\n    );\n};\n\nexport const UserServiceReportModal = ({ visibleHandler, info, service, onMateInfo }) => {\n    const { timeline } = info;\n\n    return (\n        <Container>\n            <ModalBlock>\n                <ModalTitle>\n                    서비스 리포트\n                    <ModalCloseButtons onClick={visibleHandler} src='/assets/images/close.png' alt='close-button' />\n                </ModalTitle>\n                <ModalLabel>타임라인</ModalLabel>\n                {service === 'happycare' ? (\n                    <ModalInfo>\n                        {timeline.receipt ? <p>{`고객님과 메이트가 ${moment(timeline.receipt.time).format('HH시 mm분')}에 만났습니다.`}</p> : ''}\n                        {timeline.careStart ? <p>{`${moment(timeline.careStart.time).format('HH시 mm분')}에 진료를 시작하였고,`}</p> : ''}\n                        {timeline.careDone ? (\n                            <p>{`${moment(timeline.careDone.time).diff(moment(timeline.careStart.time), 'minute')}분 동안 진료를 봤습니다.`}</p>\n                        ) : (\n                            ''\n                        )}\n                        {timeline.complete ? <p>{`${moment(timeline.complete.time).format('HH시 mm분')}에 고객님과의 동행 서비스가 종료되었습니다.`}</p> : ''}\n                    </ModalInfo>\n                ) : null}\n                {service === 'assist' ? (\n                    <ModalInfo>\n                        {timeline.arrived ? <p>{`메이트가 ${moment(timeline.arrived.time).format('MM월 DD일, HH시 mm분')}에 병원에 도착하였습니다.`}</p> : ''}\n                        {timeline.receipt ? <p>{`고객님과는 ${moment(timeline.receipt.time).format('HH시 mm분')}에 만났습니다.`}</p> : ''}\n                        {timeline.careStart ? <p>{`${moment(timeline.careStart.time).format('HH시 mm분')}에 진료를 시작하였고,`}</p> : ''}\n                        {timeline.careDone ? (\n                            <p>{`${moment(timeline.careDone.time).diff(moment(timeline.careStart.time), 'minute')}분 동안 진료를 봤습니다.`}</p>\n                        ) : (\n                            ''\n                        )}\n                        {timeline.complete ? <p>{`${moment(timeline.complete.time).format('HH시 mm분')}에 고객님과의 동행 서비스가 종료되었습니다.`}</p> : ''}\n                    </ModalInfo>\n                ) : null}\n                {service === 'unemergency' ? (\n                    <ModalInfo>\n                        {timeline.receipt ? <p>{`메이트가 고객님과 ${moment(timeline.receipt.time).format('MM월 DD일, HH시 mm분')}에 만났습니다.`}</p> : ''}\n                        {timeline.start ? <p>{`병원으로 ${moment(timeline.start.time).format('HH시 mm분')}에 출발하였습니다.`}</p> : ''}\n                        {timeline.arrived ? <p>{`그리고 ${moment(timeline.arrived.time).format('HH시 mm분')}에 병원에 도착하였습니다.`}</p> : ''}\n                        {timeline.careStart ? <p>{`${moment(timeline.careStart.time).format('HH시 mm분')}에 진료를 시작하였고,`}</p> : ''}\n                        {timeline.careDone ? (\n                            <p>{`${moment(timeline.careDone.time).diff(moment(timeline.careStart.time), 'minute')}분 동안 진료를 봤습니다.`}</p>\n                        ) : (\n                            ''\n                        )}\n                        {timeline.backStart ? <p>{`진료 후 ${moment(timeline.backStart.time).format('HH시 mm분')}에 자택으로 출발했습니다.`}</p> : ''}\n                        {timeline.complete ? <p>{`${moment(timeline.complete.time).format('HH시 mm분')}에 고객님과의 동행 서비스가 종료되었습니다.`}</p> : ''}\n                    </ModalInfo>\n                ) : null}\n                <ModalLabel>{info.mate[0].name} 메이트 리포트</ModalLabel>\n\n                <ModalInfo style={{ overflow: 'hidden' }}>{info.report || '담당 메이트가 아직 리포트를 작성중입니다.'}</ModalInfo>\n\n                <FullWidthButton bg={Pallete.dark70} onClick={onMateInfo} style={{ marginBottom: '24px', width: '90%', margin: '0 auto' }}>\n                    담당 메이트 정보\n                </FullWidthButton>\n                <DivisionLine small />\n                <FullWidthButton bg={Pallete.blue50} onClick={visibleHandler} style={{ marginBottom: '24px', width: '90%', margin: '0 auto' }}>\n                    닫기\n                </FullWidthButton>\n                <DivisionLine small />\n            </ModalBlock>\n        </Container>\n    );\n};\n\nexport const HandleReportModal = ({ visibleHandler, onHandleReport, inputHandler, desc }) => {\n    return (\n        <Container>\n            <ModalBlock>\n                <ModalTitle>\n                    서비스 리포트 작성\n                    <ModalCloseButtons onClick={visibleHandler} src='/assets/images/close.png' alt='close-button' />\n                </ModalTitle>\n\n                <ModalLabel>서비스 수행 및 진료내용 {desc && desc.length > 0 ? `(글자수 - ${desc.length}자)` : ''}</ModalLabel>\n                <ModalPaddingBlock>\n                    <Input.TextArea\n                        rows={6}\n                        placleholder='서비스 수행중 있었던 특이사항이나 진료내용 등을 입력해주세요.'\n                        maxLength={600}\n                        onChange={ev => {\n                            inputHandler({ type: 'report', value: ev.target.value });\n                        }}\n                    />\n                </ModalPaddingBlock>\n                <WhiteButton onClick={onHandleReport}>리포트 등록</WhiteButton>\n                <BlueButton onClick={visibleHandler} style={{ marginBottom: '24px' }}>\n                    닫기\n                </BlueButton>\n            </ModalBlock>\n        </Container>\n    );\n};\n\nexport const ShareCarRequestModal = ({ visibleHandler, inputHandler, onSave, data }) => {\n    return (\n        <Container>\n            <ModalLargeBlock>\n                <ModalTitle>\n                    셔틀 셰어링 신청\n                    <ModalCloseButtons onClick={visibleHandler} src='/assets/images/close.png' alt='close-button' />\n                </ModalTitle>\n\n                <FlexWrapper>\n                    <FlexBox>\n                        <p className='label'>기관명</p>\n                        <Input\n                            type='text'\n                            placeholder='ex. 한빛 요양원'\n                            value={data.corp}\n                            onChange={ev => {\n                                if (ev.target.value.length >= 20) return null;\n\n                                inputHandler({ type: 'corp', value: ev.target.value });\n                            }}\n                        />\n                    </FlexBox>\n                    <FlexBox>\n                        <p className='label'>지역</p>\n                        <Input\n                            type='text'\n                            placeholder='ex. 경기도 수원시'\n                            value={data.address}\n                            onChange={ev => {\n                                if (ev.target.value.length >= 20) return null;\n\n                                inputHandler({ type: 'address', value: ev.target.value });\n                            }}\n                        />\n                    </FlexBox>\n                </FlexWrapper>\n\n                <FlexWrapper>\n                    <FlexBox>\n                        <p className='label'>담당자</p>\n                        <Input\n                            type='text'\n                            placeholder='ex. 홍길동'\n                            value={data.manager}\n                            onChange={ev => {\n                                if (ev.target.value.length >= 20) return null;\n\n                                inputHandler({ type: 'manager', value: ev.target.value });\n                            }}\n                        />\n                    </FlexBox>\n                    <FlexBox>\n                        <p className='label'>전화번호</p>\n                        <Input\n                            type='number'\n                            placeholder='ex. 01012349876'\n                            value={data.contact}\n                            onChange={ev => {\n                                if (ev.target.value.length >= 13) return null;\n\n                                inputHandler({ type: 'contact', value: ev.target.value });\n                            }}\n                        />\n                    </FlexBox>\n                </FlexWrapper>\n\n                <FlexWrapper>\n                    <FlexFullBox>\n                        <p className='label'>기타 문의 및 전달사항</p>\n                        <Input.TextArea\n                            type='text'\n                            placeholder='위드메이트 관리자에게 전달할 메시지를 입력해주세요.'\n                            value={data.message}\n                            onChange={ev => {\n                                if (ev.target.value.length > 150) return null;\n\n                                inputHandler({ type: 'message', value: ev.target.value });\n                            }}\n                        />\n                    </FlexFullBox>\n                </FlexWrapper>\n\n                <BlueButton onClick={onSave} style={{ marginBottom: '24px' }}>\n                    접수하기\n                </BlueButton>\n            </ModalLargeBlock>\n        </Container>\n    );\n};\n\nexport const EmergencyCorpSearchModal = ({ visibleHandler, inputHandler, keyword = '', data = [] }) => {\n    return (\n        <Container>\n            <ModalLargeBlock>\n                <ModalTitle>\n                    사설 구급업체 검색\n                    <ModalCloseButtons onClick={visibleHandler} src='/assets/images/close.png' alt='close-button' />\n                </ModalTitle>\n\n                <FlexWrapper>\n                    <FlexFullBox>\n                        <p className='label'>지역 검색</p>\n                        <Input\n                            placeholder='ex. 경기, 대구, 부산'\n                            value={keyword}\n                            onChange={ev => {\n                                if (ev.target.value.length > 10) return null;\n\n                                inputHandler(ev.target.value);\n                            }}\n                        />\n                    </FlexFullBox>\n                </FlexWrapper>\n\n                <FlexWrapper>\n                    <FlexFullBox>\n                        <p className='label'>검색결과</p>\n                        <TableWrapper>\n                            <TableHeaderWrapper>\n                                <FlexColumn>\n                                    <span className='title'>시도 / 시군구</span>\n                                </FlexColumn>\n                                <FlexColumn>\n                                    <span className='title'>기관명</span>\n                                </FlexColumn>\n                                <FlexColumn>\n                                    <span className='title'>대표번호</span>\n                                </FlexColumn>\n                            </TableHeaderWrapper>\n                            {data && data.length > 0 ? (\n                                data\n                                    .filter(\n                                        item =>\n                                            (item.addr1 && item.addr1.includes(keyword)) ||\n                                            (item.addr2 && item.addr2.includes(keyword)) ||\n                                            (item.name && item.name.includes(keyword)) ||\n                                            (item.contact && item.contact.includes(keyword)),\n                                    )\n                                    .map((item, index) => (\n                                        <TableRowWrapper key={'emergency-corporation-item-' + index.toString()}>\n                                            <FlexColumn>\n                                                <span className='value'>{item.addr1 + ' ' + item.addr2}</span>\n                                            </FlexColumn>\n                                            <FlexColumn>\n                                                <span className='value'>{item.name}</span>\n                                            </FlexColumn>\n                                            <FlexColumn>\n                                                <span className='value'>{item.contact}</span>\n                                            </FlexColumn>\n                                        </TableRowWrapper>\n                                    ))\n                            ) : (\n                                <EmptyTable />\n                            )}\n                        </TableWrapper>\n                    </FlexFullBox>\n                </FlexWrapper>\n\n                <BlueButton onClick={visibleHandler} style={{ marginBottom: '24px' }}>\n                    확인\n                </BlueButton>\n            </ModalLargeBlock>\n        </Container>\n    );\n};\n\nclass CardModal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        this.modalValidation();\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('radiation-modal') &&\n            typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n            JSON.parse(localStorage.getItem('radiation-modal')) !== null\n                ? JSON.parse(localStorage.getItem('radiation-modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('radiation-modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container id='event-popup'>\n                    <ModalBlock>\n                        <Top>\n                            <Title>카드결제 안내</Title>\n                        </Top>\n                        <Bottom>\n                            <div style={{ display: 'flex', justifyContent: 'center', paddingTop: '10px' }}>\n                                <img src='/assets/images/popup_img/withmate_card.png' style={{ width: '400px', height: 'auto' }} />\n                                {/* <PopupImage /> */}\n                            </div>\n                            <div style={{ marginTop: '15px' }}>\n                                <MessageRow>\n                                    <a\n                                        onClick={() => {\n                                            this.onClose();\n                                            this.props.history.push('/user/mypage/info');\n                                        }}\n                                    >\n                                        결제카드 등록하기 {'>'}\n                                    </a>\n                                </MessageRow>\n                                {/* <MessageRow>\n                                    <a\n                                        href='https://docs.google.com/forms/d/e/1FAIpQLSfX6N8E0-fPVHXDFQN0iKUCjpZNP_cHl4e1kDRwEORk9NmtCw/viewform'\n                                        target='_blank'\n                                    >\n                                        쿠폰(설문 조사) 링크 {'>'}\n                                    </a>\n                                </MessageRow> */}\n                            </div>\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\nclass ManagerModal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        this.modalValidation();\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('radiation-modal') &&\n            typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n            JSON.parse(localStorage.getItem('radiation-modal')) !== null\n                ? JSON.parse(localStorage.getItem('radiation-modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('radiation-modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container id='event-popup'>\n                    <ModalBlock>\n                        {/* <Top>\n                            <Title>위드메이트 X 국립암센터 암특화 병원동행 매니저 자격과정 모집</Title>\n                        </Top> */}\n                        <Bottom>\n                            <div style={{ display: 'flex', justifyContent: 'center', paddingTop: '10px' }}>\n                                <img src='/assets/images/popup_img/withmate_manager.png' style={{ width: '300px', height: 'auto' }} />\n                                {/* <PopupImage /> */}\n                            </div>\n                            <div style={{ marginTop: '10px' }}>\n                                <MessageRow>\n                                    <a\n                                        onClick={() => {\n                                            this.onClose();\n                                            this.props.history.push({\n                                                pathname: `/newsEvent/info/63d9f951397216d7ff7672a8`,\n                                                state: { id: '63d9f951397216d7ff7672a8' },\n                                            });\n                                        }}\n                                    >\n                                        자세히 보기 {'>'}\n                                    </a>\n                                </MessageRow>\n                                {/* <MessageRow>\n                                    <a\n                                        href='https://docs.google.com/forms/d/e/1FAIpQLSfX6N8E0-fPVHXDFQN0iKUCjpZNP_cHl4e1kDRwEORk9NmtCw/viewform'\n                                        target='_blank'\n                                    >\n                                        쿠폰(설문 조사) 링크 {'>'}\n                                    </a>\n                                </MessageRow> */}\n                            </div>\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\nclass EventModal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        this.modalValidation();\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('radiation-modal') &&\n            typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n            JSON.parse(localStorage.getItem('radiation-modal')) !== null\n                ? JSON.parse(localStorage.getItem('radiation-modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('radiation-modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container id='event-popup'>\n                    <ModalBlock>\n                        {/* <Top>\n                            <Title>위드메이트 X 국립암센터 암특화 병원동행 매니저 자격과정 모집</Title>\n                        </Top> */}\n                        <Bottom>\n                            <div style={{ display: 'flex', justifyContent: 'center', paddingTop: '20px' }}>\n                                <img src='/assets/images/popup_img/event_img.png' style={{ width: '400px', height: 'auto' }} />\n                                {/* <PopupImage /> */}\n                            </div>\n                            <div style={{ marginTop: '10px' }}>\n                                <MessageRow>\n                                    <a\n                                        onClick={() => {\n                                            this.onClose();\n                                            this.props.history.push({\n                                                pathname: `/newsEvent/info/645dc777f0316a44d06a1fdb`,\n                                                state: { id: '645dc777f0316a44d06a1fdb' },\n                                            });\n                                        }}\n                                    >\n                                        자세히 보기 {'>'}\n                                    </a>\n                                </MessageRow>\n                            </div>\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\nclass NoticeModal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        this.modalValidation();\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('radiation-modal') &&\n            typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n            JSON.parse(localStorage.getItem('radiation-modal')) !== null\n                ? JSON.parse(localStorage.getItem('radiation-modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('radiation-modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    onCloseToday2 = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container id='event-popup'>\n                    <ModalBlock>\n                        <Top>\n                            <Title>서버오류로 인한 데이터 복구작업 안내</Title>\n                        </Top>\n                        <Bottom>\n                            <ContentRow>\n                                <br />\n                                <div style={{ fontSize: '16px', textAlign: 'center' }}>\n                                    서버 오류가 발생하여 손실된 데이터 복구작업 진행중입니다.\n                                    <br />\n                                    이에 관련하여 문의사항은 고객센터로 연락을 주시면 <br />\n                                    빠르게 해결해드리겠습니다.\n                                    <br />\n                                    위드메이트를 이용하시는데 불편을 드려 죄송합니다.\n                                    <br />\n                                    <br />\n                                    <br />\n                                    <b>\n                                        ⏰ 운영시간 : 오전 9시 - 오후 6시 (토·일 제외)\n                                        <br />\n                                        👩🏻‍💻 문의방법 : 채널톡 및 카카오톡 혹은 전화(070-4300-9075)\n                                    </b>\n                                </div>\n                            </ContentRow>\n                            <div style={{ marginTop: '15px' }}>\n                                <MessageRow>\n                                    {/* <a\n                                        onClick={() => {\n                                            this.onClose();\n                                            this.props.history.push(\n                                                {\n                                                    pathname: `/newsEvent/info/63c0ec49fe7889400f150b97`,\n                                                    state: { id: '63c0ec49fe7889400f150b97' },\n                                                });\n                                        }}\n                                    >\n                                        자세히 보기 {'>'}\n                                    </a> */}\n                                </MessageRow>\n                            </div>\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday2}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday2}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\nclass MetlifeModal extends React.PureComponent {\n    state = {\n        modal: false,\n    };\n\n    componentDidMount = () => {\n        this.modalValidation();\n    };\n\n    modalValidation = () => {\n        const { lastTime } =\n            localStorage.getItem('radiation-modal') &&\n            typeof JSON.parse(localStorage.getItem('radiation-modal')) === 'object' &&\n            JSON.parse(localStorage.getItem('radiation-modal')) !== null\n                ? JSON.parse(localStorage.getItem('radiation-modal'))\n                : {\n                      lastTime: moment().subtract('day', 1).toDate(),\n                  };\n\n        if (!lastTime || moment(lastTime).format('YYYY-MM-DD') !== moment().format('YYYY-MM-DD')) {\n            this.setState({ modal: true });\n        }\n    };\n\n    onClose = () => {\n        localStorage.setItem('radiation-modal', null);\n        this.setState({ modal: false });\n    };\n\n    onCloseToday = () => {\n        localStorage.setItem('radiation-modal', JSON.stringify({ lastTime: moment().toDate() }));\n        this.setState({ modal: false });\n    };\n\n    render() {\n        if (this.state.modal) {\n            return (\n                <Container id='event-popup'>\n                    <ModalBlock>\n                        {/* <Top>\n                            <Title>위드메이트 X 국립암센터 암특화 병원동행 매니저 자격과정 모집</Title>\n                        </Top> */}\n                        <Bottom>\n                            <div style={{ display: 'flex', justifyContent: 'center', paddingTop: '20px' }}>\n                                <img src='/assets/images/popup_img/metlife_popup.png' style={{ width: '400px', height: 'auto' }} />\n                                {/* <PopupImage /> */}\n                            </div>\n                            <div style={{ marginTop: '10px' }}>\n                                <MessageRow>\n                                    <a\n                                        onClick={() => {\n                                            this.onClose();\n                                            this.props.history.push('/360F/nemt/service/#types');\n                                        }}\n                                    >\n                                        서비스 종류 보기 {'>'}\n                                    </a>\n                                </MessageRow>\n                            </div>\n                        </Bottom>\n                        <EndBottom>\n                            <CloseToday>\n                                <span onClick={this.onCloseToday}>\n                                    <i className='fas fa-check' />\n                                </span>\n                                <span onClick={this.onCloseToday}>오늘은 그만보기</span>\n                            </CloseToday>\n                            <CloseNow onClick={this.onClose}>닫기</CloseNow>\n                        </EndBottom>\n                    </ModalBlock>\n                </Container>\n            );\n        } else {\n            return <></>;\n        }\n    }\n}\n\nexport const CustomModal = ({ children }) => {\n    return <CustomContaienr>{children}</CustomContaienr>;\n};\n\nconst TableWrapper = styled.div`\n    border: 1px solid #e6e6e6;\n    border-radius: 4px;\n\n    overflow-x: hidden;\n    overflow-y: scroll;\n\n    margin-bottom: 30px;\n`;\n\nconst TableHeaderWrapper = styled.div`\n    border-bottom: 1px solid #e6e6e6;\n    padding: 6px 22px;\n\n    display: flex;\n`;\n\nconst TableRowWrapper = styled.div`\n    border-bottom: 1px solid #e6e6e6;\n    padding: 9.5px 22px;\n\n    display: flex;\n`;\n\nconst EmptyTable = styled.div`\n    height: 100px;\n`;\n\nconst FlexColumn = styled.div`\n    flex: 1;\n\n    text-align: left;\n\n    > span.title {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 10px;\n        line-height: 18px;\n\n        letter-spacing: -0.2px;\n        color: rgba(0, 0, 0, 0.4);\n    }\n\n    > span.value {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 14px;\n        line-height: 28px;\n\n        letter-spacing: -0.2625px;\n        color: rgba(0, 0, 0, 0.8);\n    }\n`;\n\nconst FlexWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        width: 100%;\n    }\n`;\n\nconst FlexBox = styled.div`\n    flex: 1;\n\n    width: calc(50% - 10px);\n\n    &:first-child {\n        margin-right: 20px;\n    }\n\n    > p.label {\n        margin-bottom: 4px;\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 11px;\n        line-height: 18px;\n\n        color: #a7a7a7;\n    }\n\n    > input {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 14px;\n\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.8);\n\n        margin-bottom: 20px;\n\n        height: 40px;\n        line-height: 40px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n\n        &:first-child {\n            margin-right: 0px;\n        }\n    }\n`;\n\nconst FlexFullBox = styled(FlexBox)`\n    width: 100%;\n\n    &:first-child {\n        margin-right: 0px;\n    }\n\n    > input {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 14px;\n\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.8);\n\n        margin-bottom: 20px;\n\n        height: 40px;\n        line-height: 40px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n\n    > textarea.ant-input {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 14px;\n\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.8);\n\n        margin-bottom: 20px;\n\n        height: 100px;\n        line-height: 20px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n`;\n\nexport const EventPopup = withRouter(EventModal);\nexport const ManagerPopup = withRouter(ManagerModal);\nexport const CardPopup = withRouter(CardModal);\nexport const NoticePopup = withRouter(NoticeModal);\nexport const MetlifePopup = withRouter(MetlifeModal);\n\nconst Container = styled.div`\n    position: fixed;\n    left: 0px;\n    top: 0px;\n    z-index: 100;\n    display: flex;\n    width: 100vw;\n    height: 100vh;\n    align-items: center;\n    justify-content: center;\n    background-color: rgba(0, 0, 0, 0.6);\n\n    @media (max-width: 768px) {\n        padding-left: 16px;\n        padding-right: 16px;\n        overflow: hidden;\n    }\n`;\n\nconst CustomContaienr = styled(Container)`\n    @media (max-width: 768px) {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n`;\n\nconst ModalBlock = styled.div`\n    margin-top: -46px;\n    // margin-right: 400px;\n    width: 100%;\n    min-width: 430px;\n    max-width: 450px;\n    max-height: 90%;\n    overflow-y: scroll;\n    ::-webkit-scrollbar {\n        display: none;\n    }\n\n    background-color: #fdfdfd;\n    border-radius: 4px;\n\n    @media (max-width: 768px) {\n        min-width: auto;\n        max-width: 380px;\n        margin-right: 0px;\n    }\n`;\n\nconst ModalBlock2 = styled.div`\n    margin-top: -46px;\n    margin-left: 600px;\n    width: 100%;\n    min-width: 430px;\n    max-width: 450px;\n    max-height: 90%;\n    overflow-y: scroll;\n    ::-webkit-scrollbar {\n        display: none;\n    }\n\n    background-color: #fdfdfd;\n    border-radius: 4px;\n\n    @media (max-width: 768px) {\n        min-width: auto;\n        max-width: 380px;\n        margin-left: 0px;\n    }\n`;\n\nconst ModalLargeBlock = styled(ModalBlock)`\n    max-width: 740px;\n    padding: 32px;\n\n    @media (max-width: 1120px) {\n        max-width: 540px;\n    }\n\n    @media (max-width: 768px) {\n        max-width: 440px;\n    }\n\n    @media (max-width: 430px) {\n        max-width: 380;\n    }\n`;\n\nconst ModalTitle = styled.div`\n    font-size: 18px;\n    font-weight: bold;\n    text-align: center;\n    letter-spacing: 0.03px;\n    color: rgba(0, 0, 0, 0.87);\n\n    position: relative;\n\n    margin-top: 24px;\n    margin-bottom: 24px;\n`;\n\nconst ModalFlexbox = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    > div {\n        flex: 1;\n    }\n`;\n\nconst ModalCloseButtons = styled.img`\n    position: absolute;\n    top: 0px;\n    right: 24px;\n\n    display: inline-block;\n    width: 18px;\n    height: 18px;\n\n    cursor: pointer;\n`;\n\nconst ModalLabel = styled.p`\n    font-size: 12px;\n    color: #b6b6b6;\n    margin-bottom: 4px;\n    font-weight: bold;\n\n    padding-left: 32px;\n    padding-right: 32px;\n`;\n\nconst ModalPaddingBlock = styled.div`\n    padding-left: 32px;\n    padding-right: 32px;\n\n    margin-bottom: 24px;\n`;\n\nconst ModalInfo = styled.p`\n    font-size: 13px;\n    color: #565656;\n    margin-bottom: 12px;\n    font-weight: bold;\n\n    padding-left: 32px;\n    padding-right: 32px;\n`;\n\nconst WhiteButton = styled.div`\n    width: 100%;\n    max-width: calc(100% - 64px);\n    height: 40px;\n    line-height: 40px;\n\n    border-radius: 16px;\n\n    border: 1px solid ${mainColor};\n    color: ${mainColor}\n\n    font-size: 13px;\n    text-align: center;\n\n    margin: 0 auto;\n    margin-bottom: 24px;\n\n    cursor: pointer;\n    &:hover {\n        transition: all 0.5s;\n        background-color: ${mainColor};\n        color: white;\n    }\n`;\n\nconst BlueButton = styled.div`\n    \n    width: calc(100% - 64px);\n    max-width: 360px;\n    height: 40px;\n    line-height: 40px;\n\n    border-radius: 16px;\n\n    background-color: ${mainColor};\n    color: #ffffff\n\n    font-size: 13px;\n    text-align: center;\n\n    margin: 0 auto;\n\n    cursor: pointer;\n    &:hover {\n        transition: all 0.5s;\n        opacity: 0.85;\n    }\n`;\n\nconst Top = styled.div`\n    // border-bottom: 3px solid ${mainColor};\n\n    height: 42px;\n    line-height: 42px;\n    border-bottom: 2px solid #e9e9e9;\n`;\n\nconst Title = styled.p`\n    font-size: 18px;\n    font-weight: bold;\n    text-align: center;\n    letter-spacing: 0.03px;\n    color: rgba(0, 0, 0, 0.87);\n    margin: 0px;\n`;\n\nconst Bottom = styled.div`\n    position: relative;\n    // padding-top: 20px;\n    padding-bottom: 20px;\n`;\n\nconst BottomImage = styled.div`\n    // position: absolute;\n    // width: 100%;\n    // height: 100%;\n    // top: 0px;\n    // left: 0px;\n\n    width: 100%;\n    height: 170px;\n    opacity: 0.86;\n\n    margin-bottom: 10px;\n\n    background-image: url('/assets/images/main_logo.png');\n    background-size: contain;\n    background-repeat: no-repeat;\n    background-position: center;\n`;\n\nconst PopupImage = styled.div`\n    // position: absolute;\n    // width: 100%;\n    // height: 100%;\n    // top: 0px;\n    // left: 0px;\n\n    width: 100%;\n    height: 170px;\n    opacity: 0.86;\n\n    margin-bottom: 10px;\n\n    background-image: url('/assets/images/icons/manager.png');\n    background-size: contain;\n    background-repeat: no-repeat;\n    background-position: center;\n`;\n\nconst ContentRow = styled.p`\n    // font-weight: 600;\n    margin: 0px;\n    font-size: 12px;\n    color: rgba(0, 0, 0, 0.7);\n    margin-bottom: 2px;\n    padding: 0px 16px;\n    text-indent: 4px;\n\n    word-break: keep-all;\n\n    > span {\n        color: ${Pallete.blue100};\n        font-weight: bold;\n    }\n`;\n\nconst WarningRow = styled.p`\n    font-size: 13px;\n    font-weight: 600;\n    color: red;\n    padding: 0px 16px;\n    margin-top: 8px;\n`;\n\nconst WarningContentRow = styled.p`\n    font-size: 13px;\n    color: rgba(0, 0, 0, 0.7);\n    // font-weight: bold;\n    padding: 0px 16px;\n`;\n\nconst EndBottom = styled.div`\n    padding: 6px 16px;\n    display: flex;\n    align-items: center;\n    border-top: 1px solid #e6e6e6;\n    background-color: #f5f5f5;\n`;\n\nconst CloseToday = styled.p`\n    flex: 1;\n\n    > span {\n        font-size: 13px;\n        margin-right: 4px;\n        cursor: pointer;\n    }\n\n    > span:last-child {\n        font-size: 13px;\n        color: rgba(0, 0, 0, 0.4);\n        cursor: pointer;\n    }\n`;\n\nconst CloseNow = styled.p`\n    font-size: 13px;\n    color: rgba(0, 0, 0, 0.4);\n    cursor: pointer;\n`;\n\nconst MessageRow = styled.p`\n    font-size: 13px;\n    font-weight: bold;\n    color: #6e82d6;\n    padding: 0px 16px;\n\n    word-break: keep-all;\n\n    a,\n    span {\n        text-decoration: none;\n        font-size: 12px;\n        font-weight: bold;\n        color: #6e82d6;\n    }\n\n    // color: ${mainColor};\n`;\n\nconst Info = styled.p`\n    font-size: 12px;\n    fong-weight: bold;\n    // margin-top: 16px;\n    color: rgba(0, 0, 0, 0.6);\n    padding: 0px 16px;\n`;\n","import React from 'react';\nimport moment from 'moment';\nimport PropTypes from 'prop-types';\nimport { debounce } from 'lodash';\nimport styled from 'styled-components';\nimport { Button, message, Spin } from 'antd';\nimport _ from 'lodash';\n\n// components\nimport { NoCatchedList } from '../../../Components/User/Mate/reserve';\nimport { MateReserveInfoModal } from '../../../Components/modal';\n\n// utils\nimport { UNEMER } from '../../../Lib/variables';\nimport axios from '../../../Lib/axios';\n\nclass Reserve extends React.PureComponent {\n    state = {\n        reserveModal: false,\n        reserveInfo: null,\n        refreshing: false,\n        list: [],\n    };\n\n    componentDidMount = () => {\n        this.fetchList();\n    };\n\n    fetchList = debounce(() => {\n        const mateId = localStorage.getItem('id');\n\n        this.setState(\n            {\n                refreshing: true,\n            },\n            () => {\n                axios\n                    .get('/v2/service/mate/reserve/list', {\n                        params: {\n                            mateId,\n                        },\n                    })\n                    .then(resolve => {\n                        const { data: list } = resolve;\n                        if (list && Array.isArray(list)) {\n                            this.setState({ list, refreshing: false });\n                        }\n                    })\n                    .catch(error => {\n                        this.setState({ refreshing: false });\n                    });\n            },\n        );\n    }, 300);\n\n    onCatchCall = () => {\n        const { reserveInfo } = this.state;\n        const { id } = this.props.auth;\n\n        if (!reserveInfo || !reserveInfo.call || !reserveInfo.call._id) {\n            this.setState({ reserveInfo: null, reserveModal: false });\n            message.warning('유효하지않은 예약내역입니다. 다른 예약내역을 확인해주세요.');\n            return null;\n        }\n\n        axios\n            .put('/v2/service/catch/call', {\n                callId: reserveInfo.call._id,\n                mateId: id,\n            })\n            .then(resolve => {\n                const { data: result } = resolve;\n                if (!result) return message.warning('요청에 실패했습니다.');\n                if (result === 'invalid call') return message.warning('잘못된 요청입니다.');\n                if (result === 'already catched') return message.warning('이미 접수된 요청입니다.');\n                if (result === 'denied') return message.warning('예약자에 의해 거절 당하셨거나 혹은 메이트님이 직접 해당 내역을 수신거부 하셨습니다.');\n                if (result === 'success') {\n                    message.success('예약 접수 요청완료');\n                    this.setState({ reserveModal: false, reserveInfo: null }, () => {\n                        this.fetchList();\n                    });\n                }\n            })\n            .catch(error => {\n                message.warning('요청에 실패했습니다.');\n            });\n    };\n\n    render() {\n        const { list } = this.state;\n\n        return (\n            <>\n                <NoCatchedList\n                    data={this.state}\n                    list={list}\n                    onRefresh={this.fetchList}\n                    detailHandler={info => {\n                        this.setState({ reserveModal: true, reserveInfo: info });\n                    }}\n                />\n\n                {this.state.reserveModal ? (\n                    <MateReserveInfoModal\n                        info={this.state.reserveInfo}\n                        visibleHandler={() => {\n                            this.setState({\n                                reserveModal: false,\n                                reserveInfo: null,\n                            });\n                        }}\n                        onCatch={this.onCatchCall}\n                    />\n                ) : null}\n\n                {this.state.refreshing ? (\n                    <SpinWrapper>\n                        <Spin size='large' />\n                    </SpinWrapper>\n                ) : null}\n            </>\n        );\n    }\n}\n\nconst SpinWrapper = styled.div`\n    position: fixed;\n    top: 0px;\n    left: 0px;\n    width: 100vw;\n    height: 100vh;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n\n    z-index: 9999\n    background-color: rgba(0, 0, 0, 0.6);\n`;\n\nexport default Reserve;\n","import React from \"react\";\nimport AnimatedNumbers from \"react-animated-numbers\";\nimport styled from 'styled-components';\nimport { BsPeopleFill, BsNewspaper, BsClockFill } from \"react-icons/bs\";\n\nfunction MainNumber() {\n  const [num, setNum] = React.useState(3021);\n  const [num2, setNum2] = React.useState(289);\n  const [num3, setNum3] = React.useState(16700);\n\n  return (\n    <div className=\"container\" style={{ height: '70px', display: 'flex', flexDirection: 'initial' }}>\n      <div style={{ textAlign: 'center' }}>\n        <label>총 이용자 수</label>\n        <HighLight>\n          <b>\n            <AnimatedNumbers\n              includeComma // 숫자에 쉼표 여부\n              easing\n              animateToNumber={num}\n              animationType={\"calm\"}\n              fontStyle={{ fontSize: 30 }}\n              configs={(number, index) => {\n              return { mass: 1, tension: 430 * (index + 1), friction: 140 };\n            }} />\n          </b>\n        </HighLight>\n      </div>&emsp;&emsp;\n\n      <div style={{ textAlign: 'center' }}>\n        <label>메이트 수</label>\n        <HighLight>\n          <b><AnimatedNumbers\n            includeComma\n            easing\n            animateToNumber={num2}\n            animationType={\"calm\"}\n            fontStyle={{ fontSize: 30 }}\n            configs={(number, index) => {\n              return { mass: 1, tension: 430 * (index + 1), friction: 140 };\n            }}\n          /></b>\n        </HighLight>\n      </div>&emsp;&emsp;\n\n      <div style={{ textAlign: 'center' }}>\n        <label>총 이용 건수</label>\n        <HighLight>\n          <b><AnimatedNumbers\n            includeComma\n            easing\n            animateToNumber={num3}\n            animationType={\"calm\"}\n            fontStyle={{ fontSize: 30 }}\n            configs={(number, index) => {\n              return { mass: 1, tension: 430 * (index + 1), friction: 140 };\n            }}\n            suffix=\"건\"\n          /></b>\n        </HighLight>\n      </div>\n    </div>\n  );\n}\n\nexport default MainNumber;\n\nconst HighLight = styled.p`\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.2px;\n    text-align: center;\n    color: #ffffff;\n\n    margin-bottom: 64px;\n\n    @media (max-width: 768px) {\n        text-align: center;\n    }\n`;","import { message } from 'antd';\nimport React from 'react';\nimport styled from 'styled-components';\nimport swal from 'sweetalert2';\nimport MainNumber from './MainNumber';\nimport Popup from './Popup';\nimport { ManagerPopup } from '../../../../Components/modal';\n\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport SwiperCore, { Pagination, Navigation, Autoplay } from 'swiper';\nimport 'swiper/swiper-bundle.min.css';\nimport 'swiper/swiper.min.css';\nimport 'swiper/components/navigation/navigation.min.css';\nimport 'swiper/components/pagination/pagination.min.css';\nimport { DivisionLine } from '../../../../Components/Common/input';\n\nSwiperCore.use([Navigation, Pagination, Autoplay]);\n\nexport const UserMain = ({ history }) => {\n    return (\n        // <Swiper\n        //     direction={'horizontal'} // 슬라이드의 방향을 수직으로 설정합니다.\n        //     spaceBetween={50}\n        //     slidesPerView={1}\n        //     pagination={{ clickable: true }} // 우측의 점을 클릭했을 때, 클릭한 슬라이드로 이동하게 됩니다.\n        //     navigation\n        //     modules={[Pagination]} // 페이지네이션, 마우스휠등을 사용하려면 모듈을 import해줘야 합니다.\n        //     allowTouchMove // 터치 동작을 허용합니다.\n        //     className=\"main_slider\"\n        //     threshold={20} // 터치 감도를 조정합니다. 숫자가 클수록 터치에 반응하지 않습니다.\n        //     autoplay={{ delay: 4000 }}\n        //     loop={true}\n        //     speed={1000} // 슬라이드가 넘어가는 속도를 조정합니다. 단위는 ms입니다.\n        // >\n        //     <SwiperSlide>\n        <UserMainContainer>\n            <UserMainInnerContainer>\n                {/* <TitleSticker>위드메이트를 사용하는 것, 일상을 돌려받는 것</TitleSticker> */}\n                <TitleSticker>\n                    병원동행매니저가 <span>케어</span>부터 <span>이동</span>까지 다 해드립니다\n                </TitleSticker>\n                <WithmateSpecRow>\n                    {/* 전국민 통원치료 <span>해결사</span> */}\n                    환우 가족들이 <span>직접 추천</span>하는\n                </WithmateSpecRow>\n                <WithmateSpecRow>\n                    <span>병원동행서비스</span>\n                </WithmateSpecRow>\n                <br />\n                <WithmateSpecRow>\n                    <ButtonWrapper>\n                        <GooglePlayButton\n                            onClick={() => {\n                                window.open('https://play.google.com/store/apps/details?id=com.bluecamel.withmate');\n                            }}\n                        >\n                            <img src='/assets/images/icons/google_play_logo.png' alt='구글플레이' style={{ marginRight: '12px' }} />\n                            Google Play\n                        </GooglePlayButton>\n                    </ButtonWrapper>\n                </WithmateSpecRow>\n\n                <BottomSection>\n                    <HighLight>\n                        {/* <MainNumber /> */}\n                        <Popup />\n                    </HighLight>\n\n                    <HighLight>\n                        병원동행매니저가 케어부터 이동까지 <br />\n                        위드메이트가 함께합니다.\n                    </HighLight>\n                    <ButtonWrapper>\n                        <ReserveButton\n                            onClick={() => {\n                                if (!localStorage.getItem('id')) {\n                                    message.warning('병원 동행서비스 예약을 이용하시려면 로그인 후 이용해주세요.');\n                                    return history.push('/user/login');\n                                }\n\n                                history.push('/reserve/items');\n                            }}\n                        >\n                            온라인 예약하기\n                            <img src='/assets/images/main_right_blue.png' alt='방향표' />\n                        </ReserveButton>\n                        <CallButton\n                            onClick={() => {\n                                swal.fire({\n                                    title: '위드메이트 고객센터',\n                                    text: '☎ 070-4300-9075',\n                                    icon: 'info',\n                                    confirmButtonText: '전화걸기',\n                                    cancelButtonText: '확인',\n                                    showCancelButton: true,\n                                }).then(result => {\n                                    if (result.isConfirmed) {\n                                        document.location.href = 'tel:070-4300-9075';\n                                    }\n                                });\n                            }}\n                        >\n                            전화 상담하기\n                            <img src='/assets/images/main_right_white.png' alt='방향표' />\n                        </CallButton>\n                    </ButtonWrapper>\n                </BottomSection>\n            </UserMainInnerContainer>\n        </UserMainContainer>\n        //     </SwiperSlide>\n        // </Swiper>\n    );\n};\n\nconst UserMainContainer = styled.div`\n    width: 100%;\n    height: 628px;\n\n    background: linear-gradient(to top, #3bc1ff, #5b62f5);\n\n    @media (max-width: 768px) {\n        // height: 598px;\n        height: 650px;\n    }\n`;\n\nconst UserMainContainer2 = styled.div`\n    width: 100%;\n    height: 628px;\n\n    background: #f8f8fa;\n\n    @media (max-width: 768px) {\n        height: 598px;\n    }\n`;\n\nconst UserMainInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    height: 100%;\n    margin: 0 auto;\n\n    background-image: url('/assets/images/w_main.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: 72px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        padding-top: 52px;\n        align-items: center;\n        background: transparent;\n    }\n`;\n\nconst UserMainInnerContainer2 = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    height: 100%;\n    margin: 0 auto;\n\n    background-image: url('/assets/images/collaboration/withmate_dlive.png');\n    background-size: 90%;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: 72px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        padding-top: 52px;\n        align-items: center;\n        background: transparent;\n    }\n`;\n\nconst TitleSticker = styled.span`\n    height: 36px;\n\n    padding: 8px 24px;\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: normal;\n    text-align: left;\n    color: #ffffff;\n\n    border-radius: 50vh;\n    background-color: #3bc1ff;\n\n    margin-bottom: 34px;\n\n    @media (max-width: 768px) {\n        margin-bottom: 34px;\n    }\n`;\n\nconst WithmateSpecRow = styled.div`\n    display: flex;\n    align-items: flex-end;\n\n    font-size: 32px;\n    font-stretch: normal;\n    font-style: normal;\n    font-weight: 300;\n    line-height: 1.48;\n    letter-spacing: -0.7px;\n    text-align: left;\n    color: #ffffff;\n\n    > span {\n        font-size: 32px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.5;\n        letter-spacing: -0.7px;\n        text-align: left;\n        color: #ffffff;\n\n        margin-left: 4px;\n    }\n\n    > span.big {\n        font-size: 64px;\n        line-height: 1.2;\n        position: relative;\n        margin-right: 6px;\n\n        > d {\n            font-size: 28px;\n            position: absolute;\n            top: -16px;\n            left: calc(50% - 12px);\n        }\n    }\n\n    > span.normal {\n        font-size: 40px;\n        line-height: 1.2;\n        position: relative;\n        margin-right: 6px;\n\n        > d {\n            font-size: 18px;\n            position: absolute;\n            top: -16px;\n            left: calc(50% - 12px);\n        }\n    }\n\n    margin-bottom: 4px;\n\n    @media (max-width: 768px) {\n        margin-bottom: 8px;\n\n        font-size: 22px;\n\n        > span {\n            font-size: 22px;\n        }\n\n        > span.big {\n            font-size: 48px;\n            line-height: 1.2;\n            position: relative;\n            margin-right: 4px;\n\n            > d {\n                font-size: 20px;\n                position: absolute;\n                top: -16px;\n                left: calc(50% - 8px);\n            }\n        }\n    }\n`;\n\nconst BottomSection = styled.div`\n    margin-top: 32px;\n\n    @media (max-width: 768px) {\n        margin-top: 43px;\n    }\n`;\n\nconst HighLight = styled.p`\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: #ffffff;\n\n    margin-bottom: 64px;\n\n    @media (max-width: 768px) {\n        text-align: center;\n    }\n`;\n\nconst ButtonWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n\n        > div:first-child {\n            margin-bottom: 8px;\n        }\n    }\n`;\n\nconst ButtonCommon = styled.div`\n    display: flex;\n    padding: 20px 24px;\n    width: 210px;\n    align-items: center;\n    justify-content: space-between;\n\n    border-radius: 4px;\n    margin-right: 8px;\n    cursor: pointer;\n\n    > img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n    }\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n\n    &:hover {\n        box-shadow: 4px 10px 24px -4px rgba(0, 0, 0, 0.1);\n        transition: all 0.3s;\n    }\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst GPButtonCommon = styled.div`\n    display: flex;\n    padding: 20px 24px;\n    width: 210px;\n    align-items: center;\n    // justify-content: space-between;\n\n    border-radius: 4px;\n    margin-right: 8px;\n    cursor: pointer;\n\n    > img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n    }\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n\n    &:hover {\n        box-shadow: 4px 10px 24px -4px rgba(0, 0, 0, 0.1);\n        transition: all 0.3s;\n    }\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst ReserveButton = styled(ButtonCommon)`\n    background-color: #ffffff;\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst CallButton = styled(ButtonCommon)`\n    border: 1px solid #ffffff;\n\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: #ffffff;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst GooglePlayButton = styled(GPButtonCommon)`\n    background-color: #ffffff;\n    background-color: rgba(255, 255, 255, 0.1);\n    border-color: #ffffff;\n    border-style: solid;\n    font-size: 20px;\n    // font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    // color: rgba(0, 0, 0, 0.7);\n    color: #ffffff;\n    height: 60px;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const UserVideoSection = () => {\n    return (\n        <VideoSectionContainer>\n            <VideoSectionInnerContainer>\n                {/* <VideoSectionTitle>\n                    위드메이트를 사용하는 것,\n                    <MobileBr /> 일상을 돌려받는 것\n                </VideoSectionTitle> */}\n                <VideoArea>\n                    {/* <iframe\n                        width='100%'\n                        height='100%'\n                        src='/assets/videos/withmate_video.mp4'\n                        title='withmate YouTube video player'\n                        frameborder='0'\n                        allow='accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture'\n                        allowFullScreen\n                        autoplay='autoplay'\n                        loop='loop'\n                    ></iframe> */}\n                    <video controls loop='loop' autoplay='autoplay' muted playsinline width='800px' height='auto'>\n                        <source src='/assets/videos/withmate_video.mp4' />\n                    </video>\n                </VideoArea>\n            </VideoSectionInnerContainer>\n        </VideoSectionContainer>\n    );\n};\n\nconst VideoSectionContainer = styled.div`\n    // padding-top: 105px;\n    // padding-bottom: 208px;\n    padding-top: 55px;\n    padding-bottom: 55px;\n\n    width: 100%;\n    background-color: #f9f9f9;\n\n    @media (max-width: 768px) {\n        // padding-top: 62px;\n        padding-top: 10px;\n        // padding-bottom: 0px;\n        padding-bottom: 10px;\n    }\n`;\n\nconst VideoSectionInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    margin: 0 auto;\n`;\n\nconst VideoSectionTitle = styled.h4`\n    font-size: 22px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.6);\n\n    margin-top: 0px;\n    margin-bottom: 105px;\n\n    @media (max-width: 768px) {\n        font-size: 14px;\n        margin-bottom: 68px;\n    }\n`;\n\nconst VideoArea = styled.div`\n    width: 100%;\n    height: calc(1120px / 16 * 9);\n    background-color: #000000;\n\n    > iframe,\n    video {\n        width: 100%;\n        height: 100%;\n    }\n\n    @media (max-width: 1120px) {\n        height: calc(100vw / 16 * 9);\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n        height: calc(100vw / 16 * 9);\n        background-color: #000000;\n\n        display: flex;\n        align-items: center;\n        justify-content: center;\n\n        > iframe,\n        video {\n            width: 100%;\n            height: 100%;\n        }\n    }\n`;\n\nconst MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const UserGuideSection = () => {\n    return (\n        <UserGuideContainer>\n            <UserGuideInnerContainer>\n                <UserGuideTitle>서비스 이용 방법</UserGuideTitle>\n                <UserGuideStepWrapper>\n                    <TextStep>서비스 신청</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>동행 인력 매칭</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>병원 방문</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>서비스 결과 확인</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>후불 결제</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>혜택 적립</TextStep>\n                </UserGuideStepWrapper>\n\n                <MainStepRow>\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_1.png'\n                        description={`위드메이트 플랫폼에 회원 가입 후\\n병원 동행 서비스 종류를 선택하고\\n신청해주세요!`}\n                        num='01'\n                        name='신청하세요!'\n                    />\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_2.png'\n                        description={`접수하신 서비스는 24시간 내에\\n매칭 가능 여부가 결정됩니다. 동행 인력이\\n매칭을 시도하면 고객님께서 매칭 수락\\n여부를 결정하시면 됩니다!`}\n                        num='02'\n                        name='매칭되세요!'\n                    />\n                    <MainStep\n                        className='uniq'\n                        mArrow\n                        source='/assets/images/main_step_3.png'\n                        description={`동행 인력 매칭 성공 후 예정된 진료일에\\n병원에 다녀오세요! 병원에서 하실 일은\\n진료를 받는 것 밖에 없습니다.\\n진료 동행, 보호자 대행, 병원 행정 보조 등\\n 나머지는 위드메이트가 해드립니다.`}\n                        num='03'\n                        name='다녀오세요!'\n                    />\n                </MainStepRow>\n\n                <MainStepRow>\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_4.png'\n                        description={`위드메이트는 동행 서비스 진행 과정을\\n실시간 카카오 알림톡으로 알려드리고,\\n서비스 종료 후 진료 결과와 특이사항 등의\\n내용이 정리된 서비스 리포트를 제공합니다`}\n                        num='04'\n                        name='확인하세요!'\n                    />\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_5.png'\n                        description={`위드메이트는 정확한 시간 계산이 불가능한\\n병원 진료 특성상, 서비스 요금의 투명성을\\n위해 후불 결제를 진행하고 있습니다.\\n서비스 시간은 초 단위로 자동 계산되니,\\n안심하고 서비스를 받으세요!`}\n                        num='05'\n                        name='후불이에요!'\n                    />\n                    <MainStep\n                        source='/assets/images/main_step_6.png'\n                        description={`회원 가입만 해도 2,000 포인트를\\n지급해드리며, 매번 서비스 후기 작성을\\n할 때마다 최대 3,000 포인트를 지급해드려요!\\n적립된 포인트로 더 저렴하게 서비스를\\n이용해보세요!`}\n                        num='06'\n                        name='받아가세요!'\n                    />\n                </MainStepRow>\n            </UserGuideInnerContainer>\n        </UserGuideContainer>\n    );\n};\n\nconst MainStep = ({ webArrow, mArrow, source, num, name, description, className }) => {\n    return (\n        <MainStepWrapper className={className || ''}>\n            <MainStepImageSection>\n                <img className='bg' src={source} alt='thumbnail' />\n            </MainStepImageSection>\n\n            <MainStepTextSection>\n                <StepIndex>{num}</StepIndex>\n                <StepTitle>{name}</StepTitle>\n                <StepDescription>\n                    {description.split('\\n').map((word, index) => (\n                        <span key={'word-break-down-' + index.toString() + num}>\n                            {word}\n                            <KeepBr />\n                        </span>\n                    ))}\n                </StepDescription>\n            </MainStepTextSection>\n            <img className={`arrow ${webArrow && 'web'} ${mArrow && 'mobile'}`} src='/assets/images/w_main_stepper.png' />\n        </MainStepWrapper>\n    );\n};\n\nconst UserGuideContainer = styled.div`\n    width: 100%;\n\n    background-color: #ffffff;\n\n    padding-top: 103px;\n    padding-bottom: 162px;\n\n    @media (max-width: 768px) {\n        padding-top: 90px;\n        padding-bottom: 130px;\n    }\n`;\n\nconst UserGuideInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    margin: 0 auto;\n`;\n\nconst UserGuideTitle = styled.h4`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-top: 0px;\n    margin-bottom: 32px;\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        line-height: 1.42;\n        letter-spacing: -0.1px;\n        margin-bottom: 24px;\n    }\n`;\n\nconst UserGuideStepWrapper = styled.div`\n    width: 100%;\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n\n    margin-bottom: 90px;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        margin-bottom: 77px;\n    }\n`;\n\nconst TextStep = styled.span`\n    font-size: 15px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.33;\n    letter-spacing: normal;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.6);\n`;\n\nconst ImgStep = styled.img`\n    margin-left: 16px;\n    margin-right: 16px;\n\n    width: 24px;\n    height: 24px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        transform: rotate(90deg);\n\n        width: 16px;\n        height: 16px;\n\n        margin-left: 0px;\n        margin-right: 0px;\n\n        margin-top: 8px;\n        margin-bottom: 8px;\n    }\n`;\n\nconst MainStepRow = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    > div:first-child {\n        border-left: 0px;\n    }\n\n    > div:last-child {\n        border-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n\n        > div:last-child {\n            border-bottom: 0px;\n        }\n\n        > div.uniq {\n            border-bottom: 1px solid #f2f2f2;\n        }\n    }\n`;\n\nconst MainStepWrapper = styled.div`\n    padding-left: 47px;\n    padding-right: 52px;\n    border-right: 1px solid #f2f2f2;\n\n    position: relative;\n\n    > img.arrow {\n        width: 24px;\n        height: 24px;\n\n        position: absolute;\n        top: calc(90px - 12px);\n        right: -11.5px;\n\n        display: none;\n    }\n\n    > img.mobile {\n        display: none;\n    }\n\n    > img.web {\n        display: block;\n    }\n\n    @media (max-width: 768px) {\n        border-right: 0px;\n        border-bottom: 1px solid #f2f2f2;\n\n        > img.arrow {\n            width: 24px;\n            height: 24px;\n\n            top: unset;\n            right: unset;\n            bottom: -10px;\n            left: calc(50% - 12px);\n\n            transform: rotate(90deg);\n        }\n\n        > img.web {\n            display: none;\n        }\n\n        > img.mobile {\n            display: block;\n        }\n    }\n\n    @media (max-width: 768px) {\n        padding-right: 0px;\n        padding-left: 0px;\n        padding-bottom: 44px;\n    }\n`;\n\nconst MainStepImageSection = styled.div`\n    width: 288px;\n    height: 180px;\n\n    margin-bottom: 24px;\n\n    > img.bg {\n        width: 100%;\n        height: 100%;\n        object-fit: contain;\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n        text-align: center;\n    }\n`;\n\nconst MainStepTextSection = styled.div`\n    display: flex;\n    align-items: center;\n    flex-direction: column;\n`;\n\nconst StepIndex = styled.span`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.43;\n    letter-spacing: normal;\n    text-align: center;\n    color: #afb0b2;\n    margin-bottom: 8px;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst StepTitle = styled.span`\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    margin-bottom: 24px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst StepDescription = styled.span`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-size: 15px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.57;\n        letter-spacing: -0.3px;\n        text-align: center;\n        color: rgba(0, 0, 0, 0.7);\n    }\n    word-break: keep-all;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst KeepBr = styled.br`\n    display: block;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const UserMainBanner = ({ goPage }) => (\n    <BannerContainer>\n        <Description>\n            위드메이트에 대해 더 알고 싶으시죠? <br />\n            위드메이트를 소개해드릴게요!\n        </Description>\n        <LinkButton onClick={goPage}>\n            위드메이트 소개\n            <img src='/assets/images/main_right_white.png' />\n        </LinkButton>\n    </BannerContainer>\n);\n\nconst BannerContainer = styled.div`\n    width: 100%;\n    background-color: #3bc1ff;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    flex-direction: column;\n\n    padding: 48px 0px;\n\n    @media (max-width: 480px) {\n        padding-top: 67px;\n        padding-bottom: 51px;\n    }\n`;\n\nconst Description = styled.p`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: center;\n    color: #ffffff;\n\n    margin-bottom: 24px;\n\n    > br {\n        display: none;\n        @media (max-width: 480px) {\n            display: block;\n        }\n    }\n`;\n\nconst LinkButton = styled.a`\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: 1px solid #ffffff;\n    border-radius: 50vh;\n\n    padding: 20px 24px;\n\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: #ffffff;\n\n    cursor: pointer;\n\n    > img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n\n        margin-left: 18px;\n    }\n    &:hover {\n        background-color: transparent;\n        color: #ffffff;\n    }\n`;\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../theme';\n\nconst HomeStyledContainer = styled.div`\n    padding-top: 55px;\n\n    .center-title {\n        text-align: center;\n        margin-bottom: 28px;\n\n        > p {\n            height: 52px;\n            line-height: 52px;\n            margin-bottom: 0px;\n            font-size: 28px;\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n        }\n    }\n\n    .ant-collapse > .ant-collapse-item > .ant-collapse-header {\n        padding: 0px;\n    }\n\n    .ant-collapse-borderless > .ant-collapse-item {\n        border: 0px;\n    }\n\n    .ant-collapse-content > .ant-collapse-content-box {\n        padding: 0px;\n        padding-top: 4px;\n        padding-bottom: 12px;\n    }\n\n    .fake-input {\n        width: 100%;\n        height: 36px;\n        border-radius: 4px;\n        border: 1px solid #e6e6e6;\n    }\n\n    .main-section {\n        position: relative;\n        width: 100%;\n        height: 100vh;\n        max-height: 628px;\n        // min-height: calc(100vh - 55px);\n\n        // background-color: #ebf9ff;\n        // background-image: url('/assets/images/new_mainbg.png');\n        background-color: linear-gradient(to top, #3bc1ff, #5b62f5);\n        background-image: url('/assets/images/w_main.png');\n        background-size: cover;\n        background-repeat: no-repeat;\n        background-position: center;\n\n        @media (max-width: 768px) {\n            background-image: url('/assets/images/new_mainbg-mobile.png');\n            min-height: 86vh;\n\n            .inner-container {\n                padding: 0px;\n                padding-bottom: 30px;\n                min-height: 86vh;\n\n                display: flex;\n                align-items: flex-end;\n                justify-content: flex-end;\n            }\n        }\n\n        .ant-input[disabled] {\n            color: rgba(0, 0, 0, 0.7);\n        }\n        .ant-input {\n            font-size: 12px;\n        }\n\n        .order-menu-wrapper {\n            width: 50%;\n            position: relative;\n            max-width: 440px;\n            min-width: 370px;\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 1px 2px 3.5px #e6e6e6;\n            padding: 32px;\n\n            .mobile-close-button {\n                display: none;\n            }\n\n            @media (max-width: 768px) {\n                display: none;\n\n                &.active {\n                    display: block;\n                }\n\n                margin: 0px auto;\n                position: fixed;\n                z-index: 99;\n                top: 55px;\n                left: 0px;\n                width: 100%;\n                max-width: 100%;\n                height: calc(100vh - 55px);\n                overflow: scroll;\n                border-radius: 0px;\n\n                .mobile-close-button {\n                    display: block;\n                    position: absolute;\n                    top: 16px;\n                    right: 24px;\n                    padding: 6px;\n                    cursor: pointer;\n\n                    img {\n                        width: 18px;\n                        height: 18px;\n                    }\n                }\n\n                &.blocked {\n                    z-index: 0;\n                    position: relative;\n                    height: auto;\n                    overflow: auto;\n                }\n            }\n\n            .order-title {\n                margin-bottom: 20px;\n\n                p {\n                    margin: 0px;\n                    padding: 0px;\n                    font-size: ${sizeHandler(28)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n            }\n\n            .service {\n                margin-bottom: 20px;\n\n                .time-checker {\n                    width: calc(50% - 4px);\n                }\n\n                .time-checker.margin {\n                    margin-right: 8px;\n                }\n\n                .search-button {\n                    position: absolute;\n                    top: 1px;\n                    right: 1px;\n                    background-color: #ececec;\n                    height: 34px;\n                    width: 50px;\n                    border-top-right-radius: 4px;\n                    border-bottom-right-radius: 4px;\n\n                    font-size: 12px;\n                    line-height: 34px;\n                    text-align: center;\n                    cursor: pointer;\n                    color: rgba(0, 0, 0, 0.4);\n                }\n\n                .service-tab {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                    border: 1px solid #ddd;\n                    border-radius: 6px;\n\n                    .tab {\n                        flex: 1;\n                        height: 48px;\n                        border-right: 1px solid #ddd;\n                        cursor: pointer;\n                        display: flex;\n                        justify-content: center;\n                        align-items: center;\n\n                        &:last-child {\n                            border: 0px;\n                        }\n\n                        span {\n                            font-size: ${sizeHandler(14)};\n                            letter-spacing: -0.2px;\n                            font-weight: bold;\n                            color: ${mainColor};\n                        }\n                    }\n\n                    .tab.active {\n                        background-color: ${mainColor};\n\n                        span {\n                            color: white;\n                        }\n                    }\n                }\n\n                .info-tab {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n\n                    p {\n                        flex: 1;\n                        margin: 0px;\n                        padding: 0px;\n                        text-align: left;\n\n                        &:first-child {\n                            margin-right: 8px;\n                        }\n                    }\n                }\n\n                .info-input-tab {\n                    display: flex;\n                    align-items: center;\n\n                    > div {\n                        flex: 1;\n\n                        &:first-child {\n                            margin-right: 8px;\n                        }\n                    }\n\n                    .name-wrapper {\n                        position: relative;\n\n                        .sex-type-wrapper {\n                            position: absolute;\n                            top: 1px;\n                            right: 1px;\n                            z-index: 3;\n                            background-color: white;\n\n                            .sex-type {\n                                display: inline-block;\n                                width: 34px;\n                                height: 34px;\n                                line-height: 36px;\n                                text-align: center;\n                                border-left: 1px solid #e6e6e6;\n\n                                font-size: ${sizeHandler(14)};\n                                font-weight: normal;\n                                letter-spacing: -0.2px;\n                                color: rgba(0, 0, 0, 0.2);\n                                cursor: pointer;\n\n                                &:hover {\n                                    color: rgba(0, 0, 0, 0.3);\n                                    transition: all 0.3s;\n                                }\n\n                                &.active {\n                                    color: ${mainColor};\n                                }\n                            }\n                        }\n                    }\n\n                    .input {\n                        flex-grow: 1;\n                        display: flex;\n                        min-width: 0;\n                        align-items: center;\n\n                        border-radius: 4px;\n                        border: solid 1px #e6e6e6;\n                        min-height: 36px;\n                        line-height: 36px;\n                        text-indent: 12px;\n                        font-size: ${sizeHandler(12)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        background-color: #f5f5f5;\n                        cursor: not-allowed;\n\n                        p {\n                            white-space: nowrap;\n                            text-overflow: ellipsis;\n                            overflow: hidden;\n                        }\n\n                        // .ant-input {\n                        //     color: rgba(0, 0, 0, 0.8);\n                        // }\n\n                        &.phone {\n                            flex: 0.5;\n\n                            @media (max-width: 768px) {\n                                flex: 1;\n                            }\n                        }\n\n                        &.input-with-icon {\n                            p {\n                                height: 100%;\n                                flex: 1;\n                                text-overflow: ellipsis;\n                                overflow: hidden;\n                                white-space: nowrap;\n                            }\n\n                            div {\n                                height: 100%;\n                                width: 36px;\n                                border-left: 1px solid #e6e6e6;\n                                display: flex;\n                                justify-content: center;\n                                align-items: center;\n\n                                span {\n                                    text-align: center;\n                                    text-indent: 0px;\n                                    // opacity: 0.3;\n                                    font-size: ${sizeHandler(12)};\n                                    letter-spacing: -0.3px;\n                                    color: rgba(0, 0, 0, 0.8);\n\n                                    img {\n                                        width: 18px;\n                                    }\n                                }\n                            }\n                        }\n                    }\n                }\n\n                .service-fee-wrapper {\n                    margin-bottom: 32px;\n\n                    .service {\n                        display: flex;\n                        align-items: center;\n                        padding-top: 12px;\n                        margin-bottom: 0px;\n\n                        .name {\n                            flex: 1;\n                            font-size: ${sizeHandler(14)};\n                            letter-spacing: -0.3px;\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n\n                        .fee {\n                            font-size: ${sizeHandler(14)};\n                            font-weight: bold;\n                            text-align: right;\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n                    }\n                }\n\n                input {\n                    height: 36px;\n                    display: inline-block;\n                    width: 100%;\n                    overflow: hidden;\n                    text-overflow: ellipsis;\n                    white-space: nowrap;\n                }\n\n                .ant-input-number-input-wrap {\n                    height: 100%;\n\n                    .ant-input-number-input {\n                        height: 100%;\n                    }\n\n                    input {\n                        height: 100%;\n                    }\n                }\n\n                .select {\n                    display: inline-block;\n                    height: 36px;\n                    width: 100%;\n\n                    .ant-select-selection--single {\n                        height: 100%;\n                    }\n\n                    .ant-select-selection__rendered {\n                        line-height: 36px;\n                    }\n                }\n\n                .info {\n                    font-size: ${sizeHandler(12)};\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 4px;\n                    letter-spacing: -0.15px;\n                }\n\n                .ant-select-selection__rendered {\n                    margin-right: 34px;\n                    border-right: 1px solid #e6e6e6;\n                }\n\n                .ant-select-arrow {\n                    color: ${mainColor};\n                }\n\n                .image-with-text {\n                    display: flex;\n                    align-items: center;\n                    img {\n                        height: 18px;\n                        border: 0px;\n                    }\n\n                    p {\n                        flex: 1;\n                        margin: 0px;\n                        padding: 0px;\n                        margin-left: 12px;\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        color: #3bc1ff;\n                    }\n                }\n            }\n\n            .side-summary-tab {\n                position: absolute;\n                top: 0px;\n                right: -380px;\n                width: 360px;\n                height: 100%;\n                background-color: white;\n                border-radius: 8px;\n                box-shadow: 1px 2px 3.5px #e6e6e6;\n                padding: 32px;\n                overflow: hidden;\n                display: flex;\n                flex-direction: column;\n\n                @media (max-width: 768px) {\n                    width: 100%;\n                    height: auto;\n                    border-radius: 0px;\n                    box-shadow: none;\n                    padding: 0px;\n                    position: relative;\n                    top: 55px;\n                    left: 0px;\n                    background-color: transparent;\n                }\n\n                .refund-info-wrapper {\n                    flex: 1;\n                    display: flex;\n                    align-items: flex-end;\n\n                    .info-wrapper {\n                        width: 100%;\n\n                        .title {\n                            font-size: ${sizeHandler(12)};\n                            font-weight: bold;\n                            color: #a7a7a7;\n                            margin-bottom: 8px;\n                        }\n\n                        .info {\n                            font-size: ${sizeHandler(10)};\n                            line-height: ${sizeHandler(16)};\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n\n                        @media (max-width: 768px) {\n                            margin-top: 36px;\n                            padding-bottom: 20px;\n\n                            .info {\n                                margin-bottom: 60px;\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .additional-fee {\n        p {\n            margin: 0px;\n            padding: 0px;\n            margin-top: 8px;\n            font-size: ${sizeHandler(10)};\n            color: rgba(0, 0, 0, 0.7);\n        }\n    }\n\n    .ant-input-number {\n        width: 100%;\n        height: 48px;\n\n        .ant-input-number-input-wrap {\n            height: 100%;\n\n            .ant-input-number-input {\n                height: 100%;\n            }\n\n            input {\n                height: 100%;\n            }\n        }\n\n        .ant-input-number-handler-wrap {\n            opacity: 1;\n            width: 48px;\n\n            span {\n                display: flex;\n                align-items: center;\n                justify-content: center;\n\n                i {\n                    position: relative;\n                    margin-top: 0px;\n                    left: 0px;\n                    top: 0px;\n                    bottom: 0px;\n                    right: 0px;\n                    font-size: 16px;\n                }\n            }\n            .anticon.anticon-up.ant-input-number-handler-up-inner {\n                color: ${mainColor};\n            }\n            .anticon.anticon-down.ant-input-number-handler-down-inner {\n                color: ${mainColor};\n            }\n        }\n    }\n\n    .total-fee-wrapper {\n        padding: 18px 0px;\n        border-top: 1px solid #e6e6e6;\n        border-bottom: 1px solid #e6e6e6;\n\n        .total-fee {\n            display: flex;\n            align-items: center;\n\n            .total-min {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                // font-weight: bold;\n                letter-spacing: -0.5px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            .fee-min {\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.5px;\n                text-align: right;\n                // font-weight: bold;\n                // color: #3bc1ff;\n\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            span.vat {\n                font-size: ${sizeHandler(11)};\n                color: #565656;\n            }\n        }\n\n        .total {\n            flex: 1;\n            font-size: ${sizeHandler(16)};\n            font-weight: bold;\n            letter-spacing: -0.5px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        .fee {\n            font-size: ${sizeHandler(16)};\n            font-weight: bold;\n            letter-spacing: -0.5px;\n            text-align: right;\n            color: #3bc1ff;\n        }\n    }\n\n    // 여기\n    .service-section {\n        .concept-container {\n            margin-bottom: 68px;\n\n            .concept-title {\n                font-size: 24px;\n                font-weight: bold;\n                line-height: 2.17;\n                letter-spacing: -0.67px;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 12px;\n            }\n\n            .concept-body {\n                font-size: 18px;\n                font-weight: normal;\n                line-height: 1.78;\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.8);\n\n                @media (max-width: 768px) {\n                    font-size: 16px;\n                }\n            }\n        }\n\n        .service-item:last-child {\n            border-top: 1px solid #e6e6e6;\n            margin-top: 96px;\n            padding-top: 96px;\n        }\n\n        .service-item {\n            .service-name {\n                p {\n                    font-size: ${sizeHandler(36)};\n                    font-weight: bold;\n                    letter-spacing: -1px;\n                    color: rgba(0, 0, 0, 0.8);\n\n                    position: relative;\n\n                    .stamp {\n                        margin-left: 20px;\n                        padding: 8px 12px;\n                        border-radius: 4px;\n                        background-color: #ff0052;\n                        font-size: 10px;\n                        font-weight: bold;\n                        text-align: center;\n                        color: #ffffff;\n\n                        position: absolute;\n                        bottom: 6px;\n                    }\n                }\n\n                margin-bottom: 12px;\n            }\n\n            .mobile {\n                display: none;\n            }\n\n            .desktop {\n                display: block;\n            }\n\n            .service-info {\n                display: flex;\n                align-items: center;\n\n                .service-photo {\n                    flex: 1;\n                    display: flex;\n                    align-items: center;\n                    justify-content: flex-start;\n                    padding-left: 60px;\n\n                    img {\n                        // height: 100%;\n                        width: 100%;\n                    }\n                }\n\n                .info-wrapper {\n                    flex: 2;\n\n                    .main-description {\n                        font-size: ${sizeHandler(18)};\n                        color: rgba(0, 0, 0, 0.8);\n                        letter-spacing: -0.3px;\n                        margin-bottom: 32px;\n\n                        @media (max-width: 768px) {\n                            font-size: 16px;\n                        }\n                    }\n\n                    .service-detail {\n                        display: flex;\n                        align-item: center;\n\n                        .target-price {\n                            // flex: ;\n                            min-width: 240px;\n\n                            .target {\n                                margin-bottom: 36px;\n                            }\n                        }\n\n                        .scheme {\n                            flex: 1;\n                            margin-left: 20px;\n\n                            .scheme-items {\n                                p {\n                                    font-size: ${sizeHandler(14)};\n                                    letter-spacing: -0.3px;\n                                    color: rgba(0, 0, 0, 0.7);\n                                    height: 38px;\n                                    line-height: 38px;\n                                    margin: 0px;\n                                    padding: 0px;\n                                    overflow: hidden;\n                                    text-overflow: ellipsis;\n                                    white-space: nowrap;\n                                }\n                                border-bottom: 1px solid #e6e6e6;\n                            }\n\n                            .ps {\n                                font-size: ${sizeHandler(14)};\n                                color: ${mainColor};\n                                // font-weight: bold;\n                                height: 28px;\n                                line-height: 28px;\n\n                                &:nth-child(2n-1) {\n                                    color: #ff5500;\n                                }\n                            }\n                        }\n                    }\n\n                    .detail-button-wrapper {\n                        min-width: 240px;\n                        margin-top: 40px;\n                        background-color: #606060;\n                        border-radius: 4px;\n                        height: 48px;\n                        cursor: pointer;\n\n                        p {\n                            width: 100%;\n                            height: 100%;\n                            text-align: center;\n                            line-height: 48px;\n                            font-size: ${sizeHandler(14)};\n                            color: white;\n                            font-weight: bold;\n                        }\n                    }\n\n                    .reserve-button-wrapper {\n                        flex: 1;\n\n                        margin-top: 40px;\n                        background-color: ${mainColor};\n                        border-radius: 4px;\n                        height: 48px;\n                        cursor: pointer;\n\n                        p {\n                            width: 100%;\n                            height: 100%;\n                            text-align: center;\n                            line-height: 48px;\n                            font-size: ${sizeHandler(14)};\n                            color: white;\n                            font-weight: bold;\n                        }\n                    }\n\n                    .title {\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-top: 36px;\n                        margin-bottom: 8px;\n                    }\n\n                    .content {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n\n                    .price-content {\n                        font-size: ${sizeHandler(16)};\n                        font-weight: bold;\n                        color: #606060;\n                        letter-spacing: -0.3px;\n                    }\n\n                    .info-container {\n                        .spec-title {\n                            font-size: 18px;\n                            font-weight: bold;\n                            line-height: 1.56;\n                            letter-spacing: normal;\n                            color: rgba(0, 0, 0, 0.8);\n                        }\n\n                        .spec-wrapper {\n                            padding: 8px 0px;\n                            border-bottom: 1px solid #e6e6e6;\n\n                            .spec-row {\n                                font-size: 14px;\n                                letter-spacing: -0.3px;\n                                color: rgba(0, 0, 0, 0.7);\n                                margin: 0px;\n                            }\n\n                            .spec-sub {\n                                font-size: 12px;\n                                letter-spacing: -0.26px;\n                                color: #a7a7a7;\n                                margin: 0px;\n                                margin-top: 4px;\n                            }\n                        }\n                    }\n\n                    .button-container {\n                        display: flex;\n                        align-items: center;\n                        margin-top: 32px;\n\n                        .button {\n                            border-radius: 4px;\n                            height: 48px;\n                            line-height: 48px;\n                            text-align: center;\n                            cursor: pointer;\n\n                            &.video-button {\n                                width: 285px;\n                                background-color: #606060;\n                                margin-right: 20px;\n\n                                &:hover {\n                                    transition: all 0.3s;\n                                    background-color: #707070;\n                                }\n                            }\n\n                            &.reserve-button {\n                                background-color: #3bc1ff;\n                                flex: 1;\n\n                                &:hover {\n                                    transition: all 0.3s;\n                                    background-color: #54c9ff;\n                                }\n                            }\n\n                            span {\n                                font-size: 14px;\n                                font-weight: bold;\n                                text-align: center;\n                                color: #ffffff;\n                            }\n                        }\n\n                        @media (max-width: 768px) {\n                            flex-direction: column;\n\n                            .button {\n                                width: 100% !important;\n                                margin-right: 0px !important;\n                                height: 40px;\n                                line-height: 40px;\n\n                                &:last-child {\n                                    margin-top: 16px;\n                                }\n                            }\n                        }\n                    }\n                }\n            }\n        }\n\n        @media (max-width: 768px) {\n            .service-item {\n                .service-name {\n                    p {\n                        font-size: ${sizeHandler(30)};\n\n                        .stamp {\n                            padding: 4px 8px;\n                            bottom: 8px;\n                        }\n                    }\n                }\n\n                .service-info {\n                    display: block;\n\n                    .service-photo {\n                        margin-top: 40px;\n                        padding-left: 0px;\n\n                        img {\n                            width: 100%;\n                        }\n                    }\n\n                    .info-wrapper {\n                        width: 100%;\n\n                        > p {\n                            font-size: ${sizeHandler(16)};\n                        }\n\n                        .service-detail {\n                            flex-direction: column;\n\n                            .service-photo {\n                                display: none;\n                            }\n\n                            .scheme {\n                                margin: 0px;\n                            }\n                        }\n\n                        .detail-button-wrapper {\n                            display: block;\n                            width: 100%;\n                            height: 40px;\n\n                            p {\n                                line-height: 40px;\n                            }\n                        }\n\n                        .reserve-button-wrapper {\n                            display: block;\n                            width: 100%;\n                            height: 40px;\n\n                            p {\n                                line-height: 40px;\n                            }\n                        }\n                        .mobile {\n                            display: block;\n                        }\n\n                        .desktop {\n                            display: none;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .reserve-section {\n        .menu-top {\n            display: flex;\n            align-items: flex-end;\n            margin-bottom: 16px;\n\n            .main-title {\n                flex: 1;\n                font-size: 28px;\n                font-weight: bold;\n                letter-spacing: -1px;\n                color: rgba(0, 0, 0, 0.8);\n            }\n\n            .sub-button {\n                color: ${mainColor};\n                font-weight: bold;\n                font-size: 14px;\n                cursor: pointer;\n            }\n        }\n\n        .menu-bottom {\n            .reserve-menu {\n                display: flex;\n                align-items: center;\n                justify-content: center;\n                padding: 20px;\n                margin-bottom: 12px;\n                border-radius: 4px;\n                box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n                background-color: #ffffff;\n\n                .title {\n                    color: #a7a7a7;\n                    font-size: ${sizeHandler(12)};\n                    font-weight: bold;\n                    margin: 0px;\n                    padding: 0px;\n                }\n\n                .contents {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: #606060;\n                    margin: 0px;\n                    padding: 0px;\n                    white-space: nowrap;\n                    overflow: hidden;\n                    text-overflow: ellipsis;\n                }\n\n                .service-name {\n                    flex: 0.7;\n                    .contents {\n                        color: ${mainColor};\n                    }\n                }\n\n                .user {\n                    flex: 0.5;\n                }\n\n                .date {\n                    flex: 0.7;\n                }\n\n                .hospital {\n                    flex: 1;\n                }\n\n                .status {\n                    flex: 0.4;\n                }\n\n                .button {\n                    flex: 0.5;\n                    > div {\n                        display: flex;\n                        height: 48px;\n                        border-radius: 4px;\n                        align-items: center;\n                        justify-content: center;\n                        border: 1px solid ${mainColor};\n                        cursor: pointer;\n                        transition: all 0.3s;\n\n                        span {\n                            font-size: ${sizeHandler(14)};\n                            font-weight: bold;\n                            color: ${mainColor};\n                        }\n\n                        &:hover {\n                            background-color: ${mainColor};\n                            span {\n                                color: white;\n                            }\n                        }\n                    }\n                }\n\n                .content.service {\n                    color: ${mainColor};\n                }\n            }\n            @media (max-width: 768px) {\n                .reserve-menu {\n                    flex-direction: column;\n                    align-items: flex-start;\n                    justify-content: flex-start;\n\n                    .contents {\n                        margin-bottom: 20px;\n                    }\n\n                    .button {\n                        width: 100%;\n                        > div {\n                            height: 40px;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .section-title {\n        padding-bottom: 16px;\n        border-bottom: 1px solid #ececec;\n        margin-bottom: 48px;\n\n        p {\n            font-size: ${sizeHandler(18)};\n            color: #a7a7a7;\n            font-weight: bold;\n            margin: 0px;\n            padding: 0px;\n            opacity: 1;\n        }\n    }\n\n    .order-menu-mobile-wrapper {\n        // position: absolute;\n        // bottom: 68px;\n        // left: 0;\n        display: flex;\n        justify-content: center;\n        align-items: center;\n        flex-direction: column;\n        width: 100%;\n        padding: 10px;\n\n        p {\n            text-align: center;\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: white;\n        }\n\n        p:nth-child(1) {\n            font-size: ${sizeHandler(14)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: white;\n            lineheight: ${sizeHandler(20)};\n        }\n\n        button {\n            width: 100%;\n            height: 56px;\n            font-size: ${sizeHandler(16)};\n            font-weight: bold;\n            text-align: center;\n            color: #ffffff;\n            margin-top: 28px;\n        }\n\n        @media (min-width: 768px) {\n            display: none;\n        }\n    }\n`;\n\nexport default HomeStyledContainer;\n\nexport const UserMainContainer = styled.div`\n    width: 100%;\n    // min-height: calc(100vh - 55px);\n    // background-image: url('/assets/images/');\n\n    height: 100vh;\n    max-height: 628px;\n\n    background-color: linear-gradient(to top, #3bc1ff, #5b62f5);\n    background-image: url('/assets/images/w_main.png');\n\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: calc((100vh - 55px) * 0.2);\n\n    @media (max-width: 768px) {\n        background-size: cover;\n        background-image: url('/assets/images/new_mainbg-mobile.png');\n\n        min-height: initial;\n        height: 600px;\n\n        padding-top: 354px;\n    }\n`;\n\nexport const InnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    margin: 0 auto;\n\n    @media (max-width: 1120px) {\n        padding-left: 32px;\n        padding-right: 32px;\n    }\n\n    @media (max-width: 768px) {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n`;\n\nexport const UserMainTitle = styled.div`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 50px;\n    line-height: 66px;\n\n    letter-spacing: -1.44444px;\n\n    color: #ffffff;\n\n    position: relative;\n    margin-bottom: 16px;\n\n    @media (max-width: 768px) {\n        > br {\n            display: block;\n        }\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 22px;\n        line-height: 30px;\n\n        text-align: center;\n        color: #ffffff;\n\n        margin-bottom: 4px;\n    }\n`;\n\nexport const UserMainTitleDeco = styled.img`\n    position: absolute;\n\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const DecoRight = styled(UserMainTitleDeco)`\n    top: 0px;\n    left: 240px;\n\n    width: 32px;\n    height: 32px;\n`;\n\nexport const DecoLeft = styled(UserMainTitleDeco)`\n    top: 36px;\n    left: -60px;\n\n    width: 22px;\n    height: 22px;\n`;\n\nexport const DecoLeftTop = styled(UserMainTitleDeco)`\n    top: -52px;\n    left: -62px;\n\n    width: 62px;\n    height: 62px;\n`;\n\nexport const UserMainSubtitle = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 22px;\n    line-height: 30px;\n    color: rgba(255, 255, 255, 0.8);\n    letter-spacing: -0.4px;\n\n    margin-bottom: 44px;\n\n    @media (max-width: 768px) {\n        font-weight: normal;\n        font-size: 12px;\n        line-height: 22px;\n        letter-spacing: -0.3px;\n        text-align: center;\n\n        margin-bottom: 24px;\n    }\n`;\n\nexport const UserMainRoute = styled.div`\n    width: 100%;\n\n    @media (max-width: 768px) {\n        text-align: center;\n    }\n`;\n\nexport const UserMainRouteButton = styled.a`\n    display: inline-block;\n    width: 100%;\n    max-width: 360px;\n    height: 64px;\n    line-height: 64px;\n\n    background: #3bc1ff;\n    border: 1px solid #3bc1ff;\n    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.1);\n    border-radius: 4px;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 19px;\n    letter-spacing: 0.2;\n\n    text-align: center;\n\n    color: #ffffff;\n    cursor: pointer;\n\n    &:hover {\n        transition: 0.5s;\n        opacity: 0.85;\n    }\n\n    @media (max-width: 768px) {\n        width: calc(100vw - 20px);\n        max-width: 360px;\n\n        height: 56px;\n        line-height: 56px;\n        font-size: 16px;\n\n        margin: 0 auto;\n    }\n`;\n\nexport const PartnerContainer = styled.div`\n    width: 100%;\n\n    padding-top: 60px;\n    padding-bottom: 60px;\n\n    @media (max-width: 768px) {\n        margin-top: 40px;\n    }\n`;\n\nexport const PartnerInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n\n    margin: 0 auto;\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    flex-direction: column;\n\n    position: relative;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none;\n    }\n\n    @media (max-width: 768px) {\n        padding-left: 24px;\n        padding-right: 24px;\n    }\n`;\n\nexport const PartnerTitle = styled.div`\n    display: flex;\n    flex-direction: column;\n    width: auto;\n\n    align-items: center;\n    margin-top: 10px;\n    margin-bottom: 46px;\n\n    > img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n\n        margin-bottom: 16px;\n    }\n\n    > span {\n        font-size: 24px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.3;\n        letter-spacing: -0.5px;\n        text-align: center;\n        // color: #3bc1ff;\n    }\n\n    @media (max-width: 1120px) {\n        width: 100%;\n        text-align: left;\n    }\n`;\n\nexport const PartnerListRow = styled.div`\n    display: flex;\n    width: 100%;\n\n    justify-content: space-between;\n    align-items: center;\n    text-align: center;\n    flex-wrap: wrap;\n\n    @media (max-width: 768px) {\n        justify-content: flex-start;\n    }\n\n    @media (max-width: 480px) {\n        justify-content: space-between;\n\n        > div:nth-child(2n) {\n            margin-right: 0px;\n        }\n    }\n`;\n\nexport const PartnerItem = styled.div`\n    margin-bottom: 10px;\n\n    width: 215px;\n    height: 76px;\n\n    border-radius: 4px;\n    // box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    // border: 1px solid rgba(0, 0, 0, 0.1);\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > img {\n        height: 100%;\n        width: 100%;\n        object-fit: cover;\n        transform: scale(1.1);\n    }\n\n    @media (max-width: 768px) {\n        margin-right: 8px;\n        margin-bottom: 8px;\n    }\n\n    @media (max-width: 480px) {\n        width: calc(50% - 4px);\n        height: calc((50vw - 24px) * 0.35);\n    }\n`;\n\nexport const SectionHeader = styled.div`\n    padding-bottom: 10px;\n    margin-bottom: 66px;\n\n    border-bottom: 1px solid #e9e9e9;\n\n    display: flex;\n    align-items: flex-end;\n\n    > img {\n        width: 58px;\n        height: 76px;\n        object-fit: contain;\n\n        margin-right: 16px;\n    }\n\n    > span {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 26px;\n        line-height: 50px;\n\n        text-align: center;\n        letter-spacing: -0.777778px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n        justify-content: center;\n        > img {\n            width: 48px;\n            height: 48px;\n\n            margin-bottom: 10px;\n        }\n\n        > span {\n            font-size: 20px;\n            line-height: 32px;\n            text-align: center;\n            letter-spacing: -0.555556px;\n        }\n    }\n`;\n\nexport const ServiceListContainer = styled.div`\n    margin-bottom: 102px;\n\n    @media (max-width: 1120px) {\n        padding-left: 20px;\n        padding-right: 20px;\n    }\n`;\n\nexport const ServiceListInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n\n    margin: 0 auto;\n`;\n\nexport const ServiceBoxWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const ServiceBoxContainer = styled.div`\n    margin-right: 20px;\n\n    &:last-child {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        margin-right: 0px;\n    }\n\n    margin-bottom: 46px;\n`;\n\nexport const ServiceBoxHeader = styled.div`\n    > p:first-child {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 12px;\n        line-height: 26px;\n\n        letter-spacing: -0.3px;\n    }\n\n    > p:last-child {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 20px;\n        line-height: 32px;\n\n        letter-spacing: -0.6px;\n    }\n`;\n\nexport const ServiceBoxImageWrapper = styled.div`\n    border-radius: 6px;\n    overflow: hidden;\n`;\n\nexport const ServiceBoxImg = styled.img`\n    width: calc((1120px / 3) - (40px / 3));\n    max-width: 360px;\n    object-fit: contain;\n\n    @media (max-width: 1120px) {\n        max-width: 280px;\n    }\n\n    @media (max-width: 900px) {\n        max-width: 240px;\n    }\n\n    @media (max-width: 768px) {\n        max-width: 300px;\n    }\n`;\n\nexport const ServiceBoxButtons = styled.div`\n    width: 100%;\n    display: flex;\n\n    margin-top: -12px;\n`;\n\nexport const MoreButton = styled.a`\n    width: 132px;\n    height: 48px;\n\n    text-align: center;\n    line-height: 48px;\n\n    background: #606060;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 13px;\n\n    color: #ffffff;\n\n    cursor: pointer;\n`;\n\nexport const ActionButton = styled.span`\n    flex: 1;\n\n    height: 48px;\n    line-height: 48px;\n\n    text-align: center;\n\n    background: #3bc1ff;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 13px;\n\n    color: #ffffff;\n\n    > img {\n        margin-right: 6px;\n\n        width: 18px;\n        height: 18px;\n        object-fit: contain;\n    }\n\n    cursor: pointer;\n`;\n\nexport const IntroduceSection = styled.div`\n    display: flex;\n    align-items: center;\n\n    margin-bottom: 40px;\n\n    > div {\n        width: 50%;\n        flex: 1;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const IntroduceSectionFst = styled(IntroduceSection)`\n    div.text-block {\n        @media (max-width: 768px) {\n            order: 2;\n            width: 100%;\n\n            p {\n                text-align: center;\n            }\n        }\n    }\n\n    div.img-block {\n        position: relative;\n        text-align: center;\n\n        display: flex;\n        align-items: center;\n        height: 100px;\n\n        img {\n            position: absolute;\n            bottom: -50px;\n\n            left: 5%;\n\n            width: 50%;\n            object-fit: contain;\n        }\n\n        @media (max-width: 768px) {\n            order: 1;\n            width: 100%;\n            justify-content: center;\n\n            margin-bottom: 14px;\n\n            > img {\n                position: initial;\n            }\n        }\n    }\n`;\n\nexport const IntroduceSectionSnd = styled(IntroduceSection)`\n    div.text-block {\n        @media (max-width: 768px) {\n            width: 100%;\n        }\n    }\n\n    div.img-block {\n        text-align: center;\n        width: 100%;\n\n        img {\n            width: 50%;\n            object-fit: cover;\n\n            @media (max-width: 768px) {\n                object-fit: contain;\n                margin-bottom: 14px;\n            }\n        }\n    }\n`;\n\nexport const IntroduceSectionTrd = styled(IntroduceSection)`\n    div.text-block {\n        @media (max-width: 768px) {\n            width: 100%;\n        }\n    }\n\n    div.img-block {\n        text-align: center;\n        width: 100%;\n\n        img {\n            width: 50%;\n            object-fit: cover;\n\n            @media (max-width: 768px) {\n                width: 65%;\n                object-fit: contain;\n                margin-bottom: 14px;\n            }\n        }\n    }\n`;\n\nexport const IntroduceTitle = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 22px;\n    line-height: 48px;\n\n    letter-spacing: -0.666667px;\n\n    color: rgba(0, 0, 0, 0.8);\n\n    @media (max-width: 768px) {\n        font-size: 18px;\n        line-height: 28px;\n        letter-spacing: -0.5px;\n    }\n`;\n\nexport const IntroduceContent = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: ${props => (props.small ? '13px' : '16px')};\n    line-height: ${props => (props.small ? '22px' : '30px')};\n\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-weight: bold;\n    }\n\n    @media (max-width: 768px) {\n        word-break: keep-all;\n        font-size: ${props => (props.small ? '12px' : '14px')};\n        line-height: ${props => (props.small ? '20px' : '23px')};\n    }\n`;\n\nexport const MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const DesktopBr = styled.br`\n    display: block;\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const SpecListRow = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    width: 100%;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const SpecWrapper = styled.div`\n    margin-bottom: 28px;\n    margin-right: 20px;\n\n    &:last-child {\n        margin-right: 0px;\n    }\n\n    width: calc((100% / 3) - (40px / 3));\n\n    @media (max-width: 768px) {\n        width: 100%;\n        margin-right: 0px;\n    }\n`;\n\nexport const SpecIndex = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 12px;\n    line-height: 16px;\n\n    letter-spacing: -0.333333px;\n    color: rgba(0, 0, 0, 0.2);\n\n    margin-bottom: 4px;\n`;\n\nexport const SpecTitleWrapper = styled.div`\n    display: flex;\n    align-items: center;\n\n    text-align: left;\n\n    > img {\n        width: 24px;\n        height: 24px;\n\n        margin-right: 8px;\n        object-fit: contain;\n    }\n\n    > span {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 20px;\n        line-height: 44px;\n\n        letter-spacing: -0.666667px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n`;\n\nexport const SpecContent = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 13px;\n    line-height: 22px;\n\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 0px;\n\n    > span {\n        font-weight: bold;\n    }\n\n    @media (max-width: 768px) {\n        br {\n            display: block;\n        }\n    }\n`;\n\nexport const ButtonWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    width: 360px;\n\n    > div,\n    span,\n    a {\n        width: calc(50% - 4px);\n    }\n\n    @media (max-width: 768px) {\n        margin: 0 auto;\n    }\n`;\n","import { message } from 'antd';\nimport React from 'react';\nimport styled from 'styled-components';\nimport swal from 'sweetalert2';\nimport Withmate from '../renew/img/new-gov-care.png';\n\nimport { PartnerListRow } from '../../home.styled';\n\nexport const UserSiteBanner = ({ }) => {\n    \n    // const baseUrl = '/assets/images/partners/';\n    // const fstRow = [\n    //     baseUrl + 'new-goyang.png',\n    //     baseUrl + 'ajuuniv.png',\n    //     baseUrl + 'new-gov-care.png',\n    //     baseUrl + 'new-goyang-happy.png',\n    //     baseUrl + 'new-goyang-society.png',\n    // ];\n    // const sndRow = [\n    //     baseUrl + 'new-junglang-woman.png',\n    //     baseUrl + 'new-paju_woman.png',\n    //     baseUrl + 'new-beatus.png',\n    //     baseUrl + 'new-cheongdam.png',\n    //     baseUrl + 'new-hyo-hospital.png',\n    // ];\n\n    return (\n        <UserMainContainer>\n            <UserMainInnerContainer>\n                <PartnerTitle>\n                    <span>위드메이트 파트너</span>\n                </PartnerTitle>\n\n                <PartnerListRow>\n                    <BannerButton type=\"button\" onClick={() => {\n                            //window.location.href = \"http://www.naver.com\" // 현재 페이지에서 열기\n                            window.open(\"http://www.naver.com\") //새로운 창에서 열기\n                    }}/>\n                    <BannerButton type=\"button\" onClick={() => {\n                        window.location.href = \"http://www.daum.net\"\n                    }}/>\n                    <BannerButton type=\"button\" onClick={() => {\n                        window.location.href = \"http://www.google.com\"\n                    }}/>\n                    <BannerButton type=\"button\" onClick={() => {\n                        window.location.href = \"http://www.nate.com\"\n                    }}/>\n                </PartnerListRow>\n                <br/><br/>\n                <PartnerListRow>\n                    <BannerButton type=\"button\" onClick={() => {\n                            window.location.href = \"http://www.naver.com\"\n                    }}/>\n                    <BannerButton type=\"button\" onClick={() => {\n                        window.location.href = \"http://www.naver.com\"\n                    }}/>\n                    <BannerButton type=\"button\" onClick={() => {\n                        window.location.href = \"http://www.naver.com\"\n                    }}/>\n                    <BannerButton type=\"button\" onClick={() => {\n                        window.location.href = \"http://www.naver.com\"\n                    }}/>\n                </PartnerListRow>\n            </UserMainInnerContainer>\n        </UserMainContainer>\n    );\n};\n\nconst UserMainContainer = styled.div`\n    width: 100%;\n    height: 350px;\n\n    background: #fff;\n\n    @media (max-width: 768px) {\n        height: 598px;\n    }\n`;\n\nconst UserMainInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    height: 100%;\n    margin: 0 auto;\n\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: 22px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        padding-top: 52px;\n        align-items: center;\n        background: transparent;\n    }\n`;\n\nconst ButtonCommon = styled.div`\n    display: flex;\n    padding: 20px 24px;\n    width: 210px;\n    align-items: center;\n    justify-content: space-between;\n\n    border-radius: 4px;\n    margin-right: 70px;\n    cursor: pointer;\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n\n    &:hover {\n        box-shadow: 4px 10px 24px -4px rgba(0, 0, 0, 0.1);\n        transition: all 0.3s;\n    }\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst BannerButton = styled(ButtonCommon)`\n    background-image: url(${Withmate});\n    width: 210px;\n    height: 65px;\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n    }\n`;\n\nexport const PartnerTitle = styled.div`\n    display: flex;\n    flex-direction: column;\n    width: auto;\n\n    align-items: center;\n    margin-top: 10px;\n    margin-bottom: 46px;\n\n    > span {\n        font-size: 24px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.3;\n        letter-spacing: -0.5px;\n        text-align: center;\n        color: #3bc1ff;\n    }\n\n    @media (max-width: 1120px) {\n        width: 100%;\n        text-align: left;\n    }\n`;\n\n","import React from 'react';\nimport CountUp from 'react-countup';\nimport styled from 'styled-components';\n\nimport { DivisionLine, WithmateLabel } from '../../../../Components/Common/input';\n\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faUsers, faHospitalUser } from '@fortawesome/free-solid-svg-icons';\nimport { faRectangleList } from '@fortawesome/free-regular-svg-icons';\n\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport SwiperCore, { Pagination, Navigation, Autoplay } from 'swiper';\nimport 'swiper/swiper-bundle.min.css';\nimport 'swiper/swiper.min.css';\nimport 'swiper/components/navigation/navigation.min.css';\nimport 'swiper/components/pagination/pagination.min.css';\nimport { MobileBr } from '../../home.styled';\nimport { Button } from 'antd';\n\nSwiperCore.use([Navigation, Pagination, Autoplay]);\n\nexport const UserNumberCount = () => {\n    function handleClick(e) {\n        window.location.href = '/review/list';\n    }\n\n    return (\n        <div className='container' style={{ height: '700px' }}>\n            <RollingContainer>\n                <div className='numberCount' style={{ textAlign: 'center' }}>\n                    <NumberLabel>\n                        <FontAwesomeIcon icon={faHospitalUser} style={{ paddingRight: '6px' }} />총 가입자 수\n                    </NumberLabel>\n                    <br />\n                    <CountUp className='numberCount' end={1557} suffix=' 명' style={{ fontWeight: 'bold' }} />\n                </div>\n\n                <div className='numberCount' style={{ textAlign: 'center', paddingLeft: '7%' }}>\n                    <NumberLabel>\n                        <FontAwesomeIcon icon={faUsers} style={{ paddingRight: '6px' }} />\n                        메이트 수\n                    </NumberLabel>\n                    <br />\n                    <CountUp end={612} suffix=' 명' style={{ fontWeight: 'bold' }} />\n                </div>\n\n                <div className='numberCount' style={{ textAlign: 'center', paddingLeft: '7%' }}>\n                    <NumberLabel>\n                        <FontAwesomeIcon icon={faRectangleList} style={{ paddingRight: '6px' }} />총 이용 건수\n                    </NumberLabel>\n                    <br />\n                    <CountUp end={5000} suffix=' 건 <i class=\"fa-solid fa-arrow-up\" style=\"color: #3bc1ff\"></i>' style={{ fontWeight: 'bold' }} />\n                </div>\n            </RollingContainer>\n            <SatisfactionContainer>\n                <SatisfactionLabel>\n                    만족도 200% 이용 후기와 서비스 만족도 98% <MobileBr />\n                    \"위드메이트\" 에게 맡겨주세요\n                </SatisfactionLabel>\n            </SatisfactionContainer>\n\n            <DivisionLine />\n\n            <ReviewContainer>\n                <Swiper\n                    direction={'horizontal'} // 슬라이드의 방향을 수직으로 설정합니다.\n                    spaceBetween={10}\n                    slidesPerView={1}\n                    breakpoints={{\n                        768: {\n                            slidesPerView: 1,\n                            spaceBetween: -50,\n                        },\n                    }}\n                    pagination={{ clickable: true }} // 우측의 점을 클릭했을 때, 클릭한 슬라이드로 이동하게 됩니다.\n                    navigation\n                    modules={[Pagination]} // 페이지네이션, 마우스휠등을 사용하려면 모듈을 import해줘야 합니다.\n                    allowTouchMove // 터치 동작을 허용합니다.\n                    className='main_slider'\n                    threshold={20} // 터치 감도를 조정합니다. 숫자가 클수록 터치에 반응하지 않습니다.\n                    autoplay={{ delay: 1500 }}\n                    loop={true}\n                    speed={1000} // 슬라이드가 넘어가는 속도를 조정합니다. 단위는 ms입니다.\n                >\n                    <SwiperSlide>\n                        <ReviewMainContainer>\n                            <ReviewMainInnerContainer>\n                                <ImgStyle>\n                                    <img src={'/assets/images/review/review1.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                                </ImgStyle>\n                            </ReviewMainInnerContainer>\n                        </ReviewMainContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review2.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review3.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review4.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review5.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review6.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n                </Swiper>\n            </ReviewContainer>\n            <DivisionLine />\n\n            <Button\n                type='primary'\n                style={{\n                    justifyContent: 'center',\n                    alignItems: 'center',\n                    display: 'flex',\n                    margin: '0 auto',\n                    width: '200px',\n                    height: '46px',\n                    borderRadius: '10px',\n                    fontSize: '20px',\n                }}\n                onClick={handleClick}\n            >\n                이용후기 더보기\n            </Button>\n        </div>\n    );\n};\n\nconst ReviewContainer = styled.div`\n    width: 42%;\n    margin-top: 10px;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    margin: 0 auto;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nconst ReviewMainContainer = styled.div`\n    width: 100%;\n    height: 330px;\n\n    @media (max-width: 768px) {\n        height: 330px;\n    }\n`;\n\nconst ReviewMainInnerContainer = styled.div`\n    max-width: 500px;\n    height: 100%;\n    margin: 0 auto;\n\n    padding-top: 10px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst RollingContainer = styled.div`\n    padding-top: 10px;\n    padding-bottom: 20px;\n    justify-content: center;\n    display: flex;\n    flex-direction: initial;\n    background-color: #f9f9f9;\n\n    .numberCount {\n        font-size: 35px;\n    }\n\n    @media (max-width: 768px) {\n        justify-content: center;\n\n        .numberCount {\n            font-size: 20px;\n        }\n    }\n`;\n\nconst ImgStyle = styled.div`\n    width: 330px;\n    height: auto;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    margin: 0 auto;\n\n    @media (max-width: 768px) {\n        width: 280px;\n        height: auto;\n    }\n`;\n\nconst SatisfactionContainer = styled.label`\n    padding-top: 20px;\n    justify-content: center;\n    display: flex;\n    flex-direction: initial;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst SatisfactionLabel = styled.label`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 20px;\n    font-weight: bold;\n    text-align: center;\n\n    @media (max-width: 768px) {\n        font-size: 15px;\n    }\n`;\n\nconst NumberLabel = styled.label`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 20px;\n\n    @media (max-width: 768px) {\n        font-size: 12px;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { fontSize } from '../../../theme';\n\n// components\nimport { PartnerContainer, PartnerInnerContainer, PartnerTitle, PartnerListRow, PartnerItem } from '../home.styled';\n\nexport const WithmatePartners = ({}) => {\n    const baseUrl = '/assets/images/partners/';\n    const fstRow = [\n        baseUrl + 'new-gov-care.png',\n        baseUrl + 'new-goyang.png',\n        baseUrl + 'new-cancel.png',\n        baseUrl + 'aju.png',\n        baseUrl + 'new-goyang-happy.png',\n    ];\n    const sndRow = [\n        baseUrl + 'new-junglang-woman.png',\n        baseUrl + 'new-paju_woman.png',\n        baseUrl + 'new-beatus.png',\n        baseUrl + 'new-cheongdam.png',\n        baseUrl + 'new-hyo-hospital.png',\n    ];\n\n    const trdRow = [baseUrl + 'ssn.png', baseUrl + 'limo-korea.png', baseUrl + 'help-you.png', baseUrl + 'errichi.png', baseUrl + 'new-imagine-us.png'];\n\n    const fthRow = [baseUrl + 'iu-hosp.png', baseUrl + 'new-gpcop.png', baseUrl + 'goyohanM.png', baseUrl + 'carehouse.jpeg', baseUrl + 'bravo.png'];\n\n    const ftfRow = [baseUrl + 'dlive.png', baseUrl + 'sungmo.png', baseUrl + 'metlife.png', baseUrl + 'aju_nursing_hospital.png', baseUrl + 'yongin.png'];\n\n    return (\n        <PartnerContainer id='partners'>\n            <PartnerInnerContainer>\n                <PartnerTitle>\n                    <span>\n                        <img src='/assets/images/partners_map.png' style={{ width: '32px', height: 'auto', paddingBottom: '10px' }} /> 파트너사\n                    </span>\n                    <p style={{ color: '#a9a9a9', fontSize: '18px' }}>위드메이트와 함께하는 협력 파트너사입니다.</p>\n                </PartnerTitle>\n                <PartnerListRow>\n                    <PartnerItem>\n                        <img src={fstRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[4]} />\n                    </PartnerItem>\n                </PartnerListRow>\n            </PartnerInnerContainer>\n        </PartnerContainer>\n    );\n};\n","import React from 'react';\nimport { message as Message } from 'antd';\n\nimport { MATE } from '../../Lib/variables';\nimport axios from '../../Lib/axios';\nimport Slider from 'react-slick';\nimport \"slick-carousel/slick/slick.css\";\nimport \"slick-carousel/slick/slick-theme.css\";\n\n// section\nimport Reserve from './Section/reserve';\nimport { UserMain as RenewMain } from './Section/renew/main';\nimport { UserVideoSection } from './Section/renew/video';\nimport { UserGuideSection } from './Section/renew/guide';\nimport { UserMainBanner } from './Section/renew/banner';\nimport { UserSiteBanner } from './Section/renew/siteBanner';\nimport { UserNumberCount } from './Section/renew/numberCount';\n\n// import Main from './Section/userMain';\nimport { WithmatePartners } from './Section/partners';\n// import { Services } from './Section/services';\n// import { Introduce } from './Section/introduce';\n// import { WithmateSpecs } from './Section/spec';\n\n// modal\nimport { EmergencyCorpSearchModal, ShareCarRequestModal } from '../../Components/modal';\nimport { ManagerPopup } from '../../Components/modal';\n\n// import MateMain from './Section/mateMain';\n// import Review from './Section/review';\n// import { CoCompany } from '../Company/Section/fifth';\n\nconst settings = {\n    dots: true,\n    arrows: true,\n    infinite: true,\n    speed: 800,\n    slidesToShow: 1,\n    slidesToScroll: 1,\n    autoplay: true,\n    autoplaySpeed: 5000,\n    pauseOnHover: true,\n};\n\nexport default class HomePage extends React.PureComponent {\n    state = {\n        searchModal: false,\n        emergencyList: [],\n        emergencyKeyword: '',\n        requestModal: false,\n        requestInfo: {\n            corp: '',\n            address: '',\n            manager: '',\n            contact: '',\n            message: '',\n        },\n    };\n\n    componentDidMount = async () => {\n        const { data } = await axios.get(`/v1/corp/list`);\n        if (!data) return null;\n\n        if (data && Array.isArray(data)) {\n            this.setState({\n                emergencyList: data,\n            });\n        }\n    };\n\n    onShareRequest = async () => {\n        const {\n            requestInfo: { corp, address, manager, contact, message },\n        } = this.state;\n        if (!corp || !address || !manager || !contact || !message) return Message.info('정보를 기입해주세요.');\n\n        const { data } = await axios.post('/v1/share/add', {\n            corp,\n            address,\n            manager,\n            contact,\n            message,\n        });\n\n        if (!data) {\n            return Message.error('일시적인 서버장애가 발생했습니다. 다시 시도해주세요.');\n        }\n\n        if (data === 'check parameters') {\n            return Message.warning('정보를 모두 기입해주세요.');\n        }\n\n        if (data === 'success') {\n            Message.success('셔틀 셰어링 서비스를 요청하였습니다.');\n\n            this.setState({\n                requestModal: false,\n                requestInfo: {\n                    corp: '',\n                    address: '',\n                    manager: '',\n                    contact: '',\n                    message: '',\n                },\n            });\n        }\n    };\n\n    render() {\n        const { requestInfo, emergencyKeyword, emergencyList } = this.state;\n        const { userType } = this.props.auth;\n\n        return (\n            <div id='#main'>\n                {/* <Slider {...settings}>\n                    <div>\n                        <UserSiteBanner />\n                    </div>\n                    <div>\n                        <RenewMain {...this.props} />\n                    </div>\n                </Slider> */}\n                {userType === MATE ? (\n                    <>\n                        <Reserve {...this.props} />\n                    </>\n                ) : (\n                    <>\n                        {/* <ManagerPopup /> */}\n                        <RenewMain {...this.props} />\n                        <UserNumberCount />\n                        {/* <UserSiteBanner /> */}\n                        <UserVideoSection />\n                        <UserGuideSection />\n                        <WithmatePartners />\n                        <UserMainBanner\n                            goPage={() => {\n                                this.props.history.push('/nemt/service');\n                            }}\n                        />\n                        {/* <Main {...this.props} /> */}\n                        {/* <Introduce /> */}\n                        {/* <WithmateSpecs /> */}\n                    </>\n                )}\n\n                {this.state.searchModal ? (\n                    <EmergencyCorpSearchModal\n                        data={emergencyList}\n                        keyword={emergencyKeyword}\n                        inputHandler={value => {\n                            this.setState({ emergencyKeyword: value });\n                        }}\n                        visibleHandler={() => {\n                            this.setState({ searchModal: false });\n                        }}\n                    />\n                ) : null}\n\n                {this.state.requestModal ? (\n                    <ShareCarRequestModal\n                        data={requestInfo}\n                        visibleHandler={() => {\n                            this.setState({ requestModal: false });\n                        }}\n                        inputHandler={({ type, value }) => {\n                            this.setState(prevState => ({\n                                requestInfo: {\n                                    ...prevState.requestInfo,\n                                    [type]: value,\n                                },\n                            }));\n                        }}\n                        onSave={this.onShareRequest}\n                    />\n                ) : null}\n            </div>\n        );\n    }\n}\n","import axios from '../axios';\n\nexport const getUserInfo = ({ id, userType }) => {\n    return axios.get(`/v1/user/${id}/${userType}`);\n};\n\nexport const modifyUserInfo = async ({ id, userType, info }) => {\n    if (info.photo) {\n        const { data } = await imageUpload(info.photo);\n        info.photo = data;\n    }\n\n    return axios.post('/v1/user/modify/info', { id, userType, info });\n};\n\nexport const serviceInfo = ({ code }) => {\n    return axios.get('/v1/service/product/list', { params: { code } });\n};\n\nexport const buyTicket = ({ userId, info }) => {\n    return axios.post('/v1/service/buy/ticket', { userId, info });\n};\n\nexport const serviceReserve = ({ userId, info }) => {\n    return axios.post('/v1/service/reserve', { userId, info });\n};\n\nexport const reserveList = ({ userId }) => {\n    return axios.get('/v1/service/user/reserve/history', { params: { userId } });\n};\n\nexport const getReserve = ({ reserveId, userId }) => {\n    return axios.get('/v1/service/user/reserve', { params: { reserveId, userId } });\n};\n\nexport const getReserveList = ({ userId }) => {\n    return axios.get('/v1/service/user/reserve/list', { params: { userId } });\n};\n\nexport const serviceRequest = ({ impUid, buyerId, info }) => {\n    // return axios.post('/v1/service/request', { impUid, buyerId, info });\n};\n\nexport const payHistory = ({ userId }) => {\n    return axios.get('/v1/service/user/pay/history', { params: { userId } });\n};\n\nexport const mateReserveList = ({ mateId }) => {\n    return axios.get('/v1/service/mate/call/list', { params: { mateId } });\n};\n\nexport const mateCallReserveList = ({ mateId, page }) => {\n    return axios.get('/v1/service/mate/reserve/list', { params: { mateId, page } });\n};\n\nexport const acceptCall = ({ callId, mateId }) => {\n    return axios.put('/v1/service/mate/accept/call', { callId, mateId });\n};\n\nexport const completeCall = ({ callId }) => {\n    return axios.put('/v1/service/mate/complete/call', { callId });\n};\n\nexport const modifyReserve = ({ reserveId, info }) => {\n    return axios.put('/v1/service/user/reserve/modify', { reserveId, info });\n};\n\nexport const cancelReserve = ({ callId }) => {\n    return axios.put('/v1/service/user/reserve/cancel', { callId });\n};\n\nexport const cancelCall = ({ callId }) => {\n    return axios.put('/v1/service/mate/reserve/cancel', { callId });\n};\n\nexport const imageUpload = file => {\n    const formData = new FormData();\n    formData.append('photo', file);\n    const header = { headers: { 'Content-Type': 'multipart/form-data' } };\n    return axios.post('/v1/common/image/upload', formData, header);\n};\n\nexport const getPartnerServices = () => {\n    return axios.get('/v1/partner/service/list');\n};\n\nexport const getContractServices = ({ service, mateId }) => {\n    return axios.get(`/v1/partner/${service}/reserve/list`, {\n        params: {\n            mateId,\n        },\n    });\n};\n","import axios from '../axios';\nimport { MATE } from '../variables';\n\n//type: 로그인방식\nexport const register = async ({\n    termsOfUse,\n    privacyPolicy,\n    essentialGeneral,\n    essentialSensitive,\n    selectiveGeneral,\n    selectiveSensitive,\n    selectiveAdvertise,\n    id,\n    password,\n    userType,\n    name,\n    code,\n    identify,\n    reason,\n    type,\n    photo,\n    contact,\n    marketing,\n    connection,\n    recommenderName,\n    longtermCare,\n    birth,\n    email,\n}) => {\n    const config = {\n        termsOfUse,\n        privacyPolicy,\n        essentialGeneral,\n        essentialSensitive,\n        selectiveGeneral,\n        selectiveSensitive,\n        selectiveAdvertise,\n        id,\n        password,\n        userType,\n        name,\n        type,\n        photo,\n        contact,\n        marketing,\n        connection,\n        recommenderName,\n        longtermCare,\n        birth,\n        email,\n        code,\n        identify,\n        reason,\n        urlSource: window.location.search === '?url_source=dlive' ? 'dlive' : window.location.search === '?url_source=metlife' ? 'metlife' : 'withmate',\n    };\n\n    if (userType === MATE && photo) {\n        const result = await imageUpload(photo);\n        config.photo = result.data;\n    }\n\n    return axios.post('/v1/auth/register', config);\n};\n\nexport const addPatient = async ({ id, relate, name, sex, age, contact, starting, environment, caution }) => {\n    const config = {\n        id,\n        relate,\n        name,\n        sex,\n        age,\n        contact,\n        starting,\n        environment,\n        caution,\n    };\n\n    return axios.post('/v1/auth/patient/profile', config);\n};\n\nexport const addCard = async ({ id, userName, cardName, cardNum, year, month }) => {\n    const config = {\n        id,\n        userName,\n        cardName,\n        cardNum,\n        year,\n        month,\n    };\n\n    return axios.post('/v1/auth/card/add', config);\n};\n\nexport const getCardInfo = async ({ cardId, info }) => {\n    return axios.get('/v1/auth/card/list/info', { cardId, info });\n};\n\nexport const fetchCard = async ({ id }) => {\n    return axios.get('/v1/auth/card/list', { params: { id } });\n};\n\nexport const deleteCard = async ({ cardId }) => {\n    return axios.post('/v1/auth/card/info/delete', { cardId });\n};\n\nexport const modifyCard = async ({ cardId, info }) => {\n    return axios.post('/v1/auth/card/info/modify', { cardId, info });\n};\n\nexport const getMateInfo = async ({ mateId, info }) => {\n    return axios.get('/v1/auth/mate/list/info', { mateId, info });\n};\n\nexport const fetchMate = async ({ id }) => {\n    return axios.get('/v1/auth/mate/list', { params: { id } });\n};\n\nexport const getPatientInfo = async ({ patientId, info }) => {\n    return axios.get('/v1/auth/patient/list/info', { patientId, info });\n};\n\nexport const fetchPatient = async ({ id }) => {\n    return axios.get('/v1/auth/patient/list', { params: { id } });\n};\n\nexport const deletePatient = async ({ patientId }) => {\n    return axios.post('/v1/auth/patient/info/delete', { patientId });\n};\n\nexport const modifyPatient = async ({ patientId, info }) => {\n    return axios.post('/v1/auth/patient/info/modify', { patientId, info });\n};\n\nexport const login = ({ id, password, userType, type }) => {\n    return axios.post('/v1/auth/login', { id, password, userType, type });\n};\n\nexport const logout = ({ id, userType }) => {\n    return axios.get('/v1/auth/logout', { params: { id, userType } });\n};\n\nexport const checkUserId = ({ id, userType, type }) => {\n    return axios.get('/v1/auth/validate/user', { params: { id, userType, type } });\n};\n\nexport const checkAuth = ({ id, userType }) => {\n    return axios.get('/v1/auth/authorized', { params: { id, userType } });\n};\n\nexport const findPassword = ({ id, userType }) => {\n    return axios.post('/v1/auth/find/password', { id, userType });\n};\n\nexport const confirmEmailAuth = ({ verificationCode }) => {\n    return axios.post('/v1/auth/register', { verificationCode });\n};\n\nexport const modifyPassword = ({ id, userType, password, newPassword }) => {\n    return axios.post('/v1/auth/modify/password', { id, userType, password, newPassword });\n};\n\nexport const withdrawl = ({ id, userType, password }) => {\n    return axios.post('/v1/auth/withdrawl', { id, userType, password });\n};\n\nexport const withdrawlKakao = ({ id, userType }) => {\n    return axios.post('/v1/auth/withdrawl/kakao', { id, userType });\n};\n\nexport const imageUpload = photo => {\n    const formData = new FormData();\n    formData.append('photo', photo);\n    const header = { headers: { 'Content-Type': 'multipart/form-data' } };\n    return axios.post('/v1/common/image/upload', formData, header);\n};\n\nexport const onAddLongTermCare = async ({ userId, info }) => {\n    return axios.post('/v1/longTermCare/add', { userId, info });\n};\n","import jwt from 'jsonwebtoken';\nimport * as authAPI from './Api/auth';\n\nexport function createReduxThunk(type, request) {\n    const SUCCESS = `${type}_SUCCESS`;\n    const FAILURE = `${type}_FAILURE`;\n\n    return params => async dispatch => {\n        dispatch({ type: 'app/LOADING_ON' });\n        if (!request) {\n            return dispatch({ type });\n        }\n\n        try {\n            const response = await request(params);\n\n            if (response.data === 'expired token' || response.data === 'invalid token') {\n                const refreshToken = localStorage.getItem('refreshToken');\n                const decoded = jwt.decode(refreshToken);\n                if (decoded && decoded.id) {\n                    try {\n                        const result = await authAPI.checkAuth({ id: decoded.id, refreshToken });\n                        if (result.data === 'invalid') {\n                            localStorage.clear();\n                            window.location.href = '/';\n                            return null;\n                        }\n\n                        localStorage.setItem('accessToken', result.data.accessToken);\n                        // 재요청\n                        try {\n                            const response = await request(params);\n                            dispatch({\n                                type: SUCCESS,\n                                payload: response.data,\n                                meta: params,\n                            });\n                            dispatch({ type: 'app/LOADING_OFF' });\n                            return response.data;\n                        } catch (e) {\n                            dispatch({\n                                type: FAILURE,\n                                payload: e,\n                                error: true,\n                            });\n                            dispatch({ type: 'app/LOADING_OFF' });\n                            throw e;\n                        }\n                    } catch (error) {\n                        console.log('error: ', error);\n                    }\n                }\n            }\n\n            dispatch({\n                type: SUCCESS,\n                payload: response.data,\n                meta: params,\n            });\n            dispatch({ type: 'app/LOADING_OFF' });\n            return response.data;\n        } catch (e) {\n            dispatch({\n                type: FAILURE,\n                payload: e,\n                error: true,\n            });\n            dispatch({ type: 'app/LOADING_OFF' });\n            throw e;\n        }\n    };\n}\n","import { createAction, handleActions } from 'redux-actions';\nimport produce from 'immer';\nimport * as appAPI from '../../Lib/Api/app';\nimport _ from 'lodash';\n\n// middleware\nimport { createReduxThunk } from '../../Lib/middleware';\n\nconst USER_INFO = 'app/USER_INFO';\nconst USER_INFO_SUCCESS = 'app/USER_INFO_SUCCESS';\n\nconst MODIFY_USER_INFO = 'app/MODIFY_USER_INFO';\nconst MODIFY_USER_INFO_SUCCESS = 'app/MODIFY_USER_INFO_SUCCESS';\n\nconst SERVICE_INFO = 'app/SERVICE_INFO';\nconst SERVICE_INFO_SUCCESS = 'app/SERVICE_INFO_SUCCESS';\n\nconst SERVICE_RESERVE = 'app/SERVICE_RESERVE';\nconst SERVICE_RESERVE_SUCCESS = 'app/SERVICE_RESERVE_SUCCESS';\nconst SERVICE_RESERVE_USAGE = 'app/SERVICE_RESERVE_USAGE';\nconst SERVICE_RESERVE_USAGE_SUCCESS = 'app/SERVICE_RESERVE_USAGE_SUCCESS';\nconst SERVICE_RESERVE_LIST = 'app/SERVICE_RESERVE_LIST';\nconst SERVICE_RESERVE_LIST_SUCCESS = 'app/SERVICE_RESERVE_LIST_SUCCESS';\n\nconst RESERVE_INFO = 'app/RESERVE_INFO';\nconst RESERVE_INFO_SUCCESS = 'app/RESERVE_INFO_SUCCESS';\n\nconst CANCEL_CALL = 'app/CANCEL_CALL';\nconst CANCEL_CALL_SUCCESS = 'app/CANCEL_CALL_SUCCESS';\n\nconst CANCEL_RESERVE = 'app/CANCEL_RESERVE';\nconst CANCEL_RESERVE_SUCCESS = 'app/CANCEL_RESERVE_SUCCESS';\n\nconst MODIFY_RESERVE = 'app/MODIFY_RESERVE';\nconst MODIFY_RESERVE_SUCCESS = 'app/MODIFY_RESERVE_SUCCESS';\n\nconst MATE_CALL_RESERVE_LIST = 'app/MATE_CALL_RESERVE_LIST';\nconst MATE_CALL_RESERVE_LIST_SUCCESS = 'app/MATE_CALL_RESERVE_LIST_SUCCESS';\nconst MATE_SERVICE_RESERVE_LIST = 'app/MATE_SERVICE_RESERVE_LIST';\nconst MATE_SERVICE_RESERVE_LIST_SUCCESS = 'app/MATE_SERVICE_RESERVE_LIST_SUCCESS';\nconst MATE_ACCEPT_CALL = 'app/MATE_ACCEPT_CALL';\nconst MATE_ACCEPT_CALL_SUCCESS = 'app/MATE_ACCEPT_CALL_SUCCESS';\nconst MATE_COMPLETE_CALL = 'app/MATE_COMPLETE_CALL';\nconst MATE_COMPLETE_CALL_SUCCESS = 'app/MATE_COMPLETE_CALL_SUCCESS';\n\nconst PAY_HISTORY = 'app/PAY_HISTORY';\nconst PAY_HISTORY_SUCCESS = 'app/PAY_HISTORY_SUCCESS';\n\nconst BUY_TICKET = 'app/BUY_TICKET';\nconst BUY_TICKET_SUCCESS = 'app/BUY_TICKET_SUCCESS';\n\nconst GET_CONTRACT_PARTNERS = 'app/GET_CONTRACT_PARTNERS';\nconst GET_CONTRACT_PARTNERS_SUCCESS = 'app/GET_CONTRACT_PARTNERS_SUCCESS';\n\nconst GET_CONTRACT_SERVICE_LIST = 'app/GET_CONTRACT_SERVICE_LIST';\nconst GET_CONTRACT_SERVICE_LIST_SUCCESS = 'app/GET_CONTRACT_SERVICE_LIST_SUCCESS';\n\nconst EDIT_USER_FORM = 'app/EDIT_USER_FORM';\nconst EDIT_BUY_FORM = 'app/EDIT_BUY_FORM';\nconst EDIT_RESERVE_FORM = 'app/EDIT_RESERVE_FORM';\nconst EDIT_DETAIL_VIEW = 'app/EDIT_DETAIL_VIEW';\nconst EDIT_LATEST_VIEW = 'app/EDIT_LATEST_VIEW';\nconst EDIT_VIEW_TYPE = 'app/EDIT_VIEW_TYPE';\nconst EDIT_CALL_PAGE = 'app/EDIT_CALL_PAGE';\nconst EDIT_CONTRACT_FORM = 'app/EDIT_CONTRACT_FORM';\n\nconst LOADING_ON = 'app/LOADING_ON';\nconst LOADING_OFF = 'app/LOADING_OFF';\n\n// initalState\nconst initialState = {\n    userInfo: {},\n    serviceInfo: {},\n    reserveForm: {\n        page: 1,\n        service: 'assist',\n        addTime: 1,\n        payMethod: 'transfer',\n        sex: '남',\n        transport: 'common', // common, own\n        report: false,\n    },\n    reserve: {\n        unemergency: 0,\n        assist: 0,\n    },\n    contractForm: {\n        page: 1,\n        service: '',\n        addTime: 1,\n        payMethod: 'transfer',\n        sex: '남',\n        transport: 'common', // common, own\n        report: false,\n    },\n    buyForm: {\n        service: 'unemergency',\n        count: 1,\n    },\n    mateCallPage: 0,\n    mateCallList: [],\n    reserveList: [],\n    reserveInfo: {},\n    mateReserveList: [],\n    mateViewType: 'latest',\n    mateReserveLatest: {},\n    mateReserveDetail: {},\n    payHistory: [],\n    partners: [],\n    loading: false,\n    contractServices: [],\n};\n\nexport const getUserInfo = createReduxThunk(USER_INFO, appAPI.getUserInfo);\nexport const modifyUserInfo = createReduxThunk(MODIFY_USER_INFO, appAPI.modifyUserInfo);\n\nexport const getServiceInfo = createReduxThunk(SERVICE_INFO, appAPI.serviceInfo);\n\nexport const buyTicket = createReduxThunk(BUY_TICKET, appAPI.buyTicket);\nexport const getPayHistory = createReduxThunk(PAY_HISTORY, appAPI.payHistory);\n\nexport const serviceReserve = createReduxThunk(SERVICE_RESERVE, appAPI.serviceReserve);\nexport const getReserveUsage = createReduxThunk(SERVICE_RESERVE_USAGE, appAPI.reserveList);\nexport const getReserveList = createReduxThunk(SERVICE_RESERVE_LIST, appAPI.getReserveList);\nexport const getMateReserveList = createReduxThunk(MATE_SERVICE_RESERVE_LIST, appAPI.mateReserveList);\nexport const getMateCallReserveList = createReduxThunk(MATE_CALL_RESERVE_LIST, appAPI.mateCallReserveList);\nexport const getReserveInfo = createReduxThunk(RESERVE_INFO, appAPI.getReserve);\nexport const getContractPartners = createReduxThunk(GET_CONTRACT_PARTNERS, appAPI.getPartnerServices);\nexport const getContractList = createReduxThunk(GET_CONTRACT_SERVICE_LIST, appAPI.getContractServices);\n\nexport const acceptCall = createReduxThunk(MATE_ACCEPT_CALL, appAPI.acceptCall);\nexport const cancelCall = createReduxThunk(CANCEL_CALL, appAPI.cancelCall);\nexport const completeCall = createReduxThunk(MATE_COMPLETE_CALL, appAPI.completeCall);\nexport const modifyReserve = createReduxThunk(MODIFY_RESERVE, appAPI.modifyReserve);\nexport const cancelReserve = createReduxThunk(CANCEL_RESERVE, appAPI.cancelReserve);\n\nexport const editViewType = createAction(EDIT_VIEW_TYPE, input => input);\nexport const editResrveForm = createAction(EDIT_RESERVE_FORM, input => input);\nexport const editContractForm = createAction(EDIT_CONTRACT_FORM, input => input);\nexport const editBuyForm = createAction(EDIT_BUY_FORM, input => input);\nexport const editUserForm = createAction(EDIT_USER_FORM, input => input);\nexport const editReserveDetailView = createAction(EDIT_DETAIL_VIEW, input => input);\nexport const editReserveLatestView = createAction(EDIT_LATEST_VIEW, input => input);\nexport const editCallPage = createAction(EDIT_CALL_PAGE, input => input);\n\n// reducer\nconst appReducer = handleActions(\n    {\n        [LOADING_ON]: (state, action) =>\n            produce(state, draft => {\n                draft.loading = true;\n            }),\n        [LOADING_OFF]: (state, action) =>\n            produce(state, draft => {\n                draft.loading = false;\n            }),\n        [USER_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload._id) {\n                    draft['userInfo'] = payload;\n                }\n            }),\n        [MODIFY_USER_INFO_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const { photo, name, contact } = meta.info;\n                    draft['userInfo']['name'] = name;\n                    draft['userInfo']['contact'] = contact;\n                    if (photo) {\n                        draft['userInfo']['photo'] = photo;\n                    }\n                }\n            }),\n        [SERVICE_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && Array.isArray(payload) && payload.length > 0) {\n                    draft['serviceInfo'] = payload[0];\n                }\n            }),\n        [SERVICE_RESERVE_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    draft['reserveForm'] = {\n                        page: 1,\n                        service: 'unemergency',\n                        addTime: 1,\n                        payMethod: 'transfer',\n                        sex: '남',\n                    };\n                }\n            }),\n        [RESERVE_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['reserveInfo'] = payload;\n            }),\n        [SERVICE_RESERVE_USAGE_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && !_.isEmpty(payload)) {\n                    draft['reserve'] = payload;\n                }\n            }),\n        [SERVICE_RESERVE_LIST_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && !_.isEmpty(payload) && Array.isArray(payload)) {\n                    draft['reserveList'] = payload;\n                }\n            }),\n        [GET_CONTRACT_PARTNERS_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['partners'] = payload;\n                if (payload && Array.isArray(payload)) {\n                    localStorage.setItem('partners', JSON.stringify(payload));\n                }\n            }),\n        [GET_CONTRACT_SERVICE_LIST_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && !_.isEmpty(payload) && Array.isArray(payload)) {\n                    draft['contractServices'] = payload;\n                }\n            }),\n        [MATE_SERVICE_RESERVE_LIST_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && !_.isEmpty(payload) && Array.isArray(payload)) {\n                    draft['mateReserveList'] = payload;\n                }\n            }),\n        [MATE_CALL_RESERVE_LIST_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && !_.isEmpty(payload) && Array.isArray(payload)) {\n                    draft['mateCallList'] = payload;\n                }\n            }),\n        [MATE_ACCEPT_CALL_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const list = draft['mateReserveList'];\n                    draft['mateReserveList'] = list.map(l => {\n                        if (l._id === meta.callId) {\n                            l.status = '예약완료';\n                        }\n\n                        return l;\n                    });\n\n                    draft['mateReserveDetail']['status'] = '예약완료';\n                }\n            }),\n        [MATE_COMPLETE_CALL_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    if (payload && payload === 'success') {\n                        const list = draft['mateReserveList'];\n                        draft['mateReserveList'] = list.map(l => {\n                            if (l._id === meta.callId) {\n                                l.status = '서비스 종료';\n                            }\n\n                            return l;\n                        });\n                    }\n                }\n            }),\n        [PAY_HISTORY_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['payHistory'] = payload;\n            }),\n        [BUY_TICKET_SUCCESS]: (state, { payload }) => produce(state, draft => {}),\n        [CANCEL_CALL_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const list = draft['mateReserveList'];\n                    draft['mateReserveList'] = list.map(l => {\n                        if (l._id === meta.callId) {\n                            l.status = '접수대기';\n                        }\n\n                        return l;\n                    });\n                }\n            }),\n        [CANCEL_RESERVE_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                const list = draft['reserveList'];\n                draft['reserveList'] = list.map(l => {\n                    if (l.callId === meta.callId) l.call[0].status = '접수취소';\n                    return l;\n                });\n            }),\n        [MODIFY_RESERVE_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const list = draft['reserveList'];\n                    draft['reserveList'] = list.map(l => {\n                        if (l._id === meta.reserveId) {\n                            const { patient, relate, contact, comment, sex } = meta.info;\n                            l['patient'] = patient;\n                            l['relate'] = relate;\n                            l['contact'] = contact;\n                            l['comment'] = comment;\n                            l['sex'] = sex;\n\n                            if (meta.info && meta.info.starting) {\n                                const { starting, destination, reserveDate, usageTime } = meta.info;\n                                l['starting'] = starting;\n                                l['destination'] = destination;\n                                l['reserveDate'] = reserveDate;\n                                l['usageTime'] = usageTime;\n                            }\n\n                            return l;\n                        }\n\n                        return l;\n                    });\n                }\n            }),\n        [EDIT_RESERVE_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['reserveForm'] = {};\n                } else {\n                    draft['reserveForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_CONTRACT_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['contractForm'] = {};\n                } else {\n                    draft['contractForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_BUY_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['buyForm'] = {\n                        service: 'unemergency',\n                        count: 1,\n                    };\n                } else {\n                    draft['buyForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_USER_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['userInfo'] = {};\n                } else {\n                    draft['userInfo'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_DETAIL_VIEW]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['mateReserveDetail'] = {};\n                } else {\n                    draft['mateReserveDetail'] = payload.value;\n                }\n            }),\n        [EDIT_LATEST_VIEW]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['mateReserveLatest'] = payload.value;\n            }),\n        [EDIT_VIEW_TYPE]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['mateViewType'] = 'latest';\n                } else {\n                    draft['mateViewType'] = payload.value;\n                }\n            }),\n        [EDIT_CALL_PAGE]: (state, { payload }) =>\n            produce(state, draft => {\n                if (typeof payload === 'number') {\n                    draft['mateCallPage'] = payload;\n                }\n            }),\n    },\n    initialState,\n);\n\nexport default appReducer;\n","import { createAction, handleActions } from 'redux-actions';\nimport produce from 'immer';\nimport * as authAPI from '../../Lib/Api/auth';\nimport { USER, MATE } from '../../Lib/variables';\n\n// middleware\nimport { createReduxThunk } from '../../Lib/middleware';\n\nconst EDIT_LOGIN_FORM = 'auth/EDIT_LOGIN_FORM';\nconst EDIT_REGISTER_FORM = 'auth/EDIT_REGISTER_FORM';\n\nconst ADD_LONGTERMCARE = 'auth/ADD_LONGTERMCARE';\nconst ADD_LONGTERMCARE_SUCCESS = 'auth/ADD_LONGTERMCARE_SUCCESS';\n\n// 환자 프로필\nconst ADD_PATIENT = 'auth/ADD_PATIENT';\nconst ADD_PATIENT_SUCCESS = 'auth/ADD_PATIENT_SUCCESS';\nconst GET_PATIENT = 'auth/GET_PATIENT';\nconst GET_PATIENT_SUCCESS = 'auth/GET_PATIENT_SUCCESS';\nconst EDIT_ADD_PATIENT_FORM = 'auth/EDIT_ADD_PATIENT_FORM';\nconst DELETE_PATIENT = 'auth/DELETE_PATIENT';\nconst DELETE_PATIENT_SUCCESS = 'auth/DELETE_PATIENT_SUCCESS';\nconst MODIFY_PATIENT = 'auth/MODIFY_PATIENT';\nconst MODIFY_PATIENT_SUCCESS = 'auth/MODIFY_PATIENT_SUCCESS';\nconst PATIENT_INFO = 'auth/PATIENT_INFO';\nconst PATIENT_INFO_SUCCESS = 'auth/PATIENT_INFO_SUCCESS';\n\n// 카드 정보\nconst ADD_CARD = 'auth/ADD_CARD';\nconst ADD_CARD_SUCCESS = 'auth/ADD_CARD_SUCCESS';\nconst GET_CARD = 'auth/GET_CARD';\nconst GET_CARD_SUCCESS = 'auth/GET_CARD_SUCCESS';\nconst EDIT_ADD_CARD_FORM = 'auth/EDIT_ADD_CARD_FORM';\nconst DELETE_CARD = 'auth/DELETE_CARD';\nconst DELETE_CARD_SUCCESS = 'auth/DELETE_CARD_SUCCESS';\nconst MODIFY_CARD = 'auth/MODIFY_CARD';\nconst MODIFY_CARD_SUCCESS = 'auth/MODIFY_CARD_SUCCESS';\nconst CARD_INFO = 'auth/CARD_INFO';\nconst CARD_INFO_SUCCESS = 'auth/CARD_INFO_SUCCESS';\n\nconst MATE_INFO = 'auth/MATE_INFO';\nconst MATE_INFO_SUCCESS = 'auth/MATE_INFO_SUCCESS';\nconst GET_MATE = 'auth/GET_MATE';\nconst GET_MATE_SUCCESS = 'auth/GET_MATE_SUCCESS';\n\nconst EDIT_FINDPASSWORD_FORM = 'auth/EDIT_FINDPASSWORD_FORM';\nconst EDIT_PASSWORD_FORM = 'auth/EDIT_PASSWORD_FORM';\nconst EDIT_INFO = 'auth/EDIT_INFO';\nconst EDIT_AUTH = 'auth/EDIT_AUTH';\n\nconst LOGIN = 'auth/LOGIN';\nconst LOGIN_SUCCESS = 'auth/LOGIN_SUCCESS';\nconst LOGOUT = 'auth/LOGOUT';\nconst LOGOUT_SUCCESS = 'auth/LOGOUT_SUCCESS';\nconst VALIDATE_USER_ID = 'auth/VALIDATE_USER_ID';\nconst VALIDATE_USER_ID_SUCCESS = 'auth/VALIDATE_USER_ID_SUCCESS';\nconst REGISTER = 'auth/REGISTER';\nconst REGISTER_SUCCESS = 'auth/REGISTER_SUCCESS';\nconst CHECK_AUTH = 'auth/CHECK_AUTH';\nconst CHECK_AUTH_SUCCESS = 'auth/CHECK_AUTH_SUCCESS';\nconst FIND_PASSWORD = 'auth/FIND_PASSWORD';\nconst FIND_PASSWORD_SUCCESS = 'auth/FIND_PASSWORD_SUCCESS';\nconst MODIFY_PASSWORD = 'auth/MODIFY_PASSWORD';\nconst MODIFY_PASSWORD_SUCCESS = 'auth/MODIFY_PASSWORD_SUCCESS';\n\nconst USER_WITHDRAWL = 'auth/USER_WITHDRAWL';\nconst USER_WITHDRAWL_SUCCESS = 'auth/USER_WITHDRAWL_SUCCESS';\nconst KAKAO_WITHDRAWL = 'auth/KAKAO_WITHDRAWL';\nconst KAKAO_WITHDRAWL_SUCCESS = 'auth/KAKAO_WITHDRAWL_SUCCESS';\n\nconst CONFIRM_EMAILAUTH = 'auth/CONFIRM_EMAILAUTH';\nconst CONFIRM_EMAILAUTH_SUCCESS = 'auth/CONFIRM_EMAILAUTH_SUCCESS';\n\nexport const login = createReduxThunk(LOGIN, authAPI.login);\nexport const logout = createReduxThunk(LOGOUT, authAPI.logout);\nexport const register = createReduxThunk(REGISTER, authAPI.register);\n\nexport const checkUserId = createReduxThunk(VALIDATE_USER_ID, authAPI.checkUserId);\nexport const checkAuth = createReduxThunk(CHECK_AUTH, authAPI.checkAuth);\nexport const findPassword = createReduxThunk(FIND_PASSWORD, authAPI.findPassword);\nexport const modifyPassword = createReduxThunk(MODIFY_PASSWORD, authAPI.modifyPassword);\n\nexport const withdrawlUser = createReduxThunk(USER_WITHDRAWL, authAPI.withdrawl);\nexport const withdrawlKakao = createReduxThunk(KAKAO_WITHDRAWL, authAPI.withdrawlKakao);\n\nexport const confirmEmailAuth = createReduxThunk(CONFIRM_EMAILAUTH, authAPI.confirmEmailAuth);\n\nexport const editAuth = createAction(EDIT_AUTH, input => input);\nexport const editLoginForm = createAction(EDIT_LOGIN_FORM, input => input);\nexport const editRegisterForm = createAction(EDIT_REGISTER_FORM, input => input);\n\nexport const onEditLongTermCare = createAction(ADD_LONGTERMCARE, authAPI.onAddLongTermCare);\n\nexport const fetchPatient = createReduxThunk(GET_PATIENT, authAPI.fetchPatient);\nexport const addPatient = createReduxThunk(ADD_PATIENT, authAPI.addPatient);\nexport const editAddPatientForm = createAction(EDIT_ADD_PATIENT_FORM, input => input);\nexport const deletePatient = createReduxThunk(DELETE_PATIENT, authAPI.deletePatient);\nexport const modifyPatient = createReduxThunk(MODIFY_PATIENT, authAPI.modifyPatient);\nexport const getPatientInfo = createReduxThunk(PATIENT_INFO, authAPI.getPatientInfo);\n\nexport const fetchCard = createReduxThunk(GET_CARD, authAPI.fetchCard);\nexport const addCard = createReduxThunk(ADD_CARD, authAPI.addCard);\nexport const editAddCardForm = createAction(EDIT_ADD_CARD_FORM, input => input);\nexport const deleteCard = createReduxThunk(DELETE_CARD, authAPI.deleteCard);\nexport const modifyCard = createReduxThunk(MODIFY_CARD, authAPI.modifyCard);\nexport const getCardInfo = createReduxThunk(CARD_INFO, authAPI.getCardInfo);\n\nexport const getMateInfo = createReduxThunk(MATE_INFO, authAPI.getMateInfo);\nexport const fetchMate = createReduxThunk(GET_MATE, authAPI.fetchMate);\n\nexport const editFindPasswordForm = createAction(EDIT_FINDPASSWORD_FORM, input => input);\nexport const editPasswordForm = createAction(EDIT_PASSWORD_FORM, input => input);\nexport const editInfo = createAction(EDIT_INFO, input => input);\n\n// initalState\nconst initialState = {\n    id: '',\n    name: '',\n    photo: '',\n    userType: '',\n    allowed: null,\n    ticket: {\n        assist: 0,\n        unemergency: 0,\n    },\n\n    loginForm: {\n        userType: '',\n    },\n    registerForm: {\n        userType: USER,\n        page: 1,\n        sex: '남',\n        identify: '본인',\n        agree: false,\n    },\n\n    longTermCare: [],\n    longTermCareInfo: {},\n\n    patientList: [],\n    patientInfo: {},\n    addPatientForm: {\n        sex: '남'\n    },\n\n    cardList: [],\n    cardInfo: {},\n    addCardForm: {\n        cardName: '',\n        cardNum: '',\n        year: '',\n        month: ''\n    },\n\n    findForm: {\n        userType: USER,\n    },\n    passwordForm: {\n        password: '',\n        newPassword: '',\n        reNewPassword: '',\n    },\n    infoForm: {},\n\n    mateInfo: {},\n};\n\n// reducer\nconst authReducer = handleActions(\n    {\n        [EDIT_LOGIN_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['loginForm'] = {\n                        userType: USER,\n                    };\n                } else {\n                    draft['loginForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_REGISTER_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['registerForm'] = {\n                        userType: USER,\n                        page: 1,\n                        sex: '남',\n                        identify: '본인',\n                        agree: false,\n                    };\n                } else {\n                    draft['registerForm'][payload.type] = payload.value;\n                }\n            }),\n\n        [EDIT_ADD_PATIENT_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['addPatientForm'] = {\n                        sex: '남',\n                    };\n                } else {\n                    draft['addPatientForm'][payload.type] = payload.value;\n                }\n            }),\n\n        [EDIT_FINDPASSWORD_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['findForm'] = {\n                        userType: USER,\n                    };\n                } else {\n                    draft['findForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_PASSWORD_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['passwordForm'] = {};\n                } else {\n                    draft['passwordForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_INFO]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['infoForm'] = {};\n                } else {\n                    draft['infoForm'][payload.type] = payload.value;\n                }\n            }),\n        [EDIT_AUTH]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['id'] = '';\n                    draft['userType'] = '';\n                    draft['type'] = '';\n                    draft['photo'] = '';\n                    draft['name'] = '';\n                } else {\n                    draft[payload.type] = payload.value;\n                }\n            }),\n        [LOGIN_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload._id) {\n                    draft['id'] = payload._id;\n                    draft['photo'] = payload.photo;\n                    draft['name'] = payload.name;\n                    draft['type'] = payload.type;\n                    draft['userType'] = meta.userType;\n                    // if (payload.ticket) {\n                    //     draft['ticket'] = payload.ticket;\n                    // }\n\n                    localStorage.setItem('id', payload._id);\n                    localStorage.setItem('photo', payload.photo);\n                    localStorage.setItem('name', payload.name);\n                    localStorage.setItem('contact', payload.contact);\n                    localStorage.setItem('userType', meta.userType);\n\n                    window.location.href = '/';\n                }\n            }),\n        [USER_WITHDRAWL_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    draft['id'] = '';\n                    draft['userType'] = '';\n                    draft['photo'] = '';\n                    draft['name'] = '';\n                    draft['password'] = '';\n                    draft['allowed'] = false;\n                    localStorage.clear();\n                    window.location.href = '/';\n                }\n            }),\n        [KAKAO_WITHDRAWL_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    draft['id'] = '';\n                    draft['userType'] = '';\n                    draft['photo'] = '';\n                    draft['name'] = '';\n                    draft['allowed'] = false;\n                    localStorage.clear();\n                    window.location.href = '/';\n                }\n            }),\n        [LOGOUT_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    draft['id'] = '';\n                    draft['userType'] = '';\n                    draft['photo'] = '';\n                    draft['name'] = '';\n                    draft['allowed'] = false;\n                    localStorage.clear();\n                    window.location.href = '/';\n                }\n            }),\n        [VALIDATE_USER_ID_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                // console.log('VALIDATE_USER_ID_SUCCESS: ', payload);\n            }),\n            \n        [REGISTER_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    const { data } = payload;\n                    draft['id'] = data._id;\n                    draft['photo'] = data.photo;\n                    draft['name'] = data.name;\n                    draft['userType'] = meta.userType;\n                    draft['allowed'] = data.allowed;\n                    if (payload.ticket) {\n                        draft['ticket'] = payload.ticket;\n                    }\n\n                    localStorage.setItem('id', data._id);\n                    localStorage.setItem('photo', data.photo);\n                    localStorage.setItem('name', data.name);\n                    localStorage.setItem('allowed', data.allowed);\n                    localStorage.setItem('userType', meta.userType);\n\n                    // window.location.href = '/success';\n                }\n            }),\n\n        [ADD_LONGTERMCARE_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const list = draft['longTermCare'];\n                    draft['longTermCare'] = list.map(info => {\n                        const { name, age, contact, sex, region, gradePresence, gradeLevel } = meta.info;\n                        info['name'] = name;\n                        info['age'] = age;\n                        info['contact'] = contact;\n                        info['sex'] = sex;\n                        info['region'] = region;\n                        info['gradePresence'] = gradePresence;\n                        info['gradeLevel'] = gradeLevel;\n\n                        return info;\n                    })\n                }\n            }),\n\n        [CHECK_AUTH_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload._id) {\n                    draft['id'] = payload._id;\n                    draft['photo'] = payload.photo;\n                    draft['name'] = payload.name;\n                    draft['allowed'] = payload.allowed;\n                    draft['type'] = payload.type;\n                    draft['userType'] = meta.userType;\n                    if (payload.ticket) {\n                        draft['ticket'] = payload.ticket;\n                    }\n                } else {\n                    localStorage.clear();\n                    window.location.href = '/';\n                    return null;\n                }\n            }),\n        [FIND_PASSWORD_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                // console.log();\n            }),\n        [MODIFY_PASSWORD_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                // console.log();\n            }),\n\n        [CONFIRM_EMAILAUTH_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                // console.log();\n            }),\n\n        [ADD_PATIENT_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    draft['patientList'].push(payload.data);\n                }\n            }),\n\n        [GET_PATIENT_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    draft['patientList'] = payload.data;\n                }\n            }),\n\n        [PATIENT_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['patientInfo'] = payload.data;\n            }),\n\n        [MODIFY_PATIENT_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const list = draft['patientList'];\n                    draft['patientList'] = list.map(info => {\n                        if (info._id === meta.patientId) {\n                            const { name, relate, sex, age, contact, starting, environment, caution } = meta.info;\n                            info['name'] = name;\n                            info['relate'] = relate;\n                            info['sex'] = sex;\n                            info['age'] = age;\n                            info['contact'] = contact;\n                            info['starting'] = starting;\n                            info['environment'] = environment;\n                            info['caution'] = caution;\n\n                            return info;\n                        }\n                    })\n                }\n            }),\n\n        [DELETE_PATIENT_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    // draft['patientList'] = '';\n                    // window.location.href = '/user/mypage/profile';\n                }\n            }),\n\n        // 결제 카드 등록\n        [ADD_CARD_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    draft['cardList'].push(payload.data);\n                }\n            }),\n        \n        [EDIT_ADD_CARD_FORM]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.type === 'clear') {\n                    draft['addCardForm'] = {\n                        cardName: '',\n                        cardNum: '',\n                        year: '',\n                        month: ''\n                    };\n                } else {\n                    draft['addCardForm'][payload.type] = payload.value;\n                }\n            }),\n\n        [GET_CARD_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    draft['cardList'] = payload.data;\n                }\n            }),\n\n        [CARD_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['cardInfo'] = payload.data;\n            }),\n\n        [MODIFY_CARD_SUCCESS]: (state, { payload, meta }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    const list = draft['cardList'];\n                    draft['cardList'] = list.map(info => {\n                        if (info._id === meta.cardId) {\n                            const { cardName, cardNum, year, month } = meta.info;\n                            info['cardName'] = cardName;\n                            info['cardNum'] = cardNum;\n                            info['year'] = year;\n                            info['month'] = month;\n\n                            return info;\n                        }\n                    })\n                }\n            }),\n\n        [DELETE_CARD_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload === 'success') {\n                    // draft['patientList'] = '';\n                    // window.location.href = '/user/mypage/profile';\n                }\n            }),\n\n        [GET_MATE_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    draft['mateList'] = payload.data;\n                }\n            }),\n\n        [MATE_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['mateInfo'] = payload.data;\n            }),\n    },\n    initialState,\n);\n\nexport default authReducer;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\nimport { message } from 'antd';\n\n// component\nimport Home from './home';\nimport { MATE } from '../../Lib/variables';\n\n// styles\nimport HomeStyledContainer from './home.styled';\n\n// actions\nimport {\n    editResrveForm,\n    getServiceInfo,\n    serviceReserve,\n    getUserInfo,\n    // getMateReserveList,\n    // getMateCallReserveList,\n    getContractPartners,\n    acceptCall,\n    editReserveDetailView,\n    editReserveLatestView,\n    editViewType,\n    editCallPage,\n    editContractForm,\n} from '../../Reducer/Modules/app';\nimport { editAuth } from '../../Reducer/Modules/auth';\n\nclass HomeContainer extends React.PureComponent {\n    componentDidMount = () => {\n        const id = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n\n        if (id && userType === MATE) {\n        } else {\n            const prevList = localStorage.getItem('partners');\n            if (prevList) {\n                const list = JSON.parse(prevList);\n                this.props.editContractForm({ type: 'partners', value: list });\n            }\n\n            this.props.fetchPartners();\n        }\n    };\n\n    render() {\n        return (\n            <HomeStyledContainer>\n                <Home {...this.props} />\n            </HomeStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapStateToDispatch = dispatch => ({\n    editAuth: ({ type, value }) => dispatch(editAuth({ type, value })),\n    editForm: ({ type, value }) => dispatch(editResrveForm({ type, value })),\n    editLatest: ({ value }) => dispatch(editReserveLatestView({ value })),\n    editDetail: ({ value }) => dispatch(editReserveDetailView({ value })),\n    editViewType: ({ value }) => dispatch(editViewType({ value })),\n    editCallPage: value => dispatch(editCallPage(value)),\n    editContractForm: ({ type, value }) => dispatch(editContractForm({ type, value })),\n\n    getServiceInfo: ({ code }) => dispatch(getServiceInfo({ code })),\n    getUserInfo: ({ id, userType }) => dispatch(getUserInfo({ id, userType })),\n    fetchPartners: () => dispatch(getContractPartners()),\n    serviceReserve: ({ userId, info }) => dispatch(serviceReserve({ userId, info })),\n    // mateReserveList: ({ mateId }) => dispatch(getMateReserveList({ mateId })),\n    // mateCallList: ({ mateId, page }) => dispatch(getMateCallReserveList({ mateId, page })),\n    acceptCall: ({ mateId, callId }) => dispatch(acceptCall({ mateId, callId })),\n});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(HomeContainer);\n","import React from 'react';\n\nconst NotFoundPage = () => (\n    <div style={{ height: '100vh', padding: '100px' }}>\n        <img src='/assets/images/new_logo_img.png' alt='위드메이트 로고' style={{ width: '55px', height: 'auto' }} />\n        <p style={{ display: 'inline-block', verticalAlign: '-10px', paddingLeft: '10px', paddingBottom: '35px', color: 'skyblue', fontSize: '40px' }}>해당 페이지를 찾을 수 없습니다.</p>\n\n        <h3 style={{ paddingBottom: '5px' }}>원하시는 결과를 찾을 수 없습니다.</h3>\n        <h3>올바른 URL을 입력하였는지 확인하세요. 자세한 내용은 사이트 관리자에게 문의하시기 바랍니다.</h3>\n    </div>\n);\nexport default NotFoundPage;\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\nconst LoginStyledContainer = styled.div`\n    margin-top: 55px;\n    min-height: 100vh;\n    background-image: url('/assets/images/login_bg.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: 80% 50%;\n\n    @media (max-width: 480px) {\n        min-height: initial;\n        height: 100%;\n    }\n\n    .inner-container {\n        padding: 0px;\n        padding-top: 144px;\n        padding-bottom: 100px;\n\n        @media (max-width: 480px) {\n            padding: 0px;\n        }\n\n        .login-form {\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n            width: 100%;\n            max-width: 340px;\n            margin: 0 auto;\n            padding: 24px;\n\n            @media (max-width: 480px) {\n                max-width: initial;\n                width: 100%;\n                border-radius: 0px;\n                box-shadow: none;\n            }\n\n            .login-title {\n                margin-bottom: 24px;\n\n                p {\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n            }\n\n            .form {\n                label {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.15px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n\n                input {\n                    height: 40px;\n                    border: solid 1px #e6e6e6;\n                    // margin-bottom: 20px;\n                }\n\n                button {\n                    width: 100%;\n                    height: 46px;\n                    margin-top: 4px;\n                    margin-bottom: 16px;\n\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    letter-spacing: -0.2px;\n                    text-align: center;\n                    color: #ffffff;\n                }\n\n                .link-wrapper {\n                    display: flex;\n                    justify-content: center;\n\n                    .link {\n                        cursor: pointer;\n                        font-size: ${sizeHandler(12)};\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: rgba(0, 0, 0, 0.5);\n\n                        &:first-child {\n                            // border-right: 1px solid #e6e6e6;\n                            padding-right: 16px;\n                        }\n\n                        &:last-child {\n                            margin-left: 16px;\n                            color: ${mainColor};\n                        }\n                    }\n                }\n            }\n\n            .form-user-type {\n                height: 76px;\n                margin-bottom: 20px;\n                border-radius: 4px;\n                border: 1px solid #e6e6e6;\n                display: flex;\n                align-items: center;\n                overflow: hidden;\n\n                .type {\n                    flex: 1;\n                    height: 100%;\n                    line-height: 30px;\n                    background-color: #ffffff;\n                    cursor: pointer;\n\n                    &:first-child {\n                        border-right: 1px solid #e6e6e6;\n                    }\n\n                    p {\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        line-height: 40px;\n                        text-align: left;\n                        padding-left: 10px;\n                        color: #606060;\n                    }\n\n                    h5 {\n                        font-size: ${sizeHandler(12)};\n                        text-align: left;\n                        padding-left: 10px;\n                        color: #606060;\n                    }\n\n                    &.active {\n                        background-color: #606060;\n\n                        p {\n                            color: #ffffff;\n                        }\n\n                        h5 {\n                            color: white;\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\nexport default LoginStyledContainer;\n","import React from 'react';\nimport styled from 'styled-components';\n\nconst TabContainer = styled.div`\n    width: 100%;\n    height: 48px;\n\n    border: 1px solid #dddddd;\n    border-radius: 6px;\n    overflow: hidden;\n\n    display: flex;\n    align-items: center;\n`;\n\nconst Tab = styled.div`\n    flex: 1;\n    height: 100%;\n\n    cursor: pointer;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    background-color: ${props => (props.active ? '#3bc1ff' : '#ffffff')};\n\n    color: ${props => (props.active ? '#ffffff' : '#3bc1ff')};\n    font-size: 14px;\n    font-weight: bold;\n\n    transition: all 0.5s;\n`;\n\nexport { TabContainer, Tab };\n","import styled from 'styled-components';\n\nimport Pallete from '../../theme';\n\nconst H1 = styled.h1`\n    margin: 0px;\n    margin-bottom: 16px;\n\n    font-size: 26px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.5;\n\n    > span {\n        font-size: 26px;\n        font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n        line-height: 1.5;\n    }\n`;\n\nconst H2 = styled.h2`\n    margin: 0px;\n    margin-bottom: 16px;\n\n    font-size: 23px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.5;\n`;\n\nconst H3 = styled.h3`\n    margin: 0px;\n    margin-bottom: 12px;\n\n    font-size: 18px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.5;\n`;\n\nconst H4 = styled.h4`\n    margin: 0px;\n    margin-bottom: 8px;\n\n    font-size: 16px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.4;\n`;\n\nconst H5 = styled.h5`\n    margin: 0px;\n    margin-bottom: 8px;\n\n    font-size: 13px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.4;\n`;\n\nconst H6 = styled.h6`\n    margin: 0px;\n    margin-bottom: 4px;\n\n    font-size: 12px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.4;\n`;\n\nconst Text = styled.p`\n    margin: 0px;\n    margin-bottom: 0px;\n\n    font-size: 11px;\n    font-weight: ${props => (props.bold ? 'bold' : 'normal')};\n    line-height: 1.4;\n`;\n\nexport { H1, H2, H3, H4, H5, H6, Text };\n","import styled from 'styled-components';\nimport Pallete from '../../theme';\n\nconst Container = styled.div`\n    width: 100%;\n`;\n\nconst InnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    margin: 0 auto;\n`;\n\nexport { Container, InnerContainer };\n","export const isNotNumber = value => {\n    const regExp = /[a-z|ㄱ-ㅎ|ㅏ-ㅣ|가-힣]/g;\n    return regExp.test(value);\n};\n\nexport const celluarValidate = phone => {\n    const regExp = /^01(?:0|1|[6-9])[0-9]{4}[0-9]{4}$/;\n    const regExp2 = /^1(?:0|1|[6-9])[0-9]{4}[0-9]{4}$/;\n\n    const result = regExp.test(phone);\n    const result2 = regExp2.test(phone);\n\n    return result === true || result2 === true ? true : false;\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Select, ConfigProvider, DatePicker, message } from 'antd';\nimport holidayKR from 'holiday-kr';\nimport moment from 'moment';\nimport swal from 'sweetalert2';\nimport 'moment/locale/zh-cn';\nimport locale from 'antd/es/locale/ko_KR';\n\n// components\nimport {\n    DivisionLine,\n    WithmateLabel,\n    WithmateInput,\n    WithamteInputWithButton,\n    HalfWithmateInput,\n    WithmateTextarea,\n    WithmateSelect,\n    FlexWrapper,\n    HalfWithmateSelect,\n    WithmateDatePicker,\n    BorderDivisionLine,\n    StyledHotFix,\n    WithmateValue,\n    WithmateValueTip,\n} from '../Common/input';\nimport { H1, H2, H3, H4, H5, H6, Text } from '../Common/text';\nimport { Container } from '../Common/container';\nimport { TabContainer, Tab } from '../Common/tab';\nimport { FullWidthButton } from '../Common/button';\n\n// utils\nimport Pallete from '../../theme';\nimport { isNotNumber, celluarValidate } from '../../Lib/regex';\n\n// imgs\n\nmoment.lang('ko', {\n    weekdays: ['일요일', '월요일', '화요일', '수요일', '목요일', '금요일', '토요일'],\n    weekdaysShort: ['일', '월', '화', '수', '목', '금', '토'],\n});\n\nexport const Step1 = ({ data, inputDeepHandler, setDestination, setStarting }) => {\n    const { service, sex, relate, patient, contact, destination, starting } = data;\n\n    const onTab = tab => {\n        inputDeepHandler({ type: 'temp', deepType: 'service', value: tab });\n    };\n\n    const onSex = sex => {\n        inputDeepHandler({ type: 'temp', deepType: 'sex', value: sex });\n    };\n\n    const onRelation = relate => {\n        inputDeepHandler({ type: 'temp', deepType: 'relate', value: relate });\n    };\n\n    const destinationHandler = ev => {\n        inputDeepHandler({ type: 'temp', deepType: 'destination', value: ev.target.value });\n    };\n\n    const startingHandler = ev => {\n        inputDeepHandler({ type: 'temp', deepType: 'starting', value: ev.target.value });\n    };\n\n    const onEditShielder = () => {\n        const id = localStorage.getItem('id');\n        if (!id) return null;\n\n        inputDeepHandler({ type: '_temp', deepType: 'shielder', value: (data && data.shielder) || '' });\n        inputDeepHandler({ type: '_temp', deepType: 'onShieldModal', value: true });\n    };\n\n    const onNextStep = () => {\n        if (!localStorage.getItem('id')) {\n            return message.warning('로그인 후 이용해주세요');\n        }\n\n        const fix = [];\n        if (!relate) fix.push('relate');\n        if (!contact || !celluarValidate(contact)) fix.push('contact');\n        if (!patient) fix.push('patient');\n        if (!starting) fix.push('starting');\n        if (service === 'unemergency' && !destination) fix.push('destination');\n\n        inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n        if (fix.length > 0) return null;\n\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 2 });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                위드메이트와의\n                <br className='mobile-exist' />\n                병원 동행을 예약하세요\n            </H1>\n\n            <DivisionLine small />\n\n            <WithmateLabel required>서비스 선택</WithmateLabel>\n            <TabContainer>\n                <Tab\n                    active={data && data.service === 'unemergency'}\n                    onClick={() => {\n                        onTab('unemergency');\n                    }}\n                >\n                    Pro\n                </Tab>\n                <Tab\n                    active={data && data.service === 'assist'}\n                    onClick={() => {\n                        onTab('assist');\n                    }}\n                >\n                    Basic\n                </Tab>\n            </TabContainer>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel required>이용자 성함 / 성별</WithmateLabel>\n                <WithmateLabel required>관계</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <RelativeWrapper>\n                    <WithmateInput\n                        type='text'\n                        placeholder='ex) 홍길동'\n                        value={(data && data.patient) || undefined}\n                        onChange={ev => {\n                            if (ev.target.value && ev.target.value.length > 10) return null;\n\n                            inputDeepHandler({ type: 'temp', deepType: 'patient', value: ev.target.value });\n                        }}\n                    />\n\n                    <SigleButtonWrapper>\n                        <SigleButton\n                            active={data && data.sex === '남'}\n                            onClick={() => {\n                                onSex('남');\n                            }}\n                        >\n                            남\n                        </SigleButton>\n                        <SigleButton\n                            active={data && data.sex === '녀'}\n                            onClick={() => {\n                                onSex('녀');\n                            }}\n                        >\n                            녀\n                        </SigleButton>\n                    </SigleButtonWrapper>\n                </RelativeWrapper>\n                <WithmateSelect placeholder='-' value={(data && data.relate) || undefined} onChange={onRelation}>\n                    <Select.Option value='본인'>본인</Select.Option>\n                    <Select.Option value='부모'>부모</Select.Option>\n                    <Select.Option value='자매'>자매</Select.Option>\n                    <Select.Option value='친구'>친구</Select.Option>\n                    <Select.Option value='지인'>지인</Select.Option>\n                    <Select.Option value='기타'>기타</Select.Option>\n                </WithmateSelect>\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'patient') && (\n                <StyledHotFix>이용자 성함을 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'relate') && (\n                <StyledHotFix>환자와의 관계를 선택해주세요.</StyledHotFix>\n            )}\n            <DivisionLine small />\n\n            <WithmateLabel required>보호자(서비스를 신청한 사람) 연락처</WithmateLabel>\n            <WithamteInputWithButton\n                inputConfig={{\n                    type: 'text',\n                    disabled: true,\n                    placeholder: 'ex) 01029101234 (\"-\" 없이 입력해주세요)',\n                    value: data && data.shielder,\n                }}\n                buttonName='수정'\n                onButton={onEditShielder}\n                // value={(data && data.contact) || undefined}\n            />\n            <DivisionLine small />\n\n            <WithmateLabel required>환자(서비스를 받는 사람) 연락처</WithmateLabel>\n            <WithmateInput\n                type='text'\n                placeholder='ex) 01029101234 (\"-\" 없이 입력해주세요)'\n                value={(data && data.contact) || undefined}\n                onChange={ev => {\n                    const numValue = parseFloat(ev.target.value);\n                    if (typeof numValue !== 'number') return null;\n                    if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                        ev.preventDefault();\n                        return null;\n                    }\n                    if (ev.target.value.length > 11) return null;\n\n                    inputDeepHandler({ type: 'temp', deepType: 'contact', value: ev.target.value });\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'contact') && (\n                <StyledHotFix>올바른 휴대전화번호를 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine small />\n\n            <WithmateLabel required>병원 위치</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                onButton={setStarting}\n                inputConfig={{\n                    type: 'text',\n                    value: (data && data.starting) || undefined,\n                    placeholder: 'ex) 서울특별시 강남 을지병원',\n                    onChange: startingHandler,\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'starting') && (\n                <StyledHotFix>병원 위치를 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine small />\n\n            <WithmateLabel required={data && data.service === 'unemergency'}>자택 주소</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                onButton={setDestination}\n                inputConfig={{\n                    type: 'text',\n                    value: (data && data.destination) || undefined,\n                    placeholder: 'ex) 서울특별시 서초대로 30, ABC 아파트',\n                    onChange: destinationHandler,\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'destination') && (\n                <StyledHotFix>귀가시 자택 주소를 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                신청하기\n            </FullWidthButton>\n\n            <BorderDivisionLine small />\n\n            <FullWidthButton\n                bg={Pallete.dark60}\n                href='tel:070-4300-9075'\n                onClick={e => {\n                    if (window.innerWidth > 480) {\n                        e.preventDefault();\n                        e.stopPropagation();\n\n                        swal.fire({\n                            title: '고객 센터 연결 번호',\n                            text: '☎ 070-4300-9075',\n                            icon: 'info',\n                            confirmButtonText: '확인',\n                        });\n                    }\n                }}\n            >\n                전화 예약하기\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const Step2 = ({ data, inputDeepHandler }) => {\n    const { date, time, minute, sick, comment } = data;\n    const onNextStep = () => {\n        const fix = [];\n        if (!date) fix.push('date');\n        if (!sick) fix.push('sick');\n        if (!comment) fix.push('comment');\n        if (!time) fix.push('time');\n        if (time && time >= 18) fix.push('overtime');\n        if (!minute) fix.push('minute');\n\n        inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n        if (fix.length > 0) return null;\n\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 3 });\n    };\n\n    const onPrevStep = () => {\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 1 });\n    };\n\n    const onCalendar = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'date', value });\n    };\n\n    const sickHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'sick', value });\n    };\n\n    const commentHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'comment', value });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                병원 동행 예약을\n                <br className='mobile-exist' />\n                마무리 해주세요\n            </H1>\n\n            <WithmateLabel required>예약일자</WithmateLabel>\n            <ConfigProvider locale={locale}>\n                <WithmateDatePicker\n                    inputReadOnly\n                    style={{ width: '100%', height: '36px' }}\n                    value={(data && data.date) || undefined}\n                    placeholder='예약일자를 설정해주세요.'\n                    format='YYYY-MM-DD'\n                    onChange={onCalendar}\n                    disabledDate={current =>\n                        current < moment().add(0, 'day') ||\n                        current.get('day') === 0 ||\n                        current.get('day') === 6 ||\n                        holidayKR.isSolarHoliday(moment(current).toDate())\n                    }\n                />\n            </ConfigProvider>\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'date') && (\n                <StyledHotFix>예약일자를 선택해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>예약 시간</WithmateLabel>\n            <FlexWrapper withHalf>\n                <WithmateInput\n                    type='text'\n                    placeholder='ex) 16'\n                    value={(data && data.time) || undefined}\n                    style={{ marginRight: '4px' }}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 23) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'time', value: ev.target.value });\n                    }}\n                    suffix='시'\n                />\n                <WithmateInput\n                    type='text'\n                    placeholder='ex) 30'\n                    value={(data && data.minute) || undefined}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 60) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'minute', value: ev.target.value });\n                    }}\n                    suffix='분'\n                />\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'time' || r === 'minute') && (\n                <StyledHotFix>서비스 이용을 위한 예약 시간을 정확히 입력해주세요.</StyledHotFix>\n            )}\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'overtime') && (\n                <StyledHotFix>18시 이후의 서비스 예약은 불가능합니다.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>병명</WithmateLabel>\n            <WithmateInput\n                type='text'\n                placeholder='ex) 위암, 대장암, 팔 골절 등'\n                value={(data && data.sick) || undefined}\n                onChange={ev => {\n                    sickHandler(ev.target.value);\n                }}\n            />\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'sick') && (\n                <StyledHotFix>환자분의 병명을 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>병원 이름 및 상세내용</WithmateLabel>\n            <WithmateTextarea\n                type='text'\n                placeholder='병원 이름 및 상세 내용을 입력해주세요. 특히, 병원 이름을 반드시 기재해주세요 (ex. 서울대학교 병원)'\n                value={(data && data.comment) || undefined}\n                onChange={ev => {\n                    commentHandler(ev.target.value);\n                }}\n            />\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'comment') && (\n                <StyledHotFix>병원 이름 및 상세내용을 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                신청하기\n            </FullWidthButton>\n\n            <BorderDivisionLine small />\n\n            <FullWidthButton bg={Pallete.dark80} onClick={onPrevStep}>\n                이전으로\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const Step3 = ({ data, inputDeepHandler, onReserve }) => {\n    const addTimeSelector = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'addTime', value });\n    };\n    const transportHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'transport', value });\n    };\n\n    const getFee = () => {\n        const { addTime = '60', service } = data;\n        const minute = parseInt(addTime, 10);\n\n        const time = minute / 60;\n        let total = 0;\n        if (service === 'unemergency') {\n            total = time * 20000 + time * 20000 * 0.1;\n        } else {\n            total = time * 15000 + time * 15000 * 0.1;\n        }\n\n        if (data.transport === 'own' && data.service === 'unemergency') {\n            total += 20000;\n        }\n\n        return total;\n    };\n\n    const onSaveAndNext = () => {\n        const fix = [];\n        onReserve();\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                서비스 신청내용 확인\n            </H1>\n\n            <WithmateLabel>선택된 서비스</WithmateLabel>\n            <WithmateValue>{data && data.service === 'unemergency' ? '병원 동행 Pro' : '병원 동행 Basic'}</WithmateValue>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>이용자 성함</WithmateLabel>\n                <WithmateLabel>이용자와의 관계</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.patient) || undefined} />\n                <WithmateInput disabled value={(data && data.relate) || undefined} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>전화번호</WithmateLabel>\n                <WithmateLabel>병명</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.contact) || undefined} />\n                <WithmateInput disabled value={(data && data.sick) || undefined} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>병원 위치</WithmateLabel>\n                <WithmateLabel>자택 주소</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.destination) || undefined} />\n                <WithmateInput disabled value={(data && data.starting) || undefined} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>예약 일자</WithmateLabel>\n                <WithmateLabel>예약 시간</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.date && moment(data.date).format('YY. MM. DD')) || undefined} />\n                <WithmateInput disabled value={((data && data.time) || '00') + '시 ' + ((data && data.minute) || '00') + '분'} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <WithmateLabel>병원 이름 및 상세내용</WithmateLabel>\n            <WithmateTextarea disabled value={(data && data.comment) || undefined} />\n\n            <DivisionLine small />\n\n            <FullWidthButton\n                bg={Pallete.dark80}\n                onClick={() => {\n                    inputDeepHandler({ type: 'temp', deepType: 'step', value: 2 });\n                }}\n            >\n                이전으로\n            </FullWidthButton>\n\n            <DivisionLine />\n\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                예약 접수하기\n            </H1>\n\n            <WithmateLabel required bg={Pallete.blue50}>\n                예상 소요 시간\n            </WithmateLabel>\n            <WithmateSelect value={(data && data.addTime) || undefined} placeholder='예상 소요시간을 선택해주세요' onChange={addTimeSelector}>\n                <Select.Option value='60'>1시간</Select.Option>\n                <Select.Option value='90'>1시간 30분</Select.Option>\n                <Select.Option value='120'>2시간</Select.Option>\n                <Select.Option value='150'>2시간 30분</Select.Option>\n                <Select.Option value='180'>3시간</Select.Option>\n                <Select.Option value='210'>3시간 30분</Select.Option>\n                <Select.Option value='240'>4시간</Select.Option>\n                <Select.Option value='270'>4시간 30분</Select.Option>\n                <Select.Option value='300'>5시간</Select.Option>\n                <Select.Option value='330'>5시간 30분</Select.Option>\n                <Select.Option value='360'>6시간</Select.Option>\n                <Select.Option value='390'>6시간 30분</Select.Option>\n                <Select.Option value='420'>7시간</Select.Option>\n                <Select.Option value='450'>7시간 30분</Select.Option>\n                <Select.Option value='480'>8시간</Select.Option>\n            </WithmateSelect>\n\n            {data && data.service === 'unemergency' && (\n                <>\n                    <DivisionLine small />\n\n                    <WithmateLabel required>이동 수단 선택</WithmateLabel>\n                    <WithmateSelect\n                        value={(data && data.transport) || undefined}\n                        placeholder='서비스 이용간 이동 수단을 선택해주세요'\n                        onChange={transportHandler}\n                    >\n                        <Select.Option value='common'>대중교통 이용 (택시・버스 등)</Select.Option>\n                        <Select.Option value='own'>본인소유 자차 이용</Select.Option>\n                        {/* <Select.Option value='withcar'>위드메이트 차량 호출</Select.Option> */}\n                    </WithmateSelect>\n                    {data.transport && data.transport === 'own' && <AlertMessage>* 자차 이용시, 운전자 보험 변경 필수</AlertMessage>}\n                </>\n            )}\n\n            <DivisionLine small />\n\n            <WithmateLabel>총 예상비용</WithmateLabel>\n            <WithmateValue>₩ {getFee()}</WithmateValue>\n            <WithmateValueTip>(VAT 10% 포함된 가격입니다)</WithmateValueTip>\n\n            <DivisionLine small />\n\n            <WithmateLabel>결제수단</WithmateLabel>\n            <WithmateValue>계좌이체</WithmateValue>\n\n            <DivisionLine x_small />\n\n            <WithmateValueTip>- 입금계좌는 서비스 종료 후 안내됩니다.</WithmateValueTip>\n            <WithmateValueTip>- 카드 결제는 예약접수 후, 고객센터에 문의바랍니다.</WithmateValueTip>\n            <WithmateValueTip>- 환불 및 접수 취소에 대한 자세한 안내 사항은 FAQ에서 확인 가능합니다.</WithmateValueTip>\n            <WithmateValueTip>- 위드메이트는 후불제 서비스입니다.</WithmateValueTip>\n\n            <DivisionLine small />\n\n            <FullWidthButton bg={Pallete.blue50} onClick={onSaveAndNext}>\n                예약 접수하기\n            </FullWidthButton>\n            <WithmateValueTip style={{ color: 'red' }}>\n                * 위드메이트는 자율형 매칭 플랫폼으로, 예약접수 시 서비스 매칭 인력 배정이 보장되지 않음을 알려드립니다.\n            </WithmateValueTip>\n        </Container>\n    );\n};\n\nexport const ContractdStep_1 = ({ data, inputDeepHandler, setDestination, onDropoReserve }) => {\n    const { service, sex, relate, patient, contact, destination, starting } = data;\n\n    const onTab = tab => {\n        inputDeepHandler({ type: 'temp', deepType: 'service', value: tab });\n    };\n\n    const onSex = sex => {\n        inputDeepHandler({ type: 'temp', deepType: 'sex', value: sex });\n    };\n\n    const onRelation = relate => {\n        inputDeepHandler({ type: 'temp', deepType: 'relate', value: relate });\n    };\n\n    const destinationHandler = ev => {\n        inputDeepHandler({ type: 'temp', deepType: 'destination', value: ev.target.value });\n    };\n\n    const onNextStep = () => {\n        if (!localStorage.getItem('id')) {\n            return message.warning('로그인 후 이용해주세요');\n        }\n\n        const fix = [];\n        if (!relate) fix.push('relate');\n        if (!contact || !celluarValidate(contact)) fix.push('contact');\n        if (!patient) fix.push('patient');\n        if (!destination) fix.push('destination');\n\n        inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n        if (fix.length > 0) return null;\n\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 2 });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                {data.info &&\n                    data.info.description &&\n                    data.info.description.split('\\n').map((word, index) => (\n                        <span key={'title-word-' + index.toString()}>\n                            {word}\n                            <br className='mobile-exist' />\n                        </span>\n                    ))}\n            </H1>\n\n            <DivisionLine small />\n\n            <WithmateLabel required>서비스 선택</WithmateLabel>\n            {data && data.services && data.services.length > 0 && (\n                <TabContainer>\n                    {data.services.map((s, index) => (\n                        <Tab\n                            key={'service-item-key' + index.toString()}\n                            active={data && data.service === s.code}\n                            onClick={() => {\n                                onTab(s.code);\n                            }}\n                        >\n                            {s.serviceName}\n                        </Tab>\n                    ))}\n                </TabContainer>\n            )}\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel required>이용자 성함 / 성별</WithmateLabel>\n                <WithmateLabel required>관계</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <RelativeWrapper>\n                    <WithmateInput\n                        type='text'\n                        placeholder='ex) 홍길동'\n                        value={(data && data.patient) || undefined}\n                        onChange={ev => {\n                            if (ev.target.value && ev.target.value.length > 10) return null;\n\n                            inputDeepHandler({ type: 'temp', deepType: 'patient', value: ev.target.value });\n                        }}\n                    />\n\n                    <SigleButtonWrapper>\n                        <SigleButton\n                            active={data && data.sex === '남'}\n                            onClick={() => {\n                                onSex('남');\n                            }}\n                        >\n                            남\n                        </SigleButton>\n                        <SigleButton\n                            active={data && data.sex === '녀'}\n                            onClick={() => {\n                                onSex('녀');\n                            }}\n                        >\n                            녀\n                        </SigleButton>\n                    </SigleButtonWrapper>\n                </RelativeWrapper>\n                <WithmateSelect placeholder='-' value={(data && data.relate) || undefined} onChange={onRelation}>\n                    <Select.Option value='본인'>본인</Select.Option>\n                    <Select.Option value='부모'>부모</Select.Option>\n                    <Select.Option value='자매'>자매</Select.Option>\n                    <Select.Option value='친구'>친구</Select.Option>\n                    <Select.Option value='지인'>지인</Select.Option>\n                    <Select.Option value='기타'>기타</Select.Option>\n                </WithmateSelect>\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'patient') && (\n                <StyledHotFix>이용자 성함을 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'relate') && (\n                <StyledHotFix>환자와의 관계를 선택해주세요.</StyledHotFix>\n            )}\n            <DivisionLine small />\n\n            <WithmateLabel required>연락처(휴대전화번호)</WithmateLabel>\n            <WithmateInput\n                type='text'\n                placeholder='ex) 01029101234 (\"-\" 없이 입력해주세요)'\n                value={(data && data.contact) || undefined}\n                onChange={ev => {\n                    const numValue = parseFloat(ev.target.value);\n                    if (typeof numValue !== 'number') return null;\n                    if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                        ev.preventDefault();\n                        return null;\n                    }\n                    if (ev.target.value.length > 11) return null;\n\n                    inputDeepHandler({ type: 'temp', deepType: 'contact', value: ev.target.value });\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'contact') && (\n                <StyledHotFix>올바른 휴대전화번호를 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine small />\n\n            <WithmateLabel required>병원 위치</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                inputConfig={{\n                    type: 'text',\n                    disabled: true,\n                    value: (data && data.starting) || undefined,\n                }}\n            />\n\n            <DivisionLine small />\n\n            <WithmateLabel required={data && data.service === 'unemergency'}>자택 주소 (고향시 내 주소지만 서비스 진행 가능)</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                onButton={setDestination}\n                inputConfig={{\n                    type: 'text',\n                    value: (data && data.destination) || undefined,\n                    placeholder: 'ex) 경기 고양시 덕양구 고양시청로',\n                    onChange: destinationHandler,\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'starting') && (\n                <StyledHotFix>귀가시 자택 주소를 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.service === 'dropcare' && (\n                <>\n                    <DivisionLine small />\n\n                    <FlexWrapper withHalf>\n                        <WithmateLabel required>거주 유형</WithmateLabel>\n                        <WithmateLabel required>주택 유형</WithmateLabel>\n                    </FlexWrapper>\n                    <FlexWrapper withHalf>\n                        <WithmateSelect placeholder='-'>\n                            <Select.Option value='아파트'>아파트</Select.Option>\n                            <Select.Option value='단독'>단독</Select.Option>\n                            <Select.Option value='다가구'>다가구</Select.Option>\n                        </WithmateSelect>\n                        <WithmateSelect placeholder='-'>\n                            <Select.Option value='자가'>자가</Select.Option>\n                            <Select.Option value='전.월세'>전.월세</Select.Option>\n                            <Select.Option value='기타'>기타</Select.Option>\n                        </WithmateSelect>\n                    </FlexWrapper>\n\n                    <DivisionLine small />\n                    <FlexWrapper withHalf>\n                        <WithmateLabel required>장기 요양 등급</WithmateLabel>\n                        <WithmateLabel required>확정</WithmateLabel>\n                    </FlexWrapper>\n                    <FlexWrapper withHalf>\n                        <WithmateSelect placeholder='-'>\n                            <Select.Option value='1등급'>1등급</Select.Option>\n                            <Select.Option value='2등급'>2등급</Select.Option>\n                            <Select.Option value='3등급'>3등급</Select.Option>\n                            <Select.Option value='4등급'>4등급</Select.Option>\n                            <Select.Option value='5등급'>5등급</Select.Option>\n                        </WithmateSelect>\n                        <WithmateSelect placeholder='-'>\n                            <Select.Option value='해피케어'>해피케어</Select.Option>\n                            <Select.Option value='장기요양'>장기요양</Select.Option>\n                            <Select.Option value='렌탈'>렌탈</Select.Option>\n                        </WithmateSelect>\n                    </FlexWrapper>\n                </>\n            )}\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                신청하기\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const ContractStep_2 = ({ data, inputDeepHandler }) => {\n    const { date, time, minute, sick, comment } = data;\n    const onNextStep = () => {\n        const fix = [];\n        if (!date) fix.push('date');\n        if (!sick) fix.push('sick');\n        if (!comment) fix.push('comment');\n        if (!time) fix.push('time');\n        if (time && time >= 18) fix.push('overtime');\n        if (!minute) fix.push('minute');\n\n        inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n        if (fix.length > 0) return null;\n\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 3 });\n    };\n\n    const onPrevStep = () => {\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 1 });\n    };\n\n    const onCalendar = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'date', value });\n    };\n\n    const sickHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'sick', value });\n    };\n\n    const commentHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'comment', value });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                예약 신청을\n                <br className='mobile-exist' />\n                마무리 해주세요\n            </H1>\n\n            <WithmateLabel required>예약일자</WithmateLabel>\n            <ConfigProvider locale={locale}>\n                <WithmateDatePicker\n                    inputReadOnly\n                    style={{ width: '100%', height: '36px' }}\n                    value={(data && data.date) || undefined}\n                    placeholder='예약일자를 설정해주세요.'\n                    format='YYYY-MM-DD'\n                    onChange={onCalendar}\n                    disabledDate={current =>\n                        current < moment().add(0, 'day') ||\n                        current.get('day') === 0 ||\n                        current.get('day') === 6 ||\n                        holidayKR.isSolarHoliday(moment(current).toDate())\n                    }\n                />\n            </ConfigProvider>\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'date') && (\n                <StyledHotFix>예약일자를 선택해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>예약 시간</WithmateLabel>\n            <FlexWrapper withHalf>\n                <WithmateInput\n                    type='text'\n                    placeholder='ex) 16'\n                    value={(data && data.time) || undefined}\n                    style={{ marginRight: '4px' }}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 23) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'time', value: ev.target.value });\n                    }}\n                    suffix='시'\n                />\n                <WithmateInput\n                    type='text'\n                    placeholder='ex) 30'\n                    value={(data && data.minute) || undefined}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 60) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'minute', value: ev.target.value });\n                    }}\n                    suffix='분'\n                />\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'time' || r === 'minute') && (\n                <StyledHotFix>서비스 이용을 위한 예약 시간을 정확히 입력해주세요.</StyledHotFix>\n            )}\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'overtime') && (\n                <StyledHotFix>18시 이후의 서비스 예약은 불가능합니다.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>병명</WithmateLabel>\n            <WithmateInput\n                type='text'\n                placeholder='ex) 위암, 대장암, 팔 골절 등'\n                value={(data && data.sick) || undefined}\n                onChange={ev => {\n                    sickHandler(ev.target.value);\n                }}\n            />\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'sick') && (\n                <StyledHotFix>환자분의 병명을 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>추가 요청 사항</WithmateLabel>\n            <WithmateTextarea\n                type='text'\n                placeholder={`서비스 진행자에게 추가적으로 요청할 사항을 적어주세요.\n                ex) 이동 간 낙상 방지에 각별히 신경써주세요.`}\n                value={(data && data.comment) || undefined}\n                onChange={ev => {\n                    commentHandler(ev.target.value);\n                }}\n            />\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'comment') && (\n                <StyledHotFix>추가 요청 사항을 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                신청하기\n            </FullWidthButton>\n\n            <BorderDivisionLine small />\n\n            <FullWidthButton bg={Pallete.dark80} onClick={onPrevStep}>\n                이전으로\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const ContractStep_3 = ({ data, inputDeepHandler, onReserve }) => {\n    const addTimeSelector = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'addTime', value });\n    };\n\n    const onSaveAndNext = () => {\n        const fix = [];\n\n        onReserve();\n    };\n\n    let selectedService = '';\n    if (data && data.service && data.services && data.services.length > 0 && data.services.some(s => s.code === data.service)) {\n        const s = data.services.filter(s => s.code === data.service)[0];\n        selectedService = s.serviceName;\n    }\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                서비스 신청내용 확인\n            </H1>\n\n            <WithmateLabel>선택된 서비스</WithmateLabel>\n            <WithmateValue>{selectedService}</WithmateValue>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>이용자 성함</WithmateLabel>\n                <WithmateLabel>이용자와의 관계</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.patient) || undefined} />\n                <WithmateInput disabled value={(data && data.relate) || undefined} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>전화번호</WithmateLabel>\n                <WithmateLabel>병명</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.contact) || undefined} />\n                <WithmateInput disabled value={(data && data.sick) || undefined} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>병원 위치</WithmateLabel>\n                <WithmateLabel>자택 주소</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.destination) || undefined} />\n                <WithmateInput disabled value={(data && data.starting) || undefined} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel>예약 일자</WithmateLabel>\n                <WithmateLabel>예약 시간</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <WithmateInput disabled value={(data && data.date && moment(data.date).format('YY. MM. DD')) || undefined} />\n                <WithmateInput disabled value={((data && data.time) || '00') + '시 ' + ((data && data.minute) || '00') + '분'} />\n            </FlexWrapper>\n\n            <DivisionLine small />\n\n            <WithmateLabel>병원 이름 및 상세내용</WithmateLabel>\n            <WithmateTextarea disabled value={(data && data.comment) || undefined} />\n\n            <DivisionLine small />\n\n            <FullWidthButton\n                bg={Pallete.dark80}\n                onClick={() => {\n                    inputDeepHandler({ type: 'temp', deepType: 'step', value: 2 });\n                }}\n            >\n                이전으로\n            </FullWidthButton>\n\n            <DivisionLine />\n\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                예약 접수하기\n            </H1>\n\n            <WithmateLabel required bg={Pallete.blue50}>\n                예상 소요 시간\n            </WithmateLabel>\n            <WithmateSelect value={(data && data.addTime) || undefined} placeholder='예상 소요시간을 선택해주세요' onChange={addTimeSelector}>\n                <Select.Option value='60'>1시간</Select.Option>\n                <Select.Option value='90'>1시간 30분</Select.Option>\n                <Select.Option value='120'>2시간</Select.Option>\n                <Select.Option value='150'>2시간 30분</Select.Option>\n                <Select.Option value='180'>3시간</Select.Option>\n                <Select.Option value='210'>3시간 30분</Select.Option>\n                <Select.Option value='240'>4시간</Select.Option>\n                <Select.Option value='270'>4시간 30분</Select.Option>\n                <Select.Option value='300'>5시간</Select.Option>\n                <Select.Option value='330'>5시간 30분</Select.Option>\n                <Select.Option value='360'>6시간</Select.Option>\n                <Select.Option value='390'>6시간 30분</Select.Option>\n                <Select.Option value='420'>7시간</Select.Option>\n                <Select.Option value='450'>7시간 30분</Select.Option>\n                <Select.Option value='480'>8시간</Select.Option>\n            </WithmateSelect>\n\n            <DivisionLine small />\n\n            <FullWidthButton bg={Pallete.blue50} onClick={onSaveAndNext}>\n                예약 접수하기\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nconst RelativeWrapper = styled.div`\n    position: relative;\n\n    > input {\n        width: 100% !important;\n    }\n`;\n\nconst SigleButtonWrapper = styled.div`\n    position: absolute;\n    top: 1px;\n    right: 1px;\n`;\n\nconst SigleButton = styled.span`\n    display: inline-block;\n    width: 43px;\n    height: 100%;\n    line-height: 43px;\n\n    cursor: pointer;\n    font-size: 11px;\n    color: ${props => (props.active ? '#ffffff' : Pallete.dark60)};\n    text-align: center;\n\n    background-color: ${props => (props.active ? Pallete.blue50 : '#ffffff')};\n`;\n\nconst AlertMessage = styled.p`\n    margin-bottom: 0px;\n    margin-top: 4px;\n\n    font-size: 11px;\n    color: red;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Select, ConfigProvider, DatePicker } from 'antd';\nimport holidayKR from 'holiday-kr';\nimport moment from 'moment';\n\nimport 'moment/locale/zh-cn';\nimport locale from 'antd/es/locale/ko_KR';\n\n// components\nimport {\n    DivisionLine,\n    WithmateLabel,\n    WithmateInput,\n    WithamteInputWithButton,\n    HalfWithmateInput,\n    WithmateTextarea,\n    WithmateSelect,\n    FlexWrapper,\n    HalfWithmateSelect,\n    WithmateDatePicker,\n    BorderDivisionLine,\n    StyledHotFix,\n    WithmateValue,\n    WithmateValueTip,\n} from '../Common/input';\nimport { H1, H2, H3, H4, H5, H6, Text } from '../Common/text';\nimport { Container } from '../Common/container';\nimport { TabContainer, Tab } from '../Common/tab';\nimport { FullWidthButton } from '../Common/button';\n\n// utils\nimport Pallete from '../../theme';\nimport { isNotNumber, celluarValidate } from '../../Lib/regex';\nimport { ASSIST } from '../../Lib/variables';\n\nexport const EditStep1 = ({ data, inputDeepHandler, setDestination, setStarting }) => {\n    const { service, sex, relate, patient, contact, destination, starting, status } = data;\n\n    const onTab = tab => {\n        inputDeepHandler({ type: 'temp', deepType: 'service', value: tab });\n    };\n\n    const onSex = sex => {\n        inputDeepHandler({ type: 'temp', deepType: 'sex', value: sex });\n    };\n\n    const onRelation = relate => {\n        inputDeepHandler({ type: 'temp', deepType: 'relate', value: relate });\n    };\n\n    const destinationHandler = ev => {\n        inputDeepHandler({ type: 'temp', deepType: 'destination', value: ev.target.value });\n    };\n\n    const startingHandler = ev => {\n        inputDeepHandler({ type: 'temp', deepType: 'starting', value: ev.target.value });\n    };\n\n    const onNextStep = () => {\n        const fix = [];\n        if (!relate) fix.push('relate');\n        if (!contact || !celluarValidate(contact)) fix.push('contact');\n        if (!patient) fix.push('patient');\n        if (!starting) fix.push('starting');\n        if (service === 'unemergency' && !destination) fix.push('destination');\n\n        if (!data.disabled) {\n            inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n            if (fix.length > 0) return null;\n        }\n\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 2 });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                병원 동행 예약을\n                <br className='mobile-exist' />\n                확인해주세요\n            </H1>\n\n            <DivisionLine small />\n\n            <WithmateLabel required>서비스 선택</WithmateLabel>\n            <TabContainer>\n                <Tab\n                    active={data && data.service === 'unemergency'}\n                    onClick={() => {\n                        if (data && !data.disabled) onTab('unemergency');\n                    }}\n                >\n                    Pro\n                </Tab>\n                <Tab\n                    active={data && data.service === 'assist'}\n                    onClick={() => {\n                        if (data && !data.disabled) onTab('assist');\n                    }}\n                >\n                    Basic\n                </Tab>\n            </TabContainer>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel required>이용자 성함 / 성별</WithmateLabel>\n                <WithmateLabel required>관계</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <RelativeWrapper>\n                    <WithmateInput\n                        disabled={data.disabled}\n                        type='text'\n                        placeholder='ex) 홍길동'\n                        value={(data && data.patient) || undefined}\n                        onChange={ev => {\n                            if (ev.target.value && ev.target.value.length > 10) return null;\n\n                            inputDeepHandler({ type: 'temp', deepType: 'patient', value: ev.target.value });\n                        }}\n                    />\n\n                    <SigleButtonWrapper>\n                        <SigleButton\n                            active={data && data.sex === '남'}\n                            onClick={() => {\n                                if (data && !data.disabled) onSex('남');\n                            }}\n                        >\n                            남\n                        </SigleButton>\n                        <SigleButton\n                            active={data && data.sex === '녀'}\n                            onClick={() => {\n                                if (data && !data.disabled) onSex('녀');\n                            }}\n                        >\n                            녀\n                        </SigleButton>\n                    </SigleButtonWrapper>\n                </RelativeWrapper>\n                <WithmateSelect placeholder='-' value={(data && data.relate) || undefined} onChange={onRelation}>\n                    <Select.Option value='본인'>본인</Select.Option>\n                    <Select.Option value='부모'>부모</Select.Option>\n                    <Select.Option value='자매'>자매</Select.Option>\n                    <Select.Option value='친구'>친구</Select.Option>\n                    <Select.Option value='지인'>지인</Select.Option>\n                    <Select.Option value='기타'>기타</Select.Option>\n                </WithmateSelect>\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'patient') && (\n                <StyledHotFix>이용자 성함을 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'relate') && (\n                <StyledHotFix>환자와의 관계를 선택해주세요.</StyledHotFix>\n            )}\n            <DivisionLine small />\n\n            <WithmateLabel required>연락처(휴대전화번호)</WithmateLabel>\n            <WithmateInput\n                type='text'\n                disabled={data.disabled}\n                placeholder='ex) 01029101234 (\"-\" 없이 입력해주세요)'\n                value={(data && data.contact) || undefined}\n                onChange={ev => {\n                    const numValue = parseFloat(ev.target.value);\n                    if (typeof numValue !== 'number') return null;\n                    if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                        ev.preventDefault();\n                        return null;\n                    }\n                    if (ev.target.value.length > 11) return null;\n\n                    inputDeepHandler({ type: 'temp', deepType: 'contact', value: ev.target.value });\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'contact') && (\n                <StyledHotFix>올바른 휴대전화번호를 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine small />\n\n            <WithmateLabel required>병원 위치</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                inputConfig={{\n                    type: 'text',\n                    value: (data && data.destination) || undefined,\n                    placeholder: 'ex) 서울특별시 강남 을지병원',\n                    onChange: () => {},\n                    disabled: true,\n                }}\n            />\n\n            <DivisionLine small />\n\n            <WithmateLabel required={data && data.service === 'unemergency'}>자택 주소</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                inputConfig={{\n                    type: 'text',\n                    value: (data && data.starting) || undefined,\n                    placeholder: 'ex) 서울특별시 강남 을지병원',\n                    onChange: () => {},\n                    disabled: true,\n                }}\n            />\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                다음으로\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const EditStep2 = ({ data, inputDeepHandler, onClose, onModify }) => {\n    const { date, time, minute, sick, comment } = data;\n    const onNextStep = () => {\n        const fix = [];\n        if (!date) fix.push('date');\n        if (!sick) fix.push('sick');\n        if (!comment) fix.push('comment');\n        if (!time) fix.push('time');\n        if (time && time >= 18) fix.push('overtime');\n        if (!minute) fix.push('minute');\n\n        if (!data.disabled) {\n            inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n            if (fix.length > 0) return null;\n        }\n\n        // onModify();\n    };\n\n    const onCancelReserve = () => {};\n\n    const onPrevStep = () => {\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 1 });\n    };\n\n    const onCalendar = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'date', value });\n    };\n\n    const sickHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'sick', value });\n    };\n\n    const commentHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'comment', value });\n    };\n\n    const getFee = () => {\n        const _transport = data.transport && data.transport === 'own' ? 20000 : 0;\n        const _service =\n            data.productInfo &&\n            data.service &&\n            (data.service === 'unemergency' ? data.productInfo.proPrice : data.productInfo.basicPrice ? data.productInfo.basicPrice : 0) * data.usageTime;\n\n        const _point = (data.usingPoint || 0) * -1;\n\n        return _transport + _service + _point;\n    };\n\n    const addTimeSelector = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'addTime', value });\n    };\n\n    const transportHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'transport', value });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                병원 동행 예약을\n                <br className='mobile-exist' />\n                확인해주세요\n            </H1>\n\n            {data.meetDate && (\n                <>\n                    <WithmateLabel required>{data.service === ASSIST ? '병원 도착 요청 일자' : '자택 도착 희망 일자'}</WithmateLabel>\n                    <ConfigProvider locale={locale}>\n                        <WithmateDatePicker\n                            inputReadOnly\n                            disabled={data.disabled}\n                            style={{ width: '100%', height: '36px' }}\n                            value={(data && data.meetDate) || undefined}\n                            placeholder='예약일자를 설정해주세요.'\n                            format='YYYY-MM-DD'\n                            onChange={onCalendar}\n                            disabledDate={current =>\n                                current < moment().add(0, 'day') ||\n                                current.get('day') === 0 ||\n                                current.get('day') === 6 ||\n                                holidayKR.isSolarHoliday(moment(current).toDate())\n                            }\n                        />\n                    </ConfigProvider>\n                    <DivisionLine />\n                    <WithmateLabel required>{data.service === ASSIST ? '병원 도착 요청 시간' : '자택 도착 희망 시간'}</WithmateLabel>\n                    <FlexWrapper withHalf>\n                        <WithmateInput\n                            disabled={data.disabled}\n                            type='text'\n                            placeholder='ex) 16'\n                            value={(data && data.meetTime) || undefined}\n                            style={{ marginRight: '4px' }}\n                            onChange={ev => {\n                                if (ev.target.value && ev.target.value.length > 10) return null;\n                                const numValue = parseFloat(ev.target.value);\n                                if (typeof numValue !== 'number') return null;\n                                if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                                    ev.preventDefault();\n                                    return null;\n                                }\n                                if (ev.target.value.length > 2 || numValue > 23) return null;\n\n                                inputDeepHandler({ type: 'temp', deepType: 'meetTime', value: ev.target.value });\n                            }}\n                            suffix='시'\n                        />\n                        <WithmateInput\n                            disabled={data.disabled}\n                            type='text'\n                            placeholder='ex) 30'\n                            value={(data && data.meetMinute) || undefined}\n                            onChange={ev => {\n                                if (ev.target.value && ev.target.value.length > 10) return null;\n                                const numValue = parseFloat(ev.target.value);\n                                if (typeof numValue !== 'number') return null;\n                                if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                                    ev.preventDefault();\n                                    return null;\n                                }\n                                if (ev.target.value.length > 2 || numValue > 60) return null;\n\n                                inputDeepHandler({ type: 'temp', deepType: 'meetMinute', value: ev.target.value });\n                            }}\n                            suffix='분'\n                        />\n                    </FlexWrapper>\n                    <DivisionLine />\n                </>\n            )}\n\n            <WithmateLabel required>예약일자</WithmateLabel>\n            <ConfigProvider locale={locale}>\n                <WithmateDatePicker\n                    inputReadOnly\n                    disabled={data.disabled}\n                    style={{ width: '100%', height: '36px' }}\n                    value={(data && data.date) || undefined}\n                    placeholder='예약일자를 설정해주세요.'\n                    format='YYYY-MM-DD'\n                    onChange={onCalendar}\n                    disabledDate={current =>\n                        current < moment().add(0, 'day') ||\n                        current.get('day') === 0 ||\n                        current.get('day') === 6 ||\n                        holidayKR.isSolarHoliday(moment(current).toDate())\n                    }\n                />\n            </ConfigProvider>\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'date') && (\n                <StyledHotFix>예약일자를 선택해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n            <WithmateLabel required>병원 진료 예약 시간</WithmateLabel>\n            <FlexWrapper withHalf>\n                <WithmateInput\n                    disabled={data.disabled}\n                    type='text'\n                    placeholder='ex) 16'\n                    value={(data && data.time) || undefined}\n                    style={{ marginRight: '4px' }}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 23) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'time', value: ev.target.value });\n                    }}\n                    suffix='시'\n                />\n                <WithmateInput\n                    disabled={data.disabled}\n                    type='text'\n                    placeholder='ex) 30'\n                    value={(data && data.minute) || undefined}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 60) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'minute', value: ev.target.value });\n                    }}\n                    suffix='분'\n                />\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'time' || r === 'minute') && (\n                <StyledHotFix>서비스 이용을 위한 예약 시간을 정확히 입력해주세요.</StyledHotFix>\n            )}\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'overtime') && (\n                <StyledHotFix>18시 이후의 서비스 예약은 불가능합니다.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>추가 요청 사항</WithmateLabel>\n            <WithmateTextarea\n                type='text'\n                disabled={data.disabled}\n                placeholder='병원 이름 및 상세 내용을 입력해주세요. 특히, 병원 이름을 반드시 기재해주세요 (ex. 서울대학교 병원)'\n                value={(data && data.comment) || undefined}\n                onChange={ev => {\n                    commentHandler(ev.target.value);\n                }}\n            />\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'comment') && (\n                <StyledHotFix>병원 이름 및 상세내용을 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.service === 'unemergency' && (\n                <>\n                    <DivisionLine small />\n\n                    <WithmateLabel required>이동 수단 선택</WithmateLabel>\n                    <WithmateSelect\n                        disabled={data.disabled}\n                        value={(data && data.transport) || undefined}\n                        placeholder='서비스 이용간 이동 수단을 선택해주세요'\n                        onChange={transportHandler}\n                    >\n                        <Select.Option value='common'>대중교통 이용 (택시・버스 등)</Select.Option>\n                        <Select.Option value='own'>본인소유 자차 이용</Select.Option>\n                        {data.disabled && <Select.Option value='withcar'>위드메이트 차량 호출</Select.Option>}\n                        {data.transport && data.transport === 'own' && <AlertMessage>* 자차 이용시, 운전자 보험 변경 필수</AlertMessage>}\n                    </WithmateSelect>\n                </>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required bg={Pallete.blue50}>\n                예상 소요 시간\n            </WithmateLabel>\n            <WithmateSelect\n                disabled={data.disabled}\n                value={(data && data.addTime) || undefined}\n                placeholder='예상 소요시간을 선택해주세요'\n                onChange={addTimeSelector}\n            >\n                <Select.Option value='60'>1시간</Select.Option>\n                <Select.Option value='90'>1시간 30분</Select.Option>\n                <Select.Option value='120'>2시간</Select.Option>\n                <Select.Option value='150'>2시간 30분</Select.Option>\n                <Select.Option value='180'>3시간</Select.Option>\n                <Select.Option value='210'>3시간 30분</Select.Option>\n                <Select.Option value='240'>4시간</Select.Option>\n                <Select.Option value='270'>4시간 30분</Select.Option>\n                <Select.Option value='300'>5시간</Select.Option>\n                <Select.Option value='330'>5시간 30분</Select.Option>\n                <Select.Option value='360'>6시간</Select.Option>\n                <Select.Option value='390'>6시간 30분</Select.Option>\n                <Select.Option value='420'>7시간</Select.Option>\n                <Select.Option value='450'>7시간 30분</Select.Option>\n                <Select.Option value='480'>8시간</Select.Option>\n            </WithmateSelect>\n\n            <DivisionLine />\n\n            <WithmateLabel>총 예상 비용 (실제 비용과 다를 수 있습니다)</WithmateLabel>\n            <WithmateValue>₩ {getFee()}</WithmateValue>\n            <WithmateValueTip>(VAT 10% 포함된 가격입니다)</WithmateValueTip>\n\n            <DivisionLine />\n\n            {/* {data && !data.disabled && ( */}\n            {data && (\n                <>\n                    <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                        예약 변경\n                    </FullWidthButton>\n                    <BorderDivisionLine small />\n                </>\n            )}\n\n            <FullWidthButton bg={Pallete.dark80} onClick={onClose}>\n                확인완료\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const ContractEditStep_1 = ({ data, inputDeepHandler, setDestination, onDropoReserve }) => {\n    const { service, sex, relate, patient, contact, destination, starting } = data;\n\n    const onTab = tab => {\n        inputDeepHandler({ type: 'temp', deepType: 'service', value: tab });\n    };\n\n    const onSex = sex => {\n        inputDeepHandler({ type: 'temp', deepType: 'sex', value: sex });\n    };\n\n    const onRelation = relate => {\n        inputDeepHandler({ type: 'temp', deepType: 'relate', value: relate });\n    };\n\n    const onNextStep = () => {\n        const fix = [];\n        if (!relate) fix.push('relate');\n        if (!contact || !celluarValidate(contact)) fix.push('contact');\n        if (!patient) fix.push('patient');\n        if (!destination) fix.push('destination');\n\n        inputDeepHandler({ type: 'temp', deepType: 'reserveHotFix', value: fix });\n        if (fix.length > 0) return null;\n\n        inputDeepHandler({ type: 'temp', deepType: 'step', value: 2 });\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                예약을\n                <br className='mobile-exist' />\n                확인해주세요\n            </H1>\n\n            <DivisionLine small />\n\n            <FlexWrapper withHalf>\n                <WithmateLabel required>이용자 성함 / 성별</WithmateLabel>\n                <WithmateLabel required>관계</WithmateLabel>\n            </FlexWrapper>\n            <FlexWrapper withHalf>\n                <RelativeWrapper>\n                    <WithmateInput\n                        type='text'\n                        disabled\n                        placeholder='ex) 홍길동'\n                        value={(data && data.patient) || undefined}\n                        onChange={ev => {\n                            if (ev.target.value && ev.target.value.length > 10) return null;\n\n                            inputDeepHandler({ type: 'temp', deepType: 'patient', value: ev.target.value });\n                        }}\n                    />\n\n                    <SigleButtonWrapper>\n                        <SigleButton\n                            disabled\n                            active={data && data.sex === '남'}\n                            onClick={() => {\n                                onSex('남');\n                            }}\n                        >\n                            남\n                        </SigleButton>\n                        <SigleButton\n                            disabled\n                            active={data && data.sex === '녀'}\n                            onClick={() => {\n                                onSex('녀');\n                            }}\n                        >\n                            녀\n                        </SigleButton>\n                    </SigleButtonWrapper>\n                </RelativeWrapper>\n                <WithmateSelect disabled placeholder='-' value={(data && data.relate) || undefined} onChange={onRelation}>\n                    <Select.Option value='본인'>본인</Select.Option>\n                    <Select.Option value='부모'>부모</Select.Option>\n                    <Select.Option value='자매'>자매</Select.Option>\n                    <Select.Option value='친구'>친구</Select.Option>\n                    <Select.Option value='지인'>지인</Select.Option>\n                    <Select.Option value='기타'>기타</Select.Option>\n                </WithmateSelect>\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'patient') && (\n                <StyledHotFix>이용자 성함을 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'relate') && (\n                <StyledHotFix>환자와의 관계를 선택해주세요.</StyledHotFix>\n            )}\n            <DivisionLine small />\n\n            <WithmateLabel required>연락처(휴대전화번호)</WithmateLabel>\n            <WithmateInput\n                type='text'\n                disabled\n                placeholder='ex) 01029101234 (\"-\" 없이 입력해주세요)'\n                value={(data && data.contact) || undefined}\n                onChange={ev => {\n                    const numValue = parseFloat(ev.target.value);\n                    if (typeof numValue !== 'number') return null;\n                    if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                        ev.preventDefault();\n                        return null;\n                    }\n                    if (ev.target.value.length > 11) return null;\n\n                    inputDeepHandler({ type: 'temp', deepType: 'contact', value: ev.target.value });\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'contact') && (\n                <StyledHotFix>올바른 휴대전화번호를 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine small />\n\n            <WithmateLabel required>병원 위치</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                inputConfig={{\n                    type: 'text',\n                    disabled: true,\n                    value: (data && data.starting) || undefined,\n                }}\n            />\n\n            <DivisionLine small />\n\n            <WithmateLabel required={data && data.service === 'unemergency'}>자택 주소 (고향시 내 주소지만 서비스 진행 가능)</WithmateLabel>\n            <WithamteInputWithButton\n                buttonName='검색'\n                inputConfig={{\n                    type: 'text',\n                    disabled: true,\n                    value: (data && data.destination) || undefined,\n                    placeholder: 'ex) 경기 고양시 덕양구 고양시청로',\n                }}\n            />\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'starting') && (\n                <StyledHotFix>귀가시 자택 주소를 입력해주세요.</StyledHotFix>\n            )}\n\n            {data && data.service === 'dropcare' && (\n                <>\n                    <DivisionLine small />\n\n                    <FlexWrapper withHalf>\n                        <WithmateLabel required>거주 유형</WithmateLabel>\n                        <WithmateLabel required>주택 유형</WithmateLabel>\n                    </FlexWrapper>\n                    <FlexWrapper withHalf>\n                        <WithmateSelect placeholder='-' disabled>\n                            <Select.Option value='아파트'>아파트</Select.Option>\n                            <Select.Option value='단독'>단독</Select.Option>\n                            <Select.Option value='다가구'>다가구</Select.Option>\n                        </WithmateSelect>\n                        <WithmateSelect placeholder='-' disabled>\n                            <Select.Option value='자가'>자가</Select.Option>\n                            <Select.Option value='전.월세'>전.월세</Select.Option>\n                            <Select.Option value='기타'>기타</Select.Option>\n                        </WithmateSelect>\n                    </FlexWrapper>\n\n                    <DivisionLine small />\n                    <FlexWrapper withHalf>\n                        <WithmateLabel required>장기 요양 등급</WithmateLabel>\n                        <WithmateLabel required>확정</WithmateLabel>\n                    </FlexWrapper>\n                    <FlexWrapper withHalf>\n                        <WithmateSelect placeholder='-' disabled>\n                            <Select.Option value='1등급'>1등급</Select.Option>\n                            <Select.Option value='2등급'>2등급</Select.Option>\n                            <Select.Option value='3등급'>3등급</Select.Option>\n                            <Select.Option value='4등급'>4등급</Select.Option>\n                            <Select.Option value='5등급'>5등급</Select.Option>\n                        </WithmateSelect>\n                        <WithmateSelect placeholder='-' disabled>\n                            <Select.Option value='해피케어'>해피케어</Select.Option>\n                            <Select.Option value='장기요양'>장기요양</Select.Option>\n                            <Select.Option value='렌탈'>렌탈</Select.Option>\n                        </WithmateSelect>\n                    </FlexWrapper>\n                </>\n            )}\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.blue100} onClick={onNextStep}>\n                다음으로\n            </FullWidthButton>\n        </Container>\n    );\n};\n\nexport const ContractEditStep_2 = ({ data, inputDeepHandler, onClose }) => {\n    const onCalendar = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'date', value });\n    };\n\n    const sickHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'sick', value });\n    };\n\n    const commentHandler = value => {\n        inputDeepHandler({ type: 'temp', deepType: 'comment', value });\n    };\n\n    const getFee = () => {\n        const _transport = data.transport && data.transport === 'own' ? 20000 : 0;\n        const _service =\n            data.productInfo &&\n            data.service &&\n            (data.service === 'unemergency' ? data.productInfo.proPrice : data.productInfo.basicPrice ? data.productInfo.basicPrice : 0) * data.usageTime;\n\n        const _point = (data.usingPoint || 0) * -1;\n\n        return _transport + _service + _point;\n    };\n\n    return (\n        <Container>\n            <H1 bold style={{ color: Pallete.dark80 }}>\n                예약을\n                <br className='mobile-exist' />\n                확인해주세요\n            </H1>\n\n            <WithmateLabel required>예약일자</WithmateLabel>\n            <ConfigProvider locale={locale}>\n                <WithmateDatePicker\n                    inputReadOnly\n                    disabled\n                    style={{ width: '100%', height: '36px' }}\n                    value={(data && data.date) || undefined}\n                    placeholder='예약일자를 설정해주세요.'\n                    format='YYYY-MM-DD'\n                    onChange={onCalendar}\n                    disabledDate={current =>\n                        current < moment().add(0, 'day') ||\n                        current.get('day') === 0 ||\n                        current.get('day') === 6 ||\n                        holidayKR.isSolarHoliday(moment(current).toDate())\n                    }\n                />\n            </ConfigProvider>\n\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'date') && (\n                <StyledHotFix>예약일자를 선택해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>예약 시간</WithmateLabel>\n            <FlexWrapper withHalf>\n                <WithmateInput\n                    type='text'\n                    disabled\n                    placeholder='ex) 16'\n                    value={(data && data.time) || undefined}\n                    style={{ marginRight: '4px' }}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 23) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'time', value: ev.target.value });\n                    }}\n                    suffix='시'\n                />\n                <WithmateInput\n                    type='text'\n                    disabled\n                    placeholder='ex) 30'\n                    value={(data && data.minute) || undefined}\n                    onChange={ev => {\n                        if (ev.target.value && ev.target.value.length > 10) return null;\n                        const numValue = parseFloat(ev.target.value);\n                        if (typeof numValue !== 'number') return null;\n                        if (ev.nativeEvent.data && isNotNumber(ev.nativeEvent.data)) {\n                            ev.preventDefault();\n                            return null;\n                        }\n                        if (ev.target.value.length > 2 || numValue > 60) return null;\n\n                        inputDeepHandler({ type: 'temp', deepType: 'minute', value: ev.target.value });\n                    }}\n                    suffix='분'\n                />\n            </FlexWrapper>\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'time' || r === 'minute') && (\n                <StyledHotFix>서비스 이용을 위한 예약 시간을 정확히 입력해주세요.</StyledHotFix>\n            )}\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'overtime') && (\n                <StyledHotFix>18시 이후의 서비스 예약은 불가능합니다.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>추가 요청 사항</WithmateLabel>\n            <WithmateTextarea\n                type='text'\n                disabled\n                placeholder={`서비스 진행자에게 추가적으로 요청할 사항을 적어주세요.\n                ex) 이동 간 낙상 방지에 각별히 신경써주세요.`}\n                value={(data && data.comment) || undefined}\n                onChange={ev => {\n                    commentHandler(ev.target.value);\n                }}\n            />\n            {data && data.reserveHotFix && data.reserveHotFix.length > 0 && data.reserveHotFix.some(r => r === 'comment') && (\n                <StyledHotFix>추가 요청 사항을 입력해주세요.</StyledHotFix>\n            )}\n\n            <DivisionLine />\n\n            <WithmateLabel required>이동 수단 선택</WithmateLabel>\n            <WithmateValue>\n                {data.transport === 'own'\n                    ? '본인소유 자차 이용'\n                    : data.transport === 'common'\n                    ? '대중교통 이용 (택시・버스 등)'\n                    : data.transport === 'withcar'\n                    ? '위드메이트 차량 호출'\n                    : '-'}\n            </WithmateValue>\n\n            <DivisionLine />\n\n            <WithmateLabel required bg={Pallete.blue50}>\n                예상 소요 시간\n            </WithmateLabel>\n            <WithmateValue>{parseInt(data.addTime || 0, 10) / 60} 시간</WithmateValue>\n\n            <DivisionLine />\n\n            <WithmateLabel>총 예상비용</WithmateLabel>\n            <WithmateValue>₩ {getFee()}</WithmateValue>\n            <WithmateValueTip>(VAT 10% 포함된 가격입니다)</WithmateValueTip>\n\n            <DivisionLine />\n\n            <FullWidthButton bg={Pallete.dark80} onClick={onClose}>\n                확인완료\n            </FullWidthButton>\n        </Container>\n    );\n};\nconst RelativeWrapper = styled.div`\n    position: relative;\n\n    > input {\n        width: 100% !important;\n    }\n`;\n\nconst SigleButtonWrapper = styled.div`\n    position: absolute;\n    top: 1px;\n    right: 1px;\n`;\n\nconst SigleButton = styled.span`\n    display: inline-block;\n    width: 43px;\n    height: 100%;\n    line-height: 43px;\n    // border-radius: 4px;\n\n    cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n    font-size: 11px;\n    color: ${props => (props.active ? '#ffffff' : Pallete.dark60)};\n    text-align: center;\n\n    background-color: ${props => (props.active ? Pallete.blue50 : '#ffffff')};\n`;\n\nconst AlertMessage = styled.p`\n    margin-bottom: 0px;\n    margin-top: 4px;\n\n    font-size: 11px;\n    color: #565656;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport Modal from 'react-modal';\nimport { Timeline } from 'antd';\nimport moment from 'moment';\n\n// components\nimport { TabContainer, Tab } from '../Components/Common/tab';\nimport { FullWidthButton, HalfWidthButton, ButtonWrapper } from '../Components/Common/button';\nimport {\n    DivisionLine,\n    WithmateLabel,\n    WithmateInput,\n    HalfWithmateInput,\n    WithmateTextarea,\n    WithmateSelect,\n    FlexWrapper,\n    FlexDiv,\n    HalfWithmateSelect,\n} from '../Components/Common/input';\n\nimport { Step1, Step2, Step3, ContractdStep_1, ContractStep_2, ContractStep_3 } from './Reserve/step';\nimport { EditStep1, EditStep2, ContractEditStep_1, ContractEditStep_2 } from './Reserve/editStep';\nimport ColorPallete from '../theme';\n\nconst customStyles = {\n    overlay: {\n        display: 'flex',\n\n        backgroundColor: 'rgba(0, 0, 0, 0.4)',\n        alignItems: 'center',\n        justifyContent: 'center',\n\n        zIndex: '99999999999999 !important',\n    },\n    content: {\n        width: '100%',\n        height: '100%',\n        boxShadow: 'initial',\n        border: '0px',\n        top: '0px',\n        left: '0px',\n        right: '0px',\n        bottom: '0px',\n        backgroundColor: 'transparent',\n        padding: '0px',\n\n        display: 'flex',\n        alignItems: 'center',\n    },\n};\n\nclass CustomModal extends React.PureComponent {\n    state = {};\n\n    componentDidMount = () => {\n        window.addEventListener('resize', this.onCheckSize, false);\n        if (this.props.visible) {\n            document.body.style.overflow = 'hidden';\n        }\n    };\n\n    componentWillUnmount = () => {\n        window.removeEventListener('resize', this.onCheckSize, false);\n        document.body.style.overflow = 'unset';\n    };\n\n    onCheckSize = () => {\n        const windowWidth = window.innerWidth;\n        const windowHeight = window.innerHeight;\n        const innerContent = document.getElementById(this.props.childrenId);\n\n        if (windowWidth <= 480) {\n            let top = innerContent.clientHeight / windowHeight >= 0.8 ? '100px' : 'initial';\n            let bottom = innerContent.clientHeight / windowHeight >= 0.8 ? 'initial' : '0px';\n\n            if (this.props.childrenId && this.props.childrenId.includes('full-header')) {\n                top = '0px';\n                bottom = '0px';\n            }\n\n            innerContent.style.maxWidth = '424px';\n            innerContent.style.top = top;\n            innerContent.style.bottom = bottom;\n\n            this.setState({\n                top,\n                bottom,\n            });\n        } else {\n            innerContent.style.maxWidth = this.props.childrenId && this.props.childrenId.includes('wide') ? '720px' : '424px';\n            innerContent.style.top = windowHeight * 0.15 + 'px';\n            innerContent.style.marginBottom = windowHeight * 0.15 + 'px';\n        }\n    };\n\n    render() {\n        return (\n            <Modal style={{ ...customStyles }} isOpen={this.props.visible} onAfterOpen={this.onCheckSize}>\n                {this.props.children}\n            </Modal>\n        );\n    }\n}\n\nexport const CommonWithmateModal = ({ visible, config = {}, onCancel, onOk }) => {\n    return (\n        <CustomModal visible={visible} childrenId='common-withmate-modal'>\n            <ModalInnerContainer id='common-withmate-modal'>\n                {!config.noClose && <CloseButton src={'/assets/images/close.png'} onClick={onCancel} />}\n\n                <TitleSection style={{ textAlign: 'center' }}>\n                    <CommonModalTitle style={{ textAlign: 'center' }}>{config && config.title ? config.title : ''}</CommonModalTitle>\n                    <CommonModalSubtitle style={{ marginTop: 0, wordBreak: 'keep-all' }}>\n                        {config && config.description ? config.description : ''}\n                    </CommonModalSubtitle>\n                </TitleSection>\n\n                <ContentSection style={{ textAlign: 'center' }}>\n                    {/* contents */}\n                    {config && config.content ? config.content : null}\n                    <ButtonWrapper half={config && config.cancelText && onCancel && typeof onCancel === 'function'}>\n                        {/* cancel */}\n                        {config && config.cancelText && onCancel && typeof onCancel === 'function' ? (\n                            <FullWidthButton bg={ColorPallete.dark70} onClick={onCancel}>\n                                {config && config.cancelText ? config.cancelText : '취소'}\n                            </FullWidthButton>\n                        ) : null}\n                        {/* confirm */}\n                        <FullWidthButton bg={ColorPallete.blue50} small onClick={onOk && typeof onOk === 'function' ? onOk : onCancel}>\n                            {config && config.confirmText ? config.confirmText : '확인 및 저장'}\n                        </FullWidthButton>\n                    </ButtonWrapper>\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const SampleModal = ({ visible, visibleHandler, inputHandler, inputDeepHandler, data, onSave }) => {\n    return (\n        <CustomModal visible={visible} childrenId='sample-new-modal'>\n            <ModalInnerContainer id='sample-new-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n                <TitleSection>\n                    <CommonModalTitle></CommonModalTitle>\n                </TitleSection>\n\n                <ContentSection></ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const NoramlReserveModal = ({ visible, visibleHandler, inputHandler, inputDeepHandler, data, setDestination, setStarting, onSave }) => {\n    const { step = 1 } = data;\n\n    return (\n        <CustomModal visible={visible} childrenId='normal-reserve-modal'>\n            <ModalInnerContainer id='normal-reserve-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n\n                <ContentSection>\n                    {step === 1 && <Step1 data={data} inputDeepHandler={inputDeepHandler} setDestination={setDestination} setStarting={setStarting} />}\n\n                    {step === 2 && <Step2 data={data} inputDeepHandler={inputDeepHandler} />}\n\n                    {step === 3 ? <Step3 data={data} inputDeepHandler={inputDeepHandler} onReserve={onSave} /> : null}\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const HappyReserveModal = ({ visible, visibleHandler, inputHandler, inputDeepHandler, data, setDestination, setStarting, onSave, onDropSave }) => {\n    const { step = 1 } = data;\n\n    return (\n        <CustomModal visible={visible} childrenId='normal-reserve-modal'>\n            <ModalInnerContainer id='normal-reserve-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n\n                <ContentSection>\n                    {step === 1 && (\n                        <ContractdStep_1\n                            data={data}\n                            inputDeepHandler={inputDeepHandler}\n                            setDestination={setDestination}\n                            setStarting={setStarting}\n                            onDropoReserve={onDropSave}\n                        />\n                    )}\n\n                    {step === 2 && <ContractStep_2 data={data} inputDeepHandler={inputDeepHandler} />}\n\n                    {step === 3 ? <ContractStep_3 data={data} inputDeepHandler={inputDeepHandler} onReserve={onSave} /> : null}\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const NoramlReserveEditModal = ({ visible, visibleHandler, data, inputDeepHandler, onModify }) => {\n    const { step = 1 } = data;\n    return (\n        <CustomModal visible={visible} childrenId='normal-edit-reserve-modal'>\n            <ModalInnerContainer id='normal-edit-reserve-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n                <ContentSection>\n                    {step === 1 && <EditStep1 data={data} inputDeepHandler={inputDeepHandler} />}\n\n                    {step === 2 && <EditStep2 data={data} inputDeepHandler={inputDeepHandler} onModify={onModify} onClose={visibleHandler} />}\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const HappyReserveEditModal = ({ visible, visibleHandler, data, inputDeepHandler, onModify }) => {\n    const { step = 1 } = data;\n    return (\n        <CustomModal visible={visible} childrenId='normal-edit-reserve-modal'>\n            <ModalInnerContainer id='normal-edit-reserve-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n                <ContentSection>\n                    {step === 1 && <ContractEditStep_1 data={data} inputDeepHandler={inputDeepHandler} />}\n\n                    {step === 2 && <ContractEditStep_2 data={data} inputDeepHandler={inputDeepHandler} onClose={visibleHandler} />}\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const NewHandleReportModal = ({ visible, visibleHandler, data, inputHandler, onSave }) => {\n    return (\n        <CustomModal visible={visible} childrenId='wide-edit-report-modal'>\n            <ModalInnerContainer id='wide-edit-report-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n                <TitleSection>\n                    <WideModalTitle>서비스 리포트 작성</WideModalTitle>\n                    <AlertText>\n                        *서비스 리포트를 작성하지 않을 경우 서비스 종료로 인정되지 않습니다.\n                        <br />\n                        환자와 헤어진 후 1시간 내에 꼭 리포트를 작성해주세요. 리포트 작성 완료 후 정산이 진행됩니다*\n                    </AlertText>\n                </TitleSection>\n                <ContentSection>\n                    <DivisionLine />\n\n                    <WithmateLabel required>서비스 진행 중 특이사항</WithmateLabel>\n                    <WithmateTextarea\n                        small\n                        placeholder='ex) 금일 이동 중 차가 많이 막혀 서비스 시간이 늘어났습니다.\n                                    금일 진료와는 상관없이 환자분의 잔기침이  많았습니다.\n                                    금일 내시경 검사가 밀려 예약된 시간보다 늦게 진료가 시작되었습니다.'\n                        value={data.description || null}\n                        onChange={ev => {\n                            inputHandler({ type: 'description', value: ev.target.value });\n                        }}\n                    />\n\n                    <DivisionLine />\n\n                    <WithmateLabel required>진료 및 치료 내용</WithmateLabel>\n                    <WithmateTextarea\n                        small\n                        placeholder='ex) 환자분의 증상은 점차 호전되고 있으며, 다음 진료 간 최종 완치 유무를 결정한다고 합니다. \n                                        또, 따로 물어보셨던 안마의자 사용은 삼가라는 답변을 들었습니다.'\n                        value={data.care || null}\n                        onChange={ev => {\n                            inputHandler({ type: 'care', value: ev.target.value });\n                        }}\n                    />\n\n                    <DivisionLine />\n\n                    <WithmateLabel>복약지도 사항</WithmateLabel>\n                    <WithmateTextarea\n                        small\n                        placeholder='ex) (약이름) : 1일 3회 식 후 복용, 해당 약 복용 중 매운 음식 자제'\n                        value={data.medicine || null}\n                        onChange={ev => {\n                            inputHandler({ type: 'medicine', value: ev.target.value });\n                        }}\n                    />\n\n                    <DivisionLine />\n\n                    <WithmateLabel>다음 진료 일정 정리</WithmateLabel>\n                    <WithmateTextarea\n                        small\n                        placeholder='ex) 다음 진료일 > 서울대병원 2021년 6월 15일 (화) 14시 20분 / CT 촬영 및 혈액 검사 예정'\n                        value={data.nextSchedule || null}\n                        onChange={ev => {\n                            inputHandler({ type: 'nextSchedule', value: ev.target.value });\n                        }}\n                    />\n\n                    <DivisionLine />\n\n                    <WithmateLabel>메이트 전달 사항</WithmateLabel>\n                    <WithmateTextarea\n                        small\n                        placeholder='ex) 오늘 병원 동행 서비스를 진행하며 어머님이 참 밝고 용감한 분이라는 생각이 많이 들었습니다. \n                                    시종일관 웃음으로 저를 대해주셨고, 치료와 진료 또한 긍정적인 마음으로 받으셨습니다. \n                                    어머님의 건강을 기원하며, 오늘 서비스를 마무리하겠습니다. 감사합니다.'\n                        value={data.mateComment || null}\n                        onChange={ev => {\n                            inputHandler({ type: 'mateComment', value: ev.target.value });\n                        }}\n                    />\n\n                    <DivisionLine />\n\n                    <WithmateLabel required>의료 기관 및 의사 평가</WithmateLabel>\n                    <WithmateTextarea\n                        small\n                        placeholder='ex) 서비스에 만족했습니다. \n                                        의사 성함 : 만족스러웠던 이유'\n                        value={data.doctorComment || null}\n                        onChange={ev => {\n                            inputHandler({ type: 'doctorComment', value: ev.target.value });\n                        }}\n                    />\n\n                    <DivisionLine big />\n\n                    <ButtonWrapper>\n                        <HalfWidthButton style={{ marginRight: '8px', color: '#afb0b2' }} bg='#e6e6e6' onClick={visibleHandler}>\n                            닫기\n                        </HalfWidthButton>\n                        <HalfWidthButton bg='#3bc1ff' onClick={onSave}>\n                            리포트 등록하기\n                        </HalfWidthButton>\n                    </ButtonWrapper>\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nexport const NoReportModal = ({ visible, visibleHandler, onNext }) => {\n    return (\n        <CustomModal visible={visible} childrenId='viewer-report-modal'>\n            <ModalInnerContainer id='viewer-report-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n                <TitleSection>\n                    <WideModalTitle>서비스 리포트 미완료 예약 알림</WideModalTitle>\n                </TitleSection>\n                <ContentSection>\n                    <DivisionLine big />\n\n                    <p>서비스 리포트 작성을 완료하지않은 수행 이력이 있습니다. </p>\n                    <p>서비스 리포트 등록을 완료하고 서비스 수행 대금을 수령해보세요.</p>\n\n                    <DivisionLine big />\n\n                    <ButtonWrapper>\n                        <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff' onClick={visibleHandler}>\n                            리포트 작성하러 가기\n                        </HalfWidthButton>\n                    </ButtonWrapper>\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\nexport const ReportMoal = ({ visible, visibleHandler, data }) => {\n    const { report, timeline, selectedServiceName } = data;\n\n    return (\n        <CustomModal visible={visible} childrenId='wide-viewer-report-modal'>\n            <ModalInnerContainer id='wide-viewer-report-modal'>\n                <CloseButton src={'/assets/images/close.png'} onClick={visibleHandler} />\n                <TitleSection>\n                    <WideModalTitle>서비스 리포트</WideModalTitle>\n                </TitleSection>\n                <ContentSection>\n                    <DivisionLine big />\n\n                    <ReportInfoBlock style={{ border: '0px' }}>\n                        <p className='title'>{moment(report.createdAt).format('YYYY년 MM월 DD일')}</p>\n                        <ReportDescription>\n                            금일 {selectedServiceName} 서비스는\n                            <span style={{ color: '#3bc1ff', fontWeight: 'bold' }}>\n                                총 {moment(timeline.complete.time).diff(timeline.receipt.time, 'minutes')}분\n                            </span>\n                            동안 진행됐습니다.\n                        </ReportDescription>\n                    </ReportInfoBlock>\n\n                    <Timeline mode={'left'}>\n                        {timeline && timeline.receipt && timeline.receipt.time && (\n                            <Timeline.Item label={moment(timeline.receipt.time).format('HH:mm').toString()}>고객님과 메이트가 만났습니다.</Timeline.Item>\n                        )}\n                        {timeline && timeline.start && timeline.start.time && (\n                            <Timeline.Item label={moment(timeline.start.time).format('HH:mm').toString()}>병원으로 출발했습니다.</Timeline.Item>\n                        )}\n                        {timeline && timeline.arrived && timeline.arrived.time && (\n                            <Timeline.Item label={moment(timeline.arrived.time).format('HH:mm').toString()}>병원에 도착했습니다.</Timeline.Item>\n                        )}\n                        {timeline && timeline.careStart && timeline.careStart.time && (\n                            <Timeline.Item label={moment(timeline.careStart.time).format('HH:mm').toString()}>진료를 시작했습니다.</Timeline.Item>\n                        )}\n                        {timeline && timeline.careDone && timeline.careDone.time && (\n                            <Timeline.Item label={moment(timeline.careDone.time).format('HH:mm').toString()}>\n                                진료가 종료됐습니다. {moment(timeline.careDone.time).diff(moment(timeline.careStart.time).toDate(), 'minutes')}분 동안\n                                진료했습니다.\n                            </Timeline.Item>\n                        )}\n\n                        {timeline && timeline.treatmentStart && timeline.treatmentStart.time && (\n                            <Timeline.Item label={moment(timeline.treatmentStart.time).format('HH:mm').toString()}>치료를 시작했습니다.</Timeline.Item>\n                        )}\n                        {timeline && timeline.treatmentDone && timeline.treatmentDone.time && (\n                            <Timeline.Item label={moment(timeline.treatmentDone.time).format('HH:mm').toString()}>\n                                치료가 종료됐습니다. {moment(timeline.treatmentDone.time).diff(moment(timeline.treatmentStart.time).toDate(), 'minutes')}분 동안\n                                치료했습니다.\n                            </Timeline.Item>\n                        )}\n\n                        {/* 진료 시작/종료(두 번째) */}\n                        {timeline && timeline.careStart_second && timeline.careStart_second.time && (\n                            <Timeline.Item label={moment(timeline.careStart_second.time).format('HH:mm').toString()}>\n                                진료(두 번째)를 시작했습니다.\n                            </Timeline.Item>\n                        )}\n                        {timeline && timeline.careDone_second && timeline.careDone_second.time && (\n                            <Timeline.Item label={moment(timeline.careDone_second.time).format('HH:mm').toString()}>\n                                진료(두 번째)가 종료됐습니다.{' '}\n                                {moment(timeline.careDone_second.time).diff(moment(timeline.careStart_second.time).toDate(), 'minutes')}분 동안 진료했습니다.\n                            </Timeline.Item>\n                        )}\n                        {/* 치료 시작/종료(두 번째) */}\n                        {timeline && timeline.treatmentStart_second && timeline.treatmentStart_second.time && (\n                            <Timeline.Item label={moment(timeline.treatmentStart_second.time).format('HH:mm').toString()}>\n                                치료(두 번째)를 시작했습니다.\n                            </Timeline.Item>\n                        )}\n                        {timeline && timeline.treatmentDone_second && timeline.treatmentDone_second.time && (\n                            <Timeline.Item label={moment(timeline.treatmentDone_second.time).format('HH:mm').toString()}>\n                                치료(두 번째)가 종료됐습니다.{' '}\n                                {moment(timeline.treatmentDone_second.time).diff(moment(timeline.treatmentStart_second.time).toDate(), 'minutes')}분 동안\n                                치료했습니다.\n                            </Timeline.Item>\n                        )}\n\n                        {/* 진료 시작/종료(세 번째) */}\n                        {timeline && timeline.careStart_third && timeline.careStart_third.time && (\n                            <Timeline.Item label={moment(timeline.careStart_third.time).format('HH:mm').toString()}>\n                                진료(세 번째)를 시작했습니다.\n                            </Timeline.Item>\n                        )}\n                        {timeline && timeline.careDone_third && timeline.careDone_third.time && (\n                            <Timeline.Item label={moment(timeline.careDone_third.time).format('HH:mm').toString()}>\n                                진료(세 번째)가 종료됐습니다.{' '}\n                                {moment(timeline.careDone_third.time).diff(moment(timeline.careStart_third.time).toDate(), 'minutes')}분 동안 진료했습니다.\n                            </Timeline.Item>\n                        )}\n                        {/* 치료 시작/종료(세 번째) */}\n                        {timeline && timeline.treatmentStart_third && timeline.treatmentStart_third.time && (\n                            <Timeline.Item label={moment(timeline.treatmentStart_third.time).format('HH:mm').toString()}>\n                                치료(세 번째)를 시작했습니다.\n                            </Timeline.Item>\n                        )}\n                        {timeline && timeline.treatmentDone_third && timeline.treatmentDone_third.time && (\n                            <Timeline.Item label={moment(timeline.treatmentDone_third.time).format('HH:mm').toString()}>\n                                치료(세 번째)가 종료됐습니다.{' '}\n                                {moment(timeline.treatmentDone_third.time).diff(moment(timeline.treatmentStart_third.time).toDate(), 'minutes')}분 동안\n                                치료했습니다.\n                            </Timeline.Item>\n                        )}\n\n                        {timeline && timeline.backStart && timeline.backStart.time && (\n                            <Timeline.Item label={moment(timeline.backStart.time).format('HH:mm').toString()}>귀가를 시작했습니다.</Timeline.Item>\n                        )}\n                        {timeline && timeline.complete && timeline.complete.time && (\n                            <Timeline.Item label={moment(timeline.complete.time).format('HH:mm').toString()}>\n                                귀가 완료하였으며, 서비스가 종료됐습니다.\n                            </Timeline.Item>\n                        )}\n                    </Timeline>\n                    {report.description && (\n                        <>\n                            <ReportInfoBlock>\n                                <p className='title'>서비스 진행 중 특이사항</p>\n                                <ReportDescription>\n                                    {(report.description &&\n                                        report.description.split('\\n').map((word, index) => (\n                                            <span key={'report-desc-word' + index.toString()}>\n                                                {word}\n                                                <br />\n                                            </span>\n                                        ))) ||\n                                        '-'}\n                                </ReportDescription>\n                            </ReportInfoBlock>\n\n                            <DivisionLine small />\n                        </>\n                    )}\n\n                    {report.care && (\n                        <>\n                            <ReportInfoBlock>\n                                <p className='title'>진료 및 치료 내용</p>\n                                <ReportDescription>\n                                    {(report.care &&\n                                        report.care.split('\\n').map((word, index) => (\n                                            <span key={'report-care-word' + index.toString()}>\n                                                {word}\n                                                <br />\n                                            </span>\n                                        ))) ||\n                                        '-'}\n                                </ReportDescription>\n                            </ReportInfoBlock>\n                            <DivisionLine small />\n                        </>\n                    )}\n\n                    {report.medicine && (\n                        <>\n                            <ReportInfoBlock>\n                                <p className='title'>복약지도 내용</p>\n                                <ReportDescription>\n                                    {(report.medicine &&\n                                        report.medicine.split('\\n').map((word, index) => (\n                                            <span key={'report-medicine-word' + index.toString()}>\n                                                {word}\n                                                <br />\n                                            </span>\n                                        ))) ||\n                                        '-'}\n                                </ReportDescription>\n                            </ReportInfoBlock>\n\n                            <DivisionLine small />\n                        </>\n                    )}\n                    {report.nextSchedule && (\n                        <>\n                            <ReportInfoBlock>\n                                <p className='title'>다음 진료 일정 정리</p>\n                                <ReportDescription>\n                                    {(report.nextSchedule &&\n                                        report.nextSchedule.split('\\n').map((word, index) => (\n                                            <span key={'report-nextSchedule-word' + index.toString()}>\n                                                {word}\n                                                <br />\n                                            </span>\n                                        ))) ||\n                                        '-'}\n                                </ReportDescription>\n                            </ReportInfoBlock>\n\n                            <DivisionLine small />\n                        </>\n                    )}\n                    {report.mateComment && (\n                        <>\n                            <ReportInfoBlock>\n                                <p className='title'>메이트 전달 사항</p>\n                                <ReportDescription>\n                                    {(report.mateComment &&\n                                        report.mateComment.split('\\n').map((word, index) => (\n                                            <span key={'report-mateComment-word' + index.toString()}>\n                                                {word}\n                                                <br />\n                                            </span>\n                                        ))) ||\n                                        '-'}\n                                </ReportDescription>\n                            </ReportInfoBlock>\n\n                            <DivisionLine small />\n                        </>\n                    )}\n\n                    {selectedServiceName.includes('은평 성모병원') && (\n                        <>\n                            <ReportInfoBlock>\n                                <p className='title'>가톨릭대학교 은평성모병원 안내 말</p>\n                                <ReportDescription>\n                                    {(report.mateComment &&\n                                        report.mateComment.split('\\n').map((word, index) => (\n                                            <span key={'report-mateComment-word' + index.toString()}>\n                                                가톨릭대학교 은평성모병원을 이용해 주셔서 감사드립니다. <br />\n                                                최고의 환자경험이 되도록 항상 최선을 다하겠습니다.\n                                                <br />\n                                            </span>\n                                        ))) ||\n                                        '-'}\n                                </ReportDescription>\n                            </ReportInfoBlock>\n\n                            <DivisionLine small />\n                        </>\n                    )}\n\n                    <ButtonWrapper>\n                        <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff' onClick={visibleHandler}>\n                            닫기\n                        </HalfWidthButton>\n                    </ButtonWrapper>\n                </ContentSection>\n            </ModalInnerContainer>\n        </CustomModal>\n    );\n};\n\nconst ModalInnerContainer = styled.div`\n    position: absolute;\n    left: 0px;\n    right: 0px;\n\n    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);\n    border: 1px solid #e6e6e6;\n    background-color: #ffffff;\n    border-radius: 8px;\n\n    width: 100%;\n    max-width: 424px;\n    overflow: hidden;\n    display: flex;\n    flex-direction: column;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none;\n    }\n\n    margin: 0 auto;\n    height: auto;\n    padding: 24px;\n\n    ${props =>\n        props.onlyMobile\n            ? `\n        display: none;\n    `\n            : ''}\n    @media (max-width: 480px) {\n        border-bottom-left-radius: 0px;\n        border-bottom-right-radius: 0px;\n        bottom: 0px;\n        padding: 16px;\n\n        ${props =>\n            props.onlyMobile\n                ? `\n        display: flex;\n        border-radius: 0px;\n        padding: 0px;\n    `\n                : ''}\n    }\n`;\n\nconst TitleSection = styled.div``;\n\nconst HeaderTitleSection = styled.div`\n    height: 44px;\n    line-height: 44px;\n    font-size: 15px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: -0.45px;\n    text-align: center;\n    color: #161616;\n    border-bottom: 1px solid #e9e9e9;\n    > span.mobile-only {\n        font-size: 15px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        letter-spacing: -0.45px;\n        text-align: center;\n        color: #161616;\n    }\n    position: relative;\n    > img {\n        position: absolute;\n        top: 6px;\n        left: 10px;\n        width: 32px;\n        height: 32px;\n        object-fit: contain;\n        cursor: pointer;\n    }\n    > img.close {\n        left: unset;\n        right: 10px;\n    }\n    @media (min-width: 480px) {\n        height: unset;\n        line-height: unset;\n        border-bottom: 0px;\n        > span.mobile-only {\n            display: none;\n        }\n        > img.mobile-only {\n            display: none;\n        }\n    }\n`;\n\nconst ContentSection = styled.div`\n    flex: 1;\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none;\n    }\n`;\n\nconst MobileContentSection = styled(ContentSection)`\n    padding: 16px;\n    @media (min-width: 480px) {\n        padding: 0px;\n    }\n`;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 24px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst AlertText = styled.div`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.52;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n`;\nconst CommonModalTitle = styled.p`\n    font-size: 28px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    text-align: left;\n    color: #161616;\n\n    margin-bottom: ${props => (props.withSub ? '8px' : '16px')};\n`;\n\nconst CommonModalSubtitle = styled.p`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.43;\n    letter-spacing: -0.7px;\n    text-align: center;\n    color: #565656;\n\n    margin-bottom: 40px;\n\n    @media (max-width: 480px) {\n        font-size: 13px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.46;\n        letter-spacing: -0.65px;\n        text-align: center;\n        margin-bottom: 32px;\n    }\n`;\n\nconst CommonModalDescription = styled.p`\n    font-size: 12px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    text-align: center;\n    color: #a6a6a6;\n    margin-top: -32px;\n    margin-bottom: 40px;\n\n    @media (max-width: 480px) {\n        font-size: 11px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.55;\n        letter-spacing: -0.55px;\n        text-align: center;\n    }\n`;\n\nconst ReportInfoBlock = styled.div`\n    padding-bottom: 24px;\n    border-bottom: 1px solid #e9e9e9;\n\n    > p.title {\n        font-size: 14px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.43;\n        letter-spacing: normal;\n        text-align: left;\n        color: #afb0b2;\n        margin-bottom: 8px;\n    }\n`;\n\nconst ReportDescription = styled.div`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-size: 15px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.57;\n        letter-spacing: -0.3px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n`;\n","import React, { Component } from 'react';\nimport Styled from 'styled-components';\nimport { withRouter } from 'react-router-dom';\nimport KakaoLoginImg from './o2.png';\nimport KakaoLoginImgM from './o.png';\nimport { KAKAO, USER } from '../../../../Lib/variables';\nimport { notification } from 'antd';\n\nconst { Kakao } = window;\n\nclass KakaoLogin extends Component {\n    onEdit = ({ type, value }) => {\n        this.props.editRegisterForm({ type, value });\n    };\n\n    checkUser = async ({ email }) => {\n        const { userType, type } = this.props.auth.registerForm;\n        const resolve = await this.props.checkUserId({ id: email, userType: USER, type: KAKAO });\n        console.log(resolve);\n        return resolve;\n    };\n\n    register = async ({ email, gender }) => {\n        const { photo, contact, marketing, connection, birth, message, userType, type, name } = this.props.auth.registerForm;\n        this.onEdit({ type: 'type', value: KAKAO });\n        this.onEdit({ type: 'email', value: email });\n        this.onEdit({ type: 'sex', value: gender === 'male' ? '남' : '녀' });\n        this.props.history.push('/user/register');\n        // const resolve = await this.props.register({ id: email, userType: USER, name, type: KAKAO, photo, contact, marketing, connection, birth, sex: gender });\n        // if (resolve && resolve.message === 'success') {\n        // }\n\n        // if (resolve === 'check parameters') {\n        //   notification.open({\n        //     message: '회원가입에 실패하였습니다.',\n        //     description: '누락된 정보가 없는지 확인해주세요.',\n        //     type: 'success',\n        //   });\n        // }\n    };\n\n    login = async ({ email }) => {\n        const { userType, type } = this.props.auth.registerForm;\n        const resolve = await this.props.login({ id: email, userType: USER, type: KAKAO });\n        if (resolve === 'not exist') {\n            return this.setState({\n                modal: true,\n                modalTitle: '이메일 로그인',\n                modalInfo: '존재하지 않는 사용자의 아이디입니다. 아이디를 확인해주세요.',\n            });\n        }\n\n        if (resolve === 'not allowed') {\n            return this.setState({\n                modal: true,\n                modalTitle: '이메일 로그인',\n                modalInfo: '관리자로부터의 가입 승인을 대기중입니다. ',\n            });\n        }\n\n        if (resolve === 'wrong password') {\n            return this.setState({\n                modal: true,\n                modalTitle: '이메일 로그인',\n                modalInfo: '잘못된 비밀번호입니다. 확인 후 다시 시도해주세요. ',\n            });\n        }\n    };\n\n    loginWithKakao = () => {\n        // scope : 수집할 사용자 정보 명시(동의항목)\n        const scope = 'profile_nickname, gender, account_email';\n\n        const that = this;\n        // const { photo, contact, marketing, connection, birth, message } = this.props.auth.registerForm;\n\n        Kakao.Auth.login({\n            scope,\n            // success는 인증 정보를 응답(response) 받는다.\n            success: function (response) {\n                //카카오 SDK에 사용자 토큰을 설정한다.\n                window.Kakao.Auth.setAccessToken(response.access_token);\n                // console.log(`AccessToken 정보 : ${window.Kakao.Auth.getAccessToken()}`);\n\n                window.Kakao.API.request({\n                    url: '/v2/user/me',\n                    success: async function ({ kakao_account }) {\n                        //어떤 정보 넘어오는지 확인\n                        // console.log(kakao_account);\n                        const { email, gender } = kakao_account;\n\n                        // console.log(email)\n                        const resolve = await that.checkUser({ email });\n                        console.log(resolve);\n                        if (resolve === true) {\n                            that.login({ email });\n                        } else {\n                            that.register({ email, gender });\n                        }\n                    },\n                    fail: function (error) {\n                        console.log(error);\n                    },\n                });\n            },\n            fail: function (error) {\n                console.log(error);\n            },\n        });\n    };\n    render() {\n        const { location } = this.props.history;\n\n        let viewToShow;\n        if (location.pathname.includes('/login')) {\n            viewToShow = <ButtonWrap onClick={this.loginWithKakao}>카카오 로그인</ButtonWrap>;\n        } else if (location.pathname.includes('/mainRegister')) {\n            viewToShow = (\n                <ButtonWrap2 onClick={this.loginWithKakao}>\n                    <span className='visually-hidden'>카카오</span>\n                </ButtonWrap2>\n            );\n        }\n\n        return <div className='KakaoIdLogin'>{viewToShow}</div>;\n    }\n}\n\nexport default withRouter(KakaoLogin);\n\nconst ButtonWrap = Styled.div`\n  background-image: url(${KakaoLoginImg});\n  background-repeat: no-repeat;\n  margin: -10px auto;\n  padding-top: 12px;\n  text-align: center;\n  font-weight: bold;\n  width: 100%;\n  height: 45px;\n  border-radius: 12px;\n\n    @media (max-width: 768px) {\n      background-image: url(${KakaoLoginImgM});\n      width: 100%;\n      height: 45px;\n    }\n`;\n\nconst ButtonWrap2 = Styled.div`\n  background-image: url(${'/assets/images/icons/kakaotalk.png'});\n  background-repeat: no-repeat;\n  margin: -10px auto;\n  text-align: center;\n  width: 50px;\n  height: 50px;\n  overflow: hidden;\n\n  @media (max-width: 768px) {\n    background-image: url(${'/assets/images/icons/kakaotalk.png'});\n    width: 100%;\n    height: 45px;\n  }\n\n  span.visually-hidden {\n    position: absolute;\n    width: 1px;\n    height: 1px;\n    margin: -1px;\n    padding: 0;\n    border: 0;\n    clip: rect(0, 0, 0, 0);\n    overflow: hidden;\n  }\n`;\n","import React from 'react';\nimport { NavLink } from 'react-router-dom';\nimport { notification, message, Input, Button } from 'antd';\nimport { LOCAL, MATE, USER } from '../../../../Lib/variables';\nimport { CommonWithmateModal } from '../../../../Components/newModal';\nimport { DivisionLine, WithmateInput } from '../../../../Components/Common/input';\n\nimport KakaoLogin from './KakaoLogin';\n\nclass LoginComponent extends React.PureComponent {\n    state = {\n        modal: false,\n        modalTitle: '',\n        modalInfo: '',\n    };\n\n    onEdit = ({ type, value }) => {\n        this.props.editLoginForm({ type, value });\n    };\n\n    login = () => {\n        const { email, password, userType } = this.props.auth.loginForm;\n        const type = LOCAL;\n\n        this.props\n            .login({ id: email, password, userType, type })\n            .then(resolve => {\n                if (resolve === 'not exist') {\n                    return this.setState({\n                        modal: true,\n                        modalTitle: '이메일 로그인',\n                        modalInfo: '존재하지 않는 사용자의 아이디입니다. 아이디를 확인해주세요.',\n                    });\n                }\n\n                if (resolve === 'not allowed') {\n                    return this.setState({\n                        modal: true,\n                        modalTitle: '이메일 로그인',\n                        modalInfo: '관리자로부터의 가입 승인을 대기중입니다. ',\n                    });\n                }\n\n                if (resolve === 'wrong password') {\n                    return this.setState({\n                        modal: true,\n                        modalTitle: '이메일 로그인',\n                        modalInfo: '잘못된 비밀번호입니다. 확인 후 다시 시도해주세요. ',\n                    });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n                // return notification.open({\n                //     message: '로그인 에러',\n                //     description: '로그인 처리중 에러가 발생하였습니다. 새로고침 후 다시 시도해주세요.',\n                //     type: 'error',\n                // });\n            });\n    };\n\n    render() {\n        const { loginForm } = this.props.auth;\n\n        return (\n            <div className='login-container'>\n                <div className='inner-container'>\n                    <div className='login-form'>\n                        <div className='login-title'>\n                            <img src='/assets/images/new_logo_img.png' alt='위드메이트 로고' style={{ width: '45px', height: 'auto' }} /><p style={{ display: 'inline-block', verticalAlign: '-10px', paddingLeft: '10px' }}>로그인</p>\n                            <br/>\n                            <h5 style={{color: 'gray'}}>위드메이트의 서비스를 이용하기 위해 로그인을 해주세요.</h5>\n                        </div>\n                        <div>\n                            <div className='form-user-type'>\n                                <div\n                                    onClick={() => {\n                                        this.onEdit({ type: 'userType', value: USER });\n                                    }}\n                                    className={`type ${loginForm && loginForm.userType === USER ? 'active' : undefined}`}\n                                >\n                                    <p>일반 고객 로그인</p>\n                                    <h5>병원 동행서비스를 이용하고 싶어요!</h5>\n                                </div>\n                            </div>\n                            <div className='form-user-type'>\n                                <div\n                                    onClick={() => {\n                                        this.onEdit({ type: 'userType', value: MATE });\n                                    }}\n                                    className={`type ${loginForm && loginForm.userType === MATE ? 'active' : undefined}`}\n                                >\n                                    <p>메이트 로그인</p>\n                                    <h5>병원 동행서비스를 수행하는 메이트로 활동하고 싶어요!</h5>\n                                </div>\n                            </div>\n                        </div>\n                        {loginForm.userType === USER ? <>\n                            <div className='form'>\n                                <label>이메일</label>\n                                <WithmateInput\n                                    type='email'\n                                    value={loginForm.email}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'email', value: ev.target.value });\n                                    }}\n                                    placeholder='ex) korea@mail.com'\n                                />\n                                <DivisionLine />\n                                <WithmateInput\n                                    type='password'\n                                    value={loginForm.password}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'password', value: ev.target.value });\n                                    }}\n                                    onPressEnter={this.login}\n                                    placeholder='비밀번호를 입력해주세요'\n                                />\n\n                                <Button type='primary' style={{ borderRadius: '4px', marginTop: '20px', borderRadius: '12px' }} onClick={this.login}>\n                                    로그인 하기\n                                </Button>\n                                {loginForm.userType === USER ?\n                                    <KakaoLogin {...this.props} /> : null\n                                }\n\n                                <DivisionLine />\n\n                                <div className='link-wrapper'>\n                                    <span\n                                        className='link'\n                                        onClick={() => {\n                                            this.props.history.push('/user/register');\n                                        }}\n                                    >\n                                        회원가입\n                                    </span>\n                                    <span\n                                        className='link'\n                                        onClick={() => {\n                                            this.props.history.push('/user/find/password');\n                                        }}\n                                    >\n                                        비밀번호 찾기\n                                    </span>\n                                    <span\n                                        className='link'\n                                        onClick={() => {\n                                            this.props.history.push('/mate/apply');\n                                        }}\n                                    >\n                                        메이트 지원하기\n                                    </span>\n                                </div>\n                            </div>\n                        </> : null}\n\n                        {loginForm.userType === MATE ? <>\n                            <div className='form'>\n                                <label>이메일</label>\n                                <WithmateInput\n                                    type='email'\n                                    value={loginForm.email}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'email', value: ev.target.value });\n                                    }}\n                                    placeholder='ex) korea@mail.com'\n                                />\n                                <DivisionLine />\n                                <WithmateInput\n                                    type='password'\n                                    value={loginForm.password}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'password', value: ev.target.value });\n                                    }}\n                                    onPressEnter={this.login}\n                                    placeholder='비밀번호를 입력해주세요'\n                                />\n\n                                <Button type='primary' style={{ borderRadius: '4px', marginTop: '20px', borderRadius: '12px' }} onClick={this.login}>\n                                    로그인 하기\n                                </Button>\n\n                                <DivisionLine />\n\n                                <div className='link-wrapper'>\n                                    <span\n                                        className='link'\n                                        onClick={() => {\n                                            this.props.history.push('/user/register');\n                                        }}\n                                    >\n                                        회원가입\n                                    </span>\n                                    <span\n                                        className='link'\n                                        onClick={() => {\n                                            this.props.history.push('/user/find/password');\n                                        }}\n                                    >\n                                        비밀번호 찾기\n                                    </span>\n                                    <span\n                                        className='link'\n                                        onClick={() => {\n                                            this.props.history.push('/mate/apply');\n                                        }}\n                                    >\n                                        메이트 지원하기\n                                    </span>\n                                </div>\n                            </div>\n                        </> : null}\n                    </div>\n                </div>\n\n                {this.state.modal && (\n                    <CommonWithmateModal\n                        visible={this.state.modal}\n                        config={{\n                            title: this.state.modalTitle,\n                            description: this.state.modalInfo,\n                            confirmText: '확인 및 닫기',\n                            noClose: true,\n                        }}\n                        onOk={() => {\n                            this.setState({ modal: false, modalTitle: '', modalInfo: '' });\n                        }}\n                    />\n                )}\n            </div>\n        );\n    }\n}\nexport default LoginComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport LoginStyledContainer from './login.styled';\nimport Login from './login';\nimport { login, editLoginForm, editRegisterForm, checkUserId } from '../../../../Reducer/Modules/auth';\n\nclass LoginPage extends React.PureComponent {\n    componentDidMount = () => {\n        const { auth } = this.props;\n        const userId = localStorage.getItem('id');\n        if ((auth && auth.id) || userId) return this.props.history.goBack('/');\n    };\n    render() {\n        return (\n            <LoginStyledContainer>\n                <Login {...this.props} />\n            </LoginStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ auth }) => ({\n    auth,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    editRegisterForm: ({ type, value }) => dispatch(editRegisterForm({ type, value })),\n    login: ({ id, password, userType, type }) => dispatch(login({ id, password, userType, type })),\n    checkUserId: ({ id, userType, type }) => dispatch(checkUserId({ id, userType, type })),\n    editLoginForm: ({ type, value }) => dispatch(editLoginForm({ type, value })),\n});\nexport default connect(mapStateToProps, mapDispatchToProps)(LoginPage);\n","import React from 'react';\nimport { MATE, USER } from '../../../../Lib/variables';\nimport KakaoLogin from '../Login/KakaoLogin';\n\nclass MainComponent extends React.PureComponent {\n    render() {\n        const { userType } = this.props.auth;\n\n        return (\n            <div className='login-container'>\n                <div className='inner-container'>\n                    <div className='register-form'>\n                        <div className='register-title'>\n                            <img src='/assets/images/new_logo_img.png' alt='위드메이트 로고' style={{ width: '45px', height: 'auto' }} />\n                            <p style={{ display: 'inline-block', verticalAlign: '-10px', paddingLeft: '10px' }}>회원가입</p>\n                            <br />\n                            <h5 style={{ color: 'gray' }}>위드메이트의 서비스를 이용하기 위해 회원가입을 해주세요.</h5>\n                        </div>\n\n                        <div>\n                            <div className='form-user-type'>\n                                <div\n                                    onClick={() => {\n                                        this.props.history.push('/user/register');\n                                    }}\n                                    className={`type ${userType === USER ? 'active' : undefined}`}\n                                >\n                                    <p>일반 고객으로 가입하기</p>\n                                    <h5>병원 동행서비스를 이용하고 싶어요!</h5>\n                                </div>\n                            </div>\n                            <div className='form-user-type'>\n                                <div\n                                    onClick={() => {\n                                        this.props.history.push('/mate/apply');\n                                    }}\n                                    className={`type ${userType === MATE ? 'active' : undefined}`}\n                                >\n                                    <p>메이트 지원하기</p>\n                                    <h5>병원 동행서비스를 수행하는 메이트로 활동하고 싶어요!</h5>\n                                </div>\n                            </div>\n                        </div>\n\n                        {/* <div className='link-wrapper'>\n                            <span className='text'>SNS계정으로 간편하게 회원가입 </span>\n                            <div style={{ paddingLeft: '15px', paddingBottom: '15px', borderRadius: '20px', width: 'auto', height: 'auto' }}>\n                                <KakaoLogin {...this.props} checkUserId={this.props.checkUserId} />\n                            </div>\n                        </div> */}\n                        <div className='link-wrapper'>\n                            <span className='text'>이미 계정이 있으신가요? </span>\n                            <span\n                                onClick={() => {\n                                    this.props.history.push('/user/login');\n                                }}\n                                className='link'\n                            >\n                                로그인\n                            </span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default MainComponent;\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\n\nconst MainRegisterStyledContainer = styled.div`\n    margin-top: 55px;\n    min-height: 100vh;\n    background-image: url('/assets/images/login_bg.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: 80% 50%;\n\n    @media (max-width: 480px) {\n        min-height: initial;\n        height: 100%;\n    }\n\n    .inner-container {\n        padding: 0px;\n        padding-top: 144px;\n        padding-bottom: 100px;\n\n        @media (max-width: 480px) {\n            padding: 0px;\n        }\n\n        .register-form {\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n            width: 100%;\n            max-width: 340px;\n            margin: 0 auto;\n            padding: 24px;\n\n            @media (max-width: 480px) {\n                max-width: initial;\n                width: 100%;\n                border-radius: 0px;\n                box-shadow: none;\n            }\n\n            .register-title {\n                margin-bottom: 24px;\n\n                p {\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n            }\n\n            .link-wrapper {\n                display: flex;\n                justify-content: center;\n                .text {\n                    font-size: ${sizeHandler(14)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: rgba(0, 0, 0, 0.7);\n                    line-height: 21px;\n                }\n\n                .link {\n                    cursor: pointer;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: ${mainColor};\n\n                    margin-left: 8px;\n                }\n            }\n\n            .form {\n                label {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.15px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n\n                input {\n                    height: 40px;\n                    border: solid 1px #e6e6e6;\n                    // margin-bottom: 20px;\n                }\n\n                button {\n                    width: 100%;\n                    height: 46px;\n                    margin-top: 4px;\n                    margin-bottom: 16px;\n\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    letter-spacing: -0.2px;\n                    text-align: center;\n                    color: #ffffff;\n                }\n            }\n\n            .form-user-type {\n                height: 76px;\n                margin-bottom: 20px;\n                border-radius: 4px;\n                border: 1px solid #e6e6e6;\n                display: flex;\n                align-items: center;\n                overflow: hidden;\n\n                .type {\n                    flex: 1;\n                    height: 100%;\n                    line-height: 30px;\n                    background-color: #ffffff;\n                    cursor: pointer;\n\n                    &:first-child {\n                        border-right: 1px solid #e6e6e6;\n                    }\n\n                    p {\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        line-height: 40px;\n                        text-align: left;\n                        padding-left: 10px;\n                        color: #606060;\n                    }\n\n                    h5 {\n                        font-size: ${sizeHandler(12)};\n                        text-align: left;\n                        padding-left: 10px;\n                        color: #606060;\n                    }\n\n                    &.active {\n                        background-color: #606060;\n\n                        p {\n                            color: #ffffff;\n                        }\n\n                        h5 {\n                            color: white;\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\nexport default MainRegisterStyledContainer;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport MainRegister from './main';\nimport MainRegisterStyledContainer from './main.styled';\n\nclass MainRegisterPage extends React.PureComponent {\n    render() {\n        return (\n            <MainRegisterStyledContainer>\n                <MainRegister {...this.props} />\n            </MainRegisterStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ auth }) => ({\n    auth,\n});\n\nconst mapDispatchToProps = dispatch => ({\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(MainRegisterPage);","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\n\nconst RegisterStyledContainer = styled.div`\n    padding-top: 110px;\n    padding-bottom: 55px;\n\n    background-image: url('/assets/images/login_bg.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: 80% 50%;\n\n    @media (max-width: 480px) {\n        min-height: initial;\n        height: 100%;\n        padding-bottom: 0px;\n        padding-top: 55px;\n    }\n\n    .inner-container {\n        padding-bottom: 0px;\n        padding-top: 0px;\n\n        @media (max-width: 480px) {\n            padding: 0px;\n        }\n\n        .register-form {\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n            width: 100%;\n            max-width: 360px;\n            margin: 0 auto;\n            padding: 32px;\n\n            @media (max-width: 480px) {\n                max-width: initial;\n                width: 100%;\n                border-radius: 0px;\n                box-shadow: none;\n                padding: 24px;\n            }\n\n            .title-wrapper {\n                display: flex;\n                justify-content: flex-start;\n                margin-bottom: 16px;\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    line-height: 48px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                }\n\n                span {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: right;\n                    color: ${mainColor};\n                }\n            }\n\n            .form {\n                label {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.15px;\n                    line-height: 20px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 4px;\n                }\n\n                input {\n                    height: 44px;\n                    border: solid 1px #e6e6e6;\n                    padding: 10px;\n\n                    &.ant-input {\n                        font-size: 16px;\n                        line-height: 28px;\n                        letter-spacing: -0.2px;\n                        color: rgba(0, 0, 0, 0.7);\n\n                        &::placeholder {\n                            font-size: 14px;\n                        }\n                    }\n                }\n\n                .type-button-wrapper {\n                    width: 100%;\n                    height: 48px;\n\n                    background-color: white;\n                    border: 1px solid #e6e6e6;\n                    border-radius: 4px;\n\n                    display: flex;\n                    align-items: center;\n\n                    > .type-button {\n                        width: 50%;\n                        height: 100%;\n                        line-height: 48px;\n\n                        text-align: center;\n                        cursor: pointer;\n\n                        font-size: 16px;\n                        letter-spacing: -0.2px;\n                        color: rgba(0, 0, 0, 0.2);\n                    }\n\n                    > .type-button.active {\n                        background: rgba(0, 0, 0, 0.7);\n                        border-radius: 4px;\n                        color: #f9f9f9;\n                    }\n                }\n\n                button {\n                    width: 100%;\n                    height: 46px;\n                    margin-top: 4px;\n                    margin-bottom: 16px;\n\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    letter-spacing: -0.2px;\n                    text-align: center;\n                    color: #ffffff;\n                }\n\n                .link-wrapper {\n                    display: flex;\n                    justify-content: center;\n                    margin-bottom: 8px;\n                    .text {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: rgba(0, 0, 0, 0.7);\n                        line-height: 21px;\n                    }\n\n                    .link {\n                        cursor: pointer;\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: ${mainColor};\n\n                        margin-left: 8px;\n                    }\n                }\n            }\n\n            .form-user-type {\n                height: 36px;\n                margin-bottom: 20px;\n                border-radius: 4px;\n                border: 1px solid #e6e6e6;\n                display: flex;\n                align-items: center;\n                overflow: hidden;\n\n                .type {\n                    flex: 1;\n                    height: 100%;\n                    line-height: 36px;\n                    background-color: #ffffff;\n                    cursor: pointer;\n\n                    &:first-child {\n                        border-right: 1px solid #e6e6e6;\n                    }\n\n                    p {\n                        font-size: ${sizeHandler(12)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #606060;\n                    }\n\n                    &.active {\n                        background-color: #606060;\n\n                        p {\n                            color: #ffffff;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .ant-upload-drag-container {\n        .title {\n            margin-top: 12px;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: rgba(0, 0, 0, 0.8);\n        }\n\n        .reco {\n            font-size: ${sizeHandler(12)};\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: #a7a7a7;\n        }\n    }\n`;\nexport default RegisterStyledContainer;\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../theme';\nconst TermsStyledContainer = styled.div`\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default TermsStyledContainer;\n","import React from 'react';\n\nclass TermsComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>위드메이트 서비스 이용약관</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 1조(목적)</h3>\n                        <p>\n                            본 약관은 ㈜블루카멜(이하 “회사”라 한다)가 제공하는 위드메이트 병원 동행 서비스와 관련하여 회사와 회원과의 권리,\n                            <br />\n                            의무 및 책임 사항, 그리고 기타 필요한 사항을 규정함을 목적으로 합니다.\n                        </p>\n                        <br />\n                        <p>본 서비스 이용약관은 2021년 12월 20일부터 시행됩니다.</p>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 2조(정의)</h3>\n                        <h5>1. 본 약관에서 사용하는 용어의 정의는 다음과 같습니다.</h5>\n\n                        <div className='info'>\n                            <p className='title'>“위드메이트 서비스” 혹은 “서비스”라 함은 당사가 제공하는 ‘병원 동행 서비스’를 의미합니다.</p>\n                            <p className='title'>\n                                “회원”이라 함은 회사가 제공하는 서비스를 이용하기 위하여 본 약관에 동의하고 회사의 회원으로 가입하는 자를 말합니다. (단,\n                                메이트와 관련된 사실 관계에 한하여, 메이트도 본 약관에서 “회원”에 포함될 수 있습니다)\n                            </p>\n                            <p className='title'>\n                                “메이트”라 함은 회사가 회원에게 서비스를 제공하기 위해 직접 선별하고 교육하여 ‘프리랜서’의 형태로 간접 고용한 인원을 말합니다.\n                            </p>\n                            <p className='title'>\n                                “운송사업자\"라 함은 여객자동차 운수사업법 제4조에 따른 면허를 받은 여객자동차 운송사업자로서, 회사(메이트 인력)의 중개 또는 회원\n                                스스로를 통해 택시 등 그 면허를 받은 운송 수단을 이용하여 운송서비스를 제공하는 자를 의미합니다.\n                            </p>\n                            <p className='title'>\n                                “중개”라 함은 회사가 직접 서비스를 제공하지 않고, 이용자 또는 회원의 요청에 따라 적격 메이트를 연결하여 알선하는 것을\n                                의미합니다.\n                            </p>\n                            <p className='title'>\n                                “매칭”이라 함은 회원이 플랫폼(웹사이트 포함)에서 출발지와 목적지를 입력하고, “예약하기\" 버튼을 통해 서비스 이용을 요청(이하\n                                “이용 요청”이라고 합니다)하면, 요청 시점에 서비스 제공이 가능한 메이트가 플랫폼(웹사이트 포함)을 통하여\n                                수락함으로써(매칭됨으로써), 회원과 회사 사이의 메이트 알선 계약이 각 체결된 상태를 의미합니다.\n                            </p>\n                            <p className='title'>\n                                “플랫폼(웹사이트 포함)”이라 함은 회사가 회원에게 서비스를 제공하기 위하여 개발한 위드메이트 애플리케이션과 웹사이트를\n                                의미합니다.\n                            </p>\n                            <p className='title'>\n                                “이용요금”이라 함은\n                                <br />\n                                (i) 메이트가 제공하는 의료 동행 서비스에 대한 비용\n                                <br />\n                                (ii) 회원이 택시 등 운송사업자의 운송 수단을 예약하거나 호출하여 이동하는 비용,\n                                <br />\n                                (iii) 기타 비용(고객 소유 자가용 대리 운전 비용, 예약 취소 및 변경 수수료 등)을 총칭하여 의미합니다.\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '56px' }}>\n                            2. 본 약관에서 사용하는 용어의 정의는 본 조제 1항에서 정하는 것을 제외하고는 관계 법령에서 정하는 바에 의합니다. 관계 법령에서\n                            정하지 않는 것은 일반적인 상 관례에 의합니다.\n                        </h5>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 3조(약관의 효력 및 변경)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            약관은 애플리케이션 소프트웨어 및 해당 애플리케이션과 웹사이트의 모든 패치, 업데이트, 업그레이드 또는 새로운 버전에 적용되며, 가장\n                            최신 버전이 모든 기존 버전에 우선합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            본 약관은 서비스 이용계약의 성격상 회사의 웹사이트 또는 서비스 이용을 위한 애플리케이션 내에 본 약관을 명시하고, 이용자가\n                            애플리케이션을 설치 및 실행 혹은 웹사이트 열람과 동시에 효력이 발생합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>회사는 관계 법령 또는 상관습에 위배되지 않는 범위에서 본 약관을 개정할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사는 관련 법령의 변경이나 이용자의 권리 및 의무사항, 서비스 등을 개선하기 위해 본 약관을 변경할 수 있으며, 변경된 경우에 약관의\n                            내용과 적용일을 정하여, 적용일 7일 전 회사 공식 홈페이지나 공식 블로그, 제공하는 애플리케이션 등을 통해 이용자에게 고지하고\n                            적용일부터 효력이 발생합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            이용자는 변경된 약관에 대해 거부할 권리가 있습니다. 본 약관의 변경에 대해 이의가 있는 이용자는 서비스 이용을 중단하고 이용을\n                            해지(탈퇴 및 삭제)할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회사가 본 조 4항에 따라 변경된 약관을 공시 또는 고지하면서 이용자가 기간 내의 의사표시를 하지 않으면 변경된 약관에 동의한 것으로\n                            간주합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 4조(약관 외 준칙)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 필요한 경우 특정 서비스에 관하여 적용될 사항을 위해 개별 약관이나 이용 정책을 정하여 운영할 수 있으며, 해당 내용은 홈페이지\n                            등을 통해 공지합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            본 약관에 규정되지 않은 사항에 대해서는 관련 법령 또는 개별 약관, 이용 정책, 서비스 이용 화면을 통하여 제시된 개별 이용 조건(이용\n                            요금 등, 이하 “개별계약“이라고 합니다)에서 정한 바에 따릅니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            본 약관과 개별 약관, 개별 계약의 내용이 충돌할 경우 본 약관에 별도의 규정이 없는 한 개별 계약 또는 개별 약관에서 정한 바에 따릅니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회원은 서비스 이용 시 개별 계약 또는 개별 약관의 내용을 확인하여야 하며, 이를 확인하지 않아 발생한 손해에 대해 회사는 책임을\n                            부담하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 5조(이용 계약의 성립)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            이용 계약은 이용자가 본 이용 약관에 대한 동의 또는 회사의 애플리케이션을 다운로드 받거나 실행하여 이용하는 경우, 그리고 웹사이트\n                            회원 가입을 완료한 경우 이 약관에 동의한 것으로 간주합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>이용자는 동의하지 않는 경우 애플리케이션이나 웹사이트 계정 로그아웃 및 삭제와 함께 이를 철회할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 제 1항에 따른 회원 가입 신청에 대해 승낙함을 원칙으로 합니다. 다만, 다음 각 호의 경우 회사는 회원 가입 신청을 승낙하지 않거나\n                            사후에 회원 계약을 해지할 수 있습니다.\n                        </h6>\n\n                        <div className='info'>\n                            <p className='title'>신청자가 본 약관 위반 등의 사유로 이전에 회원 자격이 상실 또는 회원 계약이 해지되었던 경우</p>\n                            <p className='title'>자신의 귀책으로 이용 정지를 당한 회원이 그 이용 정지 기간 중에 이용 계약을 임의 해지하고 재신청을 하는 경우</p>\n                            <p className='title'>본 약관에 위배되거나 위법 또는 사회상규상 부당한 가입 신청임이 확인된 경우</p>\n                            <p className='title'>허위의 정보를 기재한 경우, 회사가 제시하는 내용을 기재하지 않은 경우 또는 오기 등이 있는 경우</p>\n                            <p className='title'>미성년자 등 법령상 행위 무능력자인 경우</p>\n                            <p className='title'>기타 신청자의 귀책 사유로 인하여 승낙이 불가능하거나 기타 회사가 정한 제반 사항을 위반한 자의 신청</p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            서비스 신청자가 대리인일 경우, 해당 서비스 수혜자에 대한 모든 정보는 사실에 근거하여 제공되어야 하며, 허위 사실 기재 시 발생하는\n                            모든 민형사상 책임은 신청자에게 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 6조(회원 계약의 해제 및 해지 등)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            회원은 언제든지 회원 계약의 해지를 신청할 수 있으며, 회사는 관련 법령에서 정하는 바에 따라 이를 즉시 처리하여야 합니다. 다만,\n                            회원에게 미수금이 있을 경우에는 미수금에 대한 결제를 완료한 이후에 해지 신청이 가능합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원이 회원 계약을 해지할 경우, 회사는 관련 법령 개인정보처리방침 또는 내부관리 계획 등에 따라 회원 정보를 보유하는 경우를\n                            제외하고는 해지 즉시 회원의 모든 정보를 삭제합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회원 계약 해지로 인해 발생한 불이익에 대한 책임은 회원 본인이 부담해야 하며, 회사는 회원에게 부가적으로 제공한 각종 무상 혜택을\n                            회수할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사가 회원 계약을 해지하는 경우 회사는 회원에게 해지 사유를 밝혀 해지 의사를 통지합니다. 이 경우 회사는 해지를 하기 전에 상당한\n                            기간을 정하여 회원에게 이의 신청의 기회를 부여합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>회원 계약이 회사에 의해 해지되는 경우 회원의 재이용 신청에 대해 회사는 승낙을 거절할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회원의 귀책 사유로 인해 회원 계약이 해지됨으로써 발생한 손해는 당해 회원이 부담하여야 하며, 회사는 관련 법령에 규정이 없는 한 책임을\n                            부담하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 7조(서비스 내용)</h3>\n                        <h5>1.</h5>\n                        <h6>회사가 제공하는 병원 동행 서비스의 내용은 다음과 같습니다.</h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>병원 동행 Pro 서비스 : </span>응급 상황에 처하지는 않았으나 정기적, 혹은 비정기적으로 의료 기관에 방문해\n                                적절한 조치를 받아야 하는 고객을 위한 서비스.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>병원 동행 Basic 서비스 & 수면내시경 보호자 서비스 :</span>보호자 동행이 법적 의무는 아니나 보호자가 없을\n                                경우 시술이 어려운 수면 내시경 등과 같은 의료 조치를 받아야 하는 고객을 위한 보호자 대행 서비스.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>병원 동행 서비스 제공을 위한 메이트 알선(중개) 서비스 : </span>회원의 서비스 이용 요청 시 적격 자격을\n                                갖춘 인원을 회사가 직접 선별하고 교육한 후, 프리랜서로 등록된 인력이 병원 동행 서비스를 위한 동행자를 알선 받을 수 있도록\n                                중개해주는 서비스.\n                            </p>\n\n                            <p className='title'>\n                                <span className='bold'>고객 소유 자가용 대리 운전 서비스 : </span>회원의 요청에 따라 알선된 메이트가 고객 소유의 자가용을 운행해\n                                병원과 자택을 이동하는 서비스\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>택시 등 여객자동차 운송 중개 서비스 :</span>회원의 요청에 따라 알선된 메이트가 택시 등 여객자동차\n                                운송사업자의 운송 수단을 호출하여 동행할 수 있도록 중개해주는 서비스.\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 제1항의 각 호의 서비스 이외에도 추가적인 서비스를 개발하여 회원에게 제공할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사가 제공하는 서비스와 플랫폼(웹사이트 포함)의 사용은 무료입니다. 단, 회사가 제공한 서비스를 통해 메이트 알선을 포함한 병원 동행\n                            서비스가 제공되는 경우 사용자는 해당 서비스에 대한 이용 요금을 지불할 의무를 가집니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사는 회원과 메이트 사이의 병원 동행 서비스 혹은 메이트 알선 계약 및 회원과 여객자동차 운송사업자 사이의 운송 계약 체결을 중개하고\n                            제 8조 1항에 명시된 ‘병원 동행 서비스 비용’을 수취하는 회사입니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>회사의 메이트는 고객에게 어떠한 형태의 의료 서비스나 치료, 구급차 등의 의료 운송 서비스를 제공하지 않습니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 8조(이용 요금 등)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            위드메이트 서비스 이용 요금은 ‘병원 동행 서비스 비용’으로 구성되어 있습니다. 단, 상황에 따라 이동 중에 발생하는 운송 교통 비용이\n                            고객 본인 부담으로 발생할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 이용 요금을 애플리케이션 혹은 웹사이트 내의 예약하기 페이지에 게시하거나, 예약 완료 시에 별도로 회원에게 안내합니다. 다만\n                            최종 이용 요금은 다양한 변수에 따라서 서비스 종료 후 추가 부과가 될 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            메이트가 회원이 지정한 출발지에 도착하여 회원에게 도착을 안내하였음에도 회원이 사전 연락 없이 일정 시간(20분) 이내에 나타나지\n                            아니하거나 계약을 취소하는 경우 회사는 제 9조에 명시된 취소 수수료를 회원에게 부과할 수 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            [병원 동행 Pro] 서비스 이용 옵션 중 ‘고객 소유의 자차 운행’을 선택한 경우 예약일에 맞춰 본인의 차량 보험사가 제공하는 ‘임시 운전자\n                            특약’에 가입을 해야 합니다. 이때 발생하는 보험 비용은 고객 본인 부담이며, 임시 운전자 특약에 가입을 하지 않고 메이트에게 운전을\n                            위임하여 사고가 발생한 경우 모든 책임은 고객 본인에게 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            서비스와 관련하여 발생한 미납경비, 손해배상 등 회원의 회사에 대한 채무가 모두 정산될 때까지 해당 회원의 서비스 사용이 중지되며, 그\n                            채무가 일정기간 계속하여 변제되지 않을 경우에는 해당 회원의 회원자격이 박탈될 수 있습니다. 서비스 사용 중지 또는 회원자격 박탈에\n                            대한 판단 기준은 회사의 약관 및 이용정책에 근거합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회원이 본 약관 및 위 각 조항을 준수하지 않았을 경우, 회사는 본 약관 및 이용 정책에 따라 손해배상 금액 등 각종 수수료를 부과하는 것\n                            외에 계약을 해지할 수 있는 권리를 가집니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>7.</h5>\n                        <h6>\n                            회사는 본 서비스와 관련하여 발생한 미납경비, 손해배상 등 회원의 회사에 대한 채무가 정산되지 않을 경우 회원을 상대로 보전처분,\n                            본안소송제기, 강제집행절차의 착수 등 채무 변제를 위한 법적 조치에 들어갈 수 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 9조(계약 등의 취소)</h3>\n                        <h5>1. 회원이 정상적으로 매칭된 병원 동행 서비스 계약을 취소 및 변경하는 경우에는 아래와 같이 수수료가 발생합니다.</h5>\n\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>서비스 예약 날짜 기준 48시간 이내 변경 및 취소</span>수수료 없이 변경 & 취소 가능\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>서비스 예약 전날 18:00 이전 변경 및 취소</span>취소 시 수수료 10,000원 발생. 단, 메이트와 변경 협의 성공\n                                시에는 수수료 부과 X 수수료 부과 X\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>당일 예약 변경 및 취소</span>취소 시 수수료 15,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과\n                                X\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>서비스 시작 2시간 전 이내 변경 및 취소</span>서비스 수수료 20,000원 발생. 단, 메이트와 변경 협의 성공\n                                시에는 수수료 부과 X 수수료 부과 X\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>노쇼(No-Show)의 경우</span>회원 자격 정지 및 민/형사상 책임 소지를 물을 수 있음\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>\n                            2. 회사가 서비스 계약을 취소하는 경우 회원에게 사유를 설명하고 이용요금 전액을 청구하지 아니하며, 회원이 입은 피해에 대한 보상을\n                            협의하고 지급합니다.\n                        </h5>\n\n                        <h5 style={{ marginTop: '48px' }}>\n                            3. 서비스 수혜자의 상태(건강 이상, 인지능력 저하 등)에 따른 현장 판단으로 서비스가 수행되지 못한 경우에도, 이용자는 당일 취소\n                            수수료를 부담할 수 있습니다.\n                        </h5>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 10조(서비스 제공 밎 중단)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 서비스를 주 5일 (월~금), 1일 10시간 (오전 9시~오후 7시) 제공함을 원칙으로 합니다. 특수 예약에 대해서는 검토 후 해당 시간\n                            외에도 서비스를 제공할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 서비스의 제공에 필요한 경우 정기 점검을 실시할 수 있으며, 정기 점검 시간은 플랫폼(웹사이트 포함)의 서비스 제공 화면에 공지한\n                            바에 따릅니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 파산 또는 회생 절차 개시 등 정상적인 영업 활동이 곤란한 경우 또는 회사의 영업상 필요한 경우 서비스 내용을 변경하거나 서비스를\n                            종료할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>회사는 다음 각 호의 경우 당해 서비스의 전부 또는 일부의 제공을 중단하거나 제한할 수 있습니다.</h6>\n\n                        <div className='info'>\n                            <p className='title'>\n                                천재지변, 전쟁, 폭동, 화재, 파업 등 쟁의행위, 정부기관의 통제, 테러, 해킹, DDOS, 기타 회사의 합리적인 노력으로 제어할 수 없는\n                                사유가 발생하거나 발생할 우려가 있는 경우\n                            </p>\n                            <p className='title'>기간통신사업자로부터 전기통신서비스가 제공되지 않은 경우</p>\n                            <p className='title'>서비스용 설비의 장애 및 정기 점검, 보수점검, 교체 또는 고장, 통신의 두절 등의 사유가 발생한 경우</p>\n                            <p className='title'>서비스가 제3자와의 제휴를 통하여 제공되는 경우에 당해 제휴사업자의 사정에 따라 변경되거나 중지되는 경우</p>\n                            <p className='title'>기타 서비스의 원활한 운영을 현저히 저해하는 사유가 발생한 경우</p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            본 조 제3항, 제4항의 사유로 서비스 내용이 변경 또는 중단되는 경우, 회사는 그로 인해 회원이 입은 손해에 대하여 고의 또는 중과실이\n                            없는 한 배상하지 않습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>회사는 본 조 상기된 사유가 발생한 경우 최대한 빠른 시간 내에 서비스를 재개하도록 최선의 노력을 다합니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 11조(서비스의 변경)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 상당한 이유가 있는 경우에 운영상, 기술상의 필요에 따라 제공하고 있는 전부 또는 일부의 서비스를 변경할 수 있습니다. 다만,\n                            변경된 내용이 중대하거나 회원에게 불리한 경우에는 회사가 해당 서비스를 제공받는 회원에게 통지합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 전항에 따른 서비스 변경에 대한 동의를 거절한 회원에 대하여는 해당 서비스의 제공을 중지하거나 회원 이용 계약을 해지할 수\n                            있습니다. 이 때 회원 역시 회원 계약을 종료할 권한을 가집니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 12조(회원에 대한 서비스 이용 제한 등)</h3>\n\n                        <h5>1.</h5>\n                        <h6>회사는 다음 각 호에 해당하는 경우 회원에 대하여 서비스 제공을 제한하거나 중지할 수 있습니다.</h6>\n                        <div className='info'>\n                            <p className='title'>\n                                폭언, 폭행, 그 밖에 적정 범위를 벗어난 신체적ㆍ정신적 고통을 유발하는 행위를 통해, 회원이 서비스의 정상적인 운영을 방해한 경우\n                            </p>\n                            <p className='title'>\n                                법정 감염병 환자, 법정 감염병 의사 환자, 감염병 병원체보유자 등, 환자가 각종 매개체를 통해 메이트에게 질병을 전염 및 유발할\n                                것으로 우려되는 경우\n                            </p>\n                            <p className='title'>회원이 타인의 명의를 도용하여 회원가입을 한 경우</p>\n                            <p className='title'>\n                                이용 요금을 지급하지 아니하거나 이용 요금을 결제함에 있어서 타인 명의 결제 도용, 전화번호 도용 등 불법적인 방법을 사용한 경우\n                            </p>\n                            <p className='title'>\n                                불법프로그램의 제공 및 운영 방해, 정보통신망법을 위반한 불법 통신 및 해킹, 악성프로그램의 배포, 접속 권한 초과 행위 등과 같이\n                                회원이 관련 법령을 위반한 경우\n                            </p>\n                            <p className='title'>회원이 계속해서 1년 이상 로그인하지 않는 경우</p>\n                            <p className='title'>\n                                서비스 수혜자의 상태가 다음에 해당하는 경우:\n                                <br />\n                                <p style={{ paddingLeft: '20px' }}>· 거동이 불가능하거나 현저히 떨어지는 경우</p>\n                                <p style={{ paddingLeft: '20px' }}>· 인지장애가 의심 또는 확인된 경우 (경중 불문, 서비스 제공 불가)</p>\n                                <p style={{ paddingLeft: '20px' }}>\n                                    · 위 사실을 은폐하거나 허위로 신청한 경우: 서비스 즉시 중단 및 법적 조치 대상이 될 수 있음\n                                </p>\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 사안에 따라 사전 또는 사후 통지하며, 보호자의 진술, 병원 소견, 메이트의 현장 판단 등을 토대로 제한 여부를 결정할 수 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 서비스 수혜자 또는 보호자의 사전 고지 의무 위반 여부를 확인하기 위해 필요한 경우 의학적 소견서나 병원 진료 정보를 요청할 수\n                            있으며, 협조하지 않을 경우 서비스 제공이 제한될 수 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 13조(개인정보의 관리 및 변경)</h3>\n\n                        <h6>\n                            이용자는 본 서비스의 이용을 위해 자신의 개인 정보를 성실히 관리해야 하며, 개인정보에 변동사항이 있을 경우 이를 변경해야 합니다. 본\n                            서비스를 이용하면서 이용자의 개인정보 변경이 지연되거나 누락, 이용자에 의해 유출되어 발생하는 손해는 이용자의 책임으로 합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 14조(정보의 제공 및 광고의 게재)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 회원이 서비스 이용 중 필요하다고 인정되는 다양한 정보를 서비스 내 공지사항 또는 서비스 화면, 메시지, 전자우편 등의 방법으로\n                            회원에게 제공할 수 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 서비스의 운영과 관련하여 서비스 화면 등에 광고를 게재할 수 있습니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 15조(회사의 의무)</h3>\n\n                        <h5>1.</h5>\n                        <h6>회사는 관련법과 본 약관의 금지하는 행위를 하지 않으며, 계속적이고 안정적인 서비스를 제공하기 위하여 최선을 다하여 노력합니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 이용자의 개인정보 보호를 위한 보안 의무에 최선을 다합니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 이용자로부터 제기되는 의견이나 불만이 정당하고 객관적으로 인정될 경우에는 적절한 절차를 거쳐 즉시 처리하여야 합니다. 다만,\n                            즉시 처리가 불가한 경우에는 이용자에게 그 사유와 처리 일정을 통보하여야 합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사가 제공하는 서비스로 인하여 회원에게 손해가 발생한 경우 그러한 손해가 회사의 고의나 과실에 기해 발생한 경우에 한하여 회사에서\n                            책임을 부담합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>회사는 정보통신망법, 통신비밀보호법, 전기통신사업법 등 서비스의 운영, 유지와 관련 있는 법령을 준수합니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 16조(회원의 의무)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회원은 최종 요금 등의 서비스 조건을 확인한 후 이용 요청을 하여야 하고, 제 8조 2항에 따라 서비스 종료 이후 추가 요금이 발생할 수\n                            있다는 사실을 인지해야 합니다. 서비스 조건을 확인하지 않고 이용 요청을 하여 발생한 손실, 손해에 대한 책임은 회원 본인이 부담하여야\n                            합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원은 본 약관 및 회사가 서비스와 관련하여 고지하는 내용을 준수하여야 하며, 약관 및 고지 내용을 위반하거나 이행하지 아니하여\n                            발생하는 모든 손실, 손해에 대하여 책임을 부담합니다. 이용 요청과 관련하여 회원이 입력한 정보 및 그 정보와 관련하여 발생한 책임과\n                            불이익은 전적으로 회원이 부담하여야 합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회원은 택시 혹은 승합자동차의 대여 및 이동 서비스 이용 시 반드시 본인 명의의 결제수단을 사용하여야 하며, 타인의 결제 수단을 임의로\n                            사용해서는 안 됩니다. 타인의 결제수단을 임의로 사용함으로써 발생하는 회사, 결제 수단의 적법한 소유자, 전자결제대행 또는 이동서비스\n                            제공자 등의 손실과 손해에 대한 모든 책임은 회원에게 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회원은 회사가 서비스를 안전하게 제공할 수 있도록 회사에 협조하여야 하며, 회사가 회원의 본 약관 위반행위를 발견하여 회원에게 해당\n                            위반행위에 대하여 소명을 요청할 경우 회원은 회사의 요청에 적극 응하여야 합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            회원은 분쟁이 발생한 경우 분쟁의 해결을 위하여 성실히 임하여야 하며, 분쟁 해결에 대한 회원의 불성실로 인하여 이동 서비스 제공자 또는\n                            회사에 손해가 발생한 경우 회원은 이에 대한 책임을 부담하여야 합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 17조(회원의 금지 행위)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 서비스의 신뢰성을 제고하고 안전한 거래가 이뤄질 수 있도록 회원에게 특정한 행위를 금지하며 이를 금지 행위로 규정하고 있습니다.\n                            금지 행위의 항목은 수시로 갱신될 수 있으며 항목 추가 및 변경 시 별도로 고지하지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원이 위드메이트 서비스로 중개 받은 메이트 또는 기타 운송 수단 탑승 중 메이트, 차량, 혹은 제 3자에 대하여 손해를 입혔을 경우 회원은\n                            이를 배상하여야 하며 구체적인 금액은 아래와 같습니다. 이에 관하여 제휴사의 기사 알선 포함 승합자동차 대여 서비스 이용약관에서 정한\n                            사항이 있다면 그에 따릅니다.\n                        </h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>메이트를 폭행하거나 정신적인 피해를 끼친 경우 :</span>치료비 전액 배상 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>차량을 오염시킨 경우: </span>30만원 이내에서 세차 실비 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>차량 및 차내 기물 파손 비용:</span> 원상 복구 비용 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>목적지 도착 후 하차 거부:</span>경찰서 등의 인계 시까지의 운임 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>분실물 발견 후 배달 요청 :</span>배차 중지 후 분실물 배달을 위한 영업손실비\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 회원이 본 조의 금지행위를 하는 경우 서비스 이용을 제한할 수 있으며, 이 경우 발생하는 모든 책임은 회원이 부담합니다. 회사는\n                            필요한 경우 회원의 금지 행위 사실을 관련 정부기관 또는 사법기관에 통지할 수 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 18조(책임 제한)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 회원과 메이트 간, 회원과 운송사업자 간 거래를 중개하는 시스템의 운영 관리를 제공하며, 회원, 메이트, 운송사업자를 대리하지\n                            않습니다. 회원과 메이트, 그리고 운송사업자 사이에 성립된 거래에 따라 회원 또는 메이트, 혹은 운송사업자가 제공한 정보에 대한 책임은\n                            회원과 메이트, 그리고 운송사업자가 부담합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원이 자신의 개인 정보 및 계정 등을 타인에게 제공하거나, 회원의 관리 소홀로 유출됨으로써 발생하는 피해에 대해서 책임을 부담하지\n                            않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>회사는 회원의 귀책 사유로 인한 서비스 이용의 장애에 대하여는 책임을 지지 않습니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>회사는 회원이 서비스와 관련하여 게재한 정보, 자료, 사실의 신뢰도, 정확성 등의 내용에 관하여는 책임을 부담하지 않습니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            회사는 서비스간 회원의 귀책 사유로 발생한 메이트와의 갈등(물리적 폭행, 언어 폭력, 부적절한 신체 접촉 등)으로 인해 발생한 피해에\n                            대해서 책임을 부담하지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회사는 관계 법령의 변경, 천재지변, 디도스(DDOS)공격, IDC 장애, 기간통신사업자의 회선 장애 또는 이에 준하는 불가항력으로 인하여\n                            서비스를 제공할 수 없는 경우에는 서비스 제공에 관한 책임이 면제됩니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>7.</h5>\n                        <h6>\n                            회사는 회원의 서비스 이용과 직접적으로 관련이 없는 분쟁에 관여하지 않으며, 회원과 운전용역 제공자 및 운송사업자 또는 회원과 제3자\n                            간의 분쟁을 포함하여 도난, 폭행, 성범죄 등에 대해서는 회사의 과실이 없는 한 책임을 부담하지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>8.</h5>\n                        <h6>\n                            회사는 스마트기기 환경으로 인하여 발생하는 제반 문제 또는 회사의 귀책 사유가 없는 네트워크 환경으로 인하여 발생하는 문제에 대해서\n                            책임을 지지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>9.</h5>\n                        <h6>\n                            회사는 메이트의 현장 상황 판단(서비스 거부 포함)에 따라 불가피하게 서비스가 중단된 경우, 고의 또는 중대한 과실이 없는 한 책임을\n                            부담하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block' style={{ marginBottom: '100px' }}>\n                        <h3>제 19조(분쟁의 해결)</h3>\n\n                        <h5>1.</h5>\n                        <h6>본 약관에 명시되지 않은 사항이 관계 법령에 규정되어 있을 경우에는 해당 규정에 따릅니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>서비스 이용으로 발생한 분쟁에 대해 소송이 제기되는 경우 법령에 정한 절차에 따른 법원을 관할 법원으로 합니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <div className='privacy-justify'>\n                            <p className='version'>개인정보 처리방법 버전 번호 : v.1.2</p>\n                            <p className='date'>제정일자 : 2021년 12월 20일</p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default TermsComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport TermsStyledContainer from './terms.styled';\nimport Terms from './terms';\n\nclass TermsContainer extends React.PureComponent {\n    render() {\n        return (\n            <TermsStyledContainer component={this.props.isComponent || undefined}>\n                <Terms {...this.props} />\n            </TermsStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(TermsContainer);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../theme';\nconst PrivacyStyledContainer = styled.div`\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .medium-bold {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n\n                \n                .in {\n                    font-size: ${sizeHandler(13)};\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                    text-indent: -20px;\n                    padding-left: 40px;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default PrivacyStyledContainer;\n","import React from 'react';\n\nclass PrivacyComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='privacy-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>㈜ 블루카멜 개인정보처리방침</h2>\n                        <p>\n                            병원동행서비스 위드메이트(www.withmate.kr, 이하 “서비스\")를 운영하는 (주)블루카멜(이하 “회사”)은 「개인정보보호법」 제30조에 따라\n                            정보주체의 개인정보를 보호하고 이와 관련한 고충을 신속하고 원활하게 처리할 수 있도록 다음과 같이 개인정보처리방침(이하 \"방침\")을\n                            수립 및 공개합니다. 개인정보처리방침은 관련 법령 또는 지침, 회사의 약관 또는 정책에 따라 변경될 수 있습니다. 회사는 해당 변경 사항을\n                            온라인 게시 등의 방법으로 이용자에게 알립니다.\n                            <br />\n                            <br />이 개인정보처리방침은 2023년 7월 25일부터 적용됩니다.\n                        </p>\n                        <br />\n                        <br />\n                        <br />\n\n                        <p style={{ fontSize: '20px' }}>\n                            <a\n                                href='https://docs.google.com/document/d/e/2PACX-1vTQ3CepPqUO6BqEg8va9_5e0zZg7V1nMuK7xiibF1Nxa2RQAX1C5xv3p4mnIVmkeeh_ClORu1P3Fs0p/pub'\n                                target='_blank'\n                                style={{ color: 'gray' }}\n                            >\n                                ✅ 개인정보처리방침 2차(2023.07.22)\n                            </a>\n                        </p>\n                        <p style={{ fontSize: '20px' }}>\n                            <a\n                                href='https://docs.google.com/document/d/e/2PACX-1vQTjHkJBb2VK4gofoPrHZVYbgCOvOgDDvClVJjwYpx7ikkLFW37GUlFS5Hwa8osGb7a7mNbg55qlEMu/pub'\n                                target='_blank'\n                                style={{ color: 'gray' }}\n                            >\n                                ✅ 개인정보처리방침 1차(2021.12.20)\n                            </a>\n                        </p>\n                    </div>\n                    {/* <div className='context-block'>\n                        <h3>제 1조 (수집하는 개인정보의 항목 및 수집 방법)</h3>\n                        <h5>1. 수집하는 개인정보의 항목</h5>\n                        <p>\n                            회사는 회원가입(또는 서비스 가입), 원활한 고객 상담, 의료 시설 관계자와 메이트 지원자의 신분 확인, 그리고 각종 서비스의 제공을 위해\n                            위드메이트 서비스 최초 이용 시 다음과 같은 개인정보를 수집하고 있습니다.\n                            <br />\n                            <br />\n                            일반개인정보: 회원의 이름, 이메일 주소(아이디) 및 패스워드, 전화번호, 단말기 정보, 프로필 사진(메이트 지원자에 한함), 블랙박스로\n                            인하여 수집되는 영상 (회사는 음성을 수집하지 않으나, 회사가 직접 관리하지 않는 일반 택시와 같은 여객운송 서비스 차량에 설치된\n                            블랙박스 기종에 따라 음성이 녹음될 수 있습니다), 민원/사고 발생 관련 정보, 집이나 회사 등의 주소 정보, 기타 아래 서비스 이용\n                            과정에서 수집되는 정보 및 회원이 서비스 이용을 위해 자발적으로 입력하는 정보 등.\n                        </p>\n                        <div className='info'>\n                            <p className='title'>또한, 서비스 이용과정이나 사업처리 과정에서 아래와 같은 정보들이 자동으로 생성되어 수집될 수 있습니다.</p>\n                            <p className='content'>\n                                - IP Address, 방문 일시, 서비스 이용 기록, 쿠키, 접속 로그, 불량 이용 기록, 앱 설치정보, 네트워크 위치정보 등{' '}\n                            </p>\n                        </div>\n                        <div className='info'>\n                            <p className='title'>나아가 서비스 이용과정에서 다음과 같은 정보들이 수집될 수 있습니다.</p>\n                            <p className='content'>- 계좌 이체 시: 은행명, 계좌번호 등</p>\n                            <p className='content'>- 신용카드 결제 시 : 카드사명, 카드번호 등</p>\n                            <p className='content'>- 휴대전화 결제 시 : 전화 번호, 통신사, 결제 승인 번호 등</p>\n                        </div>\n\n                        <h5 style={{ marginTop: '80px' }}>2. 개인정보 수집방법</h5>\n                        <p>회사는 다음과 같은 방법으로 개인정보를 수집합니다.</p>\n                        <div className='info'>\n                            <p className='content'>- 위드메이트 플랫폼(애플리케이션 & 웹사이트)의 실행 또는 사용 과정에서 수집</p>\n                            <p className='content'>- 협력 회사로부터의 제공</p>\n                            <p className='content'>- 생성 정보 수집 툴(쿠키를 포함)을 통한 수집</p>\n                            <p className='content'>- 사용 중 회원의 자발적 제공을 통한 수집</p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 2조 (개인정보의 수집 및 이용 목적)</h3>\n                        <p>\n                            회사는 회원의 동의가 있거나 법령의 규정에 의한 경우를 제외하고는 본 조에서 고지한 범위를 넘어 회원의 개인정보를 활용하지 않습니다.\n                            회사는 수집한 개인정보를 다음과 같은 목적으로 이용합니다.\n                        </p>\n\n                        <div className='info-block'>\n                            <p className='title'>1. 위드메이트 서비스 제공 및 운영</p>\n                            <p className='content'>\n                                회원이 가입한 위드메이트 서비스 내 상호 식별, 서비스 제공에 관한 계약 이행 및 서비스 제공에 따른 요금정산, 이용 및 경비 결제,\n                                콘텐츠 제공, 물품 배송 또는 청구서 등 발송, 금융거래 본인 인증 및 금융 서비스(추후 기능 추가 예정), 미수금 추심, 서비스 이용 중\n                                사고 발생 시 사고처리, 회사의 약관 또는 이용 정책의 위반 행위 적발을 위한 기록 조회\n                            </p>\n                        </div>\n\n                        <div className='info-block'>\n                            <p className='title'>2. 회원관리</p>\n                            <p className='content'>\n                                서비스 제공, 회원 식별, 본인 확인, 개인 식별, 이용이 제한된 회원 - 위드메이트 이용약관에 따라 이용이 제한된 회원 - 의 부정 이용\n                                방지와 비인가 사용 방지, 가입 의사 확인 및 가입 횟수 제한, 분쟁 조정을 위한 기록 보존, 불만 처리 등 민원 처리, 고지 사항 전달,\n                                추후 법정 대리인 본인 확인, 최신 정보 전달, 서비스의 유효성 확인, 접속 빈도 파악, 회원의 서비스 이용에 대한 통계 확인 및 파악\n                            </p>\n                        </div>\n\n                        <div className='info-block'>\n                            <p className='title'>3. (선택적) 신규 서비스 개발 및 마케팅 · 광고에 활용</p>\n                            <p className='content'>\n                                신규 서비스 개발 및 맞춤 서비스 제공, 통계학적 특성에 따른 서비스 제공 및 광고 게재, 이벤트 참여 기회 제공 또는 광고성 정보 제공\n                            </p>\n                        </div>\n\n                        <div className='info-block'>\n                            <p className='title'>4. 사고 발생시 원인 규명 및 처리를 위한 수집 및 이용</p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 3조 (개인정보의 제한적 공개 및 제 3자 제공)</h3>\n                        <h6>\n                        회사는 회원의 개인정보를 “제2조 (개인정보의 수집 및 이용목적)”에서 고지한 범위 내에서 처리하며, 회원의 사전 동의가 있거나 법령에 규정된 \n                        경우를 제외하고는 회원의 개인정보를 동의 범위를 초과하여 이용하거나 외부에 공개 또는 제3자에게 제공하지 않는 것을 원칙으로 합니다. \n                        다만, 다음의 경우 주의를 기울여 회원의 개인정보를 제한적으로 공개할 수 있습니다.\n                        </h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 제휴관계 :</span>회사는 제 3자와 제휴 관계를 맺을 경우 반드시 사전에 제휴사명, 제휴사의 개인정보 이용목적, \n                                공유하는 개인정보의 항목, 제휴기간에 관하여 알릴 것이며 반드시 이용자의 동의에 의해서만 정보를 제공하거나 공유합니다. 제휴 관계에 있어서 \n                                위 고지할 사항에 변화가 있을 때도 같은 절차에 의하여 이용자에게 알리고 동의를 구합니다.\n                            </p>\n                        </div>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 취급위탁 :</span>원활한 업무 처리를 위해 이용자의 개인정보를 위탁 처리할 경우 반드시 사전에 위탁 처리 업체명과 \n                                개인정보 취급 위탁을 하는 업무의 내용을 이용자에게 알리고 동의를 받아야 합니다.\n                            </p>\n                        </div>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 매각, 인수합병 등 :</span>회사의 영업의 전부 또는 일부의 양도 합병 등으로 이용자의 개인정보를 제3자에게 이전하는 \n                                경우에는 회사는 해당 이용자에게 개인정보를 이전하려는 사실, 개인정보를 이전받는 자의 명칭, 이용자가 개인정보의 이전을 원하지 아니하는 경우 \n                                그 동의를 철회할 수 있는 방법과 절차에 관하여 사전에 전자우편ㆍ서면ㆍ전화 또는 이와 유사한 방법 중 어느 하나의 방법으로(회사가 과실 없이 \n                                이용자의 연락처를 알 수 없어 이러한 방법에 따라 통지할 수 없는 경우에는 회사의 어플리케이션 또는 플랫폼 첫 화면에 30일 이상 게시하는 방법으로\n                                 한다) 알릴 것이며 이용자의 개인정보에 대한 동의 철회의 선택권을 부여합니다.\n                            </p>\n                        </div>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 고지 및 동의 방법 :</span>위 제휴 관계 또는 취급 위탁의 경우 회사가 이용자의 동의를 얻는 방법은 다음 열거된 방법들 중 \n                                어느 하나와 같습니다. 다만, 개인정보 수집 매체의 특성상 동의 내용을 전부 표시하기 어려운 경우에는 이용자에게 동의 내용을 확인할 수 있는 \n                                아래의 방법(인터넷주소ㆍ사업장 전화번호 등)을 안내하고 동의를 얻을 수 있습니다.\n                                <br/><br/>\n                                <span className='in'><b> 가. </b>인터넷 사이트(어플리케이션 또는 플랫폼)에 동의 내용을 게재하고 이용자가 동의 여부를 표시하도록 하는 방법</span><br/>\n                                <span className='in'><b> 나. </b>동의 내용이 기재된 서면을 이용자에게 직접 교부하거나, 우편을 통하여 전달하고 이용자가 동의 내용에 대하여 \n                                                                서명 날인 후 제출하도록 하는 방법</span><br/>\n                                <span className='in'><b> 다. </b>동의 내용이 적힌 전자우편을 발송하여 이용자로부터 동의의 의사표시가 적힌 전자우편을 전송 받는 방법</span><br/>\n                                <span className='in'><b> 라. </b>전화를 통하여 동의 내용을 이용자에게 알리고 동의를 얻거나 인터넷 주소 등 동의 내용을 확인할 수 있는 방법을 \n                                                                 안내하고 <br/>재차 전화 통화를 통하여 동의를 얻는 방법</span>\n                            </p>\n                        </div>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 예외 사항 :</span>다음 예외의 경우에는 회사는 이용자의 동의를 받지 아니하고 또한 이용자에게 고지하지 아니하고도 이용자의 \n                                개인정보를 제공할 수 있습니다.\n                                <br/><br/>\n                                <span className='in'><b> 가. </b>법관이 발부한 영장에 의하여 이용자의 개인정보의 제공 요구가 있을 경우</span><br/>\n                                <span className='in'><b> 나. </b>통계 작성, 학술 연구나 시장 조사를 위하여 특정 개인을 식별할 수 없는 형태로 광고주, 협력사 또는 연구 단체 등에 \n                                                                제공하는 경우</span><br/>\n                                <span className='in'><b> 다. </b>기타 관계 법령에 따라 회사에게 이용자의 개인정보를 제공할 의무가 인정되는 경우</span>\n                                <br/>\n                                그러나 위 예외에 해당하여 이용자의 동의를 받지 아니하고 정보를 제공하는 경우에도 정보를 제공하는 경우에도 본래의 수집 목적 및 이용 목적에 반하여 무분별하게 \n                                정보가 제공되지 않도록 최대한 노력하겠습니다.\n                            </p>\n                        </div>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 병원 동행 서비스 매칭 서비스 및 온라인 플랫폼 특성에 의한 예외 사항 :</span>위드메이트 서비스 이용 도중 매칭된 회원과 메이트 상호간\n                                식별을 위해 이름, 프로필 사진, 전화 번호, 주소, 병명, 나이 등이 위드메이트 서비스 내의 매칭된 회원에게 공개됩니다. 이는 공개 범위 특정이 불가능하여 별도로 고지하여 \n                                동의 받지 못함을 양해바랍니다.\n                            </p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 4조 (개인정보의 취급 위탁)</h3>\n                        <h6>\n                            회사는 원활한 개인정보 업무 처리를 위하여 추후 개인정보 처리 업무를 외부에 위탁할 예정이며, 해당 업체의 명단은 확정 후 공지될\n                            예정입니다.\n                            <br />\n                            <br />\n                            또, 회사는 위탁 계약 체결 시 개인정보보호법 제25조에 따라 위탁 업무 수행 목적 외 개인정보 처리 금지, 재위탁 제한, 수탁자에 대한 관리\n                            및 감독, 책임에 관한 사항을 명시하고, 수탁자가 개인정보를 안전하게 처리하는지 감독할 의무가 있으며, 해당 의무를 책임지고 준수할\n                            것입니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 5조 (동의의 거부권 및 거부 시의 불이익 고지)</h3>\n                        <h6>\n                            회원은 개인정보 수집ㆍ이용에 관한 동의를 거부할 권리가 있습니다. 다만, 계약 체결 및 이행 등을 위해 필요한 최소한의 개인정보\n                            수집ㆍ이용에 관한 동의를 거부하는 경우에는 서비스 이용이 불가능하거나 처리 업무가 지연되는 등의 불이익이 있을 수 있습니다.\n                            <br />\n                            <br />\n                            또한 마케팅 활동 및 홍보를 위한 개인정보 수집ㆍ이용 및/또는 선택적 수집ㆍ이용에 관한 동의를 거부하는 경우에는 이벤트, 혜택에 대한\n                            정보를 제공받지 못하거나 사은품ㆍ판촉물 제공, 제휴서비스 이용, 할인 혜택 적용 및 포인트 적립 불가 등의 불이익이 있을 수 있습니다.\n                        </h6>\n                        <p>\n                            ※ 본 제공 동의 이외에도 회사는 회원이 별도로 동의한 경우, 회원이 동의한 바에 따라 개인정보를 수집ㆍ이용하거나 제3자에게 개인정보를\n                            제공할 수 있습니다.\n                        </p>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 6조 (개인정보의 보유 및 이용 기간)</h3>\n                        <h5>1.</h5>\n                        <h6>회사는 회원이 회원의 자격을 유지하고 있는 동안 수집된 회원의 개인정보를 보유 및 이용할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            하지만 회원이 탈퇴하거나 자격을 상실한 경우, 회사는 회원의 별도 요청이 없더라도 수집된 회원 정보를 삭제 및 파기합니다. 회사는 다음의\n                            방법으로 개인정보를 파기합니다.\n                        </h6>\n                        <div className='info'>\n                            <p className='content'>- 전자적 파일 : 파일 삭제 및 디스크 등의 저장 매체 포맷</p>\n                            <p className='content'>- 수기(手記) 문서 : 분쇄하거나 소각</p>\n                        </div>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>단, 회원의 탈퇴 또는 자격 상실에도 불구하고 다음의 정보는 아래의 이유로 명시 기간 동안 보존 후 삭제 및 파기됩니다.</h6>\n                        <div className='info'>\n                            <p className='title'>3-1) 회사 내부 방침에 의한 정보 보유</p>\n                            <p className='content'>- 회원 간의 분쟁 및 문제해결을 위한 회원정보 기록 : 분쟁의 소멸 시효 등 도과시까지</p>\n                            <p className='content'>- 탈퇴 회원의 재가입 제한을 위한 회원정보 기록: 3개월</p>\n                            <p className='content'>- 이용 제한 회원 및 부정 회원의 재가입 제한을 위한 회원 정보 기록: 제한 기간에 따름(별도저장)</p>\n                        </div>\n                        <div className='info' style={{ marginTop: '32px' }}>\n                            <p className='title'>3-2) 관계 법령에 의한 정보 보유</p>\n                            <p className='content'>- 표시/광고에 관한 기록 : 6개월 (「전자상거래 등에서의 소비자보호에 관한 법률」)</p>\n                            <p className='content'>- 계약 또는 청약철회 등에 관한 기록 : 5년 (「전자상거래 등에서의 소비자보호에 관한 법률」)</p>\n                            <p className='content'>- 대금결제 및 재화 등의 공급에 관한 기록 : 5년 (「전자상거래 등에서의 소비자보호에 관한 법률」)</p>\n                            <p className='content'>- 소비자의 불만 또는 분쟁 처리에 관한 기록 : 3년 (「전자상거래 등에서의 소비자보호에 관한 법률」)</p>\n                            <p className='content'>- 로그인 기록 : 3개월 (「통신비밀보호법」)</p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 7조 (회원 및 법정대리인의 권리, 의무와 그 행사 방법)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            회원은 언제든지 등록되어 있는 자신의 개인 정보를 열람하거나 수정할 수 있으며, 회사의 개인정보 처리에 동의하지 않는 경우 동의를\n                            거부하거나 가입 해지(회원탈퇴)를 요청할 수 있습니다. 단, 개인 정보에서 서비스 운영을 위해 확인이 필요한 정보를 변경할 경우에는\n                            회사의 승인이 이루어질 때까지 서비스 이용이 제한될 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원의 개인정보 조회 및 수정을 위해서는 \"개인정보변경\"(또는 \"회원정보수정\" 등)을, 가입해지(동의철회)를 위해서는 \"회원탈퇴\"를, 각\n                            클릭하여 본인 확인 절차를 거치신 후 직접 열람, 정정 또는 탈퇴가 가능합니다. 혹은 개인정보 관리책임자에게 서면 또는 이메일로\n                            연락하시면 지체 없이 조치하겠습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회원이 개인정보의 오류에 대한 정정을 요청하신 경우에 회사는 당해 정정을 완료하기 전까지 당해 개인정보를 이용하거나 제3자에게\n                            제공하지 않습니다. 또한 잘못된 개인정보를 제3자에게 이미 제공한 경우에는 정정 처리 결과를 제3자에게 지체 없이 통지하여 정정이\n                            이루어지도록 하겠습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사는 회원의 요청에 의해 해지 또는 삭제된 개인정보는 \"제6조 개인정보의 보유 및 이용기간\"에 명시된 바에 따라 처리하고 그 외의 용도로\n                            열람 또는 이용할 수 없도록 처리하고 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            서비스에 가입할 수 있는 자는 만 19세 이상이며, 개인정보의 수집∙이용에 법정 대리인의 동의가 필요한 만 14세 미만 아동의 개인정보는\n                            원칙적으로 수집하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 8조 (개인정보 자동 수집 장치의 설치와 운영 및 거부에 관한 사항)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            회원은 언제든지 등록되어 있는 자신의 개인 정보를 열람하거나 수정할 수 있으며, 회사의 개인정보 처리에 동의하지 않는 경우 동의를\n                            거부하거나 가입 해지(회원탈퇴)를 요청할 수 있습니다. 단, 개인 정보에서 서비스 운영을 위해 확인이 필요한 정보를 변경할 경우에는\n                            회사의 승인이 이루어질 때까지 서비스 이용이 제한될 수 있습니다.\n                        </h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>쿠키의 사용목적 :</span>이용자가 방문한 각 서비스와 웹 사이트들에 대한 방문 및 이용 형태, 인기 검색어,\n                                보안 접속 여부, 등을 파악하여 이용자에게 최적화된 정보 제공을 위해 사용됩니다.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>쿠키의 설치∙운영 및 거부 :</span>웹브라우저 상단의 도구>인터넷 옵션>개인정보 메뉴의 옵션 설정을 통해 쿠키\n                                저장을 거부 할 수 있습니다.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>쿠키 저장을 거부할 경우 맞춤형 서비스 이용에 어려움이 발생할 수 있습니다.</span>\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 이용자에게 개별적인 맞춤 서비스를 제공하기 위해 온라인 맞춤형 광고 서비스를 사용합니다.</h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>행태 정보 수집 방법 :</span>이용자가 당사 애플리케이션을 실행할 때 자동 수집 및 전송합니다.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>모바일 애플리케이션 사용 시 광고 식별자 수집 :</span>회사는 이용자의 ADID/IDFA를 수집할 수 있습니다.\n                                ADID/IDFA란 모바일 앱 이용자의 광고 식별 값으로써, 사용자의 맞춤 서비스 제공이나 더 나은 환경의 광고를 제공하기 위한 측정을 위해\n                                수집할 수 있습니다.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>거부 방법 :</span>- Android: 설정 → 구글(구글설정) → 광고 → 광고 맞춤설정 선택 해제\n                            </p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 9조 (개인정보의 안전성 확보 조치)</h3>\n                        <h6>\n                            회원은 언제든지 등록되어 있는 자신의 개인 정보를 열람하거나 수정할 수 있으며, 회사의 개인정보 처리에 동의하지 않는 경우 동의를\n                            거부하거나 가입 해지(회원탈퇴)를 요청할 수 있습니다. 단, 개인 정보에서 서비스 운영을 위해 확인이 필요한 정보를 변경할 경우에는\n                            회사의 승인이 이루어질 때까지 서비스 이용이 제한될 수 있습니다.\n                        </h6>\n\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>- 관리적 조치 :</span>내부 관리 계획 수립 및 시행, 직원과 종업원 등에 대한 정기적 교육\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>- 기술적 조치 : </span>개인정보 처리시스템(또는 개인정보가 저장된 컴퓨터)의 비밀번호 설정 등 접근권한\n                                관리, 백신소프트웨어 등 보안프로그램 설치, 개인정보가 저장된 파일의 암호화\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>- 물리적 조치 :</span>개인정보가 저장․보관된 장소의 시건, 출입통제 등\n                            </p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 10조 (개인정보 관리책임자 및 담당자의 연락처)</h3>\n                        <h6>\n                            회사는 개인정보 처리에 관한 업무를 총괄해서 책임지고, 개인정보 처리와 관련한 정보 주체의 불만 및 피해 구제를 처리하기 위하여 아래와\n                            같이 개인정보 보호책임자를 지정하고 있습니다.\n                        </h6>\n\n                        <p className='medium-bold'>개인정보 보호 및 관리 책임자 (사업주 또는 대표자)</p>\n                        <div className='info'>\n                            <p className='title' style={{ borderTop: '1px solid #e6e6e6' }}>\n                                <span className='bold'>성명 및 직책 :</span>지승배 / 대표이사\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>연락처 :</span>ceo@withmate.kr\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>고객센터 :</span>070-4300-9075\n                            </p>\n                        </div>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 11조 (고지의 의무)</h3>\n                        <h6>\n                            현 개인정보처리방침 내용 추가, 삭제 및 수정이 있을 시에는 개정 최소 7일전부터 회사 애플리케이션, 서비스 내의 '공지사항' 또는 기타\n                            알기 쉬운 방법을 통해 고지할 것입니다. 다만, 개인정보의 수집 및 활용, 제3자 제공 등과 같이 회원 권리의 중요한 변경이 있을 경우에는\n                            최소 30일 전에 고지합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <div className='privacy-justify'>\n                            <p className='version'>개인정보 처리방법 버전 번호 : v.1.2</p>\n                            <p className='date'>제정일자 : 2021년 12월 20일</p>\n                        </div>\n                    </div> */}\n                </div>\n            </div>\n        );\n    }\n}\nexport default PrivacyComponent;\n","import React from 'react';\n\n// component\nimport PrivacyStyledContainer from './privacy.styled';\nimport Privacy from './privacy';\n\nclass PrivacyContainer extends React.PureComponent {\n    render() {\n        return (\n            <PrivacyStyledContainer component={this.props.isComponent || undefined}>\n                <Privacy {...this.props} />\n            </PrivacyStyledContainer>\n        );\n    }\n}\n\nexport default PrivacyContainer;\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../theme';\nconst MarketingStyledContainer = styled.div`\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > table {\n            border-spacing: 0px;\n            width: 100%;\n            height: 100px;\n            border: 1px solid #e2e2e2;\n\n            > tr, th, td {\n                width: 200px;\n                border: 1px solid #e2e2e2;\n                text-align: left;\n                padding-left: 10px;\n            }\n\n            > td {\n                line-height: 2rem;\n                border: 1px solid #e2e2e2;\n            }\n\n            > thead {\n                height: 35px;    \n            }\n\n            > tbody {\n                background-color: #f9f9f9;\n            }\n\n            @media (max-width: 832px) {\n                width: 100%;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default MarketingStyledContainer;","import React from 'react';\n\nclass MarketingComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='marketing-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>위드메이트 마케팅 정보 활용 동의</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <p>\n                            마케팅 정보 수신 여부 및 마케팅을 위한 개인정보 수집이용을 거부하실 수 있으며, <br />\n                            거부 시에도 위드메이트 서비스를 이용하실 수 있으나, 동의를 거부한 경우 각종 소식 및 이벤트 참여에 제한이 있을 수 있습니다.\n                        </p>\n                        <br/>\n                        <table class=\"table\">\n                            <thead>\n                                <tr>\n                                    <th>개인정보 수집 항목</th>\n                                    <th>개인정보 수집 이용 목적</th>\n                                    <th>보유 및 이용기간</th>\n                                </tr>\n                            </thead>\n                            <tbody>\n                                <tr>\n                                    <td>이름, 연락처, 이메일</td>\n                                    <td>• 이벤트 운영 및 광고성 정보 전송\n                                        <br/>\n                                        • 서비스 관련 정보 전송\n                                    </td>\n                                    <td>이용자가 동의를 철회하거나, 회원 탈퇴시 즉시 삭제</td>\n                                </tr>\n                            </tbody>\n                        </table>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default MarketingComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport MarketingStyledContainer from './marketing.styled';\nimport Marketing from './marketing';\n\nclass MarketingContainer extends React.PureComponent {\n    render() {\n        return (\n            <MarketingStyledContainer component={this.props.isComponent || undefined}>\n                <Marketing {...this.props} />\n            </MarketingStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(MarketingContainer);\n","import styled from 'styled-components';\nimport { sizeHandler } from '../../../../theme';\nconst NromalStyledContainer = styled.div`\n    * {\n        thead {\n            border: 1px solid gray;\n            text-align: center;\n\n            tr {\n                font-weight: bold;\n            }\n        }\n\n        tbody {\n            td:nth-child(2),\n            td:nth-child(3) {\n                text-align: center;\n            }\n        }\n\n        tr {\n            border: 1px solid gray;\n        }\n\n        td {\n            padding: 0.5rem;\n            border: 1px solid gray;\n        }\n    }\n\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default NromalStyledContainer;\n","import React from 'react';\n\nclass EssentialComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>[필수/일반] (주)블루카멜 개인정보 수집 및 이용 동의 확인서</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <table>\n                            <thead>\n                                <tr>\n                                    <td style={{ width: '55%' }}>처리 항목</td>\n                                    <td>처리 목적</td>\n                                    <td>처리 목적</td>\n                                </tr>\n                            </thead>\n                            <tbody style={{ border: '1px solid gray' }}>\n                                <tr>\n                                    <td>\n                                        공통(가입경로, 가입자 생년월일, 가입자 성별, 가입자 이름, 가입자 휴대전화번호, 보호자/환자 여부), 이메일주소 가입\n                                        시(이메일 주소, 비밀번호, 인증번호), 카카오계정 가입 시(카카오계정)\n                                    </td>\n                                    <td>회원 가입 및 관리</td>\n                                </tr>\n                                <tr>\n                                    <td>민원인 이름, 민원인 휴대전화번호</td>\n                                    <td>회원 가입 및 관리</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        거주환경(계단이용여부), 동행인 선택 여부, 동행인 성별 선택, 동행인 이름, 예상 소요시간, 예약자 휴대전화번호, 이동 수단,\n                                        환자 나이, 환자 성별, 환자 이름, 환자 휴대전화번호, 환자와의 관계, 희망 접선 일시\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>온라인 예약하기</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        서비스 종류, 작성 일시, 작성자 이름, 평점, 방문병원 주소, 서비스 진행 현황, 예약 신청 일자, 진료 예약 일시, 환자 이름\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>후기 작성하기</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        동행인 사진, 동행인 서비스 이력, 동행인 이름, 동행인 평점, 동행인 휴대전화번호, 보호자 휴대전화번호, 서비스 종류, 예상\n                                        소요시간, 예약 신청 일시, 이동 수단, 환자 성별, 환자 이름, 환자 휴대전화번호, 환자와의 관계, 희망 접선 시간, 희망 접선\n                                        일자\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(예약내역)</td>\n                                </tr>\n                                <tr>\n                                    <td>가입자 이름, 가입자 휴대전화번호, 비밀번호, 카드 유효기간, 카드번호, 카드사</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(개인정보 관리)</td>\n                                </tr>\n                                <tr>\n                                    <td>쿠폰 번호, 쿠폰 사용 내역, 포인트 적립 내역, 포인트 사용 내역, 현재 잔여 포인트</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(내 포인트)</td>\n                                </tr>\n                                <tr>\n                                    <td>거주환경(계단이용여부), 환자 나이, 환자 성별, 환자 이름, 환자 휴대전화번호, 환자와의 관계</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(환자 프로필 관리)</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        거주환경(계단이용여부), 동행인 성별 선택, 동행인 의료 기관 평가, 동행인 의사 평가, 동행인 이름, 동행인 휴대전화번호,\n                                        보호자 휴대전화번호, 서비스 종류, 예상 소요시간, 예약번호, 예약자 이름, 이동 수단, 환자 나이, 환자 성별, 환자 이름, 환자\n                                        휴대전화번호, 희망 접선 일시\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>관리자페이지(예약/수행이력)</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        가입자 생년월일, 가입자 성별, 거주환경(계단이용여부), 병원동행서비스 개선점, 의료 기관 만족 여부, 동행인 서비스 이력,\n                                        동행인 선택 여부, 동행인 성별 선택, 동행인 의료 기관 평가, 동행인 의사 평가, 동행인 평점, 의료 기관 만족 이유, 의료진\n                                        만족 여부, 의료진 만족 이유, 서비스 종류, 예상 소요시간, 이벤트 참여 여부, 이용 후기, 향후 재신청 의향, 이동 수단,\n                                        포인트 사용 내역, 환불 정보, 결제수단, 이용금액(결산), 이용금액(예상), 쿠폰 사용 내역, 평점, 총 이용시간, 포인트 적립\n                                        내역, 현재 잔여 포인트, 환자 나이, 환자 성별, 환자와의 관계\n                                    </td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                </tr>\n                            </tbody>\n                        </table>\n\n                        <div className='info'>\n                            <p className='title' />\n                            <p className='title'>\n                                <b>[ 개인정보의 수집 및 이용 동의 거부 시 불이익 ]</b> <br />\n                                정보주체는 개인정보 수집 및 이용에 동의를 거부할 권리가 있습니다. 단, 필수항목에 대해 거부할 경우,\n                                ‘(주)블루카멜(개인정보처리자)’이 제공하는 서비스의 일부 또는 전부를 이용할 수 없습니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 개인정보의 보유 및 이용 기간 ]</b> <br />\n                                ① 위에서 제시한 처리 목적과 관련한 개인정보는 수집 및 이용에 대한 동의일부터 회원 탈퇴 후 2년까지\n                                ‘(주)블루카멜(개인정보처리자)’이 보유 및 처리합니다. <br />\n                                ② 다음과 같은 경우에는 ‘(주)블루카멜(개인정보처리자)’이 개인정보를 제1항에서 정한 기간과 달리 보유 및 처리할 수 있습니다. <br />\n                                &ensp; 1. 다음과 같이 관련 법령에 의하여 보존할 필요성이 있는 경우 <br />\n                                &emsp; 1) 신용정보의 수집/처리 및 이용 등에 관한 기록 : 3년 <br />\n                                &emsp; 2) 소비자의 불만 또는 분쟁처리에 관한 기록 : 3년 <br />\n                                &emsp; 3) 대금결제 및 재화 등의 공급에 관한 기록 : 5년 <br />\n                                &emsp; 4) 계약 또는 청약철회 등에 관한 기록 : 5년 <br />\n                                &emsp; 5) 표시/광고에 관한 기록 : 6개월 <br />\n                                &ensp; 2. 정보주체로부터 사전에 동의를 받은 경우 : 정보주체가 사전 동의한 기간\n                            </p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default EssentialComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport NormalStyledContainer from './normal.styled';\nimport Normal from './normal';\n\nclass NormalContainer extends React.PureComponent {\n    render() {\n        return (\n            <NormalStyledContainer component={this.props.isComponent || undefined}>\n                <Normal {...this.props} />\n            </NormalStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(NormalContainer);\n","import styled from 'styled-components';\nimport { sizeHandler } from '../../../../theme';\nconst TermsStyledContainer = styled.div`\n    * {\n        thead {\n            border: 1px solid gray;\n            text-align: center;\n\n            tr {\n                font-weight: bold;\n            }\n        }\n\n        tbody {\n            td:nth-child(2),\n            td:nth-child(3) {\n                text-align: center;\n            }\n        }\n\n        tr {\n            border: 1px solid gray;\n        }\n\n        td {\n            padding: 0.5rem;\n            border: 1px solid gray;\n        }\n    }\n\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default TermsStyledContainer;\n","import React from 'react';\n\nclass SensitiveComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>[필수/민감] (주)블루카멜 개인정보 수집 및 이용 동의 확인서</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <table>\n                            <thead>\n                                <tr>\n                                    <td style={{ width: '55%' }}>수집 및 이용 항목</td>\n                                    <td>수집 및 이용 목적</td>\n                                    <td>수집 및 이용 목적</td>\n                                </tr>\n                            </thead>\n                            <tbody style={{ border: '1px solid gray' }}>\n                                <tr>\n                                    <td>동행 시 주의사항, 진료 예약 시간, 진료 예약 일자, 방문병원 주소, 출발지 주소(자택, 터미널, 입원 병원 등)</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>온라인 예약하기</td>\n                                </tr>\n                                <tr>\n                                    <td>방문병원 주소, 서비스 진행 현황, 예약 신청 일자, 진료 예약 일시</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>후기 작성하기</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        다음 진료 일정 정리, 동행인 전달사항, 방문병원 주소, 복약 지도사항, 서비스 진행 중 특이사항, 진료 및 치료 내용, 진료\n                                        예약 시간, 진료 예약 일자, 출발지 주소(자택, 터미널, 입원 병원 등), 환자 통원 타임라인\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(예약내역)</td>\n                                </tr>\n                                <tr>\n                                    <td>동행 시 주의사항, 출발지 주소(자택, 터미널, 입원 병원 등)</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(환자 프로필 관리)</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        다음 진료 일정 정리, 동행 시 주의사항, 동행인 전달사항, 방문병원 주소, 복약 지도사항, 서비스 진행 중 특이사항, 서비스\n                                        진행 현황, 진료 및 치료 내용, 진료 예약 일시, 출발지 주소(자택, 터미널, 입원 병원 등), 환자 통원 타임라인\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>관리자페이지(예약/수행이력)</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        동행 시 주의사항, 동행인 전달사항, 방문병원 주소, 서비스 진행 중 특이사항, 진료 및 치료 내용, 출발지 주소(자택, 터미널,\n                                        입원 병원 등), 환자 통원 타임라인\n                                    </td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                </tr>\n                            </tbody>\n                        </table>\n\n                        <div className='info'>\n                            <p className='title' />\n                            <p className='title'>\n                                <b>[ 개인정보의 수집 및 이용 동의 거부 시 불이익 ]</b> <br />\n                                정보주체는 개인정보 수집 및 이용에 동의를 거부할 권리가 있습니다. 단, 필수항목에 대해 거부할 경우,\n                                ‘(주)블루카멜(개인정보처리자)’이 제공하는 서비스의 일부 또는 전부를 이용할 수 없습니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 개인정보의 보유 및 이용 기간 ]</b> <br />\n                                ① 위에서 제시한 처리 목적과 관련한 개인정보는 수집 및 이용에 대한 동의일부터 회원 탈퇴 후 2년까지\n                                ‘(주)블루카멜(개인정보처리자)’이 보유 및 처리합니다. <br />\n                                ② 다음과 같은 경우에는 ‘(주)블루카멜(개인정보처리자)’이 개인정보를 제1항에서 정한 기간과 달리 보유 및 처리할 수 있습니다. <br />\n                                &ensp; 1. 다음과 같이 관련 법령에 의하여 보존할 필요성이 있는 경우 <br />\n                                &emsp; 1) 신용정보의 수집/처리 및 이용 등에 관한 기록 : 3년 <br />\n                                &emsp; 2) 소비자의 불만 또는 분쟁처리에 관한 기록 : 3년 <br />\n                                &emsp; 3) 대금결제 및 재화 등의 공급에 관한 기록 : 5년 <br />\n                                &emsp; 4) 계약 또는 청약철회 등에 관한 기록 : 5년 <br />\n                                &emsp; 5) 표시/광고에 관한 기록 : 6개월 <br />\n                                &ensp; 2. 정보주체로부터 사전에 동의를 받은 경우 : 정보주체가 사전 동의한 기간\n                            </p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default SensitiveComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport SensitiveStyledContainer from './sensitive.styled';\nimport Sensitive from './sensitive';\n\nclass SensitiveContainer extends React.PureComponent {\n    render() {\n        return (\n            <SensitiveStyledContainer component={this.props.isComponent || undefined}>\n                <Sensitive {...this.props} />\n            </SensitiveStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(SensitiveContainer);\n","import styled from 'styled-components';\nimport { sizeHandler } from '../../../../theme';\nconst NromalStyledContainer = styled.div`\n    * {\n        thead {\n            border: 1px solid gray;\n            text-align: center;\n\n            tr {\n                font-weight: bold;\n            }\n        }\n\n        tbody {\n            td:nth-child(2),\n            td:nth-child(3) {\n                text-align: center;\n            }\n        }\n\n        tr {\n            border: 1px solid gray;\n        }\n\n        td {\n            padding: 0.5rem;\n            border: 1px solid gray;\n        }\n    }\n\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default NromalStyledContainer;\n","import React from 'react';\n\nclass NormalComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>[선택/일반] (주)블루카멜 개인정보 수집 및 이용 동의 확인서</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <table>\n                            <thead>\n                                <tr>\n                                    <td style={{ width: '55%' }}>수집 및 이용 항목</td>\n                                    <td>수집 및 이용 목적</td>\n                                    <td>수집 및 이용 목적</td>\n                                </tr>\n                            </thead>\n                            <tbody style={{ border: '1px solid gray' }}>\n                                <tr>\n                                    <td>추천인 이름, 추천인 휴대전화번호, 이벤트 참여 정보(이벤트 참여 여부, 받는 사람, 받는 주소)</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>온라인 예약하기</td>\n                                </tr>\n                                <tr>\n                                    <td>\n                                        병원동행서비스 개선점, 의료 기관 만족 여부, 의료 기관 만족 이유, 의료진 만족 여부, 의료진 만족 이유, 이용 후기, 제목,\n                                        향후 재신청 의향\n                                    </td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>후기 작성하기</td>\n                                </tr>\n                                <tr>\n                                    <td>추천인 이름</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>관리자페이지(예약/수행이력)</td>\n                                </tr>\n                                <tr>\n                                    <td>이벤트 참여 여부, 병원동행서비스 개선점, 의료 기관 만족 여부, 의료 기관 만족 이유, 이용 후기, 향후 재신청 의향</td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                </tr>\n                            </tbody>\n                        </table>\n\n                        <div className='info'>\n                            <p className='title' />\n                            <p className='title'>\n                                <b>[ 개인정보의 수집 및 이용 동의 거부 시 불이익 ]</b> <br />\n                                정보주체는 개인정보 수집 및 이용에 동의를 거부할 권리가 있습니다. 단, 필수항목에 대해 거부할 경우,\n                                ‘(주)블루카멜(개인정보처리자)’이 제공하는 서비스의 일부 또는 전부를 이용할 수 없습니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 선택항목 입력 시 처리 동의로 간주 ]</b> <br />\n                                ‘(주)블루카멜(개인정보처리자)’이 정한 선택항목은 정보주체가 서비스 이용 과정에서 해당 항목을 입력하지 않는다면 수집되지\n                                않습니다. 선택항목 처리에 동의를 거부하더라도, 서비스 이용 중 정보주체가 해당 항목을 입력한다면 처리에 대해 동의한 것으로\n                                간주합니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 개인정보의 보유 및 이용 기간 ]</b> <br />\n                                ① 위에서 제시한 처리 목적과 관련한 개인정보는 수집 및 이용에 대한 동의일부터 회원 탈퇴 후 2년까지\n                                ‘(주)블루카멜(개인정보처리자)’이 보유 및 처리합니다. <br />\n                                ② 다음과 같은 경우에는 ‘(주)블루카멜(개인정보처리자)’이 개인정보를 제1항에서 정한 기간과 달리 보유 및 처리할 수 있습니다. <br />\n                                &ensp; 1. 다음과 같이 관련 법령에 의하여 보존할 필요성이 있는 경우 <br />\n                                &emsp; 1) 신용정보의 수집/처리 및 이용 등에 관한 기록 : 3년 <br />\n                                &emsp; 2) 소비자의 불만 또는 분쟁처리에 관한 기록 : 3년 <br />\n                                &emsp; 3) 대금결제 및 재화 등의 공급에 관한 기록 : 5년 <br />\n                                &emsp; 4) 계약 또는 청약철회 등에 관한 기록 : 5년 <br />\n                                &emsp; 5) 표시/광고에 관한 기록 : 6개월 <br />\n                                &ensp; 2. 정보주체로부터 사전에 동의를 받은 경우 : 정보주체가 사전 동의한 기간\n                            </p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default NormalComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport NormalStyledContainer from './normal.styled';\nimport Normal from './normal';\n\nclass NormalContainer extends React.PureComponent {\n    render() {\n        return (\n            <NormalStyledContainer component={this.props.isComponent || undefined}>\n                <Normal {...this.props} />\n            </NormalStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(NormalContainer);\n","import styled from 'styled-components';\nimport { sizeHandler } from '../../../../theme';\nconst SensitiveStyledContainer = styled.div`\n    * {\n        thead {\n            border: 1px solid gray;\n            text-align: center;\n\n            tr {\n                font-weight: bold;\n            }\n        }\n\n        tbody {\n            td:nth-child(2),\n            td:nth-child(3) {\n                text-align: center;\n            }\n        }\n\n        tr {\n            border: 1px solid gray;\n        }\n\n        td {\n            padding: 0.5rem;\n            border: 1px solid gray;\n        }\n    }\n\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default SensitiveStyledContainer;\n","import React from 'react';\n\nclass SensitiveComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>[선택/민감] (주)블루카멜 개인정보 수집 및 이용 동의 확인서</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <table>\n                            <thead>\n                                <tr>\n                                    <td style={{ width: '55%' }}>수집 및 이용 항목</td>\n                                    <td>수집 및 이용 목적</td>\n                                    <td>수집 및 이용 목적</td>\n                                </tr>\n                            </thead>\n                            <tbody style={{ border: '1px solid gray' }}>\n                                <tr>\n                                    <td>기타 요청 및 전달사항</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>온라인 예약하기</td>\n                                </tr>\n                                <tr>\n                                    <td>의료진 이름</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>후기 작성하기</td>\n                                </tr>\n                                <tr>\n                                    <td>기타 요청 및 전달사항</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>마이페이지(예약내역)</td>\n                                </tr>\n                                <tr>\n                                    <td>기타 요청 및 전달사항</td>\n                                    <td>서비스 제공 및 관리</td>\n                                    <td>관리자페이지(예약/수행이력)</td>\n                                </tr>\n                                <tr>\n                                    <td>기타 요청 및 전달사항</td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                    <td>서비스 품질 개선 및 신규 서비스 개발</td>\n                                </tr>\n                            </tbody>\n                        </table>\n\n                        <div className='info'>\n                            <p className='title' />\n                            <p className='title'>\n                                <b>[ 개인정보의 수집 및 이용 동의 거부 시 불이익 ]</b> <br />\n                                정보주체는 개인정보 수집 및 이용에 동의를 거부할 권리가 있습니다. 단, 필수항목에 대해 거부할 경우,\n                                ‘(주)블루카멜(개인정보처리자)’이 제공하는 서비스의 일부 또는 전부를 이용할 수 없습니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 선택항목 입력 시 처리 동의로 간주 ]</b> <br />\n                                ‘(주)블루카멜(개인정보처리자)’이 정한 선택항목은 정보주체가 서비스 이용 과정에서 해당 항목을 입력하지 않는다면 수집되지\n                                않습니다. 선택항목 처리에 동의를 거부하더라도, 서비스 이용 중 정보주체가 해당 항목을 입력한다면 처리에 대해 동의한 것으로\n                                간주합니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 개인정보의 보유 및 이용 기간 ]</b> <br />\n                                ① 위에서 제시한 처리 목적과 관련한 개인정보는 수집 및 이용에 대한 동의일부터 회원 탈퇴 후 2년까지\n                                ‘(주)블루카멜(개인정보처리자)’이 보유 및 처리합니다. <br />\n                                ② 다음과 같은 경우에는 ‘(주)블루카멜(개인정보처리자)’이 개인정보를 제1항에서 정한 기간과 달리 보유 및 처리할 수 있습니다. <br />\n                                &ensp; 1. 다음과 같이 관련 법령에 의하여 보존할 필요성이 있는 경우 <br />\n                                &emsp; 1) 신용정보의 수집/처리 및 이용 등에 관한 기록 : 3년 <br />\n                                &emsp; 2) 소비자의 불만 또는 분쟁처리에 관한 기록 : 3년 <br />\n                                &emsp; 3) 대금결제 및 재화 등의 공급에 관한 기록 : 5년 <br />\n                                &emsp; 4) 계약 또는 청약철회 등에 관한 기록 : 5년 <br />\n                                &emsp; 5) 표시/광고에 관한 기록 : 6개월 <br />\n                                &ensp; 2. 정보주체로부터 사전에 동의를 받은 경우 : 정보주체가 사전 동의한 기간\n                            </p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default SensitiveComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport SensitiveStyledContainer from './sensitive.styled';\nimport Sensitive from './sensitive';\n\nclass SensitiveContainer extends React.PureComponent {\n    render() {\n        return (\n            <SensitiveStyledContainer component={this.props.isComponent || undefined}>\n                <Sensitive {...this.props} />\n            </SensitiveStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(SensitiveContainer);\n","import styled from 'styled-components';\nimport { sizeHandler } from '../../../theme';\nconst AdvertisementStyledContainer = styled.div`\n    * {\n        thead {\n            border: 1px solid gray;\n            text-align: center;\n\n            tr {\n                font-weight: bold;\n            }\n        }\n\n        tbody {\n            td:nth-child(2),\n            td:nth-child(3) {\n                text-align: center;\n            }\n        }\n\n        tr {\n            border: 1px solid gray;\n        }\n\n        td {\n            padding: 0.5rem;\n            border: 1px solid gray;\n        }\n    }\n\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default AdvertisementStyledContainer;\n","import React from 'react';\n\nclass AdvertisementComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>[맞춤 광고] (주)블루카멜 개인정보 수집 및 이용 동의 확인서</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <div className='info'>\n                            <p className='title'>\n                                <b>[ 개인정보 처리 항목 ]</b> <br />\n                                가입경로, 가입자 생년월일, 가입자 성별, 가입자 휴대전화번호, 서비스 종류, 이동 수단, 이메일 주소, 결제 카드사, 카드사, 환자\n                                나이, 환자 성별, 환자 휴대전화번호, <b>다음 진료 일정 정리</b> <br />* ‘<b>다음 진료 일정 정리</b>’는 민감 정보에 해당\n                            </p>\n                            <p className='title'>\n                                <b>[ 개인정보의 수집 및 이용 동의 거부 시 불이익 ]</b> <br />\n                                정보주체는 개인정보 수집 및 이용에 동의를 거부할 권리가 있습니다. 맞춤 광고 목적의 항목에 대해 거부하더라도,\n                                ‘(주)블루카멜(개인정보처리자)’이 제공하는 서비스를 전부 또는 일부를 이용하실 수 있습니다.\n                            </p>\n                            <p className='title'>\n                                <b>[ 개인정보의 보유 및 이용 기간 ]</b> <br />\n                                ① 위에서 제시한 처리 목적과 관련한 개인정보는 수집 및 이용에 대한 동의일부터 회원 탈퇴 후 2년까지\n                                ‘(주)블루카멜(개인정보처리자)’이 보유 및 처리합니다. <br />\n                                ② 다음과 같은 경우에는 ‘(주)블루카멜(개인정보처리자)’이 개인정보를 제1항에서 정한 기간과 달리 보유 및 처리할 수 있습니다. <br />\n                                &ensp; 1. 다음과 같이 관련 법령에 의하여 보존할 필요성이 있는 경우 <br />\n                                &emsp; 1) 신용정보의 수집/처리 및 이용 등에 관한 기록 : 3년 <br />\n                                &emsp; 2) 소비자의 불만 또는 분쟁처리에 관한 기록 : 3년 <br />\n                                &emsp; 3) 대금결제 및 재화 등의 공급에 관한 기록 : 5년 <br />\n                                &emsp; 4) 계약 또는 청약철회 등에 관한 기록 : 5년 <br />\n                                &emsp; 5) 표시/광고에 관한 기록 : 6개월 <br />\n                                &ensp; 2. 정보주체로부터 사전에 동의를 받은 경우 : 정보주체가 사전 동의한 기간\n                            </p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default AdvertisementComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport AdvertisementStyledContainer from './advertisement.styled';\nimport Advertisement from './advertisement';\n\nclass AdvertisementContainer extends React.PureComponent {\n    render() {\n        return (\n            <AdvertisementStyledContainer component={this.props.isComponent || undefined}>\n                <Advertisement {...this.props} />\n            </AdvertisementStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(AdvertisementContainer);\n","import React from 'react';\nimport { notification, message, Button, Checkbox, Select } from 'antd';\nimport validator from 'validator';\nimport styled from 'styled-components';\n\nimport { LOCAL, MATE, USER, KAKAO } from '../../../../Lib/variables';\nimport axios from '../../../../Lib/axios';\nimport { CommonWithmateModal } from '../../../../Components/newModal';\nimport { DivisionLine, WithmateSelect, WithmateInput } from '../../../../Components/Common/input';\n\nimport Terms from '../../../Policy/Terms';\nimport Privacy from '../../../Policy/Privacy';\nimport Marketing from '../../../Policy/Marketing';\nimport EssentialNormal from '../../../Policy/Essential/Normal';\nimport EssentialSensitive from '../../../Policy/Essential/Sensitive';\nimport SelectiveNormal from '../../../Policy/Selective/Normal';\nimport SelectiveSensitive from '../../../Policy/Selective/Sensitive';\nimport Advertisement from '../../../Policy/Advertisement';\n\nclass RegisterComponent extends React.PureComponent {\n    state = {\n        modal: false,\n        modalInfo: '',\n        modalTitle: '',\n        createdAuthCode: '',\n        authCodeCheck: false,\n        vaildated: false,\n    };\n\n    componentWillUnmount = () => {\n        this.onEdit({ type: 'clear', value: '' });\n    };\n\n    onEdit = ({ type, value }) => {\n        this.props.editRegisterForm({ type, value });\n    };\n\n    handleCheckAllChange = () => {\n        const { registerForm } = this.props.auth;\n\n        this.onEdit({ type: 'checkAll', value: !registerForm.checkAll });\n\n        this.onEdit({ type: 'termsOfUse', value: !registerForm.checkAll });\n        this.onEdit({ type: 'privacyPolicy', value: !registerForm.checkAll });\n        this.onEdit({ type: 'essentialGeneral', value: !registerForm.checkAll });\n        this.onEdit({ type: 'essentialSensitive', value: !registerForm.checkAll });\n        this.onEdit({ type: 'selectiveGeneral', value: !registerForm.checkAll });\n        this.onEdit({ type: 'selectiveSensitive', value: !registerForm.checkAll });\n        this.onEdit({ type: 'selectiveAdvertise', value: !registerForm.checkAll });\n    };\n\n    onSendMailHandler = event => {\n        event.preventDefault();\n\n        const { email } = this.props.auth.registerForm;\n\n        if (!email) {\n            this.setState({\n                modal: true,\n                modalTitle: '이메일 미입력',\n                modalInfo: '이메일이 입력되지 않았습니다. 사용하실 이메일을 입력해주세요.',\n            });\n            return;\n        }\n\n        axios.post('/v1/auth/create/code', { email: this.props.auth.registerForm.email }).then(response => {\n            console.log('>> 인증코드가 발송되었습니다.');\n            alert('인증코드가 발송되었습니다.', response);\n        });\n    };\n\n    onCheckHandler = event => {\n        event.preventDefault();\n        const { email, code } = this.props.auth.registerForm;\n        axios.get('/v1/auth/vaildate/code', { params: { email, code } }).then(resolve => {\n            const { data } = resolve;\n            if (data === 'success') {\n                notification.open({\n                    message: '이메일 인증완료',\n                    description: '이메일 인증이 완료되었습니다.',\n                    type: 'success',\n                });\n            } else {\n                notification.open({\n                    message: '이메일 인증실패',\n                    description: '이메일 인증에 실패하였습니다. 다시 입력하세요.',\n                    type: 'warning',\n                });\n            }\n\n            this.setState({ vaildated: true });\n        });\n    };\n\n    pageOneValidator = () => {\n        const { termsOfUse, privacyPolicy, essentialGeneral, essentialSensitive } = this.props.auth.registerForm;\n\n        if (!termsOfUse) {\n            return this.setState({\n                modal: true,\n                modalTitle: '서비스 이용 약관에 동의해주세요.',\n                modalInfo: '원활한 서비스 이용을 위해 위드메이트 서비스 이용약관에 동의해주세요.',\n            });\n        }\n\n        if (!privacyPolicy) {\n            return this.setState({\n                modal: true,\n                modalTitle: '개인 정보 처리 방침에 동의해주세요.',\n                modalInfo: '원활한 서비스 이용을 위해 위드메이트 개인 정보 처리 방침에 동의해주세요.',\n            });\n        }\n\n        if (!essentialGeneral) {\n            return this.setState({\n                modal: true,\n                modalTitle: '[필수/일반] 개인정보 수집 및 이용 동의에 동의해주세요.',\n                modalInfo: '원활한 서비스 이용을 위해 위드메이트 [필수/일반] 개인정보 수집 및 이용 동의에 동의해주세요.',\n            });\n        }\n\n        if (!essentialSensitive) {\n            return this.setState({\n                modal: true,\n                modalTitle: '[필수/민감] 개인정보 수집 및 이용 동의에 동의해주세요.',\n                modalInfo: '원활한 서비스 이용을 위해 위드메이트 [필수/일반] 개인정보 수집 및 이용 동의에 동의해주세요.',\n            });\n        }\n\n        this.onEdit({ type: 'page', value: 2 });\n    };\n\n    pageSndValidator = () => {\n        const { userType, name, photo = '', contact, sex, birth } = this.props.auth.registerForm;\n\n        if (!name)\n            return this.setState({\n                modal: true,\n                modalTitle: '성함을 입력해주세요.',\n                modalInfo: '보다 원활한 서비스 이용을 위해 고객님의 성함을 입력해주세요.',\n            });\n\n        if (!sex) {\n            return this.setState({\n                modal: true,\n                modalTitle: '성별을 선택해주세요.',\n                modalInfo: '보다 원활한 서비스 이용을 위해 고객님의 성별을 선택해주세요.',\n            });\n        }\n\n        if (!birth || birth.length < 8) {\n            return this.setState({\n                modal: true,\n                modalTitle: '생년월일을 입력해주세요.',\n                modalInfo: '보다 원활한 서비스 이용을 위해 고객님의 생년월일을 입력해주세요.',\n            });\n        }\n\n        if (userType === USER) {\n            if (!contact || contact.length < 11) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '연락처를 입력해주세요.',\n                    modalInfo: '원활한 위드메이트 서비스를 이용을 위해 고객님의 연락처를 입력해주세요.',\n                });\n            }\n        }\n\n        if (userType === MATE) {\n            if (!photo) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '메이트님의 프로필 사진을 설정해주세요.',\n                    modalInfo: '실물 사진(ex. 증명사진)으로 프로필 사진을 설정하시면 고객과의 원활한 소통에 도움이 됩니다.',\n                });\n            }\n\n            if (!contact) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '메이트님의 연락처를 입력해주세요.',\n                    modalInfo: '메이트님의 신원 확인을 위해 위드메이트에서 연락이 갈 예정입니다. 올바른 연락처를 입력해주세요.',\n                });\n            }\n        }\n\n        this.onEdit({ type: 'page', value: 3 });\n    };\n\n    onRegister = () => {\n        const {\n            termsOfUse, // 서비스 이용약관\n            privacyPolicy, // 개인정보처리방침 동의\n            essentialGeneral, // 필수_일반\n            essentialSensitive, // 필수_민감\n            selectiveGeneral = false, // 선택_일반\n            selectiveSensitive = false, // 선택_민감\n            selectiveAdvertise = false, // 선택_광고\n            email,\n            password,\n            repassword,\n            connection,\n            recommenderName,\n            longtermCare = false,\n            marketing = false,\n            userType,\n            type = LOCAL,\n            name,\n            photo,\n            contact,\n            birth,\n            code,\n            identify,\n            reason,\n        } = this.props.auth.registerForm;\n\n        const urlSource = window.location.search === '?source=dlive' ? 'dlive' : 'withmate';\n\n        if (type === LOCAL) {\n            if (!email || !validator.isEmail(email)) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '올바른 이메일을 입력해주세요',\n                    modalInfo: '잘못된 이메일을 입력하시면 예약 알림을 받지 못하는 등의 불이익을 받으실 수 있습니다',\n                });\n            }\n\n            if (!password || password.length < 10) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '비밀번호를 확인해주세요.',\n                    modalInfo: '고객님의 개인정보 보호를 위해 비밀번호는 최소 10자리 이상으로 설정해주세요.',\n                });\n            }\n\n            if (!repassword || password !== repassword) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '비밀번호가 일치하지 않습니다.',\n                    modalInfo: '입력하신 비밀번호와 비밀번호 확인란의 정보가 일치하지 않습니다.',\n                });\n            }\n\n            if (!this.state.vaildated || !code) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '이메일 인증을 먼저 진행해주세요.',\n                    modalInfo: '이메일을 입력 후 인증을 먼저 진행해주세요.',\n                });\n            }\n        }\n\n        if (!connection) {\n            return this.setState({\n                modal: true,\n                modalTitle: '유입 경로를 선택해주세요.',\n                modalInfo: '위드메이트를 알게된 경로를 선택해주세요.',\n            });\n        }\n\n        if (!identify) {\n            return this.setState({\n                modal: true,\n                modalTitle: '보호자인지 본인인지 선택해주세요.',\n                modalInfo: '보다 원활한 서비스 이용을 위해 보호자인지 본인인지 선택해주세요.',\n            });\n        }\n\n        if (identify === '보호자') {\n            if (!reason) {\n                return this.setState({\n                    modal: true,\n                    modalTitle: '이용하는 이유를 입력하세요.',\n                    modalInfo: '위드메이트를 이용하는 이유를 입력해주세요.',\n                });\n            }\n        }\n\n        this.props\n            .checkUserId({ id: email, userType, type })\n            .then(resolve => {\n                if (!resolve) {\n                    this.props\n                        .register({\n                            termsOfUse,\n                            privacyPolicy,\n                            essentialGeneral,\n                            essentialSensitive,\n                            selectiveGeneral,\n                            selectiveSensitive,\n                            selectiveAdvertise,\n\n                            id: email,\n                            password,\n                            userType,\n                            name,\n                            code,\n                            identify,\n                            reason,\n                            type,\n                            photo,\n                            contact,\n                            marketing,\n                            connection,\n                            recommenderName,\n                            birth,\n                            longtermCare,\n                            urlSource:\n                                window.location.search === '?source=dlive' ? 'dlive' : window.location.search === '?source=metlife' ? 'metlife' : 'withmate',\n                        })\n                        .then(resolve => {\n                            // 메이트 회원가입 처리\n                            if (userType === MATE && resolve && resolve.message === 'success') {\n                                this.props.editRegisterForm({ type: 'clear', value: '' });\n\n                                notification.open({\n                                    message: '회원가입을 완료하였습니다.',\n                                    description: '관리자의 회원가입 승인 후 활동가능합니다.',\n                                    type: 'success',\n                                });\n                            }\n\n                            if (userType === USER && resolve === 'check parameters') {\n                                notification.open({\n                                    message: '회원가입에 실패하였습니다.',\n                                    description: '누락된 정보가 없는지 확인해주세요.',\n                                    type: 'success',\n                                });\n                            }\n\n                            if (userType === USER && resolve && resolve.message === 'success') {\n                                this.props.history.push(`/success`);\n                            }\n                        })\n                        .catch(error => {\n                            message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n                        });\n                } else {\n                    return this.setState({\n                        modal: true,\n                        modalTitle: '이미 존재하는 사용자의 이메일입니다.',\n                        modalInfo: '아이디를 확인해주세요. 비밀번호를 분실하신 경우 비밀번호 찾기를 이용해주세요.',\n                    });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    setPhoto = ({ file }) => {\n        this.onEdit({ type: 'photo', value: file.originFileObj });\n    };\n\n    formCompleteStatus = () => {\n        let valid = true;\n        if (!this.props.auth || !this.props.auth.registerForm) return false;\n\n        const { page } = this.props.auth.registerForm;\n        if (page === 1) {\n            const { termsOfUse, privacyPolicy, essentialGeneral, essentialSensitive, selectiveGeneral, selectiveSensitive, selectiveAdvertise } =\n                this.props.auth.registerForm;\n            if (!termsOfUse) valid = false;\n            if (!privacyPolicy) valid = false;\n            if (!essentialGeneral) valid = false;\n            if (!essentialSensitive) valid = false;\n        }\n\n        if (page === 2) {\n            const { name, contact, sex, birth } = this.props.auth.registerForm;\n            if (!name) valid = false;\n            if (!contact || contact.length < 11) valid = false;\n            if (!sex) valid = false;\n            if (!birth || birth.length < 8) valid = false;\n        }\n\n        if (page === 3) {\n            const { email, password, repassword, connection, recommenderName, code, type, identify, reason, longtermCare } = this.props.auth.registerForm;\n            if (type === LOCAL) {\n                if (!email) valid = false;\n                if (!password) valid = false;\n                if (!repassword) valid = false;\n                if (!code) valid = false;\n                if (!this.state.vaildated) valid = false;\n            }\n            if (!connection) valid = false;\n            if (!identify) valid = false;\n\n            if (identify === '보호자') {\n                if (!reason) valid = false;\n            }\n        }\n\n        return valid;\n    };\n\n    render() {\n        const { registerForm } = this.props.auth;\n        // console.log(registerForm)\n        const status = this.formCompleteStatus();\n\n        return (\n            <div className='register-container'>\n                <div className='inner-container'>\n                    <div className='register-form'>\n                        <div className='title-wrapper'>\n                            <p>회원가입</p>\n                            <span>{registerForm.page}/3</span>\n                        </div>\n                        {registerForm.page === 1 ? (\n                            <div className='form snd'>\n                                <Agree>\n                                    <Checkbox onChange={this.handleCheckAllChange} value={registerForm.checkAll || false}>\n                                        전체 동의하기\n                                    </Checkbox>\n                                </Agree>\n                                <p style={{ fontSize: '12px', color: 'gray' }}>\n                                    [선택/일반] 개인정보 수집 및 이용 동의, [선택/민감] 개인정보 수집 및 이용 동의, [맞춤 광고] 개인정보 수집 및 이용 동의를\n                                    포함합니다.\n                                </p>\n                                <br />\n\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'termsOfUse', value: !registerForm.termsOfUse });\n                                        }}\n                                        checked={registerForm.termsOfUse || false}\n                                    >\n                                        [필수] 서비스 이용 약관\n                                    </Checkbox>\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({ modal: true, modalTitle: '이용약관 확인', modalInfo: <Terms isComponent /> });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'privacyPolicy', value: !registerForm.privacyPolicy });\n                                        }}\n                                        checked={registerForm.privacyPolicy || false}\n                                    >\n                                        [필수] 개인 정보 처리 방침 동의\n                                    </Checkbox>\n\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({ modal: true, modalTitle: '개인정보 처리방침 확인', modalInfo: <Privacy isComponent /> });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'essentialGeneral', value: !registerForm.essentialGeneral });\n                                        }}\n                                        checked={registerForm.essentialGeneral || false}\n                                    >\n                                        [필수/<span style={{ color: '#3399ff' }}>일반</span>] 개인정보 수집 및 이용 동의\n                                    </Checkbox>\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({\n                                                modal: true,\n                                                modalTitle: '[필수/일반] 개인정보 수집 및 이용 동의',\n                                                modalInfo: <EssentialNormal isComponent />,\n                                            });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'essentialSensitive', value: !registerForm.essentialSensitive });\n                                        }}\n                                        checked={registerForm.essentialSensitive || false}\n                                    >\n                                        [필수/<span style={{ color: '#ff4040' }}>민감</span>] 개인정보 수집 및 이용 동의\n                                    </Checkbox>\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({\n                                                modal: true,\n                                                modalTitle: '[필수/민감] 개인정보 수집 및 이용 동의',\n                                                modalInfo: <EssentialSensitive isComponent />,\n                                            });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'selectiveGeneral', value: !registerForm.selectiveGeneral });\n                                        }}\n                                        checked={registerForm.selectiveGeneral || false}\n                                    >\n                                        [<span style={{ color: '#03c75a' }}>선택</span>/<span style={{ color: '#3399ff' }}>일반</span>] 개인정보 수집 및 이용\n                                        동의\n                                    </Checkbox>\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({\n                                                modal: true,\n                                                modalTitle: '[선택/일반] 개인정보 수집 및 이용 동의',\n                                                modalInfo: <SelectiveNormal isComponent />,\n                                            });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'selectiveSensitive', value: !registerForm.selectiveSensitive });\n                                        }}\n                                        checked={registerForm.selectiveSensitive || false}\n                                    >\n                                        [<span style={{ color: '#03c75a' }}>선택</span>/<span style={{ color: '#ff4040' }}>민감</span>] 개인정보 수집 및 이용\n                                        동의\n                                    </Checkbox>\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({\n                                                modal: true,\n                                                modalTitle: '[선택/민감] 개인정보 수집 및 이용 동의',\n                                                modalInfo: <SelectiveSensitive isComponent />,\n                                            });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n                                <Agree>\n                                    <Checkbox\n                                        onChange={() => {\n                                            this.onEdit({ type: 'selectiveAdvertise', value: !registerForm.selectiveAdvertise });\n                                        }}\n                                        checked={registerForm.selectiveAdvertise || false}\n                                    >\n                                        [<span style={{ color: '#03c75a' }}>선택</span>/<span style={{ color: '#FF6666' }}>광고</span>] 개인정보 수집 및 이용\n                                        동의\n                                    </Checkbox>\n                                    <AgreeLinkText\n                                        onClick={() => {\n                                            this.setState({\n                                                modal: true,\n                                                modalTitle: '[맞춤 광고] 개인정보 수집 및 이용 동의',\n                                                modalInfo: <Advertisement isComponent />,\n                                            });\n                                        }}\n                                    >\n                                        <p style={{ color: '#A5A5A5' }}>내용보기</p>\n                                    </AgreeLinkText>\n                                </Agree>\n\n                                <DivisionLine />\n\n                                <Button\n                                    onClick={() => {\n                                        if (!status) return null;\n\n                                        this.pageOneValidator();\n                                    }}\n                                    type='primary'\n                                    style={!status ? { backgroundColor: '#E6E6E6', border: 0, cursor: 'not-allowed' } : {}}\n                                >\n                                    계속하기\n                                </Button>\n                            </div>\n                        ) : registerForm.page === 2 ? (\n                            <div className='form snd'>\n                                <label>이름</label>\n                                <WithmateInput\n                                    type='text'\n                                    placeholder='ex. 홍길동'\n                                    value={registerForm.name || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'name', value: ev.target.value });\n                                    }}\n                                />\n\n                                <DivisionLine small />\n\n                                <label>성별</label>\n                                <div className='type-button-wrapper'>\n                                    <div\n                                        className={`type-button ${registerForm.sex && registerForm.sex === '남' ? 'active' : ''}`}\n                                        onClick={() => {\n                                            this.onEdit({ type: 'sex', value: '남' });\n                                        }}\n                                    >\n                                        남자\n                                    </div>\n                                    <div\n                                        className={`type-button ${registerForm.sex && registerForm.sex === '녀' ? 'active' : ''}`}\n                                        onClick={() => {\n                                            this.onEdit({ type: 'sex', value: '녀' });\n                                        }}\n                                    >\n                                        여자\n                                    </div>\n                                </div>\n\n                                <DivisionLine small />\n\n                                <label>생년월일</label>\n                                <WithmateInput\n                                    type='text'\n                                    maxLength={8}\n                                    placeholder='숫자만 입력해주세요 (ex. 19880320)'\n                                    value={registerForm.birth || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'birth', value: ev.target.value });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <label>연락처</label>\n                                <WithmateInput\n                                    type='text'\n                                    maxLength={11}\n                                    placeholder='숫자만 입력해주세요.(ex. 01014231324)'\n                                    value={registerForm.contact || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'contact', value: ev.target.value });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <Button\n                                    onClick={() => {\n                                        if (!status) return null;\n\n                                        this.pageSndValidator();\n                                    }}\n                                    type='primary'\n                                    style={!status ? { backgroundColor: '#E6E6E6', border: 0, cursor: 'not-allowed' } : {}}\n                                >\n                                    계속하기\n                                </Button>\n\n                                <div className='link-wrapper'>\n                                    <span className='text'>메이트 신청을 희망하시나요? </span>\n                                    <span\n                                        onClick={() => {\n                                            this.props.history.push('/mate/apply');\n                                        }}\n                                        className='link'\n                                    >\n                                        메이트 신청하기\n                                    </span>\n                                </div>\n\n                                <div className='link-wrapper'>\n                                    <span className='text'>이미 계정이 있으신가요? </span>\n                                    <span\n                                        onClick={() => {\n                                            this.props.history.push('/user/login');\n                                        }}\n                                        className='link'\n                                    >\n                                        로그인\n                                    </span>\n                                </div>\n                            </div>\n                        ) : (\n                            <>\n                                <div className='form fst'>\n                                    {registerForm.type === KAKAO ? null : (\n                                        <>\n                                            <label>이메일</label>\n                                            <div>\n                                                <WithmateInput\n                                                    type='email'\n                                                    value={registerForm.email || ''}\n                                                    onChange={ev => {\n                                                        this.onEdit({ type: 'email', value: ev.target.value });\n                                                    }}\n                                                    required\n                                                    style={{ width: '180px' }}\n                                                    placeholder='이메일을 입력해주세요.'\n                                                />\n                                                <button\n                                                    onClick={this.onSendMailHandler}\n                                                    style={{\n                                                        width: '90px',\n                                                        height: '44px',\n                                                        marginLeft: '10px',\n                                                        backgroundColor: '#3bc1ff',\n                                                        borderColor: '#3bc1ff',\n                                                        border: '0',\n                                                        outline: '0',\n                                                        borderRadius: '3px',\n                                                    }}\n                                                >\n                                                    인증하기\n                                                </button>\n                                            </div>\n\n                                            <div>\n                                                <WithmateInput\n                                                    type='password'\n                                                    value={registerForm.code || ''}\n                                                    onChange={ev => {\n                                                        this.onEdit({ type: 'code', value: ev.target.value });\n                                                    }}\n                                                    required\n                                                    style={{ width: '180px' }}\n                                                    placeholder='인증번호를 입력해주세요.'\n                                                />\n                                                <button\n                                                    onClick={this.onCheckHandler}\n                                                    style={{\n                                                        width: '90px',\n                                                        height: '44px',\n                                                        marginLeft: '10px',\n                                                        backgroundColor: '#3bc1ff',\n                                                        borderColor: '#3bc1ff',\n                                                        border: '0',\n                                                        outline: '0',\n                                                        borderRadius: '3px',\n                                                    }}\n                                                >\n                                                    확인\n                                                </button>\n                                            </div>\n\n                                            <DivisionLine small />\n\n                                            <label style={{ display: 'block' }}>비밀번호</label>\n                                            <WithmateInput\n                                                password='true'\n                                                type='password'\n                                                onChange={ev => {\n                                                    this.onEdit({ type: 'password', value: ev.target.value });\n                                                }}\n                                                placeholder='10자리 이상 비밀번호를 입력해주세요.'\n                                                value={registerForm.password || ''}\n                                            />\n\n                                            <DivisionLine small />\n\n                                            <label style={{ display: 'block' }}>비밀번호 확인</label>\n                                            <WithmateInput\n                                                type='password'\n                                                password='true'\n                                                onChange={ev => {\n                                                    this.onEdit({ type: 'repassword', value: ev.target.value });\n                                                }}\n                                                placeholder='비밀번호를 확인해주세요.'\n                                                value={registerForm.repassword || ''}\n                                            />\n\n                                            <DivisionLine small />\n                                        </>\n                                    )}\n\n                                    <label style={{ display: 'block' }}>위드메이트를 어떻게 알고 오셨나요?</label>\n                                    <WithmateSelect\n                                        style={{ height: '48px', width: '100%' }}\n                                        placeholder='유입 경로를 선택해주세요.'\n                                        value={registerForm.connection || undefined}\n                                        onChange={value => {\n                                            this.onEdit({ type: 'connection', value });\n                                        }}\n                                    >\n                                        <Select.Option value='메트라이프'>메트라이프(360Future)</Select.Option>\n                                        <Select.Option value='딜라이브'>딜라이브</Select.Option>\n                                        <Select.Option value='검색'>검색</Select.Option>\n                                        <Select.Option value='언론기사'>언론기사</Select.Option>\n                                        <Select.Option value='광고'>광고</Select.Option>\n                                        <Select.Option value='지인 추천'>지인 추천</Select.Option>\n                                    </WithmateSelect>\n\n                                    <DivisionLine small />\n\n                                    {registerForm.connection === '지인 추천' ? (\n                                        <>\n                                            <label style={{ display: 'block' }}>추천인 성함을 입력하세요.</label>\n                                            <WithmateInput\n                                                type='text'\n                                                onChange={ev => {\n                                                    this.onEdit({ type: 'recommenderName', value: ev.target.value });\n                                                }}\n                                                value={registerForm.recommenderName || ''}\n                                            />\n                                        </>\n                                    ) : null}\n\n                                    <DivisionLine small />\n\n                                    <label>본인인가요 ? 보호자인가요 ?</label>\n                                    <div className='type-button-wrapper'>\n                                        <div\n                                            className={`type-button ${registerForm.identify && registerForm.identify === '본인' ? 'active' : ''}`}\n                                            onClick={() => {\n                                                this.onEdit({ type: 'identify', value: '본인' });\n                                            }}\n                                        >\n                                            본인\n                                        </div>\n                                        <div\n                                            className={`type-button ${registerForm.identify && registerForm.identify === '보호자' ? 'active' : ''}`}\n                                            onClick={() => {\n                                                this.onEdit({ type: 'identify', value: '보호자' });\n                                            }}\n                                        >\n                                            보호자\n                                        </div>\n                                    </div>\n\n                                    <DivisionLine small />\n\n                                    {registerForm.identify === '본인' ? null : (\n                                        <>\n                                            <label style={{ display: 'block' }}>이용하는 이유 (보호자 선택시)</label>\n                                            <WithmateInput\n                                                type='text'\n                                                onChange={ev => {\n                                                    this.onEdit({ type: 'reason', value: ev.target.value });\n                                                }}\n                                                placeholder='육아, 직장등'\n                                                value={registerForm.reason || ''}\n                                            />\n\n                                            <DivisionLine small />\n                                        </>\n                                    )}\n\n                                    {/* <Agree>\n                                        <Checkbox\n                                            onChange={() => {\n                                                this.onEdit({ type: 'longtermCare', value: !registerForm.longtermCare });\n                                            }}\n                                            value={registerForm.agree || false}\n                                        >\n                                            장기요양등급 상담 신청하기 (선택)\n                                        </Checkbox>\n                                    </Agree>\n                                    <Alert>*장기요양등급 상담 신청을 원하시면 체크해주세요.</Alert> */}\n\n                                    <DivisionLine small />\n\n                                    <Agree>\n                                        <Checkbox\n                                            onClick={() => {\n                                                this.onEdit({ type: 'marketing', value: !registerForm.marketing });\n                                            }}\n                                        >\n                                            개인정보 마케팅 활용 동의 (선택)\n                                        </Checkbox>\n                                        <a\n                                            className='point'\n                                            onClick={() => {\n                                                this.setState({ modal: true, modalTitle: '개인정보 마케팅 활용 동의', modalInfo: <Marketing isComponent /> });\n                                            }}\n                                        >\n                                            더보기 {'>'}\n                                        </a>\n                                    </Agree>\n\n                                    <Alert>*개인 정보 활용에 동의할 경우, 2000 포인트를 지급합니다.</Alert>\n\n                                    <DivisionLine small />\n\n                                    <Button\n                                        type='primary'\n                                        onClick={() => {\n                                            this.onRegister();\n                                        }}\n                                        style={{ display: 'block' }}\n                                        style={!status ? { backgroundColor: '#E6E6E6', border: 0, cursor: 'not-allowed' } : {}}\n                                    >\n                                        가입하기\n                                    </Button>\n\n                                    <div className='link-wrapper'>\n                                        <span className='text'>이미 계정이 있으신가요? </span>\n                                        <a\n                                            className='link'\n                                            onClick={() => {\n                                                this.props.history.push('/user/login');\n                                            }}\n                                        >\n                                            로그인\n                                        </a>\n                                    </div>\n                                </div>\n                            </>\n                        )}\n                    </div>\n                </div>\n\n                {this.state.modal && (\n                    <CommonWithmateModal\n                        visible={this.state.modal}\n                        config={{\n                            title: this.state.modalTitle,\n                            description: this.state.modalInfo,\n                            confirmText: '확인 및 닫기',\n                            noClose: false,\n                        }}\n                        onOk={() => {\n                            this.setState({ modal: false, modalTitle: '', modalInfo: '' });\n                        }}\n                        onCancel={() => {\n                            this.setState({ modal: false, modalTitle: '', modalInfo: '' });\n                        }}\n                    />\n                )}\n            </div>\n        );\n    }\n}\nexport default RegisterComponent;\n\nconst Agree = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    margin-bottom: 8px;\n\n    span {\n        font-size: 14px;\n        line-height: 21px;\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.7);\n    }\n\n    span.point {\n        color: #3bc1ff;\n    }\n\n    a.point {\n        color: #3bc1ff;\n        cursor: pointer;\n        text-decoration: none;\n    }\n\n    .ant-checkbox-wrapper {\n        margin-bottom: 0px !important;\n    }\n`;\n\nconst Alert = styled.p`\n    margin-bottom: 0px;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 12px;\n    line-height: 20px;\n    letter-spacing: -0.15px;\n    color: #ff5500;\n`;\n\nconst AgreeLinkText = styled.p`\n    margin-bottom: 4px;\n    font-size: 13px;\n    color: rgba(0, 0, 0, 0.7);s\n\n    cursor: pointer;\n    &:hover {\n        color: #3bc1ff;\n        transition: all 0.3s;\n    }\n`;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport RegisterStyledContainer from './register.styled';\nimport Register from './register';\nimport { register, editRegisterForm, checkUserId, confirmEmailAuth } from '../../../../Reducer/Modules/auth';\n\nclass RegisterPage extends React.PureComponent {\n    render() {\n        return (\n            <RegisterStyledContainer>\n                <Register {...this.props} />\n            </RegisterStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ auth }) => ({\n    auth,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    editRegisterForm: ({ type, value }) => dispatch(editRegisterForm({ type, value })),\n    register: info => dispatch(register(info)),\n    checkUserId: ({ id, userType, type }) => dispatch(checkUserId({ id, userType, type })),\n    confirmEmailAuth: verificationCode => dispatch(confirmEmailAuth(verificationCode))\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(RegisterPage);","import React from 'react';\nimport { connect } from 'react-redux';\nimport { KAKAO } from '../../../../Lib/variables';\nimport { logout } from '../../../../Reducer/Modules/auth';\n\nclass LogoutPage extends React.PureComponent {\n    componentDidMount = () => {\n        const { id, userType, type } = this.props.auth;\n        if (!id || !userType) {\n            localStorage.clear();\n            return (window.location.href = '/');\n        }\n        if( type === KAKAO && window.Kakao) {\n            window.Kakao.Auth.logout()\n        }\n        this.props.logout({ id, userType });\n    };\n\n    render() {\n        return <div></div>;\n    }\n}\n\nconst mapStateToProps = ({ auth }) => ({\n    auth,\n});\nconst mapDispatchToProps = dispatch => ({\n    logout: ({ id, userType }) => dispatch(logout({ id, userType })),\n});\nexport default connect(mapStateToProps, mapDispatchToProps)(LogoutPage);\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\n\nconst StyledFindContainer = styled.div`\n    margin-top: 55px;\n    min-height: 100vh;\n    background-image: url('/assets/images/main-background.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    .find-container {\n        .inner-container {\n            padding: 0px;\n            padding-top: 144px;\n            padding-bottom: 100px;\n\n            .login-form {\n                background-color: white;\n                border-radius: 8px;\n                box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n                width: 100%;\n                max-width: 340px;\n                margin: 0 auto;\n                padding: 24px;\n\n                .login-title {\n                    margin-bottom: 24px;\n\n                    p {\n                        font-size: ${sizeHandler(32)};\n                        font-weight: bold;\n                        letter-spacing: -0.7px;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n                }\n\n                .form {\n                    label {\n                        font-size: ${sizeHandler(12)};\n                        letter-spacing: -0.15px;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n\n                    input {\n                        height: 40px;\n                        border: solid 1px #e6e6e6;\n                        margin-bottom: 20px;\n                    }\n\n                    button {\n                        width: 100%;\n                        height: 46px;\n                        margin-top: 4px;\n                        margin-bottom: 16px;\n\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        letter-spacing: -0.2px;\n                        text-align: center;\n                        color: #ffffff;\n                    }\n\n                    .link-wrapper {\n                        display: flex;\n                        justify-content: center;\n\n                        .link {\n                            cursor: pointer;\n                            font-size: ${sizeHandler(12)};\n                            letter-spacing: -0.3px;\n                            text-align: center;\n                            color: rgba(0, 0, 0, 0.5);\n\n                            &:first-child {\n                                border-right: 1px solid #e6e6e6;\n                                padding-right: 16px;\n                            }\n\n                            &:last-child {\n                                margin-left: 16px;\n                            }\n                        }\n                    }\n                }\n\n                .form-user-type {\n                    height: 36px;\n                    margin-bottom: 20px;\n                    border-radius: 4px;\n                    border: 1px solid #e6e6e6;\n                    display: flex;\n                    align-items: center;\n                    overflow: hidden;\n\n                    .type {\n                        flex: 1;\n                        height: 100%;\n                        line-height: 36px;\n                        background-color: #ffffff;\n                        cursor: pointer;\n\n                        &:first-child {\n                            border-right: 1px solid #e6e6e6;\n                        }\n\n                        p {\n                            font-size: ${sizeHandler(12)};\n                            font-weight: bold;\n                            text-align: center;\n                            color: #606060;\n                        }\n\n                        &.active {\n                            background-color: #606060;\n\n                            p {\n                                color: #ffffff;\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\nexport default StyledFindContainer;\n","import React from 'react';\nimport { notification, Input, Button, message } from 'antd';\nimport { USER, MATE } from '../../../../Lib/variables';\n\nclass Find extends React.PureComponent {\n    state = {\n        alert: '',\n    };\n\n    onEdit = ({ type, value }) => {\n        this.props.editFindForm({ type, value });\n    };\n\n    onFind = () => {\n        const { email, userType } = this.props.auth.findForm;\n\n        this.props\n            .findPassword({ id: email, userType })\n            .then(resolve => {\n                if (resolve === 'not exist') {\n                    return message.info('존재하지 않는 사용자 아이디입니다.');\n                }\n\n                if (resolve === 'success') {\n                    message.info('이메일로 임시 비밀번호가 전송되었습니다.');\n                    setTimeout(() => {\n                        this.props.history.push('/user/login');\n                    }, 1200);\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    render() {\n        const { findForm } = this.props.auth;\n        return (\n            <div className='find-container'>\n                <div className='inner-container'>\n                    <div className='login-form'>\n                        <div className='login-title'>\n                            <p>비밀번호 찾기</p>\n                        </div>\n                        <div className='form-user-type'>\n                            <div\n                                onClick={() => {\n                                    this.onEdit({ type: 'userType', value: USER });\n                                }}\n                                className={`type ${findForm && findForm.userType === USER ? 'active' : undefined}`}\n                            >\n                                <p>일반</p>\n                            </div>\n                            <div\n                                onClick={() => {\n                                    this.onEdit({ type: 'userType', value: MATE });\n                                }}\n                                className={`type ${findForm && findForm.userType === MATE ? 'active' : undefined}`}\n                            >\n                                <p>메이트</p>\n                            </div>\n                        </div>\n                        <div className='form'>\n                            <label>이메일</label>\n                            <Input\n                                type='email'\n                                placeholder='ex) korea@mail.com'\n                                value={findForm.email}\n                                onChange={ev => {\n                                    this.onEdit({ type: 'email', value: ev.target.value });\n                                }}\n                            />\n                            <Button type='primary' onClick={this.onFind}>\n                                이메일 전송하기\n                            </Button>\n\n                            <div className='link-wrapper'>\n                                <span\n                                    className='link'\n                                    onClick={() => {\n                                        this.props.history.push('/user/login');\n                                    }}\n                                >\n                                    로그인\n                                </span>\n                                <span\n                                    className='link'\n                                    onClick={() => {\n                                        this.props.history.push('/user/register');\n                                    }}\n                                >\n                                    회원가입\n                                </span>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default Find;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledFindContainer from './find.styled';\nimport Find from './find';\nimport { editFindPasswordForm, findPassword } from './../../../../Reducer/Modules/auth';\n\nclass FindPage extends React.PureComponent {\n    render() {\n        return (\n            <StyledFindContainer>\n                <Find {...this.props} />\n            </StyledFindContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ auth }) => ({\n    auth,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    editFindForm: ({ type, value }) => dispatch(editFindPasswordForm({ type, value })),\n    findPassword: ({ id, userType }) => dispatch(findPassword({ id, userType })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(FindPage);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\n\nconst StyledMateContainer = styled.div`\n    margin-top: 55px;\n\n    .auth-container {\n        // min-height: 100vh;\n        // display: flex;\n        flex-direction: column;\n        background-color: rgba(0, 0, 0, 0.02);\n    }\n\n    .navigation-container {\n        border-bottom: 1px solid #e6e6e6;\n        background-color: white;\n\n        .inner-container {\n            padding: 0px;\n        }\n\n        .user-info-container {\n            display: flex;\n            align-items: center;\n            padding: 82px 30px;\n\n            .default-info {\n                flex: 1;\n                display: flex;\n                align-items: center;\n\n                div {\n                    width: 110px;\n                    height: 110px;\n                    border-radius: 55px;\n                    margin-right: 20px;\n                    background-color: #e6e6e6;\n                    position: relative;\n                    overflow: hidden;\n\n                    img {\n                        width: 100%;\n                        height: 110px;\n                        object-fit: cover;\n                        position: absolute;\n                        margin: auto;\n                        top: 0px;\n                        left: 0px;\n                        right: 0px;\n                        bottom: 0px;\n                    }\n\n                    span {\n                        display: inline-block;\n                        position: absolute;\n                        margin: auto;\n                        top: 0px;\n                        left: 0px;\n                        right: 0px;\n                        bottom: 0px;\n                        line-height: 110px;\n                        text-align: center;\n                        color: #ada5a5;\n                    }\n                }\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(38)};\n                    font-weight: bold;\n                    letter-spacing: -0.6px;\n                    color: rgba(0, 0, 0, 0.8);\n\n                    > span {\n                        font-size: ${sizeHandler(38)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: rgba(0, 0, 0, 0.8);\n                    }\n\n                    br {\n                        display: block;\n                    }\n\n                    @media (max-width: 768px) {\n                        font-size: ${sizeHandler(26)};\n                        \n                        > span {\n                            font-size: ${sizeHandler(26)};\n                        }\n                    }\n                }\n            }\n\n            .reserve-info {\n                flex: 1;\n\n                .title {\n                    margin-bottom: 12px;\n\n                    p {\n                        font-size: ${sizeHandler(12)};\n                        font-weight: bold;\n                        color: rgba(145, 145, 145, 0.8);\n                    }\n                }\n\n                .value-wrapper {\n                    display: flex;\n                    align-items; center;\n\n                    .value-block {\n                        flex: 1;\n\n                        .title {\n                            img {\n                                height: 14px;\n                                margin-right: 4px;\n                            }\n    \n                            span {\n                                font-size: ${sizeHandler(14)};\n                                font-weight: bold;\n                                color: rgba(0, 0, 0, 0.8);\n                            }\n                        }\n    \n                        .value {\n                            font-size: ${sizeHandler(16)};\n                            font-weight: bold;\n                            color: #3bc1ff;\n                            overflow: hidden;\n                            text-overflow: ellipsis;\n                            white-space: nowrap;\n                        }\n                    }\n                }\n            }\n        }\n\n        .navigator {\n            display: flex;\n            align-items: center;\n            padding: 0px 30px;\n\n            @media (max-width: 768px) {\n                padding: 0px 16px;\n            }\n\n            .nav-tab {\n                margin-right: 32px;\n                padding-bottom: 12px;\n                position: relative;\n\n                @media (max-width: 768px) {\n                    margin-right: 16px;\n                }\n\n                .name {\n                    font-size: ${sizeHandler(14)};\n                    text-align: center;\n                    cursor: pointer;\n\n                    &.active { \n                        font-weight: bold;\n                        color: #3bc1ff;\n                    }\n                }\n\n                span.underline {\n                    background-color: #3bc1ff;\n                    position: absolute;\n                    bottom: 0px;\n                    left: 0px;\n\n                    &.active {\n                        width: 100%;\n                        height: 3px;\n                        display: inline-block;\n                    }\n                }\n            }\n        }\n\n        @media (max-width: 768px) {\n            .user-info-container {\n                padding: 42px 16px;\n                flex-direction: column;\n                align-items: flex-start;\n\n                .reserve-info {\n                    margin-top: 40px;\n                }\n\n                .value-wrapper {\n                    flex-direction: column;\n\n                    .value-block:last-child {\n                        margin-top: 20px;\n                    }\n                }\n            }\n        }\n    }\n\n    .usage-info-container {\n        flex: 1;\n        // background-color: rgba(0, 0, 0, 0.02);\n\n        .inner-container {\n            height: 100%;\n            padding: 56px 30px;\n\n            @media (max-width: 768px) {\n                padding: 40px 16px;\n            }\n        }\n\n        .filter-wrapper {\n            margin-bottom: 20px;\n\n            .filter {\n                font-size: 14px;\n                font-weight: bold;\n                text-align: center;\n                color: rgba(0, 0, 0, 0.4);\n                margin-right: 32px;\n                cursor: pointer;\n            }\n\n            .filter.active {\n                color: ${mainColor};\n            }\n        }\n    }\n\n    .user-info-wrapper {\n        .wrapper {\n            padding: 36px;\n            background-color: white;\n            border-radius: 4px;\n            border: solid 1px #e6e6e6;\n            float: left;\n            width: calc(50% - 10px);\n            \n            @media (max-width: 768px) {\n                width: 100%;\n            }\n        }\n        \n        .title-wrapper {\n            font-size: ${sizeHandler(20)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 28px;\n        }\n\n        .service {\n            margin-bottom: 20px;\n\n            p.info {\n                font-size: ${sizeHandler(12)};\n                font-weight: normal;\n                letter-spacing: -0.15px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            input {\n                height: 36px;\n                display: inline-block;\n                width: 100%;\n            }\n\n            button {\n                width: 100%;\n                height: 48px;\n                border-radius: 2px;\n                color: white;\n            }\n\n            .ant-upload-drag-container {\n                .title {\n                    margin-top: 12px;\n                    font-size: ${sizeHandler(14)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: rgba(0, 0, 0, 0.8);\n                }\n        \n                .reco {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: #a7a7a7;\n                }\n            }\n\n            .flex-wrapper {\n                display: flex;\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: #606060;\n                    cursor: pointer;\n                }\n            }\n        }\n\n        .default-info {\n            margin-right: 20px;\n        }\n\n        .privacy-info {\n\n            @media (max-width: 768px) {\n                margin-top: 20px;\n            }\n        }\n\n        .etc-info {\n            margin-top: 20px;\n        }\n    }\n`;\n\nexport const UserPhoto = styled.div`\n    width: 100%;\n    height: 200px;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    border-radius: 4px;\n    border: 2px dotted #e9e9e9;\n    // background-color: #e6e6e6;\n\n    > img {\n        width: 120px;\n        height: 120px;\n        object-fit: cover;\n        border-radius: 50%;\n    }\n`;\n\nexport const GuideRowWrapper = styled.div`\n    width: 100%;\n    height: 293px;\n\n    max-width: 372px;\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: solid 1px #f2f2f2;\n    background-color: #ffffff;\n\n    margin-right: 12px;\n\n    @media (max-width: 768px) {\n        > div:last-child {\n            margin-right: 0px;\n        }\n    }\n`;\n\nexport const GuideRowWrapper2 = styled.div`\n    width: 100%;\n    height: 293px;\n\n    max-width: 750px;\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: solid 1px #f2f2f2;\n    background-color: #ffffff;\n\n    margin-right: 12px;\n\n    @media (max-width: 768px) {\n        > div:last-child {\n            margin-right: 0px;\n        }\n    }\n`;\n\nexport const GuideContainer = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: center;\n\n    margin-bottom: 56px;\n\n    > div:last-child {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n\n        > div:last-child {\n            margin-top: 12px;\n        }\n    }\n`;\n\nexport const GuideDescriptionSectionTitle = styled.div`\n    margin-top: 0px;\n    margin-bottom: 16pxs;\n\n    border-bottom: 1px solid #f2f2f2;\n    padding: 32px;\n    padding-bottom: 24px;\n\n    font-size: 20px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.56;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n    text-decoration: underline;\n    cursor: pointer;\n\n    > img {\n        text-decoration: none;\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n\n        margin-left: 4px;\n    }\n`;\n\nexport const GuideDescriptionSection = styled.div`\n    padding: 32px;\n    padding-top: 24px;\n`;\n\nexport const GuideDescriptionSectionContent = styled.div`\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.86;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    word-break: keep-all;\n`;\n\nexport const StudyButton = styled.div`\n    margin: 32px auto;\n\n    height: 76px;\n    width: fit-content;\n\n    padding: 22px 30px;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: solid 2px #3bc1ff;\n    background-color: #ffffff;\n\n    font-size: 22px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: #3bc1ff;\n\n    cursor: pointer;\n\n    img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n\n        margin-left: 8px;\n    }\n\n    @media (max-width: 768px) {\n        font-size: 18px;\n        height: 52px;\n        padding: 12px 24px;\n    }\n`;\n\nexport const AlertMessage = styled.div`\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.64;\n    letter-spacing: -0.2px;\n    text-align: center;\n    color: #ff5500;\n\n    max-width: 682px;\n    margin: 0 auto;\n\n    word-break: keep-all;\n\n    @media (max-width: 768px) {\n        font-size: 14px;\n    }\n`;\n\nexport default StyledMateContainer;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Input, message } from 'antd';\n\nimport { sizeHandler, mainColor } from '../../../theme';\nimport { colorParserByStatus } from '../../../Lib/utils';\nimport { ASSIST, UNEMER, HAPPYCARE } from '../../../Lib/variables';\n\nimport moment from 'moment';\n\nexport const InputFilter = ({ keyword, keywordHandler }) => (\n    <FilterWrapper>\n        <Input\n            value={keyword}\n            onChange={ev => {\n                keywordHandler(ev.target.value);\n            }}\n            placeholder='예약번호, 이용자 성함 등을 검색해보세요.'\n        />\n    </FilterWrapper>\n);\n\nconst FilterWrapper = styled.div`\n    margin-bottom: 12px;\n`;\n\nexport const CalleList = ({ list, onRow }) => {\n    if (!list || list.length === 0) {\n        return (\n            <FullContainer>\n                <Inner>\n                    <EmptyList>서비스 수행 내역이 없습니다.</EmptyList>\n                </Inner>\n            </FullContainer>\n        );\n    }\n\n    return (\n        <ListConatiner>\n            {list.map((item, index) => {\n                const serviceType =\n                    !item.productInfo || !item.productInfo.usePro || !item.productInfo.useBasic ? '' : item.service === 'unemergency' ? 'Pro' : 'Basic';\n                const serviceName = (item.productInfo && item.productInfo.name && item.service && item.productInfo.name + serviceType) || '-';\n\n                return (\n                    <ReserveItem\n                        key={item._id + index + 'call-list'}\n                        reserveCode={item.reserveCode}\n                        name={item.patient}\n                        serviceType={item.service}\n                        service={serviceName}\n                        reserveDate={moment(item.reserveDate).format('MM월 DD일 HH시mm분')}\n                        starting={item.call && item.call.status === '예약접수' ? item.shortStarting || '' : item.starting || ''}\n                        destination={item.destination}\n                        status={(item.call && item.call.status) || ''}\n                        onRow={() => {\n                            onRow(item);\n                        }}\n                    />\n                );\n            })}\n        </ListConatiner>\n    );\n};\n\nconst ReserveItem = ({ service, name, reserveDate, starting, destination, serviceType, status, onDetail, reserveCode, onRow }) => (\n    <ItemContainer>\n        <TitleSection>\n            <ItemColumn>\n                <ItemTitle>서비스 명</ItemTitle>\n                <ItemContents style={{ color: mainColor }}>{service}</ItemContents>\n            </ItemColumn>\n        </TitleSection>\n\n        <ContentSection>\n            <ItemColumn>\n                <ItemTitle>예약 상태</ItemTitle>\n                <ItemContents>{status}</ItemContents>\n            </ItemColumn>\n            <ItemColumn>\n                <ItemTitle>예약 코드</ItemTitle>\n                <ItemContents>{reserveCode}</ItemContents>\n            </ItemColumn>\n            <ItemColumn>\n                <ItemTitle>이용자 성함</ItemTitle>\n                <ItemContents>{name}</ItemContents>\n            </ItemColumn>\n            <ItemColumn>\n                <ItemTitle>병원 진료 예약 시간</ItemTitle>\n                <ItemContents>{reserveDate}</ItemContents>\n            </ItemColumn>\n            {serviceType === 'unemergency' && (\n                <ItemColumn>\n                    <ItemTitle>자택 주소</ItemTitle>\n                    <ItemContents>{starting}</ItemContents>\n                </ItemColumn>\n            )}\n            <ItemColumn>\n                <ItemTitle>병원 주소</ItemTitle>\n                <ItemContents>{destination}</ItemContents>\n            </ItemColumn>\n        </ContentSection>\n\n        <ItemColumn>\n            <DetailButton onClick={onRow}>\n                <span>상세정보 및 관리</span>\n            </DetailButton>\n        </ItemColumn>\n    </ItemContainer>\n);\n\nconst EmptyList = styled.p`\n    font-size: 20px;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 16px;\n    position: relative;\n`;\n\nconst FullContainer = styled.div`\n    width: 100%;\n    min-height: 300px;\n`;\n\nconst Inner = styled.div`\n    max-width: 1024px;\n    margin: 0 auto;\n    padding-top: 40px;\n\n    @media (max-width: 1080px) {\n        padding-left: 16px;\n        padding-right: 16px;\n    }\n\n    @media (max-width: 768px) {\n        padding-top: 40px;\n    }\n`;\nconst TitleSection = styled.div``;\n\nconst ContentSection = styled.div`\n    flex: 1;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    justify-content: flex-start;\n\n    overflow-y: scroll;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none; /* Chrome, Safari, Opera*/\n    }\n`;\n\nconst ListConatiner = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: flex-start;\n    flex-wrap: wrap;\n\n    > div:nth-child(3n) {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        > div:nth-child(3n) {\n            margin-right: 16px;\n        }\n\n        > div:nth-child(2n) {\n            margin-right: 0px;\n        }\n    }\n\n    @media (max-width: 480px) {\n        > div:nth-child(3n) {\n            margin-right: 0px;\n        }\n\n        flex-direction: column;\n        justify-content: center;\n    }\n`;\n\nconst ItemContainer = styled.div`\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    justify-content: center;\n\n    width: 340px;\n    height: 410px;\n    overflow: scroll;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none; /* Chrome, Safari, Opera*/\n    }\n\n    padding: 20px;\n    margin-bottom: 16px;\n    margin-right: 16px;\n\n    border-radius: 4px;\n    box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n    background-color: #ffffff;\n\n    @media (max-width: 768px) {\n        margin-bottom: 16px;\n    }\n\n    @media (max-width: 480px) {\n        width: 100%;\n        max-width: initial;\n        margin-right: 0px;\n    }\n`;\n\nconst ItemTitle = styled.p`\n    color: #a7a7a7;\n    font-size: ${sizeHandler(12)};\n    font-weight: bold;\n    margin: 0px;\n    padding: 0px;\n\n    @media (max-width: 430px) {\n        font-size: ${sizeHandler(11)};\n    }\n`;\n\nconst ItemContents = styled.p`\n    font-size: ${sizeHandler(14)};\n    font-weight: bold;\n    color: #606060;\n    margin: 0px;\n    padding: 0px;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n\n    @media (max-width: 430px) {\n        font-size: ${sizeHandler(12)};\n        margin-bottom: 4px;\n    }\n`;\n\nconst ItemColumn = styled.div`\n    width: 100%;\n    margin-bottom: 6px;\n\n    @media (max-width: 768px) {\n        display: ${props => (props.hiddenMobile ? 'none' : 'block')};\n        width: 100%;\n    }\n`;\n\nconst DetailButton = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    width: 100%;\n    height: 44px;\n\n    border-radius: 4px;\n    border: 1px solid ${mainColor};\n    cursor: pointer;\n    transition: all 0.3s;\n    text-align: center;\n\n    span {\n        font-size: ${sizeHandler(14)};\n        font-weight: bold;\n        color: ${mainColor};\n        text-align: center;\n\n        @media (max-width: 430px) {\n            font-size: ${sizeHandler(12)};\n        }\n    }\n\n    &:hover {\n        background-color: ${mainColor};\n        span {\n            color: white;\n        }\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n        height: 34px;\n        font-size: ${sizeHandler(12)};\n    }\n`;\n","import React from 'react';\nimport { Table, Input, Button, message, Modal, Select } from 'antd';\nimport axios from '../../../../Lib/axios';\n\n// components\nimport { MateCallStatusModal } from '../../../../Components/modal';\nimport { NewHandleReportModal } from '../../../../Components/newModal';\nimport { InputFilter, CalleList } from '../../../../Components/User/Mate/auth';\n\n// styled\nimport { GuideRowWrapper2, UserPhoto } from './mate.styled';\nimport {\n    GuideRowWrapper,\n    GuideDescriptionSection,\n    StudyButton,\n    GuideDescriptionSectionTitle,\n    GuideDescriptionSectionContent,\n    AlertMessage,\n    GuideContainer,\n} from './mate.styled';\n// utils\nimport moment from 'moment';\nimport { ASSIST, MATE, UNEMER } from '../../../../Lib/variables';\nimport { WithmateLabel, WithmateInput, WithmateSelect, DivisionLine } from '../../../../Components/Common/input';\nimport { NoReportModal } from '../../../../Components/newModal';\n\nclass Mate extends React.PureComponent {\n    state = {\n        active: 'list', // list, info, guide\n        reservedFilter: 'none', // none, reserved, matched, complete\n        modal: false,\n\n        onRowModal: false,\n        rowDetail: null,\n        handleReportModal: false,\n        report: '',\n        keyword: '',\n        callList: [],\n    };\n\n    componentDidMount = () => {\n        this.syncStep();\n        this.fetchList();\n    };\n\n    componentDidUpdate = (prevProps, prevState) => {\n        if (prevState.active !== this.state.active) {\n            this.props.history.push(`/user/mate/mypage/${this.state.active}`);\n        }\n    };\n\n    syncStep = () => {\n        const { params } = this.props.match;\n        const { active } = this.state;\n\n        if (params.tab && active !== params.tab) {\n            this.setState({ active: params.tab });\n        } else if (!params.tab) {\n            this.props.history.push(`/user/mate/mypage/list`);\n        }\n    };\n\n    fetchList = () => {\n        const { userType, id } = this.props.auth;\n        if (id && userType === MATE) {\n            axios.get('/v2/service/mate/call/list', { params: { mateId: id } }).then(resolve => {\n                const { data: callList } = resolve;\n                if (callList && Array.isArray(callList)) {\n                    this.setState({ callList }, () => {\n                        const noReports = callList.filter(d => d.call && !d.call.reportId && d.call.status === '서비스 종료').length;\n                        if (noReports > 0) {\n                            this.setState({\n                                noReportModal: true,\n                            });\n                        }\n                    });\n                }\n            });\n        }\n    };\n\n    updateBasicInfo = () => {\n        const { id, userType } = this.props.auth;\n        const { userInfo } = this.props.app;\n        const { newPhoto, name, contact } = userInfo;\n\n        if (!name || !contact) return message.info('필수정보인 이름과 연락처를 입력해주세요.');\n        if (name.length > 15) return message.info('이름이 너무 깁니다. 이름은 15자 이내로 설정해주세요.');\n\n        const info = { name, contact };\n        if (newPhoto) info.photo = newPhoto;\n\n        this.props.modify({ id, userType, info }).then(resolve => {\n            if (resolve && resolve.name) {\n                message.success('정보를 업데이트 하였습니다.');\n\n                localStorage.setItem('name', resolve.name);\n                localStorage.setItem('photo', resolve.photo);\n\n                this.props.editAuth({ type: 'photo', value: resolve.photo });\n                this.props.editAuth({ type: 'name', value: resolve.name });\n                this.props.editAuth({ type: 'contact', value: resolve.contact });\n                this.props.onEdit({ type: 'photo', value: resolve.photo });\n                this.props.onEdit({ type: 'newPhoto', value: '' });\n            }\n        });\n    };\n\n    modifyPassword = () => {\n        const { passwordForm, id, userType } = this.props.auth;\n        const { password, newPassword, reNewPassword } = passwordForm;\n\n        if (password === newPassword) return message.info('새 비밀번호는 기존 비밀번호와 달라야합니다.');\n        if (reNewPassword !== newPassword) return message.info('새 비밀번호를 확인해주세요.');\n\n        this.props.modifyPassword({ id, userType, password, newPassword }).then(resolve => {\n            if (resolve && resolve === 'wrong password') {\n                return message.error('비밀번호가 일치하지 않습니다.');\n            }\n\n            if (resolve && resolve === 'not exist') {\n                message.error('유효하지 않은 계정입니다. 다시 로그인해주세요.');\n                return this.props.history.push('/user/logout');\n            }\n\n            if (resolve && resolve === 'success') {\n                message.success('비밀번호를 변경하였습니다.');\n                this.props.editPassword({ type: 'clear', value: '' });\n            }\n        });\n    };\n\n    withdrawl = () => {\n        const { id, userType } = this.props.auth;\n        const { password } = this.state.temp;\n\n        if (!password) return message.info('비밀번호를 입력해주세요.');\n\n        this.props.withdrawlUser({ id, userType, password }).then(resolve => {\n            if (resolve && resolve === 'wrong password') {\n                return message.info('잘못된 비밀번호입니다.');\n            }\n\n            if (resolve && resolve === 'success') {\n                message.info('회원탈퇴를 완료하였습니다. 이용해주셔서 감사합니다.');\n                this.setState({ modal: false, temp: null }, () => {\n                    setTimeout(() => {\n                        this.props.history.push('/user/logout');\n                    }, 500);\n                });\n            }\n        });\n    };\n\n    tabHandler = type => {\n        this.setState({ active: type });\n    };\n\n    onNextProcess = async () => {\n        const { rowDetail } = this.state;\n\n        const {\n            _id,\n            callId,\n            service,\n            call: { status, reportId },\n            reserveDate,\n        } = rowDetail;\n\n        if (moment(reserveDate).startOf('day').valueOf() > moment().startOf('day').valueOf()) {\n            message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n            return null;\n        }\n\n        if (!_id || !callId || !service) {\n            return message.error('해당 예약정보는 유효하지 않습니다. 새로고침 후 다시 시도해주세요.');\n        }\n\n        if (status && status === '예약접수') {\n            return message.warning('아직 고객님이 예약을 확정짓지 않아 진행이 불가능합니다.');\n        }\n\n        if (service === UNEMER) {\n            if (status === '예약완료') return this.unemergencyService().doReceipt();\n            else if (status === '접선') return this.unemergencyService().doStart();\n            else if (status === '병원 출발') return this.unemergencyService().doArrive();\n            else if (status === '병원 도착') return this.unemergencyService().doCare();\n            else if (status === '진료 시작') return this.unemergencyService().doCareDone();\n            else if (status === '진료 종료') return this.unemergencyService().doBackStart();\n            else if (status === '자택 출발') return this.unemergencyService().doComplete();\n            else if (status === '서비스 종료') {\n                if (reportId) return message.warning('이미 종료된 서비스입니다.');\n                else this.openReportForm();\n            }\n        }\n\n        if (service === ASSIST) {\n            if (status === '예약완료') return this.assistService().doReceipt();\n            else if (status === '접선') return this.assistService().doCare();\n            else if (status === '진료 시작') return this.assistService().doCareDone();\n            else if (status === '진료 종료') return this.assistService().doComplete();\n            else if (status === '서비스 종료') {\n                if (reportId) return message.warning('이미 종료된 서비스입니다.');\n                else this.openReportForm();\n            }\n        }\n    };\n\n    unemergencyService = () => {\n        const { id } = localStorage.getItem('id');\n        const { rowDetail } = this.state;\n        const { _id, callId } = rowDetail;\n\n        const doReceipt = async () => {\n            axios.put('/v2/service/receipt/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"접선\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('접선 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doStart = async () => {\n            axios.put('/v2/service/start/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"병원 출발\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('병원 출발 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doArrive = async () => {\n            axios.put('/v2/service/arrive/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"병원 도착\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('병원 도착 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doCare = async () => {\n            axios.put('/v2/service/care/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"진료 시작\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('진료 시작 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doCareDone = async () => {\n            axios.put('/v2/service/caredone/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"진료 종료\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('진료 종료 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doBackStart = async () => {\n            axios\n                .put('/v2/service/goback/mate/call', { reserveId: _id, callId })\n                .then(resolve => {\n                    const { data } = resolve;\n                    if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                    if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                    if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                    if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                    if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                    if (data === 'already done') return message.warning('이미 \"자택 출발\" 처리 하였습니다.');\n                    if (data === 'success') {\n                        message.success('자택 출발 처리 완료');\n                        this.setState({ onRowModal: false });\n                        this.fetchList();\n                    }\n                })\n                .catch(err => {\n                    console.log(err);\n                });\n        };\n\n        const doComplete = async () => {\n            axios.put('/v2/service/complete/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"서비스 종료\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('서비스 종료 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        return {\n            doReceipt,\n            doStart,\n            doArrive,\n            doCare,\n            doCareDone,\n            doBackStart,\n            doComplete,\n        };\n    };\n\n    assistService = () => {\n        const { id } = localStorage.getItem('id');\n        const { rowDetail } = this.state;\n        const { _id, callId } = rowDetail;\n\n        const doReceipt = async () => {\n            axios.put('/v2/service/receipt/normal/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"접선\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('접선 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doCare = async () => {\n            axios.put('/v2/service/care/normal/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"진료 시작\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('진료 시작 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doCareDone = async () => {\n            axios.put('/v2/service/caredone/normal/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"진료 종료\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('진료 종료 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        const doComplete = async () => {\n            axios.put('/v2/service/complete/normal/mate/call', { reserveId: _id, callId }).then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'check parameters') return message.warning('죄송합니다. 요청에 실패하였습니다.');\n                if (data === 'not yet') return message.warning('진료 예약일 전에는 예약을 진행할 수 없습니다.');\n                if (data === 'invalid call') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                if (data === 'already done') return message.warning('이미 \"서비스 종료\" 처리 하였습니다.');\n                if (data === 'success') {\n                    message.success('서비스 종료 처리 완료');\n                    this.setState({ onRowModal: false });\n                    this.fetchList();\n                }\n            });\n        };\n\n        return { doReceipt, doCare, doCareDone, doComplete };\n    };\n\n    onAddReport = () => {\n        const { report } = this.state;\n        const { description, care, doctorComment } = report;\n\n        if (!description) message.warning('서비스 진행 중 특이사항을 작성해주세요.');\n        if (!care) message.warning('진료 및 치료 내용을 작성해주세요.');\n        if (!doctorComment) message.warning('의료 기관 및 의사 평가을 작성해주세요.');\n\n        axios\n            .post('/v2/review/add/report', { ...report, mateId: localStorage.getItem('id') })\n            .then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n                if (data === 'check parameters') return message.warning('입력하지 않은 내용이 있는지 확인해주세요.');\n                if (data === 'already done') return message.warning('이미 리포트 등록을 완료하였습니다. 새로고침하여 확인해주세요.');\n                if (data === 'invalid call') return message.warning('유효하지 않은 수행이력입니다. 새로고침 후 다시 시도해주세요.');\n                if (data === 'unmatched mate') return message.warning('잘못된 시도입니다. 다른 메이트에게 배정된 예약입니다.');\n\n                message.success('사후리포트 등록 완료');\n                this.setState({ report: null, handleReportModal: false });\n                this.fetchList();\n            })\n            .catch(error => {\n                return message.error('요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n            });\n    };\n\n    inputHandler = ({ type, value }) => {\n        this.setState(prevState => ({\n            report: {\n                ...prevState['report'],\n                [type]: value,\n            },\n        }));\n    };\n\n    openReportForm = () => {\n        const { rowDetail } = this.state;\n\n        this.setState({\n            onRowModal: false,\n            rowDetail: null,\n            handleReportModal: true,\n            report: {\n                description: '',\n                care: '',\n                medicine: '',\n                nextSchedule: '',\n                mateComment: '',\n                doctorComment: '',\n                callId: rowDetail.callId,\n            },\n        });\n    };\n\n    render() {\n        const { auth } = this.props;\n        const { active, reservedFilter, callList, keyword } = this.state;\n\n        const { password, newPassword, reNewPassword } = auth.passwordForm;\n        const { list, userInfo } = this.props.app;\n\n        const filteredList = keyword\n            ? callList.filter(reserve => {\n                  return (\n                      (reserve && reserve.reserveCode && reserve.reserveCode.toLowerCase().includes(keyword.toLowerCase())) ||\n                      (reserve && reserve.patient && reserve.patient.toLowerCase().includes(keyword.toLowerCase()))\n                  );\n              })\n            : callList;\n\n        return (\n            <div className='auth-container'>\n                <div className='navigation-container'>\n                    <div className='inner-container'>\n                        <div className='user-info-container'>\n                            <div className='default-info'>\n                                <div>{auth.photo ? <img src={auth.photo} alt='user-profile' /> : <span>no image</span>}</div>\n                                <p>\n                                    <span>{auth.name}님,</span>\n                                    <br />\n                                    <span>안녕하세요</span>\n                                </p>\n                            </div>\n                            <div className='reserve-info'>\n                                <div className='title'>\n                                    <p>\n                                        수행 통계{' '}\n                                        {/* <a href='https://www.notion.so/FAQ-cfe01db37c67472086b414a044ed6370' target='_blank' style={{ fontSize: '12px' }}>\n                                            (메이트 교육 자료 바로가기)\n                                        </a> */}\n                                    </p>\n                                </div>\n                                <div className='value-wrapper'>\n                                    <div className='value-block'>\n                                        <div className='title'>\n                                            <img src='/assets/images/unemergency-small.png' alt='small-icon' />\n                                            <span>병원 동행 Pro</span>\n                                        </div>\n                                        <div className='value'>\n                                            <p>\n                                                {callList && callList.length > 0\n                                                    ? callList.filter(m => m.service === UNEMER && m.call.status === '서비스 종료').length\n                                                    : '0'}\n                                                회 수행\n                                            </p>\n                                        </div>\n                                    </div>\n\n                                    <div className='value-block'>\n                                        <div className='title'>\n                                            <img src='/assets/images/withassist-small.png' alt='small-icon' />\n                                            <span>병원 동행 Basic</span>\n                                        </div>\n                                        <div className='value'>\n                                            <p>\n                                                {callList && callList.length > 0\n                                                    ? callList.filter(m => m.service !== UNEMER && m.call.status === '서비스 종료').length\n                                                    : '0'}\n                                                회 수행\n                                            </p>\n                                        </div>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n\n                        <div className='navigator'>\n                            <div className='nav-tab'>\n                                <span\n                                    onClick={() => {\n                                        this.tabHandler('list');\n                                    }}\n                                    className={`name ${active === 'list' ? 'active' : ''}`}\n                                >\n                                    예약 및 접수내역\n                                </span>\n                                <span className={`underline ${active === 'list' ? 'active' : ''}`}></span>\n                            </div>\n\n                            <div className='nav-tab'>\n                                <span\n                                    onClick={() => {\n                                        this.tabHandler('info');\n                                    }}\n                                    className={`name ${active === 'info' ? 'active' : ''}`}\n                                >\n                                    개인정보 관리\n                                </span>\n                                <span className={`underline ${active === 'info' ? 'active' : ''}`}></span>\n                            </div>\n\n                            <div className='nav-tab'>\n                                <span\n                                    onClick={() => {\n                                        this.tabHandler('guide');\n                                    }}\n                                    className={`name ${active === 'guide' ? 'active' : ''}`}\n                                >\n                                    메이트 온라인 학습\n                                </span>\n                                <span className={`underline ${active === 'guide' ? 'active' : ''}`}></span>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n\n                <div className='usage-info-container'>\n                    <div className='inner-container'>\n                        {active === 'list' && (\n                            <>\n                                <div className='filter-wrapper'>\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='none'\n                                        name='전체'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'none' });\n                                        }}\n                                    />\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='reserved'\n                                        name='예약접수'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'reserved' });\n                                        }}\n                                    />\n\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='matched'\n                                        name='예약완료 (진행중)'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'matched' });\n                                        }}\n                                    />\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='complete'\n                                        name='서비스 종료'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'complete' });\n                                        }}\n                                    />\n                                </div>\n\n                                <InputFilter\n                                    keyword={this.state.keyword}\n                                    keywordHandler={value => {\n                                        this.setState({ keyword: value });\n                                    }}\n                                />\n\n                                <CalleList\n                                    list={\n                                        reservedFilter === 'none'\n                                            ? filteredList\n                                            : reservedFilter === 'reserved'\n                                            ? filteredList.filter(p => p.call && p.call.status === '예약접수')\n                                            : reservedFilter === 'matched'\n                                            ? filteredList.filter(\n                                                  p =>\n                                                      p.call &&\n                                                      (p.call.status === '예약완료' ||\n                                                          p.call.status === '접선' ||\n                                                          p.call.status === '병원 출발' ||\n                                                          p.call.status === '병원 도착' ||\n                                                          p.call.status === '진료 시작' ||\n                                                          p.call.status === '진료 종료' ||\n                                                          p.call.status === '자택 출발'),\n                                              )\n                                            : reservedFilter === 'complete'\n                                            ? filteredList.filter(p => p.call && p.call.status === '서비스 종료')\n                                            : []\n                                    }\n                                    onRow={info => {\n                                        this.setState({ rowDetail: info, onRowModal: true });\n                                    }}\n                                />\n                            </>\n                        )}\n\n                        {active === 'info' && (\n                            <>\n                                <div className='user-info-wrapper'>\n                                    <div className='default-info wrapper'>\n                                        <div className='title-wrapper'>\n                                            <p>프로필 수정</p>\n                                        </div>\n                                        <div className='service' style={{ marginBottom: '40px' }}>\n                                            <WithmateLabel>프로필 사진</WithmateLabel>\n                                            <div>\n                                                <input\n                                                    id='mate-profile'\n                                                    hidden\n                                                    type='file'\n                                                    accept='image/x-png,image/gif,image/jpeg'\n                                                    onChange={ev => {\n                                                        this.props.onEdit({ type: 'newPhoto', value: ev.target.files[0] });\n                                                    }}\n                                                />\n                                                <UserPhoto\n                                                    onClick={e => {\n                                                        e.preventDefault();\n                                                        document.getElementById('mate-profile').click();\n                                                    }}\n                                                >\n                                                    <img src={userInfo.newPhoto ? URL.createObjectURL(userInfo.newPhoto) : userInfo.photo} alt='user-profile' />\n                                                </UserPhoto>\n                                            </div>\n                                        </div>\n\n                                        <div className='service'>\n                                            <WithmateLabel>이름</WithmateLabel>\n                                            <WithmateInput\n                                                placeholder='성함을 입력해주세요.'\n                                                value={userInfo.name}\n                                                onChange={ev => {\n                                                    this.props.onEdit({ type: 'name', value: ev.target.value });\n                                                }}\n                                            />\n                                        </div>\n\n                                        <div className='service'>\n                                            <WithmateLabel>연락처</WithmateLabel>\n                                            <WithmateInput\n                                                placeholder='연락처를 입력해주세요.'\n                                                value={userInfo.contact}\n                                                onChange={ev => {\n                                                    this.props.onEdit({ type: 'contact', value: ev.target.value });\n                                                }}\n                                            />\n                                        </div>\n\n                                        <div className='service'>\n                                            <WithmateLabel>\n                                                성별 <span style={{ fontSize: '11px' }}>(변경은 1:1 문의로 인증 후 가능)</span>\n                                            </WithmateLabel>\n                                            <WithmateInput placeholder='성별을 입력해주세요.' value={userInfo.sex} disabled />\n                                        </div>\n\n                                        <div className='service' style={{ marginBottom: '0px' }}>\n                                            <Button onClick={this.updateBasicInfo} style={{ backgroundColor: '#484848' }}>\n                                                수정된 프로필 저장\n                                            </Button>\n                                        </div>\n                                    </div>\n                                    <div className='privacy-info wrapper'>\n                                        <div className='title-wrapper'>\n                                            <p>비밀번호 변경</p>\n                                        </div>\n\n                                        <div className='service'>\n                                            <WithmateLabel>현재 비밀번호</WithmateLabel>\n                                            <div>\n                                                <WithmateInput\n                                                    type='password'\n                                                    placeholder='현재 비밀번호를 입력해주세요.'\n                                                    value={password}\n                                                    onChange={ev => {\n                                                        this.props.editPassword({ type: 'password', value: ev.target.value });\n                                                    }}\n                                                />\n                                            </div>\n                                        </div>\n\n                                        <div className='service'>\n                                            <WithmateLabel>새 비밀번호</WithmateLabel>\n                                            <div>\n                                                <WithmateInput\n                                                    type='password'\n                                                    placeholder='새 비밀번호를 입력해주세요.'\n                                                    value={newPassword}\n                                                    onChange={ev => {\n                                                        this.props.editPassword({ type: 'newPassword', value: ev.target.value });\n                                                    }}\n                                                />\n                                            </div>\n                                        </div>\n\n                                        <div className='service'>\n                                            <WithmateLabel>새 비밀번호 확인</WithmateLabel>\n                                            <div>\n                                                <WithmateInput\n                                                    type='password'\n                                                    placeholder='새 비밀번호를 확인해주세요.'\n                                                    value={reNewPassword}\n                                                    onChange={ev => {\n                                                        this.props.editPassword({ type: 'reNewPassword', value: ev.target.value });\n                                                    }}\n                                                />\n                                            </div>\n                                        </div>\n\n                                        <div className='service'>\n                                            <Button onClick={this.modifyPassword} style={{ backgroundColor: '#ffffff', color: '#606060', marginBottom: '0px' }}>\n                                                비밀번호 변경\n                                            </Button>\n                                        </div>\n                                    </div>\n                                    <div className='etc-info wrapper'>\n                                        <div className='title-wrapper'>\n                                            <p>기타</p>\n                                        </div>\n\n                                        <div className='service'>\n                                            <div className='flex-wrapper'>\n                                                <p\n                                                    onClick={() => {\n                                                        this.props.history.push('/policy/privacy');\n                                                    }}\n                                                >\n                                                    개인정보 처리방침 <b>{'>'}</b>\n                                                </p>\n                                                <p\n                                                    onClick={() => {\n                                                        this.props.history.push('/policy/terms');\n                                                    }}\n                                                >\n                                                    서비스 이용약관 <b>{'>'}</b>\n                                                </p>\n                                            </div>\n                                        </div>\n\n                                        <div className='service'>\n                                            <Button\n                                                style={{ backgroundColor: '#b7b7b7' }}\n                                                onClick={() => {\n                                                    this.props.history.push('/user/logout');\n                                                }}\n                                            >\n                                                로그아웃\n                                            </Button>\n                                        </div>\n\n                                        <div className='service' style={{ marginBottom: '0px' }}>\n                                            <Button\n                                                onClick={() => {\n                                                    this.setState({ modal: true, temp: { password: '' } });\n                                                }}\n                                                style={{ color: '#a7a7a7', height: '30px' }}\n                                            >\n                                                회원탈퇴\n                                            </Button>\n                                        </div>\n                                    </div>\n                                    <div className='clearfix' />\n                                </div>\n                            </>\n                        )}\n\n                        {active === 'guide' && (\n                            <>\n                                {userInfo.doProducts.includes('ITEM_mIagil546753836') ? (\n                                    <GuideContainer>\n                                        <GuideBlock2\n                                            title='메이트 교육영상 시청'\n                                            content='메이트 서비스를 활동하기 위한 온라인 영상 교육입니다. 서비스 수행 시 필요한 지침과 규칙을 준수하고 책임을 질 수 있는 서비스 건수를 매칭하기 위해 병원동행서비스의 개념과 수행 방법을 동영상 교육 자료를 통해 학습할 수 있습니다 '\n                                            link='/mateEducation/manual'\n                                        />\n                                    </GuideContainer>\n                                ) : null}\n                                <GuideContainer>\n                                    <GuideBlock\n                                        title='서비스 매뉴얼 보기'\n                                        content='메이트 서비스를 수행하기 위한 교육 자료입니다. 위드메이트가 제공하는 종류 및 타입별 병원 동행 서비스의 개념과 수행방법, 그리고 주의사항에 대해 학습할 수 있습니다.'\n                                        // link='https://s3.ap-northeast-2.amazonaws.com/withmate.photo/withmate_service_manual.pdf'\n                                        link='/service/manual'\n                                    />\n                                    <GuideBlock\n                                        title='플랫폼 이용 방법 보기'\n                                        content='위드메이트 온라인 플랫폼 이용 방법을 설명하는 교육 자료입니다. 플랫폼의 효율적인 사용 방법과 정상적인 병원 동행 서비스 제공을 위한 필수 기능들에 대해 학습할 수 있습니다.'\n                                        // link='https://s3.ap-northeast-2.amazonaws.com/withmate.photo/withmate_platform_manual.pdf'\n                                        link='/platform/manual'\n                                    />\n                                </GuideContainer>\n                                <StudyButton\n                                    onClick={() => {\n                                        window.open('https://www.notion.so/FAQ-cfe01db37c67472086b414a044ed6370', '_blank');\n                                    }}\n                                >\n                                    메이트 FAQ 바로가기\n                                    <img src='/assets/images/w_copy.png' />\n                                </StudyButton>\n\n                                <AlertMessage>\n                                    *해당 페이지에서 제공되는 모든 교육 자료를 학습하고 숙지한 뒤 서비스 수행이 가능합니다. 서비스 매뉴얼 및 플랫폼 이용 방법\n                                    미숙지로 인해 발생하는 피해에 대한\n                                    <br />\n                                    모든 책임은 메이트 본인에게 있습니다*\n                                </AlertMessage>\n                            </>\n                        )}\n                    </div>\n                </div>\n\n                {this.state.modal && (\n                    <Modal\n                        visible={this.state.modal}\n                        title='회원탈퇴'\n                        footer={null}\n                        onCancel={() => {\n                            this.setState({ modal: false, temp: null });\n                        }}\n                    >\n                        <WithmateInput\n                            type='password'\n                            placeholder='회원탈퇴를 위해 비밀번호를 입력해주세요.'\n                            value={this.state.temp.password}\n                            onChange={ev => {\n                                const value = ev.target.value;\n                                this.setState(prevState => ({ temp: { password: value } }));\n                            }}\n                        />\n                        <DivisionLine />\n                        <div style={{ display: 'flex' }}>\n                            <Button\n                                style={{ flex: 1, marginRight: '8px', height: '40px' }}\n                                type='danger'\n                                onClick={() => {\n                                    this.setState({ modal: false, temp: null });\n                                }}\n                            >\n                                취소\n                            </Button>\n                            <Button style={{ flex: 1, height: '40px' }} type='primary' onClick={this.withdrawl}>\n                                확인\n                            </Button>\n                        </div>\n                    </Modal>\n                )}\n\n                {this.state.noReportModal && (\n                    <NoReportModal\n                        visible={this.state.noReportModal}\n                        visibleHandler={() => {\n                            this.setState({ noReportModal: false, reservedFilter: 'complete' });\n                        }}\n                    />\n                )}\n\n                {this.state.onRowModal ? (\n                    <MateCallStatusModal\n                        visibleHandler={() => {\n                            this.setState({ onRowModal: false, rowDetail: null });\n                        }}\n                        info={this.state.rowDetail}\n                        onNext={this.onNextProcess}\n                    />\n                ) : null}\n\n                {this.state.handleReportModal ? (\n                    <NewHandleReportModal\n                        data={this.state.report}\n                        visible={this.state.handleReportModal}\n                        visibleHandler={() => {\n                            this.setState({ handleReportModal: false, report: null });\n                        }}\n                        onSave={this.onAddReport}\n                        inputHandler={this.inputHandler}\n                    />\n                ) : null}\n            </div>\n        );\n    }\n}\nexport default Mate;\n\nconst GuideBlock = ({ title, content, link }) => (\n    <GuideRowWrapper>\n        <GuideDescriptionSectionTitle\n            onClick={() => {\n                window.open(link, '_blank');\n            }}\n        >\n            {title} <img src={'/assets/images/w_right_arrow.png'} alt='링크' />\n        </GuideDescriptionSectionTitle>\n        <GuideDescriptionSection>\n            <GuideDescriptionSectionContent>{content}</GuideDescriptionSectionContent>\n        </GuideDescriptionSection>\n    </GuideRowWrapper>\n);\n\nconst GuideBlock2 = ({ title, content, link, history }) => (\n    <GuideRowWrapper2>\n        <GuideDescriptionSectionTitle\n            onClick={() => {\n                window.open(link, '_blank');\n            }}\n        >\n            {title} <img src={'/assets/images/w_right_arrow.png'} alt='링크' />\n        </GuideDescriptionSectionTitle>\n        <GuideDescriptionSection>\n            <GuideDescriptionSectionContent>{content}</GuideDescriptionSectionContent>\n        </GuideDescriptionSection>\n    </GuideRowWrapper2>\n);\n\nconst Filter = ({ filter, value, onClick, name }) => {\n    return (\n        <span className={`filter ${filter === value ? 'active' : ''}`} onClick={onClick}>\n            {name}\n        </span>\n    );\n};\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\n\nimport StyledMateContainer from './mate.styled';\nimport Mate from './mate';\nimport { MATE } from '../../../../Lib/variables';\n\nimport {\n    acceptCall,\n    cancelCall,\n    getUserInfo,\n    editUserForm,\n    modifyUserInfo,\n    completeCall,\n    // getMateReserveList,\n    // getContractList,\n} from '../../../../Reducer/Modules/app';\nimport { editAuth, editPasswordForm, modifyPassword, withdrawlUser } from '../../../../Reducer/Modules/auth';\n\nclass MatePage extends React.PureComponent {\n    componentDidMount = () => {\n        const mateId = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n\n        if (mateId) {\n            if (userType !== MATE) {\n                window.location.href = '/';\n            } else {\n                this.props.getUserInfo({ id: mateId, userType });\n            }\n        } else {\n            this.props.history.push('/user/login');\n        }\n    };\n\n    render() {\n        if (this.props.auth.userType !== MATE) {\n            return <div></div>;\n        }\n\n        return (\n            <StyledMateContainer>\n                <Mate {...this.props} />\n            </StyledMateContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\nconst mapDispatchToProps = dispatch => ({\n    getUserInfo: ({ id, userType }) => dispatch(getUserInfo({ id, userType })),\n    onEdit: ({ type, value }) => dispatch(editUserForm({ type, value })),\n    modify: ({ id, userType, info }) => dispatch(modifyUserInfo({ id, userType, info })),\n    modifyPassword: ({ id, userType, password, newPassword }) => dispatch(modifyPassword({ id, userType, password, newPassword })),\n    editAuth: ({ type, value }) => dispatch(editAuth({ type, value })),\n    editPassword: ({ type, value }) => dispatch(editPasswordForm({ type, value })),\n\n    withdrawlUser: ({ id, userType, password }) => dispatch(withdrawlUser({ id, userType, password })),\n    cancelCall: ({ callId }) => dispatch(cancelCall({ callId })),\n    completeCall: ({ callId }) => dispatch(completeCall({ callId })),\n    acceptCall: ({ callId, mateId }) => dispatch(acceptCall({ callId, mateId })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(MatePage);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\n\nconst StyledNormalContainer = styled.div`\n    margin-top: 55px;\n\n    .auth-container {\n        // display: flex;\n        // flex-direction: column;\n        min-height: 100vh;\n        background-color: rgba(0, 0, 0, 0.02);\n    }\n\n    .navigation-container {\n        flex-shrink: 0;\n        border-bottom: 1px solid #e6e6e6;\n        background-color: white;\n\n        .inner-container {\n            padding: 0px;\n        }\n\n        .user-info-container {\n            display: flex;\n            align-items: center;\n            padding: 82px 30px;\n\n            .default-info {\n                flex: 1;\n                display: flex;\n                align-items: center;\n\n                div {\n                    width: 110px;\n                    height: 110px;\n                    border-radius: 55px;\n                    margin-right: 20px;\n                    background-color: #e6e6e6;\n                    position: relative;\n                    overflow: hidden;\n\n                    img {\n                        height: 110px;\n                        position: absolute;\n                        margin: auto;\n                        top: 0px;\n                        left: 0px;\n                        right: 0px;\n                        bottom: 0px;\n                    }\n\n                    span {\n                        display: inline-block;\n                        position: absolute;\n                        margin: auto;\n                        top: 0px;\n                        left: 0px;\n                        right: 0px;\n                        bottom: 0px;\n                        line-height: 110px;\n                        text-align: center;\n                        color: #ada5a5;\n                    }\n                }\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(38)};\n                    font-weight: bold;\n                    letter-spacing: -0.6px;\n                    color: rgba(0, 0, 0, 0.8);\n                }\n            }\n\n            .reserve-info {\n                flex: 1;\n\n                .title {\n                    margin-bottom: 12px;\n\n                    p {\n                        font-size: ${sizeHandler(12)};\n                        font-weight: bold;\n                        color: rgba(145, 145, 145, 0.8);\n                    }\n                }\n\n                .value-wrapper {\n                    display: flex;\n                    align-items; center;\n\n                    .value-block {\n                        flex: 1;\n\n                        .title {\n                            img {\n                                height: 14px;\n                                margin-right: 4px;\n                            }\n    \n                            span {\n                                font-size: ${sizeHandler(14)};\n                                font-weight: bold;\n                                color: rgba(0, 0, 0, 0.8);\n                            }\n                        }\n    \n                        .value {\n                            font-size: ${sizeHandler(16)};\n                            font-weight: bold;\n                            color: #3bc1ff;\n                            text-overflow: ellipsis;\n                            overflow: hidden;\n                            white-space: nowrap;\n                        }\n                    }\n                }\n            }\n        }\n\n        .navigator {\n            display: flex;\n            align-items: center;\n            padding: 0px 30px;\n\n            .nav-tab {\n                margin-right: 32px;\n                padding-bottom: 12px;\n                position: relative;\n\n                .name {\n                    font-size: ${sizeHandler(14)};\n                    text-align: center;\n                    cursor: pointer;\n\n                    &.active { \n                        font-weight: bold;\n                        color: #3bc1ff;\n                    }\n                }\n\n                span.underline {\n                    background-color: #3bc1ff;\n                    position: absolute;\n                    bottom: 0px;\n                    left: 0px;\n\n                    &.active {\n                        width: 100%;\n                        height: 3px;\n                        display: inline-block;\n                    }\n                }\n            }\n        }\n\n        @media (max-width: 768px) {\n            .user-info-container {\n                flex-direction: column;\n                align-items: flex-start;\n\n                .reserve-info {\n                    margin-top: 40px;\n                }\n\n                .value-wrapper {\n                    flex-direction: column;\n\n                    .value-block:last-child {\n                        margin-top: 20px;\n                    }\n                }\n            }\n        }\n    }\n\n    .usage-info-container {\n        flex: 1;\n        // background-color: rgba(0, 0, 0, 0.02);\n\n        .inner-container {\n            height: 100%;\n            padding: 56px 30px;\n\n            @media (max-width: 768px) {\n                padding: 40px 16px;\n            }\n        }\n\n        .filter-wrapper {\n            margin-bottom: 20px;\n\n            .filter {\n                font-size: 14px;\n                font-weight: bold;\n                text-align: center;\n                color: rgba(0, 0, 0, 0.4);\n                margin-right: 32px;\n                cursor: pointer;\n            }\n\n            .filter.active {\n                color: ${mainColor};\n            }\n        }\n    }\n\n    .user-info-wrapper {\n        .wrapper {\n            padding: 36px;\n            background-color: white;\n            border-radius: 4px;\n            border: solid 1px #e6e6e6;\n            float: left;\n            width: calc(50% - 10px);\n            \n            @media (max-width: 768px) {\n                width: 100%;\n            }\n        }\n\n        .wrapper.etc-info {\n            float: right;\n        }\n        \n        .title-wrapper {\n            font-size: ${sizeHandler(20)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 28px;\n        }\n\n        .service {\n            margin-bottom: 20px;\n\n            p.info {\n                font-size: ${sizeHandler(12)};\n                font-weight: normal;\n                letter-spacing: -0.15px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            input {\n                height: 36px;\n                display: inline-block;\n                width: 100%;\n            }\n\n            button {\n                width: 100%;\n                height: 48px;\n                border-radius: 2px;\n                color: white;\n            }\n\n            .ant-upload-drag-container {\n                .title {\n                    margin-top: 12px;\n                    font-size: ${sizeHandler(14)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: rgba(0, 0, 0, 0.8);\n                }\n        \n                .reco {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: #a7a7a7;\n                }\n            }\n\n            .flex-wrapper {\n                display: flex;\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: #606060;\n                    cursor: pointer;\n                }\n            }\n        }\n\n        .default-info {\n            margin-right: 20px;\n        }\n\n        .card-info {\n            margin-right: 20px;\n            margin-top: 20px;\n        }\n\n        .privacy-info {\n            margin-top: -352px;\n            @media (max-width: 768px) {\n                margin-top: 20px;\n            }\n        }\n\n        .etc-info {\n            margin-top: -290px;\n            @media (max-width: 768px) {\n                margin-top: 20px;\n            }\n        }\n    }\n\n    .user-profile-wrapper {\n        .wrapper {\n            padding: 36px;\n            background-color: white;\n            border-radius: 4px;\n            border: solid 1px #e6e6e6;\n            float: left;\n            width: calc(100% - 10px);\n            \n            @media (max-width: 768px) {\n                width: 100%;\n            }\n        }\n\n        .wrapper.etc-info {\n            float: right;\n        }\n        \n        .title-wrapper {\n            font-size: ${sizeHandler(20)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 28px;\n        }\n\n        .service {\n            margin-bottom: 20px;\n\n            p.info {\n                font-size: ${sizeHandler(12)};\n                font-weight: normal;\n                letter-spacing: -0.15px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            input {\n                height: 36px;\n                display: inline-block;\n                width: 100%;\n            }\n\n            button {\n                width: 110px;\n                height: 48px;\n                border-radius: 2px;\n                color: white;\n            }\n\n            .ant-upload-drag-container {\n                .title {\n                    margin-top: 12px;\n                    font-size: ${sizeHandler(14)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: rgba(0, 0, 0, 0.8);\n                }\n        \n                .reco {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.3px;\n                    text-align: center;\n                    color: #a7a7a7;\n                }\n            }\n\n            .flex-wrapper {\n                display: flex;\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: #606060;\n                    cursor: pointer;\n                }\n            }\n        }\n\n        .default-info {\n            margin-right: 20px;\n        }\n\n        .privacy-info {\n\n            @media (max-width: 768px) {\n                margin-top: 20px;\n            }\n        }\n\n        .etc-info {\n            margin-top: 20px;\n        }\n    }\n\n    input {\n        height: 36px;\n        display: inline-block;\n        width: 100%;\n    }\n\n    .ant-input-number-input-wrap {\n        height: 100%;\n\n        .ant-input-number-input {\n            height: 100%;\n        }\n\n        input {\n            height: 100%;\n        }\n    } \n`;\n\nexport const PointBoxRow = styled.div`\n    display: flex;\n    align-items: flex-start;\n    margin-bottom: 20px;\n\n    > div:last-child {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 480px) {\n        margin-bottom: 0px;\n        flex-direction: column;\n    }\n`;\n\nexport const PointBox = styled.div`\n    width: calc(50% - 10px);\n    margin-right: 20px;\n\n    padding: 32px;\n    background-color: #ffffff;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: solid 1px #f2f2f2;\n\n    @media (max-width: 480px) {\n        margin-right: 0px;\n        margin-bottom: 10px;\n\n        max-height: 320px;\n        padding: 16px;\n\n        width: 100%;\n    }\n`;\n\nexport const PointBox2 = styled.div`\n    width: 100%;\n    margin-right: 20px;\n\n    padding: 32px;\n    background-color: #ffffff;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: solid 1px #f2f2f2;\n\n    @media (max-width: 480px) {\n        margin-right: 0px;\n        margin-bottom: 10px;\n\n        max-height: 320px;\n        padding: 16px;\n\n        width: 100%;\n    }\n`;\n\nexport const PointBox3 = styled.div`\n    width: 100%;\n    margin-right: 20px;\n\n    padding: 32px;\n    background-color: #ffffff;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: solid 1px #f2f2f2;\n\n    @media (max-width: 480px) {\n        margin-right: 0px;\n        margin-bottom: 10px;\n\n        max-height: 370px;\n        padding: 16px;\n\n        width: 100%;\n    }\n`;\n\nexport const PointContent = styled.div`\n    max-height: 400px;\n    padding-right: 10px;\n    overflow-y: scroll;\n\n    @media (max-width: 480px) {\n        max-height: 320px;\n    }\n`;\n\nexport const PointBoxTitle = styled.h4`\n    margin-top: 0px;\n    margin-bottom: 10px;\n\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 480px) {\n        font-size: 18px;\n    }\n`;\n\nexport const PointTotal = styled.h5`\n    font-size: 32px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    letter-spacing: -0.7px;\n    text-align: left;\n    color: #3bc1ff;\n\n    @media (max-width: 480px) {\n        font-size: 26px;\n    }\n`;\n\nexport const PointHistoryRow = styled.div`\n    padding-top: 16px;\n    padding-bottom: 16px;\n    border-bottom: 1px solid #e6e6e6;\n`;\n\nexport const PointHistoryNameRow = styled.div`\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n\n    margin-bottom: 4px;\n\n    > .title {\n        font-size: 18px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.65;\n        letter-spacing: -0.2px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n\n        @media (max-width: 480px) {\n            font-size: 12px;\n        }\n    }\n\n    > .value {\n        font-size: 18px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.26;\n        letter-spacing: -0.1px;\n        text-align: right;\n        color: ${props => (props.add ? '#3bc1ff' : '#ff5500')};\n\n        @media (max-width: 480px) {\n            font-size: 12px;\n        }\n    }\n`;\n\nexport const PointHistoryValueRow = styled(PointHistoryNameRow)`\n    margin-bottom: 0px;\n\n    > .title {\n        font-size: 13px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.75;\n        letter-spacing: -0.1px;\n        text-align: left;\n        color: #afb0b2;\n\n        @media (max-width: 480px) {\n            font-size: 10px;\n        }\n    }\n\n    > .value {\n        font-size: 13px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.54;\n        letter-spacing: -0.15px;\n        text-align: left;\n        color: #afb0b2;\n\n        @media (max-width: 480px) {\n            font-size: 10px;\n        }\n    }\n`;\n\nexport const NoHistory = styled.div`\n    padding: 12px;\n    text-align: center;\n\n    font-size: 20px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.65;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n`;\n\nexport default StyledNormalContainer;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Input, message, notification } from 'antd';\nimport axios from '../../../Lib/axios';\n\nimport { sizeHandler, mainColor } from '../../../theme';\nimport { colorParserByStatus } from '../../../Lib/utils';\nimport { ASSIST, UNEMER, HAPPYCARE } from '../../../Lib/variables';\n\nimport moment from 'moment';\nexport const InputFilter = ({ keyword, keywordHandler }) => (\n    <FilterWrapper>\n        <Input\n            value={keyword}\n            onChange={ev => {\n                keywordHandler(ev.target.value);\n            }}\n            placeholder='예약번호, 담당자 성함 등을 검색해보세요.'\n        />\n    </FilterWrapper>\n);\n\nconst FilterWrapper = styled.div`\n    margin-bottom: 12px;\n`;\n\nexport const ReserveList = ({ list, onDetailModal, onMateModal, onReport, onCancel }) => {\n    if (!list || list.length === 0) {\n        return (\n            <FullContainer>\n                <Inner>\n                    <EmptyList>이용내역이 없습니다.</EmptyList>\n                </Inner>\n            </FullContainer>\n        );\n    }\n\n    return (\n        <ListConatiner>\n            {list.map((item, index) => {\n                const serviceType =\n                    !item.productInfo || !item.productInfo.usePro || !item.productInfo.useBasic ? '' : item.service === 'unemergency' ? 'Pro' : 'Basic';\n                const serviceName = (item.productInfo && item.productInfo.name && item.service && item.productInfo.name + serviceType) || '-';\n\n                return (\n                    <ReserveItem\n                        key={item._id + index + 'service-list'}\n                        reserveCode={item.reserveCode}\n                        service={serviceName}\n                        serviceType={item.service}\n                        reserveDate={moment(item.reserveDate).format('MM월 DD일 dddd HH시mm분')}\n                        destination={item.destination}\n                        starting={item.starting}\n                        status={item.call.status}\n                        onReport={() => {\n                            onReport(item);\n                        }}\n                        onDetail={() => {\n                            onDetailModal(item._id);\n                        }}\n                        onMate={() => {\n                            if (item.call.status === '접수취소') {\n                                return message.info('접수취소된 서비스입니다.');\n                            }\n\n                            if (!item.call.mate || !item.call.mate) {\n                                return message.info('아직 담당자가 배정되지 않았습니다.');\n                            }\n\n                            onMateModal({\n                                ...item.call.mate,\n                                service: item.service,\n                                status: item.call.status,\n                                callId: item.call._id,\n                                reserveId: item._id,\n                                mateId: item.call.mateId,\n                            });\n                        }}\n                        onCancel={() => {\n                            const confirmCancel = window.confirm('예약을 취소하시겠습니까?');\n                            if (confirmCancel) {\n                                axios\n                                    .put('/v2/service/cancel/reserve/by/user', {\n                                        reserveId: item._id,\n                                        callId: item.callId,\n                                    })\n                                    .then(resolve => {\n                                        const { data } = resolve;\n                                        if (!data) return message.error('요청 실패');\n                                        else if (data === 'wrong request') return message.warning('잘못된 요청입니다.');\n                                        else if (data === 'already cancel') return message.warning('접수 취소된 요청입니다.');\n                                        else if (data === 'already done') return message.warning('서비스 종료된 요청입니다.');\n                                        else if (data === 'success') {\n                                            notification.success({\n                                                message: '예약 취소',\n                                                description: '예약 취소가 완료 되었습니다.',\n                                            });\n                                            // setTimeout(() => {\n                                            //     window.location.reload();\n                                            // }, 3000);\n                                            return null;\n                                        }\n                                    });\n                            }\n                        }}\n                    />\n                );\n            })}\n        </ListConatiner>\n    );\n};\n\nconst ReserveItem = ({ reserveCode, service, serviceType, reserveDate, destination, starting, status, onReport, onDetail, onMate, onCancel }) => (\n    <ItemContainer>\n        <TitleSection>\n            <ItemColumn>\n                <ItemTitle>서비스 명</ItemTitle>\n                <ItemContents style={{ color: mainColor }}>{service}</ItemContents>\n            </ItemColumn>\n        </TitleSection>\n\n        <ContentSection>\n            <ItemColumn>\n                <ItemTitle>예약 번호</ItemTitle>\n                <ItemContents>{reserveCode}</ItemContents>\n            </ItemColumn>\n            <ItemColumn>\n                <ItemTitle>진행 상황</ItemTitle>\n                <ItemContents style={{ color: colorParserByStatus(status) }}>{status}</ItemContents>\n            </ItemColumn>\n            <ItemColumn>\n                <ItemTitle>예약 날짜</ItemTitle>\n                <ItemContents>{reserveDate}</ItemContents>\n            </ItemColumn>\n            {serviceType === 'unemergency' && (\n                <ItemColumn>\n                    <ItemTitle>자택 주소</ItemTitle>\n                    <ItemContents>{starting}</ItemContents>\n                </ItemColumn>\n            )}\n            <ItemColumn>\n                <ItemTitle>병원 위치</ItemTitle>\n                <ItemContents>{destination}</ItemContents>\n            </ItemColumn>\n        </ContentSection>\n        <ItemColumn>\n            <DetailButton\n                onClick={() => {\n                    if (status === '서비스 종료') {\n                        onReport();\n                    } else {\n                        onMate();\n                    }\n                }}\n            >\n                <span>{status === '서비스 종료' ? '서비스 리포트' : '담당자 확인'}</span>\n            </DetailButton>\n        </ItemColumn>\n        <ItemColumn>\n            {status === '접수취소' ? null : (\n                <ReserveButton\n                    onClick={() => {\n                        if (status === '서비스 종료') {\n                            return null;\n                        } else {\n                            onCancel();\n                        }\n                    }}\n                >\n                    <span>예약 취소</span>\n                </ReserveButton>\n            )}\n        </ItemColumn>\n        <ItemColumn>\n            <ReserveButton\n                onClick={() => {\n                    onDetail();\n                }}\n            >\n                <span>예약 확인</span>\n            </ReserveButton>\n        </ItemColumn>\n    </ItemContainer>\n);\nconst TitleSection = styled.div``;\n\nconst EmptyList = styled.p`\n    font-size: 20px;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 16px;\n    position: relative;\n    text-align: center;\n`;\n\nconst FullContainer = styled.div`\n    width: 100%;\n    min-height: 300px;\n`;\n\nconst Inner = styled.div`\n    max-width: 1024px;\n    margin: 0 auto;\n    padding-top: 40px;\n\n    @media (max-width: 1080px) {\n        padding-left: 16px;\n        padding-right: 16px;\n    }\n\n    @media (max-width: 768px) {\n        padding-top: 40px;\n    }\n`;\nconst ContentSection = styled.div`\n    flex: 1;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    justify-content: flex-start;\n\n    overflow-y: scroll;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none; /* Chrome, Safari, Opera*/\n    }\n`;\n\nconst ListConatiner = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: flex-start;\n    flex-wrap: wrap;\n\n    > div:nth-child(3n) {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        > div:nth-child(3n) {\n            margin-right: 16px;\n        }\n\n        > div:nth-child(2n) {\n            margin-right: 0px;\n        }\n    }\n\n    @media (max-width: 480px) {\n        > div:nth-child(3n) {\n            margin-right: 0px;\n        }\n\n        flex-direction: column;\n        justify-content: center;\n    }\n`;\n\nconst ItemContainer = styled.div`\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    justify-content: center;\n\n    width: 340px;\n    height: 430px;\n    overflow: scroll;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none; /* Chrome, Safari, Opera*/\n    }\n\n    padding: 20px;\n    margin-bottom: 16px;\n    margin-right: 16px;\n\n    border-radius: 4px;\n    box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n    background-color: #ffffff;\n\n    @media (max-width: 768px) {\n        margin-bottom: 16px;\n    }\n\n    @media (max-width: 480px) {\n        width: 100%;\n        max-width: initial;\n        margin-right: 0px;\n    }\n`;\n\nconst ItemTitle = styled.p`\n    color: #a7a7a7;\n    font-size: ${sizeHandler(12)};\n    font-weight: bold;\n    margin: 0px;\n    padding: 0px;\n\n    @media (max-width: 430px) {\n        font-size: ${sizeHandler(11)};\n    }\n`;\nconst ItemContents = styled.p`\n    font-size: ${sizeHandler(14)};\n    font-weight: bold;\n    color: #606060;\n    margin: 0px;\n    padding: 0px;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n\n    @media (max-width: 430px) {\n        font-size: ${sizeHandler(12)};\n        margin-bottom: 4px;\n    }\n`;\n\nconst ItemColumn = styled.div`\n    width: 100%;\n    margin-bottom: 6px;\n\n    @media (max-width: 768px) {\n        display: ${props => (props.hiddenMobile ? 'none' : 'block')};\n        width: 100%;\n    }\n`;\n\nconst DetailButton = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    width: 100%;\n    height: 44px;\n\n    border-radius: 4px;\n    border: 1px solid ${mainColor};\n    cursor: pointer;\n    transition: all 0.3s;\n    text-align: center;\n\n    span {\n        font-size: ${sizeHandler(14)};\n        font-weight: bold;\n        color: ${mainColor};\n        text-align: center;\n\n        @media (max-width: 430px) {\n            font-size: ${sizeHandler(12)};\n        }\n    }\n\n    &:hover {\n        background-color: ${mainColor};\n        span {\n            color: white;\n        }\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n        height: 34px;\n        font-size: ${sizeHandler(12)};\n    }\n`;\n\nconst ReserveButton = styled(DetailButton)`\n    border: 1px solid #e9e9e9;\n    color: #565656;\n\n    > span {\n        color: #565656;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nimport { sizeHandler, mainColor } from '../../../theme';\n\nexport const UserStatistics = ({ auth, pro, basic }) => (\n    <UserContainer>\n        <div className='default-info'>\n            <p>\n                {auth.name},\n                <br />\n                안녕하세요\n            </p>\n        </div>\n\n        <div className='reserve-info'>\n            <div className='title'>\n                <p>이용 통계</p>\n            </div>\n            <div className='value-wrapper'>\n                <div className='value-block'>\n                    <div className='title'>\n                        <img src='/assets/images/unemergency-small.png' alt='small-icon' />\n                        <span>병원 동행 Pro</span>\n                    </div>\n                    <div className='value'>\n                        <p>{pro}회 이용</p>\n                    </div>\n                </div>\n\n                <div className='value-block'>\n                    <div className='title'>\n                        <img src='/assets/images/withassist-small.png' alt='small-icon' />\n                        <span>병원 동행 Basic</span>\n                    </div>\n                    <div className='value'>\n                        <p>{basic}회 이용</p>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </UserContainer>\n);\n\nconst UserContainer = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 82px 30px;\n\n    .default-info {\n        flex: 1;\n        display: flex;\n        align-items: center;\n\n        div {\n            width: 110px;\n            height: 110px;\n            border-radius: 55px;\n            margin-right: 20px;\n            background-color: #e6e6e6;\n            position: relative;\n            overflow: hidden;\n\n            img {\n                height: 110px;\n                position: absolute;\n                margin: auto;\n                top: 0px;\n                left: 0px;\n                right: 0px;\n                bottom: 0px;\n            }\n\n            span {\n                display: inline-block;\n                position: absolute;\n                margin: auto;\n                top: 0px;\n                left: 0px;\n                right: 0px;\n                bottom: 0px;\n                line-height: 110px;\n                text-align: center;\n                color: #ada5a5;\n            }\n        }\n\n        p {\n            flex: 1;\n            font-size: ${sizeHandler(38)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: rgba(0, 0, 0, 0.8);\n        }\n    }\n\n    .reserve-info {\n        flex: 1;\n\n        .title {\n            margin-bottom: 12px;\n\n            p {\n                font-size: ${sizeHandler(12)};\n                font-weight: bold;\n                color: rgba(145, 145, 145, 0.8);\n            }\n        }\n\n        .value-wrapper {\n            display: flex;\n            align-items; center;\n\n            .value-block {\n                flex: 1;\n\n                .title {\n                    img {\n                        height: 14px;\n                        margin-right: 4px;\n                    }\n\n                    span {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.8);\n                    }\n                }\n\n                .value {\n                    font-size: ${sizeHandler(16)};\n                    font-weight: bold;\n                    color: #3bc1ff;\n                    text-overflow: ellipsis;\n                    overflow: hidden;\n                    white-space: nowrap;\n                }\n            }\n        }\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: flex-start;\n\n        .reserve-info {\n            margin-top: 40px;\n        }\n\n        .value-wrapper {\n            flex-direction: column;\n\n            .value-block:last-child {\n                margin-top: 20px;\n            }\n        }\n    }\n        \n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nimport { sizeHandler, mainColor } from '../../../theme';\n\nexport const UserNavigation = ({ active, tabHandler, onPatientModal }) => (\n    <NaviWrapper>\n        <div className='nav-tab'>\n            <span\n                onClick={() => {\n                    tabHandler('list');\n                }}\n                className={`name ${active === 'list' ? 'active' : ''}`}\n            >\n                예약내역\n            </span>\n            <span className={`underline ${active === 'list' ? 'active' : ''}`}></span>\n        </div>\n\n        <div className='nav-tab'>\n            <span\n                onClick={() => {\n                    tabHandler('info');\n                }}\n                className={`name ${active === 'info' ? 'active' : ''}`}\n            >\n                개인정보 관리\n            </span>\n            <span className={`underline ${active === 'info' ? 'active' : ''}`}></span>\n        </div>\n\n        <div className='nav-tab'>\n            <span\n                onClick={() => {\n                    tabHandler('point');\n                }}\n                className={`name ${active === 'point' ? 'active' : ''}`}\n            >\n                내 포인트\n            </span>\n            <span className={`underline ${active === 'point' ? 'active' : ''}`}></span>\n        </div>\n\n        <div className='nav-tab'>\n            <span\n                onClick={() => {\n                    // onPatientModal();\n                    tabHandler('profile');\n                }}\n                className={`name ${active === 'profile' ? 'active' : ''}`}\n            >\n                환자 프로필 관리\n            </span>\n            <span className={`underline ${active === 'profile' ? 'active' : ''}`}></span>\n        </div>\n    </NaviWrapper>\n);\n\nconst NaviWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    padding: 0px 30px;\n\n    .nav-tab {\n        margin-right: 32px;\n        padding-bottom: 12px;\n        position: relative;\n\n        .name {\n            font-size: ${sizeHandler(14)};\n            text-align: center;\n            cursor: pointer;\n\n            &.active {\n                font-weight: bold;\n                color: #3bc1ff;\n            }\n        }\n\n        span.underline {\n            background-color: #3bc1ff;\n            position: absolute;\n            bottom: 0px;\n            left: 0px;\n\n            &.active {\n                width: 100%;\n                height: 3px;\n                display: inline-block;\n            }\n        }\n    }\n`;\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\n\nconst ProfileStyledContainer = styled.div`\n\n    @media (max-width: 480px) {\n        min-height: initial;\n        height: 100%;\n        padding-bottom: 0px;\n        padding-top: 5px;\n    }\n\n    .inner-container {\n        padding-bottom: 0px;\n        padding-top: 0px;\n\n        @media (max-width: 480px) {\n            padding: 0px;\n        }\n\n        .profile-form {\n\n            .title-wrapper {\n                display: flex;\n                justify-content: flex-start;\n                margin-bottom: 16px;\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    line-height: 48px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                }\n\n                span {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: right;\n                    color: ${mainColor};\n                }\n            }\n\n            .form {\n                label {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.15px;\n                    line-height: 20px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 4px;\n                }\n\n                input {\n                    height: 44px;\n                    border: solid 1px #e6e6e6;\n                    padding: 10px;\n\n                    &.ant-input {\n                        font-size: 16px;\n                        line-height: 28px;\n                        letter-spacing: -0.2px;\n                        color: rgba(0, 0, 0, 0.7);\n\n                        &::placeholder {\n                            font-size: 14px;\n                        }\n                    }\n                }\n\n                .type-button-wrapper {\n                    width: 100%;\n                    height: 48px;\n\n                    background-color: white;\n                    border: 1px solid #e6e6e6;\n                    border-radius: 4px;\n\n                    display: flex;\n                    align-items: center;\n\n                    > .type-button {\n                        width: 50%;\n                        height: 100%;\n                        line-height: 48px;\n\n                        text-align: center;\n                        cursor: pointer;\n\n                        font-size: 16px;\n                        letter-spacing: -0.2px;\n                        color: rgba(0, 0, 0, 0.2);\n                    }\n\n                    > .type-button.active {\n                        background: rgba(0, 0, 0, 0.7);\n                        border-radius: 4px;\n                        color: #f9f9f9;\n                    }\n                }\n\n                button {\n                    width: 100%;\n                    height: 46px;\n                    margin-top: 4px;\n                    margin-bottom: 16px;\n\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    letter-spacing: -0.2px;\n                    text-align: center;\n                    color: #ffffff;\n                }\n\n                .link-wrapper {\n                    display: flex;\n                    justify-content: center;\n                    margin-bottom: 8px;\n                    .text {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: rgba(0, 0, 0, 0.7);\n                        line-height: 21px;\n                    }\n\n                    .link {\n                        cursor: pointer;\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: ${mainColor};\n\n                        margin-left: 8px;\n                    }\n                }\n            }\n\n            .form-user-type {\n                height: 36px;\n                margin-bottom: 20px;\n                border-radius: 4px;\n                border: 1px solid #e6e6e6;\n                display: flex;\n                align-items: center;\n                overflow: hidden;\n\n                .type {\n                    flex: 1;\n                    height: 100%;\n                    line-height: 36px;\n                    background-color: #ffffff;\n                    cursor: pointer;\n\n                    &:first-child {\n                        border-right: 1px solid #e6e6e6;\n                    }\n\n                    p {\n                        font-size: ${sizeHandler(12)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #606060;\n                    }\n\n                    &.active {\n                        background-color: #606060;\n\n                        p {\n                            color: #ffffff;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .ant-upload-drag-container {\n        .title {\n            margin-top: 12px;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: rgba(0, 0, 0, 0.8);\n        }\n\n        .reco {\n            font-size: ${sizeHandler(12)};\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: #a7a7a7;\n        }\n    }\n`;\n\nexport default ProfileStyledContainer;","import styled from 'styled-components';\n\nconst StyledContainer = styled.div``;\n\nexport default StyledContainer;\n\nexport const Container = styled.div`\n    padding-top: 55px;\n`;\n\nexport const GuideNavContainer = styled.div`\n    width: 100%;\n    background-color: #ffffff;\n\n    border-bottom: 4px solid #f2f2f2;\n`;\n\nexport const InnerContainer = styled.div`\n    width: 100%;\n\n    max-width: 1120px;\n    margin: 0 auto;\n\n    // @media (max-width: 1120px) {\n    //     padding-left: 32px;\n    //     padding-right: 32px;\n    // }\n\n    @media (max-width: 768px) {\n        padding-left: 20px;\n        padding-right: 20px;\n    }\n`;\n\nexport const GuideNavWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    padding-top: 16px;\n    padding-bottom: 16px;\n\n    @media (max-width: 768px) {\n        overflow-x: scroll;\n    }\n`;\n\nexport const NavTab = styled.div`\n    > a {\n        cursor: pointer;\n        font-size: 22px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.42;\n        letter-spacing: -0.5px;\n        text-align: left;\n\n        white-space: nowrap;\n\n        color: ${props => (props.active ? '#3BC1FF' : 'rgba(0,0,0,0.6)')};\n\n        display: inline-block;\n    }\n\n    @media (max-width: 768px) {\n        margin-right: 40px;\n\n        > a {\n            font-size: 16px;\n        }\n    }\n`;\n\nexport const GuideConceptContainer = styled.div`\n    margin-top: 102px;\n`;\n\nexport const GuideConceptTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 50px;\n`;\n\nexport const GuideConceptImageWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    width: 100%;\n\n    margin-bottom: 40px;\n`;\n\nexport const GuideConceptImage = styled.img`\n    height: 200px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const GuideConceptImageMobile = styled.img`\n    display: none;\n\n    height: 300px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const GuideConceptTextWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: center;\n\n    margin-bottom: 122px;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const GuideConceptTextBlock = styled.div`\n    &:first-child {\n        margin-right: 20px;\n\n        @media (max-width: 768px) {\n            margin-right: 0px;\n\n            margin-bottom: 16px;\n        }\n    }\n\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.67;\n    letter-spacing: -0.2px;\n    text-align: left;\n    word-break: keep-all;\n\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.75;\n        letter-spacing: -0.2px;\n        text-align: left;\n    }\n\n    > span {\n        font-weight: bold;\n    }\n`;\n\nexport const MobileBr = styled.br`\n    display: none;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n\n    @media (max-width: 320px) {\n        display: none;\n    }\n`;\n\nexport const DesktopBr = styled.br`\n    display: block;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const MeritContainer = styled.div`\n    background-color: #ffffff;\n\n    padding-top: 100px;\n    padding-bottom: 80px;\n`;\n\nexport const MeritHeaderWrapper = styled.div`\n    width: 100%;\n    padding-bottom: 10px;\n    border-bottom: 2px solid #f2f2f2;\n\n    div.wrap {\n        display: flex;\n        align-items: flex-end;\n        justify-content: flex-start;\n    }\n\n    img {\n        width: 72px;\n        height: 72px;\n        object-fit: contain;\n\n        margin-right: 10px;\n    }\n\n    h3 {\n        font-size: 24px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.3;\n        letter-spacing: -0.5px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n        margin-bottom: 0px;\n    }\n`;\n\nexport const MeritCardList = styled.div`\n    display: flex;\n    flex-wrap: wrap;\n\n    padding-top: 64px;\n`;\n\nexport const MeritCardWrapper = styled.div`\n    height: 260px;\n    width: 33.333%;\n\n    @media (max-width: 768px) {\n        width: 100%;\n        height: auto;\n        margin-bottom: 24px;\n    }\n`;\n\nexport const MeritCardNumber = styled.p`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.43;\n    letter-spacing: normal;\n    text-align: left;\n    color: #afb0b2;\n    margin-bottom: 16px;\n`;\n\nexport const MeritCardTitleRow = styled.div`\n    display: flex;\n    align-items: center;\n\n    > img {\n        width: 20px;\n        height: 20px;\n        object-fit: contain;\n        margin-right: 10px;\n    }\n\n    > span {\n        font-size: 20px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.54;\n        letter-spacing: -0.1px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n`;\n\nexport const MeritCardDesc = styled.div`\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.65;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-weight: bold;\n    }\n\n    @media (max-width: 768px) {\n        font-size: 15px;\n    }\n`;\n\nexport const GuideDetailContainer = styled.div`\n    background-color: #f9f9f9;\n\n    padding-top: 56px;\n    padding-bottom: 100px;\n`;\n\nexport const GuideDetailServiceCardWrapper = styled.div`\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const GuideDetailServiceCard = styled.div`\n    width: 360px;\n    padding: 34px 32px;\n\n    background: #ffffff;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: 1px solid rgba(0, 0, 0, 0.1);\n    border-radius: 4px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n\n    @media (max-width: 768px) {\n        margin-bottom: 24px;\n        width: 100%;\n\n        padding: 34px 16px;\n    }\n`;\n\nexport const GuideCardImage = styled.img`\n    width: 124px;\n    height: 124px;\n    border-radius: 50%;\n\n    margin-bottom: 40px;\n`;\n\nexport const GuideCardSpecTitle = styled.p`\n    width: 100%;\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    margin-bottom: 24px;\n`;\n\nexport const GuideCardSpecRow = styled.div`\n    display: flex;\n    width: 100%;\n    align-items: flex-start;\n\n    margin-bottom: 24px;\n\n    > span {\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        // line-height: 1.43;\n        letter-spacing: normal;\n        text-align: left;\n        color: #3bc1ff;\n        margin-right: 10px;\n    }\n\n    > p {\n        width: 100%;\n        flex: 1;\n        font-size: 17px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        // line-height: 1.65;\n        letter-spacing: -0.3px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n`;\n\nexport const GuideCardName = styled.p`\n    width: 100%;\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    margin-bottom: 2px;\n`;\n\nexport const GuideCardType = styled.h3`\n    width: 100%;\n    font-size: 26px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.2;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: #3bc1ff;\n    margin-bottom: 24px;\n`;\n\nexport const GuideCardDescription = styled.p`\n    width: 100%;\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-weight: bold;\n    }\n\n    margin-bottom: 60px;\n`;\n\nexport const GuideDetailSubFlexWrapper = styled.div`\n    display: flex;\n    justify-content: content;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const GuideDetailButtonWrapper = styled(GuideDetailSubFlexWrapper)`\n    border-radius: 4px;\n    overflow: hidden;\n\n    > span.button {\n        cursor: pointer;\n        display: inline-block;\n\n        flex: 1;\n        height: 44px;\n        line-height: 44px;\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 12px;\n        text-align: center;\n        color: #ffffff;\n\n        @media (max-width: 768px) {\n            width: 100%;\n        }\n    }\n\n    > span.gray {\n        background-color: #606060;\n\n        @media (max-width: 768px) {\n            margin-bottom: 8px;\n        }\n    }\n\n    > span.blue {\n        background-color: #3bc1ff;\n    }\n`;\n\nexport const GuideDetailSubFlexbox = styled.div`\n    flex: 1;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    > p {\n        margin-bottom: 20px;\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 12px;\n        line-height: 18px;\n\n        text-align: left;\n\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.7);\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nexport const GuideUsingContainer = styled.div`\n    padding-top: 62px;\n    padding-bottom: 78px;\n    background-color: #f9f9f9;\n`;\n\nexport const GuideUsingSubFlexWrapper = styled(GuideDetailSubFlexWrapper)`\n    align-items: center;\n    justify-content: center;\n\n    @media (max-width: 768px) {\n        align-items: flex-start;\n        padding-left: 40px;\n    }\n`;\n\nexport const GuideUsingFlexbox = styled(GuideDetailSubFlexbox)`\n    align-items: center;\n    flex: initial;\n    min-width: 320px;\n\n    > p.index {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 10px;\n        line-height: 14px;\n\n        letter-spacing: -0.333333px;\n        color: rgba(0, 0, 0, 0.2);\n\n        margin-bottom: 16px;\n    }\n\n    > p {\n        width: auto;\n        text-align: center;\n    }\n\n    > p.title {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 16px;\n        line-height: 22px;\n\n        text-align: center;\n        letter-spacing: -0.6px;\n    }\n\n    > div {\n        display: flex;\n        justify-content: center;\n\n        margin-bottom: 16px;\n\n        img {\n            height: 90px;\n            object-fit: contain;\n        }\n    }\n\n    margin-bottom: 44px;\n`;\n\nexport const GuideUsageFlexbox = styled.div`\n    flex: 1;\n\n    display: flex;\n    align-items: center;\n    justify-content: flex-start;\n\n    margin-bottom: 68px;\n\n    @media (max-width: 768px) {\n        margin-bottom: 32px;\n        // width: 230px;\n        align-items: ;\n    }\n\n    div {\n        // width: 120px;\n\n        img {\n            width: 64px;\n            height: 64px;\n            margin-right: 34px;\n            object-fit: contain;\n        }\n\n        // @media (max-width: 768px) {\n        //     width: 70px;\n\n        //     img {\n        //         height: 32px;\n        //     }\n        // }\n    }\n\n    span {\n        font-size: 18px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.65;\n        letter-spacing: -0.2px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n\n        // @media (max-width: 768px) {\n        //     font-size: 13px;\n        //     line-height: 19px;\n        // }\n    }\n`;\n\nexport const WithmateContainer = styled.div`\n    padding-top: 56px;\n    // padding-bottom: 120px;\n`;\n\nexport const FlexDivWrapper = styled.div`\n    display: flex;\n    width: 100%;\n\n    ${props => props.top && `margin-bottom: 72px;`}\n`;\n\nexport const HiddenType = styled.div`\n    @media (max-width: 768px) {\n        ${props => props.mHidden && `display: none;`}\n    }\n`;\n\nexport const BigSideBox = styled(HiddenType)`\n    width: 58%;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nexport const SmallSideBox = styled(HiddenType)`\n    width: 42%;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nexport const WithmateBg = styled.div`\n    width: 100%;\n    height: 100%;\n\n    background-image: url(${props => props.bg});\n    background-size: 80% auto;\n    background-position: center;\n    background-repeat: no-repeat;\n`;\n\nexport const WithmateTitle = styled.div`\n    > img {\n        width: 72.5px;\n        height: 48px;\n        object-fit: contain;\n        margin-right: 8px;\n    }\n\n    > span {\n        font-size: 28px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.11;\n        letter-spacing: -0.5px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n\n    display: flex;\n    align-items: flex-end;\n    margin-bottom: 24px;\n`;\n","import React from \"react\";\nimport Modal from \"react-modal\";\nimport styled from 'styled-components';\nimport { Button, Checkbox, notification, Select, message, Radio } from 'antd';\n\nimport { DivisionLine, WithmateSelect, WithmateInput, WithamteInputWithButton, WithmateLabel, WithmateTextarea } from \"../../../../Components/Common/input\";\nimport { HalfWidthButton } from '../../../../Components/Common/button';\nimport ProfileStyledContainer from \"./profile.styled\";\nimport { MobileBr } from \"../../../Guide/guide.styled\";\nimport { addPatient } from \"../../../../Lib/Api/auth\";\n\nconst customStyles = {\n    overlay: {\n        position: \"fixed\",\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: \"rgba(15, 15, 15, 0.79)\",\n    },\n    content: {\n        position: \"absolute\",\n        top: \"30px\",\n        height: \"90%\",\n        border: \"1px solid #ccc\",\n        background: \"#ffffff\",\n        overflow: \"auto\",\n        WebkitOverflowScrolling: \"touch\",\n        borderRadius: \"4px\",\n        outline: \"none\",\n        padding: \"20px\",\n    },\n};\n\nclass NewProfileComponent extends React.PureComponent {\n    state = {\n        modalInfo: '',\n        modalTitle: '',\n    };\n\n    onEdit = ({ type, value }) => {\n        this.props.editAddPatientForm({ type, value });\n    };\n\n    onStarting = () => {\n        new window.daum.Postcode({\n            oncomplete: data => {\n                const { sido, sigungu, bname, roadAddress, buildingName } = data;\n                this.onEdit({ type: 'shortStarting', value: `${sido} ${sigungu} ${bname}` });\n                this.onEdit({ type: 'starting', value: `${roadAddress} (${ buildingName })` });\n            },\n        }).open();\n    };\n\n    onProfile = () => {\n        const {\n            name,\n            relate,\n            sex,\n            age,\n            contact,\n            starting,\n            environment,\n            caution\n        } = this.props.auth.addPatientForm;\n\n        if (!name) {\n            return message.warning('성함을 입력해주세요.');\n        }\n\n        if (!relate) {\n            return message.warning('관계를 선택해주세요.');\n        }\n\n        if (!sex) {\n            return message.warning('성별을 선택해주세요.');\n        }\n\n        if (!age || age.length > 3) {\n            return message.warning('나이를 입력해주세요.');\n        }\n\n        if (!contact) {\n            return message.warning('연락처를 입력해주세요.');\n        }\n\n        if (!starting) {\n            return message.warning('주소(자택, 출발지)를 입력해주세요.');\n        }\n\n        if (!environment) {\n            return message.warning('거주환경을 입력해주세요.');\n        }\n\n        if (!caution) {\n            return message.warning('메이트와 동행할 때 주의해야할 점을 선택해주세요.');\n        }\n\n        this.props\n            .addPatient({\n                id: this.props.auth.id, name, relate, sex, age, contact, starting, environment, caution\n            })\n            .then(resolve => {\n                // console.log(resolve)\n                if (resolve.message === 'success') {\n                    this.props.onClose();\n                    this.onEdit({ type: 'clear', value: '' });\n                    notification.open({\n                        message: '환자 프로필 등록이 완료되었습니다.',\n                        description: '등록된 환자 프로필을 서비스 예약시 편리하게 이용하실 수 있습니다.',\n                        type: 'success'\n                    });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    }\n\n    formCompleteStatus = () => {\n        let valid = true;\n        if (!this.props.auth || !this.props.auth.addPatientForm) return false;\n\n        const { name, relate, sex, age, contact, starting, environment, caution } = this.props.auth.addPatientForm;\n        if (!name) valid = false;\n        if (!relate) valid = false;\n        if (!sex) valid = false;\n        if (!age) valid = false;\n        if (!contact) valid = false;\n        if (!starting) valid = false;\n        if (!environment) valid = false;\n        if (!caution) valid = false;\n\n        return valid;\n    };\n\n    render() {\n        const { addPatientForm } = this.props.auth;\n        const status = this.formCompleteStatus();\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <ProfileStyledContainer>\n                    <div className='inner-container'>\n                        <div className='profile-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>환자 프로필 등록</WideModalTitle>\n                                    <AlertText>\n                                        *위드메이트 서비스를 사용하실 프로필을 등록할 수 있습니다.\n                                    </AlertText>\n                                </TitleSection>\n\n                                <br />\n\n                                <WithmateLabel required>환자 이름</WithmateLabel>\n                                <WithmateInput\n                                    type='text'\n                                    placeholder='ex. 홍길동'\n                                    value={addPatientForm.name || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'name', value: ev.target.value.trim() });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>본인-{addPatientForm.name}님 간 관계</WithmateLabel>\n                                <WithmateSelect\n                                    style={{ height: '48px', width: '100%' }}\n                                    placeholder='환자 프로필을 등록하는 대상의 관계를 선택해주세요.'\n                                    value={addPatientForm.relate || undefined}\n                                    onChange={value => {\n                                        this.onEdit({ type: 'relate', value });\n                                    }}\n                                >\n                                    <Select.Option value='본인'>본인</Select.Option>\n                                    <Select.Option value='부모'>부모</Select.Option>\n                                    <Select.Option value='자매'>자매</Select.Option>\n                                    <Select.Option value='친구'>친구</Select.Option>\n                                    <Select.Option value='지인'>지인</Select.Option>\n                                    <Select.Option value='기타'>기타</Select.Option>\n                                </WithmateSelect>\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>{addPatientForm.name}님 성별</WithmateLabel>\n                                <div className='type-button-wrapper'>\n                                    <div\n                                        className={`type-button ${addPatientForm.sex && addPatientForm.sex === '남자' ? 'active' : ''}`}\n                                        onClick={() => {\n                                            this.onEdit({ type: 'sex', value: '남자' });\n                                        }}\n                                    >\n                                        남자\n                                    </div>\n                                    <div\n                                        className={`type-button ${addPatientForm.sex && addPatientForm.sex === '여자' ? 'active' : ''}`}\n                                        onClick={() => {\n                                            this.onEdit({ type: 'sex', value: '여자' });\n                                        }}\n                                    >\n                                        여자\n                                    </div>\n                                </div>\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>{addPatientForm.name}님 나이</WithmateLabel>\n                                <WithmateInput\n                                    type='text'\n                                    maxLength='2'\n                                    placeholder=''\n                                    name='age'\n                                    suffix='세'\n                                    value={addPatientForm.age || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'age', value: ev.target.value.trim() });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>{addPatientForm.name}님 연락처</WithmateLabel>\n                                <WithmateInput\n                                    type='text'\n                                    maxLength={11}\n                                    placeholder='숫자만 입력해주세요.(ex. 01012345678)'\n                                    value={addPatientForm.contact || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'contact', value: ev.target.value.trim() });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>{addPatientForm.name}님의 주소(자택 혹은 출발지)를 입력해주세요.</WithmateLabel>\n                                <WithamteInputWithButton\n                                    inputConfig={{\n                                        type: 'text',\n                                        placeholder: 'ex) 서울특별시 도산대로  40, OO 아파트',\n                                        name: 'starting',\n                                        disabled: true,\n                                        value: addPatientForm.starting || ''\n                                    }}\n                                    buttonName='검색'\n                                    onButton={() => { this.onStarting() }}\n                                />\n                                <DivisionLine />\n\n                                <WithmateLabel required>{addPatientForm.name}님은 외출하실 때 '꼭' 계단을 이용하셔야 하나요?</WithmateLabel>\n                                <Radio\n                                    checked={addPatientForm.environment === '네'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'environment', value: '네' });\n                                    }}\n                                >\n                                    네\n                                </Radio>\n                                <Radio checked={addPatientForm.environment === '아니요, 엘레베이터가 있어요'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'environment', value: '아니요, 엘레베이터가 있어요' })\n                                    }}\n                                >\n                                    아니요, 엘레베이터가 있어요\n                                </Radio>\n                                <Radio checked={addPatientForm.environment === '1층이라 괜찮아요'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'environment', value: '1층이라 괜찮아요' })\n                                    }}\n                                >\n                                    1층이라 괜찮아요\n                                </Radio>\n                                <DivisionLine />\n\n                                <WithmateLabel required>메이트가 {addPatientForm.name}님과 동행할 때 주의해야 할 점이 있을까요?</WithmateLabel>\n                                <WithmateInput\n                                    type='text'\n                                    placeholder='메이트 도움 필요 소요(승하차 어려움, 보행 어려움, 의료진 설명 이해 어려움 등) 및 메이트 주의 사항'\n                                    value={addPatientForm.caution || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'caution', value: ev.target.value });\n                                    }}\n                                />\n                                <Checkbox checked={addPatientForm.caution === '없어요'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'caution', value: '없어요' })\n                                    }}\n                                >\n                                    없어요\n                                </Checkbox>\n\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ marginRight: '8px', color: '#afb0b2' }} bg='#e6e6e6'\n                                        onClick={this.props.onClose}\n                                    >\n                                        닫기\n                                    </HalfWidthButton>\n                                    <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff'\n                                        onClick={() => {\n                                            this.onProfile()\n                                        }}\n                                        style={!status ? { backgroundColor: '#E6E6E6', border: 0, cursor: 'not-allowed' } : {}}\n                                    >\n                                        프로필 등록\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n\n                                <MobileBr />\n                            </div>\n                        </div>\n                    </div>\n                </ProfileStyledContainer >\n            </Modal >\n        );\n    }\n};\n\nexport default NewProfileComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst AlertText = styled.div`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.52;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n`;\n\nconst Agree = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    margin-bottom: 8px;\n\n    span {\n        font-size: 14px;\n        line-height: 21px;\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.7);\n    }\n\n    span.point {\n        color: #3bc1ff;\n    }\n\n    a.point {\n        color: #3bc1ff;\n        cursor: pointer;\n        text-decoration: none;\n    }\n\n    .ant-checkbox-wrapper {\n        margin-bottom: 0px !important;\n    }\n`;\n\nconst Alert = styled.p`\n    margin-bottom: 0px;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 12px;\n    line-height: 20px;\n    letter-spacing: -0.15px;\n    color: #ff5500;\n`;","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\n\nconst CardStyledContainer = styled.div`\n\n    @media (max-width: 480px) {\n        min-height: initial;\n        height: 100%;\n        padding-bottom: 0px;\n        padding-top: 5px;\n    }\n\n    .inner-container {\n        padding-bottom: 0px;\n        padding-top: 0px;\n\n        @media (max-width: 480px) {\n            padding: 0px;\n        }\n\n        .profile-form {\n\n            .title-wrapper {\n                display: flex;\n                justify-content: flex-start;\n                margin-bottom: 16px;\n\n                p {\n                    flex: 1;\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    line-height: 48px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                }\n\n                span {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: right;\n                    color: ${mainColor};\n                }\n            }\n\n            .form {\n                label {\n                    font-size: ${sizeHandler(12)};\n                    letter-spacing: -0.15px;\n                    line-height: 20px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 4px;\n                }\n\n                input {\n                    height: 44px;\n                    border: solid 1px #e6e6e6;\n                    padding: 10px;\n\n                    &.ant-input {\n                        font-size: 16px;\n                        line-height: 28px;\n                        letter-spacing: -0.2px;\n                        color: rgba(0, 0, 0, 0.7);\n\n                        &::placeholder {\n                            font-size: 14px;\n                        }\n                    }\n                }\n\n                .type-button-wrapper {\n                    width: 100%;\n                    height: 48px;\n\n                    background-color: white;\n                    border: 1px solid #e6e6e6;\n                    border-radius: 4px;\n\n                    display: flex;\n                    align-items: center;\n\n                    > .type-button {\n                        width: 50%;\n                        height: 100%;\n                        line-height: 48px;\n\n                        text-align: center;\n                        cursor: pointer;\n\n                        font-size: 16px;\n                        letter-spacing: -0.2px;\n                        color: rgba(0, 0, 0, 0.2);\n                    }\n\n                    > .type-button.active {\n                        background: rgba(0, 0, 0, 0.7);\n                        border-radius: 4px;\n                        color: #f9f9f9;\n                    }\n                }\n\n                button {\n                    width: 100%;\n                    height: 46px;\n                    margin-top: 4px;\n                    margin-bottom: 16px;\n\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    letter-spacing: -0.2px;\n                    text-align: center;\n                    color: #ffffff;\n                }\n\n                .link-wrapper {\n                    display: flex;\n                    justify-content: center;\n                    margin-bottom: 8px;\n                    .text {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: rgba(0, 0, 0, 0.7);\n                        line-height: 21px;\n                    }\n\n                    .link {\n                        cursor: pointer;\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: ${mainColor};\n\n                        margin-left: 8px;\n                    }\n                }\n            }\n\n            .form-user-type {\n                height: 36px;\n                margin-bottom: 20px;\n                border-radius: 4px;\n                border: 1px solid #e6e6e6;\n                display: flex;\n                align-items: center;\n                overflow: hidden;\n\n                .type {\n                    flex: 1;\n                    height: 100%;\n                    line-height: 36px;\n                    background-color: #ffffff;\n                    cursor: pointer;\n\n                    &:first-child {\n                        border-right: 1px solid #e6e6e6;\n                    }\n\n                    p {\n                        font-size: ${sizeHandler(12)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #606060;\n                    }\n\n                    &.active {\n                        background-color: #606060;\n\n                        p {\n                            color: #ffffff;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .ant-upload-drag-container {\n        .title {\n            margin-top: 12px;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: rgba(0, 0, 0, 0.8);\n        }\n\n        .reco {\n            font-size: ${sizeHandler(12)};\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: #a7a7a7;\n        }\n    }\n`;\n\nexport default CardStyledContainer;","import React from 'react';\nimport Modal from 'react-modal';\nimport styled from 'styled-components';\nimport { notification, Select, message } from 'antd';\n\nimport { DivisionLine, WithmateSelect, WithmateInput, WithmateLabel } from '../../../../Components/Common/input';\nimport { HalfWidthButton } from '../../../../Components/Common/button';\nimport CardStyledContainer from './card.styled';\n\nconst customStyles = {\n    overlay: {\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: 'rgba(15, 15, 15, 0.79)',\n    },\n    content: {\n        position: 'absolute',\n        top: '30px',\n        width: '350px',\n        height: '37%',\n        border: '1px solid #ccc',\n        background: '#ffffff',\n        overflow: 'auto',\n        WebkitOverflowScrolling: 'touch',\n        borderRadius: '4px',\n        outline: 'none',\n        padding: '20px',\n    },\n};\n\nclass NewProfileComponent extends React.PureComponent {\n    state = {\n        modalInfo: '',\n        modalTitle: '',\n    };\n\n    onEdit = ({ type, value }) => {\n        this.props.editAddCardForm({ type, value });\n    };\n\n    onCard = () => {\n        const { cardName, cardNum, year, month } = this.props.auth.addCardForm;\n\n        if (!cardName) {\n            return message.warning('카드명을 입력하세요');\n        }\n\n        if (!cardNum) {\n            return message.warning('카드번호를 입력하세요');\n        }\n\n        if (!year) {\n            return message.warning('유효 연도를 선택하세요');\n        }\n\n        if (!month) {\n            return message.warning('유효 월을 선택하세요');\n        }\n\n        this.props\n            .addCard({\n                id: this.props.auth.id,\n                userName: this.props.auth.name,\n                cardName,\n                cardNum,\n                year,\n                month,\n            })\n            .then(resolve => {\n                // console.log(resolve)\n                if (resolve.message === 'success') {\n                    this.props.onClose();\n                    this.onEdit({ type: 'clear', value: '' });\n                    notification.open({\n                        message: '결제카드 등록이 완료되었습니다.',\n                        description: '등록된 결제카드정보로 서비스 이용결제시 편리하게 이용하실 수 있습니다.',\n                        type: 'success',\n                    });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    formCompleteStatus = () => {\n        let valid = true;\n        if (!this.props.auth || !this.props.auth.addCardForm) return false;\n\n        const { cardName, cardNum, year, month } = this.props.auth.addCardForm;\n        if (!cardName) valid = false;\n        if (!cardNum) valid = false;\n        if (!year) valid = false;\n        if (!month) valid = false;\n\n        return valid;\n    };\n\n    render() {\n        // console.log(this.props.auth);\n        const { addCardForm } = this.props.auth;\n        const status = this.formCompleteStatus();\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <CardStyledContainer>\n                    <div className='inner-container'>\n                        <div className='profile-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>결제카드정보 등록</WideModalTitle>\n                                </TitleSection>\n\n                                <br />\n\n                                <WithmateLabel required>결제 카드사</WithmateLabel>\n                                <WithmateSelect\n                                    name='cardName'\n                                    placeholder='카드사를 선택하세요'\n                                    value={addCardForm.cardName || undefined}\n                                    onChange={value => {\n                                        this.onEdit({ type: 'cardName', value });\n                                    }}\n                                >\n                                    <Select.Option value='KB국민카드'>KB국민카드</Select.Option>\n                                    <Select.Option value='삼성카드'>삼성카드</Select.Option>\n                                    <Select.Option value='현대카드'>현대카드</Select.Option>\n                                    <Select.Option value='우리카드'>우리카드</Select.Option>\n                                    <Select.Option value='BC카드'>BC카드</Select.Option>\n                                    <Select.Option value='신한카드'>신한카드</Select.Option>\n                                    <Select.Option value='롯데카드'>롯데카드</Select.Option>\n                                    <Select.Option value='NH농협카드'>NH농협카드</Select.Option>\n                                </WithmateSelect>\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>카드번호</WithmateLabel>\n                                <WithmateInput\n                                    type='phone'\n                                    placeholder='11자리 또는 12자리의 카드번호를 입력하세요'\n                                    value={addCardForm.cardNum || ''}\n                                    maxLength='19'\n                                    onChange={ev => {\n                                        this.onEdit({\n                                            type: 'cardNum',\n                                            value: ev.target.value\n                                                .replace(/[^0-9]/g, '')\n                                                .replace(/^(\\d{0,4})(\\d{0,4})(\\d{0,4})(\\d{0,4})$/g, '$1-$2-$3-$4')\n                                                .replace(/(\\-{1,2})$/g, ''),\n                                        });\n                                    }}\n                                />\n                                <DivisionLine />\n\n                                <WithmateLabel required>유효기간(MM/YY)</WithmateLabel>\n                                <YMWrapper withHalf>\n                                    <div style={{ flex: 1 }}>\n                                        <WithmateSelect\n                                            style={{ width: '150px' }}\n                                            placeholder='MM'\n                                            value={addCardForm.month || undefined}\n                                            onChange={value => {\n                                                this.onEdit({ type: 'month', value });\n                                            }}\n                                        >\n                                            <Select.Option value='1'>1</Select.Option>\n                                            <Select.Option value='2'>2</Select.Option>\n                                            <Select.Option value='3'>3</Select.Option>\n                                            <Select.Option value='4'>4</Select.Option>\n                                            <Select.Option value='5'>5</Select.Option>\n                                            <Select.Option value='6'>6</Select.Option>\n                                            <Select.Option value='7'>7</Select.Option>\n                                            <Select.Option value='8'>8</Select.Option>\n                                            <Select.Option value='9'>9</Select.Option>\n                                            <Select.Option value='10'>10</Select.Option>\n                                            <Select.Option value='11'>11</Select.Option>\n                                            <Select.Option value='12'>12</Select.Option>\n                                        </WithmateSelect>\n                                    </div>\n                                    <div style={{ flex: 1 }}>\n                                        <WithmateInput\n                                            style={{ width: '150px' }}\n                                            type='text'\n                                            placeholder='YY'\n                                            maxLength='2'\n                                            value={addCardForm.year || ''}\n                                            onChange={ev => {\n                                                this.onEdit({ type: 'year', value: ev.target.value });\n                                            }}\n                                        />\n                                    </div>\n                                </YMWrapper>\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ marginRight: '8px', color: '#afb0b2' }} bg='#e6e6e6' onClick={this.props.onClose}>\n                                        닫기\n                                    </HalfWidthButton>\n                                    <HalfWidthButton\n                                        style={{ margin: '0 auto' }}\n                                        bg='#3bc1ff'\n                                        onClick={() => {\n                                            this.onCard();\n                                        }}\n                                        style={!status ? { backgroundColor: '#E6E6E6', border: 0, cursor: 'not-allowed' } : {}}\n                                    >\n                                        카드정보 등록\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n                            </div>\n                        </div>\n                    </div>\n                </CardStyledContainer>\n            </Modal>\n        );\n    }\n}\n\nexport default NewProfileComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst YMWrapper = styled.div`\n    display: flex;\n    align-items: center;\n\n    ${props =>\n        props.withHalf\n            ? `\n        > div, p {\n            width: calc(50% - 4px) !important;\n            margin-right: 8px;\n        }\n    `\n            : ''}\n\n    > div:last-child {\n        margin-right: 0px;\n    }\n`;\n","import React from 'react';\nimport Modal from 'react-modal';\nimport styled from 'styled-components';\nimport { Select, message } from 'antd';\n\nimport { DivisionLine, WithmateSelect, WithmateInput, WithmateLabel } from '../../../../Components/Common/input';\nimport { HalfWidthButton } from '../../../../Components/Common/button';\nimport CardStyledContainer from './card.styled';\nimport { modifyCard } from '../../../../Lib/Api/auth';\n\nconst customStyles = {\n    overlay: {\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: 'rgba(15, 15, 15, 0.79)',\n    },\n    content: {\n        position: 'absolute',\n        top: '30px',\n        width: '350px',\n        height: '37%',\n        border: '1px solid #ccc',\n        background: '#ffffff',\n        overflow: 'auto',\n        WebkitOverflowScrolling: 'touch',\n        borderRadius: '4px',\n        outline: 'none',\n        padding: '20px',\n    },\n};\n\nclass ModifyProfileComponent extends React.PureComponent {\n    state = {\n        modalInfo: '',\n        modalTitle: '',\n        cardId: '',\n        cardInfo: null,\n    };\n\n    componentWillUnmount = () => {\n        this.setState({ cardInfo: null });\n    };\n\n    componentDidUpdate = (prevState, prevProps) => {\n        if (!this.state.cardInfo && JSON.stringify(prevProps) !== JSON.stringify(this.props)) {\n            this.setState({ cardInfo: this.props });\n        }\n        if (JSON.stringify(prevProps) !== JSON.stringify(this.props) && !this.props._id) {\n            this.setState({ cardInfo: null });\n        }\n    };\n\n    onEdit = ({ type, value }) => {\n        this.setState(prevState => ({\n            cardInfo: {\n                ...prevState.cardInfo,\n                [type]: value,\n            },\n        }));\n    };\n\n    onCard = () => {\n        const { cardInfo } = this.state;\n        const { cardName, cardNum, year, month } = cardInfo;\n\n        if (!cardName) {\n            return message.warning('카드명을 입력하세요');\n        }\n\n        if (!cardNum) {\n            return message.warning('카드번호를 입력하세요');\n        }\n\n        if (!year) {\n            return message.warning('유효 연도를 선택하세요');\n        }\n\n        if (!month) {\n            return message.warning('유효 월을 선택하세요');\n        }\n\n        const info = { cardName, cardNum, year, month };\n\n        modifyCard({ cardId: cardInfo._id, info })\n            .then(resolve => {\n                if (resolve && resolve.data === 'success') {\n                    message.success('등록된 카드정보를 변경하였습니다.');\n                    this.props.onClose();\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    render() {\n        if (!this.state.cardInfo) {\n            return <div></div>;\n        }\n\n        const { cardInfo } = this.state;\n\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <CardStyledContainer>\n                    <div className='inner-container'>\n                        <div className='profile-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>결제카드정보 수정</WideModalTitle>\n                                </TitleSection>\n\n                                <br />\n\n                                <WithmateLabel required>결제 카드사</WithmateLabel>\n                                <WithmateSelect\n                                    name='cardName'\n                                    placeholder='카드사를 선택하세요'\n                                    value={cardInfo.cardName || undefined}\n                                    onChange={value => {\n                                        this.onEdit({ type: 'cardName', value });\n                                    }}\n                                >\n                                    <Select.Option value='KB국민카드'>KB국민카드</Select.Option>\n                                    <Select.Option value='삼성카드'>삼성카드</Select.Option>\n                                    <Select.Option value='현대카드'>현대카드</Select.Option>\n                                    <Select.Option value='우리카드'>우리카드</Select.Option>\n                                    <Select.Option value='BC카드'>BC카드</Select.Option>\n                                    <Select.Option value='신한카드'>신한카드</Select.Option>\n                                    <Select.Option value='롯데카드'>롯데카드</Select.Option>\n                                    <Select.Option value='NH농협카드'>NH농협카드</Select.Option>\n                                </WithmateSelect>\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>카드번호</WithmateLabel>\n                                <WithmateInput\n                                    type='phone'\n                                    placeholder='11자리 또는 12자리의 카드번호를 입력하세요'\n                                    value={cardInfo.cardNum || ''}\n                                    maxLength='19'\n                                    onChange={ev => {\n                                        this.onEdit({\n                                            type: 'cardNum',\n                                            value: ev.target.value\n                                                .replace(/[^0-9]/g, '')\n                                                .replace(/^(\\d{0,4})(\\d{0,4})(\\d{0,4})(\\d{0,4})$/g, '$1-$2-$3-$4')\n                                                .replace(/(\\-{1,2})$/g, ''),\n                                        });\n                                    }}\n                                />\n                                <DivisionLine />\n\n                                <WithmateLabel required>유효기간(MM/YY)</WithmateLabel>\n                                <YMWrapper withHalf>\n                                    <div style={{ flex: 1 }}>\n                                        <WithmateSelect\n                                            style={{ width: '150px' }}\n                                            placeholder='MM'\n                                            value={cardInfo.month || ''}\n                                            onChange={value => {\n                                                this.onEdit({ type: 'month', value });\n                                            }}\n                                        >\n                                            <Select.Option value='1'>1</Select.Option>\n                                            <Select.Option value='2'>2</Select.Option>\n                                            <Select.Option value='3'>3</Select.Option>\n                                            <Select.Option value='4'>4</Select.Option>\n                                            <Select.Option value='5'>5</Select.Option>\n                                            <Select.Option value='6'>6</Select.Option>\n                                            <Select.Option value='7'>7</Select.Option>\n                                            <Select.Option value='8'>8</Select.Option>\n                                            <Select.Option value='9'>9</Select.Option>\n                                            <Select.Option value='10'>10</Select.Option>\n                                            <Select.Option value='11'>11</Select.Option>\n                                            <Select.Option value='12'>12</Select.Option>\n                                        </WithmateSelect>\n                                    </div>\n                                    <div style={{ flex: 1 }}>\n                                        <WithmateInput\n                                            style={{ width: '150px' }}\n                                            type='text'\n                                            placeholder='YY'\n                                            maxLength='2'\n                                            value={cardInfo.year || ''}\n                                            onChange={ev => {\n                                                this.onEdit({ type: 'year', value: ev.target.value });\n                                            }}\n                                        />\n                                    </div>\n                                </YMWrapper>\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ marginRight: '8px', color: '#afb0b2' }} bg='#e6e6e6' onClick={this.props.onClose}>\n                                        닫기\n                                    </HalfWidthButton>\n                                    <HalfWidthButton\n                                        style={{ margin: '0 auto' }}\n                                        bg='#3bc1ff'\n                                        onClick={() => {\n                                            this.onCard();\n                                        }}\n                                    >\n                                        카드정보 수정\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n                            </div>\n                        </div>\n                    </div>\n                </CardStyledContainer>\n            </Modal>\n        );\n    }\n}\n\nexport default ModifyProfileComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst YMWrapper = styled.div`\n    display: flex;\n    align-items: center;\n\n    ${props =>\n        props.withHalf\n            ? `\n        > div, p {\n            width: calc(50% - 4px) !important;\n            margin-right: 8px;\n        }\n    `\n            : ''}\n\n    > div:last-child {\n        margin-right: 0px;\n    }\n`;\n","import React from \"react\";\nimport Modal from \"react-modal\";\nimport styled from 'styled-components';\nimport { Button, Checkbox, notification, Select, message, Radio } from 'antd';\n\nimport { DivisionLine, WithmateSelect, WithmateInput, WithamteInputWithButton, WithmateLabel } from \"../../../../Components/Common/input\";\nimport { HalfWidthButton } from '../../../../Components/Common/button';\nimport ProfileStyledContainer from \"./profile.styled\";\nimport { modifyPatient } from \"../../../../Lib/Api/auth\";\nimport { MobileBr } from \"../../../Guide/guide.styled\";\n\nconst customStyles = {\n\n    overlay: {\n        position: \"fixed\",\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: \"rgba(15, 15, 15, 0.79)\",\n    },\n    content: {\n        position: \"absolute\",\n        top: \"30px\",\n        height: \"90%\",\n        border: \"1px solid #ccc\",\n        background: \"#ffffff\",\n        overflow: \"auto\",\n        WebkitOverflowScrolling: \"touch\",\n        borderRadius: \"4px\",\n        outline: \"none\",\n        padding: \"20px\",\n    },\n}\n\nclass ModifyProfileComponent extends React.PureComponent {\n    state = {\n        modalInfo: '',\n        modalTitle: '',\n        patientId: '',\n        patientInfo: null\n    };\n\n    componentWillUnmount = () => {\n        this.setState({ patientInfo: null });\n    };\n\n    componentDidUpdate = (prevState, prevProps) => {\n        if (!this.state.patientInfo && JSON.stringify(prevProps) !== JSON.stringify(this.props)) {\n            this.setState({ patientInfo: this.props })\n        }\n        if (JSON.stringify(prevProps) !== JSON.stringify(this.props) && !this.props._id) {\n            this.setState({ patientInfo: null })\n        }\n    }\n\n    onEdit = ({ type, value }) => {\n        this.setState(prevState => ({\n            patientInfo: {\n                ...prevState.patientInfo,\n                [type]: value,\n            }\n        }));\n    };\n\n    onStarting = () => {\n        new window.daum.Postcode({\n            oncomplete: data => {\n                const { sido, sigungu, bname, roadAddress, buildingName } = data;\n                this.onEdit({ type: 'shortStarting', value: `${sido} ${sigungu} ${bname}` });\n                this.onEdit({ type: 'starting', value: `${roadAddress} (${ buildingName })` });\n            },\n        }).open();\n    };\n\n    onProfile = () => {\n        const { patientInfo } = this.state;\n        const {\n            name,\n            relate,\n            sex,\n            age,\n            contact,\n            starting,\n            environment,\n            caution\n        } = patientInfo;\n\n        if (!name) {\n            return message.warning('성함을 입력해주세요.');\n        }\n\n        if (!relate) {\n            return message.warning('관계를 선택해주세요.');\n        }\n\n        if (!sex) {\n            return message.warning('성별을 선택해주세요.');\n        }\n\n        if (!age || age.length > 3) {\n            return message.warning('나이를 입력해주세요.');\n        }\n\n        if (!contact) {\n            return message.warning('연락처를 입력해주세요.');\n        }\n\n        if (!starting) {\n            return message.warning('주소(자택, 출발지)를 입력해주세요.');\n        }\n\n        if (!environment) {\n            return message.warning('거주환경을 입력해주세요.');\n        }\n\n        if (!caution) {\n            return message.warning('기타 불편한 사항(시력)을 입력해주세요.');\n        }\n\n        if (name.length > 15) return message.info('이름이 너무 깁니다. 이름은 15자 이내로 설정해주세요.');\n\n        const info = {\n            name, relate, sex, age, contact, starting, environment, caution\n        }\n\n        modifyPatient({ patientId: patientInfo._id, info })\n            .then(resolve => {\n                // console.log(resolve)\n                if (resolve && resolve.data === 'success') {\n                    message.success('환자 프로필 정보를 변경하였습니다.')\n                    this.props.onClose();\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    }\n\n    render() {\n        if (!this.state.patientInfo) {\n            return <div></div>;\n        }\n\n        const { patientInfo } = this.state;\n\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <ProfileStyledContainer>\n                    <div className='inner-container'>\n                        <div className='profile-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>환자 프로필 수정</WideModalTitle>\n                                    <AlertText>\n                                        * 환자 프로필 정보를 수정할 수 있습니다.\n                                    </AlertText>\n                                </TitleSection>\n\n                                <br />\n\n                                <WithmateLabel required>환자 이름</WithmateLabel>\n                                <WithmateInput\n                                    type='email'\n                                    placeholder='ex. 홍길동'\n                                    value={patientInfo.name}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'name', value: ev.target.value.trim() });\n                                    }}\n                                />\n\n                                <DivisionLine small />\n\n                                <WithmateLabel required>본인-환자 간 관계</WithmateLabel>\n                                <WithmateSelect\n                                    name='relate'\n                                    style={{ height: '48px', width: '100%' }}\n                                    placeholder='환자 프로필을 등록하는 대상의 관계를 선택해주세요.'\n                                    value={patientInfo.relate || undefined}\n                                    onChange={value => {\n                                        this.onEdit({ type: 'relate', value });\n                                    }}\n                                >\n                                    <Select.Option value='본인'>본인</Select.Option>\n                                    <Select.Option value='부모'>부모</Select.Option>\n                                    <Select.Option value='자매'>자매</Select.Option>\n                                    <Select.Option value='친구'>친구</Select.Option>\n                                    <Select.Option value='지인'>지인</Select.Option>\n                                    <Select.Option value='기타'>기타</Select.Option>\n                                </WithmateSelect>\n\n                                <DivisionLine small />\n\n                                <WithmateLabel required>{patientInfo.name}님 성별</WithmateLabel>\n                                <div className='type-button-wrapper'>\n                                    <div\n                                        className={`type-button ${patientInfo.sex && patientInfo.sex === '남자' ? 'active' : ''}`}\n                                        onClick={() => {\n                                            this.onEdit({ type: 'sex', value: '남자' });\n                                        }}\n                                    >\n                                        남자\n                                    </div>\n                                    <div\n                                        className={`type-button ${patientInfo.sex && patientInfo.sex === '여자' ? 'active' : ''}`}\n                                        onClick={() => {\n                                            this.onEdit({ type: 'sex', value: '여자' });\n                                        }}\n                                    >\n                                        여자\n                                    </div>\n                                </div>\n\n                                <DivisionLine small />\n\n                                <WithmateLabel required>{patientInfo.name}님 나이</WithmateLabel>\n                                <WithmateInput\n                                    type='number'\n                                    maxLength='2'\n                                    placeholder=''\n                                    name='age'\n                                    suffix='세'\n                                    value={patientInfo.age}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'age', value: ev.target.value.trim() });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>{patientInfo.name}님 연락처</WithmateLabel>\n                                <WithmateInput\n                                    name='contact'\n                                    type='text'\n                                    maxLength={11}\n                                    placeholder='숫자만 입력해주세요.(ex. 01012345678)'\n                                    value={patientInfo.contact}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'contact', value: ev.target.value.trim() });\n                                    }}\n                                />\n\n                                <DivisionLine />\n\n                                <WithmateLabel required>{patientInfo.name}님의 주소(자택 혹은 출발지)를 입력해주세요.</WithmateLabel>\n                                <WithamteInputWithButton\n                                    inputConfig={{\n                                        type: 'text',\n                                        placeholder: 'ex) 서울특별시 도산대로  40, OO 아파트',\n                                        name: 'starting',\n                                        disabled: true,\n                                        value: patientInfo.starting\n                                    }}\n                                    buttonName='검색'\n                                    onButton={() => { this.onStarting() }}\n                                />\n                                <DivisionLine />\n\n                                <WithmateLabel required>메이트가 {patientInfo.name}님은 외출하실 때 '꼭' 계단을 이용하셔야 하나요?</WithmateLabel>\n                                <Radio\n                                    checked={patientInfo.environment === '네'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'environment', value: '네' });\n                                    }}\n                                >\n                                    네\n                                </Radio>\n                                <Radio checked={patientInfo.environment === '아니요, 엘레베이터가 있어요'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'environment', value: '아니요, 엘레베이터가 있어요' })\n                                    }}\n                                >\n                                    아니요, 엘레베이터가 있어요\n                                </Radio>\n                                <Radio checked={patientInfo.environment === '1층이라 괜찮아요'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'environment', value: '1층이라 괜찮아요' })\n                                    }}\n                                >\n                                    1층이라 괜찮아요\n                                </Radio>\n                                <DivisionLine />\n                            \n                                <WithmateLabel required>메이트가 {patientInfo.name}님과 동행할 때 주의해야 할 점이 있을까요?</WithmateLabel>\n                                <WithmateInput\n                                    type='text'\n                                    placeholder='동행시 주의사항을 입력하세요.'\n                                    value={patientInfo.caution || ''}\n                                    onChange={ev => {\n                                        this.onEdit({ type: 'caution', value: ev.target.value });\n                                    }}\n                                />\n                                <Checkbox checked={patientInfo.caution === '없어요'}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'caution', value: '없어요' })\n                                    }}\n                                >\n                                    없어요\n                                </Checkbox>\n\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ marginRight: '8px', color: '#afb0b2' }} bg='#e6e6e6'\n                                        onClick={this.props.onClose}\n                                    >\n                                        닫기\n                                    </HalfWidthButton>\n                                    <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff'\n                                        onClick={(e) => {\n                                            e.preventDefault();\n                                            e.stopPropagation();\n                                            this.onProfile()\n                                        }}\n                                    >\n                                        프로필 수정\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n\n                                <MobileBr />\n                            </div>\n                        </div>\n                    </div>\n                </ProfileStyledContainer >\n            </Modal >\n        );\n    }\n};\n\nexport default ModifyProfileComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst AlertText = styled.div`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.52;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n`;","import React from 'react';\nimport { DeleteOutlined, EditOutlined } from \"@ant-design/icons\"\n\n\nexport const patientColumn = ({ onModify, onDelete }) => {\n    return [\n        {\n            title: '번호',\n            dataIndex: 'index',\n            align: 'center',\n            width: '58px',\n        },\n        {\n            title: '이름',\n            dataIndex: 'name',\n            align: 'center'\n        },\n        {\n            title: '나이',\n            dataIndex: 'age',\n            align: 'center'\n        },\n        {\n            title: '수정',\n            dataIndex: 'valid',\n            align: 'center',\n            width: '58px',\n            render: (valid, info) =>\n                <EditOutlined\n                    onClick={(e) => {\n                        e.preventDefault();\n                        e.stopPropagation();\n\n                        onModify(info);\n                    }}\n                />\n        },\n        {\n            title: '삭제',\n            dataIndex: 'createdAt',\n            align: 'center',\n            width: '58px',\n            render: (createdAt, { _id }) =>\n                <DeleteOutlined\n                    onClick={(e) => {\n                        console.log('_id: ', _id)\n                        e.preventDefault();\n                        e.stopPropagation();\n\n                        onDelete({ _id });\n                    }}\n                />\n        },\n    ]\n}\n\nexport const cardColumn = ({ onModify, onDelete }) => {\n    return [\n        {\n            title: '번호',\n            dataIndex: 'index',\n            align: 'center',\n            width: '58px',\n        },\n        {\n            title: '카드명',\n            dataIndex: 'cardName',\n            align: 'center'\n        },\n        {\n            title: '카드번호',\n            dataIndex: 'cardNum',\n            align: 'center',\n            render: cardNum => <span>**** - **** - **** - {cardNum.slice(15, 19)}</span>\n        },\n        {\n            title: '수정',\n            dataIndex: 'valid',\n            align: 'center',\n            width: '58px',\n            render: (valid, info) =>\n                <EditOutlined\n                    onClick={(e) => {\n                        e.preventDefault();\n                        e.stopPropagation();\n\n                        onModify(info);\n                    }}\n                />\n        },\n        {\n            title: '삭제',\n            dataIndex: 'createdAt',\n            align: 'center',\n            width: '58px',\n            render: (createdAt, { _id }) =>\n                <DeleteOutlined\n                    onClick={(e) => {\n                        console.log('_id: ', _id)\n                        e.preventDefault();\n                        e.stopPropagation();\n\n                        onDelete({ _id });\n                    }}\n                />\n        },\n    ]\n};","import React from 'react';\nimport styled from 'styled-components';\nimport { Table, Input, notification, Upload, Button, message, Modal, Select, DatePicker, Collapse, InputNumber, Radio } from 'antd';\nimport moment from 'moment';\nimport _ from 'lodash';\nimport StarRatingComponent from 'react-star-rating-component';\nimport swal from 'sweetalert2';\nimport { DeleteOutlined, EditOutlined } from '@ant-design/icons';\nimport Pallete from '../../../../theme';\n\n// components\nimport { InputFilter, ReserveList } from '../../../../Components/User/Normal/auth';\nimport { UserStatistics } from '../../../../Components/User/Normal/statistics';\nimport { UserNavigation } from '../../../../Components/User/Normal/navi';\nimport { NoramlReserveEditModal, ReportMoal, NoReportModal } from '../../../../Components/newModal';\nimport {\n    PointBoxRow,\n    PointBox,\n    PointBox2,\n    PointBox3,\n    NoHistory,\n    PointBoxTitle,\n    PointTotal,\n    PointHistoryRow,\n    PointHistoryNameRow,\n    PointContent,\n    PointHistoryValueRow,\n} from './normal.styled';\n\n// utils\nimport axios from '../../../../Lib/axios';\nimport { UNEMER, ASSIST, LOCAL } from '../../../../Lib/variables';\nimport { datetimeFormatter, timeFormatter, currencyFormatter, getWithcarPrice } from '../../../../Lib/utils';\nimport Profile from '../Profile/profile';\nimport Card from '../Card/card';\nimport ModifyCard from '../Card/cardInfoCheck';\nimport ModifyProfile from '../Profile/profileInfoCheck';\nimport { DivisionLine, WithmateInput, WithmateLabel } from '../../../../Components/Common/input';\nimport { patientColumn, cardColumn } from '../../../../Components/Columns/normal';\nimport { HalfWidthButton } from '../../../../Components/Common/button';\n\nconst { Kakao } = window;\n\nmoment.lang('ko', {\n    weekdays: ['일요일', '월요일', '화요일', '수요일', '목요일', '금요일', '토요일'],\n    weekdaysShort: ['일', '월', '화', '수', '목', '금', '토'],\n});\n\nclass NormalUser extends React.PureComponent {\n    state = {\n        active: 'list', // list, info, point\n        reservedFilter: 'none', // none, reserved, matched, complete\n        paidFilter: 'none', // none, paid, refund\n        modal: false,\n        kakaoModal: false,\n        selected: null,\n        cancelModal: false,\n        modifyModal: false,\n        detailModalPage: 1,\n        reserveDetailModal: false,\n        mateModal: false,\n        mateInfo: {},\n        serviceInfo: null,\n        serviceStatus: null,\n        serviceModal: false,\n        keyword: '',\n        addHalfTime: false,\n        totalPro: 0,\n        totalBasic: 0,\n        pointUsingHistory: [],\n        pointAddHistory: [],\n        couponAddHistory: [],\n\n        patientModal: false,\n        patientModifyModal: false,\n        patientInfo: {},\n        patientId: '',\n\n        cardModal: false,\n        cardModifyModal: false,\n        cardInfo: {},\n        cardId: '',\n\n        appointedCode: '',\n    };\n\n    patientModalOff = () => {\n        const userId = localStorage.getItem('id');\n        this.props.fetchPatient({ id: userId });\n        this.setState({\n            patientModal: false,\n            patientInfo: {},\n        });\n    };\n\n    patientModifyModalOff = () => {\n        const userId = localStorage.getItem('id');\n        this.props.fetchPatient({ id: userId });\n        this.setState({\n            patientModifyModal: false,\n            patientInfo: {},\n        });\n    };\n\n    cardModalOff = () => {\n        const userId = localStorage.getItem('id');\n        this.props.fetchCard({ id: userId });\n        this.setState({\n            cardModal: false,\n            cardInfo: {},\n        });\n    };\n\n    cardModifyModalOff = () => {\n        const userId = localStorage.getItem('id');\n        this.props.fetchCard({ id: userId });\n        this.setState({\n            cardModifyModal: false,\n            cardInfo: {},\n        });\n    };\n\n    componentDidMount = () => {\n        this.syncStep();\n        this.fetchUserInfo();\n    };\n\n    componentDidUpdate = (prevProps, prevState) => {\n        if (prevState.active !== this.state.active) {\n            this.props.history.push(`/user/mypage/${this.state.active}`);\n        }\n    };\n\n    syncStep = () => {\n        const { params } = this.props.match;\n        const { active } = this.state;\n\n        if (params.tab && active !== params.tab) {\n            this.setState({ active: params.tab });\n        } else if (!params.tab) {\n            this.props.history.push(`/user/mypage/list`);\n        }\n    };\n\n    fetchUserInfo = () => {\n        const { userType, id } = this.props.auth;\n        // 예약이력\n        axios.get('/v2/service/user/reserve/list', { params: { userId: id } }).then(resolve => {\n            const { data } = resolve;\n            if (data && Array.isArray(data)) {\n                this.setState({\n                    reserves: data,\n                    totalPro: data.filter(d => d && d.service === UNEMER).length,\n                    totalBasic: data.filter(d => d && d.service === ASSIST).length,\n                });\n            }\n        });\n        // 사용자 포인트\n        axios.get('/v2/user/point/history', { params: { userId: id } }).then(resolve => {\n            const { data } = resolve;\n            if (data && Array.isArray(data)) {\n                this.setState({\n                    pointUsingHistory: data.filter(d => d && d.actionType === 'use'),\n                    pointAddHistory: data.filter(d => d && d.actionType === 'add'),\n                });\n            }\n        });\n        // 사용자 쿠폰\n        axios.get('/v2/user/coupon/history', { params: { userId: id } }).then(resolve => {\n            const { data } = resolve;\n            if (data && Array.isArray(data)) {\n                this.setState({\n                    couponAddHistory: data.filter(d => d && d.actionType === 'add'),\n                });\n            }\n        });\n    };\n\n    updateBasicInfo = () => {\n        const { id, userType } = this.props.auth;\n        const { userInfo } = this.props.app;\n        const { name, contact } = userInfo;\n\n        if (!name || !contact) return message.info('필수정보인 이름과 연락처를 입력해주세요.');\n        if (name.length > 15) return message.info('이름이 너무 깁니다. 이름은 15자 이내로 설정해주세요.');\n\n        const info = { name, contact };\n\n        this.props.modify({ id, userType, info }).then(resolve => {\n            if (resolve && resolve.name) {\n                message.success('정보를 업데이트 하였습니다.');\n                localStorage.setItem('name', resolve.name);\n                this.props.editAuth({ type: 'name', value: resolve.name });\n                this.props.editAuth({ type: 'contact', value: resolve.contact });\n            }\n        });\n    };\n\n    modifyPassword = () => {\n        const { passwordForm, id, userType } = this.props.auth;\n        const { password, newPassword, reNewPassword } = passwordForm;\n\n        if (password === newPassword) return message.info('새 비밀번호는 기존 비밀번호와 달라야합니다.');\n        if (reNewPassword !== newPassword) return message.info('새 비밀번호를 확인해주세요.');\n\n        this.props\n            .modifyPassword({ id, userType, password, newPassword })\n            .then(resolve => {\n                if (resolve && resolve === 'wrong password') {\n                    return message.error('비밀번호가 일치하지 않습니다.');\n                }\n\n                if (resolve && resolve === 'not exist') {\n                    message.error('유효하지 않은 계정입니다. 다시 로그인해주세요.');\n                    return this.props.history.push('/user/logout');\n                }\n\n                if (resolve && resolve === 'success') {\n                    message.success('비밀번호를 변경하였습니다.');\n                    this.props.editPassword({ type: 'clear', value: '' });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    withdrawl = () => {\n        const { id, userType, password } = this.props.auth;\n\n        if (!password) return message.info('비밀번호를 입력해주세요.');\n\n        this.props\n            .withdrawlUser({ id, userType, password })\n            .then(resolve => {\n                if (resolve && resolve === 'wrong password') {\n                    return message.info('잘못된 비밀번호입니다.');\n                }\n\n                if (resolve && resolve === 'success') {\n                    message.info('회원탈퇴를 완료하였습니다. 이용해주셔서 감사합니다.');\n                    this.setState({ modal: false });\n                    setTimeout(() => {\n                        this.props.history.push('/user/logout');\n                    }, 500);\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    tabHandler = type => {\n        this.setState({ active: type });\n    };\n\n    onMateModal = async info => {\n        const { data } = await axios.get('/v2/user/mate/info/detail', {\n            params: {\n                mateId: info.mateId,\n            },\n        });\n\n        this.setState({\n            mateInfo: data,\n            callStatus: info.status,\n            callId: info.callId,\n            reserveId: info.reserveId,\n            mateModal: true,\n            modifyModal: false,\n            reserveDetailModal: false,\n            cancelModal: false,\n        });\n    };\n\n    // 요거 진행해야함\n    onRematch = async () => {\n        const { reserveId, callId } = this.state;\n\n        const { data } = await axios.put('/v2/service/deny/mate/call', {\n            callId,\n            reserveId,\n        });\n\n        if (data === 'check parameters') {\n            return message.warning('요청하신 정보가 올바르지 않습니다. 새로고침 후 다시 시도해주세요.');\n        }\n\n        if (data === 'no mate') {\n            return console.warn('현재 예약 신청항 메이트가 없습니다.');\n        }\n\n        if (data === 'invalid call') {\n            return message.warning('접수내역에 문제가 발생하였습니다. 새로고침 후 다시 시도해주세요.');\n        }\n\n        if (data === 'already matched') {\n            return message.warning('이미 메이트 매칭이 완료되었습니다.');\n        }\n\n        if (data === 'do not') {\n            return message.warning('해당 예약은 메이트 거절 불가한 상태입니다.');\n        }\n\n        if (data === 'success') {\n            message.success('요청완료하였습니다.');\n            setTimeout(() => {\n                window.location.reload();\n            }, 1000);\n        }\n    };\n\n    confirmReserve = () => {\n        const { callId, reserveId } = this.state;\n        const { id } = this.props.auth;\n\n        axios\n            .put('/v2/service/allow/mate/call', {\n                callId,\n                reserveId,\n            })\n            .then(resolve => {\n                const { data } = resolve;\n                if (data === 'check parameters') {\n                    return message.warning('요청하신 정보가 올바르지 않습니다. 새로고침 후 다시 시도해주세요.');\n                }\n                if (data === 'invalid call') {\n                    return message.warning('유효하지않은 접수내역입니다. 새로고침 후 다시 시도해주세요.');\n                }\n                if (data === 'no mate') {\n                    return console.warn('아직 접수 요청중인 메이트가 없습니다. 문제가 계속되면 고객센터로 문의해주세요.');\n                }\n                if (data === 'wrong status') {\n                    return message.warning('해당 예약이 메이트 확정가능한 상태가 아닙니다.');\n                }\n                if (data === 'issue call') {\n                    return message.warning('예약에 문제가 발생했습니다. 고객센터로 문의해주세요.');\n                }\n                if (data === 'success') {\n                    message.success('메이트 확정 완료');\n                    setTimeout(() => {\n                        window.location.reload();\n                    }, 250);\n                }\n            });\n    };\n\n    onDetailModal = reserveId => {\n        const { userType, id } = this.props.auth;\n\n        axios.get('/v2/service/user/reserve/info', { params: { userId: id, reserveId } }).then(resolve => {\n            const { data } = resolve;\n            if (!data) return message.error('죄송합니다. 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n            if (data === 'invalid reserve') return message.warning('유효하지않은 예약입니다.');\n\n            this.setState({\n                reserveDetailModal: true,\n                temp: {\n                    ...data,\n                    disabled: true,\n                    addTime: data.usageTime * 60 + '분',\n                    date: moment(data.reserveDate),\n                    time: moment(data.reserveDate).format('HH').toString(),\n                    minute: moment(data.reserveDate).format('mm').toString(),\n                    meetDate: data.meetDate ? moment(data.meetDate) : '',\n                    meetTime: data.meetDate ? moment(data.meetDate).format('HH').toString() : '',\n                    meetMinute: data.meetDate ? moment(data.meetDate).format('mm').toString() : '',\n                },\n            });\n        });\n    };\n\n    inputHandler = ({ type, value }) => {\n        this.setState({ [type]: value });\n    };\n\n    inputDeepHandler = ({ type, deepType, value }) => {\n        this.setState(prevState => ({\n            [type]: {\n                ...prevState[type],\n                [deepType]: value,\n            },\n        }));\n    };\n\n    onViewReport = item => {\n        const { call } = item;\n        if (!call.reportId) {\n            message.warning('죄송합니다. 아직 담당 메이트가 리포트를 등록하지 않았습니다.');\n            return null;\n        }\n        axios.get('/v2/review/report/viewer', { params: { reportId: call.reportId, callId: call._id } }).then(resolve => {\n            const { data } = resolve;\n\n            this.setState({\n                report: data.report,\n                timeline: data.timeline,\n                selectedServiceName:\n                    item.productInfo.name + (item.productInfo.name.includes('내시경') ? '' : item.service === 'unemergency' ? ' Pro' : ' Basic'),\n                onReportMoal: true,\n            });\n        });\n    };\n\n    onPatientModal = () => {\n        this.setState({ patientModal: true });\n    };\n\n    onPatientModifyModal = () => {\n        this.setState({ patientModifyModal: true });\n    };\n\n    onCardModal = () => {\n        this.setState({ cardModal: true });\n    };\n\n    onCardModifyModal = () => {\n        this.setState({ cardModifyModal: true });\n    };\n\n    onRow = row => {\n        return {\n            onClick: async () => {\n                // const info = await this.onFetchPatientInfo(row);\n                // console.log(row)\n                swal.fire({\n                    title: '환자 프로필 정보',\n                    icon: 'info',\n                    width: '550px',\n                    html: `\n                    <br/>\n                    <div align=\"left\">\n                        <p><b>ㆍ이름 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.name}</p>\n                        <p><b>ㆍ관계 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.relate}</p>\n                        <p><b>ㆍ성별 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.sex}</p>\n                        <p><b>ㆍ나이 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.age} 세</p>\n                        <p><b>ㆍ연락처 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.contact}</p>\n                        <p><b>ㆍ주소 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.starting}</p>\n                        <p><b>ㆍ계단 이용 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.environment}</p>\n                        <p><b>ㆍ메이트 주의사항 : </b>&nbsp;&nbsp;&nbsp;&nbsp;${row.caution}</p>\n                    </div>\n                    `,\n                });\n            },\n        };\n    };\n\n    onFetchPatientInfo = async row => {\n        console.log(row);\n        return axios.get('/v1/auth/patient/list/info', { params: { userId: row.userId, patientId: row._id } });\n    };\n\n    onPatientModify = info => {\n        this.setState({ patientModifyModal: true, patientInfo: info });\n        // console.log(info)\n    };\n\n    onPatientDelete = ({ _id }) => {\n        const { id } = this.props.auth;\n        console.log('_id: ', _id);\n\n        const confirmed = window.confirm('해당 환자 프로필을 삭제하시겠습니까?');\n        if (!confirmed) return null;\n\n        this.props\n            .deletePatient({ patientId: _id })\n            .then(resolve => {\n                if (resolve && resolve === 'success') {\n                    const userId = localStorage.getItem('id');\n                    this.props.fetchPatient({ id: userId });\n                    notification.open({\n                        message: '환자 프로필을 삭제하였습니다.',\n                        description: '환자 프로필을 삭제하였습니다.',\n                        type: 'success',\n                    });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    onCardModify = info => {\n        this.setState({ cardModifyModal: true, cardInfo: info });\n        // console.log(info)\n    };\n\n    onCardDelete = ({ _id }) => {\n        const { id } = this.props.auth;\n        console.log('_id: ', _id);\n\n        const confirmed = window.confirm('해당 카드정보를 삭제하시겠습니까?');\n        if (!confirmed) return null;\n\n        this.props\n            .deleteCard({ cardId: _id })\n            .then(resolve => {\n                if (resolve && resolve === 'success') {\n                    const userId = localStorage.getItem('id');\n                    this.props.fetchCard({ id: userId });\n                    notification.open({\n                        message: '카드정보를 삭제하였습니다.',\n                        description: '카드정보를 삭제하였습니다.',\n                        type: 'success',\n                    });\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    // kakao api unlink\n    kakaoUnlink = () => {\n        const { id, userType } = this.props.auth;\n\n        window.Kakao.API.request({\n            url: '/v1/user/unlink',\n            success: function (response) {\n                console.log(response, 'kakao api unlink!');\n                // window.location.href = '/user/logout'\n            },\n            fail: function (error) {\n                console.log(error, 'kakao api unlink error');\n            },\n        });\n\n        this.props\n            .withdrawlKakao({ id, userType })\n            .then(resolve => {\n                if (resolve && resolve === 'success') {\n                    notification.open({\n                        message: '회원탈퇴를 완료하였습니다.',\n                        description: '그동안 위드메이트의 서비스를 이용해주셔서 감사합니다.',\n                        type: 'success',\n                    });\n                    this.setState({ kakaoModal: false });\n                    setTimeout(() => {\n                        this.props.history.push('/user/logout');\n                    }, 500);\n                }\n            })\n            .catch(error => {\n                message.error('서버장애가 발생하였습니다. 관리자에게 문의해주세요.');\n            });\n    };\n\n    onAddCoupon = async () => {\n        const { appointedCode } = this.state;\n        if (!appointedCode) {\n            // notification.open({\n            //     message: '쿠폰 코드가 입력되지 않았습니다',\n            //     description: '쿠폰 코드를 입력해주세요',\n            //     type: 'warning',\n            // });\n        }\n\n        if (appointedCode) {\n            const { data } = await axios.post('/v2/user/add/coupon', {\n                userId: this.props.auth.id,\n                userName: this.props.auth.name,\n                appointedCode,\n                info: {\n                    couponName: '',\n                    couponValue: '',\n                },\n            });\n\n            if (!data || data === 'check parameters') {\n                notification.open({\n                    message: '쿠폰 코드 등록에 실패하였습니다',\n                    description: '다시 한번 쿠폰 코드를 입력해주세요',\n                    type: 'warning',\n                });\n            }\n\n            if (data === 'wrong access') {\n                notification.open({\n                    message: '쿠폰 코드가 일치하지 않습니다',\n                    description: '입력하신 쿠폰 코드를 다시한번 확인하세요',\n                    type: 'warning',\n                });\n            }\n\n            if (data === 'duplicate') {\n                notification.open({\n                    message: '이미 등록된 쿠폰 코드입니다',\n                    description: '다른 쿠폰 코드를 입력해주세요',\n                    type: 'warning',\n                });\n            }\n\n            if (data === 'success') {\n                notification.open({\n                    message: '쿠폰 코드가 등록되었습니다',\n                    description: '포인트가 정상적으로 지급되었습니다',\n                    type: 'success',\n                });\n                setTimeout(() => {\n                    window.location.reload();\n                }, 250);\n            }\n        }\n    };\n\n    handleChange = e => {\n        this.setState({ [e.target.title]: e.target.value });\n    };\n\n    render() {\n        // console.log(this.props.auth)\n        const { auth } = this.props;\n        const { password, newPassword, reNewPassword } = auth.passwordForm;\n        const { userInfo } = this.props.app;\n        // console.log(userInfo)\n        const { pointUsingHistory, pointAddHistory, couponAddHistory, active, reservedFilter, reserves, mateInfo, keyword, totalPro, totalBasic } = this.state;\n\n        // console.log(auth);\n        const list = keyword\n            ? reserves.filter(reserve => {\n                  const { call } = reserve;\n\n                  return (\n                      (reserve && reserve.reserveCode && reserve.reserveCode.toLowerCase().includes(keyword.toLowerCase())) ||\n                      (call && call.mate && call.mate.toLowerCase().includes(keyword.toLowerCase()))\n                  );\n              })\n            : reserves;\n\n        return (\n            <div className='auth-container'>\n                <div className='navigation-container'>\n                    <div className='inner-container'>\n                        <UserStatistics auth={auth} pro={totalPro || 0} basic={totalBasic || 0} />\n                        <UserNavigation\n                            active={active}\n                            tabHandler={this.tabHandler}\n                            onPatientModal={this.onPatientModal}\n                            onPatientModifyModal={this.onPatientModifyModal}\n                            onCardModal={this.onCardModal}\n                            onCardModifyModal={this.onCardModifyModal}\n                        />\n                    </div>\n                </div>\n\n                <div className='usage-info-container'>\n                    <div className='inner-container'>\n                        {active === 'list' ? (\n                            <>\n                                <div className='filter-wrapper'>\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='none'\n                                        name='전체'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'none' });\n                                        }}\n                                    />\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='reserved'\n                                        name='접수대기'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'reserved' });\n                                        }}\n                                    />\n\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='matched'\n                                        name='예약완료 (진행중)'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'matched' });\n                                        }}\n                                    />\n                                    <Filter\n                                        filter={reservedFilter}\n                                        value='complete'\n                                        name='서비스 종료'\n                                        onClick={() => {\n                                            this.setState({ reservedFilter: 'complete' });\n                                        }}\n                                    />\n                                </div>\n\n                                <InputFilter\n                                    keyword={this.state.keyword}\n                                    keywordHandler={value => {\n                                        this.setState({ keyword: value });\n                                    }}\n                                />\n                                <ReserveList\n                                    list={\n                                        reservedFilter === 'none'\n                                            ? list\n                                            : reservedFilter === 'reserved'\n                                            ? list.filter(p => p.call.status === '접수대기' || p.call.status === '예약접수')\n                                            : reservedFilter === 'matched'\n                                            ? list.filter(\n                                                  p =>\n                                                      p.call.status === '예약완료' ||\n                                                      p.call.status === '접선' ||\n                                                      p.call.status === '병원 출발' ||\n                                                      p.call.status === '병원 도착' ||\n                                                      p.call.status === '진료 시작' ||\n                                                      p.call.status === '진료 종료' ||\n                                                      p.call.status === '자택 출발',\n                                              )\n                                            : reservedFilter === 'complete'\n                                            ? list.filter(p => p.call.status === '서비스 종료')\n                                            : []\n                                    }\n                                    onReport={this.onViewReport}\n                                    onDetailModal={_id => {\n                                        this.onDetailModal(_id);\n                                    }}\n                                    onMateModal={info => {\n                                        this.onMateModal(info);\n                                    }}\n                                />\n                            </>\n                        ) : null}\n\n                        {active === 'info' ? (\n                            <div className='user-info-wrapper'>\n                                <div>\n                                    <div className='default-info wrapper'>\n                                        <div className='title-wrapper'>\n                                            <p>프로필 수정</p>\n                                            <p style={{ fontSize: '7px', fontWeight: 'normal', color: 'gray', marginTop: '5px' }}>\n                                                위드메이트의 이름과 연락처를 수정 하실 수 있습니다.\n                                            </p>\n                                        </div>\n\n                                        <div className='service'>\n                                            <p className='info'>이름</p>\n                                            <div>\n                                                <Input\n                                                    placeholder='성함을 입력해주세요.'\n                                                    value={userInfo.name}\n                                                    onChange={ev => {\n                                                        this.props.onEdit({ type: 'name', value: ev.target.value });\n                                                    }}\n                                                />\n                                            </div>\n                                        </div>\n\n                                        <div className='service'>\n                                            <p className='info'>연락처</p>\n                                            <div>\n                                                <Input\n                                                    placeholder='연락처를 입력해주세요.'\n                                                    value={userInfo.contact}\n                                                    onChange={ev => {\n                                                        this.props.onEdit({ type: 'contact', value: ev.target.value });\n                                                    }}\n                                                />\n                                            </div>\n                                        </div>\n\n                                        <div className='service' style={{ marginBottom: '0px' }}>\n                                            <Button onClick={this.updateBasicInfo} style={{ backgroundColor: '#484848' }}>\n                                                수정된 프로필 저장\n                                            </Button>\n                                        </div>\n                                    </div>\n\n                                    <div className='card-info wrapper'>\n                                        <div className='title-wrapper'>\n                                            <p>결제 카드 정보</p>\n                                            <p style={{ fontSize: '7px', fontWeight: 'normal', color: 'gray', marginTop: '5px' }}>\n                                                등록된 카드정보를 통해 서비스 결제를 하실 수 있습니다.\n                                            </p>\n                                        </div>\n\n                                        <Card {...this.props} visible={this.state.cardModal} onClose={this.cardModalOff} />\n                                        <ModifyCard {...this.state.cardInfo} visible={this.state.cardModifyModal} onClose={this.cardModifyModalOff} />\n\n                                        <Table\n                                            dataSource={this.props.auth.cardList}\n                                            columns={cardColumn({ onDelete: this.onCardDelete, onModify: this.onCardModify })}\n                                            pagination={{ pageSize: 3 }}\n                                        />\n\n                                        <div className='service' style={{ marginBottom: '0px' }}>\n                                            <Button onClick={this.onCardModal} style={{ backgroundColor: '#484848' }}>\n                                                카드 정보 추가\n                                            </Button>\n                                        </div>\n                                    </div>\n\n                                    {/* 수정해야할 부분 - KAKAO 로그인인 경우 안보이게*/}\n                                    {this.props.auth.type === LOCAL ? (\n                                        <div className='privacy-info wrapper'>\n                                            <div className='title-wrapper'>\n                                                <p>비밀번호 변경</p>\n                                            </div>\n\n                                            <div className='service'>\n                                                <p className='info'>현재 비밀번호</p>\n                                                <div>\n                                                    <Input.Password\n                                                        password='true'\n                                                        placeholder='현재 비밀번호를 입력해주세요.'\n                                                        value={password}\n                                                        onChange={ev => {\n                                                            this.props.editPassword({ type: 'password', value: ev.target.value });\n                                                        }}\n                                                    />\n                                                </div>\n                                            </div>\n\n                                            <div className='service'>\n                                                <p className='info'>새 비밀번호</p>\n                                                <div>\n                                                    <Input.Password\n                                                        password='true'\n                                                        placeholder='새 비밀번호를 입력해주세요.'\n                                                        value={newPassword}\n                                                        onChange={ev => {\n                                                            this.props.editPassword({ type: 'newPassword', value: ev.target.value });\n                                                        }}\n                                                    />\n                                                </div>\n                                            </div>\n\n                                            <div className='service'>\n                                                <p className='info'>새 비밀번호 확인</p>\n                                                <div>\n                                                    <Input.Password\n                                                        password='true'\n                                                        placeholder='새 비밀번호를 확인해주세요.'\n                                                        value={reNewPassword}\n                                                        onChange={ev => {\n                                                            this.props.editPassword({ type: 'reNewPassword', value: ev.target.value });\n                                                        }}\n                                                    />\n                                                </div>\n                                            </div>\n\n                                            <div className='service'>\n                                                <Button\n                                                    onClick={this.modifyPassword}\n                                                    style={{ backgroundColor: '#ffffff', color: '#606060', marginBottom: '0px' }}\n                                                >\n                                                    비밀번호 변경\n                                                </Button>\n                                            </div>\n                                        </div>\n                                    ) : (\n                                        <div className='etc-info wrapper' style={{ marginTop: '0px' }}>\n                                            <div className='title-wrapper'>\n                                                <p>기타</p>\n                                            </div>\n\n                                            <div className='service'>\n                                                <div className='flex-wrapper'>\n                                                    <p\n                                                        onClick={() => {\n                                                            this.props.history.push('/policy/privacy');\n                                                        }}\n                                                    >\n                                                        개인정보 처리방침 <b>{'>'}</b>\n                                                    </p>\n                                                    <p\n                                                        onClick={() => {\n                                                            this.props.history.push('/policy/terms');\n                                                        }}\n                                                    >\n                                                        서비스 이용약관 <b>{'>'}</b>\n                                                    </p>\n                                                </div>\n                                            </div>\n\n                                            <div className='service'>\n                                                <Button\n                                                    style={{ backgroundColor: '#b7b7b7' }}\n                                                    onClick={() => {\n                                                        this.props.history.push('/user/logout');\n                                                    }}\n                                                >\n                                                    로그아웃\n                                                </Button>\n                                            </div>\n\n                                            <div className='service' style={{ marginBottom: '0px' }}>\n                                                {this.props.auth.type === LOCAL ? (\n                                                    <Button\n                                                        onClick={() => {\n                                                            this.setState({ modal: true });\n                                                        }}\n                                                        style={{ color: '#a7a7a7', height: '30px' }}\n                                                    >\n                                                        회원탈퇴\n                                                    </Button>\n                                                ) : (\n                                                    <Button\n                                                        onClick={() => {\n                                                            this.setState({ kakaoModal: true });\n                                                        }}\n                                                        style={{ color: '#a7a7a7', height: '30px' }}\n                                                    >\n                                                        카카오 회원탈퇴\n                                                    </Button>\n                                                )}\n                                            </div>\n                                        </div>\n                                    )}\n                                    <div className='clearfix' />\n                                </div>\n                                {this.props.auth.type === LOCAL ? (\n                                    <div>\n                                        <div className='etc-info wrapper'>\n                                            <div className='title-wrapper'>\n                                                <p>기타</p>\n                                            </div>\n\n                                            <div className='service'>\n                                                <div className='flex-wrapper'>\n                                                    <p\n                                                        onClick={() => {\n                                                            this.props.history.push('/policy/privacy');\n                                                        }}\n                                                    >\n                                                        개인정보 처리방침 <b>{'>'}</b>\n                                                    </p>\n                                                    <p\n                                                        onClick={() => {\n                                                            this.props.history.push('/policy/terms');\n                                                        }}\n                                                    >\n                                                        서비스 이용약관 <b>{'>'}</b>\n                                                    </p>\n                                                </div>\n                                            </div>\n\n                                            <div className='service'>\n                                                <Button\n                                                    style={{ backgroundColor: '#b7b7b7' }}\n                                                    onClick={() => {\n                                                        this.props.history.push('/user/logout');\n                                                    }}\n                                                >\n                                                    로그아웃\n                                                </Button>\n                                            </div>\n\n                                            <div className='service' style={{ marginBottom: '0px' }}>\n                                                {this.props.auth.type === LOCAL ? (\n                                                    <Button\n                                                        onClick={() => {\n                                                            this.setState({ modal: true });\n                                                        }}\n                                                        style={{ color: '#a7a7a7', height: '30px' }}\n                                                    >\n                                                        회원탈퇴\n                                                    </Button>\n                                                ) : (\n                                                    <Button\n                                                        onClick={() => {\n                                                            this.setState({ kakaoModal: true });\n                                                        }}\n                                                        style={{ color: '#a7a7a7', height: '30px' }}\n                                                    >\n                                                        카카오 회원탈퇴\n                                                    </Button>\n                                                )}\n                                            </div>\n                                        </div>\n                                        <div className='clearfix' />\n                                    </div>\n                                ) : null}\n                            </div>\n                        ) : null}\n\n                        {active === 'point' && (\n                            <>\n                                <PointBoxRow>\n                                    <PointBox>\n                                        <PointBoxTitle>현재 잔여 포인트</PointBoxTitle>\n                                        <PointTotal>{userInfo.point ? currencyFormatter(userInfo.point) : 0} 원</PointTotal>\n                                    </PointBox>\n                                </PointBoxRow>\n                                <PointBoxRow>\n                                    <PointBox3>\n                                        <PointBoxTitle>포인트 적립 내역</PointBoxTitle>\n                                        {pointAddHistory && pointAddHistory.length > 0 ? (\n                                            <PointContent>\n                                                {pointAddHistory.map((item, index) => (\n                                                    <PointHistoryRow key={'add-point-' + index.toString()}>\n                                                        <PointHistoryNameRow add>\n                                                            <span className='title'>{item.name}</span>\n                                                            <span className='value'>+ {currencyFormatter(item.value)} 원</span>\n                                                        </PointHistoryNameRow>\n                                                        <PointHistoryValueRow>\n                                                            <span className='title'>{moment(item.addedAt).format('YY년 M월 D일 HH:mm')}</span>\n                                                            <span className='value'>잔여 포인트 {currencyFormatter(item.leftValue)} 원</span>\n                                                        </PointHistoryValueRow>\n                                                    </PointHistoryRow>\n                                                ))}\n                                            </PointContent>\n                                        ) : (\n                                            <NoHistory>내역 없음</NoHistory>\n                                        )}\n                                    </PointBox3>\n                                    <PointBox3>\n                                        <PointBoxTitle>포인트 사용 내역</PointBoxTitle>\n                                        {pointUsingHistory && pointUsingHistory.length > 0 ? (\n                                            <PointContent style={{ paddingRight: '10px' }}>\n                                                {pointUsingHistory.map((item, index) => (\n                                                    <PointHistoryRow key={'using-point-' + index.toString()}>\n                                                        <PointHistoryNameRow>\n                                                            <span className='title'>{item.name}</span>\n                                                            <span className='value'>- {currencyFormatter(item.value)} 원</span>\n                                                        </PointHistoryNameRow>\n                                                        <PointHistoryValueRow>\n                                                            <span className='title'>{moment(item.usedAt).format('YY년 M월 D일 HH:mm')}</span>\n                                                            <span className='value'>잔여 포인트 {currencyFormatter(item.leftValue)} 원</span>\n                                                        </PointHistoryValueRow>\n                                                    </PointHistoryRow>\n                                                ))}\n                                            </PointContent>\n                                        ) : (\n                                            <NoHistory>내역 없음</NoHistory>\n                                        )}\n                                    </PointBox3>\n                                </PointBoxRow>\n                                <PointBoxRow>\n                                    <PointBox2>\n                                        <PointBoxTitle>쿠폰 등록</PointBoxTitle>\n                                        <CouponInput\n                                            placeholder='쿠폰 번호를 입력하세요'\n                                            title='appointedCode'\n                                            value={this.state.appointedCode}\n                                            onChange={this.handleChange}\n                                        />\n                                        <Button\n                                            style={{\n                                                margin: '0 auto',\n                                                width: '100px',\n                                                height: '45px',\n                                                backgroundColor: '#3bc1ff',\n                                                color: 'white',\n                                                fontWeight: 'bold',\n                                            }}\n                                            onClick={() => {\n                                                this.onAddCoupon();\n                                            }}\n                                        >\n                                            등록\n                                        </Button>\n\n                                        <DivisionLine />\n                                        <DivisionLine />\n                                        <DivisionLine />\n\n                                        <PointBoxTitle>쿠폰 사용 내역</PointBoxTitle>\n                                        {couponAddHistory && couponAddHistory.length > 0 ? (\n                                            <PointContent style={{ paddingRight: '10px' }}>\n                                                {couponAddHistory.map((item, index) => (\n                                                    <PointHistoryRow key={'add-coupon-' + index.toString()}>\n                                                        <PointHistoryNameRow add>\n                                                            <span className='title'>{item.couponName}</span>\n                                                            <span className='value'>+ {currencyFormatter(item.couponValue)} P</span>\n                                                        </PointHistoryNameRow>\n                                                        <PointHistoryValueRow>\n                                                            <span className='title'>{moment(item.addedAt).format('YY년 M월 D일 HH:mm')}</span>\n                                                        </PointHistoryValueRow>\n                                                    </PointHistoryRow>\n                                                ))}\n                                            </PointContent>\n                                        ) : (\n                                            <NoHistory>사용 내역 없음</NoHistory>\n                                        )}\n                                    </PointBox2>\n                                </PointBoxRow>\n                            </>\n                        )}\n\n                        {active === 'profile' ? (\n                            <div className='user-profile-wrapper'>\n                                <div>\n                                    <div className='default-profile wrapper'>\n                                        <div className='title-wrapper'>\n                                            <p>환자 프로필 목록</p>\n                                            <p style={{ fontSize: '12px', fontWeight: 'normal', color: 'gray', marginTop: '5px' }}>\n                                                위드메이트 서비스를 사용하시는 프로필을 관리할 수 있습니다.\n                                            </p>\n                                            <div className='service' style={{ display: 'flex', justifyContent: 'right' }}>\n                                                <Button onClick={this.onPatientModal} style={{ backgroundColor: '#3bc1ff', borderRadius: '5px' }}>\n                                                    프로필 등록\n                                                </Button>\n\n                                                <Profile {...this.props} visible={this.state.patientModal} onClose={this.patientModalOff} />\n                                                <ModifyProfile\n                                                    {...this.state.patientInfo}\n                                                    visible={this.state.patientModifyModal}\n                                                    onClose={this.patientModifyModalOff}\n                                                />\n                                            </div>\n                                        </div>\n\n                                        <div className='profileList'>\n                                            <Table\n                                                dataSource={this.props.auth.patientList}\n                                                columns={patientColumn({ onDelete: this.onPatientDelete, onModify: this.onPatientModify })}\n                                                onRow={this.onRow}\n                                                pagination={{\n                                                    pageSize: 5,\n                                                }}\n                                            />\n                                        </div>\n                                    </div>\n\n                                    <div className='clearfix' />\n                                </div>\n                            </div>\n                        ) : null}\n                    </div>\n                </div>\n\n                {this.state.reserveDetailModal && (\n                    <NoramlReserveEditModal\n                        visible={this.state.reserveDetailModal}\n                        visibleHandler={() => {\n                            this.setState({ temp: null, reserveDetailModal: false });\n                        }}\n                        data={this.state.temp}\n                        inputDeepHandler={this.inputDeepHandler}\n                    />\n                )}\n\n                {this.state.onReportMoal && (\n                    <ReportMoal\n                        visible={this.state.onReportMoal}\n                        visibleHandler={() => {\n                            this.setState({\n                                report: null,\n                                timeline: null,\n                                onReportMoal: false,\n                                selectedServiceName: '',\n                            });\n                        }}\n                        data={{\n                            report: this.state.report,\n                            timeline: this.state.timeline,\n                            selectedServiceName: this.state.selectedServiceName,\n                        }}\n                    />\n                )}\n\n                <Modal\n                    visible={this.state.modal}\n                    title='회원탈퇴'\n                    footer={null}\n                    onCancel={() => {\n                        this.setState({ modal: false });\n                    }}\n                >\n                    <DivisionLine />\n\n                    <p>\n                        <b>* 회원탈퇴 전, 유의사항을 확인해 주시기 바랍니다.</b> <DivisionLine />\n                        - 회원탈퇴 시 위드메이트 서비스 이용이 불가합니다. <br />\n                        - 회원탈퇴 후 회원 정보 및 이용 기록은 모두 삭제되며, <br /> &nbsp;&nbsp;복구 가능하지 않습니다.\n                    </p>\n\n                    <DivisionLine />\n\n                    <label>\n                        <b>* 비밀번호</b>\n                    </label>\n                    <Input.Password\n                        style={{ height: '36px', marginBottom: '20px' }}\n                        password='true'\n                        placeholder='회원탈퇴를 위해 비밀번호를 입력해주세요.'\n                        value={auth.password}\n                        onChange={ev => {\n                            this.props.editAuth({ type: 'password', value: ev.target.value });\n                        }}\n                    />\n                    <br />\n\n                    <div style={{ display: 'flex' }}>\n                        <Button\n                            style={{ flex: 1, marginRight: '8px', height: '40px' }}\n                            type='danger'\n                            onClick={() => {\n                                this.setState({ modal: false });\n                            }}\n                        >\n                            취소\n                        </Button>\n                        <Button style={{ flex: 1, height: '40px' }} type='primary' onClick={this.withdrawl}>\n                            확인\n                        </Button>\n                    </div>\n                </Modal>\n\n                <Modal\n                    visible={this.state.kakaoModal}\n                    title='카카오 회원탈퇴'\n                    footer={null}\n                    onCancel={() => {\n                        this.setState({ modal: false });\n                    }}\n                >\n                    <DivisionLine />\n\n                    <p>\n                        <b>* 회원탈퇴 전, 유의사항을 확인해 주시기 바랍니다.</b> <DivisionLine />\n                        - 회원탈퇴 시 위드메이트 서비스 이용이 불가합니다. <br />\n                        - 회원탈퇴 후 회원 정보 및 이용 기록은 모두 삭제되며, <br /> &nbsp;&nbsp;복구 가능하지 않습니다.\n                    </p>\n                    <DivisionLine />\n                    <label>\n                        <b>카카오 계정 회원 탈퇴를 하시겠습니까 ?</b>\n                    </label>\n                    <DivisionLine />\n                    <div style={{ display: 'flex' }}>\n                        <Button\n                            style={{ flex: 1, marginRight: '8px', height: '40px' }}\n                            type='danger'\n                            onClick={() => {\n                                this.setState({ kakaoModal: false });\n                            }}\n                        >\n                            취소\n                        </Button>\n                        <Button style={{ flex: 1, height: '40px' }} type='primary' onClick={this.kakaoUnlink}>\n                            확인\n                        </Button>\n                    </div>\n                </Modal>\n\n                <Modal\n                    visible={this.state.mateModal}\n                    title='담당 메이트 정보'\n                    footer={null}\n                    onCancel={() => {\n                        this.setState({ mateModal: false });\n                    }}\n                >\n                    <div className='mate-img-wrapper'>\n                        <img src={mateInfo && mateInfo.mate ? mateInfo.mate.photo : '사진이 제공되지 않았습니다.'} alt='mate' />\n                    </div>\n                    <div className='mate-info-wrapper'>\n                        <div>\n                            <p className='label'>이름</p>\n                            <div className='input'>\n                                <p className='value'>{mateInfo && mateInfo.mate ? mateInfo.mate.name : ''}</p>\n                            </div>\n                        </div>\n                        <div>\n                            <p className='label'>연락처</p>\n                            <div className='input'>\n                                <p className='value'>{mateInfo && mateInfo.mate ? mateInfo.mate.contact : ''}</p>\n                            </div>\n                        </div>\n                        <div>\n                            <p className='label'>Pro 서비스 이력</p>\n                            <div className='input'>\n                                <p className='value'>{(mateInfo && mateInfo.review && mateInfo.review.unemergency) || 0}건</p>\n                            </div>\n                        </div>\n                        <div>\n                            <p className='label'>Basic 서비스 이력</p>\n                            <div className='input'>\n                                <p className='value'>{(mateInfo && mateInfo.review && mateInfo.review.assist) || 0}건</p>\n                            </div>\n                        </div>\n                        {mateInfo && mateInfo.review ? (\n                            <div>\n                                <p className='label'>동행 서비스 이행 평점</p>\n                                <StarRatingComponent\n                                    starCount={5}\n                                    value={(mateInfo.review && mateInfo.review.score) || 4}\n                                    renderStarIcon={(index, value) => {\n                                        return (\n                                            <img\n                                                style={{ width: '24px', height: '23px', marginRight: '8px' }}\n                                                src={`/assets/images/icon_${index <= value ? 'active_star' : 'star'}.png`}\n                                            />\n                                        );\n                                    }}\n                                    onStarClick={() => {}}\n                                />\n                            </div>\n                        ) : null}\n                        <Button\n                            type='primary'\n                            onClick={() => {\n                                if (mateInfo && this.state.callStatus === '예약접수') {\n                                    this.confirmReserve();\n                                } else {\n                                    this.setState({ mateModal: false });\n                                }\n                            }}\n                        >\n                            {mateInfo && this.state.callStatus === '예약접수' ? '예약 및 메이트 확정하기' : '확인'}\n                        </Button>\n                        {mateInfo && this.state.callStatus === '예약접수' ? (\n                            <Button style={{ marginTop: '12px' }} onClick={this.onRematch}>\n                                메이트 거절 및 재배정\n                            </Button>\n                        ) : null}\n                    </div>\n                </Modal>\n            </div>\n        );\n    }\n}\nexport default NormalUser;\n\nconst Filter = ({ filter, value, onClick, name }) => {\n    return (\n        <span className={`filter ${filter === value ? 'active' : ''}`} onClick={onClick}>\n            {name}\n        </span>\n    );\n};\n\nconst PanelHead = styled.p`\n    font-size: 14px;\n    font-weight: 600;\n    line-height: 24px;\n    height: 24px;\n    color: rgba(0, 0, 0, 0.7);\n    margin: 0px;\n    padding: 0px;\n`;\n\nconst AddTimeSelector = styled.div`\n    display: flex;\n    flex-wrap: wrap;\n\n    min-height: 60px;\n\n    > span {\n        margin-right: 8px;\n        margin-bottom: 6px;\n\n        display: inline-block;\n\n        padding-left: 12px;\n        padding-right: 12px;\n        height: 24px;\n        line-height: 24px;\n\n        font-size: 12px;\n        text-align: center;\n\n        background-color: #dedede;\n        color: #ffffff;\n\n        border-radius: 10px;\n        white-space: nowrap;\n        cursor: pointer;\n\n        @media (min-width: 768px) {\n            &:hover {\n                transition: all 0.5s;\n                background-color: #3bc1ff;\n            }\n        }\n\n        &.active {\n            background-color: #3bc1ff;\n        }\n    }\n`;\n\nconst CouponInput = styled(Input)`\n    width: 100%;\n    height: 46px;\n    line-height: 44px;\n    ${props => props.small && `max-width: 102px; height: 32px; line-height: 29px;`}\n\n    margin-bottom: 0px;\n\n    color: ${Pallete.dark100};\n    font-size: 14px;\n    font-weight: normal;\n\n    border-radius: 4px;\n    border: 1px solid ${Pallete.dark50} !important;\n    background-color: #ffffff;\n\n    @media (max-width: 480px) {\n        font-size: 12px;\n        border: 1px solid ${Pallete.dark50} !important;\n    }\n\n    &.ant-input {\n        width: 65%;\n        height: 45px;\n        line-height: 44px;\n\n        margin-bottom: 0px;\n\n        color: ${Pallete.dark100};\n        font-size: 14px;\n        font-weight: normal;\n\n        border-radius: 4px;\n        border: 1px solid ${Pallete.dark50} !important;\n        background-color: #ffffff;\n\n        &::placeholder {\n            color: ${Pallete.dark60};\n            font-size: 14px;\n            font-weight: normal;\n        }\n\n        @media (max-width: 480px) {\n            font-size: 12px;\n            border: 1px solid ${Pallete.dark50} !important;\n\n            &::placeholder {\n                font-size: 12px;\n            }\n        }\n    }\n\n    &:focus {\n        border: 1px solid ${Pallete.blue100} !important;\n        transition: all 0.3s;\n        box-shadow: none;\n        outline: 0;\n    }\n\n    &:disabled {\n        background-color: ${Pallete.dark10};\n    }\n\n    &.ant-input-affix-wrapper-disabled {\n        background-color: #f5f5f5;\n    }\n\n    &.ant-input-affix-wrapper {\n        height: 46px;\n        line-height: 43px;\n        padding: 0px 11px;\n\n        ${props => props.small && `max-width: 102px; height: 32px; line-height: 29px;`}\n\n        .ant-input {\n            width: 100% !important;\n            height: 100%;\n            line-height: 43px;\n\n            color: ${Pallete.dark100};\n            font-size: 14px;\n            font-weight: normal;\n\n            border: 0px !important;\n            &::placeholder {\n                color: ${Pallete.dark60};\n                font-size: 14px;\n                font-weight: normal;\n            }\n\n            &:focus {\n                border: 1px solid ${Pallete.blue100} !important;\n                transition: all 0.3s;\n                box-shadow: none;\n                outline: 0;\n            }\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n                line-height: 43px;\n\n                &:focus {\n                    border: 1px solid ${Pallete.dark50} !important;\n                }\n\n                &::placeholder {\n                    font-size: 12px;\n                }\n            }\n            &:disabled {\n                background-color: ${Pallete.dark10};\n            }\n        }\n\n        .ant-input-suffix {\n            font-size: 14px;\n            font-weight: normal;\n            font-stretch: normal;\n            text-align: right;\n            color: ${Pallete.dark100};\n\n            @media (max-width: 480px) {\n                font-size: 12px;\n            }\n        }\n    }\n`;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledNormalContainer from './normal.styled';\nimport Normal from './normal';\nimport { USER } from '../../../../Lib/variables';\nimport {\n    // getPayHistory,\n    // getReserveUsage,\n    // getReserveList,\n    getUserInfo,\n    editUserForm,\n    modifyUserInfo,\n    cancelReserve,\n    modifyReserve,\n} from '../../../../Reducer/Modules/app';\nimport { editAuth, editPasswordForm, modifyPassword, withdrawlUser, withdrawlKakao,\n    editAddPatientForm, addPatient, fetchPatient, deletePatient, modifyPatient, getPatientInfo, \n    fetchCard, editAddCardForm, addCard, getCardInfo, modifyCard, deleteCard, checkCouponCode } from '../../../../Reducer/Modules/auth';\n\nclass NormalPage extends React.PureComponent {\n    componentDidMount = () => {\n        const userId = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n        const type = localStorage.getItem('type');\n\n        if (userId) {\n            if (userType !== USER) {\n                window.location.href = '/';\n            } else {\n                this.props.getUserInfo({ id: userId, userType, type });\n                this.props.fetchPatient({ id: userId });\n                this.props.fetchCard({ id: userId });\n            }\n        } else {\n            this.props.history.push('/user/login');\n        }\n    };\n\n    render() {\n        if (this.props.auth.userType !== USER) {\n            return <div></div>;\n        }\n\n        return (\n            <StyledNormalContainer>\n                <Normal {...this.props} />\n            </StyledNormalContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    fetchPatient: ({ id }) => dispatch(fetchPatient({ id })),\n    fetchCard: ({ id }) => dispatch(fetchCard({ id })),\n\n    getUserInfo: ({ id, userType, type }) => dispatch(getUserInfo({ id, userType, type })),\n    onEdit: ({ type, value }) => dispatch(editUserForm({ type, value })),\n    modify: ({ id, userType, info }) => dispatch(modifyUserInfo({ id, userType, info })),\n    modifyPassword: ({ id, userType, password, newPassword }) => dispatch(modifyPassword({ id, userType, password, newPassword })),\n    editAuth: ({ type, value }) => dispatch(editAuth({ type, value })),\n    editPassword: ({ type, value }) => dispatch(editPasswordForm({ type, value })),\n    \n    withdrawlUser: ({ id, userType, password }) => dispatch(withdrawlUser({ id, userType, password })),\n    withdrawlKakao: ({ id, userType }) => dispatch(withdrawlKakao({ id, userType })),\n\n    cancelReserve: ({ callId }) => dispatch(cancelReserve({ callId })),\n    modifyReserve: ({ reserveId, info }) => dispatch(modifyReserve({ reserveId, info })),\n    \n    editAddPatientForm: ({ type, value }) => dispatch(editAddPatientForm({ type, value })),\n    addPatient: (info) => dispatch(addPatient(info)),\n    deletePatient: ({ patientId }) => dispatch(deletePatient({ patientId })),\n    modifyPatient: ({ id, patientId, info }) => dispatch(modifyPatient({ id, patientId, info })),\n    getPatientInfo: ({ id, patientId }) => dispatch(getPatientInfo({ id, patientId })),\n\n    editAddCardForm: ({ type, value }) => dispatch(editAddCardForm({ type, value })),\n    addCard: (info) => dispatch(addCard(info)),\n    getCardInfo: ({ id, cardId }) => dispatch(getCardInfo({ id, cardId })),\n    modifyCard: ({ id, cardId, info }) => dispatch(modifyCard({ id, cardId, info })),\n    deleteCard: ({ cardId }) => dispatch(deleteCard({ cardId })),\n});\n \nexport default connect(mapStateToProps, mapDispatchToProps)(NormalPage);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\n\nconst StyledPendingContainer = styled.div`\n    margin-top: 55px;\n    min-height: 100vh;\n    background-color: rgba(0, 0, 0, 0.02);\n    // background-size: cover;\n    // background-repeat: no-repeat;\n    // background-position: center;\n\n    .inner-container {\n        padding: 0px;\n        padding-top: 144px;\n        padding-bottom: 100px;\n\n        .pending-form {\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n            width: 100%;\n            max-width: 340px;\n            margin: 0 auto;\n            padding: 24px;\n\n            .login-title {\n                margin-bottom: 24px;\n\n                p {\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n            }\n\n            .form {\n                .img-wrapper {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                    height: 124px;\n                    padding: 20px 0px;\n\n                    img {\n                        height: 100%;\n                    }\n                }\n\n                .info-title {\n                    p {\n                        margin: 0px;\n                        padding: 0px;\n                        font-size: ${sizeHandler(24)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: rgba(0, 0, 0, 0.8);\n                    }\n\n                    margin-bottom: 4px;\n                }\n\n                .info-body {\n                    margin-bottom: 32px;\n\n                    p {\n                        margin: 0px;\n                        padding: 0px;\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        text-align: center;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n                }\n            }\n        }\n    }\n`;\nexport default StyledPendingContainer;\n","import React from 'react';\nimport {} from 'antd';\n\nexport default class Pending extends React.PureComponent {\n    render() {\n        return (\n            <div className='pending-container'>\n                <div className='inner-container'>\n                    <div className='pending-form'>\n                        <div className='login-title'>\n                            <p>회원가입</p>\n                        </div>\n                        <div className='form'>\n                            <div className='img-wrapper'>\n                                <img src='/assets/images/checkpoint.png' alt='check-circle' />\n                            </div>\n                            <div className='info-title'>\n                                <p>메이트 가입신청 완료</p>\n                            </div>\n                            <div className='info-body'>\n                                <p>\n                                    약 7일 이내에 메이트 가입신청 결과를 <br />\n                                    가입하신 이메일로 보내드리겠습니다.\n                                </p>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledPendingContainer from './pending.styled';\nimport Pending from './pending';\n\nclass PendingPage extends React.PureComponent {\n    render() {\n        return (\n            <StyledPendingContainer>\n                <Pending {...this.props} />\n            </StyledPendingContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ auth }) => ({\n    auth,\n});\n\nconst mapDispatchToProps = dsipatch => ({});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(PendingPage);\n","import React from 'react';\nimport { Switch, Route } from 'react-router-dom';\n\n// pages\nimport NotFound from '../NotFound';\nimport Login from './AuthPages/Login';\nimport Main from './AuthPages/MainRegister';\nimport Register from './AuthPages/Register';\nimport Logout from './AuthPages/Logout';\nimport Find from './AuthPages/Find';\nimport Mate from './AuthPages/Mate';\nimport Normal from './AuthPages/Normal';\nimport Pending from './AuthPages/Pending';\n\n// import Example from './AuthPages/Example';\n\n// component\nexport default class AuthPage extends React.PureComponent {\n    render() {\n        const { url } = this.props.match;\n        // console.log(url);\n        return (\n            <Switch>\n                <Route exact path={`${url}/login`} component={Login} />\n                <Route exact path={`${url}/logout`} component={Logout} />\n\n                <Route exact path={`${url}/register?url_source=dlive`} component={Register} />\n                <Route exact path={`${url}/register?url_source=metlife`} component={Register} />\n\n                <Route exact path={`${url}/register`} component={Register} />\n                <Route exact path={`${url}/mainRegister`} component={Main} />\n\n                {/* <Route exact path={`${url}/example`} component={Example} />  경로 입력 시 /user/example로 해야 화면출력*/}\n\n                <Route exact path={`${url}/find/password`} component={Find} />\n                <Route exact path={`${url}/mypage`} component={Normal} />\n                <Route exact path={`${url}/mypage/:tab`} component={Normal} />\n                <Route exact path={`${url}/mate/pending`} component={Pending} />\n                <Route exact path={`${url}/mate/mypage`} component={Mate} />\n                <Route exact path={`${url}/mate/mypage/:tab`} component={Mate} />\n                {/* <Route exact path={`${url}/withdrawl`} component={Register} /> */}\n                <Route component={NotFound} />\n            </Switch>\n        );\n    }\n}\n","import styled from 'styled-components';\n\nconst AuthStyledContainer = styled.div``;\n\nexport default AuthStyledContainer;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport Auth from './auth';\n\n// styles\nimport AuthStyledContainer from './auth.styled';\n\nclass AuthPages extends React.PureComponent {\n    render() {\n        return (\n            <AuthStyledContainer>\n                <Auth {...this.props} />\n            </AuthStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\n\nconst mapStateToDispatch = dispatch => ({});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(AuthPages);\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../theme';\n\nconst StyledCompanyContainer = styled.div`\n    padding-top: 55px;\n\n    .snd-section .inner-container .block:nth-child(2) {\n        align-items: flex-end;\n    }\n\n    .block {\n        display: flex;\n        align-items: center;\n        justify-content: center;\n\n        .img-block {\n            flex: 1;\n            margin-bottom: 30px;\n            position: relative;\n            display: flex;\n            align-items: flex-start;\n\n            img {\n                width: 65%;\n            }\n\n            &.right {\n                // justify-content: flex-end;\n            }\n        }\n\n        .text-block {\n            flex: 1;\n            margin-bottom: 30px;\n\n            .title {\n                p {\n                    padding: 0px;\n                    margin: 0px;\n                    font-size: ${sizeHandler(36)};\n                    font-weight: bold;\n                    margin-bottom: 20px;\n                    color: rgba(0, 0, 0, 0.8);\n                    letter-spacing: -1px;\n                }\n            }\n\n            .content {\n                p {\n                    padding: 0px;\n                    margin: 0px;\n                    font-size: ${sizeHandler(14)};\n                    line-height: ${sizeHandler(24)};\n                    letter-spacing: -0.3px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 20px;\n                }\n            }\n        }\n    }\n\n    .fst-section {\n        background-image: url('/assets/images/company-main.png');\n        background-size: cover;\n        background-repeat: no-repeat;\n        background-position: center;\n\n        .inner-container {\n            padding-top: 166px;\n            padding-bottom: 166px;\n        }\n\n        .text-block {\n            p {\n                margin: 0px;\n                padding: 0px;\n                text-align: center;\n                color: white;\n\n                &.title {\n                    color: #161616;\n                    font-size: ${sizeHandler(28)};\n                    font-weight: bold;\n                    margin-bottom: 8px;\n                    letter-spacing: -0.6px;\n                }\n\n                &.content {\n                    font-size: ${sizeHandler(32)};\n                    font-weight: bold;\n                    letter-spacing: -0.38px;\n                }\n            }\n        }\n    }\n\n    .trd-section {\n        background-image: url('/assets/images/hug.png');\n        background-size: cover;\n        background-repeat: no-repeat;\n        background-position: center;\n\n\n        .inner-container {\n            padding-top: 144px;\n            padding-bottom: 88px;\n        }\n\n        .text-block {\n            p {\n                text-align: center;\n                margin: 0px;\n                padding: 0px;\n                color: white;\n\n                &.title {\n                    font-size: ${sizeHandler(34)};\n                    font-weight: bold;\n                    letter-spacing: -1px\n                    margin-bottom: 12px;\n                }\n\n                &.content {\n                    font-size: ${sizeHandler(14)};\n                    line-height: ${sizeHandler(22)};\n                    letter-spacing: -0.3px;\n                }\n            }\n        }\n    }\n\n    .fth-section {\n        margin-bottom: 40px;\n        border-bottom: 1px solid #e6e6e6;\n        \n        .title-block {\n            margin-bottom: 20px;\n\n            p {\n                text-align: center;\n                font-size: ${sizeHandler(36)};\n                font-weight: bold;\n                margin-bottom: 20px;\n                color: rgba(0, 0, 0, 0.8);\n                letter-spacing: -1px;\n            }\n        }\n\n        .items-block {\n            .item {\n                float: left;\n                display: flex;\n                align-items: center;\n                justify-content: center;\n                width: 33.3333%;\n                height: 124px;\n\n                @media(max-width: 768px) {\n                    width: 100%;\n                    padding: 0px 20px;\n                }\n\n                .img-wrapper {\n                    width: 30%;\n                    float: left;\n\n                    img {\n                        width: 70%;\n                    }\n                }\n\n                .text-wrapper {\n                    width: 70%;\n                    float: left;\n\n                    .name {\n                        font-size: ${sizeHandler(20)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.8);\n                      \n                    }\n\n                    .value {\n                        font-size: ${sizeHandler(16)};\n                        font-weight: normal;\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                    }\n                }\n            }\n        }\n    }\n\n    .fifth-section {\n\n        .inner-container {\n            padding-top: 200px;\n            padding-bottom: 65px;\n\n            .text-block {\n                .title {\n                    text-align: center;\n                    font-size: ${sizeHandler(36)};\n                    font-weight: bold;\n                    margin-bottom: 20px;\n                    color: rgba(0, 0, 0, 0.8);\n                    letter-spacing: -1px;\n                }\n\n                .content {\n                    text-align: center;\n                    font-size: ${sizeHandler(14)};\n                    line-height: ${sizeHandler(24)};\n                    letter-spacing: -0.3px;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 20px;\n                }\n\n                .news {\n                    text-align: center;\n                    margin-bottom: 80px;\n                }\n            }\n\n            // .logo-block {\n                \n            //     .three {\n                    \n            //         .logo-wrapper {\n            //             float: left;\n            //             width: 20%;\n\n            //             display: flex;\n            //             align-items: center;\n            //             justify-content: center;\n                        \n            //             margin-bottom: 16px;\n\n            //             img {\n            //                 height: 76px;\n            //             }\n            //         }\n            //     }\n            // }\n        }\n    }\n\n    @media (max-width: 768px) {\n        .block {\n            flex-direction: column;\n\n            &.fst {\n                order: 1;\n                \n                .img-block {\n                    align-items: center;\n                    justify-content: center;\n                }\n            }\n\n            .snd {\n                order: 2;\n            }\n\n            .trd {\n                order: 4;\n            }\n\n            .fth {\n                order: 3;\n                margin-top: 20px;\n            }\n            \n            .img-block {\n                // display: none;\n                // margin-bottom: 20px;\n                // justify-content: center;\n\n                // &.right {\n                //     justify-content: center;\n                // }\n\n                // img {\n                //     width: 25%;\n                // }\n            }\n        }\n\n        .fth-section {            \n            .items-block {\n                flex-direction: column;\n\n                .row {\n                    flex-direction: row;\n\n                    .item {\n                        flex: 1;\n                        justify-content: flex-start;\n\n                        .text-block {\n                            flex: 1;\n                        }\n                    }\n                }\n            }\n        }\n\n    }\n\n\n    .sth-container {\n        .img-wrapper {\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            height: 156px;\n            margin-bottom: 34px;\n\n            img {\n                height: 100%;\n            }\n        }\n\n        .text-wrapper {\n            .title {\n                font-size: ${sizeHandler(36)};\n                font-weight: bold;\n                letter-spacing: -1px;\n                text-align: center;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 16px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: normal;\n                letter-spacing: -0.3px;\n                text-align: center;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n`;\nexport default StyledCompanyContainer;\n","import React from 'react';\n\nimport { mainColor } from '../../../theme';\n\nclass FstBlock extends React.PureComponent {\n    render() {\n        return (\n            <div className='fst-section'>\n                <div className='inner-container'>\n                    <div className='text-block'>\n                        <p className='title'>Built for Healthcare, Designed for NEMT</p>\n                        <p className='content'>병원으로 향하는 새로운 길,</p>\n                        <p className='content'>위드메이트가 열어갑니다.</p>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default FstBlock;\n","import React from 'react';\n\nclass SndBlock extends React.PureComponent {\n    render() {\n        return (\n            <div className='snd-section'>\n                <div className='inner-container'>\n                    <div className='block fst'>\n                        <div className='img-block'>\n                            <img alt='something img' src='/assets/images/why.png' />\n                        </div>\n                        <div className='text-block snd'>\n                            <div className='title'>\n                                <p>등장배경</p>\n                            </div>\n                            <div className='content'>\n                                <p>\n                                    날로 분주해지는 현대 사회 속에서, 우리는 매일 직장과 육아라는 전투를 치릅니다. <br />\n                                    살아남기 위한 발버둥을 치기에도 버거운 순간, 떨어져 있는 가족들에 대한 걱정과 <br />\n                                    자기 자신을 돌보기 위한 시간을 내는 것이 힘겹기만 합니다.\n                                </p>\n                                <p>\n                                    과연 그 누가 물리적인 거리와 시간적인 제약, 그리고 직장과 육아가 주는 압박감을 <br />\n                                    떨쳐내고 가족과 자신을 위해 선뜻 움직일 수 있을까요? 그렇다면 우리는 언제까지 <br />\n                                    이런 막막한 상황을 견디기만 해야 할까요?\n                                </p>\n                                <p>이를 해결하기 위한 믿을 수 있는 서비스를 합리적인 가격으로 제공받을 수는 없는 걸까요?</p>\n                            </div>\n                        </div>\n                    </div>\n                    <div className='block'>\n                        <div className='text-block trd'>\n                            <div className='title'>\n                                <p>위드메이트의 시작</p>\n                            </div>\n                            <div className='content'>\n                                <p>\n                                    2015년 설립된 위드메이트는 고령화 및 1인 가구 시대에 접어든 <br />\n                                    대한민국의 현 상황에 적합한 의료 동행 서비스는 무엇인지 연구했습니다.\n                                </p>\n                                <p>\n                                    이후 위드메이트는 탄탄한 신뢰와 안정된 서비스 시스템을 기반으로 <br />\n                                    유수의 병원 동행 서비스를 수행하며 축적된 데이터와 <br />\n                                    실전 경험을 바탕으로 차별화된 병원 동행 Pro/Basic 서비스를 <br />\n                                    런칭하게 되었습니다.\n                                </p>\n                            </div>\n                        </div>\n                        <div className='img-block right fth'>\n                            <img alt='something img' src='/assets/images/withtaxi.png' style={{ width: '100%' }} />\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default SndBlock;\n","import React from 'react';\n\nclass TrdBlock extends React.PureComponent {\n    render() {\n        return (\n            <div className='trd-section'>\n                <div className='inner-container'>\n                    <div className='text-block'>\n                        <p className='title'>암 치료 동행 전문 기업</p>\n                        <p className='content'>\n                            위드메이트는 자타공인 국내 최고 수준의 암 치료 동행 서비스를 제공합니다. 위드메이트는 청담동과 하남에 위치한 암 전문 요양 병원과\n                            <br />\n                            국립 암센터와의 협업 시스템 구축을 통해 항암 치료 동행과 관련된 다양한 경험과 데이터를 축적했습니다.\n                            <br />\n                            이를 통해 위드메이트는 단순한 동행이 아닌, 전문적인 수준의 암 치료 동행 서비스를 제공합니다.\n                        </p>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default TrdBlock;\n","import React from 'react';\n\nclass FthBlock extends React.PureComponent {\n    render() {\n        return (\n            <div className='fth-section' data-aos='fade-up' data-aos-anchor-placement='top-bottom' data-aos-duration='2000'>\n                <div className='inner-container'>\n                    <div className='title-block'>\n                        <p>통계로 보는 위드메이트</p>\n                    </div>\n                    <div className='items-block'>\n                        <Item name='5,000건 ↑' value='총 서비스 수행 건수' img='/assets/images/daily-count.png' />\n                        <Item name='3,500건 ↑' value='암 치료 병원 동행 건수' img='/assets/images/satisfied.png' />\n                        <Item name='50건 ↑' value='일일 서비스 수행 건수' img='/assets/images/daily-count.png' />\n                        <Item name='12 곳' value='협력 기관' img='/assets/images/services.png' />\n                        <Item name='81%' value='서비스 재사용률' img='/assets/images/unsatisfied.png' />\n                        <Item name='1억 2천만원' value='책임 보험' img='/assets/images/shield.png' />\n                        <div className='clearfix' />\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n\nconst Item = ({ name, value, img }) => {\n    return (\n        <div className='item'>\n            <div className='img-wrapper'>\n                <img src={img} alt='value-icon' />\n            </div>\n            <div className='text-wrapper'>\n                <p className='name'>{name}</p>\n                <p className='value'>{value}</p>\n            </div>\n            <div className='clearfix' />\n        </div>\n    );\n};\nexport default FthBlock;\n","import React from 'react';\nimport styled from 'styled-components';\n\nclass FstBlock extends React.PureComponent {\n    render() {\n        return (\n            <div className='fifth-section'>\n                <div className='inner-container'>\n                    <div className='text-block' data-aos='fade-up' data-aos-anchor-placement='top-bottom' data-aos-duration='2000'>\n                        <p className='title'>믿을 수 있는 기업</p>\n                        <p className='content'>\n                            위드메이트는 국가 기관과 지자체에게 검증 받은 서비스로, 현재 <b>보건복지부</b>와 <b>고양시</b>, 그리고 <br />\n                            <b>국립 암센터</b>가 주관하는 <b>‘고양 해피 케어’</b> 컨소시엄의 일원으로 소속되어 국립 암센터를 이용하는 <br />\n                            고양 시민에게 병원 동행 서비스를 제공하고 있습니다. 위드메이트와 함께할 <br />\n                            협력 단체 및 기업은 추후 확장될 예정이니 많은 관심 부탁드립니다.\n                            <br />\n                        </p>\n                        <p className='news'>\n                            <a href='https://news.naver.com/main/read.nhn?mode=LSD&mid=sec&sid1=103&oid=025&aid=0002919541#' target='_blank'>\n                                기사링크 >\n                            </a>\n                        </p>\n                    </div>\n                    <CoCompany />\n                </div>\n            </div>\n        );\n    }\n}\n\nexport const CoCompany = ({ style }) => {\n    return (\n        <StyledCoCompany data-aos='fade-up' data-aos-anchor-placement='top-bottom' data-aos-duration='2000' style={style || {}}>\n            <div className='logo-block'>\n                <div className='three'>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/gov-care.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/goyang.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/cancel.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/goyang-society.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/ericchi.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/beatus.png' alt='logo' />\n                    </div>\n\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/juga.png' alt='logo' />\n                    </div>\n\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/goyang-happy.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/gpcop.png' alt='logo' />\n                    </div>\n\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/paju_woman.png' alt='logo' />\n                    </div>\n\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/cheongdam.png' alt='logo' />\n                    </div>\n                    <div className='logo-wrapper'>\n                        <img src='/assets/images/hyo-hospital.png' alt='logo' />\n                    </div>\n                    <div className='clearfix' />\n                </div>\n            </div>\n        </StyledCoCompany>\n    );\n};\n\nconst StyledCoCompany = styled.div`\n    .logo-block {\n        .three {\n            .logo-wrapper {\n                float: left;\n                width: calc(100% / 6);\n\n                display: flex;\n                align-items: center;\n                justify-content: center;\n\n                margin-bottom: 16px;\n\n                img {\n                    height: 76px;\n                }\n            }\n        }\n    }\n\n    @media (max-width: 768px) {\n        .logo-block {\n            .three {\n                // flex-direction: column;\n                display: block;\n\n                .logo-wrapper {\n                    width: 50%;\n                    float: left;\n\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                }\n            }\n        }\n    }\n`;\nexport default FstBlock;\n","import React from 'react';\n\nexport default class SthSection extends React.PureComponent {\n    render() {\n        return (\n            <div className='sth-container' data-aos='fade-up' data-aos-anchor-placement='top-bottom' data-aos-duration='2000'>\n                <div className='inner-container'>\n                    <div className='img-wrapper'>\n                        <img src='/assets/images/safetyservice.png' alt='smile' />\n                    </div>\n                    <div className='text-wrapper'>\n                        <p className='title'>안전한 병원 동행의 시작</p>\n                        <p className='content'>\n                            위드메이트는 병원 동행 서비스의 본질을 ‘안전’이라고 생각합니다. 이에 위드메이트는 전직원의 <br />\n                            정기적인 교육 및 검열, 전문 자격증 취득 및 보유 여부 상시 점검, 영업배상책임 보험 가입 등 안전한\n                            <br />\n                            병원 동행 서비스의 제공을 위해 최선을 다하고 있습니다.\n                        </p>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n","import React from 'react';\n\n// section\nimport FstBlock from './Section/fst';\nimport SndBlock from './Section/snd';\nimport TrdBlock from './Section/trd';\nimport FthBlock from './Section/fth';\nimport FifBlock from './Section/fifth';\nimport SthBlock from './Section/sth';\n\nclass Company extends React.PureComponent {\n    render() {\n        return (\n            <div className='company-container'>\n                <FstBlock />\n                <FthBlock />\n                <SndBlock />\n                <TrdBlock />\n                <FifBlock />\n                <SthBlock />\n            </div>\n        );\n    }\n}\nexport default Company;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledCompanyContainer from './company.styled';\nimport Company from './company';\n\nclass CompanyPage extends React.PureComponent {\n    render() {\n        return (\n            <StyledCompanyContainer>\n                <Company {...this.props} />\n            </StyledCompanyContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CompanyPage);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../theme';\n\nconst StyledFaqContainer = styled.div`\n    padding-top: 55px;\n\n    .faq-header {\n        border-bottom: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding: 0px;\n            padding-top: 82px;\n\n            @media (max-width: 768px) {\n                padding-top: 42px;\n            }\n\n            > .flex-wrapper {\n                position: relative;\n\n                .faq-main-title {\n                    flex: 1;\n                    .title {\n                        font-size: ${sizeHandler(44)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: #000000;\n                        margin-bottom: 8px;\n                    }\n\n                    .description {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-bottom: 82px;\n                    }\n                }\n\n                .img-section {\n                    position: absolute;\n                    bottom: 0px;\n                    right: 0px;\n\n                    > img {\n                        width: 100%;\n                        max-width: 549px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n\n                    @media (max-width: 768px) {\n                        display: none;\n                    }\n                }\n            }\n\n            .faq-nav {\n                display: flex;\n                align-items: center;\n\n                .nav-tab {\n                    margin-right: 32px;\n                    padding-bottom: 12px;\n                    position: relative;\n\n                    a {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #3bc1ff;\n                    }\n\n                    span.underline {\n                        background-color: #3bc1ff;\n                        position: absolute;\n                        bottom: 0px;\n                        left: 0px;\n\n                        &.active {\n                            width: 100%;\n                            height: 3px;\n                            display: inline-block;\n                        }\n                    }\n\n                    @media (max-width: 768px) {\n                        margin-right: 16px;\n                    }\n                }\n            }\n        }\n    }\n\n    .faq-contents {\n        .inner-container {\n            padding-top: 0px;\n\n            @media (max-width: 768px) {\n                h1 {\n                    font-size: 30px;\n                    margin-top: 60px;\n                }\n            }\n        }\n    }\n\n    .panel-header {\n        display: flex;\n        align-items: center;\n\n        .row-index {\n            width: 80px;\n            color: ${mainColor};\n            font-size: ${sizeHandler(14)};\n            font-weight: bold;\n        }\n\n        .title {\n            flex: 1;\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        @media (max-width: 768px) {\n            .title {\n                font-size: ${sizeHandler(14)};\n            }\n        }\n    }\n\n    .panel-content {\n        padding-left: 80px;\n\n        > p {\n            width: 60%;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .panel-contents-wrapper {\n            margin-top: 20px;\n            margin-bottom: 20px;\n\n            .panel-contents {\n                padding: 12px 0px;\n                border-bottom: 1px solid #e6e6e6;\n\n                &:first-child {\n                    border-top: 1px solid #e6e6e6;\n                }\n\n                .panel-content-subtitle {\n                    float: left;\n                    width: 40%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: left;\n                    color: ${mainColor};\n                }\n\n                .panel-content-subcontents {\n                    float: left;\n                    width: 50%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n\n                @media (max-width: 768px) {\n                    .panel-content-subtitle {\n                        width: 100%;\n                    }\n\n                    .panel-content-subcontents {\n                        width: 100%;\n                    }\n                }\n            }\n        }\n    }\n\n    h1 {\n        font-size: ${sizeHandler(34)};\n        font-weight: bold;\n        color: rgba(0, 0, 0, 0.8);\n        letter-spacing: -1px;\n\n        margin-bottom: 26px;\n        margin-top: 50px;\n    }\n\n    @media (max-width: 1120px) {\n        .faq-header {\n            .inner-container {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n        }\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .panel-header {\n            .row-index {\n                width: 70px;\n            }\n        }\n\n        .panel-content {\n            padding-left: 70px;\n\n            > p {\n                width: 90%;\n            }\n        }\n    }\n`;\nexport default StyledFaqContainer;\n","import React from 'react';\nimport { HashLink } from 'react-router-hash-link';\nimport { Collapse, Icon } from 'antd';\nimport { mainColor } from '../../theme';\nconst { Panel } = Collapse;\n\nexport default class FAQ extends React.PureComponent {\n    render() {\n        const { hash } = this.props.location;\n        return (\n            <div className='faq-container'>\n                <div className='faq-header'>\n                    <div className='inner-container'>\n                        <div className='flex-wrapper'>\n                            <div className='faq-main-title'>\n                                <p className='title'>위드메이트 FAQ</p>\n                                <p className='description'>고객님의 궁금증을 해소하세요!</p>\n                            </div>\n                            <div className='img-section'>\n                                <img src={'/assets/images/faq_bg2.png'} alt='faq-img' />\n                            </div>\n                            <div className='faq-nav'>\n                                <div className='nav-tab'>\n                                    <HashLink className='name' to='/faq/#common' scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'start' })}>\n                                        공통 FAQ\n                                    </HashLink>\n                                    <span className={`underline ${hash === '#common' ? 'active' : undefined}`}></span>\n                                </div>\n                                <div className='nav-tab'>\n                                    <HashLink className='name' to='/faq/#emergency' scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'start' })}>\n                                        병원 동행 Pro FAQ\n                                    </HashLink>\n                                    <span className={`underline ${hash === '#emergency' ? 'active' : undefined}`}></span>\n                                </div>\n                                <div className='nav-tab'>\n                                    <HashLink className='name' to='/faq/#assist' scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'start' })}>\n                                        병원 동행 Basic FAQ\n                                    </HashLink>\n                                    <span className={`underline ${hash === '#assist' ? 'active' : undefined}`}></span>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div className='faq-contents'>\n                    <div className='inner-container'>\n                        <h1 id='common'>공통 FAQ</h1>\n                        <div>\n                            <Collapse\n                                expandIconPosition='right'\n                                bordered={false}\n                                expandIcon={({ isActive }) => (\n                                    <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? mainColor : '#a7a7a7' }} />\n                                )}\n                            >\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-1' title='동행인의 신원은 확실한가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            현재 위드메이트는 적격 자격을 갖춘 인원들을 선별하고 세밀한 채용 단계를 거친 후, 영업 배상 책임 보험 가입과 함께\n                                            엄격한 자체 교육을 실시하며 서비스 인력을 모집하고 있습니다.\n                                            <br />\n                                            이와 동시에 위드메이트가 진행하는 주기적인 교육과 점검을 통해 서비스를 제공하는 인력 모두가 건강한 긴장감을 놓치지\n                                            않도록 철저하게 관리하고 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-2' title='서비스 신청 방법에 대해 알려주세요.' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트 서비스는 웹사이트를 통해 신청이 가능합니다. 웹사이트 내 서비스 신청 모듈을 통해 서비스 신청을 해주시면\n                                            됩니다. 회원 가입 진행을 완료하신 분이라면 전화 상담을 통한 예약 신청 또한 가능합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-3' title='서비스 신청 후 절차가 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            예약 접수가 완료되면, 위드메이트 소속의 전문 동행인들은 예약 발생 알림을 받고 검토를 진행하게 됩니다. 이후 동행인이\n                                            예약을 접수하면 고객님께 ‘예약 완료’ 알림이 가고, 고객님께서 해당 동행인의 접수를 수락하시면 최종 ‘매칭’이\n                                            이루어집니다. 이후 예약 일정에 맞춰 동행인과 함께 병원에 방문하시면 됩니다. 고객님께서 동행인의 접수를 거절하시면\n                                            처음 단계로 돌아가 다른 동행인의 접수를 대기하게 됩니다.\n                                            <br />\n                                            만약 동행인 접수가 불가한 경우 고객님께 예약 불가 알림이 가고, 추후 서비스 재신청을 통해 서비스를 받을 수 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-4' title='위드메이트 서비스 이용 가능 지역은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트의 서비스는 현재 수도권 내에서 이용 가능합니다. 빠른 시일 내 경기도를 포함한 타 지역 서비스 확장을 계획\n                                            중에 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-5' title='예약 변경 및 취소 수수료는 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>고객님께서 정상적으로 매칭된 병원 동행 서비스 계약을 취소 및 변경하는 경우에는 아래와 같이 수수료가 발생합니다.</p>\n                                        <div className='panel-contents-wrapper'>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>서비스 예약 날짜 기준 48시간 이내 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>수수료 없이 변경 & 취소 가능</p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>서비스 예약 전날 18:00 이전 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>\n                                                    취소 시 수수료 10,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과 X\n                                                </p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>당일 예약 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>\n                                                    취소 시 수수료 15,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과 X\n                                                </p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>서비스 시작 2시간 전 이내 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>\n                                                    취소 시 수수료 20,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과 X\n                                                </p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>노쇼(No-Show)의 경우</p>\n                                                <p className='panel-content-subcontents'>회원 자격 정지 및 민/형사상 책임 소지를 물을 수 있음</p>\n                                                <div className='clearfix' />\n                                            </div>\n                                        </div>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-6' title='회사측의 과실로 예약일정을 소화 못하면 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            회사측의 과실로 예약된 서비스를 이용하지 못한 경우 서비스 요금을 전액 배상해드리며, 상황에 따라 서비스 무료 이용권\n                                            등의 추가 배상을 진행합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-7' title='예약 장소에서 담당 동행인을 어떻게 찾나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            예약 접수 후 동행인 매칭이 완료되면 ‘마이페이지’ 내에서 동행인의 정보를 확인하실 수 있으며, 해당 정보를 통해\n                                            동행인과 서비스 관련 소통을 진행하시면 됩니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-8' title='예약한 시간보다 진료나 귀가가 늦어져 서비스 시간이 추가되면 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트 서비스는 후불제이기 때문에 예약한 서비스 시간을 넘어 추가 서비스가 이루어지는 경우, 해당 시간만큼의 추가\n                                            비용이 발생합니다. 서비스 종료 후 추가된 금액이 포함된 최종 요금을 결제하시면 됩니다. 추가 비용은 서비스 시간 15분\n                                            미만 초과 시 발생하지 않으며, 15분을 초과할 시 30분 단위의 요금이 발생합니다.\n                                            <br />\n                                            (Ex. 2시간 예약 서비스가 최종 2시간 14분으로 종료 > 추가 요금 발생 X)\n                                            <br />\n                                            (Ex. 2시간 예약 서비스가 최종 2시간 16분으로 종료 > 추가 요금 발생 O)\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-9' title='위드메이트 서비스는 사용 가능 시간이 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트의 모든 서비스는 주 5일 (월~금), 1일 10시간 (오전 9시 ~ 오후 7시) 동안 이용 가능합니다. 주말 및 공휴일에는\n                                            서비스 제공을 하지 않습니다. 하지만 특수 예약에 대해서는 해당 시간 외에도 서비스를 제공할 수 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                            </Collapse>\n                        </div>\n                        <h1 id='emergency'>병원 동행 Pro FAQ</h1>\n                        <div>\n                            <Collapse\n                                expandIconPosition='right'\n                                bordered={false}\n                                expandIcon={({ isActive }) => (\n                                    <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? mainColor : '#a7a7a7' }} />\n                                )}\n                            >\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-1' title='병원 동행 Pro는 정확히 어떤 경우에 신청할 수 있나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Pro는 응급 상황에 처하지는 않았으나 정기적, 혹은 비정기적으로 의료 기관에 방문해 의료 조치를 받아야 하는\n                                            경우에 신청 가능합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-2' title='서비스 요금은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Pro 서비스 요금은 시간 당 25,000원입니다. 또, 고객 소유의 차량을 메이트가 운행하여 동행할 경우 20,000원이\n                                            추가됩니다 (택시 등 대중 교통을 이용할 경우 추가 요금은 없으나 해당 교통비 개별 부담). 모든 서비스 비용은 VAT 포함\n                                            가격입니다.\n                                            <br />\n                                            (Ex. 2시간 예약 + 고객 소유 차량 운행 선택 시 > 기본 요금 50,000원 + 차량 운행비 20,000원 = 70,000원)\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-3' title='동행인의 성별은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>남성과 여성 인력이 모두 대기 중입니다.</p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-4' title='서비스는 어떤 형식으로 이루어지나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            예약일과 시간에 맞춰 위드메이트 소속의 동행인이 병원 출발지(고객님 자택 등)로 도착합니다. 이후 서비스 신청에 따라\n                                            고객 소유의 차량을 통해 이동할 경우 동행인이 차량을 운행하고 병원까지 이동하며(택시 등의 대중 교통 이용 시 해당 비용\n                                            자가 부담), 병원 내에서 이루어지는 모든 활동에 동행합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-5' title='동행인은 어떤 사람들인가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            동행인은 철저하게 선별되고 영업배상책임보험에 가입되어 있으며, 위드메이트가 자체적으로 실시하는 엄격한 서비스 교육을\n                                            모두 이수하고 통과한 전문가입니다. 또, 위드메이트의 동행인은 국립 암센터에서 실시하는 주기적인 암 환자 관리 교육 및\n                                            세미나에 지속적으로 참여해 서비스 품질과 전문성이 보장된 인력들입니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-6' title='중증 또는 휠체어 등의 의료 기구 대동이 필요한 환자도 이용 가능한가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            중증 또는 휠체어 등의 의료 기구 대동이 필요한 환자에 대한 비응급 의료 동행 서비스는 준비 중에 있습니다. 현\n                                            서비스로는 해당 인원과의 동행은 불가하며, 예약이 접수된 경우 개별적인 연락을 통해 예약 불가를 알려드립니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={\n                                        <PanelHeader\n                                            rowIndex='2-7'\n                                            title='단발성이 아니라 수회에 걸쳐서 정기적으로 위드메이트 서비스를 이용하고 싶은데 이 같은 경우 예약을 어떻게 하나요?'\n                                        />\n                                    }\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            방사선이나 암 치료와 같이 주기적으로 내원이 필요한 경우 개별 상담을 통해 예약이 가능합니다. 위드메이트 서비스를 장기\n                                            예약할 경우 특별 할인 혜택 또한 제공되고 있습니다. 서비스 센터로 문의 주실 경우 위드메이트의 전문 상담원이\n                                            안내해드립니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                            </Collapse>\n                        </div>\n                        <h1 id='assist'>병원 동행 Basic FAQ</h1>\n                        <div>\n                            <Collapse\n                                expandIconPosition='right'\n                                bordered={false}\n                                expandIcon={({ isActive }) => (\n                                    <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? mainColor : '#a7a7a7' }} />\n                                )}\n                            >\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-1' title='병원 동행 Basic은 정확히 어떤 경우에 신청할 수 있나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Basic은 주로 수술의 범주에는 속하지 않지만 마취 혹은 단순 보호자가 필요한 수면 내시경 등을 포함한 모든\n                                            종류의 시술을 해야 할 경우에 신청합니다. 물론 Pro 서비스를 받아야 하지만 자택에서 병원, 다시 병원에서 자택까지의\n                                            동행 과정을 필요로 하지 않는 상황에서도 신청이 가능합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-2' title='서비스 요금은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Basic 요금은 시간 당 15,000원입니다. (Ex. 2시간 예약 시 30,000원)\n                                            <br /> 모든 서비스 비용은 VAT 포함 가격입니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-3' title='동행인은 어떤 사람들인가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>병원 동행 Basic 서비스 동행인은 Pro 서비스와 동일한 인력으로 구성되어 있습니다.</p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-4' title='동행인의 성별은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>남성과 여성 인력이 모두 대기 중입니다.</p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-5' title='서비스는 어떤 형식으로 이루어지나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            고객님께서 지정하신 병원에서 동행자와 접선 후, 동행자는 예약자의 진료 접수부터 종료 시점까지 병원 내부에서\n                                            대기합니다. 진료 종료 후, 동행자는 예약자의 의사를 확인한 후 업무를 마치고 복귀합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                            </Collapse>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n\nconst PanelHeader = ({ rowIndex, title }) => {\n    return (\n        <div className='panel-header'>\n            <p className='row-index'>{rowIndex}</p>\n            <p className='title'>{title}</p>\n        </div>\n    );\n};\n\nconst PanelContent = ({ children }) => {\n    return <div className='panel-content'>{children}</div>;\n};\n","import React from 'react';\nimport StyledFaqContainer from './faq.styled';\nimport FAQ from './faq';\n\nclass FAQContainer extends React.PureComponent {\n    render() {\n        return (\n            <StyledFaqContainer>\n                <FAQ {...this.props} />\n            </StyledFaqContainer>\n        );\n    }\n}\nexport default FAQContainer;\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../../theme';\nconst StyledBuyContainer = styled.div`\n    margin-top: 55px;\n\n    .buy-container {\n        min-height: 100vh;\n        position: relative;\n        width: 100%;\n        background-color: #ebf9ff;\n        background-image: url('/assets/images/main-bg.png');\n        background-size: cover;\n        background-repeat: no-repeat;\n        background-position: center;\n\n        @media (max-width: 768px) {\n            background-image: none;\n        }\n\n        .order-menu-wrapper {\n            width: 50%;\n            position: relative;\n            max-width: 440px;\n            min-width: 370px;\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 1px 2px 3.5px #e6e6e6;\n            padding: 32px;\n            // overflow: hidden;\n\n            .mobile-close-button {\n                display: none;\n            }\n\n            .ant-input-number {\n                width: 100%;\n                height: 48px;\n\n                .ant-input-number-input-wrap {\n                    height: 100%;\n\n                    input {\n                        height: 100%;\n                    }\n                }\n\n                .ant-input-number-handler-wrap {\n                    opacity: 1;\n                    width: 48px;\n\n                    span {\n                        display: flex;\n                        align-items: center;\n                        justify-content: center;\n\n                        i {\n                            position: relative;\n                            margin-top: 0px;\n                            left: 0px;\n                            top: 0px;\n                            bottom: 0px;\n                            right: 0px;\n                            font-size: 16px;\n                        }\n                    }\n                    .anticon.anticon-up.ant-input-number-handler-up-inner {\n                        color: ${mainColor};\n                    }\n                    .anticon.anticon-down.ant-input-number-handler-down-inner {\n                        color: ${mainColor};\n                    }\n                }\n            }\n\n            @media (max-width: 768px) {\n                margin: 0px auto;\n                width: 100%;\n            }\n\n            .order-title {\n                margin-bottom: 20px;\n\n                p {\n                    margin: 0px;\n                    padding: 0px;\n                    font-size: ${sizeHandler(28)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n            }\n\n            .fee-wrapper {\n                margin-bottom: 8px;\n                display: flex;\n                align-items: center;\n\n                p {\n                    margin: 0px;\n                    padding: 0px;\n\n                    &.info {\n                        flex: 1;\n                        font-size: 14px;\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n\n                    &.fee {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        text-align: right;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n                }\n            }\n\n            .total-wrapper {\n                display: flex;\n                align-items: center;\n                padding: 20px 0px;\n                margin-top: 16px;\n                margin-bottom: 32px;\n                border-top: 1px solid #e6e6e6;\n                border-bottom: 1px solid #e6e6e6;\n\n                p {\n                    margin: 0px;\n                    padding: 0px;\n\n                    &.info {\n                        flex: 1;\n                        font-size: ${sizeHandler(16)};\n                        font-weight: bold;\n                        letter-spacing: -0.5px;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n\n                    &.fee {\n                        font-size: ${sizeHandler(16)};\n                        font-weight: bold;\n                        letter-spacing: -0.5px;\n                        text-align: right;\n                        color: #3bc1ff;\n                    }\n                }\n            }\n\n            .service {\n                margin-bottom: 20px;\n\n                .service-tab {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                    border: 1px solid #ddd;\n                    border-radius: 6px;\n\n                    .tab {\n                        flex: 1;\n                        height: 48px;\n                        border-right: 1px solid #ddd;\n                        cursor: pointer;\n                        display: flex;\n                        justify-content: center;\n                        align-items: center;\n\n                        &:last-child {\n                            border: 0px;\n                        }\n\n                        span {\n                            font-size: ${sizeHandler(14)};\n                            letter-spacing: -0.2px;\n                            font-weight: bold;\n                            color: ${mainColor};\n                        }\n                    }\n\n                    .tab.active {\n                        background-color: ${mainColor};\n\n                        span {\n                            color: white;\n                        }\n                    }\n                }\n\n                .info-tab {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n\n                    p {\n                        flex: 1;\n                        margin: 0px;\n                        padding: 0px;\n                        text-align: left;\n\n                        &:first-child {\n                            margin-right: 8px;\n                        }\n                    }\n                }\n\n                .info-input-tab {\n                    display: flex;\n                    align-items: center;\n                    // justify-content: center;\n\n                    > div {\n                        flex: 1;\n\n                        &:first-child {\n                            margin-right: 8px;\n                        }\n                    }\n\n                    .input {\n                        display: flex;\n                        border-radius: 4px;\n                        border: solid 1px #e6e6e6;\n                        height: 36px;\n                        line-height: 36px;\n                        text-indent: 12px;\n                        align-items: center;\n                        font-size: ${sizeHandler(12)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        overflow: hidden;\n                        text-overflow: ellipsis;\n                        white-space: nowrap;\n                        background-color: #f5f5f5;\n                        cursor: not-allowed;\n\n                        // .ant-input {\n                        //     color: rgba(0, 0, 0, 0.8);\n                        // }\n\n                        &.phone {\n                            flex: 0.5;\n\n                            @media (max-width: 768px) {\n                                flex: 1;\n                            }\n                        }\n\n                        &.input-with-icon {\n                            p {\n                                height: 100%;\n                                flex: 1;\n                            }\n\n                            div {\n                                height: 100%;\n                                width: 36px;\n                                border-left: 1px solid #e6e6e6;\n                                display: flex;\n                                justify-content: center;\n                                align-items: center;\n\n                                span {\n                                    text-align: center;\n                                    text-indent: 0px;\n                                    opacity: 0.3;\n                                    font-size: ${sizeHandler(12)};\n                                    letter-spacing: -0.3px;\n                                    color: rgba(0, 0, 0, 0.8);\n                                }\n                            }\n                        }\n                    }\n                }\n\n                .service-fee-wrapper {\n                    margin-bottom: 32px;\n\n                    .service {\n                        display: flex;\n                        align-items: center;\n                        padding-top: 12px;\n                        margin-bottom: 0px;\n\n                        .name {\n                            flex: 1;\n                            font-size: ${sizeHandler(14)};\n                            letter-spacing: -0.3px;\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n\n                        .fee {\n                            font-size: ${sizeHandler(14)};\n                            font-weight: bold;\n                            text-align: right;\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n                    }\n                }\n\n                input {\n                    height: 36px;\n                    display: inline-block;\n                    width: 100%;\n                }\n\n                .select {\n                    display: inline-block;\n                    height: 36px;\n                    width: 100%;\n\n                    .ant-select-selection--single {\n                        height: 100%;\n                    }\n\n                    .ant-select-selection__rendered {\n                        line-height: 36px;\n                    }\n                }\n\n                .info {\n                    font-size: ${sizeHandler(12)};\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 4px;\n                    letter-spacing: -0.15px;\n                }\n\n                .ant-select-selection__rendered {\n                    margin-right: 34px;\n                    border-right: 1px solid #e6e6e6;\n                }\n\n                .ant-select-arrow {\n                    color: ${mainColor};\n                }\n\n                .image-with-text {\n                    display: flex;\n                    align-items: center;\n                    img {\n                        height: 18px;\n                        border: 0px;\n                    }\n\n                    p {\n                        flex: 1;\n                        margin: 0px;\n                        padding: 0px;\n                        margin-left: 12px;\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        color: #3bc1ff;\n                    }\n                }\n            }\n\n            .side-summary-tab {\n                position: absolute;\n                top: 0px;\n                right: -380px;\n                width: 360px;\n                height: 100%;\n                background-color: white;\n                border-radius: 8px;\n                box-shadow: 1px 2px 3.5px #e6e6e6;\n                padding: 32px;\n                overflow: hidden;\n                display: flex;\n                flex-direction: column;\n\n                @media (max-width: 768px) {\n                    width: 100%;\n                    height: auto;\n                    border-radius: 0px;\n                    box-shadow: none;\n                    padding: 0px;\n                    position: relative;\n                    top: 55px;\n                    left: 0px;\n                    background-color: transparent;\n                }\n\n                .refund-info-wrapper {\n                    flex: 1;\n                    display: flex;\n                    align-items: flex-end;\n\n                    .info-wrapper {\n                        width: 100%;\n\n                        .title {\n                            font-size: ${sizeHandler(12)};\n                            font-weight: bold;\n                            color: #a7a7a7;\n                            margin-bottom: 8px;\n                        }\n\n                        .info {\n                            font-size: ${sizeHandler(10)};\n                            line-height: ${sizeHandler(16)};\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n\n                        @media (max-width: 768px) {\n                            margin-top: 36px;\n                            padding-bottom: 20px;\n\n                            .info {\n                                margin-bottom: 60px;\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\nexport default StyledBuyContainer;\n","import React from 'react';\nimport { Input, Button, InputNumber, message } from 'antd';\nimport { mainColor } from '../../../../theme';\nimport { UNEMER, ASSIST, MATE, DEV } from '../../../../Lib/variables';\nimport { currencyFormatter } from '../../../../Lib/utils';\nimport moment from 'moment';\n\nexport default class BuyTicket extends React.PureComponent {\n    onEdit = ({ type, value }) => {\n        this.props.edit({ type, value });\n    };\n\n    componentWillUnmount = () => {\n        this.onEdit({ type: 'clear', value: '' });\n    };\n\n    payment = () => {\n        const { id, name, userType } = this.props.auth;\n        const { service, count } = this.props.app.buyForm;\n\n        if (userType === MATE) return message.info('해당 서비스는 일반 사용자만 이용가능합니다.');\n        if (!id) return this.props.history.push('/logout');\n\n        this.props\n            .getServiceInfo({ code: service })\n            .then(resolve => {\n                if (resolve && Array.isArray(resolve) && resolve.length > 0) {\n                    const { _id, defaultPrice } = resolve[0];\n                    const discount = count >= 10 ? count * defaultPrice * 0.1 : count >= 4 ? count * defaultPrice * 0.05 : 0;\n\n                    const totalPrice = defaultPrice * count - discount;\n\n                    const IMP = window.IMP; // 생략해도 괜찮습니다.\n                    IMP.init('imp47625929'); // \"imp00000000\" 대신 발급받은 \"가맹점 식별코드\"를 사용합니다.\n\n                    // IMP.request_pay(param, callback) 호출\n                    IMP.request_pay(\n                        {\n                            // param\n                            pg: 'inicis',\n                            pay_method: 'card',\n                            merchant_uid: _id + '-' + moment().valueOf(),\n                            name: service === UNEMER ? '병원 동행 Pro 이용권' : '병원 동행 Basic 이용권',\n                            amount: totalPrice,\n                            buyer_email: '',\n                            buyer_name: name,\n                            buyer_tel: '',\n                            m_redirect_url: `https://server.withmate.kr/v1/service/buy/ticket/${count}/${id}/${service}/mobile`,\n                        },\n                        function(rsp) {\n                            // callback\n                            if (rsp.success === true) {\n                                const productInfo = {\n                                    productCode: service,\n                                    totalPrice: rsp.paid_amount,\n                                    productId: _id,\n                                    name: rsp.name,\n                                    merchantUid: rsp.merchant_uid,\n                                    count,\n                                    impUid: rsp.imp_uid,\n                                    payMethod: rsp.pay_method,\n                                    unit: rsp.currency,\n                                    paidStatus: rsp.paid === 'paid' ? true : false,\n                                    cardName: rsp.card_name,\n                                    bankName: rsp.bank_name,\n                                    cardQuota: rsp.card_quota, // 할부 월수\n                                    buyerEmail: rsp.buyer_email,\n                                };\n\n                                this.props\n                                    .buyTicket({ userId: id, info: productInfo })\n                                    .then(resolve => {\n                                        if (resolve && resolve !== 'success') {\n                                            return message.error('결제가 정상적으로 수행되지 않았습니다. 새로고침 후 다시 시도해주세요.');\n                                        }\n\n                                        if (resolve && resolve === 'success') {\n                                            message.success('상품 구매를 완료하였습니다. 서비스를 예약해보세요.');\n                                            return this.props.history.push('/');\n                                        }\n                                    })\n                                    .catch(error => {\n                                        message.error('상품 결제이력 등록 중 오류가 발생하였습니다. 관리자에게 문의하여 주시기 바랍니다.');\n                                    });\n                            } else {\n                                return message.error('결제 시도 중 오류가 발생하였습니다. 다시 시도해주세요.');\n                            }\n                        },\n                    );\n                } else {\n                    return message.info('현재 판매 마감된 상품입니다. 다른 상품을 고매해주세요.');\n                }\n            })\n            .catch(error => {\n                return message.error('결제 시도 중 오류가 발생하였습니다. 다시 시도해주세요.');\n            });\n    };\n\n    render() {\n        const { service, count } = this.props.app.buyForm;\n        const discount =\n            count >= 10 ? count * (service === UNEMER ? 120000 : 18000) * 0.1 : count >= 4 ? count * (service === UNEMER ? 120000 : 18000) * 0.05 : 0;\n        return (\n            <div className='buy-container'>\n                <div className='inner-container'>\n                    <div className='order-menu-wrapper'>\n                        <div className='order-title'>\n                            <p>서비스 이용을 위해</p>\n                            <p>이용권을 구매해주세요</p>\n                        </div>\n                        <div className='service'>\n                            <p className='info'>\n                                <img\n                                    src='/assets/images/info-icon.png'\n                                    alt='info'\n                                    style={{ width: '12px', height: '12px', marginRight: '4px', color: mainColor }}\n                                />\n                                서비스 선택\n                            </p>\n                            <div className='service-tab'>\n                                <div\n                                    className={`tab ${service === UNEMER ? 'active' : ''}`}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'service', value: UNEMER });\n                                        this.onEdit({ type: 'count', value: 1 });\n                                    }}\n                                >\n                                    <span>비응급 동행</span>\n                                </div>\n                                <div\n                                    className={`tab ${service === 'assist' ? 'active' : ''}`}\n                                    onClick={() => {\n                                        this.onEdit({ type: 'service', value: ASSIST });\n                                        this.onEdit({ type: 'count', value: 1 });\n                                    }}\n                                >\n                                    <span>위드 어시스트</span>\n                                </div>\n                            </div>\n                        </div>\n\n                        <div className='service'>\n                            <p className='info'>이용권 구매 수량</p>\n                            <div>\n                                <InputNumber\n                                    min={1}\n                                    max={30}\n                                    value={count}\n                                    onChange={val => {\n                                        if (typeof val !== 'number') return null;\n\n                                        this.onEdit({ type: 'count', value: val });\n                                    }}\n                                    formatter={() => {\n                                        return `${service === UNEMER ? '병원 동행 Pro x ' : '병원 동행 Basic x '}${count}`;\n                                    }}\n                                />\n                            </div>\n                        </div>\n\n                        <div className='fee-wrapper'>\n                            <p className='info'>{service === UNEMER ? '병원 동행 Pro' : '병원 동행 Basic'} 이용권 비용</p>\n                            <p className='fee'>{service === UNEMER ? '120,000 KRW' : '18,000 KRW'}</p>\n                        </div>\n\n                        <div className='fee-wrapper'>\n                            <p className='info'>구매 수량</p>\n                            <p className='fee'>x {count}</p>\n                        </div>\n\n                        {count >= 4 ? (\n                            <div className='fee-wrapper'>\n                                <p className='info'>할인액</p>\n                                <p className='fee'>\n                                    {currencyFormatter(discount)}\n                                    KRW ({count >= 10 ? 10 : count >= 4 ? 5 : 0}%)\n                                </p>\n                            </div>\n                        ) : null}\n\n                        <div className='total-wrapper'>\n                            <p className='info'>Total</p>\n                            <p className='fee'>{currencyFormatter(count * (service === UNEMER ? 120000 : 18000) - discount)} KRW</p>\n                        </div>\n\n                        <div className='button-wrapper'>\n                            <Button style={{ width: '100%', height: '40px' }} type='primary' onClick={this.payment}>\n                                구매하기\n                            </Button>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledBuyContaeinr from './buy.styled';\nimport Buy from './buy';\n\nimport { MATE } from '../../../../Lib/variables';\nimport { editBuyForm, getServiceInfo, buyTicket } from '../../../../Reducer/Modules/app';\n\nclass BuyTicketPage extends React.PureComponent {\n    componentDidMount = () => {\n        const { id, userType } = this.props.auth;\n        if (!id || userType === MATE) this.props.history.goBack();\n    };\n\n    render() {\n        return (\n            <StyledBuyContaeinr>\n                <Buy {...this.props} />\n            </StyledBuyContaeinr>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    edit: ({ value, type }) => dispatch(editBuyForm({ type, value })),\n    getServiceInfo: ({ code }) => dispatch(getServiceInfo({ code })),\n    buyTicket: ({ userId, info }) => dispatch(buyTicket({ userId, info })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(BuyTicketPage);\n","import React from 'react';\nimport { Switch, Route } from 'react-router-dom';\n\nimport Buy from './ProductPages/Buy';\n\nexport default class ProductRenderPages extends React.PureComponent {\n    render() {\n        const { url } = this.props.match;\n        return (\n            <Switch>\n                <Route path={`${url}/buy/ticket`} component={Buy} />\n            </Switch>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\n\nimport Products from './product';\n\nclass ProductPages extends React.PureComponent {\n    render() {\n        return <Products {...this.props} />;\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\n\nconst mapStateToDispatch = dispatch => ({});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(ProductPages);\n","import styled from 'styled-components';\n\nexport const ValueBox = styled.div`\n  margin-bottom: 16px;\n\n  .switch {\n    margin-right: 10px;\n  }\n\n  .slide-img-div {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n    height: 300px;\n    border: 2px dashed #ccc;\n    border-radius: 5px;\n    margin-bottom: 10px;\n\n    .slide-img-desc {\n      bottom-margin: 20px;\n    }\n\n    .slide-img-preview {\n        position: relative;\n  \n        .upload-img {\n          max-width: 200px;\n          max-height: auto;\n          margin-top: 10px;\n          pointer-evnets: none;\n        }\n  \n        .icon-div {\n          position: absolute;\n          padding-bottom: 30px;\n          right: 0;\n  \n          .delete-btn {\n            border: none;\n            font-size: 18px;\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst ReservePageContainer = styled.div`\n    width: 100%;\n    min-height: 100vh;\n\n    padding-top: 54px;\n    // padding-bottom: 54px;\n`;\n\nconst ResrevePageInnerContainer = styled.div`\n    width: 1120px;\n    margin: 0 auto;\n\n    ${props => props.bg && `background-image: url(${props.bg}); background-size: contain; background-position: 50% 80%; background-repeat: no-repeat;`}\n\n    padding-top: ${props => (props.smallPadding ? '0px' : '48px')};\n    padding-bottom: ${props => (props.smallPadding ? '0px' : '188px')};\n\n    @media (max-width: 768px) {\n        width: 100%;\n        padding-top: 24px;\n        padding-bottom: 30px;\n        ${props => props.bg && `background-image: transparent; background-color: ${props.mobileBg ? props.mobieBg : '#ffffff'};`}\n    }\n`;\n\nconst ResrevePageHalfInnerContainer = styled.div`\n    margin: 0 auto;\n    width: 1120px;\n    margin-right: auto;\n    margin-left: auto;\n    padding: 15px;\n\n    ${props => props.bg && `background-image: url(${props.bg}); background-size: cover; background-position: 50% 80%; background-repeat: no-repeat;`}\n\n    padding-top: ${props => (props.smallPadding ? '0px' : '10px')};\n    padding-bottom: ${props => (props.smallPadding ? '0px' : '30px')};\n\n    @media (max-width: 768px) {\n        width: 100%;\n        padding-top: 24px;\n        padding-bottom: 48px;\n        ${props => props.bg && `background-image: transparent; background-color: ${props.mobileBg ? props.mobieBg : '#ffffff'};`}\n    }\n`;\n\nconst ReserveTopCover = styled.div`\n    background: ${props =>\n        props.isMain ? `url('/assets/images/w_reserve_web.png') no-repeat top center` : `url('/assets/images/w_reserve_m.png') no-repeat top center`};\n    background-size: cover;\n\n    @media (max-width: 768px) {\n        ${props => !props.isMain && `display: none;`}\n    }\n`;\nexport { ReserveTopCover, ReservePageContainer, ResrevePageInnerContainer, ResrevePageHalfInnerContainer };\n\nconst TopBannerSubDescription = styled.div`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ffffff;\n    margin-top: 8px;\n`;\n\nconst TopBannerSection = styled.div`\n    width: 100%;\n\n    padding-top: ${props => (props.isMain ? '110px' : '86px')};\n    padding-bottom: ${props => (props.isMain ? '0px' : '67px')};\n\n    text-align: center;\n\n    @media (max-width: 768px) {\n        text-align: center;\n        ${props => props.bg === '#f9f9f9' && `display: none;`}\n        padding-top: 56px;\n    }\n`;\n\nconst TopBannerText = styled.h3`\n    margin-top: 0px;\n    margin-bottom: 2px;\n\n    font-size: 32px;\n    font-weight: 300;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    letter-spacing: -0.7px;\n    text-align: center;\n    color: #ffffff;\n\n    > span {\n        font-size: 32px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.5;\n        letter-spacing: -0.7px;\n        text-align: left;\n        color: #ffffff;\n    }\n\n    @media (max-width: 768px) {\n        font-size: 24px;\n\n        > span {\n            font-size: 24px;\n        }\n    }\n`;\n\nconst TopBannerDescription = styled.div`\n    padding: 8px 24px;\n    width: fit-content;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: center;\n    background-color: #3bc1ff;\n    color: #ffffff;\n\n    border-radius: 50vh;\n    margin: 0 auto;\n    margin-bottom: 16px;\n`;\n\nexport { TopBannerSection, TopBannerText, TopBannerDescription };\n\nconst StepSectionContainer = styled.div`\n    padding-top: 32px;\n    padding-bottom: 32px;\n\n    background-color: #ffffff;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nconst StepButtonWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    width: 100%;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nconst StepButton = styled.button`\n    width: 200px;\n    height: 64px;\n    line-height: 64px;\n    border: 0px;\n    outline: none;\n\n    border-radius: 50vh;\n    cursor: not-allowed;\n\n    text-align: center;\n    font-size: 18px;\n    letter-spacing: -0.1px;\n\n    ${props =>\n        props.active\n            ? `\n    background-color: #3bc1ff;\n    color: #ffffff;\n    `\n            : `\n    background-color: #e6e6e6;\n    color:#afb0b2;`}\n\n    @media (max-width: 768px) {\n        width: 192px;\n        height: 52px;\n        line-height: 52px;\n        font-size: 14px;\n        letter-spacing: normal;\n    }\n`;\n\nconst UnderLineText = styled.span`\n    cursor: pointer;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: #3bc1ff;\n\n    text-decoration: underline;\n`;\n\nconst StepArrow = styled.img`\n    width: 16px;\n    height: 16px;\n    object-fit: contain;\n\n    margin-left: 8px;\n    margin-right: 8px;\n\n    @media (max-width: 768px) {\n        transform: rotate(90deg);\n        widteh: 24px;\n        height: 24px;\n        margin-left: 0px;\n        margin-right: 0px;\n        margin-top: 8px;\n        margin-bottom: 8px;\n    }\n`;\n\nexport { UnderLineText, TopBannerSubDescription, StepSectionContainer, StepButtonWrapper, StepButton, StepArrow };\n\nconst NextStepGudieContainer = styled.div`\n    width: 100%;\n\n    padding-top: 56px;\n    padding-bottom: 42px;\n\n    ${props => props.useBg && `background-color: rgba(242,242,242,0.3);`}\n    text-align: center;\n\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n\n    // margin-bottom: 48px;\n\n    @media (max-width: 768px) {\n        padding-top: 24px;\n        padding-bottom: 24px;\n\n        // margin-bottom: 24px;\n    }\n`;\n\nconst NextStepEmoj = styled.img`\n    width: 64px;\n    height: 64px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        width: 32px;\n        height: 32px;\n    }\n`;\n\nconst NextStepTitle = styled.h4`\n    margin-top: 24px;\n    margin-bottom: 16px;\n\n    font-size: 36px;\n    line-height: 48px;\n    color: ${props => props.color};\n    letter-spacing: -0.7px;\n    text-align: center;\n    font-weight: bold;\n\n    @media (max-width: 768px) {\n        margin-top: 16px;\n\n        font-size: 22px;\n        line-height: 30px;\n        letter-spacing: -0.5px;\n    }\n`;\n\nconst MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nconst DesktopBr = styled.br`\n    display: block;\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nconst NextStepArrowDown = styled.img`\n    width: 48px;\n    height: 48px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        width: 24px;\n        height: 24px;\n    }\n`;\n\nexport { NextStepGudieContainer, NextStepEmoj, NextStepTitle, NextStepArrowDown };\n\nconst ServiceSectionContainer = styled.div`\n    position: relative;\n`;\n\nconst ServiceSectionTitle = styled.h5`\n    font-size: 28px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n    font-weight: bold;\n    margin-bottom: 16px;\n\n    @media (max-width: 768px) {\n        font-size: 22px;\n    }\n`;\n\nconst ServiceSectionDescription = styled.p`\n    margin-bottom: 52px;\n\n    font-size: 16px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n    letter-spacing: -0.2px;\n    line-height: 28px;\n\n    @media (max-width: 768px) {\n        font-size: 15px;\n        line-height: 23px;\n        letter-spacing: -0.3px;\n\n        margin-bottom: 48px;\n    }\n`;\n\nexport { ServiceSectionContainer, ServiceSectionTitle, ServiceSectionDescription };\n\nconst ServiceCardList = styled.div`\n    display: flex;\n    flex-wrap: wrap;\n    align-items: flex-start;\n    justify-content: center;\n    padding-bottom: 80px;\n\n    > div:nth-child(5n) {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        justify-content: flex-start;\n        padding-left: 16px;\n        padding-right: 16px;\n\n        > div:nth-child(5n) {\n            margin-right: 12px;\n        }\n\n        > div:nth-child(2n) {\n            margin-right: 0px;\n        }\n    }\n`;\n\nconst ServiceCardWrapper = styled.div`\n    width: 216px;\n    height: 234px;\n\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: ${props => (props.on ? '4px solid #3bc1ff' : '1px solid #e6e6e6')};\n    padding: ${props => (props.on ? '13px' : '16px')};\n    background-color: #ffffff;\n\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: space-between;\n\n    margin-right: 10px;\n    margin-bottom: 10px;\n\n    > img {\n        width: 144px;\n        height: 144px;\n        object-fit: contain;\n\n        margin-bottom: 4px;\n    }\n\n    @media (max-width: 768px) {\n        width: calc(50% - 6px);\n        height: 195px;\n\n        margin-right: 12px;\n        margin-bottom: 10px;\n\n        padding: 4px;\n\n        padding-top: ${props => (props.on ? '12px' : '15px')};\n        padding-bottom: ${props => (props.on ? '12px' : '15px')};\n\n        > img {\n            // width: 100%;\n            // max-height: 120px\n            width: 120px;\n            height: 120px;\n\n            margin-bottom: 2px;\n        }\n    }\n`;\n\nconst ServiceCardButton = styled.div`\n    display: inline-block;\n\n    width: 100%;\n    max-width: 184px;\n    height: 48px;\n    line-height: 48px;\n\n    cursor: pointer;\n\n    font-size: 18px;\n    letter-spacing: -0.1px;\n    color: #3bc1ff;\n    background-color: #ffffff;\n    border-radius: 50vh;\n    text-align: center;\n    border: 1px solid #afb0b2;\n\n    &:hover {\n        transition: all 0.25s;\n        color: #ffffff;\n        background-color: #3bc1ff;\n    }\n\n    &.selected {\n        color: #ffffff;\n        background-color: #3bc1ff;\n    }\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        max-width: 130px;\n\n        height: 40px;\n        line-height: 40px;\n\n        &:hover {\n            transition: none;\n            color: #3bc1ff;\n            background-color: #ffffff;\n        }\n\n        &.selected {\n            color: #ffffff;\n            background-color: #3bc1ff;\n        }\n    }\n`;\n\nexport { ServiceCardList, ServiceCardWrapper, ServiceCardButton };\n\nconst ZzzServiceWrapper = styled.div`\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n\n    padding: 32px;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: 1px solid #e6e6e6;\n\n    @media (max-width: 768px) {\n        width: calc(100% - 32px);\n        margin: 0 auto;\n    }\n`;\n\nconst ZzzArt = styled.img`\n    width: 200px;\n    height: 160px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        width: 175px;\n        height: 140px;\n\n        margin-bottom: 16px;\n    }\n`;\n\nconst ZzzDescription = styled.div`\n    margin-bottom: 8px;\n\n    font-weight: bold;\n    font-size: 20px;\n    letter-spacing: -0.1px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        margin-bottom: 16px;\n        text-align: center;\n    }\n`;\n\nexport { ZzzServiceWrapper, ZzzArt, ZzzDescription };\n\nconst AlzheServiceWrapper = styled.div`\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n\n    padding: 32px;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: 1px solid #e6e6e6;\n\n    @media (max-width: 768px) {\n        width: calc(100% - 32px);\n        margin: 0 auto;\n    }\n`;\n\nconst AlzheArt = styled.img`\n    width: 200px;\n    height: 160px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        width: 175px;\n        height: 140px;\n\n        margin-bottom: 16px;\n    }\n`;\n\nconst AlzheDescription = styled.div`\n    margin-bottom: 8px;\n\n    font-weight: bold;\n    font-size: 20px;\n    letter-spacing: -0.1px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        margin-bottom: 16px;\n        text-align: center;\n    }\n`;\n\nexport { AlzheServiceWrapper, AlzheArt, AlzheDescription };\n\nconst ServiceTypeSectionContainer = styled.div`\n    width: 100%;\n    position: relative;\n\n    padding-top: 36px;\n    ${props => props.gap && `padding-bottom: 54px;`}\n\n    ${props => props.bg && `background-image: url(${props.bg}); background-size: contain; background-position: right; background-repeat: no-repeat;`}\n\n    @media (max-width: 768px) {\n        ${props => props.bg && `background-image: transparent; background-color: ${props.mobileBg ? props.mobieBg : '#ffffff'};`}\n    }\n`;\n\nconst ServiceTypeWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > div:last-child {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n\n        > div:last-child {\n            margin-bottom: 0px;\n            margin-right: auto;\n        }\n    }\n`;\n\nexport { ServiceTypeSectionContainer, ServiceTypeWrapper };\n\nconst ServiceTypeCardWrapper = styled.div`\n    width: 368px;\n    height: 410px;\n    padding: 16px;\n    border-radius: 4px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    background-color: #ffffff;\n    border: 4px solid ${props => (props.selected ? '#3bc1ff' : '#e6e6e6')};\n\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n\n    margin-right: 8px;\n\n    @media (max-width: 768px) {\n        margin-right: auto;\n        margin: 0 auto;\n        margin-bottom: 10px;\n\n        width: calc(100% - 32px);\n        height: auto;\n        border: 1px solid ${props => (props.selected ? '#3bc1ff' : '#e6e6e6')};\n    }\n`;\n\nconst ServiceTypeCardImg = styled.img`\n    width: 140px;\n    height: 140px;\n    object-fit: cover;\n`;\n\nconst ServiceTypeName = styled.span`\n    margin-top: 11px;\n    margin-bottom: 8px;\n\n    font-size: 24px;\n    font-weight: bold;\n    text-align: center;\n    letter-spacing: -0.5px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n        font-size: 22px;\n        line-height: 1.42;\n        letter-spacing: -0.5px;\n\n        margin-top: 0px;\n        margin-bottom: 0px;\n    }\n`;\n\nconst ServiceTypeDescription = styled.div`\n    word-break: keep-all;\n    font-size: 15px;\n    text-align: center;\n    letter-spacing: -0.3px;\n    margin-bottom: 36px;\n\n    max-width: 204px;\n`;\n\nconst NextStepButton = styled.div`\n    width: 280px;\n    height: 72px;\n    line-height: 72px;\n    text-align: center;\n\n    margin: 0 auto;\n    margin-top: 100px;\n\n    border-radius: 50vh;\n    cursor: pointer;\n\n    background-color: ${props => (props.on ? '#3bc1ff' : '#e6e6e6')};\n    color: ${props => (props.on ? '#ffffff' : '#afb0b2')};\n    font-size: 22px;\n    letter-spacing: -0.5px;\n\n    @media (max-width: 768px) {\n        height: 55px;\n        line-height: 55px;\n        font-size: 16px;\n        letter-spacing: -0.1px;\n\n        margin-top: 56px;\n    }\n`;\n\nconst LastStepButton = styled(NextStepButton)`\n    @media (max-width: 768px) {\n        margin-top: 32px;\n        margin-bottom: 32px;\n    }\n`;\nexport { MobileBr, DesktopBr, NextStepButton, LastStepButton, ServiceTypeCardWrapper, ServiceTypeCardImg, ServiceTypeName, ServiceTypeDescription };\n\nconst FormContainer = styled.div`\n    width: 100%;\n    background-color: #f9f9f9;\n\n    padding-top: 68px;\n    padding-bottom: 80px;\n\n    background-image: url('/assets/images/artwork_both_bg.png');\n    background-size: contain;\n    background-position: 50% 70%;\n    background-repeat: no-repeat;\n\n    @media (max-width: 768px) {\n        background: transparent;\n\n        padding-top: 0px;\n        padding-bottom: 0px;\n    }\n`;\n\nconst FormWrapper = styled.div`\n    width: 646px;\n    margin: 0 auto;\n    background-color: #ffffff;\n    border: 1px solid #e6e6e6;\n    border-radius: 8px;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n\n    padding: 48px 32px;\n    margin-bottom: 64px;\n\n    @media (max-width: 768px) {\n        width: 100%;\n        border-radius: 0px;\n        box-shadow: unset;\n        border: 0px;\n\n        padding: 32px 16px;\n        margin-bottom: 0px;\n    }\n\n    .type-button-wrapper {\n        width: 100%;\n        height: 48px;\n\n        background-color: white;\n        border: 1px solid #e6e6e6;\n        border-radius: 4px;\n\n        display: flex;\n        align-items: center;\n\n        > .type-button {\n            width: 50%;\n            height: 100%;\n            line-height: 48px;\n\n            text-align: center;\n            cursor: pointer;\n\n            font-size: 16px;\n            letter-spacing: -0.2px;\n            color: rgba(0, 0, 0, 0.2);\n        }\n\n        > .type-button.active {\n            background: rgba(0, 0, 0, 0.7);\n            border-radius: 4px;\n            color: #f9f9f9;\n        }\n    }\n`;\n\nconst FormMainTitle = styled.h3`\n    font-size: 32px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    letter-spacing: -0.7px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-top: 0px;\n    margin-bottom: 16px;\n\n    @media (max-width: 768px) {\n        font-size: 22px;\n        line-height: 1.42;\n        letter-spacing: -0.5px;\n        margin-bottom: 8px;\n    }\n`;\n\nconst FormMainAlert = styled.p`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n\n    margin-top: 0px;\n    margin-bottom: 32px;\n\n    word-break: keep-all;\n\n    @media (max-width: 768px) {\n        font-size: 14px;\n        line-height: 1.58;\n        letter-spacing: -0.3px;\n    }\n`;\n\nexport { FormContainer, FormWrapper, FormMainTitle, FormMainAlert };\n\nconst ServiceName = styled.h5`\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: #3bc1ff;\n\n    margin-bottom: 40px;\n`;\n\nconst Sexes = styled.div`\n    display: flex;\n    width: 100%;\n    height: 100%;\n    line-height: 44px;\n\n    > span {\n        display: inline-block;\n        cursor: pointer;\n\n        flex: 1;\n        height: 100%;\n        border-radius: 4px;\n        border: 1px solid #e9e9e9;\n\n        text-align: center;\n        color: rgba(0, 0, 0, 0.7);\n        font-size: 14px;\n        letter-spacing: -0.2px;\n\n        margin-right: 8px;\n    }\n\n    > span.active {\n        background-color: #3bc1ff;\n        color: white;\n    }\n\n    > span:last-child {\n        margin-right: 0px;\n    }\n`;\n\nconst LabelDescription = styled.span`\n    font-size: 13px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #afb0b2;\n    margin-left: 4px;\n`;\n\nconst FlexFormWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: center;\n\n    max-width: 1120px;\n    margin: 0 auto;\n\n    > div:first-child {\n        margin-right: 20px;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n\n        > div:first-child {\n            margin-right: 0px;\n            margin-bottom: 0px;\n        }\n    }\n`;\n\nconst ResultFormWrapper = styled(FormWrapper)`\n    width: auto;\n    flex: 1;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nconst LabelAndValueRow = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    ${props => props.borderColor && `border-bottom: 1px solid ${props.borderColor};`}\n\n    padding-top: 8px;\n    padding-bottom: 8px;\n`;\n\nconst LabelValue = styled.span`\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        ine-height: 1.42;\n    }\n`;\n\nconst PriceValue = styled.span`\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: right;\n    color: #3bc1ff;\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        ine-height: 1.42;\n    }\n`;\n\nconst PriceDetailLabel = styled.span`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    padding-left: 12px;\n    position: relative;\n\n    > span {\n        position: absolute;\n        top: 0px;\n        left: 0px;\n        font-size: 12px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.57;\n        letter-spacing: -0.3px;\n        text-align: left;\n        color: #cecfd0;\n    }\n`;\n\nconst PriceDetailValue = styled.span`\n    font-size: 16px;\n    font-weight: ${props => (props.value ? 'bold' : 'normal')};\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.2px;\n    text-align: right;\n    color: ${props => (props.value ? '#3bc1ff' : '#afb0b2')};\n`;\n\nconst DashAndText = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    img {\n        width: 16px;\n        height: 16px;\n        margin-top: 4px;\n        margin-right: 8px;\n    }\n\n    > a {\n        color: #3bc1ff;\n        font-size: 14px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.58;\n        letter-spacing: -0.3px;\n        text-align: left;\n    }\n\n    > span {\n        font-size: 15px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.57;\n        letter-spacing: -0.3px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n        word-break: keep-all;\n    }\n\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    word-break: keep-all;\n\n    ${props => props.alert && `color: #ff5500;`}\n\n    @media (max-width: 768px) {\n        font-size: 14px;\n\n        > span {\n            font-size: 14px;\n        }\n    }\n`;\nexport {\n    DashAndText,\n    LabelValue,\n    PriceDetailLabel,\n    PriceDetailValue,\n    ServiceName,\n    LabelAndValueRow,\n    PriceValue,\n    Sexes,\n    LabelDescription,\n    FlexFormWrapper,\n    ResultFormWrapper,\n};\n\nconst CongraturateLogo = styled.div`\n    width: 100%;\n    height: auto;\n\n    text-align: center;\n\n    margin-top: 12px;\n    margin-bottom: 12px;\n\n    > img {\n        width: 200px;\n        height: 200px;\n    }\n`;\n\nconst DoneResultWrapper = styled.div`\n    padding-top: 40px;\n    padding-bottom: 40px;\n    border-bottom: 1px solid #e9e9e9;\n`;\n\nconst MobileStepImage = styled.div`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n        margin-top: 32px;\n        text-align: center;\n        width: 100%;\n\n        > img {\n            margin: 0 auto;\n            width: 174px;\n            height: 174px;\n        }\n    }\n`;\n\nexport { CongraturateLogo, MobileStepImage, DoneResultWrapper };\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mainColor } from '../../../theme';\n\nexport const Container = styled.div`\n    width: 100vw;\n    height: auto;\n    padding-top: 55px;\n`;\n\nexport const TopWrapper = styled.div`\n    width: 100%;\n    height: auto;\n\n    // background-image: url('/assets/images/main-background.png');\n    // background-position: center;\n    // background-repeat: no-repeat;\n    // background-size: cover;\n    background-color: #80abff;\n`;\n\nexport const BottomWrapper = styled.div`\n    width: 100%;\n    background-color: white;\n`;\n\nexport const InnerContainer = styled.div`\n    max-width: 1080px;\n    margin: 0 auto;\n\n    padding: 80px 0px;\n    position: relative;\n\n    img.bg {\n        width: auto;\n        height: 100%;\n\n        position: absolute;\n        top: 0px;\n        right: 0px;\n    }\n\n    @media (max-width: 1080px) {\n        padding: 80px 16px;\n        img.bg {\n            display: none;\n        }\n\n        br {\n            display: block;\n        }\n    }\n\n    @media (max-width: 768px) {\n        padding: 80px 16px;\n\n        br {\n            display: block;\n        }\n    }\n`;\n\nexport const Logo = styled.img`\n    display: inline-block;\n    width: 200px;\n    object-fit: contain;\n`;\n\nexport const Title = styled.p`\n    margin-bottom: 24px;\n\n    font-size: 22px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n`;\n\nexport const MediumText = styled.p`\n    margin-bottom: 8px;\n\n    font-size: 36px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.33;\n    letter-spacing: -0.7px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-size: 36px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.33;\n        letter-spacing: -0.7px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n        border-bottom: 1px solid #000000;\n    }\n`;\n\nexport const Noti = styled.div`\n    font-size: 13px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.54;\n    letter-spacing: -0.15px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.6);\n    word-break: keep-all;\n`;\n\nexport const ApplyButton = styled.span`\n    padding: 14px 28px;\n    background-color: #3bc1ff;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.4;\n    letter-spacing: -0.1px;\n    text-align: center;\n    color: #ffffff;\n\n    border-radius: 4px;\n    min-width: 230px;\n    overflow: hidden;\n\n    display: inline-block;\n    margin-top: 42px;\n    cursor: pointer;\n\n    &:hover {\n        transition: all 0.5s;\n        background-color: ${mainColor};\n        color: white;\n    }\n`;\n\nexport const LargeText = styled.p`\n    margin-bottom: 0px;\n\n    font-weight: bold;\n    color: #ffffff;\n    font-size: 32px;\n\n    padding: 2.5px;\n    border-bottom: 4px solid #ffffff;\n    display: inline-block;\n`;\n\nexport const FlexWrapper = styled.div`\n    display: flex;\n\n    > div {\n        flex: 1;\n        margin-bottom: 32px;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const FlexTitle = styled.p`\n    display: inline-block;\n\n    font-size: 16px;\n    font-weight: bold;\n    color: #161616;\n\n    padding: 12px;\n    border-bottom: 0.5px solid #161616;\n\n    margin-bottom: 20px;\n`;\n\nexport const Contact = styled.p`\n    margin-bottom: 8px;\n\n    font-weight: bold;\n    color: #161616;\n    font-size: 20px;\n`;\n\nexport const ContactTime = styled.p`\n    font-weight: bold;\n    color: #161616;\n    font-size: 12px;\n`;\n\nexport const Link = styled.a`\n    display: inline-block;\n    margin-bottom: 8px;\n\n    color: #565656;\n    font-size: 12px;\n    font-weight: bold;\n    text-decoration: underline;\n`;\n","import React from 'react';\nimport { message } from 'antd';\nimport axios from '../../Lib/axios';\n\nimport { DivisionLine, WithmateInput, WithmateLabel } from '../../Components/Common/input';\nimport { FlexFormWrapper, FormMainTitle, FormWrapper, LabelAndValueRow, PriceDetailLabel, PriceDetailValue, ResultFormWrapper, ServiceName, Sexes } from '../Reserve/reserve.styled';\nimport { FlexWrapper } from '../Apply/Ready/ready.styled';\nimport { HalfWidthButton } from '../../Components/Common/button';\n\nclass LongTermCareComponent extends React.PureComponent {\n    state = {\n        name: '',\n        age: '',\n        contact: '',\n        sex: '',\n        region: '',\n        gradePresence: '',\n        gradeLevel: ''\n    };\n\n    onLongTermCare = async () => {\n        const userId = localStorage.getItem('id');\n        const { name, age, contact, sex, region, gradePresence, gradeLevel } = this.state;\n\n        if (!name) {\n            return this.setState({\n                modal: true,\n                modalTitle: '이름을 입력해주세요.',\n                modalInfo: '장기요양등급 상담하시는분의 이름을 입력해주세요.',\n            });\n        }\n\n        if (!age) {\n            return this.setState({\n                modal: true,\n                modalTitle: '나이를 입력해주세요.',\n                modalInfo: '장기요양등급 상담하시는분의 나이를 입력해주세요.',\n            });\n        }\n\n        if (!contact) {\n            return this.setState({\n                modal: true,\n                modalTitle: '연락처를 입력하세요.',\n                modalInfo: '장기요양등급 상담하시는분의 연락처를 입력해주세요.',\n            });\n        }\n\n        if (!sex) {\n            return this.setState({\n                modal: true,\n                modalTitle: '성별을 선택하세요.',\n                modalInfo: '장기요양등급 상담하시는분의 성별을 선택해주세요.',\n            });\n        }\n\n        if (!region) {\n            return this.setState({\n                modal: true,\n                modalTitle: '거주지 지역을 입력하세요.',\n                modalInfo: '장기요양등급 상담하시는 분의 거주지 지역을 입력해주세요.',\n            });\n        }\n\n        if (!gradePresence) {\n            return this.setState({\n                modal: true,\n                modalTitle: '요양등급 유무를 선택하세요.',\n                modalInfo: '요양등급 유무를 선택해주세요.',\n            });\n        }\n\n\n        const { data } = await axios.post('/v1/longTermCare/add', { userId, name, age, contact, sex, region, gradePresence, gradeLevel });\n\n        if (!data) return message.error('죄송합니다. 일시적인 서버 장애가 발생하였습니다.');\n        if (data === 'check parameters') return message.warning('필수 정보들을 입력해주세요.');\n        if (data === 'success') {\n            message.success('장기요양등급 신청서 작성이 완료되었습니다. 빠른 시일내에 상담 연락드리겠습니다.');\n            setTimeout(() => {\n                this.props.history.push('/');\n            }, 600);\n        }\n    };\n\n    handleChange = e => {\n        this.setState({ [e.target.title]: e.target.value });\n    };\n\n    render() {\n        return (\n            <div style={{ padding: '10px', marginTop: '100px' }}>\n                <FlexFormWrapper>\n                    <FormWrapper>\n                        <FormMainTitle>장기요양 등급 상담 신청서</FormMainTitle>\n                        <ServiceName style={{ fontSize: '15px' }}>장기요양 등급 신청서를 작성하시면 상담신청이 가능합니다.</ServiceName>\n\n                        <FlexWrapper withHalf>\n                            <div style={{ flex: 1 }}>\n                                <WithmateLabel required>이름</WithmateLabel>\n                                <WithmateInput\n                                    type='text'\n                                    title='name'\n                                    value={this.state.name || ''}\n                                    onChange={this.handleChange}\n                                />\n                            </div>\n                            &ensp;&ensp;\n                            <div style={{ flex: 1 }}>\n                                <WithmateLabel required>나이</WithmateLabel>\n                                <WithmateInput maxLength='2' placeholder='50' title='age' suffix='세' value={this.state.age} onChange={this.handleChange} />\n                            </div>\n                        </FlexWrapper>\n\n                        <FlexWrapper withHalf>\n                            <div style={{ flex: 1 }}>\n                                <WithmateLabel required>연락처</WithmateLabel>\n                                <WithmateInput maxLength='11' title='contact' value={this.state.contact} onChange={this.handleChange} />\n                            </div>\n                            &ensp;&ensp;\n                            <div style={{ flex: 1 }}>\n                                <WithmateLabel required>성별</WithmateLabel>\n                                <Sexes style={{ height: '46px' }}>\n                                    <span\n                                        className={this.state.sex === '남성' ? 'active' : 'inactive'}\n                                        onClick={() => {\n                                            this.handleChange({ target: { title: 'sex', value: '남성' } });\n                                        }}\n                                    >\n                                        남성\n                                    </span>\n                                    <span\n                                        className={this.state.sex === '여성' ? 'active' : 'inactive'}\n                                        onClick={() => {\n                                            this.handleChange({ target: { title: 'sex', value: '여성' } });\n                                        }}\n                                    >\n                                        여성\n                                    </span>\n                                </Sexes>\n                            </div>\n                        </FlexWrapper>\n\n                        <FlexWrapper withHalf>\n                            <div style={{ flex: 1 }}>\n                                <WithmateLabel required>지역</WithmateLabel>\n                                <WithmateInput placeholder='지역의 구까지 입력해주세요. ex) 서울특별시 강남구' title='region' value={this.state.region} onChange={this.handleChange} />\n                            </div>\n                        </FlexWrapper>\n\n                        <FlexWrapper withHalf>\n                            <div style={{ flex: 1 }}>\n                                <WithmateLabel required>요양등급 유무</WithmateLabel>\n                                <Sexes style={{ height: '46px' }}>\n                                    <span\n                                        className={this.state.gradePresence === '있다' ? 'active' : 'inactive'}\n                                        onClick={() => {\n                                            this.handleChange({ target: { title: 'gradePresence', value: '있다' } });\n                                        }}\n                                    >\n                                        있다\n                                    </span>\n                                    <span\n                                        className={this.state.gradePresence === '없다' ? 'active' : 'inactive'}\n                                        onClick={() => {\n                                            this.handleChange({ target: { title: 'gradePresence', value: '없다' } });\n                                        }}\n                                    >\n                                        없다\n                                    </span>\n                                </Sexes>\n                            </div>\n                            &ensp;&ensp;\n                            {this.state.gradePresence === '있다' ? <>\n                                <div style={{ flex: 1 }}>\n                                    <WithmateLabel required>등급을 입력하세요</WithmateLabel>\n                                    <WithmateInput title='gradeLevel' suffix='등급' value={this.state.gradeLevel} onChange={this.handleChange} />\n                                </div>\n                            </> : null}\n                        </FlexWrapper>\n                    </FormWrapper>\n\n                    <ResultFormWrapper>\n                        <FormMainTitle style={{ fontSize: '25px' }}>신청 내역</FormMainTitle>\n\n                        <LabelAndValueRow borderColor='#cecfd0'>\n                        </LabelAndValueRow>\n\n                        <DivisionLine x_small />\n                        <DivisionLine />\n\n                        <LabelAndValueRow>\n                            <PriceDetailLabel><span>* </span>이름</PriceDetailLabel>\n                            <PriceDetailValue>{this.state.name}</PriceDetailValue>\n                        </LabelAndValueRow>\n                        <LabelAndValueRow>\n                            <PriceDetailLabel><span>* </span>나이</PriceDetailLabel>\n                            <PriceDetailValue>{this.state.age + ' 세'}</PriceDetailValue>\n                        </LabelAndValueRow>\n                        <LabelAndValueRow>\n                            <PriceDetailLabel><span>* </span>연락처</PriceDetailLabel>\n                            <PriceDetailValue>{this.state.contact}</PriceDetailValue>\n                        </LabelAndValueRow>\n                        <LabelAndValueRow>\n                            <PriceDetailLabel><span>* </span>성별</PriceDetailLabel>\n                            <PriceDetailValue>{this.state.sex}</PriceDetailValue>\n                        </LabelAndValueRow>\n                        <LabelAndValueRow>\n                            <PriceDetailLabel><span>* </span>지역</PriceDetailLabel>\n                            <PriceDetailValue>{this.state.region}</PriceDetailValue>\n                        </LabelAndValueRow>\n                        <LabelAndValueRow>\n                            <PriceDetailLabel><span>* </span>장애등급 유무</PriceDetailLabel>\n                            <PriceDetailValue>{this.state.gradePresence}</PriceDetailValue>\n                        </LabelAndValueRow>\n                        {this.state.gradePresence == '있다' ? <>\n                            <LabelAndValueRow>\n                                <PriceDetailLabel><span>* </span>장애등급</PriceDetailLabel>\n                                <PriceDetailValue>{this.state.gradeLevel}</PriceDetailValue>\n                            </LabelAndValueRow>\n                        </> : null}\n\n                        <DivisionLine /><DivisionLine /><DivisionLine /><DivisionLine small />\n                        <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff'\n                            onClick={this.onLongTermCare}\n                        >\n                            신청하기\n                        </HalfWidthButton>\n                    </ResultFormWrapper>\n                </FlexFormWrapper>\n            </div>\n        );\n    }\n}\nexport default LongTermCareComponent;","import React from 'react';\nimport { AutoComplete, Button } from 'antd';\nimport styled from 'styled-components';\nimport { DivisionLine } from '../../Components/Common/input';\nimport Background from './login_bg.png';\nimport Checkpoint from './checkpoint.png';\n\nclass SuccessComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='success-container' style={{ backgroundImage: 'url('+Background+')' }}>\n                <div className='inner-container' style={{ display: 'flex', justifyContent: 'center'}}>\n                    <div className='success-form' style={{ border: '1px solid lightgray', borderRadius: '7px', width: '550px', marginTop: '40px', paddingTop: '80px', maxWidth: '480px' , backgroundColor: 'white' }}>\n                        <div className='success-title'>\n                            <img class=\"successImg\" src={Checkpoint} style={{ width: '70px', height: '70px', display: 'block', margin: '0px auto' }}/>\n                            <DivisionLine />\n                            <h1 style={{ textAlign: 'center' }}>회원가입이 <b>완료</b> 되었습니다.</h1>\n                        </div>\n\n                        <DivisionLine /><DivisionLine />\n\n                        <div className='form-success-type' style={{ textAlign: 'center' }}>\n                            <div>\n                                <h4>※ 위드메이트의 서비스를 더욱 편리하게 사용할 수 있도록 <br/>\n                                    <b>환자 프로필</b>을 등록하실 수 있습니다.</h4>\n                            </div>\n                        </div>\n                        \n                        <DivisionLine />\n                        <hr style={{ textAlgn: 'center', width: '320px', color: 'gray' }}/>\n\n                        <div className='form'  style={{ textAlign: 'center' }}>\n                            <Button type='primary' style={{ borderRadius: '4px', marginTop: '20px', backgroundColor: 'gray' }} \n                                    onClick={() => {\n                                        this.props.history.push('/user/mypage/profile');\n                                    }}\n                            >\n                                프로필 등록\n                            </Button>\n                            &nbsp;&nbsp;&nbsp;\n                            <Button type='primary' style={{ borderRadius: '4px', marginTop: '20px' }} \n                                    onClick={() => {\n                                        this.props.history.push('/');\n                                    }}\n                            >\n                                다음에 하기\n                            </Button>\n                        </div>\n                        <DivisionLine />\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default SuccessComponent;","// import React, { useState } from 'react';\n// import { Document, Page, pdfjs } from 'react-pdf';\n// import samplePDF from '../PDFfile/withmate_service_manual.pdf';\n// import './servicePDF.css';\n\n// pdfjs.GlobalWorkerOptions.workerSrc = `//cdnjs.cloudflare.com/ajax/libs/pdf.js/${pdfjs.version}/pdf.worker.js`;\n\n// export default function ServicePDF() {\n//     const [numPages, setNumPages] = useState(null);\n\n//     function onDocumentLoadSuccess({ numPages }) {\n//         setNumPages(numPages);\n//     }\n\n//     return (\n//         <div style={{ height: '1000px', overflow: 'auto', overflowX: 'hidden' }}>\n//             <Document\n//                 className={'PDFDocument'}\n//                 file={samplePDF}\n//                 options={{ workerSrc: \"/pdf.worker.js\" }}\n//                 onLoadSuccess={onDocumentLoadSuccess}\n//             >\n//                 {Array.from(new Array(numPages), (el, index) => (\n//                     <Page className={'PDFPage'} key={`page_${index + 1}`} pageNumber={index + 1} width={1000}/>\n//                 ))}\n//             </Document>\n//         </div>\n//     );\n// }\n\nimport React, { Component } from \"react\";\n\nexport default class ServicePDF extends Component {\n  constructor() {\n    super();\n    this.state = {\n      iFrameHeight: \"0px\"\n    };\n  }\n\n  render() {\n    return (\n      <div>\n        <iframe\n          style={{\n            position: \"absolute\",\n            top: '60px',\n            left: 0,\n            width: \"100%\",\n            height: \"95%\"\n          }}\n          src={`https://drive.google.com/file/d/141x-SJYLk8W5ix4vjVWKi3738Osux2bT/preview`}\n          frameBorder=\"0\"\n        />\n      </div>\n    );\n  }\n}\n","import { message } from 'antd';\nimport React from 'react';\nimport ServiceManual from './servicePDF';\n\nclass ManualComponent extends React.PureComponent {\n    componentDidMount = () => {\n        if (!localStorage.getItem('id')) {\n            message.warning('서비스 매뉴얼을 보시려면 로그인 후 이용해주세요.');\n            return this.props.history.push('/user/login');\n        }\n        this.props.history.push('/service/manual');\n    }\n\n    render() {\n        return (\n            <div className='pdf-form'>\n                <ServiceManual />\n            </div>\n        );\n    }\n}\nexport default ManualComponent;","// import React, { useState } from 'react';\n// import { Document, Page, pdfjs } from 'react-pdf';\n// import samplePDF from '../PDFfile/withmate_platform_manual.pdf';\n// import './platformPDF.css';\n\n// pdfjs.GlobalWorkerOptions.workerSrc = `//cdnjs.cloudflare.com/ajax/libs/pdf.js/${pdfjs.version}/pdf.worker.js`;\n\n// export default function PlatformPDF() {\n//     const [numPages, setNumPages] = useState(null);\n\n//     function onDocumentLoadSuccess({ numPages }) {\n//         setNumPages(numPages);\n//     }\n\n//     return (\n//         <div style={{ height: '1000px', overflow: 'auto', overflowX: 'hidden' }}>\n//             <Document\n//                 className={'PDFDocument'}\n//                 file={samplePDF}\n//                 options={{ workerSrc: \"/pdf.worker.js\" }}\n//                 onLoadSuccess={onDocumentLoadSuccess}\n//             >\n//                 {Array.from(new Array(numPages), (el, index) => (\n//                     <Page className={'PDFPage'} key={`page_${index + 1}`} pageNumber={index + 1} width={1000}/>\n//                 ))}\n//             </Document>\n//         </div>\n//     );\n// }\n\nimport React, { Component } from \"react\";\n\nexport default class PlatformPDF extends Component {\n  constructor() {\n    super();\n    this.state = {\n      iFrameHeight: \"0px\"\n    };\n  }\n\n  render() {\n    return (\n      <div>\n        <iframe\n          style={{\n            position: \"absolute\",\n            top: '60px',\n            left: 0,\n            width: \"100%\",\n            height: \"95%\"\n          }}\n          src={`https://drive.google.com/file/d/1uC2X66wxaGyIiekW_lkDsuLeIbPcMf_t/preview`}\n          frameBorder=\"0\"\n        />\n      </div>\n    );\n  }\n}\n","import { message } from 'antd';\nimport React from 'react';\nimport PlatformManual from './platformPDF';\n\nclass ManualComponent extends React.PureComponent {\n    componentDidMount = () => {\n        if (!localStorage.getItem('id')) {\n            message.warning('플랫폼 매뉴얼을 보시려면 로그인 후 이용해주세요.');\n            return this.props.history.push('/user/login');\n        }\n        this.props.history.push('/platform/manual');\n    }\n\n    render() {\n        return (\n            <div className='pdf-form'>\n                <PlatformManual />\n            </div>\n        );\n    }\n}\nexport default ManualComponent;","import { Button } from 'antd';\nimport Title from 'antd/lib/typography/Title';\nimport React from 'react';\nimport styled from 'styled-components';\nimport { WithmateLabel } from '../../../../Components/Common/input';\n\nexport const EduVideo1 = () => {\n  return (\n    <VideoSectionContainer>\n      <VideoSectionInnerContainer>\n        <div style={{ paddingBottom: '30px' }}>\n          <Title style={{ fontWeight: 'bold' }}>메이트 온라인 교육영상</Title><br />\n          <p style={{ color: '#3bc1ff'}}>* 해당 영상 화면을 클릭하시면 재생/일시정지가 가능합니다.</p><br />\n          <p style={{ paddingBottom: '10px' }}>온라인 교육영상을 모두 시청하신 후 <MobileBr />아래 주소의 구글폼에 접속하셔서<br/>\n             교육영상 문제를 풀고 제출하시면 <MobileBr />확인 후 메이트 지원 합격안내를 해드립니다.\n          </p>\n            <Button \n              onClick={() => {\n                window.open('https://docs.google.com/forms/d/e/1FAIpQLSfimp7QrRY0OkrMQQiZLQ3xFodaD7KosDL7PRsIcypencUaXg/viewform?usp=share_link')\n              }}\n              style={{ width: '250px', height: '40px', fontSize: '20px', textAlign: 'center' }}\n          >\n            메이트 교육영상 문제풀기\n          </Button>\n        </div>\n        <WithmateLabel style={{ fontSize: '15px' }}>병원동행 매니저 교육 1: 병원 동행 서비스의 정의</WithmateLabel>\n        <VideoArea>\n          <iframe\n            width=\"100%\"\n            height=\"100%\"\n            src=\"https://youtube.com/embed/3f-CHGx75LY?modestbranding=1?cc_load_policy=1&controls=0&rel=0&disablekb=1\"\n            title=\"withmate YouTube video player2\"\n            allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\"\n            allowFullScreen\n            loop={true}\n            controls={false}\n          ></iframe>\n        </VideoArea>\n      </VideoSectionInnerContainer>\n    </VideoSectionContainer>\n  );\n};\n\nconst VideoSectionContainer = styled.div`\n  padding-top: 105px;\n  padding-bottom: 30px;\n\n  width: 100%;\n\n  @media (max-width: 768px) {\n    text-align: center;\n    padding-top: 100px;\n    // padding-top: 10px;\n    // padding-bottom: 0px;\n    padding-bottom: 10px;\n  }\n`;\n\nconst VideoSectionInnerContainer = styled.div`\n  width: 100%;\n  max-width: 1120px;\n  margin: 0 auto;\n`;\n\nconst VideoSectionTitle = styled.h4`\n  font-size: 22px;\n  font-weight: bold;\n  font-stretch: normal;\n  font-style: normal;\n  line-height: 1.42;\n  letter-spacing: -0.5px;\n  text-align: center;\n  color: rgba(0, 0, 0, 0.6);\n\n  margin-top: 0px;\n  margin-bottom: 105px;\n\n  @media (max-width: 768px) {\n    font-size: 14px;\n    margin-bottom: 68px;\n  }\n`;\n\nconst VideoArea = styled.div`\n  width: 100%;\n  height: calc(1120px / 16 * 9);\n  background-color: #000000;\n\n  > iframe,\n  video {\n    width: 100%;\n    height: 100%;\n  }\n\n  @media (max-width: 1120px) {\n    height: calc(100vw / 16 * 9);\n  }\n\n  @media (max-width: 768px) {\n    width: 100%;\n    height: calc(100vw / 16 * 9);\n    background-color: #000000;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > iframe,\n    video {\n      width: 100%;\n      height: 100%;\n    }\n  }\n`;\n\nconst MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;","import React from 'react';\nimport styled from 'styled-components';\nimport { WithmateLabel } from '../../../../Components/Common/input';\n\nexport const EduVideo2 = () => {\n    return (\n        <VideoSectionContainer>\n            <VideoSectionInnerContainer>\n            <WithmateLabel style={{ fontSize: '15px' }}>병원동행 매니저 교육 2: 메이트 - 안전한 동행</WithmateLabel>\n                <VideoArea>\n                    <iframe\n                        width=\"100%\"\n                        height=\"100%\"\n                        src=\"https://youtube.com/embed/pWcuUOdho-8?modestbranding=1?cc_load_policy=1&controls=0&rel=0&disablekb=1\"\n                        title=\"withmate YouTube video player\"\n                        allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\"\n                        allowFullScreen\n                        loop={true}\n                        controls={false}\n                    ></iframe>\n                </VideoArea>\n            </VideoSectionInnerContainer>\n        </VideoSectionContainer>\n    );\n};\n\nconst VideoSectionContainer = styled.div`\n  padding-top: 105px;\n  padding-bottom: 30px;\n\n  width: 100%;\n\n  @media (max-width: 768px) {\n    // padding-top: 62px;\n    padding-top: 10px;\n    // padding-bottom: 0px;\n    padding-bottom: 10px;\n  }\n`;\n\nconst VideoSectionInnerContainer = styled.div`\n  width: 100%;\n  max-width: 1120px;\n  margin: 0 auto;\n`;\n\nconst VideoSectionTitle = styled.h4`\n  font-size: 22px;\n  font-weight: bold;\n  font-stretch: normal;\n  font-style: normal;\n  line-height: 1.42;\n  letter-spacing: -0.5px;\n  text-align: center;\n  color: rgba(0, 0, 0, 0.6);\n\n  margin-top: 0px;\n  margin-bottom: 105px;\n\n  @media (max-width: 768px) {\n    font-size: 14px;\n    margin-bottom: 68px;\n  }\n`;\n\nconst VideoArea = styled.div`\n  width: 100%;\n  height: calc(1120px / 16 * 9);\n  background-color: #000000;\n\n  > iframe,\n  video {\n    width: 100%;\n    height: 100%;\n  }\n\n  @media (max-width: 1120px) {\n    height: calc(100vw / 16 * 9);\n  }\n\n  @media (max-width: 768px) {\n    width: 100%;\n    height: calc(100vw / 16 * 9);\n    background-color: #000000;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > iframe,\n    video {\n      width: 100%;\n      height: 100%;\n    }\n  }\n`;\n\nconst MobileBr = styled.br`\n  display: none;\n  @media (max-width: 768px) {\n    display: block;\n  }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { WithmateLabel } from '../../../../Components/Common/input';\n\nexport const EduVideo3 = () => {\n    return (\n        <VideoSectionContainer>\n            <VideoSectionInnerContainer>\n            <WithmateLabel style={{ fontSize: '15px' }}>병원동행 매니저 교육 3: 위드메이트 플랫폼 사용 매뉴얼</WithmateLabel>\n                <VideoArea>\n                    <iframe\n                        width=\"100%\"\n                        height=\"100%\"\n                        src=\"https://youtube.com/embed/juq5t-NyCsA?modestbranding=1?cc_load_policy=1&controls=0&rel=0&disablekb=1\"\n                        title=\"withmate YouTube video player3\"\n                        allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\"\n                        allowFullScreen\n                        loop={true}\n                        controls={false}\n                    ></iframe>\n                </VideoArea>\n            </VideoSectionInnerContainer>\n        </VideoSectionContainer>\n    );\n};\n\nconst VideoSectionContainer = styled.div`\n  padding-top: 105px;\n  padding-bottom: 30px;\n\n  width: 100%;\n\n  @media (max-width: 768px) {\n    // padding-top: 62px;\n    padding-top: 10px;\n    // padding-bottom: 0px;\n    padding-bottom: 10px;\n  }\n`;\n\nconst VideoSectionInnerContainer = styled.div`\n  width: 100%;\n  max-width: 1120px;\n  margin: 0 auto;\n`;\n\nconst VideoSectionTitle = styled.h4`\n  font-size: 22px;\n  font-weight: bold;\n  font-stretch: normal;\n  font-style: normal;\n  line-height: 1.42;\n  letter-spacing: -0.5px;\n  text-align: center;\n  color: rgba(0, 0, 0, 0.6);\n\n  margin-top: 0px;\n  margin-bottom: 105px;\n\n  @media (max-width: 768px) {\n    font-size: 14px;\n    margin-bottom: 68px;\n  }\n`;\n\nconst VideoArea = styled.div`\n  width: 100%;\n  height: calc(1120px / 16 * 9);\n  background-color: #000000;\n\n  > iframe,\n  video {\n    width: 100%;\n    height: 100%;\n  }\n\n  @media (max-width: 1120px) {\n    height: calc(100vw / 16 * 9);\n  }\n\n  @media (max-width: 768px) {\n    width: 100%;\n    height: calc(100vw / 16 * 9);\n    background-color: #000000;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > iframe,\n    video {\n      width: 100%;\n      height: 100%;\n    }\n  }\n`;\n\nconst MobileBr = styled.br`\n  display: none;\n  @media (max-width: 768px) {\n    display: block;\n  }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { WithmateLabel } from '../../../../Components/Common/input';\n\nexport const EduVideo4 = () => {\n    return (\n        <VideoSectionContainer>\n            <VideoSectionInnerContainer>\n            <WithmateLabel style={{ fontSize: '15px' }}>병원동행 매니저 교육 4: 메이트 학습 매뉴얼</WithmateLabel>\n                <VideoArea>\n                    <iframe\n                        width=\"100%\"\n                        height=\"100%\"\n                        src=\"https://youtube.com/embed/S9daiT1kMmE?modestbranding=1?cc_load_policy=1&controls=0&rel=0&disablekb=1\"\n                        title=\"withmate YouTube video player4\"\n                        allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\"\n                        allowFullScreen\n                        loop={true}\n                        controls={false}\n                    ></iframe>\n                </VideoArea>\n            </VideoSectionInnerContainer>\n        </VideoSectionContainer>\n    );\n};\n\nconst VideoSectionContainer = styled.div`\n  padding-top: 105px;\n  padding-bottom: 30px;\n\n  width: 100%;\n\n  @media (max-width: 768px) {\n    // padding-top: 62px;\n    padding-top: 10px;\n    // padding-bottom: 0px;\n    padding-bottom: 10px;\n  }\n`;\n\nconst VideoSectionInnerContainer = styled.div`\n  width: 100%;\n  max-width: 1120px;\n  margin: 0 auto;\n`;\n\nconst VideoSectionTitle = styled.h4`\n  font-size: 22px;\n  font-weight: bold;\n  font-stretch: normal;\n  font-style: normal;\n  line-height: 1.42;\n  letter-spacing: -0.5px;\n  text-align: center;\n  color: rgba(0, 0, 0, 0.6);\n\n  margin-top: 0px;\n  margin-bottom: 105px;\n\n  @media (max-width: 768px) {\n    font-size: 14px;\n    margin-bottom: 68px;\n  }\n`;\n\nconst VideoArea = styled.div`\n  width: 100%;\n  height: calc(1120px / 16 * 9);\n  background-color: #000000;\n\n  > iframe,\n  video {\n    width: 100%;\n    height: 100%;\n  }\n\n  @media (max-width: 1120px) {\n    height: calc(100vw / 16 * 9);\n  }\n\n  @media (max-width: 768px) {\n    width: 100%;\n    height: calc(100vw / 16 * 9);\n    background-color: #000000;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > iframe,\n    video {\n      width: 100%;\n      height: 100%;\n    }\n  }\n`;\n\nconst MobileBr = styled.br`\n  display: none;\n  @media (max-width: 768px) {\n    display: block;\n  }\n`;\n","import { message } from 'antd';\nimport React from 'react';\nimport { EduVideo1 } from './VideoList/Video1';\nimport { EduVideo2 } from './VideoList/Video2';\nimport { EduVideo3 } from './VideoList/Video3';\nimport { EduVideo4 } from './VideoList/Video4';\n\nclass ManualComponent extends React.PureComponent {\n    state = {\n        // showEduVideo2: false,\n        // showEduVideo3: false,\n        // showEduVideo4: false\n    }\n\n    componentDidMount = () => {\n        if (!localStorage.getItem('id')) {\n            message.warning('메이트 교육 영상을 시청하시려면 로그인 후 이용해주세요.');\n            return this.props.history.push('/user/login');\n        }\n        this.props.history.push('/mateEducation/manual');\n\n        // this.timer2 = setTimeout(() => {\n        //     this.setState({ showEduVideo2: true });\n        //   }, 2400000); // 40분 뒤 (40 * 60 * 1000)\n          \n        //   this.timer3 = setTimeout(() => {\n        //     this.setState({ showEduVideo3: true });\n        //   }, 3600000); // 1시간 뒤 (60 * 60 * 1000)\n          \n        //   this.timer4 = setTimeout(() => {\n        //     this.setState({ showEduVideo4: true });\n        //   }, 4800000); // 1시간 20분 뒤 (80 * 60 * 1000)\n    }\n\n    // componentWillUnmount() {\n    //     clearTimeout(this.timer2);\n    //     clearTimeout(this.timer3);\n    //     clearTimeout(this.timer4);\n    // }\n\n    render() {\n        return (\n            <div className='video-form'>\n                <EduVideo1 />\n                <EduVideo2 />\n                <EduVideo3 />\n                <EduVideo4 />\n                {/* {this.state.showEduVideo2 && <EduVideo2 />}\n                {this.state.showEduVideo3 && <EduVideo3 />}\n                {this.state.showEduVideo4 && <EduVideo4 />} */}\n            </div>\n\n        );\n    }\n}\nexport default ManualComponent;","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../theme';\n\nconst StyledListContainer = styled.div`\n    padding-top: 55px;\n\n    .faq-header {\n        // border-bottom: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding: 0px;\n            padding-top: 82px;\n\n            @media (max-width: 768px) {\n                padding-top: 42px;\n            }\n\n            > .flex-wrapper {\n                position: relative;\n\n                .faq-main-title {\n                    flex: 1;\n                    .title {\n                        font-size: ${sizeHandler(30)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: #000000;\n                        margin-bottom: 8px;\n                    }\n\n                    .description {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-bottom: 82px;\n                    }\n                }\n\n                .img-section {\n                    position: absolute;\n                    bottom: -50px;\n                    right: 0px;\n\n                    > img {\n                        width: 100%;\n                        max-width: 549px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n\n                    @media (max-width: 768px) {\n                        display: none;\n                    }\n                }\n            }\n\n            .faq-nav {\n                display: flex;\n                align-items: center;\n\n                .nav-tab {\n                    margin-right: 32px;\n                    padding-bottom: 12px;\n                    position: relative;\n\n                    a {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #3bc1ff;\n                    }\n\n                    span.underline {\n                        background-color: #3bc1ff;\n                        position: absolute;\n                        bottom: 0px;\n                        left: 0px;\n\n                        &.active {\n                            width: 100%;\n                            height: 3px;\n                            display: inline-block;\n                        }\n                    }\n\n                    @media (max-width: 768px) {\n                        margin-right: 16px;\n                    }\n                }\n            }\n        }\n    }\n\n    .faq-contents {\n        .inner-container {\n            padding-top: 0px;\n\n            @media (max-width: 768px) {\n                h1 {\n                    font-size: 30px;\n                    margin-top: 60px;\n                }\n            }\n        }\n    }\n\n    .panel-header {\n        display: flex;\n        align-items: center;\n\n        .row-index {\n            width: 80px;\n            color: ${mainColor};\n            font-size: ${sizeHandler(14)};\n            font-weight: bold;\n        }\n\n        .title {\n            flex: 1;\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        @media (max-width: 768px) {\n            .title {\n                font-size: ${sizeHandler(14)};\n            }\n        }\n    }\n\n    .panel-content {\n        padding-left: 80px;\n\n        > p {\n            width: 60%;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .panel-contents-wrapper {\n            margin-top: 20px;\n            margin-bottom: 20px;\n\n            .panel-contents {\n                padding: 12px 0px;\n                border-bottom: 1px solid #e6e6e6;\n\n                &:first-child {\n                    border-top: 1px solid #e6e6e6;\n                }\n\n                .panel-content-subtitle {\n                    float: left;\n                    width: 40%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: left;\n                    color: ${mainColor};\n                }\n\n                .panel-content-subcontents {\n                    float: left;\n                    width: 50%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n\n                @media (max-width: 768px) {\n                    .panel-content-subtitle {\n                        width: 100%;\n                    }\n\n                    .panel-content-subcontents {\n                        width: 100%;\n                    }\n                }\n            }\n        }\n    }\n\n    h1 {\n        font-size: ${sizeHandler(34)};\n        font-weight: bold;\n        color: rgba(0, 0, 0, 0.8);\n        letter-spacing: -1px;\n\n        margin-bottom: 26px;\n        margin-top: 50px;\n    }\n\n    @media (max-width: 1120px) {\n        .faq-header {\n            .inner-container {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n        }\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .panel-header {\n            .row-index {\n                width: 70px;\n            }\n        }\n\n        .panel-content {\n            padding-left: 70px;\n\n            > p {\n                width: 90%;\n            }\n        }\n    }\n`;\nexport default StyledListContainer;\n","import styled from 'styled-components';\n\nconst StyledListContainer = styled.div`\n    // border-bottom: 1px solid #e6e6e6;\n`;\n\nexport const HeaderButton = styled.div`\n    cursor: pointer;\n\n    width: 265px;\n    height: 60px;\n    line-height: 60px;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: -0.2px;\n    text-align: center;\n    color: #ffffff;\n\n    margin-top: 40px;\n    margin-bottom: 90px;\n    border-radius: 4px;\n    background-color: #3bc1ff;\n\n    &:hover {\n        transition: all 0.5s;\n        opacity: 0.8;\n    }\n\n    @media (max-width: 768px) {\n        width: 230px;\n        height: 48px;\n        line-height: 48px;\n    }\n`;\n\nexport const NavigationTabWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: flex-start;\n`;\n\nexport const NavigationTab = styled.span`\n    position: relative;\n    display: inline-block;\n    margin-right: 44px;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: normal;\n    letter-spacing: normal;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.8);\n    padding-bottom: 20px;\n\n    cursor: pointer;\n\n    &.active {\n        color: #55d4ff;\n    }\n`;\n\nexport const NavigationTabUnderline = styled.span`\n    display: inline-block;\n    position: absolute;\n    left: 0px;\n    bottom: -3px;\n\n    width: 100%;\n    height: 3px;\n    background-color: #55d4ff;\n`;\n\nexport const CountDisplay = styled.div`\n    font-size: 36px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.44;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    > span {\n        color: #4bcfff;\n    }\n\n    margin-bottom: 20px;\n`;\n\nexport const CollapseContainer = styled.div`\n    .ant-collapse-icon-position-right > .ant-collapse-item > .ant-collapse-header {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n\n    .ant-collapse-content > .ant-collapse-content-box {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n`;\n\nexport const CollapseHeader = styled.div`\n    display: flex;\n    align-items: center;\n    border-bottom: 1px solid #e6e6e6;\n`;\n\nexport const CollapseTab = styled.div`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: normal;\n    color: rgba(0, 0, 0, 0.7);\n\n    padding-bottom: 11px;\n`;\n\nexport const CollapseTabOnlyDesktop = styled(CollapseTab)`\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const PanelHeader = styled.div`\n    display: flex;\n`;\n\nexport const PanelField = styled.div`\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    overflow: hidden;\n\n    ${props => (props.style ? props.style : `flex: 1;`)}\n    ${props => (props.onlyDesktop ? `display: block;` : null)} \n\n    &.title {\n        font-size: 16px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.56;\n        letter-spacing: normal;\n        color: rgba(0, 0, 0, 0.8);\n    }\n\n    @media (max-width: 768px) {\n        ${props => (props.onlyDesktop ? `display: none;` : null)}\n    }\n`;\n\nexport const Star = styled.img`\n    width: 16.7px;\n    height: 16px;\n    object-fit: contain;\n    margin-bottom: 4px;\n`;\n\nexport const ReviewTextWrapper = styled.div`\n    padding-left: 120px;\n    padding-right: 50px;\n\n    @media (max-width: 768px) {\n        padding-left: 0px;\n    }\n`;\n\nexport const ReviewText = styled.p`\n    font-size: 13px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.71;\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n`;\n\nexport const MyReview = styled.span`\n    display: inline-block;\n    width: 53px;\n    height: 20px;\n    line-height: 20px;\n    border-radius: 10px;\n    background-color: #3bc1ff;\n\n    font-size: 10px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: -0.21px;\n    color: #ffffff;\n    text-align: center;\n`;\n\nexport const ReviewMobileInfo = styled.div`\n    display: flex;\n    align-items: center;\n\n    margin-bottom: 27px;\n    display: none;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const ReviewerName = styled.span`\n    font-size: 13px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.71;\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 0px;\n    margin-right: 16px;\n`;\n\nexport default StyledListContainer;\n","import React from 'react';\nimport moment from 'moment';\nimport { Button, Popover } from 'antd';\nimport _ from 'lodash';\n\nimport { UNEMER, ASSIST } from '../../Lib/variables';\nimport { currencyFormatter, colorParserByStatus } from '../../Lib/utils';\n\nexport const callColumn = ({ onAccept, onCancel, onComplete }) => {\n    return [\n        {\n            title: '예약번호',\n            align: 'left',\n            width: '110px',\n            render: ({ reserve }) => <span>{reserve && reserve.length > 0 ? reserve[0].reserveCode : '-'}</span>,\n        },\n        {\n            title: '이용자 성함',\n            align: 'left',\n            ellipsis: true,\n            width: '72px',\n            render: (_id, { reserve }) => <span>{!reserve ? '-' : reserve[0].patient}</span>,\n        },\n        {\n            title: '진행 현황',\n            align: 'center',\n            ellipsis: true,\n            width: '100px',\n            render: ({ status }) =>\n                status === '결제대기' ? (\n                    <Button className='button' style={{ backgroundColor: '#3bc1ff' }}>\n                        잔금 결제\n                    </Button>\n                ) : (\n                    <span\n                        style={{\n                            fontWeight: 'bold',\n                            color: colorParserByStatus(status),\n                        }}\n                    >\n                        {status}\n                    </span>\n                ),\n        },\n        {\n            title: '서비스',\n            dataIndex: 'reserve',\n            align: 'left',\n            ellipsis: true,\n            width: '100px',\n            render: reserve => (\n                <span>{!reserve ? '-' : reserve[0].service === UNEMER ? '병원 동행 Pro' : reserve[0].service === ASSIST ? '병원 동행 Basic' : '-'}</span>\n            ),\n        },\n        {\n            title: '병원 위치',\n            align: 'left',\n            ellipsis: true,\n            width: '140px',\n            render: (createdAt, { reserve }) => <span>{!reserve ? '-' : reserve[0].starting}</span>,\n        },\n        {\n            title: '예약 일자',\n            align: 'left',\n            ellipsis: true,\n            width: '140px',\n            render: ({ reserve }) => <span>{moment(reserve[0].reserveDate).format('YYYY년 MM월 DD일 - HH:mm A')}</span>,\n        },\n    ];\n};\n\nexport const reserveColumn = ({ onMate, onCancel, onModify, onDetailModify, onServiceReport }) => {\n    return [\n        {\n            title: '예약번호',\n            dataIndex: 'reserveCode',\n            width: '110px',\n            render: reserveCode => <span>{reserveCode ? reserveCode : '-'}</span>,\n        },\n        {\n            title: '서비스',\n            dataIndex: 'service',\n            align: 'left',\n            ellipsis: true,\n            width: '100px',\n            render: service => <span>{service === UNEMER ? '병원 동행 Pro' : service === ASSIST ? '병원 동행 Basic' : '-'}</span>,\n        },\n        {\n            title: '이용자 성함',\n            dataIndex: 'patient',\n            align: 'left',\n            ellipsis: true,\n            width: '90px',\n            render: patient => <span>{patient}</span>,\n        },\n        {\n            title: '병원 위치',\n            dataIndex: 'starting',\n            align: 'left',\n            ellipsis: true,\n            width: '140px',\n            render: starting => <span>{starting}</span>,\n        },\n        {\n            title: '예약 일자',\n            dataIndex: 'reserveDate',\n            align: 'left',\n            ellipsis: true,\n            width: '140px',\n            render: reserveDate => <span>{moment(reserveDate).format('YYYY년 MM월 DD일 - HH:mm A')}</span>,\n        },\n        {\n            title: '진행 현황',\n            // dataIndex: 'status',\n            align: 'center',\n            ellipsis: true,\n            width: '100px',\n            render: ({ call }) =>\n                call[0].status === '결제대기' ? (\n                    <Button className='button' style={{ backgroundColor: '#3bc1ff' }}>\n                        잔금 결제\n                    </Button>\n                ) : (\n                    <span\n                        style={{\n                            fontWeight: 'bold',\n                            color: colorParserByStatus(call[0].status),\n                        }}\n                    >\n                        {call[0].status}\n                    </span>\n                ),\n        },\n        {\n            title: '결제',\n            align: 'center',\n            width: '70px',\n            ellipsis: true,\n            render: ({ paidStatus, call }) => (\n                <span style={{ color: paidStatus ? '#606060' : '#ff5500' }}>{call[0].status === '환불' ? '-' : paidStatus ? '완료' : '대기'}</span>\n            ),\n        },\n        {\n            title: '담당자',\n            align: 'center',\n            width: '70px',\n            ellipsis: true,\n            render: ({ call }) => (\n                <span\n                    onClick={() => {\n                        if (!_.isEmpty(call) && !_.isEmpty(call[0].mate)) onMate(call[0]);\n                    }}\n                    style={{ cursor: !_.isEmpty(call) && !_.isEmpty(call[0].mate) ? 'pointer' : undefined }}\n                >\n                    {!_.isEmpty(call) && !_.isEmpty(call[0].mate) ? call[0].mate[0].name : '-'}\n                </span>\n            ),\n        },\n        {\n            title: '-',\n            align: 'center',\n            width: '50px',\n            render: ({ _id, call, paidStatus, callId, service }) =>\n                call[0].status === '서비스 종료' ? (\n                    <Popover\n                        placement='bottomRight'\n                        content={\n                            <div className='popover-content-wrapper'>\n                                <p\n                                    style={{ borderBottom: '1px solid #606060' }}\n                                    onClick={() => {\n                                        onServiceReport(call[0], service);\n                                    }}\n                                >\n                                    서비스 리포트\n                                </p>\n                            </div>\n                        }\n                    >\n                        <span\n                            style={{\n                                cursor: 'pointer',\n                                display: 'inline-block',\n                                height: '24px',\n                                width: '24px',\n                                lineHeight: '22px',\n                                textAlign: 'center',\n                                border: '1px solid #e6e6e6',\n                                borderRadius: '12px',\n                            }}\n                        >\n                            <i style={{ fontSize: '11px', fontWeight: 300, color: '#3bc1ff' }} className='fas fa-ellipsis-h' />\n                        </span>\n                    </Popover>\n                ) : call[0].status === '접수대기' || (call[0].status === '예약완료' && paidStatus === false) ? (\n                    <Popover\n                        placement='bottomRight'\n                        content={\n                            <div className='popover-content-wrapper'>\n                                <p\n                                    style={{ borderBottom: '1px solid #606060' }}\n                                    onClick={() => {\n                                        call[0].status === '접수대기' ? onDetailModify(_id) : onModify(_id);\n                                    }}\n                                >\n                                    예약수정\n                                    <i className='fas fa-pen' color='#606060' style={{ marginLeft: '20px' }} />\n                                </p>\n                                <p\n                                    onClick={() => {\n                                        onCancel(callId);\n                                    }}\n                                >\n                                    예약취소\n                                    <i className='fas fa-times' color='#606060' style={{ marginLeft: '20px' }} />\n                                </p>\n                            </div>\n                        }\n                    >\n                        <span\n                            style={{\n                                cursor: 'pointer',\n                                display: 'inline-block',\n                                height: '24px',\n                                width: '24px',\n                                lineHeight: '22px',\n                                textAlign: 'center',\n                                border: '1px solid #e6e6e6',\n                                borderRadius: '12px',\n                            }}\n                        >\n                            <i style={{ fontSize: '11px', fontWeight: 300, color: '#3bc1ff' }} className='fas fa-ellipsis-h' />\n                        </span>\n                    </Popover>\n                ) : (\n                    '-'\n                ),\n        },\n    ];\n};\n\nexport const payHistoryColumn = [\n    {\n        title: '서비스',\n        dataIndex: 'service',\n        align: 'left',\n        ellipsis: true,\n        width: '100px',\n        render: service => <span>{service === UNEMER ? '병원 동행 Pro' : service === ASSIST ? '병원 동행 Basic' : '-'}</span>,\n    },\n    {\n        title: '요청사항',\n        dataIndex: 'type',\n        align: 'left',\n        ellipsis: true,\n        width: '60px',\n        render: type => (\n            <span\n                style={{\n                    fontSize: '14px',\n                    fontWeight: 'bold',\n                    letterSpacing: '-0.3px',\n                    color: type === 'paid' ? '#3bc1ff' : '#ff5500',\n                }}\n            >\n                {type === 'paid' ? '결제' : '환불'}\n            </span>\n        ),\n    },\n    {\n        title: '금액',\n        dataIndex: 'price',\n        align: 'left',\n        ellipsis: true,\n        width: '120px',\n        render: price => <span>{currencyFormatter(price)} KRW</span>,\n    },\n    {\n        title: '요청시간',\n        dataIndex: 'createdAt',\n        align: 'left',\n        ellipsis: true,\n        width: '140px',\n        render: createdAt => <span>{moment(createdAt).format('YYYY년 MM월 DD일 - hh:mm A')}</span>,\n    },\n    {\n        title: '상태',\n        dataIndex: 'status',\n        align: 'left',\n        ellipsis: true,\n        width: '80px',\n        render: status => <span style={{ fontSize: '14px', letterSpacing: '-0.3px', color: '#a7a7a7' }}>{status === true ? '완료' : '진행중'}</span>,\n    },\n];\n\nexport const newsEvent = [\n    {\n        title: '번호',\n        dataIndex: 'index',\n        align: 'center',\n        width: '80px',\n    },\n    {\n        title: '제목',\n        dataIndex: 'title',\n        align: 'left',\n        \n    },\n    {\n        title: '등록일',\n        dataIndex: 'createdAt',\n        align: 'center',\n        width: '100px',\n        render: createdAt => <span>{moment(createdAt).format('YY.MM.DD') || '0'}</span>\n    },\n];","import React from 'react';\nimport { Collapse, Icon, Table } from 'antd';\nimport { CollapseContainer } from '../../Review/List/list.styled';\n\nimport { newsEvent } from '../../../Components/Columns/user';\n\nexport default class Event extends React.PureComponent {\n\n    onRow = (row, index) => {\n        return {\n            onClick: () => {\n                this.props.history.push({\n                    pathname: `/newsEvent/info/${row._id}`,\n                    state: {\n                        id: row._id,\n                    },\n                });\n            },\n        };\n    };\n\n    render() {\n\n        return (\n            <div className='faq-container'>\n                <div className='faq-header'>\n                    <div className='inner-container'>\n                        <div className='flex-wrapper'>\n                            <div className='faq-main-title'>\n                                <p className='title'>위드메이트 소식</p>\n                                <p className='description'>위드메이트의 다양한 소식을 확인할 수 있습니다.</p>\n                            </div>\n                            <div className='img-section'>\n                                <img src={'/assets/images/comment_main.png'} style={{ width: '200px', height: 'auto', marginRight: '100px' }} alt='faq-img' />\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div className='faq-contents'>\n                    <CollapseContainer className='inner-container'>\n                        <Table\n                            rowKey='id'\n                            dataSource={this.props.newsEvent.newsEventList}\n                            columns={newsEvent}\n                            onRow={this.onRow}\n                            pagination={{\n                                pageSize: 10\n                            }}\n                        />\n                    </CollapseContainer>\n                </div>\n            </div>\n        );\n    }\n}","import axios from '../axios';\n\nexport const addNewsEvent = async ({ id, title, content, photo, url, url2, urlSource, urlSource2 }) => {\n    const config = {\n        id,\n        title,\n        content,\n        photo,\n        url,\n        url2,\n        urlSource,\n        urlSource2,\n    };\n\n    const result = await imageUpload(photo);\n    config.photo = result.data;\n\n    return axios.post(`/v1/newsEvent/add`, config);\n};\n\nexport const fetchNewsEvent = () => {\n    return axios.get('/v1/newsEvent/list');\n};\n\nexport const getNewsEventInfo = async ({ newsEventId, info }) => {\n    return axios.get('/v1/newsEvent/list/info', { newsEventId, info });\n};\n\nexport const imageUpload = photo => {\n    const formData = new FormData();\n    formData.append('photo', photo);\n    const header = { headers: { 'Content-Type': 'multipart/form-data' } };\n    return axios.post('/v1/newsEvent/image/upload', formData, header);\n};\n","import { createAction, handleActions } from \"redux-actions\";\nimport produce from \"immer\";\nimport * as newsEventAPI from '../../Lib/Api/newsEvent';\nimport _ from 'lodash';\nimport { createReduxThunk } from '../../Lib/middleware';\n\nconst ADD_NEWSEVENT = 'newsEvent/ADD_NEWSEVENT';\nconst ADD_NEWSEVENT_SUCCESS = 'newsEvent/ADD_NEWSEVENT_SUCCESS';\n\nconst NEWSEVENT_INFO = 'newsEvent/NEWSEVENT_INFO';\nconst NEWSEVENT_INFO_SUCCESS = 'newsEvent/NEWSEVENT_INFO_SUCCESS';\n\nconst GET_NEWSEVENT = 'newsEvent/GET_NEWSEVENT';\nconst GET_NEWSEVENT_SUCCESS = 'newsEvent/GET_NEWSEVENT_SUCCESS';\n\nexport const addNewsEvent = createReduxThunk(ADD_NEWSEVENT, newsEventAPI.addNewsEvent);\nexport const fetchNewsEvent = createReduxThunk(GET_NEWSEVENT, newsEventAPI.fetchNewsEvent);\nexport const getNewsEventInfo = createReduxThunk(NEWSEVENT_INFO, newsEventAPI.getNewsEventInfo);\n\n\nconst initalState = {\n    newsEventInfo: {},\n    newsEventList: [],\n};\n\nconst appReducer = handleActions(\n    {\n        [ADD_NEWSEVENT_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => { }),\n\n        [GET_NEWSEVENT_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && payload.message === 'success') {\n                    draft['newsEventList'] = payload.data;\n                }\n            }),\n\n        [NEWSEVENT_INFO_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                if (payload && !_.isEmpty(payload)) {\n                    draft['newsEventInfo'] = payload.data;\n                }\n            }),\n    },\n    initalState\n);\n\nexport default appReducer;","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledListContainer from './list.styled';\nimport List from './list';\nimport { addNewsEvent, fetchNewsEvent, getNewsEventInfo } from '../../../Reducer/Modules/newsEvent';\n\nclass InfoContainer extends React.PureComponent {\n    componentDidMount = () => {\n        this.props.fetchNewsEvent();\n    };\n\n    render() {\n        return (\n            <StyledListContainer>\n                <List {...this.props} />\n            </StyledListContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, newsEvent }) => ({\n    app,\n    auth,\n    newsEvent,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    fetchNewsEvent: () => dispatch(fetchNewsEvent()),\n    addNewsEvent: info => dispatch(addNewsEvent(info)),\n    getNewsEventInfo: ({ id, newsEventId }) => dispatch(getNewsEventInfo({ id, newsEventId })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(InfoContainer);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../theme';\n\nconst StyledInfoContainer = styled.div`\n    padding-top: 55px;\n\n    .faq-header {\n        // border-bottom: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding: 0px;\n            padding-top: 82px;\n\n            @media (max-width: 768px) {\n                padding-top: 42px;\n            }\n\n            > .flex-wrapper {\n                position: relative;\n\n                .faq-main-title {\n                    flex: 1;\n                    .title {\n                        font-size: ${sizeHandler(30)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: #000000;\n                        margin-bottom: 8px;\n\n                        @media {\n                            padding-left: 10px;\n                        }\n                    }\n\n                    .description {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-bottom: 82px;\n\n                        @media {\n                            padding-left: 10px;\n                        }\n                    }\n                }\n\n                .img-section {\n                    position: absolute;\n                    bottom: -50px;\n                    right: 0px;\n\n                    > img {\n                        width: 100%;\n                        max-width: 549px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n\n                    @media (max-width: 768px) {\n                        display: none;\n                    }\n                }\n            }\n        }\n    }\n\n    .info-contents {\n        .inner-container {\n            padding-top: 0px;\n\n            @media (max-width: 768px) {\n                h1 {\n                    font-size: 30px;\n                    margin-top: 60px;\n                }\n            }\n\n            .img-section {\n\n                > img {\n                    max-width: 500px;\n                    height: auto;\n                    object-fit: cover;\n                }\n            }\n        }\n    }    \n\n    h1 {\n        font-size: ${sizeHandler(34)};\n        font-weight: bold;\n        color: rgba(0, 0, 0, 0.8);\n        letter-spacing: -1px;\n\n        margin-bottom: 26px;\n        margin-top: 50px;\n    }\n\n    @media (max-width: 832px) {\n        .info-contents {\n            .inner-container {\n                .img-section {\n                    > img {\n                        max-width: 300px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n                }\n            }\n        }    \n    }\n\n    @media (max-width: 1120px) {\n        .faq-header {\n            .inner-container {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n        }\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .panel-header {\n            .row-index {\n                width: 70px;\n            }\n        }\n\n        .panel-content {\n            padding-left: 70px;\n\n            > p {\n                width: 90%;\n            }\n        }\n    }\n`;\n\nexport default StyledInfoContainer;","import React from 'react';\n\nexport const InfoBlock = ({ label, value, children }) => (\n    <div style={{ paddingBottom: '20px', marginBottom: '20px', borderBottom: '1px solid #e6e6e6' }}>\n        <p style={{ margin: 0, padding: 0, marginBottom: '8px', color: 'rgba(0,0,0,0.4)', fontSize: '10px' }}>{label}</p>\n        <p style={{ margin: 0, padding: 0, color: 'rgba(0,0,0,0.87)', fontSize: '14px' }}>{value}</p>\n        {children}\n    </div>\n);\n","import React from 'react';\nimport axios from '../../../Lib/axios';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport { Button, message, Table } from 'antd';\nimport { CollapseContainer } from '../../Review/List/list.styled';\n\nimport { InfoBlock } from '../../../Components/Common/block';\n\nexport default class Event extends React.PureComponent {\n    state = {\n        data: {},\n    };\n\n    componentDidMount = () => {\n        // const { state } = this.props.history.location;\n        // if (!state || !state.id) return this.props.history.goBack();\n        const { id } = this.props.match.params;\n\n        this.fetchInfo(id);\n    };\n\n    fetchInfo = async id => {\n        const { data } = await axios.get('/v1/newsEvent/list/info', {\n            params: {\n                newsEventId: id,\n            },\n        });\n\n        if (!data || data === 'check parameters') {\n            return this.props.history.goBack();\n        }\n\n        if (data === 'invalid newEvent') {\n            return message.warning('잘못된 게시물 정보입니다.');\n        }\n\n        this.setState({ ...data });\n    };\n\n    render() {\n        const { url, url2, urlSource, urlSource2 } = this.state;\n\n        return (\n            <div className='faq-container'>\n                <div className='faq-header'>\n                    <div className='inner-container'>\n                        <div className='flex-wrapper'>\n                            <div className='faq-main-title'>\n                                <p className='title'>위드메이트 소식</p>\n                                <p className='description'>위드메이트의 다양한 소식을 확인할 수 있습니다.</p>\n                            </div>\n                            <div className='img-section'>\n                                <img src={'/assets/images/comment_main.png'} style={{ width: '200px', height: 'auto', marginRight: '100px' }} alt='faq-img' />\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div className='info-contents'>\n                    <CollapseContainer className='inner-container' style={{ width: '80%', margin: 'auto' }}>\n                        <>\n                            <ValueBox>\n                                <Label style={{ fontSize: '25px' }}>{this.state.title}</Label>\n                            </ValueBox>\n\n                            <ValueBox style={{ textAlign: 'right' }}>\n                                <InfoBlock label='작성일' value={moment(this.state.createdAt).format('YYYY년 MM월 DD일 dddd')} />\n                            </ValueBox>\n\n                            <ValueBox>\n                                {this.state.photo && (\n                                    <div className='img-section' style={{ display: 'flex', justifyContent: 'center' }}>\n                                        <img\n                                            style={{ objectFit: 'contain' }}\n                                            src={typeof this.state.photo === 'string' ? this.state.photo : URL.createObjectURL(this.state.photo)}\n                                            alt='사진'\n                                        />\n                                    </div>\n                                )}\n                            </ValueBox>\n\n                            <ValueBox>\n                                <InfoBlock label='내용'>\n                                    <p style={{ whiteSpace: 'pre-wrap' }}>{this.state.content} </p>\n                                </InfoBlock>\n                                {this.state.url ? (\n                                    <InfoBlock label='링크'>\n                                        {url ? (\n                                            <a href={this.state.url} target='_blank' style={{ fontSize: '15px', color: '#3bc1ff' }}>\n                                                ㆍ{urlSource}\n                                            </a>\n                                        ) : (\n                                            ''\n                                        )}{' '}\n                                        <br />\n                                        {url2 ? (\n                                            <a href={this.state.url2} target='_blank' style={{ fontSize: '15px', color: '#3bc1ff' }}>\n                                                ㆍ{urlSource2}\n                                            </a>\n                                        ) : (\n                                            ''\n                                        )}\n                                    </InfoBlock>\n                                ) : null}\n                            </ValueBox>\n\n                            <ValueBox>\n                                <Button\n                                    className='white'\n                                    onClick={() => {\n                                        this.props.history.goBack();\n                                    }}\n                                    style={{ float: 'right' }}\n                                >\n                                    목록으로\n                                </Button>\n                            </ValueBox>\n                        </>\n                    </CollapseContainer>\n                </div>\n            </div>\n        );\n    }\n}\n\nexport const ValueBox = styled.div`\n    margin-bottom: 16px;\n`;\n\nexport const Label = styled.p`\n    text-align: left;\n    font-size: 11px;\n    margin-bottom: 4px;\n    color: #565656;\n`;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledInfoContainer from './info.styled';\nimport Info from './info';\nimport { addNewsEvent, fetchNewsEvent, getNewsEventInfo } from '../../../Reducer/Modules/newsEvent';\n\nclass InfoContainer extends React.PureComponent {\n    componentDidMount = () => {\n        const { id } = this.props.auth;\n        const { state } = this.props.location;\n        const { id: newsEventId } = this.props.match.params;\n\n        // console.log(newsEventId, state);\n\n        if (state === 'newsEvent') this.props.getNewsEventInfo({ newsEventId });\n    };\n\n    render() {\n        return (\n            <StyledInfoContainer>\n                <Info {...this.props} />\n            </StyledInfoContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, newsEvent }) => ({\n    app, \n    auth,\n    newsEvent\n});\n\nconst mapDispatchToProps = dispatch => ({\n    fetchNewsEvent: () => dispatch(fetchNewsEvent()),\n    addNewsEvent: (info) => dispatch(addNewsEvent(info)),\n    getNewsEventInfo: ({ id, newsEventId }) => dispatch(getNewsEventInfo({ id, newsEventId }))\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(InfoContainer);\n","import React from 'react';\nimport { Switch, Route } from 'react-router-dom';\n\n// pages\nimport List from './List';\nimport Info from './Info';\n\nclass NewsEvent extends React.PureComponent {\n    render() {\n        return (\n            <Switch>\n                <Route exact path='/newsEvent/list' component={List} />\n                <Route exact path='/newsEvent/info/:id' component={Info} />\n            </Switch>\n        );\n    }\n}\nexport default NewsEvent;\n","import { createAction, handleActions } from 'redux-actions';\nimport produce from 'immer';\nimport * as reviewAPI from '../../Lib/Api/review';\nimport _ from 'lodash';\nimport { createReduxThunk } from '../../Lib/middleware';\n\nconst ADD_REVIEW = 'review/ADD_REVIEW';\nconst ADD_REVIEW_SUCCESS = 'review/ADD_REVIEW_SUCCESS';\n\nconst REPLY_REVIEW = 'review/REPLY_REVIEW';\nconst REPLY_REVIEW_SUCCESS = 'review/REPLY_REVIEW_SUCCESS';\n\nconst DELETE_REVIEW = 'review/DELETE_REVIEW';\nconst DELETE_REVIEW_SUCCESS = 'review/DELETE_REVIEW_SUCCESS';\n\nconst GET_REVIEW_LIST = 'review/GET_REVIEW_LIST';\nconst GET_REVIEW_LIST_SUCCESS = 'review/GET_REVIEW_LIST_SUCCESS';\n\nconst EDIT_REVIEW = 'review/EDIT_REVIEW';\n\n// initalState\nconst initialState = {\n    review: {},\n    reviewList: [],\n    reviewPage: 0,\n    tab: 'basic',\n};\n\nexport const addReview = createReduxThunk(ADD_REVIEW, reviewAPI.addReview);\nexport const replyReview = createReduxThunk(REPLY_REVIEW, reviewAPI.replyReview);\nexport const deleteReview = createReduxThunk(DELETE_REVIEW, reviewAPI.deleteReview);\nexport const getReviewList = createReduxThunk(GET_REVIEW_LIST, reviewAPI.getReviewList);\n\nexport const editReview = createAction(EDIT_REVIEW, input => input);\n\nconst appReducer = handleActions(\n    {\n        [ADD_REVIEW_SUCCESS]: (state, { payload }) => produce(state, draft => {}),\n        [GET_REVIEW_LIST_SUCCESS]: (state, { payload }) =>\n            produce(state, draft => {\n                draft['reviewList'] = payload;\n            }),\n        [EDIT_REVIEW]: (state, { payload }) =>\n            produce(state, draft => {\n                draft[payload.type] = payload.value;\n            }),\n    },\n    initialState,\n);\n\nexport default appReducer;\n","import axios from '../axios';\n\nexport const addReview = ({ reserveId, userId, title, review, score, reserveDate }) => {\n    return axios.post(`/v1/review/add`, { reserveId, userId, title, review, score, reserveDate });\n};\n\nexport const getReviewList = ({ page }) => {\n    return axios.get(`/v1/review/list`, { page });\n};\n\nexport const replyReview = ({}) => {\n    return axios.post(`/v1/reply/review`, {});\n};\n\nexport const deleteReview = ({ reviewId }) => {\n    return axios.put(`/v1/delete/review`, { reviewId });\n};\n","import styled from 'styled-components';\nimport { Input } from 'antd';\n\nconst StyledAddContainer = styled.div``;\n\nexport default StyledAddContainer;\n\nexport const WritePaper = styled.div`\n    background-color: white;\n    padding: 21px 31px 31px 31px;\n    border-radius: 8px;\n    border: solid 1px #e6e6e6;\n\n    @media (max-width: 480px) {\n        padding: 16px;\n        border-radius: 4px;\n    }\n`;\n\nexport const FormHeader = styled.div`\n    border-bottom: solid 1px #e6e6e6;\n    padding-bottom: 22px;\n`;\n\nexport const FormTitle = styled.div`\n    font-size: 32px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    letter-spacing: -0.7px;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n\n    @media (max-width: 480px) {\n        font-size: 24px;\n    }\n`;\n\nexport const FormSubtitle = styled.div`\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 32px;\n\n    @media (max-width: 480px) {\n        font-size: 13px;\n    }\n`;\n\nexport const FormTypeWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: flex-start;\n    }\n`;\n\nexport const FormTypeBlock = styled.div`\n    margin-right 220px;\n\n    @media (max-width: 768px) {\n        margin-right: 0px;\n        margin-bottom: 20px;\n\n        &:last-child {\n            margin-bottom: 0px;\n        }\n    }\n`;\n\nexport const FormTypeTitle = styled.p`\n    font-size: 11px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.67;\n    letter-spacing: normal;\n    color: #b1b1b1;\n\n    margin-bottom: 11px;\n\n    @media (max-width: 480px) {\n        font-size: 10px;\n    }\n`;\n\nexport const FormTypeDesc = styled.p`\n    font-size: 20px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.54;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: #3bc1ff;\n\n    margin-bottom: 0px;\n\n    @media (max-width: 480px) {\n        font-size: 16px;\n    }\n`;\n\nexport const FormDescription = styled.span`\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: #3bc1ff;\n\n    margin-left: 4px;\n\n    @media (max-width: 480px) {\n        font-size: 11px;\n    }\n`;\n\nexport const StarImg = styled.img`\n    width: 46px;\n    height: 44px;\n    margin-right: 8px;\n\n    @media (max-width: 480px) {\n        width: 26px;\n        height: 24px;\n        margin-right: 4px;\n    }\n`;\n\nexport const FormBody = styled.div`\n    padding-top: 22px;\n`;\n\nexport const FormRow = styled.div`\n    margin-bottom: 32px;\n`;\n\nexport const FormInput = styled(Input)`\n    height: 44px;\n\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.3px;\n    color: #161616;\n\n    &::placeholder {\n        font-size: 14px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.75;\n        letter-spacing: -0.3px;\n        color: #a7a7a7;\n    }\n\n    @media (max-width: 480px) {\n        font-size: 12px;\n\n        &::placeholder {\n            font-size: 11px;\n        }\n    }\n`;\n\nexport const FormTextarea = styled(Input.TextArea)`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.3px;\n    color: #161616;\n\n    &::placeholder {\n        font-size: 14px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.75;\n        letter-spacing: -0.3px;\n        color: #a7a7a7;\n    }\n\n    @media (max-width: 480px) {\n        font-size: 12px;\n\n        &::placeholder {\n            font-size: 11px;\n        }\n    }\n`;\n\nexport const FormButtonWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    margin-top: 50px;\n\n    @media (max-width: 480px) {\n        margin-top: 32px;\n    }\n`;\n\nexport const FormButton = styled.div`\n    cursor: pointer;\n\n    border-radius: 2px;\n    width: 297px;\n    height: 60px;\n    line-height: 60px;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: -0.15px;\n    text-align: center;\n    color: #ffffff;\n\n    &.blue {\n        background-color: #3bc1ff;\n    }\n\n    &.white {\n        background-color: #b7b7b7;\n        margin-right: 16px;\n    }\n\n    &:hover {\n        transition: all 0.5s;\n        opacity: 0.8;\n    }\n\n    @media (max-width: 480px) {\n        height: 44px;\n        line-height: 44px;\n        font-size: 13px;\n    }\n`;\n\nexport const FormTitleRowWrapper = styled.div`\n    padding-top: 16px;\n    padding-bottom: 16px;\n\n    border-bottom: 1px solid #f2f2f2;\n`;\n\nexport const FormRowTitle = styled.div`\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.65;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    margin-bottom: 0px;\n\n    @media (max-width: 480px) {\n        font-size: 14px;\n        flex-direction: column;\n        align-items: flex-start;\n    }\n`;\n\nexport const CheckboxGroup = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: flex-end;\n    text-align: right;\n\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.65;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    .ant-checkbox-inner {\n        width: 18px;\n        height: 18px;\n    }\n\n    @media (max-width: 480px) {\n        .ant-checkbox-wrapper {\n            font-size: 12px !important;\n        }\n        .ant-checkbox-inner {\n            width: 16px;\n            height: 16px;\n        }\n\n        margin-top: 4px;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nconst CommentPageHeader = ({ children, title, desc }) => {\n    return (\n        <HeaderContainer>\n            <HeaderWrapper className='inner-container'>\n                <HeaderBlock>\n                    <HeaderTitle>{title}</HeaderTitle>\n                    <HeaderDescription>\n                        {desc.split('\\n').map((word, index) => (\n                            <p key={'add-word-brea-' + index.toString()}>{word}</p>\n                        ))}\n                    </HeaderDescription>\n                    {children}\n                </HeaderBlock>\n                <HeaderBlock className='img-cover'>\n                    <MainImageWrapper>\n                        {/* <MainImage src='/assets/images/comment_main.png' /> */}\n                        <MainImage src='/assets/images/w_main_crop.png' />\n                    </MainImageWrapper>\n                </HeaderBlock>\n            </HeaderWrapper>\n        </HeaderContainer>\n    );\n};\n\nconst HeaderContainer = styled.div`\n    // border-bottom: 1px solid #e6e6e6;\n`;\n\nconst HeaderWrapper = styled.div`\n    display: flex;\n\n    padding: 0px;\n    padding-top: 100px;\n    padding-bottom: 0px;\n\n    @media (max-width: 1120px) {\n        padding: 100px 16px 0px 16px;\n    }\n`;\n\nconst HeaderBlock = styled.div`\n    flex: 1;\n\n    &.img-cover {\n        flex: 1.2;\n\n        display: flex;\n        justify-content: flex-start;\n        align-items: flex-end;\n\n        @media (max-width: 768px) {\n            display: none;\n        }\n    }\n`;\n\nconst HeaderTitle = styled.div`\n    font-size: 44px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.33;\n    letter-spacing: -0.6px;\n    color: #000000;\n\n    margin-top: 30px;\n    margin-bottom: 6px;\n\n    @media (max-width: 768px) {\n        font-size: 32px;\n        margin-top: 16px;\n    }\n`;\n\nconst HeaderDescription = styled.div`\n    > p {\n        margin-bottom: 0px;\n\n        font-size: 14px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.75;\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.8);\n\n        @media (max-width: 768px) {\n            font-size: 12px;\n        }\n    }\n`;\n\nconst MainImageWrapper = styled.div`\n    display: flex;\n    justify-content: flex-start;\n\n    width: 80%;\n    height: 100%;\n    max-height: 391px;\n`;\n\nconst MainImage = styled.div`\n    width: 100%;\n    height: 100%;\n    background-image: url(${props => props.src});\n    background-position: top;\n    background-repeat: no-repeat;\n    background-size: cover;\n`;\n\nexport default CommentPageHeader;\n","import React from 'react';\nimport styled from 'styled-components';\nimport StarRatingComponent from 'react-star-rating-component';\nimport { message, notification, Checkbox } from 'antd';\nimport moment from 'moment';\n\nimport { ASSIST } from '../../../Lib/variables';\nimport axios from '../../../Lib/axios';\nimport CommentPageHeader from '../../../Components/Templates/Review/header';\nimport { WithmateLabel, DivisionLine, WithmateInput, WithmateTextarea } from '../../../Components/Common/input';\n\nimport {\n    WritePaper,\n    FormHeader,\n    StarImg,\n    FormTitle,\n    FormSubtitle,\n    FormTypeWrapper,\n    FormTypeBlock,\n    CheckboxGroup,\n    FormTypeDesc,\n    FormRowTitle,\n    FormDescription,\n    FormTitleRowWrapper,\n    FormButtonWrapper,\n    FormButton,\n} from './add.styled';\n\nexport default class AddComment extends React.PureComponent {\n    state = {\n        star: 0,\n        title: '',\n        review: '',\n        useAgain: null,\n        corpSatisfied: null,\n        corpSatisfiedReason: '',\n        doctorSatisfied: null,\n        doctorSatisfiedReason: '',\n        hope: '',\n    };\n\n    componentDidMount = () => {\n        this.checkReserveValidation();\n    };\n\n    checkReserveValidation = async () => {\n        const id = localStorage.getItem('id');\n        const { params } = this.props.match;\n\n        if (!params.reserveId) {\n            message.info('올바르지않은 시도입니다. 다시 시도해주세요.');\n            return this.props.history.goBack();\n        }\n        const { data: reviewStatus } = await axios.get('/v1/review/check/validation', { params: { reserveId: params.reserveId } });\n        if (!reviewStatus) {\n            message.info('올바르지않은 시도입니다. 다시 시도해주세요.');\n            return setTimeout(() => {\n                this.props.history.goBack();\n            }, 1000);\n        }\n\n        if (reviewStatus === 'already registered') {\n            notification.error({\n                message: '작성 완료 알림',\n                description: `이미 해당 이용에 대한 후기를 작성하였습니다. 목록으로 돌아가 다시 시도해주세요.`,\n            });\n\n            return setTimeout(() => {\n                this.props.history.goBack();\n            }, 1000);\n        }\n\n        if (reviewStatus === 'invalid reserve') {\n            notification.error({\n                message: '유효하지 않은 이용내역',\n                description: `올바르지않은 시도입니다. 다시 시도해주세요.`,\n            });\n            return setTimeout(() => {\n                this.props.history.goBack();\n            }, 1000);\n        }\n\n        axios.get('/v2/service/user/reserve/info', { params: { userId: id, reserveId: params.reserveId } }).then(resolve => {\n            const { data: info } = resolve;\n            if (!info) return message.error('죄송합니다. 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n            if (info === 'invalid reserve') return message.warning('유효하지않은 예약입니다.');\n\n            const serviceType =\n                !info.productInfo || !info.productInfo.usePro || !info.productInfo.useBasic ? '' : info.service === 'unemergency' ? 'Pro' : 'Basic';\n            const serviceName = (info.productInfo && info.productInfo.name && info.service && info.productInfo.name + serviceType) || '-';\n\n            this.setState({\n                reserveId: info._id,\n                callId: info.call._id,\n                service: info.service,\n                reserveDate: info.reserveDate,\n                serviceName,\n            });\n        });\n    };\n\n    starHandler = (nextValue, prevValue, name) => {\n        this.setState({ star: nextValue });\n    };\n\n    inputHandler = ({ type, value }) => {\n        this.setState({\n            [type]: value,\n        });\n    };\n\n    onAddReview = () => {\n        // 리뷰 추가\n        const userId = localStorage.getItem('id');\n        const { star, reserveId, title, review, useAgain, corpSatisfied, corpSatisfiedReason, doctorSatisfied, doctorSatisfiedReason, hope, reserveDate } = this.state;\n\n        const info = { score: star };\n\n        if (title) info.title = title;\n        if (reserveDate) info.reserveDate = reserveDate;\n        if (review) info.review = review;\n        if (typeof useAgain === 'boolean') info.useAgain = useAgain;\n        if (typeof corpSatisfied === 'boolean') info.corpSatisfied = corpSatisfied;\n        if (corpSatisfiedReason) info.corpSatisfiedReason = corpSatisfiedReason;\n        if (typeof doctorSatisfied === 'boolean') info.doctorSatisfied = doctorSatisfied;\n        if (doctorSatisfiedReason) info.doctorSatisfiedReason = doctorSatisfiedReason;\n        if (hope) info.hope = hope;\n\n        if (!star) return message.warning('별점을 매겨주세요.');\n\n        axios\n            .post('/v2/review/add', { info, reserveId, userId })\n            .then(resolve => {\n                const { data } = resolve;\n                if (!data) return message.error('죄송합니다. 일시적인 서버 장애로 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n                else if (data === 'check parameters') return message.warning('요청에 실패하였습니다.');\n                else if (data === 'invalid') return message.warning('잘못된 요청입니다. 재 로그인 후 시도해주세요.');\n                else if (data === 'not exist reserve') return message.warning('잘못된 요청입니다. 새로고침 후 다시 시도해주세요.');\n                else if (data === 'already registered') return message.warning('이미 리뷰 등록을 완료한 예약입니다.');\n                else if (data === 'success') {\n                    message.success('리뷰 등록 완료');\n                    setTimeout(() => {\n                        this.props.history.goBack();\n                    }, 250);\n                    return null;\n                }\n            })\n            .catch(error => {\n                return message.error('죄송합니다. 일시적인 서버 장애로 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n            });\n    };\n\n    render() {\n        const { star, title, serviceName, reserveDate, review, useAgain, corpSatisfied, corpSatisfiedReason, doctorSatisfied, doctorSatisfiedReason, hope } =\n            this.state;\n\n        return (\n            <div>\n                <CommentPageHeader title='서비스 이용 후기 작성' desc={`후기 작성 시 최대 3,000포인트를\\n 지급해드립니다.`}>\n                    <PaddingDiv style={{ paddingTop: '90px' }} />\n                </CommentPageHeader>\n\n                <FullContainer>\n                    <div className='inner-container'>\n                        <WritePaper>\n                            <FormHeader>\n                                <FormTitle>후기 작성</FormTitle>\n                                <FormSubtitle>후기를 작성하실 이용 내역을 선택해주세요</FormSubtitle>\n                                <FormTypeWrapper>\n                                    <FormTypeBlock>\n                                        <WithmateLabel>이용하신 서비스</WithmateLabel>\n                                        <FormTypeDesc>{serviceName}</FormTypeDesc>\n                                    </FormTypeBlock>\n                                    <FormTypeBlock>\n                                        {/* <WithmateLabel>이용 날짜</WithmateLabel>\n                                        <FormTypeDesc>{moment(reserveDate).format('YYYY년 MM월 DD일')}</FormTypeDesc>\n                                    </FormTypeBlock> */}\n                                        <WithmateLabel>서비스 이용 날짜</WithmateLabel>\n                                        <FormTypeDesc>{moment(reserveDate).format('YYYY년 MM월 DD일')}</FormTypeDesc>\n                                    </FormTypeBlock>\n                                </FormTypeWrapper>\n                            </FormHeader>\n\n                            <DivisionLine big />\n\n                            <WithmateLabel required>\n                                별점\n                                <FormDescription>(작성 시 500포인트 지급)</FormDescription>\n                            </WithmateLabel>\n                            <StarRatingComponent\n                                starCount={5}\n                                value={star}\n                                renderStarIcon={(index, value) => {\n                                    return <StarImg src={`/assets/images/icon_${index <= value ? 'active_star' : 'star'}.png`} />;\n                                }}\n                                onStarClick={this.starHandler}\n                            />\n\n                            <DivisionLine big />\n\n                            <WithmateLabel>\n                                제목\n                                <FormDescription>(제목 + 이용후기 작성 시 500포인트 지급)</FormDescription>\n                            </WithmateLabel>\n                            <WithmateInput\n                                value={title}\n                                maxLength={30}\n                                onChange={ev => {\n                                    this.inputHandler({ type: 'title', value: ev.target.value });\n                                }}\n                                placeholder='제목을 입력해주세요.'\n                            />\n\n                            <DivisionLine big />\n\n                            <WithmateLabel>이용 후기</WithmateLabel>\n                            <WithmateTextarea\n                                value={review || undefined}\n                                placeholder='고객님의 소중한 후기는 위드메이트 서비스 개선에 많은 도움이 됩니다. 감사합니다.'\n                                onChange={ev => {\n                                    this.inputHandler({ type: 'review', value: ev.target.value });\n                                }}\n                            />\n\n                            <DivisionLine big />\n                            <DivisionLine big />\n\n                            <WithmateLabel>\n                                추가 선택 사항\n                                <FormDescription>(선택사항까지 작성 완료 시 2000포인트 추가 지급)</FormDescription>\n                            </WithmateLabel>\n\n                            <DivisionLine small />\n\n                            <FormTitleRowWrapper>\n                                <FormRowTitle>\n                                    다음 진료에도 위드메이트를 사용하실건가요?\n                                    <CheckboxGroup>\n                                        <Checkbox\n                                            value={true}\n                                            checked={useAgain === true}\n                                            onClick={() => {\n                                                this.setState({ useAgain: !useAgain ? true : null });\n                                            }}\n                                        >\n                                            예\n                                        </Checkbox>\n                                        <Checkbox\n                                            value={false}\n                                            checked={useAgain === false}\n                                            onClick={() => {\n                                                this.setState({ useAgain: useAgain === false ? null : false });\n                                            }}\n                                        >\n                                            아니오\n                                        </Checkbox>\n                                    </CheckboxGroup>\n                                </FormRowTitle>\n                            </FormTitleRowWrapper>\n\n                            <FormTitleRowWrapper>\n                                <FormRowTitle>\n                                    금일 방문하신 의료 기관의 서비스에 만족하시나요?\n                                    <CheckboxGroup>\n                                        <Checkbox\n                                            value={true}\n                                            checked={corpSatisfied === true}\n                                            onClick={() => {\n                                                this.setState({ corpSatisfied: !corpSatisfied ? true : null });\n                                            }}\n                                        >\n                                            예\n                                        </Checkbox>\n                                        <Checkbox\n                                            value={false}\n                                            checked={corpSatisfied === false}\n                                            onClick={() => {\n                                                this.setState({ corpSatisfied: corpSatisfied === false ? null : false });\n                                            }}\n                                        >\n                                            아니오\n                                        </Checkbox>\n                                    </CheckboxGroup>\n                                </FormRowTitle>\n                            </FormTitleRowWrapper>\n\n                            <FormTitleRowWrapper>\n                                <FormRowTitle>이유는 무엇인가요?</FormRowTitle>\n                                <DivisionLine x_small />\n                                <WithmateInput\n                                    value={corpSatisfiedReason}\n                                    maxLength={30}\n                                    onChange={ev => {\n                                        this.inputHandler({ type: 'corpSatisfiedReason', value: ev.target.value });\n                                    }}\n                                    placeholder='어떤 부분에서 의료기관이 만족스러우셨는지 입력해주세요.'\n                                />\n                            </FormTitleRowWrapper>\n\n                            <FormTitleRowWrapper>\n                                <FormRowTitle>\n                                    금일 방문하신 의료 기관의 의료진은 누구이고, 서비스에 만족하시나요?\n                                    <CheckboxGroup>\n                                        <Checkbox\n                                            value={true}\n                                            checked={doctorSatisfied === true}\n                                            onClick={() => {\n                                                this.setState({ doctorSatisfied: !doctorSatisfied ? true : null });\n                                            }}\n                                        >\n                                            예\n                                        </Checkbox>\n                                        <Checkbox\n                                            value={false}\n                                            checked={doctorSatisfied === false}\n                                            onClick={() => {\n                                                this.setState({ doctorSatisfied: doctorSatisfied === false ? null : false });\n                                            }}\n                                        >\n                                            아니오\n                                        </Checkbox>\n                                    </CheckboxGroup>\n                                </FormRowTitle>\n                                <DivisionLine x_small />\n                                <WithmateInput\n                                    value={doctorSatisfiedReason}\n                                    maxLength={30}\n                                    onChange={ev => {\n                                        this.inputHandler({ type: 'doctorSatisfiedReason', value: ev.target.value });\n                                    }}\n                                    placeholder='의료진의 이름과 만족하는 이유를 입력해주세요.'\n                                />\n                            </FormTitleRowWrapper>\n\n                            <FormTitleRowWrapper>\n                                <FormRowTitle>병원 동행 서비스의 개선점이 있다면 무엇이라고 생각하시나요?</FormRowTitle>\n                                <DivisionLine x_small />\n                                <WithmateTextarea\n                                    value={hope || undefined}\n                                    placeholder={`고객님의 소중한 후기는 위드메이트 서비스개선에 많은 도움이 됩니다.\n감사합니다.`}\n                                    onChange={ev => {\n                                        this.inputHandler({ type: 'hope', value: ev.target.value });\n                                    }}\n                                />\n                            </FormTitleRowWrapper>\n\n                            <DivisionLine big />\n\n                            <FormButtonWrapper>\n                                <FormButton\n                                    className='white'\n                                    onClick={() => {\n                                        this.props.history.goBack();\n                                    }}\n                                >\n                                    뒤로가기\n                                </FormButton>\n                                <FormButton className='blue' onClick={this.onAddReview}>\n                                    등록하기\n                                </FormButton>\n                            </FormButtonWrapper>\n                        </WritePaper>\n                    </div>\n                </FullContainer>\n            </div>\n        );\n    }\n}\nexport const PaddingDiv = styled.div``;\n\nexport const FullContainer = styled.div`\n    width: 100%;\n    background-color: #f6f6f6;\n    min-height: 70vh;\n\n    @media (max-width: 480px) {\n        > .inner-container {\n            padding: 16px 16px;\n        }\n    }\n`;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\nimport { getReserveInfo } from '../../../Reducer/Modules/app';\nimport { addReview } from '../../../Reducer/Modules/review';\nimport StyledAddContainer from './add.styled';\nimport AddCommentPage from './add';\nimport { message } from 'antd';\n\nclass AddCommentPageContainer extends React.PureComponent {\n    componentDidMount = () => {\n        const id = localStorage.getItem('id');\n        const { params } = this.props.match;\n\n        if (!id) {\n            message.info('로그인 후 이용해주세요.');\n            return this.props.history.push('/user/login');\n        }\n\n        if (params && params.reserveId) {\n            this.props\n                .getReserve({\n                    reserveId: params.reserveId,\n                    userId: id,\n                })\n                .then(resolve => {\n                    if (resolve === 'no matched user') {\n                        message.info('해당 리뷰의 접근권한이 없습니다.');\n                        return this.props.history.push('/review/own/usage/list');\n                    }\n\n                    if (resolve && resolve.review && resolve.review.length > 0) {\n                        message.info('이미 리뷰를 작성하였습니다.');\n                        return this.props.history.push('/review/own/usage/list');\n                    }\n                });\n        }\n    };\n\n    render() {\n        return (\n            <StyledAddContainer>\n                <AddCommentPage {...this.props} />\n            </StyledAddContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, review }) => ({\n    app,\n    auth,\n    review,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    addReview: ({ reserveId, userId, title, review, score }) => dispatch(addReview({ reserveId, userId, title, review, score })),\n    getReserve: ({ reserveId, userId }) => dispatch(getReserveInfo({ reserveId, userId })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(AddCommentPageContainer);\n","import React from 'react';\nimport { Collapse, Icon, Pagination, message } from 'antd';\nimport moment from 'moment';\n\nimport CommentPageHeader from '../../../Components/Templates/Review/header';\nimport {\n    HeaderButton,\n    CollapseContainer,\n    CollapseHeader,\n    CollapseTab,\n    CollapseTabOnlyDesktop,\n    CountDisplay,\n    PanelHeader,\n    PanelField,\n    Star,\n    ReviewTextWrapper,\n    ReviewText,\n    ReviewMobileInfo,\n    ReviewerName,\n    MyReview,\n} from './list.styled';\n\nimport axios from '../../../Lib/axios';\n\nconst { Panel } = Collapse;\n\nconst PerPage = 20;\n\nexport default class CommentList extends React.PureComponent {\n    state = {\n        tab: 'basic',\n        total: 0,\n        list: [],\n        page: 1,\n    };\n\n    componentDidMount = () => {\n        this.fetchList();\n    };\n\n    fetchList = () => {\n        const { page } = this.state;\n        axios.get('/v2/review/list', { params: { page, pageCnt: PerPage } }).then(resolve => {\n            const { data } = resolve;\n            if (data && data.total) {\n                this.setState({ total: data.total || 0, list: data.list || [] });\n            }\n        });\n    };\n\n    renderStar = score => {\n        return (\n            <>\n                {new Array(score).fill(0).map((star, index) => (\n                    <Star key={'active-star=' + index.toString()} src='/assets/images/icon_active_star.png' alt='active-star' />\n                ))}\n                {new Array(5 - score).fill(0).map((star, index) => (\n                    <Star key={'active-star=' + index.toString()} src='/assets/images/icon_star.png' alt='active-star' />\n                ))}\n            </>\n        );\n    };\n\n    getAutoTitle = ({ title, rate }) => {\n        if (title) return title;\n        if (rate === 5) return '서비스 매우 만족';\n        if (rate >= 4) return '서비스 만족';\n        if (rate >= 3) return '서비스 보통';\n        if (rate >= 2) return '서비스 불만족';\n        if (rate >= 1) return '서비스 매우 불만족';\n    };\n\n    render() {\n        const { tab, list, page, total } = this.state;\n        const { id, userType } = this.props.auth;\n\n        return (\n            <div>\n                <CommentPageHeader title='이용 후기' desc={`고객님의 소중한 후기를 통해 더욱 발전하는\\n 위드메이트가 되겠습니다.`}>\n                    <HeaderButton\n                        onClick={() => {\n                            if (userType && userType === 'user') {\n                                this.props.history.push('/review/own/usage/list');\n                            } else {\n                                message.warning('비회원과 메이트는 작성할 수 없습니다.');\n                            }\n                        }}\n                    >\n                        후기 작성하기\n                    </HeaderButton>\n                </CommentPageHeader>\n\n                <CollapseContainer className='inner-container'>\n                    <CountDisplay>\n                        <span>{total}</span>건\n                    </CountDisplay>\n\n                    <CollapseHeader>\n                        <CollapseTab style={{ width: '40px' }}>번호</CollapseTab>\n                        <CollapseTab style={{ flex: 1 }}>서비스</CollapseTab>\n                        <CollapseTab style={{ flex: 1 }}>제목</CollapseTab>\n                        <CollapseTabOnlyDesktop style={{ width: '80px' }}>작성자</CollapseTabOnlyDesktop>\n                        <CollapseTabOnlyDesktop style={{ width: '120px' }}>별점</CollapseTabOnlyDesktop>\n                        <CollapseTabOnlyDesktop style={{ width: '152px' }}>작성일</CollapseTabOnlyDesktop>\n                    </CollapseHeader>\n                    <Collapse\n                        key={'item-key-frefresh'}\n                        expandIconPosition='right'\n                        bordered={false}\n                        expandIcon={({ isActive }) => <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? '#3bc1ff' : '#a7a7a7' }} />}\n                    >\n                        {list &&\n                            list.map((info, index) => (\n                                <Panel\n                                    key={'comment-order-' + index.toString() + 'item'}\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={\n                                        <PanelHeader>\n                                            <PanelField style={{ width: '40px' }} index>\n                                                {total - ((page - 1) * PerPage + index)}\n                                            </PanelField>\n                                            <PanelField style={{ width: '80px' }}>{info.reserve.service === 'assist' ? 'Basic' : 'Pro'}</PanelField>\n                                            <PanelField className='title' style={{ flex: 1 }}>\n                                                {this.getAutoTitle({ title: info.title, rate: info.score })}\n                                            </PanelField>\n                                            <PanelField style={{ width: '80px' }} onlyDesktop>\n                                                {id === info.user._id ? <MyReview>내후기</MyReview> : info.user.name}\n                                            </PanelField>\n                                            <PanelField style={{ width: '120px' }} onlyDesktop>\n                                                {info.score ? this.renderStar(parseInt(info.score, 10)) : null}\n                                            </PanelField>\n                                            <PanelField style={{ width: '152px' }} onlyDesktop>\n                                                {moment(info.createdAt).format('YYYY-MM-DD')}\n                                            </PanelField>\n                                        </PanelHeader>\n                                    }\n                                >\n                                    <ReviewTextWrapper>\n                                        <ReviewMobileInfo>\n                                            {id === info.user._id ? (\n                                                <MyReview style={{ marginRight: '17px' }}>내후기</MyReview>\n                                            ) : (\n                                                <ReviewerName>{info.user.name}</ReviewerName>\n                                            )}\n                                            <span style={{ marginRight: '18px' }}>{info.score ? this.renderStar(parseInt(info.score, 10)) : null}</span>\n                                            <ReviewerName>{moment(info.createdAt).format('YYYY-MM-DD')}</ReviewerName>\n                                        </ReviewMobileInfo>\n                                        {info.review && (\n                                            <ReviewText>\n                                                {info.review.split('\\n').map((text, index) => (\n                                                    <span key={info._id + index.toString() + tab}>\n                                                        {text}\n                                                        <br />\n                                                    </span>\n                                                ))}\n                                            </ReviewText>\n                                        )}\n                                        <ReviewText style={{ marginTop: '8px' }}>\n                                            (담당 메이트: {info.reserve && info.reserve.call && info.reserve.call.mate ? info.reserve.call.mate.name : '-'})\n                                        </ReviewText>\n\n                                        <ReviewText style={{ marginTop: '15px', paddingLeft: '15px' }}>\n                                            {info.reply === '' ? (\n                                                ''\n                                            ) : (\n                                                <>\n                                                    <a style={{ color: '#3bc1ff' }}>➔&ensp;</a>\n                                                    <b>위드메이트</b>: {info.reply ? info.reply : ''}\n                                                </>\n                                            )}\n                                        </ReviewText>\n                                    </ReviewTextWrapper>\n                                </Panel>\n                            ))}\n                    </Collapse>\n                    <Pagination\n                        pageSize={PerPage}\n                        total={this.state.total}\n                        current={this.state.page}\n                        onChange={page => {\n                            this.setState({ page, list: [] }, () => {\n                                this.fetchList();\n                            });\n                        }}\n                    />\n                </CollapseContainer>\n            </div>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledListContainer from './list.styled';\nimport CommentList from './list';\n\nimport { getReviewList, editReview } from '../../../Reducer/Modules/review';\n\nclass CommentListPage extends React.PureComponent {\n    render() {\n        return (\n            <StyledListContainer>\n                <CommentList {...this.props} />\n            </StyledListContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, review }) => ({\n    app,\n    auth,\n    review,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    // getReviewList: page => dispatch(getReviewList({ page })),\n    editReview: ({ type, value }) => dispatch(editReview({ type, value })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CommentListPage);\n","import styled from 'styled-components';\n\nconst StyledListContainer = styled.div``;\n\nexport const FullContainer = styled.div`\n    width: 100%;\n    background-color: #f6f6f6;\n    min-height: 70vh;\n`;\n\nexport const PaddingDiv = styled.div``;\n\nexport const TableContainer = styled.div``;\n\nexport const TableHeader = styled.div`\n    padding: 23px 32px 32px 32px;\n    background-color: #ffffff;\n    border-bottom: 1px solid rgba(0, 0, 0, 0.09);\n\n    border-top-left-radius: 4px;\n    border-top-right-radius: 4px;\n`;\n\nexport const TableTitle = styled.p`\n    font-size: 36px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.44;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 4px;\n`;\n\nexport const TableSubTitle = styled.p`\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 0px;\n`;\n\nexport const TableAlert = styled.p`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.71;\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 0px;\n    margin-top: 16px;\n`;\n\nexport const TableBody = styled.div`\n    overflow-x: scroll;\n    background-color: white;\n`;\n\nexport const TableRow = styled.div`\n    width: 100%;\n\n    display: flex;\n    align-items: center;\n\n    padding-top: 11px;\n    padding-bottom: 12px;\n\n    border-bottom: 1px solid #e6e6e6;\n\n    @media (max-width: 768px) {\n        width: fit-content;\n    }\n`;\n\nexport const TableField = styled.div`\n    ${props => (props.style ? props.style : `flex: 1;`)}\n\n    display: flex;\n    flex-direction: column;\n    text-align: left;\n\n    margin: 0px 26px;\n\n    ${props =>\n        props.desktopOnly\n            ? `\n        @media (max-width: 768px) {\n            display: none;\n        }\n    `\n            : undefined}\n\n    ${props => (props.title ? `font-weight: bold;` : undefined)}\n`;\n\nexport const TableButton = styled.div`\n    align-self: flex-end;\n    width: 134px;\n    height: 28px;\n    line-height: 28px;\n\n    border-radius: 2px;\n    border: 1px solid #3bc1ff;\n    background-color: #3bc1ff;\n\n    font-size: 10px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: normal;\n    text-align: center;\n    color: #ffffff;\n\n    cursor: pointer;\n    &:hover {\n        transition: all 0.5s;\n        opacity: 0.8;\n    }\n\n    &.disabled {\n        border: 1px solid #a7a7a7;\n        background-color: #a7a7a7;\n        cursor: not-allowed;\n\n        &:hover {\n            transition: all 0.5s;\n            opacity: 1;\n        }\n    }\n`;\n\nexport const EmptyWrapper = styled.div`\n    padding: 32px;\n    width: 100%;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    flex-direction: column;\n`;\n\nexport const EmptyImage = styled.img`\n    width: 200px;\n    height: 120px;\n    object-fit: contain;\n\n    margin-bottom: 20px;\n`;\n\nexport const EmptyText = styled.span`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.71;\n    letter-spacing: -0.3px;\n    color: #b1b1b1;\n`;\n\nexport default StyledListContainer;\n","import React from 'react';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport { ASSIST, UNEMER } from '../../../Lib/variables';\nimport ReviewPageHeader from '../../../Components/Templates/Review/header';\nimport {\n    FullContainer,\n    TableContainer,\n    TableHeader,\n    TableTitle,\n    PaddingDiv,\n    TableBody,\n    TableSubTitle,\n    TableAlert,\n    TableRow,\n    TableField,\n    TableButton,\n    EmptyWrapper,\n    EmptyText,\n    EmptyImage,\n} from './mylist.styled';\n\nexport default class MyReviewList extends React.PureComponent {\n    onReserve = _id => {\n        this.props.history.push('/review/edit/' + _id);\n    };\n\n    render() {\n        const { reserveList } = this.props.app;\n        const done_list = reserveList.filter(reserve => reserve.call.length > 0 && reserve.call[0].status === '서비스 종료' && reserve.review.length === 0);\n\n        return (\n            <div>\n                <ReviewPageHeader title='이용 후기 쓰기' desc={`후기 작성 시 서비스 요금 2,000원\\n 할인이 적용됩니다.`}>\n                    <PaddingDiv style={{ paddingTop: '120px' }} />\n                </ReviewPageHeader>\n\n                <FullContainer>\n                    <TableContainer className='inner-container'>\n                        <TableHeader>\n                            <TableTitle>이용 내역 선택</TableTitle>\n                            <TableSubTitle>후기를 작성하실 이용 내역을 선택해주세요</TableSubTitle>\n                        </TableHeader>\n\n                        <TableBody>\n                            <TableRow>\n                                <TableField title style={{ width: '40px' }}>\n                                    서비스\n                                </TableField>\n                                <TableField title style={{ width: '64px' }}>\n                                    환자 이름\n                                </TableField>\n                                <TableField title style={{ width: '110px' }}>\n                                    예약 병원\n                                </TableField>\n                                <TableField title style={{ width: '200px' }}>\n                                    예약 시간\n                                </TableField>\n                                <TableField title style={{ width: '120px' }}>\n                                    신청 날짜\n                                </TableField>\n                                <TableField title style={{ width: '70px' }}>\n                                    진행 현황\n                                </TableField>\n                                <TableField></TableField>\n                            </TableRow>\n                            {done_list.length > 0 ? (\n                                done_list.map((reserve, index) => {\n                                    return (\n                                        <TableRow key={reserve._id.substr(4, 8) + index.toString()}>\n                                            <TableField style={{ width: '40px' }}>{reserve.service === ASSIST ? 'BASIC' : 'PRO'}</TableField>\n                                            <TableField style={{ width: '64px' }}>{reserve.patient}님</TableField>\n                                            <TableField style={{ width: '110px' }}>{reserve.destination || '-'}</TableField>\n                                            <TableField style={{ width: '200px' }}>{moment(reserve.reserveDate).format('YYYY년 MM월 DD일 - HH:mm')}</TableField>\n                                            <TableField style={{ width: '120px' }}>{moment(reserve.createdAt).format('YYYY년 MM월 DD일')}</TableField>\n                                            <TableField style={{ width: '70px' }}>{reserve.call.length > 0 ? reserve.call[0].status : '-'}</TableField>\n                                            <TableField>\n                                                <TableButton\n                                                    onClick={() => {\n                                                        this.onReserve(reserve._id);\n                                                    }}\n                                                >\n                                                    작성 하기\n                                                </TableButton>\n                                            </TableField>\n                                        </TableRow>\n                                    );\n                                })\n                            ) : (\n                                <EmptyList />\n                            )}\n                            {/* \n                            {reserveList\n                                .map((reserve, index) => {\n                                    return (\n                                        <TableRow key={reserve._id.substr(4, 8) + index.toString()}>\n                                            <TableField style={{ width: '40px' }}>{reserve.service === ASSIST ? 'BASIC' : 'PRO'}</TableField>\n                                            <TableField style={{ width: '64px' }}>{reserve.patient}님</TableField>\n                                            <TableField style={{ width: '86px' }}>{reserve.destination || '-'}</TableField>\n                                            <TableField style={{ width: '170px' }}>{moment(reserve.reserveDate).format('YYYY년 MM월 DD일 - hh:mm')}</TableField>\n                                            <TableField style={{ width: '120px' }}>{moment(reserve.creaetedAt).format('YYYY년 MM월 DD일')}</TableField>\n                                            <TableField style={{ width: '70px' }}>{reserve.call.length > 0 ? reserve.call[0].status : '-'}</TableField>\n                                            <TableField>\n                                                {reserve.call.length > 0 && reserve.call[0].status === '서비스 종료' && reserve.review.length === 0 ? (\n                                                <TableButton\n                                                    onClick={() => {\n                                                        this.onReserve(reserve._id);\n                                                    }}\n                                                >\n                                                    작성 하기\n                                                </TableButton>\n                                            ) : (\n                                                <TableButton className='disabled'>작성 불가</TableButton>\n                                            )}\n                                            </TableField>\n                                        </TableRow>\n                                    );\n                                })} */}\n                        </TableBody>\n\n                        {/* <TableAlert>* 최근 2주내의 이용 내역에 대한 리뷰만 작성이 가능합니다.</TableAlert> */}\n                    </TableContainer>\n                </FullContainer>\n            </div>\n        );\n    }\n}\n\nconst EmptyList = () => (\n    <EmptyWrapper>\n        <EmptyImage src='/assets/images/main_logo.png' alt='logo' />\n        <EmptyText>후기를 작성가능한 이용내역이 없습니다.</EmptyText>\n    </EmptyWrapper>\n);\n","import React from 'react';\nimport { connect } from 'react-redux';\n\nimport { USER, MATE } from '../../../Lib/variables';\nimport { getReserveList } from '../../../Reducer/Modules/app';\nimport StyledMylistContainer from './mylist.styled';\nimport MyCommentList from './mylist';\nimport { message } from 'antd';\n\nclass MyCommentListPage extends React.PureComponent {\n    componentDidMount = () => {\n        const id = localStorage.getItem('id');\n        const userType = localStorage.getItem('userTYp');\n\n        if (id) {\n            this.props.fetchReserveList({ userId: id });\n        }\n\n        if (!id) {\n            message.info('로그인 후 이용해주세요.');\n            return this.props.history.push('/user/login');\n        }\n\n        if (id && userType === MATE) {\n            message.info('일반 사용자를 위한 페이지입니다.');\n            return this.props.history.push('/');\n        }\n    };\n\n    componentDidUpdate = (prevProps, prevState) => {\n        const { id } = this.props.auth;\n\n        if (!prevProps.auth.id && id) {\n            this.props.fetchReserveList({ userId: id });\n        }\n    };\n\n    render() {\n        return (\n            <StyledMylistContainer>\n                <MyCommentList {...this.props} />\n            </StyledMylistContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\nconst mapDispatchToProps = dispatch => ({\n    fetchReserveList: ({ userId }) => dispatch(getReserveList({ userId })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(MyCommentListPage);\n","import React from 'react';\nimport {\n    Container,\n    TopWrapper,\n    BottomWrapper,\n    InnerContainer,\n    Logo,\n    MediumText,\n    LargeText,\n    Title,\n    ApplyButton,\n    FlexWrapper,\n    FlexTitle,\n    Contact,\n    ContactTime,\n    Link,\n    Noti,\n} from './ready.styled';\n\nclass ReadyApplyPage extends React.PureComponent {\n    render() {\n        return (\n            <Container>\n                <TopWrapper>\n                    <InnerContainer>\n                        {/* <Logo src='/assets/images/main_logo.png' alt='withmate' /> */}\n                        <Title>위드메이트 동행 매니저, ‘메이트’</Title>\n                        <MediumText>병원 동행 서비스</MediumText>\n                        <MediumText>새로운 수익 창출의 시작</MediumText>\n                        <Noti>개인 일정에 맞춰 동행 서비스 접수 내역에</Noti>\n                        <Noti>매칭 신청을 하고 수익을 창출하세요!</Noti>\n                        <Noti>*단, 해외 여행에 결격 사유가 없는 자에 한해 지원이 가능합니다*</Noti>\n                        <Noti>* 지원 3일 이내 채용 담당자가 연락을 드립니다.</Noti>\n                        <div>\n                            <ApplyButton\n                                onClick={() => {\n                                    this.props.history.push('/apply/form');\n                                }}\n                            >\n                                메이트 지원하기\n                            </ApplyButton>\n                        </div>\n                        <img className='bg' src={'/assets/images/art_clap.png'} alt='일러스트' />\n                    </InnerContainer>\n                </TopWrapper>\n                <BottomWrapper>\n                    <InnerContainer>\n                        <FlexWrapper>\n                            <div>\n                                <Title style={{ color: '#161616' }}>위드메이트</Title>\n                            </div>\n                            <div>\n                                <FlexTitle>지원관련 상담</FlexTitle>\n                                <Contact>070-4300-9075</Contact>\n                                <ContactTime>상담 가능시간 / 오전 9시 ~ 오후 5시</ContactTime>\n                            </div>\n                            <div>\n                                <FlexTitle>안내사항</FlexTitle>\n                                <br />\n                                <Link href='https://www.notion.so/FAQ-cfe01db37c67472086b414a044ed6370' target='_blank'>\n                                    메이트 가이드\n                                </Link>\n                                <br />\n                                <Link href='https://www.notion.so/01a7a20704d14289a4f6b93de6c56a04?v=b137c8389c66455eb89361fc99291539' target='_blank'>\n                                    메이트 FAQ\n                                </Link>\n                                {/* <br />\n                                <Link href='/service/guide' target='_blank'>\n                                    회사소개\n                                </Link> */}\n                            </div>\n                        </FlexWrapper>\n                    </InnerContainer>\n                </BottomWrapper>\n            </Container>\n        );\n    }\n}\nexport default ReadyApplyPage;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Input } from 'antd';\n\nimport { mainColor } from '../../../theme';\n\nexport const FormContainer = styled.div`\n    // background-color: ${mainColor};\n    width: 100vw;\n\n    padding-top: 55px;\n`;\n\nexport const InnerContainer = styled.div`\n    max-width: 800px;\n    margin: 0 auto;\n    padding: 80px 0px;\n\n    @media (max-width: 1080px) {\n        padding: 80px 16px;\n    }\n\n    @media (max-width: 768px) {\n        padding: 80px 16px;\n    }\n`;\n\nexport const LargeText = styled.p`\n    margin-bottom: 0px;\n\n    font-weight: bold;\n    color: #ffffff;\n    font-size: 32px;\n\n    padding: 2.5px;\n    border-bottom: 4px solid #ffffff;\n    display: inline-block;\n`;\n\nexport const InputWrapper = styled.div`\n    border-radius: 8px;\n    border: 1px solid #e9e9e9;\n    background-color: #ffffff;\n    padding: 16px;\n    border-left: 8px solid ${mainColor};\n\n    margin-bottom: 12px;\n    overflow: hidden;\n`;\n\nexport const InputLabel = styled.div`\n    font-size: 14px;\n    margin-bottom: 8px;\n\n    > span {\n        font-size: 12px;\n    }\n`;\n\nexport const StyledInput = styled(Input.TextArea)`\n    font-size: 14px;\n    &::placeholder {\n        font-size: 14px;\n    }\n`;\n\nexport const ApplyButton = styled.span`\n    padding: 10px 16px;\n    background-color: ${mainColor};\n\n    color: #ffffff;\n    font-size: 16px;\n    font-weight: bold;\n\n    width: 100%;\n    min-width: 200px;\n    max-width: 360px;\n\n    border-radius: 40px;\n    overflow: hidden;\n\n    display: inline-block;\n    margin-top: 40px;\n    cursor: pointer;\n\n    &:hover {\n        transition: all 0.5s;\n        background-color: #ffffff;\n        border: 1px solid ${mainColor};\n        color: ${mainColor};\n    }\n`;\n\nexport const FormImgWrapper = styled.div`\n    > img {\n        width: 150px;\n        object-fit: contain;\n    }\n`;\n\nexport const SpinWrapper = styled.div`\n    display: flex;\n    width: 100vw;\n    height: 100vh;\n\n    position: fixed;\n    top: 0px;\n    left: 0px;\n\n    z-index: 9999;\n\n    align-items: center;\n    justify-content: center;\n\n    background-color: rgba(0, 0, 0, 0.6);\n`;\n","import React from 'react';\nimport { Checkbox, Input, message, Spin } from 'antd';\n\n// utils\nimport axios from '../../../Lib/axios';\nimport { imageUpload } from '../../../Lib/Api/app';\n\n// styles\nimport { FormContainer, InnerContainer, InputWrapper, InputLabel, StyledInput, ApplyButton, LargeText, FormImgWrapper, SpinWrapper } from './form.styled';\n\nconst initialState = {\n    info: [],\n    photoFst: false,\n    photoSnd: false,\n    fileFst: false,\n    fileSnd: false,\n    photoFstValue: null,\n    photoSndValue: null,\n    fileFstValue: null,\n    fileSndValue: null,\n    onSpin: false,\n};\n\nclass MateFormPage extends React.PureComponent {\n    state = {\n        ...initialState,\n    };\n\n    componentDidMount = () => {\n        this.fetchForm();\n    };\n\n    componentWillUnmount = () => {\n        this.setState({ ...initialState });\n    };\n\n    fetchForm = async () => {\n        const { data: form } = await axios.get('/v1/user/recent/apply/form');\n        this.setState({\n            ...form,\n        });\n    };\n\n    editForm = ({ type, value }) => {\n        this.setState({ [type]: value });\n    };\n\n    sendForm = async () => {\n        const { careCareer, info, photoFst, photoSnd, fileSnd, fileFst } = this.state;\n        const { photoFstValue, photoSndValue, fileFstValue, fileSndValue } = this.state;\n\n        this.setState({ onSpin: true });\n\n        if (!careCareer) {\n            this.setState({ onSpin: false });\n            return message.warning('치매 간병 경력 여부를 선택해주세요.');\n        }\n\n        if (info.some(item => !item.value)) {\n            this.setState({ onSpin: false });\n            return message.warning('답변하지 않은 질문이 있습니다.');\n        }\n\n        if (photoFst && !photoFstValue) {\n            this.setState({ onSpin: false });\n            return message.warning('프로필 사진을 첨부해주세요.');\n        }\n\n        if (photoSnd && !photoSndValue) {\n            this.setState({ onSpin: false });\n            return message.warning('이미지 파일을 첨부해주세요.');\n        }\n\n        if (fileFst && !fileFstValue) {\n            this.setState({ onSpin: false });\n            return message.warning('이미지 파일을 첨부해주세요.');\n        }\n\n        if (fileSnd && !fileSndValue) {\n            this.setState({ onSpin: false });\n            return message.warning('추가 파일을 첨부해주세요.');\n        }\n\n        const form = { careCareer, info };\n        if (photoFst) {\n            const { data } = await imageUpload(photoFstValue);\n            form.photoFst = data;\n        }\n        if (photoSnd) {\n            const { data } = await imageUpload(photoSndValue);\n            form.photoSnd = data;\n        }\n        if (fileFst) {\n            const { data } = await imageUpload(fileFstValue);\n            form.fileFst = data;\n        }\n        if (fileSnd) {\n            const { data } = await imageUpload(fileSndValue);\n            form.fileSnd = data;\n        }\n\n        const { data } = await axios.post('/v1/user/apply/mate', {\n            form,\n        });\n\n        if (!data) {\n            this.setState({ onSpin: false });\n            return message.error('서버 장애로 지원에 실패했습니다. 관리자에게 문의해주세요.');\n        }\n\n        if (data === 'success') {\n            this.setState({ onSpin: false });\n            message.success('감사합니다. 메이트 지원이 완료되었습니다. 검토후 결과를 안내해드리겠습니다.');\n            console.log(data, form);\n            setTimeout(() => {\n                window.location.href = '/';\n            }, 1500);\n            return null;\n        }\n\n        if (data === 'check parameters') {\n            this.setState({ onSpin: false });\n            return message.info('누락된 정보가 있는지 지원서 양식을 확인해주세요.');\n        }\n    };\n\n    render() {\n        const { careCareer, info, photoFst, photoSnd, fileFst, fileSnd } = this.state;\n\n        return (\n            <FormContainer>\n                <InnerContainer>\n                    <LargeText style={{ color: '#161616', marginBottom: '20px' }}>메이트 지원하기</LargeText>\n                    <InputWrapper>\n                        <InputLabel>치매관련 간병 경력</InputLabel>\n                        <Checkbox checked={careCareer === '없어요'}\n                            onClick={() => {\n                                this.editForm({ type: 'careCareer', value: '없어요' })\n                            }}\n                        >\n                            없어요\n                        </Checkbox>\n                        <Checkbox checked={careCareer === '1년 미만'}\n                            onClick={() => {\n                                this.editForm({ type: 'careCareer', value: '1년 미만' })\n                            }}\n                        >\n                            1년 미만\n                        </Checkbox>\n                        <Checkbox checked={careCareer === '2 ~ 3년'}\n                            onClick={() => {\n                                this.editForm({ type: 'careCareer', value: '2 ~ 3년' })\n                            }}\n                        >\n                            2 ~ 3년\n                        </Checkbox>\n                        <Checkbox checked={careCareer === '3년이상'}\n                            onClick={() => {\n                                this.editForm({ type: 'careCareer', value: '3년이상' })\n                            }}\n                        >\n                            3년이상\n                        </Checkbox>\n                    </InputWrapper>\n\n                    {info.map((item, index) => (\n                        <InputWrapper key={'question-' + index.toString() + '-keys'}>\n                            <InputLabel>\n                                {item.question}{' '}\n                                {item.maxLength ? (\n                                    <span>\n                                        ({item.value ? item.value.length : 0}/{item.maxLength})\n                                    </span>\n                                ) : (\n                                    ''\n                                )}\n                            </InputLabel>\n                            <StyledInput\n                                value={item.value}\n                                placeholder={item.placeholder}\n                                onChange={ev => {\n                                    const _info = JSON.parse(JSON.stringify(info));\n                                    if (item.maxLength && ev.target.value.length > item.maxLength) {\n                                        return null;\n                                    }\n\n                                    _info[index].value = ev.target.value;\n                                    this.editForm({ type: 'info', value: _info });\n                                }}\n                            />\n                        </InputWrapper>\n                    ))}\n                    {photoFst ? (\n                        <InputWrapper>\n                            <InputLabel>프로필 사진</InputLabel>\n                            {this.state.photoFstValue ? (\n                                <FormImgWrapper>\n                                    <img src={URL.createObjectURL(this.state.photoFstValue)} />\n                                </FormImgWrapper>\n                            ) : null}\n                            <input\n                                type='file'\n                                accept='image/x-png,image/gif,image/jpeg'\n                                onChange={ev => {\n                                    this.editForm({ type: 'photoFstValue', value: ev.target.files[0] });\n                                }}\n                            />\n                        </InputWrapper>\n                    ) : null}\n                    {photoSnd ? (\n                        <InputWrapper>\n                            <InputLabel>이미지 파일 첨부</InputLabel>\n                            {this.state.photoSndValue ? (\n                                <FormImgWrapper>\n                                    <img src={URL.createObjectURL(this.state.photoSndValue)} />\n                                </FormImgWrapper>\n                            ) : null}\n                            <input\n                                type='file'\n                                accept='image/x-png,image/gif,image/jpeg'\n                                onChange={ev => {\n                                    this.editForm({ type: 'photoSndValue', value: ev.target.files[0] });\n                                }}\n                            />\n                        </InputWrapper>\n                    ) : null}\n                    {fileFst ? (\n                        <InputWrapper>\n                            <InputLabel>이력서 첨부</InputLabel>\n                            {this.state.fileFstValue ? <p>{this.state.fileFstValue.name}</p> : null}\n                            <input\n                                type='file'\n                                onChange={ev => {\n                                    this.editForm({ type: 'fileFstValue', value: ev.target.files[0] });\n                                }}\n                            />\n                        </InputWrapper>\n                    ) : null}\n                    {fileSnd ? (\n                        <InputWrapper>\n                            <InputLabel>추가 파일첨부</InputLabel>\n                            {this.state.fileSndValue ? <p>{this.state.fileSndValue.name}</p> : null}\n                            <input\n                                type='file'\n                                onChange={ev => {\n                                    this.editForm({ type: 'fileSndValue', value: ev.target.files[0] });\n                                }}\n                            />\n                        </InputWrapper>\n                    ) : null}\n\n                    <div style={{ textAlign: 'center' }}>\n                        <ApplyButton onClick={this.sendForm}>지원하기</ApplyButton>\n                    </div>\n                </InnerContainer>\n                {this.state.onSpin ? (\n                    <SpinWrapper>\n                        <Spin size='large' />\n                    </SpinWrapper>\n                ) : null}\n            </FormContainer>\n        );\n    }\n}\n\nexport default MateFormPage;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Input } from 'antd';\n\nimport { mainColor } from '../../../theme';\n\nexport const FormContainer = styled.div`\n    // background-color: ${mainColor};\n    width: 100vw;\n\n    padding-top: 55px;\n`;\n\nexport const InnerContainer = styled.div`\n    max-width: 800px;\n    margin: 0 auto;\n    padding: 80px 0px;\n\n    .type-button-wrapper {\n        width: 100%;\n        height: 48px;\n\n        background-color: white;\n        border: 1px solid #e6e6e6;\n        border-radius: 4px;\n\n        display: flex;\n        align-items: center;\n\n        > .type-button {\n            width: 50%;\n            height: 100%;\n            line-height: 48px;\n\n            text-align: center;\n            cursor: pointer;\n\n            font-size: 16px;\n            letter-spacing: -0.2px;\n            color: rgba(0, 0, 0, 0.2);\n        }\n\n        > .type-button.active {\n            background: rgba(0, 0, 0, 0.7);\n            border-radius: 4px;\n            color: #f9f9f9;\n        }\n    }\n\n    @media (max-width: 1080px) {\n        padding: 80px 16px;\n    }\n\n    @media (max-width: 768px) {\n        padding: 80px 16px;\n    }\n`;\n\nexport const LargeText = styled.p`\n    margin-bottom: 0px;\n\n    font-weight: bold;\n    color: #ffffff;\n    font-size: 32px;\n\n    padding: 2.5px;\n    border-bottom: 4px solid #ffffff;\n    display: inline-block;\n`;\n\nexport const InputWrapper = styled.div`\n    border-radius: 8px;\n    border: 1px solid #e9e9e9;\n    background-color: #ffffff;\n    padding: 16px;\n    border-left: 8px solid ${mainColor};\n\n    margin-bottom: 12px;\n    overflow: hidden;\n`;\n\nexport const InputLabel = styled.div`\n    font-size: 17px;\n    margin-bottom: 8px;\n\n    > span {\n        font-size: 12px;\n    }\n`;\n\nexport const StyledInput = styled(Input.TextArea)`\n    font-size: 14px;\n    &::placeholder {\n        font-size: 14px;\n    }\n`;\n\nexport const ApplyButton = styled.span`\n    padding: 10px 16px;\n    background-color: ${mainColor};\n\n    color: #ffffff;\n    font-size: 16px;\n    font-weight: bold;\n\n    width: 100%;\n    min-width: 200px;\n    max-width: 360px;\n\n    border-radius: 40px;\n    overflow: hidden;\n\n    display: inline-block;\n    margin-top: 40px;\n    cursor: pointer;\n\n    &:hover {\n        transition: all 0.5s;\n        background-color: #ffffff;\n        border: 1px solid ${mainColor};\n        color: ${mainColor};\n    }\n`;\n\nexport const FormImgWrapper = styled.div`\n    > img {\n        padding-bottom: 10px;\n        width: 150px;\n        object-fit: contain;\n    }\n`;\n\nexport const SpinWrapper = styled.div`\n    display: flex;\n    width: 100vw;\n    height: 100vh;\n\n    position: fixed;\n    top: 0px;\n    left: 0px;\n\n    z-index: 9999;\n\n    align-items: center;\n    justify-content: center;\n\n    background-color: rgba(0, 0, 0, 0.6);\n`;\n","import React from 'react';\nimport { Checkbox, Select, message, Spin } from 'antd';\n\n// utils\nimport axios from '../../../Lib/axios';\nimport { imageUpload } from '../../../Lib/Api/app';\n\n// styles\nimport { FormContainer, InnerContainer, InputWrapper, InputLabel, ApplyButton, LargeText, FormImgWrapper, SpinWrapper } from './mateApply.styled';\nimport { WithamteInputWithButton, WithmateInput, WithmateSelect, WithmateTextarea } from '../../../Components/Common/input';\n\nclass MateApplyPage extends React.PureComponent {\n    state = {\n        photo: '',\n        onSpin: false,\n    };\n\n    handleChange = e => {\n        this.setState({ [e.target.title]: e.target.value });\n    };\n\n    handleTrimChange = e => {\n        this.setState({ [e.target.title]: e.target.value.trim() });\n    };\n\n    onAddress = () => {\n        new window.daum.Postcode({\n            oncomplete: data => {\n                const { roadAddress, buildingName } = data;\n                this.setState(prevState => ({\n                    address: `${roadAddress} (${buildingName})`,\n                }));\n            },\n        }).open();\n    };\n\n    editApply = ({ type, value }) => {\n        this.setState({ [type]: value });\n    };\n\n    onSendApply = async () => {\n        const {\n            name,\n            gender,\n            birth,\n            // photo,\n            email,\n            contact,\n            address,\n            connection,\n            connection_etc,\n            activity_area,\n            drive,\n            careCareer,\n            care_experience,\n            insurance,\n            privacy,\n            license_photo,\n        } = this.state;\n\n        this.setState({ onSpin: true });\n\n        if (!name) {\n            this.setState({ onSpin: false });\n            return message.warning('성함을 입력하세요.');\n        }\n\n        if (!gender) {\n            this.setState({ onSpin: false });\n            return message.warning('성별을 입력하세요.');\n        }\n\n        if (!birth || birth.length < 8) {\n            this.setState({ onSpin: false });\n            return message.warning('생년월일 8자리를 입력하세요.');\n        }\n\n        if (!email) {\n            this.setState({ onSpin: false });\n            return message.warning('이메일을 입력하세요.');\n        }\n\n        if (!contact) {\n            this.setState({ onSpin: false });\n            return message.warning('개인 연락처를 입력하세요.');\n        }\n\n        if (!address) {\n            this.setState({ onSpin: false });\n            return message.warning('자택 주소를 검색하여 입력하세요.');\n        }\n\n        if (!careCareer) {\n            this.setState({ onSpin: false });\n            return message.warning('치매관련 간병 경력 기간을 선택하세요.');\n        }\n\n        // if (!activity_area) {\n        //     this.setState({ onSpin: false });\n        //     return message.warning('메이트 활동이 가능한 지역을 선택해주세요.');\n        // }\n\n        if (!care_experience) {\n            this.setState({ onSpin: false });\n            return message.warning('개인 간병 경력 사항을 입력하세요.');\n        }\n\n        if (!insurance) {\n            this.setState({ onSpin: false });\n            return message.warning('삼성화재 전문인 배상 책임 보험 가입 동의를 선택하세요.');\n        }\n\n        if (!privacy) {\n            this.setState({ onSpin: false });\n            return message.warning('개인정보 수집 및 이용 동의를 선택하세요.');\n        }\n\n        const formData = new FormData();\n        formData.append('license_photo', license_photo);\n        const header = { headers: { 'Content-Type': 'multipart/form-data' } };\n        const { data: image } = await axios.post('/v1/user/apply/mate/image/upload', formData, header);\n\n        const { data } = await axios.post('/v1/user/apply/mate/add', {\n            name,\n            gender,\n            birth,\n            // photo: image,\n            email,\n            contact,\n            address,\n            connection,\n            connection_etc,\n            activity_area: activity_area ? activity_area.join(', ') : '', // 배열을 쉼표로 구분된 문자열로 변환\n            drive,\n            careCareer,\n            care_experience,\n            insurance,\n            privacy,\n            license_photo: image,\n        });\n\n        if (!data) {\n            this.setState({ onSpin: false });\n            return message.error('서버 장애로 지원에 실패했습니다. 관리자에게 문의해주세요.');\n        }\n\n        if (data === 'success') {\n            this.setState({ onSpin: false });\n            message.success('감사합니다. 메이트 지원이 완료되었습니다. 검토후 결과를 안내해드리겠습니다.');\n            setTimeout(() => {\n                window.location.href = '/';\n            }, 1500);\n            return null;\n        }\n\n        if (data === 'check parameters') {\n            this.setState({ onSpin: false });\n            return message.info('누락된 정보가 있는지 지원서 양식을 확인해주세요.');\n        }\n    };\n\n    render() {\n        return (\n            <FormContainer>\n                <InnerContainer>\n                    <LargeText style={{ color: '#161616', marginBottom: '20px' }}>메이트 지원하기</LargeText>\n\n                    <InputWrapper>\n                        <InputLabel>성함을 입력하세요</InputLabel>\n                        <WithmateInput type='text' title='name' value={this.state.name || ''} onChange={this.handleTrimChange} />\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>성별을 선택하세요</InputLabel>\n                        <div className='type-button-wrapper'>\n                            <div\n                                className={`type-button ${this.state.gender && this.state.gender === '남자' ? 'active' : ''}`}\n                                onClick={() => {\n                                    this.editApply({ type: 'gender', value: '남자' });\n                                }}\n                            >\n                                남자\n                            </div>\n                            <div\n                                className={`type-button ${this.state.gender && this.state.gender === '여자' ? 'active' : ''}`}\n                                onClick={() => {\n                                    this.editApply({ type: 'gender', value: '여자' });\n                                }}\n                            >\n                                여자\n                            </div>\n                        </div>\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>생년월일을 입력하세요</InputLabel>\n                        <WithmateInput\n                            type='text'\n                            title='birth'\n                            value={this.state.birth || ''}\n                            onChange={this.handleTrimChange}\n                            placeholder='만 19세 이상의 성인만 메이트로 활동이 가능합니다. 생년월일을 8자리로 입력해주세요'\n                        />\n                    </InputWrapper>\n\n                    {/* <InputWrapper>\n                        <InputLabel>이미지 파일 첨부</InputLabel>\n                        {this.state.photo ? (\n                            <FormImgWrapper>\n                                <img src={URL.createObjectURL(this.state.photo)} />\n                            </FormImgWrapper>\n                        ) : null}\n                        <input\n                            type='file'\n                            accept='image/x-png,image/gif,image/jpeg'\n                            onChange={ev => {\n                                this.editApply({ type: 'photo', value: ev.target.files[0] });\n                            }}\n                        />\n                    </InputWrapper> */}\n\n                    <InputWrapper>\n                        <InputLabel>개인 이메일을 입력하세요</InputLabel>\n                        <WithmateInput\n                            type='text'\n                            title='email'\n                            value={this.state.email || ''}\n                            onChange={this.handleTrimChange}\n                            placeholder='기입하신 이메일로 프리랜서 근로 계약 문서가 전송되고 온라인 계약 체결이 진행됩니다.'\n                        />\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>개인 연락처를 입력하세요</InputLabel>\n                        <WithmateInput\n                            type='text'\n                            title='contact'\n                            value={this.state.contact || ''}\n                            onChange={this.handleTrimChange}\n                            placeholder='기입해주신 연락처로 메이트 합격/불합격 여부 알림과 메이트로 활동하실때 사용하시는 아이디와 임시 비밀번호 전송됩니다.'\n                        />\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>자택 주소를 입력하세요</InputLabel>\n                        <WithamteInputWithButton\n                            inputConfig={{\n                                type: 'text',\n                                placeholder: 'ex) 서울특별시 도산대로 40, OO 아파트',\n                                name: 'address',\n                                value: this.state.address || '',\n                            }}\n                            buttonName='검색'\n                            onButton={() => {\n                                this.onAddress();\n                            }}\n                        />\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>메이트 가입 경로(선택 사항)</InputLabel>\n                        <WithmateSelect\n                            style={{ height: '48px', width: '100%', paddingBottom: '5px' }}\n                            placeholder='위드메이트의 메이트 가입 경로를 선택하세요'\n                            value={this.state.connection || undefined}\n                            onChange={value => {\n                                this.editApply({ type: 'connection', value });\n                            }}\n                        >\n                            <Select.Option value='한국직업평가진흥협회'>한국직업평가진흥협회</Select.Option>\n                            <Select.Option value='검색'>검색</Select.Option>\n                            <Select.Option value='광고'>광고</Select.Option>\n                            <Select.Option value='구직사이트'>구직사이트</Select.Option>\n                            <Select.Option value='뉴스기사'>뉴스기사</Select.Option>\n                            <Select.Option value='대신위드유'>대신위드유</Select.Option>\n                            <Select.Option value='에이플러스'>에이플러스</Select.Option>\n                            <Select.Option value='복지넷'>복지넷</Select.Option>\n                            <Select.Option value='강동 50+'>강동 50+</Select.Option>\n                            <Select.Option value='서대문 50+'>서대문 50+</Select.Option>\n                            <Select.Option value='국립 암센터'>국립 암센터</Select.Option>\n                            <Select.Option value='지인'>지인</Select.Option>\n                            <Select.Option value='카페'>카페•블로그</Select.Option>\n                            <Select.Option value='기타'>기타</Select.Option>\n                        </WithmateSelect>\n                        {this.state.connection === '기타' ? (\n                            <WithmateInput\n                                type='text'\n                                title='connection_etc'\n                                value={this.state.connection_etc || ''}\n                                onChange={this.handleChange}\n                                placeholder='메이트 가입 경로를 입력하세요'\n                            />\n                        ) : null}\n                        {this.state.connection === '한국직업평가진흥협회' ? (\n                            <InputWrapper>\n                                <InputLabel>자격증 이미지 파일첨부</InputLabel>\n                                {this.state.license_photo ? (\n                                    <FormImgWrapper>\n                                        <img src={URL.createObjectURL(this.state.license_photo)} />\n                                    </FormImgWrapper>\n                                ) : null}\n                                <input\n                                    type='file'\n                                    accept='image/x-png,image/gif,image/jpeg'\n                                    onChange={ev => {\n                                        this.editApply({ type: 'license_photo', value: ev.target.files[0] });\n                                    }}\n                                />\n                            </InputWrapper>\n                        ) : null}\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>메이트 활동 가능 지역을 알려주세요</InputLabel>\n                        <WithmateSelect\n                            style={{ height: '48px', width: '100%', paddingBottom: '5px' }}\n                            placeholder='메이트 활동이 가능한 지역을 선택해주세요 (여러개 가능)'\n                            value={this.state.si || undefined}\n                            onChange={value => {\n                                this.editApply({ type: 'si', value });\n                            }}\n                        >\n                            <Select.Option value='서울'>서울</Select.Option>\n                            <Select.Option value='경기도'>경기도</Select.Option>\n                            <Select.Option value='경상남도'>경상남도</Select.Option>\n                        </WithmateSelect>\n                        {this.state.si === '서울' ? (\n                            <WithmateSelect\n                                mode='multiple'\n                                style={{ height: '48px', width: '100%', paddingBottom: '5px' }}\n                                placeholder='메이트 활동이 가능한 지역을 선택해주세요 (여러개 가능)'\n                                value={this.state.activity_area || []}\n                                onChange={value => {\n                                    this.editApply({ type: 'activity_area', value });\n                                }}\n                            >\n                                <Select.Option value='강남구'>강남구</Select.Option>\n                                <Select.Option value='강동구'>강동구</Select.Option>\n                                <Select.Option value='강북구'>강북구</Select.Option>\n                                <Select.Option value='강서구'>강서구</Select.Option>\n                                <Select.Option value='관악구'>관악구</Select.Option>\n                                <Select.Option value='광진구'>광진구</Select.Option>\n                                <Select.Option value='구로구'>구로구</Select.Option>\n                                <Select.Option value='금천구'>금천구</Select.Option>\n                                <Select.Option value='노원구'>노원구</Select.Option>\n                                <Select.Option value='도봉구'>도봉구</Select.Option>\n                                <Select.Option value='동대문구'>동대문구</Select.Option>\n                                <Select.Option value='동작구'>동작구</Select.Option>\n                                <Select.Option value='마포구'>마포구</Select.Option>\n                                <Select.Option value='서대문구'>서대문구</Select.Option>\n                                <Select.Option value='서초구'>서초구</Select.Option>\n                                <Select.Option value='성동구'>성동구</Select.Option>\n                                <Select.Option value='성북구'>성북구</Select.Option>\n                                <Select.Option value='송파구'>송파구</Select.Option>\n                                <Select.Option value='양천구'>양천구</Select.Option>\n                                <Select.Option value='영등포구'>영등포구</Select.Option>\n                                <Select.Option value='용산구'>용산구</Select.Option>\n                                <Select.Option value='은평구'>은평구</Select.Option>\n                                <Select.Option value='종로구'>종로구</Select.Option>\n                                <Select.Option value='중구'>중구</Select.Option>\n                                <Select.Option value='중랑구'>중랑구</Select.Option>\n                            </WithmateSelect>\n                        ) : null}\n                        {this.state.si === '경기도' ? (\n                            <WithmateSelect\n                                mode='multiple'\n                                style={{ height: '48px', width: '100%', paddingBottom: '5px' }}\n                                placeholder='메이트 활동이 가능한 지역을 선택해주세요 (여러개 가능)'\n                                value={this.state.activity_area || []}\n                                onChange={value => {\n                                    this.editApply({ type: 'activity_area', value });\n                                }}\n                            >\n                                <Select.Option value='경기남부'>경기남부</Select.Option>\n                                <Select.Option value='수원시'>수원시</Select.Option>\n                                <Select.Option value='용인시'>용인시</Select.Option>\n                                <Select.Option value='성남시'>성남시</Select.Option>\n                                <Select.Option value='부천시'>부천시</Select.Option>\n                                <Select.Option value='화성시'>화성시</Select.Option>\n                                <Select.Option value='안산시'>안산시</Select.Option>\n                                <Select.Option value='평택시'>평택시</Select.Option>\n                                <Select.Option value='시흥시'>시흥시</Select.Option>\n                                <Select.Option value='김포시'>김포시</Select.Option>\n                                <Select.Option value='광주시'>광주시</Select.Option>\n                                <Select.Option value='광명시'>광명시</Select.Option>\n                                <Select.Option value='군포시'>군포시</Select.Option>\n                                <Select.Option value='하남시'>하남시</Select.Option>\n                                <Select.Option value='오산시'>오산시</Select.Option>\n                                <Select.Option value='이천시'>이천시</Select.Option>\n                                <Select.Option value='안성시'>안성시</Select.Option>\n                                <Select.Option value='의왕시'>의왕시</Select.Option>\n                                <Select.Option value='양평군'>양평군</Select.Option>\n                                <Select.Option value='여주시'>여주시</Select.Option>\n                                <Select.Option value='과천시'>과천시</Select.Option>\n                                <Select.Option value='경기북부'>경기북부</Select.Option>\n                                <Select.Option value='고양시'>고양시</Select.Option>\n                                <Select.Option value='남양주시'>남양주시</Select.Option>\n                                <Select.Option value='파주시'>파주시</Select.Option>\n                                <Select.Option value='의정부시'>의정부시</Select.Option>\n                                <Select.Option value='양주시'>양주시</Select.Option>\n                                <Select.Option value='구리시'>구리시</Select.Option>\n                                <Select.Option value='포천시'>포천시</Select.Option>\n                                <Select.Option value='동두천시'>동두천시</Select.Option>\n                                <Select.Option value='가평군'>가평군</Select.Option>\n                                <Select.Option value='연천군'>연천군</Select.Option>\n                            </WithmateSelect>\n                        ) : null}\n\n                        {this.state.si === '경상남도' ? (\n                            <WithmateSelect\n                                mode='multiple'\n                                style={{ height: '48px', width: '100%', paddingBottom: '5px' }}\n                                placeholder='메이트 활동이 가능한 지역을 선택해주세요 (여러개 가능)'\n                                value={this.state.activity_area || []}\n                                onChange={value => {\n                                    this.editApply({ type: 'activity_area', value });\n                                }}\n                            >\n                                <Select.Option value='창원시'>창원시</Select.Option>\n                            </WithmateSelect>\n                        ) : null}\n                        {/* <WithmateInput\n                            type='text'\n                            title='activity_area'\n                            value={this.state.activity_area || ''}\n                            onChange={this.handleChange}\n                            placeholder='메이트 활동이 가능한 서비스 지역과 병원을 알려주세요 (강남구 일대, 종로구 일대, 세브란스 병원, 서울대 병원, 아산병원 등'\n                        /> */}\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>운전 가능 여부를 선택하세요</InputLabel>\n                        <Checkbox\n                            checked={this.state.drive === '가능'}\n                            onClick={() => {\n                                this.editApply({ type: 'drive', value: '가능' });\n                            }}\n                        >\n                            가능\n                        </Checkbox>\n                        <Checkbox\n                            checked={this.state.drive === '불가능'}\n                            onClick={() => {\n                                this.editApply({ type: 'drive', value: '불가능' });\n                            }}\n                        >\n                            불가능\n                        </Checkbox>\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>치매관련 간병 경력</InputLabel>\n                        <Checkbox\n                            checked={this.state.careCareer === '없어요'}\n                            onClick={() => {\n                                this.editApply({ type: 'careCareer', value: '없어요' });\n                            }}\n                        >\n                            없어요\n                        </Checkbox>\n                        <Checkbox\n                            checked={this.state.careCareer === '1년 미만'}\n                            onClick={() => {\n                                this.editApply({ type: 'careCareer', value: '1년 미만' });\n                            }}\n                        >\n                            1년 미만\n                        </Checkbox>\n                        <Checkbox\n                            checked={this.state.careCareer === '2 ~ 3년'}\n                            onClick={() => {\n                                this.editApply({ type: 'careCareer', value: '2 ~ 3년' });\n                            }}\n                        >\n                            2 ~ 3년\n                        </Checkbox>\n                        <Checkbox\n                            checked={this.state.careCareer === '3년이상'}\n                            onClick={() => {\n                                this.editApply({ type: 'careCareer', value: '3년이상' });\n                            }}\n                        >\n                            3년이상\n                        </Checkbox>\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>개인의 간병 경력 사항을 입력하세요</InputLabel>\n                        <WithmateTextarea\n                            style={{ height: '100px' }}\n                            type='text'\n                            title='care_experience'\n                            value={this.state.care_experience || ''}\n                            onChange={this.handleChange}\n                            placeholder='메이트 활동을 위해 도움이 되는 자신의 간병 경력을 500자 이내로 자유롭게 남겨주세요 (요양보호사 자격증 보유 & OO요양병원 3년 근무 등 / 간병 이외의 경력도 기재 가능'\n                        />\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>삼성화재 전문인 배상 책임 보험 가입 동의</InputLabel>\n                        <p style={{ fontSize: '13px', color: 'gray', paddingBottom: '10px' }}>\n                            보험 가입 심사를 위해 설계 동의를 진행해주세요. 위드메이트는 메이트의 서비스 이행 중 안전한 보호를 위해 회사가 부담하는 보험 가입\n                            절차를 도와드리고 있습니다. 보험 가입에 대한 의사를 체크해주세요. 해당 절차는 보험 가입 심사 동의를 위한 것이며, 동의를 하는것\n                            만으로 보험에 가입이 되는 것은 아닙니다. 보험 가입은 메이트 심사 합격 후 실제 서비스가 매칭된 인원에 한하여 본사와 전화 상담 후\n                            진행됩니다.\n                        </p>\n                        <Checkbox\n                            checked={this.state.insurance === '동의'}\n                            onClick={() => {\n                                this.editApply({ type: 'insurance', value: '동의' });\n                            }}\n                        >\n                            동의\n                        </Checkbox>\n                        <Checkbox\n                            checked={this.state.insurance === '비동의'}\n                            onClick={() => {\n                                this.editApply({ type: 'insurance', value: '비동의' });\n                            }}\n                        >\n                            비동의\n                        </Checkbox>\n                    </InputWrapper>\n\n                    <InputWrapper>\n                        <InputLabel>개인정보 수집 및 이용 동의</InputLabel>\n                        <p style={{ fontSize: '13px', color: 'gray', paddingBottom: '10px' }}>\n                            위드메이트는 본 지원서를 통해 수집한 개인정보를 메이트 심사, 서비스 교육 안내, 동행 서비스 중개를 제외한 타 목적으로 이용하지\n                            않습니다. 지원자는 본 개인정보 수집 및 이용에 동의하지 않을 권리가 있습니다. 단, 동의하지 않을 경우 메이트 심사 및 모집에 제한이\n                            있을 수 있습니다. 위드메이트의 개인정보 수집 및 이용 동의 여부를 선택해주세요.\n                        </p>\n                        <Checkbox\n                            checked={this.state.privacy === '동의'}\n                            onClick={() => {\n                                this.editApply({ type: 'privacy', value: '동의' });\n                            }}\n                        >\n                            동의\n                        </Checkbox>\n                        <Checkbox\n                            checked={this.state.privacy === '비동의'}\n                            onClick={() => {\n                                this.editApply({ type: 'privacy', value: '비동의' });\n                            }}\n                        >\n                            비동의\n                        </Checkbox>\n                    </InputWrapper>\n\n                    <div style={{ textAlign: 'center' }}>\n                        <ApplyButton onClick={this.onSendApply}>지원하기</ApplyButton>\n                    </div>\n                </InnerContainer>\n                {/* {this.state.onSpin ? (\n                    <SpinWrapper>\n                        <Spin size='large' />\n                    </SpinWrapper>\n                ) : null} */}\n            </FormContainer>\n        );\n    }\n}\n\nexport default MateApplyPage;\n","import React from 'react';\nimport { HashLink } from 'react-router-hash-link';\nimport swal from 'sweetalert2';\n\n// components\nimport { GuideNavContainer, InnerContainer, GuideNavWrapper, NavTab, MobileBr } from '../guide.styled';\n\nexport const GuideNav = ({ activeTab, onTab, onReserve }) => {\n    return (\n        <GuideNavContainer>\n            <InnerContainer>\n                <GuideNavWrapper>\n                    <NavTab active={activeTab === 'withmate'}>\n                        <HashLink\n                            to='/nemt/service/#withmate'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('withmate');\n                            }}\n                        >\n                            위드메이트란?\n                        </HashLink>\n                    </NavTab>\n                    {/* <NavTab active={activeTab === 'concept'}>\n                        <HashLink\n                            to='/nemt/service/#concept'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('concept');\n                            }}\n                        >\n                            병원 동행이란?\n                        </HashLink>\n                    </NavTab> */}\n                    <NavTab active={activeTab === 'types'}>\n                        <HashLink\n                            to='/nemt/service/#types'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('types');\n                            }}\n                        >\n                            서비스 종류\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'merit'}>\n                        <HashLink\n                            to='/nemt/service/#merit'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('merit');\n                            }}\n                        >\n                            믿을수 있는 위드메이트\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'usage'}>\n                        <HashLink\n                            to='/nemt/service/#usage'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('usage');\n                            }}\n                        >\n                            이런분께 추천해요\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'partners'}>\n                        <HashLink\n                            to='/nemt/service/#partners'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('partners');\n                            }}\n                        >\n                            위드메이트 파트너\n                        </HashLink>\n                    </NavTab>\n                </GuideNavWrapper>\n            </InnerContainer>\n        </GuideNavContainer>\n    );\n};\n","import React from 'react';\n\n// components\nimport {\n    GuideConceptContainer,\n    InnerContainer,\n    GuideConceptTitle,\n    GuideConceptImageWrapper,\n    GuideConceptImage,\n    GuideConceptImageMobile,\n    GuideConceptTextWrapper,\n    GuideConceptTextBlock,\n    MobileBr,\n    DesktopBr,\n} from '../guide.styled';\n\nexport const GuideConcept = ({}) => {\n    return (\n        <GuideConceptContainer id='concept'>\n            {/* <InnerContainer>\n                <GuideConceptTitle>병원 동행이란?</GuideConceptTitle>\n                <GuideConceptImageWrapper>\n                    <GuideConceptImage src='/assets/images/with_concept_new.png' />\n                    <GuideConceptImageMobile src='/assets/images/with_concept_mobile_new.png' />\n                </GuideConceptImageWrapper>\n                <GuideConceptTextWrapper>\n                    <GuideConceptTextBlock>\n                        <span>‘비응급 의료 동행(Non-Emergency-Medical-Transportation)’</span>으로\n                        <DesktopBr /> 불리는 ‘병원 동행’ 서비스는 응급 상황에 처하지는 않았으나 정기적, 혹은\n                        <DesktopBr /> 비정기적으로 의료 기관에 방문해 적절한 의료 조치를 받아야 하는 사람을\n                        <DesktopBr /> 위한 <span>헬스케어 서비스</span>\n                        입니다. 이미 미국과 캐나다, 일본 등의 선진국에서는\n                        <DesktopBr /> 국가 주도의 복지 서비스로 정착했으며, 이를 넘어 국가 차원의 병원 동행\n                        <DesktopBr /> 전문 기업 육성에 힘을 쏟고 있는 상황입니다.\n                    </GuideConceptTextBlock>\n                    <GuideConceptTextBlock>\n                        위드메이트는 <span>국내 최초</span>로 ‘비응급 의료 동행 서비스’의 개념을 구축했으며,\n                        <DesktopBr /> 유수의 기관과 많은 개인에게 병원 동행 서비스를 제공했습니다.\n                        <DesktopBr />\n                        <MobileBr />\n                        <DesktopBr /> 위드메이트 플랫폼이 제공하는 병원 동행 서비스는 다음과 같습니다.\n                    </GuideConceptTextBlock>\n                </GuideConceptTextWrapper>\n            </InnerContainer> */}\n        </GuideConceptContainer>\n    );\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport swal from 'sweetalert2';\n\n// components\nimport {\n    GuideDetailContainer,\n    InnerContainer,\n    GuideConceptTitle,\n    GuideDetailServiceCardWrapper,\n    GuideDetailServiceCard,\n    GuideCardImage,\n    GuideCardName,\n    GuideCardType,\n    GuideCardDescription,\n    GuideCardSpecTitle,\n    GuideCardSpecRow,\n    MobileBr,\n    DesktopBr,\n} from '../guide.styled';\n\nimport { UNEMER, ASSIST } from '../../../Lib/variables';\n\nexport const GuideDetail = () => {\n    return (\n        <GuideDetailContainer id='types'>\n            <InnerContainer>\n                <GuideConceptTitle>서비스 종류</GuideConceptTitle>\n                <GuideDetailServiceCardWrapper>\n                    <GuideCard\n                        source={'/assets/images/art_pro.png'}\n                        name='병원 동행'\n                        type='Pro'\n                        desc={\n                            <>\n                                <>\n                                    위드메이트 동행 전문가가 고객님의\n                                    <br />\n                                    <span>자택에서 병원까지 </span>동행하고, 병원 업무를\n                                    <br />\n                                    마친 뒤 <span>다시 자택까지</span> 동행합니다.\n                                </>\n                                <br />\n                                <br />\n                                <>\n                                    <b>요금</b> <br />\n                                    시간당 25,000원 (추가 30분마다 12,500원)\n                                </>\n                            </>\n                        }\n                        spec1={\n                            <>\n                                위드메이트 소속 동행 전문가가 <br />\n                                자택에서 병원까지 동행\n                            </>\n                        }\n                        spec2={\n                            <>\n                                대중교통, 고객님 소유 자차, 택시 중<br />\n                                선택하여 이동\n                            </>\n                        }\n                        spec3={\n                            <>\n                                서비스 종료 이후\n                                <br />\n                                서비스 보고서 열람 가능\n                            </>\n                        }\n                        spec4={\n                            <>\n                                서비스 진행 단계별 카카오톡\n                                <br />\n                                실시간 알림 업데이트 제공\n                            </>\n                        }\n                    />\n                    <GuideCard\n                        source={'/assets/images/art_basic.png'}\n                        name='병원 동행'\n                        type='Basic'\n                        desc={\n                            <>\n                                <>\n                                    위드메이트 베이직 서비스는 위드메이트 동행\n                                    <br />\n                                    전문가가 고객님께서 지정한 의료 시설 혹은\n                                    <br />\n                                    <span>병원 내에서 보호자 대행 업무</span>를 수행합니다.\n                                </>\n                                <br />\n                                <br />\n                                <>\n                                    <b>요금</b> <br />\n                                    시간당 15,000원 (추가 30분마다 7,500원)\n                                </>\n                            </>\n                        }\n                        spec1={\n                            <>\n                                고객님의 진료 일정에 맞춰 위드메이트 <br />\n                                소속 동행 전문가가 의료 시설 도착\n                            </>\n                        }\n                        spec2={\n                            <>\n                                지정된 의료 시설에서 고객님 접선 후 <br />\n                                진료 시작부터 끝까지 동행\n                            </>\n                        }\n                        spec3={\n                            <>\n                                진료 종료 후 고객님의 상태를 <br />\n                                파악하고 이상 없을 시 서비스 종료\n                            </>\n                        }\n                        spec4={\n                            <>\n                                서비스 진행 단계별 카카오톡\n                                <br />\n                                실시간 알림 업데이트 제공\n                            </>\n                        }\n                    />\n                    <GuideCard\n                        source={'/assets/images/art_zzz.png'}\n                        name='보호자 동행'\n                        type='수면 내시경'\n                        desc={\n                            <>\n                                <>\n                                    {/* 위드메이트 동행 전문가가 고객님께서\n                                <br />\n                                <span>자택에서 병원까지 </span>동행하고, 병원 내에서\n                                <br />\n                                <span>보호자 대행 업무</span>를 수행합니다. */}\n                                    고객님께서 수면내시경 검사를 받는\n                                    <br />\n                                    <span>병원 내에서 </span>위드메이트 동행 전문가가\n                                    <br />\n                                    <span>보호자 대행 업무</span>를 수행합니다.\n                                </>\n                                <br />\n                                <br />\n                                <>\n                                    <b>요금</b> <br />\n                                    시간당 15,000원 (추가 30분마다 7,500원)\n                                </>\n                            </>\n                        }\n                        spec1={\n                            <>\n                                고객님의 진료 일정에 맞춰 위드메이트 <br />\n                                소속 동행 전문가가 의료 시설 도착\n                            </>\n                        }\n                        spec2={\n                            <>\n                                지정된 의료 시설에서 고객님 접선 후 <br />\n                                수면 내시경 검사 시작부터 끝까지 동행\n                            </>\n                        }\n                        spec3={\n                            <>\n                                수면 내시경 검사 종료 후 고객님의 <br />\n                                상태를 파악하고 이상 없을 시 종료\n                            </>\n                        }\n                        spec4={\n                            <>\n                                서비스 진행 단계별 카카오톡 <br />\n                                실시간 알림 업데이트 제공\n                            </>\n                        }\n                    />\n                </GuideDetailServiceCardWrapper>\n            </InnerContainer>\n        </GuideDetailContainer>\n    );\n};\n\nconst GuideCard = ({ source, name, type, desc, spec1, spec2, spec3, spec4 }) => (\n    <GuideDetailServiceCard>\n        <GuideCardImage src={source} />\n        <GuideCardName>{name}</GuideCardName>\n        <GuideCardType>{type}</GuideCardType>\n        <GuideCardDescription>{desc}</GuideCardDescription>\n        <GuideCardSpecTitle>서비스 구성</GuideCardSpecTitle>\n\n        <GuideCardSpecRow>\n            <span>01</span>\n            <p>{spec1}</p>\n        </GuideCardSpecRow>\n\n        <GuideCardSpecRow>\n            <span>02</span>\n            <p>{spec2}</p>\n        </GuideCardSpecRow>\n\n        <GuideCardSpecRow>\n            <span>03</span>\n            <p>{spec3}</p>\n        </GuideCardSpecRow>\n\n        <GuideCardSpecRow>\n            <span>04</span>\n            <p>{spec4}</p>\n        </GuideCardSpecRow>\n    </GuideDetailServiceCard>\n);\n","import React from 'react';\nimport styled from 'styled-components';\n\n// components\nimport { GuideUsingContainer, InnerContainer, GuideConceptTitle, GuideUsingSubFlexWrapper, GuideUsageFlexbox, MobileBr, DesktopBr } from '../guide.styled';\n\nexport const GuideUsage = () => {\n    return (\n        <GuideUsingContainer id='usage'>\n            <InnerContainer>\n                <GuideConceptTitle>이런 분께 추천해요</GuideConceptTitle>\n                <GuideUsingSubFlexWrapper>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_legache.png' />\n                        </div>\n                        <span>\n                            병원에 가시는 <DesktopBr />\n                            <MobileBr />\n                            어르신\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_wheelchair.png' />\n                        </div>\n                        <span>\n                            거동이 <DesktopBr />\n                            <MobileBr />\n                            힘드신 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_x-ray.png' />\n                        </div>\n                        <span>\n                            항암 / 방사선 치료를 <DesktopBr />\n                            <MobileBr />\n                            받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                </GuideUsingSubFlexWrapper>\n\n                <GuideUsingSubFlexWrapper>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_injection.png' />\n                        </div>\n                        <span>\n                            수면내시경 등 <DesktopBr />\n                            <MobileBr />\n                            마취가 동반되는 <DesktopBr />\n                            <MobileBr />\n                            치료를 받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_round_trip.png' />\n                        </div>\n                        <span>\n                            입원 / 퇴원\n                            <DesktopBr />\n                            <MobileBr />\n                            하시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_eyecare.png' />\n                        </div>\n                        <span>\n                            안과 진료/시술을 <DesktopBr />\n                            <MobileBr />\n                            받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                </GuideUsingSubFlexWrapper>\n\n                <GuideUsingSubFlexWrapper>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_detailcheck.png' />\n                        </div>\n                        <span>\n                            각종 검진을 <DesktopBr />\n                            <MobileBr />\n                            받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_pregnant.png' />\n                        </div>\n                        <span>\n                            임산부, 산모, <DesktopBr />\n                            <MobileBr />및 소아\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_blood.png' />\n                        </div>\n                        <span>혈액 투석 환자</span>\n                    </GuideUsageFlexbox>\n                </GuideUsingSubFlexWrapper>\n            </InnerContainer>\n        </GuideUsingContainer>\n    );\n};\n","import React from 'react';\nimport {\n    MeritContainer,\n    InnerContainer,\n    MeritHeaderWrapper,\n    MeritCardList,\n    MeritCardWrapper,\n    MeritCardNumber,\n    MeritCardDesc,\n    MeritCardTitleRow,\n} from '../guide.styled';\n\nexport const Merit = () => {\n    return (\n        <MeritContainer id='merit'>\n            <MeritHeaderWrapper>\n                <InnerContainer>\n                    <div className='wrap'>\n                        <img src='/assets/images/faith_up.png' />\n                        <h3>믿을 수 있는 위드메이트</h3>\n                    </div>\n                </InnerContainer>\n            </MeritHeaderWrapper>\n            <InnerContainer>\n                <MeritCardList>\n                    <MeritCard\n                        title='인정 받은 서비스'\n                        source='/assets/images/faith_icon_1.png'\n                        desc={\n                            <>\n                                위드메이트 병원 동행 서비스는\n                                <br />\n                                <span>신한 오픈 이노베이션 2기 우수 기업</span>으로\n                                <br />\n                                선정된 신뢰할 수 있는 서비스입니다.{' '}\n                            </>\n                        }\n                        number='01'\n                    />\n                    <MeritCard\n                        title='검증 받은 서비스'\n                        source='/assets/images/faith_icon_2.png'\n                        desc={\n                            <>\n                                위드메이트는 엄격한 검증을 거친 후<br />\n                                보건복지부와 고양시, 그리고 국립 암센터가\n                                <br />\n                                주관하는<span>‘고양 해피 케어’</span>컨소시엄의 <br />\n                                일원으로 활동 중에 있습니다.\n                            </>\n                        }\n                        number='02'\n                    />\n                    <MeritCard\n                        title='서비스 인력 평점 제도'\n                        source='/assets/images/faith_icon_3.png'\n                        desc={\n                            <>\n                                위드메이트는 더욱 높은 서비스 경험을\n                                <br />\n                                제공하기 위해 매뉴얼을 만들고, 서비스 <br />\n                                종료 후 <span>고객님의 후기를 반영</span>하여 <br />\n                                서비스 인력을 관리합니다.\n                            </>\n                        }\n                        number='03'\n                    />\n                    <MeritCard\n                        title='전문적인 서비스 인력 양성'\n                        source='/assets/images/faith_icon_4.png'\n                        desc={\n                            <>\n                                위드메이트는 여성 인력 개발 센터,\n                                <br /> 재취업 지원 센터, 고용 복지 플러스\n                                <br /> 센터 등의 전문 기관과 <span>일자리 협업 </span>\n                                <br />\n                                <span>프로그램</span>을 운영하며 검증된 서비스\n                                <br />\n                                인력을 주기적으로 양성하고 있습니다.\n                            </>\n                        }\n                        number='04'\n                    />\n                    <MeritCard\n                        title='책임지는 서비스'\n                        source='/assets/images/faith_icon_5.png'\n                        desc={\n                            <>\n                                위드메이트는 서비스 제공 인력 전원이\n                                <br />\n                                삼성화재가 제공하는 1억 2천만원 한도의 <br />\n                                <span>‘전문인 영업 배상 책임 보험’</span>에 가입되어 <br />\n                                책임지는 서비스를 제공합니다.\n                            </>\n                        }\n                        number='05'\n                    />\n                    <MeritCard\n                        title='안전한 서비스'\n                        source='/assets/images/faith_icon_6.png'\n                        desc={\n                            <>\n                                위드메이트는 <span> 시니어 헬스케어 서비스의</span>\n                                <br />\n                                <span>본질은 ‘안전’</span>이라고 생각하고, 서비스 인력의\n                                <br />\n                                정기적인 교육, 자격증 취득 및 보유 여부 <br />\n                                점검, 서비스 매뉴얼의 수정 및 보완등을 <br />\n                                진행하고 있습니다.\n                            </>\n                        }\n                        number='06'\n                    />\n                </MeritCardList>\n            </InnerContainer>\n        </MeritContainer>\n    );\n};\n\nconst MeritCard = ({ number, title, source, desc }) => (\n    <MeritCardWrapper>\n        <MeritCardNumber>{number}</MeritCardNumber>\n        <MeritCardTitleRow>\n            <img src={source} />\n            <span>{title}</span>\n        </MeritCardTitleRow>\n        <MeritCardDesc>{desc}</MeritCardDesc>\n    </MeritCardWrapper>\n);\n","import React from 'react';\nimport styled from 'styled-components';\n\nimport {\n    WithmateContainer,\n    InnerContainer,\n    WithmateTitle,\n    MeritCardDesc,\n    FlexDivWrapper,\n    BigSideBox,\n    SmallSideBox,\n    WithmateBg,\n    GuideConceptTitle,\n    MobileBr,\n    DesktopBr,\n} from '../guide.styled';\nexport const Withmate = () => {\n    return (\n        <WithmateContainer id='withmate'>\n            <InnerContainer>\n                <FlexDivWrapper top>\n                    <SmallSideBox>\n                        <WithmateTitle>\n                            <img src='/assets/images/new_logo_img.png' />\n                            <span>위드메이트란?</span>\n                        </WithmateTitle>\n                        <Block bigMargin>\n                            위드메이트는 <span>온라인 병원 동행 서비스 매칭 플랫폼</span>을<MobileBr /> 시작으로,\n                            <DesktopBr /> 대한민국에서{' '}\n                            <span>\n                                사회적 의미의 ‘시니어’라는 <MobileBr />\n                                단어를 없애기 위해\n                            </span>{' '}\n                            설립된 <DesktopBr />\n                            <span>\n                                시니어 라이프 스타일 <MobileBr />\n                                혁신 기업\n                            </span>\n                            입니다.\n                        </Block>\n                        <Title>위드메이트의 시작</Title>\n                        <Block>\n                            <span>2015년</span>에 설립된 위드메이트는 <span>초고령화 </span>및 <MobileBr />\n                            <span>1인 가구 시대</span>에 <DesktopBr />\n                            접어든 대한민국의 현 상황에 적합한\n                            <MobileBr />\n                            <span> 시니어 라이프 스타일 혁신</span>\n                            <DesktopBr />\n                            <span>서비스를 개발합니다.</span>\n                        </Block>\n                        <Block noMargin>\n                            이를 위해 위드메이트는 <MobileBr />\n                            <span>국내 최초로 병원 동행 서비스를 런칭해</span>\n                            <MobileBr />\n                            <DesktopBr />\n                            <span>탄탄한 신뢰</span>와 <span>안정된 서비스</span> 시스템을 기반으로 <MobileBr />\n                            축적되는 <DesktopBr />\n                            데이터와 실전 경험을 바탕으로{' '}\n                            <span>\n                                다양한 <MobileBr />\n                                신규 서비스를 연구\n                            </span>\n                            하여 <DesktopBr />\n                            <span>\n                                시니어 라이프 스타일 <MobileBr />\n                                혁신 기업\n                            </span>\n                            의 길을 걷고 있습니다.\n                        </Block>\n                    </SmallSideBox>\n                    <BigSideBox mHidden>\n                        <WithmateBg bg='/assets/images/guide_withmate_main1.png' />\n                    </BigSideBox>\n                </FlexDivWrapper>\n                {/* <FlexDivWrapper>\n                    <SmallSideBox mHidden>\n                        <WithmateBg bg='/assets/images/guide_withmate_main2.png' />\n                    </SmallSideBox>\n                    <BigSideBox>\n                        <Title>등장 배경</Title>\n                        <Block>\n                            2017년, 국내 <span>65세 이상 인구 비율이 14%를 넘으며</span> <MobileBr />\n                            대한민국은 공식적으로 <DesktopBr />\n                            <span>고령 사회</span> 에 접어들었습니다. <MobileBr />\n                            다가올 2025년, 65세 이상 인구 비율은 20%를\n                            <MobileBr />\n                            <DesktopBr />\n                            넘길 것으로 전망되며 이후{' '}\n                            <span>\n                                대한민국은 초고령 사회로 <MobileBr />\n                                접어들게 될 것\n                            </span>\n                            입니다.\n                        </Block>\n\n                        <Block>\n                            이렇게 시니어가 늘어가는 순간에도, <MobileBr />\n                            <span>현대 사회는 날로 분주해지기만 합니다.</span>\n                            <DesktopBr />\n                            젊은 세대는 <MobileBr />\n                            매일 직장과 육아라는 전투를 치르며 살아남기 위한 <MobileBr />\n                            발버둥을 치기에도 <DesktopBr />\n                            버겁습니다. 이렇게 자기 자신을 <MobileBr />\n                            돌보기 위한 시간을 내는 것도 힘겨운 상황 속에서,\n                            <MobileBr />\n                            <DesktopBr />\n                            <span>\n                                떨어져 있는 고령 가족에 대한 걱정은 어쩌면 <MobileBr />\n                                사치처럼 보이기도 합니다.{' '}\n                            </span>\n                        </Block>\n\n                        <Block noMargin>\n                            물리적인 거리와 시간적인 제약, 그리고 직장과 육아가 <MobileBr />\n                            주는 압박감을 떨쳐내고 <DesktopBr />\n                            <span>\n                                고령의 가족을 위해 선뜻 <MobileBr />\n                                움직일 수 있을까요?{' '}\n                            </span>\n                            시니어는 날로 발전하는 기술의 <DesktopBr />\n                            <MobileBr />\n                            파도 속에서 자신의 생존을 위해 필요한 서비스를 <MobileBr />\n                            누군가의 도움 없이 적재적소에 선택해 <DesktopBr />\n                            <span>\n                                자유롭게 <MobileBr />\n                                사용할 수 있을까요?\n                            </span>{' '}\n                            그렇다면 우리는 언제까지 이런 <MobileBr />\n                            막막한 상황을 견디기만 <DesktopBr />\n                            해야 할까요? 위드메이트는 <MobileBr />\n                            이렇게 시니어가 겪게 되는 다양한{' '}\n                            <span>\n                                일상 생활의 <MobileBr />\n                                불편함을{' '}\n                            </span>\n                            <DesktopBr />\n                            <span>병원 동행 서비스를 시작으로 해소합니다.</span>\n                        </Block>\n                    </BigSideBox>\n                </FlexDivWrapper> */}\n            </InnerContainer>\n        </WithmateContainer>\n    );\n};\n\nconst Title = styled(GuideConceptTitle)`\n    margin-bottom: 24px;\n    text-align: left;\n`;\n\nconst Block = styled(MeritCardDesc)`\n    font-size: 16px;\n    margin-bottom: 24px;\n    ${props => props.noMargin && `margin-bottom: 0px;`}\n    ${props => props.bigMargin && `margin-bottom: 74px;`}\n\n    @media (max-width: 768px) {\n        word-break: keep-all;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const GuideBanner = () => {\n    return <GuideBannerContainer>위드메이트를 알려드릴게요!</GuideBannerContainer>;\n};\n\nconst GuideBannerContainer = styled.div`\n    width: 100%;\n    height: 235px;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    font-size: 40px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.2;\n    letter-spacing: -0.7px;\n    text-align: center;\n    color: #ffffff;\n\n    background-image: url('/assets/images/guide_title_bg.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    @media (max-width: 768px) {\n        font-size: 22px;\n        background-position: left;\n    }\n`;\n","import React from 'react';\nimport _ from 'lodash';\nimport styled from 'styled-components';\nimport { message } from 'antd';\n\n// components\nimport { GuideNav } from './Section/nav';\nimport { GuideConcept } from './Section/concept';\nimport { GuideDetail } from './Section/detail';\nimport { GuideUsage } from './Section/usage';\nimport { WithmatePartners } from '../Home/Section/partners';\nimport { Merit } from './Section/merit';\nimport { Withmate } from './Section/withmate';\nimport { GuideBanner } from './Section/banner';\n\nimport { Container } from './guide.styled';\nimport { NoramlReserveModal } from '../../Components/newModal';\n\nclass GuidePage extends React.PureComponent {\n    state = {\n        activeTab: 'concept',\n        reserveModal: false,\n        reserveType: null,\n        step: 1,\n        mobile_menu: false,\n        addHalfTime: false,\n    };\n\n    inputHandler = ({ type, value }) => {\n        this.setState({ [type]: value });\n    };\n\n    inputDeepHandler = ({ type, deepType, value }) => {\n        this.setState(prevState => ({\n            [type]: {\n                ...prevState[type],\n                [deepType]: value,\n            },\n        }));\n    };\n\n    onTab = tab => {\n        this.setState({\n            activeTab: tab,\n        });\n    };\n\n    onRoute = path => {\n        this.props.history.push(path);\n    };\n\n    render() {\n        const { activeTab, reserveModal, step, addHalfTime, popoverVisible } = this.state;\n\n        return (\n            <Container>\n                <GuideBanner />\n                <GuideNav\n                    activeTab={activeTab}\n                    onTab={this.onTab}\n                    onReserve={serviceType => {\n                        this.setState({\n                            reserveModal: true,\n                            temp: {\n                                page: 1,\n                                service: 'unemergency',\n                                addTime: '60',\n                                payMethod: 'transfer',\n                                sex: '남',\n                                transport: 'common',\n                                report: false,\n                            },\n                        });\n                    }}\n                />\n                <Withmate />\n                <GuideConcept />\n                <GuideDetail />\n                <Merit />\n                <GuideUsage />\n                <WithmatePartners />\n            </Container>\n        );\n    }\n}\n\nexport default GuidePage;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\n\n// component\nimport GuidePage from './guide';\nimport { MATE } from '../../Lib/variables';\n\n// styles\nimport StyledContainer from './guide.styled';\n\n// actions\nimport { serviceReserve, editResrveForm } from '../../Reducer/Modules/app';\n\nclass GuideContainer extends React.PureComponent {\n    componentDidMount = () => {};\n\n    render() {\n        return (\n            <StyledContainer>\n                <GuidePage {...this.props} />\n            </StyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapStateToDispatch = dispatch => ({\n    serviceReserve: ({ userId, info }) => dispatch(serviceReserve({ userId, info })),\n    editForm: ({ type, value }) => dispatch(editResrveForm({ type, value })),\n});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(GuideContainer);\n","import styled from 'styled-components';\n\nconst StyledContainer = styled.div``;\n\nexport default StyledContainer;\n\nexport const Container = styled.div``;\n\nexport const NemtTitleWrapper = styled.div`\n    margin-top: 104px;\n    margin-bottom: 58px;\n`;\n\nexport const InnerContainer = styled.div`\n    width: 100%;\n\n    max-width: 1120px;\n    margin: 0 auto;\n\n    @media (max-width: 1120px) {\n        padding-left: 32px;\n        padding-right: 32px;\n    }\n\n    @media (max-width: 768px) {\n        padding-left: 20px;\n        padding-right: 20px;\n    }\n`;\n\nexport const NemtTitle = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 40px;\n    line-height: 46px;\n\n    text-align: center;\n    letter-spacing: -0.6px;\n\n    color: rgba(0, 0, 0, 0.8);\n`;\n\nexport const NemtServiceWrapper = styled.div`\n    display: flex;\n    flex-direction: column;\n\n    justify-content: flex-start;\n`;\n\nexport const NemtServiceFlexWrapper = styled.div`\n    display: flex;\n\n    align-items: flex-start;\n    justify-content: center;\n\n    margin-bottom: 30px;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const NemtBox = styled.div`\n    margin-bottom: 30px;\n    position: relative;\n\n    @media (max-width: 768px) {\n        margin-bottom: 80px;\n    }\n`;\n\nexport const NemtColumnBox = styled(NemtBox)`\n    width: calc((100% - 20px) / 2);\n\n    &:first-child {\n        margin-right: 20px;\n    }\n\n    @media (max-width: 768px) {\n        &:first-child {\n            margin-right: 0px;\n        }\n\n        width: 100%;\n    }\n`;\n\nexport const NemtBoxTitle = styled.p`\n    position: absolute;\n    top: 34px;\n    left: 34px;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 16px;\n    line-height: 20px;\n\n    letter-spacing: -0.4px;\n\n    > span {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 26px;\n        line-height: 44px;\n\n        letter-spacing: -0.777778px;\n    }\n\n    @media (max-width: 768px) {\n        position: relative;\n        top: 0px;\n        left: 0px;\n\n        margin-bottom: 4px;\n\n        font-size: 15px;\n        line-height: 21px;\n\n        > span {\n            font-size: 24px;\n            line-height: 40px;\n        }\n    }\n`;\n\nexport const NemtServiceImageWrapper = styled.div`\n    border-radius: 12px;\n    overflow: hidden;\n\n    &.desktop-visible {\n        display: block;\n\n        @media (max-width: 768px) {\n            display: none;\n        }\n    }\n\n    &.mobile-visible {\n        display: none;\n\n        @media (max-width: 768px) {\n            display: block;\n        }\n    }\n\n    > img {\n        width: 100%;\n        object-fit: contain;\n    }\n`;\n\nexport const MobileBr = styled.br`\n    display: none;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const DesktopBr = styled.br`\n    display: block;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const NemtInfobox = styled.div`\n    padding: 24px;\n\n    @media (max-width: 768px) {\n        padding: 0px;\n        padding-top: 24px;\n    }\n`;\n\nexport const ReserveButton = styled.span`\n    width: 246px;\n    height: 48px;\n\n    display: inline-flex;\n    align-items: center;\n    justify-content: center;\n\n    background: #3bc1ff;\n    border-radius: 4px;\n\n    cursor: pointer;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 14px;\n    line-height: 24px;\n    text-align: center;\n\n    color: #ffffff;\n\n    > img {\n        width: 18px;\n        height: 18px;\n\n        margin-right: 6px;\n    }\n\n    margin-bottom: 20px;\n\n    &:hover {\n        opacity: 0.85;\n        transition: all 0.5s;\n    }\n\n    @media (max-width: 430px) {\n        font-size: 12px;\n    }\n\n    @media (max-width: 430px) {\n        width: 100%;\n    }\n`;\n\nexport const NemtDescription = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 14px;\n    line-height: 20px;\n\n    word-break: keep-all;\n\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        color: #3bc1ff;\n        cursor: pointer;\n    }\n\n    @media (max-width: 768px) {\n        font-size: 12px;\n        line-height: 18px;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { message as Message } from 'antd';\n\n// components\nimport {\n    Container,\n    InnerContainer,\n    NemtTitleWrapper,\n    NemtTitle,\n    NemtServiceWrapper,\n    NemtBox,\n    NemtColumnBox,\n    NemtBoxTitle,\n    NemtServiceFlexWrapper,\n    NemtServiceImageWrapper,\n    ReserveButton,\n    NemtInfobox,\n    NemtDescription,\n    MobileBr,\n    DesktopBr,\n} from './nemt.styled';\n\n// utils\nimport axios from '../../Lib/axios';\n\n// modal\nimport { EmergencyCorpSearchModal, ShareCarRequestModal } from '../../Components/modal';\n\nclass NemtPage extends React.PureComponent {\n    state = {\n        activeTab: 'concept',\n        reserveModal: false,\n        searchModal: false,\n        emergencyList: [],\n        emergencyKeyword: '',\n        requestModal: false,\n        requestInfo: {\n            corp: '',\n            address: '',\n            manager: '',\n            contact: '',\n            message: '',\n        },\n    };\n\n    componentDidMount = async () => {\n        const { data } = await axios.get(`/v1/corp/list`);\n        if (!data) return null;\n\n        if (data && Array.isArray(data)) {\n            this.setState({\n                emergencyList: data,\n            });\n        }\n    };\n\n    onRoute = path => {\n        this.props.history.push(path);\n    };\n\n    onShareRequest = async () => {\n        const {\n            requestInfo: { corp, address, manager, contact, message },\n        } = this.state;\n        if (!corp || !address || !manager || !contact || !message) return Message.info('정보를 기입해주세요.');\n\n        const { data } = await axios.post('/v1/share/add', {\n            corp,\n            address,\n            manager,\n            contact,\n            message,\n        });\n\n        if (!data) {\n            return Message.error('일시적인 서버장애가 발생했습니다. 다시 시도해주세요.');\n        }\n\n        if (data === 'check parameters') {\n            return Message.warning('정보를 모두 기입해주세요.');\n        }\n\n        if (data === 'success') {\n            Message.success('셔틀 셰어링 서비스를 요청하였습니다.');\n\n            this.setState({\n                requestModal: false,\n                requestInfo: {\n                    corp: '',\n                    address: '',\n                    manager: '',\n                    contact: '',\n                    message: '',\n                },\n            });\n        }\n    };\n\n    render() {\n        const { requestInfo, emergencyKeyword, emergencyList } = this.state;\n\n        return (\n            <Container>\n                <InnerContainer>\n                    <NemtTitleWrapper>\n                        <NemtTitle>서비스 안내</NemtTitle>\n                    </NemtTitleWrapper>\n\n                    <NemtServiceWrapper>\n                        <NemtBox>\n                            <NemtServiceImageWrapper className='desktop-visible'>\n                                <img src='/assets/images/service_around_desktop.png' />\n                            </NemtServiceImageWrapper>\n                            <NemtServiceImageWrapper className='mobile-visible'>\n                                <img src='/assets/images/service_around_mobile.png' />\n                            </NemtServiceImageWrapper>\n\n                            <NemtInfobox>\n                                <ReserveButton\n                                    onClick={() => {\n                                        this.props.history.push('/nemt/service');\n                                    }}\n                                >\n                                    <img src='/assets/images/icon_calendar.png' />\n                                    예약하기\n                                </ReserveButton>\n\n                                <NemtBoxTitle style={{ color: '#236037' }}>\n                                    위드메이트\n                                    <DesktopBr />\n                                    <MobileBr />\n                                    <span>병원 동행 서비스</span>\n                                </NemtBoxTitle>\n\n                                <NemtDescription>\n                                    병원 동행 서비스는 응급 상황에 처하지는 않았으나 정기적, 혹은 비정기적으로 <DesktopBr />\n                                    의료 기관에 방문해 적절한 의료 조치를 받아야 하는 분들을 위한 서비스입니다. <DesktopBr />\n                                    <MobileBr />\n                                    자세한 설명은{' '}\n                                    <span\n                                        onClick={() => {\n                                            this.props.history.push('/nemt/service');\n                                        }}\n                                    >\n                                        병원동행 서비스 NEMT 페이지\n                                    </span>\n                                    에서 확인이 가능합니다.\n                                </NemtDescription>\n                            </NemtInfobox>\n                        </NemtBox>\n                    </NemtServiceWrapper>\n\n                    <NemtServiceFlexWrapper>\n                        <NemtColumnBox id='shuttle-service'>\n                            <NemtServiceImageWrapper>\n                                <img src='/assets/images/shuttle.png' />\n                            </NemtServiceImageWrapper>\n\n                            <NemtInfobox>\n                                <ReserveButton\n                                    onClick={() => {\n                                        this.setState({ requestModal: true });\n                                    }}\n                                >\n                                    <img src='/assets/images/icon_message.png' />\n                                    문의하기\n                                </ReserveButton>\n\n                                <NemtBoxTitle style={{ color: '#1D5DA2' }}>\n                                    위드메이트\n                                    <DesktopBr />\n                                    <MobileBr />\n                                    <span>셔틀 셰어링 서비스</span>\n                                </NemtBoxTitle>\n\n                                <NemtDescription>\n                                    요양 시설 운영비 중 차량 유지 비용은 주유비, 운행 직원 급여, 식대 등이 <DesktopBr />\n                                    더해질 경우 막대한 비중을 차지합니다. 하지만 노후 차량을 사용하거나, <DesktopBr />\n                                    운행 직원 수를 줄일 경우 입소 환자 안전에 문제가 생기기 때문에 <DesktopBr />\n                                    요양 시설이 차량 유지 비용을 줄이는 방법은 사실상 없습니다.\n                                    <DesktopBr />\n                                    <DesktopBr />\n                                    이에 위드메이트는 요양 시설이 차량 유지 비용을 절감할 수 있는\n                                    <DesktopBr />\n                                    ‘셔틀 셰어링’ 서비스를 도입했습니다. A와 B라는 두 곳의 요양원이 <DesktopBr />\n                                    위드메이트가 제공하는 셔틀과 기사를 공유하며 잉여 시간과 좌석을 함께 <DesktopBr />\n                                    사용하는 방법입니다. A 병원의 남는 좌석을 B 병원이 이용하거나, <DesktopBr />\n                                    B 병원의 환자가 치료를 받는 동안 A 병원의 환자가 차량을 이용하는 방식이죠.\n                                    <DesktopBr />\n                                    <DesktopBr />\n                                    위드메이트의 셔틀 쉐어링 서비스가 필요한 기관은 <DesktopBr />\n                                    문의 접수 버튼을 클릭하세요!\n                                </NemtDescription>\n                            </NemtInfobox>\n                        </NemtColumnBox>\n\n                        <NemtColumnBox id='search-service'>\n                            <NemtServiceImageWrapper>\n                                <img src='/assets/images/emergency_car.png' />\n                            </NemtServiceImageWrapper>\n\n                            <NemtInfobox>\n                                <ReserveButton\n                                    onClick={() => {\n                                        this.setState({ searchModal: true });\n                                    }}\n                                >\n                                    <img src='/assets/images/icon_search.png' />\n                                    검색하기\n                                </ReserveButton>\n\n                                <NemtBoxTitle style={{ color: '#B85465' }}>\n                                    위드메이트\n                                    <DesktopBr />\n                                    <MobileBr />\n                                    <span>사설 구급 업체 검색 서비스 </span>\n                                </NemtBoxTitle>\n\n                                <NemtDescription>\n                                    '구급’이라는 단어가 들어간 탓에, 흔히 사설 구급차를 떠올렸을 때 응급 상황이 <DesktopBr />\n                                    아닌 이상 사용할 일이 없을 것이라고 생각이 듭니다. 하지만 사설 구급차는 <DesktopBr />\n                                    요양 시설 입소 환자의 병원 이송, 대형 행사 진행 중 비상 대기, 정상 거동이 <DesktopBr />\n                                    불가한 환자 이송 등 일상 생활의 다양한 분야에 필요한 서비스입니다.\n                                    <DesktopBr />\n                                    <DesktopBr />\n                                    위드메이트는 플랫폼 이용자에게 무료로 각 지역의 사설 구급 업체를 <DesktopBr />\n                                    검색할 수 있는 서비스를 제공하고 있습니다. 지역별로 나눠 편리하게 <DesktopBr />\n                                    사설 구급 업체를 검색해보세요!\n                                </NemtDescription>\n                            </NemtInfobox>\n                        </NemtColumnBox>\n                    </NemtServiceFlexWrapper>\n                </InnerContainer>\n\n                {this.state.searchModal ? (\n                    <EmergencyCorpSearchModal\n                        data={emergencyList}\n                        keyword={emergencyKeyword}\n                        inputHandler={value => {\n                            this.setState({ emergencyKeyword: value });\n                        }}\n                        visibleHandler={() => {\n                            this.setState({ searchModal: false });\n                        }}\n                    />\n                ) : null}\n                {this.state.requestModal ? (\n                    <ShareCarRequestModal\n                        data={requestInfo}\n                        visibleHandler={() => {\n                            this.setState({ requestModal: false });\n                        }}\n                        inputHandler={({ type, value }) => {\n                            this.setState(prevState => ({\n                                requestInfo: {\n                                    ...prevState.requestInfo,\n                                    [type]: value,\n                                },\n                            }));\n                        }}\n                        onSave={this.onShareRequest}\n                    />\n                ) : null}\n            </Container>\n        );\n    }\n}\n\nexport default NemtPage;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\n\n// component\nimport NemtPage from './nemt';\nimport { MATE } from '../../Lib/variables';\n\n// styles\nimport StyledContainer from './nemt.styled';\n\n// actions\nimport {} from '../../Reducer/Modules/app';\n\nclass NemtContainer extends React.PureComponent {\n    componentDidMount = () => {};\n\n    render() {\n        return (\n            <StyledContainer>\n                <NemtPage {...this.props} />\n            </StyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapStateToDispatch = dispatch => ({});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(NemtContainer);\n","import React from \"react\";\nimport Modal from \"react-modal\";\nimport styled from 'styled-components';\nimport { Button, message, Table } from 'antd';\n\nimport ProfileStyledContainer from \"../Auth/AuthPages/Profile/profile.styled\";\nimport { HalfWidthButton } from \"../../Components/Common/button\";\nimport { DivisionLine } from \"../../Components/Common/input\";\nimport { getPatientInfo } from \"../../Lib/Api/auth\";\n\nconst customStyles = {\n\n    overlay: {\n        position: \"fixed\",\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: \"rgba(15, 15, 15, 0.79)\",\n    },\n    content: {\n        position: \"absolute\",\n        top: \"30px\",\n        height: \"60%\",\n        border: \"1px solid #ccc\",\n        background: \"#ffffff\",\n        overflow: \"auto\",\n        WebkitOverflowScrolling: \"touch\",\n        borderRadius: \"4px\",\n        outline: \"none\",\n        padding: \"20px\",\n    },\n}\n\nconst patientColumn = ({ onCheck }) => {\n    return [\n        {\n            title: '이름',\n            dataIndex: 'name',\n            align: 'center',\n            width: '100px'\n        },\n        {\n            title: '나이',\n            dataIndex: 'age',\n            align: 'center',\n            width: '100px'\n        },\n        {\n            title: '선택',\n            align: 'center',\n            width: '100px',\n            dataIndex: '_id',\n            render: (_id, data) =>\n                <Button\n                    style={{ width: '70px', height: '30px' }}\n                    onClick={() => { onCheck(data) }}\n                >\n                    선택\n                </Button>\n        },\n    ]\n}\n\nclass PatientProfileListComponent extends React.PureComponent {\n    state = {\n        patientInfo: {},\n        patientList: [],\n        patientId: '',\n        patientInfo: null\n    };\n\n    componentWillUnmount = () => {\n        this.setState({ patientInfo: null });\n    };\n\n    onChoose = () => {\n        const { patientInfo } = this.state;\n        console.log(patientInfo)\n\n        getPatientInfo({ patientId: patientInfo._id }).then(resolve => {\n            console.log(resolve)\n            const { data } = resolve;\n            if (resolve && resolve.data && resolve.data.message === 'success') {\n                if (patientInfo && patientInfo.reservedStarting) delete data.starting;\n                if (patientInfo && patientInfo.environment) delete data.environment;\n                if (patientInfo && patientInfo.walk) delete data.walk;\n\n                this.setState({ patientInfo: resolve.data.data })\n            } else {\n                message.info('선택하신 환자 프로필이 존재하지 않습니다.');\n            }\n        });\n    };\n\n    onChangeCheckbox = ({ }) => {\n\n    };\n\n    // 체크박스 선택\n    // rowSelection = {\n    //     onChange: (selectedRowKeys , selectedRows ) => {\n    //       console.log(`selectedRowKeys: ${selectedRowKeys}`, 'selectedRows: ', selectedRows);\n    //     },\n    //     getCheckboxProps: (record ) => {\n    //         console.log(record)\n    //     }\n    //   };\n\n    render() {\n        // console.log(this.props)\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <ProfileStyledContainer>\n                    <div className='inner-container'>\n                        <div className='profile-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>환자 프로필 목록</WideModalTitle>\n                                    <AlertText>\n                                        * 환자 프로필 정보를 선택할 수 있습니다. <br />\n                                        [ 마이페이지 ]에서 환자 프로필을 등록하실 수 있습니다.\n                                    </AlertText>\n                                </TitleSection>\n\n                                <br />\n\n                                <DivisionLine />\n\n                                <div className='profileList'>\n                                    <Table\n                                        dataSource={this.props.list}\n                                        columns={patientColumn({\n                                            onCheck: (data) => {\n                                                this.props.onUpdatePatient(data);\n                                                this.props.onClose()\n                                            }\n                                        })}\n                                        rowKey='_id'\n                                        pagination={{\n                                            pageSize: 3,\n                                            hideOnSinglePage: true,\n                                            size: 'small',\n                                        }}\n                                    // rowSelection={{\n                                    //     type: 'checkbox',\n                                    //     ...this.rowSelection\n                                    // }}\n                                    // rowKey='_id'\n                                    />\n                                </div>\n\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff'\n                                        onClick={this.props.onClose}\n                                    >\n                                        닫기\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n                            </div>\n                        </div>\n                    </div>\n                </ProfileStyledContainer >\n            </Modal >\n        );\n    }\n};\n\nexport default PatientProfileListComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst AlertText = styled.div`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.52;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n`;","import React from 'react';\nimport Modal from 'react-modal';\nimport styled from 'styled-components';\nimport { Button, Input, message, Table } from 'antd';\n\nimport ProfileStyledContainer from '../Auth/AuthPages/Profile/profile.styled';\nimport { HalfWidthButton } from '../../Components/Common/button';\nimport { DivisionLine } from '../../Components/Common/input';\nimport { getMateInfo } from '../../Lib/Api/auth';\nimport axios from '../../Lib/axios';\n\nconst customStyles = {\n    overlay: {\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: 'rgba(15, 15, 15, 0.79)',\n    },\n    content: {\n        position: 'absolute',\n        top: '30px',\n        height: '90%',\n        border: '1px solid #ccc',\n        background: '#ffffff',\n        overflow: 'auto',\n        WebkitOverflowScrolling: 'touch',\n        borderRadius: '4px',\n        outline: 'none',\n        padding: '20px',\n    },\n};\n\nconst mateListColumn = ({ onCheck }) => {\n    return [\n        {\n            title: '이름',\n            dataIndex: 'name',\n            align: 'center',\n            width: '100px',\n            sorter: (a, b) => a.name.localeCompare(b.name),\n        },\n        // {\n        //     title: '성별',\n        //     dataIndex: 'sex',\n        //     align: 'center',\n        //     width: '100px',\n        //     render: sex => <span>{sex === '남' ? '남자' : '여자'}</span>\n        // },\n        {\n            title: '사진',\n            dataIndex: 'photo',\n            align: 'center',\n            width: '100px',\n            render: photoURL => <img src={photoURL} style={{ width: '100px', height: 'auto' }} />,\n        },\n        // {\n        //     title: '수행 이력',\n        //     dataIndex: 'review',\n        //     align: 'center',\n        //     width: '100px',\n        //     render: review => <span>Pro 서비스 이력: {(review && review.unemergency) || 0}건\n        //         <br />Basic 서비스 이력: {(review && review.assist) || 0}건</span>,\n        // },\n        {\n            title: '선택',\n            align: 'center',\n            width: '100px',\n            dataIndex: '_id',\n            render: (_id, data) => (\n                <Button\n                    style={{ width: '70px', height: '30px' }}\n                    onClick={() => {\n                        onCheck(data);\n                    }}\n                >\n                    선택\n                </Button>\n            ),\n        },\n    ];\n};\n\nclass PatientProfileListComponent extends React.PureComponent {\n    state = {\n        mateInfo: {},\n        mateList: [],\n        mateId: '',\n        keyword: '',\n        review: null,\n    };\n\n    componentWillUnmount = () => {\n        this.setState({ mateInfo: null });\n    };\n\n    onChoose = () => {\n        const { mateInfo, mateId } = this.state;\n        console.log(mateInfo, mateId);\n\n        getMateInfo({ mateId: mateInfo._id }).then(resolve => {\n            console.log(resolve);\n            const { data } = resolve;\n            if (resolve && resolve.data && resolve.data.message === 'success') {\n                this.setState({ mateInfo: resolve.data.data });\n            } else {\n                message.info('선택하신 메이트가 존재하지 않습니다.');\n            }\n        });\n    };\n\n    getList = () => {\n        const { keyword } = this.state;\n\n        const list = this.props.list.filter(item => item && item.name && item.name.toLowerCase().includes(keyword));\n\n        return list;\n    };\n\n    render() {\n        const list = this.getList();\n        // console.log(this.props)\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <ProfileStyledContainer>\n                    <div className='inner-container'>\n                        <div className='mate-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>메이트 선택하기</WideModalTitle>\n                                    <AlertText>* 서비스 수행을 함께할 메이트를 선택하실 수 있습니다.</AlertText>\n                                </TitleSection>\n\n                                <br />\n\n                                <DivisionLine />\n\n                                <div className='mateList'>\n                                    <Input\n                                        value={this.state.keyword}\n                                        onChange={ev => {\n                                            this.setState({ keyword: ev.target.value });\n                                        }}\n                                        placeholder='메이트 이름으로 검색하세요.'\n                                        style={{ marginBottom: '24px' }}\n                                    />\n                                    <Table\n                                        dataSource={list}\n                                        columns={mateListColumn({\n                                            onCheck: data => {\n                                                this.props.onUpdateMate(data);\n                                                this.props.onClose();\n                                            },\n                                        })}\n                                        rowKey='_id'\n                                        pagination={{\n                                            pageSize: 5,\n                                            hideOnSinglePage: true,\n                                            size: 'small',\n                                        }}\n                                    />\n                                </div>\n\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff' onClick={this.props.onClose}>\n                                        닫기\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n                            </div>\n                        </div>\n                    </div>\n                </ProfileStyledContainer>\n            </Modal>\n        );\n    }\n}\n\nexport default PatientProfileListComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst AlertText = styled.div`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.52;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n`;\n","import React from \"react\";\nimport Modal from \"react-modal\";\nimport styled from 'styled-components';\nimport { Button, message, Table } from 'antd';\n\nimport CardStyledContainer from \"../Auth/AuthPages/Card/card.styled\";\nimport { HalfWidthButton } from \"../../Components/Common/button\";\nimport { DivisionLine } from \"../../Components/Common/input\";\nimport { getCardInfo } from \"../../Lib/Api/auth\";\n\nconst customStyles = {\n    overlay: {\n        position: \"fixed\",\n        top: 0,\n        left: 0,\n        right: 0,\n        bottom: 0,\n        backgroundColor: \"rgba(15, 15, 15, 0.79)\",\n    },\n    content: {\n        position: \"absolute\",\n        top: \"30px\",\n        height: \"40%\",\n        border: \"1px solid #ccc\",\n        background: \"#ffffff\",\n        overflow: \"auto\",\n        WebkitOverflowScrolling: \"touch\",\n        borderRadius: \"4px\",\n        outline: \"none\",\n        padding: \"20px\",\n    }\n}\n\nconst cardColumn = ({ onCheck }) => {\n    return [\n        {\n            title: '카드명',\n            dataIndex: 'cardName',\n            align: 'center',\n            width: '80px'\n        },\n        {\n            title: '카드번호',\n            dataIndex: 'cardNum',\n            align: 'center',\n            render: cardNum => <span>**** - **** - **** - {cardNum.slice(15, 19)}</span>\n        },\n        {\n            title: '선택',\n            align: 'center',\n            width: '60px',\n            dataIndex: '_id',\n            render: (_id, data) =>\n                <Button\n                    style={{ width: '60px', height: '30px' }}\n                    onClick={() => { onCheck(data) }}\n                >\n                    선택\n                </Button>\n        },\n    ]\n}\n\nclass CardListComponent extends React.PureComponent {\n    state = {\n        cardInfo: {},\n        cardList: [],\n        cardId: '',\n        cardInfo: null\n    };\n\n    componentWillUnmount = () => {\n        this.setState({ cardInfo: null });\n    };\n\n    onChoose = () => {\n        const { cardInfo } = this.state;\n        console.log(cardInfo)\n\n        getCardInfo({ cardId: cardInfo._id }).then(resolve => {\n            console.log(resolve)\n            const { data } = resolve;\n            if (resolve && resolve.data && resolve.data.message === 'success') {\n                if (cardInfo && cardInfo.cardName) delete data.cardName;\n                if (cardInfo && cardInfo.cardNum) delete data.cardNum;\n                if (cardInfo && cardInfo.year) delete data.year;\n                if (cardInfo && cardInfo.month) delete data.month;\n\n                this.setState({ cardInfo: resolve.data.data })\n            } else {\n                message.info('선택하신 카드정보가 존재하지 않습니다.');\n            }\n        });\n    };\n\n    render() {\n        // console.log(this.props)\n        return (\n            <Modal\n                isOpen={this.props.visible}\n                ariaHideApp={false}\n                // onRequestClose={modalOff} // esc키 또는 background 클릭 시 모달창 닫힘\n                style={{ ...customStyles }}\n            >\n                <CardStyledContainer>\n                    <div className='inner-container'>\n                        <div className='profile-form'>\n                            <div className='form'>\n                                <div>\n                                    <CloseButton src={'/assets/images/close.png'} onClick={this.props.onClose} style={{ width: '22px', height: '22px' }} />\n                                </div>\n                                <TitleSection>\n                                    <WideModalTitle>결제 카드 목록</WideModalTitle>\n                                    <AlertText>\n                                        * 결제하실 카드를 선택할 수 있습니다. <br />\n                                        [ 마이페이지 ]에서 결제 카드를 등록하실 수 있습니다.\n                                    </AlertText>\n                                </TitleSection>\n\n                                <br />\n\n                                <DivisionLine />\n\n                                <div className='profileList'>\n                                    <Table\n                                        dataSource={this.props.list}\n                                        columns={cardColumn({\n                                            onCheck: (data) => {\n                                                this.props.onUpdateCard(data);\n                                                this.props.onClose()\n                                            }\n                                        })}\n                                        rowKey='_id'\n                                        pagination={{\n                                            pageSize: 3,\n                                            hideOnSinglePage: true,\n                                            size: 'small',\n                                        }}\n                                    />\n                                </div>\n\n                                <DivisionLine />\n\n                                <ButtonWrap>\n                                    <HalfWidthButton style={{ margin: '0 auto' }} bg='#3bc1ff'\n                                        onClick={this.props.onClose}\n                                    >\n                                        닫기\n                                    </HalfWidthButton>\n                                </ButtonWrap>\n                            </div>\n                        </div>\n                    </div>\n                </CardStyledContainer >\n            </Modal >\n        );\n    }\n};\n\nexport default CardListComponent;\n\nconst CloseButton = styled.img`\n    position: absolute;\n    top: 16px;\n    right: 12px;\n\n    width: 18px;\n    height: 18px;\n\n    object-fit: cover;\n    cursor: pointer;\n\n    @media (max-width: 480px) {\n        width: 16px;\n        height: 16px;\n\n        &.desktop-only {\n            display: none;\n        }\n    }\n`;\n\nconst ButtonWrap = styled.div`\n    width: 100%;\n    display: flex;\n    align-items: center;\n`;\n\nconst TitleSection = styled.div``;\n\nconst WideModalTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 4px;\n`;\n\nconst AlertText = styled.div`\n    font-size: 14px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.52;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: #ff5500;\n`;","import React from 'react';\nimport styled from 'styled-components';\nimport { Button, Checkbox, message, notification, Radio, Select } from 'antd';\nimport moment from 'moment';\nimport 'moment/locale/ko';\nimport locale from 'antd/es/date-picker/locale/ko_KR';\nimport holidayKR from 'holiday-kr';\nimport swal from 'sweetalert2';\n\n// libs\nimport axios from '../../Lib/axios';\nimport { combineDateAndTime } from '../../Lib/utils';\nimport { celluarValidate } from '../../Lib/regex';\n\n// styled\nimport { ReserveTopCover, ReservePageContainer, ResrevePageInnerContainer, ResrevePageHalfInnerContainer, MobileBr, DesktopBr } from './reserve.styled';\nimport { TopBannerSection, TopBannerText, TopBannerDescription } from './reserve.styled';\nimport { StepSectionContainer, StepButton, LastStepButton, StepButtonWrapper, StepArrow } from './reserve.styled';\nimport { NextStepGudieContainer, NextStepEmoj, NextStepTitle, NextStepArrowDown } from './reserve.styled';\nimport { ServiceSectionContainer, ServiceSectionTitle, ServiceSectionDescription } from './reserve.styled';\nimport { ServiceCardWrapper, ServiceCardButton, ServiceCardList } from './reserve.styled';\nimport { ZzzServiceWrapper, ZzzArt, ZzzDescription } from './reserve.styled';\nimport { AlzheServiceWrapper, AlzheArt, AlzheDescription } from './reserve.styled';\nimport { ServiceTypeSectionContainer, ServiceTypeWrapper } from './reserve.styled';\nimport { ServiceTypeCardWrapper, ServiceTypeCardImg, NextStepButton, ServiceTypeName, ServiceTypeDescription } from './reserve.styled';\nimport { FormContainer, MobileStepImage, TopBannerSubDescription, UnderLineText, FormWrapper, FormMainTitle, FormMainAlert } from './reserve.styled';\nimport {\n    ServiceName,\n    LabelValue,\n    DashAndText,\n    Sexes,\n    LabelAndValueRow,\n    PriceValue,\n    LabelDescription,\n    FlexFormWrapper,\n    ResultFormWrapper,\n    PriceDetailLabel,\n    PriceDetailValue,\n    CongraturateLogo,\n    DoneResultWrapper,\n} from './reserve.styled';\n\n// components\nimport {\n    DivisionLine,\n    WithmateLabel,\n    WithmateInput,\n    WithmateTextarea,\n    WithmateSelect,\n    FlexWrapper,\n    WithmateTimepicker,\n    WithamteInputWithButton,\n    WithmateDatePicker,\n} from '../../Components/Common/input';\nimport { ButtonWrapper, RadiusHalfWidthButton } from '../../Components/Common/button';\n\nimport PatientProfileListModal from './patientListModal';\nimport MateModal from './mateListModal';\nimport CardListModal from './cardListModal';\nimport { fetchPatient, fetchMate, fetchCard } from '../../Lib/Api/auth';\nimport { Label } from 'reactstrap';\n\nexport default class ReservationPage extends React.PureComponent {\n    state = {\n        step: 'items', // items, basic, form, confirm, done\n        big5: [],\n        local: [],\n        corpBy: [],\n        zzz: [],\n        alzhe: [],\n        productId: '',\n        productInfo: null,\n        service: '',\n        patientList: [],\n        patientId: '',\n        mateList: [],\n        chooseMate: '아니오',\n        cardList: [],\n    };\n\n    componentDidMount = async () => {\n        const userId = localStorage.getItem('id');\n        if (!userId) {\n            message.warning('로그인 후 이용해주세요.');\n            setTimeout(() => {\n                this.props.history.goBack();\n            }, 250);\n            return null;\n        }\n\n        const { params } = this.props.match;\n        if (params.step && params.step !== 'items') {\n            this.props.history.push('/reserve/items');\n        }\n\n        this.fetchUserInfo();\n        this.fetchItemList();\n    };\n\n    componentDidUpdate = prevProps => {\n        const { params: prevParams } = prevProps.match;\n        const { params } = this.props.match;\n        if (JSON.stringify(prevParams) !== JSON.stringify(params)) {\n            this.setState({ step: params.step });\n        }\n    };\n\n    fetchUserInfo = () => {\n        const userId = localStorage.getItem('id');\n        if (!userId) return null;\n        axios.get(`/v1/user/${userId}/user`).then(resolve => {\n            const { data } = resolve;\n            if (data && data._id) {\n                this.setState({ userInfo: data, point: data.point, usePoint: 0, connection: data.connection });\n            }\n        });\n    };\n\n    onPrevSetting = () => {\n        const userId = localStorage.getItem('id');\n        fetchPatient({ id: userId }).then(resolve => {\n            // console.log(resolve)\n            if (resolve && resolve.data && resolve.data.message === 'success') {\n                this.setState({ patientList: resolve.data.data, patientProfileListModal: true });\n            } else {\n                notification.open({\n                    message: '조회되는 환자 목록이 없습니다.',\n                    description: '[마이페이지]에서 환자 프로필을 등록하실 수 있습니다.',\n                    type: 'primary',\n                });\n            }\n        });\n\n        // const { productInfo } = this.state;\n        // if (!userId) return null;\n\n        // axios.get('/v2/user/recent/reserve/info', { params: { userId } }).then(resolve => {\n        //     const { data } = resolve;\n        //     if (data && data._id) {\n        //         delete data._id;\n        //         // 도착지랑 출발지 제외하고 나머지 다 추가\n        //         if (productInfo && productInfo.reservedDestination) delete data.destination;\n        //         if (productInfo && productInfo.reservedStarting) delete data.starting;\n\n        //         this.setState({ ...data });\n        //     } else {\n        //         message.warning('조회되는 최근 예약정보가 없습니다.');\n        //     }\n        // });\n    };\n\n    onPrevSetting2 = () => {\n        fetchMate({ valid: true }).then(resolve => {\n            console.log(resolve);\n            if (resolve && resolve.data && resolve.data.message === 'success') {\n                this.setState({ mateList: resolve.data.data, mateListModal: true });\n            } else {\n                message.info('조회되는 메이트가 없습니다.');\n            }\n        });\n    };\n\n    // 카드 목록 불러오기\n    onPrevSetting3 = () => {\n        const userId = localStorage.getItem('id');\n        fetchCard({ id: userId }).then(resolve => {\n            if (resolve && resolve.data && resolve.data.message === 'success') {\n                this.setState({ cardList: resolve.data.data, cardListModal: true });\n            } else {\n                notification.open({\n                    message: '조회되는 카도 목록이 없습니다.',\n                    description: '[마이페이지]에서 결제 카드를 등록하실 수 있습니다.',\n                    type: 'primary',\n                });\n            }\n        });\n    };\n\n    fetchItemList = () => {\n        axios.get('/v1/product/service/tag/group', { params: { isOption: true } }).then(resolve => {\n            const { data } = resolve;\n            if (data) {\n                this.setState({ ...data });\n            }\n        });\n    };\n\n    onSelectService = info => {\n        this.setState(\n            {\n                productId: info.id,\n                productInfo: info,\n                isZzz: false,\n                isAlzhe: false,\n                starting: info.reservedStarting || '',\n                destination: info.reservedDestination || '',\n                shortStarting: info.reservedShortStarting || '',\n                shortDestination: info.reservedShortDestination || '',\n            },\n            this.goSecondStep,\n        );\n    };\n\n    goSecondStep = () => {\n        const rect = document.querySelector('#second-step').getClientRects();\n        const { top } = rect[0];\n        window.scrollTo(0, window.scrollY + top - 55);\n    };\n\n    goNextButton = () => {\n        const rect = document.querySelector('#fst-next-btn').getClientRects();\n        const { top } = rect[0];\n        window.scrollTo(0, window.scrollY + top - 55);\n    };\n    // Daum Address Search 출발지\n    onStarting = () => {\n        new window.daum.Postcode({\n            oncomplete: data => {\n                const { sido, sigungu, bname, roadAddress, buildingName } = data;\n                this.setState(prevState => ({\n                    shortStarting: `${sido} ${sigungu} ${bname}`,\n                    starting: `${roadAddress} (${buildingName})`,\n                }));\n            },\n        }).open();\n    };\n    // Daum Address Search 도착지\n    onDestination = () => {\n        new window.daum.Postcode({\n            oncomplete: data => {\n                const { sido, sigungu, bname, roadAddress, buildingName } = data;\n                this.setState(prevState => ({\n                    destination: `${roadAddress} (${buildingName})`,\n                    shortDestination: `${sido} ${sigungu} ${bname}`,\n                }));\n            },\n        }).open();\n    };\n\n    onAddress = () => {\n        new window.daum.Postcode({\n            oncomplete: data => {\n                const { roadAddress, buildingName } = data;\n                this.setState(prevState => ({\n                    address: `${roadAddress} (${buildingName})`,\n                }));\n            },\n        }).open();\n    };\n\n    stepHandler = () => {\n        const { step: currentStep, service, productId, shortStarting, shortDestination, recommender = '', recommenderContact = '' } = this.state;\n        const { patient, sex, contact = '', age, guardContact, relate, starting, destination } = this.state;\n        const {\n            mateGender,\n            reserveDate,\n            meetTime,\n            meetMinute,\n            reserveTime,\n            reserveMinute,\n            addTime,\n            comment,\n            transport,\n            // payment = 'transfer',\n            payment,\n            usePoint,\n            point,\n            productInfo,\n            environment,\n            caution,\n            chooseMate,\n            mateName,\n            cardName,\n            cardNum,\n            year,\n            month,\n            installment,\n        } = this.state;\n\n        switch (currentStep) {\n            case 'items':\n                if (!service) return message.warning('서비스를 선택해주세요.');\n                if (!productId) return message.warning('서비스 상세 분류를 선택해주세요. (ex. Pro, Basic, 내시경 등)');\n\n                this.props.history.push('/reserve/basic');\n                break;\n\n            case 'basic':\n                if (!patient) return message.warning('환자분의 성함을 입력해주세요.');\n                if (!sex) return message.warning('환자분의 성별을 입력해주세요.');\n                // if (!contact) return message.warning('환자분의 연락처를 입력해주세요.');\n                if (!age) return message.warning('환자분의 나이를 입력해주세요.');\n                if (!relate) return message.warning('환자분과의 관계를 선택해주세요.');\n                if (!guardContact) return message.warning('보호자님의 연락처를 확인해주세요.');\n                if (!destination) return message.warning('도착지를 검색 및 설정해주세요.');\n                if (service === 'unemergency' && !starting) return message.warning('출발지를 검색 및 설정해주세요.');\n\n                this.props.history.push('/reserve/form');\n                break;\n\n            case 'form':\n                if (!reserveDate) return message.warning('진료 예약일을 설정해주세요.');\n                if (!reserveTime || !reserveMinute) return message.warning('진료 예약 시간을 설정해주세요.');\n                if (service === 'unemergency' && (!meetTime || !meetMinute)) return message.warning('동행인의 출발지 도착 희망 시간을 설정해주세요.');\n                if (!addTime) return message.warning('예상 소요 시간을 입력해주세요.');\n                if (recommenderContact && !celluarValidate(recommenderContact))\n                    return message.warning('추천인 연락처를 올바르게 입력해주세요. (ex. 01012341243');\n                if ((recommenderContact && !recommender) || (recommender && !recommenderContact)) return message.warning('추천인 정보를 마저 입력해주세요.');\n\n                this.props.history.push('/reserve/confirm');\n                break;\n\n            case 'confirm':\n                // 여기서 결제해야함\n                const userId = localStorage.getItem('id');\n                if (!userId) return null;\n\n                const _transport = transport && transport === 'own' ? 20000 : 0;\n                const _service =\n                    productInfo &&\n                    service &&\n                    (service === 'unemergency' ? productInfo.proPrice : productInfo.basicPrice ? productInfo.basicPrice : 0) * addTime;\n                const discount = service === 'unemergency' ? productInfo.proDiscount || 0 : productInfo.basicDiscount || 0;\n                const totalFee = _transport + _service - discount;\n\n                if (service === 'unemergency' && !transport) return message.warning('이동 수단을 선택해주세요.');\n                if (usePoint > point) return message.warning('잔여 포인트보다 사용하고자 하는 포인트가 더 높습니다.');\n                if (usePoint > totalFee) return message.warning('사용하고자 하는 포인트가 예상 결제금액보다 높습니다.');\n\n                const info = {\n                    shortStarting,\n                    destination,\n                    shortDestination,\n                    comment,\n                    service,\n                    addTime,\n                    starting,\n                    contact,\n                    guardContact,\n                    reserveDate: combineDateAndTime({ date: reserveDate, time: reserveTime, minute: reserveMinute }),\n                    meetDate: combineDateAndTime({ date: reserveDate, time: meetTime, minute: meetMinute }),\n                    patient,\n                    relate,\n                    payment,\n                    sex,\n                    age,\n                    transport,\n                    recommender,\n                    recommenderContact,\n                    product: productId,\n                    usingPoint: usePoint,\n                    mateGender,\n                    environment,\n                    caution,\n                    chooseMate,\n                    mateName,\n                    cardName,\n                    cardNum,\n                    year,\n                    month,\n                    installment,\n                };\n\n                axios\n                    .post('/v2/service/reserve/new', { info, userId })\n                    .then(async resolve => {\n                        const { data } = resolve;\n                        if (!data) message.error('죄송합니다 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n                        if (data === 'check parameters') return message.warning('입력하지 않은 정보가 있는지 다시 한번 확인해주세요.');\n                        if (data === 'invalid user') return message.warning('세션이 만료되었습니다. 재 로그인 후 다시 시도해주세요.');\n                        if (data === 'invalid product')\n                            return message.warning('죄송합니다. 선택하신 서비스가 더이상 지원하지 않는 서비스입니다. 다른 서비스를 이용해주세요.');\n\n                        if (data === 'success') {\n                            // 사용자 연락처 갱신\n                            // await axios.post('/v1/user/modify/info', { id: userId, userType: 'user', info: { contact: guardContact } });\n\n                            message.success('동행 서비스 요청 완료');\n                            this.props.history.push('/reserve/done');\n                        }\n                    })\n                    .catch(error => {\n                        message.error('죄송합니다 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n                    });\n                break;\n        }\n    };\n\n    stepHandler2 = () => {\n        const { step: currentStep, service, productId, shortStarting, shortDestination, recommender = '', recommenderContact = '' } = this.state;\n        const { patient, sex, contact, age, guardContact, relate, starting, destination, mateId } = this.state;\n        const {\n            mateGender,\n            reserveDate,\n            meetTime,\n            meetMinute,\n            reserveTime,\n            reserveMinute,\n            addTime,\n            comment,\n            transport,\n            // payment = 'transfer',\n            payment,\n            usePoint,\n            point,\n            productInfo,\n            environment,\n            caution,\n            chooseMate,\n            mateName,\n        } = this.state;\n\n        switch (currentStep) {\n            case 'items':\n                if (!service) return message.warning('서비스를 선택해주세요.');\n                if (!productId) return message.warning('서비스 상세 분류를 선택해주세요. (ex. Pro, Basic, 내시경 등)');\n\n                this.props.history.push('/reserve/basic');\n                break;\n\n            case 'basic':\n                if (!patient) return message.warning('환자분의 성함을 입력해주세요.');\n                if (!sex) return message.warning('환자분의 성별을 입력해주세요.');\n                // if (!contact) return message.warning('환자분의 연락처를 입력해주세요.');\n                if (!age) return message.warning('환자분의 나이를 입력해주세요.');\n                if (!relate) return message.warning('환자분과의 관계를 선택해주세요.');\n                if (!guardContact) return message.warning('보호자님의 연락처를 확인해주세요.');\n                if (!destination) return message.warning('도착지를 검색 및 설정해주세요.');\n                if (service === 'unemergency' && !starting) return message.warning('출발지를 검색 및 설정해주세요.');\n\n                this.props.history.push('/reserve/form');\n                break;\n\n            case 'form':\n                if (!reserveDate) return message.warning('진료 예약일을 설정해주세요.');\n                if (!reserveTime || !reserveMinute) return message.warning('진료 예약 시간을 설정해주세요.');\n                if (service === 'unemergency' && (!meetTime || !meetMinute)) return message.warning('동행인의 출발지 도착 희망 시간을 설정해주세요.');\n                if (!addTime) return message.warning('예상 소요 시간을 입력해주세요.');\n                if (recommenderContact && !celluarValidate(recommenderContact))\n                    return message.warning('추천인 연락처를 올바르게 입력해주세요. (ex. 01012341243');\n                if ((recommenderContact && !recommender) || (recommender && !recommenderContact)) return message.warning('추천인 정보를 마저 입력해주세요.');\n\n                this.props.history.push('/reserve/confirm');\n                break;\n\n            case 'confirm':\n                // 여기서 결제해야함\n                const userId = localStorage.getItem('id');\n                if (!userId) return null;\n\n                const _transport = transport && transport === 'own' ? 20000 : 0;\n                const _service =\n                    productInfo &&\n                    service &&\n                    (service === 'unemergency' ? productInfo.proPrice : productInfo.basicPrice ? productInfo.basicPrice : 0) * addTime;\n                const discount = service === 'unemergency' ? productInfo.proDiscount || 0 : productInfo.basicDiscount || 0;\n                const totalFee = _transport + _service - discount;\n\n                if (service === 'unemergency' && !transport) return message.warning('이동 수단을 선택해주세요.');\n                if (usePoint > point) return message.warning('잔여 포인트보다 사용하고자 하는 포인트가 더 높습니다.');\n                if (usePoint > totalFee) return message.warning('사용하고자 하는 포인트가 예상 결제금액보다 높습니다.');\n\n                const info = {\n                    shortStarting,\n                    destination,\n                    shortDestination,\n                    comment,\n                    service,\n                    addTime,\n                    starting,\n                    contact,\n                    guardContact,\n                    reserveDate: combineDateAndTime({ date: reserveDate, time: reserveTime, minute: reserveMinute }),\n                    meetDate: combineDateAndTime({ date: reserveDate, time: meetTime, minute: meetMinute }),\n                    patient,\n                    relate,\n                    payment,\n                    sex,\n                    age,\n                    transport,\n                    recommender,\n                    recommenderContact,\n                    product: productId,\n                    usingPoint: usePoint,\n                    mateGender,\n                    environment,\n                    caution,\n                    chooseMate,\n                    mateId,\n                };\n\n                axios\n                    .post('/v2/service/reserve/mate/new', { info, userId, mateId })\n                    .then(async resolve => {\n                        const { data } = resolve;\n                        if (!data) message.error('죄송합니다 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n                        if (data === 'check parameters') return message.warning('입력하지 않은 정보가 있는지 다시 한번 확인해주세요.');\n                        if (data === 'invalid user') return message.warning('세션이 만료되었습니다. 재 로그인 후 다시 시도해주세요.');\n                        if (data === 'invalid product')\n                            return message.warning('죄송합니다. 선택하신 서비스가 더이상 지원하지 않는 서비스입니다. 다른 서비스를 이용해주세요.');\n\n                        if (data === 'success') {\n                            message.success('동행 서비스 요청 완료');\n                            this.props.history.push('/reserve/done');\n                        }\n                    })\n                    .catch(error => {\n                        message.error('죄송합니다 요청에 실패하였습니다. 잠시 후 다시 시도해주세요.');\n                    });\n                break;\n        }\n    };\n\n    prevStep = () => {\n        this.props.history.goBack();\n    };\n\n    handleChange = e => {\n        const type = e.target.name;\n        const value = e.target.value;\n\n        this.setState({ [type]: value });\n    };\n\n    patientProfileListModalOff = () => {\n        this.setState({\n            patientProfileListModal: false,\n        });\n    };\n\n    mateListModalOff = () => {\n        this.setState({\n            mateListModal: false,\n        });\n    };\n\n    cardListModalOff = () => {\n        this.setState({\n            cardListModal: false,\n        });\n    };\n\n    onUpdatePatient = data => {\n        this.setState({\n            patient: data.name,\n            age: data.age,\n            contact: data.contact,\n            relate: data.relate,\n            sex: data.sex,\n            starting: data.starting,\n            environment: data.environment,\n            caution: data.caution,\n        });\n    };\n\n    onUpdateMate = data => {\n        this.setState({\n            mateName: data.name,\n            mateContact: data.contact,\n            mateId: data._id,\n        });\n    };\n\n    onUpdateCard = data => {\n        this.setState({\n            cardName: data.cardName,\n            cardNum: data.cardNum,\n            year: data.year,\n            month: data.month,\n        });\n    };\n\n    render() {\n        const { step, big5, local, corpBy, zzz, alzhe, productId = '', productInfo, service, isZzz = false, isAlzhe = false, mateName } = this.state;\n        // console.log(this.state)\n        return (\n            <ReservePageContainer>\n                <ReserveTopCover isMain={step === 'items'}>\n                    <BannerSection isMain={step === 'items'} />\n                    {step === 'items' && (\n                        <NextGuider\n                            color={'#ffffff'}\n                            emoj={'/assets/images/guide_step_1.png'}\n                            title={\n                                <>\n                                    먼저, 원하시는 <MobileBr />\n                                    서비스 종류를 선택하세요!\n                                </>\n                            }\n                        />\n                    )}\n                </ReserveTopCover>\n                {step && step !== 'items' && <StepSection step={step} />}\n                {step === 'items' && (\n                    <>\n                        <ServiceSection\n                            bg='/assets/images/artwork_right_bg.png'\n                            mobileBg='#ffffff'\n                            title='대형병원 동행 서비스'\n                            description='대형병원에 방문하는 분들을 위한 서비스입니다.'\n                        >\n                            <ServiceCardList>\n                                {big5 &&\n                                    big5.length > 0 &&\n                                    big5.map((product, index) => (\n                                        <Card\n                                            key={'big5-item-' + index.toString()}\n                                            source={product.logo}\n                                            selected={product.id === productId ? 'selected' : ''}\n                                            onSelect={() => {\n                                                this.onSelectService(product);\n                                            }}\n                                        />\n                                    ))}\n                            </ServiceCardList>\n                        </ServiceSection>\n                        <ServiceSection\n                            mobileBg='#f2f2f2'\n                            title='지역별 병원 동행 서비스'\n                            description={\n                                <>\n                                    대형병원을 제외한 각 지역별 병원에 <MobileBr /> 방문하는 분들을 위한 서비스입니다.\n                                </>\n                            }\n                        >\n                            <ServiceCardList>\n                                {local &&\n                                    local.length > 0 &&\n                                    local.map((product, index) => (\n                                        <Card\n                                            key={'local-item-' + index.toString()}\n                                            source={product.logo}\n                                            selected={product.id === productId ? 'selected' : ''}\n                                            onSelect={() => {\n                                                this.onSelectService(product);\n                                            }}\n                                        />\n                                    ))}\n                            </ServiceCardList>\n                        </ServiceSection>\n                        {/* <ServiceSection\n                            bg='/assets/images/artwork_left_bg.png'\n                            mobileBg='#ffffff'\n                            title='기업 기관별 동행 서비스'\n                            description={\n                                <>\n                                    위드메이트와 협업 중인 <MobileBr /> 기업 및 기관을 위한 접수 창구입니다\n                                </>\n                            }\n                        >\n                            <ServiceCardList>\n                                {corpBy &&\n                                    corpBy.length > 0 &&\n                                    corpBy.map((product, index) => (\n                                        <Card\n                                            key={'corpBy-item-' + index.toString()}\n                                            source={product.logo}\n                                            selected={product.id === productId ? 'selected' : ''}\n                                            onSelect={() => {\n                                                this.onSelectService(product);\n                                            }}\n                                        />\n                                    ))}\n                            </ServiceCardList>\n                        </ServiceSection> */}\n                        {/* <ZzzService\n                            selected={zzz.length === 0 ? '' : zzz[0].id === productId ? 'selected' : ''}\n                            onSelect={() => {\n                                if (zzz.length === 0) return message.warning('운영중인 내시경 보호자 서비스가 없습니다.');\n\n                                const z_one = zzz[0];\n                                this.setState({ productId: z_one.id, productInfo: z_one, isZzz: true }, this.goSecondStep);\n                            }}\n                        />\n\n                        <AlzheService\n                            selected={alzhe.length === 0 ? '' : alzhe[0].id === productId ? 'selected' : ''}\n                            onSelect={() => {\n                                if (alzhe.length === 0) return message.warning('운영중인 치매 보호자 서비스가 없습니다.');\n\n                                const a_one = alzhe[0];\n                                this.setState({ productId: a_one.id, productInfo: a_one, isAlzhe: true }, this.goSecondStep);\n                            }}\n                        /> */}\n                        {productId && (\n                            <>\n                                <NextGuider\n                                    bg\n                                    id='second-step'\n                                    emoj={'/assets/images/guide_step_2.png'}\n                                    title={\n                                        <>\n                                            이제, 원하시는 <MobileBr /> 서비스 타입을 선택하세요!\n                                        </>\n                                    }\n                                />\n                                <ServiceTypeSection bg='/assets/images/artwork_right_bg2.png' mobileBg={'#ffffff'}>\n                                    <ServiceTypeWrapper>\n                                        {productInfo.usePro && !isZzz && (\n                                            <ServiceTypeCard\n                                                emoj={'/assets/images/art_pro.png'}\n                                                name='Pro'\n                                                desc={`위드메이트 동행 전문가가 고객님 자택에서 병원까지 동행하고, 병원 업무를 마친 뒤  다시 자택까지 \n                                                동행합니다.`}\n                                                selected={service === 'unemergency' ? 'selected' : ''}\n                                                onSelect={() => {\n                                                    this.setState({ service: 'unemergency' }, this.goNextButton);\n                                                }}\n                                            />\n                                        )}\n\n                                        {productInfo.useBasic && !isZzz && (\n                                            <ServiceTypeCard\n                                                emoj={'/assets/images/art_basic.png'}\n                                                name='Basic'\n                                                desc={`위드메이트 베이직 서비스는 \n                                                위드메이트 동행 전문가가 지정한 의료 시설 혹은 병원 내에서 \n                                                보호자 대행 업무를 수행합니다.`}\n                                                selected={service === 'assist' ? 'selected' : ''}\n                                                onSelect={() => {\n                                                    this.setState({ service: 'assist' }, this.goNextButton);\n                                                }}\n                                            />\n                                        )}\n\n                                        {isZzz && (\n                                            <ServiceTypeCard\n                                                emoj={'/assets/images/art_zzz.png'}\n                                                name='내시경'\n                                                desc={`위드메이트 동행 전문가가 고객님께서 수면 내시경 검사/진료를 \n                                                받는 의료 시설에 도착한 후 \n                                                보호자 대행 업무를 수행합니다.`}\n                                                selected={service === 'assist' ? 'selected' : ''}\n                                                onSelect={() => {\n                                                    this.setState({ service: 'assist' }, this.goNextButton);\n                                                }}\n                                            />\n                                        )}\n                                    </ServiceTypeWrapper>\n                                    <NextStepButton id='fst-next-btn' on={productId && service} onClick={this.stepHandler}>\n                                        다음 단계로가기\n                                    </NextStepButton>\n                                </ServiceTypeSection>\n                            </>\n                        )}\n                    </>\n                )}\n                {/* {step === 'basic' && ( */}\n                {step === 'basic' && (\n                    <>\n                        <FormContainer>\n                            <BasicForm\n                                data={this.state}\n                                handleChange={this.handleChange}\n                                onStarting={this.onStarting}\n                                onDestination={this.onDestination}\n                                onPrevSetting={this.onPrevSetting}\n                            />\n                            <CustomButtonWrapper>\n                                <RadiusHalfWidthButton bg='#cecfd0' onClick={this.prevStep}>\n                                    이전으로\n                                </RadiusHalfWidthButton>\n                                <RadiusHalfWidthButton bg='#3bc1ff' onClick={this.stepHandler}>\n                                    다음 단계로가기\n                                </RadiusHalfWidthButton>\n                            </CustomButtonWrapper>\n                        </FormContainer>\n                    </>\n                )}\n                {/* {step === 'form' && ( */}\n                {step === 'form' && (\n                    <>\n                        <FormContainer>\n                            <MainForm data={this.state} handleChange={this.handleChange} onPrevSetting2={this.onPrevSetting2} />\n                            <CustomButtonWrapper>\n                                <RadiusHalfWidthButton bg='#cecfd0' onClick={this.prevStep}>\n                                    이전으로\n                                </RadiusHalfWidthButton>\n                                <RadiusHalfWidthButton bg='#3bc1ff' onClick={this.stepHandler}>\n                                    다음 단계로가기\n                                </RadiusHalfWidthButton>\n                            </CustomButtonWrapper>\n                        </FormContainer>\n                    </>\n                )}\n                {step === 'confirm' && (\n                    <>\n                        <FormContainer>\n                            <ConfirmForm data={this.state} handleChange={this.handleChange} onPrevSetting3={this.onPrevSetting3} onAddress={this.onAddress} />\n                            <CustomButtonWrapper>\n                                <RadiusHalfWidthButton bg='#cecfd0' onClick={this.prevStep}>\n                                    이전으로\n                                </RadiusHalfWidthButton>\n                                {mateName ? (\n                                    <>\n                                        <RadiusHalfWidthButton bg='#3bc1ff' onClick={this.stepHandler2}>\n                                            신청 완료\n                                        </RadiusHalfWidthButton>\n                                    </>\n                                ) : (\n                                    <RadiusHalfWidthButton bg='#3bc1ff' onClick={this.stepHandler}>\n                                        신청 완료하기\n                                    </RadiusHalfWidthButton>\n                                )}\n                            </CustomButtonWrapper>\n                        </FormContainer>\n                    </>\n                )}\n                {step === 'done' && (\n                    <>\n                        <FormContainer>\n                            <DoneForm data={this.state} />\n                            <LastStepButton\n                                on\n                                onClick={() => {\n                                    this.props.history.push('/user/mypage/list');\n                                }}\n                            >\n                                마이 페이지로\n                            </LastStepButton>\n                        </FormContainer>\n                    </>\n                )}\n\n                <PatientProfileListModal\n                    list={this.state.patientList}\n                    visible={this.state.patientProfileListModal}\n                    onClose={this.patientProfileListModalOff}\n                    onUpdatePatient={this.onUpdatePatient}\n                />\n\n                <MateModal list={this.state.mateList} visible={this.state.mateListModal} onClose={this.mateListModalOff} onUpdateMate={this.onUpdateMate} />\n\n                <CardListModal list={this.state.cardList} visible={this.state.cardListModal} onClose={this.cardListModalOff} onUpdateCard={this.onUpdateCard} />\n            </ReservePageContainer>\n        );\n    }\n}\n\nconst BannerSection = ({ isMain }) => (\n    <TopBannerSection isMain={isMain}>\n        {isMain && (\n            <ResrevePageInnerContainer smallPadding>\n                <TopBannerDescription>국내 최대 규모의 병원 동행 서비스 매칭 플랫폼</TopBannerDescription>\n                <TopBannerText>\n                    <span>위드메이트</span>가 함께 동행해드립니다\n                </TopBannerText>\n            </ResrevePageInnerContainer>\n        )}\n        {!isMain && (\n            <ResrevePageInnerContainer smallPadding>\n                <TopBannerText style={{ textAlign: 'left' }}>\n                    <span>\n                        위드메이트가\n                        <br />\n                        함께 동행 해드립니다\n                    </span>\n                </TopBannerText>\n                <TopBannerSubDescription>국내 최대 규모의 병원 동행 서비스 매칭 플랫폼</TopBannerSubDescription>\n            </ResrevePageInnerContainer>\n        )}\n    </TopBannerSection>\n);\n\nconst StepSection = ({ step }) => (\n    <StepSectionContainer>\n        <ResrevePageInnerContainer smallPadding>\n            <StepButtonWrapper>\n                <StepButton active={step === 'basic'}>환자 기본 정보 입력</StepButton>\n                <StepArrow src={'/assets/images/stepper.png'} alt='화살표' />\n                <StepButton active={step === 'form'}>서비스 신청 정보 입력</StepButton>\n                <StepArrow src={'/assets/images/stepper.png'} alt='화살표' />\n                <StepButton active={step === 'confirm'}>매칭 신청 확인</StepButton>\n                <StepArrow src={'/assets/images/stepper.png'} alt='화살표' />\n                <StepButton active={step === 'done'}>신청 완료</StepButton>\n            </StepButtonWrapper>\n        </ResrevePageInnerContainer>\n    </StepSectionContainer>\n);\n\nconst NextGuider = ({ id, emoj, title, color = 'rgba(0,0,0,0.7)', bg = false }) => (\n    <NextStepGudieContainer id={id} useBg={bg ? true : false}>\n        <NextStepEmoj src={emoj} alt='스텝넘버' />\n        <NextStepTitle color={color}>{title}</NextStepTitle>\n        <NextStepArrowDown src={'/assets/images/arrowDown.png'} alt='아래로' />\n    </NextStepGudieContainer>\n);\n\nconst ServiceSection = ({ title, description, bg, mBg, children }) => {\n    return (\n        <ServiceSectionContainer>\n            <ResrevePageInnerContainer bg={bg} mobileBg={mBg}>\n                <ServiceSectionTitle>{title}</ServiceSectionTitle>\n                <ServiceSectionDescription>{description}</ServiceSectionDescription>\n                {children}\n            </ResrevePageInnerContainer>\n        </ServiceSectionContainer>\n    );\n};\n\nconst Card = ({ source, onSelect, selected }) => (\n    <ServiceCardWrapper on={selected || ''}>\n        <img src={source} alt='로고' />\n        <ServiceCardButton className={selected ? 'selected' : 'none-selected'} onClick={onSelect}>\n            선택\n        </ServiceCardButton>\n    </ServiceCardWrapper>\n);\n\nconst ZzzService = ({ selected, onSelect }) => (\n    <ResrevePageHalfInnerContainer>\n        <ZzzServiceWrapper>\n            <ZzzArt src='/assets/images/art_zzz.png' />\n            <ServiceSectionTitle>수면 내시경 보호자 서비스</ServiceSectionTitle>\n            <ZzzDescription>\n                {' '}\n                수면 내시경 검사 시 <MobileBr />\n                보호자를 대행하는 서비스입니다.\n            </ZzzDescription>\n            <ServiceSectionDescription>\n                수면 내시경 검사가 끝날 때까지 <b>병원 안에서</b>\n                <MobileBr /> 고객님의 보호자 대행 업무를 수행합니다.\n                <DesktopBr />\n                <MobileBr />\n                <MobileBr />\n                <b>서울/경기(일부)</b>에서만 서비스가 제공됩니다.\n                <DesktopBr />\n                <MobileBr />\n            </ServiceSectionDescription>\n            <ServiceCardButton className={selected ? 'selected' : 'none-selected'} onClick={onSelect}>\n                선택\n            </ServiceCardButton>\n        </ZzzServiceWrapper>\n    </ResrevePageHalfInnerContainer>\n);\n\nconst AlzheService = () => (\n    <ResrevePageHalfInnerContainer>\n        <AlzheServiceWrapper>\n            <AlzheArt src='/assets/images/art_alzhe.jpg' />\n            <ServiceSectionTitle>치매 동행 서비스 (beta)</ServiceSectionTitle>\n            <AlzheDescription>\n                메이트가 치매 환자분의 집-병원 간 <MobileBr /> 모든 여정을 함께하는 서비스입니다.\n            </AlzheDescription>\n            <ServiceSectionDescription>\n                <b>치매 환자 전문</b> 메이트를 포함하여 <MobileBr /> 2인의 메이트가 배정됩니다.\n                <DesktopBr />\n                <MobileBr />\n                <MobileBr />\n                메이트(<b>2인</b>)-환자 간 매칭이 완료되지 않으면\n                <MobileBr /> 서비스가 제공되지 않는 점 양해바랍니다.\n                <MobileBr />\n                <DesktopBr />\n                <MobileBr />\n                <b>전화</b>로만 서비스 예약을 하실 수 있습니다.\n            </ServiceSectionDescription>\n            <ServiceCardButton\n                onClick={() => {\n                    swal.fire({\n                        title: '위드메이트 고객센터',\n                        text: '☎ 070-4300-9075',\n                        icon: 'info',\n                        confirmButtonText: '전화걸기',\n                        cancelButtonText: '확인',\n                        showCancelButton: true,\n                    }).then(result => {\n                        if (result.isConfirmed) {\n                            document.location.href = 'tel:070-4300-9075';\n                        }\n                    });\n                }}\n            >\n                전화 상담하기\n            </ServiceCardButton>\n        </AlzheServiceWrapper>\n    </ResrevePageHalfInnerContainer>\n);\n\nconst ServiceTypeSection = ({ bg, mobileBg, children }) => (\n    <ServiceTypeSectionContainer bg={bg} mBg={mobileBg} gap>\n        {children}\n    </ServiceTypeSectionContainer>\n);\n\nconst ServiceTypeCard = ({ emoj, name, desc, selected, onSelect }) => (\n    <ServiceTypeCardWrapper selected={selected || ''}>\n        <ServiceTypeCardImg src={emoj} alt='type' />\n        <ServiceTypeName>{name}</ServiceTypeName>\n        <ServiceTypeDescription>{desc}</ServiceTypeDescription>\n        <ServiceCardButton onClick={onSelect} className={selected ? 'selected' : 'none-selected'}>\n            선택\n        </ServiceCardButton>\n    </ServiceTypeCardWrapper>\n);\n\nconst BasicForm = ({ data, handleChange, onStarting, onDestination, onPrevSetting }) => {\n    const { productInfo, service, patient, contact, sex, age, relate, guardContact = '', starting, destination } = data;\n    return (\n        <FormWrapper>\n            <FormMainTitle>좋아요! 매칭 신청을 시작해볼까요?</FormMainTitle>\n\n            <DivisionLine big />\n\n            <WithmateLabel>선택하신 서비스</WithmateLabel>\n\n            <ServiceName>\n                {productInfo.name} {productInfo.name.includes('내시경') ? '' : service === 'unemergency' ? 'Pro' : 'Basic'}\n            </ServiceName>\n\n            <DivisionLine big />\n\n            <FlexWrapper style={{ justifyContent: 'space-between' }}>\n                <ServiceTypeName style={{ marginTop: '0px', marginBottom: '0px' }}>환자 정보 입력</ServiceTypeName>\n            </FlexWrapper>\n\n            <div style={{ textAlign: 'right' }}>\n                <Label style={{ color: 'gray', fontSize: '11px' }}>* 등록하신 환자프로필 정보를 가져와 편리하게 예약하실 수 있습니다.</Label>\n                <br />\n                <UnderLineText onClick={onPrevSetting}>환자 프로필 불러오기</UnderLineText>\n            </div>\n\n            <DivisionLine />\n\n            <FlexWrapper withHalf>\n                <div style={{ flex: 1 }}>\n                    <WithmateLabel required>환자 성함</WithmateLabel>\n                    <WithmateInput type='text' placeholder='홍길동' maxLength='24' name='patient' value={patient || null} onChange={handleChange} />\n                </div>\n                <div style={{ flex: 1 }}>\n                    <WithmateLabel required>환자 나이</WithmateLabel>\n                    <WithmateInput type='text' maxLength='2' placeholder='50' name='age' suffix='세' value={age || null} onChange={handleChange} />\n                </div>\n            </FlexWrapper>\n\n            <DivisionLine big />\n\n            <FlexWrapper withHalf>\n                {productInfo.name.includes('내시경') ? null : (\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>환자 연락처</WithmateLabel>\n                        <WithmateInput\n                            type='text'\n                            maxLength='11'\n                            placeholder='ex) 01029791234'\n                            name='contact'\n                            value={contact || null}\n                            onChange={handleChange}\n                        />\n                    </div>\n                )}\n                <div style={{ flex: 1 }}>\n                    <WithmateLabel required>환자 성별</WithmateLabel>\n                    <Sexes>\n                        <span\n                            className={sex === '남자' ? 'active' : 'inactive'}\n                            onClick={() => {\n                                handleChange({ target: { name: 'sex', value: '남자' } });\n                            }}\n                        >\n                            남성\n                        </span>\n                        <span\n                            className={sex === '여자' ? 'active' : 'inactive'}\n                            onClick={() => {\n                                handleChange({ target: { name: 'sex', value: '여자' } });\n                            }}\n                        >\n                            여성\n                        </span>\n                    </Sexes>\n                </div>\n            </FlexWrapper>\n\n            <DivisionLine big />\n\n            <FlexWrapper withHalf>\n                <div style={{ flex: 1 }}>\n                    {productInfo.name.includes('내시경') ? (\n                        <>\n                            <WithmateLabel required>서비스 신청인 연락처</WithmateLabel>\n                            <WithmateInput\n                                type='text'\n                                maxLength='11'\n                                placeholder='서비스를 제공받으실 분의 연락처를 입력하세요.'\n                                name='guardContact'\n                                value={guardContact || null}\n                                onChange={handleChange}\n                            />\n                        </>\n                    ) : (\n                        <>\n                            <WithmateLabel required>보호자 연락처</WithmateLabel>\n                            <WithmateInput\n                                type='text'\n                                maxLength='11'\n                                placeholder='ex) 01029791234'\n                                name='guardContact'\n                                value={guardContact || null}\n                                onChange={handleChange}\n                            />\n                        </>\n                    )}\n                </div>\n                <div style={{ flex: 1 }}>\n                    <WithmateLabel required>환자와의 관계</WithmateLabel>\n                    <WithmateSelect\n                        placeholder='본인'\n                        value={relate || undefined}\n                        onChange={value => {\n                            handleChange({ target: { name: 'relate', value } });\n                        }}\n                    >\n                        <Select.Option value='본인'>본인</Select.Option>\n                        <Select.Option value='부모'>부모</Select.Option>\n                        <Select.Option value='자매'>자매</Select.Option>\n                        <Select.Option value='친구'>친구</Select.Option>\n                        <Select.Option value='지인'>지인</Select.Option>\n                        <Select.Option value='기타'>기타</Select.Option>\n                    </WithmateSelect>\n                </div>\n            </FlexWrapper>\n\n            <DivisionLine big />\n\n            <WithmateLabel required>목적지 주소 (방문 병원 위치)</WithmateLabel>\n            <WithamteInputWithButton\n                inputConfig={{\n                    type: 'text',\n                    placeholder: 'ex) 서울특별시 강남 을지병원',\n                    name: 'destination',\n                    disabled: true,\n                    value: destination || null,\n                }}\n                buttonName='검색'\n                onButton={() => {\n                    if (productInfo.reservedDestination) return message.info('목적지가 고정된 서비스입니다.');\n                    else onDestination();\n                }}\n            />\n\n            <DivisionLine big />\n            {service === 'unemergency' && (\n                <>\n                    <WithmateLabel required>출발지 주소 (자택, 터미널, 역, 입원 병원 등)</WithmateLabel>\n                    <WithamteInputWithButton\n                        inputConfig={{\n                            type: 'text',\n                            placeholder: 'ex) 서울특별시 서초대로  30, ABC아파트',\n                            name: 'starting',\n                            disabled: true,\n                            value: starting || null,\n                        }}\n                        buttonName='검색'\n                        onButton={() => {\n                            if (productInfo.reservedStarting) return message.info('출발지가 고정된 서비스입니다.');\n                            else onStarting();\n                        }}\n                    />\n\n                    <DivisionLine big />\n                </>\n            )}\n\n            <MobileStepImage>\n                <img src={service === 'unemergency' ? '/assets/images/art_pro.png' : '/assets/images/art_basic.png'} alt='스텝이미지' />\n            </MobileStepImage>\n        </FormWrapper>\n    );\n};\n\nconst MainForm = ({ data, handleChange, onPrevSetting2 }) => {\n    const {\n        productInfo,\n        service,\n        addTime,\n        reserveDate,\n        reserveTime,\n        reserveMinute,\n        meetTime,\n        meetMinute,\n        mateGender,\n        comment,\n        recommender,\n        recommenderContact,\n        environment,\n        caution,\n        chooseMate,\n        mateName,\n        mateContact,\n    } = data;\n    const time = !reserveTime ? 9 : moment(reserveTime).get('hour');\n    let allowedAddTimes = 18 - parseInt(time, 10) > 0 ? 18 - parseInt(time, 10) : 0;\n\n    return (\n        <FormWrapper>\n            <FormMainTitle>이것만 하면 매칭 신청이 끝나요!</FormMainTitle>\n            <DivisionLine x_small />\n\n            <WithmateLabel>선택하신 서비스</WithmateLabel>\n            <ServiceName>\n                {productInfo.name} {productInfo.name.includes('내시경') ? '' : service === 'unemergency' ? 'Pro' : 'Basic'}\n            </ServiceName>\n\n            <ServiceTypeName style={{ marginTop: '0px', marginBottom: '0px' }}>병원 정보 입력</ServiceTypeName>\n            <DivisionLine />\n\n            <WithmateLabel required>동행 인력 희망 성별</WithmateLabel>\n            <Sexes>\n                <span\n                    className={!mateGender ? 'active' : 'inactive'}\n                    onClick={() => {\n                        handleChange({ target: { name: 'mateGender', value: '' } });\n                    }}\n                >\n                    상관없음\n                </span>\n                <span\n                    className={mateGender === '남' ? 'active' : 'inactive'}\n                    onClick={() => {\n                        handleChange({ target: { name: 'mateGender', value: '남' } });\n                    }}\n                >\n                    남성\n                </span>\n                <span\n                    className={mateGender === '녀' ? 'active' : 'inactive'}\n                    onClick={() => {\n                        handleChange({ target: { name: 'mateGender', value: '녀' } });\n                    }}\n                >\n                    여성\n                </span>\n            </Sexes>\n            <DivisionLine big />\n\n            <WithmateLabel required>\n                메이트 선택\n                {/* <LabelDescription>(선택하신 메이트님과 상의가 되신 경우에만 가능합니다.)</LabelDescription> */}\n                <LabelDescription>(이전에 동행한 메이트 중에서 선택할 수 있습니다.)</LabelDescription>\n            </WithmateLabel>\n            <Sexes>\n                <span\n                    className={chooseMate === '예' ? 'active' : 'inactive'}\n                    onClick={() => {\n                        handleChange({ target: { name: 'chooseMate', value: '예' } });\n                    }}\n                >\n                    예\n                </span>\n                <span\n                    className={chooseMate === '아니오' ? 'active' : 'inactive'}\n                    onClick={() => {\n                        handleChange({ target: { name: 'chooseMate', value: '아니오' } });\n                    }}\n                >\n                    아니오\n                </span>\n            </Sexes>\n            <DivisionLine small />\n\n            {chooseMate === '아니오' ? null : (\n                <>\n                    <FlexWrapper withHalf>\n                        <div style={{ flex: 3 }}>\n                            <WithmateInput\n                                allowClear\n                                readonly='readonly'\n                                type='text'\n                                name='mateName'\n                                value={mateName || null}\n                                onChange={ev => {\n                                    handleChange({ target: { name: 'mateName', value: ev.target.value } });\n                                }}\n                            />\n                        </div>\n                        <div style={{ flex: 1 }}>\n                            <Button onClick={onPrevSetting2} style={{ height: '46px' }}>\n                                메이트 목록 불러오기\n                            </Button>\n                        </div>\n                    </FlexWrapper>\n                    <DivisionLine big />\n                </>\n            )}\n\n            <WithmateLabel required>진료 예약일</WithmateLabel>\n            <WithmateDatePicker\n                locale={locale}\n                placeholder='진료 예약일을 설정해주세요.'\n                disabledDate={current =>\n                    current < moment().add(0, 'day') ||\n                    current.get('day') === 0 ||\n                    current.get('day') === 6 ||\n                    holidayKR.isSolarHoliday(moment(current).toDate())\n                }\n                inputReadOnly\n                value={reserveDate || undefined}\n                name='reserveDate'\n                onChange={date => {\n                    handleChange({ target: { name: 'reserveDate', value: date } });\n                }}\n            />\n            <DivisionLine big />\n\n            <>\n                {service === 'unemergency' && (\n                    <WithmateLabel required>\n                        동행인의 출발지 도착 희망 시간 <LabelDescription>(자택, 터미널, 역, 입원 병원 등)</LabelDescription>\n                    </WithmateLabel>\n                )}\n                {service === 'assist' && (\n                    <WithmateLabel required>\n                        동행인의 병원 도착 희망 시간 <LabelDescription>(진료 병원, 입원 병원 등)</LabelDescription>\n                    </WithmateLabel>\n                )}\n                <FlexWrapper withHalf>\n                    <div style={{ flex: 1 }}>\n                        <WithmateInput\n                            placeholder='13'\n                            name='meetTime'\n                            maxLength={2}\n                            value={meetTime || undefined}\n                            onChange={ev => {\n                                if (ev.target.value.length > 2) return null;\n                                if (ev.target.value && parseInt(ev.target.value) > 24) return null;\n\n                                handleChange({ target: { name: 'meetTime', value: ev.target.value } });\n                            }}\n                        />\n                    </div>\n                    <div style={{ flex: 1 }}>\n                        <WithmateInput\n                            placeholder='30'\n                            name='meetMinute'\n                            maxLength={2}\n                            value={meetMinute || undefined}\n                            onChange={ev => {\n                                if (ev.target.value.length > 2) return null;\n                                if (ev.target.value && parseInt(ev.target.value) > 59) return null;\n\n                                handleChange({ target: { name: 'meetMinute', value: ev.target.value } });\n                            }}\n                        />\n                    </div>\n                </FlexWrapper>\n                <DivisionLine big />\n            </>\n            {/* {service === 'unemergency' && (\n            )} */}\n\n            <WithmateLabel required>방문병원 진료 예약 시간</WithmateLabel>\n            <FlexWrapper withHalf>\n                <div style={{ flex: 1 }}>\n                    <WithmateInput\n                        placeholder='13'\n                        name='reserveTime'\n                        maxLength={2}\n                        value={reserveTime || undefined}\n                        onChange={ev => {\n                            if (ev.target.value.length > 2) return null;\n                            if (ev.target.value && parseInt(ev.target.value) > 24) return null;\n\n                            handleChange({ target: { name: 'reserveTime', value: ev.target.value } });\n                        }}\n                    />\n                </div>\n                <div style={{ flex: 1 }}>\n                    <WithmateInput\n                        placeholder='30'\n                        name='reserveMinute'\n                        maxLength={2}\n                        value={reserveMinute || undefined}\n                        onChange={ev => {\n                            if (ev.target.value.length > 2) return null;\n                            if (ev.target.value && parseInt(ev.target.value) > 59) return null;\n\n                            handleChange({ target: { name: 'reserveMinute', value: ev.target.value } });\n                        }}\n                    />\n                </div>\n            </FlexWrapper>\n\n            <DivisionLine big />\n\n            <WithmateLabel required>예상 소요 시간</WithmateLabel>\n            <WithmateSelect\n                placeholder='예상 소요 시간을 선택해주세요.'\n                value={\n                    addTime\n                        ? meetTime && meetMinute\n                            ? `${addTime}시간 (${parseInt(meetTime, 10) + parseInt(addTime, 10)}시 ${meetMinute}분 서비스 종료 예정)`\n                            : addTime\n                        : addTime\n                }\n                onChange={val => {\n                    handleChange({ target: { name: 'addTime', value: val } });\n                }}\n            >\n                {new Array(9).fill(0).map((hour, index) => {\n                    return (\n                        <Select.Option key={'hour-row-' + index.toString()} value={index + 1}>\n                            {index + 1}시간\n                        </Select.Option>\n                    );\n                })}\n            </WithmateSelect>\n            <DivisionLine big />\n\n            <WithmateLabel required>외출하실 때 '꼭' 계단을 이용하셔야 하나요?</WithmateLabel>\n            <Radio\n                checked={environment === '네'}\n                onClick={() => {\n                    handleChange({ target: { name: 'environment', value: '네' } });\n                }}\n            >\n                네\n            </Radio>\n            <Radio\n                checked={environment === '아니요, 엘레베이터가 있어요'}\n                onClick={() => {\n                    handleChange({ target: { name: 'environment', value: '아니요, 엘레베이터가 있어요' } });\n                }}\n            >\n                아니요, 엘레베이터가 있어요\n            </Radio>\n            <Radio\n                checked={environment === '1층이라 괜찮아요'}\n                onClick={() => {\n                    handleChange({ target: { name: 'environment', value: '1층이라 괜찮아요' } });\n                }}\n            >\n                1층이라 괜찮아요\n            </Radio>\n            <DivisionLine />\n\n            <DivisionLine />\n\n            <WithmateLabel required>메이트가 동행할 때 주의해야 할 점이 있을까요?</WithmateLabel>\n            <WithmateInput\n                type='text'\n                placeholder='동행시 주의사항을 입력하세요.'\n                value={caution || ''}\n                onChange={ev => {\n                    handleChange({ target: { name: 'caution', value: ev.target.value } });\n                }}\n            />\n            <Checkbox\n                checked={caution === '없어요'}\n                onClick={() => {\n                    handleChange({ target: { name: 'caution', value: '없어요' } });\n                }}\n            >\n                없어요\n            </Checkbox>\n\n            <DivisionLine />\n\n            <WithmateLabel>기타 요청 및 전달 사항</WithmateLabel>\n            <WithmateTextarea\n                type='text'\n                middle='true'\n                placeholder={`그 외에, \"정형외과에 갑니다\", \"안마 의자 사용이 가능한지 물어봐주세요\", \"다음 예약 일정을 꼭 잡아주세요\" 등 메이트님께 요청 및 전달하는 사항을 입력해주세요.`}\n                name='comment'\n                value={comment || null}\n                onChange={handleChange}\n            />\n            <DivisionLine />\n\n            <FlexWrapper withHalf>\n                <div style={{ flex: 1 }}>\n                    <WithmateLabel>추천인 성함</WithmateLabel>\n                    <WithmateInput type='text' placeholder='홍길동' maxLength={24} name='recommender' onChange={handleChange} value={recommender || null} />\n                </div>\n                <div style={{ flex: 1 }}>\n                    <WithmateLabel>추천인 전화번호</WithmateLabel>\n                    <WithmateInput\n                        type='text'\n                        maxLength={11}\n                        placeholder='ex) 01029701234'\n                        name='recommenderContact'\n                        onChange={handleChange}\n                        value={recommenderContact || null}\n                    />\n                </div>\n            </FlexWrapper>\n\n            <MobileStepImage>\n                <img src={service === 'unemergency' ? '/assets/images/art_pro.png' : '/assets/images/art_basic.png'} alt='스텝이미지' />\n            </MobileStepImage>\n        </FormWrapper>\n    );\n};\n\nconst ConfirmForm = ({ data, handleChange, onAddress, onPrevSetting3 }) => {\n    const { productInfo, service, patient, contact, sex, age, relate, guardContact = '', starting, destination, environment, caution } = data;\n    const { addTime, usePoint, reserveDate, transport, reserveTime, meetTime, mateGender, comment, reserveMinute, meetMinute, mateName, connection } = data;\n    const { cardName, cardNum, year, month, installment } = data;\n\n    const _transport = transport && transport === 'own' ? 20000 : 0;\n    const _service =\n        productInfo && service && (service === 'unemergency' ? productInfo.proPrice : productInfo.basicPrice ? productInfo.basicPrice : 0) * addTime;\n\n    const _point = !usePoint ? 0 : parseInt(usePoint, 10) * -1;\n    const discount = service === 'unemergency' ? productInfo.proDiscount || 0 : productInfo.basicDiscount || 0;\n    const totalFee = _transport + _service + _point - discount;\n\n    return (\n        <FlexFormWrapper>\n            <FormWrapper>\n                <FormMainTitle>매칭 신청 내역을 알려드릴게요!</FormMainTitle>\n                <DivisionLine x_small />\n                <WithmateLabel>선택하신 서비스</WithmateLabel>\n                <ServiceName>\n                    {productInfo.name} {productInfo.name.includes('내시경') ? '' : service === 'unemergency' ? 'Pro' : 'Basic'}\n                </ServiceName>\n\n                <LabelValue style={{ marginTop: '0px', marginBottom: '0px' }}>신청 내역</LabelValue>\n                <DivisionLine />\n\n                <FlexWrapper withHalf>\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>환자 성함</WithmateLabel>\n                        <WithmateInput type='text' placeholder='' maxLength='24' name='patient' value={patient || null} disabled />\n                    </div>\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>환자 나이</WithmateLabel>\n                        <WithmateInput type='text' maxLength='2' placeholder='50' name='age' suffix='세' value={age || null} disabled />\n                    </div>\n                </FlexWrapper>\n\n                <DivisionLine big />\n\n                <FlexWrapper withHalf>\n                    {productInfo.name.includes('내시경') ? null : (\n                        <div style={{ flex: 1 }}>\n                            <WithmateLabel required>환자 연락처</WithmateLabel>\n                            <WithmateInput type='text' placeholder='' maxLength='11' name='contact' value={contact || null} disabled />\n                        </div>\n                    )}\n                </FlexWrapper>\n\n                <DivisionLine big />\n                <FlexWrapper withHalf>\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>보호자 연락처</WithmateLabel>\n                        <WithmateInput type='text' placeholder='' maxLength='11' name='guardContact' value={guardContact || null} disabled />\n                    </div>\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>환자와의 관계</WithmateLabel>\n                        <WithmateInput type='text' placeholder='50' name='relate' value={relate || null} disabled />\n                    </div>\n                </FlexWrapper>\n\n                <DivisionLine big />\n\n                <FlexWrapper withHalf>\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>환자 성별</WithmateLabel>\n                        <WithmateInput type='text' placeholder='' name='sex' value={sex || null} disabled />\n                    </div>\n                    <div style={{ flex: 1 }}>\n                        <WithmateLabel required>동행 인력 희망 성별</WithmateLabel>\n                        <WithmateInput type='text' placeholder='50' name='mateGender' value={mateGender || '상관 없음'} disabled />\n                    </div>\n                </FlexWrapper>\n\n                <DivisionLine big />\n\n                <FlexWrapper withHalf>\n                    <WithmateLabel required>선택된 메이트</WithmateLabel>\n                    <WithmateInput type='text' name='mateName' value={mateName || '선택 안함'} disabled />\n                </FlexWrapper>\n\n                <DivisionLine big />\n\n                <WithmateLabel required>목적지 주소 (방문 병원 위치)</WithmateLabel>\n                <WithmateInput type='text' placeholder='' name='destination' value={destination || null} disabled />\n\n                <DivisionLine big />\n                {service === 'unemergency' && (\n                    <>\n                        <WithmateLabel required>출발지 주소 (자택, 터미널, 역, 입원 병원 등)</WithmateLabel>\n                        <WithmateInput type='text' placeholder='' name='starting' value={starting || null} disabled />\n\n                        <DivisionLine big />\n                    </>\n                )}\n\n                <WithmateLabel required>진료 일정</WithmateLabel>\n                <WithmateInput\n                    type='text'\n                    placeholder=''\n                    maxLength={24}\n                    name='reserveDate'\n                    value={moment(combineDateAndTime({ date: reserveDate, time: reserveTime, minute: reserveMinute })).format('YYYY-MM-DD HH시 mm분') || null}\n                    disabled\n                />\n\n                <DivisionLine big />\n\n                {service === 'unemergency' && (\n                    <WithmateLabel required>\n                        동행인의 출발지 도착 희망 시간 <LabelDescription>(자택, 터미널, 역, 입원 병원 등)</LabelDescription>\n                    </WithmateLabel>\n                )}\n                {service === 'assist' && (\n                    <WithmateLabel required>\n                        동행인의 병원 도착 희망 시간 <LabelDescription>(진료 병원, 입원 병원 등)</LabelDescription>\n                    </WithmateLabel>\n                )}\n                <WithmateInput\n                    type='text'\n                    placeholder=''\n                    maxLength={24}\n                    name='meetDate'\n                    value={moment(combineDateAndTime({ date: reserveDate, time: meetTime, minute: meetMinute })).format('YYYY-MM-DD HH시 mm분') || null}\n                    disabled\n                />\n\n                <DivisionLine big />\n\n                <WithmateLabel required>외출하실 때 '꼭' 계단을 이용하셔야 하나요?</WithmateLabel>\n                <WithmateInput type='text' placeholder='' maxLength='24' name='environment' value={environment || null} disabled />\n\n                <DivisionLine />\n\n                <WithmateLabel required>메이트가 동행할 때 주의해야 할 점이 있을까요?</WithmateLabel>\n                <WithmateInput type='text' placeholder='' maxLength='24' name='caution' value={caution || null} disabled />\n\n                <DivisionLine />\n\n                <WithmateLabel required>기타 요청 및 전달 사항</WithmateLabel>\n                <WithmateTextarea type='text' placeholder='' name='comment' value={comment || null} disabled />\n            </FormWrapper>\n\n            <ResultFormWrapper>\n                <FormMainTitle>결제 내역</FormMainTitle>\n                <DivisionLine x_small />\n                {service === 'unemergency' && (\n                    <>\n                        <WithmateSelect\n                            placeholder='이동 수단을 선택해주세요'\n                            value={transport || undefined}\n                            onChange={value => {\n                                handleChange({ target: { name: 'transport', value } });\n                            }}\n                        >\n                            <Select.Option value='common'>대중 교통</Select.Option>\n                            <Select.Option value='own'>본인 소유 자차 이동</Select.Option>\n                        </WithmateSelect>\n\n                        {transport === 'own' && (\n                            <>\n                                <DivisionLine x_small />\n                                <FormMainAlert>서비스 당일 ‘누구나 보험’ 변경 필수입니다.</FormMainAlert>\n                            </>\n                        )}\n                        <DivisionLine />\n                    </>\n                )}\n\n                <LabelAndValueRow borderColor='#cecfd0'>\n                    <LabelValue>예상 비용</LabelValue>\n                    {service === 'unemergency' ? (\n                        <PriceValue>\n                            {connection === '메트라이프'\n                                ? '(10% 할인가격) ' + (parseInt(totalFee, 10) + -1 * _point > 0 ? parseInt(totalFee, 10) + -1 * _point : 0) * 0.9\n                                : parseInt(totalFee, 10) + -1 * _point > 0\n                                ? parseInt(totalFee, 10) + -1 * _point\n                                : 0}\n                            원\n                        </PriceValue>\n                    ) : (\n                        <PriceValue>{parseInt(totalFee, 10) + -1 * _point > 0 ? parseInt(totalFee, 10) + -1 * _point : 0}원</PriceValue>\n                    )}\n                </LabelAndValueRow>\n                {service === 'unemergency' ? (\n                    <>\n                        <LabelAndValueRow>\n                            <PriceDetailLabel>\n                                <span>ㄴ</span>보유 포인트\n                            </PriceDetailLabel>\n                            <PriceDetailValue>{data.point}원</PriceDetailValue>\n                        </LabelAndValueRow>\n                        <LabelAndValueRow borderColor='#e6e6e6'>\n                            <PriceDetailLabel>\n                                <span>ㄴ</span>사용할 포인트\n                            </PriceDetailLabel>\n                            <PriceDetailValue>\n                                <WithmateInput\n                                    type='text'\n                                    small\n                                    suffix='원'\n                                    name='usePoint'\n                                    value={data.usePoint || null}\n                                    placeholder='0'\n                                    onChange={handleChange}\n                                />\n                            </PriceDetailValue>\n                        </LabelAndValueRow>\n                    </>\n                ) : null}\n                <LabelAndValueRow borderColor='#e6e6e6'>\n                    <PriceDetailLabel>\n                        <span>ㄴ</span>결제 수단\n                    </PriceDetailLabel>\n                    <WithmateSelect\n                        placeholder='결제수단'\n                        value={data.payment || undefined}\n                        onChange={value => {\n                            handleChange({ target: { name: 'payment', value } });\n                        }}\n                        style={{ width: '102px' }}\n                    >\n                        <Select.Option value='transfer'>계좌이체</Select.Option>\n                        <Select.Option value='card'>카드결제</Select.Option>\n                    </WithmateSelect>\n                </LabelAndValueRow>\n                {data.payment === 'card' && (\n                    <>\n                        <FormMainAlert>카드결제 이용시 [ 서비스 안내 사항 ]을 확인하세요</FormMainAlert>\n                        <div style={{ textAlign: 'right' }}>\n                            <UnderLineText onClick={onPrevSetting3}>등록된 카드목록</UnderLineText>\n                        </div>\n                        <div style={{ flex: 1, paddingBottom: '10px' }}>\n                            <WithmateLabel required>결제 카드사</WithmateLabel>\n                            <WithmateSelect\n                                name='cardName'\n                                placeholder='카드사를 선택하세요'\n                                value={cardName || undefined}\n                                onChange={value => {\n                                    handleChange({ target: { name: 'cardName', value } });\n                                }}\n                            >\n                                <Select.Option value='KB국민카드'>KB국민카드</Select.Option>\n                                <Select.Option value='삼성카드'>삼성카드</Select.Option>\n                                <Select.Option value='현대카드'>현대카드</Select.Option>\n                                <Select.Option value='우리카드'>우리카드</Select.Option>\n                                <Select.Option value='BC카드'>BC카드</Select.Option>\n                                <Select.Option value='신한카드'>신한카드</Select.Option>\n                                <Select.Option value='롯데카드'>롯데카드</Select.Option>\n                                <Select.Option value='NH농협카드'>NH농협카드</Select.Option>\n                            </WithmateSelect>\n                        </div>\n                        <div style={{ flex: 1, paddingBottom: '10px' }}>\n                            <WithmateLabel required>카드 번호</WithmateLabel>\n                            <WithmateInput\n                                type='text'\n                                placeholder='카드 번호를 입력하세요'\n                                maxLength='24'\n                                name='cardNum'\n                                value={cardNum || null}\n                                onChange={handleChange}\n                            />\n                        </div>\n                        <div style={{ flex: 1, paddingBottom: '10px' }}>\n                            <WithmateLabel required>유효기간(MM/YY)</WithmateLabel>\n                            <WithmateInput\n                                type='text'\n                                placeholder='월(MM)'\n                                maxLength='24'\n                                name='month'\n                                value={month || null}\n                                onChange={handleChange}\n                                style={{ width: '100px', marginRight: '15px' }}\n                            />\n                            <WithmateInput\n                                type='text'\n                                placeholder='년(YY)'\n                                maxLength='24'\n                                name='year'\n                                value={year || null}\n                                onChange={handleChange}\n                                style={{ width: '100px', marginRight: '15px' }}\n                            />\n                        </div>\n                        <div style={{ flex: 1 }}>\n                            <WithmateLabel required>할부 기간</WithmateLabel>\n                            <WithmateSelect\n                                name='installment'\n                                placeholder='할부 기간을 선택하세요'\n                                value={installment || undefined}\n                                onChange={value => {\n                                    handleChange({ target: { name: 'installment', value } });\n                                }}\n                            >\n                                <Select.Option value='일시불'>일시불</Select.Option>\n                                <Select.Option value='2개월'>2개월</Select.Option>\n                                <Select.Option value='3개월'>3개월</Select.Option>\n                                <Select.Option value='4개월'>4개월</Select.Option>\n                                <Select.Option value='5개월'>5개월</Select.Option>\n                                <Select.Option value='6개월'>6개월</Select.Option>\n                                <Select.Option value='7개월'>7개월</Select.Option>\n                                <Select.Option value='8개월'>8개월</Select.Option>\n                                <Select.Option value='9개월'>9개월</Select.Option>\n                                <Select.Option value='10개월'>10개월</Select.Option>\n                                <Select.Option value='11개월'>11개월</Select.Option>\n                                <Select.Option value='12개월'>12개월</Select.Option>\n                            </WithmateSelect>\n                        </div>\n                    </>\n                )}\n\n                <DivisionLine />\n\n                {/* <LabelAndValueRow>\n                    <LabelValue>포인트 적용 후 예상 비용</LabelValue>\n                    <PriceValue>{totalFee > 0 ? totalFee : 0}원</PriceValue>\n                </LabelAndValueRow> */}\n\n                <DivisionLine big />\n                <DivisionLine big />\n\n                <ServiceTypeName style={{ marginTop: '0px', marginBottom: '0px' }}>서비스 안내 사항</ServiceTypeName>\n                <DivisionLine />\n\n                <DashAndText>\n                    <img src='/assets/images/w_check.png' alt='아이콘' />\n                    • 위드메이트 서비스는 후불제이며, 모든 서비스가 종료된 이후 최종 요금 안내에 따라 [계좌이체] 또는 [카드결제]를 통한 결제를 진행해주시면\n                    됩니다.\n                    <br />• [카드결제]를 이용하실 경우 [마이페이지]에서 사용하실 카드를 등록하시면 편리하게 카드 정보로 결제하실 수 있습니다.\n                </DashAndText>\n\n                <DivisionLine />\n\n                <DashAndText>\n                    <img src='/assets/images/w_check.png' alt='아이콘' />\n                    <span>\n                        • [카드결제]는 [페이투페이]의 <a>수기결제</a>로 카드결제가 진행됩니다. <br />• 카드 정보는 서비스 비용 결제 목적으로만 이용되며, 그 외\n                        다른 목적으로 이용되거나 제3자에게 제공되는 일은 절대 없습니다.\n                    </span>\n                </DashAndText>\n\n                <DivisionLine />\n\n                <DashAndText>\n                    <img src='/assets/images/w_check.png' alt='아이콘' />\n                    이동 수단 중 [자차 이동]을 선택한 경우 예약일에 맞춰 차량 보험을 예약자 또는 본인이 직접 [누구나 보험]으로 변경해주셔야 합니다.\n                </DashAndText>\n\n                <DivisionLine />\n\n                <DashAndText>\n                    <img src='/assets/images/w_check.png' alt='아이콘' />\n                    택시비와 진료비 등의 부가 비용은 고객님께서 부담해주셔야 합니다.\n                </DashAndText>\n\n                <DivisionLine />\n\n                <DashAndText>\n                    <img src='/assets/images/w_pin.png' alt='아이콘' />\n                    <span>\n                        서비스에 대한 추가 문의 사항은 <a>FAQ</a>에서 확인 가능합니다. 위드메이트 상담 센터 운영 시간은 월 ~ 금 09:00 ~ 18:00 입니다.\n                    </span>\n                </DashAndText>\n\n                <DivisionLine />\n\n                <DashAndText alert>\n                    <img src='/assets/images/w_alert.png' alt='아이콘' />\n                    위드메이트는 플랫폼 내 전문 인력 스스로 매칭 신청을 검토하므로, 매칭 신청을 하시더라도 최종 매칭에 실패할 가능성이 있음을 알려드립니다.\n                </DashAndText>\n                <MobileStepImage>\n                    <img src={service === 'unemergency' ? '/assets/images/art_pro.png' : '/assets/images/art_basic.png'} alt='스텝이미지' />\n                </MobileStepImage>\n            </ResultFormWrapper>\n        </FlexFormWrapper>\n    );\n};\n\nconst DoneForm = ({ data }) => {\n    const { usePoint, point, transport, reserveDate, reserveTime, reserveMinute, productInfo, service, addTime } = data;\n\n    const _transport = transport && transport === 'own' ? 20000 : 0;\n    const _service =\n        productInfo && service && (service === 'unemergency' ? productInfo.proPrice : productInfo.basicPrice ? productInfo.basicPrice : 0) * addTime;\n\n    const _point = (usePoint || 0) * -1;\n    const discount = service === 'unemergency' ? productInfo.proDiscount || 0 : productInfo.basicDiscount || 0;\n\n    const totalFee = _transport + _service + _point - discount;\n\n    return (\n        <FormWrapper>\n            <ServiceTypeName style={{ marginTop: '0px', marginBottom: '0px' }}>매칭 신청이 완료되었어요!</ServiceTypeName>\n            <CongraturateLogo>\n                <img src='/assets/images/artwork_festival.png' alt='예약완료' />\n            </CongraturateLogo>\n\n            <DoneResultWrapper>\n                <LabelAndValueRow borderColor='#cecfd0'>\n                    <LabelValue>신청일자</LabelValue>\n                    <PriceDetailValue style={{ color: 'rgba(0,0,0,0.7)' }}>\n                        {moment(combineDateAndTime({ date: reserveDate, time: reserveTime, minute: reserveMinute })).format('YYYY-MM-DD HH시 mm분')}\n                    </PriceDetailValue>\n                </LabelAndValueRow>\n                <LabelAndValueRow borderColor='#cecfd0'>\n                    <LabelValue>선택하신 서비스</LabelValue>\n                    <PriceDetailValue style={{ color: 'rgba(0,0,0,0.7)' }}>\n                        {productInfo.name} {productInfo.name.includes('내시경') ? '' : service === 'unemergency' ? 'Pro' : 'Basic'}\n                    </PriceDetailValue>\n                </LabelAndValueRow>\n                <LabelAndValueRow borderColor='#cecfd0'>\n                    <LabelValue>총 예상 비용</LabelValue>\n                    <ServiceName style={{ marginBottom: '0px' }}>{totalFee}</ServiceName>\n                </LabelAndValueRow>\n                <LabelAndValueRow>\n                    <PriceDetailLabel>\n                        <span>ㄴ</span>사용된 포인트\n                    </PriceDetailLabel>\n                    <PriceDetailValue>{data.usePoint}원</PriceDetailValue>\n                </LabelAndValueRow>\n                <LabelAndValueRow>\n                    <PriceDetailLabel>\n                        <span>ㄴ</span>잔여 포인트\n                    </PriceDetailLabel>\n                    <PriceDetailValue>{point - usePoint}원</PriceDetailValue>\n                </LabelAndValueRow>\n                <LabelAndValueRow>\n                    <PriceDetailLabel>\n                        <span>ㄴ</span>결제 수단\n                    </PriceDetailLabel>\n                    <PriceDetailValue value>{data.payment === 'card' ? '카드결제' : '계좌이체'}</PriceDetailValue>\n                </LabelAndValueRow>\n            </DoneResultWrapper>\n\n            <DivisionLine />\n            <ServiceTypeName style={{ marginTop: '0px', marginBottom: '0px' }}>서비스 안내 사항</ServiceTypeName>\n            <DivisionLine />\n\n            <DashAndText>\n                <img src='/assets/images/w_check.png' alt='아이콘' />\n                위드메이트 서비스는 후불제이며, 모든 서비스가 종료된 이후 최종 요금 안내에 따라 계좌 이체를 통한 결제를 진행해주시면 됩니다.\n            </DashAndText>\n\n            <DivisionLine />\n\n            <DashAndText>\n                <img src='/assets/images/w_check.png' alt='아이콘' />\n                이동 수단 중 ‘자차 이동’을 선택한 경우 예약일에 맞춰 차량 보험을 예약자 또는 본인이 직접 ‘누구나 보험’으로 변경해주셔야 합니다.\n            </DashAndText>\n\n            <DivisionLine />\n\n            <DashAndText>\n                <img src='/assets/images/w_check.png' alt='아이콘' />\n                택시비와 진료비 등의 부가 비용은 고객님께서 부담해주셔야 합니다.\n            </DashAndText>\n\n            <DivisionLine />\n\n            <DashAndText>\n                <img src='/assets/images/w_pin.png' alt='아이콘' />\n                <span>\n                    서비스에 대한 추가 문의 사항은 <a>FAQ</a>에서 확인 가능합니다. 위드메이트 상담 센터 운영 시간은 월 ~ 금 09:00 ~ 18:00 입니다.\n                </span>\n            </DashAndText>\n\n            <DivisionLine />\n\n            <DashAndText alert>\n                <img src='/assets/images/w_alert.png' alt='아이콘' />\n                위드메이트는 플랫폼 내 전문 인력 스스로 매칭 신청을 검토하므로, 매칭 신청을 하시더라도 최종 매칭에 실패할 가능성이 있음을 알려드립니다.\n            </DashAndText>\n        </FormWrapper>\n    );\n};\n\nconst CustomButtonWrapper = styled(ButtonWrapper)`\n    max-width: 640px;\n    margin: 0 auto;\n\n    @media (max-width: 480px) {\n        flex-direction: column;\n\n        > a:first-child {\n            order: 2;\n            margin-bottom: 48px;\n        }\n\n        > a:last-child {\n            order: 1;\n        }\n    }\n`;\n","import React from 'react';\nimport { debounce } from 'lodash';\nimport styled from 'styled-components';\nimport { message, Spin } from 'antd';\nimport _ from 'lodash';\n\n// components\nimport { NoCatchedList } from '../../../../Components/User/Mate/reserve';\nimport { MateReserveInfoModal } from '../../../../Components/modal';\n\n// utils\nimport axios from '../../../../Lib/axios';\n\nclass Reserve extends React.PureComponent {\n    state = {\n        reserveModal: false,\n        reserveInfo: null,\n        refreshing: false,\n        list: [],\n    };\n\n    componentDidMount = () => {\n        this.fetchList();\n    };\n\n    fetchList = debounce(() => {\n        const mateId = localStorage.getItem('id');\n\n        this.setState(\n            {\n                refreshing: true,\n            },\n            () => {\n                axios\n                    .get('/v2/service/mate/reserve/list', {\n                        params: {\n                            mateId,\n                        },\n                    })\n                    .then(resolve => {\n                        const { data: list } = resolve;\n                        if (list && Array.isArray(list)) {\n                            this.setState({ list, refreshing: false });\n                        }\n                    })\n                    .catch(error => {\n                        this.setState({ refreshing: false });\n                    });\n            },\n        );\n    }, 300);\n\n    onCatchCall = () => {\n        const { reserveInfo } = this.state;\n        const { id } = this.props.auth;\n\n        if (!reserveInfo || !reserveInfo.call || !reserveInfo.call._id) {\n            this.setState({ reserveInfo: null, reserveModal: false });\n            message.warning('유효하지않은 예약내역입니다. 다른 예약내역을 확인해주세요.');\n            return null;\n        }\n\n        axios\n            .put('/v2/service/catch/call', {\n                callId: reserveInfo.call._id,\n                mateId: id,\n            })\n            .then(resolve => {\n                const { data: result } = resolve;\n                if (!result) return message.warning('요청에 실패했습니다.');\n                if (result === 'invalid call') return message.warning('잘못된 요청입니다.');\n                if (result === 'already catched') return message.warning('이미 접수된 요청입니다.');\n                if (result === 'denied') return message.warning('예약자에 의해 거절 당하셨거나 혹은 메이트님이 직접 해당 내역을 수신거부 하셨습니다.');\n                if (result === 'success') {\n                    message.success('예약 접수 요청완료');\n                    this.setState({ reserveModal: false, reserveInfo: null }, () => {\n                        this.fetchList();\n                    });\n                }\n            })\n            .catch(error => {\n                message.warning('요청에 실패했습니다.');\n            });\n    };\n\n    render() {\n        const { list } = this.state;\n\n        return (\n            <>\n                <NoCatchedList\n                    data={this.state}\n                    list={list}\n                    onRefresh={this.fetchList}\n                    detailHandler={info => {\n                        this.setState({ reserveModal: true, reserveInfo: info });\n                    }}\n                />\n\n                {this.state.reserveModal ? (\n                    <MateReserveInfoModal\n                        info={this.state.reserveInfo}\n                        visibleHandler={() => {\n                            this.setState({\n                                reserveModal: false,\n                                reserveInfo: null,\n                            });\n                        }}\n                        onCatch={this.onCatchCall}\n                    />\n                ) : null}\n\n                {this.state.refreshing ? (\n                    <SpinWrapper>\n                        <Spin size='large' />\n                    </SpinWrapper>\n                ) : null}\n            </>\n        );\n    }\n}\n\nconst SpinWrapper = styled.div`\n    position: fixed;\n    top: 0px;\n    left: 0px;\n    width: 100vw;\n    height: 100vh;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n\n    z-index: 9999\n    background-color: rgba(0, 0, 0, 0.6);\n`;\n\nexport default Reserve;\n","import { message } from 'antd';\nimport React from 'react';\nimport styled from 'styled-components';\nimport swal from 'sweetalert2';\nimport SwiperCore, { Pagination, Navigation, Autoplay } from 'swiper';\nimport 'swiper/swiper-bundle.min.css';\nimport 'swiper/swiper.min.css';\nimport 'swiper/components/navigation/navigation.min.css';\nimport 'swiper/components/pagination/pagination.min.css';\n\nSwiperCore.use([Navigation, Pagination, Autoplay]);\n\nexport const UserMain = ({ history }) => {\n    return (\n        <UserMainContainer>\n            <UserMainInnerContainer>\n                <WithmateSpecRow>\n                    <img src='/assets/images/collaboration/withmate_metlife_main.png' style={{ paddingTop: '40px', width: '380px' }} alt='메인 이미지' />\n                </WithmateSpecRow>\n                <BottomSection>\n                    <HighLight>\n                        메트라이프 360Future <br />\n                        회원만을 위한 <br />\n                        <p style={{ fontSize: '30px', color: '#3bc1ff' }}>병원동행서비스</p>\n                    </HighLight>\n                    <ButtonWrapper>\n                        <ReserveButton\n                            onClick={() => {\n                                window.open('https://play.google.com/store/apps/details?id=com.bluecamel.withmate');\n                            }}\n                        >\n                            위드메이트 이용하기\n                        </ReserveButton>\n                        <ReserveButton\n                            onClick={() => {\n                                if (!localStorage.getItem('id')) {\n                                    message.warning('병원 동행서비스 예약을 이용하시려면 회원가입 후 이용해주세요.');\n                                    return history.push('/user/register?url_source=metlife');\n                                }\n\n                                history.push('/reserve/items');\n                            }}\n                        >\n                            동행서비스 예약\n                            <img src='/assets/images/main_right_blue.png' alt='방향표' />\n                        </ReserveButton>\n                        <div style={{ paddingBottom: '8px' }} />\n                        <CallButton\n                            onClick={() => {\n                                swal.fire({\n                                    title: '위드메이트 고객센터',\n                                    text: '☎ 070-4300-9075',\n                                    icon: 'info',\n                                    confirmButtonText: '전화걸기',\n                                    cancelButtonText: '확인',\n                                    showCancelButton: true,\n                                }).then(result => {\n                                    if (result.isConfirmed) {\n                                        document.location.href = 'tel:070-4300-9075';\n                                    }\n                                });\n                            }}\n                        >\n                            전화 상담하기\n                            <img src='/assets/images/icons/phone.png' alt='전화기' />\n                        </CallButton>\n                    </ButtonWrapper>\n                </BottomSection>\n            </UserMainInnerContainer>\n        </UserMainContainer>\n    );\n};\n\nconst UserMainContainer = styled.div`\n    width: 100%;\n    height: 628px;\n\n    background: linear-gradient(to top, #ffffff, #eeeeee);\n\n    @media (max-width: 768px) {\n        // height: 598px;\n        height: 650px;\n    }\n`;\n\nconst UserMainInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    height: 100%;\n    margin: 0 auto;\n\n    background-image: url('/assets/images/w_main.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: 72px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        padding-top: 52px;\n        align-items: center;\n        background: transparent;\n    }\n`;\n\nconst WithmateSpecRow = styled.div`\n    display: flex;\n    align-items: flex-end;\n\n    font-size: 32px;\n    font-stretch: normal;\n    font-style: normal;\n    font-weight: 300;\n    line-height: 1.48;\n    letter-spacing: -0.7px;\n    text-align: left;\n    color: #ffffff;\n\n    > span {\n        font-size: 32px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.5;\n        letter-spacing: -0.7px;\n        text-align: left;\n        color: #ffffff;\n\n        margin-left: 4px;\n    }\n\n    > span.big {\n        font-size: 64px;\n        line-height: 1.2;\n        position: relative;\n        margin-right: 6px;\n\n        > d {\n            font-size: 28px;\n            position: absolute;\n            top: -16px;\n            left: calc(50% - 12px);\n        }\n    }\n\n    > span.normal {\n        font-size: 40px;\n        line-height: 1.2;\n        position: relative;\n        margin-right: 6px;\n\n        > d {\n            font-size: 18px;\n            position: absolute;\n            top: -16px;\n            left: calc(50% - 12px);\n        }\n    }\n\n    margin-bottom: 4px;\n\n    @media (max-width: 768px) {\n        margin-bottom: 8px;\n\n        font-size: 22px;\n\n        > span {\n            font-size: 22px;\n        }\n\n        > span.big {\n            font-size: 48px;\n            line-height: 1.2;\n            position: relative;\n            margin-right: 4px;\n\n            > d {\n                font-size: 20px;\n                position: absolute;\n                top: -16px;\n                left: calc(50% - 8px);\n            }\n        }\n    }\n`;\n\nconst BottomSection = styled.div`\n    margin-top: 28px;\n\n    @media (max-width: 768px) {\n        margin-top: 43px;\n    }\n`;\n\nconst HighLight = styled.p`\n    font-size: 28px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.75;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: black;\n\n    margin-bottom: 64px;\n\n    @media (max-width: 768px) {\n        text-align: center;\n    }\n`;\n\nconst ButtonWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n\n        > div:first-child {\n            margin-bottom: 8px;\n        }\n    }\n`;\n\nconst ButtonCommon = styled.div`\n    display: flex;\n    padding: 20px 24px;\n    width: 210px;\n    align-items: center;\n    justify-content: space-between;\n\n    border-radius: 4px;\n    margin-right: 8px;\n    cursor: pointer;\n\n    > img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n    }\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n\n    &:hover {\n        box-shadow: 4px 10px 24px -4px rgba(0, 0, 0, 0.1);\n        transition: all 0.3s;\n    }\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst GPButtonCommon = styled.div`\n    display: flex;\n    padding: 20px 24px;\n    width: 210px;\n    align-items: center;\n\n    border-radius: 4px;\n    margin-right: 8px;\n    cursor: pointer;\n\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n\n    &:hover {\n        box-shadow: 4px 10px 24px -4px rgba(0, 0, 0, 0.1);\n        transition: all 0.3s;\n    }\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst ReserveButton = styled(ButtonCommon)`\n    background-color: #ffffff;\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst CallButton = styled(ButtonCommon)`\n    border: 1px solid #ffffff;\n\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    background-color: white;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst GooglePlayButton = styled(GPButtonCommon)`\n    background-color: #ffffff;\n    border-color: #ffffff;\n    border-style: solid;\n    font-size: 18px;\n    font-weight: bold;\n    font-style: normal;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n    height: 60px;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const UserGuideSection = () => {\n    return (\n        <UserGuideContainer>\n            <UserGuideInnerContainer>\n                <UserGuideTitle>서비스 이용 방법</UserGuideTitle>\n                <UserGuideStepWrapper>\n                    <TextStep>서비스 신청</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>동행 인력 매칭</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>병원 방문</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>서비스 결과 확인</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>후불 결제</TextStep>\n                    <ImgStep src='/assets/images/main_right_gray.png' alt='방향표' />\n                    <TextStep>혜택 적립</TextStep>\n                </UserGuideStepWrapper>\n\n                <MainStepRow>\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_1.png'\n                        description={`위드메이트 플랫폼에 회원 가입 후\\n병원 동행 서비스 종류를 선택하고\\n신청해주세요!`}\n                        num='01'\n                        name='신청하세요!'\n                    />\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_2.png'\n                        description={`접수하신 서비스는 24시간 내에\\n매칭 가능 여부가 결정됩니다. 동행 인력이\\n매칭을 시도하면 고객님께서 매칭 수락\\n여부를 결정하시면 됩니다!`}\n                        num='02'\n                        name='매칭되세요!'\n                    />\n                    <MainStep\n                        className='uniq'\n                        mArrow\n                        source='/assets/images/main_step_3.png'\n                        description={`동행 인력 매칭 성공 후 예정된 진료일에\\n병원에 다녀오세요! 병원에서 하실 일은\\n진료를 받는 것 밖에 없습니다.\\n진료 동행, 보호자 대행, 병원 행정 보조 등\\n 나머지는 위드메이트가 해드립니다.`}\n                        num='03'\n                        name='다녀오세요!'\n                    />\n                </MainStepRow>\n\n                <MainStepRow>\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_4.png'\n                        description={`위드메이트는 동행 서비스 진행 과정을\\n실시간 카카오 알림톡으로 알려드리고,\\n서비스 종료 후 진료 결과와 특이사항 등의\\n내용이 정리된 서비스 리포트를 제공합니다`}\n                        num='04'\n                        name='확인하세요!'\n                    />\n                    <MainStep\n                        webArrow\n                        mArrow\n                        source='/assets/images/main_step_5.png'\n                        description={`위드메이트는 정확한 시간 계산이 불가능한\\n병원 진료 특성상, 서비스 요금의 투명성을\\n위해 후불 결제를 진행하고 있습니다.\\n서비스 시간은 초 단위로 자동 계산되니,\\n안심하고 서비스를 받으세요!`}\n                        num='05'\n                        name='후불이에요!'\n                    />\n                    <MainStep\n                        source='/assets/images/main_step_6.png'\n                        description={`회원 가입만 해도 2,000 포인트를\\n지급해드리며, 매번 서비스 후기 작성을\\n할 때마다 최대 3,000 포인트를 지급해드려요!\\n적립된 포인트로 더 저렴하게 서비스를\\n이용해보세요!`}\n                        num='06'\n                        name='받아가세요!'\n                    />\n                </MainStepRow>\n            </UserGuideInnerContainer>\n        </UserGuideContainer>\n    );\n};\n\nconst MainStep = ({ webArrow, mArrow, source, num, name, description, className }) => {\n    return (\n        <MainStepWrapper className={className || ''}>\n            <MainStepImageSection>\n                <img className='bg' src={source} alt='thumbnail' />\n            </MainStepImageSection>\n\n            <MainStepTextSection>\n                <StepIndex>{num}</StepIndex>\n                <StepTitle>{name}</StepTitle>\n                <StepDescription>\n                    {description.split('\\n').map((word, index) => (\n                        <span key={'word-break-down-' + index.toString() + num}>\n                            {word}\n                            <KeepBr />\n                        </span>\n                    ))}\n                </StepDescription>\n            </MainStepTextSection>\n            <img className={`arrow ${webArrow && 'web'} ${mArrow && 'mobile'}`} src='/assets/images/w_main_stepper.png' />\n        </MainStepWrapper>\n    );\n};\n\nconst UserGuideContainer = styled.div`\n    width: 100%;\n\n    background-color: #ffffff;\n\n    padding-top: 103px;\n    padding-bottom: 162px;\n\n    @media (max-width: 768px) {\n        padding-top: 90px;\n        padding-bottom: 130px;\n    }\n`;\n\nconst UserGuideInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    margin: 0 auto;\n`;\n\nconst UserGuideTitle = styled.h4`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-top: 0px;\n    margin-bottom: 32px;\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        line-height: 1.42;\n        letter-spacing: -0.1px;\n        margin-bottom: 24px;\n    }\n`;\n\nconst UserGuideStepWrapper = styled.div`\n    width: 100%;\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n\n    margin-bottom: 90px;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        margin-bottom: 77px;\n    }\n`;\n\nconst TextStep = styled.span`\n    font-size: 15px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.33;\n    letter-spacing: normal;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.6);\n`;\n\nconst ImgStep = styled.img`\n    margin-left: 16px;\n    margin-right: 16px;\n\n    width: 24px;\n    height: 24px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        transform: rotate(90deg);\n\n        width: 16px;\n        height: 16px;\n\n        margin-left: 0px;\n        margin-right: 0px;\n\n        margin-top: 8px;\n        margin-bottom: 8px;\n    }\n`;\n\nconst MainStepRow = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    > div:first-child {\n        border-left: 0px;\n    }\n\n    > div:last-child {\n        border-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n\n        > div:last-child {\n            border-bottom: 0px;\n        }\n\n        > div.uniq {\n            border-bottom: 1px solid #f2f2f2;\n        }\n    }\n`;\n\nconst MainStepWrapper = styled.div`\n    padding-left: 47px;\n    padding-right: 52px;\n    border-right: 1px solid #f2f2f2;\n\n    position: relative;\n\n    > img.arrow {\n        width: 24px;\n        height: 24px;\n\n        position: absolute;\n        top: calc(90px - 12px);\n        right: -11.5px;\n\n        display: none;\n    }\n\n    > img.mobile {\n        display: none;\n    }\n\n    > img.web {\n        display: block;\n    }\n\n    @media (max-width: 768px) {\n        border-right: 0px;\n        border-bottom: 1px solid #f2f2f2;\n\n        > img.arrow {\n            width: 24px;\n            height: 24px;\n\n            top: unset;\n            right: unset;\n            bottom: -10px;\n            left: calc(50% - 12px);\n\n            transform: rotate(90deg);\n        }\n\n        > img.web {\n            display: none;\n        }\n\n        > img.mobile {\n            display: block;\n        }\n    }\n\n    @media (max-width: 768px) {\n        padding-right: 0px;\n        padding-left: 0px;\n        padding-bottom: 44px;\n    }\n`;\n\nconst MainStepImageSection = styled.div`\n    width: 288px;\n    height: 180px;\n\n    margin-bottom: 24px;\n\n    > img.bg {\n        width: 100%;\n        height: 100%;\n        object-fit: contain;\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n        text-align: center;\n    }\n`;\n\nconst MainStepTextSection = styled.div`\n    display: flex;\n    align-items: center;\n    flex-direction: column;\n`;\n\nconst StepIndex = styled.span`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.43;\n    letter-spacing: normal;\n    text-align: center;\n    color: #afb0b2;\n    margin-bottom: 8px;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst StepTitle = styled.span`\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    margin-bottom: 24px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst StepDescription = styled.span`\n    font-size: 15px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: -0.3px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-size: 15px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.57;\n        letter-spacing: -0.3px;\n        text-align: center;\n        color: rgba(0, 0, 0, 0.7);\n    }\n    word-break: keep-all;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst KeepBr = styled.br`\n    display: block;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n","import styled from 'styled-components';\nimport { mainColor, sizeHandler } from '../../../theme';\n\nconst HomeStyledContainer = styled.div`\n    padding-top: 55px;\n\n    .center-title {\n        text-align: center;\n        margin-bottom: 28px;\n\n        > p {\n            height: 52px;\n            line-height: 52px;\n            margin-bottom: 0px;\n            font-size: 28px;\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n        }\n    }\n\n    .ant-collapse > .ant-collapse-item > .ant-collapse-header {\n        padding: 0px;\n    }\n\n    .ant-collapse-borderless > .ant-collapse-item {\n        border: 0px;\n    }\n\n    .ant-collapse-content > .ant-collapse-content-box {\n        padding: 0px;\n        padding-top: 4px;\n        padding-bottom: 12px;\n    }\n\n    .fake-input {\n        width: 100%;\n        height: 36px;\n        border-radius: 4px;\n        border: 1px solid #e6e6e6;\n    }\n\n    .main-section {\n        position: relative;\n        width: 100%;\n        height: 100vh;\n        max-height: 628px;\n        // min-height: calc(100vh - 55px);\n\n        // background-color: #ebf9ff;\n        // background-image: url('/assets/images/new_mainbg.png');\n        background-color: linear-gradient(to top, #3bc1ff, #5b62f5);\n        background-image: url('/assets/images/w_main.png');\n        background-size: cover;\n        background-repeat: no-repeat;\n        background-position: center;\n\n        @media (max-width: 768px) {\n            background-image: url('/assets/images/new_mainbg-mobile.png');\n            min-height: 86vh;\n\n            .inner-container {\n                padding: 0px;\n                padding-bottom: 30px;\n                min-height: 86vh;\n\n                display: flex;\n                align-items: flex-end;\n                justify-content: flex-end;\n            }\n        }\n\n        .ant-input[disabled] {\n            color: rgba(0, 0, 0, 0.7);\n        }\n        .ant-input {\n            font-size: 12px;\n        }\n\n        .order-menu-wrapper {\n            width: 50%;\n            position: relative;\n            max-width: 440px;\n            min-width: 370px;\n            background-color: white;\n            border-radius: 8px;\n            box-shadow: 1px 2px 3.5px #e6e6e6;\n            padding: 32px;\n\n            .mobile-close-button {\n                display: none;\n            }\n\n            @media (max-width: 768px) {\n                display: none;\n\n                &.active {\n                    display: block;\n                }\n\n                margin: 0px auto;\n                position: fixed;\n                z-index: 99;\n                top: 55px;\n                left: 0px;\n                width: 100%;\n                max-width: 100%;\n                height: calc(100vh - 55px);\n                overflow: scroll;\n                border-radius: 0px;\n\n                .mobile-close-button {\n                    display: block;\n                    position: absolute;\n                    top: 16px;\n                    right: 24px;\n                    padding: 6px;\n                    cursor: pointer;\n\n                    img {\n                        width: 18px;\n                        height: 18px;\n                    }\n                }\n\n                &.blocked {\n                    z-index: 0;\n                    position: relative;\n                    height: auto;\n                    overflow: auto;\n                }\n            }\n\n            .order-title {\n                margin-bottom: 20px;\n\n                p {\n                    margin: 0px;\n                    padding: 0px;\n                    font-size: ${sizeHandler(28)};\n                    font-weight: bold;\n                    letter-spacing: -0.7px;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n            }\n\n            .service {\n                margin-bottom: 20px;\n\n                .time-checker {\n                    width: calc(50% - 4px);\n                }\n\n                .time-checker.margin {\n                    margin-right: 8px;\n                }\n\n                .search-button {\n                    position: absolute;\n                    top: 1px;\n                    right: 1px;\n                    background-color: #ececec;\n                    height: 34px;\n                    width: 50px;\n                    border-top-right-radius: 4px;\n                    border-bottom-right-radius: 4px;\n\n                    font-size: 12px;\n                    line-height: 34px;\n                    text-align: center;\n                    cursor: pointer;\n                    color: rgba(0, 0, 0, 0.4);\n                }\n\n                .service-tab {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                    border: 1px solid #ddd;\n                    border-radius: 6px;\n\n                    .tab {\n                        flex: 1;\n                        height: 48px;\n                        border-right: 1px solid #ddd;\n                        cursor: pointer;\n                        display: flex;\n                        justify-content: center;\n                        align-items: center;\n\n                        &:last-child {\n                            border: 0px;\n                        }\n\n                        span {\n                            font-size: ${sizeHandler(14)};\n                            letter-spacing: -0.2px;\n                            font-weight: bold;\n                            color: ${mainColor};\n                        }\n                    }\n\n                    .tab.active {\n                        background-color: ${mainColor};\n\n                        span {\n                            color: white;\n                        }\n                    }\n                }\n\n                .info-tab {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n\n                    p {\n                        flex: 1;\n                        margin: 0px;\n                        padding: 0px;\n                        text-align: left;\n\n                        &:first-child {\n                            margin-right: 8px;\n                        }\n                    }\n                }\n\n                .info-input-tab {\n                    display: flex;\n                    align-items: center;\n\n                    > div {\n                        flex: 1;\n\n                        &:first-child {\n                            margin-right: 8px;\n                        }\n                    }\n\n                    .name-wrapper {\n                        position: relative;\n\n                        .sex-type-wrapper {\n                            position: absolute;\n                            top: 1px;\n                            right: 1px;\n                            z-index: 3;\n                            background-color: white;\n\n                            .sex-type {\n                                display: inline-block;\n                                width: 34px;\n                                height: 34px;\n                                line-height: 36px;\n                                text-align: center;\n                                border-left: 1px solid #e6e6e6;\n\n                                font-size: ${sizeHandler(14)};\n                                font-weight: normal;\n                                letter-spacing: -0.2px;\n                                color: rgba(0, 0, 0, 0.2);\n                                cursor: pointer;\n\n                                &:hover {\n                                    color: rgba(0, 0, 0, 0.3);\n                                    transition: all 0.3s;\n                                }\n\n                                &.active {\n                                    color: ${mainColor};\n                                }\n                            }\n                        }\n                    }\n\n                    .input {\n                        flex-grow: 1;\n                        display: flex;\n                        min-width: 0;\n                        align-items: center;\n\n                        border-radius: 4px;\n                        border: solid 1px #e6e6e6;\n                        min-height: 36px;\n                        line-height: 36px;\n                        text-indent: 12px;\n                        font-size: ${sizeHandler(12)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        background-color: #f5f5f5;\n                        cursor: not-allowed;\n\n                        p {\n                            white-space: nowrap;\n                            text-overflow: ellipsis;\n                            overflow: hidden;\n                        }\n\n                        // .ant-input {\n                        //     color: rgba(0, 0, 0, 0.8);\n                        // }\n\n                        &.phone {\n                            flex: 0.5;\n\n                            @media (max-width: 768px) {\n                                flex: 1;\n                            }\n                        }\n\n                        &.input-with-icon {\n                            p {\n                                height: 100%;\n                                flex: 1;\n                                text-overflow: ellipsis;\n                                overflow: hidden;\n                                white-space: nowrap;\n                            }\n\n                            div {\n                                height: 100%;\n                                width: 36px;\n                                border-left: 1px solid #e6e6e6;\n                                display: flex;\n                                justify-content: center;\n                                align-items: center;\n\n                                span {\n                                    text-align: center;\n                                    text-indent: 0px;\n                                    // opacity: 0.3;\n                                    font-size: ${sizeHandler(12)};\n                                    letter-spacing: -0.3px;\n                                    color: rgba(0, 0, 0, 0.8);\n\n                                    img {\n                                        width: 18px;\n                                    }\n                                }\n                            }\n                        }\n                    }\n                }\n\n                .service-fee-wrapper {\n                    margin-bottom: 32px;\n\n                    .service {\n                        display: flex;\n                        align-items: center;\n                        padding-top: 12px;\n                        margin-bottom: 0px;\n\n                        .name {\n                            flex: 1;\n                            font-size: ${sizeHandler(14)};\n                            letter-spacing: -0.3px;\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n\n                        .fee {\n                            font-size: ${sizeHandler(14)};\n                            font-weight: bold;\n                            text-align: right;\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n                    }\n                }\n\n                input {\n                    height: 36px;\n                    display: inline-block;\n                    width: 100%;\n                    overflow: hidden;\n                    text-overflow: ellipsis;\n                    white-space: nowrap;\n                }\n\n                .ant-input-number-input-wrap {\n                    height: 100%;\n\n                    .ant-input-number-input {\n                        height: 100%;\n                    }\n\n                    input {\n                        height: 100%;\n                    }\n                }\n\n                .select {\n                    display: inline-block;\n                    height: 36px;\n                    width: 100%;\n\n                    .ant-select-selection--single {\n                        height: 100%;\n                    }\n\n                    .ant-select-selection__rendered {\n                        line-height: 36px;\n                    }\n                }\n\n                .info {\n                    font-size: ${sizeHandler(12)};\n                    color: rgba(0, 0, 0, 0.7);\n                    margin-bottom: 4px;\n                    letter-spacing: -0.15px;\n                }\n\n                .ant-select-selection__rendered {\n                    margin-right: 34px;\n                    border-right: 1px solid #e6e6e6;\n                }\n\n                .ant-select-arrow {\n                    color: ${mainColor};\n                }\n\n                .image-with-text {\n                    display: flex;\n                    align-items: center;\n                    img {\n                        height: 18px;\n                        border: 0px;\n                    }\n\n                    p {\n                        flex: 1;\n                        margin: 0px;\n                        padding: 0px;\n                        margin-left: 12px;\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        color: #3bc1ff;\n                    }\n                }\n            }\n\n            .side-summary-tab {\n                position: absolute;\n                top: 0px;\n                right: -380px;\n                width: 360px;\n                height: 100%;\n                background-color: white;\n                border-radius: 8px;\n                box-shadow: 1px 2px 3.5px #e6e6e6;\n                padding: 32px;\n                overflow: hidden;\n                display: flex;\n                flex-direction: column;\n\n                @media (max-width: 768px) {\n                    width: 100%;\n                    height: auto;\n                    border-radius: 0px;\n                    box-shadow: none;\n                    padding: 0px;\n                    position: relative;\n                    top: 55px;\n                    left: 0px;\n                    background-color: transparent;\n                }\n\n                .refund-info-wrapper {\n                    flex: 1;\n                    display: flex;\n                    align-items: flex-end;\n\n                    .info-wrapper {\n                        width: 100%;\n\n                        .title {\n                            font-size: ${sizeHandler(12)};\n                            font-weight: bold;\n                            color: #a7a7a7;\n                            margin-bottom: 8px;\n                        }\n\n                        .info {\n                            font-size: ${sizeHandler(10)};\n                            line-height: ${sizeHandler(16)};\n                            color: rgba(0, 0, 0, 0.7);\n                        }\n\n                        @media (max-width: 768px) {\n                            margin-top: 36px;\n                            padding-bottom: 20px;\n\n                            .info {\n                                margin-bottom: 60px;\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .additional-fee {\n        p {\n            margin: 0px;\n            padding: 0px;\n            margin-top: 8px;\n            font-size: ${sizeHandler(10)};\n            color: rgba(0, 0, 0, 0.7);\n        }\n    }\n\n    .ant-input-number {\n        width: 100%;\n        height: 48px;\n\n        .ant-input-number-input-wrap {\n            height: 100%;\n\n            .ant-input-number-input {\n                height: 100%;\n            }\n\n            input {\n                height: 100%;\n            }\n        }\n\n        .ant-input-number-handler-wrap {\n            opacity: 1;\n            width: 48px;\n\n            span {\n                display: flex;\n                align-items: center;\n                justify-content: center;\n\n                i {\n                    position: relative;\n                    margin-top: 0px;\n                    left: 0px;\n                    top: 0px;\n                    bottom: 0px;\n                    right: 0px;\n                    font-size: 16px;\n                }\n            }\n            .anticon.anticon-up.ant-input-number-handler-up-inner {\n                color: ${mainColor};\n            }\n            .anticon.anticon-down.ant-input-number-handler-down-inner {\n                color: ${mainColor};\n            }\n        }\n    }\n\n    .total-fee-wrapper {\n        padding: 18px 0px;\n        border-top: 1px solid #e6e6e6;\n        border-bottom: 1px solid #e6e6e6;\n\n        .total-fee {\n            display: flex;\n            align-items: center;\n\n            .total-min {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                // font-weight: bold;\n                letter-spacing: -0.5px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            .fee-min {\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.5px;\n                text-align: right;\n                // font-weight: bold;\n                // color: #3bc1ff;\n\n                color: rgba(0, 0, 0, 0.7);\n            }\n\n            span.vat {\n                font-size: ${sizeHandler(11)};\n                color: #565656;\n            }\n        }\n\n        .total {\n            flex: 1;\n            font-size: ${sizeHandler(16)};\n            font-weight: bold;\n            letter-spacing: -0.5px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        .fee {\n            font-size: ${sizeHandler(16)};\n            font-weight: bold;\n            letter-spacing: -0.5px;\n            text-align: right;\n            color: #3bc1ff;\n        }\n    }\n\n    // 여기\n    .service-section {\n        .concept-container {\n            margin-bottom: 68px;\n\n            .concept-title {\n                font-size: 24px;\n                font-weight: bold;\n                line-height: 2.17;\n                letter-spacing: -0.67px;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 12px;\n            }\n\n            .concept-body {\n                font-size: 18px;\n                font-weight: normal;\n                line-height: 1.78;\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.8);\n\n                @media (max-width: 768px) {\n                    font-size: 16px;\n                }\n            }\n        }\n\n        .service-item:last-child {\n            border-top: 1px solid #e6e6e6;\n            margin-top: 96px;\n            padding-top: 96px;\n        }\n\n        .service-item {\n            .service-name {\n                p {\n                    font-size: ${sizeHandler(36)};\n                    font-weight: bold;\n                    letter-spacing: -1px;\n                    color: rgba(0, 0, 0, 0.8);\n\n                    position: relative;\n\n                    .stamp {\n                        margin-left: 20px;\n                        padding: 8px 12px;\n                        border-radius: 4px;\n                        background-color: #ff0052;\n                        font-size: 10px;\n                        font-weight: bold;\n                        text-align: center;\n                        color: #ffffff;\n\n                        position: absolute;\n                        bottom: 6px;\n                    }\n                }\n\n                margin-bottom: 12px;\n            }\n\n            .mobile {\n                display: none;\n            }\n\n            .desktop {\n                display: block;\n            }\n\n            .service-info {\n                display: flex;\n                align-items: center;\n\n                .service-photo {\n                    flex: 1;\n                    display: flex;\n                    align-items: center;\n                    justify-content: flex-start;\n                    padding-left: 60px;\n\n                    img {\n                        // height: 100%;\n                        width: 100%;\n                    }\n                }\n\n                .info-wrapper {\n                    flex: 2;\n\n                    .main-description {\n                        font-size: ${sizeHandler(18)};\n                        color: rgba(0, 0, 0, 0.8);\n                        letter-spacing: -0.3px;\n                        margin-bottom: 32px;\n\n                        @media (max-width: 768px) {\n                            font-size: 16px;\n                        }\n                    }\n\n                    .service-detail {\n                        display: flex;\n                        align-item: center;\n\n                        .target-price {\n                            // flex: ;\n                            min-width: 240px;\n\n                            .target {\n                                margin-bottom: 36px;\n                            }\n                        }\n\n                        .scheme {\n                            flex: 1;\n                            margin-left: 20px;\n\n                            .scheme-items {\n                                p {\n                                    font-size: ${sizeHandler(14)};\n                                    letter-spacing: -0.3px;\n                                    color: rgba(0, 0, 0, 0.7);\n                                    height: 38px;\n                                    line-height: 38px;\n                                    margin: 0px;\n                                    padding: 0px;\n                                    overflow: hidden;\n                                    text-overflow: ellipsis;\n                                    white-space: nowrap;\n                                }\n                                border-bottom: 1px solid #e6e6e6;\n                            }\n\n                            .ps {\n                                font-size: ${sizeHandler(14)};\n                                color: ${mainColor};\n                                // font-weight: bold;\n                                height: 28px;\n                                line-height: 28px;\n\n                                &:nth-child(2n-1) {\n                                    color: #ff5500;\n                                }\n                            }\n                        }\n                    }\n\n                    .detail-button-wrapper {\n                        min-width: 240px;\n                        margin-top: 40px;\n                        background-color: #606060;\n                        border-radius: 4px;\n                        height: 48px;\n                        cursor: pointer;\n\n                        p {\n                            width: 100%;\n                            height: 100%;\n                            text-align: center;\n                            line-height: 48px;\n                            font-size: ${sizeHandler(14)};\n                            color: white;\n                            font-weight: bold;\n                        }\n                    }\n\n                    .reserve-button-wrapper {\n                        flex: 1;\n\n                        margin-top: 40px;\n                        background-color: ${mainColor};\n                        border-radius: 4px;\n                        height: 48px;\n                        cursor: pointer;\n\n                        p {\n                            width: 100%;\n                            height: 100%;\n                            text-align: center;\n                            line-height: 48px;\n                            font-size: ${sizeHandler(14)};\n                            color: white;\n                            font-weight: bold;\n                        }\n                    }\n\n                    .title {\n                        font-size: ${sizeHandler(18)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-top: 36px;\n                        margin-bottom: 8px;\n                    }\n\n                    .content {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n\n                    .price-content {\n                        font-size: ${sizeHandler(16)};\n                        font-weight: bold;\n                        color: #606060;\n                        letter-spacing: -0.3px;\n                    }\n\n                    .info-container {\n                        .spec-title {\n                            font-size: 18px;\n                            font-weight: bold;\n                            line-height: 1.56;\n                            letter-spacing: normal;\n                            color: rgba(0, 0, 0, 0.8);\n                        }\n\n                        .spec-wrapper {\n                            padding: 8px 0px;\n                            border-bottom: 1px solid #e6e6e6;\n\n                            .spec-row {\n                                font-size: 14px;\n                                letter-spacing: -0.3px;\n                                color: rgba(0, 0, 0, 0.7);\n                                margin: 0px;\n                            }\n\n                            .spec-sub {\n                                font-size: 12px;\n                                letter-spacing: -0.26px;\n                                color: #a7a7a7;\n                                margin: 0px;\n                                margin-top: 4px;\n                            }\n                        }\n                    }\n\n                    .button-container {\n                        display: flex;\n                        align-items: center;\n                        margin-top: 32px;\n\n                        .button {\n                            border-radius: 4px;\n                            height: 48px;\n                            line-height: 48px;\n                            text-align: center;\n                            cursor: pointer;\n\n                            &.video-button {\n                                width: 285px;\n                                background-color: #606060;\n                                margin-right: 20px;\n\n                                &:hover {\n                                    transition: all 0.3s;\n                                    background-color: #707070;\n                                }\n                            }\n\n                            &.reserve-button {\n                                background-color: #3bc1ff;\n                                flex: 1;\n\n                                &:hover {\n                                    transition: all 0.3s;\n                                    background-color: #54c9ff;\n                                }\n                            }\n\n                            span {\n                                font-size: 14px;\n                                font-weight: bold;\n                                text-align: center;\n                                color: #ffffff;\n                            }\n                        }\n\n                        @media (max-width: 768px) {\n                            flex-direction: column;\n\n                            .button {\n                                width: 100% !important;\n                                margin-right: 0px !important;\n                                height: 40px;\n                                line-height: 40px;\n\n                                &:last-child {\n                                    margin-top: 16px;\n                                }\n                            }\n                        }\n                    }\n                }\n            }\n        }\n\n        @media (max-width: 768px) {\n            .service-item {\n                .service-name {\n                    p {\n                        font-size: ${sizeHandler(30)};\n\n                        .stamp {\n                            padding: 4px 8px;\n                            bottom: 8px;\n                        }\n                    }\n                }\n\n                .service-info {\n                    display: block;\n\n                    .service-photo {\n                        margin-top: 40px;\n                        padding-left: 0px;\n\n                        img {\n                            width: 100%;\n                        }\n                    }\n\n                    .info-wrapper {\n                        width: 100%;\n\n                        > p {\n                            font-size: ${sizeHandler(16)};\n                        }\n\n                        .service-detail {\n                            flex-direction: column;\n\n                            .service-photo {\n                                display: none;\n                            }\n\n                            .scheme {\n                                margin: 0px;\n                            }\n                        }\n\n                        .detail-button-wrapper {\n                            display: block;\n                            width: 100%;\n                            height: 40px;\n\n                            p {\n                                line-height: 40px;\n                            }\n                        }\n\n                        .reserve-button-wrapper {\n                            display: block;\n                            width: 100%;\n                            height: 40px;\n\n                            p {\n                                line-height: 40px;\n                            }\n                        }\n                        .mobile {\n                            display: block;\n                        }\n\n                        .desktop {\n                            display: none;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .reserve-section {\n        .menu-top {\n            display: flex;\n            align-items: flex-end;\n            margin-bottom: 16px;\n\n            .main-title {\n                flex: 1;\n                font-size: 28px;\n                font-weight: bold;\n                letter-spacing: -1px;\n                color: rgba(0, 0, 0, 0.8);\n            }\n\n            .sub-button {\n                color: ${mainColor};\n                font-weight: bold;\n                font-size: 14px;\n                cursor: pointer;\n            }\n        }\n\n        .menu-bottom {\n            .reserve-menu {\n                display: flex;\n                align-items: center;\n                justify-content: center;\n                padding: 20px;\n                margin-bottom: 12px;\n                border-radius: 4px;\n                box-shadow: 2px 2px 10px 3px rgba(0, 0, 0, 0.1);\n                background-color: #ffffff;\n\n                .title {\n                    color: #a7a7a7;\n                    font-size: ${sizeHandler(12)};\n                    font-weight: bold;\n                    margin: 0px;\n                    padding: 0px;\n                }\n\n                .contents {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: #606060;\n                    margin: 0px;\n                    padding: 0px;\n                    white-space: nowrap;\n                    overflow: hidden;\n                    text-overflow: ellipsis;\n                }\n\n                .service-name {\n                    flex: 0.7;\n                    .contents {\n                        color: ${mainColor};\n                    }\n                }\n\n                .user {\n                    flex: 0.5;\n                }\n\n                .date {\n                    flex: 0.7;\n                }\n\n                .hospital {\n                    flex: 1;\n                }\n\n                .status {\n                    flex: 0.4;\n                }\n\n                .button {\n                    flex: 0.5;\n                    > div {\n                        display: flex;\n                        height: 48px;\n                        border-radius: 4px;\n                        align-items: center;\n                        justify-content: center;\n                        border: 1px solid ${mainColor};\n                        cursor: pointer;\n                        transition: all 0.3s;\n\n                        span {\n                            font-size: ${sizeHandler(14)};\n                            font-weight: bold;\n                            color: ${mainColor};\n                        }\n\n                        &:hover {\n                            background-color: ${mainColor};\n                            span {\n                                color: white;\n                            }\n                        }\n                    }\n                }\n\n                .content.service {\n                    color: ${mainColor};\n                }\n            }\n            @media (max-width: 768px) {\n                .reserve-menu {\n                    flex-direction: column;\n                    align-items: flex-start;\n                    justify-content: flex-start;\n\n                    .contents {\n                        margin-bottom: 20px;\n                    }\n\n                    .button {\n                        width: 100%;\n                        > div {\n                            height: 40px;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .section-title {\n        padding-bottom: 16px;\n        border-bottom: 1px solid #ececec;\n        margin-bottom: 48px;\n\n        p {\n            font-size: ${sizeHandler(18)};\n            color: #a7a7a7;\n            font-weight: bold;\n            margin: 0px;\n            padding: 0px;\n            opacity: 1;\n        }\n    }\n\n    .order-menu-mobile-wrapper {\n        // position: absolute;\n        // bottom: 68px;\n        // left: 0;\n        display: flex;\n        justify-content: center;\n        align-items: center;\n        flex-direction: column;\n        width: 100%;\n        padding: 10px;\n\n        p {\n            text-align: center;\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: white;\n        }\n\n        p:nth-child(1) {\n            font-size: ${sizeHandler(14)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            text-align: center;\n            color: white;\n            lineheight: ${sizeHandler(20)};\n        }\n\n        button {\n            width: 100%;\n            height: 56px;\n            font-size: ${sizeHandler(16)};\n            font-weight: bold;\n            text-align: center;\n            color: #ffffff;\n            margin-top: 28px;\n        }\n\n        @media (min-width: 768px) {\n            display: none;\n        }\n    }\n`;\n\nexport default HomeStyledContainer;\n\nexport const UserMainContainer = styled.div`\n    width: 100%;\n    // min-height: calc(100vh - 55px);\n    // background-image: url('/assets/images/');\n\n    height: 100vh;\n    max-height: 628px;\n\n    background-color: linear-gradient(to top, #3bc1ff, #5b62f5);\n    background-image: url('/assets/images/w_main.png');\n\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    padding-top: calc((100vh - 55px) * 0.2);\n\n    @media (max-width: 768px) {\n        background-size: cover;\n        background-image: url('/assets/images/new_mainbg-mobile.png');\n\n        min-height: initial;\n        height: 600px;\n\n        padding-top: 354px;\n    }\n`;\n\nexport const InnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n    margin: 0 auto;\n\n    @media (max-width: 1120px) {\n        padding-left: 32px;\n        padding-right: 32px;\n    }\n\n    @media (max-width: 768px) {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n`;\n\nexport const UserMainTitle = styled.div`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 50px;\n    line-height: 66px;\n\n    letter-spacing: -1.44444px;\n\n    color: #ffffff;\n\n    position: relative;\n    margin-bottom: 16px;\n\n    @media (max-width: 768px) {\n        > br {\n            display: block;\n        }\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 22px;\n        line-height: 30px;\n\n        text-align: center;\n        color: #ffffff;\n\n        margin-bottom: 4px;\n    }\n`;\n\nexport const UserMainTitleDeco = styled.img`\n    position: absolute;\n\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const DecoRight = styled(UserMainTitleDeco)`\n    top: 0px;\n    left: 240px;\n\n    width: 32px;\n    height: 32px;\n`;\n\nexport const DecoLeft = styled(UserMainTitleDeco)`\n    top: 36px;\n    left: -60px;\n\n    width: 22px;\n    height: 22px;\n`;\n\nexport const DecoLeftTop = styled(UserMainTitleDeco)`\n    top: -52px;\n    left: -62px;\n\n    width: 62px;\n    height: 62px;\n`;\n\nexport const UserMainSubtitle = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 22px;\n    line-height: 30px;\n    color: rgba(255, 255, 255, 0.8);\n    letter-spacing: -0.4px;\n\n    margin-bottom: 44px;\n\n    @media (max-width: 768px) {\n        font-weight: normal;\n        font-size: 12px;\n        line-height: 22px;\n        letter-spacing: -0.3px;\n        text-align: center;\n\n        margin-bottom: 24px;\n    }\n`;\n\nexport const UserMainRoute = styled.div`\n    width: 100%;\n\n    @media (max-width: 768px) {\n        text-align: center;\n    }\n`;\n\nexport const UserMainRouteButton = styled.a`\n    display: inline-block;\n    width: 100%;\n    max-width: 360px;\n    height: 64px;\n    line-height: 64px;\n\n    background: #3bc1ff;\n    border: 1px solid #3bc1ff;\n    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.1);\n    border-radius: 4px;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 19px;\n    letter-spacing: 0.2;\n\n    text-align: center;\n\n    color: #ffffff;\n    cursor: pointer;\n\n    &:hover {\n        transition: 0.5s;\n        opacity: 0.85;\n    }\n\n    @media (max-width: 768px) {\n        width: calc(100vw - 20px);\n        max-width: 360px;\n\n        height: 56px;\n        line-height: 56px;\n        font-size: 16px;\n\n        margin: 0 auto;\n    }\n`;\n\nexport const PartnerContainer = styled.div`\n    width: 100%;\n\n    padding-top: 60px;\n    padding-bottom: 60px;\n\n    @media (max-width: 768px) {\n        margin-top: 40px;\n    }\n`;\n\nexport const PartnerInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n\n    margin: 0 auto;\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    flex-direction: column;\n\n    position: relative;\n\n    -ms-overflow-style: none; /* IE and Edge */\n    scrollbar-width: none; /* Firefox */\n    &::-webkit-scrollbar {\n        display: none;\n    }\n\n    @media (max-width: 768px) {\n        padding-left: 24px;\n        padding-right: 24px;\n    }\n`;\n\nexport const PartnerTitle = styled.div`\n    display: flex;\n    flex-direction: column;\n    width: auto;\n\n    align-items: center;\n    margin-top: 10px;\n    margin-bottom: 46px;\n\n    > img {\n        width: 24px;\n        height: 24px;\n        object-fit: contain;\n\n        margin-bottom: 16px;\n    }\n\n    > span {\n        font-size: 24px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.3;\n        letter-spacing: -0.5px;\n        text-align: center;\n        // color: #3bc1ff;\n    }\n\n    @media (max-width: 1120px) {\n        width: 100%;\n        text-align: left;\n    }\n`;\n\nexport const PartnerListRow = styled.div`\n    display: flex;\n    width: 100%;\n\n    justify-content: space-between;\n    align-items: center;\n    text-align: center;\n    flex-wrap: wrap;\n\n    @media (max-width: 768px) {\n        justify-content: flex-start;\n    }\n\n    @media (max-width: 480px) {\n        justify-content: space-between;\n\n        > div:nth-child(2n) {\n            margin-right: 0px;\n        }\n    }\n`;\n\nexport const PartnerItem = styled.div`\n    margin-bottom: 10px;\n\n    width: 215px;\n    height: 76px;\n\n    border-radius: 4px;\n    // box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    // border: 1px solid rgba(0, 0, 0, 0.1);\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    > img {\n        height: 100%;\n        width: 100%;\n        object-fit: cover;\n        transform: scale(1.1);\n    }\n\n    @media (max-width: 768px) {\n        margin-right: 8px;\n        margin-bottom: 8px;\n    }\n\n    @media (max-width: 480px) {\n        width: calc(50% - 4px);\n        height: calc((50vw - 24px) * 0.35);\n    }\n`;\n\nexport const SectionHeader = styled.div`\n    padding-bottom: 10px;\n    margin-bottom: 66px;\n\n    border-bottom: 1px solid #e9e9e9;\n\n    display: flex;\n    align-items: flex-end;\n\n    > img {\n        width: 58px;\n        height: 76px;\n        object-fit: contain;\n\n        margin-right: 16px;\n    }\n\n    > span {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 26px;\n        line-height: 50px;\n\n        text-align: center;\n        letter-spacing: -0.777778px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n        align-items: center;\n        justify-content: center;\n        > img {\n            width: 48px;\n            height: 48px;\n\n            margin-bottom: 10px;\n        }\n\n        > span {\n            font-size: 20px;\n            line-height: 32px;\n            text-align: center;\n            letter-spacing: -0.555556px;\n        }\n    }\n`;\n\nexport const ServiceListContainer = styled.div`\n    margin-bottom: 102px;\n\n    @media (max-width: 1120px) {\n        padding-left: 20px;\n        padding-right: 20px;\n    }\n`;\n\nexport const ServiceListInnerContainer = styled.div`\n    width: 100%;\n    max-width: 1120px;\n\n    margin: 0 auto;\n`;\n\nexport const ServiceBoxWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const ServiceBoxContainer = styled.div`\n    margin-right: 20px;\n\n    &:last-child {\n        margin-right: 0px;\n    }\n\n    @media (max-width: 768px) {\n        margin-right: 0px;\n    }\n\n    margin-bottom: 46px;\n`;\n\nexport const ServiceBoxHeader = styled.div`\n    > p:first-child {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 12px;\n        line-height: 26px;\n\n        letter-spacing: -0.3px;\n    }\n\n    > p:last-child {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 20px;\n        line-height: 32px;\n\n        letter-spacing: -0.6px;\n    }\n`;\n\nexport const ServiceBoxImageWrapper = styled.div`\n    border-radius: 6px;\n    overflow: hidden;\n`;\n\nexport const ServiceBoxImg = styled.img`\n    width: calc((1120px / 3) - (40px / 3));\n    max-width: 360px;\n    object-fit: contain;\n\n    @media (max-width: 1120px) {\n        max-width: 280px;\n    }\n\n    @media (max-width: 900px) {\n        max-width: 240px;\n    }\n\n    @media (max-width: 768px) {\n        max-width: 300px;\n    }\n`;\n\nexport const ServiceBoxButtons = styled.div`\n    width: 100%;\n    display: flex;\n\n    margin-top: -12px;\n`;\n\nexport const MoreButton = styled.a`\n    width: 132px;\n    height: 48px;\n\n    text-align: center;\n    line-height: 48px;\n\n    background: #606060;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 13px;\n\n    color: #ffffff;\n\n    cursor: pointer;\n`;\n\nexport const ActionButton = styled.span`\n    flex: 1;\n\n    height: 48px;\n    line-height: 48px;\n\n    text-align: center;\n\n    background: #3bc1ff;\n\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 13px;\n\n    color: #ffffff;\n\n    > img {\n        margin-right: 6px;\n\n        width: 18px;\n        height: 18px;\n        object-fit: contain;\n    }\n\n    cursor: pointer;\n`;\n\nexport const IntroduceSection = styled.div`\n    display: flex;\n    align-items: center;\n\n    margin-bottom: 40px;\n\n    > div {\n        width: 50%;\n        flex: 1;\n    }\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const IntroduceSectionFst = styled(IntroduceSection)`\n    div.text-block {\n        @media (max-width: 768px) {\n            order: 2;\n            width: 100%;\n\n            p {\n                text-align: center;\n            }\n        }\n    }\n\n    div.img-block {\n        position: relative;\n        text-align: center;\n\n        display: flex;\n        align-items: center;\n        height: 100px;\n\n        img {\n            position: absolute;\n            bottom: -50px;\n\n            left: 5%;\n\n            width: 50%;\n            object-fit: contain;\n        }\n\n        @media (max-width: 768px) {\n            order: 1;\n            width: 100%;\n            justify-content: center;\n\n            margin-bottom: 14px;\n\n            > img {\n                position: initial;\n            }\n        }\n    }\n`;\n\nexport const IntroduceSectionSnd = styled(IntroduceSection)`\n    div.text-block {\n        @media (max-width: 768px) {\n            width: 100%;\n        }\n    }\n\n    div.img-block {\n        text-align: center;\n        width: 100%;\n\n        img {\n            width: 50%;\n            object-fit: cover;\n\n            @media (max-width: 768px) {\n                object-fit: contain;\n                margin-bottom: 14px;\n            }\n        }\n    }\n`;\n\nexport const IntroduceSectionTrd = styled(IntroduceSection)`\n    div.text-block {\n        @media (max-width: 768px) {\n            width: 100%;\n        }\n    }\n\n    div.img-block {\n        text-align: center;\n        width: 100%;\n\n        img {\n            width: 50%;\n            object-fit: cover;\n\n            @media (max-width: 768px) {\n                width: 65%;\n                object-fit: contain;\n                margin-bottom: 14px;\n            }\n        }\n    }\n`;\n\nexport const IntroduceTitle = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 22px;\n    line-height: 48px;\n\n    letter-spacing: -0.666667px;\n\n    color: rgba(0, 0, 0, 0.8);\n\n    @media (max-width: 768px) {\n        font-size: 18px;\n        line-height: 28px;\n        letter-spacing: -0.5px;\n    }\n`;\n\nexport const IntroduceContent = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: ${props => (props.small ? '13px' : '16px')};\n    line-height: ${props => (props.small ? '22px' : '30px')};\n\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-weight: bold;\n    }\n\n    @media (max-width: 768px) {\n        word-break: keep-all;\n        font-size: ${props => (props.small ? '12px' : '14px')};\n        line-height: ${props => (props.small ? '20px' : '23px')};\n    }\n`;\n\nexport const MobileBr = styled.br`\n    display: none;\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const DesktopBr = styled.br`\n    display: block;\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const SpecListRow = styled.div`\n    display: flex;\n    align-items: flex-start;\n\n    width: 100%;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const SpecWrapper = styled.div`\n    margin-bottom: 28px;\n    margin-right: 20px;\n\n    &:last-child {\n        margin-right: 0px;\n    }\n\n    width: calc((100% / 3) - (40px / 3));\n\n    @media (max-width: 768px) {\n        width: 100%;\n        margin-right: 0px;\n    }\n`;\n\nexport const SpecIndex = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: bold;\n    font-size: 12px;\n    line-height: 16px;\n\n    letter-spacing: -0.333333px;\n    color: rgba(0, 0, 0, 0.2);\n\n    margin-bottom: 4px;\n`;\n\nexport const SpecTitleWrapper = styled.div`\n    display: flex;\n    align-items: center;\n\n    text-align: left;\n\n    > img {\n        width: 24px;\n        height: 24px;\n\n        margin-right: 8px;\n        object-fit: contain;\n    }\n\n    > span {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 20px;\n        line-height: 44px;\n\n        letter-spacing: -0.666667px;\n\n        color: rgba(0, 0, 0, 0.8);\n    }\n`;\n\nexport const SpecContent = styled.p`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 13px;\n    line-height: 22px;\n\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 0px;\n\n    > span {\n        font-weight: bold;\n    }\n\n    @media (max-width: 768px) {\n        br {\n            display: block;\n        }\n    }\n`;\n\nexport const ButtonWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    width: 360px;\n\n    > div,\n    span,\n    a {\n        width: calc(50% - 4px);\n    }\n\n    @media (max-width: 768px) {\n        margin: 0 auto;\n    }\n`;\n","import React from 'react';\nimport CountUp from 'react-countup';\nimport styled from 'styled-components';\n\nimport { DivisionLine } from '../../../../../Components/Common/input';\n\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faUsers, faHospitalUser } from '@fortawesome/free-solid-svg-icons';\nimport { faRectangleList } from '@fortawesome/free-regular-svg-icons';\n\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport SwiperCore, { Pagination, Navigation, Autoplay } from 'swiper';\nimport 'swiper/swiper-bundle.min.css';\nimport 'swiper/swiper.min.css';\nimport 'swiper/components/navigation/navigation.min.css';\nimport 'swiper/components/pagination/pagination.min.css';\nimport { MobileBr } from '../../home.styled';\nimport { Button } from 'antd';\n\nSwiperCore.use([Navigation, Pagination, Autoplay]);\n\nexport const UserNumberCount = () => {\n    function handleClick(e) {\n        window.location.href = '/360F/review/list';\n    }\n\n    return (\n        <div className='container' style={{ height: '700px' }}>\n            <RollingContainer>\n                <div className='numberCount' style={{ textAlign: 'center' }}>\n                    <NumberLabel>\n                        <FontAwesomeIcon icon={faHospitalUser} style={{ paddingRight: '6px' }} />총 가입자 수\n                    </NumberLabel>\n                    <br />\n                    <CountUp className='numberCount' end={1557} suffix=' 명' style={{ fontWeight: 'bold' }} />\n                </div>\n\n                <div className='numberCount' style={{ textAlign: 'center', paddingLeft: '7%' }}>\n                    <NumberLabel>\n                        <FontAwesomeIcon icon={faUsers} style={{ paddingRight: '6px' }} />\n                        메이트 수\n                    </NumberLabel>\n                    <br />\n                    <CountUp end={612} suffix=' 명' style={{ fontWeight: 'bold' }} />\n                </div>\n\n                <div className='numberCount' style={{ textAlign: 'center', paddingLeft: '7%' }}>\n                    <NumberLabel>\n                        <FontAwesomeIcon icon={faRectangleList} style={{ paddingRight: '6px' }} />총 이용 건수\n                    </NumberLabel>\n                    <br />\n                    <CountUp end={5000} suffix=' 건 <i class=\"fa-solid fa-arrow-up\" style=\"color: #3bc1ff\"></i>' style={{ fontWeight: 'bold' }} />\n                </div>\n            </RollingContainer>\n            <SatisfactionContainer>\n                <SatisfactionLabel>\n                    만족도 200% 이용 후기와 서비스 만족도 98% <MobileBr />\n                    \"위드메이트\" 에게 맡겨주세요\n                </SatisfactionLabel>\n            </SatisfactionContainer>\n\n            <DivisionLine />\n\n            <ReviewContainer>\n                <Swiper\n                    direction={'horizontal'} // 슬라이드의 방향을 수직으로 설정합니다.\n                    spaceBetween={10}\n                    slidesPerView={1}\n                    breakpoints={{\n                        768: {\n                            slidesPerView: 1,\n                            spaceBetween: -50,\n                        },\n                    }}\n                    pagination={{ clickable: true }} // 우측의 점을 클릭했을 때, 클릭한 슬라이드로 이동하게 됩니다.\n                    navigation\n                    modules={[Pagination]} // 페이지네이션, 마우스휠등을 사용하려면 모듈을 import해줘야 합니다.\n                    allowTouchMove // 터치 동작을 허용합니다.\n                    className='main_slider'\n                    threshold={20} // 터치 감도를 조정합니다. 숫자가 클수록 터치에 반응하지 않습니다.\n                    autoplay={{ delay: 1500 }}\n                    loop={true}\n                    speed={1000} // 슬라이드가 넘어가는 속도를 조정합니다. 단위는 ms입니다.\n                >\n                    <SwiperSlide>\n                        <ReviewMainContainer>\n                            <ReviewMainInnerContainer>\n                                <ImgStyle>\n                                    <img src={'/assets/images/review/review1.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                                </ImgStyle>\n                            </ReviewMainInnerContainer>\n                        </ReviewMainContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review2.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review3.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review4.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review5.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n\n                    <SwiperSlide>\n                        <ReviewMainInnerContainer>\n                            <ImgStyle>\n                                <img src={'/assets/images/review/review6.png'} style={{ width: '100%', height: '100%' }} alt='' />\n                            </ImgStyle>\n                        </ReviewMainInnerContainer>\n                    </SwiperSlide>\n                </Swiper>\n            </ReviewContainer>\n            <DivisionLine />\n\n            <Button\n                type='primary'\n                style={{\n                    justifyContent: 'center',\n                    alignItems: 'center',\n                    display: 'flex',\n                    margin: '0 auto',\n                    width: '200px',\n                    height: '46px',\n                    borderRadius: '10px',\n                    fontSize: '20px',\n                }}\n                onClick={handleClick}\n            >\n                이용후기 더보기\n            </Button>\n        </div>\n    );\n};\n\nconst ReviewContainer = styled.div`\n    width: 42%;\n    margin-top: 10px;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    margin: 0 auto;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nconst ReviewMainContainer = styled.div`\n    width: 100%;\n    height: 330px;\n\n    @media (max-width: 768px) {\n        height: 330px;\n    }\n`;\n\nconst ReviewMainInnerContainer = styled.div`\n    max-width: 500px;\n    height: 100%;\n    margin: 0 auto;\n\n    padding-top: 10px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst RollingContainer = styled.div`\n    padding-top: 10px;\n    padding-bottom: 20px;\n    justify-content: center;\n    display: flex;\n    flex-direction: initial;\n    background-color: #f9f9f9;\n\n    .numberCount {\n        font-size: 35px;\n    }\n\n    @media (max-width: 768px) {\n        justify-content: center;\n\n        .numberCount {\n            font-size: 20px;\n        }\n    }\n`;\n\nconst ImgStyle = styled.div`\n    width: 330px;\n    height: auto;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    margin: 0 auto;\n\n    @media (max-width: 768px) {\n        width: 280px;\n        height: auto;\n    }\n`;\n\nconst SatisfactionContainer = styled.label`\n    padding-top: 20px;\n    justify-content: center;\n    display: flex;\n    flex-direction: initial;\n\n    @media (max-width: 768px) {\n    }\n`;\n\nconst SatisfactionLabel = styled.label`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 20px;\n    font-weight: bold;\n    text-align: center;\n\n    @media (max-width: 768px) {\n        font-size: 15px;\n    }\n`;\n\nconst NumberLabel = styled.label`\n    font-family: Noto Sans KR;\n    font-style: normal;\n    font-weight: normal;\n    font-size: 20px;\n\n    @media (max-width: 768px) {\n        font-size: 12px;\n    }\n`;\n","import React from 'react';\n\n// components\nimport { PartnerContainer, PartnerInnerContainer, PartnerTitle, PartnerListRow, PartnerItem } from '../home.styled';\n\nexport const WithmatePartners = ({}) => {\n    const baseUrl = '/assets/images/partners/';\n    const fstRow = [\n        baseUrl + 'new-goyang.png',\n        baseUrl + 'new-gov-care.png',\n        baseUrl + 'new-cancel.png',\n        baseUrl + 'aju.png',\n        baseUrl + 'new-goyang-happy.png',\n    ];\n    const sndRow = [\n        baseUrl + 'new-junglang-woman.png',\n        baseUrl + 'new-paju_woman.png',\n        baseUrl + 'new-beatus.png',\n        baseUrl + 'new-cheongdam.png',\n        baseUrl + 'new-hyo-hospital.png',\n    ];\n\n    const trdRow = [baseUrl + 'ssn.png', baseUrl + 'limo-korea.png', baseUrl + 'help-you.png', baseUrl + 'errichi.png', baseUrl + 'new-imagine-us.png'];\n\n    const fthRow = [baseUrl + 'iu-hosp.png', baseUrl + 'new-gpcop.png', baseUrl + 'goyohanM.png', baseUrl + 'carehouse.jpeg', baseUrl + 'bravo.png'];\n\n    const ftfRow = [baseUrl + 'dlive.png', baseUrl + 'sungmo.png', baseUrl + 'metlife.png', baseUrl + 'aju_nursing_hospital.png', baseUrl + 'yongin.png'];\n\n    return (\n        <PartnerContainer id='partners'>\n            <PartnerInnerContainer>\n                <PartnerTitle>\n                    <span>\n                        <img src='/assets/images/partners_map.png' style={{ width: '32px', height: 'auto', paddingBottom: '10px' }} /> 파트너사\n                    </span>\n                    <p style={{ color: '#a9a9a9', fontSize: '18px' }}>위드메이트와 함께하는 협력 파트너사입니다.</p>\n                </PartnerTitle>\n                <PartnerListRow>\n                    <PartnerItem>\n                        <img src={fstRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fstRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={sndRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={trdRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={fthRow[4]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[0]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[1]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[2]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[3]} />\n                    </PartnerItem>\n                    <PartnerItem>\n                        <img src={ftfRow[4]} />\n                    </PartnerItem>\n                </PartnerListRow>\n            </PartnerInnerContainer>\n        </PartnerContainer>\n    );\n};\n","import React from 'react';\n\nimport { MATE } from '../../../Lib/variables';\nimport 'slick-carousel/slick/slick.css';\nimport 'slick-carousel/slick/slick-theme.css';\n\n// section\nimport Reserve from './Section/reserve';\nimport { UserMain as RenewMain } from './Section/renew/main';\nimport { GuideDetail } from '../../Guide/Section/detail';\nimport { UserGuideSection } from './Section/renew/guide';\nimport { UserNumberCount } from './Section/renew/numberCount';\n\nimport { WithmatePartners } from './Section/partners';\n\nexport default class HomePage extends React.PureComponent {\n    state = {\n        searchModal: false,\n    };\n\n    componentDidMount = async () => {};\n\n    render() {\n        const { userType } = this.props.auth;\n\n        return (\n            <div id='#main'>\n                {userType === MATE ? (\n                    <>\n                        <Reserve {...this.props} />\n                    </>\n                ) : (\n                    <>\n                        <RenewMain {...this.props} />\n                        <UserNumberCount />\n                        <GuideDetail />\n                        <UserGuideSection />\n                        <WithmatePartners />\n                        {/* <UserMainBanner\n                            goPage={() => {\n                                this.props.history.push('/nemt/service');\n                            }}\n                        /> */}\n                    </>\n                )}\n            </div>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\n\n// component\nimport Home from './home';\nimport { MATE } from '../../../Lib/variables';\n\n// styles\nimport HomeStyledContainer from './home.styled';\n\n// actions\nimport {\n    editResrveForm,\n    getServiceInfo,\n    serviceReserve,\n    getUserInfo,\n    getContractPartners,\n    acceptCall,\n    editReserveDetailView,\n    editReserveLatestView,\n    editViewType,\n    editCallPage,\n    editContractForm,\n} from '../../../Reducer/Modules/app';\nimport { editAuth } from '../../../Reducer/Modules/auth';\n\nclass HomeContainer extends React.PureComponent {\n    componentDidMount = () => {\n        const id = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n\n        if (id && userType === MATE) {\n        } else {\n            const prevList = localStorage.getItem('partners');\n            if (prevList) {\n                const list = JSON.parse(prevList);\n                this.props.editContractForm({ type: 'partners', value: list });\n            }\n\n            this.props.fetchPartners();\n        }\n    };\n\n    render() {\n        return (\n            <HomeStyledContainer>\n                <Home {...this.props} />\n            </HomeStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapStateToDispatch = dispatch => ({\n    editAuth: ({ type, value }) => dispatch(editAuth({ type, value })),\n    editForm: ({ type, value }) => dispatch(editResrveForm({ type, value })),\n    editLatest: ({ value }) => dispatch(editReserveLatestView({ value })),\n    editDetail: ({ value }) => dispatch(editReserveDetailView({ value })),\n    editViewType: ({ value }) => dispatch(editViewType({ value })),\n    editCallPage: value => dispatch(editCallPage(value)),\n    editContractForm: ({ type, value }) => dispatch(editContractForm({ type, value })),\n\n    getServiceInfo: ({ code }) => dispatch(getServiceInfo({ code })),\n    getUserInfo: ({ id, userType }) => dispatch(getUserInfo({ id, userType })),\n    fetchPartners: () => dispatch(getContractPartners()),\n    serviceReserve: ({ userId, info }) => dispatch(serviceReserve({ userId, info })),\n    acceptCall: ({ mateId, callId }) => dispatch(acceptCall({ mateId, callId })),\n});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(HomeContainer);\n","import styled from 'styled-components';\n\nconst StyledContainer = styled.div``;\n\nexport default StyledContainer;\n\nexport const Container = styled.div`\n    padding-top: 55px;\n`;\n\nexport const GuideNavContainer = styled.div`\n    width: 100%;\n    background-color: #ffffff;\n\n    border-bottom: 4px solid #f2f2f2;\n`;\n\nexport const InnerContainer = styled.div`\n    width: 100%;\n\n    max-width: 1120px;\n    margin: 0 auto;\n\n    // @media (max-width: 1120px) {\n    //     padding-left: 32px;\n    //     padding-right: 32px;\n    // }\n\n    @media (max-width: 768px) {\n        padding-left: 20px;\n        padding-right: 20px;\n    }\n`;\n\nexport const GuideNavWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    padding-top: 16px;\n    padding-bottom: 16px;\n\n    @media (max-width: 768px) {\n        overflow-x: scroll;\n    }\n`;\n\nexport const NavTab = styled.div`\n    > a {\n        cursor: pointer;\n        font-size: 22px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.42;\n        letter-spacing: -0.5px;\n        text-align: left;\n\n        white-space: nowrap;\n\n        color: ${props => (props.active ? '#3BC1FF' : 'rgba(0,0,0,0.6)')};\n\n        display: inline-block;\n    }\n\n    @media (max-width: 768px) {\n        margin-right: 40px;\n\n        > a {\n            font-size: 16px;\n        }\n    }\n`;\n\nexport const GuideConceptContainer = styled.div`\n    margin-top: 102px;\n`;\n\nexport const GuideConceptTitle = styled.p`\n    font-size: 24px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.3;\n    letter-spacing: -0.5px;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.8);\n\n    margin-bottom: 50px;\n`;\n\nexport const GuideConceptImageWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    width: 100%;\n\n    margin-bottom: 40px;\n`;\n\nexport const GuideConceptImage = styled.img`\n    height: 200px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const GuideConceptImageMobile = styled.img`\n    display: none;\n\n    height: 300px;\n    object-fit: contain;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const GuideConceptTextWrapper = styled.div`\n    display: flex;\n    align-items: flex-start;\n    justify-content: center;\n\n    margin-bottom: 122px;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const GuideConceptTextBlock = styled.div`\n    &:first-child {\n        margin-right: 20px;\n\n        @media (max-width: 768px) {\n            margin-right: 0px;\n\n            margin-bottom: 16px;\n        }\n    }\n\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.67;\n    letter-spacing: -0.2px;\n    text-align: left;\n    word-break: keep-all;\n\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    @media (max-width: 768px) {\n        font-size: 16px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.75;\n        letter-spacing: -0.2px;\n        text-align: left;\n    }\n\n    > span {\n        font-weight: bold;\n    }\n`;\n\nexport const MobileBr = styled.br`\n    display: none;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n\n    @media (max-width: 320px) {\n        display: none;\n    }\n`;\n\nexport const DesktopBr = styled.br`\n    display: block;\n\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const MeritContainer = styled.div`\n    background-color: #ffffff;\n\n    padding-top: 100px;\n    padding-bottom: 80px;\n`;\n\nexport const MeritHeaderWrapper = styled.div`\n    width: 100%;\n    padding-bottom: 10px;\n    border-bottom: 2px solid #f2f2f2;\n\n    div.wrap {\n        display: flex;\n        align-items: flex-end;\n        justify-content: flex-start;\n    }\n\n    img {\n        width: 72px;\n        height: 72px;\n        object-fit: contain;\n\n        margin-right: 10px;\n    }\n\n    h3 {\n        font-size: 24px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.3;\n        letter-spacing: -0.5px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n        margin-bottom: 0px;\n    }\n`;\n\nexport const MeritCardList = styled.div`\n    display: flex;\n    flex-wrap: wrap;\n\n    padding-top: 64px;\n`;\n\nexport const MeritCardWrapper = styled.div`\n    height: 260px;\n    width: 33.333%;\n\n    @media (max-width: 768px) {\n        width: 100%;\n        height: auto;\n        margin-bottom: 24px;\n    }\n`;\n\nexport const MeritCardNumber = styled.p`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.43;\n    letter-spacing: normal;\n    text-align: left;\n    color: #afb0b2;\n    margin-bottom: 16px;\n`;\n\nexport const MeritCardTitleRow = styled.div`\n    display: flex;\n    align-items: center;\n\n    > img {\n        width: 20px;\n        height: 20px;\n        object-fit: contain;\n        margin-right: 10px;\n    }\n\n    > span {\n        font-size: 20px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.54;\n        letter-spacing: -0.1px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n`;\n\nexport const MeritCardDesc = styled.div`\n    font-size: 18px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.65;\n    letter-spacing: -0.2px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-weight: bold;\n    }\n\n    @media (max-width: 768px) {\n        font-size: 15px;\n    }\n`;\n\nexport const GuideDetailContainer = styled.div`\n    background-color: #f9f9f9;\n\n    padding-top: 56px;\n    padding-bottom: 100px;\n`;\n\nexport const GuideDetailServiceCardWrapper = styled.div`\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const GuideDetailServiceCard = styled.div`\n    width: 360px;\n    padding: 34px 32px;\n\n    background: #ffffff;\n    box-shadow: 2px 4px 16px -4px rgba(0, 0, 0, 0.1);\n    border: 1px solid rgba(0, 0, 0, 0.1);\n    border-radius: 4px;\n\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n\n    @media (max-width: 768px) {\n        margin-bottom: 24px;\n        width: 100%;\n\n        padding: 34px 16px;\n    }\n`;\n\nexport const GuideCardImage = styled.img`\n    width: 124px;\n    height: 124px;\n    border-radius: 50%;\n\n    margin-bottom: 40px;\n`;\n\nexport const GuideCardSpecTitle = styled.p`\n    width: 100%;\n    font-size: 18px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.26;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    margin-bottom: 24px;\n`;\n\nexport const GuideCardSpecRow = styled.div`\n    display: flex;\n    width: 100%;\n    align-items: flex-start;\n\n    margin-bottom: 24px;\n\n    > span {\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        // line-height: 1.43;\n        letter-spacing: normal;\n        text-align: left;\n        color: #3bc1ff;\n        margin-right: 10px;\n    }\n\n    > p {\n        width: 100%;\n        flex: 1;\n        font-size: 17px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        // line-height: 1.65;\n        letter-spacing: -0.3px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n`;\n\nexport const GuideCardName = styled.p`\n    width: 100%;\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.42;\n    letter-spacing: -0.1px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n    margin-bottom: 2px;\n`;\n\nexport const GuideCardType = styled.h3`\n    width: 100%;\n    font-size: 26px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.2;\n    letter-spacing: -0.5px;\n    text-align: left;\n    color: #3bc1ff;\n    margin-bottom: 24px;\n`;\n\nexport const GuideCardDescription = styled.p`\n    width: 100%;\n    font-size: 16px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.5;\n    letter-spacing: -0.3px;\n    text-align: left;\n    color: rgba(0, 0, 0, 0.7);\n\n    > span {\n        font-weight: bold;\n    }\n\n    margin-bottom: 60px;\n`;\n\nexport const GuideDetailSubFlexWrapper = styled.div`\n    display: flex;\n    justify-content: content;\n    align-items: flex-start;\n\n    @media (max-width: 768px) {\n        flex-direction: column;\n    }\n`;\n\nexport const GuideDetailButtonWrapper = styled(GuideDetailSubFlexWrapper)`\n    border-radius: 4px;\n    overflow: hidden;\n\n    > span.button {\n        cursor: pointer;\n        display: inline-block;\n\n        flex: 1;\n        height: 44px;\n        line-height: 44px;\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 12px;\n        text-align: center;\n        color: #ffffff;\n\n        @media (max-width: 768px) {\n            width: 100%;\n        }\n    }\n\n    > span.gray {\n        background-color: #606060;\n\n        @media (max-width: 768px) {\n            margin-bottom: 8px;\n        }\n    }\n\n    > span.blue {\n        background-color: #3bc1ff;\n    }\n`;\n\nexport const GuideDetailSubFlexbox = styled.div`\n    flex: 1;\n\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n\n    > p {\n        margin-bottom: 20px;\n\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: normal;\n        font-size: 12px;\n        line-height: 18px;\n\n        text-align: left;\n\n        letter-spacing: -0.3px;\n        color: rgba(0, 0, 0, 0.7);\n    }\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nexport const GuideUsingContainer = styled.div`\n    padding-top: 62px;\n    padding-bottom: 78px;\n    background-color: #f9f9f9;\n`;\n\nexport const GuideUsingSubFlexWrapper = styled(GuideDetailSubFlexWrapper)`\n    align-items: center;\n    justify-content: center;\n\n    @media (max-width: 768px) {\n        align-items: flex-start;\n        padding-left: 40px;\n    }\n`;\n\nexport const GuideUsingFlexbox = styled(GuideDetailSubFlexbox)`\n    align-items: center;\n    flex: initial;\n    min-width: 320px;\n\n    > p.index {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 10px;\n        line-height: 14px;\n\n        letter-spacing: -0.333333px;\n        color: rgba(0, 0, 0, 0.2);\n\n        margin-bottom: 16px;\n    }\n\n    > p {\n        width: auto;\n        text-align: center;\n    }\n\n    > p.title {\n        font-family: Noto Sans KR;\n        font-style: normal;\n        font-weight: bold;\n        font-size: 16px;\n        line-height: 22px;\n\n        text-align: center;\n        letter-spacing: -0.6px;\n    }\n\n    > div {\n        display: flex;\n        justify-content: center;\n\n        margin-bottom: 16px;\n\n        img {\n            height: 90px;\n            object-fit: contain;\n        }\n    }\n\n    margin-bottom: 44px;\n`;\n\nexport const GuideUsageFlexbox = styled.div`\n    flex: 1;\n\n    display: flex;\n    align-items: center;\n    justify-content: flex-start;\n\n    margin-bottom: 68px;\n\n    @media (max-width: 768px) {\n        margin-bottom: 32px;\n        // width: 230px;\n        align-items: ;\n    }\n\n    div {\n        // width: 120px;\n\n        img {\n            width: 64px;\n            height: 64px;\n            margin-right: 34px;\n            object-fit: contain;\n        }\n\n        // @media (max-width: 768px) {\n        //     width: 70px;\n\n        //     img {\n        //         height: 32px;\n        //     }\n        // }\n    }\n\n    span {\n        font-size: 18px;\n        font-weight: normal;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.65;\n        letter-spacing: -0.2px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n\n        // @media (max-width: 768px) {\n        //     font-size: 13px;\n        //     line-height: 19px;\n        // }\n    }\n`;\n\nexport const WithmateContainer = styled.div`\n    padding-top: 56px;\n    // padding-bottom: 120px;\n`;\n\nexport const FlexDivWrapper = styled.div`\n    display: flex;\n    width: 100%;\n\n    ${props => props.top && `margin-bottom: 72px;`}\n`;\n\nexport const HiddenType = styled.div`\n    @media (max-width: 768px) {\n        ${props => props.mHidden && `display: none;`}\n    }\n`;\n\nexport const BigSideBox = styled(HiddenType)`\n    width: 58%;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nexport const SmallSideBox = styled(HiddenType)`\n    width: 42%;\n\n    @media (max-width: 768px) {\n        width: 100%;\n    }\n`;\n\nexport const WithmateBg = styled.div`\n    width: 100%;\n    height: 100%;\n\n    background-image: url(${props => props.bg});\n    background-size: 80% auto;\n    background-position: center;\n    background-repeat: no-repeat;\n`;\n\nexport const WithmateTitle = styled.div`\n    > img {\n        width: 72.5px;\n        height: 48px;\n        object-fit: contain;\n        margin-right: 8px;\n    }\n\n    > span {\n        font-size: 28px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.11;\n        letter-spacing: -0.5px;\n        text-align: left;\n        color: rgba(0, 0, 0, 0.7);\n    }\n\n    display: flex;\n    align-items: flex-end;\n    margin-bottom: 24px;\n`;\n","import React from 'react';\nimport { HashLink } from 'react-router-hash-link';\n\n// components\nimport { GuideNavContainer, InnerContainer, GuideNavWrapper, NavTab } from '../guide.styled';\n\nexport const GuideNav = ({ activeTab, onTab }) => {\n    return (\n        <GuideNavContainer>\n            <InnerContainer>\n                <GuideNavWrapper>\n                    <NavTab active={activeTab === 'withmate'}>\n                        <HashLink\n                            to='/360F/nemt/service/#withmate'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('withmate');\n                            }}\n                        >\n                            위드메이트란?\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'types'}>\n                        <HashLink\n                            to='/360F/nemt/service/#types'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('types');\n                            }}\n                        >\n                            서비스 종류\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'merit'}>\n                        <HashLink\n                            to='/360F/nemt/service/#merit'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('merit');\n                            }}\n                        >\n                            믿을수 있는 위드메이트\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'usage'}>\n                        <HashLink\n                            to='/360F/nemt/service/#usage'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('usage');\n                            }}\n                        >\n                            이런분께 추천해요\n                        </HashLink>\n                    </NavTab>\n                    <NavTab active={activeTab === 'partners'}>\n                        <HashLink\n                            to='/360F/nemt/service/#partners'\n                            scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'nearest' })}\n                            onClick={() => {\n                                onTab('partners');\n                            }}\n                        >\n                            위드메이트 파트너\n                        </HashLink>\n                    </NavTab>\n                </GuideNavWrapper>\n            </InnerContainer>\n        </GuideNavContainer>\n    );\n};\n","import React from 'react';\n\n// components\nimport { GuideConceptContainer } from '../guide.styled';\n\nexport const GuideConcept = ({}) => {\n    return <GuideConceptContainer id='concept'></GuideConceptContainer>;\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport swal from 'sweetalert2';\n\n// components\nimport {\n    GuideDetailContainer,\n    InnerContainer,\n    GuideConceptTitle,\n    GuideDetailServiceCardWrapper,\n    GuideDetailServiceCard,\n    GuideCardImage,\n    GuideCardName,\n    GuideCardType,\n    GuideCardDescription,\n    GuideCardSpecTitle,\n    GuideCardSpecRow,\n} from '../guide.styled';\n\nexport const GuideDetail = () => {\n    return (\n        <GuideDetailContainer id='types'>\n            <InnerContainer>\n                <GuideConceptTitle>서비스 종류</GuideConceptTitle>\n                <GuideDetailServiceCardWrapper>\n                    <GuideCard\n                        source={'/assets/images/art_pro.png'}\n                        name='병원 동행'\n                        type='Pro'\n                        desc={\n                            <>\n                                <>\n                                    위드메이트 동행 전문가가 고객님의\n                                    <br />\n                                    <span>자택에서 병원까지 </span>동행하고, 병원 업무를\n                                    <br />\n                                    마친 뒤 <span>다시 자택까지</span> 동행합니다.\n                                </>\n                                <br />\n                                <br />\n                                <>\n                                    <b>요금</b> <br />\n                                    시간당 25,000원 (추가 30분마다 12,500원)\n                                </>\n                            </>\n                        }\n                        spec1={\n                            <>\n                                위드메이트 소속 동행 전문가가 <br />\n                                자택에서 병원까지 동행\n                            </>\n                        }\n                        spec2={\n                            <>\n                                대중교통, 고객님 소유 자차, 택시 중<br />\n                                선택하여 이동\n                            </>\n                        }\n                        spec3={\n                            <>\n                                서비스 종료 이후\n                                <br />\n                                서비스 보고서 열람 가능\n                            </>\n                        }\n                        spec4={\n                            <>\n                                서비스 진행 단계별 카카오톡\n                                <br />\n                                실시간 알림 업데이트 제공\n                            </>\n                        }\n                    />\n                    <GuideCard\n                        source={'/assets/images/art_basic.png'}\n                        name='병원 동행'\n                        type='Basic'\n                        desc={\n                            <>\n                                <>\n                                    위드메이트 베이직 서비스는 위드메이트 동행\n                                    <br />\n                                    전문가가 고객님께서 지정한 의료 시설 혹은\n                                    <br />\n                                    <span>병원 내에서 보호자 대행 업무</span>를 수행합니다.\n                                </>\n                                <br />\n                                <br />\n                                <>\n                                    <b>요금</b> <br />\n                                    시간당 15,000원 (추가 30분마다 7,500원)\n                                </>\n                            </>\n                        }\n                        spec1={\n                            <>\n                                고객님의 진료 일정에 맞춰 위드메이트 <br />\n                                소속 동행 전문가가 의료 시설 도착\n                            </>\n                        }\n                        spec2={\n                            <>\n                                지정된 의료 시설에서 고객님 접선 후 <br />\n                                진료 시작부터 끝까지 동행\n                            </>\n                        }\n                        spec3={\n                            <>\n                                진료 종료 후 고객님의 상태를 <br />\n                                파악하고 이상 없을 시 서비스 종료\n                            </>\n                        }\n                        spec4={\n                            <>\n                                서비스 진행 단계별 카카오톡\n                                <br />\n                                실시간 알림 업데이트 제공\n                            </>\n                        }\n                    />\n                    <GuideCard\n                        source={'/assets/images/art_zzz.png'}\n                        name='보호자 동행'\n                        type='수면 내시경'\n                        desc={\n                            <>\n                                <>\n                                    {/* 위드메이트 동행 전문가가 고객님께서\n                                <br />\n                                <span>자택에서 병원까지 </span>동행하고, 병원 내에서\n                                <br />\n                                <span>보호자 대행 업무</span>를 수행합니다. */}\n                                    고객님께서 수면내시경 검사를 받는\n                                    <br />\n                                    <span>병원 내에서 </span>위드메이트 동행 전문가가\n                                    <br />\n                                    <span>보호자 대행 업무</span>를 수행합니다.\n                                </>\n                                <br />\n                                <br />\n                                <>\n                                    <b>요금</b> <br />\n                                    시간당 15,000원 (추가 30분마다 7,500원)\n                                </>\n                            </>\n                        }\n                        spec1={\n                            <>\n                                고객님의 진료 일정에 맞춰 위드메이트 <br />\n                                소속 동행 전문가가 의료 시설 도착\n                            </>\n                        }\n                        spec2={\n                            <>\n                                지정된 의료 시설에서 고객님 접선 후 <br />\n                                수면 내시경 검사 시작부터 끝까지 동행\n                            </>\n                        }\n                        spec3={\n                            <>\n                                수면 내시경 검사 종료 후 고객님의 <br />\n                                상태를 파악하고 이상 없을 시 종료\n                            </>\n                        }\n                        spec4={\n                            <>\n                                서비스 진행 단계별 카카오톡 <br />\n                                실시간 알림 업데이트 제공\n                            </>\n                        }\n                    />\n                </GuideDetailServiceCardWrapper>\n            </InnerContainer>\n        </GuideDetailContainer>\n    );\n};\n\nconst GuideCard = ({ source, name, type, desc, spec1, spec2, spec3, spec4 }) => (\n    <GuideDetailServiceCard>\n        <GuideCardImage src={source} />\n        <GuideCardName>{name}</GuideCardName>\n        <GuideCardType>{type}</GuideCardType>\n        <GuideCardDescription>{desc}</GuideCardDescription>\n        <GuideCardSpecTitle>서비스 구성</GuideCardSpecTitle>\n\n        <GuideCardSpecRow>\n            <span>01</span>\n            <p>{spec1}</p>\n        </GuideCardSpecRow>\n\n        <GuideCardSpecRow>\n            <span>02</span>\n            <p>{spec2}</p>\n        </GuideCardSpecRow>\n\n        <GuideCardSpecRow>\n            <span>03</span>\n            <p>{spec3}</p>\n        </GuideCardSpecRow>\n\n        <GuideCardSpecRow>\n            <span>04</span>\n            <p>{spec4}</p>\n        </GuideCardSpecRow>\n    </GuideDetailServiceCard>\n);\n","import React from 'react';\nimport styled from 'styled-components';\n\n// components\nimport { GuideUsingContainer, InnerContainer, GuideConceptTitle, GuideUsingSubFlexWrapper, GuideUsageFlexbox, MobileBr, DesktopBr } from '../guide.styled';\n\nexport const GuideUsage = () => {\n    return (\n        <GuideUsingContainer id='usage'>\n            <InnerContainer>\n                <GuideConceptTitle>이런 분께 추천해요</GuideConceptTitle>\n                <GuideUsingSubFlexWrapper>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_legache.png' />\n                        </div>\n                        <span>\n                            병원에 가시는 <DesktopBr />\n                            <MobileBr />\n                            어르신\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_wheelchair.png' />\n                        </div>\n                        <span>\n                            거동이 <DesktopBr />\n                            <MobileBr />\n                            힘드신 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_x-ray.png' />\n                        </div>\n                        <span>\n                            항암 / 방사선 치료를 <DesktopBr />\n                            <MobileBr />\n                            받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                </GuideUsingSubFlexWrapper>\n\n                <GuideUsingSubFlexWrapper>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_injection.png' />\n                        </div>\n                        <span>\n                            수면내시경 등 <DesktopBr />\n                            <MobileBr />\n                            마취가 동반되는 <DesktopBr />\n                            <MobileBr />\n                            치료를 받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_round_trip.png' />\n                        </div>\n                        <span>\n                            입원 / 퇴원\n                            <DesktopBr />\n                            <MobileBr />\n                            하시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_eyecare.png' />\n                        </div>\n                        <span>\n                            안과 진료/시술을 <DesktopBr />\n                            <MobileBr />\n                            받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                </GuideUsingSubFlexWrapper>\n\n                <GuideUsingSubFlexWrapper>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_detailcheck.png' />\n                        </div>\n                        <span>\n                            각종 검진을 <DesktopBr />\n                            <MobileBr />\n                            받으시는 분\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_pregnant.png' />\n                        </div>\n                        <span>\n                            임산부, 산모, <DesktopBr />\n                            <MobileBr />및 소아\n                        </span>\n                    </GuideUsageFlexbox>\n                    <GuideUsageFlexbox>\n                        <div>\n                            <img src='/assets/images/icon_blood.png' />\n                        </div>\n                        <span>혈액 투석 환자</span>\n                    </GuideUsageFlexbox>\n                </GuideUsingSubFlexWrapper>\n            </InnerContainer>\n        </GuideUsingContainer>\n    );\n};\n","import React from 'react';\nimport {\n    MeritContainer,\n    InnerContainer,\n    MeritHeaderWrapper,\n    MeritCardList,\n    MeritCardWrapper,\n    MeritCardNumber,\n    MeritCardDesc,\n    MeritCardTitleRow,\n} from '../guide.styled';\n\nexport const Merit = () => {\n    return (\n        <MeritContainer id='merit'>\n            <MeritHeaderWrapper>\n                <InnerContainer>\n                    <div className='wrap'>\n                        <img src='/assets/images/faith_up.png' />\n                        <h3>믿을 수 있는 위드메이트</h3>\n                    </div>\n                </InnerContainer>\n            </MeritHeaderWrapper>\n            <InnerContainer>\n                <MeritCardList>\n                    <MeritCard\n                        title='인정 받은 서비스'\n                        source='/assets/images/faith_icon_1.png'\n                        desc={\n                            <>\n                                위드메이트 병원 동행 서비스는\n                                <br />\n                                <span>신한 오픈 이노베이션 2기 우수 기업</span>으로\n                                <br />\n                                선정된 신뢰할 수 있는 서비스입니다.{' '}\n                            </>\n                        }\n                        number='01'\n                    />\n                    <MeritCard\n                        title='검증 받은 서비스'\n                        source='/assets/images/faith_icon_2.png'\n                        desc={\n                            <>\n                                위드메이트는 엄격한 검증을 거친 후<br />\n                                보건복지부와 고양시, 그리고 국립 암센터가\n                                <br />\n                                주관하는<span>‘고양 해피 케어’</span>컨소시엄의 <br />\n                                일원으로 활동 중에 있습니다.\n                            </>\n                        }\n                        number='02'\n                    />\n                    <MeritCard\n                        title='서비스 인력 평점 제도'\n                        source='/assets/images/faith_icon_3.png'\n                        desc={\n                            <>\n                                위드메이트는 더욱 높은 서비스 경험을\n                                <br />\n                                제공하기 위해 매뉴얼을 만들고, 서비스 <br />\n                                종료 후 <span>고객님의 후기를 반영</span>하여 <br />\n                                서비스 인력을 관리합니다.\n                            </>\n                        }\n                        number='03'\n                    />\n                    <MeritCard\n                        title='전문적인 서비스 인력 양성'\n                        source='/assets/images/faith_icon_4.png'\n                        desc={\n                            <>\n                                위드메이트는 여성 인력 개발 센터,\n                                <br /> 재취업 지원 센터, 고용 복지 플러스\n                                <br /> 센터 등의 전문 기관과 <span>일자리 협업 </span>\n                                <br />\n                                <span>프로그램</span>을 운영하며 검증된 서비스\n                                <br />\n                                인력을 주기적으로 양성하고 있습니다.\n                            </>\n                        }\n                        number='04'\n                    />\n                    <MeritCard\n                        title='책임지는 서비스'\n                        source='/assets/images/faith_icon_5.png'\n                        desc={\n                            <>\n                                위드메이트는 서비스 제공 인력 전원이\n                                <br />\n                                삼성화재가 제공하는 1억 2천만원 한도의 <br />\n                                <span>‘전문인 영업 배상 책임 보험’</span>에 가입되어 <br />\n                                책임지는 서비스를 제공합니다.\n                            </>\n                        }\n                        number='05'\n                    />\n                    <MeritCard\n                        title='안전한 서비스'\n                        source='/assets/images/faith_icon_6.png'\n                        desc={\n                            <>\n                                위드메이트는 <span> 시니어 헬스케어 서비스의</span>\n                                <br />\n                                <span>본질은 ‘안전’</span>이라고 생각하고, 서비스 인력의\n                                <br />\n                                정기적인 교육, 자격증 취득 및 보유 여부 <br />\n                                점검, 서비스 매뉴얼의 수정 및 보완등을 <br />\n                                진행하고 있습니다.\n                            </>\n                        }\n                        number='06'\n                    />\n                </MeritCardList>\n            </InnerContainer>\n        </MeritContainer>\n    );\n};\n\nconst MeritCard = ({ number, title, source, desc }) => (\n    <MeritCardWrapper>\n        <MeritCardNumber>{number}</MeritCardNumber>\n        <MeritCardTitleRow>\n            <img src={source} />\n            <span>{title}</span>\n        </MeritCardTitleRow>\n        <MeritCardDesc>{desc}</MeritCardDesc>\n    </MeritCardWrapper>\n);\n","import React from 'react';\nimport styled from 'styled-components';\n\nimport {\n    WithmateContainer,\n    InnerContainer,\n    WithmateTitle,\n    MeritCardDesc,\n    FlexDivWrapper,\n    BigSideBox,\n    SmallSideBox,\n    WithmateBg,\n    GuideConceptTitle,\n    MobileBr,\n    DesktopBr,\n} from '../guide.styled';\nexport const Withmate = () => {\n    return (\n        <WithmateContainer id='withmate'>\n            <InnerContainer>\n                <FlexDivWrapper top>\n                    <SmallSideBox>\n                        <WithmateTitle>\n                            <img src='/assets/images/new_logo_img.png' />\n                            <span>위드메이트란?</span>\n                        </WithmateTitle>\n                        <Block bigMargin>\n                            위드메이트는 <span>온라인 병원 동행 서비스 매칭 플랫폼</span>을<MobileBr /> 시작으로,\n                            <DesktopBr /> 대한민국에서{' '}\n                            <span>\n                                사회적 의미의 ‘시니어’라는 <MobileBr />\n                                단어를 없애기 위해\n                            </span>{' '}\n                            설립된 <DesktopBr />\n                            <span>\n                                시니어 라이프 스타일 <MobileBr />\n                                혁신 기업\n                            </span>\n                            입니다.\n                        </Block>\n                        <Title>위드메이트의 시작</Title>\n                        <Block>\n                            <span>2015년</span>에 설립된 위드메이트는 <span>초고령화 </span>및 <MobileBr />\n                            <span>1인 가구 시대</span>에 <DesktopBr />\n                            접어든 대한민국의 현 상황에 적합한\n                            <MobileBr />\n                            <span> 시니어 라이프 스타일 혁신</span>\n                            <DesktopBr />\n                            <span>서비스를 개발합니다.</span>\n                        </Block>\n                        <Block noMargin>\n                            이를 위해 위드메이트는 <MobileBr />\n                            <span>국내 최초로 병원 동행 서비스를 런칭해</span>\n                            <MobileBr />\n                            <DesktopBr />\n                            <span>탄탄한 신뢰</span>와 <span>안정된 서비스</span> 시스템을 기반으로 <MobileBr />\n                            축적되는 <DesktopBr />\n                            데이터와 실전 경험을 바탕으로{' '}\n                            <span>\n                                다양한 <MobileBr />\n                                신규 서비스를 연구\n                            </span>\n                            하여 <DesktopBr />\n                            <span>\n                                시니어 라이프 스타일 <MobileBr />\n                                혁신 기업\n                            </span>\n                            의 길을 걷고 있습니다.\n                        </Block>\n                    </SmallSideBox>\n                    <BigSideBox mHidden>\n                        <WithmateBg bg='/assets/images/guide_withmate_main1.png' />\n                    </BigSideBox>\n                </FlexDivWrapper>\n            </InnerContainer>\n        </WithmateContainer>\n    );\n};\n\nconst Title = styled(GuideConceptTitle)`\n    margin-bottom: 24px;\n    text-align: left;\n`;\n\nconst Block = styled(MeritCardDesc)`\n    font-size: 16px;\n    margin-bottom: 24px;\n    ${props => props.noMargin && `margin-bottom: 0px;`}\n    ${props => props.bigMargin && `margin-bottom: 74px;`}\n\n    @media (max-width: 768px) {\n        word-break: keep-all;\n    }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const GuideBanner = () => {\n    return <GuideBannerContainer>병원동행 서비스는 위드메이트에게!</GuideBannerContainer>;\n};\n\nconst GuideBannerContainer = styled.div`\n    width: 100%;\n    height: 235px;\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n\n    font-size: 40px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.2;\n    letter-spacing: -0.7px;\n    text-align: center;\n    color: #ffffff;\n\n    background-image: url('/assets/images/guide_title_bg.png');\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center;\n\n    @media (max-width: 768px) {\n        font-size: 22px;\n        background-position: left;\n    }\n`;\n","import React from 'react';\nimport _ from 'lodash';\n\n// components\nimport { GuideNav } from './Section/nav';\nimport { GuideConcept } from './Section/concept';\nimport { GuideDetail } from './Section/detail';\nimport { GuideUsage } from './Section/usage';\nimport { WithmatePartners } from '../../Home/Section/partners';\nimport { Merit } from './Section/merit';\nimport { Withmate } from './Section/withmate';\nimport { GuideBanner } from './Section/banner';\n\nimport { Container } from './guide.styled';\n\nclass GuidePage extends React.PureComponent {\n    state = {\n        activeTab: 'concept',\n        reserveModal: false,\n        reserveType: null,\n        step: 1,\n        mobile_menu: false,\n        addHalfTime: false,\n    };\n\n    inputHandler = ({ type, value }) => {\n        this.setState({ [type]: value });\n    };\n\n    inputDeepHandler = ({ type, deepType, value }) => {\n        this.setState(prevState => ({\n            [type]: {\n                ...prevState[type],\n                [deepType]: value,\n            },\n        }));\n    };\n\n    onTab = tab => {\n        this.setState({\n            activeTab: tab,\n        });\n    };\n\n    onRoute = path => {\n        this.props.history.push(path);\n    };\n\n    render() {\n        const { activeTab } = this.state;\n\n        return (\n            <Container>\n                <GuideBanner />\n                <GuideNav\n                    activeTab={activeTab}\n                    onTab={this.onTab}\n                    onReserve={serviceType => {\n                        this.setState({\n                            reserveModal: true,\n                            temp: {\n                                page: 1,\n                                service: 'unemergency',\n                                addTime: '60',\n                                payMethod: 'transfer',\n                                sex: '남',\n                                transport: 'common',\n                                report: false,\n                            },\n                        });\n                    }}\n                />\n                <Withmate />\n                <GuideConcept />\n                <GuideDetail />\n                <Merit />\n                <GuideUsage />\n                <WithmatePartners />\n            </Container>\n        );\n    }\n}\n\nexport default GuidePage;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\n\n// component\nimport GuidePage from './guide';\n\n// styles\nimport StyledContainer from './guide.styled';\n\n// actions\nimport { serviceReserve, editResrveForm } from '../../../Reducer/Modules/app';\n\nclass GuideContainer extends React.PureComponent {\n    componentDidMount = () => {};\n\n    render() {\n        return (\n            <StyledContainer>\n                <GuidePage {...this.props} />\n            </StyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth }) => ({\n    app,\n    auth,\n});\n\nconst mapStateToDispatch = dispatch => ({\n    serviceReserve: ({ userId, info }) => dispatch(serviceReserve({ userId, info })),\n    editForm: ({ type, value }) => dispatch(editResrveForm({ type, value })),\n});\n\nexport default connect(mapStateToProps, mapStateToDispatch)(GuideContainer);\n","import styled from 'styled-components';\n\nconst StyledListContainer = styled.div`\n    // border-bottom: 1px solid #e6e6e6;\n`;\n\nexport const HeaderButton = styled.div`\n    cursor: pointer;\n\n    width: 265px;\n    height: 60px;\n    line-height: 60px;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: -0.2px;\n    text-align: center;\n    color: #ffffff;\n\n    margin-top: 40px;\n    margin-bottom: 90px;\n    border-radius: 4px;\n    background-color: #3bc1ff;\n\n    &:hover {\n        transition: all 0.5s;\n        opacity: 0.8;\n    }\n\n    @media (max-width: 768px) {\n        width: 230px;\n        height: 48px;\n        line-height: 48px;\n    }\n`;\n\nexport const NavigationTabWrapper = styled.div`\n    display: flex;\n    align-items: center;\n    justify-content: flex-start;\n`;\n\nexport const NavigationTab = styled.span`\n    position: relative;\n    display: inline-block;\n    margin-right: 44px;\n\n    font-size: 16px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: normal;\n    letter-spacing: normal;\n    text-align: center;\n    color: rgba(0, 0, 0, 0.8);\n    padding-bottom: 20px;\n\n    cursor: pointer;\n\n    &.active {\n        color: #55d4ff;\n    }\n`;\n\nexport const NavigationTabUnderline = styled.span`\n    display: inline-block;\n    position: absolute;\n    left: 0px;\n    bottom: -3px;\n\n    width: 100%;\n    height: 3px;\n    background-color: #55d4ff;\n`;\n\nexport const CountDisplay = styled.div`\n    font-size: 36px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.44;\n    letter-spacing: -1px;\n    color: rgba(0, 0, 0, 0.8);\n\n    > span {\n        color: #4bcfff;\n    }\n\n    margin-bottom: 20px;\n`;\n\nexport const CollapseContainer = styled.div`\n    .ant-collapse-icon-position-right > .ant-collapse-item > .ant-collapse-header {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n\n    .ant-collapse-content > .ant-collapse-content-box {\n        padding-left: 0px;\n        padding-right: 0px;\n    }\n`;\n\nexport const CollapseHeader = styled.div`\n    display: flex;\n    align-items: center;\n    border-bottom: 1px solid #e6e6e6;\n`;\n\nexport const CollapseTab = styled.div`\n    font-size: 14px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.57;\n    letter-spacing: normal;\n    color: rgba(0, 0, 0, 0.7);\n\n    padding-bottom: 11px;\n`;\n\nexport const CollapseTabOnlyDesktop = styled(CollapseTab)`\n    @media (max-width: 768px) {\n        display: none;\n    }\n`;\n\nexport const PanelHeader = styled.div`\n    display: flex;\n`;\n\nexport const PanelField = styled.div`\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    overflow: hidden;\n\n    ${props => (props.style ? props.style : `flex: 1;`)}\n    ${props => (props.onlyDesktop ? `display: block;` : null)} \n\n    &.title {\n        font-size: 16px;\n        font-weight: bold;\n        font-stretch: normal;\n        font-style: normal;\n        line-height: 1.56;\n        letter-spacing: normal;\n        color: rgba(0, 0, 0, 0.8);\n    }\n\n    @media (max-width: 768px) {\n        ${props => (props.onlyDesktop ? `display: none;` : null)}\n    }\n`;\n\nexport const Star = styled.img`\n    width: 16.7px;\n    height: 16px;\n    object-fit: contain;\n    margin-bottom: 4px;\n`;\n\nexport const ReviewTextWrapper = styled.div`\n    padding-left: 120px;\n    padding-right: 50px;\n\n    @media (max-width: 768px) {\n        padding-left: 0px;\n    }\n`;\n\nexport const ReviewText = styled.p`\n    font-size: 13px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.71;\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n`;\n\nexport const MyReview = styled.span`\n    display: inline-block;\n    width: 53px;\n    height: 20px;\n    line-height: 20px;\n    border-radius: 10px;\n    background-color: #3bc1ff;\n\n    font-size: 10px;\n    font-weight: bold;\n    font-stretch: normal;\n    font-style: normal;\n    letter-spacing: -0.21px;\n    color: #ffffff;\n    text-align: center;\n`;\n\nexport const ReviewMobileInfo = styled.div`\n    display: flex;\n    align-items: center;\n\n    margin-bottom: 27px;\n    display: none;\n\n    @media (max-width: 768px) {\n        display: block;\n    }\n`;\n\nexport const ReviewerName = styled.span`\n    font-size: 13px;\n    font-weight: normal;\n    font-stretch: normal;\n    font-style: normal;\n    line-height: 1.71;\n    letter-spacing: -0.3px;\n    color: rgba(0, 0, 0, 0.7);\n\n    margin-bottom: 0px;\n    margin-right: 16px;\n`;\n\nexport default StyledListContainer;\n","import React from 'react';\nimport { Collapse, Icon, Pagination, message } from 'antd';\nimport moment from 'moment';\n\nimport CommentPageHeader from '../../../Components/Templates/Review/header';\nimport {\n    HeaderButton,\n    CollapseContainer,\n    CollapseHeader,\n    CollapseTab,\n    CollapseTabOnlyDesktop,\n    CountDisplay,\n    PanelHeader,\n    PanelField,\n    Star,\n    ReviewTextWrapper,\n    ReviewText,\n    ReviewMobileInfo,\n    ReviewerName,\n    MyReview,\n} from './review.styled';\n\nimport axios from '../../../Lib/axios';\n\nconst { Panel } = Collapse;\n\nconst PerPage = 20;\n\nexport default class CommentList extends React.PureComponent {\n    state = {\n        tab: 'basic',\n        total: 0,\n        list: [],\n        page: 1,\n    };\n\n    componentDidMount = () => {\n        this.fetchList();\n    };\n\n    fetchList = () => {\n        const { page } = this.state;\n        axios.get('/v2/review/list', { params: { page, pageCnt: PerPage } }).then(resolve => {\n            const { data } = resolve;\n            if (data && data.total) {\n                this.setState({ total: data.total || 0, list: data.list || [] });\n            }\n        });\n    };\n\n    renderStar = score => {\n        return (\n            <>\n                {new Array(score).fill(0).map((star, index) => (\n                    <Star key={'active-star=' + index.toString()} src='/assets/images/icon_active_star.png' alt='active-star' />\n                ))}\n                {new Array(5 - score).fill(0).map((star, index) => (\n                    <Star key={'active-star=' + index.toString()} src='/assets/images/icon_star.png' alt='active-star' />\n                ))}\n            </>\n        );\n    };\n\n    getAutoTitle = ({ title, rate }) => {\n        if (title) return title;\n        if (rate === 5) return '서비스 매우 만족';\n        if (rate >= 4) return '서비스 만족';\n        if (rate >= 3) return '서비스 보통';\n        if (rate >= 2) return '서비스 불만족';\n        if (rate >= 1) return '서비스 매우 불만족';\n    };\n\n    render() {\n        const { tab, list, page, total } = this.state;\n        const { id, userType } = this.props.auth;\n\n        return (\n            <div>\n                <CommentPageHeader title='이용 후기' desc={`고객님의 소중한 후기를 통해 더욱 발전하는\\n 위드메이트가 되겠습니다.`}>\n                    <div style={{ height: '190px' }} />\n                </CommentPageHeader>\n\n                <CollapseContainer className='inner-container'>\n                    <CountDisplay>\n                        <span>{total}</span>건\n                    </CountDisplay>\n\n                    <CollapseHeader>\n                        <CollapseTab style={{ width: '40px' }}>번호</CollapseTab>\n                        <CollapseTab style={{ flex: 1 }}>서비스</CollapseTab>\n                        <CollapseTab style={{ flex: 1 }}>제목</CollapseTab>\n                        <CollapseTabOnlyDesktop style={{ width: '80px' }}>작성자</CollapseTabOnlyDesktop>\n                        <CollapseTabOnlyDesktop style={{ width: '120px' }}>별점</CollapseTabOnlyDesktop>\n                        <CollapseTabOnlyDesktop style={{ width: '152px' }}>작성일</CollapseTabOnlyDesktop>\n                    </CollapseHeader>\n                    <Collapse\n                        key={'item-key-frefresh'}\n                        expandIconPosition='right'\n                        bordered={false}\n                        expandIcon={({ isActive }) => <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? '#3bc1ff' : '#a7a7a7' }} />}\n                    >\n                        {list &&\n                            list.map((info, index) => (\n                                <Panel\n                                    key={'comment-order-' + index.toString() + 'item'}\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={\n                                        <PanelHeader>\n                                            <PanelField style={{ width: '40px' }} index>\n                                                {total - ((page - 1) * PerPage + index)}\n                                            </PanelField>\n                                            <PanelField style={{ width: '80px' }}>{info.reserve.service === 'assist' ? 'Basic' : 'Pro'}</PanelField>\n                                            <PanelField className='title' style={{ flex: 1 }}>\n                                                {this.getAutoTitle({ title: info.title, rate: info.score })}\n                                            </PanelField>\n                                            <PanelField style={{ width: '80px' }} onlyDesktop>\n                                                {id === info.user._id ? <MyReview>내후기</MyReview> : info.user.name}\n                                            </PanelField>\n                                            <PanelField style={{ width: '120px' }} onlyDesktop>\n                                                {info.score ? this.renderStar(parseInt(info.score, 10)) : null}\n                                            </PanelField>\n                                            <PanelField style={{ width: '152px' }} onlyDesktop>\n                                                {moment(info.createdAt).format('YYYY-MM-DD')}\n                                            </PanelField>\n                                        </PanelHeader>\n                                    }\n                                >\n                                    <ReviewTextWrapper>\n                                        <ReviewMobileInfo>\n                                            {id === info.user._id ? (\n                                                <MyReview style={{ marginRight: '17px' }}>내후기</MyReview>\n                                            ) : (\n                                                <ReviewerName>{info.user.name}</ReviewerName>\n                                            )}\n                                            <span style={{ marginRight: '18px' }}>{info.score ? this.renderStar(parseInt(info.score, 10)) : null}</span>\n                                            <ReviewerName>{moment(info.createdAt).format('YYYY-MM-DD')}</ReviewerName>\n                                        </ReviewMobileInfo>\n                                        {info.review && (\n                                            <ReviewText>\n                                                {info.review.split('\\n').map((text, index) => (\n                                                    <span key={info._id + index.toString() + tab}>\n                                                        {text}\n                                                        <br />\n                                                    </span>\n                                                ))}\n                                            </ReviewText>\n                                        )}\n                                        <ReviewText style={{ marginTop: '8px' }}>\n                                            (담당 메이트: {info.reserve && info.reserve.call && info.reserve.call.mate ? info.reserve.call.mate.name : '-'})\n                                        </ReviewText>\n                                    </ReviewTextWrapper>\n                                </Panel>\n                            ))}\n                    </Collapse>\n                    <Pagination\n                        pageSize={PerPage}\n                        total={this.state.total}\n                        current={this.state.page}\n                        onChange={page => {\n                            this.setState({ page, list: [] }, () => {\n                                this.fetchList();\n                            });\n                        }}\n                    />\n                </CollapseContainer>\n            </div>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledListContainer from './review.styled';\nimport CommentList from './review';\n\nimport { getReviewList, editReview } from '../../../Reducer/Modules/review';\n\nclass CommentListPage extends React.PureComponent {\n    render() {\n        return (\n            <StyledListContainer>\n                <CommentList {...this.props} />\n            </StyledListContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, review }) => ({\n    app,\n    auth,\n    review,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    // getReviewList: page => dispatch(getReviewList({ page })),\n    editReview: ({ type, value }) => dispatch(editReview({ type, value })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CommentListPage);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\n\nconst StyledListContainer = styled.div`\n    padding-top: 55px;\n\n    .faq-header {\n        // border-bottom: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding: 0px;\n            padding-top: 82px;\n\n            @media (max-width: 768px) {\n                padding-top: 42px;\n            }\n\n            > .flex-wrapper {\n                position: relative;\n\n                .faq-main-title {\n                    flex: 1;\n                    .title {\n                        font-size: ${sizeHandler(30)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: #000000;\n                        margin-bottom: 8px;\n                    }\n\n                    .description {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-bottom: 82px;\n                    }\n                }\n\n                .img-section {\n                    position: absolute;\n                    bottom: -50px;\n                    right: 0px;\n\n                    > img {\n                        width: 100%;\n                        max-width: 549px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n\n                    @media (max-width: 768px) {\n                        display: none;\n                    }\n                }\n            }\n\n            .faq-nav {\n                display: flex;\n                align-items: center;\n\n                .nav-tab {\n                    margin-right: 32px;\n                    padding-bottom: 12px;\n                    position: relative;\n\n                    a {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #3bc1ff;\n                    }\n\n                    span.underline {\n                        background-color: #3bc1ff;\n                        position: absolute;\n                        bottom: 0px;\n                        left: 0px;\n\n                        &.active {\n                            width: 100%;\n                            height: 3px;\n                            display: inline-block;\n                        }\n                    }\n\n                    @media (max-width: 768px) {\n                        margin-right: 16px;\n                    }\n                }\n            }\n        }\n    }\n\n    .faq-contents {\n        .inner-container {\n            padding-top: 0px;\n\n            @media (max-width: 768px) {\n                h1 {\n                    font-size: 30px;\n                    margin-top: 60px;\n                }\n            }\n        }\n    }\n\n    .panel-header {\n        display: flex;\n        align-items: center;\n\n        .row-index {\n            width: 80px;\n            color: ${mainColor};\n            font-size: ${sizeHandler(14)};\n            font-weight: bold;\n        }\n\n        .title {\n            flex: 1;\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        @media (max-width: 768px) {\n            .title {\n                font-size: ${sizeHandler(14)};\n            }\n        }\n    }\n\n    .panel-content {\n        padding-left: 80px;\n\n        > p {\n            width: 60%;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .panel-contents-wrapper {\n            margin-top: 20px;\n            margin-bottom: 20px;\n\n            .panel-contents {\n                padding: 12px 0px;\n                border-bottom: 1px solid #e6e6e6;\n\n                &:first-child {\n                    border-top: 1px solid #e6e6e6;\n                }\n\n                .panel-content-subtitle {\n                    float: left;\n                    width: 40%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: left;\n                    color: ${mainColor};\n                }\n\n                .panel-content-subcontents {\n                    float: left;\n                    width: 50%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n\n                @media (max-width: 768px) {\n                    .panel-content-subtitle {\n                        width: 100%;\n                    }\n\n                    .panel-content-subcontents {\n                        width: 100%;\n                    }\n                }\n            }\n        }\n    }\n\n    h1 {\n        font-size: ${sizeHandler(34)};\n        font-weight: bold;\n        color: rgba(0, 0, 0, 0.8);\n        letter-spacing: -1px;\n\n        margin-bottom: 26px;\n        margin-top: 50px;\n    }\n\n    @media (max-width: 1120px) {\n        .faq-header {\n            .inner-container {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n        }\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .panel-header {\n            .row-index {\n                width: 70px;\n            }\n        }\n\n        .panel-content {\n            padding-left: 70px;\n\n            > p {\n                width: 90%;\n            }\n        }\n    }\n`;\nexport default StyledListContainer;\n","import React from 'react';\nimport { Collapse, Icon, Table } from 'antd';\n\nimport { CollapseContainer } from '../../../Review/List/list.styled';\nimport { newsEvent } from '../../../../Components/Columns/user';\n\nexport default class Event extends React.PureComponent {\n    onRow = (row, index) => {\n        return {\n            onClick: () => {\n                this.props.history.push({\n                    pathname: `/360F/newsEvent/info/${row._id}`,\n                    state: {\n                        id: row._id,\n                    },\n                });\n            },\n        };\n    };\n\n    render() {\n        return (\n            <div className='faq-container'>\n                <div className='faq-header'>\n                    <div className='inner-container'>\n                        <div className='flex-wrapper'>\n                            <div className='faq-main-title'>\n                                <p className='title'>위드메이트 소식</p>\n                                <p className='description'>위드메이트의 다양한 소식을 확인할 수 있습니다.</p>\n                            </div>\n                            <div className='img-section'>\n                                <img src={'/assets/images/comment_main.png'} style={{ width: '200px', height: 'auto', marginRight: '100px' }} alt='faq-img' />\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div className='faq-contents'>\n                    <CollapseContainer className='inner-container'>\n                        <Table\n                            rowKey='id'\n                            dataSource={this.props.newsEvent.newsEventList}\n                            columns={newsEvent}\n                            onRow={this.onRow}\n                            pagination={{\n                                pageSize: 10,\n                            }}\n                        />\n                    </CollapseContainer>\n                </div>\n            </div>\n        );\n    }\n}\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledListContainer from './list.styled';\nimport List from './list';\nimport { addNewsEvent, fetchNewsEvent, getNewsEventInfo } from '../../../../Reducer/Modules/newsEvent';\n\nclass InfoContainer extends React.PureComponent {\n    componentDidMount = () => {\n        this.props.fetchNewsEvent();\n    };\n\n    render() {\n        return (\n            <StyledListContainer>\n                <List {...this.props} />\n            </StyledListContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, newsEvent }) => ({\n    app,\n    auth,\n    newsEvent,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    fetchNewsEvent: () => dispatch(fetchNewsEvent()),\n    addNewsEvent: info => dispatch(addNewsEvent(info)),\n    getNewsEventInfo: ({ id, newsEventId }) => dispatch(getNewsEventInfo({ id, newsEventId })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(InfoContainer);\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\n\nconst StyledInfoContainer = styled.div`\n    padding-top: 55px;\n\n    .faq-header {\n        // border-bottom: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding: 0px;\n            padding-top: 82px;\n\n            @media (max-width: 768px) {\n                padding-top: 42px;\n            }\n\n            > .flex-wrapper {\n                position: relative;\n\n                .faq-main-title {\n                    flex: 1;\n                    .title {\n                        font-size: ${sizeHandler(30)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: #000000;\n                        margin-bottom: 8px;\n\n                        @media {\n                            padding-left: 10px;\n                        }\n                    }\n\n                    .description {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-bottom: 82px;\n\n                        @media {\n                            padding-left: 10px;\n                        }\n                    }\n                }\n\n                .img-section {\n                    position: absolute;\n                    bottom: -50px;\n                    right: 0px;\n\n                    > img {\n                        width: 100%;\n                        max-width: 549px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n\n                    @media (max-width: 768px) {\n                        display: none;\n                    }\n                }\n            }\n        }\n    }\n\n    .info-contents {\n        .inner-container {\n            padding-top: 0px;\n\n            @media (max-width: 768px) {\n                h1 {\n                    font-size: 30px;\n                    margin-top: 60px;\n                }\n            }\n\n            .img-section {\n                > img {\n                    max-width: 500px;\n                    height: auto;\n                    object-fit: cover;\n                }\n            }\n        }\n    }\n\n    h1 {\n        font-size: ${sizeHandler(34)};\n        font-weight: bold;\n        color: rgba(0, 0, 0, 0.8);\n        letter-spacing: -1px;\n\n        margin-bottom: 26px;\n        margin-top: 50px;\n    }\n\n    @media (max-width: 832px) {\n        .info-contents {\n            .inner-container {\n                .img-section {\n                    > img {\n                        max-width: 300px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n                }\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .faq-header {\n            .inner-container {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n        }\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .panel-header {\n            .row-index {\n                width: 70px;\n            }\n        }\n\n        .panel-content {\n            padding-left: 70px;\n\n            > p {\n                width: 90%;\n            }\n        }\n    }\n`;\n\nexport default StyledInfoContainer;\n","import React from 'react';\nimport axios from '../../../../Lib/axios';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport { Button, message, Table } from 'antd';\nimport { CollapseContainer } from '../../../Review/List/list.styled';\n\nimport { InfoBlock } from '../../../../Components/Common/block';\n\nexport default class Event extends React.PureComponent {\n    state = {\n        data: {},\n    };\n\n    componentDidMount = () => {\n        const { state } = this.props.history.location;\n        if (!state || !state.id) return this.props.history.goBack();\n\n        this.fetchInfo(state.id);\n    };\n\n    fetchInfo = async id => {\n        const { data } = await axios.get('/v1/newsEvent/list/info', {\n            params: {\n                newsEventId: id,\n            },\n        });\n\n        if (!data || data === 'check parameters') {\n            return this.props.history.goBack();\n        }\n\n        if (data === 'invalid newEvent') {\n            return message.warning('잘못된 게시물 정보입니다.');\n        }\n\n        this.setState({ ...data });\n    };\n\n    render() {\n        const { url, url2, urlSource, urlSource2 } = this.state;\n\n        return (\n            <div className='faq-container'>\n                <div className='faq-header'>\n                    <div className='inner-container'>\n                        <div className='flex-wrapper'>\n                            <div className='faq-main-title'>\n                                <p className='title'>위드메이트 소식</p>\n                                <p className='description'>위드메이트의 다양한 소식을 확인할 수 있습니다.</p>\n                            </div>\n                            <div className='img-section'>\n                                <img src={'/assets/images/comment_main.png'} style={{ width: '200px', height: 'auto', marginRight: '100px' }} alt='faq-img' />\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div className='info-contents'>\n                    <CollapseContainer className='inner-container' style={{ width: '80%', margin: 'auto' }}>\n                        <>\n                            <ValueBox>\n                                <Label style={{ fontSize: '25px' }}>{this.state.title}</Label>\n                            </ValueBox>\n\n                            <ValueBox style={{ textAlign: 'right' }}>\n                                <InfoBlock label='작성일' value={moment(this.state.createdAt).format('YYYY년 MM월 DD일 dddd')} />\n                            </ValueBox>\n\n                            <ValueBox>\n                                {this.state.photo && (\n                                    <div className='img-section' style={{ display: 'flex', justifyContent: 'center' }}>\n                                        <img\n                                            style={{ objectFit: 'contain' }}\n                                            src={typeof this.state.photo === 'string' ? this.state.photo : URL.createObjectURL(this.state.photo)}\n                                            alt='사진'\n                                        />\n                                    </div>\n                                )}\n                            </ValueBox>\n\n                            <ValueBox>\n                                <InfoBlock label='내용'>\n                                    <p style={{ whiteSpace: 'pre-wrap' }}>{this.state.content} </p>\n                                </InfoBlock>\n                                {this.state.url ? (\n                                    <InfoBlock label='링크'>\n                                        {url ? (\n                                            <a href={this.state.url} target='_blank' style={{ fontSize: '15px', color: '#3bc1ff' }}>\n                                                ㆍ{urlSource}\n                                            </a>\n                                        ) : (\n                                            ''\n                                        )}{' '}\n                                        <br />\n                                        {url2 ? (\n                                            <a href={this.state.url2} target='_blank' style={{ fontSize: '15px', color: '#3bc1ff' }}>\n                                                ㆍ{urlSource2}\n                                            </a>\n                                        ) : (\n                                            ''\n                                        )}\n                                    </InfoBlock>\n                                ) : null}\n                            </ValueBox>\n\n                            <ValueBox>\n                                <Button\n                                    className='white'\n                                    onClick={() => {\n                                        this.props.history.goBack();\n                                    }}\n                                    style={{ float: 'right' }}\n                                >\n                                    목록으로\n                                </Button>\n                            </ValueBox>\n                        </>\n                    </CollapseContainer>\n                </div>\n            </div>\n        );\n    }\n}\n\nexport const ValueBox = styled.div`\n    margin-bottom: 16px;\n`;\n\nexport const Label = styled.p`\n    text-align: left;\n    font-size: 11px;\n    margin-bottom: 4px;\n    color: #565656;\n`;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport StyledInfoContainer from './info.styled';\nimport Info from './info';\nimport { addNewsEvent, fetchNewsEvent, getNewsEventInfo } from '../../../../Reducer/Modules/newsEvent';\n\nclass InfoContainer extends React.PureComponent {\n    componentDidMount = () => {\n        const { id } = this.props.auth;\n        const { state } = this.props.location;\n        const { id: newsEventId } = this.props.match.params;\n\n        // console.log(newsEventId, state);\n\n        if (state === 'newsEvent') this.props.getNewsEventInfo({ newsEventId });\n    };\n\n    render() {\n        return (\n            <StyledInfoContainer>\n                <Info {...this.props} />\n            </StyledInfoContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({ app, auth, newsEvent }) => ({\n    app,\n    auth,\n    newsEvent,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    fetchNewsEvent: () => dispatch(fetchNewsEvent()),\n    addNewsEvent: info => dispatch(addNewsEvent(info)),\n    getNewsEventInfo: ({ id, newsEventId }) => dispatch(getNewsEventInfo({ id, newsEventId })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(InfoContainer);\n","import React from 'react';\nimport { Switch, Route } from 'react-router-dom';\n\n// pages\nimport List from './List';\nimport Info from './Info';\n\nclass NewsEvent extends React.PureComponent {\n    render() {\n        return (\n            <Switch>\n                <Route exact path='/360F/newsEvent/list' component={List} />\n                <Route exact path='/360F/newsEvent/info/:id' component={Info} />\n            </Switch>\n        );\n    }\n}\nexport default NewsEvent;\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../theme';\n\nconst StyledFaqContainer = styled.div`\n    padding-top: 55px;\n\n    .faq-header {\n        border-bottom: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding: 0px;\n            padding-top: 82px;\n\n            @media (max-width: 768px) {\n                padding-top: 42px;\n            }\n\n            > .flex-wrapper {\n                position: relative;\n\n                .faq-main-title {\n                    flex: 1;\n                    .title {\n                        font-size: ${sizeHandler(44)};\n                        font-weight: bold;\n                        letter-spacing: -0.6px;\n                        color: #000000;\n                        margin-bottom: 8px;\n                    }\n\n                    .description {\n                        font-size: ${sizeHandler(14)};\n                        letter-spacing: -0.3px;\n                        color: rgba(0, 0, 0, 0.8);\n                        margin-bottom: 82px;\n                    }\n                }\n\n                .img-section {\n                    position: absolute;\n                    bottom: 0px;\n                    right: 0px;\n\n                    > img {\n                        width: 100%;\n                        max-width: 549px;\n                        height: auto;\n                        object-fit: cover;\n                    }\n\n                    @media (max-width: 768px) {\n                        display: none;\n                    }\n                }\n            }\n\n            .faq-nav {\n                display: flex;\n                align-items: center;\n\n                .nav-tab {\n                    margin-right: 32px;\n                    padding-bottom: 12px;\n                    position: relative;\n\n                    a {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        text-align: center;\n                        color: #3bc1ff;\n                    }\n\n                    span.underline {\n                        background-color: #3bc1ff;\n                        position: absolute;\n                        bottom: 0px;\n                        left: 0px;\n\n                        &.active {\n                            width: 100%;\n                            height: 3px;\n                            display: inline-block;\n                        }\n                    }\n\n                    @media (max-width: 768px) {\n                        margin-right: 16px;\n                    }\n                }\n            }\n        }\n    }\n\n    .faq-contents {\n        .inner-container {\n            padding-top: 0px;\n\n            @media (max-width: 768px) {\n                h1 {\n                    font-size: 30px;\n                    margin-top: 60px;\n                }\n            }\n        }\n    }\n\n    .panel-header {\n        display: flex;\n        align-items: center;\n\n        .row-index {\n            width: 80px;\n            color: ${mainColor};\n            font-size: ${sizeHandler(14)};\n            font-weight: bold;\n        }\n\n        .title {\n            flex: 1;\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        @media (max-width: 768px) {\n            .title {\n                font-size: ${sizeHandler(14)};\n            }\n        }\n    }\n\n    .panel-content {\n        padding-left: 80px;\n\n        > p {\n            width: 60%;\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .panel-contents-wrapper {\n            margin-top: 20px;\n            margin-bottom: 20px;\n\n            .panel-contents {\n                padding: 12px 0px;\n                border-bottom: 1px solid #e6e6e6;\n\n                &:first-child {\n                    border-top: 1px solid #e6e6e6;\n                }\n\n                .panel-content-subtitle {\n                    float: left;\n                    width: 40%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    text-align: left;\n                    color: ${mainColor};\n                }\n\n                .panel-content-subcontents {\n                    float: left;\n                    width: 50%;\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                }\n\n                @media (max-width: 768px) {\n                    .panel-content-subtitle {\n                        width: 100%;\n                    }\n\n                    .panel-content-subcontents {\n                        width: 100%;\n                    }\n                }\n            }\n        }\n    }\n\n    h1 {\n        font-size: ${sizeHandler(34)};\n        font-weight: bold;\n        color: rgba(0, 0, 0, 0.8);\n        letter-spacing: -1px;\n\n        margin-bottom: 26px;\n        margin-top: 50px;\n    }\n\n    @media (max-width: 1120px) {\n        .faq-header {\n            .inner-container {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n        }\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .panel-header {\n            .row-index {\n                width: 70px;\n            }\n        }\n\n        .panel-content {\n            padding-left: 70px;\n\n            > p {\n                width: 90%;\n            }\n        }\n    }\n`;\nexport default StyledFaqContainer;\n","import React from 'react';\nimport { HashLink } from 'react-router-hash-link';\nimport { Collapse, Icon } from 'antd';\nimport { mainColor } from '../../../theme';\nconst { Panel } = Collapse;\n\nexport default class FAQ extends React.PureComponent {\n    render() {\n        const { hash } = this.props.location;\n        return (\n            <div className='faq-container'>\n                <div className='faq-header'>\n                    <div className='inner-container'>\n                        <div className='flex-wrapper'>\n                            <div className='faq-main-title'>\n                                <p className='title'>위드메이트 FAQ</p>\n                                <p className='description'>고객님의 궁금증을 해소하세요!</p>\n                            </div>\n                            <div className='img-section'>\n                                <img src={'/assets/images/faq_bg2.png'} alt='faq-img' />\n                            </div>\n                            <div className='faq-nav'>\n                                <div className='nav-tab'>\n                                    <HashLink className='name' to='/360F/faq/#common' scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'start' })}>\n                                        공통 FAQ\n                                    </HashLink>\n                                    <span className={`underline ${hash === '#common' ? 'active' : undefined}`}></span>\n                                </div>\n                                <div className='nav-tab'>\n                                    <HashLink\n                                        className='name'\n                                        to='/360F/faq/#emergency'\n                                        scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'start' })}\n                                    >\n                                        병원 동행 Pro FAQ\n                                    </HashLink>\n                                    <span className={`underline ${hash === '#emergency' ? 'active' : undefined}`}></span>\n                                </div>\n                                <div className='nav-tab'>\n                                    <HashLink className='name' to='/360F/faq/#assist' scroll={el => el.scrollIntoView({ behavior: 'smooth', block: 'start' })}>\n                                        병원 동행 Basic FAQ\n                                    </HashLink>\n                                    <span className={`underline ${hash === '#assist' ? 'active' : undefined}`}></span>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div className='faq-contents'>\n                    <div className='inner-container'>\n                        <h1 id='common'>공통 FAQ</h1>\n                        <div>\n                            <Collapse\n                                expandIconPosition='right'\n                                bordered={false}\n                                expandIcon={({ isActive }) => (\n                                    <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? mainColor : '#a7a7a7' }} />\n                                )}\n                            >\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-1' title='동행인의 신원은 확실한가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            현재 위드메이트는 적격 자격을 갖춘 인원들을 선별하고 세밀한 채용 단계를 거친 후, 영업 배상 책임 보험 가입과 함께\n                                            엄격한 자체 교육을 실시하며 서비스 인력을 모집하고 있습니다.\n                                            <br />\n                                            이와 동시에 위드메이트가 진행하는 주기적인 교육과 점검을 통해 서비스를 제공하는 인력 모두가 건강한 긴장감을 놓치지\n                                            않도록 철저하게 관리하고 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-2' title='서비스 신청 방법에 대해 알려주세요.' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트 서비스는 웹사이트를 통해 신청이 가능합니다. 웹사이트 내 서비스 신청 모듈을 통해 서비스 신청을 해주시면\n                                            됩니다. 회원 가입 진행을 완료하신 분이라면 전화 상담을 통한 예약 신청 또한 가능합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-3' title='서비스 신청 후 절차가 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            예약 접수가 완료되면, 위드메이트 소속의 전문 동행인들은 예약 발생 알림을 받고 검토를 진행하게 됩니다. 이후 동행인이\n                                            예약을 접수하면 고객님께 ‘예약 완료’ 알림이 가고, 고객님께서 해당 동행인의 접수를 수락하시면 최종 ‘매칭’이\n                                            이루어집니다. 이후 예약 일정에 맞춰 동행인과 함께 병원에 방문하시면 됩니다. 고객님께서 동행인의 접수를 거절하시면\n                                            처음 단계로 돌아가 다른 동행인의 접수를 대기하게 됩니다.\n                                            <br />\n                                            만약 동행인 접수가 불가한 경우 고객님께 예약 불가 알림이 가고, 추후 서비스 재신청을 통해 서비스를 받을 수 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-4' title='위드메이트 서비스 이용 가능 지역은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트의 서비스는 현재 수도권 내에서 이용 가능합니다. 빠른 시일 내 경기도를 포함한 타 지역 서비스 확장을 계획\n                                            중에 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-5' title='예약 변경 및 취소 수수료는 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>고객님께서 정상적으로 매칭된 병원 동행 서비스 계약을 취소 및 변경하는 경우에는 아래와 같이 수수료가 발생합니다.</p>\n                                        <div className='panel-contents-wrapper'>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>서비스 예약 날짜 기준 48시간 이내 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>수수료 없이 변경 & 취소 가능</p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>서비스 예약 전날 18:00 이전 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>\n                                                    취소 시 수수료 10,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과 X\n                                                </p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>당일 예약 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>\n                                                    취소 시 수수료 15,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과 X\n                                                </p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>서비스 시작 2시간 전 이내 변경 및 취소</p>\n                                                <p className='panel-content-subcontents'>\n                                                    취소 시 수수료 20,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과 X\n                                                </p>\n                                                <div className='clearfix' />\n                                            </div>\n                                            <div className='panel-contents'>\n                                                <p className='panel-content-subtitle'>노쇼(No-Show)의 경우</p>\n                                                <p className='panel-content-subcontents'>회원 자격 정지 및 민/형사상 책임 소지를 물을 수 있음</p>\n                                                <div className='clearfix' />\n                                            </div>\n                                        </div>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-6' title='회사측의 과실로 예약일정을 소화 못하면 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            회사측의 과실로 예약된 서비스를 이용하지 못한 경우 서비스 요금을 전액 배상해드리며, 상황에 따라 서비스 무료 이용권\n                                            등의 추가 배상을 진행합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-7' title='예약 장소에서 담당 동행인을 어떻게 찾나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            예약 접수 후 동행인 매칭이 완료되면 ‘마이페이지’ 내에서 동행인의 정보를 확인하실 수 있으며, 해당 정보를 통해\n                                            동행인과 서비스 관련 소통을 진행하시면 됩니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-8' title='예약한 시간보다 진료나 귀가가 늦어져 서비스 시간이 추가되면 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트 서비스는 후불제이기 때문에 예약한 서비스 시간을 넘어 추가 서비스가 이루어지는 경우, 해당 시간만큼의 추가\n                                            비용이 발생합니다. 서비스 종료 후 추가된 금액이 포함된 최종 요금을 결제하시면 됩니다. 추가 비용은 서비스 시간 15분\n                                            미만 초과 시 발생하지 않으며, 15분을 초과할 시 30분 단위의 요금이 발생합니다.\n                                            <br />\n                                            (Ex. 2시간 예약 서비스가 최종 2시간 14분으로 종료 > 추가 요금 발생 X)\n                                            <br />\n                                            (Ex. 2시간 예약 서비스가 최종 2시간 16분으로 종료 > 추가 요금 발생 O)\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='1-9' title='위드메이트 서비스는 사용 가능 시간이 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            위드메이트의 모든 서비스는 주 5일 (월~금), 1일 10시간 (오전 9시 ~ 오후 7시) 동안 이용 가능합니다. 주말 및 공휴일에는\n                                            서비스 제공을 하지 않습니다. 하지만 특수 예약에 대해서는 해당 시간 외에도 서비스를 제공할 수 있습니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                            </Collapse>\n                        </div>\n                        <h1 id='emergency'>병원 동행 Pro FAQ</h1>\n                        <div>\n                            <Collapse\n                                expandIconPosition='right'\n                                bordered={false}\n                                expandIcon={({ isActive }) => (\n                                    <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? mainColor : '#a7a7a7' }} />\n                                )}\n                            >\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-1' title='병원 동행 Pro는 정확히 어떤 경우에 신청할 수 있나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Pro는 응급 상황에 처하지는 않았으나 정기적, 혹은 비정기적으로 의료 기관에 방문해 의료 조치를 받아야 하는\n                                            경우에 신청 가능합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-2' title='서비스 요금은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Pro 서비스 요금은 시간 당 25,000원입니다. 또, 고객 소유의 차량을 메이트가 운행하여 동행할 경우 20,000원이\n                                            추가됩니다 (택시 등 대중 교통을 이용할 경우 추가 요금은 없으나 해당 교통비 개별 부담). 모든 서비스 비용은 VAT 포함\n                                            가격입니다.\n                                            <br />\n                                            (Ex. 2시간 예약 + 고객 소유 차량 운행 선택 시 > 기본 요금 50,000원 + 차량 운행비 20,000원 = 70,000원)\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-3' title='동행인의 성별은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>남성과 여성 인력이 모두 대기 중입니다.</p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-4' title='서비스는 어떤 형식으로 이루어지나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            예약일과 시간에 맞춰 위드메이트 소속의 동행인이 병원 출발지(고객님 자택 등)로 도착합니다. 이후 서비스 신청에 따라\n                                            고객 소유의 차량을 통해 이동할 경우 동행인이 차량을 운행하고 병원까지 이동하며(택시 등의 대중 교통 이용 시 해당 비용\n                                            자가 부담), 병원 내에서 이루어지는 모든 활동에 동행합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-5' title='동행인은 어떤 사람들인가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            동행인은 철저하게 선별되고 영업배상책임보험에 가입되어 있으며, 위드메이트가 자체적으로 실시하는 엄격한 서비스 교육을\n                                            모두 이수하고 통과한 전문가입니다. 또, 위드메이트의 동행인은 국립 암센터에서 실시하는 주기적인 암 환자 관리 교육 및\n                                            세미나에 지속적으로 참여해 서비스 품질과 전문성이 보장된 인력들입니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='2-6' title='중증 또는 휠체어 등의 의료 기구 대동이 필요한 환자도 이용 가능한가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            중증 또는 휠체어 등의 의료 기구 대동이 필요한 환자에 대한 비응급 의료 동행 서비스는 준비 중에 있습니다. 현\n                                            서비스로는 해당 인원과의 동행은 불가하며, 예약이 접수된 경우 개별적인 연락을 통해 예약 불가를 알려드립니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={\n                                        <PanelHeader\n                                            rowIndex='2-7'\n                                            title='단발성이 아니라 수회에 걸쳐서 정기적으로 위드메이트 서비스를 이용하고 싶은데 이 같은 경우 예약을 어떻게 하나요?'\n                                        />\n                                    }\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            방사선이나 암 치료와 같이 주기적으로 내원이 필요한 경우 개별 상담을 통해 예약이 가능합니다. 위드메이트 서비스를 장기\n                                            예약할 경우 특별 할인 혜택 또한 제공되고 있습니다. 서비스 센터로 문의 주실 경우 위드메이트의 전문 상담원이\n                                            안내해드립니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                            </Collapse>\n                        </div>\n                        <h1 id='assist'>병원 동행 Basic FAQ</h1>\n                        <div>\n                            <Collapse\n                                expandIconPosition='right'\n                                bordered={false}\n                                expandIcon={({ isActive }) => (\n                                    <Icon type='right' rotate={isActive ? 90 : -90} style={{ color: isActive ? mainColor : '#a7a7a7' }} />\n                                )}\n                            >\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-1' title='병원 동행 Basic은 정확히 어떤 경우에 신청할 수 있나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Basic은 주로 수술의 범주에는 속하지 않지만 마취 혹은 단순 보호자가 필요한 수면 내시경 등을 포함한 모든\n                                            종류의 시술을 해야 할 경우에 신청합니다. 물론 Pro 서비스를 받아야 하지만 자택에서 병원, 다시 병원에서 자택까지의\n                                            동행 과정을 필요로 하지 않는 상황에서도 신청이 가능합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-2' title='서비스 요금은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            병원 동행 Basic 요금은 시간 당 15,000원입니다. (Ex. 2시간 예약 시 30,000원)\n                                            <br /> 모든 서비스 비용은 VAT 포함 가격입니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-3' title='동행인은 어떤 사람들인가요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>병원 동행 Basic 서비스 동행인은 Pro 서비스와 동일한 인력으로 구성되어 있습니다.</p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-4' title='동행인의 성별은 어떻게 되나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>남성과 여성 인력이 모두 대기 중입니다.</p>\n                                    </PanelContent>\n                                </Panel>\n                                <Panel\n                                    style={{ backgroundColor: '#ffffff', borderColor: '#e6e6e6' }}\n                                    header={<PanelHeader rowIndex='3-5' title='서비스는 어떤 형식으로 이루어지나요?' />}\n                                >\n                                    <PanelContent>\n                                        <p>\n                                            고객님께서 지정하신 병원에서 동행자와 접선 후, 동행자는 예약자의 진료 접수부터 종료 시점까지 병원 내부에서\n                                            대기합니다. 진료 종료 후, 동행자는 예약자의 의사를 확인한 후 업무를 마치고 복귀합니다.\n                                        </p>\n                                    </PanelContent>\n                                </Panel>\n                            </Collapse>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n\nconst PanelHeader = ({ rowIndex, title }) => {\n    return (\n        <div className='panel-header'>\n            <p className='row-index'>{rowIndex}</p>\n            <p className='title'>{title}</p>\n        </div>\n    );\n};\n\nconst PanelContent = ({ children }) => {\n    return <div className='panel-content'>{children}</div>;\n};\n","import React from 'react';\nimport StyledFaqContainer from './faq.styled';\nimport FAQ from './faq';\n\nclass FAQContainer extends React.PureComponent {\n    render() {\n        return (\n            <StyledFaqContainer>\n                <FAQ {...this.props} />\n            </StyledFaqContainer>\n        );\n    }\n}\nexport default FAQContainer;\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\nconst PrivacyStyledContainer = styled.div`\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .medium-bold {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n\n                .in {\n                    font-size: ${sizeHandler(13)};\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                    text-indent: -20px;\n                    padding-left: 40px;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default PrivacyStyledContainer;\n","import React from 'react';\n\nclass PrivacyComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='privacy-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>㈜ 블루카멜 개인정보처리방침</h2>\n                        <p>\n                            병원동행서비스 위드메이트(www.withmate.kr, 이하 “서비스\")를 운영하는 (주)블루카멜(이하 “회사”)은 「개인정보보호법」 제30조에 따라\n                            정보주체의 개인정보를 보호하고 이와 관련한 고충을 신속하고 원활하게 처리할 수 있도록 다음과 같이 개인정보처리방침(이하 \"방침\")을\n                            수립 및 공개합니다. 개인정보처리방침은 관련 법령 또는 지침, 회사의 약관 또는 정책에 따라 변경될 수 있습니다. 회사는 해당 변경 사항을\n                            온라인 게시 등의 방법으로 이용자에게 알립니다.\n                            <br />\n                            <br />이 개인정보처리방침은 2023년 7월 25일부터 적용됩니다.\n                        </p>\n                        <br />\n                        <br />\n                        <br />\n\n                        <p style={{ fontSize: '20px' }}>\n                            <a\n                                href='https://docs.google.com/document/d/e/2PACX-1vTQ3CepPqUO6BqEg8va9_5e0zZg7V1nMuK7xiibF1Nxa2RQAX1C5xv3p4mnIVmkeeh_ClORu1P3Fs0p/pub'\n                                target='_blank'\n                                style={{ color: 'gray' }}\n                            >\n                                ✅ 개인정보처리방침 2차(2023.07.22)\n                            </a>\n                        </p>\n                        <p style={{ fontSize: '20px' }}>\n                            <a\n                                href='https://docs.google.com/document/d/e/2PACX-1vQTjHkJBb2VK4gofoPrHZVYbgCOvOgDDvClVJjwYpx7ikkLFW37GUlFS5Hwa8osGb7a7mNbg55qlEMu/pub'\n                                target='_blank'\n                                style={{ color: 'gray' }}\n                            >\n                                ✅ 개인정보처리방침 1차(2021.12.20)\n                            </a>\n                        </p>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default PrivacyComponent;\n","import React from 'react';\n\n// component\nimport PrivacyStyledContainer from './privacy.styled';\nimport Privacy from './privacy';\n\nclass PrivacyContainer extends React.PureComponent {\n    render() {\n        return (\n            <PrivacyStyledContainer component={this.props.isComponent || undefined}>\n                <Privacy {...this.props} />\n            </PrivacyStyledContainer>\n        );\n    }\n}\n\nexport default PrivacyContainer;\n","import styled from 'styled-components';\nimport { sizeHandler, mainColor } from '../../../../theme';\nconst TermsStyledContainer = styled.div`\n    .inner-container {\n        ${props => props.component && `padding: 0px !important;`}\n    }\n    .main-context {\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        h2 {\n            ${props => props.component && `display: none;`}\n            font-size: ${sizeHandler(44)};\n            font-weight: bold;\n            letter-spacing: -0.6px;\n            color: #000000;\n            margin-bottom: 24px;\n        }\n\n        p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            padding: 0px;\n            margin: 0px;\n        }\n    }\n\n    .context-block {\n        margin-top: ${props => (props.component ? '24px' : '100px')};\n        padding-top: 24px;\n        border-top: 1px solid #e6e6e6;\n        width: ${props => (props.component ? '100%' : '60%')};\n\n        > h3 {\n            font-size: ${sizeHandler(24)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 16px;\n        }\n\n        > h6 {\n            font-size: ${sizeHandler(16)};\n            font-weight: normal;\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.8);\n            margin-bottom: 24px;\n        }\n\n        > h5 {\n            font-size: ${sizeHandler(18)};\n            font-weight: bold;\n            color: rgba(0, 0, 0, 0.8);\n            margin-top: 20px;\n            margin-bottom: 12px;\n        }\n\n        > p {\n            font-size: ${sizeHandler(14)};\n            letter-spacing: -0.3px;\n            color: rgba(0, 0, 0, 0.7);\n        }\n\n        > .privacy-justify {\n            display: flex;\n            align-items: center;\n            ${props => props.component && `display: block;`}\n\n            p {\n                flex: 1;\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n\n                &:first-child {\n                    text-align: left;\n                }\n\n                &:last-child {\n                    text-align: right;\n                    ${props => props.component && `text-align: left;`}\n                }\n            }\n        }\n\n        > .info {\n            margin-top: 8px;\n            .title {\n                border-bottom: 1px solid #e6e6e6;\n                padding: 24px 0px;\n                font-size: ${sizeHandler(14)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n                margin: 0px;\n\n                .bold {\n                    font-size: ${sizeHandler(14)};\n                    font-weight: bold;\n                    color: rgba(0, 0, 0, 0.7);\n                    margin: 0px;\n                    padding: 0px;\n                    margin-bottom: 4px;\n                    display: block;\n                }\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.7);\n                padding: 20px 0px;\n                border-bottom: 1px solid #e6e6e6;\n            }\n        }\n\n        > .info-block {\n            margin-top: 68px;\n\n            .title {\n                font-size: ${sizeHandler(18)};\n                font-weight: bold;\n                color: rgba(0, 0, 0, 0.8);\n                margin-bottom: 8px;\n            }\n\n            .content {\n                font-size: ${sizeHandler(14)};\n                line-height: ${sizeHandler(24)};\n                letter-spacing: -0.3px;\n                color: rgba(0, 0, 0, 0.7);\n            }\n        }\n    }\n\n    @media (max-width: 1120px) {\n        .inner-container {\n            padding-left: 16px;\n            padding-right: 16px;\n        }\n    }\n\n    @media (max-width: 768px) {\n        .main-context {\n            width: 100%;\n\n            h2 {\n                font-size: ${sizeHandler(38)};\n            }\n        }\n\n        .context-block {\n            width: 100%;\n        }\n\n        .privacy-justify {\n            flex-direction: column;\n\n            p {\n                &:first-child {\n                    text-align: center;\n                }\n                &:last-child {\n                    text-align: center;\n                }\n            }\n        }\n    }\n`;\nexport default TermsStyledContainer;\n","import React from 'react';\n\nclass TermsComponent extends React.PureComponent {\n    render() {\n        return (\n            <div className='terms-container'>\n                <div className='inner-container'>\n                    <div className='main-context'>\n                        <h2>위드메이트 서비스 이용약관</h2>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 1조(목적)</h3>\n                        <p>\n                            본 약관은 ㈜블루카멜(이하 “회사”라 한다)가 제공하는 위드메이트 병원 동행 서비스와 관련하여 회사와 회원과의 권리,\n                            <br />\n                            의무 및 책임 사항, 그리고 기타 필요한 사항을 규정함을 목적으로 합니다.\n                        </p>\n                        <br />\n                        <p>본 서비스 이용약관은 2021년 12월 20일부터 시행됩니다.</p>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 2조(정의)</h3>\n                        <h5>1. 본 약관에서 사용하는 용어의 정의는 다음과 같습니다.</h5>\n\n                        <div className='info'>\n                            <p className='title'>“위드메이트 서비스” 혹은 “서비스”라 함은 당사가 제공하는 ‘병원 동행 서비스’를 의미합니다.</p>\n                            <p className='title'>\n                                “회원”이라 함은 회사가 제공하는 서비스를 이용하기 위하여 본 약관에 동의하고 회사의 회원으로 가입하는 자를 말합니다. (단,\n                                메이트와 관련된 사실 관계에 한하여, 메이트도 본 약관에서 “회원”에 포함될 수 있습니다)\n                            </p>\n                            <p className='title'>\n                                “메이트”라 함은 회사가 회원에게 서비스를 제공하기 위해 직접 선별하고 교육하여 ‘프리랜서’의 형태로 간접 고용한 인원을 말합니다.\n                            </p>\n                            <p className='title'>\n                                “운송사업자\"라 함은 여객자동차 운수사업법 제4조에 따른 면허를 받은 여객자동차 운송사업자로서, 회사(메이트 인력)의 중개 또는 회원\n                                스스로를 통해 택시 등 그 면허를 받은 운송 수단을 이용하여 운송서비스를 제공하는 자를 의미합니다.\n                            </p>\n                            <p className='title'>\n                                “중개”라 함은 회사가 직접 서비스를 제공하지 않고, 이용자 또는 회원의 요청에 따라 적격 메이트를 연결하여 알선하는 것을\n                                의미합니다.\n                            </p>\n                            <p className='title'>\n                                “매칭”이라 함은 회원이 플랫폼(웹사이트 포함)에서 출발지와 목적지를 입력하고, “예약하기\" 버튼을 통해 서비스 이용을 요청(이하\n                                “이용 요청”이라고 합니다)하면, 요청 시점에 서비스 제공이 가능한 메이트가 플랫폼(웹사이트 포함)을 통하여\n                                수락함으로써(매칭됨으로써), 회원과 회사 사이의 메이트 알선 계약이 각 체결된 상태를 의미합니다.\n                            </p>\n                            <p className='title'>\n                                “플랫폼(웹사이트 포함)”이라 함은 회사가 회원에게 서비스를 제공하기 위하여 개발한 위드메이트 애플리케이션과 웹사이트를\n                                의미합니다.\n                            </p>\n                            <p className='title'>\n                                “이용요금”이라 함은\n                                <br />\n                                (i) 메이트가 제공하는 의료 동행 서비스에 대한 비용\n                                <br />\n                                (ii) 회원이 택시 등 운송사업자의 운송 수단을 예약하거나 호출하여 이동하는 비용,\n                                <br />\n                                (iii) 기타 비용(고객 소유 자가용 대리 운전 비용, 예약 취소 및 변경 수수료 등)을 총칭하여 의미합니다.\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '56px' }}>\n                            2. 본 약관에서 사용하는 용어의 정의는 본 조제 1항에서 정하는 것을 제외하고는 관계 법령에서 정하는 바에 의합니다. 관계 법령에서\n                            정하지 않는 것은 일반적인 상 관례에 의합니다.\n                        </h5>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 3조(약관의 효력 및 변경)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            약관은 애플리케이션 소프트웨어 및 해당 애플리케이션과 웹사이트의 모든 패치, 업데이트, 업그레이드 또는 새로운 버전에 적용되며, 가장\n                            최신 버전이 모든 기존 버전에 우선합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            본 약관은 서비스 이용계약의 성격상 회사의 웹사이트 또는 서비스 이용을 위한 애플리케이션 내에 본 약관을 명시하고, 이용자가\n                            애플리케이션을 설치 및 실행 혹은 웹사이트 열람과 동시에 효력이 발생합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>회사는 관계 법령 또는 상관습에 위배되지 않는 범위에서 본 약관을 개정할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사는 관련 법령의 변경이나 이용자의 권리 및 의무사항, 서비스 등을 개선하기 위해 본 약관을 변경할 수 있으며, 변경된 경우에 약관의\n                            내용과 적용일을 정하여, 적용일 7일 전 회사 공식 홈페이지나 공식 블로그, 제공하는 애플리케이션 등을 통해 이용자에게 고지하고\n                            적용일부터 효력이 발생합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            이용자는 변경된 약관에 대해 거부할 권리가 있습니다. 본 약관의 변경에 대해 이의가 있는 이용자는 서비스 이용을 중단하고 이용을\n                            해지(탈퇴 및 삭제)할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회사가 본 조 4항에 따라 변경된 약관을 공시 또는 고지하면서 이용자가 기간 내의 의사표시를 하지 않으면 변경된 약관에 동의한 것으로\n                            간주합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 4조(약관 외 준칙)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 필요한 경우 특정 서비스에 관하여 적용될 사항을 위해 개별 약관이나 이용 정책을 정하여 운영할 수 있으며, 해당 내용은 홈페이지\n                            등을 통해 공지합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            본 약관에 규정되지 않은 사항에 대해서는 관련 법령 또는 개별 약관, 이용 정책, 서비스 이용 화면을 통하여 제시된 개별 이용 조건(이용\n                            요금 등, 이하 “개별계약“이라고 합니다)에서 정한 바에 따릅니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            본 약관과 개별 약관, 개별 계약의 내용이 충돌할 경우 본 약관에 별도의 규정이 없는 한 개별 계약 또는 개별 약관에서 정한 바에 따릅니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회원은 서비스 이용 시 개별 계약 또는 개별 약관의 내용을 확인하여야 하며, 이를 확인하지 않아 발생한 손해에 대해 회사는 책임을\n                            부담하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 5조(이용 계약의 성립)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            이용 계약은 이용자가 본 이용 약관에 대한 동의 또는 회사의 애플리케이션을 다운로드 받거나 실행하여 이용하는 경우, 그리고 웹사이트\n                            회원 가입을 완료한 경우 이 약관에 동의한 것으로 간주합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>이용자는 동의하지 않는 경우 애플리케이션이나 웹사이트 계정 로그아웃 및 삭제와 함께 이를 철회할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 제 1항에 따른 회원 가입 신청에 대해 승낙함을 원칙으로 합니다. 다만, 다음 각 호의 경우 회사는 회원 가입 신청을 승낙하지 않거나\n                            사후에 회원 계약을 해지할 수 있습니다.\n                        </h6>\n\n                        <div className='info'>\n                            <p className='title'>신청자가 본 약관 위반 등의 사유로 이전에 회원 자격이 상실 또는 회원 계약이 해지되었던 경우</p>\n                            <p className='title'>자신의 귀책으로 이용 정지를 당한 회원이 그 이용 정지 기간 중에 이용 계약을 임의 해지하고 재신청을 하는 경우</p>\n                            <p className='title'>본 약관에 위배되거나 위법 또는 사회상규상 부당한 가입 신청임이 확인된 경우</p>\n                            <p className='title'>허위의 정보를 기재한 경우, 회사가 제시하는 내용을 기재하지 않은 경우 또는 오기 등이 있는 경우</p>\n                            <p className='title'>미성년자 등 법령상 행위 무능력자인 경우</p>\n                            <p className='title'>기타 신청자의 귀책 사유로 인하여 승낙이 불가능하거나 기타 회사가 정한 제반 사항을 위반한 자의 신청</p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            서비스 신청자가 대리인일 경우, 해당 서비스 수혜자에 대한 모든 정보는 사실에 근거하여 제공되어야 하며, 허위 사실 기재 시 발생하는\n                            모든 민형사상 책임은 신청자에게 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 6조(회원 계약의 해제 및 해지 등)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            회원은 언제든지 회원 계약의 해지를 신청할 수 있으며, 회사는 관련 법령에서 정하는 바에 따라 이를 즉시 처리하여야 합니다. 다만,\n                            회원에게 미수금이 있을 경우에는 미수금에 대한 결제를 완료한 이후에 해지 신청이 가능합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원이 회원 계약을 해지할 경우, 회사는 관련 법령 개인정보처리방침 또는 내부관리 계획 등에 따라 회원 정보를 보유하는 경우를\n                            제외하고는 해지 즉시 회원의 모든 정보를 삭제합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회원 계약 해지로 인해 발생한 불이익에 대한 책임은 회원 본인이 부담해야 하며, 회사는 회원에게 부가적으로 제공한 각종 무상 혜택을\n                            회수할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사가 회원 계약을 해지하는 경우 회사는 회원에게 해지 사유를 밝혀 해지 의사를 통지합니다. 이 경우 회사는 해지를 하기 전에 상당한\n                            기간을 정하여 회원에게 이의 신청의 기회를 부여합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>회원 계약이 회사에 의해 해지되는 경우 회원의 재이용 신청에 대해 회사는 승낙을 거절할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회원의 귀책 사유로 인해 회원 계약이 해지됨으로써 발생한 손해는 당해 회원이 부담하여야 하며, 회사는 관련 법령에 규정이 없는 한 책임을\n                            부담하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 7조(서비스 내용)</h3>\n                        <h5>1.</h5>\n                        <h6>회사가 제공하는 병원 동행 서비스의 내용은 다음과 같습니다.</h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>병원 동행 Pro 서비스 : </span>응급 상황에 처하지는 않았으나 정기적, 혹은 비정기적으로 의료 기관에 방문해\n                                적절한 조치를 받아야 하는 고객을 위한 서비스.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>병원 동행 Basic 서비스 & 수면내시경 보호자 서비스 :</span>보호자 동행이 법적 의무는 아니나 보호자가 없을\n                                경우 시술이 어려운 수면 내시경 등과 같은 의료 조치를 받아야 하는 고객을 위한 보호자 대행 서비스.\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>병원 동행 서비스 제공을 위한 메이트 알선(중개) 서비스 : </span>회원의 서비스 이용 요청 시 적격 자격을\n                                갖춘 인원을 회사가 직접 선별하고 교육한 후, 프리랜서로 등록된 인력이 병원 동행 서비스를 위한 동행자를 알선 받을 수 있도록\n                                중개해주는 서비스.\n                            </p>\n\n                            <p className='title'>\n                                <span className='bold'>고객 소유 자가용 대리 운전 서비스 : </span>회원의 요청에 따라 알선된 메이트가 고객 소유의 자가용을 운행해\n                                병원과 자택을 이동하는 서비스\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>택시 등 여객자동차 운송 중개 서비스 :</span>회원의 요청에 따라 알선된 메이트가 택시 등 여객자동차\n                                운송사업자의 운송 수단을 호출하여 동행할 수 있도록 중개해주는 서비스.\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 제1항의 각 호의 서비스 이외에도 추가적인 서비스를 개발하여 회원에게 제공할 수 있습니다.</h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사가 제공하는 서비스와 플랫폼(웹사이트 포함)의 사용은 무료입니다. 단, 회사가 제공한 서비스를 통해 메이트 알선을 포함한 병원 동행\n                            서비스가 제공되는 경우 사용자는 해당 서비스에 대한 이용 요금을 지불할 의무를 가집니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사는 회원과 메이트 사이의 병원 동행 서비스 혹은 메이트 알선 계약 및 회원과 여객자동차 운송사업자 사이의 운송 계약 체결을 중개하고\n                            제 8조 1항에 명시된 ‘병원 동행 서비스 비용’을 수취하는 회사입니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>회사의 메이트는 고객에게 어떠한 형태의 의료 서비스나 치료, 구급차 등의 의료 운송 서비스를 제공하지 않습니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 8조(이용 요금 등)</h3>\n                        <h5>1.</h5>\n                        <h6>\n                            위드메이트 서비스 이용 요금은 ‘병원 동행 서비스 비용’으로 구성되어 있습니다. 단, 상황에 따라 이동 중에 발생하는 운송 교통 비용이\n                            고객 본인 부담으로 발생할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 이용 요금을 애플리케이션 혹은 웹사이트 내의 예약하기 페이지에 게시하거나, 예약 완료 시에 별도로 회원에게 안내합니다. 다만\n                            최종 이용 요금은 다양한 변수에 따라서 서비스 종료 후 추가 부과가 될 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            메이트가 회원이 지정한 출발지에 도착하여 회원에게 도착을 안내하였음에도 회원이 사전 연락 없이 일정 시간(20분) 이내에 나타나지\n                            아니하거나 계약을 취소하는 경우 회사는 제 9조에 명시된 취소 수수료를 회원에게 부과할 수 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            [병원 동행 Pro] 서비스 이용 옵션 중 ‘고객 소유의 자차 운행’을 선택한 경우 예약일에 맞춰 본인의 차량 보험사가 제공하는 ‘임시 운전자\n                            특약’에 가입을 해야 합니다. 이때 발생하는 보험 비용은 고객 본인 부담이며, 임시 운전자 특약에 가입을 하지 않고 메이트에게 운전을\n                            위임하여 사고가 발생한 경우 모든 책임은 고객 본인에게 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            서비스와 관련하여 발생한 미납경비, 손해배상 등 회원의 회사에 대한 채무가 모두 정산될 때까지 해당 회원의 서비스 사용이 중지되며, 그\n                            채무가 일정기간 계속하여 변제되지 않을 경우에는 해당 회원의 회원자격이 박탈될 수 있습니다. 서비스 사용 중지 또는 회원자격 박탈에\n                            대한 판단 기준은 회사의 약관 및 이용정책에 근거합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회원이 본 약관 및 위 각 조항을 준수하지 않았을 경우, 회사는 본 약관 및 이용 정책에 따라 손해배상 금액 등 각종 수수료를 부과하는 것\n                            외에 계약을 해지할 수 있는 권리를 가집니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>7.</h5>\n                        <h6>\n                            회사는 본 서비스와 관련하여 발생한 미납경비, 손해배상 등 회원의 회사에 대한 채무가 정산되지 않을 경우 회원을 상대로 보전처분,\n                            본안소송제기, 강제집행절차의 착수 등 채무 변제를 위한 법적 조치에 들어갈 수 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 9조(계약 등의 취소)</h3>\n                        <h5>1. 회원이 정상적으로 매칭된 병원 동행 서비스 계약을 취소 및 변경하는 경우에는 아래와 같이 수수료가 발생합니다.</h5>\n\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>서비스 예약 날짜 기준 48시간 이내 변경 및 취소</span>수수료 없이 변경 & 취소 가능\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>서비스 예약 전날 18:00 이전 변경 및 취소</span>취소 시 수수료 10,000원 발생. 단, 메이트와 변경 협의 성공\n                                시에는 수수료 부과 X 수수료 부과 X\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>당일 예약 변경 및 취소</span>취소 시 수수료 15,000원 발생. 단, 메이트와 변경 협의 성공 시에는 수수료 부과\n                                X\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>서비스 시작 2시간 전 이내 변경 및 취소</span>서비스 수수료 20,000원 발생. 단, 메이트와 변경 협의 성공\n                                시에는 수수료 부과 X 수수료 부과 X\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>노쇼(No-Show)의 경우</span>회원 자격 정지 및 민/형사상 책임 소지를 물을 수 있음\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>\n                            2. 회사가 서비스 계약을 취소하는 경우 회원에게 사유를 설명하고 이용요금 전액을 청구하지 아니하며, 회원이 입은 피해에 대한 보상을\n                            협의하고 지급합니다.\n                        </h5>\n\n                        <h5 style={{ marginTop: '48px' }}>\n                            3. 서비스 수혜자의 상태(건강 이상, 인지능력 저하 등)에 따른 현장 판단으로 서비스가 수행되지 못한 경우에도, 이용자는 당일 취소\n                            수수료를 부담할 수 있습니다.\n                        </h5>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 10조(서비스 제공 밎 중단)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 서비스를 주 5일 (월~금), 1일 10시간 (오전 9시~오후 7시) 제공함을 원칙으로 합니다. 특수 예약에 대해서는 검토 후 해당 시간\n                            외에도 서비스를 제공할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 서비스의 제공에 필요한 경우 정기 점검을 실시할 수 있으며, 정기 점검 시간은 플랫폼(웹사이트 포함)의 서비스 제공 화면에 공지한\n                            바에 따릅니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 파산 또는 회생 절차 개시 등 정상적인 영업 활동이 곤란한 경우 또는 회사의 영업상 필요한 경우 서비스 내용을 변경하거나 서비스를\n                            종료할 수 있습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>회사는 다음 각 호의 경우 당해 서비스의 전부 또는 일부의 제공을 중단하거나 제한할 수 있습니다.</h6>\n\n                        <div className='info'>\n                            <p className='title'>\n                                천재지변, 전쟁, 폭동, 화재, 파업 등 쟁의행위, 정부기관의 통제, 테러, 해킹, DDOS, 기타 회사의 합리적인 노력으로 제어할 수 없는\n                                사유가 발생하거나 발생할 우려가 있는 경우\n                            </p>\n                            <p className='title'>기간통신사업자로부터 전기통신서비스가 제공되지 않은 경우</p>\n                            <p className='title'>서비스용 설비의 장애 및 정기 점검, 보수점검, 교체 또는 고장, 통신의 두절 등의 사유가 발생한 경우</p>\n                            <p className='title'>서비스가 제3자와의 제휴를 통하여 제공되는 경우에 당해 제휴사업자의 사정에 따라 변경되거나 중지되는 경우</p>\n                            <p className='title'>기타 서비스의 원활한 운영을 현저히 저해하는 사유가 발생한 경우</p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            본 조 제3항, 제4항의 사유로 서비스 내용이 변경 또는 중단되는 경우, 회사는 그로 인해 회원이 입은 손해에 대하여 고의 또는 중과실이\n                            없는 한 배상하지 않습니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>회사는 본 조 상기된 사유가 발생한 경우 최대한 빠른 시간 내에 서비스를 재개하도록 최선의 노력을 다합니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 11조(서비스의 변경)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 상당한 이유가 있는 경우에 운영상, 기술상의 필요에 따라 제공하고 있는 전부 또는 일부의 서비스를 변경할 수 있습니다. 다만,\n                            변경된 내용이 중대하거나 회원에게 불리한 경우에는 회사가 해당 서비스를 제공받는 회원에게 통지합니다.\n                        </h6>\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 전항에 따른 서비스 변경에 대한 동의를 거절한 회원에 대하여는 해당 서비스의 제공을 중지하거나 회원 이용 계약을 해지할 수\n                            있습니다. 이 때 회원 역시 회원 계약을 종료할 권한을 가집니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 12조(회원에 대한 서비스 이용 제한 등)</h3>\n\n                        <h5>1.</h5>\n                        <h6>회사는 다음 각 호에 해당하는 경우 회원에 대하여 서비스 제공을 제한하거나 중지할 수 있습니다.</h6>\n                        <div className='info'>\n                            <p className='title'>\n                                폭언, 폭행, 그 밖에 적정 범위를 벗어난 신체적ㆍ정신적 고통을 유발하는 행위를 통해, 회원이 서비스의 정상적인 운영을 방해한 경우\n                            </p>\n                            <p className='title'>\n                                법정 감염병 환자, 법정 감염병 의사 환자, 감염병 병원체보유자 등, 환자가 각종 매개체를 통해 메이트에게 질병을 전염 및 유발할\n                                것으로 우려되는 경우\n                            </p>\n                            <p className='title'>회원이 타인의 명의를 도용하여 회원가입을 한 경우</p>\n                            <p className='title'>\n                                이용 요금을 지급하지 아니하거나 이용 요금을 결제함에 있어서 타인 명의 결제 도용, 전화번호 도용 등 불법적인 방법을 사용한 경우\n                            </p>\n                            <p className='title'>\n                                불법프로그램의 제공 및 운영 방해, 정보통신망법을 위반한 불법 통신 및 해킹, 악성프로그램의 배포, 접속 권한 초과 행위 등과 같이\n                                회원이 관련 법령을 위반한 경우\n                            </p>\n                            <p className='title'>회원이 계속해서 1년 이상 로그인하지 않는 경우</p>\n                            <p className='title'>\n                                서비스 수혜자의 상태가 다음에 해당하는 경우:\n                                <br />\n                                <p style={{ paddingLeft: '20px' }}>· 거동이 불가능하거나 현저히 떨어지는 경우</p>\n                                <p style={{ paddingLeft: '20px' }}>· 인지장애가 의심 또는 확인된 경우 (경중 불문, 서비스 제공 불가)</p>\n                                <p style={{ paddingLeft: '20px' }}>\n                                    · 위 사실을 은폐하거나 허위로 신청한 경우: 서비스 즉시 중단 및 법적 조치 대상이 될 수 있음\n                                </p>\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회사는 사안에 따라 사전 또는 사후 통지하며, 보호자의 진술, 병원 소견, 메이트의 현장 판단 등을 토대로 제한 여부를 결정할 수 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 서비스 수혜자 또는 보호자의 사전 고지 의무 위반 여부를 확인하기 위해 필요한 경우 의학적 소견서나 병원 진료 정보를 요청할 수\n                            있으며, 협조하지 않을 경우 서비스 제공이 제한될 수 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 13조(개인정보의 관리 및 변경)</h3>\n\n                        <h6>\n                            이용자는 본 서비스의 이용을 위해 자신의 개인 정보를 성실히 관리해야 하며, 개인정보에 변동사항이 있을 경우 이를 변경해야 합니다. 본\n                            서비스를 이용하면서 이용자의 개인정보 변경이 지연되거나 누락, 이용자에 의해 유출되어 발생하는 손해는 이용자의 책임으로 합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 14조(정보의 제공 및 광고의 게재)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 회원이 서비스 이용 중 필요하다고 인정되는 다양한 정보를 서비스 내 공지사항 또는 서비스 화면, 메시지, 전자우편 등의 방법으로\n                            회원에게 제공할 수 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 서비스의 운영과 관련하여 서비스 화면 등에 광고를 게재할 수 있습니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 15조(회사의 의무)</h3>\n\n                        <h5>1.</h5>\n                        <h6>회사는 관련법과 본 약관의 금지하는 행위를 하지 않으며, 계속적이고 안정적인 서비스를 제공하기 위하여 최선을 다하여 노력합니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>회사는 이용자의 개인정보 보호를 위한 보안 의무에 최선을 다합니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 이용자로부터 제기되는 의견이나 불만이 정당하고 객관적으로 인정될 경우에는 적절한 절차를 거쳐 즉시 처리하여야 합니다. 다만,\n                            즉시 처리가 불가한 경우에는 이용자에게 그 사유와 처리 일정을 통보하여야 합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회사가 제공하는 서비스로 인하여 회원에게 손해가 발생한 경우 그러한 손해가 회사의 고의나 과실에 기해 발생한 경우에 한하여 회사에서\n                            책임을 부담합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>회사는 정보통신망법, 통신비밀보호법, 전기통신사업법 등 서비스의 운영, 유지와 관련 있는 법령을 준수합니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 16조(회원의 의무)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회원은 최종 요금 등의 서비스 조건을 확인한 후 이용 요청을 하여야 하고, 제 8조 2항에 따라 서비스 종료 이후 추가 요금이 발생할 수\n                            있다는 사실을 인지해야 합니다. 서비스 조건을 확인하지 않고 이용 요청을 하여 발생한 손실, 손해에 대한 책임은 회원 본인이 부담하여야\n                            합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원은 본 약관 및 회사가 서비스와 관련하여 고지하는 내용을 준수하여야 하며, 약관 및 고지 내용을 위반하거나 이행하지 아니하여\n                            발생하는 모든 손실, 손해에 대하여 책임을 부담합니다. 이용 요청과 관련하여 회원이 입력한 정보 및 그 정보와 관련하여 발생한 책임과\n                            불이익은 전적으로 회원이 부담하여야 합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회원은 택시 혹은 승합자동차의 대여 및 이동 서비스 이용 시 반드시 본인 명의의 결제수단을 사용하여야 하며, 타인의 결제 수단을 임의로\n                            사용해서는 안 됩니다. 타인의 결제수단을 임의로 사용함으로써 발생하는 회사, 결제 수단의 적법한 소유자, 전자결제대행 또는 이동서비스\n                            제공자 등의 손실과 손해에 대한 모든 책임은 회원에게 있습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>\n                            회원은 회사가 서비스를 안전하게 제공할 수 있도록 회사에 협조하여야 하며, 회사가 회원의 본 약관 위반행위를 발견하여 회원에게 해당\n                            위반행위에 대하여 소명을 요청할 경우 회원은 회사의 요청에 적극 응하여야 합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            회원은 분쟁이 발생한 경우 분쟁의 해결을 위하여 성실히 임하여야 하며, 분쟁 해결에 대한 회원의 불성실로 인하여 이동 서비스 제공자 또는\n                            회사에 손해가 발생한 경우 회원은 이에 대한 책임을 부담하여야 합니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 17조(회원의 금지 행위)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 서비스의 신뢰성을 제고하고 안전한 거래가 이뤄질 수 있도록 회원에게 특정한 행위를 금지하며 이를 금지 행위로 규정하고 있습니다.\n                            금지 행위의 항목은 수시로 갱신될 수 있으며 항목 추가 및 변경 시 별도로 고지하지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원이 위드메이트 서비스로 중개 받은 메이트 또는 기타 운송 수단 탑승 중 메이트, 차량, 혹은 제 3자에 대하여 손해를 입혔을 경우 회원은\n                            이를 배상하여야 하며 구체적인 금액은 아래와 같습니다. 이에 관하여 제휴사의 기사 알선 포함 승합자동차 대여 서비스 이용약관에서 정한\n                            사항이 있다면 그에 따릅니다.\n                        </h6>\n                        <div className='info'>\n                            <p className='title'>\n                                <span className='bold'>메이트를 폭행하거나 정신적인 피해를 끼친 경우 :</span>치료비 전액 배상 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>차량을 오염시킨 경우: </span>30만원 이내에서 세차 실비 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>차량 및 차내 기물 파손 비용:</span> 원상 복구 비용 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>목적지 도착 후 하차 거부:</span>경찰서 등의 인계 시까지의 운임 및 영업손실비\n                            </p>\n                            <p className='title'>\n                                <span className='bold'>분실물 발견 후 배달 요청 :</span>배차 중지 후 분실물 배달을 위한 영업손실비\n                            </p>\n                        </div>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>\n                            회사는 회원이 본 조의 금지행위를 하는 경우 서비스 이용을 제한할 수 있으며, 이 경우 발생하는 모든 책임은 회원이 부담합니다. 회사는\n                            필요한 경우 회원의 금지 행위 사실을 관련 정부기관 또는 사법기관에 통지할 수 있습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <h3>제 18조(책임 제한)</h3>\n\n                        <h5>1.</h5>\n                        <h6>\n                            회사는 회원과 메이트 간, 회원과 운송사업자 간 거래를 중개하는 시스템의 운영 관리를 제공하며, 회원, 메이트, 운송사업자를 대리하지\n                            않습니다. 회원과 메이트, 그리고 운송사업자 사이에 성립된 거래에 따라 회원 또는 메이트, 혹은 운송사업자가 제공한 정보에 대한 책임은\n                            회원과 메이트, 그리고 운송사업자가 부담합니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>\n                            회원이 자신의 개인 정보 및 계정 등을 타인에게 제공하거나, 회원의 관리 소홀로 유출됨으로써 발생하는 피해에 대해서 책임을 부담하지\n                            않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>3.</h5>\n                        <h6>회사는 회원의 귀책 사유로 인한 서비스 이용의 장애에 대하여는 책임을 지지 않습니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>4.</h5>\n                        <h6>회사는 회원이 서비스와 관련하여 게재한 정보, 자료, 사실의 신뢰도, 정확성 등의 내용에 관하여는 책임을 부담하지 않습니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>5.</h5>\n                        <h6>\n                            회사는 서비스간 회원의 귀책 사유로 발생한 메이트와의 갈등(물리적 폭행, 언어 폭력, 부적절한 신체 접촉 등)으로 인해 발생한 피해에\n                            대해서 책임을 부담하지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>6.</h5>\n                        <h6>\n                            회사는 관계 법령의 변경, 천재지변, 디도스(DDOS)공격, IDC 장애, 기간통신사업자의 회선 장애 또는 이에 준하는 불가항력으로 인하여\n                            서비스를 제공할 수 없는 경우에는 서비스 제공에 관한 책임이 면제됩니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>7.</h5>\n                        <h6>\n                            회사는 회원의 서비스 이용과 직접적으로 관련이 없는 분쟁에 관여하지 않으며, 회원과 운전용역 제공자 및 운송사업자 또는 회원과 제3자\n                            간의 분쟁을 포함하여 도난, 폭행, 성범죄 등에 대해서는 회사의 과실이 없는 한 책임을 부담하지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>8.</h5>\n                        <h6>\n                            회사는 스마트기기 환경으로 인하여 발생하는 제반 문제 또는 회사의 귀책 사유가 없는 네트워크 환경으로 인하여 발생하는 문제에 대해서\n                            책임을 지지 않습니다.\n                        </h6>\n\n                        <h5 style={{ marginTop: '48px' }}>9.</h5>\n                        <h6>\n                            회사는 메이트의 현장 상황 판단(서비스 거부 포함)에 따라 불가피하게 서비스가 중단된 경우, 고의 또는 중대한 과실이 없는 한 책임을\n                            부담하지 않습니다.\n                        </h6>\n                    </div>\n\n                    <div className='context-block' style={{ marginBottom: '100px' }}>\n                        <h3>제 19조(분쟁의 해결)</h3>\n\n                        <h5>1.</h5>\n                        <h6>본 약관에 명시되지 않은 사항이 관계 법령에 규정되어 있을 경우에는 해당 규정에 따릅니다.</h6>\n\n                        <h5 style={{ marginTop: '48px' }}>2.</h5>\n                        <h6>서비스 이용으로 발생한 분쟁에 대해 소송이 제기되는 경우 법령에 정한 절차에 따른 법원을 관할 법원으로 합니다.</h6>\n                    </div>\n\n                    <div className='context-block'>\n                        <div className='privacy-justify'>\n                            <p className='version'>개인정보 처리방법 버전 번호 : v.1.2</p>\n                            <p className='date'>제정일자 : 2021년 12월 20일</p>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default TermsComponent;\n","import React from 'react';\nimport { connect } from 'react-redux';\n\n// component\nimport TermsStyledContainer from './terms.styled';\nimport Terms from './terms';\n\nclass TermsContainer extends React.PureComponent {\n    render() {\n        return (\n            <TermsStyledContainer component={this.props.isComponent || undefined}>\n                <Terms {...this.props} />\n            </TermsStyledContainer>\n        );\n    }\n}\n\nconst mapStateToProps = ({}) => ({});\nconst mapDispatchToProps = dispatch => ({});\nexport default connect(mapStateToProps, mapDispatchToProps)(TermsContainer);\n","import React, { useState } from \"react\";\nimport styled from 'styled-components';\nimport { message, Button } from 'antd';\nimport { DivisionLine } from '../../Components/Common/input';\nimport { Checkbox } from 'antd';\n\nconst DepartmentComponent = () => {\n    const department_data = [\n        { id: 1, name: \"가정의학과\" },\n        { id: 2, name: \"내과\" },\n        { id: 3, name: \"마취통증의학과\" },\n        { id: 4, name: \"방사선종양학과\" },\n        { id: 5, name: \"병리과\" },\n        { id: 6, name: \"산부인과\" },\n        { id: 7, name: \"성형외과\" },\n        { id: 8, name: \"신경과\" },\n        { id: 9, name: \"신경외과\" },\n        { id: 9, name: \"안과\" },\n        { id: 9, name: \"영상의학과\" },\n        { id: 9, name: \"외과\" },\n        { id: 9, name: \"응급의학과\" },\n        { id: 9, name: \"이비인후과\" },\n        { id: 9, name: \"임상약리학과\" },\n        { id: 9, name: \"재할의학과\" },\n        { id: 9, name: \"정신건강의학과\" },\n        { id: 9, name: \"정형외과\" },\n        { id: 9, name: \"중환자의학과\" },\n        { id: 9, name: \"진단검사의학과\" },\n        { id: 9, name: \"피부과\" },\n        { id: 9, name: \"핵의학과\" },\n        { id: 9, name: \"흉부외과\" },\n    ];\n\n    const [isChecked, setIsChecked] = useState(false); //체크 여부\n    const [checkedItems, setCheckedItems] = useState(new Set());//체크된 요소들\n\n    const checkHandler = ({ target }) => {\n        setIsChecked(!isChecked);\n        checkedItemHandler(target.parentNode, target.value, target.checked);\n    };\n\n    const checkedItemHandler = (box, id, isChecked) => {\n        if (isChecked) { //체크 되었을때\n            checkedItems.add(id); //체크시 삽입\n            setCheckedItems(checkedItems); //체크 요소 넣어주기\n\n        } else if (!isChecked && checkedItems.has(id)) { //체크가 안되었고, id가 있을때(클릭 2번시)\n            checkedItems.delete(id); //체크 두번시 삭제\n            setCheckedItems(checkedItems);\n        }\n\n        console.log(checkedItems);\n        return checkedItems;\n    };\n\n    return (\n        <div className='department-container'>\n            <div className='inner-container' style={{ display: 'flex', justifyContent: 'center' }}>\n                <div className='department-form' style={{ border: '1px solid lightgray', borderRadius: '7px', width: '900px', marginTop: '40px', paddingTop: '80px', backgroundColor: 'white' }}>\n                    <div className='department-title'>\n                        <h1 style={{ textAlign: 'center' }}>진료(치료) 받는 과 선택</h1>\n                    </div>\n                    <DivisionLine /><DivisionLine />\n                    <div className=\"contStyle\" style={{ padding: '20px' }}>\n                        {department_data.map((item) => (\n                            <label key={item.id} className=\"innerBox\" style={{ display: 'flex', justifyContent: 'center' }}>\n                                <div style={{ display: 'flex' }}>\n                                    <Checkbox\n                                        value={item.name}\n                                        onChange={(e) => checkHandler(e)}\n                                        style={{ fontSize: '20px' }}\n                                    >\n                                        {item.name}\n                                    </Checkbox>\n                                </div>\n                            </label>\n                        ))}\n                    </div>\n                    <DivisionLine />\n                    <hr style={{ textAlgn: 'center', width: '840px', color: 'gray' }} />\n\n                    <div className='form' style={{ textAlign: 'center' }}>\n                        <Button type='primary' style={{ borderRadius: '4px', marginTop: '20px', backgroundColor: 'gray' }}\n                            onClick={() => {\n                                this.props.history.push('/user/mypage/profile');\n                            }}\n                        >\n                            등록\n                        </Button>\n                        &nbsp;&nbsp;&nbsp;\n                        <Button type='primary' style={{ borderRadius: '4px', marginTop: '20px' }}\n                            onClick={() => {\n                                this.props.history.push('/');\n                            }}\n                        >\n                            취소\n                        </Button>\n                    </div>\n                    <DivisionLine />\n                </div>\n            </div>\n        </div>\n    );\n};\n\nexport default DepartmentComponent;\n\nconst Departments = styled.div`\n    display: flex;\n    width: 100%;\n    height: 100%;\n    line-height: 44px;\n\n    > span {\n        display: inline-block;\n        cursor: pointer;\n\n        flex: 1;\n        height: 100%;\n        border-radius: 4px;\n        border: 1px solid #e9e9e9;\n\n        text-align: center;\n        color: rgba(0, 0, 0, 0.7);\n        font-size: 14px;\n        letter-spacing: -0.2px;\n\n        margin-right: 8px;\n    }\n\n    > span.active {\n        background-color: #3bc1ff;\n        color: white;\n    }\n\n    > span:last-child {\n        margin-right: 0px;\n    }\n`;","import React from 'react';\nimport { NavLink } from 'react-router-dom';\nimport { Popover } from 'antd';\n// lib\nimport { USER } from '../../../Lib/variables';\n\nexport default class NavComponent extends React.PureComponent {\n    state = {\n        menu: false,\n    };\n\n    onClose = () => {\n        const { pathname } = this.props.location;\n        if (pathname === '/' && window.innerWidth <= 768) {\n            const main = document.querySelector('.order-menu-wrapper');\n            main.style.display = 'none';\n        }\n    };\n\n    componentDidUpdate = prevProps => {\n        const { pathname: prevPath } = prevProps.location;\n        const { pathname } = this.props.location;\n        if (prevPath !== pathname) {\n            this.setState({ menu: false });\n        }\n    };\n\n    // payment test\n    onMobileMenuHandler = () => {\n        this.setState({ menu: !this.state.menu });\n    };\n\n    render() {\n        // const { id, name, userType, ticket } = this.props.auth;\n        // const { name, userType } = this.props.auth;\n        const id = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n\n        return (\n            <div className='nav-container'>\n                <div className='nav-inner'>\n                    <div className='logo'>\n                        <NavLink exact to='/' activeClassName='active' lang='en' onClick={this.onClose}>\n                            <img src='https://s3.ap-northeast-2.amazonaws.com/withmate.photo/withmate_new_logo.png' alt='logo' />\n                        </NavLink>\n                    </div>\n                    <div className='nav'>\n                        <div className='mobile-menu'>\n                            <span onClick={this.onMobileMenuHandler}>\n                                <i className='fas fa-bars' />\n                            </span>\n                        </div>\n                        <ul className={`nav-items ${this.state.menu ? 'active' : ''}`}>\n                            <li className='item'>\n                                <NavLink lang='kr' exact to='/' className='nav-item' activeClassName='active'>\n                                    메인\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='kr' exact to='/nemt/service' className='nav-item' activeClassName='active'>\n                                    위드메이트 소개\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='en' exact to='/review/list' className='nav-item' activeClassName='active'>\n                                    이용후기\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='en' exact to='/newsEvent/list' className='nav-item' activeClassName='active'>\n                                    소식 보기\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='en' exact to='/faq' className='nav-item' activeClassName='active'>\n                                    FAQ\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            {!id ? (\n                                <>\n                                    <li className='item item-login'>\n                                        <NavLink lang='kr' exact to='/user/login' className='nav-item block login'>\n                                            로그인\n                                            <span className='underline'></span>\n                                        </NavLink>\n                                    </li>\n                                    <li className='item item-register'>\n                                        <NavLink lang='kr' exact to='/user/mainRegister' className='nav-item block register'>\n                                            회원가입\n                                            <span className='underline'></span>\n                                        </NavLink>\n                                    </li>\n                                    <li className='item item-apply'>\n                                        <NavLink lang='kr' exact to='/mate/apply' className='nav-item block apply'>\n                                            메이트 지원\n                                            <span className='underline'></span>\n                                        </NavLink>\n                                    </li>\n                                </>\n                            ) : (\n                                <>\n                                    <li className='item item-name'>\n                                        <NavLink\n                                            lang='kr'\n                                            to={userType === USER ? '/user/mypage' : '/user/mate/mypage'}\n                                            className='nav-item'\n                                            activeClassName='active'\n                                        >\n                                            마이페이지\n                                            <span className='underline'></span>\n                                        </NavLink>\n                                    </li>\n\n                                    <li className='item item-logout'>\n                                        <NavLink lang='kr' exact to='/user/logout' className='nav-item' activeClassName='active'>\n                                            로그아웃\n                                            <span className='underline'></span>\n                                        </NavLink>\n                                    </li>\n                                </>\n                            )}\n                        </ul>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n","import styled from 'styled-components';\nimport { borderColor, mainBoldColor, mainColor, fontSize, sizeHandler } from '../../../theme';\nconst NavStyledContainer = styled.div`\n    .nav-container {\n        width: 100vw;\n        height: 56px;\n        background-color: white;\n        border-bottom: 1px solid ${borderColor};\n        position: fixed;\n        top: 0px;\n        left: 0px;\n        z-index: 10;\n\n        .nav-inner {\n            display: flex;\n            flex-direction: row;\n            max-width: 1120px;\n            height: 100%;\n            margin: 0 auto;\n            position: relative;\n\n            .logo {\n                width: auto;\n                display: flex;\n                align-items: center;\n                justify-content: center;\n\n                a {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                }\n                img {\n                    width: 80%;\n                }\n            }\n\n            .nav {\n                flex: 1;\n                padding-right: 12px;\n\n                .mobile-menu {\n                    display: none;\n                }\n\n                ul.nav-items {\n                    width: 100%;\n                    height: 100%;\n                    display: flex;\n                    flex-direction: row;\n                    align-items: center;\n                    justify-content: flex-end;\n                    padding: 0px;\n                    padding-left: 32px;\n\n                    li.item {\n                        padding-left: 13px;\n                        padding-right: 13px;\n                        position: relative;\n                        \n                        > a {\n                            font-size: 13px;\n                            line-height: 21px;\n                        }\n\n                        display: flex;\n                        align-items: center;\n                        justify-content: center;\n\n                        &.item-apply {\n                            padding-left: 0px;\n                            padding-right: 0px;\n\n                            margin-left: 12px;\n\n                            .underline {\n                                bottom: -12px;\n                            }\n                        }\n\n                        &.item-login {\n                            padding-left: 0px;\n                            padding-right: 0px;\n                            margin-left: 12px;\n\n                            .underline {\n                                bottom: -12px;\n                            }\n                        }\n\n                        &.item-register {\n                            padding-left: 0px;\n                            padding-right: 0px;\n\n                            margin-left: 12px;\n\n                            .underline {\n                                bottom: -12px;\n                            }\n                        }\n\n                        &.item-logout {\n                            border-left: 1px solid #e6e6e6;\n                        }\n\n                        &.item-name {\n                            border-left: 1px solid #e6e6e6;\n                            border-right: 1px solid #e6e6e6;\n                        }\n\n                        @media (max-width: 1080px) {\n                            padding-left: 8px;\n                            padding-right: 8px;\n\n                            > a {\n                                font-size: 13px;\n                                line-height: 18px;\n                            }\n                        }\n\n                        @media (max-width: 900px) {\n                            padding-left: 6px;\n                            padding-right: 6px;\n\n                            > a {\n                                font-size: 12px;\n                                line-height: 18px;\n                            }\n                        }\n                    }\n\n                    .tickets {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        letter-spacing: -0.18px;\n                        color: #606060;\n                    }\n\n                    .nav-item {\n                        font-weight: bold;\n                        font-size: 12px;\n                        color: #606060;\n\n                        &.block {\n                            padding: 9.25px 30px;\n                            \n                            line-height: 18px;\n                            text-align: center;\n                            border: 1px solid ${mainColor}\n                            font-weight: bold;\n                            border-radius: 2px;\n                        }\n\n                        &.login, &.register {\n                            color: ${mainColor};\n                        }\n\n                        &.apply {\n                            background-color: ${mainColor};\n                            color: white;\n                        }\n\n                        @media (max-width: 1080px) {\n                            &.block {\n                                padding: 8px 24px;\n                            }\n                        }\n\n                        @media (max-width: 900px) {\n                            &.block {\n                                padding: 6px 18px;\n                            }\n                        }\n                    }\n\n                    .active {\n                        color: ${mainColor};\n                        font-weight: bold;\n\n                        .underline {\n                            display: inline-block;\n                            position: absolute;\n                            bottom: -18.5px;\n                            left: 0px;\n                            width: 100%;\n                            height: 3px;\n                            background-color: ${mainColor};\n                        }\n                    }\n                }\n\n                \n\n                @media (max-width: 768px) {\n                    padding-right: 0px;\n                    \n                    .mobile-menu {\n                        height: 100%;\n                        width: 100%;\n                        display: block;\n                        position: relative;\n\n                        span {\n                            position: absolute;\n                            right: 32px;\n                            top: 16px;\n                            cursor: pointer;\n                            color: ${mainColor};\n\n                            svg {\n                                font-size: ${fontSize.b20};\n                            }\n                        }\n                    }\n\n                    ul.nav-items {\n                        display: none;\n\n                        li.item {\n                            \n    \n                            &.item-logout {\n                                border-left: 0px;\n                            }\n    \n                            &.item-name {\n                                border-left: 0px;\n                                border-right: 0px;\n                            }\n                        }\n                    }\n\n                    ul.nav-items.active {\n                        position: absolute;\n                        background-color: white;\n                        z-index: 9999;\n                        top: 56px;\n                        left: 0px;\n                        width: 100%;\n                        height: auto;\n                        display: block;\n                        padding: 0px;\n                        padding: 0px 12px;\n\n                        li.item {\n                            width: 100%;\n                            min-height: 40px;\n                            margin: 0;\n                            border-bottom: 1px solid ${borderColor};\n                            background-color: white;\n                            color: #606060;\n\n                            &.item-login {\n                                margin-left: 0px;\n                            }\n    \n                            &.item-register {\n                                margin-left: 0px;\n                            }\n\n                            a {\n                                display: inline-block;\n                                width: 100%;\n                                text-align: center;\n                                line-height: 40px;\n                                // color: #606060;\n                            }\n                        }\n\n                        .nav-item {\n                            &.block {\n                                margin: 6px 0px;\n                                line-height: 32px;\n                            }\n                        }\n\n                        .active .underline {\n                            height: 0px;\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\n\nexport default NavStyledContainer;\n","import React from 'react';\nimport { withRouter } from 'react-router-dom';\n\n// component\nimport Nav from './nav';\n\n// styles\nimport NavStyledContainer from './nav.styled';\n\n// actions\n// import {} from '../../Redux/Modules/';\n\nclass NavContainer extends React.PureComponent {\n    render() {\n        return (\n            <NavStyledContainer>\n                <Nav {...this.props} />\n            </NavStyledContainer>\n        );\n    }\n}\n\nexport default withRouter(NavContainer);\n","import React from 'react';\nimport { NavLink } from 'react-router-dom';\nimport { Popover } from 'antd';\n// lib\nimport { USER } from '../../../Lib/variables';\n\nexport default class NavComponent extends React.PureComponent {\n    state = {\n        menu: false,\n    };\n\n    onClose = () => {\n        const { pathname } = this.props.location;\n        if (pathname === '/' && window.innerWidth <= 768) {\n            const main = document.querySelector('.order-menu-wrapper');\n            main.style.display = 'none';\n        }\n    };\n\n    componentDidUpdate = prevProps => {\n        const { pathname: prevPath } = prevProps.location;\n        const { pathname } = this.props.location;\n        if (prevPath !== pathname) {\n            this.setState({ menu: false });\n        }\n    };\n\n    // payment test\n    onMobileMenuHandler = () => {\n        this.setState({ menu: !this.state.menu });\n    };\n\n    render() {\n        // const { id, name, userType, ticket } = this.props.auth;\n        // const { name, userType } = this.props.auth;\n        const id = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n\n        return (\n            <div className='nav-container'>\n                <div className='nav-inner'>\n                    <div className='logo'>\n                        <NavLink exact to='/360F' activeClassName='active' lang='en' onClick={this.onClose}>\n                            <img src='/assets/images/collaboration/withmate_metlife_main.png' style={{ width: '240px' }} alt='logo' />\n                        </NavLink>\n                    </div>\n                    <div className='nav'>\n                        <div className='mobile-menu'>\n                            <span onClick={this.onMobileMenuHandler}>\n                                <i className='fas fa-bars' />\n                            </span>\n                        </div>\n                        <ul className={`nav-items ${this.state.menu ? 'active' : ''}`}>\n                            <li className='item'>\n                                <NavLink lang='kr' exact to='/360F' className='nav-item' activeClassName='active'>\n                                    메인\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='kr' exact to='/360F/nemt/service' className='nav-item' activeClassName='active'>\n                                    위드메이트 소개\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='en' exact to='/360F/review/list' className='nav-item' activeClassName='active'>\n                                    이용후기\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='en' exact to='/360F/newsEvent/list' className='nav-item' activeClassName='active'>\n                                    소식 보기\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                            <li className='item'>\n                                <NavLink lang='en' exact to='/360F/faq' className='nav-item' activeClassName='active'>\n                                    FAQ\n                                    <span className='underline'></span>\n                                </NavLink>\n                            </li>\n                        </ul>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n","import styled from 'styled-components';\nimport { borderColor, mainBoldColor, mainColor, fontSize, sizeHandler } from '../../../theme';\nconst NavStyledContainer = styled.div`\n    .nav-container {\n        width: 100vw;\n        height: 56px;\n        background-color: white;\n        border-bottom: 1px solid ${borderColor};\n        position: fixed;\n        top: 0px;\n        left: 0px;\n        z-index: 10;\n\n        .nav-inner {\n            display: flex;\n            flex-direction: row;\n            max-width: 1120px;\n            height: 100%;\n            margin: 0 auto;\n            position: relative;\n\n            .logo {\n                width: auto;\n                display: flex;\n                align-items: center;\n                justify-content: center;\n\n                a {\n                    display: flex;\n                    align-items: center;\n                    justify-content: center;\n                }\n                img {\n                    width: 80%;\n                }\n            }\n\n            .nav {\n                flex: 1;\n                padding-right: 12px;\n\n                .mobile-menu {\n                    display: none;\n                }\n\n                ul.nav-items {\n                    width: 100%;\n                    height: 100%;\n                    display: flex;\n                    flex-direction: row;\n                    align-items: center;\n                    justify-content: flex-end;\n                    padding: 0px;\n                    padding-left: 32px;\n\n                    li.item {\n                        padding-left: 13px;\n                        padding-right: 13px;\n                        position: relative;\n                        \n                        > a {\n                            font-size: 13px;\n                            line-height: 21px;\n                        }\n\n                        display: flex;\n                        align-items: center;\n                        justify-content: center;\n\n                        &.item-apply {\n                            padding-left: 0px;\n                            padding-right: 0px;\n\n                            margin-left: 12px;\n\n                            .underline {\n                                bottom: -12px;\n                            }\n                        }\n\n                        &.item-login {\n                            padding-left: 0px;\n                            padding-right: 0px;\n                            margin-left: 12px;\n\n                            .underline {\n                                bottom: -12px;\n                            }\n                        }\n\n                        &.item-register {\n                            padding-left: 0px;\n                            padding-right: 0px;\n\n                            margin-left: 12px;\n\n                            .underline {\n                                bottom: -12px;\n                            }\n                        }\n\n                        &.item-logout {\n                            border-left: 1px solid #e6e6e6;\n                        }\n\n                        &.item-name {\n                            border-left: 1px solid #e6e6e6;\n                            border-right: 1px solid #e6e6e6;\n                        }\n\n                        @media (max-width: 1080px) {\n                            padding-left: 8px;\n                            padding-right: 8px;\n\n                            > a {\n                                font-size: 13px;\n                                line-height: 18px;\n                            }\n                        }\n\n                        @media (max-width: 900px) {\n                            padding-left: 6px;\n                            padding-right: 6px;\n\n                            > a {\n                                font-size: 12px;\n                                line-height: 18px;\n                            }\n                        }\n                    }\n\n                    .tickets {\n                        font-size: ${sizeHandler(14)};\n                        font-weight: bold;\n                        letter-spacing: -0.18px;\n                        color: #606060;\n                    }\n\n                    .nav-item {\n                        font-weight: bold;\n                        font-size: 12px;\n                        color: #606060;\n\n                        &.block {\n                            padding: 9.25px 30px;\n                            \n                            line-height: 18px;\n                            text-align: center;\n                            border: 1px solid ${mainColor}\n                            font-weight: bold;\n                            border-radius: 2px;\n                        }\n\n                        &.login, &.register {\n                            color: ${mainColor};\n                        }\n\n                        &.apply {\n                            background-color: ${mainColor};\n                            color: white;\n                        }\n\n                        @media (max-width: 1080px) {\n                            &.block {\n                                padding: 8px 24px;\n                            }\n                        }\n\n                        @media (max-width: 900px) {\n                            &.block {\n                                padding: 6px 18px;\n                            }\n                        }\n                    }\n\n                    .active {\n                        color: ${mainColor};\n                        font-weight: bold;\n\n                        .underline {\n                            display: inline-block;\n                            position: absolute;\n                            bottom: -18.5px;\n                            left: 0px;\n                            width: 100%;\n                            height: 3px;\n                            background-color: ${mainColor};\n                        }\n                    }\n                }\n\n                \n\n                @media (max-width: 768px) {\n                    padding-right: 0px;\n                    \n                    .mobile-menu {\n                        height: 100%;\n                        width: 100%;\n                        display: block;\n                        position: relative;\n\n                        span {\n                            position: absolute;\n                            right: 32px;\n                            top: 16px;\n                            cursor: pointer;\n                            color: ${mainColor};\n\n                            svg {\n                                font-size: ${fontSize.b20};\n                            }\n                        }\n                    }\n\n                    ul.nav-items {\n                        display: none;\n\n                        li.item {\n                            \n    \n                            &.item-logout {\n                                border-left: 0px;\n                            }\n    \n                            &.item-name {\n                                border-left: 0px;\n                                border-right: 0px;\n                            }\n                        }\n                    }\n\n                    ul.nav-items.active {\n                        position: absolute;\n                        background-color: white;\n                        z-index: 9999;\n                        top: 56px;\n                        left: 0px;\n                        width: 100%;\n                        height: auto;\n                        display: block;\n                        padding: 0px;\n                        padding: 0px 12px;\n\n                        li.item {\n                            width: 100%;\n                            min-height: 40px;\n                            margin: 0;\n                            border-bottom: 1px solid ${borderColor};\n                            background-color: white;\n                            color: #606060;\n\n                            &.item-login {\n                                margin-left: 0px;\n                            }\n    \n                            &.item-register {\n                                margin-left: 0px;\n                            }\n\n                            a {\n                                display: inline-block;\n                                width: 100%;\n                                text-align: center;\n                                line-height: 40px;\n                                // color: #606060;\n                            }\n                        }\n\n                        .nav-item {\n                            &.block {\n                                margin: 6px 0px;\n                                line-height: 32px;\n                            }\n                        }\n\n                        .active .underline {\n                            height: 0px;\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\n\nexport default NavStyledContainer;\n","import React from 'react';\nimport { withRouter } from 'react-router-dom';\n\n// component\nimport Nav from './nav';\n\n// styles\nimport NavStyledContainer from './nav.styled';\n\n// actions\n// import {} from '../../Redux/Modules/';\n\nclass NavContainer extends React.PureComponent {\n    render() {\n        return (\n            <NavStyledContainer>\n                <Nav {...this.props} />\n            </NavStyledContainer>\n        );\n    }\n}\n\nexport default withRouter(NavContainer);\n","import React from 'react';\nimport { NavLink } from 'react-router-dom';\nimport { MobileBr } from '../../../Pages/Guide/guide.styled';\n\nexport default class FooterComponent extends React.PureComponent {\n    render() {\n        const { location } = this.props.history;\n        const { pathname } = this.props.location;\n        const darkMode =\n            pathname === '/' || pathname === '/user/mate/pending' || pathname === '/faq' || pathname === '/company' || pathname.indexOf('/user') !== -1;\n\n        return (\n            <div className={`footer-container ${darkMode ? 'darkmode' : ''}`}>\n                <div className='inner-container'>\n                    <div className='default-info-wrapper'>\n                        <div className='right'>\n                            <p>2019 Withmate Org, All rights reserved.</p>\n                        </div>\n                        <div className='policy'>\n                            {location.pathname.startsWith('/360F') ? (\n                                <>\n                                    <NavLink to='/360F/policy/terms'>이용약관</NavLink>\n                                    <NavLink to='/360F/policy/privacy'>개인정보 처리방침</NavLink>\n                                </>\n                            ) : (\n                                <>\n                                    <NavLink to='/policy/terms'>이용약관</NavLink>\n                                    <NavLink to='/policy/privacy'>개인정보 처리방침</NavLink>\n                                </>\n                            )}\n                            {/* <a\n                                onClick={() => {\n                                    window.open('https://www.notion.so/FAQ-cfe01db37c67472086b414a044ed6370', '_blank');\n                                }}\n                            >\n                                메이트 매뉴얼\n                            </a> */}\n                            <MobileBr />\n                            <MobileBr />\n                            <a style={{ marginLeft: '70px' }}></a>\n                            <a href='https://blog.naver.com/PostList.naver?blogId=pond909' name='naver-blog' target='_blank' rel='noreferrer noopener'>\n                                <img\n                                    style={{ border: '0px currentColor', width: '30px', verticalAlign: 'top' }}\n                                    alt='네이버 블로그'\n                                    src='/assets/images/icons/naverblog_icon.png'\n                                    loading='lazy'\n                                />\n                            </a>\n                            <a\n                                href='https://www.facebook.com/%EC%9C%84%EB%93%9C%EB%A9%94%EC%9D%B4%ED%8A%B8-%EB%B3%91%EC%9B%90%EB%8F%99%ED%96%89%EC%84%9C%EB%B9%84%EC%8A%A4-103107278930429'\n                                name='facebook'\n                                target='_blank'\n                                rel='noreferrer noopener'\n                                style={{ marginLeft: '-15px' }}\n                            >\n                                <img\n                                    style={{ border: '0px currentColor', width: '30px', verticalAlign: 'top' }}\n                                    alt='페이스북'\n                                    src='/assets/images/icons/facebook_icon.png'\n                                    loading='lazy'\n                                />\n                            </a>\n                            <a\n                                href='https://www.instagram.com/withmate_official'\n                                name='naver-blog'\n                                target='_blank'\n                                rel='noreferrer noopener'\n                                style={{ marginLeft: '-15px' }}\n                            >\n                                <img\n                                    style={{ border: '0px currentColor', width: '30px', verticalAlign: 'top' }}\n                                    alt='인스타그램'\n                                    src='/assets/images/icons/instagram_icon.png'\n                                    loading='lazy'\n                                />\n                            </a>\n                        </div>\n                    </div>\n\n                    <div className='footer-info'>\n                        <div className='info-block'>\n                            <div className='row-wrapper'>\n                                <p className='infoTitle'>회사 정보</p>\n                                <p className='content'></p>\n                            </div>\n                            <div className='row-wrapper'>\n                                <p className='title'>법인명</p>\n                                <p className='content'>㈜블루카멜</p>\n                            </div>\n                            <div className='row-wrapper'>\n                                <p className='title'>대표자</p>\n                                <p className='content'>지승배</p>\n                            </div>\n                            <div className='row-wrapper'>\n                                <p className='title'>사업자 등록번호</p>\n                                <p className='content'>153-88-00622</p>\n                            </div>\n                            <div className='row-wrapper'>\n                                <p className='title'>통신판매업 신고번호</p>\n                                <p className='content'>2021-서울 서대문-2081</p>\n                            </div>\n                        </div>\n                        <div className='info-block'>\n                            <div className='row-wrapper'>\n                                <p className='contactTitle'>연락처</p>\n                                <p className='content'></p>\n                            </div>\n                            <div className='row-wrapper address'>\n                                <p className='title'>주소</p>\n                                <p className='content'>서울시 서대문구 경기대로 11길 26-6 우진빌딩 비동 203호</p>\n                            </div>\n                            <div className='row-wrapper'>\n                                <p className='title'>전화번호</p>\n                                <p className='content'>070-4300-9075</p>\n                            </div>\n                            <div className='row-wrapper'>\n                                <p className='title'>이메일</p>\n                                <p className='content'>ceo@withmate.kr</p>\n                            </div>\n                            <div className='row-wrapper2' />\n                        </div>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n","import styled from 'styled-components';\nimport { fontSize, mainColor, bgDarkColor, sizeHandler } from '../../../theme';\n\nconst FooterStyledContainer = styled.div`\n    .footer-container {\n        background-color: #f9f9f9;\n        border-top: 1px solid #e6e6e6;\n\n        .inner-container {\n            padding-top: 52px;\n            padding-bottom: 52px;\n\n            .default-info-wrapper {\n                display: flex;\n\n                .right {\n                    flex: 1;\n\n                    p {\n                        font-size: ${sizeHandler(16)};\n                        font-weight: bold;\n                        color: rgba(0, 0, 0, 0.7);\n                    }\n                }\n\n                .policy {\n                    flex: 1;\n                    text-align: center;\n\n                    a {\n                        font-size: ${sizeHandler(12)};\n                        font-weight: bold;\n                        letter-spacing: -0.26px;\n                        color: rgba(0, 0, 0, 0.7);\n                        text-decoration: underline;\n                        margin-right: 32px;\n                    }\n                }\n            }\n\n            .footer-info {\n                display: flex;\n                align-items: center;\n\n                .info-block {\n                    margin-top: 40px;\n                    flex: 1;\n                    margin-right: 20px;\n\n                    .row-wrapper2 {\n                        height: 42px;\n                        line-height: 42px;\n                        display: flex;\n                        borderColor: rgba(41 41 41);\n                    }\n\n                    .row-wrapper {\n                        height: 42px;\n                        line-height: 42px;\n                        border-bottom: 1px solid #e6e6e6;\n                        display: flex;\n\n                        &.address {\n                            height: 42px;\n                        }\n\n                        p {\n                            &.title {\n                                width: 140px;\n                                font-size: ${sizeHandler(10)};\n                                font-weight: bold;\n                                color: rgba(0, 0, 0, 0.7);\n                            }\n\n                            &.infoTitle {\n                                width: 140px;\n                                font-size: ${sizeHandler(14)};\n                                font-weight: bold;\n                                color: rgba(0, 0, 0, 0.7);\n                            }\n\n                            &.contactTitle {\n                                width: 140px;\n                                font-size: ${sizeHandler(14)};\n                                font-weight: bold;\n                                color: rgba(0, 0, 0, 0.7);\n                            }\n\n                            &.content {\n                                flex: 1;\n                                font-size: ${sizeHandler(12)};\n                                letter-spacing: -0.26px;\n                                color: rgba(0, 0, 0, 0.7);\n                            }\n\n                        }\n                    }\n                }\n            }\n\n            @media (max-width: 1120px) {\n                padding-left: 16px;\n                padding-right: 16px;\n            }\n\n            @media (max-width: 768px) {\n\t\t.info-block .row-wrapper {\n\t\t    min-height: 42px;\n\t\t    height: auto !important;\n\t\t    line-height: 24px !important;\n\t\t}\n\n                .default-info-wrapper {\n                    flex-direction: column;\n\n                    .right {\n                        margin-bottom: 12px;\n                    }\n\n                    .policy {\n                        text-align: left;\n\n                        a {\n                            font-size: ${sizeHandler(10)};\n                        }\n                    }\n                }\n\n                .footer-info {\n                    flex-direction: column;\n\n                    .info-block {\n                        margin-right: 0px;\n                        width: 100%;\n\n                        .row-wrapper {\n                            p {\n                                &.content {\n                                    font-size: ${sizeHandler(10)};\n                                }\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    .footer-container.darkmode {\n        background-color: #292929;\n\n        .inner-container {\n            .default-info-wrapper {\n                .right {\n                    p {\n                        color: #e6e6e6;\n                    }\n                }\n\n                .policy {\n                    a {\n                        color: #e6e6e6;\n                    }\n                }\n            }\n\n            .footer-info {\n                .info-block {\n                    .row-wrapper {\n                        border-bottom: 1px solid #606060;\n\n                        p {\n                            &.title {\n                                color: #ffffff;\n                            }\n\n                            &.content {\n                                color: #a7a7a7;\n                            }\n\n                            &.infoTitle {\n                                color: #ffffff;\n                            }\n\n                            &.contactTitle {\n                                color: #ffffff;\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n`;\n\nexport default FooterStyledContainer;\n","import React from 'react';\nimport { withRouter } from 'react-router-dom';\n\n// component\nimport Footer from './footer';\n\n// styles\nimport FooterStyledContainer from './footer.styled';\n\nclass FooterContainer extends React.PureComponent {\n    render() {\n        return (\n            <FooterStyledContainer>\n                <Footer {...this.props} />\n            </FooterStyledContainer>\n        );\n    }\n}\n\nexport default withRouter(FooterContainer);\n","import React from 'react';\nimport { Switch, Route, withRouter } from 'react-router-dom';\nimport { connect } from 'react-redux';\nimport AOS from 'aos';\nimport { message, Spin } from 'antd';\nimport Modal from 'react-modal';\n\nimport ScrollTop from './Lib/utils';\nimport axios from './Lib/axios';\n\n// styles\nimport './Styles';\nimport 'aos/dist/aos.css';\n// antd-styles > set in /config-overrides.js\n// import 'antd/dist/antd.css';\n\n// components\nimport Home from './Pages/Home';\nimport Auth from './Pages/Auth';\n\n// 개인정보 수집 및 이용 동의 약관\nimport Privacy from './Pages/Policy/Privacy';\nimport Terms from './Pages/Policy/Terms';\nimport Marketing from './Pages/Policy/Marketing';\nimport EssentialNormal from './Pages/Policy/Essential/Normal';\nimport EssentialSensitive from './Pages/Policy/Essential/Sensitive';\nimport SelectiveNormal from './Pages/Policy/Selective/Normal';\nimport SelectiveSensitive from './Pages/Policy/Selective/Sensitive';\nimport Advertisement from './Pages/Policy/Advertisement';\n\nimport Company from './Pages/Company';\nimport FAQ from './Pages/Faq';\nimport Product from './Pages/Product';\n\nimport LongTermCare from './Pages/LongtermCare/longTermCare';\nimport Success from './Pages/Success/success';\nimport SManual from './Pages/Manual/Service/service';\nimport PManual from './Pages/Manual/Platform/platform';\nimport EduVideo from './Pages/Manual/MateEduVideo/eduVideo';\n\nimport NewsEvent from './Pages/NewsEvent';\n\nimport ReviewAdd from './Pages/Review/Add';\nimport ReviewList from './Pages/Review/List';\nimport ReviewMylist from './Pages/Review/MyList';\nimport MateReady from './Pages/Apply/Ready';\nimport MateApplyForm from './Pages/Apply/Form';\nimport MateApplyForm_v2 from './Pages/Apply/MateApplyForm';\nimport Nemt from './Pages/Guide';\nimport Guide from './Pages/Nemt';\nimport Reserve from './Pages/Reserve';\n\n// MetLife\nimport MetLife from './Pages/MetLife/MetLifeLanding';\n// import MetLifeReserve from './Pages/MetLife/Reserve';\nimport MetLifeNemt from './Pages/MetLife/MetLifeGuide';\nimport MetLifeReviewList from './Pages/MetLife/Review';\nimport MetLifeNewsEvent from './Pages/MetLife/NewsEvent';\nimport MetLifeFAQ from './Pages/MetLife/Faq';\nimport MetLifePrivacy from './Pages/MetLife/MetLifePolicy/Privacy';\nimport MetLifeTerms from './Pages/MetLife/MetLifePolicy/Terms';\n\nimport Department from './Pages/Big5Department/department';\n\nimport NotFound from './Pages/NotFound';\n// import Test from './Pages/Test';\n// import { FreeModal } from './Components/modal';\nimport { CardPopup, EventPopup, ManagerPopup, MetlifePopup, NoticePopup } from './Components/modal';\n\n// templates\nimport Nav from './Components/Templates/Nav';\nimport MetLifeNav from './Components/Templates/MetLifeNav';\nimport Footer from './Components/Templates/Footer';\n\nimport { editAuth, checkAuth } from './Reducer/Modules/auth';\nimport { MATE } from './Lib/variables';\nModal.setAppElement('#root');\n\nclass App extends React.PureComponent {\n    componentDidMount = async () => {\n        AOS.init();\n\n        const id = localStorage.getItem('id');\n        const userType = localStorage.getItem('userType');\n\n        if (id && userType) {\n            const { data } = await axios.get(`/v1/user/${id}/${userType}`);\n\n            if (data && data._id) {\n                this.props.editAuth({ type: 'id', value: data._id });\n                this.props.editAuth({ type: 'userType', value: userType });\n                this.props.editAuth({ type: 'name', value: data.name });\n                this.props.editAuth({ type: 'photo', value: data.photo });\n                this.props.editAuth({ type: 'contact', value: data.contact });\n                this.props.checkAuth({ id, userType });\n\n                localStorage.setItem('id', data._id);\n                localStorage.setItem('photo', data.photo);\n                localStorage.setItem('name', data.name);\n                localStorage.setItem('contact', data.contact);\n            }\n        }\n    };\n\n    render() {\n        const { location } = this.props.history;\n        const { userType, allowed } = this.props.auth;\n\n        if (userType === MATE && allowed === false) {\n            if (location.pathname === '/user/mate/mypage' || location.pathname === '/user/mate/mypage/history' || location.pathname === '/')\n                this.props.history.push('/user/mate/pending');\n        }\n\n        return (\n            <div id='app-container' className='app-container'>\n                {location.pathname.startsWith('/360F') ? <MetLifeNav {...this.props} /> : <Nav {...this.props} />}\n                <ScrollTop>\n                    <div className='main-area'>\n                        <Switch>\n                            <Route exact path='/' component={Home} />\n                            <Route exact path='/main/step1' component={Home} />\n                            <Route exact path='/main/step2' component={Home} />\n                            <Route exact path='/main/step3' component={Home} />\n                            <Route exact path='/reserve' component={Reserve} />\n                            <Route path='/reserve/:step' component={Reserve} />\n                            <Route path='/user' component={Auth} />\n                            <Route path='/product' component={Product} />\n                            <Route exact path='/faq' component={FAQ} />\n                            <Route exact path='/company' component={Company} />\n\n                            <Route exact path='/policy/privacy' component={Privacy} />\n                            <Route exact path='/policy/terms' component={Terms} />\n                            <Route exact path='/policy/marketing' component={Marketing} />\n                            <Route exact path='/policy/essential/normal' component={EssentialNormal} />\n                            <Route exact path='/policy/essential/sensitive' component={EssentialSensitive} />\n                            <Route exact path='/policy/selective/normal' component={SelectiveNormal} />\n                            <Route exact path='/policy/selective/sensitive' component={SelectiveSensitive} />\n                            <Route exact path='/policy/advertisement' component={Advertisement} />\n\n                            <Route exact path='/mate/apply' component={MateReady} />\n                            <Route exact path='/apply/form' component={MateApplyForm_v2} />\n                            <Route exact path='/mateApply/form' component={MateApplyForm} />\n\n                            <Route exact path='/review/list' component={ReviewList} />\n                            <Route exact path='/review/own/usage/list' component={ReviewMylist} />\n                            <Route exact path='/review/edit/:reserveId' component={ReviewAdd} />\n\n                            <Route exact path='/longTermCare' component={LongTermCare} />\n                            <Route exact path='/success' component={Success} />\n                            <Route exact path='/service/manual' component={SManual} />\n                            <Route exact path='/platform/manual' component={PManual} />\n                            <Route exact path='/mateEducation/manual' component={EduVideo} />\n\n                            <Route path='/NewsEvent' component={NewsEvent} />\n\n                            {/* MetLife */}\n                            <Route exact path='/360F' component={MetLife} />\n                            <Route path='/360F/nemt/service' component={MetLifeNemt} />\n                            <Route exact path='/360F/review/list' component={MetLifeReviewList} />\n                            <Route path='/360F/NewsEvent' component={MetLifeNewsEvent} />\n                            <Route exact path='/360F/faq' component={MetLifeFAQ} />\n                            <Route exact path='/360F/policy/privacy' component={MetLifePrivacy} />\n                            <Route exact path='/360F/policy/terms' component={MetLifeTerms} />\n\n                            <Route exact path='/department' component={Department} />\n\n                            {/* <Route path='/service/guide' component={Guide} /> */}\n                            <Route path='/nemt/service' component={Nemt} />\n\n                            <Route component={NotFound} />\n                        </Switch>\n                    </div>\n                </ScrollTop>\n                <Footer />\n                {this.props.app.loading ? (\n                    <div id='loading'>\n                        <Spin size='large' />\n                    </div>\n                ) : null}\n                {/* <FreeModal /> */}\n                {/* <NoticePopup /> */}\n                {/* <CardPopup /> */}\n                {/* <ManagerPopup /> */}\n                {/* {location.pathname === '/' ? <EventPopup /> : null} */}\n                {location.pathname === '/360F' ? <MetlifePopup /> : null}\n            </div>\n        );\n    }\n}\n\nconst mapStateToProps = ({ auth, app }) => ({\n    auth,\n    app,\n});\n\nconst mapDispatchToProps = dispatch => ({\n    editAuth: ({ type, value }) => dispatch(editAuth({ type, value })),\n    checkAuth: ({ id, userType }) => dispatch(checkAuth({ id, userType })),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withRouter(App));\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n  window.location.hostname === 'localhost' ||\n    // [::1] is the IPv6 localhost address.\n    window.location.hostname === '[::1]' ||\n    // 127.0.0.1/8 is considered localhost for IPv4.\n    window.location.hostname.match(\n      /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n    )\n);\n\nexport function register(config) {\n  if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n    // The URL constructor is available in all browsers that support SW.\n    const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n    if (publicUrl.origin !== window.location.origin) {\n      // Our service worker won't work if PUBLIC_URL is on a different origin\n      // from what our page is served on. This might happen if a CDN is used to\n      // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n      return;\n    }\n\n    window.addEventListener('load', () => {\n      const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n      if (isLocalhost) {\n        // This is running on localhost. Let's check if a service worker still exists or not.\n        checkValidServiceWorker(swUrl, config);\n\n        // Add some additional logging to localhost, pointing developers to the\n        // service worker/PWA documentation.\n        navigator.serviceWorker.ready.then(() => {\n          console.log(\n            'This web app is being served cache-first by a service ' +\n              'worker. To learn more, visit https://bit.ly/CRA-PWA'\n          );\n        });\n      } else {\n        // Is not localhost. Just register service worker\n        registerValidSW(swUrl, config);\n      }\n    });\n  }\n}\n\nfunction registerValidSW(swUrl, config) {\n  navigator.serviceWorker\n    .register(swUrl)\n    .then(registration => {\n      registration.onupdatefound = () => {\n        const installingWorker = registration.installing;\n        if (installingWorker == null) {\n          return;\n        }\n        installingWorker.onstatechange = () => {\n          if (installingWorker.state === 'installed') {\n            if (navigator.serviceWorker.controller) {\n              // At this point, the updated precached content has been fetched,\n              // but the previous service worker will still serve the older\n              // content until all client tabs are closed.\n              console.log(\n                'New content is available and will be used when all ' +\n                  'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n              );\n\n              // Execute callback\n              if (config && config.onUpdate) {\n                config.onUpdate(registration);\n              }\n            } else {\n              // At this point, everything has been precached.\n              // It's the perfect time to display a\n              // \"Content is cached for offline use.\" message.\n              console.log('Content is cached for offline use.');\n\n              // Execute callback\n              if (config && config.onSuccess) {\n                config.onSuccess(registration);\n              }\n            }\n          }\n        };\n      };\n    })\n    .catch(error => {\n      console.error('Error during service worker registration:', error);\n    });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n  // Check if the service worker can be found. If it can't reload the page.\n  fetch(swUrl)\n    .then(response => {\n      // Ensure service worker exists, and that we really are getting a JS file.\n      const contentType = response.headers.get('content-type');\n      if (\n        response.status === 404 ||\n        (contentType != null && contentType.indexOf('javascript') === -1)\n      ) {\n        // No service worker found. Probably a different app. Reload the page.\n        navigator.serviceWorker.ready.then(registration => {\n          registration.unregister().then(() => {\n            window.location.reload();\n          });\n        });\n      } else {\n        // Service worker found. Proceed as normal.\n        registerValidSW(swUrl, config);\n      }\n    })\n    .catch(() => {\n      console.log(\n        'No internet connection found. App is running in offline mode.'\n      );\n    });\n}\n\nexport function unregister() {\n  if ('serviceWorker' in navigator) {\n    navigator.serviceWorker.ready.then(registration => {\n      registration.unregister();\n    });\n  }\n}\n","import { createStore, combineReducers, applyMiddleware } from 'redux';\nimport thunk from 'redux-thunk';\n\n// reducers\nimport auth from './Modules/auth';\nimport app from './Modules/app';\nimport review from './Modules/review';\nimport newsEvent from './Modules/newsEvent';\n\nconst reducers = combineReducers({ app, auth, review, newsEvent });\nconst store = createStore(reducers, applyMiddleware(thunk));\nexport default store;\n","import 'react-app-polyfill/ie9';\nimport 'react-app-polyfill/stable';\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport { BrowserRouter } from 'react-router-dom';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\nimport { Provider } from 'react-redux';\nimport store from './Reducer';\n\nReactDOM.render(\n    <Provider store={store}>\n        <BrowserRouter>\n            <App />\n        </BrowserRouter>\n    </Provider>,\n    document.getElementById('root'),\n);\n\nserviceWorker.unregister();\n","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/login_bg.9bab868b.png\";","module.exports = __webpack_public_path__ + \"static/media/checkpoint.e82ce0ca.png\";","const req = require.context('./', true, /\\.scss$/);\nreq.keys().forEach(req);\n","var map = {\n\t\"./index.scss\": 846\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 845;"],"sourceRoot":""}