diff options
| -rw-r--r-- | solr-8.3.1/CHANGES.txt | 2 | ||||
| -rw-r--r-- | solr-8.3.1/bin/solr-8983.pid | 2 | ||||
| -rw-r--r-- | src/client/documents/DocumentTypes.ts | 3 | ||||
| -rw-r--r-- | src/client/documents/Documents.ts | 30 | ||||
| -rw-r--r-- | src/client/views/nodes/DocumentContentsView.tsx | 5 | ||||
| -rw-r--r-- | src/client/views/nodes/DocumentView.tsx | 2 | ||||
| -rw-r--r-- | src/client/views/nodes/FieldView.tsx | 4 | ||||
| -rw-r--r-- | src/client/views/nodes/LabelBox.tsx | 16 | ||||
| -rw-r--r-- | src/client/views/nodes/QueryBox.tsx | 71 | ||||
| -rw-r--r-- | src/client/views/search/SearchBox.scss | 58 | ||||
| -rw-r--r-- | src/client/views/search/SearchBox.tsx | 448 | ||||
| -rw-r--r-- | src/client/views/search/SearchItem.tsx | 103 | ||||
| -rw-r--r-- | src/new_fields/Doc.ts | 10 | ||||
| -rw-r--r-- | src/server/authentication/models/current_user_utils.ts | 13 | 
14 files changed, 569 insertions, 198 deletions
| diff --git a/solr-8.3.1/CHANGES.txt b/solr-8.3.1/CHANGES.txt index 219888b49..78ee2efc1 100644 --- a/solr-8.3.1/CHANGES.txt +++ b/solr-8.3.1/CHANGES.txt @@ -66,7 +66,7 @@ Upgrade Notes  ----------------------  * Users who have written test cases that extend SolrTestCaseJ4 may see NullPointerExceptions if -  their tests directly reference both SolrTestCaseJ4.initCoreDataDir and SolrTestCaseJ4.deleteCore(). +  their tests directly reference both SolrTestCaseJ4.initCoreDataDir and TestCaseJ4.deleteCore().    This change in behavior is due to a bug fix in deleteCore() to ensure the dataDir is properly reset    in tests that call initCore()/deleteCore() multiple times in a given test (class).  initCoreDataDir    is now deprecated, and users are encouraged to use SolrTestCaseJ4.initAndGetDataDir() in it's place. diff --git a/solr-8.3.1/bin/solr-8983.pid b/solr-8.3.1/bin/solr-8983.pid index 779eb1af5..a873e717c 100644 --- a/solr-8.3.1/bin/solr-8983.pid +++ b/solr-8.3.1/bin/solr-8983.pid @@ -1 +1 @@ -17656 +39661 diff --git a/src/client/documents/DocumentTypes.ts b/src/client/documents/DocumentTypes.ts index de366763b..36d3e1c52 100644 --- a/src/client/documents/DocumentTypes.ts +++ b/src/client/documents/DocumentTypes.ts @@ -13,7 +13,7 @@ export enum DocumentType {      INK = "ink",        // ink stroke      SCREENSHOT = "screenshot",  // view of a desktop application      FONTICON = "fonticonbox",   // font icon -    QUERY = "query",            // search query +    SEARCH = "search",            // search query      LABEL = "label",            // simple text label      BUTTON = "button",          // onClick button      WEBCAM = "webcam",          // webcam @@ -31,6 +31,7 @@ export enum DocumentType {      COLOR = "color",            // color picker (view of a color picker for a color string)      YOUTUBE = "youtube",        // youtube directory (view of you tube search results)      DOCHOLDER = "docholder",    // nested document (view of a document) +    SEARCHITEM= "searchitem",      LINKDB = "linkdb",          // database of links  ??? why do we have this      RECOMMENDATION = "recommendation", // view of a recommendation diff --git a/src/client/documents/Documents.ts b/src/client/documents/Documents.ts index 125a531f4..f0f45bd34 100644 --- a/src/client/documents/Documents.ts +++ b/src/client/documents/Documents.ts @@ -32,9 +32,14 @@ import { ComputedField, ScriptField } from "../../new_fields/ScriptField";  import { ProxyField } from "../../new_fields/Proxy";  import { DocumentType } from "./DocumentTypes";  import { RecommendationsBox } from "../views/RecommendationsBox"; +import { filterData} from "../views/search/SearchBox"; + +//import { PresBox } from "../views/nodes/PresBox"; +//import { PresField } from "../../new_fields/PresField";  import { PresElementBox } from "../views/presentationview/PresElementBox"; +import { SearchItem } from "../views/search/SearchItem";  import { DashWebRTCVideo } from "../views/webcam/DashWebRTCVideo"; -import { QueryBox } from "../views/nodes/QueryBox"; +import { SearchBox } from "../views/search/SearchBox";  import { ColorBox } from "../views/nodes/ColorBox";  import { LinkAnchorBox } from "../views/nodes/LinkAnchorBox";  import { DocHolderBox } from "../views/nodes/DocHolderBox"; @@ -171,10 +176,12 @@ export interface DocumentOptions {      flexDirection?: "unset" | "row" | "column" | "row-reverse" | "column-reverse";      selectedIndex?: number;      syntaxColor?: string; // can be applied to text for syntax highlighting all matches in the text -    searchText?: string; //for searchbox -    searchQuery?: string; // for queryBox -    filterQuery?: string; +    searchText?: string, //for searchbox +    searchQuery?: string, // for quersyBox +    filterQuery?: filterData,      linearViewIsExpanded?: boolean; // is linear view expanded +    border?: string; //for searchbox +    hovercolor?:string;  }  class EmptyBox { @@ -204,8 +211,8 @@ export namespace Docs {                  layout: { view: FormattedTextBox, dataField: "text" },                  options: { _height: 150, _xMargin: 10, _yMargin: 10 }              }], -            [DocumentType.QUERY, { -                layout: { view: QueryBox, dataField: defaultDataKey }, +            [DocumentType.SEARCH, { +                layout: { view: SearchBox, dataField: defaultDataKey },                  options: { _width: 400 }              }],              [DocumentType.COLOR, { @@ -290,6 +297,9 @@ export namespace Docs {              [DocumentType.PRESELEMENT, {                  layout: { view: PresElementBox, dataField: defaultDataKey }              }], +            [DocumentType.SEARCHITEM, { +                layout: { view: SearchItem, dataField: defaultDataKey  } +            }],              [DocumentType.INK, {                  layout: { view: InkingStroke, dataField: defaultDataKey },                  options: { backgroundColor: "transparent" } @@ -560,8 +570,8 @@ export namespace Docs {              return instance;          } -        export function QueryDocument(options: DocumentOptions = {}) { -            return InstanceFromProto(Prototypes.get(DocumentType.QUERY), "", options); +        export function SearchDocument(options: DocumentOptions = {}) { +            return InstanceFromProto(Prototypes.get(DocumentType.SEARCH), new List<Doc>([]), options);          }          export function ColorDocument(options: DocumentOptions = {}) { @@ -715,6 +725,10 @@ export namespace Docs {              return InstanceFromProto(Prototypes.get(DocumentType.PRESELEMENT), undefined, { ...(options || {}) });          } +        export function SearchItemBoxDocument(options?: DocumentOptions) { +            return InstanceFromProto(Prototypes.get(DocumentType.SEARCHITEM), undefined, { ...(options || {}) }); +        } +          export function DockDocument(documents: Array<Doc>, config: string, options: DocumentOptions, id?: string) {              const inst = InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { ...options, _viewType: CollectionViewType.Docking, dockingConfig: config }, id);              Doc.GetProto(inst).data = new List<Doc>(documents); diff --git a/src/client/views/nodes/DocumentContentsView.tsx b/src/client/views/nodes/DocumentContentsView.tsx index 2fc82e524..729209fd7 100644 --- a/src/client/views/nodes/DocumentContentsView.tsx +++ b/src/client/views/nodes/DocumentContentsView.tsx @@ -24,7 +24,8 @@ import { ImageBox } from "./ImageBox";  import { KeyValueBox } from "./KeyValueBox";  import { PDFBox } from "./PDFBox";  import { PresBox } from "./PresBox"; -import { QueryBox } from "./QueryBox"; +import { SearchBox } from "../search/SearchBox"; +import { SearchItem } from "../search/SearchItem"  import { ColorBox } from "./ColorBox";  import { DashWebRTCVideo } from "../webcam/DashWebRTCVideo";  import { LinkAnchorBox } from "./LinkAnchorBox"; @@ -192,7 +193,7 @@ export class DocumentContentsView extends React.Component<DocumentViewProps & {                  components={{                      FormattedTextBox, ImageBox, DirectoryImportBox, FontIconBox, LabelBox, SliderBox, FieldView,                      CollectionFreeFormView, CollectionDockingView, CollectionSchemaView, CollectionView, WebBox, KeyValueBox, -                    PDFBox, VideoBox, AudioBox, PresBox, YoutubeBox, PresElementBox, QueryBox, +                    PDFBox, VideoBox, AudioBox, PresBox, YoutubeBox, PresElementBox, SearchBox, SearchItem,                      ColorBox, DashWebRTCVideo, LinkAnchorBox, InkingStroke, DocHolderBox, LinkBox, ScriptingBox,                      RecommendationsBox, ScreenshotBox, HTMLtag                  }} diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx index 91275d89b..3d20148e7 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -1152,7 +1152,7 @@ export class DocumentView extends DocComponent<DocumentViewProps, Document>(Docu                  pointerEvents: this.ignorePointerEvents ? "none" : undefined,                  color: StrCast(this.layoutDoc.color, "inherit"),                  outline: highlighting && !borderRounding ? `${highlightColors[fullDegree]} ${highlightStyles[fullDegree]} ${localScale}px` : "solid 0px", -                border: highlighting && borderRounding ? `${highlightStyles[fullDegree]} ${highlightColors[fullDegree]} ${localScale}px` : undefined, +                border: this.layoutDoc.border ? StrCast(this.layoutDoc.border) : highlighting && borderRounding ? `${highlightStyles[fullDegree]} ${highlightColors[fullDegree]} ${localScale}px` : undefined,                  boxShadow: this.props.Document.isTemplateForField ? "black 0.2vw 0.2vw 0.8vw" : undefined,                  background: finalColor,                  opacity: this.Document.opacity, diff --git a/src/client/views/nodes/FieldView.tsx b/src/client/views/nodes/FieldView.tsx index 2ab0a416d..9fba91fd8 100644 --- a/src/client/views/nodes/FieldView.tsx +++ b/src/client/views/nodes/FieldView.tsx @@ -51,6 +51,10 @@ export interface FieldViewProps {      setVideoBox?: (player: VideoBox) => void;      ContentScaling: () => number;      ChromeHeight?: () => number; +    childLayoutTemplate?: () => Opt<Doc>; +    highlighting?: string[]; +    lines?: string[]; +    doc?: Doc;      // properties intended to be used from within layout strings (otherwise use the function equivalents that work more efficiently with React)      height?: number;      width?: number; diff --git a/src/client/views/nodes/LabelBox.tsx b/src/client/views/nodes/LabelBox.tsx index ac27640bd..38558c43d 100644 --- a/src/client/views/nodes/LabelBox.tsx +++ b/src/client/views/nodes/LabelBox.tsx @@ -1,6 +1,6 @@  import { library } from '@fortawesome/fontawesome-svg-core';  import { faEdit } from '@fortawesome/free-regular-svg-icons'; -import { action } from 'mobx'; +import { action, computed, observable, runInAction } from 'mobx';  import { observer } from 'mobx-react';  import * as React from 'react';  import { Doc, DocListCast } from '../../../new_fields/Doc'; @@ -61,17 +61,27 @@ export class LabelBox extends ViewBoxBaseComponent<FieldViewProps, LabelDocument              e.stopPropagation();          }      } + + + +    @observable backColor= "unset"; + +    @observable clicked = false;      // (!missingParams || !missingParams.length ? "" : "(" + missingParams.map(m => m + ":").join(" ") + ")")      render() {          const params = Cast(this.paramsDoc["onClick-paramFieldKeys"], listSpec("string"), []);          const missingParams = params?.filter(p => !this.paramsDoc[p]);          params?.map(p => DocListCast(this.paramsDoc[p])); // bcz: really hacky form of prefetching ...  +        console.log(this.backColor);          return ( -            <div className="labelBox-outerDiv" ref={this.createDropTarget} onContextMenu={this.specificContextMenu} +            <div className="labelBox-outerDiv" onClick={()=>runInAction(()=>{this.clicked=!this.clicked; this.clicked? this.backColor=StrCast(this.layoutDoc.hovercolor) : this.backColor ="unset"})} onMouseLeave={()=>runInAction(()=>{ !this.clicked ?this.backColor="unset" : null})}  +            onMouseOver={()=>runInAction(()=>{this.backColor=StrCast(this.layoutDoc.hovercolor);})}ref={this.createDropTarget} onContextMenu={this.specificContextMenu}                  style={{ boxShadow: this.layoutDoc.opacity ? StrCast(this.layoutDoc.boxShadow) : "" }}>                  <div className="labelBox-mainButton" style={{                      background: StrCast(this.layoutDoc.backgroundColor), -                    color: StrCast(this.layoutDoc.color, "inherit"), +                    color: StrCast(this.layoutDoc.color), +                    backgroundColor:this.backColor, +                    fontSize: NumCast(this.layoutDoc.fontSize) || "inherit",                      fontSize: NumCast(this.layoutDoc._fontSize) || "inherit",                      fontFamily: StrCast(this.layoutDoc._fontFamily) || "inherit",                      letterSpacing: StrCast(this.layoutDoc.letterSpacing), diff --git a/src/client/views/nodes/QueryBox.tsx b/src/client/views/nodes/QueryBox.tsx index 2a21a380d..1b6056be6 100644 --- a/src/client/views/nodes/QueryBox.tsx +++ b/src/client/views/nodes/QueryBox.tsx @@ -1,41 +1,38 @@ -import React = require("react"); -import { IReactionDisposer } from "mobx"; -import { observer } from "mobx-react"; -import { documentSchema } from "../../../new_fields/documentSchemas"; -import { Id } from '../../../new_fields/FieldSymbols'; -import { makeInterface, listSpec } from "../../../new_fields/Schema"; -import { StrCast, Cast } from "../../../new_fields/Types"; -import { ViewBoxAnnotatableComponent } from '../DocComponent'; -import { SearchBox } from "../search/SearchBox"; -import { FieldView, FieldViewProps } from './FieldView'; -import "./QueryBox.scss"; -import { List } from "../../../new_fields/List"; -import { SnappingManager } from "../../util/SnappingManager"; +// import React = require("react"); +// import { IReactionDisposer } from "mobx"; +// import { observer } from "mobx-react"; +// import { documentSchema } from "../../../new_fields/documentSchemas"; +// import { Id } from '../../../new_fields/FieldSymbols'; +// import { makeInterface, listSpec } from "../../../new_fields/Schema"; +// import { StrCast, Cast } from "../../../new_fields/Types"; +// import { ViewBoxAnnotatableComponent } from '../DocComponent'; +// import { SearchBox } from "../search/SearchBox"; +// import { FieldView, FieldViewProps } from './FieldView'; +// import "./QueryBox.scss"; +// import { List } from "../../../new_fields/List"; +// import { SnappingManager } from "../../util/SnappingManager"; -type QueryDocument = makeInterface<[typeof documentSchema]>; -const QueryDocument = makeInterface(documentSchema); +// type QueryDocument = makeInterface<[typeof documentSchema]>; +// const QueryDocument = makeInterface(documentSchema); -@observer -export class QueryBox extends ViewBoxAnnotatableComponent<FieldViewProps, QueryDocument>(QueryDocument) { -    public static LayoutString(fieldKey: string) { return FieldView.LayoutString(QueryBox, fieldKey); } -    _docListChangedReaction: IReactionDisposer | undefined; -    componentDidMount() { -    } +// @observer +// export class QueryBox extends ViewBoxAnnotatableComponent<FieldViewProps, QueryDocument>(QueryDocument) { +//     public static LayoutString(fieldKey: string) { return FieldView.LayoutString(QueryBox, fieldKey); } +//     _docListChangedReaction: IReactionDisposer | undefined; +//     componentDidMount() { +//     } -    componentWillUnmount() { -        this._docListChangedReaction?.(); -    } +//     componentWillUnmount() { +//         this._docListChangedReaction?.(); +//     } -    render() { -        const dragging = !SnappingManager.GetIsDragging() ? "" : "-dragging"; -        return <div className={`queryBox${dragging}`} onWheel={(e) => e.stopPropagation()} > -            <SearchBox -                id={this.props.Document[Id]} -                setSearchQuery={q => this.dataDoc.searchQuery = q} -                searchQuery={StrCast(this.dataDoc.searchQuery)} -                setSearchFileTypes={q => this.dataDoc.searchFileTypes = new List<string>(q)} -                searchFileTypes={Cast(this.dataDoc.searchFileTypes, listSpec("string"), [])} -                filterQquery={StrCast(this.dataDoc.filterQuery)} /> -        </div >; -    } -}
\ No newline at end of file +//     render() { +//         const dragging = !SnappingManager.GetIsDragging() ? "" : "-dragging"; +//         return <div className={`queryBox${dragging}`} onWheel={(e) => e.stopPropagation()} > +             +//             <SearchBox  Document={this.props.Document}  /> +//         </div >; +//     } +// } + +// //<SearchBox id={this.props.Document[Id]} sideBar={side} Document={this.props.Document} searchQuery={StrCast(this.dataDoc.searchQuery)} filterQuery={this.dataDoc.filterQuery} /> diff --git a/src/client/views/search/SearchBox.scss b/src/client/views/search/SearchBox.scss index bb62113a1..1e71f8cb0 100644 --- a/src/client/views/search/SearchBox.scss +++ b/src/client/views/search/SearchBox.scss @@ -45,9 +45,11 @@          &.searchBox-filter {              align-self: stretch; +            button{ +                transform:none; +            }              button:hover{ -                transform:scale(1.0); -                background:"#121721"; +                transform:none;              }          } @@ -96,20 +98,20 @@      background: #121721;      flex-direction: column;      transform-origin: top; -    transition: height 0.3s ease, display 0.6s ease; +    transition: height 0.3s ease, display 0.6s ease, overflow 0.6s ease;      height:0px;      overflow:hidden;      .filter-header { -        display: flex; +        //display: flex;          position: relative; -        flex-wrap:wrap; +        //flex-wrap:wrap;          right: 1px;          color: grey; -        flex-direction: row-reverse; +        //flex-direction: row-reverse;          transform-origin: top; -        justify-content: space-evenly; +        //justify-content: space-evenly;          margin-bottom: 5px;          overflow:hidden;          transition:height 0.3s ease-out; @@ -130,9 +132,7 @@          color: grey;          transform-origin: top;          border-top: 0px; -        //padding-top: 5px; -        margin-left: 10px; -        margin-right: 10px; +          overflow:hidden;          transition:height 0.3s ease-out;          height:0px; @@ -144,30 +144,28 @@          color: grey;          transform-origin: top;          border-top: 0px; -        //padding-top: 5px; -        margin-left: 10px; -        margin-right: 10px;          overflow:hidden;          transition:height 0.3s ease-out;          height:0px; -        .filter-keybar { -            display: flex; -            flex-wrap: wrap; -            justify-content: space-evenly; -            height: auto; -            width: 100%; -            flex-direction: row-reverse; -            margin-top:5px; -             -            .filter-item { -                position: relative; -                border:1px solid grey; -                border-radius: 16px; -     -            } -        } - +        .labelBox-mainButton:hover{ +            color:"White"; +        } +        // .filter-keybar { +        //     display: flex; +        //     flex-wrap: wrap; +        //     justify-content: space-evenly; +        //     height: auto; +        //     width: 100%; +        //     flex-direction: row-reverse; +        //     margin-top:5px; +             +        //     .filter-item { +        //         position: relative; +        //         border:1px solid grey; +        //         border-radius: 16px; +        //     } +        // }      }  } diff --git a/src/client/views/search/SearchBox.tsx b/src/client/views/search/SearchBox.tsx index e41b725b1..e784580e5 100644 --- a/src/client/views/search/SearchBox.tsx +++ b/src/client/views/search/SearchBox.tsx @@ -8,29 +8,55 @@ import * as rp from 'request-promise';  import { Doc } from '../../../new_fields/Doc';  import { Id } from '../../../new_fields/FieldSymbols';  import { Cast, NumCast, StrCast } from '../../../new_fields/Types'; -import { Utils } from '../../../Utils'; -import { Docs } from '../../documents/Documents'; -import { SetupDrag } from '../../util/DragManager'; +import { Utils, returnTrue, emptyFunction, returnFalse, emptyPath, returnOne, returnEmptyString } from '../../../Utils'; +import { Docs, DocumentOptions } from '../../documents/Documents'; +import { SetupDrag, DragManager } from '../../util/DragManager';  import { SearchUtil } from '../../util/SearchUtil';  import "./SearchBox.scss";  import { SearchItem } from './SearchItem';  import { IconBar } from './IconBar'; -import { FieldView } from '../nodes/FieldView'; +import { FieldView, FieldViewProps } from '../nodes/FieldView';  import { DocumentType } from "../../documents/DocumentTypes";  import { DocumentView } from '../nodes/DocumentView';  import { SelectionManager } from '../../util/SelectionManager'; +import { FilterQuery } from 'mongodb'; +import { CollectionLinearView } from '../collections/CollectionLinearView'; +import { CurrentUserUtils } from '../../../server/authentication/models/current_user_utils'; +import { CollectionDockingView } from '../collections/CollectionDockingView'; +import { ScriptField } from '../../../new_fields/ScriptField'; +import { PrefetchProxy } from '../../../new_fields/Proxy'; +import { List } from '../../../new_fields/List'; +import { faSearch, faFilePdf, faFilm, faImage, faObjectGroup, faStickyNote, faMusic, faLink, faChartBar, faGlobeAsia, faBan, faVideo, faCaretDown } from '@fortawesome/free-solid-svg-icons'; +import { Transform } from '../../util/Transform'; +import { MainView } from "../MainView"; +import { Scripting } from '../../util/Scripting'; +import { CollectionView, CollectionViewType } from '../collections/CollectionView'; +import { ViewBoxBaseComponent } from "../DocComponent"; +import { documentSchema } from "../../../new_fields/documentSchemas"; +import { makeInterface, createSchema } from '../../../new_fields/Schema';  import { listSpec } from '../../../new_fields/Schema'; +  library.add(faTimes); -export interface SearchProps { -    id: string; -    searchQuery: string; -    filterQquery?: string; -    setSearchQuery: (q: string) => {}; -    searchFileTypes: string[]; -    setSearchFileTypes: (types: string[]) => {}; -} +// export interface SearchProps { +//     id: string; +//     Document: Doc; +//     sideBar?: Boolean; +//     searchQuery?: string; +//     filterQuery?: filterData; +// } + +export const searchSchema = createSchema({ +    id: "string", +    Document: Doc, +    sideBar: "boolean", +    searchQuery: "string", +}); + +//add back filterquery + +  export enum Keys {      TITLE = "title", @@ -38,16 +64,30 @@ export enum Keys {      DATA = "data"  } +export interface filterData{ +    deletedDocsStatus: boolean; +    authorFieldStatus: boolean; +    titleFieldStatus:boolean; +    basicWordStatus:boolean; +    icons: string[]; +} + +type SearchBoxDocument = makeInterface<[typeof documentSchema, typeof searchSchema]>; +const SearchBoxDocument = makeInterface(documentSchema, searchSchema); + +//React.Component<SearchProps>   @observer -export class SearchBox extends React.Component<SearchProps> { +export class SearchBox extends ViewBoxBaseComponent<FieldViewProps, SearchBoxDocument>(SearchBoxDocument) { -    private get _searchString() { return this.props.searchQuery; } -    private set _searchString(value) { this.props.setSearchQuery(value); } +    // private get _searchString() { return this.rootDoc.searchQuery; } +    // private set _searchString(value) { this.rootDoc.setSearchQuery(value); } +    @observable private _searchString: string ="";      @observable private _resultsOpen: boolean = false;      @observable private _searchbarOpen: boolean = false;      @observable private _results: [Doc, string[], string[]][] = [];      @observable private _openNoResults: boolean = false;      @observable private _visibleElements: JSX.Element[] = []; +    @observable private _visibleDocuments: Doc[] = [];      private _resultsSet = new Map<Doc, number>();      private _resultsRef = React.createRef<HTMLDivElement>(); @@ -70,23 +110,45 @@ export class SearchBox extends React.Component<SearchProps> {      @observable private _nodeStatus: boolean = false;      @observable private _keyStatus: boolean = false; +    @observable private newAssign: boolean = true;      constructor(props: any) {          super(props);          SearchBox.Instance = this;          this.resultsScrolled = this.resultsScrolled.bind(this);      } - -    componentDidMount = action(() => { +    @observable setupButtons =false; +    componentDidMount = () => { +        console.log(this.setupButtons); +        if (this.setupButtons==false){ +        console.log("Yuh"); +            this.setupDocTypeButtons(); +            this.setupKeyButtons(); +            this.setupDefaultButtons(); +        runInAction(()=>this.setupButtons==true); +    }          if (this.inputRef.current) {              this.inputRef.current.focus(); -            this._searchbarOpen = true; +            runInAction( () => {this._searchbarOpen = true});          } -        if (this.props.searchQuery) { // bcz: why was this here?    } && this.props.filterQquery) { -            this._searchString = this.props.searchQuery; -            this.submitSearch(); +        if (this.rootDoc.searchQuery&& this.newAssign) { +            console.log(this.rootDoc.searchQuery); +            const sq = this.rootDoc.searchQuery; +            runInAction(() => { + +            // this._deletedDocsStatus=this.props.filterQuery!.deletedDocsStatus; +            // this._authorFieldStatus=this.props.filterQuery!.authorFieldStatus +            // this._titleFieldStatus=this.props.filterQuery!.titleFieldStatus; +            // this._basicWordStatus=this.props.filterQuery!.basicWordStatus; +            // this._icons=this.props.filterQuery!.icons; +            this.newAssign=false; +            }); +            runInAction(() => { +                this._searchString = StrCast(sq); +                this.submitSearch(); +            });          } -    }); +    };      @action @@ -163,10 +225,10 @@ export class SearchBox extends React.Component<SearchProps> {          }          //if should be searched in a specific collection -        if (this._collectionStatus) { -            query = this.addCollectionFilter(query); -            query = query.replace(/\s+/g, ' ').trim(); -        } +        // if (this._collectionStatus) { +        //     query = this.addCollectionFilter(query); +        //     query = query.replace(/\s+/g, ' ').trim(); +        // }          return query;      } @@ -279,12 +341,15 @@ export class SearchBox extends React.Component<SearchProps> {      @action      submitSearch = async () => { +        console.log(this._searchString); +        this.dataDoc[this.fieldKey] = new List<Doc>([]);          const query = this._searchString;          this.getFinalQuery(query);          this._results = [];          this._resultsSet.clear();          this._isSearch = [];          this._visibleElements = []; +        this._visibleDocuments = [];          if (query !== "") {              this._endIndex = 12;              this._maxSearchIndex = 0; @@ -305,15 +370,16 @@ export class SearchBox extends React.Component<SearchProps> {      }      private get filterQuery() { -        const types = this.filterTypes; -        const baseExpr = "NOT baseProto_b:true"; -        const includeDeleted = this.getDataStatus() ? "" : " NOT deleted_b:true"; -        const includeIcons = this.getDataStatus() ? "" : " NOT type_t:fonticonbox"; -        const typeExpr = !types ? "" : ` (${types.map(type => `({!join from=id to=proto_i}type_t:"${type}" AND NOT type_t:*) OR type_t:"${type}"`).join(" ")})`; -        // fq: type_t:collection OR {!join from=id to=proto_i}type_t:collection   q:text_t:hello -        const query = [baseExpr, includeDeleted, includeIcons, typeExpr].join(" AND ").replace(/AND $/, ""); -        return query; -    } +        // const types = this.filterTypes; +        // const baseExpr = "NOT baseProto_b:true"; +        // const includeDeleted = this.getDataStatus() ? "" : " NOT deleted_b:true"; +        // const includeIcons = this.getDataStatus() ? "" : " NOT type_t:fonticonbox"; +        // const typeExpr = !types ? "" : ` (${types.map(type => `({!join from=id to=proto_i}type_t:"${type}" AND NOT type_t:*) OR type_t:"${type}"`).join(" ")})`; +        // // fq: type_t:collection OR {!join from=id to=proto_i}type_t:collection   q:text_t:hello +        // const query = [baseExpr, includeDeleted, includeIcons, typeExpr].join(" AND ").replace(/AND $/, ""); +        // return query; +        return ""; +        }      getDataStatus() { return this._deletedDocsStatus; } @@ -339,7 +405,8 @@ export class SearchBox extends React.Component<SearchProps> {                      const docs = await Promise.all(res.docs.map(async doc => (await Cast(doc.extendsDoc, Doc)) || doc));                      const highlights: typeof res.highlighting = {};                      docs.forEach((doc, index) => highlights[doc[Id]] = highlightList[index]); -                    const filteredDocs = this.filterDocsByType(docs); +                    const filteredDocs = docs; +                    //this.filterDocsByType(docs);                      runInAction(() => {                          //this._results.push(...filteredDocs);                          filteredDocs.forEach(doc => { @@ -404,7 +471,14 @@ export class SearchBox extends React.Component<SearchProps> {                  y += 300;              }          } -        return Docs.Create.QueryDocument({ _autoHeight: true, title: this._searchString, filterQuery: this.filterQuery, searchQuery: this._searchString }); +        const filter : filterData = { +            deletedDocsStatus: this._deletedDocsStatus, +            authorFieldStatus: this._authorFieldStatus, +            titleFieldStatus: this._titleFieldStatus, +            basicWordStatus: this._basicWordStatus, +            icons: this._icons, +        } +        return Docs.Create.SearchDocument({ _autoHeight: true, title: this._searchString, filterQuery: filter, searchQuery: this._searchString });      }      @action.bound @@ -427,6 +501,7 @@ export class SearchBox extends React.Component<SearchProps> {          this._results = [];          this._resultsSet.clear();          this._visibleElements = []; +        this._visibleDocuments=[];          this._numTotalResults = -1;          this._endIndex = -1;          this._curRequest = undefined; @@ -438,12 +513,13 @@ export class SearchBox extends React.Component<SearchProps> {          const scrollY = e ? e.currentTarget.scrollTop : this._resultsRef.current ? this._resultsRef.current.scrollTop : 0;          const itemHght = 53;          const startIndex = Math.floor(Math.max(0, scrollY / itemHght)); -        const endIndex = Math.ceil(Math.min(this._numTotalResults - 1, startIndex + (this._resultsRef.current.getBoundingClientRect().height / itemHght))); - +        //const endIndex = Math.ceil(Math.min(this._numTotalResults - 1, startIndex + (this._resultsRef.current.getBoundingClientRect().height / itemHght))); +        const endIndex= 30;          this._endIndex = endIndex === -1 ? 12 : endIndex; - +        this._endIndex=30;          if ((this._numTotalResults === 0 || this._results.length === 0) && this._openNoResults) {              this._visibleElements = [<div className="no-result">No Search Results</div>]; +            //this._visibleDocuments= Docs.Create.              return;          } @@ -456,7 +532,8 @@ export class SearchBox extends React.Component<SearchProps> {          else if (this._visibleElements.length !== this._numTotalResults) {              // undefined until a searchitem is put in there              this._visibleElements = Array<JSX.Element>(this._numTotalResults === -1 ? 0 : this._numTotalResults); -            // indicates if things are placeholders +            this._visibleDocuments = Array<Doc>(this._numTotalResults === -1 ? 0 : this._numTotalResults); +            // indicates if things are placeholders               this._isSearch = Array<undefined>(this._numTotalResults === -1 ? 0 : this._numTotalResults);          } @@ -477,7 +554,14 @@ export class SearchBox extends React.Component<SearchProps> {                          if (i < this._results.length) result = this._results[i];                          if (result) {                              const highlights = Array.from([...Array.from(new Set(result[1]).values())]); -                            this._visibleElements[i] = <SearchItem doc={result[0]} query={this._searchString} key={result[0][Id]} lines={result[2]} highlighting={highlights} />; +                            result[0].query=this._searchString; +                            //Make alias +                            result[0].lines=new List<string>(result[2]); +                            result[0].highlighting=new List<string>(highlights); + +                            this._visibleElements[i] = <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";                          }                      } @@ -485,7 +569,13 @@ export class SearchBox extends React.Component<SearchProps> {                          result = this._results[i];                          if (result) {                              const highlights = Array.from([...Array.from(new Set(result[1]).values())]); -                            this._visibleElements[i] = <SearchItem doc={result[0]} query={this._searchString} key={result[0][Id]} lines={result[2]} highlighting={highlights} />; +                            result[0].query=this._searchString; +                            result[0].lines=new List<string>(result[2]); +                            result[0].highlighting=new List<string>(highlights); + +                            this._visibleElements[i] = <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";                          }                      } @@ -494,6 +584,7 @@ export class SearchBox extends React.Component<SearchProps> {          }          if (this._maxSearchIndex >= this._numTotalResults) {              this._visibleElements.length = this._results.length; +            this._visibleDocuments.length = this._results.length;              this._isSearch.length = this._results.length;          }      } @@ -512,12 +603,13 @@ export class SearchBox extends React.Component<SearchProps> {      @action.bound      handleNodeChange = () => { +        console.log("oi!");          this._nodeStatus = !this._nodeStatus;          if (this._nodeStatus) { -            this.expandSection(`node${this.props.id}`); +            this.expandSection(`node${this.props.Document[Id]}`);          }          else { -            this.collapseSection(`node${this.props.id}`); +            this.collapseSection(`node${this.props.Document[Id]}`);          }      } @@ -525,10 +617,10 @@ export class SearchBox extends React.Component<SearchProps> {      handleKeyChange = () => {          this._keyStatus = !this._keyStatus;          if (this._keyStatus) { -            this.expandSection(`key${this.props.id}`); +            this.expandSection(`key${this.props.Document[Id]}`);          }          else { -            this.collapseSection(`key${this.props.id}`); +            this.collapseSection(`key${this.props.Document[Id]}`);          }      } @@ -536,16 +628,18 @@ export class SearchBox extends React.Component<SearchProps> {      handleFilterChange = () => {          this._filterOpen = !this._filterOpen;          if (this._filterOpen) { -            this.expandSection(`filterhead${this.props.id}`); -            document.getElementById(`filterhead${this.props.id}`)!.style.padding = "5"; +            this.expandSection(`filterhead${this.props.Document[Id]}`); +            document.getElementById(`filterhead${this.props.Document[Id]}`)!.style.padding = "5";          }          else { -            this.collapseSection(`filterhead${this.props.id}`); +            this.collapseSection(`filterhead${this.props.Document[Id]}`);          }      } +   //layoutDoc  +      @computed      get menuHeight() {          return document.getElementById("hi")?.clientHeight; @@ -553,7 +647,7 @@ export class SearchBox extends React.Component<SearchProps> {      collapseSection(thing: string) { -        const id = this.props.id; +        const id = this.props.Document[Id];          const element = document.getElementById(thing)!;          // get the height of the element's inner content, regardless of its actual size          const sectionHeight = element.scrollHeight; @@ -625,10 +719,209 @@ export class SearchBox extends React.Component<SearchProps> {      @action.bound      updateDataStatus() { this._deletedDocsStatus = !this._deletedDocsStatus; } +    addButtonDoc = (doc: Doc) => Doc.AddDocToList(CurrentUserUtils.UserDocument.expandingButtons as Doc, "data", doc); +    remButtonDoc = (doc: Doc) => Doc.RemoveDocFromList(CurrentUserUtils.UserDocument.expandingButtons as Doc, "data", doc); +    moveButtonDoc = (doc: Doc, targetCollection: Doc | undefined, addDocument: (document: Doc) => boolean) => this.remButtonDoc(doc) && addDocument(doc); +     +    @computed get docButtons() { +        const nodeBtns = this.props.Document.nodeButtons; +        let width = () => NumCast(this.props.Document._width); +        if (this.rootDoc.sideBar===true){ +            width = MainView.Instance.flyoutWidthFunc; +        } +        if (nodeBtns instanceof Doc) { +            return <div id="hi" style={{height:"100px",}}> +                <DocumentView +                Document={nodeBtns} +                DataDoc={undefined} +                LibraryPath={emptyPath} +                addDocument={undefined} +                addDocTab={returnFalse} +                rootSelected={returnTrue} +                pinToPres={emptyFunction} +                onClick={undefined} +                removeDocument={undefined} +                ScreenToLocalTransform={this.getTransform} +                ContentScaling={returnOne} +                PanelWidth={width} +                PanelHeight={() => 100} +                renderDepth={0} +                backgroundColor={returnEmptyString} +                focus={emptyFunction} +                parentActive={returnTrue} +                whenActiveChanged={emptyFunction} +                bringToFront={emptyFunction} +                ContainingCollectionView={undefined} +                ContainingCollectionDoc={undefined} +                NativeHeight={()=>100} +                NativeWidth={width} +            /> +            </div>; +        } +        return (null); +    } + +    @computed get keyButtons() { +        const nodeBtns = this.props.Document.keyButtons; +        let width = () => NumCast(this.props.Document._width); +        if (this.rootDoc.sideBar===true){ +            width = MainView.Instance.flyoutWidthFunc; +        } +        if (nodeBtns instanceof Doc) { +            return <div id="hi" style={{height:"35px",}}> +                <DocumentView +                Document={nodeBtns} +                DataDoc={undefined} +                LibraryPath={emptyPath} +                addDocument={undefined} +                addDocTab={returnFalse} +                rootSelected={returnTrue} +                pinToPres={emptyFunction} +                onClick={undefined} +                removeDocument={undefined} +                ScreenToLocalTransform={this.getTransform} +                ContentScaling={returnOne} +                PanelWidth={width} +                PanelHeight={() => 100} +                renderDepth={0} +                backgroundColor={returnEmptyString} +                focus={emptyFunction} +                parentActive={returnTrue} +                whenActiveChanged={emptyFunction} +                bringToFront={emptyFunction} +                ContainingCollectionView={undefined} +                ContainingCollectionDoc={undefined} +                NativeHeight={()=>100} +                NativeWidth={width} +            /> +            </div>; +        } +        return (null); +    } + +    @computed get defaultButtons() { +        const defBtns = this.props.Document.defaultButtons; +        let width = () => NumCast(this.props.Document._width); +        if (this.rootDoc.sideBar===true){ +            width = MainView.Instance.flyoutWidthFunc; +        } +        if (defBtns instanceof Doc) { +            return <div id="hi" style={{height:"35px",}}> +                <DocumentView +                Document={defBtns} +                DataDoc={undefined} +                LibraryPath={emptyPath} +                addDocument={undefined} +                addDocTab={returnFalse} +                rootSelected={returnTrue} +                pinToPres={emptyFunction} +                onClick={undefined} +                removeDocument={undefined} +                ScreenToLocalTransform={this.getTransform} +                ContentScaling={returnOne} +                PanelWidth={width} +                PanelHeight={() => 100} +                renderDepth={0} +                backgroundColor={returnEmptyString} +                focus={emptyFunction} +                parentActive={returnTrue} +                whenActiveChanged={emptyFunction} +                bringToFront={emptyFunction} +                ContainingCollectionView={undefined} +                ContainingCollectionDoc={undefined} +                NativeHeight={()=>100} +                NativeWidth={width} +            /> +            </div>; +        } +        return (null); +    } + +    setupDocTypeButtons() { +        let doc = this.props.Document; +        const ficon = (opts: DocumentOptions) => new PrefetchProxy(Docs.Create.FontIconDocument({ ...opts,   +        dropAction: "alias", removeDropProperties: new List<string>(["dropAction"]), _nativeWidth: 100, _nativeHeight: 100, _width: 100, +         _height: 100 })) as any as Doc; +        //backgroundColor: "#121721",        +        doc.Music = ficon({ onClick: undefined, title: "mussic button", icon: "music" }); +        doc.Col = ficon({ onClick: undefined, title: "col button", icon: "object-group" }); +        doc.Hist = ficon({ onClick: undefined, title: "hist button", icon: "chart-bar" }); +        doc.Image = ficon({ onClick: undefined, title: "image button", icon: "image" }); +        doc.Link = ficon({ onClick: undefined, title: "link button", icon: "link" }); +        doc.PDF = ficon({ onClick: undefined, title: "pdf button", icon: "file-pdf" }); +        doc.TEXT = ficon({ onClick: undefined, title: "text button", icon: "sticky-note" }); +        doc.Vid = ficon({ onClick: undefined, title: "vid button", icon: "video" }); +        doc.Web = ficon({ onClick: undefined, title: "web button", icon: "globe-asia" }); + +        let buttons = [doc.None as Doc, doc.Music as Doc, doc.Col as Doc, doc.Hist as Doc, +        doc.Image as Doc, doc.Link as Doc, doc.PDF as Doc, doc.TEXT as Doc, doc.Vid as Doc, doc.Web as Doc]; + +        const dragCreators = Docs.Create.MasonryDocument(buttons, { +            _width: 500, backgroundColor:"#121721", _autoHeight: true, columnWidth: 35, ignoreClick: true, lockedPosition: true, _chromeStatus: "disabled", title: "buttons", +            dropConverter: ScriptField.MakeScript("convertToButtons(dragData)", { dragData: DragManager.DocumentDragData.name }), _yMargin: 5 +        }); +        doc.nodeButtons= dragCreators; +    } + + +    setupKeyButtons() { +        let doc = this.props.Document; +        const button = (opts: DocumentOptions) => new PrefetchProxy( Docs.Create.ButtonDocument({...opts, +            _width: 35, _height: 30, +            borderRounding: "16px", border:"1px solid grey", color:"white", hovercolor: "rgb(170, 170, 163)", letterSpacing: "2px", +            _fontSize: 7, +        }))as any as Doc; +        doc.title=button({ title: "Title", onClick:ScriptField.MakeScript("this.updateTitleStatus")}); +        doc.deleted=button({ title: "Deleted", onClick:ScriptField.MakeScript(`handleNodeChange()`)}); +        doc.author = button({ title: "Author", onClick:ScriptField.MakeScript("this.updateTitleStatus")}); + +        let buttons = [doc.title as Doc, doc.deleted as Doc, doc.author as Doc]; + +        const dragCreators = Docs.Create.MasonryDocument(buttons, { +            _width: 500, backgroundColor:"#121721", _autoHeight: true, columnWidth: 50, ignoreClick: true, lockedPosition: true, _chromeStatus: "disabled", title: "buttons",_yMargin: 5 +            //dropConverter: ScriptField.MakeScript("convertToButtons(dragData)", { dragData: DragManager.DocumentDragData.name }),  +        }); +        doc.keyButtons= dragCreators; +    } + +    setupDefaultButtons() { +        let doc = this.props.Document; +        const button = (opts: DocumentOptions) => new PrefetchProxy( Docs.Create.ButtonDocument({...opts, +            _width: 35, _height: 30, +            borderRounding: "16px", border:"1px solid grey", color:"white", hovercolor: "rgb(170, 170, 163)", letterSpacing: "2px", +            _fontSize: 7, +        }))as any as Doc; +        doc.keywords=button({ title: "Keywords", onClick:ScriptField.MakeScript("handleNodeChange(this)")}); +        doc.keys=button({ title: "Keys", onClick:ScriptField.MakeScript(`this.handleNodeChange`)}); +        doc.nodes = button({ title: "Nodes", onClick:ScriptField.MakeScript("this.updateTitleStatus")}); +        let buttons = [doc.keywords as Doc, doc.keys as Doc, doc.nodes as Doc]; +        const dragCreators = Docs.Create.MasonryDocument(buttons, { +            _width: 500, backgroundColor:"#121721", _autoHeight: true, columnWidth: 60, ignoreClick: true, lockedPosition: true, _chromeStatus: "disabled", title: "buttons",_yMargin: 5 +            //dropConverter: ScriptField.MakeScript("convertToButtons(dragData)", { dragData: DragManager.DocumentDragData.name }),  +        }); +        doc.defaultButtons= dragCreators; +    } +    childLayoutTemplate = () => this.layoutDoc._viewType === CollectionViewType.Stacking ? Cast(Doc.UserDoc().searchItemTemplate, Doc, null) : undefined; +    getTransform = () => { +    return this.props.ScreenToLocalTransform().translate(-5, -65);// listBox padding-left and pres-box-cont minHeight +    } +    panelHeight = () => { +        return this.props.PanelHeight() - 50; +    } +    selectElement = (doc: Doc) => { +        //this.gotoDocument(this.childDocs.indexOf(doc), NumCast(this.layoutDoc._itemIndex)); +    } + +    addDocument = (doc: Doc) => { +        const newPinDoc = Doc.MakeAlias(doc); +        newPinDoc.presentationTargetDoc = doc; +        return Doc.AddDocToList(this.dataDoc, this.fieldKey, newPinDoc); +    } +    //Make id layour document      render() {          return ( -            <div className="searchBox-container"> +            <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">                          <FontAwesomeIcon icon="object-group" size="lg" /> @@ -636,36 +929,55 @@ export class SearchBox extends React.Component<SearchProps> {                      <input value={this._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" title="Advanced Filtering Options" onClick={() => this.handleFilterChange()}><FontAwesomeIcon icon="ellipsis-v" color="white" /></button> +                    <button className="searchBox-barChild searchBox-filter" style={{transform:"none"}} title="Advanced Filtering Options" onClick={() => this.handleFilterChange()}><FontAwesomeIcon icon="ellipsis-v" color="white" /></button>                  </div> -                <div id={`filterhead${this.props.id}`} className="filter-form" > -                    <div id={`filterhead2${this.props.id}`} className="filter-header" style={this._filterOpen ? {} : {}}> -                        <button className="filter-item" style={this._basicWordStatus ? { background: "#aaaaa3", } : {}} onClick={this.handleWordQueryChange}>Keywords</button> +                <div id={`filterhead${this.props.Document[Id]}`} className="filter-form" style={this._filterOpen && this._numTotalResults >0 ? {overflow:"visible"} : {overflow:"hidden"}}> +                    <div id={`filterhead2${this.props.Document[Id]}`} className="filter-header"  > +                        {this.defaultButtons} +                        {/* <button className="filter-item" style={this._basicWordStatus ? { background: "#aaaaa3", } : {}} onClick={this.handleWordQueryChange}>Keywords</button>                          <button className="filter-item" style={this._keyStatus ? { background: "#aaaaa3" } : {}} onClick={this.handleKeyChange}>Keys</button> -                        <button className="filter-item" style={this._nodeStatus ? { background: "#aaaaa3" } : {}} onClick={this.handleNodeChange}>Nodes</button> +                        <button className="filter-item" style={this._nodeStatus ? { background: "#aaaaa3" } : {}} onClick={this.handleNodeChange}>Nodes</button> */}                      </div> -                    <div id={`node${this.props.id}`} className="filter-body" style={this._nodeStatus ? { borderTop: "grey 1px solid" } : { borderTop: "0px" }}> -                        <IconBar setIcons={(icons: string[]) => { -                            this._icons = icons; -                        }} /> +                    <div id={`node${this.props.Document[Id]}`} className="filter-body" style={this._nodeStatus ? { borderTop: "grey 1px solid" } : { borderTop: "0px" }}> +                        {this.docButtons}                      </div> -                    <div className="filter-key" id={`key${this.props.id}`} style={this._keyStatus ? { borderTop: "grey 1px solid" } : { borderTop: "0px" }}> -                        <div className="filter-keybar"> -                            <button className="filter-item" style={this._titleFieldStatus ? { background: "#aaaaa3", } : {}} onClick={this.updateTitleStatus}>Title</button> +                    <div className="filter-key" id={`key${this.props.Document[Id]}`} style={this._keyStatus ? { borderTop: "grey 1px solid" } : { borderTop: "0px" }}> +                        {/* <div className="filter-keybar"> */} +                            {/* <button className="filter-item" style={this._titleFieldStatus ? { background: "#aaaaa3", } : {}} onClick={this.updateTitleStatus}>Title</button>                              <button className="filter-item" style={this._deletedDocsStatus ? { background: "#aaaaa3", } : {}} onClick={this.updateDataStatus}>Deleted Docs</button> -                            <button className="filter-item" style={this._authorFieldStatus ? { background: "#aaaaa3", } : {}} onClick={this.updateAuthorStatus}>Author</button> -                        </div> +                            <button className="filter-item" style={this._authorFieldStatus ? { background: "#aaaaa3", } : {}} onClick={this.updateAuthorStatus}>Author</button> */} +                        {this.keyButtons}                      </div>                  </div> +                <CollectionView {...this.props} +                        Document={this.props.Document} +                        PanelHeight={this.panelHeight} +                        moveDocument={returnFalse} +                        childLayoutTemplate={this.childLayoutTemplate} +                        addDocument={this.addDocument} +                        removeDocument={returnFalse} +                        focus={this.selectElement} +                        ScreenToLocalTransform={this.getTransform} />                  <div className="searchBox-results" onScroll={this.resultsScrolled} style={{                      display: this._resultsOpen ? "flex" : "none",                      height: this.resFull ? "auto" : this.resultHeight,                      overflow: "visibile" // this.resFull ? "auto" : "visible"                  }} ref={this._resultsRef}> -                    {this._visibleElements} +                    {this._visibleElements.length} +                     +                                      </div>              </div>          );      } -}
\ No newline at end of file +} + +// Scripting.addGlobal(function handleNodeChange(doc: any) { +//     console.log("oi"); +//     doc.handleNodeChange(); +     +//     // 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 diff --git a/src/client/views/search/SearchItem.tsx b/src/client/views/search/SearchItem.tsx index 96f43e931..28874ede0 100644 --- a/src/client/views/search/SearchItem.tsx +++ b/src/client/views/search/SearchItem.tsx @@ -4,7 +4,7 @@ import { faCaretUp, faChartBar, faFile, faFilePdf, faFilm, faFingerprint, faGlob  import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";  import { action, computed, observable, runInAction } from "mobx";  import { observer } from "mobx-react"; -import { Doc } from "../../../new_fields/Doc"; +import { Doc, DocCastAsync } from "../../../new_fields/Doc";  import { Id } from "../../../new_fields/FieldSymbols";  import { Cast, NumCast, StrCast } from "../../../new_fields/Types";  import { emptyFunction, emptyPath, returnFalse, Utils, returnTrue, returnOne, returnZero } from "../../../Utils"; @@ -22,6 +22,10 @@ import { ContentFittingDocumentView } from "../nodes/ContentFittingDocumentView"  import { SearchBox } from "./SearchBox";  import "./SearchItem.scss";  import "./SelectorContextMenu.scss"; +import { FieldViewProps, FieldView } from "../nodes/FieldView"; +import { ViewBoxBaseComponent } from "../DocComponent"; +import { makeInterface, createSchema } from "../../../new_fields/Schema"; +import { documentSchema } from "../../../new_fields/documentSchemas";  export interface SearchItemProps {      doc: Doc; @@ -122,30 +126,42 @@ export class LinkContextMenu extends React.Component<LinkMenuProps> {  } + +type SearchSchema = makeInterface<[typeof documentSchema]>; + +export const SearchSchema = createSchema({ +    targetDoc: Doc, +}); + +const SearchDocument = makeInterface(documentSchema); + + +  @observer -export class SearchItem extends React.Component<SearchItemProps> { +export class SearchItem extends ViewBoxBaseComponent<FieldViewProps, SearchSchema>(SearchDocument) { +    public static LayoutString(fieldKey: string) { return FieldView.LayoutString(SearchItem, fieldKey); }      @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.props.doc, false); +        DocumentManager.Instance.jumpToDocument(this.targetDoc, false);      }      @observable _useIcons = true;      @observable _displayDim = 50;      componentDidMount() { -        Doc.SetSearchQuery(this.props.query); -        this.props.doc.searchMatch = true; +        Doc.SetSearchQuery(StrCast(this.targetDoc.query)); +        this.targetDoc.searchMatch = true;      }      componentWillUnmount() { -        this.props.doc.searchMatch = undefined; +        this.targetDoc.searchMatch = undefined;      }      //@computed      @action      public DocumentIcon() { -        const layoutresult = StrCast(this.props.doc.type); +        const layoutresult = StrCast(this.targetDoc.type);          if (!this._useIcons) {              const returnXDimension = () => this._useIcons ? 50 : Number(SEARCH_THUMBNAIL_SIZE);              const returnYDimension = () => this._displayDim; @@ -156,10 +172,10 @@ export class SearchItem extends React.Component<SearchItemProps> {                  })}                  onPointerEnter={action(() => this._displayDim = this._useIcons ? 50 : Number(SEARCH_THUMBNAIL_SIZE))} >                  <ContentFittingDocumentView -                    Document={this.props.doc} +                    Document={this.targetDoc}                      LibraryPath={emptyPath}                      rootSelected={returnFalse} -                    fitToBox={StrCast(this.props.doc.type).indexOf(DocumentType.COL) !== -1} +                    fitToBox={StrCast(this.targetDoc.type).indexOf(DocumentType.COL) !== -1}                      addDocument={returnFalse}                      removeDocument={returnFalse}                      addDocTab={returnFalse} @@ -204,36 +220,36 @@ export class SearchItem extends React.Component<SearchItemProps> {      nextHighlight = (e: React.PointerEvent) => {          e.preventDefault();          e.button === 0 && SearchBox.Instance.openSearch(e); -        this.props.doc.searchMatch = false; -        setTimeout(() => this.props.doc.searchMatch = true, 0); +        this.targetDoc!.searchMatch = false; +        setTimeout(() => this.targetDoc!.searchMatch = true, 0);      }      highlightDoc = (e: React.PointerEvent) => { -        if (this.props.doc.type === DocumentType.LINK) { -            if (this.props.doc.anchor1 && this.props.doc.anchor2) { +        // if (this.targetDoc!.type === DocumentType.LINK) { +        //     if (this.targetDoc!.anchor1 && this.targetDoc!.anchor2) { -                const doc1 = Cast(this.props.doc.anchor1, Doc, null); -                const doc2 = Cast(this.props.doc.anchor2, Doc, null); -                Doc.BrushDoc(doc1); -                Doc.BrushDoc(doc2); -            } -        } else { -            Doc.BrushDoc(this.props.doc); -        } +        //         const doc1 = Cast(this.targetDoc!.anchor1, Doc, null); +        //         const doc2 = Cast(this.targetDoc!.anchor2, Doc, null); +        //         Doc.BrushDoc(doc1); +        //         Doc.BrushDoc(doc2); +        //     } +        // } else { +        //     Doc.BrushDoc(this.targetDoc!); +        // }          e.stopPropagation();      }      unHighlightDoc = (e: React.PointerEvent) => { -        if (this.props.doc.type === DocumentType.LINK) { -            if (this.props.doc.anchor1 && this.props.doc.anchor2) { +        // if (this.targetDoc!.type === DocumentType.LINK) { +        //     if (this.targetDoc!.anchor1 && this.targetDoc!.anchor2) { -                const doc1 = Cast(this.props.doc.anchor1, Doc, null); -                const doc2 = Cast(this.props.doc.anchor2, Doc, null); -                Doc.UnBrushDoc(doc1); -                Doc.UnBrushDoc(doc2); -            } -        } else { -            Doc.UnBrushDoc(this.props.doc); -        } +        //         const doc1 = Cast(this.targetDoc!.anchor1, Doc, null); +        //         const doc2 = Cast(this.targetDoc!.anchor2, Doc, null); +        //         Doc.UnBrushDoc(doc1); +        //         Doc.UnBrushDoc(doc2); +        //     } +        // } else { +        //     Doc.UnBrushDoc(this.targetDoc!); +        // }      }      onContextMenu = (e: React.MouseEvent) => { @@ -242,7 +258,7 @@ export class SearchItem extends React.Component<SearchItemProps> {          ContextMenu.Instance.clearItems();          ContextMenu.Instance.addItem({              description: "Copy ID", event: () => { -                Utils.CopyText(this.props.doc[Id]); +                Utils.CopyText(StrCast(this.targetDoc[Id]));              },              icon: "fingerprint"          }); @@ -267,7 +283,7 @@ export class SearchItem extends React.Component<SearchItemProps> {              Math.abs(e.clientY - this._downY) > Utils.DRAG_THRESHOLD) {              document.removeEventListener("pointermove", this.onPointerMoved);              document.removeEventListener("pointerup", this.onPointerUp); -            const doc = Doc.IsPrototype(this.props.doc) ? Doc.MakeDelegate(this.props.doc) : this.props.doc; +            const doc = Doc.IsPrototype(this.targetDoc) ? Doc.MakeDelegate(this.targetDoc) : this.targetDoc;              DragManager.StartDocumentDrag([this._target], new DragManager.DocumentDragData([doc]), e.clientX, e.clientY);          }      } @@ -278,30 +294,33 @@ export class SearchItem extends React.Component<SearchItemProps> {      @computed      get contextButton() { -        return <ParentDocSelector Document={this.props.doc} addDocTab={(doc, where) => CollectionDockingView.AddRightSplit(doc)} />; +        return <ParentDocSelector Document={this.targetDoc} addDocTab={(doc, where) => CollectionDockingView.AddRightSplit(doc)} />;      } +    @computed get searchElementDoc() { return this.rootDoc; } +    @computed get targetDoc() { return this.searchElementDoc?.targetDoc as Doc; } +      render() { -        const doc1 = Cast(this.props.doc.anchor1, Doc); -        const doc2 = Cast(this.props.doc.anchor2, Doc); +        // const doc1 = Cast(this.targetDoc!.anchor1, Doc); +        // const doc2 = Cast(this.targetDoc!.anchor2, Doc);          return <div className="searchItem-overview" onPointerDown={this.pointerDown} onContextMenu={this.onContextMenu}>              <div className="searchItem" onPointerDown={this.nextHighlight} onPointerEnter={this.highlightDoc} onPointerLeave={this.unHighlightDoc}>                  <div className="searchItem-body" onClick={this.onClick}>                      <div className="searchItem-title-container"> -                        <div className="searchItem-title">{StrCast(this.props.doc.title)}</div> -                        <div className="searchItem-highlighting">{this.props.highlighting.length ? "Matched fields:" + this.props.highlighting.join(", ") : 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 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> */} +                        {/* {this.props.lines!.filter((m, i) => i).map((l, i) => <div id={i.toString()} className="searchItem-highlighting">`${l}`</div>)} */}                      </div>                  </div>                  <div className="searchItem-info" style={{ width: this._useIcons ? "30px" : "100%" }}>                      <div className={`icon-${this._useIcons ? "icons" : "live"}`}>                          <div className="searchItem-type" title="Click to Preview" onPointerDown={this.onPointerDown}>{this.DocumentIcon()}</div> -                        <div className="searchItem-label">{this.props.doc.type ? this.props.doc.type : "Other"}</div> +                        <div className="searchItem-label">{this.targetDoc.type ? this.targetDoc.type : "Other"}</div>                      </div>                  </div>                  <div className="searchItem-context" title="Drag as document"> -                    {(doc1 instanceof Doc && doc2 instanceof Doc) && this.props.doc.type === DocumentType.LINK ? <LinkContextMenu doc1={doc1} doc2={doc2} /> : -                        this.contextButton} +                    {/* {(doc1 instanceof Doc && doc2 instanceof Doc) && this.targetDoc!.type === DocumentType.LINK ? <LinkContextMenu doc1={doc1} doc2={doc2} /> : +                        this.contextButton} */}                  </div>              </div>          </div>; diff --git a/src/new_fields/Doc.ts b/src/new_fields/Doc.ts index a1e1e11b1..921891799 100644 --- a/src/new_fields/Doc.ts +++ b/src/new_fields/Doc.ts @@ -1106,4 +1106,12 @@ Scripting.addGlobal(function selectedDocs(container: Doc, excludeCollections: bo      return docs.length ? new List(docs) : prevValue;  });  Scripting.addGlobal(function setDocFilter(container: Doc, key: string, value: any, modifiers?: "check" | "x" | undefined) { Doc.setDocFilter(container, key, value, modifiers); }); -Scripting.addGlobal(function setDocFilterRange(container: Doc, key: string, range: number[]) { Doc.setDocFilterRange(container, key, range); });
\ No newline at end of file +Scripting.addGlobal(function setDocFilterRange(container: Doc, key: string, range: number[]) { Doc.setDocFilterRange(container, key, range); }); +Scripting.addGlobal(function handleNodeChange(doc: any) { +    console.log("oi"); +    doc.handleNodeChange(); +     +    // const dv = DocumentManager.Instance.getDocumentView(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 diff --git a/src/server/authentication/models/current_user_utils.ts b/src/server/authentication/models/current_user_utils.ts index b6ff10bab..782582930 100644 --- a/src/server/authentication/models/current_user_utils.ts +++ b/src/server/authentication/models/current_user_utils.ts @@ -43,7 +43,7 @@ export class CurrentUserUtils {          if (doc["template-button-query"] === undefined) {              const queryTemplate = Docs.Create.MulticolumnDocument(                  [ -                    Docs.Create.QueryDocument({ title: "query", _height: 200 }), +                    Docs.Create.SearchDocument({ title: "query", _height: 200 }),                      Docs.Create.FreeformDocument([], { title: "data", _height: 100, _LODdisable: true })                  ],                  { _width: 400, _height: 300, title: "queryView", _chromeStatus: "disabled", _xMargin: 3, _yMargin: 3, hideFilterView: true } @@ -326,7 +326,7 @@ export class CurrentUserUtils {              { title: "Drag a audio recorder", label: "Audio", icon: "microphone", ignoreClick: true, drag: `Docs.Create.AudioDocument("${nullAudio}", { _width: 200, title: "ready to record audio" })` },              { title: "Drag a clickable button", label: "Btn", icon: "bolt", ignoreClick: true, drag: 'Docs.Create.ButtonDocument({ _width: 150, _height: 50, _xPadding:10, _yPadding: 10, title: "Button" })' },              { title: "Drag a presentation view", label: "Prezi", icon: "tv", click: 'openOnRight(Doc.UserDoc().activePresentation = getCopy(this.dragFactory, true))', drag: `Doc.UserDoc().activePresentation = getCopy(this.dragFactory,true)`, dragFactory: doc.emptyPresentation as Doc }, -            { title: "Drag a search box", label: "Query", icon: "search", ignoreClick: true, drag: 'Docs.Create.QueryDocument({ _width: 200, title: "an image of a cat" })' }, +            { title: "Drag a search box", label: "Query", icon: "search", ignoreClick: true, drag: 'Docs.Create.SearchDocument({ _width: 200, title: "an image of a cat" })' },              { title: "Drag a scripting box", label: "Script", icon: "terminal", ignoreClick: true, drag: 'Docs.Create.ScriptingDocument(undefined, { _width: 200, _height: 250 title: "untitled script" })' },              { title: "Drag an import folder", label: "Load", icon: "cloud-upload-alt", ignoreClick: true, drag: 'Docs.Create.DirectoryImportDocument({ title: "Directory Import", _width: 400, _height: 400 })' },              { title: "Drag a mobile view", label: "Phone", icon: "phone", ignoreClick: true, drag: 'Doc.UserDoc().activeMobile' }, @@ -339,6 +339,7 @@ export class CurrentUserUtils {              { title: "Drag a document previewer", label: "Prev", icon: "expand", click: 'openOnRight(getCopy(this.dragFactory, true))', drag: 'getCopy(this.dragFactory,true)', dragFactory: doc.emptyDocHolder as Doc },              { title: "Toggle a Calculator REPL", label: "repl", icon: "calculator", click: 'addOverlayWindow("ScriptingRepl", { x: 300, y: 100, width: 200, height: 200, title: "Scripting REPL" })' },              { title: "Connect a Google Account", label: "Google Account", icon: "external-link-alt", click: 'GoogleAuthenticationManager.Instance.fetchOrGenerateAccessToken(true)' }, +            { title: "query", icon: "bolt", label: "Col", ignoreClick: true, drag: 'Docs.Create.SearchDocument({ _width: 200, title: "an image of a cat" })' },          ];      } @@ -556,7 +557,7 @@ export class CurrentUserUtils {              doc["tabs-button-search"] = new PrefetchProxy(Docs.Create.ButtonDocument({                  _width: 50, _height: 25, title: "Search", _fontSize: 10,                  letterSpacing: "0px", textTransform: "unset", borderRounding: "5px 5px 0px 0px", boxShadow: "3px 3px 0px rgb(34, 34, 34)", -                sourcePanel: new PrefetchProxy(Docs.Create.QueryDocument({ title: "search stack", })) as any as Doc, +                sourcePanel: new PrefetchProxy(Docs.Create.SearchDocument({ title: "search stack", })) as any as Doc,                  searchFileTypes: new List<string>([DocumentType.RTF, DocumentType.IMG, DocumentType.PDF, DocumentType.VID, DocumentType.WEB, DocumentType.SCRIPTING]),                  targetContainer: new PrefetchProxy(sidebarContainer) as any as Doc,                  lockedPosition: true, @@ -632,6 +633,12 @@ 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" +            })); +        }          if (doc.activePresentation === undefined) {              doc.activePresentation = Docs.Create.PresDocument(new List<Doc>(), {                  title: "Presentation", _viewType: CollectionViewType.Stacking, targetDropAction: "alias", | 
