StackGenVis: Alignment of Data, Algorithms, and Models for Stacking Ensemble Learning Using Performance Metrics https://doi.org/10.1109/TVCG.2020.3030352
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
StackGenVis/frontend/node_modules/vue-functional-data-merge/dist/lib.js.map

1 line
6.6 KiB

4 years ago
{"version":3,"file":"lib.js","sources":["../src/index.ts"],"sourcesContent":["import { VNodeData } from \"vue\";\n\nconst pattern = {\n kebab: /-(\\w)/g,\n styleProp: /:(.*)/,\n\tstyleList: /;(?![^(]*\\))/g,\n} as const;\n\nfunction camelReplace(_substr: string, match: string) {\n return match ? match.toUpperCase() : \"\";\n}\n\nfunction camelCase(str: string) {\n return str.replace(pattern.kebab, camelReplace);\n}\n\nfunction parseStyle(style: string) {\n let styleMap: Record<string, any> = {};\n\n for (let s of style.split(pattern.styleList)) {\n let [key, val] = s.split(pattern.styleProp);\n key = key.trim();\n if (!key) {\n continue;\n }\n // May be undefined if the `key: value` pair is incomplete.\n if (typeof val === \"string\") {\n val = val.trim();\n }\n styleMap[camelCase(key)] = val;\n }\n\n return styleMap;\n}\n\n/**\n * Intelligently merges data for createElement.\n * Merges arguments left to right, preferring the right argument.\n * Returns new VNodeData object.\n */\nfunction mergeData(...vNodeData: VNodeData[]): VNodeData;\nfunction mergeData(): VNodeData {\n let mergeTarget: VNodeData & Record<string, any> = {};\n let i: number = arguments.length;\n let prop: string;\n let event: string;\n\n // Allow for variadic argument length.\n while (i--) {\n // Iterate through the data properties and execute merge strategies\n // Object.keys eliminates need for hasOwnProperty call\n for (prop of Object.keys(arguments[i])) {\n switch (prop) {\n // Array merge strategy (array concatenation)\n case \"class\":\n case \"style\":\n case \"directives\":\n if (!Array.isArray(mergeTarget[prop])) {\n mergeTarget[prop] = [];\n }\n\n if (prop === \"style\") {\n let style: any[];\n if (Array.isArray(arguments[i].style)) {\n style = arguments[i].style;\n } else {\n style = [arguments[i].style];\n }\n for (let j = 0; j < style.length; j++) {\n let s = style[j];\n if (typeof s === \"string\") {\n style[j] = parseStyle(s);\n }\n }\n arguments[i].style = style;\n }\n\n // Repackaging in an array allows Vue runtime\n // to merge class/style bindings regardless of type.\n mergeTarget[prop] = mergeTarget[prop].concat(arguments[i][prop]);\n break;\n // Space delimited string concatenation strategy\n case \"staticClass\":\n if (!arguments[i][prop]) {\n break;\n }\n if (mergeTarget[prop] === undefined) {\n mergeTarget[prop] = \"\";\n }\n if (mergeTarget[prop]) {\n // Not an empty string, so concatenate\n mergeTarget[prop] += \" \";\n }\n mergeTarget[prop] += arguments[i][prop].trim();\n break;\n // Object, the properties of which to merge via array merge strategy (array concatenation).\n // Callback merge strategy merges callbacks to the beginning of the array,\n // so that the last defined callback will be invoked first.\n // This is done since to mimic how Object.assign merging\n // uses the last given value to assign.\n case \"on\":\n case \"nativeOn\":\n if (!mergeTarget[prop]) {\n mergeTarget[prop] = {};\n }\n for (event of Object.keys(arguments[i][prop] || {})) {\n // Concat function to array of functions if callback present.\n if (mergeTarget[prop][event]) {\n // Insert current iteration data in beginning of merged array.\n mergeTarget[prop][event] = [].concat(\n mergeTarget[prop][event],\n arguments[i][prop][event]\n );\n } else {\n // Straight assign.\n mergeTarget[prop][event] = arguments[i][prop][event];\n }\n }\n break;\n // Obje