OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/frontend/app/helpers/custom-field-helper.js

94 lines
3.3 KiB

//-- copyright
// OpenProject is a project management system.
// Copyright (C) 2012-2017 the OpenProject Foundation (OPF)
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License version 3.
//
// OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
// Copyright (C) 2006-2017 Jean-Philippe Lang
// Copyright (C) 2010-2013 the ChiliProject Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//
// See doc/COPYRIGHT.rdoc for more details.
//++
module.exports = function(CUSTOM_FIELD_PREFIX, I18n) {
var CustomFieldHelper = {
isCustomFieldKey: function(key) {
return key.substr(0, CUSTOM_FIELD_PREFIX.length) === CUSTOM_FIELD_PREFIX;
},
getCustomFieldId: function(cfKey) {
return parseInt(cfKey.substr(CUSTOM_FIELD_PREFIX.length, 10), 10);
},
booleanCustomFieldValue: function(value) {
switch(value) {
case ('f'):
return I18n.t('js.general_text_No');
case ('t'):
return I18n.t('js.general_text_Yes');
default:
return '';
}
},
userCustomFieldValue: function(value, users) {
if (users && users[value] && users[value].name) {
// try to look up users, assume value is an id
return users[value].name;
}
return CustomFieldHelper.nestedCustomFieldValue(value);
},
versionCustomFieldValue: function(value) {
// I am pretty sure that we need to have the same behavior here as
// we have for the user custom fields.
// However, there is no code that would be using it so ...
return CustomFieldHelper.nestedCustomFieldValue(value);
},
nestedCustomFieldValue: function(value) {
if (value && value.name) {
return value.name;
}
return '';
},
parseNumeric: function(value, parseMethod){
if(value && ((typeof(value) == "string" && value.length > 0) || typeof(value) == "number") && !isNaN(value)){
return parseMethod(value);
}
return '';
},
formatCustomFieldValue: function(value, fieldFormat, users) {
switch(fieldFormat) {
case 'bool':
return CustomFieldHelper.booleanCustomFieldValue(value);
case 'user':
return CustomFieldHelper.userCustomFieldValue(value, users);
case 'version':
return CustomFieldHelper.versionCustomFieldValue(value);
case 'int':
return CustomFieldHelper.parseNumeric(value, parseInt);
case 'float':
return CustomFieldHelper.parseNumeric(value, parseFloat);
default:
return value;
}
}
};
return CustomFieldHelper;
};