diff options
| author | Andy Rickert <andrew_rickert@brown.edu> | 2020-05-12 23:02:23 -0700 | 
|---|---|---|
| committer | Andy Rickert <andrew_rickert@brown.edu> | 2020-05-12 23:02:23 -0700 | 
| commit | a1d6cf23a902215b91433d26724a75a1844bd4dd (patch) | |
| tree | cf0218811394785e2dce566d32aeccf313d38133 /src | |
| parent | 9ad062907d38a7a853ba89fa31433380ae3cd7b3 (diff) | |
setting up facets
Diffstat (limited to 'src')
| -rw-r--r-- | src/client/util/SearchUtil.ts | 2 | ||||
| -rw-r--r-- | src/client/views/search/SearchBox.tsx | 63 | ||||
| -rw-r--r-- | src/client/views/search/SearchItem.tsx | 11 | ||||
| -rw-r--r-- | src/server/authentication/models/current_user_utils.ts | 1 | 
4 files changed, 54 insertions, 23 deletions
| diff --git a/src/client/util/SearchUtil.ts b/src/client/util/SearchUtil.ts index 6501da34a..c2be385ae 100644 --- a/src/client/util/SearchUtil.ts +++ b/src/client/util/SearchUtil.ts @@ -35,7 +35,9 @@ export namespace SearchUtil {      export async function Search(query: string, returnDocs: boolean, options: SearchParams = {}) {          query = query || "*"; //If we just have a filter query, search for * as the query          const rpquery = Utils.prepend("/dashsearch"); +        console.log(query);          const gotten = await rp.get(rpquery, { qs: { ...options, q: query } }); +        console.log(gotten);          const result: IdSearchResult = gotten.startsWith("<") ? { ids: [], docs: [], numFound: 0, lines: [] } : JSON.parse(gotten);          if (!returnDocs) {              return result; diff --git a/src/client/views/search/SearchBox.tsx b/src/client/views/search/SearchBox.tsx index e784580e5..632bcd211 100644 --- a/src/client/views/search/SearchBox.tsx +++ b/src/client/views/search/SearchBox.tsx @@ -116,12 +116,26 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc          super(props);          SearchBox.Instance = this;          this.resultsScrolled = this.resultsScrolled.bind(this); +        this.rootDoc._viewType = CollectionViewType.Stacking; + +       new PrefetchProxy(Docs.Create.SearchItemBoxDocument({ title: "search item template",  +       backgroundColor: "transparent", _xMargin: 5, _height: 46, isTemplateDoc: true, isTemplateForField: "data" })); + + +        if (!this.searchItemTemplate) { // create exactly one presElmentBox template to use by any and all presentations. +            Doc.UserDoc().searchItemTemplate = new PrefetchProxy(Docs.Create.SearchItemBoxDocument({ title: "search item template", backgroundColor: "transparent", _xMargin: 5, _height: 46, isTemplateDoc: true, isTemplateForField: "data" })); +            // this script will be called by each presElement to get rendering-specific info that the PresBox knows about but which isn't written to the PresElement +            // this is a design choice -- we could write this data to the presElements which would require a reaction to keep it up to date, and it would prevent +            // the preselement docs from being part of multiple presentations since they would all have the same field, or we'd have to keep per-presentation data +            // stored on each pres element.   +            (this.searchItemTemplate as Doc).lookupField = ScriptField.MakeFunction("lookupSearchBoxField(container, field, data)", +                { field: "string", data: Doc.name, container: Doc.name }); +        }      }      @observable setupButtons =false;      componentDidMount = () => {          console.log(this.setupButtons);          if (this.setupButtons==false){ -        console.log("Yuh");              this.setupDocTypeButtons();              this.setupKeyButtons();              this.setupDefaultButtons(); @@ -144,7 +158,7 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc              this.newAssign=false;              });              runInAction(() => { -                this._searchString = StrCast(sq); +                this.layoutDoc._searchString = StrCast(sq);                  this.submitSearch();              });          } @@ -156,7 +170,7 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc      @action.bound      onChange(e: React.ChangeEvent<HTMLInputElement>) { -        this._searchString = e.target.value; +        this.layoutDoc._searchString = e.target.value;          this._openNoResults = false;          this._results = []; @@ -341,9 +355,9 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc      @action      submitSearch = async () => { -        console.log(this._searchString); +        console.log(StrCast(this.layoutDoc._searchString));          this.dataDoc[this.fieldKey] = new List<Doc>([]); -        const query = this._searchString; +        const query = StrCast(this.layoutDoc._searchString);          this.getFinalQuery(query);          this._results = [];          this._resultsSet.clear(); @@ -438,7 +452,7 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc      collectionRef = React.createRef<HTMLSpanElement>();      startDragCollection = async () => { -        const res = await this.getAllResults(this.getFinalQuery(this._searchString)); +        const res = await this.getAllResults(this.getFinalQuery(StrCast(this.layoutDoc._searchString)));          const filtered = this.filterDocsByType(res.docs);          const docs = filtered.map(doc => {              const isProto = Doc.GetT(doc, "isPrototype", "boolean", true); @@ -478,7 +492,7 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc              basicWordStatus: this._basicWordStatus,              icons: this._icons,          } -        return Docs.Create.SearchDocument({ _autoHeight: true, title: this._searchString, filterQuery: filter, searchQuery: this._searchString }); +        return Docs.Create.SearchDocument({ _autoHeight: true, title: StrCast(this.layoutDoc._searchString), filterQuery: filter, searchQuery: StrCast(this.layoutDoc._searchString) });      }      @action.bound @@ -550,16 +564,17 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc                  if (this._isSearch[i] !== "search") {                      let result: [Doc, string[], string[]] | undefined = undefined;                      if (i >= this._results.length) { -                        this.getResults(this._searchString); +                        this.getResults(StrCast(this.layoutDoc._searchString));                          if (i < this._results.length) result = this._results[i];                          if (result) {                              const highlights = Array.from([...Array.from(new Set(result[1]).values())]); -                            result[0].query=this._searchString; +                            result[0].query=StrCast(this.layoutDoc._searchString);                              //Make alias                              result[0].lines=new List<string>(result[2]); -                            result[0].highlighting=new List<string>(highlights); +                            result[0].highlighting=highlights.join(", "); -                            this._visibleElements[i] = <SearchItem {...this.props} doc={result[0]} lines={result[2]} highlighting={highlights} />; +                            this._visibleDocuments[i] = result[0]; +                            //<SearchItem {...this.props} doc={result[0]} lines={result[2]} highlighting={highlights} />;                              result[0].targetDoc=result[0];                              Doc.AddDocToList(this.dataDoc, this.props.fieldKey, result[0]);                              this._isSearch[i] = "search"; @@ -569,11 +584,12 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc                          result = this._results[i];                          if (result) {                              const highlights = Array.from([...Array.from(new Set(result[1]).values())]); -                            result[0].query=this._searchString; +                            result[0].query=StrCast(this.layoutDoc._searchString);                              result[0].lines=new List<string>(result[2]); -                            result[0].highlighting=new List<string>(highlights); +                            result[0].highlighting=highlights.join(", "); -                            this._visibleElements[i] = <SearchItem {...this.props} doc={result[0]} lines={result[2]} highlighting={highlights} />; +                            //this._visibleElements[i] = <SearchItem {...this.props} doc={result[0]} lines={result[2]} highlighting={highlights} />; +                            this._visibleDocuments[i]=result[0];                              result[0].targetDoc=result[0];                              Doc.AddDocToList(this.dataDoc, this.props.fieldKey, result[0])                              this._isSearch[i] = "search"; @@ -901,7 +917,9 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc          });          doc.defaultButtons= dragCreators;      } -    childLayoutTemplate = () => this.layoutDoc._viewType === CollectionViewType.Stacking ? Cast(Doc.UserDoc().searchItemTemplate, Doc, null) : undefined; +    @computed get searchItemTemplate() { return Cast(Doc.UserDoc().searchItemTemplate, Doc, null); } + +    childLayoutTemplate = () => this.layoutDoc._viewType === CollectionViewType.Stacking ? this.searchItemTemplate: undefined;      getTransform = () => {      return this.props.ScreenToLocalTransform().translate(-5, -65);// listBox padding-left and pres-box-cont minHeight      } @@ -923,10 +941,10 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc          return (              <div style={{pointerEvents:"all"}}className="searchBox-container">                  <div className="searchBox-bar"> -                    <span className="searchBox-barChild searchBox-collection" onPointerDown={SetupDrag(this.collectionRef, () => this._searchString ? this.startDragCollection() : undefined)} ref={this.collectionRef} title="Drag Results as Collection"> +                    <span className="searchBox-barChild searchBox-collection" onPointerDown={SetupDrag(this.collectionRef, () => StrCast(this.layoutDoc._searchString) ? this.startDragCollection() : undefined)} ref={this.collectionRef} title="Drag Results as Collection">                          <FontAwesomeIcon icon="object-group" size="lg" />                      </span> -                    <input value={this._searchString} onChange={this.onChange} type="text" placeholder="Search..." id="search-input" ref={this.inputRef} +                    <input value={StrCast(this.layoutDoc._searchString)} onChange={this.onChange} type="text" placeholder="Search..." id="search-input" ref={this.inputRef}                          className="searchBox-barChild searchBox-input" onPointerDown={this.openSearch} onKeyPress={this.enter} onFocus={this.openSearch}                          style={{ width: this._searchbarOpen ? "500px" : "100px" }} />                      <button className="searchBox-barChild searchBox-filter" style={{transform:"none"}} title="Advanced Filtering Options" onClick={() => this.handleFilterChange()}><FontAwesomeIcon icon="ellipsis-v" color="white" /></button> @@ -980,4 +998,13 @@ export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDoc  //     // const dv = DocumentManager.Instance.getD  ocumentView(doc);  //     // if (dv?.props.Document.layoutKey === layoutKey) dv?.switchViews(otherKey !== "layout", otherKey.replace("layout_", ""));  //     // else dv?.switchViews(true, layoutKey.replace("layout_", "")); -// });
\ No newline at end of file +// }); + +Scripting.addGlobal(function lookupSearchBoxField(container: Doc, field: string, data: Doc) { +    // if (field === 'indexInPres') return DocListCast(container[StrCast(container.presentationFieldKey)]).indexOf(data); +    // if (field === 'presCollapsedHeight') return container._viewType === CollectionViewType.Stacking ? 50 : 46; +    // if (field === 'presStatus') return container.presStatus; +    // if (field === '_itemIndex') return container._itemIndex; +        if (field == "query") return container._searchString; +    return undefined; +});
\ No newline at end of file diff --git a/src/client/views/search/SearchItem.tsx b/src/client/views/search/SearchItem.tsx index 28874ede0..c3010e6c4 100644 --- a/src/client/views/search/SearchItem.tsx +++ b/src/client/views/search/SearchItem.tsx @@ -144,21 +144,23 @@ export class SearchItem extends ViewBoxBaseComponent<FieldViewProps, SearchSchem      @observable _selected: boolean = false;      onClick = () => { -        // I dont think this is the best functionality because clicking the name of the collection does that. Change it back if you'd like          DocumentManager.Instance.jumpToDocument(this.targetDoc, false);      }      @observable _useIcons = true;      @observable _displayDim = 50; +    @computed get query() { return StrCast(this.lookupField("query")); } +      componentDidMount() { -        Doc.SetSearchQuery(StrCast(this.targetDoc.query)); + +        console.log(this.query); +        Doc.SetSearchQuery(this.query);          this.targetDoc.searchMatch = true;      }      componentWillUnmount() {          this.targetDoc.searchMatch = undefined;      } -    //@computed      @action      public DocumentIcon() {          const layoutresult = StrCast(this.targetDoc.type); @@ -308,7 +310,8 @@ export class SearchItem extends ViewBoxBaseComponent<FieldViewProps, SearchSchem                  <div className="searchItem-body" onClick={this.onClick}>                      <div className="searchItem-title-container">                          <div className="searchItem-title">{StrCast(this.targetDoc.title)}</div> -                        {/* <div className="searchItem-highlighting">{this.props.highlighting!.length ? "Matched fields:" + this.targetDoc.highlighting!.join(", ") : this.props.lines.length ? this.props.lines[0] : ""}</div> */} +                        <div className="searchItem-highlighting">{StrCast(this.targetDoc.highlighting).length ? "Matched fields:" + StrCast(this.targetDoc.highlighting) : //this.props.lines.length ? this.props.lines[0] :  +                        ""}</div>                          {/* {this.props.lines!.filter((m, i) => i).map((l, i) => <div id={i.toString()} className="searchItem-highlighting">`${l}`</div>)} */}                      </div>                  </div> diff --git a/src/server/authentication/models/current_user_utils.ts b/src/server/authentication/models/current_user_utils.ts index 782582930..bc024356d 100644 --- a/src/server/authentication/models/current_user_utils.ts +++ b/src/server/authentication/models/current_user_utils.ts @@ -633,7 +633,6 @@ export class CurrentUserUtils {      // the initial presentation Doc to use      static setupDefaultPresentation(doc: Doc) { -        doc.searchItemTemplate = new PrefetchProxy(Docs.Create.SearchItemBoxDocument({ title: "search item template", backgroundColor: "transparent", _xMargin: 5, _height: 46, isTemplateDoc: true, isTemplateForField: "data" }));          if (doc["template-presentation"] === undefined) {              doc["template-presentation"] = new PrefetchProxy(Docs.Create.PresElementBoxDocument({                  title: "pres element template", backgroundColor: "transparent", _xMargin: 5, _height: 46, isTemplateDoc: true, isTemplateForField: "data" | 
