atomservices 0.14.1 → 0.14.2

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.cjs CHANGED
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require(`uuidv7`);const t=t=>{let{AggregateType:n,EventName:r,AggregateIdentifier:i=()=>(0,e.uuidv7)(),EventIdentifier:a=()=>(0,e.uuidv7)()}=t;return({aggregateID:e,payloads:t,_metadata:o,_version:s,_createdBy:c,...l})=>({...l,_id:a(),name:r,aggregateType:n,aggregateID:e??i(),payloads:t,_version:s,_createdBy:c,_createdAt:new Date,_metadata:o??{}})},n=e=>{let{EventStore:t,Projections:n,Reactions:r,onReactionError:i}=e,a=n.reduce((e,t)=>{let n=e[t.name]||[];return n.push(t),e[t.name]=n,e},{}),o=r.reduce((e,t)=>{let n=e[t.name]||[];return n.push(t),e[t.name]=n,e},{});return{async dispatch(e,n){try{await t.append(e);let r=a[e.name]||[];await Promise.all(r.map(t=>t.project(e))),(o[e.name]||[]).forEach(t=>{t.on(e).catch(n=>{let r=n instanceof Error?n:Error(String(n));i&&i({reactionName:t.name,eventName:e.name,eventID:e._id,error:r})})}),n?.()}catch(e){let t=e instanceof Error?e:Error(String(e));throw n?.(t),t}}}},r=(...e)=>e.flatMap(e=>Object.values(e)),i=()=>(0,e.uuidv7)();exports.composeEventBuilder=t,exports.createService=n,exports.generateID=i,exports.remap=r;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require(`uuidv7`);const t=t=>{let{AggregateType:n,EventName:r,AggregateIdentifier:i=()=>(0,e.uuidv7)(),EventIdentifier:a=()=>(0,e.uuidv7)()}=t;return({aggregateID:e,payloads:t,_metadata:o,_version:s,_createdBy:c,...l})=>({...l,_id:a(),name:r,aggregateType:n,aggregateID:e??i(),payloads:t,_version:s,_createdBy:c,_createdAt:new Date,_metadata:o??{}})},n=()=>{let e=new Map,t=(e,t)=>`${e}:${t}`;return{register:n=>{let r=t(n.type,n.name),i=e.get(r)||[];e.set(r,[...i,n])},resolve:(n,r)=>e.get(t(n,r))||[]}},r=e=>{let{EventStore:t,Projections:r,Reactions:i,onReactionError:a}=e,o=n(),s=n();return r.forEach(e=>o.register(e)),i.forEach(e=>s.register(e)),{async dispatch(e,n){try{await t.append(e);let r=o.resolve(e.aggregateType,e.name);await Promise.all(r.map(t=>t.project(e))),s.resolve(e.aggregateType,e.name).forEach(t=>{t.on(e).catch(n=>{let r=n instanceof Error?n:Error(String(n));a&&a({reactionName:t.name,eventName:e.name,eventID:e._id,error:r})})}),n?.()}catch(e){let t=e instanceof Error?e:Error(String(e));throw n?.(t),t}}}},i=(...e)=>e.flatMap(e=>Object.values(e)),a=()=>(0,e.uuidv7)();exports.composeEventBuilder=t,exports.createService=r,exports.generateID=a,exports.remap=i;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":[],"sources":["../src/composeEventBuilder.ts","../src/createService.ts","../src/util.ts"],"sourcesContent":["import { uuidv7 } from \"uuidv7\";\r\nimport { IEvent } from \"./core/IEvent\";\r\n\r\nexport const composeEventBuilder = <T extends IEvent>(definitions: {\r\n EventName: string;\r\n AggregateType: string;\r\n AggregateIdentifier?: () => string;\r\n EventIdentifier?: () => string;\r\n}) => {\r\n const {\r\n AggregateType,\r\n EventName,\r\n AggregateIdentifier = () => uuidv7(),\r\n EventIdentifier = () => uuidv7(),\r\n } = definitions;\r\n\r\n return ({\r\n aggregateID,\r\n payloads,\r\n _metadata,\r\n _version,\r\n _createdBy,\r\n ...others\r\n }: Omit<T, \"_id\" | \"name\" | \"aggregateID\" | \"aggregateType\" | \"_createdAt\" | \"_metadata\"> & {\r\n aggregateID?: string;\r\n _metadata?: T[\"_metadata\"];\r\n }): T => ({\r\n ...others,\r\n _id: EventIdentifier(),\r\n name: EventName,\r\n aggregateType: AggregateType,\r\n aggregateID: aggregateID ?? AggregateIdentifier(),\r\n payloads,\r\n _version,\r\n _createdBy,\r\n _createdAt: new Date(),\r\n _metadata: _metadata ?? ({} as T[\"_metadata\"]),\r\n } as T);\r\n};\r\n","// src/createService.ts\r\n\r\nimport { IEventStore } from \"./core/IEventStore\";\r\nimport { IProjection } from \"./core/IProjection\";\r\nimport { IReaction } from \"./core/IReaction\";\r\nimport { IReactionError } from \"./core/IReactionError\";\r\nimport { IService } from \"./IService\";\r\n\r\nexport const createService = (definition: {\r\n EventStore: IEventStore;\r\n Projections: IProjection[];\r\n Reactions: IReaction[];\r\n onReactionError?: (context: IReactionError) => void;\r\n}): IService => {\r\n const { EventStore, Projections, Reactions, onReactionError } = definition;\r\n\r\n // Group Projections by Event Name (Supports One-to-Many)\r\n const PROJECTION_MAP = Projections.reduce((result, projection) => {\r\n const list = result[projection.name] || [];\r\n list.push(projection);\r\n result[projection.name] = list;\r\n\r\n return result;\r\n }, {} as Record<string, IProjection[]>);\r\n\r\n const REACTION_MAP = Reactions.reduce((result, reaction) => {\r\n const list = result[reaction.name] || [];\r\n list.push(reaction);\r\n result[reaction.name] = list;\r\n\r\n return result;\r\n }, {} as Record<string, IReaction[]>);\r\n\r\n return {\r\n async dispatch(event, afterHandler): Promise<void> {\r\n try {\r\n await EventStore.append(event);\r\n\r\n const projections = PROJECTION_MAP[event.name] || [];\r\n await Promise.all(projections.map((p) => p.project(event)));\r\n\r\n const reactions = REACTION_MAP[event.name] || [];\r\n reactions.forEach((r) => {\r\n r.on(event).catch((error) => {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n if (onReactionError) {\r\n onReactionError({\r\n reactionName: r.name,\r\n eventName: event.name,\r\n eventID: event._id,\r\n error: wrappedError,\r\n });\r\n }\r\n });\r\n });\r\n\r\n // Resolve successful dispatch immediately after state is sync'd\r\n afterHandler?.();\r\n } catch (error) {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n afterHandler?.(wrappedError);\r\n throw wrappedError;\r\n }\r\n },\r\n };\r\n};\r\n","import { uuidv7 } from \"uuidv7\";\r\n\r\nexport const remap = <T>(...objs: Record<string, T>[]): T[] =>\r\n objs.flatMap(obj => Object.values(obj));\r\n\r\nexport const generateID = (): string => uuidv7();\r\n"],"mappings":"2FAGA,MAAa,EAAyC,GAKhD,CACJ,GAAM,CACJ,gBACA,YACA,2BAAA,EAAA,EAAA,SAAoC,CACpC,uBAAA,EAAA,EAAA,SAAgC,EAC9B,EAEJ,OAAQ,CACN,cACA,WACA,YACA,WACA,aACA,GAAG,MAIK,CACR,GAAG,EACH,IAAK,GAAiB,CACtB,KAAM,EACN,cAAe,EACf,YAAa,GAAe,GAAqB,CACjD,WACA,WACA,aACA,WAAY,IAAI,KAChB,UAAW,GAAc,EAAE,CAC5B,GC7BU,EAAiB,GAKd,CACd,GAAM,CAAE,aAAY,cAAa,YAAW,mBAAoB,EAG1D,EAAiB,EAAY,QAAQ,EAAQ,IAAe,CAChE,IAAM,EAAO,EAAO,EAAW,OAAS,EAAE,CAI1C,OAHA,EAAK,KAAK,EAAW,CACrB,EAAO,EAAW,MAAQ,EAEnB,GACN,EAAE,CAAkC,CAEjC,EAAe,EAAU,QAAQ,EAAQ,IAAa,CAC1D,IAAM,EAAO,EAAO,EAAS,OAAS,EAAE,CAIxC,OAHA,EAAK,KAAK,EAAS,CACnB,EAAO,EAAS,MAAQ,EAEjB,GACN,EAAE,CAAgC,CAErC,MAAO,CACL,MAAM,SAAS,EAAO,EAA6B,CACjD,GAAI,CACF,MAAM,EAAW,OAAO,EAAM,CAE9B,IAAM,EAAc,EAAe,EAAM,OAAS,EAAE,CACpD,MAAM,QAAQ,IAAI,EAAY,IAAK,GAAM,EAAE,QAAQ,EAAM,CAAC,CAAC,EAEzC,EAAa,EAAM,OAAS,EAAE,EACtC,QAAS,GAAM,CACvB,EAAE,GAAG,EAAM,CAAC,MAAO,GAAU,CAC3B,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAC1E,GACF,EAAgB,CACd,aAAc,EAAE,KAChB,UAAW,EAAM,KACjB,QAAS,EAAM,IACf,MAAO,EACR,CAAC,EAEJ,EACF,CAGF,KAAgB,OACT,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAE9E,MADA,IAAe,EAAa,CACtB,IAGX,EC9DU,GAAY,GAAG,IAC1B,EAAK,QAAQ,GAAO,OAAO,OAAO,EAAI,CAAC,CAE5B,OAAA,EAAA,EAAA,SAAmC"}
1
+ {"version":3,"file":"index.cjs","names":[],"sources":["../src/composeEventBuilder.ts","../src/common/Mapper.ts","../src/createService.ts","../src/util.ts"],"sourcesContent":["import { uuidv7 } from \"uuidv7\";\r\nimport { IEvent } from \"./core/IEvent\";\r\n\r\nexport const composeEventBuilder = <T extends IEvent>(definitions: {\r\n EventName: string;\r\n AggregateType: string;\r\n AggregateIdentifier?: () => string;\r\n EventIdentifier?: () => string;\r\n}) => {\r\n const {\r\n AggregateType,\r\n EventName,\r\n AggregateIdentifier = () => uuidv7(),\r\n EventIdentifier = () => uuidv7(),\r\n } = definitions;\r\n\r\n return ({\r\n aggregateID,\r\n payloads,\r\n _metadata,\r\n _version,\r\n _createdBy,\r\n ...others\r\n }: Omit<T, \"_id\" | \"name\" | \"aggregateID\" | \"aggregateType\" | \"_createdAt\" | \"_metadata\"> & {\r\n aggregateID?: string;\r\n _metadata?: T[\"_metadata\"];\r\n }): T => ({\r\n ...others,\r\n _id: EventIdentifier(),\r\n name: EventName,\r\n aggregateType: AggregateType,\r\n aggregateID: aggregateID ?? AggregateIdentifier(),\r\n payloads,\r\n _version,\r\n _createdBy,\r\n _createdAt: new Date(),\r\n _metadata: _metadata ?? ({} as T[\"_metadata\"]),\r\n } as T);\r\n};\r\n","// src/common/Mapper.ts\r\n\r\nexport const Mapper = <T extends { type: string; name: string; }>(): {\r\n register: (component: T) => void;\r\n resolve: (type: string, name: string) => T[];\r\n} => {\r\n const registry = new Map<string, T[]>();\r\n const toKey = (type: string, name: string): string => `${type}:${name}`;\r\n\r\n return {\r\n register: (component: T) => {\r\n const key = toKey(component.type, component.name);\r\n const others = registry.get(key) || [];\r\n registry.set(key, [...others, component]);\r\n },\r\n resolve: (type: string, name: string): T[] =>\r\n registry.get(toKey(type, name)) || [],\r\n };\r\n};\r\n","// src/createService.ts\r\n\r\nimport { IEventStore } from \"./core/IEventStore\";\r\nimport { IProjection } from \"./core/IProjection\";\r\nimport { IReaction } from \"./core/IReaction\";\r\nimport { IReactionError } from \"./core/IReactionError\";\r\nimport { IService } from \"./IService\";\r\nimport { Mapper } from \"./common/Mapper\";\r\n\r\nexport const createService = (definition: {\r\n EventStore: IEventStore;\r\n Projections: IProjection[];\r\n Reactions: IReaction[];\r\n onReactionError?: (context: IReactionError) => void;\r\n}): IService => {\r\n const { EventStore, Projections, Reactions, onReactionError } = definition;\r\n\r\n // Initialize Mappers inside the service to handle the internal grouping\r\n const ProjectionMapper = Mapper<IProjection>();\r\n const ReactionMapper = Mapper<IReaction>();\r\n\r\n // Register all provided components\r\n Projections.forEach((p) => ProjectionMapper.register(p));\r\n Reactions.forEach((r) => ReactionMapper.register(r));\r\n\r\n return {\r\n async dispatch(event, afterHandler): Promise<void> {\r\n try {\r\n await EventStore.append(event);\r\n\r\n const projections = ProjectionMapper.resolve(event.aggregateType, event.name);\r\n await Promise.all(projections.map((p) => p.project(event)));\r\n\r\n const reactions = ReactionMapper.resolve(event.aggregateType, event.name);\r\n reactions.forEach((r) => {\r\n r.on(event).catch((error) => {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n if (onReactionError) {\r\n onReactionError({\r\n reactionName: r.name,\r\n eventName: event.name,\r\n eventID: event._id,\r\n error: wrappedError,\r\n });\r\n }\r\n });\r\n });\r\n\r\n // Resolve successful dispatch immediately after state is sync'd\r\n afterHandler?.();\r\n } catch (error) {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n afterHandler?.(wrappedError);\r\n throw wrappedError;\r\n }\r\n },\r\n };\r\n};\r\n","import { uuidv7 } from \"uuidv7\";\r\n\r\nexport const remap = <T>(...objs: Record<string, T>[]): T[] =>\r\n objs.flatMap(obj => Object.values(obj));\r\n\r\nexport const generateID = (): string => uuidv7();\r\n"],"mappings":"2FAGA,MAAa,EAAyC,GAKhD,CACJ,GAAM,CACJ,gBACA,YACA,2BAAA,EAAA,EAAA,SAAoC,CACpC,uBAAA,EAAA,EAAA,SAAgC,EAC9B,EAEJ,OAAQ,CACN,cACA,WACA,YACA,WACA,aACA,GAAG,MAIK,CACR,GAAG,EACH,IAAK,GAAiB,CACtB,KAAM,EACN,cAAe,EACf,YAAa,GAAe,GAAqB,CACjD,WACA,WACA,aACA,WAAY,IAAI,KAChB,UAAW,GAAc,EAAE,CAC5B,GCnCU,MAGR,CACH,IAAM,EAAW,IAAI,IACf,GAAS,EAAc,IAAyB,GAAG,EAAK,GAAG,IAEjE,MAAO,CACL,SAAW,GAAiB,CAC1B,IAAM,EAAM,EAAM,EAAU,KAAM,EAAU,KAAK,CAC3C,EAAS,EAAS,IAAI,EAAI,EAAI,EAAE,CACtC,EAAS,IAAI,EAAK,CAAC,GAAG,EAAQ,EAAU,CAAC,EAE3C,SAAU,EAAc,IACtB,EAAS,IAAI,EAAM,EAAM,EAAK,CAAC,EAAI,EAAE,CACxC,ECRU,EAAiB,GAKd,CACd,GAAM,CAAE,aAAY,cAAa,YAAW,mBAAoB,EAG1D,EAAmB,GAAqB,CACxC,EAAiB,GAAmB,CAM1C,OAHA,EAAY,QAAS,GAAM,EAAiB,SAAS,EAAE,CAAC,CACxD,EAAU,QAAS,GAAM,EAAe,SAAS,EAAE,CAAC,CAE7C,CACL,MAAM,SAAS,EAAO,EAA6B,CACjD,GAAI,CACF,MAAM,EAAW,OAAO,EAAM,CAE9B,IAAM,EAAc,EAAiB,QAAQ,EAAM,cAAe,EAAM,KAAK,CAC7E,MAAM,QAAQ,IAAI,EAAY,IAAK,GAAM,EAAE,QAAQ,EAAM,CAAC,CAAC,CAEzC,EAAe,QAAQ,EAAM,cAAe,EAAM,KAC3D,CAAC,QAAS,GAAM,CACvB,EAAE,GAAG,EAAM,CAAC,MAAO,GAAU,CAC3B,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAC1E,GACF,EAAgB,CACd,aAAc,EAAE,KAChB,UAAW,EAAM,KACjB,QAAS,EAAM,IACf,MAAO,EACR,CAAC,EAEJ,EACF,CAGF,KAAgB,OACT,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAE9E,MADA,IAAe,EAAa,CACtB,IAGX,ECtDU,GAAY,GAAG,IAC1B,EAAK,QAAQ,GAAO,OAAO,OAAO,EAAI,CAAC,CAE5B,OAAA,EAAA,EAAA,SAAmC"}
package/dist/index.d.cts CHANGED
@@ -23,6 +23,7 @@ interface IEventStore {
23
23
  * Must be idempotent and focused solely on state representation.
24
24
  */
25
25
  interface IProjection<E extends IEvent = IEvent> {
26
+ type: string;
26
27
  name: string;
27
28
  project: (event: E) => Promise<void>;
28
29
  }
@@ -34,6 +35,7 @@ interface IProjection<E extends IEvent = IEvent> {
34
35
  * They do NOT update state directly; they trigger external actions or new events.
35
36
  */
36
37
  interface IReaction<E extends IEvent = IEvent> {
38
+ type: string;
37
39
  name: string;
38
40
  on: (event: E) => Promise<void>;
39
41
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.cts","names":[],"sources":["../src/core/IEvent.ts","../src/core/IEventStore.ts","../src/core/IProjection.ts","../src/core/IReaction.ts","../src/core/IReactionError.ts","../src/core/IReducer.ts","../src/IService.ts","../src/composeEventBuilder.ts","../src/createService.ts","../src/util.ts"],"mappings":";UAEiB,MAAA,kCAAwC,MAAA;EACvD,GAAA;EACA,IAAA;EACA,WAAA;EACA,aAAA;EACA,QAAA,EAAU,QAAA;EACV,QAAA;EACA,UAAA,EAAY,IAAA;EACZ,UAAA;EACA,SAAA,EAAW,QAAA;AAAA;;;UCPI,WAAA;EACf,MAAA,GAAS,KAAA,EAAO,MAAA,KAAW,OAAA;AAAA;;;ADH7B;;;;;AAAA,UEOiB,WAAA,WAAsB,MAAA,GAAS,MAAA;EAC9C,IAAA;EACA,OAAA,GAAU,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;AFTzB;;;;;AAAA,UGKiB,SAAA,WAAoB,MAAA,GAAS,MAAA;EAC5C,IAAA;EACA,EAAA,GAAK,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;UCTH,cAAA;EACf,YAAA;EACA,SAAA;EACA,OAAA;EACA,KAAA,EAAO,KAAA;AAAA;;;AJFT;;;;;AAAA,UKOiB,QAAA;EAAA,CACd,KAAA,EAAO,CAAA,EAAG,KAAA,EAAO,MAAA,GAAS,CAAA;AAAA;;;UCNZ,QAAA;ENFM;;;;;;EMSrB,QAAA,GAAW,KAAA,EAAO,MAAA,EAAQ,YAAA,IAAgB,KAAA,GAAQ,KAAA,cAAmB,OAAA;AAAA;;;cCR1D,mBAAA,aAAiC,MAAA,EAAQ,WAAA;EACpD,SAAA;EACA,aAAA;EACA,mBAAA;EACA,eAAA;AAAA;EASQ,WAAA;EAAA,QAAA;EAAA,SAAA;EAAA,QAAA;EAAA,UAAA;EAAA,GAAA;AAAA,GAOL,IAAA,CAAK,CAAA;EACN,WAAA;EACA,SAAA,GAAY,CAAA;AAAA,MACV,CAAA;;;cClBO,aAAA,GAAiB,UAAA;EAC5B,UAAA,EAAY,WAAA;EACZ,WAAA,EAAa,WAAA;EACb,SAAA,EAAW,SAAA;EACX,eAAA,IAAmB,OAAA,EAAS,cAAA;AAAA,MAC1B,QAAA;;;cCXS,KAAA,SAAe,IAAA,EAAM,MAAA,SAAe,CAAA,QAAO,CAAA;AAAA,cAG3C,UAAA"}
1
+ {"version":3,"file":"index.d.cts","names":[],"sources":["../src/core/IEvent.ts","../src/core/IEventStore.ts","../src/core/IProjection.ts","../src/core/IReaction.ts","../src/core/IReactionError.ts","../src/core/IReducer.ts","../src/IService.ts","../src/composeEventBuilder.ts","../src/createService.ts","../src/util.ts"],"mappings":";UAEiB,MAAA,kCAAwC,MAAA;EACvD,GAAA;EACA,IAAA;EACA,WAAA;EACA,aAAA;EACA,QAAA,EAAU,QAAA;EACV,QAAA;EACA,UAAA,EAAY,IAAA;EACZ,UAAA;EACA,SAAA,EAAW,QAAA;AAAA;;;UCPI,WAAA;EACf,MAAA,GAAS,KAAA,EAAO,MAAA,KAAW,OAAA;AAAA;;;ADH7B;;;;;AAAA,UEOiB,WAAA,WAAsB,MAAA,GAAS,MAAA;EAC9C,IAAA;EACA,IAAA;EACA,OAAA,GAAU,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;AFVzB;;;;;AAAA,UGKiB,SAAA,WAAoB,MAAA,GAAS,MAAA;EAC5C,IAAA;EACA,IAAA;EACA,EAAA,GAAK,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;UCVH,cAAA;EACf,YAAA;EACA,SAAA;EACA,OAAA;EACA,KAAA,EAAO,KAAA;AAAA;;;AJFT;;;;;AAAA,UKOiB,QAAA;EAAA,CACd,KAAA,EAAO,CAAA,EAAG,KAAA,EAAO,MAAA,GAAS,CAAA;AAAA;;;UCNZ,QAAA;ENFM;;;;;;EMSrB,QAAA,GAAW,KAAA,EAAO,MAAA,EAAQ,YAAA,IAAgB,KAAA,GAAQ,KAAA,cAAmB,OAAA;AAAA;;;cCR1D,mBAAA,aAAiC,MAAA,EAAQ,WAAA;EACpD,SAAA;EACA,aAAA;EACA,mBAAA;EACA,eAAA;AAAA;EASQ,WAAA;EAAA,QAAA;EAAA,SAAA;EAAA,QAAA;EAAA,UAAA;EAAA,GAAA;AAAA,GAOL,IAAA,CAAK,CAAA;EACN,WAAA;EACA,SAAA,GAAY,CAAA;AAAA,MACV,CAAA;;;cCjBO,aAAA,GAAiB,UAAA;EAC5B,UAAA,EAAY,WAAA;EACZ,WAAA,EAAa,WAAA;EACb,SAAA,EAAW,SAAA;EACX,eAAA,IAAmB,OAAA,EAAS,cAAA;AAAA,MAC1B,QAAA;;;cCZS,KAAA,SAAe,IAAA,EAAM,MAAA,SAAe,CAAA,QAAO,CAAA;AAAA,cAG3C,UAAA"}
package/dist/index.d.mts CHANGED
@@ -23,6 +23,7 @@ interface IEventStore {
23
23
  * Must be idempotent and focused solely on state representation.
24
24
  */
25
25
  interface IProjection<E extends IEvent = IEvent> {
26
+ type: string;
26
27
  name: string;
27
28
  project: (event: E) => Promise<void>;
28
29
  }
@@ -34,6 +35,7 @@ interface IProjection<E extends IEvent = IEvent> {
34
35
  * They do NOT update state directly; they trigger external actions or new events.
35
36
  */
36
37
  interface IReaction<E extends IEvent = IEvent> {
38
+ type: string;
37
39
  name: string;
38
40
  on: (event: E) => Promise<void>;
39
41
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.mts","names":[],"sources":["../src/core/IEvent.ts","../src/core/IEventStore.ts","../src/core/IProjection.ts","../src/core/IReaction.ts","../src/core/IReactionError.ts","../src/core/IReducer.ts","../src/IService.ts","../src/composeEventBuilder.ts","../src/createService.ts","../src/util.ts"],"mappings":";UAEiB,MAAA,kCAAwC,MAAA;EACvD,GAAA;EACA,IAAA;EACA,WAAA;EACA,aAAA;EACA,QAAA,EAAU,QAAA;EACV,QAAA;EACA,UAAA,EAAY,IAAA;EACZ,UAAA;EACA,SAAA,EAAW,QAAA;AAAA;;;UCPI,WAAA;EACf,MAAA,GAAS,KAAA,EAAO,MAAA,KAAW,OAAA;AAAA;;;ADH7B;;;;;AAAA,UEOiB,WAAA,WAAsB,MAAA,GAAS,MAAA;EAC9C,IAAA;EACA,OAAA,GAAU,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;AFTzB;;;;;AAAA,UGKiB,SAAA,WAAoB,MAAA,GAAS,MAAA;EAC5C,IAAA;EACA,EAAA,GAAK,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;UCTH,cAAA;EACf,YAAA;EACA,SAAA;EACA,OAAA;EACA,KAAA,EAAO,KAAA;AAAA;;;AJFT;;;;;AAAA,UKOiB,QAAA;EAAA,CACd,KAAA,EAAO,CAAA,EAAG,KAAA,EAAO,MAAA,GAAS,CAAA;AAAA;;;UCNZ,QAAA;ENFM;;;;;;EMSrB,QAAA,GAAW,KAAA,EAAO,MAAA,EAAQ,YAAA,IAAgB,KAAA,GAAQ,KAAA,cAAmB,OAAA;AAAA;;;cCR1D,mBAAA,aAAiC,MAAA,EAAQ,WAAA;EACpD,SAAA;EACA,aAAA;EACA,mBAAA;EACA,eAAA;AAAA;EASQ,WAAA;EAAA,QAAA;EAAA,SAAA;EAAA,QAAA;EAAA,UAAA;EAAA,GAAA;AAAA,GAOL,IAAA,CAAK,CAAA;EACN,WAAA;EACA,SAAA,GAAY,CAAA;AAAA,MACV,CAAA;;;cClBO,aAAA,GAAiB,UAAA;EAC5B,UAAA,EAAY,WAAA;EACZ,WAAA,EAAa,WAAA;EACb,SAAA,EAAW,SAAA;EACX,eAAA,IAAmB,OAAA,EAAS,cAAA;AAAA,MAC1B,QAAA;;;cCXS,KAAA,SAAe,IAAA,EAAM,MAAA,SAAe,CAAA,QAAO,CAAA;AAAA,cAG3C,UAAA"}
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../src/core/IEvent.ts","../src/core/IEventStore.ts","../src/core/IProjection.ts","../src/core/IReaction.ts","../src/core/IReactionError.ts","../src/core/IReducer.ts","../src/IService.ts","../src/composeEventBuilder.ts","../src/createService.ts","../src/util.ts"],"mappings":";UAEiB,MAAA,kCAAwC,MAAA;EACvD,GAAA;EACA,IAAA;EACA,WAAA;EACA,aAAA;EACA,QAAA,EAAU,QAAA;EACV,QAAA;EACA,UAAA,EAAY,IAAA;EACZ,UAAA;EACA,SAAA,EAAW,QAAA;AAAA;;;UCPI,WAAA;EACf,MAAA,GAAS,KAAA,EAAO,MAAA,KAAW,OAAA;AAAA;;;ADH7B;;;;;AAAA,UEOiB,WAAA,WAAsB,MAAA,GAAS,MAAA;EAC9C,IAAA;EACA,IAAA;EACA,OAAA,GAAU,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;AFVzB;;;;;AAAA,UGKiB,SAAA,WAAoB,MAAA,GAAS,MAAA;EAC5C,IAAA;EACA,IAAA;EACA,EAAA,GAAK,KAAA,EAAO,CAAA,KAAM,OAAA;AAAA;;;UCVH,cAAA;EACf,YAAA;EACA,SAAA;EACA,OAAA;EACA,KAAA,EAAO,KAAA;AAAA;;;AJFT;;;;;AAAA,UKOiB,QAAA;EAAA,CACd,KAAA,EAAO,CAAA,EAAG,KAAA,EAAO,MAAA,GAAS,CAAA;AAAA;;;UCNZ,QAAA;ENFM;;;;;;EMSrB,QAAA,GAAW,KAAA,EAAO,MAAA,EAAQ,YAAA,IAAgB,KAAA,GAAQ,KAAA,cAAmB,OAAA;AAAA;;;cCR1D,mBAAA,aAAiC,MAAA,EAAQ,WAAA;EACpD,SAAA;EACA,aAAA;EACA,mBAAA;EACA,eAAA;AAAA;EASQ,WAAA;EAAA,QAAA;EAAA,SAAA;EAAA,QAAA;EAAA,UAAA;EAAA,GAAA;AAAA,GAOL,IAAA,CAAK,CAAA;EACN,WAAA;EACA,SAAA,GAAY,CAAA;AAAA,MACV,CAAA;;;cCjBO,aAAA,GAAiB,UAAA;EAC5B,UAAA,EAAY,WAAA;EACZ,WAAA,EAAa,WAAA;EACb,SAAA,EAAW,SAAA;EACX,eAAA,IAAmB,OAAA,EAAS,cAAA;AAAA,MAC1B,QAAA;;;cCZS,KAAA,SAAe,IAAA,EAAM,MAAA,SAAe,CAAA,QAAO,CAAA;AAAA,cAG3C,UAAA"}
package/dist/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- import{uuidv7 as e}from"uuidv7";const t=t=>{let{AggregateType:n,EventName:r,AggregateIdentifier:i=()=>e(),EventIdentifier:a=()=>e()}=t;return({aggregateID:e,payloads:t,_metadata:o,_version:s,_createdBy:c,...l})=>({...l,_id:a(),name:r,aggregateType:n,aggregateID:e??i(),payloads:t,_version:s,_createdBy:c,_createdAt:new Date,_metadata:o??{}})},n=e=>{let{EventStore:t,Projections:n,Reactions:r,onReactionError:i}=e,a=n.reduce((e,t)=>{let n=e[t.name]||[];return n.push(t),e[t.name]=n,e},{}),o=r.reduce((e,t)=>{let n=e[t.name]||[];return n.push(t),e[t.name]=n,e},{});return{async dispatch(e,n){try{await t.append(e);let r=a[e.name]||[];await Promise.all(r.map(t=>t.project(e))),(o[e.name]||[]).forEach(t=>{t.on(e).catch(n=>{let r=n instanceof Error?n:Error(String(n));i&&i({reactionName:t.name,eventName:e.name,eventID:e._id,error:r})})}),n?.()}catch(e){let t=e instanceof Error?e:Error(String(e));throw n?.(t),t}}}},r=(...e)=>e.flatMap(e=>Object.values(e)),i=()=>e();export{t as composeEventBuilder,n as createService,i as generateID,r as remap};
1
+ import{uuidv7 as e}from"uuidv7";const t=t=>{let{AggregateType:n,EventName:r,AggregateIdentifier:i=()=>e(),EventIdentifier:a=()=>e()}=t;return({aggregateID:e,payloads:t,_metadata:o,_version:s,_createdBy:c,...l})=>({...l,_id:a(),name:r,aggregateType:n,aggregateID:e??i(),payloads:t,_version:s,_createdBy:c,_createdAt:new Date,_metadata:o??{}})},n=()=>{let e=new Map,t=(e,t)=>`${e}:${t}`;return{register:n=>{let r=t(n.type,n.name),i=e.get(r)||[];e.set(r,[...i,n])},resolve:(n,r)=>e.get(t(n,r))||[]}},r=e=>{let{EventStore:t,Projections:r,Reactions:i,onReactionError:a}=e,o=n(),s=n();return r.forEach(e=>o.register(e)),i.forEach(e=>s.register(e)),{async dispatch(e,n){try{await t.append(e);let r=o.resolve(e.aggregateType,e.name);await Promise.all(r.map(t=>t.project(e))),s.resolve(e.aggregateType,e.name).forEach(t=>{t.on(e).catch(n=>{let r=n instanceof Error?n:Error(String(n));a&&a({reactionName:t.name,eventName:e.name,eventID:e._id,error:r})})}),n?.()}catch(e){let t=e instanceof Error?e:Error(String(e));throw n?.(t),t}}}},i=(...e)=>e.flatMap(e=>Object.values(e)),a=()=>e();export{t as composeEventBuilder,r as createService,a as generateID,i as remap};
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","names":[],"sources":["../src/composeEventBuilder.ts","../src/createService.ts","../src/util.ts"],"sourcesContent":["import { uuidv7 } from \"uuidv7\";\r\nimport { IEvent } from \"./core/IEvent\";\r\n\r\nexport const composeEventBuilder = <T extends IEvent>(definitions: {\r\n EventName: string;\r\n AggregateType: string;\r\n AggregateIdentifier?: () => string;\r\n EventIdentifier?: () => string;\r\n}) => {\r\n const {\r\n AggregateType,\r\n EventName,\r\n AggregateIdentifier = () => uuidv7(),\r\n EventIdentifier = () => uuidv7(),\r\n } = definitions;\r\n\r\n return ({\r\n aggregateID,\r\n payloads,\r\n _metadata,\r\n _version,\r\n _createdBy,\r\n ...others\r\n }: Omit<T, \"_id\" | \"name\" | \"aggregateID\" | \"aggregateType\" | \"_createdAt\" | \"_metadata\"> & {\r\n aggregateID?: string;\r\n _metadata?: T[\"_metadata\"];\r\n }): T => ({\r\n ...others,\r\n _id: EventIdentifier(),\r\n name: EventName,\r\n aggregateType: AggregateType,\r\n aggregateID: aggregateID ?? AggregateIdentifier(),\r\n payloads,\r\n _version,\r\n _createdBy,\r\n _createdAt: new Date(),\r\n _metadata: _metadata ?? ({} as T[\"_metadata\"]),\r\n } as T);\r\n};\r\n","// src/createService.ts\r\n\r\nimport { IEventStore } from \"./core/IEventStore\";\r\nimport { IProjection } from \"./core/IProjection\";\r\nimport { IReaction } from \"./core/IReaction\";\r\nimport { IReactionError } from \"./core/IReactionError\";\r\nimport { IService } from \"./IService\";\r\n\r\nexport const createService = (definition: {\r\n EventStore: IEventStore;\r\n Projections: IProjection[];\r\n Reactions: IReaction[];\r\n onReactionError?: (context: IReactionError) => void;\r\n}): IService => {\r\n const { EventStore, Projections, Reactions, onReactionError } = definition;\r\n\r\n // Group Projections by Event Name (Supports One-to-Many)\r\n const PROJECTION_MAP = Projections.reduce((result, projection) => {\r\n const list = result[projection.name] || [];\r\n list.push(projection);\r\n result[projection.name] = list;\r\n\r\n return result;\r\n }, {} as Record<string, IProjection[]>);\r\n\r\n const REACTION_MAP = Reactions.reduce((result, reaction) => {\r\n const list = result[reaction.name] || [];\r\n list.push(reaction);\r\n result[reaction.name] = list;\r\n\r\n return result;\r\n }, {} as Record<string, IReaction[]>);\r\n\r\n return {\r\n async dispatch(event, afterHandler): Promise<void> {\r\n try {\r\n await EventStore.append(event);\r\n\r\n const projections = PROJECTION_MAP[event.name] || [];\r\n await Promise.all(projections.map((p) => p.project(event)));\r\n\r\n const reactions = REACTION_MAP[event.name] || [];\r\n reactions.forEach((r) => {\r\n r.on(event).catch((error) => {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n if (onReactionError) {\r\n onReactionError({\r\n reactionName: r.name,\r\n eventName: event.name,\r\n eventID: event._id,\r\n error: wrappedError,\r\n });\r\n }\r\n });\r\n });\r\n\r\n // Resolve successful dispatch immediately after state is sync'd\r\n afterHandler?.();\r\n } catch (error) {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n afterHandler?.(wrappedError);\r\n throw wrappedError;\r\n }\r\n },\r\n };\r\n};\r\n","import { uuidv7 } from \"uuidv7\";\r\n\r\nexport const remap = <T>(...objs: Record<string, T>[]): T[] =>\r\n objs.flatMap(obj => Object.values(obj));\r\n\r\nexport const generateID = (): string => uuidv7();\r\n"],"mappings":"gCAGA,MAAa,EAAyC,GAKhD,CACJ,GAAM,CACJ,gBACA,YACA,0BAA4B,GAAQ,CACpC,sBAAwB,GAAQ,EAC9B,EAEJ,OAAQ,CACN,cACA,WACA,YACA,WACA,aACA,GAAG,MAIK,CACR,GAAG,EACH,IAAK,GAAiB,CACtB,KAAM,EACN,cAAe,EACf,YAAa,GAAe,GAAqB,CACjD,WACA,WACA,aACA,WAAY,IAAI,KAChB,UAAW,GAAc,EAAE,CAC5B,GC7BU,EAAiB,GAKd,CACd,GAAM,CAAE,aAAY,cAAa,YAAW,mBAAoB,EAG1D,EAAiB,EAAY,QAAQ,EAAQ,IAAe,CAChE,IAAM,EAAO,EAAO,EAAW,OAAS,EAAE,CAI1C,OAHA,EAAK,KAAK,EAAW,CACrB,EAAO,EAAW,MAAQ,EAEnB,GACN,EAAE,CAAkC,CAEjC,EAAe,EAAU,QAAQ,EAAQ,IAAa,CAC1D,IAAM,EAAO,EAAO,EAAS,OAAS,EAAE,CAIxC,OAHA,EAAK,KAAK,EAAS,CACnB,EAAO,EAAS,MAAQ,EAEjB,GACN,EAAE,CAAgC,CAErC,MAAO,CACL,MAAM,SAAS,EAAO,EAA6B,CACjD,GAAI,CACF,MAAM,EAAW,OAAO,EAAM,CAE9B,IAAM,EAAc,EAAe,EAAM,OAAS,EAAE,CACpD,MAAM,QAAQ,IAAI,EAAY,IAAK,GAAM,EAAE,QAAQ,EAAM,CAAC,CAAC,EAEzC,EAAa,EAAM,OAAS,EAAE,EACtC,QAAS,GAAM,CACvB,EAAE,GAAG,EAAM,CAAC,MAAO,GAAU,CAC3B,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAC1E,GACF,EAAgB,CACd,aAAc,EAAE,KAChB,UAAW,EAAM,KACjB,QAAS,EAAM,IACf,MAAO,EACR,CAAC,EAEJ,EACF,CAGF,KAAgB,OACT,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAE9E,MADA,IAAe,EAAa,CACtB,IAGX,EC9DU,GAAY,GAAG,IAC1B,EAAK,QAAQ,GAAO,OAAO,OAAO,EAAI,CAAC,CAE5B,MAA2B,GAAQ"}
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../src/composeEventBuilder.ts","../src/common/Mapper.ts","../src/createService.ts","../src/util.ts"],"sourcesContent":["import { uuidv7 } from \"uuidv7\";\r\nimport { IEvent } from \"./core/IEvent\";\r\n\r\nexport const composeEventBuilder = <T extends IEvent>(definitions: {\r\n EventName: string;\r\n AggregateType: string;\r\n AggregateIdentifier?: () => string;\r\n EventIdentifier?: () => string;\r\n}) => {\r\n const {\r\n AggregateType,\r\n EventName,\r\n AggregateIdentifier = () => uuidv7(),\r\n EventIdentifier = () => uuidv7(),\r\n } = definitions;\r\n\r\n return ({\r\n aggregateID,\r\n payloads,\r\n _metadata,\r\n _version,\r\n _createdBy,\r\n ...others\r\n }: Omit<T, \"_id\" | \"name\" | \"aggregateID\" | \"aggregateType\" | \"_createdAt\" | \"_metadata\"> & {\r\n aggregateID?: string;\r\n _metadata?: T[\"_metadata\"];\r\n }): T => ({\r\n ...others,\r\n _id: EventIdentifier(),\r\n name: EventName,\r\n aggregateType: AggregateType,\r\n aggregateID: aggregateID ?? AggregateIdentifier(),\r\n payloads,\r\n _version,\r\n _createdBy,\r\n _createdAt: new Date(),\r\n _metadata: _metadata ?? ({} as T[\"_metadata\"]),\r\n } as T);\r\n};\r\n","// src/common/Mapper.ts\r\n\r\nexport const Mapper = <T extends { type: string; name: string; }>(): {\r\n register: (component: T) => void;\r\n resolve: (type: string, name: string) => T[];\r\n} => {\r\n const registry = new Map<string, T[]>();\r\n const toKey = (type: string, name: string): string => `${type}:${name}`;\r\n\r\n return {\r\n register: (component: T) => {\r\n const key = toKey(component.type, component.name);\r\n const others = registry.get(key) || [];\r\n registry.set(key, [...others, component]);\r\n },\r\n resolve: (type: string, name: string): T[] =>\r\n registry.get(toKey(type, name)) || [],\r\n };\r\n};\r\n","// src/createService.ts\r\n\r\nimport { IEventStore } from \"./core/IEventStore\";\r\nimport { IProjection } from \"./core/IProjection\";\r\nimport { IReaction } from \"./core/IReaction\";\r\nimport { IReactionError } from \"./core/IReactionError\";\r\nimport { IService } from \"./IService\";\r\nimport { Mapper } from \"./common/Mapper\";\r\n\r\nexport const createService = (definition: {\r\n EventStore: IEventStore;\r\n Projections: IProjection[];\r\n Reactions: IReaction[];\r\n onReactionError?: (context: IReactionError) => void;\r\n}): IService => {\r\n const { EventStore, Projections, Reactions, onReactionError } = definition;\r\n\r\n // Initialize Mappers inside the service to handle the internal grouping\r\n const ProjectionMapper = Mapper<IProjection>();\r\n const ReactionMapper = Mapper<IReaction>();\r\n\r\n // Register all provided components\r\n Projections.forEach((p) => ProjectionMapper.register(p));\r\n Reactions.forEach((r) => ReactionMapper.register(r));\r\n\r\n return {\r\n async dispatch(event, afterHandler): Promise<void> {\r\n try {\r\n await EventStore.append(event);\r\n\r\n const projections = ProjectionMapper.resolve(event.aggregateType, event.name);\r\n await Promise.all(projections.map((p) => p.project(event)));\r\n\r\n const reactions = ReactionMapper.resolve(event.aggregateType, event.name);\r\n reactions.forEach((r) => {\r\n r.on(event).catch((error) => {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n if (onReactionError) {\r\n onReactionError({\r\n reactionName: r.name,\r\n eventName: event.name,\r\n eventID: event._id,\r\n error: wrappedError,\r\n });\r\n }\r\n });\r\n });\r\n\r\n // Resolve successful dispatch immediately after state is sync'd\r\n afterHandler?.();\r\n } catch (error) {\r\n const wrappedError = error instanceof Error ? error : new Error(String(error));\r\n afterHandler?.(wrappedError);\r\n throw wrappedError;\r\n }\r\n },\r\n };\r\n};\r\n","import { uuidv7 } from \"uuidv7\";\r\n\r\nexport const remap = <T>(...objs: Record<string, T>[]): T[] =>\r\n objs.flatMap(obj => Object.values(obj));\r\n\r\nexport const generateID = (): string => uuidv7();\r\n"],"mappings":"gCAGA,MAAa,EAAyC,GAKhD,CACJ,GAAM,CACJ,gBACA,YACA,0BAA4B,GAAQ,CACpC,sBAAwB,GAAQ,EAC9B,EAEJ,OAAQ,CACN,cACA,WACA,YACA,WACA,aACA,GAAG,MAIK,CACR,GAAG,EACH,IAAK,GAAiB,CACtB,KAAM,EACN,cAAe,EACf,YAAa,GAAe,GAAqB,CACjD,WACA,WACA,aACA,WAAY,IAAI,KAChB,UAAW,GAAc,EAAE,CAC5B,GCnCU,MAGR,CACH,IAAM,EAAW,IAAI,IACf,GAAS,EAAc,IAAyB,GAAG,EAAK,GAAG,IAEjE,MAAO,CACL,SAAW,GAAiB,CAC1B,IAAM,EAAM,EAAM,EAAU,KAAM,EAAU,KAAK,CAC3C,EAAS,EAAS,IAAI,EAAI,EAAI,EAAE,CACtC,EAAS,IAAI,EAAK,CAAC,GAAG,EAAQ,EAAU,CAAC,EAE3C,SAAU,EAAc,IACtB,EAAS,IAAI,EAAM,EAAM,EAAK,CAAC,EAAI,EAAE,CACxC,ECRU,EAAiB,GAKd,CACd,GAAM,CAAE,aAAY,cAAa,YAAW,mBAAoB,EAG1D,EAAmB,GAAqB,CACxC,EAAiB,GAAmB,CAM1C,OAHA,EAAY,QAAS,GAAM,EAAiB,SAAS,EAAE,CAAC,CACxD,EAAU,QAAS,GAAM,EAAe,SAAS,EAAE,CAAC,CAE7C,CACL,MAAM,SAAS,EAAO,EAA6B,CACjD,GAAI,CACF,MAAM,EAAW,OAAO,EAAM,CAE9B,IAAM,EAAc,EAAiB,QAAQ,EAAM,cAAe,EAAM,KAAK,CAC7E,MAAM,QAAQ,IAAI,EAAY,IAAK,GAAM,EAAE,QAAQ,EAAM,CAAC,CAAC,CAEzC,EAAe,QAAQ,EAAM,cAAe,EAAM,KAC3D,CAAC,QAAS,GAAM,CACvB,EAAE,GAAG,EAAM,CAAC,MAAO,GAAU,CAC3B,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAC1E,GACF,EAAgB,CACd,aAAc,EAAE,KAChB,UAAW,EAAM,KACjB,QAAS,EAAM,IACf,MAAO,EACR,CAAC,EAEJ,EACF,CAGF,KAAgB,OACT,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAY,MAAM,OAAO,EAAM,CAAC,CAE9E,MADA,IAAe,EAAa,CACtB,IAGX,ECtDU,GAAY,GAAG,IAC1B,EAAK,QAAQ,GAAO,OAAO,OAAO,EAAI,CAAC,CAE5B,MAA2B,GAAQ"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "atomservices",
3
- "version": "0.14.1",
3
+ "version": "0.14.2",
4
4
  "type": "module",
5
5
  "main": "./dist/index.cjs",
6
6
  "module": "./dist/index.mjs",