All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jetbrains.kotlinx.kandy.dsl.internal.BindingHandler.kt Maven / Gradle / Ivy

The newest version!
package org.jetbrains.kotlinx.kandy.dsl.internal

import org.jetbrains.kotlinx.kandy.ir.aes.Aes
import org.jetbrains.kotlinx.kandy.ir.bindings.*
import org.jetbrains.kotlinx.kandy.ir.scale.PositionalFreeScale

/**
 * The class responsible for handling bindings. It is used by builders in which bindings are made.
 */
internal open class BindingHandler(private val datasetBuilderAccessor: () -> DatasetBuilder) {
    val bindingCollector: BindingCollector = BindingCollector()
    var firstMapping = true
    val datasetBuilder: DatasetBuilder
        get() = datasetBuilderAccessor()

    open fun checkMappingSourceSize(size: Int) {
        val rowsCount = datasetBuilder.rowsCount()
        if (rowsCount == 0) {
            return
        }
        if (rowsCount != size) {
            error("Unexpected size of mapping source: excepted $rowsCount, but received $size")
        }
    }

    /**
     * Adds a [non-positional setting][NonPositionalSetting] with the given aes and value.
     *
     * @param aes the aesthetic attribute (aes) to associate with the non-positional setting.
     * @param value the value of the setting.
     * @return the newly created [NonPositionalSetting] object with the provided aes and value.
     */
    fun  addNonPositionalSetting(
        aes: Aes,
        value: DomainType
    ): NonPositionalSetting {
        return NonPositionalSetting(aes, value).also {
            bindingCollector.settings[aes] = it
        }
    }

    /**
     * Adds a [positional setting][PositionalSetting] with the given aes and value.
     *
     * @param aes the aesthetic attribute (aes) to associate with the positional setting.
     * @param value the value of the setting.
     * @return the newly created [PositionalSetting] object with the provided aes and value.
     */
    fun  addPositionalSetting(aes: Aes, value: DomainType): PositionalSetting {
        return PositionalSetting(aes, value).also {
            bindingCollector.settings[aes] = it
        }
    }

    /**
     * Creates and adds a [positional mapping][PositionalMapping] for a given aesthetic attribute
     * ([aes]) and [values].
     *
     * @param aes the aesthetic attribute (aes) to be mapped.
     * @param values the list of values to be mapped.
     * @param name the name of the mapping (optional, defaults to the name of the aes).
     * @param parameters the positional mapping parameters (optional).
     * @return the created [positional mapping][PositionalMapping].
     */
    fun  addPositionalMapping(
        aes: Aes, values: List, name: String?, parameters: PositionalMappingParameters?
    ): PositionalMapping {
        checkMappingSourceSize(values.size)
        val columnID = datasetBuilder.addColumn(values, name ?: aes.name)
        return PositionalMapping(aes, columnID, parameters).also {
            bindingCollector.mappings[aes] = it
        }.also {
            firstMapping = false
        }
    }

    /**
     * Creates and adds a [positional mapping][PositionalMapping] for a given aesthetic attribute
     * ([aes]), [columnID], and [parameters].
     *
     * @param aes the aesthetic attribute (aes) to be mapped.
     * @param columnID the column ID from dataset to be mapped.
     * @param parameters the positional mapping parameters (optional).
     * @return the created [positional mapping][PositionalMapping].
     */
    fun  addPositionalMapping(
        aes: Aes, columnID: String, parameters: PositionalMappingParameters?
    ): PositionalMapping {
        val newColumnID = datasetBuilder.takeColumn(columnID)
        return PositionalMapping(aes, newColumnID, parameters).also {
            bindingCollector.mappings[aes] = it
        }.also {
            firstMapping = false
        }
    }

    /**
     * Creates and adds a [non-positional mapping][NonPositionalMapping] for a given aesthetic attribute
     * ([aes]) and [values].
     *
     * @param aes the aesthetic attribute (aes) to be mapped.
     * @param values the list of values to be mapped.
     * @param name the name of the mapping (optional, defaults to the name of the aes).
     * @param parameters the non-positional mapping parameters (optional).
     * @return the created [non-positional mapping][NonPositionalMapping].
     */
    fun  addNonPositionalMapping(
        aes: Aes,
        values: List,
        name: String?,
        parameters: NonPositionalMappingParameters?
    ): NonPositionalMapping {
        checkMappingSourceSize(values.size)
        val columnID = datasetBuilder.addColumn(values, name ?: aes.name)
        return NonPositionalMapping(aes, columnID, parameters).also {
            bindingCollector.mappings[aes] = it
        }.also {
            firstMapping = false
        }
    }

    /**
     * Creates and adds a [non-positional mapping][NonPositionalMapping] for a given aesthetic attribute
     * ([aes]), [columnID], and [parameters].
     *
     * @param aes the aesthetic attribute (aes) to be mapped.
     * @param columnID the column ID from dataset to be mapped.
     * @param parameters the non-positional mapping parameters (optional).
     * @return the created [non-positional mapping][NonPositionalMapping].
     */
    fun  addNonPositionalMapping(
        aes: Aes,
        columnID: String,
        parameters: NonPositionalMappingParameters?
    ): NonPositionalMapping {
        val newColumnID = datasetBuilder.takeColumn(columnID)
        return NonPositionalMapping(aes, newColumnID, parameters).also {
            bindingCollector.mappings[aes] = it
        }.also {
            firstMapping = false
        }
    }

    /**
     * Adds a [non-positional mapping][NonPositionalMapping] for a given positional aesthetic attribute
     * ([aes]) and [parameters] to [binding collector][BindingCollector].
     *
     * @param aes the positional aesthetic attribute (aes) to be mapped.
     * @param parameters the positional mapping parameters (optional).
     */
    fun  addPositionalFreeScale(
        aes: Aes,
        parameters: PositionalMappingParameters
    ) {
        bindingCollector.freeScales[aes] = PositionalFreeScale(aes, parameters)
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy