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

r.pamflet-knockoff_2.10.0.6.0.source-code.headers.scala Maven / Gradle / Ivy

The newest version!
package pamflet

import scala.xml.Node
import com.tristanhunt.knockoff._
import java.net.URLEncoder

trait IdentifiedHeaders extends Discounter { self: TextWriter =>
  def headerText( spans : Seq[Span] ) : String = {
    val stringWriter = new java.io.StringWriter
    spans.map( self.spanToText(_)(stringWriter) )
    return stringWriter.toString        
  }
  override def headerToXHTML = (level, spans) => {
    val name = BlockNames.encode(BlockNames.textOf(spans))
    val spanned = spans.map(spanToXHTML)
    val anchored = spanned ++
       
    level match {
      case 1 => 

{ anchored }

case 2 =>

{ anchored }

case 3 =>

{ anchored }

case 4 =>

{ anchored }

case 5 =>
{ anchored }
case 6 =>
{ spanned }
case _ =>
{ spanned }
} } } object BlockNames { /** Do not generate ids for higher levels than this */ val maxLevel = 5 def encode(str: String) = java.net.URLEncoder.encode(str.trim(), "utf-8") def fragment(str: String) = "#" + encode(str) def textOf(spans: Seq[Span]) = spans.flatMap { case t: Text => Seq(t.content) case h: HTMLSpan => Seq(h.html) case _ => Seq() }.mkString("") def name(blocks: Seq[Block]) = blocks.view.collect { case h: Header => textOf(h.spans) }.headOption.getOrElse { "Untitled" } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy