UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

269 lines (267 loc) • 10.3 kB
/** * DevExtreme (cjs/data/odata/query_adapter.js) * Version: 23.2.6 * Build date: Wed May 01 2024 * * Copyright (c) 2012 - 2024 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; exports.odata = void 0; var _type = require("../../core/utils/type"); var _iterator = require("../../core/utils/iterator"); var _config = _interopRequireDefault(require("../../core/config")); var _extend = require("../../core/utils/extend"); var _query_adapters = _interopRequireDefault(require("../query_adapters")); var _utils = require("./utils"); var _errors = require("../errors"); var _utils2 = require("../utils"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj } } 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) => "".concat(prop, " ").concat(op, " ").concat(val); const createStringFuncFormatter = (op, reverse) => (prop, val) => { const bag = [op, "("]; if (forceLowerCase) { prop = -1 === prop.indexOf("tolower(") ? "tolower(".concat(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, _utils2.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 _errors.errors.Error("E4024", op, fieldName, fieldType) } var name; const formatters = 4 === protocolVersion ? formattersV4 : formattersV2; const formatter = formatters[op.toLowerCase()]; if (!formatter) { throw _errors.errors.Error("E4003", op) } let value = criteria[2]; if (null !== (_fieldTypes = fieldTypes) && void 0 !== _fieldTypes && _fieldTypes[fieldName]) { value = (0, _utils.convertPrimitiveValue)(fieldTypes[fieldName], value) } return formatter((0, _utils.serializePropName)(fieldName), (0, _utils.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 _errors.errors.Error("E4019") } bag.push("(".concat(compileCore(criterion), ")")); groupOperator = nextGroupOperator; nextGroupOperator = "and" } else { nextGroupOperator = (0, _utils2.isConjunctiveOperator)(this) ? "and" : "or" } })); return bag.join(" ".concat(groupOperator, " ")) }; const compileCore = criteria => { if (Array.isArray(criteria[0])) { return compileGroup(criteria) } if ((0, _utils2.isUnaryOperation)(criteria)) { return (criteria => { const op = criteria[0]; const crit = compileCore(criteria[1]); if ("!" === op) { return "not (".concat(crit, ")") } throw _errors.errors.Error("E4003", op) })(criteria) } return compileBinary(criteria) }; return (criteria, version, types, filterToLower) => { fieldTypes = types; forceLowerCase = null !== filterToLower && void 0 !== filterToLower ? 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, _utils.generateSelect)(_oDataVersion, _select) || void 0; result.$expand = (0, _utils.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, _utils.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, _utils.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 = createODataQueryAdapter; exports.odata = odata;