diff options
| author | usodhi <61431818+usodhi@users.noreply.github.com> | 2021-04-13 10:39:54 -0400 | 
|---|---|---|
| committer | usodhi <61431818+usodhi@users.noreply.github.com> | 2021-04-13 10:39:54 -0400 | 
| commit | a97cd98786ff5572547430fff6c9a46117423bb1 (patch) | |
| tree | aace722360ebb7580bdd22171912688c3d254140 /src/client/views/nodes/WebBox.tsx | |
| parent | 95a42c92c9b4b2af8703afe85ece4e32975a3047 (diff) | |
| parent | 07ad05653c419a197a58a4f076f4d63697c375d9 (diff) | |
Merge branch 'master' of https://github.com/browngraphicslab/Dash-Web into sharing_scenario
Diffstat (limited to 'src/client/views/nodes/WebBox.tsx')
| -rw-r--r-- | src/client/views/nodes/WebBox.tsx | 25 | 
1 files changed, 15 insertions, 10 deletions
| diff --git a/src/client/views/nodes/WebBox.tsx b/src/client/views/nodes/WebBox.tsx index ab178c60b..fc6f9ceab 100644 --- a/src/client/views/nodes/WebBox.tsx +++ b/src/client/views/nodes/WebBox.tsx @@ -2,20 +2,22 @@ import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";  import { action, computed, IReactionDisposer, observable, ObservableMap, reaction, runInAction } from "mobx";  import { observer } from "mobx-react";  import * as WebRequest from 'web-request'; -import { Doc, DocListCast, HeightSym, Opt, StrListCast, WidthSym } from "../../../fields/Doc"; +import { Doc, DocListCast, HeightSym, Opt, WidthSym } from "../../../fields/Doc";  import { documentSchema } from "../../../fields/documentSchemas";  import { Id } from "../../../fields/FieldSymbols";  import { HtmlField } from "../../../fields/HtmlField";  import { InkTool } from "../../../fields/InkField";  import { List } from "../../../fields/List"; -import { makeInterface, listSpec } from "../../../fields/Schema"; +import { listSpec, makeInterface } from "../../../fields/Schema"; +import { ComputedField } from "../../../fields/ScriptField";  import { Cast, NumCast, StrCast } from "../../../fields/Types";  import { WebField } from "../../../fields/URLField";  import { TraceMobx } from "../../../fields/util"; -import { emptyFunction, getWordAtPoint, OmitKeys, returnOne, smoothScroll, Utils, setupMoveUpEvents } from "../../../Utils"; +import { emptyFunction, getWordAtPoint, OmitKeys, returnFalse, returnOne, setupMoveUpEvents, smoothScroll, Utils } from "../../../Utils";  import { Docs } from "../../documents/Documents";  import { DocumentType } from '../../documents/DocumentTypes';  import { CurrentUserUtils } from "../../util/CurrentUserUtils"; +import { Scripting } from "../../util/Scripting";  import { SnappingManager } from "../../util/SnappingManager";  import { undoBatch } from "../../util/UndoManager";  import { CollectionFreeFormView } from "../collections/collectionFreeForm/CollectionFreeFormView"; @@ -79,7 +81,9 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps          runInAction(() => {              this._url = this.webField?.toString() || ""; -            this._annotationKey = "annotations-" + this.urlHash(this._url); +            this._annotationKey = "annotations-" + WebBox.urlHash(this._url); +            // bcz: need to make sure that doc.data-annotations points to the currently active web page's annotations (this could/should be when the doc is created) +            this.dataDoc[this.fieldKey + "-annotations"] = ComputedField.MakeFunction(`copyField(this["${this.fieldKey}-annotations-"+urlHash(this["${this.fieldKey}"]?.url?.toString()))`);          });          this._disposers.selection = reaction(() => this.props.isSelected(), @@ -289,7 +293,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps          if (future.length) {              history.push(this._url);              this.dataDoc[this.fieldKey] = new WebField(new URL(this._url = future.pop()!)); -            this._annotationKey = "annotations-" + this.urlHash(this._url); +            this._annotationKey = "annotations-" + WebBox.urlHash(this._url);              return true;          }          return false; @@ -303,13 +307,13 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps              if (future === undefined) this.dataDoc[this.fieldKey + "-future"] = new List<string>([this._url]);              else future.push(this._url);              this.dataDoc[this.fieldKey] = new WebField(new URL(this._url = history.pop()!)); -            this._annotationKey = "annotations-" + this.urlHash(this._url); +            this._annotationKey = "annotations-" + WebBox.urlHash(this._url);              return true;          }          return false;      } -    urlHash = (s: string) => { +    static urlHash = (s: string) => {          return s.split('').reduce((a: any, b: any) => { a = ((a << 5) - a) + b.charCodeAt(0); return a & a; }, 0);      } @@ -331,7 +335,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps                  future && (future.length = 0);              }              this._url = newUrl; -            this._annotationKey = "annotations-" + this.urlHash(this._url); +            this._annotationKey = "annotations-" + WebBox.urlHash(this._url);              this.dataDoc[this.fieldKey] = new WebField(new URL(newUrl));          } catch (e) {              console.log("WebBox URL error:" + this._url); @@ -507,7 +511,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps                                  PanelHeight={this.panelHeight}                                  dropAction={"alias"}                                  select={emptyFunction} -                                isContentActive={this.isContentActive} +                                isContentActive={returnFalse}                                  ContentScaling={returnOne}                                  bringToFront={emptyFunction}                                  whenChildContentsActiveChanged={this.whenChildContentsActiveChanged} @@ -555,4 +559,5 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps                  </button>              </div>);      } -}
\ No newline at end of file +} +Scripting.addGlobal(function urlHash(url: string) { return WebBox.urlHash(url); });
\ No newline at end of file | 
