import _defineProperty from "@babel/runtime-corejs3/helpers/defineProperty"; import _slicedToArray from "@babel/runtime-corejs3/helpers/slicedToArray"; import _typeof from "@babel/runtime-corejs3/helpers/typeof"; import _toConsumableArray from "@babel/runtime-corejs3/helpers/toConsumableArray"; import _Object$values from "@babel/runtime-corejs3/core-js-stable/object/values"; import _concatInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/concat"; import _mapInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/map"; import _Array$isArray from "@babel/runtime-corejs3/core-js-stable/array/is-array"; import _Object$keys2 from "@babel/runtime-corejs3/core-js-stable/object/keys"; import _startsWithInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/starts-with"; import _Object$entries from "@babel/runtime-corejs3/core-js-stable/object/entries"; import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/filter"; import _includesInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/includes"; import _sortInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/sort"; import "core-js/modules/es.array.join.js"; import "core-js/modules/es.object.to-string.js"; import "core-js/modules/es.regexp.exec.js"; import "core-js/modules/es.regexp.test.js"; import "core-js/modules/es.regexp.to-string.js"; import "core-js/modules/es.string.replace.js"; import "core-js/modules/es.string.split.js"; /** * @file Create and build SOQL string from configuration * @author Shinichi Tomita */ import SfDate from './date'; /** @private **/ function escapeSOQLString(str) { return String(str || '').replace(/'/g, "\\'"); } /** @private **/ function createFieldsClause(fields) { var _context; var childQueries = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var cqueries = _Object$values(childQueries); // eslint-disable-next-line no-use-before-define return _concatInstanceProperty(_context = []).call(_context, _toConsumableArray(fields || ['Id']), _toConsumableArray(_mapInstanceProperty(cqueries).call(cqueries, function (cquery) { return "(".concat(createSOQL(cquery), ")"); }))).join(', '); } /** @private **/ function createValueExpression(value) { if (_Array$isArray(value)) { return value.length > 0 ? "(".concat(_mapInstanceProperty(value).call(value, createValueExpression).join(', '), ")") : undefined; } if (value instanceof SfDate) { return value.toString(); } if (typeof value === 'string') { return "'".concat(escapeSOQLString(value), "'"); } if (typeof value === 'number') { return value.toString(); } if (value === null) { return 'null'; } return value; } var opMap = { '=': '=', $eq: '=', '!=': '!=', $ne: '!=', '>': '>', $gt: '>', '<': '<', $lt: '<', '>=': '>=', $gte: '>=', '<=': '<=', $lte: '<=', $like: 'LIKE', $nlike: 'NOT LIKE', $in: 'IN', $nin: 'NOT IN', $includes: 'INCLUDES', $excludes: 'EXCLUDES', $exists: 'EXISTS' }; /** @private **/ function createFieldExpression(field, value) { var op = '$eq'; var _value = value; // Assume the `$in` operator if value is an array and none was supplied. if (_Array$isArray(value)) { op = '$in'; } else if (_typeof(value) === 'object' && value !== null) { // Otherwise, if an object was passed then process the supplied ops. for (var _i = 0, _Object$keys = _Object$keys2(value); _i < _Object$keys.length; _i++) { var k = _Object$keys[_i]; if (_startsWithInstanceProperty(k).call(k, '$')) { op = k; _value = value[k]; break; } } } var sfop = opMap[op]; if (!sfop || typeof _value === 'undefined') { return null; } var valueExpr = createValueExpression(_value); if (typeof valueExpr === 'undefined') { return null; } switch (sfop) { case 'NOT LIKE': return "(".concat(['NOT', field, 'LIKE', valueExpr].join(' '), ")"); case 'EXISTS': return [field, _value ? '!=' : '=', 'null'].join(' '); default: return [field, sfop, valueExpr].join(' '); } } /** @private **/ function createOrderByClause() { var sort = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; var _sort = []; if (typeof sort === 'string') { var _context2; if (/,|\s+(asc|desc)\s*$/.test(sort)) { // must be specified in pure "order by" clause. Return raw config. return sort; } // sort order in mongoose-style expression. // e.g. "FieldA -FieldB" => "ORDER BY FieldA ASC, FieldB DESC" _sort = _mapInstanceProperty(_context2 = sort.split(/\s+/)).call(_context2, function (field) { var dir = 'ASC'; // ascending var flag = field[0]; if (flag === '-') { dir = 'DESC'; field = field.substring(1); // eslint-disable-line no-param-reassign } else if (flag === '+') { field = field.substring(1); // eslint-disable-line no-param-reassign } return [field, dir]; }); } else if (_Array$isArray(sort)) { _sort = sort; } else { var _context3; _sort = _mapInstanceProperty(_context3 = _Object$entries(sort)).call(_context3, function (_ref) { var _ref2 = _slicedToArray(_ref, 2), field = _ref2[0], dir = _ref2[1]; return [field, dir]; }); } return _mapInstanceProperty(_sort).call(_sort, function (_ref3) { var _context4; var _ref4 = _slicedToArray(_ref3, 2), field = _ref4[0], dir = _ref4[1]; /* eslint-disable no-param-reassign */ switch (String(dir)) { case 'DESC': case 'desc': case 'descending': case '-': case '-1': dir = 'DESC'; break; default: dir = 'ASC'; } return _concatInstanceProperty(_context4 = "".concat(field, " ")).call(_context4, dir); }).join(', '); } /** @private **/ function createConditionClause() { var _context7; var conditions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var operator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'AND'; var depth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; if (typeof conditions === 'string') { return conditions; } var conditionList = []; if (!_Array$isArray(conditions)) { var _context5; // if passed in hash object var conditionsMap = conditions; conditionList = _mapInstanceProperty(_context5 = _Object$keys2(conditionsMap)).call(_context5, function (key) { return { key: key, value: conditionsMap[key] }; }); } else { conditionList = _mapInstanceProperty(conditions).call(conditions, function (cond) { var _context6; var conds = _mapInstanceProperty(_context6 = _Object$keys2(cond)).call(_context6, function (key) { return { key: key, value: cond[key] }; }); return conds.length > 1 ? { key: '$and', value: _mapInstanceProperty(conds).call(conds, function (c) { return _defineProperty({}, c.key, c.value); }) } : conds[0]; }); } var conditionClauses = _filterInstanceProperty(_context7 = _mapInstanceProperty(conditionList).call(conditionList, function (cond) { var d = depth + 1; var op; switch (cond.key) { case '$or': case '$and': case '$not': if (operator !== 'NOT' && conditionList.length === 1) { d = depth; // not change tree depth } op = cond.key === '$or' ? 'OR' : cond.key === '$and' ? 'AND' : 'NOT'; return createConditionClause(cond.value, op, d); default: return createFieldExpression(cond.key, cond.value); } })).call(_context7, function (expr) { return expr; }); var hasParen; if (operator === 'NOT') { var _context8, _context9; hasParen = depth > 0; return _concatInstanceProperty(_context8 = _concatInstanceProperty(_context9 = "".concat(hasParen ? '(' : '', "NOT ")).call(_context9, conditionClauses[0])).call(_context8, hasParen ? ')' : ''); } hasParen = depth > 0 && conditionClauses.length > 1; return (hasParen ? '(' : '') + conditionClauses.join(" ".concat(operator, " ")) + (hasParen ? ')' : ''); } /** * Create SOQL * @private */ export function createSOQL(query) { var soql = ['SELECT ', createFieldsClause(query.fields, _includesInstanceProperty(query)), ' FROM ', query.table].join(''); var cond = createConditionClause(query.conditions); if (cond) { soql += " WHERE ".concat(cond); } var orderby = createOrderByClause(_sortInstanceProperty(query)); if (orderby) { soql += " ORDER BY ".concat(orderby); } if (query.limit) { soql += " LIMIT ".concat(query.limit); } if (query.offset) { soql += " OFFSET ".concat(query.offset); } return soql; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SfDate","escapeSOQLString","str","String","replace","createFieldsClause","fields","_context","childQueries","arguments","length","undefined","cqueries","_Object$values","_concatInstanceProperty","call","_toConsumableArray","_mapInstanceProperty","cquery","concat","createSOQL","join","createValueExpression","value","_Array$isArray","toString","opMap","$eq","$ne","$gt","$lt","$gte","$lte","$like","$nlike","$in","$nin","$includes","$excludes","$exists","createFieldExpression","field","op","_value","_typeof","_i","_Object$keys","_Object$keys2","k","_startsWithInstanceProperty","sfop","valueExpr","createOrderByClause","sort","_sort","_context2","test","split","dir","flag","substring","_context3","_Object$entries","_ref","_ref2","_slicedToArray","_ref3","_context4","_ref4","createConditionClause","_context7","conditions","operator","depth","conditionList","_context5","conditionsMap","key","cond","_context6","conds","c","_defineProperty","conditionClauses","_filterInstanceProperty","d","expr","hasParen","_context8","_context9","query","soql","_includesInstanceProperty","table","orderby","_sortInstanceProperty","limit","offset"],"sources":["../src/soql-builder.ts"],"sourcesContent":["/**\n * @file Create and build SOQL string from configuration\n * @author Shinichi Tomita <shinichi.tomita@gmail.com>\n */\nimport SfDate from './date';\nimport { Optional } from './types';\n\nexport type Condition =\n  | string\n  | { [field: string]: any }\n  | Array<{ [field: string]: any }>;\n\nexport type SortDir = 'ASC' | 'DESC' | 'asc' | 'desc' | 1 | -1;\n\nexport type Sort =\n  | string\n  | Array<[string, SortDir]>\n  | { [field: string]: SortDir };\n\nexport type QueryConfig = {\n  fields?: string[];\n  includes?: { [field: string]: QueryConfig };\n  table?: string;\n  conditions?: Condition;\n  sort?: Sort;\n  limit?: number;\n  offset?: number;\n};\n\n/** @private **/\nfunction escapeSOQLString(str: Optional<string | number | boolean>) {\n  return String(str || '').replace(/'/g, \"\\\\'\");\n}\n\n/** @private **/\nfunction createFieldsClause(\n  fields?: string[],\n  childQueries: { [name: string]: QueryConfig } = {},\n): string {\n  const cqueries: QueryConfig[] = (Object.values(\n    childQueries,\n  ) as any) as QueryConfig[];\n  // eslint-disable-next-line no-use-before-define\n  return [\n    ...(fields || ['Id']),\n    ...cqueries.map((cquery) => `(${createSOQL(cquery)})`),\n  ].join(', ');\n}\n\n/** @private **/\nfunction createValueExpression(value: any): Optional<string> {\n  if (Array.isArray(value)) {\n    return value.length > 0\n      ? `(${value.map(createValueExpression).join(', ')})`\n      : undefined;\n  }\n  if (value instanceof SfDate) {\n    return value.toString();\n  }\n  if (typeof value === 'string') {\n    return `'${escapeSOQLString(value)}'`;\n  }\n  if (typeof value === 'number') {\n    return value.toString();\n  }\n  if (value === null) {\n    return 'null';\n  }\n  return value;\n}\n\nconst opMap: { [op: string]: string } = {\n  '=': '=',\n  $eq: '=',\n  '!=': '!=',\n  $ne: '!=',\n  '>': '>',\n  $gt: '>',\n  '<': '<',\n  $lt: '<',\n  '>=': '>=',\n  $gte: '>=',\n  '<=': '<=',\n  $lte: '<=',\n  $like: 'LIKE',\n  $nlike: 'NOT LIKE',\n  $in: 'IN',\n  $nin: 'NOT IN',\n  $includes: 'INCLUDES',\n  $excludes: 'EXCLUDES',\n  $exists: 'EXISTS',\n};\n\n/** @private **/\nfunction createFieldExpression(field: string, value: any): Optional<string> {\n  let op = '$eq';\n  let _value = value;\n\n  // Assume the `$in` operator if value is an array and none was supplied.\n  if (Array.isArray(value)) {\n    op = '$in';\n  } else if (typeof value === 'object' && value !== null) {\n    // Otherwise, if an object was passed then process the supplied ops.\n    for (const k of Object.keys(value)) {\n      if (k.startsWith('$')) {\n        op = k;\n        _value = value[k];\n        break;\n      }\n    }\n  }\n  const sfop = opMap[op];\n  if (!sfop || typeof _value === 'undefined') {\n    return null;\n  }\n  const valueExpr = createValueExpression(_value);\n  if (typeof valueExpr === 'undefined') {\n    return null;\n  }\n  switch (sfop) {\n    case 'NOT LIKE':\n      return `(${['NOT', field, 'LIKE', valueExpr].join(' ')})`;\n    case 'EXISTS':\n      return [field, _value ? '!=' : '=', 'null'].join(' ');\n    default:\n      return [field, sfop, valueExpr].join(' ');\n  }\n}\n\n/** @private **/\nfunction createOrderByClause(sort: Sort = []): string {\n  let _sort: Array<[string, SortDir]> = [];\n  if (typeof sort === 'string') {\n    if (/,|\\s+(asc|desc)\\s*$/.test(sort)) {\n      // must be specified in pure \"order by\" clause. Return raw config.\n      return sort;\n    }\n    // sort order in mongoose-style expression.\n    // e.g. \"FieldA -FieldB\" => \"ORDER BY FieldA ASC, FieldB DESC\"\n    _sort = sort.split(/\\s+/).map((field) => {\n      let dir: SortDir = 'ASC'; // ascending\n      const flag = field[0];\n      if (flag === '-') {\n        dir = 'DESC';\n        field = field.substring(1); // eslint-disable-line no-param-reassign\n      } else if (flag === '+') {\n        field = field.substring(1); // eslint-disable-line no-param-reassign\n      }\n      return [field, dir] as [string, SortDir];\n    });\n  } else if (Array.isArray(sort)) {\n    _sort = sort;\n  } else {\n    _sort = Object.entries(sort).map(\n      ([field, dir]) => [field, dir] as [string, SortDir],\n    );\n  }\n  return _sort\n    .map(([field, dir]) => {\n      /* eslint-disable no-param-reassign */\n      switch (String(dir)) {\n        case 'DESC':\n        case 'desc':\n        case 'descending':\n        case '-':\n        case '-1':\n          dir = 'DESC';\n          break;\n        default:\n          dir = 'ASC';\n      }\n      return `${field} ${dir}`;\n    })\n    .join(', ');\n}\n\ntype LogicalOperator = 'AND' | 'OR' | 'NOT';\n\n/** @private **/\nfunction createConditionClause(\n  conditions: Condition = {},\n  operator: LogicalOperator = 'AND',\n  depth: number = 0,\n): string {\n  if (typeof conditions === 'string') {\n    return conditions;\n  }\n  let conditionList: Array<{ key: string; value: Condition }> = [];\n  if (!Array.isArray(conditions)) {\n    // if passed in hash object\n    const conditionsMap = conditions;\n    conditionList = Object.keys(conditionsMap).map((key) => ({\n      key,\n      value: conditionsMap[key],\n    }));\n  } else {\n    conditionList = conditions.map((cond) => {\n      const conds = Object.keys(cond).map((key) => ({ key, value: cond[key] }));\n      return conds.length > 1\n        ? { key: '$and', value: conds.map((c) => ({ [c.key]: c.value })) }\n        : conds[0];\n    });\n  }\n  const conditionClauses = (conditionList\n    .map((cond) => {\n      let d = depth + 1;\n      let op: Optional<LogicalOperator>;\n      switch (cond.key) {\n        case '$or':\n        case '$and':\n        case '$not':\n          if (operator !== 'NOT' && conditionList.length === 1) {\n            d = depth; // not change tree depth\n          }\n          op = cond.key === '$or' ? 'OR' : cond.key === '$and' ? 'AND' : 'NOT';\n          return createConditionClause(cond.value, op, d);\n        default:\n          return createFieldExpression(cond.key, cond.value);\n      }\n    })\n    .filter((expr) => expr) as any) as string[];\n\n  let hasParen: boolean;\n  if (operator === 'NOT') {\n    hasParen = depth > 0;\n    return `${hasParen ? '(' : ''}NOT ${conditionClauses[0]}${\n      hasParen ? ')' : ''\n    }`;\n  }\n  hasParen = depth > 0 && conditionClauses.length > 1;\n  return (\n    (hasParen ? '(' : '') +\n    conditionClauses.join(` ${operator} `) +\n    (hasParen ? ')' : '')\n  );\n}\n\n/**\n * Create SOQL\n * @private\n */\nexport function createSOQL(query: QueryConfig): string {\n  let soql = [\n    'SELECT ',\n    createFieldsClause(query.fields, query.includes),\n    ' FROM ',\n    query.table,\n  ].join('');\n  const cond = createConditionClause(query.conditions);\n  if (cond) {\n    soql += ` WHERE ${cond}`;\n  }\n  const orderby = createOrderByClause(query.sort);\n  if (orderby) {\n    soql += ` ORDER BY ${orderby}`;\n  }\n  if (query.limit) {\n    soql += ` LIMIT ${query.limit}`;\n  }\n  if (query.offset) {\n    soql += ` OFFSET ${query.offset}`;\n  }\n  return soql;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA,OAAOA,MAAM,MAAM,QAAQ;AAyB3B;AACA,SAASC,gBAAgBA,CAACC,GAAwC,EAAE;EAClE,OAAOC,MAAM,CAACD,GAAG,IAAI,EAAE,CAAC,CAACE,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;AAC/C;;AAEA;AACA,SAASC,kBAAkBA,CACzBC,MAAiB,EAET;EAAA,IAAAC,QAAA;EAAA,IADRC,YAA6C,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAElD,IAAMG,QAAuB,GAAIC,cAAA,CAC/BL,YACF,CAA0B;EAC1B;EACA,OAAOM,uBAAA,CAAAP,QAAA,OAAAQ,IAAA,CAAAR,QAAA,EAAAS,kBAAA,CACDV,MAAM,IAAI,CAAC,IAAI,CAAC,GAAAU,kBAAA,CACjBC,oBAAA,CAAAL,QAAQ,EAAAG,IAAA,CAARH,QAAQ,EAAK,UAACM,MAAM;IAAA,WAAAC,MAAA,CAASC,UAAU,CAACF,MAAM,CAAC;EAAA,CAAG,CAAC,GACtDG,IAAI,CAAC,IAAI,CAAC;AACd;;AAEA;AACA,SAASC,qBAAqBA,CAACC,KAAU,EAAoB;EAC3D,IAAIC,cAAA,CAAcD,KAAK,CAAC,EAAE;IACxB,OAAOA,KAAK,CAACb,MAAM,GAAG,CAAC,OAAAS,MAAA,CACfF,oBAAA,CAAAM,KAAK,EAAAR,IAAA,CAALQ,KAAK,EAAKD,qBAAqB,CAAC,CAACD,IAAI,CAAC,IAAI,CAAC,SAC/CV,SAAS;EACf;EACA,IAAIY,KAAK,YAAYvB,MAAM,EAAE;IAC3B,OAAOuB,KAAK,CAACE,QAAQ,CAAC,CAAC;EACzB;EACA,IAAI,OAAOF,KAAK,KAAK,QAAQ,EAAE;IAC7B,WAAAJ,MAAA,CAAWlB,gBAAgB,CAACsB,KAAK,CAAC;EACpC;EACA,IAAI,OAAOA,KAAK,KAAK,QAAQ,EAAE;IAC7B,OAAOA,KAAK,CAACE,QAAQ,CAAC,CAAC;EACzB;EACA,IAAIF,KAAK,KAAK,IAAI,EAAE;IAClB,OAAO,MAAM;EACf;EACA,OAAOA,KAAK;AACd;AAEA,IAAMG,KAA+B,GAAG;EACtC,GAAG,EAAE,GAAG;EACRC,GAAG,EAAE,GAAG;EACR,IAAI,EAAE,IAAI;EACVC,GAAG,EAAE,IAAI;EACT,GAAG,EAAE,GAAG;EACRC,GAAG,EAAE,GAAG;EACR,GAAG,EAAE,GAAG;EACRC,GAAG,EAAE,GAAG;EACR,IAAI,EAAE,IAAI;EACVC,IAAI,EAAE,IAAI;EACV,IAAI,EAAE,IAAI;EACVC,IAAI,EAAE,IAAI;EACVC,KAAK,EAAE,MAAM;EACbC,MAAM,EAAE,UAAU;EAClBC,GAAG,EAAE,IAAI;EACTC,IAAI,EAAE,QAAQ;EACdC,SAAS,EAAE,UAAU;EACrBC,SAAS,EAAE,UAAU;EACrBC,OAAO,EAAE;AACX,CAAC;;AAED;AACA,SAASC,qBAAqBA,CAACC,KAAa,EAAElB,KAAU,EAAoB;EAC1E,IAAImB,EAAE,GAAG,KAAK;EACd,IAAIC,MAAM,GAAGpB,KAAK;;EAElB;EACA,IAAIC,cAAA,CAAcD,KAAK,CAAC,EAAE;IACxBmB,EAAE,GAAG,KAAK;EACZ,CAAC,MAAM,IAAIE,OAAA,CAAOrB,KAAK,MAAK,QAAQ,IAAIA,KAAK,KAAK,IAAI,EAAE;IACtD;IACA,SAAAsB,EAAA,MAAAC,YAAA,GAAgBC,aAAA,CAAYxB,KAAK,CAAC,EAAAsB,EAAA,GAAAC,YAAA,CAAApC,MAAA,EAAAmC,EAAA,IAAE;MAA/B,IAAMG,CAAC,GAAAF,YAAA,CAAAD,EAAA;MACV,IAAII,2BAAA,CAAAD,CAAC,EAAAjC,IAAA,CAADiC,CAAC,EAAY,GAAG,CAAC,EAAE;QACrBN,EAAE,GAAGM,CAAC;QACNL,MAAM,GAAGpB,KAAK,CAACyB,CAAC,CAAC;QACjB;MACF;IACF;EACF;EACA,IAAME,IAAI,GAAGxB,KAAK,CAACgB,EAAE,CAAC;EACtB,IAAI,CAACQ,IAAI,IAAI,OAAOP,MAAM,KAAK,WAAW,EAAE;IAC1C,OAAO,IAAI;EACb;EACA,IAAMQ,SAAS,GAAG7B,qBAAqB,CAACqB,MAAM,CAAC;EAC/C,IAAI,OAAOQ,SAAS,KAAK,WAAW,EAAE;IACpC,OAAO,IAAI;EACb;EACA,QAAQD,IAAI;IACV,KAAK,UAAU;MACb,WAAA/B,MAAA,CAAW,CAAC,KAAK,EAAEsB,KAAK,EAAE,MAAM,EAAEU,SAAS,CAAC,CAAC9B,IAAI,CAAC,GAAG,CAAC;IACxD,KAAK,QAAQ;MACX,OAAO,CAACoB,KAAK,EAAEE,MAAM,GAAG,IAAI,GAAG,GAAG,EAAE,MAAM,CAAC,CAACtB,IAAI,CAAC,GAAG,CAAC;IACvD;MACE,OAAO,CAACoB,KAAK,EAAES,IAAI,EAAEC,SAAS,CAAC,CAAC9B,IAAI,CAAC,GAAG,CAAC;EAC7C;AACF;;AAEA;AACA,SAAS+B,mBAAmBA,CAAA,EAA0B;EAAA,IAAzBC,IAAU,GAAA5C,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,EAAE;EAC1C,IAAI6C,KAA+B,GAAG,EAAE;EACxC,IAAI,OAAOD,IAAI,KAAK,QAAQ,EAAE;IAAA,IAAAE,SAAA;IAC5B,IAAI,qBAAqB,CAACC,IAAI,CAACH,IAAI,CAAC,EAAE;MACpC;MACA,OAAOA,IAAI;IACb;IACA;IACA;IACAC,KAAK,GAAGrC,oBAAA,CAAAsC,SAAA,GAAAF,IAAI,CAACI,KAAK,CAAC,KAAK,CAAC,EAAA1C,IAAA,CAAAwC,SAAA,EAAK,UAACd,KAAK,EAAK;MACvC,IAAIiB,GAAY,GAAG,KAAK,CAAC,CAAC;MAC1B,IAAMC,IAAI,GAAGlB,KAAK,CAAC,CAAC,CAAC;MACrB,IAAIkB,IAAI,KAAK,GAAG,EAAE;QAChBD,GAAG,GAAG,MAAM;QACZjB,KAAK,GAAGA,KAAK,CAACmB,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;MAC9B,CAAC,MAAM,IAAID,IAAI,KAAK,GAAG,EAAE;QACvBlB,KAAK,GAAGA,KAAK,CAACmB,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;MAC9B;MACA,OAAO,CAACnB,KAAK,EAAEiB,GAAG,CAAC;IACrB,CAAC,CAAC;EACJ,CAAC,MAAM,IAAIlC,cAAA,CAAc6B,IAAI,CAAC,EAAE;IAC9BC,KAAK,GAAGD,IAAI;EACd,CAAC,MAAM;IAAA,IAAAQ,SAAA;IACLP,KAAK,GAAGrC,oBAAA,CAAA4C,SAAA,GAAAC,eAAA,CAAeT,IAAI,CAAC,EAAAtC,IAAA,CAAA8C,SAAA,EAC1B,UAAAE,IAAA;MAAA,IAAAC,KAAA,GAAAC,cAAA,CAAAF,IAAA;QAAEtB,KAAK,GAAAuB,KAAA;QAAEN,GAAG,GAAAM,KAAA;MAAA,OAAM,CAACvB,KAAK,EAAEiB,GAAG,CAAC;IAAA,CAChC,CAAC;EACH;EACA,OAAOzC,oBAAA,CAAAqC,KAAK,EAAAvC,IAAA,CAALuC,KAAK,EACL,UAAAY,KAAA,EAAkB;IAAA,IAAAC,SAAA;IAAA,IAAAC,KAAA,GAAAH,cAAA,CAAAC,KAAA;MAAhBzB,KAAK,GAAA2B,KAAA;MAAEV,GAAG,GAAAU,KAAA;IACf;IACA,QAAQjE,MAAM,CAACuD,GAAG,CAAC;MACjB,KAAK,MAAM;MACX,KAAK,MAAM;MACX,KAAK,YAAY;MACjB,KAAK,GAAG;MACR,KAAK,IAAI;QACPA,GAAG,GAAG,MAAM;QACZ;MACF;QACEA,GAAG,GAAG,KAAK;IACf;IACA,OAAA5C,uBAAA,CAAAqD,SAAA,MAAAhD,MAAA,CAAUsB,KAAK,QAAA1B,IAAA,CAAAoD,SAAA,EAAIT,GAAG;EACxB,CAAC,CAAC,CACDrC,IAAI,CAAC,IAAI,CAAC;AACf;AAIA;AACA,SAASgD,qBAAqBA,CAAA,EAIpB;EAAA,IAAAC,SAAA;EAAA,IAHRC,UAAqB,GAAA9D,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAAA,IAC1B+D,QAAyB,GAAA/D,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,KAAK;EAAA,IACjCgE,KAAa,GAAAhE,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC;EAEjB,IAAI,OAAO8D,UAAU,KAAK,QAAQ,EAAE;IAClC,OAAOA,UAAU;EACnB;EACA,IAAIG,aAAuD,GAAG,EAAE;EAChE,IAAI,CAAClD,cAAA,CAAc+C,UAAU,CAAC,EAAE;IAAA,IAAAI,SAAA;IAC9B;IACA,IAAMC,aAAa,GAAGL,UAAU;IAChCG,aAAa,GAAGzD,oBAAA,CAAA0D,SAAA,GAAA5B,aAAA,CAAY6B,aAAa,CAAC,EAAA7D,IAAA,CAAA4D,SAAA,EAAK,UAACE,GAAG;MAAA,OAAM;QACvDA,GAAG,EAAHA,GAAG;QACHtD,KAAK,EAAEqD,aAAa,CAACC,GAAG;MAC1B,CAAC;IAAA,CAAC,CAAC;EACL,CAAC,MAAM;IACLH,aAAa,GAAGzD,oBAAA,CAAAsD,UAAU,EAAAxD,IAAA,CAAVwD,UAAU,EAAK,UAACO,IAAI,EAAK;MAAA,IAAAC,SAAA;MACvC,IAAMC,KAAK,GAAG/D,oBAAA,CAAA8D,SAAA,GAAAhC,aAAA,CAAY+B,IAAI,CAAC,EAAA/D,IAAA,CAAAgE,SAAA,EAAK,UAACF,GAAG;QAAA,OAAM;UAAEA,GAAG,EAAHA,GAAG;UAAEtD,KAAK,EAAEuD,IAAI,CAACD,GAAG;QAAE,CAAC;MAAA,CAAC,CAAC;MACzE,OAAOG,KAAK,CAACtE,MAAM,GAAG,CAAC,GACnB;QAAEmE,GAAG,EAAE,MAAM;QAAEtD,KAAK,EAAEN,oBAAA,CAAA+D,KAAK,EAAAjE,IAAA,CAALiE,KAAK,EAAK,UAACC,CAAC;UAAA,OAAAC,eAAA,KAASD,CAAC,CAACJ,GAAG,EAAGI,CAAC,CAAC1D,KAAK;QAAA,CAAG;MAAE,CAAC,GAChEyD,KAAK,CAAC,CAAC,CAAC;IACd,CAAC,CAAC;EACJ;EACA,IAAMG,gBAAgB,GAAIC,uBAAA,CAAAd,SAAA,GAAArD,oBAAA,CAAAyD,aAAa,EAAA3D,IAAA,CAAb2D,aAAa,EAChC,UAACI,IAAI,EAAK;IACb,IAAIO,CAAC,GAAGZ,KAAK,GAAG,CAAC;IACjB,IAAI/B,EAA6B;IACjC,QAAQoC,IAAI,CAACD,GAAG;MACd,KAAK,KAAK;MACV,KAAK,MAAM;MACX,KAAK,MAAM;QACT,IAAIL,QAAQ,KAAK,KAAK,IAAIE,aAAa,CAAChE,MAAM,KAAK,CAAC,EAAE;UACpD2E,CAAC,GAAGZ,KAAK,CAAC,CAAC;QACb;QACA/B,EAAE,GAAGoC,IAAI,CAACD,GAAG,KAAK,KAAK,GAAG,IAAI,GAAGC,IAAI,CAACD,GAAG,KAAK,MAAM,GAAG,KAAK,GAAG,KAAK;QACpE,OAAOR,qBAAqB,CAACS,IAAI,CAACvD,KAAK,EAAEmB,EAAE,EAAE2C,CAAC,CAAC;MACjD;QACE,OAAO7C,qBAAqB,CAACsC,IAAI,CAACD,GAAG,EAAEC,IAAI,CAACvD,KAAK,CAAC;IACtD;EACF,CAAC,CAAC,EAAAR,IAAA,CAAAuD,SAAA,EACM,UAACgB,IAAI;IAAA,OAAKA,IAAI;EAAA,EAAqB;EAE7C,IAAIC,QAAiB;EACrB,IAAIf,QAAQ,KAAK,KAAK,EAAE;IAAA,IAAAgB,SAAA,EAAAC,SAAA;IACtBF,QAAQ,GAAGd,KAAK,GAAG,CAAC;IACpB,OAAA3D,uBAAA,CAAA0E,SAAA,GAAA1E,uBAAA,CAAA2E,SAAA,MAAAtE,MAAA,CAAUoE,QAAQ,GAAG,GAAG,GAAG,EAAE,WAAAxE,IAAA,CAAA0E,SAAA,EAAON,gBAAgB,CAAC,CAAC,CAAC,GAAApE,IAAA,CAAAyE,SAAA,EACrDD,QAAQ,GAAG,GAAG,GAAG,EAAE;EAEvB;EACAA,QAAQ,GAAGd,KAAK,GAAG,CAAC,IAAIU,gBAAgB,CAACzE,MAAM,GAAG,CAAC;EACnD,OACE,CAAC6E,QAAQ,GAAG,GAAG,GAAG,EAAE,IACpBJ,gBAAgB,CAAC9D,IAAI,KAAAF,MAAA,CAAKqD,QAAQ,MAAG,CAAC,IACrCe,QAAQ,GAAG,GAAG,GAAG,EAAE,CAAC;AAEzB;;AAEA;AACA;AACA;AACA;AACA,OAAO,SAASnE,UAAUA,CAACsE,KAAkB,EAAU;EACrD,IAAIC,IAAI,GAAG,CACT,SAAS,EACTtF,kBAAkB,CAACqF,KAAK,CAACpF,MAAM,EAAAsF,yBAAA,CAAEF,KAAK,CAAS,CAAC,EAChD,QAAQ,EACRA,KAAK,CAACG,KAAK,CACZ,CAACxE,IAAI,CAAC,EAAE,CAAC;EACV,IAAMyD,IAAI,GAAGT,qBAAqB,CAACqB,KAAK,CAACnB,UAAU,CAAC;EACpD,IAAIO,IAAI,EAAE;IACRa,IAAI,cAAAxE,MAAA,CAAc2D,IAAI,CAAE;EAC1B;EACA,IAAMgB,OAAO,GAAG1C,mBAAmB,CAAA2C,qBAAA,CAACL,KAAK,CAAK,CAAC;EAC/C,IAAII,OAAO,EAAE;IACXH,IAAI,iBAAAxE,MAAA,CAAiB2E,OAAO,CAAE;EAChC;EACA,IAAIJ,KAAK,CAACM,KAAK,EAAE;IACfL,IAAI,cAAAxE,MAAA,CAAcuE,KAAK,CAACM,KAAK,CAAE;EACjC;EACA,IAAIN,KAAK,CAACO,MAAM,EAAE;IAChBN,IAAI,eAAAxE,MAAA,CAAeuE,KAAK,CAACO,MAAM,CAAE;EACnC;EACA,OAAON,IAAI;AACb","ignoreList":[]}