diff options
author | tschicke-brown <tyler_schicke@brown.edu> | 2019-03-02 23:21:31 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-03-02 23:21:31 -0500 |
commit | 77dc4aa8b5033d8c7896809d1417ed8305de1421 (patch) | |
tree | ba4e62f7d7cfe1b50fd20a90a1d5cad803a29c32 /src/client/views/ContextMenu.tsx | |
parent | f1be2fc29ea59c05a3ece851df3ed72adb07a0c2 (diff) | |
parent | 09928503be98d605052fba65dcd2f91f9b056f23 (diff) |
Merge pull request #16 from browngraphicslab/contextMenu
Context menu
Diffstat (limited to 'src/client/views/ContextMenu.tsx')
-rw-r--r-- | src/client/views/ContextMenu.tsx | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/client/views/ContextMenu.tsx b/src/client/views/ContextMenu.tsx index 9459d45f8..fcb934860 100644 --- a/src/client/views/ContextMenu.tsx +++ b/src/client/views/ContextMenu.tsx @@ -12,6 +12,8 @@ export class ContextMenu extends React.Component { @observable private _pageX: number = 0; @observable private _pageY: number = 0; @observable private _display: string = "none"; + @observable private _searchString: string = ""; + private ref: React.RefObject<HTMLDivElement>; @@ -45,6 +47,8 @@ export class ContextMenu extends React.Component { this._pageX = x this._pageY = y + this._searchString = ""; + this._display = "flex" } @@ -62,10 +66,18 @@ export class ContextMenu extends React.Component { render() { return ( <div className="contextMenu-cont" style={{ left: this._pageX, top: this._pageY, display: this._display }} ref={this.ref}> - {this._items.map(prop => { + <input className="contextMenu-item" type="text" placeholder="Search . . ." value={this._searchString} onChange={this.onChange}></input> + {this._items.filter(prop => { + return prop.description.toLowerCase().indexOf(this._searchString.toLowerCase()) !== -1; + }).map(prop => { return <ContextMenuItem {...prop} key={prop.description} /> })} </div> ) } + + @action + onChange = (e: React.ChangeEvent<HTMLInputElement>) => { + this._searchString = e.target.value; + } }
\ No newline at end of file |