79 lines
1.8 KiB
TypeScript
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;
|
|
}
|