@undp/carbon-library 1.0.274-CARBON-404.0 → 1.0.274-CARBON-363.2

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.
package/dist/cjs/index.js CHANGED
@@ -2047,7 +2047,7 @@ exports.NdcActionStatus = void 0;
2047
2047
  NdcActionStatus["PENDING"] = "Pending";
2048
2048
  NdcActionStatus["APPROVED"] = "Approved";
2049
2049
  })(exports.NdcActionStatus || (exports.NdcActionStatus = {}));
2050
- var getNdcActionStatusEnumVal = function (value) {
2050
+ var getNdcActionStatusEnumVal$1 = function (value) {
2051
2051
  var index = Object.keys(exports.NdcActionStatus).indexOf(value);
2052
2052
  if (index < 0) {
2053
2053
  return value;
@@ -2055,7 +2055,7 @@ var getNdcActionStatusEnumVal = function (value) {
2055
2055
  return Object.values(exports.NdcActionStatus)[index];
2056
2056
  };
2057
2057
  var getNdcStatusTagType = function (status) {
2058
- switch (getNdcActionStatusEnumVal(status)) {
2058
+ switch (getNdcActionStatusEnumVal$1(status)) {
2059
2059
  case exports.NdcActionStatus.PENDING:
2060
2060
  return "processing";
2061
2061
  case exports.NdcActionStatus.APPROVED:
@@ -26675,622 +26675,785 @@ var RegistryDashboardComponent = function (props) {
26675
26675
  lastUpdateTransferLocations))))))))) : ("")));
26676
26676
  };
26677
26677
 
26678
- var EditableContext = React.createContext(null);
26679
- var EditableRow = function (_a) {
26680
- _a.index; var props = __rest(_a, ["index"]);
26681
- var form = antd.Form.useForm()[0];
26682
- return (React.createElement(antd.Form, { form: form, component: false },
26683
- React.createElement(EditableContext.Provider, { value: form },
26684
- React.createElement("tr", __assign({}, props)))));
26685
- };
26678
+ React.createContext(null);
26686
26679
  var EditableCell = function (_a) {
26687
- var title = _a.title, editable = _a.editable, children = _a.children, dataIndex = _a.dataIndex, record = _a.record, handleSave = _a.handleSave, restProps = __rest(_a, ["title", "editable", "children", "dataIndex", "record", "handleSave"]);
26688
- var _b = React.useState(false), editing = _b[0], setEditing = _b[1];
26689
- var inputRef = React.useRef(null);
26690
- var form = React.useContext(EditableContext);
26691
- React.useEffect(function () {
26692
- if (editing) {
26693
- inputRef.current.focus();
26694
- }
26695
- }, [editing]);
26696
- var toggleEdit = function () {
26697
- var _a;
26698
- setEditing(!editing);
26699
- form.setFieldsValue((_a = {}, _a[dataIndex] = record[dataIndex], _a));
26700
- };
26701
- var save = function () { return __awaiter(void 0, void 0, void 0, function () {
26702
- var values, errInfo_1;
26703
- return __generator(this, function (_a) {
26704
- switch (_a.label) {
26705
- case 0:
26706
- _a.trys.push([0, 2, , 3]);
26707
- return [4 /*yield*/, form.validateFields()];
26708
- case 1:
26709
- values = _a.sent();
26710
- toggleEdit();
26711
- handleSave(__assign(__assign({}, record), values));
26712
- return [3 /*break*/, 3];
26713
- case 2:
26714
- errInfo_1 = _a.sent();
26715
- console.log("Save failed:", errInfo_1);
26716
- return [3 /*break*/, 3];
26717
- case 3: return [2 /*return*/];
26718
- }
26719
- });
26720
- }); };
26721
- var childNode = children;
26722
- if (editable) {
26723
- childNode = editing ? (React.createElement(antd.Form.Item, { style: { margin: 0 }, name: dataIndex, rules: [
26724
- {
26725
- required: true,
26726
- message: "".concat(title, " is required."),
26727
- },
26728
- ] },
26729
- React.createElement(antd.Input, { ref: inputRef, onPressEnter: save, onBlur: save }))) : (React.createElement("div", { className: "editable-cell-value-wrap", style: { paddingRight: 24, minWidth: "100px", minHeight: "20px" }, onClick: toggleEdit }, children));
26680
+ var editing = _a.editing, dataIndex = _a.dataIndex, title = _a.title; _a.inputType; var record = _a.record; _a.index; var children = _a.children, onBlurHandler = _a.onBlurHandler, t = _a.t, restProps = __rest(_a, ["editing", "dataIndex", "title", "inputType", "record", "index", "children", "onBlurHandler", "t"]);
26681
+ var inputNode;
26682
+ if (dataIndex === "nationalPlanObjective") {
26683
+ inputNode = (React.createElement(antd.Input, { onBlur: function () { return onBlurHandler(record); }, placeholder: t("ndc:nationalPlanObjectivePlaceHolder") }));
26684
+ }
26685
+ else if (dataIndex === "kpi") {
26686
+ inputNode = (React.createElement(antd.InputNumber, { onBlur: function () { return onBlurHandler(record); }, placeholder: t("ndc:kpiPlaceHolder") }));
26730
26687
  }
26731
- return React.createElement("td", __assign({}, restProps), childNode);
26688
+ return (React.createElement("td", __assign({}, restProps), editing ? (React.createElement(antd.Form.Item, { name: dataIndex, style: { margin: 0 }, rules: [
26689
+ {
26690
+ required: true,
26691
+ message: "".concat(title, " ").concat(t("ndc:isRequired")),
26692
+ },
26693
+ ] }, inputNode)) : (children)));
26732
26694
  };
26733
26695
 
26734
- var css_248z$4 = ".ndc-steps-actions {\n display: flex;\n flex-direction: row-reverse;\n margin-right: 1rem;\n justify-content: center; }\n .ndc-steps-actions .action-btn {\n border: 1px solid #16b1ff;\n color: #16b1ff;\n margin-right: 1rem; }\n .ndc-steps-actions .back-btn {\n border: 1px solid rgba(140, 140, 140, 0.7);\n color: rgba(140, 140, 140, 0.7);\n margin-right: 1rem; }\n .ndc-steps-actions .mg-left-1 {\n margin-left: 1rem; }\n";
26696
+ var css_248z$4 = ".ndc-steps-actions {\n display: flex;\n flex-direction: row-reverse;\n margin-right: 1rem;\n justify-content: center; }\n .ndc-steps-actions .action-btn {\n border: 1px solid #16b1ff;\n color: #16b1ff;\n margin-right: 1rem; }\n .ndc-steps-actions .back-btn {\n border: 1px solid rgba(140, 140, 140, 0.7);\n color: rgba(140, 140, 140, 0.7);\n margin-right: 1rem; }\n .ndc-steps-actions .mg-left-1 {\n margin-left: 1rem; }\n\n.ndc-details .ant-input-number-input-wrap {\n margin-right: 10px; }\n";
26735
26697
  styleInject(css_248z$4);
26736
26698
 
26737
- var NdcActionType;
26738
- (function (NdcActionType) {
26739
- NdcActionType[NdcActionType["main"] = 0] = "main";
26740
- NdcActionType[NdcActionType["sub"] = 1] = "sub";
26741
- })(NdcActionType || (NdcActionType = {}));
26699
+ var NdcDetailsActionType;
26700
+ (function (NdcDetailsActionType) {
26701
+ NdcDetailsActionType["MainAction"] = "MainAction";
26702
+ NdcDetailsActionType["SubAction"] = "SubAction";
26703
+ })(NdcDetailsActionType || (NdcDetailsActionType = {}));
26704
+ var NdcDetailsActionStatus;
26705
+ (function (NdcDetailsActionStatus) {
26706
+ NdcDetailsActionStatus["New"] = "New";
26707
+ NdcDetailsActionStatus["Pending"] = "Pending";
26708
+ NdcDetailsActionStatus["Approved"] = "Approved";
26709
+ NdcDetailsActionStatus["Rejected"] = "Rejected";
26710
+ })(NdcDetailsActionStatus || (NdcDetailsActionStatus = {}));
26711
+ var getNdcActionStatusEnumVal = function (value) {
26712
+ var index = Object.keys(NdcDetailsActionStatus).indexOf(value);
26713
+ if (index < 0) {
26714
+ return value;
26715
+ }
26716
+ return Object.values(NdcDetailsActionStatus)[index];
26717
+ };
26718
+ var getNdcActionStatusTagType = function (status) {
26719
+ switch (getNdcActionStatusEnumVal(status)) {
26720
+ case NdcDetailsActionStatus.Rejected:
26721
+ return "error";
26722
+ case NdcDetailsActionStatus.Pending:
26723
+ return "processing";
26724
+ case NdcDetailsActionStatus.Approved:
26725
+ return "success";
26726
+ default:
26727
+ return "default";
26728
+ }
26729
+ };
26730
+
26742
26731
  var NdcDetailsComponent = function (props) {
26743
- var t = props.t; props.useConnection; var useUserContext = props.useUserContext;
26732
+ var t = props.t, useConnection = props.useConnection, useUserContext = props.useUserContext;
26744
26733
  var RangePicker = antd.DatePicker.RangePicker;
26745
- var _a = React.useState([]), ndcDetailsData = _a[0], setNdcDetailsData = _a[1];
26746
- var _b = React.useState(false), loading = _b[0]; _b[1];
26747
- var periodItemsRef = React.useRef([]);
26734
+ var _a = React.useState([]), ndcActionsList = _a[0], setNdcActionsList = _a[1];
26735
+ var _b = React.useState(false), loading = _b[0], setLoading = _b[1];
26748
26736
  var _c = React.useState([]), periodItems = _c[0], setPeriodItems = _c[1];
26749
- var _d = React.useState("add_new"), selectedTab = _d[0], setSelectedTab = _d[1];
26750
- var selectedPeriod = React.useRef({});
26751
- var addedNdcDetailId = React.useRef(0);
26752
- var selectedNdcDetail = React.useRef({});
26737
+ var _d = React.useState({}), selectedPeriod = _d[0], setSelectedPeriod = _d[1];
26738
+ var selectedDateRangeRef = React.useRef({});
26753
26739
  var _e = React.useState(0), tableKey = _e[0], setTableKey = _e[1];
26740
+ var _f = useConnection(), get = _f.get, post = _f.post, put = _f.put;
26741
+ var _g = React.useState([]), ministryOrgList = _g[0], setMinistryOrgList = _g[1];
26742
+ var _h = React.useState({}), actionInfo = _h[0], setActionInfo = _h[1];
26743
+ var _j = React.useState(false), openConfirmationModal = _j[0], setOpenConfirmationModal = _j[1];
26744
+ var form = antd.Form.useForm()[0];
26745
+ var _k = React.useState(-1), editingKey = _k[0], setEditingKey = _k[1];
26746
+ var _l = React.useState(0), nextAvailableActionId = _l[0], setNextAvailableActionId = _l[1];
26747
+ var _m = React.useState([]), expandedRowKeys = _m[0], setExpandedRowKeys = _m[1];
26748
+ var _o = React.useState([]), subNdcActionsForPeriod = _o[0], setSubNdcActionsForPeriod = _o[1];
26749
+ var isEditing = function (record) { return record.id === editingKey; };
26754
26750
  var userInfoState = useUserContext().userInfoState;
26755
- var isAddRangeVisible = function () {
26756
- return (((userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.MINISTRY ||
26757
- (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.GOVERNMENT) &&
26751
+ React.useEffect(function () {
26752
+ if (expandedRowKeys && expandedRowKeys.length > 0) {
26753
+ var expandedKey = expandedRowKeys[0];
26754
+ setNdcSubActionsForMainAction(expandedKey);
26755
+ }
26756
+ }, ndcActionsList);
26757
+ var loginMinistry = (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.GOVERNMENT
26758
+ ? process.env.REACT_APP_GOVERNMENT_MINISTRY
26759
+ ? process.env.REACT_APP_GOVERNMENT_MINISTRY
26760
+ : "Ministry Of Environment"
26761
+ : (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.MINISTRY
26762
+ ? userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyName
26763
+ : undefined;
26764
+ var isGovernmentUser = (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.GOVERNMENT &&
26765
+ (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.userRole) !== exports.Role.ViewOnly;
26766
+ var isMainNdcActionsEditable = !selectedPeriod.finalized &&
26767
+ (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.GOVERNMENT &&
26768
+ (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.userRole) !== exports.Role.ViewOnly;
26769
+ var isSubNdcActionsEditable = function (record) {
26770
+ return (!selectedPeriod.finalized &&
26771
+ record.status !== NdcDetailsActionStatus.Approved &&
26772
+ ((userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.GOVERNMENT ||
26773
+ ((userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.MINISTRY &&
26774
+ (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyName) === record.ministryName)) &&
26758
26775
  (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.userRole) !== exports.Role.ViewOnly);
26759
26776
  };
26760
- var isAddNdcActionVisible = function () {
26761
- return ((userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.companyRole) === exports.CompanyRole.GOVERNMENT &&
26762
- (userInfoState === null || userInfoState === void 0 ? void 0 : userInfoState.userRole) !== exports.Role.ViewOnly);
26777
+ var isNdcActionEditable = function (record) {
26778
+ if (record.actionType === NdcDetailsActionType.MainAction) {
26779
+ return isMainNdcActionsEditable;
26780
+ }
26781
+ else if (record.actionType === NdcDetailsActionType.SubAction) {
26782
+ return isSubNdcActionsEditable(record);
26783
+ }
26784
+ };
26785
+ var ndcMainDetailsForPeriod = selectedPeriod.key !== "add_new"
26786
+ ? ndcActionsList.filter(function (ndcDetail) {
26787
+ return (ndcDetail.periodId === parseInt(selectedPeriod.key) &&
26788
+ ndcDetail.actionType === NdcDetailsActionType.MainAction);
26789
+ })
26790
+ : [];
26791
+ var setNdcSubActionsForMainAction = function (mainActionId) {
26792
+ var subNdcDetails = ndcActionsList.filter(function (ndcDetail) {
26793
+ return (ndcDetail.parentActionId === mainActionId &&
26794
+ ndcDetail.actionType === NdcDetailsActionType.SubAction);
26795
+ });
26796
+ var emptySubNdcRow = {
26797
+ id: nextAvailableActionId,
26798
+ actionType: NdcDetailsActionType.SubAction,
26799
+ nationalPlanObjective: "",
26800
+ kpi: "",
26801
+ ministryName: loginMinistry,
26802
+ status: NdcDetailsActionStatus.New,
26803
+ parentActionId: mainActionId,
26804
+ };
26805
+ if (!selectedPeriod.finalized) {
26806
+ subNdcDetails = __spreadArray(__spreadArray([], subNdcDetails, true), [emptySubNdcRow], false);
26807
+ setEditingKey(nextAvailableActionId);
26808
+ setNextAvailableActionId(function (value) { return value + 1; });
26809
+ form.setFieldsValue({
26810
+ nationalPlanObjective: "",
26811
+ kpi: "",
26812
+ });
26813
+ }
26814
+ setSubNdcActionsForPeriod(subNdcDetails);
26763
26815
  };
26764
26816
  var inRange = function (num, min, max) {
26765
26817
  return num >= min && num <= max;
26766
26818
  };
26767
- function onAddNewSubNdcDetail() {
26768
- var range = selectedTab.split("-");
26769
- var ndcDetail = ndcDetailsData.find(function (item) { return item.key === selectedNdcDetail.current.key; });
26770
- var ndcDetailItemIndex = ndcDetailsData.findIndex(function (item) { return item.key === selectedNdcDetail.current.key; });
26771
- if (ndcDetail) {
26772
- addedNdcDetailId.current = addedNdcDetailId.current + 1;
26773
- var newData = {
26774
- key: addedNdcDetailId.current,
26775
- startDate: new Date("".concat(Number(range[0]), "-01-24 23:12:00")),
26776
- endDate: new Date("".concat(Number(range[0]), "-12-24 23:12:00")),
26777
- ndcActionId: ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.key,
26778
- nationalPlanObj: "",
26779
- kpi: "",
26780
- ministry: "",
26781
- };
26782
- if (!ndcDetail.subNdcDetails) {
26783
- ndcDetail.subNdcDetails = [];
26784
- }
26785
- ndcDetail.subNdcDetails.push(newData);
26786
- }
26787
- ndcDetailsData[ndcDetailItemIndex] = ndcDetail;
26788
- setNdcDetailsData(ndcDetailsData);
26789
- setTableKey(function (key) { return key + 1; });
26790
- }
26791
- var handleSave = function (row) {
26792
- setNdcDetailsData(function (prevData) {
26793
- var newData = JSON.parse(JSON.stringify(prevData));
26794
- if (row.type === NdcActionType.main) {
26795
- var index = newData.findIndex(function (item) { return row.key === item.key; });
26796
- if (index !== -1) {
26797
- newData[index] = __assign(__assign({}, newData[index]), row);
26798
- }
26799
- }
26800
- else {
26801
- var parentIndex = newData.findIndex(function (item) { return row.ndcActionId === item.key; });
26802
- var parentItem = newData[parentIndex];
26803
- if (parentItem) {
26804
- if (parentItem.subNdcDetails) {
26805
- var itemIndex = parentItem.subNdcDetails.findIndex(function (item) { return row.key === item.key; });
26806
- if (itemIndex === -1) {
26807
- parentItem.subNdcDetails.push(row);
26808
- }
26809
- else {
26810
- parentItem.subNdcDetails[itemIndex] = __assign({}, row);
26811
- }
26819
+ var handleSave = function (row) { return __awaiter(void 0, void 0, void 0, function () {
26820
+ var updatedFields, updatedItem, exception_2;
26821
+ return __generator(this, function (_a) {
26822
+ switch (_a.label) {
26823
+ case 0:
26824
+ _a.trys.push([0, 9, , 10]);
26825
+ updatedFields = void 0;
26826
+ _a.label = 1;
26827
+ case 1:
26828
+ _a.trys.push([1, 3, , 4]);
26829
+ return [4 /*yield*/, form.validateFields()];
26830
+ case 2:
26831
+ updatedFields = (_a.sent());
26832
+ return [3 /*break*/, 4];
26833
+ case 3:
26834
+ _a.sent();
26835
+ return [2 /*return*/];
26836
+ case 4:
26837
+ updatedItem = __assign(__assign({}, row), updatedFields);
26838
+ if (!(updatedItem.status === NdcDetailsActionStatus.New)) return [3 /*break*/, 6];
26839
+ if (isGovernmentUser &&
26840
+ updatedItem.actionType === NdcDetailsActionType.SubAction) {
26841
+ updatedItem.status = NdcDetailsActionStatus.Approved;
26812
26842
  }
26813
26843
  else {
26814
- parentItem.subNdcDetails = [row];
26844
+ updatedItem.status = NdcDetailsActionStatus.Pending;
26815
26845
  }
26816
- }
26817
- newData[parentIndex] = __assign({}, parentItem);
26818
- setTableKey(function (key) { return key + 1; });
26846
+ return [4 /*yield*/, post("national/programme/addNdcDetailsAction", __assign(__assign({}, updatedItem), { kpi: parseInt(updatedItem.kpi.toString()) }))];
26847
+ case 5:
26848
+ _a.sent();
26849
+ return [3 /*break*/, 8];
26850
+ case 6:
26851
+ updatedItem.status = NdcDetailsActionStatus.Pending;
26852
+ return [4 /*yield*/, put("national/programme/updateNdcDetailsAction", __assign(__assign({}, updatedItem), { kpi: parseInt(updatedItem.kpi.toString()) }))];
26853
+ case 7:
26854
+ _a.sent();
26855
+ _a.label = 8;
26856
+ case 8:
26857
+ fetchNdcDetailActions();
26858
+ setEditingKey(-1);
26859
+ return [3 /*break*/, 10];
26860
+ case 9:
26861
+ exception_2 = _a.sent();
26862
+ setEditingKey(-1);
26863
+ antd.message.open({
26864
+ type: "error",
26865
+ content: exception_2.message,
26866
+ duration: 3,
26867
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
26868
+ });
26869
+ return [3 /*break*/, 10];
26870
+ case 10: return [2 /*return*/];
26819
26871
  }
26820
- return newData;
26821
26872
  });
26822
- };
26823
- var getNdcDetailsForPeriod = function () {
26824
- var range = selectedTab.split("-");
26825
- if (range.length > 1) {
26826
- var filteredData = ndcDetailsData.filter(function (item) {
26827
- return inRange(Number(moment(item.startDate).year()), Number(range[0]), Number(range[1]));
26828
- });
26829
- return filteredData;
26830
- }
26831
- else {
26832
- return [];
26833
- }
26834
- };
26835
- var getSubNdcDetails = function (key) {
26836
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
26837
- var ndcDetail = ndcDetailsData.find(function (item) { return item.key === key; });
26838
- if (ndcDetail) {
26839
- if (((_b = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails[((_a = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails) === null || _a === void 0 ? void 0 : _a.length) - 1]) === null || _b === void 0 ? void 0 : _b.ministry.trim()) !== "" &&
26840
- ((_d = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails[((_c = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails) === null || _c === void 0 ? void 0 : _c.length) - 1]) === null || _d === void 0 ? void 0 : _d.ministry) &&
26841
- ((_f = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails[((_e = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails) === null || _e === void 0 ? void 0 : _e.length) - 1]) === null || _f === void 0 ? void 0 : _f.nationalPlanObj.trim()) !== "" &&
26842
- ((_h = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails[((_g = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails) === null || _g === void 0 ? void 0 : _g.length) - 1]) === null || _h === void 0 ? void 0 : _h.nationalPlanObj) &&
26843
- String((_k = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails[((_j = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails) === null || _j === void 0 ? void 0 : _j.length) - 1]) === null || _k === void 0 ? void 0 : _k.kpi).trim() !== "" &&
26844
- String((_m = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails[((_l = ndcDetail === null || ndcDetail === void 0 ? void 0 : ndcDetail.subNdcDetails) === null || _l === void 0 ? void 0 : _l.length) - 1]) === null || _m === void 0 ? void 0 : _m.kpi)) {
26845
- onAddNewSubNdcDetail();
26846
- }
26847
- return ndcDetail.subNdcDetails;
26873
+ }); };
26874
+ var actionMenu = function (record) {
26875
+ if (record.status === NdcDetailsActionStatus.Pending &&
26876
+ isGovernmentUser &&
26877
+ !selectedPeriod.finalized) {
26878
+ return (React.createElement(antd.List, { className: "action-menu", size: "small", dataSource: [
26879
+ {
26880
+ text: t("ndc:approve"),
26881
+ icon: React.createElement(Icon__namespace.BoxArrowInDown, null),
26882
+ click: function () {
26883
+ setActionInfo({
26884
+ action: "Approve",
26885
+ headerText: t("ndc:actionApproveTitle"),
26886
+ type: "primary",
26887
+ icon: React.createElement(Icon__namespace.BoxArrowInDown, null),
26888
+ recordId: record.id,
26889
+ });
26890
+ setOpenConfirmationModal(true);
26891
+ },
26892
+ },
26893
+ {
26894
+ text: t("ndc:reject"),
26895
+ icon: React.createElement(Icon__namespace.XOctagon, null),
26896
+ click: function () {
26897
+ setActionInfo({
26898
+ action: "Reject",
26899
+ headerText: t("ndc:rejectApproveTitle"),
26900
+ type: "danger",
26901
+ icon: React.createElement(Icon__namespace.BoxArrowInDown, null),
26902
+ recordId: record.id,
26903
+ });
26904
+ setOpenConfirmationModal(true);
26905
+ },
26906
+ },
26907
+ ], renderItem: function (item) { return (React.createElement(antd.List.Item, { onClick: item.click },
26908
+ React.createElement(antd.Typography.Text, { className: "action-icon color-error" }, item.icon),
26909
+ React.createElement("span", null, item.text))); } }));
26848
26910
  }
26849
26911
  else {
26850
- return [];
26912
+ return null;
26851
26913
  }
26852
26914
  };
26853
26915
  var defaultColumns = [
26854
26916
  {
26855
26917
  title: t("ndc:ndcColumnsNationalPlanObj"),
26856
- dataIndex: "nationalPlanObj",
26857
- key: "nationalPlanObj",
26918
+ dataIndex: "nationalPlanObjective",
26919
+ key: "nationalPlanObjective",
26858
26920
  align: "left",
26921
+ width: 400,
26859
26922
  editable: true,
26860
- width: "50%",
26861
- render: function (_, record) { return (React.createElement(React.Fragment, null, record.nationalPlanObj ? (React.createElement(antd.Space, { size: "middle" },
26862
- React.createElement("span", null, record.nationalPlanObj))) : (React.createElement("input", { placeholder: "Please add Programmes", className: "ant-input", type: "text" })))); },
26923
+ render: function (_, record) { return (React.createElement(antd.Space, { size: "middle" }, record.nationalPlanObjective ? (React.createElement("span", null, record.nationalPlanObjective)) : (React.createElement(antd.Input, { placeholder: "Enter National Plan Objective" })))); },
26863
26924
  },
26864
26925
  {
26865
26926
  title: t("ndc:ndcColumnsKpi"),
26866
26927
  dataIndex: "kpi",
26867
26928
  key: "kpi",
26868
26929
  align: "left",
26930
+ width: 100,
26869
26931
  editable: true,
26870
- width: "10%",
26871
- render: function (_, record) { return (React.createElement(React.Fragment, null, record.nationalPlanObj ? (React.createElement(antd.Space, { size: "middle" },
26872
- React.createElement("span", null, record.kpi))) : (React.createElement("input", { placeholder: "Enter Kpi", className: "ant-input", type: "text" })))); },
26932
+ render: function (_, record) { return (React.createElement(antd.Space, { size: "middle" }, record.kpi ? (React.createElement("span", null, record.kpi)) : (React.createElement(antd.Input, { placeholder: "Enter Kpi" })))); },
26873
26933
  },
26874
26934
  {
26875
- title: "Government Department",
26876
- dataIndex: "ministry",
26877
- key: "ministry",
26935
+ title: t("ndc:ndcColumnsMinistry"),
26936
+ dataIndex: "ministryName",
26937
+ key: "ministryName",
26878
26938
  align: "left",
26879
- editable: true,
26880
- width: "40%",
26881
- render: function (_, record) { return (React.createElement(React.Fragment, null, record.nationalPlanObj ? (React.createElement(antd.Space, { size: "middle" },
26882
- React.createElement("span", null, record.ministry))) : (React.createElement("input", { placeholder: "Please add the Government Department", className: "ant-input", type: "text" })))); },
26939
+ width: 300,
26940
+ editable: false,
26941
+ render: function (_, record) { return (React.createElement(React.Fragment, null,
26942
+ React.createElement(antd.Select, { disabled: !(isSubNdcActionsEditable(record) && isEditing(record)), defaultValue: record.ministryName ? record.ministryName : loginMinistry, style: { width: 220 }, onChange: function (value, option) {
26943
+ record.ministryName = option.label;
26944
+ handleSave(record);
26945
+ }, options: ministryOrgList }))); },
26946
+ },
26947
+ {
26948
+ title: t("ndc:ndcColumnsStatus"),
26949
+ dataIndex: "status",
26950
+ key: "status",
26951
+ align: "left",
26952
+ width: 200,
26953
+ editable: false,
26954
+ render: function (_, record) {
26955
+ var menu = actionMenu(record);
26956
+ return (React.createElement("div", { onClick: function (event) { return event.stopPropagation(); } },
26957
+ record.actionType === NdcDetailsActionType.SubAction &&
26958
+ record.status !== NdcDetailsActionStatus.New ? (React.createElement(antd.Tooltip, { title: record.status, color: TooltipColor, key: TooltipColor },
26959
+ React.createElement(antd.Tag, { className: "clickable", color: getNdcActionStatusTagType(record.status) }, addSpaces(record.status)))) : (""),
26960
+ record.actionType === NdcDetailsActionType.SubAction && menu ? (React.createElement(antd.Popover, { placement: "bottomRight", content: menu, trigger: "click" },
26961
+ React.createElement(icons.EllipsisOutlined, { rotate: 90, style: {
26962
+ fontWeight: 600,
26963
+ fontSize: "1rem",
26964
+ cursor: "pointer",
26965
+ } }))) : (React.createElement("span", null))));
26966
+ },
26883
26967
  },
26884
26968
  ];
26885
26969
  var columns = defaultColumns.map(function (col) {
26886
26970
  if (!col.editable) {
26887
26971
  return col;
26888
26972
  }
26889
- return __assign(__assign({}, col), { onCell: function (record) { return ({
26890
- record: record,
26891
- editable: col.editable,
26892
- dataIndex: col.dataIndex,
26893
- title: col.title,
26894
- handleSave: handleSave,
26895
- }); } });
26973
+ return __assign(__assign({}, col), { onCell: function (record) {
26974
+ return {
26975
+ record: record,
26976
+ editing: isEditing(record),
26977
+ dataIndex: col.dataIndex,
26978
+ title: col.title,
26979
+ onBlurHandler: function (record) {
26980
+ if (isEditing(record)) {
26981
+ handleSave(record);
26982
+ }
26983
+ },
26984
+ t: t,
26985
+ };
26986
+ } });
26896
26987
  });
26897
- function onAddNewNdcDetail() {
26898
- var range = selectedTab.split("-");
26899
- var ndcActionId = ++addedNdcDetailId.current;
26900
- var newData = {
26901
- key: ndcActionId,
26902
- type: NdcActionType.main,
26903
- startDate: new Date("".concat(Number(range[0]), "-01-24 23:12:00")),
26904
- endDate: new Date("".concat(Number(range[0]), "-12-24 23:12:00")),
26905
- nationalPlanObj: "",
26906
- kpi: "",
26907
- ministry: "",
26908
- subNdcDetails: [
26909
- {
26910
- key: ++addedNdcDetailId.current,
26911
- ndcActionId: ndcActionId,
26912
- type: NdcActionType.sub,
26913
- startDate: new Date("2019-03-25"),
26914
- endDate: new Date("2020-03-25"),
26915
- nationalPlanObj: "",
26916
- kpi: "",
26917
- ministry: "",
26918
- },
26919
- ],
26920
- };
26921
- setNdcDetailsData(__spreadArray(__spreadArray([], ndcDetailsData, true), [newData], false));
26988
+ function onClickedAddNewNdcDetail() {
26989
+ return __awaiter(this, void 0, void 0, function () {
26990
+ var periodId, newData_1;
26991
+ return __generator(this, function (_a) {
26992
+ if (selectedPeriod.key !== "add_new") {
26993
+ form.setFieldsValue({
26994
+ nationalPlanObjective: "",
26995
+ kpi: "",
26996
+ });
26997
+ periodId = parseInt(selectedPeriod.key);
26998
+ newData_1 = {
26999
+ id: nextAvailableActionId,
27000
+ actionType: NdcDetailsActionType.MainAction,
27001
+ nationalPlanObjective: "",
27002
+ kpi: "",
27003
+ ministryName: loginMinistry,
27004
+ periodId: periodId,
27005
+ status: NdcDetailsActionStatus.New,
27006
+ };
27007
+ setEditingKey(nextAvailableActionId);
27008
+ setNextAvailableActionId(function (value) { return value + 1; });
27009
+ setNdcActionsList(function (ndcActionsList) { return __spreadArray(__spreadArray([], ndcActionsList, true), [
27010
+ newData_1,
27011
+ ], false); });
27012
+ setTableKey(function (key) { return key + 1; });
27013
+ }
27014
+ return [2 /*return*/];
27015
+ });
27016
+ });
26922
27017
  }
26923
27018
  var components = {
26924
27019
  body: {
26925
- row: EditableRow,
26926
27020
  cell: EditableCell,
26927
27021
  },
26928
27022
  };
26929
- //commented because rendering issue
26930
- function ndcDetailsTableContent() {
26931
- return (React.createElement("div", null)
26932
- // <div>
26933
- // <Button
26934
- // onClick={onAddNewNdcDetail}
26935
- // type="primary"
26936
- // style={{
26937
- // marginBottom: 16,
26938
- // }}
26939
- // >
26940
- // Add a row
26941
- // </Button>
26942
- // <Table
26943
- // components={components}
26944
- // rowClassName={() => 'editable-row'}
26945
- // bordered
26946
- // dataSource={ndcDetailsData}
26947
- // columns={columns}
26948
- // />
26949
- // </div>
26950
- );
26951
- }
26952
- var onCancelPeriod = function () { };
26953
- var onAddNewPeriod = function () {
26954
- if (selectedPeriod &&
26955
- selectedPeriod.current &&
26956
- selectedPeriod.current.start &&
26957
- selectedPeriod.current.end) {
26958
- var newPeriodItem_1 = {
26959
- key: "".concat(selectedPeriod.current.start, "-").concat(selectedPeriod.current.end),
26960
- label: "".concat(selectedPeriod.current.start, "-").concat(selectedPeriod.current.end),
26961
- start: selectedPeriod.current.start,
26962
- end: selectedPeriod.current.end,
26963
- children: ndcDetailsTableContent(),
26964
- };
26965
- var existingIndex = periodItemsRef.current.findIndex(function (item) {
26966
- return inRange(newPeriodItem_1.start, item.start, item.end) ||
26967
- inRange(newPeriodItem_1.end, item.start, item.end);
27023
+ var onClickedDeletePeriod = function () { return __awaiter(void 0, void 0, void 0, function () {
27024
+ return __generator(this, function (_a) {
27025
+ setActionInfo({
27026
+ action: "Delete",
27027
+ headerText: t("ndc:periodDeleteConfirmTitle"),
27028
+ type: "danger",
27029
+ icon: React.createElement(Icon__namespace.XCircle, null),
27030
+ recordId: selectedPeriod.key,
26968
27031
  });
26969
- if (existingIndex === -1) {
26970
- setPeriodItems(function (items) { return __spreadArray(__spreadArray([], items, true), [newPeriodItem_1], false); });
26971
- periodItemsRef.current = __spreadArray(__spreadArray([], periodItemsRef.current, true), [newPeriodItem_1], false);
27032
+ setOpenConfirmationModal(true);
27033
+ return [2 /*return*/];
27034
+ });
27035
+ }); };
27036
+ var onClickedFinalizePeriod = function () { return __awaiter(void 0, void 0, void 0, function () {
27037
+ var pendingActions;
27038
+ return __generator(this, function (_a) {
27039
+ if (subNdcActionsForPeriod.length === 0) {
27040
+ antd.message.open({
27041
+ type: "error",
27042
+ content: t("ndc:finalizeNdcEmptyErrorText"),
27043
+ duration: 3,
27044
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27045
+ });
27046
+ return [2 /*return*/];
26972
27047
  }
26973
- else {
27048
+ pendingActions = subNdcActionsForPeriod.filter(function (action) {
27049
+ return action.status === NdcDetailsActionStatus.Pending;
27050
+ });
27051
+ if (pendingActions && pendingActions.length > 0) {
26974
27052
  antd.message.open({
26975
27053
  type: "error",
26976
- content: t("ndc:rangeAlreadyExists"),
27054
+ content: t("ndc:finalizeErrorText"),
26977
27055
  duration: 3,
26978
27056
  style: { textAlign: "right", marginRight: 15, marginTop: 10 },
26979
27057
  });
26980
27058
  }
27059
+ else {
27060
+ setActionInfo({
27061
+ action: "Finalize",
27062
+ headerText: t("ndc:finalizeApproveTitle"),
27063
+ text: t("ndc:finalizeApproveSubTitle"),
27064
+ type: "primary",
27065
+ icon: React.createElement(Icon__namespace.Clipboard2Check, null),
27066
+ recordId: selectedPeriod.key,
27067
+ });
27068
+ setOpenConfirmationModal(true);
27069
+ }
27070
+ return [2 /*return*/];
27071
+ });
27072
+ }); };
27073
+ var onMainTableRowExpand = function (expanded, record) {
27074
+ var keys = [];
27075
+ if (expanded) {
27076
+ keys.push(record.id);
26981
27077
  }
26982
- };
26983
- React.useEffect(function () {
26984
- if (periodItems && periodItems.length > 3) {
26985
- setSelectedTab(periodItems[periodItems.length - 1].key);
26986
- }
26987
- }, [periodItems]);
26988
- var onDateRangeChanged = function (range) {
26989
- var period = {
26990
- start: Number(moment(range[0]).year()),
26991
- end: Number(moment(range[1]).year()),
26992
- };
26993
- selectedPeriod.current = period;
27078
+ setExpandedRowKeys(keys);
27079
+ setNdcSubActionsForMainAction(record.id);
26994
27080
  };
26995
27081
  function addNewPeriodContent() {
26996
27082
  return (React.createElement("div", null,
26997
- React.createElement(antd.Row, null,
26998
- React.createElement(RangePicker, { onChange: onDateRangeChanged, picker: "year" })),
26999
- React.createElement(antd.Row, { className: "mg-top-1" },
27000
- React.createElement("div", { className: "ndc-steps-actions" },
27001
- React.createElement(antd.Button, { type: "primary", onClick: onAddNewPeriod, htmlType: "submit", loading: loading }, t("ndc:submit")),
27002
- React.createElement(antd.Button, { className: "back-btn", onClick: onCancelPeriod, loading: loading }, t("ndc:back"))))));
27083
+ React.createElement(antd.Row, { justify: "start", align: "middle", gutter: [16, 16] },
27084
+ React.createElement(antd.Col, { flex: "340px" },
27085
+ React.createElement(RangePicker, { onChange: onDateRangeChanged, picker: "year" })),
27086
+ React.createElement(antd.Col, { flex: "auto" },
27087
+ React.createElement(antd.Button, { type: "primary", onClick: onAddNewPeriod, htmlType: "submit", loading: loading }, t("ndc:submit"))))));
27003
27088
  }
27004
- function getSubNdcActionContent(record) {
27005
- selectedNdcDetail.current = record;
27006
- return (React.createElement(antd.Table, { components: components, rowClassName: function () { return "editable-row"; }, bordered: true, dataSource: getSubNdcDetails(record.key), columns: columns, showHeader: false, pagination: false }));
27089
+ function mainNdcActionTableContent() {
27090
+ return (React.createElement("div", null,
27091
+ React.createElement(antd.Row, null,
27092
+ React.createElement(antd.Col, { span: 24 },
27093
+ React.createElement(antd.Form, { form: form, component: false },
27094
+ React.createElement(antd.Table, { tableLayout: "fixed", key: tableKey, rowKey: "id", components: components, rowClassName: function () { return "editable-row"; }, bordered: true, loading: loading, dataSource: ndcMainDetailsForPeriod, columns: columns, expandedRowKeys: expandedRowKeys, onExpand: onMainTableRowExpand, expandable: {
27095
+ expandedRowRender: function (record) {
27096
+ return subNdcActionTableContent();
27097
+ },
27098
+ columnWidth: 40,
27099
+ }, onRow: function (record, rowIndex) {
27100
+ return {
27101
+ onClick: function (event) {
27102
+ if (record.id &&
27103
+ isNdcActionEditable(record) &&
27104
+ !isEditing(record)) {
27105
+ form.setFieldsValue(__assign({}, record));
27106
+ setEditingKey(record.id);
27107
+ }
27108
+ },
27109
+ onMouseLeave: function () {
27110
+ if (isEditing(record)) {
27111
+ handleSave(record);
27112
+ }
27113
+ },
27114
+ };
27115
+ }, footer: function () {
27116
+ return isGovernmentUser &&
27117
+ !selectedPeriod.finalized && (React.createElement(antd.Row, { justify: "center" },
27118
+ React.createElement(antd.Button, { onClick: onClickedAddNewNdcDetail, type: "default", style: {
27119
+ marginBottom: 16,
27120
+ width: "100%",
27121
+ } }, t("ndc:addNdcAction"))));
27122
+ } })))),
27123
+ isGovernmentUser && !selectedPeriod.finalized ? (React.createElement(antd.Row, { justify: "end" },
27124
+ React.createElement(antd.Button, { className: "mg-left-1", type: "primary", onClick: onClickedDeletePeriod, htmlType: "submit", loading: loading }, t("ndc:delete")),
27125
+ React.createElement(antd.Button, { className: "mg-left-1", type: "primary", onClick: onClickedFinalizePeriod, htmlType: "submit", loading: loading }, t("ndc:finalize")))) : ("")));
27126
+ }
27127
+ function subNdcActionTableContent(record) {
27128
+ return (React.createElement(antd.Table, { tableLayout: "fixed", rowKey: "id", components: components, rowClassName: function () { return "editable-row"; }, bordered: true, dataSource: subNdcActionsForPeriod, loading: loading, onRow: function (record, rowIndex) {
27129
+ return {
27130
+ onClick: function (event) {
27131
+ if (record.id &&
27132
+ isNdcActionEditable(record) &&
27133
+ !isEditing(record)) {
27134
+ form.setFieldsValue(__assign({}, record));
27135
+ setEditingKey(record.id);
27136
+ }
27137
+ },
27138
+ onMouseLeave: function () {
27139
+ if (isEditing(record)) {
27140
+ handleSave(record);
27141
+ }
27142
+ },
27143
+ };
27144
+ }, columns: columns, showHeader: false, pagination: false }));
27007
27145
  }
27146
+ var onAddNewPeriod = function () { return __awaiter(void 0, void 0, void 0, function () {
27147
+ var periodItem_1, existingIndex, response, addedPeriodItem, updatedPeriodItem_1, exception_3;
27148
+ return __generator(this, function (_a) {
27149
+ switch (_a.label) {
27150
+ case 0:
27151
+ _a.trys.push([0, 4, , 5]);
27152
+ if (!(selectedDateRangeRef && selectedDateRangeRef.current)) return [3 /*break*/, 3];
27153
+ periodItem_1 = {
27154
+ startYear: selectedDateRangeRef.current.startYear,
27155
+ endYear: selectedDateRangeRef.current.endYear,
27156
+ finalized: false,
27157
+ };
27158
+ existingIndex = periodItems.findIndex(function (item) {
27159
+ return inRange(periodItem_1.startYear, item.startYear, item.endYear) ||
27160
+ inRange(periodItem_1.endYear, item.startYear, item.endYear);
27161
+ });
27162
+ if (!(existingIndex === -1)) return [3 /*break*/, 2];
27163
+ return [4 /*yield*/, post("national/programme/addNdcDetailsPeriod", __assign({}, periodItem_1))];
27164
+ case 1:
27165
+ response = _a.sent();
27166
+ if (response && response.data) {
27167
+ addedPeriodItem = response.data;
27168
+ updatedPeriodItem_1 = __assign(__assign({}, addedPeriodItem), { key: addedPeriodItem.id, label: "".concat(addedPeriodItem.startYear, "-").concat(addedPeriodItem.endYear) });
27169
+ setPeriodItems(function (items) { return __spreadArray(__spreadArray([], items, true), [updatedPeriodItem_1], false); });
27170
+ setSelectedPeriod(updatedPeriodItem_1);
27171
+ }
27172
+ return [3 /*break*/, 3];
27173
+ case 2:
27174
+ antd.message.open({
27175
+ type: "error",
27176
+ content: t("ndc:rangeAlreadyExists"),
27177
+ duration: 3,
27178
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27179
+ });
27180
+ _a.label = 3;
27181
+ case 3: return [3 /*break*/, 5];
27182
+ case 4:
27183
+ exception_3 = _a.sent();
27184
+ antd.message.open({
27185
+ type: "error",
27186
+ content: exception_3.message,
27187
+ duration: 3,
27188
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27189
+ });
27190
+ return [3 /*break*/, 5];
27191
+ case 5: return [2 /*return*/];
27192
+ }
27193
+ });
27194
+ }); };
27195
+ var onDateRangeChanged = function (range) {
27196
+ var period = {
27197
+ startYear: Number(moment(range[0]).year()),
27198
+ endYear: Number(moment(range[1]).year()),
27199
+ };
27200
+ selectedDateRangeRef.current = period;
27201
+ };
27008
27202
  var onTabChange = function (key) {
27009
- setSelectedTab(key);
27203
+ var selectedPeriod = periodItems.find(function (item) { return item.key === key; });
27204
+ if (selectedPeriod) {
27205
+ setSelectedPeriod(selectedPeriod);
27206
+ }
27207
+ };
27208
+ var onActionConfirmed = function () { return __awaiter(void 0, void 0, void 0, function () {
27209
+ var actionResponse, exception_4;
27210
+ return __generator(this, function (_a) {
27211
+ switch (_a.label) {
27212
+ case 0:
27213
+ setLoading(true);
27214
+ _a.label = 1;
27215
+ case 1:
27216
+ _a.trys.push([1, 10, , 11]);
27217
+ if (!(actionInfo.action === "Approve")) return [3 /*break*/, 3];
27218
+ return [4 /*yield*/, post("national/programme/approveNdcDetailsAction", {
27219
+ id: actionInfo.recordId,
27220
+ })];
27221
+ case 2:
27222
+ actionResponse = _a.sent();
27223
+ return [3 /*break*/, 9];
27224
+ case 3:
27225
+ if (!(actionInfo.action === "Reject")) return [3 /*break*/, 5];
27226
+ return [4 /*yield*/, post("national/programme/rejectNdcDetailsAction", {
27227
+ id: actionInfo.recordId,
27228
+ })];
27229
+ case 4:
27230
+ actionResponse = _a.sent();
27231
+ return [3 /*break*/, 9];
27232
+ case 5:
27233
+ if (!(actionInfo.action === "Finalize")) return [3 /*break*/, 7];
27234
+ return [4 /*yield*/, post("national/programme/finalizeNdcDetailsPeriod", {
27235
+ id: selectedPeriod.key,
27236
+ })];
27237
+ case 6:
27238
+ actionResponse = _a.sent();
27239
+ return [3 /*break*/, 9];
27240
+ case 7:
27241
+ if (!(actionInfo.action === "Delete")) return [3 /*break*/, 9];
27242
+ return [4 /*yield*/, post("national/programme/deleteNdcDetailsPeriod", {
27243
+ id: selectedPeriod.key,
27244
+ })];
27245
+ case 8:
27246
+ actionResponse = _a.sent();
27247
+ _a.label = 9;
27248
+ case 9: return [3 /*break*/, 11];
27249
+ case 10:
27250
+ exception_4 = _a.sent();
27251
+ antd.message.open({
27252
+ type: "error",
27253
+ content: exception_4.message,
27254
+ duration: 3,
27255
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27256
+ });
27257
+ return [3 /*break*/, 11];
27258
+ case 11:
27259
+ if (actionResponse) {
27260
+ if (actionInfo.action === "Delete") {
27261
+ antd.message.open({
27262
+ type: "success",
27263
+ content: t("ndc:deletePeriodSuccessMsg"),
27264
+ duration: 3,
27265
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27266
+ });
27267
+ fetchNdcDetailPeriods();
27268
+ }
27269
+ else if (actionInfo.action === "Finalize") {
27270
+ antd.message.open({
27271
+ type: "success",
27272
+ content: t("ndc:finalizeSuccessMsg"),
27273
+ duration: 3,
27274
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27275
+ });
27276
+ fetchNdcDetailPeriods();
27277
+ }
27278
+ else if (actionInfo.action === "Approve") {
27279
+ antd.message.open({
27280
+ type: "success",
27281
+ content: t("ndc:approveSuccessMsg"),
27282
+ duration: 3,
27283
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27284
+ });
27285
+ fetchNdcDetailActions();
27286
+ }
27287
+ else if (actionInfo.action === "Reject") {
27288
+ antd.message.open({
27289
+ type: "success",
27290
+ content: t("ndc:rejectSuccessMsg"),
27291
+ duration: 3,
27292
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27293
+ });
27294
+ fetchNdcDetailActions();
27295
+ }
27296
+ }
27297
+ setOpenConfirmationModal(false);
27298
+ setLoading(false);
27299
+ return [2 /*return*/];
27300
+ }
27301
+ });
27302
+ }); };
27303
+ var onActionCanceled = function () {
27304
+ setOpenConfirmationModal(false);
27010
27305
  };
27306
+ var fetchNdcDetailPeriods = function () { return __awaiter(void 0, void 0, void 0, function () {
27307
+ var periods, addNewTab, response, exception_5;
27308
+ return __generator(this, function (_a) {
27309
+ switch (_a.label) {
27310
+ case 0:
27311
+ setLoading(true);
27312
+ _a.label = 1;
27313
+ case 1:
27314
+ _a.trys.push([1, 3, 4, 5]);
27315
+ periods = [];
27316
+ addNewTab = {
27317
+ key: "add_new",
27318
+ label: "Add New",
27319
+ startYear: 0,
27320
+ endYear: 0,
27321
+ finalized: false,
27322
+ deleted: false,
27323
+ };
27324
+ return [4 /*yield*/, get("national/programme/queryNdcDetailsPeriod")];
27325
+ case 2:
27326
+ response = _a.sent();
27327
+ if (response && response.data) {
27328
+ periods = response.data.map(function (period) {
27329
+ return __assign(__assign({}, period), { key: period.id, label: period.finalized ? (React.createElement("span", null,
27330
+ React.createElement(icons.LockOutlined, null),
27331
+ " ",
27332
+ period.startYear,
27333
+ "-",
27334
+ period.endYear,
27335
+ " ")) : ("".concat(period.startYear, "-").concat(period.endYear)) });
27336
+ });
27337
+ }
27338
+ if (isGovernmentUser) {
27339
+ periods.unshift(addNewTab);
27340
+ }
27341
+ setPeriodItems(periods);
27342
+ if (isGovernmentUser) {
27343
+ setSelectedPeriod(addNewTab);
27344
+ }
27345
+ else {
27346
+ setSelectedPeriod(periods[0]);
27347
+ }
27348
+ setLoading(false);
27349
+ return [3 /*break*/, 5];
27350
+ case 3:
27351
+ exception_5 = _a.sent();
27352
+ antd.message.open({
27353
+ type: "error",
27354
+ content: exception_5.message,
27355
+ duration: 3,
27356
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27357
+ });
27358
+ return [3 /*break*/, 5];
27359
+ case 4:
27360
+ setLoading(false);
27361
+ return [7 /*endfinally*/];
27362
+ case 5: return [2 /*return*/];
27363
+ }
27364
+ });
27365
+ }); };
27366
+ var fetchNdcDetailActions = function () { return __awaiter(void 0, void 0, void 0, function () {
27367
+ var response, maxActionId, exception_6;
27368
+ return __generator(this, function (_a) {
27369
+ switch (_a.label) {
27370
+ case 0:
27371
+ setLoading(true);
27372
+ _a.label = 1;
27373
+ case 1:
27374
+ _a.trys.push([1, 3, 4, 5]);
27375
+ return [4 /*yield*/, get("national/programme/queryNdcDetailsAction")];
27376
+ case 2:
27377
+ response = _a.sent();
27378
+ if (response && response.data) {
27379
+ maxActionId = Math.max.apply(Math, response.data.map(function (item) { return item.id; }));
27380
+ setNextAvailableActionId(maxActionId + 1);
27381
+ setNdcActionsList(response.data);
27382
+ }
27383
+ setLoading(false);
27384
+ return [3 /*break*/, 5];
27385
+ case 3:
27386
+ exception_6 = _a.sent();
27387
+ antd.message.open({
27388
+ type: "error",
27389
+ content: exception_6.message,
27390
+ duration: 3,
27391
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27392
+ });
27393
+ return [3 /*break*/, 5];
27394
+ case 4:
27395
+ setLoading(false);
27396
+ return [7 /*endfinally*/];
27397
+ case 5: return [2 /*return*/];
27398
+ }
27399
+ });
27400
+ }); };
27401
+ var fetchMinistries = function () { return __awaiter(void 0, void 0, void 0, function () {
27402
+ var response, ministryOrgDetails, exception_7;
27403
+ return __generator(this, function (_a) {
27404
+ switch (_a.label) {
27405
+ case 0:
27406
+ setLoading(true);
27407
+ _a.label = 1;
27408
+ case 1:
27409
+ _a.trys.push([1, 3, 4, 5]);
27410
+ return [4 /*yield*/, get("national/organisation/getMinistries")];
27411
+ case 2:
27412
+ response = _a.sent();
27413
+ if (response && response.data) {
27414
+ ministryOrgDetails = response.data.map(function (value) {
27415
+ return {
27416
+ value: value.company_companyId,
27417
+ label: value.company_name,
27418
+ };
27419
+ });
27420
+ setMinistryOrgList(ministryOrgDetails);
27421
+ }
27422
+ setLoading(false);
27423
+ return [3 /*break*/, 5];
27424
+ case 3:
27425
+ exception_7 = _a.sent();
27426
+ antd.message.open({
27427
+ type: "error",
27428
+ content: exception_7.message,
27429
+ duration: 3,
27430
+ style: { textAlign: "right", marginRight: 15, marginTop: 10 },
27431
+ });
27432
+ return [3 /*break*/, 5];
27433
+ case 4:
27434
+ setLoading(false);
27435
+ return [7 /*endfinally*/];
27436
+ case 5: return [2 /*return*/];
27437
+ }
27438
+ });
27439
+ }); };
27011
27440
  React.useEffect(function () {
27012
- var defaultNdcDetails = [
27013
- {
27014
- key: 1,
27015
- type: NdcActionType.main,
27016
- startDate: new Date("2019-03-25"),
27017
- endDate: new Date("2020-03-25"),
27018
- nationalPlanObj: "Enhance value addition in key growth opportunities",
27019
- kpi: 25,
27020
- ministry: "Ministry of Environment",
27021
- subNdcDetails: [
27022
- {
27023
- key: 6,
27024
- ndcActionId: 1,
27025
- type: NdcActionType.sub,
27026
- startDate: new Date("2019-03-25"),
27027
- endDate: new Date("2020-03-25"),
27028
- nationalPlanObj: "Enhance value addition in key growth opportunities sub details",
27029
- kpi: 25,
27030
- ministry: "Ministry of Agriculture, Water and Forestry (MAWF)",
27031
- },
27032
- {
27033
- key: 7,
27034
- ndcActionId: 1,
27035
- type: NdcActionType.sub,
27036
- startDate: new Date("2019-03-25"),
27037
- endDate: new Date("2020-03-25"),
27038
- nationalPlanObj: "",
27039
- kpi: "",
27040
- ministry: "",
27041
- },
27042
- ],
27043
- },
27044
- {
27045
- key: 2,
27046
- type: NdcActionType.main,
27047
- startDate: new Date("2019-03-25"),
27048
- endDate: new Date("2019-08-25"),
27049
- nationalPlanObj: "Strengthen the private sector to create 10,000 jobs",
27050
- kpi: 10500,
27051
- ministry: "Ministry of Environment",
27052
- subNdcDetails: [
27053
- {
27054
- key: 8,
27055
- ndcActionId: 2,
27056
- type: NdcActionType.sub,
27057
- startDate: new Date("2019-03-25"),
27058
- endDate: new Date("2020-03-25"),
27059
- nationalPlanObj: "",
27060
- kpi: "",
27061
- ministry: "",
27062
- },
27063
- ],
27064
- },
27065
- {
27066
- key: 12,
27067
- type: NdcActionType.main,
27068
- startDate: new Date("2019-03-25"),
27069
- endDate: new Date("2019-08-25"),
27070
- nationalPlanObj: "Other",
27071
- kpi: 10500,
27072
- ministry: "Ministry of Environment",
27073
- subNdcDetails: [
27074
- {
27075
- key: 8,
27076
- ndcActionId: 12,
27077
- type: NdcActionType.sub,
27078
- startDate: new Date("2019-03-25"),
27079
- endDate: new Date("2020-03-25"),
27080
- nationalPlanObj: "",
27081
- kpi: "",
27082
- ministry: "",
27083
- },
27084
- ],
27085
- },
27086
- {
27087
- key: 3,
27088
- type: NdcActionType.main,
27089
- startDate: new Date("2021-03-25"),
27090
- endDate: new Date("2022-03-25"),
27091
- nationalPlanObj: "Consolidate and increase the stock and quality of productive infrastructure by 50%",
27092
- kpi: 48,
27093
- ministry: "Ministry of Environment",
27094
- subNdcDetails: [
27095
- {
27096
- key: 9,
27097
- ndcActionId: 3,
27098
- type: NdcActionType.sub,
27099
- startDate: new Date("2019-03-25"),
27100
- endDate: new Date("2020-03-25"),
27101
- nationalPlanObj: "",
27102
- kpi: "",
27103
- ministry: "",
27104
- },
27105
- ],
27106
- },
27107
- {
27108
- key: 4,
27109
- type: NdcActionType.main,
27110
- startDate: new Date("2022-03-25"),
27111
- endDate: new Date("2022-05-25"),
27112
- nationalPlanObj: "Enhance the productivity and social wellbeing of the population",
27113
- kpi: 20,
27114
- ministry: "Ministry of Environment",
27115
- subNdcDetails: [
27116
- {
27117
- key: 10,
27118
- ndcActionId: 4,
27119
- type: NdcActionType.sub,
27120
- startDate: new Date("2019-03-25"),
27121
- endDate: new Date("2020-03-25"),
27122
- nationalPlanObj: "",
27123
- kpi: "",
27124
- ministry: "",
27125
- },
27126
- ],
27127
- },
27128
- {
27129
- key: 5,
27130
- type: NdcActionType.main,
27131
- startDate: new Date("2022-03-25"),
27132
- endDate: new Date("2023-03-25"),
27133
- nationalPlanObj: "Strengthen the role of the state in guiding and facilitating development",
27134
- kpi: 10,
27135
- ministry: "Ministry of Environment",
27136
- subNdcDetails: [
27137
- {
27138
- key: 11,
27139
- ndcActionId: 5,
27140
- type: NdcActionType.sub,
27141
- startDate: new Date("2019-03-25"),
27142
- endDate: new Date("2020-03-25"),
27143
- nationalPlanObj: "",
27144
- kpi: "",
27145
- ministry: "",
27146
- },
27147
- ],
27148
- },
27149
- {
27150
- key: 13,
27151
- type: NdcActionType.main,
27152
- startDate: new Date("2022-03-25"),
27153
- endDate: new Date("2023-03-25"),
27154
- nationalPlanObj: "Convert to solar energy",
27155
- kpi: 50000,
27156
- ministry: "Ministry of Environment",
27157
- subNdcDetails: [
27158
- {
27159
- key: 11,
27160
- ndcActionId: 13,
27161
- type: NdcActionType.sub,
27162
- startDate: new Date("2019-03-25"),
27163
- endDate: new Date("2020-03-25"),
27164
- nationalPlanObj: "Convert to solar energy",
27165
- kpi: "3000",
27166
- ministry: "Ministry of Agriculture, Water and Forestry (MAWF)",
27167
- },
27168
- {
27169
- key: 14,
27170
- ndcActionId: 13,
27171
- type: NdcActionType.sub,
27172
- startDate: new Date("2019-03-25"),
27173
- endDate: new Date("2020-03-25"),
27174
- nationalPlanObj: "",
27175
- kpi: "",
27176
- ministry: "",
27177
- },
27178
- ],
27179
- },
27180
- {
27181
- key: 15,
27182
- type: NdcActionType.main,
27183
- startDate: new Date("2022-03-25"),
27184
- endDate: new Date("2023-03-25"),
27185
- nationalPlanObj: "Strengthen the private sector to create jobs",
27186
- kpi: 10000,
27187
- ministry: "Ministry of Environment",
27188
- subNdcDetails: [
27189
- {
27190
- key: 16,
27191
- ndcActionId: 15,
27192
- type: NdcActionType.sub,
27193
- startDate: new Date("2019-03-25"),
27194
- endDate: new Date("2020-03-25"),
27195
- nationalPlanObj: "Strengthen the private sector to create jobs",
27196
- kpi: "7200",
27197
- ministry: "Ministry of Tourism (MoT)",
27198
- },
27199
- {
27200
- key: 17,
27201
- ndcActionId: 15,
27202
- type: NdcActionType.sub,
27203
- startDate: new Date("2019-03-25"),
27204
- endDate: new Date("2020-03-25"),
27205
- nationalPlanObj: "",
27206
- kpi: "",
27207
- ministry: "",
27208
- },
27209
- ],
27210
- },
27211
- {
27212
- key: 18,
27213
- type: NdcActionType.main,
27214
- startDate: new Date("2022-03-25"),
27215
- endDate: new Date("2023-03-25"),
27216
- nationalPlanObj: "Other",
27217
- kpi: "",
27218
- ministry: "Ministry of Environment",
27219
- subNdcDetails: [
27220
- {
27221
- key: 19,
27222
- ndcActionId: 18,
27223
- type: NdcActionType.sub,
27224
- startDate: new Date("2019-03-25"),
27225
- endDate: new Date("2020-03-25"),
27226
- nationalPlanObj: "Strengthen the private sector to create jobs",
27227
- kpi: "",
27228
- ministry: "Ministry of Agriculture, Water and Forestry (MAWF)",
27229
- },
27230
- {
27231
- key: 20,
27232
- ndcActionId: 18,
27233
- type: NdcActionType.sub,
27234
- startDate: new Date("2019-03-25"),
27235
- endDate: new Date("2020-03-25"),
27236
- nationalPlanObj: "",
27237
- kpi: "",
27238
- ministry: "",
27239
- },
27240
- ],
27241
- },
27242
- ];
27243
- var initialPeriods = [
27244
- {
27245
- key: "2019-2020",
27246
- label: "2019-2020",
27247
- start: 2019,
27248
- end: 2020,
27249
- children: ndcDetailsTableContent(),
27250
- },
27251
- {
27252
- key: "2021-2023",
27253
- label: "2021-2023",
27254
- start: 2021,
27255
- end: 2021,
27256
- children: ndcDetailsTableContent(),
27257
- },
27258
- ];
27259
- if (isAddRangeVisible()) {
27260
- initialPeriods.unshift({
27261
- key: "add_new",
27262
- label: "Add New",
27263
- start: 0,
27264
- end: 0,
27265
- children: addNewPeriodContent(),
27266
- });
27267
- }
27268
- addedNdcDetailId.current = 20;
27269
- setPeriodItems(initialPeriods);
27270
- periodItemsRef.current = initialPeriods;
27271
- setNdcDetailsData(defaultNdcDetails);
27441
+ fetchNdcDetailPeriods();
27442
+ fetchNdcDetailActions();
27443
+ fetchMinistries();
27272
27444
  }, []);
27273
- return (React.createElement("div", { className: "ndc-management content-container" },
27445
+ return (React.createElement("div", { className: "ndc-details content-container" },
27274
27446
  React.createElement("div", { className: "title-bar" },
27275
27447
  React.createElement(antd.Row, { justify: "space-between", align: "middle" },
27276
27448
  React.createElement(antd.Col, { span: 20 },
27277
27449
  React.createElement("div", { className: "body-title" }, t("ndc:ndcTitle")),
27278
27450
  React.createElement("div", { className: "body-sub-title" }, t("ndc:ndcSubTitle"))))),
27279
27451
  React.createElement("div", null,
27280
- React.createElement(antd.Tabs, { centered: false, defaultActiveKey: "1", items: periodItems, activeKey: selectedTab, onChange: onTabChange })),
27281
- selectedTab !== "add_new" && (React.createElement("div", null,
27282
- React.createElement("div", null,
27283
- React.createElement(antd.Table, { key: tableKey, components: components, rowClassName: function () { return "editable-row"; }, bordered: true, dataSource: getNdcDetailsForPeriod(), columns: columns, expandable: {
27284
- expandedRowRender: function (record) { return getSubNdcActionContent(record); },
27285
- indentSize: 0,
27286
- defaultExpandedRowKeys: [selectedNdcDetail.current.key],
27287
- }, footer: function () {
27288
- return isAddNdcActionVisible() && (React.createElement(antd.Row, { justify: "center" },
27289
- React.createElement(antd.Button, { onClick: onAddNewNdcDetail, type: "default", style: {
27290
- marginBottom: 16,
27291
- width: "100%",
27292
- } }, t("ndc:addNdcAction"))));
27293
- } }))))));
27452
+ React.createElement(antd.Tabs, { centered: false, defaultActiveKey: "1", items: periodItems, activeKey: selectedPeriod.key, onChange: onTabChange })),
27453
+ React.createElement("div", null, selectedPeriod.key === "add_new"
27454
+ ? addNewPeriodContent()
27455
+ : mainNdcActionTableContent()),
27456
+ React.createElement(UserActionConfirmationModel, { t: t, actionInfo: actionInfo, onActionConfirmed: onActionConfirmed, onActionCanceled: onActionCanceled, openModal: openConfirmationModal, errorMsg: "", loading: loading })));
27294
27457
  };
27295
27458
 
27296
27459
  var ImgWithFallback = function (_a) {
@@ -29083,7 +29246,7 @@ exports.getCreditStageVal = getCreditStageVal;
29083
29246
  exports.getFinancialFields = getFinancialFields;
29084
29247
  exports.getGeneralFields = getGeneralFields;
29085
29248
  exports.getInvestmentStatusEnumVal = getInvestmentStatusEnumVal;
29086
- exports.getNdcActionStatusEnumVal = getNdcActionStatusEnumVal;
29249
+ exports.getNdcActionStatusEnumVal = getNdcActionStatusEnumVal$1;
29087
29250
  exports.getNdcStatusTagType = getNdcStatusTagType;
29088
29251
  exports.getRetirementTypeString = getRetirementTypeString;
29089
29252
  exports.getStageEnumVal = getStageEnumVal;