react-input-emoji 5.8.1 → 5.9.0-beta.2
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.es.js +600 -1052
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +600 -1052
- package/dist/index.js.map +1 -1
- package/dist/src/utils/input-event-utils.d.ts +9 -2
- package/package.json +1 -1
    
        package/dist/index.es.js
    CHANGED
    
    | @@ -30,479 +30,10 @@ function styleInject(css, ref) { | |
| 30 30 | 
             
            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";
         | 
| 31 31 | 
             
            styleInject(css_248z);
         | 
| 32 32 |  | 
| 33 | 
            -
            function _iterableToArrayLimit(r, l) {
         | 
| 34 | 
            -
              var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
         | 
| 35 | 
            -
              if (null != t) {
         | 
| 36 | 
            -
                var e,
         | 
| 37 | 
            -
                  n,
         | 
| 38 | 
            -
                  i,
         | 
| 39 | 
            -
                  u,
         | 
| 40 | 
            -
                  a = [],
         | 
| 41 | 
            -
                  f = !0,
         | 
| 42 | 
            -
                  o = !1;
         | 
| 43 | 
            -
                try {
         | 
| 44 | 
            -
                  if (i = (t = t.call(r)).next, 0 === l) {
         | 
| 45 | 
            -
                    if (Object(t) !== t) return;
         | 
| 46 | 
            -
                    f = !1;
         | 
| 47 | 
            -
                  } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
         | 
| 48 | 
            -
                } catch (r) {
         | 
| 49 | 
            -
                  o = !0, n = r;
         | 
| 50 | 
            -
                } finally {
         | 
| 51 | 
            -
                  try {
         | 
| 52 | 
            -
                    if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;
         | 
| 53 | 
            -
                  } finally {
         | 
| 54 | 
            -
                    if (o) throw n;
         | 
| 55 | 
            -
                  }
         | 
| 56 | 
            -
                }
         | 
| 57 | 
            -
                return a;
         | 
| 58 | 
            -
              }
         | 
| 59 | 
            -
            }
         | 
| 60 | 
            -
            function ownKeys(e, r) {
         | 
| 61 | 
            -
              var t = Object.keys(e);
         | 
| 62 | 
            -
              if (Object.getOwnPropertySymbols) {
         | 
| 63 | 
            -
                var o = Object.getOwnPropertySymbols(e);
         | 
| 64 | 
            -
                r && (o = o.filter(function (r) {
         | 
| 65 | 
            -
                  return Object.getOwnPropertyDescriptor(e, r).enumerable;
         | 
| 66 | 
            -
                })), t.push.apply(t, o);
         | 
| 67 | 
            -
              }
         | 
| 68 | 
            -
              return t;
         | 
| 69 | 
            -
            }
         | 
| 70 | 
            -
            function _objectSpread2(e) {
         | 
| 71 | 
            -
              for (var r = 1; r < arguments.length; r++) {
         | 
| 72 | 
            -
                var t = null != arguments[r] ? arguments[r] : {};
         | 
| 73 | 
            -
                r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {
         | 
| 74 | 
            -
                  _defineProperty(e, r, t[r]);
         | 
| 75 | 
            -
                }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {
         | 
| 76 | 
            -
                  Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));
         | 
| 77 | 
            -
                });
         | 
| 78 | 
            -
              }
         | 
| 79 | 
            -
              return e;
         | 
| 80 | 
            -
            }
         | 
| 81 | 
            -
            function _regeneratorRuntime() {
         | 
| 82 | 
            -
              _regeneratorRuntime = function () {
         | 
| 83 | 
            -
                return e;
         | 
| 84 | 
            -
              };
         | 
| 85 | 
            -
              var t,
         | 
| 86 | 
            -
                e = {},
         | 
| 87 | 
            -
                r = Object.prototype,
         | 
| 88 | 
            -
                n = r.hasOwnProperty,
         | 
| 89 | 
            -
                o = Object.defineProperty || function (t, e, r) {
         | 
| 90 | 
            -
                  t[e] = r.value;
         | 
| 91 | 
            -
                },
         | 
| 92 | 
            -
                i = "function" == typeof Symbol ? Symbol : {},
         | 
| 93 | 
            -
                a = i.iterator || "@@iterator",
         | 
| 94 | 
            -
                c = i.asyncIterator || "@@asyncIterator",
         | 
| 95 | 
            -
                u = i.toStringTag || "@@toStringTag";
         | 
| 96 | 
            -
              function define(t, e, r) {
         | 
| 97 | 
            -
                return Object.defineProperty(t, e, {
         | 
| 98 | 
            -
                  value: r,
         | 
| 99 | 
            -
                  enumerable: !0,
         | 
| 100 | 
            -
                  configurable: !0,
         | 
| 101 | 
            -
                  writable: !0
         | 
| 102 | 
            -
                }), t[e];
         | 
| 103 | 
            -
              }
         | 
| 104 | 
            -
              try {
         | 
| 105 | 
            -
                define({}, "");
         | 
| 106 | 
            -
              } catch (t) {
         | 
| 107 | 
            -
                define = function (t, e, r) {
         | 
| 108 | 
            -
                  return t[e] = r;
         | 
| 109 | 
            -
                };
         | 
| 110 | 
            -
              }
         | 
| 111 | 
            -
              function wrap(t, e, r, n) {
         | 
| 112 | 
            -
                var i = e && e.prototype instanceof Generator ? e : Generator,
         | 
| 113 | 
            -
                  a = Object.create(i.prototype),
         | 
| 114 | 
            -
                  c = new Context(n || []);
         | 
| 115 | 
            -
                return o(a, "_invoke", {
         | 
| 116 | 
            -
                  value: makeInvokeMethod(t, r, c)
         | 
| 117 | 
            -
                }), a;
         | 
| 118 | 
            -
              }
         | 
| 119 | 
            -
              function tryCatch(t, e, r) {
         | 
| 120 | 
            -
                try {
         | 
| 121 | 
            -
                  return {
         | 
| 122 | 
            -
                    type: "normal",
         | 
| 123 | 
            -
                    arg: t.call(e, r)
         | 
| 124 | 
            -
                  };
         | 
| 125 | 
            -
                } catch (t) {
         | 
| 126 | 
            -
                  return {
         | 
| 127 | 
            -
                    type: "throw",
         | 
| 128 | 
            -
                    arg: t
         | 
| 129 | 
            -
                  };
         | 
| 130 | 
            -
                }
         | 
| 131 | 
            -
              }
         | 
| 132 | 
            -
              e.wrap = wrap;
         | 
| 133 | 
            -
              var h = "suspendedStart",
         | 
| 134 | 
            -
                l = "suspendedYield",
         | 
| 135 | 
            -
                f = "executing",
         | 
| 136 | 
            -
                s = "completed",
         | 
| 137 | 
            -
                y = {};
         | 
| 138 | 
            -
              function Generator() {}
         | 
| 139 | 
            -
              function GeneratorFunction() {}
         | 
| 140 | 
            -
              function GeneratorFunctionPrototype() {}
         | 
| 141 | 
            -
              var p = {};
         | 
| 142 | 
            -
              define(p, a, function () {
         | 
| 143 | 
            -
                return this;
         | 
| 144 | 
            -
              });
         | 
| 145 | 
            -
              var d = Object.getPrototypeOf,
         | 
| 146 | 
            -
                v = d && d(d(values([])));
         | 
| 147 | 
            -
              v && v !== r && n.call(v, a) && (p = v);
         | 
| 148 | 
            -
              var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
         | 
| 149 | 
            -
              function defineIteratorMethods(t) {
         | 
| 150 | 
            -
                ["next", "throw", "return"].forEach(function (e) {
         | 
| 151 | 
            -
                  define(t, e, function (t) {
         | 
| 152 | 
            -
                    return this._invoke(e, t);
         | 
| 153 | 
            -
                  });
         | 
| 154 | 
            -
                });
         | 
| 155 | 
            -
              }
         | 
| 156 | 
            -
              function AsyncIterator(t, e) {
         | 
| 157 | 
            -
                function invoke(r, o, i, a) {
         | 
| 158 | 
            -
                  var c = tryCatch(t[r], t, o);
         | 
| 159 | 
            -
                  if ("throw" !== c.type) {
         | 
| 160 | 
            -
                    var u = c.arg,
         | 
| 161 | 
            -
                      h = u.value;
         | 
| 162 | 
            -
                    return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
         | 
| 163 | 
            -
                      invoke("next", t, i, a);
         | 
| 164 | 
            -
                    }, function (t) {
         | 
| 165 | 
            -
                      invoke("throw", t, i, a);
         | 
| 166 | 
            -
                    }) : e.resolve(h).then(function (t) {
         | 
| 167 | 
            -
                      u.value = t, i(u);
         | 
| 168 | 
            -
                    }, function (t) {
         | 
| 169 | 
            -
                      return invoke("throw", t, i, a);
         | 
| 170 | 
            -
                    });
         | 
| 171 | 
            -
                  }
         | 
| 172 | 
            -
                  a(c.arg);
         | 
| 173 | 
            -
                }
         | 
| 174 | 
            -
                var r;
         | 
| 175 | 
            -
                o(this, "_invoke", {
         | 
| 176 | 
            -
                  value: function (t, n) {
         | 
| 177 | 
            -
                    function callInvokeWithMethodAndArg() {
         | 
| 178 | 
            -
                      return new e(function (e, r) {
         | 
| 179 | 
            -
                        invoke(t, n, e, r);
         | 
| 180 | 
            -
                      });
         | 
| 181 | 
            -
                    }
         | 
| 182 | 
            -
                    return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
         | 
| 183 | 
            -
                  }
         | 
| 184 | 
            -
                });
         | 
| 185 | 
            -
              }
         | 
| 186 | 
            -
              function makeInvokeMethod(e, r, n) {
         | 
| 187 | 
            -
                var o = h;
         | 
| 188 | 
            -
                return function (i, a) {
         | 
| 189 | 
            -
                  if (o === f) throw new Error("Generator is already running");
         | 
| 190 | 
            -
                  if (o === s) {
         | 
| 191 | 
            -
                    if ("throw" === i) throw a;
         | 
| 192 | 
            -
                    return {
         | 
| 193 | 
            -
                      value: t,
         | 
| 194 | 
            -
                      done: !0
         | 
| 195 | 
            -
                    };
         | 
| 196 | 
            -
                  }
         | 
| 197 | 
            -
                  for (n.method = i, n.arg = a;;) {
         | 
| 198 | 
            -
                    var c = n.delegate;
         | 
| 199 | 
            -
                    if (c) {
         | 
| 200 | 
            -
                      var u = maybeInvokeDelegate(c, n);
         | 
| 201 | 
            -
                      if (u) {
         | 
| 202 | 
            -
                        if (u === y) continue;
         | 
| 203 | 
            -
                        return u;
         | 
| 204 | 
            -
                      }
         | 
| 205 | 
            -
                    }
         | 
| 206 | 
            -
                    if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
         | 
| 207 | 
            -
                      if (o === h) throw o = s, n.arg;
         | 
| 208 | 
            -
                      n.dispatchException(n.arg);
         | 
| 209 | 
            -
                    } else "return" === n.method && n.abrupt("return", n.arg);
         | 
| 210 | 
            -
                    o = f;
         | 
| 211 | 
            -
                    var p = tryCatch(e, r, n);
         | 
| 212 | 
            -
                    if ("normal" === p.type) {
         | 
| 213 | 
            -
                      if (o = n.done ? s : l, p.arg === y) continue;
         | 
| 214 | 
            -
                      return {
         | 
| 215 | 
            -
                        value: p.arg,
         | 
| 216 | 
            -
                        done: n.done
         | 
| 217 | 
            -
                      };
         | 
| 218 | 
            -
                    }
         | 
| 219 | 
            -
                    "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
         | 
| 220 | 
            -
                  }
         | 
| 221 | 
            -
                };
         | 
| 222 | 
            -
              }
         | 
| 223 | 
            -
              function maybeInvokeDelegate(e, r) {
         | 
| 224 | 
            -
                var n = r.method,
         | 
| 225 | 
            -
                  o = e.iterator[n];
         | 
| 226 | 
            -
                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;
         | 
| 227 | 
            -
                var i = tryCatch(o, e.iterator, r.arg);
         | 
| 228 | 
            -
                if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
         | 
| 229 | 
            -
                var a = i.arg;
         | 
| 230 | 
            -
                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);
         | 
| 231 | 
            -
              }
         | 
| 232 | 
            -
              function pushTryEntry(t) {
         | 
| 233 | 
            -
                var e = {
         | 
| 234 | 
            -
                  tryLoc: t[0]
         | 
| 235 | 
            -
                };
         | 
| 236 | 
            -
                1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
         | 
| 237 | 
            -
              }
         | 
| 238 | 
            -
              function resetTryEntry(t) {
         | 
| 239 | 
            -
                var e = t.completion || {};
         | 
| 240 | 
            -
                e.type = "normal", delete e.arg, t.completion = e;
         | 
| 241 | 
            -
              }
         | 
| 242 | 
            -
              function Context(t) {
         | 
| 243 | 
            -
                this.tryEntries = [{
         | 
| 244 | 
            -
                  tryLoc: "root"
         | 
| 245 | 
            -
                }], t.forEach(pushTryEntry, this), this.reset(!0);
         | 
| 246 | 
            -
              }
         | 
| 247 | 
            -
              function values(e) {
         | 
| 248 | 
            -
                if (e || "" === e) {
         | 
| 249 | 
            -
                  var r = e[a];
         | 
| 250 | 
            -
                  if (r) return r.call(e);
         | 
| 251 | 
            -
                  if ("function" == typeof e.next) return e;
         | 
| 252 | 
            -
                  if (!isNaN(e.length)) {
         | 
| 253 | 
            -
                    var o = -1,
         | 
| 254 | 
            -
                      i = function next() {
         | 
| 255 | 
            -
                        for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
         | 
| 256 | 
            -
                        return next.value = t, next.done = !0, next;
         | 
| 257 | 
            -
                      };
         | 
| 258 | 
            -
                    return i.next = i;
         | 
| 259 | 
            -
                  }
         | 
| 260 | 
            -
                }
         | 
| 261 | 
            -
                throw new TypeError(typeof e + " is not iterable");
         | 
| 262 | 
            -
              }
         | 
| 263 | 
            -
              return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
         | 
| 264 | 
            -
                value: GeneratorFunctionPrototype,
         | 
| 265 | 
            -
                configurable: !0
         | 
| 266 | 
            -
              }), o(GeneratorFunctionPrototype, "constructor", {
         | 
| 267 | 
            -
                value: GeneratorFunction,
         | 
| 268 | 
            -
                configurable: !0
         | 
| 269 | 
            -
              }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
         | 
| 270 | 
            -
                var e = "function" == typeof t && t.constructor;
         | 
| 271 | 
            -
                return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
         | 
| 272 | 
            -
              }, e.mark = function (t) {
         | 
| 273 | 
            -
                return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
         | 
| 274 | 
            -
              }, e.awrap = function (t) {
         | 
| 275 | 
            -
                return {
         | 
| 276 | 
            -
                  __await: t
         | 
| 277 | 
            -
                };
         | 
| 278 | 
            -
              }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
         | 
| 279 | 
            -
                return this;
         | 
| 280 | 
            -
              }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
         | 
| 281 | 
            -
                void 0 === i && (i = Promise);
         | 
| 282 | 
            -
                var a = new AsyncIterator(wrap(t, r, n, o), i);
         | 
| 283 | 
            -
                return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
         | 
| 284 | 
            -
                  return t.done ? t.value : a.next();
         | 
| 285 | 
            -
                });
         | 
| 286 | 
            -
              }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
         | 
| 287 | 
            -
                return this;
         | 
| 288 | 
            -
              }), define(g, "toString", function () {
         | 
| 289 | 
            -
                return "[object Generator]";
         | 
| 290 | 
            -
              }), e.keys = function (t) {
         | 
| 291 | 
            -
                var e = Object(t),
         | 
| 292 | 
            -
                  r = [];
         | 
| 293 | 
            -
                for (var n in e) r.push(n);
         | 
| 294 | 
            -
                return r.reverse(), function next() {
         | 
| 295 | 
            -
                  for (; r.length;) {
         | 
| 296 | 
            -
                    var t = r.pop();
         | 
| 297 | 
            -
                    if (t in e) return next.value = t, next.done = !1, next;
         | 
| 298 | 
            -
                  }
         | 
| 299 | 
            -
                  return next.done = !0, next;
         | 
| 300 | 
            -
                };
         | 
| 301 | 
            -
              }, e.values = values, Context.prototype = {
         | 
| 302 | 
            -
                constructor: Context,
         | 
| 303 | 
            -
                reset: function (e) {
         | 
| 304 | 
            -
                  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);
         | 
| 305 | 
            -
                },
         | 
| 306 | 
            -
                stop: function () {
         | 
| 307 | 
            -
                  this.done = !0;
         | 
| 308 | 
            -
                  var t = this.tryEntries[0].completion;
         | 
| 309 | 
            -
                  if ("throw" === t.type) throw t.arg;
         | 
| 310 | 
            -
                  return this.rval;
         | 
| 311 | 
            -
                },
         | 
| 312 | 
            -
                dispatchException: function (e) {
         | 
| 313 | 
            -
                  if (this.done) throw e;
         | 
| 314 | 
            -
                  var r = this;
         | 
| 315 | 
            -
                  function handle(n, o) {
         | 
| 316 | 
            -
                    return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
         | 
| 317 | 
            -
                  }
         | 
| 318 | 
            -
                  for (var o = this.tryEntries.length - 1; o >= 0; --o) {
         | 
| 319 | 
            -
                    var i = this.tryEntries[o],
         | 
| 320 | 
            -
                      a = i.completion;
         | 
| 321 | 
            -
                    if ("root" === i.tryLoc) return handle("end");
         | 
| 322 | 
            -
                    if (i.tryLoc <= this.prev) {
         | 
| 323 | 
            -
                      var c = n.call(i, "catchLoc"),
         | 
| 324 | 
            -
                        u = n.call(i, "finallyLoc");
         | 
| 325 | 
            -
                      if (c && u) {
         | 
| 326 | 
            -
                        if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
         | 
| 327 | 
            -
                        if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
         | 
| 328 | 
            -
                      } else if (c) {
         | 
| 329 | 
            -
                        if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
         | 
| 330 | 
            -
                      } else {
         | 
| 331 | 
            -
                        if (!u) throw new Error("try statement without catch or finally");
         | 
| 332 | 
            -
                        if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
         | 
| 333 | 
            -
                      }
         | 
| 334 | 
            -
                    }
         | 
| 335 | 
            -
                  }
         | 
| 336 | 
            -
                },
         | 
| 337 | 
            -
                abrupt: function (t, e) {
         | 
| 338 | 
            -
                  for (var r = this.tryEntries.length - 1; r >= 0; --r) {
         | 
| 339 | 
            -
                    var o = this.tryEntries[r];
         | 
| 340 | 
            -
                    if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
         | 
| 341 | 
            -
                      var i = o;
         | 
| 342 | 
            -
                      break;
         | 
| 343 | 
            -
                    }
         | 
| 344 | 
            -
                  }
         | 
| 345 | 
            -
                  i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
         | 
| 346 | 
            -
                  var a = i ? i.completion : {};
         | 
| 347 | 
            -
                  return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
         | 
| 348 | 
            -
                },
         | 
| 349 | 
            -
                complete: function (t, e) {
         | 
| 350 | 
            -
                  if ("throw" === t.type) throw t.arg;
         | 
| 351 | 
            -
                  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;
         | 
| 352 | 
            -
                },
         | 
| 353 | 
            -
                finish: function (t) {
         | 
| 354 | 
            -
                  for (var e = this.tryEntries.length - 1; e >= 0; --e) {
         | 
| 355 | 
            -
                    var r = this.tryEntries[e];
         | 
| 356 | 
            -
                    if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
         | 
| 357 | 
            -
                  }
         | 
| 358 | 
            -
                },
         | 
| 359 | 
            -
                catch: function (t) {
         | 
| 360 | 
            -
                  for (var e = this.tryEntries.length - 1; e >= 0; --e) {
         | 
| 361 | 
            -
                    var r = this.tryEntries[e];
         | 
| 362 | 
            -
                    if (r.tryLoc === t) {
         | 
| 363 | 
            -
                      var n = r.completion;
         | 
| 364 | 
            -
                      if ("throw" === n.type) {
         | 
| 365 | 
            -
                        var o = n.arg;
         | 
| 366 | 
            -
                        resetTryEntry(r);
         | 
| 367 | 
            -
                      }
         | 
| 368 | 
            -
                      return o;
         | 
| 369 | 
            -
                    }
         | 
| 370 | 
            -
                  }
         | 
| 371 | 
            -
                  throw new Error("illegal catch attempt");
         | 
| 372 | 
            -
                },
         | 
| 373 | 
            -
                delegateYield: function (e, r, n) {
         | 
| 374 | 
            -
                  return this.delegate = {
         | 
| 375 | 
            -
                    iterator: values(e),
         | 
| 376 | 
            -
                    resultName: r,
         | 
| 377 | 
            -
                    nextLoc: n
         | 
| 378 | 
            -
                  }, "next" === this.method && (this.arg = t), y;
         | 
| 379 | 
            -
                }
         | 
| 380 | 
            -
              }, e;
         | 
| 381 | 
            -
            }
         | 
| 382 | 
            -
            function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
         | 
| 383 | 
            -
              try {
         | 
| 384 | 
            -
                var info = gen[key](arg);
         | 
| 385 | 
            -
                var value = info.value;
         | 
| 386 | 
            -
              } catch (error) {
         | 
| 387 | 
            -
                reject(error);
         | 
| 388 | 
            -
                return;
         | 
| 389 | 
            -
              }
         | 
| 390 | 
            -
              if (info.done) {
         | 
| 391 | 
            -
                resolve(value);
         | 
| 392 | 
            -
              } else {
         | 
| 393 | 
            -
                Promise.resolve(value).then(_next, _throw);
         | 
| 394 | 
            -
              }
         | 
| 395 | 
            -
            }
         | 
| 396 | 
            -
            function _asyncToGenerator(fn) {
         | 
| 397 | 
            -
              return function () {
         | 
| 398 | 
            -
                var self = this,
         | 
| 399 | 
            -
                  args = arguments;
         | 
| 400 | 
            -
                return new Promise(function (resolve, reject) {
         | 
| 401 | 
            -
                  var gen = fn.apply(self, args);
         | 
| 402 | 
            -
                  function _next(value) {
         | 
| 403 | 
            -
                    asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
         | 
| 404 | 
            -
                  }
         | 
| 405 | 
            -
                  function _throw(err) {
         | 
| 406 | 
            -
                    asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
         | 
| 407 | 
            -
                  }
         | 
| 408 | 
            -
                  _next(undefined);
         | 
| 409 | 
            -
                });
         | 
| 410 | 
            -
              };
         | 
| 411 | 
            -
            }
         | 
| 412 | 
            -
            function _defineProperty(obj, key, value) {
         | 
| 413 | 
            -
              key = _toPropertyKey(key);
         | 
| 414 | 
            -
              if (key in obj) {
         | 
| 415 | 
            -
                Object.defineProperty(obj, key, {
         | 
| 416 | 
            -
                  value: value,
         | 
| 417 | 
            -
                  enumerable: true,
         | 
| 418 | 
            -
                  configurable: true,
         | 
| 419 | 
            -
                  writable: true
         | 
| 420 | 
            -
                });
         | 
| 421 | 
            -
              } else {
         | 
| 422 | 
            -
                obj[key] = value;
         | 
| 423 | 
            -
              }
         | 
| 424 | 
            -
              return obj;
         | 
| 425 | 
            -
            }
         | 
| 426 | 
            -
            function _objectWithoutPropertiesLoose(source, excluded) {
         | 
| 427 | 
            -
              if (source == null) return {};
         | 
| 428 | 
            -
              var target = {};
         | 
| 429 | 
            -
              var sourceKeys = Object.keys(source);
         | 
| 430 | 
            -
              var key, i;
         | 
| 431 | 
            -
              for (i = 0; i < sourceKeys.length; i++) {
         | 
| 432 | 
            -
                key = sourceKeys[i];
         | 
| 433 | 
            -
                if (excluded.indexOf(key) >= 0) continue;
         | 
| 434 | 
            -
                target[key] = source[key];
         | 
| 435 | 
            -
              }
         | 
| 436 | 
            -
              return target;
         | 
| 437 | 
            -
            }
         | 
| 438 | 
            -
            function _objectWithoutProperties(source, excluded) {
         | 
| 439 | 
            -
              if (source == null) return {};
         | 
| 440 | 
            -
              var target = _objectWithoutPropertiesLoose(source, excluded);
         | 
| 441 | 
            -
              var key, i;
         | 
| 442 | 
            -
              if (Object.getOwnPropertySymbols) {
         | 
| 443 | 
            -
                var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
         | 
| 444 | 
            -
                for (i = 0; i < sourceSymbolKeys.length; i++) {
         | 
| 445 | 
            -
                  key = sourceSymbolKeys[i];
         | 
| 446 | 
            -
                  if (excluded.indexOf(key) >= 0) continue;
         | 
| 447 | 
            -
                  if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
         | 
| 448 | 
            -
                  target[key] = source[key];
         | 
| 449 | 
            -
                }
         | 
| 450 | 
            -
              }
         | 
| 451 | 
            -
              return target;
         | 
| 452 | 
            -
            }
         | 
| 453 | 
            -
            function _slicedToArray(arr, i) {
         | 
| 454 | 
            -
              return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
         | 
| 455 | 
            -
            }
         | 
| 456 | 
            -
            function _toConsumableArray(arr) {
         | 
| 457 | 
            -
              return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
         | 
| 458 | 
            -
            }
         | 
| 459 | 
            -
            function _arrayWithoutHoles(arr) {
         | 
| 460 | 
            -
              if (Array.isArray(arr)) return _arrayLikeToArray(arr);
         | 
| 461 | 
            -
            }
         | 
| 462 | 
            -
            function _arrayWithHoles(arr) {
         | 
| 463 | 
            -
              if (Array.isArray(arr)) return arr;
         | 
| 464 | 
            -
            }
         | 
| 465 | 
            -
            function _iterableToArray(iter) {
         | 
| 466 | 
            -
              if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
         | 
| 467 | 
            -
            }
         | 
| 468 | 
            -
            function _unsupportedIterableToArray(o, minLen) {
         | 
| 469 | 
            -
              if (!o) return;
         | 
| 470 | 
            -
              if (typeof o === "string") return _arrayLikeToArray(o, minLen);
         | 
| 471 | 
            -
              var n = Object.prototype.toString.call(o).slice(8, -1);
         | 
| 472 | 
            -
              if (n === "Object" && o.constructor) n = o.constructor.name;
         | 
| 473 | 
            -
              if (n === "Map" || n === "Set") return Array.from(o);
         | 
| 474 | 
            -
              if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
         | 
| 475 | 
            -
            }
         | 
| 476 | 
            -
            function _arrayLikeToArray(arr, len) {
         | 
| 477 | 
            -
              if (len == null || len > arr.length) len = arr.length;
         | 
| 478 | 
            -
              for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
         | 
| 479 | 
            -
              return arr2;
         | 
| 480 | 
            -
            }
         | 
| 481 | 
            -
            function _nonIterableSpread() {
         | 
| 482 | 
            -
              throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
         | 
| 483 | 
            -
            }
         | 
| 484 | 
            -
            function _nonIterableRest() {
         | 
| 485 | 
            -
              throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
         | 
| 486 | 
            -
            }
         | 
| 487 | 
            -
            function _toPrimitive(input, hint) {
         | 
| 488 | 
            -
              if (typeof input !== "object" || input === null) return input;
         | 
| 489 | 
            -
              var prim = input[Symbol.toPrimitive];
         | 
| 490 | 
            -
              if (prim !== undefined) {
         | 
| 491 | 
            -
                var res = prim.call(input, hint || "default");
         | 
| 492 | 
            -
                if (typeof res !== "object") return res;
         | 
| 493 | 
            -
                throw new TypeError("@@toPrimitive must return a primitive value.");
         | 
| 494 | 
            -
              }
         | 
| 495 | 
            -
              return (hint === "string" ? String : Number)(input);
         | 
| 496 | 
            -
            }
         | 
| 497 | 
            -
            function _toPropertyKey(arg) {
         | 
| 498 | 
            -
              var key = _toPrimitive(arg, "string");
         | 
| 499 | 
            -
              return typeof key === "symbol" ? key : String(key);
         | 
| 500 | 
            -
            }
         | 
| 501 | 
            -
             | 
| 502 33 | 
             
            /* eslint-disable valid-jsdoc */
         | 
| 503 34 | 
             
            // @ts-check
         | 
| 504 35 |  | 
| 505 | 
            -
             | 
| 36 | 
            +
            const TRANSPARENT_GIF = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7";
         | 
| 506 37 |  | 
| 507 38 | 
             
            /**
         | 
| 508 39 | 
             
             * Replace all text with emoji with an image html tag
         | 
| @@ -510,11 +41,11 @@ var TRANSPARENT_GIF = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAA | |
| 510 41 | 
             
             * @return {string}
         | 
| 511 42 | 
             
             */
         | 
| 512 43 | 
             
            function replaceAllTextEmojis(text) {
         | 
| 513 | 
            -
               | 
| 44 | 
            +
              let allEmojis = getAllEmojisFromText(text);
         | 
| 514 45 | 
             
              if (allEmojis) {
         | 
| 515 | 
            -
                allEmojis =  | 
| 46 | 
            +
                allEmojis = [...new Set(allEmojis)]; // remove duplicates
         | 
| 516 47 |  | 
| 517 | 
            -
                allEmojis.forEach( | 
| 48 | 
            +
                allEmojis.forEach(emoji => {
         | 
| 518 49 | 
             
                  text = replaceAll(text, emoji, getInputEmojiHTML('', emoji));
         | 
| 519 50 | 
             
                });
         | 
| 520 51 | 
             
              }
         | 
| @@ -550,18 +81,18 @@ function getAllEmojisFromText(text) { | |
| 550 81 | 
             
            function getImageEmoji(emoji) {
         | 
| 551 82 | 
             
              var _emojiPickerEl$shadow;
         | 
| 552 83 | 
             
              /** @type {HTMLElement | null} */
         | 
| 553 | 
            -
               | 
| 84 | 
            +
              const emojiPickerEl = document.querySelector('em-emoji-picker');
         | 
| 554 85 | 
             
              if (!emojiPickerEl) {
         | 
| 555 | 
            -
                return getInputEmojiNativeHTML(emoji | 
| 86 | 
            +
                return getInputEmojiNativeHTML(emoji.native);
         | 
| 556 87 | 
             
              }
         | 
| 557 88 |  | 
| 558 89 | 
             
              /** @type {HTMLSpanElement | null=} */
         | 
| 559 | 
            -
               | 
| 90 | 
            +
              const 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"));
         | 
| 560 91 | 
             
              if (!emojiSpanEl) {
         | 
| 561 | 
            -
                return getInputEmojiNativeHTML(emoji | 
| 92 | 
            +
                return getInputEmojiNativeHTML(emoji.native);
         | 
| 562 93 | 
             
              }
         | 
| 563 | 
            -
               | 
| 564 | 
            -
              return getInputEmojiHTML(style, emoji | 
| 94 | 
            +
              const style = replaceAll(emojiSpanEl.style.cssText, '"', "'");
         | 
| 95 | 
            +
              return getInputEmojiHTML(style, emoji.native);
         | 
| 565 96 | 
             
            }
         | 
| 566 97 |  | 
| 567 98 | 
             
            // eslint-disable-next-line valid-jsdoc
         | 
| @@ -590,10 +121,10 @@ function getInputEmojiNativeHTML(emoji) { | |
| 590 121 | 
             
             * @return {string}
         | 
| 591 122 | 
             
             */
         | 
| 592 123 | 
             
            function replaceAllTextEmojiToString(html) {
         | 
| 593 | 
            -
               | 
| 124 | 
            +
              const container = document.createElement("div");
         | 
| 594 125 | 
             
              container.innerHTML = html;
         | 
| 595 | 
            -
               | 
| 596 | 
            -
              images.forEach( | 
| 126 | 
            +
              const images = Array.prototype.slice.call(container.querySelectorAll("img"));
         | 
| 127 | 
            +
              images.forEach(image => {
         | 
| 597 128 | 
             
                container.innerHTML = container.innerHTML.replace(image.outerHTML, image.dataset.emoji);
         | 
| 598 129 | 
             
              });
         | 
| 599 130 | 
             
              return container.innerHTML;
         | 
| @@ -606,12 +137,12 @@ function replaceAllTextEmojiToString(html) { | |
| 606 137 | 
             
             * @param {React.ClipboardEvent} event
         | 
| 607 138 | 
             
             */
         | 
| 608 139 | 
             
            function handleCopy(event) {
         | 
| 609 | 
            -
               | 
| 140 | 
            +
              const selectedText = window.getSelection();
         | 
| 610 141 | 
             
              if (selectedText === null) {
         | 
| 611 142 | 
             
                return;
         | 
| 612 143 | 
             
              }
         | 
| 613 | 
            -
               | 
| 614 | 
            -
              for ( | 
| 144 | 
            +
              let container = document.createElement("div");
         | 
| 145 | 
            +
              for (let i = 0, len = selectedText.rangeCount; i < len; ++i) {
         | 
| 615 146 | 
             
                container.appendChild(selectedText.getRangeAt(i).cloneContents());
         | 
| 616 147 | 
             
              }
         | 
| 617 148 | 
             
              container = replaceEmojiToString(container);
         | 
| @@ -619,28 +150,42 @@ function handleCopy(event) { | |
| 619 150 | 
             
              event.preventDefault();
         | 
| 620 151 | 
             
            }
         | 
| 621 152 |  | 
| 153 | 
            +
            /** @type {Range|undefined} */
         | 
| 154 | 
            +
            /** @type {Range|undefined} */
         | 
| 155 | 
            +
            let currentRangeCached;
         | 
| 156 | 
            +
             | 
| 622 157 | 
             
            /**
         | 
| 623 | 
            -
             *
         | 
| 624 | 
            -
              | 
| 158 | 
            +
             * Caches the current text selection range
         | 
| 159 | 
            +
             */
         | 
| 160 | 
            +
            function cacheCurrentRange() {
         | 
| 161 | 
            +
              const selection = window.getSelection();
         | 
| 162 | 
            +
              if (!selection.rangeCount || (selection === null || selection === void 0 ? void 0 : selection.anchorNode['className']) !== 'react-input-emoji--input' && selection.anchorNode.parentNode['className'] !== 'react-input-emoji--input') return;
         | 
| 163 | 
            +
              const range = selection.getRangeAt(0);
         | 
| 164 | 
            +
              currentRangeCached = range.cloneRange();
         | 
| 165 | 
            +
            }
         | 
| 166 | 
            +
             | 
| 167 | 
            +
            /**
         | 
| 168 | 
            +
             * @param {string} html - HTML string to be pasted at the caret position
         | 
| 625 169 | 
             
             */
         | 
| 626 170 | 
             
            function handlePasteHtmlAtCaret(html) {
         | 
| 627 | 
            -
               | 
| 628 | 
            -
               | 
| 171 | 
            +
              let sel;
         | 
| 172 | 
            +
              let range;
         | 
| 629 173 | 
             
              if (window.getSelection) {
         | 
| 630 174 | 
             
                // IE9 and non-IE
         | 
| 631 175 | 
             
                sel = window.getSelection();
         | 
| 632 176 | 
             
                if (sel === null) return;
         | 
| 633 177 | 
             
                if (sel.getRangeAt && sel.rangeCount) {
         | 
| 634 | 
            -
                   | 
| 178 | 
            +
                  var _currentRangeCached;
         | 
| 179 | 
            +
                  range = (_currentRangeCached = currentRangeCached) !== null && _currentRangeCached !== void 0 ? _currentRangeCached : sel.getRangeAt(0);
         | 
| 635 180 | 
             
                  range.deleteContents();
         | 
| 636 181 |  | 
| 637 182 | 
             
                  // Range.createContextualFragment() would be useful here but is
         | 
| 638 183 | 
             
                  // non-standard and not supported in all browsers (IE9, for one)
         | 
| 639 | 
            -
                   | 
| 184 | 
            +
                  const el = document.createElement("div");
         | 
| 640 185 | 
             
                  el.innerHTML = html;
         | 
| 641 | 
            -
                   | 
| 642 | 
            -
                   | 
| 643 | 
            -
                   | 
| 186 | 
            +
                  const frag = document.createDocumentFragment();
         | 
| 187 | 
            +
                  let node;
         | 
| 188 | 
            +
                  let lastNode;
         | 
| 644 189 | 
             
                  while (node = el.firstChild) {
         | 
| 645 190 | 
             
                    lastNode = frag.appendChild(node);
         | 
| 646 191 | 
             
                  }
         | 
| @@ -649,6 +194,7 @@ function handlePasteHtmlAtCaret(html) { | |
| 649 194 | 
             
                  // Preserve the selection
         | 
| 650 195 | 
             
                  if (lastNode) {
         | 
| 651 196 | 
             
                    range = range.cloneRange();
         | 
| 197 | 
            +
                    currentRangeCached = range;
         | 
| 652 198 | 
             
                    range.setStartAfter(lastNode);
         | 
| 653 199 | 
             
                    range.collapse(true);
         | 
| 654 200 | 
             
                    sel.removeAllRanges();
         | 
| @@ -664,8 +210,8 @@ function handlePasteHtmlAtCaret(html) { | |
| 664 210 | 
             
             * @return {HTMLDivElement}
         | 
| 665 211 | 
             
             */
         | 
| 666 212 | 
             
            function replaceEmojiToString(container) {
         | 
| 667 | 
            -
               | 
| 668 | 
            -
              images.forEach( | 
| 213 | 
            +
              const images = Array.prototype.slice.call(container.querySelectorAll("img"));
         | 
| 214 | 
            +
              images.forEach(image => {
         | 
| 669 215 | 
             
                image.outerHTML = image.dataset.emoji;
         | 
| 670 216 | 
             
              });
         | 
| 671 217 | 
             
              return container;
         | 
| @@ -677,10 +223,12 @@ function replaceEmojiToString(container) { | |
| 677 223 | 
             
             * @return {number}
         | 
| 678 224 | 
             
             */
         | 
| 679 225 | 
             
            function totalCharacters(_ref2) {
         | 
| 680 | 
            -
               | 
| 681 | 
            -
                 | 
| 682 | 
            -
             | 
| 683 | 
            -
               | 
| 226 | 
            +
              let {
         | 
| 227 | 
            +
                text,
         | 
| 228 | 
            +
                html
         | 
| 229 | 
            +
              } = _ref2;
         | 
| 230 | 
            +
              const textCount = text.length;
         | 
| 231 | 
            +
              const emojisCount = (html.match(/<img/g) || []).length;
         | 
| 684 232 | 
             
              return textCount + emojisCount;
         | 
| 685 233 | 
             
            }
         | 
| 686 234 | 
             
            /**
         | 
| @@ -689,12 +237,12 @@ function totalCharacters(_ref2) { | |
| 689 237 | 
             
             * @return {string}
         | 
| 690 238 | 
             
             */
         | 
| 691 239 | 
             
            function removeHtmlExceptBr(inputDiv) {
         | 
| 692 | 
            -
               | 
| 693 | 
            -
               | 
| 240 | 
            +
              const temp = inputDiv.innerHTML.replaceAll(/<br\s*\/?>/gi, "[BR]"); // temporarily replace <br> with placeholder
         | 
| 241 | 
            +
              const tempContainer = document.createElement("div");
         | 
| 694 242 | 
             
              tempContainer.innerHTML = temp;
         | 
| 695 | 
            -
               | 
| 696 | 
            -
               | 
| 697 | 
            -
              return  | 
| 243 | 
            +
              const stripped = tempContainer.innerText; // strip all html tags
         | 
| 244 | 
            +
              const final = stripped.replaceAll(/\[BR\]/gi, "</br>"); // replace placeholders with <br>
         | 
| 245 | 
            +
              return final;
         | 
| 698 246 | 
             
            }
         | 
| 699 247 |  | 
| 700 248 | 
             
            /**
         | 
| @@ -703,8 +251,8 @@ function removeHtmlExceptBr(inputDiv) { | |
| 703 251 | 
             
             * @returns 
         | 
| 704 252 | 
             
             */
         | 
| 705 253 | 
             
            function getSelectionStart$1(range) {
         | 
| 706 | 
            -
               | 
| 707 | 
            -
               | 
| 254 | 
            +
              let node = range.startContainer;
         | 
| 255 | 
            +
              let offset = range.startOffset;
         | 
| 708 256 |  | 
| 709 257 | 
             
              // Handle cases where the selection start node is not a text node
         | 
| 710 258 | 
             
              if (node.nodeType !== Node.TEXT_NODE) {
         | 
| @@ -721,8 +269,8 @@ function getSelectionStart$1(range) { | |
| 721 269 | 
             
                offset = 0;
         | 
| 722 270 | 
             
              }
         | 
| 723 271 | 
             
              return {
         | 
| 724 | 
            -
                node | 
| 725 | 
            -
                offset | 
| 272 | 
            +
                node,
         | 
| 273 | 
            +
                offset
         | 
| 726 274 | 
             
              };
         | 
| 727 275 | 
             
            }
         | 
| 728 276 |  | 
| @@ -731,13 +279,13 @@ function getSelectionStart$1(range) { | |
| 731 279 | 
             
             * @return {Object} cursor
         | 
| 732 280 | 
             
             */
         | 
| 733 281 | 
             
            function getCursor() {
         | 
| 734 | 
            -
               | 
| 735 | 
            -
               | 
| 736 | 
            -
               | 
| 282 | 
            +
              const selection = window.getSelection();
         | 
| 283 | 
            +
              const range = selection.getRangeAt(0);
         | 
| 284 | 
            +
              const selectionStart = getSelectionStart$1(range);
         | 
| 737 285 | 
             
              return {
         | 
| 738 | 
            -
                selection | 
| 739 | 
            -
                range | 
| 740 | 
            -
                selectionStart | 
| 286 | 
            +
                selection,
         | 
| 287 | 
            +
                range,
         | 
| 288 | 
            +
                selectionStart
         | 
| 741 289 | 
             
              };
         | 
| 742 290 | 
             
            }
         | 
| 743 291 |  | 
| @@ -745,30 +293,31 @@ function getCursor() { | |
| 745 293 | 
             
             *
         | 
| 746 294 | 
             
             */
         | 
| 747 295 | 
             
            function addLineBreak() {
         | 
| 748 | 
            -
               | 
| 749 | 
            -
                selection | 
| 750 | 
            -
                range | 
| 751 | 
            -
                selectionStart | 
| 296 | 
            +
              const {
         | 
| 297 | 
            +
                selection,
         | 
| 298 | 
            +
                range,
         | 
| 299 | 
            +
                selectionStart
         | 
| 300 | 
            +
              } = getCursor();
         | 
| 752 301 |  | 
| 753 302 | 
             
              // If cursor is at the end of the text content, add one more line break
         | 
| 754 303 | 
             
              if (selection.isCollapsed && selectionStart.offset === selectionStart.node.textContent.length) {
         | 
| 755 | 
            -
                 | 
| 304 | 
            +
                const br = document.createElement("br");
         | 
| 756 305 | 
             
                range.insertNode(br);
         | 
| 757 306 | 
             
                range.setStartAfter(br);
         | 
| 758 307 | 
             
                range.setEndAfter(br);
         | 
| 759 308 | 
             
                selection.removeAllRanges();
         | 
| 760 309 | 
             
                selection.addRange(range);
         | 
| 761 | 
            -
                 | 
| 310 | 
            +
                const br2 = document.createElement("br");
         | 
| 762 311 | 
             
                range.insertNode(br2);
         | 
| 763 312 | 
             
                range.setStartAfter(br2);
         | 
| 764 313 | 
             
                range.setEndAfter(br2);
         | 
| 765 314 | 
             
                selection.removeAllRanges();
         | 
| 766 315 | 
             
                selection.addRange(range);
         | 
| 767 316 | 
             
              } else {
         | 
| 768 | 
            -
                 | 
| 769 | 
            -
                range.insertNode( | 
| 770 | 
            -
                range.setStartAfter( | 
| 771 | 
            -
                range.setEndAfter( | 
| 317 | 
            +
                const br = document.createElement("br");
         | 
| 318 | 
            +
                range.insertNode(br);
         | 
| 319 | 
            +
                range.setStartAfter(br);
         | 
| 320 | 
            +
                range.setEndAfter(br);
         | 
| 772 321 | 
             
                selection.removeAllRanges();
         | 
| 773 322 | 
             
                selection.addRange(range);
         | 
| 774 323 | 
             
                // Set cursor position right before the first letter after the line break
         | 
| @@ -987,7 +536,7 @@ var reactEasyEmoji = function reactEasyEmoji(element, optionsOrFn) { | |
| 987 536 | 
             
            var emoji = reactEasyEmoji;
         | 
| 988 537 |  | 
| 989 538 | 
             
            // @ts-check
         | 
| 990 | 
            -
             | 
| 539 | 
            +
            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);
         | 
| 991 540 |  | 
| 992 541 | 
             
            /**
         | 
| 993 542 | 
             
             * @typedef {import('../types/types').SanitizeFn} SanitizeFn
         | 
| @@ -1000,17 +549,17 @@ var EMOJI_REGEX = new RegExp(/(?:[\u2700-\u27bf]|(?:\ud83c[\udde6-\uddff]){2}|[\ | |
| 1000 549 | 
             
             */
         | 
| 1001 550 | 
             
            function useSanitize(shouldReturn, shouldConvertEmojiToImage) {
         | 
| 1002 551 | 
             
              /** @type {React.MutableRefObject<SanitizeFn[]>} */
         | 
| 1003 | 
            -
               | 
| 1004 | 
            -
               | 
| 552 | 
            +
              const sanitizeFnsRef = useRef([]);
         | 
| 553 | 
            +
              const sanitizedTextRef = useRef("");
         | 
| 1005 554 |  | 
| 1006 555 | 
             
              /** @type {(fn: SanitizeFn) => void} */
         | 
| 1007 | 
            -
               | 
| 556 | 
            +
              const addSanitizeFn = useCallback(fn => {
         | 
| 1008 557 | 
             
                sanitizeFnsRef.current.push(fn);
         | 
| 1009 558 | 
             
              }, []);
         | 
| 1010 559 |  | 
| 1011 560 | 
             
              /** @type {(html: string) => string} */
         | 
| 1012 | 
            -
               | 
| 1013 | 
            -
                 | 
| 561 | 
            +
              const sanitize = useCallback(html => {
         | 
| 562 | 
            +
                let result = sanitizeFnsRef.current.reduce((acc, fn) => {
         | 
| 1014 563 | 
             
                  return fn(acc);
         | 
| 1015 564 | 
             
                }, html);
         | 
| 1016 565 | 
             
                result = replaceAllHtmlToString(result, shouldReturn);
         | 
| @@ -1021,9 +570,9 @@ function useSanitize(shouldReturn, shouldConvertEmojiToImage) { | |
| 1021 570 | 
             
                return result;
         | 
| 1022 571 | 
             
              }, [shouldReturn, shouldConvertEmojiToImage]);
         | 
| 1023 572 | 
             
              return {
         | 
| 1024 | 
            -
                addSanitizeFn | 
| 1025 | 
            -
                sanitize | 
| 1026 | 
            -
                sanitizedTextRef | 
| 573 | 
            +
                addSanitizeFn,
         | 
| 574 | 
            +
                sanitize,
         | 
| 575 | 
            +
                sanitizedTextRef
         | 
| 1027 576 | 
             
              };
         | 
| 1028 577 | 
             
            }
         | 
| 1029 578 |  | 
| @@ -1034,9 +583,9 @@ function useSanitize(shouldReturn, shouldConvertEmojiToImage) { | |
| 1034 583 | 
             
             * @return {string}
         | 
| 1035 584 | 
             
             */
         | 
| 1036 585 | 
             
            function replaceAllHtmlToString(html, shouldReturn) {
         | 
| 1037 | 
            -
               | 
| 586 | 
            +
              const container = document.createElement("div");
         | 
| 1038 587 | 
             
              container.innerHTML = html;
         | 
| 1039 | 
            -
               | 
| 588 | 
            +
              let text;
         | 
| 1040 589 | 
             
              if (shouldReturn) {
         | 
| 1041 590 | 
             
                text = removeHtmlExceptBr(container);
         | 
| 1042 591 | 
             
              } else {
         | 
| @@ -1086,34 +635,35 @@ function handleEmoji(text) { | |
| 1086 635 | 
             
             * @param {Props} props
         | 
| 1087 636 | 
             
             */
         | 
| 1088 637 | 
             
            function useExpose(_ref) {
         | 
| 1089 | 
            -
               | 
| 1090 | 
            -
                 | 
| 1091 | 
            -
                 | 
| 1092 | 
            -
                 | 
| 1093 | 
            -
                 | 
| 1094 | 
            -
             | 
| 1095 | 
            -
             | 
| 1096 | 
            -
             | 
| 1097 | 
            -
             | 
| 1098 | 
            -
                 | 
| 1099 | 
            -
             | 
| 1100 | 
            -
             | 
| 1101 | 
            -
             | 
| 1102 | 
            -
                   | 
| 1103 | 
            -
             | 
| 1104 | 
            -
             | 
| 1105 | 
            -
                   | 
| 1106 | 
            -
             | 
| 1107 | 
            -
             | 
| 1108 | 
            -
                   | 
| 1109 | 
            -
                   | 
| 1110 | 
            -
             | 
| 1111 | 
            -
             | 
| 1112 | 
            -
             | 
| 1113 | 
            -
                     | 
| 638 | 
            +
              let {
         | 
| 639 | 
            +
                ref,
         | 
| 640 | 
            +
                textInputRef,
         | 
| 641 | 
            +
                setValue,
         | 
| 642 | 
            +
                emitChange,
         | 
| 643 | 
            +
                shouldConvertEmojiToImage
         | 
| 644 | 
            +
              } = _ref;
         | 
| 645 | 
            +
              const {
         | 
| 646 | 
            +
                sanitize,
         | 
| 647 | 
            +
                sanitizedTextRef
         | 
| 648 | 
            +
              } = useSanitize(false, shouldConvertEmojiToImage);
         | 
| 649 | 
            +
              useImperativeHandle(ref, () => ({
         | 
| 650 | 
            +
                get value() {
         | 
| 651 | 
            +
                  return sanitizedTextRef.current;
         | 
| 652 | 
            +
                },
         | 
| 653 | 
            +
                set value(value) {
         | 
| 654 | 
            +
                  setValue(value);
         | 
| 655 | 
            +
                },
         | 
| 656 | 
            +
                focus: () => {
         | 
| 657 | 
            +
                  if (textInputRef.current === null) return;
         | 
| 658 | 
            +
                  textInputRef.current.focus();
         | 
| 659 | 
            +
                },
         | 
| 660 | 
            +
                blur: () => {
         | 
| 661 | 
            +
                  if (textInputRef.current !== null) {
         | 
| 662 | 
            +
                    sanitize(textInputRef.current.html);
         | 
| 1114 663 | 
             
                  }
         | 
| 1115 | 
            -
             | 
| 1116 | 
            -
             | 
| 664 | 
            +
                  emitChange();
         | 
| 665 | 
            +
                }
         | 
| 666 | 
            +
              }));
         | 
| 1117 667 | 
             
            }
         | 
| 1118 668 |  | 
| 1119 669 | 
             
            // @ts-check
         | 
| @@ -1127,19 +677,19 @@ function useExpose(_ref) { | |
| 1127 677 | 
             
             */
         | 
| 1128 678 | 
             
            function useEmit(textInputRef, onResize, onChange) {
         | 
| 1129 679 | 
             
              /** @type {React.MutableRefObject<{width: number; height: number} | null>} */
         | 
| 1130 | 
            -
               | 
| 1131 | 
            -
               | 
| 1132 | 
            -
               | 
| 680 | 
            +
              const currentSizeRef = useRef(null);
         | 
| 681 | 
            +
              const onChangeFn = useRef(onChange);
         | 
| 682 | 
            +
              const checkAndEmitResize = useCallback(() => {
         | 
| 1133 683 | 
             
                if (textInputRef.current !== null) {
         | 
| 1134 | 
            -
                   | 
| 1135 | 
            -
                   | 
| 684 | 
            +
                  const currentSize = currentSizeRef.current;
         | 
| 685 | 
            +
                  const nextSize = textInputRef.current.size;
         | 
| 1136 686 | 
             
                  if ((!currentSize || currentSize.width !== nextSize.width || currentSize.height !== nextSize.height) && typeof onResize === "function") {
         | 
| 1137 687 | 
             
                    onResize(nextSize);
         | 
| 1138 688 | 
             
                  }
         | 
| 1139 689 | 
             
                  currentSizeRef.current = nextSize;
         | 
| 1140 690 | 
             
                }
         | 
| 1141 691 | 
             
              }, [onResize, textInputRef]);
         | 
| 1142 | 
            -
               | 
| 692 | 
            +
              const emitChange = useCallback(sanitizedText => {
         | 
| 1143 693 | 
             
                if (typeof onChangeFn.current === "function") {
         | 
| 1144 694 | 
             
                  onChangeFn.current(sanitizedText);
         | 
| 1145 695 | 
             
                }
         | 
| @@ -1147,7 +697,7 @@ function useEmit(textInputRef, onResize, onChange) { | |
| 1147 697 | 
             
                  checkAndEmitResize();
         | 
| 1148 698 | 
             
                }
         | 
| 1149 699 | 
             
              }, [checkAndEmitResize, onResize]);
         | 
| 1150 | 
            -
              useEffect( | 
| 700 | 
            +
              useEffect(() => {
         | 
| 1151 701 | 
             
                if (textInputRef.current) {
         | 
| 1152 702 | 
             
                  checkAndEmitResize();
         | 
| 1153 703 | 
             
                }
         | 
| @@ -1155,7 +705,84 @@ function useEmit(textInputRef, onResize, onChange) { | |
| 1155 705 | 
             
              return emitChange;
         | 
| 1156 706 | 
             
            }
         | 
| 1157 707 |  | 
| 1158 | 
            -
             | 
| 708 | 
            +
            function ownKeys(e, r) {
         | 
| 709 | 
            +
              var t = Object.keys(e);
         | 
| 710 | 
            +
              if (Object.getOwnPropertySymbols) {
         | 
| 711 | 
            +
                var o = Object.getOwnPropertySymbols(e);
         | 
| 712 | 
            +
                r && (o = o.filter(function (r) {
         | 
| 713 | 
            +
                  return Object.getOwnPropertyDescriptor(e, r).enumerable;
         | 
| 714 | 
            +
                })), t.push.apply(t, o);
         | 
| 715 | 
            +
              }
         | 
| 716 | 
            +
              return t;
         | 
| 717 | 
            +
            }
         | 
| 718 | 
            +
            function _objectSpread2(e) {
         | 
| 719 | 
            +
              for (var r = 1; r < arguments.length; r++) {
         | 
| 720 | 
            +
                var t = null != arguments[r] ? arguments[r] : {};
         | 
| 721 | 
            +
                r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {
         | 
| 722 | 
            +
                  _defineProperty(e, r, t[r]);
         | 
| 723 | 
            +
                }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {
         | 
| 724 | 
            +
                  Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));
         | 
| 725 | 
            +
                });
         | 
| 726 | 
            +
              }
         | 
| 727 | 
            +
              return e;
         | 
| 728 | 
            +
            }
         | 
| 729 | 
            +
            function _defineProperty(obj, key, value) {
         | 
| 730 | 
            +
              key = _toPropertyKey(key);
         | 
| 731 | 
            +
              if (key in obj) {
         | 
| 732 | 
            +
                Object.defineProperty(obj, key, {
         | 
| 733 | 
            +
                  value: value,
         | 
| 734 | 
            +
                  enumerable: true,
         | 
| 735 | 
            +
                  configurable: true,
         | 
| 736 | 
            +
                  writable: true
         | 
| 737 | 
            +
                });
         | 
| 738 | 
            +
              } else {
         | 
| 739 | 
            +
                obj[key] = value;
         | 
| 740 | 
            +
              }
         | 
| 741 | 
            +
              return obj;
         | 
| 742 | 
            +
            }
         | 
| 743 | 
            +
            function _objectWithoutPropertiesLoose(source, excluded) {
         | 
| 744 | 
            +
              if (source == null) return {};
         | 
| 745 | 
            +
              var target = {};
         | 
| 746 | 
            +
              var sourceKeys = Object.keys(source);
         | 
| 747 | 
            +
              var key, i;
         | 
| 748 | 
            +
              for (i = 0; i < sourceKeys.length; i++) {
         | 
| 749 | 
            +
                key = sourceKeys[i];
         | 
| 750 | 
            +
                if (excluded.indexOf(key) >= 0) continue;
         | 
| 751 | 
            +
                target[key] = source[key];
         | 
| 752 | 
            +
              }
         | 
| 753 | 
            +
              return target;
         | 
| 754 | 
            +
            }
         | 
| 755 | 
            +
            function _objectWithoutProperties(source, excluded) {
         | 
| 756 | 
            +
              if (source == null) return {};
         | 
| 757 | 
            +
              var target = _objectWithoutPropertiesLoose(source, excluded);
         | 
| 758 | 
            +
              var key, i;
         | 
| 759 | 
            +
              if (Object.getOwnPropertySymbols) {
         | 
| 760 | 
            +
                var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
         | 
| 761 | 
            +
                for (i = 0; i < sourceSymbolKeys.length; i++) {
         | 
| 762 | 
            +
                  key = sourceSymbolKeys[i];
         | 
| 763 | 
            +
                  if (excluded.indexOf(key) >= 0) continue;
         | 
| 764 | 
            +
                  if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
         | 
| 765 | 
            +
                  target[key] = source[key];
         | 
| 766 | 
            +
                }
         | 
| 767 | 
            +
              }
         | 
| 768 | 
            +
              return target;
         | 
| 769 | 
            +
            }
         | 
| 770 | 
            +
            function _toPrimitive(input, hint) {
         | 
| 771 | 
            +
              if (typeof input !== "object" || input === null) return input;
         | 
| 772 | 
            +
              var prim = input[Symbol.toPrimitive];
         | 
| 773 | 
            +
              if (prim !== undefined) {
         | 
| 774 | 
            +
                var res = prim.call(input, hint || "default");
         | 
| 775 | 
            +
                if (typeof res !== "object") return res;
         | 
| 776 | 
            +
                throw new TypeError("@@toPrimitive must return a primitive value.");
         | 
| 777 | 
            +
              }
         | 
| 778 | 
            +
              return (hint === "string" ? String : Number)(input);
         | 
| 779 | 
            +
            }
         | 
| 780 | 
            +
            function _toPropertyKey(arg) {
         | 
| 781 | 
            +
              var key = _toPrimitive(arg, "string");
         | 
| 782 | 
            +
              return typeof key === "symbol" ? key : String(key);
         | 
| 783 | 
            +
            }
         | 
| 784 | 
            +
             | 
| 785 | 
            +
            const _excluded = ["placeholder", "style", "tabIndex", "className", "onChange"];
         | 
| 1159 786 |  | 
| 1160 787 | 
             
            /**
         | 
| 1161 788 | 
             
             * @typedef {Object} Props
         | 
| @@ -1189,78 +816,78 @@ var _excluded = ["placeholder", "style", "tabIndex", "className", "onChange"]; | |
| 1189 816 |  | 
| 1190 817 | 
             
            // eslint-disable-next-line valid-jsdoc
         | 
| 1191 818 | 
             
            /** @type {React.ForwardRefRenderFunction<Ref, Props>} */
         | 
| 1192 | 
            -
             | 
| 1193 | 
            -
               | 
| 1194 | 
            -
             | 
| 1195 | 
            -
             | 
| 1196 | 
            -
             | 
| 1197 | 
            -
             | 
| 819 | 
            +
            const TextInput = (_ref, ref) => {
         | 
| 820 | 
            +
              let {
         | 
| 821 | 
            +
                  placeholder,
         | 
| 822 | 
            +
                  style,
         | 
| 823 | 
            +
                  tabIndex,
         | 
| 824 | 
            +
                  className,
         | 
| 825 | 
            +
                  onChange
         | 
| 826 | 
            +
                } = _ref,
         | 
| 1198 827 | 
             
                props = _objectWithoutProperties(_ref, _excluded);
         | 
| 1199 | 
            -
              useImperativeHandle(ref,  | 
| 1200 | 
            -
                 | 
| 1201 | 
            -
                   | 
| 1202 | 
            -
                     | 
| 1203 | 
            -
             | 
| 1204 | 
            -
             | 
| 1205 | 
            -
             | 
| 1206 | 
            -
                     | 
| 1207 | 
            -
             | 
| 1208 | 
            -
             | 
| 1209 | 
            -
                     | 
| 828 | 
            +
              useImperativeHandle(ref, () => ({
         | 
| 829 | 
            +
                appendContent: html => {
         | 
| 830 | 
            +
                  if (textInputRef.current) {
         | 
| 831 | 
            +
                    textInputRef.current.focus();
         | 
| 832 | 
            +
                  }
         | 
| 833 | 
            +
                  handlePasteHtmlAtCaret(html);
         | 
| 834 | 
            +
                  if (textInputRef.current) {
         | 
| 835 | 
            +
                    textInputRef.current.focus();
         | 
| 836 | 
            +
                  }
         | 
| 837 | 
            +
                  if (textInputRef.current && placeholderRef.current && replaceAllTextEmojiToString(textInputRef.current.innerHTML) === "") {
         | 
| 838 | 
            +
                    placeholderRef.current.style.visibility = "visible";
         | 
| 839 | 
            +
                  } else if (placeholderRef.current) {
         | 
| 840 | 
            +
                    placeholderRef.current.style.visibility = "hidden";
         | 
| 841 | 
            +
                  }
         | 
| 842 | 
            +
                  if (textInputRef.current && typeof onChange === 'function') {
         | 
| 843 | 
            +
                    onChange(textInputRef.current.innerHTML);
         | 
| 844 | 
            +
                  }
         | 
| 845 | 
            +
                },
         | 
| 846 | 
            +
                set html(value) {
         | 
| 847 | 
            +
                  if (textInputRef.current) {
         | 
| 848 | 
            +
                    textInputRef.current.innerHTML = value;
         | 
| 849 | 
            +
                  }
         | 
| 850 | 
            +
                  if (placeholderRef.current) {
         | 
| 851 | 
            +
                    const text = replaceAllTextEmojiToString(value);
         | 
| 852 | 
            +
                    if (text === "") {
         | 
| 1210 853 | 
             
                      placeholderRef.current.style.visibility = "visible";
         | 
| 1211 | 
            -
                    } else  | 
| 854 | 
            +
                    } else {
         | 
| 1212 855 | 
             
                      placeholderRef.current.style.visibility = "hidden";
         | 
| 1213 856 | 
             
                    }
         | 
| 1214 | 
            -
             | 
| 1215 | 
            -
             | 
| 1216 | 
            -
                     | 
| 1217 | 
            -
                  } | 
| 1218 | 
            -
             | 
| 1219 | 
            -
             | 
| 1220 | 
            -
             | 
| 1221 | 
            -
             | 
| 1222 | 
            -
             | 
| 1223 | 
            -
             | 
| 1224 | 
            -
             | 
| 1225 | 
            -
             | 
| 1226 | 
            -
             | 
| 1227 | 
            -
             | 
| 1228 | 
            -
             | 
| 1229 | 
            -
                    }
         | 
| 1230 | 
            -
                    if (typeof onChange === 'function' && textInputRef.current) {
         | 
| 1231 | 
            -
                      onChange(textInputRef.current.innerHTML);
         | 
| 1232 | 
            -
                    }
         | 
| 1233 | 
            -
                  },
         | 
| 1234 | 
            -
                  get html() {
         | 
| 1235 | 
            -
                    if (!textInputRef.current) return '';
         | 
| 1236 | 
            -
                    return textInputRef.current.innerHTML;
         | 
| 1237 | 
            -
                  },
         | 
| 1238 | 
            -
                  get text() {
         | 
| 1239 | 
            -
                    if (!textInputRef.current) return '';
         | 
| 1240 | 
            -
                    return textInputRef.current.innerText;
         | 
| 1241 | 
            -
                  },
         | 
| 1242 | 
            -
                  get size() {
         | 
| 1243 | 
            -
                    if (!textInputRef.current) {
         | 
| 1244 | 
            -
                      return {
         | 
| 1245 | 
            -
                        width: 0,
         | 
| 1246 | 
            -
                        height: 0
         | 
| 1247 | 
            -
                      };
         | 
| 1248 | 
            -
                    }
         | 
| 857 | 
            +
                  }
         | 
| 858 | 
            +
                  if (typeof onChange === 'function' && textInputRef.current) {
         | 
| 859 | 
            +
                    onChange(textInputRef.current.innerHTML);
         | 
| 860 | 
            +
                  }
         | 
| 861 | 
            +
                },
         | 
| 862 | 
            +
                get html() {
         | 
| 863 | 
            +
                  if (!textInputRef.current) return '';
         | 
| 864 | 
            +
                  return textInputRef.current.innerHTML;
         | 
| 865 | 
            +
                },
         | 
| 866 | 
            +
                get text() {
         | 
| 867 | 
            +
                  if (!textInputRef.current) return '';
         | 
| 868 | 
            +
                  return textInputRef.current.innerText;
         | 
| 869 | 
            +
                },
         | 
| 870 | 
            +
                get size() {
         | 
| 871 | 
            +
                  if (!textInputRef.current) {
         | 
| 1249 872 | 
             
                    return {
         | 
| 1250 | 
            -
                      width:  | 
| 1251 | 
            -
                      height:  | 
| 873 | 
            +
                      width: 0,
         | 
| 874 | 
            +
                      height: 0
         | 
| 1252 875 | 
             
                    };
         | 
| 1253 | 
            -
                  },
         | 
| 1254 | 
            -
                  focus: function focus() {
         | 
| 1255 | 
            -
                    if (!textInputRef.current) return;
         | 
| 1256 | 
            -
                    textInputRef.current.focus();
         | 
| 1257 876 | 
             
                  }
         | 
| 1258 | 
            -
             | 
| 1259 | 
            -
             | 
| 877 | 
            +
                  return {
         | 
| 878 | 
            +
                    width: textInputRef.current.offsetWidth,
         | 
| 879 | 
            +
                    height: textInputRef.current.offsetHeight
         | 
| 880 | 
            +
                  };
         | 
| 881 | 
            +
                },
         | 
| 882 | 
            +
                focus() {
         | 
| 883 | 
            +
                  if (!textInputRef.current) return;
         | 
| 884 | 
            +
                  textInputRef.current.focus();
         | 
| 885 | 
            +
                }
         | 
| 886 | 
            +
              }));
         | 
| 1260 887 |  | 
| 1261 888 | 
             
              /** @type {React.CSSProperties} */
         | 
| 1262 | 
            -
               | 
| 1263 | 
            -
                 | 
| 889 | 
            +
              const placeholderStyle = useMemo(() => {
         | 
| 890 | 
            +
                const placeholderStyle = {};
         | 
| 1264 891 | 
             
                if (style.placeholderColor) {
         | 
| 1265 892 | 
             
                  placeholderStyle.color = style.placeholderColor;
         | 
| 1266 893 | 
             
                }
         | 
| @@ -1268,8 +895,8 @@ var TextInput = function TextInput(_ref, ref) { | |
| 1268 895 | 
             
              }, [style === null || style === void 0 ? void 0 : style.placeholderColor]);
         | 
| 1269 896 |  | 
| 1270 897 | 
             
              /** @type {React.CSSProperties} */
         | 
| 1271 | 
            -
               | 
| 1272 | 
            -
                 | 
| 898 | 
            +
              const inputStyle = useMemo(() => {
         | 
| 899 | 
            +
                const inputStyle = {};
         | 
| 1273 900 | 
             
                if (style.color) {
         | 
| 1274 901 | 
             
                  inputStyle.color = style.color;
         | 
| 1275 902 | 
             
                }
         | 
| @@ -1277,9 +904,9 @@ var TextInput = function TextInput(_ref, ref) { | |
| 1277 904 | 
             
              }, [style === null || style === void 0 ? void 0 : style.color]);
         | 
| 1278 905 |  | 
| 1279 906 | 
             
              /** @type {React.MutableRefObject<HTMLDivElement | null>} */
         | 
| 1280 | 
            -
               | 
| 907 | 
            +
              const placeholderRef = useRef(null);
         | 
| 1281 908 | 
             
              /** @type {React.MutableRefObject<HTMLDivElement | null>} */
         | 
| 1282 | 
            -
               | 
| 909 | 
            +
              const textInputRef = useRef(null);
         | 
| 1283 910 |  | 
| 1284 911 | 
             
              /**
         | 
| 1285 912 | 
             
               *
         | 
| @@ -1318,9 +945,9 @@ var TextInput = function TextInput(_ref, ref) { | |
| 1318 945 | 
             
               */
         | 
| 1319 946 | 
             
              function handleKeyUp(event) {
         | 
| 1320 947 | 
             
                props.onKeyUp(event);
         | 
| 1321 | 
            -
                 | 
| 948 | 
            +
                const input = textInputRef.current;
         | 
| 1322 949 | 
             
                if (placeholderRef.current && input) {
         | 
| 1323 | 
            -
                   | 
| 950 | 
            +
                  const text = replaceAllTextEmojiToString(input.innerHTML);
         | 
| 1324 951 | 
             
                  if (text === "") {
         | 
| 1325 952 | 
             
                    placeholderRef.current.style.visibility = "visible";
         | 
| 1326 953 | 
             
                  } else {
         | 
| @@ -1355,7 +982,9 @@ var TextInput = function TextInput(_ref, ref) { | |
| 1355 982 | 
             
                style: inputStyle
         | 
| 1356 983 | 
             
              })));
         | 
| 1357 984 | 
             
            };
         | 
| 1358 | 
            -
             | 
| 985 | 
            +
            const TextInputWithRef = /*#__PURE__*/forwardRef(TextInput);
         | 
| 986 | 
            +
             | 
| 987 | 
            +
            // vendors
         | 
| 1359 988 |  | 
| 1360 989 | 
             
            /**
         | 
| 1361 990 | 
             
             * @typedef {object} Props
         | 
| @@ -1371,16 +1000,15 @@ var TextInputWithRef = /*#__PURE__*/forwardRef(TextInput); | |
| 1371 1000 | 
             
             * @return {JSX.Element}
         | 
| 1372 1001 | 
             
             */
         | 
| 1373 1002 | 
             
            function EmojiPickerButton(_ref) {
         | 
| 1374 | 
            -
               | 
| 1375 | 
            -
                 | 
| 1376 | 
            -
                 | 
| 1377 | 
            -
                 | 
| 1378 | 
            -
             | 
| 1379 | 
            -
               | 
| 1380 | 
            -
             | 
| 1381 | 
            -
             | 
| 1382 | 
            -
             | 
| 1383 | 
            -
              useEffect(function () {
         | 
| 1003 | 
            +
              let {
         | 
| 1004 | 
            +
                showPicker,
         | 
| 1005 | 
            +
                toggleShowPicker,
         | 
| 1006 | 
            +
                buttonElement,
         | 
| 1007 | 
            +
                buttonRef
         | 
| 1008 | 
            +
              } = _ref;
         | 
| 1009 | 
            +
              const localButtonRef = useRef(null);
         | 
| 1010 | 
            +
              const [showCustomButtonContent, setShowCustomButtonContent] = useState(false);
         | 
| 1011 | 
            +
              useEffect(() => {
         | 
| 1384 1012 | 
             
                var _buttonRef$current$ch, _buttonRef$current, _buttonElement$childN, _buttonElement$childN2;
         | 
| 1385 1013 | 
             
                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) {
         | 
| 1386 1014 | 
             
                  localButtonRef.current.appendChild(buttonRef.current.childNodes[0]);
         | 
| @@ -3845,8 +3473,9 @@ function $e5534fc185f7111e$export$2e2bcd8739ae039(props) { | |
| 3845 3473 | 
             
              });
         | 
| 3846 3474 | 
             
            }
         | 
| 3847 3475 |  | 
| 3848 | 
            -
             | 
| 3849 | 
            -
             | 
| 3476 | 
            +
            // vendors
         | 
| 3477 | 
            +
            const EMOJI_MART_DATA_URL = "https://cdn.jsdelivr.net/npm/@emoji-mart/data";
         | 
| 3478 | 
            +
            const cacheI18n = {};
         | 
| 3850 3479 |  | 
| 3851 3480 | 
             
            /**
         | 
| 3852 3481 | 
             
             * @typedef {object} Props
         | 
| @@ -3862,55 +3491,38 @@ var cacheI18n = {}; | |
| 3862 3491 | 
             
             * @param {Props} props
         | 
| 3863 3492 | 
             
             */
         | 
| 3864 3493 | 
             
            function EmojiPicker(props) {
         | 
| 3865 | 
            -
               | 
| 3866 | 
            -
                 | 
| 3867 | 
            -
                 | 
| 3868 | 
            -
                 | 
| 3869 | 
            -
                 | 
| 3494 | 
            +
              const {
         | 
| 3495 | 
            +
                theme,
         | 
| 3496 | 
            +
                onSelectEmoji,
         | 
| 3497 | 
            +
                disableRecent,
         | 
| 3498 | 
            +
                customEmojis,
         | 
| 3499 | 
            +
                language
         | 
| 3500 | 
            +
              } = props;
         | 
| 3870 3501 |  | 
| 3871 3502 | 
             
              /** @type {string[]} */
         | 
| 3872 | 
            -
               | 
| 3503 | 
            +
              const categories = useMemo(() => {
         | 
| 3873 3504 | 
             
                /** @type {string[]} */
         | 
| 3874 | 
            -
                 | 
| 3505 | 
            +
                let categoryies = [];
         | 
| 3875 3506 | 
             
                if (!disableRecent) {
         | 
| 3876 3507 | 
             
                  categoryies.push("frequent");
         | 
| 3877 3508 | 
             
                }
         | 
| 3878 | 
            -
                categoryies = [ | 
| 3509 | 
            +
                categoryies = [...categoryies, "people", "nature", "foods", "activity", "places", "objects", "symbols", "flags"];
         | 
| 3879 3510 | 
             
                return categoryies;
         | 
| 3880 3511 | 
             
              }, [disableRecent]);
         | 
| 3881 | 
            -
               | 
| 3882 | 
            -
             | 
| 3883 | 
            -
                i18n = _useState2[0],
         | 
| 3884 | 
            -
                setI18n = _useState2[1];
         | 
| 3885 | 
            -
              useEffect(function () {
         | 
| 3886 | 
            -
                var _ref2;
         | 
| 3512 | 
            +
              const [i18n, setI18n] = useState(undefined);
         | 
| 3513 | 
            +
              useEffect(() => {
         | 
| 3887 3514 | 
             
                if (!language) {
         | 
| 3888 | 
            -
                  var _ref;
         | 
| 3889 3515 | 
             
                  if (cacheI18n.en) {
         | 
| 3890 3516 | 
             
                    setI18n(cacheI18n.en);
         | 
| 3891 3517 | 
             
                    return;
         | 
| 3892 3518 | 
             
                  }
         | 
| 3893 3519 |  | 
| 3894 3520 | 
             
                  // @ts-ignore
         | 
| 3895 | 
            -
                  fetch("".concat(EMOJI_MART_DATA_URL, "/i18n/en.json")).then( | 
| 3896 | 
            -
                     | 
| 3897 | 
            -
             | 
| 3898 | 
            -
             | 
| 3899 | 
            -
             | 
| 3900 | 
            -
                          case 0:
         | 
| 3901 | 
            -
                            _context.next = 2;
         | 
| 3902 | 
            -
                            return data.json();
         | 
| 3903 | 
            -
                          case 2:
         | 
| 3904 | 
            -
                            translations = _context.sent;
         | 
| 3905 | 
            -
                            setI18n(translations);
         | 
| 3906 | 
            -
                            cacheI18n.en = translations;
         | 
| 3907 | 
            -
                          case 5:
         | 
| 3908 | 
            -
                          case "end":
         | 
| 3909 | 
            -
                            return _context.stop();
         | 
| 3910 | 
            -
                        }
         | 
| 3911 | 
            -
                      }, _callee);
         | 
| 3912 | 
            -
                    }))).apply(this, arguments);
         | 
| 3913 | 
            -
                  })["catch"](function (error) {
         | 
| 3521 | 
            +
                  fetch("".concat(EMOJI_MART_DATA_URL, "/i18n/en.json")).then(async data => {
         | 
| 3522 | 
            +
                    const translations = await data.json();
         | 
| 3523 | 
            +
                    setI18n(translations);
         | 
| 3524 | 
            +
                    cacheI18n.en = translations;
         | 
| 3525 | 
            +
                  }).catch(error => {
         | 
| 3914 3526 | 
             
                    console.error("Failed to load translations:", error);
         | 
| 3915 3527 | 
             
                  });
         | 
| 3916 3528 | 
             
                  return;
         | 
| @@ -3921,25 +3533,11 @@ function EmojiPicker(props) { | |
| 3921 3533 | 
             
                }
         | 
| 3922 3534 |  | 
| 3923 3535 | 
             
                // @ts-ignore
         | 
| 3924 | 
            -
                fetch("".concat(EMOJI_MART_DATA_URL, "/i18n/").concat(language, ".json")).then( | 
| 3925 | 
            -
                   | 
| 3926 | 
            -
             | 
| 3927 | 
            -
             | 
| 3928 | 
            -
             | 
| 3929 | 
            -
                        case 0:
         | 
| 3930 | 
            -
                          _context2.next = 2;
         | 
| 3931 | 
            -
                          return data.json();
         | 
| 3932 | 
            -
                        case 2:
         | 
| 3933 | 
            -
                          translations = _context2.sent;
         | 
| 3934 | 
            -
                          setI18n(translations);
         | 
| 3935 | 
            -
                          cacheI18n[language] = translations;
         | 
| 3936 | 
            -
                        case 5:
         | 
| 3937 | 
            -
                        case "end":
         | 
| 3938 | 
            -
                          return _context2.stop();
         | 
| 3939 | 
            -
                      }
         | 
| 3940 | 
            -
                    }, _callee2);
         | 
| 3941 | 
            -
                  }))).apply(this, arguments);
         | 
| 3942 | 
            -
                })["catch"](function (error) {
         | 
| 3536 | 
            +
                fetch("".concat(EMOJI_MART_DATA_URL, "/i18n/").concat(language, ".json")).then(async data => {
         | 
| 3537 | 
            +
                  const translations = await data.json();
         | 
| 3538 | 
            +
                  setI18n(translations);
         | 
| 3539 | 
            +
                  cacheI18n[language] = translations;
         | 
| 3540 | 
            +
                }).catch(error => {
         | 
| 3943 3541 | 
             
                  console.error("Failed to load translations:", error);
         | 
| 3944 3542 | 
             
                });
         | 
| 3945 3543 | 
             
              }, [language]);
         | 
| @@ -3976,20 +3574,20 @@ var EmojiPicker$1 = /*#__PURE__*/memo(EmojiPicker); | |
| 3976 3574 | 
             
             * @return {JSX.Element}
         | 
| 3977 3575 | 
             
             */
         | 
| 3978 3576 | 
             
            function EmojiPickerContainer(_ref) {
         | 
| 3979 | 
            -
               | 
| 3980 | 
            -
                 | 
| 3981 | 
            -
                 | 
| 3982 | 
            -
                 | 
| 3983 | 
            -
                 | 
| 3984 | 
            -
                 | 
| 3985 | 
            -
                 | 
| 3577 | 
            +
              let {
         | 
| 3578 | 
            +
                showPicker,
         | 
| 3579 | 
            +
                theme,
         | 
| 3580 | 
            +
                handleSelectEmoji,
         | 
| 3581 | 
            +
                disableRecent,
         | 
| 3582 | 
            +
                customEmojis,
         | 
| 3583 | 
            +
                position,
         | 
| 3584 | 
            +
                language
         | 
| 3585 | 
            +
              } = _ref;
         | 
| 3986 3586 | 
             
              return /*#__PURE__*/React.createElement("div", {
         | 
| 3987 3587 | 
             
                className: "react-emoji-picker--container"
         | 
| 3988 3588 | 
             
              }, showPicker && /*#__PURE__*/React.createElement("div", {
         | 
| 3989 3589 | 
             
                className: "react-emoji-picker--wrapper",
         | 
| 3990 | 
            -
                onClick:  | 
| 3991 | 
            -
                  return evt.stopPropagation();
         | 
| 3992 | 
            -
                },
         | 
| 3590 | 
            +
                onClick: evt => evt.stopPropagation(),
         | 
| 3993 3591 | 
             
                style: position === 'below' ? {
         | 
| 3994 3592 | 
             
                  top: '40px'
         | 
| 3995 3593 | 
             
                } : {}
         | 
| @@ -4004,7 +3602,8 @@ function EmojiPickerContainer(_ref) { | |
| 4004 3602 | 
             
              }))));
         | 
| 4005 3603 | 
             
            }
         | 
| 4006 3604 |  | 
| 4007 | 
            -
             | 
| 3605 | 
            +
            // @ts-check
         | 
| 3606 | 
            +
            const EMOJI_PICKER_CONTAINER_HEIGHT = 435;
         | 
| 4008 3607 |  | 
| 4009 3608 | 
             
            /**
         | 
| 4010 3609 | 
             
             * @typedef {import('../types/types').SanitizeFn} SanitizeFn
         | 
| @@ -4030,38 +3629,36 @@ var EMOJI_PICKER_CONTAINER_HEIGHT = 435; | |
| 4030 3629 |  | 
| 4031 3630 | 
             
            // eslint-disable-next-line valid-jsdoc
         | 
| 4032 3631 | 
             
            /** @type {React.FC<Props>} */
         | 
| 4033 | 
            -
             | 
| 4034 | 
            -
               | 
| 4035 | 
            -
                 | 
| 4036 | 
            -
                 | 
| 4037 | 
            -
                 | 
| 4038 | 
            -
                 | 
| 4039 | 
            -
                 | 
| 4040 | 
            -
                 | 
| 4041 | 
            -
                 | 
| 4042 | 
            -
                 | 
| 4043 | 
            -
                 | 
| 4044 | 
            -
             | 
| 4045 | 
            -
             | 
| 4046 | 
            -
             | 
| 4047 | 
            -
                setShowPicker = _useState2[1];
         | 
| 3632 | 
            +
            const EmojiPickerWrapper = props => {
         | 
| 3633 | 
            +
              const {
         | 
| 3634 | 
            +
                theme,
         | 
| 3635 | 
            +
                keepOpened,
         | 
| 3636 | 
            +
                disableRecent,
         | 
| 3637 | 
            +
                customEmojis,
         | 
| 3638 | 
            +
                addSanitizeFn,
         | 
| 3639 | 
            +
                addPolluteFn,
         | 
| 3640 | 
            +
                appendContent,
         | 
| 3641 | 
            +
                buttonElement,
         | 
| 3642 | 
            +
                buttonRef,
         | 
| 3643 | 
            +
                language
         | 
| 3644 | 
            +
              } = props;
         | 
| 3645 | 
            +
              const [showPicker, setShowPicker] = useState(false);
         | 
| 4048 3646 | 
             
              /** @type {[HTMLDivElement | undefined, React.Dispatch<React.SetStateAction<HTMLDivElement | undefined>>]} */
         | 
| 4049 | 
            -
               | 
| 4050 | 
            -
                _useState4 = _slicedToArray(_useState3, 2),
         | 
| 4051 | 
            -
                customButton = _useState4[0],
         | 
| 4052 | 
            -
                setCustomButton = _useState4[1];
         | 
| 3647 | 
            +
              const [customButton, setCustomButton] = useState();
         | 
| 4053 3648 | 
             
              /** @type {['above' | 'below' | undefined, React.Dispatch<React.SetStateAction<'above' | 'below' | undefined>>]} */
         | 
| 4054 | 
            -
               | 
| 4055 | 
            -
             | 
| 4056 | 
            -
                 | 
| 4057 | 
            -
             | 
| 4058 | 
            -
             | 
| 3649 | 
            +
              const [emojiPickerPosition, setEmojiPickerPosition] = useState();
         | 
| 3650 | 
            +
              useEffect(() => {
         | 
| 3651 | 
            +
                if (showPicker) {
         | 
| 3652 | 
            +
                  cacheCurrentRange();
         | 
| 3653 | 
            +
                }
         | 
| 3654 | 
            +
              }, [showPicker]);
         | 
| 3655 | 
            +
              useEffect(() => {
         | 
| 4059 3656 | 
             
                addSanitizeFn(replaceAllTextEmojiToString);
         | 
| 4060 3657 | 
             
              }, [addSanitizeFn]);
         | 
| 4061 | 
            -
              useEffect( | 
| 3658 | 
            +
              useEffect(() => {
         | 
| 4062 3659 | 
             
                addPolluteFn(replaceAllTextEmojis);
         | 
| 4063 3660 | 
             
              }, [addPolluteFn]);
         | 
| 4064 | 
            -
              useEffect( | 
| 3661 | 
            +
              useEffect(() => {
         | 
| 4065 3662 | 
             
                /**
         | 
| 4066 3663 | 
             
                 *
         | 
| 4067 3664 | 
             
                 * @param {MouseEvent} event
         | 
| @@ -4069,14 +3666,14 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) { | |
| 4069 3666 | 
             
                function checkClickOutside(event) {
         | 
| 4070 3667 | 
             
                  /** @type {HTMLElement} */
         | 
| 4071 3668 | 
             
                  // @ts-ignore
         | 
| 4072 | 
            -
                   | 
| 3669 | 
            +
                  const element = event.target;
         | 
| 4073 3670 | 
             
                  if (element.classList.contains("react-input-emoji--button") || element.classList.contains("react-input-emoji--button--icon")) {
         | 
| 4074 3671 | 
             
                    return;
         | 
| 4075 3672 | 
             
                  }
         | 
| 4076 3673 | 
             
                  setShowPicker(false);
         | 
| 4077 3674 | 
             
                }
         | 
| 4078 3675 | 
             
                document.addEventListener("click", checkClickOutside);
         | 
| 4079 | 
            -
                return  | 
| 3676 | 
            +
                return () => {
         | 
| 4080 3677 | 
             
                  document.removeEventListener("click", checkClickOutside);
         | 
| 4081 3678 | 
             
                };
         | 
| 4082 3679 | 
             
              }, []);
         | 
| @@ -4089,9 +3686,7 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) { | |
| 4089 3686 | 
             
                event.stopPropagation();
         | 
| 4090 3687 | 
             
                event.preventDefault();
         | 
| 4091 3688 | 
             
                setEmojiPickerPosition(calcTopPosition(event));
         | 
| 4092 | 
            -
                setShowPicker( | 
| 4093 | 
            -
                  return !currentShowPicker;
         | 
| 4094 | 
            -
                });
         | 
| 3689 | 
            +
                setShowPicker(currentShowPicker => !currentShowPicker);
         | 
| 4095 3690 | 
             
              }
         | 
| 4096 3691 |  | 
| 4097 3692 | 
             
              /**
         | 
| @@ -4100,9 +3695,9 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) { | |
| 4100 3695 | 
             
               * @return {'above' | 'below'}
         | 
| 4101 3696 | 
             
               */
         | 
| 4102 3697 | 
             
              function calcTopPosition(event) {
         | 
| 4103 | 
            -
                 | 
| 4104 | 
            -
                 | 
| 4105 | 
            -
                 | 
| 3698 | 
            +
                const btn = event.currentTarget;
         | 
| 3699 | 
            +
                const btnRect = btn.getBoundingClientRect();
         | 
| 3700 | 
            +
                const popoverHeight = EMOJI_PICKER_CONTAINER_HEIGHT;
         | 
| 4106 3701 |  | 
| 4107 3702 | 
             
                // Decide to display above or below based on available space
         | 
| 4108 3703 | 
             
                if (btnRect.top >= popoverHeight) {
         | 
| @@ -4122,12 +3717,10 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) { | |
| 4122 3717 | 
             
              function handleSelectEmoji(emoji) {
         | 
| 4123 3718 | 
             
                appendContent(getImageEmoji(emoji));
         | 
| 4124 3719 | 
             
                if (!keepOpened) {
         | 
| 4125 | 
            -
                  setShowPicker( | 
| 4126 | 
            -
                    return !currentShowPicker;
         | 
| 4127 | 
            -
                  });
         | 
| 3720 | 
            +
                  setShowPicker(currentShowPicker => !currentShowPicker);
         | 
| 4128 3721 | 
             
                }
         | 
| 4129 3722 | 
             
              }
         | 
| 4130 | 
            -
              useEffect( | 
| 3723 | 
            +
              useEffect(() => {
         | 
| 4131 3724 | 
             
                var _buttonRef$current;
         | 
| 4132 3725 | 
             
                if (buttonRef !== null && buttonRef !== void 0 && (_buttonRef$current = buttonRef.current) !== null && _buttonRef$current !== void 0 && _buttonRef$current.style) {
         | 
| 4133 3726 | 
             
                  buttonRef.current.style.position = "relative";
         | 
| @@ -4171,16 +3764,16 @@ var EmojiPickerWrapper = function EmojiPickerWrapper(props) { | |
| 4171 3764 | 
             
             * @return {string | null}
         | 
| 4172 3765 | 
             
             */
         | 
| 4173 3766 | 
             
            function getTextFromAtToCaret() {
         | 
| 4174 | 
            -
               | 
| 3767 | 
            +
              const range = getRangeFromAtToCaret();
         | 
| 4175 3768 | 
             
              if (!range) return null;
         | 
| 4176 | 
            -
               | 
| 3769 | 
            +
              const text = range.text.substring(range.begin, range.end);
         | 
| 4177 3770 | 
             
              return text || null;
         | 
| 4178 3771 | 
             
            }
         | 
| 4179 3772 |  | 
| 4180 3773 | 
             
            // eslint-disable-next-line valid-jsdoc
         | 
| 4181 3774 | 
             
            /** */
         | 
| 4182 3775 | 
             
            function deleteTextFromAtToCaret() {
         | 
| 4183 | 
            -
               | 
| 3776 | 
            +
              const range = getRangeFromAtToCaret();
         | 
| 4184 3777 | 
             
              if (!range) return;
         | 
| 4185 3778 |  | 
| 4186 3779 | 
             
              // @ts-ignore
         | 
| @@ -4192,22 +3785,24 @@ function deleteTextFromAtToCaret() { | |
| 4192 3785 | 
             
             * @return {{begin: number, end: number, text: string, element: Node} | null}
         | 
| 4193 3786 | 
             
             */
         | 
| 4194 3787 | 
             
            function getRangeFromAtToCaret() {
         | 
| 4195 | 
            -
               | 
| 3788 | 
            +
              const elementWithFocus = getElementWithFocus();
         | 
| 4196 3789 | 
             
              if (!elementWithFocus) {
         | 
| 4197 3790 | 
             
                return null;
         | 
| 4198 3791 | 
             
              }
         | 
| 4199 | 
            -
               | 
| 4200 | 
            -
                 | 
| 4201 | 
            -
             | 
| 4202 | 
            -
               | 
| 3792 | 
            +
              const {
         | 
| 3793 | 
            +
                element,
         | 
| 3794 | 
            +
                caretOffset
         | 
| 3795 | 
            +
              } = elementWithFocus;
         | 
| 3796 | 
            +
              const text = element.textContent;
         | 
| 3797 | 
            +
              const lastAt = text.lastIndexOf("@");
         | 
| 4203 3798 | 
             
              if (lastAt === -1 || lastAt >= caretOffset || lastAt !== 0 && text[lastAt - 1] !== " ") {
         | 
| 4204 3799 | 
             
                return null;
         | 
| 4205 3800 | 
             
              }
         | 
| 4206 3801 | 
             
              return {
         | 
| 4207 3802 | 
             
                begin: lastAt,
         | 
| 4208 3803 | 
             
                end: caretOffset,
         | 
| 4209 | 
            -
                text | 
| 4210 | 
            -
                element | 
| 3804 | 
            +
                text,
         | 
| 3805 | 
            +
                element
         | 
| 4211 3806 | 
             
              };
         | 
| 4212 3807 | 
             
            }
         | 
| 4213 3808 |  | 
| @@ -4216,14 +3811,14 @@ function getRangeFromAtToCaret() { | |
| 4216 3811 | 
             
             * @return {{element: Node, caretOffset: number}}
         | 
| 4217 3812 | 
             
             */
         | 
| 4218 3813 | 
             
            function getElementWithFocus() {
         | 
| 4219 | 
            -
               | 
| 3814 | 
            +
              const element = getSelectionStart();
         | 
| 4220 3815 | 
             
              if (element === null) {
         | 
| 4221 3816 | 
             
                return null;
         | 
| 4222 3817 | 
             
              }
         | 
| 4223 | 
            -
               | 
| 3818 | 
            +
              let caretOffset = 0;
         | 
| 4224 3819 | 
             
              if (typeof window.getSelection != "undefined") {
         | 
| 4225 | 
            -
                 | 
| 4226 | 
            -
                 | 
| 3820 | 
            +
                const range = window.getSelection().getRangeAt(0);
         | 
| 3821 | 
            +
                const preCaretRange = range.cloneRange();
         | 
| 4227 3822 | 
             
                preCaretRange.selectNodeContents(element);
         | 
| 4228 3823 | 
             
                preCaretRange.setEnd(range.endContainer, range.endOffset);
         | 
| 4229 3824 | 
             
                caretOffset = preCaretRange.toString().length;
         | 
| @@ -4233,16 +3828,16 @@ function getElementWithFocus() { | |
| 4233 3828 | 
             
              // @ts-ignore
         | 
| 4234 3829 | 
             
              document.selection.type != "Control") {
         | 
| 4235 3830 | 
             
                // @ts-ignore
         | 
| 4236 | 
            -
                 | 
| 3831 | 
            +
                const textRange = document.selection.createRange();
         | 
| 4237 3832 | 
             
                // @ts-ignore
         | 
| 4238 | 
            -
                 | 
| 3833 | 
            +
                const preCaretTextRange = document.body.createTextRange();
         | 
| 4239 3834 | 
             
                preCaretTextRange.moveToElementText(element);
         | 
| 4240 3835 | 
             
                preCaretTextRange.setEndPoint("EndToEnd", textRange);
         | 
| 4241 3836 | 
             
                caretOffset = preCaretTextRange.text.length;
         | 
| 4242 3837 | 
             
              }
         | 
| 4243 3838 | 
             
              return {
         | 
| 4244 | 
            -
                element | 
| 4245 | 
            -
                caretOffset | 
| 3839 | 
            +
                element,
         | 
| 3840 | 
            +
                caretOffset
         | 
| 4246 3841 | 
             
              };
         | 
| 4247 3842 | 
             
            }
         | 
| 4248 3843 |  | 
| @@ -4251,10 +3846,12 @@ function getElementWithFocus() { | |
| 4251 3846 | 
             
             * @return {Node | null}
         | 
| 4252 3847 | 
             
             */
         | 
| 4253 3848 | 
             
            function getSelectionStart() {
         | 
| 4254 | 
            -
               | 
| 3849 | 
            +
              const node = document.getSelection().anchorNode;
         | 
| 4255 3850 | 
             
              return (node === null || node === void 0 ? void 0 : node.nodeType) == 3 ? node : null;
         | 
| 4256 3851 | 
             
            }
         | 
| 4257 3852 |  | 
| 3853 | 
            +
            // @ts-check
         | 
| 3854 | 
            +
             | 
| 4258 3855 | 
             
            /**
         | 
| 4259 3856 | 
             
             * @typedef {import('../types/types').MentionUser} MentionUser
         | 
| 4260 3857 | 
             
             */
         | 
| @@ -4266,95 +3863,53 @@ function getSelectionStart() { | |
| 4266 3863 | 
             
             * @returns {{mentionSearchText: string | null, mentionUsers: MentionUser[], onKeyUp: (event: React.KeyboardEvent) => void, onFocus: () => void, onSelectUser: () => void, loading: boolean}}
         | 
| 4267 3864 | 
             
             */
         | 
| 4268 3865 | 
             
            function useMention(searchMention) {
         | 
| 4269 | 
            -
               | 
| 4270 | 
            -
              var _useState = useState(false),
         | 
| 4271 | 
            -
                _useState2 = _slicedToArray(_useState, 2),
         | 
| 4272 | 
            -
                loading = _useState2[0],
         | 
| 4273 | 
            -
                setLoading = _useState2[1];
         | 
| 3866 | 
            +
              const [loading, setLoading] = useState(false);
         | 
| 4274 3867 |  | 
| 4275 3868 | 
             
              /** @type {[MentionUser[], React.Dispatch<React.SetStateAction<MentionUser[]>>]} */
         | 
| 4276 | 
            -
               | 
| 4277 | 
            -
                _useState4 = _slicedToArray(_useState3, 2),
         | 
| 4278 | 
            -
                mentionUsers = _useState4[0],
         | 
| 4279 | 
            -
                setMentionUsers = _useState4[1];
         | 
| 3869 | 
            +
              const [mentionUsers, setMentionUsers] = useState([]);
         | 
| 4280 3870 |  | 
| 4281 3871 | 
             
              /** @type {[string | null, React.Dispatch<React.SetStateAction<string | null>>]} */
         | 
| 4282 | 
            -
               | 
| 4283 | 
            -
             | 
| 4284 | 
            -
                mentionSearchText = _useState6[0],
         | 
| 4285 | 
            -
                setMentionSearchText = _useState6[1];
         | 
| 4286 | 
            -
              var onSelectUser = useCallback(function () {
         | 
| 3872 | 
            +
              const [mentionSearchText, setMentionSearchText] = useState(null);
         | 
| 3873 | 
            +
              const onSelectUser = useCallback(() => {
         | 
| 4287 3874 | 
             
                deleteTextFromAtToCaret();
         | 
| 4288 3875 | 
             
                setMentionUsers([]);
         | 
| 4289 3876 | 
             
              }, []);
         | 
| 4290 3877 |  | 
| 4291 3878 | 
             
              /** */
         | 
| 4292 | 
            -
               | 
| 4293 | 
            -
                 | 
| 4294 | 
            -
                 | 
| 4295 | 
            -
             | 
| 4296 | 
            -
             | 
| 4297 | 
            -
             | 
| 4298 | 
            -
             | 
| 4299 | 
            -
             | 
| 4300 | 
            -
             | 
| 4301 | 
            -
             | 
| 4302 | 
            -
             | 
| 4303 | 
            -
             | 
| 4304 | 
            -
                      _context.next = 12;
         | 
| 4305 | 
            -
                      break;
         | 
| 4306 | 
            -
                    case 6:
         | 
| 4307 | 
            -
                      setLoading(true);
         | 
| 4308 | 
            -
                      _context.next = 9;
         | 
| 4309 | 
            -
                      return searchMention(metionText);
         | 
| 4310 | 
            -
                    case 9:
         | 
| 4311 | 
            -
                      users = _context.sent;
         | 
| 4312 | 
            -
                      setLoading(false);
         | 
| 4313 | 
            -
                      setMentionUsers(users);
         | 
| 4314 | 
            -
                    case 12:
         | 
| 4315 | 
            -
                    case "end":
         | 
| 4316 | 
            -
                      return _context.stop();
         | 
| 4317 | 
            -
                  }
         | 
| 4318 | 
            -
                }, _callee);
         | 
| 4319 | 
            -
              })), [searchMention]);
         | 
| 3879 | 
            +
              const checkMentionText = useCallback(async () => {
         | 
| 3880 | 
            +
                const metionText = getTextFromAtToCaret();
         | 
| 3881 | 
            +
                setMentionSearchText(metionText);
         | 
| 3882 | 
            +
                if (metionText === null) {
         | 
| 3883 | 
            +
                  setMentionUsers([]);
         | 
| 3884 | 
            +
                } else {
         | 
| 3885 | 
            +
                  setLoading(true);
         | 
| 3886 | 
            +
                  const users = await searchMention(metionText);
         | 
| 3887 | 
            +
                  setLoading(false);
         | 
| 3888 | 
            +
                  setMentionUsers(users);
         | 
| 3889 | 
            +
                }
         | 
| 3890 | 
            +
              }, [searchMention]);
         | 
| 4320 3891 |  | 
| 4321 3892 | 
             
              /** @type {(event: React.KeyboardEvent) => void} */
         | 
| 4322 | 
            -
               | 
| 4323 | 
            -
                 | 
| 4324 | 
            -
             | 
| 4325 | 
            -
             | 
| 4326 | 
            -
                   | 
| 4327 | 
            -
             | 
| 4328 | 
            -
             | 
| 4329 | 
            -
             | 
| 4330 | 
            -
             | 
| 4331 | 
            -
                          break;
         | 
| 4332 | 
            -
                        }
         | 
| 4333 | 
            -
                        return _context2.abrupt("return");
         | 
| 4334 | 
            -
                      case 2:
         | 
| 4335 | 
            -
                        if (event.key === "Backspace" && (_getElementWithFocus = getElementWithFocus()) !== null && _getElementWithFocus !== void 0 && _getElementWithFocus.element.parentElement.hasAttribute("data-mention-id")) {
         | 
| 4336 | 
            -
                          elementWithFocus = getElementWithFocus();
         | 
| 4337 | 
            -
                          elementWithFocus.element.parentElement.remove();
         | 
| 4338 | 
            -
                        } else if (!["ArrowUp", "ArrowDown", "Esc", "Escape"].includes(event.key)) {
         | 
| 4339 | 
            -
                          checkMentionText();
         | 
| 4340 | 
            -
                        }
         | 
| 4341 | 
            -
                      case 3:
         | 
| 4342 | 
            -
                      case "end":
         | 
| 4343 | 
            -
                        return _context2.stop();
         | 
| 4344 | 
            -
                    }
         | 
| 4345 | 
            -
                  }, _callee2);
         | 
| 4346 | 
            -
                }))).apply(this, arguments);
         | 
| 3893 | 
            +
              const onKeyUp = useCallback(async event => {
         | 
| 3894 | 
            +
                var _getElementWithFocus;
         | 
| 3895 | 
            +
                if (typeof searchMention !== "function") return;
         | 
| 3896 | 
            +
                if (event.key === "Backspace" && (_getElementWithFocus = getElementWithFocus()) !== null && _getElementWithFocus !== void 0 && _getElementWithFocus.element.parentElement.hasAttribute("data-mention-id")) {
         | 
| 3897 | 
            +
                  const elementWithFocus = getElementWithFocus();
         | 
| 3898 | 
            +
                  elementWithFocus.element.parentElement.remove();
         | 
| 3899 | 
            +
                } else if (!["ArrowUp", "ArrowDown", "Esc", "Escape"].includes(event.key)) {
         | 
| 3900 | 
            +
                  checkMentionText();
         | 
| 3901 | 
            +
                }
         | 
| 4347 3902 | 
             
              }, [checkMentionText, searchMention]);
         | 
| 4348 | 
            -
               | 
| 3903 | 
            +
              const onFocus = useCallback(() => {
         | 
| 4349 3904 | 
             
                checkMentionText();
         | 
| 4350 3905 | 
             
              }, [checkMentionText]);
         | 
| 4351 3906 | 
             
              return {
         | 
| 4352 | 
            -
                mentionSearchText | 
| 4353 | 
            -
                mentionUsers | 
| 4354 | 
            -
                onKeyUp | 
| 4355 | 
            -
                onFocus | 
| 4356 | 
            -
                onSelectUser | 
| 4357 | 
            -
                loading | 
| 3907 | 
            +
                mentionSearchText,
         | 
| 3908 | 
            +
                mentionUsers,
         | 
| 3909 | 
            +
                onKeyUp,
         | 
| 3910 | 
            +
                onFocus,
         | 
| 3911 | 
            +
                onSelectUser,
         | 
| 3912 | 
            +
                loading
         | 
| 4358 3913 | 
             
              };
         | 
| 4359 3914 | 
             
            }
         | 
| 4360 3915 |  | 
| @@ -4380,36 +3935,33 @@ function useMention(searchMention) { | |
| 4380 3935 |  | 
| 4381 3936 | 
             
            // eslint-disable-next-line valid-jsdoc
         | 
| 4382 3937 | 
             
            /** @type {React.ForwardRefRenderFunction<Ref, Props>} */
         | 
| 4383 | 
            -
             | 
| 4384 | 
            -
               | 
| 4385 | 
            -
                 | 
| 4386 | 
            -
                 | 
| 4387 | 
            -
                 | 
| 4388 | 
            -
             | 
| 4389 | 
            -
             | 
| 4390 | 
            -
             | 
| 4391 | 
            -
             | 
| 4392 | 
            -
             | 
| 4393 | 
            -
             | 
| 4394 | 
            -
             | 
| 4395 | 
            -
             | 
| 4396 | 
            -
             | 
| 4397 | 
            -
             | 
| 4398 | 
            -
             | 
| 4399 | 
            -
             | 
| 4400 | 
            -
             | 
| 4401 | 
            -
                   | 
| 4402 | 
            -
             | 
| 4403 | 
            -
             | 
| 4404 | 
            -
             | 
| 4405 | 
            -
             | 
| 4406 | 
            -
             | 
| 4407 | 
            -
             | 
| 4408 | 
            -
             | 
| 4409 | 
            -
             | 
| 4410 | 
            -
                };
         | 
| 4411 | 
            -
              });
         | 
| 4412 | 
            -
              useEffect(function () {
         | 
| 3938 | 
            +
            const MentionUserList = (_ref, ref) => {
         | 
| 3939 | 
            +
              let {
         | 
| 3940 | 
            +
                users,
         | 
| 3941 | 
            +
                mentionSearchText,
         | 
| 3942 | 
            +
                onSelect,
         | 
| 3943 | 
            +
                addEventListener
         | 
| 3944 | 
            +
              } = _ref;
         | 
| 3945 | 
            +
              const [selectedUser, setSelectedUser] = useState(0);
         | 
| 3946 | 
            +
              useImperativeHandle(ref, () => ({
         | 
| 3947 | 
            +
                prevUser: () => {
         | 
| 3948 | 
            +
                  setSelectedUser(currentSelectedUser => {
         | 
| 3949 | 
            +
                    if (currentSelectedUser === 0) {
         | 
| 3950 | 
            +
                      return 0;
         | 
| 3951 | 
            +
                    }
         | 
| 3952 | 
            +
                    return currentSelectedUser - 1;
         | 
| 3953 | 
            +
                  });
         | 
| 3954 | 
            +
                },
         | 
| 3955 | 
            +
                nextUser: () => {
         | 
| 3956 | 
            +
                  setSelectedUser(currentSelectedUser => {
         | 
| 3957 | 
            +
                    if (currentSelectedUser === users.length - 1) {
         | 
| 3958 | 
            +
                      return users.length - 1;
         | 
| 3959 | 
            +
                    }
         | 
| 3960 | 
            +
                    return currentSelectedUser + 1;
         | 
| 3961 | 
            +
                  });
         | 
| 3962 | 
            +
                }
         | 
| 3963 | 
            +
              }));
         | 
| 3964 | 
            +
              useEffect(() => {
         | 
| 4413 3965 | 
             
                setSelectedUser(0);
         | 
| 4414 3966 | 
             
              }, [users]);
         | 
| 4415 3967 |  | 
| @@ -4424,16 +3976,16 @@ var MentionUserList = function MentionUserList(_ref, ref) { | |
| 4424 3976 | 
             
              }
         | 
| 4425 3977 |  | 
| 4426 3978 | 
             
              /** @type {(MentionUser & {nameHtml: string})[]} */
         | 
| 4427 | 
            -
               | 
| 4428 | 
            -
                 | 
| 4429 | 
            -
                return users.map( | 
| 4430 | 
            -
                   | 
| 3979 | 
            +
              const usersFiltered = useMemo(() => {
         | 
| 3980 | 
            +
                const searchText = mentionSearchText ? mentionSearchText.substring(1).toLocaleLowerCase() : "";
         | 
| 3981 | 
            +
                return users.map(user => {
         | 
| 3982 | 
            +
                  let nameHtml = user.name;
         | 
| 4431 3983 | 
             
                  if (mentionSearchText && mentionSearchText.length > 1) {
         | 
| 4432 3984 | 
             
                    if (user.name.toLowerCase().startsWith(searchText)) {
         | 
| 4433 3985 | 
             
                      nameHtml = getMentionSelectedNameEl(user.name.substring(0, searchText.length), user.name.substring(searchText.length));
         | 
| 4434 3986 | 
             
                    } else {
         | 
| 4435 | 
            -
                       | 
| 4436 | 
            -
                      nameHtml = names.map( | 
| 3987 | 
            +
                      const names = user.name.split(" ");
         | 
| 3988 | 
            +
                      nameHtml = names.map(name => {
         | 
| 4437 3989 | 
             
                        if (name.toLocaleLowerCase().startsWith(searchText)) {
         | 
| 4438 3990 | 
             
                          return getMentionSelectedNameEl(name.substring(0, searchText.length), name.substring(searchText.length));
         | 
| 4439 3991 | 
             
                        }
         | 
| @@ -4442,7 +3994,7 @@ var MentionUserList = function MentionUserList(_ref, ref) { | |
| 4442 3994 | 
             
                    }
         | 
| 4443 3995 | 
             
                  }
         | 
| 4444 3996 | 
             
                  return _objectSpread2(_objectSpread2({}, user), {}, {
         | 
| 4445 | 
            -
                    nameHtml | 
| 3997 | 
            +
                    nameHtml
         | 
| 4446 3998 | 
             
                  });
         | 
| 4447 3999 | 
             
                });
         | 
| 4448 4000 | 
             
              }, [mentionSearchText, users]);
         | 
| @@ -4454,47 +4006,45 @@ var MentionUserList = function MentionUserList(_ref, ref) { | |
| 4454 4006 | 
             
               * @returns {(event: React.MouseEvent) => void} event
         | 
| 4455 4007 | 
             
               */
         | 
| 4456 4008 | 
             
              function handleClick(user) {
         | 
| 4457 | 
            -
                return  | 
| 4009 | 
            +
                return event => {
         | 
| 4458 4010 | 
             
                  event.stopPropagation();
         | 
| 4459 4011 | 
             
                  event.preventDefault();
         | 
| 4460 4012 | 
             
                  onSelect(user);
         | 
| 4461 4013 | 
             
                };
         | 
| 4462 4014 | 
             
              }
         | 
| 4463 | 
            -
              useEffect( | 
| 4464 | 
            -
                 | 
| 4015 | 
            +
              useEffect(() => {
         | 
| 4016 | 
            +
                const unsubscribe = addEventListener("enter", event => {
         | 
| 4465 4017 | 
             
                  event.stopPropagation();
         | 
| 4466 4018 | 
             
                  event.preventDefault();
         | 
| 4467 4019 | 
             
                  onSelect(usersFiltered[selectedUser]);
         | 
| 4468 4020 | 
             
                });
         | 
| 4469 | 
            -
                return  | 
| 4021 | 
            +
                return () => {
         | 
| 4470 4022 | 
             
                  unsubscribe();
         | 
| 4471 4023 | 
             
                };
         | 
| 4472 4024 | 
             
              }, [addEventListener, onSelect, selectedUser, usersFiltered]);
         | 
| 4473 4025 | 
             
              return /*#__PURE__*/React.createElement("ul", {
         | 
| 4474 4026 | 
             
                className: "react-input-emoji--mention--list",
         | 
| 4475 4027 | 
             
                "data-testid": "mention-user-list"
         | 
| 4476 | 
            -
              }, usersFiltered.map( | 
| 4477 | 
            -
                 | 
| 4478 | 
            -
             | 
| 4479 | 
            -
                 | 
| 4480 | 
            -
             | 
| 4481 | 
            -
             | 
| 4482 | 
            -
             | 
| 4483 | 
            -
             | 
| 4484 | 
            -
             | 
| 4485 | 
            -
             | 
| 4486 | 
            -
             | 
| 4487 | 
            -
             | 
| 4488 | 
            -
             | 
| 4489 | 
            -
             | 
| 4490 | 
            -
             | 
| 4491 | 
            -
             | 
| 4492 | 
            -
                    __html: user.nameHtml
         | 
| 4493 | 
            -
                  }
         | 
| 4494 | 
            -
                })));
         | 
| 4495 | 
            -
              }));
         | 
| 4028 | 
            +
              }, usersFiltered.map((user, index) => /*#__PURE__*/React.createElement("li", {
         | 
| 4029 | 
            +
                key: user.id
         | 
| 4030 | 
            +
              }, /*#__PURE__*/React.createElement("button", {
         | 
| 4031 | 
            +
                type: "button",
         | 
| 4032 | 
            +
                onClick: handleClick(user),
         | 
| 4033 | 
            +
                className: "react-input-emoji--mention--item".concat(selectedUser === index ? " react-input-emoji--mention--item__selected" : ""),
         | 
| 4034 | 
            +
                onMouseOver: () => setSelectedUser(index)
         | 
| 4035 | 
            +
              }, /*#__PURE__*/React.createElement("img", {
         | 
| 4036 | 
            +
                className: "react-input-emoji--mention--item--img",
         | 
| 4037 | 
            +
                src: user.image
         | 
| 4038 | 
            +
              }), /*#__PURE__*/React.createElement("div", {
         | 
| 4039 | 
            +
                className: "react-input-emoji--mention--item--name",
         | 
| 4040 | 
            +
                dangerouslySetInnerHTML: {
         | 
| 4041 | 
            +
                  __html: user.nameHtml
         | 
| 4042 | 
            +
                }
         | 
| 4043 | 
            +
              })))));
         | 
| 4496 4044 | 
             
            };
         | 
| 4497 | 
            -
             | 
| 4045 | 
            +
            const MentionUserListWithRef = /*#__PURE__*/forwardRef(MentionUserList);
         | 
| 4046 | 
            +
             | 
| 4047 | 
            +
            // @ts-check
         | 
| 4498 4048 |  | 
| 4499 4049 | 
             
            /**
         | 
| 4500 4050 | 
             
             * @typedef {import('../types/types').MentionUser} MetionUser
         | 
| @@ -4518,55 +4068,55 @@ var MentionUserListWithRef = /*#__PURE__*/forwardRef(MentionUserList); | |
| 4518 4068 |  | 
| 4519 4069 | 
             
            // eslint-disable-next-line valid-jsdoc
         | 
| 4520 4070 | 
             
            /** @type {React.FC<Props>} */
         | 
| 4521 | 
            -
             | 
| 4522 | 
            -
               | 
| 4523 | 
            -
                 | 
| 4524 | 
            -
                 | 
| 4525 | 
            -
                 | 
| 4071 | 
            +
            const MentionWrapper = _ref => {
         | 
| 4072 | 
            +
              let {
         | 
| 4073 | 
            +
                searchMention,
         | 
| 4074 | 
            +
                addEventListener,
         | 
| 4075 | 
            +
                appendContent,
         | 
| 4076 | 
            +
                addSanitizeFn
         | 
| 4077 | 
            +
              } = _ref;
         | 
| 4526 4078 | 
             
              /** @type {React.MutableRefObject<import('./mention-user-list').Ref | null>} */
         | 
| 4527 | 
            -
               | 
| 4528 | 
            -
               | 
| 4529 | 
            -
             | 
| 4530 | 
            -
                 | 
| 4531 | 
            -
                 | 
| 4532 | 
            -
             | 
| 4533 | 
            -
                 | 
| 4534 | 
            -
                 | 
| 4535 | 
            -
                 | 
| 4536 | 
            -
             | 
| 4537 | 
            -
             | 
| 4538 | 
            -
                 | 
| 4539 | 
            -
             | 
| 4540 | 
            -
                addSanitizeFn(function (html) {
         | 
| 4541 | 
            -
                  var container = document.createElement("div");
         | 
| 4079 | 
            +
              const metionUserListRef = useRef(null);
         | 
| 4080 | 
            +
              const [showUserList, setShowUserList] = useState(false);
         | 
| 4081 | 
            +
              const {
         | 
| 4082 | 
            +
                mentionSearchText,
         | 
| 4083 | 
            +
                mentionUsers,
         | 
| 4084 | 
            +
                loading,
         | 
| 4085 | 
            +
                onKeyUp,
         | 
| 4086 | 
            +
                onFocus,
         | 
| 4087 | 
            +
                onSelectUser
         | 
| 4088 | 
            +
              } = useMention(searchMention);
         | 
| 4089 | 
            +
              useEffect(() => {
         | 
| 4090 | 
            +
                addSanitizeFn(html => {
         | 
| 4091 | 
            +
                  const container = document.createElement("div");
         | 
| 4542 4092 | 
             
                  container.innerHTML = html;
         | 
| 4543 | 
            -
                   | 
| 4544 | 
            -
                  mentionsEl.forEach( | 
| 4093 | 
            +
                  const mentionsEl = Array.prototype.slice.call(container.querySelectorAll(".react-input-emoji--mention--text"));
         | 
| 4094 | 
            +
                  mentionsEl.forEach(mentionEl => {
         | 
| 4545 4095 | 
             
                    container.innerHTML = container.innerHTML.replace(mentionEl.outerHTML, "@[".concat(mentionEl.dataset.mentionName, "](userId:").concat(mentionEl.dataset.mentionId, ")"));
         | 
| 4546 4096 | 
             
                  });
         | 
| 4547 4097 | 
             
                  return container.innerHTML;
         | 
| 4548 4098 | 
             
                });
         | 
| 4549 4099 | 
             
              }, [addSanitizeFn]);
         | 
| 4550 | 
            -
              useEffect( | 
| 4100 | 
            +
              useEffect(() => {
         | 
| 4551 4101 | 
             
                setShowUserList(mentionUsers.length > 0);
         | 
| 4552 4102 | 
             
              }, [mentionUsers]);
         | 
| 4553 | 
            -
              useEffect( | 
| 4103 | 
            +
              useEffect(() => {
         | 
| 4554 4104 | 
             
                /** */
         | 
| 4555 4105 | 
             
                function checkClickOutside() {
         | 
| 4556 4106 | 
             
                  setShowUserList(false);
         | 
| 4557 4107 | 
             
                }
         | 
| 4558 4108 | 
             
                document.addEventListener("click", checkClickOutside);
         | 
| 4559 | 
            -
                return  | 
| 4109 | 
            +
                return () => {
         | 
| 4560 4110 | 
             
                  document.removeEventListener("click", checkClickOutside);
         | 
| 4561 4111 | 
             
                };
         | 
| 4562 4112 | 
             
              }, []);
         | 
| 4563 | 
            -
              useEffect( | 
| 4564 | 
            -
                 | 
| 4565 | 
            -
                return  | 
| 4113 | 
            +
              useEffect(() => {
         | 
| 4114 | 
            +
                const unsubscribe = addEventListener("keyUp", onKeyUp);
         | 
| 4115 | 
            +
                return () => {
         | 
| 4566 4116 | 
             
                  unsubscribe();
         | 
| 4567 4117 | 
             
                };
         | 
| 4568 4118 | 
             
              }, [addEventListener, onKeyUp]);
         | 
| 4569 | 
            -
              useEffect( | 
| 4119 | 
            +
              useEffect(() => {
         | 
| 4570 4120 | 
             
                /**
         | 
| 4571 4121 | 
             
                 *
         | 
| 4572 4122 | 
             
                 * @param {React.KeyboardEvent} event
         | 
| @@ -4579,30 +4129,30 @@ var MentionWrapper = function MentionWrapper(_ref) { | |
| 4579 4129 | 
             
                      break;
         | 
| 4580 4130 | 
             
                  }
         | 
| 4581 4131 | 
             
                }
         | 
| 4582 | 
            -
                 | 
| 4583 | 
            -
                return  | 
| 4132 | 
            +
                const unsubscribe = addEventListener("keyDown", handleKeyDown);
         | 
| 4133 | 
            +
                return () => {
         | 
| 4584 4134 | 
             
                  unsubscribe();
         | 
| 4585 4135 | 
             
                };
         | 
| 4586 4136 | 
             
              }, [addEventListener]);
         | 
| 4587 | 
            -
              useEffect( | 
| 4588 | 
            -
                 | 
| 4589 | 
            -
                return  | 
| 4137 | 
            +
              useEffect(() => {
         | 
| 4138 | 
            +
                const unsubscribe = addEventListener("focus", onFocus);
         | 
| 4139 | 
            +
                return () => {
         | 
| 4590 4140 | 
             
                  unsubscribe();
         | 
| 4591 4141 | 
             
                };
         | 
| 4592 4142 | 
             
              }, [addEventListener, onFocus]);
         | 
| 4593 | 
            -
              useEffect( | 
| 4143 | 
            +
              useEffect(() => {
         | 
| 4594 4144 | 
             
                if (showUserList) {
         | 
| 4595 | 
            -
                   | 
| 4145 | 
            +
                  const unsubscribeArrowUp = addEventListener("arrowUp", event => {
         | 
| 4596 4146 | 
             
                    event.stopPropagation();
         | 
| 4597 4147 | 
             
                    event.preventDefault();
         | 
| 4598 4148 | 
             
                    metionUserListRef.current.prevUser();
         | 
| 4599 4149 | 
             
                  });
         | 
| 4600 | 
            -
                   | 
| 4150 | 
            +
                  const unsubscribeArrowDown = addEventListener("arrowDown", event => {
         | 
| 4601 4151 | 
             
                    event.stopPropagation();
         | 
| 4602 4152 | 
             
                    event.preventDefault();
         | 
| 4603 4153 | 
             
                    metionUserListRef.current.nextUser();
         | 
| 4604 4154 | 
             
                  });
         | 
| 4605 | 
            -
                  return  | 
| 4155 | 
            +
                  return () => {
         | 
| 4606 4156 | 
             
                    unsubscribeArrowUp();
         | 
| 4607 4157 | 
             
                    unsubscribeArrowDown();
         | 
| 4608 4158 | 
             
                  };
         | 
| @@ -4625,9 +4175,7 @@ var MentionWrapper = function MentionWrapper(_ref) { | |
| 4625 4175 | 
             
                className: "react-input-emoji--mention--loading--spinner"
         | 
| 4626 4176 | 
             
              }, "Loading..."))) : showUserList && /*#__PURE__*/React.createElement("div", {
         | 
| 4627 4177 | 
             
                className: "react-input-emoji--mention--container",
         | 
| 4628 | 
            -
                onClick:  | 
| 4629 | 
            -
                  return evt.stopPropagation();
         | 
| 4630 | 
            -
                }
         | 
| 4178 | 
            +
                onClick: evt => evt.stopPropagation()
         | 
| 4631 4179 | 
             
              }, /*#__PURE__*/React.createElement(MentionUserListWithRef, {
         | 
| 4632 4180 | 
             
                ref: metionUserListRef,
         | 
| 4633 4181 | 
             
                mentionSearchText: mentionSearchText,
         | 
| @@ -4646,20 +4194,16 @@ var MentionWrapper = function MentionWrapper(_ref) { | |
| 4646 4194 | 
             
             */
         | 
| 4647 4195 | 
             
            function createObserver() {
         | 
| 4648 4196 | 
             
              /** @type {import('../types/types').Listerner<T>[]} */
         | 
| 4649 | 
            -
               | 
| 4197 | 
            +
              let listeners = [];
         | 
| 4650 4198 | 
             
              return {
         | 
| 4651 | 
            -
                subscribe:  | 
| 4199 | 
            +
                subscribe: listener => {
         | 
| 4652 4200 | 
             
                  listeners.push(listener);
         | 
| 4653 | 
            -
                  return  | 
| 4654 | 
            -
                    listeners = listeners.filter( | 
| 4655 | 
            -
                      return l !== listener;
         | 
| 4656 | 
            -
                    });
         | 
| 4201 | 
            +
                  return () => {
         | 
| 4202 | 
            +
                    listeners = listeners.filter(l => l !== listener);
         | 
| 4657 4203 | 
             
                  };
         | 
| 4658 4204 | 
             
                },
         | 
| 4659 | 
            -
                publish:  | 
| 4660 | 
            -
                  listeners.forEach( | 
| 4661 | 
            -
                    return listener(event);
         | 
| 4662 | 
            -
                  });
         | 
| 4205 | 
            +
                publish: event => {
         | 
| 4206 | 
            +
                  listeners.forEach(listener => listener(event));
         | 
| 4663 4207 | 
             
                },
         | 
| 4664 4208 | 
             
                get currentListerners() {
         | 
| 4665 4209 | 
             
                  return listeners;
         | 
| @@ -4677,28 +4221,26 @@ function createObserver() { | |
| 4677 4221 | 
             
            /** */
         | 
| 4678 4222 | 
             
            function useEventListeners() {
         | 
| 4679 4223 | 
             
              /** @type {TextInputListeners} */
         | 
| 4680 | 
            -
               | 
| 4681 | 
            -
                 | 
| 4682 | 
            -
             | 
| 4683 | 
            -
             | 
| 4684 | 
            -
             | 
| 4685 | 
            -
             | 
| 4686 | 
            -
             | 
| 4687 | 
            -
             | 
| 4688 | 
            -
             | 
| 4689 | 
            -
                };
         | 
| 4690 | 
            -
              }, []);
         | 
| 4224 | 
            +
              const listeners = useMemo(() => ({
         | 
| 4225 | 
            +
                keyDown: createObserver(),
         | 
| 4226 | 
            +
                keyUp: createObserver(),
         | 
| 4227 | 
            +
                arrowUp: createObserver(),
         | 
| 4228 | 
            +
                arrowDown: createObserver(),
         | 
| 4229 | 
            +
                enter: createObserver(),
         | 
| 4230 | 
            +
                focus: createObserver(),
         | 
| 4231 | 
            +
                blur: createObserver()
         | 
| 4232 | 
            +
              }), []);
         | 
| 4691 4233 |  | 
| 4692 4234 | 
             
              /**
         | 
| 4693 4235 | 
             
               * @template {keyof TextInputListeners} T, K
         | 
| 4694 4236 | 
             
               * @type {(event: keyof TextInputListeners, fn: import('../types/types').Listerner<any>) => () => void}
         | 
| 4695 4237 | 
             
               */
         | 
| 4696 | 
            -
               | 
| 4238 | 
            +
              const addEventListener = useCallback((event, fn) => {
         | 
| 4697 4239 | 
             
                return listeners[event].subscribe(fn);
         | 
| 4698 4240 | 
             
              }, [listeners]);
         | 
| 4699 4241 | 
             
              return {
         | 
| 4700 | 
            -
                addEventListener | 
| 4701 | 
            -
                listeners | 
| 4242 | 
            +
                addEventListener,
         | 
| 4243 | 
            +
                listeners
         | 
| 4702 4244 | 
             
              };
         | 
| 4703 4245 | 
             
            }
         | 
| 4704 4246 |  | 
| @@ -4712,23 +4254,23 @@ function useEventListeners() { | |
| 4712 4254 | 
             
            /** */
         | 
| 4713 4255 | 
             
            function usePollute() {
         | 
| 4714 4256 | 
             
              /** @type {React.MutableRefObject<PolluteFn[]>} */
         | 
| 4715 | 
            -
               | 
| 4257 | 
            +
              const polluteFnsRef = useRef([]);
         | 
| 4716 4258 |  | 
| 4717 4259 | 
             
              /** @type {(fn: PolluteFn) => void} */
         | 
| 4718 | 
            -
               | 
| 4260 | 
            +
              const addPolluteFn = useCallback(fn => {
         | 
| 4719 4261 | 
             
                polluteFnsRef.current.push(fn);
         | 
| 4720 4262 | 
             
              }, []);
         | 
| 4721 4263 |  | 
| 4722 4264 | 
             
              /** @type {(html: string) => string} */
         | 
| 4723 | 
            -
               | 
| 4724 | 
            -
                 | 
| 4265 | 
            +
              const pollute = useCallback(text => {
         | 
| 4266 | 
            +
                const result = polluteFnsRef.current.reduce((acc, fn) => {
         | 
| 4725 4267 | 
             
                  return fn(acc);
         | 
| 4726 4268 | 
             
                }, text);
         | 
| 4727 4269 | 
             
                return result;
         | 
| 4728 4270 | 
             
              }, []);
         | 
| 4729 4271 | 
             
              return {
         | 
| 4730 | 
            -
                addPolluteFn | 
| 4731 | 
            -
                pollute | 
| 4272 | 
            +
                addPolluteFn,
         | 
| 4273 | 
            +
                pollute
         | 
| 4732 4274 | 
             
              };
         | 
| 4733 4275 | 
             
            }
         | 
| 4734 4276 |  | 
| @@ -4784,72 +4326,78 @@ function usePollute() { | |
| 4784 4326 | 
             
             * @return {JSX.Element}
         | 
| 4785 4327 | 
             
             */
         | 
| 4786 4328 | 
             
            function InputEmoji(props, ref) {
         | 
| 4787 | 
            -
               | 
| 4788 | 
            -
                 | 
| 4789 | 
            -
                 | 
| 4790 | 
            -
                 | 
| 4791 | 
            -
                 | 
| 4792 | 
            -
                 | 
| 4793 | 
            -
                 | 
| 4794 | 
            -
                 | 
| 4795 | 
            -
                 | 
| 4796 | 
            -
                 | 
| 4797 | 
            -
                 | 
| 4798 | 
            -
                 | 
| 4799 | 
            -
                 | 
| 4800 | 
            -
                 | 
| 4801 | 
            -
                 | 
| 4802 | 
            -
                 | 
| 4803 | 
            -
                 | 
| 4804 | 
            -
                 | 
| 4805 | 
            -
                 | 
| 4806 | 
            -
                 | 
| 4807 | 
            -
                 | 
| 4808 | 
            -
                 | 
| 4809 | 
            -
                 | 
| 4810 | 
            -
                 | 
| 4811 | 
            -
                 | 
| 4812 | 
            -
                 | 
| 4813 | 
            -
                 | 
| 4814 | 
            -
                 | 
| 4815 | 
            -
                 | 
| 4816 | 
            -
                 | 
| 4329 | 
            +
              const {
         | 
| 4330 | 
            +
                onChange,
         | 
| 4331 | 
            +
                onEnter,
         | 
| 4332 | 
            +
                onResize,
         | 
| 4333 | 
            +
                onClick,
         | 
| 4334 | 
            +
                onFocus,
         | 
| 4335 | 
            +
                onBlur,
         | 
| 4336 | 
            +
                onKeyDown,
         | 
| 4337 | 
            +
                theme,
         | 
| 4338 | 
            +
                cleanOnEnter,
         | 
| 4339 | 
            +
                placeholder,
         | 
| 4340 | 
            +
                maxLength,
         | 
| 4341 | 
            +
                keepOpened,
         | 
| 4342 | 
            +
                inputClass,
         | 
| 4343 | 
            +
                disableRecent,
         | 
| 4344 | 
            +
                tabIndex,
         | 
| 4345 | 
            +
                value,
         | 
| 4346 | 
            +
                customEmojis,
         | 
| 4347 | 
            +
                language,
         | 
| 4348 | 
            +
                searchMention,
         | 
| 4349 | 
            +
                buttonElement,
         | 
| 4350 | 
            +
                buttonRef,
         | 
| 4351 | 
            +
                shouldReturn,
         | 
| 4352 | 
            +
                shouldConvertEmojiToImage,
         | 
| 4353 | 
            +
                // style
         | 
| 4354 | 
            +
                borderRadius,
         | 
| 4355 | 
            +
                borderColor,
         | 
| 4356 | 
            +
                fontSize,
         | 
| 4357 | 
            +
                fontFamily,
         | 
| 4358 | 
            +
                background,
         | 
| 4359 | 
            +
                placeholderColor,
         | 
| 4360 | 
            +
                color
         | 
| 4361 | 
            +
              } = props;
         | 
| 4817 4362 |  | 
| 4818 4363 | 
             
              /** @type {React.MutableRefObject<import('./text-input').Ref | null>} */
         | 
| 4819 | 
            -
               | 
| 4820 | 
            -
               | 
| 4821 | 
            -
                addEventListener | 
| 4822 | 
            -
                listeners | 
| 4823 | 
            -
               | 
| 4824 | 
            -
             | 
| 4825 | 
            -
                 | 
| 4826 | 
            -
                 | 
| 4827 | 
            -
             | 
| 4828 | 
            -
             | 
| 4829 | 
            -
             | 
| 4830 | 
            -
             | 
| 4831 | 
            -
                 | 
| 4364 | 
            +
              const textInputRef = useRef(null);
         | 
| 4365 | 
            +
              const {
         | 
| 4366 | 
            +
                addEventListener,
         | 
| 4367 | 
            +
                listeners
         | 
| 4368 | 
            +
              } = useEventListeners();
         | 
| 4369 | 
            +
              const {
         | 
| 4370 | 
            +
                addSanitizeFn,
         | 
| 4371 | 
            +
                sanitize,
         | 
| 4372 | 
            +
                sanitizedTextRef
         | 
| 4373 | 
            +
              } = useSanitize(shouldReturn, shouldConvertEmojiToImage);
         | 
| 4374 | 
            +
              const {
         | 
| 4375 | 
            +
                addPolluteFn,
         | 
| 4376 | 
            +
                pollute
         | 
| 4377 | 
            +
              } = usePollute();
         | 
| 4378 | 
            +
              const updateHTML = useCallback(function () {
         | 
| 4379 | 
            +
                let nextValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
         | 
| 4832 4380 | 
             
                if (textInputRef.current === null) return;
         | 
| 4833 4381 | 
             
                textInputRef.current.html = replaceAllTextEmojis(nextValue);
         | 
| 4834 4382 | 
             
                sanitizedTextRef.current = nextValue;
         | 
| 4835 4383 | 
             
              }, [sanitizedTextRef]);
         | 
| 4836 | 
            -
               | 
| 4384 | 
            +
              const setValue = useCallback(
         | 
| 4837 4385 | 
             
              /**
         | 
| 4838 4386 | 
             
               * 
         | 
| 4839 4387 | 
             
               * @param {string} value
         | 
| 4840 4388 | 
             
               */
         | 
| 4841 | 
            -
               | 
| 4389 | 
            +
              value => {
         | 
| 4842 4390 | 
             
                updateHTML(value);
         | 
| 4843 4391 | 
             
              }, [updateHTML]);
         | 
| 4844 | 
            -
               | 
| 4392 | 
            +
              const emitChange = useEmit(textInputRef, onResize, onChange);
         | 
| 4845 4393 | 
             
              useExpose({
         | 
| 4846 | 
            -
                ref | 
| 4847 | 
            -
                setValue | 
| 4848 | 
            -
                textInputRef | 
| 4849 | 
            -
                emitChange | 
| 4850 | 
            -
                shouldConvertEmojiToImage | 
| 4394 | 
            +
                ref,
         | 
| 4395 | 
            +
                setValue,
         | 
| 4396 | 
            +
                textInputRef,
         | 
| 4397 | 
            +
                emitChange,
         | 
| 4398 | 
            +
                shouldConvertEmojiToImage
         | 
| 4851 4399 | 
             
              });
         | 
| 4852 | 
            -
              useEffect( | 
| 4400 | 
            +
              useEffect(() => {
         | 
| 4853 4401 | 
             
                if (sanitizedTextRef.current !== value) {
         | 
| 4854 4402 | 
             
                  setValue(value);
         | 
| 4855 4403 | 
             
                }
         | 
| @@ -4859,7 +4407,7 @@ function InputEmoji(props, ref) { | |
| 4859 4407 | 
             
              //   updateHTML();
         | 
| 4860 4408 | 
             
              // }, [updateHTML]);
         | 
| 4861 4409 |  | 
| 4862 | 
            -
              useEffect( | 
| 4410 | 
            +
              useEffect(() => {
         | 
| 4863 4411 | 
             
                /**
         | 
| 4864 4412 | 
             
                 * Handle keydown event
         | 
| 4865 4413 | 
             
                 * @param {React.KeyboardEvent} event
         | 
| @@ -4871,7 +4419,7 @@ function InputEmoji(props, ref) { | |
| 4871 4419 | 
             
                  }
         | 
| 4872 4420 | 
             
                  if (event.key === "Enter" && textInputRef.current) {
         | 
| 4873 4421 | 
             
                    event.preventDefault();
         | 
| 4874 | 
            -
                     | 
| 4422 | 
            +
                    const text = sanitize(textInputRef.current.html);
         | 
| 4875 4423 | 
             
                    emitChange(sanitizedTextRef.current);
         | 
| 4876 4424 | 
             
                    if (typeof onEnter === "function" && listeners.enter.currentListerners.length === 0) {
         | 
| 4877 4425 | 
             
                      onEnter(text);
         | 
| @@ -4889,12 +4437,12 @@ function InputEmoji(props, ref) { | |
| 4889 4437 | 
             
                  }
         | 
| 4890 4438 | 
             
                  return true;
         | 
| 4891 4439 | 
             
                }
         | 
| 4892 | 
            -
                 | 
| 4893 | 
            -
                return  | 
| 4440 | 
            +
                const unsubscribe = addEventListener("keyDown", handleKeydown);
         | 
| 4441 | 
            +
                return () => {
         | 
| 4894 4442 | 
             
                  unsubscribe();
         | 
| 4895 4443 | 
             
                };
         | 
| 4896 4444 | 
             
              }, [addEventListener, cleanOnEnter, emitChange, listeners.enter.currentListerners.length, maxLength, onEnter, onKeyDown, sanitize, sanitizedTextRef, updateHTML]);
         | 
| 4897 | 
            -
              useEffect( | 
| 4445 | 
            +
              useEffect(() => {
         | 
| 4898 4446 | 
             
                /** */
         | 
| 4899 4447 | 
             
                function handleFocus() {
         | 
| 4900 4448 | 
             
                  if (typeof onClick === "function") {
         | 
| @@ -4904,20 +4452,20 @@ function InputEmoji(props, ref) { | |
| 4904 4452 | 
             
                    onFocus();
         | 
| 4905 4453 | 
             
                  }
         | 
| 4906 4454 | 
             
                }
         | 
| 4907 | 
            -
                 | 
| 4908 | 
            -
                return  | 
| 4455 | 
            +
                const unsubscribe = addEventListener("focus", handleFocus);
         | 
| 4456 | 
            +
                return () => {
         | 
| 4909 4457 | 
             
                  unsubscribe();
         | 
| 4910 4458 | 
             
                };
         | 
| 4911 4459 | 
             
              }, [addEventListener, onClick, onFocus]);
         | 
| 4912 | 
            -
              useEffect( | 
| 4460 | 
            +
              useEffect(() => {
         | 
| 4913 4461 | 
             
                /** */
         | 
| 4914 4462 | 
             
                function handleBlur() {
         | 
| 4915 4463 | 
             
                  if (typeof onBlur === "function") {
         | 
| 4916 4464 | 
             
                    onBlur();
         | 
| 4917 4465 | 
             
                  }
         | 
| 4918 4466 | 
             
                }
         | 
| 4919 | 
            -
                 | 
| 4920 | 
            -
                return  | 
| 4467 | 
            +
                const unsubscribe = addEventListener("blur", handleBlur);
         | 
| 4468 | 
            +
                return () => {
         | 
| 4921 4469 | 
             
                  unsubscribe();
         | 
| 4922 4470 | 
             
                };
         | 
| 4923 4471 | 
             
              }, [addEventListener, onBlur]);
         | 
| @@ -4952,7 +4500,7 @@ function InputEmoji(props, ref) { | |
| 4952 4500 | 
             
               */
         | 
| 4953 4501 | 
             
              function handlePaste(event) {
         | 
| 4954 4502 | 
             
                event.preventDefault();
         | 
| 4955 | 
            -
                 | 
| 4503 | 
            +
                let content;
         | 
| 4956 4504 | 
             
                if (event.clipboardData) {
         | 
| 4957 4505 | 
             
                  content = event.clipboardData.getData("text/plain");
         | 
| 4958 4506 | 
             
                  content = pollute(content);
         | 
| @@ -4980,13 +4528,13 @@ function InputEmoji(props, ref) { | |
| 4980 4528 | 
             
                onEnter: listeners.enter.publish,
         | 
| 4981 4529 | 
             
                placeholder: placeholder,
         | 
| 4982 4530 | 
             
                style: {
         | 
| 4983 | 
            -
                  borderRadius | 
| 4984 | 
            -
                  borderColor | 
| 4985 | 
            -
                  fontSize | 
| 4986 | 
            -
                  fontFamily | 
| 4987 | 
            -
                  background | 
| 4988 | 
            -
                  placeholderColor | 
| 4989 | 
            -
                  color | 
| 4531 | 
            +
                  borderRadius,
         | 
| 4532 | 
            +
                  borderColor,
         | 
| 4533 | 
            +
                  fontSize,
         | 
| 4534 | 
            +
                  fontFamily,
         | 
| 4535 | 
            +
                  background,
         | 
| 4536 | 
            +
                  placeholderColor,
         | 
| 4537 | 
            +
                  color
         | 
| 4990 4538 | 
             
                },
         | 
| 4991 4539 | 
             
                tabIndex: tabIndex,
         | 
| 4992 4540 | 
             
                className: inputClass,
         | 
| @@ -5004,7 +4552,7 @@ function InputEmoji(props, ref) { | |
| 5004 4552 | 
             
                language: language
         | 
| 5005 4553 | 
             
              }));
         | 
| 5006 4554 | 
             
            }
         | 
| 5007 | 
            -
             | 
| 4555 | 
            +
            const InputEmojiWithRef = /*#__PURE__*/forwardRef(InputEmoji);
         | 
| 5008 4556 | 
             
            InputEmojiWithRef.defaultProps = {
         | 
| 5009 4557 | 
             
              theme: /** @type {const} */"auto",
         | 
| 5010 4558 | 
             
              height: 30,
         |