Commit ca0afd94 by wong.peiyi

添加mobx、Inversify

parent 88754c62
...@@ -7,16 +7,17 @@ ...@@ -7,16 +7,17 @@
*/ */
import React, { Component } from 'react' import React, { Component } from 'react'
import { Text, TextInput, View } from 'react-native' import { Text, TextInput, View } from 'react-native'
import { Provider } from 'react-redux'
import CodePush from 'react-native-code-push' import CodePush from 'react-native-code-push'
import configureStore from './app/store/configureStore'
// 旧版本,之前的版本用这个打包 // 旧版本,之前的版本用这个打包
// import { Provider } from 'react-redux'
// import configureStore from './app/store/configureStore'
// import Router from './app/Router' // import Router from './app/Router'
// const store = configureStore()
// 重构后版本, 计划从2.0.0开始 // 重构后版本, 计划从2.0.0开始
import { Provider } from 'mobx-react'
import Router from './src/Router' import Router from './src/Router'
import stores from './src/stores'
const store = configureStore()
// 字体不随系统字体变化 首字母不大写 // 字体不随系统字体变化 首字母不大写
Text.defaultProps = Object.assign({}, Text.defaultProps, { allowFontScaling: false }) Text.defaultProps = Object.assign({}, Text.defaultProps, { allowFontScaling: false })
...@@ -77,7 +78,7 @@ class App extends Component { ...@@ -77,7 +78,7 @@ class App extends Component {
render() { render() {
return ( return (
<Provider store={store}> <Provider {...stores}>
<Router /> <Router />
</Provider> </Provider>
) )
......
...@@ -5,6 +5,7 @@ module.exports = { ...@@ -5,6 +5,7 @@ module.exports = {
"root": ["./app"], "root": ["./app"],
"extensions": [".js", ".jsx", ".ts", ".tsx", ".ios.js", ".android.js"] "extensions": [".js", ".jsx", ".ts", ".tsx", ".ios.js", ".android.js"]
}], }],
["@babel/plugin-proposal-decorators", { "legacy": true }],
"@babel/plugin-transform-runtime", "@babel/plugin-transform-runtime",
] ]
}; };
...@@ -5,8 +5,15 @@ ...@@ -5,8 +5,15 @@
* @format * @format
*/ */
module.exports = { const { getDefaultConfig } = require('metro-config')
module.exports = (async () => {
const {
resolver: { sourceExts },
} = await getDefaultConfig()
return {
transformer: { transformer: {
babelTransformerPath: require.resolve('react-native-stylus-transformer'),
getTransformOptions: async () => ({ getTransformOptions: async () => ({
transform: { transform: {
experimentalImportSupport: false, experimentalImportSupport: false,
...@@ -14,4 +21,8 @@ module.exports = { ...@@ -14,4 +21,8 @@ module.exports = {
}, },
}), }),
}, },
}; resolver: {
sourceExts: [...sourceExts, 'styl'],
},
}
})()
...@@ -8,7 +8,12 @@ ...@@ -8,7 +8,12 @@
"test": "jest" "test": "jest"
}, },
"dependencies": { "dependencies": {
"@types/ramda": "^0.27.39", "@babel/plugin-proposal-decorators": "^7.13.15",
"@react-native-community/async-storage": "^1.12.1",
"inversify": "^5.0.5",
"mobx": "^5.0.0",
"mobx-persist": "^0.4.1",
"mobx-react": "~6.0.0",
"moment": "2.29.1", "moment": "2.29.1",
"ramda": "^0.27.1", "ramda": "^0.27.1",
"react": "16.8.3", "react": "16.8.3",
...@@ -29,6 +34,7 @@ ...@@ -29,6 +34,7 @@
"redux": "4.0.1", "redux": "4.0.1",
"redux-persist": "5.10.0", "redux-persist": "5.10.0",
"redux-thunk": "2.3.0", "redux-thunk": "2.3.0",
"reflect-metadata": "^0.1.13",
"rn-fetch-blob": "0.12.0" "rn-fetch-blob": "0.12.0"
}, },
"devDependencies": { "devDependencies": {
...@@ -36,6 +42,7 @@ ...@@ -36,6 +42,7 @@
"@babel/plugin-transform-runtime": "^7.13.10", "@babel/plugin-transform-runtime": "^7.13.10",
"@babel/runtime": "^7.4.5", "@babel/runtime": "^7.4.5",
"@types/jest": "^26.0.22", "@types/jest": "^26.0.22",
"@types/ramda": "^0.27.39",
"@types/react": "^17.0.3", "@types/react": "^17.0.3",
"@types/react-native": "^0.64.2", "@types/react-native": "^0.64.2",
"@types/react-test-renderer": "^17.0.1", "@types/react-test-renderer": "^17.0.1",
...@@ -45,6 +52,7 @@ ...@@ -45,6 +52,7 @@
"jetifier": "^1.6.6", "jetifier": "^1.6.6",
"metro-react-native-babel-preset": "^0.65.2", "metro-react-native-babel-preset": "^0.65.2",
"react-native-gesture-handler": "^1.10.3", "react-native-gesture-handler": "^1.10.3",
"react-native-postcss-transformer": "^1.2.4",
"react-native-stylus-transformer": "^1.2.0", "react-native-stylus-transformer": "^1.2.0",
"react-test-renderer": "16.8.3", "react-test-renderer": "16.8.3",
"stylus": "^0.54.8", "stylus": "^0.54.8",
......
...@@ -8,7 +8,7 @@ import { ...@@ -8,7 +8,7 @@ import {
} from 'react-navigation' } from 'react-navigation'
import { font_family_regular, first_text_color } from './assets/styles/base' import { font_family_regular, first_text_color } from './assets/styles/base'
import Resolution from './components/common/Resolution' import Resolution from './components/common/Resolution'
import Home from './pages/Home' import Home from './pages/index'
import Mine from './pages/Mine' import Mine from './pages/Mine'
import Signin from './pages/Signin' import Signin from './pages/Signin'
......
import 'reflect-metadata'
import { Container } from 'inversify'
import { TYPES } from './types'
import Store from '../stores/store'
const container = new Container({ defaultScope: 'Singleton' })
container.bind<Store>(TYPES.Store).to(Store)
export default container
export const TYPES = {
Store: Symbol.for('store'),
}
.index
&-text
font-size 18px
&-bg
background-color #f00
import React, { Component } from 'react' import React, { Component } from 'react'
import { View, Text, TouchableHighlight } from 'react-native' import { View, Text, TouchableHighlight } from 'react-native'
import slashScreen from 'react-native-splash-screen' import slashScreen from 'react-native-splash-screen'
import Resolution from '../components/common/Resolution' import { observer, inject } from 'mobx-react'
import Resolution from '../../components/common/Resolution'
import { g } from '../../utils/utils'
import styles from './index.styl'
class Home extends Component { type IProps = {
store: {
count: number
inc: Function
}
}
class Index extends Component<IProps> {
componentDidMount() { componentDidMount() {
slashScreen.hide() slashScreen.hide()
const { navigation } = this.props
// if (true) { const { navigation, store } = this.props
// navigation.navigate('Signin') this.timer = setInterval(() => {
// } // store.inc()
}, 1000)
}
componentWillUnmount() {
clearInterval(this.timer)
} }
render() { render() {
const { navigation } = this.props const { navigation, store } = this.props
return ( return (
<View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}> <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
<TouchableHighlight <TouchableHighlight
...@@ -21,17 +36,19 @@ class Home extends Component { ...@@ -21,17 +36,19 @@ class Home extends Component {
navigation.navigate('Signin', {}) navigation.navigate('Signin', {})
}} }}
> >
<Text style={{ fontSize: 18 }}>Home Screen</Text> <Text style={g(styles, ['index-text', 'index-bg'])}>count: {store.count}</Text>
</TouchableHighlight> </TouchableHighlight>
<TouchableHighlight <TouchableHighlight
onPress={() => { onPress={() => {
navigation.navigate('Signin', {}) navigation.navigate('Signin', {})
}} }}
> >
<Text style={{ fontSize: 18 }}>Home Screen</Text> <Text style={{ fontSize: 18 }}>Home Screen Heloo</Text>
</TouchableHighlight> </TouchableHighlight>
</View> </View>
) )
} }
} }
export default Home
export default inject('store')(observer(Index))
import container from '../inversify'
import { TYPES } from '../inversify/types'
import { AsyncStorage } from 'react-native'
import { create } from 'mobx-persist'
const store = container.get<any>(TYPES.Store)
const hydrate = create({
storage: AsyncStorage,
jsonify: true,
debounce: 0,
})
hydrate('store', store)
export default { store }
import { observable, action, reaction } from 'mobx'
import { persist } from 'mobx-persist'
import { injectable } from 'inversify'
@injectable()
export default class Store {
@persist @observable count: number = 0
@action
inc() {
this.count = this.count + 1
}
}
File mode changed
import * as R from 'ramda'
export const isBlank = R.anyPass([R.isNil, R.isEmpty])
export const isNotBlank = R.complement(isBlank)
/**
* 样式对象辅助函数
* @param styles 样式
* @param cls 类名
* @returns 样式对象
*/
export const getStyles = (styles: any, ...cls: any[]) => {
let clses: any = []
if (isNotBlank(styles) && isNotBlank(cls)) {
clses = R.compose(
R.concat(clses),
R.map((key: any) => {
if (R.type(key) === 'Array') {
return getStyles(styles, ...key)
}
return [styles[key]]
})
)(cls)
}
return clses
}
export const g = getStyles
...@@ -4,18 +4,14 @@ ...@@ -4,18 +4,14 @@
"allowSyntheticDefaultImports": true, "allowSyntheticDefaultImports": true,
"esModuleInterop": true, "esModuleInterop": true,
"isolatedModules": true, "isolatedModules": true,
"experimentalDecorators": true,
"jsx": "react", "jsx": "react",
"lib": ["es6"], "lib": ["es6"],
"moduleResolution": "node", "moduleResolution": "node",
"noEmit": true, "noEmit": true,
"strict": true, "strict": true,
"target": "esnext", "target": "esnext",
"rootDir": ".", "rootDir": "."
}, },
"exclude": [ "exclude": ["node_modules", "babel.config.js", "metro.config.js", "jest.config.js"]
"node_modules",
"babel.config.js",
"metro.config.js",
"jest.config.js"
]
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment