UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

271 lines (269 loc) • 10.4 kB
/** * DevExtreme (cjs/__internal/data/odata/m_query_adapter.js) * Version: 24.2.6 * Build date: Mon Mar 17 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.odata = void 0; var _query_adapters = _interopRequireDefault(require("../../../common/data/query_adapters")); var _config = _interopRequireDefault(require("../../../core/config")); var _extend = require("../../../core/utils/extend"); var _iterator = require("../../../core/utils/iterator"); var _type = require("../../../core/utils/type"); var _m_errors = require("../m_errors"); var _m_utils = require("../m_utils"); var _m_utils2 = require("./m_utils"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e } } const DEFAULT_PROTOCOL_VERSION = 4; const STRING_FUNCTIONS = ["contains", "notcontains", "startswith", "endswith"]; const compileCriteria = (() => { let protocolVersion; let forceLowerCase; let fieldTypes; const createBinaryOperationFormatter = op => (prop, val) => `${prop} ${op} ${val}`; const createStringFuncFormatter = (op, reverse) => (prop, val) => { const bag = [op, "("]; if (forceLowerCase) { prop = -1 === prop.indexOf("tolower(") ? `tolower(${prop})` : prop; val = val.toLowerCase() } if (reverse) { bag.push(val, ",", prop) } else { bag.push(prop, ",", val) } bag.push(")"); return bag.join("") }; const formatters = { "=": createBinaryOperationFormatter("eq"), "<>": createBinaryOperationFormatter("ne"), ">": createBinaryOperationFormatter("gt"), ">=": createBinaryOperationFormatter("ge"), "<": createBinaryOperationFormatter("lt"), "<=": createBinaryOperationFormatter("le"), startswith: createStringFuncFormatter("startswith"), endswith: createStringFuncFormatter("endswith") }; const formattersV2 = (0, _extend.extend)({}, formatters, { contains: createStringFuncFormatter("substringof", true), notcontains: createStringFuncFormatter("not substringof", true) }); const formattersV4 = (0, _extend.extend)({}, formatters, { contains: createStringFuncFormatter("contains"), notcontains: createStringFuncFormatter("not contains") }); const compileBinary = criteria => { var _fieldTypes; criteria = (0, _m_utils.normalizeBinaryCriterion)(criteria); const op = criteria[1]; const fieldName = criteria[0]; const fieldType = fieldTypes && fieldTypes[fieldName]; if (fieldType && (name = op, STRING_FUNCTIONS.some((funcName => funcName === name))) && "String" !== fieldType) { throw new _m_errors.errors.Error("E4024", op, fieldName, fieldType) } var name; const formatters = 4 === protocolVersion ? formattersV4 : formattersV2; const formatter = formatters[op.toLowerCase()]; if (!formatter) { throw _m_errors.errors.Error("E4003", op) } let value = criteria[2]; if (null !== (_fieldTypes = fieldTypes) && void 0 !== _fieldTypes && _fieldTypes[fieldName]) { value = (0, _m_utils2.convertPrimitiveValue)(fieldTypes[fieldName], value) } return formatter((0, _m_utils2.serializePropName)(fieldName), (0, _m_utils2.serializeValue)(value, protocolVersion)) }; const compileGroup = criteria => { const bag = []; let groupOperator; let nextGroupOperator; (0, _iterator.each)(criteria, (function(index, criterion) { if (Array.isArray(criterion)) { if (bag.length > 1 && groupOperator !== nextGroupOperator) { throw new _m_errors.errors.Error("E4019") } bag.push(`(${compileCore(criterion)})`); groupOperator = nextGroupOperator; nextGroupOperator = "and" } else { nextGroupOperator = (0, _m_utils.isConjunctiveOperator)(this) ? "and" : "or" } })); return bag.join(` ${groupOperator} `) }; const compileCore = criteria => { if (Array.isArray(criteria[0])) { return compileGroup(criteria) } if ((0, _m_utils.isUnaryOperation)(criteria)) { return (criteria => { const op = criteria[0]; const crit = compileCore(criteria[1]); if ("!" === op) { return `not (${crit})` } throw _m_errors.errors.Error("E4003", op) })(criteria) } return compileBinary(criteria) }; return (criteria, version, types, filterToLower) => { fieldTypes = types; forceLowerCase = filterToLower ?? (0, _config.default)().oDataFilterToLower; protocolVersion = version; return compileCore(criteria) } })(); const createODataQueryAdapter = queryOptions => { let _sorting = []; const _criteria = []; const _expand = queryOptions.expand; let _select; let _skip; let _take; let _countQuery; const _oDataVersion = queryOptions.version || 4; const hasSlice = () => _skip || void 0 !== _take; const hasFunction = criterion => { for (let i = 0; i < criterion.length; i++) { if ((0, _type.isFunction)(criterion[i])) { return true } if (Array.isArray(criterion[i]) && hasFunction(criterion[i])) { return true } } return false }; const requestData = () => { const result = {}; if (!_countQuery) { if (_sorting.length) { result.$orderby = _sorting.join(",") } if (_skip) { result.$skip = _skip } if (void 0 !== _take) { result.$top = _take } result.$select = (0, _m_utils2.generateSelect)(_oDataVersion, _select) || void 0; result.$expand = (0, _m_utils2.generateExpand)(_oDataVersion, _expand, _select) || void 0 } if (_criteria.length) { const criteria = _criteria.length < 2 ? _criteria[0] : _criteria; const fieldTypes = null === queryOptions || void 0 === queryOptions ? void 0 : queryOptions.fieldTypes; const filterToLower = null === queryOptions || void 0 === queryOptions ? void 0 : queryOptions.filterToLower; result.$filter = compileCriteria(criteria, _oDataVersion, fieldTypes, filterToLower) } if (_countQuery) { result.$top = 0 } if (queryOptions.requireTotalCount || _countQuery) { if (4 !== _oDataVersion) { result.$inlinecount = "allpages" } else { result.$count = "true" } } return result }; return { optimize: tasks => { let selectIndex = -1; for (let i = 0; i < tasks.length; i++) { if ("select" === tasks[i].name) { selectIndex = i; break } } if (selectIndex < 0 || !(0, _type.isFunction)(tasks[selectIndex].args[0])) { return } const nextTask = tasks[1 + selectIndex]; if (!nextTask || "slice" !== nextTask.name) { return } tasks[1 + selectIndex] = tasks[selectIndex]; tasks[selectIndex] = nextTask }, exec: url => (0, _m_utils2.sendRequest)(_oDataVersion, { url: url, params: (0, _extend.extend)(requestData(), null === queryOptions || void 0 === queryOptions ? void 0 : queryOptions.params) }, { beforeSend: queryOptions.beforeSend, jsonp: queryOptions.jsonp, withCredentials: queryOptions.withCredentials, countOnly: _countQuery, deserializeDates: queryOptions.deserializeDates, fieldTypes: queryOptions.fieldTypes, isPaged: isFinite(_take) }), multiSort(args) { let rules; if (hasSlice()) { return false } for (let i = 0; i < args.length; i++) { const getter = args[i][0]; const desc = !!args[i][1]; let rule; if ("string" !== typeof getter) { return false } rule = (0, _m_utils2.serializePropName)(getter); if (desc) { rule += " desc" } rules = rules || []; rules.push(rule) } _sorting = rules }, slice(skipCount, takeCount) { if (hasSlice()) { return false } _skip = skipCount; _take = takeCount }, filter(criterion) { if (hasSlice()) { return false } if (!Array.isArray(criterion)) { criterion = [].slice.call(arguments) } if (hasFunction(criterion)) { return false } if (_criteria.length) { _criteria.push("and") } _criteria.push(criterion) }, select(expr) { if (_select || (0, _type.isFunction)(expr)) { return false } if (!Array.isArray(expr)) { expr = [].slice.call(arguments) } _select = expr }, count: () => _countQuery = true } }; _query_adapters.default.odata = createODataQueryAdapter; const odata = exports.odata = createODataQueryAdapter;