| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
 | import { IconProp } from '@fortawesome/fontawesome-svg-core';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { Tooltip } from '@material-ui/core';
import { action, observable, runInAction } from 'mobx';
import { observer } from "mobx-react";
import { Doc, DocListCast } from '../../../fields/Doc';
import { Cast, StrCast } from '../../../fields/Types';
import { WebField } from '../../../fields/URLField';
import { emptyFunction, setupMoveUpEvents, returnFalse, returnTrue, returnEmptyDoclist, returnEmptyFilter } from '../../../Utils';
import { DocumentType } from '../../documents/DocumentTypes';
import { DocumentManager } from '../../util/DocumentManager';
import { DragManager } from '../../util/DragManager';
import { Hypothesis } from '../../util/HypothesisUtils';
import { LinkManager } from '../../util/LinkManager';
import { undoBatch } from '../../util/UndoManager';
import { DocumentLinksButton } from '../nodes/DocumentLinksButton';
import { DocumentView, DocumentViewSharedProps } from '../nodes/DocumentView';
import { LinkDocPreview } from '../nodes/LinkDocPreview';
import './LinkPopup.scss';
import React = require("react");
import { CurrentUserUtils } from '../../util/CurrentUserUtils';
import { DefaultStyleProvider } from '../StyleProvider';
import { Transform } from '../../util/Transform';
import { DocUtils } from '../../documents/Documents';
import { SearchBox } from '../search/SearchBox';
import { EditorView } from 'prosemirror-view';
import { FormattedTextBox } from '../nodes/formattedText/FormattedTextBox';
interface LinkPopupProps {
    showPopup: boolean;
    // groupType: string;
    // linkDoc: Doc;
    // docView: DocumentView;
    // sourceDoc: Doc;
}
/**
 * Popup component for creating links from text to Dash documents 
 */
@observer
export class LinkPopup extends React.Component<LinkPopupProps> {
    @observable private linkURL: string = "";
    @observable public view?: EditorView;
    // TODO: should check for valid URL
    @undoBatch
    makeLinkToURL = (target: string, lcoation: string) => {
        ((this.view as any)?.TextView as FormattedTextBox).makeLinkAnchor(undefined, "onRadd:rightight", target, target);
    }
    @action
    onLinkChange = (e: React.ChangeEvent<HTMLInputElement>) => {
        this.linkURL = e.target.value;
        console.log(this.linkURL)
    }
    getPWidth = () => 500;
    getPHeight = () => 500;
    render() {
        const popupVisibility = this.props.showPopup ? "block" : "none";
        return (
            <div className="linkPopup-container" style={{ display: popupVisibility }}>
                <div className="linkPopup-url-container">
                    <input autoComplete="off" type="text" value={this.linkURL} placeholder="Enter URL..." onChange={this.onLinkChange} />
                    <button onPointerDown={e => this.makeLinkToURL(this.linkURL, "add:right")}
                        style={{ display: "block", margin: "10px auto", }}>Apply hyperlink</button>
                </div>
                <div className="divider">
                    <div className="line"></div>
                    <p className="divider-text">or</p>
                </div>
                <div className="linkPopup-document-search-container">
                    {/* <i></i>
                    <input defaultValue={""} autoComplete="off" type="text" placeholder="Search for Document..." id="search-input"
                        className="linkPopup-searchBox searchBox-input" /> */}
                    <SearchBox Document={CurrentUserUtils.MySearchPanelDoc}
                        DataDoc={CurrentUserUtils.MySearchPanelDoc}
                        fieldKey="data"
                        dropAction="move"
                        isSelected={returnTrue}
                        isContentActive={returnTrue}
                        select={returnTrue}
                        setHeight={returnFalse}
                        addDocument={undefined}
                        addDocTab={returnTrue}
                        pinToPres={emptyFunction}
                        rootSelected={returnTrue}
                        styleProvider={DefaultStyleProvider}
                        layerProvider={undefined}
                        removeDocument={undefined}
                        ScreenToLocalTransform={Transform.Identity}
                        PanelWidth={this.getPWidth}
                        PanelHeight={this.getPHeight}
                        renderDepth={0}
                        focus={DocUtils.DefaultFocus}
                        docViewPath={returnEmptyDoclist}
                        whenChildContentsActiveChanged={emptyFunction}
                        bringToFront={emptyFunction}
                        docFilters={returnEmptyFilter}
                        docRangeFilters={returnEmptyFilter}
                        searchFilterDocs={returnEmptyDoclist}
                        ContainingCollectionView={undefined}
                        ContainingCollectionDoc={undefined} />
                </div>
            </div>
        );
    }
}
 |