law-common 11.3.8-beta.0 → 11.3.8-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,6 +6,7 @@ export type IVendorTdsLiabilityUpdateDto = DeepPartialButRequired<IVendorTdsLiab
6
6
  export interface IVendorTdsLiabilityActionDataDto {
7
7
  action: VendorTdsLiabilityActionEnum;
8
8
  remark?: string;
9
+ tdsDeducted?: number;
9
10
  }
10
11
  export declare enum VendorTdsLiabilityActionEnum {
11
12
  CREATE = "create",
@@ -13,5 +14,6 @@ export declare enum VendorTdsLiabilityActionEnum {
13
14
  DELETE = "delete",
14
15
  DEACTIVATE = "deactivate",
15
16
  ACTIVATE = "activate",
16
- RESTORE = "restore"
17
+ RESTORE = "restore",
18
+ TDS_DEDUCTED = "tds_deducted"
17
19
  }
@@ -9,4 +9,5 @@ var VendorTdsLiabilityActionEnum;
9
9
  VendorTdsLiabilityActionEnum["DEACTIVATE"] = "deactivate";
10
10
  VendorTdsLiabilityActionEnum["ACTIVATE"] = "activate";
11
11
  VendorTdsLiabilityActionEnum["RESTORE"] = "restore";
12
+ VendorTdsLiabilityActionEnum["TDS_DEDUCTED"] = "tds_deducted";
12
13
  })(VendorTdsLiabilityActionEnum || (exports.VendorTdsLiabilityActionEnum = VendorTdsLiabilityActionEnum = {}));
@@ -2,5 +2,6 @@ import { FlowConfig } from "./flow-config.type";
2
2
  import { VendorTdsLiabilityActionEnum } from "../../api";
3
3
  import { VendorTdsLiabilityStatusEnum } from "../enums/vendor_tds_liability_status_enum";
4
4
  export interface IVendorTdsLiabilityFlowConfigContextData {
5
+ tds_deducted?: number;
5
6
  }
6
7
  export declare const vendorTdsLiabilityFlowConfig: FlowConfig<VendorTdsLiabilityStatusEnum, VendorTdsLiabilityActionEnum, IVendorTdsLiabilityFlowConfigContextData>;
@@ -4,6 +4,8 @@ exports.vendorTdsLiabilityFlowConfig = void 0;
4
4
  const base_flow_config_factory_1 = require("./base-flow-config.factory");
5
5
  const api_1 = require("../../api");
6
6
  const vendor_tds_liability_status_enum_1 = require("../enums/vendor_tds_liability_status_enum");
7
+ const exceptions_1 = require("../../exceptions");
8
+ const enums_1 = require("../../enums");
7
9
  const VENDOR_TDS_LIABILITY_CREATE_PERMISSION = ["VENDOR_TDS_LIABILITY_CREATE"];
8
10
  const VENDOR_TDS_LIABILITY_UPDATE_PERMISSION = ["VENDOR_TDS_LIABILITY_UPDATE"];
9
11
  const VENDOR_TDS_LIABILITY_DELETE_PERMISSION = ["VENDOR_TDS_LIABILITY_DELETE"];
@@ -35,12 +37,46 @@ const ACTION_MAP = {
35
37
  reachableStatues: [vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.APPROVED],
36
38
  permissions: VENDOR_TDS_LIABILITY_RESTORE_PERMISSION,
37
39
  },
40
+ [api_1.VendorTdsLiabilityActionEnum.TDS_DEDUCTED]: {
41
+ reachableStatues: [vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.APPROVED],
42
+ permissions: VENDOR_TDS_LIABILITY_UPDATE_PERMISSION,
43
+ },
38
44
  };
39
- const { createActionConfig } = (0, base_flow_config_factory_1.createFlowConfigFactory)()(ACTION_MAP);
45
+ const { createActionConfig, createTransition } = (0, base_flow_config_factory_1.createFlowConfigFactory)()(ACTION_MAP);
46
+ // const createTransitionApprovedStatusPaymentAction = createTransition<
47
+ // VendorInvoiceActionEnum.PAYMENT,
48
+ // VendorInvoiceStatusEnum.APPROVED | VendorInvoiceStatusEnum.PAYMENT_DISBURSE
49
+ // >((context: IVendorInvoiceFlowConfigContextData) => {
50
+ // const { vendorInvoicePayment, existingVendorInvoice } = context;
51
+ // if (vendorInvoicePayment && existingVendorInvoice) {
52
+ // if (existingVendorInvoice.totalNetAmount === existingVendorInvoice.paidAmount + existingVendorInvoice.adjustedAmount + vendorInvoicePayment.amount) {
53
+ // return VendorInvoiceStatusEnum.PAYMENT_DISBURSE;
54
+ // }
55
+ // } else {
56
+ // throw new AppBadRequestException({
57
+ // key: ErrorKeyEnum.VENDOR_INVOICE_FLOW_CONTEXT_DATA,
58
+ // message: ["Both vendorInvoicePayment and existingVendorInvoice must be provided in the context data for processing payment action."],
59
+ // });
60
+ // }
61
+ // return VendorInvoiceStatusEnum.APPROVED;
62
+ // });
40
63
  // APPROVED status transitions
64
+ const createTransitionApprovedStatusTdsDeductedAction = createTransition((context) => {
65
+ const { tds_deducted } = context;
66
+ if (tds_deducted !== undefined && tds_deducted !== null && !isNaN(tds_deducted) && tds_deducted >= 0) {
67
+ return vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.APPROVED;
68
+ }
69
+ else {
70
+ throw new exceptions_1.AppBadRequestException({
71
+ key: enums_1.ErrorKeyEnum.VENDOR_TDS_LIABILITY_FLOW_CONTEXT_DATA,
72
+ message: ["tds_deducted value must be provided in the context data for processing TDS Deducted action."],
73
+ });
74
+ }
75
+ });
41
76
  const transitionApprovedStatusUpdateAction = createActionConfig(api_1.VendorTdsLiabilityActionEnum.UPDATE, vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.APPROVED);
42
77
  const transitionApprovedStatusDeleteAction = createActionConfig(api_1.VendorTdsLiabilityActionEnum.DELETE, vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.DELETED);
43
78
  const transitionApprovedStatusDeactivateAction = createActionConfig(api_1.VendorTdsLiabilityActionEnum.DEACTIVATE, vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.DEACTIVATED);
79
+ const transitionApprovedStatusTdsDeductedAction = createActionConfig(api_1.VendorTdsLiabilityActionEnum.TDS_DEDUCTED, createTransitionApprovedStatusTdsDeductedAction);
44
80
  // DEACTIVATED status transitions
45
81
  const transitionDeactivatedStatusDeleteAction = createActionConfig(api_1.VendorTdsLiabilityActionEnum.DELETE, vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.DELETED);
46
82
  const transitionDeactivatedStatusActivateAction = createActionConfig(api_1.VendorTdsLiabilityActionEnum.ACTIVATE, vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.APPROVED);
@@ -53,6 +89,7 @@ exports.vendorTdsLiabilityFlowConfig = {
53
89
  [api_1.VendorTdsLiabilityActionEnum.UPDATE]: transitionApprovedStatusUpdateAction,
54
90
  [api_1.VendorTdsLiabilityActionEnum.DELETE]: transitionApprovedStatusDeleteAction,
55
91
  [api_1.VendorTdsLiabilityActionEnum.DEACTIVATE]: transitionApprovedStatusDeactivateAction,
92
+ [api_1.VendorTdsLiabilityActionEnum.TDS_DEDUCTED]: transitionApprovedStatusTdsDeductedAction,
56
93
  },
57
94
  },
58
95
  [vendor_tds_liability_status_enum_1.VendorTdsLiabilityStatusEnum.DEACTIVATED]: {
@@ -55,4 +55,7 @@ export declare class VendorTdsLiabilityEntityModel extends BaseEntityModel<Entit
55
55
  getUpdateActionVisibility(currentUser: UserEntityModel): {
56
56
  [key: string]: () => boolean;
57
57
  };
58
+ static derivePeriodFromDateCode({ dateCode }: {
59
+ dateCode: number;
60
+ }): number;
58
61
  }
@@ -187,6 +187,9 @@ class VendorTdsLiabilityEntityModel extends base_entity_model_1.BaseEntityModel
187
187
  getUpdateActionVisibility(currentUser) {
188
188
  return {};
189
189
  }
190
+ static derivePeriodFromDateCode({ dateCode }) {
191
+ return dateCode.toString().slice(0, 6);
192
+ }
190
193
  }
191
194
  exports.VendorTdsLiabilityEntityModel = VendorTdsLiabilityEntityModel;
192
195
  VendorTdsLiabilityEntityModel.relationConfigs = [
@@ -35,5 +35,6 @@ export declare enum ErrorKeyEnum {
35
35
  VENDOR_INVOICE_ITEMS = "VENDOR_INVOICE_ITEMS",
36
36
  PROJECT_USER_MAPPING = "PROJECT_USER_MAPPING",
37
37
  CONFIGURATION_KEY = "CONFIGURATION_KEY",
38
- VENDOR_INVOICE_FLOW_CONTEXT_DATA = "VENDOR_INVOICE_FLOW_CONTEXT_DATA"
38
+ VENDOR_INVOICE_FLOW_CONTEXT_DATA = "VENDOR_INVOICE_FLOW_CONTEXT_DATA",
39
+ VENDOR_TDS_LIABILITY_FLOW_CONTEXT_DATA = "VENDOR_TDS_LIABILITY_FLOW_CONTEXT_DATA"
39
40
  }
@@ -40,4 +40,5 @@ var ErrorKeyEnum;
40
40
  ErrorKeyEnum["PROJECT_USER_MAPPING"] = "PROJECT_USER_MAPPING";
41
41
  ErrorKeyEnum["CONFIGURATION_KEY"] = "CONFIGURATION_KEY";
42
42
  ErrorKeyEnum["VENDOR_INVOICE_FLOW_CONTEXT_DATA"] = "VENDOR_INVOICE_FLOW_CONTEXT_DATA";
43
+ ErrorKeyEnum["VENDOR_TDS_LIABILITY_FLOW_CONTEXT_DATA"] = "VENDOR_TDS_LIABILITY_FLOW_CONTEXT_DATA";
43
44
  })(ErrorKeyEnum || (exports.ErrorKeyEnum = ErrorKeyEnum = {}));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "law-common",
3
- "version": "11.3.8-beta.0",
3
+ "version": "11.3.8-beta.1",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "files": [