🧲 New features Custom user role permissions Employee edit form updated Employee daily task list Attendance and employee distribution charts on dashboard Improvements to company structure and company assets module Improved tables for displaying data in several modules Faster data loading (specially for employee module) Initials based profile pictures Re-designed login page Re-designed user profile page Improvements to filtering New REST endpoints for employee qualifications 🐛 Bug fixes Fixed, issue with managers being able to create performance reviews for employees who are not their direct reports Fixed, issues related to using full profile image instead of using smaller version of profile image Changing third gender to other Improvements and fixes for internal frontend data caching
138 lines
4.2 KiB
JavaScript
138 lines
4.2 KiB
JavaScript
/*
|
|
Copyright (c) 2018 [Glacies UG, Berlin, Germany] (http://glacies.de)
|
|
Developer: Thilina Hasantha (http://lk.linkedin.com/in/thilinah | https://github.com/thilinah)
|
|
*/
|
|
import React from 'react';
|
|
import { Space } from 'antd';
|
|
import AdapterBase from './ReactModalAdapterBase';
|
|
|
|
/*
|
|
* CustomFieldAdapter
|
|
*/
|
|
|
|
class ReactCustomFieldAdapter extends AdapterBase {
|
|
constructor(endPoint, tab, filter, orderBy) {
|
|
super(endPoint, tab, filter, orderBy);
|
|
this.tableType = '';
|
|
}
|
|
|
|
getDataMapping() {
|
|
return [
|
|
'id',
|
|
'name',
|
|
'display',
|
|
'display_order',
|
|
];
|
|
}
|
|
|
|
getHeaders() {
|
|
return [
|
|
{ sTitle: 'ID', bVisible: false },
|
|
{ sTitle: 'Name' },
|
|
{ sTitle: 'Display Status' },
|
|
{ sTitle: 'Priority' },
|
|
];
|
|
}
|
|
|
|
getTableColumns() {
|
|
return [
|
|
{
|
|
title: 'Name',
|
|
dataIndex: 'name',
|
|
sorter: true,
|
|
width: '25%',
|
|
},
|
|
{
|
|
title: 'Display Status',
|
|
dataIndex: 'display',
|
|
width: '35%',
|
|
},
|
|
{
|
|
title: 'Priority',
|
|
dataIndex: 'display_order',
|
|
width: '10%',
|
|
},
|
|
];
|
|
}
|
|
|
|
getFormFields() {
|
|
return [
|
|
['id', { label: 'ID', type: 'hidden' }],
|
|
['name', { label: 'Name', type: 'text', validation: '' }],
|
|
['display', { label: 'Display Status', type: 'select', source: [['Form', 'Show'], ['Hidden', 'Hidden']] }],
|
|
['field_type', { label: 'Field Type', type: 'select', source: [['text', 'Text Field'], ['textarea', 'Text Area'], ['select', 'Select'], ['select2', 'Select2'], ['select2multi', 'Multi Select'], ['fileupload', 'File Upload'], ['date', 'Date'], ['datetime', 'Date Time'], ['time', 'Time']] }],
|
|
['field_label', { label: 'Field Label', type: 'text', validation: '' }],
|
|
['field_validation', {
|
|
label: 'Validation', type: 'select2', validation: 'none', sort: 'none', 'null-label': 'Required', 'allow-null': true, source: [['none', 'None'], ['number', 'Number'], ['numberOrEmpty', 'Number or Empty'], ['float', 'Decimal'], ['email', 'Email'], ['emailOrEmpty', 'Email or Empty']],
|
|
}],
|
|
['field_options', {
|
|
label: 'Field Options',
|
|
type: 'datagroup',
|
|
form: [
|
|
['label', { label: 'Label', type: 'text', validation: '' }],
|
|
['value', { label: 'Value', type: 'text', validation: 'none' }],
|
|
],
|
|
html: '<div id="#_id_#" class="panel panel-default"><div class="panel-body">#_delete_##_edit_#<span style="color:#999;font-size:13px;font-weight:bold">#_label_#</span>:#_value_#</div></div>',
|
|
columns: [
|
|
{
|
|
title: 'Label',
|
|
dataIndex: 'label',
|
|
key: 'label',
|
|
},
|
|
{
|
|
title: 'Option Value',
|
|
dataIndex: 'value',
|
|
key: 'value',
|
|
},
|
|
],
|
|
validation: 'none',
|
|
}],
|
|
['display_order', { label: 'Priority', type: 'text', validation: 'number' }],
|
|
['display_section', { label: 'Display Section', type: 'text', validation: 'none' }],
|
|
];
|
|
}
|
|
|
|
setTableType(type) {
|
|
this.tableType = type;
|
|
}
|
|
|
|
doCustomValidation(params) {
|
|
const validateName = function (str) {
|
|
const name = /^[a-z][a-z0-9._]+$/;
|
|
return str != null && name.test(str);
|
|
};
|
|
|
|
if (!validateName(params.name)) {
|
|
return 'Invalid name for custom field';
|
|
}
|
|
|
|
|
|
return null;
|
|
}
|
|
|
|
forceInjectValuesBeforeSave(params) {
|
|
const data = [params.name]; const options = []; let
|
|
optionsData;
|
|
data.push({});
|
|
data[1].label = params.field_label;
|
|
data[1].type = params.field_type;
|
|
data[1].validation = params.field_validation;
|
|
if (['select', 'select2', 'select2multi'].indexOf(params.field_type) >= 0) {
|
|
optionsData = (params.field_options === '' || params.field_options === undefined)
|
|
? [] : JSON.parse(params.field_options);
|
|
for (const index in optionsData) {
|
|
options.push([optionsData[index].value, optionsData[index].label]);
|
|
}
|
|
data[1].source = options;
|
|
}
|
|
if (params.field_validation == null || params.field_validation === undefined) {
|
|
params.field_validation = '';
|
|
}
|
|
params.data = JSON.stringify(data);
|
|
params.type = this.tableType;
|
|
return params;
|
|
}
|
|
}
|
|
|
|
export default ReactCustomFieldAdapter;
|