antd-mobile 5.36.1 → 5.37.0
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/2x/bundle/antd-mobile.cjs.development.js +355 -283
- package/2x/bundle/antd-mobile.cjs.js +7 -7
- package/2x/bundle/antd-mobile.es.development.js +355 -283
- package/2x/bundle/antd-mobile.es.js +5428 -5379
- package/2x/bundle/antd-mobile.umd.development.js +355 -283
- package/2x/bundle/antd-mobile.umd.js +7 -7
- package/2x/bundle/style.css +5 -8
- package/2x/cjs/components/card/card.css +5 -5
- package/2x/cjs/components/card/card.patch.css +21 -0
- package/2x/cjs/components/center-popup/center-popup.js +46 -43
- package/2x/cjs/components/check-list/check-list.js +15 -11
- package/2x/cjs/components/collapse/collapse.d.ts +9 -1
- package/2x/cjs/components/collapse/collapse.js +26 -28
- package/2x/cjs/components/config-provider/config-provider.d.ts +40 -2
- package/2x/cjs/components/dropdown/context.d.ts +2 -0
- package/2x/cjs/components/dropdown/context.js +10 -0
- package/2x/cjs/components/dropdown/dropdown.d.ts +11 -3
- package/2x/cjs/components/dropdown/dropdown.js +23 -16
- package/2x/cjs/components/dropdown/index.d.ts +1 -0
- package/2x/cjs/components/dropdown/item.d.ts +5 -1
- package/2x/cjs/components/dropdown/item.js +22 -8
- package/2x/cjs/components/form/form-item.d.ts +6 -5
- package/2x/cjs/components/form/form-item.js +25 -17
- package/2x/cjs/components/form/form.d.ts +1 -1
- package/2x/cjs/components/form/index.d.ts +1 -1
- package/2x/cjs/components/input/input.d.ts +3 -1
- package/2x/cjs/components/input/input.js +53 -51
- package/2x/cjs/components/list/list-item.d.ts +6 -2
- package/2x/cjs/components/list/list-item.js +16 -6
- package/2x/cjs/components/nav-bar/nav-bar.d.ts +4 -0
- package/2x/cjs/components/nav-bar/nav-bar.js +18 -13
- package/2x/cjs/components/notice-bar/notice-bar.css +0 -3
- package/2x/cjs/components/notice-bar/notice-bar.d.ts +3 -1
- package/2x/cjs/components/notice-bar/notice-bar.js +30 -25
- package/2x/cjs/components/number-keyboard/number-keyboard.d.ts +1 -1
- package/2x/cjs/components/number-keyboard/number-keyboard.js +14 -13
- package/2x/cjs/components/popup/popup-base-props.d.ts +3 -2
- package/2x/cjs/components/popup/popup-base-props.js +4 -0
- package/2x/cjs/components/popup/popup.js +5 -5
- package/2x/cjs/components/result/result.js +3 -10
- package/2x/cjs/components/result/use-result-icon.d.ts +3 -0
- package/2x/cjs/components/result/use-result-icon.js +37 -0
- package/2x/cjs/components/result-page/result-page.js +3 -10
- package/2x/cjs/components/search-bar/search-bar.d.ts +10 -2
- package/2x/cjs/components/search-bar/search-bar.js +34 -33
- package/2x/cjs/components/toast/toast.d.ts +2 -2
- package/2x/cjs/components/toast/toast.js +4 -4
- package/2x/cjs/components/virtual-input/virtual-input.d.ts +5 -5
- package/2x/cjs/components/virtual-input/virtual-input.js +26 -24
- package/2x/cjs/utils/is-node-with-content.d.ts +3 -0
- package/2x/cjs/utils/is-node-with-content.js +3 -0
- package/2x/cjs/utils/with-default-props.d.ts +7 -0
- package/2x/cjs/utils/with-default-props.js +21 -5
- package/2x/es/components/card/card.css +5 -5
- package/2x/es/components/card/card.patch.css +21 -0
- package/2x/es/components/center-popup/center-popup.js +45 -42
- package/2x/es/components/check-list/check-list.js +15 -11
- package/2x/es/components/collapse/collapse.d.ts +9 -1
- package/2x/es/components/collapse/collapse.js +26 -28
- package/2x/es/components/config-provider/config-provider.d.ts +40 -2
- package/2x/es/components/dropdown/context.d.ts +2 -0
- package/2x/es/components/dropdown/context.js +2 -0
- package/2x/es/components/dropdown/dropdown.d.ts +11 -3
- package/2x/es/components/dropdown/dropdown.js +24 -17
- package/2x/es/components/dropdown/index.d.ts +1 -0
- package/2x/es/components/dropdown/item.d.ts +5 -1
- package/2x/es/components/dropdown/item.js +22 -8
- package/2x/es/components/form/form-item.d.ts +6 -5
- package/2x/es/components/form/form-item.js +24 -16
- package/2x/es/components/form/form.d.ts +1 -1
- package/2x/es/components/form/index.d.ts +1 -1
- package/2x/es/components/input/input.d.ts +3 -1
- package/2x/es/components/input/input.js +52 -50
- package/2x/es/components/list/list-item.d.ts +6 -2
- package/2x/es/components/list/list-item.js +16 -6
- package/2x/es/components/nav-bar/nav-bar.d.ts +4 -0
- package/2x/es/components/nav-bar/nav-bar.js +18 -13
- package/2x/es/components/notice-bar/notice-bar.css +0 -3
- package/2x/es/components/notice-bar/notice-bar.d.ts +3 -1
- package/2x/es/components/notice-bar/notice-bar.js +29 -24
- package/2x/es/components/number-keyboard/number-keyboard.d.ts +1 -1
- package/2x/es/components/number-keyboard/number-keyboard.js +13 -12
- package/2x/es/components/popup/popup-base-props.d.ts +3 -2
- package/2x/es/components/popup/popup-base-props.js +3 -0
- package/2x/es/components/popup/popup.js +5 -5
- package/2x/es/components/result/result.js +3 -10
- package/2x/es/components/result/use-result-icon.d.ts +3 -0
- package/2x/es/components/result/use-result-icon.js +29 -0
- package/2x/es/components/result-page/result-page.js +3 -10
- package/2x/es/components/search-bar/search-bar.d.ts +10 -2
- package/2x/es/components/search-bar/search-bar.js +33 -32
- package/2x/es/components/toast/toast.d.ts +2 -2
- package/2x/es/components/toast/toast.js +3 -3
- package/2x/es/components/virtual-input/virtual-input.d.ts +5 -5
- package/2x/es/components/virtual-input/virtual-input.js +25 -23
- package/2x/es/utils/is-node-with-content.d.ts +3 -0
- package/2x/es/utils/is-node-with-content.js +3 -0
- package/2x/es/utils/with-default-props.d.ts +7 -0
- package/2x/es/utils/with-default-props.js +20 -5
- package/2x/package.json +1 -1
- package/bundle/antd-mobile.cjs.development.js +355 -283
- package/bundle/antd-mobile.cjs.js +7 -7
- package/bundle/antd-mobile.compatible.umd.js +1 -1
- package/bundle/antd-mobile.es.development.js +355 -283
- package/bundle/antd-mobile.es.js +5428 -5379
- package/bundle/antd-mobile.umd.development.js +355 -283
- package/bundle/antd-mobile.umd.js +7 -7
- package/bundle/style.css +1 -1
- package/cjs/components/card/card.css +5 -5
- package/cjs/components/card/card.patch.css +17 -0
- package/cjs/components/center-popup/center-popup.js +46 -43
- package/cjs/components/check-list/check-list.js +15 -11
- package/cjs/components/collapse/collapse.d.ts +9 -1
- package/cjs/components/collapse/collapse.js +26 -28
- package/cjs/components/config-provider/config-provider.d.ts +40 -2
- package/cjs/components/dropdown/context.d.ts +2 -0
- package/cjs/components/dropdown/context.js +10 -0
- package/cjs/components/dropdown/dropdown.d.ts +11 -3
- package/cjs/components/dropdown/dropdown.js +23 -16
- package/cjs/components/dropdown/index.d.ts +1 -0
- package/cjs/components/dropdown/item.d.ts +5 -1
- package/cjs/components/dropdown/item.js +22 -8
- package/cjs/components/form/form-item.d.ts +6 -5
- package/cjs/components/form/form-item.js +25 -17
- package/cjs/components/form/form.d.ts +1 -1
- package/cjs/components/form/index.d.ts +1 -1
- package/cjs/components/input/input.d.ts +3 -1
- package/cjs/components/input/input.js +53 -51
- package/cjs/components/list/list-item.d.ts +6 -2
- package/cjs/components/list/list-item.js +16 -6
- package/cjs/components/nav-bar/nav-bar.d.ts +4 -0
- package/cjs/components/nav-bar/nav-bar.js +18 -13
- package/cjs/components/notice-bar/notice-bar.css +0 -2
- package/cjs/components/notice-bar/notice-bar.d.ts +3 -1
- package/cjs/components/notice-bar/notice-bar.js +30 -25
- package/cjs/components/number-keyboard/number-keyboard.d.ts +1 -1
- package/cjs/components/number-keyboard/number-keyboard.js +14 -13
- package/cjs/components/popup/popup-base-props.d.ts +3 -2
- package/cjs/components/popup/popup-base-props.js +4 -0
- package/cjs/components/popup/popup.js +5 -5
- package/cjs/components/result/result.js +3 -10
- package/cjs/components/result/use-result-icon.d.ts +3 -0
- package/cjs/components/result/use-result-icon.js +37 -0
- package/cjs/components/result-page/result-page.js +3 -10
- package/cjs/components/search-bar/search-bar.d.ts +10 -2
- package/cjs/components/search-bar/search-bar.js +34 -33
- package/cjs/components/toast/toast.css +1 -1
- package/cjs/components/toast/toast.d.ts +2 -2
- package/cjs/components/toast/toast.js +4 -4
- package/cjs/components/virtual-input/virtual-input.d.ts +5 -5
- package/cjs/components/virtual-input/virtual-input.js +26 -24
- package/cjs/utils/is-node-with-content.d.ts +3 -0
- package/cjs/utils/is-node-with-content.js +3 -0
- package/cjs/utils/with-default-props.d.ts +7 -0
- package/cjs/utils/with-default-props.js +21 -5
- package/es/components/card/card.css +5 -5
- package/es/components/card/card.patch.css +17 -0
- package/es/components/center-popup/center-popup.js +45 -42
- package/es/components/check-list/check-list.js +15 -11
- package/es/components/collapse/collapse.d.ts +9 -1
- package/es/components/collapse/collapse.js +26 -28
- package/es/components/config-provider/config-provider.d.ts +40 -2
- package/es/components/dropdown/context.d.ts +2 -0
- package/es/components/dropdown/context.js +2 -0
- package/es/components/dropdown/dropdown.d.ts +11 -3
- package/es/components/dropdown/dropdown.js +24 -17
- package/es/components/dropdown/index.d.ts +1 -0
- package/es/components/dropdown/item.d.ts +5 -1
- package/es/components/dropdown/item.js +22 -8
- package/es/components/form/form-item.d.ts +6 -5
- package/es/components/form/form-item.js +24 -16
- package/es/components/form/form.d.ts +1 -1
- package/es/components/form/index.d.ts +1 -1
- package/es/components/input/input.d.ts +3 -1
- package/es/components/input/input.js +52 -50
- package/es/components/list/list-item.d.ts +6 -2
- package/es/components/list/list-item.js +16 -6
- package/es/components/nav-bar/nav-bar.d.ts +4 -0
- package/es/components/nav-bar/nav-bar.js +18 -13
- package/es/components/notice-bar/notice-bar.css +0 -2
- package/es/components/notice-bar/notice-bar.d.ts +3 -1
- package/es/components/notice-bar/notice-bar.js +29 -24
- package/es/components/number-keyboard/number-keyboard.d.ts +1 -1
- package/es/components/number-keyboard/number-keyboard.js +13 -12
- package/es/components/popup/popup-base-props.d.ts +3 -2
- package/es/components/popup/popup-base-props.js +3 -0
- package/es/components/popup/popup.js +5 -5
- package/es/components/result/result.js +3 -10
- package/es/components/result/use-result-icon.d.ts +3 -0
- package/es/components/result/use-result-icon.js +29 -0
- package/es/components/result-page/result-page.js +3 -10
- package/es/components/search-bar/search-bar.d.ts +10 -2
- package/es/components/search-bar/search-bar.js +33 -32
- package/es/components/toast/toast.css +1 -1
- package/es/components/toast/toast.d.ts +2 -2
- package/es/components/toast/toast.js +3 -3
- package/es/components/virtual-input/virtual-input.d.ts +5 -5
- package/es/components/virtual-input/virtual-input.js +25 -23
- package/es/utils/is-node-with-content.d.ts +3 -0
- package/es/utils/is-node-with-content.js +3 -0
- package/es/utils/with-default-props.d.ts +7 -0
- package/es/utils/with-default-props.js +20 -5
- package/package.json +1 -1
- package/umd/antd-mobile.js +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
1
|
import type { ReactElement } from 'react';
|
|
3
|
-
import
|
|
2
|
+
import React from 'react';
|
|
4
3
|
import { NativeProps } from '../../utils/native-props';
|
|
4
|
+
import type { InputProps } from '../input';
|
|
5
5
|
import { NumberKeyboardProps } from '../number-keyboard';
|
|
6
6
|
export declare type VirtualInputProps = {
|
|
7
7
|
onFocus?: () => void;
|
|
@@ -10,7 +10,7 @@ export declare type VirtualInputProps = {
|
|
|
10
10
|
keyboard?: ReactElement<NumberKeyboardProps>;
|
|
11
11
|
clearable?: boolean;
|
|
12
12
|
onClear?: () => void;
|
|
13
|
-
} & Pick<InputProps, 'value' | 'onChange' | 'placeholder' | 'disabled'> & NativeProps<'--font-size' | '--color' | '--placeholder-color' | '--disabled-color' | '--text-align' | '--caret-width' | '--caret-color'>;
|
|
13
|
+
} & Pick<InputProps, 'value' | 'onChange' | 'placeholder' | 'disabled' | 'clearIcon'> & NativeProps<'--font-size' | '--color' | '--placeholder-color' | '--disabled-color' | '--text-align' | '--caret-width' | '--caret-color'>;
|
|
14
14
|
export declare type VirtualInputRef = {
|
|
15
15
|
focus: () => void;
|
|
16
16
|
blur: () => void;
|
|
@@ -19,10 +19,10 @@ export declare const VirtualInput: React.ForwardRefExoticComponent<{
|
|
|
19
19
|
onFocus?: (() => void) | undefined;
|
|
20
20
|
onBlur?: (() => void) | undefined;
|
|
21
21
|
onClick?: ((e: React.MouseEvent<HTMLDivElement>) => void) | undefined;
|
|
22
|
-
keyboard?:
|
|
22
|
+
keyboard?: ReactElement<NumberKeyboardProps, string | React.JSXElementConstructor<any>> | undefined;
|
|
23
23
|
clearable?: boolean | undefined;
|
|
24
24
|
onClear?: (() => void) | undefined;
|
|
25
|
-
} & Pick<InputProps, "value" | "onChange" | "disabled" | "placeholder"> & {
|
|
25
|
+
} & Pick<InputProps, "value" | "onChange" | "disabled" | "placeholder" | "clearIcon"> & {
|
|
26
26
|
className?: string | undefined;
|
|
27
27
|
style?: (React.CSSProperties & Partial<Record<"--color" | "--font-size" | "--placeholder-color" | "--text-align" | "--disabled-color" | "--caret-width" | "--caret-color", string>>) | undefined;
|
|
28
28
|
tabIndex?: number | undefined;
|
|
@@ -1,24 +1,26 @@
|
|
|
1
|
+
import { useIsomorphicLayoutEffect } from 'ahooks';
|
|
2
|
+
import { CloseCircleFill } from 'antd-mobile-icons';
|
|
3
|
+
import classNames from 'classnames';
|
|
1
4
|
import React, { forwardRef, useEffect, useImperativeHandle, useRef, useState } from 'react';
|
|
2
5
|
import { withNativeProps } from '../../utils/native-props';
|
|
3
|
-
import { mergeProps } from '../../utils/with-default-props';
|
|
4
6
|
import { usePropsValue } from '../../utils/use-props-value';
|
|
5
|
-
import
|
|
6
|
-
import { CloseCircleFill } from 'antd-mobile-icons';
|
|
7
|
-
import { useIsomorphicLayoutEffect } from 'ahooks';
|
|
7
|
+
import { mergeProp, mergeProps } from '../../utils/with-default-props';
|
|
8
8
|
import { useConfig } from '../config-provider';
|
|
9
9
|
const classPrefix = 'adm-virtual-input';
|
|
10
10
|
const defaultProps = {
|
|
11
11
|
defaultValue: ''
|
|
12
12
|
};
|
|
13
|
-
export const VirtualInput = forwardRef((
|
|
14
|
-
const
|
|
15
|
-
|
|
13
|
+
export const VirtualInput = forwardRef((props, ref) => {
|
|
14
|
+
const {
|
|
15
|
+
locale,
|
|
16
|
+
input: componentConfig = {}
|
|
17
|
+
} = useConfig();
|
|
18
|
+
const mergedProps = mergeProps(defaultProps, componentConfig, props);
|
|
19
|
+
const [value, setValue] = usePropsValue(mergedProps);
|
|
16
20
|
const rootRef = useRef(null);
|
|
17
21
|
const contentRef = useRef(null);
|
|
18
22
|
const [hasFocus, setHasFocus] = useState(false);
|
|
19
|
-
const
|
|
20
|
-
locale
|
|
21
|
-
} = useConfig();
|
|
23
|
+
const clearIcon = mergeProp(React.createElement(CloseCircleFill, null), componentConfig.clearIcon, props.clearIcon);
|
|
22
24
|
function scrollToEnd() {
|
|
23
25
|
const root = rootRef.current;
|
|
24
26
|
if (!root) return;
|
|
@@ -50,14 +52,14 @@ export const VirtualInput = forwardRef((p, ref) => {
|
|
|
50
52
|
function onFocus() {
|
|
51
53
|
var _a;
|
|
52
54
|
setHasFocus(true);
|
|
53
|
-
(_a =
|
|
55
|
+
(_a = mergedProps.onFocus) === null || _a === void 0 ? void 0 : _a.call(mergedProps);
|
|
54
56
|
}
|
|
55
57
|
function onBlur() {
|
|
56
58
|
var _a;
|
|
57
59
|
setHasFocus(false);
|
|
58
|
-
(_a =
|
|
60
|
+
(_a = mergedProps.onBlur) === null || _a === void 0 ? void 0 : _a.call(mergedProps);
|
|
59
61
|
}
|
|
60
|
-
const keyboard =
|
|
62
|
+
const keyboard = mergedProps.keyboard;
|
|
61
63
|
const keyboardElement = keyboard && React.cloneElement(keyboard, {
|
|
62
64
|
onInput: v => {
|
|
63
65
|
var _a, _b;
|
|
@@ -84,36 +86,36 @@ export const VirtualInput = forwardRef((p, ref) => {
|
|
|
84
86
|
},
|
|
85
87
|
getContainer: null
|
|
86
88
|
});
|
|
87
|
-
return withNativeProps(
|
|
89
|
+
return withNativeProps(mergedProps, React.createElement("div", {
|
|
88
90
|
ref: rootRef,
|
|
89
91
|
className: classNames(classPrefix, {
|
|
90
|
-
[`${classPrefix}-disabled`]:
|
|
92
|
+
[`${classPrefix}-disabled`]: mergedProps.disabled
|
|
91
93
|
}),
|
|
92
|
-
tabIndex:
|
|
94
|
+
tabIndex: mergedProps.disabled ? undefined : 0,
|
|
93
95
|
role: 'textbox',
|
|
94
96
|
onFocus: onFocus,
|
|
95
97
|
onBlur: onBlur,
|
|
96
|
-
onClick:
|
|
98
|
+
onClick: mergedProps.onClick
|
|
97
99
|
}, React.createElement("div", {
|
|
98
100
|
className: `${classPrefix}-content`,
|
|
99
101
|
ref: contentRef,
|
|
100
|
-
"aria-disabled":
|
|
101
|
-
"aria-label":
|
|
102
|
+
"aria-disabled": mergedProps.disabled,
|
|
103
|
+
"aria-label": mergedProps.placeholder
|
|
102
104
|
}, value, React.createElement("div", {
|
|
103
105
|
className: `${classPrefix}-caret-container`
|
|
104
106
|
}, hasFocus && React.createElement("div", {
|
|
105
107
|
className: `${classPrefix}-caret`
|
|
106
|
-
}))),
|
|
108
|
+
}))), mergedProps.clearable && !!value && hasFocus && React.createElement("div", {
|
|
107
109
|
className: `${classPrefix}-clear`,
|
|
108
110
|
onClick: e => {
|
|
109
111
|
var _a;
|
|
110
112
|
e.stopPropagation();
|
|
111
113
|
setValue('');
|
|
112
|
-
(_a =
|
|
114
|
+
(_a = mergedProps.onClear) === null || _a === void 0 ? void 0 : _a.call(mergedProps);
|
|
113
115
|
},
|
|
114
116
|
role: 'button',
|
|
115
117
|
"aria-label": locale.Input.clear
|
|
116
|
-
},
|
|
118
|
+
}, clearIcon), [undefined, null, ''].includes(value) && React.createElement("div", {
|
|
117
119
|
className: `${classPrefix}-placeholder`
|
|
118
|
-
},
|
|
120
|
+
}, mergedProps.placeholder), keyboardElement));
|
|
119
121
|
});
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import type { ReactNode } from 'react';
|
|
2
2
|
declare type Regulated<T> = T extends null | undefined | false ? never : T;
|
|
3
|
+
/**
|
|
4
|
+
* Check if the `node` is visible Node (not null, undefined, or false)
|
|
5
|
+
*/
|
|
3
6
|
export declare function isNodeWithContent(node: ReactNode): node is Regulated<ReactNode>;
|
|
4
7
|
export {};
|
|
@@ -1,2 +1,9 @@
|
|
|
1
1
|
export declare function mergeProps<A, B>(a: A, b: B): B & A;
|
|
2
2
|
export declare function mergeProps<A, B, C>(a: A, b: B, c: C): C & B & A;
|
|
3
|
+
export declare function mergeProps<A, B, C, D>(a: A, b: B, c: C, d: D): D & C & B & A;
|
|
4
|
+
/**
|
|
5
|
+
* Merge props and return the first non-undefined value.
|
|
6
|
+
* The later has higher priority. e.g. (10, 1, 5) => 5 wins.
|
|
7
|
+
* This is useful with legacy props that have been deprecated.
|
|
8
|
+
*/
|
|
9
|
+
export declare function mergeProp<T, DefaultT extends T = T>(defaultProp: DefaultT, ...propList: T[]): T | undefined;
|
|
@@ -1,11 +1,26 @@
|
|
|
1
1
|
export function mergeProps(...items) {
|
|
2
2
|
const ret = {};
|
|
3
3
|
items.forEach(item => {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
if (item) {
|
|
5
|
+
Object.keys(item).forEach(key => {
|
|
6
|
+
if (item[key] !== undefined) {
|
|
7
|
+
ret[key] = item[key];
|
|
8
|
+
}
|
|
9
|
+
});
|
|
10
|
+
}
|
|
9
11
|
});
|
|
10
12
|
return ret;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Merge props and return the first non-undefined value.
|
|
16
|
+
* The later has higher priority. e.g. (10, 1, 5) => 5 wins.
|
|
17
|
+
* This is useful with legacy props that have been deprecated.
|
|
18
|
+
*/
|
|
19
|
+
export function mergeProp(defaultProp, ...propList) {
|
|
20
|
+
for (let i = propList.length - 1; i >= 0; i -= 1) {
|
|
21
|
+
if (propList[i] !== undefined) {
|
|
22
|
+
return propList[i];
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return defaultProp;
|
|
11
26
|
}
|