diff options
| author | usodhi <61431818+usodhi@users.noreply.github.com> | 2021-04-10 16:58:05 -0400 | 
|---|---|---|
| committer | usodhi <61431818+usodhi@users.noreply.github.com> | 2021-04-10 16:58:05 -0400 | 
| commit | c2b0b413af3e2a4847d26f14f7833f04a3314e7a (patch) | |
| tree | 3360f83904dbf026251756c15fb995dbb7181c9e /src/client/documents/Documents.ts | |
| parent | 3d434ba49ed378cbbf0214d991ca448de0864a03 (diff) | |
| parent | f87c528f95912319c4181b3955cad4f1042c021e (diff) | |
merging
Diffstat (limited to 'src/client/documents/Documents.ts')
| -rw-r--r-- | src/client/documents/Documents.ts | 33 | 
1 files changed, 28 insertions, 5 deletions
| diff --git a/src/client/documents/Documents.ts b/src/client/documents/Documents.ts index c5b210d1f..a2d1dbe53 100644 --- a/src/client/documents/Documents.ts +++ b/src/client/documents/Documents.ts @@ -171,7 +171,7 @@ export class DocumentOptions {      description?: string; // added for links      layout?: string | Doc; // default layout string for a document      contentPointerEvents?: string;  // pointer events allowed for content of a document view.  eg. set to "none" in menuSidebar for sharedDocs so that you can select a document, but not interact with its contents -    childLimitHeight?: number; // whether to limit the height of colleciton children.  0 - means  height can be no bigger than width +    childLimitHeight?: number; // whether to limit the height of collection children.  0 - means  height can be no bigger than width      childLayoutTemplate?: Doc; // template for collection to use to render its children (see PresBox or Buxton layout in tree view)      childLayoutString?: string; // template string for collection to use to render its children      childDontRegisterViews?: boolean; @@ -248,6 +248,7 @@ export class DocumentOptions {      treeViewHideHeaderFields?: boolean; // whether to hide the drop down options for tree view items.      treeViewShowClearButton?: boolean; // whether a clear button should be displayed       treeViewOpenIsTransient?: boolean; // ignores the treeViewOpen Doc flag, allowing a treeViewItem's expand/collapse state to be independent of other views of the same document in the same or any other tree view +    _treeViewOpen?: boolean; // whether this document is expanded in a tree view  (note: need _ and regular versions since this can be specified for both proto and layout docs)      treeViewOpen?: boolean; // whether this document is expanded in a tree view      treeViewExpandedView?: string; // which field/thing is displayed when this item is opened in tree view      treeViewExpandedViewLock?: boolean; // whether the expanded view can be changed @@ -947,7 +948,14 @@ export namespace DocUtils {          }          return false;      } -    export function FilterDocs(docs: Doc[], docFilters: string[], docRangeFilters: string[], viewSpecScript?: ScriptField) { +    /** +     * @param docs  +     * @param docFilters  +     * @param docRangeFilters  +     * @param viewSpecScript  +     * Given a list of docs and docFilters, @returns the list of Docs that match those filters  +     */ +    export function FilterDocs(docs: Doc[], docFilters: string[], docRangeFilters: string[], viewSpecScript?: ScriptField, parentCollection?: Doc) {          const childDocs = viewSpecScript ? docs.filter(d => viewSpecScript.script.run({ doc: d }, console.log).result) : docs;          if (!docFilters?.length && !docRangeFilters?.length) {              return childDocs.filter(d => !d.cookies);  // remove documents that need a cookie if there are no filters to provide one @@ -971,11 +979,20 @@ export namespace DocUtils {              if (d.cookies && (!filterFacets.cookies || !Object.keys(filterFacets.cookies).some(key => d.cookies === key))) {                  return false;              } +              for (const facetKey of Object.keys(filterFacets).filter(fkey => fkey !== "cookies")) {                  const facet = filterFacets[facetKey]; + +                // facets that match some value in the field of the document (e.g. some text field)                  const matches = Object.keys(facet).filter(value => value !== "cookies" && facet[value] === "match"); + +                // facets that have a check next to them                  const checks = Object.keys(facet).filter(value => facet[value] === "check"); + +                // facets that have an x next to them                  const xs = Object.keys(facet).filter(value => facet[value] === "x"); + +                if (!xs.length && !checks.length && !matches.length) return true;                  const failsNotEqualFacets = !xs.length ? false : xs.some(value => Doc.matchFieldValue(d, facetKey, value));                  const satisfiesCheckFacets = !checks.length ? true : checks.some(value => Doc.matchFieldValue(d, facetKey, value));                  const satisfiesMatchFacets = !matches.length ? true : matches.some(value => { @@ -987,11 +1004,17 @@ export namespace DocUtils {                      }                      return Field.toString(d[facetKey] as Field).includes(value);                  }); -                if (!satisfiesCheckFacets || !satisfiesMatchFacets || failsNotEqualFacets) { -                    return false; +                // if we're ORing them together, the default return is false, and we return true for a doc if it satisfies any one set of criteria +                if ((parentCollection?.currentFilter as Doc)?.filterBoolean === "OR") { +                    if (satisfiesCheckFacets && !failsNotEqualFacets && satisfiesMatchFacets) return true; +                } +                // if we're ANDing them together, the default return is true, and we return false for a doc if it doesn't satisfy any set of criteria +                else { +                    if (!satisfiesCheckFacets || failsNotEqualFacets || (matches.length && !satisfiesMatchFacets)) return false;                  } +              } -            return true; +            return (parentCollection?.currentFilter as Doc)?.filterBoolean === "OR" ? false : true;          }) : childDocs;          const rangeFilteredDocs = filteredDocs.filter(d => {              for (let i = 0; i < docRangeFilters.length; i += 3) { | 
