@adonoustech/bacon-core 6.17.0 → 6.18.0

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.
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i-admin-client-detail.js","sourceRoot":"","sources":["../../../src/interfaces/i-admin-client-detail.ts"],"names":[],"mappings":"","sourcesContent":["import { IBaconClientChecklistItem } from \"./i-bacon-client-checklist-item\";\nimport { IClientAcctBusinessOwner } from \"./i-client-acct-business-owner\";\nimport { IAdminClientActionItem, IAdminClientService } from \"./i-admin-client\";\nimport { IActionItemV2 } from \"./i-action-item-v2\";\nimport { IClientMessage } from \"./i-client-message\";\n\n/**\n * Business information structure for client detail view\n */\nexport interface IAdminClientDetailBusinessInfo {\n    /** Legal business name */\n    legalBusinessName?: string;\n    /** IRS Tax ID / EIN */\n    irsTaxIdEIN?: string;\n    /** Business entity type (S-Corporation, LLC, etc.) */\n    businessEntityType?: string;\n    /** Date of incorporation - ISO date string */\n    dateOfIncorporation?: string;\n    /** Date of S-Corp election - ISO date string (S-Corps only) */\n    dateOfSCorpElection?: string;\n    /** State of incorporation (2-letter code) */\n    stateOfIncorporation?: string;\n    /** State tax ID */\n    stateTaxId?: string;\n    /** Client acquisition date - ISO date string */\n    clientAcquisitionDate?: string;\n}\n\n/**\n * Employee information structure for client detail view\n */\nexport interface IAdminClientDetailEmployeeInfo {\n    /** Number of shareholders on payroll (S-Corp/C-Corp only) */\n    shareholdersOnPayroll?: number;\n    /** Number of non-shareholder employees */\n    nonShareholderEmployees?: number;\n    /** B&O tax filing frequency */\n    boTaxFilingFrequency?: string;\n}\n\n/**\n * Admin configuration flags for client detail view\n */\nexport interface IAdminClientDetailAdminConfig {\n    /** Whether LHA provides payroll services for this client */\n    providesPayroll: boolean;\n    /** Whether LHA provides state tax filings (B&O) for this client */\n    providesStateTaxFilingsBnO: boolean;\n    /** Whether this is a business tax client */\n    isBusinessTaxClient: boolean;\n    /** Whether this is a personal tax client */\n    isPersonalTaxClient: boolean;\n}\n\n/**\n * Action items categorized by status for detail view (V1 - Legacy)\n */\nexport interface IAdminClientDetailActionItems {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IAdminClientActionItem[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IAdminClientActionItem[];\n    /** Total count of all action items */\n    total: number;\n}\n\n/**\n * V2 Action items categorized by status and category for detail view\n */\nexport interface IAdminClientDetailActionItemsV2 {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IActionItemV2[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IActionItemV2[];\n    /** Total count of all action items */\n    total: number;\n    /** Action items grouped by category */\n    byCategory: {\n        /** Action items with 'audit_cleanup' category */\n        auditCleanup: IActionItemV2[];\n        /** Action items with 'setup' category */\n        setup: IActionItemV2[];\n        /** Action items with no category */\n        uncategorized: IActionItemV2[];\n    };\n    /** Action items grouped by severity */\n    bySeverity: {\n        low: IActionItemV2[];\n        normal: IActionItemV2[];\n        high: IActionItemV2[];\n        critical: IActionItemV2[];\n    };\n}\n\n/**\n * Checklist summary for client detail view\n */\nexport interface IAdminClientDetailChecklist {\n    /** All checklist items */\n    items: IBaconClientChecklistItem[];\n    /** Count of completed items */\n    completedCount: number;\n    /** Total count of items */\n    totalCount: number;\n    /** Completion percentage (0-100) */\n    progressPercent: number;\n}\n\n/**\n * File sharing configuration for client detail view\n */\nexport interface IAdminClientDetailFileSharing {\n    /** Whether file sharing is enabled */\n    enabled: boolean;\n}\n\n/**\n * Intake form status for client detail view\n */\nexport interface IAdminClientDetailIntakeStatus {\n    /** Whether the intake form is complete */\n    isComplete: boolean;\n    /** ISO timestamp of when intake was submitted */\n    submittedAt?: string;\n    /** ISO timestamp of last modification */\n    lastModified?: string;\n}\n\n/**\n * Admin note for client detail view\n */\nexport interface IAdminClientNote {\n    /** Unique note identifier */\n    id: string;\n    /** Note text content */\n    text: string;\n    /** ISO timestamp when note was created */\n    createdAt: string;\n    /** Name of user who created the note */\n    createdBy: string;\n}\n\n/**\n * Structured detail view model for individual client\n * Used in the client detail panel/modal\n *\n * @description This interface provides a structured, organized view\n * of all client data for the detail panel. Data is transformed from\n * the raw IAdminClient format into logical groups for display.\n */\nexport interface IAdminClientDetail {\n    /** User unique identifier (Cognito sub) */\n    sub: string;\n\n    /** Client's federated identity ID for S3 access */\n    federatedIdentity: string;\n\n    /** Client display name */\n    name: string;\n\n    /** Client email address */\n    email: string;\n\n    /** Client phone number */\n    phone?: string;\n\n    /** Account status */\n    status: \"active\" | \"inactive\";\n\n    /** Business information from intake form */\n    businessInfo: IAdminClientDetailBusinessInfo;\n\n    /** Array of business owners from intake form */\n    businessOwners: IClientAcctBusinessOwner[];\n\n    /** Employee information from intake form */\n    employeeInfo: IAdminClientDetailEmployeeInfo;\n\n    /** Admin configuration flags */\n    adminConfig: IAdminClientDetailAdminConfig;\n\n    /** Client's subscribed services */\n    services: IAdminClientService[];\n\n    /** Total value of all subscribed services */\n    totalServiceValue: number;\n\n    /** Whether client has private pricing (service ID 'EXT00') */\n    hasPrivatePricing: boolean;\n\n    /** Action items organized by status (V1 - Legacy) */\n    actionItems: IAdminClientDetailActionItems;\n\n    /** V2 Action items organized by status, category, and severity */\n    actionItemsV2: IAdminClientDetailActionItemsV2;\n\n    /** Onboarding checklist summary */\n    checklist: IAdminClientDetailChecklist;\n\n    /** File sharing configuration */\n    fileSharing: IAdminClientDetailFileSharing;\n\n    /** Intake form submission status */\n    intakeStatus: IAdminClientDetailIntakeStatus;\n\n    /** Admin notes for this client */\n    notes: IAdminClientNote[];\n\n    /** Admin-to-client message history */\n    messages?: IClientMessage[];\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i-admin-client-detail.js","sourceRoot":"","sources":["../../../src/interfaces/i-admin-client-detail.ts"],"names":[],"mappings":"","sourcesContent":["import { IBaconClientChecklistItem } from \"./i-bacon-client-checklist-item\";\nimport { IClientAcctBusinessOwner } from \"./i-client-acct-business-owner\";\nimport { IAdminClientActionItem, IAdminClientService } from \"./i-admin-client\";\nimport { IActionItemV2 } from \"./i-action-item-v2\";\nimport { IClientMessage } from \"./i-client-message\";\n\n/**\n * Business information structure for client detail view\n */\nexport interface IAdminClientDetailBusinessInfo {\n    /** Legal business name */\n    legalBusinessName?: string;\n    /** IRS Tax ID / EIN */\n    irsTaxIdEIN?: string;\n    /** Business entity type (S-Corporation, LLC, etc.) */\n    businessEntityType?: string;\n    /** Date of incorporation - ISO date string */\n    dateOfIncorporation?: string;\n    /** Date of S-Corp election - ISO date string (S-Corps only) */\n    dateOfSCorpElection?: string;\n    /** State of incorporation (2-letter code) */\n    stateOfIncorporation?: string;\n    /** State tax ID */\n    stateTaxId?: string;\n    /** Client acquisition date - ISO date string */\n    clientAcquisitionDate?: string;\n}\n\n/**\n * Employee information structure for client detail view\n */\nexport interface IAdminClientDetailEmployeeInfo {\n    /** Number of shareholders on payroll (S-Corp/C-Corp only) */\n    shareholdersOnPayroll?: number;\n    /** Number of non-shareholder employees */\n    nonShareholderEmployees?: number;\n    /** B&O tax filing frequency */\n    boTaxFilingFrequency?: string;\n}\n\n/**\n * Admin configuration flags for client detail view\n */\nexport interface IAdminClientDetailAdminConfig {\n    /** Whether LHA provides payroll services for this client */\n    providesPayroll: boolean;\n    /** Whether LHA provides state tax filings (B&O) for this client */\n    providesStateTaxFilingsBnO: boolean;\n    /** Whether this is a business tax client */\n    isBusinessTaxClient: boolean;\n    /** Whether this is a personal tax client */\n    isPersonalTaxClient: boolean;\n}\n\n/**\n * Action items categorized by status for detail view (V1 - Legacy)\n */\nexport interface IAdminClientDetailActionItems {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IAdminClientActionItem[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IAdminClientActionItem[];\n    /** Total count of all action items */\n    total: number;\n}\n\n/**\n * V2 Action items categorized by status and category for detail view\n */\nexport interface IAdminClientDetailActionItemsV2 {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IActionItemV2[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IActionItemV2[];\n    /** Total count of all action items */\n    total: number;\n    /** Action items grouped by category */\n    byCategory: {\n        /** Action items with 'audit_cleanup' category */\n        auditCleanup: IActionItemV2[];\n        /** Action items with 'setup' category */\n        setup: IActionItemV2[];\n        /** Action items with no category */\n        uncategorized: IActionItemV2[];\n    };\n    /** Action items grouped by severity */\n    bySeverity: {\n        low: IActionItemV2[];\n        normal: IActionItemV2[];\n        high: IActionItemV2[];\n        critical: IActionItemV2[];\n    };\n}\n\n/**\n * Checklist summary for client detail view\n */\nexport interface IAdminClientDetailChecklist {\n    /** All checklist items */\n    items: IBaconClientChecklistItem[];\n    /** Count of completed items */\n    completedCount: number;\n    /** Total count of items */\n    totalCount: number;\n    /** Completion percentage (0-100) */\n    progressPercent: number;\n}\n\n/**\n * File sharing configuration for client detail view\n */\nexport interface IAdminClientDetailFileSharing {\n    /** Whether file sharing is enabled */\n    enabled: boolean;\n}\n\n/**\n * Intake form status for client detail view\n */\nexport interface IAdminClientDetailIntakeStatus {\n    /** Whether the intake form is complete */\n    isComplete: boolean;\n    /** ISO timestamp of when intake was submitted */\n    submittedAt?: string;\n    /** ISO timestamp of last modification */\n    lastModified?: string;\n}\n\n/**\n * Note category types for organization\n */\nexport type NoteCategory =\n    | \"general\"\n    | \"follow-up\"\n    | \"issue\"\n    | \"billing\"\n    | \"reminder\"\n    | \"compliance\";\n\n/**\n * Attachment metadata for admin notes\n */\nexport interface INoteAttachment {\n    /** Unique attachment identifier */\n    attachmentId: string;\n    /** Original file name */\n    fileName: string;\n    /** MIME type of the file */\n    mimeType: string;\n    /** File size in bytes */\n    fileSize: number;\n    /** S3 key path (stored in admin's federated identity space) */\n    s3Key: string;\n    /** ISO timestamp when attachment was uploaded */\n    uploadedAt: string;\n}\n\n/**\n * Admin note for client detail view\n */\nexport interface IAdminClientNote {\n    /** Unique note identifier */\n    id: string;\n    /** Note text content (supports HTML from rich text editor) */\n    text: string;\n    /** ISO timestamp when note was created */\n    createdAt: string;\n    /** Name of user who created the note */\n    createdBy: string;\n    /** Cognito sub of user who created the note */\n    createdBySub?: string;\n    /** Whether this note is pinned to the top */\n    pinned?: boolean;\n    /** ISO timestamp when note was pinned */\n    pinnedAt?: string;\n    /** Note category for organization */\n    category?: NoteCategory;\n    /** Custom tags for filtering */\n    tags?: string[];\n    /** File attachments (stored in admin's S3 space) */\n    attachments?: INoteAttachment[];\n    /** ISO timestamp of last update */\n    updatedAt?: string;\n    /** Name of user who last updated the note */\n    updatedBy?: string;\n}\n\n/**\n * Structured detail view model for individual client\n * Used in the client detail panel/modal\n *\n * @description This interface provides a structured, organized view\n * of all client data for the detail panel. Data is transformed from\n * the raw IAdminClient format into logical groups for display.\n */\nexport interface IAdminClientDetail {\n    /** User unique identifier (Cognito sub) */\n    sub: string;\n\n    /** Client's federated identity ID for S3 access */\n    federatedIdentity: string;\n\n    /** Client display name */\n    name: string;\n\n    /** Client email address */\n    email: string;\n\n    /** Client phone number */\n    phone?: string;\n\n    /** Account status */\n    status: \"active\" | \"inactive\";\n\n    /** Business information from intake form */\n    businessInfo: IAdminClientDetailBusinessInfo;\n\n    /** Array of business owners from intake form */\n    businessOwners: IClientAcctBusinessOwner[];\n\n    /** Employee information from intake form */\n    employeeInfo: IAdminClientDetailEmployeeInfo;\n\n    /** Admin configuration flags */\n    adminConfig: IAdminClientDetailAdminConfig;\n\n    /** Client's subscribed services */\n    services: IAdminClientService[];\n\n    /** Total value of all subscribed services */\n    totalServiceValue: number;\n\n    /** Whether client has private pricing (service ID 'EXT00') */\n    hasPrivatePricing: boolean;\n\n    /** Action items organized by status (V1 - Legacy) */\n    actionItems: IAdminClientDetailActionItems;\n\n    /** V2 Action items organized by status, category, and severity */\n    actionItemsV2: IAdminClientDetailActionItemsV2;\n\n    /** Onboarding checklist summary */\n    checklist: IAdminClientDetailChecklist;\n\n    /** File sharing configuration */\n    fileSharing: IAdminClientDetailFileSharing;\n\n    /** Intake form submission status */\n    intakeStatus: IAdminClientDetailIntakeStatus;\n\n    /** Admin notes for this client */\n    notes: IAdminClientNote[];\n\n    /** Admin-to-client message history */\n    messages?: IClientMessage[];\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i-admin-client-detail.js","sourceRoot":"","sources":["../../../src/interfaces/i-admin-client-detail.ts"],"names":[],"mappings":"","sourcesContent":["import { IBaconClientChecklistItem } from \"./i-bacon-client-checklist-item\";\nimport { IClientAcctBusinessOwner } from \"./i-client-acct-business-owner\";\nimport { IAdminClientActionItem, IAdminClientService } from \"./i-admin-client\";\nimport { IActionItemV2 } from \"./i-action-item-v2\";\nimport { IClientMessage } from \"./i-client-message\";\n\n/**\n * Business information structure for client detail view\n */\nexport interface IAdminClientDetailBusinessInfo {\n    /** Legal business name */\n    legalBusinessName?: string;\n    /** IRS Tax ID / EIN */\n    irsTaxIdEIN?: string;\n    /** Business entity type (S-Corporation, LLC, etc.) */\n    businessEntityType?: string;\n    /** Date of incorporation - ISO date string */\n    dateOfIncorporation?: string;\n    /** Date of S-Corp election - ISO date string (S-Corps only) */\n    dateOfSCorpElection?: string;\n    /** State of incorporation (2-letter code) */\n    stateOfIncorporation?: string;\n    /** State tax ID */\n    stateTaxId?: string;\n    /** Client acquisition date - ISO date string */\n    clientAcquisitionDate?: string;\n}\n\n/**\n * Employee information structure for client detail view\n */\nexport interface IAdminClientDetailEmployeeInfo {\n    /** Number of shareholders on payroll (S-Corp/C-Corp only) */\n    shareholdersOnPayroll?: number;\n    /** Number of non-shareholder employees */\n    nonShareholderEmployees?: number;\n    /** B&O tax filing frequency */\n    boTaxFilingFrequency?: string;\n}\n\n/**\n * Admin configuration flags for client detail view\n */\nexport interface IAdminClientDetailAdminConfig {\n    /** Whether LHA provides payroll services for this client */\n    providesPayroll: boolean;\n    /** Whether LHA provides state tax filings (B&O) for this client */\n    providesStateTaxFilingsBnO: boolean;\n    /** Whether this is a business tax client */\n    isBusinessTaxClient: boolean;\n    /** Whether this is a personal tax client */\n    isPersonalTaxClient: boolean;\n}\n\n/**\n * Action items categorized by status for detail view (V1 - Legacy)\n */\nexport interface IAdminClientDetailActionItems {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IAdminClientActionItem[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IAdminClientActionItem[];\n    /** Total count of all action items */\n    total: number;\n}\n\n/**\n * V2 Action items categorized by status and category for detail view\n */\nexport interface IAdminClientDetailActionItemsV2 {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IActionItemV2[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IActionItemV2[];\n    /** Total count of all action items */\n    total: number;\n    /** Action items grouped by category */\n    byCategory: {\n        /** Action items with 'audit_cleanup' category */\n        auditCleanup: IActionItemV2[];\n        /** Action items with 'setup' category */\n        setup: IActionItemV2[];\n        /** Action items with no category */\n        uncategorized: IActionItemV2[];\n    };\n    /** Action items grouped by severity */\n    bySeverity: {\n        low: IActionItemV2[];\n        normal: IActionItemV2[];\n        high: IActionItemV2[];\n        critical: IActionItemV2[];\n    };\n}\n\n/**\n * Checklist summary for client detail view\n */\nexport interface IAdminClientDetailChecklist {\n    /** All checklist items */\n    items: IBaconClientChecklistItem[];\n    /** Count of completed items */\n    completedCount: number;\n    /** Total count of items */\n    totalCount: number;\n    /** Completion percentage (0-100) */\n    progressPercent: number;\n}\n\n/**\n * File sharing configuration for client detail view\n */\nexport interface IAdminClientDetailFileSharing {\n    /** Whether file sharing is enabled */\n    enabled: boolean;\n}\n\n/**\n * Intake form status for client detail view\n */\nexport interface IAdminClientDetailIntakeStatus {\n    /** Whether the intake form is complete */\n    isComplete: boolean;\n    /** ISO timestamp of when intake was submitted */\n    submittedAt?: string;\n    /** ISO timestamp of last modification */\n    lastModified?: string;\n}\n\n/**\n * Admin note for client detail view\n */\nexport interface IAdminClientNote {\n    /** Unique note identifier */\n    id: string;\n    /** Note text content */\n    text: string;\n    /** ISO timestamp when note was created */\n    createdAt: string;\n    /** Name of user who created the note */\n    createdBy: string;\n}\n\n/**\n * Structured detail view model for individual client\n * Used in the client detail panel/modal\n *\n * @description This interface provides a structured, organized view\n * of all client data for the detail panel. Data is transformed from\n * the raw IAdminClient format into logical groups for display.\n */\nexport interface IAdminClientDetail {\n    /** User unique identifier (Cognito sub) */\n    sub: string;\n\n    /** Client's federated identity ID for S3 access */\n    federatedIdentity: string;\n\n    /** Client display name */\n    name: string;\n\n    /** Client email address */\n    email: string;\n\n    /** Client phone number */\n    phone?: string;\n\n    /** Account status */\n    status: \"active\" | \"inactive\";\n\n    /** Business information from intake form */\n    businessInfo: IAdminClientDetailBusinessInfo;\n\n    /** Array of business owners from intake form */\n    businessOwners: IClientAcctBusinessOwner[];\n\n    /** Employee information from intake form */\n    employeeInfo: IAdminClientDetailEmployeeInfo;\n\n    /** Admin configuration flags */\n    adminConfig: IAdminClientDetailAdminConfig;\n\n    /** Client's subscribed services */\n    services: IAdminClientService[];\n\n    /** Total value of all subscribed services */\n    totalServiceValue: number;\n\n    /** Whether client has private pricing (service ID 'EXT00') */\n    hasPrivatePricing: boolean;\n\n    /** Action items organized by status (V1 - Legacy) */\n    actionItems: IAdminClientDetailActionItems;\n\n    /** V2 Action items organized by status, category, and severity */\n    actionItemsV2: IAdminClientDetailActionItemsV2;\n\n    /** Onboarding checklist summary */\n    checklist: IAdminClientDetailChecklist;\n\n    /** File sharing configuration */\n    fileSharing: IAdminClientDetailFileSharing;\n\n    /** Intake form submission status */\n    intakeStatus: IAdminClientDetailIntakeStatus;\n\n    /** Admin notes for this client */\n    notes: IAdminClientNote[];\n\n    /** Admin-to-client message history */\n    messages?: IClientMessage[];\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i-admin-client-detail.js","sourceRoot":"","sources":["../../../src/interfaces/i-admin-client-detail.ts"],"names":[],"mappings":"","sourcesContent":["import { IBaconClientChecklistItem } from \"./i-bacon-client-checklist-item\";\nimport { IClientAcctBusinessOwner } from \"./i-client-acct-business-owner\";\nimport { IAdminClientActionItem, IAdminClientService } from \"./i-admin-client\";\nimport { IActionItemV2 } from \"./i-action-item-v2\";\nimport { IClientMessage } from \"./i-client-message\";\n\n/**\n * Business information structure for client detail view\n */\nexport interface IAdminClientDetailBusinessInfo {\n    /** Legal business name */\n    legalBusinessName?: string;\n    /** IRS Tax ID / EIN */\n    irsTaxIdEIN?: string;\n    /** Business entity type (S-Corporation, LLC, etc.) */\n    businessEntityType?: string;\n    /** Date of incorporation - ISO date string */\n    dateOfIncorporation?: string;\n    /** Date of S-Corp election - ISO date string (S-Corps only) */\n    dateOfSCorpElection?: string;\n    /** State of incorporation (2-letter code) */\n    stateOfIncorporation?: string;\n    /** State tax ID */\n    stateTaxId?: string;\n    /** Client acquisition date - ISO date string */\n    clientAcquisitionDate?: string;\n}\n\n/**\n * Employee information structure for client detail view\n */\nexport interface IAdminClientDetailEmployeeInfo {\n    /** Number of shareholders on payroll (S-Corp/C-Corp only) */\n    shareholdersOnPayroll?: number;\n    /** Number of non-shareholder employees */\n    nonShareholderEmployees?: number;\n    /** B&O tax filing frequency */\n    boTaxFilingFrequency?: string;\n}\n\n/**\n * Admin configuration flags for client detail view\n */\nexport interface IAdminClientDetailAdminConfig {\n    /** Whether LHA provides payroll services for this client */\n    providesPayroll: boolean;\n    /** Whether LHA provides state tax filings (B&O) for this client */\n    providesStateTaxFilingsBnO: boolean;\n    /** Whether this is a business tax client */\n    isBusinessTaxClient: boolean;\n    /** Whether this is a personal tax client */\n    isPersonalTaxClient: boolean;\n}\n\n/**\n * Action items categorized by status for detail view (V1 - Legacy)\n */\nexport interface IAdminClientDetailActionItems {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IAdminClientActionItem[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IAdminClientActionItem[];\n    /** Total count of all action items */\n    total: number;\n}\n\n/**\n * V2 Action items categorized by status and category for detail view\n */\nexport interface IAdminClientDetailActionItemsV2 {\n    /** Action items with lifeCycle !== 'Completed' */\n    pending: IActionItemV2[];\n    /** Action items with lifeCycle === 'Completed' */\n    completed: IActionItemV2[];\n    /** Total count of all action items */\n    total: number;\n    /** Action items grouped by category */\n    byCategory: {\n        /** Action items with 'audit_cleanup' category */\n        auditCleanup: IActionItemV2[];\n        /** Action items with 'setup' category */\n        setup: IActionItemV2[];\n        /** Action items with no category */\n        uncategorized: IActionItemV2[];\n    };\n    /** Action items grouped by severity */\n    bySeverity: {\n        low: IActionItemV2[];\n        normal: IActionItemV2[];\n        high: IActionItemV2[];\n        critical: IActionItemV2[];\n    };\n}\n\n/**\n * Checklist summary for client detail view\n */\nexport interface IAdminClientDetailChecklist {\n    /** All checklist items */\n    items: IBaconClientChecklistItem[];\n    /** Count of completed items */\n    completedCount: number;\n    /** Total count of items */\n    totalCount: number;\n    /** Completion percentage (0-100) */\n    progressPercent: number;\n}\n\n/**\n * File sharing configuration for client detail view\n */\nexport interface IAdminClientDetailFileSharing {\n    /** Whether file sharing is enabled */\n    enabled: boolean;\n}\n\n/**\n * Intake form status for client detail view\n */\nexport interface IAdminClientDetailIntakeStatus {\n    /** Whether the intake form is complete */\n    isComplete: boolean;\n    /** ISO timestamp of when intake was submitted */\n    submittedAt?: string;\n    /** ISO timestamp of last modification */\n    lastModified?: string;\n}\n\n/**\n * Note category types for organization\n */\nexport type NoteCategory =\n    | \"general\"\n    | \"follow-up\"\n    | \"issue\"\n    | \"billing\"\n    | \"reminder\"\n    | \"compliance\";\n\n/**\n * Attachment metadata for admin notes\n */\nexport interface INoteAttachment {\n    /** Unique attachment identifier */\n    attachmentId: string;\n    /** Original file name */\n    fileName: string;\n    /** MIME type of the file */\n    mimeType: string;\n    /** File size in bytes */\n    fileSize: number;\n    /** S3 key path (stored in admin's federated identity space) */\n    s3Key: string;\n    /** ISO timestamp when attachment was uploaded */\n    uploadedAt: string;\n}\n\n/**\n * Admin note for client detail view\n */\nexport interface IAdminClientNote {\n    /** Unique note identifier */\n    id: string;\n    /** Note text content (supports HTML from rich text editor) */\n    text: string;\n    /** ISO timestamp when note was created */\n    createdAt: string;\n    /** Name of user who created the note */\n    createdBy: string;\n    /** Cognito sub of user who created the note */\n    createdBySub?: string;\n    /** Whether this note is pinned to the top */\n    pinned?: boolean;\n    /** ISO timestamp when note was pinned */\n    pinnedAt?: string;\n    /** Note category for organization */\n    category?: NoteCategory;\n    /** Custom tags for filtering */\n    tags?: string[];\n    /** File attachments (stored in admin's S3 space) */\n    attachments?: INoteAttachment[];\n    /** ISO timestamp of last update */\n    updatedAt?: string;\n    /** Name of user who last updated the note */\n    updatedBy?: string;\n}\n\n/**\n * Structured detail view model for individual client\n * Used in the client detail panel/modal\n *\n * @description This interface provides a structured, organized view\n * of all client data for the detail panel. Data is transformed from\n * the raw IAdminClient format into logical groups for display.\n */\nexport interface IAdminClientDetail {\n    /** User unique identifier (Cognito sub) */\n    sub: string;\n\n    /** Client's federated identity ID for S3 access */\n    federatedIdentity: string;\n\n    /** Client display name */\n    name: string;\n\n    /** Client email address */\n    email: string;\n\n    /** Client phone number */\n    phone?: string;\n\n    /** Account status */\n    status: \"active\" | \"inactive\";\n\n    /** Business information from intake form */\n    businessInfo: IAdminClientDetailBusinessInfo;\n\n    /** Array of business owners from intake form */\n    businessOwners: IClientAcctBusinessOwner[];\n\n    /** Employee information from intake form */\n    employeeInfo: IAdminClientDetailEmployeeInfo;\n\n    /** Admin configuration flags */\n    adminConfig: IAdminClientDetailAdminConfig;\n\n    /** Client's subscribed services */\n    services: IAdminClientService[];\n\n    /** Total value of all subscribed services */\n    totalServiceValue: number;\n\n    /** Whether client has private pricing (service ID 'EXT00') */\n    hasPrivatePricing: boolean;\n\n    /** Action items organized by status (V1 - Legacy) */\n    actionItems: IAdminClientDetailActionItems;\n\n    /** V2 Action items organized by status, category, and severity */\n    actionItemsV2: IAdminClientDetailActionItemsV2;\n\n    /** Onboarding checklist summary */\n    checklist: IAdminClientDetailChecklist;\n\n    /** File sharing configuration */\n    fileSharing: IAdminClientDetailFileSharing;\n\n    /** Intake form submission status */\n    intakeStatus: IAdminClientDetailIntakeStatus;\n\n    /** Admin notes for this client */\n    notes: IAdminClientNote[];\n\n    /** Admin-to-client message history */\n    messages?: IClientMessage[];\n}\n"]}
@@ -117,18 +117,55 @@ export interface IAdminClientDetailIntakeStatus {
117
117
  /** ISO timestamp of last modification */
118
118
  lastModified?: string;
119
119
  }
120
+ /**
121
+ * Note category types for organization
122
+ */
123
+ export type NoteCategory = "general" | "follow-up" | "issue" | "billing" | "reminder" | "compliance";
124
+ /**
125
+ * Attachment metadata for admin notes
126
+ */
127
+ export interface INoteAttachment {
128
+ /** Unique attachment identifier */
129
+ attachmentId: string;
130
+ /** Original file name */
131
+ fileName: string;
132
+ /** MIME type of the file */
133
+ mimeType: string;
134
+ /** File size in bytes */
135
+ fileSize: number;
136
+ /** S3 key path (stored in admin's federated identity space) */
137
+ s3Key: string;
138
+ /** ISO timestamp when attachment was uploaded */
139
+ uploadedAt: string;
140
+ }
120
141
  /**
121
142
  * Admin note for client detail view
122
143
  */
123
144
  export interface IAdminClientNote {
124
145
  /** Unique note identifier */
125
146
  id: string;
126
- /** Note text content */
147
+ /** Note text content (supports HTML from rich text editor) */
127
148
  text: string;
128
149
  /** ISO timestamp when note was created */
129
150
  createdAt: string;
130
151
  /** Name of user who created the note */
131
152
  createdBy: string;
153
+ /** Cognito sub of user who created the note */
154
+ createdBySub?: string;
155
+ /** Whether this note is pinned to the top */
156
+ pinned?: boolean;
157
+ /** ISO timestamp when note was pinned */
158
+ pinnedAt?: string;
159
+ /** Note category for organization */
160
+ category?: NoteCategory;
161
+ /** Custom tags for filtering */
162
+ tags?: string[];
163
+ /** File attachments (stored in admin's S3 space) */
164
+ attachments?: INoteAttachment[];
165
+ /** ISO timestamp of last update */
166
+ updatedAt?: string;
167
+ /** Name of user who last updated the note */
168
+ updatedBy?: string;
132
169
  }
133
170
  /**
134
171
  * Structured detail view model for individual client
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@adonoustech/bacon-core",
3
- "version": "6.17.0",
3
+ "version": "6.18.0",
4
4
  "scripts": {
5
5
  "build:cjs": "tsc -p tsconfig.cjs.json",
6
6
  "build:es": "tsc -p tsconfig.es.json",
@@ -39,5 +39,5 @@
39
39
  "bugs": {
40
40
  "url": "https://github.com/AdonousTech/bacon-core/issues"
41
41
  },
42
- "gitHead": "6bd3c704dd439e3b7cd90675f0a645ed3122c667"
42
+ "gitHead": "a34ae71070e19edf6bf64ed3bcc67bfa565f4657"
43
43
  }
@@ -126,18 +126,63 @@ export interface IAdminClientDetailIntakeStatus {
126
126
  lastModified?: string;
127
127
  }
128
128
 
129
+ /**
130
+ * Note category types for organization
131
+ */
132
+ export type NoteCategory =
133
+ | "general"
134
+ | "follow-up"
135
+ | "issue"
136
+ | "billing"
137
+ | "reminder"
138
+ | "compliance";
139
+
140
+ /**
141
+ * Attachment metadata for admin notes
142
+ */
143
+ export interface INoteAttachment {
144
+ /** Unique attachment identifier */
145
+ attachmentId: string;
146
+ /** Original file name */
147
+ fileName: string;
148
+ /** MIME type of the file */
149
+ mimeType: string;
150
+ /** File size in bytes */
151
+ fileSize: number;
152
+ /** S3 key path (stored in admin's federated identity space) */
153
+ s3Key: string;
154
+ /** ISO timestamp when attachment was uploaded */
155
+ uploadedAt: string;
156
+ }
157
+
129
158
  /**
130
159
  * Admin note for client detail view
131
160
  */
132
161
  export interface IAdminClientNote {
133
162
  /** Unique note identifier */
134
163
  id: string;
135
- /** Note text content */
164
+ /** Note text content (supports HTML from rich text editor) */
136
165
  text: string;
137
166
  /** ISO timestamp when note was created */
138
167
  createdAt: string;
139
168
  /** Name of user who created the note */
140
169
  createdBy: string;
170
+ /** Cognito sub of user who created the note */
171
+ createdBySub?: string;
172
+ /** Whether this note is pinned to the top */
173
+ pinned?: boolean;
174
+ /** ISO timestamp when note was pinned */
175
+ pinnedAt?: string;
176
+ /** Note category for organization */
177
+ category?: NoteCategory;
178
+ /** Custom tags for filtering */
179
+ tags?: string[];
180
+ /** File attachments (stored in admin's S3 space) */
181
+ attachments?: INoteAttachment[];
182
+ /** ISO timestamp of last update */
183
+ updatedAt?: string;
184
+ /** Name of user who last updated the note */
185
+ updatedBy?: string;
141
186
  }
142
187
 
143
188
  /**