2022-04-19 11:29:36 +05:30
|
|
|
import { Fyo } from 'fyo';
|
|
|
|
import NumberSeries from 'fyo/models/NumberSeries';
|
|
|
|
import { DEFAULT_SERIES_START } from 'fyo/utils/consts';
|
|
|
|
import { BaseError } from 'fyo/utils/errors';
|
2022-04-08 11:40:04 +05:30
|
|
|
import { Field, Schema } from 'schemas/types';
|
2022-04-21 18:38:36 +05:30
|
|
|
import { getRandomString } from 'utils';
|
2022-04-24 12:18:44 +05:30
|
|
|
import { Doc } from './doc';
|
2022-04-08 11:40:04 +05:30
|
|
|
|
|
|
|
export function getNumberSeries(schema: Schema): Field | undefined {
|
|
|
|
const numberSeries = schema.fields.find(
|
|
|
|
(f) => f.fieldname === 'numberSeries'
|
|
|
|
);
|
|
|
|
return numberSeries;
|
|
|
|
}
|
2018-03-05 22:15:21 +05:30
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
export function isNameAutoSet(schemaName: string, fyo: Fyo): boolean {
|
|
|
|
const schema = fyo.schemaMap[schemaName]!;
|
2022-04-08 11:40:04 +05:30
|
|
|
if (schema.naming === 'autoincrement') {
|
2022-03-17 17:16:49 +05:30
|
|
|
return true;
|
|
|
|
}
|
2022-02-24 11:39:35 +05:30
|
|
|
|
2022-04-08 11:40:04 +05:30
|
|
|
const numberSeries = getNumberSeries(schema);
|
2022-03-17 17:16:49 +05:30
|
|
|
if (numberSeries) {
|
|
|
|
return true;
|
|
|
|
}
|
2022-03-08 13:42:08 +05:30
|
|
|
|
2022-03-17 17:16:49 +05:30
|
|
|
return false;
|
|
|
|
}
|
2018-03-05 22:15:21 +05:30
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
export async function setName(doc: Doc, fyo: Fyo) {
|
2022-04-29 18:30:24 +05:30
|
|
|
if (doc.schema.naming === 'manual') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-04-08 11:40:04 +05:30
|
|
|
if (doc.schema.naming === 'autoincrement') {
|
2022-04-19 11:29:36 +05:30
|
|
|
doc.name = await getNextId(doc.schemaName, fyo);
|
2022-04-08 11:40:04 +05:30
|
|
|
return;
|
|
|
|
}
|
2022-03-08 13:42:08 +05:30
|
|
|
|
2022-04-08 11:40:04 +05:30
|
|
|
// Current, per doc number series
|
|
|
|
const numberSeries = doc.numberSeries as string | undefined;
|
|
|
|
if (numberSeries !== undefined) {
|
2022-04-19 11:29:36 +05:30
|
|
|
doc.name = await getSeriesNext(numberSeries, doc.schemaName, fyo);
|
2022-04-08 11:40:04 +05:30
|
|
|
return;
|
2022-03-17 17:16:49 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
if (doc.name) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-05-01 10:15:47 +05:30
|
|
|
// name === schemaName for Single
|
2022-04-08 11:40:04 +05:30
|
|
|
if (doc.schema.isSingle) {
|
2022-05-01 10:15:47 +05:30
|
|
|
doc.name = doc.schemaName;
|
2022-03-17 17:16:49 +05:30
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// assign a random name by default
|
|
|
|
// override doc to set a name
|
|
|
|
if (!doc.name) {
|
|
|
|
doc.name = getRandomString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
export async function getNextId(schemaName: string, fyo: Fyo) {
|
2022-03-17 17:16:49 +05:30
|
|
|
// get the last inserted row
|
2022-04-19 11:29:36 +05:30
|
|
|
const lastInserted = await getLastInserted(schemaName, fyo);
|
2022-03-17 17:16:49 +05:30
|
|
|
let name = 1;
|
|
|
|
if (lastInserted) {
|
2022-04-08 11:40:04 +05:30
|
|
|
let lastNumber = parseInt(lastInserted.name as string);
|
2022-03-17 17:16:49 +05:30
|
|
|
if (isNaN(lastNumber)) lastNumber = 0;
|
|
|
|
name = lastNumber + 1;
|
|
|
|
}
|
|
|
|
return (name + '').padStart(9, '0');
|
|
|
|
}
|
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
export async function getLastInserted(schemaName: string, fyo: Fyo) {
|
|
|
|
const lastInserted = await fyo.db.getAll(schemaName, {
|
2022-03-17 17:16:49 +05:30
|
|
|
fields: ['name'],
|
|
|
|
limit: 1,
|
2022-04-27 17:32:43 +05:30
|
|
|
orderBy: 'created',
|
2022-03-17 17:16:49 +05:30
|
|
|
order: 'desc',
|
|
|
|
});
|
|
|
|
return lastInserted && lastInserted.length ? lastInserted[0] : null;
|
|
|
|
}
|
|
|
|
|
2022-04-18 16:59:20 +05:30
|
|
|
export async function getSeriesNext(
|
|
|
|
prefix: string,
|
|
|
|
schemaName: string,
|
2022-04-19 11:29:36 +05:30
|
|
|
fyo: Fyo
|
2022-04-18 16:59:20 +05:30
|
|
|
) {
|
2022-04-08 11:40:04 +05:30
|
|
|
let series: NumberSeries;
|
2022-03-17 17:16:49 +05:30
|
|
|
|
|
|
|
try {
|
2022-04-19 11:29:36 +05:30
|
|
|
series = (await fyo.doc.getDoc('NumberSeries', prefix)) as NumberSeries;
|
2022-03-17 17:16:49 +05:30
|
|
|
} catch (e) {
|
2022-04-08 11:40:04 +05:30
|
|
|
const { statusCode } = e as BaseError;
|
|
|
|
if (!statusCode || statusCode !== 404) {
|
2022-03-17 17:16:49 +05:30
|
|
|
throw e;
|
2022-01-21 02:27:29 +05:30
|
|
|
}
|
2022-03-08 13:42:08 +05:30
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
await createNumberSeries(prefix, schemaName, DEFAULT_SERIES_START, fyo);
|
|
|
|
series = (await fyo.doc.getDoc('NumberSeries', prefix)) as NumberSeries;
|
2022-03-17 17:16:49 +05:30
|
|
|
}
|
2018-03-27 19:25:26 +05:30
|
|
|
|
2022-04-08 11:40:04 +05:30
|
|
|
return await series.next(schemaName);
|
2022-03-17 17:16:49 +05:30
|
|
|
}
|
|
|
|
|
2022-04-08 11:40:04 +05:30
|
|
|
export async function createNumberSeries(
|
|
|
|
prefix: string,
|
|
|
|
referenceType: string,
|
2022-04-18 16:59:20 +05:30
|
|
|
start: number,
|
2022-04-19 11:29:36 +05:30
|
|
|
fyo: Fyo
|
2022-04-08 11:40:04 +05:30
|
|
|
) {
|
2022-04-19 11:29:36 +05:30
|
|
|
const exists = await fyo.db.exists('NumberSeries', prefix);
|
2022-03-17 17:16:49 +05:30
|
|
|
if (exists) {
|
|
|
|
return;
|
|
|
|
}
|
2022-03-08 13:42:08 +05:30
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
const series = fyo.doc.getNewDoc('NumberSeries', {
|
2022-03-17 17:16:49 +05:30
|
|
|
name: prefix,
|
|
|
|
start,
|
|
|
|
referenceType,
|
|
|
|
});
|
2022-03-08 13:42:08 +05:30
|
|
|
|
2022-04-24 12:18:44 +05:30
|
|
|
await series.sync();
|
2022-03-17 17:16:49 +05:30
|
|
|
}
|