UNPKG

12.7 kBTypeScriptView Raw
1import { ComponentType } from 'react'
2import { StyleProp, TextStyle, ViewStyle } from 'react-native'
3import { StandardProps, CommonEventFunction, FormItemProps } from './common'
4/** 选择器通用参数 */
5interface PickerStandardProps extends StandardProps, FormItemProps {
6 /**
7 * 选择器的标题,微信小程序中仅安卓可用
8 * @supported weapp
9 */
10 headerText?: string
11 /**
12 * 选择器类型,默认是普通选择器
13 * @default "selector"
14 * @supported weapp, h5, rn, harmony, harmony_hybrid
15 */
16 mode?: keyof PickerStandardProps.Mode
17 /**
18 * 是否禁用
19 * @default false
20 * @supported weapp, h5, rn, harmony_hybrid
21 */
22 disabled?: boolean
23 /**
24 * 取消选择或点遮罩层收起 picker 时触发
25 * @supported weapp, h5, rn, harmony, harmony_hybrid
26 */
27 onCancel?: CommonEventFunction
28 /**
29 * 用于替换组件内部文本
30 * @supported h5, harmony, harmony_hybrid
31 */
32 textProps?: PickerStandardProps.PickerText
33}
34declare namespace PickerStandardProps {
35 /** 选择器类型 */
36 interface Mode {
37 /** 普通选择器 */
38 selector
39 /** 多列选择器 */
40 multiSelector
41 /** 时间选择器 */
42 time
43 /** 日期选择器 */
44 date
45 /** 省市区选择器 */
46 region
47 }
48 interface PickerText {
49 okText?: string
50 cancelText?: string
51 }
52}
53/** 普通选择器:mode = selector */
54interface PickerSelectorProps extends PickerStandardProps {
55 /** 选择器类型 */
56 mode?: 'selector'
57 /**
58 * mode为 selector 或 multiSelector 时,range 有效
59 * @supported weapp, h5, rn, harmony, harmony_hybrid
60 * @default []
61 */
62 range: string[] | number[] | Record<string, any>[]
63 /**
64 * 当 range 是一个 Object Array 时,通过 rangeKey 来指定 Object 中 key 的值作为选择器显示内容
65 * @supported weapp, h5, rn, harmony, harmony_hybrid
66 */
67 rangeKey?: string
68 /**
69 * 表示选择了 range 中的第几个(下标从 0 开始)
70 * @supported weapp, h5, rn, harmony, harmony_hybrid
71 * @default 0
72 */
73 value?: number
74 /** 设置 React 非受控状态下的初始取值
75 * @supported weapp, h5, rn, harmony_hybrid
76 */
77 defaultValue?: number
78 /**
79 * mode为 selector 或 multiSelector 时 itemStyle 有效
80 * @supported rn
81 * @default {}
82 */
83 itemStyle?: StyleProp<TextStyle>
84 /**
85 * mode为 selector 或 multiSelector 时 indicatorStyle 有效
86 * @supported rn
87 * @default {}
88 */
89 indicatorStyle?: StyleProp<ViewStyle>
90 /**
91 * value 改变时触发 change 事件
92 * @supported weapp, h5, rn, harmony, harmony_hybrid
93 */
94 onChange?: CommonEventFunction<PickerSelectorProps.ChangeEventDetail>
95}
96declare namespace PickerSelectorProps {
97 interface ChangeEventDetail {
98 /** 表示变更值的下标 */
99 value: string | number
100 }
101}
102/** 多列选择器:mode = multiSelector */
103interface PickerMultiSelectorProps extends PickerStandardProps {
104 /** 选择器类型 */
105 mode: 'multiSelector'
106 /**
107 * mode为 selector 或 multiSelector 时,range 有效
108 * @supported weapp, h5, rn, harmony, harmony_hybrid
109 * @default []
110 */
111 range: Array<string[]> | Array<number[]> | Array<Record<string, any>[]>
112 /**
113 * 当 range 是一个 Object Array 时,通过 rangeKey 来指定 Object 中 key 的值作为选择器显示内容
114 * @supported weapp, h5, rn, harmony, harmony_hybrid
115 */
116 rangeKey?: string
117 /**
118 * 表示选择了 range 中的第几个(下标从 0 开始)
119 * @supported weapp, h5, rn, harmony, harmony_hybrid
120 * @default []
121 */
122 value: number[] | string[] | Record<string, any>[]
123 /**
124 * mode为 selector 或 multiSelector 时 itemStyle 有效
125 * @supported rn
126 * @default {}
127 */
128 itemStyle?: StyleProp<TextStyle>
129 /**
130 * mode为 selector 或 multiSelector 时 indicatorStyle 有效
131 * @supported rn
132 * @default {}
133 */
134 indicatorStyle?: StyleProp<ViewStyle>
135 /**
136 * 当 value 改变时触发 change 事件
137 * @supported weapp, h5, rn, harmony, harmony_hybrid
138 */
139 onChange: CommonEventFunction<PickerMultiSelectorProps.ChangeEventDetail>
140 /**
141 * 列改变时触发
142 * @supported weapp, h5, rn, harmony, harmony_hybrid
143 */
144 onColumnChange?: CommonEventFunction<PickerMultiSelectorProps.ColumnChangeEventDetail>
145}
146declare namespace PickerMultiSelectorProps {
147 interface ChangeEventDetail {
148 /** 表示变更值的下标 */
149 value: number[]
150 }
151 interface ColumnChangeEventDetail {
152 /** 表示改变了第几列(下标从0开始) */
153 column: number
154 /** 表示变更值的下标 */
155 value: number
156 }
157}
158/** 时间选择器:mode = time */
159interface PickerTimeProps extends PickerStandardProps {
160 /** 选择器类型 */
161 mode: 'time'
162 /**
163 * value 的值表示选择了 range 中的第几个(下标从 0 开始)
164 * @supported weapp, h5, rn, harmony, harmony_hybrid
165 */
166 value?: string
167 /** 设置 React 非受控状态下的初始取值
168 * @supported weapp, h5, rn
169 */
170 defaultValue?: string
171 /**
172 * 仅当 mode 为 "time" 或 "date" 时有效,表示有效时间范围的开始,字符串格式为"hh:mm"
173 * @supported weapp, h5, rn, harmony, harmony_hybrid
174 */
175 start?: string
176 /**
177 * 仅当 mode 为 "time" 或 "date" 时有效,表示有效时间范围的结束,字符串格式为"hh:mm"
178 * @supported weapp, h5, rn, harmony, harmony_hybrid
179 */
180 end?: string
181 /**
182 * value 改变时触发 change 事件
183 * @supported weapp, h5, rn, harmony, harmony_hybrid
184 */
185 onChange: CommonEventFunction<PickerTimeProps.ChangeEventDetail>
186}
187declare namespace PickerTimeProps {
188 interface ChangeEventDetail {
189 /** 表示选中的时间 */
190 value: string
191 }
192}
193/** 日期选择器:mode = date */
194interface PickerDateProps extends PickerStandardProps {
195 /** 选择器类型 */
196 mode: 'date'
197 /**
198 * 表示选中的日期,格式为"YYYY-MM-DD"
199 * @supported weapp, h5, rn, harmony, harmony_hybrid
200 * @default 0
201 */
202 value: string
203 /** 设置 React 非受控状态下的初始取值
204 * @supported weapp, h5, rn
205 */
206 defaultValue?: string
207 /**
208 * 仅当 mode 为 "time" 或 "date" 时有效,表示有效时间范围的开始,字符串格式为"YYYY-MM-DD"
209 * @supported weapp, h5, rn, harmony, harmony_hybrid
210 */
211 start?: string
212 /**
213 * 仅当 mode 为 "time" 或 "date" 时有效,表示有效时间范围的结束,字符串格式为"YYYY-MM-DD"
214 * @supported weapp, h5, rn, harmony, harmony_hybrid
215 */
216 end?: string
217 /**
218 * 有效值 year, month, day,表示选择器的粒度
219 * @supported weapp, h5, rn, harmony_hybrid
220 * @default "day"
221 */
222 fields?: keyof PickerDateProps.Fields
223 /**
224 * value 改变时触发 change 事件
225 * @supported weapp, h5, rn, harmony, harmony_hybrid
226 */
227 onChange: CommonEventFunction<PickerDateProps.ChangeEventDetail>
228}
229declare namespace PickerDateProps {
230 interface Fields {
231 /** 选择器粒度为年 */
232 year
233 /** 选择器粒度为月份 */
234 month
235 /** 选择器粒度为天 */
236 day
237 }
238 interface ChangeEventDetail {
239 /** 表示选中的日期 */
240 value: string
241 }
242}
243/** 省市区选择器:mode = region */
244interface PickerRegionProps extends PickerStandardProps {
245 /** 选择器类型 */
246 mode: 'region'
247 /**
248 * 表示选中的省市区,默认选中每一列的第一个值
249 * @supported weapp, h5, rn, harmony_hybrid
250 * @default []
251 */
252 value?: string[]
253 /** 设置 React 非受控状态下的初始取值
254 * @supported weapp, h5, rn
255 */
256 defaultValue?: string[]
257 /**
258 * 可为每一列的顶部添加一个自定义的项
259 * @supported weapp, h5, rn, harmony_hybrid
260 */
261 customItem?: string
262 /**
263 * 选择器层级
264 * @supported weapp
265 * @default "region"
266 */
267 level?: keyof PickerRegionProps.Level
268 /**
269 * 自定义省市区数据
270 * @supported rn
271 */
272 regionData?: PickerRegionProps.RegionData[]
273 /**
274 * value 改变时触发 change 事件
275 * @supported weapp, h5, rn, harmony_hybrid
276 */
277 onChange: CommonEventFunction<PickerRegionProps.ChangeEventDetail>
278}
279declare namespace PickerRegionProps {
280 interface ChangeEventDetail {
281 /** 表示选中的省市区 */
282 value: string[]
283 /** 统计用区划代码 */
284 code: string[]
285 /** 邮政编码 */
286 postcode?: string
287 }
288 interface RegionData {
289 value: string
290 code: string
291 postcode?: string
292 children?: RegionData[]
293 }
294 interface Level {
295 /** 省级选择器 */
296 province
297 /** 市级选择器 */
298 city
299 /** 区级选择器 */
300 region
301 /** 街道选择器 */
302 'sub-district'
303 }
304}
305/**
306 * 从底部弹起的滚动选择器
307 * @classification forms
308 * @supported weapp, swan, alipay, tt, h5, rn, harmony, harmony_hybrid
309 * @example_react
310 * ```tsx
311 * export default class PagePicker extends Component {
312 * state = {
313 * selector: ['美国', '中国', '巴西', '日本'],
314 * selectorChecked: '美国',
315 * timeSel: '12:01',
316 * dateSel: '2018-04-22'
317 * }
318 *
319 * onChange = e => {
320 * this.setState({
321 * selectorChecked: this.state.selector[e.detail.value]
322 * })
323 * }
324 *
325 * onTimeChange = e => {
326 * this.setState({
327 * timeSel: e.detail.value
328 * })
329 * }
330 * onDateChange = e => {
331 * this.setState({
332 * dateSel: e.detail.value
333 * })
334 * }
335 *
336 * render () {
337 * return (
338 * <View className='container'>
339 * <View className='page-body'>
340 * <View className='page-section'>
341 * <Text>地区选择器</Text>
342 * <View>
343 * <Picker mode='selector' range={this.state.selector} onChange={this.onChange}>
344 * <View className='picker'>
345 * 当前选择:{this.state.selectorChecked}
346 * </View>
347 * </Picker>
348 * </View>
349 * </View>
350 * <View className='page-section'>
351 * <Text>时间选择器</Text>
352 * <View>
353 * <Picker mode='time' onChange={this.onTimeChange}>
354 * <View className='picker'>
355 * 当前选择:{this.state.timeSel}
356 * </View>
357 * </Picker>
358 * </View>
359 * </View>
360 * <View className='page-section'>
361 * <Text>日期选择器</Text>
362 * <View>
363 * <Picker mode='date' onChange={this.onDateChange}>
364 * <View className='picker'>
365 * 当前选择:{this.state.dateSel}
366 * </View>
367 * </Picker>
368 * </View>
369 * </View>
370 * </View>
371 * </View>
372 * )
373 * }
374 * }
375 * ```
376 * @example_vue
377 * ```html
378 * <template>
379 * <view class="page-body">
380 * <view class="page-section">
381 * <text>地区选择器</text>
382 * <view>
383 * <picker mode="selector" :range="selector" `@change="onChange">
384 * <view class="picker">
385 * 当前选择:{{selectorChecked}}
386 * </view>
387 * </picker>
388 * </view>
389 * </view>
390 * <view class="page-section">
391 * <text>时间选择器</text>
392 * <view>
393 * <picker mode="time" `@change="onTimeChange">
394 * <view class="picker">
395 * 当前选择:{{timeSel}}
396 * </view>
397 * </picker>
398 * </view>
399 * </view>
400 * <view class="page-section">
401 * <text>日期选择器</text>
402 * <view>
403 * <picker mode="date" `@change="onDateChange">
404 * <view class="picker">
405 * 当前选择:{{dateSel}}
406 * </view>
407 * </picker>
408 * </view>
409 * </view>
410 * </view>
411 * </template>
412 *
413 * <script>
414 * export default {
415 * data() {
416 * return {
417 * selector: ['美国', '中国', '巴西', '日本'],
418 * selectorChecked: '美国',
419 * timeSel: '12:01',
420 * dateSel: '2018-04-22'
421 * }
422 * },
423 * methods: {
424 * onChange: function(e) {
425 * this.selectorChecked = this.selector[e.detail.value]
426 * },
427 *
428 * onTimeChange: function(e) {
429 * this.timeSel = e.detail.value
430 * },
431 *
432 * onDateChange: function(e) {
433 * this.dateSel = e.detail.value
434 * }
435 * }
436 * }
437 * </script>
438 * ```
439 * @see https://developers.weixin.qq.com/miniprogram/dev/component/picker.html
440 */
441declare const Picker: ComponentType<
442 PickerMultiSelectorProps | PickerTimeProps | PickerDateProps | PickerRegionProps | PickerSelectorProps
443>
444export {
445 Picker,
446 PickerStandardProps,
447 PickerSelectorProps,
448 PickerMultiSelectorProps,
449 PickerTimeProps,
450 PickerDateProps,
451 PickerRegionProps,
452}