diff options
Diffstat (limited to 'src/client/views/collections/CollectionView.tsx')
| -rw-r--r-- | src/client/views/collections/CollectionView.tsx | 59 | 
1 files changed, 44 insertions, 15 deletions
| diff --git a/src/client/views/collections/CollectionView.tsx b/src/client/views/collections/CollectionView.tsx index 8c953a23f..43bfbc913 100644 --- a/src/client/views/collections/CollectionView.tsx +++ b/src/client/views/collections/CollectionView.tsx @@ -18,7 +18,7 @@ import { BoolCast, Cast, NumCast, ScriptCast, StrCast } from '../../../fields/Ty  import { ImageField } from '../../../fields/URLField';  import { TraceMobx } from '../../../fields/util';  import { emptyFunction, emptyPath, returnFalse, returnOne, returnZero, setupMoveUpEvents, Utils, returnEmptyFilter } from '../../../Utils'; -import { Docs } from '../../documents/Documents'; +import { Docs, DocUtils } from '../../documents/Documents';  import { DocumentType } from '../../documents/DocumentTypes';  import { CurrentUserUtils } from '../../util/CurrentUserUtils';  import { ImageUtils } from '../../util/Import & Export/ImageUtils'; @@ -47,6 +47,8 @@ import { CollectionGridView } from './collectionGrid/CollectionGridView';  import './CollectionView.scss';  import { CollectionViewBaseChrome } from './CollectionViewChromes';  import { UndoManager } from '../../util/UndoManager'; +import { RichTextField } from '../../../fields/RichTextField'; +import { TextField } from '../../util/ProsemirrorCopy/prompt';  const higflyout = require("@hig/flyout");  export const { anchorPoints } = higflyout;  export const Flyout = higflyout.default; @@ -137,7 +139,23 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus              } else if (this.dataDoc[AclSym] === AclAddonly) {                  added.map(doc => Doc.AddDocToList(targetDataDoc, this.props.fieldKey, doc));              } else { -                added.map(doc => doc.context = this.props.Document); +                added.map(doc => { +                    const context = Cast(doc.context, Doc, null); +                    if (context && (context.type === DocumentType.VID || context.type === DocumentType.WEB || context.type === DocumentType.PDF || context.type === DocumentType.IMG) && +                        !DocListCast(doc.links).some(d => d.isPushpin)) { +                        const pushpin = Docs.Create.FontIconDocument({ +                            icon: "map-pin", x: Cast(doc.x, "number", null), y: Cast(doc.y, "number", null), _backgroundColor: "#0000003d", color: "#ACCEF7", +                            _width: 15, _height: 15, _xPadding: 0, isLinkButton: true, displayTimecode: Cast(doc.displayTimecode, "number", null) +                        }); +                        Doc.AddDocToList(context, Doc.LayoutFieldKey(context) + "-annotations", pushpin); +                        const pushpinLink = DocUtils.MakeLink({ doc: pushpin }, { doc: doc }, "pushpin"); +                        const first = DocListCast(pushpin.links).find(d => d instanceof Doc); +                        first && (first.hidden = true); +                        pushpinLink && (Doc.GetProto(pushpinLink).isPushpin = true); +                        doc.displayTimecode = undefined; +                    } +                    doc.context = this.props.Document; +                });                  added.map(add => Doc.AddDocToList(Cast(Doc.UserDoc().myCatalog, Doc, null), "data", add));                  targetDataDoc[this.props.fieldKey] = new List<Doc>([...docList, ...added]);                  targetDataDoc[this.props.fieldKey + "-lastModified"] = new DateField(new Date(Date.now())); @@ -207,8 +225,8 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus              case CollectionViewType.Pile: { return (<CollectionPileView key="collview" {...props} />); }              case CollectionViewType.Carousel: { return (<CollectionCarouselView key="collview" {...props} />); }              case CollectionViewType.Carousel3D: { return (<CollectionCarousel3DView key="collview" {...props} />); } -            case CollectionViewType.Stacking: { this.props.Document.singleColumn = true; return (<CollectionStackingView key="collview" {...props} />); } -            case CollectionViewType.Masonry: { this.props.Document.singleColumn = false; return (<CollectionStackingView key="collview" {...props} />); } +            case CollectionViewType.Stacking: { this.props.Document._columnsStack = true; return (<CollectionStackingView key="collview" {...props} />); } +            case CollectionViewType.Masonry: { this.props.Document._columnsStack = false; return (<CollectionStackingView key="collview" {...props} />); }              case CollectionViewType.Time: { return (<CollectionTimeView key="collview" {...props} />); }              case CollectionViewType.Map: return (<CollectionMapView key="collview" {...props} />);              case CollectionViewType.Grid: return (<CollectionGridView key="gridview" {...props} />); @@ -357,10 +375,11 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus          return viewSpecScript ? docs.filter(d => viewSpecScript.script.run({ doc: d }, console.log).result) : docs;      }      @computed get _allFacets() { -        const facets = new Set<string>(); -        this.childDocs.filter(child => child).forEach(child => Object.keys(Doc.GetProto(child)).forEach(key => facets.add(key))); +        TraceMobx(); +        const facets = new Set<string>(["type", "text", "data", "author", "ACL"]); +        this.childDocs.filter(child => child).forEach(child => child && Object.keys(Doc.GetProto(child)).forEach(key => facets.add(key)));          Doc.AreProtosEqual(this.dataDoc, this.props.Document) && this.childDocs.filter(child => child).forEach(child => Object.keys(child).forEach(key => facets.add(key))); -        return Array.from(facets); +        return Array.from(facets).filter(f => !f.startsWith("_") && !["proto", "zIndex", "isPrototype", "context", "text-noTemplate"].includes(f)).sort();      }      /** @@ -387,8 +406,13 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus              }          } else {              const allCollectionDocs = DocListCast(this.dataDoc[this.props.fieldKey]); -            const facetValues = Array.from(allCollectionDocs.reduce((set, child) => -                set.add(Field.toString(child[facetHeader] as Field)), new Set<string>())); +            var rtfields = 0; +            const facetValues = Array.from(allCollectionDocs.reduce((set, child) => { +                const field = child[facetHeader] as Field; +                const fieldStr = Field.toString(field); +                if (field instanceof RichTextField || (typeof (field) === "string" && fieldStr.split(" ").length > 2)) rtfields++; +                return set.add(fieldStr); +            }, new Set<string>()));              let nonNumbers = 0;              let minVal = Number.MAX_VALUE, maxVal = -Number.MAX_VALUE; @@ -402,13 +426,18 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus                  }              });              let newFacet: Opt<Doc>; -            if (nonNumbers / allCollectionDocs.length < .1) { -                newFacet = Docs.Create.SliderDocument({ title: facetHeader }); +            if (facetHeader === "text" || rtfields / allCollectionDocs.length > 0.1) { +                newFacet = Docs.Create.TextDocument("", { _width: 100, _height: 25, treeViewExpandedView: "layout", title: facetHeader, treeViewOpen: true, forceActive: true, ignoreClick: true }); +                Doc.GetProto(newFacet).type = DocumentType.COL; // forces item to show an open/close button instead ofa checkbox +                newFacet.target = this.props.Document; +                newFacet._textBoxPadding = 4; +                const scriptText = `setDocFilter(this.target, "${facetHeader}", text, "match")`; +                newFacet.onTextChanged = ScriptField.MakeScript(scriptText, { this: Doc.name, text: "string" }); +            } else if (nonNumbers / facetValues.length < .1) { +                newFacet = Docs.Create.SliderDocument({ title: facetHeader, treeViewExpandedView: "layout", treeViewOpen: true });                  const newFacetField = Doc.LayoutFieldKey(newFacet);                  const ranged = Doc.readDocRangeFilter(this.props.Document, facetHeader);                  Doc.GetProto(newFacet).type = DocumentType.COL; // forces item to show an open/close button instead ofa checkbox -                newFacet.treeViewExpandedView = "layout"; -                newFacet.treeViewOpen = true;                  const extendedMinVal = minVal - Math.min(1, Math.abs(maxVal - minVal) * .05);                  const extendedMaxVal = maxVal + Math.min(1, Math.abs(maxVal - minVal) * .05);                  newFacet[newFacetField + "-min"] = ranged === undefined ? extendedMinVal : ranged[0]; @@ -418,7 +447,6 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus                  newFacet.target = this.props.Document;                  const scriptText = `setDocFilterRange(this.target, "${facetHeader}", range)`;                  newFacet.onThumbChanged = ScriptField.MakeScript(scriptText, { this: Doc.name, range: "number" }); -                  Doc.AddDocToList(facetCollection, this.props.fieldKey + "-filter", newFacet);              } else {                  newFacet = new Doc(); @@ -445,6 +473,7 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus          return ScriptField.MakeScript(scriptText, { this: Doc.name, heading: "string", checked: "string", containingTreeView: Doc.name });      }      @computed get filterView() { +        TraceMobx();          const facetCollection = this.props.Document;          const flyout = (              <div className="collectionTimeView-flyout" style={{ width: `${this.facetWidth()}`, height: this.props.PanelHeight() - 30 }} onWheel={e => e.stopPropagation()}> @@ -534,7 +563,7 @@ export class CollectionView extends Touchable<FieldViewProps & CollectionViewCus                          Utils.CorsProxy(Cast(d.data, ImageField)!.url.href) : Cast(d.data, ImageField)!.url.href                      :                      ""))} -            {!this.props.isSelected() || this.props.PanelHeight() < 100 || this.props.Document.hideFilterView ? (null) : +            {(!this.props.isSelected() || this.props.Document.hideFilterView) && !this.props.Document.forceActive ? (null) :                  <div className="collectionView-filterDragger" title="library View Dragger" onPointerDown={this.onPointerDown}                      style={{ right: this.facetWidth() - 1, top: this.props.Document._viewType === CollectionViewType.Docking ? "25%" : "55%" }} />              } | 
