mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-14 00:24:07 -08:00
8cefafa47d
* Feature // Created BambooHR Node, Init Simple Api Calls for Employees * BambooHR Added EmployeesFiles, CompanyFiles API Operations * BambooHR / Refactor the code * Bamboo HR Node // Refactor + Optimization of Employee Api Requests * Bamboo HR Node // Refactor + Optimization of EmployeeFiles Api Requests * Bamboo HR Node // Refactor + Optimization of CompanyFiles Api Requests * Bamboo HR Node // Add Reports - Get Reports by ID * Bamboo HR Node // Format BambooAPI Credential files * Bamboo HR Node // Added Account Information API operations * Bamboo HR Node //Add Https Reposnse Code for All API Operations, Implement new Http Helper * Bamboo HR Node // Added Tabular Data Api Operations * Bamboo HR Node // Added Time Off Api Operations * Bamboo HR Node //Fixed bugs for AccountInformation Operation, Uploading Employees File, TimeOff EstimationTime * Bamboo HR Node // Update AccountInformation - UpdateFields Api operation * Bamboo HR Node //Fixed Add and Update Table rows // Tabular Data API Operations * Update AccountInformation - Added TimeOff Operations - Get Requests, Create Request, Create History Item, Fixed Get Types * Bamboo HR Node // Fixed Adjust Time - TimeOff API Operation, Wrote comments, Finished TimeOff Api Operations * Bamboo HR Node // Add Multi choice Property for Employee Operations, Expand and Add new Optional Fields for Creating and Updating Employee, Write Comments, Fixed Employee API operations * Bamboo HR Node // Add Multi choice Property + Update Fields and Write Comments for Employee Files & Company Files & Reports Acc Info API Operation * N8N-2603 Move Company Name Prop to Credentials, Changed Execution Function * N8N-2603 Obtain Employee ID and bind to the response after create an employee, Refactor GetDirectoy to GetAll + update the output of the response * N8N-2603 Refactor, Added ID in responses, Added Pagination to some operations * N8N-2603 Refactor Employee Files to Employee File * N8N-2603 Refactor CompanyFiles to Company File, Refactor CompanyFile:Create -> CompanyFile:addCategory * N8N-2603 Refactor employeeFile:create -> employeeFile:addCategory, Get rid off Account Information resources * N8N-2603 EmployeeFile:Update -> Change ShareWithEmployee Parameter to be boolean * N8N-2603 CompanyFIle:update -> Change shareWithCompany prop to boolean * N8N-2603 Added Load Options for getTimeOffTypeId, Rename AdditionalFields to UpdateFields * N8N-2603 Updated Logo and Border * N8N-2603 Refactor Employees to Employee * N8N-2603 Linter Fixes * N8N-2603 Refactor EmployeeFile:get -> EmployeeFile:download, CompanyFile:get -> CompanyFile:download * N8N-2603 Linter fix * N8N-2603 Linter Fixes * N8N-2603 Hotfix * N8N-2603 Fixed EmployeeFile:Download * N8N-2603 Updated Assertion * N8N-2603 Remove unnecesary description, optimized code, created separate loadOptions file * N8N-2603 Added Download Function for CompanyFile operation * N8N-2603 Added DateTime Fields instead of string, Removed Color prop from Node * N8N-2603 Refactor Del to Delete * N8N-2603 Added Upload Employ File Operation * N8N-2603 Updated Possible Types of the Request * N8N-2603 Fixed Linter Errors * N8N-2603 Hotfix Upload Employee File Description * N8N-2603 Added options to download the report * ⚡ Improvements * ⚡ Improvements * ⚡ Simplify node * ⚡ Fix linting issue * ⚡ Improvements * ⚡ Fix returned mimeType Co-authored-by: ricardo <ricardoespinoza105@gmail.com> Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
177 lines
4.5 KiB
TypeScript
177 lines
4.5 KiB
TypeScript
import {
|
|
IDataObject,
|
|
ILoadOptionsFunctions,
|
|
INodePropertyOptions,
|
|
} from 'n8n-workflow';
|
|
|
|
import {
|
|
apiRequest,
|
|
} from '../transport';
|
|
|
|
// Get all the available channels
|
|
export async function getTimeOffTypeID(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const endPoint = 'meta/time_off/types';
|
|
|
|
const response = await apiRequest.call(this, requestMethod, endPoint, body);
|
|
const timeOffTypeIds = response.body.timeOffTypes;
|
|
|
|
for (const item of timeOffTypeIds) {
|
|
returnData.push({
|
|
name: item.name,
|
|
value: item.id,
|
|
});
|
|
}
|
|
return returnData;
|
|
}
|
|
|
|
export async function getCompanyFileCategories(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const endPoint = 'files/view/';
|
|
|
|
const response = await apiRequest.call(this, requestMethod, endPoint, body);
|
|
const categories = response.categories;
|
|
|
|
for (const category of categories) {
|
|
returnData.push({
|
|
name: category.name,
|
|
value: category.id,
|
|
});
|
|
}
|
|
|
|
returnData.sort(sort);
|
|
|
|
return returnData;
|
|
}
|
|
|
|
export async function getEmployeeDocumentCategories(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const id = this.getCurrentNodeParameter('employeeId') as string;
|
|
|
|
const endPoint = `employees/${id}/files/view/`;
|
|
|
|
const response = await apiRequest.call(this, requestMethod, endPoint, body);
|
|
const categories = response.categories;
|
|
|
|
for (const category of categories) {
|
|
returnData.push({
|
|
name: category.name,
|
|
value: category.id,
|
|
});
|
|
}
|
|
|
|
returnData.sort(sort);
|
|
|
|
return returnData;
|
|
}
|
|
|
|
export async function getEmployeeLocations(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const endPoint = 'meta/lists/';
|
|
|
|
//do not request all data?
|
|
const fields = await apiRequest.call(this, requestMethod, endPoint, body, {}) as [{ fieldId: number, options: [{ id: number, name: string }] }];
|
|
|
|
const options = fields.filter(field => field.fieldId === 18)[0].options;
|
|
|
|
for (const option of options) {
|
|
returnData.push({
|
|
name: option.name,
|
|
value: option.id,
|
|
});
|
|
}
|
|
|
|
returnData.sort(sort);
|
|
|
|
return returnData;
|
|
}
|
|
|
|
export async function getDepartments(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const endPoint = 'meta/lists/';
|
|
|
|
//do not request all data?
|
|
const fields = await apiRequest.call(this, requestMethod, endPoint, body, {}) as [{ fieldId: number, options: [{ id: number, name: string }] }];
|
|
|
|
const options = fields.filter(field => field.fieldId === 4)[0].options;
|
|
|
|
for (const option of options) {
|
|
returnData.push({
|
|
name: option.name,
|
|
value: option.id,
|
|
});
|
|
}
|
|
|
|
returnData.sort(sort);
|
|
|
|
return returnData;
|
|
}
|
|
|
|
export async function getDivisions(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const endPoint = 'meta/lists/';
|
|
|
|
//do not request all data?
|
|
const fields = await apiRequest.call(this, requestMethod, endPoint, body, {}) as [{ fieldId: number, options: [{ id: number, name: string }] }];
|
|
|
|
const options = fields.filter(field => field.fieldId === 1355)[0].options;
|
|
|
|
for (const option of options) {
|
|
returnData.push({
|
|
name: option.name,
|
|
value: option.id,
|
|
});
|
|
}
|
|
|
|
returnData.sort(sort);
|
|
|
|
return returnData;
|
|
}
|
|
|
|
export async function getEmployeeFields(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const body: IDataObject = {};
|
|
const requestMethod = 'GET';
|
|
const endPoint = 'employees/directory';
|
|
|
|
const { fields } = await apiRequest.call(this, requestMethod, endPoint, body);
|
|
|
|
for (const field of fields) {
|
|
returnData.push({
|
|
name: field.name || field.id,
|
|
value: field.id,
|
|
});
|
|
}
|
|
|
|
returnData.sort(sort);
|
|
|
|
returnData.unshift({
|
|
name: '[All]',
|
|
value: 'all',
|
|
});
|
|
|
|
return returnData;
|
|
}
|
|
|
|
//@ts-ignore
|
|
const sort = (a, b) => {
|
|
if (a.name.toLocaleLowerCase() < b.name.toLocaleLowerCase()) { return -1; }
|
|
if (a.name.toLocaleLowerCase() > b.name.toLocaleLowerCase()) { return 1; }
|
|
return 0;
|
|
};
|
|
|
|
|
|
|