diff options
| -rw-r--r-- | package-lock.json | 192 | ||||
| -rw-r--r-- | src/.DS_Store | bin | 6148 -> 8196 bytes | |||
| -rw-r--r-- | src/client/documents/Documents.ts | 5 | ||||
| -rw-r--r-- | src/client/views/EditableView.tsx | 9 | ||||
| -rw-r--r-- | src/client/views/nodes/ScriptingBox.scss | 52 | ||||
| -rw-r--r-- | src/client/views/nodes/ScriptingBox.tsx | 178 | ||||
| -rw-r--r-- | src/server/database.ts | 1 | ||||
| -rw-r--r-- | src/server/index.ts | 9 | 
8 files changed, 332 insertions, 114 deletions
| diff --git a/package-lock.json b/package-lock.json index e3f7fa018..9bd1db03d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -5529,18 +5529,81 @@                  "to-regex": "^3.0.1"              },              "dependencies": { -                "define-property": { +                "abbrev": { +                    "version": "1.1.1", +                    "bundled": true, +                    "optional": true +                }, +                "ansi-regex": { +                    "version": "2.1.1", +                    "bundled": true, +                    "optional": true +                }, +                "aproba": { +                    "version": "1.2.0", +                    "bundled": true, +                    "optional": true +                }, +                "are-we-there-yet": { +                    "version": "1.1.5", +                    "bundled": true, +                    "optional": true, +                    "requires": { +                        "delegates": "^1.0.0", +                        "readable-stream": "^2.0.6" +                    } +                }, +                "balanced-match": {                      "version": "1.0.0", -                    "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", -                    "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", +                    "bundled": true, +                    "optional": true +                }, +                "bindings": { +                    "version": "1.5.0", +                    "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", +                    "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", +                    "optional": true, +                    "requires": { +                        "file-uri-to-path": "1.0.0" +                    } +                }, +                "brace-expansion": { +                    "version": "1.1.11", +                    "bundled": true, +                    "optional": true,                      "requires": {                          "is-descriptor": "^1.0.0"                      }                  }, -                "extend-shallow": { -                    "version": "2.0.1", -                    "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", -                    "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", +                "chownr": { +                    "version": "1.1.4", +                    "bundled": true, +                    "optional": true +                }, +                "code-point-at": { +                    "version": "1.1.0", +                    "bundled": true, +                    "optional": true +                }, +                "concat-map": { +                    "version": "0.0.1", +                    "bundled": true, +                    "optional": true +                }, +                "console-control-strings": { +                    "version": "1.1.0", +                    "bundled": true, +                    "optional": true +                }, +                "core-util-is": { +                    "version": "1.0.2", +                    "bundled": true, +                    "optional": true +                }, +                "debug": { +                    "version": "3.2.6", +                    "bundled": true, +                    "optional": true,                      "requires": {                          "is-extendable": "^0.1.0"                      } @@ -5571,82 +5634,20 @@                          "kind-of": "^6.0.2"                      }                  }, -                "is-extendable": { -                    "version": "0.1.1", -                    "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", -                    "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" -                } -            } -        }, -        "extsprintf": { -            "version": "1.3.0", -            "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", -            "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" -        }, -        "fast-deep-equal": { -            "version": "3.1.1", -            "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", -            "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==" -        }, -        "fast-json-stable-stringify": { -            "version": "2.1.0", -            "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", -            "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" -        }, -        "fast-levenshtein": { -            "version": "2.0.6", -            "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", -            "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", -            "dev": true -        }, -        "fast-text-encoding": { -            "version": "1.0.2", -            "resolved": "https://registry.npmjs.org/fast-text-encoding/-/fast-text-encoding-1.0.2.tgz", -            "integrity": "sha512-5rQdinSsycpzvAoHga2EDn+LRX1d5xLFsuNG0Kg61JrAT/tASXcLL0nf/33v+sAxlQcfYmWbTURa1mmAf55jGw==" -        }, -        "faye-websocket": { -            "version": "0.10.0", -            "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", -            "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", -            "dev": true, -            "requires": { -                "websocket-driver": ">=0.5.1" -            } -        }, -        "fbjs": { -            "version": "0.8.17", -            "resolved": "https://registry.npmjs.org/fbjs/-/fbjs-0.8.17.tgz", -            "integrity": "sha1-xNWY6taUkRJlPWWIsBpc3Nn5D90=", -            "requires": { -                "core-js": "^1.0.0", -                "isomorphic-fetch": "^2.1.1", -                "loose-envify": "^1.0.0", -                "object-assign": "^4.1.0", -                "promise": "^7.1.1", -                "setimmediate": "^1.0.5", -                "ua-parser-js": "^0.7.18" -            } -        }, -        "feedparser": { -            "version": "2.2.9", -            "resolved": "https://registry.npmjs.org/feedparser/-/feedparser-2.2.9.tgz", -            "integrity": "sha1-kTgZfa/a4F/K3eADa+6vYGbCxek=", -            "requires": { -                "addressparser": "^1.0.1", -                "array-indexofobject": "~0.0.1", -                "lodash.assign": "^4.2.0", -                "lodash.get": "^4.4.2", -                "lodash.has": "^4.5.2", -                "lodash.uniq": "^4.5.0", -                "mri": "^1.1.0", -                "readable-stream": "^2.2.2", -                "sax": "^1.2.4" -            }, -            "dependencies": { -                "readable-stream": { -                    "version": "2.3.7", -                    "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", -                    "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", +                "inherits": { +                    "version": "2.0.4", +                    "bundled": true, +                    "optional": true +                }, +                "ini": { +                    "version": "1.3.5", +                    "bundled": true, +                    "optional": true +                }, +                "is-fullwidth-code-point": { +                    "version": "1.0.0", +                    "bundled": true, +                    "optional": true,                      "requires": {                          "core-util-is": "~1.0.0",                          "inherits": "~2.0.3", @@ -5677,9 +5678,26 @@              "dependencies": {                  "schema-utils": {                      "version": "1.0.0", -                    "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", -                    "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", -                    "dev": true, +                    "bundled": true, +                    "optional": true +                }, +                "minimatch": { +                    "version": "3.0.4", +                    "bundled": true, +                    "optional": true, +                    "requires": { +                        "brace-expansion": "^1.1.7" +                    } +                }, +                "minimist": { +                    "version": "1.2.5", +                    "bundled": true, +                    "optional": true +                }, +                "minipass": { +                    "version": "2.9.0", +                    "bundled": true, +                    "optional": true,                      "requires": {                          "ajv": "^6.1.0",                          "ajv-errors": "^1.0.0", @@ -18739,4 +18757,4 @@              }          }      } -} +}
\ No newline at end of file diff --git a/src/.DS_Store b/src/.DS_StoreBinary files differ index 5b35884bd..942a5672b 100644 --- a/src/.DS_Store +++ b/src/.DS_Store diff --git a/src/client/documents/Documents.ts b/src/client/documents/Documents.ts index 18a0b43ff..471045400 100644 --- a/src/client/documents/Documents.ts +++ b/src/client/documents/Documents.ts @@ -699,6 +699,11 @@ export namespace Docs {          }          export function ButtonDocument(options?: DocumentOptions) { +            // const btn = InstanceFromProto(Prototypes.get(DocumentType.BUTTON), undefined, { ...(options || {}), "onClick-rawScript": "-script-" }); +            // btn.layoutKey = "layout_onClick"; +            // btn.height = 250; +            // btn.width = 200; +            // btn.layout_onClick = ScriptingBox.LayoutString("onClick");              return InstanceFromProto(Prototypes.get(DocumentType.BUTTON), undefined, { ...(options || {}), "onClick-rawScript": "-script-" });          } diff --git a/src/client/views/EditableView.tsx b/src/client/views/EditableView.tsx index e0e205df9..4f3da70d7 100644 --- a/src/client/views/EditableView.tsx +++ b/src/client/views/EditableView.tsx @@ -5,6 +5,7 @@ import * as Autosuggest from 'react-autosuggest';  import { ObjectField } from '../../fields/ObjectField';  import { SchemaHeaderField } from '../../fields/SchemaHeaderField';  import "./EditableView.scss"; +import { DragManager } from '../util/DragManager';  export interface EditableProps {      /** @@ -48,6 +49,7 @@ export interface EditableProps {      HeadingObject?: SchemaHeaderField | undefined;      toggle?: () => void;      color?: string | undefined; +    onDrop?: any;  }  /** @@ -77,6 +79,13 @@ export class EditableView extends React.Component<EditableProps> {          }      } +    @action +    componentDidMount() { +        if (this._ref.current && this.props.onDrop) { +            DragManager.MakeDropTarget(this._ref.current, this.props.onDrop.bind(this)); +        } +    } +      _didShow = false;      @action diff --git a/src/client/views/nodes/ScriptingBox.scss b/src/client/views/nodes/ScriptingBox.scss index 43695f00d..4746d62d4 100644 --- a/src/client/views/nodes/ScriptingBox.scss +++ b/src/client/views/nodes/ScriptingBox.scss @@ -5,31 +5,63 @@      flex-direction: column;      background-color: rgb(241, 239, 235);      padding: 10px; +      .scriptingBox-inputDiv {          display: flex;          flex-direction: column;          height: calc(100% - 30px); +        table-layout: fixed; + +        overflow-y: hidden; +        white-space: nowrap; + +        .scriptingBox-wrapper { +            width: 100%; +            height: 100%; +            max-height: calc(100%-30px); +            display: flex; +            flex-direction: row; +            justify-content: center; +            overflow-y: hidden; + +            .scriptingBox-textArea { +                flex: 70; +                width: 70%; +                height: 100%; +                box-sizing: border-box; +                resize: none; +                padding: 7px; +                overflow-y: hidden; +            } + +            .scriptingBox-plist { +                flex: 30; +                width: 30%; +                height: 100%; +                box-sizing: border-box; +                resize: none; +                padding: 2px; +                overflow-y: scroll; +            } +        } +          .scriptingBox-errorMessage {              overflow: auto;          } +          .scripting-params {              background: "beige";          } -        .scriptingBox-textArea { -            width: 100%; -            height: 100%; -            box-sizing: border-box; -            resize: none; -            padding: 7px; -        }      }      .scriptingBox-toolbar {          width: 100%;          height: 30px; +          .scriptingBox-button { -            width: 50% +            width: 50%; +            resize: auto; +          }      } -} - +}
\ No newline at end of file diff --git a/src/client/views/nodes/ScriptingBox.tsx b/src/client/views/nodes/ScriptingBox.tsx index 0944edf60..9de072062 100644 --- a/src/client/views/nodes/ScriptingBox.tsx +++ b/src/client/views/nodes/ScriptingBox.tsx @@ -12,27 +12,37 @@ import { EditableView } from "../EditableView";  import { FieldView, FieldViewProps } from "../nodes/FieldView";  import "./ScriptingBox.scss";  import { OverlayView } from "../OverlayView"; -import { DocumentIconContainer } from "./DocumentIcon"; +import { DocumentIconContainer, DocumentIcon } from "./DocumentIcon";  import { List } from "../../../fields/List"; +import { DragManager } from "../../util/DragManager"; +import { Id } from "../../../fields/FieldSymbols";  const ScriptingSchema = createSchema({});  type ScriptingDocument = makeInterface<[typeof ScriptingSchema, typeof documentSchema]>;  const ScriptingDocument = makeInterface(ScriptingSchema, documentSchema); +  @observer  export class ScriptingBox extends ViewBoxAnnotatableComponent<FieldViewProps, ScriptingDocument>(ScriptingDocument) { +      protected multiTouchDisposer?: InteractionUtils.MultiTouchEventDisposer | undefined; +    rowProps: any; +    _paramNum: number = 0;      public static LayoutString(fieldStr: string) { return FieldView.LayoutString(ScriptingBox, fieldStr); }      _overlayDisposer?: () => void;      @observable private _errorMessage: string = ""; +    @observable private _dropped: boolean = false;      @computed get rawScript() { return StrCast(this.dataDoc[this.props.fieldKey + "-rawScript"], StrCast(this.layoutDoc[this.props.fieldKey + "-rawScript"])); }      @computed get compileParams() { return Cast(this.dataDoc[this.props.fieldKey + "-params"], listSpec("string"), Cast(this.layoutDoc[this.props.fieldKey + "-params"], listSpec("string"), [])); }      set rawScript(value) { this.dataDoc[this.props.fieldKey + "-rawScript"] = value; } +      set compileParams(value) { this.dataDoc[this.props.fieldKey + "-params"] = value; } +    @observable private _parameters: any = this.compileParams; +      @action      componentDidMount() {          this.rawScript = ScriptCast(this.dataDoc[this.props.fieldKey])?.script?.originalScript || this.rawScript; @@ -41,21 +51,73 @@ export class ScriptingBox extends ViewBoxAnnotatableComponent<FieldViewProps, Sc      componentWillUnmount() { this._overlayDisposer?.(); }      @action +    onFinish = () => { +        const result = CompileScript(this.rawScript, {}); +        this.rootDoc.layoutKey = "layout"; +        this.rootDoc.height = 50; +        this.rootDoc.width = 100; +        this.props.Document.documentText = this.rawScript; +    } + +    @action +    onError = (error: any) => { +        for (const entry of error) { +            this._errorMessage = this._errorMessage + "   " + entry.messageText; +        } +    } + +    @action      onCompile = () => { +        // const params = this.compileParams.reduce((o: ScriptParam, p: string) => { o[p] = "any"; return o; }, {} as ScriptParam); +        // const result = CompileScript(this.rawScript, { +        //     editable: true, +        //     transformer: DocumentIconContainer.getTransformer(), +        //     params, +        //     typecheck: false +        // }); +        // this._errorMessage = isCompileError(result) ? result.errors.map(e => e.messageText).join("\n") : ""; +        // return this.dataDoc[this.props.fieldKey] = result.compiled ? new ScriptField(result) : undefined;          const params = this.compileParams.reduce((o: ScriptParam, p: string) => { o[p] = "any"; return o; }, {} as ScriptParam);          const result = CompileScript(this.rawScript, {              editable: true,              transformer: DocumentIconContainer.getTransformer(),              params, -            typecheck: false +            typecheck: true          }); -        this._errorMessage = isCompileError(result) ? result.errors.map(e => e.messageText).join("\n") : ""; -        return this.dataDoc[this.props.fieldKey] = result.compiled ? new ScriptField(result) : undefined; +        this._errorMessage = ""; +        if (result.compiled) { +            this._errorMessage = ""; +            this.props.Document.data = new ScriptField(result); +        } +        else { +            this.onError(result.errors); +        } +        this.props.Document.documentText = this.rawScript;      }      @action      onRun = () => { -        this.onCompile()?.script.run({}, err => this._errorMessage = err.map((e: any) => e.messageText).join("\n")); +        const params = this.compileParams.reduce((o: ScriptParam, p: string) => { o[p] = "any"; return o; }, {} as ScriptParam); +        const result = CompileScript(this.rawScript, { +            editable: true, +            transformer: DocumentIconContainer.getTransformer(), +            params, +            typecheck: true +        }); +        this._errorMessage = ""; +        if (result.compiled) { +            // this automatically saves +            result.run({}, (err: any) => { +                this._errorMessage = ""; +                this.onError(err); +            }); +            this.props.Document.data = new ScriptField(result); +        } +        else { +            this.onError(result.errors); +        } +        this.props.Document.documentText = this.rawScript; +        //this.onCompile()?.script.run({}, err => this._errorMessage = err.map((e: any) => e.messageText).join("\n"));      }      onFocus = () => { @@ -63,36 +125,118 @@ export class ScriptingBox extends ViewBoxAnnotatableComponent<FieldViewProps, Sc          this._overlayDisposer = OverlayView.Instance.addElement(<DocumentIconContainer />, { x: 0, y: 0 });      } +    @action +    onDrop = (e: Event, de: DragManager.DropEvent, index: any) => { +        this._dropped = true; +        console.log("drop"); +        const firstParam = this.compileParams[index].split("="); +        const droppedDocs = de.complete.docDragData?.droppedDocuments; +        if (droppedDocs?.length) { +            const dropped = droppedDocs[0]; +            this.compileParams[index] = firstParam[0] + " = " + dropped.title; +            //this._parameters[index] = dropped; +        } +    } + +    @action +    onDelete = (num: number) => { +        this.compileParams.splice(num, 1); +        //this._parameters.splice(num, 1); +    } +      render() { +          const params = <EditableView -            contents={this.compileParams.join(" ")} +            contents={""}              display={"block"}              maxHeight={72}              height={35} -            fontSize={28} +            fontSize={22}              GetValue={() => ""} -            SetValue={value => { this.compileParams = new List<string>(value.split(" ").filter(s => s !== " ")); return true; }} +            SetValue={value => { +                if (value !== "" && value !== " ") { +                    this._paramNum++; +                    const par = this.compileParams; +                    this.compileParams = new List<string>(value.split(";").filter(s => s !== " ")); +                    //this._parameters.push(this.compileParams); +                    this.compileParams.push.apply(this.compileParams, par); +                    console.log(this.compileParams); +                    return true; +                } +                return false; +            }}          />; + +        const listParams = this.compileParams.map((parameter, i) => +            <div className="scriptingBox-pborder" +                onFocus={this.onFocus} +                onBlur={e => this._overlayDisposer?.()} +                onKeyPress={e => { +                    if (e.key === "Enter") { +                        this._overlayDisposer?.(); +                    } +                } +                } +                style={{ background: this._dropped ? "yellow" : "" }}> +                <EditableView +                    contents={parameter} +                    display={"block"} +                    maxHeight={72} +                    height={35} +                    fontSize={12} +                    GetValue={() => parameter} +                    onDrop={(e: Event, de: DragManager.DropEvent) => this.onDrop(e, de, i)} +                    SetValue={value => { +                        if (value !== "" && value !== " ") { +                            this.compileParams[i] = value; +                            //this._parameters[i] = value; +                            parameter = value; +                            return true; +                        } else { +                            this.onDelete(i); +                            return true; +                        } +                    }} +                /> +            </div> +        ); +          return (              <div className="scriptingBox-outerDiv" +                  onWheel={e => this.props.isSelected(true) && e.stopPropagation()}> +                  <div className="scriptingBox-inputDiv"                      onPointerDown={e => this.props.isSelected(true) && e.stopPropagation()} > -                    <textarea className="scriptingBox-textarea" -                        placeholder="write your script here" -                        onChange={e => this.rawScript = e.target.value} -                        value={this.rawScript} -                        onFocus={this.onFocus} -                        onBlur={e => this._overlayDisposer?.()} /> -                    <div className="scriptingBox-errorMessage" style={{ background: this._errorMessage ? "red" : "" }}>{this._errorMessage}</div> +                    <div className="scriptingBox-wrapper"> + +                        <textarea className="scriptingBox-textarea" +                            placeholder="write your script here" +                            onChange={e => this.rawScript = e.target.value} +                            value={this.rawScript} +                            onFocus={this.onFocus} +                            onBlur={e => this._overlayDisposer?.()} +                            style={{ width: this.compileParams.length > 0 ? "70%" : "100%" }} /> + +                        {this.compileParams.length > 0 ? <div className="scriptingBox-plist" style={{ width: "30%" }}> +                            {listParams} +                        </div> : null} +                    </div>                      <div className="scriptingBox-params" >{params}</div> +                    <div className="scriptingBox-errorMessage" style={{ background: this._errorMessage ? "red" : "" }}>{this._errorMessage}</div>                  </div>                  {this.rootDoc.layout === "layout" ? <div></div> : (null)}                  <div className="scriptingBox-toolbar"> -                    <button className="scriptingBox-button" onPointerDown={e => { this.onCompile(); e.stopPropagation(); }}>Compile</button> -                    <button className="scriptingBox-button" onPointerDown={e => { this.onRun(); e.stopPropagation(); }}>Run</button> +                    <button className="scriptingBox-button" style={{ width: this.rootDoc.layoutKey === "layout_onClick" ? "33%" : "50%" }} +                        onPointerDown={e => { this.onCompile(); e.stopPropagation(); }}>Compile</button> +                    <button className="scriptingBox-button" style={{ width: this.rootDoc.layoutKey === "layout_onClick" ? "33%" : "50%" }} +                        onPointerDown={e => { this.onRun(); e.stopPropagation(); }}>Run</button> +                    {this.rootDoc.layoutKey === "layout_onClick" ? <button className="scriptingBox-button" +                        style={{ width: this.rootDoc.layoutKey === "layout_onClick" ? "33%" : "50%" }} +                        onPointerDown={e => { this.onFinish(); e.stopPropagation(); }}>Finish</button> : null}                  </div>              </div>          );      } +  } diff --git a/src/server/database.ts b/src/server/database.ts index a5f23c4b1..b017f1e3c 100644 --- a/src/server/database.ts +++ b/src/server/database.ts @@ -8,6 +8,7 @@ import { IDatabase, DocumentsCollection } from './IDatabase';  import { MemoryDatabase } from './MemoryDatabase';  import * as mongoose from 'mongoose';  import { Upload } from './SharedMediaTypes'; +import { timeout } from 'async';  export namespace Database { diff --git a/src/server/index.ts b/src/server/index.ts index 7ac032ed3..fd5552d12 100644 --- a/src/server/index.ts +++ b/src/server/index.ts @@ -149,9 +149,18 @@ export async function launchServer() {   * log the output of the server process, so it's not ideal for development.   * So, the 'else' clause is exactly what we've always run when executing npm start.   */ +<<<<<<< HEAD +if (process.env.RELEASE) { +    (sessionAgent = new DashSessionAgent()).launch(); +} else { +    setTimeout(() => (Database.Instance as Database.Database).doConnect(), 30000); +    launchServer(); +} +=======  // if (process.env.RELEASE) {  //     (sessionAgent = new DashSessionAgent()).launch();  // } else {  (Database.Instance as Database.Database).doConnect();  launchServer();  // } +>>>>>>> 9c3d461a9642a4596c55f642af2b55e186b0fe20 | 
