community-app/app/scripts/controllers/system/DataTableEntryController.js

166 lines
8.4 KiB
JavaScript
Raw Normal View History

2014-03-02 12:09:27 +00:00
(function (module) {
mifosX.controllers = _.extend(module, {
DataTableEntryController: function (scope, location, routeParams, route, resourceFactory, $modal, dateFilter) {
2013-10-08 03:30:51 +00:00
2014-03-02 12:09:27 +00:00
scope.tableName = routeParams.tableName;
scope.entityId = routeParams.entityId;
scope.resourceId = routeParams.resourceId;
scope.formDat = {};
scope.columnHeaders = [];
scope.formData = {};
scope.isViewMode = true;
2013-10-08 03:30:51 +00:00
2014-03-02 12:09:27 +00:00
var reqparams = {datatablename: scope.tableName, entityId: scope.entityId, genericResultSet: 'true'};
if (scope.resourceId) {
reqparams.resourceId = scope.resourceId;
2013-10-08 03:30:51 +00:00
}
2014-03-02 12:09:27 +00:00
resourceFactory.DataTablesResource.getTableDetails(reqparams, function (data) {
for (var i in data.columnHeaders) {
if (data.columnHeaders[i].columnCode) {
if (data.columnHeaders[i].columnName.indexOf("_cd_") > 0) {
var temp = data.columnHeaders[i].columnName.split("_cd_");
data.columnHeaders[i].code = temp[0];
data.columnHeaders[i].columnName = temp[1];
data.columnHeaders[i].codeType = "_cd_";
} else if (data.columnHeaders[i].columnName.indexOf("_cv_") > 0) {
var temp = data.columnHeaders[i].columnName.split("_cv_");
data.columnHeaders[i].code = temp[0];
data.columnHeaders[i].columnName = temp[1];
data.columnHeaders[i].codeType = "_cv_";
}
2014-03-02 12:09:27 +00:00
for (var j in data.columnHeaders[i].columnValues) {
if (data.data[0].row[i] == data.columnHeaders[i].columnValues[j].id) {
data.columnHeaders[i].value = data.columnHeaders[i].columnValues[j].value;
}
}
} else {
data.columnHeaders[i].value = data.data[0].row[i];
}
}
scope.columnHeaders = data.columnHeaders;
});
2013-10-08 03:30:51 +00:00
2014-04-23 10:23:01 +00:00
//return input type
scope.fieldType = function (type) {
var fieldType = "";
if (type) {
if (type == 'STRING' || type == 'INTEGER' || type == 'TEXT' || type == 'DECIMAL') {
fieldType = 'TEXT';
} else if (type == 'CODELOOKUP' || type == 'CODEVALUE') {
fieldType = 'SELECT';
} else if (type == 'DATE') {
fieldType = 'DATE';
}
}
return fieldType;
};
2014-03-02 12:09:27 +00:00
scope.editDatatableEntry = function () {
scope.isViewMode = false;
var colName = scope.columnHeaders[0].columnName;
if (colName == 'id') {
scope.columnHeaders.splice(0, 1);
}
2014-03-02 12:09:27 +00:00
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 {
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) {
scope.formData[scope.columnHeaders[i].columnName] = scope.columnHeaders[i].columnValues[j].id;
}
}
}
}
};
scope.deleteDatatableEntry = function () {
$modal.open({
templateUrl: 'deletedatatable.html',
controller: DatatableDeleteCtrl
});
};
var DatatableDeleteCtrl = function ($scope, $modalInstance) {
$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;
}
2014-03-15 13:32:02 +00:00
$modalInstance.close('delete');
2014-03-02 12:09:27 +00:00
location.path(destination);
});
};
$scope.cancel = function () {
$modalInstance.dismiss('cancel');
};
};
scope.cancel = function () {
route.reload();
};
scope.submit = function () {
this.formData.locale = scope.optlang.code;
this.formData.dateFormat = scope.df;
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], scope.df);
} else if (scope.columnHeaders[i].columnDisplayType == 'CODELOOKUP' || scope.columnHeaders[i].columnDisplayType == 'CODEVALUE') {
this.formData[scope.columnHeaders[i].code+scope.columnHeaders[i].codeType+scope.columnHeaders[i].columnName]=this.formData[scope.columnHeaders[i].columnName];
delete scope.formData[scope.columnHeaders[i].columnName];
};
2014-03-02 12:09:27 +00:00
}
resourceFactory.DataTablesResource.update(reqparams, this.formData, function (data) {
var destination = "";
2014-03-02 12:09:27 +00:00
if (data.loanId) {
destination = '/viewloanaccount/' + data.loanId;
} else if (data.savingsId) {
destination = '/viewsavingaccount/' + data.savingsId;
2014-03-02 12:09:27 +00:00
} else if (data.clientId) {
destination = '/viewclient/' + data.clientId;
} else if (data.groupId) {
if (scope.isCenter) {
2014-03-02 12:09:27 +00:00
destination = '/viewcenter/' + data.groupId;
} else {
2014-03-02 12:09:27 +00:00
destination = '/viewgroup/' + data.groupId;
}
2014-03-02 12:09:27 +00:00
} else if (data.officeId) {
destination = '/viewoffice/' + data.officeId;
}
location.path(destination);
});
};
2013-10-08 03:30:51 +00:00
2014-03-02 12:09:27 +00:00
}
});
mifosX.ng.application.controller('DataTableEntryController', ['$scope', '$location', '$routeParams', '$route', 'ResourceFactory', '$modal', 'dateFilter', mifosX.controllers.DataTableEntryController]).run(function ($log) {
$log.info("DataTableEntryController initialized");
});
2013-10-08 03:30:51 +00:00
}(mifosX.controllers || {}));