@glodon-aiot/chat-app-sdk 0.0.12 → 0.0.14

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.
package/es/index.esm.js CHANGED
@@ -9304,6 +9304,12 @@ ___CSS_LOADER_EXPORT___.push([module.id, `:root {
9304
9304
  .coze-chat-sdk :is(.font-normal) {
9305
9305
  font-weight: 400;
9306
9306
  }
9307
+ .coze-chat-sdk :is(.uppercase) {
9308
+ text-transform: uppercase;
9309
+ }
9310
+ .coze-chat-sdk :is(.lowercase) {
9311
+ text-transform: lowercase;
9312
+ }
9307
9313
  .coze-chat-sdk :is(.\\!leading-28px) {
9308
9314
  line-height: var(--coze-28) !important;
9309
9315
  }
@@ -10788,6 +10794,16 @@ ___CSS_LOADER_EXPORT___.push([module.id, `.c8c142b9ad89b1ac {
10788
10794
  margin-left: auto;
10789
10795
  color: #6B6B75;
10790
10796
  }
10797
+ .c8c142b9ad89b1ac .fc5357218ceb1c78:hover {
10798
+ background-color: transparent !important;
10799
+ }
10800
+ .c8c142b9ad89b1ac .f07e95aab0abcc5a {
10801
+ margin-left: auto;
10802
+ color: #6B6B75;
10803
+ }
10804
+ .c8c142b9ad89b1ac .f07e95aab0abcc5a:hover {
10805
+ background-color: transparent !important;
10806
+ }
10791
10807
  .a513b83ef65c6e47 .ae3efd63d21216ca {
10792
10808
  opacity: 0.4;
10793
10809
  }
@@ -10824,6 +10840,8 @@ ___CSS_LOADER_EXPORT___.locals = {
10824
10840
  "fileText": `d8de5ac7f79d78ac`,
10825
10841
  "retry-button": `fc5357218ceb1c78`,
10826
10842
  "retryButton": `fc5357218ceb1c78`,
10843
+ "preview-button": `f07e95aab0abcc5a`,
10844
+ "previewButton": `f07e95aab0abcc5a`,
10827
10845
  "normal-file-not-success": `a513b83ef65c6e47`,
10828
10846
  "normalFileNotSuccess": `a513b83ef65c6e47`,
10829
10847
  "file-error-text": `b91da080705f8042`,
@@ -12911,6 +12929,9 @@ var ___CSS_LOADER_EXPORT___ = _common_temp_default_node_modules_pnpm_css_loader_
12911
12929
  ___CSS_LOADER_EXPORT___.push([module.id, `.chat-uikit-file-card-progress-animation {
12912
12930
  transition: width 0.3s linear;
12913
12931
  }
12932
+ .chat-uikit-file-card__preview-button:hover {
12933
+ background: transparent !important;
12934
+ }
12914
12935
  `, ""]);
12915
12936
  // Exports
12916
12937
  /* ESM default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
@@ -14984,6 +15005,7 @@ ___CSS_LOADER_EXPORT___.push([module.id, `.f93f377f7f3466bb {
14984
15005
  .f93f377f7f3466bb .a78675f9ead11e1c {
14985
15006
  flex: 1 1 auto;
14986
15007
  min-height: 0;
15008
+ position: relative;
14987
15009
  }
14988
15010
  `, ""]);
14989
15011
  // Exports
@@ -15126,15 +15148,38 @@ ___CSS_LOADER_EXPORT___.push([module.id, `.f86baf679567ad27 {
15126
15148
  align-self: stretch;
15127
15149
  border-radius: var(--mini, 5px);
15128
15150
  cursor: pointer;
15151
+ position: relative;
15129
15152
  }
15130
- .b604f7d22988c3dd .d81b38a3a3378ade {
15131
- display: none;
15153
+ .b604f7d22988c3dd .f4df3ee0cadb5d32 {
15154
+ position: absolute;
15155
+ right: 8px;
15156
+ top: 50%;
15157
+ transform: translateY(-50%);
15158
+ opacity: 0;
15159
+ pointer-events: none;
15160
+ transition: opacity 0.2s;
15161
+ width: auto;
15162
+ min-width: 0;
15163
+ flex-shrink: 0;
15164
+ display: flex;
15165
+ align-items: center;
15166
+ justify-content: center;
15167
+ }
15168
+ .b604f7d22988c3dd .def35156ce4da8d3 {
15169
+ width: auto;
15170
+ min-width: 0;
15171
+ flex-shrink: 0;
15172
+ background: #F1F1F1 !important;
15173
+ }
15174
+ .b604f7d22988c3dd .def35156ce4da8d3:hover {
15175
+ background: #DFDFDF !important;
15132
15176
  }
15133
15177
  .b604f7d22988c3dd:hover {
15134
15178
  background: #F1F1F1;
15135
15179
  }
15136
- .b604f7d22988c3dd:hover .d81b38a3a3378ade {
15137
- display: block;
15180
+ .b604f7d22988c3dd:hover .f4df3ee0cadb5d32 {
15181
+ opacity: 1;
15182
+ pointer-events: auto;
15138
15183
  }
15139
15184
  .d20070d79d26fc4c {
15140
15185
  background: #DFDFDF;
@@ -15148,8 +15193,10 @@ ___CSS_LOADER_EXPORT___.locals = {
15148
15193
  "conversationItemTime": `a333a6f519d76789`,
15149
15194
  "conversation-item-content": `b604f7d22988c3dd`,
15150
15195
  "conversationItemContent": `b604f7d22988c3dd`,
15151
- "conversation-operate": `d81b38a3a3378ade`,
15152
- "conversationOperate": `d81b38a3a3378ade`,
15196
+ "conversation-operate-wrapper": `f4df3ee0cadb5d32`,
15197
+ "conversationOperateWrapper": `f4df3ee0cadb5d32`,
15198
+ "conversation-operate-button": `def35156ce4da8d3`,
15199
+ "conversationOperateButton": `def35156ce4da8d3`,
15153
15200
  "conversation-item-content-active": `d20070d79d26fc4c`,
15154
15201
  "conversationItemContentActive": `d20070d79d26fc4c`
15155
15202
  };
@@ -15640,6 +15687,8 @@ ___CSS_LOADER_EXPORT___.push([module.id, `.c64c9a8ea4a38e72 {
15640
15687
  width: 100%;
15641
15688
  height: 100%;
15642
15689
  min-height: 0;
15690
+ padding-bottom: 34px;
15691
+ box-sizing: border-box;
15643
15692
  }
15644
15693
  .c5a6e169fa0cf192 * {
15645
15694
  box-sizing: border-box;
@@ -267629,10 +267678,11 @@ class PreSendLocalMessageFactory {
267629
267678
  /**
267630
267679
  * Update image message content
267631
267680
  */ updateImageMessageContent(message, uploadResult) {
267632
- const { Uri = '', Url = '', ImageWidth = 0, ImageHeight = 0 } = uploadResult;
267681
+ const { Uri = '', Url = '', ImageWidth = 0, ImageHeight = 0, Id } = uploadResult;
267633
267682
  message.content_obj.image_list[0] = {
267634
267683
  ...message.content_obj.image_list[0],
267635
267684
  key: Uri,
267685
+ id: Id,
267636
267686
  image_thumb: {
267637
267687
  ...message.content_obj.image_list[0].image_thumb,
267638
267688
  width: ImageWidth,
@@ -267651,8 +267701,9 @@ class PreSendLocalMessageFactory {
267651
267701
  /**
267652
267702
  * Update file message content
267653
267703
  */ updateFileMessageContent(message, uploadResult) {
267654
- const { Uri = '', Url = '' } = uploadResult;
267655
- message.content_obj.file_list[0].file_key = Uri;
267704
+ const { Uri = '', Url = '', Id } = uploadResult;
267705
+ message.content_obj.file_list[0].file_key = Uri; // URI for URL generation/viewing
267706
+ message.content_obj.file_list[0].file_id = Id; // Backend file ID for file_id in API calls
267656
267707
  message.content_obj.file_list[0].file_url = Url;
267657
267708
  message.content = JSON.stringify(message.content_obj);
267658
267709
  }
@@ -267700,6 +267751,7 @@ class PreSendLocalMessageFactory {
267700
267751
  type,
267701
267752
  file: {
267702
267753
  file_key: item.uri,
267754
+ file_id: item.id,
267703
267755
  file_name: item.file.name,
267704
267756
  file_type: fileType,
267705
267757
  file_size: item.file.size,
@@ -267713,6 +267765,7 @@ class PreSendLocalMessageFactory {
267713
267765
  type,
267714
267766
  image: {
267715
267767
  key: item.uri,
267768
+ id: item.id,
267716
267769
  image_thumb: {
267717
267770
  url: blobUrl,
267718
267771
  width: item.width,
@@ -271591,6 +271644,7 @@ class ChatCoreUploadPlugin {
271591
271644
  }
271592
271645
  });
271593
271646
  this.dataAuth = dataAuth.data || {};
271647
+ // DataAuth structure may vary, using any for flexibility
271594
271648
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
271595
271649
  const { service_id, upload_host, schema } = this.dataAuth || {};
271596
271650
  this.uploader = getUploader({
@@ -271608,6 +271662,29 @@ class ChatCoreUploadPlugin {
271608
271662
  }, false);
271609
271663
  this.addFile(this.uploaderConfig.file, this.uploaderConfig.type);
271610
271664
  this.uploader.on('complete', (info)=>{
271665
+ const extendedInfo = info;
271666
+ // Try to extract raw backend data from info object
271667
+ let backendData = null;
271668
+ if (extendedInfo.task) {
271669
+ var _extendedInfo_task_response, _extendedInfo_task_responseData, _extendedInfo_task__response, _extendedInfo_task_rawResponse;
271670
+ backendData = ((_extendedInfo_task_response = extendedInfo.task.response) === null || _extendedInfo_task_response === void 0 ? void 0 : _extendedInfo_task_response.data) || ((_extendedInfo_task_responseData = extendedInfo.task.responseData) === null || _extendedInfo_task_responseData === void 0 ? void 0 : _extendedInfo_task_responseData.data) || ((_extendedInfo_task__response = extendedInfo.task._response) === null || _extendedInfo_task__response === void 0 ? void 0 : _extendedInfo_task__response.data) || ((_extendedInfo_task_rawResponse = extendedInfo.task.rawResponse) === null || _extendedInfo_task_rawResponse === void 0 ? void 0 : _extendedInfo_task_rawResponse.data) || extendedInfo.task.data || null;
271671
+ }
271672
+ if (!backendData) {
271673
+ var _extendedInfo_response, _extendedInfo_result;
271674
+ backendData = extendedInfo.data || ((_extendedInfo_response = extendedInfo.response) === null || _extendedInfo_response === void 0 ? void 0 : _extendedInfo_response.data) || extendedInfo.responseData || ((_extendedInfo_result = extendedInfo.result) === null || _extendedInfo_result === void 0 ? void 0 : _extendedInfo_result.data) || null;
271675
+ }
271676
+ // If we found raw backend data, add uri and id to uploadResult
271677
+ if (backendData && extendedInfo.uploadResult) {
271678
+ if (backendData.uri) {
271679
+ extendedInfo.uploadResult.Uri = backendData.uri;
271680
+ }
271681
+ if (backendData.id) {
271682
+ extendedInfo.uploadResult.Id = backendData.id;
271683
+ }
271684
+ if (backendData.url) {
271685
+ extendedInfo.uploadResult.Url = backendData.url;
271686
+ }
271687
+ }
271611
271688
  this.eventBus.emit('complete', info);
271612
271689
  });
271613
271690
  this.uploader.on('progress', (info)=>{
@@ -271616,9 +271693,6 @@ class ChatCoreUploadPlugin {
271616
271693
  this.uploader.on('error', (info)=>{
271617
271694
  this.eventBus.emit('error', info);
271618
271695
  });
271619
- this.uploader.on('complete', (info)=>{
271620
- this.eventBus.emit('complete', info);
271621
- });
271622
271696
  this.uploader.start();
271623
271697
  } catch (e) {
271624
271698
  safeAsyncThrow(`upload-plugin error: ${e instanceof Error ? e.message : String(e)}`);
@@ -296996,7 +297070,13 @@ const TextItemList = (param)=>{
296996
297070
  showBackground
296997
297071
  }),
296998
297072
  style: {
296999
- width: 'fit-content'
297073
+ width: 'fit-content',
297074
+ marginLeft: 'auto',
297075
+ // mix-content 内的文本内容应该和纯文本消息使用相同的样式
297076
+ background: '#F4F4F4',
297077
+ padding: '10px',
297078
+ borderRadius: '10px 0 10px 10px',
297079
+ textAlign: 'right'
297000
297080
  },
297001
297081
  children: [
297002
297082
  TextContentAddonTop,
@@ -297823,6 +297903,129 @@ UIKitTooltip.displayName = 'UIKitTooltip';
297823
297903
  return `${digit} ${sizes[i]}`;
297824
297904
  };
297825
297905
 
297906
+ ;// CONCATENATED MODULE: ../../../common/chat-area/chat-uikit/src/hooks/use-doc-viewer-config.ts
297907
+ /*
297908
+ * Copyright 2025 coze-dev Authors
297909
+ *
297910
+ * Licensed under the Apache License, Version 2.0 (the "License");
297911
+ * you may not use this file except in compliance with the License.
297912
+ * You may obtain a copy of the License at
297913
+ *
297914
+ * http://www.apache.org/licenses/LICENSE-2.0
297915
+ *
297916
+ * Unless required by applicable law or agreed to in writing, software
297917
+ * distributed under the License is distributed on an "AS IS" BASIS,
297918
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
297919
+ * See the License for the specific language governing permissions and
297920
+ * limitations under the License.
297921
+ */ // Try to import useChatAppProps and useChatAppStore from open-chat if available
297922
+
297923
+
297924
+
297925
+ let useChatAppProps = null;
297926
+ let useChatAppStore = null;
297927
+ try {
297928
+ // Dynamic import, module may not be available
297929
+ // eslint-disable-next-line @typescript-eslint/no-require-imports -- Dynamic require needed for optional dependency
297930
+ const openChatModule = __webpack_require__(Object(function webpackMissingModule() { var e = new Error("Cannot find module '@coze-studio/open-chat'"); e.code = 'MODULE_NOT_FOUND'; throw e; }()));
297931
+ // eslint-disable-next-line prefer-destructuring -- Direct assignment needed for conditional hook usage
297932
+ useChatAppProps = openChatModule.useChatAppProps;
297933
+ // eslint-disable-next-line prefer-destructuring -- Direct assignment needed for conditional hook usage
297934
+ useChatAppStore = openChatModule.useChatAppStore;
297935
+ } catch (error) {
297936
+ // Module not available, will use default values
297937
+ // Error is expected when module is not available, so we can safely ignore it
297938
+ if (false) {}
297939
+ }
297940
+ /**
297941
+ * Parse domain and productCode from apiUrl
297942
+ * apiUrl format: 域名/api/productCode/flow
297943
+ * Example: https://aiot-dev.glodon.com/api/cvforce/flow
297944
+ * Returns: { domain: 'https://aiot-dev.glodon.com', productCode: 'cvforce' }
297945
+ */ const parseApiUrl = (apiUrl)=>{
297946
+ const defaultDomain = 'https://aiot-dev.glodon.com';
297947
+ const defaultProductCode = 'cvforcepd';
297948
+ if (!apiUrl) {
297949
+ return {
297950
+ domain: defaultDomain,
297951
+ productCode: defaultProductCode
297952
+ };
297953
+ }
297954
+ try {
297955
+ // Parse URL: 域名/api/productCode/flow
297956
+ const url = new URL(apiUrl);
297957
+ const domain = `${url.protocol}//${url.host}`;
297958
+ const pathParts = url.pathname.split('/').filter(Boolean);
297959
+ // Find 'api' in path and get the next part as productCode
297960
+ const apiIndex = pathParts.indexOf('api');
297961
+ if (apiIndex >= 0 && apiIndex < pathParts.length - 1) {
297962
+ const productCode = pathParts[apiIndex + 1];
297963
+ return {
297964
+ domain,
297965
+ productCode
297966
+ };
297967
+ }
297968
+ } catch (urlError) {
297969
+ // If URL parsing fails, try regex
297970
+ const match = apiUrl.match(/^(https?:\/\/[^\/]+)\/api\/([^\/]+)\//);
297971
+ if (match) {
297972
+ return {
297973
+ domain: match[1],
297974
+ productCode: match[2]
297975
+ };
297976
+ }
297977
+ // If regex also fails, log in development mode
297978
+ if (false) {}
297979
+ }
297980
+ return {
297981
+ domain: defaultDomain,
297982
+ productCode: defaultProductCode
297983
+ };
297984
+ };
297985
+ /**
297986
+ * Build default doc viewer URL from apiUrl
297987
+ * Format: 域名/portal/_/productCode/doc-viewer/
297988
+ * Example: https://aiot-dev.glodon.com/api/cvforce/flow -> https://aiot-dev.glodon.com/portal/_/cvforce/doc-viewer/
297989
+ */ const buildDefaultDocViewerUrl = (apiUrl)=>{
297990
+ const { domain, productCode } = parseApiUrl(apiUrl);
297991
+ return `${domain}/portal/_/${productCode}/doc-viewer/`;
297992
+ };
297993
+ /**
297994
+ * Get document viewer configuration from SDK config
297995
+ * Falls back to default values parsed from apiUrl if SDK config is not available
297996
+ */ const useDocViewerConfig = ()=>{
297997
+ let docViewerConfig;
297998
+ let apiUrl;
297999
+ // These hooks are dynamically imported and may not be available
298000
+ if (useChatAppProps) {
298001
+ try {
298002
+ var _chatConfigResult_chatConfig_extra, _chatConfigResult_chatConfig;
298003
+ // eslint-disable-next-line react-hooks/rules-of-hooks -- Hook is conditionally available
298004
+ const chatConfigResult = useChatAppProps();
298005
+ docViewerConfig = chatConfigResult === null || chatConfigResult === void 0 ? void 0 : (_chatConfigResult_chatConfig = chatConfigResult.chatConfig) === null || _chatConfigResult_chatConfig === void 0 ? void 0 : (_chatConfigResult_chatConfig_extra = _chatConfigResult_chatConfig.extra) === null || _chatConfigResult_chatConfig_extra === void 0 ? void 0 : _chatConfigResult_chatConfig_extra.docViewer;
298006
+ } catch (hookError) {
298007
+ // Hook not available in this context, use defaults
298008
+ if (false) {}
298009
+ }
298010
+ }
298011
+ if (useChatAppStore) {
298012
+ try {
298013
+ // eslint-disable-next-line react-hooks/rules-of-hooks -- Hook is conditionally available
298014
+ apiUrl = useChatAppStore((state)=>state.apiUrl);
298015
+ } catch (storeError) {
298016
+ // Store not available in this context, use defaults
298017
+ if (false) {}
298018
+ }
298019
+ }
298020
+ // Default values: use config if provided, otherwise parse from apiUrl
298021
+ const baseUrl = (docViewerConfig === null || docViewerConfig === void 0 ? void 0 : docViewerConfig.baseUrl) || buildDefaultDocViewerUrl(apiUrl);
298022
+ const urlParam = (docViewerConfig === null || docViewerConfig === void 0 ? void 0 : docViewerConfig.urlParam) || 'url';
298023
+ return {
298024
+ baseUrl,
298025
+ urlParam
298026
+ };
298027
+ };
298028
+
297826
298029
  ;// CONCATENATED MODULE: ../../../common/chat-area/chat-uikit/src/components/contents/file-content/components/FileCard/variants.ts
297827
298030
  /*
297828
298031
  * Copyright 2025 coze-dev Authors
@@ -298597,7 +298800,68 @@ var file_card_update = injectStylesIntoStyleTag_default()(file_card/* ["default"
298597
298800
 
298598
298801
 
298599
298802
 
298600
- // eslint-disable-next-line @coze-arch/max-line-per-function
298803
+
298804
+ /**
298805
+ * Get file URL from URI using GetImagexShortUrl API (same as image)
298806
+ * Falls back to URI if API call fails
298807
+ */ const getFileUrlFromUri = async (uri)=>{
298808
+ try {
298809
+ // Build API URL using the same logic as getBaseURL from @coze-arch/bot-http
298810
+ const productCode = // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Window global property may not be typed
298811
+ window.__PRODUCT_CODE__ || {"NODE_ENV":"production","CHAT_APP_CHATFLOW_COZE_APP_ID":"","CHAT_APP_CHATFLOW_COZE_WORKFLOW_ID":"","CHAT_APP_INDEX_COZE_BOT_ID":"","CHAT_APP_COZE_TOKEN":"","CHAT_APP_COZE_BOT_USER_URL":""}.VITE_PRODUCD_CODE || location.pathname.split('/')[3];
298812
+ const isLocal = "production" === 'development';
298813
+ const baseUrl = {"NODE_ENV":"production","CHAT_APP_CHATFLOW_COZE_APP_ID":"","CHAT_APP_CHATFLOW_COZE_WORKFLOW_ID":"","CHAT_APP_INDEX_COZE_BOT_ID":"","CHAT_APP_COZE_TOKEN":"","CHAT_APP_COZE_BOT_USER_URL":""}.VITE_BASE_API || window.location.origin;
298814
+ const apiPath = '/api/playground_api/get_imagex_url';
298815
+ const apiUrl = isLocal ? `${window.location.origin}/server/api/${productCode}/flow${apiPath}` : `${baseUrl}/api/${productCode}/flow${apiPath}`;
298816
+ // Get auth token - try to use the same method as axiosInstance
298817
+ const getAuthToken = ()=>{
298818
+ var _document_cookie_split_find;
298819
+ if (window.location.hash.includes('/embed/application')) {
298820
+ return localStorage.getItem('embed.token');
298821
+ }
298822
+ // Try to get token from localStorage (same as getTokenWithSync)
298823
+ return localStorage.getItem('token') || localStorage.getItem('coze_token') || ((_document_cookie_split_find = document.cookie.split(';').find((c)=>c.trim().startsWith('token='))) === null || _document_cookie_split_find === void 0 ? void 0 : _document_cookie_split_find.split('=')[1]);
298824
+ };
298825
+ const token = getAuthToken();
298826
+ const headers = {
298827
+ 'Content-Type': 'application/json',
298828
+ 'x-requested-with': 'XMLHttpRequest',
298829
+ 'Agw-Js-Conv': 'str'
298830
+ };
298831
+ if (token) {
298832
+ headers.Authorization = `Bearer ${token}`;
298833
+ }
298834
+ // Call GetImagexShortUrl API with uris array
298835
+ const response = await fetch(apiUrl, {
298836
+ method: 'POST',
298837
+ headers,
298838
+ credentials: 'include',
298839
+ body: JSON.stringify({
298840
+ uris: [
298841
+ uri
298842
+ ]
298843
+ })
298844
+ });
298845
+ if (response.ok) {
298846
+ const contentType = response.headers.get('content-type');
298847
+ if (contentType && contentType.includes('application/json')) {
298848
+ var _result_data_url_info_uri, _result_data_url_info, _result_data;
298849
+ const result = await response.json();
298850
+ // Get URL from url_info map using URI as key (same as image)
298851
+ const url = result === null || result === void 0 ? void 0 : (_result_data = result.data) === null || _result_data === void 0 ? void 0 : (_result_data_url_info = _result_data.url_info) === null || _result_data_url_info === void 0 ? void 0 : (_result_data_url_info_uri = _result_data_url_info[uri]) === null || _result_data_url_info_uri === void 0 ? void 0 : _result_data_url_info_uri.url;
298852
+ if (url) {
298853
+ return url;
298854
+ }
298855
+ }
298856
+ }
298857
+ } catch (error) {
298858
+ // Silently fail and fall back to URI
298859
+ if (false) {}
298860
+ }
298861
+ // Fallback to URI if API call fails
298862
+ return uri;
298863
+ };
298864
+ // eslint-disable-next-line @coze-arch/max-line-per-function -- FileCard component requires many lines
298601
298865
  const FileCard_FileCard = (props)=>{
298602
298866
  const { file, attributeKeys, tooltipsCopywriting, readonly, onCancel, onCopy, onRetry, className, layout, showBackground } = props;
298603
298867
  const { statusKey, statusEnum, percentKey } = attributeKeys;
@@ -298609,6 +298873,74 @@ const FileCard_FileCard = (props)=>{
298609
298873
  const buttonsVisible = !readonly;
298610
298874
  const { extension, nameWithoutExtension } = getFileExtensionAndName(file.file_name);
298611
298875
  const isCanceled = file[statusKey] === statusEnum.cancelEnum;
298876
+ const fileStatusValue = file[statusKey];
298877
+ const fileUrl = file.file_url;
298878
+ const fileKey = file.file_key;
298879
+ // If upload_status is undefined but file has file_url or file_key, consider it as success
298880
+ // This handles files from server messages that don't have upload_status field
298881
+ const isSuccess = fileStatusValue === statusEnum.successEnum || fileStatusValue === undefined && (fileUrl || fileKey);
298882
+ const { baseUrl, urlParam } = useDocViewerConfig();
298883
+ const buildDocViewerUrl = (fileUrlParam)=>{
298884
+ const separator = baseUrl.includes('?') ? '&' : '?';
298885
+ return `${baseUrl}${separator}${urlParam}=${encodeURIComponent(fileUrlParam)}`;
298886
+ };
298887
+ const handlePreview = async (e)=>{
298888
+ e.stopPropagation();
298889
+ if (!isSuccess) {
298890
+ return;
298891
+ }
298892
+ // 优先使用 file_url,如果没有则使用 file_key (URI)
298893
+ if (fileUrl) {
298894
+ const docViewerUrl = buildDocViewerUrl(fileUrl);
298895
+ window.open(docViewerUrl, '_blank');
298896
+ return;
298897
+ }
298898
+ if (fileKey) {
298899
+ // Get URL from URI using API
298900
+ try {
298901
+ const resolvedUrl = await getFileUrlFromUri(fileKey);
298902
+ const docViewerUrl = buildDocViewerUrl(resolvedUrl);
298903
+ window.open(docViewerUrl, '_blank');
298904
+ } catch (error) {
298905
+ // Fallback to using URI directly
298906
+ if (false) {}
298907
+ const docViewerUrl = buildDocViewerUrl(fileKey);
298908
+ window.open(docViewerUrl, '_blank');
298909
+ }
298910
+ return;
298911
+ }
298912
+ };
298913
+ const handleClick = async (e)=>{
298914
+ if (!isSuccess) {
298915
+ return;
298916
+ }
298917
+ // 如果点击的是操作按钮或其子元素,不执行跳转
298918
+ const target = e.target;
298919
+ const isButton = target.closest('button') || target.closest('[role="button"]') || target.closest('[class*="IconButton"]');
298920
+ if (isButton) {
298921
+ return;
298922
+ }
298923
+ // 优先使用 file_url,如果没有则使用 file_key (URI)
298924
+ if (fileUrl) {
298925
+ const docViewerUrl = buildDocViewerUrl(fileUrl);
298926
+ window.open(docViewerUrl, '_blank');
298927
+ return;
298928
+ }
298929
+ if (fileKey) {
298930
+ // Get URL from URI using API
298931
+ try {
298932
+ const resolvedUrl = await getFileUrlFromUri(fileKey);
298933
+ const docViewerUrl = buildDocViewerUrl(resolvedUrl);
298934
+ window.open(docViewerUrl, '_blank');
298935
+ } catch (error) {
298936
+ // Fallback to using URI directly
298937
+ if (false) {}
298938
+ const docViewerUrl = buildDocViewerUrl(fileKey);
298939
+ window.open(docViewerUrl, '_blank');
298940
+ }
298941
+ return;
298942
+ }
298943
+ };
298612
298944
  return /*#__PURE__*/ (0,jsx_runtime.jsxs)("div", {
298613
298945
  // className={classNames(className, 'chat-uikit-file-card', {
298614
298946
  // 'chat-uikit-file-card--error': file[statusKey] === statusEnum.failEnum,
@@ -298621,7 +298953,8 @@ const FileCard_FileCard = (props)=>{
298621
298953
  isError: file[statusKey] === statusEnum.failEnum,
298622
298954
  layout: layout === common_Layout.PC ? 'pc' : 'mobile',
298623
298955
  showBackground
298624
- }), className),
298956
+ }), className, 'cursor-pointer'),
298957
+ onClick: handleClick,
298625
298958
  children: [
298626
298959
  /*#__PURE__*/ (0,jsx_runtime.jsx)("img", {
298627
298960
  src: fileIconMap[file.file_type],
@@ -298653,7 +298986,7 @@ const FileCard_FileCard = (props)=>{
298653
298986
  }),
298654
298987
  children: nameWithoutExtension
298655
298988
  }),
298656
- /*#__PURE__*/ (0,jsx_runtime.jsx)("span", {
298989
+ file.file_size > 0 && /*#__PURE__*/ (0,jsx_runtime.jsx)("span", {
298657
298990
  // chat-uikit-file-card__info__size
298658
298991
  className: classnames_default()('text-base font-normal leading-[16px]', isCanceled ? 'coz-fg-dim' : 'coz-fg-secondary'),
298659
298992
  children: convertBytes(file.file_size)
@@ -298677,7 +299010,10 @@ const FileCard_FileCard = (props)=>{
298677
299010
  , {}),
298678
299011
  size: "small",
298679
299012
  color: "secondary",
298680
- onClick: onCancel
299013
+ onClick: (e)=>{
299014
+ e.stopPropagation();
299015
+ onCancel();
299016
+ }
298681
299017
  })
298682
299018
  }),
298683
299019
  [
@@ -298694,21 +299030,47 @@ const FileCard_FileCard = (props)=>{
298694
299030
  , {}),
298695
299031
  size: "small",
298696
299032
  color: "secondary",
298697
- onClick: onRetry
299033
+ onClick: (e)=>{
299034
+ e.stopPropagation();
299035
+ onRetry();
299036
+ }
298698
299037
  })
298699
299038
  }),
299039
+ isSuccess ? /*#__PURE__*/ (0,jsx_runtime.jsx)(UIKitTooltip, {
299040
+ theme: "light",
299041
+ position: "top",
299042
+ content: (tooltipsCopywriting === null || tooltipsCopywriting === void 0 ? void 0 : tooltipsCopywriting.preview) || '预览',
299043
+ hideToolTip: layout === common_Layout.MOBILE,
299044
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
299045
+ className: "chat-uikit-file-card__preview-button-wrapper",
299046
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_IconButton, {
299047
+ icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(__webpack_exports__IconCozEye, {}),
299048
+ size: "small",
299049
+ color: "secondary",
299050
+ onClick: handlePreview,
299051
+ className: "chat-uikit-file-card__preview-button"
299052
+ })
299053
+ })
299054
+ }) : null,
298700
299055
  file[statusKey] === statusEnum.successEnum && /*#__PURE__*/ (0,jsx_runtime.jsx)(UIKitTooltip, {
298701
299056
  theme: "light",
298702
299057
  position: "top",
298703
299058
  content: tooltipsCopywriting === null || tooltipsCopywriting === void 0 ? void 0 : tooltipsCopywriting.copy,
298704
299059
  hideToolTip: layout === common_Layout.MOBILE,
298705
- children: /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_IconButton, {
298706
- // chat-uikit-file-card__buttons__button
298707
- icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(__webpack_exports__IconCozCopy // chat-uikit-file-card__buttons__icon
298708
- , {}),
298709
- size: "small",
298710
- color: "secondary",
298711
- onClick: onCopy
299060
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
299061
+ className: "chat-uikit-file-card__copy-button-wrapper",
299062
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_IconButton, {
299063
+ // chat-uikit-file-card__buttons__button
299064
+ icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(__webpack_exports__IconCozCopy // chat-uikit-file-card__buttons__icon
299065
+ , {}),
299066
+ size: "small",
299067
+ color: "secondary",
299068
+ onClick: (e)=>{
299069
+ e.stopPropagation();
299070
+ onCopy();
299071
+ },
299072
+ className: "chat-uikit-file-card__copy-button"
299073
+ })
298712
299074
  })
298713
299075
  })
298714
299076
  ]
@@ -298747,6 +299109,19 @@ FileCard_FileCard.displayName = 'FileCard';
298747
299109
  */
298748
299110
 
298749
299111
 
299112
+ // 默认的 fileAttributeKeys,用于混合消息中的文件显示
299113
+ // 注意:这些值需要与实际的 FileStatus 枚举值匹配
299114
+ // FileStatus: Init=0, Uploading=1, Success=2, Canceled=3, Error=4
299115
+ const DEFAULT_FILE_ATTRIBUTE_KEYS = {
299116
+ statusKey: 'upload_status',
299117
+ statusEnum: {
299118
+ successEnum: 2,
299119
+ failEnum: 4,
299120
+ cancelEnum: 3,
299121
+ uploadingEnum: 1
299122
+ },
299123
+ percentKey: 'upload_percent'
299124
+ };
298750
299125
  const FileItemList = (param)=>{
298751
299126
  let { fileItemList, fileAttributeKeys, fileCopywriting, readonly, onRetry, onCancel, onCopy, message, layout, showBackground } = param;
298752
299127
  /**
@@ -298773,13 +299148,15 @@ const FileItemList = (param)=>{
298773
299148
  extra: {}
298774
299149
  });
298775
299150
  };
299151
+ // 使用传入的 fileAttributeKeys 或默认值
299152
+ const effectiveFileAttributeKeys = fileAttributeKeys || DEFAULT_FILE_ATTRIBUTE_KEYS;
298776
299153
  return /*#__PURE__*/ (0,jsx_runtime.jsx)(jsx_runtime.Fragment, {
298777
299154
  children: fileItemList.map((item)=>{
298778
- if (isFileMixItem(item) && fileAttributeKeys) {
299155
+ if (isFileMixItem(item)) {
298779
299156
  return /*#__PURE__*/ (0,jsx_runtime.jsx)(components_FileCard, {
298780
299157
  className: "chat-uikit-multi-modal-file-image-content select-none",
298781
299158
  file: item.file,
298782
- attributeKeys: fileAttributeKeys,
299159
+ attributeKeys: effectiveFileAttributeKeys,
298783
299160
  tooltipsCopywriting: fileCopywriting === null || fileCopywriting === void 0 ? void 0 : fileCopywriting.tooltips,
298784
299161
  readonly: readonly,
298785
299162
  onCancel: handleCancel,
@@ -300098,6 +300475,7 @@ var message_box_update = injectStylesIntoStyleTag_default()(message_box/* ["defa
300098
300475
 
300099
300476
 
300100
300477
 
300478
+
300101
300479
  const MessageBoxWrap = (props)=>{
300102
300480
  const { children, theme, nickname, avatar, showUserInfo, renderFooter, hoverContent, right, senderId, classname, messageBubbleClassname, messageBubbleWrapperClassname, messageBoxWrapperClassname, messageHoverWrapperClassName, messageErrorWrapperClassname, isHoverShowUserInfo = true, layout, contentTime, showBackground, extendedUserInfo, topRightSlot, imageAutoSizeContainerWidth, enableImageAutoSize, messageId, eventCallbacks, onError } = props;
300103
300481
  const { userLabel, userUniqueName } = extendedUserInfo ?? {};
@@ -300110,6 +300488,10 @@ const MessageBoxWrap = (props)=>{
300110
300488
  const isMobileLayout = layout === common_Layout.MOBILE;
300111
300489
  // 判断是否为发送消息:发送消息通常使用 'primary' 主题
300112
300490
  const isSentMessage = theme === 'primary';
300491
+ // 判断是否为 mix-content 消息:mix-content 消息使用 'none' 主题,但仍然是发送的消息
300492
+ const isMixContentMessage = theme === 'none' && (classname === null || classname === void 0 ? void 0 : classname.includes('chat-uikit-mix-content-message-box'));
300493
+ // 判断是否应该应用发送消息的样式(包括纯文本和 mix-content)
300494
+ const shouldApplySentMessageStyle = isSentMessage || isMixContentMessage;
300113
300495
  const refreshContainerWidthConditionally = use_event_callback_useEventCallback(()=>{
300114
300496
  if (!messageContainerRef.current || !messageFooterRef.current) {
300115
300497
  return;
@@ -300167,14 +300549,14 @@ const MessageBoxWrap = (props)=>{
300167
300549
  // chat-uikit-message-box-container chat-uikit-message-box-container-pc
300168
300550
  className: classnames_default()(messageBoxContainerVariants({
300169
300551
  isMobileLayout,
300170
- isSentMessage
300552
+ isSentMessage: shouldApplySentMessageStyle
300171
300553
  }), messageBoxWrapperClassname),
300172
300554
  children: [
300173
300555
  showUserInfo ? /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
300174
300556
  // chat-uikit-message-box-container__avatar-wrap
300175
300557
  className: classnames_default()('w-32px h-32px', {
300176
- 'ml-[12px]': isSentMessage,
300177
- 'mr-[12px]': !isSentMessage
300558
+ 'ml-[12px]': shouldApplySentMessageStyle,
300559
+ 'mr-[12px]': !shouldApplySentMessageStyle
300178
300560
  }),
300179
300561
  children: /*#__PURE__*/ (0,jsx_runtime.jsx)(AvatarWrap, {
300180
300562
  children: /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_Avatar, {
@@ -300189,7 +300571,7 @@ const MessageBoxWrap = (props)=>{
300189
300571
  // chat-uikit-message-box-container__message
300190
300572
  className: classnames_default()('flex-1', {
300191
300573
  'max-w-[calc(100%-80px)]': true,
300192
- 'flex justify-end': isSentMessage
300574
+ 'flex justify-end': shouldApplySentMessageStyle
300193
300575
  }),
300194
300576
  children: /*#__PURE__*/ (0,jsx_runtime.jsxs)("div", {
300195
300577
  // chat-uikit-message-box-container__message__message-box
@@ -358055,9 +358437,10 @@ const removeAllListeners = (instance)=>{
358055
358437
  instance.removeAllListeners('error');
358056
358438
  instance.removeAllListeners('progress');
358057
358439
  };
358058
- // eslint-disable-next-line max-lines-per-function
358440
+ // eslint-disable-next-line @coze-arch/max-line-per-function, max-lines-per-function -- Upload function requires many lines for complete functionality
358059
358441
  function upload_uploadFile(param) {
358060
358442
  let { file, fileType = 'image', userId, signal, onProgress, onUploaderReady, onUploadError, onGetTokenError, onSuccess } = param;
358443
+ // eslint-disable-next-line @coze-arch/max-line-per-function, max-lines-per-function -- Promise handler requires many lines
358061
358444
  return new Promise((resolve)=>{
358062
358445
  let bytedUploader = null;
358063
358446
  let shouldContinue = true;
@@ -358107,6 +358490,34 @@ function upload_uploadFile(param) {
358107
358490
  }, false);
358108
358491
  onUploaderReady === null || onUploaderReady === void 0 ? void 0 : onUploaderReady(bytedUploader);
358109
358492
  bytedUploader.on('complete', (inform)=>{
358493
+ var _informAny_response, _informAny_result, _informAny__response, _informAny_rawResponse;
358494
+ // Backend returns: { data: { uri: "xxx", id: "yyy", url: "zzz" } }
358495
+ // Upload adapter may not map data.uri correctly - check complete inform structure
358496
+ const informAny = inform;
358497
+ // Check task object for raw response data
358498
+ let rawResponseData = null;
358499
+ if (informAny.task) {
358500
+ var _informAny_task_response, _informAny_task_responseData, _informAny_task_result, _informAny_task__response, _informAny_task_rawResponse;
358501
+ // Check various possible locations in task
358502
+ rawResponseData = ((_informAny_task_response = informAny.task.response) === null || _informAny_task_response === void 0 ? void 0 : _informAny_task_response.data) || ((_informAny_task_responseData = informAny.task.responseData) === null || _informAny_task_responseData === void 0 ? void 0 : _informAny_task_responseData.data) || ((_informAny_task_result = informAny.task.result) === null || _informAny_task_result === void 0 ? void 0 : _informAny_task_result.data) || informAny.task.data || ((_informAny_task__response = informAny.task._response) === null || _informAny_task__response === void 0 ? void 0 : _informAny_task__response.data) || ((_informAny_task_rawResponse = informAny.task.rawResponse) === null || _informAny_task_rawResponse === void 0 ? void 0 : _informAny_task_rawResponse.data);
358503
+ }
358504
+ // Also check inform level - check all possible nested paths
358505
+ const informLevelData = informAny.data || ((_informAny_response = informAny.response) === null || _informAny_response === void 0 ? void 0 : _informAny_response.data) || informAny.responseData || ((_informAny_result = informAny.result) === null || _informAny_result === void 0 ? void 0 : _informAny_result.data) || ((_informAny__response = informAny._response) === null || _informAny__response === void 0 ? void 0 : _informAny__response.data) || ((_informAny_rawResponse = informAny.rawResponse) === null || _informAny_rawResponse === void 0 ? void 0 : _informAny_rawResponse.data);
358506
+ // Use rawResponseData or informLevelData
358507
+ const backendData = rawResponseData || informLevelData;
358508
+ if (informAny.uploadResult && backendData) {
358509
+ // Backend returns lowercase fields: uri, id, url
358510
+ // Map them correctly to uploadResult
358511
+ if (backendData.uri) {
358512
+ informAny.uploadResult.uri = backendData.uri;
358513
+ }
358514
+ if (backendData.id) {
358515
+ informAny.uploadResult.id = backendData.id;
358516
+ }
358517
+ if (backendData.url) {
358518
+ informAny.uploadResult.url = backendData.url;
358519
+ }
358520
+ }
358110
358521
  onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(inform);
358111
358522
  resolve();
358112
358523
  });
@@ -358180,7 +358591,7 @@ const checkHasFileOnDrag = (e)=>{
358180
358591
  Boolean((_e_dataTransfer = e.dataTransfer) === null || _e_dataTransfer === void 0 ? void 0 : _e_dataTransfer.types.includes('Files')));
358181
358592
  };
358182
358593
  const formatFileDataListToMessagePayload = (fileDataList)=>fileDataList.map((data)=>{
358183
- const { uri } = data;
358594
+ const { uri, fileId } = data;
358184
358595
  if (!uri) {
358185
358596
  throw new Error('failed to get file uri');
358186
358597
  }
@@ -358188,7 +358599,8 @@ const formatFileDataListToMessagePayload = (fileDataList)=>fileDataList.map((dat
358188
358599
  const filePayload = {
358189
358600
  type: types_ContentType.File,
358190
358601
  file: data.file,
358191
- uri
358602
+ uri,
358603
+ id: fileId || undefined
358192
358604
  };
358193
358605
  return filePayload;
358194
358606
  }
@@ -358198,7 +358610,8 @@ const formatFileDataListToMessagePayload = (fileDataList)=>fileDataList.map((dat
358198
358610
  file: data.file,
358199
358611
  uri,
358200
358612
  width: (meta === null || meta === void 0 ? void 0 : meta.width) ?? 0,
358201
- height: (meta === null || meta === void 0 ? void 0 : meta.height) ?? 0
358613
+ height: (meta === null || meta === void 0 ? void 0 : meta.height) ?? 0,
358614
+ id: fileId || undefined
358202
358615
  };
358203
358616
  return imagePayload;
358204
358617
  });
@@ -358438,17 +358851,52 @@ const useUpload = ()=>{
358438
358851
  data.percent = event.percent;
358439
358852
  });
358440
358853
  },
358441
- onComplete: (param, id)=>{
358442
- let { uploadResult } = param;
358854
+ onComplete: (event, id)=>{
358855
+ const { uploadResult } = event;
358856
+ // Event structure may contain additional properties from uploader library
358857
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Event structure varies
358858
+ const eventAny = event;
358443
358859
  immerUpdateFileDataById(id, (data)=>{
358444
358860
  data.status = types_FileStatus.Success;
358445
358861
  data.percent = MAX_UPLOAD_PROGRESS;
358446
- const uri = uploadResult.Uri;
358447
- if (!uri) {
358862
+ // Backend returns: { data: { uri: "xxx", id: "yyy", url: "zzz" } }
358863
+ // Upload adapter may map data.id to uploadResult.Uri (incorrectly)
358864
+ // We need to check the actual structure to get both id and uri correctly
358865
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any -- UploadResult structure varies
358866
+ const uploadResultAny = uploadResult;
358867
+ // Try to get raw response data from event object
358868
+ let backendData = null;
358869
+ if (eventAny.task) {
358870
+ var _eventAny_task_response, _eventAny_task_responseData, _eventAny_task_result;
358871
+ backendData = ((_eventAny_task_response = eventAny.task.response) === null || _eventAny_task_response === void 0 ? void 0 : _eventAny_task_response.data) || ((_eventAny_task_responseData = eventAny.task.responseData) === null || _eventAny_task_responseData === void 0 ? void 0 : _eventAny_task_responseData.data) || ((_eventAny_task_result = eventAny.task.result) === null || _eventAny_task_result === void 0 ? void 0 : _eventAny_task_result.data) || eventAny.task.data;
358872
+ }
358873
+ if (!backendData) {
358874
+ var _eventAny_response, _eventAny_result;
358875
+ backendData = eventAny.data || ((_eventAny_response = eventAny.response) === null || _eventAny_response === void 0 ? void 0 : _eventAny_response.data) || eventAny.responseData || ((_eventAny_result = eventAny.result) === null || _eventAny_result === void 0 ? void 0 : _eventAny_result.data);
358876
+ }
358877
+ // Backend returns lowercase fields: data.uri and data.id
358878
+ // Check if uploadResult has these fields directly (from raw response)
358879
+ // Or check if they're mapped to different fields
358880
+ const backendId = (backendData === null || backendData === void 0 ? void 0 : backendData.id) || // From raw backend response
358881
+ uploadResultAny.id || // Backend returns lowercase 'id'
358882
+ uploadResultAny.Id || // Check uppercase variant
358883
+ uploadResult.Uri || // Fallback to Uri if id not available
358884
+ null;
358885
+ // Backend returns lowercase 'uri' field
358886
+ // This is the real URI we need for getting file URL
358887
+ const backendUri = (backendData === null || backendData === void 0 ? void 0 : backendData.uri) || // From raw backend response - this is the real uri!
358888
+ uploadResultAny.uri || // Backend returns lowercase 'uri'
358889
+ uploadResultAny.Uri || // Check uppercase variant
358890
+ null;
358891
+ // Save backend file ID (used for other operations)
358892
+ data.fileId = backendId;
358893
+ // Save backend URI (used to get URL) - this should be the real URI from backend
358894
+ data.uri = backendUri;
358895
+ data.url = uploadResult.Url || uploadResultAny.url || (backendData === null || backendData === void 0 ? void 0 : backendData.url) || null;
358896
+ if (!data.uri && !data.fileId) {
358448
358897
  data.status = types_FileStatus.Error;
358449
- throw new Error('upload complete without uri');
358898
+ throw new Error('upload complete without uri or id');
358450
358899
  }
358451
- data.uri = uri;
358452
358900
  if (data.fileType !== types_FileType.Image) {
358453
358901
  return;
358454
358902
  }
@@ -382853,7 +383301,10 @@ const scroll_view_ScrollView = /*#__PURE__*/ (0,react.forwardRef)(function Scrol
382853
383301
  value: scrollViewContentRef,
382854
383302
  children: /*#__PURE__*/ (0,jsx_runtime.jsxs)("div", {
382855
383303
  className: classnames_default()(src_scroll_view_index_module["scroll-view"], className),
382856
- style: style,
383304
+ style: {
383305
+ ...style,
383306
+ flexGrow: 1
383307
+ },
382857
383308
  ref: wrapperRef,
382858
383309
  children: [
382859
383310
  before ? /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
@@ -382870,6 +383321,9 @@ const scroll_view_ScrollView = /*#__PURE__*/ (0,react.forwardRef)(function Scrol
382870
383321
  className: classnames_default()(src_scroll_view_index_module.scrollable, showScrollbar && src_scroll_view_index_module["show-scrollbar"], autoShowScrollbar && src_scroll_view_index_module["auto-show-scrollbar"], scrollbarWidthNone && src_scroll_view_index_module["scrollbar-width-none"], {
382871
383322
  [src_scroll_view_index_module.reverse]: reverse
382872
383323
  }),
383324
+ // style={{
383325
+ // height: '100%',
383326
+ // }}
382873
383327
  onScroll: handleScroll,
382874
383328
  children: [
382875
383329
  lodash_es_isFunction(children) ? children(controller) : children,
@@ -396331,7 +396785,10 @@ const DeleteFileButton = (param)=>{
396331
396785
  };
396332
396786
  return /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
396333
396787
  className: batch_upload_file_list_delete_file_button_index_module["icon-close"],
396334
- onClick: onDelete,
396788
+ onClick: (e)=>{
396789
+ e.stopPropagation();
396790
+ onDelete();
396791
+ },
396335
396792
  children: /*#__PURE__*/ (0,jsx_runtime.jsx)(IconCloseNoCycle, {})
396336
396793
  });
396337
396794
  };
@@ -396541,6 +396998,131 @@ const ui_button_Button = /*#__PURE__*/ (0,react.forwardRef)((param, ref)=>{
396541
396998
  });
396542
396999
  });
396543
397000
 
397001
+ ;// CONCATENATED MODULE: ../../../common/chat-area/chat-area/src/hooks/use-doc-viewer-config.ts
397002
+ /*
397003
+ * Copyright 2025 coze-dev Authors
397004
+ *
397005
+ * Licensed under the Apache License, Version 2.0 (the "License");
397006
+ * you may not use this file except in compliance with the License.
397007
+ * You may obtain a copy of the License at
397008
+ *
397009
+ * http://www.apache.org/licenses/LICENSE-2.0
397010
+ *
397011
+ * Unless required by applicable law or agreed to in writing, software
397012
+ * distributed under the License is distributed on an "AS IS" BASIS,
397013
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
397014
+ * See the License for the specific language governing permissions and
397015
+ * limitations under the License.
397016
+ */ // Try to import useChatAppProps and useChatAppStore from open-chat if available
397017
+
397018
+
397019
+
397020
+ let use_doc_viewer_config_useChatAppProps = null;
397021
+ let use_doc_viewer_config_useChatAppStore = null;
397022
+ try {
397023
+ // Dynamic import, module may not be available
397024
+ // eslint-disable-next-line @typescript-eslint/no-require-imports -- Dynamic require needed for optional dependency
397025
+ const openChatModule = __webpack_require__(Object(function webpackMissingModule() { var e = new Error("Cannot find module '@coze-studio/open-chat'"); e.code = 'MODULE_NOT_FOUND'; throw e; }()));
397026
+ // eslint-disable-next-line prefer-destructuring -- Direct assignment needed for conditional hook usage
397027
+ use_doc_viewer_config_useChatAppProps = openChatModule.useChatAppProps;
397028
+ // eslint-disable-next-line prefer-destructuring -- Direct assignment needed for conditional hook usage
397029
+ use_doc_viewer_config_useChatAppStore = openChatModule.useChatAppStore;
397030
+ } catch (error) {
397031
+ // Module not available, will use default values
397032
+ // Error is expected when module is not available, so we can safely ignore it
397033
+ if (false) {}
397034
+ }
397035
+ /**
397036
+ * Parse domain and productCode from apiUrl
397037
+ * apiUrl format: 域名/api/productCode/flow
397038
+ * Example: https://aiot-dev.glodon.com/api/cvforce/flow
397039
+ * Returns: { domain: 'https://aiot-dev.glodon.com', productCode: 'cvforce' }
397040
+ */ const use_doc_viewer_config_parseApiUrl = (apiUrl)=>{
397041
+ const defaultDomain = 'https://aiot-dev.glodon.com';
397042
+ const defaultProductCode = 'cvforcepd';
397043
+ if (!apiUrl) {
397044
+ return {
397045
+ domain: defaultDomain,
397046
+ productCode: defaultProductCode
397047
+ };
397048
+ }
397049
+ try {
397050
+ // Parse URL: 域名/api/productCode/flow
397051
+ const url = new URL(apiUrl);
397052
+ const domain = `${url.protocol}//${url.host}`;
397053
+ const pathParts = url.pathname.split('/').filter(Boolean);
397054
+ // Find 'api' in path and get the next part as productCode
397055
+ const apiIndex = pathParts.indexOf('api');
397056
+ if (apiIndex >= 0 && apiIndex < pathParts.length - 1) {
397057
+ const productCode = pathParts[apiIndex + 1];
397058
+ if (productCode) {
397059
+ return {
397060
+ domain,
397061
+ productCode
397062
+ };
397063
+ }
397064
+ }
397065
+ } catch (urlError) {
397066
+ // If URL parsing fails, try regex
397067
+ const match = apiUrl.match(/^(https?:\/\/[^\/]+)\/api\/([^\/]+)\//);
397068
+ if (match && match[1] && match[2]) {
397069
+ return {
397070
+ domain: match[1],
397071
+ productCode: match[2]
397072
+ };
397073
+ }
397074
+ // If regex also fails, log in development mode
397075
+ if (false) {}
397076
+ }
397077
+ return {
397078
+ domain: defaultDomain,
397079
+ productCode: defaultProductCode
397080
+ };
397081
+ };
397082
+ /**
397083
+ * Build default doc viewer URL from apiUrl
397084
+ * Format: 域名/portal/_/productCode/doc-viewer/
397085
+ * Example: https://aiot-dev.glodon.com/api/cvforce/flow -> https://aiot-dev.glodon.com/portal/_/cvforce/doc-viewer/
397086
+ */ const use_doc_viewer_config_buildDefaultDocViewerUrl = (apiUrl)=>{
397087
+ const { domain, productCode } = use_doc_viewer_config_parseApiUrl(apiUrl);
397088
+ return `${domain}/portal/_/${productCode}/doc-viewer/`;
397089
+ };
397090
+ /**
397091
+ * Get document viewer configuration from SDK config
397092
+ * Falls back to default values parsed from apiUrl if SDK config is not available
397093
+ */ const use_doc_viewer_config_useDocViewerConfig = ()=>{
397094
+ let docViewerConfig;
397095
+ let apiUrl;
397096
+ // These hooks are dynamically imported and may not be available
397097
+ if (use_doc_viewer_config_useChatAppProps) {
397098
+ try {
397099
+ var _chatConfigResult_chatConfig_extra, _chatConfigResult_chatConfig;
397100
+ // eslint-disable-next-line react-hooks/rules-of-hooks -- Hook is conditionally available
397101
+ const chatConfigResult = use_doc_viewer_config_useChatAppProps();
397102
+ docViewerConfig = chatConfigResult === null || chatConfigResult === void 0 ? void 0 : (_chatConfigResult_chatConfig = chatConfigResult.chatConfig) === null || _chatConfigResult_chatConfig === void 0 ? void 0 : (_chatConfigResult_chatConfig_extra = _chatConfigResult_chatConfig.extra) === null || _chatConfigResult_chatConfig_extra === void 0 ? void 0 : _chatConfigResult_chatConfig_extra.docViewer;
397103
+ } catch (hookError) {
397104
+ // Hook not available in this context, use defaults
397105
+ if (false) {}
397106
+ }
397107
+ }
397108
+ if (use_doc_viewer_config_useChatAppStore) {
397109
+ try {
397110
+ // eslint-disable-next-line react-hooks/rules-of-hooks -- Hook is conditionally available
397111
+ apiUrl = use_doc_viewer_config_useChatAppStore((state)=>state.apiUrl);
397112
+ } catch (storeError) {
397113
+ // Store not available in this context, use defaults
397114
+ if (false) {}
397115
+ }
397116
+ }
397117
+ // Default values: use config if provided, otherwise parse from apiUrl
397118
+ const baseUrl = (docViewerConfig === null || docViewerConfig === void 0 ? void 0 : docViewerConfig.baseUrl) || use_doc_viewer_config_buildDefaultDocViewerUrl(apiUrl);
397119
+ const urlParam = (docViewerConfig === null || docViewerConfig === void 0 ? void 0 : docViewerConfig.urlParam) || 'url';
397120
+ return {
397121
+ baseUrl,
397122
+ urlParam
397123
+ };
397124
+ };
397125
+
396544
397126
  // EXTERNAL MODULE: ../../../../../common/temp/default/node_modules/.pnpm/css-loader@6.11.0_@rspack+core@1.5.8_webpack@5.91.0/node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[7].use[1]!../../../../../common/temp/default/node_modules/.pnpm/postcss-loader@7.3.4_postcss@8.5.6_typescript@5.8.2_webpack@5.91.0/node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[7].use[2]!../../../../../common/temp/default/node_modules/.pnpm/less-loader@11.1.4_less@4.4.2_webpack@5.91.0/node_modules/less-loader/dist/cjs.js??ruleSet[1].rules[7].use[3]!../../../common/chat-area/chat-area/src/components/batch-upload-file-list/common-file/index.module.less
396545
397127
  var common_file_index_module = __webpack_require__(26758);
396546
397128
  ;// CONCATENATED MODULE: ../../../common/chat-area/chat-area/src/components/batch-upload-file-list/common-file/index.module.less
@@ -396628,8 +397210,12 @@ const ProgressMask = (param)=>{
396628
397210
 
396629
397211
 
396630
397212
 
397213
+
397214
+
397215
+
397216
+
396631
397217
  const CommonFile = (param)=>{
396632
- let { file, status, percent, id, className } = param;
397218
+ let { file, status, percent, id, className, uri, url } = param;
396633
397219
  const ref = (0,react.useRef)(null);
396634
397220
  const isHover = es_useHover(ref);
396635
397221
  const retryUpload = useRetryUpload();
@@ -396638,9 +397224,59 @@ const CommonFile = (param)=>{
396638
397224
  const isSuccess = status === types_FileStatus.Success;
396639
397225
  const fileTypeConfig = getFileTypConfig(file);
396640
397226
  const { extension, nameWithoutExtension } = getFileExtensionAndName(file.name);
397227
+ const { baseUrl, urlParam } = use_doc_viewer_config_useDocViewerConfig();
397228
+ const buildDocViewerUrl = (fileUrl)=>{
397229
+ const separator = baseUrl.includes('?') ? '&' : '?';
397230
+ return `${baseUrl}${separator}${urlParam}=${encodeURIComponent(fileUrl)}`;
397231
+ };
397232
+ const handlePreview = (e)=>{
397233
+ e.stopPropagation();
397234
+ if (!isSuccess) {
397235
+ return;
397236
+ }
397237
+ // 如果已经有 url,直接使用
397238
+ if (url) {
397239
+ const docViewerUrl = buildDocViewerUrl(url);
397240
+ window.open(docViewerUrl, '_blank');
397241
+ return;
397242
+ }
397243
+ if (!uri) {
397244
+ console.warn('File URI is not available, cannot open file');
397245
+ return;
397246
+ }
397247
+ const docViewerUrl = buildDocViewerUrl(uri);
397248
+ window.open(docViewerUrl, '_blank');
397249
+ };
397250
+ const handleClick = (e)=>{
397251
+ if (!isSuccess) {
397252
+ return;
397253
+ }
397254
+ // 如果点击的是操作按钮或其子元素,不执行跳转
397255
+ // 操作按钮已经通过 stopPropagation 阻止冒泡,这里作为额外保护
397256
+ const target = e.target;
397257
+ if (target.closest(`.${batch_upload_file_list_common_file_index_module["retry-button"]}`) || target.closest(`.${batch_upload_file_list_common_file_index_module["preview-button"]}`) || target.closest('[class*="icon-close"]') || target.closest('button')) {
397258
+ return;
397259
+ }
397260
+ // 如果已经有 url,直接使用
397261
+ if (url) {
397262
+ const docViewerUrl = buildDocViewerUrl(url);
397263
+ window.open(docViewerUrl, '_blank');
397264
+ return;
397265
+ }
397266
+ if (!uri) {
397267
+ console.warn('File URI is not available, cannot open file');
397268
+ return;
397269
+ }
397270
+ const docViewerUrl = buildDocViewerUrl(uri);
397271
+ window.open(docViewerUrl, '_blank');
397272
+ };
396641
397273
  return /*#__PURE__*/ (0,jsx_runtime.jsxs)("div", {
396642
397274
  ref: ref,
396643
397275
  className: classnames_default()(batch_upload_file_list_common_file_index_module["normal-file"], !isSuccess && batch_upload_file_list_common_file_index_module["normal-file-not-success"], className),
397276
+ style: {
397277
+ cursor: 'pointer'
397278
+ },
397279
+ onClick: handleClick,
396644
397280
  children: [
396645
397281
  /*#__PURE__*/ (0,jsx_runtime.jsx)("img", {
396646
397282
  src: getCommonFileIcon(fileTypeConfig === null || fileTypeConfig === void 0 ? void 0 : fileTypeConfig.fileType),
@@ -396675,10 +397311,24 @@ const CommonFile = (param)=>{
396675
397311
  }),
396676
397312
  isError ? /*#__PURE__*/ (0,jsx_runtime.jsx)(ui_button_Button, {
396677
397313
  icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(src_IconRefresh, {}),
396678
- onClick: onRetry,
397314
+ onClick: (e)=>{
397315
+ e.stopPropagation();
397316
+ onRetry();
397317
+ },
396679
397318
  theme: "borderless",
396680
397319
  className: batch_upload_file_list_common_file_index_module["retry-button"]
396681
397320
  }) : null,
397321
+ isSuccess ? /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_Tooltip, {
397322
+ content: "预览",
397323
+ theme: "light",
397324
+ position: "top",
397325
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)(ui_button_Button, {
397326
+ icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(__webpack_exports__IconCozEye, {}),
397327
+ onClick: handlePreview,
397328
+ theme: "borderless",
397329
+ className: batch_upload_file_list_common_file_index_module["preview-button"]
397330
+ })
397331
+ }) : null,
396682
397332
  !isError && !isSuccess && /*#__PURE__*/ (0,jsx_runtime.jsx)(ProgressMask, {
396683
397333
  percent: percent
396684
397334
  }),
@@ -398290,9 +398940,6 @@ const ChatAreaMain = (param)=>{
398290
398940
  [src_chat_area_main_index_modules["chat-area-main-pc"]]: layout === common_Layout.PC,
398291
398941
  [src_chat_area_main_index_modules["chat-area-main-mobile"]]: layout === common_Layout.MOBILE
398292
398942
  }, classname),
398293
- style: {
398294
- justifyContent: !hasMessages ? 'center' : 'auto'
398295
- },
398296
398943
  children: [
398297
398944
  /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
398298
398945
  className: src_chat_area_main_index_modules["header-node"],
@@ -398523,6 +399170,31 @@ class upload_plugin_UploadPlugin {
398523
399170
  this.eventBus.emit('error', errorEvent);
398524
399171
  },
398525
399172
  onSuccess: (event)=>{
399173
+ // Event structure may contain additional properties from uploader library
399174
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Event structure varies
399175
+ const eventAny = event;
399176
+ // Try to get raw response from task if it exists
399177
+ let backendData = null;
399178
+ if (eventAny.task) {
399179
+ var _eventAny_task_response, _eventAny_task_responseData, _eventAny_task__response, _eventAny_task_rawResponse;
399180
+ backendData = ((_eventAny_task_response = eventAny.task.response) === null || _eventAny_task_response === void 0 ? void 0 : _eventAny_task_response.data) || ((_eventAny_task_responseData = eventAny.task.responseData) === null || _eventAny_task_responseData === void 0 ? void 0 : _eventAny_task_responseData.data) || ((_eventAny_task__response = eventAny.task._response) === null || _eventAny_task__response === void 0 ? void 0 : _eventAny_task__response.data) || ((_eventAny_task_rawResponse = eventAny.task.rawResponse) === null || _eventAny_task_rawResponse === void 0 ? void 0 : _eventAny_task_rawResponse.data) || eventAny.task.data;
399181
+ }
399182
+ if (!backendData) {
399183
+ var _eventAny_response, _eventAny_result;
399184
+ backendData = eventAny.data || ((_eventAny_response = eventAny.response) === null || _eventAny_response === void 0 ? void 0 : _eventAny_response.data) || eventAny.responseData || ((_eventAny_result = eventAny.result) === null || _eventAny_result === void 0 ? void 0 : _eventAny_result.data);
399185
+ }
399186
+ // If we found raw data, add uri and id to uploadResult
399187
+ if (backendData && eventAny.uploadResult) {
399188
+ if (backendData.uri) {
399189
+ eventAny.uploadResult.uri = backendData.uri;
399190
+ }
399191
+ if (backendData.id) {
399192
+ eventAny.uploadResult.id = backendData.id;
399193
+ }
399194
+ if (backendData.url) {
399195
+ eventAny.uploadResult.url = backendData.url;
399196
+ }
399197
+ }
398526
399198
  const completeEvent = event;
398527
399199
  this.eventBus.emit('complete', completeEvent);
398528
399200
  }
@@ -398574,7 +399246,9 @@ class UploadController {
398574
399246
  type: batch_file_upload_isImage(file) ? 'image' : 'object'
398575
399247
  });
398576
399248
  this.uploadPlugin.on('progress', (event)=>onProgress(event, fileId));
398577
- this.uploadPlugin.on('complete', (event)=>onComplete(event, fileId));
399249
+ this.uploadPlugin.on('complete', (event)=>{
399250
+ onComplete(event, fileId);
399251
+ });
398578
399252
  this.uploadPlugin.on('error', (event)=>onError(event, fileId));
398579
399253
  this.uploadPlugin.on('ready', (event)=>onReady(event, fileId));
398580
399254
  }
@@ -403173,7 +403847,9 @@ const createBatchFileUploadStore = (mark)=>esm_create()(devtools((set, get)=>({
403173
403847
  set(immer_produce((state)=>{
403174
403848
  const baseFileData = {
403175
403849
  percent: 0,
403850
+ fileId: null,
403176
403851
  uri: null,
403852
+ url: null,
403177
403853
  file,
403178
403854
  id,
403179
403855
  status: types_FileStatus.Uploading
@@ -406908,8 +407584,8 @@ const usePaginationRequest = (param)=>{
406908
407584
  // eslint-disable-next-line @coze-arch/max-line-per-function
406909
407585
  const useConversationList = (conversationListParams)=>{
406910
407586
  const { pageSize = 20, initialPageNum = 1, order = 'updated_at' } = conversationListParams ?? {};
406911
- const { chatConfig: { bot_id: botId, appInfo, type: chatType, auth: { connectorId } = {} } } = useChatAppProps();
406912
- const { cozeApiSdk, currentConversationInfo, updateCurrentConversationInfo, conversations, updateConversations } = useChatAppStore(shallow_useShallow((state)=>({
407587
+ const { chatConfig: { bot_id: botId, appInfo, type: chatType, auth: { connectorId } = {} } } = context_useChatAppProps();
407588
+ const { cozeApiSdk, currentConversationInfo, updateCurrentConversationInfo, conversations, updateConversations } = context_useChatAppStore(shallow_useShallow((state)=>({
406913
407589
  cozeApiSdk: state.cozeApi,
406914
407590
  conversations: state.conversations,
406915
407591
  updateCurrentConversationInfo: state.updateCurrentConversationInfo,
@@ -406936,7 +407612,7 @@ const useConversationList = (conversationListParams)=>{
406936
407612
  }
406937
407613
  setAppModeLoading(true);
406938
407614
  try {
406939
- var _res_data;
407615
+ var _res_data, _res_data1;
406940
407616
  const res = await cozeApiSdk.get('/v1/workflow/conversations', {
406941
407617
  app_id: appId,
406942
407618
  workflow_id: workflowId,
@@ -406965,8 +407641,9 @@ const useConversationList = (conversationListParams)=>{
406965
407641
  title: item.title
406966
407642
  }
406967
407643
  }));
406968
- // 判断是否还有更多数据:如果返回的数据量小于 limit,说明没有更多了
406969
- const hasMoreData = convertedConversations.length >= pageSize;
407644
+ // 使用 API 返回的 has_more 字段来判断是否还有更多数据
407645
+ // 如果 API 没有返回 has_more,则根据返回的数据量判断(兼容旧版本)
407646
+ const hasMoreData = ((_res_data1 = res.data) === null || _res_data1 === void 0 ? void 0 : _res_data1.has_more) !== undefined ? res.data.has_more : convertedConversations.length >= pageSize;
406970
407647
  if (beforeTimestamp === undefined) {
406971
407648
  // 首次加载,替换数据
406972
407649
  setAppModeData(convertedConversations);
@@ -406979,9 +407656,9 @@ const useConversationList = (conversationListParams)=>{
406979
407656
  }
406980
407657
  // 更新 before_updated_at:使用返回数据中最小的 updated_at(原始毫秒级时间戳)
406981
407658
  if (convertedConversations.length > 0) {
406982
- var _res_data1;
407659
+ var _res_data2;
406983
407660
  // 从原始数据中找到最小的 updated_at(毫秒级)
406984
- const minUpdatedAtMs = Math.min(...(((_res_data1 = res.data) === null || _res_data1 === void 0 ? void 0 : _res_data1.conversations) || []).map((item)=>item.updated_at || 0));
407661
+ const minUpdatedAtMs = Math.min(...(((_res_data2 = res.data) === null || _res_data2 === void 0 ? void 0 : _res_data2.conversations) || []).map((item)=>item.updated_at || 0));
406985
407662
  if (minUpdatedAtMs > 0) {
406986
407663
  setBeforeUpdatedAt(minUpdatedAtMs);
406987
407664
  } else {
@@ -406991,6 +407668,7 @@ const useConversationList = (conversationListParams)=>{
406991
407668
  // 如果没有返回数据,说明没有更多了
406992
407669
  setAppModeHasMore(false);
406993
407670
  }
407671
+ // 根据 API 返回的 has_more 字段设置状态
406994
407672
  setAppModeHasMore(hasMoreData);
406995
407673
  } catch (e) {
406996
407674
  console.error(e);
@@ -407010,8 +407688,9 @@ const useConversationList = (conversationListParams)=>{
407010
407688
  appModeLoading
407011
407689
  ]);
407012
407690
  // App 模式:首次加载
407691
+ // 只在列表为空且 hasMore 为 true 时才加载,避免 has_more: false 时重复请求
407013
407692
  (0,react.useEffect)(()=>{
407014
- if (isAppType && cozeApiSdk && hasValidId && appModeData.length === 0) {
407693
+ if (isAppType && cozeApiSdk && hasValidId && appModeData.length === 0 && appModeHasMore && !appModeLoading) {
407015
407694
  loadAppModeConversations();
407016
407695
  }
407017
407696
  }, [
@@ -407019,9 +407698,12 @@ const useConversationList = (conversationListParams)=>{
407019
407698
  cozeApiSdk,
407020
407699
  hasValidId,
407021
407700
  loadAppModeConversations,
407022
- appModeData.length
407701
+ appModeData.length,
407702
+ appModeHasMore,
407703
+ appModeLoading
407023
407704
  ]);
407024
407705
  // App 模式:loadMore 函数
407706
+ // 只在 has_more 为 true 时才发送请求
407025
407707
  const appModeLoadMore = (0,react.useCallback)(async ()=>{
407026
407708
  if (appModeHasMore && !appModeLoading && beforeUpdatedAt !== undefined) {
407027
407709
  await loadAppModeConversations(beforeUpdatedAt);
@@ -407717,23 +408399,26 @@ const PcConversationItem = (param)=>{
407717
408399
  },
407718
408400
  children: item.title || intl_i18n.t('web_sdk_conversation_default_name')
407719
408401
  }),
407720
- /*#__PURE__*/ (0,jsx_runtime.jsx)(Operate, {
407721
- onRename: ()=>{
407722
- onRename(item);
407723
- setVisible(false);
407724
- },
407725
- onDelete: ()=>{
407726
- onDelete(item);
407727
- setVisible(false);
407728
- },
407729
- visible: visible,
407730
- setVisible: setVisible,
407731
- children: /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_IconButton, {
407732
- className: conversation_item_pc_index_module["conversation-operate"],
407733
- onClick: handleClick,
407734
- size: "small",
407735
- icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(__webpack_exports__IconCozMore, {}),
407736
- color: "secondary"
408402
+ /*#__PURE__*/ (0,jsx_runtime.jsx)("div", {
408403
+ className: conversation_item_pc_index_module["conversation-operate-wrapper"],
408404
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Operate, {
408405
+ onRename: ()=>{
408406
+ onRename(item);
408407
+ setVisible(false);
408408
+ },
408409
+ onDelete: ()=>{
408410
+ onDelete(item);
408411
+ setVisible(false);
408412
+ },
408413
+ visible: visible,
408414
+ setVisible: setVisible,
408415
+ children: /*#__PURE__*/ (0,jsx_runtime.jsx)(esm_webpack_exports_IconButton, {
408416
+ className: conversation_item_pc_index_module["conversation-operate-button"],
408417
+ onClick: handleClick,
408418
+ size: "small",
408419
+ icon: /*#__PURE__*/ (0,jsx_runtime.jsx)(__webpack_exports__IconCozMore, {}),
408420
+ color: "secondary"
408421
+ })
407737
408422
  })
407738
408423
  })
407739
408424
  ]
@@ -407802,7 +408487,7 @@ var conversation_list_index_module_update = injectStylesIntoStyleTag_default()(c
407802
408487
  const ConversationList = /*#__PURE__*/ (0,react.forwardRef)(// eslint-disable-next-line @coze-arch/max-line-per-function
407803
408488
  (param, ref)=>{
407804
408489
  let { onRename, onDelete, loading, groupedConversations, conversations, hasMore, loadMore, removeConversation } = param;
407805
- const { currentConversationInfo, updateCurrentConversationInfo, cozeApi, updateConversations } = useChatAppStore(shallow_useShallow((state)=>({
408490
+ const { currentConversationInfo, updateCurrentConversationInfo, cozeApi, updateConversations } = context_useChatAppStore(shallow_useShallow((state)=>({
407806
408491
  currentConversationInfo: state.currentConversationInfo,
407807
408492
  updateCurrentConversationInfo: state.updateCurrentConversationInfo,
407808
408493
  cozeApi: state.cozeApi,
@@ -407811,7 +408496,7 @@ const ConversationList = /*#__PURE__*/ (0,react.forwardRef)(// eslint-disable-ne
407811
408496
  const conversationRef = (0,react.useRef)();
407812
408497
  const [addLoading, setAddLoading] = (0,react.useState)(false);
407813
408498
  const isCreatingRef = (0,react.useRef)(false);
407814
- const { layout, chatConfig: { type: chatType } } = useChatAppProps();
408499
+ const { layout, chatConfig: { type: chatType } } = context_useChatAppProps();
407815
408500
  // 确保 conversationRef 与 currentConversationInfo 保持同步
407816
408501
  // 这样在重载页面后,getConversationInfo 也能返回正确的值
407817
408502
  // 注意:即使 id 为空字符串,也要更新 conversationRef,以便 getConversationInfo 返回空会话
@@ -408140,13 +408825,13 @@ var conversation_list_sider_index_module_update = injectStylesIntoStyleTag_defau
408140
408825
  /* eslint-disable @coze-arch/max-line-per-function -- This component handles complex conversation list sidebar logic */ const ConversationListSider = /*#__PURE__*/ (0,react.forwardRef)((param, ref)=>{
408141
408826
  let { children } = param;
408142
408827
  const conversationListRef = (0,react.useRef)(null);
408143
- const { currentConversationInfo, updateConversations, updateCurrentConversationInfo, cozeApi } = useChatAppStore(shallow_useShallow((state)=>({
408828
+ const { currentConversationInfo, updateConversations, updateCurrentConversationInfo, cozeApi } = context_useChatAppStore(shallow_useShallow((state)=>({
408144
408829
  currentConversationInfo: state.currentConversationInfo,
408145
408830
  updateConversations: state.updateConversations,
408146
408831
  updateCurrentConversationInfo: state.updateCurrentConversationInfo,
408147
408832
  cozeApi: state.cozeApi
408148
408833
  })));
408149
- const { chatConfig: { type: chatType } } = useChatAppProps();
408834
+ const { chatConfig: { type: chatType } } = context_useChatAppProps();
408150
408835
  const { loading, conversations, hasMore, loadMore, removeConversation } = useConversationList();
408151
408836
  const groupedConversations = useGroupedConversations(conversations);
408152
408837
  const [isModalLoading, setIsModalLoading] = (0,react.useState)(false);
@@ -408814,7 +409499,7 @@ const ChatPropsProvider = (param)=>{
408814
409499
  }) : children
408815
409500
  });
408816
409501
  };
408817
- const useChatAppProps = ()=>{
409502
+ const context_useChatAppProps = ()=>{
408818
409503
  const { appProps } = (0,react.useContext)(ChatPropsContext);
408819
409504
  const { chatConfig = {
408820
409505
  conversation_id: index_browser_nanoid(),
@@ -408828,7 +409513,7 @@ const useChatAppProps = ()=>{
408828
409513
  enableReplacePrologueNicknameWithVar
408829
409514
  };
408830
409515
  };
408831
- const useChatAppStore = (selector)=>{
409516
+ const context_useChatAppStore = (selector)=>{
408832
409517
  const { store } = (0,react.useContext)(ChatPropsContext);
408833
409518
  if (!store) {
408834
409519
  throw ChatSdkError.create(error_SDKErrorCode.StoreProvider);
@@ -408854,8 +409539,8 @@ const useChatAppStore = (selector)=>{
408854
409539
  */
408855
409540
  const useIsShowBackground = ()=>{
408856
409541
  var _backgroundInfo_mobile_background_image;
408857
- const backgroundInfo = useChatAppStore((s)=>s.backgroundInfo);
408858
- const { isCustomBackground } = useChatAppProps();
409542
+ const backgroundInfo = context_useChatAppStore((s)=>s.backgroundInfo);
409543
+ const { isCustomBackground } = context_useChatAppProps();
408859
409544
  // 自定义背景图,或者背景图有数据,则有背景状态
408860
409545
  return isCustomBackground || !!(backgroundInfo === null || backgroundInfo === void 0 ? void 0 : (_backgroundInfo_mobile_background_image = backgroundInfo.mobile_background_image) === null || _backgroundInfo_mobile_background_image === void 0 ? void 0 : _backgroundInfo_mobile_background_image.origin_image_url) || false;
408861
409546
  };
@@ -412906,13 +413591,23 @@ const createSDKUploadPluginClass = (param)=>{
412906
413591
  this.file = props.file;
412907
413592
  this.fileType = props.type;
412908
413593
  this.upload().then((meta)=>{
413594
+ // Backend returns: { uri: "xxx", id: "yyy", url: "zzz" }
413595
+ // meta.uri should be the real URI (not the id)
413596
+ // meta.id should be the backend file ID
413597
+ // UploadResult structure requires dynamic properties, using type assertion
413598
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any -- UploadResult structure requires dynamic properties
413599
+ const uploadResult = {
413600
+ Uri: meta.uri,
413601
+ Url: meta.url
413602
+ };
413603
+ // Add id if available
413604
+ if (meta.id) {
413605
+ uploadResult.Id = meta.id;
413606
+ }
412909
413607
  this.eventBus.emit('complete', {
412910
413608
  percent: 100,
412911
413609
  status: types_FileStatus.Success,
412912
- uploadResult: {
412913
- Uri: meta.uri,
412914
- Url: meta.url
412915
- },
413610
+ uploadResult,
412916
413611
  type: 'success'
412917
413612
  });
412918
413613
  }).catch((err)=>{
@@ -413011,7 +413706,7 @@ studioOpenClientReporter.init(studio_open_client_reporter_slardarInstance);
413011
413706
 
413012
413707
  const useUpdateConversationNameByMessage = ()=>{
413013
413708
  const currentConversationNameRef = (0,react.useRef)();
413014
- const { updateCurrentConversationNameByMessage, currentConversationInfo } = useChatAppStore(shallow_useShallow((s)=>({
413709
+ const { updateCurrentConversationNameByMessage, currentConversationInfo } = context_useChatAppStore(shallow_useShallow((s)=>({
413015
413710
  updateCurrentConversationNameByMessage: s.updateCurrentConversationNameByMessage,
413016
413711
  currentConversationInfo: s.currentConversationInfo
413017
413712
  })));
@@ -413055,7 +413750,7 @@ const useUpdateConversationNameByMessage = ()=>{
413055
413750
 
413056
413751
 
413057
413752
  const useUserInfo = ()=>{
413058
- const userInfo = useChatAppStore((s)=>s.userInfo);
413753
+ const userInfo = context_useChatAppStore((s)=>s.userInfo);
413059
413754
  return (0,react.useMemo)(()=>{
413060
413755
  const openUserInfo = userInfo;
413061
413756
  if (!openUserInfo || !openUserInfo.id) {
@@ -416016,9 +416711,9 @@ class CozeApiCustom extends CozeAPI {
416016
416711
 
416017
416712
 
416018
416713
  const useApiClient = ()=>{
416019
- const { debug } = useChatAppProps();
416714
+ const { debug } = context_useChatAppProps();
416020
416715
  const { token = '', refreshToken: refreshTokenRaw, setToken, setCozeApi, // 从 store 中获取 apiUrl
416021
- apiUrl } = useChatAppStore(shallow_useShallow((s)=>({
416716
+ apiUrl } = context_useChatAppStore(shallow_useShallow((s)=>({
416022
416717
  token: s.token,
416023
416718
  setToken: s.setToken,
416024
416719
  refreshToken: s.refreshToken,
@@ -416145,9 +416840,20 @@ const useUploadFileApi = ()=>{
416145
416840
  const result = await (cozeApiSdk === null || cozeApiSdk === void 0 ? void 0 : cozeApiSdk.files.upload({
416146
416841
  file
416147
416842
  }));
416843
+ // Backend response structure may vary, using type assertion for flexibility
416844
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Backend response structure varies
416845
+ const resultAny = result;
416846
+ // Backend returns: { data: { uri: "xxx", id: "yyy", url: "zzz" } }
416847
+ // Or possibly: { id: "yyy", uri: "xxx", url: "zzz" }
416848
+ // We need to extract both uri and id correctly
416849
+ const backendData = (resultAny === null || resultAny === void 0 ? void 0 : resultAny.data) || resultAny;
416850
+ const uri = (backendData === null || backendData === void 0 ? void 0 : backendData.uri) || ''; // Real URI from backend
416851
+ const id = (backendData === null || backendData === void 0 ? void 0 : backendData.id) || (resultAny === null || resultAny === void 0 ? void 0 : resultAny.id) || ''; // Backend file ID
416852
+ const url = (backendData === null || backendData === void 0 ? void 0 : backendData.url) || (resultAny === null || resultAny === void 0 ? void 0 : resultAny.url) || '';
416148
416853
  return {
416149
- uri: (result === null || result === void 0 ? void 0 : result.id) || '',
416150
- url: ''
416854
+ uri: uri || id,
416855
+ url,
416856
+ id: id || undefined
416151
416857
  };
416152
416858
  }, [
416153
416859
  cozeApiSdk
@@ -416270,7 +416976,45 @@ const convertShortcutData = (shortcutCommands, botInfo)=>//@ts-expect-error: 不
416270
416976
 
416271
416977
 
416272
416978
 
416979
+
416980
+
416981
+
416273
416982
  const microSeconds = 1000;
416983
+ /**
416984
+ * 从URL中提取文件名
416985
+ * @param url 文件URL
416986
+ * @returns 文件名,如果无法提取则返回空字符串
416987
+ */ const extractFileNameFromUrl = (url)=>{
416988
+ if (!url) {
416989
+ return '';
416990
+ }
416991
+ try {
416992
+ const urlObj = new URL(url);
416993
+ const { pathname } = urlObj;
416994
+ let fileName = pathname.split('/').pop() || '';
416995
+ // 移除查询参数和hash
416996
+ fileName = fileName.split('?')[0].split('#')[0] || '';
416997
+ // 解码URI编码的文件名
416998
+ try {
416999
+ return decodeURIComponent(fileName);
417000
+ } catch {
417001
+ // 如果解码失败,返回原始文件名
417002
+ return fileName;
417003
+ }
417004
+ } catch {
417005
+ // 如果不是有效的URL,尝试直接解析路径
417006
+ const parts = url.split('/');
417007
+ let fileName = parts[parts.length - 1] || '';
417008
+ fileName = fileName.split('?')[0].split('#')[0] || '';
417009
+ // 解码URI编码的文件名
417010
+ try {
417011
+ return decodeURIComponent(fileName);
417012
+ } catch {
417013
+ // 如果解码失败,返回原始文件名
417014
+ return fileName;
417015
+ }
417016
+ }
417017
+ };
416274
417018
  // 消息转换成 Coze的消息,主要用于消息接收后,在页面显示。
416275
417019
  class MessageConverseToCoze {
416276
417020
  convertMessageListResponse(res) {
@@ -416421,22 +417165,25 @@ class MessageConverseToCoze {
416421
417165
  }
416422
417166
  case 'file':
416423
417167
  {
416424
- const { fileType = const_FileTypeEnum.DEFAULT_UNKNOWN } = // @ts-expect-error -- linter-disable-autofix, 新添加参数,sdk中还未支持到
416425
- getFileInfo(new File([], item === null || item === void 0 ? void 0 : item.name)) || {};
416426
- return {
417168
+ const fileName = (item === null || item === void 0 ? void 0 : item.name) || extractFileNameFromUrl(item === null || item === void 0 ? void 0 : item.file_url);
417169
+ const { fileType = const_FileTypeEnum.DEFAULT_UNKNOWN } = getFileInfo(new File([], fileName)) || {};
417170
+ console.log('convertMixContent file', item);
417171
+ // 当没有 file_id 时,使用 file_url 作为 file_key
417172
+ const fileKey = item.file_id || item.file_url || '';
417173
+ const fileData = {
416427
417174
  type: types_ContentType.File,
416428
417175
  file: {
416429
- file_key: item.file_id || '',
416430
- // @ts-expect-error -- linter-disable-autofix, 新添加参数,sdk中还未支持到
416431
- file_name: item === null || item === void 0 ? void 0 : item.name,
416432
- // @ts-expect-error -- linter-disable-autofix, 新添加参数,sdk中还未支持到
416433
- file_size: item === null || item === void 0 ? void 0 : item.size,
417176
+ file_key: fileKey,
417177
+ file_name: fileName || '未知文件',
417178
+ file_size: (item === null || item === void 0 ? void 0 : item.size) ?? 0,
416434
417179
  file_type: fileType,
416435
- file_url: item === null || item === void 0 ? void 0 : item.file_url
417180
+ file_url: (item === null || item === void 0 ? void 0 : item.file_url) || ''
416436
417181
  },
416437
417182
  // @ts-expect-error -- linter-disable-autofix
416438
417183
  is_refer: item.is_refer || undefined
416439
417184
  };
417185
+ console.log('convertMixContent file result', fileData);
417186
+ return fileData;
416440
417187
  }
416441
417188
  case 'json':
416442
417189
  {
@@ -416485,7 +417232,7 @@ const messageConverterToCoze = new MessageConverseToCoze();
416485
417232
 
416486
417233
  const useMessageList = ()=>{
416487
417234
  const getMessageListByPairs = useGetMessageListByPairs();
416488
- const { chatConfig } = useChatAppProps();
417235
+ const { chatConfig } = context_useChatAppProps();
416489
417236
  const { bot_id: botId } = chatConfig || {};
416490
417237
  const { refMessageListLeft } = useChatCozeSdk();
416491
417238
  return (0,react.useMemo)(()=>{
@@ -416716,14 +417463,14 @@ const getCustomInitInfo = async (param)=>{
416716
417463
  };
416717
417464
  const useRequestInit = ()=>{
416718
417465
  var _chatConfig_auth;
416719
- const { chatConfig, openRequestInit, defaultHistoryMessage = [], onDefaultHistoryClear } = useChatAppProps();
417466
+ const { chatConfig, openRequestInit, defaultHistoryMessage = [], onDefaultHistoryClear } = context_useChatAppProps();
416720
417467
  const { cozeApiSdk } = useChatCozeSdk();
416721
- const setInitError = useChatAppStore((s)=>s.setInitError);
416722
- const setDefaultInputMode = useChatAppStore((s)=>s.setDefaultInputMode);
416723
- const updateShortcuts = useChatAppStore((s)=>s.updateShortcuts);
416724
- const setIsStartBotVoiceCall = useChatAppStore((s)=>s.setIsStartBotVoiceCall);
416725
- const updateBackgroundInfo = useChatAppStore((s)=>s.updateBackgroundInfo);
416726
- const { currentConversationInfo, updateCurrentConversationInfo, conversations } = useChatAppStore(shallow_useShallow((s)=>({
417468
+ const setInitError = context_useChatAppStore((s)=>s.setInitError);
417469
+ const setDefaultInputMode = context_useChatAppStore((s)=>s.setDefaultInputMode);
417470
+ const updateShortcuts = context_useChatAppStore((s)=>s.updateShortcuts);
417471
+ const setIsStartBotVoiceCall = context_useChatAppStore((s)=>s.setIsStartBotVoiceCall);
417472
+ const updateBackgroundInfo = context_useChatAppStore((s)=>s.updateBackgroundInfo);
417473
+ const { currentConversationInfo, updateCurrentConversationInfo, conversations } = context_useChatAppStore(shallow_useShallow((s)=>({
416727
417474
  currentConversationInfo: s.currentConversationInfo,
416728
417475
  updateCurrentConversationInfo: s.updateCurrentConversationInfo,
416729
417476
  conversations: s.conversations
@@ -416911,7 +417658,7 @@ const useRequestInit = ()=>{
416911
417658
 
416912
417659
 
416913
417660
  const useClearMessageContextAdapter = ()=>{
416914
- const { chatConfig: { type: chatType } } = useChatAppProps();
417661
+ const { chatConfig: { type: chatType } } = context_useChatAppProps();
416915
417662
  return (0,react.useMemo)(()=>{
416916
417663
  const isAppType = chatType === client_ChatType.APP;
416917
417664
  const baseUrl = isAppType ? '/v1/workflow/conversations/:conversation_id/clear' : '/v1/conversations/:conversation_id/clear';
@@ -416953,6 +417700,35 @@ const useClearMessageContextAdapter = ()=>{
416953
417700
  ]);
416954
417701
  };
416955
417702
 
417703
+ ;// CONCATENATED MODULE: ../open-chat/src/chat/builder-chat/helper/get-connector-id.ts
417704
+ /*
417705
+ * Copyright 2025 coze-dev Authors
417706
+ *
417707
+ * Licensed under the Apache License, Version 2.0 (the "License");
417708
+ * you may not use this file except in compliance with the License.
417709
+ * You may obtain a copy of the License at
417710
+ *
417711
+ * http://www.apache.org/licenses/LICENSE-2.0
417712
+ *
417713
+ * Unless required by applicable law or agreed to in writing, software
417714
+ * distributed under the License is distributed on an "AS IS" BASIS,
417715
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
417716
+ * See the License for the specific language governing permissions and
417717
+ * limitations under the License.
417718
+ */
417719
+ const getConnectorId = (props)=>{
417720
+ const { project } = props;
417721
+ const { mode, connectorId } = project || {};
417722
+ if (!connectorId) {
417723
+ if (mode === 'websdk') {
417724
+ return webSdkDefaultConnectorId;
417725
+ } else if (mode === 'draft') {
417726
+ return chatflowDraftConnectorId;
417727
+ }
417728
+ }
417729
+ return connectorId;
417730
+ };
417731
+
416956
417732
  ;// CONCATENATED MODULE: ../open-chat/src/chat/builder-chat/services/create-conversation.ts
416957
417733
  /*
416958
417734
  * Copyright 2025 coze-dev Authors
@@ -416970,6 +417746,7 @@ const useClearMessageContextAdapter = ()=>{
416970
417746
  * limitations under the License.
416971
417747
  */
416972
417748
 
417749
+
416973
417750
  // 用于发送消息时创建 conversation 的函数
416974
417751
  const createConversationForMessage = async (apiSdk, props)=>{
416975
417752
  let conversationId = '';
@@ -417090,13 +417867,87 @@ const createConversationForMessage = async (apiSdk, props)=>{
417090
417867
  throw new Error(`Failed to create conversation: ${JSON.stringify(error)}`);
417091
417868
  }
417092
417869
  };
417093
- const createOrGetConversation = (apiSdk, props)=>// 初始化时不创建 conversation,返回空值
417870
+ const createOrGetConversation = async (apiSdk, props)=>{
417871
+ // 如果没有 conversationName,保持现有行为:不创建会话,返回空值
417094
417872
  // conversation 将在用户发送第一条消息时创建
417095
- Promise.resolve({
417873
+ if (!props.project.conversationName || props.project.conversationName.trim() === '') {
417874
+ return {
417875
+ conversationId: '',
417876
+ sectionId: '',
417877
+ conversationName: undefined
417878
+ };
417879
+ }
417880
+ // 如果有 conversationName,在初始化时就创建/获取会话
417881
+ if (props.project.type === 'app') {
417882
+ try {
417883
+ const connectorId = getConnectorId(props);
417884
+ const createPayload = {
417885
+ app_id: props.project.id,
417886
+ draft_mode: props.project.mode === 'draft',
417887
+ workflow_id: props.workflow.id || '',
417888
+ connector_id: connectorId,
417889
+ get_or_create: true,
417890
+ conversation_name: props.project.conversationName
417891
+ };
417892
+ const res = await (apiSdk === null || apiSdk === void 0 ? void 0 : apiSdk.post('/v1/workflow/conversation/create', createPayload, false, {
417893
+ headers: {
417894
+ 'Accept-Language': intl.language === 'zh-CN' ? 'zh' : 'en'
417895
+ }
417896
+ }));
417897
+ if ((res === null || res === void 0 ? void 0 : res.code) === 0 && (res === null || res === void 0 ? void 0 : res.data)) {
417898
+ const conversationId = res.data.id || '';
417899
+ const sectionId = res.data.last_section_id || '';
417900
+ // 确保 conversationId 不为空
417901
+ if (!conversationId || conversationId.trim() === '') {
417902
+ throw new Error('Failed to create conversation: empty conversationId returned');
417903
+ }
417904
+ // 获取会话详情以获取 conversation_name
417905
+ let conversationName = undefined;
417906
+ if (conversationId) {
417907
+ try {
417908
+ const detailRes = await (apiSdk === null || apiSdk === void 0 ? void 0 : apiSdk.get(`/v1/workflow/conversations/${conversationId}`, {
417909
+ app_id: props.project.id,
417910
+ workflow_id: props.workflow.id || '',
417911
+ connector_id: connectorId
417912
+ }));
417913
+ if ((detailRes === null || detailRes === void 0 ? void 0 : detailRes.code) === 0 && (detailRes === null || detailRes === void 0 ? void 0 : detailRes.data)) {
417914
+ const name = detailRes.data.conversation_name || detailRes.data.name || detailRes.data.title;
417915
+ conversationName = name || undefined;
417916
+ }
417917
+ } catch (detailError) {
417918
+ console.warn('Failed to fetch conversation detail:', detailError);
417919
+ conversationName = props.project.conversationName;
417920
+ }
417921
+ }
417922
+ return {
417923
+ conversationId,
417924
+ sectionId,
417925
+ conversationName: conversationName || props.project.conversationName
417926
+ };
417927
+ } else {
417928
+ const errorMsg = (res === null || res === void 0 ? void 0 : res.msg) || `code=${(res === null || res === void 0 ? void 0 : res.code) ?? 'unknown'}`;
417929
+ throw new Error(`Failed to create conversation: ${errorMsg}`);
417930
+ }
417931
+ } catch (error) {
417932
+ console.error('createOrGetConversation error:', error);
417933
+ // 如果创建失败,返回空值,让系统在发送消息时再创建
417934
+ if (error instanceof Error) {
417935
+ console.warn('Failed to create conversation during init, will create on first message:', error.message);
417936
+ }
417937
+ return {
417938
+ conversationId: '',
417939
+ sectionId: '',
417940
+ conversationName: undefined
417941
+ };
417942
+ }
417943
+ }
417944
+ // Bot 模式:保持现有行为,不在这里创建会话
417945
+ return {
417096
417946
  conversationId: '',
417097
417947
  sectionId: '',
417098
417948
  conversationName: undefined
417099
- });
417949
+ };
417950
+ };
417100
417951
 
417101
417952
  ;// CONCATENATED MODULE: ../open-chat/src/components/studio-open-chat/provider/coz-sdk/api-adapter/message/message-convert-to-sdk.ts
417102
417953
  /*
@@ -417208,10 +418059,12 @@ class MessageConverterToSdk {
417208
418059
  case types_ContentType.Image:
417209
418060
  {
417210
418061
  var _item_image_image_ori;
418062
+ // Use id (backend file ID) if available, fallback to key (URI) for backward compatibility
418063
+ const fileId = item.image.id || item.image.key;
417211
418064
  return {
417212
418065
  type: 'image',
417213
- file_id: item.image.key,
417214
- file_url: isNeedFileUrl || !item.image.key ? (_item_image_image_ori = item.image.image_ori) === null || _item_image_image_ori === void 0 ? void 0 : _item_image_image_ori.url : undefined,
418066
+ file_id: fileId,
418067
+ file_url: isNeedFileUrl || !fileId ? (_item_image_image_ori = item.image.image_ori) === null || _item_image_image_ori === void 0 ? void 0 : _item_image_image_ori.url : undefined,
417215
418068
  // @ts-expect-error -- linter-disable-autofix
417216
418069
  is_refer: item.is_refer || undefined
417217
418070
  };
@@ -417219,9 +418072,11 @@ class MessageConverterToSdk {
417219
418072
  case types_ContentType.File:
417220
418073
  {
417221
418074
  var _item_file;
418075
+ // Use file_id (backend file ID) if available, fallback to file_key (URI) for backward compatibility
418076
+ const fileId = item.file.file_id || item.file.file_key;
417222
418077
  return {
417223
418078
  type: 'file',
417224
- file_id: item.file.file_key || !item.file.file_key,
418079
+ file_id: fileId,
417225
418080
  file_url: isNeedFileUrl ? (_item_file = item.file) === null || _item_file === void 0 ? void 0 : _item_file.file_url : undefined,
417226
418081
  // @ts-expect-error -- linter-disable-autofix
417227
418082
  is_refer: item.is_refer || undefined
@@ -419238,8 +420093,8 @@ class MessageParser {
419238
420093
 
419239
420094
  /* eslint-disable @coze-arch/max-line-per-function -- This adapter function handles complex message sending logic */ const useSendMessageAdapter = (userInfo, refChatFunc)=>{
419240
420095
  var _chatConfig_auth;
419241
- const { debug, chatConfig } = useChatAppProps();
419242
- const { shortcuts, apiUrl, updateConversations, updateCurrentConversationInfo, currentConversationInfo, conversations, cozeApi } = useChatAppStore(shallow_useShallow((state)=>({
420096
+ const { debug, chatConfig } = context_useChatAppProps();
420097
+ const { shortcuts, apiUrl, updateConversations, updateCurrentConversationInfo, currentConversationInfo, conversations, cozeApi } = context_useChatAppStore(shallow_useShallow((state)=>({
419243
420098
  shortcuts: state.shortcuts,
419244
420099
  apiUrl: state.apiUrl,
419245
420100
  updateConversations: state.updateConversations,
@@ -419616,7 +420471,7 @@ class MessageParser {
419616
420471
  const useClearHistoryAdapter = (param)=>{
419617
420472
  let { refChatFunc } = param;
419618
420473
  var _chatConfig_auth;
419619
- const { chatConfig } = useChatAppProps();
420474
+ const { chatConfig } = context_useChatAppProps();
419620
420475
  const refConnectorId = (0,react.useRef)('');
419621
420476
  refConnectorId.current = (chatConfig === null || chatConfig === void 0 ? void 0 : (_chatConfig_auth = chatConfig.auth) === null || _chatConfig_auth === void 0 ? void 0 : _chatConfig_auth.connectorId) || '';
419622
420477
  return (0,react.useMemo)(()=>{
@@ -419680,7 +420535,7 @@ const useClearHistoryAdapter = (param)=>{
419680
420535
 
419681
420536
 
419682
420537
  const useCommonOnBeforeRequestHooks = ()=>{
419683
- const { debug } = useChatAppProps();
420538
+ const { debug } = context_useChatAppProps();
419684
420539
  return [
419685
420540
  // 去除无用的头部
419686
420541
  (requestConfig)=>{
@@ -419805,7 +420660,7 @@ const useCoreManager = (param)=>{
419805
420660
  const userInfo = useUserInfo();
419806
420661
  const { refreshToken } = useChatCozeSdk();
419807
420662
  // 获取 apiUrl
419808
- const { apiUrl } = useChatAppStore(shallow_useShallow((s)=>({
420663
+ const { apiUrl } = context_useChatAppStore(shallow_useShallow((s)=>({
419809
420664
  apiUrl: s.apiUrl
419810
420665
  })));
419811
420666
  const clearMessageContextAdapter = useClearMessageContextAdapter();
@@ -419817,7 +420672,7 @@ const useCoreManager = (param)=>{
419817
420672
  const commonOnAfterResponseHooks = useCommonOnAfterResponseHooks(refreshToken);
419818
420673
  const commonErrorResponseHooks = useCommonErrorResponseHooks(refreshToken);
419819
420674
  const messageListAdapter = useMessageList();
419820
- const { requestManagerOptions } = useChatAppProps();
420675
+ const { requestManagerOptions } = context_useChatAppProps();
419821
420676
  const breakMessageAdapter = useBreakMessage();
419822
420677
  // 计算最终的 baseURL
419823
420678
  const finalBaseURL = apiUrl || openApiHostByRegionWithToken;
@@ -419871,7 +420726,7 @@ const useCoreManager = (param)=>{
419871
420726
 
419872
420727
  const useCoreOverrideConfig = (param)=>{
419873
420728
  let { refChatFunc } = param;
419874
- const { chatConfig } = useChatAppProps();
420729
+ const { chatConfig } = context_useChatAppProps();
419875
420730
  const { tokenManager } = useChatCozeSdk();
419876
420731
  const requestManagerOptions = useCoreManager({
419877
420732
  refChatFunc
@@ -420025,10 +420880,10 @@ const services_life_cycle_bizLifeCycleServiceGenerator = (plugin)=>({
420025
420880
 
420026
420881
  const useMessageGroupFooterInfo = (messageGroup)=>{
420027
420882
  var _messageInfo_extra_info;
420028
- const feedbackInfo = useChatAppStore((s)=>s.feedbackInfo);
420883
+ const feedbackInfo = context_useChatAppStore((s)=>s.feedbackInfo);
420029
420884
  const { useMessagesStore } = use_chat_area_context_useChatAreaStoreSet();
420030
420885
  const { findMessage } = useMessagesStore.getState();
420031
- const lastGroupFeedbackInfo = useChatAppStore((s)=>s.lastGroupFeedbackInfo);
420886
+ const lastGroupFeedbackInfo = context_useChatAppStore((s)=>s.lastGroupFeedbackInfo);
420032
420887
  const { messageId } = lastGroupFeedbackInfo;
420033
420888
  const messageInfo = findMessage(messageId || '');
420034
420889
  // @ts-expect-error -- linter-disable-autofix, 新添加参数,接口未支持
@@ -421705,7 +422560,7 @@ const BotTriggerConfigButtonGroup = (param)=>{
421705
422560
  const useCurMessageInfo = ()=>{
421706
422561
  var _chatConfig_ui_chatBot, _chatConfig_ui;
421707
422562
  const { message } = message_box_useMessageBoxContext();
421708
- const { chatConfig } = useChatAppProps();
422563
+ const { chatConfig } = context_useChatAppProps();
421709
422564
  // @ts-expect-error -- linter-disable-autofix, 新添加参数,接口未支持
421710
422565
  const cozeApiMessageId = message.extra_info.coze_api_message_id;
421711
422566
  // @ts-expect-error -- linter-disable-autofix, 新添加参数,接口未支持
@@ -421812,7 +422667,7 @@ const delete_message_DeleteMessage = (param)=>{
421812
422667
  const { useGlobalInitStore } = storeSet;
421813
422668
  const { groupId } = message_box_useMessageBoxContext();
421814
422669
  const isDeleteMessageLock = use_is_delete_message_lock_useIsDeleteMessageLock(groupId);
421815
- const { chatConfig } = useChatAppProps();
422670
+ const { chatConfig } = context_useChatAppProps();
421816
422671
  const deleteMessage = useDeleteMessage();
421817
422672
  const conversationId = useGlobalInitStore((state)=>state.conversationId);
421818
422673
  const { messageId, cozeApiMessageId, isShowDelete } = useCurMessageInfo();
@@ -421913,7 +422768,7 @@ const useMessageHoverInfo = ()=>{
421913
422768
  const UIKitMessageBoxHoverSlot = ()=>{
421914
422769
  const { meta } = message_box_useMessageBoxContext();
421915
422770
  const { message } = message_box_useMessageBoxContext();
421916
- const { readonly } = useChatAppProps();
422771
+ const { readonly } = context_useChatAppProps();
421917
422772
  const isLastGroupMessage = meta.isGroupLastMessage && meta.isFromLatestGroup && (message === null || message === void 0 ? void 0 : message.type) === 'answer';
421918
422773
  if (isLastGroupMessage || readonly) {
421919
422774
  /*
@@ -422091,7 +422946,7 @@ const UIKitMessageBoxFooter = (param)=>{
422091
422946
  const { meta } = message_box_useMessageBoxContext();
422092
422947
  const { message } = message_box_useMessageBoxContext();
422093
422948
  const { useWaitingStore } = use_chat_area_context_useChatAreaStoreSet();
422094
- const { readonly } = useChatAppProps();
422949
+ const { readonly } = context_useChatAppProps();
422095
422950
  const waiting = useWaitingStore((state)=>!!state.waiting);
422096
422951
  const isAnswerMessage = message.type === 'answer';
422097
422952
  const isLastGroupMessage = meta.isGroupLastMessage && meta.isFromLatestGroup;
@@ -422582,8 +423437,8 @@ const createChatBackgroundPlugin = ()=>{
422582
423437
 
422583
423438
  const useBgBackgroundPlugin = ()=>{
422584
423439
  const { ChatBackgroundPlugin, chatBackgroundEvent } = (0,react.useMemo)(()=>createChatBackgroundPlugin(), []);
422585
- const { isCustomBackground } = useChatAppProps();
422586
- const backgroundInfo = useChatAppStore((s)=>s.backgroundInfo);
423440
+ const { isCustomBackground } = context_useChatAppProps();
423441
+ const backgroundInfo = context_useChatAppStore((s)=>s.backgroundInfo);
422587
423442
  const backgroundInfoToShow = isCustomBackground ? undefined : backgroundInfo;
422588
423443
  (0,react.useEffect)(()=>{
422589
423444
  // 监听用户设置背景图,将更新的背景图信息传入插件
@@ -422643,8 +423498,8 @@ const useBgBackgroundPlugin = ()=>{
422643
423498
  const ChatProviderFuncComp = /*#__PURE__*/ (0,react.forwardRef)((param, ref)=>{
422644
423499
  let { children } = param;
422645
423500
  var _chatConfig_ui_conversations, _chatConfig_ui;
422646
- const { chatConfig } = useChatAppProps();
422647
- const { updateCurrentConversationInfo, currentConversationInfo, updateConversations, conversations } = useChatAppStore(shallow_useShallow((s)=>({
423501
+ const { chatConfig } = context_useChatAppProps();
423502
+ const { updateCurrentConversationInfo, currentConversationInfo, updateConversations, conversations } = context_useChatAppStore(shallow_useShallow((s)=>({
422648
423503
  updateCurrentConversationInfo: s.updateCurrentConversationInfo,
422649
423504
  currentConversationInfo: s.currentConversationInfo,
422650
423505
  updateConversations: s.updateConversations,
@@ -422759,12 +423614,12 @@ const ChatProviderImpl = (param)=>{
422759
423614
  var _chatConfig_ui, _chatConfig_appInfo, _chatConfig_ui_chatBot, _chatConfig_ui1;
422760
423615
  const refLastIsError = (0,react.useRef)(false);
422761
423616
  const { refreshToken } = useChatCozeSdk();
422762
- const { initError, setInitError } = useChatAppStore(shallow_useShallow((s)=>({
423617
+ const { initError, setInitError } = context_useChatAppStore(shallow_useShallow((s)=>({
422763
423618
  initError: s.initError,
422764
423619
  setInitError: s.setInitError
422765
423620
  })));
422766
423621
  const refChatFunc = (0,react.useRef)();
422767
- const { chatConfig, onImageClick, initErrorFallbackFC: ErrorFallback } = useChatAppProps();
423622
+ const { chatConfig, onImageClick, initErrorFallbackFC: ErrorFallback } = context_useChatAppProps();
422768
423623
  const userInfoRaw = useUserInfo();
422769
423624
  // 确保 userInfo 始终有效,即使 useUserInfo 返回 null(虽然不应该)
422770
423625
  const userInfo = userInfoRaw && userInfoRaw.id ? userInfoRaw : {
@@ -422933,8 +423788,8 @@ const ChatProvider = (param)=>{
422933
423788
  const provider_ChatProvider = (param)=>{
422934
423789
  let { children, plugins } = param;
422935
423790
  var _chatConfig_extra;
422936
- const { chatConfig, onImageClick, onThemeChange } = useChatAppProps();
422937
- const setInitError = useChatAppStore((s)=>s.setInitError);
423791
+ const { chatConfig, onImageClick, onThemeChange } = context_useChatAppProps();
423792
+ const setInitError = context_useChatAppStore((s)=>s.setInitError);
422938
423793
  // plugin初始化
422939
423794
  const commonChatPlugin = getChatCommonPlugin({
422940
423795
  onImageClick,
@@ -434413,7 +435268,7 @@ const shortcut_bar_ShortcutBar = (param)=>{
434413
435268
  var _shortcuts_at;
434414
435269
  const activeShortcutRef = (0,react.useRef)(undefined);
434415
435270
  const showBackground = useIsShowBackground();
434416
- const shortcuts = useChatAppStore((store)=>store.shortcuts);
435271
+ const shortcuts = context_useChatAppStore((store)=>store.shortcuts);
434417
435272
  const defaultId = (_shortcuts_at = shortcuts.at(0)) === null || _shortcuts_at === void 0 ? void 0 : _shortcuts_at.command_id;
434418
435273
  if (!(shortcuts === null || shortcuts === void 0 ? void 0 : shortcuts.length)) {
434419
435274
  return null;
@@ -434523,7 +435378,7 @@ const IconAddNewConversation = (param)=>{
434523
435378
 
434524
435379
  const useChatOpInfo = ()=>{
434525
435380
  var _chatConfig_ui_header, _chatConfig_ui;
434526
- const { chatConfig } = useChatAppProps();
435381
+ const { chatConfig } = context_useChatAppProps();
434527
435382
  const chatInputLeftOps = [];
434528
435383
  const headerTopLeftOps = [];
434529
435384
  console.log('useChatOpInfo:', chatConfig);
@@ -434565,7 +435420,7 @@ const useChatOpInfo = ()=>{
434565
435420
  };
434566
435421
  const useChatChatButtonInfo = (opList)=>{
434567
435422
  const { isClearHistoryButtonDisabled, isClearContextButtonDisabled } = useBuiltinButtonStatus({});
434568
- const { readonly } = useChatAppProps();
435423
+ const { readonly } = context_useChatAppProps();
434569
435424
  const { clearHistory } = useChatAreaController();
434570
435425
  const clearContext = useClearContext();
434571
435426
  const buttonList = (0,react.useMemo)(()=>opList.map((item)=>{
@@ -434678,7 +435533,7 @@ const MoreBtn = (param)=>{
434678
435533
  let { buttonList } = param;
434679
435534
  const showBackground = useIsShowBackground();
434680
435535
  const [visible, setVisible] = (0,react.useState)(false);
434681
- const { readonly } = useChatAppProps();
435536
+ const { readonly } = context_useChatAppProps();
434682
435537
  (0,react.useEffect)(()=>{
434683
435538
  document.addEventListener('click', ()=>{
434684
435539
  setVisible(false);
@@ -434728,7 +435583,7 @@ const ChatInputLeftSlot = ()=>{
434728
435583
  var _chatConfig_ui_base, _chatConfig_ui;
434729
435584
  const { chatInputLeftOps } = useChatOpInfo();
434730
435585
  const showBackground = useIsShowBackground();
434731
- const { chatConfig } = useChatAppProps();
435586
+ const { chatConfig } = context_useChatAppProps();
434732
435587
  const isMobile = ((_chatConfig_ui = chatConfig.ui) === null || _chatConfig_ui === void 0 ? void 0 : (_chatConfig_ui_base = _chatConfig_ui.base) === null || _chatConfig_ui_base === void 0 ? void 0 : _chatConfig_ui_base.layout) === client_Layout.MOBILE;
434733
435588
  const buttonClass = showBackground ? '!coz-fg-images-white' : '';
434734
435589
  const buttonList = useChatChatButtonInfo(chatInputLeftOps);
@@ -434824,10 +435679,10 @@ const StudioChatArea = (param)=>{
434824
435679
  let { coreAreaClassName, className, showInputArea = true, inputPlaceholder, inputNativeCallbacks, messageGroupListClassName, renderChatInputTopSlot, renderChatInputRightActions, isShowClearContextDivider, headerNode, messageMaxWidth, isMiniScreen, enableMultimodalUpload = false, uiKitCustomComponents, contentBox, getMessageRenderIndex, inputMode, onboardingPrologue, showOnboardingBotInfo, showOnboardingSuggestions } = param;
434825
435680
  var _chatConfig_ui_chatBot, _chatConfig_ui, _chatConfig_ui_chatBot1, _chatConfig_ui1, _chatConfig_ui_footer, _chatConfig_ui2;
434826
435681
  const initStatus = useInitStatus();
434827
- const { layout, onInitStateChange, chatConfig } = useChatAppProps();
435682
+ const { layout, onInitStateChange, chatConfig } = context_useChatAppProps();
434828
435683
  const refContainer = (0,react.useRef)(null);
434829
- const { readonly } = useChatAppProps();
434830
- const currentConversationInfo = useChatAppStore((state)=>state.currentConversationInfo);
435684
+ const { readonly } = context_useChatAppProps();
435685
+ const currentConversationInfo = context_useChatAppStore((state)=>state.currentConversationInfo);
434831
435686
  // 空会话的判断:id 为空字符串
434832
435687
  const isEmptyConversation = !currentConversationInfo || currentConversationInfo.id === '';
434833
435688
  const InputRightActionsComponent = (0,react.useMemo)(()=>renderChatInputRightActions ? (()=>{
@@ -435038,13 +435893,13 @@ const ChatHeader = (param)=>{
435038
435893
  let { iconUrl = coze_logo_namespaceObject, title = 'Coze Bot', extra, theme, isShowConversations, isNeedLogo = true } = param;
435039
435894
  const { headerTopLeftOps } = useChatOpInfo();
435040
435895
  const buttonList = useChatChatButtonInfo(headerTopLeftOps);
435041
- const { updateCurrentConversationInfo, currentConversationInfo, updateConversations, cozeApi } = useChatAppStore(shallow_useShallow((s)=>({
435896
+ const { updateCurrentConversationInfo, currentConversationInfo, updateConversations, cozeApi } = context_useChatAppStore(shallow_useShallow((s)=>({
435042
435897
  updateCurrentConversationInfo: s.updateCurrentConversationInfo,
435043
435898
  currentConversationInfo: s.currentConversationInfo,
435044
435899
  updateConversations: s.updateConversations,
435045
435900
  cozeApi: s.cozeApi
435046
435901
  })));
435047
- const { chatConfig: { type: chatType } } = useChatAppProps();
435902
+ const { chatConfig: { type: chatType } } = context_useChatAppProps();
435048
435903
  const [isRenameModalVisible, setIsRenameModalVisible] = (0,react.useState)(false);
435049
435904
  const [renameInputValue, setRenameInputValue] = (0,react.useState)('');
435050
435905
  const [isRenameLoading, setIsRenameLoading] = (0,react.useState)(false);
@@ -435290,13 +436145,13 @@ const ChatHeaderMobile = (param)=>{
435290
436145
  let { iconUrl = coze_logo_namespaceObject, title = 'Coze Bot', extra, theme, isShowConversations, isNeedLogo = true } = param;
435291
436146
  const { headerTopLeftOps } = useChatOpInfo();
435292
436147
  const buttonList = useChatChatButtonInfo(headerTopLeftOps);
435293
- const { updateCurrentConversationInfo, currentConversationInfo, updateConversations, cozeApi } = useChatAppStore(shallow_useShallow((s)=>({
436148
+ const { updateCurrentConversationInfo, currentConversationInfo, updateConversations, cozeApi } = context_useChatAppStore(shallow_useShallow((s)=>({
435294
436149
  updateCurrentConversationInfo: s.updateCurrentConversationInfo,
435295
436150
  currentConversationInfo: s.currentConversationInfo,
435296
436151
  updateConversations: s.updateConversations,
435297
436152
  cozeApi: s.cozeApi
435298
436153
  })));
435299
- const { chatConfig: { type: chatType } } = useChatAppProps();
436154
+ const { chatConfig: { type: chatType } } = context_useChatAppProps();
435300
436155
  const [isRenameModalVisible, setIsRenameModalVisible] = (0,react.useState)(false);
435301
436156
  const [renameInputValue, setRenameInputValue] = (0,react.useState)('');
435302
436157
  const [isRenameLoading, setIsRenameLoading] = (0,react.useState)(false);
@@ -435524,7 +436379,7 @@ var header_index_module_update = injectStylesIntoStyleTag_default()(header_index
435524
436379
 
435525
436380
 
435526
436381
  const FloatBtn = ()=>{
435527
- const { updateCurrentConversationInfo, currentConversationInfo } = useChatAppStore(shallow_useShallow((s)=>({
436382
+ const { updateCurrentConversationInfo, currentConversationInfo } = context_useChatAppStore(shallow_useShallow((s)=>({
435528
436383
  updateCurrentConversationInfo: s.updateCurrentConversationInfo,
435529
436384
  currentConversationInfo: s.currentConversationInfo
435530
436385
  })));
@@ -436271,35 +437126,6 @@ const getBuilderEventCallbackPlugin = (props)=>{
436271
437126
 
436272
437127
  ;// CONCATENATED MODULE: ../open-chat/src/assets/chatflow-logo.png
436273
437128
  const chatflow_logo_namespaceObject = "";
436274
- ;// CONCATENATED MODULE: ../open-chat/src/chat/builder-chat/helper/get-connector-id.ts
436275
- /*
436276
- * Copyright 2025 coze-dev Authors
436277
- *
436278
- * Licensed under the Apache License, Version 2.0 (the "License");
436279
- * you may not use this file except in compliance with the License.
436280
- * You may obtain a copy of the License at
436281
- *
436282
- * http://www.apache.org/licenses/LICENSE-2.0
436283
- *
436284
- * Unless required by applicable law or agreed to in writing, software
436285
- * distributed under the License is distributed on an "AS IS" BASIS,
436286
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
436287
- * See the License for the specific language governing permissions and
436288
- * limitations under the License.
436289
- */
436290
- const getConnectorId = (props)=>{
436291
- const { project } = props;
436292
- const { mode, connectorId } = project || {};
436293
- if (!connectorId) {
436294
- if (mode === 'websdk') {
436295
- return webSdkDefaultConnectorId;
436296
- } else if (mode === 'draft') {
436297
- return chatflowDraftConnectorId;
436298
- }
436299
- }
436300
- return connectorId;
436301
- };
436302
-
436303
437129
  ;// CONCATENATED MODULE: ../open-chat/src/chat/builder-chat/services/get-bot-info.ts
436304
437130
  /*
436305
437131
  * Copyright 2025 coze-dev Authors