erp-core-backend-v2/src/modules/financial/entities/tax.entity.ts

79 lines
1.8 KiB
TypeScript

import {
Entity,
PrimaryGeneratedColumn,
Column,
CreateDateColumn,
UpdateDateColumn,
Index,
ManyToOne,
JoinColumn,
} from 'typeorm';
import { Company } from '../../auth/entities/company.entity.js';
export enum TaxType {
SALES = 'sales',
PURCHASE = 'purchase',
ALL = 'all',
}
@Entity({ schema: 'financial', name: 'taxes' })
@Index('idx_taxes_tenant_id', ['tenantId'])
@Index('idx_taxes_company_id', ['companyId'])
@Index('idx_taxes_code', ['tenantId', 'code'], { unique: true })
@Index('idx_taxes_type', ['taxType'])
export class Tax {
@PrimaryGeneratedColumn('uuid')
id: string;
@Column({ type: 'uuid', nullable: false, name: 'tenant_id' })
tenantId: string;
@Column({ type: 'uuid', nullable: false, name: 'company_id' })
companyId: string;
@Column({ type: 'varchar', length: 100, nullable: false })
name: string;
@Column({ type: 'varchar', length: 20, nullable: false })
code: string;
@Column({
type: 'enum',
enum: TaxType,
nullable: false,
name: 'tax_type',
})
taxType: TaxType;
@Column({ type: 'decimal', precision: 5, scale: 2, nullable: false })
amount: number;
@Column({ type: 'boolean', default: false, nullable: false, name: 'included_in_price' })
includedInPrice: boolean;
@Column({ type: 'boolean', default: true, nullable: false })
active: boolean;
// Relations
@ManyToOne(() => Company)
@JoinColumn({ name: 'company_id' })
company: Company;
// Audit fields
@CreateDateColumn({ name: 'created_at', type: 'timestamp' })
createdAt: Date;
@Column({ type: 'uuid', nullable: true, name: 'created_by' })
createdBy: string | null;
@UpdateDateColumn({
name: 'updated_at',
type: 'timestamp',
nullable: true,
})
updatedAt: Date | null;
@Column({ type: 'uuid', nullable: true, name: 'updated_by' })
updatedBy: string | null;
}