提交 01212947 authored 作者: 吴强's avatar 吴强

发布的第一版

上级 e6d8185d
import React, { PureComponent } from 'react';
import { View } from 'react-native';
import { WhiteSpace, List, Picker } from 'antd-mobile';
import { createAction } from '../utils/index';
class PickerComponent extends PureComponent {
onClick = () => {
this.props.dispatch(createAction('domain/fetch')());
};
onPickerChange = (val) => {
let colNum = 1;
const d = [...this.props.data];
const asyncValue = [...val];
if (val[0] !== undefined) {
d.forEach((i) => {
if (i.value === 'zj') {
colNum = 2;
if (!i.children) {
i.children = [{
value: 'zj-nb',
label: '宁波',
}, {
value: 'zj-hz',
label: '杭州',
}];
asyncValue.push('zj-nb');
} else if (val[1] === 'zj-hz') {
i.children.forEach((j) => {
if (j.value === 'zj-hz') {
j.children = [{
value: 'zj-hz-xh',
label: '西湖区',
}];
asyncValue.push('zj-hz-xh');
}
});
colNum = 3;
}
}
});
} else {
colNum = 1;
}
};
render() {
return (
<View>
<WhiteSpace size="lg" />
<List style={{ backgroundColor: 'white' }} className="picker-list">
<Picker
data={this.props.data}
cols={this.props.cols}
value={this.props.asyncValue}
onPickerChange={this.onPickerChange}
>
<List.Item arrow="horizontal" onClick={this.onClick}>当前基地</List.Item>
</Picker>
</List>
</View>
);
}
}
export default PickerComponent;
...@@ -21,6 +21,13 @@ export default { ...@@ -21,6 +21,13 @@ export default {
if (singularData.dangShiRenXingMing !== undefined) { if (singularData.dangShiRenXingMing !== undefined) {
singularData.dangShiRenXingMing = payload.peopleName; singularData.dangShiRenXingMing = payload.peopleName;
} }
if (singularData.dangShiRenIdentityCard !== undefined) {
singularData.dangShiRenIdentityCard = payload.idcard;
}
if (singularData.dangShiRenXingBie !== undefined) {
singularData.dangShiRenXingBie = payload.sex;
}
return { ...state, singularData }; return { ...state, singularData };
}, },
setEnable(state, { payload: enableEdit }) { setEnable(state, { payload: enableEdit }) {
...@@ -66,14 +73,13 @@ export default { ...@@ -66,14 +73,13 @@ export default {
}, },
*DuKa(ignored, { call, put }) { *DuKa(ignored, { call, put }) {
try { try {
Toast.loading('读卡中...', 0);
const result = yield call(scan); const result = yield call(scan);
if (result) { if (result) {
yield put({ type: 'setSingularData', payload: result }); yield put({ type: 'setSingularData', payload: result });
} }
Toast.loading('读卡完成', 5); } catch (e) {
} finally { console.log(e);
Toast.loading('读卡失败', 10); throw e;
} }
// //
}, },
......
...@@ -23,6 +23,14 @@ export default { ...@@ -23,6 +23,14 @@ export default {
yield put({ type: 'queryInit', payload: init }); yield put({ type: 'queryInit', payload: init });
yield put({ type: 'queryList', payload: list }); yield put({ type: 'queryList', payload: list });
}, },
*fetchParam(dmpath, { put, call }) {
const domain = yield call(getDomain);
const init = domain ? domain.path : undefined;
const list = yield call(fetchDomains, dmpath);
yield put({ type: 'queryInit', payload: init });
yield put({ type: 'queryList', payload: list });
},
*switch({ payload: domainPath }, { put, call }) { *switch({ payload: domainPath }, { put, call }) {
yield call(switchDomain, domainPath); yield call(switchDomain, domainPath);
const { path, name } = yield call(currentDomain); const { path, name } = yield call(currentDomain);
......
...@@ -6,9 +6,11 @@ import obligeeInfo from './houseinfo/ObligeeInfo'; ...@@ -6,9 +6,11 @@ import obligeeInfo from './houseinfo/ObligeeInfo';
import DSRInfo from './dangshireninfo/dsrinfo'; import DSRInfo from './dangshireninfo/dsrinfo';
import DSRInfoDetail from './dangshireninfo/dsrinfodetail'; import DSRInfoDetail from './dangshireninfo/dsrinfodetail';
import peopleInfo from './peopleInfo/peopleInfo'; import peopleInfo from './peopleInfo/peopleInfo';
import domain from './domain';
export default [ export default [
welcome, welcome,
domain,
login, login,
listHouse, listHouse,
HouseDetail, HouseDetail,
......
...@@ -5,6 +5,7 @@ import { Toast } from 'antd-mobile'; ...@@ -5,6 +5,7 @@ import { Toast } from 'antd-mobile';
import { NavigationActions } from 'react-navigation'; import { NavigationActions } from 'react-navigation';
import { getData, getMeta } from '../../utils/DataTemplate'; import { getData, getMeta } from '../../utils/DataTemplate';
import { datasourceApi } from '../../services/datasource'; import { datasourceApi } from '../../services/datasource';
import { scan } from '../../services/idcard';
export default { export default {
namespace: 'peopleInfo', namespace: 'peopleInfo',
...@@ -129,6 +130,20 @@ export default { ...@@ -129,6 +130,20 @@ export default {
yield put({ type: 'setDisabled', payload: false }); yield put({ type: 'setDisabled', payload: false });
yield put({ type: 'setEdit', payload }); yield put({ type: 'setEdit', payload });
}, },
*DuKa(ignored, { call, put }) {
try {
Toast.loading('读卡中...', 0);
const result = yield call(scan);
console.info(result);
if (result) {
yield put({ type: 'setdetailData', payload: result });
}
Toast.loading('读卡完成', 5);
} finally {
Toast.loading('读卡失败', 10);
}
//
},
}, },
reducers: { reducers: {
setPeopPleID(state, { payload }) { setPeopPleID(state, { payload }) {
...@@ -147,6 +162,15 @@ export default { ...@@ -147,6 +162,15 @@ export default {
detailData: payload, detailData: payload,
}; };
}, },
setdetailData(state, { payload: { peopleName, idcard, birthDay, people } }) {
const detailData = {
xingMing: peopleName,
identityCard: idcard,
birthday: birthDay,
minZu: people,
};
return { ...state, detailData };
},
setPeopleList(state, { payload: { arrayData } }) { setPeopleList(state, { payload: { arrayData } }) {
return { ...state, sourceData: [...state.sourceData, ...arrayData] }; return { ...state, sourceData: [...state.sourceData, ...arrayData] };
}, },
......
...@@ -6,19 +6,12 @@ export default { ...@@ -6,19 +6,12 @@ export default {
userName: undefined, userName: undefined,
currentJiDiName: undefined, currentJiDiName: undefined,
jidiList: [], jidiList: [],
language: '',
}, },
subscriptions: { subscriptions: {
setup({ dispatch }) { // eslint-disable-line setup({ dispatch }) { // eslint-disable-line
}, },
}, },
reducers: { reducers: {
setlanguage(state, { payload: language }) {
return {
...state,
language,
};
},
setUserName(state, { payload: userName }) { setUserName(state, { payload: userName }) {
return { return {
...state, ...state,
......
...@@ -4,7 +4,8 @@ ...@@ -4,7 +4,8 @@
import React from 'react'; import React from 'react';
import { createForm } from 'rc-form'; import { createForm } from 'rc-form';
import { View, ScrollView } from 'react-native'; import { View, ScrollView } from 'react-native';
import { List, InputItem, Button, Toast } from 'antd-mobile'; import { List, InputItem, Toast, WhiteSpace } from 'antd-mobile';
import Icon from 'react-native-vector-icons/FontAwesome';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { createAction } from '../../../utils'; import { createAction } from '../../../utils';
...@@ -36,8 +37,22 @@ class DSRInfoDetailScreen extends React.Component { ...@@ -36,8 +37,22 @@ class DSRInfoDetailScreen extends React.Component {
render() { render() {
const { singularData, metas, enableEdit } = this.props.DSRInfoDetail; const { singularData, metas, enableEdit } = this.props.DSRInfoDetail;
const { getFieldProps } = this.props.form; const { getFieldProps } = this.props.form;
if (this.props.DSRInfoDetail.enableEdit === true) {
return ( return (
<ScrollView> <ScrollView>
<WhiteSpace />
<View style={{ flexDirection: 'row', justifyContent: 'space-between' }}>
<Icon.Button
name="id-card"
backgroundColor="#08BBF9"
onPress={() => {
this.props.dispatch({ type: 'DSRInfoDetail/DuKa' });
}}
>
读卡
</Icon.Button>
</View>
<WhiteSpace />
<List> <List>
{ {
metas.map((m) => { metas.map((m) => {
...@@ -54,7 +69,9 @@ class DSRInfoDetailScreen extends React.Component { ...@@ -54,7 +69,9 @@ class DSRInfoDetailScreen extends React.Component {
clear clear
placeholder="请输入" placeholder="请输入"
editable={enableEdit} editable={enableEdit}
ref={(el) => { this.customFocusInst = el; }} ref={(el) => {
this.customFocusInst = el;
}}
> >
姓名 姓名
</InputItem> </InputItem>
...@@ -68,7 +85,9 @@ class DSRInfoDetailScreen extends React.Component { ...@@ -68,7 +85,9 @@ class DSRInfoDetailScreen extends React.Component {
clear clear
placeholder="请输入" placeholder="请输入"
editable={enableEdit} editable={enableEdit}
ref={(el) => { this.customFocusInst = el; }} ref={(el) => {
this.customFocusInst = el;
}}
> >
{m.label} {m.label}
</InputItem> </InputItem>
...@@ -78,12 +97,14 @@ class DSRInfoDetailScreen extends React.Component { ...@@ -78,12 +97,14 @@ class DSRInfoDetailScreen extends React.Component {
{[1].map(() => { {[1].map(() => {
return ( return (
<List.Item> <List.Item>
<View style={{ flexDirection: 'row' }}> <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
<Button onClick={() => { <Icon.Button
this.props.dispatch({ type: 'DSRInfoDetail/DuKa' }); name="save"
}}></Button> backgroundColor="#08BBF9"
<Button style={{ marginRight: 8 }} type="primary" onClick={this.onEdit}>编辑</Button> onPress={this.onSubmit}
<Button style={{ marginRight: 8 }} onClick={this.onSubmit}>保存</Button> >
保存
</Icon.Button>
</View> </View>
</List.Item> </List.Item>
); );
...@@ -91,8 +112,38 @@ class DSRInfoDetailScreen extends React.Component { ...@@ -91,8 +112,38 @@ class DSRInfoDetailScreen extends React.Component {
} }
</List> </List>
</ScrollView> </ScrollView>
); );
} else {
return (
<ScrollView>
<WhiteSpace />
<View style={{ flexDirection: 'row', justifyContent: 'space-between' }}>
<Icon.Button
name="edit"
backgroundColor="#08BBF9"
onPress={this.onEdit}
>
编辑
</Icon.Button>
</View>
<WhiteSpace />
<List>
{
metas.map((m) => {
return (
<List.Item
key={m.key}
extra={singularData[m.key]}
>
{m.label}
</List.Item>
);
})
}
</List>
</ScrollView>
);
}
} }
} }
......
...@@ -39,7 +39,7 @@ class HouseDetail extends Component { ...@@ -39,7 +39,7 @@ class HouseDetail extends Component {
render() { render() {
const { getFieldProps } = this.props.form; const { getFieldProps } = this.props.form;
const { fwLouCeng } = this.props.HouseDetail.singularData; const { fwLouCeng } = this.props.HouseDetail.singularData;
if (this.props.HouseDetail.enableEdit === false) { if (this.props.HouseDetail.enableEdit === true) {
return ( return (
<View> <View>
<List> <List>
......
import React, { Component } from 'react'; import React, { Component } from 'react';
import { View, Text, Image, StyleSheet } from 'react-native'; import { View, Text, Image, StyleSheet } from 'react-native';
import { TabNavigator } from 'react-navigation'; import { TabNavigator } from 'react-navigation';
import Icon from 'react-native-vector-icons/MaterialIcons';
import userInfoPageScreen from './userinfo/index'; import userInfoPageScreen from './userinfo/index';
import fwInfo from './fwInfo'; import fwInfo from './fwInfo';
import peopleInfoErJiScreen from './peopleInfo/index'; import peopleInfoErJiScreen from './peopleInfo/index';
...@@ -17,10 +18,7 @@ const Content = TabNavigator({ ...@@ -17,10 +18,7 @@ const Content = TabNavigator({
tabBarLabel: '房屋信息', tabBarLabel: '房屋信息',
// Note: By default the icon is only shown on iOS. Search the showIcon option below. // Note: By default the icon is only shown on iOS. Search the showIcon option below.
tabBarIcon: () => ( tabBarIcon: () => (
<Image <Icon name="home" size={28} color="#3b5998" />
source={chatsIcon}
style={[styles.icon]}
/>
), ),
}, },
}, },
...@@ -31,10 +29,7 @@ const Content = TabNavigator({ ...@@ -31,10 +29,7 @@ const Content = TabNavigator({
tabBarLabel: '权利人信息', tabBarLabel: '权利人信息',
// Note: By default the icon is only shown on iOS. Search the showIcon option below. // Note: By default the icon is only shown on iOS. Search the showIcon option below.
tabBarIcon: () => ( tabBarIcon: () => (
<Image <Icon name="person" size={28} />
source={chatsIcon}
style={[styles.icon]}
/>
), ),
}, },
}, },
...@@ -66,20 +61,20 @@ const Content = TabNavigator({ ...@@ -66,20 +61,20 @@ const Content = TabNavigator({
), ),
}, },
}, },
UserInfoPageScreen: { // UserInfoPageScreen: {
screen: userInfoPageScreen, // screen: userInfoPageScreen,
navigationOptions: { // navigationOptions: {
lazy: true, // lazy: true,
tabBarLabel: '个人中心', // tabBarLabel: '个人中心',
// Note: By default the icon is only shown on iOS. Search the showIcon option below. // // Note: By default the icon is only shown on iOS. Search the showIcon option below.
tabBarIcon: () => ( // tabBarIcon: () => (
<Image // <Image
source={chatsIcon} // source={chatsIcon}
style={[styles.icon]} // style={[styles.icon]}
/> // />
), // ),
}, // },
}, // },
}, { }, {
lazy: true, lazy: true,
tabBarPosition: 'bottom', tabBarPosition: 'bottom',
......
...@@ -4,8 +4,9 @@ ...@@ -4,8 +4,9 @@
import React from 'react'; import React from 'react';
import { createForm } from 'rc-form'; import { createForm } from 'rc-form';
import { View, ScrollView } from 'react-native'; import { View, ScrollView } from 'react-native';
import { Button, List, InputItem } from 'antd-mobile'; import { Button, List, InputItem, WhiteSpace } from 'antd-mobile';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import Icon from 'react-native-vector-icons/FontAwesome';
import { createAction } from '../../../utils'; import { createAction } from '../../../utils';
@connect(({ peopleInfo }) => ({ peopleInfo })) @connect(({ peopleInfo }) => ({ peopleInfo }))
...@@ -23,114 +24,92 @@ class AddPeopleInfo extends React.Component { ...@@ -23,114 +24,92 @@ class AddPeopleInfo extends React.Component {
} }
}); });
}; };
validateNoNull = (rule, value, callback) => {
if (value) {
callback();
} else {
callback(new Error('At least four charactors for account'));
}
};
onEditBack = () => { onEditBack = () => {
this.props.dispatch(createAction('peopleInfo/onEBack')('clear')); this.props.dispatch(createAction('peopleInfo/onEBack')('clear'));
}; };
render() { render() {
console.log(this.props.peopleInfo);
const { getFieldProps } = this.props.form; const { getFieldProps } = this.props.form;
const { detailData, metas } = this.props.peopleInfo;
console.info(metas);
return ( return (
<ScrollView> <ScrollView>
<WhiteSpace />
<View style={{ flexDirection: 'row', justifyContent: 'space-between' }}>
<Icon.Button
name="id-card"
backgroundColor="#08BBF9"
onPress={() => {
this.props.dispatch({ type: 'peopleInfo/DuKa' });
}}
>
读卡
</Icon.Button>
</View>
<WhiteSpace />
<List> <List>
{
metas.map((m) => {
if (m.required === true) {
return (
<InputItem <InputItem
{...getFieldProps('xingMing', { {...getFieldProps(m.key, {
initialValue: detailData[m.key],
rules: [ rules: [
{ required: true, message: '不允许为空' }, { required: true, message: '不允许为空' },
{ validator: this.validateNoNull },
], ],
})} })}
clear clear
placeholder="" placeholder="请输入"
ref={(el) => { this.customFocusInst = el; }} editable="true"
ref={(el) => {
this.customFocusInst = el;
}}
> >
姓名 姓名
</InputItem> </InputItem>
);
} else {
return (
<InputItem <InputItem
{...getFieldProps('identityCard', { {...getFieldProps(m.key, {
})} initialValue: detailData[m.key],
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
证件号码
</InputItem>
<InputItem
{...getFieldProps('birthday', {
})}
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
出生日期
</InputItem>
<InputItem
{...getFieldProps('guoJi', {
})}
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
国籍
</InputItem>
<InputItem
{...getFieldProps('minZu', {
})}
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
民族
</InputItem>
<InputItem
{...getFieldProps('lianXiDianHua', {
})}
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
联系电话
</InputItem>
<InputItem
{...getFieldProps('lianXiDiZhi', {
})}
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
联系地址
</InputItem>
<InputItem
{...getFieldProps('yuHuZhuGuanXi', {
})}
clear
placeholder=""
ref={(el) => { this.customFocusInst = el; }}
>
与户主关系
</InputItem>
<InputItem
{...getFieldProps('zhengZhiMianMao', {
})} })}
clear clear
placeholder="" placeholder="请输入"
ref={(el) => { this.customFocusInst = el; }} editable="true"
ref={(el) => {
this.customFocusInst = el;
}}
> >
政治面貌 {m.label}
</InputItem> </InputItem>
<InputItem );
{...getFieldProps('hunYinZhuangKuang', { }
})} })}
clear {[1].map(() => {
placeholder="" return (
ref={(el) => { this.customFocusInst = el; }}
>
婚姻状况
</InputItem>
<List.Item> <List.Item>
<View style={{ flexDirection: 'row' }}> <View style={{ flexDirection: 'row', justifyContent: 'center' }}>
<Button style={{ marginRight: 8 }} type="primary" onClick={this.onSubmit}>保存</Button> <Icon.Button
<Button onClick={this.onEditBack}>返回</Button> name="save"
backgroundColor="#08BBF9"
onPress={this.onSubmit}
>
保存
</Icon.Button>
</View> </View>
</List.Item> </List.Item>
);
})
}
</List> </List>
</ScrollView> </ScrollView>
); );
......
import React, { PureComponent } from 'react'; import React, { PureComponent } from 'react';
import { View, StyleSheet, Dimensions, ScrollView, Text, Picker } from 'react-native'; import { View, StyleSheet, Dimensions, ScrollView, Text } from 'react-native';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { List, InputItem } from 'antd-mobile'; import PickerComponent from '../../../components/pickerComponent';
const width = Dimensions.get('window').width; const width = Dimensions.get('window').width;
const height = Dimensions.get('window').height; const height = Dimensions.get('window').height;
...@@ -24,20 +25,7 @@ class UserInfoHomeScreen extends PureComponent { ...@@ -24,20 +25,7 @@ class UserInfoHomeScreen extends PureComponent {
<Text style={{ color: 'white', marginTop: 4 }}>个人信息</Text> <Text style={{ color: 'white', marginTop: 4 }}>个人信息</Text>
</View> </View>
</View> </View>
<List style={{ backgroundColor: 'white' }} className="picker-list"> <PickerComponent />
<Picker
extra="请选择(可选)"
data={district}
title="Areas"
{...getFieldProps('district', {
initialValue: ['340000', '341500', '341502'],
})}
onOk={e => console.log('ok', e)}
onDismiss={e => console.log('dismiss', e)}
>
<List.Item arrow="horizontal">Multiple & cascader</List.Item>
</Picker>
</List>
</View> </View>
</ScrollView> </ScrollView>
</View> </View>
......
...@@ -39,7 +39,7 @@ const config = { ...@@ -39,7 +39,7 @@ const config = {
productId: 'manager-app-sz', productId: 'manager-app-sz',
footerText: '上海铂蓝信息科技有限公司', footerText: '上海铂蓝信息科技有限公司',
contextPath: '', contextPath: '',
apiContextPath: 'http://192.168.1.22:8080/bm', apiContextPath: 'http://14.21.68.149:9089/test',
defaultDateFormat, defaultDateFormat,
defaultTimeFormat, defaultTimeFormat,
defaultDateTimeFormat, defaultDateTimeFormat,
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论