2018-08-13 10:58:37 +08:00
|
|
|
snippet reactConnectedRoute "React template" b
|
|
|
|
import React from 'react'
|
|
|
|
import { connect } from 'react-redux'
|
|
|
|
import { isLogin } from 'utils/self'
|
|
|
|
import { Redirect, Route } from 'react-router-dom'
|
|
|
|
|
|
|
|
export default connect((state, ownProps) => {
|
|
|
|
const { self } = state
|
|
|
|
return { self }
|
|
|
|
})(({ component: Component, ...rest }) => {
|
|
|
|
const { self } = rest
|
|
|
|
return <Route
|
|
|
|
{...rest}
|
|
|
|
render={props => isLogin(self) ? <Component {...props} /> : <Redirect
|
|
|
|
to={{
|
|
|
|
pathname: '/login',
|
|
|
|
state: { from: props.location }
|
|
|
|
}} />
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
})
|
|
|
|
endsnippet
|
|
|
|
|
2017-04-09 03:28:56 +08:00
|
|
|
snippet reactComponent "React template" b
|
|
|
|
import React, { Component } from 'react'
|
2017-03-10 17:14:30 +08:00
|
|
|
|
2017-04-09 03:28:56 +08:00
|
|
|
export default class extends Component {
|
2017-03-10 17:14:30 +08:00
|
|
|
render () {
|
|
|
|
}
|
|
|
|
}
|
2017-04-09 03:28:56 +08:00
|
|
|
endsnippet
|
2017-03-10 17:14:30 +08:00
|
|
|
|
2017-04-09 03:28:56 +08:00
|
|
|
snippet reactConnect "React template" b
|
|
|
|
import component from './component'
|
|
|
|
import { connect } from 'react-redux'
|
2017-03-10 17:14:30 +08:00
|
|
|
|
2017-04-09 03:28:56 +08:00
|
|
|
export default connect((state, ownProps) => ({
|
|
|
|
}), {
|
|
|
|
})(component)
|
2017-03-10 17:14:30 +08:00
|
|
|
endsnippet
|
|
|
|
|
|
|
|
snippet TODO "Javascript Todo" b
|
|
|
|
// TODO: ${1:desc} `echo $USER` `!v strftime("%c")` ${2}
|
|
|
|
endsnippet
|
|
|
|
|
|
|
|
snippet connect "react redux connect" b
|
|
|
|
export default connect((state, ownProps) => {
|
|
|
|
return {
|
|
|
|
}
|
|
|
|
})($1)
|
|
|
|
endsnippet
|
|
|
|
|
|
|
|
snippet Card "Default Expandable Card" b
|
|
|
|
<Card initiallyExpanded={false} className="MT-5">
|
|
|
|
<CardTitle showExpandableButton title="$1" />
|
|
|
|
<CardText expandable>
|
|
|
|
</CardText>
|
|
|
|
<CardActions expandable>
|
|
|
|
<RaisedButton primary label="保存" onTouchTap={$2} />
|
|
|
|
</CardActions>
|
|
|
|
</Card>
|
|
|
|
endsnippet
|
|
|
|
|
|
|
|
snippet redux "redux" b
|
|
|
|
export const SET_${1/\w/\u$0/g} = 'SET_${1/\w/\u$0/g}'
|
|
|
|
import {store} from 'redux/store'
|
|
|
|
import {Map} from 'immutable'
|
|
|
|
export default function (${1} = Map({}), action) {
|
|
|
|
// let {$1Id} = action
|
|
|
|
switch (action.type) {
|
|
|
|
case SET_${1/\w/\u$0/g}:
|
|
|
|
return action.$1
|
|
|
|
default:
|
|
|
|
return $1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function set${1/\w+\s*/\u$0/} ($1) {
|
|
|
|
store.dispatch({
|
|
|
|
type: SET_${1/\w/\u$0/g},
|
|
|
|
$1
|
|
|
|
})
|
|
|
|
}
|
|
|
|
endsnippet
|