diff options
author | Stanley <syip0810@gmail.com> | 2019-05-19 14:10:53 -0700 |
---|---|---|
committer | Stanley <syip0810@gmail.com> | 2019-05-19 14:10:53 -0700 |
commit | eec769b586d4a1c6e73c4ce4ae78b4b8f2d4762b (patch) | |
tree | 7218f2df63e028391e40a084d41bce72fd43e00c /src/client/util/SearchUtil.ts | |
parent | 2cc62cd88688ccdec8275fcaaba939d448f9baf5 (diff) | |
parent | 01a223f2e6685506cc1e5db69e9062d5ff0d3246 (diff) |
Merge branch 'master' of https://github.com/browngraphicslab/Dash-Web into pdf_impl
Diffstat (limited to 'src/client/util/SearchUtil.ts')
-rw-r--r-- | src/client/util/SearchUtil.ts | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/src/client/util/SearchUtil.ts b/src/client/util/SearchUtil.ts new file mode 100644 index 000000000..4ccff0d1b --- /dev/null +++ b/src/client/util/SearchUtil.ts @@ -0,0 +1,25 @@ +import * as rp from 'request-promise'; +import { DocServer } from '../DocServer'; +import { Doc } from '../../new_fields/Doc'; +import { Id } from '../../new_fields/RefField'; + +export namespace SearchUtil { + export function Search(query: string, returnDocs: true): Promise<Doc[]>; + export function Search(query: string, returnDocs: false): Promise<string[]>; + export async function Search(query: string, returnDocs: boolean) { + const ids = JSON.parse(await rp.get(DocServer.prepend("/search"), { + qs: { query } + })); + if (!returnDocs) { + return ids; + } + const docMap = await DocServer.GetRefFields(ids); + return ids.map((id: string) => docMap[id]).filter((doc: any) => doc instanceof Doc); + } + + export async function GetAliasesOfDocument(doc: Doc): Promise<Doc[]> { + const proto = await Doc.GetT(doc, "proto", Doc, true); + const protoId = (proto || doc)[Id]; + return Search(`{!join from=id to=proto_i}id:${protoId}`, true); + } +}
\ No newline at end of file |