From b0e843fd3e4482c7024474b638fad7ed9c51b895 Mon Sep 17 00:00:00 2001 From: Martin Donnelly Date: Tue, 17 Nov 2020 16:31:00 +0000 Subject: [PATCH] Added get function Bumped to version 2.0.2 --- package.json | 2 +- src/utils.js | 103 ++++++++++++++++++--------------------------- ts-src/get.test.ts | 35 +++++++++++++++ ts-src/get.ts | 24 +++++++++++ 4 files changed, 101 insertions(+), 63 deletions(-) create mode 100644 ts-src/get.test.ts create mode 100644 ts-src/get.ts diff --git a/package.json b/package.json index 06a2dc0..ed33991 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@rakh/utils", - "version": "2.0.1", + "version": "2.0.2", "main": "dist/commonjs/index.js", "module": "dist/es/index.js", "jsnext:main": "dist/es/index.js", diff --git a/src/utils.js b/src/utils.js index d92ff8d..8baf302 100644 --- a/src/utils.js +++ b/src/utils.js @@ -6,37 +6,23 @@ */ const partOfDay = (timeString, today) => { console.log(new Date()); - if (timeString === undefined || timeString === null) - timeString = (new Date()).getHours().toString(); + if (timeString === undefined || timeString === null) timeString = new Date().getHours().toString(); - if (today === undefined) - today = false; + if (today === undefined) today = false; const hours = timeString.substring(0, 2); let dayBit; console.log('Hours', hours); - if (hours >= 0 && hours < 4) - dayBit = 'Late Night'; + if (hours >= 0 && hours < 4) dayBit = 'Late Night'; + else if (hours >= 4 && hours < 7) dayBit = 'Early Morning'; + else if (hours >= 7 && hours < 12) dayBit = 'Morning'; + else if (hours >= 12 && hours < 17) dayBit = 'Afternoon'; + else if (hours < 21) dayBit = 'Evening'; + else dayBit = 'Night'; - else if (hours >= 4 && hours < 7) - dayBit = 'Early Morning'; - - else if (hours >= 7 && hours < 12) - dayBit = 'Morning'; - - else if (hours >= 12 && hours < 17) - dayBit = 'Afternoon'; - - else if (hours < 21) - dayBit = 'Evening'; - - else - dayBit = 'Night'; - - if (today) - dayBit = dayBit === 'night' ? 'tonight' : `this ${dayBit}`; + if (today) dayBit = dayBit === 'night' ? 'tonight' : `this ${dayBit}`; console.log('partOfDay', dayBit); @@ -50,7 +36,7 @@ const partOfDay = (timeString, today) => { */ const toHour = (extra = 0) => { const now = new Date(); - return (3600000 - (now.getTime() % 3600000)) + extra; + return 3600000 - (now.getTime() % 3600000) + extra; }; /** @@ -75,10 +61,10 @@ const getWeek = function (d) { var firstThursday = target.valueOf(); target.setMonth(0, 1); if (target.getDay() != 4) { - target.setMonth(0, 1 + ((4 - target.getDay()) + 7) % 7); + target.setMonth(0, 1 + ((4 - target.getDay() + 7) % 7)); } return 1 + Math.ceil((firstThursday - target) / 604800000); -} +}; /** * @@ -91,16 +77,12 @@ const getWeek = function (d) { const distance = (lat1, lon1, lat2, lon2) => { const p = 0.017453292519943295; // Math.PI / 180 const c = Math.cos; - const a = 0.5 - c((lat2 - lat1) * p) / 2 + - c(lat1 * p) * c(lat2 * p) * - (1 - c((lon2 - lon1) * p)) / 2; + const a = 0.5 - c((lat2 - lat1) * p) / 2 + (c(lat1 * p) * c(lat2 * p) * (1 - c((lon2 - lon1) * p))) / 2; return 12742 * Math.asin(Math.sqrt(a)); // 2 * R; R = 6371 km }; -function splitURL(url) { - -} +function splitURL(url) {} /** * @@ -109,8 +91,7 @@ function splitURL(url) { * @param suffix * @returns {string} */ -const maybePluralize = (count, noun, suffix = 's') => - `${count} ${noun}${count !== 1 ? suffix : ''}`; +const maybePluralize = (count, noun, suffix = 's') => `${count} ${noun}${count !== 1 ? suffix : ''}`; /** * @@ -122,7 +103,8 @@ const maybePluralize = (count, noun, suffix = 's') => const debounce = function (fn, time) { let timeout; - return function (...args) { // <-- not an arrow function + return function (...args) { + // <-- not an arrow function const functionCall = () => fn.apply(this, args); clearTimeout(timeout); @@ -176,7 +158,7 @@ const once = function (func) { * @param obj * @returns {boolean|boolean} */ -const isEmpty = obj => [Object, Array].includes((obj || {}).constructor) && !Object.entries((obj || {})).length; +const isEmpty = (obj) => [Object, Array].includes((obj || {}).constructor) && !Object.entries(obj || {}).length; const hasOwnProperty = Object.prototype.hasOwnProperty; @@ -196,11 +178,12 @@ const hasOwn = (obj, prop) => hasOwnProperty.call(obj, prop); * @returns {*} */ const get = (obj, path, defaultValue = undefined) => { - const travel = regexp => - String.prototype.split + const travel = (regexp) => { + return String.prototype.split .call(path, regexp) .filter(Boolean) .reduce((res, key) => (res !== null && res !== undefined ? res[key] : res), obj); + }; const result = travel(/[,[\]]+?/) || travel(/[,[\].]+?/); return result === undefined || result === obj ? defaultValue : result; @@ -208,22 +191,20 @@ const get = (obj, path, defaultValue = undefined) => { const arrayFromObj = (jsonObj, wantedFields) => { return wantedFields.map((key) => { - if (jsonObj.hasOwnProperty(key)) - return jsonObj[key]; + if (jsonObj.hasOwnProperty(key)) return jsonObj[key]; }); }; const extractFromObj = (jsonObj, wantedFields) => { return Object.keys(jsonObj).reduce((obj, key) => { - if (wantedFields.includes(key)) - obj[key] = jsonObj[key]; + if (wantedFields.includes(key)) obj[key] = jsonObj[key]; return obj; }, {}); }; const objectMatcher = (obj, matcher) => { - if (typeof(obj) !== 'object' || obj === null) return false; + if (typeof obj !== 'object' || obj === null) return false; let count = Object.keys(obj).length; const keys = Object.keys(obj); @@ -231,30 +212,28 @@ const objectMatcher = (obj, matcher) => { if (count !== matcher.length) return false; matcher.forEach((item) => { - if (keys.indexOf(item) !== -1) - count--; + if (keys.indexOf(item) !== -1) count--; }); - return (count === 0); + return count === 0; }; exports = { - 'partOfDay': partOfDay, - 'toHour': toHour, - 'hourFloor': hourFloor, - 'getWeek': getWeek, - 'distance': distance, - 'maybePluralize': maybePluralize, - 'debounce': debounce, - 'throttle': throttle, - 'once': once, - 'isEmpty': isEmpty, - 'hasOwn': hasOwn, - 'get': get, - 'arrayFromObj' : arrayFromObj, - 'extractFromObj' : extractFromObj, - 'objectMatcher' : objectMatcher - + partOfDay: partOfDay, + toHour: toHour, + hourFloor: hourFloor, + getWeek: getWeek, + distance: distance, + maybePluralize: maybePluralize, + debounce: debounce, + throttle: throttle, + once: once, + isEmpty: isEmpty, + hasOwn: hasOwn, + get: get, + arrayFromObj: arrayFromObj, + extractFromObj: extractFromObj, + objectMatcher: objectMatcher }; // module.exports = { partOfDay, toHour, hourFloor, distance, maybePluralize, debounce, throttle, once, isEmpty, hasOwn, get, Logger, LocalStorage }; diff --git a/ts-src/get.test.ts b/ts-src/get.test.ts new file mode 100644 index 0000000..5102767 --- /dev/null +++ b/ts-src/get.test.ts @@ -0,0 +1,35 @@ +import { get } from './get'; + +test('Get something from the object', function () { + const o = { a: 1, b: 2 }; + + expect(get(o, 'b')).toEqual(2); +}); + +test('Get something from a complex object', function () { + const o = { + a: 1, + b: { + c: 3, + d: { + e: 5 + } + } + }; + + expect(get(o, 'b')).toEqual({ c: 3, d: { e: 5 } }); +}); + +test('Get a deep item from a complex object', function () { + const o = { + a: 1, + b: { + c: 3, + d: { + e: 5 + } + } + }; + + expect(get(o, 'b.d.e')).toEqual(5); +}); diff --git a/ts-src/get.ts b/ts-src/get.ts new file mode 100644 index 0000000..65d27bc --- /dev/null +++ b/ts-src/get.ts @@ -0,0 +1,24 @@ +/** + * + * @param obj + * @param path + * @param defaultValue + */ +export function get(obj: Object, path: string, defaultValue: any = undefined): any { + const travel = (regexp: any) => { + return String.prototype.split + .call(path, regexp) + .filter(Boolean) + .reduce((res, key) => { + if (res !== null && res !== undefined && res.hasOwnProperty(key)) { + const { value }: any = Object.getOwnPropertyDescriptor(res, key); + return value; + } else { + return res; + } + }, obj); + }; + const result = travel(/[,[\].]+?/); + + return result === undefined || result === obj ? defaultValue : result; +}