# frozen_string_literal: true require "htmlentities" require_relative "unary_function" module Plurimath module Math module Function class Text < UnaryFunction PARSER_REGEX = %r{unicode\[:(?\w{1,})\]}.freeze def to_asciimath "\"#{parse_text('asciimath') || parameter_one}\"" end def to_mathml_without_math_tag text = Utility.ox_element("mtext") return text unless parameter_one text << (parse_text("mathml") || parameter_one) end def to_latex text_value = parse_text("latex") || parameter_one "\\text{#{text_value}}" end def to_html parse_text("html") || parameter_one end def to_omml_without_math_tag(_display_style) text = Utility.ox_element("t", namespace: "m") text << (parse_text("omml") || parameter_one) [text] end def insert_t_tag(display_style) r_tag = Utility.ox_element("r", namespace: "m") Utility.update_nodes(r_tag, to_omml_without_math_tag(display_style)) [r_tag] end def validate_function_formula false end def to_asciimath_math_zone(spacing, _, _) "#{spacing}#{to_asciimath} text\n" end def to_latex_math_zone(spacing, _, _) "#{spacing}#{to_asciimath} text\n" end def to_mathml_math_zone(spacing, _, _) "#{spacing}\"#{dump_mathml(self)}\" text\n" end def to_omml_math_zone(spacing, _, _, display_style:) "#{spacing}\"#{dump_omml(self, display_style)}\" text\n" end def value parameter_one end protected def symbol_value(unicode) Mathml::Constants::UNICODE_SYMBOLS.invert[unicode] || Mathml::Constants::SYMBOLS.invert[unicode] end def parse_text(lang) html_value = first_value(lang).dup html_value = html_value&.gsub(PARSER_REGEX) do |_text| last_match = Regexp.last_match case lang when "mathml", "html", "omml" symbol_value(last_match[:unicode]) else last_match[:unicode] end end html_value end def first_value(lang) if lang == "omml" entities = HTMLEntities.new entities.encode( entities.decode(parameter_one&.gsub(/ /, " ")), :hexadecimal, ) else parameter_one end end end end end end