{"version":3,"file":"js/common.4fa15b83f3fcda1d9359.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/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, DevBanner, 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 \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}\n","import \"./Button.scss\"\n\nimport React 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\ninterface ButtonState {\n clicked: boolean\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 class Button extends React.Component {\n private unmounted = false\n\n public static defaultProps: Partial = {\n size: \"default\",\n variant: \"secondary\",\n type: \"button\",\n }\n\n public constructor(props: ButtonProps) {\n super(props)\n this.state = {\n clicked: false,\n }\n }\n\n public componentWillUnmount() {\n this.unmounted = true\n }\n\n public click = async (e?: React.SyntheticEvent) => {\n if (e) {\n e.preventDefault()\n e.stopPropagation()\n }\n\n if (this.state.clicked) {\n return\n }\n\n const event = new ButtonClickEvent()\n this.setState({ clicked: true })\n if (this.props.onClick) {\n await this.props.onClick(event)\n if (!this.unmounted && event.canEnable()) {\n this.setState({ clicked: false })\n }\n }\n }\n\n public render() {\n const className = classSet({\n \"c-button\": true,\n [`c-button--${this.props.size}`]: this.props.size,\n [`c-button--${this.props.variant}`]: this.props.variant,\n \"c-button--loading\": this.state.clicked,\n \"c-button--disabled\": this.state.clicked || this.props.disabled,\n [this.props.className || \"\"]: this.props.className,\n \"shadow-sm\": this.props.variant !== \"tertiary\",\n })\n\n if (this.props.href) {\n return (\n \n {this.props.children}\n \n )\n } else if (this.props.onClick) {\n return (\n \n )\n } else {\n return (\n \n )\n }\n }\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 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\ninterface RadioButtonState {\n selected: RadioButtonOption\n}\n\nexport class RadioButton extends React.Component {\n constructor(props: RadioButtonProps) {\n super(props)\n this.state = {\n selected: props.defaultOption || props.options[0],\n }\n }\n\n private onChange = (selected: RadioButtonOption) => {\n this.setState({ selected }, () => {\n if (this.props.onSelect) {\n this.props.onSelect(this.state.selected)\n }\n })\n }\n\n public render() {\n const inputs = this.props.options.map((option) => {\n return (\n \n \n \n \n )\n })\n\n return (\n
    \n \n {inputs}\n
    \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\ninterface SelectState {\n selected?: SelectOption\n}\n\nexport class Select extends React.Component {\n constructor(props: SelectProps) {\n super(props)\n this.state = {\n selected: this.getOption(props.defaultValue),\n }\n }\n\n private getOption(value?: string): SelectOption | undefined {\n if (value && this.props.options) {\n const filtered = this.props.options.filter((x) => x.value === value)\n if (filtered && filtered.length > 0) {\n return filtered[0]\n }\n }\n }\n\n private onChange = (e: React.FormEvent) => {\n let selected: SelectOption | undefined\n if (e.currentTarget.value) {\n const options = this.props.options.filter((o) => o.value === e.currentTarget.value)\n if (options && options.length > 0) {\n selected = options[0]\n }\n }\n\n this.setState({ selected }, () => {\n if (this.props.onChange) {\n this.props.onChange(this.state.selected)\n }\n })\n }\n\n public render() {\n const options = this.props.options.map((option) => {\n return (\n \n )\n })\n\n return (\n \n {(ctx) => (\n <>\n
    \n {!!this.props.label && }\n \n {options}\n \n \n {this.props.children}\n
    \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 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 ImageViewerProps {\n bkey: string\n}\n\ninterface ImageViewerState {\n showModal: boolean\n loadedThumbnail: boolean\n loadedPreview: boolean\n}\n\nexport class ImageViewer extends React.Component {\n constructor(props: ImageViewerProps) {\n super(props)\n\n this.state = {\n showModal: false,\n loadedThumbnail: false,\n loadedPreview: false,\n }\n }\n\n private openModal = () => {\n if (this.state.loadedThumbnail) {\n this.setState({ showModal: true })\n }\n }\n\n private closeModal = async () => {\n this.setState({ showModal: false })\n }\n\n private onThumbnailLoad = () => {\n this.setState({ loadedThumbnail: true })\n }\n\n private onPreviewLoad = () => {\n this.setState({ loadedPreview: true })\n }\n\n private modal() {\n return (\n \n \n {!this.state.loadedPreview && }\n \"\"\n \n\n \n \n \n \n )\n }\n\n public render() {\n const previewURL = uploadedImageURL(this.props.bkey, 200)\n return (\n
    \n {this.modal()}\n {!this.state.loadedThumbnail && }\n \"\"\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 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 [`${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 }\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 {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: ``,\n facebook: ``,\n github:\n \"\",\n}\n\nexport const OAuthProviderLogoURL = (logoBlobKey?: string): string | undefined => {\n if (logoBlobKey) {\n return uploadedImageURL(logoBlobKey, 100)\n }\n return undefined\n}\n\nexport const OAuthProviderLogo = (props: OAuthProviderLogoProps) => {\n if (props.option.logoBlobKey) {\n return {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\"\n\nimport \"./PoweredByFider.scss\"\n\ninterface PoweredByFiderProps {\n className: string\n}\n\nexport const PoweredByFider = (props: PoweredByFiderProps) => {\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 post 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\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\": status.closed,\n })\n\n const vote = (\n \n )\n\n const disabled = (\n \n )\n\n return (\n <>\n \n
    {status.closed ? 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 { 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\"\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 })\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}\n\nexport interface User {\n id: number\n name: 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}\n\nexport interface ImageUpload {\n bkey?: string\n upload?: {\n fileName?: string\n content?: string\n contentType?: string\n }\n remove: boolean\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 === 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 } from \"@fider/models\"\n\nexport class FiderSession {\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.pContextID = data.contextID\n this.pProps = data.props\n this.pUser = data.user\n this.pTenant = data.tenant\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 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, de, se, ru, sk, nl } 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(\"nl\", { plurals: nl })\n i18n.loadLocaleData(\"de\", { plurals: de })\n i18n.loadLocaleData(\"fr\", { plurals: fr })\n i18n.loadLocaleData(\"ru\", { plurals: ru })\n i18n.loadLocaleData(\"sk\", { plurals: sk })\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 } 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 (key: string, name: string): Promise => {\n return await http.post(\"/_api/signin/complete\", {\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}\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 (): Promise> => {\n return await http.post(\"/_api/billing/checkout-link\")\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","data-tooltip","text","target","width","height","sprite","IconInformationCircle","Icon","styles","style","src","viewBox","url","ErrorBoundary","React","constructor","super","this","state","error","errorInfo","componentDidCatch","onError","setState","render","fider","showDetails","isProduction","children","ShowPostResponse","status","PostStatus","response","show","ShowPostStatus","UserName","user","original","number","slug","title","DuplicateDetails","Markdown","StatusDetails","id","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","DevBanner","SignInModal","isOpen","onClose","justify","TenantLogo","size","session","tenant","isAuthenticated","spacing","NotificationIndicator","UserMenu","e","preventDefault","ButtonClickEvent","preventEnable","shouldEnable","canEnable","Button","async","stopPropagation","clicked","event","unmounted","componentWillUnmount","variant","disabled","rel","type","click","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","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","onSelect","defaultOption","options","inputs","option","checked","bind","Select","o","getOption","defaultValue","filtered","Field","Checkbox","setChecked","isChecked","ImageViewer","loadedThumbnail","loadedPreview","Loader","onLoad","onPreviewLoad","onThumbnailLoad","html","markdown","tagName","dangerouslySetInnerHTML","__html","truncate","Avatar","avatarURL","AvatarStack","users","i","Message","IconExclamation","IconExclamationCircle","IconCheckCircle","showIcon","Hint","cacheKey","permanentCloseKey","isClosed","setIsClosed","cache","condition","IconX","TermsOfService","settings","hasLegal","PrivacyPolicy","LegalNotice","LegalFooter","align","LegalAgreement","SocialSignInButton","redirectTo","window","location","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","useRef","document","getElementById","useEffect","body","overflow","addEventListener","keyDown","removeEventListener","keyCode","close","canClose","current","ReactDOM","aria-disabled","data-testid","evt","defaultProps","isStaff","role","isCollaborator","setShow","useTimeout","TenantLogoURL","logoBlobKey","useFiderIfEmpty","systemProvidersLogo","google","facebook","github","OAuthProviderLogoURL","Toggle","active","setActive","toggle","newActive","onToggle","aria-hidden","PoweredByFider","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","closed","vote","action","FaCaretUp","unreadNotifications","setUnreadNotifications","then","data","IconBell","Stack","dir","flex","divide","HStack","VStack","filterable","All","Error","TenantStatus","UserAvatarType","UserStatus","UserRole","Open","Planned","Started","Completed","Duplicate","Declined","Collaborator","Administrator","OAuthConfigStatus","Disabled","Enabled","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","pContextID","contextID","pProps","pUser","pTenant","Fider","initData","pSettings","pSession","el","parse","textContent","innerText","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","nl","de","fr","ru","sk","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","encodeURIComponent","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","changeUserRole","userID","blockUser","unblockUser","getOAuthConfig","saveOAuthConfig","getTotalUnreadNotifications","total","markAllAsRead","sendInvites","subject","recipients","sendSampleInvite","ignoreErrors","logError","pattern","createWebhook","updateWebhook","deleteWebhook","testWebhook","previewWebhook","getWebhookHelp","generateCheckoutLink","hasContainer","setup"],"sourceRoot":""}