{"version":3,"file":"static/chunks/Chat.wrapper.d330638da26a3772.js","sources":["webpack://_N_E/./node_modules/flairup/dist/esm/index.js","webpack://_N_E/./src/LegacyApp/client/components/dropdown/dropdown.style.ts","webpack://_N_E/./src/LegacyApp/client/store/dropdown/thunks/dropdownGet.thunk.ts","webpack://_N_E/./src/LegacyApp/client/components/dropdown/dropdown.tsx","webpack://_N_E/./src/LegacyApp/client/components/textarea/textarea.jsx","webpack://_N_E/./src/LegacyApp/client/components/textarea/textarea.container.ts","webpack://_N_E/./src/LegacyApp/client/store/dropdown/dropdown.actions.ts","webpack://_N_E/./src/LegacyApp/client/store/dropdown/methods/dropdownContentEqualityFn.ts","webpack://_N_E/./src/LegacyApp/client/store/dropdown/selectors/useDropdownActiveSelector.ts","webpack://_N_E/./src/LegacyApp/methods/array/removeArrayDuplicates.ts","webpack://_N_E/./src/common/components/auth/AuthActionButton.tsx","webpack://_N_E/./src/common/hooks/useOnUnmount.ts","webpack://_N_E/./src/modules/chat/components/header/chat.header.style.ts","webpack://_N_E/./src/modules/chat/components/message/chat.message.style.ts","webpack://_N_E/./public/img/main/rain.svg","webpack://_N_E/./src/modules/chat/components/message/components/text/index.ts","webpack://_N_E/./src/modules/chat/components/private/privateIcon/NotificationCounter.styled.ts","webpack://_N_E/./src/LegacyApp/client/store/websocket/websocket.types.ts","webpack://_N_E/./src/LegacyApp/client/store/privateMessages/privateMessages.selectors.ts","webpack://_N_E/./src/modules/chat/store/selectors/useChatContentType.ts","webpack://_N_E/./src/modules/chat/store/selectors/useChatPrivateActive.ts","webpack://_N_E/./src/modules/chat/store/selectors/useChatRoom.ts","webpack://_N_E/./src/modules/websocket/components/WebsocketConnectionFailed.tsx","webpack://_N_E/./src/common/selectors/websocket.selectors.ts","webpack://_N_E/./src/common/components/contentLoaders/ChatMessageLoader.tsx","webpack://_N_E/./src/modules/chat/methods/checkIsTriviaMessage.ts","webpack://_N_E/./src/modules/chat/components/message/components/trivia/index.ts","webpack://_N_E/./src/modules/chat/components/message/chatMessage.tsx","webpack://_N_E/./src/modules/chat/components/stream/chatUnreadMessagesCounter.tsx","webpack://_N_E/./src/modules/chat/components/stream/chatStream.tsx","webpack://_N_E/./src/modules/chat/store/selectors/useChatLoaded.ts","webpack://_N_E/./src/modules/chat/components/private/stream/chat.private.stream.jsx","webpack://_N_E/./src/modules/chat/components/private/stream/chat.private.stream.container.ts","webpack://_N_E/./src/modules/chat/components/stream/chatStreamContainer.tsx","webpack://_N_E/./src/modules/chat/store/selectors/useChatStreamList.ts","webpack://_N_E/./src/modules/chat/components/private/privateHistory/chat.private.style.js","webpack://_N_E/./src/modules/chat/components/private/historyList/historyList.style.js","webpack://_N_E/./src/modules/chat/components/private/historyList/historyList.jsx","webpack://_N_E/./src/modules/chat/components/private/historyList/historyList.container.ts","webpack://_N_E/./src/modules/chat/components/private/privateHistory/chat.privateHistory.jsx","webpack://_N_E/./src/modules/chat/components/private/privateHistory/chat.privateHistory.container.ts","webpack://_N_E/./src/LegacyApp/client/components/friendsList/friendsList.tsx","webpack://_N_E/./src/modules/chat/components/friends/chat.friends.jsx","webpack://_N_E/./src/modules/chat/components/friends/chat.friends.container.ts","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetsList/BetsList.tsx","webpack://_N_E/./src/modules/sports/hooks/useBetSlipValidation.ts","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipForm/BetSlipSubmit.tsx","webpack://_N_E/./src/modules/sports/hooks/useValidateBetsListOdds.ts","webpack://_N_E/./src/modules/sports/components/BetSlipSection/ReuseFailedBets/ReuseFailedBets.tsx","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipForm/BetSlipFormOptions.tsx","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipForm/BetSlipFormMultiInput.tsx","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipForm/BetSlipFormMessage.tsx","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipForm/BetSlipForm.tsx","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipForm/BetSlipForm.container.ts","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipSection.styled.js","webpack://_N_E/./src/modules/sports/hooks/useTypeTabsAutoSwitch.ts","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipTypeTabs.tsx","webpack://_N_E/./src/modules/sports/components/BetSlipSection/BetSlipSection.tsx","webpack://_N_E/./src/modules/sports/components/SideContent/Wrapper/SideContentWrapper.tsx","webpack://_N_E/./src/modules/chat/components/content/chatContent.tsx","webpack://_N_E/./src/modules/chat/components/friends/friendsIcon/chat.friends.icon.jsx","webpack://_N_E/./src/modules/chat/components/friends/friendsIcon/chat.friends.icon.container.ts","webpack://_N_E/./src/modules/chat/components/private/privateIcon/chat.private.icon.jsx","webpack://_N_E/./src/modules/chat/components/private/privateIcon/chat.private.icon.container.ts","webpack://_N_E/./src/LegacyApp/client/components/globeIcon/globeIcon.jsx","webpack://_N_E/./src/LegacyApp/client/components/globeIcon/globeIcon.container.ts","webpack://_N_E/./src/modules/chat/components/header/chat.roomSelect.tsx","webpack://_N_E/./src/modules/chat/components/header/chat.header.container.tsx","webpack://_N_E/./src/modules/chat/constants/CHAT_FEATURES.ts","webpack://_N_E/./src/modules/chat/store/thunks/getChatFeatures.thunk.ts","webpack://_N_E/./src/modules/chat/methods/getChatFeatures.ts","webpack://_N_E/./src/modules/chat/store/thunks/checkChatFeatureListActiveThunk.ts","webpack://_N_E/./src/modules/chat/methods/getDataQuery.ts","webpack://_N_E/./src/modules/chat/store/selectors/useChatMessage.ts","webpack://_N_E/./src/modules/chat/components/chat.list/chatListStyle.ts","webpack://_N_E/./src/modules/chat/components/chat.list/chat.list.tsx","webpack://_N_E/./src/modules/chat/components/chat.list/chat.featuresList.tsx","webpack://_N_E/./src/modules/chat/components/EmojiPickerWrapper/emojiPickerWrapper.tsx","webpack://_N_E/./src/modules/chat/store/thunks/checkUsersListActiveThunk.ts","webpack://_N_E/./src/modules/chat/components/chat.list/chat.usersList.tsx","webpack://_N_E/./src/modules/chat/store/selectors/useChatUsers.ts","webpack://_N_E/./src/modules/chat/methods/regexFeatureWithoutParameter.ts","webpack://_N_E/./src/modules/chat/store/thunks/getChatFeature.thunk.ts","webpack://_N_E/./src/modules/chat/store/thunks/matchFeature.thunk.ts","webpack://_N_E/./src/modules/chat/methods/regexFeatureWithParameter.ts","webpack://_N_E/./node_modules/uuid-v4-validator/lib/esm/UUIDv4/index.js","webpack://_N_E/./src/modules/chat/store/thunks/chatBetHandle.thunk.ts","webpack://_N_E/./src/modules/chat/store/thunks/chatSessionHandle.thunk.ts","webpack://_N_E/./src/modules/chat/store/thunks/chatUserHandle.thunk.ts","webpack://_N_E/./src/modules/chat/store/thunks/chatPrivateMessageHandle.thunk.ts","webpack://_N_E/./src/modules/chat/store/thunks/chatIgnoreHandle.thunk.ts","webpack://_N_E/./src/modules/chat/store/thunks/chatFeatureHandle.thunk.ts","webpack://_N_E/./src/modules/chat/components/wrapper/chat.styled.ts","webpack://_N_E/./src/modules/chat/components/input/chat.input.style.ts","webpack://_N_E/./src/modules/chat/components/input/chatInput.tsx","webpack://_N_E/./src/modules/chat/components/private/activeList/ChatActiveTabs.style.js","webpack://_N_E/./src/modules/chat/components/private/activeList/ChatActiveTabs.jsx","webpack://_N_E/./src/modules/chat/components/private/activeList/ChatActiveTabs.container.ts","webpack://_N_E/./src/modules/chat/components/wrapper/Chat.wrapper.tsx","webpack://_N_E/./src/modules/chat/constants/MESSAGE_COMPARE_KEYS.ts","webpack://_N_E/./src/modules/chat/context/chatMessage.context.ts","webpack://_N_E/./src/modules/chat/context/chatStream.context.ts","webpack://_N_E/./src/modules/chat/methods/getMessageId.ts","webpack://_N_E/./src/modules/chat/methods/addShareDetails.ts","webpack://_N_E/./src/modules/chat/store/thunks/sendMessage.thunk.tsx"],"sourceRoot":"","sourcesContent":["// src/utils/asArray.ts\nfunction asArray(v) {\n  return [].concat(v);\n}\n\n// src/utils/is.ts\nfunction isPsuedoSelector(selector) {\n  return selector.startsWith(\":\");\n}\nfunction isStyleCondition(selector) {\n  return isString(selector) && (selector === \"*\" || selector.length > 1 && \":>~.+*\".includes(selector.slice(0, 1)) || isImmediatePostcondition(selector));\n}\nfunction isValidProperty(property, value) {\n  return (isString(value) || typeof value === \"number\") && !isCssVariables(property) && !isPsuedoSelector(property) && !isMediaQuery(property);\n}\nfunction isMediaQuery(selector) {\n  return selector.startsWith(\"@media\");\n}\nfunction isDirectClass(selector) {\n  return selector === \".\";\n}\nfunction isCssVariables(selector) {\n  return selector === \"--\";\n}\nfunction isString(value) {\n  return value + \"\" === value;\n}\nfunction isImmediatePostcondition(value) {\n  return isString(value) && (value.startsWith(\"&\") || isPsuedoSelector(value));\n}\n\n// src/utils/joinTruthy.ts\nfunction joinTruthy(arr, delimiter = \"\") {\n  return arr.filter(Boolean).join(delimiter);\n}\n\n// src/utils/stableHash.ts\nfunction stableHash(prefix, seed) {\n  let hash = 0;\n  if (seed.length === 0)\n    return hash.toString();\n  for (let i = 0; i < seed.length; i++) {\n    const char = seed.charCodeAt(i);\n    hash = (hash << 5) - hash + char;\n    hash = hash & hash;\n  }\n  return `${prefix ?? \"cl\"}_${hash.toString(36)}`;\n}\n\n// src/utils/stringManipulators.ts\nfunction handlePropertyValue(property, value) {\n  if (property === \"content\") {\n    return `\"${value}\"`;\n  }\n  return value;\n}\nfunction camelCaseToDash(str) {\n  return str.replace(/([a-z])([A-Z])/g, \"$1-$2\").toLowerCase();\n}\nfunction joinedProperty(property, value) {\n  return `${property}:${value}`;\n}\nfunction toClass(str) {\n  return str ? `.${str}` : \"\";\n}\nfunction appendString(base, line) {\n  return base ? `${base}\n${line}` : line;\n}\n\n// src/Rule.ts\nvar Rule = class _Rule {\n  constructor(sheet, property, value, selector) {\n    this.sheet = sheet;\n    this.property = property;\n    this.value = value;\n    this.selector = selector;\n    this.property = property;\n    this.value = value;\n    this.joined = joinedProperty(property, value);\n    const joinedConditions = this.selector.preconditions.concat(\n      this.selector.postconditions\n    );\n    this.hash = this.selector.hasConditions ? this.selector.scopeClassName : stableHash(this.sheet.name, this.joined);\n    this.key = joinTruthy([this.joined, joinedConditions, this.hash]);\n  }\n  toString() {\n    let selectors = mergeSelectors(this.selector.preconditions, {\n      right: this.hash\n    });\n    selectors = mergeSelectors(this.selector.postconditions, {\n      left: selectors\n    });\n    return `${selectors} {${_Rule.genRule(this.property, this.value)}}`;\n  }\n  static genRule(property, value) {\n    const transformedProperty = camelCaseToDash(property);\n    return joinedProperty(\n      transformedProperty,\n      handlePropertyValue(property, value)\n    ) + \";\";\n  }\n};\nfunction mergeSelectors(selectors, { left = \"\", right = \"\" } = {}) {\n  const output = selectors.reduce((selectors2, current) => {\n    if (isPsuedoSelector(current)) {\n      return selectors2 + current;\n    }\n    if (isImmediatePostcondition(current)) {\n      return selectors2 + current.slice(1);\n    }\n    return joinTruthy([selectors2, current], \" \");\n  }, left);\n  return joinTruthy([output, toClass(right)], \" \");\n}\nvar Selector = class _Selector {\n  constructor(sheet, scopeName = null, {\n    preconditions,\n    postconditions\n  } = {}) {\n    this.sheet = sheet;\n    this.preconditions = [];\n    this.scopeClassName = null;\n    this.scopeName = null;\n    this.postconditions = [];\n    this.preconditions = preconditions ? asArray(preconditions) : [];\n    this.postconditions = postconditions ? asArray(postconditions) : [];\n    this.setScope(scopeName);\n  }\n  setScope(scopeName) {\n    if (!scopeName) {\n      return this;\n    }\n    if (!this.scopeClassName) {\n      this.scopeName = scopeName;\n      this.scopeClassName = stableHash(\n        this.sheet.name,\n        // adding the count guarantees uniqueness across style.create calls\n        scopeName + this.sheet.count\n      );\n    }\n    return this;\n  }\n  get hasConditions() {\n    return this.preconditions.length > 0 || this.postconditions.length > 0;\n  }\n  addScope(scopeName) {\n    return new _Selector(this.sheet, scopeName, {\n      preconditions: this.preconditions,\n      postconditions: this.postconditions\n    });\n  }\n  addPrecondition(precondition) {\n    return new _Selector(this.sheet, this.scopeClassName, {\n      postconditions: this.postconditions,\n      preconditions: this.preconditions.concat(precondition)\n    });\n  }\n  addPostcondition(postcondition) {\n    return new _Selector(this.sheet, this.scopeClassName, {\n      preconditions: this.preconditions,\n      postconditions: this.postconditions.concat(postcondition)\n    });\n  }\n  createRule(property, value) {\n    return new Rule(this.sheet, property, value, this);\n  }\n};\n\n// src/Sheet.ts\nvar Sheet = class {\n  constructor(name, rootNode) {\n    this.name = name;\n    this.rootNode = rootNode;\n    // Hash->css\n    this.storedStyles = {};\n    // styles->hash\n    this.storedClasses = {};\n    this.style = \"\";\n    this.count = 0;\n    this.id = `flairup-${name}`;\n    this.styleTag = this.createStyleTag();\n  }\n  getStyle() {\n    return this.style;\n  }\n  append(css) {\n    this.style = appendString(this.style, css);\n  }\n  apply() {\n    this.count++;\n    if (!this.styleTag) {\n      return;\n    }\n    this.styleTag.innerHTML = this.style;\n  }\n  isApplied() {\n    return !!this.styleTag;\n  }\n  createStyleTag() {\n    if (typeof document === \"undefined\" || this.isApplied() || // Explicitly disallow mounting to the DOM\n    this.rootNode === null) {\n      return this.styleTag;\n    }\n    const styleTag = document.createElement(\"style\");\n    styleTag.type = \"text/css\";\n    styleTag.id = this.id;\n    (this.rootNode ?? document.head).appendChild(styleTag);\n    return styleTag;\n  }\n  addRule(rule) {\n    const storedClass = this.storedClasses[rule.key];\n    if (isString(storedClass)) {\n      return storedClass;\n    }\n    this.storedClasses[rule.key] = rule.hash;\n    this.storedStyles[rule.hash] = [rule.property, rule.value];\n    this.append(rule.toString());\n    return rule.hash;\n  }\n};\n\n// src/utils/forIn.ts\nfunction forIn(obj, fn) {\n  for (const key in obj) {\n    fn(key.trim(), obj[key]);\n  }\n}\n\n// src/cx.ts\nfunction cx(...args) {\n  const classes = args.reduce((classes2, arg) => {\n    if (arg instanceof Set) {\n      classes2.push(...arg);\n    } else if (typeof arg === \"string\") {\n      classes2.push(arg);\n    } else if (Array.isArray(arg)) {\n      classes2.push(cx(...arg));\n    } else if (typeof arg === \"object\") {\n      Object.entries(arg).forEach(([key, value]) => {\n        if (value) {\n          classes2.push(key);\n        }\n      });\n    }\n    return classes2;\n  }, []);\n  return joinTruthy(classes, \" \").trim();\n}\n\n// src/index.ts\nfunction createSheet(name, rootNode) {\n  const sheet = new Sheet(name, rootNode);\n  return {\n    create,\n    getStyle: sheet.getStyle.bind(sheet),\n    isApplied: sheet.isApplied.bind(sheet)\n  };\n  function create(styles) {\n    const scopedStyles = {};\n    iteratePreconditions(sheet, styles, new Selector(sheet)).forEach(\n      ([scopeName, styles2, selector]) => {\n        iterateStyles(sheet, styles2, selector).forEach(\n          (className) => {\n            addScopedStyle(scopeName, className);\n          }\n        );\n      }\n    );\n    sheet.apply();\n    return scopedStyles;\n    function addScopedStyle(name2, className) {\n      scopedStyles[name2] = scopedStyles[name2] ?? /* @__PURE__ */ new Set();\n      scopedStyles[name2].add(className);\n    }\n  }\n}\nfunction iteratePreconditions(sheet, styles, selector) {\n  const output = [];\n  forIn(styles, (key, value) => {\n    if (isStyleCondition(key)) {\n      return iteratePreconditions(\n        sheet,\n        value,\n        selector.addPrecondition(key)\n      ).forEach((item) => output.push(item));\n    }\n    output.push([key, styles[key], selector.addScope(key)]);\n  });\n  return output;\n}\nfunction iterateStyles(sheet, styles, selector) {\n  const output = /* @__PURE__ */ new Set();\n  forIn(styles, (property, value) => {\n    let res = [];\n    if (isStyleCondition(property)) {\n      res = iterateStyles(\n        sheet,\n        value,\n        selector.addPostcondition(property)\n      );\n    } else if (isDirectClass(property)) {\n      res = asArray(value);\n    } else if (isMediaQuery(property)) {\n      res = handleMediaQuery(sheet, value, property, selector);\n    } else if (isCssVariables(property)) {\n      res = cssVariablesBlock(sheet, value, selector);\n    } else if (isValidProperty(property, value)) {\n      const rule = selector.createRule(property, value);\n      sheet.addRule(rule);\n      output.add(rule.hash);\n    }\n    return addEachClass(res, output);\n  });\n  return output;\n}\nfunction addEachClass(list, to) {\n  list.forEach((className) => to.add(className));\n  return to;\n}\nfunction cssVariablesBlock(sheet, styles, selector) {\n  const classes = /* @__PURE__ */ new Set();\n  const chunkRows = [];\n  forIn(styles, (property, value) => {\n    if (isValidProperty(property, value)) {\n      chunkRows.push(Rule.genRule(property, value));\n      return;\n    }\n    const res = iterateStyles(sheet, value ?? {}, selector);\n    addEachClass(res, classes);\n  });\n  if (!selector.scopeClassName) {\n    return classes;\n  }\n  if (chunkRows.length) {\n    const output = chunkRows.join(\" \");\n    sheet.append(\n      `${mergeSelectors(selector.preconditions, {\n        right: selector.scopeClassName\n      })} {${output}}`\n    );\n  }\n  classes.add(selector.scopeClassName);\n  return classes;\n}\nfunction handleMediaQuery(sheet, styles, mediaQuery, selector) {\n  sheet.append(mediaQuery + \" {\");\n  const output = iterateStyles(sheet, styles, selector);\n  sheet.append(\"}\");\n  return output;\n}\nexport {\n  createSheet,\n  cx\n};\n//# sourceMappingURL=index.js.map","import styled, { css } from 'styled-components';\nimport { DropdownProps } from '@legacyApp/client/components/dropdown/dropdown';\nimport classnames from 'classnames';\nimport { boxNoHeight } from '../../modules/style/defaults';\n\nconst getProps = (props: { localTheme: DropdownProps['localTheme'] }) => {\n\tif (!props.localTheme || !Object.keys(props.localTheme).length) {\n\t\treturn '';\n\t}\n\tif (props.localTheme && props.localTheme.default) {\n\t\treturn css`\n\t\t\t.button {\n\t\t\t\tfont-family: ${(props) => props.theme.text.fonts.Bold};\n\t\t\t\theight: unset;\n\t\t\t\tmargin: 0 !important;\n\t\t\t\tpadding: 7px 15px;\n\n\t\t\t\t&.icon-wrapper {\n\t\t\t\t\tpadding-right: 30px;\n\n\t\t\t\t\ti,\n\t\t\t\t\tsvg {\n\t\t\t\t\t\tright: 10px;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t`;\n\t}\n};\n\nexport const DropdownStyle = styled.div.attrs<{\n\tclassName: string;\n\tlocalTheme: DropdownProps['localTheme'];\n}>((props) => ({\n\tclassName: classnames('dropdown', props.className),\n}))<{\n\tclassName: string;\n\tlocalTheme: DropdownProps['localTheme'];\n}>`\n\t${boxNoHeight};\n\tposition: relative;\n\twidth: unset;\n\tpadding-bottom: 7px;\n\tmargin-bottom: -7px;\n\n\t* {\n\t\tcursor: pointer !important;\n\t}\n\n\t&[data-id*='when-name'] {\n\t\t* {\n\t\t\ttext-transform: capitalize;\n\t\t}\n\t}\n\n\t${(props) =>\n\t\tprops.localTheme?.error\n\t\t\t? css`\n\t\t\t\t\tbutton:first-of-type {\n\t\t\t\t\t\tborder: 1px solid red;\n\t\t\t\t\t}\n\t\t\t  `\n\t\t\t: null}\n\n\t${getProps}\n`;\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { DropdownContentData } from '@legacyApp/client/store/dropdown/dropdown.reducer';\n\nexport const dropdownGetThunk = (id: string): AppThunk<DropdownContentData> => {\n\treturn (dispatch, getState) => {\n\t\tconst state = getState();\n\t\treturn state.dropdown.content[id];\n\t};\n};\n","import React, { FC, PropsWithChildren, useCallback, useEffect } from 'react';\nimport { Button } from '@ui/button';\nimport { DropdownArrow } from '@ui/dropdown/DropdownArrow';\nimport { InputStyleType } from '@uiTypes/InputStyleType';\nimport { ButtonStyleType } from '@uiTypes/ButtonStyleType';\nimport { dropdownGetThunk } from '@legacyApp/client/store/dropdown/thunks/dropdownGet.thunk';\nimport { useOnUnmount } from '@common/hooks/useOnUnmount';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { DropdownContentData } from '@legacyApp/client/store/dropdown/dropdown.reducer';\nimport { useDropdownActiveSelector } from '@legacyApp/client/store/dropdown/selectors/useDropdownActiveSelector';\nimport { dropdownContentEqualityFn } from '@legacyApp/client/store/dropdown/methods/dropdownContentEqualityFn';\nimport {\n\tdropdownAdd,\n\tdropdownDelete,\n\tdropdownToggle,\n} from '../../store/dropdown/dropdown.actions';\nimport { Trans } from '../../modules/translation/translate';\nimport { DropdownStyle } from './dropdown.style';\n\nexport interface DropdownProps extends DropdownContentData {\n\tactive?: string;\n\tid: string; // isRequired\n\thelp?: any;\n\tlocalTheme?: {\n\t\terror?: boolean;\n\t\tdefault?: boolean;\n\t};\n}\n\nexport const Dropdown: FC<PropsWithChildren<DropdownProps>> = (props) => {\n\tconst active = useDropdownActiveSelector(props.id);\n\tconst close = useDispatchCallback(dropdownDelete);\n\tconst add = useDispatchCallback(dropdownAdd);\n\tconst toggle = useDispatchCallback(dropdownToggle);\n\tconst get = useDispatchCallback(dropdownGetThunk);\n\n\tconst addContent = useCallback(() => {\n\t\tif (!props.items) {\n\t\t\treturn;\n\t\t}\n\t\tconst lastContent: DropdownContentData = get(props.id);\n\t\tconst content: DropdownContentData = {\n\t\t\tscrollElement: props.scrollElement,\n\t\t\titems: props.items,\n\t\t\ttitle: props.title,\n\t\t\tonClick: props.onClick,\n\t\t\twidth: props.width,\n\t\t\tclassName: props.className,\n\t\t\tcss: props.css,\n\t\t\ttrans: props.trans,\n\t\t\titemElement: props.itemElement,\n\t\t};\n\t\tif (lastContent && dropdownContentEqualityFn(content, lastContent)) {\n\t\t\treturn;\n\t\t}\n\t\tadd({\n\t\t\tid: props.id,\n\t\t\tcontent: content,\n\t\t});\n\t}, [add, get, props]);\n\n\tconst toggleList = () => {\n\t\tif (props.items) {\n\t\t\ttoggle({\n\t\t\t\tid: props.id,\n\t\t\t\tbool: !active,\n\t\t\t});\n\t\t}\n\t};\n\n\tuseOnUnmount(() => {\n\t\tif (props.items) {\n\t\t\tclose(props.id);\n\t\t}\n\t});\n\n\tuseEffect(() => {\n\t\taddContent();\n\t}, [addContent]);\n\n\treturn (\n\t\t<DropdownStyle\n\t\t\tlocalTheme={props.localTheme}\n\t\t\tdata-id={props.id}\n\t\t\tonClick={!props.children ? undefined : toggleList}\n\t\t\tclassName={props.className}\n\t\t>\n\t\t\t{props.children ? (\n\t\t\t\tprops.children\n\t\t\t) : (\n\t\t\t\t<Button\n\t\t\t\t\tonClick={toggleList}\n\t\t\t\t\tname=\"dropdown-active\"\n\t\t\t\t\tstyleType={ButtonStyleType.SECONDARY}\n\t\t\t\t\tborderType={InputStyleType.SQUARE}\n\t\t\t\t\tclassName=\"icon-wrapper\"\n\t\t\t\t\tlabel={\n\t\t\t\t\t\tprops.trans ? (\n\t\t\t\t\t\t\t<Trans\n\t\t\t\t\t\t\t\tlabel={props.active}\n\t\t\t\t\t\t\t\tnamespace={\n\t\t\t\t\t\t\t\t\ttypeof props.trans === 'boolean' ? undefined : props.trans\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\tprops.active\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t\t{!!props.items && <DropdownArrow />}\n\t\t\t\t</Button>\n\t\t\t)}\n\t\t\t{props.help}\n\t\t</DropdownStyle>\n\t);\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { translationService } from '../../modules/translation/translationService';\nimport { enhanceComponent } from '../../wrappers/enhanceComponent';\nimport { InputStyle } from '../input/styled/input.style';\n\nclass Textarea extends React.PureComponent {\n\tstatic propTypes = {\n\t\tt: PropTypes.func,\n\t\trows: PropTypes.any,\n\t\tid: PropTypes.string,\n\t\tvalue: PropTypes.any,\n\t\tplaceholder: PropTypes.any,\n\t\tonChange: PropTypes.any,\n\t\tonKeyDown: PropTypes.any,\n\t};\n\n\tconstructor(props) {\n\t\tsuper(props);\n\t\tthis.state = {\n\t\t\tvalue: props.value,\n\t\t};\n\t\tthis.input = React.createRef();\n\t}\n\n\tcomponentDidUpdate(prevProps) {\n\t\tif (\n\t\t\tthis.props.value !== this.state.value &&\n\t\t\tthis.props.value !== prevProps.value\n\t\t) {\n\t\t\tthis.setState({\n\t\t\t\tvalue: this.props.value,\n\t\t\t});\n\t\t}\n\t}\n\n\tonChange = (e) => {\n\t\tthis.setState({\n\t\t\tvalue: this.props.onChange(e.target.value),\n\t\t});\n\t};\n\n\thandleKeyboard = (obj) => {\n\t\tif (!this.input.current || this.input.current !== document.activeElement) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.props.onKeyDown) {\n\t\t\tthis.props.onKeyDown(obj);\n\t\t}\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<InputStyle\n\t\t\t\tas={'textarea'}\n\t\t\t\tid={this.props.id}\n\t\t\t\tref={this.input}\n\t\t\t\trows={this.props.rows || 1}\n\t\t\t\tvalue={this.state.value}\n\t\t\t\tplaceholder={translationService.translateString(\n\t\t\t\t\tthis.props.placeholder,\n\t\t\t\t\tthis.props.t,\n\t\t\t\t)}\n\t\t\t\tonChange={this.onChange}\n\t\t\t\tonKeyDown={this.handleKeyboard}\n\t\t\t/>\n\t\t);\n\t}\n}\n\nTextarea = enhanceComponent({\n\tTextarea,\n});\n\nexport { Textarea };\n","import { compose } from 'redux';\nimport { withTranslation } from 'next-i18next';\nimport { DEFAULT_NAMESPACE } from '../../modules/translation/translate.constants';\nimport { Textarea } from './textarea';\n\nconst TextareaContainer = compose(withTranslation(DEFAULT_NAMESPACE))(Textarea);\n\nexport { TextareaContainer };\n","import { DropdownContentData } from '@legacyApp/client/store/dropdown/dropdown.reducer';\nimport { actionSimple } from '../../modules/app/actionService';\nimport {\n\tDROPDOWN_ADD,\n\tDROPDOWN_DELETE,\n\tDROPDOWN_SET_ACTIVE,\n\tDROPDOWN_SET_CONTENT,\n\tDROPDOWN_TOGGLE,\n} from './dropdown.constants';\n\nexport const dropdownSetActive = actionSimple<{\n\tid: string;\n}>(DROPDOWN_SET_ACTIVE);\nexport const dropdownSetContent = actionSimple<{\n\tid: string;\n\tcontent: DropdownContentData;\n}>(DROPDOWN_SET_CONTENT);\nexport const dropdownDelete = actionSimple<string>(DROPDOWN_DELETE);\nexport const dropdownAdd = actionSimple<{\n\tid: string;\n\tcontent: DropdownContentData;\n}>(DROPDOWN_ADD);\nexport const dropdownToggle = actionSimple<{\n\tid: string;\n\tbool: boolean;\n}>(DROPDOWN_TOGGLE);\n","import { DropdownContentData } from '@legacyApp/client/store/dropdown/dropdown.reducer';\nimport transactionService from '@modules/transactions/transactionsService';\n\nexport const dropdownContentEqualityFn = (\n\ta: DropdownContentData,\n\tb: DropdownContentData,\n) => {\n\treturn !transactionService.isListDifferent(a?.items, b?.items, [\n\t\t'id',\n\t\t'name',\n\t\t'value',\n\t\t'disabled',\n\t\t'className',\n\t]);\n};\n","import { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport { shallowEqual } from 'react-redux';\n\nexport const useDropdownActiveSelector = (id: string) =>\n\tuseAppSelector((state) => state.dropdown.active[id], shallowEqual);\n","import uniq from 'lodash.uniq';\n\nexport const removeArrayDuplicates = (array) => {\n\treturn uniq(array);\n};\n","import { FC, PropsWithChildren } from 'react';\nimport { Button, ButtonProps } from '@ui/button';\nimport {\n\tTrans,\n\tTransProps,\n} from '@legacyApp/client/modules/translation/translate';\nimport { openModal } from '@modules/modals/store/modal.actions';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { MODAL_ID } from '@common/constants/modal/ids.modal.constants';\nimport { useUserIsLogged } from '@common/selectors/user.selectors';\n\nexport const AuthActionButton: FC<\n\tPropsWithChildren<{\n\t\tlabelText?: string | TransProps;\n\t\tprops?: ButtonProps;\n\t}>\n> = ({ labelText, children, props }) => {\n\tconst isLogged = useUserIsLogged();\n\tconst dispatch = useAppDispatch();\n\n\tif (!isLogged || !children) {\n\t\treturn (\n\t\t\t<Button\n\t\t\t\tlabel={<Trans label={labelText || 'Available after registration'} />}\n\t\t\t\tonClick={(): ReturnType<typeof dispatch> =>\n\t\t\t\t\tdispatch(openModal(MODAL_ID.NEW_ACCOUNT, 'auth_action_button'))\n\t\t\t\t}\n\t\t\t\tname={'submit-not-auth'}\n\t\t\t\t{...props}\n\t\t\t/>\n\t\t);\n\t}\n\n\treturn <>{children}</>;\n};\n","import { EffectCallback, useEffect } from 'react';\n\nexport const useOnUnmount = (callback: EffectCallback) => {\n\tuseEffect(() => {\n\t\treturn () => {\n\t\t\tcallback();\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, []);\n};\n","import styled, { css } from 'styled-components';\nimport { Button } from '@ui/button';\nimport { boxNoHeight } from '@legacyApp/client/modules/style/defaults';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\nimport { HeaderHeight } from '../../../header/Header.styled';\n\nexport const ChatHeaderStyle = styled.div.attrs(() => ({\n\tclassName: 'chat-header',\n}))`\n\t${boxNoHeight};\n\t${HeaderHeight(\n\t\t(height) => css`\n\t\t\theight: ${height};\n\t\t`,\n\t)};\n\tbackground-color: var(--color-dark-800);\n\tdisplay: flex;\n\talign-items: center;\n\tpadding: 0 5px;\n\tjustify-content: space-between;\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n\t\tpadding: 10px;\n\t}\n`;\n\nexport const ChatButtonsStyle = styled.div`\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-end;\n\n\tsvg {\n\t\twidth: 1em;\n\t}\n`;\n\nexport const ChatButtonStyle = styled(Button)`\n\talign-items: center;\n\tdisplay: flex;\n\tflex-direction: column;\n\tjustify-content: center;\n\tmargin: 0 10px;\n\tpadding: 0 !important;\n\n\t& > div {\n\t\tdisplay: flex;\n\t}\n\n\ti,\n\tsvg {\n\t\t${fontSize({\n\t\t\tsize: '16px',\n\t\t\tsizeDesktop: '18px',\n\t\t})};\n\t\tpadding-bottom: 2px;\n\t\ttransition: ${(props) => props.theme.layout.transition};\n\t}\n\n\tsvg {\n\t\t${fontSize({\n\t\t\tsize: '16px',\n\t\t\tsizeDesktop: '18px',\n\t\t\tlabel: 'height',\n\t\t})};\n\t}\n\n\t&:hover {\n\t\topacity: 0.7;\n\t}\n`;\n","import styled, { css } from 'styled-components';\nimport classnames from 'classnames';\nimport { rgba } from 'polished';\nimport { StyledVipIcon } from '@ui/vip-icon/VipIcon.styled';\nimport { StyledUserName } from '@ui/user-name/user-name.styled';\nimport {\n\tborderRadius,\n\tboxNoHeight,\n} from '@legacyApp/client/modules/style/defaults';\nimport { borderRadiusValue } from '@legacyApp/client/modules/style/mixins';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\nimport { calcStyle } from '@legacyApp/client/modules/style/methods/calcStyle';\nimport { CSSClassNameButton } from '@ui/button';\nimport RainAnimation from '@public/img/main/rain.svg';\nimport { MessageTextStyled } from '@modules/chat/components/message/components/text/MessageTextStyled';\n\nconst getBackground = (props) => {\n\tif (props.isMyMessage) {\n\t\treturn rgba(props.theme.colors.inputButton, 0.15);\n\t}\n\tif (props.isBotMessage) {\n\t\treturn rgba(props.theme.colors.inputButton, 0.25);\n\t}\n\tif (props.isPrivate) {\n\t\treturn rgba('white', 0.05);\n\t}\n\treturn rgba('white', 0.01);\n};\n\nconst getPrivateMessage = (props) => {\n\tif (!props.isPrivate) {\n\t\treturn '';\n\t}\n\treturn css`\n\t\tclear: both;\n\t\tmax-width: 90%;\n\t\tmin-width: 20%;\n\t\twidth: auto;\n\n\t\t&:before {\n\t\t\tborder-style: solid;\n\t\t\tbottom: 0;\n\t\t\tcontent: '';\n\t\t\theight: 0;\n\t\t\tline-height: 0;\n\t\t\tposition: absolute;\n\t\t\twidth: 0;\n\t\t}\n\n\t\t${props.isMyMessage\n\t\t\t? css`\n\t\t\t\t\tborder-bottom-right-radius: 0 !important;\n\t\t\t\t\tfloat: right;\n\t\t\t\t\tmargin-right: 10px;\n\n\t\t\t\t\t&:before {\n\t\t\t\t\t\tborder-color: transparent transparent transparent\n\t\t\t\t\t\t\t${getBackground(props)};\n\t\t\t\t\t\tborder-width: 7px 0 0 10px;\n\t\t\t\t\t\tright: -10px;\n\t\t\t\t\t}\n\t\t\t  `\n\t\t\t: css`\n\t\t\t\t\tborder-bottom-left-radius: 0 !important;\n\t\t\t\t\tfloat: left;\n\t\t\t\t\tmargin-left: 10px;\n\n\t\t\t\t\t&:before {\n\t\t\t\t\t\tborder-color: transparent transparent ${getBackground(props)}\n\t\t\t\t\t\t\ttransparent;\n\t\t\t\t\t\tborder-width: 0 0 7px 10px;\n\t\t\t\t\t\tleft: -10px;\n\t\t\t\t\t}\n\t\t\t  `}\n\t`;\n};\n\nconst getNew = (props) =>\n\tprops.new\n\t\t? css`\n\t\t\t\tleft: 5px;\n\t\t\t\ttext-transform: uppercase;\n\t\t\t\twidth: calc(100% - 10px);\n\n\t\t\t\tspan {\n\t\t\t\t\tbackground: #0c1420;\n\t\t\t\t\tcolor: ${props.theme.colors.orange};\n\t\t\t\t\tleft: 10px;\n\t\t\t\t\tline-height: 1;\n\t\t\t\t\tpadding: 0 5px;\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\ttop: 50%;\n\t\t\t\t\ttransform: translateY(-50%);\n\t\t\t\t\t${fontSize({\n\t\t\t\t\t\tsizeDiff: -3,\n\t\t\t\t\t\tsizeDesktop: calcStyle({\n\t\t\t\t\t\t\ta: props.theme.text.size.default,\n\t\t\t\t\t\t\tb: 1,\n\t\t\t\t\t\t\tmode: '-',\n\t\t\t\t\t\t}),\n\t\t\t\t\t\tsizeBigScreen: calcStyle({\n\t\t\t\t\t\t\ta: props.theme.text.size.desktop,\n\t\t\t\t\t\t\tb: 3,\n\t\t\t\t\t\t\tmode: '-',\n\t\t\t\t\t\t}),\n\t\t\t\t\t\timportant: true,\n\t\t\t\t\t})}\n\t\t\t\t}\n\n\t\t\t\t&:before {\n\t\t\t\t\tbackground-color: ${props.theme.colors.orange};\n\t\t\t\t\tcontent: '';\n\t\t\t\t\tdisplay: block;\n\t\t\t\t\theight: 1px;\n\t\t\t\t\tleft: 0;\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\ttop: calc(50% + 1px);\n\t\t\t\t\ttransform: translateY(-50%);\n\t\t\t\t\twidth: 100%;\n\t\t\t\t\tz-index: -1;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n\nexport interface ChatMessageStyleProps {\n\tnew?: boolean;\n\tisMyMessage?: boolean;\n\tisBotMessage?: boolean;\n\tisPrivate?: boolean;\n}\n\nexport const ChatMessageStyle = styled.div.attrs<ChatMessageStyleProps>(\n\t(props) => ({\n\t\tclassName: classnames('chat-stream__message', {\n\t\t\t'chat-stream__new-message': props.new,\n\t\t}),\n\t}),\n)<ChatMessageStyleProps>`\n\t${boxNoHeight};\n\tuser-select: text;\n\tbackground-color: ${getBackground};\n\tmargin-top: 5px;\n\tpadding: 5px;\n\t${borderRadius};\n\tline-height: 1.5;\n\tfont-family: ${(props) => props.theme.text.fonts.Regular};\n\tcolor: ${(props) => props.theme.colors.veryLightBlue};\n\tposition: relative;\n\t${(props) => (props.isPrivate ? '' : 'overflow-x: hidden;')}\n\t${(props) =>\n\t\tfontSize({\n\t\t\tsizeDiff: -2,\n\t\t\tsizeDesktop: props.theme.text.size.default,\n\t\t\tsizeBigScreen: calcStyle({\n\t\t\t\ta: props.theme.text.size.desktop,\n\t\t\t\tb: 2,\n\t\t\t\tmode: '-',\n\t\t\t}),\n\t\t\timportant: true,\n\t\t})}\n\n\t* {\n\t\tuser-select: text;\n\t}\n\n\t> ${StyledUserName}:hover {\n\t\topacity: 1;\n\t\tcolor: ${(props) => props.theme.colors.text};\n\t}\n\n\th5 {\n\t\tmargin: -7px -7px 7px;\n\t\tpadding: 4px 7px;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tbackground-color: ${(props) => rgba(props.theme.colors.inputButton, 0.5)};\n\t\t${(props) =>\n\t\t\tfontSize({\n\t\t\t\tsizeDiff: -2,\n\t\t\t\tsizeDesktop: props.theme.text.size.default,\n\t\t\t\tsizeBigScreen: calcStyle({\n\t\t\t\t\ta: props.theme.text.size.desktop,\n\t\t\t\t\tb: 2,\n\t\t\t\t\tmode: '-',\n\t\t\t\t}),\n\t\t\t\timportant: true,\n\t\t\t})}\n\t\tcolor: ${(props) => props.theme.colors.text};\n\t\tposition: relative;\n\t\t${borderRadiusValue(\n\t\t\t(value) =>\n\t\t\t\tcss`\n\t\t\t\t\tborder-radius: ${value} ${value} 0 0;\n\t\t\t\t`,\n\t\t)};\n\n\t\tsvg {\n\t\t\tmargin-right: 5px;\n\t\t}\n\n\t\t&[class*='theme-'] {\n\t\t\t&:before {\n\t\t\t\tcontent: '';\n\t\t\t\tdisplay: block;\n\t\t\t\tposition: absolute;\n\t\t\t\ttop: 0;\n\t\t\t\tleft: 0;\n\t\t\t\twidth: 100%;\n\t\t\t\theight: 100%;\n\t\t\t\tz-index: -1;\n\t\t\t\tborder-radius: inherit;\n\t\t\t}\n\t\t}\n\n\t\t&.theme-rain {\n\t\t\t&:before {\n\t\t\t\tbackground: url(${RainAnimation});\n\t\t\t\tbackground-position: center;\n\t\t\t\tbackground-size: 160%;\n\t\t\t\tanimation: FadeOut 2s ease 5s 1;\n\t\t\t\tanimation-fill-mode: forwards;\n\t\t\t}\n\t\t}\n\n\t\t&.theme-tip {\n\t\t\tbackground-color: #044da180;\n\n\t\t\t&:before {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t}\n\t}\n\n\t${getNew}\n\n\t${getPrivateMessage}\n\n  ${(props) =>\n\t\t!props.isMyMessage && !props.isBotMessage && !props.isPrivate\n\t\t\t? css`\n\t\t\t\t\t&:nth-of-type(even) {\n\t\t\t\t\t\tbackground-color: ${rgba('white', 0.05)};\n\t\t\t\t\t}\n\n\t\t\t\t\t${MessageTextStyled} {\n\t\t\t\t\t\t> span:not([class]):first-of-type {\n\t\t\t\t\t\t\t&:before {\n\t\t\t\t\t\t\t\tcontent: '';\n\t\t\t\t\t\t\t\tfloat: right;\n\t\t\t\t\t\t\t\theight: 5px;\n\t\t\t\t\t\t\t\twidth: 20px;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t  `\n\t\t\t: ''};\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n\t\tmargin-top: 7px;\n\t\tpadding: 7px;\n\t}\n`;\n\nexport const ChatMessageUserStyle = styled.span`\n\tfloat: left;\n\tmargin-right: 5px;\n\n\t${StyledVipIcon} {\n\t\tdisplay: inline-flex !important;\n\t\theight: 13px;\n\t\tposition: relative;\n\t\twidth: 15px;\n\n\t\tsvg {\n\t\t\tleft: 50%;\n\t\t\tposition: absolute;\n\t\t\ttop: 50%;\n\t\t\ttransform: translate(-50%, -50%);\n\t\t}\n\t}\n`;\n\nexport const ChatMessageShareStyle = styled.span`\n\tposition: absolute;\n\tright: 6px;\n\ttop: 3px;\n\n\t.${CSSClassNameButton} {\n\t\tcolor: ${(props) => props.theme.colors.passwordValidationColor};\n\t\tsvg {\n\t\t\tfont-size: 12px;\n\t\t\theight: 12px;\n\t\t\tline-height: 12px;\n\t\t\tmin-height: 12px;\n\t\t\tmin-width: 12px;\n\t\t\twidth: 12px;\n\t\t}\n\t}\n`;\n\nexport const ChatMessageDateStyle = styled.div`\n\tfont-size: 8px;\n\tline-height: 1;\n\tmargin-bottom: -3px;\n\ttext-align: right;\n`;\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHN0eWxlPSJtYXJnaW46YXV0bztiYWNrZ3JvdW5kOjAgMDt6LWluZGV4OjE7cG9zaXRpb246cmVsYXRpdmUiIHdpZHRoPSIxMTQwIiBoZWlnaHQ9IjMyMiIgcHJlc2VydmVBc3BlY3RSYXRpbz0ieE1pZFlNaWQiIGRpc3BsYXk9ImJsb2NrIj48ZGVmcz48cGF0dGVybiBpZD0iYSIgeD0iMCIgeT0iMCIgd2lkdGg9IjE2My44IiBoZWlnaHQ9IjE2My44IiBwYXR0ZXJuVW5pdHM9InVzZXJTcGFjZU9uVXNlIj48ZyB0cmFuc2Zvcm09InNjYWxlKC42NCkiPjxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0xMTcgMTE3KSI+PHBhdGggc3Ryb2tlLXdpZHRoPSI1IiBzdHJva2U9IiMzODczN2YiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgZD0iTTE0NCAxNjdsLTE5IDE5TTE0NC0zNDVsLTE5IDE5TTQwMC0zNDVsLTE5IDE5TTY1Ni0zNDVsLTE5IDE5TTE0NC04OWwtMTkgMTlNNDAwLTg5bC0xOSAxOU02NTYtODlsLTE5IDE5TTE0NCAxNjdsLTE5IDE5TTQwMCAxNjdsLTE5IDE5TTY1NiAxNjdsLTE5IDE5TTgyIDk1bC0xNCAxNE04Mi00MTdsLTE0IDE0TTMzOC00MTdsLTE0IDE0TTU5NC00MTdsLTE0IDE0TTgyLTE2MWwtMTQgMTRNMzM4LTE2MWwtMTQgMTRNNTk0LTE2MWwtMTQgMTRNODIgOTVsLTE0IDE0TTMzOCA5NWwtMTQgMTRNNTk0IDk1bC0xNCAxNE03MCAxOTVsLTE2IDE2TTcwLTMxN2wtMTYgMTZNMzI2LTMxN2wtMTYgMTZNNTgyLTMxN2wtMTYgMTZNNzAtNjFMNTQtNDVNMzI2LTYxbC0xNiAxNk01ODItNjFsLTE2IDE2TTcwIDE5NWwtMTYgMTZNMzI2IDE5NWwtMTYgMTZNNTgyIDE5NWwtMTYgMTZNMTEzLTZMOTggOU0xMTMtNTE4bC0xNSAxNU0zNjktNTE4bC0xNSAxNU02MjUtNTE4bC0xNSAxNU0xMTMtMjYybC0xNSAxNU0zNjktMjYybC0xNSAxNU02MjUtMjYybC0xNSAxNU0xMTMtNkw5OCA5TTM2OS02TDM1NCA5TTYyNS02TDYxMCA5TTExMyAyNTBsLTE1IDE1TTczIDQ3TDU3IDYzTTczLTQ2NWwtMTYgMTZNMzI5LTQ2NWwtMTYgMTZNNTg1LTQ2NWwtMTYgMTZNNzMtMjA5bC0xNiAxNk0zMjktMjA5bC0xNiAxNk01ODUtMjA5bC0xNiAxNk03MyA0N0w1NyA2M00zMjkgNDdsLTE2IDE2TTU4NSA0N2wtMTYgMTZNOTcgMTg4bC0yMyAyMk05Ny0zMjRsLTIzIDIyTTM1My0zMjRsLTIzIDIyTTYwOS0zMjRsLTIzIDIyTTk3LTY4TDc0LTQ2TTM1My02OGwtMjMgMjJNNjA5LTY4bC0yMyAyMk05NyAxODhsLTIzIDIyTTM1MyAxODhsLTIzIDIyTTYwOSAxODhsLTIzIDIyTTE1NiAyMDJsLTI1IDI2TTE1Ni0zMTBsLTI1IDI2TTQxMi0zMTBsLTI1IDI2TTY2OC0zMTBsLTI1IDI2TTE1Ni01NGwtMjUgMjZNNDEyLTU0bC0yNSAyNk02NjgtNTRsLTI1IDI2TTE1NiAyMDJsLTI1IDI2TTQxMiAyMDJsLTI1IDI2TTY2OCAyMDJsLTI1IDI2TTIzOCAxMTVsLTI5IDI5TTIzOC0zOTdsLTI5IDI5TTQ5NC0zOTdsLTI5IDI5TTc1MC0zOTdsLTI5IDI5TTIzOC0xNDFsLTI5IDI5TTQ5NC0xNDFsLTI5IDI5TTc1MC0xNDFsLTI5IDI5TTIzOCAxMTVsLTI5IDI5TTQ5NCAxMTVsLTI5IDI5TTc1MCAxMTVsLTI5IDI5TTEwOCAzMUw4NCA1NU0xMDgtNDgxbC0yNCAyNE0zNjQtNDgxbC0yNCAyNE02MjAtNDgxbC0yNCAyNE0xMDgtMjI1bC0yNCAyNE0zNjQtMjI1bC0yNCAyNE02MjAtMjI1bC0yNCAyNE0xMDggMzFMODQgNTVNMzY0IDMxbC0yNCAyNE02MjAgMzFsLTI0IDI0TTIxOSAyMjBsLTE3IDE3TTIxOS0yOTJsLTE3IDE3TTQ3NS0yOTJsLTE3IDE3TTczMS0yOTJsLTE3IDE3TTIxOS0zNmwtMTcgMTdNNDc1LTM2bC0xNyAxN003MzEtMzZsLTE3IDE3TTIxOSAyMjBsLTE3IDE3TTQ3NSAyMjBsLTE3IDE3TTczMSAyMjBsLTE3IDE3Ii8+PGFuaW1hdGVUcmFuc2Zvcm0gYXR0cmlidXRlTmFtZT0idHJhbnNmb3JtIiB0eXBlPSJ0cmFuc2xhdGUiIHZhbHVlcz0iMCAwOy0yNTYgMjU2IiBrZXlUaW1lcz0iMDsxIiByZXBlYXRDb3VudD0iaW5kZWZpbml0ZSIgZHVyPSI1cyIvPjwvZz48ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjM0IDIzNCkiPjxwYXRoIHN0cm9rZS13aWR0aD0iNSIgc3Ryb2tlPSIjMzg3MzdmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIGQ9Ik00MSAxOTNsLTcgOE00MS0zMTlsLTcgOE0yOTctMzE5bC03IDhNNTUzLTMxOWwtNyA4TTQxLTYzbC03IDhNMjk3LTYzbC03IDhNNTUzLTYzbC03IDhNNDEgMTkzbC03IDhNMjk3IDE5M2wtNyA4TTU1MyAxOTNsLTcgOCIvPjxwYXRoIHN0cm9rZS13aWR0aD0iNSIgc3Ryb2tlPSIjNjA5OWE1IiBzdHJva2UtbGluZWNhcD0icm91bmQiIGQ9Ik0xNDMgOTJsLTE5IDE5TTE0My00MjBsLTE5IDE5TTM5OS00MjBsLTE5IDE5TTY1NS00MjBsLTE5IDE5TTE0My0xNjRsLTE5IDE5TTM5OS0xNjRsLTE5IDE5TTY1NS0xNjRsLTE5IDE5TTE0MyA5MmwtMTkgMTlNMzk5IDkybC0xOSAxOU02NTUgOTJsLTE5IDE5TTEzNSA2NWwtMjcgMjdNMTM1LTQ0N2wtMjcgMjdNMzkxLTQ0N2wtMjcgMjdNNjQ3LTQ0N2wtMjcgMjdNMTM1LTE5MWwtMjcgMjdNMzkxLTE5MWwtMjcgMjdNNjQ3LTE5MWwtMjcgMjdNMTM1IDY1bC0yNyAyN00zOTEgNjVsLTI3IDI3TTY0NyA2NWwtMjcgMjdNMjIzIDUxbC03IDhNMjIzLTQ2MWwtNyA4TTQ3OS00NjFsLTcgOE03MzUtNDYxbC03IDhNMjIzLTIwNWwtNyA4TTQ3OS0yMDVsLTcgOE03MzUtMjA1bC03IDhNMjIzIDUxbC03IDhNNDc5IDUxbC03IDhNNzM1IDUxbC03IDhNMjMwIDE2MWwtMjcgMjdNMjMwLTM1MWwtMjcgMjdNNDg2LTM1MWwtMjcgMjdNNzQyLTM1MWwtMjcgMjdNMjMwLTk1bC0yNyAyN000ODYtOTVsLTI3IDI3TTc0Mi05NWwtMjcgMjdNMjMwIDE2MWwtMjcgMjdNNDg2IDE2MWwtMjcgMjdNNzQyIDE2MWwtMjcgMjdNMTA2IDE0M2wtMjcgMjdNMTA2LTM2OWwtMjcgMjdNMzYyLTM2OWwtMjcgMjdNNjE4LTM2OWwtMjcgMjdNMTA2LTExM0w3OS04Nk0zNjItMTEzbC0yNyAyN002MTgtMTEzbC0yNyAyN00xMDYgMTQzbC0yNyAyN00zNjIgMTQzbC0yNyAyN002MTggMTQzbC0yNyAyNyIvPjxwYXRoIHN0cm9rZS13aWR0aD0iNSIgc3Ryb2tlPSIjMzg3MzdmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIGQ9Ik04MyAzOEw3MiA0OU04My00NzRsLTExIDExTTMzOS00NzRsLTExIDExTTU5NS00NzRsLTExIDExTTgzLTIxOGwtMTEgMTFNMzM5LTIxOGwtMTEgMTFNNTk1LTIxOGwtMTEgMTFNODMgMzhMNzIgNDlNMzM5IDM4bC0xMSAxMU01OTUgMzhsLTExIDExIi8+PHBhdGggc3Ryb2tlLXdpZHRoPSI1IiBzdHJva2U9IiM2MDk5YTUiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgZD0iTTIzOSAxOTJsLTI1IDI1TTIzOS0zMjBsLTI1IDI1TTQ5NS0zMjBsLTI1IDI1TTc1MS0zMjBsLTI1IDI1TTIzOS02NGwtMjUgMjVNNDk1LTY0bC0yNSAyNU03NTEtNjRsLTI1IDI1TTIzOSAxOTJsLTI1IDI1TTQ5NSAxOTJsLTI1IDI1TTc1MSAxOTJsLTI1IDI1TTEwNiAxMDhsLTExIDExTTEwNi00MDRsLTExIDExTTM2Mi00MDRsLTExIDExTTYxOC00MDRsLTExIDExTTEwNi0xNDhsLTExIDExTTM2Mi0xNDhsLTExIDExTTYxOC0xNDhsLTExIDExTTEwNiAxMDhsLTExIDExTTM2MiAxMDhsLTExIDExTTYxOCAxMDhsLTExIDExTTEwNyAxODhsLTIzIDIyTTEwNy0zMjRsLTIzIDIyTTM2My0zMjRsLTIzIDIyTTYxOS0zMjRsLTIzIDIyTTEwNy02OEw4NC00Nk0zNjMtNjhsLTIzIDIyTTYxOS02OGwtMjMgMjJNMTA3IDE4OGwtMjMgMjJNMzYzIDE4OGwtMjMgMjJNNjE5IDE4OGwtMjMgMjIiLz48YW5pbWF0ZVRyYW5zZm9ybSBhdHRyaWJ1dGVOYW1lPSJ0cmFuc2Zvcm0iIHR5cGU9InRyYW5zbGF0ZSIgdmFsdWVzPSIwIDA7LTI1NiAyNTYiIGtleVRpbWVzPSIwOzEiIHJlcGVhdENvdW50PSJpbmRlZmluaXRlIiBkdXI9IjIuNXMiLz48L2c+PGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTk1IDk1KSI+PHBhdGggc3Ryb2tlLXdpZHRoPSI1IiBzdHJva2U9IiM4OGMzY2YiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgZD0iTTE0NyAyMDdsLTI5IDI5TTE0Ny0zMDVsLTI5IDI5TTQwMy0zMDVsLTI5IDI5TTY1OS0zMDVsLTI5IDI5TTE0Ny00OWwtMjkgMjlNNDAzLTQ5bC0yOSAyOU02NTktNDlsLTI5IDI5TTE0NyAyMDdsLTI5IDI5TTQwMyAyMDdsLTI5IDI5TTY1OSAyMDdsLTI5IDI5TTE2MSAxOWwtMjIgMjJNMTYxLTQ5M2wtMjIgMjJNNDE3LTQ5M2wtMjIgMjJNNjczLTQ5M2wtMjIgMjJNMTYxLTIzN2wtMjIgMjJNNDE3LTIzN2wtMjIgMjJNNjczLTIzN2wtMjIgMjJNMTYxIDE5bC0yMiAyMk00MTcgMTlsLTIyIDIyTTY3MyAxOWwtMjIgMjJNMjQxIDcybC0yNSAyNU0yNDEtNDQwbC0yNSAyNU00OTctNDQwbC0yNSAyNU03NTMtNDQwbC0yNSAyNU0yNDEtMTg0bC0yNSAyNU00OTctMTg0bC0yNSAyNU03NTMtMTg0bC0yNSAyNU0yNDEgNzJsLTI1IDI1TTQ5NyA3MmwtMjUgMjVNNzUzIDcybC0yNSAyNU0zMiAyNUwxOSAzOE0zMi00ODdsLTEzIDEzTTI4OC00ODdsLTEzIDEzTTU0NC00ODdsLTEzIDEzTTMyLTIzMWwtMTMgMTNNMjg4LTIzMWwtMTMgMTNNNTQ0LTIzMWwtMTMgMTNNMzIgMjVMMTkgMzhNMjg4IDI1bC0xMyAxM001NDQgMjVsLTEzIDEzTTEyMCA4NmwtMTggMTlNMTIwLTQyNmwtMTggMTlNMzc2LTQyNmwtMTggMTlNNjMyLTQyNmwtMTggMTlNMTIwLTE3MGwtMTggMTlNMzc2LTE3MGwtMTggMTlNNjMyLTE3MGwtMTggMTlNMTIwIDg2bC0xOCAxOU0zNzYgODZsLTE4IDE5TTYzMiA4NmwtMTggMTlNMTQxIDk5bC0xMiAxMk0xNDEtNDEzbC0xMiAxMk0zOTctNDEzbC0xMiAxMk02NTMtNDEzbC0xMiAxMk0xNDEtMTU3bC0xMiAxMk0zOTctMTU3bC0xMiAxMk02NTMtMTU3bC0xMiAxMk0xNDEgOTlsLTEyIDEyTTM5NyA5OWwtMTIgMTJNNjUzIDk5bC0xMiAxMk03NSAxNDFsLTE4IDE4TTc1LTM3MWwtMTggMThNMzMxLTM3MWwtMTggMThNNTg3LTM3MWwtMTggMThNNzUtMTE1TDU3LTk3TTMzMS0xMTVsLTE4IDE4TTU4Ny0xMTVsLTE4IDE4TTc1IDE0MWwtMTggMThNMzMxIDE0MWwtMTggMThNNTg3IDE0MWwtMTggMThNODUgNjhMNTggOTVNODUtNDQ0bC0yNyAyN00zNDEtNDQ0bC0yNyAyN001OTctNDQ0bC0yNyAyN004NS0xODhsLTI3IDI3TTM0MS0xODhsLTI3IDI3TTU5Ny0xODhsLTI3IDI3TTg1IDY4TDU4IDk1TTM0MSA2OGwtMjcgMjdNNTk3IDY4bC0yNyAyN00yNCA5MEwwIDExNU0yNC00MjJMMC0zOTdNMjgwLTQyMmwtMjQgMjVNNTM2LTQyMmwtMjQgMjVNMjQtMTY2TDAtMTQxTTI4MC0xNjZsLTI0IDI1TTUzNi0xNjZsLTI0IDI1TTI0IDkwTDAgMTE1TTI4MCA5MGwtMjQgMjVNNTM2IDkwbC0yNCAyNU0zMiAyMjZsLTE1IDE1TTMyLTI4NmwtMTUgMTVNMjg4LTI4NmwtMTUgMTVNNTQ0LTI4NmwtMTUgMTVNMzItMzBMMTctMTVNMjg4LTMwbC0xNSAxNU01NDQtMzBsLTE1IDE1TTMyIDIyNmwtMTUgMTVNMjg4IDIyNmwtMTUgMTVNNTQ0IDIyNmwtMTUgMTUiLz48YW5pbWF0ZVRyYW5zZm9ybSBhdHRyaWJ1dGVOYW1lPSJ0cmFuc2Zvcm0iIHR5cGU9InRyYW5zbGF0ZSIgdmFsdWVzPSIwIDA7LTI1NiAyNTYiIGtleVRpbWVzPSIwOzEiIHJlcGVhdENvdW50PSJpbmRlZmluaXRlIiBkdXI9IjEuNjY2NjY2NjY2NjY2NjY2NXMiLz48L2c+PC9nPjwvcGF0dGVybj48L2RlZnM+PHBhdGggZmlsbD0idXJsKCNhKSIgZD0iTTAgMGgxMTQwdjMyMkgweiIvPjwvc3ZnPg==\"","import dynamic from 'next/dynamic';\n\nexport const MessageText = dynamic(() => import('./MessageText.memo'), {\n\tssr: false,\n});\n","import styled, { css } from 'styled-components';\n\nexport const notificationCounterIcon = css`\n\tfont-style: normal;\n\n\t${(props: { $count: number }) =>\n\t\tprops.$count\n\t\t\t? css`\n\t\t\t\t\tposition: relative;\n\n\t\t\t\t\t&:after {\n\t\t\t\t\t\talign-items: center;\n\t\t\t\t\t\tbackground: ${(props) => props.theme.colors.active};\n\t\t\t\t\t\tborder: 1px solid rgb(5, 27, 56);\n\t\t\t\t\t\tborder-radius: 100%;\n\t\t\t\t\t\tcolor: ${(props) => props.theme.colors.text};\n\t\t\t\t\t\tcontent: '${props.$count}';\n\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\tfont-family: ${(props) => props.theme.text.fonts.Bold};\n\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\theight: 14px;\n\t\t\t\t\t\tjustify-content: center;\n\t\t\t\t\t\tposition: absolute;\n\t\t\t\t\t\tright: -5px;\n\t\t\t\t\t\ttop: -5px;\n\t\t\t\t\t\twidth: 14px;\n\t\t\t\t\t}\n\t\t\t  `\n\t\t\t: ''}\n`;\n\nexport const StyledNotificationCounter = styled.div<{\n\t$count: number;\n}>`\n\t${notificationCounterIcon};\n`;\n","export enum PusherConnectionStates {\n\tINITIALIZED = 'initialized',\n\tCONNECTING = 'connecting',\n\tCONNECTED = 'connected',\n\tUNAVAILABLE = 'unavailable',\n\tFAILED = 'failed',\n\tDISCONNECTED = 'disconnected',\n}\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../../hooks/store/useAppSelector';\n\nexport const usePrivateMessagesActiveList = () =>\n\tuseAppSelector((state) => state?.privateMessages?.activeList, shallowEqual);\nexport const usePrivateMessagesActiveListLength = () =>\n\tusePrivateMessagesActiveList().length;\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\n\nexport const useChatContentType = () =>\n\tuseAppSelector((state) => state?.chat?.contentType, shallowEqual);\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\n\nexport const useChatPrivateActive = () =>\n\tuseAppSelector((state) => state?.chat?.privateActive, shallowEqual);\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\n\nexport const useChatRoom = () =>\n\tuseAppSelector((state) => state?.chat?.room, shallowEqual);\n","import { FC, PropsWithChildren } from 'react';\nimport { useWebsocketConnectionState } from '@common/selectors/websocket.selectors';\nimport { PusherConnectionStates } from '@legacyApp/client/store/websocket/websocket.types';\n\nexport const WebsocketConnectionFailed: FC<PropsWithChildren<any>> = ({\n\tchildren,\n}) => {\n\tconst connectionState = useWebsocketConnectionState();\n\tif (\n\t\t[\n\t\t\tPusherConnectionStates.CONNECTED,\n\t\t\tPusherConnectionStates.CONNECTING,\n\t\t].indexOf(connectionState) > -1\n\t) {\n\t\treturn null;\n\t}\n\treturn <>{children}</>;\n};\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport { PusherConnectionStates } from '@legacyApp/client/store/websocket/websocket.types';\n\nexport const useWebsocketConnectionState = () =>\n\tuseAppSelector<PusherConnectionStates>(\n\t\t(state) => state.websocket.connectionState,\n\t\tshallowEqual,\n\t);\n","import ContentLoader from 'react-content-loader';\nimport { FC } from 'react';\nimport { config } from './loaders.config';\n\nexport const ChatMessageLoader: FC<{\n\tid: string;\n\twidth?: number;\n\theight?: number;\n}> = ({ id, width = 280, height = 30 }) => {\n\treturn (\n\t\t<ContentLoader\n\t\t\theight={height}\n\t\t\twidth={width}\n\t\t\tviewBox={`0 0 ${width} ${height}`}\n\t\t\tuniqueKey={`${id || 0}-chat-message`}\n\t\t\t{...config}\n\t\t>\n\t\t\t<rect\n\t\t\t\tx=\"0\"\n\t\t\t\ty=\"0\"\n\t\t\t\trx=\"3\"\n\t\t\t\try=\"3\"\n\t\t\t\twidth={width * 0.2}\n\t\t\t\theight={height * 0.4}\n\t\t\t/>\n\t\t\t<rect\n\t\t\t\tx={width * 0.22}\n\t\t\t\ty=\"0\"\n\t\t\t\trx=\"3\"\n\t\t\t\try=\"3\"\n\t\t\t\twidth={width * 0.6}\n\t\t\t\theight={height * 0.4}\n\t\t\t/>\n\t\t\t<rect\n\t\t\t\tx=\"0\"\n\t\t\t\ty={height * 0.6}\n\t\t\t\trx=\"3\"\n\t\t\t\try=\"3\"\n\t\t\t\twidth={width * 0.5}\n\t\t\t\theight={height * 0.5}\n\t\t\t/>\n\t\t\t<circle cx={width - height * 0.2} cy={height * 0.5} r={height * 0.2} />\n\t\t</ContentLoader>\n\t);\n};\n","import { Message } from '../types/Message.type';\n\nexport const checkIsTriviaMessage = (message: Message) => {\n\treturn (\n\t\t(message?.user.is_moderator || message?.user.is_admin) &&\n\t\t(message.message.indexOf('trivia:') === 0 ||\n\t\t\tmessage.message.indexOf('trivia_winner:') === 0)\n\t);\n};\n","import dynamic from 'next/dynamic';\n\nconst Trivia = dynamic(() => import('./Trivia'));\n\nexport { Trivia };\n","import { FC, useContext } from 'react';\nimport { ChatMessageLoader } from '@common/components/contentLoaders/ChatMessageLoader';\nimport { useUserName } from '@common/selectors/user.selectors';\nimport { Loadable } from '@legacyApp/client/components/loader/loadable/loadable';\nimport { checkIsBotLogin } from '../../constants/BOTS';\nimport { Message } from '../../types/Message.type';\nimport { ChatMessageContext } from '../../context/chatMessage.context';\nimport { ChatStreamContext } from '../../context/chatStream.context';\nimport { checkIsTriviaMessage } from '../../methods/checkIsTriviaMessage';\nimport { Trivia } from './components/trivia';\nimport { ChatMessageStyle } from './chat.message.style';\n\nconst MessageUnreadNotification = Loadable(\n\t{\n\t\tloader: () =>\n\t\t\timport(\n\t\t\t\t/* webpackChunkName: \"MessageUnreadNotification\" */ './components/MessageUnreadNotification'\n\t\t\t),\n\t\tssr: false,\n\t},\n\t'./components/MessageUnreadNotification',\n);\nconst AdminMessage = Loadable(\n\t{\n\t\tloader: () =>\n\t\t\timport(\n\t\t\t\t/* webpackChunkName: \"AdminMessage\" */ './components/admin/AdminMessage'\n\t\t\t),\n\t\tssr: false,\n\t},\n\t'./components/admin/AdminMessage',\n);\nconst BotMessage = Loadable(\n\t{\n\t\tloader: () =>\n\t\t\timport(/* webpackChunkName: \"BotMessage\" */ './components/BotMessage'),\n\t\tssr: false,\n\t},\n\t'./components/BotMessage',\n);\nconst MessageContent = Loadable(\n\t{\n\t\tloader: () =>\n\t\t\timport(\n\t\t\t\t/* webpackChunkName: \"MessageContent\" */ './components/MessageContent'\n\t\t\t),\n\t\tssr: false,\n\t},\n\t'./components/MessageContent',\n);\n\nexport interface ChatMessageProps {\n\tmessage?: Message;\n}\n\nconst ChatMessage_: FC<ChatMessageProps> = ({ message }) => {\n\tconst userName = useUserName();\n\tconst { privateStream } = useContext(ChatStreamContext);\n\tconst isMyMessage = message?.user.login === userName;\n\tconst isBotMessage = checkIsBotLogin(message?.user.login);\n\treturn (\n\t\t<ChatMessageContext.Provider\n\t\t\tvalue={{ message, isPrivate: privateStream, isMyMessage, isBotMessage }}\n\t\t>\n\t\t\t<MessageUnreadNotification />\n\t\t\t<ChatMessageStyle\n\t\t\t\tdata-nonce={message?.nonce}\n\t\t\t\tisPrivate={privateStream}\n\t\t\t\tisMyMessage={isMyMessage}\n\t\t\t\tisBotMessage={isBotMessage}\n\t\t\t>\n\t\t\t\t{isBotMessage ? (\n\t\t\t\t\t<BotMessage />\n\t\t\t\t) : checkIsTriviaMessage(message) ? (\n\t\t\t\t\t<Trivia />\n\t\t\t\t) : (\n\t\t\t\t\t<MessageContent />\n\t\t\t\t)}\n\t\t\t\t{message && userName && (\n\t\t\t\t\t<AdminMessage pm={privateStream} message={message} />\n\t\t\t\t)}\n\t\t\t</ChatMessageStyle>\n\t\t</ChatMessageContext.Provider>\n\t);\n};\n\nexport const ChatMessage: FC<ChatMessageProps> = ({ message }) => {\n\tif (!message) {\n\t\treturn (\n\t\t\t<div>\n\t\t\t\t<ChatMessageLoader id={null} />\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn <ChatMessage_ message={message} />;\n};\n","import {\n\tFC,\n\tMutableRefObject,\n\tuseCallback,\n\tuseContext,\n\tuseEffect,\n\tuseRef,\n\tuseState,\n} from 'react';\nimport { Trans } from '@legacyApp/client/modules/translation/translate';\nimport { useUserId } from '@common/selectors/user.selectors';\nimport { usePrevious } from '@legacyApp/hooks/render/usePrevious';\nimport { config } from '@legacyApp/client/config';\nimport { isFunction } from '@common/methods/isFunction';\nimport { getMessageId } from '../../methods/getMessageId';\nimport { Message } from '../../types/Message.type';\nimport transactionsService from '../../../transactions/transactionsService';\nimport { MESSAGE_COMPARE_KEYS } from '../../constants/MESSAGE_COMPARE_KEYS';\nimport { ChatStreamContext } from '../../context/chatStream.context';\nimport { ChatStreamNotificationStyle } from './chat.stream.style';\n\nexport const ChatUnreadMessagesCounter: FC<{\n\tlist: Array<Message>;\n\tautoScroll: boolean;\n\troom: string;\n\tboxRef: MutableRefObject<HTMLElement>;\n\tresetRef?: MutableRefObject<Function>;\n}> = ({ list, autoScroll, room, boxRef, resetRef }) => {\n\tconst { unreadFromId, setUnreadFromId } = useContext(ChatStreamContext);\n\tconst myUserId = useUserId();\n\tconst prevList = usePrevious(list);\n\tconst prevRoom = usePrevious(room);\n\tconst scrollTimeoutRef = useRef<NodeJS.Timeout>(null);\n\tconst clearUnreadTimeout = useRef<NodeJS.Timeout>(null);\n\tconst [unreadCounter, setUnreadCounter] = useState<string>('0');\n\tconst prevUnreadFromId = usePrevious(unreadFromId);\n\n\tconst checkIsMyLastMessage = useCallback(\n\t\t(list: Array<Message>) => {\n\t\t\treturn (\n\t\t\t\tlist?.[list?.length - 1] && list[list.length - 1].user.uuid === myUserId\n\t\t\t);\n\t\t},\n\t\t[myUserId],\n\t);\n\n\tconst resetUnread = useCallback(() => {\n\t\tif (!unreadCounter) {\n\t\t\treturn;\n\t\t}\n\t\tsetUnreadCounter('0');\n\t\tif (clearUnreadTimeout.current) {\n\t\t\tclearTimeout(clearUnreadTimeout.current);\n\t\t}\n\t\t// console.log('resetUnread');\n\t\tclearUnreadTimeout.current = setTimeout(() => {\n\t\t\t// console.log('clearUnread');\n\t\t\tsetUnreadFromId(null);\n\t\t}, config.unreadMessageTimeout);\n\t}, [setUnreadFromId, unreadCounter]);\n\n\tconst incrementUnread = useCallback(() => {\n\t\tif (!unreadCounter) {\n\t\t\tif (clearUnreadTimeout.current) {\n\t\t\t\tclearTimeout(clearUnreadTimeout.current);\n\t\t\t}\n\t\t\t// console.log('incrementUnread');\n\t\t\tsetUnreadFromId(getMessageId(list[list.length - 1]));\n\t\t}\n\t\tif (unreadCounter === `+${config.chatStreamLength}`) {\n\t\t\treturn;\n\t\t}\n\t\tif (unreadCounter === String(config.chatStreamLength)) {\n\t\t\treturn setUnreadCounter(`+${config.chatStreamLength}`);\n\t\t}\n\t\tsetUnreadCounter((unreadCounter) => {\n\t\t\treturn String(Number(unreadCounter) + 1);\n\t\t});\n\t}, [list, setUnreadFromId, unreadCounter]);\n\n\tconst clearScrollTimeout = useCallback(() => {\n\t\tif (scrollTimeoutRef.current) {\n\t\t\tclearTimeout(scrollTimeoutRef.current);\n\t\t}\n\t}, []);\n\n\tconst scrollToBottom = useCallback(\n\t\t(type: ScrollBehavior = 'auto', force?: boolean) => {\n\t\t\tif (!autoScroll && !force) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tclearScrollTimeout();\n\t\t\tscrollTimeoutRef.current = setTimeout(\n\t\t\t\t() => {\n\t\t\t\t\tif (\n\t\t\t\t\t\t!boxRef ||\n\t\t\t\t\t\t!boxRef.current ||\n\t\t\t\t\t\t!isFunction(boxRef.current.scroll)\n\t\t\t\t\t) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\tif (!type) {\n\t\t\t\t\t\tboxRef.current.scrollTop = boxRef.current.scrollHeight;\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\tboxRef.current.scroll({\n\t\t\t\t\t\ttop: boxRef.current.scrollHeight,\n\t\t\t\t\t\tbehavior: type,\n\t\t\t\t\t});\n\t\t\t\t},\n\t\t\t\ttype ? 300 : 0,\n\t\t\t);\n\t\t},\n\t\t[autoScroll, boxRef, clearScrollTimeout],\n\t);\n\n\tuseEffect(() => {\n\t\tif (\n\t\t\ttransactionsService.isListDifferent(\n\t\t\t\tlist,\n\t\t\t\tprevList,\n\t\t\t\tMESSAGE_COMPARE_KEYS,\n\t\t\t) &&\n\t\t\tlist?.[list?.length - 1]?.nonce !==\n\t\t\t\tprevList?.[prevList?.length - 1]?.nonce\n\t\t) {\n\t\t\tif (unreadFromId === prevUnreadFromId) {\n\t\t\t\tconst autoScroll_ = checkIsMyLastMessage(list) ? true : autoScroll;\n\t\t\t\tautoScroll_ ? resetUnread() : incrementUnread();\n\t\t\t\tscrollToBottom('smooth', autoScroll_);\n\t\t\t}\n\t\t}\n\t}, [\n\t\tautoScroll,\n\t\tincrementUnread,\n\t\tcheckIsMyLastMessage,\n\t\tlist,\n\t\tprevList,\n\t\tprevUnreadFromId,\n\t\tresetUnread,\n\t\tscrollToBottom,\n\t\tunreadFromId,\n\t]);\n\n\tuseEffect(() => {\n\t\tif (room !== prevRoom) {\n\t\t\tresetUnread();\n\t\t}\n\t}, [prevRoom, resetUnread, room]);\n\n\tuseEffect(() => {\n\t\tif (resetRef && !resetRef?.current) {\n\t\t\tresetRef.current = resetUnread;\n\t\t}\n\t\treturn () => {\n\t\t\tif (resetRef?.current) {\n\t\t\t\tresetRef.current = null;\n\t\t\t}\n\t\t};\n\t}, [resetRef, resetUnread]);\n\n\tconst onUnreadNotification = useCallback(() => {\n\t\tscrollToBottom('smooth', true);\n\t\tresetUnread();\n\t}, [resetUnread, scrollToBottom]);\n\n\tif (unreadCounter === '0') {\n\t\treturn null;\n\t}\n\treturn (\n\t\t<ChatStreamNotificationStyle\n\t\t\tonClick={onUnreadNotification}\n\t\t\tclassName=\"onclick\"\n\t\t>\n\t\t\t<Trans\n\t\t\t\tlabel={'{{number}} unread messages'}\n\t\t\t\toptions={{ number: unreadCounter }}\n\t\t\t/>\n\t\t</ChatStreamNotificationStyle>\n\t);\n};\n","import { FC, useCallback, useEffect, useRef, useState } from 'react';\nimport { isFunction } from '@common/methods/isFunction';\nimport { Trans } from '@legacyApp/client/modules/translation/translate';\nimport { Button } from '@legacyApp/client/components/button';\nimport { Loader } from '@legacyApp/client/components/loader/loader';\nimport { LoaderListWrapper } from '@common/components/contentLoaders/LoaderListWrapper';\nimport { useOnMount } from '@common/hooks/useOnMount';\nimport { usePrevious } from '@legacyApp/hooks/render/usePrevious';\nimport transactionsService from '../../../transactions/transactionsService';\nimport { MESSAGE_COMPARE_KEYS } from '../../constants/MESSAGE_COMPARE_KEYS';\nimport { getMessageId } from '../../methods/getMessageId';\nimport { WebsocketConnectionFailed } from '../../../websocket/components/WebsocketConnectionFailed';\nimport { ChatMessage } from '../message/chatMessage';\nimport { useChatLoaded } from '../../store/selectors/useChatLoaded';\nimport { Message } from '../../types/Message.type';\nimport { ChatStreamContext } from '../../context/chatStream.context';\nimport {\n\tChatConnectionError,\n\tChatStreamInfoStyle,\n\tChatStreamStyle,\n} from './chat.stream.style';\nimport { ChatUnreadMessagesCounter } from './chatUnreadMessagesCounter';\n\nexport interface ChatStreamProps {\n\tlist: Array<Message>;\n\tgetStream: (nonce?: number) => void;\n\troom: string;\n\tclassName?: string;\n\tloadingId?: string;\n\tnoHistory?: boolean;\n\tprivateStream?: boolean;\n}\n\nconst isBottom = (el: HTMLElement) => {\n\t// console.log(el.scrollTop, el.scrollHeight - el.offsetHeight - 100);\n\treturn el.scrollTop >= el.scrollHeight - el.offsetHeight - 100;\n};\n\nconst isTop = (el: HTMLElement) => {\n\t// console.log(el.scrollTop, el.offsetHeight, el);\n\treturn el.scrollTop === 0;\n};\n\nexport const ChatStream: FC<ChatStreamProps> = ({\n\tlist,\n\tgetStream,\n\troom,\n\tclassName,\n\tloadingId,\n\tnoHistory,\n\tprivateStream,\n}) => {\n\tconst loaded = useChatLoaded();\n\tconst boxRef = useRef<HTMLDivElement>(null);\n\tconst resetRef = useRef<Function>(null);\n\tconst [autoScroll, setAutoScroll] = useState<boolean>(true);\n\tconst [historyLoading, setHistoryLoading] = useState<boolean>(false);\n\tconst prevList = usePrevious(list, transactionsService.isListDifferent);\n\tconst [unreadFromId, setUnreadFromId] = useState<string>(null);\n\n\tconst scrollToMessage = useCallback(\n\t\t(nonce) => {\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (!boxRef?.current) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst element = boxRef.current.querySelector(\n\t\t\t\t\t`[data-nonce=\"${nonce}\"]`,\n\t\t\t\t) as HTMLElement;\n\t\t\t\tif (!element) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst top = element?.offsetTop;\n\t\t\t\t// console.log('HISTORY_UPDATED', nonce, {element, top, box: boxRef.current});\n\t\t\t\tif (!isFunction(boxRef?.current?.scroll)) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tboxRef.current.scrollTop = top - element.clientHeight;\n\t\t\t}, 100);\n\t\t},\n\t\t[boxRef],\n\t);\n\n\tconst loadHistory = useCallback(() => {\n\t\tif (noHistory || historyLoading) {\n\t\t\treturn;\n\t\t}\n\t\tlet nonce = undefined;\n\t\tif (list?.length && list[0]) {\n\t\t\tnonce = list[0].nonce;\n\t\t}\n\t\tif (nonce === 1) {\n\t\t\treturn;\n\t\t}\n\t\t// console.log('load history', nonce);\n\t\tsetHistoryLoading(true);\n\t\tsetTimeout(() => {\n\t\t\tgetStream(nonce);\n\t\t}, 500);\n\t}, [getStream, historyLoading, list, noHistory]);\n\n\tconst resetUnread = useCallback(() => {\n\t\tif (isFunction(resetRef?.current)) {\n\t\t\tresetRef.current();\n\t\t}\n\t}, []);\n\n\tconst trackScrolling = useCallback(\n\t\t(event: Event) => {\n\t\t\tconst el = event.target as HTMLElement;\n\t\t\tif (isBottom(el)) {\n\t\t\t\tresetUnread();\n\t\t\t\tif (!autoScroll) {\n\t\t\t\t\tsetAutoScroll(true);\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (isTop(el)) {\n\t\t\t\tloadHistory();\n\t\t\t}\n\t\t\tif (autoScroll) {\n\t\t\t\tsetAutoScroll(false);\n\t\t\t}\n\t\t},\n\t\t[autoScroll, loadHistory, resetUnread],\n\t);\n\n\tuseOnMount(() => {\n\t\tif (!list?.length) {\n\t\t\tgetStream();\n\t\t}\n\t});\n\n\tuseEffect(() => {\n\t\tif (\n\t\t\ttransactionsService.isListDifferent(list, prevList, MESSAGE_COMPARE_KEYS)\n\t\t) {\n\t\t\tconst isListsExist = list && prevList && list.length && prevList.length;\n\t\t\tconst isHistoryUploaded = isListsExist\n\t\t\t\t? list[0].nonce < prevList[0].nonce\n\t\t\t\t: false;\n\t\t\tif (!isHistoryUploaded) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tsetHistoryLoading(false);\n\t\t\tif (!noHistory) {\n\t\t\t\tscrollToMessage(prevList[0].nonce);\n\t\t\t}\n\t\t}\n\t}, [list, noHistory, prevList, scrollToMessage]);\n\n\tuseEffect(() => {\n\t\tconst boxElem = boxRef?.current;\n\t\tboxElem?.addEventListener('scroll', (e) => trackScrolling(e));\n\n\t\treturn () => {\n\t\t\tif (boxElem) {\n\t\t\t\tboxElem?.removeEventListener('scroll', (e) => trackScrolling(e));\n\t\t\t}\n\t\t};\n\t}, [trackScrolling]);\n\n\treturn (\n\t\t<ChatStreamContext.Provider\n\t\t\tvalue={{\n\t\t\t\tunreadFromId,\n\t\t\t\tsetUnreadFromId,\n\t\t\t\tprivateStream,\n\t\t\t\tscrollToMessage,\n\t\t\t\tstream: list,\n\t\t\t}}\n\t\t>\n\t\t\t<WebsocketConnectionFailed>\n\t\t\t\t<ChatConnectionError>\n\t\t\t\t\t<Trans label={'Connection problem, please refresh page'} />\n\t\t\t\t</ChatConnectionError>\n\t\t\t</WebsocketConnectionFailed>\n\t\t\t<ChatStreamStyle className={className} ref={boxRef}>\n\t\t\t\t{historyLoading && (\n\t\t\t\t\t<div className=\"box-no-height align-center small-margin-bottom\">\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tname={'Loading'}\n\t\t\t\t\t\t\tlocalTheme={{\n\t\t\t\t\t\t\t\ttype: 'clear',\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\tclassName=\"no-click\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<Loader active={true} />\n\t\t\t\t\t\t</Button>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t\t<LoaderListWrapper\n\t\t\t\t\tlist={list}\n\t\t\t\t\tlistElementCallback={(message) => (\n\t\t\t\t\t\t<ChatMessage key={getMessageId(message)} message={message} />\n\t\t\t\t\t)}\n\t\t\t\t\tloaded={loaded}\n\t\t\t\t\tpreloadElement={(el, index) => <ChatMessage key={index} />}\n\t\t\t\t\tpreloadLength={20}\n\t\t\t\t/>\n\t\t\t\t{!historyLoading && loaded && (\n\t\t\t\t\t<Loader\n\t\t\t\t\t\tmodule={loadingId || 'getRoomStream'}\n\t\t\t\t\t\tmessage={\n\t\t\t\t\t\t\t!list?.length && (\n\t\t\t\t\t\t\t\t<ChatStreamInfoStyle>\n\t\t\t\t\t\t\t\t\t<Trans label={'No messages'} />\n\t\t\t\t\t\t\t\t</ChatStreamInfoStyle>\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</ChatStreamStyle>\n\t\t\t<ChatUnreadMessagesCounter\n\t\t\t\troom={room}\n\t\t\t\tlist={list}\n\t\t\t\tautoScroll={autoScroll}\n\t\t\t\tboxRef={boxRef}\n\t\t\t\tresetRef={resetRef}\n\t\t\t/>\n\t\t</ChatStreamContext.Provider>\n\t);\n};\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\n\nexport const useChatLoaded = () =>\n\tuseAppSelector((state) => state.chat.loaded, shallowEqual);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { ChatStream } from '../../stream/chatStream';\n\nclass ChatPrivateStream extends React.PureComponent {\n\tstatic propTypes = {\n\t\tchannel: PropTypes.any,\n\t\tcloseStream: PropTypes.func,\n\t\tlist: PropTypes.array,\n\t\tgetStream: PropTypes.func,\n\t};\n\n\tgetStream = (nonce) => {\n\t\tthis.props.getStream(this.props.channel, nonce);\n\t};\n\n\trender() {\n\t\tif (!this.props.channel) {\n\t\t\treturn false;\n\t\t}\n\t\treturn (\n\t\t\t<ChatStream\n\t\t\t\troom={this.props.channel}\n\t\t\t\tlist={this.props.list}\n\t\t\t\tprivateStream={true}\n\t\t\t\tgetStream={this.getStream}\n\t\t\t\tloadingId={`getPrivateStream-${this.props.channel}`}\n\t\t\t/>\n\t\t);\n\t}\n}\n\nChatPrivateStream = enhanceComponent({\n\tChatPrivateStream,\n});\n\nexport { ChatPrivateStream };\n","import { connect } from 'react-redux';\nimport { privateMessagesGetStream } from '@legacyApp/client/store/privateMessages/privateMessages.actions';\nimport { chatActions } from '../../../store/chat.actions';\nimport { ChatPrivateStream } from './chat.private.stream';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\t// TODO: chat store usage\n\t\tchannel: state?.chat?.privateActive,\n\t\tlist: state.privateMessages.stream[state?.chat?.privateActive],\n\t};\n};\n\nconst mapDispatchToProps = (dispatch) => {\n\treturn {\n\t\tcloseStream: () => dispatch(chatActions.setPrivateActive()),\n\t\tgetStream: (channelId, nonce) =>\n\t\t\tdispatch(privateMessagesGetStream(channelId, nonce)),\n\t};\n};\n\nconst ChatPrivateStreamContainer = connect(\n\tmapStateToProps,\n\tmapDispatchToProps,\n)(ChatPrivateStream);\n\nexport { ChatPrivateStreamContainer };\n","import React, { FC } from 'react';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { useChatRoom } from '../../store/selectors/useChatRoom';\nimport { useChatStreamList } from '../../store/selectors/useChatStreamList';\nimport { getRoomStreamThunk } from '../../store/thunks/getRoomStream.thunk';\nimport { ChatStream, ChatStreamProps } from './chatStream';\n\nexport const ChatStreamContainer: FC<\n\tOmit<ChatStreamProps, 'getStream' | 'list' | 'room'>\n> = (props) => {\n\tconst room = useChatRoom();\n\tconst list = useChatStreamList(room);\n\tconst getStream = useDispatchCallback(getRoomStreamThunk);\n\treturn (\n\t\t<ChatStream\n\t\t\tlist={list}\n\t\t\tgetStream={() => getStream()}\n\t\t\troom={room}\n\t\t\tnoHistory={true}\n\t\t\t{...props}\n\t\t/>\n\t);\n};\n","import { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport transactionService from '../../../transactions/transactionsService';\nimport { Message } from '../../types/Message.type';\n\nexport const useChatStreamList = (room: string) =>\n\tuseAppSelector<Message[]>(\n\t\t(state) => state.chat.stream[room],\n\t\t(a, b) => !transactionService.isListDifferent(a, b),\n\t);\n","import styled from 'styled-components';\nimport {\n\tborderRadius,\n\tbox,\n\tboxNoHeight,\n} from '@legacyApp/client/modules/style/defaults';\nimport { StyledUserActions } from '@legacyApp/client/components/userActions/userActions.styled';\nimport { ChatStreamStyle } from '../../stream/chat.stream.style';\n\nexport const ChatPrivateStyle = styled(ChatStreamStyle).attrs(() => ({\n\tclassName: 'chat-private',\n}))``;\n\nexport const ChatPrivateBoxStyle = styled.div.attrs(() => ({\n\tclassName: 'chat-private-box',\n}))`\n\t${box}\n\n\th5 {\n\t\tpadding: 10px 0;\n\t\tmargin: 10px 0;\n\t\tborder: 1px solid ${(props) => props.theme.colors.borderColor};\n\t\tborder-left: none;\n\t\tborder-right: none;\n\t}\n\n\t&:first-of-type {\n\t\th5 {\n\t\t\tmargin-top: 0;\n\t\t\tpadding-top: 5px;\n\t\t\tborder-top: none;\n\t\t}\n\t}\n`;\n\nexport const ChatPrivateListStyle = styled.div.attrs(() => ({\n\tclassName: 'chat-private--list',\n}))`\n\t${boxNoHeight};\n\tposition: relative;\n\tmin-height: 50px;\n`;\n\nexport const ChatPrivateListElementStyle = styled.div`\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: space-between;\n\tmargin-bottom: 20px;\n\tpadding: 2px 5px;\n\tposition: relative;\n\ttransition: ${(props) => props.theme.layout.transition};\n\t${borderRadius};\n\n\t${StyledUserActions} {\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 50%;\n\t\ttransform: translateY(-50%);\n\t}\n`;\n","import styled from 'styled-components';\nimport { rgba } from 'polished';\nimport { StyledUserName } from 'src/ui/components/user-name/user-name.styled';\nimport { cutTextStyle } from '@legacyApp/client/modules/style/defaults';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\nimport { ChatPrivateListElementStyle } from '../privateHistory/chat.private.style';\n\nexport const HistoryListStyle = styled(ChatPrivateListElementStyle)`\n\tbackground-color: ${(props) => rgba(props.theme.colors.inputBackground, 0.5)};\n\tcursor: pointer;\n\tdisplay: block;\n\tpadding: 10px;\n\tposition: relative;\n\n\t.text-small {\n\t\t${(props) =>\n\t\t\tfontSize({\n\t\t\t\tsize: '10px',\n\t\t\t\tsizeDesktop: '12px',\n\t\t\t\tminWidth: props.theme.media.minWidthBigDesktop,\n\t\t\t\tsizeBigScreen: '14px',\n\t\t\t\timportant: true,\n\t\t\t})}\n\t}\n\n\t&:hover {\n\t\tbackground-color: ${(props) =>\n\t\t\tprops.theme.colors.inputBackground}input-background;\n\t}\n`;\n\nexport const HistoryListHeaderStyle = styled.div`\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: space-between;\n\tmargin-bottom: 5px;\n\tposition: relative;\n\n\t${StyledUserName} {\n\t\t${(props) =>\n\t\t\tfontSize({\n\t\t\t\tsize: '12px',\n\t\t\t\tsizeDesktop: '14px',\n\t\t\t\tminWidth: props.theme.media.minWidthBigDesktop,\n\t\t\t\tsizeBigScreen: '16px',\n\t\t\t\timportant: true,\n\t\t\t})};\n\t\tz-index: 1;\n\t}\n`;\n\nexport const HistoryListMessageStyle = styled.div`\n\t${(props) =>\n\t\tfontSize({\n\t\t\tsize: '10px',\n\t\t\tsizeDesktop: '12px',\n\t\t\tminWidth: props.theme.media.minWidthBigDesktop,\n\t\t\tsizeBigScreen: '14px',\n\t\t\timportant: true,\n\t\t})};\n\t${cutTextStyle};\n\n\tspan {\n\t\tcolor: ${(props) =>\n\t\t\tprops.unread\n\t\t\t\t? props.theme.colors.text\n\t\t\t\t: props.theme.colors.grey}!important;\n\t}\n`;\n","import React, { Fragment } from 'react';\nimport PropTypes from 'prop-types';\nimport { faCircle } from '@fortawesome/free-solid-svg-icons';\nimport { UserLogin } from '@common/components/user/UserLogin/UserLogin';\nimport { formatDate } from '@legacyApp/client/modules/app/timeService';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { MessageText } from '../../message/components/text';\nimport sortService, {\n\tDIRECTION,\n} from '../../../../../LegacyApp/client/modules/app/sortService';\nimport {\n\tHistoryListHeaderStyle,\n\tHistoryListMessageStyle,\n\tHistoryListStyle,\n} from './historyList.style';\n\nclass HistoryList extends React.PureComponent {\n\tstatic propTypes = {\n\t\tlist: PropTypes.array,\n\t\tclassName: PropTypes.string,\n\t\topenChat: PropTypes.func,\n\t\tunread: PropTypes.object,\n\t};\n\n\topenChat = (data) => {\n\t\tthis.props.openChat(data);\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<Fragment>\n\t\t\t\t{this.props.list\n\t\t\t\t\t.sort((a, b) =>\n\t\t\t\t\t\tsortService.sort(\n\t\t\t\t\t\t\tDIRECTION.DESC,\n\t\t\t\t\t\t\ta.last_message_timestamp,\n\t\t\t\t\t\t\tb.last_message_timestamp,\n\t\t\t\t\t\t),\n\t\t\t\t\t)\n\t\t\t\t\t.map((el) => {\n\t\t\t\t\t\tconst isUnread = this.props.unread[el.channelId];\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<HistoryListStyle key={el.user.uuid}>\n\t\t\t\t\t\t\t\t<HistoryListHeaderStyle>\n\t\t\t\t\t\t\t\t\t<UserLogin user={el.user} />\n\t\t\t\t\t\t\t\t\t<span className=\"text-small hint\">\n\t\t\t\t\t\t\t\t\t\t{formatDate(\n\t\t\t\t\t\t\t\t\t\t\tel.last_message_timestamp * 1000,\n\t\t\t\t\t\t\t\t\t\t\t'YYYY-MM-DD HH:mm',\n\t\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\tonClick={() => this.openChat(el)}\n\t\t\t\t\t\t\t\t\t\tclassName={'click-box'}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</HistoryListHeaderStyle>\n\t\t\t\t\t\t\t\t<HistoryListMessageStyle unread={isUnread}>\n\t\t\t\t\t\t\t\t\t{isUnread && (\n\t\t\t\t\t\t\t\t\t\t<AwesomeIcon\n\t\t\t\t\t\t\t\t\t\t\ticon={faCircle}\n\t\t\t\t\t\t\t\t\t\t\tclassName=\"hint small-margin-right\"\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\t<MessageText message={el.last_message} simple={true} />\n\t\t\t\t\t\t\t\t</HistoryListMessageStyle>\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tonClick={() => this.openChat(el)}\n\t\t\t\t\t\t\t\t\tclassName={'click-box'}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</HistoryListStyle>\n\t\t\t\t\t\t);\n\t\t\t\t\t})}\n\t\t\t</Fragment>\n\t\t);\n\t}\n}\n\nHistoryList = enhanceComponent({\n\tHistoryList,\n});\n\nexport { HistoryList };\n","import { connect } from 'react-redux';\nimport { privateMessagesOpenActive } from '@legacyApp/client/store/privateMessages/privateMessages.actions';\nimport { HistoryList } from './historyList';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\tunread: state.privateMessages.unread,\n\t};\n};\n\nconst mapDispatchToProps = (dispatch) => {\n\treturn {\n\t\topenChat: (data) => dispatch(privateMessagesOpenActive(data)),\n\t};\n};\n\nconst HistoryListContainer = connect(\n\tmapStateToProps,\n\tmapDispatchToProps,\n)(HistoryList);\n\nexport { HistoryListContainer };\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { Loader } from '@legacyApp/client/components/loader/loader';\nimport { trans } from '@legacyApp/client/modules/translation/translate';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { HistoryListContainer } from '../historyList/historyList.container';\nimport { ChatStreamInfoStyle } from '../../stream/chat.stream.style';\nimport {\n\tChatPrivateBoxStyle,\n\tChatPrivateListStyle,\n\tChatPrivateStyle,\n} from './chat.private.style';\n\nclass ChatPrivateHistory extends React.PureComponent {\n\tstatic propTypes = {\n\t\thistory: PropTypes.array,\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<ChatPrivateStyle>\n\t\t\t\t<ChatPrivateBoxStyle>\n\t\t\t\t\t<h5 className=\"text-capitalize\">\n\t\t\t\t\t\t{trans({ label: 'recent messages' })}\n\t\t\t\t\t</h5>\n\t\t\t\t\t<ChatPrivateListStyle>\n\t\t\t\t\t\t<HistoryListContainer list={this.props.history} />\n\t\t\t\t\t\t<Loader\n\t\t\t\t\t\t\tmodule=\"getPrivateMessages\"\n\t\t\t\t\t\t\tmessage={\n\t\t\t\t\t\t\t\t!this.props.history.length && (\n\t\t\t\t\t\t\t\t\t<ChatStreamInfoStyle>\n\t\t\t\t\t\t\t\t\t\t{trans({ label: 'No private messages' })}\n\t\t\t\t\t\t\t\t\t</ChatStreamInfoStyle>\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</ChatPrivateListStyle>\n\t\t\t\t</ChatPrivateBoxStyle>\n\t\t\t</ChatPrivateStyle>\n\t\t);\n\t}\n}\n\nChatPrivateHistory = enhanceComponent({\n\tChatPrivateHistory,\n});\n\nexport { ChatPrivateHistory };\n","import { connect } from 'react-redux';\nimport { ChatPrivateHistory } from './chat.privateHistory';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\thistory: state.privateMessages.history,\n\t};\n};\n\nconst ChatPrivateHistoryContainer = connect(\n\tmapStateToProps,\n\tnull,\n)(ChatPrivateHistory);\n\nexport { ChatPrivateHistoryContainer };\n","import React, { FC } from 'react';\nimport { UserLogin } from '@common/components/user/UserLogin/UserLogin';\nimport { ChatPrivateListElementStyle } from '@modules/chat/components/private/privateHistory/chat.private.style';\nimport { UserActionsContainer } from '../userActions';\nimport transactionService from '../../../../modules/transactions/transactionsService';\n\nexport const FriendsList: FC<{\n\tlist: Array<any>;\n\tactionsType?: string;\n}> = ({ list, actionsType }) => {\n\treturn (\n\t\t<>\n\t\t\t{list.map((friend) => {\n\t\t\t\treturn (\n\t\t\t\t\t<ChatPrivateListElementStyle\n\t\t\t\t\t\tkey={transactionService.getCompareData(friend, [\n\t\t\t\t\t\t\t'$.user.uuid',\n\t\t\t\t\t\t\t'state',\n\t\t\t\t\t\t])}\n\t\t\t\t\t>\n\t\t\t\t\t\t<UserLogin user={friend.user} className={'text-style-sm-medium'} />\n\t\t\t\t\t\t<UserActionsContainer\n\t\t\t\t\t\t\tuser={friend.user}\n\t\t\t\t\t\t\tstatus={friend.state}\n\t\t\t\t\t\t\tactionsType={actionsType}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</ChatPrivateListElementStyle>\n\t\t\t\t);\n\t\t\t})}\n\t\t</>\n\t);\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { Loader } from '@legacyApp/client/components/loader/loader';\nimport { trans } from '@legacyApp/client/modules/translation/translate';\nimport { FriendsList } from '@legacyApp/client/components/friendsList/friendsList';\nimport { Tabs } from '@legacyApp/client/components/tabs';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport {\n\tChatPrivateBoxStyle,\n\tChatPrivateListStyle,\n\tChatPrivateStyle,\n} from '../private/privateHistory/chat.private.style';\nimport { ChatStreamInfoStyle } from '../stream/chat.stream.style';\n\nclass ChatFriends extends React.PureComponent {\n\tstatic propTypes = {\n\t\tfriends: PropTypes.array,\n\t\trequests: PropTypes.array,\n\t};\n\n\tconstructor(props) {\n\t\tsuper(props);\n\t\tthis.state = {\n\t\t\ttabs: [\n\t\t\t\t{\n\t\t\t\t\tid: 'friends',\n\t\t\t\t\tname: trans({ label: 'Friends' }),\n\t\t\t\t\tloadingId: 'getFriends',\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tid: 'requests',\n\t\t\t\t\tname: trans({ label: 'Friend requests' }),\n\t\t\t\t\tloadingId: 'getFriendRequests',\n\t\t\t\t\tactionsType: 'request',\n\t\t\t\t},\n\t\t\t],\n\t\t\tactiveTab: false,\n\t\t};\n\t\tthis.state.activeTab = this.state.tabs[0];\n\t}\n\n\thandleChangeTab = (el) => {\n\t\tthis.setState({\n\t\t\tactiveTab: el,\n\t\t});\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<ChatPrivateStyle>\n\t\t\t\t<ChatPrivateBoxStyle>\n\t\t\t\t\t<Tabs\n\t\t\t\t\t\tlist={this.state.tabs}\n\t\t\t\t\t\tsmallText={true}\n\t\t\t\t\t\tnoWrap={true}\n\t\t\t\t\t\tlight={true}\n\t\t\t\t\t\tscrollHorizontal={true}\n\t\t\t\t\t\tfullWidth={true}\n\t\t\t\t\t\tcallback={this.handleChangeTab}\n\t\t\t\t\t/>\n\t\t\t\t\t<ChatPrivateListStyle>\n\t\t\t\t\t\t<FriendsList\n\t\t\t\t\t\t\tlist={this.props[this.state.activeTab.id]}\n\t\t\t\t\t\t\tactionsType={this.state.activeTab.actionsType}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<Loader\n\t\t\t\t\t\t\tmodule={this.state.activeTab.loadingId}\n\t\t\t\t\t\t\tmessage={\n\t\t\t\t\t\t\t\t!this.props[this.state.activeTab.id].length && (\n\t\t\t\t\t\t\t\t\t<ChatStreamInfoStyle>\n\t\t\t\t\t\t\t\t\t\t{trans({ label: 'Empty list' })}\n\t\t\t\t\t\t\t\t\t</ChatStreamInfoStyle>\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</ChatPrivateListStyle>\n\t\t\t\t</ChatPrivateBoxStyle>\n\t\t\t</ChatPrivateStyle>\n\t\t);\n\t}\n}\n\nChatFriends = enhanceComponent({\n\tChatFriends,\n});\n\nexport { ChatFriends };\n","import { connect } from 'react-redux';\nimport { ChatFriends } from './chat.friends';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\tfriends: state.friends.list,\n\t\trequests: state.friends.requests,\n\t};\n};\n\nconst ChatFriendsContainer = connect(mapStateToProps, null)(ChatFriends);\n\nexport { ChatFriendsContainer };\n","import styled from 'styled-components';\nimport { FunctionComponent, useRef } from 'react';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { ChatStreamStyle } from '@modules/chat/components/stream/chat.stream.style';\nimport { getId } from '@legacyApp/client/modules/app/appService';\nimport { BetElement } from '../BetElement/BetElement';\nimport { SportsbookListContext } from '../../../context/SportsbookListContext';\nimport { useSportsBetSlipBetsList } from '../../../store/selectors/sportsBetSlip.selectors';\n\nconst BetsList: FunctionComponent = () => {\n\tconst refID = useRef(getId());\n\tconst list = useSportsBetSlipBetsList();\n\n\treturn (\n\t\t<SportsbookListContext.Provider value={{ id: refID.current }}>\n\t\t\t<StyledBetsList>\n\t\t\t\t{list.map((el) => (\n\t\t\t\t\t<BetElement key={`${el.matchId}_${el.outcomeId}`} bet={el} />\n\t\t\t\t))}\n\t\t\t</StyledBetsList>\n\t\t</SportsbookListContext.Provider>\n\t);\n};\n\nconst StyledBetsList = styled(ChatStreamStyle)`\n\t&:after {\n\t\tcontent: '';\n\t\tdisplay: block;\n\t\theight: 250px;\n\t\tposition: static;\n\t\twidth: 100%;\n\t}\n`;\n\nexport default enhanceComponent({\n\tBetsList,\n});\n","import { useCallback, useEffect, useState } from 'react';\nimport { IdDictionary } from '@legacyApp/types/default/IdDictionary';\nimport {\n\tuseValidateStake,\n\tuseValidateStakeCallback,\n} from '@legacyApp/hooks/game/useValidateStake';\nimport {\n\tuseValidateProfit,\n\tuseValidateProfitCallback,\n} from '@legacyApp/hooks/game/useValidateProfit';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { jsonToString } from '@common/methods/jsonToString';\nimport { roundNumber } from '@common/methods/roundNumber/roundNumber';\nimport { BETSLIP_MULTI_LIMIT } from '../constants/betSlip';\nimport { sportsBetSlipSetFormError } from '../store/sportsBetSlip/sportsBetSlip.actions';\nimport { BetSlipMatchDataType } from '../types/BetSlip/BetSlipDataReducerType';\nimport { BetSlipBet } from '../types/BetSlip/BetSlipBet';\nimport { GameType } from '../../games/Game/constants/availableGames';\nimport { checkBetSlipError } from './useCheckBetError';\n\nconst useValidateBetsList = (\n\tbetsList: BetSlipBet[],\n\tbetsData: IdDictionary<BetSlipMatchDataType>,\n) => {\n\tconst validateStake = useValidateStakeCallback();\n\tconst validateProfit = useValidateProfitCallback();\n\tconst [bool, setBool] = useState(true);\n\n\tconst check = useCallback(() => {\n\t\treturn !betsList.some((bet) => {\n\t\t\tif (validateStake(bet.stake, GameType.SPORTS)?.error) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\treturn !!validateProfit(\n\t\t\t\troundNumber(\n\t\t\t\t\tbet.stake *\n\t\t\t\t\t\t((betsData?.[bet.matchId]?.outcome?.[bet.outcomeId]?.decimal_odds ||\n\t\t\t\t\t\t\t1) -\n\t\t\t\t\t\t\t1),\n\t\t\t\t),\n\t\t\t\tGameType.SPORTS,\n\t\t\t)?.error;\n\t\t});\n\t}, [betsData, betsList, validateProfit, validateStake]);\n\n\tuseEffect(() => {\n\t\tsetBool(check());\n\t}, [check]);\n\n\treturn bool;\n};\n\nconst useErrorBetsList = () => {\n\tconst [bool, setBool] = useState<boolean | string>(false);\n\tconst { betsList, type } = useAppSelector((state) => ({\n\t\tbetsList: state.sportsBetSlip?.betsList,\n\t\ttype: state.sportsBetSlip?.type?.id,\n\t}));\n\n\tconst check = useCallback(() => {\n\t\treturn type === 'multi'\n\t\t\t? betsList.some((bet) => bet.error?.multiMatch)\n\t\t\t: betsList.some((bet) => checkBetSlipError(bet.error));\n\t}, [betsList, type]);\n\n\tuseEffect(() => {\n\t\tsetBool(check());\n\t}, [check]);\n\n\treturn bool;\n};\n\nconst useErrorBetsListLength = () => {\n\tconst [bool, setBool] = useState<boolean | string>(false);\n\tconst { betsList, type } = useAppSelector((state) => ({\n\t\tbetsList: state.sportsBetSlip?.betsList,\n\t\ttype: state.sportsBetSlip?.type?.id,\n\t}));\n\n\tconst isMulti = type === 'multi';\n\n\tconst check = useCallback(() => {\n\t\treturn (\n\t\t\tbetsList.length > BETSLIP_MULTI_LIMIT &&\n\t\t\tisMulti &&\n\t\t\t'Exceeded max events amount on single multi bet'\n\t\t);\n\t}, [betsList.length, isMulti]);\n\n\tuseEffect(() => {\n\t\tsetBool(check());\n\t}, [check]);\n\n\treturn bool;\n};\n\nexport const useBetSlipValidation = ({\n\tstake,\n\ttotalMultiOdds,\n}: {\n\tstake: number;\n\ttotalMultiOdds: number;\n}): {\n\tdisabled: boolean;\n} => {\n\tconst dispatch = useAppDispatch();\n\tconst { betsList, betsData, type, error } = useAppSelector((state) => ({\n\t\tbetsList: state.sportsBetSlip?.betsList,\n\t\tbetsData: state.sportsBetSlip?.bets,\n\t\ttype: state.sportsBetSlip?.type?.id,\n\t\terror: state.sportsBetSlip?.error,\n\t}));\n\n\tconst isMulti = type === 'multi';\n\tconst profit = roundNumber(stake * (totalMultiOdds - 1));\n\n\tconst stakeValidation = useValidateStake({\n\t\tvalue: stake,\n\t\tgame: GameType.SPORTS,\n\t});\n\tconst profitValidation = useValidateProfit({\n\t\tvalue: profit,\n\t\tgame: GameType.SPORTS,\n\t});\n\tconst betsListValidation = useValidateBetsList(betsList, betsData);\n\tconst betSlipLengthError = useErrorBetsListLength();\n\tconst betSlipListError = useErrorBetsList();\n\n\tconst disabled =\n\t\tcheckBetSlipError(error.message) ||\n\t\t((stakeValidation.error || profitValidation.error) && isMulti);\n\n\tuseEffect(() => {\n\t\tconst invalid = isMulti\n\t\t\t? stake > 0\n\t\t\t\t? profitValidation.error ||\n\t\t\t\t  stakeValidation.error ||\n\t\t\t\t  betSlipLengthError ||\n\t\t\t\t  betSlipListError\n\t\t\t\t: null\n\t\t\t: !betsListValidation || betSlipListError || null;\n\n\t\tif (!(!error?.message?.default && !invalid)) {\n\t\t\t// console.log('invalid', {\n\t\t\t// \tinvalid,\n\t\t\t// \tjsonInvalid: jsonToString(invalid),\n\t\t\t// \tjsonError: jsonToString(error?.message?.default),\n\t\t\t// \terror: error?.message?.default,\n\t\t\t// \tbetSlipListError,\n\t\t\t// \tisMulti,\n\t\t\t// \tprofitValidation: profitValidation.error,\n\t\t\t// \tstakeValidation: stakeValidation.error,\n\t\t\t// \tbetSlipLengthError,\n\t\t\t// \tbetsListValidation,\n\t\t\t// \tstake,\n\t\t\t// });\n\t\t\tdispatch(\n\t\t\t\tsportsBetSlipSetFormError({\n\t\t\t\t\ttype: invalid ? 'error' : null,\n\t\t\t\t\tmessage: {\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tjsonToString(invalid) === jsonToString(error?.message?.default)\n\t\t\t\t\t\t\t\t? error?.message?.default\n\t\t\t\t\t\t\t\t: invalid,\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\t}, [\n\t\tprofitValidation.error,\n\t\tbetsListValidation,\n\t\tbetSlipLengthError,\n\t\tbetSlipListError,\n\t\tdispatch,\n\t\tstakeValidation.error,\n\t\tisMulti,\n\t\tstake,\n\t\terror?.message?.default,\n\t]);\n\n\t// console.log('useBetSlipValidation', { isMulti, profit, stake, stakeValidation, profitValidation, disabled, error });\n\n\treturn {\n\t\tdisabled,\n\t};\n};\n","import styled from 'styled-components';\nimport { FunctionComponent, useCallback } from 'react';\nimport {\n\ttrans,\n\ttransSports,\n} from '@legacyApp/client/modules/translation/translate';\nimport { Button } from '@legacyApp/client/components/button';\nimport { AuthActionButton } from '@common/components/auth/AuthActionButton';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\nimport { sportsBetSlipSubmit } from '../../../store/sportsBetSlip/sportsBetSlip.thunk';\nimport {\n\tsportsBetSlipSetBets,\n\tsportsBetSlipSetBetsList,\n} from '../../../store/sportsBetSlip/sportsBetSlip.actions';\nimport { useBetSlipValidation } from '../../../hooks/useBetSlipValidation';\nimport { useValidateBetsListOdds } from '../../../hooks/useValidateBetsListOdds';\nimport {\n\tuseSportsBetSlipBetsData,\n\tuseSportsBetSlipBetsList,\n} from '../../../store/selectors/sportsBetSlip.selectors';\n\nconst BetSlipSubmit: FunctionComponent<{\n\tstake: number;\n\ttotalMultiOdds: number;\n}> = ({ stake, totalMultiOdds }) => {\n\tconst dispatch = useAppDispatch();\n\n\tconst betsData = useSportsBetSlipBetsData();\n\tconst betsList = useSportsBetSlipBetsList();\n\n\tconst { disabled } = useBetSlipValidation({\n\t\tstake,\n\t\ttotalMultiOdds,\n\t});\n\n\tconst { isNewOdds } = useValidateBetsListOdds();\n\n\tconst submit = useCallback(() => {\n\t\t// console.log('submitBetSlip', {\n\t\t// \terror,\n\t\t// \tstakeValidation,\n\t\t// \ttype,\n\t\t// \tbetsList,\n\t\t// });\n\t\tif (disabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst updatedBetsData = { ...betsData };\n\t\tconst updateBetsList = betsList\n\t\t\t.filter((el) => !el.placed_at)\n\t\t\t.map((bet) => {\n\t\t\t\tif (bet.newOdds) {\n\t\t\t\t\tupdatedBetsData[bet.matchId].outcome[bet.outcomeId].decimal_odds =\n\t\t\t\t\t\tbet.newOdds;\n\t\t\t\t\treturn {\n\t\t\t\t\t\t...bet,\n\t\t\t\t\t\toddsChanged: false,\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\treturn bet;\n\t\t\t});\n\n\t\tdispatch(sportsBetSlipSetBets(updatedBetsData));\n\t\tdispatch(sportsBetSlipSetBetsList(updateBetsList));\n\t\tif (isNewOdds) {\n\t\t\tdispatch(sportsBetSlipSubmit(stake));\n\t\t}\n\t}, [disabled, betsData, betsList, dispatch, isNewOdds, stake]);\n\n\t// console.log('submitBetSlip', {\n\t// \terror,\n\t// \tstakeValidation,\n\t// \ttype,\n\t// \tbetsList,\n\t// \tbetSlipLengthError,\n\t// \tbetsListValidation,\n\t// \tbetSlipListError,\n\t// \tprofitValidation,\n\t// });\n\n\treturn (\n\t\t<AuthActionButton labelText={'Login to place bet'}>\n\t\t\t{!isNewOdds && (\n\t\t\t\t<StyledOddsInfo>\n\t\t\t\t\t{transSports({\n\t\t\t\t\t\tlabel:\n\t\t\t\t\t\t\t'Odds have changed! Please review them before placing your bet',\n\t\t\t\t\t})}\n\t\t\t\t</StyledOddsInfo>\n\t\t\t)}\n\t\t\t<StyledButton\n\t\t\t\tdisabled={disabled}\n\t\t\t\tonClick={submit}\n\t\t\t\tname={'submit-betslip'}\n\t\t\t>\n\t\t\t\t{!isNewOdds\n\t\t\t\t\t? transSports({ label: 'accept new odds' })\n\t\t\t\t\t: trans({ label: 'place bet' })}\n\t\t\t</StyledButton>\n\t\t</AuthActionButton>\n\t);\n};\n\nconst StyledOddsInfo = styled.p`\n\tcolor: ${(props) => props.theme.colors.negative};\n\tmargin: 0.25rem 0 !important;\n\t${fontSize({\n\t\tsizeDiff: -4,\n\t\tsizeDesktopDiff: -4,\n\t\tsizeBigScreenDiff: -4,\n\t\timportant: true,\n\t})};\n`;\n\nconst StyledButton = styled(Button)`\n\tmargin: 0;\n\ttext-transform: capitalize;\n\twidth: 100%;\n`;\n\nexport default BetSlipSubmit;\n","import { useCallback, useEffect, useState } from 'react';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport {\n\tALL_ACCEPT,\n\tNO_ODDS_ACCEPT,\n\tONLY_HIGHER_ACCEPT,\n} from '../constants/betSlipAcceptTypes';\n\nexport const useValidateBetsListOdds = (): {\n\tisNewOdds: boolean;\n} => {\n\tconst { betsList, betsData, acceptType } = useAppSelector((state) => ({\n\t\tbetsList: state.sportsBetSlip?.betsList,\n\t\tbetsData: state.sportsBetSlip?.bets,\n\t\ttype: state.sportsBetSlip?.type?.id,\n\t\tacceptType: state.sportsBetSlip?.acceptType,\n\t}));\n\n\tconst [bool, setBool] = useState(true);\n\n\tconst check = useCallback(() => {\n\t\tif (acceptType.id === ALL_ACCEPT) {\n\t\t\treturn true;\n\t\t}\n\t\treturn !betsList\n\t\t\t.filter((el) => !el.placed_at)\n\t\t\t.some((bet) => {\n\t\t\t\tif (!bet.newOdds) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\tif (acceptType.id === ONLY_HIGHER_ACCEPT) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t(betsData?.[bet.matchId]?.outcome?.[bet.outcomeId]?.decimal_odds ||\n\t\t\t\t\t\t\t1) > bet.newOdds\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tif (acceptType.id === NO_ODDS_ACCEPT) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t(betsData?.[bet.matchId]?.outcome?.[bet.outcomeId]?.decimal_odds ||\n\t\t\t\t\t\t\t1) !== bet.newOdds\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treturn false;\n\t\t\t});\n\t}, [acceptType.id, betsData, betsList]);\n\n\tuseEffect(() => {\n\t\tsetBool(check());\n\t}, [check]);\n\n\treturn {\n\t\tisNewOdds: bool,\n\t};\n};\n","import { FC } from 'react';\nimport styled from 'styled-components';\nimport { faRedoAlt } from '@fortawesome/free-solid-svg-icons';\nimport { transSports } from '@legacyApp/client/modules/translation/translate';\nimport { Button } from '@legacyApp/client/components/button';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\nimport { sportsBetSlipSetBetsList } from '../../../store/sportsBetSlip/sportsBetSlip.actions';\n\nconst sportsBetSlipReuseFailedBets = (): AppThunk => {\n\treturn (dispatch, getState) => {\n\t\tdispatch(\n\t\t\tsportsBetSlipSetBetsList(\n\t\t\t\tgetState().sportsBetSlip.betsList.map((el) => ({\n\t\t\t\t\t...el,\n\t\t\t\t\tplaced_at: null,\n\t\t\t\t\tinfo: null,\n\t\t\t\t})),\n\t\t\t),\n\t\t);\n\t};\n};\n\nexport const ReuseFailedBets: FC = () => {\n\tconst dispatch = useAppDispatch();\n\tconst reuseBets = () => dispatch(sportsBetSlipReuseFailedBets());\n\treturn (\n\t\t<StyledReuseFailedBets onClick={reuseBets} localTheme={{ type: 'clear' }}>\n\t\t\t<AwesomeIcon icon={faRedoAlt} />{' '}\n\t\t\t{transSports({ label: 'Reuse failed bets' })}\n\t\t</StyledReuseFailedBets>\n\t);\n};\n\nexport const StyledReuseFailedBets = styled(Button)`\n\tmargin: 0 0 0.5rem;\n\tpadding: 0;\n\ttext-align: left;\n\t${fontSize({ sizeDiff: -2, sizeDesktopDiff: -2, sizeBigScreenDiff: -2 })}\n\n\ti, svg {\n\t\tmargin-right: 0.25rem;\n\t}\n`;\n","import { FC, useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { faTrash } from '@fortawesome/free-solid-svg-icons';\nimport { Button } from '@legacyApp/client/components/button';\nimport { DropdownStyle } from '@legacyApp/client/components/dropdown/dropdown.style';\nimport { ButtonStyle } from '@legacyApp/client/components/button/button.style';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\nimport { TransNamespace } from '@legacyApp/client/modules/translation/TransNamespace';\nimport { Dropdown } from '@legacyApp/client/components/dropdown/dropdown';\nimport { ReuseFailedBets } from '../ReuseFailedBets/ReuseFailedBets';\nimport { BETSLIP_ACCEPT_TYPES } from '../../../constants/betSlip';\nimport { sportsBetSlipSetAcceptType } from '../../../store/sportsBetSlip/sportsBetSlip.actions';\nimport {\n\tsportsBetSlipClearPlacedBets,\n\tsportsBetSlipUpdate,\n} from '../../../store/sportsBetSlip/sportsBetSlip.thunk';\nimport { BetSlipBet } from '../../../types/BetSlip/BetSlipBet';\nimport {\n\tuseSportsBetSlipAcceptType,\n\tuseSportsBetSlipBetsList,\n} from '../../../store/selectors/sportsBetSlip.selectors';\n\nconst checkReuseFailed = (list: BetSlipBet[]): boolean => {\n\treturn list.some((el) => el.placed_at && el.info && !el.result_odds);\n};\n\nexport const BetSlipFormOptions: FC = () => {\n\tconst dispatch = useAppDispatch();\n\tconst clearBets = () => dispatch(sportsBetSlipUpdate({}));\n\tconst updateAcceptType = (data) => {\n\t\tdispatch(sportsBetSlipSetAcceptType(data));\n\t\tdispatch(sportsBetSlipClearPlacedBets());\n\t};\n\tconst acceptType = useSportsBetSlipAcceptType();\n\tconst list = useSportsBetSlipBetsList();\n\tconst [isReuseFailed, setIsReuseFailed] = useState(false);\n\n\tuseEffect(() => {\n\t\tsetIsReuseFailed(checkReuseFailed(list));\n\t}, [list]);\n\n\treturn (\n\t\t<StyledOptions>\n\t\t\t{isReuseFailed ? (\n\t\t\t\t<ReuseFailedBets />\n\t\t\t) : (\n\t\t\t\t<Dropdown\n\t\t\t\t\tid=\"betSlipAcceptType\"\n\t\t\t\t\ttrans={TransNamespace.SPORTS}\n\t\t\t\t\titems={BETSLIP_ACCEPT_TYPES}\n\t\t\t\t\tactive={acceptType.name}\n\t\t\t\t\tonClick={updateAcceptType}\n\t\t\t\t/>\n\t\t\t)}\n\t\t\t<Button\n\t\t\t\tlocalTheme={{ type: 'clear' }}\n\t\t\t\tname={'delete-all'}\n\t\t\t\tonClick={clearBets}\n\t\t\t>\n\t\t\t\t<AwesomeIcon icon={faTrash} />\n\t\t\t</Button>\n\t\t</StyledOptions>\n\t);\n};\n\nconst StyledDropdownElement = styled.span`\n\tfont-family: ${(props) => props.theme.text.fonts.Black};\n\t${fontSize({\n\t\tsizeDiff: -2,\n\t\tsizeDesktopDiff: -2,\n\t\tsizeBigScreenDiff: -2,\n\t\timportant: true,\n\t})};\n\tpadding: 5px 0;\n\ttext-transform: capitalize;\n`;\n\nconst StyledOptions = styled.div`\n\tbottom: 100%;\n\tdisplay: grid;\n\tgrid-template-columns: calc(100% - 30px) 30px;\n\tleft: 0;\n\tpadding: 0 10px !important;\n\tposition: absolute;\n\twidth: 100%;\n\n\t${DropdownStyle} {\n\t\t${ButtonStyle} {\n\t\t\t${fontSize({\n\t\t\t\tsizeDiff: -2,\n\t\t\t\tsizeDesktopDiff: -2,\n\t\t\t\tsizeBigScreenDiff: -2,\n\t\t\t\timportant: true,\n\t\t\t})};\n\t\t\tfont-family: ${(props) => props.theme.text.fonts.Black};\n\t\t\tmargin: 0;\n\t\t\twhite-space: nowrap;\n\t\t\tpadding: 0 25px 0 0;\n\t\t\ttext-transform: capitalize;\n\t\t\tbackground-color: transparent;\n\t\t\theight: 100%;\n\t\t\tmax-width: 100%;\n\t\t\ttext-overflow: ellipsis;\n\t\t\toverflow: hidden;\n\n\t\t\ti,\n\t\t\tsvg {\n\t\t\t\tright: 5px;\n\t\t\t}\n\t\t}\n\t}\n\n\t> ${ButtonStyle} {\n\t\tmargin: 0;\n\t\tpadding: 5px 0;\n\t}\n`;\n","import { FC } from 'react';\nimport styled, { css } from 'styled-components';\nimport { config } from '@legacyApp/client/config';\nimport { GameType } from '@modules/games/Game/constants/availableGames';\nimport {\n\tuseSportsBetSlipBetsData,\n\tuseSportsBetSlipPlacedBets,\n\tuseSportsBetSlipReadyToBetBets,\n\tuseSportsEventsData,\n} from '../../../store/selectors/sportsBetSlip.selectors';\nimport { checkDisabledOffer } from '../../Match/Details/OutcomesList/OutcomesList';\nimport { StakeInput } from './StakeInput';\n\nexport const BetSlipFormMultiInput: FC<{\n\tamount: number | string;\n\tupdate: (string) => void;\n\tupdateError?: (error) => void;\n}> = ({ amount, update, updateError }) => {\n\tconst placedBets = useSportsBetSlipPlacedBets();\n\tconst betsList = useSportsBetSlipReadyToBetBets();\n\tconst eventsData = useSportsEventsData();\n\tconst betsData = useSportsBetSlipBetsData();\n\n\tconst disabled =\n\t\tbetsList.findIndex((bet) => {\n\t\t\tconst outcome = betsData?.[bet.matchId]?.outcome?.[bet.outcomeId];\n\t\t\tconst offerData = eventsData.odds?.[`${outcome?.offer_id}__offers`];\n\n\t\t\t// console.log('BetSlipFormMultiInput', {\n\t\t\t// \t// @ts-expect-error invalid type in SportEventsDataReducer\n\t\t\t// \tdisabled: checkDisabledOffer(offerData?.state),\n\t\t\t// \tbetsList,\n\t\t\t// \tbet,\n\t\t\t// \tofferData,\n\t\t\t// \toutcome,\n\t\t\t// \tbetsData,\n\t\t\t// \teventsData,\n\t\t\t// });\n\n\t\t\t// @ts-expect-error invalid type in SportEventsDataReducer\n\t\t\treturn checkDisabledOffer(offerData?.state);\n\t\t}) > -1;\n\n\treturn (\n\t\t!placedBets.length && (\n\t\t\t<StyledBetSlipFormMultiInput $disabled={disabled}>\n\t\t\t\t<StakeInput\n\t\t\t\t\tgame={GameType.SPORTS}\n\t\t\t\t\tvalue={amount}\n\t\t\t\t\tupdateError={updateError}\n\t\t\t\t\tupdate={update}\n\t\t\t\t\tprecision={config.decimals.bet}\n\t\t\t\t/>\n\t\t\t</StyledBetSlipFormMultiInput>\n\t\t)\n\t);\n};\n\nconst StyledBetSlipFormMultiInput = styled.div<{\n\t$disabled?: boolean;\n}>`\n\t${(props) =>\n\t\tprops.$disabled\n\t\t\t? css`\n\t\t\t\t\topacity: 0.3;\n\t\t\t\t\tpointer-events: none;\n\t\t\t  `\n\t\t\t: ''}\n`;\n","import { FunctionComponent } from 'react';\nimport {\n\tfaCalendarCheck,\n\tfaExclamationCircle,\n} from '@fortawesome/free-solid-svg-icons';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport {\n\tBetSlipError,\n\tStyledBetSlipElementMessage,\n} from '../BetElement/BetSlipElementMessage';\nimport { checkBetSlipError } from '../../../hooks/useCheckBetError';\nimport {\n\tuseSportsBetSlipBetsList,\n\tuseSportsBetSlipError,\n} from '../../../store/selectors/sportsBetSlip.selectors';\n\nexport const BetSlipFormMessage: FunctionComponent = () => {\n\tconst error = useSportsBetSlipError();\n\tconst betsList = useSportsBetSlipBetsList();\n\n\tif (\n\t\tcheckBetSlipError(error.message, true) ||\n\t\t!betsList.some((bet) => !bet.placed_at)\n\t) {\n\t\t// console.log('BetSlipFormMessage', {error, betsList});\n\t\treturn (\n\t\t\t<StyledBetSlipElementMessage $success={error.type === 'success'}>\n\t\t\t\t<span>\n\t\t\t\t\t<AwesomeIcon\n\t\t\t\t\t\ticon={\n\t\t\t\t\t\t\terror.type === 'success' ? faExclamationCircle : faCalendarCheck\n\t\t\t\t\t\t}\n\t\t\t\t\t\tclassName={'small-margin-right'}\n\t\t\t\t\t/>\n\t\t\t\t\t<BetSlipError error={error.message} />\n\t\t\t\t</span>\n\t\t\t</StyledBetSlipElementMessage>\n\t\t);\n\t}\n\n\treturn null;\n};\n","import React, { Component, PureComponent, ReactElement } from 'react';\nimport styled from 'styled-components';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { filterArrayDuplicates } from '@legacyApp/client/modules/app/appService';\nimport { config } from '@legacyApp/client/config';\nimport {\n\tborderRadius,\n\tboxNoHeight,\n} from '@legacyApp/client/modules/style/defaults';\nimport { IdDictionary } from '@legacyApp/types/default/IdDictionary';\nimport { InputWrapperStyle } from '@legacyApp/client/components/input/styled/inputWrapper.style';\nimport { mathService } from '@legacyApp/client/modules/math/mathService';\nimport { lsSet } from '@modules/localStorage/methods/lsSet';\nimport { lsGet } from '@modules/localStorage/methods/lsGet';\nimport { LocalStorageKeys } from '@modules/localStorage/types/localStorageKeys.type';\nimport { roundNumber } from '@common/methods/roundNumber/roundNumber';\nimport transactionService from '../../../../transactions/transactionsService';\nimport { MatchOdds } from '../../Match/MatchOdds/MatchOdds';\nimport { BetSlipInput } from '../BetElement/BetSlipElementForm';\nimport { StyledBetSlipElementMessage } from '../BetElement/BetSlipElementMessage';\nimport {\n\tBetSlipBet,\n\tBetSlipErrorType,\n} from '../../../types/BetSlip/BetSlipBet';\nimport { BetSlipTypeType } from '../../../types/BetSlip/BetSlipType';\nimport {\n\tBetSlipMatchDataOutcomeType,\n\tBetSlipMatchDataType,\n} from '../../../types/BetSlip/BetSlipDataReducerType';\nimport { MatchType } from '../../../types/Match/MatchType';\nimport SummaryValue from './SummaryValue';\nimport BetSlipSubmit from './BetSlipSubmit';\nimport { BetSlipFormOptions } from './BetSlipFormOptions';\nimport { BetSlipFormMultiInput } from './BetSlipFormMultiInput';\nimport { BetSlipFormMessage } from './BetSlipFormMessage';\n\nexport interface BetSlipFormProps {\n\tsubmit: () => void;\n\tisLogged: boolean;\n\ttype: BetSlipTypeType;\n\tlist: BetSlipBet[];\n\tonUpdate: (list: BetSlipBet[]) => void;\n\tonUpdateError: (error: IdDictionary<string | Component>) => void;\n\terror: {\n\t\ttype: string;\n\t\tmessage: BetSlipErrorType;\n\t};\n\tplacedBets: BetSlipBet[];\n\tbets: IdDictionary<BetSlipMatchDataType>;\n}\n\nexport class BetSlipForm extends PureComponent<BetSlipFormProps> {\n\tstate = {\n\t\ttotalMultiOdds: 0,\n\t\ttotalSingleStake: 0,\n\t\ttotalWin: 0,\n\t\tstake: lsGet(LocalStorageKeys.SPORTS_BETSLIP_MULTI_STAKE) || null,\n\t};\n\n\tcomponentDidMount = (): void => {\n\t\tthis.setPossibleWinnings();\n\t\tthis.setTotalOdds();\n\t\tthis.setTotalStake();\n\t\tif (this.state.stake === null) {\n\t\t\tthis.setStakeFromFirstListElement();\n\t\t}\n\t};\n\n\tcomponentDidUpdate(prevProps: BetSlipFormProps, prevState): void {\n\t\tconst currentList = this.getCompareList([\n\t\t\t...(this.props.placedBets.length\n\t\t\t\t? this.props.placedBets\n\t\t\t\t: this.props.list),\n\t\t]);\n\t\tconst prevList = this.getCompareList([\n\t\t\t...(prevProps.placedBets.length ? prevProps.placedBets : prevProps.list),\n\t\t]);\n\t\tconst isStakeListChanged = transactionService.isListDifferent(\n\t\t\tcurrentList,\n\t\t\tprevList,\n\t\t\t['stake'],\n\t\t);\n\t\tconst isStakeChanged = mathService.isNumberDiff(\n\t\t\tprevState.stake,\n\t\t\tthis.state.stake,\n\t\t);\n\t\tconst isOddsChanged = transactionService.isListDifferent(\n\t\t\tcurrentList,\n\t\t\tprevList,\n\t\t\t['decimal_odds'],\n\t\t);\n\t\tconst isTypeChanged = this.props.type !== prevProps.type;\n\n\t\t// console.log('componentDidUpdate', {\n\t\t// \tisOddsChanged,\n\t\t// \tisStakeChanged,\n\t\t// \tcurrentList,\n\t\t// \tprevList,\n\t\t// });\n\n\t\tif (isTypeChanged) {\n\t\t\tthis.setPossibleWinnings();\n\t\t}\n\n\t\tif (isStakeListChanged) {\n\t\t\tthis.setTotalStake();\n\t\t\tthis.setStakeFromFirstListElement();\n\t\t}\n\n\t\tif (isOddsChanged) {\n\t\t\tthis.setTotalOdds();\n\t\t}\n\n\t\tif (isStakeChanged || isOddsChanged) {\n\t\t\tthis.setPossibleWinnings();\n\t\t}\n\t}\n\n\tgetCompareList = (\n\t\tlist: BetSlipBet[],\n\t): { stake: number; decimal_odds: number }[] => {\n\t\treturn list.map((bet) => {\n\t\t\treturn {\n\t\t\t\tstake: bet?.stake || 0,\n\t\t\t\tdecimal_odds: this.getBetOdds(bet) || 0,\n\t\t\t};\n\t\t});\n\t};\n\n\tgetBetDetails = (\n\t\tmatchId: string,\n\t\toutcomeId: string,\n\t): {\n\t\tdata: MatchType;\n\t\toutcome: BetSlipMatchDataOutcomeType;\n\t} => {\n\t\tconst match = this.props.bets[matchId];\n\t\treturn {\n\t\t\tdata: match?.data,\n\t\t\toutcome: match?.outcome?.[outcomeId],\n\t\t};\n\t};\n\n\tsetStakeFromFirstListElement = (): void => {\n\t\tlet stake = 0;\n\t\tconst filtered = filterArrayDuplicates(this.props.list, ['stake']);\n\t\tif (filtered.length === 1) {\n\t\t\tstake = filtered[0].stake;\n\t\t}\n\t\t// console.log('setStakeFromFirstListElement', { filtered, stake, state: this.state, });\n\t\tif (stake === this.state.stake) {\n\t\t\treturn;\n\t\t}\n\t\tthis.setState({ stake });\n\t};\n\n\tsetPossibleWinnings = (): void => {\n\t\tlet result = 0;\n\t\tif (this.props.type === 'single') {\n\t\t\tresult = this.props.list.reduce((a, b) => {\n\t\t\t\treturn a + roundNumber(b.stake * (this.getBetOdds(b) - 1));\n\t\t\t}, 0);\n\t\t} else if (this.props.type === 'multi') {\n\t\t\tconst odds = roundNumber(\n\t\t\t\tthis.props.list.reduce((a, b) => {\n\t\t\t\t\treturn a * this.getBetOdds(b);\n\t\t\t\t}, 1),\n\t\t\t\t2,\n\t\t\t\t'floor',\n\t\t\t);\n\t\t\tconst stake = this.state.stake;\n\t\t\tresult = (odds - 1) * stake;\n\t\t\t// console.log('setPossibleWinnings', {\n\t\t\t// \todds,\n\t\t\t// \tstake,\n\t\t\t// \tresult,\n\t\t\t// \tlist: [...this.props.list],\n\t\t\t// });\n\t\t}\n\t\tif (result === this.state.totalWin) {\n\t\t\treturn;\n\t\t}\n\t\tthis.setState({ totalWin: result });\n\t};\n\n\tsetTotalOdds = (): void => {\n\t\tlet result = 1;\n\t\tthis.props.list?.forEach((bet) => {\n\t\t\tresult = result * this.getBetOdds(bet);\n\t\t});\n\t\t// console.log('setTotalOdds', result, round(result, 2, 'floor'));\n\t\tif (result === this.state.totalMultiOdds) {\n\t\t\treturn;\n\t\t}\n\t\tthis.setState({ totalMultiOdds: roundNumber(result, 2, 'floor') });\n\t};\n\n\tgetBetOdds = (bet) => {\n\t\tconst { outcome } = this.getBetDetails(bet.matchId, bet.outcomeId);\n\t\treturn bet?.result_odds || bet?.newOdds || outcome?.decimal_odds;\n\t};\n\n\tsetTotalStake = (): void => {\n\t\tlet result = 0;\n\t\tthis.props.list?.forEach((bet) => {\n\t\t\tresult += bet.stake;\n\t\t});\n\t\tif (result === this.state.totalSingleStake) {\n\t\t\treturn;\n\t\t}\n\t\tthis.setState({\n\t\t\ttotalSingleStake: roundNumber(result, config.decimals.bet),\n\t\t});\n\t};\n\n\tonChange = (value: string): void => {\n\t\t// console.log('onChange', {value});\n\t\tconst stake = parseFloat(value);\n\t\tlsSet(LocalStorageKeys.SPORTS_BETSLIP_MULTI_STAKE, stake);\n\t\tthis.setState({ stake });\n\t};\n\n\tinputUpdateError = (error) =>\n\t\tthis.props.onUpdateError({\n\t\t\t...(this.props.error?.message || {}),\n\t\t\tstake: error,\n\t\t});\n\n\trender(): ReactElement {\n\t\treturn (\n\t\t\t<StyledBetSlipForm>\n\t\t\t\t<BetSlipFormOptions />\n\t\t\t\t<StyledBetSlipFormBox>\n\t\t\t\t\t<StyledSummary>\n\t\t\t\t\t\t{this.props.type === 'multi' && (\n\t\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t\t<BetSlipFormMessage />\n\t\t\t\t\t\t\t\t<BetSlipFormMultiInput\n\t\t\t\t\t\t\t\t\tupdate={this.onChange}\n\t\t\t\t\t\t\t\t\tupdateError={this.inputUpdateError}\n\t\t\t\t\t\t\t\t\tamount={this.state.stake}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{this.props.type === 'single' ? (\n\t\t\t\t\t\t\t<SummaryValue\n\t\t\t\t\t\t\t\ttitle=\"total stake\"\n\t\t\t\t\t\t\t\tvalue={this.state.totalSingleStake}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) : this.props.type === 'multi' ? (\n\t\t\t\t\t\t\t<SummaryValue\n\t\t\t\t\t\t\t\ttitle=\"total odds\"\n\t\t\t\t\t\t\t\tsimpleValue\n\t\t\t\t\t\t\t\tvalue={<MatchOdds odds={this.state.totalMultiOdds} />}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) : null}\n\t\t\t\t\t\t<SummaryValue\n\t\t\t\t\t\t\ttitle=\"possible winnings\"\n\t\t\t\t\t\t\tvalueProps={{\n\t\t\t\t\t\t\t\tcolor: true,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\tvalue={this.state.totalWin}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</StyledSummary>\n\t\t\t\t\t<BetSlipSubmit\n\t\t\t\t\t\ttotalMultiOdds={this.state.totalMultiOdds}\n\t\t\t\t\t\tstake={this.state.stake}\n\t\t\t\t\t/>\n\t\t\t\t</StyledBetSlipFormBox>\n\t\t\t</StyledBetSlipForm>\n\t\t);\n\t}\n}\n\nexport const StyledSummary = styled.div`\n\tdisplay: grid;\n\tgrid-row-gap: 0.5rem;\n\tgrid-template-columns: 100%;\n\tmargin: 0 0 0.5rem;\n\n\t> div {\n\t\tmargin: 0 !important;\n\t}\n`;\n\nconst StyledBetSlipFormBox = styled.div`\n\t${boxNoHeight};\n\tbackground-color: #062247;\n\n\t@media (max-width: ${(props) => props.theme.media.maxWidthTablet}) {\n\t\t${InputWrapperStyle} {\n\t\t\tpadding-bottom: 0;\n\t\t}\n\t}\n`;\n\nexport const StyledBetSlipForm = styled.div`\n\tbackground: ${(props) => props.theme.colors.background};\n\tbottom: 0;\n\tfloat: left;\n\tleft: 0;\n\tposition: absolute;\n\twidth: 100%;\n\tz-index: 2;\n\n\t> * {\n\t\tpadding: 10px;\n\t}\n\n\t&:before {\n\t\tbackground: linear-gradient(\n\t\t\t0deg,\n\t\t\t${(props) => props.theme.colors.background} 0%,\n\t\t\ttransparent 100%\n\t\t);\n\t\tcontent: '';\n\t\theight: 40px;\n\t\tleft: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\ttop: -40px;\n\t\twidth: 100%;\n\t}\n\n\t${BetSlipInput};\n\n\t${StyledBetSlipElementMessage} {\n\t\t${borderRadius};\n\t\tpadding: 0.5rem 0.75rem;\n\t}\n\n\t@media (max-width: ${(props) => props.theme.media.maxWidthTablet}) {\n\t\t> * {\n\t\t\tpadding: 6px;\n\t\t}\n\t}\n`;\n\nexport default enhanceComponent({\n\tBetSlipForm,\n});\n","import { connect } from 'react-redux';\nimport {\n\tsportsBetSlipSetBetsList,\n\tsportsBetSlipSetFormError,\n} from '../../../store/sportsBetSlip/sportsBetSlip.actions';\nimport BetSlipForm from './BetSlipForm';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\tisLogged: state.user.isLogged,\n\t\tlist: state.sportsBetSlip?.betsList.filter((el) => !el.placed_at),\n\t\tplacedBets: state.sportsBetSlip?.betsList.filter((el) => el.placed_at),\n\t\ttype: state.sportsBetSlip?.type?.id,\n\t\tbets: state.sportsBetSlip?.bets,\n\t\tacceptType: state.sportsBetSlip?.acceptType,\n\t\terror: state.sportsBetSlip?.error,\n\t};\n};\n\nconst mapDispatchToProps = (dispatch) => {\n\treturn {\n\t\tonUpdate: (list) => dispatch(sportsBetSlipSetBetsList(list)),\n\t\tonUpdateError: (error) =>\n\t\t\tdispatch(sportsBetSlipSetFormError({ type: 'error', message: error })),\n\t};\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(BetSlipForm);\n","import styled from 'styled-components';\nimport { boxNoHeight } from '@legacyApp/client/modules/style/defaults';\nimport { StyledLoader } from '@legacyApp/client/components/loader/Loader.styled';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\n\nexport const StyledBetSlipInfo = styled.div`\n\talign-items: flex-start;\n\tdisplay: flex;\n\tflex-direction: column;\n\theight: 100%;\n\tjustify-content: flex-start;\n\tpadding-top: 0.5rem;\n\twidth: 100%;\n\n\tdiv {\n\t\t${boxNoHeight};\n\t\tpadding: 0 5px 0 30px;\n\t\tposition: relative;\n\t}\n\n\ti,\n\tsvg {\n\t\tcolor: ${(props) => props.theme.colors.active};\n\t\tfont-size: 20px;\n\t\tleft: 0;\n\t\tmargin-top: 2px;\n\t\tposition: absolute;\n\t\ttop: 0;\n\t}\n\n\th5 {\n\t\tmargin: 0 0 10px;\n\t\t${fontSize({ sizeDiff: 2, sizeDesktopDiff: 2 })}\n\t}\n\n\tp {\n\t\tmargin: 0;\n\t\t${fontSize({\n\t\t\tsizeDiff: -2,\n\t\t\tsizeDesktopDiff: -2,\n\t\t\tsizeBigScreenDiff: -4,\n\t\t\timportant: true,\n\t\t})}\n\t}\n`;\n\nexport const StyledBetSlipSection = styled.div`\n\t${boxNoHeight};\n\theight: calc(100% - 30px);\n\n\t${StyledLoader} {\n\t\tbackground-color: ${(props) => props.theme.colors.background};\n\t\topacity: 0.8;\n\t\tpointer-events: auto;\n\t\tz-index: 199;\n\t}\n`;\n","import { useCallback, useEffect, useState } from 'react';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { usePrevious } from '@legacyApp/hooks/render/usePrevious';\nimport { removeArrayDuplicates } from '@legacyApp/methods/array/removeArrayDuplicates';\nimport { sportsBetSlipSetType } from '../store/sportsBetSlip/sportsBetSlip.thunk';\nimport {\n\tuseSportsBetSlipBetsList,\n\tuseSportsBetSlipType,\n} from '../store/selectors/sportsBetSlip.selectors';\nimport { BETSLIP_TYPE } from '../constants/betSlip';\nimport { BetSlipBet } from '../types/BetSlip/BetSlipBet';\nimport { BetSlipTypeType } from '../types/BetSlip/BetSlipType';\n\nconst isMultiMode = ({ list }: { list: BetSlipBet[] }) => {\n\tif (list.length > 1) {\n\t\tconst matchIdList = list.map((bet) => bet.matchId);\n\t\tconst filteredMatchIdList = removeArrayDuplicates(matchIdList);\n\t\treturn matchIdList.length === filteredMatchIdList.length;\n\t}\n\treturn false;\n};\n\nexport const useTypeTabsAutoSwitch = () => {\n\tconst dispatch = useAppDispatch();\n\n\tconst [allowAutoSwitch, setAllowAutoSwitch] = useState(true);\n\n\tconst list = useSportsBetSlipBetsList();\n\tconst type = useSportsBetSlipType();\n\n\tconst prevListLength = usePrevious(list.length);\n\n\tconst _setType = useCallback(\n\t\t(newType: BetSlipTypeType) => {\n\t\t\tif (newType === type.id) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconsole.log('useTypeTabsAutoSwitch / _setType', { newType });\n\t\t\tdispatch(sportsBetSlipSetType(newType));\n\t\t},\n\t\t[dispatch, type.id],\n\t);\n\n\tconst uiSetType = (newType: BetSlipTypeType) => {\n\t\tif (newType === type.id) {\n\t\t\treturn;\n\t\t}\n\t\tconsole.log('useTypeTabsAutoSwitch / uiSetType', { newType });\n\t\t_setType(newType);\n\t\tsetAllowAutoSwitch(false);\n\t};\n\n\tuseEffect(() => {\n\t\tconsole.log('useTypeTabsAutoSwitch / useEffect', {\n\t\t\tlistLength: list.length,\n\t\t\tprevListLength: prevListLength,\n\t\t\tallowAutoSwitch,\n\t\t});\n\t\tif (list.length === prevListLength) {\n\t\t\treturn;\n\t\t}\n\t\tif (!list.length) {\n\t\t\t_setType(BETSLIP_TYPE.SINGLE);\n\t\t\tsetAllowAutoSwitch(true);\n\t\t\treturn;\n\t\t}\n\t\tif (!allowAutoSwitch) {\n\t\t\treturn;\n\t\t}\n\t\tif (isMultiMode({ list })) {\n\t\t\t_setType(BETSLIP_TYPE.MULTI);\n\t\t} else {\n\t\t\t_setType(BETSLIP_TYPE.SINGLE);\n\t\t}\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [list.length]);\n\n\treturn {\n\t\tsetType: uiSetType,\n\t};\n};\n","import { FunctionComponent } from 'react';\nimport { Tabs } from '@legacyApp/client/components/tabs';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { BETSLIP_TYPES } from '../../constants/betSlip';\nimport { useTypeTabsAutoSwitch } from '../../hooks/useTypeTabsAutoSwitch';\nimport { useSportsBetSlipType } from '../../store/selectors/sportsBetSlip.selectors';\n\nconst BetSlipTypeTabs: FunctionComponent = () => {\n\tconst { setType } = useTypeTabsAutoSwitch();\n\n\tconst type = useSportsBetSlipType();\n\n\treturn (\n\t\t<Tabs\n\t\t\tbuttonsStyle={true}\n\t\t\tsmallText={true}\n\t\t\tnoWrap={true}\n\t\t\tlight={true}\n\t\t\tscrollHorizontal={true}\n\t\t\tfullWidth={true}\n\t\t\tlist={BETSLIP_TYPES}\n\t\t\tactive={type}\n\t\t\tcallbackOnInit={true}\n\t\t\tcallback={(tab) => setType(tab.id)}\n\t\t\tnamespace={'sports'}\n\t\t/>\n\t);\n};\n\nexport default enhanceComponent({\n\tBetSlipTypeTabs,\n});\n","import { FunctionComponent } from 'react';\nimport { faExclamationCircle } from '@fortawesome/free-solid-svg-icons';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { transSports } from '@legacyApp/client/modules/translation/translate';\nimport { Loader } from '@legacyApp/client/components/loader/loader';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport {\n\tuseSportsBetSlipBetsList,\n\tuseSportsBetSlipPlacingBet,\n} from '../../store/selectors/sportsBetSlip.selectors';\nimport BetsList from './BetsList/BetsList';\nimport BetSlipFormContainer from './BetSlipForm/BetSlipForm.container';\nimport {\n\tStyledBetSlipInfo,\n\tStyledBetSlipSection,\n} from './BetSlipSection.styled';\nimport BetSlipTypeTabs from './BetSlipTypeTabs';\n\nconst BetSlipSection: FunctionComponent = () => {\n\tconst list = useSportsBetSlipBetsList();\n\tconst loading = useSportsBetSlipPlacingBet();\n\n\tif (!list?.length) {\n\t\treturn (\n\t\t\t<StyledBetSlipInfo>\n\t\t\t\t<div>\n\t\t\t\t\t<AwesomeIcon icon={faExclamationCircle} />\n\t\t\t\t\t<h5>\n\t\t\t\t\t\t{transSports({\n\t\t\t\t\t\t\tlabel: 'No bets selected',\n\t\t\t\t\t\t\tnoTranslationCheck: true,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\t!\n\t\t\t\t\t</h5>\n\t\t\t\t\t<p>\n\t\t\t\t\t\t{transSports({\n\t\t\t\t\t\t\tlabel:\n\t\t\t\t\t\t\t\t'Please browse our sportsbook and select bets by tapping on the odds',\n\t\t\t\t\t\t\tnoTranslationCheck: true,\n\t\t\t\t\t\t})}\n\t\t\t\t\t</p>\n\t\t\t\t</div>\n\t\t\t</StyledBetSlipInfo>\n\t\t);\n\t}\n\n\treturn (\n\t\t<StyledBetSlipSection>\n\t\t\t<BetSlipTypeTabs />\n\t\t\t<BetsList />\n\t\t\t<BetSlipFormContainer />\n\t\t\t<Loader active={loading} />\n\t\t</StyledBetSlipSection>\n\t);\n};\n\nexport default enhanceComponent({\n\tBetSlipSection,\n});\n","import React, { FunctionComponent } from 'react';\nimport BetSlip from '../../BetSlipSection/BetSlipSection';\nimport { BetsHistory } from '../../BetSlipSection/BetsHistory/BetsHistory';\nimport { useSportsSideContent } from '../../../store/selectors/sportsBetSlip.selectors';\n\nconst SideContentWrapper: FunctionComponent = () => {\n\tconst contentType = useSportsSideContent();\n\tif (contentType === 'my_bets') {\n\t\treturn <BetsHistory />;\n\t}\n\tif (contentType === 'bet_slip') {\n\t\treturn <BetSlip />;\n\t}\n\treturn null;\n};\n\nexport default SideContentWrapper;\n","import React, { FC } from 'react';\nimport { ChatPrivateStreamContainer } from '../private/stream/chat.private.stream.container';\nimport { ChatStreamContainer } from '../stream/chatStreamContainer';\nimport { ChatPrivateHistoryContainer } from '../private/privateHistory/chat.privateHistory.container';\nimport { ChatFriendsContainer } from '../friends/chat.friends.container';\nimport { useChatContentType } from '../../store/selectors/useChatContentType';\nimport { useChatPrivateActive } from '../../store/selectors/useChatPrivateActive';\nimport SideContentWrapper from '../../../sports/components/SideContent/Wrapper/SideContentWrapper';\nimport {\n\tuseSportsActive,\n\tuseSportsSideContent,\n} from '../../../sports/store/selectors/sportsBetSlip.selectors';\nimport { ContentType } from '../../store/slices/contentType.slice';\n\nexport const ChatContent: FC = () => {\n\tconst contentType = useChatContentType();\n\tconst sportsContent = useSportsSideContent();\n\tconst sportsActive = useSportsActive();\n\tconst privateActive = useChatPrivateActive();\n\n\tif (sportsContent && sportsActive) {\n\t\treturn <SideContentWrapper />;\n\t}\n\tif (privateActive) {\n\t\treturn <ChatPrivateStreamContainer />;\n\t}\n\tif (contentType === ContentType.STREAM) {\n\t\treturn <ChatStreamContainer />;\n\t}\n\tif (contentType === ContentType.PRIVATE) {\n\t\treturn <ChatPrivateHistoryContainer />;\n\t}\n\tif (contentType === ContentType.FRIENDS) {\n\t\treturn <ChatFriendsContainer />;\n\t}\n\treturn null;\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { faUserFriends } from '@fortawesome/free-solid-svg-icons';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { StyledNotificationCounter } from '../../private/privateIcon/NotificationCounter.styled';\n\nclass ChatFriendsIcon extends React.PureComponent {\n\tstatic propTypes = {\n\t\trequests: PropTypes.number,\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<StyledNotificationCounter $count={this.props.requests}>\n\t\t\t\t<AwesomeIcon icon={faUserFriends} />\n\t\t\t</StyledNotificationCounter>\n\t\t);\n\t}\n}\n\nChatFriendsIcon = enhanceComponent({\n\tChatFriendsIcon,\n});\n\nexport { ChatFriendsIcon };\n","import { connect } from 'react-redux';\nimport { ChatFriendsIcon } from './chat.friends.icon';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\trequests: state.friends.requests.length,\n\t};\n};\n\nconst ChatFriendsIconContainer = connect(\n\tmapStateToProps,\n\tnull,\n)(ChatFriendsIcon);\n\nexport { ChatFriendsIconContainer };\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { faEnvelope } from '@fortawesome/free-solid-svg-icons';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { StyledNotificationCounter } from './NotificationCounter.styled';\n\nclass ChatPrivateIcon extends React.PureComponent {\n\tstatic propTypes = {\n\t\tunread: PropTypes.object,\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<StyledNotificationCounter $count={Object.keys(this.props.unread).length}>\n\t\t\t\t<AwesomeIcon icon={faEnvelope} />\n\t\t\t</StyledNotificationCounter>\n\t\t);\n\t}\n}\n\nChatPrivateIcon = enhanceComponent({\n\tChatPrivateIcon,\n});\n\nexport { ChatPrivateIcon };\n","import { connect } from 'react-redux';\nimport { ChatPrivateIcon } from './chat.private.icon';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\tunread: state.privateMessages.unread,\n\t};\n};\n\nconst ChatPrivateIconContainer = connect(\n\tmapStateToProps,\n\tnull,\n)(ChatPrivateIcon);\n\nexport { ChatPrivateIconContainer };\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {\n\tfaGlobe,\n\tfaGlobeAfrica,\n\tfaGlobeAmericas,\n\tfaGlobeAsia,\n\tfaGlobeEurope,\n} from '@fortawesome/free-solid-svg-icons';\nimport { enhanceComponent } from '../../wrappers/enhanceComponent';\nimport { AwesomeIcon } from '../../../../common/components/icons/AwesomeIcon';\n\nconst AVAILABLE_CONTINENTS = {\n\teurope: faGlobeEurope,\n\tasia: faGlobeAsia,\n\tamerica: faGlobeAmericas,\n\tafrica: faGlobeAfrica,\n};\n\nclass GlobeIcon extends React.Component {\n\tstatic propTypes = {\n\t\tcontinent: PropTypes.any,\n\t};\n\n\tgetIcon = (continent) => {\n\t\tif (!continent) {\n\t\t\treturn faGlobeAsia;\n\t\t}\n\t\tcontinent = continent.toLowerCase();\n\t\tif (continent.indexOf('america') > -1 || continent === 'antarctica') {\n\t\t\treturn faGlobeAmericas;\n\t\t}\n\t\treturn AVAILABLE_CONTINENTS[continent] || faGlobe;\n\t};\n\n\trender() {\n\t\treturn <AwesomeIcon icon={this.getIcon(this.props.continent)} />;\n\t}\n}\n\nGlobeIcon = enhanceComponent({\n\tGlobeIcon,\n});\n\nexport { GlobeIcon };\n","import { connect } from 'react-redux';\nimport { GlobeIcon } from './globeIcon';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\tcontinent: state.app.location.continent,\n\t};\n};\n\nconst GlobeIconContainer = connect(mapStateToProps, null)(GlobeIcon);\n\nexport { GlobeIconContainer };\n","import React, { FC, useCallback } from 'react';\nimport { Button } from '@ui/button';\nimport { DropdownArrow } from '@ui/dropdown/DropdownArrow';\nimport { Trans, trans } from '@legacyApp/client/modules/translation/translate';\nimport { ButtonStyleType } from '@uiTypes/ButtonStyleType';\nimport { FlagIcon } from '@common/components/icons/FlagIcon';\nimport { languageConfig } from '@server/config/language.config';\nimport { Tooltip } from '@legacyApp/client/components/tooltip';\nimport { GlobeIconContainer } from '@legacyApp/client/components/globeIcon';\nimport { useStateEffect } from '@common/hooks/useStateEffect';\nimport { useUserIsAdmin } from '@common/selectors/user.selectors';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { config } from '@legacyApp/client/config';\nimport { Dropdown } from '@legacyApp/client/components/dropdown/dropdown';\nimport { DropdownContentDataItemObject } from '@legacyApp/client/store/dropdown/dropdown.reducer';\nimport { useChatRoom } from '../../store/selectors/useChatRoom';\nimport { useChatContentType } from '../../store/selectors/useChatContentType';\nimport { useChatPrivateActive } from '../../store/selectors/useChatPrivateActive';\nimport { chatActions } from '../../store/chat.actions';\nimport { ContentType } from '../../store/slices/contentType.slice';\nimport transactionsService from '../../../transactions/transactionsService';\nimport { ChatButtonStyle } from './chat.header.style';\n\nconst AVAILABLE_ROOMS = config.chat.rooms;\n\nexport const ChatRoomSelect: FC = () => {\n\tconst activeRoom = useChatRoom();\n\tconst contentType = useChatContentType();\n\tconst privateActive = useChatPrivateActive();\n\tconst isAdmin = useUserIsAdmin();\n\tconst switchRoom = useDispatchCallback(chatActions.setRoom);\n\tconst setContentType = useDispatchCallback(chatActions.setContentType);\n\n\tconst roomsList = useStateEffect(\n\t\tuseCallback(() => {\n\t\t\treturn AVAILABLE_ROOMS.filter((el) => (el.admin ? isAdmin : true)).map(\n\t\t\t\t(el): DropdownContentDataItemObject => {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tid: el.id,\n\t\t\t\t\t\tname: el.name,\n\t\t\t\t\t\tvalue: el.symbol,\n\t\t\t\t\t};\n\t\t\t\t},\n\t\t\t);\n\t\t}, [isAdmin]),\n\t\t(a, b) => transactionsService.isListDifferent(a, b, ['id']),\n\t);\n\n\tconst activeRoom_ = useStateEffect(\n\t\tuseCallback(\n\t\t\t() => roomsList.find((el) => el.id === activeRoom),\n\t\t\t[roomsList, activeRoom],\n\t\t),\n\t\t(a, b) => transactionsService.isDataDifferent(a, b, ['id']),\n\t);\n\n\tif (!(contentType === ContentType.STREAM && !privateActive)) {\n\t\tconst activateStream = () => setContentType(ContentType.STREAM);\n\t\treturn (\n\t\t\t<Tooltip\n\t\t\t\tcontent={trans({ label: 'Public rooms' })}\n\t\t\t\tinteractive={true}\n\t\t\t\tzIndex={9999}\n\t\t\t>\n\t\t\t\t<ChatButtonStyle\n\t\t\t\t\tonClick={activateStream}\n\t\t\t\t\tname=\"open_public\"\n\t\t\t\t\tstyleType={ButtonStyleType.CLEAR}\n\t\t\t\t>\n\t\t\t\t\t<GlobeIconContainer />\n\t\t\t\t</ChatButtonStyle>\n\t\t\t</Tooltip>\n\t\t);\n\t}\n\tif (roomsList.length > 1 && activeRoom) {\n\t\tconst onClick = (el) => {\n\t\t\tsetContentType();\n\t\t\tswitchRoom({\n\t\t\t\tname: el.id,\n\t\t\t\tlastRoom: activeRoom,\n\t\t\t});\n\t\t};\n\t\treturn (\n\t\t\t<Dropdown\n\t\t\t\tid={'chatHeaderRooms'}\n\t\t\t\twidth={120}\n\t\t\t\ttitle={\n\t\t\t\t\t<span>\n\t\t\t\t\t\t<Trans label={'Public rooms'} />:\n\t\t\t\t\t</span>\n\t\t\t\t}\n\t\t\t\titems={roomsList}\n\t\t\t\titemElement={(item: DropdownContentDataItemObject) => (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<FlagIcon\n\t\t\t\t\t\t\tsymbol={\n\t\t\t\t\t\t\t\titem.value === languageConfig.default\n\t\t\t\t\t\t\t\t\t? 'gb'\n\t\t\t\t\t\t\t\t\t: String(item.value)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\twithWrapper\n\t\t\t\t\t\t/>{' '}\n\t\t\t\t\t\t<span className=\"text-capitalize\">{item.name}</span>\n\t\t\t\t\t</>\n\t\t\t\t)}\n\t\t\t\tonClick={onClick}\n\t\t\t>\n\t\t\t\t<Button\n\t\t\t\t\tname=\"chat-room\"\n\t\t\t\t\tstyleType={ButtonStyleType.CLEAR}\n\t\t\t\t\tclassName=\"text-capitalize text-white\"\n\t\t\t\t\ticonBefore={\n\t\t\t\t\t\t<FlagIcon\n\t\t\t\t\t\t\tsymbol={\n\t\t\t\t\t\t\t\tactiveRoom_?.value === languageConfig.default\n\t\t\t\t\t\t\t\t\t? 'gb'\n\t\t\t\t\t\t\t\t\t: String(activeRoom_?.value)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\twithWrapper\n\t\t\t\t\t\t/>\n\t\t\t\t\t}\n\t\t\t\t\tlabel={activeRoom_?.name}\n\t\t\t\t>\n\t\t\t\t\t<DropdownArrow />\n\t\t\t\t</Button>\n\t\t\t</Dropdown>\n\t\t);\n\t}\n\tif (activeRoom) {\n\t\treturn (\n\t\t\t<Button\n\t\t\t\tname=\"chat-room\"\n\t\t\t\tclassName=\"text-capitalize\"\n\t\t\t\ticonBefore={\n\t\t\t\t\t<FlagIcon\n\t\t\t\t\t\tsymbol={\n\t\t\t\t\t\t\tactiveRoom_?.value === languageConfig.default\n\t\t\t\t\t\t\t\t? 'gb'\n\t\t\t\t\t\t\t\t: String(activeRoom_?.value)\n\t\t\t\t\t\t}\n\t\t\t\t\t\twithWrapper\n\t\t\t\t\t/>\n\t\t\t\t}\n\t\t\t\tlabel={activeRoom_?.name}\n\t\t\t/>\n\t\t);\n\t}\n\treturn null;\n};\n","import { FC } from 'react';\nimport { faInfoCircle, faTimes } from '@fortawesome/free-solid-svg-icons';\nimport classnames from 'classnames';\nimport { MODAL_ID } from '@common/constants/modal/ids.modal.constants';\nimport { trans } from '@legacyApp/client/modules/translation/translate';\nimport { Tooltip } from '@legacyApp/client/components/tooltip';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { useAppMobile } from '@common/selectors/app.selectors';\nimport { useUserIsLogged } from '@common/selectors/user.selectors';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { ButtonStyleType } from '@uiTypes/ButtonStyleType';\nimport { useChatContentType } from '../../store/selectors/useChatContentType';\nimport { useChatPrivateActive } from '../../store/selectors/useChatPrivateActive';\nimport { ChatFriendsIconContainer } from '../friends/friendsIcon/chat.friends.icon.container';\nimport { ChatPrivateIconContainer } from '../private/privateIcon/chat.private.icon.container';\nimport { ContentType } from '../../store/slices/contentType.slice';\nimport { openModal } from '../../../modals/store/modal.actions';\nimport { chatActions } from '../../store/chat.actions';\nimport {\n\tChatButtonsStyle,\n\tChatButtonStyle,\n\tChatHeaderStyle,\n} from './chat.header.style';\nimport { ChatRoomSelect } from './chat.roomSelect';\n\nexport const ChatHeaderContainer: FC = () => {\n\tconst isLogged = useUserIsLogged();\n\tconst contentType = useChatContentType();\n\tconst privateActive = useChatPrivateActive();\n\tconst isMobile = useAppMobile();\n\tconst openModal_ = useDispatchCallback(openModal);\n\tconst setContentType = useDispatchCallback(chatActions.setContentType);\n\tconst toggleChat = useDispatchCallback(chatActions.setVisible);\n\treturn (\n\t\t<ChatHeaderStyle>\n\t\t\t<ChatRoomSelect />\n\t\t\t<ChatButtonsStyle>\n\t\t\t\t{isLogged && (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<Tooltip\n\t\t\t\t\t\t\tcontent={trans({ label: 'Private messages' })}\n\t\t\t\t\t\t\tinteractive={true}\n\t\t\t\t\t\t\tzIndex={9999}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ChatButtonStyle\n\t\t\t\t\t\t\t\tonClick={() => setContentType(ContentType.PRIVATE)}\n\t\t\t\t\t\t\t\tname=\"open_messages\"\n\t\t\t\t\t\t\t\tstyleType={ButtonStyleType.CLEAR}\n\t\t\t\t\t\t\t\tclassName={classnames({\n\t\t\t\t\t\t\t\t\tactive: contentType === ContentType.PRIVATE && !privateActive,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<ChatPrivateIconContainer />\n\t\t\t\t\t\t\t</ChatButtonStyle>\n\t\t\t\t\t\t</Tooltip>\n\t\t\t\t\t\t<Tooltip\n\t\t\t\t\t\t\tcontent={trans({ label: 'Friends' })}\n\t\t\t\t\t\t\tinteractive={true}\n\t\t\t\t\t\t\tzIndex={9999}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ChatButtonStyle\n\t\t\t\t\t\t\t\tonClick={() => setContentType(ContentType.FRIENDS)}\n\t\t\t\t\t\t\t\tname=\"open_friends\"\n\t\t\t\t\t\t\t\tstyleType={ButtonStyleType.CLEAR}\n\t\t\t\t\t\t\t\tclassName={classnames({\n\t\t\t\t\t\t\t\t\tactive: contentType === ContentType.FRIENDS && !privateActive,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<ChatFriendsIconContainer />\n\t\t\t\t\t\t\t</ChatButtonStyle>\n\t\t\t\t\t\t</Tooltip>\n\t\t\t\t\t</>\n\t\t\t\t)}\n\t\t\t\t<Tooltip\n\t\t\t\t\tcontent={trans({ label: 'Rules' })}\n\t\t\t\t\tinteractive={true}\n\t\t\t\t\tzIndex={9999}\n\t\t\t\t>\n\t\t\t\t\t<ChatButtonStyle\n\t\t\t\t\t\tonClick={() => openModal_(MODAL_ID.CHAT, 'chatHeader')}\n\t\t\t\t\t\tname=\"open_rules\"\n\t\t\t\t\t\tstyleType={ButtonStyleType.CLEAR}\n\t\t\t\t\t>\n\t\t\t\t\t\t<AwesomeIcon icon={faInfoCircle} />\n\t\t\t\t\t</ChatButtonStyle>\n\t\t\t\t</Tooltip>\n\t\t\t\t{isMobile && (\n\t\t\t\t\t<ChatButtonStyle\n\t\t\t\t\t\tonClick={() => toggleChat({ isVisible: false })}\n\t\t\t\t\t\tname=\"close_chat\"\n\t\t\t\t\t\tclassName=\"padding-left\"\n\t\t\t\t\t\tstyleType={ButtonStyleType.CLEAR}\n\t\t\t\t\t>\n\t\t\t\t\t\t<AwesomeIcon icon={faTimes} />\n\t\t\t\t\t</ChatButtonStyle>\n\t\t\t\t)}\n\t\t\t</ChatButtonsStyle>\n\t\t</ChatHeaderStyle>\n\t);\n};\n","import {\n\tfaAddressCard,\n\tfaChartLine,\n\tfaCloudRain,\n\tfaCommentDollar,\n\tfaEnvelope,\n\tfaLock,\n\tfaLockOpen,\n\tfaQuestion,\n\tfaReceipt,\n} from '@fortawesome/free-solid-svg-icons';\n\nexport interface ChatFeature {\n\tid: string;\n\ticon: any;\n\tcode: string;\n\tmock: string;\n\tname: string;\n\tonClick: () => string;\n\tisModerator?: boolean;\n\tisAdmin?: boolean;\n\tdisabled?: boolean;\n}\n\nexport const CHAT_FEATURES: Array<ChatFeature> = [\n\t{\n\t\tid: 'rain',\n\t\ticon: faCloudRain,\n\t\tcode: '/rain',\n\t\tmock: '/rain',\n\t\tname: 'Make rain',\n\t\tonClick: () => 'rain',\n\t},\n\t{\n\t\tid: 'tip',\n\t\ticon: faCommentDollar,\n\t\tcode: '/tip @user',\n\t\tmock: '/tip',\n\t\tname: 'Tip user',\n\t\tonClick: () => 'tip',\n\t},\n\t{\n\t\tid: 'user',\n\t\ticon: faAddressCard,\n\t\tcode: '/user @user',\n\t\tmock: '/user',\n\t\tname: 'User details',\n\t\tonClick: () => 'user',\n\t},\n\t{\n\t\tid: 'pm',\n\t\ticon: faEnvelope,\n\t\tcode: '/pm @user [message]',\n\t\tmock: '/pm',\n\t\tname: 'Send private message',\n\t\tonClick: () => 'pm',\n\t},\n\t{\n\t\tid: 'bet',\n\t\ticon: faReceipt,\n\t\tcode: '/bet [bet id]',\n\t\tmock: '/bet',\n\t\tname: 'Bet details',\n\t\tonClick: () => 'bet',\n\t},\n\t{\n\t\tid: 'sports',\n\t\ticon: faReceipt,\n\t\tcode: '/sports [betslip id]',\n\t\tmock: '/sports',\n\t\tname: 'Bet Slip details',\n\t\tonClick: () => 'sports',\n\t},\n\t{\n\t\tid: 'session',\n\t\ticon: faChartLine,\n\t\tcode: '/session [session id]',\n\t\tmock: '/session',\n\t\tname: 'Session details',\n\t\tonClick: () => 'session',\n\t},\n\t{\n\t\tid: 'ignore',\n\t\ticon: faLock,\n\t\tcode: '/ignore @user',\n\t\tmock: '/ignore',\n\t\tname: 'Ignore user',\n\t\tonClick: () => 'ignore',\n\t},\n\t{\n\t\tid: 'unignore',\n\t\ticon: faLockOpen,\n\t\tcode: '/unignore @user',\n\t\tmock: '/unignore',\n\t\tname: 'Unignore user',\n\t\tonClick: () => 'unignore',\n\t},\n\t{\n\t\tid: 'trivia',\n\t\ticon: faQuestion,\n\t\tcode: '/trivia',\n\t\tmock: '/trivia',\n\t\tname: 'Trivia',\n\t\tonClick: () => 'trivia',\n\t\tisModerator: true,\n\t},\n];\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { getChatFeatures } from '../../methods/getChatFeatures';\nimport { ChatFeature } from '../../constants/CHAT_FEATURES';\n\nexport const getChatFeaturesThunk = (): AppThunk<Array<ChatFeature>> => {\n\treturn (dispatch, getState) => {\n\t\tconst { user, options } = getState();\n\t\treturn getChatFeatures(!options.tip, user);\n\t};\n};\n","import { RootState } from '@legacyApp/client/store/configure.store';\nimport { CHAT_FEATURES, ChatFeature } from '../constants/CHAT_FEATURES';\n\nexport const getChatFeatures = (\n\tdisableTip: boolean,\n\tuser?: RootState['user'],\n): Array<ChatFeature> => {\n\treturn CHAT_FEATURES.filter((el) => {\n\t\tif (el.id === 'tip' && disableTip) {\n\t\t\treturn false;\n\t\t}\n\t\tif (el.isModerator && !user?.isModerator && !user?.isAdmin) {\n\t\t\treturn false;\n\t\t}\n\t\tif (el.isAdmin && !user?.isAdmin) {\n\t\t\treturn false;\n\t\t}\n\t\treturn !el.disabled;\n\t});\n};\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { getChatFeaturesThunk } from './getChatFeatures.thunk';\n\nexport const checkChatFeatureListActiveThunk = (\n\tmessage: string,\n): AppThunk<boolean> => {\n\treturn (dispatch) => {\n\t\tconst list = dispatch(getChatFeaturesThunk());\n\t\tif (!list.length) {\n\t\t\treturn false;\n\t\t}\n\t\tconst index = list.findIndex((el) => {\n\t\t\treturn message.indexOf(el.mock) > -1;\n\t\t});\n\n\t\treturn message[0] === '/' && index === -1;\n\t};\n};\n","export const getDataQuery = (message: string, prefix: string) => {\n\tconst split = message.split(prefix);\n\tif (split.length <= 1) {\n\t\treturn '';\n\t}\n\treturn split[split.length - 1];\n};\n","import { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\n\nexport const useChatMessage = () =>\n\tuseAppSelector((state) => state.chat?.message, shallowEqual);\n","import styled, { css } from 'styled-components';\nimport { rgba } from 'polished';\nimport { borderRadius } from '@legacyApp/client/modules/style/defaults';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\n\nexport const ChatListStyle = styled.ul`\n\tbackground-color: ${(props) => props.theme.colors.inputBackgroundSolid};\n\tleft: 50%;\n\tmax-height: 300px;\n\toverflow-y: auto;\n\tposition: absolute;\n\ttop: -5px;\n\ttransform: translate(-50%, -100%);\n\twidth: calc(100% - 20px);\n\tz-index: 1;\n\t${borderRadius}\n`;\n\nexport interface ChatListElementStyleProps {\n\thighlight?: boolean;\n}\n\nexport const ChatListElementStyle = styled.li<ChatListElementStyleProps>`\n\tcursor: pointer;\n\t${(props) =>\n\t\tprops.highlight\n\t\t\t? css`\n\t\t\t\t\tbackground-color: ${rgba(\n\t\t\t\t\t\tprops.theme.colors.inputButton,\n\t\t\t\t\t\t0.8,\n\t\t\t\t\t)}!important;\n\t\t\t  `\n\t\t\t: css`\n\t\t\t\t\tbackground-color: ${rgba(props.theme.colors.inputButton, 0.5)};\n\t\t\t\t\t&:nth-of-type(even) {\n\t\t\t\t\t\tbackground-color: ${props.theme.colors.inputBackgroundSolid};\n\t\t\t\t\t}\n\t\t\t  `};\n\n\tpadding: 10px 15px;\n\t${(props) =>\n\t\tfontSize({\n\t\t\tsizeDiff: -2,\n\t\t\tsizeDesktop: props.theme.text.size.default,\n\t\t\tsizeBigScreenDiff: -2,\n\t\t\timportant: true,\n\t\t})}\n\n\t&:hover {\n\t\topacity: 0.7;\n\t\ttransition: opacity ${(props) => props.theme.layout.transition};\n\t}\n\n\ti,\n\tsvg {\n\t\tcolor: ${(props) => props.theme.colors.text};\n\t\tmargin-right: 5px;\n\t\tposition: static;\n\t\tright: unset;\n\t\ttop: unset;\n\t\ttransform: unset;\n\t}\n`;\n","import React, { FC, useCallback, useEffect, useState } from 'react';\nimport useOnclickOutside from 'react-cool-onclickoutside';\nimport { usePrevious } from '@legacyApp/hooks/render/usePrevious';\nimport { useStateEffect } from '@common/hooks/useStateEffect';\nimport { getDataQuery } from '../../methods/getDataQuery';\nimport { useChatMessage } from '../../store/selectors/useChatMessage';\nimport transactionService from '../../../transactions/transactionsService';\nimport { ChatListElementStyle, ChatListStyle } from './chatListStyle';\n\nexport interface ListElement {\n\tname: string;\n\thighlight?: boolean;\n}\n\nexport const ChatList: FC<{\n\tonClick: (el: ListElement) => void;\n\tlist: ListElement[];\n\tcheckActive: (message: string, name?: string) => boolean;\n\tparseEl: (el: ListElement) => JSX.Element;\n\tprefix: string;\n}> = ({ onClick, list, checkActive, parseEl, prefix }) => {\n\tconst message = useChatMessage();\n\tconst prevMessage = usePrevious(message);\n\n\tconst [name, setName] = useState<string>(getDataQuery(message, prefix));\n\tconst [show, setShow] = useState<boolean>(checkActive(message));\n\tconst [selectedElement, setSelectedElement] = useState<number>(null);\n\n\tconst filterElement = useCallback(\n\t\t(el: ListElement) => {\n\t\t\tif (!name) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\treturn el.name.toLowerCase().indexOf(name.toLowerCase()) > -1;\n\t\t},\n\t\t[name],\n\t);\n\n\tconst list_ = useStateEffect(\n\t\tuseCallback(() => {\n\t\t\treturn list.filter(filterElement).map((el, index) => {\n\t\t\t\treturn {\n\t\t\t\t\t...el,\n\t\t\t\t\thighlight: selectedElement === index + 1,\n\t\t\t\t};\n\t\t\t});\n\t\t}, [filterElement, list, selectedElement]),\n\t\ttransactionService.isListDifferent,\n\t);\n\n\tconst handleArrows = useCallback(\n\t\t(isUp: boolean) => {\n\t\t\tif (list_.length <= 1) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (!selectedElement && selectedElement !== 0) {\n\t\t\t\tif (!isUp) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\treturn setSelectedElement(list_.length);\n\t\t\t}\n\n\t\t\tif (!isUp) {\n\t\t\t\tif (selectedElement >= list_.length) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\treturn setSelectedElement(selectedElement + 1);\n\t\t\t}\n\n\t\t\tif (selectedElement <= 1) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\treturn setSelectedElement(selectedElement - 1);\n\t\t},\n\t\t[list_, selectedElement],\n\t);\n\n\tconst onOptionClick = useCallback(\n\t\t(el) => {\n\t\t\t// console.log(el, el.replace(name, ''));\n\t\t\tif (onClick) {\n\t\t\t\tonClick(el);\n\t\t\t}\n\t\t\tsetShow(false);\n\t\t},\n\t\t[onClick],\n\t);\n\n\tconst onEnter = useCallback(() => {\n\t\tif (list_.length > 1 && selectedElement === null) {\n\t\t\treturn;\n\t\t}\n\t\tconst el =\n\t\t\tselectedElement && list_[selectedElement - 1]\n\t\t\t\t? list_[selectedElement - 1]\n\t\t\t\t: list_[0]\n\t\t\t\t? list_[0]\n\t\t\t\t: null;\n\t\tif (el) {\n\t\t\tonOptionClick(el);\n\t\t}\n\t}, [list_, onOptionClick, selectedElement]);\n\n\tconst handleKeyboard = useCallback(\n\t\t(obj: KeyboardEvent) => {\n\t\t\tif (!show) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tobj.stopPropagation();\n\n\t\t\t// handle Enter and TAB click\n\t\t\tif (obj.keyCode === 13 || obj.keyCode === 9) {\n\t\t\t\tobj.preventDefault();\n\t\t\t\tonEnter();\n\t\t\t}\n\n\t\t\t// handle Arrow up and down\n\t\t\tif (obj.keyCode === 38 || obj.keyCode === 40) {\n\t\t\t\tobj.preventDefault();\n\t\t\t\thandleArrows(obj.keyCode === 38);\n\t\t\t}\n\t\t},\n\t\t[handleArrows, onEnter, show],\n\t);\n\n\tconst handleClickOutside = useCallback(() => setShow(false), []);\n\n\tconst outsideClickRef = useOnclickOutside(handleClickOutside);\n\n\tuseEffect(() => {\n\t\tdocument.addEventListener('keyup', handleKeyboard);\n\t\treturn () => document.removeEventListener('keyup', handleKeyboard);\n\t}, [handleKeyboard]);\n\n\tuseEffect(() => {\n\t\tconst isMessageChanged = message !== prevMessage;\n\t\tif (isMessageChanged) {\n\t\t\tconst currUserName = getDataQuery(message, prefix);\n\t\t\tsetShow(checkActive(message, currUserName));\n\t\t\tif (currUserName !== name) {\n\t\t\t\tsetSelectedElement(null);\n\t\t\t\tsetName(currUserName);\n\t\t\t}\n\t\t}\n\t}, [checkActive, message, name, prefix, prevMessage]);\n\n\tuseEffect(() => {\n\t\tif (!selectedElement && list_?.length) {\n\t\t\tsetSelectedElement(list_.length);\n\t\t}\n\t}, [selectedElement, list_]);\n\n\treturn (\n\t\t<ChatListStyle ref={outsideClickRef} className=\"list--no-style\">\n\t\t\t{show &&\n\t\t\t\tlist_.map((el) => {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<ChatListElementStyle\n\t\t\t\t\t\t\tkey={el.name}\n\t\t\t\t\t\t\thighlight={el.highlight}\n\t\t\t\t\t\t\tonClick={() => onOptionClick(el)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{parseEl(el)}\n\t\t\t\t\t\t</ChatListElementStyle>\n\t\t\t\t\t);\n\t\t\t\t})}\n\t\t</ChatListStyle>\n\t);\n};\n","import React, { FC, useCallback } from 'react';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { useStateEffect } from '@common/hooks/useStateEffect';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { trans } from '@legacyApp/client/modules/translation/translate';\nimport transactionService from '../../../transactions/transactionsService';\nimport { getChatFeaturesThunk } from '../../store/thunks/getChatFeatures.thunk';\nimport { ChatFeature } from '../../constants/CHAT_FEATURES';\nimport { checkChatFeatureListActiveThunk } from '../../store/thunks/checkChatFeatureListActiveThunk';\nimport { ChatList } from './chat.list';\n\nexport const ChatFeaturesList: FC<{\n\tonClick: (el: ChatFeature) => void;\n}> = ({ onClick }) => {\n\tconst checkActive = useDispatchCallback(checkChatFeatureListActiveThunk);\n\tconst getFeaturesList = useDispatchCallback(getChatFeaturesThunk);\n\n\tconst list: Array<ChatFeature> = useStateEffect(\n\t\tuseCallback(getFeaturesList, [getFeaturesList]),\n\t\ttransactionService.isListDifferent,\n\t);\n\n\treturn (\n\t\t<ChatList\n\t\t\tonClick={onClick}\n\t\t\tlist={list}\n\t\t\tcheckActive={checkActive}\n\t\t\tprefix={'/'}\n\t\t\tparseEl={(el: ChatFeature) => (\n\t\t\t\t<>\n\t\t\t\t\t<AwesomeIcon icon={el.icon} /> {el.code}: {trans({ label: el.name })}\n\t\t\t\t</>\n\t\t\t)}\n\t\t/>\n\t);\n};\n","import dynamic from 'next/dynamic';\nimport React, { FC } from 'react';\n// eslint-disable-next-line import/named\nimport useOnclickOutside, { Callback } from 'react-cool-onclickoutside';\n// eslint-disable-next-line import/named\nimport { PickerProps, Theme } from 'emoji-picker-react';\nimport styled from 'styled-components';\nimport { calcStyle } from '@legacyApp/client/modules/style/methods/calcStyle';\n\nconst EmojiPicker = dynamic(() => import('emoji-picker-react'), { ssr: false });\n\nexport interface EmojiPickerWrapperProps extends PickerProps {\n\tclickOutside: Callback<Event>;\n}\n\nexport const EmojiPickerWrapper: FC<EmojiPickerWrapperProps> = ({\n\tclickOutside,\n\t...props\n}) => {\n\tconst outSideRef = useOnclickOutside(clickOutside);\n\treturn (\n\t\t<EmojiPickerWrapperStyled ref={outSideRef}>\n\t\t\t<EmojiPicker {...props} theme={Theme.DARK} />\n\t\t</EmojiPickerWrapperStyled>\n\t);\n};\n\nexport const EmojiPickerWrapperStyled = styled.div`\n\tbottom: ${(props) =>\n\t\tcalcStyle({ a: props.theme.layout.chat.inputHeight, b: '15px' })};\n\tposition: absolute;\n\tright: 10px;\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n\t\tright: 15px;\n\t\tbottom: ${(props) =>\n\t\t\tcalcStyle({ a: props.theme.layout.chat.inputHeightDesktop, b: '15' })};\n\t}\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthBigDesktop}) {\n\t\tbottom: ${(props) =>\n\t\t\tcalcStyle({\n\t\t\t\ta: props.theme.layout.chat.inputHeightBigDesktop,\n\t\t\t\tb: '15',\n\t\t\t})};\n\t}\n\n\t.epr-main {\n\t\tul,\n\t\tol {\n\t\t\tfloat: unset !important;\n\t\t\tfont-size: unset !important;\n\t\t}\n\n\t\th1,\n\t\th2 {\n\t\t\tborder-bottom: unset !important;\n\t\t\tfloat: unset !important;\n\t\t\tfont-size: unset !important;\n\t\t\theight: unset !important;\n\t\t\twidth: unset !important;\n\t\t}\n\t}\n`;\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { getDataQuery } from '../../methods/getDataQuery';\n\nexport const checkUsersListActiveThunk = (\n\tmessage: string,\n\tuserName?: string,\n): AppThunk<boolean> => {\n\treturn (dispatch, getState) => {\n\t\tif (userName === undefined) {\n\t\t\tuserName = getDataQuery(message, '@');\n\t\t}\n\n\t\tconst state = getState();\n\n\t\tif (\n\t\t\tuserName &&\n\t\t\t!state.chat.users.filter(String).find((name: string) => {\n\t\t\t\treturn name.indexOf(userName) === 0;\n\t\t\t})\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn (\n\t\t\t(!!message.length && message[message.length - 1] === '@') ||\n\t\t\t(userName && userName.indexOf(' ') === -1)\n\t\t);\n\t};\n};\n","import { FC, useCallback } from 'react';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { useStateEffect } from '@common/hooks/useStateEffect';\nimport { checkUsersListActiveThunk } from '../../store/thunks/checkUsersListActiveThunk';\nimport { useChatUsers } from '../../store/selectors/useChatUsers';\nimport transactionService from '../../../transactions/transactionsService';\nimport { ChatList, ListElement } from './chat.list';\n\nexport const ChatUsersList: FC<{\n\tonClick: (el: ListElement) => void;\n}> = ({ onClick }) => {\n\tconst list = useChatUsers();\n\tconst checkActive = useDispatchCallback(checkUsersListActiveThunk);\n\n\tconst list_ = useStateEffect(\n\t\tuseCallback(() => {\n\t\t\treturn list.map((el) => {\n\t\t\t\treturn {\n\t\t\t\t\tname: el,\n\t\t\t\t};\n\t\t\t});\n\t\t}, [list]),\n\t\ttransactionService.isListDifferent,\n\t);\n\n\treturn (\n\t\t<ChatList\n\t\t\tonClick={onClick}\n\t\t\tlist={list_}\n\t\t\tcheckActive={checkActive}\n\t\t\tprefix={'@'}\n\t\t\tparseEl={(el) => <>{el.name}</>}\n\t\t/>\n\t);\n};\n","import { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport transactionService from '../../../transactions/transactionsService';\n\nexport const useChatUsers = () => {\n\treturn useAppSelector(\n\t\t(state) => state.chat?.users,\n\t\t(a, b) => !transactionService.isListDifferent(a, b),\n\t);\n};\n","import { regexString } from '@legacyApp/client/modules/app/regexString';\n\nexport const regexFeatureWithoutParameter = (string: string) =>\n\tregexString(/\\/[A-Za-z0-9\\-._]*/, string);\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { regexFeatureWithoutParameter } from '../../methods/regexFeatureWithoutParameter';\nimport { getChatFeaturesThunk } from './getChatFeatures.thunk';\n\nexport interface GetChatFeatureThunkReturn {\n\tname?: string;\n\tparameter?: string;\n\trest?: string;\n}\n\nexport const getChatFeatureThunk = (\n\tstring: string,\n\twithParameter: boolean,\n\tmessage: string,\n): AppThunk<GetChatFeatureThunkReturn> => {\n\treturn (dispatch) => {\n\t\tconst restMessage = message.replace(string, '').replace(' ', '');\n\t\tconst name = regexFeatureWithoutParameter(string)[0].replace('/', '');\n\t\tconst chatFeatures = dispatch(getChatFeaturesThunk());\n\t\tconst potentialFeature = chatFeatures.find(\n\t\t\t(feature) => name.indexOf(feature.id) === 0,\n\t\t);\n\t\t// console.log('getChatFeature', { string, withParameter, restMessage, name, potentialFeature });\n\t\tif (!chatFeatures.some((feature) => feature.id === name)) {\n\t\t\tif (potentialFeature) {\n\t\t\t\treturn {};\n\t\t\t}\n\t\t\treturn null;\n\t\t}\n\t\tconst parameter = withParameter\n\t\t\t? string.replace(`/${name} @`, '')\n\t\t\t: undefined;\n\t\t// console.log('getFeature', {string, withParameter, name, parameter});\n\t\treturn {\n\t\t\tname,\n\t\t\tparameter,\n\t\t\trest: restMessage,\n\t\t};\n\t};\n};\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { regexFeatureWithParameter } from '../../methods/regexFeatureWithParameter';\nimport { regexFeatureWithoutParameter } from '../../methods/regexFeatureWithoutParameter';\nimport {\n\tgetChatFeatureThunk,\n\tGetChatFeatureThunkReturn,\n} from './getChatFeature.thunk';\n\nexport const matchFeatureThunk = (\n\tmessage: string,\n): AppThunk<GetChatFeatureThunkReturn> => {\n\treturn (dispatch) => {\n\t\tlet message_ = message;\n\t\tif (message[message.length - 1] === ' ') {\n\t\t\tconst messageArray = message.split('');\n\t\t\tmessageArray.pop();\n\t\t\tmessage_ = messageArray.join('');\n\t\t}\n\t\t// console.log('message');\n\t\tconst matchesWithParameter = regexFeatureWithParameter(message_);\n\t\tconsole.log('matchFeature', { matchesWithParameter, message_, message });\n\t\tif (matchesWithParameter && matchesWithParameter.length) {\n\t\t\treturn dispatch(\n\t\t\t\tgetChatFeatureThunk(matchesWithParameter[0], true, message_),\n\t\t\t);\n\t\t}\n\t\tconst matchesWithoutParameter = regexFeatureWithoutParameter(message_);\n\t\tconsole.log('matchFeature', { matchesWithoutParameter, message, message_ });\n\t\tif (matchesWithoutParameter && matchesWithoutParameter.length) {\n\t\t\treturn dispatch(\n\t\t\t\tgetChatFeatureThunk(matchesWithoutParameter[0], false, message_),\n\t\t\t);\n\t\t}\n\t\t// console.log('matchFeature', {matchesWithParameter, matchesWithoutParameter});\n\t\treturn null;\n\t};\n};\n","import { regexString } from '@legacyApp/client/modules/app/regexString';\n\nexport const regexFeatureWithParameter = (string: string) =>\n\tregexString(/\\/[A-Za-z0-9\\-._]* @[A-Za-z0-9\\-._]*/, string);\n","/** Base pattern for UUIDv4 generation */\r\nconst uuidPattern = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx';\r\nconst validationRegex = /^[A-Za-z0-9]{8}-[A-Za-z0-9]{4}-4[A-Za-z0-9]{3}-[A-Za-z0-9]{4}-[A-Za-z0-9]{12}$/;\r\n/**\r\n * UUIDv4 custom type guard\r\n * @param arg UUIDv4-like object to check\r\n * @return UUIDv4-like object validity\r\n */\r\nconst isUUIDv4Like = (arg) => {\r\n    return arg && arg._id && typeof arg._id == 'string';\r\n};\r\n/**\r\n * Generate, manage and validate Universally Unique Identifiers v4.\r\n * For usage and details, see the [docs](https://github.com/jonamat/uuid-v4-validator)\r\n */\r\nexport class UUIDv4 {\r\n    /**\r\n     * Create a new UUIDv4 instance.\r\n     * @param id Initialize with custom UUID. It will be validated at runtime and it could generate an error.\r\n     * If not specified, a valid random one will be generated.\r\n     */\r\n    constructor(id) {\r\n        this._validationRegex = validationRegex;\r\n        this._uuidPattern = uuidPattern;\r\n        /**\r\n         * Generate a new Error or warn message\r\n         * @param id Invalid UUID\r\n         * @private\r\n         */\r\n        this._throwInvalidIdError = (id) => {\r\n            if (UUIDv4.blockingError)\r\n                throw new Error(`The provided UUIDv4 \"${id}\" string doesn't pass the validation. Use a valid UUIDv4 string or generate a new one`);\r\n            else\r\n                console.warn(`The provided UUIDv4 \"${id}\" string doesn't pass the validation. Use a valid UUIDv4 string or generate a new one`);\r\n        };\r\n        /**\r\n         * Generate a new UUID that will override the old one\r\n         */\r\n        this.refreshId = () => {\r\n            this._id = UUIDv4.generate();\r\n        };\r\n        if (id) {\r\n            if (!UUIDv4.validate(id)) {\r\n                this._throwInvalidIdError(id);\r\n                this._id = UUIDv4.generate();\r\n            }\r\n            else\r\n                this._id = id;\r\n        }\r\n        else\r\n            this._id = UUIDv4.generate();\r\n    }\r\n    /**\r\n     * Validate an UUID v4 string, instance or UUIDv4-like object\r\n     * ```\r\n     * // UUIDv4-like object:\r\n     * const toValidate = {\r\n     *   _id: \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\"\r\n     * }\r\n     * ```\r\n     * @param arg An UUIDv4 instance, a string or an UUIDv4-like object\r\n     * @returns Validity of the provided param\r\n     */\r\n    static validate(arg) {\r\n        if (arg instanceof UUIDv4)\r\n            return validationRegex.test(arg.id);\r\n        else if (typeof arg == 'string')\r\n            return validationRegex.test(arg);\r\n        else\r\n            return isUUIDv4Like(arg) && validationRegex.test(arg._id);\r\n    }\r\n    /**\r\n     * The current assigned UUID\r\n     * @param id A valid UUID v4 string. It will be validated at runtime and it could generate an error.\r\n     * @returns The current assigned UUID\r\n     */\r\n    get id() {\r\n        return this._id;\r\n    }\r\n    set id(id) {\r\n        if (!UUIDv4.validate(id))\r\n            this._throwInvalidIdError(id);\r\n        else\r\n            this._id = id;\r\n    }\r\n}\r\nUUIDv4.blockingError = true;\r\n/**\r\n * Generate a new valid UUID v4 string\r\n * @returns A random generated UUID v4 string\r\n */\r\nUUIDv4.generate = () => uuidPattern.replace(/[xy]/g, (char) => {\r\n    const rand = (Math.random() * 16) | 0;\r\n    return (char === 'x' ? rand : (rand & 0x3) | 0x8).toString(16);\r\n});\r\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport {\n\tMODAL_ID,\n\tModalIdType,\n} from '@common/constants/modal/ids.modal.constants';\nimport { openModal } from '../../../modals/store/modal.actions';\nimport { GameType } from '../../../games/Game/constants/availableGames';\nimport { ChatFeatureHandleThunkProps } from './chatFeatureHandle.thunk';\n\nexport const chatBetHandleThunk = (\n\tprops: ChatFeatureHandleThunkProps,\n): AppThunk => {\n\treturn (dispatch) => {\n\t\tif (!props) {\n\t\t\treturn;\n\t\t}\n\t\tdispatch(\n\t\t\topenModal(\n\t\t\t\tprops.name === GameType.SPORTS\n\t\t\t\t\t? MODAL_ID.BET\n\t\t\t\t\t: (props.name as ModalIdType),\n\t\t\t\t'chatHandleBetThunk',\n\t\t\t\t{\n\t\t\t\t\tid: props.rest,\n\t\t\t\t\ttype: props.name === GameType.SPORTS ? GameType.SPORTS : undefined,\n\t\t\t\t},\n\t\t\t),\n\t\t);\n\t};\n};\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { ModalIdType } from '@common/constants/modal/ids.modal.constants';\nimport { openModal } from '../../../modals/store/modal.actions';\nimport { ChatFeatureHandleThunkProps } from './chatFeatureHandle.thunk';\n\nexport const chatSessionHandleThunk = (\n\tprops: ChatFeatureHandleThunkProps,\n): AppThunk => {\n\treturn (dispatch) => {\n\t\tif (!props) {\n\t\t\treturn;\n\t\t}\n\t\tdispatch(\n\t\t\topenModal(props.name as ModalIdType, 'chatSessionHandleThunk', {\n\t\t\t\tid: props.rest,\n\t\t\t}),\n\t\t);\n\t};\n};\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { MODAL_ID } from '@common/constants/modal/ids.modal.constants';\nimport { getUserDetailsByLogin } from '@legacyApp/client/store/user/user.actions';\nimport { openModal } from '../../../modals/store/modal.actions';\nimport { ChatFeatureHandleThunkProps } from './chatFeatureHandle.thunk';\n\nexport const chatUserHandleThunk = (\n\tprops: ChatFeatureHandleThunkProps,\n): AppThunk => {\n\treturn (dispatch) => {\n\t\tdispatch(\n\t\t\tgetUserDetailsByLogin(props.parameter, (data) => {\n\t\t\t\t// console.log(data);\n\t\t\t\tif (!data) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\treturn dispatch(\n\t\t\t\t\topenModal(MODAL_ID.USER_DETAILS, 'userEpic', {\n\t\t\t\t\t\tname: props.parameter,\n\t\t\t\t\t\tuuid: data.uuid,\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t}),\n\t\t);\n\t};\n};\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { getUserDetailsByLogin } from '@legacyApp/client/store/user/user.actions';\nimport { privateMessagesOpenActive } from '@legacyApp/client/store/privateMessages/privateMessages.actions';\nimport { chatActions } from '../chat.actions';\nimport { ChatFeatureHandleThunkProps } from './chatFeatureHandle.thunk';\n\nexport const chatPrivateMessageHandleThunk = (\n\tprops: ChatFeatureHandleThunkProps,\n): AppThunk => {\n\treturn (dispatch) => {\n\t\tif (!props) {\n\t\t\treturn;\n\t\t}\n\t\tdispatch(\n\t\t\tgetUserDetailsByLogin(props.parameter, (data) => {\n\t\t\t\t// console.log(data);\n\n\t\t\t\tif (!data) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tdispatch(chatActions.setMessage(props.rest));\n\t\t\t\treturn dispatch(\n\t\t\t\t\tprivateMessagesOpenActive({\n\t\t\t\t\t\tuser: data,\n\t\t\t\t\t\tchannelId: data.uuid,\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t}),\n\t\t);\n\t};\n};\n","import { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { getUserDetailsByLogin } from '@legacyApp/client/store/user/user.actions';\nimport {\n\tfriendsIgnore,\n\tfriendsUnignore,\n} from '@legacyApp/client/store/friends/friends.actions';\nimport { ChatFeatureHandleThunkProps } from './chatFeatureHandle.thunk';\n\nexport const chatIgnoreHandleThunk = (\n\tprops: ChatFeatureHandleThunkProps,\n): AppThunk => {\n\treturn (dispatch) => {\n\t\tif (!props) {\n\t\t\treturn;\n\t\t}\n\t\tdispatch(\n\t\t\tgetUserDetailsByLogin(props.parameter, (data) => {\n\t\t\t\t// console.log(data);\n\t\t\t\tif (!data) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\treturn dispatch(\n\t\t\t\t\tprops.name === 'unignore'\n\t\t\t\t\t\t? friendsUnignore(data.uuid)\n\t\t\t\t\t\t: friendsIgnore(data.uuid),\n\t\t\t\t);\n\t\t\t}),\n\t\t);\n\t};\n};\n","import { UUIDv4 } from 'uuid-v4-validator';\nimport { showAlert } from '@legacyApp/client/store/alerts/alerts.actions';\nimport { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { ModalIdType } from '@common/constants/modal/ids.modal.constants';\nimport { chatActions } from '../chat.actions';\nimport { openModal } from '../../../modals/store/modal.actions';\nimport { chatBetHandleThunk } from './chatBetHandle.thunk';\nimport { chatSessionHandleThunk } from './chatSessionHandle.thunk';\nimport { chatUserHandleThunk } from './chatUserHandle.thunk';\nimport { chatPrivateMessageHandleThunk } from './chatPrivateMessageHandle.thunk';\nimport { chatIgnoreHandleThunk } from './chatIgnoreHandle.thunk';\n\nexport interface ChatFeatureHandleThunkProps {\n\tname: string;\n\trest: string;\n\tparameter: string;\n}\n\nexport const chatFeatureHandleThunk = (\n\tprops: ChatFeatureHandleThunkProps,\n): AppThunk => {\n\treturn async (dispatch, getState) => {\n\t\tif (!props) {\n\t\t\treturn;\n\t\t}\n\t\tconst { name, parameter } = props;\n\t\tlet { rest } = props;\n\t\tif (!name) {\n\t\t\treturn dispatch(showAlert('error', 'Please type correct command'));\n\t\t}\n\t\tconst data = { parameter };\n\t\tif (rest?.trim) {\n\t\t\trest = rest.trim();\n\t\t}\n\t\tif (name === 'bet' || name === 'sports') {\n\t\t\tif (!rest || !UUIDv4.validate(rest)) {\n\t\t\t\treturn dispatch(showAlert('error', 'Please type bet id'));\n\t\t\t}\n\t\t\tdispatch(chatBetHandleThunk(props));\n\t\t\tdispatch(chatActions.setMessage(''));\n\t\t\treturn;\n\t\t}\n\t\tif (name === 'session') {\n\t\t\tif (!rest || !UUIDv4.validate(rest)) {\n\t\t\t\treturn dispatch(showAlert('error', 'Please type session id'));\n\t\t\t}\n\t\t\tdispatch(chatSessionHandleThunk(props));\n\t\t\treturn dispatch(chatActions.setMessage(''));\n\t\t}\n\t\tif (!getState().user.isLogged) {\n\t\t\treturn dispatch(showAlert('info', 'Please, login first'));\n\t\t}\n\t\tif (name === 'user') {\n\t\t\tif (!parameter) {\n\t\t\t\treturn dispatch(showAlert('error', 'Please type user login'));\n\t\t\t}\n\t\t\tdispatch(chatUserHandleThunk(props));\n\t\t\treturn dispatch(chatActions.setMessage(''));\n\t\t}\n\t\tif (name === 'pm') {\n\t\t\tif (!parameter) {\n\t\t\t\treturn dispatch(showAlert('error', 'Please type user login'));\n\t\t\t}\n\t\t\tif (!rest) {\n\t\t\t\treturn dispatch(showAlert('error', 'Please type your message'));\n\t\t\t}\n\t\t\tdispatch(chatPrivateMessageHandleThunk(props));\n\t\t\treturn dispatch(chatActions.setMessage(''));\n\t\t}\n\t\tif (name.indexOf('ignore') > -1) {\n\t\t\tif (!parameter) {\n\t\t\t\treturn dispatch(showAlert('error', 'Please type user login'));\n\t\t\t}\n\t\t\tdispatch(chatIgnoreHandleThunk(props));\n\t\t\treturn dispatch(chatActions.setMessage(''));\n\t\t}\n\t\tdispatch(openModal(name as ModalIdType, 'chatFeatureHandleThunk', data));\n\t\tdispatch(chatActions.setMessage(''));\n\t};\n};\n","import styles, { css } from 'styled-components';\nimport classnames from 'classnames';\nimport { boxNoHeight } from '@legacyApp/client/modules/style/defaults';\nimport { calcStyle } from '@legacyApp/client/modules/style/methods/calcStyle';\n\nexport interface ChatStyledProps {\n\thiddenStyle?: boolean;\n\t$initialized?: boolean;\n}\n\nexport const ChatStyled = styles.div.attrs<ChatStyledProps>((props) => ({\n\tclassName: classnames('chat-wrapper', props.className),\n}))<ChatStyledProps>`\n\t${boxNoHeight};\n\tposition: fixed;\n\theight: calc(100% - ${(props) => props.theme.layout.bottomMenuHeight} + 5px);\n\twidth: 100vw;\n\ttop: 0;\n\tright: 0;\n\tbackground: ${(props) => props.theme.colors.background};\n\tz-index: 9999; // 4\n\ttransition: transform 100ms;\n\ttransform: translateX(${(props) => (props.hiddenStyle ? '100vw' : '0')});\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n    max-width: ${(props) => props.theme.layout.chat.width};\n    height: 100vh;\n\t\ttransform: translateX(${(props) =>\n\t\t\tprops.hiddenStyle\n\t\t\t\t? css`\n\t\t\t\t\t\t${props.theme.layout.chat.width};\n\t\t\t\t  `\n\t\t\t\t: '0'});\n  }\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthBigDesktop}) {\n\t\tmax-width: ${(props) => props.theme.layout.chat.widthDesktop};\n\t\ttransform: translateX(${(props) =>\n\t\t\tprops.hiddenStyle\n\t\t\t\t? css`\n\t\t\t\t\t\t${props.theme.layout.chat.widthDesktop};\n\t\t\t\t  `\n\t\t\t\t: '0'});\n\t}\n\n\t${(props) =>\n\t\t!props.$initialized\n\t\t\t? css`\n\t\t\t\t\t@media (max-width: ${(props) => props.theme.media.maxWidthTablet}) {\n\t\t\t\t\t\tdisplay: none;\n\t\t\t\t\t}\n\t\t\t  `\n\t\t\t: ''}\n`;\n\nexport interface ChatMainStyledProps {\n\t$chatContent?: boolean;\n\t$menu?: boolean;\n\t$noInput?: boolean;\n\t$tabs?: boolean;\n}\n\nconst getHeight = (\n\tprops: ChatMainStyledProps,\n\theaderHeight: string,\n\tinputHeight: string,\n) => {\n\tif (!props.$chatContent) {\n\t\treturn css`\n\t\t\theight: calc(100% - ${headerHeight});\n\t\t`;\n\t}\n\treturn css`\n\t\theight: calc(\n\t\t\t100% -\n\t\t\t\t${calcStyle({ a: headerHeight, b: props.$menu ? 2 : 1, mode: '*' })} -\n\t\t\t\t${props.$noInput ? '0px' : inputHeight}\n\t\t);\n\t`;\n};\n\nexport const chatPaddingMixin = css`\n\tpadding: 5px;\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n\t\tpadding: 10px;\n\t}\n`;\n\nexport const ChatMainStyle = styles.div.attrs<ChatMainStyledProps>((props) => ({\n\tclassName: classnames('chat-main', props.className),\n}))<ChatMainStyledProps>`\n\t${boxNoHeight};\n\t${chatPaddingMixin};\n\tposition: relative;\n\t${(props) =>\n\t\tgetHeight(\n\t\t\tprops,\n\t\t\tprops.theme.layout.chat.headerHeight,\n\t\t\tprops.theme.layout.chat.inputHeight,\n\t\t)};\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n\t\t${(props) =>\n\t\t\tgetHeight(\n\t\t\t\tprops,\n\t\t\t\tprops.theme.layout.chat.headerHeightDesktop,\n\t\t\t\tprops.theme.layout.chat.inputHeightDesktop,\n\t\t\t)};\n\t}\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthBigDesktop}) {\n\t\t${(props) =>\n\t\t\tgetHeight(\n\t\t\t\tprops,\n\t\t\t\tprops.theme.layout.chat.headerHeightBigDesktop,\n\t\t\t\tprops.theme.layout.chat.inputHeightBigDesktop,\n\t\t\t)};\n\t}\n\n\t${(props) =>\n\t\tprops.$tabs\n\t\t\t? css`\n\t\t\t\t\t.chat-stream {\n\t\t\t\t\t\theight: calc(100% - 35px);\n\t\t\t\t\t}\n\t\t\t  `\n\t\t\t: ''}\n`;\n","import styled from 'styled-components';\nimport { boxNoHeight } from '@legacyApp/client/modules/style/defaults';\nimport { chatPaddingMixin } from '../wrapper/chat.styled';\n\nexport const ChatTextareaWrapperStyled = styled.div`\n\tfloat: left;\n\tposition: relative;\n\twidth: 100%;\n\n\ttextarea {\n\t\tfloat: left;\n\t}\n\n\t> svg {\n\t\tcolor: ${(props) => props.theme.colors.veryLightBlue};\n\t\tcursor: pointer;\n\t\tposition: absolute;\n\t\tright: 15px;\n\t\ttop: 50%;\n\t\ttransform: translateY(-50%);\n\t\twidth: 1em;\n\n\t\t&:hover {\n\t\t\topacity: 0.8;\n\t\t}\n\t}\n`;\n\nexport const ChatButtonsWrapperStyled = styled.div`\n\talign-items: center;\n\tdisplay: flex;\n\tflex-direction: row;\n\tfloat: left;\n\tjustify-content: space-between;\n\twidth: 100%;\n\n\t> div {\n\t\talign-items: center;\n\t\tdisplay: flex;\n\t\tflex-direction: row;\n\t\tgap: 8px;\n\t\tjustify-content: flex-end;\n\t}\n`;\n\nexport const ChatInputStyle = styled.div.attrs(() => ({\n\tclassName: 'chat-input',\n}))`\n\t${chatPaddingMixin};\n\t${boxNoHeight};\n\tpadding-top: 0 !important;\n\theight: ${(props) => props.theme.layout.chat.inputHeight};\n\tdisplay: flex;\n\tflex-direction: column;\n\tjustify-content: space-between;\n\talign-items: stretch;\n\n\ttextarea {\n\t\tresize: none;\n\t\theight: unset;\n\t}\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthDesktop}) {\n\t\theight: ${(props) => props.theme.layout.chat.inputHeightDesktop};\n\t}\n\n\t@media (min-width: ${(props) => props.theme.media.minWidthBigDesktop}) {\n\t\theight: ${(props) => props.theme.layout.chat.inputHeightBigDesktop};\n\t}\n`;\n","import React, { FC, useCallback, useRef, useState } from 'react';\nimport classnames from 'classnames';\nimport EmojiConvertor from 'emoji-js';\nimport { faLaugh } from '@fortawesome/free-solid-svg-icons';\nimport { Button } from '@ui/button';\nimport { showAlert } from '@legacyApp/client/store/alerts/alerts.actions';\nimport { trans } from '@legacyApp/client/modules/translation/translate';\nimport { TextareaContainer } from '@legacyApp/client/components/textarea';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport { useAppMobile } from '@common/selectors/app.selectors';\nimport { useUserIsLogged } from '@common/selectors/user.selectors';\nimport { useStatsOnline } from '@common/selectors/stats.selectors';\nimport { useDispatchCallback } from '@legacyApp/hooks/store/useAppDispatch';\nimport { useOnMount } from '@common/hooks/useOnMount';\nimport { preventDefault } from '@common/methods/preventDefault';\nimport { simpleTrans } from '@legacyApp/client/modules/translation/translationService';\nimport { ButtonStyleType } from '@uiTypes/ButtonStyleType';\nimport { Size } from '@uiTypes/Size';\nimport { Loader } from '@legacyApp/client/components/loader/loader';\nimport { roundNumber } from '@common/methods/roundNumber/roundNumber';\nimport { ChatFeaturesList } from '../chat.list/chat.featuresList';\nimport { ListElement } from '../chat.list/chat.list';\nimport { ChatFeature } from '../../constants/CHAT_FEATURES';\nimport { useChatMessage } from '../../store/selectors/useChatMessage';\nimport {\n\tEmojiPickerWrapper,\n\tEmojiPickerWrapperProps,\n} from '../EmojiPickerWrapper/emojiPickerWrapper';\nimport { getDataQuery } from '../../methods/getDataQuery';\nimport { ChatUsersList } from '../chat.list/chat.usersList';\nimport { chatActions } from '../../store/chat.actions';\nimport { checkUsersListActiveThunk } from '../../store/thunks/checkUsersListActiveThunk';\nimport { checkChatFeatureListActiveThunk } from '../../store/thunks/checkChatFeatureListActiveThunk';\nimport { matchFeatureThunk } from '../../store/thunks/matchFeature.thunk';\nimport { sendMessageThunk } from '../../store/thunks/sendMessage.thunk';\nimport { chatFeatureHandleThunk } from '../../store/thunks/chatFeatureHandle.thunk';\nimport {\n\tChatButtonsWrapperStyled,\n\tChatInputStyle,\n\tChatTextareaWrapperStyled,\n} from './chat.input.style';\n\nconst MAX = 320;\n\nexport const ChatInput: FC = () => {\n\tconst emojiRef = useRef(null);\n\n\tconst isMobile = useAppMobile();\n\tconst isLogged = useUserIsLogged();\n\tconst online = useStatsOnline();\n\tconst message = useChatMessage();\n\n\tconst send_ = useDispatchCallback(sendMessageThunk);\n\tconst showAlert_ = useDispatchCallback(showAlert);\n\tconst handleFeature_ = useDispatchCallback(chatFeatureHandleThunk);\n\tconst setMessage_ = useDispatchCallback(chatActions.setMessage);\n\tconst updateMessage_ = useDispatchCallback(chatActions.updateMessage);\n\tconst matchFeature_ = useDispatchCallback(matchFeatureThunk);\n\tconst checkUsersListActive_ = useDispatchCallback(checkUsersListActiveThunk);\n\tconst checkChatFeatureListActive_ = useDispatchCallback(\n\t\tcheckChatFeatureListActiveThunk,\n\t);\n\n\tconst checkChatFeaturesDisabled = useCallback(\n\t\t(message_) => {\n\t\t\tconst message__ = message_ === undefined ? message : message_;\n\t\t\treturn !(message__ === '/' || message__ === '');\n\t\t},\n\t\t[message],\n\t);\n\n\tconst [showEmojiPicker, setShowEmojiPicker] = useState<boolean>(false);\n\tconst [disableChatFeatures, setDisableChatFeatures] = useState<boolean>(\n\t\tcheckChatFeaturesDisabled(''),\n\t);\n\n\tconst validateMessage = useCallback(() => {\n\t\treturn message && message.trim() !== '';\n\t}, [message]);\n\n\tconst handleChatFeature = useCallback(\n\t\t(message) => {\n\t\t\tconst feature = matchFeature_(message);\n\t\t\thandleFeature_(feature);\n\t\t\tconsole.log('handleChatFeature', { message, feature });\n\t\t\treturn feature;\n\t\t},\n\t\t[handleFeature_, matchFeature_],\n\t);\n\n\tconst onSubmit = useCallback(() => {\n\t\tif (!validateMessage()) {\n\t\t\tshowAlert_('info', 'Please, type message');\n\t\t}\n\t\tif (\n\t\t\tcheckUsersListActive_(message) ||\n\t\t\tcheckChatFeatureListActive_(message)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\tif (!handleChatFeature(message) && validateMessage()) {\n\t\t\tif (!isLogged) {\n\t\t\t\treturn showAlert_('info', 'Please, login first');\n\t\t\t}\n\t\t\tsend_(message);\n\t\t\tsetMessage_('');\n\t\t}\n\t\tsetDisableChatFeatures(checkChatFeaturesDisabled(''));\n\t}, [\n\t\tcheckChatFeatureListActive_,\n\t\tcheckChatFeaturesDisabled,\n\t\tcheckUsersListActive_,\n\t\thandleChatFeature,\n\t\tisLogged,\n\t\tmessage,\n\t\tsend_,\n\t\tsetMessage_,\n\t\tshowAlert_,\n\t\tvalidateMessage,\n\t]);\n\n\tconst handleKeyboard = useCallback(\n\t\t(obj) => {\n\t\t\t// handle Enter click\n\t\t\tif (obj.keyCode === 13) {\n\t\t\t\tif (obj.shiftKey) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tobj.preventDefault();\n\t\t\t\tonSubmit();\n\t\t\t}\n\t\t},\n\t\t[onSubmit],\n\t);\n\n\tconst handleMessage = useCallback(\n\t\t(message: string) => {\n\t\t\tif (message.length > MAX) {\n\t\t\t\treturn message;\n\t\t\t}\n\t\t\tsetDisableChatFeatures(checkChatFeaturesDisabled(message));\n\t\t\tmessage = emojiRef.current.replace_emoticons(message);\n\t\t\tsetMessage_(message);\n\t\t\treturn message;\n\t\t},\n\t\t[checkChatFeaturesDisabled, setMessage_],\n\t);\n\n\tconst onEmojiClick: EmojiPickerWrapperProps['onEmojiClick'] = useCallback(\n\t\t(emoji, event) => {\n\t\t\tconsole.log('onEmojiClick', { emoji, event });\n\t\t\thandleMessage(message + `${emoji.emoji}`);\n\t\t},\n\t\t[handleMessage, message],\n\t);\n\n\tconst handleChatFeatures = useCallback(() => {\n\t\tif (disableChatFeatures) {\n\t\t\treturn;\n\t\t}\n\t\thandleMessage('/');\n\t\t// console.log('handleChatFeatures');\n\t}, [disableChatFeatures, handleMessage]);\n\n\tconst handleChatMentionUser = useCallback(() => {\n\t\t// console.log('handleChatMentionUser');\n\t\tif (message && message[message.length - 1] === '@') {\n\t\t\treturn;\n\t\t}\n\t\tupdateMessage_('@');\n\t}, [message, updateMessage_]);\n\n\tconst onUserClick = useCallback(\n\t\t(user: ListElement) => {\n\t\t\tconst { name } = user;\n\t\t\tconst userQuery = getDataQuery(message, '@');\n\t\t\tif (userQuery) {\n\t\t\t\tconst split = message.split('@');\n\t\t\t\tsplit[split.length - 1] = split[split.length - 1].replace(\n\t\t\t\t\tuserQuery,\n\t\t\t\t\tname,\n\t\t\t\t);\n\t\t\t\treturn handleMessage(`${split.join('@')} `);\n\t\t\t}\n\t\t\treturn handleMessage(`${message}${name} `);\n\t\t},\n\t\t[handleMessage, message],\n\t);\n\n\tconst onFeatureClick = useCallback(\n\t\t(feature: ChatFeature) => {\n\t\t\thandleMessage(`${feature.mock} `);\n\t\t},\n\t\t[handleMessage],\n\t);\n\n\tconst toggleEmojiPicker = useCallback(() => {\n\t\tsetShowEmojiPicker(!showEmojiPicker);\n\t}, [showEmojiPicker]);\n\n\tconst onEmojiClickOutside = useCallback(\n\t\t() => (showEmojiPicker ? setShowEmojiPicker(false) : false),\n\t\t[showEmojiPicker],\n\t);\n\n\tuseOnMount(() => {\n\t\temojiRef.current = new EmojiConvertor();\n\t\temojiRef.current.text_mode = true;\n\t});\n\n\treturn (\n\t\t<>\n\t\t\t<ChatInputStyle>\n\t\t\t\t<ChatTextareaWrapperStyled>\n\t\t\t\t\t<ChatUsersList onClick={onUserClick} />\n\t\t\t\t\t<ChatFeaturesList onClick={onFeatureClick} />\n\t\t\t\t\t<label\n\t\t\t\t\t\thtmlFor=\"chat-input\"\n\t\t\t\t\t\tonClick={preventDefault}\n\t\t\t\t\t\tclassName=\"display-none\"\n\t\t\t\t\t>\n\t\t\t\t\t\tChat input\n\t\t\t\t\t</label>\n\t\t\t\t\t<TextareaContainer\n\t\t\t\t\t\tid={'chat-input'}\n\t\t\t\t\t\trows={1}\n\t\t\t\t\t\tvalue={message}\n\t\t\t\t\t\tplaceholder={simpleTrans('Type your message')}\n\t\t\t\t\t\tonChange={handleMessage}\n\t\t\t\t\t\tonKeyDown={handleKeyboard}\n\t\t\t\t\t/>\n\t\t\t\t\t{!isMobile && (\n\t\t\t\t\t\t<AwesomeIcon\n\t\t\t\t\t\t\ticon={faLaugh}\n\t\t\t\t\t\t\tclassName={classnames({\n\t\t\t\t\t\t\t\tactive: showEmojiPicker,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\tonClick={toggleEmojiPicker}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t</ChatTextareaWrapperStyled>\n\t\t\t\t<ChatButtonsWrapperStyled>\n\t\t\t\t\t<span>\n\t\t\t\t\t\t<span className=\"text-style-label-cap\">\n\t\t\t\t\t\t\t{trans({ label: 'Online' })}: {online}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</span>\n\t\t\t\t\t<div>\n\t\t\t\t\t\t<span className=\"text-style-label-cap\">\n\t\t\t\t\t\t\t{roundNumber(MAX - message.length, 0, 'ceil')}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tname=\"chat_features\"\n\t\t\t\t\t\t\tdisabled={disableChatFeatures}\n\t\t\t\t\t\t\tonClick={handleChatFeatures}\n\t\t\t\t\t\t\tstyleType={ButtonStyleType.OUTLINE}\n\t\t\t\t\t\t\tsize={Size.SMALL}\n\t\t\t\t\t\t\ticonBefore={<span>/</span>}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tname=\"chat_users\"\n\t\t\t\t\t\t\tonClick={handleChatMentionUser}\n\t\t\t\t\t\t\tstyleType={ButtonStyleType.OUTLINE}\n\t\t\t\t\t\t\tsize={Size.SMALL}\n\t\t\t\t\t\t\ticonBefore={<span>@</span>}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tname=\"chat_message_submit\"\n\t\t\t\t\t\t\tstyleType={ButtonStyleType.PRIMARY}\n\t\t\t\t\t\t\tsize={Size.SMALL}\n\t\t\t\t\t\t\tonClick={onSubmit}\n\t\t\t\t\t\t\tlabel={trans({ label: 'Send' })}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<Loader module=\"sendChatMessage\" />\n\t\t\t\t\t\t</Button>\n\t\t\t\t\t</div>\n\t\t\t\t</ChatButtonsWrapperStyled>\n\t\t\t</ChatInputStyle>\n\t\t\t{showEmojiPicker && !isMobile && (\n\t\t\t\t<EmojiPickerWrapper\n\t\t\t\t\tonEmojiClick={onEmojiClick}\n\t\t\t\t\tclickOutside={onEmojiClickOutside}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</>\n\t);\n};\n","import styled, { css } from 'styled-components';\nimport { StyledUserName } from 'src/ui/components/user-name/user-name.styled';\nimport {\n\tTabsStyle,\n\tTabsTabStyle,\n} from '@legacyApp/client/components/tabs/tabs.style';\nimport { fontSize } from '@legacyApp/client/modules/style/mixins/fontSize';\n\nexport const ChatActiveChatsStyle = styled(TabsStyle).attrs(() => ({\n\tclassName: 'chat-active-chats',\n}))`\n\tmargin: -10px -10px 5px;\n\twidth: calc(100% + 20px) !important;\n\tpadding: 5px 5px 0;\n\talign-items: flex-end;\n\theight: 35px !important;\n\tborder-bottom: 1px solid ${(props) => props.theme.colors.borderColor};\n\tdisplay: flex;\n\toverflow: auto;\n`;\n\nexport const ChatActiveChatsCloseStyle = styled.div.attrs(() => ({\n\tclassName: 'chat-active-chats__close',\n}))`\n\tmargin: 0 0 0 10px;\n\twidth: 15px;\n\n\ti,\n\tsvg {\n\t\theight: 15px !important;\n\t\tmargin: 0 !important;\n\t}\n`;\n\nexport const ChatActiveChatsTabStyle = styled(TabsTabStyle).attrs(() => ({\n\tclassName: 'chat-active-chats__tab',\n}))`\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tmargin: 0 1px !important;\n\theight: ${(props) => (props.active ? '30px' : '25px')};\n\tpadding: 0 10px !important;\n\tbackground-color: ${(props) =>\n\t\tprops.active\n\t\t\t? props.theme.colors.inputBackgroundActive\n\t\t\t: props.theme.colors.inputBackground};\n\tborder-radius: ${(props) => props.theme.layout.borderRadius}\n\t\t${(props) => props.theme.layout.borderRadius} 0 0;\n\n\t${(props) =>\n\t\tprops.unread\n\t\t\t? css`\n\t\t\t\t\tanimation-duration: 2s;\n\t\t\t\t\tanimation-iteration-count: infinite;\n\t\t\t\t\tanimation-name: bounce;\n\t\t\t\t\tanimation-timing-function: cubic-bezier(0.28, 0.84, 0.42, 1);\n\t\t\t\t\tbottom: -2px;\n\t\t\t\t\tposition: relative;\n\t\t\t  `\n\t\t\t: ''}\n\n\t* {\n\t\t${(props) =>\n\t\t\tfontSize({\n\t\t\t\tsize: '12px',\n\t\t\t\tsizeDesktop: '14px',\n\t\t\t\tsizeBigScreen: '16px',\n\t\t\t\tminWidth: props.theme.media.minWidthBigDesktop,\n\t\t\t})}\n\t}\n\n\t&:before {\n\t\tdisplay: none !important;\n\t}\n\n\t${StyledUserName} {\n\t\tsvg,\n\t\timg {\n\t\t\theight: 15px !important;\n\t\t\twidth: auto !important;\n\t\t\tmargin: 0 !important;\n\t\t}\n\t}\n`;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\nimport { UserLogin } from '@common/components/user/UserLogin/UserLogin';\nimport { enhanceComponent } from '@legacyApp/client/wrappers/enhanceComponent';\nimport { AwesomeIcon } from '@common/components/icons/AwesomeIcon';\nimport {\n\tChatActiveChatsCloseStyle,\n\tChatActiveChatsStyle,\n\tChatActiveChatsTabStyle,\n} from './ChatActiveTabs.style';\n\nclass ChatActiveTabs extends React.PureComponent {\n\tstatic propTypes = {\n\t\tlist: PropTypes.array,\n\t\tclassName: PropTypes.string,\n\t\tcloseChat: PropTypes.func,\n\t\topenChat: PropTypes.func,\n\t\tprivateActive: PropTypes.any,\n\t\tunread: PropTypes.object,\n\t};\n\n\tcloseChat = (data) => {\n\t\tthis.props.closeChat(data);\n\t};\n\n\topenChat = (data) => {\n\t\tthis.props.openChat(data);\n\t};\n\n\trender() {\n\t\treturn (\n\t\t\t<ChatActiveChatsStyle>\n\t\t\t\t{this.props.list.map((el) => {\n\t\t\t\t\tconst isUnread = this.props.unread[el.channelId];\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<ChatActiveChatsTabStyle\n\t\t\t\t\t\t\tlocalTheme={{\n\t\t\t\t\t\t\t\tscrollHorizontal: true,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\tactive={el.channelId === this.props.privateActive}\n\t\t\t\t\t\t\tunread={isUnread}\n\t\t\t\t\t\t\tclassName={classnames({\n\t\t\t\t\t\t\t\t[this.props.className]: this.props.className,\n\t\t\t\t\t\t\t\t'chat-active-chats__tab--active':\n\t\t\t\t\t\t\t\t\tel.channelId === this.props.privateActive,\n\t\t\t\t\t\t\t\t'chat-active-chats__tab--unread': isUnread,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\tkey={el.user.uuid}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<div onClick={() => this.openChat(el)}>\n\t\t\t\t\t\t\t\t<UserLogin noClick user={el.user} />\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<ChatActiveChatsCloseStyle onClick={() => this.closeChat(el)}>\n\t\t\t\t\t\t\t\t<AwesomeIcon icon={faTimes} />\n\t\t\t\t\t\t\t</ChatActiveChatsCloseStyle>\n\t\t\t\t\t\t</ChatActiveChatsTabStyle>\n\t\t\t\t\t);\n\t\t\t\t})}\n\t\t\t</ChatActiveChatsStyle>\n\t\t);\n\t}\n}\n\nChatActiveTabs = enhanceComponent({\n\tChatActiveTabs,\n});\n\nexport { ChatActiveTabs };\n","import { connect } from 'react-redux';\nimport {\n\tprivateMessagesCloseActive,\n\tprivateMessagesOpenActive,\n} from '@legacyApp/client/store/privateMessages/privateMessages.actions';\nimport { ChatActiveTabs } from './ChatActiveTabs';\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\t// TODO: chat store usage\n\t\tlist: state.privateMessages.activeList,\n\t\tprivateActive: state?.chat?.privateActive,\n\t\tunread: state.privateMessages.unread,\n\t};\n};\n\nconst mapDispatchToProps = (dispatch) => {\n\treturn {\n\t\tcloseChat: (data) => dispatch(privateMessagesCloseActive(data)),\n\t\topenChat: (data) => dispatch(privateMessagesOpenActive(data)),\n\t};\n};\n\nconst ChatActiveTabsContainer = connect(\n\tmapStateToProps,\n\tmapDispatchToProps,\n)(ChatActiveTabs);\n\nexport { ChatActiveTabsContainer };\n","import classnames from 'classnames';\nimport dynamic from 'next/dynamic';\nimport { FC, useCallback, useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\n\nimport { useOnMount } from '@common/hooks/useOnMount';\nimport { useStateEffect } from '@common/hooks/useStateEffect';\nimport { useAppInitialized } from '@common/selectors/app.selectors';\nimport { FEATURES_TYPE } from '@legacyApp/client/config';\nimport { checkIsMobile } from '@legacyApp/client/modules/app/appService';\nimport { isFeatureAvailable } from '@legacyApp/client/modules/app/featureService';\nimport { setLockedView } from '@legacyApp/client/store/app/app.actions';\nimport { useAppDispatch } from '@legacyApp/hooks/store/useAppDispatch';\nimport { useAppSelector } from '@legacyApp/hooks/store/useAppSelector';\nimport { usePrivateMessagesActiveListLength } from '@legacyApp/client/store/privateMessages/privateMessages.selectors';\nimport { chatActions } from '@modules/chat/store/chat.actions';\nimport { useChatContentType } from '@modules/chat/store/selectors/useChatContentType';\nimport { useChatDisabled } from '@modules/chat/store/selectors/useChatDisabled';\nimport { useChatPrivateActive } from '@modules/chat/store/selectors/useChatPrivateActive';\nimport { useChatRoom } from '@modules/chat/store/selectors/useChatRoom';\nimport { useChatVisible } from '@modules/chat/store/selectors/useChatVisible';\nimport { ContentType } from '@modules/chat/store/slices/contentType.slice';\nimport ChatStoreController from '@modules/chat/store/ChatStoreController';\nimport { ChatContent } from '@modules/chat/components/content/chatContent';\nimport { ChatHeaderContainer } from '@modules/chat/components/header/chat.header.container';\nimport { ChatInput } from '@modules/chat/components/input/chatInput';\nimport { ChatActiveTabsContainer } from '@modules/chat/components/private/activeList/ChatActiveTabs.container';\nimport {\n\tChatMainStyle,\n\tChatStyled,\n} from '@modules/chat/components/wrapper/chat.styled';\n\nconst ChatMenu = dynamic(() => import('@modules/chat/components/ChatMenu'));\n\nconst ChatWrapper: FC = () => {\n\tconst dispatch = useAppDispatch();\n\n\tconst visible = useChatVisible();\n\n\tconst room = useChatRoom();\n\n\tconst contentType = useChatContentType();\n\n\tconst activePrivate = !!usePrivateMessagesActiveListLength();\n\n\tconst disabled = useChatDisabled();\n\n\tconst privateActive = useChatPrivateActive();\n\n\tconst initialized = useAppInitialized();\n\n\tconst isMenu = useAppSelector(\n\t\t(state) =>\n\t\t\tstate.sports?.active &&\n\t\t\t(state.app.mobile ? !!state.sports.sideContent : true),\n\t\tshallowEqual,\n\t);\n\n\tconst isChatContent = useAppSelector(\n\t\t(state) => !(state.sports?.active && state.sports?.sideContent),\n\t\tshallowEqual,\n\t);\n\n\tuseEffect(() => {\n\t\tif (checkIsMobile()) {\n\t\t\tvisible && dispatch(setLockedView('visibilityEpic', true));\n\t\t}\n\t}, [dispatch, visible]);\n\n\tconst wrapperClasses = useStateEffect(\n\t\tuseCallback(() => {\n\t\t\treturn classnames(`chat-${room} chat-content-${contentType}`);\n\t\t}, [contentType, room]),\n\t);\n\n\tuseOnMount(() => {\n\t\tif (checkIsMobile()) {\n\t\t\tdispatch(chatActions.setVisible({ isVisible: false }));\n\t\t}\n\t});\n\n\tif (!isFeatureAvailable(FEATURES_TYPE.CHAT) || disabled) {\n\t\treturn null;\n\t}\n\n\tconst isInput =\n\t\t(privateActive || contentType === ContentType.STREAM) && visible;\n\n\treturn (\n\t\t<>\n\t\t\t<ChatStoreController />\n\n\t\t\t<ChatStyled\n\t\t\t\t$initialized={initialized}\n\t\t\t\thiddenStyle={!visible}\n\t\t\t\tclassName={wrapperClasses}\n\t\t\t>\n\t\t\t\t{isMenu && <ChatMenu />}\n\n\t\t\t\t{isChatContent && <ChatHeaderContainer />}\n\n\t\t\t\t<ChatMainStyle\n\t\t\t\t\t$noInput={!isInput}\n\t\t\t\t\t$chatContent={isChatContent}\n\t\t\t\t\t$menu={isMenu}\n\t\t\t\t\t$tabs={activePrivate}\n\t\t\t\t>\n\t\t\t\t\t{isChatContent && activePrivate && <ChatActiveTabsContainer />}\n\n\t\t\t\t\t{visible && <ChatContent />}\n\t\t\t\t</ChatMainStyle>\n\n\t\t\t\t{isInput && isChatContent && <ChatInput />}\n\t\t\t</ChatStyled>\n\t\t</>\n\t);\n};\n\nexport default ChatWrapper;\n","export const MESSAGE_COMPARE_KEYS = ['$.user.login', 'message', 'nonce'];\n","import { createContext } from 'react';\nimport { Message } from '../types/Message.type';\n\nexport interface ChatMessageContextProps {\n\tmessage: Message;\n\tisPrivate: boolean;\n\tisBotMessage: boolean;\n\tisMyMessage: boolean;\n}\n\nexport const ChatMessageContext = createContext<ChatMessageContextProps>(\n\t{} as ChatMessageContextProps,\n);\n","import { createContext } from 'react';\nimport { Message } from '../types/Message.type';\n\nexport interface ChatStreamContextProps {\n\tunreadFromId: string;\n\tsetUnreadFromId: (id: string) => void;\n\tprivateStream: boolean;\n\tscrollToMessage: (nonce: number) => void;\n\tstream: Array<Message>;\n}\n\nexport const ChatStreamContext = createContext<ChatStreamContextProps>({\n\tunreadFromId: null,\n\tsetUnreadFromId: () => null,\n\tprivateStream: false,\n\tscrollToMessage: () => null,\n\tstream: [],\n} as ChatStreamContextProps);\n","import transactionsService from '../../transactions/transactionsService';\nimport { MESSAGE_COMPARE_KEYS } from '../constants/MESSAGE_COMPARE_KEYS';\nimport { Message } from '../types/Message.type';\n\nexport const getMessageId = (message: Message): string => {\n\tif (!message) {\n\t\treturn null;\n\t}\n\treturn transactionsService.getCompareData(message, MESSAGE_COMPARE_KEYS);\n};\n","import { lsGet } from '@modules/localStorage/methods/lsGet';\nimport { lsClear } from '@modules/localStorage/methods/lsClear';\nimport { LocalStorageKeys } from '@modules/localStorage/types/localStorageKeys.type';\nimport { jsonToString } from '@common/methods/jsonToString';\n\nexport const addShareDetails = (message: string) => {\n\tconst lsData = lsGet(LocalStorageKeys.CHAT_SHARE_DATA);\n\tif (!lsData) {\n\t\treturn message;\n\t}\n\t// console.log('addShareDetails', {\n\t// \tmessage,\n\t// \tlsData,\n\t// });\n\tlsClear(LocalStorageKeys.CHAT_SHARE_DATA);\n\tObject.keys(lsData).forEach((key) => {\n\t\tif (message.indexOf(key) > -1) {\n\t\t\tconst [keyBase] = key.split('#:');\n\t\t\tconst data = lsData[key];\n\t\t\tmessage = message.replace(\n\t\t\t\tkey,\n\t\t\t\t`${keyBase}#${data.data_id}^detailsStart${jsonToString(\n\t\t\t\t\tdata,\n\t\t\t\t)}detailsEnd`,\n\t\t\t);\n\t\t}\n\t});\n\treturn message;\n};\n","import React from 'react';\nimport { second } from '@legacyApp/client/modules/app/time';\nimport { getTimestamp } from '@legacyApp/client/modules/app/timeService';\nimport { simpleTrans } from '@legacyApp/client/modules/translation/translationService';\nimport { TimerCountDown } from '@common/components/timerCountDown';\nimport {\n\tcloseAlert,\n\tshowAlert,\n} from '@legacyApp/client/store/alerts/alerts.actions';\nimport { tokenService } from '@legacyApp/client/modules/app/tokenService';\nimport { isFeatureAvailable } from '@legacyApp/client/modules/app/featureService';\nimport { FEATURES_TYPE } from '@legacyApp/client/config';\nimport { fetchApiAction } from '@legacyApp/client/store/fetch/fetch.thunk';\nimport { AppThunk } from '@legacyApp/types/store/ThunkAction';\nimport { addShareDetails } from '../../methods/addShareDetails';\n\nlet lastMessageTimestamp = getTimestamp();\n\nexport const sendMessageThunk = (message: string): AppThunk => {\n\treturn (dispatch, getState) => {\n\t\tif (!tokenService.token.value) {\n\t\t\tdispatch(showAlert('error', 'Please, sign in if you want to chat'));\n\t\t\treturn;\n\t\t}\n\t\tconst { chat } = getState();\n\t\tconst isPrivate = chat?.privateActive;\n\t\tconst antispamDelay = isPrivate ? second : 5 * second;\n\t\tconst currTimestamp = getTimestamp();\n\t\t// console.log('SEND_MESSAGE', {\n\t\t//   curr: currTimestamp,\n\t\t//   last: lastMessageTimestamp,\n\t\t//   bool: lastMessageTimestamp >= currTimestamp,\n\t\t// });\n\t\tif (lastMessageTimestamp > currTimestamp) {\n\t\t\tif (lastMessageTimestamp - currTimestamp > antispamDelay) {\n\t\t\t\tlastMessageTimestamp = currTimestamp + antispamDelay;\n\t\t\t}\n\t\t\tconst error = (\n\t\t\t\t<span>\n\t\t\t\t\t<span>\n\t\t\t\t\t\t{simpleTrans('Anti-Spam - you will be able to resend in')}\n\t\t\t\t\t</span>{' '}\n\t\t\t\t\t<TimerCountDown\n\t\t\t\t\t\tdate={lastMessageTimestamp}\n\t\t\t\t\t\tdispatchCallback={closeAlert(undefined, 1)}\n\t\t\t\t\t\tprecise={true}\n\t\t\t\t\t/>\n\t\t\t\t</span>\n\t\t\t);\n\t\t\tdispatch(showAlert('error', error, true));\n\t\t\treturn;\n\t\t}\n\t\tlastMessageTimestamp = currTimestamp + antispamDelay;\n\t\tconst uri = isPrivate ? '/user/messages' : '/chat/send';\n\t\tconst body = {\n\t\t\tmessage: addShareDetails(message),\n\t\t\troom: null,\n\t\t\tuuid: null,\n\t\t};\n\t\tisPrivate ? (body.uuid = isPrivate) : (body.room = chat?.room);\n\t\tif (\n\t\t\tbody.room &&\n\t\t\tbody.room !== 'admin' &&\n\t\t\t!isFeatureAvailable(FEATURES_TYPE.CHAT)\n\t\t) {\n\t\t\tdispatch(showAlert('info', 'Chat is disabled'));\n\t\t\treturn;\n\t\t}\n\t\tdispatch(\n\t\t\tfetchApiAction({\n\t\t\t\turl: uri,\n\t\t\t\tparameters: {\n\t\t\t\t\tAuthorization: true,\n\t\t\t\t\tbody,\n\t\t\t\t},\n\t\t\t\tmethod: 'POST',\n\t\t\t\tloaderId: 'sendChatMessage',\n\t\t\t}),\n\t\t);\n\t};\n};\n"],"names":["asArray","v","concat","isPsuedoSelector","selector","startsWith","isStyleCondition","isString","length","includes","slice","isImmediatePostcondition","isValidProperty","property","value","isCssVariables","isMediaQuery","joinTruthy","arr","delimiter","filter","Boolean","join","stableHash","prefix","seed","hash","toString","i","charCodeAt","joinedProperty","Rule","_Rule","constructor","sheet","this","joined","joinedConditions","preconditions","postconditions","hasConditions","scopeClassName","name","key","selectors","mergeSelectors","right","left","genRule","static","replace","toLowerCase","handlePropertyValue","output","reduce","selectors2","current","str","Selector","_Selector","scopeName","setScope","count","addScope","addPrecondition","precondition","addPostcondition","postcondition","createRule","forIn","obj","fn","trim","cx","args","classes2","arg","Set","push","Array","isArray","Object","entries","forEach","createSheet","rootNode","storedStyles","storedClasses","style","id","styleTag","createStyleTag","getStyle","append","css","base","line","apply","innerHTML","isApplied","document","createElement","type","head","appendChild","addRule","rule","storedClass","create","styles","scopedStyles","iteratePreconditions","styles2","iterateStyles","className","name2","add","addScopedStyle","bind","item","res","isDirectClass","mediaQuery","handleMediaQuery","classes","chunkRows","addEachClass","cssVariablesBlock","list","to","DropdownStyle","styled","props","classnames","boxNoHeight","localTheme","error","keys","theme","text","fonts","Bold","dropdownGetThunk","dispatch","getState","dropdown","content","Dropdown","active","useDropdownActiveSelector","close","useDispatchCallback","dropdownDelete","dropdownAdd","toggle","dropdownToggle","get","addContent","useCallback","items","lastContent","scrollElement","title","onClick","width","trans","itemElement","dropdownContentEqualityFn","toggleList","bool","useOnUnmount","useEffect","children","undefined","styleType","ButtonStyleType","borderType","InputStyleType","label","namespace","DropdownArrow","help","Textarea","e","setState","onChange","target","input","activeElement","onKeyDown","state","React","prevProps","as","ref","rows","placeholder","translationService","t","handleKeyboard","enhanceComponent","TextareaContainer","compose","withTranslation","DEFAULT_NAMESPACE","actionSimple","DROPDOWN_SET_ACTIVE","DROPDOWN_SET_CONTENT","DROPDOWN_DELETE","DROPDOWN_ADD","DROPDOWN_TOGGLE","a","b","transactionService","useAppSelector","shallowEqual","removeArrayDuplicates","array","uniq","AuthActionButton","labelText","isLogged","useUserIsLogged","useAppDispatch","openModal","MODAL_ID","callback","ChatHeaderStyle","HeaderHeight","height","media","minWidthDesktop","ChatButtonsStyle","ChatButtonStyle","Button","fontSize","size","sizeDesktop","layout","transition","getBackground","isMyMessage","rgba","colors","inputButton","isBotMessage","isPrivate","ChatMessageStyle","borderRadius","Regular","veryLightBlue","sizeDiff","sizeBigScreen","calcStyle","desktop","mode","important","StyledUserName","borderRadiusValue","orange","MessageTextStyled","ChatMessageUserStyle","StyledVipIcon","ChatMessageShareStyle","CSSClassNameButton","passwordValidationColor","ChatMessageDateStyle","MessageText","dynamic","ssr","notificationCounterIcon","$count","StyledNotificationCounter","PusherConnectionStates","usePrivateMessagesActiveListLength","privateMessages","activeList","useChatContentType","chat","contentType","useChatPrivateActive","privateActive","useChatRoom","room","WebsocketConnectionFailed","connectionState","websocket","CONNECTED","CONNECTING","indexOf","ChatMessageLoader","viewBox","uniqueKey","config","x","y","rx","ry","cy","r","checkIsTriviaMessage","message","user","is_moderator","is_admin","Trivia","MessageUnreadNotification","Loadable","loader","AdminMessage","BotMessage","MessageContent","ChatMessage_","userName","useUserName","privateStream","useContext","ChatStreamContext","login","checkIsBotLogin","nonce","pm","ChatMessage","ChatUnreadMessagesCounter","autoScroll","boxRef","resetRef","unreadFromId","setUnreadFromId","myUserId","useUserId","prevList","usePrevious","prevRoom","scrollTimeoutRef","useRef","clearUnreadTimeout","useState","unreadCounter","setUnreadCounter","prevUnreadFromId","checkIsMyLastMessage","uuid","resetUnread","clearTimeout","setTimeout","incrementUnread","getMessageId","String","Number","clearScrollTimeout","scrollToBottom","force","isFunction","scroll","top","scrollHeight","behavior","scrollTop","transactionsService","MESSAGE_COMPARE_KEYS","autoScroll_","onUnreadNotification","options","number","ChatStream","getStream","loadingId","noHistory","loaded","setAutoScroll","historyLoading","setHistoryLoading","scrollToMessage","element","querySelector","offsetTop","clientHeight","loadHistory","trackScrolling","event","el","offsetHeight","isBottom","isTop","useOnMount","boxElem","addEventListener","removeEventListener","stream","LoaderListWrapper","listElementCallback","preloadElement","index","preloadLength","module","ChatPrivateStream","channel","ChatPrivateStreamContainer","connect","closeStream","chatActions","channelId","privateMessagesGetStream","ChatStreamContainer","useChatStreamList","getRoomStreamThunk","ChatPrivateStyle","ChatStreamStyle","attrs","ChatPrivateBoxStyle","box","borderColor","ChatPrivateListStyle","ChatPrivateListElementStyle","StyledUserActions","HistoryListStyle","inputBackground","minWidth","minWidthBigDesktop","HistoryListHeaderStyle","HistoryListMessageStyle","cutTextStyle","unread","grey","HistoryList","data","openChat","Fragment","sort","sortService","DIRECTION","last_message_timestamp","map","isUnread","UserLogin","formatDate","AwesomeIcon","icon","faCircle","last_message","simple","HistoryListContainer","privateMessagesOpenActive","ChatPrivateHistory","history","ChatPrivateHistoryContainer","FriendsList","actionsType","friend","status","ChatFriends","activeTab","tabs","smallText","noWrap","light","scrollHorizontal","fullWidth","handleChangeTab","ChatFriendsContainer","friends","requests","StyledBetsList","BetsList","refID","getId","useSportsBetSlipBetsList","SportsbookListContext","BetElement","bet","matchId","outcomeId","useBetSlipValidation","stake","totalMultiOdds","betsList","sportsBetSlip","betsData","bets","isMulti","profit","roundNumber","stakeValidation","useValidateStake","game","GameType","profitValidation","useValidateProfit","betsListValidation","validateStake","useValidateStakeCallback","validateProfit","useValidateProfitCallback","setBool","check","some","outcome","decimal_odds","useValidateBetsList","betSlipLengthError","BETSLIP_MULTI_LIMIT","useErrorBetsListLength","betSlipListError","multiMatch","checkBetSlipError","useErrorBetsList","disabled","invalid","sportsBetSlipSetFormError","default","jsonToString","StyledOddsInfo","negative","sizeDesktopDiff","sizeBigScreenDiff","StyledButton","useSportsBetSlipBetsData","acceptType","ALL_ACCEPT","placed_at","newOdds","ONLY_HIGHER_ACCEPT","NO_ODDS_ACCEPT","isNewOdds","useValidateBetsListOdds","submit","updatedBetsData","updateBetsList","oddsChanged","sportsBetSlipSetBets","sportsBetSlipSetBetsList","sportsBetSlipSubmit","transSports","ReuseFailedBets","StyledReuseFailedBets","info","faRedoAlt","BetSlipFormOptions","useSportsBetSlipAcceptType","isReuseFailed","setIsReuseFailed","result_odds","checkReuseFailed","StyledOptions","TransNamespace","BETSLIP_ACCEPT_TYPES","sportsBetSlipSetAcceptType","sportsBetSlipClearPlacedBets","sportsBetSlipUpdate","faTrash","Black","ButtonStyle","BetSlipFormMultiInput","amount","update","updateError","placedBets","useSportsBetSlipPlacedBets","useSportsBetSlipReadyToBetBets","eventsData","useSportsEventsData","findIndex","offerData","odds","offer_id","checkDisabledOffer","StyledBetSlipFormMultiInput","$disabled","StakeInput","precision","BetSlipFormMessage","useSportsBetSlipError","$success","faExclamationCircle","faCalendarCheck","BetSlipForm","totalSingleStake","totalWin","lsGet","LocalStorageKeys","setPossibleWinnings","setTotalOdds","setTotalStake","setStakeFromFirstListElement","getBetOdds","match","filtered","filterArrayDuplicates","result","getBetDetails","parseFloat","lsSet","onUpdateError","prevState","currentList","getCompareList","isStakeListChanged","isStakeChanged","mathService","isOddsChanged","StyledBetSlipForm","StyledBetSlipFormBox","StyledSummary","inputUpdateError","SummaryValue","simpleValue","MatchOdds","valueProps","color","PureComponent","maxWidthTablet","InputWrapperStyle","background","BetSlipInput","StyledBetSlipElementMessage","onUpdate","StyledBetSlipInfo","StyledBetSlipSection","StyledLoader","useTypeTabsAutoSwitch","allowAutoSwitch","setAllowAutoSwitch","useSportsBetSlipType","prevListLength","_setType","newType","sportsBetSlipSetType","matchIdList","filteredMatchIdList","isMultiMode","BETSLIP_TYPE","setType","BetSlipTypeTabs","buttonsStyle","BETSLIP_TYPES","callbackOnInit","tab","BetSlipSection","loading","useSportsBetSlipPlacingBet","noTranslationCheck","useSportsSideContent","BetsHistory","ChatContent","sportsContent","sportsActive","useSportsActive","ContentType","ChatFriendsIcon","faUserFriends","ChatFriendsIconContainer","ChatPrivateIcon","faEnvelope","ChatPrivateIconContainer","AVAILABLE_CONTINENTS","europe","faGlobeEurope","asia","faGlobeAsia","america","faGlobeAmericas","africa","faGlobeAfrica","GlobeIcon","continent","faGlobe","getIcon","GlobeIconContainer","app","location","AVAILABLE_ROOMS","ChatRoomSelect","activeRoom","isAdmin","useUserIsAdmin","switchRoom","setContentType","roomsList","useStateEffect","admin","symbol","activeRoom_","find","interactive","zIndex","FlagIcon","languageConfig","withWrapper","lastRoom","iconBefore","ChatHeaderContainer","isMobile","useAppMobile","openModal_","toggleChat","faInfoCircle","isVisible","faTimes","CHAT_FEATURES","faCloudRain","code","mock","faCommentDollar","faAddressCard","faReceipt","faChartLine","faLock","faLockOpen","faQuestion","isModerator","getChatFeaturesThunk","disableTip","getChatFeatures","tip","checkChatFeatureListActiveThunk","getDataQuery","split","useChatMessage","ChatListStyle","inputBackgroundSolid","ChatListElementStyle","highlight","ChatList","checkActive","parseEl","prevMessage","setName","show","setShow","selectedElement","setSelectedElement","filterElement","list_","handleArrows","isUp","onOptionClick","onEnter","stopPropagation","keyCode","preventDefault","handleClickOutside","outsideClickRef","useOnclickOutside","currUserName","ChatFeaturesList","getFeaturesList","EmojiPicker","EmojiPickerWrapper","clickOutside","outSideRef","EmojiPickerWrapperStyled","Theme","inputHeight","inputHeightDesktop","inputHeightBigDesktop","checkUsersListActiveThunk","users","ChatUsersList","regexFeatureWithoutParameter","string","regexString","getChatFeatureThunk","withParameter","restMessage","chatFeatures","potentialFeature","feature","parameter","rest","matchFeatureThunk","message_","messageArray","pop","matchesWithParameter","matchesWithoutParameter","uuidPattern","validationRegex","UUIDv4","_validationRegex","_uuidPattern","_throwInvalidIdError","blockingError","Error","console","warn","refreshId","_id","generate","validate","test","isUUIDv4Like","char","rand","Math","random","chatBetHandleThunk","chatSessionHandleThunk","chatUserHandleThunk","getUserDetailsByLogin","chatPrivateMessageHandleThunk","chatIgnoreHandleThunk","friendsUnignore","friendsIgnore","chatFeatureHandleThunk","showAlert","ChatStyled","bottomMenuHeight","hiddenStyle","widthDesktop","$initialized","getHeight","headerHeight","$chatContent","$menu","$noInput","chatPaddingMixin","ChatMainStyle","headerHeightDesktop","headerHeightBigDesktop","$tabs","ChatTextareaWrapperStyled","ChatButtonsWrapperStyled","ChatInputStyle","ChatInput","emojiRef","online","useStatsOnline","send_","sendMessageThunk","showAlert_","handleFeature_","setMessage_","updateMessage_","matchFeature_","checkUsersListActive_","checkChatFeatureListActive_","checkChatFeaturesDisabled","message__","showEmojiPicker","setShowEmojiPicker","disableChatFeatures","setDisableChatFeatures","validateMessage","handleChatFeature","onSubmit","shiftKey","handleMessage","replace_emoticons","onEmojiClick","emoji","handleChatFeatures","handleChatMentionUser","onUserClick","userQuery","onFeatureClick","toggleEmojiPicker","onEmojiClickOutside","EmojiConvertor","text_mode","htmlFor","simpleTrans","faLaugh","Size","ChatActiveChatsStyle","TabsStyle","ChatActiveChatsCloseStyle","ChatActiveChatsTabStyle","TabsTabStyle","inputBackgroundActive","ChatActiveTabs","closeChat","noClick","ChatActiveTabsContainer","privateMessagesCloseActive","ChatMenu","visible","useChatVisible","activePrivate","useChatDisabled","initialized","useAppInitialized","isMenu","sports","mobile","sideContent","isChatContent","checkIsMobile","setLockedView","wrapperClasses","isFeatureAvailable","FEATURES_TYPE","isInput","ChatStoreController","ChatMessageContext","createContext","addShareDetails","lsData","lsClear","keyBase","data_id","lastMessageTimestamp","getTimestamp","tokenService","antispamDelay","second","currTimestamp","date","dispatchCallback","closeAlert","precise","uri","body","fetchApiAction","url","parameters","Authorization","method","loaderId"],"mappings":"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","debug_id":"c0cd368e-7b28-550f-a021-5da1c8837263"}