Compare commits

..

No commits in common. "f238b038332fbc7ee226523fb528e132a78f6f12" and "e5882d01f8e512a59c45a77099a189814c32c16e" have entirely different histories.

3 changed files with 17 additions and 31 deletions

View File

@ -10,7 +10,7 @@ val dataforgeVersion by extra("0.8.0")
allprojects {
group = "space.kscience"
version = "0.4.2-dev-1"
version = "0.4.1"
}
subprojects {

View File

@ -8,7 +8,6 @@ import org.w3c.dom.Element
import space.kscience.dataforge.meta.Meta
import space.kscience.dataforge.names.Name
import space.kscience.visionforge.Vision
import kotlin.reflect.cast
/**
* An [ElementVisionRenderer] that could be used directly in Compose-html as well as a stand-alone renderer
@ -26,24 +25,4 @@ public interface ComposeHtmlVisionRenderer : ElementVisionRenderer {
}
public companion object
}
/**
* A compose-html renderer for a vision of given type
*/
public inline fun <reified T : Vision> ComposeHtmlVisionRenderer(
acceptRating: Int = ElementVisionRenderer.DEFAULT_RATING,
noinline renderFunction: @Composable DOMScope<Element>.(name: Name, vision: T, meta: Meta) -> Unit,
): ComposeHtmlVisionRenderer = object : ComposeHtmlVisionRenderer {
override fun rateVision(vision: Vision): Int =
if (vision::class == T::class) acceptRating else ElementVisionRenderer.ZERO_RATING
@Composable
override fun DOMScope<Element>.render(name: Name, vision: Vision, meta: Meta) {
renderFunction(name, T::class.cast(vision), meta)
}
override fun toString(): String = "ElementVisionRender(${T::class.simpleName})"
}
}

View File

@ -9,6 +9,7 @@ import space.kscience.dataforge.meta.Meta
import space.kscience.dataforge.misc.DfType
import space.kscience.dataforge.names.Name
import space.kscience.visionforge.Vision
import kotlin.reflect.KClass
import kotlin.reflect.cast
/**
@ -45,15 +46,16 @@ public interface ElementVisionRenderer {
}
/**
* A browser renderer for a vision of given type
* A browser renderer for element of given type
*/
public inline fun <reified T : Vision> ElementVisionRenderer(
acceptRating: Int = ElementVisionRenderer.DEFAULT_RATING,
noinline renderFunction: TagConsumer<HTMLElement>.(name: Name, vision: T, meta: Meta) -> Unit,
): ElementVisionRenderer = object : ElementVisionRenderer {
public class SingleTypeVisionRenderer<T : Vision>(
public val kClass: KClass<T>,
private val acceptRating: Int = ElementVisionRenderer.DEFAULT_RATING,
private val renderFunction: TagConsumer<HTMLElement>.(name: Name, vision: T, meta: Meta) -> Unit,
) : ElementVisionRenderer {
override fun rateVision(vision: Vision): Int =
if (vision::class == T::class) acceptRating else ElementVisionRenderer.ZERO_RATING
if (vision::class == kClass) acceptRating else ElementVisionRenderer.ZERO_RATING
override fun render(
element: Element,
@ -63,9 +65,14 @@ public inline fun <reified T : Vision> ElementVisionRenderer(
) {
element.clear()
element.append {
renderFunction(name, T::class.cast(vision), meta)
renderFunction(name, kClass.cast(vision), meta)
}
}
override fun toString(): String = "ElementVisionRender(${T::class.simpleName})"
override fun toString(): String = "ElementVisionRender(${kClass.simpleName})"
}
public inline fun <reified T : Vision> ElementVisionRenderer(
acceptRating: Int = ElementVisionRenderer.DEFAULT_RATING,
noinline renderFunction: TagConsumer<HTMLElement>.(name: Name, vision: T, meta: Meta) -> Unit,
): ElementVisionRenderer = SingleTypeVisionRenderer(T::class, acceptRating, renderFunction)