@vserifsaglam/chat-react-client 1.0.2 → 1.0.4

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.
@@ -323,7 +323,13 @@ var ChatApi = /*#__PURE__*/function () {
323
323
  _proto.sendMessage = function sendMessage(message) {
324
324
  try {
325
325
  var _this1 = this;
326
- return Promise.resolve(_this1.client.post('/api/messages/send-message', message)).then(function (response) {
326
+ var config = {};
327
+ if (message.isAppointment) {
328
+ config.headers = {
329
+ 'x-disable-limit': true
330
+ };
331
+ }
332
+ return Promise.resolve(_this1.client.post('/api/messages/send-message', message, config)).then(function (response) {
327
333
  return response.data;
328
334
  });
329
335
  } catch (e) {
@@ -360,9 +366,21 @@ var ChatApi = /*#__PURE__*/function () {
360
366
  return Promise.reject(e);
361
367
  }
362
368
  };
363
- _proto.uploadFile = function uploadFile(file) {
369
+ _proto.getRemainingLimit = function getRemainingLimit(params) {
364
370
  try {
365
371
  var _this13 = this;
372
+ return Promise.resolve(_this13.client.get('/api/messages/remaining-limit', {
373
+ params: params
374
+ })).then(function (response) {
375
+ return response.data;
376
+ });
377
+ } catch (e) {
378
+ return Promise.reject(e);
379
+ }
380
+ };
381
+ _proto.uploadFile = function uploadFile(file) {
382
+ try {
383
+ var _this14 = this;
366
384
  var formData = new FormData();
367
385
  formData.append('file', file);
368
386
  var config = {
@@ -370,7 +388,7 @@ var ChatApi = /*#__PURE__*/function () {
370
388
  'Content-Type': 'multipart/form-data'
371
389
  }
372
390
  };
373
- return Promise.resolve(_this13.client.post('/api/files/upload', formData, config)).then(function (response) {
391
+ return Promise.resolve(_this14.client.post('/api/files/upload', formData, config)).then(function (response) {
374
392
  return response.data;
375
393
  });
376
394
  } catch (e) {
@@ -379,8 +397,8 @@ var ChatApi = /*#__PURE__*/function () {
379
397
  };
380
398
  _proto.banClient = function banClient(request) {
381
399
  try {
382
- var _this14 = this;
383
- return Promise.resolve(_this14.client.post('/api/bans/client', request)).then(function (response) {
400
+ var _this15 = this;
401
+ return Promise.resolve(_this15.client.post('/api/bans/client', request)).then(function (response) {
384
402
  return response.data;
385
403
  });
386
404
  } catch (e) {
@@ -389,8 +407,8 @@ var ChatApi = /*#__PURE__*/function () {
389
407
  };
390
408
  _proto.unbanClient = function unbanClient(request) {
391
409
  try {
392
- var _this15 = this;
393
- return Promise.resolve(_this15.client["delete"]('/api/bans/client', {
410
+ var _this16 = this;
411
+ return Promise.resolve(_this16.client["delete"]('/api/bans/client', {
394
412
  data: request
395
413
  })).then(function (response) {
396
414
  return response.data;
@@ -401,8 +419,8 @@ var ChatApi = /*#__PURE__*/function () {
401
419
  };
402
420
  _proto.adminBanClient = function adminBanClient(request) {
403
421
  try {
404
- var _this16 = this;
405
- return Promise.resolve(_this16.client.post('/api/bans/admin', request)).then(function (response) {
422
+ var _this17 = this;
423
+ return Promise.resolve(_this17.client.post('/api/bans/admin', request)).then(function (response) {
406
424
  return response.data;
407
425
  });
408
426
  } catch (e) {
@@ -411,8 +429,8 @@ var ChatApi = /*#__PURE__*/function () {
411
429
  };
412
430
  _proto.adminUnbanClient = function adminUnbanClient(request) {
413
431
  try {
414
- var _this17 = this;
415
- return Promise.resolve(_this17.client["delete"]('/api/bans/admin', {
432
+ var _this18 = this;
433
+ return Promise.resolve(_this18.client["delete"]('/api/bans/admin', {
416
434
  data: request
417
435
  })).then(function (response) {
418
436
  return response.data;
@@ -423,8 +441,8 @@ var ChatApi = /*#__PURE__*/function () {
423
441
  };
424
442
  _proto.checkBanStatus = function checkBanStatus(clientId) {
425
443
  try {
426
- var _this18 = this;
427
- return Promise.resolve(_this18.client.get("/api/bans/status/" + clientId)).then(function (response) {
444
+ var _this19 = this;
445
+ return Promise.resolve(_this19.client.get("/api/bans/status/" + clientId)).then(function (response) {
428
446
  return response.data;
429
447
  });
430
448
  } catch (e) {
@@ -433,8 +451,8 @@ var ChatApi = /*#__PURE__*/function () {
433
451
  };
434
452
  _proto.getClientProfile = function getClientProfile() {
435
453
  try {
436
- var _this19 = this;
437
- return Promise.resolve(_this19.client.get('/api/clients/profile')).then(function (response) {
454
+ var _this20 = this;
455
+ return Promise.resolve(_this20.client.get('/api/clients/profile')).then(function (response) {
438
456
  return response.data;
439
457
  });
440
458
  } catch (e) {
@@ -443,8 +461,8 @@ var ChatApi = /*#__PURE__*/function () {
443
461
  };
444
462
  _proto.getClientPreferences = function getClientPreferences() {
445
463
  try {
446
- var _this20 = this;
447
- return Promise.resolve(_this20.client.get('/api/clients/preferences')).then(function (response) {
464
+ var _this21 = this;
465
+ return Promise.resolve(_this21.client.get('/api/clients/preferences')).then(function (response) {
448
466
  return response.data;
449
467
  });
450
468
  } catch (e) {
@@ -453,8 +471,8 @@ var ChatApi = /*#__PURE__*/function () {
453
471
  };
454
472
  _proto.updateClientPreferences = function updateClientPreferences(request) {
455
473
  try {
456
- var _this21 = this;
457
- return Promise.resolve(_this21.client.put('/api/clients/preferences', request)).then(function (response) {
474
+ var _this22 = this;
475
+ return Promise.resolve(_this22.client.put('/api/clients/preferences', request)).then(function (response) {
458
476
  return response.data;
459
477
  });
460
478
  } catch (e) {
@@ -2069,7 +2087,10 @@ var useMessages = function useMessages(conversationUid) {
2069
2087
  return Promise.reject(e);
2070
2088
  }
2071
2089
  }, [conversationUid]);
2072
- var markMessageAsRead = useCallback(function (messageId) {
2090
+ var getRemainingLimit = useCallback(function (receiverClientId, conversationId) {
2091
+ if (conversationId === void 0) {
2092
+ conversationId = conversationUid;
2093
+ }
2073
2094
  try {
2074
2095
  if (!api) {
2075
2096
  setError(new Error('API not initialized'));
@@ -2079,9 +2100,12 @@ var useMessages = function useMessages(conversationUid) {
2079
2100
  setError(null);
2080
2101
  return Promise.resolve(_finallyRethrows(function () {
2081
2102
  return _catch(function () {
2082
- return Promise.resolve(api.markMessageAsRead(messageId));
2103
+ return Promise.resolve(api.getRemainingLimit({
2104
+ receiver_client_id: receiverClientId,
2105
+ conversation_uid: conversationId
2106
+ }));
2083
2107
  }, function (err) {
2084
- var error = err instanceof Error ? err : new Error('Failed to mark message as read');
2108
+ var error = err instanceof Error ? err : new Error('Failed to get remaining limit');
2085
2109
  setError(error);
2086
2110
  return null;
2087
2111
  });
@@ -2093,6 +2117,31 @@ var useMessages = function useMessages(conversationUid) {
2093
2117
  } catch (e) {
2094
2118
  return Promise.reject(e);
2095
2119
  }
2120
+ }, [api, conversationUid]);
2121
+ var markMessageAsRead = useCallback(function (messageId) {
2122
+ try {
2123
+ if (!api) {
2124
+ setError(new Error('API not initialized'));
2125
+ return Promise.resolve(null);
2126
+ }
2127
+ setLoading(true);
2128
+ setError(null);
2129
+ return Promise.resolve(_finallyRethrows(function () {
2130
+ return _catch(function () {
2131
+ return Promise.resolve(api.markMessageAsRead(messageId));
2132
+ }, function (err) {
2133
+ var error = err instanceof Error ? err : new Error('Failed to mark message as read');
2134
+ setError(error);
2135
+ return null;
2136
+ });
2137
+ }, function (_wasThrown3, _result3) {
2138
+ setLoading(false);
2139
+ if (_wasThrown3) throw _result3;
2140
+ return _result3;
2141
+ }));
2142
+ } catch (e) {
2143
+ return Promise.reject(e);
2144
+ }
2096
2145
  }, []);
2097
2146
  var sendMessage = useCallback(function (message) {
2098
2147
  try {
@@ -2113,10 +2162,10 @@ var useMessages = function useMessages(conversationUid) {
2113
2162
  setError(error);
2114
2163
  return null;
2115
2164
  });
2116
- }, function (_wasThrown3, _result3) {
2165
+ }, function (_wasThrown4, _result4) {
2117
2166
  setLoading(false);
2118
- if (_wasThrown3) throw _result3;
2119
- return _result3;
2167
+ if (_wasThrown4) throw _result4;
2168
+ return _result4;
2120
2169
  }));
2121
2170
  } catch (e) {
2122
2171
  return Promise.reject(e);
@@ -2157,10 +2206,10 @@ var useMessages = function useMessages(conversationUid) {
2157
2206
  setError(error);
2158
2207
  return null;
2159
2208
  });
2160
- }, function (_wasThrown4, _result4) {
2209
+ }, function (_wasThrown5, _result5) {
2161
2210
  setLoading(false);
2162
- if (_wasThrown4) throw _result4;
2163
- return _result4;
2211
+ if (_wasThrown5) throw _result5;
2212
+ return _result5;
2164
2213
  }));
2165
2214
  } catch (e) {
2166
2215
  return Promise.reject(e);
@@ -2191,10 +2240,10 @@ var useMessages = function useMessages(conversationUid) {
2191
2240
  setError(error);
2192
2241
  return null;
2193
2242
  });
2194
- }, function (_wasThrown5, _result5) {
2243
+ }, function (_wasThrown6, _result6) {
2195
2244
  setLoading(false);
2196
- if (_wasThrown5) throw _result5;
2197
- return _result5;
2245
+ if (_wasThrown6) throw _result6;
2246
+ return _result6;
2198
2247
  }));
2199
2248
  } catch (e) {
2200
2249
  return Promise.reject(e);
@@ -2225,10 +2274,10 @@ var useMessages = function useMessages(conversationUid) {
2225
2274
  setError(error);
2226
2275
  return null;
2227
2276
  });
2228
- }, function (_wasThrown6, _result6) {
2277
+ }, function (_wasThrown7, _result7) {
2229
2278
  setLoading(false);
2230
- if (_wasThrown6) throw _result6;
2231
- return _result6;
2279
+ if (_wasThrown7) throw _result7;
2280
+ return _result7;
2232
2281
  }));
2233
2282
  } catch (e) {
2234
2283
  return Promise.reject(e);
@@ -2363,7 +2412,8 @@ var useMessages = function useMessages(conversationUid) {
2363
2412
  deleteMessage: deleteMessage,
2364
2413
  setMessages: setMessages,
2365
2414
  updatePreferences: updatePreferences,
2366
- preferences: preferences
2415
+ preferences: preferences,
2416
+ getRemainingLimit: getRemainingLimit
2367
2417
  };
2368
2418
  };
2369
2419
 
@@ -2726,7 +2776,8 @@ function useMessageManagement(selectedConversationId) {
2726
2776
  updateMessage = _useMessages.updateMessage,
2727
2777
  setMessages = _useMessages.setMessages,
2728
2778
  preferences = _useMessages.preferences,
2729
- updatePreferences = _useMessages.updatePreferences;
2779
+ updatePreferences = _useMessages.updatePreferences,
2780
+ getRemainingLimit = _useMessages.getRemainingLimit;
2730
2781
  var _useAllMessageEvents = useAllMessageEvents$1(),
2731
2782
  messageSent = _useAllMessageEvents.messageSent,
2732
2783
  messageEdited = _useAllMessageEvents.messageEdited,
@@ -2771,7 +2822,7 @@ function useMessageManagement(selectedConversationId) {
2771
2822
  return Promise.reject(e);
2772
2823
  }
2773
2824
  }, [messagesLoading, hasMore, getMessages, page, selectedConversationId]);
2774
- var handleSendMessage = useCallback(function (content, receiver) {
2825
+ var handleSendMessage = useCallback(function (content, receiver, isAppointment) {
2775
2826
  try {
2776
2827
  if (!content.trim() || !selectedConversationId || !profile) return Promise.resolve();
2777
2828
  var tempMessageId = "temp-" + Date.now();
@@ -2796,7 +2847,8 @@ function useMessageManagement(selectedConversationId) {
2796
2847
  return Promise.resolve(sendMessage({
2797
2848
  receiver_client_id: receiver.id,
2798
2849
  content: content,
2799
- conversation_uid: selectedConversationId
2850
+ conversation_uid: selectedConversationId,
2851
+ isAppointment: isAppointment
2800
2852
  })).then(function (success) {
2801
2853
  if (!success) {
2802
2854
  setMessages(function (prevMessages) {
@@ -2808,7 +2860,7 @@ function useMessageManagement(selectedConversationId) {
2808
2860
  })
2809
2861
  });
2810
2862
  });
2811
- return false;
2863
+ return success;
2812
2864
  } else {
2813
2865
  setMessages(function (prevMessages) {
2814
2866
  return _extends({}, prevMessages, {
@@ -2821,10 +2873,11 @@ function useMessageManagement(selectedConversationId) {
2821
2873
  })
2822
2874
  });
2823
2875
  });
2824
- return true;
2876
+ return success;
2825
2877
  }
2826
2878
  });
2827
2879
  }, function (error) {
2880
+ var _error$response$data, _error$response;
2828
2881
  setMessages(function (prevMessages) {
2829
2882
  return _extends({}, prevMessages, {
2830
2883
  messages: ((prevMessages === null || prevMessages === void 0 ? void 0 : prevMessages.messages) || []).filter(function (msg) {
@@ -2832,14 +2885,15 @@ function useMessageManagement(selectedConversationId) {
2832
2885
  })
2833
2886
  });
2834
2887
  });
2835
- console.error('Failed to send message:', error);
2836
- return false;
2888
+ return (_error$response$data = error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : _error$response.data) != null ? _error$response$data : {
2889
+ message: 'Unknown error'
2890
+ };
2837
2891
  }));
2838
2892
  } catch (e) {
2839
2893
  return Promise.reject(e);
2840
2894
  }
2841
2895
  }, [sendMessage, selectedConversationId, profile === null || profile === void 0 ? void 0 : profile.id, setMessages]);
2842
- var handleSendFileMessage = useCallback(function (content, fileId, receiver, filename, url) {
2896
+ var handleSendFileMessage = useCallback(function (content, fileId, receiver, filename, url, isAppointment) {
2843
2897
  try {
2844
2898
  if (!selectedConversationId) return Promise.resolve();
2845
2899
  var tempMessageId = "temp-file-" + Date.now();
@@ -2869,7 +2923,8 @@ function useMessageManagement(selectedConversationId) {
2869
2923
  receiver_client_id: receiver.id,
2870
2924
  content: content,
2871
2925
  attachments: [fileId],
2872
- conversation_uid: selectedConversationId
2926
+ conversation_uid: selectedConversationId,
2927
+ isAppointment: isAppointment
2873
2928
  })).then(function (success) {
2874
2929
  if (success) {
2875
2930
  setMessages(function (prevMessages) {
@@ -2927,7 +2982,8 @@ function useMessageManagement(selectedConversationId) {
2927
2982
  hasMore: hasMore,
2928
2983
  setMessages: setMessages,
2929
2984
  preferences: preferences,
2930
- updatePreferences: updatePreferences
2985
+ updatePreferences: updatePreferences,
2986
+ getRemainingLimit: getRemainingLimit
2931
2987
  };
2932
2988
  }
2933
2989