Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
Alexander Fedyashov committed Jun 1, 2017
1 parent 1a1b9e0 commit 3124e5c
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 30 deletions.
Original file line number Diff line number Diff line change
@@ -1,12 +1,18 @@
/* eslint-disable max-len */

import React from 'react'
import { Container } from 'semantic-ui-react'
import { Dropdown } from 'semantic-ui-react'

const countryOptions = [
{ key: 'af', value: 'af', flag: 'af', text: 'Afghanistan' } ,
{ key: 'ae', value: 'ae', flag: 'ae', text: 'United Arab Emirates' },
{ key: 'us', value: 'us', flag: 'us', text: 'United States' },
]

const ContainerExampleContainer = () => (
<Container>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa strong. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede link mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus. Aenean leo ligula, porttitor eu, consequat vitae, eleifend ac, enim. Aliquam lorem ante, dapibus in, viverra quis, feugiat a, tellus. Phasellus viverra nulla ut metus varius laoreet. Quisque rutrum. Aenean imperdiet. Etiam ultricies nisi vel augue. Curabitur ullamcorper ultricies nisi.</p>
</Container>
const DropdownExampleSearchSelection = () => (
<div>
<Dropdown placeholder='Min 1' fluid search selection options={countryOptions} />
<br />
<Dropdown placeholder='Min 3' fluid search selection minCharacters={3} options={countryOptions} />
</div>
)

export default ContainerExampleContainer
export default DropdownExampleSearchSelection
53 changes: 31 additions & 22 deletions src/modules/Dropdown/Dropdown.js
Original file line number Diff line number Diff line change
Expand Up @@ -418,9 +418,11 @@ export default class Dropdown extends Component {
if (!prevState.focus && this.state.focus) {
debug('dropdown focused')
if (!this.isMouseDown) {
const { openOnFocus } = this.props
const { minCharacters, openOnFocus, search } = this.props
const openable = !search || (search && minCharacters === 1)

debug('mouse is not down, opening')
if (openOnFocus) this.open()
if (openOnFocus && openable) this.open()
}
if (!this.state.open) {
document.addEventListener('keydown', this.openOnArrow)
Expand Down Expand Up @@ -622,29 +624,34 @@ export default class Dropdown extends Component {

handleMouseDown = (e) => {
debug('handleMouseDown()')
const { onMouseDown } = this.props
if (onMouseDown) onMouseDown(e, this.props)

this.isMouseDown = true
_.invoke(this.props, 'onMouseDown', e, this.props)
// Do not access document when server side rendering
if (!isBrowser) return
document.addEventListener('mouseup', this.handleDocumentMouseUp)
if (isBrowser) document.addEventListener('mouseup', this.handleDocumentMouseUp)
}

handleDocumentMouseUp = () => {
debug('handleDocumentMouseUp()')

this.isMouseDown = false
// Do not access document when server side rendering
if (!isBrowser) return
document.removeEventListener('mouseup', this.handleDocumentMouseUp)
if (isBrowser) document.removeEventListener('mouseup', this.handleDocumentMouseUp)
}

handleClick = (e) => {
handleClick = e => {
debug('handleClick()', e)
const { onClick } = this.props
if (onClick) onClick(e, this.props)

const { minCharacters, onClick, search } = this.props
const { open, searchQuery } = this.state

_.invoke(this.props, 'onClick', e, this.props)
// prevent closeOnDocumentClick()
e.stopPropagation()
this.toggle(e)

if(!search) return this.toggle(e)
if(open) return
if(searchQuery.length >= minCharacters || minCharacters === 1) this.open(e)
}

handleItemClick = (e, item) => {
Expand Down Expand Up @@ -681,10 +688,11 @@ export default class Dropdown extends Component {

handleFocus = (e) => {
debug('handleFocus()')
const { onFocus } = this.props
const { focus } = this.state

if (focus) return
if (onFocus) onFocus(e, this.props)

_.invoke(this.props, 'onFocus', e, this.props)
this.setState({ focus: true })
}

Expand Down Expand Up @@ -717,16 +725,17 @@ export default class Dropdown extends Component {
const newQuery = e.target.value

if (onSearchChange) onSearchChange(e, newQuery)
this.setState({
selectedIndex: 0,
searchQuery: newQuery,
})

if (newQuery.length >= minCharacters) {
// open search dropdown on search query
if (search && newQuery && !open) this.open()

this.setState({
selectedIndex: 0,
searchQuery: newQuery,
})
if(search && newQuery && open && newQuery.length < minCharacters) {
this.close()
return
}
// open search dropdown on search query
if (search && newQuery && !open && newQuery.length >= minCharacters) this.open()
}

// ----------------------------------------
Expand Down

0 comments on commit 3124e5c

Please sign in to comment.