1
0
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:
Rokt33r
2015-11-15 20:32:02 +09:00
parent da9d7a4336
commit 26a08fac06
5 changed files with 71 additions and 18 deletions

View File

@@ -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

View File

@@ -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

View File

@@ -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
} }

View File

@@ -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>

View File

@@ -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')