mirror of
https://github.com/BoostIo/Boostnote
synced 2025-12-13 09:46:22 +00:00
266 lines
7.9 KiB
JavaScript
266 lines
7.9 KiB
JavaScript
import React, { PropTypes } from 'react'
|
|
import { connect, Provider } from 'react-redux'
|
|
import linkState from 'boost/linkState'
|
|
import store from 'boost/store'
|
|
import AppSettingTab from './Preference/AppSettingTab'
|
|
import HelpTab from './Preference/HelpTab'
|
|
import FolderSettingTab from './Preference/FolderSettingTab'
|
|
import ContactTab from './Preference/ContactTab'
|
|
import { closeModal } from 'boost/modal'
|
|
|
|
const APP = 'APP'
|
|
const HELP = 'HELP'
|
|
const FOLDER = 'FOLDER'
|
|
const CONTACT = 'CONTACT'
|
|
|
|
class Preferences extends React.Component {
|
|
constructor (props) {
|
|
super(props)
|
|
|
|
this.state = {
|
|
currentTab: APP
|
|
}
|
|
}
|
|
|
|
switchTeam (teamId) {
|
|
this.setState({currentTeamId: teamId})
|
|
}
|
|
|
|
handleNavButtonClick (tab) {
|
|
return e => {
|
|
this.setState({currentTab: tab})
|
|
}
|
|
}
|
|
|
|
render () {
|
|
let content = this.renderContent()
|
|
|
|
let tabs = [
|
|
{target: APP, label: 'Preferences'},
|
|
{target: FOLDER, label: 'Manage folder'},
|
|
{target: CONTACT, label: 'Contact form'}
|
|
]
|
|
|
|
let navButtons = tabs.map(tab => (
|
|
<button key={tab.target} onClick={e => this.handleNavButtonClick(tab.target)(e)} className={this.state.currentTab === tab.target ? 'active' : ''}>{tab.label}</button>
|
|
))
|
|
|
|
return (
|
|
<div className='Preferences modal'>
|
|
<div className='header'>
|
|
<div className='title'>Setting</div>
|
|
<button onClick={e => closeModal()} className='closeBtn'>Done</button>
|
|
</div>
|
|
|
|
<div className='nav'>
|
|
{navButtons}
|
|
</div>
|
|
|
|
{content}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
renderContent () {
|
|
let { folders, dispatch } = this.props
|
|
|
|
switch (this.state.currentTab) {
|
|
case HELP:
|
|
return (<HelpTab/>)
|
|
case FOLDER:
|
|
return (
|
|
<FolderSettingTab
|
|
dispatch={dispatch}
|
|
folders={folders}
|
|
/>
|
|
)
|
|
case CONTACT:
|
|
return (
|
|
<ContactTab/>
|
|
)
|
|
case APP:
|
|
default:
|
|
return (<AppSettingTab/>)
|
|
}
|
|
}
|
|
|
|
// handleProfileSaveButtonClick (e) {
|
|
// let profileState = this.state.profile
|
|
// profileState.userInfo.alert = {
|
|
// type: 'info',
|
|
// message: 'Sending...'
|
|
// }
|
|
// this.setState({profile: profileState}, () => {
|
|
// let input = {
|
|
// profileName: profileState.userInfo.profileName,
|
|
// email: profileState.userInfo.email
|
|
// }
|
|
// api.updateUserInfo(input)
|
|
// .then(res => {
|
|
// let profileState = this.state.profile
|
|
// profileState.userInfo.alert = {
|
|
// type: 'success',
|
|
// message: 'Successfully done!'
|
|
// }
|
|
// this.setState({profile: profileState})
|
|
// })
|
|
// .catch(err => {
|
|
// var message
|
|
// if (err.status != null) {
|
|
// message = err.response.body.message
|
|
// } else if (err.code === 'ECONNREFUSED') {
|
|
// message = 'Can\'t connect to API server.'
|
|
// } else throw err
|
|
|
|
// let profileState = this.state.profile
|
|
// profileState.userInfo.alert = {
|
|
// type: 'error',
|
|
// message: message
|
|
// }
|
|
|
|
// this.setState({profile: profileState})
|
|
// })
|
|
// })
|
|
// }
|
|
|
|
// handlePasswordSaveButton (e) {
|
|
// let profileState = this.state.profile
|
|
|
|
// if (profileState.password.newPassword !== profileState.password.confirmation) {
|
|
// profileState.password.alert = {
|
|
// type: 'error',
|
|
// message: 'Confirmation doesn\'t match'
|
|
// }
|
|
// this.setState({profile: profileState})
|
|
// return
|
|
// }
|
|
|
|
// profileState.password.alert = {
|
|
// type: 'info',
|
|
// message: 'Sending...'
|
|
// }
|
|
|
|
// this.setState({profile: profileState}, () => {
|
|
// let input = {
|
|
// password: profileState.password.currentPassword,
|
|
// newPassword: profileState.password.newPassword
|
|
// }
|
|
// api.updatePassword(input)
|
|
// .then(res => {
|
|
// let profileState = this.state.profile
|
|
// profileState.password.alert = {
|
|
// type: 'success',
|
|
// message: 'Successfully done!'
|
|
// }
|
|
// profileState.password.currentPassword = ''
|
|
// profileState.password.newPassword = ''
|
|
// profileState.password.confirmation = ''
|
|
|
|
// this.setState({profile: profileState})
|
|
// })
|
|
// .catch(err => {
|
|
// var message
|
|
// if (err.status != null) {
|
|
// message = err.response.body.message
|
|
// } else if (err.code === 'ECONNREFUSED') {
|
|
// message = 'Can\'t connect to API server.'
|
|
// } else throw err
|
|
|
|
// let profileState = this.state.profile
|
|
// profileState.password.alert = {
|
|
// type: 'error',
|
|
// message: message
|
|
// }
|
|
// profileState.password.currentPassword = ''
|
|
// profileState.password.newPassword = ''
|
|
// profileState.password.confirmation = ''
|
|
|
|
// this.setState({profile: profileState}, () => {
|
|
// if (this.refs.currentPassword != null) findDOMNode(this.refs.currentPassword).focus()
|
|
// })
|
|
// })
|
|
// })
|
|
// }
|
|
|
|
// renderProfile () {
|
|
// let profileState = this.state.profile
|
|
// return (
|
|
// <div className='content profile'>
|
|
// <div className='section userSection'>
|
|
// <div className='sectionTitle'>User Info</div>
|
|
// <div className='sectionInput'>
|
|
// <label>Profile Name</label>
|
|
// <input valueLink={this.linkState('profile.userInfo.profileName')} type='text'/>
|
|
// </div>
|
|
// <div className='sectionInput'>
|
|
// <label>E-mail</label>
|
|
// <input valueLink={this.linkState('profile.userInfo.email')} type='text'/>
|
|
// </div>
|
|
// <div className='sectionConfirm'>
|
|
// <button onClick={e => this.handleProfileSaveButtonClick(e)}>Save</button>
|
|
|
|
// {this.state.profile.userInfo.alert != null
|
|
// ? (
|
|
// <div className={'alert ' + profileState.userInfo.alert.type}>{profileState.userInfo.alert.message}</div>
|
|
// )
|
|
// : null}
|
|
// </div>
|
|
// </div>
|
|
|
|
// <div className='section passwordSection'>
|
|
// <div className='sectionTitle'>Password</div>
|
|
// <div className='sectionInput'>
|
|
// <label>Current Password</label>
|
|
// <input ref='currentPassword' valueLink={this.linkState('profile.password.currentPassword')} type='password' placeholder='Current Password'/>
|
|
// </div>
|
|
// <div className='sectionInput'>
|
|
// <label>New Password</label>
|
|
// <input valueLink={this.linkState('profile.password.newPassword')} type='password' placeholder='New Password'/>
|
|
// </div>
|
|
// <div className='sectionInput'>
|
|
// <label>Confirmation</label>
|
|
// <input valueLink={this.linkState('profile.password.confirmation')} type='password' placeholder='Confirmation'/>
|
|
// </div>
|
|
// <div className='sectionConfirm'>
|
|
// <button onClick={e => this.handlePasswordSaveButton(e)}>Save</button>
|
|
|
|
// {profileState.password.alert != null
|
|
// ? (
|
|
// <div className={'alert ' + profileState.password.alert.type}>{profileState.password.alert.message}</div>
|
|
// )
|
|
// : null}
|
|
// </div>
|
|
// </div>
|
|
// </div>
|
|
// )
|
|
// }
|
|
|
|
}
|
|
|
|
Preferences.propTypes = {
|
|
folders: PropTypes.array,
|
|
dispatch: PropTypes.func
|
|
}
|
|
|
|
Preferences.prototype.linkState = linkState
|
|
|
|
function remap (state) {
|
|
let { folders, status } = state
|
|
|
|
return {
|
|
folders,
|
|
status
|
|
}
|
|
}
|
|
|
|
let RootComponent = connect(remap)(Preferences)
|
|
export default class PreferencesModal extends React.Component {
|
|
render () {
|
|
return (
|
|
<Provider store={store}>
|
|
<RootComponent/>
|
|
</Provider>
|
|
)
|
|
}
|
|
}
|