@fle-ui/plus-im-record 0.0.7-beta.0 → 0.0.8-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/package.json +2 -2
  2. package/es/@types/index.d.ts +0 -620
  3. package/es/CardTag/index.d.ts +0 -3
  4. package/es/CardTag/index.js +0 -18
  5. package/es/ChatMessageItem/index.d.ts +0 -17
  6. package/es/ChatMessageItem/index.js +0 -130
  7. package/es/ChatMessageItem/index.less +0 -108
  8. package/es/ChatMessageList/index.d.ts +0 -26
  9. package/es/ChatMessageList/index.js +0 -56
  10. package/es/ChatMessageList/index.less +0 -33
  11. package/es/GoodsCard/index.d.ts +0 -14
  12. package/es/GoodsCard/index.js +0 -93
  13. package/es/GoodsCard/index.less +0 -49
  14. package/es/GoodsOrderCard/index.d.ts +0 -17
  15. package/es/GoodsOrderCard/index.js +0 -161
  16. package/es/GoodsOrderCard/index.less +0 -81
  17. package/es/Icon/index.d.ts +0 -8
  18. package/es/Icon/index.js +0 -11
  19. package/es/ParseSession/index.d.ts +0 -21
  20. package/es/ParseSession/index.js +0 -454
  21. package/es/ParseSession/index.less +0 -181
  22. package/es/api/index.d.ts +0 -29
  23. package/es/api/index.js +0 -48
  24. package/es/common/const/index.d.ts +0 -46
  25. package/es/common/const/index.js +0 -82
  26. package/es/common/utils/index.d.ts +0 -33
  27. package/es/common/utils/index.js +0 -169
  28. package/es/index.d.ts +0 -25
  29. package/es/index.js +0 -76
  30. package/es/styles/extends.less +0 -50
  31. package/es/styles/index.less +0 -35
  32. package/es/styles/vars.less +0 -8
  33. package/es/utils/index.d.ts +0 -14
  34. package/es/utils/index.js +0 -50
  35. package/lib/@types/index.d.ts +0 -620
  36. package/lib/CardTag/index.d.ts +0 -3
  37. package/lib/CardTag/index.js +0 -25
  38. package/lib/ChatMessageItem/index.d.ts +0 -17
  39. package/lib/ChatMessageItem/index.js +0 -136
  40. package/lib/ChatMessageItem/index.less +0 -108
  41. package/lib/ChatMessageList/index.d.ts +0 -26
  42. package/lib/ChatMessageList/index.js +0 -63
  43. package/lib/ChatMessageList/index.less +0 -33
  44. package/lib/GoodsCard/index.d.ts +0 -14
  45. package/lib/GoodsCard/index.js +0 -103
  46. package/lib/GoodsCard/index.less +0 -49
  47. package/lib/GoodsOrderCard/index.d.ts +0 -17
  48. package/lib/GoodsOrderCard/index.js +0 -169
  49. package/lib/GoodsOrderCard/index.less +0 -81
  50. package/lib/Icon/index.d.ts +0 -8
  51. package/lib/Icon/index.js +0 -18
  52. package/lib/ParseSession/index.d.ts +0 -21
  53. package/lib/ParseSession/index.js +0 -456
  54. package/lib/ParseSession/index.less +0 -181
  55. package/lib/api/index.d.ts +0 -29
  56. package/lib/api/index.js +0 -55
  57. package/lib/common/const/index.d.ts +0 -46
  58. package/lib/common/const/index.js +0 -88
  59. package/lib/common/utils/index.d.ts +0 -33
  60. package/lib/common/utils/index.js +0 -183
  61. package/lib/index.d.ts +0 -25
  62. package/lib/index.js +0 -85
  63. package/lib/styles/extends.less +0 -50
  64. package/lib/styles/index.less +0 -35
  65. package/lib/styles/vars.less +0 -8
  66. package/lib/utils/index.d.ts +0 -14
  67. package/lib/utils/index.js +0 -56
package/es/api/index.js DELETED
@@ -1,48 +0,0 @@
1
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
6
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
- import Request from '@fle-tools/request';
8
- import Cookies from 'js-cookie';
9
- var baseURLMap = {
10
- dev: 'https://dev-gateway.fxqifu.net/pangu',
11
- test: 'https://qa-gateway.fxqifu.net/pangu',
12
- qa: 'https://qa-gateway.fxqifu.net/pangu',
13
- prod: 'https://gateway.fxqifu.net/pangu'
14
- };
15
- export var apiCreate = function apiCreate(_env, token) {
16
- var localStorageEnv = Object.keys(baseURLMap).includes(localStorage.getItem('env') || '') ? localStorage.getItem('env') : '';
17
- var env = _env || localStorageEnv || 'prod';
18
- var baseURL = baseURLMap[env];
19
- var service = Request({
20
- baseUrl: baseURL,
21
- timeout: 30000,
22
- beforeRequestResolve: function beforeRequestResolve(config) {
23
- config.headers = _objectSpread(_objectSpread({}, config.headers), {}, {
24
- authority_token: token || Cookies.get('token')
25
- });
26
- }
27
- });
28
- return {
29
- // 获取用户头像名字信息
30
- getAccountInfoByAccid: function getAccountInfoByAccid(data) {
31
- return service.post("/ll/provider/message/user/info-list", data);
32
- },
33
- // 获取商品信息
34
- getProductById: function getProductById(data) {
35
- return service.post('/ll/provider/message/product/get', data);
36
- },
37
- // 获取订单信息
38
- getCSOrder: function getCSOrder(data) {
39
- return service.post('/ll/provider/message/order/get', data);
40
- },
41
- // 获取联系人信息(表单)
42
- getContact: function getContact(params) {
43
- return service.get('/ll/provider/message/contact/get', {
44
- params: params
45
- });
46
- }
47
- };
48
- };
@@ -1,46 +0,0 @@
1
- export declare const defaultAvatar = "https://qa-oss.elebuys.com/tmpdir/202402221617520002519945.png";
2
- export declare const fallbackImg = "";
3
- export declare const imMsgTypes: {
4
- text: string;
5
- image: string;
6
- video: string;
7
- audio: string;
8
- link: string;
9
- file: string;
10
- faq: string;
11
- faqLink: string;
12
- formCustomer: string;
13
- tip: string;
14
- event: string;
15
- order: string;
16
- product: string;
17
- orderGoods: string;
18
- offlineSupport: string;
19
- chatrecord: string;
20
- };
21
- export declare const msgEventTypes: {
22
- userClose: number;
23
- csClose: number;
24
- sysClose: number;
25
- userEnter: number;
26
- transferOk: number;
27
- lineUp: number;
28
- lineOverLimit: number;
29
- formCustomer: number;
30
- csOffLine: number;
31
- };
32
- export declare const roleTypes: {
33
- cs: 'cs';
34
- user: 'user';
35
- };
36
- export declare const fileTypes: {
37
- img: string[];
38
- audio: string[];
39
- video: string[];
40
- file: string[];
41
- };
42
- export declare const networkHintMap: any;
43
- export declare const cardTagMap: Record<string, {
44
- label: string;
45
- color: string;
46
- }>;
@@ -1,82 +0,0 @@
1
- export var defaultAvatar = 'https://qa-oss.elebuys.com/tmpdir/202402221617520002519945.png';
2
- export var fallbackImg = '';
3
- export var imMsgTypes = {
4
- text: 'text',
5
- image: 'image',
6
- video: 'video',
7
- audio: 'audio',
8
- link: 'link',
9
- file: 'file',
10
- faq: 'faq',
11
- faqLink: 'faqLink',
12
- formCustomer: 'formCustomer',
13
- tip: 'tip',
14
- event: 'event',
15
- order: 'order',
16
- product: 'product',
17
- orderGoods: 'order-goods',
18
- offlineSupport: 'offline-support',
19
- chatrecord: 'chatrecord'
20
- };
21
- export var msgEventTypes = {
22
- userClose: 101,
23
- csClose: 102,
24
- sysClose: 103,
25
- userEnter: 111,
26
- transferOk: 121,
27
- lineUp: 131,
28
- lineOverLimit: 132,
29
- formCustomer: 201,
30
- csOffLine: 301 // 客服离线
31
- };
32
- export var roleTypes = {
33
- cs: 'cs',
34
- user: 'user'
35
- };
36
- export var fileTypes = {
37
- img: ['.jpg', '.png', '.jpeg', '.gif'],
38
- audio: ['.ogg', '.mp3'],
39
- video: ['.mp4', '.mov'],
40
- file: ['.txt', '.zip', '.rar', '.z7', '.doc', '.docm', '.docx', '.ppt', '.pptm', '.pptx', '.xls', '.xlsx', '.pdf']
41
- };
42
- export var networkHintMap = {
43
- logined: '暂无会话',
44
- willReconnect: '即将重连...',
45
- disconnect: '连接已断开',
46
- kicked: '已在其他设备登录',
47
- default: '暂无会话'
48
- };
49
- export var cardTagMap = {
50
- '1': {
51
- label: '电商精选',
52
- color: '#FF3013'
53
- },
54
- '2': {
55
- label: '生鲜电商',
56
- color: '#D5A704'
57
- },
58
- '3': {
59
- label: '超市精选',
60
- color: '#0064E0'
61
- },
62
- '4': {
63
- label: '虚拟商品',
64
- color: '#AC30E3'
65
- },
66
- '5': {
67
- label: '生鲜蛋糕',
68
- color: '#4D2EF6'
69
- },
70
- '6': {
71
- label: '自有供应商商品',
72
- color: '#0064E0'
73
- },
74
- '7': {
75
- label: '精选商品',
76
- color: '#FF0036'
77
- },
78
- '8': {
79
- label: '自有商品',
80
- color: '#FF3013'
81
- }
82
- };
@@ -1,33 +0,0 @@
1
- export declare function getSessionIdFromMsg(msg: {
2
- from: any;
3
- to: any;
4
- scene: any;
5
- }, myAccount: any): string;
6
- export declare function paserAttach(attach?: any): any;
7
- export declare function getSimplifyMsg(attach?: any): any;
8
- export declare function concatMsgs<T>(arr1?: any[], arr2?: any[]): T[];
9
- export declare function getDateDiff(dateTimeStamp: number): string;
10
- export declare function downloadByUrl(src: string): void;
11
- /**
12
- * 将文字写入剪切板
13
- * @param {string} text
14
- * @returns {Promise} 返回promise对象
15
- */
16
- export declare function copyText(text?: string): Promise<void>;
17
- export declare const matchs: {
18
- paserProductFromUrl: (str: string) => string | null | undefined;
19
- paserOrderFromUrl: (str: string) => string | null | undefined;
20
- };
21
- declare const _default: {
22
- getSessionIdFromMsg: typeof getSessionIdFromMsg;
23
- paserAttach: typeof paserAttach;
24
- getDateDiff: typeof getDateDiff;
25
- downloadByUrl: typeof downloadByUrl;
26
- copyText: typeof copyText;
27
- getSimplifyMsg: typeof getSimplifyMsg;
28
- matchs: {
29
- paserProductFromUrl: (str: string) => string | null | undefined;
30
- paserOrderFromUrl: (str: string) => string | null | undefined;
31
- };
32
- };
33
- export default _default;
@@ -1,169 +0,0 @@
1
- function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
2
- function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
3
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
4
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
5
- function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
6
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
7
- import { imMsgTypes } from '../const';
8
- /* eslint-disable radix */
9
- export function getSessionIdFromMsg(msg, myAccount) {
10
- // 在群中,不管 from 是不是自己,sessionId 都要取 to
11
- var from = msg.from,
12
- to = msg.to,
13
- scene = msg.scene;
14
- var target = '';
15
- if (scene === 'p2p') {
16
- if (from === myAccount) {
17
- target = to;
18
- } else {
19
- target = from;
20
- }
21
- } else {
22
- target = to;
23
- }
24
- var sessionId = "".concat(scene, "-").concat(target);
25
- return sessionId;
26
- }
27
- export function paserAttach() {
28
- var attach = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
29
- if (attach.content && typeof attach.content === 'string' && ![imMsgTypes.tip, imMsgTypes.text].includes(attach.type)) {
30
- var defaultObj = [imMsgTypes.faq].includes(attach.type) ? [] : {};
31
- try {
32
- attach.content = JSON.parse(attach.content);
33
- } catch (error) {
34
- console.log('paser', error);
35
- attach.content = defaultObj;
36
- }
37
- }
38
- return attach;
39
- }
40
- export function getSimplifyMsg() {
41
- var attach = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
42
- var type = attach.type,
43
- content = attach.content;
44
- if ([imMsgTypes.text, imMsgTypes.tip].includes(type)) return content;
45
- if (type === imMsgTypes.faqLink) return content.title;
46
- if (type === imMsgTypes.event) return content.tips;
47
- if (type === imMsgTypes.audio) return '[音频]...';
48
- if (type === imMsgTypes.faq) return '[猜你想问]...';
49
- if (type === imMsgTypes.file) return '[文件]...';
50
- if (type === imMsgTypes.formCustomer) return '[表单]...';
51
- if (type === imMsgTypes.image) return '[图片]...';
52
- if (type === imMsgTypes.video) return '[视频]...';
53
- if (type === imMsgTypes.link) return '[链接]...';
54
- if (type === imMsgTypes.order) return '[订单卡片]...';
55
- if (type === imMsgTypes.product) return '[商品卡片]...';
56
- if (type === imMsgTypes.chatrecord) return '[转接记录]...';
57
- }
58
- export function concatMsgs() {
59
- var arr1 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
60
- var arr2 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
61
- var idMap = {};
62
- var result = [];
63
- [].concat(_toConsumableArray(arr1), _toConsumableArray(arr2)).forEach(function () {
64
- var item = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
65
- if (!idMap[item.idServer]) {
66
- result.push(item);
67
- idMap[item.idServer] = true;
68
- }
69
- });
70
- result.sort(function (a, b) {
71
- return a.time - b.time;
72
- });
73
- return result;
74
- }
75
- // 时间戳转多少分钟之前
76
- export function getDateDiff(dateTimeStamp) {
77
- var timestamp = dateTimeStamp || new Date().getTime();
78
- var minute = 1000 * 60;
79
- var hour = minute * 60;
80
- var day = hour * 24;
81
- var month = day * 30;
82
- var year = day * 365;
83
- var now = new Date().getTime();
84
- var diffValue = now - timestamp;
85
- var result;
86
- if (diffValue < 0) {
87
- return '刚刚';
88
- }
89
- var yearC = Math.floor(diffValue / year);
90
- var monthC = Math.floor(diffValue / month);
91
- var weekC = Math.floor(diffValue / (7 * day));
92
- var dayC = Math.floor(diffValue / day);
93
- var hourC = Math.floor(diffValue / hour);
94
- var minC = Math.floor(diffValue / minute);
95
- if (yearC >= 1) {
96
- result = "".concat(yearC, "\u5E74\u524D");
97
- } else if (monthC >= 1) {
98
- result = "".concat(monthC, "\u6708\u524D");
99
- } else if (weekC >= 1) {
100
- result = "".concat(weekC, "\u5468\u524D");
101
- } else if (dayC >= 1) {
102
- result = "".concat(dayC, "\u5929\u524D");
103
- } else if (hourC >= 1) {
104
- result = "".concat(hourC, "\u5C0F\u65F6\u524D");
105
- } else if (minC >= 1) {
106
- result = "".concat(minC, "\u5206\u949F\u524D");
107
- } else result = '刚刚';
108
- return result;
109
- }
110
- export function downloadByUrl(src) {
111
- fetch(src).then(function (response) {
112
- return response.blob();
113
- }).then(function (blob) {
114
- var url = URL.createObjectURL(new Blob([blob]));
115
- var link = document.createElement('a');
116
- link.href = url;
117
- link.download = 'image.png';
118
- document.body.appendChild(link);
119
- link.click();
120
- URL.revokeObjectURL(url);
121
- link.remove();
122
- });
123
- }
124
- /**
125
- * 将文字写入剪切板
126
- * @param {string} text
127
- * @returns {Promise} 返回promise对象
128
- */
129
- export function copyText() {
130
- var text = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
131
- // 在调用前 先访问是否存在 clipboard 对象
132
- if (navigator.clipboard) {
133
- return navigator.clipboard.writeText(text);
134
- } else {
135
- try {
136
- var t = document.createElement('textarea');
137
- t.nodeValue = text;
138
- t.value = text;
139
- document.body.appendChild(t);
140
- t.select();
141
- document.execCommand('copy');
142
- document.body.removeChild(t);
143
- return Promise.resolve();
144
- } catch (e) {
145
- return Promise.reject(e);
146
- }
147
- }
148
- }
149
- export var matchs = {
150
- paserProductFromUrl: function paserProductFromUrl(str) {
151
- if (!str) return null;
152
- var res = str.match(/^https*(.+?)(product\/product_info|productDetail|goodsDetail)\/(\d+)$/);
153
- return res === null || res === void 0 ? void 0 : res[3];
154
- },
155
- paserOrderFromUrl: function paserOrderFromUrl(str) {
156
- if (!str) return null;
157
- var res = str.match(/^https*(.+?)(order\/order_detail.+?order_id=)(\d+)$/);
158
- return res === null || res === void 0 ? void 0 : res[3];
159
- }
160
- };
161
- export default {
162
- getSessionIdFromMsg: getSessionIdFromMsg,
163
- paserAttach: paserAttach,
164
- getDateDiff: getDateDiff,
165
- downloadByUrl: downloadByUrl,
166
- copyText: copyText,
167
- getSimplifyMsg: getSimplifyMsg,
168
- matchs: matchs
169
- };
package/es/index.d.ts DELETED
@@ -1,25 +0,0 @@
1
- import React from 'react';
2
- import { apiCreate, Env } from './api';
3
- import { IMMessage } from './@types';
4
- import './styles/index.less';
5
- /**
6
- * @name 客服记录组件
7
- * @description 代码由小鲤客服平台搬运简化而来
8
- */
9
- export interface IMRecordProps {
10
- env?: Env;
11
- token?: string;
12
- msgRecords: IMMessage[];
13
- onScrollTop?: () => void;
14
- recordSession?: {
15
- relationId: string | number;
16
- accid: string;
17
- relationType?: number;
18
- };
19
- }
20
- export interface ImContextProps {
21
- api: ReturnType<typeof apiCreate>;
22
- }
23
- export declare const ImContext: React.Context<ImContextProps>;
24
- declare const IMRecord: React.FC<IMRecordProps>;
25
- export default IMRecord;
package/es/index.js DELETED
@@ -1,76 +0,0 @@
1
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
6
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
- function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
8
- function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
9
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
10
- function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
11
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
12
- function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
13
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
14
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
15
- function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
16
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
17
- import React, { createContext, useEffect, useState } from 'react';
18
- import ChatMessageList from './ChatMessageList';
19
- import { apiCreate } from './api';
20
- import './styles/index.less';
21
- export var ImContext = /*#__PURE__*/createContext({});
22
- var IMRecord = function IMRecord(_ref) {
23
- var env = _ref.env,
24
- msgRecords = _ref.msgRecords,
25
- token = _ref.token,
26
- recordSession = _ref.recordSession,
27
- onScrollTop = _ref.onScrollTop;
28
- var api = apiCreate(env, token);
29
- var _useState = useState({}),
30
- _useState2 = _slicedToArray(_useState, 2),
31
- accountsMap = _useState2[0],
32
- setAccountsMap = _useState2[1];
33
- useEffect(function () {
34
- var accids = _toConsumableArray(new Set(msgRecords.map(function (x) {
35
- return x.from;
36
- })));
37
- if (accids.length) {
38
- getAccountByAccids(accids);
39
- }
40
- }, [msgRecords]);
41
- function getAccountByAccids(accids) {
42
- api.getAccountInfoByAccid({
43
- accids: accids
44
- }).then(function (_ref2) {
45
- var data = _ref2.data;
46
- var temp = {};
47
- if (Array.isArray(data)) {
48
- data.forEach(function (item) {
49
- if (!accountsMap[item.accid]) {
50
- temp[item.accid] = item;
51
- }
52
- });
53
- }
54
- setAccountsMap(function (prev) {
55
- return _objectSpread(_objectSpread({}, prev), temp);
56
- });
57
- });
58
- }
59
- return /*#__PURE__*/React.createElement(ImContext.Provider, {
60
- value: {
61
- api: api
62
- }
63
- }, /*#__PURE__*/React.createElement(ChatMessageList, {
64
- msgs: msgRecords,
65
- h5: true,
66
- style: {
67
- height: '100%',
68
- background: '#f7f7f7'
69
- },
70
- accountsMap: accountsMap,
71
- isSessionEnd: true,
72
- recordSession: recordSession,
73
- onScrollTop: onScrollTop
74
- }));
75
- };
76
- export default IMRecord;
@@ -1,50 +0,0 @@
1
- @import './vars.less';
2
-
3
- /* flex 布局样式 */
4
- .flex {
5
- display: flex;
6
- }
7
-
8
- .flex-align-center {
9
- align-items: center;
10
- }
11
-
12
- .flex-center {
13
- &:extend(.flex);
14
- &:extend(.flex-align-center);
15
- justify-content: center;
16
- }
17
-
18
- /* 文字样式 */
19
-
20
- .one-line-text {
21
- overflow: hidden;
22
- text-overflow: ellipsis;
23
- white-space: nowrap;
24
- }
25
-
26
- .multi-line-text {
27
- display: -webkit-box;
28
- -webkit-box-orient: vertical;
29
- overflow: hidden;
30
- }
31
-
32
- .two-line-text {
33
- &:extend(.multi-line-text);
34
- -webkit-line-clamp: 2;
35
- }
36
-
37
- /* 小滚动条样式 */
38
- .scrollmini {
39
- &::-webkit-scrollbar {
40
- width: 4px;
41
- }
42
- &::-webkit-scrollbar-thumb {
43
- background: #ddd;
44
- border-radius: 4px;
45
- border-radius: 2px;
46
- }
47
- &::-webkit-scrollbar-thumb:hover {
48
- background-color: #ddd;
49
- }
50
- }
@@ -1,35 +0,0 @@
1
- @import './vars.less';
2
- @import './extends.less';
3
-
4
- .mp0() {
5
- margin: 0;
6
- padding: 0;
7
- }
8
-
9
- input::-ms-clear,
10
- input::-ms-reveal {
11
- display: none;
12
- }
13
- *,
14
- *::before,
15
- *::after {
16
- box-sizing: border-box;
17
- }
18
-
19
- ul,
20
- li {
21
- list-style: none;
22
- .mp0();
23
- }
24
-
25
- ::-webkit-scrollbar {
26
- width: 3px;
27
- border-radius: 4px;
28
- }
29
- ::-webkit-scrollbar-thumb {
30
- background: #ddd;
31
- border-radius: 4px;
32
- }
33
- ::-webkit-scrollbar-thumb:hover {
34
- background-color: #ddd;
35
- }
@@ -1,8 +0,0 @@
1
- :root {
2
- --prc: #2c6bff; // 主题色
3
- --txtc: #333; // 主文字颜色
4
- --txtc2: #777; // 次级文字颜色
5
-
6
- //
7
- --rv-primary-color: var(--prc) !important;
8
- }
@@ -1,14 +0,0 @@
1
- export declare const debounce: <T extends (...args: any[]) => any>(fn: T, delay: number) => (...args: Parameters<T>) => void;
2
- /**
3
- * 格式化文件大小
4
- * @param size 文件大小(字节)
5
- * @returns 格式化后的文件大小字符串
6
- */
7
- export declare const parseFileSize: (size: number, level?: number) => string;
8
- /**
9
- * 给URL添加查询参数
10
- * @param url 原始URL
11
- * @param search 要添加的查询字符串
12
- * @returns 添加参数后的URL
13
- */
14
- export declare const addUrlSearch: (url: string, search: string) => string;
package/es/utils/index.js DELETED
@@ -1,50 +0,0 @@
1
- export var debounce = function debounce(fn, delay) {
2
- var timeoutId;
3
- return function () {
4
- var _this = this;
5
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
6
- args[_key] = arguments[_key];
7
- }
8
- clearTimeout(timeoutId);
9
- timeoutId = setTimeout(function () {
10
- // @ts-ignore
11
- fn.apply(_this, args);
12
- }, delay);
13
- };
14
- };
15
- /**
16
- * 格式化文件大小
17
- * @param size 文件大小(字节)
18
- * @returns 格式化后的文件大小字符串
19
- */
20
- export var parseFileSize = function parseFileSize(size) {
21
- var level = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
22
- var fileSizeMap = {
23
- 0: 'B',
24
- 1: 'KB',
25
- 2: 'MB',
26
- 3: 'GB',
27
- 4: 'TB'
28
- };
29
- var handler = function handler(size, level) {
30
- if (level >= Object.keys(fileSizeMap).length) {
31
- return 'the file is too big';
32
- }
33
- if (size < 1024) {
34
- return "".concat(size).concat(fileSizeMap[level]);
35
- }
36
- return handler(Math.round(size / 1024), level + 1);
37
- };
38
- return handler(size, level);
39
- };
40
- /**
41
- * 给URL添加查询参数
42
- * @param url 原始URL
43
- * @param search 要添加的查询字符串
44
- * @returns 添加参数后的URL
45
- */
46
- export var addUrlSearch = function addUrlSearch(url, search) {
47
- var urlObj = new URL(url);
48
- urlObj.search += (urlObj.search.startsWith('?') ? '&' : '?') + search;
49
- return urlObj.href;
50
- };