From 59ee80246e45fa5464f6fed4ed7f488ee3fca0cb Mon Sep 17 00:00:00 2001 From: Gordon Smith Date: Thu, 18 Jul 2024 13:25:22 +0100 Subject: [PATCH] feat: Add maxWeight to Heat chart Added join and normalize to dataflow. Added better heat chart test / demo. Signed-off-by: Gordon Smith --- apps/dashPOC/rollup.config.js | 6 +- demos/gallery/.vscode/launch.json | 4 +- demos/gallery/package.json | 59 +- .../samples/chart/Heat/Week (StdDev).js | 40 + demos/gallery/test.html | 2 +- demos/quickstart/amd_npm/package.json | 2 +- demos/react/typescript/package.json | 2 +- package-lock.json | 1157 ++++++++--------- package.json | 8 +- packages/chart/index.html | 8 +- packages/chart/package.json | 3 +- packages/chart/rollup.config.mjs | 2 - packages/chart/src/Heat.ts | 7 +- packages/chart/src/__tests__/heat.ts | 70 + packages/chart/src/__tests__/index.ts | 2 + packages/chart/src/__tests__/test3.ts | 69 + packages/chart/tsconfig.json | 1 + packages/codemirror/rollup.config.mjs | 2 - packages/dataflow/.vscode/launch.json | 18 +- packages/dataflow/.vscode/tasks.json | 33 +- packages/dataflow/package.json | 12 +- packages/dataflow/rollup-test.config.mjs | 32 + packages/dataflow/rollup.config.mjs | 8 +- packages/dataflow/src/__tests__/index.ts | 27 + packages/dataflow/src/__tests__/join.ts | 20 + packages/dataflow/src/__tests__/normalize.ts | 14 + packages/dataflow/src/activities/activity.ts | 2 +- packages/dataflow/src/activities/join.ts | 19 + packages/dataflow/src/activities/normalize.ts | 21 + packages/dataflow/src/activities/skip.ts | 3 +- packages/dataflow/src/index.ts | 2 + packages/dgrid-shim/README.md | 6 +- packages/dgrid/rollup.config.mjs | 3 - packages/eclwatch/rollup.config.mjs | 1 - packages/map-deck/rollup.config.mjs | 3 - packages/map/rollup.config.mjs | 6 - packages/marshaller/rollup.config.mjs | 3 - packages/phosphor-shim/rollup.config.mjs | 4 - packages/preact-shim/rollup.config.mjs | 3 - packages/requirejs-shim/package.json | 4 +- tests/test-dgrid/rollup.config.js | 6 +- 41 files changed, 979 insertions(+), 715 deletions(-) create mode 100644 demos/gallery/samples/chart/Heat/Week (StdDev).js create mode 100644 packages/chart/src/__tests__/heat.ts create mode 100644 packages/chart/src/__tests__/index.ts create mode 100644 packages/chart/src/__tests__/test3.ts create mode 100644 packages/dataflow/rollup-test.config.mjs create mode 100644 packages/dataflow/src/__tests__/index.ts create mode 100644 packages/dataflow/src/__tests__/join.ts create mode 100644 packages/dataflow/src/__tests__/normalize.ts create mode 100644 packages/dataflow/src/activities/join.ts create mode 100644 packages/dataflow/src/activities/normalize.ts diff --git a/apps/dashPOC/rollup.config.js b/apps/dashPOC/rollup.config.js index a35abe2ed1..6315049f27 100644 --- a/apps/dashPOC/rollup.config.js +++ b/apps/dashPOC/rollup.config.js @@ -15,7 +15,7 @@ export default { external: ["@hpcc-js/dgrid-shim"], output: { file: `dist/vizLib.js`, - globals: function(id) { + globals: function (id) { console.log(id); if (id.indexOf("@hpcc-js/dgrid-shim") === 0) { return "@hpcc-js/dgrid-shim"; @@ -33,10 +33,6 @@ export default { jsnext: true }), commonjs({ - namedExports: { - // "../../packages/dgrid-shim/dist/dgrid-shim.js": ["Deferred", "domConstruct", "QueryResults", "Memory", "PagingGrid", "Grid"] - // "../../node_modules/dagre/index.js": ["graphlib", "layout"] - } }), postcss({ extensions: [".css"], diff --git a/demos/gallery/.vscode/launch.json b/demos/gallery/.vscode/launch.json index b32cbeff3d..2c4767fb23 100644 --- a/demos/gallery/.vscode/launch.json +++ b/demos/gallery/.vscode/launch.json @@ -27,7 +27,7 @@ "name": "galleryItem", "type": "msedge", "request": "launch", - "url": "file:///${workspaceRoot}/galleryItem.html?./samples/graph2/3%20Nodes%20Anno.js", + "url": "file:///${workspaceRoot}/galleryItem.html?./samples/chart/Heat/Week.js", "runtimeArgs": [ "--allow-file-access-from-files", "--disable-web-security" @@ -38,7 +38,7 @@ "name": "playground", "type": "msedge", "request": "launch", - "url": "file:///${workspaceRoot}/playground.html?./samples/graph2/3%20Nodes%20Anno.js", + "url": "file:///${workspaceRoot}/playground.html?./samples/chart/Heat/Week.js", "runtimeArgs": [ "--allow-file-access-from-files", "--disable-web-security" diff --git a/demos/gallery/package.json b/demos/gallery/package.json index 0f58b146c3..5413eae2a8 100644 --- a/demos/gallery/package.json +++ b/demos/gallery/package.json @@ -15,35 +15,36 @@ "tslib": "2.6.3" }, "devDependencies": { - "@hpcc-js/api": "^2.12.17", - "@hpcc-js/chart": "^2.83.3", - "@hpcc-js/codemirror": "^2.62.0", - "@hpcc-js/codemirror-shim": "^2.35.0", - "@hpcc-js/common": "^2.71.17", - "@hpcc-js/comms": "^2.92.2", - "@hpcc-js/composite": "^2.7.27", - "@hpcc-js/ddl-shim": "^2.20.6", - "@hpcc-js/deck-shim": "^2.6.9", - "@hpcc-js/dgrid": "^2.32.20", - "@hpcc-js/dgrid-shim": "^2.24.10", - "@hpcc-js/dgrid2": "^2.3.19", - "@hpcc-js/form": "^2.10.20", - "@hpcc-js/graph": "^2.85.15", - "@hpcc-js/html": "^2.42.20", - "@hpcc-js/layout": "^2.49.22", - "@hpcc-js/leaflet-shim": "^2.3.5", - "@hpcc-js/map": "^2.77.21", - "@hpcc-js/map-deck": "^2.7.19", - "@hpcc-js/marshaller": "^2.25.50", - "@hpcc-js/other": "^2.15.22", - "@hpcc-js/phosphor": "^2.18.8", - "@hpcc-js/phosphor-shim": "^2.14.6", - "@hpcc-js/preact-shim": "^2.16.10", - "@hpcc-js/react": "^2.53.16", - "@hpcc-js/timeline": "^2.51.25", - "@hpcc-js/tree": "^2.40.17", - "@hpcc-js/util": "^2.51.0", + "@hpcc-js/api": "^2.12.18", + "@hpcc-js/dataflow": "^8.1.7", + "@hpcc-js/chart": "^2.83.4", + "@hpcc-js/codemirror": "^2.62.1", + "@hpcc-js/codemirror-shim": "^2.35.1", + "@hpcc-js/common": "^2.71.18", + "@hpcc-js/comms": "^2.93.0", + "@hpcc-js/composite": "^2.7.30", + "@hpcc-js/ddl-shim": "^2.20.7", + "@hpcc-js/deck-shim": "^2.6.10", + "@hpcc-js/dgrid": "^2.32.23", + "@hpcc-js/dgrid-shim": "^2.24.11", + "@hpcc-js/dgrid2": "^2.3.20", + "@hpcc-js/form": "^2.10.21", + "@hpcc-js/graph": "^2.85.16", + "@hpcc-js/html": "^2.42.21", + "@hpcc-js/layout": "^2.49.23", + "@hpcc-js/leaflet-shim": "^2.3.6", + "@hpcc-js/map": "^2.77.22", + "@hpcc-js/map-deck": "^2.7.20", + "@hpcc-js/marshaller": "^2.25.53", + "@hpcc-js/other": "^2.15.23", + "@hpcc-js/phosphor": "^2.18.9", + "@hpcc-js/phosphor-shim": "^2.14.7", + "@hpcc-js/preact-shim": "^2.16.11", + "@hpcc-js/react": "^2.53.17", + "@hpcc-js/timeline": "^2.51.26", + "@hpcc-js/tree": "^2.40.18", + "@hpcc-js/util": "^2.51.1", "d3-selection": "^1", - "systemjs": "0.21.6" + "systemjs": "0.21.4" } } \ No newline at end of file diff --git a/demos/gallery/samples/chart/Heat/Week (StdDev).js b/demos/gallery/samples/chart/Heat/Week (StdDev).js new file mode 100644 index 0000000000..f59d409c60 --- /dev/null +++ b/demos/gallery/samples/chart/Heat/Week (StdDev).js @@ -0,0 +1,40 @@ +import { Heat } from "@hpcc-js/chart"; +import * as df from "@hpcc-js/dataflow"; + +const data = [["Sat", 0, 0.18998719125426], ["Sat", 1, 0.21651075448881343], ["Sat", 2, 0.29360917730014136], ["Sat", 3, 0.1651116355055364], ["Sat", 4, 0.11885237728786953], ["Sat", 5, 0.09315256213264339], ["Sat", 6, 0.19081093933358728], ["Sat", 7, 0.26505462252549605], ["Sat", 8, 0.31304625721290896], ["Sat", 9, 0.18326323889972618], ["Sat", 10, 0.5427922043058862], ["Sat", 11, 0.33890867440986455], ["Sat", 12, 0.22287115322174472], ["Sat", 13, 0.2587162108611005], ["Sat", 14, 0.28441551468915144], ["Sat", 15, 0.19982154681583783], ["Sat", 16, 0.2930569439508717], ["Sat", 17, 0.47723750380299584], ["Sat", 18, 0.22207706211858186], ["Sat", 19, 0.33558402511639085], ["Sat", 20, 0.3690611266071652], ["Sat", 21, 0.5573599155287506], ["Sat", 22, 0.6831520252391093], ["Sat", 23, 0.5778902129422021], ["Fri", 0, 0.22511997013849297], ["Fri", 1, 0.12872968433216836], ["Fri", 2, 0.14983215685472429], ["Fri", 3, 0.2927501476457219], ["Fri", 4, 0.10428671137370601], ["Fri", 5, 0.15568583035698308], ["Fri", 6, 0.24599132277783603], ["Fri", 7, 0.2731898378837191], ["Fri", 8, 0.44567225462048016], ["Fri", 9, 0.20923559143936044], ["Fri", 10, 0.37126545805966676], ["Fri", 11, 0.25775900638903304], ["Fri", 12, 0.3814741051135274], ["Fri", 13, 0.34006938709768136], ["Fri", 14, 0.27593924410503684], ["Fri", 15, 0.4419477474759613], ["Fri", 16, 0.38965124930012096], ["Fri", 17, 0.3172503892478122], ["Fri", 18, 0.46400589048905894], ["Fri", 19, 0.2558543126612278], ["Fri", 20, 0.3590657029853837], ["Fri", 21, 0.15632447799886998], ["Fri", 22, 0.26420326277870526], ["Fri", 23, 0.297398622995917], ["Thur", 0, 0.18232751016901919], ["Thur", 1, 0.10522908735769126], ["Thur", 2, 0.2871142995201194], ["Thur", 3, 0.13264031456847822], ["Thur", 4, 0.18082727623683653], ["Thur", 5, 0.09944495435126643], ["Thur", 6, 0.11995531000488316], ["Thur", 7, 0.32298185555518627], ["Thur", 8, 0.2721533776994879], ["Thur", 9, 0.27001193948954205], ["Thur", 10, 0.4749544279655059], ["Thur", 11, 0.2692331882016368], ["Thur", 12, 0.4508438176709558], ["Thur", 13, 0.4492663733353105], ["Thur", 14, 0.3835056079807946], ["Thur", 15, 0.3464395010469424], ["Thur", 16, 0.34637609647721146], ["Thur", 17, 0.28212732557990894], ["Thur", 18, 0.19046579349029374], ["Thur", 19, 0.3223897386862471], ["Thur", 20, 0.2504833320124048], ["Thur", 21, 0.28639128289431637], ["Thur", 22, 0.4919882701545998], ["Thur", 23, 0.11120547938200998], ["Wed", 0, 0.26539414376986187], ["Wed", 1, 0.1915083896006279], ["Wed", 2, 0.1144094554621247], ["Wed", 3, 0.1915083896006279], ["Wed", 4, 0.1915083896006279], ["Wed", 5, 0.06301033647884767], ["Wed", 6, 0.18917162440973667], ["Wed", 7, 0.2034494131242346], ["Wed", 8, 0.355351933711545], ["Wed", 9, 0.3451218109163239], ["Wed", 10, 0.3226346644031917], ["Wed", 11, 0.20270338677554525], ["Wed", 12, 0.12560445263704206], ["Wed", 13, 0.2519610675488765], ["Wed", 14, 0.30086133062670817], ["Wed", 15, 0.24946221164343108], ["Wed", 16, 0.31534569552000696], ["Wed", 17, 0.4939159736052912], ["Wed", 18, 0.31544642697353115], ["Wed", 19, 0.24156016147712192], ["Wed", 20, 0.27236557847721654], ["Wed", 21, 0.3740930973387977], ["Wed", 22, 0.1085307269282787], ["Wed", 23, 0.13101787344141086], ["Tue", 0, 0.38368457249213195], ["Tue", 1, 0.11328658098527632], ["Tue", 2, 0.14541071077033996], ["Tue", 3, 0.06827291576651778], ["Tue", 4, 0.17107115373307188], ["Tue", 5, 0.11538864700272793], ["Tue", 6, 0.11217648968780919], ["Tue", 7, 0.13902321169712045], ["Tue", 8, 0.3094408893002232], ["Tue", 9, 0.40688502041473745], ["Tue", 10, 0.36313484464602097], ["Tue", 11, 0.4601351437724185], ["Tue", 12, 0.4095924978076847], ["Tue", 13, 0.22557709663316622], ["Tue", 14, 0.3283753345997203], ["Tue", 15, 0.2706332020074705], ["Tue", 16, 0.24600410595721722], ["Tue", 17, 0.5543993311840548], ["Tue", 18, 0.2738964920399142], ["Tue", 19, 0.2781803911141563], ["Tue", 20, 0.17569661936038083], ["Tue", 21, 0.48912841726342815], ["Tue", 22, 0.38632966796969875], ["Tue", 23, 0.18644420525695468], ["Mon", 0, 0.6359227793699938], ["Mon", 1, 0.5221023728137567], ["Mon", 2, 0.37279943958541595], ["Mon", 3, 0.34710013575736504], ["Mon", 4, 0.28285085353288725], ["Mon", 5, 0.25751868261666566], ["Mon", 6, 0.28428921687686476], ["Mon", 7, 0.17089474585761072], ["Mon", 8, 0.36545166807707746], ["Mon", 9, 0.21043056304791902], ["Mon", 10, 0.3696194958825379], ["Mon", 11, 0.3105586505053191], ["Mon", 12, 0.4402250862225449], ["Mon", 13, 0.2582289160630875], ["Mon", 14, 0.2996172716093256], ["Mon", 15, 0.32338989464103557], ["Mon", 16, 0.3249376820005164], ["Mon", 17, 0.22535620329345835], ["Mon", 18, 0.2782090254359703], ["Mon", 19, 0.14818108140584293], ["Mon", 20, 0.32807825351090025], ["Mon", 21, 0.5908569587793598], ["Mon", 22, 0.5080470114204925], ["Mon", 23, 0.2530276960364474], ["Sun", 0, 0.6469792068804184], ["Sun", 1, 0.4528553787783882], ["Sun", 2, 0.540662526620971], ["Sun", 3, 0.48754995027343223], ["Sun", 4, 0.2125643313502361], ["Sun", 5, 0.1999907961108455], ["Sun", 6, 0.19768419922329403], ["Sun", 7, 0.1666001089126883], ["Sun", 8, 0.39061458969829144], ["Sun", 9, 0.3091105719450119], ["Sun", 10, 0.3605096909282889], ["Sun", 11, 0.23504738724596624], ["Sun", 12, 0.2493108587995572], ["Sun", 13, 0.27608139305975626], ["Sun", 14, 0.301086314583818], ["Sun", 15, 0.4038845525503721], ["Sun", 16, 0.46976394580954595], ["Sun", 17, 0.5597125318620746], ["Sun", 18, 0.3975047233847814], ["Sun", 19, 0.19067492630497088], ["Sun", 20, 0.348541567064394], ["Sun", 21, 0.7699334507681412], ["Sun", 22, 0.606812411955852], ["Sun", 23, 1]]; + +// Calculate the standard deviation of the weight column --- +const extractWeight = df.map(row => row[2]); +const distribution = df.scalar(df.distribution())(extractWeight(data)); + +// Convert the weight column to standard deviations --- +const toStdDevs = df.map(r => { + return [r[0], r[1], distribution.mean + (r[2] - distribution.mean) / (distribution.deviation || 1)]; +}); +const stdDevData = toStdDevs(data); + +// Normalize the standard deviations and calculate the new mean and deviation --- +const range = df.scalar(df.extent())(extractWeight(stdDevData)); +const denominator = (range[1] - range[0]) || 1; +const normalize = df.map(r => { + return [r[0], r[1], (r[2] - range[0]) / denominator]; +}); +const normalizedStdDevData = normalize(toStdDevs(data)); +const normalizedMean = (distribution.mean - range[0]) / denominator; +const normalizedDeviation = (distribution.deviation - range[0]) / denominator; + +new Heat() + .target("target") + .columns(["Day", "Hour", "weight"]) + .paletteID("RdYlGn") + .reversePalette(true) + .xAxisType("ordinal") + .yAxisType("time") + .yAxisTypeTimePattern("%H") + .yAxisTickFormat("%H:00") + .yAxisTitle("Hour") + .orientation("vertical") + .maxWeight(normalizedMean + 2 * normalizedDeviation) + .data([...normalizedStdDevData]) + .render() + ; diff --git a/demos/gallery/test.html b/demos/gallery/test.html index 6f873e0723..1b073ea0bc 100644 --- a/demos/gallery/test.html +++ b/demos/gallery/test.html @@ -9,7 +9,7 @@ - +