@clickcns/vmedic-react 0.0.7 → 0.0.9

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.
@@ -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":"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"}
@@ -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":"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"}
@@ -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"}
@@ -1,43 +1,7 @@
1
- import h from "axios";
2
- let s;
3
- const C = ({
4
- baseURL: e,
5
- timeout: t = 12e4,
6
- withCredentials: a = !0,
7
- headers: n,
8
- getAccessToken: c,
9
- getRefreshAccessToken: p,
10
- onUnauthorized: r,
11
- onRefreshTokenSuccess: u,
12
- ...w
13
- }) => (s = h.create({
14
- baseURL: e,
15
- timeout: t,
16
- withCredentials: a,
17
- headers: n || {
18
- "Content-Type": "application/json"
19
- },
20
- ...w
21
- }), s.interceptors.request.use((o) => {
22
- const i = c();
23
- return i && (o.headers.Authorization = `Bearer ${i}`), o;
24
- }, (o) => Promise.reject(o)), s.interceptors.response.use((o) => o, async (o) => {
25
- const i = o.config;
26
- if (i.url?.includes("/auth/login"))
27
- return Promise.reject(o);
28
- if (o.response?.status === 401 && !i._retry) {
29
- i._retry = !0;
30
- try {
31
- const d = await p();
32
- if (!d)
33
- throw new Error("Failed to refresh access token");
34
- return i.headers.Authorization = `Bearer ${d}`, u(d), s(i);
35
- } catch (d) {
36
- return r(), Promise.reject(d);
37
- }
38
- }
39
- return Promise.reject(o);
40
- }), s), g = {
1
+ import { a as s } from "../../feedback-BbDeqNIh.js";
2
+ import { f as B, i as T } from "../../feedback-BbDeqNIh.js";
3
+ import { u as U } from "../../user-notifications-DbJeK8gS.js";
4
+ const d = {
41
5
  getChatRooms: async (e) => (await s.get(`/speech/chat/rooms/${e}`)).data,
42
6
  deleteChatRoom: async ({
43
7
  roomId: e
@@ -57,7 +21,7 @@ const C = ({
57
21
  }) => (await s.patch(`/speech/chat/rooms/${e}`, {
58
22
  name: t
59
23
  })).data
60
- }, m = {
24
+ }, u = {
61
25
  getRecords: async () => (await s.get("/speech/records")).data,
62
26
  getRecordsWithPage: async (e) => (await s.post("/speech/records", e)).data,
63
27
  deleteRecord: async ({
@@ -88,8 +52,8 @@ const C = ({
88
52
  endDate: t,
89
53
  page: a,
90
54
  searchText: n,
91
- ykiho: c,
92
- username: p
55
+ ykiho: o,
56
+ username: c
93
57
  }) => (await s.get("/speech/records/by-dates", {
94
58
  params: {
95
59
  startDate: e,
@@ -98,11 +62,11 @@ const C = ({
98
62
  ...n && {
99
63
  searchText: n
100
64
  },
101
- ...c && {
102
- ykiho: c
65
+ ...o && {
66
+ ykiho: o
103
67
  },
104
- ...p && {
105
- username: p
68
+ ...c && {
69
+ username: c
106
70
  }
107
71
  }
108
72
  })).data,
@@ -110,7 +74,7 @@ const C = ({
110
74
  getRecordData: async ({
111
75
  recordId: e
112
76
  }) => (await s.get(`/speech/record-datas/${e}`)).data
113
- }, l = {
77
+ }, y = {
114
78
  getPatientByChart: async ({
115
79
  chart: e
116
80
  }) => (await s.get(`/speech/patients/${e}`)).data,
@@ -121,11 +85,11 @@ const C = ({
121
85
  chart: e,
122
86
  name: t
123
87
  })).data
124
- }, b = {
88
+ }, w = {
125
89
  deleteAudioFile: async ({
126
90
  audioFileId: e
127
91
  }) => (await s.delete(`/speech/audios/${e}`)).data
128
- }, $ = {
92
+ }, h = {
129
93
  resummaryPart: async ({
130
94
  recordId: e,
131
95
  level: t,
@@ -135,38 +99,38 @@ const C = ({
135
99
  level: t,
136
100
  part: a
137
101
  })).data
138
- }, f = (e) => {
102
+ }, g = (e) => {
139
103
  const t = e instanceof Blob ? e : new Blob([e], {
140
104
  type: "audio/pcm"
141
105
  }), a = new FormData();
142
106
  return a.append("file", t, "audio.pcm"), a;
143
- }, y = async (e, t, a) => {
144
- const n = f(t);
107
+ }, p = async (e, t, a) => {
108
+ const n = g(t);
145
109
  return a && n.append("language", a), (await s.post(e, n, {
146
110
  headers: {
147
111
  "Content-Type": "multipart/form-data"
148
112
  }
149
113
  })).data;
150
- }, A = {
114
+ }, l = {
151
115
  transcribeV2: async ({
152
116
  buffer: e
153
- }) => y("/speech/transcribe-v2", e),
117
+ }) => p("/speech/transcribe-v2", e),
154
118
  transcribeWithTranslation: async ({
155
119
  buffer: e,
156
120
  language: t
157
- }) => y("/speech/transcribe-with-translation", e, t),
121
+ }) => p("/speech/transcribe-with-translation", e, t),
158
122
  uploadWithTranslation: async ({
159
123
  opusBlob: e,
160
124
  chart: t,
161
125
  recordId: a,
162
126
  transcript: n,
163
- transcripts: c,
164
- durationSeconds: p
127
+ transcripts: o,
128
+ durationSeconds: c
165
129
  }) => {
166
130
  const r = new FormData();
167
131
  return r.append("opusFile", new Blob([e], {
168
132
  type: "audio/webm"
169
- }), "audio.webm"), r.append("chart", t), r.append("transcript", n), r.append("transcripts", JSON.stringify(c)), r.append("durationSeconds", p.toString()), a && r.append("recordId", a), (await s.post("/speech/upload-with-translation", r, {
133
+ }), "audio.webm"), r.append("chart", t), r.append("transcript", n), r.append("transcripts", JSON.stringify(o)), r.append("durationSeconds", c.toString()), a && r.append("recordId", a), (await s.post("/speech/upload-with-translation", r, {
170
134
  headers: {
171
135
  "Content-Type": "multipart/form-data"
172
136
  }
@@ -177,8 +141,8 @@ const C = ({
177
141
  vadBuffer: t,
178
142
  totalBuffer: a,
179
143
  chart: n,
180
- recordId: c,
181
- transcript: p
144
+ recordId: o,
145
+ transcript: c
182
146
  }) => {
183
147
  const r = new FormData();
184
148
  return r.append("opusFile", new Blob([e], {
@@ -187,18 +151,18 @@ const C = ({
187
151
  type: "audio/pcm"
188
152
  }), "audio.pcm"), t && r.append("vadFile", new Blob([t], {
189
153
  type: "audio/pcm"
190
- }), "audio.pcm"), r.append("chart", n), r.append("transcript", p), c && r.append("recordId", c), (await s.post("/speech/upload", r, {
154
+ }), "audio.pcm"), r.append("chart", n), r.append("transcript", c), o && r.append("recordId", o), (await s.post("/speech/upload", r, {
191
155
  headers: {
192
156
  "Content-Type": "multipart/form-data"
193
157
  }
194
158
  })).data;
195
159
  },
196
- chat: g,
197
- records: m,
198
- patients: l,
199
- audios: b,
200
- recordData: $
201
- }, k = {
160
+ chat: d,
161
+ records: u,
162
+ patients: y,
163
+ audios: w,
164
+ recordData: h
165
+ }, b = {
202
166
  getAudioFile: async ({
203
167
  bucket: e,
204
168
  keys: t
@@ -209,7 +173,7 @@ const C = ({
209
173
  },
210
174
  responseType: "blob"
211
175
  })).data
212
- }, F = {
176
+ }, $ = {
213
177
  register: async (e) => (await s.post("/auth/register", e)).data,
214
178
  login: async (e) => (await s.post("/auth/login", e)).data,
215
179
  getMe: async () => (await s.get("/auth/me")).data,
@@ -229,7 +193,7 @@ const C = ({
229
193
  changePassword: async (e) => {
230
194
  await s.patch("/auth/me/change-password", e);
231
195
  }
232
- }, P = {
196
+ }, R = {
233
197
  getMy: async () => (await s.get("/capture-rects/my")).data,
234
198
  // 모든 캡처 영역 조회 (GET /capture-rects)
235
199
  getCaptureRects: async () => (await s.get("capture-rects")).data,
@@ -244,30 +208,7 @@ const C = ({
244
208
  }) => (await s.patch(`capture-rects/${e}`, t)).data,
245
209
  // 캡처 영역 삭제 (DELETE /capture-rects/:id)
246
210
  deleteCaptureRect: async (e) => (await s.delete(`capture-rects/${e}`)).data
247
- }, D = {
248
- // 피드백 목록 조회 (페이지네이션)
249
- listFeedbacks: async (e) => (await s.post("/feedbacks/page", {
250
- page: e.page ?? 1,
251
- count: e.count ?? 30,
252
- status: e.status
253
- })).data,
254
- // 피드백 상세 조회
255
- getFeedback: async (e) => (await s.get(`/feedbacks/${e}`)).data,
256
- // 피드백 생성
257
- createFeedback: async (e) => (await s.post("/feedbacks", e)).data,
258
- // 피드백 수정
259
- updateFeedback: async (e, t) => (await s.put(`/feedbacks/${e}`, t)).data,
260
- // 피드백 삭제
261
- deleteFeedback: async (e) => (await s.delete(`/feedbacks/${e}`)).data,
262
- // 피드백 댓글 목록 조회
263
- getComments: async (e) => (await s.get(`/feedbacks/${e}/comments`)).data,
264
- // 피드백 댓글 작성
265
- createComment: async (e, t) => (await s.post(`/feedbacks/${e}/comments`, t)).data,
266
- // 피드백 댓글 삭제
267
- deleteComment: async (e) => (await s.delete(`/feedbacks/comments/${e}`)).data,
268
- // 피드백 댓글 수정
269
- updateComment: async (e, t) => (await s.put(`/feedbacks/comments/${e}`, t)).data
270
- }, B = {
211
+ }, A = {
271
212
  diarization: async (e, t) => (await s.post("/llm/diarization", e, {
272
213
  signal: t
273
214
  })).data,
@@ -287,7 +228,7 @@ const C = ({
287
228
  }) => (await s.post("/llm/disease-recommendation", {
288
229
  conversation: e
289
230
  })).data
290
- }, N = {
231
+ }, f = {
291
232
  getNotices: async (e) => (await s.post("/notices/page", {
292
233
  page: e?.page ?? 1,
293
234
  count: e?.count ?? 10,
@@ -303,7 +244,7 @@ const C = ({
303
244
  deleteNotice: async (e) => {
304
245
  await s.delete(`/notices/${e}`);
305
246
  }
306
- }, S = {
247
+ }, C = {
307
248
  // 모든 파트너 조회
308
249
  getPartners: async () => (await s.get("/partners")).data,
309
250
  // 파트너 상세 조회
@@ -314,7 +255,7 @@ const C = ({
314
255
  updatePartner: async (e, t) => (await s.patch(`/partners/${e}`, t)).data,
315
256
  // 파트너 삭제
316
257
  deletePartner: async (e) => (await s.delete(`/partners/${e}`)).data
317
- }, T = {
258
+ }, P = {
318
259
  /**
319
260
  * Push 구독 정보를 서버에 저장
320
261
  */
@@ -336,10 +277,10 @@ const C = ({
336
277
  sendNotification: async (e) => {
337
278
  await s.post("/push/send", e);
338
279
  }
339
- }, j = {
280
+ }, D = {
340
281
  getUserSettings: async () => (await s.get("/user-settings")).data,
341
282
  updateUserSettings: async (e) => (await s.put("/user-settings", e)).data
342
- }, z = {
283
+ }, F = {
343
284
  getInstitutions: async () => (await s.get("institutions")).data,
344
285
  register: async (e) => (await s.post("institutions", e)).data,
345
286
  update: async ({
@@ -352,17 +293,18 @@ const C = ({
352
293
  };
353
294
  export {
354
295
  s as apiClient,
355
- k as audioApi,
356
- F as authApi,
357
- P as captureRectsApi,
358
- D as feedbackApi,
359
- C as initializeAxios,
360
- z as institutionsApi,
361
- B as llmApi,
362
- N as noticeApi,
363
- S as partnersApi,
364
- T as pushApi,
365
- A as speechApi,
366
- j as userSettingsApi
296
+ b as audioApi,
297
+ $ as authApi,
298
+ R as captureRectsApi,
299
+ B as feedbackApi,
300
+ T as initializeAxios,
301
+ F as institutionsApi,
302
+ A as llmApi,
303
+ f as noticeApi,
304
+ C as partnersApi,
305
+ P as pushApi,
306
+ l as speechApi,
307
+ U as userNotificationsApi,
308
+ D as userSettingsApi
367
309
  };
368
310
  //# 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":"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"}
@@ -0,0 +1,67 @@
1
+ import { c as u } from "../../compiler-runtime-BNHg76kC.js";
2
+ import { useQuery as y, useQueryClient as f, useMutation as F } from "@tanstack/react-query";
3
+ import "axios";
4
+ import { f as i } from "../../feedback-BbDeqNIh.js";
5
+ const a = ["feedbacks"], k = (s) => {
6
+ const e = u.c(12);
7
+ let t;
8
+ e[0] !== s ? (t = s === void 0 ? {} : s, e[0] = s, e[1] = t) : t = e[1];
9
+ let n, l;
10
+ e[2] !== t ? ({
11
+ enabled: n,
12
+ ...l
13
+ } = t, e[2] = t, e[3] = n, e[4] = l) : (n = e[3], l = e[4]);
14
+ let r, o;
15
+ e[5] !== l ? (r = [...a, l], o = () => i.listFeedbacks(l), e[5] = l, e[6] = r, e[7] = o) : (r = e[6], o = e[7]);
16
+ const m = n ?? !0;
17
+ let c;
18
+ return e[8] !== r || e[9] !== o || e[10] !== m ? (c = {
19
+ queryKey: r,
20
+ queryFn: o,
21
+ enabled: m
22
+ }, e[8] = r, e[9] = o, e[10] = m, e[11] = c) : c = e[11], y(c);
23
+ }, E = (s) => {
24
+ const e = u.c(7);
25
+ let t, n;
26
+ e[0] !== s ? (t = [...a, "comments", s], n = () => i.getComments(s), e[0] = s, e[1] = t, e[2] = n) : (t = e[1], n = e[2]);
27
+ const l = !!s;
28
+ let r;
29
+ return e[3] !== t || e[4] !== n || e[5] !== l ? (r = {
30
+ queryKey: t,
31
+ queryFn: n,
32
+ enabled: l
33
+ }, e[3] = t, e[4] = n, e[5] = l, e[6] = r) : r = e[6], y(r);
34
+ }, d = (s) => {
35
+ const e = u.c(7);
36
+ let t, n;
37
+ e[0] !== s ? (t = [...a, "detail", s], n = () => i.getFeedback(s), e[0] = s, e[1] = t, e[2] = n) : (t = e[1], n = e[2]);
38
+ const l = !!s;
39
+ let r;
40
+ return e[3] !== t || e[4] !== n || e[5] !== l ? (r = {
41
+ queryKey: t,
42
+ queryFn: n,
43
+ enabled: l
44
+ }, e[3] = t, e[4] = n, e[5] = l, e[6] = r) : r = e[6], y(r);
45
+ }, Q = () => {
46
+ const s = u.c(2), e = f();
47
+ let t;
48
+ return s[0] !== e ? (t = {
49
+ mutationFn: p,
50
+ onSuccess: () => {
51
+ e.invalidateQueries({
52
+ queryKey: a
53
+ });
54
+ }
55
+ }, s[0] = e, s[1] = t) : t = s[1], F(t);
56
+ };
57
+ function p(s) {
58
+ return i.createFeedback(s);
59
+ }
60
+ export {
61
+ a as FEEDBACKS_QUERY_KEY,
62
+ Q as useCreateFeedback,
63
+ E as useFeedbackComments,
64
+ d as useFeedbackDetail,
65
+ k as useFeedbacks
66
+ };
67
+ //# 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":"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"}
@@ -0,0 +1,42 @@
1
+ import { c as o } from "../../compiler-runtime-BNHg76kC.js";
2
+ import { useQuery as r, useQueryClient as s, useMutation as u } from "@tanstack/react-query";
3
+ import "axios";
4
+ import { u as n } from "../../user-notifications-DbJeK8gS.js";
5
+ import { FEEDBACKS_QUERY_KEY as a } from "../hooks.feedbacks/index.js";
6
+ const d = () => {
7
+ const t = o.c(1);
8
+ let e;
9
+ return t[0] === Symbol.for("react.memo_cache_sentinel") ? (e = {
10
+ queryKey: ["user-notifications"],
11
+ queryFn: n.getNotifications,
12
+ refetchInterval: 18e4
13
+ }, t[0] = e) : e = t[0], r(e);
14
+ }, p = () => {
15
+ const t = o.c(1);
16
+ let e;
17
+ return t[0] === Symbol.for("react.memo_cache_sentinel") ? (e = {
18
+ queryKey: ["unread-notification-count"],
19
+ queryFn: n.getUnreadNotificationCount
20
+ }, t[0] = e) : e = t[0], r(e);
21
+ }, q = () => {
22
+ const t = o.c(2), e = s();
23
+ let i;
24
+ return t[0] !== e ? (i = {
25
+ mutationFn: n.markAsRead,
26
+ onSuccess: () => {
27
+ e.invalidateQueries({
28
+ queryKey: ["user-notifications"]
29
+ }), e.invalidateQueries({
30
+ queryKey: ["unread-notification-count"]
31
+ }), e.invalidateQueries({
32
+ queryKey: a
33
+ });
34
+ }
35
+ }, t[0] = e, t[1] = i) : i = t[1], u(i);
36
+ };
37
+ export {
38
+ q as useMarkAsRead,
39
+ p as useUnreadNotificationCount,
40
+ d as useUserNotifications
41
+ };
42
+ //# 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":";;;;;AAIO,MAAMA,IAAuBA,MAAA;AAAA,QAAAC,IAAAC,EAAAA,EAAA,CAAA;AAAA,MAAAC;AAAA,SAAAF,EAAA,CAAA,MAAAG,OAAAC,IAAA,2BAAA,KAClBF,IAAA;AAAA,IAAAG,WACH,oBAAoB;AAAA,IAAAC,SAAAC,EAAAC;AAAAA,IAAAC,iBAAA;AAAA,EAAA,GAGhCT,OAAAE,KAAAA,IAAAF,EAAA,CAAA,GAJMU,EAASR,CAIf;AAAC,GAGSS,IAA6BA,MAAA;AAAA,QAAAX,IAAAC,EAAAA,EAAA,CAAA;AAAA,MAAAC;AAAA,SAAAF,EAAA,CAAA,MAAAG,OAAAC,IAAA,2BAAA,KACxBF,IAAA;AAAA,IAAAG,WACH,2BAA2B;AAAA,IAAAC,SAAAC,EAAAK;AAAAA,EAAAA,GAEvCZ,OAAAE,KAAAA,IAAAF,EAAA,CAAA,GAHMU,EAASR,CAGf;AAAC,GAGSW,IAAgBA,MAAA;AAAA,QAAAb,IAAAC,EAAAA,EAAA,CAAA,GAC3Ba,IAAoBC,EAAAA;AAAiB,MAAAb;AAAA,SAAAF,SAAAc,KAClBZ,IAAA;AAAA,IAAAc,YAAAT,EAAAU;AAAAA,IAAAC,WAAAA,MAAA;AAGfJ,MAAAA,EAAWK,kBAAA;AAAA,QAAAd,WAAgC,oBAAoB;AAAA,MAAA,CAAG,GAClES,EAAWK,kBAAA;AAAA,QAAAd,WAAgC,2BAA2B;AAAA,MAAA,CAAG,GACzES,EAAWK,kBAAA;AAAA,QAAAd,UAAAe;AAAAA,MAAAA,CAAoD;AAAA,IAAC;AAAA,EAAA,GAEnEpB,OAAAc,GAAAd,OAAAE,KAAAA,IAAAF,EAAA,CAAA,GAPMqB,EAAYnB,CAOlB;AAAC;"}
@@ -0,0 +1,69 @@
1
+ import f from "axios";
2
+ let t;
3
+ const b = ({
4
+ baseURL: e,
5
+ timeout: s = 12e4,
6
+ withCredentials: o = !0,
7
+ headers: c,
8
+ getAccessToken: i,
9
+ getRefreshAccessToken: p,
10
+ onUnauthorized: u,
11
+ onRefreshTokenSuccess: d,
12
+ ...m
13
+ }) => (t = f.create({
14
+ baseURL: e,
15
+ timeout: s,
16
+ withCredentials: o,
17
+ headers: c || {
18
+ "Content-Type": "application/json"
19
+ },
20
+ ...m
21
+ }), t.interceptors.request.use((a) => {
22
+ const r = i();
23
+ return r && (a.headers.Authorization = `Bearer ${r}`), a;
24
+ }, (a) => Promise.reject(a)), t.interceptors.response.use((a) => a, async (a) => {
25
+ const r = a.config;
26
+ if (r.url?.includes("/auth/login"))
27
+ return Promise.reject(a);
28
+ if (a.response?.status === 401 && !r._retry) {
29
+ r._retry = !0;
30
+ try {
31
+ const n = await p();
32
+ if (!n)
33
+ throw new Error("Failed to refresh access token");
34
+ return r.headers.Authorization = `Bearer ${n}`, d(n), t(r);
35
+ } catch (n) {
36
+ return u(), Promise.reject(n);
37
+ }
38
+ }
39
+ return Promise.reject(a);
40
+ }), t), l = {
41
+ // 피드백 목록 조회 (페이지네이션)
42
+ listFeedbacks: async (e) => (await t.post("/feedbacks/page", {
43
+ page: e.page ?? 1,
44
+ count: e.count ?? 30,
45
+ status: e.status
46
+ })).data,
47
+ // 피드백 상세 조회
48
+ getFeedback: async (e) => (await t.get(`/feedbacks/${e}`)).data,
49
+ // 피드백 생성
50
+ createFeedback: async (e) => (await t.post("/feedbacks", e)).data,
51
+ // 피드백 수정
52
+ updateFeedback: async (e, s) => (await t.put(`/feedbacks/${e}`, s)).data,
53
+ // 피드백 삭제
54
+ deleteFeedback: async (e) => (await t.delete(`/feedbacks/${e}`)).data,
55
+ // 피드백 댓글 목록 조회
56
+ getComments: async (e) => (await t.get(`/feedbacks/${e}/comments`)).data,
57
+ // 피드백 댓글 작성
58
+ createComment: async (e, s) => (await t.post(`/feedbacks/${e}/comments`, s)).data,
59
+ // 피드백 댓글 삭제
60
+ deleteComment: async (e) => (await t.delete(`/feedbacks/comments/${e}`)).data,
61
+ // 피드백 댓글 수정
62
+ updateComment: async (e, s) => (await t.put(`/feedbacks/comments/${e}`, s)).data
63
+ };
64
+ export {
65
+ t as a,
66
+ l as f,
67
+ b as i
68
+ };
69
+ //# sourceMappingURL=feedback-BbDeqNIh.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feedback-BbDeqNIh.js","sources":["../src/api/axios/initialize-axios.ts","../src/api/common/feedback.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 { 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"],"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","feedbackApi","listFeedbacks","params","post","page","count","data","getFeedback","id","get","createFeedback","updateFeedback","put","deleteFeedback","delete","getComments","feedbackId","createComment","deleteComment","commentId","updateComment"],"mappings":";AAWO,IAAIA;AAEJ,MAAMC,IAAkBA,CAAC;AAAA,EAC9BC,SAAAA;AAAAA,EACAC,SAAAA,IAAU;AAAA,EACVC,iBAAAA,IAAkB;AAAA,EAClBC,SAAAA;AAAAA,EACAC,gBAAAA;AAAAA,EACAC,uBAAAA;AAAAA,EACAC,gBAAAA;AAAAA,EACAC,uBAAAA;AAAAA,EACA,GAAGC;AACW,OACdV,IAAYW,EAAMC,OAAO;AAAA,EACvBV,SAAAA;AAAAA,EACAC,SAAAA;AAAAA,EACAC,iBAAAA;AAAAA,EACAC,SAASA,KAAW;AAAA,IAClB,gBAAgB;AAAA,EAAA;AAAA,EAElB,GAAGK;AAAAA,CACJ,GAEDV,EAAUa,aAAaC,QAAQC,IAC5BC,CAAAA,MAAW;AACV,QAAMC,IAAQX,EAAAA;AACd,SAAIW,MACFD,EAAOX,QAAQa,gBAAgB,UAAUD,CAAK,KAEzCD;AACT,GACCG,CAAAA,MACQC,QAAQC,OAAOF,CAAK,CAE/B,GAGAnB,EAAUa,aAAaS,SAASP,IAC7BO,CAAAA,MACQA,GAET,OAAOH,MAAU;AACf,QAAMI,IAAkBJ,EAAMH;AAG9B,MAAIO,EAAgBC,KAAKC,SAAS,aAAa;AAC7C,WAAOL,QAAQC,OAAOF,CAAK;AAG7B,MAAIA,EAAMG,UAAUI,WAAW,OAAO,CAACH,EAAgBI,QAAQ;AAC7DJ,IAAAA,EAAgBI,SAAS;AAEzB,QAAI;AAEF,YAAMC,IAAc,MAAMrB,EAAAA;AAC1B,UAAI,CAACqB;AACH,cAAM,IAAIC,MAAM,gCAAgC;AAGlDN,aAAAA,EAAgBlB,QAAQa,gBAAgB,UAAUU,CAAW,IAC7DnB,EAAsBmB,CAAW,GAC1B5B,EAAUuB,CAAe;AAAA,IAClC,SAASO,GAAc;AAErBtB,aAAAA,EAAAA,GACOY,QAAQC,OAAOS,CAAY;AAAA,IACpC;AAAA,EACF;AAEA,SAAOV,QAAQC,OAAOF,CAAK;AAC7B,CACF,GACOnB,ICxEI+B,IAAc;AAAA;AAAA,EAEzBC,eAAe,OACbC,OAEiB,MAAMjC,EAAUkC,KAC/B,mBACA;AAAA,IACEC,MAAMF,EAAOE,QAAQ;AAAA,IACrBC,OAAOH,EAAOG,SAAS;AAAA,IACvBV,QAAQO,EAAOP;AAAAA,EAAAA,CAEnB,GACgBW;AAAAA;AAAAA,EAIlBC,aAAa,OAAOC,OACD,MAAMvC,EAAUwC,IAAc,cAAcD,CAAE,EAAE,GACjDF;AAAAA;AAAAA,EAIlBI,gBAAgB,OAAOJ,OACJ,MAAMrC,EAAUkC,KAAe,cAAcG,CAAI,GAClDA;AAAAA;AAAAA,EAIlBK,gBAAgB,OACdH,GACAF,OAEiB,MAAMrC,EAAU2C,IAAc,cAAcJ,CAAE,IAAIF,CAAI,GACvDA;AAAAA;AAAAA,EAIlBO,gBAAgB,OAAOL,OACJ,MAAMvC,EAAU6C,OAC/B,cAAcN,CAAE,EAClB,GACgBF;AAAAA;AAAAA,EAIlBS,aAAa,OACXC,OAEiB,MAAM/C,EAAUwC,IAC/B,cAAcO,CAAU,WAC1B,GACgBV;AAAAA;AAAAA,EAIlBW,eAAe,OACbD,GACAV,OAEiB,MAAMrC,EAAUkC,KAC/B,cAAca,CAAU,aACxBV,CACF,GACgBA;AAAAA;AAAAA,EAIlBY,eAAe,OAAOC,OACH,MAAMlD,EAAU6C,OAC/B,uBAAuBK,CAAS,EAClC,GACgBb;AAAAA;AAAAA,EAIlBc,eAAe,OACbD,GACAb,OAEiB,MAAMrC,EAAU2C,IAC/B,uBAAuBO,CAAS,IAChCb,CACF,GACgBA;AAEpB;"}
@@ -0,0 +1,2 @@
1
+ "use strict";const l=require("axios");exports.apiClient=void 0;const C=({baseURL:e,timeout:t=12e4,withCredentials:r=!0,headers:i,getAccessToken:o,getRefreshAccessToken:c,onUnauthorized:p,onRefreshTokenSuccess:u,...d})=>(exports.apiClient=l.create({baseURL:e,timeout:t,withCredentials:r,headers:i||{"Content-Type":"application/json"},...d}),exports.apiClient.interceptors.request.use(s=>{const a=o();return a&&(s.headers.Authorization=`Bearer ${a}`),s},s=>Promise.reject(s)),exports.apiClient.interceptors.response.use(s=>s,async s=>{const a=s.config;if(a.url?.includes("/auth/login"))return Promise.reject(s);if(s.response?.status===401&&!a._retry){a._retry=!0;try{const n=await c();if(!n)throw new Error("Failed to refresh access token");return a.headers.Authorization=`Bearer ${n}`,u(n),exports.apiClient(a)}catch(n){return p(),Promise.reject(n)}}return Promise.reject(s)}),exports.apiClient),k={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};exports.feedbackApi=k;exports.initializeAxios=C;
2
+ //# sourceMappingURL=feedback-xoeZc8ns.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feedback-xoeZc8ns.cjs","sources":["../src/api/axios/initialize-axios.ts","../src/api/common/feedback.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 { 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"],"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","feedbackApi","listFeedbacks","params","post","page","count","data","getFeedback","id","get","createFeedback","updateFeedback","put","deleteFeedback","delete","getComments","feedbackId","createComment","deleteComment","commentId","updateComment"],"mappings":"sCAWWA,QAAAA,UAAAA,OAEJ,MAAMC,EAAkBA,CAAC,CAC9BC,QAAAA,EACAC,QAAAA,EAAU,KACVC,gBAAAA,EAAkB,GAClBC,QAAAA,EACAC,eAAAA,EACAC,sBAAAA,EACAC,eAAAA,EACAC,sBAAAA,EACA,GAAGC,CACW,KACdV,QAAAA,UAAYW,EAAMC,OAAO,CACvBV,QAAAA,EACAC,QAAAA,EACAC,gBAAAA,EACAC,QAASA,GAAW,CAClB,eAAgB,kBAAA,EAElB,GAAGK,CAAAA,CACJ,EAEDV,QAAAA,UAAUa,aAAaC,QAAQC,IAC5BC,GAAW,CACV,MAAMC,EAAQX,EAAAA,EACd,OAAIW,IACFD,EAAOX,QAAQa,cAAgB,UAAUD,CAAK,IAEzCD,CACT,EACCG,GACQC,QAAQC,OAAOF,CAAK,CAE/B,EAGAnB,QAAAA,UAAUa,aAAaS,SAASP,IAC7BO,GACQA,EAET,MAAOH,GAAU,CACf,MAAMI,EAAkBJ,EAAMH,OAG9B,GAAIO,EAAgBC,KAAKC,SAAS,aAAa,EAC7C,OAAOL,QAAQC,OAAOF,CAAK,EAG7B,GAAIA,EAAMG,UAAUI,SAAW,KAAO,CAACH,EAAgBI,OAAQ,CAC7DJ,EAAgBI,OAAS,GAEzB,GAAI,CAEF,MAAMC,EAAc,MAAMrB,EAAAA,EAC1B,GAAI,CAACqB,EACH,MAAM,IAAIC,MAAM,gCAAgC,EAGlDN,OAAAA,EAAgBlB,QAAQa,cAAgB,UAAUU,CAAW,GAC7DnB,EAAsBmB,CAAW,EAC1B5B,QAAAA,UAAUuB,CAAe,CAClC,OAASO,EAAc,CAErBtB,OAAAA,EAAAA,EACOY,QAAQC,OAAOS,CAAY,CACpC,CACF,CAEA,OAAOV,QAAQC,OAAOF,CAAK,CAC7B,CACF,EACOnB,QAAAA,WCxEI+B,EAAc,CAEzBC,cAAe,MACbC,IAEiB,MAAMjC,kBAAUkC,KAC/B,kBACA,CACEC,KAAMF,EAAOE,MAAQ,EACrBC,MAAOH,EAAOG,OAAS,GACvBV,OAAQO,EAAOP,MAAAA,CAEnB,GACgBW,KAIlBC,YAAa,MAAOC,IACD,MAAMvC,kBAAUwC,IAAc,cAAcD,CAAE,EAAE,GACjDF,KAIlBI,eAAgB,MAAOJ,IACJ,MAAMrC,QAAAA,UAAUkC,KAAe,aAAcG,CAAI,GAClDA,KAIlBK,eAAgB,MACdH,EACAF,KAEiB,MAAMrC,QAAAA,UAAU2C,IAAc,cAAcJ,CAAE,GAAIF,CAAI,GACvDA,KAIlBO,eAAgB,MAAOL,IACJ,MAAMvC,kBAAU6C,OAC/B,cAAcN,CAAE,EAClB,GACgBF,KAIlBS,YAAa,MACXC,IAEiB,MAAM/C,kBAAUwC,IAC/B,cAAcO,CAAU,WAC1B,GACgBV,KAIlBW,cAAe,MACbD,EACAV,KAEiB,MAAMrC,QAAAA,UAAUkC,KAC/B,cAAca,CAAU,YACxBV,CACF,GACgBA,KAIlBY,cAAe,MAAOC,IACH,MAAMlD,kBAAU6C,OAC/B,uBAAuBK,CAAS,EAClC,GACgBb,KAIlBc,cAAe,MACbD,EACAb,KAEiB,MAAMrC,QAAAA,UAAU2C,IAC/B,uBAAuBO,CAAS,GAChCb,CACF,GACgBA,IAEpB"}
@@ -0,0 +1,10 @@
1
+ import { CreateFeedbackRequest, FeedbackListRequest } from '@clickcns/vmedic-react/types';
2
+ export declare const FEEDBACKS_QUERY_KEY: string[];
3
+ interface UseFeedbacksParams extends FeedbackListRequest {
4
+ enabled?: boolean;
5
+ }
6
+ export declare const useFeedbacks: ({ enabled, ...params }?: UseFeedbacksParams) => import('@tanstack/react-query').UseQueryResult<import('../../types').FeedbackListResponse, Error>;
7
+ export declare const useFeedbackComments: (feedbackId: string | null) => import('@tanstack/react-query').UseQueryResult<import('../../types').FeedbackCommentsResponse, Error>;
8
+ export declare const useFeedbackDetail: (id: string | null) => import('@tanstack/react-query').UseQueryResult<import('../../types').Feedback, Error>;
9
+ export declare const useCreateFeedback: () => import('@tanstack/react-query').UseMutationResult<import('../../types').Feedback, Error, CreateFeedbackRequest, unknown>;
10
+ export {};
@@ -0,0 +1,7 @@
1
+ export declare const useUserNotifications: () => import('@tanstack/react-query').UseQueryResult<import('../../types').UserNotificationListResponse, Error>;
2
+ export declare const useUnreadNotificationCount: () => import('@tanstack/react-query').UseQueryResult<{
3
+ count: number;
4
+ }, Error>;
5
+ export declare const useMarkAsRead: () => import('@tanstack/react-query').UseMutationResult<void, Error, {
6
+ targetId: string;
7
+ }, unknown>;
@@ -1,6 +1,6 @@
1
1
  import * as ResizablePrimitive from "react-resizable-panels";
2
2
  declare const ResizablePanelGroup: ({ className, ...props }: React.ComponentProps<typeof ResizablePrimitive.PanelGroup>) => import("react/jsx-runtime").JSX.Element;
3
- declare const ResizablePanel: import('react').ForwardRefExoticComponent<Omit<import('react').HTMLAttributes<HTMLButtonElement | HTMLElement | HTMLInputElement | HTMLObjectElement | HTMLDataElement | HTMLHeadElement | HTMLLinkElement | HTMLLabelElement | HTMLAnchorElement | HTMLAreaElement | HTMLAudioElement | HTMLBaseElement | HTMLQuoteElement | HTMLBodyElement | HTMLBRElement | HTMLCanvasElement | HTMLTableColElement | HTMLDataListElement | HTMLModElement | HTMLDetailsElement | HTMLDialogElement | HTMLDivElement | HTMLDListElement | HTMLEmbedElement | HTMLFieldSetElement | HTMLFormElement | HTMLHeadingElement | HTMLHRElement | HTMLHtmlElement | HTMLIFrameElement | HTMLImageElement | HTMLLegendElement | HTMLLIElement | HTMLMapElement | HTMLMetaElement | HTMLMeterElement | HTMLOListElement | HTMLOptGroupElement | HTMLOptionElement | HTMLOutputElement | HTMLParagraphElement | HTMLPreElement | HTMLProgressElement | HTMLSlotElement | HTMLScriptElement | HTMLSelectElement | HTMLSourceElement | HTMLSpanElement | HTMLStyleElement | HTMLTableElement | HTMLTemplateElement | HTMLTableSectionElement | HTMLTableCellElement | HTMLTextAreaElement | HTMLTimeElement | HTMLTitleElement | HTMLTableRowElement | HTMLTrackElement | HTMLUListElement | HTMLVideoElement | HTMLTableCaptionElement | HTMLMenuElement | HTMLPictureElement>, "id" | "onResize"> & {
3
+ declare const ResizablePanel: import('react').ForwardRefExoticComponent<Omit<import('react').HTMLAttributes<HTMLButtonElement | HTMLElement | HTMLInputElement | HTMLObjectElement | HTMLDataElement | HTMLHeadElement | HTMLLinkElement | HTMLLabelElement | HTMLMapElement | HTMLAnchorElement | HTMLAreaElement | HTMLAudioElement | HTMLBaseElement | HTMLQuoteElement | HTMLBodyElement | HTMLBRElement | HTMLCanvasElement | HTMLTableColElement | HTMLDataListElement | HTMLModElement | HTMLDetailsElement | HTMLDialogElement | HTMLDivElement | HTMLDListElement | HTMLEmbedElement | HTMLFieldSetElement | HTMLFormElement | HTMLHeadingElement | HTMLHRElement | HTMLHtmlElement | HTMLIFrameElement | HTMLImageElement | HTMLLegendElement | HTMLLIElement | HTMLMetaElement | HTMLMeterElement | HTMLOListElement | HTMLOptGroupElement | HTMLOptionElement | HTMLOutputElement | HTMLParagraphElement | HTMLPreElement | HTMLProgressElement | HTMLSlotElement | HTMLScriptElement | HTMLSelectElement | HTMLSourceElement | HTMLSpanElement | HTMLStyleElement | HTMLTableElement | HTMLTemplateElement | HTMLTableSectionElement | HTMLTableCellElement | HTMLTextAreaElement | HTMLTimeElement | HTMLTitleElement | HTMLTableRowElement | HTMLTrackElement | HTMLUListElement | HTMLVideoElement | HTMLTableCaptionElement | HTMLMenuElement | HTMLPictureElement>, "id" | "onResize"> & {
4
4
  className?: string;
5
5
  collapsedSize?: number | undefined;
6
6
  collapsible?: boolean | undefined;
@@ -11,15 +11,18 @@ export interface FeedbackDetail {
11
11
  export interface Feedback {
12
12
  id: string;
13
13
  userId: string;
14
- status: 'pending' | 'resolved';
14
+ status: "pending" | "resolved";
15
15
  userName: string;
16
16
  institutionName: string | null;
17
17
  createdAt: string;
18
18
  updatedAt: string;
19
19
  feedbackDetail: FeedbackDetail;
20
20
  }
21
+ export interface FeedbackExtended extends Feedback {
22
+ unreadNotificationCount: number;
23
+ }
21
24
  export interface FeedbackListResponse {
22
- feedbacks: Feedback[];
25
+ feedbacks: FeedbackExtended[];
23
26
  currentPage: number;
24
27
  totalPages: number;
25
28
  totalCount: number;
@@ -27,7 +30,7 @@ export interface FeedbackListResponse {
27
30
  export interface FeedbackListRequest {
28
31
  page?: number;
29
32
  count?: number;
30
- status?: 'pending' | 'resolved';
33
+ status?: "pending" | "resolved";
31
34
  }
32
35
  export interface CreateFeedbackRequest {
33
36
  feedbackDetail: {
@@ -11,3 +11,4 @@ export * from './user-setting';
11
11
  export * from './llm';
12
12
  export * from './push';
13
13
  export * from './partners';
14
+ export * from './notifications';
@@ -0,0 +1,11 @@
1
+ export interface UserNotification {
2
+ id: string;
3
+ userId: string;
4
+ targetId: string;
5
+ targetType: "feedback" | "notice";
6
+ title: string;
7
+ isRead: boolean;
8
+ createdAt: string;
9
+ }
10
+ export interface UserNotificationListResponse extends Array<UserNotification> {
11
+ }
@@ -0,0 +1,10 @@
1
+ import { a } from "./feedback-BbDeqNIh.js";
2
+ const e = {
3
+ getNotifications: async () => (await a.get("/user-notifications")).data,
4
+ markAsRead: async (t) => (await a.patch("/user-notifications/mark/read", t)).data,
5
+ getUnreadNotificationCount: async () => (await a.get("/user-notifications/unread/count")).data
6
+ };
7
+ export {
8
+ e as u
9
+ };
10
+ //# sourceMappingURL=user-notifications-DbJeK8gS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-notifications-DbJeK8gS.js","sources":["../src/api/common/user-notifications.ts"],"sourcesContent":["import type { UserNotificationListResponse } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const userNotificationsApi = {\r\n getNotifications: async (): Promise<UserNotificationListResponse> => {\r\n const response = await apiClient.get(\"/user-notifications\");\r\n return response.data;\r\n },\r\n\r\n markAsRead: async (request: { targetId: string }): Promise<void> => {\r\n const response = await apiClient.patch(`/user-notifications/mark/read`, request);\r\n return response.data;\r\n },\r\n\r\n getUnreadNotificationCount: async (): Promise<{ count: number }> => {\r\n const response = await apiClient.get(\"/user-notifications/unread/count\");\r\n return response.data;\r\n },\r\n};\r\n"],"names":["userNotificationsApi","getNotifications","apiClient","get","data","markAsRead","request","patch","getUnreadNotificationCount"],"mappings":";AAGO,MAAMA,IAAuB;AAAA,EAClCC,kBAAkB,aACC,MAAMC,EAAUC,IAAI,qBAAqB,GAC1CC;AAAAA,EAGlBC,YAAY,OAAOC,OACA,MAAMJ,EAAUK,MAAM,iCAAiCD,CAAO,GAC/DF;AAAAA,EAGlBI,4BAA4B,aACT,MAAMN,EAAUC,IAAI,kCAAkC,GACvDC;AAEpB;"}
@@ -0,0 +1,2 @@
1
+ "use strict";const e=require("./feedback-xoeZc8ns.cjs"),i={getNotifications:async()=>(await e.apiClient.get("/user-notifications")).data,markAsRead:async t=>(await e.apiClient.patch("/user-notifications/mark/read",t)).data,getUnreadNotificationCount:async()=>(await e.apiClient.get("/user-notifications/unread/count")).data};exports.userNotificationsApi=i;
2
+ //# sourceMappingURL=user-notifications-eaEdb3_1.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-notifications-eaEdb3_1.cjs","sources":["../src/api/common/user-notifications.ts"],"sourcesContent":["import type { UserNotificationListResponse } from \"../../types\";\r\nimport { apiClient } from \"../axios\";\r\n\r\nexport const userNotificationsApi = {\r\n getNotifications: async (): Promise<UserNotificationListResponse> => {\r\n const response = await apiClient.get(\"/user-notifications\");\r\n return response.data;\r\n },\r\n\r\n markAsRead: async (request: { targetId: string }): Promise<void> => {\r\n const response = await apiClient.patch(`/user-notifications/mark/read`, request);\r\n return response.data;\r\n },\r\n\r\n getUnreadNotificationCount: async (): Promise<{ count: number }> => {\r\n const response = await apiClient.get(\"/user-notifications/unread/count\");\r\n return response.data;\r\n },\r\n};\r\n"],"names":["userNotificationsApi","getNotifications","apiClient","get","data","markAsRead","request","patch","getUnreadNotificationCount"],"mappings":"wDAGaA,EAAuB,CAClCC,iBAAkB,UACC,MAAMC,YAAUC,IAAI,qBAAqB,GAC1CC,KAGlBC,WAAY,MAAOC,IACA,MAAMJ,EAAAA,UAAUK,MAAM,gCAAiCD,CAAO,GAC/DF,KAGlBI,2BAA4B,UACT,MAAMN,YAAUC,IAAI,kCAAkC,GACvDC,IAEpB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@clickcns/vmedic-react",
3
- "version": "0.0.7",
3
+ "version": "0.0.9",
4
4
  "description": "A collection of powerful utilities and components built with React and Vite",
5
5
  "author": "clickcns",
6
6
  "license": "MIT",
@@ -41,6 +41,21 @@
41
41
  "types": "./dist/shadcn-ui/index.d.ts",
42
42
  "import": "./dist/es/shadcn-ui/index.js",
43
43
  "require": "./dist/cjs/shadcn-ui/index.js"
44
+ },
45
+ "./hooks": {
46
+ "types": "./dist/hooks/index.d.ts",
47
+ "import": "./dist/es/hooks/index.js",
48
+ "require": "./dist/cjs/hooks/index.js"
49
+ },
50
+ "./hooks.user-notifications": {
51
+ "types": "./dist/hooks.user-notifications/index.d.ts",
52
+ "import": "./dist/es/hooks.user-notifications/index.js",
53
+ "require": "./dist/cjs/hooks.user-notifications/index.js"
54
+ },
55
+ "./hooks.feedbacks": {
56
+ "types": "./dist/hooks.feedbacks/index.d.ts",
57
+ "import": "./dist/es/hooks.feedbacks/index.js",
58
+ "require": "./dist/cjs/hooks.feedbacks/index.js"
44
59
  }
45
60
  },
46
61
  "files": [