mirror of
https://github.com/openMF/community-app.git
synced 2026-02-06 17:36:48 +00:00
206 lines
10 KiB
JavaScript
206 lines
10 KiB
JavaScript
(function (module) {
|
|
mifosX.controllers = _.extend(module, {
|
|
DataTableEntryController: function (scope, location, routeParams, route, resourceFactory, $uibModal, dateFilter) {
|
|
|
|
if (routeParams.tableName) {
|
|
scope.tableName = routeParams.tableName;
|
|
}
|
|
if (routeParams.entityId) {
|
|
scope.entityId = routeParams.entityId;
|
|
}
|
|
if (routeParams.resourceId) {
|
|
scope.resourceId = routeParams.resourceId;
|
|
}
|
|
scope.formDat = {};
|
|
scope.columnHeaders = [];
|
|
scope.formData = {};
|
|
scope.isViewMode = true;
|
|
scope.tf = "HH:mm";
|
|
if(routeParams.mode && routeParams.mode == 'edit'){
|
|
scope.isViewMode = false;
|
|
}
|
|
|
|
var reqparams = {datatablename: scope.tableName, entityId: scope.entityId, genericResultSet: 'true'};
|
|
if (scope.resourceId) {
|
|
reqparams.resourceId = scope.resourceId;
|
|
}
|
|
|
|
resourceFactory.DataTablesResource.getTableDetails(reqparams, function (data) {
|
|
for (var i in data.columnHeaders) {
|
|
if (data.columnHeaders[i].columnCode) {
|
|
//logic for display codeValue instead of codeId in view datatable details
|
|
for (var j in data.columnHeaders[i].columnValues) {
|
|
if(data.columnHeaders[i].columnDisplayType=='CODELOOKUP'){
|
|
if (data.data[0].row[i] == data.columnHeaders[i].columnValues[j].id) {
|
|
data.columnHeaders[i].value = data.columnHeaders[i].columnValues[j].value;
|
|
}
|
|
} else if(data.columnHeaders[i].columnDisplayType=='CODEVALUE'){
|
|
if (data.data[0].row[i] == data.columnHeaders[i].columnValues[j].value) {
|
|
data.columnHeaders[i].value = data.columnHeaders[i].columnValues[j].value;
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
data.columnHeaders[i].value = data.data[0].row[i];
|
|
}
|
|
}
|
|
scope.columnHeaders = data.columnHeaders;
|
|
if(routeParams.mode && routeParams.mode == 'edit'){
|
|
scope.editDatatableEntry();
|
|
}
|
|
});
|
|
|
|
//return input type
|
|
scope.fieldType = function (type) {
|
|
var fieldType = "";
|
|
if (type) {
|
|
if (type == 'CODELOOKUP' || type == 'CODEVALUE') {
|
|
fieldType = 'SELECT';
|
|
} else if (type == 'DATE') {
|
|
fieldType = 'DATE';
|
|
} else if (type == 'DATETIME') {
|
|
fieldType = 'DATETIME';
|
|
} else if (type == 'BOOLEAN') {
|
|
fieldType = 'BOOLEAN';
|
|
} else {
|
|
fieldType = 'TEXT';
|
|
}
|
|
}
|
|
return fieldType;
|
|
};
|
|
|
|
scope.dateTimeFormat = function () {
|
|
for (var i in scope.columnHeaders) {
|
|
if(scope.columnHeaders[i].columnDisplayType == 'DATETIME') {
|
|
return scope.df + " " + scope.tf;
|
|
}
|
|
}
|
|
return scope.df;
|
|
};
|
|
|
|
scope.editDatatableEntry = function () {
|
|
scope.isViewMode = false;
|
|
var colName = scope.columnHeaders[0].columnName;
|
|
if (colName == 'id') {
|
|
scope.columnHeaders.splice(0, 1);
|
|
}
|
|
|
|
colName = scope.columnHeaders[0].columnName;
|
|
if (colName == 'client_id' || colName == 'office_id' || colName == 'group_id' || colName == 'center_id' || colName == 'loan_id' || colName == 'savings_account_id') {
|
|
scope.columnHeaders.splice(0, 1);
|
|
scope.isCenter = colName == 'center_id' ? true : false;
|
|
}
|
|
|
|
for (var i in scope.columnHeaders) {
|
|
|
|
if (scope.columnHeaders[i].columnDisplayType == 'DATE') {
|
|
scope.formDat[scope.columnHeaders[i].columnName] = scope.columnHeaders[i].value;
|
|
} else if (scope.columnHeaders[i].columnDisplayType == 'DATETIME') {
|
|
scope.formDat[scope.columnHeaders[i].columnName] = {};
|
|
if(scope.columnHeaders[i].value != null) {
|
|
scope.formDat[scope.columnHeaders[i].columnName] = {
|
|
date: dateFilter(new Date(scope.columnHeaders[i].value), scope.df),
|
|
time: new Date(scope.columnHeaders[i].value)
|
|
};
|
|
}
|
|
} else {
|
|
scope.formData[scope.columnHeaders[i].columnName] = scope.columnHeaders[i].value;
|
|
}
|
|
if (scope.columnHeaders[i].columnCode) {
|
|
for (var j in scope.columnHeaders[i].columnValues) {
|
|
if (scope.columnHeaders[i].value == scope.columnHeaders[i].columnValues[j].value) {
|
|
if(scope.columnHeaders[i].columnDisplayType=='CODELOOKUP'){
|
|
scope.formData[scope.columnHeaders[i].columnName] = scope.columnHeaders[i].columnValues[j].id;
|
|
} else if(scope.columnHeaders[i].columnDisplayType=='CODEVALUE'){
|
|
scope.formData[scope.columnHeaders[i].columnName] = scope.columnHeaders[i].columnValues[j].value;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
scope.deleteDatatableEntry = function () {
|
|
$uibModal.open({
|
|
templateUrl: 'deletedatatable.html',
|
|
controller: DatatableDeleteCtrl
|
|
});
|
|
};
|
|
var DatatableDeleteCtrl = function ($scope, $uibModalInstance) {
|
|
$scope.delete = function () {
|
|
resourceFactory.DataTablesResource.delete(reqparams, {}, function (data) {
|
|
var destination = "";
|
|
if (data.loanId) {
|
|
destination = '/viewloanaccount/' + data.loanId;
|
|
} else if (data.savingsId) {
|
|
destination = '/viewsavingaccount/' + data.savingsId;
|
|
} else if (data.clientId) {
|
|
destination = '/viewclient/' + data.clientId;
|
|
} else if (data.groupId) {
|
|
if (scope.isCenter) {
|
|
destination = '/viewcenter/' + data.groupId;
|
|
} else {
|
|
destination = '/viewgroup/' + data.groupId;
|
|
}
|
|
} else if (data.officeId) {
|
|
destination = '/viewoffice/' + data.officeId;
|
|
}
|
|
$uibModalInstance.close('delete');
|
|
location.path(destination);
|
|
});
|
|
};
|
|
$scope.cancel = function () {
|
|
$uibModalInstance.dismiss('cancel');
|
|
};
|
|
};
|
|
|
|
scope.cancel = function () {
|
|
if(routeParams.mode){
|
|
window.history.back();
|
|
} else{
|
|
route.reload();
|
|
}
|
|
|
|
};
|
|
|
|
scope.submit = function () {
|
|
this.formData.locale = scope.optlang.code;
|
|
this.formData.dateFormat = scope.dateTimeFormat();
|
|
for (var i = 0; i < scope.columnHeaders.length; i++) {
|
|
if (!_.contains(_.keys(this.formData), scope.columnHeaders[i].columnName)) {
|
|
this.formData[scope.columnHeaders[i].columnName] = "";
|
|
}
|
|
if (scope.columnHeaders[i].columnDisplayType == 'DATE') {
|
|
this.formData[scope.columnHeaders[i].columnName] = dateFilter(this.formDat[scope.columnHeaders[i].columnName], this.formData.dateFormat);
|
|
} else if(scope.columnHeaders[i].columnDisplayType == 'DATETIME') {
|
|
this.formData[scope.columnHeaders[i].columnName] = dateFilter(this.formDat[scope.columnHeaders[i].columnName].date, scope.df) + " " +
|
|
dateFilter(this.formDat[scope.columnHeaders[i].columnName].time, scope.tf);
|
|
}
|
|
}
|
|
resourceFactory.DataTablesResource.update(reqparams, this.formData, function (data) {
|
|
var destination = "";
|
|
if (data.loanId) {
|
|
destination = '/viewloanaccount/' + data.loanId;
|
|
} else if (data.savingsId) {
|
|
destination = '/viewsavingaccount/' + data.savingsId;
|
|
} else if (data.clientId) {
|
|
destination = '/viewclient/' + data.clientId;
|
|
} else if (data.groupId) {
|
|
if (scope.isCenter) {
|
|
destination = '/viewcenter/' + data.groupId;
|
|
} else {
|
|
destination = '/viewgroup/' + data.groupId;
|
|
}
|
|
} else if (data.officeId) {
|
|
destination = '/viewoffice/' + data.officeId;
|
|
}
|
|
location.path(destination);
|
|
});
|
|
};
|
|
|
|
}
|
|
});
|
|
mifosX.ng.application.controller('DataTableEntryController', ['$scope', '$location', '$routeParams', '$route', 'ResourceFactory', '$uibModal', 'dateFilter', mifosX.controllers.DataTableEntryController]).run(function ($log) {
|
|
$log.info("DataTableEntryController initialized");
|
|
});
|
|
}(mifosX.controllers || {}));
|