12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380 |
- <template>
- <view>
- <!-- 顶部导航栏 -->
- <view class="top-navbar">
- <view class="navbar-content">
- <!-- 左侧返回按钮 -->
- <view class="navbar-left" @click="goBack">
- <u-icon name="arrow-leftward" size="48" color="#333"></u-icon>
- </view>
-
- <!-- 中间用户信息 -->
- <view class="navbar-center">
- <view class="user-info">
- <view class="avatar-container">
- <image :src="postPushInfo.company ? postPushInfo.company.companyLogo : '../../static/logo.png'" class="user-avatar" mode="aspectFill"></image>
- <view class="status-indicator"></view>
- </view>
- <view class="user-details">
- <view class="user-name">{{ postPushInfo.company ? postPushInfo.company.companyLegalPerson : '未知' }}</view>
- <view class="user-title">{{ postPushInfo.company ? postPushInfo.company.companyName : '未知公司' }}</view>
- </view>
- </view>
- </view>
-
- <!-- 右侧更多按钮 -->
- <view class="navbar-right" @click="showMoreOptions">
- <u-icon name="more-dot-fill" size="38" color="#333"></u-icon>
- </view>
- </view>
- </view>
-
- <!-- 顶部操作 -->
- <view class="topSe flex justify-center" v-if="userType==1">
- <view class="topSe-box flex align-center justify-around">
- <view class="topSe-box-item flex flex-wrap justify-center" @click="currentPhone()">
- <image src="../../static/im/mobilePhone2.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 换电话
- </view>
- </view>
- <view class="topSe-box-item flex flex-wrap justify-center" @click="currentWchat()">
- <image src="../../static/im/weiChat2.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 换微信
- </view>
- </view>
- <view class="topSe-box-item flex flex-wrap justify-center" @click="sendResumes()">
- <image src="../../static/im/orderInfo2.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 发简历
- </view>
- </view>
- <view class="topSe-box-item flex flex-wrap justify-center">
- <image src="../../static/im/nowei.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 无兴趣
- </view>
- </view>
- </view>
- </view>
- <view class="topSe flex justify-center" v-else>
- <view class="topSe-box flex align-center justify-around">
- <view class="topSe-box-item flex flex-wrap justify-center" @click="currentPhone()">
- <image src="../../static/im/mobilePhone.png" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 换电话
- </view>
- </view>
- <view class="topSe-box-item flex flex-wrap justify-center" @click="currentWchat()">
- <image src="../../static/im/weiChat.png" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 换微信
- </view>
- </view>
- <view class="topSe-box-item flex flex-wrap justify-center" @click="giveSendResumes()">
- <image src="../../static/im/orderInfo.png" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 求简历
- </view>
- </view>
- <view class="topSe-box-item flex flex-wrap justify-center" @click="mianshiF()">
- <image src="../../static/im/mianshi.png" style="width: 48rpx;height: 48rpx;" mode=""></image>
- <view class="" style="color: #999999;">
- 约面试
- </view>
- </view>
- </view>
- </view>
- <scroll-view scroll-y="true" @touchstart="hideDrawer" @scroll="scroll" :scroll-top="scrollTop"
- style="height: calc(100vh - 360rpx);width: 100%;padding: 20rpx 0;">
- <!-- 温馨提示 -->
- <!-- <view class="xuanfu">
- <view class="xuanfu-box flex">
- <view class="" style="margin-right: 10rpx;">
- <image style="width: 30rpx;height: 30rpx;"
- src="https://zhaopin.xianmaxiong.com/file/uploadPath/2022/09/07/85e0d70ba1d9a78463b36bf7f92f6dca.png"
- mode=""></image>
- </view>
- <view class="">
- {{messages}}
- </view>
- </view>
- </view> -->
- <!-- 岗位简介 -->
- <view class="jobs flex justify-center" v-if="JSON.stringify(postPushInfo)!='{}'">
- <view class="jobs-box">
- <view class="gwList-box-item flex justify-center" @click="gotoInfo(postPushInfo.postPushId)">
- <view class="gwList-box-item-box">
- <view class="gwList-box-item-box-title flex justify-between align-center">
- <text>{{postPushInfo.stationName}}</text>
- <text>{{postPushInfo.salaryRange}}</text>
- </view>
- <!-- 公司和人数 -->
- <view class="gwList-box-item-box-name flex align-center">
- <text>{{postPushInfo.company?postPushInfo.company.companyName:''}}</text>
- <text
- v-if="postPushInfo.company">{{postPushInfo.company?postPushInfo.company.companyPeople:'0人'}}</text>
- </view>
- <view class="gwList-box-item-box-label flex align-center flex-wrap">
- <text
- style="color: #666666;font-size: 26rpx;padding: 10rpx;background: rgba(198, 198, 198, 0.1);border-radius: 8rpx;margin-right: 10rpx;margin-bottom: 20rpx;">
- {{postPushInfo.education}}
- </text>
- <text
- style="color: #666666;font-size: 26rpx;padding: 10rpx;background: rgba(198, 198, 198, 0.1);border-radius: 8rpx;margin-right: 10rpx;margin-bottom: 20rpx;">
- {{postPushInfo.experience}}
- </text>
- <text
- style="color: #666666;font-size: 26rpx;padding: 10rpx;background: rgba(198, 198, 198, 0.1);border-radius: 8rpx;margin-right: 10rpx;margin-bottom: 20rpx;"
- v-for="(ite,ind) in postPushInfo.positionWelfare" :key="ind">{{ite}}</text>
- </view>
- <!-- <view class="gwList-box-item-box-line"></view> -->
- <!-- 工作描述 -->
- <view class="gwList-box-item-box-info-text">
- <view class="job-description-item">1.负责Amazon英国、欧洲站、制定推广与销售计划,达成团队要求的销售业绩;</view>
- <view class="job-description-item">2.做好数据的统计分析工作,收集、分析市场信息,竞争对手状况,并根据产品销售与排名变化,及时制定和调整产品的销售策略;</view>
- <view class="job-description-item" v-if="isJobDescExpanded">3.熟悉Amazon店铺操作,负责店铺产品编辑上传,精准把握关键词选择,负责标题,详情页面的优化;</view>
- <view class="job-description-item" v-if="isJobDescExpanded">4.熟悉Amazon平台规则,熟悉Amazon站内广告投放和促销式,站外促销,找红人营销等提高曝光率和转化率的引流方</view>
- <view class="job-description-item" v-if="isJobDescExpanded">5.控制产品风险,合理规划FBA库存,及时合理处理滞销FBA库存;</view>
- <view class="job-description-item" v-if="isJobDescExpanded">6.对产品销售进行跟踪,分析,及时汇报销售中存在的问题,并给出可行性意见;</view>
- <view class="job-description-item" v-if="isJobDescExpanded">7.及时处理客户留言及回评,解答客户相关咨询与投诉,并进行问题整理统计分析,提高店铺的好评率,确保账号安全;</view>
- <view class="job-description-item" v-if="isJobDescExpanded">8.每月定期整理分析运营各项数据,并提出相应的合理化建议。</view>
- <!-- 展开/收起按钮 -->
- <view class="expand-btn" @click.stop="toggleJobDesc">
- <text class="expand-text">{{ isJobDescExpanded ? '收起' : '展开更多' }}</text>
- </view>
- </view>
- <!-- hr信息 -->
- <view class="gwList-box-item-box-info flex justify-between align-center">
- <view class="gwList-box-item-box-info-l flex align-center">
- <image
- :src="postPushInfo.company?postPushInfo.company.companyLogo:'../../static/logo.png'"
- style="width: 58rpx;height: 58rpx;border-radius: 50%;margin-right: 20rpx;"
- mode=""></image>
- <view class="people" v-if="postPushInfo.company">
- {{postPushInfo.company.companyLegalPerson?postPushInfo.company.companyLegalPerson:'未知'}}
- </view>·创始人
- </view>
- <!--
- <view class="gwList-box-item-box-info-r flex justify-end">
- {{postPushInfo.county}} {{postPushInfo.address}}
- </view>
- -->
- </view>
- <!-- 时间和收藏 -->
- <view class="time-favorite flex justify-between align-center">
- <view class="time-text">
- 7月24日 14:34 向你发起的沟通
- </view>
- <view class="favorite-btn flex align-center" @click.stop="toggleFavorite">
- <text class="favorite-icon">☆</text>
- <text class="favorite-text">收藏职位</text>
- </view>
- </view>
- </view>
- </view>
- </view>
- </view>
- <!-- 简历简介 -->
- <view class="jobs flex justify-center" v-if="JSON.stringify(resumesInfo)!='{}'">
- <view class="jobs-box">
- <view class="qyList-box-item flex justify-center"
- @click="goNav('/pages/index/game/orderDet?resumesId='+resumesInfo.resumesId)">
- <view class="qyList-box-item-box">
- <view class="qyList-box-item-info flex justify-between align-center">
- <view class="qyList-box-item-info-l">
- <view class="" style="color: #212121;font-size: 38rpx;font-weight: 800;">
- {{resumesInfo.resumesName}}
- </view>
- <view class="flex align-center flex-wrap"
- style="color: #999999;font-size: 26rpx;margin-top: 10rpx;">
- <text>{{resumesInfo.resumesAge}}岁</text>
- <text style="margin-left: 20rpx;margin-right: 20rpx;">|</text>
- <text>{{resumesInfo.resumesWorkExperience}}</text>
- <text style="margin-left: 20rpx;margin-right: 20rpx;">|</text>
- <text>{{resumesInfo.school}}</text>
- <text style="margin-left: 20rpx;margin-right: 20rpx;">|</text>
- <text>期望{{resumesInfo.resumesCompensation}}</text>
- </view>
- </view>
- <view class="qyList-box-item-info-r">
- <image :src="resumesInfo.avatar?resumesInfo.avatar:'../../static/logo.png'"
- style="width: 95rpx;height: 95rpx;border-radius: 50%;" mode=""></image>
- </view>
- </view>
- <view class="qyList-box-item-job flex align-center">
- <u-icon name="heart-fill" color="#00B88F" size="30" style="margin-right: 16rpx;">
- </u-icon>
- 期望岗位:{{resumesInfo.resumesPost}}
- </view>
- <view class="qyList-box-item-job flex align-center"
- v-if="resumesInfo.resumesCompanyList[0]">
- <image src="../../static/images/qi.png"
- style="width: 30rpx;height: 32rpx;margin-right: 16rpx;" mode=""></image>
- {{resumesInfo.resumesCompanyList[0]?resumesInfo.resumesCompanyList[0].resumesTitle:''}}
- /
- {{resumesInfo.resumesCompanyList[0]?resumesInfo.resumesCompanyList[0].resumesPost:''}}
- </view>
- <view class="qyList-box-item-job flex align-center" v-else>
- <image src="../../static/images/qi.png"
- style="width: 30rpx;height: 32rpx;margin-right: 16rpx;" mode=""></image>
- 暂无
- </view>
- <view class="qyList-box-item-rem" v-if="resumesInfo.resumesDetails">
- 优势:{{resumesInfo.resumesDetails}}
- </view>
- </view>
- </view>
- </view>
- </view>
- <!-- 聊天记录 -->
- <view style="display: flex;flex-direction: column;" v-for="(item,index) in ListItem" :key="index" :id=" 'id-'+index">
- <view style="margin-top: 15rpx;width: 100%;text-align: center;font-size: 26rpx;color: #999999;"
- v-if="item.createTime">
- {{item.createTime}}
- </view>
- <view v-if="item.userId && userId != item.userId" style="width: 83%;margin-right: 15%;">
- <view class="chat-listitem" style="float: left;margin-left: 10rpx;">
- <view>
- <image @tap="goGuanZhu(item)" :src="item.avatar ? item.avatar : '/static/logo.png'"
- class="chat-listitem-image"></image>
- </view>
- <view v-if="item.content && item.messageType === 1" @longpress="copy(item.content)"
- class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">{{item.content}}</view>
- <view v-if="item.messageType === 20" @tap="sendCallVideo(2)"
- class="chat-listitem-text flex align-center"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- 视频通话
- <image src="../../static/im/historyVideo_black.png"
- style="width: 50rpx;height: 50rpx;margin-left: 20rpx;" mode=""></image>
- </view>
- <view v-if="item.messageType === 21" @tap="sendCallVideo(1)"
- class="chat-listitem-text flex align-center"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- 语音通话
- <image src="../../static/im/historyAudio_black.png"
- style="width: 50rpx;height: 50rpx;margin-left: 20rpx;" mode=""></image>
- </view>
- <!-- 互换手机号 -->
- <view v-if="item.content && item.messageType === 5 && item.content=='手机号请求'"
- @longpress="copy(item.content)" class="chat-listitem-text"
- style="padding-bottom: 20rpx;;padding-top: 20rpx;margin-left: 20rpx;color: #000000;background-color: #ffffff;border: 1rpx solid #c6fee7;background: linear-gradient(to bottom, #D9FEED, #ffffff);">
- <view class="flex align-center">
- <image src="../../static/im/mobilePhone.png"
- style="width: 60rpx;height: 60rpx;margin-right: 10rpx;" mode=""></image>
- 我想跟你交换手机号,是否同意?
- </view>
- <view class="flex justify-between" style="margin-top: 30rpx;font-size: 24rpx;">
- <view @click.stop="refuseFun(item.chatContentId)"
- class="flex justify-center align-center"
- style="width: 40%;height: 50rpx;background-color: #F5F5F5;border-radius: 12rpx;">
- 拒绝
- </view>
- <view @click.stop="tongyi(item.messageType,item.chatContentId)"
- class="flex justify-center align-center"
- style="width: 40%;height: 50rpx;background-color: #D9FEED;border-radius: 12rpx;">
- 同意
- </view>
- </view>
- </view>
- <view v-if="item.content && item.messageType === 5 && item.content!='手机号请求'"
- class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- 已同意交换手机号
- </view>
- <view v-if="item.content && item.messageType === 7"
- @longpress="copyss(item.content,item.userType,'phone')" class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- <view class="" v-if="item.userType==1">
- 我的手机号为:{{JSON.parse(item.content).userPhone}}
- </view>
- <view class="" v-else>
- 我的手机号为:{{JSON.parse(item.content).companyPhone}}
- </view>
- </view>
- <!-- 互换微信号 -->
- <view v-if="item.content && item.messageType === 6 && item.content=='微信号请求'"
- @longpress="copy(item.content)" class="chat-listitem-text"
- style="padding-bottom: 20rpx;;padding-top: 20rpx;margin-left: 20rpx;color: #000000;background-color: #ffffff;border: 1rpx solid #c6fee7;background: linear-gradient(to bottom, #D9FEED, #ffffff);">
- <view class="flex align-center">
- <image src="../../static/im/weiChat.png"
- style="width: 60rpx;height: 60rpx;margin-right: 10rpx;" mode=""></image>
- 我想跟你交换微信号,是否同意?
- </view>
- <view class="flex justify-between" style="margin-top: 30rpx;font-size: 24rpx;">
- <view @click.stop="refuseFun(item.chatContentId)"
- class="flex justify-center align-center"
- style="width: 40%;height: 50rpx;background-color: #F5F5F5;border-radius: 12rpx;">
- 拒绝
- </view>
- <view @click.stop="tongyi(item.messageType,item.chatContentId)"
- class="flex justify-center align-center"
- style="width: 40%;height: 50rpx;background-color: #D9FEED;border-radius: 12rpx;">
- 同意
- </view>
- </view>
- </view>
- <view v-if="item.content && item.messageType === 6 && item.content!='微信号请求'"
- class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- 已同意交换微信号
- </view>
- <view v-if="item.content && item.messageType === 8"
- @longpress="copyss(item.content,item.userType,'wx')" class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- <view class="" v-if="item.userType==1">
- 我的微信号为:{{JSON.parse(item.content).userWx}}
- </view>
- <view class="" v-else>
- 我的微信号为:{{JSON.parse(item.content).companyWx}}
- </view>
- </view>
- <view v-if="item.content && item.messageType === 9 && item.content=='简历请求'"
- @longpress="copy(item.content)" class="chat-listitem-text"
- style="padding-bottom: 20rpx;;padding-top: 20rpx;margin-left: 20rpx;color: #000000;background-color: #ffffff;border: 1rpx solid #c6fee7;background: linear-gradient(to bottom, #D9FEED, #ffffff);">
- <view class="flex align-center">
- <image src="../../static/im/orderInfo.png"
- style="width: 60rpx;height: 60rpx;margin-right: 10rpx;" mode=""></image>
- 我想要你的一份简历,是否同意?
- </view>
- <view class="flex justify-between" style="margin-top: 30rpx;font-size: 24rpx;">
- <view @click.stop="refuseFun(item.chatContentId)"
- class="flex justify-center align-center"
- style="width: 40%;height: 50rpx;background-color: #F5F5F5;border-radius: 12rpx;">
- 拒绝
- </view>
- <view @click.stop="resumesTy()" class="flex justify-center align-center"
- style="width: 40%;height: 50rpx;background-color: #D9FEED;border-radius: 12rpx;">
- 同意
- </view>
- </view>
- </view>
- <view v-if="item.content && item.messageType === 9 && item.content!='简历请求'"
- @longpress="copy(item.content)" class="chat-listitem-text"
- style="padding-bottom: 20rpx;;padding-top: 20rpx;margin-left: 20rpx;color: #000000;background-color: #ffffff;border: 1rpx solid #c6fee7;background: linear-gradient(to bottom, #D9FEED, #ffffff);">
- <view class="flex align-center">
- <image src="../../static/im/orderInfo.png"
- style="width: 60rpx;height: 60rpx;margin-right: 10rpx;" mode=""></image>
- {{item.content}}
- </view>
- </view>
- <view v-if="item.content && item.messageType === 10" class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- {{item.content}}
- </view>
- <view v-if="item.content && item.messageType === 12" class="chat-listitem-text"
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;">
- {{item.content}}已拒绝
- </view>
- <image @tap="viewImg(item.content)" v-if="item.content && item.messageType === 2"
- :src="item.content" style="height: 200rpx;width: 200rpx;margin-left: 20rpx;"></image>
- <image class="chat-listitem-text" @tap="viewImg(item.content)"
- v-if="item.content && item.messageType === 4"
- :src="'https://zp.118zp.com/emoji/' +item.content"
- style="height: 80rpx;width: 80rpx;margin-left: 20rpx;"></image>
- <view v-if="item.content && item.messageType === 3" class="chat-listitem-text bubble voice"
- :class="playMsgid == index?'play':''"
- style="margin-left: 20rpx;display: flex;align-items: center;"
- @tap="playVoice(item.content,index)">
- <image v-if="playMsgid != index" src="../../static/im/laba.png"
- style="width: 35upx;height: 40upx;margin-right: 10rpx;"></image>
- <image v-if="playMsgid == index" src="../../static/im/labagif.gif"
- style="width: 35upx;height: 40upx;margin-right: 10rpx;"></image>
- <view class="length">{{item.width ? item.width : 0}}</view>
- </view>
- <view class="chat-listitem-text "
- style="margin-left: 20rpx;color: #000000;background-color: #ffffff;"
- v-if="item.content && item.messageType === 18"
- @click="openMapss(item.content.latitude,item.content.longitude,item.content.address)">
- <view class="padding-sm flex">
- <!-- #ifdef APP -->
- <u-icon name="map-fill" color="#ffffff" size="28" style="margin-right: 10rpx;"></u-icon>
- <!-- #endif -->
- {{item.content.address}}
- </view>
- <!-- #ifndef APP -->
- <map style="width: 100%; height: 120px;" scale="14" :latitude="item.content.latitude"
- :longitude="item.content.longitude"
- @tap="openMapss(item.content.latitude,item.content.longitude,item.content.address)"
- :markers="item.markers">
- </map>
- <!-- #endif -->
- </view>
- </view>
- </view>
- <!-- ++++++++++++++++++++++++++ -->
- <view v-if="item.userId && userId == item.userId" style="width: 83%;margin-left: 15%;">
- <view class="chat-listitem" style="float: right;">
- <view v-if="item.content && item.messageType === 1" @longpress="caozuoActive(item,1)"
- class="chat-listitem-text textColor" style="margin-right: 20rpx;">{{item.content}}</view>
- <view v-if="item.messageType === 20" @tap="sendCallVideo(2)"
- class="chat-listitem-text textColor flex align-center" style="margin-right: 20rpx;">
- 视频通话
- <image src="../../static/im/historyVideo_white.png"
- style="width: 50rpx;height: 50rpx;margin-left: 20rpx;" mode=""></image>
- </view>
- <view v-if="item.messageType === 21" @tap="sendCallVideo(1)"
- class="chat-listitem-text textColor flex align-center" style="margin-right: 20rpx;">
- 语音通话
- <image src="../../static/im/historyAudio_white.png"
- style="width: 50rpx;height: 50rpx;margin-left: 20rpx;" mode=""></image>
- </view>
- <view v-if="item.content && item.messageType === 5" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- 交换手机号请求已发送,等待对方同意
- </view>
- <view v-if="item.content && item.messageType === 7"
- @longpress="copyss(item.content,item.userType,'phone')" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- <view class="" v-if="item.userType==1">
- 我的手机号为:{{JSON.parse(item.content).userPhone}}
- </view>
- <view class="" v-else>
- 我的手机号为:{{JSON.parse(item.content).companyPhone}}
- </view>
- </view>
- <view v-if="item.content && item.messageType === 6" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- 交换微信号请求已发送,等待对方同意
- </view>
- <view v-if="item.content && item.messageType === 8"
- @longpress="copyss(item.content,item.userType,'wx')" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- <view class="" v-if="item.userType==1">
- 我的微信号为:{{JSON.parse(item.content).userWx}}
- </view>
- <view class="" v-else>
- 我的微信号为:{{JSON.parse(item.content).companyWx}}
- </view>
- </view>
- <view v-if="item.content && item.messageType === 9" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- 简历请求已发送,等待对方同意
- </view>
- <view v-if="item.content && item.messageType === 10" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- {{item.content}}
- </view>
- <view v-if="item.content && item.messageType === 12" class="chat-listitem-text textColor"
- style="margin-right: 20rpx;">
- {{item.content}}已拒绝
- </view>
- <view class="chat-listitem-text textColor" style="margin-right: 20rpx;"
- v-if="item.content && item.messageType === 18"
- @click="openMapss(item.content.latitude,item.content.longitude,item.content.address)">
- <view class="padding-sm flex">
- <!-- #ifdef APP -->
- <u-icon name="map-fill" color="#ffffff" size="28" style="margin-right: 10rpx;"></u-icon>
- <!-- #endif -->
- {{item.content.address}}
- </view>
- <!-- #ifndef APP -->
- <map style="width:520upx; height: 120px;" scale="14" :latitude="item.content.latitude"
- :longitude="item.content.longitude"
- @tap="openMapss(item.content.latitude,item.content.longitude,item.content.address)"
- :markers='item.markers'>
- </map>
- <!-- #endif -->
- </view>
- <!-- <view v-if="item.content && item.messageType === 1" @longpress="copy(item.content)"
- class="chat-listitem-text" style="margin-right: 20rpx;">{{item.content}}</view> -->
- <image @longpress="caozuoActive(item)" @tap="viewImg(item.content)"
- v-if="item.content && item.messageType === 2" :src="item.content"
- style="height: 200rpx;width: 200rpx;margin-right: 20rpx;"></image>
- <image class="chat-listitem-text textColor" @longpress="caozuoActive(item)"
- @tap="viewImg(item.content)" v-if="item.content && item.messageType === 4"
- :src="'https://zp.118zp.com/emoji/' +item.content"
- style="height: 80rpx;width: 80rpx;margin-right: 20rpx;">
- </image>
- <view v-if="item.content && item.messageType === 3"
- class="chat-listitem-text bubble voice textColor" :class="playMsgid == index?'play':''"
- style="margin-right: 20rpx;display: flex;align-items: center;"
- @longpress="caozuoActive(item)" @tap="playVoice(item.content,index)">
- <view class="length">{{item.width ? item.width : 0}}</view>
- <image v-if="playMsgid != index" src="../../static/im/labaleft.png"
- style="width: 35upx;height: 40upx;margin-left: 10rpx;"></image>
- <image v-if="playMsgid == index" src="../../static/im/labaleft.png"
- style="width: 35upx;height: 40upx;margin-left: 10rpx;"></image>
- </view>
- <view>
- <image :src="imageUrl" class="chat-listitem-image"></image>
- </view>
- </view>
- </view>
- </view>
- <!-- </view> -->
- </scroll-view>
- <!-- 底部聊天输入框 -->
- <!-- <view class="input-box">
- <view style="display: flex;margin-top: 15rpx;width: 100%;">
- <image src="https://renwu.xiansqx.com/img/20210817/024ca47bc591460daf76762a8e98283f.png" @click="chooseImage(['album'])" style="width: 60rpx;height: 60rpx;margin-top: 8rpx;"></image>
- <input confirm-type="send" @confirm='setChatSave(1)' type="text" v-model="content"
- style="width: 68%;height: 70rpx;background: #FFFFFF;margin: 4rpx 10rpx 0;border-radius: 10rpx;padding-left: 10rpx;" />
- <view class="save" @tap='setChatSave(1)'>发送</view>
- </view>
- </view> -->
- <!-- 长按操作菜单 -->
- <u-action-sheet :list="activelist" @click="activeclick" v-model="showActive" :tips="tips"></u-action-sheet>
- <!-- 抽屉栏 -->
- <view class="popup-layer" :class="popupLayerClass" @touchmove.stop.prevent="discard">
- <!-- 表情 -->
- <swiper class="emoji-swiper" indicator-active-color="#cccccc" :class="{hidden:hideEmoji}"
- indicator-dots="true" duration="150">
- <swiper-item v-for="(page1,pid) in emojiList" :key="pid">
- <view v-for="(em,eid) in page1" :key="eid" @tap="setChatSave(4,em.url)">
- <!-- <image src="../../static/emoji/100.gif" mode="widthFix"></image> -->
- <image mode="widthFix" :src="'https://zp.118zp.com/emoji/'+em.url"></image>
- </view>
- </swiper-item>
- </swiper>
- <!-- 更多功能 相册-拍照-红包 -->
- <view class="more-layer" :class="{hidden:hideMore}">
- <view class="list" style="color: #000000;">
- <!-- 上传图片 -->
- <view style="margin-bottom: 20rpx;">
- <view class="box" @click="chooseImage(['album'])">
- <image src="../../static/im/tupian.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
- </view>
- <view style="width: 100%;text-align: center;">上传图片</view>
- </view>
- <!-- #ifdef H5 || APP -->
- <!-- 语音 -->
- <view style="margin-bottom: 20rpx;">
- <view class="box" @tap="sendCallVideo(1)">
- <image src="../../static/im/yuyin.svg" mode=""
- style="width: 48rpx;height: 48rpx;">
- </image>
- </view>
- <view style="width: 100%;text-align: center;">语音</view>
- </view>
- <!-- 视频 -->
- <view style="margin-bottom: 20rpx;">
- <view class="box" @tap="sendCallVideo(2)">
- <image src="../../static/im/shipin.svg" mode=""
- style="width: 48rpx;height: 48rpx;">
- </image>
- </view>
- <view style="width: 100%;text-align: center;">视频</view>
- </view>
- <!-- #endif -->
- <!-- 常用语 -->
- <view style="margin-bottom: 20rpx;">
- <view class="box" @tap="showChangYongSelect">
- <view class="icon jianpan"></view>
- </view>
- <view style="width: 100%;text-align: center;">常用语句</view>
- </view>
- <!-- 添加常用语或自动回复内容 -->
- <view style="margin-bottom: 20rpx;">
- <view class="box" @tap="goAdd">
- <view class="icon add"></view>
- </view>
- <view style="width: 100%;text-align: center;">添加语句</view>
- </view>
- <view style="margin-bottom: 20rpx;">
- <view class="box" @tap="goMapss">
- <image src="../../static/images/weizhi.png" mode="" style="width: 76rpx;height: 76rpx;">
- </image>
- </view>
- <view style="width: 100%;text-align: center;">发送位置</view>
- </view>
- <view>
- <view class="box" @tap="goHistory">
- <view class="icon chehui"></view>
- </view>
- <view style="width: 100%;text-align: center;">聊天记录</view>
- </view>
- </view>
- </view>
- </view>
- <!-- 底部输入栏 -->
- <view class="input-box" :class="popupLayerClass" @touchmove.stop.prevent="discard">
- <!-- H5下不能录音,输入栏布局改动一下 -->
- <!-- #ifndef H5 -->
- <view class="voice">
- <view class="icon" :class="isVoice?'jianpan':'yuyin'" @tap="switchVoice"></view>
- </view>
- <!-- #endif -->
- <view class="textbox">
- <view class="voice-mode" :class="[isVoice?'':'hidden',recording?'recording':'']"
- @touchstart="voiceBegin" @touchmove.stop.prevent="voiceIng" @touchend="voiceEnd"
- @touchcancel="voiceCancel">{{voiceTis}}</view>
- <view class="text-mode" :class="isVoice?'hidden':''">
- <!-- 常用语按钮 -->
- <view class="changgui" @tap="showChangYongSelect">
- <image src="../../static/im/changgui.svg" style="width: 56rpx;height: 56rpx;" mode=""></image>
- </view>
- <view class="box">
- <input style="color: #000000;" auto-height="true" @confirm='setChatSave(1)' v-model="content"
- @focus="textareaFocus" />
- </view>
- <view class="em" @tap="chooseEmoji">
- <image src="../../static/im/smail.svg" style="width: 56rpx;height: 56rpx;" mode=""></image>
- </view>
- <!-- #ifdef H5 -->
- <view class="more" @tap="showMore" style="height: auto;">
- <image src="../../static/im/buleAdd.svg" style="width: 56rpx;height: 56rpx;" mode=""></image>
- </view>
- <!-- #endif -->
- </view>
- </view>
- <!-- #ifndef H5 -->
- <view class="more" @tap="showMore">
- <view class="icon add"></view>
- </view>
- <!-- #endif -->
- <view class="send" :class="isVoice?'hidden':''" @tap='setChatSave(1)'>
- <view class="btn">发送</view>
- </view>
- </view>
- <!-- 录音UI效果 -->
- <view class="record" :class="recording?'':'hidden'">
- <view class="ing" :class="willStop?'hidden':''">
- <view class="icon luyin2"></view>
- </view>
- <view class="cancel" :class="willStop?'':'hidden'">
- <view class="icon chehui"></view>
- </view>
- <view class="tis" :class="willStop?'change':''">{{recordTis}}</view>
- </view>
- <u-select v-model="showChangYong" title="常用词语" mode="single-column" :list="changYongList" @confirm="selConfirm">
- </u-select>
- <u-action-sheet :list="list" @click="click" v-model="show"></u-action-sheet>
- <u-popup v-model="mianshiShow" mode="bottom" z-index="998" :mask-close-able="false" border-radius="14"
- @close="cleanMs" :closeable="true">
- <view class="mianshiTitle">面试邀请</view>
- <view class="mianshiTime flex justify-center">
- <view class="mianshiTime-box flex justify-between align-center">
- <view class="">
- 面试时间
- </view>
- <view class="flex align-center mianshiTime-box-ti">
- <u-input disabled v-model="miamshi.interviewDateTime" @click="msTime=true" type="text"
- placeholder="请选择面试时间" />
- <u-icon name="arrow-right" style="margin-left: 10rpx;" color="#00B88F" size="28"
- @click="msTime=true"></u-icon>
- </view>
- </view>
- </view>
- <view class="mianshiTime flex justify-center">
- <view class="mianshiTime-box flex justify-between align-center">
- <view class="">
- 面试地址
- </view>
- <view class="flex align-center mianshiTime-box-ti">
- <u-input disabled @click="goMap()" v-model="miamshi.detailedAddress" type="text"
- placeholder="请选择面试地址" />
- <u-icon name="arrow-right" style="margin-left: 10rpx;" @click="goMap()" color="#00B88F"
- size="28"></u-icon>
- </view>
- </view>
- </view>
- <view class="mianshiTime flex justify-center">
- <view class="mianshiTime-box" style="border: none;">
- <view class="">
- 备注
- </view>
- <view class="flex align-center mianshiTime-box-ti">
- <u-input v-model="miamshi.remarks" type="textarea" input-align="left"
- style="padding: 10rpx;background-color: #F2F2F7;height: 200rpx;overflow: hidden;border-radius: 14rpx;width: 100%;"
- :auto-height="false" />
- </view>
- </view>
- </view>
- <view class="btnm flex justify-center">
- <view class="btn-box flex justify-around align-center">
- <view class="btn-close btnItem" @click="mianshiShow = false">
- 取消
- </view>
- <view class="btn-sub btnItem" @click="submitMs()">
- 确认
- </view>
- </view>
- </view>
- </u-popup>
- <u-toast ref="uToast" />
- <u-picker v-model="msTime" mode="time" :params="params" @confirm="mianshiConfirm" confirm-color="#00B88F">
- </u-picker>
- <!-- 面试邀请弹窗 -->
- <u-popup v-model="msshow" mode="center" z-index="998" border-radius="24" :mask-close-able="false" width="80%">
- <view class="mssTitle">
- 面试邀请
- </view>
- <view class="avatorm flex justify-center">
- <view class="avatorm-box flex justify-center">
- <block v-if="records.userEntity && records.userEntity.userAvatar">
- <image :src="records.userEntity.userAvatar"
- style="width: 100rpx;height: 100rpx;border-radius: 50%;" mode="">
- </image>
- </block>
- <block v-else>
- <image src="../../static/logo.png" style="width: 100rpx;height: 100rpx;border-radius: 50%;"
- mode="">
- </image>
- </block>
- <block v-if="records.company && records.company.companyLogo">
- <image :src="records.company.companyLogo"
- style="width: 100rpx;height: 100rpx;border-radius: 50%;" mode="">
- </image>
- </block>
- <block v-else>
- <image src="../../static/logo.png" style="width: 100rpx;height: 100rpx;border-radius: 50%;"
- mode="">
- </image>
- </block>
- </view>
- </view>
- <view class="avatorm flex justify-center">
- <view class="avatorm-box">
- <view class="avatorm-box-item flex">
- <view class="avatorm-box-item-t">
- 面试岗位:
- </view>
- <view class="avatorm-box-item-r">
- {{records.postPush?records.postPush.stationName:'未知'}}
- </view>
- </view>
- <view class="avatorm-box-item flex" v-if="records">
- <view class="avatorm-box-item-t">
- 面试时间:
- </view>
- <view class="avatorm-box-item-r">
- {{records.interviewDateTime}}
- </view>
- </view>
- <view class="avatorm-box-item flex" @click="goMapDap(records)">
- <view class="avatorm-box-item-t">
- 面试地点:
- </view>
- <view class="avatorm-box-item-r">
- {{records.detailedAddress}}
- <u-icon name="map-fill" color="#00B88F" size="28"></u-icon>
- </view>
- </view>
- <view class="avatorm-box-item flex">
- <view class="avatorm-box-item-t">
- 面试备注:
- </view>
- <view class="avatorm-box-item-r">
- {{records.remarks?records.remarks:'暂无'}}
- </view>
- </view>
- </view>
- </view>
- <view class="avatorm flex justify-center" v-if="records.company">
- <view class="avatorm-box flex justify-center">
- 来自{{records.company.companyName}}的面试邀请,是否接受?
- </view>
- </view>
- <view class="btnm flex justify-center" style="margin-bottom: 30rpx;">
- <view class="btn-box flex justify-around align-center">
- <view class="btn-close btnItem" @click="setJuJue(records)">
- 拒绝
- </view>
- <view class="btn-sub btnItem" @click="setJuJues(records)">
- 接受
- </view>
- </view>
- </view>
- </u-popup>
- <!-- 交换微信自定义弹窗 -->
- <u-popup v-model="wechatExchangeShow" mode="center" z-index="999" border-radius="24" :mask-close-able="false" width="80%">
- <view class="phone-exchange-popup">
- <!-- 顶部背景区域 -->
- <view class="phone-exchange-header">
- <image src="../../static/im/Artwork.png" class="phone-exchange-bg" mode="aspectFill"></image>
- </view>
-
- <!-- 中间内容区域 -->
- <view class="phone-exchange-content">
- <view class="phone-exchange-title">确认与对方交换微信吗?</view>
- <view class="phone-exchange-desc">交换成功后,双方可以查看彼此的微信号<br/>您可以前往个人中心管理微信号</view>
- </view>
-
- <!-- 底部按钮区域 -->
- <view class="phone-exchange-buttons">
- <view class="phone-exchange-btn phone-exchange-btn-cancel" @click="cancelWechatExchange">取消</view>
- <view class="phone-exchange-btn phone-exchange-btn-confirm" @click="confirmWechatExchange">确认</view>
- </view>
- </view>
- </u-popup>
- <!-- 交换手机号自定义弹窗 -->
- <u-popup v-model="phoneExchangeShow" mode="center" z-index="999" border-radius="24" :mask-close-able="false" width="80%">
- <view class="phone-exchange-popup">
- <!-- 顶部背景区域 -->
- <view class="phone-exchange-header">
- <image src="../../static/im/Artwork.png" class="phone-exchange-bg" mode="aspectFill"></image>
- </view>
-
- <!-- 中间内容区域 -->
- <view class="phone-exchange-content">
- <view class="phone-exchange-title">确认与对方交换电话吗?</view>
- <view class="phone-exchange-desc">交换成功后,双方可以查看彼此的电话号码<br/>您可以前往个人中心管理电话号码</view>
- </view>
-
- <!-- 底部按钮区域 -->
- <view class="phone-exchange-buttons">
- <view class="phone-exchange-btn phone-exchange-btn-cancel" @click="cancelPhoneExchange">取消</view>
- <view class="phone-exchange-btn phone-exchange-btn-confirm" @click="confirmPhoneExchange">确认</view>
- </view>
- </view>
- </u-popup>
- </view>
- </template>
- <script>
- const RECONNECT_INTERVAL = 3000; // 延迟3秒后进行重连
- const HEARTBEAT_INTERVAL = 20000; // 每20秒发送一次心跳消息
- import configdata from '../../common/config.js';
- export default {
- data() {
- return {
- msshow: false,
- params: {
- year: false,
- month: true,
- day: true,
- hour: true,
- minute: true,
- second: false
- },
- msTime: false,
- miamshi: {
- interviewDateTime: '', //面试时间
- companyId: '', //公司id
- remarks: '', //面试备注
- userId: '', //面试者id
- postPushId: '', //岗位id
- province: '', //省
- city: '', //市
- county: '', //区
- lng: '', //经度
- lat: '', //纬度
- detailedAddress: '', //详细地址
- },
- tips: {
- text: '操作',
- color: 'black',
- fontSize: 28
- },
- activelist: [],
- showActive: false,
- list: [{
- text: '查看简历',
- color: 'black',
- fontSize: 28
- }, {
- text: '查看企业',
- color: 'black',
- fontSize: 28
- }],
- show: false,
- recordLength: 0,
- initPoint: {
- identifier: 0,
- Y: 0
- },
- showChangYong: false,
- changYongList: [],
- // 工作描述展开状态
- isJobDescExpanded: false,
- //播放语音相关参数
- AUDIO: uni.createInnerAudioContext(),
- playMsgid: null,
- VoiceTimer: null,
- //文字消息
- textMsg: '',
- //消息列表
- isHistoryLoading: false,
- scrollAnimation: false,
- scrollTop: 0,
- scrollToView: '',
- msgList: [],
- msgImgList: [],
- myuid: 0,
- //录音相关参数
- // #ifndef H5
- //H5不能录音
- RECORDER: uni.getRecorderManager(),
- // #endif
- isVoice: false,
- voiceTis: '按住 说话',
- recordTis: "手指上滑 取消发送",
- recording: false,
- willStop: false,
- initPoint: {
- identifier: 0,
- Y: 0
- },
- recordTimer: null,
- recordLength: 0,
- //播放语音相关参数
- AUDIO: uni.createInnerAudioContext(),
- playMsgid: null,
- VoiceTimer: null,
- // 抽屉参数
- popupLayerClass: '',
- // more参数
- hideMore: true,
- //表情定义
- hideEmoji: true,
- emojiList: [
- [{
- "url": "100.gif",
- alt: "[微笑]"
- }, {
- "url": "101.gif",
- alt: "[伤心]"
- }, {
- "url": "102.gif",
- alt: "[美女]"
- }, {
- "url": "103.gif",
- alt: "[发呆]"
- }, {
- "url": "104.gif",
- alt: "[墨镜]"
- }, {
- "url": "105.gif",
- alt: "[哭]"
- }, {
- "url": "106.gif",
- alt: "[羞]"
- }, {
- "url": "107.gif",
- alt: "[哑]"
- }, {
- "url": "108.gif",
- alt: "[睡]"
- }, {
- "url": "109.gif",
- alt: "[哭]"
- }, {
- "url": "110.gif",
- alt: "[囧]"
- }, {
- "url": "111.gif",
- alt: "[怒]"
- }, {
- "url": "112.gif",
- alt: "[调皮]"
- }, {
- "url": "113.gif",
- alt: "[笑]"
- }, {
- "url": "114.gif",
- alt: "[惊讶]"
- }, {
- "url": "115.gif",
- alt: "[难过]"
- }, {
- "url": "116.gif",
- alt: "[酷]"
- }, {
- "url": "117.gif",
- alt: "[汗]"
- }, {
- "url": "118.gif",
- alt: "[抓狂]"
- }, {
- "url": "119.gif",
- alt: "[吐]"
- }, {
- "url": "120.gif",
- alt: "[笑]"
- }, {
- "url": "121.gif",
- alt: "[快乐]"
- }, {
- "url": "122.gif",
- alt: "[奇]"
- }, {
- "url": "123.gif",
- alt: "[傲]"
- }],
- [{
- "url": "124.gif",
- alt: "[饿]"
- }, {
- "url": "125.gif",
- alt: "[累]"
- }, {
- "url": "126.gif",
- alt: "[吓]"
- }, {
- "url": "127.gif",
- alt: "[汗]"
- }, {
- "url": "128.gif",
- alt: "[高兴]"
- }, {
- "url": "129.gif",
- alt: "[闲]"
- }, {
- "url": "130.gif",
- alt: "[努力]"
- }, {
- "url": "131.gif",
- alt: "[骂]"
- }, {
- "url": "132.gif",
- alt: "[疑问]"
- }, {
- "url": "133.gif",
- alt: "[秘密]"
- }, {
- "url": "134.gif",
- alt: "[乱]"
- }, {
- "url": "135.gif",
- alt: "[疯]"
- }, {
- "url": "136.gif",
- alt: "[哀]"
- }, {
- "url": "137.gif",
- alt: "[鬼]"
- }, {
- "url": "138.gif",
- alt: "[打击]"
- }, {
- "url": "139.gif",
- alt: "[bye]"
- }, {
- "url": "140.gif",
- alt: "[汗]"
- }, {
- "url": "141.gif",
- alt: "[抠]"
- }, {
- "url": "142.gif",
- alt: "[鼓掌]"
- }, {
- "url": "143.gif",
- alt: "[糟糕]"
- }, {
- "url": "144.gif",
- alt: "[恶搞]"
- }, {
- "url": "145.gif",
- alt: "[什么]"
- }, {
- "url": "146.gif",
- alt: "[什么]"
- }, {
- "url": "147.gif",
- alt: "[累]"
- }],
- [{
- "url": "148.gif",
- alt: "[看]"
- }, {
- "url": "149.gif",
- alt: "[难过]"
- }, {
- "url": "150.gif",
- alt: "[难过]"
- }, {
- "url": "151.gif",
- alt: "[坏]"
- }, {
- "url": "152.gif",
- alt: "[亲]"
- }, {
- "url": "153.gif",
- alt: "[吓]"
- }, {
- "url": "154.gif",
- alt: "[可怜]"
- }, {
- "url": "155.gif",
- alt: "[刀]"
- }, {
- "url": "156.gif",
- alt: "[水果]"
- }, {
- "url": "157.gif",
- alt: "[酒]"
- }, {
- "url": "158.gif",
- alt: "[篮球]"
- }, {
- "url": "159.gif",
- alt: "[乒乓]"
- }, {
- "url": "160.gif",
- alt: "[咖啡]"
- }, {
- "url": "161.gif",
- alt: "[美食]"
- }, {
- "url": "162.gif",
- alt: "[动物]"
- }, {
- "url": "163.gif",
- alt: "[鲜花]"
- }, {
- "url": "164.gif",
- alt: "[枯]"
- }, {
- "url": "165.gif",
- alt: "[唇]"
- }, {
- "url": "166.gif",
- alt: "[爱]"
- }, {
- "url": "167.gif",
- alt: "[分手]"
- }, {
- "url": "168.gif",
- alt: "[生日]"
- }, {
- "url": "169.gif",
- alt: "[电]"
- }, {
- "url": "170.gif",
- alt: "[炸弹]"
- }, {
- "url": "171.gif",
- alt: "[刀子]"
- }],
- [{
- "url": "172.gif",
- alt: "[足球]"
- }, {
- "url": "173.gif",
- alt: "[瓢虫]"
- }, {
- "url": "174.gif",
- alt: "[翔]"
- }, {
- "url": "175.gif",
- alt: "[月亮]"
- }, {
- "url": "176.gif",
- alt: "[太阳]"
- }, {
- "url": "177.gif",
- alt: "[礼物]"
- }, {
- "url": "178.gif",
- alt: "[抱抱]"
- }, {
- "url": "179.gif",
- alt: "[拇指]"
- }, {
- "url": "180.gif",
- alt: "[贬低]"
- }, {
- "url": "181.gif",
- alt: "[握手]"
- }, {
- "url": "182.gif",
- alt: "[剪刀手]"
- }, {
- "url": "183.gif",
- alt: "[抱拳]"
- }, {
- "url": "184.gif",
- alt: "[勾引]"
- }, {
- "url": "185.gif",
- alt: "[拳头]"
- }, {
- "url": "186.gif",
- alt: "[小拇指]"
- }, {
- "url": "187.gif",
- alt: "[拇指八]"
- }, {
- "url": "188.gif",
- alt: "[食指]"
- }, {
- "url": "189.gif",
- alt: "[ok]"
- }, {
- "url": "190.gif",
- alt: "[情侣]"
- }, {
- "url": "191.gif",
- alt: "[爱心]"
- }, {
- "url": "192.gif",
- alt: "[蹦哒]"
- }, {
- "url": "193.gif",
- alt: "[颤抖]"
- }, {
- "url": "194.gif",
- alt: "[怄气]"
- }, {
- "url": "195.gif",
- alt: "[跳舞]"
- }],
- [{
- "url": "196.gif",
- alt: "[发呆]"
- }, {
- "url": "197.gif",
- alt: "[背着]"
- }, {
- "url": "198.gif",
- alt: "[伸手]"
- }, {
- "url": "199.gif",
- alt: "[耍帅]"
- }, {
- "url": "200.png",
- alt: "[微笑]"
- }, {
- "url": "201.png",
- alt: "[生病]"
- }, {
- "url": "202.png",
- alt: "[哭泣]"
- }, {
- "url": "203.png",
- alt: "[吐舌]"
- }, {
- "url": "204.png",
- alt: "[迷糊]"
- }, {
- "url": "205.png",
- alt: "[瞪眼]"
- }, {
- "url": "206.png",
- alt: "[恐怖]"
- }, {
- "url": "207.png",
- alt: "[忧愁]"
- }, {
- "url": "208.png",
- alt: "[眨眉]"
- }, {
- "url": "209.png",
- alt: "[闭眼]"
- }, {
- "url": "210.png",
- alt: "[鄙视]"
- }, {
- "url": "211.png",
- alt: "[阴暗]"
- }, {
- "url": "212.png",
- alt: "[小鬼]"
- }, {
- "url": "213.png",
- alt: "[礼物]"
- }, {
- "url": "214.png",
- alt: "[拜佛]"
- }, {
- "url": "215.png",
- alt: "[力量]"
- }, {
- "url": "216.png",
- alt: "[金钱]"
- }, {
- "url": "217.png",
- alt: "[蛋糕]"
- }, {
- "url": "218.png",
- alt: "[彩带]"
- }, {
- "url": "219.png",
- alt: "[礼物]"
- }, ]
- ],
- msg: false,
- type4: [],
- listRight: {
- chat: {
- userHead: ""
- },
- content: "",
- messageType: 1,
- type: 1
- },
- content: '',
- chatId: '',
- type: 1,
- ListItem: [],
- index: 0,
- page: 1,
- size: 100,
- byUserId: 0,
- imageUrl: '/static/logo.png',
- chatConversationId: 0,
- userId: 0,
- byNickName: '',
- countDown: '',
- messages: '',
- scrollInto: '',
- tUserId: '', //对方id
- companyId: '', //对方企业的id
- activeInfo: {},
- userType: '',
- postPushId: '', //岗位id
- resumesId: '', //简历id
- postPushInfo: {}, //岗位信息
- resumesInfo: {}, //简历信息
- isSendPhone: false, //是否交换手机号
- isSendWx: false, //是否交换微信
- mianshiShow: false, //约面试弹窗
- phoneExchangeShow: false, //交换手机号弹窗
- wechatExchangeShow: false, //交换微信弹窗
- records: {}, //面试邀请信息
- recordsInter: '',
- mapsValue: '',
- showModal: true,
- arr: [],
- old: {
- scrollTop: 0 //记录旧的scrollTop值
- },
- isOpen: false, //scoket是否正在链接
- socketTimer: null, //心跳定时器
- isVip: false, //是否是会员
- isVideo: false, //是否打视频
- };
- },
- onUnload() {
- uni.closeSocket()
- uni.hideLoading()
- clearInterval(this.recordsInter)
- this.recordsInter = null
- clearInterval(this.socketTimer)
- this.socketTimer = null
- },
- onLoad(d) {
- console.log(d, 'zzzzzzzzz')
- if (d.postPushId) {
- this.postPushId = d.postPushId
- }
- if (d.resumesId) {
- this.resumesId = d.resumesId
- }
- this.userType = uni.getStorageSync('userType')
- if (this.userType == 1) {
- this.postPushId = d.postPushId
- //获取岗位信息
- this.getPostPushInfo(this.postPushId)
- this.getInterviewList()
- } else {
- this.resumesId = d.resumesId
- //获取简历信息
- this.getResumesInfo(this.resumesId)
- }
- this.userId = this.$queue.getData('userId');
- this.getMessage();
- this.connect();
- this.byNickName = d.byNickName;
- this.byUserId = d.byUserId;
- if (d.chatConversationId) {
- this.chatConversationId = d.chatConversationId;
- this.getTimeOrListItem1();
- } else {
- this.insertChat();
- }
- let image_url = this.$queue.getData('avatar');
- if (image_url && image_url !== 'undefined') {
- this.imageUrl = image_url;
- } else {
- this.imageUrl = '/static/logo.png';
- }
- // this.emojiList.forEach(d =>{
- // d.forEach(e =>{
- // console.log('/static/emoji/' + e.url)
- // });
- // });
- //语音自然播放结束
- this.AUDIO.onEnded((res) => {
- this.playMsgid = null;
- });
- // #ifndef H5
- //录音开始事件
- this.RECORDER.onStart((e) => {
- this.recordBegin(e);
- })
- //录音结束事件
- this.RECORDER.onStop((e) => {
- this.recordEnd(e);
- })
- // #endif
- },
- onShow() {
- if (this.chatConversationId) {
- this.getTimeOrListItem1();
- }
- // #ifdef MP-WEIXIN
- this.$Request.getT('/app/common/type/342').then(res => { //面试通知
- if (res.code == 0) {
- if (res.data && res.data.value) {
- this.arr.push(res.data.value)
- }
- }
- })
- if (this.showModal) {
- this.openMsg()
- }
- // #endif
- this.userType = uni.getStorageSync('userType')
- this.getChangYong();
- // if (this.isOpen) {
- // this.connect();
- // }
- if (this.userType == 1) {
- //获取用户是否有该岗位待接受的面试邀请
- this.recordsInter = setInterval(() => {
- this.getInterviewList()
- }, 5000)
- }
- this.getUserInfo()
- },
- onBackPress() {
- this.AUDIO.stop();
- this.playMsgid = null;
- },
- onHide() {
- // this.AUDIO.stop();
- // this.playMsgid = null;
- // uni.closeSocket()
- // clearInterval(this.recordsInter)
- // this.recordsInter = null
- },
- methods: {
- // 返回上一页
- goBack() {
- uni.navigateBack();
- },
- // 显示更多选项
- showMoreOptions() {
- // 可以添加更多选项的弹窗或菜单
- // console.log('显示更多选项');
- uni.navigateTo({
- url:'/pages/msg/interviewInvitation'
- })
- },
- // 切换工作描述展开状态
- toggleJobDesc() {
- this.isJobDescExpanded = !this.isJobDescExpanded;
- },
- getUserInfo() {
- this.$Request.get("/app/user/selectUserById").then(res => {
- if (res.code == 0) {
- if (this.userType == 1) { //用户
- if (res.data.isUserVip == 1) { //判断用户是否是vip
- this.isVip = true
- } else {
- this.isVip = false
- }
- } else { //企业
- if (res.data.isCompanyVip == 1) { //判断企业用户是否是vip
- this.isVip = true
- } else {
- this.isVip = false
- }
- }
- }
- })
- },
- /**
- * @param {Object} type 1:语音 2视频
- */
- sendCallVideo(type) {
- if (!this.isVip) {
- uni.showModal({
- title: '提示',
- content: type == 1 ? '语音为会员专属功能,请开通会员!' : '视频为会员专属功能,请开通会员!',
- confirmText: '开通会员',
- cancelText: '取消',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- uni.navigateTo({
- url: '/my/vip/index'
- })
- }
- }
- })
- return
- }
- if (this.isVideo) {
- return
- }
- this.isVideo = true
- let data = {
- focusedUserId: this.byUserId, //对方的userId
- messageType: type == 1 ? 21 : 20,
- userId: uni.getStorageSync('userId'), //我的userId
- userType: this.userType, //1:用户 2:企业,
- postPushId: this.postPushId,
- resumesId: this.resumesId
- }
- let that = this
- this.$Request.postJson('/app/chat/insertChatConversationByChatVideo', data).then(res => {
- if (res.code == 0) {
- //isRol 1:发起人 2:收到人
- console.log(res)
- uni.navigateTo({
- url: '/my/videoVoice/videoVoice?byUserId=' + this.byUserId +
- '&chatContentId=' + res.data.chatContentId +
- '&isRol=1&messageType=' + data.messageType + '&chatConversationId=' + res
- .data
- .chatConversationId + '&userType=' + data.userType + '&postPushId=' + data
- .postPushId + '&resumesId=' + data.resumesId,
- success() {
- uni.setStorageSync('isDial', true)
- uni.setStorageSync('videoStatus', 1)
- that.isVideo = false
- }
- })
- } else {
- that.isVideo = false
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- },
- scroll(e) {
- this.old.scrollTop = e.detail.scrollTop
- },
- // 开启订阅消息
- openMsg() {
- console.log('订阅消息')
- var that = this
- uni.getSetting({
- withSubscriptions: true, //是否获取用户订阅消息的订阅状态,默认false不返回
- success(ret) {
- console.log(ret.subscriptionsSetting, '------------------')
- // if (ret.subscriptionsSetting.itemSettings && Object.keys(ret.subscriptionsSetting.itemSettings).length == 2) {
- if (ret.subscriptionsSetting.itemSettings) {
- uni.setStorageSync('sendMsg', true)
- uni.openSetting({ // 打开设置页
- success(rea) {
- console.log(rea.authSetting)
- }
- });
- } else { // 用户没有点击“总是保持以上,不再询问”则每次都会调起订阅消息
- console.log(99999)
- uni.setStorageSync('sendMsg', false)
- uni.showModal({
- title: '提示',
- content: '为了更好的体验,请绑定消息推送',
- confirmText: '确定',
- cancelText: '取消',
- confirmColor: '#00B88F',
- success: function(res) {
- if (res.confirm) {
- console.log(that.arr)
- wx.requestSubscribeMessage({
- tmplIds: that.arr,
- success(re) {
- console.log(JSON.stringify(re),
- '++++++++++++++')
- var datas = JSON.stringify(re);
- if (datas.indexOf("accept") != -1) {
- console.log(re)
- uni.setStorageSync('sendMsg', true)
- }
- },
- fail: (res) => {
- console.log(res)
- }
- })
- uni.setStorageSync('sendMsg', true)
- console.log('确认')
- that.showModal = false
- } else if (res.cancel) {
- console.log('取消')
- uni.setStorageSync('sendMsg', false)
- that.showModal = true
- }
- }
- })
- }
- }
- })
- },
- /**
- * @param {Object} info 内容
- * @param {Object} userType 用户类型
- * @param {Object} type 参数类型
- */
- copyss(info, userType, type) {
- let content = ''
- switch (type) {
- //复制手机号
- case 'phone':
- if (userType == 1) {
- content = JSON.parse(info).companyPhone
- } else {
- content = JSON.parse(info).userPhone
- }
- break;
- //复制微信号
- case 'wx':
- if (userType == 1) {
- content = JSON.parse(info).companyWx
- } else {
- content = JSON.parse(info).userWx
- }
- break;
- default:
- break;
- }
- this.copy(content)
- },
- openMapss(latitude, longitude, name) {
- uni.openLocation({
- latitude: latitude - 0, //要去的纬度-地址
- longitude: longitude - 0, //要去的经度-地址
- name: name, //地址名称
- address: name, //详细地址名称
- success: function() {
- console.log('导航成功');
- },
- fail: function(error) {
- console.log(error)
- }
- });
- },
- goMapss() {
- let that = this
- uni.chooseLocation({
- success: function(res) {
- console.log('位置名称:' + res.name);
- console.log('详细地址:' + res.address);
- console.log('纬度:' + res.latitude);
- console.log('经度:' + res.longitude);
- let mapsValue = JSON.stringify(res);
- that.setChatSave(18, mapsValue)
- // console.log(typeof(res))
- // return
- that.showMore();
- }
- });
- },
- //接受邀请
- setJuJues(item) {
- // #ifdef MP-WEIXIN
- if (uni.getStorageSync('sendMsg')) {
- // console.log('授权+1')
- wx.requestSubscribeMessage({
- tmplIds: this.arr,
- success(re) {
- // console.log(JSON.stringify(re), 111111111111)
- var datas = JSON.stringify(re);
- if (datas.indexOf("accept") != -1) {
- // console.log(re)
- }
- },
- fail: (res) => {
- // console.log(res)
- }
- })
- }
- // #endif
- let that = this
- uni.showModal({
- title: '提示',
- content: '确定接受来自' + item.company.companyName + '的面试邀请吗?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- let data = {
- recordId: item.recordId,
- type: 1
- }
- that.$Request.getT("/app/interviewRecord/userUpdateInter", data).then(res => {
- if (res.code == 0) {
- uni.showToast({
- // title: '已接受来自' + item.company.companyName + '的面试邀请'
- title: '已接受面试邀请'
- })
- that.msshow = false
- } else {
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- }
- }
- })
- },
- //去导航
- goMapDap(info) {
- uni.openLocation({
- latitude: info.lat,
- longitude: info.lng,
- address: info.detailedAddress,
- name: info.detailedAddress,
- complete(ret) {
- }
- })
- },
- //拒绝邀请
- setJuJue(item) {
- let that = this
- uni.showModal({
- title: '提示',
- content: '确定拒绝来自' + item.company.companyName + '的面试邀请吗?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- let data = {
- recordId: item.recordId,
- type: 2
- }
- that.$Request.getT("/app/interviewRecord/userUpdateInter", data).then(res => {
- if (res.code == 0) {
- uni.showToast({
- title: '已拒绝来自' + item.company.companyName + '的面试邀请'
- })
- that.msshow = false
- } else {
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- }
- }
- })
- },
- //获取用户是否有面试记录
- getInterviewList() {
- let data = {
- userId: uni.getStorageSync('userId'),
- status: 1,
- postPushId: this.postPushId
- }
- this.$Request.getT("/app/interviewRecord/interviewList", data).then(res => {
- if (res.code == 0) {
- if ((res.data.records).length > 0) {
- this.records = res.data.records[0]
- this.msshow = true
- } else {
- this.msshow = false
- }
- } else {
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- this.msshow = false
- }
- })
- },
- submitMs() {
- if (!this.miamshi.interviewDateTime) {
- this.$refs.uToast.show({
- title: '请选择面试时间',
- type: 'default',
- position: 'bottom'
- })
- return
- }
- if (!this.miamshi.detailedAddress) {
- this.$refs.uToast.show({
- title: '请选择面试地点',
- type: 'default',
- position: 'bottom'
- })
- return
- }
- let that = this
- uni.showModal({
- title: '提示',
- content: '确定发起面试邀请吗?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- let data = {
- interviewDateTime: that.miamshi.interviewDateTime + ':00',
- companyId: uni.getStorageSync('companyId'),
- remarks: that.miamshi.remarks,
- userId: that.byUserId, //求职者id
- postPushId: that.postPushId,
- province: that.miamshi.province,
- city: that.miamshi.city,
- county: that.miamshi.county,
- lng: that.miamshi.lng,
- lat: that.miamshi.lat,
- detailedAddress: that.miamshi.detailedAddress
- }
- that.$Request.postJson("/app/interviewRecord/saveInterview", data).then(res => {
- if (res.code == 0) {
- uni.showToast({
- title: '面试邀请已发送'
- })
- that.mianshiShow = false
- } else {
- that.mianshiShow = false
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- }
- }
- })
- },
- //关闭弹窗的时候清空表单的值
- cleanMs() {
- this.miamshi = {
- interviewDateTime: '', //面试时间
- companyId: '', //公司id
- remarks: '', //面试备注
- userId: '', //面试者id
- postPushId: '', //岗位id
- province: '', //省
- city: '', //市
- county: '', //区
- lng: '', //经度
- lat: '', //纬度
- detailedAddress: '', //详细地址
- }
- },
- // 点击调起地图选择位置
- goMap() {
- let that = this
- uni.chooseLocation({
- success: function(res) {
- let arrress = res.address
- let reg = /.+?(省|市|自治区|自治州|县|区)/g;
- let adds = arrress.match(reg)
- console.log(adds)
- that.miamshi.province = adds[0]
- that.miamshi.city = adds[1]
- that.miamshi.county = adds[2]
- that.miamshi.detailedAddress = res.address + '' + res.name
- that.miamshi.lat = res.latitude
- that.miamshi.lng = res.longitude
- }
- });
- },
- //选择面试时间
- mianshiConfirm(e) {
- //获取当前时间的年份
- let date = new Date()
- let year = date.getFullYear()
- this.miamshi.interviewDateTime = year + '-' + e.month + '-' + e.day + ' ' + e.hour + ':' + e.minute
- },
- mianshiF() {
- // #ifdef MP-WEIXIN
- if (uni.getStorageSync('sendMsg')) {
- // console.log('授权+1')
- wx.requestSubscribeMessage({
- tmplIds: this.arr,
- success(re) {
- // console.log(JSON.stringify(re), 111111111111)
- var datas = JSON.stringify(re);
- if (datas.indexOf("accept") != -1) {
- // console.log(re)
- }
- },
- fail: (res) => {
- // console.log(res)
- }
- })
- }
- // #endif
- let data = {
- userId: this.byUserId,
- postPushId: this.postPushId
- }
- this.$Request.getT("/app/interviewRecord/isSendView", data).then(res => {
- if (res.code == 0) {
- if (res.data) {
- this.mianshiShow = true
- } else {
- uni.showToast({
- title: '已发送过面试邀请',
- icon: 'none'
- })
- this.mianshiShow = false
- }
- } else {
- this.mianshiShow = false
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- },
- //请求拒绝
- refuseFun(id) {
- let that = this
- uni.showModal({
- title: '提示',
- content: '确定拒绝吗?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- let data = {
- chatContentId: id
- }
- that.$Request.getT("/app/chat/refuseReqs", data).then(res => {
- if (res.code == 0) {
- uni.showToast({
- title: '已拒绝'
- })
- that.setChatSave(24)
- that.getTimeOrListItem1()
- that.getStatusInfo()
- } else {
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- }
- }
- })
- },
- // 同意简历请求并发送简历
- sendResumesSave() {
- let that = this
- let data = {
- to: this.byUserId, //接收人的userId
- postPushId: this.postPushId, //岗位id
- }
- this.$Request.postT("/app/resumes/sendResumes", data).then(res => {
- if (res.code == 0) {
- uni.showToast({
- title: '简历已发送',
- })
- that.setChatSave(24)
- that.getTimeOrListItem1()
- that.getStatusInfo()
- } else {
- uni.showToast({
- title: res.msg,
- icon: 'none'
- })
- }
- })
- },
- resumesTy() {
- let that = this
- uni.showModal({
- title: '提示',
- content: '确定发送简历给对方?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- that.sendResumesSave()
- }
- }
- })
- },
- //求简历
- giveSendResumes() {
- let that = this
- uni.showModal({
- title: '提示',
- content: '是否将简历请求发送给对方?,对方同意后将会收到对方的简历',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- that.setChatSave(9)
- }
- }
- })
- },
- //发简历
- sendResumes() {
- let that = this
- uni.showModal({
- title: '提示',
- content: '是否将简历发送给对方?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- that.sendResumesSave()
- }
- }
- })
- },
- //获取交换状态
- getStatusInfo() {
- let data = {
- chatConversationId: this.chatConversationId
- }
- this.$Request.getT("/app/chat/getConversationInfo", data).then(res => {
- if (res.code == 0) {
- if (res.data.isSendWx) {
- this.isSendWx = true
- } else {
- this.isSendWx = false
- }
- if (res.data.isSendPhone) {
- this.isSendPhone = true
- } else {
- this.isSendPhone = false
- }
- }
- })
- },
- //交换微信号弹窗
- currentWchat() {
- let that = this
- if (!uni.getStorageSync('weChatNum')) {
- uni.showModal({
- title: '提示',
- content: '请先再个人信息页面完善微信号后操作',
- confirmColor: '#00B88F',
- confirmText: '去完善',
- complete(re) {
- if (re.confirm) {
- uni.navigateTo({
- url: '/pages/my/userinfo'
- })
- }
- }
- })
- return
- }
- if (this.isSendWx == false) {
- this.wechatExchangeShow = true;
- } else {
- uni.showToast({
- title: '已交换过微信号,请查看聊天记录',
- icon: 'none'
- })
- }
- },
- //同意交换手机号/微信
- tongyi(messageType, chatContentId) {
- if (messageType == 6 && !uni.getStorageSync('weChatNum')) {
- uni.showModal({
- title: '提示',
- content: '请先再个人信息页面完善微信号后操作',
- confirmColor: '#00B88F',
- confirmText: '去完善',
- complete(re) {
- if (re.confirm) {
- uni.navigateTo({
- url: '/pages/my/userinfo'
- })
- }
- }
- })
- return
- }
- let that = this
- uni.showModal({
- title: '提示',
- content: messageType == 5 ? '同意后将交换手机号,是否同意?' : '同意后将交换微信号,是否同意?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- let data = {
- messageType: messageType,
- chatContentId: chatContentId
- }
- that.$Request.postT("/app/chat/sendPhoneOrWx", data).then(res => {
- if (res.code == 0) {
- that.setChatSave(24)
- that.getTimeOrListItem1()
- that.getStatusInfo()
- }
- })
- }
- }
- })
- },
- //交换手机号弹窗
- currentPhone() {
- if (this.isSendPhone == false) {
- this.phoneExchangeShow = true;
- } else {
- uni.showToast({
- title: '已交换过手机号,请查看聊天记录',
- icon: 'none'
- })
- }
- },
- // 取消交换手机号
- cancelPhoneExchange() {
- this.phoneExchangeShow = false;
- },
- // 确认交换手机号
- confirmPhoneExchange() {
- this.phoneExchangeShow = false;
- this.setChatSave(5);
- },
- // 取消微信交换
- cancelWechatExchange() {
- this.wechatExchangeShow = false;
- },
- // 确认微信交换
- confirmWechatExchange() {
- this.wechatExchangeShow = false;
- this.setChatSave(6);
- },
- goNav(url) {
- uni.navigateTo({
- url: url
- })
- },
- //获取简历数据
- getResumesInfo(id) {
- this.$Request.getT("/app/resumes/selectResumesByResumesId", {
- userId: uni.getStorageSync('userId'),
- resumesId: id,
- companyId: uni.getStorageSync('companyId')
- }).then(res => {
- if (res.code == 0) {
- let title = res.data.resumesName
- uni.setNavigationBarTitle({
- title: title
- })
- this.resumesInfo = res.data
- // this.postPushInfo.positionWelfare = this.postPushInfo.positionWelfare.split(',')
- }
- })
- },
- gotoInfo(id) {
- uni.navigateTo({
- url: '/pages/index/game/order?postPushId=' + id
- })
- },
- //获取岗位数据
- getPostPushInfo(id) {
- this.$Request.getT("/app/postPush/selectPostPushDetails", {
- userId: uni.getStorageSync('userId'),
- postPushId: id
- }).then(res => {
- if (res.code == 0) {
- let title = res.data.company.companyName
- uni.setNavigationBarTitle({
- title: title
- })
- this.postPushInfo = res.data
- this.postPushInfo.positionWelfare = this.postPushInfo.positionWelfare.split(',')
- }
- })
- },
- caozuoActive(item, type) {
- if (type == 1) {
- this.activelist = [{
- text: '复制',
- color: 'black',
- fontSize: 24
- }, {
- text: '撤回',
- color: 'black',
- fontSize: 24
- }]
- } else {
- this.activelist = [{
- text: '撤回',
- color: 'black',
- fontSize: 24
- }]
- }
- this.activeInfo = item
- this.showActive = true
- },
- activeclick(index) {
- if (this.activelist[index].text == '复制') { // 复制
- this.copy(this.activeInfo.content)
- } else { //撤回
- let t2 = this.activeInfo.createTimes; //格式不正确需要转换
- let aftert2 = new Date(t2.replace(/-/g, "/")); //转换
- let data = new Date(); //获取当前时间
- let times = data.getTime() - aftert2.getTime(); //时间差的毫秒数
- //计算分钟数
- let minu = parseInt(times / (1000 * 60))
- if (minu > 5) {
- uni.showToast({
- title: '超过五分钟无法撤回',
- icon: 'none'
- })
- } else {
- let that = this
- uni.showModal({
- title: '提示',
- content: '确定要撤回吗?',
- confirmColor: '#00B88F',
- complete(ret) {
- if (ret.confirm) {
- that.$Request.postT('/app/chat/deleteChatContentById', {
- chatContentId: that.activeInfo.chatContentId
- })
- .then(res => {
- if (res.code == 0) {
- uni.showToast({
- title: '已撤回',
- icon: 'none'
- })
- that.getTimeOrListItem1();
- }
- });
- }
- }
- })
- }
- }
- },
- //跳转
- click(index) {
- console.log(index)
- switch (index) {
- case 0: //简历
- uni.navigateTo({
- url: '/pages/index/game/orderDet?userId=' + this.tUserId
- })
- break;
- case 1: //企业
- uni.navigateTo({
- url: '/my/enterpriseInfo/enterpriseInfo?companyId=' + this.companyId + '&type=yes'
- })
- break;
- default:
- break;
- }
- },
- //消息公告
- getMessage() {
- this.$Request.getT('/app/common/type/311')
- .then(res => {
- if (res.code == 0) {
- this.messages = res.data.value
- }
- });
- },
- showChangYongSelect() {
- this.showMore();
- this.showChangYong = !this.showChangYong;
- },
- selConfirm(e) {
- // this.form.game = e[0].label
- // this.form.gameId = e[0].value
- this.content = e[0].label;
- this.setChatSave(1);
- },
- getChangYong() {
- this.$Request.getT('/app/message/selectMessageByUserId?page=1&limit=100&state=20')
- .then(res => {
- if (res.code == 0) {
- this.changYongList = [];
- res.data.list.forEach(d => {
- let data = {
- label: d.content,
- value: d.id
- }
- this.changYongList.push(data);
- });
- }
- });
- },
- goGuanZhu(item) {
- this.hideDrawer();
- this.tUserId = item.userId
- this.$Request.get('/app/user/selectUserByIds', {
- 'userId': item.userId
- }).then(res => {
- if (res.code == 0) {
- if (res.data.userType == 1 || res.data.userType == null) { //个人
- uni.navigateTo({
- url: '/pages/index/game/orderDet?userId=' + item.userId
- })
- } else {
- this.$Request.get('/app/resumes/selectResumesByUserIds', {
- 'userId': item.userId
- }).then(ret => {
- if (ret.code == 0) {
- if (ret.data && JSON.stringify(ret.data) != '{}') { //有简历则选择
- this.$Request.get('/app/company/selectCompanyByUserIds', {
- userId: item.userId
- }).then(ree => {
- if (ree.code == 0) {
- this.companyId = ree.data.companyId
- }
- });
- this.show = true
- } else { //没有简历直接跳转企业详情
- this.$Request.get('/app/company/selectCompanyByUserIds', {
- userId: item.userId
- }).then(ree => {
- if (ree.code == 0) {
- uni.navigateTo({
- url: '/my/enterpriseInfo/enterpriseInfo?companyId=' +
- ree.data.companyId + '&type=yes'
- })
- }
- });
- }
- }
- });
- }
- }
- });
- //去关注页面
- },
- //添加常用语/自动回复
- goAdd() {
- this.showMore();
- uni.navigateTo({
- url: '/pages/msg/addmsg'
- });
- },
- goHistory() {
- this.showMore();
- uni.navigateTo({
- url: '/pages/msg/chathistory?chatConversationId=' + this.chatConversationId
- });
- },
- insertChat() {
- let userId = this.$queue.getData('userId');
- let data = {
- focusedUserId: this.byUserId,
- userId: userId
- }
- this.$Request.postJson('/appChat/insertChatConversation', data).then(res => {
- if (res.code == 0 && res.data) {
- this.chatConversationId = res.data.chatConversationId;
- this.getTimeOrListItem1();
- }
- });
- },
- //更多功能(点击+弹出)
- showMore() {
- this.isVoice = false;
- this.hideEmoji = true;
- if (this.hideMore) {
- this.hideMore = false;
- this.openDrawer();
- } else {
- this.hideDrawer();
- }
- },
- // 打开抽屉
- openDrawer() {
- this.popupLayerClass = 'showLayer';
- },
- // 隐藏抽屉
- hideDrawer() {
- this.popupLayerClass = '';
- setTimeout(() => {
- this.hideMore = true;
- this.hideEmoji = true;
- }, 150);
- },
- // 选择表情
- chooseEmoji() {
- this.hideMore = true;
- if (this.hideEmoji) {
- this.hideEmoji = false;
- this.openDrawer();
- } else {
- this.hideDrawer();
- }
- },
- //添加表情
- addEmoji(em) {
- this.textMsg += em.alt;
- },
- //获取焦点,如果不是选表情ing,则关闭抽屉
- textareaFocus() {
- if (this.popupLayerClass == 'showLayer' && this.hideMore == false) {
- this.hideDrawer();
- }
- },
- //替换表情符号为图片
- replaceEmoji(str) {
- let replacedStr = str.replace(/\[([^(\]|\[)]*)\]/g, (item, index) => {
- console.log("item: " + item);
- for (let i = 0; i < this.emojiList.length; i++) {
- let row = this.emojiList[i];
- for (let j = 0; j < row.length; j++) {
- let EM = row[j];
- if (EM.alt == item) {
- //在线表情路径,图文混排必须使用网络路径,请上传一份表情到你的服务器后再替换此路径
- //比如你上传服务器后,你的100.gif路径为https://www.xxx.com/emoji/100.gif 则替换onlinePath填写为https://www.xxx.com/emoji/
- let onlinePath = 'https://s2.ax1x.com/2019/04/12/'
- let imgstr = '<img src="' + onlinePath + this.onlineEmoji[EM.url] + '">';
- console.log("imgstr: " + imgstr);
- return imgstr;
- }
- }
- }
- });
- return '<div style="display: flex;align-items: center;word-wrap:break-word;">' + replacedStr + '</div>';
- },
- // 播放语音
- playVoice(msg, index) {
- console.log(msg)
- this.playMsgid = index;
- this.AUDIO.src = msg;
- this.$nextTick(function() {
- this.AUDIO.play();
- });
- },
- // 录音开始
- voiceBegin(e) {
- if (e.touches.length > 1) {
- return;
- }
- this.initPoint.Y = e.touches[0].clientY;
- this.initPoint.identifier = e.touches[0].identifier;
- this.RECORDER.start({
- format: "mp3"
- }); //录音开始,
- },
- //录音开始UI效果
- recordBegin(e) {
- this.recording = true;
- this.voiceTis = '松开 结束';
- this.recordLength = 0;
- this.recordTimer = setInterval(() => {
- this.recordLength++;
- }, 1000)
- },
- // 录音被打断
- voiceCancel() {
- this.recording = false;
- this.voiceTis = '按住 说话';
- this.recordTis = '手指上滑 取消发送'
- this.willStop = true; //不发送录音
- this.RECORDER.stop(); //录音结束
- },
- // 录音中(判断是否触发上滑取消发送)
- voiceIng(e) {
- if (!this.recording) {
- return;
- }
- let touche = e.touches[0];
- //上滑一个导航栏的高度触发上滑取消发送
- if (this.initPoint.Y - touche.clientY >= uni.upx2px(100)) {
- this.willStop = true;
- this.recordTis = '松开手指 取消发送'
- } else {
- this.willStop = false;
- this.recordTis = '手指上滑 取消发送'
- }
- },
- // 结束录音
- voiceEnd(e) {
- if (!this.recording) {
- return;
- }
- this.recording = false;
- this.voiceTis = '按住 说话';
- this.recordTis = '手指上滑 取消发送'
- this.RECORDER.stop(); //录音结束
- },
- //录音结束(回调文件)
- recordEnd(e) {
- clearInterval(this.recordTimer);
- if (!this.willStop) {
- this.$queue.showLoading('发送中...')
- console.log("e: " + JSON.stringify(e));
- let msg = {
- length: 0,
- url: e.tempFilePath
- }
- let min = parseInt(this.recordLength / 60);
- let sec = this.recordLength % 60;
- min = min < 10 ? '0' + min : min;
- sec = sec < 10 ? '0' + sec : sec;
- msg.length = min + ':' + sec;
- console.log('msg.length___:' + msg.length)
- uni.uploadFile({ // 上传接口
- url: this.config("APIHOST1") + '/alioss/upload', //真实的接口地址
- filePath: e.tempFilePath,
- name: 'file',
- success: (uploadFileRes) => {
- uni.hideLoading();
- this.content = JSON.parse(uploadFileRes.data).data;
- console.log("语音:" + this.content)
- this.setChatSave(3, msg.length);
- uni.hideLoading();
- }
- });
- } else {
- console.log('取消发送录音');
- }
- this.willStop = false;
- },
- // 切换语音/文字输入
- switchVoice() {
- this.hideDrawer();
- this.isVoice = this.isVoice ? false : true;
- },
- copy(content) {
- uni.showModal({
- title: '温馨提示',
- content: '确认要复制此文字吗?',
- showCancel: true,
- cancelText: '取消',
- confirmText: '确认',
- confirmColor: '#00B88F',
- success: res => {
- if (res.confirm) {
- uni.setClipboardData({
- data: content,
- success: r => {
- this.$queue.showToast('复制成功');
- }
- });
- }
- }
- });
- },
- h5Copy(content) {
- if (!document.queryCommandSupported('copy')) {
- // 不支持
- return false
- }
- let textarea = document.createElement("textarea")
- textarea.value = content
- textarea.readOnly = "readOnly"
- document.body.appendChild(textarea)
- textarea.select() // 选择对象
- textarea.setSelectionRange(0, content.length) //核心
- let result = document.execCommand("copy") // 执行浏览器复制命令
- textarea.remove()
- return result
- },
- getDateDiff(data) {
- // 传进来的data必须是日期格式,不能是时间戳
- //var str = data;
- //将字符串转换成时间格式
- var timePublish = new Date(data);
- var timeNow = new Date();
- var minute = 1000 * 60;
- var hour = minute * 60;
- var day = hour * 24;
- var month = day * 30;
- var result = "2";
- var diffValue = timeNow - timePublish;
- var diffMonth = diffValue / month;
- var diffWeek = diffValue / (7 * day);
- var diffDay = diffValue / day;
- var diffHour = diffValue / hour;
- var diffMinute = diffValue / minute;
- if (diffMonth > 3) {
- result = timePublish.getFullYear() + "-";
- result += timePublish.getMonth() + "-";
- result += timePublish.getDate();
- } else if (diffMonth > 1) { //月
- result = data.substring(0, 10);
- } else if (diffWeek > 1) { //周
- result = data.substring(0, 10);
- } else if (diffDay > 1) { //天
- result = data.substring(0, 10);
- } else if (diffHour > 1) { //小时
- result = parseInt(diffHour) + "小时前";
- } else if (diffMinute > 1) { //分钟
- result = parseInt(diffMinute) + "分钟前";
- } else {
- result = "刚刚";
- }
- return result;
- },
- // 发送心跳包
- startHeartbeat() {
- // HeartBeat 这里是和后端约定好的值,我们发送给后端,后端再把这个值返给我们
- // 目的就是让后端知道我们一直在
- const heartbeatMsg = 'HeartBeat';
- const sendHeartbeat = () => {
- if (this.isOpen) {
- console.log('发送HeartBeat')
- uni.sendSocketMessage({
- data: heartbeatMsg,
- }).catch(error => {
- console.log('发送心跳消息失败:', error);
- //发送消息失败则进行重新链接
- this.connect()
- });
- }
- };
- this.socketTimer = setInterval(sendHeartbeat, HEARTBEAT_INTERVAL);
- },
- // 开始重连
- reconnect() {
- if (!this.isOpen) {
- clearTimeout(this.socketTimer);
- this.socketTimer = setTimeout(() => {
- console.log('开始重连...');
- this.connect();
- }, RECONNECT_INTERVAL);
- }
- },
- connect() {
- // #ifdef MP-WEIXIN
- if (uni.getStorageSync('sendMsg')) {
- // console.log('授权+1')
- wx.requestSubscribeMessage({
- tmplIds: this.arr,
- success(re) {
- // console.log(JSON.stringify(re), 111111111111)
- var datas = JSON.stringify(re);
- if (datas.indexOf("accept") != -1) {
- // console.log(re)
- }
- },
- fail: (res) => {
- // console.log(res)
- }
- })
- }
- // #endif
- let that = this
- let userId = this.$queue.getData('userId');
- uni.showLoading({
- title: '连接中...'
- })
- uni.connectSocket({
- // url: 'wss://h5.youxb.icu/wss/sqx_fast/chatSocket/' + userId,
- // url: this.config("WSHOST1") + userId,
- url: configdata.WSHOST1 + '' + userId,
- // url: 'wss://zp.xianmaxiong.com/wss/chatSocket/' + userId,
- // url: 'ws://192.168.0.128:7152/sqx_fast/chatSocket/' + userId,
- data() {
- return {
- msg: 'Hello'
- }
- },
- header: {
- 'content-type': 'application/json'
- },
- method: 'GET',
- success(res) {
- // 这里是接口调用成功的回调,不是连接成功的回调,请注意
- },
- fail(err) {
- // 这里是接口调用失败的回调,不是连接失败的回调,请注意
- }
- })
- uni.onSocketOpen((res) => {
- uni.hideLoading()
- that.isOpen = true;
- that.startHeartbeat()
- if (that.mapsValue) {
- that.setChatSave(18, that.mapsValue)
- }
- })
- uni.onSocketError((err) => {
- uni.hideLoading()
- //如果连接异常那么把状态设置为false
- that.isOpen = false;
- //并尝试进行重连
- that.reconnect();
- })
- uni.onSocketMessage((res) => {
- if (res.data == 'HeartBeat') { //如果是心跳回推则不进行处理
- return
- }
- this.getTimeOrListItem1();
- console.log('onMessage', res)
- })
- uni.onSocketClose((res) => {
- uni.hideLoading()
- that.isOpen = false;
- //链接关闭的时候也尝试进行重连
- // that.reconnect();
- })
- },
- close() {
- uni.closeSocket()
- },
- getTimeOrListItem1() {
- let userId = this.$queue.getData('userId')
- this.$Request.getT('/app/chat/selectChatContent?page=' + this.page + '&limit=' + this.size +
- '&chatConversationId=' + this.chatConversationId + '&userId=' + userId).then(
- res => {
- // this.ListItem = [];
- if (res.data) {
- var time = '';
- res.data.list.forEach(d => {
- d.createTimes = d.createTime;
- d.createTime = this.getDateDiff(d.createTime);
- if (d.createTime === time) {
- d.createTime = '';
- } else {
- time = d.createTime;
- }
- if (d.type === 4) {
- let data = d.content.split(',');
- d.content = data;
- }
- if (d.type === 3) {
- let data = d.content.split(',');
- d.content = data;
- }
- if (d.messageType === 18) {
- d.content = JSON.parse(d.content);
- d.markers = [{
- id: 1,
- latitude: d.content.latitude,
- longitude: d.content.longitude,
- width: 20,
- height: 20,
- iconPath: '../../static/images/mapMarker.png',
- callout: {
- content: d.content.name,
- color: '#000', //文字颜色
- fontSize: 10, //文本大小
- padding: 10, //附近留白
- borderRadius: 24, //边框圆角
- bgColor: '#FFFFFF', //背景颜色
- display: 'ALWAYS', //常显
- }
- }]
- }
- // this.ListItem.push(d);
- });
- this.ListItem = res.data.list
- this.ListItem.reverse();
- this.scrollTop = this.old.scrollTop
- this.$nextTick(() => {
- this.scrollTop = 99999
- })
- this.getStatusInfo()
- }
- uni.hideLoading();
- });
- },
- setChatSave(type, url) {
- //type:1文字 2图片
- if (type === 1 && this.content == '') {
- this.$queue.showToast('请输入聊天内容');
- return;
- }
- if (type != 3 && type != 2 && this.$queue.getChatSearchKeys(this.content)) {
- uni.showToast({
- title: "输入内容带有非法关键字请重新输入",
- mask: false,
- duration: 1500,
- icon: "none"
- });
- return;
- }
- // if (type === 1 && this.$queue.getChatSearchKeys(this.content) != -1) {
- // uni.showToast({
- // title: "输入内容带有非法关键字请重新输入",
- // mask: false,
- // duration: 1500,
- // icon: "none"
- // });
- // return;
- // }
- let userId = this.$queue.getData('userId');
- if (type === 4) {
- this.content = url;
- }
- if (type === 18) { //定位
- this.content = url;
- }
- let data = {};
- if (type == 3) {
- data = {
- userId: this.byUserId,
- content: this.content,
- width: url,
- messageType: type,
- chatConversationId: this.chatConversationId
- }
- } else if (type == 5) { //交换手机号
- data = {
- userId: this.byUserId,
- content: '手机号请求',
- messageType: type,
- chatConversationId: this.chatConversationId
- }
- } else if (type == 6) { //交换微信号
- data = {
- userId: this.byUserId,
- content: '微信号请求',
- messageType: type,
- chatConversationId: this.chatConversationId
- }
- } else if (type == 9) { //简历请求
- data = {
- userId: this.byUserId,
- content: '简历请求',
- messageType: type,
- chatConversationId: this.chatConversationId
- }
- } else if (type == 24) {
- data = {
- userId: this.byUserId,
- content: '刷新',
- messageType: type,
- chatConversationId: this.chatConversationId
- }
- } else {
- data = {
- userId: this.byUserId,
- content: this.content,
- messageType: type,
- chatConversationId: this.chatConversationId
- }
- }
- data = JSON.stringify(data);
- let that = this;
- uni.sendSocketMessage({
- data: data,
- success(res) {
- that.mapsValue = ''
- let image_url = that.$queue.getData('image_url');
- if (!image_url) {
- image_url = '/static/logo.png';
- }
- let datas = {
- chat: {
- userHead: image_url
- },
- content: that.content,
- type: type,
- sendType: 1
- }
- that.ListItem.push(datas);
- setTimeout(() => {
- that.getTimeOrListItem1();
- that.content = '';
- }, 50);
- console.log(that.content);
- },
- fail(err) {
- console.log(err);
- }
- })
- },
- //发送图片
- chooseImage(sourceType) {
- let that = this
- uni.chooseImage({
- count: 1,
- sourceType: ['album'],
- success: res => {
- for (let i = 0; i < res.tempFilePaths.length; i++) {
- this.$queue.showLoading("上传中...");
- uni.uploadFile({ // 上传接口
- url: this.config("APIHOST1") + '/alioss/upload', //真实的接口地址
- filePath: res.tempFilePaths[i],
- name: 'file',
- success: (uploadFileRes) => {
- let content = JSON.parse(uploadFileRes.data).data;
- // this.setChatSave(2);
- uni.hideLoading();
- let data = {
- userId: that.byUserId,
- content: content,
- messageType: 2,
- chatConversationId: that.chatConversationId
- }
- data = JSON.stringify(data);
- uni.sendSocketMessage({
- data: data,
- success(res) {
- let image_url = that.$queue.getData(
- 'image_url');
- if (!image_url) {
- image_url = '/static/logo.png';
- }
- let datas = {
- chat: {
- userHead: image_url
- },
- content: content,
- type: 2,
- sendType: 1
- }
- that.ListItem.push(datas);
- setTimeout(() => {
- that.getTimeOrListItem1();
- }, 50);
- },
- fail(err) {
- console.log(err);
- }
- })
- }
- });
- }
- }
- })
- },
- config: function(name) {
- var info = null;
- if (name) {
- var name2 = name.split("."); //字符分割
- if (name2.length > 1) {
- info = configdata[name2[0]][name2[1]] || null;
- } else {
- info = configdata[name] || null;
- }
- if (info == null) {
- let web_config = cache.get("web_config");
- if (web_config) {
- if (name2.length > 1) {
- info = web_config[name2[0]][name2[1]] || null;
- } else {
- info = web_config[name] || null;
- }
- }
- }
- }
- return info;
- },
- //查看大图
- viewImg(item) {
- let imgsArray = [];
- imgsArray[0] = item;
- uni.previewImage({
- current: 0,
- urls: imgsArray
- });
- },
- },
- };
- </script>
- <style lang="scss">
- @import "../msg/css/style.scss";
- // 展开按钮样式
- .expand-btn {
- text-align: left;
- margin-top: 20rpx;
- padding: 10rpx 0;
-
- .expand-text {
- color: #007AFF;
- font-size: 28rpx;
- }
- }
- // 时间和收藏样式
- .time-favorite {
- padding: 10rpx 0;
-
- .time-text {
- color: rgba(156, 164, 171, 1);
- font-family: DM Sans;
- font-size: 12px;
- font-weight: 400;
- line-height: 20px;
- letter-spacing: undefined;
- text-align: right;
- }
-
- .favorite-btn {
- color: rgba(156, 164, 171, 1);
- font-size: 12px;
-
- .favorite-icon {
- margin-right: 8rpx;
- font-size: 12px;
- }
-
- .favorite-text {
- font-size: 12px;
- }
- }
- }
- .avatorm {
- width: 100%;
- // height: 100rpx;
- margin-top: 20rpx;
- color: #000;
- .avatorm-box {
- width: 90%;
- height: 100%;
- .avatorm-box-item {
- margin-bottom: 10rpx;
- .avatorm-box-item-t {
- width: 30%;
- }
- .avatorm-box-item-r {
- width: 70%;
- }
- }
- }
- }
- .mssTitle {
- width: 100%;
- margin-top: 30rpx;
- text-align: center;
- font-size: 30rpx;
- color: #000;
- font-weight: bold;
- }
- .btnm {
- width: 100%;
- margin-top: 20rpx;
- height: 80rpx;
- margin-bottom: 100rpx;
- .btn-box {
- width: 686rpx;
- height: 100%;
- .btnItem {
- display: flex;
- align-items: center;
- justify-content: center;
- width: 200rpx;
- height: 100%;
- border-radius: 14rpx;
- }
- .btn-close {
- color: #00B88F;
- border: 1rpx solid #00B88F;
- }
- .btn-sub {
- color: #FFFFFF;
- background-color: #00B88F;
- }
- }
- }
- .mianshiTime {
- width: 100%;
- margin-top: 20rpx;
- .mianshiTime-box {
- padding-bottom: 20rpx;
- width: 686rpx;
- height: 100%;
- color: #000000;
- border-bottom: 1rpx solid #F2F2F7;
- .mianshiTime-box-ti {
- height: 100%;
- margin-top: 20rpx;
- }
- }
- }
- .mianshiTitle {
- width: 100%;
- margin-top: 30rpx;
- font-size: 30rpx;
- text-align: center;
- font-weight: bold;
- color: #000000;
- }
- .qyList-box-item {
- width: 100%;
- // height: 400rpx;
- padding-bottom: 40rpx;
- background-color: #ffffff;
- border-radius: 24rpx;
- margin-bottom: 20rpx;
- .qyList-box-item-box {
- width: 626rpx;
- height: 100%;
- }
- .qyList-box-item-info {
- margin-top: 40rpx;
- }
- .qyList-box-item-job {
- color: #121212;
- font-size: 28rpx;
- font-weight: 500;
- margin-top: 20rpx;
- }
- .qyList-box-item-rem {
- color: #999999;
- font-size: 26rpx;
- margin-top: 20rpx;
- }
- }
- .topSe {
- width: 100%;
- height: 100%;
- // padding-top: 80rpx;
- background-color: #FFFFFF;
- box-sizing: border-box;
- .topSe-box {
- width: 686rpx;
- height: 100%;
- .topSe-box-item {
- font-size: 24rpx;
- width: 80rpx;
- }
- }
- }
- .jobs {
- width: 100%;
- .jobs-box {
- width: 95%;
- }
- }
- .gwList-box-item {
- width: 100%;
- // height: 329rpx;
- border: 0.5px solid rgba(227, 231, 236, 1);
- background: #FDFDFD;
- border-radius: 24rpx;
- // margin-bottom: 20rpx;
- padding-bottom: 20rpx;
- }
- .gwList-box-item-box {
- width: 100%;
- height: 100%;
- padding: 0 40rpx;
- .gwList-box-item-box-title {
- margin-top: 30rpx;
- text:nth-of-type(1) {
- color: rgba(23, 23, 37, 1);
- font-family: DM Sans;
- font-size: 24px;
- font-weight: 700;
- line-height: 24px;
- letter-spacing: 0%;
- text-align: left;
- }
- text:nth-of-type(2) {
- color: rgba(1, 107, 246, 1);
- font-family: DM Sans;
- font-size: 16px;
- font-weight: 700;
- line-height: 20px;
- letter-spacing: 0.5%;
- text-align: right;
- }
- }
- .gwList-box-item-box-label {
- margin-top: 30rpx;
- }
- .gwList-box-item-box-name {
- color: rgba(156, 164, 171, 1);
- font-family: DM Sans;
- font-size: 16px;
- font-weight: 400;
- line-height: 20px;
- letter-spacing: 0.5%;
- text-align: left;
- gap: 8rpx;
- margin-top: 20rpx;
- }
- .gwList-box-item-box-line {
- width: 100%;
- border: 1rpx solid #E6E6E6;
- margin-top: 30rpx;
- margin-bottom: 20rpx;
- }
- .gwList-box-item-box-info-text {
- color: rgba(153, 153, 153, 1);
- font-family: DM Sans;
- font-size: 12px;
- font-weight: 400;
- line-height: 12px;
- letter-spacing: 0px;
- text-align: left;
- margin-bottom: 20rpx;
-
- .job-description-item {
- margin-bottom: 6rpx;
- line-height: 1.2;
-
- &:last-child {
- margin-bottom: 0;
- }
- }
- }
- .gwList-box-item-box-info {
- font-size: 26rpx;
- padding-bottom: 20rpx;
- border-bottom: 1rpx solid #E6E6E6;
- .gwList-box-item-box-info-l {
- color: #1A1A1A;
- .people {
- max-width: 110rpx;
- overflow: hidden; //超出的文本隐藏
- text-overflow: ellipsis; //溢出用省略号显示
- white-space: nowrap; // 默认不换行;
- color: rgba(156, 164, 171, 1);
- font-family: DM Sans;
- font-size: 14px;
- font-weight: 400;
- line-height: 20px;
- letter-spacing: undefined;
- text-align: left;
- }
- }
- .gwList-box-item-box-info-r {
- color: #999999;
- width: 50%;
- overflow: hidden; //超出的文本隐藏
- text-overflow: ellipsis; //溢出用省略号显示
- white-space: nowrap; // 默认不换行;
- }
- }
- }
- .xuanfu {
- width: 100%;
- display: flex;
- justify-content: center;
- align-items: center;
- color: #00B88F;
- .xuanfu-box {
- width: 95%;
- background-color: #FFFFFF;
- border-radius: 10rpx;
- padding: 20rpx 15rpx 20rpx 20rpx;
- letter-spacing: 5rpx;
- font-size: 26rpx;
- }
- }
- page {
- background: #FAFAFA;
- color: #FFFFFF;
- }
- .chat-listitem {
- display: flex;
- margin-top: 20rpx;
- padding: 10rpx;
- }
- .textColor {
- color: #FFFFFF;
- border-radius: 16px 16px 0px 16px;
- background: rgba(1, 107, 246, 1);
- }
- .chat-listitem-text {
- // color: #FFFFFF;
- margin-top: 6rpx;
- width: fit-content;
- padding: 15rpx;
- font-size: 30rpx;
- height: max-content;
- word-wrap: break-word;
- word-break: break-all;
- border-radius: 10rpx;
- }
- .chat-listitem-image-type4 {
- color: #000000;
- background: #FFFFFF;
- width: fit-content;
- font-size: 30rpx;
- height: max-content;
- word-wrap: break-word;
- word-break: break-all;
- border-top-left-radius: 20rpx;
- border-top-right-radius: 20rpx;
- }
- .chat-listitem-image {
- margin-top: 5rpx;
- width: 75rpx;
- height: 75rpx;
- border-radius: 50%;
- }
- .save {
- width: 130rpx;
- text-align: center;
- border-radius: 10rpx;
- height: 70rpx;
- background: #FFFFFF;
- margin: 5rpx 10rpx 0;
- line-height: 70rpx;
- }
- </style>
|