Files
Reactive-Resume/src/utils/index.js
2021-02-26 02:14:40 +05:30

143 lines
4.1 KiB
JavaScript

import dayjs from 'dayjs';
import { get, isEmpty, clone } from 'lodash';
export const getModalText = (isEditMode, type, t) =>
isEditMode
? `${t('shared.buttons.edit')} ${type}`
: `${t('shared.buttons.add')} ${type}`;
export const safetyCheck = (section, path = 'items') =>
!!(section && section.visible === true && !isEmpty(section[path]));
export const isItemVisible = (section) =>
section && section.isVisible !== false;
// Thought about creating a generic function to filter out non-visible items
export const genericFilter = (key, data) => {
const clonedData = clone(data);
clonedData[`${key}`].items = clonedData[`${key}`].items.filter((x) =>
isItemVisible(x),
);
return data;
};
export const handleKeyUp = (event, action) => {
(event.which === 13 || event.which === 32) && action();
};
export const isFileImage = (file) => {
const acceptedImageTypes = ['image/jpeg', 'image/png'];
return file && acceptedImageTypes.includes(file.type);
};
export const scaler = (value) => {
const logMax = 2.5;
const logMin = 0.6;
const steps = 20;
const logRange = logMax / logMin;
const logStepSize = logRange ** (1 / steps);
const min = 0;
return logStepSize ** (value - min) * logMin;
};
export const formatDate = ({ date, language = 'en', includeDay = false }) => {
const template = includeDay ? 'DD MMMM YYYY' : 'MMMM YYYY';
return dayjs(date).locale(language.substr(0, 2)).format(template);
};
export const formatDateRange = ({ startDate, endDate, language = 'en' }, t) => {
const start = `${dayjs(startDate)
.locale(language.substr(0, 2))
.format('MMMM YYYY')}`;
const end = dayjs(endDate).isValid()
? `${dayjs(endDate).locale(language.substr(0, 2)).format('MMMM YYYY')}`
: t('shared.forms.present');
return `${start} - ${end}`;
};
export const getFieldProps = (formik, schema, name) => ({
touched: get(formik, `touched.${name}`, false),
error: get(formik, `errors.${name}`, ''),
isRequired: get(schema, `fields.${name}._exclusive.required`),
...formik.getFieldProps(name),
});
export const unsplashPhotoRequestUrl =
'https://source.unsplash.com/featured/400x600';
export const getUnsplashPhoto = async () => {
const response = await fetch(unsplashPhotoRequestUrl);
return response.url;
};
export const hasAddress = (address) =>
!!address.line1 || !!address.line2 || !!address.city || !!address.pincode;
export const hexToRgb = (hex) => {
const shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
hex = hex.replace(shorthandRegex, (m, r, g, b) => r + r + g + g + b + b);
const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
return result
? {
r: parseInt(result[1], 16),
g: parseInt(result[2], 16),
b: parseInt(result[3], 16),
}
: null;
};
export const reorder = (list, startIndex, endIndex) => {
const result = Array.from(list);
const [removed] = result.splice(startIndex, 1);
result.splice(endIndex, 0, removed);
return result;
};
export const move = (
source,
destination,
droppableSource,
droppableDestination,
) => {
const sourceClone = Array.from(source);
const destClone = Array.from(destination);
const [removed] = sourceClone.splice(droppableSource.index, 1);
destClone.splice(droppableDestination.index, 0, removed);
const result = {};
result[droppableSource.droppableId] = sourceClone;
result[droppableDestination.droppableId] = destClone;
return result;
};
export const b64toBlob = (b64Data, contentType = '', sliceSize = 512) => {
const byteCharacters = atob(b64Data);
const byteArrays = [];
for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) {
const slice = byteCharacters.slice(offset, offset + sliceSize);
const byteNumbers = new Array(slice.length);
for (let i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
const byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
const blob = new Blob(byteArrays, { type: contentType });
return blob;
};
export const delay = async (milliseconds) => {
await new Promise((resolve) => setTimeout(resolve, milliseconds));
};