UNPKG

@enonic/js-utils

Version:
911 lines (840 loc) 27.1 kB
var __defProp = Object.defineProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; // storage/query/aggregation/index.ts var aggregation_exports = {}; __export(aggregation_exports, { stats: () => stats, statsParams: () => statsParams, terms: () => terms, termsParams: () => termsParams }); // storage/query/aggregation/stats.ts function statsParams(field) { const stats2 = { field }; return stats2; } function stats(field) { const statsAggregation = { stats: statsParams( field ) }; return statsAggregation; } // value/isBasicObject.ts var isBasicObject = (value) => typeof value === "object"; // value/isDate.ts function isDate(value) { return Object.prototype.toString.call(value).slice(8, -1) === "Date"; } // value/isFunction.ts function isFunction(value) { return Object.prototype.toString.call(value).slice(8, -1) === "Function"; } // value/isNumber.ts function isNumber(value) { return typeof value === "number" && isFinite(value); } // value/isStringLiteral.ts var isStringLiteral = (value) => typeof value === "string"; // value/isStringObject.ts var isStringObject = (value) => value instanceof String; // value/isString.ts var isString = (value) => isStringLiteral(value) || isStringObject(value); // value/isInt.ts function isInt(value) { return typeof value === "number" && isFinite(value) && // TODO Is isFinite() available in Enonic XP? Math.floor(value) === value; } // value/isInteger.ts var isInteger = "isInteger" in Number && isFunction(Number.isInteger) ? Number.isInteger : isInt; // value/isObject.ts var isObject = (value) => Object.prototype.toString.call(value).slice(8, -1) === "Object"; // value/isSymbol.ts var isSymbol = (value) => typeof value === "symbol"; // value/isPropertyKey.ts var isPropertyKey = (value) => isString(value) || isNumber(value) || isSymbol(value); // value/isSet.ts function isSet(value) { if (typeof value === "boolean") { return true; } return value !== null && typeof value !== "undefined"; } // value/toStr.ts function toStr(value, replacer, space = 4) { return JSON.stringify(value, replacer, space); } // storage/query/aggregation/terms.ts function termsParams(field, order, size, minDocCount) { const terms2 = { field }; if (order) { terms2.order = order; } if (size) { terms2.size = size; } if (minDocCount) { terms2.minDocCount = minDocCount; } return terms2; } function terms(field, ...optionalArgs) { let order; let size; let minDocCount; let aggregations; for (let i = 0; i < optionalArgs.length; i++) { const optinalArg = optionalArgs[i]; if (isString(optinalArg)) { if (order) { throw new Error(`terms: You can only provide one optional order parameter!`); } order = optinalArg; } else if (isNumber(optinalArg)) { if (isSet(minDocCount)) { throw new Error(`terms: You can only provide one or two optional number parameters!`); } if (isSet(size)) { minDocCount = optinalArg; } else { size = optinalArg; } } else if (isObject(optinalArg)) { if (aggregations) { throw new Error(`terms: You can only provide one optional aggregations parameter!`); } aggregations = optinalArg; } else { throw new Error(`terms: Unknown optional parameter type!`); } } const termsAggregation = { terms: termsParams( field, order, size, minDocCount ) }; if (aggregations) { termsAggregation.aggregations = aggregations; } return termsAggregation; } // storage/query/dsl/index.ts var dsl_exports = {}; __export(dsl_exports, { DSL_EXPRESSION_VALUE_TYPE_DATE_TIME: () => DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2, DSL_EXPRESSION_VALUE_TYPE_TIME: () => DSL_EXPRESSION_VALUE_TYPE_TIME2, and: () => and, bool: () => bool, fulltext: () => fulltext, inQuery: () => inQuery, isBooleanDslExpression: () => isBooleanDslExpression_default, isExistsDslExpression: () => isExistsDslExpression, isFulltextDslExpression: () => isFulltextDslExpression, isInDslExpression: () => isInDslExpression, isLikeDslExpression: () => isLikeDslExpression, isMatchAllDslExpression: () => isMatchAllDslExpression, isNgramDslExpression: () => isNgramDslExpression, isPathMatchDslExpression: () => isPathMatchDslExpression, isQueryDsl: () => isQueryDsl, isRangeDslExpression: () => isRangeDslExpression, isStemmedDslExpression: () => isStemmedDslExpression, isTermDslExpression: () => isTermDslExpression, like: () => like, must: () => must, mustNot: () => mustNot, ngram: () => ngram, not: () => not, or: () => or, pathMatch: () => pathMatch, range: () => range, should: () => should, sort: () => sort, stemmed: () => stemmed, term: () => term }); // object/hasOwnProperty.ts function hasOwnProperty(obj, propKey) { if (!isBasicObject(obj)) { throw new Error(`First parameter to hasOwnProperty must be a basic Object! ${toStr(obj)}`); } if (!isPropertyKey(propKey)) { throw new Error(`Second parameter to hasOwnProperty must be a PropertyKey (string|number|symbol)! ${toStr(propKey)}`); } return obj.hasOwnProperty(propKey); } // array/forceArray.ts function forceArray(data) { return Array.isArray(data) ? data : [data]; } // storage/query/dsl/isDslQueryType.ts var DSL_EXPRESSION_VALUE_TYPE_DATE_TIME = "dateTime"; var DSL_EXPRESSION_VALUE_TYPE_TIME = "time"; function isDslQueryType(value) { return isString(value) && (value === DSL_EXPRESSION_VALUE_TYPE_DATE_TIME || value === DSL_EXPRESSION_VALUE_TYPE_TIME); } // storage/query/dsl/isInDslExpression.ts function isInDslExpression(value) { return isObject(value) && hasOwnProperty(value, "field") && hasOwnProperty(value, "values") && isString(value.field) && Array.isArray(value.values) && (hasOwnProperty(value, "type") ? isDslQueryType(value.type) : true) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isExistsDslExpression.ts function isExistsDslExpression(value) { return isObject(value) && hasOwnProperty(value, "field") && isString(value.field) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // array/includes.ts function sameValueZero(x, y) { return x === y || typeof x === "number" && typeof y === "number" && isNaN(x) && isNaN(y); } function includes(array, searchElement, fromIndex = 0) { if (array == null) { throw new TypeError('"array" is null or not defined'); } const o = Object(array); const len = o.length >>> 0; if (len === 0) { return false; } const n = fromIndex | 0; let k = Math.max(n >= 0 ? n : len - Math.abs(n), 0); while (k < len) { if (sameValueZero(o[k], searchElement)) { return true; } k++; } return false; } // storage/query/constants.ts var FILTER_CLAUSE_MUST = "must"; var FILTER_CLAUSE_MUST_NOT = "mustNot"; var FILTER_CLAUSE_SHOULD = "should"; var FILTER_CLAUSES = [ FILTER_CLAUSE_MUST, FILTER_CLAUSE_MUST_NOT, FILTER_CLAUSE_SHOULD ]; var QUERY_FUNCTION_FULLTEXT = "fulltext"; var QUERY_FUNCTION_NGRAM = "ngram"; var QUERY_FUNCTION_RANGE = "range"; var QUERY_FUNCTION_PATH_MATCH = "pathMatch"; var QUERY_FUNCTION_STEMMED = "stemmed"; var QUERY_OPERATOR_AND = "AND"; var QUERY_OPERATOR_OR = "OR"; var QUERY_OPERATORS = [ QUERY_OPERATOR_AND, QUERY_OPERATOR_OR ]; // storage/query/dsl/isDslOperator.ts function isDslOperator(value) { return isString(value) && includes(QUERY_OPERATORS, value); } // storage/query/dsl/isFulltextDslExpression.ts function isFulltextDslExpression(value) { return isObject(value) && hasOwnProperty(value, "fields") && hasOwnProperty(value, "query") && Array.isArray(value.fields) && value.fields.every(isString) && isString(value.query) && (hasOwnProperty(value, "operator") ? isDslOperator(value.operator) : true) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isLikeDslExpression.ts function isLikeDslExpression(value) { return isObject(value) && hasOwnProperty(value, "field") && hasOwnProperty(value, "value") && isString(value.field) && isString(value.value) && (hasOwnProperty(value, "type") ? isDslQueryType(value.type) : true) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isMatchAllDslExpression.ts function isMatchAllDslExpression(value) { return isObject(value) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isNgramDslExpression.ts function isNgramDslExpression(value) { return isFulltextDslExpression(value); } // storage/query/dsl/isPathMatchDslExpression.ts function isPathMatchDslExpression(value) { return isObject(value) && hasOwnProperty(value, "field") && hasOwnProperty(value, "path") && isString(value.field) && isString(value.path) && (hasOwnProperty(value, "minimumMatch") ? isNumber(value.minimumMatch) : true) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isRangeDslExpression.ts function isRangeDslExpression(value) { return isObject(value) && hasOwnProperty(value, "field") && isString(value.field) && ["lt", "lte", "gt", "gte"].some((key) => hasOwnProperty(value, key)) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isStemmedDslExpression.ts function isStemmedDslExpression(value) { return isObject(value) && hasOwnProperty(value, "fields") && hasOwnProperty(value, "language") && hasOwnProperty(value, "query") && Array.isArray(value.fields) && value.fields.every(isString) && isString(value.language) && isString(value.query) && (hasOwnProperty(value, "operator") ? isDslOperator(value.operator) : true) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isTermDslExpression.ts function isTermDslExpression(value) { return isObject(value) && hasOwnProperty(value, "field") && hasOwnProperty(value, "value") && isString(value.field) && (hasOwnProperty(value, "type") ? isDslQueryType(value.type) : true) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } // storage/query/dsl/isQueryDsl.ts var COMPOUND_PROPERTIES = [ "must", "mustNot", "should", "filter" ]; function isBooleanDslExpression(value) { return isObject(value) && COMPOUND_PROPERTIES.every( (prop) => hasOwnProperty(value, prop) ? forceArray(value[prop]).every((item) => isQueryDsl(item)) : true // prop is optional ) && (hasOwnProperty(value, "boost") ? isNumber(value.boost) : true); } function isQueryDsl(value) { return isObject(value) && (hasOwnProperty(value, "boolean") && isBooleanDslExpression(value.boolean) || hasOwnProperty(value, "exists") && isExistsDslExpression(value.exists) || hasOwnProperty(value, "fulltext") && isFulltextDslExpression(value.fulltext) || hasOwnProperty(value, "in") && isInDslExpression(value.in) || hasOwnProperty(value, "like") && isLikeDslExpression(value.like) || hasOwnProperty(value, "matchAll") && isMatchAllDslExpression(value.matchAll) || hasOwnProperty(value, "ngram") && isNgramDslExpression(value.ngram) || hasOwnProperty(value, "pathMatch") && isPathMatchDslExpression(value.pathMatch) || hasOwnProperty(value, "range") && isRangeDslExpression(value.range) || hasOwnProperty(value, "stemmed") && isStemmedDslExpression(value.stemmed) || hasOwnProperty(value, "term") && isTermDslExpression(value.term)); } // storage/query/dsl/isBooleanDslExpression.ts var isBooleanDslExpression_default = isBooleanDslExpression; // array/flatten.ts function flatten(arr, d = 1) { return d > 0 ? arr.reduce((acc, val) => acc.concat( Array.isArray(val) ? flatten(val, d - 1) : val ), []) : arr.slice(); } // storage/query/dsl/and.ts function and(...args) { const flattened = flatten(args); return { must: flattened }; } var must = and; // storage/query/dsl/bool.ts function bool(compoundExpression) { return { boolean: compoundExpression }; } // string/includes.ts function includes2(string, searchString, position) { if (searchString instanceof RegExp) { throw new TypeError("second argument must not be a RegExp"); } if (position === void 0) { position = 0; } return string.indexOf(searchString, position) !== -1; } // storage/query/buildFields.ts function buildFieldsArray(fields) { return forceArray(fields).map((stringOrObj) => { let boost; let field; if (isObject(stringOrObj)) { boost = stringOrObj.boost || void 0; field = stringOrObj.field; } else { field = stringOrObj; } return `${field}${boost && boost !== 1 ? `^${boost}` : ""}`; }); } function buildFields(fields) { return `'${buildFieldsArray(fields).join(",")}'`; } // storage/query/dsl/fieldsContainBoost.ts function fieldsContainBoost(fields) { if (Array.isArray(fields)) { return fields.some((field) => fieldsContainBoost(field)); } else if (isObject(fields)) { const { boost } = fields; if (boost && boost !== 1) { return true; } } else if (isString(fields)) { if (includes2(fields, "^")) { return true; } } else { throw new Error(`fieldsContainBoost: fields is not array, object or string!`); } return false; } // storage/query/dsl/or.ts function or(...args) { const flattened = flatten(args); return { should: flattened }; } var should = or; // storage/query/dsl/fulltextOrNgram.ts function fulltextOrNgram(fOrN, fields, query, operator = QUERY_OPERATOR_OR, boost) { if (fieldsContainBoost(fields)) { if (Array.isArray(fields)) { return bool(or(fields.map((field) => fulltextOrNgram( fOrN, field, query, operator, boost )))); } else if (isObject(fields)) { const { boost: fieldBoost, field } = fields; if (fieldBoost && fieldBoost !== 1) { if (boost && boost !== 1) { boost = boost * fieldBoost; } else { boost = fieldBoost; } } return fulltextOrNgram( fOrN, field, query, operator, boost ); } else if (isString(fields)) { if (includes2(fields, ",")) { return fulltextOrNgram( fOrN, fields.split(","), query, operator, boost ); } else if (includes2(fields, "^")) { const caretIndex = fields.indexOf("^"); const field = fields.substring(0, caretIndex); const fieldBoost = parseFloat(fields.substring(caretIndex + 1)); if (fieldBoost && fieldBoost !== 1) { if (boost && boost !== 1) { boost = boost * fieldBoost; } else { boost = fieldBoost; } } return fulltextOrNgram( fOrN, field, query, operator, boost ); } } else { throw new Error(`${fOrN}: fields is not array, object or string!`); } } const innerObj = { fields: buildFieldsArray(fields), query, operator: operator.toUpperCase() }; if (boost && boost !== 1) { innerObj.boost = boost; } if (fOrN === "fulltext") { return { fulltext: innerObj }; } else if (fOrN === "ngram") { return { ngram: innerObj }; } throw new Error(`first parameter must be 'fulltext' or 'ngram'`); } // storage/query/dsl/fulltext.ts function fulltext(fields, query, operator = QUERY_OPERATOR_OR, boost) { return fulltextOrNgram("fulltext", fields, query, operator, boost); } // storage/query/dsl/term.ts var DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2 = "dateTime"; var DSL_EXPRESSION_VALUE_TYPE_TIME2 = "time"; function term(field, value, boost, type) { const term2 = { field, value }; if (boost) { term2.boost = boost; } if (type === DSL_EXPRESSION_VALUE_TYPE_TIME2 || type === DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2) { term2.type = type; } return { term: term2 }; } // storage/query/dsl/inQuery.ts function inQuery(field, values, boost, type) { const obj = { field, values }; if (boost) { obj.boost = boost; } if (type === DSL_EXPRESSION_VALUE_TYPE_TIME2 || type === DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2) { obj.type = type; } return { in: obj }; } // storage/query/dsl/like.ts function like(field, value, boost, type) { const like2 = { field, value }; if (boost) { like2.boost = boost; } if (type === DSL_EXPRESSION_VALUE_TYPE_TIME2 || type === DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2) { like2.type = type; } return { like: like2 }; } // storage/query/dsl/ngram.ts function ngram(fields, query, operator = QUERY_OPERATOR_OR, boost) { return fulltextOrNgram("ngram", fields, query, operator, boost); } // storage/query/dsl/not.ts function not(...args) { const flattened = flatten(args); return { mustNot: flattened }; } var mustNot = not; // storage/query/dsl/pathMatch.ts function pathMatch(field, path, minimumMatch, boost) { const pathMatch2 = { field, path }; if (minimumMatch) { pathMatch2.minimumMatch = minimumMatch; } if (boost) { pathMatch2.boost = boost; } return { pathMatch: pathMatch2 }; } // storage/query/dsl/range.ts function ifDateCastToISOString(v) { if (isDate(v)) { return v.toISOString(); } return v; } function range(field, limits = {}, boost, type) { const range2 = { field }; if (limits.gt) { range2.gt = ifDateCastToISOString(limits.gt); } if (limits.gte) { range2.gte = ifDateCastToISOString(limits.gte); } if (limits.lt) { range2.lt = ifDateCastToISOString(limits.lt); } if (limits.lte) { range2.lte = ifDateCastToISOString(limits.lte); } if (boost) { range2.boost = boost; } if (type === DSL_EXPRESSION_VALUE_TYPE_TIME2 || type === DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2) { range2.type = type; } return { range: range2 }; } // storage/indexing/stemming.ts var STEMMING_LANGUAGE_CODE_ENGLISH = "en"; // storage/query/dsl/stemmed.ts function stemmed(fields, query, operator = QUERY_OPERATOR_OR, language = STEMMING_LANGUAGE_CODE_ENGLISH, boost) { if (fieldsContainBoost(fields)) { if (Array.isArray(fields)) { return bool(or(fields.map((field) => stemmed( field, query, operator, language, boost )))); } else if (isObject(fields)) { const { boost: fieldBoost, field } = fields; if (fieldBoost && fieldBoost !== 1) { if (boost && boost !== 1) { boost = boost * fieldBoost; } else { boost = fieldBoost; } } return stemmed( field, query, operator, language, boost ); } else if (isString(fields)) { if (includes2(fields, ",")) { return stemmed( fields.split(","), query, operator, language, boost ); } else if (includes2(fields, "^")) { const caretIndex = fields.indexOf("^"); const field = fields.substring(0, caretIndex); const fieldBoost = parseFloat(fields.substring(caretIndex + 1)); if (fieldBoost && fieldBoost !== 1) { if (boost && boost !== 1) { boost = boost * fieldBoost; } else { boost = fieldBoost; } } return stemmed( field, query, operator, language, boost ); } } else { throw new Error("stemmed: fields is not array, object or string!"); } } const innerObj = { fields: buildFieldsArray(fields), query, operator: operator.toUpperCase(), language }; if (boost) { innerObj.boost = boost; } return { stemmed: innerObj }; } // storage/query/sort.ts var ASC = "ASC"; var DESC = "DESC"; var SORT_CREATED = `createdTime ${DESC}`; var SORT_DISPLAYNAME = `displayName ${ASC}`; var SORT_MANUAL = `_manualordervalue ${DESC}, _timestamp ${DESC}`; var SORT_MODIFIED = `modifiedTime ${DESC}`; function isDirection(s) { return s === ASC || s === DESC; } // storage/query/dsl/sort.ts function sort(...args) { const sort2 = []; let param = {}; for (let i = 0; i < args.length; i++) { const arg = args[i]; if (isDirection(arg)) { if (!param.field || param.direction) { throw new Error(`sort: direction:${arg} is optional, but must come after field parameter!`); } param.direction = arg; } else { if (param.field) { sort2.push(JSON.parse(JSON.stringify(param))); param = { field: arg }; } else { param.field = arg; } } if (i === args.length - 1) { sort2.push(param); } } return sort2.length === 1 ? sort2[0] : sort2; } // storage/query/filter/index.ts var filter_exports = {}; __export(filter_exports, { isBooleanFilter: () => isBooleanFilter, isExistsFilter: () => isExistsFilter, isFilter: () => isFilter, isHasValueFilter: () => isHasValueFilter, isIdsFilter: () => isIdsFilter, isNotExistsFilter: () => isNotExistsFilter }); // storage/query/filter/isExistsFilter.ts function isExistsFilter(value) { return isObject(value) && hasOwnProperty(value, "exists") && isObject(value.exists) && hasOwnProperty(value.exists, "field") && isString(value.exists.field); } // storage/query/filter/isHasValueFilter.ts function isHasValueFilter(value) { return isObject(value) && hasOwnProperty(value, "hasValue") && isObject(value.hasValue) && hasOwnProperty(value.hasValue, "field") && isString(value.hasValue.field) && hasOwnProperty(value.hasValue, "values") && Array.isArray(value.hasValue.values); } // storage/query/filter/isIdsFilter.ts function isIdsFilter(value) { return isObject(value) && hasOwnProperty(value, "ids") && isObject(value.ids) && hasOwnProperty(value.ids, "values") && Array.isArray(value.ids.values) && value.ids.values.every((v) => isString(v)); } // storage/query/filter/isNotExistsFilter.ts function isNotExistsFilter(value) { return isObject(value) && hasOwnProperty(value, "notExists") && isObject(value.notExists) && hasOwnProperty(value.notExists, "field") && isString(value.notExists.field); } // storage/query/filter/isBooleanFilter.ts function isBooleanFilter(value) { return isObject(value) && hasOwnProperty(value, "boolean") && isObject(value.boolean) && FILTER_CLAUSES.every((clause) => { const obj = value.boolean; if (hasOwnProperty(obj, clause)) { const oneOrMoreFilter = obj[clause]; if (Array.isArray(oneOrMoreFilter)) { for (let i = 0; i < oneOrMoreFilter.length; i++) { const item = oneOrMoreFilter[i]; if (!isFilter(item)) { return false; } } } else if (!isFilter(oneOrMoreFilter)) { return false; } } return true; }); } function isFilter(value) { return isBooleanFilter(value) || isExistsFilter(value) || isNotExistsFilter(value) || isHasValueFilter(value) || isIdsFilter(value); } // storage/query/addQueryFilter.ts function addQueryFilter({ clause = FILTER_CLAUSE_MUST, filter, filters: incomingFilters }) { const returnedFilters = incomingFilters ? JSON.parse(JSON.stringify(incomingFilters)) : {}; if (Array.isArray(returnedFilters)) { returnedFilters.push(addQueryFilter({ clause, filter // filters: {} })); return returnedFilters; } if (!isExistsFilter(returnedFilters) && !isNotExistsFilter(returnedFilters) && !isHasValueFilter(returnedFilters) && !isIdsFilter(returnedFilters)) { if (!returnedFilters.boolean) { returnedFilters.boolean = {}; } } if (isBooleanFilter(returnedFilters)) { if (!returnedFilters.boolean[clause]) { returnedFilters.boolean[clause] = filter; } else if (Array.isArray(returnedFilters.boolean[clause])) { returnedFilters.boolean[clause].push(filter); } else { returnedFilters.boolean[clause] = [ // TypeScript unable to narrow type of object properties https://github.com/microsoft/TypeScript/issues/33391 returnedFilters.boolean[clause], filter ]; } } return returnedFilters; } // storage/query/and.ts function and2(...args) { const flattened = flatten(args); if (Array.isArray(flattened)) { if (flattened.length === 1) { return `${QUERY_OPERATOR_AND} ${flattened}`; } return flattened.join(` ${QUERY_OPERATOR_AND} `); } return `${QUERY_OPERATOR_AND} ${flattened}`; } // storage/query/fulltextOrNgram.ts function fulltextOrNgram2(fOrN, fields, searchString, operator = QUERY_OPERATOR_OR) { return `${fOrN}(${buildFields(fields)},'${searchString}'${operator.toUpperCase() === QUERY_OPERATOR_AND ? `,'${QUERY_OPERATOR_AND}'` : ""})`; } // storage/query/fulltext.ts function fulltext2(fields, searchString, operator = QUERY_OPERATOR_OR) { return fulltextOrNgram2("fulltext", fields, searchString, operator); } // storage/query/group.ts function group(s) { return `(${s})`; } // storage/query/ngram.ts function ngram2(fields, searchString, operator = QUERY_OPERATOR_OR) { return fulltextOrNgram2("ngram", fields, searchString, operator); } // storage/query/or.ts function or2(...args) { const flattened = flatten(args); if (Array.isArray(flattened)) { if (flattened.length === 1) { return `${QUERY_OPERATOR_OR} ${flattened}`; } return flattened.join(` ${QUERY_OPERATOR_OR} `); } return `${QUERY_OPERATOR_OR} ${flattened}`; } // storage/query/stemmed.ts function stemmed2(fields, searchString, operator = QUERY_OPERATOR_OR, language = STEMMING_LANGUAGE_CODE_ENGLISH) { return `stemmed(${buildFields(fields)},'${searchString}','${operator.toUpperCase() === QUERY_OPERATOR_AND ? QUERY_OPERATOR_AND : QUERY_OPERATOR_OR}','${language}')`; } export { DSL_EXPRESSION_VALUE_TYPE_DATE_TIME2 as DSL_EXPRESSION_VALUE_TYPE_DATE_TIME, DSL_EXPRESSION_VALUE_TYPE_TIME2 as DSL_EXPRESSION_VALUE_TYPE_TIME, FILTER_CLAUSES, FILTER_CLAUSE_MUST, FILTER_CLAUSE_MUST_NOT, FILTER_CLAUSE_SHOULD, QUERY_FUNCTION_FULLTEXT, QUERY_FUNCTION_NGRAM, QUERY_FUNCTION_PATH_MATCH, QUERY_FUNCTION_RANGE, QUERY_FUNCTION_STEMMED, QUERY_OPERATOR_AND, QUERY_OPERATOR_OR, SORT_CREATED, SORT_DISPLAYNAME, SORT_MANUAL, SORT_MODIFIED, addQueryFilter, aggregation_exports as aggregation, and2 as and, dsl_exports as dsl, filter_exports as filter, fulltext2 as fulltext, group, isBooleanDslExpression_default as isBooleanDslExpression, isBooleanFilter, isExistsDslExpression, isExistsFilter, isFilter, isFulltextDslExpression, isHasValueFilter, isIdsFilter, isInDslExpression, isLikeDslExpression, isMatchAllDslExpression, isNgramDslExpression, isNotExistsFilter, isPathMatchDslExpression, isQueryDsl, isRangeDslExpression, isStemmedDslExpression, isTermDslExpression, ngram2 as ngram, or2 as or, stemmed2 as stemmed };