diff options
| author | bobzel <zzzman@gmail.com> | 2025-03-24 16:29:32 -0400 | 
|---|---|---|
| committer | bobzel <zzzman@gmail.com> | 2025-03-24 16:29:32 -0400 | 
| commit | 858f5d2f1621695a703b0e3f8297521c3ebe692d (patch) | |
| tree | 3180f91ee18bf8accef98cbbb6db6688666e8340 /src/client/views/DocComponent.tsx | |
| parent | 9c5d14fdd562dc1bcc8aa0f73ce7ad189c9fbf23 (diff) | |
| parent | b6cf21b5a52184f89909898d292a79c57c043d7e (diff) | |
Merge branch 'fieldSyntaxUpdate' into aarav_edit
Diffstat (limited to 'src/client/views/DocComponent.tsx')
| -rw-r--r-- | src/client/views/DocComponent.tsx | 88 | 
1 files changed, 64 insertions, 24 deletions
| diff --git a/src/client/views/DocComponent.tsx b/src/client/views/DocComponent.tsx index e351e2dec..8f254ddcd 100644 --- a/src/client/views/DocComponent.tsx +++ b/src/client/views/DocComponent.tsx @@ -5,7 +5,7 @@ import { DateField } from '../../fields/DateField';  import { Doc, DocListCast, Opt } from '../../fields/Doc';  import { AclAdmin, AclAugment, AclEdit, AclPrivate, AclReadonly, DocData } from '../../fields/DocSymbols';  import { List } from '../../fields/List'; -import { toList } from '../../fields/Types'; +import { DocCast, toList } from '../../fields/Types';  import { GetEffectiveAcl, inheritParentAcls } from '../../fields/util';  import { DocumentType } from '../documents/DocumentTypes';  import { ObservableReactComponent } from './ObservableReactComponent'; @@ -30,26 +30,40 @@ export function DocComponent<P extends DocComponentProps>() {          }          /** -         * This is the document being rendered.  In the case of a compound template, it -         * may not be the actual document rendered and it also may not be the 'real' root document. -         * Rather, it specifies the shared properties of all layouts of the document (eg, x,y,) +         * This is the doc that is being rendered. It will be either: +         *   1) the same as Document if the root of a regular or compound Doc is rendered +         *   2) the same as the layoutDoc if a component of a compound Doc is rendered. +         * NOTE: it is very unlikely that you really want to use this method. Instead +         *       consider: Document, layoutDoc, dataDoc           */ -        get Document() { +        get _renderDoc() {              return this._props.Document;          }          /** -         * This is the document being rendered.  It may be a template so it may or may no inherit from the data doc. +         * This is the "root" Doc being rendered.  In the case of a compound template Doc, +         * this is the outermost Doc that represents the entire compound Doc.  It is not +         * necessarily the Doc being rendered in the current React component. +         * This Doc inherits from the dataDoc, and may or may not inherit (or be) the layoutDoc. +         */ +        get Document() { +            return DocCast(this._renderDoc.rootDocument, this._renderDoc); +        } +        /** +         * This is the document being rendered by the React component. In the +         * case of a compound template, this will be the  expanded template Doc +         * that represents the component of the compound Doc being rendered. +         * This may or may not inherit from the data doc.           */          @computed get layoutDoc() { -            return this._props.LayoutTemplateString ? this.Document : Doc.Layout(this.Document, this._props.LayoutTemplate?.()); +            return this._props.LayoutTemplateString ? this._renderDoc : Doc.Layout(this._renderDoc, this._props.LayoutTemplate?.());          }          /** -         * This is the unique data repository for a dcoument that stores the intrinsic document data +         * This is the unique data repository for a document that stores the intrinsic document data.           */          @computed get dataDoc() { -            return this.Document[DocData]; +            return this._renderDoc[DocData];          }      }      return Component; @@ -75,25 +89,40 @@ export function ViewBoxBaseComponent<P extends FieldViewProps>() {          }          /** -         * This is the document being rendered.  In the case of a compound template, it -         * may not be the actual document rendered and it also may not be the 'real' root document. -         * Rather, it specifies the shared properties of all layouts of the document (eg, x,y,) +         * This is the doc that is being rendered. It will be either: +         *   1) the same as Document if the root of a regular or compound Doc is rendered +         *   2) the same as the layoutDoc if a component of a compound Doc is rendered. +         * NOTE: it is very unlikely that you really want to use this method. Instead +         *       consider: Document, layoutDoc, dataDoc           */ -        get Document() { +        get _renderDoc() {              return this._props.Document;          } +          /** -         * This is the document being rendered.  It may be a template so it may or may no inherit from the data doc. +         * This is the "root" Doc being rendered.  In the case of a compound template Doc, +         * this is the outermost Doc that represents the entire compound Doc.  It is not +         * necessarily the Doc being rendered in the current React component. +         * This Doc inherits from the dataDoc, and may or may not inherit (or be) the layoutDoc. +         */ +        get Document() { +            return DocCast(this._renderDoc.rootDocument, this._renderDoc); +        } +        /** +         * This is the document being rendered by the React component. In the +         * case of a compound template, this will be the  expanded template Doc +         * that represents the component of the compound Doc being rendered. +         * This may or may not inherit from the data doc.           */          @computed get layoutDoc() { -            return Doc.Layout(this.Document); +            return Doc.Layout(this._renderDoc);          }          /**           * This is the unique data repository for a dcoument that stores the intrinsic document data           */          @computed get dataDoc() { -            return this.Document.isTemplateForField || this.Document.isTemplateDoc ? (this._props.TemplateDataDocument ?? this.Document[DocData]) : this.Document[DocData]; +            return this._renderDoc.isTemplateForField || this._renderDoc.isTemplateDoc ? (this._props.TemplateDataDocument ?? this._renderDoc[DocData]) : this._renderDoc[DocData];          }          /** @@ -133,25 +162,37 @@ export function ViewBoxAnnotatableComponent<P extends FieldViewProps>() {          }          /** -         * This is the document being rendered.  In the case of a compound template, it -         * may not be the actual document rendered and it also may not be the 'real' root document. -         * Rather, it specifies the shared properties of all layouts of the document (eg, x,y,) +         * This is the doc that is being rendered. It will be either: +         *   1) the same as Document if the root of a regular or compound Doc is rendered +         *   2) the same as the layoutDoc if a component of a compound Doc is rendered. +         * NOTE: it would unlikely that you really want to use this instead of the +         *       other Doc options (Document, layoutDoc, dataDoc)           */ -        @computed get Document() { +        get _renderDoc() {              return this._props.Document;          } + +        /** +         * This is the "root" Doc being rendered.  In the case of a compound template Doc, +         * this is the outermost Doc that represents the entire compound Doc.  It is not +         * necessarily the Doc being rendered in the current React component. +         * This Doc inherits from the dataDoc, and may or may not inherit (or be) the layoutDoc. +         */ +        @computed get Document() { +            return DocCast(this._renderDoc.rootDocument, this._renderDoc); +        }          /**           * This is the document being rendered.  It may be a template so it may or may no inherit from the data doc.           */          @computed get layoutDoc() { -            return Doc.Layout(this.Document); +            return Doc.Layout(this._renderDoc);          }          /**           * This is the unique data repository for a dcoument that stores the intrinsic document data           */          @computed get dataDoc() { -            return this.Document.isTemplateForField || this.Document.isTemplateDoc ? (this._props.TemplateDataDocument ?? this.Document[DocData]) : this.Document[DocData]; +            return this._renderDoc.isTemplateForField || this._renderDoc.isTemplateDoc ? (this._props.TemplateDataDocument ?? this._renderDoc[DocData]) : this._props.Document[DocData];          }          /** @@ -225,8 +266,7 @@ export function ViewBoxAnnotatableComponent<P extends FieldViewProps>() {                  if ([AclAugment, AclEdit, AclAdmin].includes(effectiveAcl)) {                      added.forEach(adoc => {                          adoc._dragOnlyWithinContainer = undefined; -                        if (annotationKey ?? this._annotationKeySuffix()) adoc[DocData].annotationOn = this.Document; -                        else adoc[DocData].annotationOn = undefined; +                        adoc.$annotationOn = (annotationKey ?? this._annotationKeySuffix()) ? this.Document : undefined;                          Doc.SetContainer(adoc, this.Document);                          inheritParentAcls(targetDataDoc, adoc, true);                      }); | 
