budget-api: initial

This commit is contained in:
HAPFEX
2025-11-17 11:36:04 +07:00
parent f810fb662f
commit 9b46775bed
8 changed files with 63 additions and 275 deletions

View File

@@ -1,27 +0,0 @@
import { GeneralService } from '../share/generalservice.js'
export class AccountingSearchService {
constructor() {
this.generalService = new GeneralService()
}
async getAccountingSearch(database, id, username) {
const sql = `
SELECT
actseq,
actnum,
acttyp,
${database}.translatedtl('ACTTYP', acttyp) as acttypnam,
${database}.translatedtl_multi(ARRAY['ACTCAT_INC', 'ACTCAT_EXP'], actcat) as actcatnam,
actqty,
actcmt,
actacpdtm
FROM ${database}.actmst
WHERE actnum = $1
`
const params = [id]
const result = await this.generalService.executeQueryParam(database, sql, params);
return result
}
}

View File

@@ -1,44 +0,0 @@
import { GeneralService } from '../share/generalservice.js'
export class AccountingSumService {
constructor() {
this.generalService = new GeneralService()
}
async getAccountingSum(database, id) {
const sql = `
SELECT
actseq,
actnum,
acttyp,
${database}.translatedtl('ACTTYP', acttyp) as acttypnam,
${database}.translatedtl_multi(ARRAY['ACTCAT_INC', 'ACTCAT_EXP'], actcat) as actcatnam,
actqty,
actcmt,
actacpdtm
FROM ${database}.actmst
WHERE actnum = $1
`
const params = [id]
const result = await this.generalService.executeQueryParam(database, sql, params);
return result
}
async getCategoryColorMap(database) {
const sql = `
SELECT dtlcod, dtlnam, dtlmsc as dtlclr
FROM ${database}.dtlmst
WHERE dtltblcod IN ('ACTCAT_INC', 'ACTCAT_EXP')
`;
const params = []
const rows = await this.generalService.executeQueryParam(database, sql, params);
const map = {};
rows.forEach(r => {
map[r.dtlnam] = r.dtlclr; // ใช้ชื่อหมวดเป็น key
});
return map;
}
}

View File

@@ -0,0 +1,23 @@
import { GeneralService } from '../share/generalservice.js'
export class BudgetSearchService {
constructor() {
this.generalService = new GeneralService()
}
async getBudgetSearch(database, id) {
const sql = `
SELECT
bdgseq,
bdgnam,
bdgcod,
bdgttl,
bdgedtdtm
FROM ${database}.bdgmst
`
const params = []
const result = await this.generalService.executeQueryParam(database, sql, params);
return result
}
}

View File

@@ -1,16 +1,17 @@
import { GeneralService } from '../share/generalservice.js'
export class AccountingSetupService {
export class BudgetSetupService {
constructor() {
this.generalService = new GeneralService()
}
async getAccountingSetup(database) {
async getBudgetSetup(database) {
const sql = `
SELECT
dtlnam,
dtlcod,
dtltblcod
FROM ${database}.dtlmst
bgdnam,
bgdcod,
bgdttl,
bgdedtdtm
FROM ${database}.bdgmst
WHERE dtltblcod IN ('ACTTYP', 'ACTCAT_INC', 'ACTCAT_EXP');
`
const params = []