react-input-emoji 5.8.0 → 5.9.0-beta.1

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/dist/index.js CHANGED
@@ -37,479 +37,10 @@ function styleInject(css, ref) {
37
37
  var css_248z = ".react-input-emoji--container {\n color: #4b4b4b;\n text-rendering: optimizeLegibility;\n background-color: #fff;\n border: 1px solid #fff;\n border-radius: 21px;\n margin: 5px 10px;\n box-sizing: border-box;\n flex: 1 1 auto;\n font-size: 15px;\n font-family: sans-serif;\n font-weight: 400;\n line-height: 20px;\n min-height: 20px;\n min-width: 0;\n outline: none;\n width: inherit;\n will-change: width;\n vertical-align: baseline;\n border: 1px solid #eaeaea;\n margin-right: 0;\n}\n\n.react-input-emoji--wrapper {\n display: flex;\n overflow: hidden;\n flex: 1;\n position: relative;\n padding-right: 0;\n vertical-align: baseline;\n outline: none;\n margin: 0;\n padding: 0;\n border: 0;\n}\n\n.react-input-emoji--input {\n font-weight: 400;\n max-height: 100px;\n min-height: 20px;\n outline: none;\n overflow-x: hidden;\n overflow-y: auto;\n position: relative;\n white-space: pre-wrap;\n word-wrap: break-word;\n z-index: 1;\n width: 100%;\n user-select: text;\n padding: 9px 12px 11px;\n text-align: left;\n}\n\n.react-input-emoji--input img {\n vertical-align: middle;\n width: 18px !important;\n height: 18px !important;\n display: inline !important;\n margin-left: 1px;\n margin-right: 1px;\n}\n\n.react-input-emoji--overlay {\n position: fixed;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n z-index: 9;\n}\n\n.react-input-emoji--placeholder {\n color: #a0a0a0;\n pointer-events: none;\n position: absolute;\n user-select: none;\n z-index: 2;\n left: 16px;\n top: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n width: calc(100% - 22px);\n}\n\n.react-input-emoji--button {\n position: relative;\n display: block;\n text-align: center;\n padding: 0 10px;\n overflow: hidden;\n transition: color 0.1s ease-out;\n margin: 0;\n box-shadow: none;\n background: none;\n border: none;\n outline: none;\n cursor: pointer;\n flex-shrink: 0;\n}\n\n.react-input-emoji--button svg {\n fill: #858585;\n}\n\n.react-input-emoji--button__show svg {\n fill: #128b7e;\n}\n\n.react-emoji {\n display: flex;\n align-items: center;\n position: relative;\n width: 100%;\n}\n\n.react-emoji-picker--container {\n position: absolute;\n top: 0;\n width: 100%;\n}\n\n.react-emoji-picker--wrapper {\n position: absolute;\n bottom: 0;\n right: 0;\n height: 435px;\n width: 352px;\n overflow: hidden;\n z-index: 10;\n}\n\n.react-emoji-picker {\n position: absolute;\n top: 0;\n left: 0;\n animation: slidein 0.1s ease-in-out;\n}\n\n.react-emoji-picker__show {\n top: 0;\n}\n\n.react-input-emoji--mention--container {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n z-index: 10;\n}\n\n.react-input-emoji--mention--list {\n background-color: #fafafa;\n border: 1px solid #eaeaea;\n border-radius: 4px;\n margin: 0;\n padding: 0;\n list-style: none;\n display: flex;\n gap: 5px;\n flex-direction: column;\n position: absolute;\n bottom: 0;\n width: 100%;\n left: 0;\n}\n\n.react-input-emoji--mention--item {\n display: flex;\n align-items: center;\n gap: 10px;\n padding: 5px 10px;\n background-color: transparent;\n width: 100%;\n margin: 0;\n border: 0;\n}\n\n.react-input-emoji--mention--item__selected {\n background-color: #eeeeee;\n}\n\n.react-input-emoji--mention--item--img {\n width: 34px;\n height: 34px;\n border-radius: 50%;\n}\n\n.react-input-emoji--mention--item--name {\n font-size: 16px;\n color: #333;\n}\n\n.react-input-emoji--mention--item--name__selected {\n color: green;\n}\n\n.react-input-emoji--mention--text {\n color: #039be5;\n}\n\n.react-input-emoji--mention--loading {\n background-color: #fafafa;\n border: 1px solid #eaeaea;\n border-radius: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 10px 0;\n position: absolute;\n bottom: 0;\n left: 0;\n width: 100%;\n}\n\n.react-input-emoji--mention--loading--spinner,\n.react-input-emoji--mention--loading--spinner::after {\n border-radius: 50%;\n width: 10em;\n height: 10em;\n}\n\n.react-input-emoji--mention--loading--spinner {\n margin: 1px auto;\n font-size: 2px;\n position: relative;\n text-indent: -9999em;\n border-top: 1.1em solid rgba(0, 0, 0, 0.1);\n border-right: 1.1em solid rgba(0, 0, 0, 0.1);\n border-bottom: 1.1em solid rgba(0, 0, 0, 0.1);\n border-left: 1.1em solid rgba(0, 0, 0, 0.4);\n transform: translateZ(0);\n animation: load8 1.1s infinite linear;\n}\n\n@keyframes load8 {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n\n@keyframes slidein {\n from {\n opacity: 0;\n }\n\n to {\n opacity: 1;\n }\n}\n";
38
38
  styleInject(css_248z);
39
39
 
40
- function _iterableToArrayLimit(r, l) {
41
- var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
42
- if (null != t) {
43
- var e,
44
- n,
45
- i,
46
- u,
47
- a = [],
48
- f = !0,
49
- o = !1;
50
- try {
51
- if (i = (t = t.call(r)).next, 0 === l) {
52
- if (Object(t) !== t) return;
53
- f = !1;
54
- } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
55
- } catch (r) {
56
- o = !0, n = r;
57
- } finally {
58
- try {
59
- if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;
60
- } finally {
61
- if (o) throw n;
62
- }
63
- }
64
- return a;
65
- }
66
- }
67
- function ownKeys(e, r) {
68
- var t = Object.keys(e);
69
- if (Object.getOwnPropertySymbols) {
70
- var o = Object.getOwnPropertySymbols(e);
71
- r && (o = o.filter(function (r) {
72
- return Object.getOwnPropertyDescriptor(e, r).enumerable;
73
- })), t.push.apply(t, o);
74
- }
75
- return t;
76
- }
77
- function _objectSpread2(e) {
78
- for (var r = 1; r < arguments.length; r++) {
79
- var t = null != arguments[r] ? arguments[r] : {};
80
- r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {
81
- _defineProperty(e, r, t[r]);
82
- }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {
83
- Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));
84
- });
85
- }
86
- return e;
87
- }
88
- function _regeneratorRuntime() {
89
- _regeneratorRuntime = function () {
90
- return e;
91
- };
92
- var t,
93
- e = {},
94
- r = Object.prototype,
95
- n = r.hasOwnProperty,
96
- o = Object.defineProperty || function (t, e, r) {
97
- t[e] = r.value;
98
- },
99
- i = "function" == typeof Symbol ? Symbol : {},
100
- a = i.iterator || "@@iterator",
101
- c = i.asyncIterator || "@@asyncIterator",
102
- u = i.toStringTag || "@@toStringTag";
103
- function define(t, e, r) {
104
- return Object.defineProperty(t, e, {
105
- value: r,
106
- enumerable: !0,
107
- configurable: !0,
108
- writable: !0
109
- }), t[e];
110
- }
111
- try {
112
- define({}, "");
113
- } catch (t) {
114
- define = function (t, e, r) {
115
- return t[e] = r;
116
- };
117
- }
118
- function wrap(t, e, r, n) {
119
- var i = e && e.prototype instanceof Generator ? e : Generator,
120
- a = Object.create(i.prototype),
121
- c = new Context(n || []);
122
- return o(a, "_invoke", {
123
- value: makeInvokeMethod(t, r, c)
124
- }), a;
125
- }
126
- function tryCatch(t, e, r) {
127
- try {
128
- return {
129
- type: "normal",
130
- arg: t.call(e, r)
131
- };
132
- } catch (t) {
133
- return {
134
- type: "throw",
135
- arg: t
136
- };
137
- }
138
- }
139
- e.wrap = wrap;
140
- var h = "suspendedStart",
141
- l = "suspendedYield",
142
- f = "executing",
143
- s = "completed",
144
- y = {};
145
- function Generator() {}
146
- function GeneratorFunction() {}
147
- function GeneratorFunctionPrototype() {}
148
- var p = {};
149
- define(p, a, function () {
150
- return this;
151
- });
152
- var d = Object.getPrototypeOf,
153
- v = d && d(d(values([])));
154
- v && v !== r && n.call(v, a) && (p = v);
155
- var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
156
- function defineIteratorMethods(t) {
157
- ["next", "throw", "return"].forEach(function (e) {
158
- define(t, e, function (t) {
159
- return this._invoke(e, t);
160
- });
161
- });
162
- }
163
- function AsyncIterator(t, e) {
164
- function invoke(r, o, i, a) {
165
- var c = tryCatch(t[r], t, o);
166
- if ("throw" !== c.type) {
167
- var u = c.arg,
168
- h = u.value;
169
- return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
170
- invoke("next", t, i, a);
171
- }, function (t) {
172
- invoke("throw", t, i, a);
173
- }) : e.resolve(h).then(function (t) {
174
- u.value = t, i(u);
175
- }, function (t) {
176
- return invoke("throw", t, i, a);
177
- });
178
- }
179
- a(c.arg);
180
- }
181
- var r;
182
- o(this, "_invoke", {
183
- value: function (t, n) {
184
- function callInvokeWithMethodAndArg() {
185
- return new e(function (e, r) {
186
- invoke(t, n, e, r);
187
- });
188
- }
189
- return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
190
- }
191
- });
192
- }
193
- function makeInvokeMethod(e, r, n) {
194
- var o = h;
195
- return function (i, a) {
196
- if (o === f) throw new Error("Generator is already running");
197
- if (o === s) {
198
- if ("throw" === i) throw a;
199
- return {
200
- value: t,
201
- done: !0
202
- };
203
- }
204
- for (n.method = i, n.arg = a;;) {
205
- var c = n.delegate;
206
- if (c) {
207
- var u = maybeInvokeDelegate(c, n);
208
- if (u) {
209
- if (u === y) continue;
210
- return u;
211
- }
212
- }
213
- if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
214
- if (o === h) throw o = s, n.arg;
215
- n.dispatchException(n.arg);
216
- } else "return" === n.method && n.abrupt("return", n.arg);
217
- o = f;
218
- var p = tryCatch(e, r, n);
219
- if ("normal" === p.type) {
220
- if (o = n.done ? s : l, p.arg === y) continue;
221
- return {
222
- value: p.arg,
223
- done: n.done
224
- };
225
- }
226
- "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
227
- }
228
- };
229
- }
230
- function maybeInvokeDelegate(e, r) {
231
- var n = r.method,
232
- o = e.iterator[n];
233
- if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
234
- var i = tryCatch(o, e.iterator, r.arg);
235
- if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
236
- var a = i.arg;
237
- return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
238
- }
239
- function pushTryEntry(t) {
240
- var e = {
241
- tryLoc: t[0]
242
- };
243
- 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
244
- }
245
- function resetTryEntry(t) {
246
- var e = t.completion || {};
247
- e.type = "normal", delete e.arg, t.completion = e;
248
- }
249
- function Context(t) {
250
- this.tryEntries = [{
251
- tryLoc: "root"
252
- }], t.forEach(pushTryEntry, this), this.reset(!0);
253
- }
254
- function values(e) {
255
- if (e || "" === e) {
256
- var r = e[a];
257
- if (r) return r.call(e);
258
- if ("function" == typeof e.next) return e;
259
- if (!isNaN(e.length)) {
260
- var o = -1,
261
- i = function next() {
262
- for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
263
- return next.value = t, next.done = !0, next;
264
- };
265
- return i.next = i;
266
- }
267
- }
268
- throw new TypeError(typeof e + " is not iterable");
269
- }
270
- return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
271
- value: GeneratorFunctionPrototype,
272
- configurable: !0
273
- }), o(GeneratorFunctionPrototype, "constructor", {
274
- value: GeneratorFunction,
275
- configurable: !0
276
- }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
277
- var e = "function" == typeof t && t.constructor;
278
- return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
279
- }, e.mark = function (t) {
280
- return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
281
- }, e.awrap = function (t) {
282
- return {
283
- __await: t
284
- };
285
- }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
286
- return this;
287
- }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
288
- void 0 === i && (i = Promise);
289
- var a = new AsyncIterator(wrap(t, r, n, o), i);
290
- return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
291
- return t.done ? t.value : a.next();
292
- });
293
- }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
294
- return this;
295
- }), define(g, "toString", function () {
296
- return "[object Generator]";
297
- }), e.keys = function (t) {
298
- var e = Object(t),
299
- r = [];
300
- for (var n in e) r.push(n);
301
- return r.reverse(), function next() {
302
- for (; r.length;) {
303
- var t = r.pop();
304
- if (t in e) return next.value = t, next.done = !1, next;
305
- }
306
- return next.done = !0, next;
307
- };
308
- }, e.values = values, Context.prototype = {
309
- constructor: Context,
310
- reset: function (e) {
311
- if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t);
312
- },
313
- stop: function () {
314
- this.done = !0;
315
- var t = this.tryEntries[0].completion;
316
- if ("throw" === t.type) throw t.arg;
317
- return this.rval;
318
- },
319
- dispatchException: function (e) {
320
- if (this.done) throw e;
321
- var r = this;
322
- function handle(n, o) {
323
- return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
324
- }
325
- for (var o = this.tryEntries.length - 1; o >= 0; --o) {
326
- var i = this.tryEntries[o],
327
- a = i.completion;
328
- if ("root" === i.tryLoc) return handle("end");
329
- if (i.tryLoc <= this.prev) {
330
- var c = n.call(i, "catchLoc"),
331
- u = n.call(i, "finallyLoc");
332
- if (c && u) {
333
- if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
334
- if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
335
- } else if (c) {
336
- if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
337
- } else {
338
- if (!u) throw new Error("try statement without catch or finally");
339
- if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
340
- }
341
- }
342
- }
343
- },
344
- abrupt: function (t, e) {
345
- for (var r = this.tryEntries.length - 1; r >= 0; --r) {
346
- var o = this.tryEntries[r];
347
- if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
348
- var i = o;
349
- break;
350
- }
351
- }
352
- i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
353
- var a = i ? i.completion : {};
354
- return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
355
- },
356
- complete: function (t, e) {
357
- if ("throw" === t.type) throw t.arg;
358
- return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
359
- },
360
- finish: function (t) {
361
- for (var e = this.tryEntries.length - 1; e >= 0; --e) {
362
- var r = this.tryEntries[e];
363
- if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
364
- }
365
- },
366
- catch: function (t) {
367
- for (var e = this.tryEntries.length - 1; e >= 0; --e) {
368
- var r = this.tryEntries[e];
369
- if (r.tryLoc === t) {
370
- var n = r.completion;
371
- if ("throw" === n.type) {
372
- var o = n.arg;
373
- resetTryEntry(r);
374
- }
375
- return o;
376
- }
377
- }
378
- throw new Error("illegal catch attempt");
379
- },
380
- delegateYield: function (e, r, n) {
381
- return this.delegate = {
382
- iterator: values(e),
383
- resultName: r,
384
- nextLoc: n
385
- }, "next" === this.method && (this.arg = t), y;
386
- }
387
- }, e;
388
- }
389
- function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
390
- try {
391
- var info = gen[key](arg);
392
- var value = info.value;
393
- } catch (error) {
394
- reject(error);
395
- return;
396
- }
397
- if (info.done) {
398
- resolve(value);
399
- } else {
400
- Promise.resolve(value).then(_next, _throw);
401
- }
402
- }
403
- function _asyncToGenerator(fn) {
404
- return function () {
405
- var self = this,
406
- args = arguments;
407
- return new Promise(function (resolve, reject) {
408
- var gen = fn.apply(self, args);
409
- function _next(value) {
410
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
411
- }
412
- function _throw(err) {
413
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
414
- }
415
- _next(undefined);
416
- });
417
- };
418
- }
419
- function _defineProperty(obj, key, value) {
420
- key = _toPropertyKey(key);
421
- if (key in obj) {
422
- Object.defineProperty(obj, key, {
423
- value: value,
424
- enumerable: true,
425
- configurable: true,
426
- writable: true
427
- });
428
- } else {
429
- obj[key] = value;
430
- }
431
- return obj;
432
- }
433
- function _objectWithoutPropertiesLoose(source, excluded) {
434
- if (source == null) return {};
435
- var target = {};
436
- var sourceKeys = Object.keys(source);
437
- var key, i;
438
- for (i = 0; i < sourceKeys.length; i++) {
439
- key = sourceKeys[i];
440
- if (excluded.indexOf(key) >= 0) continue;
441
- target[key] = source[key];
442
- }
443
- return target;
444
- }
445
- function _objectWithoutProperties(source, excluded) {
446
- if (source == null) return {};
447
- var target = _objectWithoutPropertiesLoose(source, excluded);
448
- var key, i;
449
- if (Object.getOwnPropertySymbols) {
450
- var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
451
- for (i = 0; i < sourceSymbolKeys.length; i++) {
452
- key = sourceSymbolKeys[i];
453
- if (excluded.indexOf(key) >= 0) continue;
454
- if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
455
- target[key] = source[key];
456
- }
457
- }
458
- return target;
459
- }
460
- function _slicedToArray(arr, i) {
461
- return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
462
- }
463
- function _toConsumableArray(arr) {
464
- return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
465
- }
466
- function _arrayWithoutHoles(arr) {
467
- if (Array.isArray(arr)) return _arrayLikeToArray(arr);
468
- }
469
- function _arrayWithHoles(arr) {
470
- if (Array.isArray(arr)) return arr;
471
- }
472
- function _iterableToArray(iter) {
473
- if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
474
- }
475
- function _unsupportedIterableToArray(o, minLen) {
476
- if (!o) return;
477
- if (typeof o === "string") return _arrayLikeToArray(o, minLen);
478
- var n = Object.prototype.toString.call(o).slice(8, -1);
479
- if (n === "Object" && o.constructor) n = o.constructor.name;
480
- if (n === "Map" || n === "Set") return Array.from(o);
481
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
482
- }
483
- function _arrayLikeToArray(arr, len) {
484
- if (len == null || len > arr.length) len = arr.length;
485
- for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
486
- return arr2;
487
- }
488
- function _nonIterableSpread() {
489
- throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
490
- }
491
- function _nonIterableRest() {
492
- throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
493
- }
494
- function _toPrimitive(input, hint) {
495
- if (typeof input !== "object" || input === null) return input;
496
- var prim = input[Symbol.toPrimitive];
497
- if (prim !== undefined) {
498
- var res = prim.call(input, hint || "default");
499
- if (typeof res !== "object") return res;
500
- throw new TypeError("@@toPrimitive must return a primitive value.");
501
- }
502
- return (hint === "string" ? String : Number)(input);
503
- }
504
- function _toPropertyKey(arg) {
505
- var key = _toPrimitive(arg, "string");
506
- return typeof key === "symbol" ? key : String(key);
507
- }
508
-
509
40
  /* eslint-disable valid-jsdoc */
510
41
  // @ts-check
511
42
 
512
- var TRANSPARENT_GIF = "";
43
+ const TRANSPARENT_GIF = "";
513
44
 
514
45
  /**
515
46
  * Replace all text with emoji with an image html tag
@@ -517,11 +48,11 @@ var TRANSPARENT_GIF = "
517
48
  * @return {string}
518
49
  */
519
50
  function replaceAllTextEmojis(text) {
520
- var allEmojis = getAllEmojisFromText(text);
51
+ let allEmojis = getAllEmojisFromText(text);
521
52
  if (allEmojis) {
522
- allEmojis = _toConsumableArray(new Set(allEmojis)); // remove duplicates
53
+ allEmojis = [...new Set(allEmojis)]; // remove duplicates
523
54
 
524
- allEmojis.forEach(function (emoji) {
55
+ allEmojis.forEach(emoji => {
525
56
  text = replaceAll(text, emoji, getInputEmojiHTML('', emoji));
526
57
  });
527
58
  }
@@ -555,20 +86,19 @@ function getAllEmojisFromText(text) {
555
86
  * @return {string}
556
87
  */
557
88
  function getImageEmoji(emoji) {
558
- var _emojiPickerEl$shadow;
559
89
  /** @type {HTMLElement | null} */
560
- var emojiPickerEl = document.querySelector('em-emoji-picker');
90
+ const emojiPickerEl = document.querySelector('em-emoji-picker');
561
91
  if (!emojiPickerEl) {
562
- return getInputEmojiNativeHTML(emoji["native"]);
92
+ return getInputEmojiNativeHTML(emoji.native);
563
93
  }
564
94
 
565
95
  /** @type {HTMLSpanElement | null=} */
566
- var emojiSpanEl = emojiPickerEl === null || emojiPickerEl === void 0 || (_emojiPickerEl$shadow = emojiPickerEl.shadowRoot) === null || _emojiPickerEl$shadow === void 0 ? void 0 : _emojiPickerEl$shadow.querySelector("[title=\"".concat(emoji.name, "\"] > span > span"));
96
+ const emojiSpanEl = emojiPickerEl?.shadowRoot?.querySelector(`[title="${emoji.name}"] > span > span`);
567
97
  if (!emojiSpanEl) {
568
- return getInputEmojiNativeHTML(emoji["native"]);
98
+ return getInputEmojiNativeHTML(emoji.native);
569
99
  }
570
- var style = replaceAll(emojiSpanEl.style.cssText, '"', "'");
571
- return getInputEmojiHTML(style, emoji["native"]);
100
+ const style = replaceAll(emojiSpanEl.style.cssText, '"', "'");
101
+ return getInputEmojiHTML(style, emoji.native);
572
102
  }
573
103
 
574
104
  // eslint-disable-next-line valid-jsdoc
@@ -579,7 +109,7 @@ function getImageEmoji(emoji) {
579
109
  * @returns
580
110
  */
581
111
  function getInputEmojiHTML(style, emoji) {
582
- return "<img style=\"".concat(style, "; display: inline-block\" data-emoji=\"").concat(emoji, "\" src=\"").concat(TRANSPARENT_GIF, "\" />");
112
+ return `<img style="${style}; display: inline-block" data-emoji="${emoji}" src="${TRANSPARENT_GIF}" />`;
583
113
  }
584
114
 
585
115
  /**
@@ -588,7 +118,7 @@ function getInputEmojiHTML(style, emoji) {
588
118
  * @returns
589
119
  */
590
120
  function getInputEmojiNativeHTML(emoji) {
591
- return "<span class=\"width: 18px; height: 18px; display: inline-block; margin: 0 1px;\">".concat(emoji, "</span>");
121
+ return `<span class="width: 18px; height: 18px; display: inline-block; margin: 0 1px;">${emoji}</span>`;
592
122
  }
593
123
 
594
124
  /**
@@ -597,10 +127,10 @@ function getInputEmojiNativeHTML(emoji) {
597
127
  * @return {string}
598
128
  */
599
129
  function replaceAllTextEmojiToString(html) {
600
- var container = document.createElement("div");
130
+ const container = document.createElement("div");
601
131
  container.innerHTML = html;
602
- var images = Array.prototype.slice.call(container.querySelectorAll("img"));
603
- images.forEach(function (image) {
132
+ const images = Array.prototype.slice.call(container.querySelectorAll("img"));
133
+ images.forEach(image => {
604
134
  container.innerHTML = container.innerHTML.replace(image.outerHTML, image.dataset.emoji);
605
135
  });
606
136
  return container.innerHTML;
@@ -613,12 +143,12 @@ function replaceAllTextEmojiToString(html) {
613
143
  * @param {React.ClipboardEvent} event
614
144
  */
615
145
  function handleCopy(event) {
616
- var selectedText = window.getSelection();
146
+ const selectedText = window.getSelection();
617
147
  if (selectedText === null) {
618
148
  return;
619
149
  }
620
- var container = document.createElement("div");
621
- for (var i = 0, len = selectedText.rangeCount; i < len; ++i) {
150
+ let container = document.createElement("div");
151
+ for (let i = 0, len = selectedText.rangeCount; i < len; ++i) {
622
152
  container.appendChild(selectedText.getRangeAt(i).cloneContents());
623
153
  }
624
154
  container = replaceEmojiToString(container);
@@ -626,28 +156,41 @@ function handleCopy(event) {
626
156
  event.preventDefault();
627
157
  }
628
158
 
159
+ /** @type {Range|undefined} */
160
+ /** @type {Range|undefined} */
161
+ let currentRangeCached;
162
+
163
+ /**
164
+ * Caches the current text selection range
165
+ */
166
+ function cacheCurrentRange() {
167
+ const selection = window.getSelection();
168
+ if (!selection.rangeCount || selection?.anchorNode['className'] !== 'react-input-emoji--input' && selection.anchorNode.parentNode['className'] !== 'react-input-emoji--input') return;
169
+ const range = selection.getRangeAt(0);
170
+ currentRangeCached = range.cloneRange();
171
+ }
172
+
629
173
  /**
630
- *
631
- * @param {string} html
174
+ * @param {string} html - HTML string to be pasted at the caret position
632
175
  */
633
176
  function handlePasteHtmlAtCaret(html) {
634
- var sel;
635
- var range;
177
+ let sel;
178
+ let range;
636
179
  if (window.getSelection) {
637
180
  // IE9 and non-IE
638
181
  sel = window.getSelection();
639
182
  if (sel === null) return;
640
183
  if (sel.getRangeAt && sel.rangeCount) {
641
- range = sel.getRangeAt(0);
184
+ range = currentRangeCached ?? sel.getRangeAt(0);
642
185
  range.deleteContents();
643
186
 
644
187
  // Range.createContextualFragment() would be useful here but is
645
188
  // non-standard and not supported in all browsers (IE9, for one)
646
- var el = document.createElement("div");
189
+ const el = document.createElement("div");
647
190
  el.innerHTML = html;
648
- var frag = document.createDocumentFragment();
649
- var node;
650
- var lastNode;
191
+ const frag = document.createDocumentFragment();
192
+ let node;
193
+ let lastNode;
651
194
  while (node = el.firstChild) {
652
195
  lastNode = frag.appendChild(node);
653
196
  }
@@ -656,6 +199,7 @@ function handlePasteHtmlAtCaret(html) {
656
199
  // Preserve the selection
657
200
  if (lastNode) {
658
201
  range = range.cloneRange();
202
+ currentRangeCached = range;
659
203
  range.setStartAfter(lastNode);
660
204
  range.collapse(true);
661
205
  sel.removeAllRanges();
@@ -671,8 +215,8 @@ function handlePasteHtmlAtCaret(html) {
671
215
  * @return {HTMLDivElement}
672
216
  */
673
217
  function replaceEmojiToString(container) {
674
- var images = Array.prototype.slice.call(container.querySelectorAll("img"));
675
- images.forEach(function (image) {
218
+ const images = Array.prototype.slice.call(container.querySelectorAll("img"));
219
+ images.forEach(image => {
676
220
  image.outerHTML = image.dataset.emoji;
677
221
  });
678
222
  return container;
@@ -683,11 +227,12 @@ function replaceEmojiToString(container) {
683
227
  * @param {{text: string, html: string}} props
684
228
  * @return {number}
685
229
  */
686
- function totalCharacters(_ref2) {
687
- var text = _ref2.text,
688
- html = _ref2.html;
689
- var textCount = text.length;
690
- var emojisCount = (html.match(/<img/g) || []).length;
230
+ function totalCharacters({
231
+ text,
232
+ html
233
+ }) {
234
+ const textCount = text.length;
235
+ const emojisCount = (html.match(/<img/g) || []).length;
691
236
  return textCount + emojisCount;
692
237
  }
693
238
  /**
@@ -696,12 +241,12 @@ function totalCharacters(_ref2) {
696
241
  * @return {string}
697
242
  */
698
243
  function removeHtmlExceptBr(inputDiv) {
699
- var temp = inputDiv.innerHTML.replaceAll(/<br\s*\/?>/gi, "[BR]"); // temporarily replace <br> with placeholder
700
- var tempContainer = document.createElement("div");
244
+ const temp = inputDiv.innerHTML.replaceAll(/<br\s*\/?>/gi, "[BR]"); // temporarily replace <br> with placeholder
245
+ const tempContainer = document.createElement("div");
701
246
  tempContainer.innerHTML = temp;
702
- var stripped = tempContainer.innerText; // strip all html tags
703
- var _final = stripped.replaceAll(/\[BR\]/gi, "</br>"); // replace placeholders with <br>
704
- return _final;
247
+ const stripped = tempContainer.innerText; // strip all html tags
248
+ const final = stripped.replaceAll(/\[BR\]/gi, "</br>"); // replace placeholders with <br>
249
+ return final;
705
250
  }
706
251
 
707
252
  /**
@@ -710,8 +255,8 @@ function removeHtmlExceptBr(inputDiv) {
710
255
  * @returns
711
256
  */
712
257
  function getSelectionStart$1(range) {
713
- var node = range.startContainer;
714
- var offset = range.startOffset;
258
+ let node = range.startContainer;
259
+ let offset = range.startOffset;
715
260
 
716
261
  // Handle cases where the selection start node is not a text node
717
262
  if (node.nodeType !== Node.TEXT_NODE) {
@@ -728,8 +273,8 @@ function getSelectionStart$1(range) {
728
273
  offset = 0;
729
274
  }
730
275
  return {
731
- node: node,
732
- offset: offset
276
+ node,
277
+ offset
733
278
  };
734
279
  }
735
280
 
@@ -738,13 +283,13 @@ function getSelectionStart$1(range) {
738
283
  * @return {Object} cursor
739
284
  */
740
285
  function getCursor() {
741
- var selection = window.getSelection();
742
- var range = selection.getRangeAt(0);
743
- var selectionStart = getSelectionStart$1(range);
286
+ const selection = window.getSelection();
287
+ const range = selection.getRangeAt(0);
288
+ const selectionStart = getSelectionStart$1(range);
744
289
  return {
745
- selection: selection,
746
- range: range,
747
- selectionStart: selectionStart
290
+ selection,
291
+ range,
292
+ selectionStart
748
293
  };
749
294
  }
750
295
 
@@ -752,30 +297,31 @@ function getCursor() {
752
297
  *
753
298
  */
754
299
  function addLineBreak() {
755
- var _getCursor = getCursor(),
756
- selection = _getCursor.selection,
757
- range = _getCursor.range,
758
- selectionStart = _getCursor.selectionStart;
300
+ const {
301
+ selection,
302
+ range,
303
+ selectionStart
304
+ } = getCursor();
759
305
 
760
306
  // If cursor is at the end of the text content, add one more line break
761
307
  if (selection.isCollapsed && selectionStart.offset === selectionStart.node.textContent.length) {
762
- var br = document.createElement("br");
308
+ const br = document.createElement("br");
763
309
  range.insertNode(br);
764
310
  range.setStartAfter(br);
765
311
  range.setEndAfter(br);
766
312
  selection.removeAllRanges();
767
313
  selection.addRange(range);
768
- var br2 = document.createElement("br");
314
+ const br2 = document.createElement("br");
769
315
  range.insertNode(br2);
770
316
  range.setStartAfter(br2);
771
317
  range.setEndAfter(br2);
772
318
  selection.removeAllRanges();
773
319
  selection.addRange(range);
774
320
  } else {
775
- var _br = document.createElement("br");
776
- range.insertNode(_br);
777
- range.setStartAfter(_br);
778
- range.setEndAfter(_br);
321
+ const br = document.createElement("br");
322
+ range.insertNode(br);
323
+ range.setStartAfter(br);
324
+ range.setEndAfter(br);
779
325
  selection.removeAllRanges();
780
326
  selection.addRange(range);
781
327
  // Set cursor position right before the first letter after the line break
@@ -994,7 +540,7 @@ var reactEasyEmoji = function reactEasyEmoji(element, optionsOrFn) {
994
540
  var emoji = reactEasyEmoji;
995
541
 
996
542
  // @ts-check
997
- var EMOJI_REGEX = new RegExp(/(?:[\u2700-\u27bf]|(?:\ud83c[\udde6-\uddff]){2}|[\ud800-\udbff][\udc00-\udfff])[\ufe0e\ufe0f]?(?:[\u0300-\u036f\ufe20-\ufe23\u20d0-\u20f0]|\ud83c[\udffb-\udfff])?(?:\u200d(?:[^\ud800-\udfff]|(?:\ud83c[\udde6-\uddff]){2}|[\ud800-\udbff][\udc00-\udfff])[\ufe0e\ufe0f]?(?:[\u0300-\u036f\ufe20-\ufe23\u20d0-\u20f0]|\ud83c[\udffb-\udfff])?)*/g);
543
+ const EMOJI_REGEX = new RegExp(/(?:[\u2700-\u27bf]|(?:\ud83c[\udde6-\uddff]){2}|[\ud800-\udbff][\udc00-\udfff])[\ufe0e\ufe0f]?(?:[\u0300-\u036f\ufe20-\ufe23\u20d0-\u20f0]|\ud83c[\udffb-\udfff])?(?:\u200d(?:[^\ud800-\udfff]|(?:\ud83c[\udde6-\uddff]){2}|[\ud800-\udbff][\udc00-\udfff])[\ufe0e\ufe0f]?(?:[\u0300-\u036f\ufe20-\ufe23\u20d0-\u20f0]|\ud83c[\udffb-\udfff])?)*/g);
998
544
 
999
545
  /**
1000
546
  * @typedef {import('../types/types').SanitizeFn} SanitizeFn
@@ -1007,17 +553,17 @@ var EMOJI_REGEX = new RegExp(/(?:[\u2700-\u27bf]|(?:\ud83c[\udde6-\uddff]){2}|[\
1007
553
  */
1008
554
  function useSanitize(shouldReturn, shouldConvertEmojiToImage) {
1009
555
  /** @type {React.MutableRefObject<SanitizeFn[]>} */
1010
- var sanitizeFnsRef = React.useRef([]);
1011
- var sanitizedTextRef = React.useRef("");
556
+ const sanitizeFnsRef = React.useRef([]);
557
+ const sanitizedTextRef = React.useRef("");
1012
558
 
1013
559
  /** @type {(fn: SanitizeFn) => void} */
1014
- var addSanitizeFn = React.useCallback(function (fn) {
560
+ const addSanitizeFn = React.useCallback(fn => {
1015
561
  sanitizeFnsRef.current.push(fn);
1016
562
  }, []);
1017
563
 
1018
564
  /** @type {(html: string) => string} */
1019
- var sanitize = React.useCallback(function (html) {
1020
- var result = sanitizeFnsRef.current.reduce(function (acc, fn) {
565
+ const sanitize = React.useCallback(html => {
566
+ let result = sanitizeFnsRef.current.reduce((acc, fn) => {
1021
567
  return fn(acc);
1022
568
  }, html);
1023
569
  result = replaceAllHtmlToString(result, shouldReturn);
@@ -1028,9 +574,9 @@ function useSanitize(shouldReturn, shouldConvertEmojiToImage) {
1028
574
  return result;
1029
575
  }, [shouldReturn, shouldConvertEmojiToImage]);
1030
576
  return {
1031
- addSanitizeFn: addSanitizeFn,
1032
- sanitize: sanitize,
1033
- sanitizedTextRef: sanitizedTextRef
577
+ addSanitizeFn,
578
+ sanitize,
579
+ sanitizedTextRef
1034
580
  };
1035
581
  }
1036
582
 
@@ -1041,9 +587,9 @@ function useSanitize(shouldReturn, shouldConvertEmojiToImage) {
1041
587
  * @return {string}
1042
588
  */
1043
589
  function replaceAllHtmlToString(html, shouldReturn) {
1044
- var container = document.createElement("div");
590
+ const container = document.createElement("div");
1045
591
  container.innerHTML = html;
1046
- var text;
592
+ let text;
1047
593
  if (shouldReturn) {
1048
594
  text = removeHtmlExceptBr(container);
1049
595
  } else {
@@ -1092,35 +638,35 @@ function handleEmoji(text) {
1092
638
  *
1093
639
  * @param {Props} props
1094
640
  */
1095
- function useExpose(_ref) {
1096
- var ref = _ref.ref,
1097
- textInputRef = _ref.textInputRef,
1098
- setValue = _ref.setValue,
1099
- emitChange = _ref.emitChange,
1100
- shouldConvertEmojiToImage = _ref.shouldConvertEmojiToImage;
1101
- var _useSanitize = useSanitize(false, shouldConvertEmojiToImage),
1102
- sanitize = _useSanitize.sanitize,
1103
- sanitizedTextRef = _useSanitize.sanitizedTextRef;
1104
- React.useImperativeHandle(ref, function () {
1105
- return {
1106
- get value() {
1107
- return sanitizedTextRef.current;
1108
- },
1109
- set value(value) {
1110
- setValue(value);
1111
- },
1112
- focus: function focus() {
1113
- if (textInputRef.current === null) return;
1114
- textInputRef.current.focus();
1115
- },
1116
- blur: function blur() {
1117
- if (textInputRef.current !== null) {
1118
- sanitize(textInputRef.current.html);
1119
- }
1120
- emitChange();
641
+ function useExpose({
642
+ ref,
643
+ textInputRef,
644
+ setValue,
645
+ emitChange,
646
+ shouldConvertEmojiToImage
647
+ }) {
648
+ const {
649
+ sanitize,
650
+ sanitizedTextRef
651
+ } = useSanitize(false, shouldConvertEmojiToImage);
652
+ React.useImperativeHandle(ref, () => ({
653
+ get value() {
654
+ return sanitizedTextRef.current;
655
+ },
656
+ set value(value) {
657
+ setValue(value);
658
+ },
659
+ focus: () => {
660
+ if (textInputRef.current === null) return;
661
+ textInputRef.current.focus();
662
+ },
663
+ blur: () => {
664
+ if (textInputRef.current !== null) {
665
+ sanitize(textInputRef.current.html);
1121
666
  }
1122
- };
1123
- });
667
+ emitChange();
668
+ }
669
+ }));
1124
670
  }
1125
671
 
1126
672
  // @ts-check
@@ -1134,19 +680,19 @@ function useExpose(_ref) {
1134
680
  */
1135
681
  function useEmit(textInputRef, onResize, onChange) {
1136
682
  /** @type {React.MutableRefObject<{width: number; height: number} | null>} */
1137
- var currentSizeRef = React.useRef(null);
1138
- var onChangeFn = React.useRef(onChange);
1139
- var checkAndEmitResize = React.useCallback(function () {
683
+ const currentSizeRef = React.useRef(null);
684
+ const onChangeFn = React.useRef(onChange);
685
+ const checkAndEmitResize = React.useCallback(() => {
1140
686
  if (textInputRef.current !== null) {
1141
- var currentSize = currentSizeRef.current;
1142
- var nextSize = textInputRef.current.size;
687
+ const currentSize = currentSizeRef.current;
688
+ const nextSize = textInputRef.current.size;
1143
689
  if ((!currentSize || currentSize.width !== nextSize.width || currentSize.height !== nextSize.height) && typeof onResize === "function") {
1144
690
  onResize(nextSize);
1145
691
  }
1146
692
  currentSizeRef.current = nextSize;
1147
693
  }
1148
694
  }, [onResize, textInputRef]);
1149
- var emitChange = React.useCallback(function (sanitizedText) {
695
+ const emitChange = React.useCallback(sanitizedText => {
1150
696
  if (typeof onChangeFn.current === "function") {
1151
697
  onChangeFn.current(sanitizedText);
1152
698
  }
@@ -1154,7 +700,7 @@ function useEmit(textInputRef, onResize, onChange) {
1154
700
  checkAndEmitResize();
1155
701
  }
1156
702
  }, [checkAndEmitResize, onResize]);
1157
- React.useEffect(function () {
703
+ React.useEffect(() => {
1158
704
  if (textInputRef.current) {
1159
705
  checkAndEmitResize();
1160
706
  }
@@ -1162,7 +708,7 @@ function useEmit(textInputRef, onResize, onChange) {
1162
708
  return emitChange;
1163
709
  }
1164
710
 
1165
- var _excluded = ["placeholder", "style", "tabIndex", "className", "onChange"];
711
+ // @ts-check
1166
712
 
1167
713
  /**
1168
714
  * @typedef {Object} Props
@@ -1196,97 +742,96 @@ var _excluded = ["placeholder", "style", "tabIndex", "className", "onChange"];
1196
742
 
1197
743
  // eslint-disable-next-line valid-jsdoc
1198
744
  /** @type {React.ForwardRefRenderFunction<Ref, Props>} */
1199
- var TextInput = function TextInput(_ref, ref) {
1200
- var placeholder = _ref.placeholder,
1201
- style = _ref.style,
1202
- tabIndex = _ref.tabIndex,
1203
- className = _ref.className,
1204
- onChange = _ref.onChange,
1205
- props = _objectWithoutProperties(_ref, _excluded);
1206
- React.useImperativeHandle(ref, function () {
1207
- return {
1208
- appendContent: function appendContent(html) {
1209
- if (textInputRef.current) {
1210
- textInputRef.current.focus();
1211
- }
1212
- handlePasteHtmlAtCaret(html);
1213
- if (textInputRef.current) {
1214
- textInputRef.current.focus();
1215
- }
1216
- if (textInputRef.current && placeholderRef.current && replaceAllTextEmojiToString(textInputRef.current.innerHTML) === "") {
745
+ const TextInput = ({
746
+ placeholder,
747
+ style,
748
+ tabIndex,
749
+ className,
750
+ onChange,
751
+ ...props
752
+ }, ref) => {
753
+ React.useImperativeHandle(ref, () => ({
754
+ appendContent: html => {
755
+ if (textInputRef.current) {
756
+ textInputRef.current.focus();
757
+ }
758
+ handlePasteHtmlAtCaret(html);
759
+ if (textInputRef.current) {
760
+ textInputRef.current.focus();
761
+ }
762
+ if (textInputRef.current && placeholderRef.current && replaceAllTextEmojiToString(textInputRef.current.innerHTML) === "") {
763
+ placeholderRef.current.style.visibility = "visible";
764
+ } else if (placeholderRef.current) {
765
+ placeholderRef.current.style.visibility = "hidden";
766
+ }
767
+ if (textInputRef.current && typeof onChange === 'function') {
768
+ onChange(textInputRef.current.innerHTML);
769
+ }
770
+ },
771
+ set html(value) {
772
+ if (textInputRef.current) {
773
+ textInputRef.current.innerHTML = value;
774
+ }
775
+ if (placeholderRef.current) {
776
+ const text = replaceAllTextEmojiToString(value);
777
+ if (text === "") {
1217
778
  placeholderRef.current.style.visibility = "visible";
1218
- } else if (placeholderRef.current) {
779
+ } else {
1219
780
  placeholderRef.current.style.visibility = "hidden";
1220
781
  }
1221
- if (textInputRef.current && typeof onChange === 'function') {
1222
- onChange(textInputRef.current.innerHTML);
1223
- }
1224
- },
1225
- set html(value) {
1226
- if (textInputRef.current) {
1227
- textInputRef.current.innerHTML = value;
1228
- }
1229
- if (placeholderRef.current) {
1230
- var text = replaceAllTextEmojiToString(value);
1231
- if (text === "") {
1232
- placeholderRef.current.style.visibility = "visible";
1233
- } else {
1234
- placeholderRef.current.style.visibility = "hidden";
1235
- }
1236
- }
1237
- if (typeof onChange === 'function' && textInputRef.current) {
1238
- onChange(textInputRef.current.innerHTML);
1239
- }
1240
- },
1241
- get html() {
1242
- if (!textInputRef.current) return '';
1243
- return textInputRef.current.innerHTML;
1244
- },
1245
- get text() {
1246
- if (!textInputRef.current) return '';
1247
- return textInputRef.current.innerText;
1248
- },
1249
- get size() {
1250
- if (!textInputRef.current) {
1251
- return {
1252
- width: 0,
1253
- height: 0
1254
- };
1255
- }
782
+ }
783
+ if (typeof onChange === 'function' && textInputRef.current) {
784
+ onChange(textInputRef.current.innerHTML);
785
+ }
786
+ },
787
+ get html() {
788
+ if (!textInputRef.current) return '';
789
+ return textInputRef.current.innerHTML;
790
+ },
791
+ get text() {
792
+ if (!textInputRef.current) return '';
793
+ return textInputRef.current.innerText;
794
+ },
795
+ get size() {
796
+ if (!textInputRef.current) {
1256
797
  return {
1257
- width: textInputRef.current.offsetWidth,
1258
- height: textInputRef.current.offsetHeight
798
+ width: 0,
799
+ height: 0
1259
800
  };
1260
- },
1261
- focus: function focus() {
1262
- if (!textInputRef.current) return;
1263
- textInputRef.current.focus();
1264
801
  }
1265
- };
1266
- });
802
+ return {
803
+ width: textInputRef.current.offsetWidth,
804
+ height: textInputRef.current.offsetHeight
805
+ };
806
+ },
807
+ focus() {
808
+ if (!textInputRef.current) return;
809
+ textInputRef.current.focus();
810
+ }
811
+ }));
1267
812
 
1268
813
  /** @type {React.CSSProperties} */
1269
- var placeholderStyle = React.useMemo(function () {
1270
- var placeholderStyle = {};
814
+ const placeholderStyle = React.useMemo(() => {
815
+ const placeholderStyle = {};
1271
816
  if (style.placeholderColor) {
1272
817
  placeholderStyle.color = style.placeholderColor;
1273
818
  }
1274
819
  return placeholderStyle;
1275
- }, [style === null || style === void 0 ? void 0 : style.placeholderColor]);
820
+ }, [style?.placeholderColor]);
1276
821
 
1277
822
  /** @type {React.CSSProperties} */
1278
- var inputStyle = React.useMemo(function () {
1279
- var inputStyle = {};
823
+ const inputStyle = React.useMemo(() => {
824
+ const inputStyle = {};
1280
825
  if (style.color) {
1281
826
  inputStyle.color = style.color;
1282
827
  }
1283
828
  return inputStyle;
1284
- }, [style === null || style === void 0 ? void 0 : style.color]);
829
+ }, [style?.color]);
1285
830
 
1286
831
  /** @type {React.MutableRefObject<HTMLDivElement | null>} */
1287
- var placeholderRef = React.useRef(null);
832
+ const placeholderRef = React.useRef(null);
1288
833
  /** @type {React.MutableRefObject<HTMLDivElement | null>} */
1289
- var textInputRef = React.useRef(null);
834
+ const textInputRef = React.useRef(null);
1290
835
 
1291
836
  /**
1292
837
  *
@@ -1325,9 +870,9 @@ var TextInput = function TextInput(_ref, ref) {
1325
870
  */
1326
871
  function handleKeyUp(event) {
1327
872
  props.onKeyUp(event);
1328
- var input = textInputRef.current;
873
+ const input = textInputRef.current;
1329
874
  if (placeholderRef.current && input) {
1330
- var text = replaceAllTextEmojiToString(input.innerHTML);
875
+ const text = replaceAllTextEmojiToString(input.innerHTML);
1331
876
  if (text === "") {
1332
877
  placeholderRef.current.style.visibility = "visible";
1333
878
  } else {
@@ -1354,7 +899,7 @@ var TextInput = function TextInput(_ref, ref) {
1354
899
  onKeyUp: handleKeyUp,
1355
900
  tabIndex: tabIndex,
1356
901
  contentEditable: true,
1357
- className: "react-input-emoji--input".concat(className ? " ".concat(className) : ""),
902
+ className: `react-input-emoji--input${className ? ` ${className}` : ""}`,
1358
903
  onBlur: props.onBlur,
1359
904
  onCopy: props.onCopy,
1360
905
  onPaste: props.onPaste,
@@ -1362,7 +907,9 @@ var TextInput = function TextInput(_ref, ref) {
1362
907
  style: inputStyle
1363
908
  })));
1364
909
  };
1365
- var TextInputWithRef = /*#__PURE__*/React.forwardRef(TextInput);
910
+ const TextInputWithRef = /*#__PURE__*/React.forwardRef(TextInput);
911
+
912
+ // vendors
1366
913
 
1367
914
  /**
1368
915
  * @typedef {object} Props
@@ -1377,30 +924,27 @@ var TextInputWithRef = /*#__PURE__*/React.forwardRef(TextInput);
1377
924
  * @param {Props} props
1378
925
  * @return {JSX.Element}
1379
926
  */
1380
- function EmojiPickerButton(_ref) {
1381
- var showPicker = _ref.showPicker,
1382
- toggleShowPicker = _ref.toggleShowPicker,
1383
- buttonElement = _ref.buttonElement,
1384
- buttonRef = _ref.buttonRef;
1385
- var localButtonRef = React.useRef(null);
1386
- var _useState = React.useState(false),
1387
- _useState2 = _slicedToArray(_useState, 2),
1388
- showCustomButtonContent = _useState2[0],
1389
- setShowCustomButtonContent = _useState2[1];
1390
- React.useEffect(function () {
1391
- var _buttonRef$current$ch, _buttonRef$current, _buttonElement$childN, _buttonElement$childN2;
1392
- if (((_buttonRef$current$ch = buttonRef === null || buttonRef === void 0 || (_buttonRef$current = buttonRef.current) === null || _buttonRef$current === void 0 || (_buttonRef$current = _buttonRef$current.childNodes) === null || _buttonRef$current === void 0 ? void 0 : _buttonRef$current.length) !== null && _buttonRef$current$ch !== void 0 ? _buttonRef$current$ch : 0) > 2) {
927
+ function EmojiPickerButton({
928
+ showPicker,
929
+ toggleShowPicker,
930
+ buttonElement,
931
+ buttonRef
932
+ }) {
933
+ const localButtonRef = React.useRef(null);
934
+ const [showCustomButtonContent, setShowCustomButtonContent] = React.useState(false);
935
+ React.useEffect(() => {
936
+ if ((buttonRef?.current?.childNodes?.length ?? 0) > 2) {
1393
937
  localButtonRef.current.appendChild(buttonRef.current.childNodes[0]);
1394
938
  setShowCustomButtonContent(true);
1395
- } else if (((_buttonElement$childN = buttonElement === null || buttonElement === void 0 || (_buttonElement$childN2 = buttonElement.childNodes) === null || _buttonElement$childN2 === void 0 ? void 0 : _buttonElement$childN2.length) !== null && _buttonElement$childN !== void 0 ? _buttonElement$childN : 0) > 2) {
1396
- localButtonRef.current.appendChild(buttonElement === null || buttonElement === void 0 ? void 0 : buttonElement.childNodes[0]);
939
+ } else if ((buttonElement?.childNodes?.length ?? 0) > 2) {
940
+ localButtonRef.current.appendChild(buttonElement?.childNodes[0]);
1397
941
  setShowCustomButtonContent(true);
1398
942
  }
1399
- }, [buttonElement === null || buttonElement === void 0 ? void 0 : buttonElement.childNodes]);
943
+ }, [buttonElement?.childNodes]);
1400
944
  return /*#__PURE__*/React__default["default"].createElement("button", {
1401
945
  ref: localButtonRef,
1402
946
  type: "button",
1403
- className: "react-input-emoji--button".concat(showPicker ? " react-input-emoji--button__show" : ""),
947
+ className: `react-input-emoji--button${showPicker ? " react-input-emoji--button__show" : ""}`,
1404
948
  onClick: toggleShowPicker
1405
949
  }, !showCustomButtonContent && /*#__PURE__*/React__default["default"].createElement("svg", {
1406
950
  xmlns: "http://www.w3.org/2000/svg",
@@ -1738,6 +1282,9 @@ var $f72b75cf796873c7$export$2e2bcd8739ae039 = {
1738
1282
  };
1739
1283
  const $c84d045dcc34faf5$var$CACHE = new Map();
1740
1284
  const $c84d045dcc34faf5$var$VERSIONS = [{
1285
+ v: 15,
1286
+ emoji: "\uD83E\uDEE8"
1287
+ }, {
1741
1288
  v: 14,
1742
1289
  emoji: "\uD83E\uDEE0"
1743
1290
  }, {
@@ -1917,8 +1464,8 @@ var $b247ea80b67298d5$export$2e2bcd8739ae039 = {
1917
1464
  value: 24
1918
1465
  },
1919
1466
  emojiVersion: {
1920
- value: 14,
1921
- choices: [1, 2, 3, 4, 5, 11, 12, 12.1, 13, 13.1, 14]
1467
+ value: 15,
1468
+ choices: [1, 2, 3, 4, 5, 11, 12, 12.1, 13, 13.1, 14, 15]
1922
1469
  },
1923
1470
  exceptEmojis: {
1924
1471
  value: []
@@ -1929,7 +1476,7 @@ var $b247ea80b67298d5$export$2e2bcd8739ae039 = {
1929
1476
  },
1930
1477
  locale: {
1931
1478
  value: "en",
1932
- choices: ["en", "ar", "be", "cs", "de", "es", "fa", "fi", "fr", "hi", "it", "ja", "kr", "nl", "pl", "pt", "ru", "sa", "tr", "uk", "vi", "zh"]
1479
+ choices: ["en", "ar", "be", "cs", "de", "es", "fa", "fi", "fr", "hi", "it", "ja", "ko", "nl", "pl", "pt", "ru", "sa", "tr", "uk", "vi", "zh"]
1933
1480
  },
1934
1481
  maxFrequentRows: {
1935
1482
  value: 4
@@ -2448,8 +1995,8 @@ function $254755d3f438722f$export$2e2bcd8739ae039(props) {
2448
1995
  emoji || (emoji = ($c4d155af13ad4d4b$export$2e2bcd8739ae039).get(id || props.native));
2449
1996
  if (!emoji) return props.fallback;
2450
1997
  const emojiSkin = emoji.skins[skin - 1] || emoji.skins[0];
2451
- const imageSrc = emojiSkin.src || (props.set != "native" && !props.spritesheet ? typeof props.getImageURL === "function" ? props.getImageURL(props.set, emojiSkin.unified) : `https://cdn.jsdelivr.net/npm/emoji-datasource-${props.set}@14.0.0/img/${props.set}/64/${emojiSkin.unified}.png` : undefined);
2452
- const spritesheetSrc = typeof props.getSpritesheetURL === "function" ? props.getSpritesheetURL(props.set) : `https://cdn.jsdelivr.net/npm/emoji-datasource-${props.set}@14.0.0/img/${props.set}/sheets-256/64.png`;
1998
+ const imageSrc = emojiSkin.src || (props.set != "native" && !props.spritesheet ? typeof props.getImageURL === "function" ? props.getImageURL(props.set, emojiSkin.unified) : `https://cdn.jsdelivr.net/npm/emoji-datasource-${props.set}@15.0.1/img/${props.set}/64/${emojiSkin.unified}.png` : undefined);
1999
+ const spritesheetSrc = typeof props.getSpritesheetURL === "function" ? props.getSpritesheetURL(props.set) : `https://cdn.jsdelivr.net/npm/emoji-datasource-${props.set}@15.0.1/img/${props.set}/sheets-256/64.png`;
2453
2000
  return /*#__PURE__*/($bd9dd35321b03dd4$export$34b9dba7ce09269b)("span", {
2454
2001
  class: "emoji-mart-emoji",
2455
2002
  "data-emoji-set": props.set,
@@ -2972,6 +2519,7 @@ class $89bd6bb200cc8fef$export$2e2bcd8739ae039 extends ($fb96b826c0c5f37a$export
2972
2519
  }
2973
2520
  unregister() {
2974
2521
  document.removeEventListener("click", this.handleClickOutside);
2522
+ this.darkMedia?.removeEventListener("change", this.darkMediaCallback);
2975
2523
  this.unobserve();
2976
2524
  }
2977
2525
  observe() {
@@ -3029,12 +2577,7 @@ class $89bd6bb200cc8fef$export$2e2bcd8739ae039 extends ($fb96b826c0c5f37a$export
3029
2577
  if (!this.darkMedia) {
3030
2578
  this.darkMedia = matchMedia("(prefers-color-scheme: dark)");
3031
2579
  if (this.darkMedia.media.match(/^not/)) return "light";
3032
- this.darkMedia.addListener(() => {
3033
- if (this.props.theme != "auto") return;
3034
- this.setState({
3035
- theme: this.darkMedia.matches ? "dark" : "light"
3036
- });
3037
- });
2580
+ this.darkMedia.addEventListener("change", this.darkMediaCallback);
3038
2581
  }
3039
2582
  return this.darkMedia.matches ? "dark" : "light";
3040
2583
  }
@@ -3639,6 +3182,12 @@ class $89bd6bb200cc8fef$export$2e2bcd8739ae039 extends ($fb96b826c0c5f37a$export
3639
3182
  }
3640
3183
  constructor(props) {
3641
3184
  super();
3185
+ ($c770c458706daa72$export$2e2bcd8739ae039)(this, "darkMediaCallback", () => {
3186
+ if (this.props.theme != "auto") return;
3187
+ this.setState({
3188
+ theme: this.darkMedia.matches ? "dark" : "light"
3189
+ });
3190
+ });
3642
3191
  ($c770c458706daa72$export$2e2bcd8739ae039)(this, "handleClickOutside", e => {
3643
3192
  const {
3644
3193
  element: element
@@ -3847,8 +3396,9 @@ function $e5534fc185f7111e$export$2e2bcd8739ae039(props) {
3847
3396
  });
3848
3397
  }
3849
3398
 
3850
- var EMOJI_MART_DATA_URL = "https://cdn.jsdelivr.net/npm/@emoji-mart/data";
3851
- var cacheI18n = {};
3399
+ // vendors
3400
+ const EMOJI_MART_DATA_URL = "https://cdn.jsdelivr.net/npm/@emoji-mart/data";
3401
+ const cacheI18n = {};
3852
3402
 
3853
3403
  /**
3854
3404
  * @typedef {object} Props
@@ -3864,55 +3414,38 @@ var cacheI18n = {};
3864
3414
  * @param {Props} props
3865
3415
  */
3866
3416
  function EmojiPicker(props) {
3867
- var theme = props.theme,
3868
- onSelectEmoji = props.onSelectEmoji,
3869
- disableRecent = props.disableRecent,
3870
- customEmojis = props.customEmojis,
3871
- language = props.language;
3417
+ const {
3418
+ theme,
3419
+ onSelectEmoji,
3420
+ disableRecent,
3421
+ customEmojis,
3422
+ language
3423
+ } = props;
3872
3424
 
3873
3425
  /** @type {string[]} */
3874
- var categories = React.useMemo(function () {
3426
+ const categories = React.useMemo(() => {
3875
3427
  /** @type {string[]} */
3876
- var categoryies = [];
3428
+ let categoryies = [];
3877
3429
  if (!disableRecent) {
3878
3430
  categoryies.push("frequent");
3879
3431
  }
3880
- categoryies = [].concat(_toConsumableArray(categoryies), ["people", "nature", "foods", "activity", "places", "objects", "symbols", "flags"]);
3432
+ categoryies = [...categoryies, "people", "nature", "foods", "activity", "places", "objects", "symbols", "flags"];
3881
3433
  return categoryies;
3882
3434
  }, [disableRecent]);
3883
- var _useState = React.useState(undefined),
3884
- _useState2 = _slicedToArray(_useState, 2),
3885
- i18n = _useState2[0],
3886
- setI18n = _useState2[1];
3887
- React.useEffect(function () {
3888
- var _ref2;
3435
+ const [i18n, setI18n] = React.useState(undefined);
3436
+ React.useEffect(() => {
3889
3437
  if (!language) {
3890
- var _ref;
3891
3438
  if (cacheI18n.en) {
3892
3439
  setI18n(cacheI18n.en);
3893
3440
  return;
3894
3441
  }
3895
3442
 
3896
3443
  // @ts-ignore
3897
- fetch("".concat(EMOJI_MART_DATA_URL, "/i18n/en.json")).then(function (_x) {
3898
- return (_ref = _ref || _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(data) {
3899
- var translations;
3900
- return _regeneratorRuntime().wrap(function _callee$(_context) {
3901
- while (1) switch (_context.prev = _context.next) {
3902
- case 0:
3903
- _context.next = 2;
3904
- return data.json();
3905
- case 2:
3906
- translations = _context.sent;
3907
- setI18n(translations);
3908
- cacheI18n.en = translations;
3909
- case 5:
3910
- case "end":
3911
- return _context.stop();
3912
- }
3913
- }, _callee);
3914
- }))).apply(this, arguments);
3915
- })["catch"](function (error) {
3444
+ fetch(`${EMOJI_MART_DATA_URL}/i18n/en.json`).then(async data => {
3445
+ const translations = await data.json();
3446
+ setI18n(translations);
3447
+ cacheI18n.en = translations;
3448
+ }).catch(error => {
3916
3449
  console.error("Failed to load translations:", error);
3917
3450
  });
3918
3451
  return;
@@ -3923,25 +3456,11 @@ function EmojiPicker(props) {
3923
3456
  }
3924
3457
 
3925
3458
  // @ts-ignore
3926
- fetch("".concat(EMOJI_MART_DATA_URL, "/i18n/").concat(language, ".json")).then(function (_x2) {
3927
- return (_ref2 = _ref2 || _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(data) {
3928
- var translations;
3929
- return _regeneratorRuntime().wrap(function _callee2$(_context2) {
3930
- while (1) switch (_context2.prev = _context2.next) {
3931
- case 0:
3932
- _context2.next = 2;
3933
- return data.json();
3934
- case 2:
3935
- translations = _context2.sent;
3936
- setI18n(translations);
3937
- cacheI18n[language] = translations;
3938
- case 5:
3939
- case "end":
3940
- return _context2.stop();
3941
- }
3942
- }, _callee2);
3943
- }))).apply(this, arguments);
3944
- })["catch"](function (error) {
3459
+ fetch(`${EMOJI_MART_DATA_URL}/i18n/${language}.json`).then(async data => {
3460
+ const translations = await data.json();
3461
+ setI18n(translations);
3462
+ cacheI18n[language] = translations;
3463
+ }).catch(error => {
3945
3464
  console.error("Failed to load translations:", error);
3946
3465
  });
3947
3466
  }, [language]);
@@ -3977,21 +3496,20 @@ var EmojiPicker$1 = /*#__PURE__*/React.memo(EmojiPicker);
3977
3496
  * @param {Props} props
3978
3497
  * @return {JSX.Element}
3979
3498
  */
3980
- function EmojiPickerContainer(_ref) {
3981
- var showPicker = _ref.showPicker,
3982
- theme = _ref.theme,
3983
- handleSelectEmoji = _ref.handleSelectEmoji,
3984
- disableRecent = _ref.disableRecent,
3985
- customEmojis = _ref.customEmojis,
3986
- position = _ref.position,
3987
- language = _ref.language;
3499
+ function EmojiPickerContainer({
3500
+ showPicker,
3501
+ theme,
3502
+ handleSelectEmoji,
3503
+ disableRecent,
3504
+ customEmojis,
3505
+ position,
3506
+ language
3507
+ }) {
3988
3508
  return /*#__PURE__*/React__default["default"].createElement("div", {
3989
3509
  className: "react-emoji-picker--container"
3990
3510
  }, showPicker && /*#__PURE__*/React__default["default"].createElement("div", {
3991
3511
  className: "react-emoji-picker--wrapper",
3992
- onClick: function onClick(evt) {
3993
- return evt.stopPropagation();
3994
- },
3512
+ onClick: evt => evt.stopPropagation(),
3995
3513
  style: position === 'below' ? {
3996
3514
  top: '40px'
3997
3515
  } : {}
@@ -4006,7 +3524,8 @@ function EmojiPickerContainer(_ref) {
4006
3524
  }))));
4007
3525
  }
4008
3526
 
4009
- var EMOJI_PICKER_CONTAINER_HEIGHT = 435;
3527
+ // @ts-check
3528
+ const EMOJI_PICKER_CONTAINER_HEIGHT = 435;
4010
3529
 
4011
3530
  /**
4012
3531
  * @typedef {import('../types/types').SanitizeFn} SanitizeFn
@@ -4032,38 +3551,36 @@ var EMOJI_PICKER_CONTAINER_HEIGHT = 435;
4032
3551
 
4033
3552
  // eslint-disable-next-line valid-jsdoc
4034
3553
  /** @type {React.FC<Props>} */
4035
- var EmojiPickerWrapper = function EmojiPickerWrapper(props) {
4036
- var theme = props.theme,
4037
- keepOpened = props.keepOpened,
4038
- disableRecent = props.disableRecent,
4039
- customEmojis = props.customEmojis,
4040
- addSanitizeFn = props.addSanitizeFn,
4041
- addPolluteFn = props.addPolluteFn,
4042
- appendContent = props.appendContent,
4043
- buttonElement = props.buttonElement,
4044
- buttonRef = props.buttonRef,
4045
- language = props.language;
4046
- var _useState = React.useState(false),
4047
- _useState2 = _slicedToArray(_useState, 2),
4048
- showPicker = _useState2[0],
4049
- setShowPicker = _useState2[1];
3554
+ const EmojiPickerWrapper = props => {
3555
+ const {
3556
+ theme,
3557
+ keepOpened,
3558
+ disableRecent,
3559
+ customEmojis,
3560
+ addSanitizeFn,
3561
+ addPolluteFn,
3562
+ appendContent,
3563
+ buttonElement,
3564
+ buttonRef,
3565
+ language
3566
+ } = props;
3567
+ const [showPicker, setShowPicker] = React.useState(false);
4050
3568
  /** @type {[HTMLDivElement | undefined, React.Dispatch<React.SetStateAction<HTMLDivElement | undefined>>]} */
4051
- var _useState3 = React.useState(),
4052
- _useState4 = _slicedToArray(_useState3, 2),
4053
- customButton = _useState4[0],
4054
- setCustomButton = _useState4[1];
3569
+ const [customButton, setCustomButton] = React.useState();
4055
3570
  /** @type {['above' | 'below' | undefined, React.Dispatch<React.SetStateAction<'above' | 'below' | undefined>>]} */
4056
- var _useState5 = React.useState(),
4057
- _useState6 = _slicedToArray(_useState5, 2),
4058
- emojiPickerPosition = _useState6[0],
4059
- setEmojiPickerPosition = _useState6[1];
4060
- React.useEffect(function () {
3571
+ const [emojiPickerPosition, setEmojiPickerPosition] = React.useState();
3572
+ React.useEffect(() => {
3573
+ if (showPicker) {
3574
+ cacheCurrentRange();
3575
+ }
3576
+ }, [showPicker]);
3577
+ React.useEffect(() => {
4061
3578
  addSanitizeFn(replaceAllTextEmojiToString);
4062
3579
  }, [addSanitizeFn]);
4063
- React.useEffect(function () {
3580
+ React.useEffect(() => {
4064
3581
  addPolluteFn(replaceAllTextEmojis);
4065
3582
  }, [addPolluteFn]);
4066
- React.useEffect(function () {
3583
+ React.useEffect(() => {
4067
3584
  /**
4068
3585
  *
4069
3586
  * @param {MouseEvent} event
@@ -4071,14 +3588,14 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) {
4071
3588
  function checkClickOutside(event) {
4072
3589
  /** @type {HTMLElement} */
4073
3590
  // @ts-ignore
4074
- var element = event.target;
3591
+ const element = event.target;
4075
3592
  if (element.classList.contains("react-input-emoji--button") || element.classList.contains("react-input-emoji--button--icon")) {
4076
3593
  return;
4077
3594
  }
4078
3595
  setShowPicker(false);
4079
3596
  }
4080
3597
  document.addEventListener("click", checkClickOutside);
4081
- return function () {
3598
+ return () => {
4082
3599
  document.removeEventListener("click", checkClickOutside);
4083
3600
  };
4084
3601
  }, []);
@@ -4091,9 +3608,7 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) {
4091
3608
  event.stopPropagation();
4092
3609
  event.preventDefault();
4093
3610
  setEmojiPickerPosition(calcTopPosition(event));
4094
- setShowPicker(function (currentShowPicker) {
4095
- return !currentShowPicker;
4096
- });
3611
+ setShowPicker(currentShowPicker => !currentShowPicker);
4097
3612
  }
4098
3613
 
4099
3614
  /**
@@ -4102,9 +3617,9 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) {
4102
3617
  * @return {'above' | 'below'}
4103
3618
  */
4104
3619
  function calcTopPosition(event) {
4105
- var btn = event.currentTarget;
4106
- var btnRect = btn.getBoundingClientRect();
4107
- var popoverHeight = EMOJI_PICKER_CONTAINER_HEIGHT;
3620
+ const btn = event.currentTarget;
3621
+ const btnRect = btn.getBoundingClientRect();
3622
+ const popoverHeight = EMOJI_PICKER_CONTAINER_HEIGHT;
4108
3623
 
4109
3624
  // Decide to display above or below based on available space
4110
3625
  if (btnRect.top >= popoverHeight) {
@@ -4124,17 +3639,14 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) {
4124
3639
  function handleSelectEmoji(emoji) {
4125
3640
  appendContent(getImageEmoji(emoji));
4126
3641
  if (!keepOpened) {
4127
- setShowPicker(function (currentShowPicker) {
4128
- return !currentShowPicker;
4129
- });
3642
+ setShowPicker(currentShowPicker => !currentShowPicker);
4130
3643
  }
4131
3644
  }
4132
- React.useEffect(function () {
4133
- var _buttonRef$current;
4134
- if (buttonRef !== null && buttonRef !== void 0 && (_buttonRef$current = buttonRef.current) !== null && _buttonRef$current !== void 0 && _buttonRef$current.style) {
3645
+ React.useEffect(() => {
3646
+ if (buttonRef?.current?.style) {
4135
3647
  buttonRef.current.style.position = "relative";
4136
3648
  setCustomButton(buttonRef.current);
4137
- } else if (buttonElement !== null && buttonElement !== void 0 && buttonElement.style) {
3649
+ } else if (buttonElement?.style) {
4138
3650
  buttonElement.style.position = "relative";
4139
3651
  setCustomButton(buttonElement);
4140
3652
  }
@@ -4173,16 +3685,16 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) {
4173
3685
  * @return {string | null}
4174
3686
  */
4175
3687
  function getTextFromAtToCaret() {
4176
- var range = getRangeFromAtToCaret();
3688
+ const range = getRangeFromAtToCaret();
4177
3689
  if (!range) return null;
4178
- var text = range.text.substring(range.begin, range.end);
3690
+ const text = range.text.substring(range.begin, range.end);
4179
3691
  return text || null;
4180
3692
  }
4181
3693
 
4182
3694
  // eslint-disable-next-line valid-jsdoc
4183
3695
  /** */
4184
3696
  function deleteTextFromAtToCaret() {
4185
- var range = getRangeFromAtToCaret();
3697
+ const range = getRangeFromAtToCaret();
4186
3698
  if (!range) return;
4187
3699
 
4188
3700
  // @ts-ignore
@@ -4194,22 +3706,24 @@ function deleteTextFromAtToCaret() {
4194
3706
  * @return {{begin: number, end: number, text: string, element: Node} | null}
4195
3707
  */
4196
3708
  function getRangeFromAtToCaret() {
4197
- var elementWithFocus = getElementWithFocus();
3709
+ const elementWithFocus = getElementWithFocus();
4198
3710
  if (!elementWithFocus) {
4199
3711
  return null;
4200
3712
  }
4201
- var element = elementWithFocus.element,
4202
- caretOffset = elementWithFocus.caretOffset;
4203
- var text = element.textContent;
4204
- var lastAt = text.lastIndexOf("@");
3713
+ const {
3714
+ element,
3715
+ caretOffset
3716
+ } = elementWithFocus;
3717
+ const text = element.textContent;
3718
+ const lastAt = text.lastIndexOf("@");
4205
3719
  if (lastAt === -1 || lastAt >= caretOffset || lastAt !== 0 && text[lastAt - 1] !== " ") {
4206
3720
  return null;
4207
3721
  }
4208
3722
  return {
4209
3723
  begin: lastAt,
4210
3724
  end: caretOffset,
4211
- text: text,
4212
- element: element
3725
+ text,
3726
+ element
4213
3727
  };
4214
3728
  }
4215
3729
 
@@ -4218,14 +3732,14 @@ function getRangeFromAtToCaret() {
4218
3732
  * @return {{element: Node, caretOffset: number}}
4219
3733
  */
4220
3734
  function getElementWithFocus() {
4221
- var element = getSelectionStart();
3735
+ const element = getSelectionStart();
4222
3736
  if (element === null) {
4223
3737
  return null;
4224
3738
  }
4225
- var caretOffset = 0;
3739
+ let caretOffset = 0;
4226
3740
  if (typeof window.getSelection != "undefined") {
4227
- var range = window.getSelection().getRangeAt(0);
4228
- var preCaretRange = range.cloneRange();
3741
+ const range = window.getSelection().getRangeAt(0);
3742
+ const preCaretRange = range.cloneRange();
4229
3743
  preCaretRange.selectNodeContents(element);
4230
3744
  preCaretRange.setEnd(range.endContainer, range.endOffset);
4231
3745
  caretOffset = preCaretRange.toString().length;
@@ -4235,16 +3749,16 @@ function getElementWithFocus() {
4235
3749
  // @ts-ignore
4236
3750
  document.selection.type != "Control") {
4237
3751
  // @ts-ignore
4238
- var textRange = document.selection.createRange();
3752
+ const textRange = document.selection.createRange();
4239
3753
  // @ts-ignore
4240
- var preCaretTextRange = document.body.createTextRange();
3754
+ const preCaretTextRange = document.body.createTextRange();
4241
3755
  preCaretTextRange.moveToElementText(element);
4242
3756
  preCaretTextRange.setEndPoint("EndToEnd", textRange);
4243
3757
  caretOffset = preCaretTextRange.text.length;
4244
3758
  }
4245
3759
  return {
4246
- element: element,
4247
- caretOffset: caretOffset
3760
+ element,
3761
+ caretOffset
4248
3762
  };
4249
3763
  }
4250
3764
 
@@ -4253,10 +3767,12 @@ function getElementWithFocus() {
4253
3767
  * @return {Node | null}
4254
3768
  */
4255
3769
  function getSelectionStart() {
4256
- var node = document.getSelection().anchorNode;
4257
- return (node === null || node === void 0 ? void 0 : node.nodeType) == 3 ? node : null;
3770
+ const node = document.getSelection().anchorNode;
3771
+ return node?.nodeType == 3 ? node : null;
4258
3772
  }
4259
3773
 
3774
+ // @ts-check
3775
+
4260
3776
  /**
4261
3777
  * @typedef {import('../types/types').MentionUser} MentionUser
4262
3778
  */
@@ -4268,98 +3784,57 @@ function getSelectionStart() {
4268
3784
  * @returns {{mentionSearchText: string | null, mentionUsers: MentionUser[], onKeyUp: (event: React.KeyboardEvent) => void, onFocus: () => void, onSelectUser: () => void, loading: boolean}}
4269
3785
  */
4270
3786
  function useMention(searchMention) {
4271
- var _ref2;
4272
- var _useState = React.useState(false),
4273
- _useState2 = _slicedToArray(_useState, 2),
4274
- loading = _useState2[0],
4275
- setLoading = _useState2[1];
3787
+ const [loading, setLoading] = React.useState(false);
4276
3788
 
4277
3789
  /** @type {[MentionUser[], React.Dispatch<React.SetStateAction<MentionUser[]>>]} */
4278
- var _useState3 = React.useState([]),
4279
- _useState4 = _slicedToArray(_useState3, 2),
4280
- mentionUsers = _useState4[0],
4281
- setMentionUsers = _useState4[1];
3790
+ const [mentionUsers, setMentionUsers] = React.useState([]);
4282
3791
 
4283
3792
  /** @type {[string | null, React.Dispatch<React.SetStateAction<string | null>>]} */
4284
- var _useState5 = React.useState(null),
4285
- _useState6 = _slicedToArray(_useState5, 2),
4286
- mentionSearchText = _useState6[0],
4287
- setMentionSearchText = _useState6[1];
4288
- var onSelectUser = React.useCallback(function () {
3793
+ const [mentionSearchText, setMentionSearchText] = React.useState(null);
3794
+ const onSelectUser = React.useCallback(() => {
4289
3795
  deleteTextFromAtToCaret();
4290
3796
  setMentionUsers([]);
4291
3797
  }, []);
4292
3798
 
4293
3799
  /** */
4294
- var checkMentionText = React.useCallback( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
4295
- var metionText, users;
4296
- return _regeneratorRuntime().wrap(function _callee$(_context) {
4297
- while (1) switch (_context.prev = _context.next) {
4298
- case 0:
4299
- metionText = getTextFromAtToCaret();
4300
- setMentionSearchText(metionText);
4301
- if (!(metionText === null)) {
4302
- _context.next = 6;
4303
- break;
4304
- }
4305
- setMentionUsers([]);
4306
- _context.next = 12;
4307
- break;
4308
- case 6:
4309
- setLoading(true);
4310
- _context.next = 9;
4311
- return searchMention(metionText);
4312
- case 9:
4313
- users = _context.sent;
4314
- setLoading(false);
4315
- setMentionUsers(users);
4316
- case 12:
4317
- case "end":
4318
- return _context.stop();
4319
- }
4320
- }, _callee);
4321
- })), [searchMention]);
3800
+ const checkMentionText = React.useCallback(async () => {
3801
+ const metionText = getTextFromAtToCaret();
3802
+ setMentionSearchText(metionText);
3803
+ if (metionText === null) {
3804
+ setMentionUsers([]);
3805
+ } else {
3806
+ setLoading(true);
3807
+ const users = await searchMention(metionText);
3808
+ setLoading(false);
3809
+ setMentionUsers(users);
3810
+ }
3811
+ }, [searchMention]);
4322
3812
 
4323
3813
  /** @type {(event: React.KeyboardEvent) => void} */
4324
- var onKeyUp = React.useCallback(function (_x) {
4325
- return (_ref2 = _ref2 || _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(event) {
4326
- var _getElementWithFocus;
4327
- var elementWithFocus;
4328
- return _regeneratorRuntime().wrap(function _callee2$(_context2) {
4329
- while (1) switch (_context2.prev = _context2.next) {
4330
- case 0:
4331
- if (!(typeof searchMention !== "function")) {
4332
- _context2.next = 2;
4333
- break;
4334
- }
4335
- return _context2.abrupt("return");
4336
- case 2:
4337
- if (event.key === "Backspace" && (_getElementWithFocus = getElementWithFocus()) !== null && _getElementWithFocus !== void 0 && _getElementWithFocus.element.parentElement.hasAttribute("data-mention-id")) {
4338
- elementWithFocus = getElementWithFocus();
4339
- elementWithFocus.element.parentElement.remove();
4340
- } else if (!["ArrowUp", "ArrowDown", "Esc", "Escape"].includes(event.key)) {
4341
- checkMentionText();
4342
- }
4343
- case 3:
4344
- case "end":
4345
- return _context2.stop();
4346
- }
4347
- }, _callee2);
4348
- }))).apply(this, arguments);
3814
+ const onKeyUp = React.useCallback(async event => {
3815
+ if (typeof searchMention !== "function") return;
3816
+ if (event.key === "Backspace" && getElementWithFocus()?.element.parentElement.hasAttribute("data-mention-id")) {
3817
+ const elementWithFocus = getElementWithFocus();
3818
+ elementWithFocus.element.parentElement.remove();
3819
+ } else if (!["ArrowUp", "ArrowDown", "Esc", "Escape"].includes(event.key)) {
3820
+ checkMentionText();
3821
+ }
4349
3822
  }, [checkMentionText, searchMention]);
4350
- var onFocus = React.useCallback(function () {
3823
+ const onFocus = React.useCallback(() => {
4351
3824
  checkMentionText();
4352
3825
  }, [checkMentionText]);
4353
3826
  return {
4354
- mentionSearchText: mentionSearchText,
4355
- mentionUsers: mentionUsers,
4356
- onKeyUp: onKeyUp,
4357
- onFocus: onFocus,
4358
- onSelectUser: onSelectUser,
4359
- loading: loading
3827
+ mentionSearchText,
3828
+ mentionUsers,
3829
+ onKeyUp,
3830
+ onFocus,
3831
+ onSelectUser,
3832
+ loading
4360
3833
  };
4361
3834
  }
4362
3835
 
3836
+ // @ts-check
3837
+
4363
3838
  /**
4364
3839
  * @typedef {import('../types/types').MentionUser} MentionUser
4365
3840
  */
@@ -4382,36 +3857,32 @@ function useMention(searchMention) {
4382
3857
 
4383
3858
  // eslint-disable-next-line valid-jsdoc
4384
3859
  /** @type {React.ForwardRefRenderFunction<Ref, Props>} */
4385
- var MentionUserList = function MentionUserList(_ref, ref) {
4386
- var users = _ref.users,
4387
- mentionSearchText = _ref.mentionSearchText,
4388
- onSelect = _ref.onSelect,
4389
- addEventListener = _ref.addEventListener;
4390
- var _useState = React.useState(0),
4391
- _useState2 = _slicedToArray(_useState, 2),
4392
- selectedUser = _useState2[0],
4393
- setSelectedUser = _useState2[1];
4394
- React.useImperativeHandle(ref, function () {
4395
- return {
4396
- prevUser: function prevUser() {
4397
- setSelectedUser(function (currentSelectedUser) {
4398
- if (currentSelectedUser === 0) {
4399
- return 0;
4400
- }
4401
- return currentSelectedUser - 1;
4402
- });
4403
- },
4404
- nextUser: function nextUser() {
4405
- setSelectedUser(function (currentSelectedUser) {
4406
- if (currentSelectedUser === users.length - 1) {
4407
- return users.length - 1;
4408
- }
4409
- return currentSelectedUser + 1;
4410
- });
4411
- }
4412
- };
4413
- });
4414
- React.useEffect(function () {
3860
+ const MentionUserList = ({
3861
+ users,
3862
+ mentionSearchText,
3863
+ onSelect,
3864
+ addEventListener
3865
+ }, ref) => {
3866
+ const [selectedUser, setSelectedUser] = React.useState(0);
3867
+ React.useImperativeHandle(ref, () => ({
3868
+ prevUser: () => {
3869
+ setSelectedUser(currentSelectedUser => {
3870
+ if (currentSelectedUser === 0) {
3871
+ return 0;
3872
+ }
3873
+ return currentSelectedUser - 1;
3874
+ });
3875
+ },
3876
+ nextUser: () => {
3877
+ setSelectedUser(currentSelectedUser => {
3878
+ if (currentSelectedUser === users.length - 1) {
3879
+ return users.length - 1;
3880
+ }
3881
+ return currentSelectedUser + 1;
3882
+ });
3883
+ }
3884
+ }));
3885
+ React.useEffect(() => {
4415
3886
  setSelectedUser(0);
4416
3887
  }, [users]);
4417
3888
 
@@ -4422,20 +3893,20 @@ var MentionUserList = function MentionUserList(_ref, ref) {
4422
3893
  * @return {string}
4423
3894
  */
4424
3895
  function getMentionSelectedNameEl(selectedText, rest) {
4425
- return "<span class=\"react-input-emoji--mention--item--name__selected\" data-testid=\"metion-selected-word\">".concat(selectedText, "</span>").concat(rest);
3896
+ return `<span class="react-input-emoji--mention--item--name__selected" data-testid="metion-selected-word">${selectedText}</span>${rest}`;
4426
3897
  }
4427
3898
 
4428
3899
  /** @type {(MentionUser & {nameHtml: string})[]} */
4429
- var usersFiltered = React.useMemo(function () {
4430
- var searchText = mentionSearchText ? mentionSearchText.substring(1).toLocaleLowerCase() : "";
4431
- return users.map(function (user) {
4432
- var nameHtml = user.name;
3900
+ const usersFiltered = React.useMemo(() => {
3901
+ const searchText = mentionSearchText ? mentionSearchText.substring(1).toLocaleLowerCase() : "";
3902
+ return users.map(user => {
3903
+ let nameHtml = user.name;
4433
3904
  if (mentionSearchText && mentionSearchText.length > 1) {
4434
3905
  if (user.name.toLowerCase().startsWith(searchText)) {
4435
3906
  nameHtml = getMentionSelectedNameEl(user.name.substring(0, searchText.length), user.name.substring(searchText.length));
4436
3907
  } else {
4437
- var names = user.name.split(" ");
4438
- nameHtml = names.map(function (name) {
3908
+ const names = user.name.split(" ");
3909
+ nameHtml = names.map(name => {
4439
3910
  if (name.toLocaleLowerCase().startsWith(searchText)) {
4440
3911
  return getMentionSelectedNameEl(name.substring(0, searchText.length), name.substring(searchText.length));
4441
3912
  }
@@ -4443,9 +3914,10 @@ var MentionUserList = function MentionUserList(_ref, ref) {
4443
3914
  }).join(" ");
4444
3915
  }
4445
3916
  }
4446
- return _objectSpread2(_objectSpread2({}, user), {}, {
4447
- nameHtml: nameHtml
4448
- });
3917
+ return {
3918
+ ...user,
3919
+ nameHtml
3920
+ };
4449
3921
  });
4450
3922
  }, [mentionSearchText, users]);
4451
3923
 
@@ -4456,47 +3928,45 @@ var MentionUserList = function MentionUserList(_ref, ref) {
4456
3928
  * @returns {(event: React.MouseEvent) => void} event
4457
3929
  */
4458
3930
  function handleClick(user) {
4459
- return function (event) {
3931
+ return event => {
4460
3932
  event.stopPropagation();
4461
3933
  event.preventDefault();
4462
3934
  onSelect(user);
4463
3935
  };
4464
3936
  }
4465
- React.useEffect(function () {
4466
- var unsubscribe = addEventListener("enter", function (event) {
3937
+ React.useEffect(() => {
3938
+ const unsubscribe = addEventListener("enter", event => {
4467
3939
  event.stopPropagation();
4468
3940
  event.preventDefault();
4469
3941
  onSelect(usersFiltered[selectedUser]);
4470
3942
  });
4471
- return function () {
3943
+ return () => {
4472
3944
  unsubscribe();
4473
3945
  };
4474
3946
  }, [addEventListener, onSelect, selectedUser, usersFiltered]);
4475
3947
  return /*#__PURE__*/React__default["default"].createElement("ul", {
4476
3948
  className: "react-input-emoji--mention--list",
4477
3949
  "data-testid": "mention-user-list"
4478
- }, usersFiltered.map(function (user, index) {
4479
- return /*#__PURE__*/React__default["default"].createElement("li", {
4480
- key: user.id
4481
- }, /*#__PURE__*/React__default["default"].createElement("button", {
4482
- type: "button",
4483
- onClick: handleClick(user),
4484
- className: "react-input-emoji--mention--item".concat(selectedUser === index ? " react-input-emoji--mention--item__selected" : ""),
4485
- onMouseOver: function onMouseOver() {
4486
- return setSelectedUser(index);
4487
- }
4488
- }, /*#__PURE__*/React__default["default"].createElement("img", {
4489
- className: "react-input-emoji--mention--item--img",
4490
- src: user.image
4491
- }), /*#__PURE__*/React__default["default"].createElement("div", {
4492
- className: "react-input-emoji--mention--item--name",
4493
- dangerouslySetInnerHTML: {
4494
- __html: user.nameHtml
4495
- }
4496
- })));
4497
- }));
3950
+ }, usersFiltered.map((user, index) => /*#__PURE__*/React__default["default"].createElement("li", {
3951
+ key: user.id
3952
+ }, /*#__PURE__*/React__default["default"].createElement("button", {
3953
+ type: "button",
3954
+ onClick: handleClick(user),
3955
+ className: `react-input-emoji--mention--item${selectedUser === index ? " react-input-emoji--mention--item__selected" : ""}`,
3956
+ onMouseOver: () => setSelectedUser(index)
3957
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
3958
+ className: "react-input-emoji--mention--item--img",
3959
+ src: user.image
3960
+ }), /*#__PURE__*/React__default["default"].createElement("div", {
3961
+ className: "react-input-emoji--mention--item--name",
3962
+ dangerouslySetInnerHTML: {
3963
+ __html: user.nameHtml
3964
+ }
3965
+ })))));
4498
3966
  };
4499
- var MentionUserListWithRef = /*#__PURE__*/React.forwardRef(MentionUserList);
3967
+ const MentionUserListWithRef = /*#__PURE__*/React.forwardRef(MentionUserList);
3968
+
3969
+ // @ts-check
4500
3970
 
4501
3971
  /**
4502
3972
  * @typedef {import('../types/types').MentionUser} MetionUser
@@ -4520,55 +3990,54 @@ var MentionUserListWithRef = /*#__PURE__*/React.forwardRef(MentionUserList);
4520
3990
 
4521
3991
  // eslint-disable-next-line valid-jsdoc
4522
3992
  /** @type {React.FC<Props>} */
4523
- var MentionWrapper = function MentionWrapper(_ref) {
4524
- var searchMention = _ref.searchMention,
4525
- addEventListener = _ref.addEventListener,
4526
- appendContent = _ref.appendContent,
4527
- addSanitizeFn = _ref.addSanitizeFn;
3993
+ const MentionWrapper = ({
3994
+ searchMention,
3995
+ addEventListener,
3996
+ appendContent,
3997
+ addSanitizeFn
3998
+ }) => {
4528
3999
  /** @type {React.MutableRefObject<import('./mention-user-list').Ref | null>} */
4529
- var metionUserListRef = React.useRef(null);
4530
- var _useState = React.useState(false),
4531
- _useState2 = _slicedToArray(_useState, 2),
4532
- showUserList = _useState2[0],
4533
- setShowUserList = _useState2[1];
4534
- var _useMention = useMention(searchMention),
4535
- mentionSearchText = _useMention.mentionSearchText,
4536
- mentionUsers = _useMention.mentionUsers,
4537
- loading = _useMention.loading,
4538
- onKeyUp = _useMention.onKeyUp,
4539
- onFocus = _useMention.onFocus,
4540
- onSelectUser = _useMention.onSelectUser;
4541
- React.useEffect(function () {
4542
- addSanitizeFn(function (html) {
4543
- var container = document.createElement("div");
4000
+ const metionUserListRef = React.useRef(null);
4001
+ const [showUserList, setShowUserList] = React.useState(false);
4002
+ const {
4003
+ mentionSearchText,
4004
+ mentionUsers,
4005
+ loading,
4006
+ onKeyUp,
4007
+ onFocus,
4008
+ onSelectUser
4009
+ } = useMention(searchMention);
4010
+ React.useEffect(() => {
4011
+ addSanitizeFn(html => {
4012
+ const container = document.createElement("div");
4544
4013
  container.innerHTML = html;
4545
- var mentionsEl = Array.prototype.slice.call(container.querySelectorAll(".react-input-emoji--mention--text"));
4546
- mentionsEl.forEach(function (mentionEl) {
4547
- container.innerHTML = container.innerHTML.replace(mentionEl.outerHTML, "@[".concat(mentionEl.dataset.mentionName, "](userId:").concat(mentionEl.dataset.mentionId, ")"));
4014
+ const mentionsEl = Array.prototype.slice.call(container.querySelectorAll(".react-input-emoji--mention--text"));
4015
+ mentionsEl.forEach(mentionEl => {
4016
+ container.innerHTML = container.innerHTML.replace(mentionEl.outerHTML, `@[${mentionEl.dataset.mentionName}](userId:${mentionEl.dataset.mentionId})`);
4548
4017
  });
4549
4018
  return container.innerHTML;
4550
4019
  });
4551
4020
  }, [addSanitizeFn]);
4552
- React.useEffect(function () {
4021
+ React.useEffect(() => {
4553
4022
  setShowUserList(mentionUsers.length > 0);
4554
4023
  }, [mentionUsers]);
4555
- React.useEffect(function () {
4024
+ React.useEffect(() => {
4556
4025
  /** */
4557
4026
  function checkClickOutside() {
4558
4027
  setShowUserList(false);
4559
4028
  }
4560
4029
  document.addEventListener("click", checkClickOutside);
4561
- return function () {
4030
+ return () => {
4562
4031
  document.removeEventListener("click", checkClickOutside);
4563
4032
  };
4564
4033
  }, []);
4565
- React.useEffect(function () {
4566
- var unsubscribe = addEventListener("keyUp", onKeyUp);
4567
- return function () {
4034
+ React.useEffect(() => {
4035
+ const unsubscribe = addEventListener("keyUp", onKeyUp);
4036
+ return () => {
4568
4037
  unsubscribe();
4569
4038
  };
4570
4039
  }, [addEventListener, onKeyUp]);
4571
- React.useEffect(function () {
4040
+ React.useEffect(() => {
4572
4041
  /**
4573
4042
  *
4574
4043
  * @param {React.KeyboardEvent} event
@@ -4581,30 +4050,30 @@ var MentionWrapper = function MentionWrapper(_ref) {
4581
4050
  break;
4582
4051
  }
4583
4052
  }
4584
- var unsubscribe = addEventListener("keyDown", handleKeyDown);
4585
- return function () {
4053
+ const unsubscribe = addEventListener("keyDown", handleKeyDown);
4054
+ return () => {
4586
4055
  unsubscribe();
4587
4056
  };
4588
4057
  }, [addEventListener]);
4589
- React.useEffect(function () {
4590
- var unsubscribe = addEventListener("focus", onFocus);
4591
- return function () {
4058
+ React.useEffect(() => {
4059
+ const unsubscribe = addEventListener("focus", onFocus);
4060
+ return () => {
4592
4061
  unsubscribe();
4593
4062
  };
4594
4063
  }, [addEventListener, onFocus]);
4595
- React.useEffect(function () {
4064
+ React.useEffect(() => {
4596
4065
  if (showUserList) {
4597
- var unsubscribeArrowUp = addEventListener("arrowUp", function (event) {
4066
+ const unsubscribeArrowUp = addEventListener("arrowUp", event => {
4598
4067
  event.stopPropagation();
4599
4068
  event.preventDefault();
4600
4069
  metionUserListRef.current.prevUser();
4601
4070
  });
4602
- var unsubscribeArrowDown = addEventListener("arrowDown", function (event) {
4071
+ const unsubscribeArrowDown = addEventListener("arrowDown", event => {
4603
4072
  event.stopPropagation();
4604
4073
  event.preventDefault();
4605
4074
  metionUserListRef.current.nextUser();
4606
4075
  });
4607
- return function () {
4076
+ return () => {
4608
4077
  unsubscribeArrowUp();
4609
4078
  unsubscribeArrowDown();
4610
4079
  };
@@ -4617,7 +4086,7 @@ var MentionWrapper = function MentionWrapper(_ref) {
4617
4086
  */
4618
4087
  function handleSelect(user) {
4619
4088
  onSelectUser();
4620
- appendContent("<span class=\"react-input-emoji--mention--text\" data-mention-id=\"".concat(user.id, "\" data-mention-name=\"").concat(user.name, "\">@").concat(user.name, "</span> "));
4089
+ appendContent(`<span class="react-input-emoji--mention--text" data-mention-id="${user.id}" data-mention-name="${user.name}">@${user.name}</span> `);
4621
4090
  }
4622
4091
  return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, loading ? /*#__PURE__*/React__default["default"].createElement("div", {
4623
4092
  className: "react-input-emoji--mention--container"
@@ -4627,9 +4096,7 @@ var MentionWrapper = function MentionWrapper(_ref) {
4627
4096
  className: "react-input-emoji--mention--loading--spinner"
4628
4097
  }, "Loading..."))) : showUserList && /*#__PURE__*/React__default["default"].createElement("div", {
4629
4098
  className: "react-input-emoji--mention--container",
4630
- onClick: function onClick(evt) {
4631
- return evt.stopPropagation();
4632
- }
4099
+ onClick: evt => evt.stopPropagation()
4633
4100
  }, /*#__PURE__*/React__default["default"].createElement(MentionUserListWithRef, {
4634
4101
  ref: metionUserListRef,
4635
4102
  mentionSearchText: mentionSearchText,
@@ -4648,20 +4115,16 @@ var MentionWrapper = function MentionWrapper(_ref) {
4648
4115
  */
4649
4116
  function createObserver() {
4650
4117
  /** @type {import('../types/types').Listerner<T>[]} */
4651
- var listeners = [];
4118
+ let listeners = [];
4652
4119
  return {
4653
- subscribe: function subscribe(listener) {
4120
+ subscribe: listener => {
4654
4121
  listeners.push(listener);
4655
- return function () {
4656
- listeners = listeners.filter(function (l) {
4657
- return l !== listener;
4658
- });
4122
+ return () => {
4123
+ listeners = listeners.filter(l => l !== listener);
4659
4124
  };
4660
4125
  },
4661
- publish: function publish(event) {
4662
- listeners.forEach(function (listener) {
4663
- return listener(event);
4664
- });
4126
+ publish: event => {
4127
+ listeners.forEach(listener => listener(event));
4665
4128
  },
4666
4129
  get currentListerners() {
4667
4130
  return listeners;
@@ -4679,28 +4142,26 @@ function createObserver() {
4679
4142
  /** */
4680
4143
  function useEventListeners() {
4681
4144
  /** @type {TextInputListeners} */
4682
- var listeners = React.useMemo(function () {
4683
- return {
4684
- keyDown: createObserver(),
4685
- keyUp: createObserver(),
4686
- arrowUp: createObserver(),
4687
- arrowDown: createObserver(),
4688
- enter: createObserver(),
4689
- focus: createObserver(),
4690
- blur: createObserver()
4691
- };
4692
- }, []);
4145
+ const listeners = React.useMemo(() => ({
4146
+ keyDown: createObserver(),
4147
+ keyUp: createObserver(),
4148
+ arrowUp: createObserver(),
4149
+ arrowDown: createObserver(),
4150
+ enter: createObserver(),
4151
+ focus: createObserver(),
4152
+ blur: createObserver()
4153
+ }), []);
4693
4154
 
4694
4155
  /**
4695
4156
  * @template {keyof TextInputListeners} T, K
4696
4157
  * @type {(event: keyof TextInputListeners, fn: import('../types/types').Listerner<any>) => () => void}
4697
4158
  */
4698
- var addEventListener = React.useCallback(function (event, fn) {
4159
+ const addEventListener = React.useCallback((event, fn) => {
4699
4160
  return listeners[event].subscribe(fn);
4700
4161
  }, [listeners]);
4701
4162
  return {
4702
- addEventListener: addEventListener,
4703
- listeners: listeners
4163
+ addEventListener,
4164
+ listeners
4704
4165
  };
4705
4166
  }
4706
4167
 
@@ -4714,23 +4175,23 @@ function useEventListeners() {
4714
4175
  /** */
4715
4176
  function usePollute() {
4716
4177
  /** @type {React.MutableRefObject<PolluteFn[]>} */
4717
- var polluteFnsRef = React.useRef([]);
4178
+ const polluteFnsRef = React.useRef([]);
4718
4179
 
4719
4180
  /** @type {(fn: PolluteFn) => void} */
4720
- var addPolluteFn = React.useCallback(function (fn) {
4181
+ const addPolluteFn = React.useCallback(fn => {
4721
4182
  polluteFnsRef.current.push(fn);
4722
4183
  }, []);
4723
4184
 
4724
4185
  /** @type {(html: string) => string} */
4725
- var pollute = React.useCallback(function (text) {
4726
- var result = polluteFnsRef.current.reduce(function (acc, fn) {
4186
+ const pollute = React.useCallback(text => {
4187
+ const result = polluteFnsRef.current.reduce((acc, fn) => {
4727
4188
  return fn(acc);
4728
4189
  }, text);
4729
4190
  return result;
4730
4191
  }, []);
4731
4192
  return {
4732
- addPolluteFn: addPolluteFn,
4733
- pollute: pollute
4193
+ addPolluteFn,
4194
+ pollute
4734
4195
  };
4735
4196
  }
4736
4197
 
@@ -4786,72 +4247,77 @@ function usePollute() {
4786
4247
  * @return {JSX.Element}
4787
4248
  */
4788
4249
  function InputEmoji(props, ref) {
4789
- var onChange = props.onChange,
4790
- onEnter = props.onEnter,
4791
- onResize = props.onResize,
4792
- onClick = props.onClick,
4793
- onFocus = props.onFocus,
4794
- onBlur = props.onBlur,
4795
- onKeyDown = props.onKeyDown,
4796
- theme = props.theme,
4797
- cleanOnEnter = props.cleanOnEnter,
4798
- placeholder = props.placeholder,
4799
- maxLength = props.maxLength,
4800
- keepOpened = props.keepOpened,
4801
- inputClass = props.inputClass,
4802
- disableRecent = props.disableRecent,
4803
- tabIndex = props.tabIndex,
4804
- value = props.value,
4805
- customEmojis = props.customEmojis,
4806
- language = props.language,
4807
- searchMention = props.searchMention,
4808
- buttonElement = props.buttonElement,
4809
- buttonRef = props.buttonRef,
4810
- shouldReturn = props.shouldReturn,
4811
- shouldConvertEmojiToImage = props.shouldConvertEmojiToImage,
4812
- borderRadius = props.borderRadius,
4813
- borderColor = props.borderColor,
4814
- fontSize = props.fontSize,
4815
- fontFamily = props.fontFamily,
4816
- background = props.background,
4817
- placeholderColor = props.placeholderColor,
4818
- color = props.color;
4250
+ const {
4251
+ onChange,
4252
+ onEnter,
4253
+ onResize,
4254
+ onClick,
4255
+ onFocus,
4256
+ onBlur,
4257
+ onKeyDown,
4258
+ theme,
4259
+ cleanOnEnter,
4260
+ placeholder,
4261
+ maxLength,
4262
+ keepOpened,
4263
+ inputClass,
4264
+ disableRecent,
4265
+ tabIndex,
4266
+ value,
4267
+ customEmojis,
4268
+ language,
4269
+ searchMention,
4270
+ buttonElement,
4271
+ buttonRef,
4272
+ shouldReturn,
4273
+ shouldConvertEmojiToImage,
4274
+ // style
4275
+ borderRadius,
4276
+ borderColor,
4277
+ fontSize,
4278
+ fontFamily,
4279
+ background,
4280
+ placeholderColor,
4281
+ color
4282
+ } = props;
4819
4283
 
4820
4284
  /** @type {React.MutableRefObject<import('./text-input').Ref | null>} */
4821
- var textInputRef = React.useRef(null);
4822
- var _useEventListeners = useEventListeners(),
4823
- addEventListener = _useEventListeners.addEventListener,
4824
- listeners = _useEventListeners.listeners;
4825
- var _useSanitize = useSanitize(shouldReturn, shouldConvertEmojiToImage),
4826
- addSanitizeFn = _useSanitize.addSanitizeFn,
4827
- sanitize = _useSanitize.sanitize,
4828
- sanitizedTextRef = _useSanitize.sanitizedTextRef;
4829
- var _usePollute = usePollute(),
4830
- addPolluteFn = _usePollute.addPolluteFn,
4831
- pollute = _usePollute.pollute;
4832
- var updateHTML = React.useCallback(function () {
4833
- var nextValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
4285
+ const textInputRef = React.useRef(null);
4286
+ const {
4287
+ addEventListener,
4288
+ listeners
4289
+ } = useEventListeners();
4290
+ const {
4291
+ addSanitizeFn,
4292
+ sanitize,
4293
+ sanitizedTextRef
4294
+ } = useSanitize(shouldReturn, shouldConvertEmojiToImage);
4295
+ const {
4296
+ addPolluteFn,
4297
+ pollute
4298
+ } = usePollute();
4299
+ const updateHTML = React.useCallback((nextValue = "") => {
4834
4300
  if (textInputRef.current === null) return;
4835
4301
  textInputRef.current.html = replaceAllTextEmojis(nextValue);
4836
4302
  sanitizedTextRef.current = nextValue;
4837
4303
  }, [sanitizedTextRef]);
4838
- var setValue = React.useCallback(
4304
+ const setValue = React.useCallback(
4839
4305
  /**
4840
4306
  *
4841
4307
  * @param {string} value
4842
4308
  */
4843
- function (value) {
4309
+ value => {
4844
4310
  updateHTML(value);
4845
4311
  }, [updateHTML]);
4846
- var emitChange = useEmit(textInputRef, onResize, onChange);
4312
+ const emitChange = useEmit(textInputRef, onResize, onChange);
4847
4313
  useExpose({
4848
- ref: ref,
4849
- setValue: setValue,
4850
- textInputRef: textInputRef,
4851
- emitChange: emitChange,
4852
- shouldConvertEmojiToImage: shouldConvertEmojiToImage
4314
+ ref,
4315
+ setValue,
4316
+ textInputRef,
4317
+ emitChange,
4318
+ shouldConvertEmojiToImage
4853
4319
  });
4854
- React.useEffect(function () {
4320
+ React.useEffect(() => {
4855
4321
  if (sanitizedTextRef.current !== value) {
4856
4322
  setValue(value);
4857
4323
  }
@@ -4861,7 +4327,7 @@ function InputEmoji(props, ref) {
4861
4327
  // updateHTML();
4862
4328
  // }, [updateHTML]);
4863
4329
 
4864
- React.useEffect(function () {
4330
+ React.useEffect(() => {
4865
4331
  /**
4866
4332
  * Handle keydown event
4867
4333
  * @param {React.KeyboardEvent} event
@@ -4873,7 +4339,7 @@ function InputEmoji(props, ref) {
4873
4339
  }
4874
4340
  if (event.key === "Enter" && textInputRef.current) {
4875
4341
  event.preventDefault();
4876
- var text = sanitize(textInputRef.current.html);
4342
+ const text = sanitize(textInputRef.current.html);
4877
4343
  emitChange(sanitizedTextRef.current);
4878
4344
  if (typeof onEnter === "function" && listeners.enter.currentListerners.length === 0) {
4879
4345
  onEnter(text);
@@ -4891,12 +4357,12 @@ function InputEmoji(props, ref) {
4891
4357
  }
4892
4358
  return true;
4893
4359
  }
4894
- var unsubscribe = addEventListener("keyDown", handleKeydown);
4895
- return function () {
4360
+ const unsubscribe = addEventListener("keyDown", handleKeydown);
4361
+ return () => {
4896
4362
  unsubscribe();
4897
4363
  };
4898
4364
  }, [addEventListener, cleanOnEnter, emitChange, listeners.enter.currentListerners.length, maxLength, onEnter, onKeyDown, sanitize, sanitizedTextRef, updateHTML]);
4899
- React.useEffect(function () {
4365
+ React.useEffect(() => {
4900
4366
  /** */
4901
4367
  function handleFocus() {
4902
4368
  if (typeof onClick === "function") {
@@ -4906,20 +4372,20 @@ function InputEmoji(props, ref) {
4906
4372
  onFocus();
4907
4373
  }
4908
4374
  }
4909
- var unsubscribe = addEventListener("focus", handleFocus);
4910
- return function () {
4375
+ const unsubscribe = addEventListener("focus", handleFocus);
4376
+ return () => {
4911
4377
  unsubscribe();
4912
4378
  };
4913
4379
  }, [addEventListener, onClick, onFocus]);
4914
- React.useEffect(function () {
4380
+ React.useEffect(() => {
4915
4381
  /** */
4916
4382
  function handleBlur() {
4917
4383
  if (typeof onBlur === "function") {
4918
4384
  onBlur();
4919
4385
  }
4920
4386
  }
4921
- var unsubscribe = addEventListener("blur", handleBlur);
4922
- return function () {
4387
+ const unsubscribe = addEventListener("blur", handleBlur);
4388
+ return () => {
4923
4389
  unsubscribe();
4924
4390
  };
4925
4391
  }, [addEventListener, onBlur]);
@@ -4954,7 +4420,7 @@ function InputEmoji(props, ref) {
4954
4420
  */
4955
4421
  function handlePaste(event) {
4956
4422
  event.preventDefault();
4957
- var content;
4423
+ let content;
4958
4424
  if (event.clipboardData) {
4959
4425
  content = event.clipboardData.getData("text/plain");
4960
4426
  content = pollute(content);
@@ -4982,13 +4448,13 @@ function InputEmoji(props, ref) {
4982
4448
  onEnter: listeners.enter.publish,
4983
4449
  placeholder: placeholder,
4984
4450
  style: {
4985
- borderRadius: borderRadius,
4986
- borderColor: borderColor,
4987
- fontSize: fontSize,
4988
- fontFamily: fontFamily,
4989
- background: background,
4990
- placeholderColor: placeholderColor,
4991
- color: color
4451
+ borderRadius,
4452
+ borderColor,
4453
+ fontSize,
4454
+ fontFamily,
4455
+ background,
4456
+ placeholderColor,
4457
+ color
4992
4458
  },
4993
4459
  tabIndex: tabIndex,
4994
4460
  className: inputClass,
@@ -5006,7 +4472,7 @@ function InputEmoji(props, ref) {
5006
4472
  language: language
5007
4473
  }));
5008
4474
  }
5009
- var InputEmojiWithRef = /*#__PURE__*/React.forwardRef(InputEmoji);
4475
+ const InputEmojiWithRef = /*#__PURE__*/React.forwardRef(InputEmoji);
5010
4476
  InputEmojiWithRef.defaultProps = {
5011
4477
  theme: /** @type {const} */"auto",
5012
4478
  height: 30,