diff options
| author | Melissa Zhang <mzhang19096@gmail.com> | 2020-07-23 13:33:29 -0700 | 
|---|---|---|
| committer | Melissa Zhang <mzhang19096@gmail.com> | 2020-07-23 13:33:29 -0700 | 
| commit | 38b264599af2dca710b6c54d76cf30aade5e2f49 (patch) | |
| tree | 4ec3b7fb03fcc4c81160dedea651f41cdb84c331 /src/client/views/MetadataEntryMenu.tsx | |
| parent | 86a8751ca5a66fd42d7b2b3dee56210f2ef2b62d (diff) | |
| parent | 3bcc0e3a8ce4ab67dff4b3d62191c346764aa351 (diff) | |
merge with master
Diffstat (limited to 'src/client/views/MetadataEntryMenu.tsx')
| -rw-r--r-- | src/client/views/MetadataEntryMenu.tsx | 100 | 
1 files changed, 26 insertions, 74 deletions
| diff --git a/src/client/views/MetadataEntryMenu.tsx b/src/client/views/MetadataEntryMenu.tsx index b0752ffb2..82ec5a5b3 100644 --- a/src/client/views/MetadataEntryMenu.tsx +++ b/src/client/views/MetadataEntryMenu.tsx @@ -3,14 +3,14 @@ import "./MetadataEntryMenu.scss";  import { observer } from 'mobx-react';  import { observable, action, runInAction, trace, computed, IReactionDisposer, reaction } from 'mobx';  import { KeyValueBox } from './nodes/KeyValueBox'; -import { Doc, Field, DocListCastAsync } from '../../fields/Doc'; +import { Doc, Field, DocListCastAsync, DocListCast } from '../../fields/Doc';  import * as Autosuggest from 'react-autosuggest'; -import { undoBatch } from '../util/UndoManager'; +import { undoBatch, UndoManager } from '../util/UndoManager';  import { emptyFunction, emptyPath } from '../../Utils';  export type DocLike = Doc | Doc[] | Promise<Doc> | Promise<Doc[]>;  export interface MetadataEntryProps { -    docs: DocLike | (() => DocLike); +    docs: Doc[];      onError?: () => boolean;      suggestWithFunction?: boolean;  } @@ -38,27 +38,14 @@ export class MetadataEntryMenu extends React.Component<MetadataEntryProps>{          let field: Field | undefined | null = null;          let onProto: boolean = false;          let value: string | undefined = undefined; -        let docs = this.props.docs; -        if (typeof docs === "function") { -            if (this.props.suggestWithFunction) { -                docs = docs(); -            } else { -                return; -            } -        } -        docs = await docs; -        if (docs instanceof Doc) { -            await docs[this._currentKey]; -            value = Field.toKeyValueString(docs, this._currentKey); -        } else { -            for (const doc of docs) { -                const v = await doc[this._currentKey]; -                onProto = onProto || !Object.keys(doc).includes(this._currentKey); -                if (field === null) { -                    field = v; -                } else if (v !== field) { -                    value = "multiple values"; -                } +        const docs = this.props.docs; +        for (const doc of docs) { +            const v = await doc[this._currentKey]; +            onProto = onProto || !Object.keys(doc).includes(this._currentKey); +            if (field === null) { +                field = v; +            } else if (v !== field) { +                value = "multiple values";              }          }          if (value === undefined) { @@ -86,27 +73,16 @@ export class MetadataEntryMenu extends React.Component<MetadataEntryProps>{              const script = KeyValueBox.CompileKVPScript(this._currentValue);              if (!script) return; -            let doc = this.props.docs; -            if (typeof doc === "function") { -                doc = doc(); -            } -            doc = await doc; - -            let success: boolean; -            if (doc instanceof Doc) { -                success = KeyValueBox.ApplyKVPScript(doc, this._currentKey, script); -            } else { -                let childSuccess = true; -                if (this._addChildren) { -                    for (const document of doc) { -                        const collectionChildren = await DocListCastAsync(document.data); -                        if (collectionChildren) { -                            childSuccess = collectionChildren.every(c => KeyValueBox.ApplyKVPScript(c, this._currentKey, script)); -                        } +            let childSuccess = true; +            if (this._addChildren) { +                for (const document of this.props.docs) { +                    const collectionChildren = DocListCast(document.data); +                    if (collectionChildren) { +                        childSuccess = collectionChildren.every(c => KeyValueBox.ApplyKVPScript(c, this._currentKey, script));                      }                  } -                success = doc.every(d => KeyValueBox.ApplyKVPScript(d, this._currentKey, script)) && childSuccess;              } +            const success = this.props.docs.every(d => KeyValueBox.ApplyKVPScript(d, this._currentKey, script)) && childSuccess;              if (!success) {                  if (this.props.onError) {                      if (this.props.onError()) { @@ -132,24 +108,12 @@ export class MetadataEntryMenu extends React.Component<MetadataEntryProps>{          }      } -    getKeySuggestions = async (value: string): Promise<string[]> => { +    getKeySuggestions = (value: string) => {          value = value.toLowerCase(); -        let docs = this.props.docs; -        if (typeof docs === "function") { -            if (this.props.suggestWithFunction) { -                docs = docs(); -            } else { -                return []; -            } -        } -        docs = await docs; -        if (docs instanceof Doc) { -            return Object.keys(docs).filter(key => key.toLowerCase().startsWith(value)); -        } else { -            const keys = new Set<string>(); -            docs.forEach(doc => Doc.allKeys(doc).forEach(key => keys.add(key))); -            return Array.from(keys).filter(key => key.toLowerCase().startsWith(value)); -        } +        const docs = this.props.docs; +        const keys = new Set<string>(); +        docs.forEach(doc => Doc.allKeys(doc).forEach(key => keys.add(key))); +        return Array.from(keys).filter(key => key.toLowerCase().startsWith(value));      }      getSuggestionValue = (suggestion: string) => suggestion; @@ -157,9 +121,8 @@ export class MetadataEntryMenu extends React.Component<MetadataEntryProps>{          return (null);      }      componentDidMount() { -          this._suggestionDispser = reaction(() => this._currentKey, -            () => this.getKeySuggestions(this._currentKey).then(action((s: string[]) => this._allSuggestions = s)), +            () => this._allSuggestions = this.getKeySuggestions(this._currentKey),              { fireImmediately: true });      }      componentWillUnmount() { @@ -171,19 +134,8 @@ export class MetadataEntryMenu extends React.Component<MetadataEntryProps>{      }      private get considerChildOptions() { -        let docSource = this.props.docs; -        if (typeof docSource === "function") { -            docSource = docSource(); -        } -        docSource = docSource as Doc[] | Doc; -        if (docSource instanceof Doc) { -            if (docSource._viewType === undefined) { -                return (null); -            } -        } else if (Array.isArray(docSource)) { -            if (!docSource.every(doc => doc._viewType !== undefined)) { -                return null; -            } +        if (!this.props.docs.every(doc => doc._viewType !== undefined)) { +            return null;          }          return (              <div style={{ display: "flex" }}> | 
