# 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