0
1
Fork 0
hedera-web-mindshore/js/vn/value.js

207 lines
4.4 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
var VnDate = require ('./date');
2017-04-10 15:17:56 +00:00
/**
2017-10-10 11:58:25 +00:00
* Clones a simple value. A simple value is any value that is not an array,
* object or function. If non-simple value is passed, the same object reference
* is returned.
*
* @param {*} value The value to be copied
* @return {*} The value copy
*/
function simpleClone (value)
{
if (value instanceof Date)
return value.clone ();
return value;
}
/**
* Checks if two simple values are equal using the strict equality operator. For
* information about simple values see simpleClone() function.
2017-04-10 15:17:56 +00:00
*
* @param {*} a Value to compare to
* @param {*} b Value to compare with
2017-04-21 10:53:15 +00:00
* @return {boolean} %true if they are equal, %false otherwise
2017-04-10 15:17:56 +00:00
*/
2017-10-10 11:58:25 +00:00
function simpleEquals (a, b)
2017-04-10 15:17:56 +00:00
{
2017-04-21 10:53:15 +00:00
if (a === b)
2017-04-10 15:17:56 +00:00
return true;
if (a instanceof Date && b instanceof Date)
return a.getTime () === b.getTime ();
return false;
}
2017-04-19 06:16:37 +00:00
/**
2017-10-10 11:58:25 +00:00
* Calculates differences between two simple key-value objects.
2017-04-19 06:16:37 +00:00
*
* @param {Object} orgObject Value to compare to
* @param {Object} newObject Value to compare with
* @return {Object} The differences or %null if there are no differences
*/
function diff (orgObject, newObject)
{
var diff = {};
2017-04-24 07:47:56 +00:00
for (var key in orgObject)
2017-04-21 10:53:15 +00:00
if (!simpleEquals (orgObject[key], newObject[key]))
diff[key] = simpleClone (newObject[key]);
2017-04-19 06:16:37 +00:00
2017-04-24 07:47:56 +00:00
for (var key in newObject)
2017-04-21 10:53:15 +00:00
if (orgObject[key] === undefined && newObject[key] !== undefined)
diff[key] = simpleClone (newObject[key]);
2017-04-19 06:16:37 +00:00
if (Object.keys (diff).length > 0)
return diff;
return null;
}
2017-04-24 07:47:56 +00:00
/**
2017-10-10 11:58:25 +00:00
* Calculates new differences between two simple key-value objects.
2017-04-24 07:47:56 +00:00
*
* @param {Object} orgObject Value to compare to
* @param {Object} newObject Value to compare with
* @return {Object} The differences or %null if there are no differences
*/
function partialDiff (orgObject, newObject)
{
var diff = {};
for (var key in newObject)
if (!simpleEquals (orgObject[key], newObject[key]))
diff[key] = simpleClone (newObject[key]);
if (Object.keys (diff).length > 0)
return diff;
return null;
}
2017-10-10 11:58:25 +00:00
/**
* Clones a simple key-value object in wich properties are simple values. For
* information about simple values see simpleClone() function.
*
* @param {*} object The object to be cloned
* @return The cloned object
*/
2017-04-24 07:47:56 +00:00
function kvClone (object)
{
var copy = {};
2017-05-11 15:38:31 +00:00
for (var key in object)
2017-04-24 07:47:56 +00:00
copy[key] = simpleClone (object[key]);
return copy;
}
2017-04-21 10:53:15 +00:00
/**
2017-10-10 11:58:25 +00:00
* Checks if two values are equal, it also checks objects. Basic values are
* compared using the strict equality operator.
2017-04-21 10:53:15 +00:00
*
* @param {*} a Value to compare to
* @param {*} b Value to compare with
* @return {boolean} %true if they are equal, %false otherwise
*/
2017-10-10 11:58:25 +00:00
function equals (a, b)
2017-04-21 10:53:15 +00:00
{
if (a === b)
return true;
if (a instanceof Date && b instanceof Date)
return a.getTime () === b.getTime ();
2017-10-10 11:58:25 +00:00
if (a && b && (typeof a === 'object') && (typeof b === 'object'))
{
for (var key in a)
if (!equals (a[key], b[key]))
return false;
for (var key in b)
if (a[key] === undefined && b[key] !== undefined)
return false;
return true;
}
2017-04-21 10:53:15 +00:00
return false;
}
2017-04-19 06:16:37 +00:00
/**
* Returns a formated string.
*
* @param {Object} formatString The base string template
* @param {...} arguments Format parameters
2017-04-21 10:53:15 +00:00
* @return {string} The formated string
2017-04-19 06:16:37 +00:00
*/
function sprintf (formatString)
{
var args = arguments;
if (args.length <= 1)
return formatString;
var i = 1;
return formatString.replace (/%[s|d]/g, function ()
{
return args[i++];
});
}
2016-09-26 09:28:47 +00:00
module.exports =
{
regexpNumber: /%\.([0-9]+)d/g
,regexpString: /%s/g
2017-04-10 15:17:56 +00:00
,equals: equals
2017-04-19 06:16:37 +00:00
,diff: diff
2017-04-24 07:47:56 +00:00
,partialDiff: partialDiff
,kvClone: kvClone
2017-04-21 10:53:15 +00:00
,simpleClone: simpleClone
,simpleEquals: simpleEquals
2017-04-19 06:16:37 +00:00
,sprintf: sprintf
2017-04-10 15:17:56 +00:00
,compare: function (a, b)
{
if (a === b)
return true;
2017-03-23 16:20:51 +00:00
if (a instanceof Date && b instanceof Date)
return a.getTime () === b.getTime ();
return false;
}
2017-04-24 07:47:56 +00:00
,format: function (value, format)
{
if (value === null || value === undefined)
return '';
if (format)
switch (typeof value)
{
case 'number':
return format.replace (this.regexpNumber,
this.replaceNumber.bind (null, value));
case 'string':
return format.replace (this.regexpString,
this.replaceString.bind (null, value));
case 'object':
if (value instanceof Date)
2016-09-26 09:28:47 +00:00
return VnDate.strftime (value, format);
}
return value;
}
2017-04-24 07:47:56 +00:00
,replaceNumber: function (value, token, digits)
{
return new Number (value).toFixed (parseInt (digits));
}
2017-04-24 07:47:56 +00:00
,replaceString: function (value)
{
return value;
}
};