{"version":3,"file":"js/common.4514fe9c704700789087.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/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 \n \n \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 \n }\n\n return (\n \n \n \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 {\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 {(fider) => }\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
\n {\" \"}\n \n {original.title}\n \n
\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
\n \n
\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
\n \n {status.show && }\n \n · \n \n \n {status === PostStatus.Duplicate ? DuplicateDetails(props) : StatusDetails(props)}\n
\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 {title}\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 \n {!props.tag.isPublic && !props.circular && (\n \n \n \n )}\n {props.circular ? \"\" : props.tag.name || \"Tag\"}\n \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
\n \n \n
\n \n \n \n

{fider.session.tenant.name}

\n
\n {fider.session.isAuthenticated && (\n \n \n \n \n )}\n {!fider.session.isAuthenticated && (\n \n Sign in\n \n )}\n
\n
\n
\n
\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 | 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 = (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 \n {props.children}\n \n )\n } else if (onClickProp) {\n const onClick = async (e?: React.SyntheticEvent) => {\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 \n )\n } else {\n buttonContent = (\n \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({})\n\nexport const Form: React.FunctionComponent = (props) => {\n const className = classSet({\n \"c-form\": true,\n [props.className || \"\"]: props.className,\n })\n\n return (\n
\n \n {props.children}\n \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) =>
  • {m}
  • )\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
    \n
      {items}
    \n
    \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\n onChange?: (value: string) => void\n}\n\nexport const Input: React.FunctionComponent = (props) => {\n const onChange = (e: React.FormEvent) => {\n if (props.onChange) {\n props.onChange(e.currentTarget.value)\n }\n }\n\n const suffix = typeof props.suffix === \"string\" ? {props.suffix} : props.suffix\n\n const icon = props.icon ? : undefined\n\n return (\n \n {(ctx) => (\n \n {!!props.label && (\n \n )}\n \n \n {icon}\n {suffix}\n \n \n {props.children}\n \n )}\n \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 {\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) => {\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 \n {this.props.bkey ? \"\" : \"\"}\n\n \n \n \n \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 \n {(ctx) => (\n \n {this.modal()}\n {this.props.label && }\n\n {hasFile && (\n
    \n \"\"\n {!this.props.disabled && (\n \n )}\n
    \n )}\n\n (this.fileSelector = e)} type=\"file\" onChange={this.fileChanged} accept=\"image/*\" />\n {!hasFile && (\n \n )}\n \n {this.props.children}\n \n )}\n
    \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 {\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: ,\n }\n }\n\n public render() {\n const elements = Object.keys(this.state.instances).map((k) => this.state.instances[k].element)\n return (\n \n {(ctx) => (\n \n
    {elements}
    \n \n \n )}\n
    \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\n onFocus?: React.FocusEventHandler\n className?: string\n}\n\nexport const TextArea: React.FunctionComponent = (props) => {\n const onChange = (e: React.FormEvent) => {\n if (props.onChange) {\n props.onChange(e.currentTarget.value)\n }\n }\n\n return (\n \n {(ctx) => (\n <>\n
    \n {!!props.label && (\n \n )}\n \n \n {props.children}\n
    \n \n )}\n
    \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 \n \n \n \n ))\n\n return (\n
    \n \n {inputs}\n
    \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 = (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(getOption(props.defaultValue))\n const onChange = (e: React.FormEvent) => {\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 \n {(ctx) => (\n <>\n
    \n {!!props.label && }\n \n {props.options.map((option) => (\n \n ))}\n \n \n {props.children}\n
    \n \n )}\n
    \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 = (props) => {\n const fields = props.field ? [props.field] : undefined\n return (\n \n {(ctx) => (\n \n {!!props.label && (\n \n )}\n {props.children}\n \n \n )}\n \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 = (props) => {\n const [checked, setChecked] = useState(props.checked || false)\n\n const onChange = (e: React.ChangeEvent) => {\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 \n {(ctx) => (\n \n
    \n \n \n \n \n \n
    \n \n )}\n
    \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 \n \n {!props.loadedPreview && }\n \"\"\n \n\n \n \n \n \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
    \n \n {!loadedThumbnail && }\n \"\"\n
    \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
    DEV
    \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 {props.user.name}\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
    \n {props.users.map((x, i) => (\n \n ))}\n
    \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 = (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 \n {props.showIcon === true && }\n {props.children}\n \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 = (props) => {\n const cacheKey: string | undefined = props.permanentCloseKey ? `Hint-Closed-${props.permanentCloseKey}` : undefined\n const [isClosed, setIsClosed] = useState(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 \n {props.children}\n {cacheKey && }\n \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 \n Terms of Service\n \n )\n }\n return null\n}\n\nexport const PrivacyPolicy = () => {\n const fider = useFider()\n\n if (fider.settings.hasLegal) {\n return (\n \n Privacy Policy\n \n )\n }\n return null\n}\n\nexport const LegalNotice = () => {\n const fider = useFider()\n\n if (fider.settings.hasLegal) {\n return (\n

    \n \n By signing in, you agree to the and .\n \n

    \n )\n }\n return null\n}\n\nexport const LegalFooter = () => {\n const fider = useFider()\n\n if (fider.settings.hasLegal) {\n return (\n \n \n \n )\n }\n return null\n}\n\nexport const LegalAgreement: React.FunctionComponent = (props) => {\n const fider = useFider()\n\n if (fider.settings.hasLegal) {\n return (\n \n \n I have read and agree to the and .\n \n \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 \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 = (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(undefined)\n\n const forceShowEmailForm = (e: React.MouseEvent) => {\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 \n

    Cookies Required

    \n

    Cookies are not enabled on your browser. Please enable cookies in your browser preferences to continue.

    \n
    \n )\n }\n\n return (\n
    \n {providersLen > 0 && (\n <>\n
    \n {fider.settings.oauth.map((o) => (\n \n \n \n ))}\n
    \n {props.useEmail && }\n \n )}\n\n {props.useEmail &&\n (showEmailForm ? (\n
    \n

    \n Enter your email address to sign in\n

    \n
    \n \n Sign in\n \n }\n />\n \n {!fider.session.tenant.isEmailAuthAllowed && (\n

    \n Currently only allowed to sign in to an administrator account\n

    \n )}\n
    \n ) : (\n
    \n

    \n \n Email authentication has been disabled by an administrator. If you have an administrator account and need to bypass this restriction, please{\" \"}\n \n click here\n \n .\n \n

    \n
    \n ))}\n
    \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 \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 \n {display}\n \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 = (props) => {\n const root = useRef(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) => {\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
    \n
    \n
    \n {props.children}\n
    \n
    \n
    ,\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 }) =>
    {props.children}
    \nconst Content = (props: { children: React.ReactNode }) =>
    {props.children}
    \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
    {props.children}
    \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}\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
    \n {props.user.name || \"Anonymous\"}\n <>{props.user.email && ({props.user.email})}\n\n {isStaff && (\n
    \n \n \n \n
    \n )}\n
    \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
    \n
    \n {props.text && {props.text}}\n
    \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 {tenant.name}\n } else if (props.useFiderIfEmpty) {\n return \"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: `data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/PjwhRE9DVFlQRSBzdmcgIFBVQkxJQyAnLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4nICAnaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkJz48c3ZnIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDQwMCA0MDAiIGhlaWdodD0iNDAwcHgiIGlkPSJMYXllcl8xIiB2ZXJzaW9uPSIxLjEiIHZpZXdCb3g9IjAgMCA0MDAgNDAwIiB3aWR0aD0iNDAwcHgiIHhtbDpzcGFjZT0icHJlc2VydmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPjxnPjxwYXRoIGQ9Ik0xNDIuOSwyNC4yQzk3LjYsMzkuNyw1OSw3My42LDM3LjUsMTE2LjVjLTcuNSwxNC44LTEyLjksMzAuNS0xNi4yLDQ2LjhjLTguMiw0MC40LTIuNSw4My41LDE2LjEsMTIwLjMgICBjMTIuMSwyNCwyOS41LDQ1LjQsNTAuNSw2Mi4xYzE5LjksMTUuOCw0MywyNy42LDY3LjYsMzQuMWMzMSw4LjMsNjQsOC4xLDk1LjIsMWMyOC4yLTYuNSw1NC45LTIwLDc2LjItMzkuNiAgIGMyMi41LTIwLjcsMzguNi00Ny45LDQ3LjEtNzcuMmM5LjMtMzEuOSwxMC41LTY2LDQuNy05OC44Yy01OC4zLDAtMTE2LjcsMC0xNzUsMGMwLDI0LjIsMCw0OC40LDAsNzIuNmMzMy44LDAsNjcuNiwwLDEwMS40LDAgICBjLTMuOSwyMy4yLTE3LjcsNDQuNC0zNy4yLDU3LjVjLTEyLjMsOC4zLTI2LjQsMTMuNi00MSwxNi4yYy0xNC42LDIuNS0yOS44LDIuOC00NC40LTAuMWMtMTQuOS0zLTI5LTkuMi00MS40LTE3LjkgICBjLTE5LjgtMTMuOS0zNC45LTM0LjItNDIuNi01Ny4xYy03LjktMjMuMy04LTQ5LjIsMC03Mi40YzUuNi0xNi40LDE0LjgtMzEuNSwyNy00My45YzE1LTE1LjQsMzQuNS0yNi40LDU1LjYtMzAuOSAgIGMxOC0zLjgsMzctMy4xLDU0LjYsMi4yYzE1LDQuNSwyOC44LDEyLjgsNDAuMSwyMy42YzExLjQtMTEuNCwyMi44LTIyLjgsMzQuMi0zNC4yYzYtNi4xLDEyLjMtMTIsMTguMS0xOC4zICAgYy0xNy4zLTE2LTM3LjctMjguOS01OS45LTM3LjFDMjI4LjIsMTAuNiwxODMuMiwxMC4zLDE0Mi45LDI0LjJ6IiBmaWxsPSIjRkZGRkZGIi8+PGc+PHBhdGggZD0iTTE0Mi45LDI0LjJjNDAuMi0xMy45LDg1LjMtMTMuNiwxMjUuMywxLjFjMjIuMiw4LjIsNDIuNSwyMSw1OS45LDM3LjFjLTUuOCw2LjMtMTIuMSwxMi4yLTE4LjEsMTguMyAgICBjLTExLjQsMTEuNC0yMi44LDIyLjgtMzQuMiwzNC4yYy0xMS4zLTEwLjgtMjUuMS0xOS00MC4xLTIzLjZjLTE3LjYtNS4zLTM2LjYtNi4xLTU0LjYtMi4yYy0yMSw0LjUtNDAuNSwxNS41LTU1LjYsMzAuOSAgICBjLTEyLjIsMTIuMy0yMS40LDI3LjUtMjcsNDMuOWMtMjAuMy0xNS44LTQwLjYtMzEuNS02MS00Ny4zQzU5LDczLjYsOTcuNiwzOS43LDE0Mi45LDI0LjJ6IiBmaWxsPSIjRUE0MzM1Ii8+PC9nPjxnPjxwYXRoIGQ9Ik0yMS40LDE2My4yYzMuMy0xNi4yLDguNy0zMiwxNi4yLTQ2LjhjMjAuMywxNS44LDQwLjYsMzEuNSw2MSw0Ny4zYy04LDIzLjMtOCw0OS4yLDAsNzIuNCAgICBjLTIwLjMsMTUuOC00MC42LDMxLjYtNjAuOSw0Ny4zQzE4LjksMjQ2LjcsMTMuMiwyMDMuNiwyMS40LDE2My4yeiIgZmlsbD0iI0ZCQkMwNSIvPjwvZz48Zz48cGF0aCBkPSJNMjAzLjcsMTY1LjFjNTguMywwLDExNi43LDAsMTc1LDBjNS44LDMyLjcsNC41LDY2LjgtNC43LDk4LjhjLTguNSwyOS4zLTI0LjYsNTYuNS00Ny4xLDc3LjIgICAgYy0xOS43LTE1LjMtMzkuNC0zMC42LTU5LjEtNDUuOWMxOS41LTEzLjEsMzMuMy0zNC4zLDM3LjItNTcuNWMtMzMuOCwwLTY3LjYsMC0xMDEuNCwwQzIwMy43LDIxMy41LDIwMy43LDE4OS4zLDIwMy43LDE2NS4xeiIgZmlsbD0iIzQyODVGNCIvPjwvZz48Zz48cGF0aCBkPSJNMzcuNSwyODMuNWMyMC4zLTE1LjcsNDAuNi0zMS41LDYwLjktNDcuM2M3LjgsMjIuOSwyMi44LDQzLjIsNDIuNiw1Ny4xYzEyLjQsOC43LDI2LjYsMTQuOSw0MS40LDE3LjkgICAgYzE0LjYsMywyOS43LDIuNiw0NC40LDAuMWMxNC42LTIuNiwyOC43LTcuOSw0MS0xNi4yYzE5LjcsMTUuMywzOS40LDMwLjYsNTkuMSw0NS45Yy0yMS4zLDE5LjctNDgsMzMuMS03Ni4yLDM5LjYgICAgYy0zMS4yLDcuMS02NC4yLDcuMy05NS4yLTFjLTI0LjYtNi41LTQ3LjctMTguMi02Ny42LTM0LjFDNjcsMzI4LjksNDkuNiwzMDcuNSwzNy41LDI4My41eiIgZmlsbD0iIzM0QTg1MyIvPjwvZz48L2c+PC9zdmc+`,\n facebook: `data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/PjwhRE9DVFlQRSBzdmcgIFBVQkxJQyAnLS8vVzNDLy9EVEQgU1ZHIDEuMC8vRU4nICAnaHR0cDovL3d3dy53My5vcmcvVFIvMjAwMS9SRUMtU1ZHLTIwMDEwOTA0L0RURC9zdmcxMC5kdGQnPjxzdmcgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgMzIgMzIiIGhlaWdodD0iMzJweCIgaWQ9IkxheWVyXzEiIHZlcnNpb249IjEuMCIgdmlld0JveD0iMCAwIDMyIDMyIiB3aWR0aD0iMzJweCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+PGc+PHBhdGggZD0iTTMyLDMwYzAsMS4xMDQtMC44OTYsMi0yLDJIMmMtMS4xMDQsMC0yLTAuODk2LTItMlYyYzAtMS4xMDQsMC44OTYtMiwyLTJoMjhjMS4xMDQsMCwyLDAuODk2LDIsMlYzMHoiIGZpbGw9IiMzQjU5OTgiLz48cGF0aCBkPSJNMjIsMzJWMjBoNGwxLTVoLTV2LTJjMC0yLDEuMDAyLTMsMy0zaDJWNWMtMSwwLTIuMjQsMC00LDBjLTMuNjc1LDAtNiwyLjg4MS02LDd2M2gtNHY1aDR2MTJIMjJ6IiBmaWxsPSIjRkZGRkZGIiBpZD0iZiIvPjwvZz48Zy8+PGcvPjxnLz48Zy8+PGcvPjxnLz48L3N2Zz4=`,\n github:\n \"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/PjwhRE9DVFlQRSBzdmcgIFBVQkxJQyAnLS8vVzNDLy9EVEQgU1ZHIDEuMC8vRU4nICAnaHR0cDovL3d3dy53My5vcmcvVFIvMjAwMS9SRUMtU1ZHLTIwMDEwOTA0L0RURC9zdmcxMC5kdGQnPjxzdmcgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgMzIgMzIiIGhlaWdodD0iMzJweCIgaWQ9IkxheWVyXzEiIHZlcnNpb249IjEuMCIgdmlld0JveD0iMCAwIDMyIDMyIiB3aWR0aD0iMzJweCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+PHBhdGggY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNMTYuMDAzLDBDNy4xNywwLDAuMDA4LDcuMTYyLDAuMDA4LDE1Ljk5NyAgYzAsNy4wNjcsNC41ODIsMTMuMDYzLDEwLjk0LDE1LjE3OWMwLjgsMC4xNDYsMS4wNTItMC4zMjgsMS4wNTItMC43NTJjMC0wLjM4LDAuMDA4LTEuNDQyLDAtMi43NzcgIGMtNC40NDksMC45NjctNS4zNzEtMi4xMDctNS4zNzEtMi4xMDdjLTAuNzI3LTEuODQ4LTEuNzc1LTIuMzQtMS43NzUtMi4zNGMtMS40NTItMC45OTIsMC4xMDktMC45NzMsMC4xMDktMC45NzMgIGMxLjYwNSwwLjExMywyLjQ1MSwxLjY0OSwyLjQ1MSwxLjY0OWMxLjQyNywyLjQ0MywzLjc0MywxLjczNyw0LjY1NCwxLjMyOWMwLjE0Ni0xLjAzNCwwLjU2LTEuNzM5LDEuMDE3LTIuMTM5ICBjLTMuNTUyLTAuNDA0LTcuMjg2LTEuNzc2LTcuMjg2LTcuOTA2YzAtMS43NDcsMC42MjMtMy4xNzQsMS42NDYtNC4yOTJDNy4yOCwxMC40NjQsNi43Myw4LjgzNyw3LjYwMiw2LjYzNCAgYzAsMCwxLjM0My0wLjQzLDQuMzk4LDEuNjQxYzEuMjc2LTAuMzU1LDIuNjQ1LTAuNTMyLDQuMDA1LTAuNTM4YzEuMzU5LDAuMDA2LDIuNzI3LDAuMTgzLDQuMDA1LDAuNTM4ICBjMy4wNTUtMi4wNyw0LjM5Ni0xLjY0MSw0LjM5Ni0xLjY0MWMwLjg3MiwyLjIwMywwLjMyMywzLjgzLDAuMTU5LDQuMjM0YzEuMDIzLDEuMTE4LDEuNjQ0LDIuNTQ1LDEuNjQ0LDQuMjkyICBjMCw2LjE0Ni0zLjc0LDcuNDk4LTcuMzA0LDcuODkzQzE5LjQ3OSwyMy41NDgsMjAsMjQuNTA4LDIwLDI2YzAsMiwwLDMuOTAyLDAsNC40MjhjMCwwLjQyOCwwLjI1OCwwLjkwMSwxLjA3LDAuNzQ2ICBDMjcuNDIyLDI5LjA1NSwzMiwyMy4wNjIsMzIsMTUuOTk3QzMyLDcuMTYyLDI0LjgzOCwwLDE2LjAwMywweiIgZmlsbD0iIzE4MTYxNiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PGcvPjxnLz48Zy8+PGcvPjxnLz48Zy8+PC9zdmc+\",\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 {props.option.displayName}\n }\n\n if (props.option.provider && props.option.provider in systemProvidersLogo) {\n return {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 = (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 \n {(ctx) => (\n <>\n \n \n {props.label && {props.label}}\n \n {props.field && }\n \n )}\n \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 \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
    \n
    {props.title}
    \n
    {props.subtitle}
    \n
    \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 \n {props.children}\n \n )\n }\n\n return (\n
    \n {props.children}\n
    \n )\n}\n\nconst Divider = () => {\n return
    \n}\n\ninterface DropdownProps {\n renderHandle: JSX.Element\n position?: \"left\" | \"right\"\n children: React.ReactNode\n}\n\ninterface DropdownContextFuncs {\n close(): void\n}\n\nconst DropdownContext = createContext(null)\nDropdownContext.displayName = \"DropdownContext\"\n\nexport const Dropdown = (props: DropdownProps) => {\n const node = useRef(null)\n const [isOpen, setIsOpen] = useState(false)\n const position = props.position || \"right\"\n\n const toggleIsOpen = () => {\n setIsOpen(!isOpen)\n }\n\n const close = () => {\n setIsOpen(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 shadow-lg\": true,\n [`c-dropdown__list--${position}`]: position === \"left\",\n })\n\n return (\n \n
    \n \n {isOpen &&
    {props.children}
    }\n
    \n
    \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 {formatter.format(props.amount)}\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 = (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

    \n \n We have just sent a confirmation link to {email}. Click the link and you’ll be signed in.\n \n

    \n

    \n \n

    \n \n ) : (\n \n )\n\n return (\n \n \n Sign in to participate and vote\n \n {content}\n \n \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 \n )\n\n const disabled = (\n \n )\n\n return (\n <>\n \n
    {isDisabled ? disabled : vote}
    \n \n )\n}\n","import \"./NotificationIndicator.scss\"\n\nimport React, { useEffect, useState } from \"react\"\nimport IconBell from \"@fider/assets/images/heroicons-bell.svg\"\nimport { useFider } from \"@fider/hooks\"\nimport { actions } from \"@fider/services\"\nimport { Icon } from \"./common\"\n\nexport const NotificationIndicator = () => {\n const fider = useFider()\n const [unreadNotifications, setUnreadNotifications] = useState(0)\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 return (\n \n \n {unreadNotifications > 0 &&
    }\n \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
    \n }>\n
    {fider.session.user.name}
    \n \n My Settings\n \n \n\n {fider.session.user.isCollaborator && (\n <>\n
    \n Administration\n
    \n \n Site Settings\n \n \n \n )}\n \n Sign out\n \n
    \n
    \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 \n This website is currently in read-only mode because there is no active subscription. Visit{\" \"}\n \n Billing\n {\" \"}\n to subscribe.\n \n )\n }\n\n return (\n \n This website is currently in read-only mode.\n \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 ? 1 : 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
    \n {props.children}\n
    \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
    \n OR\n
    \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 Comment {\n id: number\n content: string\n createdAt: string\n user: User\n attachments?: string[]\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\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 {\n ok: boolean\n data: T\n error?: Failure\n}\n\nasync function toResult(response: Response): Promise> {\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(url: string, method: \"GET\" | \"POST\" | \"PUT\" | \"DELETE\", body?: any): Promise> {\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(response)\n } catch (err) {\n const truncatedBody = truncate(body ? JSON.stringify(body) : \"\", 1000)\n throw new Error(`Failed to ${method} ${url} with body '${truncatedBody}'`)\n }\n}\n\nexport const http = {\n get: async (url: string): Promise> => {\n return await request(url, \"GET\")\n },\n post: async (url: string, body?: any): Promise> => {\n return await request(url, \"POST\", body)\n },\n put: async (url: string, body?: any): Promise> => {\n return await request(url, \"PUT\", body)\n },\n delete: async (url: string, body?: any): Promise> => {\n return await request(url, \"DELETE\", body)\n },\n event:\n (category: string, action: string) =>\n (result: Result): Result => {\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 : \"\",\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(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 => {\n return new Promise((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 = {\n [key: string]: T\n}\n","import { i18n, I18n } from \"@lingui/core\"\nimport { en, pt, fr, el, de, se, pl, ru, sk, nl, es, tr } 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(\"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.load(locale, messages)\n i18n.activate(locale)\n return i18n\n}\n\nexport async function activateI18N(locale: string): Promise {\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 `${text}`\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 \"<\": \"<\",\n \">\": \">\",\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 => {\n return await http.post(\"/_api/user/settings\", request)\n}\n\nexport const changeUserEmail = async (email: string): Promise => {\n return await http.post(\"/_api/user/change-email\", {\n email,\n })\n}\n\nexport const deleteCurrentAccount = async (): Promise => {\n return await http.delete(\"/_api/user\")\n}\n\nexport const regenerateAPIKey = async (): Promise> => {\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> => {\n return http.post(`/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> => {\n return http.put(`/api/v1/tags/${slug}`, { name, color, isPublic }).then(http.event(\"tag\", \"update\"))\n}\n\nexport const deleteTag = async (slug: string): Promise => {\n return http.delete(`/api/v1/tags/${slug}`).then(http.event(\"tag\", \"delete\"))\n}\n\nexport const assignTag = async (slug: string, postNumber: number): Promise => {\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 => {\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> => {\n return await http.get(\"/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> => {\n return await http.get(\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 => {\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 => {\n return http.post(`/api/v1/posts/${postNumber}/votes`).then(http.event(\"post\", \"vote\"))\n}\n\nexport const removeVote = async (postNumber: number): Promise => {\n return http.delete(`/api/v1/posts/${postNumber}/votes`).then(http.event(\"post\", \"unvote\"))\n}\n\nexport const subscribe = async (postNumber: number): Promise => {\n return http.post(`/api/v1/posts/${postNumber}/subscription`).then(http.event(\"post\", \"subscribe\"))\n}\n\nexport const unsubscribe = async (postNumber: number): Promise => {\n return http.delete(`/api/v1/posts/${postNumber}/subscription`).then(http.event(\"post\", \"unsubscribe\"))\n}\n\nexport const listVotes = async (postNumber: number): Promise> => {\n return http.get(`/api/v1/posts/${postNumber}/votes`)\n}\n\nexport const createComment = async (postNumber: number, content: string, attachments: ImageUpload[]): Promise => {\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 => {\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 => {\n return http.delete(`/api/v1/posts/${postNumber}/comments/${commentID}`).then(http.event(\"comment\", \"delete\"))\n}\n\ninterface SetResponseInput {\n status: string\n text: string\n originalNumber: number\n}\n\nexport const respond = async (postNumber: number, input: SetResponseInput): Promise => {\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> => {\n return http.post(`/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 => {\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> => {\n return await http.post(\"/_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 => {\n return await http.post(\"/_api/admin/settings/general\", request)\n}\n\nexport const updateTenantAdvancedSettings = async (customCSS: string): Promise => {\n return await http.post(\"/_api/admin/settings/advanced\", { customCSS })\n}\n\nexport const updateTenantPrivacy = async (isPrivate: boolean): Promise => {\n return await http.post(\"/_api/admin/settings/privacy\", {\n isPrivate,\n })\n}\n\nexport const updateTenantEmailAuthAllowed = async (isEmailAuthAllowed: boolean): Promise => {\n return await http.post(\"/_api/admin/settings/emailauth\", {\n isEmailAuthAllowed,\n })\n}\n\nexport const checkAvailability = async (subdomain: string): Promise> => {\n return await http.get(`/_api/tenants/${subdomain}/availability`)\n}\n\nexport const signIn = async (email: string): Promise => {\n return await http.post(\"/_api/signin\", {\n email,\n })\n}\n\nexport const completeProfile = async (kind: EmailVerificationKind, key: string, name: string): Promise => {\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 => {\n return await http.post(`/_api/admin/roles/${role}/users`, {\n userID,\n })\n}\n\nexport const blockUser = async (userID: number): Promise => {\n return await http.put(`/_api/admin/users/${userID}/block`)\n}\n\nexport const unblockUser = async (userID: number): Promise => {\n return await http.delete(`/_api/admin/users/${userID}/block`)\n}\n\nexport const getOAuthConfig = async (provider: string): Promise> => {\n return await http.get(`/_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 => {\n return await http.post(\"/_api/admin/oauth\", request)\n}\n","import { http, Result } from \"@fider/services\"\n\nexport const getTotalUnreadNotifications = async (): Promise> => {\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 markAllAsRead = async (): Promise => {\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 => {\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 => {\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 => {\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 : \"\",\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> => {\n return await http.post(`/_api/admin/webhook`, data)\n}\n\nexport const updateWebhook = async (id: number, data: WebhookData): Promise => {\n return await http.put(`/_api/admin/webhook/${id}`, data)\n}\n\nexport const deleteWebhook = async (id: number): Promise => {\n return await http.delete(`/_api/admin/webhook/${id}`)\n}\n\nexport const testWebhook = async (id: number): Promise> => {\n return await http.get(`/_api/admin/webhook/test/${id}`)\n}\n\nexport const previewWebhook = async (type: WebhookType, url: string, content: string): Promise> => {\n return await http.post(\"/_api/admin/webhook/preview\", { type, url, content })\n}\n\nexport const getWebhookHelp = async (type: WebhookType): Promise> => {\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> => {\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 \n \n ,\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","className","text","target","width","height","sprite","IconInformationCircle","Icon","styles","style","src","viewBox","xlinkHref","id","ErrorBoundary","React","constructor","super","this","state","error","errorInfo","componentDidCatch","onError","setState","render","fider","ErrorPage","showDetails","isProduction","children","ShowPostResponse","status","PostStatus","response","show","ShowPostStatus","UserName","user","original","number","slug","title","DuplicateDetails","Markdown","StatusDetails","value","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","justify","TenantLogo","size","session","tenant","isAuthenticated","spacing","NotificationIndicator","UserMenu","e","preventDefault","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","message","fields","Object","keys","prototype","hasOwnProperty","call","forEach","t","length","Input","onChange","currentTarget","suffix","icon","onIconClick","Consumer","ctx","label","htmlFor","afterLabel","center","tabIndex","noTabFocus","ref","inputRef","autoFocus","onFocus","maxLength","placeholder","ImageUploader","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","minRows","RadioButton","selected","setSelected","defaultOption","option","onSelect","inputs","options","checked","Select","filtered","getOption","defaultValue","o","Field","Checkbox","setChecked","isChecked","ImageViewerModal","loadedPreview","Loader","onLoad","onPreviewLoad","imgSrc","ImageViewer","setShowModal","loadedThumbnail","setLoadedThumbnail","setLoadedPreview","html","markdown","tagName","dangerouslySetInnerHTML","__html","truncate","DevBanner","Avatar","avatarURL","AvatarStack","users","i","Message","showIcon","IconExclamation","IconExclamationCircle","IconCheckCircle","alignment","Hint","cacheKey","permanentCloseKey","isClosed","setIsClosed","cache","condition","IconX","TermsOfService","settings","hasLegal","PrivacyPolicy","LegalNotice","LegalFooter","align","LegalAgreement","SocialSignInButton","redirectTo","window","location","url","logoURL","displayName","OAuthProviderLogo","SignInControl","showEmailForm","setShowEmailForm","isEmailAuthAllowed","email","setEmail","setError","providersLen","oauth","isCookieEnabled","provider","useEmail","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","close","canClose","ReactDOM","evt","isStaff","role","isCollaborator","setShow","useTimeout","TenantLogoURL","logoBlobKey","useFiderIfEmpty","systemProvidersLogo","google","facebook","github","OAuthProviderLogoURL","Toggle","active","setActive","toggle","newActive","onToggle","PoweredByFider","source","encodeURIComponent","host","campaign","slot","PageTitle","subtitle","DropdownContext","createContext","Dropdown","node","setIsOpen","position","handleClick","contains","listClassName","renderHandle","ListItem","useContext","Divider","Money","formatter","Intl","NumberFormat","currency","amount","setTimeout","VoteCounter","hasVoted","setHasVoted","post","votesCount","setVotesCount","isDisabled","closed","isReadOnly","vote","action","FaCaretUp","unreadNotifications","setUnreadNotifications","then","data","IconBell","ReadOnlyNotice","isAdministrator","Stack","dir","flex","divide","HStack","VStack","filterable","All","Error","TenantStatus","UserAvatarType","UserStatus","UserRole","Open","Planned","Started","Completed","Duplicate","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","set","storage","setItem","localStorage","getItem","has","removeItem","local","sessionStorage","eventCategory","eventAction","ga","exDescription","stack","exFatal","FiderSession","pPage","page","pContextID","contextID","pProps","pUser","pTenant","Fider","initData","pSettings","pSession","el","parse","textContent","innerText","currentLocale","environment","isSingleHostMode","mode","FiderContext","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","activateI18NSync","messages","i18n","plurals","en","pt","se","es","nl","de","fr","pl","ru","sk","tr","activateI18N","console","marked","headerIds","xhtml","smartLists","gfm","breaks","DOMPurify","USE_PROFILES","ADD_ATTR","fullRenderer","image","plainTextRenderer","_href","_title","br","strong","list","listitem","heading","paragraph","code","codespan","del","entities","encodeHTML","s","replace","sanitize","renderer","plainText","toastify","success","toast","goHome","goTo","pathname","replaceState","path","history","newURL","baseURL","getNumber","uri","navigator","re","RegExp","match","separator","results","exec","decodeURIComponent","getArray","qs","object","symbol","Array","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","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","markAllAsRead","sendInvites","subject","recipients","sendSampleInvite","ignoreErrors","logError","pattern","createWebhook","updateWebhook","deleteWebhook","testWebhook","previewWebhook","getWebhookHelp","generateCheckoutLink","planId","hasContainer","setup"],"sourceRoot":""}