Class: Coradoc::Html::Converters::TextElement

Inherits:
Base
  • Object
show all
Defined in:
lib/coradoc/html/converters/text_element.rb

Overview

Converter for TextElement (plain text content) In CoreModel, text is handled as plain strings

Class Method Summary collapse

Methods inherited from Base

build_class_attribute, build_element, build_html_attributes, convert_content_to_html, convert_element_to_core, convert_node_to_core, escape_attribute, escape_html, extract_model_attributes, extract_node_attributes, extract_text_fallback, find_converter_class_by_name, find_converter_for_model, handle_unknown_content, render_core_abbreviation, render_core_annotation_block, render_core_bibliography, render_core_bibliography_entry, render_core_block, render_core_block_image, render_core_definition_item, render_core_definition_list, render_core_footnote, render_core_footnote_reference, render_core_inline_element, render_core_inline_image, render_core_list_block, render_core_list_item, render_core_span, render_core_structural_element, render_core_table_cell, render_core_table_row, render_core_term, render_core_toc, render_core_toc_entry, resolve_block_semantic_type, resolve_format_specific_semantic, transform_to_coremodel, treat_children

Class Method Details

.to_coradoc(node, state = {}) ⇒ String

Convert HTML text node to String

Parameters:

  • node (Nokogiri::XML::Node, String)

    HTML text node or string

  • state (Hash) (defaults to: {})

    Conversion state

Returns:

  • (String)

    Plain text



14
15
16
17
18
# File 'lib/coradoc/html/converters/text_element.rb', line 14

def to_coradoc(node, state = {})
  text = node.is_a?(String) ? node : node.text
  text = unescape_html(text) unless state[:skip_unescape]
  text
end

.to_html(model, state = {}) ⇒ String

Convert CoreModel content to HTML

Parameters:

  • model (String, CoreModel)

    Text content

  • state (Hash) (defaults to: {})

    Conversion state

Returns:

  • (String)

    Plain text (escaped)



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/coradoc/html/converters/text_element.rb', line 24

def to_html(model, state = {})
  # Handle both string and model with content attribute
  content = model.content || model

  return '' if content.nil?

  # Process content based on type
  case content
  when String
    escape_html(content)
  when Array
    content.map { |item| convert_content_to_html(item, state) }.join
  else
    escape_html(content.to_s)
  end
end