pages-chat-speechtotext.e847b9e7.js 3.4 KB

1
  1. import{s as e,P as a,a2 as t,a4 as s,f as l,g as o,w as n,q as u,n as c,E as r,p as i,r as d,F as p,m as v,t as m,i as h,l as f,L as y,u as _,K as g,A as w}from"./index-8ff8c1be.js";import{_ as b}from"./s-layout.ac40effb.js";import{_ as j}from"./_plugin-vue_export-helper.1b428a4d.js";import"./phone-international-input.03f84f64.js";import"./useGoods.150e1238.js";const x=""+new URL("audioPaly-372169db.png",import.meta.url).href,M=j({__name:"speechtotext",setup(j){const{safeAreaInsets:M,safeArea:D}=e.$platform.device,k=e.$platform.navbar,I=D.height-k-20-60,T=a([]),U=a(!1);let E=a(null);const A=a("");let L=null;const P=a(0);let R=null,B=[],C=a(!1);t((()=>{navigator.mediaDevices.getUserMedia({audio:!0}).then((e=>{R=new MediaRecorder(e),R.ondataavailable=e=>{B.push(e.data)},R.onstop=()=>{C.value||F(),B=[]}})).catch((e=>{console.error("Error accessing media devices.",e)}))}));const F=()=>{const e=new Blob(B,{type:"audio/mpeg"}),a=URL.createObjectURL(e),t=Math.max(Math.floor((new Date-E.value)/1e3),1);!async function(e,a,t,s){const l=new FormData;l.append("audio_file",e);try{const e=await fetch("https://letcgo.com/voice2text/",{method:"POST",body:l}),a=await e.json();a.success&&(T.value[s].transcription=a.transcription),console.log("Server response:",a)}catch(o){console.error("Error sending audio file:",o)}}(e,0,0,T.value.push({duration:t,audioUrl:a,transcription:""})-1),s((()=>{let e=document.getElementById("messages");e.scrollTop=e.scrollHeight}))},O=()=>{const e=Math.floor((new Date-E.value)/1e3);A.value=e+"s",e>=60&&Y(new Event("mouseup"))},S=e=>{U.value||"mousedown"!==e.type&&"touchstart"!==e.type||(E.value=new Date,U.value=!0,L=setInterval(O,1e3),A.value="1s",e.preventDefault(),P.value=e.touches?e.touches[0].clientY:0,B=[],C.value=!1,R.start())},Y=e=>{!U.value||"mouseup"!==e.type&&"touchend"!==e.type&&"mouseleave"!==e.type&&"touchcancel"!==e.type||(clearInterval(L),U.value=!1,A.value="",new Date-E.value>=500?R.stop():console.log("录音时间太短,不保存"))},$=()=>{U.value&&(clearInterval(L),console.log("录音取消"),C.value=!0,R.stop(),q())},q=()=>{U.value=!1,A.value=0,E.value=null,B=[]},G=e=>{const a=e.touches[0].clientY;P.value-a>280&&$()};return(e,a)=>{const t=g,s=w,j=f,M=y,D=u(_("s-layout"),b);return l(),o(D,{class:"chat-wrap",title:"语音转文字"},{default:n((()=>[c(j,{class:"chat-container"},{default:n((()=>[c(j,{class:"messages",style:r({height:I+"px"}),id:"messages"},{default:n((()=>[(l(!0),i(p,null,d(T.value,((e,a)=>(l(),o(j,{key:a,class:"message",onClick:e=>(e=>{const a=T.value[e];new Audio(a.audioUrl).play()})(a)},{default:n((()=>[c(j,{class:"bubble"},{default:n((()=>[c(t,{class:"duration"},{default:n((()=>[v(m(e.duration)+'" ',1)])),_:2},1024),c(t,{class:"ss-m-l-10"},{default:n((()=>[c(s,{src:x,class:"audioPaly"})])),_:1})])),_:2},1024),null!=e.transcription&&""!=e.transcription?(l(),o(j,{key:0,class:"text"},{default:n((()=>[v(m(e.transcription),1)])),_:2},1024)):h("",!0)])),_:2},1032,["onClick"])))),128))])),_:1},8,["style"]),c(j,{class:"input-area"},{default:n((()=>[c(M,{onMousedown:S,onMouseup:Y,onMouseleave:$,onTouchstart:S,onTouchend:Y,onTouchcancel:$,onTouchmove:G},{default:n((()=>[v(" 按住 说话 ")])),_:1}),U.value?(l(),o(j,{key:0,class:"recording-overlay"},{default:n((()=>[c(j,null,{default:n((()=>[v(m(A.value),1)])),_:1}),c(j,null,{default:n((()=>[v("上滑至此取消")])),_:1})])),_:1})):h("",!0)])),_:1})])),_:1})])),_:1})}}},[["__scopeId","data-v-d67bddcf"]]);export{M as default};