map-transform-cjs
Version:
MapTransform with CJS support
1 lines • 3.55 kB
Source Map (JSON)
{"version":3,"sources":["../../src/operations/plug.ts","../../src/utils/stateHelpers.ts"],"sourcesContent":["import type { Operation } from '../types.js'\nimport { setStateValue, getTargetFromState } from '../utils/stateHelpers.js'\n\nexport default function plug(): Operation {\n return () => (_next) => async (state) =>\n setStateValue(state, getTargetFromState(state))\n}\n","import xor from './xor.js'\nimport type { State, InitialState } from '../types.js'\n\n// Context\n\nexport const getLastContext = (state: State) =>\n state.context[state.context.length - 1]\n\nexport const removeLastContext = (state: State) => ({\n ...state,\n context: state.context.slice(0, -1),\n})\n\nexport const pushContext = (state: State, value: unknown) => ({\n ...state,\n context: [...state.context, value],\n})\n\nexport const popContext = (state: State) => ({\n ...state,\n context: state.context.slice(0, -1),\n value: state.context[state.context.length - 1],\n})\n\n// Root\n\nexport const getRootFromState = (state: State) =>\n state.context.length === 0 ? state.value : state.context[0]\n\n// Target\n\nexport const getTargetFromState = (state: State) => state.target\n\nexport function setTargetOnState(state: State, target: unknown): State {\n return {\n ...state,\n target,\n }\n}\n\n// State value\n\nexport const setStateValue = (\n { untouched, ...state }: State, // Clear untouched every time we set a value\n value: unknown,\n shouldPushContext = false,\n): State =>\n shouldPushContext\n ? {\n ...pushContext(state, state.value),\n value,\n }\n : { ...state, value }\n\nexport const getStateValue = (state: State): unknown => state.value\n\nexport const setValueFromState = (\n state: State,\n { value }: State,\n shouldPushContext = false,\n): State => setStateValue(state, value, shouldPushContext)\n\nexport const isNonvalue = (\n value: unknown,\n nonvalues: unknown[] = [undefined],\n) => nonvalues.includes(value)\n\nexport const isNonvalueState = (\n state: State,\n nonvalues: unknown[] = [undefined],\n) => isNonvalue(state.value, nonvalues)\n\nexport const markAsUntouched = (state: State) => ({ ...state, untouched: true })\nexport const clearUntouched = ({ untouched, ...state }: State) => state\nexport const isUntouched = ({ untouched }: State) => !!untouched\n\n// State\n\nexport const populateState = (\n data: unknown,\n { rev = false, noDefaults = false, target = undefined }: InitialState,\n): State => ({\n context: [],\n value: data,\n target,\n rev,\n noDefaults,\n})\n\nexport const goForward = (state: State) =>\n state.rev || state.flip\n ? {\n ...state,\n rev: false,\n flip: false,\n }\n : state\n\nexport const flipState = (state: State, flip = true) => ({\n ...state,\n flip: xor(state.flip, flip),\n})\n\nexport const stopIteration = (state: State) => ({ ...state, iterate: false })\n\nexport const noopNext = async (state: State) => state\n\nexport const revFromState = (state: State, flip = false) =>\n flip ? xor(state.rev, !state.flip) : xor(state.rev, state.flip)\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACaO,IAAM,cAAc,CAAC,OAAc,WAAoB;AAAA,EAC5D,GAAG;AAAA,EACH,SAAS,CAAC,GAAG,MAAM,SAAS,KAAK;AACnC;AAeO,IAAM,qBAAqB,CAAC,UAAiB,MAAM;AAWnD,IAAM,gBAAgB,CAC3B,EAAE,WAAW,GAAG,MAAM,GACtB,OACA,oBAAoB,UAEpB,oBACI;AAAA,EACE,GAAG,YAAY,OAAO,MAAM,KAAK;AAAA,EACjC;AACF,IACA,EAAE,GAAG,OAAO,MAAM;;;ADjDT,SAAR,OAAmC;AACxC,SAAO,MAAM,CAAC,UAAU,OAAO,UAC7B,cAAc,OAAO,mBAAmB,KAAK,CAAC;AAClD;","names":[]}