24 lines
857 B
JavaScript
24 lines
857 B
JavaScript
import sqlite from 'better-sqlite3';
|
|
import { lotOccupancyDB as databasePath } from '../../data/databasePaths.js';
|
|
import * as configFunctions from '../functions.config.js';
|
|
export function getNextLotId(lotId) {
|
|
const database = sqlite(databasePath, {
|
|
readonly: true
|
|
});
|
|
database.function('userFn_lotNameSortName', configFunctions.getProperty('settings.lot.lotNameSortNameFunction'));
|
|
const result = database
|
|
.prepare(`select lotId
|
|
from Lots
|
|
where recordDelete_timeMillis is null
|
|
and userFn_lotNameSortName(lotName) > (select userFn_lotNameSortName(lotName) from Lots where lotId = ?)
|
|
order by userFn_lotNameSortName(lotName)
|
|
limit 1`)
|
|
.get(lotId);
|
|
database.close();
|
|
if (result) {
|
|
return result.lotId;
|
|
}
|
|
return undefined;
|
|
}
|
|
export default getNextLotId;
|