unicorn-demo-app 7.4.1 → 7.5.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/package.json +1 -1
- package/src/screens/__tests__/__snapshots__/AvatarScreen.spec.js.snap +22 -6
- package/src/screens/componentScreens/DateTimePickerScreen.tsx +49 -7
- package/src/screens/incubatorScreens/IncubatorCalendarScreen/index.tsx +3 -3
- package/src/screens/incubatorScreens/IncubatorSliderScreen.tsx +0 -1
package/package.json
CHANGED
|
@@ -3072,19 +3072,35 @@ exports[`AvatarScreen renders screen 1`] = `
|
|
|
3072
3072
|
>
|
|
3073
3073
|
<Text
|
|
3074
3074
|
allowFontScaling={false}
|
|
3075
|
+
fsTagName="unmask"
|
|
3075
3076
|
numberOfLines={1}
|
|
3076
3077
|
style={
|
|
3077
3078
|
[
|
|
3078
3079
|
{
|
|
3079
3080
|
"backgroundColor": "transparent",
|
|
3080
|
-
"color": "#
|
|
3081
|
-
"
|
|
3082
|
-
"fontSize": 12,
|
|
3083
|
-
"fontWeight": "700",
|
|
3084
|
-
"lineHeight": 16,
|
|
3081
|
+
"color": "#20303C",
|
|
3082
|
+
"textAlign": "left",
|
|
3085
3083
|
},
|
|
3086
|
-
false,
|
|
3087
3084
|
undefined,
|
|
3085
|
+
undefined,
|
|
3086
|
+
undefined,
|
|
3087
|
+
undefined,
|
|
3088
|
+
undefined,
|
|
3089
|
+
undefined,
|
|
3090
|
+
undefined,
|
|
3091
|
+
undefined,
|
|
3092
|
+
[
|
|
3093
|
+
{
|
|
3094
|
+
"backgroundColor": "transparent",
|
|
3095
|
+
"color": "#FFFFFF",
|
|
3096
|
+
"fontFamily": "System",
|
|
3097
|
+
"fontSize": 12,
|
|
3098
|
+
"fontWeight": "700",
|
|
3099
|
+
"lineHeight": 16,
|
|
3100
|
+
},
|
|
3101
|
+
false,
|
|
3102
|
+
undefined,
|
|
3103
|
+
],
|
|
3088
3104
|
]
|
|
3089
3105
|
}
|
|
3090
3106
|
testID="badge"
|
|
@@ -1,8 +1,23 @@
|
|
|
1
1
|
import React, {Component} from 'react';
|
|
2
2
|
import {ScrollView} from 'react-native';
|
|
3
|
-
import
|
|
3
|
+
import moment from 'moment';
|
|
4
|
+
import * as LightDate from 'light-date';
|
|
5
|
+
import {DateTimePicker, DateTimePickerProps, DateTimePickerMode, View, Text, Switch} from 'react-native-ui-lib';
|
|
6
|
+
|
|
7
|
+
interface State {
|
|
8
|
+
mode: DateTimePickerMode;
|
|
9
|
+
dateTimeFormatter: 'moment' | 'light-date';
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export default class DateTimePickerScreen extends Component<{}, State> {
|
|
13
|
+
constructor(props: any) {
|
|
14
|
+
super(props);
|
|
15
|
+
this.state = {
|
|
16
|
+
mode: 'time',
|
|
17
|
+
dateTimeFormatter: 'moment'
|
|
18
|
+
};
|
|
19
|
+
}
|
|
4
20
|
|
|
5
|
-
export default class DateTimePickerScreen extends Component {
|
|
6
21
|
getCustomInputValue = (value?: string) => {
|
|
7
22
|
if (!value) {
|
|
8
23
|
return 'Default';
|
|
@@ -21,7 +36,27 @@ export default class DateTimePickerScreen extends Component {
|
|
|
21
36
|
);
|
|
22
37
|
};
|
|
23
38
|
|
|
39
|
+
toggleTimeOrDate = () => {
|
|
40
|
+
this.setState({mode: this.state.mode === 'time' ? 'date' : 'time'});
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
toggleFormatter = () => {
|
|
44
|
+
this.setState({dateTimeFormatter: this.state.dateTimeFormatter === 'moment' ? 'light-date' : 'moment'});
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
getFormatter = (): DateTimePickerProps['dateTimeFormatter'] => {
|
|
48
|
+
const {dateTimeFormatter} = this.state;
|
|
49
|
+
if (dateTimeFormatter === 'moment') {
|
|
50
|
+
return (value: Date, mode: DateTimePickerMode) =>
|
|
51
|
+
moment(value).format(mode === 'date' ? 'MMM D, YYYY' : 'h:mm A');
|
|
52
|
+
} else {
|
|
53
|
+
return (value: Date, mode: DateTimePickerMode) =>
|
|
54
|
+
LightDate.format(value, mode === 'date' ? '{mm}-{dd}-{yyyy}' : '{HH}:{mm}');
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
|
|
24
58
|
render() {
|
|
59
|
+
const {mode, dateTimeFormatter} = this.state;
|
|
25
60
|
return (
|
|
26
61
|
<ScrollView>
|
|
27
62
|
<View padding-page>
|
|
@@ -31,7 +66,6 @@ export default class DateTimePickerScreen extends Component {
|
|
|
31
66
|
containerStyle={{marginVertical: 20}}
|
|
32
67
|
label={'Date'}
|
|
33
68
|
placeholder={'Select a date'}
|
|
34
|
-
// dateFormat={'MMM D, YYYY'}
|
|
35
69
|
// value={new Date('October 13, 2014')}
|
|
36
70
|
/>
|
|
37
71
|
<DateTimePicker
|
|
@@ -39,7 +73,6 @@ export default class DateTimePickerScreen extends Component {
|
|
|
39
73
|
mode={'time'}
|
|
40
74
|
label={'Time'}
|
|
41
75
|
placeholder={'Select time'}
|
|
42
|
-
// timeFormat={'h:mm A'}
|
|
43
76
|
// value={new Date('2015-03-25T12:00:00-06:30')}
|
|
44
77
|
/>
|
|
45
78
|
|
|
@@ -64,13 +97,22 @@ export default class DateTimePickerScreen extends Component {
|
|
|
64
97
|
<Text text60R marginT-40>
|
|
65
98
|
Custom Input
|
|
66
99
|
</Text>
|
|
100
|
+
<View row marginV-20 centerV spread>
|
|
101
|
+
<View row>
|
|
102
|
+
<Text text80>{mode}</Text>
|
|
103
|
+
<Switch value={mode === 'time'} onValueChange={this.toggleTimeOrDate} marginL-10/>
|
|
104
|
+
</View>
|
|
105
|
+
<View row>
|
|
106
|
+
<Text text80>{dateTimeFormatter}</Text>
|
|
107
|
+
<Switch value={dateTimeFormatter === 'moment'} onValueChange={this.toggleFormatter} marginL-10/>
|
|
108
|
+
</View>
|
|
109
|
+
</View>
|
|
67
110
|
<DateTimePicker
|
|
68
111
|
migrateTextField
|
|
69
112
|
containerStyle={{marginVertical: 20}}
|
|
70
|
-
label={'Date'}
|
|
71
|
-
placeholder={'Select a date'}
|
|
72
113
|
renderInput={this.renderCustomInput}
|
|
73
|
-
|
|
114
|
+
mode={mode}
|
|
115
|
+
dateTimeFormatter={this.getFormatter()}
|
|
74
116
|
// value={new Date('2015-03-25T12:00:00-06:30')}
|
|
75
117
|
/>
|
|
76
118
|
</View>
|
|
@@ -39,10 +39,10 @@ export default class CalendarScreen extends Component {
|
|
|
39
39
|
};
|
|
40
40
|
|
|
41
41
|
render() {
|
|
42
|
-
const {date, events, showLoader} = this.state;
|
|
42
|
+
const {date, events/* , showLoader */} = this.state;
|
|
43
43
|
return (
|
|
44
|
-
<Incubator.Calendar data={events} initialDate={date} onChangeDate={this.onChangeDate} staticHeader>
|
|
45
|
-
<Incubator.Calendar.Agenda onEndReached={this.onEndReached} showLoader={showLoader}/>
|
|
44
|
+
<Incubator.Calendar data={events} initialDate={date} /* onChangeDate={this.onChangeDate} */ staticHeader>
|
|
45
|
+
{/* <Incubator.Calendar.Agenda onEndReached={this.onEndReached} showLoader={showLoader}/> */}
|
|
46
46
|
</Incubator.Calendar>
|
|
47
47
|
);
|
|
48
48
|
}
|
|
@@ -111,7 +111,6 @@ const IncubatorSliderScreen = () => {
|
|
|
111
111
|
<Text margin-10 text70BL $textDefault>
|
|
112
112
|
Disabled Slider
|
|
113
113
|
</Text>
|
|
114
|
-
{/* @ts-expect-error */}
|
|
115
114
|
<Incubator.Slider value={0.4} containerStyle={styles.container} disableRTL={disableRTL} disabled/>
|
|
116
115
|
</View>
|
|
117
116
|
);
|