2015-01-23 13:09:30 +00:00
|
|
|
|
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 =
|
2015-01-23 13:09:30 +00:00
|
|
|
{
|
|
|
|
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
|
|
|
|
2015-01-23 13:09:30 +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)
|
2015-01-23 13:09:30 +00:00
|
|
|
return a.getTime () === b.getTime ();
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2017-04-24 07:47:56 +00:00
|
|
|
|
2015-01-23 13:09:30 +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);
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|
2017-04-24 07:47:56 +00:00
|
|
|
|
2015-01-23 13:09:30 +00:00
|
|
|
,replaceNumber: function (value, token, digits)
|
|
|
|
{
|
|
|
|
return new Number (value).toFixed (parseInt (digits));
|
|
|
|
}
|
2017-04-24 07:47:56 +00:00
|
|
|
|
2015-01-23 13:09:30 +00:00
|
|
|
,replaceString: function (value)
|
|
|
|
{
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
};
|