diff options
| -rw-r--r-- | package-lock.json | 37 | ||||
| -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/SearchDocBox.tsx | 431 | ||||
| -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 | 3 | ||||
| -rw-r--r-- | src/client/views/nodes/LabelBox.tsx | 16 | ||||
| -rw-r--r-- | src/client/views/nodes/QueryBox.tsx | 18 | ||||
| -rw-r--r-- | src/client/views/search/SearchBox.scss | 58 | ||||
| -rw-r--r-- | src/client/views/search/SearchBox.tsx | 421 | ||||
| -rw-r--r-- | src/client/views/search/SearchItem.tsx | 69 | ||||
| -rw-r--r-- | src/new_fields/Doc.ts | 10 | ||||
| -rw-r--r-- | src/server/authentication/models/current_user_utils.ts | 9 | 
16 files changed, 541 insertions, 575 deletions
| diff --git a/package-lock.json b/package-lock.json index bc8ca01f5..6c7874fc8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2723,6 +2723,43 @@                  }              }          }, +        "canvas": { +            "version": "2.6.1", +            "resolved": "https://registry.npmjs.org/canvas/-/canvas-2.6.1.tgz", +            "integrity": "sha512-S98rKsPcuhfTcYbtF53UIJhcbgIAK533d1kJKMwsMwAIFgfd58MOyxRud3kktlzWiEkFliaJtvyZCBtud/XVEA==", +            "requires": { +                "nan": "^2.14.0", +                "node-pre-gyp": "^0.11.0", +                "simple-get": "^3.0.3" +            }, +            "dependencies": { +                "node-pre-gyp": { +                    "version": "0.11.0", +                    "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz", +                    "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==", +                    "requires": { +                        "detect-libc": "^1.0.2", +                        "mkdirp": "^0.5.1", +                        "needle": "^2.2.1", +                        "nopt": "^4.0.1", +                        "npm-packlist": "^1.1.6", +                        "npmlog": "^4.0.2", +                        "rc": "^1.2.7", +                        "rimraf": "^2.6.1", +                        "semver": "^5.3.0", +                        "tar": "^4" +                    } +                }, +                "rimraf": { +                    "version": "2.7.1", +                    "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", +                    "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", +                    "requires": { +                        "glob": "^7.1.3" +                    } +                } +            } +        },          "capture-stack-trace": {              "version": "1.0.1",              "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz", 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..657969121 100644 --- a/solr-8.3.1/bin/solr-8983.pid +++ b/solr-8.3.1/bin/solr-8983.pid @@ -1 +1 @@ -17656 +5763 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 811bb5fb2..79a1d1303 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/DocumentBox"; @@ -157,10 +162,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 { @@ -190,8 +197,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, { @@ -276,6 +283,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" } @@ -533,8 +543,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 = {}) { @@ -675,6 +685,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/SearchDocBox.tsx b/src/client/views/SearchDocBox.tsx deleted file mode 100644 index 799fa9d85..000000000 --- a/src/client/views/SearchDocBox.tsx +++ /dev/null @@ -1,431 +0,0 @@ -import { library } from "@fortawesome/fontawesome-svg-core"; -import { faBullseye, faLink } from "@fortawesome/free-solid-svg-icons"; -import { action, computed, observable, runInAction } from "mobx"; -import { observer } from "mobx-react"; -//import "./SearchBoxDoc.scss"; -import { Doc, DocListCast } from "../../new_fields/Doc"; -import { Id } from "../../new_fields/FieldSymbols"; -import { BoolCast, Cast, NumCast, StrCast } from "../../new_fields/Types"; -import { returnFalse } from "../../Utils"; -import { Docs } from "../documents/Documents"; -import { SearchUtil } from "../util/SearchUtil"; -import { EditableView } from "./EditableView"; -import { ContentFittingDocumentView } from "./nodes/ContentFittingDocumentView"; -import { FieldView, FieldViewProps } from "./nodes/FieldView"; -import { FilterBox } from "./search/FilterBox"; -import { SearchItem } from "./search/SearchItem"; -import React = require("react"); - -export interface RecProps { -    documents: { preview: Doc, similarity: number }[]; -    node: Doc; - -} - -library.add(faBullseye, faLink); -export const keyPlaceholder = "Query"; - -@observer -export class SearchDocBox extends React.Component<FieldViewProps> { - -    public static LayoutString(fieldKey: string) { return FieldView.LayoutString(SearchDocBox, fieldKey); } - -    // @observable private _display: boolean = false; -    @observable private _pageX: number = 0; -    @observable private _pageY: number = 0; -    @observable private _width: number = 0; -    @observable private _height: number = 0; -    @observable.shallow private _docViews: JSX.Element[] = []; -    // @observable private _documents: { preview: Doc, score: number }[] = []; -    private previewDocs: Doc[] = []; - -    constructor(props: FieldViewProps) { -        super(props); -        this.editingMetadata = this.editingMetadata || false; -        //SearchBox.Instance = this; -        this.resultsScrolled = this.resultsScrolled.bind(this); -    } - - -    @computed -    private get editingMetadata() { -        return BoolCast(this.props.Document.editingMetadata); -    } - -    private set editingMetadata(value: boolean) { -        this.props.Document.editingMetadata = value; -    } - -    static readonly buffer = 20; - -    componentDidMount() { -        runInAction(() => { -            console.log("didit" -            ); -            this.query = StrCast(this.props.Document.searchText); -            this.content = (Docs.Create.TreeDocument(DocListCast(Doc.GetProto(this.props.Document).data), { _width: 200, _height: 400, _chromeStatus: "disabled", title: `Search Docs:` + this.query })); - -        }); -        if (this.inputRef.current) { -            this.inputRef.current.focus(); -            runInAction(() => { -                this._searchbarOpen = true; -            }); -        } -    } - -    @observable -    private content: Doc | undefined; - -    @action -    updateKey = async (newKey: string) => { -        this.query = newKey; -        if (newKey.length > 1) { -            const newdocs = await this.getAllResults(this.query); -            const things = newdocs.docs; -            console.log(things); -            console.log(this.content); -            runInAction(() => { -                this.content = Docs.Create.TreeDocument(things, { _width: 200, _height: 400, _chromeStatus: "disabled", title: `Search Docs:` + this.query }); -            }); -            console.log(this.content); -        } - - -        //this.keyRef.current && this.keyRef.current.setIsFocused(false); -        //this.query.length === 0 && (this.query = keyPlaceholder); -        return true; -    } - -    @computed -    public get query() { -        return StrCast(this.props.Document.query); -    } - -    public set query(value: string) { -        this.props.Document.query = value; -    } - -    @observable private _searchString: string = ""; -    @observable private _resultsOpen: boolean = false; -    @observable private _searchbarOpen: boolean = false; -    @observable private _results: [Doc, string[], string[]][] = []; -    private _resultsSet = new Map<Doc, number>(); -    @observable private _openNoResults: boolean = false; -    @observable private _visibleElements: JSX.Element[] = []; - -    private resultsRef = React.createRef<HTMLDivElement>(); -    public inputRef = React.createRef<HTMLInputElement>(); - -    private _isSearch: ("search" | "placeholder" | undefined)[] = []; -    private _numTotalResults = -1; -    private _endIndex = -1; - - -    private _maxSearchIndex: number = 0; -    private _curRequest?: Promise<any> = undefined; - -    @action -    getViews = async (doc: Doc) => { -        const results = await SearchUtil.GetViewsOfDocument(doc); -        let toReturn: Doc[] = []; -        await runInAction(() => { -            toReturn = results; -        }); -        return toReturn; -    } - -    @action.bound -    onChange(e: React.ChangeEvent<HTMLInputElement>) { -        this._searchString = e.target.value; - -        this._openNoResults = false; -        this._results = []; -        this._resultsSet.clear(); -        this._visibleElements = []; -        this._numTotalResults = -1; -        this._endIndex = -1; -        this._curRequest = undefined; -        this._maxSearchIndex = 0; -    } - -    enter = async (e: React.KeyboardEvent) => { -        console.log(e.key); -        if (e.key === "Enter") { -            const newdocs = await this.getAllResults(this.query); -            console.log(newdocs.docs); -            this.content = Docs.Create.TreeDocument(newdocs.docs, { _width: 200, _height: 400, _chromeStatus: "disabled", title: `Search Docs: "Results"` }); - -        } -    } - - -    @action -    submitSearch = async () => { -        let query = this._searchString; -        query = FilterBox.Instance.getFinalQuery(query); -        this._results = []; -        this._resultsSet.clear(); -        this._isSearch = []; -        this._visibleElements = []; -        FilterBox.Instance.closeFilter(); - -        //if there is no query there should be no result -        if (query === "") { -            return; -        } -        else { -            this._endIndex = 12; -            this._maxSearchIndex = 0; -            this._numTotalResults = -1; -            await this.getResults(query); -        } - -        runInAction(() => { -            this._resultsOpen = true; -            this._searchbarOpen = true; -            this._openNoResults = true; -            this.resultsScrolled(); -        }); -    } - -    getAllResults = async (query: string) => { -        return SearchUtil.Search(query, true, { fq: this.filterQuery, start: 0, rows: 10000000 }); -    } - -    private get filterQuery() { -        const types = FilterBox.Instance.filterTypes; -        const includeDeleted = FilterBox.Instance.getDataStatus(); -        return "NOT baseProto_b:true" + (includeDeleted ? "" : " AND NOT deleted_b:true") + (types ? ` AND (${types.map(type => `({!join from=id to=proto_i}type_t:"${type}" AND NOT type_t:*) OR type_t:"${type}" OR type_t:"extension"`).join(" ")})` : ""); -    } - - -    private NumResults = 25; -    private lockPromise?: Promise<void>; -    getResults = async (query: string) => { -        if (this.lockPromise) { -            await this.lockPromise; -        } -        this.lockPromise = new Promise(async res => { -            while (this._results.length <= this._endIndex && (this._numTotalResults === -1 || this._maxSearchIndex < this._numTotalResults)) { -                this._curRequest = SearchUtil.Search(query, true, { fq: this.filterQuery, start: this._maxSearchIndex, rows: this.NumResults, hl: true, "hl.fl": "*" }).then(action(async (res: SearchUtil.DocSearchResult) => { - -                    // happens at the beginning -                    if (res.numFound !== this._numTotalResults && this._numTotalResults === -1) { -                        this._numTotalResults = res.numFound; -                    } - -                    const highlighting = res.highlighting || {}; -                    const highlightList = res.docs.map(doc => highlighting[doc[Id]]); -                    const lines = new Map<string, string[]>(); -                    res.docs.map((doc, i) => lines.set(doc[Id], res.lines[i])); -                    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 = FilterBox.Instance.filterDocsByType(docs); -                    runInAction(() => { -                        // this._results.push(...filteredDocs); -                        filteredDocs.forEach(doc => { -                            const index = this._resultsSet.get(doc); -                            const highlight = highlights[doc[Id]]; -                            const line = lines.get(doc[Id]) || []; -                            const hlights = highlight ? Object.keys(highlight).map(key => key.substring(0, key.length - 2)) : []; -                            if (index === undefined) { -                                this._resultsSet.set(doc, this._results.length); -                                this._results.push([doc, hlights, line]); -                            } else { -                                this._results[index][1].push(...hlights); -                                this._results[index][2].push(...line); -                            } -                        }); -                    }); - -                    this._curRequest = undefined; -                })); -                this._maxSearchIndex += this.NumResults; - -                await this._curRequest; -            } -            this.resultsScrolled(); -            res(); -        }); -        return this.lockPromise; -    } - -    collectionRef = React.createRef<HTMLSpanElement>(); -    startDragCollection = async () => { -        const res = await this.getAllResults(FilterBox.Instance.getFinalQuery(this._searchString)); -        const filtered = FilterBox.Instance.filterDocsByType(res.docs); -        // console.log(this._results) -        const docs = filtered.map(doc => { -            const isProto = Doc.GetT(doc, "isPrototype", "boolean", true); -            if (isProto) { -                return Doc.MakeDelegate(doc); -            } else { -                return Doc.MakeAlias(doc); -            } -        }); -        let x = 0; -        let y = 0; -        for (const doc of docs.map(d => Doc.Layout(d))) { -            doc.x = x; -            doc.y = y; -            const size = 200; -            const aspect = NumCast(doc._nativeHeight) / NumCast(doc._nativeWidth, 1); -            if (aspect > 1) { -                doc._height = size; -                doc._width = size / aspect; -            } else if (aspect > 0) { -                doc._width = size; -                doc._height = size * aspect; -            } else { -                doc._width = size; -                doc._height = size; -            } -            x += 250; -            if (x > 1000) { -                x = 0; -                y += 300; -            } -        } -        //return Docs.Create.TreeDocument(docs, { _width: 200, _height: 400, backgroundColor: "grey", title: `Search Docs: "${this._searchString}"` }); -        return Docs.Create.QueryDocument({ _width: 200, _height: 400, searchText: this._searchString, title: `Query Docs: "${this._searchString}"` }); -    } - -    @action.bound -    openSearch(e: React.SyntheticEvent) { -        e.stopPropagation(); -        this._openNoResults = false; -        FilterBox.Instance.closeFilter(); -        this._resultsOpen = true; -        this._searchbarOpen = true; -        FilterBox.Instance._pointerTime = e.timeStamp; -    } - -    @action.bound -    closeSearch = () => { -        FilterBox.Instance.closeFilter(); -        this.closeResults(); -        this._searchbarOpen = false; -    } - -    @action.bound -    closeResults() { -        this._resultsOpen = false; -        this._results = []; -        this._resultsSet.clear(); -        this._visibleElements = []; -        this._numTotalResults = -1; -        this._endIndex = -1; -        this._curRequest = undefined; -    } - -    @action -    resultsScrolled = (e?: React.UIEvent<HTMLDivElement>) => { -        if (!this.resultsRef.current) return; -        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))); - -        this._endIndex = endIndex === -1 ? 12 : endIndex; - -        if ((this._numTotalResults === 0 || this._results.length === 0) && this._openNoResults) { -            this._visibleElements = [<div className="no-result">No Search Results</div>]; -            return; -        } - -        if (this._numTotalResults <= this._maxSearchIndex) { -            this._numTotalResults = this._results.length; -        } - -        // only hit right at the beginning -        // visibleElements is all of the elements (even the ones you can't see) -        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._isSearch = Array<undefined>(this._numTotalResults === -1 ? 0 : this._numTotalResults); -        } - -        for (let i = 0; i < this._numTotalResults; i++) { -            //if the index is out of the window then put a placeholder in -            //should ones that have already been found get set to placeholders? -            if (i < startIndex || i > endIndex) { -                if (this._isSearch[i] !== "placeholder") { -                    this._isSearch[i] = "placeholder"; -                    this._visibleElements[i] = <div className="searchBox-placeholder" key={`searchBox-placeholder-${i}`}>Loading...</div>; -                } -            } -            else { -                if (this._isSearch[i] !== "search") { -                    let result: [Doc, string[], string[]] | undefined = undefined; -                    if (i >= this._results.length) { -                        this.getResults(this._searchString); -                        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} />; -                            this._isSearch[i] = "search"; -                        } -                    } -                    else { -                        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} />; -                            this._isSearch[i] = "search"; -                        } -                    } -                } -            } -        } -        if (this._maxSearchIndex >= this._numTotalResults) { -            this._visibleElements.length = this._results.length; -            this._isSearch.length = this._results.length; -        } -    } - -    @computed -    get resFull() { return this._numTotalResults <= 8; } - -    @computed -    get resultHeight() { return this._numTotalResults * 70; } - -    render() { -        const isEditing = this.editingMetadata; -        return !this.content ? (null) : ( -            <div style={{ pointerEvents: "all" }}> -                <ContentFittingDocumentView {...this.props} -                    Document={this.content} -                    rootSelected={returnFalse} -                    getTransform={this.props.ScreenToLocalTransform}> -                </ContentFittingDocumentView> -                <div -                    style={{ -                        position: "absolute", -                        right: 0, -                        width: 20, -                        height: 20, -                        background: "black", -                        pointerEvents: "all", -                        opacity: 1, -                        transition: "0.4s opacity ease", -                        zIndex: 99, -                        top: 0, -                    }} -                    title={"Add Metadata"} -                    onClick={action(() => this.editingMetadata = !this.editingMetadata)} -                /> -                <div className="editableclass" onKeyPress={this.enter} style={{ opacity: isEditing ? 1 : 0, pointerEvents: isEditing ? "auto" : "none", transition: "0.4s opacity ease", position: "absolute", top: 0, left: 0, height: 20, width: "-webkit-fill-available" }}> -                    <EditableView -                        contents={this.query} -                        SetValue={this.updateKey} -                        GetValue={() => ""} -                    /> -                </div> -            </div > -        ); -    } - -}
\ No newline at end of file diff --git a/src/client/views/nodes/DocumentContentsView.tsx b/src/client/views/nodes/DocumentContentsView.tsx index 4d20d3e2c..9c8765906 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"; @@ -196,7 +197,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 fdcaa2df3..8f3977b92 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -1150,7 +1150,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 0b9edbcd3..6bb1987ef 100644 --- a/src/client/views/nodes/FieldView.tsx +++ b/src/client/views/nodes/FieldView.tsx @@ -51,6 +51,9 @@ export interface FieldViewProps {      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 3cdec8acb..29ce0b43f 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 76885eada..bc6f6988b 100644 --- a/src/client/views/nodes/QueryBox.tsx +++ b/src/client/views/nodes/QueryBox.tsx @@ -27,15 +27,17 @@ export class QueryBox extends ViewBoxAnnotatableComponent<FieldViewProps, QueryD      }      render() { +        let side = false; +        if (this.dataDoc.searchQuery===undefined){ +            console.log("YAAA"); +            side = true; +        }          const dragging = !SelectionManager.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)} /> +             +            <SearchBox  Document={this.props.Document}  />          </div >;      } -}
\ No newline at end of file +} + +//<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..a4f1b7d34 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,8 +64,20 @@ 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); } @@ -48,6 +86,7 @@ export class SearchBox extends React.Component<SearchProps> {      @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 +109,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 +224,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 +340,14 @@ export class SearchBox extends React.Component<SearchProps> {      @action      submitSearch = async () => { +        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; @@ -404,7 +467,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 +497,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 +509,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 +528,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 +550,16 @@ 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} />; +                            debugger; +                            Doc.AddDocToList(this.dataDoc, this.props.fieldKey, result[0]) +                            //this.fieldkey + dash search results +                            //ask about document parmater in collection view                              this._isSearch[i] = "search";                          }                      } @@ -485,7 +567,14 @@ 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} />; +                            debugger; + +                            Doc.AddDocToList(this.dataDoc, this.props.fieldKey, result[0])                              this._isSearch[i] = "search";                          }                      } @@ -494,6 +583,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 +602,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 +616,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 +627,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 +646,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 +718,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 +928,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} +                     +                                      </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 fe2000700..f25464eb0 100644 --- a/src/client/views/search/SearchItem.tsx +++ b/src/client/views/search/SearchItem.tsx @@ -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 } from "../../../new_fields/Schema"; +import { documentSchema } from "../../../new_fields/documentSchemas";  export interface SearchItemProps {      doc: Doc; @@ -122,30 +126,35 @@ export class LinkContextMenu extends React.Component<LinkMenuProps> {  } + +type SearchSchema = makeInterface<[typeof documentSchema]>; +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.props.doc!, false);      }      @observable _useIcons = true;      @observable _displayDim = 50;      componentDidMount() { -        Doc.SetSearchQuery(this.props.query); -        this.props.doc.searchMatch = true; +        Doc.SetSearchQuery(StrCast(this.props.doc!.query)); +        this.props.doc!.searchMatch = true;      }      componentWillUnmount() { -        this.props.doc.searchMatch = undefined; +        this.props.doc!.searchMatch = undefined;      }      //@computed      @action      public DocumentIcon() { -        const layoutresult = StrCast(this.props.doc.type); +        const layoutresult = StrCast(this.props.doc!.type);          if (!this._useIcons) {              const returnXDimension = () => this._useIcons ? 50 : Number(SEARCH_THUMBNAIL_SIZE);              const returnYDimension = () => this._displayDim; @@ -156,10 +165,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.props.doc!}                      LibraryPath={emptyPath}                      rootSelected={returnFalse} -                    fitToBox={StrCast(this.props.doc.type).indexOf(DocumentType.COL) !== -1} +                    fitToBox={StrCast(this.props.doc!.type).indexOf(DocumentType.COL) !== -1}                      addDocument={returnFalse}                      removeDocument={returnFalse}                      addDocTab={returnFalse} @@ -198,35 +207,35 @@ 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.props.doc!.searchMatch = false; +        setTimeout(() => this.props.doc!.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.props.doc!.type === DocumentType.LINK) { +            if (this.props.doc!.anchor1 && this.props.doc!.anchor2) { -                const doc1 = Cast(this.props.doc.anchor1, Doc, null); -                const doc2 = Cast(this.props.doc.anchor2, Doc, null); +                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); +            Doc.BrushDoc(this.props.doc!);          }          e.stopPropagation();      }      unHighlightDoc = (e: React.PointerEvent) => { -        if (this.props.doc.type === DocumentType.LINK) { -            if (this.props.doc.anchor1 && this.props.doc.anchor2) { +        if (this.props.doc!.type === DocumentType.LINK) { +            if (this.props.doc!.anchor1 && this.props.doc!.anchor2) { -                const doc1 = Cast(this.props.doc.anchor1, Doc, null); -                const doc2 = Cast(this.props.doc.anchor2, Doc, null); +                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); +            Doc.UnBrushDoc(this.props.doc!);          }      } @@ -236,7 +245,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(this.props.doc![Id]);              },              icon: "fingerprint"          }); @@ -261,7 +270,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.props.doc!) ? Doc.MakeDelegate(this.props.doc!) : this.props.doc!;              DragManager.StartDocumentDrag([this._target], new DragManager.DocumentDragData([doc]), e.clientX, e.clientY);          }      } @@ -272,29 +281,29 @@ 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.props.doc!} addDocTab={(doc, where) => CollectionDockingView.AddRightSplit(doc)} />;      }      render() { -        const doc1 = Cast(this.props.doc.anchor1, Doc); -        const doc2 = Cast(this.props.doc.anchor2, Doc); +        const doc1 = Cast(this.props.doc!.anchor1, Doc); +        const doc2 = Cast(this.props.doc!.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.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>                  </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.props.doc!.type ? this.props.doc!.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} /> : +                    {(doc1 instanceof Doc && doc2 instanceof Doc) && this.props.doc!.type === DocumentType.LINK ? <LinkContextMenu doc1={doc1} doc2={doc2} /> :                          this.contextButton}                  </div>              </div> diff --git a/src/new_fields/Doc.ts b/src/new_fields/Doc.ts index 153af933a..4fe52fd30 100644 --- a/src/new_fields/Doc.ts +++ b/src/new_fields/Doc.ts @@ -1055,4 +1055,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 4b2aafac1..ba5ada6c4 100644 --- a/src/server/authentication/models/current_user_utils.ts +++ b/src/server/authentication/models/current_user_utils.ts @@ -42,7 +42,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 } @@ -267,7 +267,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' }, @@ -279,6 +279,8 @@ export class CurrentUserUtils {              // { title: "use drag", icon: "mouse-pointer", click: 'deactivateInk();this.activePen.inkPen = this;', ischecked: `sameDocs(this.activePen.inkPen, this)`, backgroundColor: "white", activePen: doc },              { title: "Drag a document previewer", label: "Prev", icon: "expand", ignoreClick: true, drag: 'Docs.Create.DocumentDocument(ComputedField.MakeFunction("selectedDocs(this,this.excludeCollections,[_last_])?.[0]"), { _width: 250, _height: 250, title: "container" })' },              { title: "Drag a Calculator REPL", label: "repl", icon: "calculator", click: 'addOverlayWindow("ScriptingRepl", { x: 300, y: 100, width: 200, height: 200, title: "Scripting REPL" })' }, +            { title: "query", icon: "bolt", label: "Col", ignoreClick: true, drag: 'Docs.Create.SearchDocument({ _width: 200, title: "an image of a cat" })' }, +          ];      } @@ -495,7 +497,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, @@ -571,6 +573,7 @@ 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" | 
