@sanity/client 3.3.0 → 3.4.0-beta.esm.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/README.md +3 -5
  2. package/dist/sanityClient.browser.mjs +4317 -0
  3. package/dist/sanityClient.browser.mjs.map +7 -0
  4. package/dist/sanityClient.node.js +1129 -0
  5. package/dist/sanityClient.node.js.map +7 -0
  6. package/package.json +26 -6
  7. package/sanityClient.d.ts +3 -2
  8. package/src/assets/assetsClient.js +135 -0
  9. package/src/auth/authClient.js +17 -0
  10. package/src/config.js +96 -0
  11. package/src/data/dataMethods.js +183 -0
  12. package/src/data/encodeQueryString.js +18 -0
  13. package/src/data/listen.js +160 -0
  14. package/src/data/patch.js +124 -0
  15. package/src/data/transaction.js +106 -0
  16. package/src/datasets/datasetsClient.js +31 -0
  17. package/src/http/browserMiddleware.js +1 -0
  18. package/src/http/errors.js +57 -0
  19. package/src/http/nodeMiddleware.js +13 -0
  20. package/src/http/queryString.js +10 -0
  21. package/src/http/request.js +54 -0
  22. package/src/http/requestOptions.js +31 -0
  23. package/src/projects/projectsClient.js +17 -0
  24. package/src/sanityClient.js +119 -0
  25. package/src/users/usersClient.js +13 -0
  26. package/src/util/defaults.js +8 -0
  27. package/src/util/getSelection.js +17 -0
  28. package/src/util/observable.js +11 -0
  29. package/src/util/once.js +12 -0
  30. package/src/util/pick.js +9 -0
  31. package/src/validators.js +76 -0
  32. package/src/warnings.js +25 -0
  33. package/test/client.test.js +0 -2561
  34. package/test/encodeQueryString.test.js +0 -36
  35. package/test/fixtures/horsehead-nebula.jpg +0 -0
  36. package/test/fixtures/pdf-sample.pdf +0 -0
  37. package/test/helpers/sseServer.js +0 -26
  38. package/test/listen.test.js +0 -205
  39. package/test/warnings.test.disabled.js +0 -80
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/util/observable.js", "../src/util/getSelection.js", "../src/validators.js", "../src/data/patch.js", "../src/data/transaction.js", "../src/data/encodeQueryString.js", "../src/util/pick.js", "../src/util/defaults.js", "../src/data/listen.js", "../src/data/dataMethods.js", "../src/datasets/datasetsClient.js", "../src/projects/projectsClient.js", "../src/http/queryString.js", "../src/assets/assetsClient.js", "../src/users/usersClient.js", "../src/auth/authClient.js", "../src/http/errors.js", "../src/http/nodeMiddleware.js", "../src/http/request.js", "../src/http/requestOptions.js", "../src/util/once.js", "../src/warnings.js", "../src/config.js", "../src/sanityClient.js"],
4
+ "sourcesContent": ["// Since `@sanity/client` doesn't offer ESM exports (yet) const {filter} = require('rxjs/operators') will cause the the whole of rxjs to be included in the bundle.\n// The internal import paths here is a stop-gap measure and will become less of a problem when @sanity/client export tree-shakeable esm bundles\nconst {Observable} = require('rxjs/internal/Observable')\nconst {filter} = require('rxjs/internal/operators/filter')\nconst {map} = require('rxjs/internal/operators/map')\n\nmodule.exports = {\n Observable,\n filter,\n map,\n}\n", "module.exports = function getSelection(sel) {\n if (typeof sel === 'string' || Array.isArray(sel)) {\n return {id: sel}\n }\n\n if (sel && sel.query) {\n return 'params' in sel ? {query: sel.query, params: sel.params} : {query: sel.query}\n }\n\n const selectionOpts = [\n '* Document ID (<docId>)',\n '* Array of document IDs',\n '* Object containing `query`',\n ].join('\\n')\n\n throw new Error(`Unknown selection - must be one of:\\n\\n${selectionOpts}`)\n}\n", "const VALID_ASSET_TYPES = ['image', 'file']\nconst VALID_INSERT_LOCATIONS = ['before', 'after', 'replace']\n\nexports.dataset = (name) => {\n if (!/^(~[a-z0-9]{1}[-\\w]{0,63}|[a-z0-9]{1}[-\\w]{0,63})$/.test(name)) {\n throw new Error(\n 'Datasets can only contain lowercase characters, numbers, underscores and dashes, and start with tilde, and be maximum 64 characters'\n )\n }\n}\n\nexports.projectId = (id) => {\n if (!/^[-a-z0-9]+$/i.test(id)) {\n throw new Error('`projectId` can only contain only a-z, 0-9 and dashes')\n }\n}\n\nexports.validateAssetType = (type) => {\n if (VALID_ASSET_TYPES.indexOf(type) === -1) {\n throw new Error(`Invalid asset type: ${type}. Must be one of ${VALID_ASSET_TYPES.join(', ')}`)\n }\n}\n\nexports.validateObject = (op, val) => {\n if (val === null || typeof val !== 'object' || Array.isArray(val)) {\n throw new Error(`${op}() takes an object of properties`)\n }\n}\n\nexports.requireDocumentId = (op, doc) => {\n if (!doc._id) {\n throw new Error(`${op}() requires that the document contains an ID (\"_id\" property)`)\n }\n\n exports.validateDocumentId(op, doc._id)\n}\n\nexports.validateDocumentId = (op, id) => {\n if (typeof id !== 'string' || !/^[a-z0-9_.-]+$/i.test(id)) {\n throw new Error(`${op}(): \"${id}\" is not a valid document ID`)\n }\n}\n\nexports.validateInsert = (at, selector, items) => {\n const signature = 'insert(at, selector, items)'\n if (VALID_INSERT_LOCATIONS.indexOf(at) === -1) {\n const valid = VALID_INSERT_LOCATIONS.map((loc) => `\"${loc}\"`).join(', ')\n throw new Error(`${signature} takes an \"at\"-argument which is one of: ${valid}`)\n }\n\n if (typeof selector !== 'string') {\n throw new Error(`${signature} takes a \"selector\"-argument which must be a string`)\n }\n\n if (!Array.isArray(items)) {\n throw new Error(`${signature} takes an \"items\"-argument which must be an array`)\n }\n}\n\nexports.hasDataset = (config) => {\n if (!config.dataset) {\n throw new Error('`dataset` must be provided to perform queries')\n }\n\n return config.dataset || ''\n}\n\nexports.requestTag = (tag) => {\n if (typeof tag !== 'string' || !/^[a-z0-9._-]{1,75}$/i.test(tag)) {\n throw new Error(\n `Tag can only contain alphanumeric characters, underscores, dashes and dots, and be between one and 75 characters long.`\n )\n }\n\n return tag\n}\n", "const assign = require('object-assign')\nconst getSelection = require('../util/getSelection')\nconst validate = require('../validators')\nconst validateObject = validate.validateObject\nconst validateInsert = validate.validateInsert\n\nfunction Patch(selection, operations = {}, client = null) {\n this.selection = selection\n this.operations = assign({}, operations)\n this.client = client\n}\n\nassign(Patch.prototype, {\n clone() {\n return new Patch(this.selection, assign({}, this.operations), this.client)\n },\n\n set(props) {\n return this._assign('set', props)\n },\n\n diffMatchPatch(props) {\n validateObject('diffMatchPatch', props)\n return this._assign('diffMatchPatch', props)\n },\n\n unset(attrs) {\n if (!Array.isArray(attrs)) {\n throw new Error('unset(attrs) takes an array of attributes to unset, non-array given')\n }\n\n this.operations = assign({}, this.operations, {unset: attrs})\n return this\n },\n\n setIfMissing(props) {\n return this._assign('setIfMissing', props)\n },\n\n replace(props) {\n validateObject('replace', props)\n return this._set('set', {$: props}) // eslint-disable-line id-length\n },\n\n inc(props) {\n return this._assign('inc', props)\n },\n\n dec(props) {\n return this._assign('dec', props)\n },\n\n insert(at, selector, items) {\n validateInsert(at, selector, items)\n return this._assign('insert', {[at]: selector, items})\n },\n\n append(selector, items) {\n return this.insert('after', `${selector}[-1]`, items)\n },\n\n prepend(selector, items) {\n return this.insert('before', `${selector}[0]`, items)\n },\n\n splice(selector, start, deleteCount, items) {\n // Negative indexes doesn't mean the same in Sanity as they do in JS;\n // -1 means \"actually at the end of the array\", which allows inserting\n // at the end of the array without knowing its length. We therefore have\n // to substract negative indexes by one to match JS. If you want Sanity-\n // behaviour, just use `insert('replace', selector, items)` directly\n const delAll = typeof deleteCount === 'undefined' || deleteCount === -1\n const startIndex = start < 0 ? start - 1 : start\n const delCount = delAll ? -1 : Math.max(0, start + deleteCount)\n const delRange = startIndex < 0 && delCount >= 0 ? '' : delCount\n const rangeSelector = `${selector}[${startIndex}:${delRange}]`\n return this.insert('replace', rangeSelector, items || [])\n },\n\n ifRevisionId(rev) {\n this.operations.ifRevisionID = rev\n return this\n },\n\n serialize() {\n return assign(getSelection(this.selection), this.operations)\n },\n\n toJSON() {\n return this.serialize()\n },\n\n commit(options = {}) {\n if (!this.client) {\n throw new Error(\n 'No `client` passed to patch, either provide one or pass the ' +\n 'patch to a clients `mutate()` method'\n )\n }\n\n const returnFirst = typeof this.selection === 'string'\n const opts = assign({returnFirst, returnDocuments: true}, options)\n return this.client.mutate({patch: this.serialize()}, opts)\n },\n\n reset() {\n this.operations = {}\n return this\n },\n\n _set(op, props) {\n return this._assign(op, props, false)\n },\n\n _assign(op, props, merge = true) {\n validateObject(op, props)\n this.operations = assign({}, this.operations, {\n [op]: assign({}, (merge && this.operations[op]) || {}, props),\n })\n return this\n },\n})\n\nmodule.exports = Patch\n", "const assign = require('object-assign')\nconst validators = require('../validators')\nconst Patch = require('./patch')\n\nconst defaultMutateOptions = {returnDocuments: false}\n\nfunction Transaction(operations = [], client, transactionId) {\n this.trxId = transactionId\n this.operations = operations\n this.client = client\n}\n\nassign(Transaction.prototype, {\n clone() {\n return new Transaction(this.operations.slice(0), this.client, this.trxId)\n },\n\n create(doc) {\n validators.validateObject('create', doc)\n return this._add({create: doc})\n },\n\n createIfNotExists(doc) {\n const op = 'createIfNotExists'\n validators.validateObject(op, doc)\n validators.requireDocumentId(op, doc)\n return this._add({[op]: doc})\n },\n\n createOrReplace(doc) {\n const op = 'createOrReplace'\n validators.validateObject(op, doc)\n validators.requireDocumentId(op, doc)\n return this._add({[op]: doc})\n },\n\n delete(documentId) {\n validators.validateDocumentId('delete', documentId)\n return this._add({delete: {id: documentId}})\n },\n\n patch(documentId, patchOps) {\n const isBuilder = typeof patchOps === 'function'\n const isPatch = documentId instanceof Patch\n\n // transaction.patch(client.patch('documentId').inc({visits: 1}))\n if (isPatch) {\n return this._add({patch: documentId.serialize()})\n }\n\n // patch => patch.inc({visits: 1}).set({foo: 'bar'})\n if (isBuilder) {\n const patch = patchOps(new Patch(documentId, {}, this.client))\n if (!(patch instanceof Patch)) {\n throw new Error('function passed to `patch()` must return the patch')\n }\n\n return this._add({patch: patch.serialize()})\n }\n\n return this._add({patch: assign({id: documentId}, patchOps)})\n },\n\n transactionId(id) {\n if (!id) {\n return this.trxId\n }\n\n this.trxId = id\n return this\n },\n\n serialize() {\n return this.operations.slice()\n },\n\n toJSON() {\n return this.serialize()\n },\n\n commit(options) {\n if (!this.client) {\n throw new Error(\n 'No `client` passed to transaction, either provide one or pass the ' +\n 'transaction to a clients `mutate()` method'\n )\n }\n\n return this.client.mutate(\n this.serialize(),\n assign({transactionId: this.trxId}, defaultMutateOptions, options || {})\n )\n },\n\n reset() {\n this.operations = []\n return this\n },\n\n _add(mut) {\n this.operations.push(mut)\n return this\n },\n})\n\nmodule.exports = Transaction\n", "const enc = encodeURIComponent\n\nmodule.exports = ({query, params = {}, options = {}}) => {\n // We generally want tag at the start of the query string\n const {tag, ...opts} = options\n const q = `query=${enc(query)}`\n const base = tag ? `?tag=${enc(tag)}&${q}` : `?${q}`\n\n const qString = Object.keys(params).reduce(\n (qs, param) => `${qs}&${enc(`$${param}`)}=${enc(JSON.stringify(params[param]))}`,\n base\n )\n\n return Object.keys(opts).reduce((qs, option) => {\n // Only include the option if it is truthy\n return options[option] ? `${qs}&${enc(option)}=${enc(options[option])}` : qs\n }, qString)\n}\n", "module.exports = (obj, props) =>\n props.reduce((selection, prop) => {\n if (typeof obj[prop] === 'undefined') {\n return selection\n }\n\n selection[prop] = obj[prop]\n return selection\n }, {})\n", "module.exports = (obj, defaults) =>\n Object.keys(defaults)\n .concat(Object.keys(obj))\n .reduce((target, prop) => {\n target[prop] = typeof obj[prop] === 'undefined' ? defaults[prop] : obj[prop]\n\n return target\n }, {})\n", "const assign = require('object-assign')\nconst {Observable} = require('../util/observable')\nconst polyfilledEventSource = require('@sanity/eventsource')\nconst pick = require('../util/pick')\nconst defaults = require('../util/defaults')\nconst encodeQueryString = require('./encodeQueryString')\n\n// Limit is 16K for a _request_, eg including headers. Have to account for an\n// unknown range of headers, but an average EventSource request from Chrome seems\n// to have around 700 bytes of cruft, so let us account for 1.2K to be \"safe\"\nconst MAX_URL_LENGTH = 16000 - 1200\nconst EventSource = polyfilledEventSource\n\nconst possibleOptions = [\n 'includePreviousRevision',\n 'includeResult',\n 'visibility',\n 'effectFormat',\n 'tag',\n]\n\nconst defaultOptions = {\n includeResult: true,\n}\n\nmodule.exports = function listen(query, params, opts = {}) {\n const {url, token, withCredentials, requestTagPrefix} = this.clientConfig\n const tag = opts.tag && requestTagPrefix ? [requestTagPrefix, opts.tag].join('.') : opts.tag\n const options = {...defaults(opts, defaultOptions), tag}\n const listenOpts = pick(options, possibleOptions)\n const qs = encodeQueryString({query, params, options: listenOpts, tag})\n\n const uri = `${url}${this.getDataUrl('listen', qs)}`\n if (uri.length > MAX_URL_LENGTH) {\n return new Observable((observer) => observer.error(new Error('Query too large for listener')))\n }\n\n const listenFor = options.events ? options.events : ['mutation']\n const shouldEmitReconnect = listenFor.indexOf('reconnect') !== -1\n\n const esOptions = {}\n if (token || withCredentials) {\n esOptions.withCredentials = true\n }\n\n if (token) {\n esOptions.headers = {\n Authorization: `Bearer ${token}`,\n }\n }\n\n return new Observable((observer) => {\n let es = getEventSource()\n let reconnectTimer\n let stopped = false\n\n function onError() {\n if (stopped) {\n return\n }\n\n emitReconnect()\n\n // Allow event handlers of `emitReconnect` to cancel/close the reconnect attempt\n if (stopped) {\n return\n }\n\n // Unless we've explicitly stopped the ES (in which case `stopped` should be true),\n // we should never be in a disconnected state. By default, EventSource will reconnect\n // automatically, in which case it sets readyState to `CONNECTING`, but in some cases\n // (like when a laptop lid is closed), it closes the connection. In these cases we need\n // to explicitly reconnect.\n if (es.readyState === EventSource.CLOSED) {\n unsubscribe()\n clearTimeout(reconnectTimer)\n reconnectTimer = setTimeout(open, 100)\n }\n }\n\n function onChannelError(err) {\n observer.error(cooerceError(err))\n }\n\n function onMessage(evt) {\n const event = parseEvent(evt)\n return event instanceof Error ? observer.error(event) : observer.next(event)\n }\n\n function onDisconnect(evt) {\n stopped = true\n unsubscribe()\n observer.complete()\n }\n\n function unsubscribe() {\n es.removeEventListener('error', onError, false)\n es.removeEventListener('channelError', onChannelError, false)\n es.removeEventListener('disconnect', onDisconnect, false)\n listenFor.forEach((type) => es.removeEventListener(type, onMessage, false))\n es.close()\n }\n\n function emitReconnect() {\n if (shouldEmitReconnect) {\n observer.next({type: 'reconnect'})\n }\n }\n\n function getEventSource() {\n const evs = new EventSource(uri, esOptions)\n evs.addEventListener('error', onError, false)\n evs.addEventListener('channelError', onChannelError, false)\n evs.addEventListener('disconnect', onDisconnect, false)\n listenFor.forEach((type) => evs.addEventListener(type, onMessage, false))\n return evs\n }\n\n function open() {\n es = getEventSource()\n }\n\n function stop() {\n stopped = true\n unsubscribe()\n }\n\n return stop\n })\n}\n\nfunction parseEvent(event) {\n try {\n const data = (event.data && JSON.parse(event.data)) || {}\n return assign({type: event.type}, data)\n } catch (err) {\n return err\n }\n}\n\nfunction cooerceError(err) {\n if (err instanceof Error) {\n return err\n }\n\n const evt = parseEvent(err)\n return evt instanceof Error ? evt : new Error(extractErrorMessage(evt))\n}\n\nfunction extractErrorMessage(err) {\n if (!err.error) {\n return err.message || 'Unknown listener error'\n }\n\n if (err.error.description) {\n return err.error.description\n }\n\n return typeof err.error === 'string' ? err.error : JSON.stringify(err.error, null, 2)\n}\n", "const assign = require('object-assign')\nconst {map, filter} = require('../util/observable')\nconst validators = require('../validators')\nconst getSelection = require('../util/getSelection')\nconst encodeQueryString = require('./encodeQueryString')\nconst Transaction = require('./transaction')\nconst Patch = require('./patch')\nconst listen = require('./listen')\n\nconst excludeFalsey = (param, defValue) => {\n const value = typeof param === 'undefined' ? defValue : param\n return param === false ? undefined : value\n}\n\nconst getMutationQuery = (options = {}) => {\n return {\n dryRun: options.dryRun,\n returnIds: true,\n returnDocuments: excludeFalsey(options.returnDocuments, true),\n visibility: options.visibility || 'sync',\n autoGenerateArrayKeys: options.autoGenerateArrayKeys,\n skipCrossDatasetReferenceValidation: options.skipCrossDatasetReferenceValidation,\n }\n}\n\nconst isResponse = (event) => event.type === 'response'\nconst getBody = (event) => event.body\n\nconst indexBy = (docs, attr) =>\n docs.reduce((indexed, doc) => {\n indexed[attr(doc)] = doc\n return indexed\n }, Object.create(null))\n\nconst toPromise = (observable) => observable.toPromise()\n\nconst getQuerySizeLimit = 11264\n\nmodule.exports = {\n listen: listen,\n\n getDataUrl(operation, path) {\n const config = this.clientConfig\n const catalog = validators.hasDataset(config)\n const baseUri = `/${operation}/${catalog}`\n const uri = path ? `${baseUri}/${path}` : baseUri\n return `/data${uri}`.replace(/\\/($|\\?)/, '$1')\n },\n\n fetch(query, params, options = {}) {\n const mapResponse = options.filterResponse === false ? (res) => res : (res) => res.result\n\n const observable = this._dataRequest('query', {query, params}, options).pipe(map(mapResponse))\n return this.isPromiseAPI() ? toPromise(observable) : observable\n },\n\n getDocument(id, opts = {}) {\n const options = {uri: this.getDataUrl('doc', id), json: true, tag: opts.tag}\n const observable = this._requestObservable(options).pipe(\n filter(isResponse),\n map((event) => event.body.documents && event.body.documents[0])\n )\n\n return this.isPromiseAPI() ? toPromise(observable) : observable\n },\n\n getDocuments(ids, opts = {}) {\n const options = {uri: this.getDataUrl('doc', ids.join(',')), json: true, tag: opts.tag}\n const observable = this._requestObservable(options).pipe(\n filter(isResponse),\n map((event) => {\n const indexed = indexBy(event.body.documents || [], (doc) => doc._id)\n return ids.map((id) => indexed[id] || null)\n })\n )\n\n return this.isPromiseAPI() ? toPromise(observable) : observable\n },\n\n create(doc, options) {\n return this._create(doc, 'create', options)\n },\n\n createIfNotExists(doc, options) {\n validators.requireDocumentId('createIfNotExists', doc)\n return this._create(doc, 'createIfNotExists', options)\n },\n\n createOrReplace(doc, options) {\n validators.requireDocumentId('createOrReplace', doc)\n return this._create(doc, 'createOrReplace', options)\n },\n\n patch(selector, operations) {\n return new Patch(selector, operations, this)\n },\n\n delete(selection, options) {\n return this.dataRequest('mutate', {mutations: [{delete: getSelection(selection)}]}, options)\n },\n\n mutate(mutations, options) {\n const mut =\n mutations instanceof Patch || mutations instanceof Transaction\n ? mutations.serialize()\n : mutations\n\n const muts = Array.isArray(mut) ? mut : [mut]\n const transactionId = options && options.transactionId\n return this.dataRequest('mutate', {mutations: muts, transactionId}, options)\n },\n\n transaction(operations) {\n return new Transaction(operations, this)\n },\n\n dataRequest(endpoint, body, options = {}) {\n const request = this._dataRequest(endpoint, body, options)\n\n return this.isPromiseAPI() ? toPromise(request) : request\n },\n\n _dataRequest(endpoint, body, options = {}) {\n const isMutation = endpoint === 'mutate'\n const isQuery = endpoint === 'query'\n\n // Check if the query string is within a configured threshold,\n // in which case we can use GET. Otherwise, use POST.\n const strQuery = !isMutation && encodeQueryString(body)\n const useGet = !isMutation && strQuery.length < getQuerySizeLimit\n const stringQuery = useGet ? strQuery : ''\n const returnFirst = options.returnFirst\n const {timeout, token, tag, headers} = options\n\n const uri = this.getDataUrl(endpoint, stringQuery)\n\n const reqOptions = {\n method: useGet ? 'GET' : 'POST',\n uri: uri,\n json: true,\n body: useGet ? undefined : body,\n query: isMutation && getMutationQuery(options),\n timeout,\n headers,\n token,\n tag,\n canUseCdn: isQuery,\n }\n\n return this._requestObservable(reqOptions).pipe(\n filter(isResponse),\n map(getBody),\n map((res) => {\n if (!isMutation) {\n return res\n }\n\n // Should we return documents?\n const results = res.results || []\n if (options.returnDocuments) {\n return returnFirst\n ? results[0] && results[0].document\n : results.map((mut) => mut.document)\n }\n\n // Return a reduced subset\n const key = returnFirst ? 'documentId' : 'documentIds'\n const ids = returnFirst ? results[0] && results[0].id : results.map((mut) => mut.id)\n return {\n transactionId: res.transactionId,\n results: results,\n [key]: ids,\n }\n })\n )\n },\n\n _create(doc, op, options = {}) {\n const mutation = {[op]: doc}\n const opts = assign({returnFirst: true, returnDocuments: true}, options)\n return this.dataRequest('mutate', {mutations: [mutation]}, opts)\n },\n}\n", "const assign = require('object-assign')\nconst validate = require('../validators')\n\nfunction DatasetsClient(client) {\n this.request = client.request.bind(client)\n}\n\nassign(DatasetsClient.prototype, {\n create(name, options) {\n return this._modify('PUT', name, options)\n },\n\n edit(name, options) {\n return this._modify('PATCH', name, options)\n },\n\n delete(name) {\n return this._modify('DELETE', name)\n },\n\n list() {\n return this.request({uri: '/datasets'})\n },\n\n _modify(method, name, body) {\n validate.dataset(name)\n return this.request({method, uri: `/datasets/${name}`, body})\n },\n})\n\nmodule.exports = DatasetsClient\n", "const assign = require('object-assign')\n\nfunction ProjectsClient(client) {\n this.client = client\n}\n\nassign(ProjectsClient.prototype, {\n list() {\n return this.client.request({uri: '/projects'})\n },\n\n getById(id) {\n return this.client.request({uri: `/projects/${id}`})\n },\n})\n\nmodule.exports = ProjectsClient\n", "module.exports = (params) => {\n const qs = []\n for (const key in params) {\n if (params.hasOwnProperty(key)) {\n qs.push(`${encodeURIComponent(key)}=${encodeURIComponent(params[key])}`)\n }\n }\n\n return qs.length > 0 ? `?${qs.join('&')}` : ''\n}\n", "const assign = require('object-assign')\nconst {map, filter} = require('../util/observable')\nconst queryString = require('../http/queryString')\nconst validators = require('../validators')\n\nfunction AssetsClient(client) {\n this.client = client\n}\n\nfunction optionsFromFile(opts, file) {\n if (typeof window === 'undefined' || !(file instanceof window.File)) {\n return opts\n }\n\n return assign(\n {\n filename: opts.preserveFilename === false ? undefined : file.name,\n contentType: file.type,\n },\n opts\n )\n}\n\nassign(AssetsClient.prototype, {\n /**\n * Upload an asset\n *\n * @param {String} assetType `image` or `file`\n * @param {File|Blob|Buffer|ReadableStream} body File to upload\n * @param {Object} opts Options for the upload\n * @param {Boolean} opts.preserveFilename Whether or not to preserve the original filename (default: true)\n * @param {String} opts.filename Filename for this file (optional)\n * @param {Number} opts.timeout Milliseconds to wait before timing the request out (default: 0)\n * @param {String} opts.contentType Mime type of the file\n * @param {Array} opts.extract Array of metadata parts to extract from image.\n * Possible values: `location`, `exif`, `image`, `palette`\n * @param {String} opts.label Label\n * @param {String} opts.title Title\n * @param {String} opts.description Description\n * @param {String} opts.creditLine The credit to person(s) and/or organization(s) required by the supplier of the image to be used when published\n * @param {Object} opts.source Source data (when the asset is from an external service)\n * @param {String} opts.source.id The (u)id of the asset within the source, i.e. 'i-f323r1E'\n * Required if source is defined\n * @param {String} opts.source.name The name of the source, i.e. 'unsplash'\n * Required if source is defined\n * @param {String} opts.source.url A url to where to find the asset, or get more info about it in the source\n * Optional\n * @return {Promise} Resolves with the created asset document\n */\n upload(assetType, body, opts = {}) {\n validators.validateAssetType(assetType)\n\n // If an empty array is given, explicitly set `none` to override API defaults\n let meta = opts.extract || undefined\n if (meta && !meta.length) {\n meta = ['none']\n }\n\n const dataset = validators.hasDataset(this.client.clientConfig)\n const assetEndpoint = assetType === 'image' ? 'images' : 'files'\n const options = optionsFromFile(opts, body)\n const {tag, label, title, description, creditLine, filename, source} = options\n const query = {\n label,\n title,\n description,\n filename,\n meta,\n creditLine,\n }\n if (source) {\n query.sourceId = source.id\n query.sourceName = source.name\n query.sourceUrl = source.url\n }\n const observable = this.client._requestObservable({\n tag,\n method: 'POST',\n timeout: options.timeout || 0,\n uri: `/assets/${assetEndpoint}/${dataset}`,\n headers: options.contentType ? {'Content-Type': options.contentType} : {},\n query,\n body,\n })\n\n return this.client.isPromiseAPI()\n ? observable\n .pipe(\n filter((event) => event.type === 'response'),\n map((event) => event.body.document)\n )\n .toPromise()\n : observable\n },\n\n delete(type, id) {\n // eslint-disable-next-line no-console\n console.warn('client.assets.delete() is deprecated, please use client.delete(<document-id>)')\n\n let docId = id || ''\n if (!/^(image|file)-/.test(docId)) {\n docId = `${type}-${docId}`\n } else if (type._id) {\n // We could be passing an entire asset document instead of an ID\n docId = type._id\n }\n\n validators.hasDataset(this.client.clientConfig)\n return this.client.delete(docId)\n },\n\n getImageUrl(ref, query) {\n const id = ref._ref || ref\n if (typeof id !== 'string') {\n throw new Error(\n 'getImageUrl() needs either an object with a _ref, or a string with an asset document ID'\n )\n }\n\n if (!/^image-[A-Za-z0-9_]+-\\d+x\\d+-[a-z]{1,5}$/.test(id)) {\n throw new Error(\n `Unsupported asset ID \"${id}\". URL generation only works for auto-generated IDs.`\n )\n }\n\n const [, assetId, size, format] = id.split('-')\n\n validators.hasDataset(this.client.clientConfig)\n const {projectId, dataset} = this.client.clientConfig\n const qs = query ? queryString(query) : ''\n return `https://cdn.sanity.io/images/${projectId}/${dataset}/${assetId}-${size}.${format}${qs}`\n },\n})\n\nmodule.exports = AssetsClient\n", "const assign = require('object-assign')\n\nfunction UsersClient(client) {\n this.client = client\n}\n\nassign(UsersClient.prototype, {\n getById(id) {\n return this.client.request({uri: `/users/${id}`})\n },\n})\n\nmodule.exports = UsersClient\n", "const assign = require('object-assign')\n\nfunction AuthClient(client) {\n this.client = client\n}\n\nassign(AuthClient.prototype, {\n getLoginProviders() {\n return this.client.request({uri: '/auth/providers'})\n },\n\n logout() {\n return this.client.request({uri: '/auth/logout', method: 'POST'})\n },\n})\n\nmodule.exports = AuthClient\n", "const makeError = require('make-error')\nconst assign = require('object-assign')\n\nfunction ClientError(res) {\n const props = extractErrorProps(res)\n ClientError.super.call(this, props.message)\n assign(this, props)\n}\n\nfunction ServerError(res) {\n const props = extractErrorProps(res)\n ServerError.super.call(this, props.message)\n assign(this, props)\n}\n\nfunction extractErrorProps(res) {\n const body = res.body\n const props = {\n response: res,\n statusCode: res.statusCode,\n responseBody: stringifyBody(body, res),\n }\n\n // API/Boom style errors ({statusCode, error, message})\n if (body.error && body.message) {\n props.message = `${body.error} - ${body.message}`\n return props\n }\n\n // Query/database errors ({error: {description, other, arb, props}})\n if (body.error && body.error.description) {\n props.message = body.error.description\n props.details = body.error\n return props\n }\n\n // Other, more arbitrary errors\n props.message = body.error || body.message || httpErrorMessage(res)\n return props\n}\n\nfunction httpErrorMessage(res) {\n const statusMessage = res.statusMessage ? ` ${res.statusMessage}` : ''\n return `${res.method}-request to ${res.url} resulted in HTTP ${res.statusCode}${statusMessage}`\n}\n\nfunction stringifyBody(body, res) {\n const contentType = (res.headers['content-type'] || '').toLowerCase()\n const isJson = contentType.indexOf('application/json') !== -1\n return isJson ? JSON.stringify(body, null, 2) : body\n}\n\nmakeError(ClientError)\nmakeError(ServerError)\n\nexports.ClientError = ClientError\nexports.ServerError = ServerError\n", "const retry = require('get-it/lib-node/middleware/retry')\nconst debug = require('get-it/lib-node/middleware/debug')\nconst headers = require('get-it/lib-node/middleware/headers')\n\nconst pkg = require('../../package.json')\n\nconst middleware = [\n debug({verbose: true, namespace: 'sanity:client'}),\n headers({'User-Agent': `${pkg.name} ${pkg.version}`}),\n retry({maxRetries: 3}),\n]\n\nmodule.exports = middleware\n", "/* eslint-disable no-empty-function, no-process-env */\nconst getIt = require('get-it')\nconst assign = require('object-assign')\nconst observable = require('get-it/lib/middleware/observable')\nconst jsonRequest = require('get-it/lib/middleware/jsonRequest')\nconst jsonResponse = require('get-it/lib/middleware/jsonResponse')\nconst progress = require('get-it/lib/middleware/progress')\nconst {Observable} = require('../util/observable')\nconst {ClientError, ServerError} = require('./errors')\n\nconst httpError = {\n onResponse: (res) => {\n if (res.statusCode >= 500) {\n throw new ServerError(res)\n } else if (res.statusCode >= 400) {\n throw new ClientError(res)\n }\n\n return res\n },\n}\n\nconst printWarnings = {\n onResponse: (res) => {\n const warn = res.headers['x-sanity-warning']\n const warnings = Array.isArray(warn) ? warn : [warn]\n warnings.filter(Boolean).forEach((msg) => console.warn(msg)) // eslint-disable-line no-console\n return res\n },\n}\n\n// Environment-specific middleware.\nconst envSpecific = require('./nodeMiddleware')\n\nconst middleware = envSpecific.concat([\n printWarnings,\n jsonRequest(),\n jsonResponse(),\n progress(),\n httpError,\n observable({implementation: Observable}),\n])\n\nconst request = getIt(middleware)\n\nfunction httpRequest(options, requester = request) {\n return requester(assign({maxRedirects: 0}, options))\n}\n\nhttpRequest.defaultRequester = request\nhttpRequest.ClientError = ClientError\nhttpRequest.ServerError = ServerError\n\nmodule.exports = httpRequest\n", "const assign = require('object-assign')\n\nconst projectHeader = 'X-Sanity-Project-ID'\n\nmodule.exports = (config, overrides = {}) => {\n const headers = {}\n\n const token = overrides.token || config.token\n if (token) {\n headers.Authorization = `Bearer ${token}`\n }\n\n if (!overrides.useGlobalApi && !config.useProjectHostname && config.projectId) {\n headers[projectHeader] = config.projectId\n }\n\n const withCredentials = Boolean(\n typeof overrides.withCredentials === 'undefined'\n ? config.token || config.withCredentials\n : overrides.withCredentials\n )\n\n const timeout = typeof overrides.timeout === 'undefined' ? config.timeout : overrides.timeout\n return assign({}, overrides, {\n headers: assign({}, headers, overrides.headers || {}),\n timeout: typeof timeout === 'undefined' ? 5 * 60 * 1000 : timeout,\n proxy: overrides.proxy || config.proxy,\n json: true,\n withCredentials,\n })\n}\n", "module.exports = (fn) => {\n let didCall = false\n let returnValue\n return (...args) => {\n if (didCall) {\n return returnValue\n }\n returnValue = fn(...args)\n didCall = true\n return returnValue\n }\n}\n", "const generateHelpUrl = require('@sanity/generate-help-url').generateHelpUrl\nconst once = require('./util/once')\n\nconst createWarningPrinter = (message) =>\n // eslint-disable-next-line no-console\n once((...args) => console.warn(message.join(' '), ...args))\n\nexports.printCdnWarning = createWarningPrinter([\n 'You are not using the Sanity CDN. That means your data is always fresh, but the CDN is faster and',\n `cheaper. Think about it! For more info, see ${generateHelpUrl('js-client-cdn-configuration')}.`,\n 'To hide this warning, please set the `useCdn` option to either `true` or `false` when creating',\n 'the client.',\n])\n\nexports.printBrowserTokenWarning = createWarningPrinter([\n 'You have configured Sanity client to use a token in the browser. This may cause unintentional security issues.',\n `See ${generateHelpUrl(\n 'js-client-browser-token'\n )} for more information and how to hide this warning.`,\n])\n\nexports.printNoApiVersionSpecifiedWarning = createWarningPrinter([\n 'Using the Sanity client without specifying an API version is deprecated.',\n `See ${generateHelpUrl('js-client-api-version')}`,\n])\n", "const generateHelpUrl = require('@sanity/generate-help-url').generateHelpUrl\nconst assign = require('object-assign')\nconst validate = require('./validators')\nconst warnings = require('./warnings')\n\nconst defaultCdnHost = 'apicdn.sanity.io'\nconst defaultConfig = {\n apiHost: 'https://api.sanity.io',\n apiVersion: '1',\n useProjectHostname: true,\n isPromiseAPI: true,\n}\n\nconst LOCALHOSTS = ['localhost', '127.0.0.1', '0.0.0.0']\nconst isLocal = (host) => LOCALHOSTS.indexOf(host) !== -1\n\nexports.defaultConfig = defaultConfig\n\n// eslint-disable-next-line complexity\nexports.initConfig = (config, prevConfig) => {\n const specifiedConfig = assign({}, prevConfig, config)\n if (!specifiedConfig.apiVersion) {\n warnings.printNoApiVersionSpecifiedWarning()\n }\n\n const newConfig = assign({}, defaultConfig, specifiedConfig)\n const projectBased = newConfig.useProjectHostname\n\n if (typeof Promise === 'undefined') {\n const helpUrl = generateHelpUrl('js-client-promise-polyfill')\n throw new Error(`No native Promise-implementation found, polyfill needed - see ${helpUrl}`)\n }\n\n if (projectBased && !newConfig.projectId) {\n throw new Error('Configuration must contain `projectId`')\n }\n\n const isBrowser = typeof window !== 'undefined' && window.location && window.location.hostname\n const isLocalhost = isBrowser && isLocal(window.location.hostname)\n\n if (isBrowser && isLocalhost && newConfig.token && newConfig.ignoreBrowserTokenWarning !== true) {\n warnings.printBrowserTokenWarning()\n } else if (typeof newConfig.useCdn === 'undefined') {\n warnings.printCdnWarning()\n }\n\n if (projectBased) {\n validate.projectId(newConfig.projectId)\n }\n\n if (newConfig.dataset) {\n validate.dataset(newConfig.dataset)\n }\n\n if ('requestTagPrefix' in newConfig) {\n // Allow setting and unsetting request tag prefix\n newConfig.requestTagPrefix = newConfig.requestTagPrefix\n ? validate.requestTag(newConfig.requestTagPrefix).replace(/\\.+$/, '')\n : undefined\n }\n\n newConfig.apiVersion = `${newConfig.apiVersion}`.replace(/^v/, '')\n newConfig.isDefaultApi = newConfig.apiHost === defaultConfig.apiHost\n newConfig.useCdn = Boolean(newConfig.useCdn) && !newConfig.withCredentials\n\n exports.validateApiVersion(newConfig.apiVersion)\n\n const hostParts = newConfig.apiHost.split('://', 2)\n const protocol = hostParts[0]\n const host = hostParts[1]\n const cdnHost = newConfig.isDefaultApi ? defaultCdnHost : host\n\n if (newConfig.useProjectHostname) {\n newConfig.url = `${protocol}://${newConfig.projectId}.${host}/v${newConfig.apiVersion}`\n newConfig.cdnUrl = `${protocol}://${newConfig.projectId}.${cdnHost}/v${newConfig.apiVersion}`\n } else {\n newConfig.url = `${newConfig.apiHost}/v${newConfig.apiVersion}`\n newConfig.cdnUrl = newConfig.url\n }\n\n return newConfig\n}\n\nexports.validateApiVersion = function validateApiVersion(apiVersion) {\n if (apiVersion === '1' || apiVersion === 'X') {\n return\n }\n\n const apiDate = new Date(apiVersion)\n const apiVersionValid =\n /^\\d{4}-\\d{2}-\\d{2}$/.test(apiVersion) && apiDate instanceof Date && apiDate.getTime() > 0\n\n if (!apiVersionValid) {\n throw new Error('Invalid API version string, expected `1` or date in format `YYYY-MM-DD`')\n }\n}\n", "const assign = require('object-assign')\nconst {Observable, map, filter} = require('./util/observable')\nconst Patch = require('./data/patch')\nconst Transaction = require('./data/transaction')\nconst dataMethods = require('./data/dataMethods')\nconst DatasetsClient = require('./datasets/datasetsClient')\nconst ProjectsClient = require('./projects/projectsClient')\nconst AssetsClient = require('./assets/assetsClient')\nconst UsersClient = require('./users/usersClient')\nconst AuthClient = require('./auth/authClient')\nconst httpRequest = require('./http/request')\nconst getRequestOptions = require('./http/requestOptions')\nconst {defaultConfig, initConfig} = require('./config')\nconst validate = require('./validators')\n\nconst toPromise = (observable) => observable.toPromise()\n\nfunction SanityClient(config = defaultConfig) {\n if (!(this instanceof SanityClient)) {\n return new SanityClient(config)\n }\n\n this.config(config)\n\n this.assets = new AssetsClient(this)\n this.datasets = new DatasetsClient(this)\n this.projects = new ProjectsClient(this)\n this.users = new UsersClient(this)\n this.auth = new AuthClient(this)\n\n if (this.clientConfig.isPromiseAPI) {\n const observableConfig = assign({}, this.clientConfig, {isPromiseAPI: false})\n this.observable = new SanityClient(observableConfig)\n }\n}\n\nassign(SanityClient.prototype, dataMethods)\nassign(SanityClient.prototype, {\n clone() {\n return new SanityClient(this.config())\n },\n\n config(newConfig) {\n if (typeof newConfig === 'undefined') {\n return assign({}, this.clientConfig)\n }\n\n if (this.observable) {\n const observableConfig = assign({}, newConfig, {isPromiseAPI: false})\n this.observable.config(observableConfig)\n }\n\n this.clientConfig = initConfig(newConfig, this.clientConfig || {})\n return this\n },\n\n withConfig(newConfig) {\n return this.clone().config(newConfig)\n },\n\n getUrl(uri, useCdn = false) {\n const base = useCdn ? this.clientConfig.cdnUrl : this.clientConfig.url\n return `${base}/${uri.replace(/^\\//, '')}`\n },\n\n isPromiseAPI() {\n return this.clientConfig.isPromiseAPI\n },\n\n _requestObservable(options) {\n const uri = options.url || options.uri\n\n // If the `canUseCdn`-option is not set we detect it automatically based on the method + URL.\n // Only the /data endpoint is currently available through API-CDN.\n const canUseCdn =\n typeof options.canUseCdn === 'undefined'\n ? ['GET', 'HEAD'].indexOf(options.method || 'GET') >= 0 && uri.indexOf('/data/') === 0\n : options.canUseCdn\n\n const useCdn = this.clientConfig.useCdn && canUseCdn\n\n const tag =\n options.tag && this.clientConfig.requestTagPrefix\n ? [this.clientConfig.requestTagPrefix, options.tag].join('.')\n : options.tag || this.clientConfig.requestTagPrefix\n\n if (tag) {\n options.query = {tag: validate.requestTag(tag), ...options.query}\n }\n\n const reqOptions = getRequestOptions(\n this.clientConfig,\n assign({}, options, {\n url: this.getUrl(uri, useCdn),\n })\n )\n\n return new Observable((subscriber) =>\n httpRequest(reqOptions, this.clientConfig.requester).subscribe(subscriber)\n )\n },\n\n request(options) {\n const observable = this._requestObservable(options).pipe(\n filter((event) => event.type === 'response'),\n map((event) => event.body)\n )\n\n return this.isPromiseAPI() ? toPromise(observable) : observable\n },\n})\n\nSanityClient.Patch = Patch\nSanityClient.Transaction = Transaction\nSanityClient.ClientError = httpRequest.ClientError\nSanityClient.ServerError = httpRequest.ServerError\nSanityClient.requester = httpRequest.defaultRequester\n\nmodule.exports = SanityClient\n"],
5
+ "mappings": ";;;;;;;;;;;;;AAAA;AAAA;AAEA,QAAM,EAAC,eAAc,UAAQ;AAC7B,QAAM,EAAC,WAAU,UAAQ;AACzB,QAAM,EAAC,QAAO,UAAQ;AAEtB,WAAO,UAAU;AAAA,MACf;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA;AAAA;;;ACVA;AAAA;AAAA,WAAO,UAAU,sBAAsB,KAAK;AAC1C,UAAI,OAAO,QAAQ,YAAY,MAAM,QAAQ,GAAG,GAAG;AACjD,eAAO,EAAC,IAAI,IAAG;AAAA,MACjB;AAEA,UAAI,OAAO,IAAI,OAAO;AACpB,eAAO,YAAY,MAAM,EAAC,OAAO,IAAI,OAAO,QAAQ,IAAI,OAAM,IAAI,EAAC,OAAO,IAAI,MAAK;AAAA,MACrF;AAEA,YAAM,gBAAgB;AAAA,QACpB;AAAA,QACA;AAAA,QACA;AAAA,MACF,EAAE,KAAK,IAAI;AAEX,YAAM,IAAI,MAAM;AAAA;AAAA,EAA0C,eAAe;AAAA,IAC3E;AAAA;AAAA;;;AChBA;AAAA;AAAA,QAAM,oBAAoB,CAAC,SAAS,MAAM;AAC1C,QAAM,yBAAyB,CAAC,UAAU,SAAS,SAAS;AAE5D,YAAQ,UAAU,CAAC,SAAS;AAC1B,UAAI,CAAC,qDAAqD,KAAK,IAAI,GAAG;AACpE,cAAM,IAAI,MACR,qIACF;AAAA,MACF;AAAA,IACF;AAEA,YAAQ,YAAY,CAAC,OAAO;AAC1B,UAAI,CAAC,gBAAgB,KAAK,EAAE,GAAG;AAC7B,cAAM,IAAI,MAAM,uDAAuD;AAAA,MACzE;AAAA,IACF;AAEA,YAAQ,oBAAoB,CAAC,SAAS;AACpC,UAAI,kBAAkB,QAAQ,IAAI,MAAM,IAAI;AAC1C,cAAM,IAAI,MAAM,uBAAuB,wBAAwB,kBAAkB,KAAK,IAAI,GAAG;AAAA,MAC/F;AAAA,IACF;AAEA,YAAQ,iBAAiB,CAAC,IAAI,QAAQ;AACpC,UAAI,QAAQ,QAAQ,OAAO,QAAQ,YAAY,MAAM,QAAQ,GAAG,GAAG;AACjE,cAAM,IAAI,MAAM,GAAG,oCAAoC;AAAA,MACzD;AAAA,IACF;AAEA,YAAQ,oBAAoB,CAAC,IAAI,QAAQ;AACvC,UAAI,CAAC,IAAI,KAAK;AACZ,cAAM,IAAI,MAAM,GAAG,iEAAiE;AAAA,MACtF;AAEA,cAAQ,mBAAmB,IAAI,IAAI,GAAG;AAAA,IACxC;AAEA,YAAQ,qBAAqB,CAAC,IAAI,OAAO;AACvC,UAAI,OAAO,OAAO,YAAY,CAAC,kBAAkB,KAAK,EAAE,GAAG;AACzD,cAAM,IAAI,MAAM,GAAG,UAAU,gCAAgC;AAAA,MAC/D;AAAA,IACF;AAEA,YAAQ,iBAAiB,CAAC,IAAI,UAAU,UAAU;AAChD,YAAM,YAAY;AAClB,UAAI,uBAAuB,QAAQ,EAAE,MAAM,IAAI;AAC7C,cAAM,QAAQ,uBAAuB,IAAI,CAAC,QAAQ,IAAI,MAAM,EAAE,KAAK,IAAI;AACvE,cAAM,IAAI,MAAM,GAAG,qDAAqD,OAAO;AAAA,MACjF;AAEA,UAAI,OAAO,aAAa,UAAU;AAChC,cAAM,IAAI,MAAM,GAAG,8DAA8D;AAAA,MACnF;AAEA,UAAI,CAAC,MAAM,QAAQ,KAAK,GAAG;AACzB,cAAM,IAAI,MAAM,GAAG,4DAA4D;AAAA,MACjF;AAAA,IACF;AAEA,YAAQ,aAAa,CAAC,WAAW;AAC/B,UAAI,CAAC,OAAO,SAAS;AACnB,cAAM,IAAI,MAAM,+CAA+C;AAAA,MACjE;AAEA,aAAO,OAAO,WAAW;AAAA,IAC3B;AAEA,YAAQ,aAAa,CAAC,QAAQ;AAC5B,UAAI,OAAO,QAAQ,YAAY,CAAC,uBAAuB,KAAK,GAAG,GAAG;AAChE,cAAM,IAAI,MACR,wHACF;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA;AAAA;;;AC3EA;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,eAAe;AACrB,QAAM,WAAW;AACjB,QAAM,iBAAiB,SAAS;AAChC,QAAM,iBAAiB,SAAS;AAEhC,mBAAe,WAAW,aAAa,CAAC,GAAG,SAAS,MAAM;AACxD,WAAK,YAAY;AACjB,WAAK,aAAa,OAAO,CAAC,GAAG,UAAU;AACvC,WAAK,SAAS;AAAA,IAChB;AAEA,WAAO,MAAM,WAAW;AAAA,MACtB,QAAQ;AACN,eAAO,IAAI,MAAM,KAAK,WAAW,OAAO,CAAC,GAAG,KAAK,UAAU,GAAG,KAAK,MAAM;AAAA,MAC3E;AAAA,MAEA,IAAI,OAAO;AACT,eAAO,KAAK,QAAQ,OAAO,KAAK;AAAA,MAClC;AAAA,MAEA,eAAe,OAAO;AACpB,uBAAe,kBAAkB,KAAK;AACtC,eAAO,KAAK,QAAQ,kBAAkB,KAAK;AAAA,MAC7C;AAAA,MAEA,MAAM,OAAO;AACX,YAAI,CAAC,MAAM,QAAQ,KAAK,GAAG;AACzB,gBAAM,IAAI,MAAM,qEAAqE;AAAA,QACvF;AAEA,aAAK,aAAa,OAAO,CAAC,GAAG,KAAK,YAAY,EAAC,OAAO,MAAK,CAAC;AAC5D,eAAO;AAAA,MACT;AAAA,MAEA,aAAa,OAAO;AAClB,eAAO,KAAK,QAAQ,gBAAgB,KAAK;AAAA,MAC3C;AAAA,MAEA,QAAQ,OAAO;AACb,uBAAe,WAAW,KAAK;AAC/B,eAAO,KAAK,KAAK,OAAO,EAAC,GAAG,MAAK,CAAC;AAAA,MACpC;AAAA,MAEA,IAAI,OAAO;AACT,eAAO,KAAK,QAAQ,OAAO,KAAK;AAAA,MAClC;AAAA,MAEA,IAAI,OAAO;AACT,eAAO,KAAK,QAAQ,OAAO,KAAK;AAAA,MAClC;AAAA,MAEA,OAAO,IAAI,UAAU,OAAO;AAC1B,uBAAe,IAAI,UAAU,KAAK;AAClC,eAAO,KAAK,QAAQ,UAAU,EAAC,CAAC,KAAK,UAAU,MAAK,CAAC;AAAA,MACvD;AAAA,MAEA,OAAO,UAAU,OAAO;AACtB,eAAO,KAAK,OAAO,SAAS,GAAG,gBAAgB,KAAK;AAAA,MACtD;AAAA,MAEA,QAAQ,UAAU,OAAO;AACvB,eAAO,KAAK,OAAO,UAAU,GAAG,eAAe,KAAK;AAAA,MACtD;AAAA,MAEA,OAAO,UAAU,OAAO,aAAa,OAAO;AAM1C,cAAM,SAAS,OAAO,gBAAgB,eAAe,gBAAgB;AACrE,cAAM,aAAa,QAAQ,IAAI,QAAQ,IAAI;AAC3C,cAAM,WAAW,SAAS,KAAK,KAAK,IAAI,GAAG,QAAQ,WAAW;AAC9D,cAAM,WAAW,aAAa,KAAK,YAAY,IAAI,KAAK;AACxD,cAAM,gBAAgB,GAAG,YAAY,cAAc;AACnD,eAAO,KAAK,OAAO,WAAW,eAAe,SAAS,CAAC,CAAC;AAAA,MAC1D;AAAA,MAEA,aAAa,KAAK;AAChB,aAAK,WAAW,eAAe;AAC/B,eAAO;AAAA,MACT;AAAA,MAEA,YAAY;AACV,eAAO,OAAO,aAAa,KAAK,SAAS,GAAG,KAAK,UAAU;AAAA,MAC7D;AAAA,MAEA,SAAS;AACP,eAAO,KAAK,UAAU;AAAA,MACxB;AAAA,MAEA,OAAO,UAAU,CAAC,GAAG;AACnB,YAAI,CAAC,KAAK,QAAQ;AAChB,gBAAM,IAAI,MACR,kGAEF;AAAA,QACF;AAEA,cAAM,cAAc,OAAO,KAAK,cAAc;AAC9C,cAAM,OAAO,OAAO,EAAC,aAAa,iBAAiB,KAAI,GAAG,OAAO;AACjE,eAAO,KAAK,OAAO,OAAO,EAAC,OAAO,KAAK,UAAU,EAAC,GAAG,IAAI;AAAA,MAC3D;AAAA,MAEA,QAAQ;AACN,aAAK,aAAa,CAAC;AACnB,eAAO;AAAA,MACT;AAAA,MAEA,KAAK,IAAI,OAAO;AACd,eAAO,KAAK,QAAQ,IAAI,OAAO,KAAK;AAAA,MACtC;AAAA,MAEA,QAAQ,IAAI,OAAO,QAAQ,MAAM;AAC/B,uBAAe,IAAI,KAAK;AACxB,aAAK,aAAa,OAAO,CAAC,GAAG,KAAK,YAAY;AAAA,UAC5C,CAAC,KAAK,OAAO,CAAC,GAAI,SAAS,KAAK,WAAW,OAAQ,CAAC,GAAG,KAAK;AAAA,QAC9D,CAAC;AACD,eAAO;AAAA,MACT;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;AC3HjB;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,aAAa;AACnB,QAAM,QAAQ;AAEd,QAAM,uBAAuB,EAAC,iBAAiB,MAAK;AAEpD,yBAAqB,aAAa,CAAC,GAAG,QAAQ,eAAe;AAC3D,WAAK,QAAQ;AACb,WAAK,aAAa;AAClB,WAAK,SAAS;AAAA,IAChB;AAEA,WAAO,YAAY,WAAW;AAAA,MAC5B,QAAQ;AACN,eAAO,IAAI,YAAY,KAAK,WAAW,MAAM,CAAC,GAAG,KAAK,QAAQ,KAAK,KAAK;AAAA,MAC1E;AAAA,MAEA,OAAO,KAAK;AACV,mBAAW,eAAe,UAAU,GAAG;AACvC,eAAO,KAAK,KAAK,EAAC,QAAQ,IAAG,CAAC;AAAA,MAChC;AAAA,MAEA,kBAAkB,KAAK;AACrB,cAAM,KAAK;AACX,mBAAW,eAAe,IAAI,GAAG;AACjC,mBAAW,kBAAkB,IAAI,GAAG;AACpC,eAAO,KAAK,KAAK,EAAC,CAAC,KAAK,IAAG,CAAC;AAAA,MAC9B;AAAA,MAEA,gBAAgB,KAAK;AACnB,cAAM,KAAK;AACX,mBAAW,eAAe,IAAI,GAAG;AACjC,mBAAW,kBAAkB,IAAI,GAAG;AACpC,eAAO,KAAK,KAAK,EAAC,CAAC,KAAK,IAAG,CAAC;AAAA,MAC9B;AAAA,MAEA,OAAO,YAAY;AACjB,mBAAW,mBAAmB,UAAU,UAAU;AAClD,eAAO,KAAK,KAAK,EAAC,QAAQ,EAAC,IAAI,WAAU,EAAC,CAAC;AAAA,MAC7C;AAAA,MAEA,MAAM,YAAY,UAAU;AAC1B,cAAM,YAAY,OAAO,aAAa;AACtC,cAAM,UAAU,sBAAsB;AAGtC,YAAI,SAAS;AACX,iBAAO,KAAK,KAAK,EAAC,OAAO,WAAW,UAAU,EAAC,CAAC;AAAA,QAClD;AAGA,YAAI,WAAW;AACb,gBAAM,QAAQ,SAAS,IAAI,MAAM,YAAY,CAAC,GAAG,KAAK,MAAM,CAAC;AAC7D,cAAI,CAAE,kBAAiB,QAAQ;AAC7B,kBAAM,IAAI,MAAM,oDAAoD;AAAA,UACtE;AAEA,iBAAO,KAAK,KAAK,EAAC,OAAO,MAAM,UAAU,EAAC,CAAC;AAAA,QAC7C;AAEA,eAAO,KAAK,KAAK,EAAC,OAAO,OAAO,EAAC,IAAI,WAAU,GAAG,QAAQ,EAAC,CAAC;AAAA,MAC9D;AAAA,MAEA,cAAc,IAAI;AAChB,YAAI,CAAC,IAAI;AACP,iBAAO,KAAK;AAAA,QACd;AAEA,aAAK,QAAQ;AACb,eAAO;AAAA,MACT;AAAA,MAEA,YAAY;AACV,eAAO,KAAK,WAAW,MAAM;AAAA,MAC/B;AAAA,MAEA,SAAS;AACP,eAAO,KAAK,UAAU;AAAA,MACxB;AAAA,MAEA,OAAO,SAAS;AACd,YAAI,CAAC,KAAK,QAAQ;AAChB,gBAAM,IAAI,MACR,8GAEF;AAAA,QACF;AAEA,eAAO,KAAK,OAAO,OACjB,KAAK,UAAU,GACf,OAAO,EAAC,eAAe,KAAK,MAAK,GAAG,sBAAsB,WAAW,CAAC,CAAC,CACzE;AAAA,MACF;AAAA,MAEA,QAAQ;AACN,aAAK,aAAa,CAAC;AACnB,eAAO;AAAA,MACT;AAAA,MAEA,KAAK,KAAK;AACR,aAAK,WAAW,KAAK,GAAG;AACxB,eAAO;AAAA,MACT;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;ACzGjB;AAAA;AAAA,QAAM,MAAM;AAEZ,WAAO,UAAU,CAAC,EAAC,OAAO,SAAS,CAAC,GAAG,UAAU,CAAC,QAAO;AAEvD,YAAM,EAAC,QAAQ,SAAQ;AACvB,YAAM,IAAI,SAAS,IAAI,KAAK;AAC5B,YAAM,OAAO,MAAM,QAAQ,IAAI,GAAG,KAAK,MAAM,IAAI;AAEjD,YAAM,UAAU,OAAO,KAAK,MAAM,EAAE,OAClC,CAAC,IAAI,UAAU,GAAG,MAAM,IAAI,IAAI,OAAO,KAAK,IAAI,KAAK,UAAU,OAAO,MAAM,CAAC,KAC7E,IACF;AAEA,aAAO,OAAO,KAAK,IAAI,EAAE,OAAO,CAAC,IAAI,WAAW;AAE9C,eAAO,QAAQ,UAAU,GAAG,MAAM,IAAI,MAAM,KAAK,IAAI,QAAQ,OAAO,MAAM;AAAA,MAC5E,GAAG,OAAO;AAAA,IACZ;AAAA;AAAA;;;ACjBA;AAAA;AAAA,WAAO,UAAU,CAAC,KAAK,UACrB,MAAM,OAAO,CAAC,WAAW,SAAS;AAChC,UAAI,OAAO,IAAI,UAAU,aAAa;AACpC,eAAO;AAAA,MACT;AAEA,gBAAU,QAAQ,IAAI;AACtB,aAAO;AAAA,IACT,GAAG,CAAC,CAAC;AAAA;AAAA;;;ACRP;AAAA;AAAA,WAAO,UAAU,CAAC,KAAK,aACrB,OAAO,KAAK,QAAQ,EACjB,OAAO,OAAO,KAAK,GAAG,CAAC,EACvB,OAAO,CAAC,QAAQ,SAAS;AACxB,aAAO,QAAQ,OAAO,IAAI,UAAU,cAAc,SAAS,QAAQ,IAAI;AAEvE,aAAO;AAAA,IACT,GAAG,CAAC,CAAC;AAAA;AAAA;;;ACPT;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,EAAC,eAAc;AACrB,QAAM,wBAAwB,UAAQ;AACtC,QAAM,OAAO;AACb,QAAM,WAAW;AACjB,QAAM,oBAAoB;AAK1B,QAAM,iBAAiB,OAAQ;AAC/B,QAAM,cAAc;AAEpB,QAAM,kBAAkB;AAAA,MACtB;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAEA,QAAM,iBAAiB;AAAA,MACrB,eAAe;AAAA,IACjB;AAEA,WAAO,UAAU,gBAAgB,OAAO,QAAQ,OAAO,CAAC,GAAG;AACzD,YAAM,EAAC,KAAK,OAAO,iBAAiB,qBAAoB,KAAK;AAC7D,YAAM,MAAM,KAAK,OAAO,mBAAmB,CAAC,kBAAkB,KAAK,GAAG,EAAE,KAAK,GAAG,IAAI,KAAK;AACzF,YAAM,UAAU,EAAC,GAAG,SAAS,MAAM,cAAc,GAAG,IAAG;AACvD,YAAM,aAAa,KAAK,SAAS,eAAe;AAChD,YAAM,KAAK,kBAAkB,EAAC,OAAO,QAAQ,SAAS,YAAY,IAAG,CAAC;AAEtE,YAAM,MAAM,GAAG,MAAM,KAAK,WAAW,UAAU,EAAE;AACjD,UAAI,IAAI,SAAS,gBAAgB;AAC/B,eAAO,IAAI,WAAW,CAAC,aAAa,SAAS,MAAM,IAAI,MAAM,8BAA8B,CAAC,CAAC;AAAA,MAC/F;AAEA,YAAM,YAAY,QAAQ,SAAS,QAAQ,SAAS,CAAC,UAAU;AAC/D,YAAM,sBAAsB,UAAU,QAAQ,WAAW,MAAM;AAE/D,YAAM,YAAY,CAAC;AACnB,UAAI,SAAS,iBAAiB;AAC5B,kBAAU,kBAAkB;AAAA,MAC9B;AAEA,UAAI,OAAO;AACT,kBAAU,UAAU;AAAA,UAClB,eAAe,UAAU;AAAA,QAC3B;AAAA,MACF;AAEA,aAAO,IAAI,WAAW,CAAC,aAAa;AAClC,YAAI,KAAK,eAAe;AACxB,YAAI;AACJ,YAAI,UAAU;AAEd,2BAAmB;AACjB,cAAI,SAAS;AACX;AAAA,UACF;AAEA,wBAAc;AAGd,cAAI,SAAS;AACX;AAAA,UACF;AAOA,cAAI,GAAG,eAAe,YAAY,QAAQ;AACxC,wBAAY;AACZ,yBAAa,cAAc;AAC3B,6BAAiB,WAAW,MAAM,GAAG;AAAA,UACvC;AAAA,QACF;AAEA,gCAAwB,KAAK;AAC3B,mBAAS,MAAM,aAAa,GAAG,CAAC;AAAA,QAClC;AAEA,2BAAmB,KAAK;AACtB,gBAAM,QAAQ,WAAW,GAAG;AAC5B,iBAAO,iBAAiB,QAAQ,SAAS,MAAM,KAAK,IAAI,SAAS,KAAK,KAAK;AAAA,QAC7E;AAEA,8BAAsB,KAAK;AACzB,oBAAU;AACV,sBAAY;AACZ,mBAAS,SAAS;AAAA,QACpB;AAEA,+BAAuB;AACrB,aAAG,oBAAoB,SAAS,SAAS,KAAK;AAC9C,aAAG,oBAAoB,gBAAgB,gBAAgB,KAAK;AAC5D,aAAG,oBAAoB,cAAc,cAAc,KAAK;AACxD,oBAAU,QAAQ,CAAC,SAAS,GAAG,oBAAoB,MAAM,WAAW,KAAK,CAAC;AAC1E,aAAG,MAAM;AAAA,QACX;AAEA,iCAAyB;AACvB,cAAI,qBAAqB;AACvB,qBAAS,KAAK,EAAC,MAAM,YAAW,CAAC;AAAA,UACnC;AAAA,QACF;AAEA,kCAA0B;AACxB,gBAAM,MAAM,IAAI,YAAY,KAAK,SAAS;AAC1C,cAAI,iBAAiB,SAAS,SAAS,KAAK;AAC5C,cAAI,iBAAiB,gBAAgB,gBAAgB,KAAK;AAC1D,cAAI,iBAAiB,cAAc,cAAc,KAAK;AACtD,oBAAU,QAAQ,CAAC,SAAS,IAAI,iBAAiB,MAAM,WAAW,KAAK,CAAC;AACxE,iBAAO;AAAA,QACT;AAEA,wBAAgB;AACd,eAAK,eAAe;AAAA,QACtB;AAEA,wBAAgB;AACd,oBAAU;AACV,sBAAY;AAAA,QACd;AAEA,eAAO;AAAA,MACT,CAAC;AAAA,IACH;AAEA,wBAAoB,OAAO;AACzB,UAAI;AACF,cAAM,OAAQ,MAAM,QAAQ,KAAK,MAAM,MAAM,IAAI,KAAM,CAAC;AACxD,eAAO,OAAO,EAAC,MAAM,MAAM,KAAI,GAAG,IAAI;AAAA,MACxC,SAAS,KAAP;AACA,eAAO;AAAA,MACT;AAAA,IACF;AAEA,0BAAsB,KAAK;AACzB,UAAI,eAAe,OAAO;AACxB,eAAO;AAAA,MACT;AAEA,YAAM,MAAM,WAAW,GAAG;AAC1B,aAAO,eAAe,QAAQ,MAAM,IAAI,MAAM,oBAAoB,GAAG,CAAC;AAAA,IACxE;AAEA,iCAA6B,KAAK;AAChC,UAAI,CAAC,IAAI,OAAO;AACd,eAAO,IAAI,WAAW;AAAA,MACxB;AAEA,UAAI,IAAI,MAAM,aAAa;AACzB,eAAO,IAAI,MAAM;AAAA,MACnB;AAEA,aAAO,OAAO,IAAI,UAAU,WAAW,IAAI,QAAQ,KAAK,UAAU,IAAI,OAAO,MAAM,CAAC;AAAA,IACtF;AAAA;AAAA;;;AC/JA;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,EAAC,KAAK,WAAU;AACtB,QAAM,aAAa;AACnB,QAAM,eAAe;AACrB,QAAM,oBAAoB;AAC1B,QAAM,cAAc;AACpB,QAAM,QAAQ;AACd,QAAM,SAAS;AAEf,QAAM,gBAAgB,CAAC,OAAO,aAAa;AACzC,YAAM,QAAQ,OAAO,UAAU,cAAc,WAAW;AACxD,aAAO,UAAU,QAAQ,SAAY;AAAA,IACvC;AAEA,QAAM,mBAAmB,CAAC,UAAU,CAAC,MAAM;AACzC,aAAO;AAAA,QACL,QAAQ,QAAQ;AAAA,QAChB,WAAW;AAAA,QACX,iBAAiB,cAAc,QAAQ,iBAAiB,IAAI;AAAA,QAC5D,YAAY,QAAQ,cAAc;AAAA,QAClC,uBAAuB,QAAQ;AAAA,QAC/B,qCAAqC,QAAQ;AAAA,MAC/C;AAAA,IACF;AAEA,QAAM,aAAa,CAAC,UAAU,MAAM,SAAS;AAC7C,QAAM,UAAU,CAAC,UAAU,MAAM;AAEjC,QAAM,UAAU,CAAC,MAAM,SACrB,KAAK,OAAO,CAAC,SAAS,QAAQ;AAC5B,cAAQ,KAAK,GAAG,KAAK;AACrB,aAAO;AAAA,IACT,GAAG,uBAAO,OAAO,IAAI,CAAC;AAExB,QAAM,YAAY,CAAC,eAAe,WAAW,UAAU;AAEvD,QAAM,oBAAoB;AAE1B,WAAO,UAAU;AAAA,MACf;AAAA,MAEA,WAAW,WAAW,MAAM;AAC1B,cAAM,SAAS,KAAK;AACpB,cAAM,UAAU,WAAW,WAAW,MAAM;AAC5C,cAAM,UAAU,IAAI,aAAa;AACjC,cAAM,MAAM,OAAO,GAAG,WAAW,SAAS;AAC1C,eAAO,QAAQ,MAAM,QAAQ,YAAY,IAAI;AAAA,MAC/C;AAAA,MAEA,MAAM,OAAO,QAAQ,UAAU,CAAC,GAAG;AACjC,cAAM,cAAc,QAAQ,mBAAmB,QAAQ,CAAC,QAAQ,MAAM,CAAC,QAAQ,IAAI;AAEnF,cAAM,aAAa,KAAK,aAAa,SAAS,EAAC,OAAO,OAAM,GAAG,OAAO,EAAE,KAAK,IAAI,WAAW,CAAC;AAC7F,eAAO,KAAK,aAAa,IAAI,UAAU,UAAU,IAAI;AAAA,MACvD;AAAA,MAEA,YAAY,IAAI,OAAO,CAAC,GAAG;AACzB,cAAM,UAAU,EAAC,KAAK,KAAK,WAAW,OAAO,EAAE,GAAG,MAAM,MAAM,KAAK,KAAK,IAAG;AAC3E,cAAM,aAAa,KAAK,mBAAmB,OAAO,EAAE,KAClD,OAAO,UAAU,GACjB,IAAI,CAAC,UAAU,MAAM,KAAK,aAAa,MAAM,KAAK,UAAU,EAAE,CAChE;AAEA,eAAO,KAAK,aAAa,IAAI,UAAU,UAAU,IAAI;AAAA,MACvD;AAAA,MAEA,aAAa,KAAK,OAAO,CAAC,GAAG;AAC3B,cAAM,UAAU,EAAC,KAAK,KAAK,WAAW,OAAO,IAAI,KAAK,GAAG,CAAC,GAAG,MAAM,MAAM,KAAK,KAAK,IAAG;AACtF,cAAM,aAAa,KAAK,mBAAmB,OAAO,EAAE,KAClD,OAAO,UAAU,GACjB,IAAI,CAAC,UAAU;AACb,gBAAM,UAAU,QAAQ,MAAM,KAAK,aAAa,CAAC,GAAG,CAAC,QAAQ,IAAI,GAAG;AACpE,iBAAO,IAAI,IAAI,CAAC,OAAO,QAAQ,OAAO,IAAI;AAAA,QAC5C,CAAC,CACH;AAEA,eAAO,KAAK,aAAa,IAAI,UAAU,UAAU,IAAI;AAAA,MACvD;AAAA,MAEA,OAAO,KAAK,SAAS;AACnB,eAAO,KAAK,QAAQ,KAAK,UAAU,OAAO;AAAA,MAC5C;AAAA,MAEA,kBAAkB,KAAK,SAAS;AAC9B,mBAAW,kBAAkB,qBAAqB,GAAG;AACrD,eAAO,KAAK,QAAQ,KAAK,qBAAqB,OAAO;AAAA,MACvD;AAAA,MAEA,gBAAgB,KAAK,SAAS;AAC5B,mBAAW,kBAAkB,mBAAmB,GAAG;AACnD,eAAO,KAAK,QAAQ,KAAK,mBAAmB,OAAO;AAAA,MACrD;AAAA,MAEA,MAAM,UAAU,YAAY;AAC1B,eAAO,IAAI,MAAM,UAAU,YAAY,IAAI;AAAA,MAC7C;AAAA,MAEA,OAAO,WAAW,SAAS;AACzB,eAAO,KAAK,YAAY,UAAU,EAAC,WAAW,CAAC,EAAC,QAAQ,aAAa,SAAS,EAAC,CAAC,EAAC,GAAG,OAAO;AAAA,MAC7F;AAAA,MAEA,OAAO,WAAW,SAAS;AACzB,cAAM,MACJ,qBAAqB,SAAS,qBAAqB,cAC/C,UAAU,UAAU,IACpB;AAEN,cAAM,OAAO,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,GAAG;AAC5C,cAAM,gBAAgB,WAAW,QAAQ;AACzC,eAAO,KAAK,YAAY,UAAU,EAAC,WAAW,MAAM,cAAa,GAAG,OAAO;AAAA,MAC7E;AAAA,MAEA,YAAY,YAAY;AACtB,eAAO,IAAI,YAAY,YAAY,IAAI;AAAA,MACzC;AAAA,MAEA,YAAY,UAAU,MAAM,UAAU,CAAC,GAAG;AACxC,cAAM,UAAU,KAAK,aAAa,UAAU,MAAM,OAAO;AAEzD,eAAO,KAAK,aAAa,IAAI,UAAU,OAAO,IAAI;AAAA,MACpD;AAAA,MAEA,aAAa,UAAU,MAAM,UAAU,CAAC,GAAG;AACzC,cAAM,aAAa,aAAa;AAChC,cAAM,UAAU,aAAa;AAI7B,cAAM,WAAW,CAAC,cAAc,kBAAkB,IAAI;AACtD,cAAM,SAAS,CAAC,cAAc,SAAS,SAAS;AAChD,cAAM,cAAc,SAAS,WAAW;AACxC,cAAM,cAAc,QAAQ;AAC5B,cAAM,EAAC,SAAS,OAAO,KAAK,YAAW;AAEvC,cAAM,MAAM,KAAK,WAAW,UAAU,WAAW;AAEjD,cAAM,aAAa;AAAA,UACjB,QAAQ,SAAS,QAAQ;AAAA,UACzB;AAAA,UACA,MAAM;AAAA,UACN,MAAM,SAAS,SAAY;AAAA,UAC3B,OAAO,cAAc,iBAAiB,OAAO;AAAA,UAC7C;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,WAAW;AAAA,QACb;AAEA,eAAO,KAAK,mBAAmB,UAAU,EAAE,KACzC,OAAO,UAAU,GACjB,IAAI,OAAO,GACX,IAAI,CAAC,QAAQ;AACX,cAAI,CAAC,YAAY;AACf,mBAAO;AAAA,UACT;AAGA,gBAAM,UAAU,IAAI,WAAW,CAAC;AAChC,cAAI,QAAQ,iBAAiB;AAC3B,mBAAO,cACH,QAAQ,MAAM,QAAQ,GAAG,WACzB,QAAQ,IAAI,CAAC,QAAQ,IAAI,QAAQ;AAAA,UACvC;AAGA,gBAAM,MAAM,cAAc,eAAe;AACzC,gBAAM,MAAM,cAAc,QAAQ,MAAM,QAAQ,GAAG,KAAK,QAAQ,IAAI,CAAC,QAAQ,IAAI,EAAE;AACnF,iBAAO;AAAA,YACL,eAAe,IAAI;AAAA,YACnB;AAAA,YACA,CAAC,MAAM;AAAA,UACT;AAAA,QACF,CAAC,CACH;AAAA,MACF;AAAA,MAEA,QAAQ,KAAK,IAAI,UAAU,CAAC,GAAG;AAC7B,cAAM,WAAW,EAAC,CAAC,KAAK,IAAG;AAC3B,cAAM,OAAO,OAAO,EAAC,aAAa,MAAM,iBAAiB,KAAI,GAAG,OAAO;AACvE,eAAO,KAAK,YAAY,UAAU,EAAC,WAAW,CAAC,QAAQ,EAAC,GAAG,IAAI;AAAA,MACjE;AAAA,IACF;AAAA;AAAA;;;ACtLA;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,WAAW;AAEjB,4BAAwB,QAAQ;AAC9B,WAAK,UAAU,OAAO,QAAQ,KAAK,MAAM;AAAA,IAC3C;AAEA,WAAO,eAAe,WAAW;AAAA,MAC/B,OAAO,MAAM,SAAS;AACpB,eAAO,KAAK,QAAQ,OAAO,MAAM,OAAO;AAAA,MAC1C;AAAA,MAEA,KAAK,MAAM,SAAS;AAClB,eAAO,KAAK,QAAQ,SAAS,MAAM,OAAO;AAAA,MAC5C;AAAA,MAEA,OAAO,MAAM;AACX,eAAO,KAAK,QAAQ,UAAU,IAAI;AAAA,MACpC;AAAA,MAEA,OAAO;AACL,eAAO,KAAK,QAAQ,EAAC,KAAK,YAAW,CAAC;AAAA,MACxC;AAAA,MAEA,QAAQ,QAAQ,MAAM,MAAM;AAC1B,iBAAS,QAAQ,IAAI;AACrB,eAAO,KAAK,QAAQ,EAAC,QAAQ,KAAK,aAAa,QAAQ,KAAI,CAAC;AAAA,MAC9D;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;AC9BjB;AAAA;AAAA,QAAM,SAAS,UAAQ;AAEvB,4BAAwB,QAAQ;AAC9B,WAAK,SAAS;AAAA,IAChB;AAEA,WAAO,eAAe,WAAW;AAAA,MAC/B,OAAO;AACL,eAAO,KAAK,OAAO,QAAQ,EAAC,KAAK,YAAW,CAAC;AAAA,MAC/C;AAAA,MAEA,QAAQ,IAAI;AACV,eAAO,KAAK,OAAO,QAAQ,EAAC,KAAK,aAAa,KAAI,CAAC;AAAA,MACrD;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;AChBjB;AAAA;AAAA,WAAO,UAAU,CAAC,WAAW;AAC3B,YAAM,KAAK,CAAC;AACZ,iBAAW,OAAO,QAAQ;AACxB,YAAI,OAAO,eAAe,GAAG,GAAG;AAC9B,aAAG,KAAK,GAAG,mBAAmB,GAAG,KAAK,mBAAmB,OAAO,IAAI,GAAG;AAAA,QACzE;AAAA,MACF;AAEA,aAAO,GAAG,SAAS,IAAI,IAAI,GAAG,KAAK,GAAG,MAAM;AAAA,IAC9C;AAAA;AAAA;;;ACTA;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,EAAC,KAAK,WAAU;AACtB,QAAM,cAAc;AACpB,QAAM,aAAa;AAEnB,0BAAsB,QAAQ;AAC5B,WAAK,SAAS;AAAA,IAChB;AAEA,6BAAyB,MAAM,MAAM;AACnC,UAAI,OAAO,WAAW,eAAe,CAAE,iBAAgB,OAAO,OAAO;AACnE,eAAO;AAAA,MACT;AAEA,aAAO,OACL;AAAA,QACE,UAAU,KAAK,qBAAqB,QAAQ,SAAY,KAAK;AAAA,QAC7D,aAAa,KAAK;AAAA,MACpB,GACA,IACF;AAAA,IACF;AAEA,WAAO,aAAa,WAAW;AAAA,MA0B7B,OAAO,WAAW,MAAM,OAAO,CAAC,GAAG;AACjC,mBAAW,kBAAkB,SAAS;AAGtC,YAAI,OAAO,KAAK,WAAW;AAC3B,YAAI,QAAQ,CAAC,KAAK,QAAQ;AACxB,iBAAO,CAAC,MAAM;AAAA,QAChB;AAEA,cAAM,UAAU,WAAW,WAAW,KAAK,OAAO,YAAY;AAC9D,cAAM,gBAAgB,cAAc,UAAU,WAAW;AACzD,cAAM,UAAU,gBAAgB,MAAM,IAAI;AAC1C,cAAM,EAAC,KAAK,OAAO,OAAO,aAAa,YAAY,UAAU,WAAU;AACvE,cAAM,QAAQ;AAAA,UACZ;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AACA,YAAI,QAAQ;AACV,gBAAM,WAAW,OAAO;AACxB,gBAAM,aAAa,OAAO;AAC1B,gBAAM,YAAY,OAAO;AAAA,QAC3B;AACA,cAAM,aAAa,KAAK,OAAO,mBAAmB;AAAA,UAChD;AAAA,UACA,QAAQ;AAAA,UACR,SAAS,QAAQ,WAAW;AAAA,UAC5B,KAAK,WAAW,iBAAiB;AAAA,UACjC,SAAS,QAAQ,cAAc,EAAC,gBAAgB,QAAQ,YAAW,IAAI,CAAC;AAAA,UACxE;AAAA,UACA;AAAA,QACF,CAAC;AAED,eAAO,KAAK,OAAO,aAAa,IAC5B,WACG,KACC,OAAO,CAAC,UAAU,MAAM,SAAS,UAAU,GAC3C,IAAI,CAAC,UAAU,MAAM,KAAK,QAAQ,CACpC,EACC,UAAU,IACb;AAAA,MACN;AAAA,MAEA,OAAO,MAAM,IAAI;AAEf,gBAAQ,KAAK,+EAA+E;AAE5F,YAAI,QAAQ,MAAM;AAClB,YAAI,CAAC,iBAAiB,KAAK,KAAK,GAAG;AACjC,kBAAQ,GAAG,QAAQ;AAAA,QACrB,WAAW,KAAK,KAAK;AAEnB,kBAAQ,KAAK;AAAA,QACf;AAEA,mBAAW,WAAW,KAAK,OAAO,YAAY;AAC9C,eAAO,KAAK,OAAO,OAAO,KAAK;AAAA,MACjC;AAAA,MAEA,YAAY,KAAK,OAAO;AACtB,cAAM,KAAK,IAAI,QAAQ;AACvB,YAAI,OAAO,OAAO,UAAU;AAC1B,gBAAM,IAAI,MACR,yFACF;AAAA,QACF;AAEA,YAAI,CAAC,2CAA2C,KAAK,EAAE,GAAG;AACxD,gBAAM,IAAI,MACR,yBAAyB,wDAC3B;AAAA,QACF;AAEA,cAAM,CAAC,EAAE,SAAS,MAAM,UAAU,GAAG,MAAM,GAAG;AAE9C,mBAAW,WAAW,KAAK,OAAO,YAAY;AAC9C,cAAM,EAAC,WAAW,YAAW,KAAK,OAAO;AACzC,cAAM,KAAK,QAAQ,YAAY,KAAK,IAAI;AACxC,eAAO,gCAAgC,aAAa,WAAW,WAAW,QAAQ,SAAS;AAAA,MAC7F;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;ACtIjB;AAAA;AAAA,QAAM,SAAS,UAAQ;AAEvB,yBAAqB,QAAQ;AAC3B,WAAK,SAAS;AAAA,IAChB;AAEA,WAAO,YAAY,WAAW;AAAA,MAC5B,QAAQ,IAAI;AACV,eAAO,KAAK,OAAO,QAAQ,EAAC,KAAK,UAAU,KAAI,CAAC;AAAA,MAClD;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;ACZjB;AAAA;AAAA,QAAM,SAAS,UAAQ;AAEvB,wBAAoB,QAAQ;AAC1B,WAAK,SAAS;AAAA,IAChB;AAEA,WAAO,WAAW,WAAW;AAAA,MAC3B,oBAAoB;AAClB,eAAO,KAAK,OAAO,QAAQ,EAAC,KAAK,kBAAiB,CAAC;AAAA,MACrD;AAAA,MAEA,SAAS;AACP,eAAO,KAAK,OAAO,QAAQ,EAAC,KAAK,gBAAgB,QAAQ,OAAM,CAAC;AAAA,MAClE;AAAA,IACF,CAAC;AAED,WAAO,UAAU;AAAA;AAAA;;;AChBjB;AAAA;AAAA,QAAM,YAAY,UAAQ;AAC1B,QAAM,SAAS,UAAQ;AAEvB,yBAAqB,KAAK;AACxB,YAAM,QAAQ,kBAAkB,GAAG;AACnC,kBAAY,MAAM,KAAK,MAAM,MAAM,OAAO;AAC1C,aAAO,MAAM,KAAK;AAAA,IACpB;AAEA,yBAAqB,KAAK;AACxB,YAAM,QAAQ,kBAAkB,GAAG;AACnC,kBAAY,MAAM,KAAK,MAAM,MAAM,OAAO;AAC1C,aAAO,MAAM,KAAK;AAAA,IACpB;AAEA,+BAA2B,KAAK;AAC9B,YAAM,OAAO,IAAI;AACjB,YAAM,QAAQ;AAAA,QACZ,UAAU;AAAA,QACV,YAAY,IAAI;AAAA,QAChB,cAAc,cAAc,MAAM,GAAG;AAAA,MACvC;AAGA,UAAI,KAAK,SAAS,KAAK,SAAS;AAC9B,cAAM,UAAU,GAAG,KAAK,WAAW,KAAK;AACxC,eAAO;AAAA,MACT;AAGA,UAAI,KAAK,SAAS,KAAK,MAAM,aAAa;AACxC,cAAM,UAAU,KAAK,MAAM;AAC3B,cAAM,UAAU,KAAK;AACrB,eAAO;AAAA,MACT;AAGA,YAAM,UAAU,KAAK,SAAS,KAAK,WAAW,iBAAiB,GAAG;AAClE,aAAO;AAAA,IACT;AAEA,8BAA0B,KAAK;AAC7B,YAAM,gBAAgB,IAAI,gBAAgB,IAAI,IAAI,kBAAkB;AACpE,aAAO,GAAG,IAAI,qBAAqB,IAAI,wBAAwB,IAAI,aAAa;AAAA,IAClF;AAEA,2BAAuB,MAAM,KAAK;AAChC,YAAM,cAAe,KAAI,QAAQ,mBAAmB,IAAI,YAAY;AACpE,YAAM,SAAS,YAAY,QAAQ,kBAAkB,MAAM;AAC3D,aAAO,SAAS,KAAK,UAAU,MAAM,MAAM,CAAC,IAAI;AAAA,IAClD;AAEA,cAAU,WAAW;AACrB,cAAU,WAAW;AAErB,YAAQ,cAAc;AACtB,YAAQ,cAAc;AAAA;AAAA;;;ACxDtB;AAAA;AAAA,QAAM,QAAQ,UAAQ;AACtB,QAAM,QAAQ,UAAQ;AACtB,QAAM,UAAU,UAAQ;AAExB,QAAM,MAAM,UAAQ;AAEpB,QAAM,aAAa;AAAA,MACjB,MAAM,EAAC,SAAS,MAAM,WAAW,gBAAe,CAAC;AAAA,MACjD,QAAQ,EAAC,cAAc,GAAG,IAAI,QAAQ,IAAI,UAAS,CAAC;AAAA,MACpD,MAAM,EAAC,YAAY,EAAC,CAAC;AAAA,IACvB;AAEA,WAAO,UAAU;AAAA;AAAA;;;ACZjB;AAAA;AACA,QAAM,QAAQ,UAAQ;AACtB,QAAM,SAAS,UAAQ;AACvB,QAAM,aAAa,UAAQ;AAC3B,QAAM,cAAc,UAAQ;AAC5B,QAAM,eAAe,UAAQ;AAC7B,QAAM,WAAW,UAAQ;AACzB,QAAM,EAAC,eAAc;AACrB,QAAM,EAAC,aAAa,gBAAe;AAEnC,QAAM,YAAY;AAAA,MAChB,YAAY,CAAC,QAAQ;AACnB,YAAI,IAAI,cAAc,KAAK;AACzB,gBAAM,IAAI,YAAY,GAAG;AAAA,QAC3B,WAAW,IAAI,cAAc,KAAK;AAChC,gBAAM,IAAI,YAAY,GAAG;AAAA,QAC3B;AAEA,eAAO;AAAA,MACT;AAAA,IACF;AAEA,QAAM,gBAAgB;AAAA,MACpB,YAAY,CAAC,QAAQ;AACnB,cAAM,OAAO,IAAI,QAAQ;AACzB,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,OAAO,CAAC,IAAI;AACnD,iBAAS,OAAO,OAAO,EAAE,QAAQ,CAAC,QAAQ,QAAQ,KAAK,GAAG,CAAC;AAC3D,eAAO;AAAA,MACT;AAAA,IACF;AAGA,QAAM,cAAc;AAEpB,QAAM,aAAa,YAAY,OAAO;AAAA,MACpC;AAAA,MACA,YAAY;AAAA,MACZ,aAAa;AAAA,MACb,SAAS;AAAA,MACT;AAAA,MACA,WAAW,EAAC,gBAAgB,WAAU,CAAC;AAAA,IACzC,CAAC;AAED,QAAM,UAAU,MAAM,UAAU;AAEhC,yBAAqB,SAAS,YAAY,SAAS;AACjD,aAAO,UAAU,OAAO,EAAC,cAAc,EAAC,GAAG,OAAO,CAAC;AAAA,IACrD;AAEA,gBAAY,mBAAmB;AAC/B,gBAAY,cAAc;AAC1B,gBAAY,cAAc;AAE1B,WAAO,UAAU;AAAA;AAAA;;;ACrDjB;AAAA;AAAA,QAAM,SAAS,UAAQ;AAEvB,QAAM,gBAAgB;AAEtB,WAAO,UAAU,CAAC,QAAQ,YAAY,CAAC,MAAM;AAC3C,YAAM,UAAU,CAAC;AAEjB,YAAM,QAAQ,UAAU,SAAS,OAAO;AACxC,UAAI,OAAO;AACT,gBAAQ,gBAAgB,UAAU;AAAA,MACpC;AAEA,UAAI,CAAC,UAAU,gBAAgB,CAAC,OAAO,sBAAsB,OAAO,WAAW;AAC7E,gBAAQ,iBAAiB,OAAO;AAAA,MAClC;AAEA,YAAM,kBAAkB,QACtB,OAAO,UAAU,oBAAoB,cACjC,OAAO,SAAS,OAAO,kBACvB,UAAU,eAChB;AAEA,YAAM,UAAU,OAAO,UAAU,YAAY,cAAc,OAAO,UAAU,UAAU;AACtF,aAAO,OAAO,CAAC,GAAG,WAAW;AAAA,QAC3B,SAAS,OAAO,CAAC,GAAG,SAAS,UAAU,WAAW,CAAC,CAAC;AAAA,QACpD,SAAS,OAAO,YAAY,cAAc,IAAI,KAAK,MAAO;AAAA,QAC1D,OAAO,UAAU,SAAS,OAAO;AAAA,QACjC,MAAM;AAAA,QACN;AAAA,MACF,CAAC;AAAA,IACH;AAAA;AAAA;;;AC9BA;AAAA;AAAA,WAAO,UAAU,CAAC,OAAO;AACvB,UAAI,UAAU;AACd,UAAI;AACJ,aAAO,IAAI,SAAS;AAClB,YAAI,SAAS;AACX,iBAAO;AAAA,QACT;AACA,sBAAc,GAAG,GAAG,IAAI;AACxB,kBAAU;AACV,eAAO;AAAA,MACT;AAAA,IACF;AAAA;AAAA;;;ACXA;AAAA;AAAA,QAAM,kBAAkB,UAAQ,6BAA6B;AAC7D,QAAM,OAAO;AAEb,QAAM,uBAAuB,CAAC,YAE5B,KAAK,IAAI,SAAS,QAAQ,KAAK,QAAQ,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC;AAE5D,YAAQ,kBAAkB,qBAAqB;AAAA,MAC7C;AAAA,MACA,+CAA+C,gBAAgB,6BAA6B;AAAA,MAC5F;AAAA,MACA;AAAA,IACF,CAAC;AAED,YAAQ,2BAA2B,qBAAqB;AAAA,MACtD;AAAA,MACA,OAAO,gBACL,yBACF;AAAA,IACF,CAAC;AAED,YAAQ,oCAAoC,qBAAqB;AAAA,MAC/D;AAAA,MACA,OAAO,gBAAgB,uBAAuB;AAAA,IAChD,CAAC;AAAA;AAAA;;;ACxBD;AAAA;AAAA,QAAM,kBAAkB,UAAQ,6BAA6B;AAC7D,QAAM,SAAS,UAAQ;AACvB,QAAM,WAAW;AACjB,QAAM,WAAW;AAEjB,QAAM,iBAAiB;AACvB,QAAM,gBAAgB;AAAA,MACpB,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,oBAAoB;AAAA,MACpB,cAAc;AAAA,IAChB;AAEA,QAAM,aAAa,CAAC,aAAa,aAAa,SAAS;AACvD,QAAM,UAAU,CAAC,SAAS,WAAW,QAAQ,IAAI,MAAM;AAEvD,YAAQ,gBAAgB;AAGxB,YAAQ,aAAa,CAAC,QAAQ,eAAe;AAC3C,YAAM,kBAAkB,OAAO,CAAC,GAAG,YAAY,MAAM;AACrD,UAAI,CAAC,gBAAgB,YAAY;AAC/B,iBAAS,kCAAkC;AAAA,MAC7C;AAEA,YAAM,YAAY,OAAO,CAAC,GAAG,eAAe,eAAe;AAC3D,YAAM,eAAe,UAAU;AAE/B,UAAI,OAAO,YAAY,aAAa;AAClC,cAAM,UAAU,gBAAgB,4BAA4B;AAC5D,cAAM,IAAI,MAAM,iEAAiE,SAAS;AAAA,MAC5F;AAEA,UAAI,gBAAgB,CAAC,UAAU,WAAW;AACxC,cAAM,IAAI,MAAM,wCAAwC;AAAA,MAC1D;AAEA,YAAM,YAAY,OAAO,WAAW,eAAe,OAAO,YAAY,OAAO,SAAS;AACtF,YAAM,cAAc,aAAa,QAAQ,OAAO,SAAS,QAAQ;AAEjE,UAAI,aAAa,eAAe,UAAU,SAAS,UAAU,8BAA8B,MAAM;AAC/F,iBAAS,yBAAyB;AAAA,MACpC,WAAW,OAAO,UAAU,WAAW,aAAa;AAClD,iBAAS,gBAAgB;AAAA,MAC3B;AAEA,UAAI,cAAc;AAChB,iBAAS,UAAU,UAAU,SAAS;AAAA,MACxC;AAEA,UAAI,UAAU,SAAS;AACrB,iBAAS,QAAQ,UAAU,OAAO;AAAA,MACpC;AAEA,UAAI,sBAAsB,WAAW;AAEnC,kBAAU,mBAAmB,UAAU,mBACnC,SAAS,WAAW,UAAU,gBAAgB,EAAE,QAAQ,QAAQ,EAAE,IAClE;AAAA,MACN;AAEA,gBAAU,aAAa,GAAG,UAAU,aAAa,QAAQ,MAAM,EAAE;AACjE,gBAAU,eAAe,UAAU,YAAY,cAAc;AAC7D,gBAAU,SAAS,QAAQ,UAAU,MAAM,KAAK,CAAC,UAAU;AAE3D,cAAQ,mBAAmB,UAAU,UAAU;AAE/C,YAAM,YAAY,UAAU,QAAQ,MAAM,OAAO,CAAC;AAClD,YAAM,WAAW,UAAU;AAC3B,YAAM,OAAO,UAAU;AACvB,YAAM,UAAU,UAAU,eAAe,iBAAiB;AAE1D,UAAI,UAAU,oBAAoB;AAChC,kBAAU,MAAM,GAAG,cAAc,UAAU,aAAa,SAAS,UAAU;AAC3E,kBAAU,SAAS,GAAG,cAAc,UAAU,aAAa,YAAY,UAAU;AAAA,MACnF,OAAO;AACL,kBAAU,MAAM,GAAG,UAAU,YAAY,UAAU;AACnD,kBAAU,SAAS,UAAU;AAAA,MAC/B;AAEA,aAAO;AAAA,IACT;AAEA,YAAQ,qBAAqB,4BAA4B,YAAY;AACnE,UAAI,eAAe,OAAO,eAAe,KAAK;AAC5C;AAAA,MACF;AAEA,YAAM,UAAU,IAAI,KAAK,UAAU;AACnC,YAAM,kBACJ,sBAAsB,KAAK,UAAU,KAAK,mBAAmB,QAAQ,QAAQ,QAAQ,IAAI;AAE3F,UAAI,CAAC,iBAAiB;AACpB,cAAM,IAAI,MAAM,yEAAyE;AAAA,MAC3F;AAAA,IACF;AAAA;AAAA;;;AC/FA;AAAA;AAAA,QAAM,SAAS,UAAQ;AACvB,QAAM,EAAC,YAAY,KAAK,WAAU;AAClC,QAAM,QAAQ;AACd,QAAM,cAAc;AACpB,QAAM,cAAc;AACpB,QAAM,iBAAiB;AACvB,QAAM,iBAAiB;AACvB,QAAM,eAAe;AACrB,QAAM,cAAc;AACpB,QAAM,aAAa;AACnB,QAAM,cAAc;AACpB,QAAM,oBAAoB;AAC1B,QAAM,EAAC,eAAe,eAAc;AACpC,QAAM,WAAW;AAEjB,QAAM,YAAY,CAAC,eAAe,WAAW,UAAU;AAEvD,0BAAsB,SAAS,eAAe;AAC5C,UAAI,CAAE,iBAAgB,eAAe;AACnC,eAAO,IAAI,aAAa,MAAM;AAAA,MAChC;AAEA,WAAK,OAAO,MAAM;AAElB,WAAK,SAAS,IAAI,aAAa,IAAI;AACnC,WAAK,WAAW,IAAI,eAAe,IAAI;AACvC,WAAK,WAAW,IAAI,eAAe,IAAI;AACvC,WAAK,QAAQ,IAAI,YAAY,IAAI;AACjC,WAAK,OAAO,IAAI,WAAW,IAAI;AAE/B,UAAI,KAAK,aAAa,cAAc;AAClC,cAAM,mBAAmB,OAAO,CAAC,GAAG,KAAK,cAAc,EAAC,cAAc,MAAK,CAAC;AAC5E,aAAK,aAAa,IAAI,aAAa,gBAAgB;AAAA,MACrD;AAAA,IACF;AAEA,WAAO,aAAa,WAAW,WAAW;AAC1C,WAAO,aAAa,WAAW;AAAA,MAC7B,QAAQ;AACN,eAAO,IAAI,aAAa,KAAK,OAAO,CAAC;AAAA,MACvC;AAAA,MAEA,OAAO,WAAW;AAChB,YAAI,OAAO,cAAc,aAAa;AACpC,iBAAO,OAAO,CAAC,GAAG,KAAK,YAAY;AAAA,QACrC;AAEA,YAAI,KAAK,YAAY;AACnB,gBAAM,mBAAmB,OAAO,CAAC,GAAG,WAAW,EAAC,cAAc,MAAK,CAAC;AACpE,eAAK,WAAW,OAAO,gBAAgB;AAAA,QACzC;AAEA,aAAK,eAAe,WAAW,WAAW,KAAK,gBAAgB,CAAC,CAAC;AACjE,eAAO;AAAA,MACT;AAAA,MAEA,WAAW,WAAW;AACpB,eAAO,KAAK,MAAM,EAAE,OAAO,SAAS;AAAA,MACtC;AAAA,MAEA,OAAO,KAAK,SAAS,OAAO;AAC1B,cAAM,OAAO,SAAS,KAAK,aAAa,SAAS,KAAK,aAAa;AACnE,eAAO,GAAG,QAAQ,IAAI,QAAQ,OAAO,EAAE;AAAA,MACzC;AAAA,MAEA,eAAe;AACb,eAAO,KAAK,aAAa;AAAA,MAC3B;AAAA,MAEA,mBAAmB,SAAS;AAC1B,cAAM,MAAM,QAAQ,OAAO,QAAQ;AAInC,cAAM,YACJ,OAAO,QAAQ,cAAc,cACzB,CAAC,OAAO,MAAM,EAAE,QAAQ,QAAQ,UAAU,KAAK,KAAK,KAAK,IAAI,QAAQ,QAAQ,MAAM,IACnF,QAAQ;AAEd,cAAM,SAAS,KAAK,aAAa,UAAU;AAE3C,cAAM,MACJ,QAAQ,OAAO,KAAK,aAAa,mBAC7B,CAAC,KAAK,aAAa,kBAAkB,QAAQ,GAAG,EAAE,KAAK,GAAG,IAC1D,QAAQ,OAAO,KAAK,aAAa;AAEvC,YAAI,KAAK;AACP,kBAAQ,QAAQ,EAAC,KAAK,SAAS,WAAW,GAAG,GAAG,GAAG,QAAQ,MAAK;AAAA,QAClE;AAEA,cAAM,aAAa,kBACjB,KAAK,cACL,OAAO,CAAC,GAAG,SAAS;AAAA,UAClB,KAAK,KAAK,OAAO,KAAK,MAAM;AAAA,QAC9B,CAAC,CACH;AAEA,eAAO,IAAI,WAAW,CAAC,eACrB,YAAY,YAAY,KAAK,aAAa,SAAS,EAAE,UAAU,UAAU,CAC3E;AAAA,MACF;AAAA,MAEA,QAAQ,SAAS;AACf,cAAM,aAAa,KAAK,mBAAmB,OAAO,EAAE,KAClD,OAAO,CAAC,UAAU,MAAM,SAAS,UAAU,GAC3C,IAAI,CAAC,UAAU,MAAM,IAAI,CAC3B;AAEA,eAAO,KAAK,aAAa,IAAI,UAAU,UAAU,IAAI;AAAA,MACvD;AAAA,IACF,CAAC;AAED,iBAAa,QAAQ;AACrB,iBAAa,cAAc;AAC3B,iBAAa,cAAc,YAAY;AACvC,iBAAa,cAAc,YAAY;AACvC,iBAAa,YAAY,YAAY;AAErC,WAAO,UAAU;AAAA;AAAA;",
6
+ "names": []
7
+ }
package/package.json CHANGED
@@ -1,22 +1,40 @@
1
1
  {
2
2
  "name": "@sanity/client",
3
- "version": "3.3.0",
3
+ "version": "3.4.0-beta.esm.1",
4
4
  "description": "Client for retrieving, creating and patching data from Sanity.io",
5
5
  "main": "lib/sanityClient.js",
6
6
  "umd": "umd/sanityClient.min.js",
7
7
  "unpkg": "umd/sanityClient.min.js",
8
8
  "types": "./sanityClient.d.ts",
9
+ "module": "./dist/sanityClient.browser.mjs",
10
+ "exports": {
11
+ ".": {
12
+ "source": "./src/sanityClient.js",
13
+ "browser": "./dist/sanityClient.browser.mjs",
14
+ "default": "./dist/sanityClient.node.js"
15
+ }
16
+ },
17
+ "files": [
18
+ "dist",
19
+ "lib",
20
+ "src",
21
+ "umd",
22
+ "sanityClient.d.ts"
23
+ ],
9
24
  "scripts": {
10
25
  "browserify": "NODE_ENV=production BROWSERIFY_ENV=build DEBUG='' browserify -t envify -g uglifyify lib/sanityClient.js -o umd/sanityClient.js --standalone=SanityClient",
11
26
  "compile": "babel -d lib src",
12
- "build": "npm run compile && npm run browserify && npm run minify",
27
+ "build": "npm run compile && npm run browserify && npm run minify && npm run esbuild:browser && npm run esbuild:node",
28
+ "esbuild": "esbuild src/sanityClient.js --bundle --format=esm --sourcemap",
29
+ "esbuild:browser": "npm run esbuild -- --outfile=dist/sanityClient.browser.mjs --platform=browser",
30
+ "esbuild:node": "npm run esbuild -- --outfile=dist/sanityClient.node.js --platform=node --external:object-assign --external:get-it --external:@sanity/eventsource --external:@sanity/generate-help-url --external:make-error --external:rxjs --external:*.json",
13
31
  "lint": "eslint .",
14
- "clean": "rimraf lib coverage .nyc_output umd/*.js",
32
+ "clean": "rimraf dist lib coverage .nyc_output umd/*.js",
15
33
  "coverage": "DEBUG=sanity NODE_ENV=test nyc --reporter=html --reporter=lcov --reporter=text npm test",
16
34
  "minify": "terser -c -m -- umd/sanityClient.js > umd/sanityClient.min.js",
17
- "prepublishOnly": "npm run build",
35
+ "prepublishOnly": "npm run clean && npm run build",
18
36
  "test": "NODE_ENV=test tape test/*.test.js",
19
- "posttest": "npm run lint"
37
+ "posttest": "npm run lint && package-check"
20
38
  },
21
39
  "browser": {
22
40
  "./src/http/nodeMiddleware.js": "./src/http/browserMiddleware.js",
@@ -26,7 +44,7 @@
26
44
  "node": ">=12"
27
45
  },
28
46
  "dependencies": {
29
- "@sanity/eventsource": "^3.0.2",
47
+ "@sanity/eventsource": "^4.0.0",
30
48
  "@sanity/generate-help-url": "^3.0.0",
31
49
  "get-it": "^6.0.1",
32
50
  "make-error": "^1.3.0",
@@ -37,8 +55,10 @@
37
55
  "@babel/cli": "^7.17.6",
38
56
  "@babel/core": "^7.17.7",
39
57
  "@babel/preset-env": "^7.11.5",
58
+ "@skypack/package-check": "^0.2.2",
40
59
  "browserify": "^17.0.0",
41
60
  "envify": "^4.0.0",
61
+ "esbuild": "^0.14.43",
42
62
  "eslint": "^8.11.0",
43
63
  "eslint-config-prettier": "^8.5.0",
44
64
  "eslint-config-sanity": "^5.1.0",
package/sanityClient.d.ts CHANGED
@@ -12,6 +12,7 @@ export type AssetMetadataType =
12
12
  export type DatasetAclMode = 'public' | 'private' | 'custom'
13
13
  export type ListenVisibility = 'sync' | 'async' | 'query'
14
14
  export type ListenEventName = 'mutation' | 'welcome' | 'reconnect'
15
+ export type MutationOperation = 'create' | 'delete' | 'update' | 'none'
15
16
 
16
17
  export interface ResponseEvent<T = unknown> {
17
18
  type: 'response'
@@ -214,13 +215,13 @@ export type Mutation<R = any> =
214
215
  export interface SingleMutationResult {
215
216
  transactionId: string
216
217
  documentId: string
217
- results: {id: string}[]
218
+ results: {id: string; operation: MutationOperation}[]
218
219
  }
219
220
 
220
221
  export interface MultipleMutationResult {
221
222
  transactionId: string
222
223
  documentIds: string[]
223
- results: {id: string}[]
224
+ results: {id: string; operation: MutationOperation}[]
224
225
  }
225
226
 
226
227
  export class Patch {
@@ -0,0 +1,135 @@
1
+ const assign = require('object-assign')
2
+ const {map, filter} = require('../util/observable')
3
+ const queryString = require('../http/queryString')
4
+ const validators = require('../validators')
5
+
6
+ function AssetsClient(client) {
7
+ this.client = client
8
+ }
9
+
10
+ function optionsFromFile(opts, file) {
11
+ if (typeof window === 'undefined' || !(file instanceof window.File)) {
12
+ return opts
13
+ }
14
+
15
+ return assign(
16
+ {
17
+ filename: opts.preserveFilename === false ? undefined : file.name,
18
+ contentType: file.type,
19
+ },
20
+ opts
21
+ )
22
+ }
23
+
24
+ assign(AssetsClient.prototype, {
25
+ /**
26
+ * Upload an asset
27
+ *
28
+ * @param {String} assetType `image` or `file`
29
+ * @param {File|Blob|Buffer|ReadableStream} body File to upload
30
+ * @param {Object} opts Options for the upload
31
+ * @param {Boolean} opts.preserveFilename Whether or not to preserve the original filename (default: true)
32
+ * @param {String} opts.filename Filename for this file (optional)
33
+ * @param {Number} opts.timeout Milliseconds to wait before timing the request out (default: 0)
34
+ * @param {String} opts.contentType Mime type of the file
35
+ * @param {Array} opts.extract Array of metadata parts to extract from image.
36
+ * Possible values: `location`, `exif`, `image`, `palette`
37
+ * @param {String} opts.label Label
38
+ * @param {String} opts.title Title
39
+ * @param {String} opts.description Description
40
+ * @param {String} opts.creditLine The credit to person(s) and/or organization(s) required by the supplier of the image to be used when published
41
+ * @param {Object} opts.source Source data (when the asset is from an external service)
42
+ * @param {String} opts.source.id The (u)id of the asset within the source, i.e. 'i-f323r1E'
43
+ * Required if source is defined
44
+ * @param {String} opts.source.name The name of the source, i.e. 'unsplash'
45
+ * Required if source is defined
46
+ * @param {String} opts.source.url A url to where to find the asset, or get more info about it in the source
47
+ * Optional
48
+ * @return {Promise} Resolves with the created asset document
49
+ */
50
+ upload(assetType, body, opts = {}) {
51
+ validators.validateAssetType(assetType)
52
+
53
+ // If an empty array is given, explicitly set `none` to override API defaults
54
+ let meta = opts.extract || undefined
55
+ if (meta && !meta.length) {
56
+ meta = ['none']
57
+ }
58
+
59
+ const dataset = validators.hasDataset(this.client.clientConfig)
60
+ const assetEndpoint = assetType === 'image' ? 'images' : 'files'
61
+ const options = optionsFromFile(opts, body)
62
+ const {tag, label, title, description, creditLine, filename, source} = options
63
+ const query = {
64
+ label,
65
+ title,
66
+ description,
67
+ filename,
68
+ meta,
69
+ creditLine,
70
+ }
71
+ if (source) {
72
+ query.sourceId = source.id
73
+ query.sourceName = source.name
74
+ query.sourceUrl = source.url
75
+ }
76
+ const observable = this.client._requestObservable({
77
+ tag,
78
+ method: 'POST',
79
+ timeout: options.timeout || 0,
80
+ uri: `/assets/${assetEndpoint}/${dataset}`,
81
+ headers: options.contentType ? {'Content-Type': options.contentType} : {},
82
+ query,
83
+ body,
84
+ })
85
+
86
+ return this.client.isPromiseAPI()
87
+ ? observable
88
+ .pipe(
89
+ filter((event) => event.type === 'response'),
90
+ map((event) => event.body.document)
91
+ )
92
+ .toPromise()
93
+ : observable
94
+ },
95
+
96
+ delete(type, id) {
97
+ // eslint-disable-next-line no-console
98
+ console.warn('client.assets.delete() is deprecated, please use client.delete(<document-id>)')
99
+
100
+ let docId = id || ''
101
+ if (!/^(image|file)-/.test(docId)) {
102
+ docId = `${type}-${docId}`
103
+ } else if (type._id) {
104
+ // We could be passing an entire asset document instead of an ID
105
+ docId = type._id
106
+ }
107
+
108
+ validators.hasDataset(this.client.clientConfig)
109
+ return this.client.delete(docId)
110
+ },
111
+
112
+ getImageUrl(ref, query) {
113
+ const id = ref._ref || ref
114
+ if (typeof id !== 'string') {
115
+ throw new Error(
116
+ 'getImageUrl() needs either an object with a _ref, or a string with an asset document ID'
117
+ )
118
+ }
119
+
120
+ if (!/^image-[A-Za-z0-9_]+-\d+x\d+-[a-z]{1,5}$/.test(id)) {
121
+ throw new Error(
122
+ `Unsupported asset ID "${id}". URL generation only works for auto-generated IDs.`
123
+ )
124
+ }
125
+
126
+ const [, assetId, size, format] = id.split('-')
127
+
128
+ validators.hasDataset(this.client.clientConfig)
129
+ const {projectId, dataset} = this.client.clientConfig
130
+ const qs = query ? queryString(query) : ''
131
+ return `https://cdn.sanity.io/images/${projectId}/${dataset}/${assetId}-${size}.${format}${qs}`
132
+ },
133
+ })
134
+
135
+ module.exports = AssetsClient
@@ -0,0 +1,17 @@
1
+ const assign = require('object-assign')
2
+
3
+ function AuthClient(client) {
4
+ this.client = client
5
+ }
6
+
7
+ assign(AuthClient.prototype, {
8
+ getLoginProviders() {
9
+ return this.client.request({uri: '/auth/providers'})
10
+ },
11
+
12
+ logout() {
13
+ return this.client.request({uri: '/auth/logout', method: 'POST'})
14
+ },
15
+ })
16
+
17
+ module.exports = AuthClient
package/src/config.js ADDED
@@ -0,0 +1,96 @@
1
+ const generateHelpUrl = require('@sanity/generate-help-url').generateHelpUrl
2
+ const assign = require('object-assign')
3
+ const validate = require('./validators')
4
+ const warnings = require('./warnings')
5
+
6
+ const defaultCdnHost = 'apicdn.sanity.io'
7
+ const defaultConfig = {
8
+ apiHost: 'https://api.sanity.io',
9
+ apiVersion: '1',
10
+ useProjectHostname: true,
11
+ isPromiseAPI: true,
12
+ }
13
+
14
+ const LOCALHOSTS = ['localhost', '127.0.0.1', '0.0.0.0']
15
+ const isLocal = (host) => LOCALHOSTS.indexOf(host) !== -1
16
+
17
+ exports.defaultConfig = defaultConfig
18
+
19
+ // eslint-disable-next-line complexity
20
+ exports.initConfig = (config, prevConfig) => {
21
+ const specifiedConfig = assign({}, prevConfig, config)
22
+ if (!specifiedConfig.apiVersion) {
23
+ warnings.printNoApiVersionSpecifiedWarning()
24
+ }
25
+
26
+ const newConfig = assign({}, defaultConfig, specifiedConfig)
27
+ const projectBased = newConfig.useProjectHostname
28
+
29
+ if (typeof Promise === 'undefined') {
30
+ const helpUrl = generateHelpUrl('js-client-promise-polyfill')
31
+ throw new Error(`No native Promise-implementation found, polyfill needed - see ${helpUrl}`)
32
+ }
33
+
34
+ if (projectBased && !newConfig.projectId) {
35
+ throw new Error('Configuration must contain `projectId`')
36
+ }
37
+
38
+ const isBrowser = typeof window !== 'undefined' && window.location && window.location.hostname
39
+ const isLocalhost = isBrowser && isLocal(window.location.hostname)
40
+
41
+ if (isBrowser && isLocalhost && newConfig.token && newConfig.ignoreBrowserTokenWarning !== true) {
42
+ warnings.printBrowserTokenWarning()
43
+ } else if (typeof newConfig.useCdn === 'undefined') {
44
+ warnings.printCdnWarning()
45
+ }
46
+
47
+ if (projectBased) {
48
+ validate.projectId(newConfig.projectId)
49
+ }
50
+
51
+ if (newConfig.dataset) {
52
+ validate.dataset(newConfig.dataset)
53
+ }
54
+
55
+ if ('requestTagPrefix' in newConfig) {
56
+ // Allow setting and unsetting request tag prefix
57
+ newConfig.requestTagPrefix = newConfig.requestTagPrefix
58
+ ? validate.requestTag(newConfig.requestTagPrefix).replace(/\.+$/, '')
59
+ : undefined
60
+ }
61
+
62
+ newConfig.apiVersion = `${newConfig.apiVersion}`.replace(/^v/, '')
63
+ newConfig.isDefaultApi = newConfig.apiHost === defaultConfig.apiHost
64
+ newConfig.useCdn = Boolean(newConfig.useCdn) && !newConfig.withCredentials
65
+
66
+ exports.validateApiVersion(newConfig.apiVersion)
67
+
68
+ const hostParts = newConfig.apiHost.split('://', 2)
69
+ const protocol = hostParts[0]
70
+ const host = hostParts[1]
71
+ const cdnHost = newConfig.isDefaultApi ? defaultCdnHost : host
72
+
73
+ if (newConfig.useProjectHostname) {
74
+ newConfig.url = `${protocol}://${newConfig.projectId}.${host}/v${newConfig.apiVersion}`
75
+ newConfig.cdnUrl = `${protocol}://${newConfig.projectId}.${cdnHost}/v${newConfig.apiVersion}`
76
+ } else {
77
+ newConfig.url = `${newConfig.apiHost}/v${newConfig.apiVersion}`
78
+ newConfig.cdnUrl = newConfig.url
79
+ }
80
+
81
+ return newConfig
82
+ }
83
+
84
+ exports.validateApiVersion = function validateApiVersion(apiVersion) {
85
+ if (apiVersion === '1' || apiVersion === 'X') {
86
+ return
87
+ }
88
+
89
+ const apiDate = new Date(apiVersion)
90
+ const apiVersionValid =
91
+ /^\d{4}-\d{2}-\d{2}$/.test(apiVersion) && apiDate instanceof Date && apiDate.getTime() > 0
92
+
93
+ if (!apiVersionValid) {
94
+ throw new Error('Invalid API version string, expected `1` or date in format `YYYY-MM-DD`')
95
+ }
96
+ }