Class: Coradoc::Html::Converters::Term
- Defined in:
- lib/coradoc/html/converters/term.rb
Overview
Converter for CoreModel::InlineElement (term) elements
Terms are used in definition lists and can have types like “acronym”, “symbol”, “preferred”, etc.
Class Method Summary collapse
-
.to_coradoc(node, _state = {}) ⇒ Object
Convert HTML to CoreModel::InlineElement (term).
-
.to_html(term, _state = {}) ⇒ Object
Convert CoreModel::InlineElement (term) to HTML.
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 = {}) ⇒ Object
Convert HTML to CoreModel::InlineElement (term)
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'lib/coradoc/html/converters/term.rb', line 13 def self.to_coradoc(node, _state = {}) attrs = extract_node_attributes(node) term_text = node.text.strip term_type = attrs[:'data-term-type'] || attrs[:class]&.split&.find do |c| c.start_with?('term-') end&.sub('term-', '') Coradoc::CoreModel::InlineElement.new( format_type: 'term', content: term_text, target: term_type || 'term', metadata: { lang: attrs[:lang] || 'en', render_text: attrs[:'data-render-text'] } ) end |
.to_html(term, _state = {}) ⇒ Object
Convert CoreModel::InlineElement (term) to HTML
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
# File 'lib/coradoc/html/converters/term.rb', line 33 def self.to_html(term, _state = {}) term_text = term.content || '' term_type = term.target || 'term' render_text = term.&.dig(:render_text) # Use render_text if available, otherwise use term display_text = render_text&.strip&.empty? ? false : render_text display_text ||= term_text # Build class attribute classes = ['term', "term-#{escape_attribute(term_type)}"] class_attr = classes.join(' ') # Build data attributes data_attrs = [] data_attrs << %( data-term-ref="#{escape_attribute(term_text)}") lang = term.&.dig(:lang) data_attrs << %( lang="#{escape_attribute(lang)}") if lang && lang != 'en' # Render as a styled span with term reference %(<span class="#{class_attr}"#{data_attrs.join}>#{escape_html(display_text)}</span>) end |