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

com.raquo.laminar.codecs.Codec.scala Maven / Gradle / Ivy

package com.raquo.laminar.codecs

/** This trait represents a way to encode and decode HTML attribute or DOM property values.
 *
 * It is needed because attributes encode all values as strings regardless of their type,
 * and then there are also multiple ways to encode e.g. boolean values. Some attributes
 * encode those as "true" / "false" strings, others as presence or absence of the element,
 * and yet others use "yes" / "no" or "on" / "off" strings, and properties encode booleans
 * as actual booleans.
 *
 * Scala DOM Types hides all this mess from you using codecs. All those pseudo-boolean
 * attributes would be simply `Attr[Boolean](name, codec)` in your code.
 * */
trait Codec[ScalaType, DomType] {

  /** Convert the result of a `dom.Node.getAttribute` call to appropriate Scala type.
   *
   * Note: HTML Attributes are generally optional, and `dom.Node.getAttribute` will return
   * `null` if an attribute is not defined on a given DOM node. However, this decoder is
   * only intended for cases when the attribute is defined.
   */
  def decode(domValue: DomType): ScalaType

  /** Convert desired attribute value to appropriate DOM type. The resulting value should
   * be passed to `dom.Node.setAttribute` call, EXCEPT when resulting value is a `null`.
   * In that case you should call `dom.Node.removeAttribute` instead.
   *
   * We use `null` instead of [[Option]] here to reduce overhead in JS land. This method
   * should not be called by end users anyway, it's the consuming library's job to
   * call this method under the hood.
   */
  def encode(scalaValue: ScalaType): DomType
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy