{"version":3,"file":"js/common.c9545c7b38c9dd2a164c.js","mappings":"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","sources":["webpack://fider/./public/components/common/HoverInfo.tsx","webpack://fider/./public/components/common/Icon.tsx","webpack://fider/./public/components/ErrorBoundary.tsx","webpack://fider/./public/components/ShowPostResponse.tsx","webpack://fider/./public/components/ShowPostStatus.tsx","webpack://fider/./public/components/ShowTag.tsx","webpack://fider/./public/components/Header.tsx","webpack://fider/./public/components/common/Button.tsx","webpack://fider/./public/components/common/form/Form.tsx","webpack://fider/./public/components/common/form/DisplayError.tsx","webpack://fider/./public/components/common/form/Input.tsx","webpack://fider/./public/components/common/form/ImageUploader.tsx","webpack://fider/./public/components/common/form/MultiImageUploader.tsx","webpack://fider/./public/components/common/form/TextArea.tsx","webpack://fider/./public/components/common/form/RadioButton.tsx","webpack://fider/./public/components/common/form/Select.tsx","webpack://fider/./public/components/common/form/Field.tsx","webpack://fider/./public/components/common/form/Checkbox.tsx","webpack://fider/./public/components/common/form/ImageViewer.tsx","webpack://fider/./public/components/common/Markdown.tsx","webpack://fider/./public/components/common/DevBanner.tsx","webpack://fider/./public/components/common/Avatar.tsx","webpack://fider/./public/components/common/AvatarStack.tsx","webpack://fider/./public/components/common/Message.tsx","webpack://fider/./public/components/common/Hint.tsx","webpack://fider/./public/components/common/Legal.tsx","webpack://fider/./public/components/common/SocialSignInButton.tsx","webpack://fider/./public/components/common/SignInControl.tsx","webpack://fider/./public/components/common/Moment.tsx","webpack://fider/./public/components/common/Modal.tsx","webpack://fider/./public/components/common/UserName.tsx","webpack://fider/./public/components/common/Loader.tsx","webpack://fider/./public/components/common/Logo.tsx","webpack://fider/./public/components/common/Toggle.tsx","webpack://fider/./public/components/common/PoweredByFider.tsx","webpack://fider/./public/components/common/PageTitle.tsx","webpack://fider/./public/components/common/Dropdown.tsx","webpack://fider/./public/components/common/Money.tsx","webpack://fider/./public/components/SignInModal.tsx","webpack://fider/./public/components/VoteCounter.tsx","webpack://fider/./public/components/NotificationIndicator.tsx","webpack://fider/./public/components/UserMenu.tsx","webpack://fider/./public/components/Reactions.tsx","webpack://fider/./public/components/ReadOnlyNotice.tsx","webpack://fider/./public/components/layout/Stack.tsx","webpack://fider/./public/components/layout/Divider.tsx","webpack://fider/./public/models/post.ts","webpack://fider/./public/models/identity.ts","webpack://fider/./public/models/settings.ts","webpack://fider/./public/models/billing.ts","webpack://fider/./public/models/webhook.ts","webpack://fider/./public/services/http.ts","webpack://fider/./public/services/cache.ts","webpack://fider/./public/services/analytics.ts","webpack://fider/./public/services/fider.ts","webpack://fider/./public/services/jwt.ts","webpack://fider/./public/services/utils.ts","webpack://fider/./public/services/i18n.ts","webpack://fider/./public/services/markdown.ts","webpack://fider/./public/services/notify.ts","webpack://fider/./public/services/navigator.ts","webpack://fider/./public/services/querystring.ts","webpack://fider/./public/services/device.ts","webpack://fider/./public/services/actions/user.ts","webpack://fider/./public/services/actions/tag.ts","webpack://fider/./public/services/actions/post.ts","webpack://fider/./public/services/actions/tenant.ts","webpack://fider/./public/services/actions/notification.ts","webpack://fider/./public/services/actions/invite.ts","webpack://fider/./public/services/actions/infra.ts","webpack://fider/./public/services/actions/webhook.ts","webpack://fider/./public/services/actions/billing.ts","webpack://fider/./public/services/toastify.tsx"],"sourcesContent":["import \"./HoverInfo.scss\"\n\nimport React from \"react\"\nimport { Icon } from \"./Icon\"\n\nimport IconInformationCircle from \"@fider/assets/images/heroicons-information-circle.svg\"\nimport { classSet } from \"@fider/services\"\n\ninterface InfoProps {\n  text: string\n  onClick?: () => void\n  href?: string\n  target?: \"_self\" | \"_blank\" | \"_parent\" | \"_top\"\n}\n\nexport const HoverInfo = (props: InfoProps) => {\n  const Elem = props.href ? \"a\" : \"span\"\n  const classList = classSet({\n    \"c-hoverinfo\": true,\n    clickable: props.onClick !== undefined,\n  })\n  return (\n    <Elem className={classList} data-tooltip={props.text} onClick={props.onClick} href={props.href} target={props.target}>\n      <Icon width=\"15\" height=\"15\" className=\"c-hoverinfo__icon\" sprite={IconInformationCircle} />\n    </Elem>\n  )\n}\n","import React from \"react\"\n\ninterface IconProps {\n  sprite: SpriteSymbol | string\n  height?: string\n  width?: string\n  className?: string\n  onClick?: () => void\n}\n\nexport const Icon = (props: IconProps) => {\n  if (typeof props.sprite === \"string\") {\n    const styles = { height: props.height && `${props.height}px`, width: props.width && `${props.width}px` }\n    return <img style={styles} height={props.height} width={props.width} className={props.className} src={props.sprite} />\n  }\n\n  return (\n    <svg onClick={props.onClick} height={props.height} width={props.width} className={props.className} viewBox={props.sprite.viewBox}>\n      <use xlinkHref={\"#\" + props.sprite.id} />\n    </svg>\n  )\n}\n","import React from \"react\"\nimport { ErrorPage } from \"@fider/pages/Error/Error.page\"\nimport { FiderContext } from \"@fider/services\"\n\ninterface ErrorBoundaryProps {\n  onError?: (err: Error) => void\n}\n\ninterface ErrorBoundaryState {\n  error?: Error\n  errorInfo?: React.ErrorInfo\n}\n\nexport class ErrorBoundary extends React.Component<ErrorBoundaryProps, ErrorBoundaryState> {\n  constructor(props: any) {\n    super(props)\n\n    this.state = {\n      error: undefined,\n      errorInfo: undefined,\n    }\n  }\n\n  public componentDidCatch(error: Error, errorInfo: React.ErrorInfo) {\n    const onError = this.props.onError\n    if (onError) {\n      onError(error)\n    }\n\n    this.setState({\n      error,\n      errorInfo,\n    })\n  }\n\n  public render() {\n    const { error, errorInfo } = this.state\n\n    if (error && errorInfo) {\n      return <FiderContext.Consumer>{(fider) => <ErrorPage error={error} errorInfo={errorInfo} showDetails={!fider.isProduction()} />}</FiderContext.Consumer>\n    } else {\n      return this.props.children\n    }\n  }\n}\n","import React from \"react\"\nimport { PostResponse, PostStatus } from \"@fider/models\"\nimport { Markdown, UserName, ShowPostStatus } from \"@fider/components\"\nimport { HStack } from \"./layout\"\n\nconst DuplicateDetails = (props: PostResponseProps): JSX.Element | null => {\n  if (!props.response) {\n    return null\n  }\n\n  const original = props.response.original\n  if (!original) {\n    return null\n  }\n\n  return (\n    <div className=\"content\">\n      <span>&#8618;</span>{\" \"}\n      <a className=\"text-link\" href={`/posts/${original.number}/${original.slug}`}>\n        {original.title}\n      </a>\n    </div>\n  )\n}\n\ninterface PostResponseProps {\n  status: string\n  response: PostResponse | null\n}\n\nconst StatusDetails = (props: PostResponseProps): JSX.Element | null => {\n  if (!props.response || !props.response.text) {\n    return null\n  }\n\n  return (\n    <div className=\"content\">\n      <Markdown text={props.response.text} style=\"full\" />\n    </div>\n  )\n}\n\nexport const ShowPostResponse = (props: PostResponseProps): JSX.Element | null => {\n  const status = PostStatus.Get(props.status)\n\n  if (props.response && (status.show || props.response.text)) {\n    return (\n      <div className=\"p-2 shadow rounded\">\n        <HStack>\n          {status.show && <ShowPostStatus status={status} />}\n          <span className=\"text-xs\">\n            &middot; <UserName user={props.response.user} />\n          </span>\n        </HStack>\n        {status === PostStatus.Duplicate ? DuplicateDetails(props) : StatusDetails(props)}\n      </div>\n    )\n  }\n\n  return null\n}\n","import \"./ShowPostStatus.scss\"\n\nimport React from \"react\"\nimport { PostStatus } from \"@fider/models\"\nimport { t } from \"@lingui/macro\"\n\ninterface ShowPostStatusProps {\n  status: PostStatus\n}\n\nexport const ShowPostStatus = (props: ShowPostStatusProps) => {\n  const id = `enum.poststatus.${props.status.value}`\n  const title = t({ id, message: props.status.title })\n  return <span className={`c-status-label c-status-label--${props.status.value}`}>{title}</span>\n}\n","import \"./ShowTag.scss\"\n\nimport React from \"react\"\nimport { Tag } from \"@fider/models\"\nimport { classSet } from \"@fider/services\"\n\ninterface TagProps {\n  tag: Tag\n  circular?: boolean\n  link?: boolean\n}\n\nconst getRGB = (color: string) => {\n  const r = color.substring(0, 2)\n  const g = color.substring(2, 4)\n  const b = color.substring(4, 6)\n\n  return {\n    R: parseInt(r, 16),\n    G: parseInt(g, 16),\n    B: parseInt(b, 16),\n  }\n}\n\nconst textColor = (color: string) => {\n  const components = getRGB(color)\n  const bgDelta = components.R * 0.299 + components.G * 0.587 + components.B * 0.114\n  return bgDelta > 140 ? \"#333\" : \"#fff\"\n}\n\nexport const ShowTag = (props: TagProps) => {\n  const className = classSet({\n    \"c-tag\": true,\n    \"c-tag--circular\": props.circular === true,\n  })\n\n  return (\n    <a\n      href={props.link && props.tag.slug ? `/?tags=${props.tag.slug}` : undefined}\n      title={`${props.tag.name}${props.tag.isPublic ? \"\" : \" (Private)\"}`}\n      className={className}\n      style={{\n        backgroundColor: `#${props.tag.color}`,\n        color: textColor(props.tag.color),\n      }}\n    >\n      {!props.tag.isPublic && !props.circular && (\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"currentColor\">\n          <path\n            fillRule=\"evenodd\"\n            d=\"M5 9V7a5 5 0 0110 0v2a2 2 0 012 2v5a2 2 0 01-2 2H5a2 2 0 01-2-2v-5a2 2 0 012-2zm8-2v2H7V7a3 3 0 016 0z\"\n            clipRule=\"evenodd\"\n          />\n        </svg>\n      )}\n      {props.circular ? \"\" : props.tag.name || \"Tag\"}\n    </a>\n  )\n}\n","import React, { useState } from \"react\"\nimport { SignInModal, TenantLogo, NotificationIndicator, UserMenu } from \"@fider/components\"\nimport { useFider } from \"@fider/hooks\"\nimport { HStack } from \"./layout\"\nimport { Trans } from \"@lingui/macro\"\n\nexport const Header = () => {\n  const fider = useFider()\n  const [isSignInModalOpen, setIsSignInModalOpen] = useState(false)\n\n  const showModal = (e: React.MouseEvent) => {\n    e.preventDefault()\n    setIsSignInModalOpen(true)\n  }\n\n  const hideModal = () => setIsSignInModalOpen(false)\n\n  return (\n    <div id=\"c-header\" className=\"bg-white\">\n      <SignInModal isOpen={isSignInModalOpen} onClose={hideModal} />\n      <HStack className=\"c-menu shadow p-4 w-full\">\n        <div className=\"container\">\n          <HStack justify=\"between\">\n            <a href=\"/\" className=\"flex flex-x flex-items-center flex--spacing-2 h-8\">\n              <TenantLogo size={100} />\n              <h1 className=\"text-header\">{fider.session.tenant.name}</h1>\n            </a>\n            {fider.session.isAuthenticated && (\n              <HStack spacing={2}>\n                <NotificationIndicator />\n                <UserMenu />\n              </HStack>\n            )}\n            {!fider.session.isAuthenticated && (\n              <a href=\"#\" className=\"uppercase text-sm\" onClick={showModal}>\n                <Trans id=\"action.signin\">Sign in</Trans>\n              </a>\n            )}\n          </HStack>\n        </div>\n      </HStack>\n    </div>\n  )\n}\n","import \"./Button.scss\"\n\nimport React, { useEffect, useRef, useState } from \"react\"\nimport { classSet } from \"@fider/services\"\n\ninterface ButtonProps {\n  className?: string\n  disabled?: boolean\n  href?: string\n  rel?: \"nofollow\"\n  target?: \"_self\" | \"_blank\" | \"_parent\" | \"_top\"\n  type?: \"button\" | \"submit\"\n  variant?: \"primary\" | \"danger\" | \"secondary\" | \"tertiary\"\n  size?: \"small\" | \"default\" | \"large\"\n  onClick?: (event: ButtonClickEvent) => Promise<any> | void\n}\n\nexport class ButtonClickEvent {\n  private shouldEnable = true\n  public preventEnable(): void {\n    this.shouldEnable = false\n  }\n  public canEnable(): boolean {\n    return this.shouldEnable\n  }\n}\n\nexport const Button: React.FC<ButtonProps> = (props) => {\n  const [clicked, setClicked] = useState(false)\n  const unmountedContainer = useRef(false)\n\n  useEffect(() => {\n    return () => {\n      unmountedContainer.current = true\n    }\n  }, [])\n\n  const className = classSet({\n    \"c-button\": true,\n    [`c-button--${props.size}`]: props.size,\n    [`c-button--${props.variant}`]: props.variant,\n    \"c-button--loading\": clicked,\n    \"c-button--disabled\": clicked || props.disabled,\n    [props.className || \"\"]: props.className,\n    \"shadow-sm\": props.variant !== \"tertiary\",\n  })\n\n  let buttonContent: JSX.Element\n  const onClickProp = props.onClick\n\n  if (props.href) {\n    buttonContent = (\n      <a href={props.href} rel={props.rel} target={props.target} className={className}>\n        {props.children}\n      </a>\n    )\n  } else if (onClickProp) {\n    const onClick = async (e?: React.SyntheticEvent<HTMLElement>) => {\n      if (e) {\n        e.preventDefault()\n        e.stopPropagation()\n      }\n\n      if (clicked) {\n        return\n      }\n\n      const event = new ButtonClickEvent()\n      setClicked(true)\n\n      await onClickProp(event)\n\n      if (!unmountedContainer.current && event.canEnable()) {\n        setClicked(false)\n      }\n    }\n\n    buttonContent = (\n      <button type={props.type} className={className} onClick={onClick}>\n        {props.children}\n      </button>\n    )\n  } else {\n    buttonContent = (\n      <button type={props.type} className={className}>\n        {props.children}\n      </button>\n    )\n  }\n\n  return buttonContent\n}\n\nButton.defaultProps = {\n  size: \"default\",\n  variant: \"secondary\",\n  type: \"button\",\n}\n","import \"./Form.scss\"\n\nimport React from \"react\"\nimport { Failure, classSet } from \"@fider/services\"\nimport { DisplayError } from \"@fider/components\"\n\ninterface ValidationContext {\n  error?: Failure\n}\n\ninterface FormProps {\n  className?: string\n  error?: Failure\n}\n\nexport const ValidationContext = React.createContext<ValidationContext>({})\n\nexport const Form: React.FunctionComponent<FormProps> = (props) => {\n  const className = classSet({\n    \"c-form\": true,\n    [props.className || \"\"]: props.className,\n  })\n\n  return (\n    <form autoComplete=\"off\" className={className}>\n      <DisplayError error={props.error} />\n      <ValidationContext.Provider value={{ error: props.error }}>{props.children}</ValidationContext.Provider>\n    </form>\n  )\n}\n","import React from \"react\"\nimport { Failure } from \"@fider/services\"\n\nimport \"./DisplayError.scss\"\n\nconst arrayToTag = (items: string[]) => {\n  return items.map((m) => <li key={m}>{m}</li>)\n}\n\ninterface DisplayErrorProps {\n  error?: Failure\n  fields?: string[]\n}\n\nexport const hasError = (field?: string, error?: Failure): boolean => {\n  if (field && error && error.errors) {\n    for (const err of error.errors) {\n      if (err.field === field) {\n        return true\n      }\n    }\n  }\n  return false\n}\n\nexport const DisplayError = (props: DisplayErrorProps) => {\n  if (!props.error || !props.error.errors) {\n    return null\n  }\n\n  const dict = props.error.errors.reduce((result, err) => {\n    result[err.field || \"\"] = result[err.field || \"\"] || []\n    result[err.field || \"\"].push(err.message)\n    return result\n  }, {} as { [key: string]: string[] })\n\n  let items: JSX.Element[] = []\n\n  if (dict[\"\"] && !props.fields) {\n    items = arrayToTag(dict[\"\"])\n  } else if (props.fields) {\n    for (const field of props.fields || Object.keys(dict)) {\n      if (Object.prototype.hasOwnProperty.call(dict, field)) {\n        const tags = arrayToTag(dict[field])\n        tags.forEach((t) => items.push(t))\n      }\n    }\n  }\n\n  return items.length > 0 ? (\n    <div className={`c-form-error`}>\n      <ul>{items}</ul>\n    </div>\n  ) : null\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\nimport { ValidationContext } from \"./Form\"\nimport { DisplayError, hasError } from \"./DisplayError\"\nimport { Icon } from \"@fider/components\"\n\nimport \"./Input.scss\"\nimport { HStack } from \"@fider/components/layout\"\n\ninterface InputProps {\n  field: string\n  label?: string\n  className?: string\n  autoComplete?: string\n  autoFocus?: boolean\n  noTabFocus?: boolean\n  afterLabel?: JSX.Element\n  icon?: SpriteSymbol\n  maxLength?: number\n  value?: string\n  disabled?: boolean\n  suffix?: string | JSX.Element\n  placeholder?: string\n  onIconClick?: () => void\n  onFocus?: () => void\n  inputRef?: React.MutableRefObject<any>\n  onChange?: (value: string) => void\n}\n\nexport const Input: React.FunctionComponent<InputProps> = (props) => {\n  const onChange = (e: React.FormEvent<HTMLInputElement>) => {\n    if (props.onChange) {\n      props.onChange(e.currentTarget.value)\n    }\n  }\n\n  const suffix = typeof props.suffix === \"string\" ? <span className=\"c-input__suffix\">{props.suffix}</span> : props.suffix\n\n  const icon = props.icon ? <Icon sprite={props.icon} onClick={props.onIconClick} className={classSet({ clickable: !!props.onIconClick })} /> : undefined\n\n  return (\n    <ValidationContext.Consumer>\n      {(ctx) => (\n        <div\n          className={classSet({\n            \"c-form-field\": true,\n            [`${props.className}`]: props.className,\n          })}\n        >\n          {!!props.label && (\n            <label htmlFor={`input-${props.field}`}>\n              {props.label}\n              {props.afterLabel}\n            </label>\n          )}\n          <HStack spacing={0} center={!!props.icon} className=\"relative\">\n            <input\n              className={classSet({\n                \"c-input\": true,\n                \"c-input--icon\": !!props.icon,\n                \"c-input--error\": hasError(props.field, ctx.error),\n                \"c-input--suffixed\": !!suffix,\n              })}\n              id={`input-${props.field}`}\n              type=\"text\"\n              autoComplete={props.autoComplete}\n              tabIndex={props.noTabFocus ? -1 : undefined}\n              ref={props.inputRef}\n              autoFocus={props.autoFocus}\n              onFocus={props.onFocus}\n              maxLength={props.maxLength}\n              disabled={props.disabled}\n              value={props.value}\n              placeholder={props.placeholder}\n              onChange={onChange}\n            />\n            {icon}\n            {suffix}\n          </HStack>\n          <DisplayError fields={[props.field]} error={ctx.error} />\n          {props.children}\n        </div>\n      )}\n    </ValidationContext.Consumer>\n  )\n}\n","import \"./ImageUploader.scss\"\n\nimport React from \"react\"\nimport { ValidationContext } from \"./Form\"\nimport { DisplayError, hasError } from \"./DisplayError\"\nimport { classSet, fileToBase64, uploadedImageURL } from \"@fider/services\"\nimport { Button, Icon, Modal } from \"@fider/components\"\nimport { ImageUpload } from \"@fider/models\"\nimport IconPhotograph from \"@fider/assets/images/heroicons-photograph.svg\"\n\nconst hardFileSizeLimit = 5 * 1024 * 1024\n\ninterface ImageUploaderProps {\n  instanceID?: string\n  field: string\n  label?: string\n  bkey?: string\n  disabled?: boolean\n  onChange(state: ImageUpload, instanceID?: string, previewURL?: string): void\n}\n\ninterface ImageUploaderState extends ImageUpload {\n  previewURL?: string\n  showModal: boolean\n}\n\nexport class ImageUploader extends React.Component<ImageUploaderProps, ImageUploaderState> {\n  private fileSelector?: HTMLInputElement | null\n\n  constructor(props: ImageUploaderProps) {\n    super(props)\n    this.state = {\n      upload: undefined,\n      remove: false,\n      showModal: false,\n      previewURL: uploadedImageURL(this.props.bkey),\n    }\n  }\n\n  public fileChanged = async (e: React.ChangeEvent<HTMLInputElement>) => {\n    if (e.target.files && e.target.files[0]) {\n      const file = e.target.files[0]\n      if (file.size > hardFileSizeLimit) {\n        alert(\"The image size must be smaller than 5MB.\")\n        return\n      }\n\n      const base64 = await fileToBase64(file)\n      this.setState(\n        {\n          bkey: this.props.bkey,\n          upload: {\n            fileName: file.name,\n            content: base64,\n            contentType: file.type,\n          },\n          remove: false,\n          previewURL: `data:${file.type};base64,${base64}`,\n        },\n        () => {\n          this.props.onChange(this.state, this.props.instanceID, this.state.previewURL)\n        }\n      )\n    }\n  }\n\n  public removeFile = async () => {\n    if (this.fileSelector) {\n      this.fileSelector.value = \"\"\n    }\n\n    this.setState(\n      {\n        bkey: this.props.bkey,\n        remove: true,\n        upload: undefined,\n        previewURL: undefined,\n      },\n      () => {\n        this.props.onChange(\n          {\n            bkey: this.state.bkey,\n            remove: this.state.remove,\n            upload: this.state.upload,\n          },\n          this.props.instanceID,\n          this.state.previewURL\n        )\n      }\n    )\n  }\n\n  public selectFile = async () => {\n    if (this.fileSelector) {\n      this.fileSelector.click()\n    }\n  }\n\n  private openModal = () => {\n    this.setState({ showModal: true })\n  }\n\n  private closeModal = async () => {\n    this.setState({ showModal: false })\n  }\n\n  private modal() {\n    return (\n      <Modal.Window className=\"c-image-viewer-modal\" isOpen={this.state.showModal} onClose={this.closeModal} center={false} size=\"fluid\">\n        <Modal.Content>{this.props.bkey ? <img alt=\"\" src={uploadedImageURL(this.props.bkey)} /> : <img alt=\"\" src={this.state.previewURL} />}</Modal.Content>\n\n        <Modal.Footer>\n          <Button variant=\"tertiary\" onClick={this.closeModal}>\n            Close\n          </Button>\n        </Modal.Footer>\n      </Modal.Window>\n    )\n  }\n\n  public render() {\n    const isUploading = !!this.state.upload\n    const hasFile = (!this.state.remove && this.props.bkey) || isUploading\n\n    return (\n      <ValidationContext.Consumer>\n        {(ctx) => (\n          <div\n            className={classSet({\n              \"c-form-field\": true,\n              \"c-image-upload\": true,\n              \"m-error\": hasError(this.props.field, ctx.error),\n            })}\n          >\n            {this.modal()}\n            {this.props.label && <label htmlFor={`input-${this.props.field}`}>{this.props.label}</label>}\n\n            {hasFile && (\n              <div className=\"preview h-20\">\n                <img alt=\"\" onClick={this.openModal} src={this.state.previewURL} />\n                {!this.props.disabled && (\n                  <Button onClick={this.removeFile} variant=\"danger\">\n                    X\n                  </Button>\n                )}\n              </div>\n            )}\n\n            <input ref={(e) => (this.fileSelector = e)} type=\"file\" onChange={this.fileChanged} accept=\"image/*\" />\n            {!hasFile && (\n              <Button onClick={this.selectFile} disabled={this.props.disabled}>\n                <Icon sprite={IconPhotograph} />\n              </Button>\n            )}\n            <DisplayError fields={[this.props.field]} error={ctx.error} />\n            {this.props.children}\n          </div>\n        )}\n      </ValidationContext.Consumer>\n    )\n  }\n}\n","import React from \"react\"\nimport { ImageUploader } from \"./ImageUploader\"\nimport { ImageUpload } from \"@fider/models\"\nimport { ValidationContext, hasError, DisplayError } from \"@fider/components\"\nimport { classSet } from \"@fider/services\"\n\nimport \"./MultiImageUploader.scss\"\n\ninterface MultiImageUploaderProps {\n  field: string\n  maxUploads: number\n  bkeys?: string[]\n  onChange?: (uploads: ImageUpload[]) => void\n}\n\ninterface MultiImageUploaderInstances {\n  [key: string]: {\n    element: JSX.Element\n    upload?: ImageUpload\n  }\n}\n\ninterface MultiImageUploaderState {\n  count: number\n  instances: MultiImageUploaderInstances\n  removed: ImageUpload[]\n}\n\nexport class MultiImageUploader extends React.Component<MultiImageUploaderProps, MultiImageUploaderState> {\n  constructor(props: MultiImageUploaderProps) {\n    super(props)\n\n    let count = 1\n    const instances = {}\n    if (props.bkeys) {\n      for (const bkey of props.bkeys) {\n        count++\n        this.addNewElement(instances, bkey)\n      }\n    }\n\n    if (count <= this.props.maxUploads) {\n      count++\n      this.addNewElement(instances)\n    }\n\n    this.state = { instances, count, removed: [] }\n  }\n\n  private imageUploaded = (upload: ImageUpload, instanceID: string) => {\n    const instances = { ...this.state.instances }\n    const removed = [...this.state.removed]\n    let count = this.state.count\n    if (upload.remove) {\n      if (upload.bkey) {\n        removed.push(upload)\n      }\n      delete instances[instanceID]\n      if (--count === this.props.maxUploads) {\n        this.addNewElement(instances)\n      }\n    } else {\n      instances[instanceID].upload = upload\n      if (count++ <= this.props.maxUploads) {\n        this.addNewElement(instances)\n      }\n    }\n    this.setState({ instances, count, removed }, this.triggerOnChange)\n  }\n\n  private triggerOnChange() {\n    if (this.props.onChange) {\n      const uploads = Object.keys(this.state.instances)\n        .map((k) => this.state.instances[k].upload)\n        .concat(this.state.removed)\n        .filter((x) => !!x) as ImageUpload[]\n      this.props.onChange(uploads)\n    }\n  }\n\n  private addNewElement(instances: MultiImageUploaderInstances, bkey?: string) {\n    const id = btoa(Math.random().toString())\n    instances[id] = {\n      element: <ImageUploader key={id} bkey={bkey} instanceID={id} field=\"attachment\" onChange={this.imageUploaded} />,\n    }\n  }\n\n  public render() {\n    const elements = Object.keys(this.state.instances).map((k) => this.state.instances[k].element)\n    return (\n      <ValidationContext.Consumer>\n        {(ctx) => (\n          <div\n            className={classSet({\n              \"c-form-field\": true,\n              \"c-multi-image-uploader\": true,\n              \"m-error\": hasError(this.props.field, ctx.error),\n            })}\n          >\n            <div className=\"c-multi-image-uploader-instances\">{elements}</div>\n            <DisplayError fields={[this.props.field]} error={ctx.error} />\n          </div>\n        )}\n      </ValidationContext.Consumer>\n    )\n  }\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\nimport { ValidationContext } from \"../\"\nimport { DisplayError, hasError } from \"./DisplayError\"\nimport Textarea from \"react-textarea-autosize\"\n\nimport \"./TextArea.scss\"\n\ninterface TextAreaProps {\n  label?: string\n  field: string\n  value?: string\n  disabled?: boolean\n  minRows?: number\n  placeholder?: string\n  afterLabel?: JSX.Element\n  onChange?: (value: string) => void\n  inputRef?: React.MutableRefObject<any>\n  onFocus?: React.FocusEventHandler<HTMLTextAreaElement>\n  className?: string\n}\n\nexport const TextArea: React.FunctionComponent<TextAreaProps> = (props) => {\n  const onChange = (e: React.FormEvent<HTMLTextAreaElement>) => {\n    if (props.onChange) {\n      props.onChange(e.currentTarget.value)\n    }\n  }\n\n  return (\n    <ValidationContext.Consumer>\n      {(ctx) => (\n        <>\n          <div className=\"c-form-field\">\n            {!!props.label && (\n              <label htmlFor={`input-${props.field}`}>\n                {props.label}\n                {props.afterLabel}\n              </label>\n            )}\n            <Textarea\n              className={classSet({\n                \"c-textarea\": true,\n                \"c-textarea--error\": hasError(props.field, ctx.error),\n                [props.className || \"\"]: props.className,\n              })}\n              id={`input-${props.field}`}\n              disabled={props.disabled}\n              onChange={onChange}\n              value={props.value}\n              minRows={props.minRows || 3}\n              placeholder={props.placeholder}\n              ref={props.inputRef}\n              onFocus={props.onFocus}\n            />\n            <DisplayError fields={[props.field]} error={ctx.error} />\n            {props.children}\n          </div>\n        </>\n      )}\n    </ValidationContext.Consumer>\n  )\n}\n","import { HStack, VStack } from \"@fider/components/layout\"\nimport React, { useState } from \"react\"\n\nimport \"./RadioButton.scss\"\n\ninterface RadioButtonOption {\n  value: string\n  label: string\n}\n\ninterface RadioButtonProps {\n  label: string\n  field: string\n  defaultOption: RadioButtonOption\n  options: RadioButtonOption[]\n  onSelect?: (value: RadioButtonOption) => void\n}\n\nexport const RadioButton = (props: RadioButtonProps) => {\n  const [selected, setSelected] = useState(props.defaultOption)\n\n  const onChange = (option: RadioButtonOption) => () => {\n    setSelected(option)\n    props.onSelect?.(option)\n  }\n\n  const inputs = props.options.map((option) => (\n    <HStack key={option.value} className=\"text-sm\">\n      <input id={`visibility-${option.value}`} type=\"radio\" name={`input-${props.field}`} checked={selected === option} onChange={onChange(option)} />\n      <label htmlFor={`visibility-${option.value}`}>{option.label}</label>\n    </HStack>\n  ))\n\n  return (\n    <div className=\"c-form-field\">\n      <label htmlFor={`input-${props.field}`}>{props.label}</label>\n      <VStack className=\"c-radiobutton\">{inputs}</VStack>\n    </div>\n  )\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\nimport { ValidationContext } from \"./Form\"\nimport { DisplayError, hasError } from \"./DisplayError\"\n\nimport \"./Select.scss\"\n\nexport interface SelectOption {\n  value: string\n  label: string\n}\n\ninterface SelectProps {\n  field: string\n  label?: string\n  maxLength?: number\n  defaultValue?: string\n  options: SelectOption[]\n  onChange?: (option?: SelectOption) => void\n}\n\nexport const Select: React.FunctionComponent<SelectProps> = (props) => {\n  const getOption = (value?: string) => {\n    if (value && props.options) {\n      const filtered = props.options.filter((x) => x.value === value)\n      if (filtered && filtered.length > 0) {\n        return filtered[0]\n      }\n    }\n  }\n  const [selected, setSelected] = React.useState<SelectOption | undefined>(getOption(props.defaultValue))\n  const onChange = (e: React.FormEvent<HTMLSelectElement>) => {\n    let selected: SelectOption | undefined\n    if (e.currentTarget.value) {\n      const options = props.options.filter((o) => o.value === e.currentTarget.value)\n      if (options && options.length > 0) {\n        selected = options[0]\n      }\n    }\n\n    setSelected(selected)\n    if (props.onChange) {\n      props.onChange(selected)\n    }\n  }\n\n  return (\n    <ValidationContext.Consumer>\n      {(ctx) => (\n        <>\n          <div className=\"c-form-field\">\n            {!!props.label && <label htmlFor={`input-${props.field}`}>{props.label}</label>}\n            <select\n              className={classSet({\n                \"c-select\": true,\n                \"c-select--error\": hasError(props.field, ctx.error),\n              })}\n              value={selected?.value}\n              id={`input-${props.field}`}\n              defaultValue={props.defaultValue}\n              onChange={onChange}\n            >\n              {props.options.map((option) => (\n                <option key={option.value} value={option.value}>\n                  {option.label}\n                </option>\n              ))}\n            </select>\n            <DisplayError fields={[props.field]} error={ctx.error} />\n            {props.children}\n          </div>\n        </>\n      )}\n    </ValidationContext.Consumer>\n  )\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\nimport { ValidationContext } from \"./Form\"\nimport { DisplayError, hasError } from \"./DisplayError\"\n\ninterface FieldProps {\n  className?: string\n  label?: string\n  field?: string\n  afterLabel?: JSX.Element\n}\n\nexport const Field: React.FunctionComponent<FieldProps> = (props) => {\n  const fields = props.field ? [props.field] : undefined\n  return (\n    <ValidationContext.Consumer>\n      {(ctx) => (\n        <div\n          className={classSet({\n            \"c-form-field\": true,\n            \"m-error\": hasError(props.field, ctx.error),\n            [props.className || \"\"]: props.className,\n          })}\n        >\n          {!!props.label && (\n            <label>\n              {props.label}\n              {props.afterLabel}\n            </label>\n          )}\n          {props.children}\n          <DisplayError fields={fields} error={ctx.error} />\n        </div>\n      )}\n    </ValidationContext.Consumer>\n  )\n}\n","import React, { useState } from \"react\"\nimport { classSet } from \"@fider/services\"\nimport { DisplayError, ValidationContext, hasError } from \"../\"\nimport { HStack } from \"@fider/components/layout\"\n\nimport \"./Checkbox.scss\"\n\ninterface CheckboxProps {\n  field: string\n  checked?: boolean\n  onChange?: (checked: boolean) => void\n}\n\nexport const Checkbox: React.FC<CheckboxProps> = (props) => {\n  const [checked, setChecked] = useState<boolean>(props.checked || false)\n\n  const onChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    const isChecked: boolean = e.currentTarget.checked\n\n    setChecked(isChecked)\n    if (props.onChange) {\n      props.onChange(isChecked)\n    }\n  }\n\n  return (\n    <ValidationContext.Consumer>\n      {(ctx) => (\n        <div\n          className={classSet({\n            \"c-form-field\": true,\n            \"m-error\": hasError(props.field, ctx.error),\n          })}\n        >\n          <div className=\"c-checkbox\">\n            <HStack>\n              <input id={`input-${props.field}`} type=\"checkbox\" checked={checked} onChange={onChange} />\n              <label htmlFor={`input-${props.field}`} className=\"text-sm\">\n                {props.children}\n              </label>\n            </HStack>\n            <DisplayError fields={[props.field]} error={ctx.error} />\n          </div>\n        </div>\n      )}\n    </ValidationContext.Consumer>\n  )\n}\n","import React, { useState } from \"react\"\nimport { uploadedImageURL } from \"@fider/services\"\nimport { Modal, Button, Loader } from \"@fider/components\"\n\nimport \"./ImageViewer.scss\"\nimport { Trans } from \"@lingui/macro\"\n\ninterface ImageViewerModalProps {\n  isOpen: boolean\n  imgSrc: string | undefined\n  loadedPreview: boolean\n  onPreviewLoad: () => void\n  onClose: () => void\n}\n\nconst ImageViewerModal = (props: ImageViewerModalProps) => (\n  <Modal.Window className=\"c-image-viewer-modal\" isOpen={props.isOpen} onClose={props.onClose} center={false} size=\"fluid\">\n    <Modal.Content>\n      {!props.loadedPreview && <Loader />}\n      <img alt=\"\" onLoad={props.onPreviewLoad} src={props.imgSrc} />\n    </Modal.Content>\n\n    <Modal.Footer>\n      <Button variant=\"tertiary\" onClick={props.onClose}>\n        <Trans id=\"action.close\">Close</Trans>\n      </Button>\n    </Modal.Footer>\n  </Modal.Window>\n)\n\ninterface ImageViewerProps {\n  bkey: string\n}\n\nexport const ImageViewer = (props: ImageViewerProps) => {\n  const [showModal, setShowModal] = useState(false)\n  const [loadedThumbnail, setLoadedThumbnail] = useState(false)\n  const [loadedPreview, setLoadedPreview] = useState(false)\n\n  const openModal = () => {\n    if (loadedThumbnail) {\n      setShowModal(true)\n    }\n  }\n\n  const closeModal = () => {\n    setShowModal(false)\n  }\n\n  const onThumbnailLoad = () => {\n    setLoadedThumbnail(true)\n  }\n\n  const onPreviewLoad = () => {\n    setLoadedPreview(true)\n  }\n\n  return (\n    <div className=\"c-image-viewer\">\n      <ImageViewerModal\n        onPreviewLoad={onPreviewLoad}\n        isOpen={showModal}\n        onClose={closeModal}\n        imgSrc={uploadedImageURL(props.bkey, 1500)}\n        loadedPreview={loadedPreview}\n      />\n      {!loadedThumbnail && <Loader />}\n      <img alt=\"\" onClick={openModal} onLoad={onThumbnailLoad} src={uploadedImageURL(props.bkey, 200)} />\n    </div>\n  )\n}\n","import React from \"react\"\nimport { markdown, truncate } from \"@fider/services\"\n\nimport \"./Markdown.scss\"\n\ninterface MarkdownProps {\n  className?: string\n  text?: string\n  maxLength?: number\n  style: \"full\" | \"plainText\"\n}\n\nexport const Markdown = (props: MarkdownProps) => {\n  if (!props.text) {\n    return null\n  }\n\n  const html = markdown[props.style](props.text)\n  const className = `c-markdown ${props.className || \"\"}`\n  const tagName = props.style === \"plainText\" ? \"p\" : \"div\"\n\n  return React.createElement(tagName, {\n    className,\n    dangerouslySetInnerHTML: { __html: props.maxLength ? truncate(html, props.maxLength) : html },\n  })\n}\n","import React from \"react\"\nimport { useFider } from \"@fider/hooks\"\n\nimport \"./DevBanner.scss\"\n\nexport const DevBanner = () => {\n  const fider = useFider()\n\n  if (fider.isProduction()) {\n    return null\n  }\n\n  return <div className=\"c-dev-banner\">DEV</div>\n}\n","import \"./Avatar.scss\"\n\nimport React from \"react\"\nimport { UserRole } from \"@fider/models\"\n\ninterface AvatarProps {\n  user: {\n    role?: UserRole\n    avatarURL: string\n    name: string\n  }\n  size?: \"small\" | \"normal\"\n}\n\nexport const Avatar = (props: AvatarProps) => {\n  const size = props.size === \"small\" ? \"h-6 w-6\" : \"h-8 w-8\"\n  return <img className={`c-avatar ${size}`} alt={props.user.name} src={`${props.user.avatarURL}?size=50`} />\n}\n","import \"./AvatarStack.scss\"\n\nimport React from \"react\"\nimport { UserRole } from \"@fider/models\"\nimport { Avatar } from \"./Avatar\"\n\ninterface AvatarStackProps {\n  users: Array<{\n    role?: UserRole\n    avatarURL: string\n    name: string\n  }>\n}\n\nexport const AvatarStack = (props: AvatarStackProps) => {\n  return (\n    <div className=\"c-avatar-stack\">\n      {props.users.map((x, i) => (\n        <Avatar key={i} user={x} />\n      ))}\n    </div>\n  )\n}\n","import \"./Message.scss\"\n\nimport React from \"react\"\nimport { classSet } from \"@fider/services\"\nimport IconCheckCircle from \"@fider/assets/images/heroicons-check-circle.svg\"\nimport IconExclamationCircle from \"@fider/assets/images/heroicons-exclamation-circle.svg\"\nimport IconExclamation from \"@fider/assets/images/heroicons-exclamation.svg\"\nimport { HStack } from \"@fider/components/layout\"\nimport { Icon } from \"./Icon\"\n\ninterface MessageProps {\n  type: \"success\" | \"warning\" | \"error\"\n  className?: string\n  alignment?: \"center\"\n  showIcon?: boolean\n}\n\nexport const Message: React.FunctionComponent<MessageProps> = (props) => {\n  const className = classSet({\n    \"c-message\": true,\n    [`c-message--${props.type}`]: true,\n    [`c-message--icon`]: props.showIcon === true,\n    [`${props.className}`]: props.className,\n  })\n\n  const icon = props.type === \"error\" ? IconExclamation : props.type === \"warning\" ? IconExclamationCircle : IconCheckCircle\n\n  return (\n    <HStack className={className} spacing={2} justify={props.alignment}>\n      {props.showIcon === true && <Icon className=\"h-5\" sprite={icon} />}\n      <span>{props.children}</span>\n    </HStack>\n  )\n}\n","import \"./Hint.scss\"\n\nimport React, { useState } from \"react\"\nimport IconX from \"@fider/assets/images/heroicons-x.svg\"\nimport { HStack } from \"@fider/components/layout\"\nimport { cache } from \"@fider/services\"\nimport { Icon } from \"./Icon\"\n\ninterface HintProps {\n  permanentCloseKey?: string\n  condition?: boolean\n}\n\nexport const Hint: React.FC<HintProps> = (props) => {\n  const cacheKey: string | undefined = props.permanentCloseKey ? `Hint-Closed-${props.permanentCloseKey}` : undefined\n  const [isClosed, setIsClosed] = useState<boolean>(cacheKey ? cache.local.has(cacheKey) : false)\n\n  const close = () => {\n    if (cacheKey) {\n      cache.local.set(cacheKey, \"true\")\n    }\n    setIsClosed(true)\n  }\n\n  if (props.condition === false || isClosed) {\n    return null\n  }\n\n  return (\n    <HStack className=\"c-hint\" justify=\"between\" spacing={2}>\n      <span>{props.children}</span>\n      {cacheKey && <Icon sprite={IconX} onClick={close} className=\"c-hint__close h-5\" />}\n    </HStack>\n  )\n}\n","import React from \"react\"\nimport { Modal, Checkbox } from \"@fider/components\"\nimport { useFider } from \"@fider/hooks\"\nimport { Trans } from \"@lingui/macro\"\n\ninterface LegalAgreementProps {\n  onChange: (agreed: boolean) => void\n}\n\nexport const TermsOfService = () => {\n  const fider = useFider()\n\n  if (fider.settings.hasLegal) {\n    return (\n      <a href=\"/terms\" className=\"text-link\" target=\"_blank\">\n        <Trans id=\"legal.termsofservice\">Terms of Service</Trans>\n      </a>\n    )\n  }\n  return null\n}\n\nexport const PrivacyPolicy = () => {\n  const fider = useFider()\n\n  if (fider.settings.hasLegal) {\n    return (\n      <a href=\"/privacy\" className=\"text-link\" target=\"_blank\">\n        <Trans id=\"legal.privacypolicy\">Privacy Policy</Trans>\n      </a>\n    )\n  }\n  return null\n}\n\nexport const LegalNotice = () => {\n  const fider = useFider()\n\n  if (fider.settings.hasLegal) {\n    return (\n      <p className=\"text-muted\">\n        <Trans id=\"legal.notice\">\n          By signing in, you agree to the <PrivacyPolicy /> and <TermsOfService />.\n        </Trans>\n      </p>\n    )\n  }\n  return null\n}\n\nexport const LegalFooter = () => {\n  const fider = useFider()\n\n  if (fider.settings.hasLegal) {\n    return (\n      <Modal.Footer align=\"center\">\n        <LegalNotice />\n      </Modal.Footer>\n    )\n  }\n  return null\n}\n\nexport const LegalAgreement: React.FunctionComponent<LegalAgreementProps> = (props) => {\n  const fider = useFider()\n\n  if (fider.settings.hasLegal) {\n    return (\n      <Checkbox field=\"legalAgreement\" onChange={props.onChange}>\n        <Trans id=\"legal.agreement\">\n          I have read and agree to the <PrivacyPolicy /> and <TermsOfService />.\n        </Trans>\n      </Checkbox>\n    )\n  }\n  return null\n}\n","import React from \"react\"\nimport { Button, OAuthProviderLogo } from \"@fider/components\"\n\ninterface SocialSignInButtonProps {\n  option: {\n    displayName: string\n    provider?: string\n    url?: string\n    logoBlobKey?: string\n    logoURL?: string\n  }\n  className?: string\n  redirectTo?: string\n}\n\nexport const SocialSignInButton = (props: SocialSignInButtonProps) => {\n  const redirectTo = props.redirectTo || window.location.href\n  const href = props.option.url ? `${props.option.url}?redirect=${redirectTo}` : undefined\n\n  return (\n    <Button href={href} rel=\"nofollow\" className={props.className}>\n      {props.option.logoURL ? <img alt={props.option.displayName} src={props.option.logoURL} /> : <OAuthProviderLogo option={props.option} />}\n      <span>{props.option.displayName}</span>\n    </Button>\n  )\n}\n","import \"./SignInControl.scss\"\n\nimport React, { useState } from \"react\"\nimport { SocialSignInButton, Form, Button, Input, Message } from \"@fider/components\"\nimport { Divider } from \"@fider/components/layout\"\nimport { device, actions, Failure, isCookieEnabled } from \"@fider/services\"\nimport { useFider } from \"@fider/hooks\"\nimport { Trans } from \"@lingui/macro\"\n\ninterface SignInControlProps {\n  useEmail: boolean\n  redirectTo?: string\n  onEmailSent?: (email: string) => void\n}\n\nexport const SignInControl: React.FunctionComponent<SignInControlProps> = (props) => {\n  const fider = useFider()\n  const [showEmailForm, setShowEmailForm] = useState(fider.session.tenant ? fider.session.tenant.isEmailAuthAllowed : true)\n  const [email, setEmail] = useState(\"\")\n  const [error, setError] = useState<Failure | undefined>(undefined)\n\n  const forceShowEmailForm = (e: React.MouseEvent<HTMLAnchorElement>) => {\n    e.preventDefault()\n    setShowEmailForm(true)\n  }\n\n  const signIn = async () => {\n    const result = await actions.signIn(email)\n    if (result.ok) {\n      setEmail(\"\")\n      setError(undefined)\n      if (props.onEmailSent) {\n        props.onEmailSent(email)\n      }\n    } else if (result.error) {\n      setError(result.error)\n    }\n  }\n\n  const providersLen = fider.settings.oauth.length\n\n  if (!isCookieEnabled()) {\n    return (\n      <Message type=\"error\">\n        <h3 className=\"text-display\">Cookies Required</h3>\n        <p>Cookies are not enabled on your browser. Please enable cookies in your browser preferences to continue.</p>\n      </Message>\n    )\n  }\n\n  return (\n    <div className=\"c-signin-control\">\n      {providersLen > 0 && (\n        <>\n          <div className=\"c-signin-control__oauth mb-2\">\n            {fider.settings.oauth.map((o) => (\n              <React.Fragment key={o.provider}>\n                <SocialSignInButton option={o} redirectTo={props.redirectTo} />\n              </React.Fragment>\n            ))}\n          </div>\n          {props.useEmail && <Divider />}\n        </>\n      )}\n\n      {props.useEmail &&\n        (showEmailForm ? (\n          <div>\n            <p>\n              <Trans id=\"signin.message.email\">Enter your email address to sign in</Trans>\n            </p>\n            <Form error={error}>\n              <Input\n                field=\"email\"\n                value={email}\n                autoFocus={!device.isTouch()}\n                onChange={setEmail}\n                placeholder=\"yourname@example.com\"\n                suffix={\n                  <Button type=\"submit\" variant=\"primary\" disabled={email === \"\"} onClick={signIn}>\n                    <Trans id=\"action.signin\">Sign in</Trans>\n                  </Button>\n                }\n              />\n            </Form>\n            {!fider.session.tenant.isEmailAuthAllowed && (\n              <p className=\"text-red-700 mt-1\">\n                <Trans id=\"signin.message.onlyadmins\">Currently only allowed to sign in to an administrator account</Trans>\n              </p>\n            )}\n          </div>\n        ) : (\n          <div>\n            <p className=\"text-muted\">\n              <Trans id=\"signin.message.emaildisabled\">\n                Email authentication has been disabled by an administrator. If you have an administrator account and need to bypass this restriction, please{\" \"}\n                <a href=\"#\" className=\"text-bold\" onClick={forceShowEmailForm}>\n                  click here\n                </a>\n                .\n              </Trans>\n            </p>\n          </div>\n        ))}\n    </div>\n  )\n}\n","import React from \"react\"\nimport { formatDate, timeSince } from \"@fider/services\"\n\ninterface MomentText {\n  locale: string\n  date: Date | string\n  format?: \"relative\" | \"full\" | \"short\" | \"date\"\n}\n\nexport const Moment = (props: MomentText) => {\n  if (!props.date) {\n    return <span />\n  }\n\n  const format = props.format || \"relative\"\n\n  const now = new Date()\n  const date = props.date instanceof Date ? props.date : new Date(props.date)\n  const diff = (now.getTime() - date.getTime()) / (60 * 60 * 24 * 1000)\n  const display =\n    diff >= 365 && format === \"relative\"\n      ? formatDate(props.locale, props.date, \"short\")\n      : format === \"relative\"\n      ? timeSince(props.locale, now, date)\n      : format === \"date\"\n      ? formatDate(props.locale, props.date, \"date\")\n      : formatDate(props.locale, props.date, format)\n\n  const tooltip = props.format === \"short\" ? formatDate(props.locale, props.date, \"full\") : undefined\n\n  return (\n    <span className=\"date\" data-tooltip={tooltip}>\n      {display}\n    </span>\n  )\n}\n","import \"./Modal.scss\"\n\nimport React, { useEffect, useRef } from \"react\"\nimport ReactDOM from \"react-dom\"\nimport { classSet } from \"@fider/services\"\n\ninterface ModalWindowProps {\n  className?: string\n  isOpen: boolean\n  size?: \"small\" | \"large\" | \"fluid\"\n  canClose?: boolean\n  center?: boolean\n  onClose: () => void\n}\n\ninterface ModalFooterProps {\n  align?: \"left\" | \"center\" | \"right\"\n  children?: React.ReactNode\n}\n\nconst ModalWindow: React.FunctionComponent<ModalWindowProps> = (props) => {\n  const root = useRef<HTMLElement>(document.getElementById(\"root-modal\"))\n\n  useEffect(() => {\n    if (props.isOpen) {\n      document.body.style.overflow = \"hidden\"\n      document.addEventListener(\"keydown\", keyDown, false)\n    } else {\n      document.body.style.overflow = \"\"\n      document.removeEventListener(\"keydown\", keyDown, false)\n    }\n  }, [props.isOpen])\n\n  const swallow = (evt: React.MouseEvent<HTMLDivElement>) => {\n    evt.stopPropagation()\n  }\n\n  const keyDown = (event: KeyboardEvent) => {\n    if (event.keyCode === 27) {\n      // ESC\n      close()\n    }\n  }\n\n  const close = () => {\n    if (props.canClose) {\n      props.onClose()\n    }\n  }\n\n  if (!props.isOpen || !root.current) {\n    return null\n  }\n\n  const className = classSet({\n    \"c-modal-window\": true,\n    [`${props.className}`]: !!props.className,\n    \"c-modal-window--center\": props.center,\n    [`c-modal-window--${props.size}`]: true,\n  })\n\n  return ReactDOM.createPortal(\n    <div aria-disabled={true} className=\"c-modal-dimmer\" onClick={close}>\n      <div className=\"c-modal-scroller\">\n        <div className={className} data-testid=\"modal\" onClick={swallow}>\n          {props.children}\n        </div>\n      </div>\n    </div>,\n    root.current\n  )\n}\n\nModalWindow.defaultProps = {\n  size: \"small\",\n  canClose: true,\n  center: true,\n}\n\nconst Header = (props: { children: React.ReactNode }) => <div className=\"c-modal-header\">{props.children}</div>\nconst Content = (props: { children: React.ReactNode }) => <div className=\"c-modal-content\">{props.children}</div>\nconst Footer = (props: ModalFooterProps) => {\n  const align = props.align || \"right\"\n  const className = classSet({\n    \"c-modal-footer\": true,\n    [`c-modal-footer--${align}`]: true,\n  })\n  return <div className={className}>{props.children}</div>\n}\n\nexport const Modal = {\n  Window: ModalWindow,\n  Header,\n  Content,\n  Footer,\n}\n","import \"./UserName.scss\"\n\nimport React from \"react\"\nimport { isCollaborator, UserRole } from \"@fider/models\"\nimport { classSet } from \"@fider/services\"\n\ninterface UserNameProps {\n  user: {\n    id: number\n    name: string\n    role?: UserRole\n    email?: string\n  }\n  showEmail?: boolean\n}\n\nexport const UserName = (props: UserNameProps) => {\n  const isStaff = props.user.role && isCollaborator(props.user.role)\n  const className = classSet({\n    \"c-username\": true,\n    \"c-username--staff\": isStaff,\n  })\n\n  return (\n    <div className={className}>\n      <span>{props.user.name || \"Anonymous\"}</span>\n      <>{props.showEmail && props.user.email && <span className=\"c-username--email\">({props.user.email})</span>}</>\n\n      {isStaff && (\n        <div data-tooltip={isStaff ? \"Staff\" : undefined}>\n          <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"currentColor\">\n            <path\n              fillRule=\"evenodd\"\n              d=\"M6.267 3.455a3.066 3.066 0 001.745-.723 3.066 3.066 0 013.976 0 3.066 3.066 0 001.745.723 3.066 3.066 0 012.812 2.812c.051.643.304 1.254.723 1.745a3.066 3.066 0 010 3.976 3.066 3.066 0 00-.723 1.745 3.066 3.066 0 01-2.812 2.812 3.066 3.066 0 00-1.745.723 3.066 3.066 0 01-3.976 0 3.066 3.066 0 00-1.745-.723 3.066 3.066 0 01-2.812-2.812 3.066 3.066 0 00-.723-1.745 3.066 3.066 0 010-3.976 3.066 3.066 0 00.723-1.745 3.066 3.066 0 012.812-2.812zm7.44 5.252a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z\"\n              clipRule=\"evenodd\"\n            ></path>\n          </svg>\n        </div>\n      )}\n    </div>\n  )\n}\n","import \"./Loader.scss\"\n\nimport React, { useState } from \"react\"\nimport { useTimeout } from \"@fider/hooks\"\nimport { classSet } from \"@fider/services\"\n\ninterface LoaderProps {\n  text?: string\n  className?: string\n}\n\nexport function Loader(props: LoaderProps) {\n  const [show, setShow] = useState(false)\n\n  useTimeout(() => {\n    setShow(true)\n  }, 500)\n\n  const className = classSet({\n    \"c-loader\": true,\n    [props.className || \"\"]: props.className,\n  })\n\n  return show ? (\n    <div className={className}>\n      <div className=\"c-loader__spinner\" />\n      {props.text && <span className=\"c-loader__text\">{props.text}</span>}\n    </div>\n  ) : null\n}\n","import React from \"react\"\nimport { uploadedImageURL } from \"@fider/services\"\nimport { useFider } from \"@fider/hooks\"\nimport { Tenant } from \"@fider/models\"\n\ntype Size = 24 | 50 | 100 | 200\n\ninterface TenantLogoProps {\n  size: Size\n  useFiderIfEmpty?: boolean\n}\n\nexport const TenantLogoURL = (tenant: Tenant, size: Size): string | undefined => {\n  if (tenant && tenant.logoBlobKey) {\n    return uploadedImageURL(tenant.logoBlobKey, size)\n  }\n  return undefined\n}\n\nexport const TenantLogo = (props: TenantLogoProps) => {\n  const fider = useFider()\n\n  const tenant = fider.session.tenant\n  if (tenant && tenant.logoBlobKey) {\n    return <img src={TenantLogoURL(fider.session.tenant, props.size)} alt={tenant.name} />\n  } else if (props.useFiderIfEmpty) {\n    return <img src=\"https://fider.io/images/logo-100x100.png\" alt=\"Fider\" />\n  }\n  return null\n}\n\nTenantLogo.defaultProps = {\n  useFiderIfEmpty: false,\n}\n\ninterface OAuthProviderLogoProps {\n  option: {\n    provider?: string\n    displayName: string\n    logoBlobKey?: string\n  }\n}\n\nconst systemProvidersLogo: { [key: string]: string } = {\n  google: ``,\n  facebook: ``,\n  github:\n    \"\",\n}\n\nexport const OAuthProviderLogoURL = (logoBlobKey?: string): string | undefined => {\n  if (logoBlobKey) {\n    return uploadedImageURL(logoBlobKey, 100)\n  }\n  return undefined\n}\n\nexport const OAuthProviderLogo = (props: OAuthProviderLogoProps) => {\n  if (props.option.logoBlobKey) {\n    return <img src={OAuthProviderLogoURL(props.option.logoBlobKey)} alt={props.option.displayName} />\n  }\n\n  if (props.option.provider && props.option.provider in systemProvidersLogo) {\n    return <img src={systemProvidersLogo[props.option.provider]} alt={props.option.displayName} />\n  }\n\n  return null\n}\n","import \"./Toggle.scss\"\n\nimport React, { useState } from \"react\"\nimport { classSet } from \"@fider/services\"\nimport { HStack } from \"../layout\"\nimport { DisplayError, ValidationContext } from \"@fider/components\"\n\ninterface ToggleProps {\n  field?: string\n  label?: string\n  active: boolean\n  disabled?: boolean\n  onToggle?: (active: boolean) => void\n}\n\nexport const Toggle: React.FC<ToggleProps> = (props) => {\n  const [active, setActive] = useState(props.active)\n\n  const toggle = () => {\n    if (props.disabled) {\n      return\n    }\n\n    const newActive = !active\n    setActive(newActive)\n    if (props.onToggle) {\n      props.onToggle(newActive)\n    }\n  }\n\n  const className = classSet({\n    \"c-toggle\": true,\n    \"c-toggle--enabled\": active,\n    \"c-toggle--disabled\": !!props.disabled,\n  })\n\n  return (\n    <ValidationContext.Consumer>\n      {(ctx) => (\n        <>\n          <HStack spacing={2}>\n            <button onClick={toggle} type=\"button\" className={className} role=\"switch\">\n              <span aria-hidden=\"true\" className=\"shadow\"></span>\n            </button>\n            {props.label && <span className=\"text-sm\">{props.label}</span>}\n          </HStack>\n          {props.field && <DisplayError fields={[props.field]} error={ctx.error} />}\n        </>\n      )}\n    </ValidationContext.Consumer>\n  )\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\n\nimport \"./PoweredByFider.scss\"\n\ninterface PoweredByFiderProps {\n  slot: string\n  className?: string\n}\n\nexport const PoweredByFider = (props: PoweredByFiderProps) => {\n  const source = encodeURIComponent(window?.location?.host || \"\")\n  const medium = \"powered-by\"\n  const campaign = props.slot\n\n  const className = classSet({\n    \"c-powered\": true,\n    [props.className || \"\"]: props.className,\n  })\n\n  return (\n    <div className={className}>\n      <a rel=\"noopener\" href={`https://fider.io?utm_source=${source}&utm_medium=${medium}&utm_campaign=${campaign}`} target=\"_blank\">\n        Powered by Fider ⚡\n      </a>\n    </div>\n  )\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\n\ninterface PageTitleLogo {\n  title: string\n  subtitle?: string\n  className?: string\n}\n\nexport const PageTitle = (props: PageTitleLogo) => {\n  const className = classSet({\n    \"mb-4\": true,\n    [`${props.className}`]: props.className,\n  })\n\n  return (\n    <div className={className}>\n      <div className=\"text-display2 mb-1\">{props.title}</div>\n      <div className=\"text-gray-700\">{props.subtitle}</div>\n    </div>\n  )\n}\n","import \"./Dropdown.scss\"\n\nimport React, { createContext, useContext, useEffect, useRef, useState } from \"react\"\nimport { classSet } from \"@fider/services\"\n\ninterface DropdownListItemProps {\n  href?: string\n  onClick?: () => void\n  className?: string\n  children: React.ReactNode\n}\n\nconst ListItem = (props: DropdownListItemProps) => {\n  const ctx = useContext(DropdownContext)\n  const handleClick = () => {\n    if (props.onClick) {\n      props.onClick()\n    }\n\n    ctx?.close()\n  }\n\n  if (props.href) {\n    return (\n      <a href={props.href} className={`c-dropdown__listitem ${props.className}`}>\n        {props.children}\n      </a>\n    )\n  }\n\n  return (\n    <div onClick={handleClick} className={`c-dropdown__listitem ${props.className}`}>\n      {props.children}\n    </div>\n  )\n}\n\nconst Divider = () => {\n  return <hr className=\"c-dropdown__divider\" />\n}\n\ninterface DropdownProps {\n  renderHandle: JSX.Element\n  position?: \"left\" | \"right\"\n  onToggled?: (isOpen: boolean) => void\n  children: React.ReactNode\n  wide?: boolean\n  fullsceenSm?: boolean\n}\n\ninterface DropdownContextFuncs {\n  close(): void\n}\n\nconst DropdownContext = createContext<DropdownContextFuncs | null>(null)\nDropdownContext.displayName = \"DropdownContext\"\n\nexport const Dropdown = (props: DropdownProps) => {\n  const node = useRef<HTMLDivElement | null>(null)\n  const [isOpen, setIsOpen] = useState(false)\n  const position = props.position || \"right\"\n\n  const changeToggleState = (newState: boolean) => {\n    setIsOpen(newState)\n    if (props.onToggled) {\n      props.onToggled(newState)\n    }\n  }\n\n  const toggleIsOpen = () => {\n    changeToggleState(!isOpen)\n  }\n\n  const close = () => {\n    changeToggleState(false)\n  }\n\n  const handleClick = (e: MouseEvent) => {\n    if (node.current && node.current.contains(e.target as Node)) {\n      return\n    }\n\n    close()\n  }\n\n  useEffect(() => {\n    document.addEventListener(\"mousedown\", handleClick)\n\n    return () => {\n      document.removeEventListener(\"mousedown\", handleClick)\n    }\n  }, [])\n\n  const listClassName = classSet({\n    \"c-dropdown__list--wide\": props.wide,\n    \"c-dropdown__list shadow-lg\": true,\n    \"c-dropdown__list--fullscreen-small\": props.fullsceenSm,\n    [`c-dropdown__list--${position}`]: position === \"left\",\n  })\n\n  return (\n    <DropdownContext.Provider value={{ close }}>\n      <div ref={node} className=\"c-dropdown\">\n        <button type=\"button\" className=\"c-dropdown__handle\" onClick={toggleIsOpen}>\n          {props.renderHandle}\n        </button>\n        {isOpen && <div className={listClassName}>{props.children}</div>}\n      </div>\n    </DropdownContext.Provider>\n  )\n}\n\nDropdown.ListItem = ListItem\nDropdown.Divider = Divider\n","import React from \"react\"\n\ninterface MomentProps {\n  locale: string\n  amount: number\n  currency: string\n}\n\nexport const Money = (props: MomentProps) => {\n  const formatter = new Intl.NumberFormat(props.locale, {\n    style: \"currency\",\n    currency: props.currency,\n  })\n\n  return <span>{formatter.format(props.amount)}</span>\n}\n","import React, { useState, useEffect } from \"react\"\nimport { Modal, SignInControl, LegalFooter } from \"@fider/components\"\nimport { Button } from \"./common\"\nimport { Trans } from \"@lingui/macro\"\n\ninterface SignInModalProps {\n  isOpen: boolean\n  onClose: () => void\n}\n\nexport const SignInModal: React.StatelessComponent<SignInModalProps> = (props) => {\n  const [email, setEmail] = useState(\"\")\n\n  useEffect(() => {\n    if (email) {\n      setTimeout(() => setEmail(\"\"), 5000)\n    }\n  }, [email])\n\n  const onEmailSent = (value: string): void => {\n    setEmail(value)\n  }\n\n  const closeModal = () => {\n    setEmail(\"\")\n    props.onClose()\n  }\n\n  const content = email ? (\n    <>\n      <p>\n        <Trans id=\"signin.message.emailsent\">\n          We have just sent a confirmation link to <b>{email}</b>. Click the link and you’ll be signed in.\n        </Trans>\n      </p>\n      <p>\n        <Button variant=\"tertiary\" onClick={closeModal}>\n          <Trans id=\"action.ok\">OK</Trans>\n        </Button>\n      </p>\n    </>\n  ) : (\n    <SignInControl useEmail={true} onEmailSent={onEmailSent} />\n  )\n\n  return (\n    <Modal.Window isOpen={props.isOpen} onClose={closeModal}>\n      <Modal.Header>\n        <Trans id=\"modal.signin.header\">Sign in to participate and vote</Trans>\n      </Modal.Header>\n      <Modal.Content>{content}</Modal.Content>\n      <LegalFooter />\n    </Modal.Window>\n  )\n}\n","import \"./VoteCounter.scss\"\n\nimport React, { useState } from \"react\"\nimport { Post, PostStatus } from \"@fider/models\"\nimport { actions, classSet } from \"@fider/services\"\nimport { Icon, SignInModal } from \"@fider/components\"\nimport { useFider } from \"@fider/hooks\"\nimport FaCaretUp from \"@fider/assets/images/fa-caretup.svg\"\n\ninterface VoteCounterProps {\n  post: Post\n}\n\nexport const VoteCounter = (props: VoteCounterProps) => {\n  const fider = useFider()\n  const [hasVoted, setHasVoted] = useState(props.post.hasVoted)\n  const [votesCount, setVotesCount] = useState(props.post.votesCount)\n  const [isSignInModalOpen, setIsSignInModalOpen] = useState(false)\n\n  const voteOrUndo = async () => {\n    if (!fider.session.isAuthenticated) {\n      setIsSignInModalOpen(true)\n      return\n    }\n\n    const action = hasVoted ? actions.removeVote : actions.addVote\n\n    const response = await action(props.post.number)\n    if (response.ok) {\n      setVotesCount(votesCount + (hasVoted ? -1 : 1))\n      setHasVoted(!hasVoted)\n    }\n  }\n\n  const hideModal = () => setIsSignInModalOpen(false)\n\n  const status = PostStatus.Get(props.post.status)\n  const isDisabled = status.closed || fider.isReadOnly\n\n  const className = classSet({\n    \"c-vote-counter__button\": true,\n    \"c-vote-counter__button--voted\": !status.closed && hasVoted,\n    \"c-vote-counter__button--disabled\": isDisabled,\n  })\n\n  const vote = (\n    <button className={className} onClick={voteOrUndo}>\n      <Icon sprite={FaCaretUp} height=\"16\" width=\"16\" />\n      {votesCount}\n    </button>\n  )\n\n  const disabled = (\n    <button className={className}>\n      <Icon sprite={FaCaretUp} height=\"16\" width=\"16\" />\n      {votesCount}\n    </button>\n  )\n\n  return (\n    <>\n      <SignInModal isOpen={isSignInModalOpen} onClose={hideModal} />\n      <div className=\"c-vote-counter\">{isDisabled ? disabled : vote}</div>\n    </>\n  )\n}\n","import \"./NotificationIndicator.scss\"\nimport NoDataIllustration from \"@fider/assets/images/undraw-empty.svg\"\n\nimport React, { useEffect, useState } from \"react\"\nimport IconBell from \"@fider/assets/images/heroicons-bell.svg\"\nimport { useFider } from \"@fider/hooks\"\nimport { actions, Fider } from \"@fider/services\"\nimport { Avatar, Icon, Markdown, Moment } from \"./common\"\nimport { Dropdown } from \"./common/Dropdown\"\nimport { Notification } from \"@fider/models\"\nimport { HStack, VStack } from \"./layout\"\n\nimport { Trans } from \"@lingui/macro\"\n\nexport const NotificationItem = ({ notification }: { notification: Notification }) => {\n  const openNotification = () => {\n    window.location.href = `/notifications/${notification.id}`\n  }\n\n  return (\n    <HStack spacing={4} className=\"px-3 pr-5 clickable hover py-4\" onClick={openNotification}>\n      <Avatar user={{ name: notification.authorName, avatarURL: notification.avatarURL }} />\n      <div>\n        <Markdown className=\"c-notification-indicator-text\" text={notification.title} style=\"full\" />\n        <span className=\"text-muted\">\n          <Moment locale={Fider.currentLocale} date={notification.createdAt} />\n        </span>\n      </div>\n    </HStack>\n  )\n}\n\nconst NotificationIcon = ({ unreadNotifications }: { unreadNotifications: number }) => {\n  return (\n    <>\n      <span className=\"c-notification-indicator mr-3\">\n        <Icon sprite={IconBell} className=\"h-6 text-gray-500\" />\n        {unreadNotifications > 0 && <div className=\"c-notification-indicator-unread-counter\" />}\n      </span>\n    </>\n  )\n}\n\nexport const NotificationIndicator = () => {\n  const fider = useFider()\n  const [unreadNotifications, setUnreadNotifications] = useState(0)\n  const [showingNotifications, setShowingNotifications] = useState(false)\n  const [recent, setRecent] = useState<Notification[] | undefined>()\n  const [unread, setUnread] = useState<Notification[] | undefined>()\n\n  useEffect(() => {\n    if (fider.session.isAuthenticated) {\n      actions.getTotalUnreadNotifications().then((result) => {\n        if (result.ok && result.data > 0) {\n          setUnreadNotifications(result.data)\n        }\n      })\n    }\n  }, [fider.session.isAuthenticated])\n\n  useEffect(() => {\n    if (showingNotifications) {\n      actions.getAllNotifications().then((result) => {\n        if (result) {\n          const [unread, recent] = (result.data || []).reduce(\n            (result, item) => {\n              result[item.read ? 1 : 0].push(item)\n              return result\n            },\n            [[] as Notification[], [] as Notification[]]\n          )\n          setRecent(recent)\n          setUnread(unread)\n          setUnreadNotifications(unread.length)\n        }\n      })\n    }\n  }, [showingNotifications])\n\n  const markAllAsRead = async (e: React.MouseEvent) => {\n    e.preventDefault()\n    const response = await actions.markAllAsRead()\n    if (response.ok) {\n      location.reload()\n    }\n  }\n\n  return (\n    <Dropdown\n      wide={true}\n      position=\"left\"\n      fullsceenSm={true}\n      onToggled={(isOpen: boolean) => setShowingNotifications(isOpen)}\n      renderHandle={<NotificationIcon unreadNotifications={unreadNotifications} />}\n    >\n      <div className=\"c-notifications-container\">\n        {showingNotifications && (unread !== undefined || recent !== undefined) && (\n          <>\n            {unread !== undefined && unread?.length > 0 ? (\n              <>\n                <p className=\"text-subtitle px-4 mt-4 mb-0\">\n                  <Trans id=\"modal.notifications.unread\">Unread notifications</Trans>\n                  {unread.length > 1 && (\n                    <a href=\"#\" className=\"text-link text-xs pl-6\" onClick={markAllAsRead}>\n                      <Trans id=\"action.markallasread\">Mark All as Read</Trans>\n                    </a>\n                  )}\n                </p>\n                <VStack spacing={0} className=\"py-2\" divide={false}>\n                  {unread.map((n) => (\n                    <NotificationItem key={n.id} notification={n} />\n                  ))}\n                </VStack>\n              </>\n            ) : (\n              <div className=\"text-center pb-6\">\n                <p className=\"text-display text-center mt-6 px-4\">\n                  <Trans id=\"modal.notifications.nonew\">No new notifications</Trans>\n                </p>\n                {recent?.length === 0 && <Icon sprite={NoDataIllustration} height=\"120\" className=\"mt-6 mb-2\" />}\n              </div>\n            )}\n            {recent !== undefined && recent?.length > 0 && (\n              <>\n                <p className=\"text-subtitle px-4 mb-0 pt-4 bg-gray-50 border-gray-200 bt\">\n                  <Trans id=\"modal.notifications.previous\">Previous notifications</Trans>\n                </p>\n                <VStack spacing={0} className=\"py-2 bg-gray-50\" divide={false}>\n                  {recent.map((n) => (\n                    <NotificationItem key={n.id} notification={n} />\n                  ))}\n                </VStack>\n              </>\n            )}\n          </>\n        )}\n      </div>\n    </Dropdown>\n  )\n}\n","import React from \"react\"\nimport { useFider } from \"@fider/hooks\"\nimport { Avatar, Dropdown } from \"./common\"\nimport { Trans } from \"@lingui/macro\"\n\nexport const UserMenu = () => {\n  const fider = useFider()\n\n  return (\n    <div className=\"c-menu-user\">\n      <Dropdown position=\"left\" renderHandle={<Avatar user={fider.session.user} />}>\n        <div className=\"p-2 text-medium uppercase\">{fider.session.user.name}</div>\n        <Dropdown.ListItem href=\"/settings\">\n          <Trans id=\"menu.mysettings\">My Settings</Trans>\n        </Dropdown.ListItem>\n        <Dropdown.Divider />\n\n        {fider.session.user.isCollaborator && (\n          <>\n            <div className=\"p-2 text-medium uppercase\">\n              <Trans id=\"menu.administration\">Administration</Trans>\n            </div>\n            <Dropdown.ListItem href=\"/admin\">\n              <Trans id=\"menu.sitesettings\">Site Settings</Trans>\n            </Dropdown.ListItem>\n            <Dropdown.Divider />\n          </>\n        )}\n        <Dropdown.ListItem href=\"/signout?redirect=/\">\n          <Trans id=\"menu.signout\">Sign out</Trans>\n        </Dropdown.ListItem>\n      </Dropdown>\n    </div>\n  )\n}\n","import React, { useEffect, useState } from \"react\"\nimport { ReactionCount } from \"@fider/models\"\nimport { Icon } from \"@fider/components\"\nimport ReactionAdd from \"@fider/assets/images/reaction-add.svg\"\nimport { HStack } from \"@fider/components/layout\"\nimport { classSet } from \"@fider/services\"\nimport { useFider } from \"@fider/hooks\"\nimport \"./Reactions.scss\"\n\ninterface ReactionsProps {\n  emojiSelectorRef: React.RefObject<HTMLDivElement>\n  toggleReaction: (emoji: string) => void\n  reactions?: ReactionCount[]\n}\n\nconst availableEmojis = [\"👍\", \"👎\", \"😄\", \"🎉\", \"😕\", \"❤️\", \"🚀\", \"👀\"]\n\nexport const Reactions: React.FC<ReactionsProps> = ({ emojiSelectorRef, toggleReaction, reactions }) => {\n  const fider = useFider()\n  const [isEmojiSelectorOpen, setIsEmojiSelectorOpen] = useState(false)\n\n  useEffect(() => {\n    const handleClickOutside = (event: MouseEvent) => {\n      if (emojiSelectorRef.current && !emojiSelectorRef.current.contains(event.target as Node)) {\n        setIsEmojiSelectorOpen(false)\n      }\n    }\n\n    document.addEventListener(\"click\", handleClickOutside)\n    return () => {\n      document.removeEventListener(\"click\", handleClickOutside)\n    }\n  }, [])\n\n  return (\n    <div ref={emojiSelectorRef}>\n      <HStack spacing={2} center={true} className=\"mt-2 c-reactions relative\">\n        {fider.session.isAuthenticated && (\n          <>\n            <span\n              onClick={() => setIsEmojiSelectorOpen(!isEmojiSelectorOpen)}\n              className=\"c-reactions-add-reaction relative text-gray-600 clickable inline-flex items-center px-1 py-1 rounded-full text-xs bg-blue-100 hover:bg-blue-200\"\n            >\n              <Icon width=\"18\" height=\"18\" sprite={ReactionAdd} className=\"\" />\n            </span>\n            {isEmojiSelectorOpen && (\n              <div className=\"c-reactions-emojis p-2 absolute bg-white border rounded shadow-lg\">\n                {availableEmojis.map((emoji) => (\n                  <a\n                    key={emoji}\n                    className=\"clickable p-2 hover:bg-gray-100\"\n                    onClick={() => {\n                      toggleReaction(emoji)\n                      setIsEmojiSelectorOpen(false)\n                    }}\n                  >\n                    {emoji}\n                  </a>\n                ))}\n              </div>\n            )}\n          </>\n        )}\n        {reactions !== undefined && (\n          <>\n            {reactions.map((reaction) => (\n              <span\n                key={reaction.emoji}\n                {...(fider.session.isAuthenticated && { onClick: () => toggleReaction(reaction.emoji) })}\n                className={classSet({\n                  \"inline-flex items-center px-2 py-1 rounded-full text-xs\": true,\n                  \"bg-blue-100\": reaction.includesMe,\n                  \"bg-gray-100\": !reaction.includesMe,\n                  \"clickable hover:bg-blue-200\": fider.session.isAuthenticated && reaction.includesMe,\n                  \"clickable hover:bg-gray-200\": fider.session.isAuthenticated && !reaction.includesMe,\n                })}\n              >\n                {reaction.emoji} <span className=\"ml-1 font-semibold\">{reaction.count}</span>\n              </span>\n            ))}\n          </>\n        )}\n      </HStack>\n    </div>\n  )\n}\n","import React from \"react\"\nimport { useFider } from \"@fider/hooks\"\nimport { Message } from \"./common\"\n\nexport const ReadOnlyNotice = () => {\n  const fider = useFider()\n  if (!fider.isReadOnly) {\n    return null\n  }\n\n  if (fider.session.isAuthenticated && fider.session.user.isAdministrator) {\n    return (\n      <Message alignment=\"center\" type=\"warning\">\n        This website is currently in read-only mode because there is no active subscription. Visit{\" \"}\n        <a className=\"text-link\" href=\"/admin/billing\">\n          Billing\n        </a>{\" \"}\n        to subscribe.\n      </Message>\n    )\n  }\n\n  return (\n    <Message alignment=\"center\" type=\"warning\">\n      This website is currently in read-only mode.\n    </Message>\n  )\n}\n","import React from \"react\"\nimport { classSet } from \"@fider/services\"\n\ninterface StackProps {\n  className?: string\n  children: React.ReactNode\n  onClick?: () => void\n  center?: boolean\n  divide?: boolean\n  justify?: \"between\" | \"evenly\" | \"full\" | \"center\"\n  spacing?: 0 | 1 | 2 | 4 | 6 | 8\n}\n\nconst Stack = (props: StackProps, dir: \"x\" | \"y\") => {\n  const spacing = props.spacing === undefined ? 2 : props.spacing\n  const className = classSet({\n    [`${props.className}`]: props.className,\n    flex: true,\n    \"flex-x\": dir === \"x\",\n    \"flex-y\": dir === \"y\",\n    [`flex--spacing-${spacing}`]: spacing > 0 && !props.divide,\n    [`flex--divide-${spacing}`]: spacing > 0 && !!props.divide,\n    \"flex-items-center\": dir === \"x\" && props.center !== false,\n    \"justify-between\": props.justify === \"between\",\n    \"justify-evenly\": props.justify === \"evenly\",\n    \"justify-full\": props.justify === \"full\",\n    \"justify-center\": props.justify === \"center\",\n  })\n\n  return (\n    <div onClick={props.onClick} className={className}>\n      {props.children}\n    </div>\n  )\n}\n\nexport const HStack = (props: StackProps) => {\n  return Stack(props, \"x\")\n}\n\nexport const VStack = (props: StackProps) => {\n  return Stack(props, \"y\")\n}\n","import \"./Divider.scss\"\n\nimport React from \"react\"\nimport { Trans } from \"@lingui/macro\"\n\nexport const Divider = () => {\n  return (\n    <div className=\"c-divider text-gray-600\">\n      <Trans id=\"label.or\">OR</Trans>\n    </div>\n  )\n}\n","import { User } from \"./identity\"\n\nexport interface Post {\n  id: number\n  number: number\n  slug: string\n  title: string\n  description: string\n  createdAt: string\n  status: string\n  user: User\n  hasVoted: boolean\n  response: PostResponse | null\n  votesCount: number\n  commentsCount: number\n  tags: string[]\n}\n\nexport class PostStatus {\n  constructor(public title: string, public value: string, public show: boolean, public closed: boolean, public filterable: boolean) {}\n\n  public static Open = new PostStatus(\"Open\", \"open\", false, false, false)\n  public static Planned = new PostStatus(\"Planned\", \"planned\", true, false, true)\n  public static Started = new PostStatus(\"Started\", \"started\", true, false, true)\n  public static Completed = new PostStatus(\"Completed\", \"completed\", true, true, true)\n  public static Declined = new PostStatus(\"Declined\", \"declined\", true, true, true)\n  public static Duplicate = new PostStatus(\"Duplicate\", \"duplicate\", true, true, false)\n  public static Deleted = new PostStatus(\"Deleted\", \"deleted\", false, true, false)\n\n  public static Get(value: string): PostStatus {\n    for (const status of PostStatus.All) {\n      if (status.value === value) {\n        return status\n      }\n    }\n    throw new Error(`PostStatus not found for value ${value}.`)\n  }\n\n  public static All = [PostStatus.Open, PostStatus.Planned, PostStatus.Started, PostStatus.Completed, PostStatus.Duplicate, PostStatus.Declined]\n}\n\nexport interface PostResponse {\n  user: User\n  text: string\n  respondedAt: Date\n  original?: {\n    number: number\n    title: string\n    slug: string\n    status: string\n  }\n}\n\nexport interface ReactionCount {\n  emoji: string\n  count: number\n  includesMe: boolean\n}\n\nexport interface Comment {\n  id: number\n  content: string\n  createdAt: string\n  user: User\n  attachments?: string[]\n  reactionCounts?: ReactionCount[]\n  editedAt?: string\n  editedBy?: User\n}\n\nexport interface Tag {\n  id: number\n  slug: string\n  name: string\n  color: string\n  isPublic: boolean\n}\n\nexport interface Vote {\n  createdAt: Date\n  user: {\n    id: number\n    name: string\n    email: string\n    avatarURL: string\n  }\n}\n","export interface Tenant {\n  id: number\n  name: string\n  cname: string\n  subdomain: string\n  locale: string\n  invitation: string\n  welcomeMessage: string\n  status: TenantStatus\n  isPrivate: boolean\n  logoBlobKey: string\n  isEmailAuthAllowed: boolean\n}\n\nexport enum TenantStatus {\n  Active = 1,\n  Pending = 2,\n  Locked = 3,\n  Disabled = 4,\n}\n\nexport interface User {\n  id: number\n  name: string\n  email?: string\n  role: UserRole\n  status: UserStatus\n  avatarURL: string\n}\n\nexport enum UserAvatarType {\n  Letter = \"letter\",\n  Gravatar = \"gravatar\",\n  Custom = \"custom\",\n}\n\nexport enum UserStatus {\n  Active = \"active\",\n  Deleted = \"deleted\",\n  Blocked = \"blocked\",\n}\n\nexport enum UserRole {\n  Visitor = \"visitor\",\n  Collaborator = \"collaborator\",\n  Administrator = \"administrator\",\n}\n\nexport const isCollaborator = (role: UserRole): boolean => {\n  return role === UserRole.Collaborator || role === UserRole.Administrator\n}\n\nexport interface CurrentUser {\n  id: number\n  name: string\n  email: string\n  avatarType: UserAvatarType\n  avatarBlobKey: string\n  avatarURL: string\n  role: UserRole\n  status: UserStatus\n  isAdministrator: boolean\n  isCollaborator: boolean\n}\n","export interface OAuthProviderOption {\n  provider: string\n  displayName: string\n  clientID: string\n  url: string\n  callbackURL: string\n  logoBlobKey: string\n  isCustomProvider: boolean\n  isEnabled: boolean\n}\n\nexport interface SystemSettings {\n  mode: string\n  locale: string\n  version: string\n  environment: string\n  domain: string\n  hasLegal: boolean\n  isBillingEnabled: boolean\n  baseURL: string\n  assetsURL: string\n  oauth: OAuthProviderOption[]\n}\n\nexport interface UserSettings {\n  [key: string]: string\n}\n\nexport const OAuthConfigStatus = {\n  Disabled: 1,\n  Enabled: 2,\n}\n\nexport interface OAuthConfig {\n  provider: string\n  displayName: string\n  status: number\n  clientID: string\n  clientSecret: string\n  authorizeURL: string\n  tokenURL: string\n  profileURL: string\n  logoBlobKey: string\n  scope: string\n  jsonUserIDPath: string\n  jsonUserNamePath: string\n  jsonUserEmailPath: string\n  isTrusted: boolean\n}\n\nexport interface ImageUpload {\n  bkey?: string\n  upload?: {\n    fileName?: string\n    content?: string\n    contentType?: string\n  }\n  remove: boolean\n}\n\nexport enum EmailVerificationKind {\n  SignIn = 1,\n  SignUp = 2,\n  ChangeEmail = 3,\n  UserInvitation = 4,\n}\n","export enum BillingStatus {\n  Trial = 1,\n  Active = 2,\n  Cancelled = 3,\n  FreeForever = 4,\n  OpenCollective = 5,\n}\n","import { StringObject } from \"@fider/services\"\n\nexport interface WebhookData {\n  name: string\n  type: WebhookType\n  status: WebhookStatus\n  url: string\n  content: string\n  http_method: string\n  http_headers: HttpHeaders\n}\n\nexport interface Webhook extends WebhookData {\n  id: number\n}\n\nexport enum WebhookType {\n  NEW_POST = \"new_post\",\n  NEW_COMMENT = \"new_comment\",\n  CHANGE_STATUS = \"change_status\",\n  DELETE_POST = \"delete_post\",\n}\n\nexport enum WebhookStatus {\n  ENABLED = \"enabled\",\n  DISABLED = \"disabled\",\n  FAILED = \"failed\",\n}\n\nexport type HttpHeaders = StringObject<string>\n\nexport interface WebhookTriggerResult {\n  webhook: Webhook\n  props: StringObject\n  success: boolean\n  url: string\n  content: string\n  status_code: number\n  message: string\n  error: string\n}\n\nexport interface WebhookPreviewResult {\n  url: PreviewedField\n  content: PreviewedField\n}\n\nexport interface PreviewedField {\n  value: string\n  message: string\n  error: string\n}\n","import { analytics, notify, truncate } from \"@fider/services\"\n\nexport interface ErrorItem {\n  field?: string\n  message: string\n}\n\nexport interface Failure {\n  errors?: ErrorItem[]\n}\n\nexport interface Result<T = void> {\n  ok: boolean\n  data: T\n  error?: Failure\n}\n\nasync function toResult<T>(response: Response): Promise<Result<T>> {\n  const body = await response.json()\n\n  if (response.status < 400) {\n    return {\n      ok: true,\n      data: body as T,\n    }\n  }\n\n  if (response.status === 500) {\n    notify.error(\"An unexpected error occurred while processing your request.\")\n  } else if (response.status === 401) {\n    notify.error(\"You need to be authenticated to perform this operation.\")\n  } else if (response.status === 403) {\n    notify.error(\"You are not authorized to perform this operation.\")\n  }\n\n  return {\n    ok: false,\n    data: body as T,\n    error: {\n      errors: body.errors,\n    },\n  }\n}\nasync function request<T>(url: string, method: \"GET\" | \"POST\" | \"PUT\" | \"DELETE\", body?: any): Promise<Result<T>> {\n  const headers = [\n    [\"Accept\", \"application/json\"],\n    [\"Content-Type\", \"application/json\"],\n  ]\n  try {\n    const response = await fetch(url, {\n      method,\n      headers,\n      body: JSON.stringify(body),\n      credentials: \"same-origin\",\n    })\n    return await toResult<T>(response)\n  } catch (err) {\n    const truncatedBody = truncate(body ? JSON.stringify(body) : \"<empty>\", 1000)\n    throw new Error(`Failed to ${method} ${url} with body '${truncatedBody}'`)\n  }\n}\n\nexport const http = {\n  get: async <T = void>(url: string): Promise<Result<T>> => {\n    return await request<T>(url, \"GET\")\n  },\n  post: async <T = void>(url: string, body?: any): Promise<Result<T>> => {\n    return await request<T>(url, \"POST\", body)\n  },\n  put: async <T = void>(url: string, body?: any): Promise<Result<T>> => {\n    return await request<T>(url, \"PUT\", body)\n  },\n  delete: async <T = void>(url: string, body?: any): Promise<Result<T>> => {\n    return await request<T>(url, \"DELETE\", body)\n  },\n  event:\n    (category: string, action: string) =>\n    <T>(result: Result<T>): Result<T> => {\n      if (result && result.ok) {\n        analytics.event(category, action)\n      }\n      return result\n    },\n}\n","const set = (storage: Storage, key: string, value: string): void => {\n  if (storage) {\n    storage.setItem(key, value)\n  }\n}\n\nconst get = (storage: Storage, key: string): string | null => {\n  if (window.localStorage) {\n    return storage.getItem(key)\n  }\n  return null\n}\n\nconst has = (storage: Storage, key: string): boolean => {\n  if (storage) {\n    return !!storage.getItem(key)\n  }\n  return false\n}\n\nconst remove = (storage: Storage, ...keys: string[]): void => {\n  if (storage && keys) {\n    for (const key of keys) {\n      storage.removeItem(key)\n    }\n  }\n}\n\nexport const cache = {\n  local: {\n    set: (key: string, value: string): void => {\n      set(window.localStorage, key, value)\n    },\n    get: (key: string): string | null => {\n      return get(window.localStorage, key)\n    },\n    has: (key: string): boolean => {\n      return has(window.localStorage, key)\n    },\n    remove: (...keys: string[]): void => {\n      remove(window.localStorage, ...keys)\n    },\n  },\n  session: {\n    set: (key: string, value: string): void => {\n      set(window.sessionStorage, key, value)\n    },\n    get: (key: string): string | null => {\n      return get(window.sessionStorage, key)\n    },\n    has: (key: string): boolean => {\n      return has(window.sessionStorage, key)\n    },\n    remove: (...keys: string[]): void => {\n      remove(window.sessionStorage, ...keys)\n    },\n  },\n}\n","export const analytics = {\n  event: (eventCategory: string, eventAction: string): void => {\n    if (window.ga) {\n      window.ga(\"send\", \"event\", {\n        eventCategory,\n        eventAction,\n      })\n    }\n  },\n  error: (err?: Error): void => {\n    if (window.ga) {\n      window.ga(\"send\", \"exception\", {\n        exDescription: err ? err.stack : \"<not available>\",\n        exFatal: false,\n      })\n    }\n  },\n}\n","import { createContext } from \"react\"\nimport { CurrentUser, SystemSettings, Tenant, TenantStatus } from \"@fider/models\"\n\nexport class FiderSession {\n  private pPage: string\n  private pContextID: string\n  private pTenant: Tenant\n  private pUser: CurrentUser | undefined\n  private pProps: { [key: string]: any } = {}\n\n  constructor(data: any) {\n    this.pPage = data.page\n    this.pContextID = data.contextID\n    this.pProps = data.props\n    this.pUser = data.user\n    this.pTenant = data.tenant\n  }\n\n  public get page(): string {\n    return this.pPage\n  }\n\n  public get contextID(): string {\n    return this.pContextID\n  }\n\n  public get user(): CurrentUser {\n    if (!this.pUser) throw new Error(\"User is undefined\")\n    return this.pUser\n  }\n\n  public get tenant(): Tenant {\n    return this.pTenant\n  }\n\n  public get props(): { [key: string]: any } {\n    return this.pProps\n  }\n\n  public get isAuthenticated(): boolean {\n    return !!this.pUser\n  }\n}\n\nexport class FiderImpl {\n  private pSettings!: SystemSettings\n  private pSession!: FiderSession\n\n  public initialize = (initData?: any): FiderImpl => {\n    if (initData) {\n      this.pSettings = initData.settings\n      this.pSession = new FiderSession(initData)\n      return this\n    }\n\n    const el = document.getElementById(\"server-data\")\n    const data = el ? JSON.parse(el.textContent || el.innerText) : {}\n    this.pSettings = data.settings\n    this.pSession = new FiderSession(data)\n    return this\n  }\n\n  public get currentLocale(): string {\n    if (this.session.tenant) {\n      return this.session.tenant.locale\n    }\n    return this.settings.locale\n  }\n\n  public get session(): FiderSession {\n    return this.pSession\n  }\n\n  public get settings(): SystemSettings {\n    return this.pSettings\n  }\n\n  public get isReadOnly(): boolean {\n    return this.session.tenant && this.session.tenant.status === TenantStatus.Locked\n  }\n\n  public isProduction(): boolean {\n    return this.pSettings.environment === \"production\"\n  }\n\n  public isSingleHostMode(): boolean {\n    return this.pSettings.mode === \"single\"\n  }\n}\n\nexport const Fider = new FiderImpl()\n\nexport const FiderContext = createContext<FiderImpl>(Fider)\n","export const jwt = {\n  decode: (token: string): any => {\n    if (token) {\n      const segments = token.split(\".\")\n      try {\n        return JSON.parse(window.atob(segments[1]))\n      } catch {\n        return undefined\n      }\n    }\n  },\n}\n","import { Fider } from \".\"\n\nexport const delay = (ms: number) => {\n  return new Promise((resolve) => setTimeout(resolve, ms))\n}\n\nexport const classSet = (input?: any): string => {\n  let classes = \"\"\n  if (input) {\n    for (const key in input) {\n      if (key && !!input[key]) {\n        classes += ` ${key}`\n      }\n    }\n    return classes.trim()\n  }\n  return \"\"\n}\n\ntype DateFormat = \"full\" | \"short\" | \"date\"\ntype DateOptsMap = {\n  [key in DateFormat]: Intl.DateTimeFormatOptions\n}\n\nconst dateOpts: DateOptsMap = {\n  date: { day: \"numeric\", month: \"short\", year: \"numeric\" },\n  short: { month: \"short\", year: \"numeric\" },\n  full: { day: \"2-digit\", month: \"long\", year: \"numeric\", hour: \"numeric\", minute: \"numeric\" },\n}\n\nexport const formatDate = (locale: string, input: Date | string, format: DateFormat = \"full\"): string => {\n  const date = input instanceof Date ? input : new Date(input)\n\n  try {\n    return new Intl.DateTimeFormat(locale, dateOpts[format]).format(date)\n  } catch {\n    return date.toLocaleString(locale)\n  }\n}\n\nexport const timeSince = (locale: string, now: Date, date: Date): string => {\n  try {\n    const seconds = Math.round((now.getTime() - date.getTime()) / 1000)\n    const minutes = Math.round(seconds / 60)\n    const hours = Math.round(minutes / 60)\n    const days = Math.round(hours / 24)\n    const months = Math.round(days / 30)\n    const years = Math.round(days / 365)\n\n    const rtf = new Intl.RelativeTimeFormat(locale, { numeric: \"auto\" })\n    return (\n      (seconds < 60 && rtf.format(-1 * seconds, \"seconds\")) ||\n      (minutes < 60 && rtf.format(-1 * minutes, \"minutes\")) ||\n      (hours < 24 && rtf.format(-1 * hours, \"hours\")) ||\n      (days < 30 && rtf.format(-1 * days, \"days\")) ||\n      (days < 365 && rtf.format(-1 * months, \"months\")) ||\n      rtf.format(-1 * years, \"years\")\n    )\n  } catch {\n    return formatDate(locale, date, \"short\")\n  }\n}\n\nexport const fileToBase64 = async (file: File): Promise<string> => {\n  return new Promise<string>((resolve, reject) => {\n    const reader = new FileReader()\n    reader.addEventListener(\n      \"load\",\n      () => {\n        const parts = (reader.result as string).split(\"base64,\")\n        resolve(parts[1])\n      },\n      false\n    )\n\n    reader.addEventListener(\n      \"error\",\n      () => {\n        reject(reader.error)\n      },\n      false\n    )\n\n    reader.readAsDataURL(file)\n  })\n}\n\nexport const timeAgo = (date: string | Date): number => {\n  const d = date instanceof Date ? date : new Date(date)\n  return (new Date().getTime() - d.getTime()) / 1000\n}\n\nexport const isCookieEnabled = (): boolean => {\n  try {\n    document.cookie = \"cookietest=1\"\n    const ret = document.cookie.indexOf(\"cookietest=\") !== -1\n    document.cookie = \"cookietest=1; expires=Thu, 01-Jan-1970 00:00:01 GMT\"\n    return ret\n  } catch (e) {\n    return false\n  }\n}\n\nexport const uploadedImageURL = (bkey: string | undefined, size?: number): string | undefined => {\n  if (bkey) {\n    if (size) {\n      return `${Fider.settings.assetsURL}/static/images/${bkey}?size=${size}`\n    }\n    return `${Fider.settings.assetsURL}/static/images/${bkey}`\n  }\n  return undefined\n}\n\nexport const truncate = (input: string, maxLength: number): string => {\n  if (input && input.length > maxLength) {\n    return `${input.substr(0, maxLength)}...`\n  }\n  return input\n}\n\nexport type StringObject<T = any> = {\n  [key: string]: T\n}\n\nexport const copyToClipboard = (text: string): Promise<void> => {\n  if (window.navigator && window.navigator.clipboard && window.navigator.clipboard.writeText) {\n    return window.navigator.clipboard.writeText(text)\n  }\n  return Promise.reject(new Error(\"Clipboard API not available\"))\n}\n\nexport const clearUrlHash = (replace?: boolean) => {\n  const oldURL = window.location.href\n  const newURL = window.location.pathname + window.location.search\n  if (replace) {\n    window.history.replaceState(\"\", document.title, newURL)\n  } else {\n    window.history.pushState(\"\", document.title, newURL)\n  }\n  // Trigger event manually\n  const hashChangeEvent = new HashChangeEvent(\"hashchange\", {\n    oldURL,\n    newURL,\n    cancelable: true,\n    bubbles: true,\n    composed: false,\n  })\n  if (!window.dispatchEvent(hashChangeEvent)) {\n    // Event got cancelled\n    window.history.replaceState(\"\", document.title, oldURL)\n  }\n}\n","import { i18n, I18n } from \"@lingui/core\"\nimport { en, pt, fr, el, de, se, pl, ru, sk, nl, es, tr, it, zh } from \"make-plural/plurals\"\n\nexport function activateI18NSync(locale: string, messages?: any): I18n {\n  i18n.loadLocaleData(\"en\", { plurals: en })\n  i18n.loadLocaleData(\"pt-BR\", { plurals: pt })\n  i18n.loadLocaleData(\"sv-SE\", { plurals: se })\n  i18n.loadLocaleData(\"es-ES\", { plurals: es })\n  i18n.loadLocaleData(\"el\", { plurals: el })\n  i18n.loadLocaleData(\"it\", { plurals: it })\n  i18n.loadLocaleData(\"nl\", { plurals: nl })\n  i18n.loadLocaleData(\"de\", { plurals: de })\n  i18n.loadLocaleData(\"fr\", { plurals: fr })\n  i18n.loadLocaleData(\"pl\", { plurals: pl })\n  i18n.loadLocaleData(\"ru\", { plurals: ru })\n  i18n.loadLocaleData(\"sk\", { plurals: sk })\n  i18n.loadLocaleData(\"tr\", { plurals: tr })\n  i18n.loadLocaleData(\"zh-CH\", { plurals: zh })\n  i18n.load(locale, messages)\n  i18n.activate(locale)\n  return i18n\n}\n\nexport async function activateI18N(locale: string): Promise<I18n> {\n  try {\n    const content = await import(\n      /* webpackChunkName: \"locale-[request]\" */\n      `@locale/${locale}/client.json`\n    )\n    return activateI18NSync(locale, content.messages)\n  } catch (err) {\n    console.error(err)\n    return activateI18NSync(locale)\n  }\n}\n","import { marked } from \"marked\"\nimport DOMPurify from \"dompurify\"\n\nmarked.setOptions({\n  headerIds: false,\n  xhtml: true,\n  smartLists: true,\n  gfm: true,\n  breaks: true,\n})\n\nif (DOMPurify.isSupported) {\n  DOMPurify.setConfig({\n    USE_PROFILES: {\n      html: true,\n    },\n    ADD_ATTR: [\"target\"],\n  })\n}\n\nconst link = (href: string, title: string, text: string) => {\n  const titleAttr = title ? ` title=${title}` : \"\"\n  return `<a class=\"text-link\" href=\"${href}\"${titleAttr} rel=\"noopener nofollow\" target=\"_blank\">${text}</a>`\n}\n\nconst fullRenderer = new marked.Renderer()\nfullRenderer.image = () => \"\"\nfullRenderer.link = link\n\nconst plainTextRenderer = new marked.Renderer()\nplainTextRenderer.link = (_href, _title, text) => text\nplainTextRenderer.image = () => \"\"\nplainTextRenderer.br = () => \" \"\nplainTextRenderer.strong = (text) => text\nplainTextRenderer.list = (body) => body\nplainTextRenderer.listitem = (text) => `${text} `\nplainTextRenderer.heading = (text) => text\nplainTextRenderer.paragraph = (text) => ` ${text} `\nplainTextRenderer.code = (code) => code\nplainTextRenderer.codespan = (code) => code\nplainTextRenderer.html = (html) => html\nplainTextRenderer.del = (text) => text\n\nconst entities: { [key: string]: string } = {\n  \"<\": \"&lt;\",\n  \">\": \"&gt;\",\n}\n\nconst encodeHTML = (s: string) => s.replace(/[<>]/g, (tag) => entities[tag] || tag)\nconst sanitize = (input: string) => (DOMPurify.isSupported ? DOMPurify.sanitize(input) : input)\n\nexport const full = (input: string): string => {\n  return sanitize(marked(encodeHTML(input), { renderer: fullRenderer }).trim())\n}\n\nexport const plainText = (input: string): string => {\n  return sanitize(marked(encodeHTML(input), { renderer: plainTextRenderer }).trim())\n}\n","const toastify = () => import(/* webpackChunkName: \"toastify\" */ \"./toastify\")\n\nexport const success = (content: string | JSX.Element) => {\n  return toastify().then((toast) => {\n    toast.success(content)\n  })\n}\n\nexport const error = (content: string | JSX.Element) => {\n  return toastify().then((toast) => {\n    toast.error(content)\n  })\n}\n","import { Fider } from \"@fider/services\"\n\nconst navigator = {\n  url: () => {\n    return window.location.href\n  },\n  goHome: () => {\n    window.location.href = \"/\"\n  },\n  goTo: (url: string) => {\n    const isEqual = window.location.href === url || window.location.pathname === url\n    if (!isEqual) {\n      window.location.href = url\n    }\n  },\n  replaceState: (path: string): void => {\n    if (history.replaceState !== undefined) {\n      const newURL = Fider.settings.baseURL + path\n      window.history.replaceState({ path: newURL }, \"\", newURL)\n    }\n  },\n}\n\nexport default navigator\n","import navigator from \"./navigator\"\n\nexport const getNumber = (name: string): number | undefined => {\n  return parseInt(get(name), 10) || undefined\n}\n\nexport const set = (name: string, value: any): string => {\n  const uri = navigator.url()\n  const re = new RegExp(\"([?&])\" + name + \"=.*?(&|$)\", \"i\")\n  if (uri.match(re)) {\n    return uri.replace(re, \"$1\" + name + \"=\" + value + \"$2\")\n  } else {\n    const separator = uri.indexOf(\"?\") !== -1 ? \"&\" : \"?\"\n    return uri + separator + name + \"=\" + value\n  }\n}\n\nexport const get = (name: string): string => {\n  name = name.replace(/[[\\]]/g, \"\\\\$&\")\n  const regex = new RegExp(\"[?&]\" + name + \"(=([^&#]*)|&|#|$)\")\n  const results = regex.exec(navigator.url())\n\n  if (!results || !results[2]) {\n    return \"\"\n  }\n\n  return decodeURIComponent(results[2].replace(/\\+/g, \" \"))\n}\n\nexport const getArray = (name: string): string[] => {\n  const qs = get(name)\n  if (qs) {\n    return qs.split(\",\").filter((i) => i)\n  }\n\n  return []\n}\n\nexport interface QueryString {\n  [key: string]: string | string[] | number | undefined\n}\n\nexport const stringify = (object: QueryString | undefined): string => {\n  if (!object) {\n    return \"\"\n  }\n\n  let qs = \"\"\n\n  for (const key of Object.keys(object)) {\n    const symbol = qs ? \"&\" : \"?\"\n    const value = object[key]\n    if (value instanceof Array) {\n      if (value.length > 0) {\n        qs += `${symbol}${key}=${value.join(\",\")}`\n      }\n    } else if (value) {\n      qs += `${symbol}${key}=${encodeURIComponent(value.toString()).replace(/%20/g, \"+\")}`\n    }\n  }\n\n  return qs\n}\n","export const isTouch = (): boolean => {\n  return \"ontouchstart\" in window || navigator.maxTouchPoints > 0\n}\n","import { http, Result } from \"@fider/services/http\"\nimport { UserSettings, UserAvatarType, ImageUpload } from \"@fider/models\"\n\ninterface UpdateUserSettings {\n  name: string\n  avatar?: ImageUpload\n  avatarType: UserAvatarType\n  settings: UserSettings\n}\n\nexport const updateUserSettings = async (request: UpdateUserSettings): Promise<Result> => {\n  return await http.post(\"/_api/user/settings\", request)\n}\n\nexport const changeUserEmail = async (email: string): Promise<Result> => {\n  return await http.post(\"/_api/user/change-email\", {\n    email,\n  })\n}\n\nexport const deleteCurrentAccount = async (): Promise<Result> => {\n  return await http.delete(\"/_api/user\")\n}\n\nexport const regenerateAPIKey = async (): Promise<Result<{ apiKey: string }>> => {\n  return await http.post<{ apiKey: string }>(\"/_api/user/regenerate-apikey\")\n}\n","import { http, Result } from \"@fider/services/http\"\nimport { Tag } from \"@fider/models\"\n\nexport const createTag = async (name: string, color: string, isPublic: boolean): Promise<Result<Tag>> => {\n  return http.post<Tag>(`/api/v1/tags`, { name, color, isPublic }).then(http.event(\"tag\", \"create\"))\n}\n\nexport const updateTag = async (slug: string, name: string, color: string, isPublic: boolean): Promise<Result<Tag>> => {\n  return http.put<Tag>(`/api/v1/tags/${slug}`, { name, color, isPublic }).then(http.event(\"tag\", \"update\"))\n}\n\nexport const deleteTag = async (slug: string): Promise<Result> => {\n  return http.delete(`/api/v1/tags/${slug}`).then(http.event(\"tag\", \"delete\"))\n}\n\nexport const assignTag = async (slug: string, postNumber: number): Promise<Result> => {\n  return http.post(`/api/v1/posts/${postNumber}/tags/${slug}`).then(http.event(\"tag\", \"assign\"))\n}\n\nexport const unassignTag = async (slug: string, postNumber: number): Promise<Result> => {\n  return http.delete(`/api/v1/posts/${postNumber}/tags/${slug}`).then(http.event(\"tag\", \"unassign\"))\n}\n","import { http, Result, querystring } from \"@fider/services\"\nimport { Post, Vote, ImageUpload } from \"@fider/models\"\n\nexport const getAllPosts = async (): Promise<Result<Post[]>> => {\n  return await http.get<Post[]>(\"/api/v1/posts\")\n}\n\nexport interface SearchPostsParams {\n  query?: string\n  view?: string\n  limit?: number\n  tags?: string[]\n}\n\nexport const searchPosts = async (params: SearchPostsParams): Promise<Result<Post[]>> => {\n  return await http.get<Post[]>(\n    `/api/v1/posts${querystring.stringify({\n      tags: params.tags,\n      query: params.query,\n      view: params.view,\n      limit: params.limit,\n    })}`\n  )\n}\n\nexport const deletePost = async (postNumber: number, text: string): Promise<Result> => {\n  return http\n    .delete(`/api/v1/posts/${postNumber}`, {\n      text,\n    })\n    .then(http.event(\"post\", \"delete\"))\n}\n\nexport const addVote = async (postNumber: number): Promise<Result> => {\n  return http.post(`/api/v1/posts/${postNumber}/votes`).then(http.event(\"post\", \"vote\"))\n}\n\nexport const removeVote = async (postNumber: number): Promise<Result> => {\n  return http.delete(`/api/v1/posts/${postNumber}/votes`).then(http.event(\"post\", \"unvote\"))\n}\n\nexport const subscribe = async (postNumber: number): Promise<Result> => {\n  return http.post(`/api/v1/posts/${postNumber}/subscription`).then(http.event(\"post\", \"subscribe\"))\n}\n\nexport const unsubscribe = async (postNumber: number): Promise<Result> => {\n  return http.delete(`/api/v1/posts/${postNumber}/subscription`).then(http.event(\"post\", \"unsubscribe\"))\n}\n\nexport const listVotes = async (postNumber: number): Promise<Result<Vote[]>> => {\n  return http.get<Vote[]>(`/api/v1/posts/${postNumber}/votes`)\n}\n\nexport const createComment = async (postNumber: number, content: string, attachments: ImageUpload[]): Promise<Result> => {\n  return http.post(`/api/v1/posts/${postNumber}/comments`, { content, attachments }).then(http.event(\"comment\", \"create\"))\n}\n\nexport const updateComment = async (postNumber: number, commentID: number, content: string, attachments: ImageUpload[]): Promise<Result> => {\n  return http.put(`/api/v1/posts/${postNumber}/comments/${commentID}`, { content, attachments }).then(http.event(\"comment\", \"update\"))\n}\n\nexport const deleteComment = async (postNumber: number, commentID: number): Promise<Result> => {\n  return http.delete(`/api/v1/posts/${postNumber}/comments/${commentID}`).then(http.event(\"comment\", \"delete\"))\n}\ninterface ToggleReactionResponse {\n  added: boolean\n}\n\nexport const toggleCommentReaction = async (postNumber: number, commentID: number, emoji: string): Promise<Result<ToggleReactionResponse>> => {\n  return http.post<ToggleReactionResponse>(`/api/v1/posts/${postNumber}/comments/${commentID}/reactions/${emoji}`)\n}\n\ninterface SetResponseInput {\n  status: string\n  text: string\n  originalNumber: number\n}\n\nexport const respond = async (postNumber: number, input: SetResponseInput): Promise<Result> => {\n  return http\n    .put(`/api/v1/posts/${postNumber}/status`, {\n      status: input.status,\n      text: input.text,\n      originalNumber: input.originalNumber,\n    })\n    .then(http.event(\"post\", \"respond\"))\n}\n\ninterface CreatePostResponse {\n  id: number\n  number: number\n  title: string\n  slug: string\n}\n\nexport const createPost = async (title: string, description: string, attachments: ImageUpload[]): Promise<Result<CreatePostResponse>> => {\n  return http.post<CreatePostResponse>(`/api/v1/posts`, { title, description, attachments }).then(http.event(\"post\", \"create\"))\n}\n\nexport const updatePost = async (postNumber: number, title: string, description: string, attachments: ImageUpload[]): Promise<Result> => {\n  return http.put(`/api/v1/posts/${postNumber}`, { title, description, attachments }).then(http.event(\"post\", \"update\"))\n}\n","import { http, Result } from \"@fider/services/http\"\nimport { UserRole, OAuthConfig, ImageUpload, EmailVerificationKind } from \"@fider/models\"\n\nexport interface CheckAvailabilityResponse {\n  message: string\n}\n\nexport interface CreateTenantRequest {\n  legalAgreement: boolean\n  tenantName: string\n  subdomain?: string\n  name?: string\n  token?: string\n  email?: string\n}\n\nexport interface CreateTenantResponse {\n  token?: string\n}\n\nexport const createTenant = async (request: CreateTenantRequest): Promise<Result<CreateTenantResponse>> => {\n  return await http.post<CreateTenantResponse>(\"/_api/tenants\", request)\n}\n\nexport interface UpdateTenantSettingsRequest {\n  logo?: ImageUpload\n  title: string\n  invitation: string\n  welcomeMessage: string\n  cname: string\n  locale: string\n}\n\nexport const updateTenantSettings = async (request: UpdateTenantSettingsRequest): Promise<Result> => {\n  return await http.post(\"/_api/admin/settings/general\", request)\n}\n\nexport const updateTenantAdvancedSettings = async (customCSS: string): Promise<Result> => {\n  return await http.post(\"/_api/admin/settings/advanced\", { customCSS })\n}\n\nexport const updateTenantPrivacy = async (isPrivate: boolean): Promise<Result> => {\n  return await http.post(\"/_api/admin/settings/privacy\", {\n    isPrivate,\n  })\n}\n\nexport const updateTenantEmailAuthAllowed = async (isEmailAuthAllowed: boolean): Promise<Result> => {\n  return await http.post(\"/_api/admin/settings/emailauth\", {\n    isEmailAuthAllowed,\n  })\n}\n\nexport const checkAvailability = async (subdomain: string): Promise<Result<CheckAvailabilityResponse>> => {\n  return await http.get<CheckAvailabilityResponse>(`/_api/tenants/${subdomain}/availability`)\n}\n\nexport const signIn = async (email: string): Promise<Result> => {\n  return await http.post(\"/_api/signin\", {\n    email,\n  })\n}\n\nexport const completeProfile = async (kind: EmailVerificationKind, key: string, name: string): Promise<Result> => {\n  return await http.post(\"/_api/signin/complete\", {\n    kind,\n    key,\n    name,\n  })\n}\n\nexport const changeUserRole = async (userID: number, role: UserRole): Promise<Result> => {\n  return await http.post(`/_api/admin/roles/${role}/users`, {\n    userID,\n  })\n}\n\nexport const blockUser = async (userID: number): Promise<Result> => {\n  return await http.put(`/_api/admin/users/${userID}/block`)\n}\n\nexport const unblockUser = async (userID: number): Promise<Result> => {\n  return await http.delete(`/_api/admin/users/${userID}/block`)\n}\n\nexport const getOAuthConfig = async (provider: string): Promise<Result<OAuthConfig>> => {\n  return await http.get<OAuthConfig>(`/_api/admin/oauth/${provider}`)\n}\n\nexport interface CreateEditOAuthConfigRequest {\n  provider: string\n  status: number\n  displayName: string\n  clientID: string\n  clientSecret: string\n  authorizeURL: string\n  tokenURL: string\n  scope: string\n  profileURL: string\n  jsonUserIDPath: string\n  jsonUserNamePath: string\n  jsonUserEmailPath: string\n  logo?: ImageUpload\n  isTrusted: boolean\n}\n\nexport const saveOAuthConfig = async (request: CreateEditOAuthConfigRequest): Promise<Result> => {\n  return await http.post(\"/_api/admin/oauth\", request)\n}\n","import { http, Result } from \"@fider/services\"\nimport { Notification } from \"@fider/models\"\n\nexport const getTotalUnreadNotifications = async (): Promise<Result<number>> => {\n  return http.get<{ total: number }>(\"/_api/notifications/unread/total\").then((result) => {\n    return {\n      ok: result.ok,\n      error: result.error,\n      data: result.data ? result.data.total : 0,\n    }\n  })\n}\n\nexport const getAllNotifications = async (): Promise<Result<Notification[]>> => {\n  return http.get<Notification[]>(\"/_api/notifications/unread\")\n}\n\nexport const markAllAsRead = async (): Promise<Result> => {\n  return await http.post(\"/_api/notifications/read-all\")\n}\n","import { http, Result } from \"@fider/services\"\n\nexport const sendInvites = async (subject: string, message: string, recipients: string[]): Promise<Result> => {\n  return http.post(\"/api/v1/invitations/send\", { subject, message, recipients }).then(http.event(\"invite\", \"send\"))\n}\n\nexport const sendSampleInvite = async (subject: string, message: string): Promise<Result> => {\n  return http.post(\"/api/v1/invitations/sample\", { subject, message }).then(http.event(\"invite\", \"sample\"))\n}\n","import { http, Result, navigator, analytics } from \"@fider/services\"\n\nconst ignoreErrors = [\n  \"http://gj.track.uc.cn/collect\", // CSP error: UC Browser tries to use sendBeacon to this domain, which is blocked by our CSP rule\n  \"null is not an object (evaluating 'c.sheet.insertRule')\", // CSP error: UC Browser throws this error even when page is loaded sucessfully\n  \"Refused to evaluate a string as JavaScript because 'unsafe-eval'\", // CSP error: usually thrown because of bad Chrome Extensions\n  \"vid_mate_check is not defined\", // CSP error: thrown by VidMate, an Android Browser\n  \"SecurityError: Failed to read the 'cssRules' property from 'CSSStyleSheet': Cannot access rules\", // CSP error: usually thrown because of bad Chrome Extensions\n]\n\nexport const logError = async (message: string, err?: Error): Promise<Result | undefined> => {\n  for (const pattern of ignoreErrors) {\n    if (message.indexOf(pattern) >= 0) {\n      return\n    }\n  }\n\n  const data = {\n    url: navigator.url(),\n    stack: err ? err.stack : \"<not available>\",\n  }\n\n  try {\n    analytics.error(err)\n    return await http.post(\"/_api/log-error\", { message, data })\n  } catch (err) {\n    console.error(err)\n  }\n}\n","import { http, Result, StringObject } from \"@fider/services\"\nimport { WebhookData, WebhookPreviewResult, WebhookTriggerResult, WebhookType } from \"@fider/models\"\n\nexport const createWebhook = async (data: WebhookData): Promise<Result<{ id: number }>> => {\n  return await http.post(`/_api/admin/webhook`, data)\n}\n\nexport const updateWebhook = async (id: number, data: WebhookData): Promise<Result> => {\n  return await http.put(`/_api/admin/webhook/${id}`, data)\n}\n\nexport const deleteWebhook = async (id: number): Promise<Result> => {\n  return await http.delete(`/_api/admin/webhook/${id}`)\n}\n\nexport const testWebhook = async (id: number): Promise<Result<WebhookTriggerResult>> => {\n  return await http.get(`/_api/admin/webhook/test/${id}`)\n}\n\nexport const previewWebhook = async (type: WebhookType, url: string, content: string): Promise<Result<WebhookPreviewResult>> => {\n  return await http.post(\"/_api/admin/webhook/preview\", { type, url, content })\n}\n\nexport const getWebhookHelp = async (type: WebhookType): Promise<Result<StringObject>> => {\n  return await http.get(`/_api/admin/webhook/props/${type}`)\n}\n","import { http, Result } from \"../http\"\n\ninterface CheckoutPageLink {\n  url: string\n}\n\nexport const generateCheckoutLink = async (planId: string): Promise<Result<CheckoutPageLink>> => {\n  return await http.post(\"/_api/billing/checkout-link\", { planId })\n}\n","import { I18nProvider } from \"@lingui/react\"\nimport React from \"react\"\nimport ReactDOM from \"react-dom\"\nimport { i18n } from \"@lingui/core\"\n\nimport { ToastContainer, toast, ToastContent, ToastOptions } from \"react-toastify\"\nimport \"react-toastify/dist/ReactToastify.css\"\n\nlet hasContainer = false\n\nconst setup = () => {\n  if (!hasContainer) {\n    hasContainer = true\n    ReactDOM.render(\n      <I18nProvider i18n={i18n}>\n        <ToastContainer position={toast.POSITION.TOP_RIGHT} />\n      </I18nProvider>,\n      document.getElementById(\"root-toastify\")\n    )\n  }\n}\n\nexport const success = (content: ToastContent, options?: ToastOptions) => {\n  setup()\n  toast.success(content, options)\n}\n\nexport const error = (content: ToastContent, options?: ToastOptions) => {\n  setup()\n  toast.error(content, options)\n}\n"],"names":["HoverInfo","props","Elem","href","classList","classSet","clickable","undefined","onClick","React","className","text","target","Icon","width","height","sprite","IconInformationCircle","styles","style","src","viewBox","xlinkHref","id","ErrorBoundary","constructor","super","this","state","error","errorInfo","componentDidCatch","onError","setState","render","FiderContext","Consumer","fider","ErrorPage","showDetails","isProduction","children","ShowPostResponse","status","PostStatus","Get","response","show","HStack","ShowPostStatus","UserName","user","Duplicate","original","number","slug","title","DuplicateDetails","Markdown","StatusDetails","value","i18n","_","message","textColor","color","components","r","substring","g","b","R","parseInt","G","B","getRGB","ShowTag","circular","link","tag","name","isPublic","backgroundColor","xmlns","fill","fillRule","d","clipRule","Header","useFider","isSignInModalOpen","setIsSignInModalOpen","useState","SignInModal","isOpen","onClose","hideModal","justify","TenantLogo","size","session","tenant","isAuthenticated","spacing","NotificationIndicator","UserMenu","e","preventDefault","Trans","ButtonClickEvent","preventEnable","shouldEnable","canEnable","Button","clicked","setClicked","unmountedContainer","useRef","useEffect","current","variant","disabled","buttonContent","onClickProp","rel","async","stopPropagation","event","type","defaultProps","ValidationContext","Form","autoComplete","DisplayError","Provider","arrayToTag","items","map","m","key","hasError","field","errors","err","dict","reduce","result","push","fields","Object","keys","prototype","hasOwnProperty","call","forEach","t","length","Input","onChange","currentTarget","suffix","icon","onIconClick","ctx","label","htmlFor","afterLabel","center","tabIndex","noTabFocus","ref","inputRef","autoFocus","onFocus","maxLength","placeholder","ImageUploader","_defineProperty","files","file","alert","base64","fileToBase64","bkey","upload","fileName","content","contentType","remove","previewURL","instanceID","fileSelector","click","showModal","uploadedImageURL","modal","Modal","Window","closeModal","Content","alt","Footer","isUploading","hasFile","openModal","removeFile","fileChanged","accept","selectFile","IconPhotograph","MultiImageUploader","instances","removed","count","maxUploads","addNewElement","triggerOnChange","bkeys","uploads","k","concat","filter","x","btoa","Math","random","toString","element","imageUploaded","elements","TextArea","Textarea","minRows","RadioButton","selected","setSelected","defaultOption","option","_props$onSelect","onSelect","inputs","options","checked","VStack","Select","filtered","getOption","defaultValue","o","Field","Checkbox","setChecked","isChecked","ImageViewerModal","loadedPreview","Loader","onLoad","onPreviewLoad","imgSrc","ImageViewer","setShowModal","loadedThumbnail","setLoadedThumbnail","setLoadedPreview","onThumbnailLoad","html","markdown","tagName","dangerouslySetInnerHTML","__html","truncate","DevBanner","Avatar","avatarURL","AvatarStack","users","i","Message","showIcon","IconExclamation","IconExclamationCircle","IconCheckCircle","alignment","Hint","cacheKey","permanentCloseKey","isClosed","setIsClosed","cache","local","has","condition","IconX","close","set","TermsOfService","settings","hasLegal","PrivacyPolicy","LegalNotice","0","1","LegalFooter","align","LegalAgreement","SocialSignInButton","redirectTo","window","location","url","logoURL","displayName","OAuthProviderLogo","SignInControl","showEmailForm","setShowEmailForm","isEmailAuthAllowed","email","setEmail","setError","providersLen","oauth","isCookieEnabled","provider","useEmail","Divider","device","actions","ok","onEmailSent","Moment","date","format","now","Date","display","getTime","formatDate","locale","timeSince","tooltip","ModalWindow","root","document","getElementById","body","overflow","addEventListener","keyDown","removeEventListener","keyCode","canClose","ReactDOM","evt","isStaff","role","isCollaborator","showEmail","setShow","useTimeout","TenantLogoURL","logoBlobKey","useFiderIfEmpty","systemProvidersLogo","google","facebook","github","OAuthProviderLogoURL","Toggle","active","setActive","toggle","newActive","onToggle","PoweredByFider","_window","_window$location","source","encodeURIComponent","host","campaign","slot","PageTitle","subtitle","DropdownContext","createContext","Dropdown","node","setIsOpen","position","changeToggleState","newState","onToggled","handleClick","contains","listClassName","wide","fullsceenSm","toggleIsOpen","renderHandle","ListItem","useContext","Money","formatter","Intl","NumberFormat","currency","amount","setTimeout","values","VoteCounter","hasVoted","setHasVoted","post","votesCount","setVotesCount","isDisabled","closed","isReadOnly","vote","action","FaCaretUp","NotificationItem","_ref","notification","openNotification","authorName","Fider","currentLocale","createdAt","NotificationIcon","_ref2","unreadNotifications","IconBell","setUnreadNotifications","showingNotifications","setShowingNotifications","recent","setRecent","unread","setUnread","then","data","item","read","reload","divide","n","NoDataIllustration","availableEmojis","Reactions","emojiSelectorRef","toggleReaction","reactions","isEmojiSelectorOpen","setIsEmojiSelectorOpen","handleClickOutside","ReactionAdd","emoji","reaction","_extends","includesMe","ReadOnlyNotice","isAdministrator","Stack","dir","flex","filterable","All","Error","TenantStatus","UserAvatarType","UserStatus","UserRole","Open","Planned","Started","Completed","Declined","Collaborator","Administrator","OAuthConfigStatus","Disabled","Enabled","EmailVerificationKind","BillingStatus","WebhookType","WebhookStatus","request","method","headers","fetch","JSON","stringify","credentials","json","notify","toResult","truncatedBody","http","get","put","delete","category","analytics","storage","setItem","localStorage","getItem","_len","arguments","Array","_key","removeItem","_len2","_key2","sessionStorage","_len3","_key3","eventCategory","eventAction","ga","exDescription","stack","exFatal","FiderSession","pPage","page","pContextID","contextID","pProps","pUser","pTenant","initData","pSettings","pSession","el","parse","textContent","innerText","Locked","environment","isSingleHostMode","mode","jwt","decode","token","segments","split","atob","input","classes","trim","dateOpts","day","month","year","short","full","hour","minute","DateTimeFormat","toLocaleString","seconds","round","minutes","hours","days","months","years","rtf","RelativeTimeFormat","numeric","Promise","resolve","reject","reader","FileReader","parts","readAsDataURL","timeAgo","cookie","ret","indexOf","assetsURL","substr","copyToClipboard","navigator","clipboard","writeText","clearUrlHash","replace","oldURL","newURL","pathname","search","history","replaceState","pushState","hashChangeEvent","HashChangeEvent","cancelable","bubbles","composed","dispatchEvent","activateI18NSync","messages","loadLocaleData","plurals","en","pt","se","es","it","nl","de","fr","pl","ru","sk","tr","zh","load","activate","activateI18N","console","marked","setOptions","headerIds","xhtml","smartLists","gfm","breaks","DOMPurify","USE_PROFILES","ADD_ATTR","fullRenderer","Renderer","image","plainTextRenderer","_href","_title","br","strong","list","listitem","heading","paragraph","code","codespan","del","entities","encodeHTML","s","sanitize","renderer","plainText","toastify","success","toast","goHome","goTo","path","baseURL","getNumber","uri","re","RegExp","match","separator","results","exec","decodeURIComponent","getArray","qs","object","symbol","join","isTouch","maxTouchPoints","updateUserSettings","changeUserEmail","deleteCurrentAccount","regenerateAPIKey","createTag","updateTag","deleteTag","assignTag","postNumber","unassignTag","getAllPosts","searchPosts","querystring","tags","params","query","view","limit","deletePost","addVote","removeVote","subscribe","unsubscribe","listVotes","createComment","attachments","updateComment","commentID","deleteComment","toggleCommentReaction","respond","originalNumber","createPost","description","updatePost","createTenant","updateTenantSettings","updateTenantAdvancedSettings","customCSS","updateTenantPrivacy","isPrivate","updateTenantEmailAuthAllowed","checkAvailability","subdomain","signIn","completeProfile","kind","changeUserRole","userID","blockUser","unblockUser","getOAuthConfig","saveOAuthConfig","getTotalUnreadNotifications","total","getAllNotifications","markAllAsRead","sendInvites","subject","recipients","sendSampleInvite","ignoreErrors","logError","pattern","createWebhook","updateWebhook","deleteWebhook","testWebhook","previewWebhook","getWebhookHelp","generateCheckoutLink","planId","hasContainer","setup","I18nProvider","ToastContainer","POSITION","TOP_RIGHT"],"sourceRoot":""}