@topthink/components 1.0.56 → 1.0.57
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/form-74ef0417.js +2 -0
- package/es/form-74ef0417.js.map +1 -0
- package/es/form-8925a750.js +231 -0
- package/es/form-8925a750.js.map +1 -0
- package/es/form-9c0e638a.js +230 -1
- package/es/form-9c0e638a.js.map +1 -1
- package/es/index-303e1845.js +560 -0
- package/es/index-303e1845.js.map +1 -0
- package/es/index-4f51cece.js +1304 -19
- package/es/index-4f51cece.js.map +1 -1
- package/es/index-6ae8237d.js +67 -0
- package/es/index-6ae8237d.js.map +1 -0
- package/es/index-7a7c06a9.js +40 -0
- package/es/index-7a7c06a9.js.map +1 -0
- package/es/index-9869b1c6.js +1350 -0
- package/es/index-9869b1c6.js.map +1 -0
- package/es/index-d964165a.js +529 -9
- package/es/index-d964165a.js.map +1 -1
- package/es/index.js +1 -1
- package/package.json +2 -2
- package/types/index.d.ts +1 -1
- package/types/utils/is-record.d.ts +1 -0
- package/types/errors/unauthorized.d.ts +0 -4
package/es/index-4f51cece.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-4f51cece.js","sources":["../src/utils/message.ts","../src/components/modal/message.tsx","../src/hooks/use-state-with-callback.ts","../src/components/modal/show.tsx","../src/components/tooltip.tsx","../src/components/lazy/table/context.ts","../src/components/button.tsx","../src/components/modal/confirm.tsx","../src/components/modal/index.tsx","../src/errors/unauthorized.ts","../src/utils/toast.tsx","../src/request.ts","../src/hooks/use-safe-state.ts","../src/hooks/use-unmounted-ref.ts","../src/utils/wait-pay-complete.tsx","../src/components/result.tsx","../src/components/dimmer.tsx","../src/components/loader.tsx","../src/components/card.tsx","../src/components/error.tsx","../src/components/space.tsx","../src/components/steps.tsx","../src/components/statistic.tsx","../src/components/pagination.tsx","../src/components/number-format.tsx","../src/components/loading-button.tsx","../src/components/image-zoom.tsx","../src/components/request-button.tsx","../src/components/form.tsx","../src/components/table.tsx","../src/hooks/use-overlay-state.ts","../src/components/modal-button.tsx","../src/components/modal-form.tsx","../src/hooks/use-request.ts","../src/hooks/use-callback-ref.ts","../src/hooks/use-controllable-state.ts","../src/hooks/use-debounce.ts"],"sourcesContent":["import Swal from 'sweetalert2/dist/sweetalert2.js';\r\nimport withReactContent from 'sweetalert2-react-content';\r\nimport { SweetAlertOptions, SweetAlertResult } from 'sweetalert2';\r\n\r\nconst CustomSwal = withReactContent(Swal);\r\n\r\ninterface MessageOptions<T = any> extends SweetAlertOptions<T> {\r\n\r\n}\r\n\r\nconst defaultOptions: MessageOptions = {\r\n confirmButtonText: '确定',\r\n cancelButtonText: '取消',\r\n};\r\n\r\nconst Message = {\r\n confirm: async <T = any>(options: MessageOptions<T>) => {\r\n const { isConfirmed } = await CustomSwal.fire({\r\n ...defaultOptions,\r\n icon: 'warning',\r\n showCancelButton: true,\r\n ...options,\r\n async preConfirm(data) {\r\n if (options.preConfirm) {\r\n try {\r\n return await options.preConfirm(data);\r\n } catch (e) {\r\n if (e instanceof Error) {\r\n CustomSwal.showValidationMessage(e.message);\r\n }\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n });\r\n\r\n return isConfirmed;\r\n },\r\n success: (options: MessageOptions) => {\r\n CustomSwal.fire({\r\n ...defaultOptions,\r\n toast: true,\r\n position: 'top',\r\n icon: 'success',\r\n timer: 2000,\r\n showConfirmButton: false,\r\n ...options\r\n });\r\n },\r\n error: (options: MessageOptions) => {\r\n CustomSwal.fire({\r\n ...defaultOptions,\r\n toast: true,\r\n position: 'top',\r\n icon: 'error',\r\n timer: 5000,\r\n showConfirmButton: false,\r\n ...options\r\n });\r\n },\r\n close: (result?: SweetAlertResult) => {\r\n CustomSwal.close(result);\r\n },\r\n defaults: defaultOptions\r\n};\r\n\r\nexport default Message;\r\n","import {\r\n ComponentType,\r\n createContext,\r\n Fragment,\r\n ReactNode,\r\n useCallback,\r\n useContext,\r\n useEffect,\r\n useMemo,\r\n useState\r\n} from 'react';\r\nimport useStateWithCallback from '../../hooks/use-state-with-callback';\r\nimport { ModalProps } from 'react-bootstrap';\r\n\r\ninterface MessageContextType {\r\n container?: ModalProps['container'];\r\n}\r\n\r\nconst MessageContext = createContext<MessageContextType>({});\r\n\r\ntype MessageWrapProps<T, P = void> = {\r\n resolve: (value: P | void) => void\r\n destroy: () => void\r\n message: T\r\n}\r\n\r\nexport type MessageProps<T, P = void> = {\r\n resolve: (value: P | void) => void\r\n message: T\r\n state: {\r\n show: boolean\r\n onHide: () => void\r\n onExited: () => void\r\n container?: ModalProps['container']\r\n }\r\n}\r\n\r\nexport function wrapMessage<T = {}, P = any>(Component: ComponentType<MessageProps<T, P>>): ComponentType<MessageWrapProps<T, P>> {\r\n\r\n return ({ resolve, destroy, message }) => {\r\n\r\n const [show, setShow] = useStateWithCallback(true);\r\n const context = useContext(MessageContext);\r\n\r\n const handleResolve = useCallback((value: P | void) => {\r\n setShow(false, () => {\r\n resolve(value);\r\n });\r\n }, [setShow, resolve]);\r\n\r\n const state = useMemo(() => {\r\n return {\r\n show,\r\n onHide: () => handleResolve(),\r\n onExited: () => destroy(),\r\n container: context.container\r\n };\r\n }, [show, handleResolve, destroy]);\r\n\r\n return <Component\r\n resolve={handleResolve}\r\n state={state}\r\n message={message}\r\n />;\r\n };\r\n}\r\n\r\nexport function createMessage<T = {}, P = any>(Component: ComponentType<MessageWrapProps<T, P>>): (message: T) => Promise<P | void> {\r\n return (message) => {\r\n return new Promise<P | void>((resolve) => {\r\n const component = <Component\r\n resolve={resolve}\r\n destroy={() => {\r\n hide(component);\r\n }}\r\n message={message}\r\n />;\r\n\r\n show(component);\r\n });\r\n };\r\n}\r\n\r\ntype State = Set<ReactNode>\r\n\r\nlet listener: (state: State) => void = () => void 0;\r\n\r\nlet memoryState: State = new Set();\r\n\r\nexport const show = (modal: ReactNode) => {\r\n memoryState = new Set(memoryState);\r\n memoryState.add(modal);\r\n\r\n listener(memoryState);\r\n};\r\n\r\nexport const hide = (modal: ReactNode) => {\r\n memoryState = new Set(memoryState);\r\n memoryState.delete(modal);\r\n\r\n listener(memoryState);\r\n};\r\n\r\nexport default function Message(props: MessageContextType) {\r\n const [state, setState] = useState<State>(memoryState);\r\n useEffect(() => {\r\n listener = setState;\r\n }, []);\r\n\r\n return <MessageContext.Provider value={props}>\r\n {Array.from(state).map((message, index) => <Fragment key={`message-${index}`}>{message}</Fragment>)}\r\n </MessageContext.Provider>;\r\n}\r\n","import { SetStateAction, useEffect, useRef, useState } from 'react';\n\nexport default function useStateWithCallback<S>(initState: S): [S, (value: SetStateAction<S>, callback: () => void) => void] {\n const callbackRef = useRef<Function | null>(null);\n\n const [state, setState] = useState(initState);\n\n useEffect(() => {\n if (callbackRef.current) {\n callbackRef.current();\n callbackRef.current = null;\n }\n }, [state]);\n\n const setCallbackState = (value: SetStateAction<S>, callback: () => void) => {\n callbackRef.current = typeof callback === 'function' ? callback : null;\n setState(value);\n };\n\n return [state, setCallbackState];\n}\n","import { createMessage, MessageProps, wrapMessage } from './message';\r\nimport { ComponentType } from 'react';\r\n\r\nexport default function show<T, P = any>(Component: ComponentType<MessageProps<any, T>>, options?: P) {\r\n return createMessage(wrapMessage(Component))(options);\r\n}\r\n","import { OverlayTrigger, OverlayTriggerProps, Tooltip as BsTooltip } from 'react-bootstrap';\r\nimport { uniqueId } from 'lodash';\r\n\r\ninterface TooltipProps {\r\n tooltip: string;\r\n children: OverlayTriggerProps['children'];\r\n placement?: OverlayTriggerProps['placement'];\r\n}\r\n\r\nexport default function Tooltip({ tooltip, children, placement = 'bottom' }: TooltipProps) {\r\n\r\n return <OverlayTrigger\r\n placement={placement}\r\n overlay={\r\n <BsTooltip id={uniqueId()}>\r\n {tooltip}\r\n </BsTooltip>\r\n }\r\n >\r\n {children}\r\n </OverlayTrigger>;\r\n}\r\n","import { createContext } from 'react';\r\n\r\nexport const TableContext = createContext(false);\r\n","import { Button as BsButton, ButtonProps as BsButtonProps, Spinner } from 'react-bootstrap';\r\nimport { forwardRef, useContext } from 'react';\r\nimport Tooltip from './tooltip';\r\nimport { TableContext } from './lazy/table/context';\r\n\r\nexport interface ButtonProps extends BsButtonProps {\r\n loading?: boolean;\r\n percent?: number;\r\n tooltip?: string;\r\n}\r\n\r\nconst Button = forwardRef<any, ButtonProps>((\r\n {\r\n loading,\r\n percent,\r\n disabled,\r\n children,\r\n tooltip,\r\n variant,\r\n ...props\r\n },\r\n ref\r\n) => {\r\n\r\n const inTable = useContext(TableContext);\r\n\r\n if (inTable && !variant) {\r\n variant = 'link';\r\n }\r\n\r\n if (loading) {\r\n disabled = true;\r\n children = <>\r\n <Spinner ref={ref} as='span' size='sm' role='status' aria-hidden='true' animation='border' />\r\n {percent ? <span className='ms-2'>{percent}%</span> : null}\r\n </>;\r\n }\r\n\r\n const button = <BsButton ref={ref} {...props} variant={variant} disabled={disabled}>{children}</BsButton>;\r\n\r\n if (tooltip) {\r\n return <Tooltip tooltip={tooltip}>\r\n <span className={'d-inline-block'}>{button}</span>\r\n </Tooltip>;\r\n }\r\n\r\n return button;\r\n});\r\n\r\nexport default Button;\r\n","import { FC } from 'react';\r\nimport { Modal } from 'react-bootstrap';\r\nimport { createMessage, MessageProps, wrapMessage } from './message';\r\nimport Button from '../button';\r\n\r\ninterface ConfirmOptions {\r\n title?: string;\r\n message: string;\r\n okText?: string;\r\n cancelText?: string;\r\n}\r\n\r\nconst Confirm: FC<MessageProps<ConfirmOptions, true>> = function({\r\n state,\r\n message: {\r\n title,\r\n message,\r\n okText,\r\n cancelText\r\n },\r\n resolve,\r\n}) {\r\n return <Modal centered {...state} >\r\n <Modal.Header>\r\n <Modal.Title as='h5'>{title || '确认'}</Modal.Title>\r\n </Modal.Header>\r\n <Modal.Body>{message}</Modal.Body>\r\n <Modal.Footer>\r\n <Button variant='secondary' onClick={() => resolve()}>{cancelText || '取消'}</Button>\r\n <Button onClick={() => resolve(true)}>{okText || '确定'}</Button>\r\n </Modal.Footer>\r\n </Modal>;\r\n};\r\n\r\nexport default function confirm(options: ConfirmOptions) {\r\n return createMessage(wrapMessage(Confirm))(options);\r\n}\r\n","import { Modal as ReactModal, ModalProps as ReactModalProps } from 'react-bootstrap';\r\nimport { ElementType, MouseEvent, ReactNode, useMemo, useState } from 'react';\r\nimport Button, { ButtonProps } from '../button';\r\nimport show from './show';\r\nimport confirm from './confirm';\r\nimport Message, { MessageProps } from './message';\r\n\r\nexport interface ModalProps extends Pick<\r\n ReactModalProps,\r\n 'style' | 'container' | 'backdrop' | 'centered' | 'size' | 'scrollable' | 'fullscreen' | 'onHide' | 'onShow' | 'onEnter' | 'onEntering' | 'onEntered' | 'onExit' | 'onExiting' | 'onExited'\r\n> {\r\n children: ReactNode;\r\n header?: ReactNode;\r\n footer?: ReactNode | ((args: { okButton: ReactNode, cancelButton: ReactNode }) => ReactNode);\r\n okText?: string;\r\n cancelText?: string;\r\n closable?: boolean;\r\n show?: boolean;\r\n onOk?: (e: MouseEvent) => void;\r\n onCancel?: (e: MouseEvent) => void;\r\n okButtonProps?: ButtonProps;\r\n bodyAs?: ElementType;\r\n headerAs?: ElementType;\r\n confirmLoading?: boolean;\r\n}\r\n\r\nconst Modal = ({\r\n header,\r\n children,\r\n footer,\r\n closable = true,\r\n show,\r\n cancelText = '取消',\r\n okText = '确定',\r\n onOk,\r\n onCancel,\r\n onHide,\r\n okButtonProps,\r\n bodyAs,\r\n headerAs = 'h5',\r\n confirmLoading = false,\r\n ...rest\r\n}: ModalProps) => {\r\n\r\n const [loading, setLoading] = useState(false);\r\n\r\n const okButton = useMemo(() => {\r\n return <Button loading={loading || confirmLoading} variant={'primary'} onClick={async (e) => {\r\n setLoading(true);\r\n try {\r\n await onOk?.(e);\r\n if (!e.defaultPrevented) {\r\n onHide?.();\r\n }\r\n } finally {\r\n setLoading(false);\r\n }\r\n }} {...okButtonProps}>{okText}</Button>;\r\n }, [okButtonProps, okText, onOk, onHide, loading, confirmLoading]);\r\n\r\n const cancelButton = useMemo(() => {\r\n return <Button variant='secondary' onClick={(e) => {\r\n onCancel?.(e);\r\n if (!e.defaultPrevented) {\r\n onHide?.();\r\n }\r\n }}>{cancelText}</Button>;\r\n }, [onCancel, onHide, cancelText]);\r\n\r\n switch (typeof footer) {\r\n case 'undefined':\r\n footer = <>\r\n {cancelButton}\r\n {okButton}\r\n </>;\r\n break;\r\n case 'function':\r\n footer = footer({ okButton, cancelButton });\r\n break;\r\n }\r\n\r\n return <ReactModal {...rest} onHide={onHide} show={show}>\r\n {header && <ReactModal.Header closeButton={closable}>\r\n <ReactModal.Title as={headerAs}>{header}</ReactModal.Title>\r\n </ReactModal.Header>}\r\n <ReactModal.Body as={bodyAs}>{children}</ReactModal.Body>\r\n {footer && <ReactModal.Footer>{footer}</ReactModal.Footer>}\r\n </ReactModal>;\r\n};\r\n\r\nModal.Message = Message;\r\nModal.confirm = confirm;\r\nModal.show = show;\r\nexport default Modal;\r\nexport { MessageProps };\r\n","export default class Unauthorized extends Error {\r\n\r\n url: string;\r\n\r\n constructor(url: string) {\r\n super('Unauthorized');\r\n this.url = url;\r\n }\r\n}\r\n","import { Alert } from 'react-bootstrap';\r\nimport { NoticeContent, NotificationInstance } from 'rc-notification/lib/Notification';\r\nimport Notification from 'rc-notification';\r\nimport { NotificationProps } from 'rc-notification/es/Notification';\r\n\r\nlet noticeInstance: NotificationInstance | null;\r\n\r\nconst defaultOptions: NotificationProps & {\r\n getContainer?: () => HTMLElement;\r\n} = {};\r\n\r\nfunction getNoticeInstance(callback: (instance: NotificationInstance) => void) {\r\n if (noticeInstance) {\r\n return callback(noticeInstance);\r\n }\r\n\r\n Notification.newInstance({\r\n ...defaultOptions,\r\n prefixCls: 'notification',\r\n maxCount: 5,\r\n style: {\r\n top: 20,\r\n right: 20\r\n }\r\n }, (instance) => {\r\n if (noticeInstance) {\r\n callback(noticeInstance);\r\n return;\r\n }\r\n noticeInstance = instance;\r\n callback(instance);\r\n });\r\n}\r\n\r\n\r\nconst notice = ({ type, ...options }: { type: string } & NoticeContent) => {\r\n getNoticeInstance((instance) => {\r\n options.duration = 3;\r\n let variant = type;\r\n switch (type) {\r\n case 'error':\r\n variant = 'danger';\r\n options.duration = options.closable ? 0 : 5;\r\n break;\r\n }\r\n\r\n options.content = <Alert variant={variant}>{options.content}</Alert>;\r\n\r\n instance.notice(options);\r\n });\r\n};\r\n\r\nconst types = ['error', 'success', 'info'] as const;\r\n\r\ntype ToastType = Record<typeof types[number], (content: string, options?: NoticeContent) => void> & {\r\n defaults: typeof defaultOptions;\r\n};\r\n\r\nconst Toast = types.reduce((toast, type) => {\r\n toast[type] = (content: string, options?: NoticeContent) => {\r\n notice({\r\n ...options,\r\n type,\r\n content\r\n });\r\n };\r\n return toast;\r\n}, {} as any);\r\n\r\nToast.defaults = defaultOptions;\r\n\r\nexport default Toast as ToastType;\r\n","import axios, { AxiosInstance, AxiosRequestConfig } from 'axios';\r\nimport queryString from 'query-string';\r\nimport * as rax from 'retry-axios';\r\nimport { RetryConfig } from 'retry-axios';\r\nimport Unauthorized from './errors/unauthorized';\r\nimport Toast from './utils/toast';\r\n\r\nexport type Errors = string | {\r\n [key: string]: string\r\n}\r\n\r\ndeclare module 'retry-axios' {\r\n interface RetryConfig {\r\n retryDecider?: () => boolean;\r\n }\r\n}\r\n\r\ndeclare module 'axios' {\r\n interface AxiosError {\r\n errors: Errors;\r\n }\r\n\r\n interface AxiosRequestConfig {\r\n raxConfig?: RetryConfig;\r\n authTokenName?: string;\r\n }\r\n}\r\n\r\nrax.attach();\r\n\r\naxios.defaults.raxConfig = {\r\n retryDelay: 2000,\r\n backoffType: 'static',\r\n shouldRetry: ({ config, response }) => {\r\n if (config.raxConfig?.retryDecider && !config.raxConfig.retryDecider()) {\r\n return false;\r\n }\r\n return config.method?.toUpperCase() === 'GET' && response?.status === 449;\r\n }\r\n};\r\naxios.defaults.maxContentLength = Infinity;\r\naxios.defaults.maxBodyLength = Infinity;\r\naxios.defaults.baseURL = '/api';\r\naxios.defaults.authTokenName = 'authorization';\r\naxios.interceptors.request.use(\r\n config => {\r\n const key = config.authTokenName;\r\n if (key) {\r\n const token = localStorage.getItem(key);\r\n\r\n if (token) {\r\n config.headers = {\r\n Authorization: `Bearer ${token}`,\r\n ...config.headers,\r\n };\r\n }\r\n }\r\n return config;\r\n },\r\n error => {\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\nconst isRecord = (data: any): data is Record<string, string> => {\r\n return data && (typeof data === 'object');\r\n};\r\n\r\naxios.interceptors.response.use(\r\n response => {\r\n if (response.status === 201 && response.data.location) {\r\n window.location.href = response.data.location;\r\n response.data = undefined; //防止多次跳转\r\n }\r\n\r\n return response;\r\n },\r\n e => {\r\n if (axios.isAxiosError(e)) {\r\n if (e.response) {\r\n const { data, status } = e.response;\r\n if (status === 401) {\r\n e.errors = 'Unauthorized';\r\n if (isRecord(data) && data.url) {\r\n e = new Unauthorized(data.url);\r\n }\r\n Toast.error('Unauthorized');\r\n } else {\r\n if (isRecord(data)) {\r\n if (status === 422) {\r\n e.errors = data;\r\n } else if ('message' in data) {\r\n e.errors = data['message'];\r\n }\r\n } else {\r\n e.errors = data as string;\r\n }\r\n }\r\n }\r\n }\r\n return Promise.reject(e);\r\n }\r\n);\r\n\r\nexport type RequestConfig = AxiosRequestConfig | string\r\nexport type RequestInstance = AxiosInstance\r\nexport const isRequestError = axios.isAxiosError;\r\n\r\nexport const showRequestError = (e: any) => {\r\n if (axios.isAxiosError(e)) {\r\n let errors = e.errors;\r\n if (typeof e.errors !== 'string') {\r\n errors = Object.values(e.errors).join('<br />');\r\n }\r\n Toast.error(errors as string);\r\n } else {\r\n throw e;\r\n }\r\n};\r\n\r\nconst request = async function <T = any>(config: RequestConfig) {\r\n config = typeof config === 'string' ? { url: config } : config;\r\n\r\n const { data } = await axios.request<T>({\r\n paramsSerializer: function(params) {\r\n return queryString.stringify(params, {\r\n sort: false,\r\n skipNull: true,\r\n skipEmptyString: true,\r\n arrayFormat: 'bracket',\r\n });\r\n },\r\n ...config\r\n });\r\n\r\n return data;\r\n};\r\n\r\nrequest.defaults = axios.defaults;\r\nrequest.interceptors = axios.interceptors;\r\n\r\nexport default request;\r\n","import { useCallback, useState } from 'react';\r\nimport type { Dispatch, SetStateAction } from 'react';\r\nimport useUnmountedRef from './use-unmounted-ref';\r\n\r\nfunction useSafeState<S>(initialState: S | (() => S)): [S, Dispatch<SetStateAction<S>>];\r\n\r\nfunction useSafeState<S = undefined>(): [S | undefined, Dispatch<SetStateAction<S | undefined>>];\r\n\r\nfunction useSafeState<S>(initialState?: S | (() => S)) {\r\n const unmountedRef = useUnmountedRef();\r\n const [state, setState] = useState(initialState);\r\n const setCurrentState = useCallback((currentState) => {\r\n /** if component is unmounted, stop update */\r\n if (unmountedRef.current) return;\r\n setState(currentState);\r\n }, []);\r\n\r\n return [state, setCurrentState] as const;\r\n}\r\n\r\nexport default useSafeState;\r\n","import { useEffect, useRef } from 'react';\r\n\r\nconst useUnmountedRef = () => {\r\n const unmountedRef = useRef(false);\r\n useEffect(() => {\r\n unmountedRef.current = false;\r\n return () => {\r\n unmountedRef.current = true;\r\n };\r\n }, []);\r\n return unmountedRef;\r\n};\r\n\r\nexport default useUnmountedRef;\r\n","import show from '../components/modal/show';\r\nimport Modal, { MessageProps } from '../components/modal';\r\nimport { useEffect, useRef } from 'react';\r\nimport request from '../request';\r\nimport useSafeState from '../hooks/use-safe-state';\r\n\r\ninterface PayResult {\r\n pay_url: string;\r\n order_no: string;\r\n}\r\n\r\ninterface Options {\r\n result: PayResult;\r\n checkUrl: string;\r\n onComplete?: () => void;\r\n}\r\n\r\nconst WaitModal = function({ state, message, resolve }: MessageProps<Options>) {\r\n\r\n const open = useRef(true);\r\n const { result, checkUrl, onComplete } = message;\r\n const [checking, setChecking] = useSafeState(false);\r\n\r\n useEffect(() => {\r\n request({\r\n url: checkUrl,\r\n method: 'post',\r\n data: { order_no: result.order_no },\r\n raxConfig: {\r\n shouldRetry(err) {\r\n return open.current && err.response?.status === 449;\r\n }\r\n }\r\n }).then(() => {\r\n onComplete?.();\r\n resolve();\r\n }).catch(() => null);\r\n }, []);\r\n\r\n return <Modal\r\n {...state}\r\n centered\r\n onHide={() => {\r\n open.current = false;\r\n state.onHide();\r\n }}\r\n backdrop='static'\r\n header='支付结果'\r\n okText='已完成支付'\r\n okButtonProps={{ loading: checking }}\r\n onOk={async (e) => {\r\n e.preventDefault();\r\n try {\r\n setChecking(true);\r\n await request({\r\n url: checkUrl,\r\n method: 'post',\r\n data: { order_no: result.order_no },\r\n raxConfig: {\r\n shouldRetry() {\r\n return false;\r\n }\r\n }\r\n });\r\n onComplete?.();\r\n resolve();\r\n } catch {\r\n // ignore\r\n } finally {\r\n setChecking(false);\r\n }\r\n }}\r\n cancelText='取消'\r\n >\r\n 请在新打开的页面上进行支付,支付完成后再关闭此窗口\r\n </Modal>;\r\n};\r\n\r\nexport default function waitPayComplete(options: Options) {\r\n const { result } = options;\r\n window.open(result.pay_url);\r\n show(WaitModal, options);\r\n}\r\n","import { ReactNode } from 'react';\r\nimport styled from 'styled-components';\r\n\r\nconst Container = styled.div`\r\n padding: 48px 32px;\r\n`;\r\n\r\nconst Icon = styled.div`\r\n margin-bottom: 24px;\r\n text-align: center;\r\n font-size: 72px;\r\n`;\r\n\r\nconst Title = styled.div`\r\n color: rgba(0, 0, 0, .85);\r\n font-size: 24px;\r\n line-height: 1.8;\r\n text-align: center;\r\n`;\r\n\r\nconst Extra = styled.div`\r\n margin-top: 32px;\r\n text-align: center;\r\n`;\r\n\r\nconst IconMap = {\r\n success: <i className='bi bi-check-circle-fill text-success' />,\r\n error: <i className='bi bi-exclamation-circle-fill text-danger' />,\r\n info: <i className='bi bi-info-circle-fill text-info' />,\r\n warning: <i className='bi bi-exclamation-triangle-fill text-warning' />,\r\n};\r\n\r\ninterface ResultProps {\r\n status?: keyof typeof IconMap\r\n icon?: ReactNode\r\n title?: string\r\n extra?: ReactNode;\r\n}\r\n\r\nexport default function Result({ status, title, icon, extra }: ResultProps) {\r\n\r\n if (!icon && status) {\r\n icon = IconMap[status];\r\n }\r\n\r\n return <Container>\r\n {icon && <Icon>{icon}</Icon>}\r\n {title && <Title>{title}</Title>}\r\n {extra && <Extra>{extra}</Extra>}\r\n </Container>;\r\n}\r\n","import styled from 'styled-components';\r\n\r\nexport const Dimmable = styled.div`\r\n position: relative;\r\n`;\r\n\r\ninterface DimmerProps {\r\n active?: boolean\r\n inverted?: boolean\r\n}\r\n\r\nconst Dimmer = styled.div<DimmerProps>`\r\n display: ${props => props.active ? 'flex' : 'none'};\r\n position: absolute;\r\n top: 0 !important;\r\n left: 0 !important;\r\n width: 100%;\r\n height: 100%;\r\n text-align: center;\r\n vertical-align: middle;\r\n padding: 1em;\r\n background-color: ${props => props.inverted ? 'rgba(255, 255, 255, .85)' : 'rgba(0, 0, 0, .85)'};\r\n opacity: ${props => props.active ? 1 : 0};\r\n line-height: 1;\r\n animation-fill-mode: both;\r\n animation-duration: .5s;\r\n transition: background-color .5s linear;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n user-select: none;\r\n will-change: opacity;\r\n z-index: 990;\r\n`;\r\n\r\nexport default Dimmer;\r\n","import { PropsWithChildren } from 'react';\r\nimport { Spinner, SpinnerProps } from 'react-bootstrap';\r\nimport Dimmer from './dimmer';\r\nimport styled from 'styled-components';\r\n\r\ninterface LoaderProps {\r\n loading?: boolean;\r\n animation?: SpinnerProps['animation'];\r\n wrap?: boolean | number;\r\n}\r\n\r\nexport default function Loader({\r\n loading = true,\r\n children,\r\n variant = 'primary',\r\n animation = 'border',\r\n wrap,\r\n ...props\r\n}: PropsWithChildren<LoaderProps & Omit<SpinnerProps, 'animation'>>): JSX.Element | null {\r\n if (!loading) {\r\n return null;\r\n }\r\n\r\n if (children) {\r\n children = <p className='mt-3 text-secondary'>{children}</p>;\r\n }\r\n\r\n children = <Dimmer inverted active>\r\n <Spinner animation={animation} variant={variant} {...props} />\r\n {children}\r\n </Dimmer>;\r\n\r\n if (wrap) {\r\n return <Wrap $height={typeof wrap === 'number' ? wrap : 150}>\r\n {children}\r\n </Wrap>;\r\n }\r\n\r\n return children as JSX.Element;\r\n}\r\n\r\nconst Wrap = styled.div<{ $height: number }>`\r\n position: relative;\r\n height: ${props => `${props.$height}px`};\r\n`;\r\n","import { PropsWithChildren } from 'react';\r\nimport { Card as BsCard, CardProps as BsCardProps } from 'react-bootstrap';\r\nimport classNames from 'classnames';\r\n\r\ninterface CardProps extends BsCardProps {\r\n title?: string;\r\n}\r\n\r\nexport default function Card({ children, title, className, ...props }: PropsWithChildren<CardProps>) {\r\n\r\n return <BsCard className={classNames('border-0 shadow-sm mb-3', className)} {...props}>\r\n <div className='card-body'>\r\n {title && <>\r\n <h5>{title}</h5>\r\n <hr />\r\n </>}\r\n {children}\r\n </div>\r\n </BsCard>;\r\n}\r\n","import { Alert } from 'react-bootstrap';\r\nimport { Errors } from '../request';\r\n\r\nexport default function Error({ errors }: { errors?: Errors }) {\r\n if (!errors) {\r\n return null;\r\n }\r\n return <Alert variant='danger'>\r\n <ul className='mb-0'>\r\n {typeof errors === 'string'\r\n ? <li>{errors}</li>\r\n : Object.entries(errors).map(([name, error]) => <li key={name}>{error}</li>)\r\n }\r\n </ul>\r\n </Alert>;\r\n}\r\n","import { Children, ReactNode } from 'react';\r\nimport styled, { css } from 'styled-components';\r\n\r\ninterface SpaceProps {\r\n children: ReactNode;\r\n size?: 'small' | 'middle' | 'large' | number;\r\n direction?: 'vertical' | 'horizontal';\r\n className?: string;\r\n}\r\n\r\n\r\nexport default function Space({ children, className, size = 'small', direction = 'horizontal' }: SpaceProps) {\r\n\r\n if (typeof size === 'string') {\r\n size = {\r\n small: 8,\r\n middle: 16,\r\n large: 24\r\n }[size];\r\n }\r\n\r\n const items = Children.map(children, (child) => {\r\n if (child) {\r\n return <Item>{child}</Item>;\r\n }\r\n });\r\n\r\n return <Container className={className} $direction={direction} $size={size}>\r\n {items}\r\n </Container>;\r\n}\r\n\r\nconst Container = styled.div<{ $size: number, $direction: string }>`\r\n display: inline-flex;\r\n align-items: center;\r\n gap: ${props => props.$size}px;\r\n\r\n ${props => props.$direction === 'vertical' && css`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: inherit;\r\n `}\r\n`;\r\n\r\nconst Item = styled.div`\r\n\r\n`;\r\n","import { ComponentProps, lazy, Suspense } from 'react';\r\n\r\nconst LazySteps = lazy(() => import('./lazy/steps'));\r\nconst LazyStep = lazy(() => import('./lazy/steps').then(({ Step }) => ({ default: Step })));\r\n\r\nexport default function Steps(props: ComponentProps<typeof LazySteps>) {\r\n return <Suspense fallback={null}>\r\n <LazySteps {...props} />\r\n </Suspense>;\r\n}\r\n\r\nconst Step = function(props: ComponentProps<typeof LazyStep>) {\r\n return <Suspense fallback={null}>\r\n <LazyStep {...props} />\r\n </Suspense>;\r\n};\r\n\r\nSteps.Step = Step;\r\n\r\nexport { Step };\r\n","import { ReactNode } from 'react';\r\nimport Card from './card';\r\nimport styled from 'styled-components';\r\n\r\nexport interface StatisticProps {\r\n title: ReactNode;\r\n content: ReactNode;\r\n footer?: ReactNode;\r\n}\r\n\r\nexport default function Statistic({ title, content, footer }: StatisticProps) {\r\n\r\n return <Card>\r\n <Title>{title}</Title>\r\n <Content>{content}</Content>\r\n {footer && <Footer>{footer}</Footer>}\r\n </Card>;\r\n}\r\n\r\nconst Footer = styled.div`\r\n margin-top: 9px;\r\n padding-top: 10px;\r\n border-top: 1px solid #f0f0f0;\r\n color: rgba(0, 0, 0, .65);\r\n`;\r\n\r\nconst Content = styled.div`\r\n color: rgba(0, 0, 0, .85);\r\n font-size: 24px;\r\n`;\r\n\r\nconst Title = styled.div`\r\n margin-bottom: 4px;\r\n color: rgba(0, 0, 0, .45);\r\n font-size: 1.1rem;\r\n`;\r\n\r\n","import { ReactNode, useCallback, useEffect, useMemo, useState } from 'react';\r\nimport { Pagination as BsPagination } from 'react-bootstrap';\r\n\r\nfunction noop() {\r\n}\r\n\r\n\r\nfunction isInteger(value: any): value is number {\r\n return (\r\n typeof value === 'number' && isFinite(value) && Math.floor(value) === value\r\n );\r\n}\r\n\r\nexport interface PaginationProps {\r\n className?: string\r\n total: number\r\n current?: number\r\n defaultCurrent?: number\r\n pageSize?: number\r\n defaultPageSize?: number,\r\n onChange?: (current: number, pageSize: number) => void\r\n}\r\n\r\nexport default function Pagination({\r\n total = 0,\r\n onChange = noop,\r\n defaultCurrent = 1,\r\n defaultPageSize = 10,\r\n className,\r\n ...props\r\n}: PaginationProps) {\r\n\r\n const [current, setCurrent] = useState(defaultCurrent);\r\n const [pageSize, setPageSize] = useState(defaultPageSize);\r\n\r\n useEffect(() => {\r\n if (isInteger(props.current)) {\r\n setCurrent(props.current);\r\n }\r\n }, [props.current]);\r\n\r\n useEffect(() => {\r\n if (isInteger(props.pageSize)) {\r\n setPageSize(props.pageSize);\r\n }\r\n }, [props.pageSize]);\r\n\r\n const allPages = useMemo(() => {\r\n return Math.floor((total - 1) / pageSize) + 1;\r\n }, [total, pageSize]);\r\n\r\n const handleChange = useCallback((p: number) => {\r\n return () => {\r\n if (p !== current) {\r\n setCurrent(p);\r\n onChange(p, pageSize);\r\n }\r\n };\r\n }, [onChange, current, pageSize]);\r\n\r\n const pageBufferSize = 2;\r\n const prevPage = current - 1 > 0 ? current - 1 : 0;\r\n const nextPage = current + 1 < allPages ? current + 1 : allPages;\r\n\r\n const pagerList: ReactNode[] = [];\r\n let jumpPrev: ReactNode = null;\r\n let jumpNext: ReactNode = null;\r\n let firstPager: ReactNode = null;\r\n let lastPager: ReactNode = null;\r\n\r\n if (allPages <= 3 + pageBufferSize * 2) {\r\n for (let i = 1; i <= allPages; i += 1) {\r\n const active = current === i;\r\n pagerList.push(\r\n <BsPagination.Item key={i} active={active} onClick={handleChange(i)}>{i}</BsPagination.Item>\r\n );\r\n }\r\n } else {\r\n lastPager = <BsPagination.Last key='last' onClick={handleChange(allPages)} />;\r\n firstPager = <BsPagination.First key='first' onClick={handleChange(1)} />;\r\n jumpPrev = <BsPagination.Prev key='prev' onClick={handleChange(prevPage)} />;\r\n jumpNext = <BsPagination.Next key='next' onClick={handleChange(nextPage)} />;\r\n\r\n let left = Math.max(1, current - pageBufferSize);\r\n let right = Math.min(current + pageBufferSize, allPages);\r\n\r\n if (current - 1 <= pageBufferSize) {\r\n right = 1 + pageBufferSize * 2;\r\n }\r\n\r\n if (allPages - current <= pageBufferSize) {\r\n left = allPages - pageBufferSize * 2;\r\n }\r\n\r\n for (let i = left; i <= right; i += 1) {\r\n const active = current === i;\r\n pagerList.push(\r\n <BsPagination.Item key={i} active={active} onClick={handleChange(i)}>{i}</BsPagination.Item>\r\n );\r\n }\r\n\r\n if (current - 1 >= pageBufferSize * 2 && current !== 1 + 2) {\r\n pagerList.unshift(jumpPrev);\r\n }\r\n if (\r\n allPages - current >= pageBufferSize * 2 &&\r\n current !== allPages - 2\r\n ) {\r\n pagerList.push(jumpNext);\r\n }\r\n\r\n if (left !== 1) {\r\n pagerList.unshift(firstPager);\r\n }\r\n if (right !== allPages) {\r\n pagerList.push(lastPager);\r\n }\r\n }\r\n\r\n return <BsPagination className={className}>\r\n {pagerList}\r\n </BsPagination>;\r\n\r\n}\r\n","import { useMemo } from 'react';\r\n\r\ninterface Props {\r\n value: number;\r\n currency?: boolean;\r\n locale?: string;\r\n className?: string;\r\n options?: Intl.NumberFormatOptions;\r\n}\r\n\r\nexport default function NumberFormat({ className, value, locale = 'zh-CN', currency = true, options = {} }: Props) {\r\n\r\n const formatter = useMemo(() => {\r\n\r\n let opt;\r\n\r\n if (currency) {\r\n opt = {\r\n style: 'currency',\r\n currency: 'CNY'\r\n };\r\n } else {\r\n opt = {\r\n minimumFractionDigits: 2,\r\n };\r\n }\r\n\r\n return new Intl.NumberFormat(locale, { ...opt, ...options });\r\n }, [currency, locale, options]);\r\n\r\n if (className) {\r\n return <span className={className}>{formatter.format(value)}</span>;\r\n }\r\n\r\n return <>{formatter.format(value)}</>;\r\n}\r\n","import { Button, ButtonProps } from 'react-bootstrap';\r\n\r\ninterface CustomButtonProps extends ButtonProps {\r\n loading: boolean;\r\n}\r\n\r\nexport default function LoadingButton({ loading, disabled, children, ...props }: CustomButtonProps) {\r\n\r\n return <Button {...props} disabled={loading || disabled}>\r\n {loading ? 'Loading…' : children}\r\n </Button>;\r\n}\r\n","import { ComponentProps, lazy, Suspense } from 'react';\r\n\r\nconst LazyImageZoom = lazy(() => import('./lazy/image-zoom'));\r\n\r\nexport default function ImageZoom(props: ComponentProps<typeof LazyImageZoom>) {\r\n return <Suspense fallback={null}>\r\n <LazyImageZoom {...props} />\r\n </Suspense>;\r\n}\r\n","import request, { RequestConfig, showRequestError } from '../request';\r\nimport { createElement, ElementType, MouseEvent, useCallback } from 'react';\r\nimport { AxiosRequestConfig } from 'axios';\r\nimport Button, { ButtonProps } from './button';\r\nimport useSafeState from '../hooks/use-safe-state';\r\nimport Modal from './modal';\r\n\r\ninterface Props extends Omit<ButtonProps, 'as'> {\r\n url: RequestConfig;\r\n method?: AxiosRequestConfig['method'];\r\n confirm?: string;\r\n onSuccess?: (result: any) => void;\r\n as?: ElementType | ButtonProps['as'];\r\n}\r\n\r\nexport default function RequestButton({\r\n url,\r\n method,\r\n confirm,\r\n onSuccess,\r\n children,\r\n disabled,\r\n as = Button,\r\n ...props\r\n}: Props) {\r\n\r\n const [fetching, setFetching] = useSafeState(false);\r\n\r\n const handleClick = useCallback(async (e: MouseEvent) => {\r\n e.preventDefault();\r\n try {\r\n setFetching(true);\r\n if (confirm) {\r\n if (!await Modal.confirm({ message: confirm })) {\r\n return;\r\n }\r\n }\r\n\r\n const config = typeof url === 'string' ? { url, method } : { method, ...url };\r\n\r\n const result = await request(config);\r\n\r\n if (onSuccess) {\r\n onSuccess(result);\r\n }\r\n } catch (e) {\r\n showRequestError(e);\r\n } finally {\r\n setFetching(false);\r\n }\r\n }, [url, method, setFetching]);\r\n\r\n return createElement(as, {\r\n ...props,\r\n disabled: disabled || fetching,\r\n onClick: handleClick\r\n }, children);\r\n}\r\n","import { forwardRef, lazy, Suspense } from 'react';\r\nimport type { CustomFormType } from './lazy/form';\r\n\r\nconst LazyForm = lazy(() => import('./lazy/form'));\r\n\r\nconst Form: CustomFormType = forwardRef((props, ref) => {\r\n return <Suspense fallback={null}>\r\n <LazyForm {...props} ref={ref} />\r\n </Suspense>;\r\n});\r\n\r\nexport default Form;\r\n\r\nexport type { FormProps, FormType } from './lazy/form';\r\n","import { ComponentProps, forwardRef, lazy, Suspense } from 'react';\r\nimport type { CustomTableType } from './lazy/table';\r\n\r\nconst LazyTable = lazy(() => import('./lazy/table'));\r\n\r\nconst Table: CustomTableType = forwardRef((props: ComponentProps<typeof LazyTable>, ref) => {\r\n return <Suspense fallback={null}>\r\n <LazyTable {...props} ref={ref} />\r\n </Suspense>;\r\n});\r\n\r\nexport default Table;\r\n\r\nexport type { TableProps, Columns, TableType } from './lazy/table';\r\n","import { useCallback, useState } from 'react';\r\n\r\ninterface Options {\r\n onHide?: () => void;\r\n onShow?: () => void;\r\n}\r\n\r\nlet id = 0;\r\n\r\nexport default function useOverlayState({ onHide, onShow }: Options = {}) {\r\n const [visible, setVisible] = useState(false);\r\n\r\n const [key, setKey] = useState(`visible-${id}`);\r\n\r\n const hide = useCallback(() => {\r\n setVisible(false);\r\n if (onHide) {\r\n onHide();\r\n }\r\n }, [setVisible, onHide]);\r\n\r\n const exit = useCallback(() => {\r\n setKey(`visible-${++id}`);\r\n }, [setKey, id]);\r\n\r\n const show = useCallback(() => {\r\n setVisible(true);\r\n if (onShow) {\r\n onShow();\r\n }\r\n }, [setVisible, onShow]);\r\n\r\n const state = {\r\n show: visible,\r\n onHide: hide,\r\n onExited: exit,\r\n key\r\n };\r\n\r\n return {\r\n visible,\r\n show,\r\n hide,\r\n state\r\n };\r\n}\r\n","import {\r\n createElement,\r\n ElementType,\r\n forwardRef,\r\n ForwardRefExoticComponent,\r\n MouseEvent,\r\n PropsWithChildren,\r\n PropsWithoutRef,\r\n ReactNode,\r\n RefAttributes,\r\n useImperativeHandle\r\n} from 'react';\r\nimport useOverlayState from '../hooks/use-overlay-state';\r\nimport Modal, { ModalProps } from './modal';\r\nimport { ButtonProps } from 'react-bootstrap';\r\nimport Button from './button';\r\n\r\nexport interface ModalButtonProps extends Omit<ButtonProps, 'as'> {\r\n text: ReactNode;\r\n modalProps?: Omit<ModalProps, 'children' | 'confirmLoading' | 'onOk'>;\r\n onOk?: () => any;\r\n onShow?: () => void;\r\n confirmLoading?: boolean;\r\n as?: ElementType | ButtonProps['as'];\r\n}\r\n\r\nexport interface ModalType {\r\n close: () => void;\r\n}\r\n\r\ntype ModalButtonType = ForwardRefExoticComponent<PropsWithoutRef<PropsWithChildren<ModalButtonProps>>\r\n & RefAttributes<ModalType>>\r\n\r\nconst ModalButton: ModalButtonType = forwardRef(({\r\n text,\r\n onOk,\r\n modalProps,\r\n children,\r\n onShow,\r\n confirmLoading,\r\n as = Button,\r\n ...props\r\n}, ref) => {\r\n\r\n const { state, show, hide } = useOverlayState({ onShow });\r\n\r\n useImperativeHandle(ref, () => ({\r\n close: hide\r\n }));\r\n\r\n const handleOk = async (e: MouseEvent) => {\r\n if (onOk) {\r\n const result = await onOk();\r\n if (result === false) {\r\n e.preventDefault();\r\n }\r\n }\r\n };\r\n\r\n const button = createElement(as, {\r\n ...props,\r\n onClick: show\r\n }, text);\r\n\r\n return <>\r\n {button}\r\n <Modal\r\n header={text}\r\n {...modalProps}\r\n {...state}\r\n confirmLoading={confirmLoading}\r\n onOk={handleOk}\r\n >\r\n {children}\r\n </Modal>\r\n </>;\r\n});\r\n\r\nexport default ModalButton;\r\n","import ModalButton, { ModalButtonProps, ModalType } from './modal-button';\r\nimport { ReactNode, useCallback, useRef, useState } from 'react';\r\nimport Form, { FormProps, FormType } from './form';\r\n\r\nexport interface ModalFormProps<T = any> extends FormProps<T> {\r\n text: ReactNode;\r\n buttonProps?: Omit<ModalButtonProps, 'text' | 'modalProps' | 'confirmLoading' | 'onOk'>;\r\n modalProps?: ModalButtonProps['modalProps'];\r\n children?: ReactNode;\r\n}\r\n\r\nexport default function ModalForm<T = any>({\r\n text,\r\n onSuccess,\r\n buttonProps,\r\n modalProps,\r\n children,\r\n ...props\r\n}: ModalFormProps<T>) {\r\n\r\n const [loading, setLoading] = useState(false);\r\n\r\n const ref = useRef<ModalType>(null);\r\n const form = useRef<FormType>(null);\r\n\r\n const handleOk = useCallback(() => {\r\n form.current?.submit();\r\n return false;\r\n }, []);\r\n\r\n const handleSuccess = useCallback((data) => {\r\n if (onSuccess) {\r\n onSuccess(data);\r\n }\r\n ref.current?.close();\r\n }, [onSuccess]);\r\n\r\n return <ModalButton\r\n ref={ref}\r\n text={text}\r\n {...buttonProps}\r\n modalProps={modalProps}\r\n onOk={handleOk}\r\n confirmLoading={loading}\r\n >\r\n <Form\r\n {...props}\r\n onSubmitting={setLoading}\r\n ref={form}\r\n onSuccess={handleSuccess}\r\n >\r\n {children}\r\n <input type='submit' hidden />\r\n </Form>\r\n </ModalButton>;\r\n}\r\n","import { useAsyncCallback, UseAsyncCallbackOptions } from 'react-async-hook';\r\nimport request, { isRequestError, RequestConfig } from '../request';\r\nimport { DependencyList, useCallback, useEffect } from 'react';\r\nimport { AxiosRequestConfig } from 'axios';\r\nimport { values } from 'lodash';\r\n\r\ntype UseRequestOptions<T> = {\r\n manual?: boolean\r\n refreshDeps?: DependencyList;\r\n} & UseAsyncCallbackOptions<T>;\r\n\r\nexport default function useRequest<T = any>(config: RequestConfig, {\r\n manual,\r\n refreshDeps,\r\n ...options\r\n}: UseRequestOptions<T> = {}) {\r\n let { execute, currentParams, error, ...others } = useAsyncCallback(async (params?: AxiosRequestConfig) => {\r\n\r\n config = typeof config === 'string' ? { url: config } : config;\r\n\r\n return await request<T>({\r\n ...config,\r\n ...params\r\n });\r\n }, options);\r\n\r\n useEffect(() => {\r\n if (!manual && !refreshDeps) {\r\n try {\r\n execute();\r\n } catch {\r\n\r\n }\r\n }\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (refreshDeps) {\r\n refresh();\r\n }\r\n }, refreshDeps);\r\n\r\n const refresh = useCallback(async () => {\r\n try {\r\n if (currentParams) {\r\n await execute(...currentParams);\r\n } else {\r\n await execute();\r\n }\r\n } catch {\r\n\r\n }\r\n }, [execute, currentParams]);\r\n\r\n if (error && isRequestError(error)) {\r\n const errors = error.errors;\r\n error = new Error(typeof errors === 'string' ? errors : values(errors).join(''));\r\n }\r\n\r\n return {\r\n refresh,\r\n execute,\r\n error,\r\n ...others\r\n };\r\n}\r\n","import { DependencyList, useCallback, useEffect, useRef } from 'react';\r\n\r\nexport default function useCallbackRef<T extends (...args: any[]) => any>(\r\n callback: T | undefined,\r\n deps: DependencyList = [],\r\n) {\r\n const callbackRef = useRef(callback);\r\n\r\n useEffect(() => {\r\n callbackRef.current = callback;\r\n });\r\n\r\n return useCallback(((...args) => callbackRef.current?.(...args)) as T, deps);\r\n}\r\n","import { Dispatch, SetStateAction, useState } from 'react';\r\nimport useCallbackRef from './use-callback-ref';\r\n\r\nexport interface UseControllableStateProps<T> {\r\n value?: T;\r\n defaultValue?: T | (() => T);\r\n onChange?: (value: T) => void;\r\n shouldUpdate?: (prev: T, next: T) => boolean;\r\n}\r\n\r\nexport default function useControllableState<T>(props: UseControllableStateProps<T>) {\r\n const {\r\n value: valueProp,\r\n defaultValue,\r\n onChange,\r\n shouldUpdate = (prev, next) => prev !== next,\r\n } = props;\r\n\r\n const onChangeProp = useCallbackRef(onChange);\r\n const shouldUpdateProp = useCallbackRef(shouldUpdate);\r\n\r\n const [uncontrolledState, setUncontrolledState] = useState(defaultValue as T);\r\n const controlled = valueProp !== undefined;\r\n const value = controlled ? valueProp : uncontrolledState;\r\n\r\n const setValue = useCallbackRef(\r\n (next: SetStateAction<T>) => {\r\n const setter = next as (prevState?: T) => T;\r\n const nextValue = typeof next === 'function' ? setter(value) : next;\r\n\r\n if (!shouldUpdateProp(value, nextValue)) {\r\n return;\r\n }\r\n\r\n if (!controlled) {\r\n setUncontrolledState(nextValue);\r\n }\r\n\r\n onChangeProp(nextValue);\r\n },\r\n [controlled, onChangeProp, value, shouldUpdateProp],\r\n );\r\n\r\n return [value, setValue] as [T, Dispatch<SetStateAction<T>>];\r\n}\r\n","import { debounce, DebouncedFunc } from 'lodash';\r\nimport { useEffect, useRef } from 'react';\r\n\r\nexport default function useDebounce<T extends (...args: any) => any>(callback: T, wait: number, options?: {}): DebouncedFunc<T> {\r\n const callbackRef = useRef<T>(callback);\r\n const debouncedCallbackRef = useRef<DebouncedFunc<T>>(\r\n debounce(callback, wait, options)\r\n );\r\n\r\n useEffect(() => {\r\n callbackRef.current = callback;\r\n });\r\n\r\n useEffect(() => {\r\n debouncedCallbackRef.current = debounce((...args: any) => {\r\n callbackRef.current(...args);\r\n }, wait, options);\r\n }, [wait, options]);\r\n\r\n return debouncedCallbackRef.current;\r\n}\r\n"],"names":["CustomSwal","withReactContent","Swal","defaultOptions","confirmButtonText","cancelButtonText","Message","confirm","async","isConfirmed","fire","icon","showCancelButton","options","data","preConfirm","e","Error","showValidationMessage","message","success","toast","position","timer","showConfirmButton","error","close","result","defaults","MessageContext","createContext","wrapMessage","Component","_ref","resolve","destroy","show","setShow","initState","callbackRef","useRef","state","setState","useState","useEffect","current","value","callback","useStateWithCallback","context","useContext","handleResolve","useCallback","useMemo","onHide","onExited","container","_jsx","createMessage","Promise","component","hide","listener","memoryState","Set","modal","add","delete","Tooltip","tooltip","children","placement","OverlayTrigger","overlay","BsTooltip","id","uniqueId","TableContext","Button","forwardRef","ref","loading","percent","disabled","variant","props","_jsxs","Spinner","as","size","role","animation","className","button","BsButton","Confirm","title","okText","cancelText","Modal","centered","Header","Title","Body","Footer","onClick","header","footer","closable","onOk","onCancel","okButtonProps","bodyAs","headerAs","confirmLoading","rest","setLoading","okButton","defaultPrevented","cancelButton","_Fragment","ReactModal","closeButton","Provider","Array","from","map","index","Fragment","Unauthorized","constructor","url","super","_defineProperty","this","noticeInstance","notice","type","Notification","newInstance","prefixCls","maxCount","style","top","right","instance","getNoticeInstance","duration","content","Alert","Toast","reduce","rax","attach","axios","raxConfig","retryDelay","backoffType","shouldRetry","config","response","retryDecider","method","toUpperCase","status","maxContentLength","Infinity","maxBodyLength","baseURL","authTokenName","interceptors","request","use","key","token","localStorage","getItem","headers","Authorization","reject","isRecord","location","window","href","undefined","isAxiosError","errors","isRequestError","showRequestError","Object","values","join","paramsSerializer","params","queryString","stringify","sort","skipNull","skipEmptyString","arrayFormat","useSafeState","initialState","unmountedRef","useUnmountedRef","currentState","WaitModal","open","checkUrl","onComplete","checking","setChecking","order_no","err","then","catch","backdrop","preventDefault","waitPayComplete","pay_url","Container","styled","div","Icon","Extra","IconMap","info","warning","Result","extra","Dimmer","active","inverted","Loader","wrap","Wrap","$height","Card","BsCard","classNames","entries","_ref2","name","Space","direction","small","middle","large","items","Children","child","Item","$direction","$size","css","LazySteps","lazy","import","LazyStep","Step","default","Steps","Suspense","fallback","Statistic","Content","noop","isInteger","isFinite","Math","floor","Pagination","total","onChange","defaultCurrent","defaultPageSize","setCurrent","pageSize","setPageSize","allPages","handleChange","p","prevPage","nextPage","pagerList","jumpPrev","jumpNext","firstPager","lastPager","i","push","BsPagination","Last","First","Prev","Next","left","max","min","pageBufferSize","unshift","NumberFormat","locale","currency","formatter","opt","minimumFractionDigits","Intl","format","LoadingButton","LazyImageZoom","ImageZoom","RequestButton","onSuccess","fetching","setFetching","handleClick","createElement","LazyForm","Form","LazyTable","Table","useOverlayState","onShow","arguments","length","visible","setVisible","setKey","exit","ModalButton","text","modalProps","useImperativeHandle","ModalForm","buttonProps","form","handleOk","submit","handleSuccess","onSubmitting","hidden","useRequest","manual","refreshDeps","execute","currentParams","others","useAsyncCallback","refresh","useCallbackRef","deps","_len","args","_key","useControllableState","valueProp","defaultValue","shouldUpdate","prev","next","onChangeProp","shouldUpdateProp","uncontrolledState","setUncontrolledState","controlled","setValue","nextValue","useDebounce","wait","debouncedCallbackRef","debounce"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index-4f51cece.js","sources":["../src/utils/message.ts","../src/hooks/use-state-with-callback.ts","../src/components/modal/message.tsx","../src/components/modal/show.tsx","../src/components/tooltip.tsx","../src/components/lazy/table/context.ts","../src/components/button.tsx","../src/components/modal/confirm.tsx","../src/components/modal/index.tsx","../src/errors/unauthorized.ts","../src/utils/toast.tsx","../src/request.ts","../src/hooks/use-unmounted-ref.ts","../src/hooks/use-safe-state.ts","../src/utils/wait-pay-complete.tsx","../src/components/result.tsx","../src/components/dimmer.tsx","../src/components/loader.tsx","../src/components/card.tsx","../src/components/error.tsx","../src/components/space.tsx","../src/components/steps.tsx","../src/components/statistic.tsx","../src/components/pagination.tsx","../src/components/number-format.tsx","../src/components/loading-button.tsx","../src/components/image-zoom.tsx","../src/components/request-button.tsx","../src/components/form.tsx","../src/components/table.tsx","../src/hooks/use-overlay-state.ts","../src/components/modal-button.tsx","../src/components/modal-form.tsx","../src/hooks/use-request.ts","../src/hooks/use-callback-ref.ts","../src/hooks/use-controllable-state.ts","../src/hooks/use-debounce.ts"],"sourcesContent":["import Swal from 'sweetalert2/dist/sweetalert2.js';\r\nimport withReactContent from 'sweetalert2-react-content';\r\nimport { SweetAlertOptions, SweetAlertResult } from 'sweetalert2';\r\n\r\nconst CustomSwal = withReactContent(Swal);\r\n\r\ninterface MessageOptions<T = any> extends SweetAlertOptions<T> {\r\n\r\n}\r\n\r\nconst defaultOptions: MessageOptions = {\r\n confirmButtonText: '确定',\r\n cancelButtonText: '取消',\r\n};\r\n\r\nconst Message = {\r\n confirm: async <T = any>(options: MessageOptions<T>) => {\r\n const { isConfirmed } = await CustomSwal.fire({\r\n ...defaultOptions,\r\n icon: 'warning',\r\n showCancelButton: true,\r\n ...options,\r\n async preConfirm(data) {\r\n if (options.preConfirm) {\r\n try {\r\n return await options.preConfirm(data);\r\n } catch (e) {\r\n if (e instanceof Error) {\r\n CustomSwal.showValidationMessage(e.message);\r\n }\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n });\r\n\r\n return isConfirmed;\r\n },\r\n success: (options: MessageOptions) => {\r\n CustomSwal.fire({\r\n ...defaultOptions,\r\n toast: true,\r\n position: 'top',\r\n icon: 'success',\r\n timer: 2000,\r\n showConfirmButton: false,\r\n ...options\r\n });\r\n },\r\n error: (options: MessageOptions) => {\r\n CustomSwal.fire({\r\n ...defaultOptions,\r\n toast: true,\r\n position: 'top',\r\n icon: 'error',\r\n timer: 5000,\r\n showConfirmButton: false,\r\n ...options\r\n });\r\n },\r\n close: (result?: SweetAlertResult) => {\r\n CustomSwal.close(result);\r\n },\r\n defaults: defaultOptions\r\n};\r\n\r\nexport default Message;\r\n","import { SetStateAction, useEffect, useRef, useState } from 'react';\n\nexport default function useStateWithCallback<S>(initState: S): [S, (value: SetStateAction<S>, callback: () => void) => void] {\n const callbackRef = useRef<Function | null>(null);\n\n const [state, setState] = useState(initState);\n\n useEffect(() => {\n if (callbackRef.current) {\n callbackRef.current();\n callbackRef.current = null;\n }\n }, [state]);\n\n const setCallbackState = (value: SetStateAction<S>, callback: () => void) => {\n callbackRef.current = typeof callback === 'function' ? callback : null;\n setState(value);\n };\n\n return [state, setCallbackState];\n}\n","import {\r\n ComponentType,\r\n createContext,\r\n Fragment,\r\n ReactNode,\r\n useCallback,\r\n useContext,\r\n useEffect,\r\n useMemo,\r\n useState\r\n} from 'react';\r\nimport useStateWithCallback from '../../hooks/use-state-with-callback';\r\nimport { ModalProps } from 'react-bootstrap';\r\n\r\ninterface MessageContextType {\r\n container?: ModalProps['container'];\r\n}\r\n\r\nconst MessageContext = createContext<MessageContextType>({});\r\n\r\ntype MessageWrapProps<T, P = void> = {\r\n resolve: (value: P | void) => void\r\n destroy: () => void\r\n message: T\r\n}\r\n\r\nexport type MessageProps<T, P = void> = {\r\n resolve: (value: P | void) => void\r\n message: T\r\n state: {\r\n show: boolean\r\n onHide: () => void\r\n onExited: () => void\r\n container?: ModalProps['container']\r\n }\r\n}\r\n\r\nexport function wrapMessage<T = {}, P = any>(Component: ComponentType<MessageProps<T, P>>): ComponentType<MessageWrapProps<T, P>> {\r\n\r\n return ({ resolve, destroy, message }) => {\r\n\r\n const [show, setShow] = useStateWithCallback(true);\r\n const context = useContext(MessageContext);\r\n\r\n const handleResolve = useCallback((value: P | void) => {\r\n setShow(false, () => {\r\n resolve(value);\r\n });\r\n }, [setShow, resolve]);\r\n\r\n const state = useMemo(() => {\r\n return {\r\n show,\r\n onHide: () => handleResolve(),\r\n onExited: () => destroy(),\r\n container: context.container\r\n };\r\n }, [show, handleResolve, destroy]);\r\n\r\n return <Component\r\n resolve={handleResolve}\r\n state={state}\r\n message={message}\r\n />;\r\n };\r\n}\r\n\r\nexport function createMessage<T = {}, P = any>(Component: ComponentType<MessageWrapProps<T, P>>): (message: T) => Promise<P | void> {\r\n return (message) => {\r\n return new Promise<P | void>((resolve) => {\r\n const component = <Component\r\n resolve={resolve}\r\n destroy={() => {\r\n hide(component);\r\n }}\r\n message={message}\r\n />;\r\n\r\n show(component);\r\n });\r\n };\r\n}\r\n\r\ntype State = Set<ReactNode>\r\n\r\nlet listener: (state: State) => void = () => void 0;\r\n\r\nlet memoryState: State = new Set();\r\n\r\nexport const show = (modal: ReactNode) => {\r\n memoryState = new Set(memoryState);\r\n memoryState.add(modal);\r\n\r\n listener(memoryState);\r\n};\r\n\r\nexport const hide = (modal: ReactNode) => {\r\n memoryState = new Set(memoryState);\r\n memoryState.delete(modal);\r\n\r\n listener(memoryState);\r\n};\r\n\r\nexport default function Message(props: MessageContextType) {\r\n const [state, setState] = useState<State>(memoryState);\r\n useEffect(() => {\r\n listener = setState;\r\n }, []);\r\n\r\n return <MessageContext.Provider value={props}>\r\n {Array.from(state).map((message, index) => <Fragment key={`message-${index}`}>{message}</Fragment>)}\r\n </MessageContext.Provider>;\r\n}\r\n","import { createMessage, MessageProps, wrapMessage } from './message';\r\nimport { ComponentType } from 'react';\r\n\r\nexport default function show<T, P = any>(Component: ComponentType<MessageProps<any, T>>, options?: P) {\r\n return createMessage(wrapMessage(Component))(options);\r\n}\r\n","import { OverlayTrigger, OverlayTriggerProps, Tooltip as BsTooltip } from 'react-bootstrap';\r\nimport { uniqueId } from 'lodash';\r\n\r\ninterface TooltipProps {\r\n tooltip: string;\r\n children: OverlayTriggerProps['children'];\r\n placement?: OverlayTriggerProps['placement'];\r\n}\r\n\r\nexport default function Tooltip({ tooltip, children, placement = 'bottom' }: TooltipProps) {\r\n\r\n return <OverlayTrigger\r\n placement={placement}\r\n overlay={\r\n <BsTooltip id={uniqueId()}>\r\n {tooltip}\r\n </BsTooltip>\r\n }\r\n >\r\n {children}\r\n </OverlayTrigger>;\r\n}\r\n","import { createContext } from 'react';\r\n\r\nexport const TableContext = createContext(false);\r\n","import { Button as BsButton, ButtonProps as BsButtonProps, Spinner } from 'react-bootstrap';\r\nimport { forwardRef, useContext } from 'react';\r\nimport Tooltip from './tooltip';\r\nimport { TableContext } from './lazy/table/context';\r\n\r\nexport interface ButtonProps extends BsButtonProps {\r\n loading?: boolean;\r\n percent?: number;\r\n tooltip?: string;\r\n}\r\n\r\nconst Button = forwardRef<any, ButtonProps>((\r\n {\r\n loading,\r\n percent,\r\n disabled,\r\n children,\r\n tooltip,\r\n variant,\r\n ...props\r\n },\r\n ref\r\n) => {\r\n\r\n const inTable = useContext(TableContext);\r\n\r\n if (inTable && !variant) {\r\n variant = 'link';\r\n }\r\n\r\n if (loading) {\r\n disabled = true;\r\n children = <>\r\n <Spinner ref={ref} as='span' size='sm' role='status' aria-hidden='true' animation='border' />\r\n {percent ? <span className='ms-2'>{percent}%</span> : null}\r\n </>;\r\n }\r\n\r\n const button = <BsButton ref={ref} {...props} variant={variant} disabled={disabled}>{children}</BsButton>;\r\n\r\n if (tooltip) {\r\n return <Tooltip tooltip={tooltip}>\r\n <span className={'d-inline-block'}>{button}</span>\r\n </Tooltip>;\r\n }\r\n\r\n return button;\r\n});\r\n\r\nexport default Button;\r\n","import { FC } from 'react';\r\nimport { Modal } from 'react-bootstrap';\r\nimport { createMessage, MessageProps, wrapMessage } from './message';\r\nimport Button from '../button';\r\n\r\ninterface ConfirmOptions {\r\n title?: string;\r\n message: string;\r\n okText?: string;\r\n cancelText?: string;\r\n}\r\n\r\nconst Confirm: FC<MessageProps<ConfirmOptions, true>> = function({\r\n state,\r\n message: {\r\n title,\r\n message,\r\n okText,\r\n cancelText\r\n },\r\n resolve,\r\n}) {\r\n return <Modal centered {...state} >\r\n <Modal.Header>\r\n <Modal.Title as='h5'>{title || '确认'}</Modal.Title>\r\n </Modal.Header>\r\n <Modal.Body>{message}</Modal.Body>\r\n <Modal.Footer>\r\n <Button variant='secondary' onClick={() => resolve()}>{cancelText || '取消'}</Button>\r\n <Button onClick={() => resolve(true)}>{okText || '确定'}</Button>\r\n </Modal.Footer>\r\n </Modal>;\r\n};\r\n\r\nexport default function confirm(options: ConfirmOptions) {\r\n return createMessage(wrapMessage(Confirm))(options);\r\n}\r\n","import { Modal as ReactModal, ModalProps as ReactModalProps } from 'react-bootstrap';\r\nimport { ElementType, MouseEvent, ReactNode, useMemo, useState } from 'react';\r\nimport Button, { ButtonProps } from '../button';\r\nimport show from './show';\r\nimport confirm from './confirm';\r\nimport Message, { MessageProps } from './message';\r\n\r\nexport interface ModalProps extends Pick<\r\n ReactModalProps,\r\n 'style' | 'container' | 'backdrop' | 'centered' | 'size' | 'scrollable' | 'fullscreen' | 'onHide' | 'onShow' | 'onEnter' | 'onEntering' | 'onEntered' | 'onExit' | 'onExiting' | 'onExited'\r\n> {\r\n children: ReactNode;\r\n header?: ReactNode;\r\n footer?: ReactNode | ((args: { okButton: ReactNode, cancelButton: ReactNode }) => ReactNode);\r\n okText?: string;\r\n cancelText?: string;\r\n closable?: boolean;\r\n show?: boolean;\r\n onOk?: (e: MouseEvent) => void;\r\n onCancel?: (e: MouseEvent) => void;\r\n okButtonProps?: ButtonProps;\r\n bodyAs?: ElementType;\r\n headerAs?: ElementType;\r\n confirmLoading?: boolean;\r\n}\r\n\r\nconst Modal = ({\r\n header,\r\n children,\r\n footer,\r\n closable = true,\r\n show,\r\n cancelText = '取消',\r\n okText = '确定',\r\n onOk,\r\n onCancel,\r\n onHide,\r\n okButtonProps,\r\n bodyAs,\r\n headerAs = 'h5',\r\n confirmLoading = false,\r\n ...rest\r\n}: ModalProps) => {\r\n\r\n const [loading, setLoading] = useState(false);\r\n\r\n const okButton = useMemo(() => {\r\n return <Button loading={loading || confirmLoading} variant={'primary'} onClick={async (e) => {\r\n setLoading(true);\r\n try {\r\n await onOk?.(e);\r\n if (!e.defaultPrevented) {\r\n onHide?.();\r\n }\r\n } finally {\r\n setLoading(false);\r\n }\r\n }} {...okButtonProps}>{okText}</Button>;\r\n }, [okButtonProps, okText, onOk, onHide, loading, confirmLoading]);\r\n\r\n const cancelButton = useMemo(() => {\r\n return <Button variant='secondary' onClick={(e) => {\r\n onCancel?.(e);\r\n if (!e.defaultPrevented) {\r\n onHide?.();\r\n }\r\n }}>{cancelText}</Button>;\r\n }, [onCancel, onHide, cancelText]);\r\n\r\n switch (typeof footer) {\r\n case 'undefined':\r\n footer = <>\r\n {cancelButton}\r\n {okButton}\r\n </>;\r\n break;\r\n case 'function':\r\n footer = footer({ okButton, cancelButton });\r\n break;\r\n }\r\n\r\n return <ReactModal {...rest} onHide={onHide} show={show}>\r\n {header && <ReactModal.Header closeButton={closable}>\r\n <ReactModal.Title as={headerAs}>{header}</ReactModal.Title>\r\n </ReactModal.Header>}\r\n <ReactModal.Body as={bodyAs}>{children}</ReactModal.Body>\r\n {footer && <ReactModal.Footer>{footer}</ReactModal.Footer>}\r\n </ReactModal>;\r\n};\r\n\r\nModal.Message = Message;\r\nModal.confirm = confirm;\r\nModal.show = show;\r\nexport default Modal;\r\nexport { MessageProps };\r\n","export default class Unauthorized extends Error {\r\n\r\n url: string;\r\n\r\n constructor(url: string) {\r\n super('Unauthorized');\r\n this.url = url;\r\n }\r\n}\r\n","import { Alert } from 'react-bootstrap';\r\nimport { NoticeContent, NotificationInstance } from 'rc-notification/lib/Notification';\r\nimport Notification from 'rc-notification';\r\nimport { NotificationProps } from 'rc-notification/es/Notification';\r\n\r\nlet noticeInstance: NotificationInstance | null;\r\n\r\nconst defaultOptions: NotificationProps & {\r\n getContainer?: () => HTMLElement;\r\n} = {};\r\n\r\nfunction getNoticeInstance(callback: (instance: NotificationInstance) => void) {\r\n if (noticeInstance) {\r\n return callback(noticeInstance);\r\n }\r\n\r\n Notification.newInstance({\r\n ...defaultOptions,\r\n prefixCls: 'notification',\r\n maxCount: 5,\r\n style: {\r\n top: 20,\r\n right: 20\r\n }\r\n }, (instance) => {\r\n if (noticeInstance) {\r\n callback(noticeInstance);\r\n return;\r\n }\r\n noticeInstance = instance;\r\n callback(instance);\r\n });\r\n}\r\n\r\n\r\nconst notice = ({ type, ...options }: { type: string } & NoticeContent) => {\r\n getNoticeInstance((instance) => {\r\n options.duration = 3;\r\n let variant = type;\r\n switch (type) {\r\n case 'error':\r\n variant = 'danger';\r\n options.duration = options.closable ? 0 : 5;\r\n break;\r\n }\r\n\r\n options.content = <Alert variant={variant}>{options.content}</Alert>;\r\n\r\n instance.notice(options);\r\n });\r\n};\r\n\r\nconst types = ['error', 'success', 'info'] as const;\r\n\r\ntype ToastType = Record<typeof types[number], (content: string, options?: NoticeContent) => void> & {\r\n defaults: typeof defaultOptions;\r\n};\r\n\r\nconst Toast = types.reduce((toast, type) => {\r\n toast[type] = (content: string, options?: NoticeContent) => {\r\n notice({\r\n ...options,\r\n type,\r\n content\r\n });\r\n };\r\n return toast;\r\n}, {} as any);\r\n\r\nToast.defaults = defaultOptions;\r\n\r\nexport default Toast as ToastType;\r\n","import axios, { AxiosInstance, AxiosRequestConfig } from 'axios';\r\nimport queryString from 'query-string';\r\nimport * as rax from 'retry-axios';\r\nimport { RetryConfig } from 'retry-axios';\r\nimport Unauthorized from './errors/unauthorized';\r\nimport Toast from './utils/toast';\r\n\r\nexport type Errors = string | {\r\n [key: string]: string\r\n}\r\n\r\ndeclare module 'retry-axios' {\r\n interface RetryConfig {\r\n retryDecider?: () => boolean;\r\n }\r\n}\r\n\r\ndeclare module 'axios' {\r\n interface AxiosError {\r\n errors: Errors;\r\n }\r\n\r\n interface AxiosRequestConfig {\r\n raxConfig?: RetryConfig;\r\n authTokenName?: string;\r\n }\r\n}\r\n\r\nrax.attach();\r\n\r\naxios.defaults.raxConfig = {\r\n retryDelay: 2000,\r\n backoffType: 'static',\r\n shouldRetry: ({ config, response }) => {\r\n if (config.raxConfig?.retryDecider && !config.raxConfig.retryDecider()) {\r\n return false;\r\n }\r\n return config.method?.toUpperCase() === 'GET' && response?.status === 449;\r\n }\r\n};\r\naxios.defaults.maxContentLength = Infinity;\r\naxios.defaults.maxBodyLength = Infinity;\r\naxios.defaults.baseURL = '/api';\r\naxios.defaults.authTokenName = 'authorization';\r\naxios.interceptors.request.use(\r\n config => {\r\n const key = config.authTokenName;\r\n if (key) {\r\n const token = localStorage.getItem(key);\r\n\r\n if (token) {\r\n config.headers = {\r\n Authorization: `Bearer ${token}`,\r\n ...config.headers,\r\n };\r\n }\r\n }\r\n return config;\r\n },\r\n error => {\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\nconst isRecord = (data: any): data is Record<string, string> => {\r\n return data && (typeof data === 'object');\r\n};\r\n\r\naxios.interceptors.response.use(\r\n response => {\r\n if (response.status === 201 && response.data.location) {\r\n window.location.href = response.data.location;\r\n response.data = undefined; //防止多次跳转\r\n }\r\n\r\n return response;\r\n },\r\n e => {\r\n if (axios.isAxiosError(e)) {\r\n if (e.response) {\r\n const { data, status } = e.response;\r\n if (status === 401) {\r\n e.errors = 'Unauthorized';\r\n if (isRecord(data) && data.url) {\r\n e = new Unauthorized(data.url);\r\n }\r\n Toast.error('Unauthorized');\r\n } else {\r\n if (isRecord(data)) {\r\n if (status === 422) {\r\n e.errors = data;\r\n } else if ('message' in data) {\r\n e.errors = data['message'];\r\n }\r\n } else {\r\n e.errors = data as string;\r\n }\r\n }\r\n }\r\n }\r\n return Promise.reject(e);\r\n }\r\n);\r\n\r\nexport type RequestConfig = AxiosRequestConfig | string\r\nexport type RequestInstance = AxiosInstance\r\nexport const isRequestError = axios.isAxiosError;\r\n\r\nexport const showRequestError = (e: any) => {\r\n if (axios.isAxiosError(e)) {\r\n let errors = e.errors;\r\n if (typeof e.errors !== 'string') {\r\n errors = Object.values(e.errors).join('<br />');\r\n }\r\n Toast.error(errors as string);\r\n } else {\r\n throw e;\r\n }\r\n};\r\n\r\nconst request = async function <T = any>(config: RequestConfig) {\r\n config = typeof config === 'string' ? { url: config } : config;\r\n\r\n const { data } = await axios.request<T>({\r\n paramsSerializer: function(params) {\r\n return queryString.stringify(params, {\r\n sort: false,\r\n skipNull: true,\r\n skipEmptyString: true,\r\n arrayFormat: 'bracket',\r\n });\r\n },\r\n ...config\r\n });\r\n\r\n return data;\r\n};\r\n\r\nrequest.defaults = axios.defaults;\r\nrequest.interceptors = axios.interceptors;\r\n\r\nexport default request;\r\n","import { useEffect, useRef } from 'react';\r\n\r\nconst useUnmountedRef = () => {\r\n const unmountedRef = useRef(false);\r\n useEffect(() => {\r\n unmountedRef.current = false;\r\n return () => {\r\n unmountedRef.current = true;\r\n };\r\n }, []);\r\n return unmountedRef;\r\n};\r\n\r\nexport default useUnmountedRef;\r\n","import { useCallback, useState } from 'react';\r\nimport type { Dispatch, SetStateAction } from 'react';\r\nimport useUnmountedRef from './use-unmounted-ref';\r\n\r\nfunction useSafeState<S>(initialState: S | (() => S)): [S, Dispatch<SetStateAction<S>>];\r\n\r\nfunction useSafeState<S = undefined>(): [S | undefined, Dispatch<SetStateAction<S | undefined>>];\r\n\r\nfunction useSafeState<S>(initialState?: S | (() => S)) {\r\n const unmountedRef = useUnmountedRef();\r\n const [state, setState] = useState(initialState);\r\n const setCurrentState = useCallback((currentState) => {\r\n /** if component is unmounted, stop update */\r\n if (unmountedRef.current) return;\r\n setState(currentState);\r\n }, []);\r\n\r\n return [state, setCurrentState] as const;\r\n}\r\n\r\nexport default useSafeState;\r\n","import show from '../components/modal/show';\r\nimport Modal, { MessageProps } from '../components/modal';\r\nimport { useEffect, useRef } from 'react';\r\nimport request from '../request';\r\nimport useSafeState from '../hooks/use-safe-state';\r\n\r\ninterface PayResult {\r\n pay_url: string;\r\n order_no: string;\r\n}\r\n\r\ninterface Options {\r\n result: PayResult;\r\n checkUrl: string;\r\n onComplete?: () => void;\r\n}\r\n\r\nconst WaitModal = function({ state, message, resolve }: MessageProps<Options>) {\r\n\r\n const open = useRef(true);\r\n const { result, checkUrl, onComplete } = message;\r\n const [checking, setChecking] = useSafeState(false);\r\n\r\n useEffect(() => {\r\n request({\r\n url: checkUrl,\r\n method: 'post',\r\n data: { order_no: result.order_no },\r\n raxConfig: {\r\n shouldRetry(err) {\r\n return open.current && err.response?.status === 449;\r\n }\r\n }\r\n }).then(() => {\r\n onComplete?.();\r\n resolve();\r\n }).catch(() => null);\r\n }, []);\r\n\r\n return <Modal\r\n {...state}\r\n centered\r\n onHide={() => {\r\n open.current = false;\r\n state.onHide();\r\n }}\r\n backdrop='static'\r\n header='支付结果'\r\n okText='已完成支付'\r\n okButtonProps={{ loading: checking }}\r\n onOk={async (e) => {\r\n e.preventDefault();\r\n try {\r\n setChecking(true);\r\n await request({\r\n url: checkUrl,\r\n method: 'post',\r\n data: { order_no: result.order_no },\r\n raxConfig: {\r\n shouldRetry() {\r\n return false;\r\n }\r\n }\r\n });\r\n onComplete?.();\r\n resolve();\r\n } catch {\r\n // ignore\r\n } finally {\r\n setChecking(false);\r\n }\r\n }}\r\n cancelText='取消'\r\n >\r\n 请在新打开的页面上进行支付,支付完成后再关闭此窗口\r\n </Modal>;\r\n};\r\n\r\nexport default function waitPayComplete(options: Options) {\r\n const { result } = options;\r\n window.open(result.pay_url);\r\n show(WaitModal, options);\r\n}\r\n","import { ReactNode } from 'react';\r\nimport styled from 'styled-components';\r\n\r\nconst Container = styled.div`\r\n padding: 48px 32px;\r\n`;\r\n\r\nconst Icon = styled.div`\r\n margin-bottom: 24px;\r\n text-align: center;\r\n font-size: 72px;\r\n`;\r\n\r\nconst Title = styled.div`\r\n color: rgba(0, 0, 0, .85);\r\n font-size: 24px;\r\n line-height: 1.8;\r\n text-align: center;\r\n`;\r\n\r\nconst Extra = styled.div`\r\n margin-top: 32px;\r\n text-align: center;\r\n`;\r\n\r\nconst IconMap = {\r\n success: <i className='bi bi-check-circle-fill text-success' />,\r\n error: <i className='bi bi-exclamation-circle-fill text-danger' />,\r\n info: <i className='bi bi-info-circle-fill text-info' />,\r\n warning: <i className='bi bi-exclamation-triangle-fill text-warning' />,\r\n};\r\n\r\ninterface ResultProps {\r\n status?: keyof typeof IconMap\r\n icon?: ReactNode\r\n title?: string\r\n extra?: ReactNode;\r\n}\r\n\r\nexport default function Result({ status, title, icon, extra }: ResultProps) {\r\n\r\n if (!icon && status) {\r\n icon = IconMap[status];\r\n }\r\n\r\n return <Container>\r\n {icon && <Icon>{icon}</Icon>}\r\n {title && <Title>{title}</Title>}\r\n {extra && <Extra>{extra}</Extra>}\r\n </Container>;\r\n}\r\n","import styled from 'styled-components';\r\n\r\nexport const Dimmable = styled.div`\r\n position: relative;\r\n`;\r\n\r\ninterface DimmerProps {\r\n active?: boolean\r\n inverted?: boolean\r\n}\r\n\r\nconst Dimmer = styled.div<DimmerProps>`\r\n display: ${props => props.active ? 'flex' : 'none'};\r\n position: absolute;\r\n top: 0 !important;\r\n left: 0 !important;\r\n width: 100%;\r\n height: 100%;\r\n text-align: center;\r\n vertical-align: middle;\r\n padding: 1em;\r\n background-color: ${props => props.inverted ? 'rgba(255, 255, 255, .85)' : 'rgba(0, 0, 0, .85)'};\r\n opacity: ${props => props.active ? 1 : 0};\r\n line-height: 1;\r\n animation-fill-mode: both;\r\n animation-duration: .5s;\r\n transition: background-color .5s linear;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n user-select: none;\r\n will-change: opacity;\r\n z-index: 990;\r\n`;\r\n\r\nexport default Dimmer;\r\n","import { PropsWithChildren } from 'react';\r\nimport { Spinner, SpinnerProps } from 'react-bootstrap';\r\nimport Dimmer from './dimmer';\r\nimport styled from 'styled-components';\r\n\r\ninterface LoaderProps {\r\n loading?: boolean;\r\n animation?: SpinnerProps['animation'];\r\n wrap?: boolean | number;\r\n}\r\n\r\nexport default function Loader({\r\n loading = true,\r\n children,\r\n variant = 'primary',\r\n animation = 'border',\r\n wrap,\r\n ...props\r\n}: PropsWithChildren<LoaderProps & Omit<SpinnerProps, 'animation'>>): JSX.Element | null {\r\n if (!loading) {\r\n return null;\r\n }\r\n\r\n if (children) {\r\n children = <p className='mt-3 text-secondary'>{children}</p>;\r\n }\r\n\r\n children = <Dimmer inverted active>\r\n <Spinner animation={animation} variant={variant} {...props} />\r\n {children}\r\n </Dimmer>;\r\n\r\n if (wrap) {\r\n return <Wrap $height={typeof wrap === 'number' ? wrap : 150}>\r\n {children}\r\n </Wrap>;\r\n }\r\n\r\n return children as JSX.Element;\r\n}\r\n\r\nconst Wrap = styled.div<{ $height: number }>`\r\n position: relative;\r\n height: ${props => `${props.$height}px`};\r\n`;\r\n","import { PropsWithChildren } from 'react';\r\nimport { Card as BsCard, CardProps as BsCardProps } from 'react-bootstrap';\r\nimport classNames from 'classnames';\r\n\r\ninterface CardProps extends BsCardProps {\r\n title?: string;\r\n}\r\n\r\nexport default function Card({ children, title, className, ...props }: PropsWithChildren<CardProps>) {\r\n\r\n return <BsCard className={classNames('border-0 shadow-sm mb-3', className)} {...props}>\r\n <div className='card-body'>\r\n {title && <>\r\n <h5>{title}</h5>\r\n <hr />\r\n </>}\r\n {children}\r\n </div>\r\n </BsCard>;\r\n}\r\n","import { Alert } from 'react-bootstrap';\r\nimport { Errors } from '../request';\r\n\r\nexport default function Error({ errors }: { errors?: Errors }) {\r\n if (!errors) {\r\n return null;\r\n }\r\n return <Alert variant='danger'>\r\n <ul className='mb-0'>\r\n {typeof errors === 'string'\r\n ? <li>{errors}</li>\r\n : Object.entries(errors).map(([name, error]) => <li key={name}>{error}</li>)\r\n }\r\n </ul>\r\n </Alert>;\r\n}\r\n","import { Children, ReactNode } from 'react';\r\nimport styled, { css } from 'styled-components';\r\n\r\ninterface SpaceProps {\r\n children: ReactNode;\r\n size?: 'small' | 'middle' | 'large' | number;\r\n direction?: 'vertical' | 'horizontal';\r\n className?: string;\r\n}\r\n\r\n\r\nexport default function Space({ children, className, size = 'small', direction = 'horizontal' }: SpaceProps) {\r\n\r\n if (typeof size === 'string') {\r\n size = {\r\n small: 8,\r\n middle: 16,\r\n large: 24\r\n }[size];\r\n }\r\n\r\n const items = Children.map(children, (child) => {\r\n if (child) {\r\n return <Item>{child}</Item>;\r\n }\r\n });\r\n\r\n return <Container className={className} $direction={direction} $size={size}>\r\n {items}\r\n </Container>;\r\n}\r\n\r\nconst Container = styled.div<{ $size: number, $direction: string }>`\r\n display: inline-flex;\r\n align-items: center;\r\n gap: ${props => props.$size}px;\r\n\r\n ${props => props.$direction === 'vertical' && css`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: inherit;\r\n `}\r\n`;\r\n\r\nconst Item = styled.div`\r\n\r\n`;\r\n","import { ComponentProps, lazy, Suspense } from 'react';\r\n\r\nconst LazySteps = lazy(() => import('./lazy/steps'));\r\nconst LazyStep = lazy(() => import('./lazy/steps').then(({ Step }) => ({ default: Step })));\r\n\r\nexport default function Steps(props: ComponentProps<typeof LazySteps>) {\r\n return <Suspense fallback={null}>\r\n <LazySteps {...props} />\r\n </Suspense>;\r\n}\r\n\r\nconst Step = function(props: ComponentProps<typeof LazyStep>) {\r\n return <Suspense fallback={null}>\r\n <LazyStep {...props} />\r\n </Suspense>;\r\n};\r\n\r\nSteps.Step = Step;\r\n\r\nexport { Step };\r\n","import { ReactNode } from 'react';\r\nimport Card from './card';\r\nimport styled from 'styled-components';\r\n\r\nexport interface StatisticProps {\r\n title: ReactNode;\r\n content: ReactNode;\r\n footer?: ReactNode;\r\n}\r\n\r\nexport default function Statistic({ title, content, footer }: StatisticProps) {\r\n\r\n return <Card>\r\n <Title>{title}</Title>\r\n <Content>{content}</Content>\r\n {footer && <Footer>{footer}</Footer>}\r\n </Card>;\r\n}\r\n\r\nconst Footer = styled.div`\r\n margin-top: 9px;\r\n padding-top: 10px;\r\n border-top: 1px solid #f0f0f0;\r\n color: rgba(0, 0, 0, .65);\r\n`;\r\n\r\nconst Content = styled.div`\r\n color: rgba(0, 0, 0, .85);\r\n font-size: 24px;\r\n`;\r\n\r\nconst Title = styled.div`\r\n margin-bottom: 4px;\r\n color: rgba(0, 0, 0, .45);\r\n font-size: 1.1rem;\r\n`;\r\n\r\n","import { ReactNode, useCallback, useEffect, useMemo, useState } from 'react';\r\nimport { Pagination as BsPagination } from 'react-bootstrap';\r\n\r\nfunction noop() {\r\n}\r\n\r\n\r\nfunction isInteger(value: any): value is number {\r\n return (\r\n typeof value === 'number' && isFinite(value) && Math.floor(value) === value\r\n );\r\n}\r\n\r\nexport interface PaginationProps {\r\n className?: string\r\n total: number\r\n current?: number\r\n defaultCurrent?: number\r\n pageSize?: number\r\n defaultPageSize?: number,\r\n onChange?: (current: number, pageSize: number) => void\r\n}\r\n\r\nexport default function Pagination({\r\n total = 0,\r\n onChange = noop,\r\n defaultCurrent = 1,\r\n defaultPageSize = 10,\r\n className,\r\n ...props\r\n}: PaginationProps) {\r\n\r\n const [current, setCurrent] = useState(defaultCurrent);\r\n const [pageSize, setPageSize] = useState(defaultPageSize);\r\n\r\n useEffect(() => {\r\n if (isInteger(props.current)) {\r\n setCurrent(props.current);\r\n }\r\n }, [props.current]);\r\n\r\n useEffect(() => {\r\n if (isInteger(props.pageSize)) {\r\n setPageSize(props.pageSize);\r\n }\r\n }, [props.pageSize]);\r\n\r\n const allPages = useMemo(() => {\r\n return Math.floor((total - 1) / pageSize) + 1;\r\n }, [total, pageSize]);\r\n\r\n const handleChange = useCallback((p: number) => {\r\n return () => {\r\n if (p !== current) {\r\n setCurrent(p);\r\n onChange(p, pageSize);\r\n }\r\n };\r\n }, [onChange, current, pageSize]);\r\n\r\n const pageBufferSize = 2;\r\n const prevPage = current - 1 > 0 ? current - 1 : 0;\r\n const nextPage = current + 1 < allPages ? current + 1 : allPages;\r\n\r\n const pagerList: ReactNode[] = [];\r\n let jumpPrev: ReactNode = null;\r\n let jumpNext: ReactNode = null;\r\n let firstPager: ReactNode = null;\r\n let lastPager: ReactNode = null;\r\n\r\n if (allPages <= 3 + pageBufferSize * 2) {\r\n for (let i = 1; i <= allPages; i += 1) {\r\n const active = current === i;\r\n pagerList.push(\r\n <BsPagination.Item key={i} active={active} onClick={handleChange(i)}>{i}</BsPagination.Item>\r\n );\r\n }\r\n } else {\r\n lastPager = <BsPagination.Last key='last' onClick={handleChange(allPages)} />;\r\n firstPager = <BsPagination.First key='first' onClick={handleChange(1)} />;\r\n jumpPrev = <BsPagination.Prev key='prev' onClick={handleChange(prevPage)} />;\r\n jumpNext = <BsPagination.Next key='next' onClick={handleChange(nextPage)} />;\r\n\r\n let left = Math.max(1, current - pageBufferSize);\r\n let right = Math.min(current + pageBufferSize, allPages);\r\n\r\n if (current - 1 <= pageBufferSize) {\r\n right = 1 + pageBufferSize * 2;\r\n }\r\n\r\n if (allPages - current <= pageBufferSize) {\r\n left = allPages - pageBufferSize * 2;\r\n }\r\n\r\n for (let i = left; i <= right; i += 1) {\r\n const active = current === i;\r\n pagerList.push(\r\n <BsPagination.Item key={i} active={active} onClick={handleChange(i)}>{i}</BsPagination.Item>\r\n );\r\n }\r\n\r\n if (current - 1 >= pageBufferSize * 2 && current !== 1 + 2) {\r\n pagerList.unshift(jumpPrev);\r\n }\r\n if (\r\n allPages - current >= pageBufferSize * 2 &&\r\n current !== allPages - 2\r\n ) {\r\n pagerList.push(jumpNext);\r\n }\r\n\r\n if (left !== 1) {\r\n pagerList.unshift(firstPager);\r\n }\r\n if (right !== allPages) {\r\n pagerList.push(lastPager);\r\n }\r\n }\r\n\r\n return <BsPagination className={className}>\r\n {pagerList}\r\n </BsPagination>;\r\n\r\n}\r\n","import { useMemo } from 'react';\r\n\r\ninterface Props {\r\n value: number;\r\n currency?: boolean;\r\n locale?: string;\r\n className?: string;\r\n options?: Intl.NumberFormatOptions;\r\n}\r\n\r\nexport default function NumberFormat({ className, value, locale = 'zh-CN', currency = true, options = {} }: Props) {\r\n\r\n const formatter = useMemo(() => {\r\n\r\n let opt;\r\n\r\n if (currency) {\r\n opt = {\r\n style: 'currency',\r\n currency: 'CNY'\r\n };\r\n } else {\r\n opt = {\r\n minimumFractionDigits: 2,\r\n };\r\n }\r\n\r\n return new Intl.NumberFormat(locale, { ...opt, ...options });\r\n }, [currency, locale, options]);\r\n\r\n if (className) {\r\n return <span className={className}>{formatter.format(value)}</span>;\r\n }\r\n\r\n return <>{formatter.format(value)}</>;\r\n}\r\n","import { Button, ButtonProps } from 'react-bootstrap';\r\n\r\ninterface CustomButtonProps extends ButtonProps {\r\n loading: boolean;\r\n}\r\n\r\nexport default function LoadingButton({ loading, disabled, children, ...props }: CustomButtonProps) {\r\n\r\n return <Button {...props} disabled={loading || disabled}>\r\n {loading ? 'Loading…' : children}\r\n </Button>;\r\n}\r\n","import { ComponentProps, lazy, Suspense } from 'react';\r\n\r\nconst LazyImageZoom = lazy(() => import('./lazy/image-zoom'));\r\n\r\nexport default function ImageZoom(props: ComponentProps<typeof LazyImageZoom>) {\r\n return <Suspense fallback={null}>\r\n <LazyImageZoom {...props} />\r\n </Suspense>;\r\n}\r\n","import request, { RequestConfig, showRequestError } from '../request';\r\nimport { createElement, ElementType, MouseEvent, useCallback } from 'react';\r\nimport { AxiosRequestConfig } from 'axios';\r\nimport Button, { ButtonProps } from './button';\r\nimport useSafeState from '../hooks/use-safe-state';\r\nimport Modal from './modal';\r\n\r\ninterface Props extends Omit<ButtonProps, 'as'> {\r\n url: RequestConfig;\r\n method?: AxiosRequestConfig['method'];\r\n confirm?: string;\r\n onSuccess?: (result: any) => void;\r\n as?: ElementType | ButtonProps['as'];\r\n}\r\n\r\nexport default function RequestButton({\r\n url,\r\n method,\r\n confirm,\r\n onSuccess,\r\n children,\r\n disabled,\r\n as = Button,\r\n ...props\r\n}: Props) {\r\n\r\n const [fetching, setFetching] = useSafeState(false);\r\n\r\n const handleClick = useCallback(async (e: MouseEvent) => {\r\n e.preventDefault();\r\n try {\r\n setFetching(true);\r\n if (confirm) {\r\n if (!await Modal.confirm({ message: confirm })) {\r\n return;\r\n }\r\n }\r\n\r\n const config = typeof url === 'string' ? { url, method } : { method, ...url };\r\n\r\n const result = await request(config);\r\n\r\n if (onSuccess) {\r\n onSuccess(result);\r\n }\r\n } catch (e) {\r\n showRequestError(e);\r\n } finally {\r\n setFetching(false);\r\n }\r\n }, [url, method, setFetching]);\r\n\r\n return createElement(as, {\r\n ...props,\r\n disabled: disabled || fetching,\r\n onClick: handleClick\r\n }, children);\r\n}\r\n","import { forwardRef, lazy, Suspense } from 'react';\r\nimport type { CustomFormType } from './lazy/form';\r\n\r\nconst LazyForm = lazy(() => import('./lazy/form'));\r\n\r\nconst Form: CustomFormType = forwardRef((props, ref) => {\r\n return <Suspense fallback={null}>\r\n <LazyForm {...props} ref={ref} />\r\n </Suspense>;\r\n});\r\n\r\nexport default Form;\r\n\r\nexport type { FormProps, FormType } from './lazy/form';\r\n","import { ComponentProps, forwardRef, lazy, Suspense } from 'react';\r\nimport type { CustomTableType } from './lazy/table';\r\n\r\nconst LazyTable = lazy(() => import('./lazy/table'));\r\n\r\nconst Table: CustomTableType = forwardRef((props: ComponentProps<typeof LazyTable>, ref) => {\r\n return <Suspense fallback={null}>\r\n <LazyTable {...props} ref={ref} />\r\n </Suspense>;\r\n});\r\n\r\nexport default Table;\r\n\r\nexport type { TableProps, Columns, TableType } from './lazy/table';\r\n","import { useCallback, useState } from 'react';\r\n\r\ninterface Options {\r\n onHide?: () => void;\r\n onShow?: () => void;\r\n}\r\n\r\nlet id = 0;\r\n\r\nexport default function useOverlayState({ onHide, onShow }: Options = {}) {\r\n const [visible, setVisible] = useState(false);\r\n\r\n const [key, setKey] = useState(`visible-${id}`);\r\n\r\n const hide = useCallback(() => {\r\n setVisible(false);\r\n if (onHide) {\r\n onHide();\r\n }\r\n }, [setVisible, onHide]);\r\n\r\n const exit = useCallback(() => {\r\n setKey(`visible-${++id}`);\r\n }, [setKey, id]);\r\n\r\n const show = useCallback(() => {\r\n setVisible(true);\r\n if (onShow) {\r\n onShow();\r\n }\r\n }, [setVisible, onShow]);\r\n\r\n const state = {\r\n show: visible,\r\n onHide: hide,\r\n onExited: exit,\r\n key\r\n };\r\n\r\n return {\r\n visible,\r\n show,\r\n hide,\r\n state\r\n };\r\n}\r\n","import {\r\n createElement,\r\n ElementType,\r\n forwardRef,\r\n ForwardRefExoticComponent,\r\n MouseEvent,\r\n PropsWithChildren,\r\n PropsWithoutRef,\r\n ReactNode,\r\n RefAttributes,\r\n useImperativeHandle\r\n} from 'react';\r\nimport useOverlayState from '../hooks/use-overlay-state';\r\nimport Modal, { ModalProps } from './modal';\r\nimport { ButtonProps } from 'react-bootstrap';\r\nimport Button from './button';\r\n\r\nexport interface ModalButtonProps extends Omit<ButtonProps, 'as'> {\r\n text: ReactNode;\r\n modalProps?: Omit<ModalProps, 'children' | 'confirmLoading' | 'onOk'>;\r\n onOk?: () => any;\r\n onShow?: () => void;\r\n confirmLoading?: boolean;\r\n as?: ElementType | ButtonProps['as'];\r\n}\r\n\r\nexport interface ModalType {\r\n close: () => void;\r\n}\r\n\r\ntype ModalButtonType = ForwardRefExoticComponent<PropsWithoutRef<PropsWithChildren<ModalButtonProps>>\r\n & RefAttributes<ModalType>>\r\n\r\nconst ModalButton: ModalButtonType = forwardRef(({\r\n text,\r\n onOk,\r\n modalProps,\r\n children,\r\n onShow,\r\n confirmLoading,\r\n as = Button,\r\n ...props\r\n}, ref) => {\r\n\r\n const { state, show, hide } = useOverlayState({ onShow });\r\n\r\n useImperativeHandle(ref, () => ({\r\n close: hide\r\n }));\r\n\r\n const handleOk = async (e: MouseEvent) => {\r\n if (onOk) {\r\n const result = await onOk();\r\n if (result === false) {\r\n e.preventDefault();\r\n }\r\n }\r\n };\r\n\r\n const button = createElement(as, {\r\n ...props,\r\n onClick: show\r\n }, text);\r\n\r\n return <>\r\n {button}\r\n <Modal\r\n header={text}\r\n {...modalProps}\r\n {...state}\r\n confirmLoading={confirmLoading}\r\n onOk={handleOk}\r\n >\r\n {children}\r\n </Modal>\r\n </>;\r\n});\r\n\r\nexport default ModalButton;\r\n","import ModalButton, { ModalButtonProps, ModalType } from './modal-button';\r\nimport { ReactNode, useCallback, useRef, useState } from 'react';\r\nimport Form, { FormProps, FormType } from './form';\r\n\r\nexport interface ModalFormProps<T = any> extends FormProps<T> {\r\n text: ReactNode;\r\n buttonProps?: Omit<ModalButtonProps, 'text' | 'modalProps' | 'confirmLoading' | 'onOk'>;\r\n modalProps?: ModalButtonProps['modalProps'];\r\n children?: ReactNode;\r\n}\r\n\r\nexport default function ModalForm<T = any>({\r\n text,\r\n onSuccess,\r\n buttonProps,\r\n modalProps,\r\n children,\r\n ...props\r\n}: ModalFormProps<T>) {\r\n\r\n const [loading, setLoading] = useState(false);\r\n\r\n const ref = useRef<ModalType>(null);\r\n const form = useRef<FormType>(null);\r\n\r\n const handleOk = useCallback(() => {\r\n form.current?.submit();\r\n return false;\r\n }, []);\r\n\r\n const handleSuccess = useCallback((data) => {\r\n if (onSuccess) {\r\n onSuccess(data);\r\n }\r\n ref.current?.close();\r\n }, [onSuccess]);\r\n\r\n return <ModalButton\r\n ref={ref}\r\n text={text}\r\n {...buttonProps}\r\n modalProps={modalProps}\r\n onOk={handleOk}\r\n confirmLoading={loading}\r\n >\r\n <Form\r\n {...props}\r\n onSubmitting={setLoading}\r\n ref={form}\r\n onSuccess={handleSuccess}\r\n >\r\n {children}\r\n <input type='submit' hidden />\r\n </Form>\r\n </ModalButton>;\r\n}\r\n","import { useAsyncCallback, UseAsyncCallbackOptions } from 'react-async-hook';\r\nimport request, { isRequestError, RequestConfig } from '../request';\r\nimport { DependencyList, useCallback, useEffect } from 'react';\r\nimport { AxiosRequestConfig } from 'axios';\r\nimport { values } from 'lodash';\r\n\r\ntype UseRequestOptions<T> = {\r\n manual?: boolean\r\n refreshDeps?: DependencyList;\r\n} & UseAsyncCallbackOptions<T>;\r\n\r\nexport default function useRequest<T = any>(config: RequestConfig, {\r\n manual,\r\n refreshDeps,\r\n ...options\r\n}: UseRequestOptions<T> = {}) {\r\n let { execute, currentParams, error, ...others } = useAsyncCallback(async (params?: AxiosRequestConfig) => {\r\n\r\n config = typeof config === 'string' ? { url: config } : config;\r\n\r\n return await request<T>({\r\n ...config,\r\n ...params\r\n });\r\n }, options);\r\n\r\n useEffect(() => {\r\n if (!manual && !refreshDeps) {\r\n try {\r\n execute();\r\n } catch {\r\n\r\n }\r\n }\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (refreshDeps) {\r\n refresh();\r\n }\r\n }, refreshDeps);\r\n\r\n const refresh = useCallback(async () => {\r\n try {\r\n if (currentParams) {\r\n await execute(...currentParams);\r\n } else {\r\n await execute();\r\n }\r\n } catch {\r\n\r\n }\r\n }, [execute, currentParams]);\r\n\r\n if (error && isRequestError(error)) {\r\n const errors = error.errors;\r\n error = new Error(typeof errors === 'string' ? errors : values(errors).join(''));\r\n }\r\n\r\n return {\r\n refresh,\r\n execute,\r\n error,\r\n ...others\r\n };\r\n}\r\n","import { DependencyList, useCallback, useEffect, useRef } from 'react';\r\n\r\nexport default function useCallbackRef<T extends (...args: any[]) => any>(\r\n callback: T | undefined,\r\n deps: DependencyList = [],\r\n) {\r\n const callbackRef = useRef(callback);\r\n\r\n useEffect(() => {\r\n callbackRef.current = callback;\r\n });\r\n\r\n return useCallback(((...args) => callbackRef.current?.(...args)) as T, deps);\r\n}\r\n","import { Dispatch, SetStateAction, useState } from 'react';\r\nimport useCallbackRef from './use-callback-ref';\r\n\r\nexport interface UseControllableStateProps<T> {\r\n value?: T;\r\n defaultValue?: T | (() => T);\r\n onChange?: (value: T) => void;\r\n shouldUpdate?: (prev: T, next: T) => boolean;\r\n}\r\n\r\nexport default function useControllableState<T>(props: UseControllableStateProps<T>) {\r\n const {\r\n value: valueProp,\r\n defaultValue,\r\n onChange,\r\n shouldUpdate = (prev, next) => prev !== next,\r\n } = props;\r\n\r\n const onChangeProp = useCallbackRef(onChange);\r\n const shouldUpdateProp = useCallbackRef(shouldUpdate);\r\n\r\n const [uncontrolledState, setUncontrolledState] = useState(defaultValue as T);\r\n const controlled = valueProp !== undefined;\r\n const value = controlled ? valueProp : uncontrolledState;\r\n\r\n const setValue = useCallbackRef(\r\n (next: SetStateAction<T>) => {\r\n const setter = next as (prevState?: T) => T;\r\n const nextValue = typeof next === 'function' ? setter(value) : next;\r\n\r\n if (!shouldUpdateProp(value, nextValue)) {\r\n return;\r\n }\r\n\r\n if (!controlled) {\r\n setUncontrolledState(nextValue);\r\n }\r\n\r\n onChangeProp(nextValue);\r\n },\r\n [controlled, onChangeProp, value, shouldUpdateProp],\r\n );\r\n\r\n return [value, setValue] as [T, Dispatch<SetStateAction<T>>];\r\n}\r\n","import { debounce, DebouncedFunc } from 'lodash';\r\nimport { useEffect, useRef } from 'react';\r\n\r\nexport default function useDebounce<T extends (...args: any) => any>(callback: T, wait: number, options?: {}): DebouncedFunc<T> {\r\n const callbackRef = useRef<T>(callback);\r\n const debouncedCallbackRef = useRef<DebouncedFunc<T>>(\r\n debounce(callback, wait, options)\r\n );\r\n\r\n useEffect(() => {\r\n callbackRef.current = callback;\r\n });\r\n\r\n useEffect(() => {\r\n debouncedCallbackRef.current = debounce((...args: any) => {\r\n callbackRef.current(...args);\r\n }, wait, options);\r\n }, [wait, options]);\r\n\r\n return debouncedCallbackRef.current;\r\n}\r\n"],"names":["CustomSwal","withReactContent","Swal","defaultOptions","confirmButtonText","cancelButtonText","Message","confirm","options","isConfirmed","fire","icon","showCancelButton","preConfirm","data","e","Error","showValidationMessage","message","success","toast","position","timer","showConfirmButton","error","close","result","defaults","useStateWithCallback","initState","callbackRef","useRef","state","setState","useState","useEffect","current","setCallbackState","value","callback","MessageContext","createContext","wrapMessage","Component","resolve","destroy","show","setShow","context","useContext","handleResolve","useCallback","useMemo","onHide","onExited","container","_jsx","createMessage","Promise","component","hide","listener","memoryState","Set","modal","add","delete","props","Provider","children","Array","from","map","index","Fragment","Tooltip","tooltip","placement","OverlayTrigger","overlay","BsTooltip","id","uniqueId","TableContext","Button","forwardRef","ref","loading","percent","disabled","variant","inTable","_jsxs","Spinner","as","size","role","animation","className","button","BsButton","Confirm","title","okText","cancelText","Modal","centered","Header","Title","Body","Footer","onClick","header","footer","closable","onOk","onCancel","okButtonProps","bodyAs","headerAs","confirmLoading","rest","setLoading","okButton","defaultPrevented","cancelButton","_Fragment","ReactModal","closeButton","Unauthorized","constructor","url","noticeInstance","getNoticeInstance","Notification","newInstance","prefixCls","maxCount","style","top","right","instance","notice","type","duration","content","Alert","types","Toast","reduce","rax","attach","axios","raxConfig","retryDelay","backoffType","shouldRetry","config","response","retryDecider","method","toUpperCase","status","maxContentLength","Infinity","maxBodyLength","baseURL","authTokenName","interceptors","request","use","key","token","localStorage","getItem","headers","Authorization","reject","isRecord","location","window","href","undefined","isAxiosError","errors","isRequestError","showRequestError","Object","values","join","paramsSerializer","params","queryString","stringify","sort","skipNull","skipEmptyString","arrayFormat","useUnmountedRef","unmountedRef","useSafeState","initialState","setCurrentState","currentState","WaitModal","open","checkUrl","onComplete","checking","setChecking","order_no","err","then","catch","backdrop","preventDefault","waitPayComplete","pay_url","Container","styled","div","Icon","Extra","IconMap","info","warning","Result","extra","Dimmer","active","inverted","Loader","wrap","Wrap","$height","Card","BsCard","classNames","entries","name","Space","direction","small","middle","large","items","Children","child","Item","$size","$direction","css","LazySteps","lazy","LazyStep","Step","default","Steps","Suspense","fallback","Statistic","Content","noop","isInteger","isFinite","Math","floor","Pagination","total","onChange","defaultCurrent","defaultPageSize","setCurrent","pageSize","setPageSize","allPages","handleChange","p","pageBufferSize","prevPage","nextPage","pagerList","jumpPrev","jumpNext","firstPager","lastPager","i","push","BsPagination","Last","First","Prev","Next","left","max","min","unshift","NumberFormat","locale","currency","formatter","opt","minimumFractionDigits","Intl","format","LoadingButton","LazyImageZoom","ImageZoom","RequestButton","onSuccess","fetching","setFetching","handleClick","createElement","LazyForm","Form","LazyTable","Table","useOverlayState","onShow","visible","setVisible","setKey","exit","ModalButton","text","modalProps","useImperativeHandle","handleOk","ModalForm","buttonProps","form","submit","handleSuccess","onSubmitting","hidden","useRequest","manual","refreshDeps","execute","currentParams","others","useAsyncCallback","refresh","useCallbackRef","deps","args","useControllableState","valueProp","defaultValue","shouldUpdate","prev","next","onChangeProp","shouldUpdateProp","uncontrolledState","setUncontrolledState","controlled","setValue","setter","nextValue","useDebounce","wait","debouncedCallbackRef","debounce"],"mappings":"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"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import e from"sweetalert2/dist/sweetalert2.js";import t from"sweetalert2-react-content";import{jsx as n,jsxs as r,Fragment as o}from"react/jsx-runtime";import{useRef as i,useState as a,useEffect as s,createContext as c,Fragment as l,useContext as d,useCallback as u,useMemo as f,forwardRef as h,Children as m,lazy as p,Suspense as g,createElement as y,useImperativeHandle as b}from"react";import{OverlayTrigger as x,Tooltip as v,Spinner as w,Button as k,Modal as C,Alert as N,Card as z,Pagination as S}from"react-bootstrap";import{uniqueId as P,values as j,debounce as B}from"lodash";import T from"axios";import $ from"query-string";import*as E from"retry-axios";import L from"rc-notification";import F,{css as H}from"styled-components";import A from"classnames";import{useAsyncCallback as D}from"react-async-hook";const M=t(e),O={confirmButtonText:"确定",cancelButtonText:"取消"},I={confirm:async e=>{const{isConfirmed:t}=await M.fire({...O,icon:"warning",showCancelButton:!0,...e,async preConfirm(t){if(e.preConfirm)try{return await e.preConfirm(t)}catch(e){return e instanceof Error&&M.showValidationMessage(e.message),!1}return!0}});return t},success:e=>{M.fire({...O,toast:!0,position:"top",icon:"success",timer:2e3,showConfirmButton:!1,...e})},error:e=>{M.fire({...O,toast:!0,position:"top",icon:"error",timer:5e3,showConfirmButton:!1,...e})},close:e=>{M.close(e)},defaults:O};const U=c({});function R(e){return t=>{let{resolve:r,destroy:o,message:c}=t;const[l,h]=function(e){const t=i(null),[n,r]=a(e);return s((()=>{t.current&&(t.current(),t.current=null)}),[n]),[n,(e,n)=>{t.current="function"==typeof n?n:null,r(e)}]}(!0),m=d(U),p=u((e=>{h(!1,(()=>{r(e)}))}),[h,r]),g=f((()=>({show:l,onHide:()=>p(),onExited:()=>o(),container:m.container})),[l,p,o]);return n(e,{resolve:p,state:g,message:c})}}function _(e){return t=>new Promise((r=>{const o=n(e,{resolve:r,destroy:()=>{Y(o)},message:t});G(o)}))}let q=()=>{},V=new Set;const G=e=>{V=new Set(V),V.add(e),q(V)},Y=e=>{V=new Set(V),V.delete(e),q(V)};function J(e,t){return _(R(e))(t)}function K(e){let{tooltip:t,children:r,placement:o="bottom"}=e;return n(x,{placement:o,overlay:n(v,{id:P(),children:t}),children:r})}const Q=c(!1),W=h(((e,t)=>{let{loading:i,percent:a,disabled:s,children:c,tooltip:l,variant:u,...f}=e;d(Q)&&!u&&(u="link"),i&&(s=!0,c=r(o,{children:[n(w,{ref:t,as:"span",size:"sm",role:"status","aria-hidden":"true",animation:"border"}),a?r("span",{className:"ms-2",children:[a,"%"]}):null]}));const h=n(k,{ref:t,...f,variant:u,disabled:s,children:c});return l?n(K,{tooltip:l,children:n("span",{className:"d-inline-block",children:h})}):h})),X=function(e){let{state:t,message:{title:o,message:i,okText:a,cancelText:s},resolve:c}=e;return r(C,{centered:!0,...t,children:[n(C.Header,{children:n(C.Title,{as:"h5",children:o||"确认"})}),n(C.Body,{children:i}),r(C.Footer,{children:[n(W,{variant:"secondary",onClick:()=>c(),children:s||"取消"}),n(W,{onClick:()=>c(!0),children:a||"确定"})]})]})};const Z=e=>{let{header:t,children:i,footer:s,closable:c=!0,show:l,cancelText:d="取消",okText:u="确定",onOk:h,onCancel:m,onHide:p,okButtonProps:g,bodyAs:y,headerAs:b="h5",confirmLoading:x=!1,...v}=e;const[w,k]=a(!1),N=f((()=>n(W,{loading:w||x,variant:"primary",onClick:async e=>{k(!0);try{await(h?.(e)),e.defaultPrevented||p?.()}finally{k(!1)}},...g,children:u})),[g,u,h,p,w,x]),z=f((()=>n(W,{variant:"secondary",onClick:e=>{m?.(e),e.defaultPrevented||p?.()},children:d})),[m,p,d]);switch(typeof s){case"undefined":s=r(o,{children:[z,N]});break;case"function":s=s({okButton:N,cancelButton:z})}return r(C,{...v,onHide:p,show:l,children:[t&&n(C.Header,{closeButton:c,children:n(C.Title,{as:b,children:t})}),n(C.Body,{as:y,children:i}),s&&n(C.Footer,{children:s})]})};let ee;Z.Message=function(e){const[t,r]=a(V);return s((()=>{q=r}),[]),n(U.Provider,{value:e,children:Array.from(t).map(((e,t)=>n(l,{children:e},`message-${t}`)))})},Z.confirm=function(e){return _(R(X))(e)},Z.show=J;const te={};const ne=e=>{let{type:t,...r}=e;!function(e){if(ee)return e(ee);L.newInstance({...te,prefixCls:"notification",maxCount:5,style:{top:20,right:20}},(t=>{ee?e(ee):(ee=t,e(t))}))}((e=>{r.duration=3;let o=t;if("error"===t)o="danger",r.duration=r.closable?0:5;r.content=n(N,{variant:o,children:r.content}),e.notice(r)}))},re=["error","success","info"].reduce(((e,t)=>(e[t]=(e,n)=>{ne({...n,type:t,content:e})},e)),{});function oe(e){return e&&"object"==typeof e}re.defaults=te,E.attach(),T.defaults.raxConfig={retryDelay:2e3,backoffType:"static",shouldRetry:e=>{let{config:t,response:n}=e;return!(t.raxConfig?.retryDecider&&!t.raxConfig.retryDecider())&&("GET"===t.method?.toUpperCase()&&449===n?.status)}},T.defaults.maxContentLength=1/0,T.defaults.maxBodyLength=1/0,T.defaults.baseURL="/api",T.defaults.authTokenName="authorization",T.interceptors.request.use((e=>{const t=e.authTokenName;if(t){const n=localStorage.getItem(t);n&&(e.headers={Authorization:`Bearer ${n}`,...e.headers})}return e}),(e=>Promise.reject(e))),T.interceptors.response.use((e=>(201===e.status&&e.data.location&&(window.location.href=e.data.location,e.data=void 0),e)),(e=>{if(T.isAxiosError(e)&&e.response){const{data:t,status:n}=e.response;401===n?(e.errors="Unauthorized",re.error("Unauthorized")):oe(t)?422===n?e.errors=t:"message"in t&&(e.errors=t.message):e.errors=t}return Promise.reject(e)}));const ie=T.isAxiosError,ae=e=>{if(!T.isAxiosError(e))throw e;{let t=e.errors;"string"!=typeof e.errors&&(t=Object.values(e.errors).join("<br />")),re.error(t)}},se=async function(e){e="string"==typeof e?{url:e}:e;const{data:t}=await T.request({paramsSerializer:function(e){return $.stringify(e,{sort:!1,skipNull:!0,skipEmptyString:!0,arrayFormat:"bracket"})},...e});return t};se.defaults=T.defaults,se.interceptors=T.interceptors;function ce(e){const t=(()=>{const e=i(!1);return s((()=>(e.current=!1,()=>{e.current=!0})),[]),e})(),[n,r]=a(e);return[n,u((e=>{t.current||r(e)}),[])]}const le=function(e){let{state:t,message:r,resolve:o}=e;const a=i(!0),{result:c,checkUrl:l,onComplete:d}=r,[u,f]=ce(!1);return s((()=>{se({url:l,method:"post",data:{order_no:c.order_no},raxConfig:{shouldRetry:e=>a.current&&449===e.response?.status}}).then((()=>{d?.(),o()})).catch((()=>null))}),[]),n(Z,{...t,centered:!0,onHide:()=>{a.current=!1,t.onHide()},backdrop:"static",header:"支付结果",okText:"已完成支付",okButtonProps:{loading:u},onOk:async e=>{e.preventDefault();try{f(!0),await se({url:l,method:"post",data:{order_no:c.order_no},raxConfig:{shouldRetry:()=>!1}}),d?.(),o()}catch{}finally{f(!1)}},cancelText:"取消",children:"请在新打开的页面上进行支付,支付完成后再关闭此窗口"})};function de(e){const{result:t}=e;window.open(t.pay_url),J(le,e)}const ue=F.div`
|
|
2
|
+
padding: 48px 32px;
|
|
3
|
+
`,fe=F.div`
|
|
4
|
+
margin-bottom: 24px;
|
|
5
|
+
text-align: center;
|
|
6
|
+
font-size: 72px;
|
|
7
|
+
`,he=F.div`
|
|
8
|
+
color: rgba(0, 0, 0, .85);
|
|
9
|
+
font-size: 24px;
|
|
10
|
+
line-height: 1.8;
|
|
11
|
+
text-align: center;
|
|
12
|
+
`,me=F.div`
|
|
13
|
+
margin-top: 32px;
|
|
14
|
+
text-align: center;
|
|
15
|
+
`,pe={success:n("i",{className:"bi bi-check-circle-fill text-success"}),error:n("i",{className:"bi bi-exclamation-circle-fill text-danger"}),info:n("i",{className:"bi bi-info-circle-fill text-info"}),warning:n("i",{className:"bi bi-exclamation-triangle-fill text-warning"})};function ge(e){let{status:t,title:o,icon:i,extra:a}=e;return!i&&t&&(i=pe[t]),r(ue,{children:[i&&n(fe,{children:i}),o&&n(he,{children:o}),a&&n(me,{children:a})]})}F.div`
|
|
16
|
+
position: relative;
|
|
17
|
+
`;const ye=F.div`
|
|
18
|
+
display: ${e=>e.active?"flex":"none"};
|
|
19
|
+
position: absolute;
|
|
20
|
+
top: 0 !important;
|
|
21
|
+
left: 0 !important;
|
|
22
|
+
width: 100%;
|
|
23
|
+
height: 100%;
|
|
24
|
+
text-align: center;
|
|
25
|
+
vertical-align: middle;
|
|
26
|
+
padding: 1em;
|
|
27
|
+
background-color: ${e=>e.inverted?"rgba(255, 255, 255, .85)":"rgba(0, 0, 0, .85)"};
|
|
28
|
+
opacity: ${e=>e.active?1:0};
|
|
29
|
+
line-height: 1;
|
|
30
|
+
animation-fill-mode: both;
|
|
31
|
+
animation-duration: .5s;
|
|
32
|
+
transition: background-color .5s linear;
|
|
33
|
+
flex-direction: column;
|
|
34
|
+
align-items: center;
|
|
35
|
+
justify-content: center;
|
|
36
|
+
user-select: none;
|
|
37
|
+
will-change: opacity;
|
|
38
|
+
z-index: 990;
|
|
39
|
+
`;function be(e){let{loading:t=!0,children:o,variant:i="primary",animation:a="border",wrap:s,...c}=e;return t?(o&&(o=n("p",{className:"mt-3 text-secondary",children:o})),o=r(ye,{inverted:!0,active:!0,children:[n(w,{animation:a,variant:i,...c}),o]}),s?n(xe,{$height:"number"==typeof s?s:150,children:o}):o):null}const xe=F.div`
|
|
40
|
+
position: relative;
|
|
41
|
+
height: ${e=>`${e.$height}px`};
|
|
42
|
+
`;function ve(e){let{children:t,title:i,className:a,...s}=e;return n(z,{className:A("border-0 shadow-sm mb-3",a),...s,children:r("div",{className:"card-body",children:[i&&r(o,{children:[n("h5",{children:i}),n("hr",{})]}),t]})})}function we(e){let{errors:t}=e;return t?n(N,{variant:"danger",children:n("ul",{className:"mb-0",children:"string"==typeof t?n("li",{children:t}):Object.entries(t).map((e=>{let[t,r]=e;return n("li",{children:r},t)}))})}):null}function ke(e){let{children:t,className:r,size:o="small",direction:i="horizontal"}=e;"string"==typeof o&&(o={small:8,middle:16,large:24}[o]);const a=m.map(t,(e=>{if(e)return n(Ne,{children:e})}));return n(Ce,{className:r,$direction:i,$size:o,children:a})}const Ce=F.div`
|
|
43
|
+
display: inline-flex;
|
|
44
|
+
align-items: center;
|
|
45
|
+
gap: ${e=>e.$size}px;
|
|
46
|
+
|
|
47
|
+
${e=>"vertical"===e.$direction&&H`
|
|
48
|
+
display: flex;
|
|
49
|
+
flex-direction: column;
|
|
50
|
+
align-items: inherit;
|
|
51
|
+
`}
|
|
52
|
+
`,Ne=F.div`
|
|
53
|
+
|
|
54
|
+
`,ze=p((()=>import("./steps-afba29a7.js"))),Se=p((()=>import("./steps-afba29a7.js").then((e=>{let{Step:t}=e;return{default:t}}))));function Pe(e){return n(g,{fallback:null,children:n(ze,{...e})})}const je=function(e){return n(g,{fallback:null,children:n(Se,{...e})})};function Be(e){let{title:t,content:o,footer:i}=e;return r(ve,{children:[n(Ee,{children:t}),n($e,{children:o}),i&&n(Te,{children:i})]})}Pe.Step=je;const Te=F.div`
|
|
55
|
+
margin-top: 9px;
|
|
56
|
+
padding-top: 10px;
|
|
57
|
+
border-top: 1px solid #f0f0f0;
|
|
58
|
+
color: rgba(0, 0, 0, .65);
|
|
59
|
+
`,$e=F.div`
|
|
60
|
+
color: rgba(0, 0, 0, .85);
|
|
61
|
+
font-size: 24px;
|
|
62
|
+
`,Ee=F.div`
|
|
63
|
+
margin-bottom: 4px;
|
|
64
|
+
color: rgba(0, 0, 0, .45);
|
|
65
|
+
font-size: 1.1rem;
|
|
66
|
+
`;function Le(){}function Fe(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e}function He(e){let{total:t=0,onChange:r=Le,defaultCurrent:o=1,defaultPageSize:i=10,className:c,...l}=e;const[d,h]=a(o),[m,p]=a(i);s((()=>{Fe(l.current)&&h(l.current)}),[l.current]),s((()=>{Fe(l.pageSize)&&p(l.pageSize)}),[l.pageSize]);const g=f((()=>Math.floor((t-1)/m)+1),[t,m]),y=u((e=>()=>{e!==d&&(h(e),r(e,m))}),[r,d,m]),b=d-1>0?d-1:0,x=d+1<g?d+1:g,v=[];let w=null,k=null,C=null,N=null;if(g<=7)for(let e=1;e<=g;e+=1){const t=d===e;v.push(n(S.Item,{active:t,onClick:y(e),children:e},e))}else{N=n(S.Last,{onClick:y(g)},"last"),C=n(S.First,{onClick:y(1)},"first"),w=n(S.Prev,{onClick:y(b)},"prev"),k=n(S.Next,{onClick:y(x)},"next");let e=Math.max(1,d-2),t=Math.min(d+2,g);d-1<=2&&(t=5),g-d<=2&&(e=g-4);for(let r=e;r<=t;r+=1){const e=d===r;v.push(n(S.Item,{active:e,onClick:y(r),children:r},r))}d-1>=4&&3!==d&&v.unshift(w),g-d>=4&&d!==g-2&&v.push(k),1!==e&&v.unshift(C),t!==g&&v.push(N)}return n(S,{className:c,children:v})}function Ae(e){let{className:t,value:r,locale:i="zh-CN",currency:a=!0,options:s={}}=e;const c=f((()=>{let e;return e=a?{style:"currency",currency:"CNY"}:{minimumFractionDigits:2},new Intl.NumberFormat(i,{...e,...s})}),[a,i,s]);return t?n("span",{className:t,children:c.format(r)}):n(o,{children:c.format(r)})}function De(e){let{loading:t,disabled:r,children:o,...i}=e;return n(k,{...i,disabled:t||r,children:t?"Loading…":o})}const Me=p((()=>import("./image-zoom-912e2b3b.js")));function Oe(e){return n(g,{fallback:null,children:n(Me,{...e})})}function Ie(e){let{url:t,method:n,confirm:r,onSuccess:o,children:i,disabled:a,as:s=W,...c}=e;const[l,d]=ce(!1),f=u((async e=>{e.preventDefault();try{if(d(!0),r&&!await Z.confirm({message:r}))return;const e="string"==typeof t?{url:t,method:n}:{method:n,...t},i=await se(e);o&&o(i)}catch(e){ae(e)}finally{d(!1)}}),[t,n,d]);return y(s,{...c,disabled:a||l,onClick:f},i)}const Ue=p((()=>import("./form-74ef0417.js"))),Re=h(((e,t)=>n(g,{fallback:null,children:n(Ue,{...e,ref:t})}))),_e=p((()=>import("./index-7a7c06a9.js"))),qe=h(((e,t)=>n(g,{fallback:null,children:n(_e,{...e,ref:t})})));let Ve=0;function Ge(){let{onHide:e,onShow:t}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const[n,r]=a(!1),[o,i]=a(`visible-${Ve}`),s=u((()=>{r(!1),e&&e()}),[r,e]),c=u((()=>{i("visible-"+ ++Ve)}),[i,Ve]),l=u((()=>{r(!0),t&&t()}),[r,t]),d={show:n,onHide:s,onExited:c,key:o};return{visible:n,show:l,hide:s,state:d}}const Ye=h(((e,t)=>{let{text:i,onOk:a,modalProps:s,children:c,onShow:l,confirmLoading:d,as:u=W,...f}=e;const{state:h,show:m,hide:p}=Ge({onShow:l});b(t,(()=>({close:p})));const g=y(u,{...f,onClick:m},i);return r(o,{children:[g,n(Z,{header:i,...s,...h,confirmLoading:d,onOk:async e=>{if(a){!1===await a()&&e.preventDefault()}},children:c})]})}));function Je(e){let{text:t,onSuccess:o,buttonProps:s,modalProps:c,children:l,...d}=e;const[f,h]=a(!1),m=i(null),p=i(null),g=u((()=>(p.current?.submit(),!1)),[]),y=u((e=>{o&&o(e),m.current?.close()}),[o]);return n(Ye,{ref:m,text:t,...s,modalProps:c,onOk:g,confirmLoading:f,children:r(Re,{...d,onSubmitting:h,ref:p,onSuccess:y,children:[l,n("input",{type:"submit",hidden:!0})]})})}function Ke(e){let{manual:t,refreshDeps:n,...r}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},{execute:o,currentParams:i,error:a,...c}=D((async t=>(e="string"==typeof e?{url:e}:e,await se({...e,...t}))),r);s((()=>{if(!t&&!n)try{o()}catch{}}),[]),s((()=>{n&&l()}),n);const l=u((async()=>{try{i?await o(...i):await o()}catch{}}),[o,i]);if(a&&ie(a)){const e=a.errors;a=new Error("string"==typeof e?e:j(e).join(""))}return{refresh:l,execute:o,error:a,...c}}function Qe(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];const n=i(e);return s((()=>{n.current=e})),u((function(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return n.current?.(...t)}),t)}function We(e){const{value:t,defaultValue:n,onChange:r,shouldUpdate:o=((e,t)=>e!==t)}=e,i=Qe(r),s=Qe(o),[c,l]=a(n),d=void 0!==t,u=d?t:c,f=Qe((e=>{const t="function"==typeof e?e(u):e;s(u,t)&&(d||l(t),i(t))}),[d,i,u,s]);return[u,f]}function Xe(e,t,n){const r=i(e),o=i(B(e,t,n));return s((()=>{r.current=e})),s((()=>{o.current=B((function(){r.current(...arguments)}),t,n)}),[t,n]),o.current}export{W as B,ve as C,we as E,Re as F,Oe as I,be as L,I as M,Ae as N,He as P,ge as R,ke as S,Q as T,Xe as a,We as b,re as c,Pe as d,je as e,Be as f,De as g,Ie as h,oe as i,qe as j,Je as k,Ye as l,Z as m,K as n,Ke as o,Ge as p,ie as q,se as r,ae as s,ce as u,de as w};
|
|
67
|
+
//# sourceMappingURL=index-6ae8237d.js.map
|