@lssm/example.wealth-snapshot 0.0.0-canary-20251212004227

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/README.md ADDED
@@ -0,0 +1,11 @@
1
+ # @lssm/example.wealth-snapshot
2
+
3
+ Wealth Snapshot mini-app for accounts, assets, liabilities, and goals.
4
+
5
+ Highlights:
6
+
7
+ - Personal/household accounts with balances and currencies
8
+ - Assets & liabilities with categories and valuations
9
+ - Net worth and indicators (runway, savings rate) derived from events
10
+ - Goals tracking with progress and target dates
11
+ - Notifications for threshold crossings and overdue goals
@@ -0,0 +1 @@
1
+ import{ScalarTypeEnum as e,defineSchemaModel as t}from"@lssm/lib.schema";import{defineCommand as n,defineQuery as r}from"@lssm/lib.contracts";const i=[`examples.wealth-snapshot`],a=t({name:`Account`,description:`Account model`,fields:{id:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},type:{type:e.String_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1},balance:{type:e.Float_unsecure(),isOptional:!1}}}),o=t({name:`Asset`,description:`Asset model`,fields:{id:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},category:{type:e.String_unsecure(),isOptional:!1},value:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1}}}),s=t({name:`Liability`,description:`Liability model`,fields:{id:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},category:{type:e.String_unsecure(),isOptional:!1},balance:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1}}}),c=t({name:`Goal`,description:`Goal model`,fields:{id:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},targetAmount:{type:e.Float_unsecure(),isOptional:!1},currentAmount:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1},status:{type:e.String_unsecure(),isOptional:!1}}}),l=t({name:`NetWorthSnapshot`,description:`Net worth snapshot model`,fields:{asOf:{type:e.DateTime(),isOptional:!1},totalAssets:{type:e.Float_unsecure(),isOptional:!1},totalLiabilities:{type:e.Float_unsecure(),isOptional:!1},netWorth:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1}}}),u=t({name:`CreateAccountInput`,description:`Create account input`,fields:{name:{type:e.String_unsecure(),isOptional:!1},type:{type:e.String_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!0},balance:{type:e.Float_unsecure(),isOptional:!0},orgId:{type:e.String_unsecure(),isOptional:!1}}}),d=t({name:`AddAssetInput`,description:`Add asset input`,fields:{accountId:{type:e.String_unsecure(),isOptional:!0},name:{type:e.String_unsecure(),isOptional:!1},category:{type:e.String_unsecure(),isOptional:!1},value:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!0},orgId:{type:e.String_unsecure(),isOptional:!1}}}),f=t({name:`AddLiabilityInput`,description:`Add liability input`,fields:{accountId:{type:e.String_unsecure(),isOptional:!0},name:{type:e.String_unsecure(),isOptional:!1},category:{type:e.String_unsecure(),isOptional:!1},balance:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!0},orgId:{type:e.String_unsecure(),isOptional:!1}}}),p=t({name:`UpdateGoalInput`,description:`Update goal progress`,fields:{goalId:{type:e.String_unsecure(),isOptional:!1},currentAmount:{type:e.Float_unsecure(),isOptional:!1},status:{type:e.String_unsecure(),isOptional:!0}}}),m=t({name:`CreateGoalInput`,description:`Create goal input`,fields:{name:{type:e.String_unsecure(),isOptional:!1},targetAmount:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!0},targetDate:{type:e.DateTime(),isOptional:!0},orgId:{type:e.String_unsecure(),isOptional:!1}}}),h=t({name:`NetWorthQueryInput`,description:`Filter for net worth snapshots`,fields:{orgId:{type:e.String_unsecure(),isOptional:!1},from:{type:e.DateTime(),isOptional:!0},to:{type:e.DateTime(),isOptional:!0}}}),g=n({meta:{name:`wealth.account.create`,version:1,stability:`stable`,owners:[...i],tags:[`wealth`,`account`,`create`],description:`Create a financial account.`,goal:`Track account balances.`,context:`Onboarding/import.`},io:{input:u,output:a},policy:{auth:`user`}}),_=n({meta:{name:`wealth.asset.add`,version:1,stability:`stable`,owners:[...i],tags:[`wealth`,`asset`,`add`],description:`Add an asset position.`,goal:`Track holdings.`,context:`Asset onboarding/update.`},io:{input:d,output:o},policy:{auth:`user`}}),v=n({meta:{name:`wealth.liability.add`,version:1,stability:`stable`,owners:[...i],tags:[`wealth`,`liability`,`add`],description:`Add a liability.`,goal:`Track debts.`,context:`Debt onboarding/update.`},io:{input:f,output:s},policy:{auth:`user`}}),y=n({meta:{name:`wealth.goal.create`,version:1,stability:`stable`,owners:[...i],tags:[`wealth`,`goal`,`create`],description:`Create a financial goal.`,goal:`Track progress toward goals.`,context:`Planning.`},io:{input:m,output:c},policy:{auth:`user`}}),b=n({meta:{name:`wealth.goal.update`,version:1,stability:`stable`,owners:[...i],tags:[`wealth`,`goal`,`update`],description:`Update goal progress.`,goal:`Keep progress current.`,context:`Periodic update.`},io:{input:p,output:c},policy:{auth:`user`}}),x=r({meta:{name:`wealth.networth.get`,version:1,stability:`stable`,owners:[...i],tags:[`wealth`,`networth`],description:`Get net worth snapshots for a period.`,goal:`Render charts and indicators.`,context:`Dashboard.`},io:{input:h,output:t({name:`NetWorthQueryOutput`,description:`Snapshots + latest indicators`,fields:{snapshots:{type:l,isArray:!0,isOptional:!1},latest:{type:l,isOptional:!0}}})},policy:{auth:`user`}});export{a as AccountModel,_ as AddAssetContract,v as AddLiabilityContract,o as AssetModel,g as CreateAccountContract,y as CreateGoalContract,x as GetNetWorthContract,c as GoalModel,s as LiabilityModel,l as NetWorthSnapshotModel,b as UpdateGoalContract};
@@ -0,0 +1 @@
1
+ import"./wealth-snapshot.docblock.js";
@@ -0,0 +1,49 @@
1
+ import{registerDocBlocks as e}from"@lssm/lib.contracts/docs";e([{id:`docs.examples.wealth-snapshot`,title:`Wealth Snapshot`,summary:`Simple wealth overview with accounts, assets, liabilities, goals, and net-worth snapshots.`,kind:`reference`,visibility:`public`,route:`/docs/examples/wealth-snapshot`,tags:[`finance`,`net-worth`,`goals`],body:`## Features
2
+
3
+ - Accounts with balances/currencies.
4
+ - Assets & liabilities categorized for net worth.
5
+ - Goals with target amounts/dates and status.
6
+ - Net worth snapshots for charting; events emitted for analytics.
7
+
8
+ ## Modules reused
9
+ - Identity/RBAC for scoping to household/org
10
+ - Notifications for threshold crossings/goal reminders
11
+ - Audit trail for financial changes
12
+
13
+ ## Presentations
14
+ - Dashboard, accounts list, assets list, liabilities list, goals list (React + Markdown targets).
15
+ `},{id:`docs.examples.wealth-snapshot.goal`,title:`Wealth Snapshot — Goal`,summary:`Why this personal/household finance template exists.`,kind:`goal`,visibility:`public`,route:`/docs/examples/wealth-snapshot/goal`,tags:[`finance`,`goal`],body:`## Why it matters
16
+ - Provides a regenerable net-worth and goals view without bespoke finance code.
17
+ - Keeps accounts/assets/liabilities/goals consistent across surfaces with PII care.
18
+
19
+ ## Business/Product goal
20
+ - Deliver clear net-worth visibility, goal tracking, and alerting for thresholds.
21
+ - Support safe regeneration while keeping currency/units explicit.
22
+
23
+ ## Success criteria
24
+ - Spec changes to assets/liabilities/goals regenerate UI/API/events cleanly.
25
+ - PII and sensitive values are marked and redacted where needed.`},{id:`docs.examples.wealth-snapshot.usage`,title:`Wealth Snapshot — Usage`,summary:`How to seed, extend, and regenerate wealth tracking safely.`,kind:`usage`,visibility:`public`,route:`/docs/examples/wealth-snapshot/usage`,tags:[`finance`,`usage`],body:`## Setup
26
+ 1) Seed (if provided) or add accounts/assets/liabilities/goals via UI.
27
+ 2) Configure Notifications for goal reminders/threshold alerts; Audit for changes.
28
+
29
+ ## Extend & regenerate
30
+ 1) Adjust schemas for asset classes, liability terms, goal metrics; keep currency/units explicit.
31
+ 2) Regenerate to update dashboards and events; mark PII paths (account numbers, holder names).
32
+ 3) Use Feature Flags to trial new indicators or alerting rules.
33
+
34
+ ## Guardrails
35
+ - Emit events for asset/liability/goal changes; log in Audit Trail.
36
+ - Redact sensitive identifiers in presentations.
37
+ - Keep calculations (net worth) transparent and driven by spec fields.`},{id:`docs.examples.wealth-snapshot.constraints`,title:`Wealth Snapshot — Constraints & Safety`,summary:`Internal guardrails for finance data, PII, and regeneration semantics.`,kind:`reference`,visibility:`internal`,route:`/docs/examples/wealth-snapshot/constraints`,tags:[`finance`,`constraints`,`internal`],body:`## Constraints
38
+ - Net worth and goal calculations must stay spec-driven; avoid hidden math.
39
+ - Events to emit: asset.created/updated, liability.created/updated, goal.created/updated, snapshot.recorded.
40
+ - Regeneration should not alter currency/unit semantics without explicit spec change.
41
+
42
+ ## PII & Sensitivity
43
+ - Mark account identifiers, holder names, and addresses as PII; redact in presentations.
44
+ - Avoid exposing raw balances in MCP/web without policy checks; prefer summaries.
45
+
46
+ ## Verification
47
+ - Add fixtures for currency/unit changes and snapshot calculations.
48
+ - Ensure Audit Trail covers all financial mutations; Notifications optional for goals/thresholds.
49
+ - Use Feature Flags for new indicators/alert rules; default safe/off.`}]);
@@ -0,0 +1 @@
1
+ import{defineEntity as e,defineEntityEnum as t,field as n,index as r}from"@lssm/lib.schema";const i=`lssm_wealth_snapshot`,a=t({name:`AccountType`,schema:i,values:[`CHECKING`,`SAVINGS`,`INVESTMENT`,`CREDIT_CARD`,`LOAN`],description:`Account categories for holdings and debts.`}),o=t({name:`AssetCategory`,schema:i,values:[`CASH`,`EQUITY`,`REAL_ESTATE`,`CRYPTO`,`OTHER`],description:`Asset categories.`}),s=t({name:`LiabilityCategory`,schema:i,values:[`CREDIT_CARD`,`LOAN`,`MORTGAGE`,`TAX`,`OTHER`],description:`Liability categories.`}),c=t({name:`GoalStatus`,schema:i,values:[`ACTIVE`,`ON_TRACK`,`AT_RISK`,`OFF_TRACK`,`COMPLETED`],description:`Goal health/status.`}),l=e({name:`Account`,description:`Financial account representing holdings or debts.`,schema:i,map:`account`,fields:{id:n.id({description:`Account ID`}),name:n.string({description:`Account name`}),type:n.enum(`AccountType`,{description:`Account type`}),currency:n.string({description:`Currency code`,default:`"USD"`}),balance:n.decimal({description:`Current balance`}),institution:n.string({description:`Institution`,isOptional:!0}),orgId:n.string({description:`Org/household id`}),ownerId:n.string({description:`Owner user id`,isOptional:!0}),createdAt:n.createdAt(),updatedAt:n.updatedAt()},enums:[a],indexes:[r.on([`orgId`]),r.on([`type`]),r.on([`ownerId`])]}),u=e({name:`Asset`,description:`Individual asset position.`,schema:i,map:`asset`,fields:{id:n.id({description:`Asset ID`}),accountId:n.foreignKey({description:`Holding account`,isOptional:!0}),name:n.string({description:`Asset name`}),category:n.enum(`AssetCategory`,{description:`Asset category`}),value:n.decimal({description:`Current value`}),currency:n.string({description:`Currency`,default:`"USD"`}),orgId:n.string({description:`Org/household id`}),metadata:n.json({description:`Metadata`,isOptional:!0}),updatedAt:n.updatedAt(),createdAt:n.createdAt(),account:n.belongsTo(`Account`,[`accountId`],[`id`],{onDelete:`SetNull`})},enums:[o],indexes:[r.on([`orgId`]),r.on([`category`])]}),d=e({name:`Liability`,description:`Debt or obligation.`,schema:i,map:`liability`,fields:{id:n.id({description:`Liability ID`}),accountId:n.foreignKey({description:`Liability account`,isOptional:!0}),name:n.string({description:`Liability name`}),category:n.enum(`LiabilityCategory`,{description:`Liability category`}),balance:n.decimal({description:`Outstanding balance`}),currency:n.string({description:`Currency`,default:`"USD"`}),interestRate:n.decimal({description:`Interest rate (e.g., 0.05 for 5%)`,isOptional:!0}),orgId:n.string({description:`Org/household id`}),metadata:n.json({description:`Metadata`,isOptional:!0}),updatedAt:n.updatedAt(),createdAt:n.createdAt(),account:n.belongsTo(`Account`,[`accountId`],[`id`],{onDelete:`SetNull`})},enums:[s],indexes:[r.on([`orgId`]),r.on([`category`])]}),f=e({name:`Goal`,description:`Financial goal with target amount/date.`,schema:i,map:`goal`,fields:{id:n.id({description:`Goal ID`}),name:n.string({description:`Goal name`}),targetAmount:n.decimal({description:`Target amount`}),currentAmount:n.decimal({description:`Current progress amount`,default:0}),currency:n.string({description:`Currency`,default:`"USD"`}),targetDate:n.dateTime({description:`Target completion date`,isOptional:!0}),status:n.enum(`GoalStatus`,{description:`Goal status`,default:`ACTIVE`}),orgId:n.string({description:`Org/household id`}),ownerId:n.string({description:`Owner user id`,isOptional:!0}),createdAt:n.createdAt(),updatedAt:n.updatedAt()},enums:[c],indexes:[r.on([`orgId`]),r.on([`status`]),r.on([`targetDate`])]}),p=e({name:`NetWorthSnapshot`,description:`Aggregated net worth snapshot for a date.`,schema:i,map:`networth_snapshot`,fields:{id:n.id({description:`Snapshot ID`}),asOf:n.dateTime({description:`Snapshot date`}),totalAssets:n.decimal({description:`Total assets`}),totalLiabilities:n.decimal({description:`Total liabilities`}),netWorth:n.decimal({description:`Net worth`}),currency:n.string({description:`Currency`,default:`"USD"`}),orgId:n.string({description:`Org/household id`}),createdAt:n.createdAt()},indexes:[r.unique([`orgId`,`asOf`],{name:`networth_unique`})]}),m=[l,u,d,f,p],h={moduleId:`@lssm/example.wealth-snapshot`,entities:m,enums:[a,o,s,c]};export{l as AccountEntity,a as AccountTypeEnum,o as AssetCategoryEnum,u as AssetEntity,f as GoalEntity,c as GoalStatusEnum,s as LiabilityCategoryEnum,d as LiabilityEntity,p as NetWorthSnapshotEntity,m as wealthSnapshotEntities,h as wealthSnapshotSchemaContribution};
package/dist/events.js ADDED
@@ -0,0 +1 @@
1
+ import{ScalarTypeEnum as e,defineSchemaModel as t}from"@lssm/lib.schema";import{defineEvent as n}from"@lssm/lib.contracts";const r=t({name:`AssetEventPayload`,description:`Payload for asset events`,fields:{assetId:{type:e.String_unsecure(),isOptional:!1},category:{type:e.String_unsecure(),isOptional:!1},value:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!1},timestamp:{type:e.DateTime(),isOptional:!1}}}),i=t({name:`LiabilityEventPayload`,description:`Payload for liability events`,fields:{liabilityId:{type:e.String_unsecure(),isOptional:!1},category:{type:e.String_unsecure(),isOptional:!1},balance:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!1},timestamp:{type:e.DateTime(),isOptional:!1}}}),a=t({name:`GoalEventPayload`,description:`Payload for goal events`,fields:{goalId:{type:e.String_unsecure(),isOptional:!1},status:{type:e.String_unsecure(),isOptional:!1},currentAmount:{type:e.Float_unsecure(),isOptional:!1},targetAmount:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!1},timestamp:{type:e.DateTime(),isOptional:!1}}}),o=n({name:`wealth.asset.added`,version:1,description:`An asset was added or updated.`,payload:r}),s=n({name:`wealth.liability.added`,version:1,description:`A liability was added or updated.`,payload:i}),c=n({name:`wealth.goal.updated`,version:1,description:`A goal was updated.`,payload:a}),l=n({name:`wealth.networth.snapshot_created`,version:1,description:`A net worth snapshot was generated.`,payload:t({name:`NetWorthSnapshotEventPayload`,description:`Net worth snapshot payload`,fields:{netWorth:{type:e.Float_unsecure(),isOptional:!1},totalAssets:{type:e.Float_unsecure(),isOptional:!1},totalLiabilities:{type:e.Float_unsecure(),isOptional:!1},currency:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!1},asOf:{type:e.DateTime(),isOptional:!1}}})}),u={AssetAddedEvent:o,LiabilityAddedEvent:s,GoalUpdatedEvent:c,NetWorthSnapshotCreatedEvent:l};export{o as AssetAddedEvent,c as GoalUpdatedEvent,s as LiabilityAddedEvent,l as NetWorthSnapshotCreatedEvent,u as WealthSnapshotEvents};
@@ -0,0 +1 @@
1
+ const e={meta:{key:`wealth-snapshot`,title:`Wealth Snapshot`,description:`Mini-app for accounts, assets, liabilities, goals, and net worth.`,domain:`finance`,owners:[`wealth-snapshot`],tags:[`finance`,`net-worth`,`goals`],stability:`experimental`},operations:[{name:`wealth.account.create`,version:1},{name:`wealth.asset.add`,version:1},{name:`wealth.liability.add`,version:1},{name:`wealth.goal.create`,version:1},{name:`wealth.goal.update`,version:1},{name:`wealth.networth.get`,version:1}],events:[{name:`wealth.asset.added`,version:1},{name:`wealth.liability.added`,version:1},{name:`wealth.goal.updated`,version:1},{name:`wealth.networth.snapshot_created`,version:1}],presentations:[{name:`wealth-snapshot.dashboard`,version:1},{name:`wealth-snapshot.accounts.list`,version:1},{name:`wealth-snapshot.assets.list`,version:1},{name:`wealth-snapshot.liabilities.list`,version:1},{name:`wealth-snapshot.goals.list`,version:1}],presentationsTargets:[{name:`wealth-snapshot.dashboard`,version:1,targets:[`react`,`markdown`]},{name:`wealth-snapshot.assets.list`,version:1,targets:[`react`,`markdown`]},{name:`wealth-snapshot.liabilities.list`,version:1,targets:[`react`,`markdown`]},{name:`wealth-snapshot.goals.list`,version:1,targets:[`react`,`markdown`]}],capabilities:{requires:[{key:`identity`,version:1},{key:`audit-trail`,version:1},{key:`notifications`,version:1}],provides:[{key:`accounts`,version:1},{key:`net-worth`,version:1},{key:`goals`,version:1}]}};export{e as WealthSnapshotFeature};
@@ -0,0 +1 @@
1
+ function e(){}export{e as registerWealthSnapshotHandlers};
package/dist/index.js ADDED
@@ -0,0 +1 @@
1
+ import{AssetAddedEvent as e,GoalUpdatedEvent as t,LiabilityAddedEvent as n,NetWorthSnapshotCreatedEvent as r,WealthSnapshotEvents as i}from"./events.js";import{WealthSnapshotFeature as a}from"./feature.js";import{AccountEntity as o,AccountTypeEnum as s,AssetCategoryEnum as c,AssetEntity as l,GoalEntity as u,GoalStatusEnum as d,LiabilityCategoryEnum as f,LiabilityEntity as p,NetWorthSnapshotEntity as m,wealthSnapshotEntities as h,wealthSnapshotSchemaContribution as g}from"./entities/index.js";import{AccountModel as _,AddAssetContract as v,AddLiabilityContract as y,AssetModel as b,CreateAccountContract as x,CreateGoalContract as S,GetNetWorthContract as C,GoalModel as w,LiabilityModel as T,NetWorthSnapshotModel as E,UpdateGoalContract as D}from"./contracts/index.js";import{WealthSnapshotPresentations as O}from"./presentations/index.js";import{registerWealthSnapshotHandlers as k}from"./handlers/index.js";import"./docs/index.js";import{identityRbacSchemaContribution as A}from"@lssm/lib.identity-rbac";import{auditTrailSchemaContribution as j}from"@lssm/module.audit-trail";import{notificationsSchemaContribution as M}from"@lssm/module.notifications";const N={modules:[A,j,M,g],provider:`postgresql`,outputPath:`./prisma/schema/generated.prisma`};export{o as AccountEntity,_ as AccountModel,s as AccountTypeEnum,v as AddAssetContract,y as AddLiabilityContract,e as AssetAddedEvent,c as AssetCategoryEnum,l as AssetEntity,b as AssetModel,x as CreateAccountContract,S as CreateGoalContract,C as GetNetWorthContract,u as GoalEntity,w as GoalModel,d as GoalStatusEnum,t as GoalUpdatedEvent,n as LiabilityAddedEvent,f as LiabilityCategoryEnum,p as LiabilityEntity,T as LiabilityModel,r as NetWorthSnapshotCreatedEvent,m as NetWorthSnapshotEntity,E as NetWorthSnapshotModel,D as UpdateGoalContract,i as WealthSnapshotEvents,a as WealthSnapshotFeature,O as WealthSnapshotPresentations,k as registerWealthSnapshotHandlers,N as schemaComposition,h as wealthSnapshotEntities,g as wealthSnapshotSchemaContribution};
@@ -0,0 +1 @@
1
+ const e=[`wealth-snapshot.dashboard`,`wealth-snapshot.accounts.list`,`wealth-snapshot.assets.list`,`wealth-snapshot.liabilities.list`,`wealth-snapshot.goals.list`];export{e as WealthSnapshotPresentations};
package/package.json ADDED
@@ -0,0 +1,65 @@
1
+ {
2
+ "name": "@lssm/example.wealth-snapshot",
3
+ "version": "0.0.0-canary-20251212004227",
4
+ "description": "Wealth Snapshot mini-app for accounts, assets, liabilities, and goals",
5
+ "main": "./dist/index.js",
6
+ "types": "./dist/index.d.ts",
7
+ "type": "module",
8
+ "scripts": {
9
+ "publish:pkg": "bun publish --tolerate-republish --ignore-scripts --verbose",
10
+ "build": "bun build:bundle && bun build:types",
11
+ "build:bundle": "tsdown",
12
+ "build:types": "tsc --noEmit",
13
+ "dev": "bun build:bundle --watch",
14
+ "clean": "rimraf dist .turbo",
15
+ "lint": "bun lint:fix",
16
+ "lint:fix": "eslint src --fix",
17
+ "lint:check": "eslint src"
18
+ },
19
+ "dependencies": {
20
+ "@lssm/lib.schema": "workspace:*",
21
+ "@lssm/lib.contracts": "workspace:*",
22
+ "@lssm/lib.bus": "workspace:*",
23
+ "@lssm/lib.identity-rbac": "workspace:*",
24
+ "@lssm/module.audit-trail": "workspace:*",
25
+ "@lssm/module.notifications": "workspace:*",
26
+ "zod": "^4.1.13"
27
+ },
28
+ "devDependencies": {
29
+ "@lssm/tool.typescript": "workspace:*",
30
+ "@lssm/tool.tsdown": "workspace:*",
31
+ "typescript": "^5.9.3"
32
+ },
33
+ "exports": {
34
+ ".": "./src/index.ts",
35
+ "./contracts": "./src/contracts/index.ts",
36
+ "./docs": "./src/docs/index.ts",
37
+ "./docs/wealth-snapshot.docblock": "./src/docs/wealth-snapshot.docblock.ts",
38
+ "./entities": "./src/entities/index.ts",
39
+ "./events": "./src/events.ts",
40
+ "./feature": "./src/feature.ts",
41
+ "./handlers": "./src/handlers/index.ts",
42
+ "./presentations": "./src/presentations/index.ts",
43
+ "./*": "./*"
44
+ },
45
+ "module": "./dist/index.js",
46
+ "files": [
47
+ "dist",
48
+ "README.md"
49
+ ],
50
+ "publishConfig": {
51
+ "access": "public",
52
+ "exports": {
53
+ ".": "./dist/index.js",
54
+ "./contracts": "./dist/contracts/index.js",
55
+ "./docs": "./dist/docs/index.js",
56
+ "./docs/wealth-snapshot.docblock": "./dist/docs/wealth-snapshot.docblock.js",
57
+ "./entities": "./dist/entities/index.js",
58
+ "./events": "./dist/events.js",
59
+ "./feature": "./dist/feature.js",
60
+ "./handlers": "./dist/handlers/index.js",
61
+ "./presentations": "./dist/presentations/index.js",
62
+ "./*": "./*"
63
+ }
64
+ }
65
+ }