UNPKG

@codetanzania/majifix-account

Version:

A representation of an entity (i.e organization, individual, customer, or client) which receiving service(s) from a particular jurisdiction

128 lines (121 loc) 2.53 kB
import { createSubSchema } from '@lykmapipo/mongoose-common'; /** * @name Period * @description a period under which a bill is applicable. * Its is the period of time between billings. * * @see {@link https://www.thebalance.com/billing-cycle-960690} * @author lally elias <lallyelias87@gmail.com> * @since 0.1.0 * @version 1.0.0 * @public */ const Period = createSubSchema({ /** * @name name * @description Human readable period name e.g November, Jan-Jun etc * * @type {object} * @property {object} type - schema(data) type * @property {boolean} trim - force trimming * * @since 0.1.0 * @version 1.0.0 * @instance * @example * January, Jan-Jun */ name: { type: String, trim: true, }, /** * @name billedAt * @description A date when a bill come to effect * * @type {object} * @property {object} type - schema(data) type * @property {object} fake - fake data generator options * * @since 0.1.0 * @version 1.0.0 * @instance * @example * 2018-01-01 */ billedAt: { type: Date, fake: { generator: 'date', type: 'past', }, }, /** * @name startedAt * @description A bill period start date(or time) * * @type {object} * @property {object} type - schema(data) type * @property {object} fake - fake data generator options * * @since 0.1.0 * @version 1.0.0 * @instance * @example * 2018-01-01 */ startedAt: { type: Date, fake: { generator: 'date', type: 'past', }, }, /** * @name endedAt * @description A bill period end date(or time) * * @type {object} * @property {object} type - schema(data) type * @property {object} fake - fake data generator options * * @since 0.1.0 * @version 1.0.0 * @instance * @example * 2018-01-20 */ endedAt: { type: Date, fake: { generator: 'date', type: 'recent', }, }, /** * @name duedAt * @description A bill period due date(or time). Mostly used by * jurisdiction to refer the date when an account should have * already pay the bill. * * * @type {object} * @property {object} type - schema(data) type * @property {object} fake - fake data generator options * * @since 0.1.0 * @version 1.0.0 * @instance * @example * 2018-01-30 */ duedAt: { type: Date, fake: { generator: 'date', type: 'future', }, }, }); /* export period schema */ export default Period;