@homedev/fields 1.2.11 → 1.2.12
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.
- package/dist/index.d.ts +70 -0
- package/dist/index.js +1 -1
- package/package.json +1 -1
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { NavigateResult } from '@homedev/navigate';
|
|
2
|
+
|
|
3
|
+
export declare interface FieldContext {
|
|
4
|
+
path: string;
|
|
5
|
+
root: any;
|
|
6
|
+
options: ProcessFieldsOptions;
|
|
7
|
+
value: string | object | number | NavigateResult | null;
|
|
8
|
+
key: string;
|
|
9
|
+
args: any[];
|
|
10
|
+
rawArgs: {
|
|
11
|
+
value: string;
|
|
12
|
+
quoted: boolean;
|
|
13
|
+
}[];
|
|
14
|
+
tags: Record<string, string[]>;
|
|
15
|
+
parent?: any;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export declare interface FieldProcessor {
|
|
19
|
+
fn: FieldProcessorFunc;
|
|
20
|
+
options: FieldProcessorOptions;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export declare type FieldProcessorFunc = (context: FieldContext) => any;
|
|
24
|
+
|
|
25
|
+
export declare type FieldProcessorMap = Record<string, FieldProcessorTypedFunc>;
|
|
26
|
+
|
|
27
|
+
export declare interface FieldProcessorOptions {
|
|
28
|
+
filters?: RegExp[];
|
|
29
|
+
processArgs?: boolean;
|
|
30
|
+
types?: Record<number, string | any[] | ((value: string, root: any, index: number, quoted: boolean) => any)> | FieldProcessorTypeChecker;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export declare type FieldProcessorTypeChecker = (n: number, value: any, args: any[]) => any;
|
|
34
|
+
|
|
35
|
+
export declare type FieldProcessorTypeCheckers<T = unknown> = Record<keyof T, FieldProcessorTypeChecker>;
|
|
36
|
+
|
|
37
|
+
export declare type FieldProcessorTypedFunc = FieldProcessorFunc | (FieldProcessorOptions & {
|
|
38
|
+
fn: FieldProcessorFunc;
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
export declare const makeFieldProcessor: (fn: SourceFunc, types?: FieldProcessorTypeChecker) => FieldProcessorTypedFunc;
|
|
42
|
+
|
|
43
|
+
export declare const makeFieldProcessorList: <T = unknown>(source: SourceFunc[], options?: {
|
|
44
|
+
types?: FieldProcessorTypeCheckers<T>;
|
|
45
|
+
}) => FieldProcessorMap;
|
|
46
|
+
|
|
47
|
+
export declare const makeFieldProcessorMap: <T = unknown>(source: Record<keyof T, SourceFunc>, options?: {
|
|
48
|
+
types?: FieldProcessorTypeCheckers<T>;
|
|
49
|
+
keys?: (keyof T)[];
|
|
50
|
+
}) => FieldProcessorMap;
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* @public
|
|
54
|
+
* @param obj
|
|
55
|
+
* @param options
|
|
56
|
+
* @returns
|
|
57
|
+
*/
|
|
58
|
+
export declare const processFields: (obj: any, options?: ProcessFieldsOptions) => Promise<any>;
|
|
59
|
+
|
|
60
|
+
export declare interface ProcessFieldsOptions {
|
|
61
|
+
sources?: FieldProcessorMap;
|
|
62
|
+
keys?: FieldProcessorMap;
|
|
63
|
+
filters?: RegExp[];
|
|
64
|
+
root?: Record<any, any>;
|
|
65
|
+
globalContext?: any;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
declare type SourceFunc = (...args: any[]) => any;
|
|
69
|
+
|
|
70
|
+
export { }
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var{defineProperty:_,getOwnPropertyNames:R,getOwnPropertyDescriptor:x}=Object,h=Object.prototype.hasOwnProperty;var k=new WeakMap,V=(F)=>{var S=k.get(F),P;if(S)return S;if(S=_({},"__esModule",{value:!0}),F&&typeof F==="object"||typeof F==="function")R(F).map((E)=>!h.call(S,E)&&_(S,E,{get:()=>F[E],enumerable:!(P=x(F,E))||P.enumerable}));return k.set(F,S),S};var w=(F,S)=>{for(var P in S)_(F,P,{get:S[P],enumerable:!0,configurable:!0,set:(E)=>S[P]=()=>E})};var p={};w(p,{processFields:()=>b,makeFieldProcessorMap:()=>v,makeFieldProcessorList:()=>n,makeFieldProcessor:()=>B,getProcessor:()=>H,getArgs:()=>K});module.exports=V(p);var O=require("@homedev/split");var D=require("@homedev/navigate"),Q=require("@homedev/select"),q=(F,S)=>{if(typeof F.value==="string"){if(F.quoted)return F.value;if(F.value.startsWith("[")&&F.value.endsWith("]")){let P=F.value.slice(1,-1);if(P.trim()==="")return[];return P.split(";").map((E)=>{let
|
|
1
|
+
var{defineProperty:_,getOwnPropertyNames:R,getOwnPropertyDescriptor:x}=Object,h=Object.prototype.hasOwnProperty;var k=new WeakMap,V=(F)=>{var S=k.get(F),P;if(S)return S;if(S=_({},"__esModule",{value:!0}),F&&typeof F==="object"||typeof F==="function")R(F).map((E)=>!h.call(S,E)&&_(S,E,{get:()=>F[E],enumerable:!(P=x(F,E))||P.enumerable}));return k.set(F,S),S};var w=(F,S)=>{for(var P in S)_(F,P,{get:S[P],enumerable:!0,configurable:!0,set:(E)=>S[P]=()=>E})};var p={};w(p,{processFields:()=>b,makeFieldProcessorMap:()=>v,makeFieldProcessorList:()=>n,makeFieldProcessor:()=>B,getProcessor:()=>H,getArgs:()=>K});module.exports=V(p);var O=require("@homedev/split");var D=require("@homedev/navigate"),Q=require("@homedev/select"),q=(F,S)=>{if(typeof F.value==="string"){if(F.quoted)return F.value;if(F.value.startsWith("[")&&F.value.endsWith("]")){let P=F.value.slice(1,-1);if(P.trim()==="")return[];return P.split(";").map((E)=>{let T=E.trim();if(!isNaN(+T))return+T;return T})}if(F.value.startsWith("{")&&F.value.endsWith("}")){if(F.value.slice(1,-1).trim()==="")return{}}if(F.value==="null")return null;if(F.value==="undefined")return;if(F.value.startsWith("@"))return F.value.slice(1);if(!isNaN(+F.value))return+F.value}return S(F.value)},J=(F,S,P,E,T,$)=>{let C=E?.(F)??F,M=T(C);if(M[0])return M[1];if(!S){let L=Q.select(P,F),G=T(L);if(G[0])return G[1]}throw Error($)},X=(F,S,P,E,T)=>{let $=typeof F.types==="function"?F.types(E,S.value,T):F.types?.[E];if(!$||$==="ref")return q(S,(M)=>Q.select(P,M));let C=q(S,()=>S.value);if(Array.isArray($)){if(!$.includes(C))throw Error(`Argument ${E.toString()} must be one of [${$.join(", ")}]: ${C}`);return C}if(typeof $==="string"){if($.endsWith("?")){let M=$.slice(0,-1);if(S.value==="null")return D.NavigateResult.ReplaceItem(null);if(S.value==="undefined")return D.NavigateResult.ReplaceItem(void 0);if(S.value==="")return"";$=M}switch($){case"any":return C;case"array":return J(C,S.quoted,P,null,(M)=>[Array.isArray(M),M],`Argument ${E.toString()} must be an array: ${C}`);case"object":return J(C,S.quoted,P,null,(M)=>[typeof M==="object"&&M!==null,M],`Argument ${E.toString()} must be an object: ${C}`);case"number":return J(C,S.quoted,P,(M)=>Number(M),(M)=>[!isNaN(M),M],`Argument ${E.toString()} must be a number: ${C}`);case"boolean":return J(C,S.quoted,P,null,(M)=>{if([!0,"true","1",1,"yes","on"].includes(M))return[!0,!0];if([!1,"false","0",0,"no","off"].includes(M))return[!0,!1];if([null,"null","undefined",void 0,""].includes(M))return[!0,!1];if(Array.isArray(M))return[!0,M.length>0];return[!1,!1]},`Argument ${E.toString()} must be a boolean: ${C}`);case"string":return C.toString();default:throw Error(`Unknown type for argument ${E.toString()}: ${$}`)}}return $(C,P,E,S.quoted)};var H=(F,S)=>{let P=F[S];if(P===void 0)throw Error(`Unhandled field processor type: ${S}`);return typeof P==="function"?{options:{},fn:P}:{options:P,fn:P.fn}},y=(F)=>!F.quoted&&F.value.startsWith("."),g=(F)=>{let S={};for(let P of F){if(!y(P))continue;let E=P.value.indexOf("="),T=E>-1?P.value.slice(1,E):P.value.slice(1),$=E>-1?P.value.slice(E+1):"";if($.length>=2){let C=$[0],M=$[$.length-1];if(C==='"'&&M==='"'||C==="'"&&M==="'")$=$.slice(1,-1)}if(!S[T])S[T]=[];S[T].push($)}return S},K=(F,S,P)=>{let E=O.splitWithQuotes(F??""),T=g(E),$=E.filter((M)=>!y(M)),C=S.options.processArgs===!1?[]:$.map((M,L)=>X(S.options,M,P,L,$));return{rawArgs:$,parsedArgs:C,tags:T}};var U=require("@homedev/navigate");var j=require("@homedev/navigate");var f=(F,S)=>S.keys!==void 0&&F.key.startsWith(".")&&S.keys[F.key.substring(1)]!==void 0,N=async(F,S,P,E)=>{let{key:T,parent:$}=F,C=H(E.keys,T.substring(1));if(C.options.processArgs!==!1&&(typeof C.options.types==="function"||C.options.types?.[0]!==void 0))F.value=X(C.options,{value:F.value,quoted:!1},P,0,[]);if(typeof F.value!=="string")await b(F.value,{...E,root:{...P,parent:F.parent,parents:F.parents},filters:[...E.filters??[],...C.options.filters??[]]});let M=await C.fn({path:S,root:P,parent:$,key:T,options:E,value:F.value,args:[F.value],rawArgs:[],tags:{}});return M instanceof j.NavigateResult?M:j.NavigateResult.ReplaceParent(M)};var z=require("@homedev/navigate"),m=require("@homedev/select");var I=(F)=>{let S=[],P=0;while(P<F.length)if(F[P]==="$"&&F[P+1]==="("&&(P===0||F[P-1]!=="\\")){let E=P;P+=2;let T=1;for(;P<F.length;P++)if(F[P]==="(")T++;else if(F[P]===")"){if(T--,T===0){S.push([E,P]);break}}if(T!==0)throw Error(`Unmatched opening $( at position ${E.toString()}`);P++}else P++;return S};class Y{value;constructor(F){this.value=F}}var d=async(F,S,P)=>{for(let E=S.length-1;E>=0;E--){let[T,$]=S[E],C=F.slice(T+2,$),M=await d(C,I(C),P);if(typeof M==="object")return M;let L=await P(M,F);if(L instanceof Y)return L.value;F=F.slice(0,T)+L+F.slice($+1)}return F},A=async(F,S)=>d(F,I(F),S);var c=async(F,S,P,E)=>{let T=await(async()=>{let $=/([\w\d.-_/]+):(.+)/.exec(F);if(!$)return await m.select(S,F);let[C,M,L]=$,G=H(E.sources,M),Z=K(L,G,S);return await G.fn({args:Z.parsedArgs,rawArgs:Z.rawArgs,tags:Z.tags,key:M,options:E,root:S,path:P,value:null})})();if(T===null||T===void 0)return"";if(typeof T==="object")return new Y(T);return T},W=async(F,S,P,E)=>{let T=await A(S,($)=>c($,P,F,E));if(T instanceof z.NavigateResult)return T;if(T===S)return z.NavigateResult.Explore();if(typeof T==="string"){let $=await W(F,T,P,E);if($.action!==z.NavigateAction.Explore)return $}return z.NavigateResult.ReplaceItem(T)};var b=async(F,S)=>{return S??={},await U.navigate(F,async(P)=>{let E=[...P.path,P.key].join(".");if(S?.filters?.length&&S.filters.some((M)=>M.test(E)))return U.NavigateResult.NoExplore();let T=P.path.length===0,$=P.parents.length>0?P.parents.toReversed():[];if(T){if($.length>0)throw Error("Root object should not have a parent");$=S?.root?.parents?[S.root.parent,...S.root.parents.toReversed()]:[]}let C={...F,...S.root,this:P.parent,parent:$.length>0?$[0]:null,parents:$};try{if(P.key.startsWith("$"))return U.NavigateResult.NoExplore();let M=U.NavigateResult.Explore();if(typeof P.value==="string")switch(M=await W(E,P.value,C,S),M.action){case U.NavigateAction.Explore:break;case U.NavigateAction.ReplaceItem:P.value=M.by;break;default:return M}if(f(P,S))M=await N(P,E,C,S);return M}catch(M){throw Error(`${M.message}
|
|
2
2
|
(${E})`)}}),F};var B=(F,S)=>S?{fn:(P)=>F(...P.args),types:S}:(P)=>F(...P.args),n=(F,S)=>Object.fromEntries(F.map((P)=>[P.name,B(P,S?.types?.[P.name])])),v=(F,S)=>Object.fromEntries((S?.keys??Object.keys(F)).map((P)=>[P,B(F[P],S?.types?.[P])]));
|