¿Cómo hacer un googleVis Sankey múltiple desde un data.frame?

Objetivo

Mi objetivo es hacer un Sankey múltiple en R usando elgoogleVis paquete. El resultado debería ser similar a esto:

Datos

He creado algunos datos ficticios en R:

set.seed(1)

source <- sample(c("North","South","East","West"),100,replace=T)
mid <- sample(c("North ","South ","East ","West "),100,replace=T)
destination <- sample(c("North","South","East","West"),100,replace=T) # N.B. It is important to have a space after the second set of destinations to avoid a cycle
dummy <- rep(1,100) # For aggregation

dat <- data.frame(source,mid,destination,dummy)
aggdat <- aggregate(dummy~source+mid+destination,dat,sum)
Lo que he probado hasta ahora

Puedo construir un Sankey con 2 variables bien si solo tengo un origen y un destino, pero no un punto medio:

aggdat <- aggregate(dummy~source+destination,dat,sum)

library(googleVis)

p <- gvisSankey(aggdat,from="source",to="destination",weight="dummy")
plot(p)

El código produce esto:

Pregunta

¿Cómo modifico?

p <- gvisSankey(aggdat,from="source",to="destination",weight="dummy")

aceptar elmid variable también?

Respuestas a la pregunta(1)

Su respuesta a la pregunta