Episodio número veintinueve (29) sobre Deneb. Aquí, crearemos un gráfico llamado Action Dots o Puntos de acción.
Version 1 Point with color: JSON template to import in Deneb
{ "$schema": "https://vega.github.io/schema/vega-lite/v5.json", "usermeta": { "deneb": { "build": "1.4.0.0", "metaVersion": 1, "provider": "vegaLite", "providerVersion": "5.4.0" }, "interactivity": { "tooltip": true, "contextMenu": true, "selection": false, "highlight": false, "dataPointLimit": 50 }, "information": { "name": "Actions Dots - version a color", "description": "Action Dots basado en el artículo Why I Stopped Using Bullet Graphs (and What I Now Use Instead) de Nick Desbarats", "author": "Sentido Analitica - José Rafael Escalante", "uuid": "65222c8a-aa4e-4e00-b9f3-8d0091fab150", "generated": "2023-02-26T00:50:14.002Z", "previewImageBase64PNG": "" }, "dataset": [ { "key": "__0__", "name": "City", "description": "", "type": "text", "kind": "column" }, { "key": "__1__", "name": "Units", "description": "", "type": "numeric", "kind": "column" }, { "key": "__2__", "name": "Best case", "description": "", "type": "numeric", "kind": "column" }, { "key": "__3__", "name": "Good", "description": "", "type": "numeric", "kind": "column" }, { "key": "__4__", "name": "Middle", "description": "", "type": "numeric", "kind": "column" }, { "key": "__5__", "name": "Bad", "description": "", "type": "numeric", "kind": "column" }, { "key": "__6__", "name": "Crisis", "description": "", "type": "numeric", "kind": "column" } ] }, "config": { "view": {"stroke": "transparent"}, "font": "Segoe UI", "arc": {}, "area": { "line": true, "opacity": 0.6 }, "bar": {}, "line": { "strokeWidth": 3, "strokeCap": "round", "strokeJoin": "round" }, "path": {}, "point": { "filled": true, "size": 75 }, "rect": {}, "shape": {}, "symbol": { "strokeWidth": 1.5, "size": 50 }, "text": { "font": "Segoe UI", "fontSize": 14 }, "axis": { "ticks": false, "grid": false, "domain": false, "labelFontSize": 12, "title": null, "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "titleFontWeight": "normal" }, "axisQuantitative": { "tickCount": 3, "grid": false, "gridDash": [1, 5], "labelFlush": false }, "axisX": { "labelPadding": 5, "labels": false }, "axisY": {"labelPadding": 10}, "header": { "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332 }, "legend": { "titleFont": "Segoe UI", "titleFontWeight": "bold", "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332, "symbolType": "circle", "symbolSize": 75 } }, "data": {"name": "dataset"}, "hconcat": [ { "encoding": { "y": { "field": "__0__", "sort": { "op": "sum", "field": "__1__", "order": "descending" } } }, "layer": [ { "mark": { "type": "bar", "tooltip": true, "color": "#d9d9d9", "height": {"band": 0.6}, "yOffset": 2, "xOffset": 5 }, "encoding": { "x": { "field": "__1__", "type": "quantitative" } } }, { "mark": { "type": "text", "align": "center", "baseline": "top", "yOffset": -3, "xOffset": 120, "fontSize": 11, "fontWeight": "bold", "color": "#444444" }, "encoding": { "text": { "field": "__1__", "type": "quantitative", "format": "0,0", "formatType": "pbiFormat" } } }, { "mark": { "type": "point", "yOffset": 2, "xOffset": 150, "size": 120 }, "encoding": { "color": { "condition": [ { "test": "datum['__1__'] > datum['__2__']", "value": "green" }, { "test": "datum['__1__'] > datum['__3__']", "value": "#32cd32" }, { "test": "datum['__1__'] > datum['__4__']", "value": "transparent" }, { "test": "datum['__1__'] > datum['__5__']", "value": "#F08080" }, { "test": "datum['__1__'] > datum['__6__']", "value": "red" }, { "test": "datum['__1__'] <= datum['__6__']", "value": "red" } ] } } } ] } ] }
Version 2 Pattern Fills Square: JSON template to import in Deneb
{ "$schema": "https://vega.github.io/schema/vega-lite/v5.json", "usermeta": { "deneb": { "build": "1.4.0.0", "metaVersion": 1, "provider": "vegaLite", "providerVersion": "5.4.0" }, "interactivity": { "tooltip": true, "contextMenu": true, "selection": false, "highlight": false, "dataPointLimit": 50 }, "information": { "name": "Action Dots - pattern fills", "description": "Action Dots basado en el artículo Why I Stopped Using Bullet Graphs (and What I Now Use Instead) de Nick Desbarats", "author": "Sentido Analitica - José Rafael Escalante", "uuid": "2e9e9496-1060-4c11-b3ad-3457b3a1bbf1", "generated": "2023-02-26T00:52:56.495Z", "previewImageBase64PNG": "" }, "dataset": [ { "key": "__0__", "name": "City", "description": "", "type": "text", "kind": "column" }, { "key": "__1__", "name": "Units", "description": "", "type": "numeric", "kind": "column" }, { "key": "__2__", "name": "Best case", "description": "", "type": "numeric", "kind": "column" }, { "key": "__3__", "name": "Good", "description": "", "type": "numeric", "kind": "column" }, { "key": "__4__", "name": "Middle", "description": "", "type": "numeric", "kind": "column" }, { "key": "__5__", "name": "Bad", "description": "", "type": "numeric", "kind": "column" }, { "key": "__6__", "name": "Crisis", "description": "", "type": "numeric", "kind": "column" } ] }, "config": { "view": {"stroke": "transparent"}, "font": "Segoe UI", "arc": {}, "area": { "line": true, "opacity": 0.6 }, "bar": {}, "line": { "strokeWidth": 3, "strokeCap": "round", "strokeJoin": "round" }, "path": {}, "point": { "filled": true, "size": 75 }, "rect": {}, "shape": {}, "symbol": { "strokeWidth": 1.5, "size": 50 }, "text": { "font": "Segoe UI", "fontSize": 14 }, "axis": { "ticks": false, "grid": false, "domain": false, "labelFontSize": 12, "title": null, "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "titleFontWeight": "normal" }, "axisQuantitative": { "tickCount": 3, "grid": false, "gridDash": [1, 5], "labelFlush": false }, "axisX": { "labelPadding": 5, "labels": false }, "axisY": {"labelPadding": 10}, "header": { "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332 }, "legend": { "titleFont": "Segoe UI", "titleFontWeight": "bold", "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332, "symbolType": "circle", "symbolSize": 75 } }, "data": {"name": "dataset"}, "hconcat": [ { "encoding": { "y": { "field": "__0__", "sort": { "op": "sum", "field": "__1__", "order": "descending" } } }, "layer": [ { "mark": { "type": "bar", "tooltip": true, "color": "#d9d9d9", "height": {"band": 0.6}, "yOffset": 2, "xOffset": 5 }, "encoding": { "x": { "field": "__1__", "type": "quantitative" } } }, { "description": "Line Crisis", "mark": { "type": "rect", "tooltip": true, "color": "#252525", "height": 10, "width": 1, "yOffset": 2, "xOffset": 5 }, "encoding": { "x": { "field": "__6__", "type": "quantitative" } } }, { "description": "Line Best case", "mark": { "type": "rect", "tooltip": true, "color": "#252525", "height": 10, "width": 2, "yOffset": 2, "xOffset": 5 }, "encoding": { "x": { "field": "__2__", "type": "quantitative" } } }, { "mark": { "type": "text", "align": "center", "baseline": "top", "yOffset": -3, "xOffset": 120, "fontSize": 11, "fontWeight": "bold", "color": "#444444" }, "encoding": { "text": { "field": "__1__", "type": "quantitative", "format": "0,0", "formatType": "pbiFormat" } } }, { "mark": { "type": "square", "yOffset": 2, "xOffset": 150, "size": 120 }, "encoding": { "color": { "condition": [ { "test": "datum['__1__'] > datum['__2__']", "value": "black" }, { "test": "datum['__1__'] > datum['__3__']", "value": "url(#horizontal-stripe-9)" }, { "test": "datum['__1__'] > datum['__4__']", "value": "white" }, { "test": "datum['__1__'] > datum['__5__']", "value": "url(#horizontal-stripe-1)" }, { "test": "datum['__1__'] > datum['__6__']", "value": "url(#crosshatch)" }, { "test": "datum['__1__'] <= datum['__6__']", "value": "url(#crosshatch)" } ] } } } ] } ] }
Version 3 SVG: JSON template to import in Deneb
{ "$schema": "https://vega.github.io/schema/vega-lite/v5.json", "usermeta": { "deneb": { "build": "1.4.0.0", "metaVersion": 1, "provider": "vegaLite", "providerVersion": "5.4.0" }, "interactivity": { "tooltip": true, "contextMenu": true, "selection": false, "highlight": false, "dataPointLimit": 50 }, "information": { "name": "Action Dots - version SVG", "description": "Action Dots basado en el artículo Why I Stopped Using Bullet Graphs (and What I Now Use Instead) de Nick Desbarats", "author": "Sentido Analitica - José Rafael Escalante", "uuid": "8c7d0989-68a2-424a-add8-0f16b66392aa", "generated": "2023-02-26T00:53:57.345Z", "previewImageBase64PNG": "" }, "dataset": [ { "key": "__0__", "name": "City", "description": "", "type": "text", "kind": "column" }, { "key": "__1__", "name": "Units", "description": "", "type": "numeric", "kind": "column" }, { "key": "__2__", "name": "Good", "description": "", "type": "numeric", "kind": "column" }, { "key": "__3__", "name": "Best case", "description": "", "type": "numeric", "kind": "column" }, { "key": "__4__", "name": "Middle", "description": "", "type": "numeric", "kind": "column" }, { "key": "__5__", "name": "Bad", "description": "", "type": "numeric", "kind": "column" }, { "key": "__6__", "name": "Crisis", "description": "", "type": "numeric", "kind": "column" } ] }, "config": { "view": {"stroke": "transparent"}, "font": "Segoe UI", "arc": {}, "area": { "line": true, "opacity": 0.6 }, "bar": {}, "line": { "strokeWidth": 3, "strokeCap": "round", "strokeJoin": "round" }, "path": {}, "point": { "filled": true, "size": 75 }, "rect": {}, "shape": {}, "symbol": { "strokeWidth": 1.5, "size": 50 }, "text": { "font": "Segoe UI", "fontSize": 14 }, "axis": { "ticks": false, "grid": false, "domain": false, "labelFontSize": 12, "title": null, "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "titleFontWeight": "normal" }, "axisQuantitative": { "tickCount": 3, "grid": false, "gridDash": [1, 5], "labelFlush": false }, "axisX": { "labelPadding": 5, "labels": false }, "axisY": {"labelPadding": 10}, "header": { "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332 }, "legend": { "titleFont": "Segoe UI", "titleFontWeight": "bold", "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332, "symbolType": "circle", "symbolSize": 75 } }, "data": {"name": "dataset"}, "hconcat": [ { "encoding": { "y": { "field": "__0__", "sort": { "op": "sum", "field": "__1__", "order": "descending" } } }, "layer": [ { "mark": { "type": "bar", "tooltip": true, "color": "#d9d9d9", "height": {"band": 0.6}, "yOffset": 2, "xOffset": 5 }, "encoding": { "x": { "field": "__1__", "type": "quantitative" } } }, { "mark": { "type": "text", "align": "center", "baseline": "top", "yOffset": -3, "xOffset": 120, "fontSize": 11, "fontWeight": "bold", "color": "#444444" }, "encoding": { "text": { "field": "__1__", "type": "quantitative", "format": "0,0", "formatType": "pbiFormat" } } }, { "description": "__3__", "mark": { "type": "point", "size": 0.003, "yOffset": -6, "xOffset": 144, "shape": { "expr": "datum['__1__'] > datum['__3__'] ? 'M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 48C141.1 48 48 141.1 48 256C48 370.9 141.1 464 256 464C370.9 464 464 370.9 464 256C464 141.1 370.9 48 256 48z' : 'M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 48C141.1 48 48 141.1 48 256C48 370.9 141.1 464 256 464C370.9 464 464 370.9 464 256C464 141.1 370.9 48 256 48z'" }, "color": { "expr": "datum['__1__'] > datum['__3__'] ? '#252525' : 'transparent'" } } }, { "description": "__2__", "mark": { "type": "point", "size": 0.0007, "yOffset": -2, "xOffset": 148, "shape": { "expr": "datum['__1__'] > datum['__2__'] && datum['__1__'] < datum['__3__'] ? 'M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 48C141.1 48 48 141.1 48 256C48 370.9 141.1 464 256 464C370.9 464 464 370.9 464 256C464 141.1 370.9 48 256 48z' : 'M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 48C141.1 48 48 141.1 48 256C48 370.9 141.1 464 256 464C370.9 464 464 370.9 464 256C464 141.1 370.9 48 256 48z'" }, "color": { "expr": "datum['__1__'] > datum['__2__'] && datum['__1__'] < datum['__3__'] ? '#252525' : 'transparent'" } } }, { "description": "__4__", "mark": { "type": "point", "size": 120, "yOffset": -2, "xOffset": 148, "color": { "expr": "datum['__1__'] > datum['__5__'] && datum['__1__'] < datum['__2__'] ? 'transparent' : 'transparent'" } } }, { "description": "__5__", "mark": { "type": "point", "size": 0.0007, "yOffset": -2, "xOffset": 148, "shape": { "expr": "datum['__1__'] > datum['__5__'] && datum['__1__'] < datum['__4__'] ? 'M256 512c141.4 0 256-114.6 256-256S397.4 0 256 0S0 114.6 0 256S114.6 512 256 512z' : 'M256 512c141.4 0 256-114.6 256-256S397.4 0 256 0S0 114.6 0 256S114.6 512 256 512z'" }, "color": { "expr": "datum['__1__'] > datum['__5__'] && datum['__1__'] < datum['__4__'] ? '#252525' : 'transparent'" } } }, { "description": "__6__", "mark": { "type": "point", "size": 0.003, "yOffset": -6, "xOffset": 144, "shape": { "expr": "datum['__1__'] > 0 && datum['__1__'] <= datum['__6__'] ? 'M256 512c141.4 0 256-114.6 256-256S397.4 0 256 0S0 114.6 0 256S114.6 512 256 512z' : 'M256 512c141.4 0 256-114.6 256-256S397.4 0 256 0S0 114.6 0 256S114.6 512 256 512z'" }, "color": { "expr": "datum['__1__'] > 0 && datum['__1__'] <= datum['__6__'] ? 'black' : 'transparent'" } } } ] } ] }
Version 4 Pattern Fills Point: JSON template to import in Deneb
{ "$schema": "https://vega.github.io/schema/vega-lite/v5.json", "usermeta": { "deneb": { "build": "1.4.0.0", "metaVersion": 1, "provider": "vegaLite", "providerVersion": "5.4.0" }, "interactivity": { "tooltip": true, "contextMenu": true, "selection": false, "highlight": false, "dataPointLimit": 50 }, "information": { "name": "Action Dots - pattern fills point", "description": "Action Dots basado en el artículo Why I Stopped Using Bullet Graphs (and What I Now Use Instead) de Nick Desbarats", "author": "Sentido Analitica - José Rafael Escalante", "uuid": "400a3012-c01d-444e-a1be-48acb142809d", "generated": "2023-02-26T00:55:30.332Z", "previewImageBase64PNG": "" }, "dataset": [ { "key": "__0__", "name": "City", "description": "", "type": "text", "kind": "column" }, { "key": "__1__", "name": "Units", "description": "", "type": "numeric", "kind": "column" }, { "key": "__2__", "name": "Best case", "description": "", "type": "numeric", "kind": "column" }, { "key": "__3__", "name": "Good", "description": "", "type": "numeric", "kind": "column" }, { "key": "__4__", "name": "Middle", "description": "", "type": "numeric", "kind": "column" }, { "key": "__5__", "name": "Bad", "description": "", "type": "numeric", "kind": "column" }, { "key": "__6__", "name": "Crisis", "description": "", "type": "numeric", "kind": "column" } ] }, "config": { "view": {"stroke": "transparent"}, "font": "Segoe UI", "arc": {}, "area": { "line": true, "opacity": 0.6 }, "bar": {}, "line": { "strokeWidth": 3, "strokeCap": "round", "strokeJoin": "round" }, "path": {}, "point": { "filled": true, "size": 75 }, "rect": {}, "shape": {}, "symbol": { "strokeWidth": 1.5, "size": 50 }, "text": { "font": "Segoe UI", "fontSize": 14 }, "axis": { "ticks": false, "grid": false, "domain": false, "labelFontSize": 12, "title": null, "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "titleFontWeight": "normal" }, "axisQuantitative": { "tickCount": 3, "grid": false, "gridDash": [1, 5], "labelFlush": false }, "axisX": { "labelPadding": 5, "labels": false }, "axisY": {"labelPadding": 10}, "header": { "titleFont": "wf_standard-font, helvetica, arial, sans-serif", "titleFontSize": 16, "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332 }, "legend": { "titleFont": "Segoe UI", "titleFontWeight": "bold", "labelFont": "Segoe UI", "labelFontSize": 13.333333333333332, "symbolType": "circle", "symbolSize": 75 } }, "data": {"name": "dataset"}, "hconcat": [ { "encoding": { "y": { "field": "__0__", "sort": { "op": "sum", "field": "__1__", "order": "descending" } } }, "layer": [ { "mark": { "type": "bar", "tooltip": true, "color": "#d9d9d9", "height": {"band": 0.6}, "yOffset": 2, "xOffset": 5 }, "encoding": { "x": { "field": "__1__", "type": "quantitative" } } }, { "mark": { "type": "text", "align": "center", "baseline": "top", "yOffset": -3, "xOffset": 120, "fontSize": 11, "fontWeight": "bold", "color": "#444444" }, "encoding": { "text": { "field": "__1__", "type": "quantitative", "format": "0,0", "formatType": "pbiFormat" } } }, { "mark": { "type": "point", "yOffset": 2, "xOffset": 150, "size": 120 }, "encoding": { "color": { "condition": [ { "test": "datum['__1__'] > datum['__2__']", "value": "black" }, { "test": "datum['__1__'] > datum['__3__']", "value": "url(#horizontal-stripe-9)" }, { "test": "datum['__1__'] > datum['__4__']", "value": "white" }, { "test": "datum['__1__'] > datum['__5__']", "value": "url(#horizontal-stripe-1)" }, { "test": "datum['__1__'] > datum['__6__']", "value": "url(#crosshatch)" }, { "test": "datum['__1__'] <= datum['__6__']", "value": "url(#crosshatch)" } ] } } } ] } ] }
Muy bueno Rafel, gracias por compartirlo. Te hago una consulta desde la ignorancia en Deneb. Intente copiar y pegar el ejemplo 1 siguiendo estos pasos:
Crear objeto visual Deneb
Agregar a Fields: City, Units, Best case, Good, Middle, Bad, Crisis
Cambie el nombre de las columnas que se agruparon automáticamente con Sum, retirando la parte en mi caso en inglés, Sum of
Luego a la derecha arriba en los … le di editar
Seleccione empty
Elimine lo que está en Specification y pegue el código que nos compartiste.
Me saltan errores.
Lo pude corregir mirando el código en el video, y partiendo desde dataset. Cambie los key por los nombre de los fields, y ahi pude crear el visual.
Que estoy haciendo mal para implementar tal cual nos compartiste el código?
Saludos desde Uruguay, Santiago
Hola Santiago, el proceso es el siguiente:
Copias el código JSON que se encuentra en esta página, y lo guardas como un documento de texto .JSON
Si tienes algún inconveniente desde tu PC, puedes utilizar esta página https://jsonformatter.curiousconcept.com/ donde pegas el texto y lo guardas a tu computador. Luego, ese archivo vas a importarlo desde Deneb en el apartado que dice «Import from template» > «Select JSON Template» y listo.
Proximamente grabaré un video sobre como utilizar las plantillas porque eso lo expliqué en uno de los videos al comienzo de la serie.
Bueno, Kerry Kolosko ya tiene un vídeo, aquí lo puedes ver: https://www.youtube.com/watch?v=fPVQRHyWZrc
Muchas gracias por tu inmediata respuesta. Me sirvió perfecto para entender lo que estaba haciendo mal. El video de Kerry Kolosco me ayudo también.
Nuevamente gracias por darme un impulso para aprender Deneb que además de su potencial es una herramienta que permite solucionar necesidades de reportes.