mirror of
https://github.com/BoostIo/Boostnote
synced 2025-12-15 10:46:32 +00:00
new folder modalにcolor select追加
This commit is contained in:
@@ -150,7 +150,7 @@ articleCount = #999
|
|||||||
&:hover
|
&:hover
|
||||||
background-color transparentify(white, 5%)
|
background-color transparentify(white, 5%)
|
||||||
&.active, &:active
|
&.active, &:active
|
||||||
background-color brandColor
|
background-color transparentify(lighten(brandColor, 25%), 70%)
|
||||||
.articleCount
|
.articleCount
|
||||||
color articleCount
|
color articleCount
|
||||||
font-size 12px
|
font-size 12px
|
||||||
|
|||||||
@@ -34,9 +34,29 @@ iptFocusBorderColor = #369DCD
|
|||||||
border-radius 5px
|
border-radius 5px
|
||||||
border solid 1px borderColor
|
border solid 1px borderColor
|
||||||
outline none
|
outline none
|
||||||
margin 100px auto 25px
|
margin 100px auto 15px
|
||||||
&:focus
|
&:focus
|
||||||
border-color iptFocusBorderColor
|
border-color iptFocusBorderColor
|
||||||
|
.colorSelect
|
||||||
|
text-align center
|
||||||
|
.option
|
||||||
|
cursor pointer
|
||||||
|
.FolderMark
|
||||||
|
padding 5px
|
||||||
|
font-size 22px
|
||||||
|
height 33px
|
||||||
|
width 33px
|
||||||
|
overflow hidden
|
||||||
|
line-height 33px
|
||||||
|
transition 0.1s
|
||||||
|
border 1px solid transparent
|
||||||
|
border-radius 5px
|
||||||
|
margin 0 2px
|
||||||
|
&:hover
|
||||||
|
border-color borderColor
|
||||||
|
&.active
|
||||||
|
font-size 28px
|
||||||
|
border-color iptFocusBorderColor
|
||||||
.alert
|
.alert
|
||||||
color infoTextColor
|
color infoTextColor
|
||||||
background-color infoBackgroundColor
|
background-color infoBackgroundColor
|
||||||
@@ -44,7 +64,7 @@ iptFocusBorderColor = #369DCD
|
|||||||
padding 15px 15px
|
padding 15px 15px
|
||||||
width 330px
|
width 330px
|
||||||
border-radius 5px
|
border-radius 5px
|
||||||
margin 0 auto
|
margin 15px auto 0
|
||||||
&.error
|
&.error
|
||||||
color errorTextColor
|
color errorTextColor
|
||||||
background-color errorBackgroundColor
|
background-color errorBackgroundColor
|
||||||
|
|||||||
@@ -3,45 +3,50 @@ import React, { PropTypes } from 'react'
|
|||||||
const BLUE = '#3460C7'
|
const BLUE = '#3460C7'
|
||||||
const LIGHTBLUE = '#2BA5F7'
|
const LIGHTBLUE = '#2BA5F7'
|
||||||
const ORANGE = '#FF8E00'
|
const ORANGE = '#FF8E00'
|
||||||
const YELLOW = '#EAEF31'
|
const YELLOW = '#E8D252'
|
||||||
const GREEN = '#02FF26'
|
const GREEN = '#3FD941'
|
||||||
const DARKGREEN = '#008A59'
|
const DARKGREEN = '#1FAD85'
|
||||||
const RED = '#E10051'
|
const RED = '#E10051'
|
||||||
const PURPLE = '#B013A4'
|
const PURPLE = '#B013A4'
|
||||||
const BRAND_COLOR = '#2BAC8F'
|
|
||||||
|
|
||||||
function getColorByIndex (index) {
|
function getColorByIndex (index) {
|
||||||
switch (index % 8) {
|
switch (index % 8) {
|
||||||
case 0:
|
case 0:
|
||||||
return LIGHTBLUE
|
return RED
|
||||||
case 1:
|
case 1:
|
||||||
return ORANGE
|
return ORANGE
|
||||||
case 2:
|
case 2:
|
||||||
return RED
|
return YELLOW
|
||||||
case 3:
|
case 3:
|
||||||
return GREEN
|
return GREEN
|
||||||
case 4:
|
case 4:
|
||||||
return DARKGREEN
|
return DARKGREEN
|
||||||
case 5:
|
case 5:
|
||||||
return YELLOW
|
return LIGHTBLUE
|
||||||
case 6:
|
case 6:
|
||||||
return BLUE
|
return BLUE
|
||||||
case 7:
|
case 7:
|
||||||
return PURPLE
|
return PURPLE
|
||||||
default:
|
default:
|
||||||
return BRAND_COLOR
|
return DARKGREEN
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default class FolderMark extends React.Component {
|
export default class FolderMark extends React.Component {
|
||||||
render () {
|
render () {
|
||||||
let color = getColorByIndex(this.props.color)
|
let color = getColorByIndex(this.props.color)
|
||||||
|
let className = 'FolderMark fa fa-square fa-fw'
|
||||||
|
if (this.props.className != null) {
|
||||||
|
className += ' active'
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<i className='fa fa-square fa-fw' style={{color: color}}/>
|
<i className={className} style={{color: color}}/>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
FolderMark.propTypes = {
|
FolderMark.propTypes = {
|
||||||
color: PropTypes.number
|
color: PropTypes.number,
|
||||||
|
className: PropTypes.string
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import React, { PropTypes } from 'react'
|
|||||||
import linkState from 'boost/linkState'
|
import linkState from 'boost/linkState'
|
||||||
import { createFolder } from 'boost/actions'
|
import { createFolder } from 'boost/actions'
|
||||||
import store from 'boost/store'
|
import store from 'boost/store'
|
||||||
|
import FolderMark from 'boost/components/FolderMark'
|
||||||
|
|
||||||
export default class CreateNewFolder extends React.Component {
|
export default class CreateNewFolder extends React.Component {
|
||||||
constructor (props) {
|
constructor (props) {
|
||||||
@@ -9,6 +10,7 @@ export default class CreateNewFolder extends React.Component {
|
|||||||
|
|
||||||
this.state = {
|
this.state = {
|
||||||
name: '',
|
name: '',
|
||||||
|
color: Math.round(Math.random() * 7),
|
||||||
alert: null
|
alert: null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -20,9 +22,11 @@ export default class CreateNewFolder extends React.Component {
|
|||||||
handleConfirmButton (e) {
|
handleConfirmButton (e) {
|
||||||
this.setState({alert: null}, () => {
|
this.setState({alert: null}, () => {
|
||||||
let { close } = this.props
|
let { close } = this.props
|
||||||
let name = this.state.name
|
let { name, color } = this.state
|
||||||
|
|
||||||
let input = {
|
let input = {
|
||||||
name
|
name,
|
||||||
|
color
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -38,6 +42,14 @@ export default class CreateNewFolder extends React.Component {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handleColorClick (colorIndex) {
|
||||||
|
return e => {
|
||||||
|
this.setState({
|
||||||
|
color: colorIndex
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
let alert = this.state.alert
|
let alert = this.state.alert
|
||||||
let alertElement = alert != null ? (
|
let alertElement = alert != null ? (
|
||||||
@@ -45,6 +57,21 @@ export default class CreateNewFolder extends React.Component {
|
|||||||
{alert.message}
|
{alert.message}
|
||||||
</p>
|
</p>
|
||||||
) : null
|
) : null
|
||||||
|
let colorIndexes = []
|
||||||
|
for (let i = 0; i < 8; i++) {
|
||||||
|
colorIndexes.push(i)
|
||||||
|
}
|
||||||
|
let colorElements = colorIndexes.map(index => {
|
||||||
|
let className = index === this.state.color
|
||||||
|
? 'active'
|
||||||
|
: null
|
||||||
|
|
||||||
|
return (
|
||||||
|
<span className='option' key={index} onClick={e => this.handleColorClick(index)(e)}>
|
||||||
|
<FolderMark className={className} color={index}/>
|
||||||
|
</span>
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='CreateNewFolder modal'>
|
<div className='CreateNewFolder modal'>
|
||||||
@@ -53,6 +80,9 @@ export default class CreateNewFolder extends React.Component {
|
|||||||
<div className='title'>Create new folder</div>
|
<div className='title'>Create new folder</div>
|
||||||
|
|
||||||
<input className='ipt' type='text' valueLink={this.linkState('name')} placeholder='Enter folder name'/>
|
<input className='ipt' type='text' valueLink={this.linkState('name')} placeholder='Enter folder name'/>
|
||||||
|
<div className='colorSelect'>
|
||||||
|
{colorElements}
|
||||||
|
</div>
|
||||||
{alertElement}
|
{alertElement}
|
||||||
|
|
||||||
<button onClick={e => this.handleConfirmButton(e)} className='confirmBtn'>Create</button>
|
<button onClick={e => this.handleConfirmButton(e)} className='confirmBtn'>Create</button>
|
||||||
|
|||||||
@@ -26,9 +26,7 @@ function folders (state = initialFolders, action) {
|
|||||||
Object.assign(newFolder, {
|
Object.assign(newFolder, {
|
||||||
key: keygen(),
|
key: keygen(),
|
||||||
createdAt: new Date(),
|
createdAt: new Date(),
|
||||||
updatedAt: new Date(),
|
updatedAt: new Date()
|
||||||
// random number (0-7)
|
|
||||||
color: Math.round(Math.random() * 7)
|
|
||||||
})
|
})
|
||||||
|
|
||||||
if (newFolder.length === 0) throw new Error('Folder name is required')
|
if (newFolder.length === 0) throw new Error('Folder name is required')
|
||||||
|
|||||||
Reference in New Issue
Block a user