aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/PropertiesDocContextSelector.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/views/PropertiesDocContextSelector.tsx')
-rw-r--r--src/client/views/PropertiesDocContextSelector.tsx26
1 files changed, 16 insertions, 10 deletions
diff --git a/src/client/views/PropertiesDocContextSelector.tsx b/src/client/views/PropertiesDocContextSelector.tsx
index d157e7b1c..a710e7816 100644
--- a/src/client/views/PropertiesDocContextSelector.tsx
+++ b/src/client/views/PropertiesDocContextSelector.tsx
@@ -1,13 +1,14 @@
-import { computed } from 'mobx';
+import { computed, makeObservable } from 'mobx';
import { observer } from 'mobx-react';
import * as React from 'react';
import { Doc, DocListCast } from '../../fields/Doc';
import { Id } from '../../fields/FieldSymbols';
import { Cast, StrCast } from '../../fields/Types';
import { DocFocusOrOpen } from '../util/DocumentManager';
+import { ObservableReactComponent } from './ObservableReactComponent';
+import './PropertiesDocContextSelector.scss';
import { CollectionDockingView } from './collections/CollectionDockingView';
import { DocumentView, OpenWhere } from './nodes/DocumentView';
-import './PropertiesDocContextSelector.scss';
type PropertiesDocContextSelectorProps = {
DocView?: DocumentView;
@@ -17,11 +18,16 @@ type PropertiesDocContextSelectorProps = {
};
@observer
-export class PropertiesDocContextSelector extends React.Component<PropertiesDocContextSelectorProps> {
+export class PropertiesDocContextSelector extends ObservableReactComponent<PropertiesDocContextSelectorProps> {
+ constructor(props: any) {
+ super(props);
+ makeObservable(this);
+ }
+
@computed get _docs() {
- if (!this.props.DocView) return [];
- const target = this.props.DocView.props.Document;
- const targetContext = this.props.DocView.props.docViewPath().lastElement()?.rootDoc;
+ if (!this._props.DocView) return [];
+ const target = this._props.DocView._props.Document;
+ const targetContext = this._props.DocView._props.docViewPath().lastElement()?.Document;
const embeddings = DocListCast(target.proto_embeddings);
const containerProtos = embeddings.filter(embedding => embedding.embedContainer && embedding.embedContainer instanceof Doc).reduce((set, embedding) => set.add(Cast(embedding.embedContainer, Doc, null)), new Set<Doc>());
const containerSets = Array.from(containerProtos.keys()).map(container => DocListCast(container.proto_embeddings));
@@ -40,23 +46,23 @@ export class PropertiesDocContextSelector extends React.Component<PropertiesDocC
);
return doclayouts
- .filter(doc => !Doc.AreProtosEqual(doc, CollectionDockingView.Instance?.props.Document))
+ .filter(doc => !Doc.AreProtosEqual(doc, CollectionDockingView.Instance?.Document))
.filter(doc => !Doc.IsSystem(doc))
.filter(doc => doc !== targetContext)
.map(doc => ({ col: doc, target }));
}
getOnClick = (col: Doc, target: Doc) => {
- if (!this.props.DocView) return;
+ if (!this._props.DocView) return;
col = Doc.IsDataProto(col) ? Doc.MakeDelegate(col) : col;
- DocFocusOrOpen(Doc.GetProto(this.props.DocView.props.Document), undefined, col);
+ DocFocusOrOpen(Doc.GetProto(this._props.DocView.Document), undefined, col);
};
render() {
if (this._docs.length < 1) return undefined;
return (
<div>
- {this.props.hideTitle ? null : <p key="contexts">Contexts:</p>}
+ {this._props.hideTitle ? null : <p key="contexts">Contexts:</p>}
{this._docs.map(doc => (
<p key={doc.col[Id] + doc.target[Id]}>
<a onClick={() => this.getOnClick(doc.col, doc.target)}>{StrCast(doc.col.title)}</a>