diff options
| author | Andy Rickert <andrew_rickert@brown.edu> | 2020-06-25 17:23:43 -0400 | 
|---|---|---|
| committer | Andy Rickert <andrew_rickert@brown.edu> | 2020-06-25 17:23:43 -0400 | 
| commit | 7a291cbffb9e609633759cfff8b459e1a32b4fc3 (patch) | |
| tree | e43ec88857c1201b7e2b9c56353253ab9b1e09d4 /src/client/views/nodes/formattedText/FormattedTextBox.tsx | |
| parent | a8d9fb68b14a5c89a3186e49ff28bbfa2cd9978e (diff) | |
bugfixing search, refreshing docs, ghost buckets, etc.
Diffstat (limited to 'src/client/views/nodes/formattedText/FormattedTextBox.tsx')
| -rw-r--r-- | src/client/views/nodes/formattedText/FormattedTextBox.tsx | 15 | 
1 files changed, 9 insertions, 6 deletions
| diff --git a/src/client/views/nodes/formattedText/FormattedTextBox.tsx b/src/client/views/nodes/formattedText/FormattedTextBox.tsx index 6b522f6d1..ca7db2cd4 100644 --- a/src/client/views/nodes/formattedText/FormattedTextBox.tsx +++ b/src/client/views/nodes/formattedText/FormattedTextBox.tsx @@ -261,20 +261,23 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp              let tr = this._editorView.state.tr;              const flattened: TextSelection[] = [];              res.map(r => r.map(h => flattened.push(h))); + +             +            const lastSel = Math.min(flattened.length - 1, this._searchIndex); +            flattened.forEach((h: TextSelection, ind: number) => tr = tr.addMark(h.from, h.to, ind === lastSel ? activeMark : mark)); +            this._searchIndex = ++this._searchIndex > flattened.length - 1 ? 0 : this._searchIndex; +            this._editorView.dispatch(tr.setSelection(new TextSelection(tr.doc.resolve(flattened[lastSel].from), tr.doc.resolve(flattened[lastSel].to))).scrollIntoView()); +             +            console.log(this._searchIndex, length);              if (this._searchIndex>1){                  this._searchIndex+=-2;              }              else if (this._searchIndex===1){                  this._searchIndex=length-1;              } -            else if (this._searchIndex===0){ +            else if (this._searchIndex===0 && length!==1){                  this._searchIndex=length-2;              } -             -            const lastSel = Math.min(flattened.length - 1, this._searchIndex); -            flattened.forEach((h: TextSelection, ind: number) => tr = tr.addMark(h.from, h.to, ind === lastSel ? activeMark : mark)); -            this._searchIndex = ++this._searchIndex > flattened.length - 1 ? 0 : this._searchIndex; -            this._editorView.dispatch(tr.setSelection(new TextSelection(tr.doc.resolve(flattened[lastSel].from), tr.doc.resolve(flattened[lastSel].to))).scrollIntoView());              let index = this._searchIndex;              Doc.GetProto(this.dataDoc).searchIndex = index; | 
