Commit 33db1c322ed95d1f12668e9dbd8fb11969166339
Merge branch 'master' of http://service.routetopa.eu:7480/WebCompDev/COMPONENTS
Showing
16 changed files
with
141 additions
and
45 deletions
bower_components/JSDataChecker/.bower.json
1 | 1 | { |
2 | 2 | "name": "JSDataChecker", |
3 | - "version": "0.0.7", | |
3 | + "version": "0.0.8", | |
4 | 4 | "homepage": "https://github.com/donpir/JSDataChecker", |
5 | 5 | "authors": [ |
6 | 6 | "'Donato Pirozzi <'donatopirozzi@gmail.com'>" |
... | ... | @@ -22,11 +22,11 @@ |
22 | 22 | "polywc": "https://github.com/donpir/polywc.git#master" |
23 | 23 | }, |
24 | 24 | "private": false, |
25 | - "_release": "0.0.7", | |
25 | + "_release": "0.0.8", | |
26 | 26 | "_resolution": { |
27 | 27 | "type": "version", |
28 | - "tag": "v0.0.7", | |
29 | - "commit": "f6d2d47543510eeefc2e0a9bda86dec09ac4b092" | |
28 | + "tag": "v0.0.8", | |
29 | + "commit": "862e4d5fe56d629ae7ef8aadb728b1add3af01d9" | |
30 | 30 | }, |
31 | 31 | "_source": "https://github.com/donpir/JSDataChecker.git", |
32 | 32 | "_target": "~0.0.6", | ... | ... |
bower_components/JSDataChecker/bower.json
bower_components/JSDataChecker/build.cmd
1 | 1 | del jsdatachecker.min.js |
2 | -uglifyjs src\ArrayUtils.js src\DataTypeConverter.js src\DataTypesUtils.js --compress -o jsdatachecker.min.js | |
3 | 2 | \ No newline at end of file |
3 | +uglifyjs src\ArrayUtils.js src\DataTypeConverter.js src\DataTypesUtils.js src\DataTypeHierarchy.js --compress -o jsdatachecker.min.js | |
4 | 4 | \ No newline at end of file | ... | ... |
bower_components/JSDataChecker/jsdatachecker.min.js
1 | -function ArrayUtils(){}function DataTypeConverter(){this._fields=[],this._numOfRows=0}function DataTypesUtils(){}ArrayUtils.TestAndSet=function(arr,key,object){return"undefined"==typeof arr?null:0==Array.isArray(arr)?null:("undefined"==typeof arr[key]&&(arr[key]=object),arr[key])},ArrayUtils.TestAndInitializeKey=function(obj,key,value){return"undefined"==typeof obj?null:("undefined"==typeof obj[key]&&(obj[key]=value),obj[key])},ArrayUtils.TestAndIncrement=function(arr,key){var exists=arr[key];return"undefined"==typeof exists&&(arr[key]=0),arr[key]++,arr},ArrayUtils.toFieldsArray=function(obj){var fields=[];return ArrayUtils.IteratorOverKeys(obj,function(field,key){field.key=key,fields.push(field)}),fields},ArrayUtils.IteratorOverKeys=function(arr,callback){for(var property in arr)if(arr.hasOwnProperty(property)){var item=arr[property];callback(item,property)}},ArrayUtils.FindMinMax=function(arr,fncompare){var max1=null,max2=null;for(var key in arr)null==max1||fncompare(arr[key],max1.value)?(max2=max1,max1={index:-1,key:key,value:arr[key]}):(null==max2||fncompare(arr[key],max2.value))&&(max2={index:-1,key:key,value:arr[key]});return{first:max1,second:max2}},ArrayUtils.isArray=function(arr){return Array.isArray(arr)?arr.length>0:!1},DataTypeConverter.TYPES={TEXT:{value:0,name:"TEXT"},CODE:{value:1,name:"CODE"},NUMBER:{value:2,name:"NUMBER"},OBJECT:{value:3,name:"OBJECT"},BOOL:{value:5,name:"BOOL"},CONST:{value:6,name:"CONST"},CATEGORY:{value:7,name:"CATEGORY"},DATETIME:{value:8,name:"DATETIME"},EMPTY:{value:101,name:"NULL"}},DataTypeConverter.SUBTYPES={PERCENTAGE:{value:1e3,name:"PERCENTAGE"},LATITUDE:{value:1001,name:"LATITUDE"},LONGITUDE:{value:1002,name:"LONGITUDE"}},DataTypeConverter.prototype=function(){var _analyseDataTypes=function(fields){ArrayUtils.IteratorOverKeys(fields,function(field){if(field._inferredTypes[DataTypeConverter.TYPES.CODE.name]){var confidence=field._inferredTypes[DataTypeConverter.TYPES.CODE.name]/field.numOfItems,_numericalInferredType=field._inferredTypes[DataTypeConverter.TYPES.NUMBER.name];return"undefined"!=typeof _numericalInferredType&&(confidence+=_numericalInferredType/field.numOfItems),field.type=DataTypeConverter.TYPES.CODE.name,void(field.typeConfidence=confidence)}var max=ArrayUtils.FindMinMax(field._inferredTypes,function(curval,lastval){return curval>lastval}),tkey=max.first.key;tkey===DataTypeConverter.TYPES.EMPTY.name&&null!=max.second&&"undefined"!=typeof max.second&&(tkey=max.second.key),field.type=tkey,field.typeConfidence=field._inferredTypes[max.first.key]/field.numOfItems})},_processInferType=function(value){if(null===value||"undefined"==typeof value)return DataTypeConverter.TYPES.EMPTY;if("object"==typeof value)return DataTypeConverter.TYPES.OBJECT;if(/^0[0-9]+$/.test(value))return DataTypeConverter.TYPES.CODE;var isnumber=DataTypesUtils.FilterFloat(value);if(isNaN(isnumber)!==!0)return DataTypeConverter.TYPES.NUMBER;var _date=DataTypesUtils.FilterDateTime(value);return 0==isNaN(_date)&&null!=_date?DataTypeConverter.TYPES.DATETIME:DataTypeConverter.TYPES.TEXT},jsonTraverse=function(json,fieldKeys,callback){var stack=[],numOfRows=0;for(stack.push({item:json,fieldKeyIndex:0});stack.length>0;){var stackTask=stack.pop(),item=stackTask.item,fieldKeyIndex=stackTask.fieldKeyIndex,fieldKey=fieldKeys[fieldKeyIndex];if("*"!=fieldKey||0!=ArrayUtils.isArray(item))if("*"!=fieldKey||1!=ArrayUtils.isArray(item)){var jsonSubtree=item[fieldKey];if(Array.isArray(jsonSubtree))for(var j=0;j<jsonSubtree.length;j++){var jsonItem=jsonSubtree[j];stack.push({item:jsonItem,fieldKeyIndex:fieldKeyIndex+1})}else stack.push({item:jsonSubtree,fieldKeyIndex:fieldKeyIndex+1})}else for(var cell,j=0;j<item.length&&(cell=item[j]);j++)stack.push({item:cell,fieldKeyIndex:fieldKeyIndex}),numOfRows++;else{var sProcessedKeys=fieldKeys.slice(0,fieldKeyIndex).toString();ArrayUtils.IteratorOverKeys(item,function(value,key){var curKey=sProcessedKeys+(sProcessedKeys.length>0?",":"")+key,_value=callback(value,key,curKey,numOfRows);item[key]=_value}),numOfRows++}}};return{constructor:DataTypeConverter,cast:function(metadata,options){return"undefined"!=typeof options&&null!=options||(options={castThresholdConfidence:1,castIfNull:!1}),this.convert(metadata,options)},convert:function(metadata,options){var lastRowIndex=0,numOfRows=0,numOfValues=0,datasetErrors=0,datasetMissingValues=0;return"undefined"!=typeof options&&null!=options||(options={castThresholdConfidence:1,castIfNull:!1}),jsonTraverse(metadata.dataset,metadata.fieldKeys,function(value,key,traversedKeys,rowIndex){var inferredType=metadata.types[traversedKeys];numOfValues++,lastRowIndex!=rowIndex&&(lastRowIndex=rowIndex,numOfRows++),null==value||"undefined"==typeof value||0==(value+"").length;var isCast=inferredType.typeConfidence>=options.castThresholdConfidence;if(inferredType.type==DataTypeConverter.TYPES.NUMBER.name&&isCast){var number=parseFloat(value);return isNaN(number)?(datasetErrors++,value):number}return value}),metadata.qualityIndex.notNullValues=(numOfValues-datasetMissingValues)/numOfValues,metadata.qualityIndex.errors=(numOfValues-datasetErrors)/numOfValues,metadata},inferJsonDataType:function(json,fieldKeys){var stack=[],fieldsType={},numOfRows=0;if("undefined"==typeof fieldKeys)throw"IllegalArgumentException: undefined json path to analyse.";for(stack.push({item:json,fieldKeyIndex:0});stack.length>0;){var stackTask=stack.pop(),item=stackTask.item,fieldKeyIndex=stackTask.fieldKeyIndex,fieldKey=fieldKeys[fieldKeyIndex];if("*"!=fieldKey||0!=ArrayUtils.isArray(item))if("*"==fieldKey&&ArrayUtils.isArray(item))for(var cell,j=0;j<item.length&&(cell=item[j]);j++)stack.push({item:cell,fieldKeyIndex:fieldKeyIndex}),numOfRows++;else{var jsonSubtree=item[fieldKey];if(Array.isArray(jsonSubtree))for(var j=0;j<jsonSubtree.length;j++){var jsonItem=jsonSubtree[j];stack.push({item:jsonItem,fieldKeyIndex:fieldKeyIndex+1})}else stack.push({item:jsonSubtree,fieldKeyIndex:fieldKeyIndex+1})}else{var sProcessedKeys=fieldKeys.slice(0,fieldKeyIndex).toString();ArrayUtils.IteratorOverKeys(item,function(item,key){var inferredType=_processInferType(item),curKey=sProcessedKeys+(0==sProcessedKeys.length?"":",")+key,fieldType=ArrayUtils.TestAndInitializeKey(fieldsType,curKey,{name:curKey,_inferredTypes:[],_inferredValues:[],numOfItems:0});fieldType.numOfItems++,ArrayUtils.TestAndIncrement(fieldType._inferredTypes,inferredType.name),inferredType===DataTypeConverter.TYPES.TEXT&&ArrayUtils.TestAndIncrement(fieldType._inferredValues,item)}),numOfRows++}}_analyseDataTypes(fieldsType);var quality={homogeneity:1,completeness:1,totalNullValues:0,totalValues:0};ArrayUtils.IteratorOverKeys(fieldsType,function(fieldType){quality.totalValues+=fieldType.numOfItems,quality.homogeneity*=fieldType.typeConfidence,fieldType.totalNullValues=0,fieldType._inferredTypes.hasOwnProperty(DataTypeConverter.TYPES.EMPTY.name)&&(fieldType.totalNullValues=fieldType._inferredTypes[DataTypeConverter.TYPES.EMPTY.name],quality.totalNullValues+=fieldType.totalNullValues)}),quality.homogeneity=Math.round(100*quality.homogeneity)/100;var totFullValues=quality.totalValues-quality.totalNullValues;quality.completeness=Math.round(totFullValues/quality.totalValues*100)/100;var warningsTextual="";return ArrayUtils.IteratorOverKeys(fieldsType,function(fieldType){fieldType.errorsDescription="";var description="";if(fieldType.typeConfidence<1){var incorrect=fieldType.numOfItems-fieldType.totalNullValues-fieldType._inferredTypes[fieldType.type];if(incorrect>0){description+="The column <"+fieldType.name+"> has the type <"+fieldType.type+">";var verb=1==incorrect?" value is":" values are";description+=", but "+incorrect+verb+" not a "+fieldType.type}}fieldType.totalNullValues>0&&(description+="The column <"+fieldType.name+"> has "+fieldType.totalNullValues+" EMPTY value",fieldType.totalNullValues>1&&(description+="s")),description.length>0&&(description+="."),fieldType.errorsDescription=description,warningsTextual+=description}),{dataset:json,fieldKeys:fieldKeys,types:fieldsType,qualityIndex:quality,warningsTextual:warningsTextual}},inferDataTypeOfValue:function(value){return _processInferType(value)}}}(),DataTypesUtils.FilterTime=function(value){var expTime=/^[0-9]{2}:[0-9]{2}(:[0-9]{2})?(\+[0-9]{2}:[0-9]{2})?$/;if(0==expTime.test(value))return null;var splitted=value.split(/[:|\+]/),expNumber=/^[0-9]{2}$/,HH=expNumber.test(splitted[0])?parseInt(splitted[0]):0,MM=expNumber.test(splitted[1])?parseInt(splitted[1]):0,SS=splitted.length>=3&&expNumber.test(splitted[2])?parseInt(splitted[2]):0,dt=new Date;return dt.setHours(HH),dt.setMinutes(MM),dt.setSeconds(SS),dt},DataTypesUtils.FilterDateTime=function(value){var _dtSplitted=value.split(/[T|\s]/);if(2==_dtSplitted.length){var dtTime=DataTypesUtils.FilterTime(_dtSplitted[1]);if(null==dtTime)return null;var dtDateTime=DataTypesUtils.FilterDate(_dtSplitted[0],dtTime);return dtDateTime}var dtDate=DataTypesUtils.FilterDate(value);if(null!=dtDate)return dtDate;var dtTime=DataTypesUtils.FilterTime(value);return dtTime},DataTypesUtils.FilterDate=function(value,dtDate){if(null==dtDate&&(dtDate=new Date),/^[0-9][0-9][0-9][0-9]\-[0-9][0-9]$/.test(value)){var year=parseInt(value.substring(0,4)),month=parseInt(value.substring(5));return dtDate.setYear(year),dtDate.setMonth(month),dtDate}var expDate=/^[0-9]{4}(\-|\/)[0-9]{2}((\-|\/)[0-9]{2})?$/;if(expDate.test(value)){var splitted=value.split(/[\-|\/]/),year=parseInt(splitted[0]),month=parseInt(splitted[1]),day=3==splitted.length?parseInt(splitted[2]):0;return dtDate.setYear(year),dtDate.setMonth(month),dtDate.setDate(day),dtDate}if(expDate=/^[0-9]{2}(\-|\/)[0-9]{2}(\-|\/)[0-9]{4}$/,expDate.test(value)){var splitted=value.split(/[\-|\/]/),year=parseInt(splitted[2]),month=parseInt(splitted[1]),day=parseInt(splitted[0]);return dtDate.setYear(year),dtDate.setMonth(month),dtDate.setDate(day),dtDate}return null},DataTypesUtils.FilterFloat=function(value){return/^(\-|\+)?((0|([1-9][0-9]*))(\.[0-9]+)?|Infinity)$/.test(value)?Number(value):NaN},DataTypesUtils.DecimalPlaces=function(num){var match=(""+num).match(/(?:\.(\d+))?(?:[eE]([+-]?\d+))?$/);return match?Math.max(0,(match[1]?match[1].length:0)-(match[2]?+match[2]:0)):0}; | |
2 | 1 | \ No newline at end of file |
2 | +function ArrayUtils(){}function DataTypeConverter(){this._fields=[],this._numOfRows=0}function DataTypesUtils(){}function DataTypeHierarchy(){}ArrayUtils.TestAndSet=function(arr,key,object){return"undefined"==typeof arr?null:0==Array.isArray(arr)?null:("undefined"==typeof arr[key]&&(arr[key]=object),arr[key])},ArrayUtils.TestAndInitializeKey=function(obj,key,value){return"undefined"==typeof obj?null:("undefined"==typeof obj[key]&&(obj[key]=value),obj[key])},ArrayUtils.TestAndIncrement=function(arr,key){var exists=arr[key];return"undefined"==typeof exists&&(arr[key]=0),arr[key]++,arr},ArrayUtils.toFieldsArray=function(obj){var fields=[];return ArrayUtils.IteratorOverKeys(obj,function(field,key){field.key=key,fields.push(field)}),fields},ArrayUtils.IteratorOverKeys=function(arr,callback){for(var property in arr)if(arr.hasOwnProperty(property)){var item=arr[property];callback(item,property)}},ArrayUtils.FindMinMax=function(arr,fncompare){var max1=null,max2=null;for(var key in arr)null==max1||fncompare(arr[key],max1.value)?(max2=max1,max1={index:-1,key:key,value:arr[key]}):(null==max2||fncompare(arr[key],max2.value))&&(max2={index:-1,key:key,value:arr[key]});return{first:max1,second:max2}},ArrayUtils.isArray=function(arr){return Array.isArray(arr)?arr.length>0:!1},DataTypeConverter.TYPES={TEXT:{value:0,name:"TEXT"},CODE:{value:1,name:"CODE"},NUMBER:{value:2,name:"NUMBER"},OBJECT:{value:3,name:"OBJECT"},BOOL:{value:5,name:"BOOL"},CONST:{value:6,name:"CONST"},CATEGORY:{value:7,name:"CATEGORY"},DATETIME:{value:8,name:"DATETIME"},EMPTY:{value:101,name:"NULL"}},DataTypeConverter.SUBTYPES={PERCENTAGE:{value:1e3,name:"PERCENTAGE"},LATITUDE:{value:1001,name:"LATITUDE"},LONGITUDE:{value:1002,name:"LONGITUDE"}},DataTypeConverter.prototype=function(){var _analyseDataTypes=function(fields){ArrayUtils.IteratorOverKeys(fields,function(field){if(field._inferredTypes[DataTypeConverter.TYPES.CODE.name]){var confidence=field._inferredTypes[DataTypeConverter.TYPES.CODE.name]/field.numOfItems,_numericalInferredType=field._inferredTypes[DataTypeConverter.TYPES.NUMBER.name];return"undefined"!=typeof _numericalInferredType&&(confidence+=_numericalInferredType/field.numOfItems),field.type=DataTypeConverter.TYPES.CODE.name,void(field.typeConfidence=confidence)}var max=ArrayUtils.FindMinMax(field._inferredTypes,function(curval,lastval){return curval>lastval}),tkey=max.first.key;tkey===DataTypeConverter.TYPES.EMPTY.name&&null!=max.second&&"undefined"!=typeof max.second&&(tkey=max.second.key),field.type=tkey,field.typeConfidence=field._inferredTypes[max.first.key]/field.numOfItems})},_processInferType=function(value){if(null===value||"undefined"==typeof value)return DataTypeConverter.TYPES.EMPTY;if("object"==typeof value)return DataTypeConverter.TYPES.OBJECT;if(/^0[0-9]+$/.test(value))return DataTypeConverter.TYPES.CODE;var isnumber=DataTypesUtils.FilterFloat(value);if(isNaN(isnumber)!==!0)return DataTypeConverter.TYPES.NUMBER;var _date=DataTypesUtils.FilterDateTime(value);return 0==isNaN(_date)&&null!=_date?DataTypeConverter.TYPES.DATETIME:DataTypeConverter.TYPES.TEXT},jsonTraverse=function(json,fieldKeys,callback){var stack=[],numOfRows=0;for(stack.push({item:json,fieldKeyIndex:0});stack.length>0;){var stackTask=stack.pop(),item=stackTask.item,fieldKeyIndex=stackTask.fieldKeyIndex,fieldKey=fieldKeys[fieldKeyIndex];if("*"!=fieldKey||0!=ArrayUtils.isArray(item))if("*"!=fieldKey||1!=ArrayUtils.isArray(item)){var jsonSubtree=item[fieldKey];if(Array.isArray(jsonSubtree))for(var j=0;j<jsonSubtree.length;j++){var jsonItem=jsonSubtree[j];stack.push({item:jsonItem,fieldKeyIndex:fieldKeyIndex+1})}else stack.push({item:jsonSubtree,fieldKeyIndex:fieldKeyIndex+1})}else for(var cell,j=0;j<item.length&&(cell=item[j]);j++)stack.push({item:cell,fieldKeyIndex:fieldKeyIndex}),numOfRows++;else{var sProcessedKeys=fieldKeys.slice(0,fieldKeyIndex).toString();ArrayUtils.IteratorOverKeys(item,function(value,key){var curKey=sProcessedKeys+(sProcessedKeys.length>0?",":"")+key,_value=callback(value,key,curKey,numOfRows);item[key]=_value}),numOfRows++}}};return{constructor:DataTypeConverter,cast:function(metadata,options){return"undefined"!=typeof options&&null!=options||(options={castThresholdConfidence:1,castIfNull:!1}),this.convert(metadata,options)},convert:function(metadata,options){var lastRowIndex=0,numOfRows=0,numOfValues=0,datasetErrors=0,datasetMissingValues=0;return"undefined"!=typeof options&&null!=options||(options={castThresholdConfidence:1,castIfNull:!1}),jsonTraverse(metadata.dataset,metadata.fieldKeys,function(value,key,traversedKeys,rowIndex){var inferredType=metadata.types[traversedKeys];numOfValues++,lastRowIndex!=rowIndex&&(lastRowIndex=rowIndex,numOfRows++),null==value||"undefined"==typeof value||0==(value+"").length;var isCast=inferredType.typeConfidence>=options.castThresholdConfidence;if(inferredType.type==DataTypeConverter.TYPES.NUMBER.name&&isCast){var number=parseFloat(value);return isNaN(number)?(datasetErrors++,value):number}return value}),metadata.qualityIndex.notNullValues=(numOfValues-datasetMissingValues)/numOfValues,metadata.qualityIndex.errors=(numOfValues-datasetErrors)/numOfValues,metadata},inferJsonDataType:function(json,fieldKeys){var stack=[],fieldsType={},numOfRows=0;if("undefined"==typeof fieldKeys)throw"IllegalArgumentException: undefined json path to analyse.";for(stack.push({item:json,fieldKeyIndex:0});stack.length>0;){var stackTask=stack.pop(),item=stackTask.item,fieldKeyIndex=stackTask.fieldKeyIndex,fieldKey=fieldKeys[fieldKeyIndex];if("*"!=fieldKey||0!=ArrayUtils.isArray(item))if("*"==fieldKey&&ArrayUtils.isArray(item))for(var cell,j=0;j<item.length&&(cell=item[j]);j++)stack.push({item:cell,fieldKeyIndex:fieldKeyIndex}),numOfRows++;else{var jsonSubtree=item[fieldKey];if(Array.isArray(jsonSubtree))for(var j=0;j<jsonSubtree.length;j++){var jsonItem=jsonSubtree[j];stack.push({item:jsonItem,fieldKeyIndex:fieldKeyIndex+1})}else stack.push({item:jsonSubtree,fieldKeyIndex:fieldKeyIndex+1})}else{var sProcessedKeys=fieldKeys.slice(0,fieldKeyIndex).toString();ArrayUtils.IteratorOverKeys(item,function(item,key){var inferredType=_processInferType(item),curKey=sProcessedKeys+(0==sProcessedKeys.length?"":",")+key,fieldType=ArrayUtils.TestAndInitializeKey(fieldsType,curKey,{name:curKey,_inferredTypes:[],_inferredValues:[],numOfItems:0});fieldType.numOfItems++,ArrayUtils.TestAndIncrement(fieldType._inferredTypes,inferredType.name),inferredType===DataTypeConverter.TYPES.TEXT&&ArrayUtils.TestAndIncrement(fieldType._inferredValues,item)}),numOfRows++}}_analyseDataTypes(fieldsType);var quality={homogeneity:1,completeness:1,totalNullValues:0,totalValues:0};ArrayUtils.IteratorOverKeys(fieldsType,function(fieldType){quality.totalValues+=fieldType.numOfItems,quality.homogeneity*=fieldType.typeConfidence,fieldType.totalNullValues=0,fieldType._inferredTypes.hasOwnProperty(DataTypeConverter.TYPES.EMPTY.name)&&(fieldType.totalNullValues=fieldType._inferredTypes[DataTypeConverter.TYPES.EMPTY.name],quality.totalNullValues+=fieldType.totalNullValues)}),quality.homogeneity=Math.round(100*quality.homogeneity)/100;var totFullValues=quality.totalValues-quality.totalNullValues;quality.completeness=Math.round(totFullValues/quality.totalValues*100)/100;var warningsTextual="";return ArrayUtils.IteratorOverKeys(fieldsType,function(fieldType){fieldType.errorsDescription="";var description="";if(fieldType.typeConfidence<1){var incorrect=fieldType.numOfItems-fieldType.totalNullValues-fieldType._inferredTypes[fieldType.type];if(incorrect>0){description+="The column <"+fieldType.name+"> has the type <"+fieldType.type+">";var verb=1==incorrect?" value is":" values are";description+=", but "+incorrect+verb+" not a "+fieldType.type}}fieldType.totalNullValues>0&&(description+="The column <"+fieldType.name+"> has "+fieldType.totalNullValues+" EMPTY value",fieldType.totalNullValues>1&&(description+="s")),description.length>0&&(description+="."),fieldType.errorsDescription=description,warningsTextual+=description}),{dataset:json,fieldKeys:fieldKeys,types:fieldsType,qualityIndex:quality,warningsTextual:warningsTextual}},inferDataTypeOfValue:function(value){return _processInferType(value)}}}(),DataTypesUtils.FilterTime=function(value){var expTime=/^[0-9]{2}:[0-9]{2}(:[0-9]{2})?(\+[0-9]{2}:[0-9]{2})?$/;if(0==expTime.test(value))return null;var splitted=value.split(/[:|\+]/),expNumber=/^[0-9]{2}$/,HH=expNumber.test(splitted[0])?parseInt(splitted[0]):0,MM=expNumber.test(splitted[1])?parseInt(splitted[1]):0,SS=splitted.length>=3&&expNumber.test(splitted[2])?parseInt(splitted[2]):0,dt=new Date;return dt.setHours(HH),dt.setMinutes(MM),dt.setSeconds(SS),dt},DataTypesUtils.FilterDateTime=function(value){var _dtSplitted=value.split(/[T|\s]/);if(2==_dtSplitted.length){var dtTime=DataTypesUtils.FilterTime(_dtSplitted[1]);if(null==dtTime)return null;var dtDateTime=DataTypesUtils.FilterDate(_dtSplitted[0],dtTime);return dtDateTime}var dtDate=DataTypesUtils.FilterDate(value);if(null!=dtDate)return dtDate;var dtTime=DataTypesUtils.FilterTime(value);return dtTime},DataTypesUtils.FilterDate=function(value,dtDate){if(null==dtDate&&(dtDate=new Date),/^[0-9][0-9][0-9][0-9]\-[0-9][0-9]$/.test(value)){var year=parseInt(value.substring(0,4)),month=parseInt(value.substring(5));return dtDate.setYear(year),dtDate.setMonth(month),dtDate}var expDate=/^[0-9]{4}(\-|\/)[0-9]{2}((\-|\/)[0-9]{2})?$/;if(expDate.test(value)){var splitted=value.split(/[\-|\/]/),year=parseInt(splitted[0]),month=parseInt(splitted[1]),day=3==splitted.length?parseInt(splitted[2]):0;return dtDate.setYear(year),dtDate.setMonth(month),dtDate.setDate(day),dtDate}if(expDate=/^[0-9]{2}(\-|\/)[0-9]{2}(\-|\/)[0-9]{4}$/,expDate.test(value)){var splitted=value.split(/[\-|\/]/),year=parseInt(splitted[2]),month=parseInt(splitted[1]),day=parseInt(splitted[0]);return dtDate.setYear(year),dtDate.setMonth(month),dtDate.setDate(day),dtDate}return null},DataTypesUtils.FilterFloat=function(value){return/^(\-|\+)?((0|([1-9][0-9]*))(\.[0-9]+)?|Infinity)$/.test(value)?Number(value):NaN},DataTypesUtils.DecimalPlaces=function(num){var match=(""+num).match(/(?:\.(\d+))?(?:[eE]([+-]?\d+))?$/);return match?Math.max(0,(match[1]?match[1].length:0)-(match[2]?+match[2]:0)):0},DataTypeHierarchy.HIERARCHY=[],DataTypeHierarchy.HIERARCHY[DataTypeConverter.TYPES.TEXT.name]=[DataTypeConverter.TYPES.TEXT.name],DataTypeHierarchy.HIERARCHY[DataTypeConverter.TYPES.NUMBER.name]=[DataTypeConverter.TYPES.NUMBER.name,DataTypeConverter.TYPES.TEXT.name],DataTypeHierarchy.HIERARCHY[DataTypeConverter.TYPES.DATETIME.name]=[DataTypeConverter.TYPES.DATETIME.name,DataTypeConverter.TYPES.TEXT.name],DataTypeHierarchy.HIERARCHY[DataTypeConverter.SUBTYPES.LATITUDE.name]=[DataTypeConverter.SUBTYPES.LATITUDE.name,DataTypeConverter.TYPES.NUMBER.name,DataTypeConverter.TYPES.TEXT.name],DataTypeHierarchy.HIERARCHY[DataTypeConverter.SUBTYPES.LONGITUDE.name]=[DataTypeConverter.SUBTYPES.LONGITUDE.name,DataTypeConverter.TYPES.NUMBER.name,DataTypeConverter.TYPES.TEXT.name],DataTypeHierarchy.canConvert=function(fromType,toType){var arrConvertableTypes=DataTypeHierarchy.HIERARCHY[fromType],idx=arrConvertableTypes.indexOf(toType);return idx>=0}; | |
3 | 3 | \ No newline at end of file | ... | ... |
bower_components/JSDataChecker/src/DataTypeConverter.js
... | ... | @@ -38,8 +38,6 @@ DataTypeConverter.TYPES = { |
38 | 38 | |
39 | 39 | DATETIME : { value: 8, name: "DATETIME" }, |
40 | 40 | |
41 | - | |
42 | - | |
43 | 41 | EMPTY : { value: 101, name: "NULL" } |
44 | 42 | }; |
45 | 43 | |
... | ... | @@ -138,14 +136,14 @@ DataTypeConverter.prototype = (function () { |
138 | 136 | field.typeConfidence = field._inferredTypes[max.first.key] / field.numOfItems; |
139 | 137 | |
140 | 138 | |
141 | - /*//TODO: improve this piece of code. | |
139 | + //TODO: improve this piece of code. | |
142 | 140 | //LAT/LNG. |
143 | - var fieldName = field.name.toLowerCase(); | |
141 | + /*var fieldName = field.name.toLowerCase(); | |
144 | 142 | var isLatType = (field.type === DataTypeConverter.TYPES.LATITUDE.name); |
145 | 143 | var fieldNameContainsLat = fieldName.indexOf('lat') >= 0; |
146 | 144 | var fieldNameContainsLon = fieldName.indexOf('ng') >= 0; //It could be 'lng'. |
147 | 145 | if (isLatType == true && fieldNameContainsLat == false && fieldNameContainsLon == true) { |
148 | - field.type = DataTypeConverter.TYPES.LONGITUDE.name; | |
146 | + field.type = DataTypeConverter.TYPES.LONGITUDE.name; | |
149 | 147 | }*/ |
150 | 148 | |
151 | 149 | //BOOLEAN. | ... | ... |
bower_components/JSDataChecker/src/DataTypeHierarchy.js
0 โ 100644
1 | +/* | |
2 | + ** This file is part of JSDataChecker. | |
3 | + ** | |
4 | + ** JSDataChecker is free software: you can redistribute it and/or modify | |
5 | + ** it under the terms of the GNU General Public License as published by | |
6 | + ** the Free Software Foundation, either version 3 of the License, or | |
7 | + ** (at your option) any later version. | |
8 | + ** | |
9 | + ** JSDataChecker is distributed in the hope that it will be useful, | |
10 | + ** but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 | + ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 | + ** GNU General Public License for more details. | |
13 | + ** | |
14 | + ** You should have received a copy of the GNU General Public License | |
15 | + ** along with JSDataChecker. If not, see <http://www.gnu.org/licenses/>. | |
16 | + ** | |
17 | + ** Copyright (C) 2016 JSDataChecker - Donato Pirozzi (donatopirozzi@gmail.com) | |
18 | + ** Distributed under the GNU GPL v3. For full terms see the file LICENSE. | |
19 | + ** License: http://www.gnu.org/licenses/gpl.html GPL version 3 or higher | |
20 | + **/ | |
21 | + | |
22 | +function DataTypeHierarchy() { | |
23 | + | |
24 | +};//EndConstructor. | |
25 | + | |
26 | +DataTypeHierarchy.HIERARCHY = [ ]; | |
27 | + | |
28 | +DataTypeHierarchy.HIERARCHY[DataTypeConverter.TYPES.TEXT.name] = [ DataTypeConverter.TYPES.TEXT.name ]; | |
29 | +DataTypeHierarchy.HIERARCHY[DataTypeConverter.TYPES.NUMBER.name] = [ DataTypeConverter.TYPES.NUMBER.name, DataTypeConverter.TYPES.TEXT.name]; | |
30 | +DataTypeHierarchy.HIERARCHY[DataTypeConverter.TYPES.DATETIME.name] = [ DataTypeConverter.TYPES.DATETIME.name, DataTypeConverter.TYPES.TEXT.name ]; | |
31 | + | |
32 | +DataTypeHierarchy.HIERARCHY[DataTypeConverter.SUBTYPES.LATITUDE.name] = [ DataTypeConverter.SUBTYPES.LATITUDE.name, | |
33 | + DataTypeConverter.TYPES.NUMBER.name, DataTypeConverter.TYPES.TEXT.name]; | |
34 | +DataTypeHierarchy.HIERARCHY[DataTypeConverter.SUBTYPES.LONGITUDE.name] = [ DataTypeConverter.SUBTYPES.LONGITUDE.name, | |
35 | + DataTypeConverter.TYPES.NUMBER.name, DataTypeConverter.TYPES.TEXT.name]; | |
36 | + | |
37 | +DataTypeHierarchy.canConvert = function (fromType, toType) { | |
38 | + var arrConvertableTypes = DataTypeHierarchy.HIERARCHY[fromType]; | |
39 | + var idx = arrConvertableTypes.indexOf(toType); | |
40 | + return (idx >= 0); | |
41 | +};//EndFunction. | ... | ... |
controllets/data-table-controllet/data-table-controllet.html
... | ... | @@ -216,6 +216,9 @@ |
216 | 216 | <paper-tooltip for="{{_fieldId(index)}}" offset="8"> |
217 | 217 | <p> |
218 | 218 | <span class="type">{{_type()}}:</span> {{item.type}} |
219 | + <!--<template is="dom-if" if={{item.errorsDescription}}>--> | |
220 | + <!--({{item.subType}})--> | |
221 | + <!--</template>--> | |
219 | 222 | <template is="dom-if" if={{item.errorsDescription.length}}> |
220 | 223 | <br/> |
221 | 224 | <span class="warning">{{_warning()}}:</span> {{item.errorsDescription}} |
... | ... | @@ -301,6 +304,7 @@ |
301 | 304 | var result = converter.inferJsonDataType(data, ["*"]); |
302 | 305 | result = converter.cast(result); |
303 | 306 | this.fields = ArrayUtils.toFieldsArray(result.types); |
307 | +// console.log(this.fields); | |
304 | 308 | this.data = result.dataset; |
305 | 309 | |
306 | 310 | this.filter = ""; | ... | ... |
controllets/providers-utility-controllet/providers-utility-controllet.html
... | ... | @@ -16,6 +16,8 @@ |
16 | 16 | } |
17 | 17 | }; |
18 | 18 | |
19 | + //utility non legato al provider, aggiungere copy e creare un altro js!!! | |
20 | + | |
19 | 21 | //jsdatachecker |
20 | 22 | utility_getFields = function(types) { |
21 | 23 | return Object.keys(types).map(function(key) { return key; }); |
... | ... | @@ -36,26 +38,7 @@ |
36 | 38 | return selectedIndices; |
37 | 39 | }; |
38 | 40 | |
39 | - // utility_getResourceUrl = function(url) { | |
40 | - // //CKAN | |
41 | - // var strDatasetPos = url.indexOf('/dataset/'); | |
42 | - // var strResourcePos = url.indexOf('/resource/'); | |
43 | - // if (strDatasetPos >= 0 && strResourcePos > strDatasetPos) { | |
44 | - // var urlSegment1 = url.substring(0, strDatasetPos); | |
45 | - // var urlResourceEnd = url.indexOf('/', strResourcePos + 10); | |
46 | - // var resourceId = url.substring(strResourcePos + 10, urlResourceEnd); | |
47 | - // return urlSegment1 + "/api/action/datastore_search?resource_id=" + resourceId; | |
48 | - // } | |
49 | - // //OPENDATASOFT | |
50 | - // var strExploreDatasetPos = url.indexOf('/explore/dataset/'); | |
51 | - // if (strExploreDatasetPos >= 0) { | |
52 | - // var urlSegment1 = url.substring(0, strExploreDatasetPos); | |
53 | - // var datasetEnd = url.indexOf(strExploreDatasetPos + 17, '/'); | |
54 | - // var datasetId = url.substring(strExploreDatasetPos + 17, datasetEnd >= 0 ? datasetEnd : url.length); | |
55 | - // return urlSegment1 + '/api/records/1.0/search?dataset=' + datasetId; | |
56 | - // } | |
57 | - // return ""; | |
58 | - // }; | |
41 | + | |
59 | 42 | </script> |
60 | 43 | |
61 | 44 | <dom-module id="providers-utility-controllet"> | ... | ... |
controllets/select-data-controllet/select-data-controllet.html
... | ... | @@ -130,7 +130,15 @@ |
130 | 130 | }, |
131 | 131 | |
132 | 132 | getData : function() { |
133 | - return this.data; | |
133 | + //return datatable.getData | |
134 | + //this.fields = "*" | |
135 | + var data = alasql_selectData(this.data, this.fields, this.filters); | |
136 | + var converter = new DataTypeConverter(); | |
137 | + var result = converter.inferJsonDataType(data, ["*"]); | |
138 | + result = converter.cast(result); | |
139 | + data = result.dataset; | |
140 | + | |
141 | + return data; | |
134 | 142 | }, |
135 | 143 | |
136 | 144 | setSelectedFields : function(selectedFields) { | ... | ... |
controllets/select-visualization-controllet/demo/index.html
... | ... | @@ -9,6 +9,10 @@ |
9 | 9 | <link rel="stylesheet" href="../../shared_js/perfect-scrollbar/css/perfect-scrollbar.min.css"> |
10 | 10 | |
11 | 11 | <script src="../../../locales/controllet_ln.js"></script> |
12 | + | |
13 | + <script type="text/javascript" src="../../../alasql-utility/alasql.min.js"></script> | |
14 | + <script type="text/javascript" src="../../../alasql-utility/alasql-utility.js"></script> | |
15 | + | |
12 | 16 | <script> |
13 | 17 | ln["localization"] = "en"; |
14 | 18 | </script> | ... | ... |
controllets/select-visualization-controllet/select-datalet-inputs.html
... | ... | @@ -303,9 +303,21 @@ |
303 | 303 | // temp.push({name: name + " " + (i-4), description: description, selection: selection}); |
304 | 304 | // } |
305 | 305 | |
306 | + else if (inputs.length == 2 && inputs[1].selection == "*") {// | |
307 | + name = inputs[1].name; | |
308 | + description = inputs[1].description; | |
309 | + selection = inputs[1].selection; | |
310 | + temp = [inputs[0]]; | |
311 | + temp.push({name: name + " 1", description: description, selection: selection}); | |
312 | + for (var i = 3; i < this.fields.length; i++) | |
313 | + temp.push({name: name + " " +(i-1), description: description, selection: selection}); | |
314 | + } | |
315 | + | |
306 | 316 | this.inputs = this._copy(temp); |
307 | 317 | |
308 | 318 | this.selectedFields = new Array(temp.length); |
319 | + | |
320 | + this.selectedFields2 = new Array(temp.length); | |
309 | 321 | }, |
310 | 322 | |
311 | 323 | fireReady : function() { |
... | ... | @@ -381,15 +393,23 @@ |
381 | 393 | this.expert = !this.expert; |
382 | 394 | }, |
383 | 395 | |
396 | + getFields : function () { | |
397 | + return this.selectedFields2; | |
398 | + }, | |
399 | + | |
384 | 400 | _addInput : function(e){ |
385 | 401 | var selectedFields = this._copy(this.selectedFields); |
386 | 402 | |
387 | 403 | var ddl_index = $(e.target).parents("paper-dropdown-menu")[0].id; |
404 | + | |
388 | 405 | var index = e.target.id; |
389 | 406 | selectedFields[ddl_index] = this.fields[index]; |
390 | 407 | |
391 | 408 | this.selectedFields = this._copy(selectedFields); |
392 | 409 | |
410 | +// console.log(this.inputs[ddl_index].name); | |
411 | + this.selectedFields2[ddl_index] = {field: this.fields[index], input: this.inputs[ddl_index].name}; | |
412 | + | |
393 | 413 | if(!this._isReady()) { |
394 | 414 | this.$.group_by.setAttribute("disabled", ""); |
395 | 415 | |
... | ... | @@ -518,6 +538,9 @@ |
518 | 538 | // if(key.indexOf("BubbleContent") > -1) { |
519 | 539 | // return ln["BubbleContent" + "_" +ln["localization"]] + key.slice(-2); |
520 | 540 | // } |
541 | + if(key.indexOf("NumericYAxis") > -1) { | |
542 | + return ln["NumericYAxis" + "_" +ln["localization"]] + key.slice(-2); | |
543 | + } | |
521 | 544 | |
522 | 545 | return ln[key + "_" +ln["localization"]]; |
523 | 546 | }, | ... | ... |
controllets/select-visualization-controllet/select-datalet-inputs_series.html
controllets/select-visualization-controllet/select-datalet-options.html
... | ... | @@ -137,11 +137,11 @@ |
137 | 137 | |
138 | 138 | <template is="dom-repeat" items={{options}} index-as="index"> |
139 | 139 | <div class="inputs"> |
140 | - <template is="dom-if" if="{{_checkType(item.type, 'text')}}"> | |
140 | + <template is="dom-if" if="{{_checkType(item.type, 'TEXT')}}"> | |
141 | 141 | <paper-input label={{_getLabelName(item.name)}} on-change="_updateParams"></paper-input> |
142 | 142 | </template> |
143 | 143 | |
144 | - <template is="dom-if" if="{{_checkType(item.type, 'list')}}"> | |
144 | + <template is="dom-if" if="{{_checkType(item.type, 'LIST')}}"> | |
145 | 145 | <paper-dropdown-menu label={{_getLabelName(item.name)}}> |
146 | 146 | <paper-menu class="dropdown-content" selected = 0> |
147 | 147 | <!--<paper-item on-tap="_updateParams"></paper-item>--> | ... | ... |
controllets/select-visualization-controllet/select-visualization-controllet.html
... | ... | @@ -342,9 +342,13 @@ |
342 | 342 | |
343 | 343 | this.selectedFields = inputs.getSelectedFields(); |
344 | 344 | |
345 | +// console.log(inputs.getFields()); | |
346 | + | |
345 | 347 | this.params = {'data-url' : this.dataUrl};//?????????????????? |
346 | 348 | // this.params = {}; |
347 | 349 | |
350 | + this.params["selectedFields"] = JSON.stringify(inputs.getFields()); | |
351 | + | |
348 | 352 | this.params["filters"] = JSON.stringify(this.filters); |
349 | 353 | this.params["aggregators"] = JSON.stringify(inputs.getAggregators()); |
350 | 354 | this.params["orders"] = JSON.stringify(inputs.getOrders()); |
... | ... | @@ -356,7 +360,9 @@ |
356 | 360 | |
357 | 361 | var data = alasql_complexSelectData(this.data, this.selectedFields, this.filters, inputs.getAggregators(), inputs.getOrders()); |
358 | 362 | data = transformData(data, this.selectedFields, true); |
359 | - this.params["data"] = JSON.stringify(data).replace(/'/g, "'"); | |
363 | + | |
364 | + //use cache | |
365 | +// this.params["data"] = JSON.stringify(data).replace(/'/g, "'"); | |
360 | 366 | |
361 | 367 | var dataletParams ={ |
362 | 368 | component: this.selectedDatalet+"-datalet", | ... | ... |
datalets/base-ajax-json-alasql-datalet/static/js/AjaxJsonAlasqlBehavior.js
... | ... | @@ -85,11 +85,13 @@ var AjaxJsonAlasqlBehavior = { |
85 | 85 | selectData : function() { |
86 | 86 | var fields = this._component.fields = JSON.parse(this._component.fields); |
87 | 87 | |
88 | + //var selectedFields = JSON.parse(this._component.getAttribute("selectedFields")); | |
89 | + | |
88 | 90 | var filters = JSON.parse(this._component.getAttribute("filters")); |
89 | 91 | var aggregators = JSON.parse(this._component.getAttribute("aggregators")); |
90 | 92 | var orders = JSON.parse(this._component.getAttribute("orders")); |
91 | 93 | |
92 | - //preview my space | |
94 | + //preview my space ? | |
93 | 95 | if(filters && filters[0] && filters[0].constructor == Array){ |
94 | 96 | filters = filters[0]; |
95 | 97 | aggregators = aggregators[0]; |
... | ... | @@ -100,12 +102,28 @@ var AjaxJsonAlasqlBehavior = { |
100 | 102 | var provider = f.getProvider(this._component.dataUrl); |
101 | 103 | var data = provider.selectData(this.properties.json_results.value); |
102 | 104 | |
105 | + //if(selectedFields) { | |
106 | + // fields = []; | |
107 | + // var inputs = []; | |
108 | + // for (var i=0; i < selectedFields.length; i++) { | |
109 | + // if (selectedFields[i]) { | |
110 | + // fields.push(selectedFields[i].field); | |
111 | + // inputs.push(selectedFields[i].input); | |
112 | + // } | |
113 | + // } | |
114 | + //} | |
115 | + | |
103 | 116 | var converter = new DataTypeConverter(); |
104 | 117 | var result = converter.inferJsonDataType(data, ["*"]); |
105 | 118 | result = converter.cast(result); |
106 | 119 | data = result.dataset; |
107 | 120 | |
108 | - //data = alasql_selectData(data, fields, filters); | |
121 | + data = alasql_selectData(data, fields, filters);//funziona senza? | |
122 | + | |
123 | + result = converter.inferJsonDataType(data, ["*"]); | |
124 | + result = converter.cast(result); | |
125 | + data = result.dataset; | |
126 | + | |
109 | 127 | data = alasql_complexSelectData(data, fields, filters, aggregators, orders); |
110 | 128 | |
111 | 129 | this.data = transformData(data, fields, true); | ... | ... |
datalets/highcharts-datalet/highcharts-datalet.html
... | ... | @@ -140,15 +140,20 @@ Example : |
140 | 140 | // }, |
141 | 141 | |
142 | 142 | transformData: function () { |
143 | + var selectedFields = JSON.parse(this._component.getAttribute("selectedFields")); | |
144 | + | |
143 | 145 | if(this.data.length == 0) |
144 | 146 | return; |
145 | 147 | |
146 | - if(this.data.length == 2){ | |
147 | - this.properties.categories.value = this.data[0].data; | |
148 | - this.properties.series.value = [this.data[1]]; | |
149 | - } | |
148 | + categories = this.data[0].data; | |
149 | + series = []; | |
150 | + for(var i = 1; i < this.data.length; i++) | |
151 | + series.push(this.data[i]); | |
152 | + | |
153 | + this.properties.categories.value = categories; | |
154 | + this.properties.series.value = series; | |
150 | 155 | |
151 | - if(this.data.length == 3){//multi series | |
156 | + if(this.data.length == 3 && !selectedFields){//split cat | |
152 | 157 | var x = this.data[0]["data"]; |
153 | 158 | var gb = this.data[1]["data"]; |
154 | 159 | var y = this.data[2]["data"]; |
... | ... | @@ -166,19 +171,21 @@ Example : |
166 | 171 | series.push({name: s[i], data: new Array(categories.length+1).join('0').split('').map(parseFloat)}); |
167 | 172 | } |
168 | 173 | |
169 | - for (var i = 0; i < y.length; i++){ | |
174 | + for(var i = 0; i < y.length; i++){ | |
170 | 175 | var index = categories.indexOf(x[i]); |
171 | 176 | var s = series.filter(function( obj ) { |
172 | 177 | return obj.name == gb[i]; |
173 | 178 | }); |
174 | - s[0]["data"][index] = y[i]; | |
179 | + s[0]["data"][index] = y[i]; | |
175 | 180 | } |
176 | 181 | |
177 | 182 | this.properties.categories.value = categories; |
178 | 183 | this.properties.series.value = series; |
179 | 184 | } |
185 | + | |
180 | 186 | }, |
181 | 187 | |
188 | + | |
182 | 189 | // setParameters: function(params) |
183 | 190 | // { |
184 | 191 | // this._component.title = params['title']; | ... | ... |