@clickcns/vmedic-react 0.0.6 → 0.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/dist/api/common/index.d.ts +1 -0
  2. package/dist/api/common/user-notifications.d.ts +10 -0
  3. package/dist/cjs/api/index.js +1 -1
  4. package/dist/cjs/api/index.js.map +1 -1
  5. package/dist/cjs/hooks.feedbacks/index.js +2 -0
  6. package/dist/cjs/hooks.feedbacks/index.js.map +1 -0
  7. package/dist/cjs/hooks.user-notifications/index.js +2 -0
  8. package/dist/cjs/hooks.user-notifications/index.js.map +1 -0
  9. package/dist/cjs/ui/index.js +1 -1
  10. package/dist/cjs/ui/index.js.map +1 -1
  11. package/dist/es/api/index.js +53 -111
  12. package/dist/es/api/index.js.map +1 -1
  13. package/dist/es/hooks.feedbacks/index.js +67 -0
  14. package/dist/es/hooks.feedbacks/index.js.map +1 -0
  15. package/dist/es/hooks.user-notifications/index.js +42 -0
  16. package/dist/es/hooks.user-notifications/index.js.map +1 -0
  17. package/dist/es/ui/index.js +1 -1
  18. package/dist/es/ui/index.js.map +1 -1
  19. package/dist/feedback-BbDeqNIh.js +69 -0
  20. package/dist/feedback-BbDeqNIh.js.map +1 -0
  21. package/dist/feedback-xoeZc8ns.cjs +2 -0
  22. package/dist/feedback-xoeZc8ns.cjs.map +1 -0
  23. package/dist/hooks/feedbacks/index.d.ts +10 -0
  24. package/dist/hooks/user-notifications/index.d.ts +7 -0
  25. package/dist/shadcn-ui/resizable.d.ts +1 -1
  26. package/dist/types/api/feedback.d.ts +6 -3
  27. package/dist/types/api/index.d.ts +1 -0
  28. package/dist/types/api/notifications.d.ts +11 -0
  29. package/dist/user-notifications-DbJeK8gS.js +10 -0
  30. package/dist/user-notifications-DbJeK8gS.js.map +1 -0
  31. package/dist/user-notifications-eaEdb3_1.cjs +2 -0
  32. package/dist/user-notifications-eaEdb3_1.cjs.map +1 -0
  33. package/package.json +16 -1
@@ -9,3 +9,4 @@ export * from './partners';
9
9
  export * from './push';
10
10
  export * from './user-settings';
11
11
  export * from './institutions';
12
+ export * from './user-notifications';
@@ -0,0 +1,10 @@
1
+ import { UserNotificationListResponse } from '../../types';
2
+ export declare const userNotificationsApi: {
3
+ getNotifications: () => Promise<UserNotificationListResponse>;
4
+ markAsRead: (request: {
5
+ targetId: string;
6
+ }) => Promise<void>;
7
+ getUnreadNotificationCount: () => Promise<{
8
+ count: number;
9
+ }>;
10
+ };
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("axios");exports.apiClient=void 0;const C=({baseURL:e,timeout:t=12e4,withCredentials:a=!0,headers:n,getAccessToken:i,getRefreshAccessToken:o,onUnauthorized:s,onRefreshTokenSuccess:d,...l})=>(exports.apiClient=y.create({baseURL:e,timeout:t,withCredentials:a,headers:n||{"Content-Type":"application/json"},...l}),exports.apiClient.interceptors.request.use(r=>{const p=i();return p&&(r.headers.Authorization=`Bearer ${p}`),r},r=>Promise.reject(r)),exports.apiClient.interceptors.response.use(r=>r,async r=>{const p=r.config;if(p.url?.includes("/auth/login"))return Promise.reject(r);if(r.response?.status===401&&!p._retry){p._retry=!0;try{const c=await o();if(!c)throw new Error("Failed to refresh access token");return p.headers.Authorization=`Bearer ${c}`,d(c),exports.apiClient(p)}catch(c){return s(),Promise.reject(c)}}return Promise.reject(r)}),exports.apiClient),w={getChatRooms:async e=>(await exports.apiClient.get(`/speech/chat/rooms/${e}`)).data,deleteChatRoom:async({roomId:e})=>(await exports.apiClient.delete(`/speech/chat/rooms/${e}`)).data,getChatMessages:async({roomId:e})=>{const t=await exports.apiClient.get(`/speech/chat/messages/${e}`);return{roomId:e,msgs:t.data}},updateChatRoomName:async({roomId:e,name:t})=>(await exports.apiClient.patch(`/speech/chat/rooms/${e}`,{name:t})).data},h={getRecords:async()=>(await exports.apiClient.get("/speech/records")).data,getRecordsWithPage:async e=>(await exports.apiClient.post("/speech/records",e)).data,deleteRecord:async({recordId:e})=>(await exports.apiClient.delete(`/speech/records/${e}`)).data,getRecordById:async({recordId:e})=>(await exports.apiClient.get(`/speech/records/${e}/details`)).data,getTodayRecord:async({chart:e})=>(await exports.apiClient.get("/speech/records/details/today",{params:{chart:e}})).data,getRecordsByChart:async({chart:e})=>(await exports.apiClient.get(`/speech/records/${e}`)).data,getRecordFromImage:async({imageUrl:e})=>(await exports.apiClient.post("/speech/records/from-image",{imageUrl:e})).data,getRecordFromAgent:async e=>(await exports.apiClient.post("/speech/records/from-agent",e)).data,getRecordsByDates:async({startDate:e,endDate:t,page:a,searchText:n,ykiho:i,username:o})=>(await exports.apiClient.get("/speech/records/by-dates",{params:{startDate:e,endDate:t,page:Number(a),...n&&{searchText:n},...i&&{ykiho:i},...o&&{username:o}}})).data,getPatients:async()=>(await exports.apiClient.get("/speech/patients")).data,getRecordData:async({recordId:e})=>(await exports.apiClient.get(`/speech/record-datas/${e}`)).data},g={getPatientByChart:async({chart:e})=>(await exports.apiClient.get(`/speech/patients/${e}`)).data,upsertPatient:async({chart:e,name:t})=>(await exports.apiClient.put("/speech/patients",{chart:e,name:t})).data},m={deleteAudioFile:async({audioFileId:e})=>(await exports.apiClient.delete(`/speech/audios/${e}`)).data},b={resummaryPart:async({recordId:e,level:t,part:a})=>(await exports.apiClient.post("/speech/record-datas/resummary/part",{recordId:e,level:t,part:a})).data},$=e=>{const t=e instanceof Blob?e:new Blob([e],{type:"audio/pcm"}),a=new FormData;return a.append("file",t,"audio.pcm"),a},u=async(e,t,a)=>{const n=$(t);return a&&n.append("language",a),(await exports.apiClient.post(e,n,{headers:{"Content-Type":"multipart/form-data"}})).data},A={transcribeV2:async({buffer:e})=>u("/speech/transcribe-v2",e),transcribeWithTranslation:async({buffer:e,language:t})=>u("/speech/transcribe-with-translation",e,t),uploadWithTranslation:async({opusBlob:e,chart:t,recordId:a,transcript:n,transcripts:i,durationSeconds:o})=>{const s=new FormData;return s.append("opusFile",new Blob([e],{type:"audio/webm"}),"audio.webm"),s.append("chart",t),s.append("transcript",n),s.append("transcripts",JSON.stringify(i)),s.append("durationSeconds",o.toString()),a&&s.append("recordId",a),(await exports.apiClient.post("/speech/upload-with-translation",s,{headers:{"Content-Type":"multipart/form-data"}})).data},upload:async({opusBlob:e,vadBuffer:t,totalBuffer:a,chart:n,recordId:i,transcript:o})=>{const s=new FormData;return s.append("opusFile",new Blob([e],{type:"audio/webm"}),"audio.webm"),s.append("totalFile",new Blob([a],{type:"audio/pcm"}),"audio.pcm"),t&&s.append("vadFile",new Blob([t],{type:"audio/pcm"}),"audio.pcm"),s.append("chart",n),s.append("transcript",o),i&&s.append("recordId",i),(await exports.apiClient.post("/speech/upload",s,{headers:{"Content-Type":"multipart/form-data"}})).data},chat:w,records:h,patients:g,audios:m,recordData:b},f={getAudioFile:async({bucket:e,keys:t})=>(await exports.apiClient.get("/audio",{params:{bucket:e,keys:t},responseType:"blob"})).data},R={register:async e=>(await exports.apiClient.post("/auth/register",e)).data,login:async e=>(await exports.apiClient.post("/auth/login",e)).data,getMe:async()=>(await exports.apiClient.get("/auth/me")).data,logout:async()=>{await exports.apiClient.post("/auth/logout")},updateMe:async e=>(await exports.apiClient.patch("/auth/me",e)).data,generateNewUserKey:async({userId:e})=>(await exports.apiClient.put(`/auth/user/generate-key/${e}`)).data,adminLogin:async e=>(await exports.apiClient.post("/auth/admin-login",e)).data,updateUser:async e=>(await exports.apiClient.put(`/auth/user/${e.id}`,e)).data,deleteUser:async e=>{await exports.apiClient.delete(`/auth/user/${e}`)},changePassword:async e=>{await exports.apiClient.patch("/auth/me/change-password",e)}},k={getMy:async()=>(await exports.apiClient.get("/capture-rects/my")).data,getCaptureRects:async()=>(await exports.apiClient.get("capture-rects")).data,getCaptureRect:async e=>(await exports.apiClient.get(`capture-rects/${e}`)).data,createCaptureRect:async e=>(await exports.apiClient.post("capture-rects",e)).data,updateCaptureRect:async({id:e,data:t})=>(await exports.apiClient.patch(`capture-rects/${e}`,t)).data,deleteCaptureRect:async e=>(await exports.apiClient.delete(`capture-rects/${e}`)).data},P={listFeedbacks:async e=>(await exports.apiClient.post("/feedbacks/page",{page:e.page??1,count:e.count??30,status:e.status})).data,getFeedback:async e=>(await exports.apiClient.get(`/feedbacks/${e}`)).data,createFeedback:async e=>(await exports.apiClient.post("/feedbacks",e)).data,updateFeedback:async(e,t)=>(await exports.apiClient.put(`/feedbacks/${e}`,t)).data,deleteFeedback:async e=>(await exports.apiClient.delete(`/feedbacks/${e}`)).data,getComments:async e=>(await exports.apiClient.get(`/feedbacks/${e}/comments`)).data,createComment:async(e,t)=>(await exports.apiClient.post(`/feedbacks/${e}/comments`,t)).data,deleteComment:async e=>(await exports.apiClient.delete(`/feedbacks/comments/${e}`)).data,updateComment:async(e,t)=>(await exports.apiClient.put(`/feedbacks/comments/${e}`,t)).data},F={diarization:async(e,t)=>(await exports.apiClient.post("/llm/diarization",e,{signal:t})).data,medicalSummary:async({request:e,signal:t})=>(await exports.apiClient.post("/llm/medical-summary",e,{signal:t})).data,mindmap:async({conversation:e})=>(await exports.apiClient.post("/llm/mindmap",{conversation:e})).data,diseaseRecommendation:async({conversation:e})=>(await exports.apiClient.post("/llm/disease-recommendation",{conversation:e})).data},S={getNotices:async e=>(await exports.apiClient.post("/notices/page",{page:e?.page??1,count:e?.count??10,searchText:e?.searchText,showPublishedOnly:e?.showPublishedOnly??!0})).data,getNotice:async e=>(await exports.apiClient.get(`/notices/${e}`)).data,createNotice:async e=>(await exports.apiClient.post("/notices",e)).data,updateNotice:async(e,t)=>(await exports.apiClient.put(`/notices/${e}`,t)).data,deleteNotice:async e=>{await exports.apiClient.delete(`/notices/${e}`)}},D={getPartners:async()=>(await exports.apiClient.get("/partners")).data,getPartner:async e=>(await exports.apiClient.get(`/partners/${e}`)).data,createPartner:async e=>(await exports.apiClient.post("/partners",e)).data,updatePartner:async(e,t)=>(await exports.apiClient.patch(`/partners/${e}`,t)).data,deletePartner:async e=>(await exports.apiClient.delete(`/partners/${e}`)).data},B={subscribe:async e=>(await exports.apiClient.post("/push/subscribe",e.toJSON())).data,unsubscribe:async e=>(await exports.apiClient.post("/push/unsubscribe",{endpoint:e})).data,getSubscriptionStatus:async()=>(await exports.apiClient.get("/push/status")).data,sendNotification:async e=>{await exports.apiClient.post("/push/send",e)}},N={getUserSettings:async()=>(await exports.apiClient.get("/user-settings")).data,updateUserSettings:async e=>(await exports.apiClient.put("/user-settings",e)).data},T={getInstitutions:async()=>(await exports.apiClient.get("institutions")).data,register:async e=>(await exports.apiClient.post("institutions",e)).data,update:async({ykiho:e,data:t})=>(await exports.apiClient.patch(`institutions/${e}`,t)).data,delete:async e=>{await exports.apiClient.delete(`institutions/${e}`)}};exports.audioApi=f;exports.authApi=R;exports.captureRectsApi=k;exports.feedbackApi=P;exports.initializeAxios=C;exports.institutionsApi=T;exports.llmApi=F;exports.noticeApi=S;exports.partnersApi=D;exports.pushApi=B;exports.speechApi=A;exports.userSettingsApi=N;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../../feedback-xoeZc8ns.cjs"),d=require("../../user-notifications-eaEdb3_1.cjs"),u={getChatRooms:async e=>(await a.apiClient.get(`/speech/chat/rooms/${e}`)).data,deleteChatRoom:async({roomId:e})=>(await a.apiClient.delete(`/speech/chat/rooms/${e}`)).data,getChatMessages:async({roomId:e})=>{const t=await a.apiClient.get(`/speech/chat/messages/${e}`);return{roomId:e,msgs:t.data}},updateChatRoomName:async({roomId:e,name:t})=>(await a.apiClient.patch(`/speech/chat/rooms/${e}`,{name:t})).data},l={getRecords:async()=>(await a.apiClient.get("/speech/records")).data,getRecordsWithPage:async e=>(await a.apiClient.post("/speech/records",e)).data,deleteRecord:async({recordId:e})=>(await a.apiClient.delete(`/speech/records/${e}`)).data,getRecordById:async({recordId:e})=>(await a.apiClient.get(`/speech/records/${e}/details`)).data,getTodayRecord:async({chart:e})=>(await a.apiClient.get("/speech/records/details/today",{params:{chart:e}})).data,getRecordsByChart:async({chart:e})=>(await a.apiClient.get(`/speech/records/${e}`)).data,getRecordFromImage:async({imageUrl:e})=>(await a.apiClient.post("/speech/records/from-image",{imageUrl:e})).data,getRecordFromAgent:async e=>(await a.apiClient.post("/speech/records/from-agent",e)).data,getRecordsByDates:async({startDate:e,endDate:t,page:s,searchText:r,ykiho:i,username:p})=>(await a.apiClient.get("/speech/records/by-dates",{params:{startDate:e,endDate:t,page:Number(s),...r&&{searchText:r},...i&&{ykiho:i},...p&&{username:p}}})).data,getPatients:async()=>(await a.apiClient.get("/speech/patients")).data,getRecordData:async({recordId:e})=>(await a.apiClient.get(`/speech/record-datas/${e}`)).data},y={getPatientByChart:async({chart:e})=>(await a.apiClient.get(`/speech/patients/${e}`)).data,upsertPatient:async({chart:e,name:t})=>(await a.apiClient.put("/speech/patients",{chart:e,name:t})).data},h={deleteAudioFile:async({audioFileId:e})=>(await a.apiClient.delete(`/speech/audios/${e}`)).data},g={resummaryPart:async({recordId:e,level:t,part:s})=>(await a.apiClient.post("/speech/record-datas/resummary/part",{recordId:e,level:t,part:s})).data},w=e=>{const t=e instanceof Blob?e:new Blob([e],{type:"audio/pcm"}),s=new FormData;return s.append("file",t,"audio.pcm"),s},o=async(e,t,s)=>{const r=w(t);return s&&r.append("language",s),(await a.apiClient.post(e,r,{headers:{"Content-Type":"multipart/form-data"}})).data},C={transcribeV2:async({buffer:e})=>o("/speech/transcribe-v2",e),transcribeWithTranslation:async({buffer:e,language:t})=>o("/speech/transcribe-with-translation",e,t),uploadWithTranslation:async({opusBlob:e,chart:t,recordId:s,transcript:r,transcripts:i,durationSeconds:p})=>{const n=new FormData;return n.append("opusFile",new Blob([e],{type:"audio/webm"}),"audio.webm"),n.append("chart",t),n.append("transcript",r),n.append("transcripts",JSON.stringify(i)),n.append("durationSeconds",p.toString()),s&&n.append("recordId",s),(await a.apiClient.post("/speech/upload-with-translation",n,{headers:{"Content-Type":"multipart/form-data"}})).data},upload:async({opusBlob:e,vadBuffer:t,totalBuffer:s,chart:r,recordId:i,transcript:p})=>{const n=new FormData;return n.append("opusFile",new Blob([e],{type:"audio/webm"}),"audio.webm"),n.append("totalFile",new Blob([s],{type:"audio/pcm"}),"audio.pcm"),t&&n.append("vadFile",new Blob([t],{type:"audio/pcm"}),"audio.pcm"),n.append("chart",r),n.append("transcript",p),i&&n.append("recordId",i),(await a.apiClient.post("/speech/upload",n,{headers:{"Content-Type":"multipart/form-data"}})).data},chat:u,records:l,patients:y,audios:h,recordData:g},m={getAudioFile:async({bucket:e,keys:t})=>(await a.apiClient.get("/audio",{params:{bucket:e,keys:t},responseType:"blob"})).data},b={register:async e=>(await a.apiClient.post("/auth/register",e)).data,login:async e=>(await a.apiClient.post("/auth/login",e)).data,getMe:async()=>(await a.apiClient.get("/auth/me")).data,logout:async()=>{await a.apiClient.post("/auth/logout")},updateMe:async e=>(await a.apiClient.patch("/auth/me",e)).data,generateNewUserKey:async({userId:e})=>(await a.apiClient.put(`/auth/user/generate-key/${e}`)).data,adminLogin:async e=>(await a.apiClient.post("/auth/admin-login",e)).data,updateUser:async e=>(await a.apiClient.put(`/auth/user/${e.id}`,e)).data,deleteUser:async e=>{await a.apiClient.delete(`/auth/user/${e}`)},changePassword:async e=>{await a.apiClient.patch("/auth/me/change-password",e)}},A={getMy:async()=>(await a.apiClient.get("/capture-rects/my")).data,getCaptureRects:async()=>(await a.apiClient.get("capture-rects")).data,getCaptureRect:async e=>(await a.apiClient.get(`capture-rects/${e}`)).data,createCaptureRect:async e=>(await a.apiClient.post("capture-rects",e)).data,updateCaptureRect:async({id:e,data:t})=>(await a.apiClient.patch(`capture-rects/${e}`,t)).data,deleteCaptureRect:async e=>(await a.apiClient.delete(`capture-rects/${e}`)).data},$={diarization:async(e,t)=>(await a.apiClient.post("/llm/diarization",e,{signal:t})).data,medicalSummary:async({request:e,signal:t})=>(await a.apiClient.post("/llm/medical-summary",e,{signal:t})).data,mindmap:async({conversation:e})=>(await a.apiClient.post("/llm/mindmap",{conversation:e})).data,diseaseRecommendation:async({conversation:e})=>(await a.apiClient.post("/llm/disease-recommendation",{conversation:e})).data},R={getNotices:async e=>(await a.apiClient.post("/notices/page",{page:e?.page??1,count:e?.count??10,searchText:e?.searchText,showPublishedOnly:e?.showPublishedOnly??!0})).data,getNotice:async e=>(await a.apiClient.get(`/notices/${e}`)).data,createNotice:async e=>(await a.apiClient.post("/notices",e)).data,updateNotice:async(e,t)=>(await a.apiClient.put(`/notices/${e}`,t)).data,deleteNotice:async e=>{await a.apiClient.delete(`/notices/${e}`)}},f={getPartners:async()=>(await a.apiClient.get("/partners")).data,getPartner:async e=>(await a.apiClient.get(`/partners/${e}`)).data,createPartner:async e=>(await a.apiClient.post("/partners",e)).data,updatePartner:async(e,t)=>(await a.apiClient.patch(`/partners/${e}`,t)).data,deletePartner:async e=>(await a.apiClient.delete(`/partners/${e}`)).data},P={subscribe:async e=>(await a.apiClient.post("/push/subscribe",e.toJSON())).data,unsubscribe:async e=>(await a.apiClient.post("/push/unsubscribe",{endpoint:e})).data,getSubscriptionStatus:async()=>(await a.apiClient.get("/push/status")).data,sendNotification:async e=>{await a.apiClient.post("/push/send",e)}},N={getUserSettings:async()=>(await a.apiClient.get("/user-settings")).data,updateUserSettings:async e=>(await a.apiClient.put("/user-settings",e)).data},S={getInstitutions:async()=>(await a.apiClient.get("institutions")).data,register:async e=>(await a.apiClient.post("institutions",e)).data,update:async({ykiho:e,data:t})=>(await a.apiClient.patch(`institutions/${e}`,t)).data,delete:async e=>{await a.apiClient.delete(`institutions/${e}`)}};Object.defineProperty(exports,"apiClient",{enumerable:!0,get:()=>a.apiClient});exports.feedbackApi=a.feedbackApi;exports.initializeAxios=a.initializeAxios;exports.userNotificationsApi=d.userNotificationsApi;exports.audioApi=m;exports.authApi=b;exports.captureRectsApi=A;exports.institutionsApi=S;exports.llmApi=$;exports.noticeApi=R;exports.partnersApi=f;exports.pushApi=P;exports.speechApi=C;exports.userSettingsApi=N;
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/api/axios/initialize-axios.ts","../../../src/api/common/speechs/speech-chat.ts","../../../src/api/common/speechs/speech-records.ts","../../../src/api/common/speechs/speech-patients.ts","../../../src/api/common/speechs/speech-audios.ts","../../../src/api/common/speechs/speech-record-datas.ts","../../../src/api/common/speechs/speech.ts","../../../src/api/common/audio.ts","../../../src/api/common/auth.ts","../../../src/api/common/capture-rects.ts","../../../src/api/common/feedback.ts","../../../src/api/common/llm.ts","../../../src/api/common/notice.ts","../../../src/api/common/partners.ts","../../../src/api/common/push.ts","../../../src/api/common/user-settings.ts","../../../src/api/common/institutions.ts"],"sourcesContent":["import axios, { type AxiosInstance, type CreateAxiosDefaults } from \"axios\";\r\n// Axios 인스턴스 생성\r\n\r\ninterface CreateAxiosArg extends CreateAxiosDefaults {\r\n baseURL: string;\r\n getAccessToken: () => string | null;\r\n getRefreshAccessToken: () => Promise<string | undefined>;\r\n onUnauthorized: () => void;\r\n onRefreshTokenSuccess: (newAccessToken: string) => void;\r\n}\r\n\r\nexport let apiClient: AxiosInstance;\r\n\r\nexport const initializeAxios = ({\r\n baseURL,\r\n timeout = 120_000,\r\n withCredentials = true,\r\n headers,\r\n getAccessToken,\r\n getRefreshAccessToken,\r\n onUnauthorized,\r\n onRefreshTokenSuccess,\r\n ...props\r\n}: CreateAxiosArg) => {\r\n apiClient = axios.create({\r\n baseURL,\r\n timeout,\r\n withCredentials,\r\n headers: headers || {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n ...props,\r\n });\r\n\r\n apiClient.interceptors.request.use(\r\n (config) => {\r\n const token = getAccessToken();\r\n if (token) {\r\n config.headers.Authorization = `Bearer ${token}`;\r\n }\r\n return config;\r\n },\r\n (error) => {\r\n return Promise.reject(error);\r\n }\r\n );\r\n\r\n // 응답 인터셉터 - Token 만료 시 자동 갱신\r\n apiClient.interceptors.response.use(\r\n (response) => {\r\n return response;\r\n },\r\n async (error) => {\r\n const originalRequest = error.config;\r\n\r\n // 로그인 요청은 인터셉터에서 처리하지 않음\r\n if (originalRequest.url?.includes(\"/auth/login\")) {\r\n return Promise.reject(error);\r\n }\r\n\r\n if (error.response?.status === 401 && !originalRequest._retry) {\r\n originalRequest._retry = true;\r\n\r\n try {\r\n // fetch 기반 refreshAccessToken 사용 (쿠키 자동 전송)\r\n const accessToken = await getRefreshAccessToken();\r\n if (!accessToken) {\r\n throw new Error(\"Failed to refresh access token\");\r\n }\r\n // 원래 요청 재시도\r\n originalRequest.headers.Authorization = `Bearer ${accessToken}`;\r\n onRefreshTokenSuccess(accessToken);\r\n return apiClient(originalRequest);\r\n } catch (refreshError) {\r\n // Refresh 실패 시 토큰만 정리하고 리다이렉트는 하지 않음\r\n onUnauthorized();\r\n return Promise.reject(refreshError);\r\n }\r\n }\r\n\r\n return Promise.reject(error);\r\n }\r\n );\r\n return apiClient;\r\n};\r\n","import type { ChatRoomsResponse, LlmMsg } from \"../../../types\";\r\nimport { apiClient } from \"../../axios\";\r\n\r\nexport const speechChat = {\r\n getChatRooms: async (recordId: string): Promise<ChatRoomsResponse[]> => {\r\n const res = await apiClient.get(`/speech/chat/rooms/${recordId}`);\r\n return res.data;\r\n },\r\n\r\n deleteChatRoom: async ({\r\n roomId,\r\n }: {\r\n roomId: string;\r\n }): Promise<ChatRoomsResponse> => {\r\n const res = await apiClient.delete(`/speech/chat/rooms/${roomId}`);\r\n return res.data;\r\n },\r\n\r\n getChatMessages: async ({\r\n roomId,\r\n }: {\r\n roomId: string;\r\n }): Promise<{ roomId: string; msgs: LlmMsg[] }> => {\r\n const res = await apiClient.get(`/speech/chat/messages/${roomId}`);\r\n return { roomId, msgs: res.data };\r\n },\r\n updateChatRoomName: async ({\r\n roomId,\r\n name,\r\n }: {\r\n roomId: string;\r\n name: string;\r\n }): Promise<ChatRoomsResponse> => {\r\n const res = await apiClient.patch(`/speech/chat/rooms/${roomId}`, {\r\n name,\r\n });\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type {\r\n GetRecordsByDatesRequest,\r\n GetRecordsByDatesResponse,\r\n Patient,\r\n RecordData,\r\n RecordsPageRequest,\r\n RecordsResponse,\r\n RecordsWithPageResponse,\r\n} from \"../../../types/api\";\r\nimport type { PatientInfoDto } from \"../../../types\";\r\n\r\nexport const speechRecords = {\r\n getRecords: async (): Promise<RecordsResponse[]> => {\r\n const res = await apiClient.get(\"/speech/records\");\r\n return res.data;\r\n },\r\n\r\n getRecordsWithPage: async (\r\n dto: RecordsPageRequest\r\n ): Promise<RecordsWithPageResponse> => {\r\n const res = await apiClient.post(\"/speech/records\", dto);\r\n return res.data;\r\n },\r\n\r\n deleteRecord: async ({\r\n recordId,\r\n }: {\r\n recordId: string;\r\n }): Promise<RecordsResponse> => {\r\n const res = await apiClient.delete(`/speech/records/${recordId}`);\r\n return res.data;\r\n },\r\n\r\n getRecordById: async ({\r\n recordId,\r\n }: {\r\n recordId: string;\r\n }): Promise<RecordsResponse> => {\r\n const res = await apiClient.get(`/speech/records/${recordId}/details`);\r\n return res.data;\r\n },\r\n\r\n getTodayRecord: async ({\r\n chart,\r\n }: {\r\n chart: string;\r\n }): Promise<Partial<RecordsResponse>> => {\r\n const res = await apiClient.get(`/speech/records/details/today`, {\r\n params: { chart },\r\n });\r\n return res.data;\r\n },\r\n\r\n getRecordsByChart: async ({\r\n chart,\r\n }: {\r\n chart: string;\r\n }): Promise<RecordsResponse[]> => {\r\n const res = await apiClient.get(`/speech/records/${chart}`);\r\n return res.data;\r\n },\r\n\r\n getRecordFromImage: async ({\r\n imageUrl,\r\n }: {\r\n imageUrl: string;\r\n }): Promise<Partial<RecordsResponse>> => {\r\n const res = await apiClient.post(`/speech/records/from-image`, {\r\n imageUrl,\r\n });\r\n return res.data;\r\n },\r\n\r\n getRecordFromAgent: async (\r\n patientInfo: PatientInfoDto\r\n ): Promise<Partial<RecordsResponse>> => {\r\n const res = await apiClient.post(`/speech/records/from-agent`, patientInfo);\r\n return res.data;\r\n },\r\n\r\n // --- admin ---\r\n getRecordsByDates: async ({\r\n startDate,\r\n endDate,\r\n page,\r\n searchText,\r\n ykiho,\r\n username,\r\n }: GetRecordsByDatesRequest): Promise<GetRecordsByDatesResponse> => {\r\n const res = await apiClient.get(\"/speech/records/by-dates\", {\r\n params: {\r\n startDate,\r\n endDate,\r\n page: Number(page),\r\n ...(searchText && { searchText }),\r\n ...(ykiho && { ykiho }),\r\n ...(username && { username }),\r\n },\r\n });\r\n return res.data;\r\n },\r\n\r\n getPatients: async (): Promise<Patient[]> => {\r\n const res = await apiClient.get(\"/speech/patients\");\r\n return res.data;\r\n },\r\n\r\n getRecordData: async ({\r\n recordId,\r\n }: {\r\n recordId: string;\r\n }): Promise<RecordData> => {\r\n const res = await apiClient.get(`/speech/record-datas/${recordId}`);\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { Patient, UpsertPatientRequest } from \"../../../types/api\";\r\n\r\nexport const speechPatients = {\r\n getPatientByChart: async ({ chart }: { chart: string }): Promise<Patient> => {\r\n const res = await apiClient.get(`/speech/patients/${chart}`);\r\n return res.data;\r\n },\r\n\r\n upsertPatient: async ({\r\n chart,\r\n name,\r\n }: UpsertPatientRequest): Promise<Patient> => {\r\n const res = await apiClient.put(`/speech/patients`, { chart, name });\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { AudioFile } from \"../../../types/api\";\r\n\r\nexport const speechAudios = {\r\n deleteAudioFile: async ({\r\n audioFileId,\r\n }: {\r\n audioFileId: string;\r\n }): Promise<AudioFile> => {\r\n const res = await apiClient.delete(`/speech/audios/${audioFileId}`);\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { MedicalSummaryResponse, ResummaryPartRequest } from \"../../../types/api\";\r\n\r\nexport const speechRecordData = {\r\n resummaryPart: async ({\r\n recordId,\r\n level,\r\n part,\r\n }: ResummaryPartRequest): Promise<MedicalSummaryResponse> => {\r\n const res = await apiClient.post(`/speech/record-datas/resummary/part`, {\r\n recordId,\r\n level,\r\n part,\r\n });\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { TranscribeV2Response, TranscribeWithTranslationResponse, UploadRequest, UploadResponse, UploadWithTranslationRequest } from \"../../../types/api\";\r\nimport { speechChat } from \"./speech-chat\";\r\nimport { speechRecords } from \"./speech-records\";\r\nimport { speechPatients } from \"./speech-patients\";\r\nimport { speechAudios } from \"./speech-audios\";\r\nimport { speechRecordData } from \"./speech-record-datas\";\r\n\r\n// Helper function to create FormData with audio file\r\nconst createAudioFormData = (buffer: ArrayBuffer | Blob): FormData => {\r\n const blob =\r\n buffer instanceof Blob ? buffer : new Blob([buffer], { type: \"audio/pcm\" });\r\n const formData = new FormData();\r\n formData.append(\"file\", blob, \"audio.pcm\");\r\n return formData;\r\n};\r\n\r\nconst transcribeWithEndpoint = async <T>(\r\n endpoint: string,\r\n buffer: ArrayBuffer | Blob,\r\n language?: string\r\n): Promise<T> => {\r\n const formData = createAudioFormData(buffer);\r\n if (language) {\r\n formData.append(\"language\", language);\r\n }\r\n const res = await apiClient.post(endpoint, formData, {\r\n headers: {\r\n \"Content-Type\": \"multipart/form-data\",\r\n },\r\n });\r\n return res.data;\r\n};\r\n\r\nexport const speechApi = {\r\n transcribeV2: async ({\r\n buffer,\r\n }: {\r\n buffer: ArrayBuffer | Blob;\r\n }): Promise<TranscribeV2Response> => {\r\n return transcribeWithEndpoint(\"/speech/transcribe-v2\", buffer);\r\n },\r\n\r\n transcribeWithTranslation: async ({\r\n buffer,\r\n language,\r\n }: {\r\n buffer: ArrayBuffer | Blob;\r\n language: string;\r\n }): Promise<TranscribeWithTranslationResponse> => {\r\n return transcribeWithEndpoint(\r\n \"/speech/transcribe-with-translation\",\r\n buffer,\r\n language\r\n );\r\n },\r\n\r\n uploadWithTranslation: async ({\r\n opusBlob,\r\n chart,\r\n recordId,\r\n transcript,\r\n transcripts,\r\n durationSeconds,\r\n }: UploadWithTranslationRequest): Promise<UploadResponse> => {\r\n const formData = new FormData();\r\n formData.append(\r\n \"opusFile\",\r\n new Blob([opusBlob], { type: \"audio/webm\" }),\r\n \"audio.webm\"\r\n );\r\n formData.append(\"chart\", chart);\r\n formData.append(\"transcript\", transcript);\r\n formData.append(\"transcripts\", JSON.stringify(transcripts));\r\n formData.append(\"durationSeconds\", durationSeconds.toString());\r\n if (recordId) formData.append(\"recordId\", recordId);\r\n\r\n const res = await apiClient.post(\r\n \"/speech/upload-with-translation\",\r\n formData,\r\n {\r\n headers: {\r\n \"Content-Type\": \"multipart/form-data\",\r\n },\r\n }\r\n );\r\n return res.data;\r\n },\r\n\r\n upload: async ({\r\n opusBlob,\r\n vadBuffer,\r\n totalBuffer,\r\n chart,\r\n recordId,\r\n transcript,\r\n }: UploadRequest): Promise<UploadResponse> => {\r\n const formData = new FormData();\r\n formData.append(\r\n \"opusFile\",\r\n new Blob([opusBlob], { type: \"audio/webm\" }),\r\n \"audio.webm\"\r\n );\r\n formData.append(\r\n \"totalFile\",\r\n new Blob([totalBuffer], { type: \"audio/pcm\" }),\r\n \"audio.pcm\"\r\n );\r\n if (vadBuffer)\r\n formData.append(\r\n \"vadFile\",\r\n new Blob([vadBuffer], { type: \"audio/pcm\" }),\r\n \"audio.pcm\"\r\n );\r\n formData.append(\"chart\", chart);\r\n formData.append(\"transcript\", transcript);\r\n if (recordId) formData.append(\"recordId\", recordId);\r\n\r\n const res = await apiClient.post(\"/speech/upload\", formData, {\r\n headers: {\r\n \"Content-Type\": \"multipart/form-data\",\r\n },\r\n });\r\n return res.data;\r\n },\r\n\r\n chat: speechChat,\r\n records: speechRecords,\r\n patients: speechPatients,\r\n audios: speechAudios,\r\n recordData: speechRecordData,\r\n};\r\n","import { apiClient } from \"../axios\";\r\n\r\nexport const audioApi = {\r\n getAudioFile: async ({ bucket, keys }: { bucket: string; keys: string }) => {\r\n const res = await apiClient.get(`/audio`, {\r\n params: { bucket, keys },\r\n responseType: \"blob\",\r\n });\r\n return res.data; // Blob 타입\r\n },\r\n};\r\n","import type {\r\n AuthResponse,\r\n LoginRequest,\r\n RegisterRequest,\r\n UserDto,\r\n} from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const authApi = {\r\n register: async (dto: RegisterRequest): Promise<UserDto> => {\r\n const response = await apiClient.post<UserDto>(\"/auth/register\", dto);\r\n return response.data;\r\n },\r\n login: async (credentials: LoginRequest): Promise<AuthResponse> => {\r\n const response = await apiClient.post<AuthResponse>(\r\n \"/auth/login\",\r\n credentials\r\n );\r\n return response.data;\r\n },\r\n getMe: async (): Promise<UserDto> => {\r\n const response = await apiClient.get<UserDto>(\"/auth/me\");\r\n return response.data;\r\n },\r\n logout: async (): Promise<void> => {\r\n await apiClient.post(\"/auth/logout\");\r\n },\r\n\r\n updateMe: async (data: Partial<UserDto>): Promise<{ user: UserDto }> => {\r\n const response = await apiClient.patch<{ user: UserDto }>(`/auth/me`, data);\r\n return response.data;\r\n },\r\n\r\n generateNewUserKey: async ({\r\n userId,\r\n }: {\r\n userId: string;\r\n }): Promise<UserDto> => {\r\n const response = await apiClient.put<UserDto>(\r\n `/auth/user/generate-key/${userId}`\r\n );\r\n return response.data;\r\n },\r\n\r\n // --- 관리자 ---\r\n adminLogin: async (credentials: LoginRequest): Promise<AuthResponse> => {\r\n const response = await apiClient.post<AuthResponse>(\r\n \"/auth/admin-login\",\r\n credentials\r\n );\r\n return response.data;\r\n },\r\n\r\n updateUser: async (data: Partial<UserDto>): Promise<{ user: UserDto }> => {\r\n const response = await apiClient.put<{ user: UserDto }>(\r\n `/auth/user/${data.id}`,\r\n data\r\n );\r\n return response.data;\r\n },\r\n\r\n deleteUser: async (userId: string): Promise<void> => {\r\n await apiClient.delete(`/auth/user/${userId}`);\r\n },\r\n\r\n changePassword: async (data: {\r\n currentPassword: string;\r\n newPassword: string;\r\n }): Promise<void> => {\r\n await apiClient.patch(\"/auth/me/change-password\", data);\r\n },\r\n};\r\n","import type {\r\n CaptureRect,\r\n CreateCaptureRectRequest,\r\n DeleteCaptureRectResponse,\r\n UpdateCaptureRectRequest,\r\n} from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const captureRectsApi = {\r\n getMy: async (): Promise<CaptureRect> => {\r\n const res = await apiClient.get(\"/capture-rects/my\");\r\n return res.data;\r\n },\r\n // 모든 캡처 영역 조회 (GET /capture-rects)\r\n getCaptureRects: async (): Promise<CaptureRect[]> => {\r\n const response = await apiClient.get<CaptureRect[]>(\"capture-rects\");\r\n return response.data;\r\n },\r\n\r\n // 특정 캡처 영역 조회 (GET /capture-rects/:id)\r\n getCaptureRect: async (id: string): Promise<CaptureRect> => {\r\n const response = await apiClient.get<CaptureRect>(`capture-rects/${id}`);\r\n return response.data;\r\n },\r\n\r\n // 캡처 영역 생성 (POST /capture-rects)\r\n createCaptureRect: async (\r\n data: CreateCaptureRectRequest\r\n ): Promise<CaptureRect> => {\r\n const response = await apiClient.post<CaptureRect>(\"capture-rects\", data);\r\n return response.data;\r\n },\r\n\r\n // 캡처 영역 수정 (PATCH /capture-rects/:id)\r\n updateCaptureRect: async ({\r\n id,\r\n data,\r\n }: {\r\n id: string;\r\n data: UpdateCaptureRectRequest;\r\n }): Promise<CaptureRect> => {\r\n const response = await apiClient.patch<CaptureRect>(\r\n `capture-rects/${id}`,\r\n data\r\n );\r\n return response.data;\r\n },\r\n\r\n // 캡처 영역 삭제 (DELETE /capture-rects/:id)\r\n deleteCaptureRect: async (id: string): Promise<DeleteCaptureRectResponse> => {\r\n const response = await apiClient.delete<DeleteCaptureRectResponse>(\r\n `capture-rects/${id}`\r\n );\r\n return response.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../api/axios\";\r\nimport type {\r\n Feedback,\r\n FeedbackListResponse,\r\n FeedbackListRequest,\r\n CreateFeedbackRequest,\r\n FeedbackComment,\r\n FeedbackCommentsResponse,\r\n CreateFeedbackCommentRequest,\r\n} from \"../../types\";\r\n\r\nexport const feedbackApi = {\r\n // 피드백 목록 조회 (페이지네이션)\r\n listFeedbacks: async (\r\n params: FeedbackListRequest\r\n ): Promise<FeedbackListResponse> => {\r\n const response = await apiClient.post<FeedbackListResponse>(\r\n \"/feedbacks/page\",\r\n {\r\n page: params.page ?? 1,\r\n count: params.count ?? 30,\r\n status: params.status,\r\n }\r\n );\r\n return response.data;\r\n },\r\n\r\n // 피드백 상세 조회\r\n getFeedback: async (id: string): Promise<Feedback> => {\r\n const response = await apiClient.get<Feedback>(`/feedbacks/${id}`);\r\n return response.data;\r\n },\r\n\r\n // 피드백 생성\r\n createFeedback: async (data: CreateFeedbackRequest): Promise<Feedback> => {\r\n const response = await apiClient.post<Feedback>(\"/feedbacks\", data);\r\n return response.data;\r\n },\r\n\r\n // 피드백 수정\r\n updateFeedback: async (\r\n id: string,\r\n data: Partial<CreateFeedbackRequest> & { status?: \"pending\" | \"resolved\" }\r\n ): Promise<Feedback> => {\r\n const response = await apiClient.put<Feedback>(`/feedbacks/${id}`, data);\r\n return response.data;\r\n },\r\n\r\n // 피드백 삭제\r\n deleteFeedback: async (id: string): Promise<{ success: boolean }> => {\r\n const response = await apiClient.delete<{ success: boolean }>(\r\n `/feedbacks/${id}`\r\n );\r\n return response.data;\r\n },\r\n\r\n // 피드백 댓글 목록 조회\r\n getComments: async (\r\n feedbackId: string\r\n ): Promise<FeedbackCommentsResponse> => {\r\n const response = await apiClient.get<FeedbackCommentsResponse>(\r\n `/feedbacks/${feedbackId}/comments`\r\n );\r\n return response.data;\r\n },\r\n\r\n // 피드백 댓글 작성\r\n createComment: async (\r\n feedbackId: string,\r\n data: CreateFeedbackCommentRequest\r\n ): Promise<FeedbackComment> => {\r\n const response = await apiClient.post<FeedbackComment>(\r\n `/feedbacks/${feedbackId}/comments`,\r\n data\r\n );\r\n return response.data;\r\n },\r\n\r\n // 피드백 댓글 삭제\r\n deleteComment: async (commentId: string): Promise<{ success: boolean }> => {\r\n const response = await apiClient.delete<{ success: boolean }>(\r\n `/feedbacks/comments/${commentId}`\r\n );\r\n return response.data;\r\n },\r\n\r\n // 피드백 댓글 수정\r\n updateComment: async (\r\n commentId: string,\r\n data: CreateFeedbackCommentRequest\r\n ): Promise<FeedbackComment> => {\r\n const response = await apiClient.put<FeedbackComment>(\r\n `/feedbacks/comments/${commentId}`,\r\n data\r\n );\r\n return response.data;\r\n },\r\n};\r\n","import type {\r\n DiarizationRequest,\r\n DiarizationResponse,\r\n DiseaseRecommendationRequestDto,\r\n DiseaseRecommendationResponseDto,\r\n MedicalSummaryRequest,\r\n MedicalSummaryResponse,\r\n MindmapResponse\r\n} from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const llmApi = {\r\n diarization: async (\r\n request: DiarizationRequest,\r\n signal?: AbortSignal\r\n ): Promise<DiarizationResponse> => {\r\n const response = await apiClient.post(\"/llm/diarization\", request, {\r\n signal,\r\n });\r\n\r\n return response.data;\r\n },\r\n\r\n medicalSummary: async ({\r\n request,\r\n signal,\r\n }: {\r\n request: MedicalSummaryRequest;\r\n signal: AbortSignal;\r\n }): Promise<MedicalSummaryResponse> => {\r\n const response = await apiClient.post(\"/llm/medical-summary\", request, {\r\n signal,\r\n });\r\n\r\n return response.data;\r\n },\r\n\r\n mindmap: async ({\r\n conversation,\r\n }: {\r\n conversation: string;\r\n }): Promise<MindmapResponse> => {\r\n const response = await apiClient.post(`/llm/mindmap`, { conversation });\r\n return response.data;\r\n },\r\n\r\n diseaseRecommendation: async ({\r\n conversation,\r\n }: DiseaseRecommendationRequestDto): Promise<DiseaseRecommendationResponseDto> => {\r\n const response = await apiClient.post(`/llm/disease-recommendation`, {\r\n conversation,\r\n });\r\n return response.data;\r\n },\r\n};\r\n","import type { CreateNoticeRequest, Notice, NoticeListRequest, NoticeListResponse, UpdateNoticeRequest } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const noticeApi = {\r\n getNotices: async (\r\n params?: NoticeListRequest\r\n ): Promise<NoticeListResponse> => {\r\n const response = await apiClient.post<NoticeListResponse>(\"/notices/page\", {\r\n page: params?.page ?? 1,\r\n count: params?.count ?? 10,\r\n searchText: params?.searchText,\r\n showPublishedOnly: params?.showPublishedOnly ?? true,\r\n });\r\n return response.data;\r\n },\r\n\r\n getNotice: async (id: string): Promise<Notice> => {\r\n const response = await apiClient.get<Notice>(`/notices/${id}`);\r\n return response.data;\r\n },\r\n\r\n // Create a new notice\r\n createNotice: async (data: CreateNoticeRequest): Promise<Notice> => {\r\n const response = await apiClient.post<Notice>(\"/notices\", data);\r\n return response.data;\r\n },\r\n\r\n // Update an existing notice\r\n updateNotice: async (\r\n id: string,\r\n data: UpdateNoticeRequest\r\n ): Promise<Notice> => {\r\n const response = await apiClient.put<Notice>(`/notices/${id}`, data);\r\n return response.data;\r\n },\r\n\r\n // Delete a notice\r\n deleteNotice: async (id: string): Promise<void> => {\r\n await apiClient.delete(`/notices/${id}`);\r\n },\r\n};\r\n","import type { PartnerDto } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\nimport type { CreatePartnerRequest, UpdatePartnerRequest } from \"../../types/api\";\r\n\r\nexport const partnersApi = {\r\n // 모든 파트너 조회\r\n getPartners: async (): Promise<PartnerDto[]> => {\r\n const response = await apiClient.get(\"/partners\");\r\n return response.data;\r\n },\r\n\r\n // 파트너 상세 조회\r\n getPartner: async (id: string): Promise<PartnerDto> => {\r\n const response = await apiClient.get(`/partners/${id}`);\r\n return response.data;\r\n },\r\n\r\n // 파트너 생성\r\n createPartner: async (request: CreatePartnerRequest): Promise<PartnerDto> => {\r\n const response = await apiClient.post(\"/partners\", request);\r\n return response.data;\r\n },\r\n\r\n // 파트너 수정\r\n updatePartner: async (\r\n id: string,\r\n request: UpdatePartnerRequest\r\n ): Promise<PartnerDto> => {\r\n const response = await apiClient.patch(`/partners/${id}`, request);\r\n return response.data;\r\n },\r\n\r\n // 파트너 삭제\r\n deletePartner: async (id: string): Promise<PartnerDto> => {\r\n const response = await apiClient.delete(`/partners/${id}`);\r\n return response.data;\r\n },\r\n};\r\n","import type { SendNotificationRequest } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const pushApi = {\r\n /**\r\n * Push 구독 정보를 서버에 저장\r\n */\r\n subscribe: async (\r\n subscription: PushSubscription\r\n ): Promise<{ success: boolean }> => {\r\n const response = await apiClient.post<{ success: boolean }>(\r\n \"/push/subscribe\",\r\n subscription.toJSON()\r\n );\r\n return response.data;\r\n },\r\n\r\n /**\r\n * Push 구독 해제\r\n */\r\n unsubscribe: async (endpoint: string): Promise<{ success: boolean }> => {\r\n const response = await apiClient.post<{ success: boolean }>(\r\n \"/push/unsubscribe\",\r\n { endpoint }\r\n );\r\n return response.data;\r\n },\r\n\r\n /**\r\n * 현재 사용자의 Push 구독 상태 확인\r\n */\r\n getSubscriptionStatus: async (): Promise<{\r\n isSubscribed: boolean;\r\n endpoint?: string;\r\n }> => {\r\n const response = await apiClient.get<{\r\n isSubscribed: boolean;\r\n endpoint?: string;\r\n }>(\"/push/status\");\r\n return response.data;\r\n },\r\n\r\n /**\r\n * Push 알림 전송\r\n * @param notification - 알림 요청 데이터\r\n */\r\n sendNotification: async (\r\n notification: SendNotificationRequest\r\n ): Promise<void> => {\r\n await apiClient.post(\"/push/send\", notification);\r\n },\r\n};\r\n","import type { UpsertUserSettingRequest, UserSetting } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const userSettingsApi = {\r\n getUserSettings: async (): Promise<UserSetting> => {\r\n const response = await apiClient.get(\"/user-settings\");\r\n return response.data;\r\n },\r\n\r\n updateUserSettings: async (\r\n settings: UpsertUserSettingRequest,\r\n ): Promise<UserSetting> => {\r\n const response = await apiClient.put(\"/user-settings\", settings);\r\n return response.data;\r\n },\r\n};\r\n","import type { Institution } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const institutionsApi = {\r\n getInstitutions: async (): Promise<Institution[]> => {\r\n const response = await apiClient.get<Institution[]>(\"institutions\");\r\n return response.data;\r\n },\r\n register: async (data: Institution): Promise<Institution> => {\r\n const response = await apiClient.post<Institution>(\"institutions\", data);\r\n return response.data;\r\n },\r\n update: async ({\r\n ykiho,\r\n data,\r\n }: {\r\n ykiho: string;\r\n data: Partial<Institution>;\r\n }): Promise<Institution> => {\r\n const response = await apiClient.patch(`institutions/${ykiho}`, data);\r\n return response.data;\r\n },\r\n delete: async (ykiho: string): Promise<void> => {\r\n await apiClient.delete(`institutions/${ykiho}`);\r\n },\r\n};\r\n"],"names":["apiClient","initializeAxios","baseURL","timeout","withCredentials","headers","getAccessToken","getRefreshAccessToken","onUnauthorized","onRefreshTokenSuccess","props","axios","create","interceptors","request","use","config","token","Authorization","error","Promise","reject","response","originalRequest","url","includes","status","_retry","accessToken","Error","refreshError","speechChat","getChatRooms","recordId","get","data","deleteChatRoom","roomId","delete","getChatMessages","res","msgs","updateChatRoomName","name","patch","speechRecords","getRecords","getRecordsWithPage","dto","post","deleteRecord","getRecordById","getTodayRecord","chart","params","getRecordsByChart","getRecordFromImage","imageUrl","getRecordFromAgent","patientInfo","getRecordsByDates","startDate","endDate","page","searchText","ykiho","username","Number","getPatients","getRecordData","speechPatients","getPatientByChart","upsertPatient","put","speechAudios","deleteAudioFile","audioFileId","speechRecordData","resummaryPart","level","part","createAudioFormData","buffer","blob","Blob","type","formData","FormData","append","transcribeWithEndpoint","endpoint","language","speechApi","transcribeV2","transcribeWithTranslation","uploadWithTranslation","opusBlob","transcript","transcripts","durationSeconds","JSON","stringify","toString","upload","vadBuffer","totalBuffer","chat","records","patients","audios","recordData","audioApi","getAudioFile","bucket","keys","responseType","authApi","register","login","credentials","getMe","logout","updateMe","generateNewUserKey","userId","adminLogin","updateUser","id","deleteUser","changePassword","captureRectsApi","getMy","getCaptureRects","getCaptureRect","createCaptureRect","updateCaptureRect","deleteCaptureRect","feedbackApi","listFeedbacks","count","getFeedback","createFeedback","updateFeedback","deleteFeedback","getComments","feedbackId","createComment","deleteComment","commentId","updateComment","llmApi","diarization","signal","medicalSummary","mindmap","conversation","diseaseRecommendation","noticeApi","getNotices","showPublishedOnly","getNotice","createNotice","updateNotice","deleteNotice","partnersApi","getPartners","getPartner","createPartner","updatePartner","deletePartner","pushApi","subscribe","subscription","toJSON","unsubscribe","getSubscriptionStatus","sendNotification","notification","userSettingsApi","getUserSettings","updateUserSettings","settings","institutionsApi","getInstitutions","update"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/api/common/speechs/speech-chat.ts","../../../src/api/common/speechs/speech-records.ts","../../../src/api/common/speechs/speech-patients.ts","../../../src/api/common/speechs/speech-audios.ts","../../../src/api/common/speechs/speech-record-datas.ts","../../../src/api/common/speechs/speech.ts","../../../src/api/common/audio.ts","../../../src/api/common/auth.ts","../../../src/api/common/capture-rects.ts","../../../src/api/common/llm.ts","../../../src/api/common/notice.ts","../../../src/api/common/partners.ts","../../../src/api/common/push.ts","../../../src/api/common/user-settings.ts","../../../src/api/common/institutions.ts"],"sourcesContent":["import type { ChatRoomsResponse, LlmMsg } from \"../../../types\";\r\nimport { apiClient } from \"../../axios\";\r\n\r\nexport const speechChat = {\r\n getChatRooms: async (recordId: string): Promise<ChatRoomsResponse[]> => {\r\n const res = await apiClient.get(`/speech/chat/rooms/${recordId}`);\r\n return res.data;\r\n },\r\n\r\n deleteChatRoom: async ({\r\n roomId,\r\n }: {\r\n roomId: string;\r\n }): Promise<ChatRoomsResponse> => {\r\n const res = await apiClient.delete(`/speech/chat/rooms/${roomId}`);\r\n return res.data;\r\n },\r\n\r\n getChatMessages: async ({\r\n roomId,\r\n }: {\r\n roomId: string;\r\n }): Promise<{ roomId: string; msgs: LlmMsg[] }> => {\r\n const res = await apiClient.get(`/speech/chat/messages/${roomId}`);\r\n return { roomId, msgs: res.data };\r\n },\r\n updateChatRoomName: async ({\r\n roomId,\r\n name,\r\n }: {\r\n roomId: string;\r\n name: string;\r\n }): Promise<ChatRoomsResponse> => {\r\n const res = await apiClient.patch(`/speech/chat/rooms/${roomId}`, {\r\n name,\r\n });\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type {\r\n GetRecordsByDatesRequest,\r\n GetRecordsByDatesResponse,\r\n Patient,\r\n RecordData,\r\n RecordsPageRequest,\r\n RecordsResponse,\r\n RecordsWithPageResponse,\r\n} from \"../../../types/api\";\r\nimport type { PatientInfoDto } from \"../../../types\";\r\n\r\nexport const speechRecords = {\r\n getRecords: async (): Promise<RecordsResponse[]> => {\r\n const res = await apiClient.get(\"/speech/records\");\r\n return res.data;\r\n },\r\n\r\n getRecordsWithPage: async (\r\n dto: RecordsPageRequest\r\n ): Promise<RecordsWithPageResponse> => {\r\n const res = await apiClient.post(\"/speech/records\", dto);\r\n return res.data;\r\n },\r\n\r\n deleteRecord: async ({\r\n recordId,\r\n }: {\r\n recordId: string;\r\n }): Promise<RecordsResponse> => {\r\n const res = await apiClient.delete(`/speech/records/${recordId}`);\r\n return res.data;\r\n },\r\n\r\n getRecordById: async ({\r\n recordId,\r\n }: {\r\n recordId: string;\r\n }): Promise<RecordsResponse> => {\r\n const res = await apiClient.get(`/speech/records/${recordId}/details`);\r\n return res.data;\r\n },\r\n\r\n getTodayRecord: async ({\r\n chart,\r\n }: {\r\n chart: string;\r\n }): Promise<Partial<RecordsResponse>> => {\r\n const res = await apiClient.get(`/speech/records/details/today`, {\r\n params: { chart },\r\n });\r\n return res.data;\r\n },\r\n\r\n getRecordsByChart: async ({\r\n chart,\r\n }: {\r\n chart: string;\r\n }): Promise<RecordsResponse[]> => {\r\n const res = await apiClient.get(`/speech/records/${chart}`);\r\n return res.data;\r\n },\r\n\r\n getRecordFromImage: async ({\r\n imageUrl,\r\n }: {\r\n imageUrl: string;\r\n }): Promise<Partial<RecordsResponse>> => {\r\n const res = await apiClient.post(`/speech/records/from-image`, {\r\n imageUrl,\r\n });\r\n return res.data;\r\n },\r\n\r\n getRecordFromAgent: async (\r\n patientInfo: PatientInfoDto\r\n ): Promise<Partial<RecordsResponse>> => {\r\n const res = await apiClient.post(`/speech/records/from-agent`, patientInfo);\r\n return res.data;\r\n },\r\n\r\n // --- admin ---\r\n getRecordsByDates: async ({\r\n startDate,\r\n endDate,\r\n page,\r\n searchText,\r\n ykiho,\r\n username,\r\n }: GetRecordsByDatesRequest): Promise<GetRecordsByDatesResponse> => {\r\n const res = await apiClient.get(\"/speech/records/by-dates\", {\r\n params: {\r\n startDate,\r\n endDate,\r\n page: Number(page),\r\n ...(searchText && { searchText }),\r\n ...(ykiho && { ykiho }),\r\n ...(username && { username }),\r\n },\r\n });\r\n return res.data;\r\n },\r\n\r\n getPatients: async (): Promise<Patient[]> => {\r\n const res = await apiClient.get(\"/speech/patients\");\r\n return res.data;\r\n },\r\n\r\n getRecordData: async ({\r\n recordId,\r\n }: {\r\n recordId: string;\r\n }): Promise<RecordData> => {\r\n const res = await apiClient.get(`/speech/record-datas/${recordId}`);\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { Patient, UpsertPatientRequest } from \"../../../types/api\";\r\n\r\nexport const speechPatients = {\r\n getPatientByChart: async ({ chart }: { chart: string }): Promise<Patient> => {\r\n const res = await apiClient.get(`/speech/patients/${chart}`);\r\n return res.data;\r\n },\r\n\r\n upsertPatient: async ({\r\n chart,\r\n name,\r\n }: UpsertPatientRequest): Promise<Patient> => {\r\n const res = await apiClient.put(`/speech/patients`, { chart, name });\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { AudioFile } from \"../../../types/api\";\r\n\r\nexport const speechAudios = {\r\n deleteAudioFile: async ({\r\n audioFileId,\r\n }: {\r\n audioFileId: string;\r\n }): Promise<AudioFile> => {\r\n const res = await apiClient.delete(`/speech/audios/${audioFileId}`);\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { MedicalSummaryResponse, ResummaryPartRequest } from \"../../../types/api\";\r\n\r\nexport const speechRecordData = {\r\n resummaryPart: async ({\r\n recordId,\r\n level,\r\n part,\r\n }: ResummaryPartRequest): Promise<MedicalSummaryResponse> => {\r\n const res = await apiClient.post(`/speech/record-datas/resummary/part`, {\r\n recordId,\r\n level,\r\n part,\r\n });\r\n return res.data;\r\n },\r\n};\r\n","import { apiClient } from \"../../axios\";\r\nimport type { TranscribeV2Response, TranscribeWithTranslationResponse, UploadRequest, UploadResponse, UploadWithTranslationRequest } from \"../../../types/api\";\r\nimport { speechChat } from \"./speech-chat\";\r\nimport { speechRecords } from \"./speech-records\";\r\nimport { speechPatients } from \"./speech-patients\";\r\nimport { speechAudios } from \"./speech-audios\";\r\nimport { speechRecordData } from \"./speech-record-datas\";\r\n\r\n// Helper function to create FormData with audio file\r\nconst createAudioFormData = (buffer: ArrayBuffer | Blob): FormData => {\r\n const blob =\r\n buffer instanceof Blob ? buffer : new Blob([buffer], { type: \"audio/pcm\" });\r\n const formData = new FormData();\r\n formData.append(\"file\", blob, \"audio.pcm\");\r\n return formData;\r\n};\r\n\r\nconst transcribeWithEndpoint = async <T>(\r\n endpoint: string,\r\n buffer: ArrayBuffer | Blob,\r\n language?: string\r\n): Promise<T> => {\r\n const formData = createAudioFormData(buffer);\r\n if (language) {\r\n formData.append(\"language\", language);\r\n }\r\n const res = await apiClient.post(endpoint, formData, {\r\n headers: {\r\n \"Content-Type\": \"multipart/form-data\",\r\n },\r\n });\r\n return res.data;\r\n};\r\n\r\nexport const speechApi = {\r\n transcribeV2: async ({\r\n buffer,\r\n }: {\r\n buffer: ArrayBuffer | Blob;\r\n }): Promise<TranscribeV2Response> => {\r\n return transcribeWithEndpoint(\"/speech/transcribe-v2\", buffer);\r\n },\r\n\r\n transcribeWithTranslation: async ({\r\n buffer,\r\n language,\r\n }: {\r\n buffer: ArrayBuffer | Blob;\r\n language: string;\r\n }): Promise<TranscribeWithTranslationResponse> => {\r\n return transcribeWithEndpoint(\r\n \"/speech/transcribe-with-translation\",\r\n buffer,\r\n language\r\n );\r\n },\r\n\r\n uploadWithTranslation: async ({\r\n opusBlob,\r\n chart,\r\n recordId,\r\n transcript,\r\n transcripts,\r\n durationSeconds,\r\n }: UploadWithTranslationRequest): Promise<UploadResponse> => {\r\n const formData = new FormData();\r\n formData.append(\r\n \"opusFile\",\r\n new Blob([opusBlob], { type: \"audio/webm\" }),\r\n \"audio.webm\"\r\n );\r\n formData.append(\"chart\", chart);\r\n formData.append(\"transcript\", transcript);\r\n formData.append(\"transcripts\", JSON.stringify(transcripts));\r\n formData.append(\"durationSeconds\", durationSeconds.toString());\r\n if (recordId) formData.append(\"recordId\", recordId);\r\n\r\n const res = await apiClient.post(\r\n \"/speech/upload-with-translation\",\r\n formData,\r\n {\r\n headers: {\r\n \"Content-Type\": \"multipart/form-data\",\r\n },\r\n }\r\n );\r\n return res.data;\r\n },\r\n\r\n upload: async ({\r\n opusBlob,\r\n vadBuffer,\r\n totalBuffer,\r\n chart,\r\n recordId,\r\n transcript,\r\n }: UploadRequest): Promise<UploadResponse> => {\r\n const formData = new FormData();\r\n formData.append(\r\n \"opusFile\",\r\n new Blob([opusBlob], { type: \"audio/webm\" }),\r\n \"audio.webm\"\r\n );\r\n formData.append(\r\n \"totalFile\",\r\n new Blob([totalBuffer], { type: \"audio/pcm\" }),\r\n \"audio.pcm\"\r\n );\r\n if (vadBuffer)\r\n formData.append(\r\n \"vadFile\",\r\n new Blob([vadBuffer], { type: \"audio/pcm\" }),\r\n \"audio.pcm\"\r\n );\r\n formData.append(\"chart\", chart);\r\n formData.append(\"transcript\", transcript);\r\n if (recordId) formData.append(\"recordId\", recordId);\r\n\r\n const res = await apiClient.post(\"/speech/upload\", formData, {\r\n headers: {\r\n \"Content-Type\": \"multipart/form-data\",\r\n },\r\n });\r\n return res.data;\r\n },\r\n\r\n chat: speechChat,\r\n records: speechRecords,\r\n patients: speechPatients,\r\n audios: speechAudios,\r\n recordData: speechRecordData,\r\n};\r\n","import { apiClient } from \"../axios\";\r\n\r\nexport const audioApi = {\r\n getAudioFile: async ({ bucket, keys }: { bucket: string; keys: string }) => {\r\n const res = await apiClient.get(`/audio`, {\r\n params: { bucket, keys },\r\n responseType: \"blob\",\r\n });\r\n return res.data; // Blob 타입\r\n },\r\n};\r\n","import type {\r\n AuthResponse,\r\n LoginRequest,\r\n RegisterRequest,\r\n UserDto,\r\n} from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const authApi = {\r\n register: async (dto: RegisterRequest): Promise<UserDto> => {\r\n const response = await apiClient.post<UserDto>(\"/auth/register\", dto);\r\n return response.data;\r\n },\r\n login: async (credentials: LoginRequest): Promise<AuthResponse> => {\r\n const response = await apiClient.post<AuthResponse>(\r\n \"/auth/login\",\r\n credentials\r\n );\r\n return response.data;\r\n },\r\n getMe: async (): Promise<UserDto> => {\r\n const response = await apiClient.get<UserDto>(\"/auth/me\");\r\n return response.data;\r\n },\r\n logout: async (): Promise<void> => {\r\n await apiClient.post(\"/auth/logout\");\r\n },\r\n\r\n updateMe: async (data: Partial<UserDto>): Promise<{ user: UserDto }> => {\r\n const response = await apiClient.patch<{ user: UserDto }>(`/auth/me`, data);\r\n return response.data;\r\n },\r\n\r\n generateNewUserKey: async ({\r\n userId,\r\n }: {\r\n userId: string;\r\n }): Promise<UserDto> => {\r\n const response = await apiClient.put<UserDto>(\r\n `/auth/user/generate-key/${userId}`\r\n );\r\n return response.data;\r\n },\r\n\r\n // --- 관리자 ---\r\n adminLogin: async (credentials: LoginRequest): Promise<AuthResponse> => {\r\n const response = await apiClient.post<AuthResponse>(\r\n \"/auth/admin-login\",\r\n credentials\r\n );\r\n return response.data;\r\n },\r\n\r\n updateUser: async (data: Partial<UserDto>): Promise<{ user: UserDto }> => {\r\n const response = await apiClient.put<{ user: UserDto }>(\r\n `/auth/user/${data.id}`,\r\n data\r\n );\r\n return response.data;\r\n },\r\n\r\n deleteUser: async (userId: string): Promise<void> => {\r\n await apiClient.delete(`/auth/user/${userId}`);\r\n },\r\n\r\n changePassword: async (data: {\r\n currentPassword: string;\r\n newPassword: string;\r\n }): Promise<void> => {\r\n await apiClient.patch(\"/auth/me/change-password\", data);\r\n },\r\n};\r\n","import type {\r\n CaptureRect,\r\n CreateCaptureRectRequest,\r\n DeleteCaptureRectResponse,\r\n UpdateCaptureRectRequest,\r\n} from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const captureRectsApi = {\r\n getMy: async (): Promise<CaptureRect> => {\r\n const res = await apiClient.get(\"/capture-rects/my\");\r\n return res.data;\r\n },\r\n // 모든 캡처 영역 조회 (GET /capture-rects)\r\n getCaptureRects: async (): Promise<CaptureRect[]> => {\r\n const response = await apiClient.get<CaptureRect[]>(\"capture-rects\");\r\n return response.data;\r\n },\r\n\r\n // 특정 캡처 영역 조회 (GET /capture-rects/:id)\r\n getCaptureRect: async (id: string): Promise<CaptureRect> => {\r\n const response = await apiClient.get<CaptureRect>(`capture-rects/${id}`);\r\n return response.data;\r\n },\r\n\r\n // 캡처 영역 생성 (POST /capture-rects)\r\n createCaptureRect: async (\r\n data: CreateCaptureRectRequest\r\n ): Promise<CaptureRect> => {\r\n const response = await apiClient.post<CaptureRect>(\"capture-rects\", data);\r\n return response.data;\r\n },\r\n\r\n // 캡처 영역 수정 (PATCH /capture-rects/:id)\r\n updateCaptureRect: async ({\r\n id,\r\n data,\r\n }: {\r\n id: string;\r\n data: UpdateCaptureRectRequest;\r\n }): Promise<CaptureRect> => {\r\n const response = await apiClient.patch<CaptureRect>(\r\n `capture-rects/${id}`,\r\n data\r\n );\r\n return response.data;\r\n },\r\n\r\n // 캡처 영역 삭제 (DELETE /capture-rects/:id)\r\n deleteCaptureRect: async (id: string): Promise<DeleteCaptureRectResponse> => {\r\n const response = await apiClient.delete<DeleteCaptureRectResponse>(\r\n `capture-rects/${id}`\r\n );\r\n return response.data;\r\n },\r\n};\r\n","import type {\r\n DiarizationRequest,\r\n DiarizationResponse,\r\n DiseaseRecommendationRequestDto,\r\n DiseaseRecommendationResponseDto,\r\n MedicalSummaryRequest,\r\n MedicalSummaryResponse,\r\n MindmapResponse\r\n} from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const llmApi = {\r\n diarization: async (\r\n request: DiarizationRequest,\r\n signal?: AbortSignal\r\n ): Promise<DiarizationResponse> => {\r\n const response = await apiClient.post(\"/llm/diarization\", request, {\r\n signal,\r\n });\r\n\r\n return response.data;\r\n },\r\n\r\n medicalSummary: async ({\r\n request,\r\n signal,\r\n }: {\r\n request: MedicalSummaryRequest;\r\n signal: AbortSignal;\r\n }): Promise<MedicalSummaryResponse> => {\r\n const response = await apiClient.post(\"/llm/medical-summary\", request, {\r\n signal,\r\n });\r\n\r\n return response.data;\r\n },\r\n\r\n mindmap: async ({\r\n conversation,\r\n }: {\r\n conversation: string;\r\n }): Promise<MindmapResponse> => {\r\n const response = await apiClient.post(`/llm/mindmap`, { conversation });\r\n return response.data;\r\n },\r\n\r\n diseaseRecommendation: async ({\r\n conversation,\r\n }: DiseaseRecommendationRequestDto): Promise<DiseaseRecommendationResponseDto> => {\r\n const response = await apiClient.post(`/llm/disease-recommendation`, {\r\n conversation,\r\n });\r\n return response.data;\r\n },\r\n};\r\n","import type { CreateNoticeRequest, Notice, NoticeListRequest, NoticeListResponse, UpdateNoticeRequest } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const noticeApi = {\r\n getNotices: async (\r\n params?: NoticeListRequest\r\n ): Promise<NoticeListResponse> => {\r\n const response = await apiClient.post<NoticeListResponse>(\"/notices/page\", {\r\n page: params?.page ?? 1,\r\n count: params?.count ?? 10,\r\n searchText: params?.searchText,\r\n showPublishedOnly: params?.showPublishedOnly ?? true,\r\n });\r\n return response.data;\r\n },\r\n\r\n getNotice: async (id: string): Promise<Notice> => {\r\n const response = await apiClient.get<Notice>(`/notices/${id}`);\r\n return response.data;\r\n },\r\n\r\n // Create a new notice\r\n createNotice: async (data: CreateNoticeRequest): Promise<Notice> => {\r\n const response = await apiClient.post<Notice>(\"/notices\", data);\r\n return response.data;\r\n },\r\n\r\n // Update an existing notice\r\n updateNotice: async (\r\n id: string,\r\n data: UpdateNoticeRequest\r\n ): Promise<Notice> => {\r\n const response = await apiClient.put<Notice>(`/notices/${id}`, data);\r\n return response.data;\r\n },\r\n\r\n // Delete a notice\r\n deleteNotice: async (id: string): Promise<void> => {\r\n await apiClient.delete(`/notices/${id}`);\r\n },\r\n};\r\n","import type { PartnerDto } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\nimport type { CreatePartnerRequest, UpdatePartnerRequest } from \"../../types/api\";\r\n\r\nexport const partnersApi = {\r\n // 모든 파트너 조회\r\n getPartners: async (): Promise<PartnerDto[]> => {\r\n const response = await apiClient.get(\"/partners\");\r\n return response.data;\r\n },\r\n\r\n // 파트너 상세 조회\r\n getPartner: async (id: string): Promise<PartnerDto> => {\r\n const response = await apiClient.get(`/partners/${id}`);\r\n return response.data;\r\n },\r\n\r\n // 파트너 생성\r\n createPartner: async (request: CreatePartnerRequest): Promise<PartnerDto> => {\r\n const response = await apiClient.post(\"/partners\", request);\r\n return response.data;\r\n },\r\n\r\n // 파트너 수정\r\n updatePartner: async (\r\n id: string,\r\n request: UpdatePartnerRequest\r\n ): Promise<PartnerDto> => {\r\n const response = await apiClient.patch(`/partners/${id}`, request);\r\n return response.data;\r\n },\r\n\r\n // 파트너 삭제\r\n deletePartner: async (id: string): Promise<PartnerDto> => {\r\n const response = await apiClient.delete(`/partners/${id}`);\r\n return response.data;\r\n },\r\n};\r\n","import type { SendNotificationRequest } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const pushApi = {\r\n /**\r\n * Push 구독 정보를 서버에 저장\r\n */\r\n subscribe: async (\r\n subscription: PushSubscription\r\n ): Promise<{ success: boolean }> => {\r\n const response = await apiClient.post<{ success: boolean }>(\r\n \"/push/subscribe\",\r\n subscription.toJSON()\r\n );\r\n return response.data;\r\n },\r\n\r\n /**\r\n * Push 구독 해제\r\n */\r\n unsubscribe: async (endpoint: string): Promise<{ success: boolean }> => {\r\n const response = await apiClient.post<{ success: boolean }>(\r\n \"/push/unsubscribe\",\r\n { endpoint }\r\n );\r\n return response.data;\r\n },\r\n\r\n /**\r\n * 현재 사용자의 Push 구독 상태 확인\r\n */\r\n getSubscriptionStatus: async (): Promise<{\r\n isSubscribed: boolean;\r\n endpoint?: string;\r\n }> => {\r\n const response = await apiClient.get<{\r\n isSubscribed: boolean;\r\n endpoint?: string;\r\n }>(\"/push/status\");\r\n return response.data;\r\n },\r\n\r\n /**\r\n * Push 알림 전송\r\n * @param notification - 알림 요청 데이터\r\n */\r\n sendNotification: async (\r\n notification: SendNotificationRequest\r\n ): Promise<void> => {\r\n await apiClient.post(\"/push/send\", notification);\r\n },\r\n};\r\n","import type { UpsertUserSettingRequest, UserSetting } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const userSettingsApi = {\r\n getUserSettings: async (): Promise<UserSetting> => {\r\n const response = await apiClient.get(\"/user-settings\");\r\n return response.data;\r\n },\r\n\r\n updateUserSettings: async (\r\n settings: UpsertUserSettingRequest,\r\n ): Promise<UserSetting> => {\r\n const response = await apiClient.put(\"/user-settings\", settings);\r\n return response.data;\r\n },\r\n};\r\n","import type { Institution } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const institutionsApi = {\r\n getInstitutions: async (): Promise<Institution[]> => {\r\n const response = await apiClient.get<Institution[]>(\"institutions\");\r\n return response.data;\r\n },\r\n register: async (data: Institution): Promise<Institution> => {\r\n const response = await apiClient.post<Institution>(\"institutions\", data);\r\n return response.data;\r\n },\r\n update: async ({\r\n ykiho,\r\n data,\r\n }: {\r\n ykiho: string;\r\n data: Partial<Institution>;\r\n }): Promise<Institution> => {\r\n const response = await apiClient.patch(`institutions/${ykiho}`, data);\r\n return response.data;\r\n },\r\n delete: async (ykiho: string): Promise<void> => {\r\n await apiClient.delete(`institutions/${ykiho}`);\r\n },\r\n};\r\n"],"names":["speechChat","getChatRooms","recordId","apiClient","get","data","deleteChatRoom","roomId","delete","getChatMessages","res","msgs","updateChatRoomName","name","patch","speechRecords","getRecords","getRecordsWithPage","dto","post","deleteRecord","getRecordById","getTodayRecord","chart","params","getRecordsByChart","getRecordFromImage","imageUrl","getRecordFromAgent","patientInfo","getRecordsByDates","startDate","endDate","page","searchText","ykiho","username","Number","getPatients","getRecordData","speechPatients","getPatientByChart","upsertPatient","put","speechAudios","deleteAudioFile","audioFileId","speechRecordData","resummaryPart","level","part","createAudioFormData","buffer","blob","Blob","type","formData","FormData","append","transcribeWithEndpoint","endpoint","language","headers","speechApi","transcribeV2","transcribeWithTranslation","uploadWithTranslation","opusBlob","transcript","transcripts","durationSeconds","JSON","stringify","toString","upload","vadBuffer","totalBuffer","chat","records","patients","audios","recordData","audioApi","getAudioFile","bucket","keys","responseType","authApi","register","login","credentials","getMe","logout","updateMe","generateNewUserKey","userId","adminLogin","updateUser","id","deleteUser","changePassword","captureRectsApi","getMy","getCaptureRects","getCaptureRect","createCaptureRect","updateCaptureRect","deleteCaptureRect","llmApi","diarization","request","signal","medicalSummary","mindmap","conversation","diseaseRecommendation","noticeApi","getNotices","count","showPublishedOnly","getNotice","createNotice","updateNotice","deleteNotice","partnersApi","getPartners","getPartner","createPartner","updatePartner","deletePartner","pushApi","subscribe","subscription","toJSON","unsubscribe","getSubscriptionStatus","sendNotification","notification","userSettingsApi","getUserSettings","updateUserSettings","settings","institutionsApi","getInstitutions","update"],"mappings":"kLAGaA,EAAa,CACxBC,aAAc,MAAOC,IACP,MAAMC,YAAUC,IAAI,sBAAsBF,CAAQ,EAAE,GACrDG,KAGbC,eAAgB,MAAO,CACrBC,OAAAA,CAAAA,KAIY,MAAMJ,YAAUK,OAAO,sBAAsBD,CAAM,EAAE,GACtDF,KAGbI,gBAAiB,MAAO,CACtBF,OAAAA,CAAAA,IAGiD,CACjD,MAAMG,EAAM,MAAMP,YAAUC,IAAI,yBAAyBG,CAAM,EAAE,EACjE,MAAO,CAAEA,OAAAA,EAAQI,KAAMD,EAAIL,IAAAA,CAC7B,EACAO,mBAAoB,MAAO,CACzBL,OAAAA,EACAM,KAAAA,CAAAA,KAKY,MAAMV,YAAUW,MAAM,sBAAsBP,CAAM,GAAI,CAChEM,KAAAA,CAAAA,CACD,GACUR,IAEf,EC1BaU,EAAgB,CAC3BC,WAAY,UACE,MAAMb,YAAUC,IAAI,iBAAiB,GACtCC,KAGbY,mBAAoB,MAClBC,IAEY,MAAMf,EAAAA,UAAUgB,KAAK,kBAAmBD,CAAG,GAC5Cb,KAGbe,aAAc,MAAO,CACnBlB,SAAAA,CAAAA,KAIY,MAAMC,YAAUK,OAAO,mBAAmBN,CAAQ,EAAE,GACrDG,KAGbgB,cAAe,MAAO,CACpBnB,SAAAA,CAAAA,KAIY,MAAMC,YAAUC,IAAI,mBAAmBF,CAAQ,UAAU,GAC1DG,KAGbiB,eAAgB,MAAO,CACrBC,MAAAA,CAAAA,KAIY,MAAMpB,EAAAA,UAAUC,IAAI,gCAAiC,CAC/DoB,OAAQ,CAAED,MAAAA,CAAAA,CAAM,CACjB,GACUlB,KAGboB,kBAAmB,MAAO,CACxBF,MAAAA,CAAAA,KAIY,MAAMpB,YAAUC,IAAI,mBAAmBmB,CAAK,EAAE,GAC/ClB,KAGbqB,mBAAoB,MAAO,CACzBC,SAAAA,CAAAA,KAIY,MAAMxB,EAAAA,UAAUgB,KAAK,6BAA8B,CAC7DQ,SAAAA,CAAAA,CACD,GACUtB,KAGbuB,mBAAoB,MAClBC,IAEY,MAAM1B,EAAAA,UAAUgB,KAAK,6BAA8BU,CAAW,GAC/DxB,KAIbyB,kBAAmB,MAAO,CACxBC,UAAAA,EACAC,QAAAA,EACAC,KAAAA,EACAC,WAAAA,EACAC,MAAAA,EACAC,SAAAA,CAAAA,KAEY,MAAMjC,YAAUC,IAAI,2BAA4B,CAC1DoB,OAAQ,CACNO,UAAAA,EACAC,QAAAA,EACAC,KAAMI,OAAOJ,CAAI,EACjB,GAAIC,GAAc,CAAEA,WAAAA,CAAAA,EACpB,GAAIC,GAAS,CAAEA,MAAAA,CAAAA,EACf,GAAIC,GAAY,CAAEA,SAAAA,CAAAA,CAAS,CAC7B,CACD,GACU/B,KAGbiC,YAAa,UACC,MAAMnC,YAAUC,IAAI,kBAAkB,GACvCC,KAGbkC,cAAe,MAAO,CACpBrC,SAAAA,CAAAA,KAIY,MAAMC,YAAUC,IAAI,wBAAwBF,CAAQ,EAAE,GACvDG,IAEf,ECjHamC,EAAiB,CAC5BC,kBAAmB,MAAO,CAAElB,MAAAA,CAAAA,KACd,MAAMpB,YAAUC,IAAI,oBAAoBmB,CAAK,EAAE,GAChDlB,KAGbqC,cAAe,MAAO,CACpBnB,MAAAA,EACAV,KAAAA,CAAAA,KAEY,MAAMV,EAAAA,UAAUwC,IAAI,mBAAoB,CAAEpB,MAAAA,EAAOV,KAAAA,CAAAA,CAAM,GACxDR,IAEf,ECbauC,EAAe,CAC1BC,gBAAiB,MAAO,CACtBC,YAAAA,CAAAA,KAIY,MAAM3C,YAAUK,OAAO,kBAAkBsC,CAAW,EAAE,GACvDzC,IAEf,ECTa0C,EAAmB,CAC9BC,cAAe,MAAO,CACpB9C,SAAAA,EACA+C,MAAAA,EACAC,KAAAA,CAAAA,KAEY,MAAM/C,EAAAA,UAAUgB,KAAK,sCAAuC,CACtEjB,SAAAA,EACA+C,MAAAA,EACAC,KAAAA,CAAAA,CACD,GACU7C,IAEf,ECPM8C,EAAuBC,GAAyC,CACpE,MAAMC,EACJD,aAAkBE,KAAOF,EAAS,IAAIE,KAAK,CAACF,CAAM,EAAG,CAAEG,KAAM,WAAA,CAAa,EACtEC,EAAW,IAAIC,SACrBD,OAAAA,EAASE,OAAO,OAAQL,EAAM,WAAW,EAClCG,CACT,EAEMG,EAAyB,MAC7BC,EACAR,EACAS,IACe,CACf,MAAML,EAAWL,EAAoBC,CAAM,EAC3C,OAAIS,GACFL,EAASE,OAAO,WAAYG,CAAQ,GAE1B,MAAM1D,EAAAA,UAAUgB,KAAKyC,EAAUJ,EAAU,CACnDM,QAAS,CACP,eAAgB,qBAAA,CAClB,CACD,GACUzD,IACb,EAEa0D,EAAY,CACvBC,aAAc,MAAO,CACnBZ,OAAAA,CAAAA,IAIOO,EAAuB,wBAAyBP,CAAM,EAG/Da,0BAA2B,MAAO,CAChCb,OAAAA,EACAS,SAAAA,CAAAA,IAKOF,EACL,sCACAP,EACAS,CACF,EAGFK,sBAAuB,MAAO,CAC5BC,SAAAA,EACA5C,MAAAA,EACArB,SAAAA,EACAkE,WAAAA,EACAC,YAAAA,EACAC,gBAAAA,CAAAA,IAC2D,CAC3D,MAAMd,EAAW,IAAIC,SACrBD,OAAAA,EAASE,OACP,WACA,IAAIJ,KAAK,CAACa,CAAQ,EAAG,CAAEZ,KAAM,YAAA,CAAc,EAC3C,YACF,EACAC,EAASE,OAAO,QAASnC,CAAK,EAC9BiC,EAASE,OAAO,aAAcU,CAAU,EACxCZ,EAASE,OAAO,cAAea,KAAKC,UAAUH,CAAW,CAAC,EAC1Db,EAASE,OAAO,kBAAmBY,EAAgBG,SAAAA,CAAU,EACzDvE,GAAUsD,EAASE,OAAO,WAAYxD,CAAQ,GAEtC,MAAMC,EAAAA,UAAUgB,KAC1B,kCACAqC,EACA,CACEM,QAAS,CACP,eAAgB,qBAAA,CAClB,CAEJ,GACWzD,IACb,EAEAqE,OAAQ,MAAO,CACbP,SAAAA,EACAQ,UAAAA,EACAC,YAAAA,EACArD,MAAAA,EACArB,SAAAA,EACAkE,WAAAA,CAAAA,IAC4C,CAC5C,MAAMZ,EAAW,IAAIC,SACrBD,OAAAA,EAASE,OACP,WACA,IAAIJ,KAAK,CAACa,CAAQ,EAAG,CAAEZ,KAAM,YAAA,CAAc,EAC3C,YACF,EACAC,EAASE,OACP,YACA,IAAIJ,KAAK,CAACsB,CAAW,EAAG,CAAErB,KAAM,WAAA,CAAa,EAC7C,WACF,EACIoB,KACOjB,OACP,UACA,IAAIJ,KAAK,CAACqB,CAAS,EAAG,CAAEpB,KAAM,WAAA,CAAa,EAC3C,WACF,EACFC,EAASE,OAAO,QAASnC,CAAK,EAC9BiC,EAASE,OAAO,aAAcU,CAAU,EACpClE,GAAUsD,EAASE,OAAO,WAAYxD,CAAQ,GAEtC,MAAMC,EAAAA,UAAUgB,KAAK,iBAAkBqC,EAAU,CAC3DM,QAAS,CACP,eAAgB,qBAAA,CAClB,CACD,GACUzD,IACb,EAEAwE,KAAM7E,EACN8E,QAAS/D,EACTgE,SAAUvC,EACVwC,OAAQpC,EACRqC,WAAYlC,CACd,ECjIamC,EAAW,CACtBC,aAAc,MAAO,CAAEC,OAAAA,EAAQC,KAAAA,CAAAA,KACjB,MAAMlF,EAAAA,UAAUC,IAAI,SAAU,CACxCoB,OAAQ,CAAE4D,OAAAA,EAAQC,KAAAA,CAAAA,EAClBC,aAAc,MAAA,CACf,GACUjF,IAEf,ECFakF,EAAU,CACrBC,SAAU,MAAOtE,IACE,MAAMf,EAAAA,UAAUgB,KAAc,iBAAkBD,CAAG,GACpDb,KAElBoF,MAAO,MAAOC,IACK,MAAMvF,EAAAA,UAAUgB,KAC/B,cACAuE,CACF,GACgBrF,KAElBsF,MAAO,UACY,MAAMxF,YAAUC,IAAa,UAAU,GACxCC,KAElBuF,OAAQ,SAA2B,CACjC,MAAMzF,EAAAA,UAAUgB,KAAK,cAAc,CACrC,EAEA0E,SAAU,MAAOxF,IACE,MAAMF,EAAAA,UAAUW,MAAyB,WAAYT,CAAI,GAC1DA,KAGlByF,mBAAoB,MAAO,CACzBC,OAAAA,CAAAA,KAIiB,MAAM5F,YAAUwC,IAC/B,2BAA2BoD,CAAM,EACnC,GACgB1F,KAIlB2F,WAAY,MAAON,IACA,MAAMvF,EAAAA,UAAUgB,KAC/B,oBACAuE,CACF,GACgBrF,KAGlB4F,WAAY,MAAO5F,IACA,MAAMF,EAAAA,UAAUwC,IAC/B,cAActC,EAAK6F,EAAE,GACrB7F,CACF,GACgBA,KAGlB8F,WAAY,MAAOJ,GAAkC,CACnD,MAAM5F,EAAAA,UAAUK,OAAO,cAAcuF,CAAM,EAAE,CAC/C,EAEAK,eAAgB,MAAO/F,GAGF,CACnB,MAAMF,YAAUW,MAAM,2BAA4BT,CAAI,CACxD,CACF,EC/DagG,EAAkB,CAC7BC,MAAO,UACO,MAAMnG,YAAUC,IAAI,mBAAmB,GACxCC,KAGbkG,gBAAiB,UACE,MAAMpG,YAAUC,IAAmB,eAAe,GACnDC,KAIlBmG,eAAgB,MAAON,IACJ,MAAM/F,YAAUC,IAAiB,iBAAiB8F,CAAE,EAAE,GACvD7F,KAIlBoG,kBAAmB,MACjBpG,IAEiB,MAAMF,EAAAA,UAAUgB,KAAkB,gBAAiBd,CAAI,GACxDA,KAIlBqG,kBAAmB,MAAO,CACxBR,GAAAA,EACA7F,KAAAA,CAAAA,KAKiB,MAAMF,EAAAA,UAAUW,MAC/B,iBAAiBoF,CAAE,GACnB7F,CACF,GACgBA,KAIlBsG,kBAAmB,MAAOT,IACP,MAAM/F,YAAUK,OAC/B,iBAAiB0F,CAAE,EACrB,GACgB7F,IAEpB,EC5CauG,EAAS,CACpBC,YAAa,MACXC,EACAC,KAEiB,MAAM5G,EAAAA,UAAUgB,KAAK,mBAAoB2F,EAAS,CACjEC,OAAAA,CAAAA,CACD,GAEe1G,KAGlB2G,eAAgB,MAAO,CACrBF,QAAAA,EACAC,OAAAA,CAAAA,KAKiB,MAAM5G,EAAAA,UAAUgB,KAAK,uBAAwB2F,EAAS,CACrEC,OAAAA,CAAAA,CACD,GAEe1G,KAGlB4G,QAAS,MAAO,CACdC,aAAAA,CAAAA,KAIiB,MAAM/G,EAAAA,UAAUgB,KAAK,eAAgB,CAAE+F,aAAAA,CAAAA,CAAc,GACtD7G,KAGlB8G,sBAAuB,MAAO,CAC5BD,aAAAA,CAAAA,KAEiB,MAAM/G,EAAAA,UAAUgB,KAAK,8BAA+B,CACnE+F,aAAAA,CAAAA,CACD,GACe7G,IAEpB,ECnDa+G,EAAY,CACvBC,WAAY,MACV7F,IAEiB,MAAMrB,YAAUgB,KAAyB,gBAAiB,CACzEc,KAAMT,GAAQS,MAAQ,EACtBqF,MAAO9F,GAAQ8F,OAAS,GACxBpF,WAAYV,GAAQU,WACpBqF,kBAAmB/F,GAAQ+F,mBAAqB,EAAA,CACjD,GACelH,KAGlBmH,UAAW,MAAOtB,IACC,MAAM/F,YAAUC,IAAY,YAAY8F,CAAE,EAAE,GAC7C7F,KAIlBoH,aAAc,MAAOpH,IACF,MAAMF,EAAAA,UAAUgB,KAAa,WAAYd,CAAI,GAC9CA,KAIlBqH,aAAc,MACZxB,EACA7F,KAEiB,MAAMF,EAAAA,UAAUwC,IAAY,YAAYuD,CAAE,GAAI7F,CAAI,GACnDA,KAIlBsH,aAAc,MAAOzB,GAA8B,CACjD,MAAM/F,EAAAA,UAAUK,OAAO,YAAY0F,CAAE,EAAE,CACzC,CACF,ECpCa0B,EAAc,CAEzBC,YAAa,UACM,MAAM1H,YAAUC,IAAI,WAAW,GAChCC,KAIlByH,WAAY,MAAO5B,IACA,MAAM/F,YAAUC,IAAI,aAAa8F,CAAE,EAAE,GACtC7F,KAIlB0H,cAAe,MAAOjB,IACH,MAAM3G,EAAAA,UAAUgB,KAAK,YAAa2F,CAAO,GAC1CzG,KAIlB2H,cAAe,MACb9B,EACAY,KAEiB,MAAM3G,EAAAA,UAAUW,MAAM,aAAaoF,CAAE,GAAIY,CAAO,GACjDzG,KAIlB4H,cAAe,MAAO/B,IACH,MAAM/F,YAAUK,OAAO,aAAa0F,CAAE,EAAE,GACzC7F,IAEpB,EClCa6H,EAAU,CAIrBC,UAAW,MACTC,IAEiB,MAAMjI,YAAUgB,KAC/B,kBACAiH,EAAaC,QACf,GACgBhI,KAMlBiI,YAAa,MAAO1E,IACD,MAAMzD,YAAUgB,KAC/B,oBACA,CAAEyC,SAAAA,CAAAA,CACJ,GACgBvD,KAMlBkI,sBAAuB,UAIJ,MAAMpI,YAAUC,IAG9B,cAAc,GACDC,KAOlBmI,iBAAkB,MAChBC,GACkB,CAClB,MAAMtI,YAAUgB,KAAK,aAAcsH,CAAY,CACjD,CACF,EChDaC,EAAkB,CAC7BC,gBAAiB,UACE,MAAMxI,YAAUC,IAAI,gBAAgB,GACrCC,KAGlBuI,mBAAoB,MAClBC,IAEiB,MAAM1I,EAAAA,UAAUwC,IAAI,iBAAkBkG,CAAQ,GAC/CxI,IAEpB,ECZayI,EAAkB,CAC7BC,gBAAiB,UACE,MAAM5I,YAAUC,IAAmB,cAAc,GAClDC,KAElBmF,SAAU,MAAOnF,IACE,MAAMF,EAAAA,UAAUgB,KAAkB,eAAgBd,CAAI,GACvDA,KAElB2I,OAAQ,MAAO,CACb7G,MAAAA,EACA9B,KAAAA,CAAAA,KAKiB,MAAMF,EAAAA,UAAUW,MAAM,gBAAgBqB,CAAK,GAAI9B,CAAI,GACpDA,KAElBG,OAAQ,MAAO2B,GAAiC,CAC9C,MAAMhC,EAAAA,UAAUK,OAAO,gBAAgB2B,CAAK,EAAE,CAChD,CACF"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../../compiler-runtime-BtE0QEUt.cjs"),l=require("@tanstack/react-query");require("axios");const m=require("../../feedback-xoeZc8ns.cjs"),i=["feedbacks"],y=s=>{const e=a.compilerRuntimeExports.c(12);let t;e[0]!==s?(t=s===void 0?{}:s,e[0]=s,e[1]=t):t=e[1];let r,n;e[2]!==t?({enabled:r,...n}=t,e[2]=t,e[3]=r,e[4]=n):(r=e[3],n=e[4]);let u,c;e[5]!==n?(u=[...i,n],c=()=>m.feedbackApi.listFeedbacks(n),e[5]=n,e[6]=u,e[7]=c):(u=e[6],c=e[7]);const b=r??!0;let o;return e[8]!==u||e[9]!==c||e[10]!==b?(o={queryKey:u,queryFn:c,enabled:b},e[8]=u,e[9]=c,e[10]=b,e[11]=o):o=e[11],l.useQuery(o)},F=s=>{const e=a.compilerRuntimeExports.c(7);let t,r;e[0]!==s?(t=[...i,"comments",s],r=()=>m.feedbackApi.getComments(s),e[0]=s,e[1]=t,e[2]=r):(t=e[1],r=e[2]);const n=!!s;let u;return e[3]!==t||e[4]!==r||e[5]!==n?(u={queryKey:t,queryFn:r,enabled:n},e[3]=t,e[4]=r,e[5]=n,e[6]=u):u=e[6],l.useQuery(u)},p=s=>{const e=a.compilerRuntimeExports.c(7);let t,r;e[0]!==s?(t=[...i,"detail",s],r=()=>m.feedbackApi.getFeedback(s),e[0]=s,e[1]=t,e[2]=r):(t=e[1],r=e[2]);const n=!!s;let u;return e[3]!==t||e[4]!==r||e[5]!==n?(u={queryKey:t,queryFn:r,enabled:n},e[3]=t,e[4]=r,e[5]=n,e[6]=u):u=e[6],l.useQuery(u)},d=()=>{const s=a.compilerRuntimeExports.c(2),e=l.useQueryClient();let t;return s[0]!==e?(t={mutationFn:f,onSuccess:()=>{e.invalidateQueries({queryKey:i})}},s[0]=e,s[1]=t):t=s[1],l.useMutation(t)};function f(s){return m.feedbackApi.createFeedback(s)}exports.FEEDBACKS_QUERY_KEY=i;exports.useCreateFeedback=d;exports.useFeedbackComments=F;exports.useFeedbackDetail=p;exports.useFeedbacks=y;
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/hooks/feedbacks/index.ts"],"sourcesContent":["import type {\r\n CreateFeedbackRequest,\r\n FeedbackListRequest,\r\n} from \"@clickcns/vmedic-react/types\";\r\nimport { useMutation, useQuery, useQueryClient } from \"@tanstack/react-query\";\r\nimport { feedbackApi } from \"../../api\";\r\n\r\nexport const FEEDBACKS_QUERY_KEY = [\"feedbacks\"];\r\n\r\ninterface UseFeedbacksParams extends FeedbackListRequest {\r\n enabled?: boolean;\r\n}\r\n\r\nexport const useFeedbacks = ({\r\n enabled,\r\n ...params\r\n}: UseFeedbacksParams = {}) => {\r\n return useQuery({\r\n queryKey: [...FEEDBACKS_QUERY_KEY, params],\r\n queryFn: () => feedbackApi.listFeedbacks(params),\r\n enabled: enabled ?? true,\r\n });\r\n};\r\n\r\nexport const useFeedbackComments = (feedbackId: string | null) => {\r\n return useQuery({ \r\n queryKey: [...FEEDBACKS_QUERY_KEY, \"comments\", feedbackId],\r\n queryFn: () => feedbackApi.getComments(feedbackId!),\r\n enabled: !!feedbackId,\r\n });\r\n};\r\n\r\nexport const useFeedbackDetail = (id: string | null) => {\r\n return useQuery({\r\n queryKey: [...FEEDBACKS_QUERY_KEY, \"detail\", id],\r\n queryFn: () => feedbackApi.getFeedback(id!),\r\n enabled: !!id,\r\n });\r\n};\r\n\r\nexport const useCreateFeedback = () => {\r\n const queryClient = useQueryClient();\r\n\r\n return useMutation({\r\n mutationFn: (data: CreateFeedbackRequest) =>\r\n feedbackApi.createFeedback(data),\r\n onSuccess: () => {\r\n queryClient.invalidateQueries({ queryKey: FEEDBACKS_QUERY_KEY });\r\n },\r\n });\r\n};\r\n"],"names":["FEEDBACKS_QUERY_KEY","useFeedbacks","t0","$","_c","t1","undefined","enabled","params","t2","t3","feedbackApi","listFeedbacks","t4","t5","queryKey","queryFn","useQuery","useFeedbackComments","feedbackId","getComments","useFeedbackDetail","id","getFeedback","useCreateFeedback","queryClient","useQueryClient","mutationFn","_temp","onSuccess","invalidateQueries","useMutation","data","createFeedback"],"mappings":"0OAOaA,EAAsB,CAAC,WAAW,EAMlCC,EAAeC,GAAA,CAAA,MAAAC,EAAAC,EAAAA,uBAAAA,EAAA,EAAA,EAAA,IAAAC,EAAAF,OAAAD,GAACG,EAAAH,IAGHI,UAHGJ,EAGHC,KAAAD,EAAAC,KAAAE,GAAAA,EAAAF,EAAA,CAAA,EAAA,IAAAI,EAAAC,EAAAL,OAAAE,GAHG,CAAAE,QAAAA,EAAA,GAAAC,CAAAA,EAAAH,EAGHF,KAAAE,EAAAF,KAAAI,EAAAJ,KAAAK,IAAAD,EAAAJ,EAAA,CAAA,EAAAK,EAAAL,EAAA,CAAA,GAAA,IAAAM,EAAAC,EAAAP,OAAAK,GAEZC,EAAA,CAAA,GAAAT,EAAyBQ,CAAM,EAChCE,EAAAA,IAAMC,EAAAA,YAAAC,cAA0BJ,CAAM,EAACL,KAAAK,EAAAL,KAAAM,EAAAN,KAAAO,IAAAD,EAAAN,EAAA,CAAA,EAAAO,EAAAP,EAAA,CAAA,GACvC,MAAAU,EAAAN,GAAO,GAAQ,IAAAO,EAAA,OAAAX,EAAA,CAAA,IAAAM,GAAAN,OAAAO,GAAAP,EAAA,EAAA,IAAAU,GAHVC,EAAA,CAAAC,SACJN,EAAgCO,QACjCN,EAAuCH,QACvCM,CAAAA,EACVV,KAAAM,EAAAN,KAAAO,EAAAP,MAAAU,EAAAV,MAAAW,GAAAA,EAAAX,EAAA,EAAA,EAJMc,EAAAA,SAASH,CAIf,CAAC,EAGSI,EAAsBC,GAAA,CAAA,MAAAhB,EAAAC,EAAAA,uBAAAA,EAAA,CAAA,EAAA,IAAAF,EAAAG,EAAAF,OAAAgB,GAErBjB,EAAA,CAAA,GAAAF,EAAyB,WAAYmB,CAAU,EAChDd,EAAAA,IAAMM,EAAAA,YAAAS,YAAwBD,CAAW,EAAChB,KAAAgB,EAAAhB,KAAAD,EAAAC,KAAAE,IAAAH,EAAAC,EAAA,CAAA,EAAAE,EAAAF,EAAA,CAAA,GAC1C,MAAAM,IAAEU,EAAU,IAAAT,EAAA,OAAAP,EAAA,CAAA,IAAAD,GAAAC,OAAAE,GAAAF,EAAA,CAAA,IAAAM,GAHPC,EAAA,CAAAK,SACJb,EAAgDc,QACjDX,EAA0CE,QAC1CE,CAAAA,EACVN,KAAAD,EAAAC,KAAAE,EAAAF,KAAAM,EAAAN,KAAAO,GAAAA,EAAAP,EAAA,CAAA,EAJMc,EAAAA,SAASP,CAIf,CAAC,EAGSW,EAAoBC,GAAA,CAAA,MAAAnB,EAAAC,EAAAA,uBAAAA,EAAA,CAAA,EAAA,IAAAF,EAAAG,EAAAF,OAAAmB,GAEnBpB,EAAA,CAAA,GAAAF,EAAyB,SAAUsB,CAAE,EACtCjB,EAAAA,IAAMM,EAAAA,YAAAY,YAAwBD,CAAG,EAACnB,KAAAmB,EAAAnB,KAAAD,EAAAC,KAAAE,IAAAH,EAAAC,EAAA,CAAA,EAAAE,EAAAF,EAAA,CAAA,GAClC,MAAAM,IAAEa,EAAE,IAAAZ,EAAA,OAAAP,EAAA,CAAA,IAAAD,GAAAC,OAAAE,GAAAF,EAAA,CAAA,IAAAM,GAHCC,EAAA,CAAAK,SACJb,EAAsCc,QACvCX,EAAkCE,QAClCE,CAAAA,EACVN,KAAAD,EAAAC,KAAAE,EAAAF,KAAAM,EAAAN,KAAAO,GAAAA,EAAAP,EAAA,CAAA,EAJMc,EAAAA,SAASP,CAIf,CAAC,EAGSc,EAAoBA,IAAA,CAAA,MAAArB,EAAAC,EAAAA,uBAAAA,EAAA,CAAA,EAC/BqB,EAAoBC,EAAAA,eAAAA,EAAiB,IAAAxB,EAAA,OAAAC,OAAAsB,GAElBvB,EAAA,CAAAyB,WAAAC,EAAAC,UAAAA,IAAA,CAIfJ,EAAWK,kBAAA,CAAAf,SAAAf,CAAAA,CAAoD,CAAC,CAAA,EAEnEG,KAAAsB,EAAAtB,KAAAD,GAAAA,EAAAC,EAAA,CAAA,EANM4B,EAAAA,YAAY7B,CAMlB,CAAC,EAT6B,SAAA0B,EAAAI,EAAA,CAAA,OAK3BrB,EAAAA,YAAAsB,eAA2BD,CAAI,CAAC"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("../../compiler-runtime-BtE0QEUt.cjs"),o=require("@tanstack/react-query");require("axios");const n=require("../../user-notifications-eaEdb3_1.cjs"),s=require("../hooks.feedbacks/index.js"),u=()=>{const t=r.compilerRuntimeExports.c(1);let e;return t[0]===Symbol.for("react.memo_cache_sentinel")?(e={queryKey:["user-notifications"],queryFn:n.userNotificationsApi.getNotifications,refetchInterval:18e4},t[0]=e):e=t[0],o.useQuery(e)},c=()=>{const t=r.compilerRuntimeExports.c(1);let e;return t[0]===Symbol.for("react.memo_cache_sentinel")?(e={queryKey:["unread-notification-count"],queryFn:n.userNotificationsApi.getUnreadNotificationCount},t[0]=e):e=t[0],o.useQuery(e)},a=()=>{const t=r.compilerRuntimeExports.c(2),e=o.useQueryClient();let i;return t[0]!==e?(i={mutationFn:n.userNotificationsApi.markAsRead,onSuccess:()=>{e.invalidateQueries({queryKey:["user-notifications"]}),e.invalidateQueries({queryKey:["unread-notification-count"]}),e.invalidateQueries({queryKey:s.FEEDBACKS_QUERY_KEY})}},t[0]=e,t[1]=i):i=t[1],o.useMutation(i)};exports.useMarkAsRead=a;exports.useUnreadNotificationCount=c;exports.useUserNotifications=u;
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/hooks/user-notifications/index.ts"],"sourcesContent":["import { useMutation, useQuery, useQueryClient } from \"@tanstack/react-query\";\r\nimport { userNotificationsApi } from \"../../api\";\r\nimport { FEEDBACKS_QUERY_KEY } from \"../feedbacks\";\r\n\r\nexport const useUserNotifications = () => {\r\n return useQuery({\r\n queryKey: [\"user-notifications\"],\r\n queryFn: userNotificationsApi.getNotifications,\r\n refetchInterval: 180_000, // 3분마다 새로고침\r\n });\r\n};\r\n\r\nexport const useUnreadNotificationCount = () => {\r\n return useQuery({\r\n queryKey: [\"unread-notification-count\"],\r\n queryFn: userNotificationsApi.getUnreadNotificationCount,\r\n });\r\n};\r\n\r\nexport const useMarkAsRead = () => {\r\n const queryClient = useQueryClient();\r\n return useMutation({\r\n mutationFn: userNotificationsApi.markAsRead,\r\n onSuccess: () => {\r\n queryClient.invalidateQueries({ queryKey: [\"user-notifications\"] });\r\n queryClient.invalidateQueries({ queryKey: [\"unread-notification-count\"] });\r\n queryClient.invalidateQueries({ queryKey: FEEDBACKS_QUERY_KEY });\r\n },\r\n });\r\n};\r\n"],"names":["useUserNotifications","$","_c","t0","Symbol","for","queryKey","queryFn","userNotificationsApi","getNotifications","refetchInterval","useQuery","useUnreadNotificationCount","getUnreadNotificationCount","useMarkAsRead","queryClient","useQueryClient","mutationFn","markAsRead","onSuccess","invalidateQueries","FEEDBACKS_QUERY_KEY","useMutation"],"mappings":"6RAIaA,EAAuBA,IAAA,CAAA,MAAAC,EAAAC,EAAAA,uBAAAA,EAAA,CAAA,EAAA,IAAAC,EAAA,OAAAF,EAAA,CAAA,IAAAG,OAAAC,IAAA,2BAAA,GAClBF,EAAA,CAAAG,UACH,oBAAoB,EAAAC,QAAAC,EAAAA,qBAAAC,iBAAAC,gBAAA,IAAA,EAGhCT,KAAAE,GAAAA,EAAAF,EAAA,CAAA,EAJMU,EAAAA,SAASR,CAIf,CAAC,EAGSS,EAA6BA,IAAA,CAAA,MAAAX,EAAAC,EAAAA,uBAAAA,EAAA,CAAA,EAAA,IAAAC,EAAA,OAAAF,EAAA,CAAA,IAAAG,OAAAC,IAAA,2BAAA,GACxBF,EAAA,CAAAG,UACH,2BAA2B,EAAAC,QAAAC,EAAAA,qBAAAK,0BAAAA,EAEvCZ,KAAAE,GAAAA,EAAAF,EAAA,CAAA,EAHMU,EAAAA,SAASR,CAGf,CAAC,EAGSW,EAAgBA,IAAA,CAAA,MAAAb,EAAAC,EAAAA,uBAAAA,EAAA,CAAA,EAC3Ba,EAAoBC,EAAAA,eAAAA,EAAiB,IAAAb,EAAA,OAAAF,OAAAc,GAClBZ,EAAA,CAAAc,WAAAT,EAAAA,qBAAAU,WAAAC,UAAAA,IAAA,CAGfJ,EAAWK,kBAAA,CAAAd,UAAgC,oBAAoB,CAAA,CAAG,EAClES,EAAWK,kBAAA,CAAAd,UAAgC,2BAA2B,CAAA,CAAG,EACzES,EAAWK,kBAAA,CAAAd,SAAAe,EAAAA,mBAAAA,CAAoD,CAAC,CAAA,EAEnEpB,KAAAc,EAAAd,KAAAE,GAAAA,EAAAF,EAAA,CAAA,EAPMqB,EAAAA,YAAYnB,CAOlB,CAAC"}